1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關(guān)咨詢
      選擇下列產(chǎn)品馬上在線溝通
      服務(wù)時(shí)間:8:30-17:00
      你可能遇到了下面的問題
      關(guān)閉右側(cè)工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
      vb.net串口程序,net串口編程

      vb.net怎么實(shí)現(xiàn)串口傳輸文件

      Imports System

      “專業(yè)、務(wù)實(shí)、高效、創(chuàng)新、把客戶的事當(dāng)成自己的事”是我們每一個(gè)人一直以來堅(jiān)持追求的企業(yè)文化。 創(chuàng)新互聯(lián)是您可以信賴的網(wǎng)站建設(shè)服務(wù)商、專業(yè)的互聯(lián)網(wǎng)服務(wù)提供商! 專注于成都做網(wǎng)站、網(wǎng)站制作、軟件開發(fā)、設(shè)計(jì)服務(wù)業(yè)務(wù)。我們始終堅(jiān)持以客戶需求為導(dǎo)向,結(jié)合用戶體驗(yàn)與視覺傳達(dá),提供有針對(duì)性的項(xiàng)目解決方案,提供專業(yè)性的建議,創(chuàng)新互聯(lián)建站將不斷地超越自我,追逐市場(chǎng),引領(lǐng)市場(chǎng)!

      Imports System.IO.Ports

      Public Class Form1

      Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

      '獲取計(jì)算機(jī)有效串口

      Dim ports As String() = SerialPort.GetPortNames() '必須用命名空間,用SerialPort,獲取計(jì)算機(jī)的有效串口

      Dim port As String

      For Each port In ports

      portnamebox.Items.Add(port) '向combobox中添加項(xiàng)

      Next port

      '初始化界面

      VB.NET編寫 一個(gè) 多線程 串口通訊 程序

      串口通訊不需要多線程吧

      如果你執(zhí)意要學(xué)

      分開學(xué) 這個(gè)是兩個(gè)不同的概念

      串口通訊和多線程分開學(xué)

      請(qǐng)教用VB.NET向串口發(fā)送16進(jìn)制的數(shù)的方法

      應(yīng)該是你的轉(zhuǎn)換格式不正確,下面代碼就是將文本框中以一個(gè)空格隔開的十六進(jìn)制轉(zhuǎn)為字節(jié)的代碼,文本框中數(shù)字格式為:01 02 03

      Dim TestArray() As String = Split(TextBox1.Text)

      Dim hexBytes() As Byte

      ReDim hexBytes(TestArray.Length - 1)

      Dim i As Integer

      For i = 0 To TestArray.Length - 1

      hexBytes(i) = Val("h" TestArray(i))

      Next

      SerialPort.Write(hexBytes, 0, hexBytes.Length)

      如果有問題可以再聯(lián)系。

      怎樣在vb中自動(dòng)檢測(cè)到可用串口號(hào)的具體程序代碼

      j = 0

      For i = 1 To 16 Step 1

      If comISP.PortOpen = True Then '先關(guān)閉串口

      comISP.PortOpen = False

      End If

      comISP.CommPort = i

      On Error Resume Next '說明當(dāng)一個(gè)運(yùn)行時(shí)錯(cuò)誤發(fā)生時(shí),控件轉(zhuǎn)到緊接著發(fā)生錯(cuò)誤的語句之后的語句,并在此繼續(xù)運(yùn)行。訪問對(duì)象時(shí)要使用這種形式而不使用 On Error GoTo。

      comISP.PortOpen = True

      If Err.Number 8002 Then '無效的串口號(hào)。這樣可以檢測(cè)到虛擬串口,如果用Err.Number = 0的話檢測(cè)不到虛擬串口

      If j = 0 Then

      j = i

      End If

      cboPort.AddItem "COM" i '生成串口選擇列表

      End If

      comISP.PortOpen = False

      Next i

      If j = 1 Then

      cboPort.Text = "COM" j '自動(dòng)打開可用的最小串口號(hào)

      comISP.CommPort = j

      comISP.PortOpen = True

      cmdOpenCom.Caption = "關(guān)閉串口"

      shpCOM.FillColor = vbGreen

      If Err.Number = 8005 Then '串口已打開,vbExclamation '

      comISP.PortOpen = False

      cboPort.Text = ""

      cmdOpenCom.Caption = "打開串口"

      shpCOM.FillColor = vbRed

      End If

      End If

      用vb.net做串口通訊程序要調(diào)用哪些api函數(shù)?

      串口API通信函數(shù)編程

      16位串口應(yīng)用程序中,使用的16位的Windows API通信函數(shù):

      ①OpenComm()打開串口資源,并指定輸入、輸出緩沖區(qū)的大小(以字節(jié)計(jì))

      CloseComm() 關(guān)閉串口;

      例:int idComDev;

      idComDev = OpenComm("COM1", 1024, 128);

      CloseComm(idComDev);

      ②BuildCommDCB() 、setCommState()填寫設(shè)備控制塊DCB,然后對(duì)已打開的串口進(jìn)行參數(shù)配置; 例:DCB dcb;

      BuildCommDCB("COM1:2400,n,8,1", dcb);

      SetCommState(dcb);

      ③ ReadComm 、WriteComm()對(duì)串口進(jìn)行讀寫操作,即數(shù)據(jù)的接收和發(fā)送.

      例:char *m_pRecieve; int count;

      ReadComm(idComDev,m_pRecieve,count);

      Char wr[30]; int count2;

      WriteComm(idComDev,wr,count2);

      16位下的串口通信程序最大的特點(diǎn)就在于:串口等外部設(shè)備的操作有自己特有的API函數(shù);而32位程序則把串口操作(以及并口等)和文件操作統(tǒng)一起來了,使用類似的操作。

      在MFC下的32位串口應(yīng)用程序

      32位下串口通信程序可以用兩種方法實(shí)現(xiàn):利用ActiveX控件;使用API 通信函數(shù)。

      使用ActiveX控件,程序?qū)崿F(xiàn)非常簡(jiǎn)單,結(jié)構(gòu)清晰,缺點(diǎn)是欠靈活;使用API 通信函數(shù)的優(yōu)缺點(diǎn)則基本上相反。

      使用ActiveX控件:

      VC++ 6.0提供的MSComm控件通過串行端口發(fā)送和接收數(shù)據(jù),為應(yīng)用程序提供串行通信功能。使用非常方便,但可惜的是,很少有介紹MSComm控件的資料。

      ⑴.在當(dāng)前的Workspace中插入MSComm控件。

      Project菜單------Add to Project----Components and Controls-----Registered

      ActiveX Controls---選擇Components: Microsoft Communications Control,

      version 6.0 插入到當(dāng)前的Workspace中。

      結(jié)果添加了類CMSComm(及相應(yīng)文件:mscomm.h和mscomm.cpp )。

      ⑵.在MainFrm.h中加入MSComm控件。

      protected:

      CMSComm m_ComPort;

      在Mainfrm.cpp::OnCreare()中:

      DWORD style=WS_VISIBLE|WS_CHILD;

      if (!m_ComPort.Create(NULL,style,CRect(0,0,0,0),this,ID_COMMCTRL)){

      TRACE0("Failed to create OLE Communications Control\n");

      return -1; // fail to create

      }

      ⑶.初始化串口

      m_ComPort.SetCommPort(1); //選擇COM?

      m_ComPort. SetInBufferSize(1024); //設(shè)置輸入緩沖區(qū)的大小,Bytes

      m_ComPort. SetOutBufferSize(512); //設(shè)置輸入緩沖區(qū)的大小,Bytes//

      if(!m_ComPort.GetPortOpen()) //打開串口

      m_ComPort.SetPortOpen(TRUE);

      m_ComPort.SetInputMode(1); //設(shè)置輸入方式為二進(jìn)制方式

      m_ComPort.SetSettings("9600,n,8,1"); //設(shè)置波特率等參數(shù)

      m_ComPort.SetRThreshold(1); //為1表示有一個(gè)字符引發(fā)一個(gè)事件

      m_ComPort.SetInputLen(0);

      ⑷.捕捉串口事項(xiàng)。MSComm控件可以采用輪詢或事件驅(qū)動(dòng)的方法從端口獲取數(shù)據(jù)。我們介紹比較使用的事件驅(qū)動(dòng)方法:有事件(如接收到數(shù)據(jù))時(shí)通知程序。在程序中需要捕獲并處理這些通訊事件。

      在MainFrm.h中:

      protected:

      afx_msg void OnCommMscomm();

      DECLARE_EVENTSINK_MAP()

      在MainFrm.cpp中:

      BEGIN_EVENTSINK_MAP(CMainFrame,CFrameWnd )

      ON_EVENT(CMainFrame,ID_COMMCTRL,1,OnCommMscomm,VTS_NONE) //映射ActiveX控件事件

      END_EVENTSINK_MAP()

      ⑸.串口讀寫. 完成讀寫的函數(shù)的確很簡(jiǎn)單,GetInput()和SetOutput()就可。兩個(gè)函數(shù)的原型是:

      VARIANT GetInput();及 void SetOutput(const VARIANT newValue);都要使用VARIANT類型(所有Idispatch::Invoke的參數(shù)和返回值在內(nèi)部都是作為VARIANT對(duì)象處理的)。

      無論是在PC機(jī)讀取上傳數(shù)據(jù)時(shí)還是在PC機(jī)發(fā)送下行命令時(shí),我們都習(xí)慣于使用字符串的形式(也可以說是數(shù)組形式)。查閱VARIANT文檔知道,可以用BSTR表示字符串,但遺憾的是所有的BSTR都是包含寬字符,即使我們沒有定義_UNICODE_UNICODE也是這樣! WinNT支持寬字符, 而Win95并不支持。為解決上述問題,我們?cè)趯?shí)際工作中使用CbyteArray,給出相應(yīng)的部分程序如下:

      void CMainFrame::OnCommMscomm(){

      VARIANT vResponse; int k;

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

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

      if(k0) {

      vResponse=m_commCtrl.GetInput(); //read

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

      } // 接收到字符,MSComm控件發(fā)送事件 }

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

      }

      void CMainFrame::OnCommSend() {

      。。。。。。。。 // 準(zhǔn)備需要發(fā)送的命令,放在TxData[]中

      CByteArray array;

      array.RemoveAll();

      array.SetSize(Count);

      for(i=0;iCount;i++)

      array.SetAt(i, TxData[i]);

      m_ComPort.SetOutput(COleVariant(array)); // 發(fā)送數(shù)據(jù) }

      二 使用32位的API 通信函數(shù):

      ⑴.在中MainFrm.cpp定義全局變量

      HANDLE hCom; // 準(zhǔn)備打開的串口的句柄

      HANDLE hCommWatchThread ;//輔助線程的全局函數(shù)

      ⑵.打開串口,設(shè)置串口

      hCom =CreateFile( "COM2", GENERIC_READ | GENERIC_WRITE, // 允許讀寫

      0, // 此項(xiàng)必須為0

      NULL, // no security attrs

      OPEN_EXISTING, //設(shè)置產(chǎn)生方式

      FILE_FLAG_OVERLAPPED, // 我們準(zhǔn)備使用異步通信

      NULL );

      我使用了FILE_FLAG_OVERLAPPED結(jié)構(gòu)。這正是使用API實(shí)現(xiàn)非阻塞通信的關(guān)鍵所在。

      ASSERT(hCom!=INVALID_HANDLE_VALUE); //檢測(cè)打開串口操作是否成功

      SetCommMask(hCom, EV_RXCHAR|EV_TXEMPTY );//設(shè)置事件驅(qū)動(dòng)的類型

      SetupComm( hCom, 1024,512) ; //設(shè)置輸入、輸出緩沖區(qū)的大小

      PurgeComm( hCom, PURGE_TXABORT | PURGE_RXABORT | PURGE_TXCLEAR

      | PURGE_RXCLEAR ); //清干凈輸入、輸出緩沖區(qū)

      COMMTIMEOUTS CommTimeOuts ; //定義超時(shí)結(jié)構(gòu),并填寫該結(jié)構(gòu)

      …………

      SetCommTimeouts( hCom, CommTimeOuts ) ;//設(shè)置讀寫操作所允許的超時(shí)

      DCB dcb ; // 定義數(shù)據(jù)控制塊結(jié)構(gòu)

      GetCommState(hCom, dcb ) ; //讀串口原來的參數(shù)設(shè)置

      dcb.BaudRate =9600; dcb.ByteSize =8; dcb.Parity = NOPARITY;

      dcb.StopBits = ONESTOPBIT ;dcb.fBinary = TRUE ;dcb.fParity = FALSE;

      SetCommState(hCom, dcb ) ; //串口參數(shù)配置

      上述的COMMTIMEOUTS結(jié)構(gòu)和DCB都很重要,實(shí)際工作中需要仔細(xì)選擇參數(shù)。

      ⑶啟動(dòng)一個(gè)輔助線程,用于串口事件的處理。

      Windows提供了兩種線程,輔助線程和用戶界面線程。輔助線程沒有窗口,所以它沒有自己的消息循環(huán)。但是輔助線程很容易編程,通常也很有用。

      在次,我們使用輔助線程。主要用它來監(jiān)視串口狀態(tài),看有無數(shù)據(jù)到達(dá)、通信有無錯(cuò)誤;而主線程則可專心進(jìn)行數(shù)據(jù)處理、提供友好的用戶界面等重要的工作。

      hCommWatchThread=

      CreateThread( (LPSECURITY_ATTRIBUTES) NULL, //安全屬性

      0,//初始化線程棧的大小,缺省為與主線程大小相同

      (LPTHREAD_START_ROUTINE)CommWatchProc, //線程的全局函數(shù)

      GetSafeHwnd(), //此處傳入了主框架的句柄

      0, dwThreadID );

      ASSERT(hCommWatchThread!=NULL);

      ⑷為輔助線程寫一個(gè)全局函數(shù),主要完成數(shù)據(jù)接收的工作。請(qǐng)注意OVERLAPPED結(jié)構(gòu)的使用,以及怎樣實(shí)現(xiàn)了非阻塞通信。

      UINT CommWatchProc(HWND hSendWnd){

      DWORD dwEvtMask=0 ;

      SetCommMask( hCom, EV_RXCHAR|EV_TXEMPTY );//有哪些串口事件需要監(jiān)視?

      WaitCommEvent( hCom, dwEvtMask, os );// 等待串口通信事件的發(fā)生

      檢測(cè)返回的dwEvtMask,知道發(fā)生了什么串口事件:

      if ((dwEvtMask EV_RXCHAR) == EV_RXCHAR){ // 緩沖區(qū)中有數(shù)據(jù)到達(dá)

      COMSTAT ComStat ; DWORD dwLength;

      ClearCommError(hCom, dwErrorFlags, ComStat ) ;

      dwLength = ComStat.cbInQue ; //輸入緩沖區(qū)有多少數(shù)據(jù)?

      if (dwLength 0) { BOOL fReadStat ;

      fReadStat = ReadFile( hCom, lpBuffer,dwLength, dwBytesRead,READ_OS( npTTYInfo ) ); //讀數(shù)據(jù)

      注:我們?cè)贑reareFile()時(shí)使用了FILE_FLAG_OVERLAPPED,現(xiàn)在ReadFile()也必須使用

      LPOVERLAPPED結(jié)構(gòu).否則,函數(shù)會(huì)不正確地報(bào)告讀操作已完成了.

      使用LPOVERLAPPED結(jié)構(gòu), ReadFile()立即返回,不必等待讀操作完成,實(shí)現(xiàn)非阻塞

      通信.此時(shí), ReadFile()返回FALSE, GetLastError()返回ERROR_IO_PENDING.

      if (!fReadStat){

      if (GetLastError() == ERROR_IO_PENDING){

      while(!GetOverlappedResult(hCom,READ_OS( npTTYInfo ), dwBytesRead, TRUE )){

      dwError = GetLastError();

      if(dwError == ERROR_IO_INCOMPLETE) continue;//緩沖區(qū)數(shù)據(jù)沒有讀完,繼續(xù)

      …… ……

      ::PostMessage((HWND)hSendWnd,WM_NOTIFYPROCESS,0,0);//通知主線程,串口收到數(shù)據(jù)}

      所謂的非阻塞通信,也即異步通信。是指在進(jìn)行需要花費(fèi)大量時(shí)間的數(shù)據(jù)讀寫操作(不僅僅是指串行通信操作)時(shí),一旦調(diào)用ReadFile()、WriteFile(), 就能立即返回,而讓實(shí)際的讀寫操作在后臺(tái)運(yùn)行;相反,如使用阻塞通信,則必須在讀或?qū)懖僮魅客瓿珊蟛拍芊祷亍S捎诓僮骺赡苄枰我忾L(zhǎng)的時(shí)間才能完成,于是問題就出現(xiàn)了。

      非常阻塞操作還允許讀、寫操作能同時(shí)進(jìn)行(即重疊操作?),在實(shí)際工作中非常有用。

      要使用非阻塞通信,首先在CreateFile()時(shí)必須使用FILE_FLAG_OVERLAPPED;然后在 ReadFile()時(shí)lpOverlapped參數(shù)一定不能為NULL,接著檢查函數(shù)調(diào)用的返回值,調(diào)用GetLastError(),看是否返回ERROR_IO_PENDING。如是,最后調(diào)用GetOverlappedResult()返回重疊操作(overlapped operation)的結(jié)果;WriteFile()的使用類似。

      ⑸.在主線程中發(fā)送下行命令。

      BOOL fWriteStat ; char szBuffer[count];

      …………//準(zhǔn)備好發(fā)送的數(shù)據(jù),放在szBuffer[]中

      fWriteStat = WriteFile(hCom, szBuffer, dwBytesToWrite,

      dwBytesWritten, WRITE_OS( npTTYInfo ) ); //寫數(shù)據(jù)

      //我在CreareFile()時(shí)使用了FILE_FLAG_OVERLAPPED,現(xiàn)在WriteFile()也必須使用LPOVERLAPPED結(jié)構(gòu).否則,函數(shù)會(huì)不正確地報(bào)告寫操作已完成了.

      使用LPOVERLAPPED結(jié)構(gòu),WriteFile()立即返回,不必等待寫操作完成,實(shí)現(xiàn)非阻塞 通信.此時(shí), WriteFile()返回FALSE, GetLastError()返回ERROR_IO_PENDING.

      int err=GetLastError();

      if (!fWriteStat) {

      if(GetLastError() == ERROR_IO_PENDING){

      while(!GetOverlappedResult(hCom, WRITE_OS( npTTYInfo ),

      dwBytesWritten, TRUE )) {

      dwError = GetLastError();

      if(dwError == ERROR_IO_INCOMPLETE){// normal result if not finished

      dwBytesSent += dwBytesWritten; continue; }

      ......................

      //我使用了多線程技術(shù),在輔助線程中監(jiān)視串口,有數(shù)據(jù)到達(dá)時(shí)依靠事件驅(qū)動(dòng),讀入數(shù)據(jù)并向主線程報(bào)告(發(fā)送數(shù)據(jù)在主線程中,相對(duì)說來,下行命令的數(shù)據(jù)總是少得多);并且,WaitCommEvent()、ReadFile()、WriteFile()都使用了非阻塞通信技術(shù),依靠重疊(overlapped)讀寫操作,讓串口讀寫操作在后臺(tái)運(yùn)行。


      文章標(biāo)題:vb.net串口程序,net串口編程
      文章分享:http://www.ef60e0e.cn/article/phhpeg.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        会宁县| 广元市| 罗田县| 星座| 太谷县| 罗城| 闻喜县| 潞城市| 兰州市| 清徐县| 宝坻区| 临桂县| 北票市| 丰县| 庆城县| 偃师市| 中西区| 临澧县| 得荣县| 靖江市| 保亭| 嘉鱼县| 长寿区| 南部县| 梨树县| 潼南县| 临西县| 云和县| 宜章县| 军事| 景谷| 灯塔市| 大理市| 临夏市| 襄樊市| 天镇县| 高州市| 区。| 长垣县| 宜兴市| 台州市|