C#做的浏览图片的程序

 最近在做一个关于图片标记的一个程序,其中里面就涉及到浏览图片的问题。浏览图片需要完成图片的移动、图片的缩放等操作。源代码先贴到后面吧,还有点地方需要修改。

一、窗体设计:

浏览图片的程序是这样搭建起来的:

在窗体中放置一个Panel组件,在Panel组件中放置一个PictureBox(我给它取名ImageBox,以下就用ImageBox这个名字代替这个控件了)组件、一个横向滚动条(hScorllBar)组件、一个纵向滚动条(vScorllBar)组件。其中,两个滚动条放置到位后将它们的Anchor属性分别设置成“Bottom, Left, Right”和“Top, Bottom, Right”。Image组件为了编辑方便可以现在Panel中随意放置,但在初始化或在加载图片时要将它的Location设置为“0,0”或根据ImageBoxPanel的大小将ImageBox居中放置在Panel中。这样才能保证图片显示时更加规范和专业。

为了在窗口缩放时Panel组件能够自动调整大小,所以把Panel组件的Anchor属性设置为“Top, Bottom, Left, Right”。

为了图片的缩放在显示时不变形,这里把ImageBoxSizeMode属性设置成“zoom”。

为了功能的实现,在窗体中还添加了openFileDialog控件和一个ToolMenu(上面添加一个按钮(手型,名叫moveButton),功能后续有介绍)。

最后窗体的布局如图所示。

二、程序功能的实现

(一)图片的载入

为了让程序简单点,图片的载入就通过双击Panel组件(DoubleClik事件)来完成。鼠标双击时,打开一个openFileDialog,通过openFileDialog获取图片文件的路径,并将图片加载到imageBox中。

当然载入图片的操作还不仅仅局限于此。这里我们还要做几件事:

1)根据显示图片的大小设置imageBox的大小(WidthHeight

本程序里让imageBox的大小与原图的大小一致。

2)判断是否需要显示滚动条以及设置滚动条的Maximum属性。

当显示的imageBox某一个方向的尺寸没有panel大时,就不需要显示该方向的滚动条;

某方向上滚动条显示时,它的Maximum应该为imageBox在该方向上的尺寸减去panel在该方向上的尺寸,再减去另一个方向上滚动条的尺寸(如果这个滚动条显示时)。

通过完成这两步的操作后,图片载入工作就算完成了。

(二)图片的移动

图片的移动在该程序中可以通过三种方式完成:

1、用鼠标拖动滚动条实现图片的移动

这是最简单的一种方式。只要在两个滚动条的ValueChanged事件中让对应方向上imageBox的坐标等于滚动条Value值就可以了。

2、通过鼠标拖拽图片实现图片的移动

这里面主要对imageBoxMouseDownMouseMoveMouseUp三个鼠标事件进行处理。而处理的对象当然就是imageBoxLocation属性和滚动条的Value属性了。

1MoveButton

这里面还要用到上面提到的那个手型按钮(moveButton),就先从这个按钮讲起吧。它主要实现是否开启用鼠标拖拽图片移动的功能:当它被按下时,拖拽功能开启,反之则否。至于它的操作就在简单不过了:

moveButton.Checked = !moveButton.Checked;

2imageBoxMouseDown事件:

这个事件为鼠标拖拽实现图片的移动提供了一个先决条件,即:只有在鼠标被按下时移动鼠标才能移动图片,鼠标若没有被按下,则移动鼠标不能提动图片。这就需要声明一个窗体类Form1的一个变量来反映鼠标是否被按下。程序利用到的变量是private bool isMouseDown = false;

这个事件所要完成的第二个任务是记录鼠标按下时鼠标在imageBox中的坐标,作为后面移动图片的参考。程序中依然用在窗体类中声明的变量private Point StartP = new Point(0, 0);来实现这个坐标的记录。

3imageBoxMouseMove事件:

这个事件是处理的核心,也比较复杂。首先判断移动功能是否开启,在判断鼠标是否被按下。当然这两个步骤可以在一个if语句中完成。当满足这两个条件后,就进入实际的处理阶段了。处理阶段主要分为两个步骤:

A.计算出所需的移动量,并根据移动量是否合法(图片的移动是有范围的)来设定imageBox的坐标。处理过程如下:

