使用DataTrigger自定义WPF DataGrid行样式

使用DataTrigger自定义WPF DataGrid行样式

在WPF开发中,通过DataTrigger可以方便地根据数据的变化自定义控件的样式。本文将展示如何在DataGrid中使用DataTrigger根据条件动态改变行的背景颜色和字体样式。

创建DataGrid控件

首先,我们创建一个包含三列的DataGrid控件:姓名、年龄和生日。我们使用AutoGenerateColumns属性设置为False,并手动定义列:

xml 复制代码
<DataGrid ItemsSource="{Binding Persons}" AutoGenerateColumns="False" Grid.Column="0">
    <DataGrid.Columns>
        <DataGridTextColumn Header="姓名" Binding="{Binding Name}" Width="Auto" />
        <DataGridTextColumn Header="年龄" Binding="{Binding Age}" Width="Auto" />
        <DataGridTextColumn Header="生日" Binding="{Binding Birthday}" Width="*" />
    </DataGrid.Columns>
</DataGrid>
定义DataTriggers

接下来,我们在DataGrid的RowStyle中定义多个DataTrigger,根据不同的年龄值改变行的背景颜色。当CheckBox被选中时,改变字体颜色和样式:

xml 复制代码
<DataGrid.RowStyle>
    <Style TargetType="DataGridRow">
        <Style.Triggers>
            <DataTrigger Binding="{Binding Age}" Value="19">
                <Setter Property="Background" Value="LightBlue"/>
            </DataTrigger>
            <DataTrigger Binding="{Binding Age}" Value="20">
                <Setter Property="Background" Value="LightGreen"/>
            </DataTrigger>
            <DataTrigger Binding="{Binding Age}" Value="21">
                <Setter Property="Background" Value="LightCoral"/>
            </DataTrigger>
            <DataTrigger Binding="{Binding ElementName=chkRedText, Path=IsChecked}" Value="True">
                <Setter Property="Foreground" Value="Red"/>
                <Setter Property="FontSize" Value="16"/>
                <Setter Property="FontWeight" Value="Bold"/>
            </DataTrigger>
        </Style.Triggers>
    </Style>
</DataGrid.RowStyle>
添加用户界面

我们为用户添加输入框和一个CheckBox,用户可以通过这些控件添加新的用户,并选择是否将字体变为红色:

xml 复制代码
<StackPanel Grid.Column="1" Margin="10">
    <TextBlock Text="姓名:"/>
    <TextBox x:Name="txtName" Width="200" Margin="5"/>
    <TextBlock Text="年龄:"/>
    <TextBox x:Name="txtAge" Width="200" Margin="5"/>
    <TextBlock Text="地址:"/>
    <TextBox x:Name="txtAddress" Width="200" Margin="5"/>
    <CheckBox x:Name="chkRedText" Content="红色字体" Margin="5"/>
    <Button Content="增加用户" Width="200" Margin="5" Click="AddPerson_Click"/>
</StackPanel>
后台代码

最后,在C#后台代码中实现数据绑定和添加用户功能:

csharp 复制代码
public partial class MainWindow : Window, INotifyPropertyChanged
{
    public ObservableCollection<Person> Persons { get; set; }
    public MainWindow()
    {
        InitializeComponent();
        Persons = new ObservableCollection<Person>
        {
            new Person { Name = "新人", Age = 20, Birthday = DateTime.Now },
            new Person { Name = "新人", Age = 19, Birthday = DateTime.Now },
            new Person { Name = "新人", Age = 21, Birthday = DateTime.Now },
            new Person { Name = "新人", Age = 18, Birthday = DateTime.Now },
            new Person { Name = "新人", Age = 19, Birthday = DateTime.Now }
        };
        DataContext = this;
    }

    private void AddPerson_Click(object sender, RoutedEventArgs e)
    {
        if (int.TryParse(txtAge.Text, out int age))
        {
            Persons.Add(new Person
            {
                Name = txtName.Text,
                Age = age,
                Birthday = DateTime.Now,
                Address = txtAddress.Text
            });
        }
        else
        {
            MessageBox.Show("请输入有效的年龄。");
        }
    }
}

结论

通过上述方法,可以在WPF中使用DataTrigger轻松实现DataGrid行样式的动态调整。这样的功能可以显著提升用户界面的交互性和数据展示的直观性。### 使用DataTrigger自定义WPF DataGrid行样式

在WPF开发中,通过DataTrigger可以方便地根据数据的变化自定义控件的样式。本文将展示如何在DataGrid中使用DataTrigger根据条件动态改变行的背景颜色和字体样式。

创建DataGrid控件

首先,我们创建一个包含三列的DataGrid控件:姓名、年龄和生日。我们使用AutoGenerateColumns属性设置为False,并手动定义列:

