WPF-16 图形处理

我们这节主要介绍WPF常用画图标签,由于WPF图形处理设计大量篇幅 ,我们在这里抛砖引玉,具体更多的学习资料链接https://github.com/microsoft/WPF-Samples/tree/master/Graphics  该链接中微软提供了大量的学习Demo,WPF图形处理最大的区别在于WPF底层使用的DirectX,Winform底层使用的是GDI+,所以WPF的图形界面上更胜一筹。

1. Line

该对象表示画一条线,我们在学习几何图形的时候,大家都知道两点可以确定一条线,所以我们画一条直线只需要给出两个坐标点可以

d4e3fe749ea2528d11456c85e59abe0e.png

<Canvas><Line X1="0" Y1="0" X2="300" Y2="300" StrokeThickness="2" Stroke="Red">
</Canvas>

2.Rectangle

    可以用Rectangle画矩形,RadiusX和RadiusY设置矩形角弧度

ad60e64e0c870cd2068970e192fb532d.png

<Canvas><Rectangle Width="120" Height="100" RadiusX="5" RadiusY="5"Stroke="Green" StrokeThickness="2" Fill="Red"></Rectangle></Canvas>

3.Ellipse(画椭圆)

fdd7f5393d782d483a7c7d8b8b667002.png

<Canvas><Ellipse Height="200" Width="400" StrokeThickness="2" Stroke="Red"  Fill="Gold"/>
</Canvas>

4.Path(表示几何路径)

该对象包含了一系列对象的组合,例如(直线,矩形,椭圆),Data属性可以通过两种方式来表示:

4.1 StreamGeometry方式

5cea5a32f470a41a3efa5d7c0b59eda1.png

<Canvas><Path Stroke="Black" Fill="Gray"Data="M 10,100 C 10,300 300,-200 300,100" />
</Canvas>

我们来介绍一下Data中的指令:

1. 移动指令(Move Command): 指定图形的起点, M或m表示起始点,大写绝对值,小写相对值,例如:  M 10,100或m 10,100 是一个System.Windows.Point

2. 绘制命令(Draw Commands):绘制命令可以由几个图形命令组成,我们可以使用下面图形命令:直线、水平线、竖线、三次贝塞尔曲线、二次贝塞尔曲线、平滑三次贝塞尔曲线、平滑二次贝塞尔曲线和椭圆弧

直线命令(Line Command):L endPoint或l endPoint表示结束点坐标,例如:l 20 30 and L 20,30 ,endPoint表示一个System.Windows.Point类型

水平线命令(Horizontal Line Command):H x 或者 h x 当前点和指定的 x 坐标之间创建一条水平线,例如:H 90,x表示System.Double

竖线命令(Vertical Line Command):V y或者 v y  在当前点和指定的 y 坐标之间创建一条竖线,例如:v 90 ,y表示System.Double类型

三次贝塞尔曲线命令(Cubic Bezier Curve Command) 

语法如下:C  CP1  CP2  EP 或者 c  CP1  CP2  EP 

备注:CP=controlPoint,EP=endPoint

例如 :C  10,300  300,-200  300,100  CP1 和CP2  和EP分别代表System.Windows.Point类型

二次贝塞尔曲线命令(Quadratic Bezier Curve Command):Q x,y x,y

语法如下:Q  CP  EP 或者 1  CP1  CP2  EP 

备注:CP=controlPoint,EP=endPoint

例如 :Q  10,300  300,100   CP和EP分别代表System.Windows.Point类型

平滑三次贝塞尔曲线命令(Smooth cubic Bezier curve Command):S x,y x,y

语法如下:S CP EP  或者 s CP EP

备注:CP=controlPoint,EP=endPoint

例如 :S  10,300  300,100   CP和EP分别代表System.Windows.Point类型

平滑二次贝塞尔曲线命令(Smooth quadratic Bezier curve Command):

语法如下:T EP 或者 t EP

例如 :S  10,300   EP分别代表System.Windows.Point类型

椭圆弧命令(Elliptical Arc Command)

语法如下:A 或者a

参数 :  

  1. size  圆弧的 x 轴和 y 轴半径

  2. rotationAngle 椭圆的旋转,以度为单位,System.Double类型

  3. isLargeArcFlag 如果圆弧角度应为 180 度或更大请设置为 1,否则    设置为 0

  4. sweepDirectionFlag 如果以正角方向绘制圆弧,请设置为 1;否则设置为 0

  5. endPoint是一个System.Windows.Point类型

3. 关闭指令(The Close Command):Z或者z , 结束当前图形,用一条直线连接图形的结束点和开始点

4.2 PathFigureCollection 方式

我们还引用刚才图形

<Canvas><Path Stroke="Black" Fill="Gray"><Path.Data><PathGeometry Figures="M 10,100 C 10,300 300,-200 300,100" /></Path.Data></Path></Canvas>

示例:

4e6522ad8a1e5b68a563a2c5ab7f9b88.png

<Path Stroke="Black" StrokeThickness="1"><Path.Data><PathGeometry><PathGeometry.Figures><PathFigureCollection><PathFigure IsClosed="True" StartPoint="10,100"><PathFigure.Segments><PathSegmentCollection><LineSegment Point="100,100" /><LineSegment Point="100,50" /></PathSegmentCollection></PathFigure.Segments></PathFigure></PathFigureCollection></PathGeometry.Figures></PathGeometry></Path.Data></Path>

我们可以看到这种方式对我们修改路径特别方便,PathSegment 派生类如下:

System.Windows.Media.ArcSegment

System.Windows.Media.BezierSegment

System.Windows.Media.LineSegment

System.Windows.Media.PolyBezierSegment

System.Windows.Media.PolyLineSegment

System.Windows.Media.PolyQuadraticBezierSegment

System.Windows.Media.QuadraticBezierSegment

那我们怎么选择这两种方式呢? 在创建路径后无需修改路径时,请使用StreamGeometry;如果需要修改路径,请使用 PathGeometry

5.Polygon

可以使用Polygon元素绘制闭合图形。创建一个Polygon元素并使用其Points属性指定形状的顶点。将自动绘制一条连接第一个点和最后一个点的线。还可以指定 Fill 和/或 Stroke

015c8baf5dffcae8cc73bac66ad807fc.png

<Canvas Height="300" Width="300"><Polygon Points="10,110 60,10 110,110" Fill="Blue" /><Polygon Points="10,110 60,10 110,110"Fill="Blue"Stroke="Black" StrokeThickness="4"Canvas.Top="150" /><Polygon Points="10,110 110,110 110,10"Fill="Blue"Canvas.Left="150" /><Polygon Points="10,110 110,110 110,10"Stroke="Black" StrokeThickness="4"Canvas.Left="150" Canvas.Top="150" /></Canvas>

6.Polyline

如果想绘制折线,我们可以创建 Polyline 元素并设置 Points 属性指定形状顶点。最后,使用 Stroke 和 StrokeThickness 属性描述折线轮廓,Polyline 元素不是封闭形状

213f94d4983bf5f0e321c26b79ca9764.png

<Canvas Height="400" Width="400"><PolylinePoints="10,110 60,10 110,110"Stroke="Black"StrokeThickness="4" /><PolylinePoints="10,110 110,110 110,10"Stroke="Black"StrokeThickness="4"Canvas.Left="150" /></Canvas>

这节我们主要介绍了常用图形绘制对象Line,Rectangle,Ellipse,Path,Polygon,Polyline用法,可以看出WPF提供了强大的绘图功能。希望对各位有所帮助,谢谢!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/280808.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

纯CSS制作各种各样的网页图标(三角形、暂停按钮、下载箭头、加号等)

三角形 <div class"box"></div> <style>.box{ width: 0;height: 0;border-top: 50px solid transparent;border-bottom: 50px solid transparent;border-left: 50px solid transparent;border-right: 50px solid red; } </style> 平行四边形…

您的MyFitnessPal帐户几乎肯定已被黑客入侵,请立即更改密码

If you’re one of the millions of the 150 million MyFitnessPal users, bad news: hackers have your email address, your user name, and your hashed password. 如果您是1.5亿MyFitnessPal用户中的数百万用户之一&#xff0c;那么这是个坏消息&#xff1a;黑客拥有您的电…

ios 启用 证书_如何在iOS 10中启用就寝提醒,轻柔的唤醒和睡眠跟踪

ios 启用 证书If you have trouble regularly getting a full night’s sleep, the new Bedtime feature in iOS 10 might just help. Set a wake up time and how many hours of sleep you need, and iOS offers bedtime reminders, more gentle alarms, and basic sleep trac…

struts OGNL表达式

OGNLContext对象有两部分构成 一部分是ROOT&#xff1a;可以放置任何对象作为ROOT 另外一部分Context&#xff1a;必须是Map形式&#xff08;键值对&#xff09; OGNL表达式操作 package cn.future.a_ognl;import java.util.HashMap; import java.util.Map;import ognl.Ognl; i…

制作一个用户头像选择器仿 WeGame

制作一个用户头像选择器仿 WeGameCropAvatar作者&#xff1a;WPFDevelopersOrg - 驚鏵原文链接&#xff1a;https://github.com/WPFDevelopersOrg/WPFDevelopers框架使用.NET40&#xff1b;Visual Studio 2019;制作一个用户头像选择Canvas为父控件所实现&#xff0c;展示图片使…

网曝南方电网搞末位淘汰和裁员,给各下属单位强制规定辞退率和降岗降级率!...