a只需要将现在鼠标在imageBox中的坐标与刚才记录的起点坐标比较一下,计算出此次imageBox所需的移动量;

b在判断移动后的坐标是否合法;

c根据合理性设定imageBox的坐标。

B.根据imageBoxpanel的尺寸确定是否显示相应的滚动条,并设定滚动条的Value。设定的方法和步骤基本和载入图片的过程类似,只是这里要根据imageBox的位置来设定滚动条的Value了。

4imageBoxMouseUp事件:

这个功能中最简单的事件。这里只需要判定鼠标是否按下的变量isMouseDown置成False就可以了,防止一次鼠标按下后永远鼠标的移动永远处于拖拽状态。

3、通过鼠标滚轮实现图片的移动

这里面只要依托imageBoxMouseWheelKeyDownKeyUp事件来实现。

这里另外提一下:这三个事件很奇怪,在pictureBox属性栏的事件列表中并不能找到它们的身影,然而它们却是可用的。具体方法是打开“*.Designer.cs”文件(*代表窗体原文件的名称),在private void InitializeComponent()函数中找到设置pictureBox属性的地方,在后面手动添加代码:

this.imageBox.KeyDown += new System.Windows.Forms.KeyEventHandler (this.imageBox_KeyDown);

this.imageBox.KeyUp += new System.Windows.Forms.KeyEventHandler (this.imageBox_KeyUp);

this.imageBox.MouseWheel += new System.Windows.Forms.MouseEventHandler (this.imageBox_MouseWheel);

并在“*.cs”窗体源文件中实现以上三个函数:

private void imageBox_KeyDown(object sender, KeyEventArgs e){}

private void imageBox_KeyUp(object sender, KeyEventArgs e){}

private void imageBox_MouseWheel(object sender, MouseEventArgs e){}

麻麻烦烦地算是把函数声明出来了。真不知道微软在这里搞什么鬼。

知道这三个函数后就先说一下思路:鼠标滚轮在本程序利要实现三个功能,分别是图片的处置方向移动、图片的水平方向移动和图片的缩放(下面会讲到),而区别这三个动作是凭借在滚动鼠标滚轮时是否有Ctrl键、Shift键按下。若没有按下这两个键滚动滚轮,则执行图片上下运动;若按下Shift键滚动滚轮,则执行图片左右移动;若按下Ctrl键滚动滚轮,则执行图片的缩放。

KeyDownKeyUp两个事件处理结果类似,就是判断有哪个按键按下。其中KeyDown会根据按键的不同设定一个窗体类的变量private int keyAction = 0;的值,从而区分是哪个按键被按下;而KeyUp则负责将keyAction值置成代表一个没有按键被按下的值。

MouseWheel事件中,首先根据keyAction的不同来做不同的动作。横向移动与纵向移动原理相同。只需要读取鼠标滚轮的滚动量(e.Delta),并将其设置为imageBox的移动量(当饭还要保证移动后的坐标合法),在适当设定滚动条是否显示及其Value值就可以了。

(三)图片的缩放

本程序中专门为图片的缩放写了一个函数:

private void zoom(Point center, int zoomIndexBy1000)

这个程序能够实现图片的center点在panel中不动,而实现缩放,缩放的倍数为zoomIndexBy1000/1000。之所以缩放因子被放大了1000倍是为了保证缩放中的精度(相当于计算中保留了小数点的后三位,到最后的结果再小数省略,保证计算精度)。下面讨论缩放功能的具体实现:

1imageBox的缩放

在缩放过程中始终以imageBox.Width为基准进行,再通过图片的横纵比计算出imageBox.Height的大小。这样做就有效避免了两个方向独立缩放使得由于误差积累,经多次缩放后图片的横纵比与imageBox的横纵比不一致。这里的横纵比依然采取乘1000的方式,以减小计算误差。

 

2缩放后imageBox的定位

下面先讲一下图片缩放的数学模型。这里面只有几个简单的几何关系,其实很简单。

模型如下图所示。xycenter在缩放前的imageBox里的坐标;x1x2分别是缩放后在imageBox左右延伸出去的距离;y1y2分别是缩放后在imageBox上下延伸出去的距离。可知

x1+x2=imageBox.Width缩放后- imageBox.Width缩放前

y1+y2=imageBox.Height缩放后- imageBox.Height缩放前

x1/(x1+x2)=x/ imageBox.Width缩放前

