WPF Path详解

WPF提供两个类来描述路径数据:一个是StreamGeometry,另一个是PathFigureCollection。

<Path Stroke="Black" Data="M 100,240 C 510,300 80,100 300,160 H40 v80" />的形式是StreamGeometry的XAML代码表示形式,也是最简洁的表示形式。

<Path Stroke="Black" StrokeThickness="1" Fill="#CCCCFF">
  <Path.Data>
    <PathGeometry Figures="M 10,100 C 10,300 300,-160 300,100" />
  </Path.Data>
</Path>
这样的方式是使用PathFigureCollection的XAML代码表示方式。

这两种方式都可以达至同一种显示效果,那么,什么时候使用StreamGeometry,什么时候使用PathFigureCollection方式呢?
一般地,当你建立路径后,不再需要修改时,可使用StreamGeometry方式,如果还需要对路径数值进行修改,则使用PathFigureCollection方式(这里就是PathGeometry)。

下面来解释一下“M 100,240 C510,300 80,100 300,160 H40 v80”这样字符串的意义。
分为四种情况来解释:
1. 移动指令:Move Command(M):M 起始点  或者:m 起始点
比如:M 100,240或m 100,240
使用大写M时,表示绝对值; 使用小写m时; 表示相对于前一点的值,如果前一点没有指定,则使用(0,0)。

2. 绘制指令(Draw Command):
我们可以绘制以下形状:
(1) 直线:Line(L)
(2) 水平直线: Horizontal line(H)
(3) 垂直直线: Vertical line(V)
(4) 三次方程式贝塞尔曲线: Cubic Bezier curve(C)
(5) 二次方程式贝塞尔曲线: Quadratic Bezier curve(Q)
(6) 平滑三次方程式贝塞尔曲线: Smooth cubic Bezier curve(S)
(7) 平滑二次方程式贝塞尔曲线: smooth quadratic Bezier curve(T)
(8) 椭圆圆弧: elliptical Arc(A)

上面每种形状后用括号括起的英文字母为命令简写的大写形式,但你也可以使用小写。使用大写与小写的区别是:大写是绝对值,小写是相对值。

比如:L 100, 200 L 300,400表示从绝对坐标点(100,200)到另一绝对坐标点(300,400)的一条直线。而l 100, 200 l 300,400则表示相对上一点(如果未指定,则默认为(0,0)坐标点)开始计算的坐标点(100,200)到坐标点为(300,400)的一条直线。

当我们重复使用同一种类型时,就可以省略前面的命令。比如:L 100, 200 L 300,400简写为:L 100, 200 300,400。

<Path Stroke="Black" StrokeThickness="1" Data="M 10,10 100,10 100,40 Z M 10,100 L 100,100 100,50 Z" />
这里有一个你暂时还没见过的Z指令,它就是一个关闭指令(close Command),表示封闭指定形状,即将首尾点连接起来形成封闭的区域。

绘制指令格式语法:

(1) 直线:Line(L)
格式:L 结束点坐标 或: l 结束点坐标。
比如:L 100,100 或 l 100 100。坐标值可以使用x,y(中间用英文逗号隔开)或x y(中间用半角空格隔开)的形式。

(2) 水平直线  Horizontal line(H):绘制从当前点到指定x坐标的直线。
格式:H x值 或 h x值(x为System.Double类型的值)
比如:H 100或h 100,也可以是:H 100.00或h 100.00等形式。

(3) 垂直直线 Vertical line(V):绘制从当前点到指定y坐标的直线。
格式:V y值 或 v y值(y为System.Double类型的值)
比如:V 100或y 100,也可以是:V 100.00或v 100.00等形式。

(4) 三次方程式贝塞尔曲线 Cubic Bezier curve(C):通过指定两个控制点来绘制由当前点到指定结束点间的三次方程贝塞尔曲线。
格式:C 第一控制点 第二控制点 结束点 或 c 第一控制点 第二控制点 结束点
比如:C 100,200 200,400 300,200 或 c 100,200 200,400 300,200
其中,点(100,200)为第一控制点,点(200,400)为第二控制点,点(300,200)为结束点。

(5) 二次方程式贝塞尔曲线 Quadratic Bezier curve(Q):通过指定的一个控制点来绘制由当前点到指定结束点间的二次方程贝塞尔曲线。
格式:Q 控制点 结束点 或 q 控制点 结束点
比如:q 100,200 300,200。其中,点(100,200)为控制点,点(300,200)为结束点。

