本人需要窜口编程,就是用mscomm读取电子地磅中的数据,想用mscomm实现,但初
使用,不动mscomm的属性,方法,请教大家!最好有例子,有读取电子地磅的更好。

解决方案 »

  1.   

    spcomm更加简单
    转贴
    Delphi中串口通信的实现河南省计算中心 张海航 --------------------------------------------------------------------------------
     Delphi是一种具有功能强大、简便易用和代码执行速度快等优点的可视化快速应用开发工具,它在构架企业信息系统方面发挥着越来越重要的作用,许多程序员愿意选择 Delphi作为开发工具编制各种应用程序。但是,美中不足之处是 Delphi没有自带的串口通信控件,在它的帮助文档里也没有提及串口通信,这就给编制通信程序的开发人员带来许多不便。  
     
    目前,利用 Delphi实现串口通信的常用的方法有 3种:一是利用控件,如 MSCOMM控件和 SPCOMM控件;二是使用 API函数;三是调用其他串口通信程序。其中利用 API编写串口通信程序较为复杂,需要掌握大量的通信知识。相比较而言,利用 SPCOMM控件则相对较简单,并且该控件具有丰富的与串口通信密切相关的属性及事件,提供了对串口的各种操作,而且还支持多线程。下面本文结合实例详细介绍 SPCOMM控件的使用。  
     
    SPCOMM的安装  
     
    1.选择下拉菜单 Component中的 Install Component选项,弹出如图 1所示的窗口。  
     
     
    图 1 
     
    在 Unit file name处填写 SPCOMM控件所在的路径,其他各项可用默认值,点击 OK按钮。  
     
    2.安装后,在 System控件面板中将出现一个红色控件 COM。现在就可以像 Delphi自带控件一样使用 COM控件了。  
     
    SPCOMM的属性、方法和事件  
     
    1.属性  
     
    ●CommName:表示 COM1、 COM2等串口的名字;  
     
    ●BaudRate:根据实际需要设定的波特率,在串口打开后也可更改此值,实际波特率随之更改;  
     
    ●ParityCheck:表示是否需要奇偶校验;  
     
    ●ByteSize:根据实际情况设定的字节长度;  
     
    ●Parity:奇偶校验位;  
     
    ●StopBits:停止位;  
     
    ●SendDataEmpty:这是一个布尔型属性,为 true时表示发送缓存为空,或者发送队列里没有信息;为 false时表示发送缓存不为空,或者发送队列里有信息。  
     
    2.方法  
     
    ●Startcomm方法用于打开串口,当打开失败时通常会报错。错误主要有 7种:⑴串口已经打开;⑵打开串口错误;⑶文件句柄不是通信句柄;⑷不能够安装通信缓存;⑸不能产生事件;⑹不能产生读进程;⑺不能产生写进程;  
     
    ●StopComm方法用于关闭串口,没有返回值;  
     
    ●WriteCommData(pDataToWrite: PChar;dwSizeofDataToWrite:Word )方法是个带有布尔型返回值的函数,用于将一个字符串发送到写进程,发送成功返回 true,发送失败返回 false。执行此函数将立即得到返回值,发送操作随后执行。该函数有两个参数,其中 pDataToWrite是要发送的字符串, dwSizeofDataToWrite是发送字符串的长度。  
     
    3.事件  
     
    ●OnReceiveData :procedure (Sender: TObject;Buffer: Pointer;BufferLength: Word) of object  
     
    当有数据输入缓存时将触发该事件,在这里可以对从串口收到的数据进行处理。 Buffer中是收到的数据, BufferLength是收到的数据长度。  
     
    ●OnReceiveError : procedure(Sender: TObject; EventMask : DWORD)  
     
    当接收数据出现错误时将触发该事件。  
     
    SPCOMM的使用  
     
    下面是一个利用 SPCOMM控件的串口通信的例子。  
     
    以实现 PC机与单片机 8051之间的通信为例,首先要调通它们之间的握手信号。假定它们之间的通信协议是: PC到 8051一帧数据 6个字节, 8051到 PC一帧数据也为 6个字节。当 PC发出( F0,01,FF,FF,01,F0)后 8051能收到一帧( F0,01,FF,FF,01,F0),表示数据通信握手成功,两者之间就可以按照协议相互传输数据。  
     
    创建一个新的工程 COMM.DPR,把窗体的 NAME属性定为 FCOMM,把窗体的标题定义为测试通信,按照图 2添加控件 (图 2中黑色矩形围住的控件即为 COMM1)。  
     
     
     
    图 2 
     
    1.设定 COMM1属性:  
     
    ●波特率: 4800;  
     
    ●奇偶校验位:无;  
     
    ●字节长度: 8;  
     
    ●停止位: 1;  
     
    ●串口: COM1。  
     
    Memo1中将显示发送和接收的数据。将新的窗体存储为 Comm.pas。  
     
    2.编写源代码  
     
    //变量说明  
     
    var  
     
    fcomm: TFCOMM;  
     
    viewstring:string;  
     
    i:integer;  
     
    rbuf,sbuf:array[16] of byte;  
     
    //打开串口  
     
    procedure TFCOMM.FormShow(Sender: TObject);  
     
    begin  
     
    comm1.StartComm;  
     
    end;  
     
    //关闭串口  
     
    procedure TFCOMM.FormClose(Sender: TObject; var Action: TCloseAction);  
     
    begin  
     
    comm1.StopComm;  
     
    end;  
     
    //自定义发送数据过程  
     
    procedure senddata;  
     
    var  
     
    i:integer;  
     
    commflg:boolean;  
     
    begin  
     
    viewstring:=‘’ ;  
     
    commflg:=true;  
     
    for i:=1 to 6 do  
     
    begin  
     
    if not fcomm.comm1.writecommdata(@sbuf[i],1) then  
     
    begin  
     
    commflg:=false;  
     
    break;  
     
    end;  
     
    //发送时字节间的延时  
     
    sleep(2);  
     
    viewstring:=viewstring+ inttohex(sbuf[i],2)+‘’ ; end;  
     
    viewstring:=‘发送’+ viewstring;  
     
    fcomm.memo1.lines.add(viewstring);  
     
    fcomm.memo1.lines.add(‘’ );  
     
    if not commflg then messagedlg(‘发送失败 !’ ,mterror,[mbyes],0);  
     
    end;  
     
    //发送按钮的点击事件  
     
    procedure TFCOMM.Btn_sendClick(Sender: TObject);  
     
    begin  
     
    sbuf[1]:=byte($ f0); //帧头  
     
    sbuf[2]:=byte($ 01); //命令号  
     
    sbuf[3]:=byte($ ff);  
     
    sbuf[4]:=byte($ ff);  
     
    sbuf[5]:=byte($ 01);  
     
    sbuf[6]:=byte($ f0); //帧尾  
     
    senddata;//调用发送函数  
     
    end;  
     
    //接收过程  
     
    procedure TFCOMM.Comm1ReceiveData(Sender: TObject; Buffer: Pointer;BufferLength: Word);  
     
    var  
     
    i:integer;  
     
    begin  
     
    viewstring:=‘’ ;  
     
    move(buffer^,pchar(@rbuf)^,bufferlength);  
     
    for i:=1 to bufferlength do  
     
    viewstring:=viewstring+ inttohex(rbuf[i],2)+‘’ ;  
     
    viewstring:=‘接收’+ viewstring;  
     
    memo1.lines.add(viewstring);  
     
    memo1.lines.add(‘’ );  
     
    end;  
     
    如果 memo1上显示发送 F0 01 FF FF 01 F0和接收到 F0 01 FF FF 01 F0,这表示串口已正确地发送出数据并正确地接收到数据,则串口通信成功。 
      

  2.   

    http://www.gjwtech.com/考...能不能说说你做的是什么型号的??
    以前搞过上海耀华的一个.
    msdn里也有.
      

  3.   

    Mscomm控件详解 
    http://www.8860.net/delphicode/dispdoc.asp?id=50
      

  4.   

    delphi中常用串口控件简介:
    mscomm:微软的东西,是VB中带的一个ActiveX控件,使用简单,性能一般,由于是ActivX控件,打包时需要注册好多信息,在Delphi中使用,建议使用VCL控件,编译程序时直接编入程序中,再不需任何其它处理。
    spcomm:比较好的vcl控件,算是比较专业的,解剖了一下,功能比较完善。
    TurboPower:公认的专业通讯vcl控件。可以到其站点下载,开放源码了。
    我在制作串口通讯软件时三种都用过,最终全部使用TurboPower!所以也推荐大家使用它。
    写了个例子,基本的串口通讯都可以实现,可提供参考:
    下载基地-》文件名称:串口通讯控制器
    版权声明:以下本文只允许在本站观看,不得以任何媒体方式进行传播。
    发表意见请到留言版。TurboPower串口通讯实际应用:
    在串口通讯时有字符和十六进制两种数据传输方式,不论使用哪种方式,只要能正确收到数据就是目的,至于收到数据后如何处理,就要根据具体的情况来定了。1.接收数据的方法:
    轮询和中断(利用windows消息激发事件)。
    1)轮询:每间隔一定的时间查询一下串口接收缓存中有无数据,有就读出来。这种方法是很毫资源的,即没事找事。
    2)中断:在控件中有OnTrigger事件,当串口收到数据后,即触发此事件,无数据时什么都不做,在这个事件中接收数据就比较科学了。
    所以,提倡使用控件中的OnTrigger事件接收数据。2.通讯协议的制定:
    接收数据的一般处理方法,最基本的思路就是通过协议进行分析,所以协议的制定是至关重要的:
    1)首先要确定指令的起始点,从大量的数据流中将指令分离出来,没有起始标志的话,结果就可想而知了,一串无效的费数据!
    2)然后就是指令结束识别点,可以利用指令的长度(如果长度一定或有表示长度的数据)或结束标志来确定,当然还可以利用下一条指令的指令头。
    3)既然头尾都明确了,指令的截取想来不是什么问题了吧!但还有一种情况就是数据错误是的容错,如何容错呢,最简单的办法:发现不符合格式的指令,就将其抛掉或特殊处理(如要求重发)一下!
    4)有效数据中如果增加一些校验,通讯将会更加可靠!
    例:#(指令头)**(指令功能)0123456789(有效数据)**(有效数据校验和)%(指令尾)
    注:**代表变动值。3.接收数据的分析技巧:
    通讯协议制定好后,一切将以通讯协议为中心。一套协议中的所有指令可能长度都是统一的,也有可能是长短不同的,并且在OnTrigger事件中实际反应速度及快,可能一条指令数据还没有完全收齐就已经触发了此事件,即收到了半截指令,并且有可能继续收取的数据中除了下半截指令外,还有下一条指令的前半截,如何处理?
    我在做这种处理时是利用全局变量,将串口收到的所有数据都收到该串中,然后按指令格式进行截取,发现不合法指令做一下特殊处理(如要求重发)或抛弃。
    如收到的数据串为:
    #**0000012000**%#**0000000343#**000000540560**%#**0002200000**%
    分段截为:
    #**0000012000**%
    #**0000000343
    #**000000540560**%
    #**0002200000**%
    四条指令,其中:#**0000000343不完整,检测到后进行抛弃处理。调试技巧篇:
    对于已了解协议的支持串口产品,要想进行编程控制,可以使用“串口通讯控制器”进行调试,以摸清具体实现数据,可按如下步骤进行:
    1.确定硬件连接无误,这是首要条件,如果错误将没有成功的可能;
    连线必须正确,必要时可以使用计算机自带的多个端口相互进行测试,已保证硬件的连接无误。串口通讯线有9针和25针,多用9针,其中最重要的是2(RXD)、3(TXD)、5(GND)线,对应关系如下:
    9针 25针
    2 -- 3
    3 -- 2
    5 -- 72.确定通讯参数正确,如:波特率、奇偶校验位、数据位、停止位等,以及收发的是十六进制还是字符串:3.以上确保正确,则使用“串口通讯控制器”,按协议输入数据进行收发控制了。
    注意:有的仪器需要进行初始化,即先发一段激活指令,然后才能进入工作状态,这种设置主要是为了实现利用硬件为软件加密,即类似加密狗,需要有激活方法才行,不过该类方法使用较少。原创作者:JPYC,望业界专家多多指正!控件及例程源码请到:http://www.kaer.cn/default.aspx->软件基地
      

  5.   

    CDHolding 属性:通过查询 Carrier Detect (CD) 线的状态确定当前是否有传输。Carrier Detect 是从调制解调器发送到相联计算机的一个信号,指示调制解调器正在联机。该属性在设计时无效,在运行时为只读。语法 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)。
    数据类型 BooleanDSRHolding 属性:确定 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
    Settings 属性: 设置并返回波特率、奇偶校验、数据位、停止位参数。语法: object.Settings[ = value]
    说明:当端口打开时,如果 value 非法,则 MSComm 控件产生错误 380(非法属性值)。
    Value 由四个设置值组成,有如下的格式:
    "BBBB,P,D,S"
    BBBB 为波特率,P 为奇偶校验,D 为数据位数,S 为停止位数。value 的缺省值是:
    "9600,N,8,1"
    InputLen 属性:设置并返回 Input 属性从接收缓冲区读取的字符数。语法 object.InputLen [ = value]
    InputLen 属性语法包括下列部分:
    value 整型表达式,说明 Input 属性从接收缓冲区中读取的字符数。 
    说明:InputLen 属性的缺省值是 0。设置 InputLen 为 0 时,使用 Input 将使 MSComm 控件读取接收缓冲区中全部的内容。若接收缓冲区中 InputLen 字符无效,Input 属性返回一个零长度字符串 ("")。在使用 Input 前,用户可以选择检查 InBufferCount 属性来确定缓冲区中是否已有需要数目的字符。该属性在从输出格式为定长数据的机器读取数据时非常有用。
    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 字符。
    错误消息(MS Comm 控件)
    下表列出 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