vb程序编写模拟串口

vb程序编写模拟串口,第1张

这是典型的VB串口通信

你可以采用Mscomm控件实现串口通信时,首先添加一Mscomm控件到窗体中,通过菜单项“工程(P)→部件(O)”进入选择窗口,在控件页中选取“Microsoft Comm Control 6.0” ,此时工具窗口中出现Mscomm图标,即可被使用。

需要注意的几点是:

1.用mscomm控件进行通信,其波特率最高只能设为115200

2.利用MSCOMM控件可以发送和接收任何文件的类型。

3.接收文本文件和二进制文件有一定的区别,接收二进制文件时用scomm1.Input读入的变量需用Variant类型的变量,而文本文件可以用字符型变量,另外InputMode属性应设置相应的文本方式或二进制方式

4.接收文本无大小限制。

5.当连续存数据时记录号是自动加的,但当文件关闭后再次打开时,默认的记录号为1,存储文件不完整的原因可能在此。接收到文件头识别字符时打开文件,接收中途不要关闭文件,直到接收到文件结束符(Mscomm1.EOFEnable事件发生)才能关闭文件。

我手头有一个完整的VB串口通信源码,对你的问题很有帮助

若你需要,发邮件至donook@qq.com

我会尽快发给你

如果满意,加点分哦,资料都来之不易的呵呵

以前做工程用的,你修改一下,可能对你有用,你看看吧

'======================串口初始化=======================

Private Sub Comm_initial(Port As Byte, BaudRate As String, ParityBit As String, DataBit As Integer, StopBit As Integer)

On Error GoTo ErrorTrap

If MSComm1.PortOpen = True Then MSComm1.PortOpen = False                          ' 串口若已打开,则先关闭

MSComm1.CommPort = Port                                                          ' 设置端口号

MSComm1.Settings = BaudRate & "," & ParityBit & "," & DataBit & "," & StopBit    ' 设置波特率、校验位、数据位、停止位

MSComm1.InBufferSize = 1024                                                      ' 设置接收缓冲区为1024字节

MSComm1.OutBufferSize = 4096                                                     ' 设置发送缓冲区为4096字节

MSComm1.InBufferCount = 0                                                        ' 清空输入缓冲区

MSComm1.OutBufferCount = 0                                                       ' 清空输出缓冲区

MSComm1.SThreshold = 1                                                           ' 发送缓冲区被清空时,触发OnComm事件

MSComm1.RThreshold = 1                                                           ' 接收缓冲区每接收到一字节数据时,触发OnComm事件

MSComm1.PortOpen = True                                                          '打开串口

If MSComm1.PortOpen = True Then

txtstatus.Text = "STATUS:" & cboport.Text & " OPEND," & cbobps.Text & "," & Left(CboParity.Text, 1) & "," & Cbobit.Text & "," & cbostop.Text

Else

txtstatus.Text = "STATUS:COM Port Cloced"

End If

Exit Sub

ErrorTrap:

Select Case Err.Number

Case comPortAlreadyOpen

MsgBox "串口冲突,请更改串口号", 48, "公司车辆管理系统"

CloseCom

Case Else

MsgBox "没有发现此串口,请确认连接", 48, "公司车辆管理系统"

CloseCom

End Select

Err.Clear

End Sub

Private Sub cmdclose_Click()

Call CloseCom

End Sub

Private Sub cmdset_Click()

Call Comm_initial(Val(Mid(cboport.Text, 4, 1)), cbobps.Text, Left(CboParity.Text, 1), Val(Cbobit.Text), Val(cbostop.Text))

End Sub

Private Sub Form_Load()

Call Comm_initial(Val(Mid(cboport.Text, 4, 1)), cbobps.Text, Left(CboParity.Text, 1), Val(Cbobit.Text), Val(cbostop.Text))  '串口初始化

MSComm1.InputMode = comInputModeText '通过文本方式读取数据

End Sub

'=========================数据接收子程序=========================

Private Sub dataReceive()

Dim strByte() As String             '数据分割用数组

Dim receiveData As String           ' 接收数据暂存

Dim i As Integer

If (MSComm1.InBufferCount > 0) Then

receiveData = ""                 ' 清接收数据暂存

receiveData = MSComm1.Input     '接收数据

'txtreceive.Text = txtreceive & receiveData

'===============数据在相应文本框里显示=======

strByte = Split(receiveData)

For i = 0 To UBound(strByte)

txt1(i).Text = strByte(i)

Next i