(6) 平滑三次方程式贝塞尔曲线: Smooth cubic Bezier curve(S):通过一个指定点来“平滑地”控制当前点到指定点的贝塞尔曲线。
格式:S 控制点 结束点 或 s 控制点 结束点
比如:S 100,200 200,300

(7) 平滑二次方程式贝塞尔曲线 smooth quadratic Bezier curve(T):与平滑三次方程贝塞尔曲线类似。
格式:T 控制点 结束点 或 t 控制点 结束点
比如:T 100,200 200,300

(8) 椭圆圆弧: elliptical Arc(A) : 在当前点与指定结束点间绘制圆弧。
A 尺寸 圆弧旋转角度值 优势弧的标记 正负角度标记 结束点
或:
a 尺寸 圆弧旋转角度值 优势弧的标记 正负角度标记 结束点
尺寸(Size): System.Windows.Size类型,指定椭圆圆弧X,Y方向上的半径值。
旋转角度(rotationAngle):System.Double类型。
圆弧旋转角度值(rotationAngle):椭圆弧的旋转角度值。
优势弧的标记(isLargeArcFlag):是否为优势弧,如果弧的角度大于等于180度,则设为1,否则为0。
正负角度标记(sweepDirectionFlag):当正角方向绘制时设为1,否则为0。
结束点(endPoint):System.Windows.Point类型。

3. 关闭指令(close Command):用以将图形的首、尾点用直线连接,以形成一个封闭的区域。
用Z或z表示。

WPF 常用path示例 http://www.cnblogs.com/xiaokang088/archive/2011/04/30/2032924.html

### WPFPath 的使用方法及示例 WPF(Windows Presentation Foundation)中的 `Path` 控件是用于绘制二维图形的重要工具。通过设置其 `Data` 属性,可以定义复杂的几何形状,并结合 `Fill` 和 `Stroke` 属性来控制填充和边框样式[^2]。 #### 1. 使用 XAML 定义 Path 在 XAML 中,可以通过 `StreamGeometry` 的简化形式直接定义路径数据。以下是一个示例: ```xml <Path Stroke="Black" Data="M 100,240 C 510,300 80,100 300,160 H40 v80" /> ``` 上述代码中,`M` 表示移动到指定点,`C` 表示绘制贝塞尔曲线,`H` 和 `v` 分别表示水平和垂直线段的绘制[^1]。 #### 2. 使用代码动态创建 Path 除了在 XAML 中定义外,还可以通过 C# 动态生成 `Path` 对象。例如: ```csharp Path thrustForceRec = new Path(); thrustForceRec.Fill = Brushes.Green; PathFigure thrustForceFigure = new PathFigure(); thrustForceFigure.IsClosed = true; thrustForceFigure.StartPoint = new Point(0, t1Position); thrustForceFigure.Segments.Add(new LineSegment(new Point(100, t1Position), false)); thrustForceFigure.Segments.Add(new LineSegment(new Point(100, 250), false)); thrustForceFigure.Segments.Add(new LineSegment(new Point(0, 250), false)); PathGeometry thrustForceGeometry = new PathGeometry(); thrustForceGeometry.Figures.Add(thrustForceFigure); thrustForceRec.Data = thrustForceGeometry; thrustCanvas.Children.Add(thrustForceRec); ``` 此代码片段展示了如何动态创建一个封闭的矩形路径,并将其添加到 `Canvas` 中[^4]。 #### 3. Path Data 微语言详解 `Path` 的 `Data` 属性使用一种微语言来描述几何图形。以下是常见的命令及其含义: - **M/m**: 移动到指定点。 - **L/l**: 绘制直线到目标点。 - **H/h**: 绘制水平线到目标点。 - **V/v**: 绘制垂直线到目标点。 - **C/c**: 绘制三次贝塞尔曲线。 - **S/s**: 绘制平滑贝塞尔曲线。 - **Q/q**: 绘制二次贝塞尔曲线。 - **T/t**: 绘制平滑二次贝塞尔曲线。 - **Z/z**: 关闭路径。 为了提高可读性,建议在编写长路径数据时适当添加空格[^3]。 #### 4. 最佳实践 - 在复杂图形中,优先使用相对命令(小写字母)以创建可缩放的图形。 - 考虑使用设计工具(如 Expression Design、Inkscape 或 Adobe Illustrator)生成 `Path Data`。 - 将常用图形定义为资源,以便在大型应用中重复使用。 - 使用调试工具(如 Snoop)检查和优化复杂路径。 ---
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值