最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

VB MSCOMM

来源:动视网 责编:小OO 时间:2025-09-27 00:02:55
文档

VB MSCOMM

VB是VisualBasic的简称,是由美国微软公司于1991年开发的一种可视化的、面向对象和采用事件驱动方式级程序设计语言,可用于开发Windows环境下的各类应用程序。它简单易学、效率高,且功能强大可以与Windows专业开发工具SDK相媲美。在VisualBasic环境下,利用事件驱动的编程机制、新颖易用的可视化设计工具,使用Windows内部的广泛应用程序接口(API)函数,动态链接库(DLL)、对象的链接与嵌入(OLE)、开放式数据连接(ODBC)等技术,可以高效、快速地开发环境下功
推荐度:
导读VB是VisualBasic的简称,是由美国微软公司于1991年开发的一种可视化的、面向对象和采用事件驱动方式级程序设计语言,可用于开发Windows环境下的各类应用程序。它简单易学、效率高,且功能强大可以与Windows专业开发工具SDK相媲美。在VisualBasic环境下,利用事件驱动的编程机制、新颖易用的可视化设计工具,使用Windows内部的广泛应用程序接口(API)函数,动态链接库(DLL)、对象的链接与嵌入(OLE)、开放式数据连接(ODBC)等技术,可以高效、快速地开发环境下功
VB是Visual Basic的简称,是由美国微软公司于1991年开发的一种可视化的、面向对象和采用事件驱动方式级程序设计语言,可用于开发 Windows 环境下的各类应用程序。它简单易学、效率高,且功能强大可以与 Windows 专业开发工具SDK相媲美。在Visual Basic环境下,利用事件驱动的编程机制、新颖易用的可视化设计工具,使用Windows内部的广泛应用程序接口(API)函数,动态链接库(DLL)、对象的链接与嵌入(OLE)、开放式数据连接(ODBC)等技术,可以高效、快速地开发环境下功能强大、图形界面丰富的应用软件系统。

他的简单易学可以使我们快速实现自己想在Windows下的软件功能。小则可以做计算器、上位机等符合自己需要的小软件;大则可以连接数据库做些管理系统,比如某公司的人事管理系统。

这里要说的是MSCOMM控件在VB中的使用方法。MSComm 作为一个串行通讯控件为程序员串口通讯编程节省了很多时间。在应用中加入一个MSComm控件非常简单。在VB的常用控件里是没有MSCOMM控件的,我们可以通过 工程 部件 勾取 Microsoft comm control 6.0 来添加MSCOMM控件。下面,让我们来了解其使用方法:

1.串口通信基础知识

    一般悦来,计算机都有一个或多个串行端口,它们依次为com1、Com2、…,这些串口还提供了外部设备与PC进行数据传输和通信的通道。这些串口在CPU和外设之间充当解释器的角色。当字符数据从CPU发送给外设时,这些字符数据将被转换成串行比特流数据;当接收数据时,比特流数据被转换为字符数据传递给CPU,再进一步说,在操作系统方面,Windows用通信驱动程序(COMM.DRV)调用API函数发送和接收数据,当用通信控件或声明调用API函数时,它门由COMM. DRV解释并传递给设备驱动程序,作为一个VB程序员,要编写通信程序.只需知道通信控件提供给Windows通信AP1函数的接口即可.换句话说,只需设定和监视通信控件的属性和事件即可。

2.使用Mscomm控件

在开始使用MSComm控件之前。需要先了解其属性、事件或错误

属性            描述

CommPort      设置或返回通信端口号

Settings         以字符串的形式设置或返回波特率、奇偶校验、数据位和停止位

PortOpen       设置或返回通信端口的状态。也可以打开和关闭端口

Input          返回和删除接收缓冲区中的字符

Output         将字符串写入发送缓冲区 

CommEvent属性为通信事件或错误返回下列值之一。在该控件的对象库中也可以找到这些常量。

常量           值        描述

ComEventBreak   1001    收到了断开信号

ComEventCTSTO   1002    Clear To Send Timeout。在发送字符时,在系统指定的事1件                              内,CTS(Clear To Send)线是低电平

ComEventDSRTO   1003    Data Set Ready Timeout。在发送字符时,在系统指定的事件内,DSR(Data Set Ready)线是低电平

