烛台多个Y值

我的任务是使用Windows窗体中的MSChart制作烛台图。 我已经成功制作了一个没有问题的3D条形图。 但经过长时间的互联网搜索,微软的源代码(WinSamples)以及大量的头像,我无法找到创建烛台图的正确方法。

什么可以帮助我是一个明确的例子,在图表中添加一个系列,其中包含多个Y值或我的代码的更正(当我运行时,调试没有显示为图例标签的exept)。

奖励是该示例基于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; } } 

你的代码添加了一个名为“price”的Series["price"] ,然后引用Series["price"]Series[0] ,如果其他系列已经存在则不会是同一个东西。 我运行了一个稍微修改过的版本(使用List<>伪造db数据)没有任何问题。 您应该validation来自数据库的数据是否正常。

在此处输入图像描述

 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 k = new List { 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; } }