[Silverlight] Mac OS 风格按钮 Style 实现的更新版-陈荣

来源:互联网 发布:mac版网游 编辑:程序博客网 时间:2024/06/06 02:42
 

[Silverlight] Mac OS 风格按钮 Style 实现的更新版(针对 Silverlight 2 RTW)

作者:陈荣

在 Silverlight 2 beta 2 时,我曾经写了一篇帖子实现了苹果风格的按钮样式( Silverlight 下苹果 (Mac OS)风格按钮的实现)。

而现在 Silverlight 2 终于发布了,也给之前的代码带来了很多问题,导致无法继续使用。

经过一阵探索,我终于成功修改了这个代码,现在在正式版下也能工作正常了。其关键点如下:

1. 在 beta 2 时,需要采用 <vsm:Setter> 和 <vsm:Style> 的语法编写样式。其中 vsm 是个名称空间引用:
xmlns:vsm="clr-namespace:System.Windows;assembly=System.Windows"
而正式版下直接用 <Style> 和 <Setter> 表签即可。
这个问题如果不修改,程序可以编译通过,但是运行时会报一个莫名其妙的 “ AG_E_PARSER_PROPERTY_NOT_FOUND ”错误。

2. ContentPresenter 和 ContentControl 控件删除了如下属性:
TextDecorations,
TextWrapping,
TextAlignment.

因此,现在必须在 template 中将 ContentPresenter 的定位改用容器 Button 的 HorizontalContentAlignment 和 VerticalContentAlignment 属性来控制。代码如下:

  1. <ContentPresenter Margin="4,5,4,4" Content="{TemplateBinding Content}" ContentTemplate="{TemplateBinding ContentTemplate}" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />

