如何向 OxyPlot 添加新点?

Posted

技术标签:

【中文标题】如何向 OxyPlot 添加新点?【英文标题】:How to add new points to OxyPlot? 【发布时间】:2014-05-30 01:38:11 【问题描述】:

这是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,(例如,答案中不应包含计时器事件的使用。)提前谢谢您。

【问题讨论】:

【参考方案1】:

试试这个代码。

XAML:

<oxy:PlotView Model="Binding DataPlot"/>

主视图模型:

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 值。

【讨论】:

你的回答结束了我几天的搜索。谢谢大侠。

以上是关于如何向 OxyPlot 添加新点?的主要内容,如果未能解决你的问题,请参考以下文章

OxyPlot 中日期时间轴上的不规则间隔

OxyPlot 添加 PlotModel

Xamarin图表开发基础教程OxyPlot框架

如何更改 OxyPlot Y 轴字符串格式?

在 Xamarin.Android 中通过 MVVMCross 绑定 OxyPlot

OxyPlot 未在 Xamarin 表单中显示