Sono in missione per creare un grafico a candela utilizzando MSChart in un modulo di Windows. Sono già riuscito a creare un grafico a barre 3D senza problemi. Ma dopo una lunga ricerca su internet, il codice sorgente di Microsoft (WinSamples) e un sacco di headscratching non riesco a trovare il modo giusto per creare un grafico a candela.Candlestick valori Y multipli
Quello che potrebbe aiutarmi è un chiaro esempio di aggiunta di una serie al grafico con più valori Y o una correzione del mio codice (quando eseguo, il debug non mostra nulla per l'etichetta della legenda).
Un bonus sarebbe che l'esempio è basato su OleDB (i miei valori sono in un database di Access).
Quindi la mia domanda: se hai esperienza con la creazione di un grafico a Candela in C# in un modulo di Windows puoi darmi un suggerimento o (ancora meglio) puoi fornirmi un codice C#?
Ecco il mio attuale (non funzionante) Codice:
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;
}
}
Grazie mille! Si scopre che il mio database ha restituito alcuni valori vuoti (risolto quello) E con i tuoi suggerimenti/correzioni extra sono finalmente riuscito a creare il mio grafico a candele. U sono i migliori! – Jens