WPF 如何实现简单放大镜

Posted dotNET跨平台

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了WPF 如何实现简单放大镜相关的知识,希望对你有一定的参考价值。

 WPF 如何实现简单放大镜

控件名:Magnifier

作   者:WPFDevelopersOrg - 驚鏵

原文链接[1]:https://github.com/WPFDevelopersOrg/WPFDevelopers

  • 框架使用.NET40

  • Visual Studio 2019;

  • 实现此功能需要用到 VisualBrush ,放大镜展现使用 Canvas -> Ellipse .

    • 可以使用 VisualBrush 创建放大效果。

    • 设置 Visual 获取或设置画笔的内容。

    • 设置 ViewboxUnits Absolute 坐标系与边界框无关。

    • 设置 Viewbox 获取或设置 TileBrush 图块中内容的位置和尺寸。

  • 当鼠标移动获取当前坐标点修改 VisualBrushViewbox

  • 鼠标移动修改 EllipseCanvas.LeftCanvas.Top 跟随鼠标。

1) xaml 代码如下:

<Grid>
        <Image Source="0.png" Stretch="Fill"
               Name="image" MouseMove="image_MouseMove"
               MouseEnter="image_MouseEnter" MouseLeave="image_MouseLeave"/>

        <Canvas IsHitTestVisible="False" Name="MagnifierPanel">
            <Ellipse Stroke="LightBlue" Name="MagnifierCircle" 
                     Height="200" Width="200">
                <Ellipse.Fill>
                    <VisualBrush x:Name="MagnifierBrush"  
                                 Visual="Binding ElementName=image" 
                                 ViewboxUnits="Absolute"/>
                </Ellipse.Fill>
            </Ellipse>
        </Canvas>
    </Grid>

2) xaml.cs 代码如下:

private void image_MouseMove(object sender, MouseEventArgs e)
        
            var center = e.GetPosition(image);
            var length = MagnifierCircle.ActualWidth * _factor;
            var radius = length / 2;
            var viewboxRect = = new Rect(center.X - radius, center.Y - radius, length, length);
            MagnifierBrush.Viewbox = viewboxRect;
            MagnifierCircle.SetValue(Canvas.LeftProperty, center.X - MagnifierCircle.ActualWidth / 2);
            MagnifierCircle.SetValue(Canvas.TopProperty, center.Y - MagnifierCircle.ActualHeight / 2);

        

        private void image_MouseEnter(object sender, MouseEventArgs e)
        
            MagnifierCircle.Visibility = Visibility.Visible;
        

        private void image_MouseLeave(object sender, MouseEventArgs e)
        
            MagnifierCircle.Visibility = Visibility.Hidden;
        

参考资料

[1]

原文链接: https://github.com/WPFDevelopersOrg/WPFDevelopers

以上是关于WPF 如何实现简单放大镜的主要内容,如果未能解决你的问题,请参考以下文章

WPF 自定义放大镜控件

如何使用 JavaFX 实现放大/缩小?

如何在 Android 的滚动视图中放大/更改子图像视图尺寸以使图像全尺寸

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

如何获得活动屏幕尺寸?

C# wpf 如何实现自定义控件,布局时,大小发生变化,内部绘制的曲线跟随变化?