txt1(8).Text = Now

End If

End Sub

'====================OnComm事件===========================

Private Sub MSComm1_OnComm()

Select Case MSComm1.CommEvent              ' 设置oncomm事件,读取片机内存的值

Case comEvReceive

Call dataReceive

Case Else

End Select

End Sub

'====================关闭串口子程序=====================

Private Sub CloseCom()

On Error GoTo Err

If MSComm1.PortOpen = True Then MSComm1.PortOpen = False                          ' 串口若已打开,则关闭

txtstatus.Text = "STATUS:COM Port Cloced"

Err:

End Sub

我也是自己摸索开发出来的每一款VBtoCOM通讯,有具体的思路如下:

给你推荐一个工具“com串口测试工具 ComTone V1.0 中文绿色版”

1、打开你的噪音计的测试软件,调整好串口号、通讯频率等等,我用温度计举例说明。

开始查询后有返回数值,这个Receive:就是返回的数值000304012200004b05,

打开串口监视精灵,监视软件的com口事件:

这里面的Write是测试软件发出的查询指令,read是设备返回的数据指令

Private Sub Command1_Click() '发送指令

If Not MSComm1.PortOpen Then

  MSComm1.CommPort = 7 '串口为7

  MSComm1.Settings = "9600,n,8,1"

  MSComm1.InBufferCount = 0 '清除接收缓冲区

  MSComm1.OutBufferCount = 0 '清除发送缓冲区

  MSComm1.InputMode = comInputModeBinary '二进制接收

  MSComm1.InputLen = 0 '读取接收缓冲区的所有字符

  MSComm1.PortOpen = True  '打开串口

  MSComm1.RTSEnable = False '置为发送状态

End If

Dim pu() As Byte

Dim strdata  As String

Dim crc_js() As Byte

ReDim pu(7)  '这个数组是8位的查询指令

pu(0) = "&H00" '温度计地址

pu(1) = "&H03" '查询指令

pu(2) = "&H00" '2、3为温度计地址

pu(3) = "&H00" '2、3为温度计地址

pu(4) = "&H00" '4、5为读取寄存器长度

pu(5) = "&H02" '4、5为读取寄存器长度

pu(6) = "&HC5" '6、7为CRC校验码 因为我们不知道设备的CRC校验规则所以用测试软件产生的校验码

pu(7) = "&HDA" '6、7为CRC校验码

MSComm1.Output = pu

'不做任何事情,仅仅允许其它应用程序处理它们的事件。

DoEvents

MSComm1.InBufferCount = 0 '清除接收缓冲区

MSComm1.RThreshold = 9 '所要接收的数据长度,我们通过COM检测精灵看到了回传数据一共是9字节

MSComm1.RTSEnable = True '转为接收状态

End Sub

Private Sub Command2_Click()

Timer1.Enabled = False

End Sub

Private Sub Form_Unload(Cancel As Integer)

    If MSComm1.PortOpen Then

        MSComm1.PortOpen = False  '关闭串口

    End If

    Timer1.Enabled = False

End Sub

Private Sub MSComm1_OnComm() 'COM事件

    Dim PA() As Byte

    Dim PB As String

Select Case MSComm1.CommEvent

 Case comEvReceive

            MSComm1.InputLen = 0 '读取接收缓冲区的所有字符

            PB = MSComm1.Input

            PA() = PB

            For i = 0 To UBound(PA())

                'Print "PA(" & i & ")" PA(i)

                If Len(Hex(PA(i))) = 1 Then

                    strdata = strdata & "0" & Hex(PA(i))

                Else

                    strdata = strdata & Hex(PA(i))

                End If

            Next

            '回传的数据串:000304012600000AC4,这9字节根据通讯协议我们进行拆分

            '00为协议内回传机号,03为读命令,04为返回的数据长度 0126 为我要的温度数据为十六进制表达,下面我进行数据处理

            wd = CLng("&H" & Left(Right(strdata, 12), 4)) / 10 & "℃"   '根据通讯协议换算成温度

            Text1 = Text1 & vbCrLf & strdata & "  " & wd

            strdata = ""

   MSComm1.PortOpen = False  '关闭串口

 End Select

End Sub

Private Sub Timer1_Timer()

Call Command1_Click

End Sub

这是我的测试结果。

下面是通讯协议

这个是我的软件用检测精灵检测的结果


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7780828.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-09
下一篇 2023-04-09

发表评论

登录后才能评论

评论列表(0条)

保存