首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >跟随光标的UWP放大镜控件(工具)

跟随光标的UWP放大镜控件(工具)
EN

Stack Overflow用户
提问于 2018-09-21 22:10:44
回答 1查看 461关注 0票数 0

我现在正在做一个任务,被要求创建一个应用程序来选择图像上的一个区域,能够放大光标周围的图像的一部分。

现在我坚持使用放大镜的部分。在WPF中有一个放大镜控制,但是UWP呢?有没有在UWP中创建放大镜的经验?

到目前为止,我已经找到了这个,但是UWP有不同的接口:http://csharphelper.com/blog/2015/06/zoom-and-crop-a-picture-in-c/

我的逻辑是: 1.在光标周围画圆圈,并在每次光标移动时重新绘制。2.在其周围的指定区域进行屏幕截图(渲染) 3.放大区域4.用放大的图像(位图)填充圆圈

任何提示或建议都将不胜感激。谢谢

EN

回答 1

Stack Overflow用户

发布于 2018-09-26 10:08:45

  1. 在光标周围绘制圆,并在每次光标移动时重新绘制。

您可以注册面板(例如,画布)的PointerMoved事件,并使用以下方法获取当前指针:

代码语言:javascript
复制
private void Canvas_PointerMoved(object sender, PointerRoutedEventArgs e)
{
    var pointer = e.GetCurrentPoint(sender as UIElement);
}

然后,您可以在其上添加一个Ellipse,并通过当前指针设置其位置。

  1. 在其周围拍摄屏幕截图(渲染)指定区域

您可以使用RenderTargetBitmap 类API来渲染特定的区域。

  1. 放大了are

您可以调整rendertarget位图的大小。检查此线程How to Resize the RenderTargetBitmap

  1. 用放大的图像(位图)填充圆圈

在获得最终的rendertargetbitmap之后,您可以使用它来创建一个填充,然后您可以将此填充指定为椭圆的ImageBrush属性,如下所示:

代码语言:javascript
复制
ellipse.Fill = new ImageBrush() { ImageSource = renderTargetBitmap};
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52445554

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档