2012-04-16 9 views
6

Dinamik grafik aşağıdaki gayrimenkulünü ZedGraph yapmak istiyorum: enter image description here Nasıl ZedGraph ters eksenleri yapmak ve ve zaman ekseni? TeşekkürZedGraph özel grafik

UPD 1: Aşağıdaki kod ile denemek zorunda:

GraphPane myPane = zg1.GraphPane; 
      myPane.YAxis.Type = AxisType.Date; 
      myPane.YAxis.Scale.MajorUnit = DateUnit.Minute; 
      myPane.YAxis.Scale.MinorUnit = DateUnit.Second; 
      myPane.XAxis.IsVisible = false; 
      myPane.X2Axis.IsVisible = true; 
      myPane.X2Axis.MajorGrid.IsVisible = true; 
      myPane.X2Axis.Scale.Min = 0; 
      myPane.X2Axis.Scale.Max = 600; 
      myPane.YAxis.Scale.Format = "HH:mm:ss"; 
      PointPairList list = new PointPairList(); 
      PointPairList list2 = new PointPairList(); 
      for (int i = 0; i < 36; i++) 
      { 
       double x = (double)i * 5.0; 
       double y = (double)new XDate(DateTime.Now.AddSeconds(i)); 
       list.Add(y, x); 
       //list2.Add(y2, x); 
       listBox1.Items.Add("x = " + x + " y = " + y); 
      } 

      // Generate a red curve with diamond symbols, and "Alpha" in the legend 
      LineItem myCurve = myPane.AddCurve("Alpha", 
       list, Color.Red, SymbolType.None); 
      // Fill the symbols with white 
      myCurve.Symbol.Fill = new Fill(Color.White); 
         myPane.Y2Axis.MajorGrid.IsVisible = true; 
      // Align the Y2 axis labels so they are flush to the axis 
      myPane.Y2Axis.Scale.Align = AlignP.Inside; 

      // Fill the axis background with a gradient 
      myPane.Chart.Fill = new Fill(Color.White, Color.LightGray, 45.0f); 
      zg1.IsShowPointValues = true; 
      zg1.AxisChange(); 
      // Make sure the Graph gets redrawn 
      zg1.Invalidate(); 

Ama ben yanlış bir şey alın:

ı için kod var: enter image description here

UPD2 çoklu yayma:

private TimerCallback ReadTimerCallback; 
     private LineItem myCurve; 
     private Random rnd = new Random(500); 
     public Form1() 
     { 
      InitializeComponent(); 
     } 

     private void button1_Click(object sender, EventArgs e) 
     { 
      GraphPane myPane = zg1.GraphPane; 

      myPane.XAxis.IsVisible = false; 

      myPane.X2Axis.IsVisible = true; 
      myPane.X2Axis.MajorGrid.IsVisible = true; 
      myPane.X2Axis.Scale.Min = 0; 
      myPane.X2Axis.Scale.Max = 600; 

      myPane.YAxis.IsVisible = false; 

      myPane.Y2Axis.IsVisible = true; 
      myPane.Y2Axis.Scale.MajorUnit = DateUnit.Minute; 
      myPane.Y2Axis.Scale.MinorUnit = DateUnit.Second; 
      myPane.Y2Axis.Scale.Format = "HH:mm:ss"; 
      myPane.Y2Axis.Type = AxisType.DateAsOrdinal; 

      // As we get more data we want to add it on to the end of the curve 
      // and we also want to get the scale so that we can shift it along 
      double? oringinalLastDate; 
      XDate firstDate; 
      if (myPane.CurveList.Count == 0) 
      { 
       myCurve = myPane.AddCurve("Alpha", 
              new PointPairList(), 
              Color.Red, 
              SymbolType.None); 
       firstDate = new XDate(DateTime.Now); 
       oringinalLastDate = null; 
      } 
      else 
      { 
       myCurve = (LineItem)myPane.CurveList[0]; 
       firstDate = myCurve.Points[myCurve.Points.Count - 1].Y; 
       oringinalLastDate = myPane.Y2Axis.Scale.Max; 
      } 

      /*for (int i = 0; i < 36; i++) 
      { 
       double x = i * 5.0; 
       firstDate.AddSeconds(i); 

       myCurve.AddPoint(x, firstDate); 

       //listBox1.Items.Add("x = " + x + " y = " + firstDate); 
      }*/ 

      myCurve.Symbol.Fill = new Fill(Color.White); 
      myCurve.IsX2Axis = true; 
      myCurve.IsY2Axis = true; 
      //myPane.Y2Axis.Scale.IsReverse = true; 

      myPane.Chart.Fill = new Fill(Color.White, Color.LightGray, 45.0f); 
      zg1.IsShowPointValues = true; 

      // Now make the minimum of the scale, the maximum that it was so 
      // the graph shifts 
      if (oringinalLastDate.HasValue) 
       myPane.Y2Axis.Scale.Min = oringinalLastDate.Value; 

      zg1.AxisChange(); 
      zg1.Invalidate(); 
      AutoResetEvent ReadautoEvent = new AutoResetEvent(false); 
      ReadTimerCallback = new TimerCallback(this.ShowData); 
      System.Threading.Timer timer = new System.Threading.Timer(ReadTimerCallback, ReadautoEvent, 100, 1000); 

     } 

     private void ShowData (object Object) 
     { 
      this.myCurve.AddPoint(rnd.Next(500, 600), new XDate(DateTime.Now)); 
     } 

