WinForm实现的图片拖拽与缩放功能示例

作者:何问起 时间:2021-06-18 09:17:26 

本文实例讲述了WinForm实现的图片拖拽与缩放功能。分享给大家供大家参考,具体如下:

最近做项目的时候遇到上传施工平面布置图,查看,因为图片比较大,一般的显示器分辨率无法显示全,然后还需要放大看清楚图片里面的文字内容,所以需要用到图片的拖拽与缩放功能。这里整理下具体操作。

首先新建一个窗体,拖一个panel控件到窗体中,然后在拖一个pictureobx控件到panel中,然后在添加个上传图片的按钮:

WinForm实现的图片拖拽与缩放功能示例

具体代码:


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Reflection;
namespace 图像平移缩放
{
 public partial class Form1 : Form
 {
   Bitmap myBmp;
   Point mouseDownPoint = new Point(); //记录拖拽过程鼠标位置
   bool isMove = false;  //判断鼠标在picturebox上移动时,是否处于拖拽过程(鼠标左键是否按下)
   int zoomStep = 20;   //缩放步长
   public Form1()
   {
     InitializeComponent();
   }
   //图片上传
   private void button1_Click(object sender, EventArgs e)
   {
     string filename = "";
     OpenFileDialog dlg = new OpenFileDialog();
     dlg.Filter = "Tiff文件|*.tif|Bmp文件|*.bmp|Erdas img文件|*.img|EVNI文件|*.hdr|jpeg文件|*.jpg|raw文件|*.raw|vrt文件|*.vrt|所有文件|*.*";
     dlg.FilterIndex = 8;
     if (dlg.ShowDialog() == DialogResult.OK)
     {
       filename = dlg.FileName;
     }
     if (filename == "")
     {
       return;
     }
     myBmp = new Bitmap(filename);
     if (myBmp == null)
     {
       MessageBox.Show("读取失败");
       return;
     }
     textBox1.Text = filename;
     pictureBox1.Image = myBmp;
     pictureBox1.SizeMode = PictureBoxSizeMode.Zoom; //设置picturebox为缩放模式
     pictureBox1.Width = myBmp.Width;
     pictureBox1.Height = myBmp.Height;
   }
   //鼠标按下功能
   private void pictureBox1_MouseDown(object sender, MouseEventArgs e)
   {
     if (e.Button == MouseButtons.Left)
     {
       mouseDownPoint.X = Cursor.Position.X;
       mouseDownPoint.Y = Cursor.Position.Y;
       isMove = true;
       pictureBox1.Focus();
     }
   }
   //鼠标松开功能
   private void pictureBox1_MouseUp(object sender, MouseEventArgs e)
   {
     if (e.Button == MouseButtons.Left)
     {
       isMove = false;
     }
   }
   //鼠标移动功能
   private void pictureBox1_MouseMove(object sender, MouseEventArgs e)
   {
     pictureBox1.Focus();
     if (isMove)
     {
       int x, y;
       int moveX, moveY;
       moveX = Cursor.Position.X - mouseDownPoint.X;
       moveY = Cursor.Position.Y - mouseDownPoint.Y;
       x = pictureBox1.Location.X + moveX;
       y = pictureBox1.Location.Y + moveY;
       pictureBox1.Location = new Point(x, y);
       mouseDownPoint.X = Cursor.Position.X;
       mouseDownPoint.Y = Cursor.Position.Y;
     }
   }
   //鼠标滚轮滚动功能
   private void pictureBox1_MouseWheel(object sender, MouseEventArgs e)
   {
     int x = e.Location.X;
     int y = e.Location.Y;
     int ow = pictureBox1.Width;
     int oh = pictureBox1.Height;
     int VX, VY;
     if (e.Delta > 0)
     {
       pictureBox1.Width += zoomStep;
       pictureBox1.Height += zoomStep;
       PropertyInfo pInfo = pictureBox1.GetType().GetProperty("ImageRectangle", BindingFlags.Instance |
         BindingFlags.NonPublic);
       Rectangle rect = (Rectangle)pInfo.GetValue(pictureBox1, null);
       pictureBox1.Width = rect.Width;
       pictureBox1.Height = rect.Height;
     }
     if (e.Delta < 0)
     {
       if (pictureBox1.Width < myBmp.Width / 10)
         return;
       pictureBox1.Width -= zoomStep;
       pictureBox1.Height -= zoomStep;
       PropertyInfo pInfo = pictureBox1.GetType().GetProperty("ImageRectangle", BindingFlags.Instance |
         BindingFlags.NonPublic);
       Rectangle rect = (Rectangle)pInfo.GetValue(pictureBox1, null);
       pictureBox1.Width = rect.Width;
       pictureBox1.Height = rect.Height;
     }
     VX = (int)((double)x * (ow - pictureBox1.Width) / ow);
     VY = (int)((double)y * (oh - pictureBox1.Height) / oh);
     pictureBox1.Location = new Point(pictureBox1.Location.X + VX, pictureBox1.Location.Y + VY);
   }
   private void panel2_MouseDown(object sender, MouseEventArgs e)
   {
     if (e.Button == MouseButtons.Left)
     {
       mouseDownPoint.X = Cursor.Position.X;
       mouseDownPoint.Y = Cursor.Position.Y;
       isMove = true;
     }
   }
   private void panel2_MouseUp(object sender, MouseEventArgs e)
   {
     if (e.Button == MouseButtons.Left)
     {
       isMove = false;
     }
   }
   private void panel2_MouseMove(object sender, MouseEventArgs e)
   {
     panel2.Focus();
     if (isMove)
     {
       int x, y;
       int moveX, moveY;
       moveX = Cursor.Position.X - mouseDownPoint.X;
       moveY = Cursor.Position.Y - mouseDownPoint.Y;
       x = pictureBox1.Location.X + moveX;
       y = pictureBox1.Location.Y + moveY;
       pictureBox1.Location = new Point(x, y);
       mouseDownPoint.X = Cursor.Position.X;
       mouseDownPoint.Y = Cursor.Position.Y;
     }
   }
 }
}

