如果你使用WinForm比较难实现通过滚动鼠标滑轮来对图片进行缩放显示,那么,你应该考虑一下使用WPF,既然是下一代Windows客户端开发平台,明显是有一定优势的,不然,MS是吃饱了撑着。
 
首先,我们应该知道WPFUI元素都具备变换功能,不仅支持二维变换,同时也支持三维变换,但3D变换对CPU的处理能力有着一定要求,如果不使用3D,WPF对性能的要求其实并不高,说WPF吃内存更子扯谈,前面我的文章中已经详细讨论过,WPF与传统的面向对象编程模有些不同,WPF属性系统使用依赖项属性,所有属性都会在全局哈希表中进行注册,这也是为什么WPF程序启动速度较慢的原因,但它并不消耗内存,因为依赖项注项后并不随类的构造函一起初始,也就是说,用到的时候才分配内存,当然,这带来的问题显示是有些耗时间,所以说WPF是用时间来换取空间。
 
呵呵,扯远了,还是回到今天的主题,为什么说在WPF中实现滚动鼠标滑轮来缩放显示图象比较简单,除了路由事件的支持外,就是上文提到的变换。
 
变换包括旋转、倾斜、位移等,当然,比较灵活复杂的是矩阵变换。
我们今天的例子就是通过缩放变换来实现的,也就是ScaleTransform的使用。
 
首先建立一个WPF应用程序,并在在Grid中放一个Image元素,你就随便准备一个图片做测试就行了。
  1. <Grid x:Name="root">
  2. <Image x:Name="img" Margin="20,20,20,77" Source="60.jpg"
  3. MouseWheel="img_MouseWheel">
  4. <Image.RenderTransform>
  5. <ScaleTransform x:Name="sfr" />
  6. </Image.RenderTransform>
  7. </Image>
  8. </Grid>
上面的XAML都很简单,注意ScaleTransform 的使用,这里为了方便在代码中访问,所以我分配了一个名字给它。
 
接着,处理MouseWeel事件。
  1. private void img_MouseWheel(object sender, MouseWheelEventArgs e)
  2. {
  3. Point centerPoint = e.GetPosition(root);
  4. this.sfr.CenterX = centerPoint.X;
  5. this.sfr.CenterY = centerPoint.Y;
  6. if (sfr.ScaleX < 0.3 && sfr.ScaleY < 0.3 && e.Delta < 0)
  7. {
  8. return;
  9. }
  10. sfr.ScaleX += (double)e.Delta / 3500;
  11. sfr.ScaleY += (double)e.Delta / 3500;
  12. }
从事件参数e的GetPosition方法获得鼠标指针的相对坐标,参照系为根Grid元素,通过这个我们可以设置缩放的中心点的坐标。
接着设置ScaleX和ScaleY属性,即分别沿X轴和Y轴缩放的倍数,当然,倍数可以负值,表示缩小显示。
 
为什么这里我要把Delta值除以3500呢?因为鼠标滑轮每次滑动变化的范围值太大,我在本机上测得的值为120,很明显,我们不能一下子就赋120,这样Image会放大或缩小120倍以上,动作太大了。
所以要想办法让每次的变化量不能太大,注意Delta值要先转换为double类型再进行运算,不然,由于是整型,运算结果太小,化为整数会被舍入为0,就等于没有变化了,所以运算前要先做类型转换。
 
现在,你可以看看效果了。如果你有兴趣的话可以进一步完善,这里只做演示。
 

