C#关于实现基于鼠标中心滚轮放大缩小

我们在用C# Graphics 画图的时候如何实现通过鼠标滚轮进行图形的放大缩小呢?

首先我们需要了解System.Drawing.Drawing2D命名空间下有个Matrix类, 此类提供了多种图形变换方法.查看微软API, 我们发现方法Scale 只有基于原点进行放大缩小, 没有类似RotateAt的基于某个坐标进行变换.
在这里插入图片描述

故,我们可以换种思路. 先缩放, 然后再移动, 从而实现鼠标坐标进行放大缩小的.

在这里插入图片描述
重点代码如下


        private void Form1_MouseWheel(object sender, MouseEventArgs e)
        {            
            if (e.Delta != 0)
            {
                if (e.Delta > 0)
                {
                    g.Clear(Color.Black);
                    System.Drawing.Drawing2D.Matrix myMatrix = new System.Drawing.Drawing2D.Matrix();
                    myMatrix.Scale(2,2);
                    myMatrix.Translate(-0.5f * centerP.X, -0.5f * centerP.Y);
                    gp.Transform(myMatrix);
                    g.FillPath(new SolidBrush(Color.Red), gp);
                }
                else
                {
                    System.Drawing.Drawing2D.Matrix myMatrix = new System.Drawing.Drawing2D.Matrix();
                    myMatrix.Scale(0.5f , 0.5f);
                    myMatrix.Translate(centerP.X, centerP.Y);
                    gp.Transform(myMatrix);
                    g.Clear(Color.Black);
                    g.FillPath(new SolidBrush(Color.Red), gp);
                }
                    
            }
        }

        

源代码

C#中,如果你想在鼠标滚轮事件中对光标所在CHART控件的位置区域实现放大缩小功能,你可以通过监听MouseWheel事件并结合Chart控件的相关属性来实现。以下是一个基本的实现步骤: 1. 为Chart控件添加MouseWheel事件处理器。 2. 在事件处理器中,获取当前鼠标的位置(相对于Chart控件)。 3. 根据鼠标滚轮滚动方向和滚动量,更新Chart控件的视图范围(ScaleView)或缩放比例(Zoom)。 下面是一个简单的代码示例,展示了如何实现该功能: ```csharp // 为Chart控件添加MouseWheel事件处理器 chart1.MouseWheel += new MouseEventHandler(chart1_MouseWheel); private void chart1_MouseWheel(object sender, MouseEventArgs e) { // 确保是在Chart控件上进行滚轮操作 if (e.Control == sender) { // 获取当前鼠标位置相对于Chart控件的位置 var cursorPosition = e.Location; // 根据滚轮的滚动方向来决定放大还是缩小 // MouseEventArgs.Delta属性值为正表示向上滚动(通常意味着放大),为负表示向下滚动(缩小) if (e.Delta > 0) { // 放大操作 chart1.ChartAreas[0].AxisX.ScaleView.Zoom(1.1); chart1.ChartAreas[0].AxisY.ScaleView.Zoom(1.1); } else { // 缩小操作 chart1.ChartAreas[0].AxisX.ScaleView.Zoom(0.9); chart1.ChartAreas[0].AxisY.ScaleView.Zoom(0.9); } } } ``` 请注意,上述代码示例是一个基础的实现框架,你可能需要根据你的具体需求进行调整。例如,你可以根据滚轮滚动的幅度调整放大缩小的比例,或者使用更复杂的逻辑来决定如何缩放
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Kevin_Lai_1987

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值