当前位置: 首页 > news >正文

C# Wpf 图片按照鼠标中心缩放和平移

C# Wpf 图片按照鼠标中心缩放和平移

1、缩放事件

MouseWheel(object sender, MouseWheelEventArgs e)

2、平移相关的事件

MouseMove(object sender, MouseEventArgs e)
MouseDown(object sender, MouseButtonEventArgs e)
MouseUp(object sender, MouseButtonEventArgs e)

3、图片平移实现

public Point StartPoint;
public Point Origin;private void ImageEx_MouseUp(object sender, MouseButtonEventArgs e){this.ReleaseMouseCapture();}private void ImageEx_MouseMove(object sender, MouseEventArgs e){if (e.LeftButton == MouseButtonState.Released) return;TranslateTransform transform = group.Children[1] as TranslateTransform;var startPoint = StartPoint - e.GetPosition(this);transform.X = Origin.X - startPoint.X;transform.Y = Origin.Y - startPoint.Y;}private void ImageEx_MouseDown(object sender, MouseButtonEventArgs e){StartPoint = e.GetPosition(this);TranslateTransform trans = group.Children[1] as TranslateTransform;Origin = new Point(trans.X, trans.Y);this.CaptureMouse();}

4、图片缩放实现

private void ImageEx_MouseWheel(object sender, MouseWheelEventArgs e)
{Point relative = e.GetPosition(image);double zoom = e.Delta > 0 ? 0.1 : -0.1;ScaleTransform scale = group.Children[0] as ScaleTransform;TranslateTransform trans = group.Children[1] as TranslateTransform;double absoluteX;double absoluteY;absoluteX = relative.X * scale.ScaleX + trans.X;absoluteY = relative.Y * scale.ScaleY + trans.Y;scale.ScaleX += zoom;scale.ScaleY += zoom;trans.X = absoluteX - relative.X * scale.ScaleX;trans.Y = absoluteY - relative.Y * scale.ScaleY;
}

5、完整代码

1、xaml

<UserControl x:Class="WpfApp1.ImageEx"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:WpfApp1"mc:Ignorable="d" xmlns:panAndZoom="clr-namespace:Wpf.Controls.PanAndZoom;assembly=Wpf.Controls.PanAndZoom"d:DesignHeight="450" d:DesignWidth="800"><Grid DataContext="{Binding RelativeSource={RelativeSource AncestorType=UserControl}}"><Image Visibility="Collapsed" Source="{Binding CurrentImage}" x:Name="image"><Image.RenderTransform><TransformGroup x:Name="group"><ScaleTransform /><TranslateTransform /></TransformGroup></Image.RenderTransform></Image></Grid></UserControl>

2、CS

namespace WpfApp1
{/// <summary>/// ImageEx.xaml 的交互逻辑/// </summary>public partial class ImageEx : UserControl{public Point StartPoint;public Point Origin;public BitmapSource CurrentImage { get; set; }public ImageEx(){InitializeComponent();CurrentImage = new BitmapImage(new Uri("C:\\Users\\Desktop\\111.png"));this.MouseDown += ImageEx_MouseDown;this.MouseMove += ImageEx_MouseMove;this.MouseUp += ImageEx_MouseUp;this.MouseWheel += ImageEx_MouseWheel;}private void ImageEx_MouseUp(object sender, MouseButtonEventArgs e){this.ReleaseMouseCapture();}private void ImageEx_MouseWheel(object sender, MouseWheelEventArgs e){Point relative = e.GetPosition(image);double zoom = e.Delta > 0 ? 0.1 : -0.1;ScaleTransform scale = group.Children[0] as ScaleTransform;TranslateTransform trans = group.Children[1] as TranslateTransform;double absoluteX;double absoluteY;absoluteX = relative.X * scale.ScaleX + trans.X;absoluteY = relative.Y * scale.ScaleY + trans.Y;scale.ScaleX += zoom;scale.ScaleY += zoom;trans.X = absoluteX - relative.X * scale.ScaleX;trans.Y = absoluteY - relative.Y * scale.ScaleY;}private void ImageEx_MouseMove(object sender, MouseEventArgs e){if (e.LeftButton == MouseButtonState.Released) return;TranslateTransform transform = group.Children[1] as TranslateTransform;var startPoint = StartPoint - e.GetPosition(this);transform.X = Origin.X - startPoint.X;transform.Y = Origin.Y - startPoint.Y;}private void ImageEx_MouseDown(object sender, MouseButtonEventArgs e){StartPoint = e.GetPosition(this);TranslateTransform trans = group.Children[1] as TranslateTransform;Origin = new Point(trans.X, trans.Y);this.CaptureMouse();}}}

3、调用方法

<Window x:Class="WpfApp1.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"xmlns:local="clr-namespace:WpfApp1"mc:Ignorable="d"Title="MainWindow" Height="450" Width="800"><Grid><local:ImageEx  x:Name="imageEx" /></Grid>
</Window>
http://www.lryc.cn/news/456710.html

相关文章:

  • 网络安全产品类型
  • 【开源风云】从若依系列脚手架汲取编程之道(五)
  • 金融市场的衍生品交易及其风险管理探讨
  • 一、创建型(单例模式)
  • 毕业设计项目-古典舞在线交流平台的设计与实现(源码/论文)
  • 【秋招笔试】10.09华子秋招(已改编)-三语言题解
  • 【算法笔记】双指针算法深度剖析
  • 第二十二天|回溯算法| 理论基础,77. 组合(剪枝),216. 组合总和III,17. 电话号码的字母组合
  • 关闭IDM自动更新
  • Go 性能剖析工具 pprof 与 Graphviz 教程
  • 【题目解析】蓝桥杯23国赛C++中高级组 - 斗鱼养殖场
  • JavaScript可视化:探索顶尖的图表库
  • 谷歌AI大模型Gemini API快速入门及LangChain调用视频教程
  • 进入容器:掌控Docker的世界
  • 初始Linux(二)基础命令
  • STM32 OLED
  • 伦敦金实时行情决策辅助!
  • ​Leetcode 746. 使用最小花费爬楼梯​ 入门dp C++实现
  • 路由协议常见知识点
  • 多模态大语言模型(MLLM)-InstructBlip深度解读
  • 网页前端开发之Javascript入门篇(7/9):字符串
  • 双登股份再战IPO:数据打架,实控人杨善基千万元股权激励儿子
  • 4.Python 函数(函数的定义、函数的传入参数、函数的返回值、None 类型、函数说明文档、变量的作用域)
  • 【JavaEE】——文件IO
  • Python的pandas库基本操作(数据分析)
  • 软件测试(平铺版本)
  • 树控件QTreeWidget
  • Python酷库之旅-第三方库Pandas(139)
  • 昇思学习打卡营学习记录:CycleGAN壁画修复
  • 南京大学《软件分析》李越, 谭添——1. 导论