这里需要注意一点,类里面用到了一个 pictureBox1_MouseWheel 时间,这个是picturebox控件没有的时间,所以需要手动去添加这个事件,可以直接在form1的设计类中添加


//
// pictureBox1
//
this.pictureBox1.BackColor = System.Drawing.Color.White;
this.pictureBox1.Location = new System.Drawing.Point(20, 20);
this.pictureBox1.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2);
this.pictureBox1.Name = "pictureBox1";
this.pictureBox1.Size = new System.Drawing.Size(67, 34);
this.pictureBox1.TabIndex = 0;
this.pictureBox1.TabStop = false;
this.pictureBox1.MouseDown += new System.Windows.Forms.MouseEventHandler(this.pictureBox1_MouseDown);
this.pictureBox1.MouseMove += new System.Windows.Forms.MouseEventHandler(this.pictureBox1_MouseMove);
this.pictureBox1.MouseUp += new System.Windows.Forms.MouseEventHandler(this.pictureBox1_MouseUp);
this.pictureBox1.MouseWheel += new System.Windows.Forms.MouseEventHandler(this.pictureBox1_MouseWheel);

这样就能直接运行成功了

希望本文所述对大家C#程序设计有所帮助。

标签:WinForm,图片
0
投稿

猜你喜欢

  • C#Process的OutputDataReceived事件不触发问题及解决

    2023-08-12 19:22:41
  • SpringAOP事务配置语法及实现过程详解

    2023-12-27 21:26:16
  • C#交错数组用法实例

    2022-08-13 09:34:55
  • C# Winfrom实现Skyline画直线功能的示例代码

    2023-04-24 12:41:48
  • 解析Android开发中多点触摸的实现方法

    2021-12-07 11:20:35
  • Java 全方位讲解面向对象特点与使用

    2023-07-21 18:34:06
  • 浅谈Java线程并发知识点

    2021-10-20 13:11:13
  • Java 中的 clone( ) 和 new哪个效率更高

    2023-11-09 05:27:44
  • Spring实战之使用注解实现声明式事务操作示例

    2021-08-19 07:16:07
  • Android仿微信QQ设置图形头像裁剪功能

    2022-06-21 10:12:25
  • Java中ArrayList和LinkedList区别

    2023-09-06 20:43:09
  • Android 反射注解与动态代理综合使用详解

    2023-01-13 12:30:56
  • Java CAS原子操作详解

    2023-05-06 15:37:15
  • Android自定义控件实现滑动开关效果

    2022-10-25 00:45:39
  • Java中缀表达式转后缀表达式实现方法详解

    2021-08-25 02:57:20
  • Android自定义TextView实现drawableLeft内容居中

    2022-04-24 18:20:14
  • c# 关闭窗体时提示的小例子

    2021-11-10 19:08:18
  • idea中Maven镜像源详细配置步骤记录(对所有项目)

    2022-12-17 14:27:56
  • Android studio 快速删除无用资源的方法

    2022-10-06 20:53:42
  • 获取Java线程转储的常用方法(推荐)

    2023-05-15 02:30:19
  • asp之家 软件编程 m.aspxhome.com