修改成功后的 Style 全部代码如下:

  1. <UserControl
  2.     x:Class="UserControl"
  3.     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  4.     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  5.     xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  6.     xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  7.     mc:Ignorable="d"
  8.     d:DesignWidth="640" d:DesignHeight="480">
  9.  
  10.     <UserControl.Resources>
  11.         <Style x:Key="MyButton" TargetType="Button">
  12.             <Setter Property="IsEnabled" Value="true"/>
  13.             <Setter Property="IsTabStop" Value="true"/>
  14.             <Setter Property="Background" Value="#FF003255"/>
  15.             <Setter Property="Foreground" Value="#FF313131"/>
  16.             <Setter Property="MinWidth" Value="5"/>
  17.             <Setter Property="MinHeight" Value="5"/>
  18.             <Setter Property="Margin" Value="0"/>
  19.             <Setter Property="HorizontalContentAlignment" Value="Center"/>
  20.             <Setter Property="VerticalContentAlignment" Value="Center"/>
  21.             <Setter Property="Cursor" Value="Arrow"/>
  22.             <Setter Property="FontSize" Value="11" />
  23.             <Setter Property="Template">
  24.                 <Setter.Value>
  25.                     <ControlTemplate TargetType="Button">
  26.                         <Grid>
  27.                             <Grid.Resources>
  28.                                 <Color x:Key="LinearBevelLightStartColor">#FFFFFFFF</Color>
  29.                                 <Color x:Key="LinearBevelLightEndColor">#F4E2E0E0</Color>
  30.                                 <Color x:Key="LinearBevelDarkStartColor">#E0E5E5E5</Color>
  31.                                 <Color x:Key="LinearBevelDarkEndColor">#B2FFFFFF</Color>
  32.                                 <Color x:Key="MouseOverLinearBevelDarkEndColor">#7FFC1717</Color>
  33.                                 <Color x:Key="HoverLinearBevelLightStartColor">#FCFFFFFF</Color>
  34.                                 <Color x:Key="HoverLinearBevelLightEndColor">#EAFFFFFF</Color>
  35.                                 <Color x:Key="HoverLinearBevelDarkStartColor">#D8FFFFFF</Color>
  36.                                 <Color x:Key="HoverLinearBevelDarkEndColor">#4CFFFFFF</Color>
  37.                                 <Color x:Key="CurvedBevelFillStartColor">#B3FFFFFF</Color>
  38.                                 <Color x:Key="CurvedBevelFillEndColor">#3CFFFFFF</Color>
  39.                                 <SolidColorBrush x:Key="BorderBrush" Color="#FF5E5E5E"/>
  40.                                 <SolidColorBrush x:Key="AccentBrush" Color="#FF000000"/>
  41.                                 <SolidColorBrush x:Key="DisabledBrush" Color="#A5FFFFFF"/>
  42.                                 <LinearGradientBrush x:Key="FocusedStrokeBrush" EndPoint="0.5,1" StartPoint="0.5,0">
  43.                                     <GradientStop Color="#B2FFFFFF" Offset="0"/>
  44.                                     <GradientStop Color="#51FFFFFF" Offset="1"/>
  45.                                     <GradientStop Color="#66FFFFFF" Offset="0.325"/>
  46.                                     <GradientStop Color="#1EFFFFFF" Offset="0.325"/>
  47.                                 </LinearGradientBrush>
  48.                             </Grid.Resources>
  49.                             <VisualStateManager.VisualStateGroups>
  50.                                 <VisualStateGroup x:Name="CommonStates">
  51.                                     <VisualStateGroup.Transitions>
  52.                                         <VisualTransition GeneratedDuration="00:00:00.2000000" To="MouseOver"/>
  53.                                         <VisualTransition GeneratedDuration="0:0:0.1" To="Pressed"/>
  54.                                         <VisualTransition GeneratedDuration="00:00:00.2000000" From="Normal" To="MouseOver"/>
  55.                                     </VisualStateGroup.Transitions>
  56.                                     <VisualState x:Name="Normal">
  57.                                         <Storyboard/>
  58.                                     </VisualState>
  59.                                     <VisualState x:Name="MouseOver">
  60.                                         <Storyboard>
  61.                                             <ColorAnimationUsingKeyFrames 
  62.                                                 Duration="0" 
  63.                                                 Storyboard.TargetName="BackgroundGradient" 
  64.                                                 Storyboard.TargetProperty="(Shape.Fill).(GradientBrush.GradientStops)[0].(GradientStop.Color)">
  65.                                                 <SplineColorKeyFrame KeyTime="0" Value="#c8d5ed" />
  66.                                             </ColorAnimationUsingKeyFrames>
  67.                                             <ColorAnimationUsingKeyFrames 
  68.                                                 Duration="0" 
  69.                                                 Storyboard.TargetName="BackgroundGradient" 
  70.                                                 Storyboard.TargetProperty="(Shape.Fill).(GradientBrush.GradientStops)[1].(GradientStop.Color)">
  71.                                                 <SplineColorKeyFrame KeyTime="0" Value="#97c2ee" />
  72.                                             </ColorAnimationUsingKeyFrames>
  73.                                             <ColorAnimationUsingKeyFrames 
  74.                                                 Duration="0" 
  75.                                                 Storyboard.TargetName="BackgroundGradient" 
  76.                                                 Storyboard.TargetProperty="(Shape.Fill).(GradientBrush.GradientStops)[2].(GradientStop.Color)">
  77.                                                 <SplineColorKeyFrame KeyTime="0" Value="#6eadee" />
  78.                                             </ColorAnimationUsingKeyFrames>
  79.                                             <ColorAnimationUsingKeyFrames 
  80.                                                 Duration="0" 
  81.                                                 Storyboard.TargetName="BackgroundGradient" 
  82.                                                 Storyboard.TargetProperty="(Shape.Fill).(GradientBrush.GradientStops)[3].(GradientStop.Color)">
  83.                                                 <SplineColorKeyFrame KeyTime="0" Value="#aff9ff" />
  84.                                             </ColorAnimationUsingKeyFrames>
  85.                                         </Storyboard>
  86.                                     </VisualState>
  87.                                     <VisualState x:Name="Pressed">
  88.                                         <Storyboard>
  89.                                             <DoubleAnimationUsingKeyFrames Duration="0" Storyboard.TargetName="BackgroundGradient" Storyboard.TargetProperty="(Shape.Fill).(GradientBrush.GradientStops)[1].(GradientStop.Offset)">
  90.                                                 <SplineDoubleKeyFrame KeyTime="0" Value=".2"/>
  91.                                             </DoubleAnimationUsingKeyFrames>
  92.                                             <ColorAnimationUsingKeyFrames 
  93.                                                 Duration="0" 
  94.                                                 Storyboard.TargetName="BackgroundGradient" 
  95.                                                 Storyboard.TargetProperty="(Shape.Fill).(GradientBrush.GradientStops)[0].(GradientStop.Color)">
  96.                                                 <SplineColorKeyFrame KeyTime="0" Value="#bac5e8" />
  97.                                             </ColorAnimationUsingKeyFrames>
  98.                                             <ColorAnimationUsingKeyFrames 
  99.                                                 Duration="0" 
  100.                                                 Storyboard.TargetName="BackgroundGradient" 
  101.                                                 Storyboard.TargetProperty="(Shape.Fill).(GradientBrush.GradientStops)[1].(GradientStop.Color)">
  102.                                                 <SplineColorKeyFrame KeyTime="0" Value="#7bb2e9" />
  103.                                             </ColorAnimationUsingKeyFrames>
  104.                                             <ColorAnimationUsingKeyFrames 
  105.                                                 Duration="0" 
  106.                                                 Storyboard.TargetName="BackgroundGradient" 
  107.                                                 Storyboard.TargetProperty="(Shape.Fill).(GradientBrush.GradientStops)[2].(GradientStop.Color)">
  108.                                                 <SplineColorKeyFrame KeyTime="0" Value="#4d9ae7" />
  109.                                             </ColorAnimationUsingKeyFrames>
  110.                                             <ColorAnimationUsingKeyFrames 
  111.                                                 Duration="0" 
  112.                                                 Storyboard.TargetName="BackgroundGradient" 
  113.                                                 Storyboard.TargetProperty="(Shape.Fill).(GradientBrush.GradientStops)[3].(GradientStop.Color)">
  114.                                                 <SplineColorKeyFrame KeyTime="0" Value="#85eaff" />
  115.                                             </ColorAnimationUsingKeyFrames>
  116.                                         </Storyboard>
  117.                                     </VisualState>
  118.                                     <VisualState x:Name="Disabled">
  119.                                         <Storyboard>
  120.                                             <DoubleAnimationUsingKeyFrames Duration="0" Storyboard.TargetName="DisabledVisual" Storyboard.TargetProperty="Opacity">
  121.                                                 <SplineDoubleKeyFrame KeyTime="0" Value="1"/>
  122.                                             </DoubleAnimationUsingKeyFrames>
  123.                                         </Storyboard>
  124.                                     </VisualState>
  125.                                 </VisualStateGroup>
  126.                                 <VisualStateGroup x:Name="FocusStates">
  127.                                     <VisualState x:Name="Focused">
  128.                                         <Storyboard>
  129.                                             <ObjectAnimationUsingKeyFrames Duration="0" Storyboard.TargetName="FocusVisual" Storyboard.TargetProperty="Visibility">
  130.                                                 <DiscreteObjectKeyFrame KeyTime="0">
  131.                                                     <DiscreteObjectKeyFrame.Value>
  132.                                                         <Visibility>Visible</Visibility>
  133.                                                     </DiscreteObjectKeyFrame.Value>
  134.                                                 </DiscreteObjectKeyFrame>
  135.                                             </ObjectAnimationUsingKeyFrames>
  136.                                         </Storyboard>
  137.                                     </VisualState>
  138.                                     <VisualState x:Name="Unfocused">
  139.                                         <Storyboard/>
  140.                                     </VisualState>
  141.                                 </VisualStateGroup>
  142.                             </VisualStateManager.VisualStateGroups>
  143.                             <Rectangle x:Name="Background" Fill="{TemplateBinding Background}" RadiusX="11" RadiusY="11"/>
  144.                             <Rectangle x:Name="BackgroundGradient" Stroke="{StaticResource BorderBrush}" StrokeThickness="1" RadiusX="11" RadiusY="11" Margin="-1,-1,-1,-1">
  145.                                 <Rectangle.Fill>
  146.                                     <LinearGradientBrush EndPoint="0.7,1" StartPoint="0.7,0">
  147.                                         <GradientStop Color="{StaticResource LinearBevelLightStartColor}" Offset="0"/>
  148.                                         <GradientStop Color="{StaticResource LinearBevelLightEndColor}" Offset="0.326"/>
  149.                                         <GradientStop Color="{StaticResource LinearBevelDarkStartColor}" Offset="0.344"/>
  150.                                         <GradientStop Color="#FFFFFFFF" Offset="0.786"/>
  151.                                     </LinearGradientBrush>
  152.                                 </Rectangle.Fill>
  153.                             </Rectangle>
  154.                             <Grid x:Name="FocusVisual" Visibility="Collapsed">
  155.                                 <Rectangle Margin="-2,1,-2,-2" Stroke="{StaticResource AccentBrush}" StrokeThickness="1" StrokeDashArray="1.5 1.5" RadiusX="3" RadiusY="3" />
  156.                             </Grid>
  157.                             <ContentPresenter Margin="4,5,4,4" Content="{TemplateBinding Content}" ContentTemplate="{TemplateBinding ContentTemplate}" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />
  158.                             <Rectangle x:Name="DisabledVisual" IsHitTestVisible="false" Opacity="0" Fill="{StaticResource DisabledBrush}" RadiusX="11" RadiusY="11" Margin="-1,-1,-1,-1"/>
  159.                         </Grid>
  160.                     </ControlTemplate>
  161.                 </Setter.Value>
  162.             </Setter>
  163.         </Style>
  164.     </UserControl.Resources>
  165.  
  166.     <Grid x:Name="LayoutRoot" Background="White" >
  167.         <Button Height="35" HorizontalAlignment="Stretch" Margin="198,132,262,0" Style="{StaticResource MyButton}" VerticalAlignment="Top" Content="Button"/>
  168.     </Grid>
  169. </UserControl>
原创粉丝点击