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

相关推荐
Macbethad9 小时前
EtherCAT从站程序技术方案:基于WPF的高性能实现
网络协议·wpf
Macbethad9 小时前
基于WPF的485主站系统技术方案
网络协议·wpf·信息与通信
赵财猫._.2 天前
HarmonyOS内存优化实战:泄漏检测、大对象管理与垃圾回收策略
华为·wpf·harmonyos
赵财猫._.2 天前
鸿蒙超级终端体验:无缝流转的底层实现与用户体验优化
wpf·harmonyos·ux
故事不长丨2 天前
C#委托的使用
c#·wpf·winfrom·委托·网站开发
行走正道2 天前
【探索实战】跨云应用分发自动化实战:基于Kurator的统一交付体系深度解析
运维·自动化·wpf·kurator·跨云分发
Macbethad2 天前
基于WPF的Ethernet/IP主站程序技术方案
网络协议·tcp/ip·wpf
张人玉2 天前
Prism Template Pack 完整使用示例(VS2022 + .NET 8 + DryIoc)
.net·wpf·prism
棉晗榜2 天前
wpf 在XAML中配置视图模型,通过 d:DataContext设置设计时类型,方便按F12跳转查看类型
wpf
赵财猫._.2 天前
HarmonyOS渲染性能优化:组件树复用与局部刷新机制
wpf·harmonyos·ux