一步一步学Silverlight 2系列(9):使用控件模板

一步一步学Silverlight 2系列(9):使用控件模板,第1张

概述概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, Ironpython,对JSON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步学Silverlight 2系列》文章带您快速进入Silverlight 2开发。 概述

Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic,Visual C#,IronRuby,Ironpython,对JsON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步学Silverlight 2系列》文章带您快速进入Silverlight 2开发。

本文为系列文章第九篇,主要介绍如何使用控件模板定制控件的观感。Silverlight提供了极其强大的功能,允许用户完全定制控件的外观。

定制控件内容

在Silverlight中,WatermarkedTextBox控件可以为用户的输入提供一段提示信息,如果只是简单的一点文字信息,有时候未免显得单调,如果加上相应的图片说明效果会更好,如下图所示的一个简单的用户登录界面:

这样看起来界面显的就生动多了,XAML声明如下:

<Canvas Background="#46461F">    <WatermarkedTextBox x:name="Username" Canvas.top="30" Canvas.left="50"                        WIDth="320" Height="48">        <WatermarkedTextBox.Watermark>            <StackPanel WIDth="320" Height="48" OrIEntation="Horizontal">                <Image Source="admin.png" HorizontalAlignment="left"></Image>                <TextBlock Text="请输入用户名" VerticalAlignment="Center" Foreground="#999999"/>            </StackPanel>        </WatermarkedTextBox.Watermark>    </WatermarkedTextBox>        <WatermarkedTextBox x:name="Password" Canvas.top="110" Canvas.left="50"                        WIDth="320" Height="48" HorizontalAlignment="left">        <WatermarkedTextBox.Watermark>            <StackPanel WIDth="320" Height="48" OrIEntation="Horizontal">                <Image Source="lock.png" HorizontalAlignment="left"></Image>                <TextBlock Text="请输入密码" VerticalAlignment="Center" Foreground="#999999"/>            </StackPanel>        </WatermarkedTextBox.Watermark>    </WatermarkedTextBox>        <button Canvas.top="180" Canvas.left="100"            WIDth="120" Height="48">        <button.Content>            <StackPanel OrIEntation="Horizontal">                <Image Source="apply.png" HorizontalAlignment="left"></Image>                <TextBlock Text="登 录" VerticalAlignment="Center" margin="10 0 0 0"></TextBlock>            </StackPanel>        </button.Content>    </button></Canvas>

很多控件都有Content或者Text属性,我们完全可以充分发挥自己的想象力去进行定制,定制后控件仍然具有原来的功能行为,如上面的示例,当输入用户名控件获得焦点时文字和图片都将消失:

使用控件模板定制控件

前面的示例中我们只是定制了控件的内容,Silverlight允许我们完全对控件进行定制,而不仅仅是内容。下面的示例中我们定制一个渐变色的圆角矩形按钮。首先我们在App.xaml中创建一个Roundbutton样式,改写按钮的Template属性:

<Style x:Key="Roundbutton" targettype="button">    <Setter Property="Template">        <Setter.Value>            <ControlTemplate targettype="button">                <GrID x:name="RootElement">                    <Rectangle WIDth="200" Height="80" RadiusX="15" RadiusY="15">                        <Rectangle.Fill>                            <linearGradIEntBrush StartPoint="0,0">                                <GradIEntStop color="#FFFFFF" Offset="0.0" />                                <GradIEntStop color="#EC04FA" Offset="1.0" />                            </linearGradIEntBrush>                        </Rectangle.Fill>                        <Rectangle.stroke>                            <linearGradIEntBrush EndPoint="0.5,1" StartPoint="0.5,0">                                <GradIEntStop color="#FCB2FD" Offset="0" />                                <GradIEntStop color="#FFFFFF" Offset="1" />                            </linearGradIEntBrush>                        </Rectangle.stroke>                    </Rectangle>                    <TextBlock Text="提 交" FontSize="26" Foreground="White"                               HorizontalAlignment="Center" VerticalAlignment="Center"/>                </GrID>            </ControlTemplate>        </Setter.Value>    </Setter></Style>

其中的渐变等内容在Graphics相关内容里将会写到。现在在XAML中使用该样式:

<Canvas Background="#46461F">    <button x:name="button1" Style="{StaticResource Roundbutton}"            Canvas.top="80" Canvas.left="150"/></Canvas>

运行后就可以看到下面的效果:

创建模板

上面的示例中,控件的文字以及控件的大小都是固定的,我们希望在开发人员使用中再设定,可以在控件模板中通过使用 {TemplateBinding ControlProperty} 的标识扩展句法来绑定到控件的属性来实现,使用ContentPresenter控件可以灵活的设置各个属性。修改Roundbutton样式如下所示:

<Style x:Key="Roundbutton" targettype="button">    <Setter Property="Template">        <Setter.Value>            <ControlTemplate targettype="button">                <GrID x:name="RootElement">                    <Rectangle WIDth="{TemplateBinding WIDth}" Height="{TemplateBinding Height}"                               RadiusX="15" RadiusY="15">                        <Rectangle.Fill>                            <linearGradIEntBrush StartPoint="0,0">                                <GradIEntStop color="#EC04FA" Offset="0" />                                <GradIEntStop color="#FFFFFF" Offset="1" />                            </linearGradIEntBrush>                        </Rectangle.stroke>                    </Rectangle>                    <ContentPresenter                        Content="{TemplateBinding Content}"                        FontSize="{TemplateBinding FontSize}"                        HorizontalContentAlignment="{TemplateBinding HorizontalContentAlignment}"                        VerticalContentAlignment="{TemplateBinding VerticalContentAlignment}"                        Foreground="{TemplateBinding Foreground}">                    </ContentPresenter>                </GrID>            </ControlTemplate>        </Setter.Value>    </Setter></Style>

这样在使用Roundbutton时我们可以设定控件的文本及控件的大小:

<Canvas Background="#46461F">    <button x:name="button1" Style="{StaticResource Roundbutton}"            Canvas.top="80" Canvas.left="50"            Content="提 交" FontSize="26"            HorizontalContentAlignment="Center"            VerticalContentAlignment="Center"            Foreground="White" WIDth="200" Height="60"/>        <button x:name="button2" Style="{StaticResource Roundbutton}"            Canvas.top="80" Canvas.left="260"            Content="取 消" FontSize="26"            HorizontalContentAlignment="Center"            VerticalContentAlignment="Center"            Foreground="White" WIDth="100" Height="100"/></Canvas>

运行时效果如下:

结束语

本文简单的介绍了如何定制控件的内容以及通过控件模板完全定制控件,你可以从这里下载本文示例代码。

下一篇:一步一步学Silverlight 2系列(10):使用用户控件

作者: TerryLee
出处: http://terrylee.cnblogs.com 总结

以上是内存溢出为你收集整理的一步一步学Silverlight 2系列(9):使用控件模板全部内容,希望文章能够帮你解决一步一步学Silverlight 2系列(9):使用控件模板所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1056486.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-25
下一篇2022-05-25

发表评论

登录后才能评论

评论列表(0条)

    保存