所以我使用WPFToolKit图表作为ColumnSeries。当我最初加载屏幕时,数据值正确填充到图表中。但是,当我尝试更新数据值时,图表的数据不会刷新。
我已经尝试过此处列出的解决方案Update and refresh wpf chart,我在其中命名我的列系列并更新了列系列的DataContext而不是图表,但这产生了相同的结果。
这是我的图表的xaml
<chartingToolkit:Chart Height="262" HorizontalAlignment="Left" Margin="120,0,0,213" Name="Chart_Payout" Title="Payout Threshold Results" VerticalAlignment="Bottom" Width="360">
<chartingToolkit:ColumnSeries Name ="ColumnSeries_Payout" DependentValuePath="Value" IndependentValuePath="Key" ItemsSource="{Binding}" Title="Payout" />
</chartingToolkit:Chart>
以下是我用来更新图表的方法
private void FillPayoutChart()
{
chartValues.Clear();
chartValues.Add(new KeyValuePair<string, decimal>("$" + Payout_In.ToString("#,##0.00") + " In", Payout_In));
chartValues.Add(new KeyValuePair<string, decimal>("", 0));
chartValues.Add(new KeyValuePair<string, decimal>("$" + Payout_Out.ToString("#,##0.00") + " Out", Payout_Out));
ColumnSeries_Payout.DataContext = chartValues;
}
Payout_In和Payout_Out都是在WPF窗口类中声明的小数。最初打开窗口时,图表已成功填充信息。但是,当我在加载窗口后尝试更新该信息时,图表不会使用新数据上下文进行刷新。
有关刷新图表值中的数据上下文需要做些什么的指导?
答案 0 :(得分:1)
这是因为您覆盖ColumnSeries
DataContext,旧绑定将失败。您应该更改将存储为字段或以其他方式存储的现有DataContext。不要第二次分配DataContext。
private void FillPayoutChart()
{
chartValues.Clear();
chartValues.Add(new KeyValuePair<string, decimal>("$" + Payout_In.ToString("#,##0.00") + " In", Payout_In));
chartValues.Add(new KeyValuePair<string, decimal>("", 0));
chartValues.Add(new KeyValuePair<string, decimal>("$" + Payout_Out.ToString("#,##0.00") + " Out", Payout_Out));
// execute next string just one time and then manipulate chartValues collection
//ColumnSeries_Payout.DataContext = chartValues;
}
当然,您的chartValues应该是ObservableCollection<KeyValuePair<string, decimal>>
,否则您的ColumnSeries
不会撤销收集更改的事件。