请问各位,如果使用此种方法能否将串口中读取出的数据实时绘制出来(不丢数)?刚实习就遇上这么个难题,小弟表示压力很大、、、、、、、有老各位给小弟讲讲实现思路,或者给小弟发个demo,小弟邮箱[email protected]小弟在此谢过了
解决方案 »
- 求助 求源码 c#即时通讯源码,免费开源的,想学习下,非商用
- Windows Mobile里关于ComboBox的问题
- 如何制作启动画面
- 各位,谁有用过c# reportViewer1(c/s),有相关比较详细的例子发一个给我,小女子在此谢过!
- 如何在MDIFORM(主窗体)添加背景图片, 不影响子窗体的打开~
- c# 数据库的问题
- 为什么我用vs2003制作的安装程序的快捷方式,如果删除程序目录中的某个文件,再点击桌面上的快捷方式老是提示重新安装?怎么解决
- 多线程问题
- postmessage发送鼠标单击事件
- 微软专家帮忙:从数据库导入Excel时中文出现乱码?
- 如何让C#组合框下拉列表中的项按大小排序
- Gridview如何绑定datatable
bytes[] bb=port1.Read(bb,0,port1.BytesToRead);
也可以写死循环 过一段时间
string xxx=port1.ReadLine();
totalBuffer+=xxx;
string xxx=prot1.ReadExisting();等等
很多方法都可以读的 关键看你串口进来的数据是什么样子
读完以后 存起来 放在画面上 就哦了
---------------------------------------------------------------
可以用串口自带的DataReceived事件
bytes[] bb=port1.Read(bb,0,port1.BytesToRead);
也可以写死循环 过一段时间
string xxx=port1.ReadLine();
totalBuffer+=xxx;
string xxx=prot1.ReadExisting();等等
很多方法都可以读的 关键看你串口进来的数据是什么样子
读完以后 存起来 放在画面上 就哦了
Public gDataInDiamete(55) As Long '每次从串口读取的粒径通道的数据(52个粒径通道)
Public gChannelData(65) As Long '从串口读取的强度通道数据(64个强度通道)'CRC-16校验函数,参数待校验的数组,返回值 余数
Function CRC16(data() As Byte) As String
Dim CRC16Lo As Byte, CRC16Hi As Byte 'CRC寄存器
Dim CL As Byte, CH As Byte '多项式码 & H8001
Dim SaveHi As Byte, SaveLo As Byte
Dim i As Integer
Dim Flag As Integer
CRC16Lo = &HFF
CRC16Hi = &HFF
CL = &H1
CH = &H80
For i = 0 To UBound(data)
CRC16Lo = CRC16Lo Xor data(i) '每一个数据与CRC寄存器进行异或
For Flag = 0 To 7
SaveHi = CRC16Hi
SaveLo = CRC16Lo
CRC16Hi = CRC16Hi \ 2 '高位右移一位
CRC16Lo = CRC16Lo \ 2 '低位右移一位
If ((SaveHi And &H1) = &H1) Then '如果高位字节最后一位为1
CRC16Lo = CRC16Lo Or &H80 '则低位字节右移后前面补1
End If '否则自动补0
If ((SaveLo And &H1) = &H1) Then '如果LSB为1,则与多项式码进行异或
CRC16Hi = CRC16Hi Xor CH
CRC16Lo = CRC16Lo Xor CL
End If
Next Flag
Next i
Dim ReturnData(1) As Byte
ReturnData(0) = CRC16Hi 'CRC高位
ReturnData(1) = CRC16Lo 'CRC低位
CRC16 = ReturnData
End Function'处理串口数据
Private Sub MSComm1_OnComm()
'Dim rs_sChannelData(55) As Long
'Dim rs_sIntensityData(52, 64) As Long
'Dim rs_pIntensity(65) As Long
Dim vbReceive As Variant
Dim i, j As Integer
Dim L As Integer
Dim dSum As Long
Dim pm25t As Single
Dim pm10t As Single
pm25t = 0
pm10t = 0
If MSComm1.CommEvent = comEvReceive Then
'wait (50) 'Receive the rs232 chars
If MSComm1.InBufferCount >= 6764 Then
vbReceive = ((MSComm1.Input))
If ((vbReceive(0) = 255) And (vbReceive(1) = 1)) Then
' //接下来是52个粒径通道的生物粒子浓度
dSum = 0
gDataInDiamete(1) = -1
gDataInDiamete(2) = -1
gDataInDiamete(3) = -1
gDataInDiamete(4) = (vbReceive(2 + 2 * 52 * 64) * 256 + vbReceive(2 + 2 * 52 * 64 + 1)) ' + Int(800 * Rnd + 1)
dSum = dSum + gDataInDiamete(4)
For i = 1 To 51
gDataInDiamete(i + 4) = vbReceive(2 + 2 * 52 * 64 + 2 * i) * 256 + vbReceive(2 + 2 * 52 * 64 + 2 * i + 1) ' + Int(800 * Rnd + 1)
dSum = dSum + gDataInDiamete(i + 4)
Next i
For i = 0 To 22
pm25t = pm25t + gDataInDiamete(i + 4) * gDiameter(i + 4) * gDiameter(i + 4) * gDiameter(i + 4)
Next i
For i = 0 To 41
pm10t = pm10t + gDataInDiamete(i + 4) * gDiameter(i + 4) * gDiameter(i + 4) * gDiameter(i + 4)
Next i
pm25t = pm25t * 1.7 * 3.14159 * 0.00001 / 3
pm10t = pm10t * 1.7 * 3.14159 * 0.00001 / 3
pm25 = pm25 + pm25t
pm10 = pm10 + pm10t
count_t = count_t + 1
gSaveFileFlag = 0
If (count_t = 20) Then
pm25 = pm25 / count_t
pm10 = pm10 / count_t
pm25 = Format(pm25, "#.####")
pm10 = Format(pm10, "#.####")
If gAutoSave = 1 Then
'自动保存文件
If gSaveFileFlag >= gSaveFileCycle Or gSaveFileFlag = 0 Then
'周期到
AutoSaveFile
gSaveFileFlag = 1
' End Select
End If
End If
count_t = 0
pm25 = 0
pm10 = 0
End If
' //接下来是64个强度通道的生物粒子荧光强度
sSum = 0
'For i = 0 To 51
' For j = 0 To 63
' rs_sIntensityData(i + 1, j + 1) = 0
' rs_sIntensityData(i + 1, j + 1) = vbReceive(2 + 2 * i * 64 + 2 * j) * 256 + vbReceive(2 + 2 * i * 64 + 2 * j + 1)
' Next j
' Next i
For j = 0 To 65
gChannelData(j) = 0
'For i = 0 To 52
' rs_pIntensity(j) = 0
' rs_pIntensity(j) + rs_sIntensityData(i, j)
'Next i
sSum = 0 'sSum + rs_pIntensity(j)
Next j
TransitSign = True
Else
runstop
Call Stopd_Click
wait (1000)
Call Start_Click
End If
'这里可以不作拷贝,在上面直接用gDataInDiamete,这样可以节省oncomm的运行时间
'CopyData gDataInDiamete, rs_sChannelData
'CopyData gChannelData, rs_pIntensity
'可能这个地方比较费时
ShowDiameterData False
'ShowChannelData False
ShowDpsAndFrq Picture5, dSum \ 3, sSum \ 3
'以上是绘图的部分,可能会比较费时
Text5.Text = str(dSum \ 3)
Text6.Text = Format(pm25t, "#.####")
Text1.Text = Format(pm10t, "#.####")
MSComm1.InBufferCount = 0 '...清空输入寄存器
timer4public = 1
End If
End If
End Sub