xml 复制代码
<DataGrid ItemsSource="{Binding Persons}" AutoGenerateColumns="False" Grid.Column="0">
    <DataGrid.Columns>
        <DataGridTextColumn Header="姓名" Binding="{Binding Name}" Width="Auto" />
        <DataGridTextColumn Header="年龄" Binding="{Binding Age}" Width="Auto" />
        <DataGridTextColumn Header="生日" Binding="{Binding Birthday}" Width="*" />
    </DataGrid.Columns>
</DataGrid>
定义DataTriggers

接下来,我们在DataGrid的RowStyle中定义多个DataTrigger,根据不同的年龄值改变行的背景颜色。当CheckBox被选中时,改变字体颜色和样式:

xml 复制代码
<DataGrid.RowStyle>
    <Style TargetType="DataGridRow">
        <Style.Triggers>
            <DataTrigger Binding="{Binding Age}" Value="19">
                <Setter Property="Background" Value="LightBlue"/>
            </DataTrigger>
            <DataTrigger Binding="{Binding Age}" Value="20">
                <Setter Property="Background" Value="LightGreen"/>
            </DataTrigger>
            <DataTrigger Binding="{Binding Age}" Value="21">
                <Setter Property="Background" Value="LightCoral"/>
            </DataTrigger>
            <DataTrigger Binding="{Binding ElementName=chkRedText, Path=IsChecked}" Value="True">
                <Setter Property="Foreground" Value="Red"/>
                <Setter Property="FontSize" Value="16"/>
                <Setter Property="FontWeight" Value="Bold"/>
            </DataTrigger>
        </Style.Triggers>
    </Style>
</DataGrid.RowStyle>
添加用户界面

我们为用户添加输入框和一个CheckBox,用户可以通过这些控件添加新的用户,并选择是否将字体变为红色:

xml 复制代码
<StackPanel Grid.Column="1" Margin="10">
    <TextBlock Text="姓名:"/>
    <TextBox x:Name="txtName" Width="200" Margin="5"/>
    <TextBlock Text="年龄:"/>
    <TextBox x:Name="txtAge" Width="200" Margin="5"/>
    <TextBlock Text="地址:"/>
    <TextBox x:Name="txtAddress" Width="200" Margin="5"/>
    <CheckBox x:Name="chkRedText" Content="红色字体" Margin="5"/>
    <Button Content="增加用户" Width="200" Margin="5" Click="AddPerson_Click"/>
</StackPanel>
后台代码

最后,在C#后台代码中实现数据绑定和添加用户功能:

csharp 复制代码
public partial class MainWindow : Window, INotifyPropertyChanged
{
    public ObservableCollection<Person> Persons { get; set; }
    public MainWindow()
    {
        InitializeComponent();
        Persons = new ObservableCollection<Person>
        {
            new Person { Name = "新人", Age = 20, Birthday = DateTime.Now },
            new Person { Name = "新人", Age = 19, Birthday = DateTime.Now },
            new Person { Name = "新人", Age = 21, Birthday = DateTime.Now },
            new Person { Name = "新人", Age = 18, Birthday = DateTime.Now },
            new Person { Name = "新人", Age = 19, Birthday = DateTime.Now }
        };
        DataContext = this;
    }

    private void AddPerson_Click(object sender, RoutedEventArgs e)
    {
        if (int.TryParse(txtAge.Text, out int age))
        {
            Persons.Add(new Person
            {
                Name = txtName.Text,
                Age = age,
                Birthday = DateTime.Now,
                Address = txtAddress.Text
            });
        }
        else
        {
            MessageBox.Show("请输入有效的年龄。");
        }
    }
}

结论

通过上述方法,可以在WPF中使用DataTrigger轻松实现DataGrid行样式的动态调整。这样的功能可以显著提升用户界面的交互性和数据展示的直观性。

相关推荐
假男孩儿3 小时前
WPF 最小化到系统托盘
wpf
勇敢小菜鸟13 小时前
WPF自定义窗口 输入验证不生效
wpf
鲤籽鲲13 小时前
WPF TextBox 输入限制 详解
wpf
鸿喵小仙女13 小时前
C# WPF读写STM32/GD32单片机Flash数据
stm32·单片机·c#·wpf
六点的晨曦13 小时前
WPF的右键菜单项目引入DLL和DllImport特性引入DLL文件的异同点
wpf
一个不正经的林Sir13 小时前
C#WPF基础介绍/第一个WPF程序
开发语言·c#·wpf
可喜~可乐1 天前
C# WPF开发
microsoft·c#·wpf
界面开发小八哥1 天前
DevExpress WPF中文教程:Grid - 如何移动和调整列大小?(二)
ui·.net·wpf·界面控件·devexpress·ui开发
界面开发小八哥1 天前
「实战应用」如何用图表控件SciChart WPF实现应用程序的DPI感知?
信息可视化·wpf·数据可视化·图表·scichart wpf·scichart
明耀3 天前
WPF TabControl 设置item不能点击
wpf