我有一个 DataGridTextColumn,它接受来自名为 Numbers 的数据库表中的数字。如果单元格中的数字是正数,我希望下一个 DataGridTextColumn 里面有“Positive”这个词。我尝试使用 IConverter Styles 但仍然不知道如何正确操作。我希望有人可以帮助我。
到目前为止,这是我的代码:
<DataGrid Grid.Row="0" Grid.Column="1" AutoGenerateColumns="False" IsReadOnly="false" CanUserAddRows="True" Margin="5,5,10,5" ItemsSource="{Binding ElementName=Numbers}">
<DataGrid.Columns>
<DataGridTextColumn Binding="{Binding Num}" Header="Number" FontSize="16"/>
<DataGridTextColumn Header="Positive/Negative" FontSize="16">
<DataGridTextColumn.ElementStyle>
<Style TargetType="{x:Type TextBlock}">
<Setter Property="Text" Value="{Binding Amount, Converter={StaticResource PositiveNegativeConverter}}"/>
</Style>
</DataGridTextColumn.ElementStyle>
</DataGridTextColumn>
</DataGrid>
我在资源里面也有这个:
<local:PositiveNegativeConverter x:Key="PositiveNegativeConverter"/>
</UserControl.Resources>
我的转换器如下所示:
class PositiveNegativeConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
bool revert = (parameter as string).StartsWith("-");
string stringValue = value as string;
string compareValue = parameter as string;
if (revert)
{
return "Negative";
}
else
return "Positive";
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
throw new NotSupportedException();
}
}