Silverlight2的Style练习

本篇的内容较为简单,主要针对Silverlight 2的Style进行一个练习。Style简要的说就是一些属性值的集合,
作用和CSS比较像。在Silverlight 2中定义Style只能同用于同种类型的Element。如下代码:

 
 
 
  1. < Style x:Key="ButtonStyleTwo" TargetType="Button">
  2.             < Setter Property="FontFamily" Value="Arial" />
  3.             < Setter Property="FontSize" Value="40" />
  4.             < Setter Property="Foreground" Value="Blue" />
  5.             < Setter Property="Background">
  6. < /Style>

这就是一个定义好的Style,它只能用于Button组件,看看它如何产生作用,将Style直接嵌入Button:

 
 
 
  1. < Button Content="Button">
  2.     < Button.Style>
  3.          < Style TargetType="Button">
  4.               < Setter Property="FontFamily" Value="Arial" />
  5.               < Setter Property="FontSize" Value="40" />
  6.               < Setter Property="Foreground" Value="Blue" />
  7.               < Setter Property="Background">
  8.                  < Setter.Value>
  9.                    < LinearGradientBrush>
  10.                      < GradientStop Color="Green" Offset="0">< /GradientStop>
  11.                      < GradientStop Color="Red" Offset="1">< /GradientStop>
  12.                    < /LinearGradientBrush>
  13.                  < /Setter.Value>
  14.               < /Setter>
  15.          < /Style>
  16.     < /Button.Style>
  17. < /Button>
  18.  

当然也可以通过Resource的方式来设置Style,分别设置了两个Style:ButtonStyleOne、ButtonStyleTwo,
ButtonStyleOne设置为默认Style,ButtonStyleTwo用于在点击Button后切换Style。

Silverlight 2的Style练习:XAML Code:

 
 
 
  1. < UserControl x:Class="SilverlightTest.Page"
  2.     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
  3.     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4.     Width="400">
  5.     < UserControl.Resources>
  6.         < Style x:Key="ButtonStyleOne" TargetType="Button">
  7.             < Setter Property="FontFamily" Value="Georgia" />
  8.             < Setter Property="FontSize" Value="40" />
  9.             < Setter Property="Foreground" Value="SlateGray" />
  10.             < Setter Property="Background">
  11.                 < Setter.Value>
  12.                     < LinearGradientBrush>
  13.                         < GradientStop Color="Blue" Offset="0">< /GradientStop>
  14.                         < GradientStop Color="Yellow" Offset="1">< /GradientStop>
  15.                     < /LinearGradientBrush>
  16.                 < /Setter.Value>
  17.             < /Setter>
  18.         < /Style>
  19.         < Style x:Key="ButtonStyleTwo" TargetType="Button">
  20.             < Setter Property="FontFamily" Value="Arial" />
  21.             < Setter Property="FontSize" Value="40" />
  22.             < Setter Property="Foreground" Value="Pink" />
  23.             < Setter Property="Background">
  24.                 < Setter.Value>
  25.                     < LinearGradientBrush>
  26.                         < GradientStop Color="Green" Offset="0">< /GradientStop>
  27.                         < GradientStop Color="Red" Offset="1">< /GradientStop>
  28.                     < /LinearGradientBrush>
  29.                 < /Setter.Value>
  30.             < /Setter>
  31.         < /Style>
  32.     < /UserControl.Resources>
  33.     < StackPanel x:Name="LayoutRoot" Background="White">
  34.         < Button x:Name="TestButton" Content="A Customized Button" 
  35.                 Style="{StaticResource ButtonStyleOne}" Click="Button_Click">< /Button>
  36.     < /StackPanel>
  37. < /UserControl>
  38.  

用C#来切换Sytle,如下代码:

 
 
 
  1. private void Button_Click(object sender, RoutedEventArgs e)
  2. {
  3.    //切换Style:ButtonStyleTwo
  4.    TestButton.Style = this.Resources["ButtonStyleTwo"] as Style;
  5.    //修改Button文字
  6.    TestButton.Content = "Style Changed";
  7. }

以上就是Silverlight 2的Style练习。

文章标题:Silverlight2的Style练习
文章来源:http://www.csdahua.cn/qtweb/news48/312698.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网