码迷,mamicode.com
首页 > Windows程序 > 详细

《Programming WPF》翻译 第9章 5.默认可视化

时间:2015-11-14 09:53:36      阅读:290      评论:0      收藏:0      [点我收藏+]

标签:

原文:《Programming WPF》翻译 第9章 5.默认可视化

虽然为控件提供一个自定义外观的能力是有用的,开发者应该能够使用一个控件而不用必须提供自定义可视化。这个控件应该正好工作,当以它最直接的方式使用时。这意味着控件应该提供一组默认的值。

这些默认的可视化存储在组件的二进制资源中,使用的源文件为theme"generic.xaml。如果你在Visual Studio 2005中创建了一个WPF 控件库的工程,这将自动添加这个文件到你的工程中,并且设置它的Build Action为作为资源内嵌。(参见第6章获取更多关于如何在组件中编译xaml资源的信息)

theme"generic.xaml文件中,定义一个样式,携有TargetType指定你的控件。这个样式应该通过一个ControlTemplate标签设置Template属性,为你的控件定义了默认可视化,正如示例9-17显示的。参见第5章获取更多关于如何定义一个提供了模板的样式的信息。

示例9-17

技术分享<?Mapping XmlNamespace="Local" ClrNamespace="CustomControlLib" ?>
技术分享
<ResourceDictionary
技术分享    
xmlns="http://schemas.microsoft.com/winfx/avalon/2005"
技术分享    xmlns:x
="http://schemas.microsoft.com/winfx/xaml/2005"
技术分享    xmlns:local
="Local"
技术分享    
>
技术分享    
<Style TargetType="{x:Type local:MyCustomControl}">
技术分享        
<Setter Property="Template">
技术分享            
<Setter.Value>
技术分享                
<ControlTemplate TargetType="{x:Type local:MyCustomControl}">
技术分享                    
<Border Background="{TemplateBinding Background}"
技术分享                            BorderBrush
="{TemplateBinding BorderBrush}"
技术分享                            BorderThickness
="{TemplateBinding BorderThickness}">
技术分享                        
<ContentPresenter />
技术分享                    
</Border>
技术分享                
</ControlTemplate>
技术分享            
</Setter.Value>
技术分享        
</Setter>
技术分享    
</Style>
技术分享
</ResourceDictionary>

为了确定你的控件获取了默认的主体,你需要让依赖属性系统知道样式所在。如果你不这么做,你只能为你选择的基类获得默认值。示例9-18显示了如何这么做。

示例9-18

技术分享public class MyCustomControl : ContentControl {
技术分享    
static MyCustomControl( ) {
技术分享        ThemeStyleKeyProperty.OverrideMetadata(
typeof(MyCustomControl),
技术分享                 
new FrameworkPropertyMetadata(typeof(MyCustomControl)));
技术分享    }

技术分享    技术分享
技术分享}

技术分享
技术分享

注意到Visual Studio 2005为你自动生成这段代码,当你添加一个新的自定义控件到你的控件库的工程中。


《Programming WPF》翻译 第9章 5.默认可视化

标签:

原文地址:http://www.cnblogs.com/lonelyxmas/p/4963883.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!