一杯清酒邀明月
天下本无事,庸人扰之而烦耳。
posts - 3121,comments - 209,views - 578万

C# 中在图像上画框,通过鼠标来实现主要有四个消息响应函数MouseDown, MouseMove, MouseUp, Paint重绘函数实现。当鼠标键按下时开始画框,鼠标键抬起时画框结束。

1 Point start; //画框的起始点
2 Point end,//画框的结束点<br>bool blnDraw;//判断是否绘制<br>Rectangel rect;

鼠标按下响应

复制代码
1 private void PictureBox1_MouseDown(object sender, MouseEventArgs e)
2 {
3       start = e.Location;
4       Invalidate();
5       blnDraw = true;
6 }
复制代码

 鼠标移动响应

复制代码
 1 private void PictureBox1_MouseMove(object sender, MouseEventArgs e)
 2 {
 3     if (blnDraw)
 4     {
 5         if (e.Button != MouseButtons.Left)//判断是否按下左键
 6             return;
 7         Point tempEndPoint = e.Location; //记录框的位置和大小
 8         rect.Location = new Point(
 9         Math.Min(start.X, tempEndPoint.X),
10         Math.Min(start.Y, tempEndPoint.Y));
11         rect.Size = new Size(
12         Math.Abs(start.X - tempEndPoint.X),
13         Math.Abs(start.Y - tempEndPoint.Y));
14         PictureBox1.Invalidate();
15      }
16 }       
复制代码

鼠标键抬起响应

private void PictureBox1_MouseUp(object sender, MouseEventArgs e)
 {
    blnDraw = false; //结束绘制
 }

重绘响应

复制代码
 1 private void imageBox1_Paint(object sender, PaintEventArgs e)
 2 {
 3      if (blnDraw)
 4      {
 5          if (imageBox1.Image != null)
 6          {
 7              if (rect != null && rect.Width > 0 && rect.Height > 0)
 8               {
 9                   e.Graphics.DrawRectangle(new Pen(Color.Red, 3),rect);//重新绘制颜色为红色
10                }
11           }
12       }
13  
14 }
复制代码

注意:在绘制中如果导入的图像的SizeMode为StretchImage时,画框后图像会缩放,导致框有可能不在pictureBox中,需要将PictureBox的FunctionMode 修改为Minimum 便可。

posted on   一杯清酒邀明月  阅读(2174)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示