用spcomm控件时写的代码可以实现通讯,如下:
var
  sendarray: array[0..4] of byte;
begin
  sendarray[0] := $10;
  sendarray[1] := $40;
  sendarray[2] := $1;
  sendarray[3] := $41;
  sendarray[4] := $16;
  comm1.WriteCommData(@sendarray[0], 5);
end;
换成用MsComm该怎么改呢?下面这个方法不行
var
  SendBuf: array[1..5] of Byte;
begin
  SendBuf[1] := $10;
  SendBuf[2] := $40;
  SendBuf[3] := $01;
  SendBuf[4] := $41;
  SendBuf[5] := $16;
  MsComm1.Output := chr(SendBuf[1])+ chr(SendBuf[2])+ chr(SendBuf[3])+ chr(SendBuf[4])+ chr(SendBuf[5]);
end;

解决方案 »

  1.   

    下面代码供参考:
    var
      CommForm: TCommForm;
      ss :string;
      savef,readf :file of char;
      i,j :longint;procedure TCommForm.FormCreate(Sender: TObject);
    begin
      mscomm.commport:=1;
      mscomm.settings:='9600,n,8,1';
      mscomm.inputlen:=1;
      mscomm.inbuffercount:=0;
      mscomm.portopen:=true;
      ss:='';
      i:=0;
      j:=0;
      assignfile(savef,'save1');
      rewrite(savef);
      assignfile(readf,'read1');
      reset(readf);
    end;procedure TCommForm.btnConfirmClick(Sender: TObject);
    begin
      if mscomm.portopen then
        mscomm.portopen:=false;
        mscomm.commport:=strtoint(edtCommport.text);
        mscomm.settings:=edtCommsetting.Text;
    end;procedure TCommForm.MSCommComm(Sender: TObject);
    var
      filenrc :char;
      buffer :variant;
      s1:string;
      c :char;
    begin
    case mscomm.commEvent of
    comEvSend:
      begin
      while not(eof(readf)) do
        begin
        read(readf,filenrc);
        mscomm.output:=filenrc;
        j:=j+1;
        lblDisplay.caption:=inttostr(j);
        if mscomm.outbuffercount>=2 then
        break;
        end;
      end;
    comEvReceive:
      begin
        buffer:=mscomm.Input;
        s1:=buffer;
        c:=s1[1];
        ss:=ss+c;
        i:=i+1;
        lblDisplay.caption:=c+inttostr(i);
        write(savef,c);
        if (c=chr(10))or(c=chr(13)) then
          begin
            lblDisplay.caption:='cr'+inttostr(i);
            memDisplay.lines.add(ss);
            ss:='';
          end;
      end;
    end;
    end;
      

  2.   

    我想知道怎么发送,按spcomm的发送内容看,发送什么格式算是正确的。
      

  3.   

    另外,mscomm是偶校验,9600,settings是不是等于9600,e,8,1?
      

  4.   

    Handshake 常数常数 值 描述 
    comNone 0 无握手。 
    comXonXoff 1 XOn/Xoff 握手。 
    comRTS 2 Request-to-send/clear-to-send 握手。 
    comRTSXOnXOff 3 Request-to-send 和 clear-to-send 握手皆可。 
    OnComm 常数常数 值 描述 
    comEvSend 1 发送事件。 
    comEvReceive 2 接收事件。 
    comEvCTS 3 clear-to-send 线变化。 
    comEvDSR 4 data-set ready 线变化。 
    comEvCD 5 carrier detect 线变化。 
    comEvRing 6 振铃检测。 
    comEvEOF 7 文件结束。 
    Error 常数常数 值 描述 
    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 属性以二进制方式检取回数据。 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
      

  5.   

    var OvTm:olevariant;
        tm:variant;
    begin
      if not mscomm1.PortOpen then
        mscomm1.PortOpen:=True;
      tm:=vararraycreate([0,127],varbyte);
      tm[1]:=$10;
      tm[2]:=$40;
      tm[3]:=$01;
      tm[4]:=$41;
      OvTm:=tm;
      mscomm1.Output:=OvTm;
    end;
    以上代码通过使用单片机测试,与SPCOMM控件发送数据相同。
    对于用MSCOMM控件接收类似的数据,小弟实在无能为力......
    老兄如果解决了这个问题,请一定告知小弟
      

  6.   

    我现在这样写,oncomm时间都触发不了!只要能触发oncomm事件我想什么都应该不难了。
    现在好象什么问题都没有明确,不知道是什么出错了。
      

  7.   

    不是这样吧? oncomm事件应该能触发的。RTSENABLE设置为true了吗?
      

  8.   

    不知道是不是控件的设置有什么问题,我用com2,'9600,e,8,1'.应该没有什么要注意的了。
    发过去没有回应真是讨嫌
      

  9.   

    这个是True啊,很多都是默认的东西没有改的
      

  10.   

    你能保证设备有数据返回吗?
    你可以从COM2发送到COM1只需要自己再做一个数据线就行了。
      

  11.   

    我现在就是用两个串口在做试验,com2用mscomm,com1用spcomm,结果是comm2可以向com1发送,com1能接收到,但com1向com2发送却收不到了。
      

  12.   

    设置:
    RTSEnable=True.
    RThreshold=2
    在ONCOMM事件中添加代码:
    if commevent=2 then
      begin
       sleep(200);    <---做点等待 保证数据完全被接收到
        ........
      end;
      

  13.   

    有空你做下试验,
    procedure TForm1.FormCreate(Sender: TObject);
    begin
      Comm1.StartComm;
      MsComm1.PortOpen := True;
    end;//mscomm的发送和oncomm
    procedure TForm1.Button1Click(Sender: TObject);
    var OvTm:olevariant;
        tm:variant;
    begin
      tm:=vararraycreate([1,5],varbyte);
      tm[1]:=$10;
      tm[2]:=$40;
      tm[3]:=$01;
      tm[4]:=$41;
      tm[5]:=$16;
      OvTm:=tm;
      mscomm1.Output:=OvTm;
    end;procedure TForm1.MSComm1Comm(Sender: TObject); //这里的代码好象触发不到
    var
      strTmp: string;
    begin
      strTmp := MsComm1.Input;
      Showmessage('Com2接收:' + strTmp);
    end;//spcomm的发送和oncomm
    procedure TForm1.Button2Click(Sender: TObject);
    var
      sendarray: array[0..5] of byte;
    begin
      sendarray[0] := $10;
      sendarray[1] := $20;
      sendarray[2] := $30;
      sendarray[3] := $40;
      sendarray[4] := $50;
      comm1.WriteCommData(@sendarray[0], 5);
    end;procedure TForm1.Comm1ReceiveData(Sender: TObject; Buffer: Pointer;
      BufferLength: Word);
    var
      iTmp: Integer;
      strTmp: string;
      bReceive: array[0..100] of Byte;
    begin
      Move(Buffer^, pchar(@bReceive)^, BufferLength);
      strTmp := '';
      for iTmp := 0 to BufferLength - 1 do
        strTmp := strTmp + ' ' + IntToHex(bReceive[iTmp], 2);
      showMessage('Com1接收:'+strTmp);
    end;
      

  14.   

    procedure TForm1.MSComm1Comm(Sender: TObject); //这里的代码好象触发不到
    var
      strTmp: string;
    begin
      strTmp := MsComm1.Input;   <---这里不应该立即取数
      Showmessage('Com2接收:' + strTmp);
    end;
      

  15.   

    不管是否应该不应该取数,没有show出message就是错误啊!
      

  16.   


    下面代码供参考:
    var
      CommForm: TCommForm;
      ss :string;
      savef,readf :file of char;
      i,j :longint;procedure TCommForm.FormCreate(Sender: TObject);
    begin
      mscomm.commport:=1;
      mscomm.settings:='9600,n,8,1';
      mscomm.inputlen:=1;
      mscomm.inbuffercount:=0;
      mscomm.portopen:=true;
      ss:='';
      i:=0;
      j:=0;
      assignfile(savef,'save1');
      rewrite(savef);
      assignfile(readf,'read1');
      reset(readf);
    end;procedure TCommForm.btnConfirmClick(Sender: TObject);
    begin
      if mscomm.portopen then
        mscomm.portopen:=false;
        mscomm.commport:=strtoint(edtCommport.text);
        mscomm.settings:=edtCommsetting.Text;
    end;procedure TCommForm.MSCommComm(Sender: TObject);
    var
      filenrc :char;
      buffer :variant;
      s1:string;
      c :char;
    begin
    case mscomm.commEvent of
    comEvSend:
      begin
      while not(eof(readf)) do
        begin
        read(readf,filenrc);
        mscomm.output:=filenrc;
        j:=j+1;
        lblDisplay.caption:=inttostr(j);
        if mscomm.outbuffercount>=2 then
        break;
        end;
      end;
    comEvReceive:
      begin
        buffer:=mscomm.Input;
        s1:=buffer;
        c:=s1[1];
        ss:=ss+c;
        i:=i+1;
        lblDisplay.caption:=c+inttostr(i);
        write(savef,c);
        if (c=chr(10))or(c=chr(13)) then
          begin
            lblDisplay.caption:='cr'+inttostr(i);
            memDisplay.lines.add(ss);
            ss:='';
          end;
      end;
    end;
    end;
    //////////////
    Handshake 常数常数 值 描述 
    comNone 0 无握手。 
    comXonXoff 1 XOn/Xoff 握手。 
    comRTS 2 Request-to-send/clear-to-send 握手。 
    comRTSXOnXOff 3 Request-to-send 和 clear-to-send 握手皆可。 
    OnComm 常数常数 值 描述 
    comEvSend 1 发送事件。 
    comEvReceive 2 接收事件。 
    comEvCTS 3 clear-to-send 线变化。 
    comEvDSR 4 data-set ready 线变化。 
    comEvCD 5 carrier detect 线变化。 
    comEvRing 6 振铃检测。 
    comEvEOF 7 文件结束。 
    Error 常数常数 值 描述 
    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 属性以二进制方式检取回数据。 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
      

  17.   

    你确保RTSEnable=True.了吗?
    我一直这样做  都能收到啊  只是只能接收ASC码