ComEventFrame   1004    数据帧错误。硬件检测到一个数据帧错误

ComEventOverrun 1006    端口溢出。硬件中的字符尚未读,下一个字符又到达,并且丢失

ComEventCDTO    1007    Carrier Detect Time。在发送字符时,在系统指定的事件内,CD(Carrier Detect)线是低电平。CD

                        也称为RLSD(Receive Line Singal Detect,接收线信号检测)

ComEventRxOver  1008    接收缓冲区溢出。在接收缓冲区中没有空间

ComEventRxParity 1009   奇偶校验错。硬件检测到奇偶校验错误7

ComEventTxFull  1010    发送缓冲区满。在对发送字符排队时,发送缓冲区满

ComEventDCB     1011    检取端口DCB(Device Control Blick)时发生了没有预料到的错误

通信事件包含了下面的设置:

常量         值        描述

ComEvSend      1    发送缓冲区中的字符数比Sthreshold值低

ComEvReceive   2    接收到了Rthreshold个字符。持续产生该事件,直到使用了Input属性删除了接收缓冲区中的数据

ComEvCTS       3    CTS(Clear To Send)线改变

ComEvDSR       4    DSR(Data Set Ready)线改变。当DSR从1到0改变时,该事件发生

ComEvCD        5    CD(Carrier Detect)线改变ComEvRing6检测到响铃信号。一些URAT(Universal AsynchronousReciver-

                    -Transmitters,通用异步收发器)不支持该事件

ComEvEOF       7    收到了EOF字符(ASCII字符26)

Error消息(MSComm控件)下表列出了MSComm控件可捕获的错误消息:

常量                       值      描述

ComInvalidPropertyvalue    380   无效的属性值

ComSetNotSupported         383   属性只读

ComGetNotSupported         394   属性只读

ComPortOpen               8000   端口打开时该存在无效

                          8001   超时设置必须比0值大

ComPortInvalid            8002   无效的端口号

                          8003   属性只在运行时有效

                          8004   属性在运行时是只读的

ComPortAleadyOpen         8005   端口已经打开

                          8006   设备标识符无效或不支持

                          8007   不支持设备的波特率

                          8008   指定的字节大小无效

                          8009   缺省参数错误

                          8010   硬件不可用(被其他设备锁住)

                          8011   函数不能分配队列

ComNoOpen                 8012   设备没有打开

                          8013   设备已经打开

                          8014   不能使用通信通知

ComSetCommStateFailed     8015   不能设置通信状态

                          8016   不能设置通信事件屏蔽

ComPortNotOpen            8018   该存在只在端口打开是有效

                          8019   设备忙

ComReadError              8020   通信设备读错误

ComDCBError               8021   检取端口设备控制块时出现内部错误

3.一些实际例子

(1)利用Visual Basic实现PC机与PC机串口通信(简单的PC串口双机聊天程序)

'串口初始化

Private Sub Form_Load()

  MSComm1.CommPort = 1                 '设置通信端口号为COM1

  MSComm1.Settings = "9600,n,8,1"      '设置串口参数

  MSComm1.InputMode = 0                '接收文本型数据

  MSComm1.PortOpen = True              '打开通信端口1

End Sub

'把字符通过串口发送出去

'启动定时器

Private Sub Cmdsend_Click()

  MSComm1.Output = Trim(Textsend.Text)

End Sub

'接收字符

Private Sub Timer1_Timer()

  Dim buf$

  buf = Trim(MSComm1.Input)           '将缓冲区内的数据读入buf变量中

If Len(buf) <> 0 Then '判断缓冲区内是否存在数据

    TextReceive.Text = TextReceive.Text + Chr(13) + Chr(10) + buf

  End If

End Sub

'停止程序运行

Private Sub Cmdquit_Click()

  Unload Me

End Sub

'关闭通信端口,

Private Sub Form_Unload(Cancel As Integer)

  MSComm1.PortOpen = False

End Sub

(二)利用Visual Basic实现PC机与单片机串口通信任务1(检查通讯是否正常)

'将数字(0,1,2,3...255,转换为16进制)传给单片机,单片机收到后回传这个数字,PC机接收到回传数据后显示出来,

'若发送和接收的数据相同,显示通信正常,否则通信不正常

