#486 – InkCanvas 支持多种编辑模式(InkCanvas Supports Different Editing Modes)

InkCanvas 控件有一个EditingMode 属性允许用户改变用户与InkCanvas的交互方式。你可以在上面画图,选中已画的部分,或者擦除。

EditingMode 属性可以设置以下几种值:

 - None —— 不可以在InkCanvas 上绘图

 - Ink ——可以用户表或者手写笔在InkCanvas 上绘图

 - GestureOnly ——InkCanvas 只响应你的绘图操作和手势,但是不允许你在上面画图

 - InkAndGesture ——InkCanvas 响应你的绘图操作和手势,允许你在上面画图

 - Select ——选择之前绘画的元素

 

 - EraseByPoint ——擦除,每次一个点

 - EraseByStroke ——擦除, 每次一个Strock

你可以运行下面的代码来感受不同编辑模式下InkCanvas 与用户的交互。

<Window x:Class="WpfApplication1.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:sys="clr-namespace:System;assembly=mscorlib"
        xmlns:controls="clr-namespace:System.Windows.Controls;assembly=PresentationFramework"
        Title="InkCanvas Editing Modes" Height="350" Width="525">
    <Window.Resources>
        <ObjectDataProvider x:Key="editingModes" MethodName="GetValues" ObjectType="{x:Type sys:Enum}">
            <ObjectDataProvider.MethodParameters>
                <x:Type TypeName="controls:InkCanvasEditingMode"/>
            </ObjectDataProvider.MethodParameters>
        </ObjectDataProvider>
    </Window.Resources>

    <Grid>
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="*"/>
            <ColumnDefinition Width="Auto"/>
        </Grid.ColumnDefinitions>

        <Border Grid.Column="0" BorderThickness="2" BorderBrush="DodgerBlue"
            Margin="5" >
            <InkCanvas MinHeight="0" MinWidth="0"
                   EditingMode="{Binding ElementName=cboEditingMode, Path=SelectedValue}"/>
        </Border>
        <ComboBox Grid.Column="1" Name="cboEditingMode" Width="100" Height="25" Margin="5"
              ItemsSource="{Binding Source={StaticResource editingModes}}"/>
    </Grid>
</Window>

代码中 xmlns:sysxmlns:controls是两个命名空间。

原文地址:https://wpf.2000things.com/2012/02/02/486-inkcanvas-supports-different-editing-modes/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
InkCanvas是一个Windows Presentation Foundation (WPF)控件,用于在任何WPF应用程序中实现涂鸦和手写输入的功能。它为用户提供了在应用程序中自由绘制、撰写和批注的能力。InkCanvas的主要特点和功能如下: 1. 绘画和撰写功能:InkCanvas提供了一个画布,用户可以使用鼠标、触摸屏、数位板等输入设备进行自由绘画和撰写。它支持不同的画笔样式、颜色和粗细,使用户能够以可定制的方式进行绘画和撰写。 2. 手写输入和识别:通过InkCanvas,用户可以使用触摸屏或数位板进行手写输入。它支持手写的识别和转换,可以将手写的文字转换为可编辑的文本,并提供了一些内置的手写识别功能,如识别基本形状、数学表达式等。 3. 历史记录和回放:InkCanvas可以记录用户的绘画和撰写过程,保存每个笔画的信息,包括位置、时间、颜色等。用户可以使用回放功能重新播放整个绘画过程,以便研究和学习。 4. 多媒体和集成:InkCanvas可以与其他WPF控件和功能进行集成,如图像、文本框、按钮等。用户可以在InkCanvas上绘制图形、写字或进行标记,并将其与应用程序的其他内容结合起来。 5. 扩展性和定制:InkCanvas具有高度的扩展性,允许开发者根据自己的需求进行定制。开发者可以自定义绘画和撰写工具,添加额外的手写识别功能,或者与其他外部设备进行集成。 总结来说,InkCanvas是一个强大的WPF控件,提供了丰富的绘画、撰写和手写输入功能。它可以广泛应用于各种应用程序中,如教育、艺术创作、笔记和批注、图形设计等领域,为用户提供了一种直观、自由和创造性的输入方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值