teresazwf
驱动牛犊
驱动牛犊
  • 注册日期2004-05-21
  • 最后登录2016-01-09
  • 粉丝0
  • 关注0
  • 积分0分
  • 威望0点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
阅读:2508回复:12

大家帮帮忙啦!!!

楼主#
更多 发布于:2004-09-09 18:07
struct ShuChuan_Data_Package
{
unsigned char Package_S;
unsigned short Vehicle_ID;
unsigned char Package_T;
unsigned short Package_L;
unsigned short Package_N;
unsigned char * Package_p;
unsigned char Package_CheckSum;
unsigned char Package_E;
};
ShuChuan_Data_Package *Data_Pointer->Package_S;
CString strtemp;
CString sendData; //转换后的字符串;
我想把数据结构里的所有成员项存到字符串里面,但要保证char型的占一个字节单元,short型的占两个字节单元,这样做的目的是为了把转变以后的字符串从串口传到对方,对方再分解成ShuChuan_Data_Package形式,我想了很久,都没有办法能把short型的数在保证其值不变的情况下放到两个字节里,大家帮我想想办法吧!!!
我是在vc 6.0下编的,以下是我程序的一部分代码,

//这句没问题,因为是字符,所以转换后占的字节数不变
strtemp.Format("%c",Data_Pointer->Package_S);
sendData+=strtemp;

//这句就有问题,如果Data_Pointer->Vehicle_ID是个位数的话,strtemp就是一个字符,如果是两位数的话,strtemp就是包含两个字符的字符串,三位数就成了包含三个字符的了,我想让strtemp不管Data_Pointer->Vehicle_ID在什么情况下都是只包含两个字符的字符串,该怎么办呢?
strtemp.Format("%d",Data_Pointer->Vehicle_ID);
sendData+=strtemp;
zhiyuan19840428
驱动小牛
驱动小牛
  • 注册日期2004-05-11
  • 最后登录2005-06-17
  • 粉丝0
  • 关注0
  • 积分0分
  • 威望0点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
