WPF技术点
常用Path路径
- 正三角形(左):<Path Data="M40,0 L0,30 40,60 z" Stretch="Uniform"/>
- 正三角形(上):<Path Data="M0,40 L30,0 60,40 z" Stretch="Uniform"/>
- 正三角形(右):<Path Data="M0,0 L40,30 0,60 z" Stretch="Uniform"/>
- 正三角形(下):<Path Data="M0,0 L30,40 60,0 z" Stretch="Uniform"/>
- 矩形:<Path Data="M0,0 L1,0 L1,1 L0,1 z" Stretch="Uniform"/>
- 圆形:<Path Data="M100,50 C100,77.614237 77.614237,100 50,100 C22.385763,100 0,77.614237 0,50 C0,22.385763 22.385763,0 50,0 C77.614237,0 100,22.385763 100,50 z" Stretch="Uniform"/>
- 箭头(左):<Path Data="M40,0 L0,30 40,60" Stretch="Uniform"/>
- 箭头(上):<Path Data="M0,40 L30,0 60,40" Stretch="Uniform"/>
- 箭头(右):<Path Data="M0,0 L40,30 0,60" Stretch="Uniform"/>
- 箭头(下):<Path Data="M0,0 L30,40 60,0" Stretch="Uniform"/>
- 半圆(左):<Path Data="M34,0 L34,68 C15.222317,68 0,52.777684 0,34 0,15.222319 15.222317,3.5762787E-07 34,0 z" Stretch="Uniform"/>
- 半圆(上):<Path Data="M34,0 C52.777684,7.1525574E-07 68,15.222319 68,34.000001 L0,34.000001 C3.5762787E-07,15.222319 15.222319,7.1525574E-07 34,0 z" Stretch="Uniform"/>
- 半圆(右):<Path Data="M0,0 C18.777683,3.5762787E-07 34,15.222319 34,34 34,52.777684 18.777683,68 0,68 z" Stretch="Uniform"/>
- 半圆(下):<Path Data="M0,0 L68,0 C68,18.777681 52.777684,34 34,34 15.222319,34 3.5762787E-07,18.777681 0,0 z" Stretch="Uniform"/>
- 椭圆矩形(水平):<Path Data="M34,0 L76,0 C94.777683,9.8347664E-07 110,15.222319 110,34.000001 110,52.777684 94.777683,68.000001 76,68.000001 L34,68.000001 C15.222317,68.000001 0,52.777684 0,34.000001 0,15.222319 15.222317,9.8347664E-07 34,0 z" Stretch="Uniform"/>
- 椭圆矩形(垂直):<Path Data="M34.000001,0 C52.777684,0 68.000001,15.222321 68.000001,34 L68.000001,76 C68.000001,94.777681 52.777684,110 34.000001,110 15.222319,110 8.9406967E-07,94.777681 0,76 L0,34 C8.9406967E-07,15.222321 15.222319,0 34.000001,0 z" Stretch="Uniform"/>
- 菱形:<Path Data="M150,0 L0,75 0,225 150,300 300,225 300,75 z" Stretch="Uniform"/>
Stretch默认使用Uniform,在这种参数下矩形为正方形、圆形为正圆形,如果修改Stretch为Fill,则根据容器高宽进行自由拉伸。
动画
- 缓动函数(使用IE查看):http://tinyurl.com/animationeasing
- WPF动画默认为60帧/s,程序会在系统资源允许的情况下努力使动画达到这个帧率,也可以在代码里手动指定帧率,修该附加属性
Timeline.DesiredFrameRate的值。
变化
LayoutTransform:对元素使用该变换时会真正改变元素的大小和位置,从而引发布局容器的重新计算,因此,只当使用该变化一次,不要在动画中使用。RenderTransform:显示变化,对元素运用该变化时并不会真正的改变元素的大小和位置,只是显示上面产生了变化,因此不会影响布局容器的测量和排版。RenderTransformOrigin:使用变化时可以在具体变化中使用决对坐标,也可以直接指定元素的RenderTransformOrigin,从而使用相对坐标,比如"0.5,0.5"就是该元素的中心点。
字体
- WPF有个问题是小文本显示不太清晰,原因是WPF没有使用GDI渲染文本,好的解决方法是增大文本,在通常的
96dpi的显示器上,文本字号最小控制在15,如果小于这个值最好将文本的TextOptions.TextFormattingMode的值设置为Display,而不是标准的Ideal,这样做会使文本更清晰。 - 检查字体版权是否允许在自己的程序中嵌入,可使用工具:https://www.microsoft.com/en-us/Typography/TrueTypeProperty21.aspx,如果右键属性显示可安装就可以使用。
- 字体加载的两种方式,第一种字体为嵌入式资源:
FontFamily="pack://application:,,,/WpfLabs;component/FontFamilyDemo/#Aileron";第二种字体为文件,可在后台代码中设置:new FontFamily(@"D:\FontFamilyDemo\FontFiles\#Aileron");。
性能
- WPF中,很多元素继承了
Freezable,表示该元素支持冻结,冻结之后变更通知就失效了,但是内存占用会下降,很多情况下都可以将元素冻结,常见的比如SolidColorBrush和Storyboard。在Xaml中使用时先引用命名空间xmlns:options="http://schemas.microsoft.com/winfx/2006/xaml/presentation/options",然后对元素使用<Storyboard options:Freeze="True">。 - 集合虚拟化:启用UI虚拟化的两个附加属性 1、
ScrollViewer.CanContentScroll="True";2、VirtualizingStackPanel.IsVirtualizing="True"。 - 大集合项容器再循环,项容器再循环提高了滚动性能,降低了内存消耗量:
VirtualizingStackPanel.VirtualizationMode="Recycling" - 当集合中使用了分组,默认不会启用虚拟化,需要手动设置
VirtualizingStackPanel.IsVirtualizingWhenGrouping属性纠正这个问题
<ListBox VirtualizingStackPanel.IsVirtualizingWhenGrouping="True"...>
绑定
Xaml中String.Format的使用参考:https://www.cnblogs.com/candyzkn/p/4476832.html
Uri绑定资源路径写法:pack://application:,,,/WpfLabs;component/FontFamilyDemo/#Aileron
Uri绑定本地文件路径写法:pack://siteoforigin:,,,/Aileron.jpg
错误验证
显示错误提示可使用专用的错误模板,即再真正的元素之上附加一层装饰层来展示真正的错误,注意在错误模板中使用AdornedElementPlaceholder来标识真正的控件元素,然后使用路径属性绑定去寻找真正的错误提示,参考19.4.5。
文章中提到的参考来源默认为《WPF编程宝典:使用C# 2012和.NET 4.5 第4版》
WPF技术点的更多相关文章
- WPF技术触屏上的应用系列(六): 视觉冲击、超炫系统主界面、系统入口效果实现
原文:WPF技术触屏上的应用系列(六): 视觉冲击.超炫系统主界面.系统入口效果实现 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7操作系统,54寸大屏电脑电视一体 ...
- WPF技术触屏上的应用系列(五): 图片列表异步加载、手指进行缩小、放大、拖动 、惯性滑入滑出等效果
原文:WPF技术触屏上的应用系列(五): 图片列表异步加载.手指进行缩小.放大.拖动 .惯性滑入滑出等效果 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7操作系统, ...
- WPF技术触屏上的应用系列(四): 3D效果图片播放器(图片立体轮放、图片立体轮播、图片倒影立体滚动)效果实现
原文:WPF技术触屏上的应用系列(四): 3D效果图片播放器(图片立体轮放.图片立体轮播.图片倒影立体滚动)效果实现 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7 ...
- WPF技术触屏上的应用系列(三): 视频播放器的使用及视频播放、播放、暂停、可拖动播放进度效果实现
原文:WPF技术触屏上的应用系列(三): 视频播放器的使用及视频播放.播放.暂停.可拖动播放进度效果实现 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7操作系统,5 ...
- WPF技术触屏上的应用系列(一): 3D 图片(照片)墙、柱面墙(凹面墙或者叫远景墙、凸面墙或者叫近景墙)实现
原文:WPF技术触屏上的应用系列(一): 3D 图片(照片)墙.柱面墙(凹面墙或者叫远景墙.凸面墙或者叫近景墙)实现 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7 ...
- WPF技术触屏上的应用系列(二): 嵌入百度地图、API调用及结合本地数据库在地图上进行自定义标点的实现
原文:WPF技术触屏上的应用系列(二): 嵌入百度地图.API调用及结合本地数据库在地图上进行自定义标点的实现 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7操作系 ...
- 使用WPF技术模拟手机界面
原文:使用WPF技术模拟手机界面 1. 前言 WPF(Windows Presentation Foundation),即"Windows呈现基础",它的目的非常明确,就是用来把数 ...
- 工作总结:WPF技术讲解(大纲)
一.WPF的历史 首先给大家讲述一下Winform的发展里程来展示WPF的历史,告诉大家WPF是在什么背景下诞生的. 二.WPF的特性 与MFC.Windows相比,WPF具有3D呈现特性,XMAL是 ...
- 基于ASP.NET WPF技术及MVP模式实战太平人寿客户管理项目开发(Repository模式)
亲爱的网友,我这里有套课程想和大家分享,假设对这个课程有兴趣的.能够加我的QQ2059055336和我联系. 课程背景 本课程是教授使用WPF.ADO.NET.MVVM技术来实现太平人寿保险有限公司 ...
- 采用WPF技术,开发OFD电子文档阅读器
前言 OFD是国家标准版式文档格式,于2016年生效.OFD文档国家标准参见<电子文件存储与交换格式版式文档>.既然是国家标准,OFD随后肯定会首先在政务系统使用,并逐步推向社会各个方面. ...
随机推荐
- HDU 5200 Trees 二分
题目链接: hdu:http://acm.hdu.edu.cn/showproblem.php?pid=5200 bc(中文):http://bestcoder.hdu.edu.cn/contests ...
- 第6题 ZigZag转换
题目描述如下: The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of ro ...
- 图文详解 IntelliJ IDEA 15 创建普通 Java Web 项目
第 1 部分:新建一个 Java Web Application 项目 File -> New -> Project…,请选择 Java EE 这个模块下的 Web Application ...
- CSUOJ 1141——第四届河南省程序设计大赛
题目的意思是给你一个机器人,初始的时候在某一个给定的路灯位置,机器人要把路边所有的路灯关掉,每个路灯都有一个距离和一个功率,求要把所有的路灯关掉最小的最终能耗是多少? 题目是一个很明显的区间DP.可以 ...
- Python中int()函数的用法浅析
int()是Python的一个内部函数 Python系统帮助里面是这么说的 >>> help(int) Help on class int in module __builti ...
- 如何在vi中设置tab的长度
在使用vi写python时(其实,不管用什么写python程序时,都要注意),首先要将Tab键的长度设为4,因为使用python编程时,我们是通过缩进来实现作用域的,所以要统一Tab键的长度.具体方法 ...
- 2017-2018-2 20165218 实验四《Android开发基础》实验报告
实验三 Android开发基础 课程:java程序设计 姓名:赵冰雨 学号:20165218 指导教师:娄嘉鹏 实验日期:2018.4.14 实验内容: 1.基于Android Studio开发简单的 ...
- 「CodePlus 2017 11 月赛」可做题
这种题先二进制拆位,显然改的位置只有每一段确定的数的开头和结尾,只需要对于每一个可决策位置都尝试一下填1和0,然后取min即可. #include<iostream> #include&l ...
- java类加载过程以及双亲委派机制
前言:最近两个月公司实行了996上班制,加上了熬了两个通宵上线,状态很不好,头疼.牙疼,一直没有时间和精力写博客,也害怕在这样的状态下写出来的东西出错.为了不让自己荒废学习的劲头和习惯,今天周日,也打 ...
- Linux之执行命令操作20170330
介绍一下Linux系统中的代码执行shell等命令的几种操作方式: 一.标准流管道popen 该函数的原型是FILE * popen(const char* command, const char * ...