y1/(y1+y2)=y/ imageBox.Height缩放前

这样就可以通过imageBox缩放前后的尺寸以及中心点的坐标得到其缩放后位置的位移x1x2

x1=x*(imageBox.Height缩放后- imageBox.Height缩放前)/imageBox.Width缩放前

y1=y*(imageBox.Height缩放后-imageBox.Height缩放前) /imageBox.Height缩放前

通过这个数学模型,编程实现已经不成问题了,这里就不多说了。

3设置滚动条是否可见滚动条的Maximum以及Value值。

前面已有相关叙述,这里就不多讲了。

以上是针对缩放函数的,而在imageBoxMouseWheel中就只是实现了判段Ctrl键是否被按下,若按下则执行缩放。

这里只检测鼠标滚轮是正向滚动还是反向滚动。正向滚动放大,每次放大到原来的1.1倍(zoomIndexBy1000=1100);正向滚动缩小,每次放大到原来的0.9倍(zoomIndexBy1000=900)。

(四)窗体缩放

在窗体缩放过程中,横向和纵向都各有如图所示的四种情况,并且横向和纵向的情况可能出现交叉(横向对应情况2,纵向可能对应情况4。把两个方向独立开,就能画出这种情况)。针对不同情况,所做的处理不同。为了处理问题方便,在窗体缩放过程中将横向和纵向分开处理。

这里仅就横向问题展开讨论(纵向问题用同样方式处理即可)。

1所示情况:imageBox完全在panel中;窗体缩放后将imageBox置于panel横向中心。

2所示情况:imageBoxpanel大,但imageBox有没有完全填充panel,右侧有剩余;窗体缩放后imageBox右侧与panel右侧取齐。

3所示情况:与图2类似,只是左侧有剩余;窗体缩放后imageBox左侧与panel左侧取齐。

4所示情况:imageBoxpanel大,且充满panel;窗体缩放后保证窗体横向显示中心的图样不变。

具体数学关系这里就不再详细推到了,可以看我的程序。

另外在需要滚动条的时候还要注意调整滚动条,尤其这里要调整滚动条的Maximum值。

 

好了,我做的工作基本都说完了。

下面我打算把这些工作做成一个图像浏览的控件。名字都想好了,就叫ImageView。有时间一定把它完成。

啊!都凌晨4点了,该睡了。

Form1.cs

