这是Oxyplot官方页面显示的代码。 名称空间WpfApplication2
{
using System.Collections.Generic;
using OxyPlot;
public class MainViewModel
{
public MainViewModel()
{
this.Title = "Example 2";
this.Points = new List<DataPoint>
{
new DataPoint(0, 4),
new DataPoint(10, 13),
new DataPoint(20, 15),
new DataPoint(30, 16),
new DataPoint(40, 12),
new DataPoint(50, 12)
};
}
public string Title { get; private set; }
public IList<DataPoint> Points { get; private set; }
}
}
这是XAML
<Window x:Class="WpfApplication2.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:oxy="http://oxyplot.codeplex.com"
xmlns:local="clr-namespace:WpfApplication2"
Title="Example 2 (WPF)" Height="350" Width="525">
<Window.DataContext>
<local:MainViewModel/>
</Window.DataContext>
<Grid>
<oxy:Plot Title="{Binding Title}">
<oxy:Plot.Series>
<oxy:LineSeries ItemsSource="{Binding Points}"/>
</oxy:Plot.Series>
</oxy:Plot>
</Grid>
</Window>
该示例工作正常并在图表上显示6个点。 我想要做的是绘制通过串行端口传输的数据图。我想在DispatcherTimer的Tick事件中添加新的图形点。为了消除任何误解,我的问题的范围是关于oxyplot,(例如,不应该在回答中包括计时器事件的使用。)提前谢谢你。
答案 0 :(得分:6)
试试这段代码。
XAML:
<oxy:PlotView Model="{Binding DataPlot}"/>
MainViewModel:
public PlotModel DataPlot { get; set; }
private double _xValue = 1;
public MainViewModel()
{
DataPlot = new PlotModel();
DataPlot.Series.Add(new LineSeries());
var dispatcherTimer = new DispatcherTimer { Interval = new TimeSpan(0, 0, 1) };
dispatcherTimer.Tick += dispatcherTimer_Tick;
dispatcherTimer.Start();
}
private void dispatcherTimer_Tick(object sender, EventArgs e)
{
Dispatcher.CurrentDispatcher.Invoke(() =>
{
(DataPlot.Series[0] as LineSeries).Points.Add(new DataPoint(_xValue, Math.Sqrt(_xValue)));
DataPlot.InvalidatePlot(true);
_xValue ++;
});
}
如果你不想在图表中从头到尾累积所有点,只需在添加每个新点后使用它:
if ((DataPlot.Series[0] as LineSeries).Points.Count > 10) //show only 10 last points
(DataPlot.Series[0] as LineSeries).Points.RemoveAt(0); //remove first point
如果你想要更好的图表流程(这个每秒更新一次),我建议使用Stopwatch
,将代码添加到自己的方法中,并在构造函数的线程中启动该方法。然后使用Stopwatch.ElapsedMilliseconds
作为x值。