主頁 > .NET開發 > 新人首帖 關于串口通信的一點小疑問

新人首帖 關于串口通信的一點小疑問

2020-09-17 06:46:48 .NET開發

初來貴地
新人第一帖~~~望能得到眾神回復為盼

初學者 做了一個小程式,涉及到一個串口設備的簡單通信
主要就是采值,用了幾個市面常用的串口工具都能和設備正常通信(參照圖片),
找到了其中的串口精靈1.0的原始碼 放到軟體里 不知道為什么就接受不到資料了
有人知道為什么嗎?是代碼的原因嗎
或者有沒人大神共享一份能用的串口原始碼啊?
通信失敗的截圖


使用封裝好的串口工具都能正常通信


uj5u.com熱心網友回復:

代碼不完整,不知道你怎么寫的。用的是serialport控制元件么

uj5u.com熱心網友回復:

看你的代碼是讀取磁盤檔案轉為byte,然后用串口發送(接受也是,把串口發送的byte保存到檔案);但你的測驗截圖又是只是一些字符發送; 關于串口通訊,VS里就有很好的例子啊。看幫助檔案就能找到。
做一個簡單的執行緒就可以了。
[

    '打開串口連接
    Private Sub Button_Open_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button_Open.Click
        SerialPort1.Open() '打開串口
        Dim SerialComm = New Threading.Thread(New Threading.ThreadStart(AddressOf Sp_Receiving))
        SerialComm.Start()      '開執行緒
    End Sub


    '接收資料
    Private Sub Sp_Receiving()
        Dim strIncoming As String
        If SerialPort1.BytesToRead > 0 Then
            strIncoming = SerialPort1.ReadExisting.ToString '讀取緩沖區中的資料
            SerialPort1.DiscardInBuffer()
            ListBox1.Items.Add(strIncoming)
        End If
    End Sub

uj5u.com熱心網友回復:

Imports System
Imports System.IO

Public Class frmMain
    Public HexSendFlag As Boolean = False
    Public HexRecieveFlag As Boolean = False
    Public AutoClearFlag As Boolean = False

    Delegate Sub RecieveRefreshMethodDelegate(ByVal [text] As String) '宣告委托
    Dim RecieveRefresh As New RecieveRefreshMethodDelegate(AddressOf RecieveRefreshMethod) '定義一個委托實體

    Sub RecieveRefreshMethod(ByVal str As String) '定義一個實體方法
        ShowRecieveData(str)
    End Sub

    Private Sub ShowRecieveData(ByVal str As String)
        On Error GoTo Err

        TextBoxRecieve.Text += str

        Exit Sub
Err:    MsgBox("資料接識訓顯示錯誤!" + vbNewLine + ErrorToString())
    End Sub

    Private Sub SerialPortInit()
        '串口設定GUI初始化
        Dim I As Integer
        ComboBoxPortName.BeginUpdate()
        For I = 1 To 50
            ComboBoxPortName.Items.Add("COM" + I.ToString)
        Next
        ComboBoxPortName.EndUpdate()

        ComboBoxPortName.SelectedIndex = 0
        ComboBoxBaudRate.SelectedIndex = 11
        ComboBoxParity.SelectedIndex = 0
        ComboBoxDataBits.SelectedIndex = 0
        ComboBoxStopBits.SelectedIndex = 0

        SerialPort.Encoding = System.Text.Encoding.Default

    End Sub

    Private Sub frmMain_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        SerialPortInit()
        ButtonOpenClose_Click(Nothing, Nothing)
        BarWorkStatus.Text = "軟體就緒。"
        BarWorkStatus.Visible = True
    End Sub

    Private Sub frmMain_Closing(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Closing
        If SerialPort.IsOpen Then SerialPort.Close()
    End Sub

    Private Sub ComboBoxPortName_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ComboBoxPortName.SelectedIndexChanged
        If SerialPort.IsOpen = True Then
            ButtonOpenClose_Click(Nothing, Nothing)
            If SerialPort.IsOpen = False Then
                SerialPort.PortName = ComboBoxPortName.Text
                ButtonOpenClose_Click(Nothing, Nothing)
            End If
        Else
            SerialPort.PortName = ComboBoxPortName.Text
        End If
    End Sub

    Private Sub ComboBoxBaudRate_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ComboBoxBaudRate.SelectedIndexChanged
        SerialPort.BaudRate = Val(ComboBoxBaudRate.Text)
    End Sub

    Private Sub ComboBoxParity_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ComboBoxParity.SelectedIndexChanged
        SerialPort.Parity = ComboBoxParity.SelectedIndex
    End Sub

    Private Sub ComboBoxDataBits_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ComboBoxDataBits.SelectedIndexChanged
        SerialPort.DataBits = Val(ComboBoxDataBits.Text)
    End Sub

    Private Sub ComboBoxStopbits_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ComboBoxStopBits.SelectedIndexChanged
        SerialPort.StopBits = ComboBoxStopBits.SelectedIndex + 1
    End Sub

    Private Sub ButtonOpenClose_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ButtonOpenClose.Click
        On Error GoTo Err
        If ButtonOpenClose.Text = "打開串口(&O)" Then
            If SerialPort.IsOpen = True Then SerialPort.Close()
            SerialPort.Open()
            ButtonOpenClose.Text = "關閉串口(&O)"
            LabelCOMStatus.Text = "串口已打開"
            LabelCOMStatus.ForeColor = Color.Green
        Else
            If CheckBoxAutoSend.Checked = True Then
                MsgBox("請先關閉自動發送!")
                Exit Sub
            End If
            If SerialPort.IsOpen = True Then SerialPort.Close()
            ButtonOpenClose.Text = "打開串口(&O)"
            LabelCOMStatus.Text = "串口已關閉"
            LabelCOMStatus.ForeColor = Color.Red
        End If
        Exit Sub

Err:    MsgBox("串口不存在或已被占用!" + vbNewLine + ErrorToString())

    End Sub

    Private Sub CheckBoxHexRecieve_CheckedChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles CheckBoxHexRecieve.CheckedChanged
        HexRecieveFlag = CheckBoxHexRecieve.Checked
    End Sub

    Private Sub CheckBoxHexSend_CheckedChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles CheckBoxHexSend.CheckedChanged
        HexSendFlag = CheckBoxHexSend.Checked
    End Sub

    Private Sub ButtonSendData_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ButtonSendData.Click
        On Error GoTo Err
        Dim outDataBuf As String = TextBoxSend.Text

        If outDataBuf = "" Then Exit Sub

        If SerialPort.IsOpen = True Then
            If HexSendFlag = True Then
                '-----------十六進制發送------------
                outDataBuf = outDataBuf.Replace(" ", "") '清除空格與回車
                outDataBuf = outDataBuf.Replace(vbNewLine, "")
                If outDataBuf.Length Mod 2 <> 0 Then
                    MsgBox("請輸入正確的十六進制數,用空格和回車隔開。")
                    Exit Sub
                End If
                Dim outBytes(outDataBuf.Length / 2 - 1) As Byte
                For I As Integer = 1 To outDataBuf.Length - 1 Step 2
                    outBytes((I - 1) / 2) = Val("&H" + Mid(outDataBuf, I, 2))
                Next
                SerialPort.Write(outBytes, 0, outDataBuf.Length / 2)
                BarCountTx.Text = Val(BarCountTx.Text) + outDataBuf.Length / 2
            Else
                '-------------文本發送--------------
                SerialPort.Write(outDataBuf)
                BarCountTx.Text = Val(BarCountTx.Text) + outDataBuf.Length '發送位元組計數
            End If
        Else
            MsgBox("串口未打開,請先打開串口。")
        End If

        Exit Sub
Err:    MsgBox("資料輸入或發送錯誤!" + vbNewLine + ErrorToString())

    End Sub

    Private Sub ButtonClearSendBuf_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ButtonClearSendBuf.Click
        TextBoxSend.Text = ""
    End Sub

    Private Sub ButtonClearRecieveBuf_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ButtonClearRecieveBuf.Click
        TextBoxRecieve.Text = ""
    End Sub

    Private Sub SerialPort_DataReceived(ByVal sender As Object, ByVal e As System.IO.Ports.SerialDataReceivedEventArgs) Handles SerialPort.DataReceived

        If HexRecieveFlag Then
            '-----------十六進制顯示------------
            Dim inDataLen As Integer = SerialPort.BytesToRead()
            If inDataLen > 0 Then
                Dim inBytes(inDataLen - 1) As Byte, bytes As Byte
                Dim strHex As String = ""
                SerialPort.Read(inBytes, 0, inDataLen)
                For Each bytes In inBytes
                    strHex = strHex + [String].Format("{0:X2} ", bytes)
                Next
                TextBoxRecieve.Invoke(RecieveRefresh, strHex)
                BarCountRx.Text = (Val(BarCountRx.Text) + inDataLen).ToString '接收位元組計數
            End If
        Else
            '-------------文本顯示--------------
            Dim str As String
            str = SerialPort.ReadExisting
            TextBoxRecieve.Invoke(RecieveRefresh, str)
            BarCountRx.Text = (Val(BarCountRx.Text) + str.Length).ToString '接收位元組計數
        End If
        
        'TextBoxRecieve.AppendText(stringout)

    End Sub

    Private Sub TextBoxRecieve_TextChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles TextBoxRecieve.TextChanged
        TextBoxRecieve.SelectionStart = TextBoxRecieve.Text.Length
        TextBoxRecieve.ScrollToCaret()

        If AutoClearFlag = True And TextBoxRecieve.Lines.Length > TextBoxRecieve.Height / TextBoxRecieve.Font.Height * 3 Then
            TextBoxRecieve.Text = ""
        End If
    End Sub

    Private Sub CheckBoxAutoClear_CheckedChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles CheckBoxAutoClear.CheckedChanged
        AutoClearFlag = CheckBoxAutoClear.Checked
    End Sub

    Private Sub TimerAutoSend_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles TimerAutoSend.Tick
        ButtonSendData_Click(Nothing, Nothing)
    End Sub

    Private Sub TextBoxSendPeriod_TextChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles TextBoxSendPeriod.TextChanged
        If Val(TextBoxSendPeriod.Text) > 0 Then
            TimerAutoSend.Interval = Val(TextBoxSendPeriod.Text)
            TimerAutoSend.Enabled = CheckBoxAutoSend.Checked
        Else
            CheckBoxAutoSend.Checked = False
            TimerAutoSend.Enabled = CheckBoxAutoSend.Checked
            MsgBox("請確保發送周期為正整數!")
            TextBoxSendPeriod.Text = "1000"
        End If
    End Sub

    Private Sub CheckBoxAutoSend_CheckedChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles CheckBoxAutoSend.CheckedChanged
        If CheckBoxAutoSend.Checked = True Then
            If SerialPort.IsOpen = True Then
                If Val(TextBoxSendPeriod.Text) > 0 Then
                    TimerAutoSend.Interval = Val(TextBoxSendPeriod.Text)
                    TimerAutoSend.Enabled = CheckBoxAutoSend.Checked
                Else
                    CheckBoxAutoSend.Checked = False
                    MsgBox("請確保發送周期為正整數!")
                    TextBoxSendPeriod.Text = "1000"
                End If
            Else
                CheckBoxAutoSend.Checked = False
                MsgBox("請在發送前先打開串口!")
            End If
        Else
            TimerAutoSend.Enabled = CheckBoxAutoSend.Checked
        End If
    End Sub

    Private Sub BarBunttonClearCount_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles BarBunttonClearCount.Click
        BarCountRx.Text = "0"
        BarCountTx.Text = "0"
    End Sub

    Private Sub ButtonSendFile_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ButtonSendFile.Click
        Dim DialogOpen As New System.Windows.Forms.OpenFileDialog
        DialogOpen.Multis

uj5u.com熱心網友回復:

不知道怎么上傳代碼

uj5u.com熱心網友回復:

參考 2 樓 良朋 的回復:
看你的代碼是讀取磁盤檔案轉為byte,然后用串口發送(接受也是,把串口發送的byte保存到檔案);但你的測驗截圖又是只是一些字符發送; 關于串口通訊,VS里就有很好的例子啊。看幫助檔案就能找到。
做一個簡單的執行緒就可以了。
[

    '打開串口連接
    Private Sub Button_Open_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button_Open.Click
        SerialPort1.Open() '打開串口
        Dim SerialComm = New Threading.Thread(New Threading.ThreadStart(AddressOf Sp_Receiving))
        SerialComm.Start()      '開執行緒
    End Sub


    '接收資料
    Private Sub Sp_Receiving()
        Dim strIncoming As String
        If SerialPort1.BytesToRead > 0 Then
            strIncoming = SerialPort1.ReadExisting.ToString '讀取緩沖區中的資料
            SerialPort1.DiscardInBuffer()
            ListBox1.Items.Add(strIncoming)
        End If
    End Sub

多謝回復   代碼我填上去了  您看看

uj5u.com熱心網友回復:

簡單的東西被你弄的極其復雜:
其實就2步驟:1.配置串口
     

SerialPort gserialport=new SerialPort();
 gserialport.PortName = "Com1";   //串口號
                    gserialport.BaudRate = 57600;  //波特率
                    gserialport.Parity = Parity.None;
                    gserialport.StopBits = StopBits.One;
                    gserialport.DataBits = 8;  //資料位
                    gserialport.Handshake = Handshake.None;
                    if (!gserialport.IsOpen)
                    {
                            gserialport.Open();
                    }

                      2.讀資料(有些串口需要預發指令的需要先發送指令在讀取)
                      

 if (GlobalSerialPort.gserialport.IsOpen)
                {
                    int n = GlobalSerialPort.gserialport.BytesToRead;
                    byte[] buf = new byte[n];    //buf就是你讀到的資料啦
               }

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/63460.html

標籤:VB.NET

上一篇:為什么參考webservice后組態檔中生成的兩個endpoint

下一篇:OCX ActiveX 視頻控制元件重繪問題

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • WebAPI簡介

    Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......

    uj5u.com 2020-09-09 22:07:47 more
  • asp.net core 3.1 入口:Program.cs中的Main函式

    本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......

    uj5u.com 2020-09-09 22:07:49 more
  • asp.net網站作為websocket服務端的應用該如何寫

    最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......

    uj5u.com 2020-09-09 22:08:02 more
  • ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用

    Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......

    uj5u.com 2020-09-09 22:08:05 more
  • 在webform中使用ajax

    如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......

    uj5u.com 2020-09-09 22:08:50 more
  • iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的

    今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......

    uj5u.com 2020-09-09 22:10:00 more
  • WebAPI-處理架構

    帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......

    uj5u.com 2020-09-09 22:11:13 more
  • 微信門戶開發框架-使用指導說明書

    微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......

    uj5u.com 2020-09-09 22:15:18 more
  • WebAPI-HTTP編程模型

    帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......

    uj5u.com 2020-09-09 22:15:23 more
  • 部署WebApi隨筆

    一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......

    uj5u.com 2020-09-09 22:15:48 more
最新发布
  • C#多執行緒學習(二) 如何操縱一個執行緒

    <a href="https://www.cnblogs.com/x-zhi/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2943582/20220801082530.png" alt="" /></...

    uj5u.com 2023-04-19 09:17:20 more
  • C#多執行緒學習(二) 如何操縱一個執行緒

    C#多執行緒學習(二) 如何操縱一個執行緒 執行緒學習第一篇:C#多執行緒學習(一) 多執行緒的相關概念 下面我們就動手來創建一個執行緒,使用Thread類創建執行緒時,只需提供執行緒入口即可。(執行緒入口使程式知道該讓這個執行緒干什么事) 在C#中,執行緒入口是通過ThreadStart代理(delegate)來提供的 ......

    uj5u.com 2023-04-19 09:16:49 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    <a href="https://www.cnblogs.com/huangxincheng/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/214741/20200614104537.png" alt="" /&g...

    uj5u.com 2023-04-18 08:39:04 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    一:背景 1. 講故事 前段時間協助訓練營里的一位朋友分析了一個程式卡死的問題,回過頭來看這個案例比較經典,這篇稍微整理一下供后來者少踩坑吧。 二:WinDbg 分析 1. 為什么會卡死 因為是表單程式,理所當然就是看主執行緒此時正在做什么? 可以用 ~0s ; k 看一下便知。 0:000> k # ......

    uj5u.com 2023-04-18 08:33:10 more
  • SignalR, No Connection with that ID,IIS

    <a href="https://www.cnblogs.com/smartstar/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/u36196.jpg" alt="" /></a>...

    uj5u.com 2023-03-30 17:21:52 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:15:33 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:13:31 more
  • C#遍歷指定檔案夾中所有檔案的3種方法

    <a href="https://www.cnblogs.com/xbhp/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/957602/20230310105611.png" alt="" /></a&...

    uj5u.com 2023-03-27 14:46:55 more
  • C#/VB.NET:如何將PDF轉為PDF/A

    <a href="https://www.cnblogs.com/Carina-baby/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2859233/20220427162558.png" alt="" />...

    uj5u.com 2023-03-27 14:46:35 more
  • 武裝你的WEBAPI-OData聚合查詢

    <a href="https://www.cnblogs.com/podolski/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/616093/20140323000327.png" alt="" /><...

    uj5u.com 2023-03-27 14:46:16 more