WPF界面设计技巧(4)—自定义列表项样式

原文:WPF界面设计技巧(4)—自定义列表项样式

WPF界面设计技巧(4)—自定义列表项样式

 

有前面修改按钮样式的基础,我们可以尝试来定制一个即好看又好用的 ListBox ,今天先来讲“好看”部分。

 

打开 Microsoft Visual Studio 2008 ,建立一个WPF应用程序,调整窗体大小,在窗体内创建一个 ListBox 和一个 Button ,按下图所示布局。

 

WPF界面设计技巧(4)—自定义列表项样式

  Window1.xaml 中为窗体 Loaded 事件及按钮 Click 事件添加事件处理:

 

WPF界面设计技巧(4)—自定义列表项样式

 

 

WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式Code
WPF界面设计技巧(4)—自定义列表项样式<Window x:Class="自定义列表项.Window1"
WPF界面设计技巧(4)—自定义列表项样式    xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
WPF界面设计技巧(4)—自定义列表项样式    xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"
WPF界面设计技巧(4)—自定义列表项样式    Title
="Window1" Height="351" Width="416" Loaded="Window_Loaded">
WPF界面设计技巧(4)—自定义列表项样式    
<Grid>
WPF界面设计技巧(4)—自定义列表项样式        
<ListBox Margin="26,21,27,54" Name="listBox1" />
WPF界面设计技巧(4)—自定义列表项样式        
<Button Height="23" Click="button1_Click" Margin="26,0,0,13" Name="button1" VerticalAlignment="Bottom" HorizontalAlignment="Left" Width="75" Background="AliceBlue">选择文件</Button>
WPF界面设计技巧(4)—自定义列表项样式    
</Grid>
WPF界面设计技巧(4)—自定义列表项样式
</Window>
WPF界面设计技巧(4)—自定义列表项样式

 

 

在项目的引用中添加对 System.Windows.Froms 的引用,因为我们要使用其中的“打开文件对话框”组件。

 

WPF界面设计技巧(4)—自定义列表项样式

 

WPF界面设计技巧(4)—自定义列表项样式

 

添加 using 语句,引用以下所示的命名空间。为 System.Windows.Froms 设置别名是为了防止和现有的命名空间内的名称冲突。

 

WPF界面设计技巧(4)—自定义列表项样式

  

Window1.xaml.cs 中书写以下代码:

 

WPF界面设计技巧(4)—自定义列表项样式

 

 

WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式Code
WPF界面设计技巧(4)—自定义列表项样式using System;
WPF界面设计技巧(4)—自定义列表项样式
using System.Collections.Generic;
WPF界面设计技巧(4)—自定义列表项样式
using System.Linq;
WPF界面设计技巧(4)—自定义列表项样式
using System.Text;
WPF界面设计技巧(4)—自定义列表项样式
using System.Windows;
WPF界面设计技巧(4)—自定义列表项样式
using System.Windows.Controls;
WPF界面设计技巧(4)—自定义列表项样式
using System.Windows.Data;
WPF界面设计技巧(4)—自定义列表项样式
using System.Windows.Documents;
WPF界面设计技巧(4)—自定义列表项样式
using System.Windows.Input;
WPF界面设计技巧(4)—自定义列表项样式
using System.Windows.Media;
WPF界面设计技巧(4)—自定义列表项样式
using System.Windows.Media.Imaging;
WPF界面设计技巧(4)—自定义列表项样式
using System.Windows.Navigation;
WPF界面设计技巧(4)—自定义列表项样式
using System.Windows.Shapes;
WPF界面设计技巧(4)—自定义列表项样式
using System.IO;
WPF界面设计技巧(4)—自定义列表项样式
using System.Collections.ObjectModel;
WPF界面设计技巧(4)—自定义列表项样式
using Forms=System.Windows.Forms;
WPF界面设计技巧(4)—自定义列表项样式
WPF界面设计技巧(4)—自定义列表项样式
WPF界面设计技巧(4)—自定义列表项样式
namespace 自定义列表项
WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式
WPF界面设计技巧(4)—自定义列表项样式{
WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式    
/**//// <summary>
WPF界面设计技巧(4)—自定义列表项样式    
/// Window1.xaml 的交互逻辑
WPF界面设计技巧(4)—自定义列表项样式    
/// </summary>

WPF界面设计技巧(4)—自定义列表项样式    public partial class Window1 : Window
WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式    
WPF界面设计技巧(4)—自定义列表项样式{
WPF界面设计技巧(4)—自定义列表项样式        
public Window1()
WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式        
WPF界面设计技巧(4)—自定义列表项样式{
WPF界面设计技巧(4)—自定义列表项样式            InitializeComponent();
WPF界面设计技巧(4)—自定义列表项样式        }

WPF界面设计技巧(4)—自定义列表项样式
WPF界面设计技巧(4)—自定义列表项样式        
public ObservableCollection<FileInfo> FileList=new ObservableCollection<FileInfo>();
WPF界面设计技巧(4)—自定义列表项样式
WPF界面设计技巧(4)—自定义列表项样式
WPF界面设计技巧(4)—自定义列表项样式        
private void Window_Loaded(object sender, RoutedEventArgs e)
WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式        
WPF界面设计技巧(4)—自定义列表项样式{
WPF界面设计技巧(4)—自定义列表项样式            listBox1.ItemsSource 
= FileList;
WPF界面设计技巧(4)—自定义列表项样式        }

WPF界面设计技巧(4)—自定义列表项样式
WPF界面设计技巧(4)—自定义列表项样式        
private void button1_Click(object sender, RoutedEventArgs e)
WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式        
WPF界面设计技巧(4)—自定义列表项样式{
WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式            var open
=new Forms.OpenFileDialog WPF界面设计技巧(4)—自定义列表项样式{ Multiselect = true };
WPF界面设计技巧(4)—自定义列表项样式            
if (open.ShowDialog() == Forms.DialogResult.OK)
WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式            
WPF界面设计技巧(4)—自定义列表项样式{
WPF界面设计技巧(4)—自定义列表项样式                
foreach (string f in open.FileNames) FileList.Add(new FileInfo(f));
WPF界面设计技巧(4)—自定义列表项样式            }

WPF界面设计技巧(4)—自定义列表项样式        }

WPF界面设计技巧(4)—自定义列表项样式    }

WPF界面设计技巧(4)—自定义列表项样式}

 

 

