当前位置: 首页 > article >正文

WPF InkCanvas 控件详解

1. InkCanvas 是什么?

InkCanvas 是 WPF 提供的一个手写绘图控件,它允许用户使用鼠标、触摸屏或手写笔在界面上进行绘图、标注等操作。

核心特点:
✅ 具备笔迹存储和管理功能。
✅ 提供 ChildrenStrokes 两个集合,分别用于管理子控件绘制的笔迹
✅ 通过 EditingMode 属性控制交互模式,比如绘制、擦除、选择等
✅ 可结合 InkStroke 进行笔迹管理、存储、撤销等操作


2. InkCanvas 的核心集合

InkCanvas 主要包含两个重要的子集合

集合名称 作用
Children 存储 UIElement 子控件,如 ButtonTextBox
Strokes 存储用户绘制的笔迹数据,可用于保存、撤销、重绘等

示例:向 Children 添加一个按钮

Button myButton = new Button { Content = "清除", Width = 80, Height = 30 };
Canvas.SetLeft(myButton, 10);
Canvas.SetTop(myButton, 10);
myInkCanvas.Children.Add(myButton);

示例:操作 Strokes 集合

// 清空所有笔迹
myInkCanvas.Strokes.Clear();

3. InkCanvas.EditingMode 属性 

EditingMode 控制 InkCanvas 的交互方式,共有7 种模式

作用 示例
Ink 默认模式,使用笔绘制线条 适用于手写绘图
GestureOnly 只识别手势,不绘制 用于手势识别
InkAndGesture 允许绘制,同时识别手势 适用于支持手势的绘图软件
Select 允许选择已有的笔迹对象 适用于编辑模式
EraseByStroke 擦除整条笔迹 适用于橡皮擦工具
EraseByPoint 逐点擦除笔迹 适用于精细擦除
None 禁用 InkCanvas 的所有交互 适用于只展示内容,不允许修改

4. 代码示例:不同模式的使用 

1️⃣ 绘制模式(Ink)

<InkCanvas x:Name="my

http://www.kler.cn/a/623263.html

相关文章:

  • Spring Boot自动配置原理解析
  • python实现股票数据可视化
  • 《Python实战进阶》No36: 使用 Hugging Face 构建 NLP 模型
  • 基于 GEE 利用 Landsat4、5、7、8、9 数据计算 MNDWI 指数实现 1990—2024 年研究区水体变化分析
  • Spring Boot 3.4.3 基于 Caffeine 实现本地缓存
  • Linux基础指令(一)
  • golang 的io与os包中的常用方法
  • VITA 模型解读,实时交互式多模态大模型的 pioneering 之作
  • HarmonyOs学习 实验六:tabs标签与Swiper轮播图页面设计
  • 2023年3月全国计算机等级考试真题(二级C语言)
  • 【算法】并查集基础讲解
  • TCP协议与wireshark抓包分析
  • 现代优雅杂志海报徽标设计手写英文字体安装包 Attomes – Brush Handwritten Font
  • 【Prompt实战】邮件意图分类助手
  • git | 版本切换的相关指令
  • 深度学习入门(二):从感知机到神经网络
  • (三)物理设备
  • 创作领域“<em >一</em><em>分</em><em>快</em><em>3</em><em>官</em><em>网
  • 关于参加CSP-J/S认证需符合年龄条件的公告(2025年起)
  • 漏洞挖掘---灵当CRM客户管理系统getOrderList SQL注入漏洞