WPF通过鼠标滑轮缩放显示图片的更多相关文章

  1. Magnifier.js - 支持鼠标滚轮缩放的图片放大镜效果

    Magnifier.js 是一个 JavaScript 库,能够帮助你在图像上实现放大镜效果,支持使用鼠标滚轮放大/缩小功能.放大的图像可以显示在镜头本身或它的外部容器中.Magnifier.js 使 ...

  2. wpf image控件循环显示图片 以达到动画效果 问题及解决方案

    1>最初方案: 用wpf的image控件循环显示图片,达到动画效果,其实就是在后台代码动态改变Image.Source的值,关键代码: ; i < ; i++)//六百张图片 { Bitm ...

  3. WPF 标签预览可以显示图片运行后不显示

    使用<Image HorizontalAlignment="Left" Height="100" Margin="106,111,0,0&quo ...

  4. C# wpf image绑定viewModel没有显示图片

    在wpf绑定图片,用viewModel的图片绑定image 我是用viewModel.cs public class viewModel:INotifyPropertyChanged { #regio ...

  5. ASP.NET将原始图片按照指定尺寸等比例缩放显示图片

    网站上可能会有很多图片,比如产品图片等,而且他们可能大小不一,宽度和高度也不一定一样,有的很大有的很小.如果放在一张网页上,可能会破坏版面,但是如果强制让他们按照指定的宽度和高度显示,因为比例不同还会 ...

  6. 【python】显示图片 并随意缩放图片大小 图片归一化

    cv2.namedWindow("image_",0)  cv2.imshow("image_",image)就可以随意缩放显示图片的窗口大小啦. ------ ...

  7. 在WPF里面实现以鼠标位置为中心缩放移动图片

    原文:在WPF里面实现以鼠标位置为中心缩放移动图片 在以前的文章使用WPF Resource以及Transform等技术实现鼠标控制图片缩放和移动的效果里面,介绍了如何在WPF里面移动和放大缩小图片, ...

  8. VS+Qt+Halcon——显示图片,实现鼠标缩放、移动图片

    摘要 本篇博文记录一下,用VS+Qt+Halcon实现对图片的读取以及鼠标缩放,移动(鼠标事件调用了halcon自带的算子)的过程.以及遇到的坑..... 先来看一下动态效果图: 主要控件: 添加一个 ...

  9. WPF 获取元素(Visual)相对于屏幕设备的缩放比例,可用于清晰显示图片

    原文:WPF 获取元素(Visual)相对于屏幕设备的缩放比例,可用于清晰显示图片 我们知道,在 WPF 中的坐标单位不是屏幕像素单位,所以如果需要知道某个控件的像素尺寸,以便做一些与屏幕像素尺寸相关 ...

随机推荐

  1. 【安卓笔记】ormlite入门

    ps:写这篇文章的目的是尝试下新的markdown编辑器哈哈 简单介绍 ORMLite provides a lightweight Object Relational Mapping between ...

  2. Oracle 静态监听注冊具体解释

    Oracle 静态监听注冊具体解释 网上有非常多关于oracle 监听静态注冊的文章.但大多都是简单说说,并没有具体的样例.这里,将结合linux as4 下的oracle 10gR2.0.1 举一个 ...

  3. @Component注解

    @component (把普通pojo实例化到spring容器中,相当于配置文件中的 <bean id="  " class="   "/>)泛指各 ...

  4. 1360 xth 的玫瑰花

    1360 xth 的玫瑰花  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解       题目描述 Description 这天是rabbit 的生日 ...

  5. Oracle数据库版本号定期检视与升级的必要性分析

    目 录 ▇1.ORACLE数据库版本号知识 ▇2.看看自己的数据库还有没有支持服务 ▇3.看11.2.0.3版本号各PSU的公布时间与解决BUG数量列表 ▇4.看11.2.0.4版本号各PSU的公布时 ...

  6. oc43--野指针和空指针

    // // main.m // 野指针和空指针 #import <Foundation/Foundation.h> #import "Person.h" int mai ...

  7. linux驱动注册汇总

    --- 01)TP file_operations: { 1. static struct file_operations tpd_fops = { // .owner = THIS_MODULE, ...

  8. CodeForces 754D Fedor and coupons&&CodeForces 822C Hacker, pack your bags!

    D. Fedor and coupons time limit per test 4 seconds memory limit per test 256 megabytes input standar ...

  9. codeforces 916E Jamie and Tree dfs序列化+线段树+LCA

    E. Jamie and Tree time limit per test 2.5 seconds memory limit per test 256 megabytes input standard ...

  10. Struts2 中 result type=”json” 的参数解释

    转自:http://wangquanhpu.iteye.com/blog/1461750 1, ignoreHierarchy 参数:表示是否忽略等级,也就是继承关系,比如:TestAction 继承 ...