labview串口通訊的深入分析.
LABVIEW的串口控制,可以通過(guò)多種方法:
本文引用地址:http://dyxdggzs.com/article/201701/337261.htm1.最基本的IN OUT 控制,LABVIEW提供了In port和Out Port兩個(gè)基本輸入輸出VI,通過(guò)它就可以直接讀寫(xiě)寄存器,我本人 做的許多并口控制設備就是利用了這兩個(gè)節點(diǎn),在計算機的DOS時(shí)代,通過(guò)IN OUT指令進(jìn)行串口通訊是唯一的選擇,現在正在做單片機的朋友都知道,單片機的串口通訊都是通過(guò)操作寄存器實(shí)現的,對于計算機的COM1,它的端口地址是0X3F8,完全可以通過(guò)它來(lái)完成串口通訊.
2.利用API的WriteFile 函數實(shí)現串口通訊,這是VC進(jìn)行串口通訊的方法.
3.利用VB提供的MSCOMM控件(這是目前用的最多的,它支持查詢(xún)和中斷兩種模式,即可以發(fā)送文本型數據(ASCII),由可以發(fā)送二進(jìn)制(BIN,實(shí)際是BYTE ARRAY)
4.利用LABVIEW特有的VISA通訊
直接控制寄存器的方法在計算機串口通訊基本看不到了.只有在單片機中還采用這種方式.
通過(guò)C51串口通訊,簡(jiǎn)單地介紹一下這種方法:
/* 發(fā)送數據函數?。?/p>
void SendData(uchar *buf)
{
uchar i;
uchar len;
len=strlen(buf); /* 取得字符串長(cháng)度*/
for(i=0;i
{
SBUF=buf[i]; /* SBUF是串口輸出REG?。?/p>
while(!TI);/* 等待發(fā)送完成?。?/p>
TI=0; /* 復位中斷標志?。?/p>
}
}
方法2直接調用API非常復雜,在LV不會(huì )采用,就不介紹了.
方法3是目前用的最多,介紹一下.
MSComm控件提供下列兩種處理通訊的方式:事件驅動(dòng)方式和查詢(xún)方式。
來(lái)源: http://dev.yesky.com/347/2636847.shtml
2.1 事件驅動(dòng)方式
事件驅動(dòng)通訊是處理串行端口交互作用的一種非常有效的方法。在許多情況下,在事件發(fā)生時(shí)需要得到通知,例如,在串口接收緩沖區中有字符,或者 Carrier Detect (CD) 或 Request To Send (RTS) 線(xiàn)上一個(gè)字符到達或一個(gè)變化發(fā)生時(shí)。在這些情況下,可以利用 MSComm 控件的 OnComm 事件捕獲并處理這些通訊事件。OnComm 事件還可以檢查和處理通訊錯誤。所有通訊事件和通訊錯誤的列表,參閱 CommEvent 屬性。在編程過(guò)程中,就可以在OnComm事件處理函數中加入自己的處理代碼。這種方法的優(yōu)點(diǎn)是程序響應及時(shí),可靠性高。每個(gè)MSComm 控件對應著(zhù)一個(gè)串行端口。如果應用程序需要訪(fǎng)問(wèn)多個(gè)串行端口,必須使用多個(gè) MSComm 控件。
?。?2 查詢(xún)方式
查詢(xún)方式實(shí)質(zhì)上還是事件驅動(dòng),但在有些情況下,這種方式顯得更為便捷。在程序的每個(gè)關(guān)鍵功能之后,可以通過(guò)檢查 CommEvent 屬性的值來(lái)查詢(xún)事件和錯誤。如果應用程序較小,并且是自保持的,這種方法可能是更可取的。例如,如果寫(xiě)一個(gè)簡(jiǎn)單的電話(huà)撥號程序,則沒(méi)有必要對每接收一個(gè)字符都產(chǎn)生事件,因為唯一等待接收的字符是調制解調器的“確定”響應。
MSComm 控件有很多重要的屬性,但首先必須熟悉幾個(gè)屬性。
CommPort | 設置并返回通訊端口號。 |
Settings | 以字符串的形式設置并返回波特率、奇偶校驗、數據位、停止位。 |
PortOpen | 設置并返回通訊端口的狀態(tài)。也可以打開(kāi)和關(guān)閉端口。 |
Input | 從接收緩沖區返回和刪除字符。 |
Output | 向傳輸緩沖區寫(xiě)一個(gè)字符串。 |
下面分別描述:
CommPort屬性:設置并返回通訊端口號。
語(yǔ)法 object.CommPort[value ] (value 一整型值,說(shuō)明端口號。)
說(shuō)明 在設計時(shí),value 可以設置成從 1 到 16 的任何數(缺省值為 1)。但是如果用 PortOpen 屬性打開(kāi)一個(gè)并不存在的端口時(shí),MSComm 控件會(huì )產(chǎn)生錯誤 68(設備無(wú)效)。
注意:必須在打開(kāi)端口之前設置 CommPort 屬性。
RThreshold 屬性:在 MSComm 控件設置 CommEvent 屬性為 comEvReceive 并產(chǎn)生 OnComm 之前,設置并返回的要接收的字符數。
語(yǔ)法:object.Rthreshold [ = value ](value 整型表達式,說(shuō)明在產(chǎn)生 OnComm 事件之前要接收的字符數。 )
說(shuō)明:當接收字符后,若 Rthreshold 屬性設置為 0(缺省值)則不產(chǎn)生 OnComm 事件。例如,設置 Rthreshold 為 1,接收緩沖區收到每一個(gè)字符都會(huì )使 MSComm 控件產(chǎn)生 OnComm 事件。
CTSHolding 屬性:確定是否可通過(guò)查詢(xún) Clear To Send (CTS) 線(xiàn)的狀態(tài)發(fā)送數據。Clear To Send 是調制解調器發(fā)送到相聯(lián)計算機的信號,指示傳輸可以進(jìn)行。該屬性在設計時(shí)無(wú)效,在運行時(shí)為只讀。
語(yǔ)法: object.CTSHolding(Boolean)
Mscomm 控件的 CTSHolding 屬性設置值:
True Clear To Send 線(xiàn)為高電平。
False Clear To Send 線(xiàn)為低電平。
說(shuō)明:如果 Clear To Send 線(xiàn)為低電平 (CTSHolding = False) 并且超時(shí)時(shí),MSComm 控件設置 CommEvent 屬性為 comEventCTSTO (Clear To Send Timeout) 并產(chǎn)生 OnComm 事件。
Clear To Send 線(xiàn)用于 RTS/CTS (Request To Send/Clear To Send)硬件握手。如果需要確定 Clear To Send 線(xiàn)的狀態(tài),CTSHolding 屬性給出一種手工查詢(xún)的方法。
詳細信息 有關(guān)握手協(xié)議,請參閱 Handshaking 屬性。
SThreshold 屬性: MSComm 控件設置 CommEvent 屬性為 comEvSend 并產(chǎn)生 OnComm 事件之前,設置并返回傳輸緩沖區中允許的最小字符數。
語(yǔ)法 object.SThreshold [ = value ]
value 整形表達式,代表在 OnComm 事件產(chǎn)生之前在傳輸緩沖區中的最小字符數。
評論