WPF 列表选择,动态调用ResourceDictionary内资源

做WPF项目经常会碰到让客户从列表中选择样式,选定后,动态更改部件的样式。下面以动态更改一个控件的背景图为例子来说说实现的方法。
如果大家有更好的方法,欢迎在评论中提出来。


控件的背景图使用Microsoft Expression Design 4 设计的,使用Express Design的很大一个好处,就是不需要使用图片(减少软件的体积),而且
可以把设计的内容直接添加到ResourceDictionary里使用。在Express Design设计好的部件,按右键选择导出,格式选择:XAML Silverlight 4/WPF Canvas 即可。
导出后,去掉不必要的内容:各个Layer的名称等等,就可以放在资源文件内使用了。


本范例实现步骤如下:


1.新建一个WPF工程,添加一个ResourceDictionary文件,命名为:VisualStyles.xaml
   在里面添加从Express Design里设计好的内容:(这里以三个不同颜色的形状为例)
   <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"> 
    <VisualBrush TileMode="None" x:Key="Style1">
        <VisualBrush.Visual>
            <Viewbox Width="1920" Height="1080">
                <Canvas Width="600.039" Height="599.879">
                    <Path Width="145.609" Height="144.765" Canvas.Left="-7.62939e-005" Canvas.Top="-4.57764e-005" Stretch="Fill" Fill="#FFFFC800" Data="F1 M -7.62939e-005,72.3784C -7.62939e-005,112.359 32.5887,144.765 72.8046,144.765L 72.8046,144.765C 113.012,144.765 145.609,112.359 145.609,72.3784L 145.609,72.3784C 145.609,32.3979 113.012,-4.57764e-005 72.8046,-4.57764e-005L 72.8046,-4.57764e-005C 32.5887,-4.57764e-005 -7.62939e-005,32.3979 -7.62939e-005,72.3784 Z "/>
                </Canvas>
            </Viewbox>
        </VisualBrush.Visual>
    </VisualBrush>
    <VisualBrush TileMode="None" x:Key="Style2">
        <VisualBrush.Visual>
            <Viewbox Width="1920" Height="1080">
                <Canvas Width="600.13" Height="599.878">
                    <Rectangle Width="122.776" Height="123.495" Canvas.Left="6.10352e-005" Canvas.Top="4.57764e-005" Stretch="Fill" Fill="#FF0096FF"/>
                </Canvas>
            </Viewbox>
        </VisualBrush.Visual>
    </VisualBrush>
    <VisualBrush TileMode="None" x:Key="Style3">
        <VisualBrush.Visual>
            <Viewbox Width="1920" Height="1080">
                <Canvas Width="600.13" Height="599.878">
                    <Rectangle Width="122.776" Height="123.495" Canvas.Left="6.10352e-005" Canvas.Top="4.57764e-005" Stretch="Fill" Fill="#FF009664"/>
                </Canvas>
            </Viewbox>
        </VisualBrush.Visual>
    </VisualBrush>
</ResourceDictionary>

注意最好放在Viewbox里,可以保证随窗体大小的变化而改变大小。


2.在App.xaml里引用这个资源文件
   <Application.Resources>
        <ResourceDictionary>
            <ResourceDictionary.MergedDictionaries>
                <ResourceDictionary Source="Styles\VisualStyles.xaml"/>                
            </ResourceDictionary.MergedDictionaries>
        </ResourceDictionary>

    </Application.Resources>


3. 将资源文件的内容绑定到一个ComboBox,供客户选择:
    首先定义一个要绑定的数据类型:
    public class WinStyles
    {
        public string StyleName { get; set; }//资源文件内的Key的名称
        public VisualBrush BackgroundBrush { get; set; }//把资源文件内的VisualBrush刷到控件上        
    }
   在主窗体XAML里添加一个ComboBox,代码如下:
    <ComboBox Grid.Row="1" x:Name="WinStyleList" Width="341" Height="114" ItemsSource="{Binding}" SelectionChanged="WinStyleList_SelectionChanged">
            <ComboBox.ItemTemplate>
                <DataTemplate>
                    <Border CornerRadius="2,2,2,2" Margin="2" Background="{Binding BackgroundBrush}" Width="310" Height="100">
                        <TextBlock Text="{Binding StyleName}" Foreground="{Binding Fontcolor}" HorizontalAlignment="Center" VerticalAlignment="Center"/>
                    </Border>
                </DataTemplate>
            </ComboBox.ItemTemplate>
        </ComboBox>
   可以看到,资源的VisualBrush会作为Border的Background呈现。
   在窗体内实现以下代码:
   private void iniStyleList()
        {
            List<WinStyles> _winstyles = new List<WinStyles>();
            WinStyles st1 = new WinStyles();
            st1.StyleName = "Style1";
            st1.Fontcolor = new SolidColorBrush(Colors.White);
            st1.BackgroundBrush = (VisualBrush)this.FindResource("Style1");
            _winstyles.Add(st1);
            WinStyles st2 = new WinStyles();
            st2.StyleName = "Style2";
            st2.Fontcolor = new SolidColorBrush(Colors.White);
            st2.BackgroundBrush = (VisualBrush)this.FindResource("Style2");
            _winstyles.Add(st2);
            WinStyles st3 = new WinStyles();
            st3.StyleName = "Style3";
            st3.Fontcolor = new SolidColorBrush(Colors.Black);
            st3.BackgroundBrush = (VisualBrush)this.FindResource("Style3");
            _winstyles.Add(st3);
            //绑定到comboBox
            WinStyleList.ItemsSource = _winstyles;
            WinStyleList.SelectedIndex = 0;

        }


4. 当用户在ComboBox做出选择时,把资源的VisualBrush显示在主控件上。
      private void WinStyleList_SelectionChanged(object sender, SelectionChangedEventArgs e)
        {
            WinStyles winStyle = (WinStyles)this.WinStyleList.SelectedItem;
            this.DisplayStyle.Background = (VisualBrush)this.FindResource(winStyle.StyleName);
        }


这是在猪八戒网上请人(金蕾品牌设计)用Express Design设计的资源文件,在ComboBox上罗列出来效果很好。


WPF 列表选择,动态调用ResourceDictionary内资源_第1张图片



本文源码下载:
http://download.csdn.net/detail/soft2buy/6713683

你可能感兴趣的:(WPF,列表选择)