【问题标题】:Candlestick multiple Y values烛台多个 Y 值
【发布时间】:2012-10-19 22:15:33
【问题描述】:

我的任务是在 Windows 窗体中使用 MSChart 制作烛台图。我已经成功地制作了一个没有问题的 3D 条形图。但是在网上搜索了很久,微软的源代码(WinSamples)和很多令人头疼的问题后,我找不到创建烛台图的正确方法。

对我有帮助的是一个清晰的例子,它向图表中添加了一个带有多个 Y 值或更正我的代码的系列(当我运行时,除了图例标签之外,调试什么都没有显示)。

一个好处是该示例基于 OleDB(我的值在 Access 数据库中)。

所以我的问题是:如果你有在 Windows 窗体中用 C# 创建烛台图表的经验,你能给我一个提示或者(甚至更好)你能给我一些 c# 代码吗?

这是我当前(不工作)的代码:

using System.Windows.Forms.DataVisualization.Charting;
public partial class CandleStick : Form
{
    public CandleStick()
    {
        InitializeComponent();
    }

    private void CandleStick_Load(object sender, EventArgs e)
    {
        GrafiekLaden();
    }

    public void GrafiekLaden()
    {

        Koers k = new Koers();
        // This method fills up a list, the data comes from my database
        // it contains Date, High, Low, Open, Close
        k.meerdereOphalen();

        Series price = new Series();
        chart1.Series.Add(price);

        // Set series chart type
        chart1.Series["price"].ChartType = SeriesChartType.Candlestick;

        // Set the style of the open-close marks
        chart1.Series["price"]["OpenCloseStyle"] = "Triangle";

        // Show both open and close marks
        chart1.Series["price"]["ShowOpenClose"] = "Both";

        // Set point width
        chart1.Series["price"]["PointWidth"] = "1.0";

        // Set colors bars
        chart1.Series[0]["PriceUpColor"] = "Green";
        chart1.Series[0]["PriceDownColor"] = "Red";

        for (int i = 0; i < k.Lijst.Count; i++)
        {
            // adding date and high
            chart1.Series["price"].Points.AddXY(DateTime.Parse(k.Lijst[i].Datum), k.Lijst[i].Hoog);
            // adding low
            chart1.Series["price"].Points[i].YValues[1] = k.Lijst[i].Laag;
            //adding open
            chart1.Series["price"].Points[i].YValues[2] = k.Lijst[i].PrijsOpen;
            // adding close
            chart1.Series["price"].Points[i].YValues[3] = k.Lijst[i].PrijsGesloten;
        }
    }

【问题讨论】:

    标签: c# oledb mschart candlestick-chart


    【解决方案1】:

    您的代码添加了一个未命名为“price”的Series,然后引用了Series["price"]Series[0],如果其他系列已经存在,这将是不同的。我运行了一个稍微修改过的版本(使用List&lt;&gt; 伪造数据库数据)没有任何问题。 您应该验证来自您的数据库的数据是否正常。

    public partial class Form3 : Form
    {
        public Form3()
        {
            InitializeComponent();
        }
    
        private void CandleStick_Load(object sender, EventArgs e)
        {
            GrafiekLaden();
        }
    
        public void GrafiekLaden()
        {
            // fake the DB data with a simple list
            List<dbdata> k = new List<dbdata> { 
                new dbdata("1/1/2012", 10f, 8f, 9f, 9.5f),
                new dbdata("2/1/2012", 15F, 10F, 12F, 13F),
                new dbdata("3/1/2012", 5F, 10F, 8F, 6F),
                new dbdata("4/1/2012", 25F, 10F, 18F, 16F)
            };
    
            Series price = new Series("price"); // <<== make sure to name the series "price"
            chart1.Series.Add(price);
    
            // Set series chart type
            chart1.Series["price"].ChartType = SeriesChartType.Candlestick;
    
            // Set the style of the open-close marks
            chart1.Series["price"]["OpenCloseStyle"] = "Triangle";
    
            // Show both open and close marks
            chart1.Series["price"]["ShowOpenClose"] = "Both";
    
            // Set point width
            chart1.Series["price"]["PointWidth"] = "1.0";
    
            // Set colors bars
            chart1.Series["price"]["PriceUpColor"] = "Green"; // <<== use text indexer for series
            chart1.Series["price"]["PriceDownColor"] = "Red"; // <<== use text indexer for series
    
            for (int i = 0; i < k.Count; i++)
            {
                // adding date and high
                chart1.Series["price"].Points.AddXY(DateTime.Parse(k[i].Datum), k[i].Hoog);
                // adding low
                chart1.Series["price"].Points[i].YValues[1] = k[i].Laag;
                //adding open
                chart1.Series["price"].Points[i].YValues[2] = k[i].PrijsOpen;
                // adding close
                chart1.Series["price"].Points[i].YValues[3] = k[i].PrijsGesloten;
            }
        }
    }
    
    class dbdata
    {
        public string Datum;
        public float Hoog;
        public float Laag;
        public float PrijsOpen;
        public float PrijsGesloten;
        public dbdata(string d, float h, float l, float o, float c) { Datum = d; Hoog = h; Laag = l; PrijsOpen = o; PrijsGesloten = c; }
    }
    

    【讨论】:

    • 非常感谢!事实证明,我的数据库返回了一些空值(已修复)并且有了额外的提示/更正,我终于设法创建了我的烛台图。你是最棒的!
    • 如果你和我一样,不使用 for 循环而是使用 foreach,那么它可能有助于提醒某人 .AddXY() 方法将实际索引返回到它插入点的位置.我还需要向 YValues 属性添加一个完整的 double[]。
    猜你喜欢
    • 2018-12-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-12-13
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多