电网作为垄断性国企&#xff0c;在人们心中一向是好单位的代名词&#xff0c;但最近却有网友曝光南方电网搞末位淘汰和裁员&#xff0c;给各单位下了辞退率和降岗降级率&#xff0c;每个单位都要开除一部分人&#xff0c;或者把一部分人岗级降下来。有南方电网员工马上跑出来辟…

二维数组中的查找

2019独角兽企业重金招聘Python工程师标准>>> 题目 在一个二维数组中&#xff0c;每一行中的数都按照从左到右、从上到下的递增顺序排列。要求输入一个整数&#xff0c;判断数组中是否存在该整数 实现代码 function find($matrix, $rows, $columns, $key) {//TODO 参…

蓝牙追踪_如何使用蓝牙追踪器跟踪您的东西

蓝牙追踪We’ve all done it: you misplace something important and you spend a lot of time (with a lot of stress) backtracking to locate it again. With Bluetooth tracking devices you can make the hunt a lot easier, less stressful, and even avoid losing the t…

vba发送邮件 签名_如何更改“从Windows 10的邮件发送”签名

vba发送邮件 签名The Windows 10 Mail app is a decent email client that allows you to add other email accounts in addition to your Microsoft accounts. You’ll notice, though, that any emails you write in the Mail app have a default signature. Windows 10 Mail…

JAVA_SE基础——24.面向对象的内存分析

黑马程序猿入学blog ... 接着上一章的代码&#xff1a; //车类 class Car{//事物的公共属性使用成员变量描写叙述。String name; //名字的属性 String color; //颜色属性 int wheel; //轮子数 //事物的公共行为使用函数描写叙述。 public void run(){ System.out.println(name&…

煮茶社区AVR开发板第二版[转]

原图:http://blossom.cnblogs.com/gallery/image/21891.html

[Kogel.Subscribe.Mssql]SQL Server增量订阅,数据库变更监听

此框架是SQL Server增量订阅&#xff0c;用来监听增删改数据库数据变更目前仅支持SQL Server&#xff0c;后续会支持MySQL和Oracle&#xff0c;Nuget上可以下载安装或者使用Nuget命令添加包dotnet add package Kogel.Subscribe.Mssql --version 0.0.0.1可以用来处理DB主从同步&…

MFC 单选按钮Radio使用注意

使用MFC Radio时遇到问题&#xff1a;数据交换时出现断言崩溃框 定位于&#xff1a; 解决方法&#xff1a; 1、按CTRLD&#xff0c;保证同一组内的radio的tab序号是连续的&#xff1b; 2、同一组内&#xff0c;设置 radio1的属性&#xff1a; group、tabstop、auto均为true&am…

C# 字符串操作:split、substring、Format

1.split split可以使用多个字符切割。 "test[12]"切割后是3个字符串&#xff0c;最后一个为空。 string testString "test[12]";string[] testData testString.Split([,]);int testLength testData.Length;Console.WriteLine(testLength.ToString());…

flac格式转换mp3格式_MP3,FLAC和其他音频格式之间有什么区别?

flac格式转换mp3格式Digital audio has been around a very long time so there’s bound to be a plethora of audio formats out there. Here are some of the more common ones, what differentiates them, and what to use them for. 数字音频已经存在了很长时间&#xff…

Kubernetes:Flomesh 服务网格与多集群通信

Kubernetes 成功普及了容器集群的概念。许多用户已经在多个集群中部署应用&#xff0c;组织需要运行多个 Kubernetes 集群可能来自以下原因&#xff08;并非详尽列表&#xff09;&#xff1a;• 位置• 延迟&#xff08;尽可能在靠近客户的地方运行应用程序&#xff09;• 管辖…

袁永福软件行业从业经历

简化版》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》 袁永福简历 袁永福&#xff0c;男&#xff0c;1980年生于江西省九江市都昌县&#xff0c;2001年南京东南大学动力工程系本科毕业。毕业后一直从事计算机软件开发工作&…

小程序之地图导航

同学们平常使用地图的时候应该都有注意到&#xff0c;当我们在一个应用中选择一个地址&#xff0c;打开一个地图&#xff0c;往往会有两种显示方式&#xff0c;一个是显示当前自己的位置&#xff1b;一个是显示对方&#xff0c;也就是目的地的位置&#xff1b;如下图&#xff1…

PS2019摄影后期处理(一)

高高手之路笔记 一、学习方法 内外兼修&#xff1a;技术会淘汰、更新&#xff0c;自己内在也要提高。 二、照片格式、色彩空间 JPEG TIFF RAW sRGB&#xff1a;互联网相关图片&#xff0c;电子设备 三、照片风格 自己定义照片格式&#xff0c;直接后期效果 相机自带工具&a…

mdnsresponder_什么是mDNSResponder.exe / Bonjour,如何卸载或删除它?

mdnsresponderYou are no doubt reading this article because you’ve noticed the mDNSResponder.exe process running in Task Manager, you don’t remember installing it, and it doesn’t show up in the Add/Remove programs in Control Panel. So what is it, and how…