zoukankan      html  css  js  c++  java
  • 将WPF UI单元复制到“.NET研究”剪贴板 狼人:

      大家在日常工作中应该遇到过这样的问题:需要对应用程序界面进行截屏操作,然后将截屏内容拷贝到其他文档中使用。通常情况下我们会使用一些截屏软件或者“Ctrl+PrtSc ”,本篇将介绍如何在WPF 程序中将UI 单元直接以图片形式复制到剪贴板,以达到为应用程序界面制作快照(Snapshot)的功能。

      以我之前做过的一个“WPF 员工卡”的文章为例。首先,要为程序添加一个自定义命令(Command):CopyUI。该命令的快捷键方式为“上海网站建设Ctrl+U”,在命令中定义两种事件CanExecute、Executed。关于自定义命令可以参考这里

    <Window.Resources>
    <
    Storyboard x:Key="flashClose">
    ... ...

    </
    Storyboard>
    <
    RoutedUICommand x:Key="CopyUI" Text="Copy WPF UI as Image" />
    </
    Window.Resources>
    <
    Window.InputBindings上海闵行企业网站制作span>>
    <
    KeyBinding Mo上海闵行企业网站设计与制作difiers="Ctrl" Key="U" <上海企业网站设计与制作span style="color: red;">Command
    ="{StaticResource CopyUI}"/>
    </
    Window.InputBindings>
    <
    Window.CommandBindings>
    <
    CommandBinding Command="{StaticResource CopyUI}"
    CanExecute="CommandBinding_CanExecute"
    Executed="CommandBinding_Executed"/>
    </
    Window.CommandBindings>

      完成命令的定义后,就可以为它们添油加醋了。

    private void CommandBinding_CanExecute(object sender, CanExecuteRoutedEventArgs e)
    {
    e.CanExecute = true;
    }

    private void CommandBinding_Executed(object sender, ExecutedRoutedEventArgs e)
    {
    CopyUIElementToClipboard(this.empCard);
    }

      到这里有些朋友可能已经发现CommandBinding_Executed 事件里CopyUIElementToClipboard 方法才是关键部分。empCard 是员工卡整体UI 结构。通过CopyUIElementToClipboard 将WPF UI 单元绘制成图片并复制到剪贴板中,如下代码:

    public static void CopyUIElementToClipboard(FrameworkElement ui)
    {
    double width = ui.ActualWidth;
    double height = ui.ActualHeight;
    RenderTargetBitmap bmp = new RenderTargetBitmap((int)Math.Round(width),
    (int)Math.Round(height), 96, 96, PixelFormats.Default);
    DrawingVisual dv = new DrawingVisual();
    using (DrawingContext dc = dv.RenderOpen())
    {
    VisualBrush vb = new VisualBrush(ui);
    dc.DrawRectangle(vb, null,
    new Rect(上海企业网站制作le="color: blue;">new Point(), new Size(width, height)));
    }
    bmp.Render(dv);
    Clipboard.SetImage(bmp);
    }

      接下来运行程序,按“Ctrl+U” 对UI 进行复制。

    image

      “Ctrl+V” 到Word 后的效果,这样就可以比较方便的复制UI 结构,当然也可以复制程序中生成的柱状图,放到PPT中做为报告使用。

    image

    声明:此博有部分内容为转载,版权归原作者所有~
  • 相关阅读:
    处理跨浏览器的事件处理程序
    html5 canvas时钟
    拖拽事件的原理
    改变top使用轮播图
    程序开发之最大子数组
    第四周学习进度
    敏捷开发相关阅读
    构建之法读书笔记04
    四则运算终结版
    第三周学习进度
  • 原文地址:https://www.cnblogs.com/waw/p/2217031.html
Copyright © 2011-2022 走看看