用VB6.0數字示波單片機實(shí)時(shí)監測數據的一種方法
三.軟件設計思想(一個(gè)具體的例)
要求:單片機每1秒串行發(fā)送給PC一幀十位數據,VB6.0波形動(dòng)態(tài)顯示數據。
設計:通過(guò)窗體Load事件程序完成如圖3所示界面設計,使得程序一運行即出現該界面,單擊接收數據按鈕,通過(guò)MsComm控件接收串行通信數據并波形動(dòng)態(tài)顯示。顯示時(shí)一屏12個(gè)數據,每次接收了新數據后,數組中的數據依次后移,既a(0)(假設為數組a(11))放最新接收的數據,原a(11)中的數據被移出而移入原a(10)中的數。每次有新數據移入并且有原數據移出時(shí),先清屏再復原背景顯示數據,造成數據平移視覺(jué)效果。
設計時(shí)波形一定要從界面最左端入,從最右端出,這樣動(dòng)態(tài)平移視覺(jué)效果才好。窗體的AutoRedraw屬性要設為T(mén)rue.
四.軟件設計源程序(波形參見(jiàn)圖4、圖5)
'定義所用變量
Dim a(11) As Single
Dim d As Integer
Dim n As Integer
Dim m As Integer
Dim Buffer As Variant
Private Sub Form_Load()
'一屏顯示的12個(gè)數賦初值0
For i = 0 To 11
a(i) = 0
Next i
'定義坐標原點(diǎn)
Form1.Scale (-10, 250)-(220, -15)
'畫(huà)X、Y軸
Line (0, 0)-(220, 0)
Line (0, 0)-(0, 250)
'加坐標刻度和數值
CurrentX = 200: CurrentY = 13: Print X(s)
CurrentX = 5: CurrentY = 245: Print Y(V)
For i = 0 To 220 Step 20
CurrentX = i: CurrentY = 3: Line -(i, 0)
If i = 200 Then CurrentX = i - 7 Else CurrentX = i - 12
CurrentY = 0: Print i Mod 19
Next i
For i = 0 To 210 Step 20
If i > 0 Then
CurrentX = -14: CurrentY = i: Print i / 10
CurrentX = 230: CurrentY = i: Line -(0, i)
End If
Next i
'mscomm控件初始化
MSComm1.CommPort = 1
MSComm1.Settings = 9600,n,8,1
MSComm1.InputMode = comInputModeBinary
MSComm1.InputLen = 0
MSComm1.RThreshold = 0
End Sub
'接收并顯示數據
Private Sub Command1_Click()
'無(wú)條件循環(huán)接收數據
Do
單片機相關(guān)文章:單片機教程
單片機相關(guān)文章:單片機視頻教程
單片機相關(guān)文章:單片機工作原理
評論