Code:
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.ComponentModel;  
  4. using System.Data;  
  5. using System.Drawing;  
  6. using System.Linq;  
  7. using System.Text;  
  8. using System.Windows.Forms;  
  9.   
  10. namespace ImageView  
  11. {  
  12.     public partial class Form1 : Form  
  13.     {  
  14.         private Point StartP = new Point(0, 0);  
  15.         private bool isMouseDown = false;  
  16.         private Point panelOldSize = new Point(0, 0);  
  17.         private int imgIndexBy1000 = 0;  
  18.         private int keyAction = 0;  
  19.   
  20.         public Form1()  
  21.         {  
  22.             InitializeComponent();  
  23.             //记录panel1的size  
  24.             panelOldSize.X = panel1.Width;  
  25.             panelOldSize.Y = panel1.Height;  
  26.         }  
  27.         /// <summary>  
  28.         /// 图片缩放  
  29.         /// </summary>  
  30.         /// <param name="center">缩放中心点</param>  
  31.         /// <param name="zoomIndexBy1000">缩放倍率的1000倍</param>  
  32.         private void zoom(Point center, int zoomIndexBy1000)  
  33.         {  
  34.             //记录原始的imageBox的Size  
  35.             Point oldSize = new Point(imageBox.Width, imageBox.Height);  
  36.             //实施放大(以x方向为基准计算得出y方向大小,防止多次运算误差积累使Image和imageBox的尺寸不匹配)  
  37.             imageBox.Width = imageBox.Width * zoomIndexBy1000 / 1000;  
  38.             imageBox.Height = imageBox.Width * imgIndexBy1000 / 1000;  
  39.             //重新定位标定后的imageBox位置  
  40.             imageBox.Left -= ((imageBox.Width - oldSize.X) * (center.X * 1000 / oldSize.X)) / 1000;  
  41.             imageBox.Top -= ((imageBox.Height - oldSize.Y) * (center.Y * 1000 / oldSize.Y)) / 1000;  
  42.             //重新设定横向滚动条最大值和位置  
  43.             if (imageBox.Width - panel1.Width > 0)  
  44.             {  
  45.                 hScrollBar1.Visible = true;  
  46.                 hScrollBar1.Maximum = imageBox.Width - panel1.Width + vScrollBar1.Width + 2;  
  47.                 hScrollBar1.Value = (imageBox.Left >= 0 ? 0 : (-imageBox.Left > hScrollBar1.Maximum ? hScrollBar1.Maximum : -imageBox.Left));  
  48.             }  
  49.             else  
  50.             {  
  51.                 hScrollBar1.Visible = false;  
  52.             }  
  53.             //重新设定纵向滚动条最大值和位置  
  54.             if (imageBox.Height - panel1.Height > 0)  
  55.             {  
  56.                 vScrollBar1.Visible = true;  
  57.                 vScrollBar1.Maximum = imageBox.Height - panel1.Height + hScrollBar1.Width + 2;  
  58.                 vScrollBar1.Value = (imageBox.Top >= 0 ? 0 : (-imageBox.Top > vScrollBar1.Maximum ? vScrollBar1.Maximum : -imageBox.Top));  
  59.             }  
  60.             else  
  61.             {  
  62.                 vScrollBar1.Visible = false;  
  63.             }  
  64.         }  
  65.   
  66.         /************************************************************ 
  67.          * 打开图片并设置滚动条 
  68.          ************************************************************/  
  69.         private void panel1_DoubleClick(object sender, EventArgs e)  
  70.         {  
  71.             openImgDlg.Filter = "图片文件|*.jpg;*.bmp;*.png";  
  72.             if (openImgDlg.ShowDialog() == DialogResult.OK)  
  73.             {  
  74.                 imageBox.Image = Image.FromFile(openImgDlg.FileName);  
  75.                 //设定图片位置  
  76.                 imageBox.Location = new Point(0, 0);  
  77.                 //设定图片初始尺寸  
  78.                 imageBox.Size = imageBox.Image.Size;  
  79.                 //设定图片纵横比  
  80.                 imgIndexBy1000 = (imageBox.Image.Height * 1000) / imageBox.Image.Width;  
  81.                 //设定滚动条  
  82.                 if (imageBox.Width - panel1.Width > 0)  
  83.                 {  
  84.                     hScrollBar1.Maximum = imageBox.Width - panel1.Width + vScrollBar1.Width +2;//+ hScrollBar1.LargeChange  
  85.                     hScrollBar1.Visible = true;  
  86.                 }  
  87.                 if (imageBox.Height - panel1.Height > 0)  
  88.                 {  
  89.                     vScrollBar1.Maximum = imageBox.Height - panel1.Height + hScrollBar1.Height +2;//+ vScrollBar1.LargeChange  
  90.                     vScrollBar1.Visible = true;  
  91.                 }  
  92.             }  
  93.         }  
  94.         /************************************************************ 
  95.          * 鼠标拖动图片移动 
  96.          ************************************************************/  
  97.         private void moveButton_Click(object sender, EventArgs e)  
  98.         {  
  99.             moveButton.Checked = !moveButton.Checked;  
  100.         }  
  101.   
  102.         private void imageBox_MouseMove(object sender, MouseEventArgs e)  
  103.         {  
  104.             if (moveButton.Checked && isMouseDown)  
  105.             {  
  106.                 //计算出移动后两个滚动条应该的Value  
  107.                 int x = -imageBox.Left + StartP.X - e.X;  
  108.                 int y = -imageBox.Top + StartP.Y - e.Y;  
  109.   
  110.                 //如果滚动条的value有效则执行操作;  
  111.                 if (x >= -panel1.Width + 10 && x <= imageBox.Width - 10)  
  112.                 {  
  113.                     if (hScrollBar1.Visible)  
  114.                     {  
  115.                         if (x > 0)  
  116.                             hScrollBar1.Value = x > hScrollBar1.Maximum ? hScrollBar1.Maximum : x;  
  117.                         imageBox.Left = -x - (vScrollBar1.Visible && x < 0 ? vScrollBar1.Width : 0);  
  118.                     }  
  119.                     else  
  120.                         imageBox.Left = -x;  
  121.                 }  
  122.   
  123.                 if (y >= -panel1.Height + 10 && y <= imageBox.Height - 10)  
  124.                 {  
  125.                     if (vScrollBar1.Visible)  
  126.                     {  
  127.                         if (y > 0)  
  128.                             vScrollBar1.Value = y > vScrollBar1.Maximum ? vScrollBar1.Maximum : y;  
  129.                         imageBox.Top = -y - (hScrollBar1.Visible && y < 0 ? hScrollBar1.Height : 0);  
  130.                     }  
  131.                     else  
  132.                         imageBox.Top = -y;  
  133.                 }  
  134.   
  135.                 /***************************************************** 
  136.                  * 给予调整滚动条调整图片位置 
  137.                  ***************************************************** 
  138.                 //计算出移动后两个滚动条应该的Value 
  139.                 int x = hScrollBar1.Value + StartP.X -e.X; 
  140.                 int y = vScrollBar1.Value + StartP.Y -e.Y; 
  141.                 //如果滚动条的value有效则执行操作; 
  142.                 //否则将滚动条按不同情况拉到两头 
  143.                 if (x >= 0 && x <= hScrollBar1.Maximum) 
  144.                 { 
  145.                     hScrollBar1.Value = x; 
  146.                 } 
  147.                 else 
  148.                 { 
  149.                     hScrollBar1.Value = (x < 0 ? 0 : hScrollBar1.Maximum); 
  150.                 } 
  151.                 if (y >= 0 && y <= vScrollBar1.Maximum) 
  152.                 { 
  153.                     vScrollBar1.Value = y; 
  154.                 } 
  155.                 else 
  156.                 { 
  157.                     vScrollBar1.Value = (y < 0 ? 0 : vScrollBar1.Maximum); 
  158.                 }*/  
  159.             }  
  160.         }  
  161.   
  162.         private void imageBox_MouseDown(object sender, MouseEventArgs e)  
  163.         {  
  164.             StartP = e.Location;  
  165.             isMouseDown = true;  
  166.         }  
  167.   
  168.         private void imageBox_MouseEnter(object sender, EventArgs e)  
  169.         {  
  170.             imageBox.Focus();  
  171.         }  
  172.   
  173.         private void imageBox_MouseUp(object sender, MouseEventArgs e)  
  174.         {  
  175.             isMouseDown = false;  
  176.         }  
  177.         /************************************************************ 
  178.          * 滚动条滚动时,图片移动 
  179.          ************************************************************/  
  180.         private void hScrollBar1_ValueChanged(object sender, EventArgs e)  
  181.         {  
  182.             imageBox.Left = -hScrollBar1.Value;  
  183.         }  
  184.   
  185.         private void vScrollBar1_ValueChanged(object sender, EventArgs e)  
  186.         {  
  187.             imageBox.Top = -vScrollBar1.Value;  
  188.         }  
  189.         /************************************************************ 
  190.          * 窗口(Panel1)尺寸改变时图像的显示位置控制 
  191.          ************************************************************/  
  192.         private void panel1_Resize(object sender, EventArgs e)  
  193.         {  
  194.             //对左右的方向操作(左右)  
  195.             if (imageBox.Width <= panel1.Width)//见程序说明 图-1:图片左右居中  
  196.             {  
  197.                 imageBox.Left = (panel1.Width-imageBox.Width)/2;  
  198.                 hScrollBar1.Visible = false;  
  199.             }  
  200.             else if (imageBox.Left < 0 && imageBox.Width + imageBox.Left < panel1.Width)//见程序说明 图-2:图片靠右  
  201.             {  
  202.                 imageBox.Left = panel1.Width - imageBox.Width;  
  203.                 hScrollBar1.Visible = true;  
  204.             }  
  205.             else if (imageBox.Left > 0 && imageBox.Width + imageBox.Left > panel1.Width)//见程序说明 图-3:图片靠左  
  206.             {  
  207.                 imageBox.Left = 0;  
  208.                 hScrollBar1.Visible = true;  
  209.             }  
  210.             else//见程序说明 图-4:保证显示的中心图样不变(左右)  
  211.             {  
  212.                 imageBox.Left += (panel1.Width - panelOldSize.X) / 2;  
  213.                 hScrollBar1.Visible = true;  
  214.             }  
  215.             //设定横向滚动条最大值  
  216.             hScrollBar1.Maximum = (imageBox.Width - panel1.Width > 0 ? imageBox.Width - panel1.Width + hScrollBar1.Maximum + 2 : 0);  
  217.             //设定横向滚动条Value  
  218.             hScrollBar1.Value = (imageBox.Left >= 0 ? 0 : -imageBox.Left);  
  219.             //重置旧的pannel1的Width  
  220.             panelOldSize.X = panel1.Width;  
  221.   
  222.             //对上下的方向操作(上下)  
  223.             if (imageBox.Height <= panel1.Height)//见程序说明 图-1:图片上下居中  
  224.             {  
  225.                 imageBox.Top = (panel1.Height - imageBox.Height) / 2;  
  226.                 vScrollBar1.Visible = false;  
  227.             }  
  228.             else if (imageBox.Top < 0 && imageBox.Height + imageBox.Top < panel1.Height)//见程序说明 图-2:图片靠下  
  229.             {  
  230.                 imageBox.Top = panel1.Height - imageBox.Height;  
  231.                 vScrollBar1.Visible = true;  
  232.             }  
  233.             else if (imageBox.Top > 0 && imageBox.Height + imageBox.Top > panel1.Height)//见程序说明 图-3:图片靠上  
  234.             {  
  235.                 imageBox.Top = 0;  
  236.                 vScrollBar1.Visible = true;  
  237.             }  
  238.             else//见程序说明 图-4:保证显示的中心图样不变(上下)  
  239.             {  
  240.                 imageBox.Top += (panel1.Height - panelOldSize.Y) / 2;  
  241.                 vScrollBar1.Visible = true;  
  242.             }  
  243.             //设定纵向滚动条最大值  
  244.             vScrollBar1.Maximum = (imageBox.Height - panel1.Height > 0 ? imageBox.Height - panel1.Height + vScrollBar1.Maximum + 2 : 0);  
  245.             //设定纵向滚动条Value  
  246.             vScrollBar1.Value = (imageBox.Top >= 0 ? 0 : -imageBox.Top);  
  247.             //重置旧的pannel1的Height  
  248.             panelOldSize.Y = panel1.Height;  
  249.         }  
  250.   
  251.         /************************************************************ 
  252.          * 滚动鼠标滚轮实现鼠标缩放 
  253.          ************************************************************/  
  254.         private void imageBox_MouseWheel(object sender, MouseEventArgs e)  
  255.         {  
  256.             switch (keyAction)  
  257.             {  
  258.                 case 1:  
  259.                     if (e.Delta > 0 && imageBox.Width < 10000)  
  260.                     {  
  261.                         zoom(e.Location, 1100);  
  262.                     }  
  263.                     else if (e.Delta < 0 && imageBox.Image.Width / imageBox.Width < 5)  
  264.                     {  
  265.                         zoom(e.Location, 900);  
  266.                     }  
  267.                     break;  
  268.                 case 2:  
  269.                     if (hScrollBar1.Visible)  
  270.                         hScrollBar1.Value = (hScrollBar1.Value - e.Delta < 0 ? 0 : (hScrollBar1.Value - e.Delta > hScrollBar1.Maximum ? hScrollBar1.Maximum : hScrollBar1.Value - e.Delta));  
  271.                     break;  
  272.                 default:  
  273.                     if (vScrollBar1.Visible)  
  274.                         vScrollBar1.Value = (vScrollBar1.Value - e.Delta < 0 ? 0 : (vScrollBar1.Value - e.Delta > vScrollBar1.Maximum ? vScrollBar1.Maximum : vScrollBar1.Value - e.Delta));  
  275.                     break;  
  276.             }  
  277.         }  
  278.   
  279.         private void Form1_KeyDown(object sender, KeyEventArgs e)  
  280.         {  
  281.             if (e.Control)  
  282.                 keyAction = 1;  
  283.             else if (e.Shift)  
  284.                 keyAction = 2;  
  285.         }  
  286.   
  287.         private void Form1_KeyUp(object sender, KeyEventArgs e)  
  288.         {  
  289.             keyAction = 0;  
  290.         }  
  291.   
  292.         private void imageBox_KeyDown(object sender, KeyEventArgs e)  
  293.         {  
  294.             if (e.Control)  
  295.                 keyAction = 1;  
  296.             else if (e.Shift)  
  297.                 keyAction = 2;  
  298.             else  
  299.                 keyAction = 3;  
  300.         }  
  301.         private void imageBox_KeyUp(object sender, KeyEventArgs e)  
  302.         {  
  303.             keyAction = 0;  
  304.         }  
  305.     }  
  306. }  

 

