在正文开始之前需要介绍一个人:Sean Sexton. 来自明尼苏达双城的软件工程师,对C#和WPF有着极深的热情。最为出色的是他维护了两个博客:2,000Things You Should Know About C# 和 2,000 Things You Should Know About WPF 。听到博客名字就懂这个人有多伟大了吧。他以类似微博式的150字简短语言来每天更新一条WPF和C#重要又容易被遗忘的知识。Follow他的博客也有一段日子了,很希望能够分享给大家。
本系列我不仅会翻译他的每一个tip,也会加入自己开发之中的看法和见解,希望能够以更贴近的语言来展示大师的风采。本系列我希望自己也能和他一样坚持下来,每天的进步才能促成伟大。
如果大家更想了解这个伟大的程序员,这个是访谈链接,他在访谈中有谈到自己生平和对编程相关学习的看法,我觉得对大家会帮助很大,有时间后面会出一篇翻译这个访谈的文章供大家阅读,希望大家能够关注。
#8. Xaml和Code Behind
WPF应用是由前端代码Xaml(可扩展应用程序标记语言)和后台代码(托管代码)组成。标记性语言Xaml定义了UI的布局和外观,后台定义了行为和逻辑。WPF技术实现了UI和后台逻辑的分离。
Xaml是一个基于Xml的声明式标记语言编写的。Xaml中组织了所有的控件,以及他们的位置和父子关系。后端.cs托管代码描述了运行时UI的逻辑和行为。在编译阶段xaml和xaml.cs会编译为一个class, 所以xaml.cs你可以看出是patical的。
下面代码是一个Xaml布局的样例:
<Grid> <StackPanel> <Button Content="Save" Height="23" Name="btnSave" Width="75" Click="btnSave_Click" /> <Button Content="Load" Height="23" Name="btnLoad" Width="75" Click="btnLoad_Click" /> </StackPanel> </Grid>
#9. 标记性语言的优势
使用标记性语言Xaml和后台代码Xaml.cs模型开发比一切都定义在代码中有着很多的优势。使用Xaml的好处有:
1. 可以在不影响控件行为的情况下更改用户界面的样式和用户体验。
2. 设计人员可以和开发同时工作,一个负责Xaml做用户界面, 一个负责撰写后台逻辑。分工两不误。
3. 微软提供了强大的设计工具Expression Design和Blend, 使用工具可以免写代码, 设计的界面可以直接导出成Xaml.
4. Vs2013已经和Blend做了很好的集成,可以更高效率的做设计和开发。
#10. 基于Page的页面导航
WPF应用程序可以用一些pages的集合以及其页面导航机制来进行构建。和WindowsForm的文档流式的模型不同,它拥有一个主窗体和一个可以弹出的提醒窗口。
如果想要创建一个基于Page的WPF程序,你需要定义一个Page来代替传统的Window:
<Page x:Class="WpfApplication7.Page1" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" mc:Ignorable="d" d:DesignHeight="300" d:DesignWidth="300" Title="Page1"> <Grid> <Label Content="This is a page, not a window." Height="28" HorizontalAlignment="Left" Margin="52,75,0,0" Name="label1" VerticalAlignment="Top" /> </Grid> </Page>
同时你需要指定app的starturi为该page
<Application x:Class="WpfApplication7.App" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" StartupUri="Page1.xaml"> </Application>
此时你便拥有了一个基于Page导航的WPF应用程序。
#11. WPF vs Silverlight vs ASP.NET
WPF, Silverlight, ASP.NET是微软开发的三大平台。下面列出三种平台各自的特点
WPF:
1. 开发Windows应用程序
2. 以最丰富的用户控件和windows特定功能构建的客户端用户界面。
3. 只能运行在Windows上
4. 需要完整的.net framework支持。
Silverlight:
1. 开发运行在Web端
2. 轻量客户端,丰富的UI控件,类似于WPF客户端呈现
3. 需要安装Silverlight插件在浏览器上
4. Silverlight的Moonlight版本可以在linux上运行
5. 第一次加载时需要安装SL插件。
ASP.NET:
1. 开发Web应用程序
2. 轻量客户端,有着通用的Web控制
3. 可以在服务端运行,也可以运行在所有支持HTML的客户端,包括移动设备的浏览器
4. 不需要在客户端安装插件
#12. 在3D硬件加速应用中使用Direct3D
虽然WPF提供3D绘制,但是3D应用中还是需要Direct3D来进行3D图形的绘制以呈现其最大性能。
而且WPF 4.0是基于DirectX9.0, 所以并不支持Direct3D 10 和 Direct3D 11。
#13. WPF的版本记录
虽然下面列出WPF版本的历史记录和相对应的VS版本。由于WPF是.NET Framework框架一部分,所以版本号是跟着.NET Framework的。下面就是其记录:
.NET Framework 3.0 – Nov, 2006
- 1st release of WPF
- CLR version 2.0
- Visual Studio 2005 SP1
- Incl w/Windows Vista
- .NET Framework 3.5 – Nov, 2007
- Various improvements to WPF
- CLR version 2.0 SP1
- Visual Studio 2008
- Incl w/Windows 7
- .NET Framework 3.5 SP1 – Aug, 2008
- Performance improvements (et al) to WPF
- CLR version 2.0 SP2
- Visual Studio 2008 SP1
- .NET Framework 4.0 – Apr, 2010
- Various improvements to WPF
- CLR version 4.0
- Visual Studio 2010
- .NET Framework 4.5 – Aug, 2012
- Various improvements to WPF
- CLR version 4.5
- Visual Studio 2012
- Incl w/Windows 8
#14. Silverlight and WPF 不同之处
Silverlight原名叫做WPF/E(WPF/Everywhere), 个人觉得原名很拽。通过名字就可以知道SL和WPF遵循相同的编程模型和大部分空间,可以理解为SL是WPF的一个浏览器特殊版本。
核心区别:
1. WPF只运行在WIndows平台
2. WPF需要.NET Framework
3. SL是WPF控件的一个子集
4. SL使用了.NET FRAMEWORK和CLR的子集
WPF独有:
1. 支持流文件 Flow document
2. 支持动态资源 Dynamic resources
3. Merged dictionaries(SL3已有)
4. 重置样式到一个新的FrameworkElement
5. Style继承(SL4已有)
6. 隐式样式TargetType属性(SL5已有)
7. Styles, ControlTemplates, DataTemplate的Triggers
8. Routed commands
9. 自定义标记扩展(Custom markup extensions)(SL5已有)
10. 运行时访问的可视化和逻辑树(Visual Tree 已有 SLSPY工具 也可以看到)
11. 一些WPF独享的控件(AccessText, BulletChrome, ButtonChrome, ContextMenu, Decorator, DocumentPageView, DocumentViewer, GridViewColumnHeader, GridViewRowPresenter, GroupBox, GroupItem, InkCanvas, Menu, MenuItem, PageContent, Ribbon, Separator, StatusBar, TickBar, ToolBar, Track, UniformGrid)
SL独有:
1. 深度缩放(Deep Zoom)
2. 一些SL独享控件( AutoCompleteBox, DataPager, DescriptionViewer, HyperlinkButton, MultiScaleImage, NumericUpDown, ValidationSummary)