'发送以00开始,以FF结束

'定义变量

Dim data, data1 As Variant '串口初始化

'在窗体的Load事件中加入下列代码对串口进行初始化:

Private Sub Form_Load()

  MSComm1.CommPort = 1

  MSComm1.InputMode = 1

  MSComm1.RThreshold = 1

  MSComm1.SThreshold = 1

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

  MSComm1.PortOpen = True

  numText.Text = "00"

End Sub

Private Sub numText_Change()

numText.Text = UCase(numText.Text)

End Sub

'单击清空文本框

Private Sub numText_Click()

  numText.Text = ""

  Cmdsend.Enabled = True

End Sub

'向单片机发送数据

Private Sub Cmdsend_Click()

   c = numText.Text

   If (c = "FF") Then

      data1 = "&H" & c

      data = Chr(data1)

      

   Else

   a = Left(c, 1) '截取numText左边字符

   b = Right(c, 1) '截取numText右边字符

   data1 = "&H" & numText.Text   'data1没有将numText中的字符拆开

   data = Chr("&H" & a) & Chr("&H" & b) '将numText中的字符拆开存入data中,这样就会解决例如A1接收不正确的问题

   End If

   MSComm1.Output = data

   Cmdsend.Enabled = False

End Sub

'获取温度测量值并显示

'每发送一次指令,触发下面事件,返回数据串

Private Sub MSComm1_OnComm()

  Dim Inbyte() As Byte

  Dim buffer As Variant

  '读取仪表返回数据串

  Select Case MSComm1.CommEvent

    Case comEvReceive

      Inbyte = MSComm1.Input

      For i = LBound(Inbyte) To UBound(Inbyte)

         buffer = buffer + Hex(Inbyte(i))

      Next i

    Case comEvSend

  End Select

  If Len(Trim(buffer)) = 1 Then

    numText.Text = Str("0") & buffer

  Else

    numText.Text = buffer

  End If

  If "&H" & buffer = data1 Then

    Label1.ForeColor = QBColor(13)

    Label1.Caption = "通信正常!"

  End If

If "&H" & buffer <> data1 Then

    Label1.ForeColor = QBColor(12)

    Label1.Caption = "通信不正常!"

    numText.Text = "未接收到数据"

  End If

  If Trim(buffer) = "FF" Then

    Label1.ForeColor = QBColor(12)

    Label1.Caption = "输入00重新开始!"

  End If

End Sub

'当退出程序时,关闭串行口

Private Sub Cmdquit_Click()

  Unload Me

End Sub

Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)

  MSComm1.PortOpen = False           '关闭串口

End Sub

Private Sub numText_KeyPress(KeyAscii As Integer)

If (KeyAscii >= Asc("a") And KeyAscii <= Asc("f")) Then

    KeyAscii = KeyAscii - 32

 End If

 

 

End Sub

(3)利用Visual Basic实现PC机与单片机串口通信任务2(方法1)

测试通信状态,循环基数,控制指示灯

'定义变量

Dim cnum As Integer              '循环计数标志

Dim choosenum As Integer         '选择指示灯号

'串口初始化

'在窗体的Load事件中加入下列代码对串口进行初始化:

Private Sub Form_Load()

  MSComm1.CommPort = 1

  MSComm1.InputMode = 1

  MSComm1.RThreshold = 1

  MSComm1.SThreshold = 1

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

  MSComm1.PortOpen = True

  choosenum = 1

End Sub

'以下为测试单片机的程序

'发送字符串“Hello”

'05 57 01 03 00 48 04 1C    发送'H' ASCII码"48"

'05 57 01 04 00 65 04 36    发送'e' ASCII码"65"

'05 57 01 05 00 6c 04 3e    发送'l' ASCII码"6c"

'05 57 01 06 00 6c 04 3d    发送'l' ASCII码"6c"

'05 57 01 07 00 6f 04 3f    发送'o' ASCII码"6f"

'05 52 01 03 00 01 04 50    读取地址03H中的值

