使用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行样式的动态调整。这样的功能可以显著提升用户界面的交互性和数据展示的直观性。

相关推荐
玉面小君2 小时前
从 WPF 到 Avalonia 的迁移系列实战篇6:ControlTheme 和 Style区别
c#·wpf·avalonia
c#上位机11 小时前
wpf之Border
c#·wpf
SunflowerCoder11 小时前
WPF迁移avalonia之图像处理(一)
图像处理·wpf·avalonia
周杰伦fans12 小时前
WPF中的DataContext以及常见的绑定方式
wpf
没有bug.的程序员1 天前
Redis 数据结构全面解析:从底层编码到实战应用
java·数据结构·redis·wpf
somethingGoWay2 天前
wpf 自定义输入ip地址的文本框
wpf
秋月的私语2 天前
Wpf程序屏幕居中问题修复全记录
wpf
我要打打代码2 天前
WPF启动窗体的三种方式
wpf
R瑾安2 天前
mysql集群部署(Mysql Group Replication)
数据库·mysql·wpf
c#上位机2 天前
wpf中资源的使用
c#·wpf