Mscomm中如何发送大于128的数?(50分)

  • 主题发起人 主题发起人 dracula_king
  • 开始时间 开始时间
D

dracula_king

Unregistered / Unconfirmed
GUEST, unregistred user!
通讯中Mscomm发送大于128的数,另一台机器收到的是0
SPcomm不能清空接收缓冲区,有时有无效数据,我有时要清空接收缓冲区
请问:Mscomm中如何发送大于128的数?
 
呵呵! 怎么又贴一张?
说了在Pwin中Mscomm不能发送大于128的数,除非你装英文WIN。
还有一个办法是自己写函数,重定义。 Mscomm有一个关于二进制的BUG!
 
谢啦YB_uniqe
 
用MSCOMM涉及到OleVariant和Variant变量,而结构TVarData直接映射了这两者,OleVariant
与Variant的区别仅仅在于前者只支持OLE类型变量.TVarData结构的定义在System单元内.
以下是MSCOMM的具体用法:

MSComm控件的主要属性及事件
  (1)CommPort:设置或返回串行端口号,缺省值1。
  (2)Setting:设置或返回串口通信参数,格式为“波特率,奇偶校验位,数据位,
停止位”。例如:MSComm1.Setting:=′9600,n,8,1′
  (3)PortOpen:打开或关闭串行端口,格式为:MSComm1.PortOpen:={True|False}
  (4)InBufferSize:设置或返回接收缓冲区的大小,缺省值为1024字节。
  (5)InBufferCount:返回接收缓冲区内等待读取的字节数,可通过设置该属性为0来
清空接收缓冲区。
  (6)RThreshold:该属性为一阀值,它确定当接收缓冲区内的字节个数达到或超过该
值后就产生代码为ComEvReceive的OnComm事件。
  (7)SThreshold:该属性为一阀值,它确定当发送缓冲区内的字节个数少于该值后就
产生代码为ComEvSend的OnComm事件。
  (8)InputLen:设置或返回接收缓冲区内用Input读入的字节数,设置该属性为0表示
Input读取整个缓冲区的内容。
  (9)Input:从接收缓冲区读取一串字符。
  (10)OutBufferSize:设置或返回发送缓冲区的大小,缺省值为512字节。
  (11)OutBufferCount:返回发送缓冲区内等待发送的字节数,可通过设置该属性为0
来清空缓冲区。
  (12)OutPut:向发送缓冲区传送一串字符。
  如果在通信过程中发生错误或事件,就会触发OnComm事件,并由CommEvent属性代码反映错误类型,在通信程序的设计中可根据该属性值来执行不同的操作。CommEvent属性值及其含义如下:
  (1)ComEvSend:值为1,发送缓冲区的内容少于SThreshold指定的值。
  (2)ComEvReceive:值为2,接收缓冲区内字符数达到RThreshold指定的值。
  (3)ComEvFrame:值为1004,硬件检测到帧错误。
  (4)ComEvRxOver:值为1008,接收缓冲区溢出。
  (5)ComEvTxFull:值为1010,发送缓冲区溢出。
  (6)ComEvRxParity:值为1009,奇偶校验错误。
  (7)ComEvEOF:值为7,接收数据中出现文件尾(ASCII码为26)字符。

type
TByteArray = array[0..999]of Byte;
PByteArray = ^TByteArray;

procedure TForm1.FormCreate(Sender: TObject);
begin
//串口初始化
MSComm.CommPort := 1; //COM1
MSComm.Setting:= '9600,n,8,1'; //波特率9600,数据位8位,无奇偶校验,停止位1位
MSComm.InBufferCount := 0; //清空接收缓冲区
 MSComm.InputLen := 0; //读取整个缓冲区内容
MSComm.InBufferSize := 4096; //接收缓冲区4096个字节
 MSComm.RThreshold := 1000; //每次接收到1000个字节即产生OnComm事件
MSComm.OutBufferCount := 0; //清空发送缓冲区
MSComm.OutBufferSize := 512; //发送缓冲区512个字节
 MSComm.SThreshold := 1; //每次发送缓冲区字节数少于1个即产生OnComm事件
if not MSComm.PortOpen then //打开串口
MSComm.PortOpen := True;
end;

procedure TForm1.MSCommComm(Sender: TObject);
var
ovRec: OleVariant; //MSCOMM接收的数据
baVal: TByteArray; //接收数组,这里假设每次接收1000个数据
s: PByteArray;
i: Integer;
begin
if MSComm.ComEvent=ComEvReceive then
begin
ovRec := MSComm.Input;
s := TVarData(ovRec).VPointer;
for i:=0 to 999 do
baVal := s^;
end;
end;

procedure TForm1.Transmit(baVal: TByteArray); //发送数据主程序
var
ovSend: OleVariant;
begin
TVarData(ovSend).VPointer := @baVal;
if not MSComm.PortOpen then //打开串口
MSComm.PortOpen := True;
MSComm.Output := ovSend;
end;
 
dELPHI的串口控件有不少,都比这个好用,为什么偏偏用这个烂东西
 
thanks 我现在用SPCOMM了
to YB_uniqe:在中文win98下VFP+mscomm可以发送大于128的数,为什么 的李不行?
 
简单
定义个variant类型的数组,
将你的大于128的数存如数组,
将数组赋值给串口就行了
这个问题我以前研究了很长时间才解决,
给我分吧
 
肯定能发大于128的数,
mscomm的发送方式定为2进制发送发送
再按上面的朋友说的就行了
这在vb里不是问题的
 
多人接受答案了
 
InputMode设置成comInputModebinary
 
多人接受答案了。
 
后退
顶部