From1.Designer.cs:

Code:
  1. namespace ImageView  
  2. {  
  3.     partial class Form1  
  4.     {  
  5.         /// <summary>  
  6.         /// 必需的设计器变量。  
  7.         /// </summary>  
  8.         private System.ComponentModel.IContainer components = null;  
  9.   
  10.         /// <summary>  
  11.         /// 清理所有正在使用的资源。  
  12.         /// </summary>  
  13.         /// <param name="disposing">如果应释放托管资源,为 true;否则为 false。</param>  
  14.         protected override void Dispose(bool disposing)  
  15.         {  
  16.             if (disposing && (components != null))  
  17.             {  
  18.                 components.Dispose();  
  19.             }  
  20.             base.Dispose(disposing);  
  21.         }  
  22.  
  23.         #region Windows 窗体设计器生成的代码  
  24.   
  25.         /// <summary>  
  26.         /// 设计器支持所需的方法 - 不要  
  27.         /// 使用代码编辑器修改此方法的内容。  
  28.         /// </summary>  
  29.         private void InitializeComponent()  
  30.         {  
  31.             this.panel1 = new System.Windows.Forms.Panel();  
  32.             this.vScrollBar1 = new System.Windows.Forms.VScrollBar();  
  33.             this.hScrollBar1 = new System.Windows.Forms.HScrollBar();  
  34.             this.imageBox = new System.Windows.Forms.PictureBox();  
  35.             this.toolMenu = new System.Windows.Forms.ToolStrip();  
  36.             this.moveButton = new System.Windows.Forms.ToolStripButton();  
  37.             this.openImgDlg = new System.Windows.Forms.OpenFileDialog();  
  38.             this.panel1.SuspendLayout();  
  39.             ((System.ComponentModel.ISupportInitialize)(this.imageBox)).BeginInit();  
  40.             this.toolMenu.SuspendLayout();  
  41.             this.SuspendLayout();  
  42.             //   
  43.             // panel1  
  44.             //   
  45.             this.panel1.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)  
  46.                         | System.Windows.Forms.AnchorStyles.Left)  
  47.                         | System.Windows.Forms.AnchorStyles.Right)));  
  48.             this.panel1.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle;  
  49.             this.panel1.Controls.Add(this.vScrollBar1);  
  50.             this.panel1.Controls.Add(this.hScrollBar1);  
  51.             this.panel1.Controls.Add(this.imageBox);  
  52.             this.panel1.Location = new System.Drawing.Point(12, 28);  
  53.             this.panel1.Name = "panel1";  
  54.             this.panel1.Size = new System.Drawing.Size(295, 224);  
  55.             this.panel1.TabIndex = 0;  
  56.             this.panel1.DoubleClick += new System.EventHandler(this.panel1_DoubleClick);  
  57.             this.panel1.Resize += new System.EventHandler(this.panel1_Resize);  
  58.             //   
  59.             // vScrollBar1  
  60.             //   
  61.             this.vScrollBar1.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)  
  62.                         | System.Windows.Forms.AnchorStyles.Right)));  
  63.             this.vScrollBar1.Location = new System.Drawing.Point(275, 0);  
  64.             this.vScrollBar1.Name = "vScrollBar1";  
  65.             this.vScrollBar1.Size = new System.Drawing.Size(18, 204);  
  66.             this.vScrollBar1.TabIndex = 2;  
  67.             this.vScrollBar1.Visible = false;  
  68.             this.vScrollBar1.ValueChanged += new System.EventHandler(this.vScrollBar1_ValueChanged);  
  69.             //   
  70.             // hScrollBar1  
  71.             //   
  72.             this.hScrollBar1.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left)  
  73.                         | System.Windows.Forms.AnchorStyles.Right)));  
  74.             this.hScrollBar1.Location = new System.Drawing.Point(0, 204);  
  75.             this.hScrollBar1.Name = "hScrollBar1";  
  76.             this.hScrollBar1.Size = new System.Drawing.Size(277, 18);  
  77.             this.hScrollBar1.TabIndex = 1;  
  78.             this.hScrollBar1.Visible = false;  
  79.             this.hScrollBar1.ValueChanged += new System.EventHandler(this.hScrollBar1_ValueChanged);  
  80.             //   
  81.             // imageBox  
  82.             //   
  83.             this.imageBox.Location = new System.Drawing.Point(48, 42);  
  84.             this.imageBox.Name = "imageBox";  
  85.             this.imageBox.Size = new System.Drawing.Size(113, 104);  
  86.             this.imageBox.SizeMode = System.Windows.Forms.PictureBoxSizeMode.Zoom;  
  87.             this.imageBox.TabIndex = 0;  
  88.             this.imageBox.TabStop = false;  
  89.             this.imageBox.MouseWheel += new System.Windows.Forms.MouseEventHandler(this.imageBox_MouseWheel);  
  90.             this.imageBox.MouseMove += new System.Windows.Forms.MouseEventHandler(this.imageBox_MouseMove);  
  91.             this.imageBox.KeyUp += new System.Windows.Forms.KeyEventHandler(this.imageBox_KeyUp);  
  92.             this.imageBox.MouseDown += new System.Windows.Forms.MouseEventHandler(this.imageBox_MouseDown);  
  93.             this.imageBox.MouseUp += new System.Windows.Forms.MouseEventHandler(this.imageBox_MouseUp);  
  94.             this.imageBox.MouseEnter += new System.EventHandler(this.imageBox_MouseEnter);  
  95.             this.imageBox.KeyDown += new System.Windows.Forms.KeyEventHandler(this.imageBox_KeyDown);  
  96.             //   
  97.             // toolMenu  
  98.             //   
  99.             this.toolMenu.Items.AddRange(new System.Windows.Forms.ToolStripItem[] {  
  100.             this.moveButton});  
  101.             this.toolMenu.Location = new System.Drawing.Point(0, 0);  
  102.             this.toolMenu.Name = "toolMenu";  
  103.             this.toolMenu.Size = new System.Drawing.Size(319, 25);  
  104.             this.toolMenu.TabIndex = 1;  
  105.             this.toolMenu.Text = "toolStrip1";  
  106.             //   
  107.             // moveButton  
  108.             //   
  109.             this.moveButton.DisplayStyle = System.Windows.Forms.ToolStripItemDisplayStyle.Image;  
  110.             this.moveButton.Image = global::ImageView.Properties.Resources.Hand;  
  111.             this.moveButton.ImageTransparentColor = System.Drawing.Color.Magenta;  
  112.             this.moveButton.Name = "moveButton";  
  113.             this.moveButton.Size = new System.Drawing.Size(23, 22);  
  114.             this.moveButton.Text = "移动图片";  
  115.             this.moveButton.Click += new System.EventHandler(this.moveButton_Click);  
  116.             //   
  117.             // Form1  
  118.             //   
  119.             this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F);  
  120.             this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;  
  121.             this.ClientSize = new System.Drawing.Size(319, 264);  
  122.             this.Controls.Add(this.toolMenu);  
  123.             this.Controls.Add(this.panel1);  
  124.             this.Name = "Form1";  
  125.             this.Text = "Form1";  
  126.             this.KeyUp += new System.Windows.Forms.KeyEventHandler(this.Form1_KeyUp);  
  127.             this.KeyDown += new System.Windows.Forms.KeyEventHandler(this.Form1_KeyDown);  
  128.             this.panel1.ResumeLayout(false);  
  129.             ((System.ComponentModel.ISupportInitialize)(this.imageBox)).EndInit();  
  130.             this.toolMenu.ResumeLayout(false);  
  131.             this.toolMenu.PerformLayout();  
  132.             this.ResumeLayout(false);  
  133.             this.PerformLayout();  
  134.   
  135.         }  
  136.  
  137.         #endregion  
  138.   
  139.         private System.Windows.Forms.Panel panel1;  
  140.         private System.Windows.Forms.PictureBox imageBox;  
  141.         private System.Windows.Forms.ToolStrip toolMenu;  
  142.         private System.Windows.Forms.OpenFileDialog openImgDlg;  
  143.         private System.Windows.Forms.HScrollBar hScrollBar1;  
  144.         private System.Windows.Forms.VScrollBar vScrollBar1;  
  145.         private System.Windows.Forms.ToolStripButton moveButton;  
  146.     }  
  147. }  

 

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值