Private Sub CmdTest_Click()

  MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H3) & Chr(&H0) & Chr(&H48) & Chr(&H4) & Chr(&H1C)

  Call delay

  MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H4) & Chr(&H0) & Chr(&H65) & Chr(&H4) & Chr(&H36)

  Call delay

  MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H5) & Chr(&H0) & Chr(&H6C) & Chr(&H4) & Chr(&H3E)

  Call delay

  MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H6) & Chr(&H0) & Chr(&H6C) & Chr(&H4) & Chr(&H3D)

  Call delay

  MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H7) & Chr(&H0) & Chr(&H6F) & Chr(&H4) & Chr(&H3F)

  Call delay

  MSComm1.Output = Chr(&H5) & Chr(&H52) & Chr(&H1) & Chr(&H3) & Chr(&H0) & Chr(&H1) & Chr(&H4) & Chr(&H50)

End Sub

Sub delay()

  For i = 0 To 2000000

    n = n + 1

  Next i

End Sub

'判断发送字符串是否正确

'返回 06 01 00 4F 03 4B  返回 'O'(4F) 代表'OK'正确

'返回 06 01 00 45 03 41  返回 'E'(45) 代表'ERROR'错误

'每发送一次指令,触发下面事件,返回字符串

Private Sub MSComm1_OnComm()

  Dim Inbyte() As Byte

  Dim buffer As String

  Select Case MSComm1.CommEvent

    Case comEvReceive

      Inbyte = MSComm1.Input

      For i = LBound(Inbyte) To UBound(Inbyte)

        buffer = buffer + Hex(Inbyte(i)) + Chr(32)

      Next i

    Case comEvSend

  End Select

  If Mid(buffer, 7, 2) = "4F" Then

    ReturnText.Text = "OK!"

    Frame2.Enabled = True

    Frame3.Enabled = True

  End If

  If Mid(buffer, 7, 2) = "45" Then ReturnText.Text = "ERROR!"

End Sub

'以下为循环计数的程序

'开始计数

Private Sub CmdStart_Click()

  Timer1.Enabled = True

End Sub

'停止计数

Private Sub CmdStop_Click()

  Timer1.Enabled = False

End Sub

'05 57 01 00 00 00 04 57  数码管显示00

'05 57 01 00 00 01 04 56  数码管显示01

'05 57 01 00 00 02 04 55  数码管显示02

'05 57 01 00 00 03 04 54  数码管显示03

'05 57 01 00 00 04 04 53  数码管显示04

'05 57 01 00 00 05 04 52  数码管显示05

'05 57 01 00 00 06 04 51  数码管显示06

'05 57 01 00 00 07 04 50  数码管显示07

'05 57 01 00 00 08 04 5F  数码管显示08

'05 57 01 00 00 09 04 5E  数码管显示09

'05 57 01 00 00 0A 04 5D  数码管显示10

Private Sub Timer1_Timer()

  Dim data1, data2 As Variant

  cnum = cnum + 1

If cnum > 10 Then

    cnum = 0

  End If

  NumText.Text = cnum

  data1 = "&H" & Hex(cnum)

  data2 = "&H" & Hex(&H5 Xor &H57 Xor &H1 Xor &H0 Xor &H0 Xor data1 Xor &H4)

  MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H0) & Chr(&H0) & Chr(data1) & Chr(&H4) & Chr(data2)

End Sub

'以下为控制指示灯的程序

 '选择1号指示灯

Private Sub Option1_Click()

  choosenum = 1

End Sub

 '选择2号指示灯

Private Sub Option2_Click()

  choosenum = 2

End Sub

'打开指定的指示灯

'发送下面指令

'05 57 01 02 00 01 04 54  1号灯亮 蜂鸣器响

'05 57 01 01 00 01 04 57  2号灯亮 蜂鸣器响

Private Sub CmdOpen_Click()

  If choosenum = 1 Then

    MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H2) & Chr(&H0) & Chr(&H1) & Chr(&H4) & Chr(&H54)

  End If

  If choosenum = 2 Then

    MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H1) & Chr(&H0) & Chr(&H1) & Chr(&H4) & Chr(&H57)

  End If

End Sub

'关闭指定的指示灯

'发送下面指令

'05 57 01 02 00 00 04 55  1号灯灭 蜂鸣器停止响

'05 57 01 01 00 00 04 56  2号灯灭 蜂鸣器停止响

