vb.net chart图表使用技巧之一

很多朋友再为使用什么样曲线来显示数据发愁,当然有MONEY的朋友除外。其实微软已经给我们提供一个很强大免费的控件,那就是chart ,当然这个控件只能再vs.2008以上的版本才能使用。不过很少有人介绍怎么使用。于是本人花了一天时间,认真进行学习。

详细的程序如下,中间我已经作了很多说明,呵呵

    Private AddDataRunner As Thread
    Private Rand As New Random()
    Public Delegate Sub AddDataDelegate()  '定义一个线程委托
    Public AddDataDel As AddDataDelegate
    Private minValue, maxValue As DateTime

    Private Sub Form2_Load(sender As System.Object, e As System.EventArgs) Handles MyBase.Load
        '定义一个新的线程进行循环执行
        Dim addDataThreadStart As New ThreadStart(AddressOf AddDataThreadLoop)
        '把线程交给公共线程来管理
        AddDataRunner = New Thread(addDataThreadStart)
        '委托交付管理
        addDataDel = New AddDataDelegate(AddressOf AddData)

    End Sub
   
    ''' <summary>
    ''' 主线程每秒循环一次,并通过委托,将数据发给你 CHART
    ''' </summary>
    ''' <remarks></remarks>
    Private Sub AddDataThreadLoop()
        While True
            chart1.Invoke(addDataDel)

            Thread.Sleep(1000)
        End While
    End Sub 'AddDataThreadLoop

    Public Sub AddData()
        Dim timeStamp As DateTime = DateTime.Now

        Dim ptA As ChartArea
        For Each ptA In Chart1.ChartAreas
            Dim ptSeries As Series
            '对每series进行数据扫描
            For Each ptSeries In Chart1.Series
                Dim k As Single
                k = Rand.Next(10, 50)
                AddNewPoint(timeStamp, k, ptSeries)
            Next ptSeries
        Next
    End Sub 'AddData

  
    ''' <summary>
    ''' x轴为时间,y轴为数据,并根据随机数据进行填写;
    ''' </summary>
    ''' <param name="timeStamp"></param>
    ''' <param name="ptSeries"></param>
    ''' <remarks></remarks>
    Public Sub AddNewPoint(timeStamp As DateTime, ByVal pValue As Single, ptSeries As System.Windows.Forms.DataVisualization.Charting.Series)
        Dim newVal As Double = 0

        If ptSeries.Points.Count > 0 Then
            newVal = ptSeries.Points((ptSeries.Points.Count - 1)).YValues(0) + (Rand.NextDouble() * 2 - 1)
        End If

        If newVal < 0 Then
            newVal = 0
        End If

        ' Add new data point to its series.
        ptSeries.Points.AddXY(timeStamp.ToOADate, pValue)

        ' remove all points from the source series older than 1.5 minutes.
        Dim removeBefore As Double = timeStamp.AddSeconds((CDbl(90) * -1)).ToOADate()
        'remove oldest values to maintain a constant number of data points
        While ptSeries.Points(0).XValue < removeBefore
            ptSeries.Points.RemoveAt(0)
        End While

        Dim ptA As ChartArea
        For Each ptA In Chart1.ChartAreas
            ptA.AxisX.Minimum = ptSeries.Points(0).XValue
            ptA.AxisX.Maximum = DateTime.FromOADate(ptSeries.Points(0).XValue).AddMinutes(2).ToOADate()
        Next
      
        Chart1.Invalidate()
    End Sub

    ' Clean up any resources being used.
    Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)
        If (addDataRunner.ThreadState And ThreadState.Suspended) = ThreadState.Suspended Then
            addDataRunner.Resume()
        End If
        addDataRunner.Abort()

        If disposing Then
            If Not (components Is Nothing) Then
                components.Dispose()
            End If
        End If
        MyBase.Dispose(disposing)
    End Sub 'Dispose

  

    Private Sub startTrending_Click(sender As System.Object, e As System.EventArgs) Handles startTrending.Click
        ' 开始按钮状态
        startTrending.Enabled = False
        ' 停止按钮状态
        stopTrending.Enabled = True

        ' Predefine the viewing area of the chart
        minValue = DateTime.Now
        '2分钟预览区域
        maxValue = minValue.AddSeconds(120)

        Chart1.ChartAreas(0).AxisX.Minimum = minValue.ToOADate()
        Chart1.ChartAreas(0).AxisX.Maximum = maxValue.ToOADate()

        Chart1.ChartAreas(1).AxisX.Minimum = minValue.ToOADate()
        Chart1.ChartAreas(1).AxisX.Maximum = maxValue.ToOADate()

        ' Reset number of series in the chart.
        Chart1.Series.Clear()

        ' create a line chart series
        Dim newSeries1 As New Series("Series1")
        With newSeries1
            .LegendText = "曲线一"
            .ChartType = SeriesChartType.Line
            .BorderWidth = 1
            .Color = Color.Red
            .XValueType = ChartValueType.Time
        End With
        newSeries1.ChartArea = "ChartArea1"

        Dim newSeries2 As New Series("Series2")
        With newSeries2
            .LegendText = "曲线二"
            .ChartType = SeriesChartType.Line
            .BorderWidth = 1
            .Color = Color.Blue
            .XValueType = ChartValueType.Time
        End With
        newSeries2.ChartArea = "ChartArea2"

        Chart1.Series.Add(newSeries1)
        Chart1.Series.Add(newSeries2)

        ' start worker threads.
        If addDataRunner.IsAlive = True Then
            addDataRunner.Resume()
        Else
            addDataRunner.Start()
        End If
    End Sub

    Private Sub stopTrending_Click_1(sender As System.Object, e As System.EventArgs) Handles stopTrending.Click
        If addDataRunner.IsAlive = True Then
            addDataRunner.Resume()
        End If

        ' Enable all controls on the form
        startTrending.Enabled = True
        ' and only Disable the Stop button
        stopTrending.Enabled = False
    End Sub


 

  • 7
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值