• mscomm控件使用详解 转


    目  次
    MSComm控件两种处理通讯的方式
    CommPort属性
    RThreshold 属性
    CTSHolding 属性
    SThreshold 属性
    CDHolding 属性
    DSRHolding 属性
    Settings 属性
    InputLen 属性
    EOFEnable 属性


         MSComm 控件通过串行端口传输和接收数据,为应用程序提供串行通讯功能。MSComm控件在串口编程时非常方便,程序员不必去花时间去
         了解较为复杂的API函数,而且在VC、VB、Delphi等语言中均可使用。 Microsoft Communications Control(以下简称MSComm)是
         Microsoft公司提供的简化Windows下串行通信编程的ActiveX控件,它为应用程序提供了通过串行接口收发数据的简便方法。
         具体的来说,它提供了两种处理通信问题的方法:一是事件驱动(Event-driven)方法,一是查询法。

    MSComm控件提供下列两种处理通讯的方式:事件驱动方式和查询方式。 
    1.1 事件驱动方式

    事件驱动通讯是处理串行端口交互作用的一种非常有效的方法。在许多情况下,在事件发生时需要得到通知,例如,在串口接收缓冲区中有字
    符,或者 Carrier Detect (CD) 或 Request To Send (RTS) 线上一个字符到达或一个变化发生时。在这些情况下,可以利用 MSComm 控件的
     OnComm 事件捕获并处理这些通讯事件。OnComm 事件还可以检查和处理通讯错误。所有通讯事件和通讯错误的列表,参阅 CommEvent 属性。
    在编程过程中,就可以在OnComm事件处理函数中加入自己的处理代码。这种方法的优点是程序响应及时,可靠性高。每个MSComm 控件对应着一
    个串行端口。如果应用程序需要访问多个串行端口,必须使用多个 MSComm 控件。

    查询方式实质上还是事件驱动,但在有些情况下,这种方式显得更为便捷。在程序的每个关键功能之后,可以通过检查 CommEvent 属性的值来
    查询事件和错误。如果应用程序较小,并且是自保持的,这种方法可能是更可取的。例如,如果写一个简单的电话拨号程序,则没有必要对每
    接收一个字符都产生事件,因为唯一等待接收的字符是调制解调器的“确定”响应。

    2.MSComm 控件的常用属性
    MSComm 控件有很多重要的属性,但首先必须熟悉几个属性。
    CommPort 设置并返回通讯端口号。 
    Settings 以字符串的形式设置并返回波特率、奇偶校验、数据位、停止位。 
    PortOpen 设置并返回通讯端口的状态。也可以打开和关闭端口。 
    Input 从接收缓冲区返回和删除字符。 
    Output 向传输缓冲区写一个字符串。

    CommPort属性 设置并返回通讯端口号。
    语法 object.CommPort[value ] (value 一整型值,说明端口号。) 
    说明 在设计时,value 可以设置成从 1 到 16 的任何数(缺省值为 1)。但是如果用 PortOpen 属性打开一个并不存在的端口时,MSComm 
    控件会产生错误 68(设备无效)。
    注意:必须在打开端口之前设置 CommPort 属性。

    CTSHolding 属性:确定是否可通过查询 Clear To Send (CTS) 线的状态发送数据。Clear To Send 是调制解调器发送到相联计算机的信号,
    指示传输可以进行。该属性在设计时无效,在运行时为只读。
    语法: object.CTSHolding(Boolean)

    Mscomm 控件的 CTSHolding 属性设置值:
    True Clear To Send 线为高电平。 
    False Clear To Send 线为低电平。

    说明:如果 Clear To Send 线为低电平 (CTSHolding = False) 并且超时时,MSComm 控件设置 CommEvent 属性为 comEventCTSTO
     (Clear To Send Timeout) 并产生 OnComm 事件。

    详细信息 有关握手协议,请参阅 Handshaking 属性。

    语法 object.SThreshold [ = value ]
    value 整形表达式,代表在 OnComm 事件产生之前在传输缓冲区中的最小字符数。


    Handshake 常数

    常数 值 描述 
    comNone 0 无握手。 
    comXonXoff 1 XOn/Xoff 握手。 
    comRTS 2 Request-to-send/clear-to-send 握手。 
    comRTSXOnXOff 3 Request-to-send 和 clear-to-send 握手皆可。

    常数 值 描述 
    comEvSend 1 发送事件。 
    comEvReceive 2 接收事件。 
    comEvCTS 3 clear-to-send 线变化。 
    comEvDSR 4 data-set ready 线变化。 
    comEvCD 5 carrier detect 线变化。 
    comEvRing 6 振铃检测。 
    comEvEOF 7 文件结束。

    常数 值 描述 
    comEventBreak 1001 接收到中断信号 
    comEventCTSTO 1002 Clear-to-send 超时 
    comEventDSRTO 1003 Data-set ready 超时 
    comEventFrame 1004 帧错误 
    comEventOverrun 1006 端口超速 
    comEventCDTO 1007 Carrier detect 超时 
    comEventRxOver 1008 接收缓冲区溢出 
    comEventRxParity 1009 Parity 错误 
    comEventTxFull 1010 传输缓冲区满 
    comEventDCB 1011 检索端口 设备控制块 (DCB) 时的意外错误

    InputMode 常数
    常数 值 描述 
    comInputModeText 0 (缺省)通过 Input 属性以文本方式取回数据。 
    comInputModeBinary 1 通过 Input 属性以二进制方式检取回数据。

     

     

    语法 object.CDHolding
    设置值:CDHolding 属性的设置值为: 
    设置 描述 
    True Carrier Detect 线为高电平 
    False Carrier Detect 线为低电平 
    说明:注意当 Carrier Detect 线为高电平 (CDHolding = True) 且超时时,MSComm 控件设置CommEvent 属性为 comEventCDTO(Carrier 
    Detect 超时错误),并产生 OnComm 事件。
    注意 在主机应用程序中捕获一个丢失的传输是特别重要的,例如一个公告板,因为呼叫者可以随时挂起(放弃传输)。
    Carrier Detect 也被称为 Receive Line Signal Detect (RLSD)。
    数据类型 Boolean

    DSRHolding 属性:确定 Data Set Ready (DSR) 线的状态。Data Set Ready 信号由调制解调器发送到相连计算机,指示作好操作准备。该属
    性在设计时无效,在运行时为只读。
    语法:object.DSRHolding
    object 所在处表示对象表达式,其值是“应用于”列表中的对象。
    DSRHolding 属性返回以下值:
    值 描述 
    True Data Set Ready 线高 
    False Data Set Ready 线低 
    说明:当 Data Set Ready 线为高电平 (DSRHolding = True) 且超时时,MSComm 控件设置 CommEvent 属性为 comEventDSRTO(数据准备超
    时)并产生 OnComm 事件。
    当为 Data Terminal Equipment (DTE) 机器写 Data Set Ready/Data Terminal Ready 握手例程时该属性是十分有用的。
    数据类型:Boolean

    语法: object.Settings[ = value]
    说明:当端口打开时,如果 value 非法,则 MSComm 控件产生错误 380(非法属性值)。
    Value 由四个设置值组成,有如下的格式:
    "BBBB,P,D,S"
    BBBB 为波特率,P 为奇偶校验,D 为数据位数,S 为停止位数。value 的缺省值是:
    "9600,N,8,1"

    语法 object.InputLen [ = value]
    InputLen 属性语法包括下列部分:
    value 整型表达式,说明 Input 属性从接收缓冲区中读取的字符数。 
    说明:InputLen 属性的缺省值是 0。设置 InputLen 为 0 时,使用 Input 将使 MSComm 控件读取接收缓冲区中全部的内容。


    EOFEnable 属性:确定在输入过程中 MSComm 控件是否寻找文件结尾 (EOF) 字符。如果找到 EOF 字符,将停止输入并激活 OnComm 事件,此
    时 CommEvent 属性设置为 comEvEOF,
    语法:object.EOFEnable [ = value ]
    EOFEnable 属性语法包括下列部分:
    value 布尔表达式,确定当找到 EOF 字符时,OnComm 事件是否被激活,如“设置值”中所描述。 
    value 的设置值:
    True 当 EOF 字符找到时 OnComm 事件被激活。 
    False (缺省)当 EOF 字符找到时 OnComm 事件不被激活。 
    说明:当 EOFEnable 属性设置为 False,OnComm 控件将不在输入流中寻找 EOF 字符。


    下表列出 MSComm 控件可以捕获的错误:

    值 描述 
    380 无效属性值 comInvalidPropertyValue
    383 属性为只读 comSetNotSupported
    394 属性为只读 comGetNotSupported 
    8000 端口打开时操作不合法 comPortOpen
    8001 超时值必须大于 0 
    8002 无效端口号 comPortInvalid
    8003 属性只在运行时有效 
    8004 属性在运行时为只读 
    8005 端口已经打开 comPortAlreadyOpen
    8006 设备标识符无效或不支持该标识符 
    8007 不支持设备的波特率 
    8008 指定的字节大小无效 
    8009 缺省参数错误 
    8010 硬件不可用(被其它设备锁定) 
    8011 函数不能分配队列 
    8012 设备没有打开 comNoOpen 
    8013 设备已经打开 
    8014 不能使用 comm 通知 
    8015 不能设置 comm 状态 comSetCommStateFailed
    8016 不能设置 comm 事件屏蔽 
    8018 仅当端口打开时操作才有效 comPortNotOpen 
    8019 设备忙 
    8020 读 comm 设备错误 comReadError
    8021 为该端口检索设备控制块时的内部错误 comDCBError

  • 相关阅读:
    Shell脚本查看apk签名信息
    Android Studio中的六种依赖
    Gradle build设置自动log开关
    转-Android Studio系列教程六--Gradle多渠道打包
    经验分享
    Android Studio build dex jar
    iPhone6搜索如何打开?详细使用方法
    Android Studio 简单设置
    Android Studio常见问题 -- uses-sdk:minSdkVersion 8 cannot be smaller than version 9 declared in library
    iOS开发学习记录【整理】
  • 原文地址:https://www.cnblogs.com/rosesmall/p/14085867.html
Copyright © 2020-2023  润新知