UPD3: Y eksenini aşağı kaydırmak istiyorum, bu ekseni ölçeklemek değil. Ve güncelledik grafik sadece 1 dakika: enter image description here

cevap

3

Sana DateAsOrdinal istediğini düşünüyorum (yerine Tarihi), daha iyi tarih temsillerini verecek şekilde (onunla mutlu belki değilse bile) ve IsX2Axis ayarlamanız gerekir ve eğride IsY2Axis özellikleri true.

İşte kodunuzun ne demek olduğunu gösteren güncellenmiş bir sürümü - bu sizin ihtiyacınız olan şey nedir? (veri değerleri göz önünde bulundurulduğunda çizili bir çizgi olmayacak ve x ekseni ölçeği çiziminizde olduğu gibi değil, 100'de başlayacaktır, ancak kodunuz açıkça 0'a ayarlanmış olduğu için bu yüzden istemek).

Her zaman çağrıldığında her zaman daha fazla veri ekleyecektir (bunu düğmenizden çağıracağınızı varsayıyorum) ve en küçük veriyi gösterecek şekilde eksen için minimum değeri değiştirecektir - Min değerini ayarlamazsanız, tüm verileri gösterdiği gibi titrek çizgi görürsünüz.

GraphPane myPane = zg1.GraphPane;    

myPane.XAxis.IsVisible = false; 

myPane.X2Axis.IsVisible = true; 
myPane.X2Axis.MajorGrid.IsVisible = true; 
myPane.X2Axis.Scale.Min = 0; 
myPane.X2Axis.Scale.Max = 600; 

myPane.YAxis.IsVisible = false; 

myPane.Y2Axis.IsVisible = true; 
myPane.Y2Axis.Scale.MajorUnit = DateUnit.Minute; 
myPane.Y2Axis.Scale.MinorUnit = DateUnit.Second; 
myPane.Y2Axis.Scale.Format = "HH:mm:ss"; 
myPane.Y2Axis.Type = AxisType.DateAsOrdinal; 

// As we get more data we want to add it on to the end of the curve 
// and we also want to get the scale so that we can shift it along 
double? oringinalLastDate; 
XDate firstDate; 
LineItem myCurve; 
if(myPane.CurveList.Count == 0) 
{ 
    myCurve = myPane.AddCurve("Alpha", 
           new PointPairList(), 
           Color.Red, 
           SymbolType.None); 
    firstDate = new XDate(DateTime.Now); 
    oringinalLastDate = null; 
} 
else 
{ 
    myCurve = (LineItem)myPane.CurveList[0]; 
    firstDate = myCurve.Points[myCurve.Points.Count - 1].Y; 
    oringinalLastDate = myPane.Y2Axis.Scale.Max; 
}    

for (int i = 0; i < 36; i++) 
{ 
    double x = i * 5.0; 
    firstDate.AddSeconds(i); 

    myCurve.AddPoint(x, firstDate); 

    listBox1.Items.Add("x = " + x + " y = " + firstDate); 
} 

