《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 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亚洲国产精品_日韩亚洲一区二区
亚洲婷婷免费| 欧美日韩在线一区二区三区| 亚洲视频日本| 日韩视频免费观看高清在线视频 | 午夜视频在线观看一区二区三区 | 国产精品久久一区二区三区| 欧美日韩网址| 欧美三级在线视频| 欧美日韩日日骚| 欧美连裤袜在线视频| 欧美激情网站在线观看| 欧美高清视频一区二区三区在线观看| 另类激情亚洲| 欧美成人综合在线| 欧美片网站免费| 欧美人妖另类| 欧美日韩美女一区二区| 欧美日韩亚洲一区二| 欧美视频在线看| 国产精品久久久久久久久免费| 欧美深夜影院| 国产精品久久久久久久久久直播| 国产精品任我爽爆在线播放 | 亚洲欧美999| 欧美伊久线香蕉线新在线| 欧美与黑人午夜性猛交久久久| 久久国产免费看| 亚洲欧洲日本国产| 艳女tv在线观看国产一区| 亚洲午夜久久久| 欧美亚洲综合久久| 久久久噜噜噜久噜久久| 欧美高清不卡在线| 欧美日韩国产精品一卡| 国产精品国产三级国产普通话99 | 国产伦精品一区二区| 国产一区二区精品久久| 亚洲承认在线| 一区二区三区高清在线| 欧美一级日韩一级| 亚洲欧洲日本专区| 亚洲专区一区| 久久中文字幕导航| 欧美日韩在线免费观看| 国产一区二区av| 亚洲三级影片| 午夜精品福利一区二区蜜股av| 亚洲第一黄网| 亚洲一区二区三区四区五区午夜 | 亚洲观看高清完整版在线观看| 亚洲人成在线播放网站岛国| 亚洲小说欧美另类婷婷| 久久狠狠婷婷| 亚洲午夜成aⅴ人片| 欧美资源在线| 欧美理论在线播放| 国产一区二区高清不卡| 日韩天天综合| 久久精品国产久精国产一老狼| 亚洲激情一区二区| 午夜在线视频一区二区区别| 麻豆精品视频在线| 国产精品社区| 亚洲高清免费视频| 亚洲欧美第一页| 亚洲精品五月天| 久久久国产精彩视频美女艺术照福利| 欧美黄色影院| 狠狠88综合久久久久综合网| 夜夜爽夜夜爽精品视频| 久久精品官网| 亚洲伊人网站| 欧美激情久久久久| 国产在线视频欧美| 亚洲一区久久久| 99视频有精品| 看片网站欧美日韩| 国产欧亚日韩视频| 日韩一区二区精品在线观看| 亚洲高清自拍| 欧美怡红院视频| 欧美视频在线视频| 亚洲激情在线播放| 欧美中日韩免费视频| 亚洲欧美精品在线| 欧美日韩国产综合视频在线| 尤物精品在线| 香蕉av福利精品导航| 亚洲综合大片69999| 欧美日韩成人一区| 亚洲国产经典视频| 久久精品官网| 久久九九免费| 国产区亚洲区欧美区| 一本大道久久a久久精品综合| 亚洲人www| 麻豆久久精品| 韩国自拍一区| 午夜日韩在线| 亚洲欧美日韩精品综合在线观看| 欧美日韩成人一区二区三区| 1204国产成人精品视频| 久久成人18免费网站| 欧美一区二区私人影院日本| 欧美午夜视频一区二区| 日韩视频在线播放| 一本大道av伊人久久综合| 欧美国产日韩一区二区三区| 原创国产精品91| 亚洲大片av| 久久免费国产精品| 国产手机视频一区二区| 亚洲欧美激情视频| 性做久久久久久久免费看| 国产精品女人毛片| 亚洲少妇自拍| 亚洲一区在线看| 国产精品久久久久久久一区探花| 日韩视频免费在线观看| 在线一区二区三区做爰视频网站| 欧美精品日韩一区| 亚洲精品视频在线看| 一本色道久久综合精品竹菊| 欧美日韩亚洲一区| 一区二区三区国产盗摄| 亚洲欧美一级二级三级| 国产乱码精品| 久久精品国产清自在天天线| 久久综合激情| 最近中文字幕日韩精品| 一区二区久久久久| 欧美三级电影网| 亚洲一区制服诱惑| 欧美专区在线观看一区| 国产一区二区视频在线观看| 久久精品夜色噜噜亚洲aⅴ| 美女精品在线| 亚洲精品乱码久久久久久日本蜜臀| 日韩视频精品| 国产精品成人久久久久| 午夜在线电影亚洲一区| 久久久久久久欧美精品| 亚洲国产精品va在线看黑人| 一本色道**综合亚洲精品蜜桃冫| 欧美日韩和欧美的一区二区| 亚洲视频1区2区| 久久爱另类一区二区小说| 一区二区三区在线高清| 亚洲精品中文字| 国产精品久久久久一区二区三区| 午夜精品一区二区三区在线| 久久亚洲春色中文字幕| 亚洲国产精品久久久| 亚洲尤物视频网| 国产一区再线| 99精品欧美| 国产欧美精品一区aⅴ影院| 亚洲第一中文字幕在线观看| 欧美精品啪啪| 亚洲欧美日韩专区| 欧美α欧美αv大片| 在线亚洲高清视频| 久久漫画官网| 日韩一区二区久久| 久久国产精品久久国产精品 | 在线一区亚洲| 国产综合在线视频| 中文国产成人精品久久一| 国产视频一区二区在线观看| 亚洲精品日产精品乱码不卡| 国产精品国产三级国产aⅴ9色| 久久av一区二区三区漫画| 欧美精品在线观看91| 亚洲欧美国内爽妇网| 欧美激情一区三区| 亚洲欧美视频在线观看| 欧美激情1区| 欧美一级视频| 欧美午夜大胆人体| 久久精品一区二区三区四区| 欧美午夜www高清视频| 久久精品视频播放| 国产精品成人观看视频免费| 亚洲国产精品传媒在线观看| 欧美无砖砖区免费| 最新高清无码专区| 国产精品一区二区三区久久| 亚洲毛片在线| 国产一级一区二区| 亚洲免费婷婷| 亚洲精品日本| 久久综合九色综合欧美就去吻| 在线一区二区日韩| 欧美成人免费小视频| 亚洲欧美一区二区三区极速播放 | 国产精品婷婷| 99日韩精品| 在线看日韩欧美| 久久国产一区| 亚洲一区二区三区精品视频|