闲话WPF之五(XAML中的类型转换)
?在前面關(guān)于XAML的Post當(dāng)中,簡單說明了XAML如果引入自定義名稱空間。還提到過XAML基本上也是一種對象初始化語言。XAML編譯器根據(jù)XAML創(chuàng)建對象然后設(shè)置對象的值。比如:
<Button Width=”100”/>
很明顯,我們設(shè)置Button的寬度屬性值為100。但是,這個“100”的字符串為什么可以表示寬度數(shù)值呢?在XAML中的所有屬性值都是用文本字符串來描述,而它們的目標(biāo)值可以是double等等。WPF如何將這些字符串轉(zhuǎn)換為目標(biāo)類型?答案是類型轉(zhuǎn)換器(TypeConverter)。WPF之所以知道使用Double類型是因為在FrameworkElement類中的WidthProperty字段被標(biāo)記了一個TypeConverterAttribute,這樣就可以知道在類型轉(zhuǎn)換時使用何種類型轉(zhuǎn)換器。TypeConverter是一種轉(zhuǎn)換類型的標(biāo)準(zhǔn)方法。.NET運行時已經(jīng)為標(biāo)準(zhǔn)的內(nèi)建類型提供了相應(yīng)的TypeConverter。所以我們可以用字符串值指定元素的屬性。
然而并不是所有的屬性都標(biāo)記了一個TypeConverterAttribute。這種情況下,WPF將根據(jù)屬性值的目標(biāo)類型,比如Brush,來判斷使用的類型轉(zhuǎn)換器。雖然屬性本身沒有指定TypeConverterAttribute,但是目標(biāo)類型Brush自己標(biāo)記了一個TypeConverterAttribute來指定它的類型轉(zhuǎn)換器:BrushConverter。所以在轉(zhuǎn)換這種屬性時將自動使用目標(biāo)值類型的BrushConverter將文本字符串類型的屬性值轉(zhuǎn)換為Brush類型。
類型轉(zhuǎn)換器對開發(fā)人員有什么作用呢?通過它我們可以實現(xiàn)自定義的類型轉(zhuǎn)換。下面一個例子演示了如何從Color類型轉(zhuǎn)換為SolidColorBrush。
[ValueConversion(typeof(Color), typeof(SolidColorBrush))]
public class ColorBrushConverter : IValueConverter
{
??? public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
??? {
??????? Color color = (Color)value;
??????? return new SolidColorBrush(color);
??? }
??? public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
??? {
??????? return null;
??? }
}
然后我們可以在資源中定義一個ColorBrushConverter 實例(src是一個自定義命名空間,引入了ColorBrushConverter 類所在的Assembly)。
<Application.Resources>
? <src:ColorBrushConverter x:Key="ColorToBrush"/>
</Application.Resources>
最后使用這個自定義的類型轉(zhuǎn)換器:
<DataTemplate DataType="{x:Type Color}">
? <Rectangle Height="25" Width="25" Fill="{Binding Converter={StaticResource ColorToBrush}}"/>
</DataTemplate>
其實WPF所使用的這種類型轉(zhuǎn)換從.Net Framework1.0已經(jīng)開始并廣泛應(yīng)用。有興趣的朋友可以參考MSDN的介紹:通用類型轉(zhuǎn)換(Generalized Type Conversion)
總結(jié)
以上是生活随笔為你收集整理的闲话WPF之五(XAML中的类型转换)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Asp.NET 的几个高级技巧
- 下一篇: Oracle 数据库DBA管理手册!