myCurve.Symbol.Fill = new Fill(Color.White); 
myCurve.IsX2Axis = true; 
myCurve.IsY2Axis = true; 

myPane.Chart.Fill = new Fill(Color.White, Color.LightGray, 45.0f); 
zg1.IsShowPointValues = true; 

// Now make the minimum of the scale, the maximum that it was so 
// the graph shifts 
if (oringinalLastDate.HasValue) 
    myPane.Y2Axis.Scale.Min = oringinalLastDate.Value; 

zg1.AxisChange();    
zg1.Invalidate(); 

Güncelleme

Eğer y ekseninde bu yapmak gerekir 500 ve 600 arasında rastgele bir sayı (her 3 puan eklendikten sonra, ölçek ile bir kere ikinci bir grafik güncellemek için boyunca hareket eder):

private int pointCount; 
private double? scaleMin = null; 
private static readonly Random rnd = new Random(); 

private void button1_Click(object sender, EventArgs e) 
{ 
    GraphPane myPane = zg1.GraphPane; 

    myPane.XAxis.IsVisible = false; 

    myPane.X2Axis.IsVisible = true; 
    myPane.X2Axis.MajorGrid.IsVisible = true; 
    myPane.X2Axis.Scale.Min = 0; 
    myPane.X2Axis.Scale.Max = 600; 

    myPane.YAxis.IsVisible = false; 

    myPane.Y2Axis.IsVisible = true; 
    myPane.Y2Axis.Scale.MajorUnit = DateUnit.Minute; 
    myPane.Y2Axis.Scale.MinorUnit = DateUnit.Second; 
    myPane.Y2Axis.Scale.Format = "HH:mm:ss"; 
    myPane.Y2Axis.Type = AxisType.DateAsOrdinal; 

    LineItem myCurve = myPane.AddCurve("Alpha", 
            new PointPairList(), 
            Color.Red, 
            SymbolType.None); 

    myCurve.Symbol.Fill = new Fill(Color.White); 
    myCurve.IsX2Axis = true; 
    myCurve.IsY2Axis = true; 

    myPane.Chart.Fill = new Fill(Color.White, Color.LightGray, 45.0f); 
    zg1.IsShowPointValues = true; 

    pointCount = 0; 

    var t = new System.Windows.Forms.Timer(); 
    t.Interval = 1000; 
    t.Tick += ShowData; 

    Thread.Sleep(100); 

    t.Start(); 
} 

private void ShowData(object sender, EventArgs e) 
{ 
    var t = (System.Windows.Forms.Timer) sender; 
    t.Enabled = false; 

    pointCount++; 

    int x = rnd.Next(500, 600); 
    var y = new XDate(DateTime.Now); 

    GraphPane myPane = zg1.GraphPane; 

    if (scaleMin == null) scaleMin = myPane.Y2Axis.Scale.Max; 

    LineItem myCurve = (LineItem)myPane.CurveList[0];    

    myCurve.AddPoint(x, y); 

    // After 3 points are added move the scale along 
    if (pointCount > 3) 
    { 
     myPane.Y2Axis.Scale.Min = scaleMin.Value; 
     scaleMin = myPane.Y2Axis.Scale.Max; 
    } 

    zg1.AxisChange(); 
    zg1.Invalidate(); 

    t.Enabled = true; 
} 
+0

Teşekkürler kmp! İhtiyacım olan budur, ama gerçek zamanlı verileri görselleştirmek için zaman eksenini harekete geçirmek istiyorum. Bunu nasıl yapılır? – amaranth

+0

Cevabı güncelledim - umarım sizi anladım - kod her çağrıldığında ekleniyor ve minimum eksen noktası ayarlanıyor, böylece son 35 saniyelik veri göreceksiniz. – kmp

+0

1. myCurve.AddPoint (x, firstDate) ile yeni veriler eklemem ve myPane.Y2Axis.Scale.Min = oringinalLastDate.Value tarafından minimum ölçek ayarlamalıyım? 2. Başka bir konudan myCurve'a puan ekleyebilir miyim? – amaranth