WPF使用Geometry绘制几何图形_第1页
WPF使用Geometry绘制几何图形_第2页
WPF使用Geometry绘制几何图形_第3页
WPF使用Geometry绘制几何图形_第4页
WPF使用Geometry绘制几何图形_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第WPF使用Geometry绘制几何图形在WPF的DrawingContext对象中,提供了基本的绘制椭圆和矩形的API:DrawEllipse和DrawRectangle。但是,这些是远远不够用的,我们在日常应用中,更多的是使用DrawGeometry函数,它可以绘制更多复杂的几何图形,并且提供了许多强大而易用的函数,在大多数场景下,甚至可以取代DrawEllipse和DrawRectangle函数。

在WPF图形体系中,Geometry类表示几何图形的基类,使用的时候是实例化它的一些子类,具体的有:

基本几何图形

线段:LineGeometry

矩形:RectangleGeometry

椭圆:EllipseGeometry

几何图形集合

路径集合图形PathGeometry里可以包含一系列几何图形集合,常见的有:

线段:LineSegment

弧:ArcSegment

贝塞尔曲线:贝塞尔曲线系列还比较多,具体有如下几种:

BezierSegment:在两个点之间创建一条三次方贝塞尔曲线。

PolyBezierSegment:创建一系列三次方贝塞尔曲线。

PolyQuadraticBezierSegment:创建一系列二次贝塞尔曲线。

QuadraticBezierSegment:创建一条二次贝塞尔曲线。

除了这种组合的方式之外,系统还提供了一个通过一系列API来绘制的StreamGeometry。它不支持绑定,动画,相应也更加灵活而高效。

StreamGeometrygeometry=newStreamGeometry;

using(StreamGeometryContextctx=geometry.Open())

ctx.BeginFigure(newPoint(10,100),true,true);

ctx.LineTo(newPoint(100,100),true,false);

ctx.LineTo(newPoint(100,50),true,false);

}

复合几何图形

使用GeometryGroup、CombinedGeometry或者通过调用静态的Geometry方法Combine,可以创建复合几何图形对象。它们主要的区别是:

CombinedGeometry对子图形进行叠加操作,没有面积的子图形将被丢弃。只能组合两个子图形(但是这两个子图形也可以是复合几何图形)。GeometryGroup只进行组合,而不进行面积叠加。可以添加多个子图形。有关示例,请参见如何:创建复合形状。

CombinedGeometry的叠加方式有四种:Union、Intersect、Exclude和Xor,它们的效果为:

这些在我们的日常应用中是非常有用的,具体示例请参看MSDN文章:如何:创建复合形状和如何:创建组合的几何图形。

Geometry对象中本身还包含了一系列非常有用的方法,如:

GetArea:获取Geometry的面积。FillContains:确定是否包含其他Geometry。StrokeContains:确定是否包含指定的点。Bounds:获取外接矩形

这些都是非常常用的方法,例如FillContains,StrokeContains用于鼠标命中测试是非常方便的。

Geometry对象并不能作为图像独立呈现出来,它一般有如下几种呈现方式:

在Path中呈现:

可以作为GeometryDrawing.Geometry的参数呈现为Path对象

PathStroke="Black"StrokeThickness="1"

Path.Data

LineGeometryStartPoint="10,20"EndPoint="100,130"/

/Path.Data

/Path

这种方式下写一些简单的几何图形还行,但对于PathGeometry来说有些冗繁,因此XAML采用了一种简单的路径标记语法来简化这一过程,

PathStroke="Black"Fill="Gray"

Path.Data

PathGeometryFigures="M10,100C10,300300,-200300,100"/

/Path.Data

/Path

甚至可以直接简化为:

PathStroke="Black"Fill="Gray"Data="M10,100C10,300300,-200300,100"/

这种语法在一些第三方矢量图转换过来的文件中非常常见,如果能熟练掌握的话,写一些简单的几何图形也是非常方便的。

在DrawingContext中呈现

可以作为DrawingContext.DrawGeometry的参数呈现,这种方式后面的文章中做会更多的说明,这里就不多介绍了。

在GeometryDrawing中呈现

可以作为GeometryDrawing.Geometry的参数呈现为Drawing对象

GeometryDrawingBrush="MediumBlue"

GeometryDrawing.Geometry

GeometryGroup

EllipseGeometryRadiusX="20"RadiusY="45"Center="50,50"/

EllipseGeometryRadiusX="45"RadiusY="20"Center="50,50"/

/GeometryGroup

/GeometryDrawing.Geometry

/GeometryDrawing

当然,Drawing对象也不能独立呈现,一般是作为DrawingBrush或作为DrawingContext.DrawDrawing的参数来使用的

其它用途:

作为UIElement.Clip参数裁剪控件

ImageSource="sampleImages\Waterlilies.jpg"Width="200"Height="150"HorizontalAlignment="Left"

Image.Clip

EllipseGeometryRadiusX="100"RadiusY="75"Center="100,75"/

/Image.Clip

/Image

另外,也常用在DrawingGroup.ClipGeometry和DrawingContext.PushClip中裁剪图像。

作为DoubleAnimationUsingPath.PathGeometry属性生成路径动画

可以将PathGeom

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论