VB.NET CHART

 import namespace

    

[vb]  view plain  copy
  1. Imports System.Windows.Forms.DataVisualization.Charting  

    找个namespace包含用于图表 Windows 窗体控件方法和属性(如chart控件)


2. 设置chart控件

    

    a. 在ChartArea属性里,添加ChartArea1, ChartArea2.

    b. 设置align相关属性。

       

       


3. 使用代码配置ChartArea

    a. 已添加ChartArea。

        这种情况直接设置

       

[vb]  view plain  copy
  1. Chart1.ChartAreas(0).AxisX.Title = "Length (nt)"   '设置ChartArea里坐标轴标题  
  2. Chart1.ChartAreas(0).AxisY.Title = "Read count"  
  3.   
  4.   
  5. Chart1.ChartAreas(1).AxisX.Title = "Length (nt)"   '设置ChartArea里坐标轴标题  
  6. Chart1.ChartAreas(1).AxisY.Title = "Read count"  
  7.   
  8.   
  9. minValue = DateTime.Now  
  10. '30预览区域   
  11. maxValue = minValue.AddSeconds(30)  
  12.   
  13.   
  14. Chart1.ChartAreas(0).AxisX.Minimum = minValue.ToOADate()  
  15. Chart1.ChartAreas(0).AxisX.Maximum = maxValue.ToOADate()  
  16.   
  17.   
  18. Chart1.ChartAreas(1).AxisX.Minimum = minValue.ToOADate()  
  19. Chart1.ChartAreas(1).AxisX.Maximum = maxValue.ToOADate()  
  20.   
  21.   
  22. Chart1.Series.Clear()  
  23.   
  24.   
  25. Dim series1 As New Series("Read Count")  
  26. series1.ChartType = SeriesChartType.Line         '设置Series的绘图类型  
  27. series1.BorderWidth = 1  
  28. series1.Color = Color.Red  
  29. series1.XValueType = ChartValueType.Time  
  30.   
  31. series1.ChartArea = "ChartArea1"  
  32.   
  33. Dim series2 As New Series("Read Count2")  
  34. series2.ChartType = SeriesChartType.Line         '设置Series的绘图类型  
  35. series2.BorderWidth = 1  
  36. series2.Color = Color.Blue  
  37. series2.XValueType = ChartValueType.Time  
  38.   
  39. series2.ChartArea = "ChartArea2"  
  40.   
  41. Chart1.Series.Add(series1)  
  42. Chart1.Series.Add(series2)  



    b. 未添加ChartArea

        在上一段代码之前添加如下代码

[vb]  view plain  copy
  1. Chart1.ChartAreas.Clear() '清空ChartArea  
  2. Dim ChartAreas1 As New ChartArea("ChartArea1")    '定义新的ChartArea  
  3. Dim ChartAreas2 As New ChartArea("ChartArea2")    '定义新的ChartArea  
  4. Chart1.ChartAreas.Add(ChartAreas1)                 '将新定义的ChartArea加入Chart1  
  5. Chart1.ChartAreas.Add(ChartAreas2)                 '将新定义的ChartArea加入Chart1  


4. 添加points

[vb]  view plain  copy
  1. For Each ptA In Chart1.ChartAreas  
  2.      Dim ptSeries As Series  
  3.      '对每series进行数据扫描   
  4.      For Each ptSeries In Chart1.Series  
  5.          ptSeries.Points.AddXY(x y)  
  6.      Next ptSeries  
  7.  Next  


5. 动态修改X轴坐标(例如:随时间变化)

[vb]  view plain  copy
  1. Dim timeStamp As DateTime = DateTime.Now  
  2. Dim removeBefore As Double = timeStamp.AddSeconds((CDbl(15) * -1)).ToOADate()  
  3. 'remove oldest values to maintain a constant number of data points   
  4. While ptSeries.Points(0).XValue < removeBefore  
  5.     ptSeries.Points.RemoveAt(0)  
  6. End While  
  7.   
  8.   
  9. Dim ptA As ChartArea  
  10. For Each ptA In Chart1.ChartAreas  
  11.     ptA.AxisX.Minimum = ptSeries.Points(0).XValue  
  12.     ptA.AxisX.Maximum = DateTime.FromOADate(ptSeries.Points(0).XValue).AddSeconds(30).ToOADate()  
  13. Next  



6. 清空数据

[vb]  view plain  copy
  1. Chart1.Series(0).Points.Clear()  


效果图





  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值