Silverlight中的主题设置

前些天看到一篇文章讲主题的设置,感觉挺不错的,当时自己还照着做了一个Demo,怕时间久了会淡忘,所以今天把这个例子翻出来,重新做了一遍。

关于Theme,我的理解是和ASP.NET主题中的CSS是一个意思,当然,Sl中的样式更加的强大。

第一种方式:

      1,装完Silverlight Tookit之后,在C:\Program Files\Microsoft SDKs\Silverlight\v3.0\Toolkit\Jul09\Themes目录下面会有一些主题的dll,我们引用其中一个dll文件,以System.Windows.Controls.Theming.ShinyRed.dll为例

      2,在XAML中添加对这个dll的引用

          xmlns:Red="clr-namespace:System.Windows.Controls.Theming;assembly=System.Windows.Controls.Theming.ShinyRed"

      3,把这里的主题当成一个控件,那么需要使用这个主题的控件应该是其子控件

          <Red:ShinyRedTheme>
            <StackPanel x:Name="LayoutRoot"
                    Width="207"
                    Margin="35,39,158,81"
                    Height="180">
            <Button Content="Button"
                    Margin="10"></Button>           
            <Button Content="Button"
                    Height="23"                    
                    Name="button1"
                    Width="75" />
            </StackPanel>
           </Red:ShinyRedTheme>

       4,因为主题控件中只能包含一个子控件,所以这里使用了一个StackPanel作为容器

       效果:QQ截图未命名         其已经覆盖了对根元素的Background设置的另一种颜色。

第2种方式:

         1,选择一个主题文件,可以从C:\Program Files\Microsoft SDKs\Silverlight\v3.0\Toolkit\Jul09\Themes\Xaml目录下选择,这里将其复制到Themes文件中。

           QQ截图未命名

     2,将文件添加进来之后,有一个地方是很关键的,就是将RainierOrange.xaml的BuildAction的属性由Page改为Content,如果不这么做的话,VS会爆出AG_E_PARSER_BAD_PROPERTY_VALUE这样的错误,同时需要添加主题文件中引用到的dll。

    3添加System.Windows.Controls.Theming.Toolkit.dll,并在页面进行引用

xmlns:Theme="clr-namespace:System.Windows.Controls.Theming;assembly=System.Windows.Controls.Theming.Toolkit"

   4,应用主题:

        <Grid Background="Black">
        <StackPanel x:Name="LayoutRoot" Width="248" Margin="100" 
            Theme:ImplicitStyleManager.ApplyMode="Auto"
                    Theme:ImplicitStyleManager.ResourceDictionaryUri="Themes/RainierOrange.xaml"
                Height="382">
       <Button Content="Button" Margin="10" ></Button>
       </StackPanel>
       </Grid>

  5,这里我们设置了背景为Blcak,看看效果:

         QQ截图未命名     其实效果就跟第一种不一样了,它可以控制到应用主题的控件。

扩展:动态换主题

        QQ截图未命名       主要就是Theme两种主题可以切换,因为只是模拟,所以UI上只放了一个ListBox用来选择不同的主题

       public void LoadTheme()
        {
            this.listBox1.Items.Add(new ComboBoxItem() { Content = "TwilightBlue", Name = "TwilightBlue", DataContext = "Themes/TwilightBlue.xaml", IsEnabled = true });
            this.listBox1.Items.Add(new ComboBoxItem() { Content = "RainierOrange", Name = "RainierOrange", DataContext = "Themes/RainierOrange.xaml",IsEnabled = true });           
            this.listBox1.SelectionChanged +=
                (obj, e) =>
                {
                    if (e != null)
                    {
                        StackPanel stack = new StackPanel();
                        Button btn = new Button();
                        stack.Children.Add(btn);
                        this.LayoutRoot.Children.Clear();
                        this.LayoutRoot.Children.Add(stack);
                        Uri uri = new Uri((this.listBox1.SelectedItem as ComboBoxItem).DataContext.ToString(), UriKind.RelativeOrAbsolute);
                        ImplicitStyleManager.SetResourceDictionaryUri(stack, uri);
                        ImplicitStyleManager.SetApplyMode(stack, ImplicitStylesApplyMode.Auto);
                        ImplicitStyleManager.Apply(stack);
                    }
                };
        }

     有一个地方需要注意的就是对于Themes下的xaml文件BuildAction不能为Page类型,否则会出现无法找到对应资源的错误

posted @ 2010-08-13 14:43  ringgo  阅读(2151)  评论(5编辑  收藏  举报