WPF快速指导2:模板
本文摘要:
1:模板作用;
2:样式模板;
3:数据模板;
4:如何使用ControlTemplate;
5:如何使用DataTemplate;
一:模板作用
1:样式模板,在应用程序内部维护和共享外观;
2:数据模板,实现表现形式和逻辑的分离;
二:样式模板
如:
片段1:
<Style TargetType="TextBlock"><Setter Property="HorizontalAlignment" Value="Center" /><Setter Property="FontFamily" Value="Comic Sans MS"/><Setter Property="FontSize" Value="14"/></Style>
以上的样式模板用于对页面范围内TextBlock进行规范。注意Style中一个属性关键字BaseOn,如:
片段2
<Style BasedOn="{StaticResource {x:Type TextBlock}}"TargetType="TextBlock"x:Key="TitleText">……</Style>
这个属性标识是指如上的风格基于片段1,同时进行拓展。
关于样式模板需要注意的几个方面:
1:如果有多个 Setter 对 Style 的同一属性进行设置,则最后声明的 Setter 优先;
2:以编程方式设置属性,textblock1.Style = (Style)(this.Resources["TitleText"]);
三:数据模板
数据模板的作用就是实现表现形式和逻辑的分离。
查看如下的代码片段,
片段3:
<ListBox ItemsSource="{Binding Source={StaticResource MyPhotos}}" > </ListBox>
这就意味着这个ListBox的数据源是资源中定义的MyPhotos数据源,如下:
片段4
<Window.Resources><ObjectDataProvider x:Key="MyPhotos" ObjectType="{x:Type local:PhotoList}"/></Window.Resources>
这个资源定义中有一个Package名local,我们如下定义:
xmlns:local="clr-namespace:WpfApplication2"
同时也指定了数据源的类型为PhotoList,即存在类为PhotoList以及PhotoList所对应的Item,类Photo。
在UI呈现的时候,需要为MyPhotos动态添加数据,添加数据的代码如下:
PhotoList Photos;private void WindowLoaded(object sender, RoutedEventArgs e){Photos = (PhotoList)(this.Resources["MyPhotos"] as ObjectDataProvider).Data;Photos.Path = "...\\...\\Images";}
注意,以上代码如果运行的话,ListBox呈现的是Photo的ToString()。要按照我们的需求显示实际的图片,仍旧需要定义DataTemplate,即
片段5:
<DataTemplate DataType="{x:Type local:Photo}"> <Border Margin="3"> <Image Source="{Binding Source}"/> </Border> </DataTemplate>
四:如何使用ControlTemplate
WPF 中的许多控件都使用 ControlTemplate 来定义控件的结构和外观,这样可将控件外观和控件功能分离开。 重新定义控件的 ControlTemplate 可以彻底改变控件的外观。使用ControlTemplate还可以创建自定义控件,在这里不做赘述。
改变现有控件的一个典型例子如下:
<Style TargetType="Button"><!--Set to true to not get any properties from the themes.--><Setter Property="OverridesDefaultStyle" Value="True"/><Setter Property="Template"><Setter.Value><ControlTemplate TargetType="Button"><Grid><Ellipse Fill="{TemplateBinding Background}"/><ContentPresenter HorizontalAlignment="Center"VerticalAlignment="Center"/></Grid></ControlTemplate></Setter.Value></Setter></Style>
五:如何使用DataTemplate
DataTemplate 可用于自定义数据在控件上的显示方式。除了自定义数据外观之外,DataTemplate 还可以包含 UI 元素,这样大大增加了自定义 UI 的灵活性。DataTemplate的用法见下一章。本文转自最课程陆敏技博客园博客,原文链接:http://www.cnblogs.com/luminji/archive/2011/01/09/1931392.html,如需转载请自行联系原作者