I'am trying to bind a ObservableCollection list to a datagrid.
The Values in the list change every 100ms. I want that the grid automatically refreshs if a value changed.
Here is a little demo project to make it work. But without the refresh UI button, nothing works right.
public partial class MainWindow : Window
{
public ObservableCollection<DemoItem> ItemList = new ObservableCollection<DemoItem>();
public MainWindow()
{
InitializeComponent();
DemoItem di1 = new DemoItem();
di1.Name = "Spieler 1";
di1.Zufallszahl = 0;
di1.Alter = 21;
DemoItem di2 = new DemoItem();
di2.Name = "Spieler 2";
di2.Zufallszahl = 0;
di2.Alter = 15;
ItemList.Add(di1);
ItemList.Add(di2);
DispatcherTimer dt = new DispatcherTimer();
dt.Interval = new TimeSpan(0, 0, 0, 0, 100);
dt.Tick += Dt_Tick;
dt.Start();
}
public ObservableCollection<DemoItem> ObservableDemoItem
{
get
{
return this.ItemList;
}
}
private void Dt_Tick(object sender, EventArgs e)
{
Random rnd = new Random();
ItemList[0].Zufallszahl = rnd.Next(0, 1000);
ItemList[1].Zufallszahl = rnd.Next(0, 1000);
}
private void button1_Click(object sender, RoutedEventArgs e)
{
dataGrid.Items.Refresh();
}
}
XAML:
<Window x:Class="WpfApplication1.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:WpfApplication1"
mc:Ignorable="d"
Title="MainWindow" Height="359.428" Width="539.141">
<Grid>
<DataGrid x:Name="dataGrid" HorizontalAlignment="Left"
Margin="10,10,0,0" SelectionMode="Extended" VerticalAlignment="Top"
Height="199" Width="497" CanUserAddRows="False"
CanUserDeleteRows="False" AutoGenerateColumns="False"
DataContext="{Binding RelativeSource={RelativeSource AncestorType=Window}}"
ItemsSource="{Binding ObservableDemoItem}" >
<DataGrid.Columns>
<DataGridTextColumn Header="Name" Binding="{Binding Name}" />
<DataGridTextColumn Header="Alter" Binding="{Binding Alter}" />
<DataGridTextColumn Header="Aktiv" Binding="{Binding Zufallszahl}" />
</DataGrid.Columns>
</DataGrid>
<Button x:Name="button1" Content="Update UI" HorizontalAlignment="Left"
Margin="55,245,0,0" VerticalAlignment="Top"
Width="425" Height="61" Click="button1_Click"/>
</Grid>
</Window>
What do I need to change, to make it work?