《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > C#下串口通信編程的開發和擴展
C#下串口通信編程的開發和擴展
來源:微型機與應用2014年第6期
朱英翔,朱福民,劉炎鳴
(上海海事大學 物流工程學院,上海201306)
摘要: 采用C#編程創建窗體應用程序,結合實際應用,實現工業數據的串口的采集處理。利用combobox控件進行串口參數預設。完成串口數據采集,通過實例化graphic類在picturebox控件中實現數據的圖樣化表達。在數據的閾值報警和Excel數據保存方面進行了研究,較好地解決了生產實踐中的關鍵問題。
Abstract:
Key words :

摘  要: 采用C#編程創建窗體應用程序,結合實際應用,實現工業數據的串口的采集處理。利用combobox控件進行串口參數預設。完成串口數據采集,通過實例化graphic類在picturebox控件中實現數據的圖樣化表達。在數據的閾值報警和Excel數據保存方面進行了研究,較好地解決了生產實踐中的關鍵問題。
關鍵詞: C#編程;串口;數據處理

    在工業現場進行作業和實驗時,需要對一些工業設備的狀態進行監測。為了方便快速搭建檢測平臺、達到靈活操作的目的,可以采用帶微控制器的傳感器采集所需要的狀態信息,通過串口直接把這些信息傳送給個人電腦,然后在電腦上編程接收處理數據。
    目前,大多數微控制器芯片(如8051系列單片機)都支持串口的輸入輸出[1-2],本文研究使用個人電腦外接USB轉串口線來接收信息,通過C#編程,運用電腦做上位機來完成采集分析記錄工作。近年來,C#編程已經幫助企業解決了很多工業問題,同時在串口通信領域也有很好的應用前景。
1 Visual Studio數據串口通信
    串口是一種比較簡單的通信形式。介紹通過Visual Studio 2010的C#進行編程使得PC能接收串口發來的信息。
    C#是一種強勁的編程語言[3],且Visual Studio也封裝了串口收發的模塊,這易于實現串口數據采集和處理。這里運用C#創建Windows窗體應用程序,首先在窗體加載時觸發串口的讀取功能,遍歷電腦的每一個串口。在窗體應用程序的combobox預設一系列與串口通信有關的參數,根據所連接的單片機來預先選擇正確的參數,通過Button的click屬性來讀取這些參數打開新的串口連接。隨后串口數據送入電腦虛擬的緩存區,完成數據讀取工作。
private void Form1_Load(object sender, EventArgs e)
//加載窗體
    {
      comport.ReceivedBytesThreshold=1;
//確定了觸發DataReceived事件的閾值,
      foreach(string com in System.IO.Ports.SerialPort.Get-
PortNames())
//遍歷并識別所有串口,之后添加至combobox供選擇
    }

        comport.BaudRate = int.Parse(cmbBaudRate.Text);
//int.Parse()函數將控件中的字符串轉化成了整型數
        comport.DataBits = int.Parse(cmbDataBits.Text);
// 設置各種串口參數
        comport.StopBits=(StopBits)Enum.Parse(typeof
(StopBits), cmbStopBits.Text);
        comport.Parity=(Parity)Enum.Parse(typeof(Parity),
cmbParity.Text);
        comport.PortName=cmbPortName.Text;
        comport.Open();//開啟串口
        comport.DiscardInBuffer();
        comport.DiscardOutBuffer();
2 數據的圖表顯示
    在接收到串口數據之后,還要對串口讀入的字節串進行分析判斷,這里需要運用C#的控制流來分析字節串的內容,分離出自己需要的字節,再對應各種傳感器的信號值與實際監測值的關系單位化后得到實際的工業信息。為了能建立操作指導控制系統[4],方便監測人員更加直觀地觀測工業設備的狀態變化,本文通過C#編程實現數據圖表的繪制。在Visual Studio中調用其中的graphic類來操作,通過實例化graphic類,采用畫直線的方式建立數據實時的折線圖和柱狀圖。
    (1)折線圖的畫法
    在picturebox控件中,以次數為橫坐標,單位化后的數據為縱坐標不斷生成點,依次畫直線連接前后生成的兩點,待畫滿圖框后自動清屏,實現數據的折線圖顯示。圖1為用該方法記錄某次加速度數據的效果。
    (2)柱狀圖的畫法
    在picturebox控件中,以采集數據的序號確立橫坐標,單位化后的數據為縱坐標,采取在該坐標點至picturebox底部畫粗線,該點至picturebox頂部畫與picturebox背景色相同的粗線的方式來刷新柱狀圖數據。這種圖像化的顯示可以為工業現場進行直觀、多維的指導操作。圖2為用該方法畫某次加速度數據的效果。