沙发#
发布于:2004-09-09 18:44
用一个指向结构体的指针不就行了吗?
//发送方
ShuChuan_Data_Package  *s;
s = (ShuChuan_Data_Package *)malloc(sizeof(ShuChuan_Data_Package);
memset(s, 0,sizeof(ShuChuan_Data_Package);
开始赋值
....
send_by_port((void *)s, sizeof(ShuChuan_Data_Package);
//接收方
ShuChuan_Data_Package  *r;
r = (ShuChuan_Data_Package *)malloc(sizeof(ShuChuan_Data_Package);
memset(r, 0,sizeof(ShuChuan_Data_Package);
rece_by_port((void *)s, sizeof(ShuChuan_Data_Package));


这样不就OK了吗?

teresazwf
驱动牛犊
驱动牛犊
  • 注册日期2004-05-21
  • 最后登录2016-01-09
  • 粉丝0
  • 关注0
  • 积分0分
  • 威望0点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
板凳#
发布于:2004-09-10 09:14
用一个指向结构体的指针不就行了吗?
//发送方
ShuChuan_Data_Package  *s;
s = (ShuChuan_Data_Package *)malloc(sizeof(ShuChuan_Data_Package);
memset(s, 0,sizeof(ShuChuan_Data_Package);
开始赋值
....
send_by_port((void *)s, sizeof(ShuChuan_Data_Package);
//接收方
ShuChuan_Data_Package  *r;
r = (ShuChuan_Data_Package *)malloc(sizeof(ShuChuan_Data_Package);
memset(r, 0,sizeof(ShuChuan_Data_Package);
rece_by_port((void *)s, sizeof(ShuChuan_Data_Package));


这样不就OK了吗?

 

是这样的,串口通信我用的是MSComm这个控件,对于这个控件我没有找到什么资料可以看一下它的成员函数具体怎么定义,只是在网上找了一个简单的程序,照猫画虎般用m_ctrlComm.SetOutput(COleVariant((char *)Data_Pointer))这个函数发送,这里Data_Pointer就是指向结构体的指针,发送过去的只是结构体的第一个成员项。
你说的那个函数send_by_port我在msdn上怎么差不到呢?
lbcat
驱动牛犊
驱动牛犊
  • 注册日期2002-03-19
  • 最后登录2007-09-27
  • 粉丝0
  • 关注0
  • 积分8分
  • 威望1点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
地板#
发布于:2004-09-10 15:01
你可以用格式符来限制嘛:
strtemp.Format("%02.2d",Data_Pointer->Vehicle_ID);
sendData+=strtemp;

"%02.2d"中02表示最少输出2位,不足两位就补0;.2限制最多输出2位。
teresazwf
驱动牛犊
驱动牛犊
  • 注册日期2004-05-21
  • 最后登录2016-01-09
  • 粉丝0
  • 关注0
  • 积分0分
  • 威望0点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
地下室#
发布于:2004-09-10 15:57
这样的话值不就错了吗?如果Data_Pointer->Vehicle_ID是333的话,输出的岂不是33了?
lbcat
驱动牛犊
驱动牛犊
  • 注册日期2002-03-19
  • 最后登录2007-09-27
  • 粉丝0
  • 关注0
  • 积分8分
  • 威望1点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
5楼#
发布于:2004-09-13 08:53
你不是要把他变成字符串吗?如果你是想保证值的正确传递,那就不能用ASC码的方式了,只能用16进制的方式或BCD码的方式,但BCD码如果是用两个字节就只能传递4位数的大小了…………
lbcat
驱动牛犊
驱动牛犊
  • 注册日期2002-03-19
  • 最后登录2007-09-27
  • 粉丝0
  • 关注0
  • 积分8分
  • 威望1点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
6楼#
发布于:2004-09-13 10:14
你的情况只能用指针了!
m_ctrlComm.SetOutput(COleVariant((char *)Data_Pointer))这个函数应该只是发送一个字节的,你应该使用可以发送buffer的函数,或者自己构建一个。以下帮你转了一篇东东:

MSComm控件使用详解


龚建伟:这篇东西来不及好好整理,因有朋友经常提及,先放在这里,如果有必要,再详细理顺一下,更为详细的信息请去看MSDN。
 

 

摘要:本文详细介绍了MSComm控件在串口编程中使用。


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

Handshake 常数
OnComm 常数
InputMode 常数
错误消息


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

1.MSComm控件两种处理通讯的方式

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

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

1.2 查询方式

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

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

下面分别描述:

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

RThreshold 属性:在 MSComm 控件设置 CommEvent 属性为 comEvReceive 并产生 OnComm 之前,设置并返回的要接收的字符数。
语法 object.Rthreshold [ = value ](value 整型表达式,说明在产生 OnComm 事件之前要接收的字符数。 )
说明 当接收字符后,若 Rthreshold 属性设置为 0(缺省值)则不产生 OnComm 事件。例如,设置 Rthreshold 为 1,接收缓冲区收到每一个字符都会使 MSComm 控件产生 OnComm 事件。

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 事件。

Clear To Send 线用于 RTS/CTS (Request To Send/Clear To Send) 硬件握手。如果需要确定 Clear To Send 线的状态,CTSHolding 属性给出一种手工查询的方法。

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

SThreshold 属性: MSComm 控件设置 CommEvent 属性为 comEvSend 并产生 OnComm 事件之前,设置并返回传输缓冲区中允许的最小字符数。

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

说明:若设置 Sthreshold 属性为 0(缺省值),数据传输事件不会产生 OnComm 事件。若设置 Sthreshold 属性为 1,当传输缓冲区完全空时,MSComm 控件产生 OnComm 事件。如果在传输缓冲区中的字符数小于 value,CommEvent 属性设置为 comEvSend,并产生 OnComm 事件。comEvSend 事件仅当字符数与 Sthreshold 交叉时被激活一次。例如,如果 Sthreshold 等于 5,仅当在输出队列中字符数从 5 降到 4 时,comEvSend 才发生。如果在输出队列中从没有比 Sthreshold 多的字符,comEvSend 事件将绝不会发生。


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)。
数据类型 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


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

 
teresazwf
驱动牛犊
驱动牛犊
  • 注册日期2004-05-21
  • 最后登录2016-01-09
  • 粉丝0
  • 关注0
  • 积分0分
  • 威望0点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
7楼#
发布于:2004-09-13 11:28
这个控件好像只有这个SetOutPut这个函数可以发送数据,至于可以发送buffer的函数我在msdn上没找到,真不知道该怎么办了!!
xx_focus
驱动中牛
驱动中牛
  • 注册日期2003-08-06
  • 最后登录2007-06-08
  • 粉丝0
  • 关注0
  • 积分96分
  • 威望10点
  • 贡献值0点
  • 好评度8点
  • 原创分0分
  • 专家分0分
8楼#
发布于:2004-09-13 14:13
实际上上面l bcat 已经恢复的很清楚

MSND 中
搜索 Comm Control 得到以下结果

This control provides serial communications for your application by enabling the transmission and reception of data through a serial port.

Library Name
CECOMMCtl

DLL Name
Mscecomm.dll

The Comm control supports the following properties:

Break InBufferCount Parent
CDHolding Index ParityReplace
CommEvent Input PortOpen
CommID InputLen RThreshold
CommPort InputMode RTSEnable
CTSHolding Name Settings
DSRHolding NullDiscard SThreshold
DTREnable OutBufferCount  
Handshaking Output  


The Comm control supports the following events:

OnComm
Remarks
Each Comm control corresponds to one serial port. If you need to access more than one serial port in your application, you must use more than one Comm control.
lbcat
驱动牛犊
驱动牛犊
  • 注册日期2002-03-19
  • 最后登录2007-09-27
  • 粉丝0
  • 关注0
  • 积分8分
  • 威望1点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
9楼#
发布于:2004-09-14 09:39
看来是你把SetOutPut函数用错了…………注意它的原型是
void SetOutput(const VARIANT& newValue)
请看:


⑸.串口读写. 完成读写的函数的确很简单,GetInput()和SetOutput()就可。两个函数的原型是:

VARIANT GetInput();及 void SetOutput(const VARIANT& newValue);都要使用VARIANT类型(所有Idispatch::Invoke的参数和返回值在内部都是作为VARIANT对象处理的)。

无论是在PC机读取上传数据时还是在PC机发送下行命令时,我们都习惯于使用字符串的形式(也可以说是数组形式)。查阅VARIANT文档知道,可以用BSTR表示字符串,但遗憾的是所有的BSTR都是包含宽字符,即使我们没有定义_UNICODE_UNICODE也是这样! WinNT支持宽字符, 而Win95并不支持。为解决上述问题,我们在实际工作中使用CbyteArray,给出相应的部分程序如下:

    void CMainFrame::OnCommMscomm(){

     VARIANT vResponse;   int k;

if(m_commCtrl.GetCommEvent()==2) {      

k=m_commCtrl.GetInBufferCount(); //接收到的字符数目

if(k>0) {

vResponse=m_commCtrl.GetInput(); //read

SaveData(k,(unsigned char*) vResponse.parray->pvData);

} // 接收到字符,MSComm控件发送事件 }

   。。。。。 // 处理其他MSComm控件

}

void CMainFrame::OnCommSend() {

。。。。。。。。 // 准备需要发送的命令,放在TxData[]中

CByteArray array;

array.RemoveAll();

array.SetSize(Count);

for(i=0;i
array.SetAt(i, TxData);

   m_ComPort.SetOutput(COleVariant(array)); // 发送数据

}



还有:

VIRIANT是ACTIVEX AUTOMATION需要用到的一种变量类型,可以称之为通用数据类型,其实它是一个结构。如果仅仅是调用ACTIVEX对象所提供的METHOD不需知道其中的细节。它仅用于通过IDISPATCH接口调用特定的METHOD或属性时用,VB和VC已经将这一过程透明。(主持人注:换句话说,VC会自动转换简单数据类型。)
    关于下面的几个METHOD,例如OPENURL,在VB中原形是object.OpenUrl(url [,datatype] url是有效的URL字符串, DATATYPE是整形,返回指定URL的文档。在MFC中是CInternetSession::OpenURL
    CStdioFile* OpenURL( LPCTSTR pstrURL, DWORD dwContext = 1, DWORD dwFlags = INTERNET_FLAG_TRANSFER_ASCII, LPCTSTR pstrHeaders = NULL, DWORD dwHeadersLength = 0 );
    Throw ( CInternetException );
    VARIANT的定义如下:
    typedef struct FARSTRUCT tagVARIANT VARIANT;
    typedef struct FARSTRUCT tagVARIANT VARIANTARG;
    
    typedef struct tagVARIANT {
     VARTYPE vt;
     unsigned short wReserved1;
     unsigned short wReserved2;
     unsigned short wReserved3;
     union {
     unsigned char bVal; // VT_UI1.
     short iVal; // VT_I2 .
     long lVal; // VT_I4 .
     float fltVal; // VT_R4 .
     double dblVal; // VT_R8 .
     VARIANT_BOOL boolVal; // VT_BOOL.
     SCODE scode; // VT_ERROR.
     CY cyVal; // VT_CY .
     DATE date; // VT_DATE.
     BSTR bstrVal; // VT_BSTR.
     IUnknown FAR* punkVal; // VT_UNKNOWN.
     IDispatch FAR* pdispVal; // VT_DISPATCH.
     SAFEARRAY FAR* parray; // VT_ARRAY|*.
     unsigned char FAR* pbVal; // VT_BYREF|VT_UI1.
     short FAR* piVal; // VT_BYREF|VT_I2.
     long FAR* plVal; // VT_BYREF|VT_I4.
     float FAR* pfltVal; // VT_BYREF|VT_R4.
     double FAR* pdblVal; // VT_BYREF|VT_R8.
     VARIANT_BOOL FAR* pboolVal; // VT_BYREF|VT_BOOL.
     SCODE FAR* pscode; // VT_BYREF|VT_ERROR.
     CY FAR* pcyVal; // VT_BYREF|VT_CY.
     DATE FAR* pdate; // VT_BYREF|VT_DATE.
     BSTR FAR* pbstrVal; // VT_BYREF|VT_BSTR.
     IUnknown FAR* FAR* ppunkVal; // VT_BYREF|VT_UNKNOWN.
     IDispatch FAR* FAR* ppdispVal; // VT_BYREF|VT_DISPATCH.
     SAFEARRAY FAR* FAR* pparray; // VT_ARRAY|*.
     VARIANT FAR* pvarVal; // VT_BYREF|VT_VARIANT.
     void FAR* byref; // Generic ByRef.
     };
    };
    主持人注:VARIANT结构的vt是很重要,它相当VB的VarType函数。
:D :D
teresazwf
驱动牛犊
驱动牛犊
  • 注册日期2004-05-21
  • 最后登录2016-01-09
  • 粉丝0
  • 关注0
  • 积分0分
  • 威望0点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
10楼#
发布于:2004-09-15 09:09
  谢谢你,lbcat!你真是太热心了。我的问题算是解决了,就是有点麻烦。我把整数的高低字节分别转换成两个字符发过去,如果是0则按照字符0发过去(因为串口在发送数据的时候遇到空字符串就停止),然后在接收方也做了相映的处理。
  我好像在嵌入式版见过你,不知道是不是记错了:)
还有怎么给分啊?我以前好像见过那项,怎么现在找不见了?
lbcat
驱动牛犊
驱动牛犊
  • 注册日期2002-03-19
  • 最后登录2007-09-27
  • 粉丝0
  • 关注0
  • 积分8分
  • 威望1点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
11楼#
发布于:2004-09-15 09:27
 哦??碰到0x00就会结束啊??看来用字符串来传还是不那么理想~~或许你把要传的数据全都加上一个基数再传可能更简单,然后接收到后再减掉这个基数就完了~~~最完美的话就用API函数吧~~~
 我是到处溜达的~~呵呵,见过也不奇怪~~
 在你顶贴底下就有两个按钮“给分”和“改分”~~  :D :D
s_6666_s_qd
驱动巨牛
驱动巨牛
  • 注册日期2004-08-14
  • 最后登录2006-07-11
  • 粉丝0
  • 关注0
  • 积分199分
  • 威望22点
  • 贡献值0点
  • 好评度14点
  • 原创分0分
  • 专家分0分
12楼#
发布于:2004-09-16 10:36
提点拙见,最好不要用MSComm这个控件,我以前用过,不怎么理想,还是用HANDLL hfile=CreateFile( "COM1", GENERIC_READ | GENERIC_WRITE, 0, NULL, NULL, 0, NULL);
使用ReadFile接收数据,使用WriteFile发送数据。
绝对可靠。
游客

返回顶部