(转载)winform图片标尺控件

2023-11-23 10:11

本文主要是介绍(转载)winform图片标尺控件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近要做个winform的东西,要在里面集成一个类似Windows自带画图的标尺功能,还要能在图片上画矩形框。在网上找了好久也没找到写好的控件,无奈自己做了一个。

目前还有些bug,这里先做个分享。(Ps:很少做winform的东西,做的不好,轻喷。另外欢迎指点。)

由于最后要做的东西的背景是黑的,标尺就画成白的了,有需要的自己改吧。。

直接上代码

using Helper;
using System;
using System.Collections.Generic;
using System.Drawing;
using System.Windows.Forms;namespace UserCtrl
{public partial class RulerControl : UserControl{private double _monitorDPI = 100;/// <summary>/// 用于控制放大倍数/// </summary>private double _multiple = 1;/// <summary>/// 每多少个像素1格/// </summary>public double MonitorDPI{get{return _monitorDPI;}set{_monitorDPI = value;}}    /// <summary>/// X轴偏移位置/// </summary>private float offSetX=0;/// <summary>/// Y轴偏移位置/// </summary>private float offSetY = 0;/// <summary>/// 开始位置X/// </summary>public double XStart{get;set;}/// <summary>/// 开始位置Y/// </summary>public double YStart{get;set;}/// <summary>/// 用户设置的原始图/// </summary>private Image _initImg = null;/// <summary>/// 图片/// </summary>public Image Image{get{return Pic.Image;}set{Pic.Image = value;if (_initImg == null&&value!=null){_initImg = PicHelper.GetNewPic(value, value.Width , value.Height );}}}private Font font = new Font("宋体", 9); //刻度值显示字体public RulerControl(){InitializeComponent();}private void Pic_MouseWheel(object sender, MouseEventArgs e){if (MouseButtons == MouseButtons.Left){return;}Image img = Pic.Image;if (img != null){if (e.Delta >= 0){if (_multiple * 2 > 4)return;_multiple *= 2;}else{if (Pic.Width < this.Width - 50)return;_multiple *= 0.5;if (Pic.Width <= (this.Width - 50)){XStart = 0;YStart = 0;}}DrawRect();AdapterDpi();ReDrawX();ReDrawY();}}private void RulerControl_Paint(object sender, PaintEventArgs e){P1.Height = 50;P1.Width = this.Width - 50;P2.Height = this.Height - 50;P2.Width = 50;P1.Location = new Point(50, 0);P2.Location = new Point(0, 50);PContainer.Location = new Point(50, 50);}private void RulerControl_Resize(object sender, EventArgs e){P1.Height = 50;P1.Width = this.Width - 50;P2.Height = this.Height - 50;P2.Width = 50;P1.Location = new Point(50, 0);P2.Location = new Point(0, 50);PContainer.Location = new Point(50, 50);}/// <summary>/// 重画Y轴/// </summary>private void ReDrawY(){if (P2.BackgroundImage != null){P2.BackgroundImage.Dispose();}Bitmap bmpY = new Bitmap(P2.Width, P2.Height);using (Graphics g = Graphics.FromImage(bmpY)){int originLocation = bmpY.Width - 1;int startY = (int)Math.Ceiling(YStart);offSetY = (float)(MonitorDPI * _multiple * (startY - YStart));for (int i = startY; i <= Math.Ceiling(P2.Height / (MonitorDPI * _multiple) + YStart); i++){float y = (float)(MonitorDPI * _multiple * (i - YStart)) + offSetY;if (y >= 0){PointF start = new PointF(originLocation, y);PointF end = new PointF(originLocation - 3, y);if (i % 5 == 0){end = new PointF(originLocation - 6, y);}if (i % 10 == 0 && i != 0){end = new PointF(originLocation - 12, y);g.DrawString((i*MonitorDPI).ToString(), font, Brushes.White, new PointF(originLocation - 30, y - 5));}g.DrawLine(Pens.White, start, end);}}g.DrawLine(Pens.White, new PointF(originLocation, 0), new PointF(originLocation, bmpY.Height));P2.BackgroundImage = bmpY;}}/// <summary>/// 重画X轴/// </summary>private void ReDrawX(){if (P1.BackgroundImage != null){P1.BackgroundImage.Dispose();}Bitmap bmpX = new Bitmap(P1.Width, P1.Height);using (Graphics g = Graphics.FromImage(bmpX)){int originLocation = bmpX.Height - 1;int startX = (int)Math.Ceiling(XStart);offSetX = (float)(MonitorDPI * _multiple * (startX - XStart));for (int i = startX; i <= Math.Ceiling(P1.Width / (MonitorDPI * _multiple) + XStart); i++){float x = (float)(MonitorDPI * _multiple * (i - XStart)) + offSetX;if (x >= 0){PointF start = new PointF(x, originLocation);PointF end = new PointF(x, originLocation - 3);if (i % 5 == 0){end = new PointF(x, originLocation - 6);}if (i % 10 == 0 && i != 0){end = new PointF(x, originLocation - 12);g.DrawString((i*MonitorDPI).ToString(), font, Brushes.White, new PointF(x - 5, originLocation - 30));}g.DrawLine(Pens.White, start, end);}}g.DrawLine(Pens.White, new PointF(0, originLocation), new PointF(bmpX.Width, originLocation));P1.BackgroundImage = bmpX;}}private void RulerControl_Load(object sender, EventArgs e){P1.Height = 50;P1.Width = this.Width - 50;P2.Height = this.Height - 50;P2.Width = 50;P1.Location = new Point(50, 0);P2.Location = new Point(0, 50);PContainer.Location = new Point(50, 50);ReDrawX();ReDrawY();Pic.MouseWheel += new MouseEventHandler(Pic_MouseWheel);}private void Pic_MouseEnter(object sender, EventArgs e){Pic.Focus();}private void PContainer_Scroll(object sender, ScrollEventArgs e){if (e.ScrollOrientation == ScrollOrientation.HorizontalScroll){XStart = e.NewValue / (MonitorDPI * _multiple);ReDrawX();}else if (e.ScrollOrientation == ScrollOrientation.VerticalScroll){YStart = e.NewValue / (MonitorDPI * _multiple);ReDrawY();}}#region 画图片选定区域bool MouseIsDown = false;Rectangle MouseRect = Rectangle.Empty;private void Pic_MouseDown(object sender, MouseEventArgs e){MouseIsDown = true;MouseRect = new Rectangle(e.X, e.Y, 0, 0);Rectangle rec = new Rectangle(0, 0,Math.Min(PContainer.ClientRectangle.Width, Pic.ClientRectangle.Width),Math.Min(PContainer.ClientRectangle.Height, Pic.ClientRectangle.Height));Cursor.Clip = PContainer.RectangleToScreen(rec);}private void Pic_MouseMove(object sender, MouseEventArgs e){if (MouseIsDown){MouseRect.Width = e.X - MouseRect.Left;MouseRect.Height = e.Y - MouseRect.Top;if (MouseRect.Width > 0 && MouseRect.Height > 0){Rectangle rect = Pic.RectangleToScreen(MouseRect);ControlPaint.DrawReversibleFrame(rect, Color.White, FrameStyle.Dashed);}Pic.Refresh();}}private void Pic_MouseUp(object sender, MouseEventArgs e){if (MouseIsDown){MouseRect.Width = e.X - MouseRect.Left;MouseRect.Height = e.Y - MouseRect.Top;using (Graphics g = Graphics.FromImage(Pic.Image)){g.DrawRectangle(new Pen(Color.Red), MouseRect);}Pic.Refresh();MouseIsDown = false;if ((int)(MouseRect.Width * _multiple) > 0 && (int)(MouseRect.Height * _multiple) > 0){list.Add(new Rectangle((int)(MouseRect.X / _multiple),(int)(MouseRect.Y / _multiple),(int)(MouseRect.Width / _multiple),(int)(MouseRect.Height / _multiple)));}MouseRect = Rectangle.Empty;Cursor.Clip = Rectangle.Empty;}}#endregionpublic List<Rectangle> list = new List<Rectangle>();private void Pic_DoubleClick(object sender, EventArgs e){MouseEventArgs ev = e as MouseEventArgs;List<Rectangle> temp = new List<Rectangle>();foreach (Rectangle item in list){if (ev.X > item.X * _multiple && ev.X < item.X * _multiple + item.Width * _multiple &&ev.Y > item.Y * _multiple && ev.Y < item.Y * _multiple + item.Height * _multiple){temp.Add(item);}}foreach (Rectangle item in temp){list.Remove(item);}DrawRect();}/// <summary>/// 把list中的框画到图片中/// </summary>private void DrawRect(){if (Pic.Image != _initImg)Pic.Image.Dispose();Pic.Image = PicHelper.GetNewPic(_initImg, (int)(_initImg.Width * _multiple), (int)(_initImg.Height * _multiple));using (Graphics g = Graphics.FromImage(Image)){foreach (Rectangle item in list){g.DrawRectangle(new Pen(Color.Red), new Rectangle((int)(item.X * _multiple),(int)(item.Y * _multiple),(int)(item.Width * _multiple),(int)(item.Height * _multiple)));}}Pic.Refresh();}private void AdapterDpi(){if (MonitorDPI * _multiple < 10){MonitorDPI *= 2;}if (MonitorDPI * _multiple > 20){MonitorDPI /= 2;}}}
}

下载链接:http://download.csdn.net/download/p690075426/10142184

 

---------------------
作者:ydp1991
来源:博客园
原文:https://www.cnblogs.com/ydp1991/p/7955382.html

 

转载于:https://www.cnblogs.com/cnwuchao/p/10586754.html

这篇关于(转载)winform图片标尺控件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/417201

相关文章

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel

Qt中QGroupBox控件的实现

《Qt中QGroupBox控件的实现》QGroupBox是Qt框架中一个非常有用的控件,它主要用于组织和管理一组相关的控件,本文主要介绍了Qt中QGroupBox控件的实现,具有一定的参考价值,感兴趣... 目录引言一、基本属性二、常用方法2.1 构造函数 2.2 设置标题2.3 设置复选框模式2.4 是否

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例