Private Sub CmdClose_Click()

  If choosenum = 1 Then

    MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H2) & Chr(&H0) & Chr(&H0) & Chr(&H4) & Chr(&H55)

  End If

  If choosenum = 2 Then

    MSComm1.Output = Chr(&H5) & Chr(&H57) & Chr(&H1) & Chr(&H1) & Chr(&H0) & Chr(&H0) & Chr(&H4) & Chr(&H56)

  End If

End Sub

'当退出程序时,关闭串行口

Private Sub Cmdquit_Click()

  Unload Me

End Sub

Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)

  MSComm1.PortOpen = False           '关闭串口

End Sub

(4)利用VB实现PC机与单片机串口通信任务2(方法2)

'定义变量

Dim choise As Integer                 '选择指示灯号

'串口初始化

Private Sub Form_Load()

  MSComm1.CommPort = 1                 '设置通信端口号为COM1

  MSComm1.Settings = "4800,n,8,1"      '设置串口通信参数

  MSComm1.InputMode = 0                '接收文本型数据

  MSComm1.PortOpen = True              '打开通信端口1

  Frame2.Enabled = False

  Frame3.Enabled = False

  choise = 1

End Sub

'把字符"H"通过串口发送出去

'如果通信正常,单片机返回字符串"OK"

Private Sub CmdTest_Click()

  Dim buffer As String

  MSComm1.Output = Trim(TestText.Text)

  Call delay

  buffer = MSComm1.Input

  If buffer = "OK" Then

    TestText.Text = "OK!"

    CmdTest.Enabled = False

    Frame2.Enabled = True

    Frame3.Enabled = True

  Else

    TestText.Text = "ERROR!"

    CmdTest.Enabled = False

  End If

End Sub

'延时

Sub delay()

  For i = 0 To 2000000

    n = n + 1

  Next i

End Sub

'开始计数

Private Sub CmdStart_Click()

  MSComm1.Output = "R"

End Sub

'停止计数

Private Sub CmdStop_Click()

  MSComm1.Output = "S"

End Sub

'选择1号灯

Private Sub Option1_Click()

  choise = 1

End Sub

'选择2号灯

Private Sub Option2_Click()

  choise = 2

End Sub

'打开指示灯

Private Sub CmdOpen_Click()

  If choise = 1 Then

    MSComm1.Output = "A"

  Else

    MSComm1.Output = "C"

  End If

End Sub

'关闭指示灯

Private Sub CmdClose_Click()

  If choise = 1 Then

    MSComm1.Output = "B"

  Else

    MSComm1.Output = "D"

  End If

End Sub

'停止程序运行

Private Sub Cmdquit_Click()

  Unload Me

End Sub

'关闭通信端口,

Private Sub Form_Unload(Cancel As Integer)

  MSComm1.PortOpen = False

End Sub

这个是传说中一个字符也不会丢的接受程序段 也贴上给参考

Private Sub MSComm_OnComm()

    Dim S() As Byte

    Dim SS(1024) As Byte

    Static N As Long

    Static T As Variant

    If (MSComm.CommEvent = comEvReceive) Then

        S = MSComm.Input                      '只要有数据就收进来,哪怕只是一个

If (Timer - T > 0.01) Then '间隔10MS以上就认为是一个新的包

            text1=""                          'text1用于搜集和显示接收(HEX格式)

            N = 0

        End If

        T = Timer

        For i = 0 To UBound(S)               '一个数据包可能产生若干个oncomm事件

            Text1.Text = Text1.Text & Right("0" & Hex(S(i)) & "H", 3) + " "

            SS(N+i)=S(i)                     '接收数据包缓存于SS()

            N=N+UBound(S)

        Next i

    End If

End Sub

文档

VB MSCOMM

VB是VisualBasic的简称,是由美国微软公司于1991年开发的一种可视化的、面向对象和采用事件驱动方式级程序设计语言,可用于开发Windows环境下的各类应用程序。它简单易学、效率高,且功能强大可以与Windows专业开发工具SDK相媲美。在VisualBasic环境下,利用事件驱动的编程机制、新颖易用的可视化设计工具,使用Windows内部的广泛应用程序接口(API)函数,动态链接库(DLL)、对象的链接与嵌入(OLE)、开放式数据连接(ODBC)等技术,可以高效、快速地开发环境下功
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top