私は現在、データベースのテーブルを表示しているdatagrid-WPFに取り組んでいます。この表には、学生の結果に関する情報がPASSANDFAILとして表示されます。ここで、データグリッドセル上のセルを、合格の場合は緑色、不合格の場合は赤色としてアニメーション化します。
これをc#とXAMLで実現するにはどうすればよいですか?ありがとう。
私は現在、データベースのテーブルを表示しているdatagrid-WPFに取り組んでいます。この表には、学生の結果に関する情報がPASSANDFAILとして表示されます。ここで、データグリッドセル上のセルを、合格の場合は緑色、不合格の場合は赤色としてアニメーション化します。
これをc#とXAMLで実現するにはどうすればよいですか?ありがとう。
DataGridTemplateColumn
あなたは..として何かを使うことができます
例に従います..
<DataGridTemplateColumn CellStyle="{StaticResource CenterAlignCell}" Header="Result" IsReadOnly="True" Width="*" Visibility="Visible" CanUserResize="True" SortMemberPath="GAIN_AT_POSITION" CanUserSort="True">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<StackPanel Background="{Binding GainHighlight}">
<TextBlock Text="{Binding GAIN_AT_POSITION, StringFormat=N2}" Foreground="{Binding GainForeGround}"/>
</StackPanel>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
ps: GainHighlight
UI にバインドするクラスのプロパティです。
お役に立てば幸いです。
一番。
スタイルとコンバーターを使用する
public class SomeConverter: IValueConverter
{
public object Convert(object value, Type targetType,
object parameter, CultureInfo culture)
{
string cellValue = value.ToString();
return cellValue == "PASS";
}
public object ConvertBack(object value, Type targetType,
object parameter, CultureInfo culture)
{
return false;
}
}
<DataGrid ItemsSource="{Binding List}" AutoGenerateColumns="False">
<DataGrid.Resources>
<myApp:SomeConverter
x:Key="SomeConverter">
</myApp:SomeConverter>
<Style TargetType="DataGridCell" x:Key="FlashStyle">
<Style.Triggers>
<DataTrigger
Binding="{Binding Col1,
Converter={StaticResource SomeConverter}}"
Value="True" >
<DataTrigger.EnterActions>
<BeginStoryboard>
<Storyboard
x:Name="Blink"
AutoReverse="True"
RepeatBehavior="Forever">
<ColorAnimationUsingKeyFrames
BeginTime="00:00:00"
Storyboard.TargetProperty="(Background).(SolidColorBrush.Color)">
<EasingColorKeyFrame
KeyTime="00:00:01"
Value="Green" />
</ColorAnimationUsingKeyFrames>
</Storyboard>
</BeginStoryboard>
</DataTrigger.EnterActions>
</DataTrigger>
</Style.Triggers>
</Style>
</DataGrid.Resources>
<DataGrid.Columns>
<DataGridTextColumn
Binding="{Binding Col1}"
CellStyle="{StaticResource FlashStyle}"></DataGridTextColumn>
<DataGridTextColumn
Binding="{Binding Col2}"></DataGridTextColumn>
</DataGrid.Columns>
そして、xaml に value = false の 2 番目のデータ トリガーを含め、赤色をトリガーします。
スタイルをデータグリッド列に追加します
<DataGrid.Columns>
<DataGridTextColumn
Binding="{Binding SomeCol}"
CellStyle="{StaticResource FlashStyle}"></DataGridTextColumn>
<DataGridTextColumn
Binding="{Binding AnotherCol}"
CellStyle="{StaticResource FlashStyle}"></DataGridTextColumn>