实时图表-可观察的价值

时间:2018-11-22 10:35:06

标签: c# winforms livecharts

我正在使用LiveCharts来显示带有库存水平的条形图。单位名称和库存水平存储在访问数据库中,并检索这些值并将其放入列表中。

唯一真正需要更改的是库存价值,因此我想跟踪库存变化并自动更新数据库,从而提供一些实时数据。

我想让图表在数据库中的值(库存)变化时自动更新。我不想更新整个表,仅更新已更改的值,以便动画在更改时显示在各个小节上。

我有以下代码将数据库值加载到数据库中:

    string[] units = new string[30];
    List<string> subs = new List<string>();
    List<string> line = new List<string>();
    List<double> min = new List<double>();
    List<double> max = new List<double>();
    List<ObservableValue> stock = new List<ObservableValue>();

    bool initial = true;
    private void LoadData()
    {
        string strConn = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Database\subDB.mdb";

        using (OleDbConnection conn = new OleDbConnection(strConn))
        {
            conn.Open();
            string strSQL = "SELECT * FROM Units";
            OleDbCommand command = new OleDbCommand(strSQL, conn);

            using (OleDbDataReader reader = command.ExecuteReader())
            {
                while (reader.Read())
                {
                    if (initial)
                    {
                        subs.Add(reader["Sub"].ToString());
                        line.Add(reader["Line"].ToString());
                        min.Add(Convert.ToDouble(reader["Minimum"]));
                        max.Add(Convert.ToDouble(reader["Maximum"]));
                    }
                        stock.Add(reader["Stock"]);
                }
            }
            initial = false;
        }
    }

图表设置:

    public void chartSetup()
    {
        cartesianChart1.Series = new SeriesCollection
        {
            new ColumnSeries
            {
                Title = "Total",
                Fill = System.Windows.Media.Brushes.Crimson,                 
                Values = new ChartValues<ObservableValue>(stock)
            }
        };
        cartesianChart1.AxisX.Add(new Axis
        {
            Title = "Unit",
            FontSize = 15,
            Separator = new Separator
            {
                Step = 1,
                IsEnabled = false //disable it to make it invisible.
            },
            LabelsRotation = 45,
            Labels = new ChartValues<string>(subs)
        });

        cartesianChart1.AxisY.Add(new Axis
        {
            Title = "Total",
            FontSize = 15,
            ShowLabels = true,
            LabelFormatter = value => value.ToString("N")
        });
    }

我的问题是我无法实现股票的ObservableValue。我收到消息:“无法从'对象'转换为 LiveCharts.Defaults.ObservableValue

1 个答案:

答案 0 :(得分:1)

LiveCharts可观察值expects to be initialized with a double,因此您需要将stock的值转换为该值,并将ObservableValue而不是原始值添加到列表中::

stock.Add(new ObservableValue(Convert.ToDouble(reader["Stock"])));