3 數據報警
    一般地,采集的數據值都有一個安全范圍,超出了安全范圍就會不利于設備的正常使用,所以要采取報警機制來提醒現場人員。這里通過Visual Studio自帶的控件——聲音控件,用if語句判斷,如果在數據值設定的閾值范圍外就觸發報警音樂。使用PC自帶的揚聲器發出警報聲。
System.Media.SoundPlayer startSoundPlayer=new
System.Media.SoundPlayer(@"C:\Windows\Media\tada.wav");
//實例化音樂并選擇報警用音樂

    if(ring == 100 && number1 % 5 == 0)
//當超出安全范圍時ring置為100,
為了降低分辨率,每5個數據判斷一次
        {
          startSoundPlayer.Play();//出聲
        }
4 數據采集記錄
    數據的采集和記錄是分析數據必不可少的過程。通過串口采集來的數據,往往刷新率不會很高,最大的波特率為115 200。正因為這樣,使用Visual Studio開發編程,在PC上就能實現串口數據的采集記錄。
    一般地,C#開發人員會優先想到使用文件流來導出數據,但是為了數據查看簡便,還有利于將來分析,本文采用連接office辦公自動化軟件中的Excel[5],因為Excel表格直觀,且后續有分析計算的功能。在Visual Studio 2010.net框架下C#編程是完全可以來自動化Excel 2007表格。
    首先要在項目中添加引用Microsoft Excel 12.0 object library,這樣就可以調出Excel類。
    在程序開啟時就加載Excel應用,創建配置Excel選項:
    object missing = Type.Missing;
    Excel.Application oXL = null;//加載Excel應用
    Excel.Workbooks oWBs = null;
    Excel.Workbook oWB = null;
    Excel.Worksheet oSheet = null;
    Excel.Range oCells = null;//確立單元格
    利用C#的try…catch語句預先在讀取數據的代碼段中設立好向Excel單元格內填數據的語句。當需要記錄時通過button控件觸發創建新的Excel文檔,這樣即執行try{}中的語句往單元格記錄數據:
    try { oCells[row / 3, index] = stringx; row += 1; }
//在指定的單元格中記錄xyz三組數據,
并更改單元格坐標
    catch { }
    更改單元格坐標就不斷繼續向Excel里填充由串口接收的數據。
    通過簡單設置名為excel和save的兩個button控件就可實現建立Excel表格填充數據和觸發保存Excel文檔的功能。圖3是某次加速度數據采集時生成的Excel文檔。

    利用開發效率高的Visual Studio來編寫上位機程序,在串口數據采集處理方面有著很好的優勢,它簡化了開發負擔,簡化了設備。便于一般工程系統的數據采集和處理。