我们采用泛型集合 ObservableCollection<FileInfo> 装载文件列表,ObservableCollection 不同于以往的集合类型,它会在其内容更改时向 WPF 控件发送更新通知,以确保显示和数据的同步,所以 WPF 开发中,集合类型应多使用该类型。

 

在窗体载入完毕后,将 ListBox1 绑定到文件列表 FileList

 

这时编译并运行程序,选择一些文件,应当是这个样子:

 

WPF界面设计技巧(4)—自定义列表项样式

 

在App.xaml中添加如下样式设定:

 

 

WPF界面设计技巧(4)—自定义列表项样式WPF界面设计技巧(4)—自定义列表项样式Code
WPF界面设计技巧(4)—自定义列表项样式         <!--ListBox样式-->
WPF界面设计技巧(4)—自定义列表项样式        
<Style TargetType="ListBox">
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="BorderBrush" Value="#BDD4F1"/>
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="BorderThickness" Value="1"/>
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="Background" Value="#F8F7F5"/>
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="ScrollViewer.HorizontalScrollBarVisibility" Value="Hidden"/>
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="ScrollViewer.VerticalScrollBarVisibility" Value="Auto"/>
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="ScrollViewer.CanContentScroll" Value="true"/>
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="VerticalContentAlignment" Value="Center"/>
WPF界面设计技巧(4)—自定义列表项样式        
</Style>
WPF界面设计技巧(4)—自定义列表项样式        
<!--ListBoxItem样式-->
WPF界面设计技巧(4)—自定义列表项样式        
<Style TargetType="ListBoxItem">
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="Foreground" Value="#B5BABF"/>
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="OverridesDefaultStyle" Value="True"/>
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="Height" Value="24"/>
WPF界面设计技巧(4)—自定义列表项样式            
<Setter Property="Template">
WPF界面设计技巧(4)—自定义列表项样式                
<Setter.Value>
WPF界面设计技巧(4)—自定义列表项样式                    
<ControlTemplate TargetType="ListBoxItem">
WPF界面设计技巧(4)—自定义列表项样式                        
<Border Name="back" BorderBrush="#F8F7F5" BorderThickness="0,1,0,1">
WPF界面设计技巧(4)—自定义列表项样式                            
<Border.Background>
WPF界面设计技巧(4)—自定义列表项样式                                
<LinearGradientBrush StartPoint="0,0" EndPoint="0,1">
WPF界面设计技巧(4)—自定义列表项样式                                    
<GradientBrush.GradientStops>
WPF界面设计技巧(4)—自定义列表项样式                                        
<GradientStopCollection>
WPF界面设计技巧(4)—自定义列表项样式                                            
<GradientStop Color="#F8F7F5" Offset="0.0"/>
WPF界面设计技巧(4)—自定义列表项样式                                            
<GradientStop Color="#F8F7F5" Offset="0.5"/>
WPF界面设计技巧(4)—自定义列表项样式                                            
<GradientStop Color="#F8F7F5" Offset="0.51"/>
WPF界面设计技巧(4)—自定义列表项样式                                            
<GradientStop Color="#F8F7F5" Offset="1"/>
WPF界面设计技巧(4)—自定义列表项样式                                        
</GradientStopCollection>
WPF界面设计技巧(4)—自定义列表项样式                                    
</GradientBrush.GradientStops>
WPF界面设计技巧(4)—自定义列表项样式                                
</LinearGradientBrush>
WPF界面设计技巧(4)—自定义列表项样式                            
</Border.Background>
WPF界面设计技巧(4)—自定义列表项样式                            
<ContentPresenter Margin="2" VerticalAlignment="Center"/>
WPF界面设计技巧(4)—自定义列表项样式                        
</Border>
WPF界面设计技巧(4)—自定义列表项样式                        
<ControlTemplate.Triggers>
WPF界面设计技巧(4)—自定义列表项样式                            
<Trigger Property="IsSelected" Value="True">
WPF界面设计技巧(4)—自定义列表项样式                                
<Trigger.EnterActions>
WPF界面设计技巧(4)—自定义列表项样式                                    
<BeginStoryboard>
WPF界面设计技巧(4)—自定义列表项样式                                        
<Storyboard>
WPF界面设计技巧(4)—自定义列表项样式                                            
<DoubleAnimation To="32" Duration="0:0:0.3" Storyboard.TargetProperty="Height"/>
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#F3C37C" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.BorderBrush).(SolidColorBrush.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#952B00" Duration="0:0:0.2" Storyboard.TargetProperty="(ListBoxItem.Foreground).(SolidColorBrush.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#FFF" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[0].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#FFEF99" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[1].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#FFE13F" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[2].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#FFF3B0" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[3].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                        
</Storyboard>
WPF界面设计技巧(4)—自定义列表项样式                                    
</BeginStoryboard>
WPF界面设计技巧(4)—自定义列表项样式                                
</Trigger.EnterActions>
WPF界面设计技巧(4)—自定义列表项样式                                
<Trigger.ExitActions>
WPF界面设计技巧(4)—自定义列表项样式                                    
<BeginStoryboard>
WPF界面设计技巧(4)—自定义列表项样式                                        
<Storyboard>
WPF界面设计技巧(4)—自定义列表项样式                                            
<DoubleAnimation BeginTime="0:0:0.4" Duration="0:0:0.2" Storyboard.TargetProperty="Height"/>
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.BorderBrush).(SolidColorBrush.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetProperty="(ListBoxItem.Foreground).(SolidColorBrush.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[0].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[1].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[2].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[3].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                        
</Storyboard>
WPF界面设计技巧(4)—自定义列表项样式                                    
</BeginStoryboard>
WPF界面设计技巧(4)—自定义列表项样式                                
</Trigger.ExitActions>
WPF界面设计技巧(4)—自定义列表项样式                            
</Trigger>
WPF界面设计技巧(4)—自定义列表项样式                            
<Trigger Property="IsMouseOver" Value="True">
WPF界面设计技巧(4)—自定义列表项样式                                
<Trigger.EnterActions>
WPF界面设计技巧(4)—自定义列表项样式                                    
<BeginStoryboard>
WPF界面设计技巧(4)—自定义列表项样式                                        
<Storyboard>
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#D8E6F5" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.BorderBrush).(SolidColorBrush.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#617A98" Duration="0:0:0.2" Storyboard.TargetProperty="(ListBoxItem.Foreground).(SolidColorBrush.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#F6F9FD" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[0].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#E0EBF7" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[1].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#D7E5F6" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[2].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation To="#F6F9FD" Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[3].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                        
</Storyboard>
WPF界面设计技巧(4)—自定义列表项样式                                    
</BeginStoryboard>
WPF界面设计技巧(4)—自定义列表项样式                                
</Trigger.EnterActions>
WPF界面设计技巧(4)—自定义列表项样式                                
<Trigger.ExitActions>
WPF界面设计技巧(4)—自定义列表项样式                                    
<BeginStoryboard>
WPF界面设计技巧(4)—自定义列表项样式                                        
<Storyboard>
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.BorderBrush).(SolidColorBrush.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetProperty="(ListBoxItem.Foreground).(SolidColorBrush.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[0].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[1].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[2].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                            
<ColorAnimation Duration="0:0:0.2" Storyboard.TargetName="back" Storyboard.TargetProperty="(Border.Background).(LinearGradientBrush.GradientStops)[3].(GradientStop.Color)" />
WPF界面设计技巧(4)—自定义列表项样式                                        
</Storyboard>
WPF界面设计技巧(4)—自定义列表项样式                                    
</BeginStoryboard>
WPF界面设计技巧(4)—自定义列表项样式                                
</Trigger.ExitActions>
WPF界面设计技巧(4)—自定义列表项样式                            
</Trigger>
WPF界面设计技巧(4)—自定义列表项样式                        
</ControlTemplate.Triggers>
WPF界面设计技巧(4)—自定义列表项样式                    
</ControlTemplate>
WPF界面设计技巧(4)—自定义列表项样式                
</Setter.Value>
WPF界面设计技巧(4)—自定义列表项样式            
</Setter>
WPF界面设计技巧(4)—自定义列表项样式        
</Style>

 

 

最终效果(按钮是沿用以前教程制作的样式):

 

WPF界面设计技巧(4)—自定义列表项样式

 

样式代码部分基本没什么可讲的了,看看前面的教程应该都可以搞明白了,有不懂的地方请留言发问吧。

 

源代码下载

 

这次教程主要是为了后面做铺垫,在下一篇教程中,我将会为大家讲述如何定制列表项的内容,比如让每个项目都可以显示图片、文件尺寸等信息,借助 WPF 的强大界面设计特性,我们不需开发自定义控件,只需用一些 XAML 代码,就可以为普通控件赋予丰富的呈现功能,敬请关注。

上一篇:BASE64 编码和解码


下一篇:创建 macvlan 网络 - 每天5分钟玩转 Docker 容器技术(55)