自定义控件实现图像的显示和放大缩小,平移,右击菜单选择“自适应窗口”“保存图像”

Posted mazai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自定义控件实现图像的显示和放大缩小,平移,右击菜单选择“自适应窗口”“保存图像”相关的知识,希望对你有一定的参考价值。

前面介绍了2个控件组合在一起实现,对PictureBox控件的操作,今天我们自己新建一个控件来自己用。

新建一个Windows窗体解决方案,添加“用户控件”,把PictureBox控件拖到指定的区域,给我们要自己定义的控件改下名字UserControl_Display

界面就完成了,现在我们要自定义的控件添加事件和右击菜单(contextMenuStrip1)控件

 

  1 using System;
  2 using System.Collections.Generic;
  3 using System.ComponentModel;
  4 using System.Drawing;
  5 using System.Data;
  6 using System.Linq;
  7 using System.Text;
  8 using System.Threading.Tasks;
  9 using System.Windows.Forms;
 10 
 11 namespace _自定义控件显示图片
 12 {
 13     public partial class UserControl_Display : UserControl
 14     {
 15 
 16         public System.Drawing.Point mouseDownPoint;//存储鼠标焦点的全局变量
 17         public bool isSelected = false;
 18         public int width;
 19         public int height;
 20      
 21 
 22         public UserControl_Display()
 23         {
 24             InitializeComponent();
 25         }
 26 
 27         //这个是显示图片用的
 28         public  void Display(Image  image)
 29         {
 30             pictureBox1.Image = image;
 31 
 32             width = pictureBox1.Width;//控件的原始大小保存一下,恢复的时候用
 33             height = pictureBox1.Height;      
 36         }
 37 
 38          // 在MouseUp处获知鼠标是否松开,终止拖动操作;
 39         private void pictureBox1_MouseUp(object sender, MouseEventArgs e)
 40         {
 41             isSelected = false;
 42         }
 43 
 44         private void pictureBox1_MouseEnter(object sender, EventArgs e)
 45         {
 46             pictureBox1.Focus();
 47             pictureBox1.Cursor = Cursors.SizeAll;
 48         }
 49 
 50         //在MouseDown处获知鼠标是否按下,并记录下此时的鼠标坐标值;
 51         private void pictureBox1_MouseDown(object sender, MouseEventArgs e)
 52         {
 53             if (e.Button == MouseButtons.Left)
 54             {
 55                 mouseDownPoint.X = Cursor.Position.X;  //注:全局变量mouseDownPoint前面已定义为Point类型  
 56                 mouseDownPoint.Y = Cursor.Position.Y;
 57                 isSelected = true;
 58             }

 61         }
 62 
 63         //图片平移,在MouseMove处添加拖动函数操作
 64         private void pictureBox1_MouseMove(object sender, MouseEventArgs e)
 65         {
 66             if (isSelected && IsMouseInPanel())//确定已经激发MouseDown事件,和鼠标在picturebox的范围内
 67             {
 68                 this.pictureBox1.Left = this.pictureBox1.Left + (Cursor.Position.X - mouseDownPoint.X);
 69                 this.pictureBox1.Top = this.pictureBox1.Top + (Cursor.Position.Y - mouseDownPoint.Y);
 70                 mouseDownPoint.X = Cursor.Position.X;
 71                 mouseDownPoint.Y = Cursor.Position.Y;
 72             }
 73         }
 74 
 75         private void pictureBox1_MouseWheel(object sender, MouseEventArgs e)
 76         {
 77             double scale = 1;
 78             if (pictureBox1.Height > 0)
 79             {
 80                 scale = (double)pictureBox1.Width / (double)pictureBox1.Height;
 81             }
 82             pictureBox1.Width += (int)(e.Delta * scale);
 83             pictureBox1.Height += e.Delta;
 84         }
 85 
 86 
 87         private bool IsMouseInPanel()
 88         {
 89             if (this.pictureBox1.Left < PointToClient(Cursor.Position).X
 90                     && PointToClient(Cursor.Position).X < this.pictureBox1.Left
 91                     + this.pictureBox1.Width && this.pictureBox1.Top
 92                     < PointToClient(Cursor.Position).Y && PointToClient(Cursor.Position).Y
 93                     < this.pictureBox1.Top + this.pictureBox1.Height)
 94             {
 95                 return true;
 96             }
 97             else
 98             {
 99                 return false;
100             }
101 
102         }
103 
104 
105         /// <summary>
106         /// 右击菜单的保存图像
107         /// </summary>
108         /// <param name="sender"></param>
109         /// <param name="e"></param>
110         private void SaveImage_Click(object sender, EventArgs e)
111         {
112             Image image = this.pictureBox1.Image;
113             string imageName = DateTime.Now.ToString("HH时MM分SS秒") + ".bmp";
114             image.Save(@imageName);
115         }
116 
117         //右击菜单的图像适应控件的大小
118         private void ImageFitPictureBox_Click(object sender, EventArgs e)
119         { 
120             pictureBox1.Width = width;//控件的大小恢复
121             pictureBox1.Height = height;
122 
123             //PictureBox控件的位置
124             pictureBox1.Left = 1;
125             pictureBox1.Top = 1;       
126         }
127     }
128 }

 

以上是关于自定义控件实现图像的显示和放大缩小,平移,右击菜单选择“自适应窗口”“保存图像”的主要内容,如果未能解决你的问题,请参考以下文章

Android自定义控件之可平移、缩放、旋转图片控件

从flex3中的自定义按钮调用放大和缩小上下文菜单

Android自定义ImageView实现图片缩放滑动,双击放大缩小,多点触控缩放

Android自定义ImageView实现图片缩放滑动,双击放大缩小,多点触控缩放

arcengine用c#开发怎么实现选择属性表中的一项属性平移至地图显示?

CAD图形的缩放——视区缩放教程