參考文獻
[1] 童長飛.C8051F系列單片機開發與C語言編程[M].北京:北京航空航天大學出版社,2005.
[2] 張毅剛,彭喜元.單片機原理及接口技術[M].北京:人民郵電出版社,2008.
[3] STELLMAN A,GREENE J.Head First C#中文版[M].林琪,譯.北京:中國電力出版社,2010.
[4] 潘新民,王燕芳.微型計算機控制技術[M].北京:人民郵電出版社,1999.
[5] 微軟.C# app automates Excel[CP/OL].[2012-3-2].http://  code.msdn.microsoft.com/CSAutomateExcel-7f89a439.

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲欧美国产另类| 亚洲精品国精品久久99热| 一区在线电影| 国产婷婷精品| 国产精品久久久久婷婷| 欧美日韩不卡视频| 欧美理论视频| 欧美激情在线免费观看| 欧美69wwwcom| 欧美大胆人体视频| 欧美成人国产va精品日本一级| 久久久久九九九| 久久九九久久九九| 久久久精品国产免大香伊| 久久国产精品一区二区三区| 欧美在线视频导航| 欧美一区三区三区高中清蜜桃| 欧美一级视频| 久久精品亚洲| 麻豆av一区二区三区| 噜噜噜91成人网| 欧美成人高清视频| 欧美人成网站| 欧美色视频一区| 国产精品国内视频| 国产农村妇女毛片精品久久麻豆| 国产人成精品一区二区三| 国产日韩久久| 精品动漫av| 亚洲国产婷婷| 一区二区三区福利| 亚洲一区二区动漫| 欧美一区二视频| 亚洲欧洲三级电影| 一区二区三区**美女毛片| 亚洲一区二区三区乱码aⅴ| 午夜在线观看免费一区| 久久久精品日韩| 欧美成人有码| 欧美日韩第一区| 国产精品久久久久久久第一福利| 国产精品视频一区二区高潮| 国产女人水真多18毛片18精品视频| 国产一区二区三区在线播放免费观看 | 欧美成人免费全部观看天天性色| 欧美激情一区二区三区在线| 欧美视频在线观看 亚洲欧| 国产精品一区二区在线观看| 国内精品视频在线观看| 亚洲破处大片| 午夜精品一区二区三区在线| 亚洲黄色在线看| 亚洲一区二区欧美日韩| 久久国产日韩| 欧美国产综合视频| 国产精品亚洲综合色区韩国| 在线免费观看欧美| 亚洲一级片在线观看| 亚洲国产欧美一区| 亚洲主播在线观看| 久久夜色精品亚洲噜噜国产mv| 欧美日本亚洲| 国产在线国偷精品产拍免费yy| 亚洲精品美女| 欧美一区二区三区久久精品茉莉花 | 国产精品h在线观看| 国内精品久久久久久久果冻传媒| 亚洲精品欧美专区| 欧美一区亚洲一区| 中日韩午夜理伦电影免费| 久久精品一区二区三区不卡| 欧美日韩一区不卡| 激情一区二区| 亚洲伊人伊色伊影伊综合网| 亚洲日本理论电影| 欧美一区二区三区视频| 欧美韩日精品| 国产专区欧美精品| 亚洲视频axxx| 亚洲三级色网| 久久精品免费电影| 国产精品成人播放| 亚洲欧洲精品天堂一级| 欧美中文字幕在线视频| 亚洲免费视频中文字幕| 免费亚洲一区| 国产原创一区二区| 亚洲图片激情小说| 一区二区三区四区精品| 蜜臀91精品一区二区三区| 国产婷婷成人久久av免费高清 | 亚洲午夜视频在线观看| 亚洲精品九九| 久久综合电影| 国产视频精品va久久久久久| 亚洲图片在线观看| 一区二区三区久久久| 女人香蕉久久**毛片精品| 国产视频一区欧美| 亚洲免费影视第一页| 亚洲一本大道在线| 欧美日韩一区二区三区四区五区| 亚洲国产你懂的| 亚洲国产成人精品久久久国产成人一区 | 激情欧美国产欧美| 亚洲欧美在线看| 亚洲女人天堂成人av在线| 欧美日韩国产影院| 亚洲欧洲免费视频| 亚洲精品一二三区| 欧美大秀在线观看| 在线日韩电影| 亚洲黄色性网站| 久久欧美肥婆一二区| 国产一区99| 欧美一区二区三区久久精品| 久久国产天堂福利天堂| 国产欧美日韩免费看aⅴ视频| 亚洲一区欧美一区| 午夜免费日韩视频| 国产精品日韩在线| 亚洲午夜一区| 午夜精品国产| 国产精品永久免费观看| 亚洲欧美国内爽妇网| 欧美在线91| 国产综合网站| 亚洲第一精品福利| 农夫在线精品视频免费观看| 在线观看日韩专区| 1024欧美极品| 久久er99精品| 欧美一区三区二区在线观看| 国产精品久久久久久久久果冻传媒| 亚洲青涩在线| 一区二区高清| 欧美午夜精品伦理| 一区二区三区欧美亚洲| 亚洲中字在线| 国产精品一区免费观看| 午夜精品久久久久久久久久久| 欧美一区二区三区四区在线观看地址 | 一区在线播放视频| 亚洲精品视频免费| 一区二区三区日韩欧美| 欧美日韩在线一区| 亚洲一区在线直播| 久久久www| 在线精品国产欧美| 亚洲精品一区二区三区四区高清| 欧美日韩黄视频| 亚洲一区二区三区久久| 久久精品视频网| 亚洲第一区在线| 亚洲免费观看| 国产精品免费电影| 欧美在线视频网站| 欧美aa国产视频| 99热免费精品| 欧美一区二区三区四区夜夜大片| 国产综合视频| 日韩亚洲国产精品| 国产精品久久久久久久免费软件 | 在线观看91精品国产入口| 亚洲精品一区二区三区蜜桃久| 欧美色大人视频| 欧美一级片一区| 欧美刺激午夜性久久久久久久| 99综合视频| 久久精品二区| 亚洲毛片在线观看| 久久成人免费视频| 亚洲国产欧美国产综合一区 | 欧美精品久久一区二区| 亚洲尤物视频在线| 欧美成人一区二区三区片免费| 亚洲视频中文字幕| 麻豆freexxxx性91精品| 亚洲视频中文| 欧美黄色aa电影| 欧美一区二区三区在线看| 欧美激情视频网站| 午夜精品亚洲| 欧美日韩精品欧美日韩精品一| 欧美一区二区三区在| 欧美日一区二区在线观看| 久久精品国产99国产精品| 欧美日韩综合一区| 亚洲激情啪啪| 国产欧美日本| 中文国产一区| 亚洲电影自拍| 欧美在线观看视频在线| 亚洲精品视频免费在线观看| 久久久欧美一区二区| 亚洲香蕉在线观看| 欧美国产日韩一区二区三区| 亚洲欧美日韩精品久久亚洲区 | 亚洲欧美激情精品一区二区| 欧美猛交免费看|