串口简易程序

Imports System
Imports System.IO.Ports

Public Class Form1

Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
'获取计算机有效串口
Dim ports As String() = SerialPort.GetPortNames() '必须用命名空间,用SerialPort,获取计算机的有效串口
Dim port As String
For Each port In ports
portnamebox.Items.Add(port)
'向combobox中添加项
Next port
'初始化界面
baudratebox.Text = baudratebox.Items(2) '注释和不注释的地方可以替换
portnamebox.Text = portnamebox.Items(0)
'baudratebox.SelectedIndex() = 2
' portnamebox.SelectedIndex() = 0
Serial_Port1() '初始化串口
Label3.Text = SerialPort1.IsOpen
statuslabel.Text
= "串口未连接"
statuslabel.ForeColor
= Color.Red
sendbox.Text
= "123"
receivebytes.Text
= "0"
linecheck.Enabled
= True
timebox.Enabled
= True

End Sub

Private Sub Serial_Port1() '设置串口参数
'SerialPort1.BaudRate = Val(baudratebox.Text) '波特率
'SerialPort1.PortName = portnamebox.Text '串口名称
SerialPort1.PortName = portnamebox.SelectedItem
SerialPort1.BaudRate
= Val(baudratebox.SelectedItem)
SerialPort1.DataBits
= 8 '数据位
SerialPort1.StopBits = IO.Ports.StopBits.One '停止位
SerialPort1.Parity = IO.Ports.Parity.None '校验位
End Sub

'关闭串口连接
Private Sub closebtn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles closebtn.Click
Try
SerialPort1.Close()
'关闭串口
Label3.Text = SerialPort1.IsOpen
If SerialPort1.IsOpen = False Then
statuslabel.Text
= "串口未连接"
statuslabel.ForeColor
= Color.Red
receivebox.Text
= ""
receivebytes.Text
= ""
End If
Catch ex As Exception
MessageBox.Show(ex.Message)
End Try
End Sub

'打开串口连接
Private Sub openbtn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles openbtn.Click
Try
SerialPort1.Open()
'打开串口
Label3.Text = SerialPort1.IsOpen
If SerialPort1.IsOpen = True Then
statuslabel.Text
= "串口已连接"
statuslabel.ForeColor
= Color.Green
End If
Catch ex As Exception
MessageBox.Show(ex.Message)
End Try
End Sub

'手动发送数据
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
send()
End Sub

'触发接收事件,接收数据
Public Sub Sp_DataReceived(ByVal sender As Object, ByVal e As System.IO.Ports.SerialDataReceivedEventArgs) Handles SerialPort1.DataReceived
Me.Invoke(New EventHandler(AddressOf Sp_Receiving)) '调用接收数据函数
End Sub

'接收数据过程
Private Sub Sp_Receiving(ByVal sender As Object, ByVal e As EventArgs)

' Dim strIncoming As Byte
Dim strIncoming As Integer
Dim str1() As String
Dim str2() As String
Dim bytes() As Byte
Dim i As Integer
Try
Threading.Thread.Sleep(
100) '添加的延时
receivebytes.Text = Str(Val(receivebytes.Text) + SerialPort1.BytesToRead)
If SerialPort1.BytesToRead > 0 Then

ReDim bytes(SerialPort1.BytesToRead)
'strIncoming = Convert.ToByte(SerialPort1.ReadByte())
If receivecheck.Checked = True Then
strIncoming
= SerialPort1.ReadByte()
bytes(
0) = strIncoming
For i = 1 To SerialPort1.BytesToRead
strIncoming
= SerialPort1.ReadByte() '读取缓冲区中的数据
bytes(i) = strIncoming
Next
' SerialPort1.Write(sendbox.Text)'发送数据
SerialPort1.DiscardInBuffer()
str1
= Split(BitConverter.ToString(bytes), "-")

ReDim str2(str1.Length - 1) '去除str1中最后的字符
For i = 0 To str1.Length - 2
str2(i)
= str1(i)
Next
receivebox.Text
= receivebox.Text & Join(str2, " ")
'BitConverter.ToString(bytes)
Else
receivebox.Text
= receivebox.Text & SerialPort1.ReadExisting()
End If

End If
Catch ex As Exception
MessageBox.Show(ex.Message)
End Try
End Sub

'更改串口设置
Private Sub portnamebox_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles portnamebox.SelectedIndexChanged
Try
Serial_Port1()
Catch ex As Exception
MessageBox.Show(ex.Message)
End Try
End Sub

'清空接收区
Private Sub clearbtn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles clearbtn.Click
receivebox.Text
= ""
End Sub

'定时发送数据
Private Sub Timer1_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Timer1.Tick
Timer1.Interval
= timebox.Text
send()
End Sub

'选择定时发送的触发事件
Private Sub timecheck_CheckedChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles timecheck.CheckedChanged

If timecheck.Checked = True Then
If timebox.Text = "" Then
MsgBox("时间间隔不能为0")
timecheck.Checked
= False
Else
send()
timebox.Enabled
= False
End If
Else
timebox.Enabled
= True
End If
End Sub

Public Sub send() '发送数据过程
Dim databyte() As Byte
Dim str1() As String
Dim str2 As String
Dim str3 As String
Dim i As Integer

Try
If sendcheck.Checked = False Then '不按照16进制发送
'timecheck.Enabled = True

If linecheck.Checked = False Then '判断是否选中分行发送
SerialPort1.Write(sendbox.Text)
Else
SerialPort1.WriteLine(sendbox.Text)
End If

Else '按照16进制发送
If InStr(sendbox.Text, " ") Then '判断是否有空格
str1 = Split(sendbox.Text)
str2
= Join(str1, "")
Else
str2
= sendbox.Text
End If

If str2.Length Mod 2 = 0 Then '判断字符串字节数是否为偶数
ReDim databyte(str2.Length / 2) '重新定义数组
For i = 0 To str2.Length / 2 - 1
databyte(i)
= Convert.ToByte(Mid(str2, 2 * i + 1, 2), 16) '两个字符转换为一个16进制字节
'databyte(i) = Val(Mid(str2, 2 * i + 1, 2))
Next
SerialPort1.Write(databyte,
0, databyte.Length - 1)
sendbytes.Text
= Str(Val(sendbytes.Text) + databyte.Length - 1)
Else

str3
= Mid(str2, 1, (str2.Length - 1)) & "0" & Mid(str2, str2.Length)
ReDim databyte(str3.Length / 2)
For i = 0 To str3.Length / 2 - 1
databyte(i)
= Convert.ToByte(Mid(str3, 2 * i + 1, 2), 16)
Next
SerialPort1.Write(databyte,
0, databyte.Length - 1)
sendbytes.Text
= Str(Val(sendbytes.Text) + databyte.Length - 1)
End If
'databyte = System.Text.Encoding.Default.GetBytes(sendbox.Text)把每个字符转换成字节

End If

Catch ex As Exception
MessageBox.Show(ex.Message)
End Try

End Sub

'是否按照16进制发送,如果是换行将不可选。如果不是,换行可选
Private Sub sendcheck_CheckedChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles sendcheck.CheckedChanged
If sendcheck.Checked = True Then '不按照16进制发送
linecheck.Enabled = False
Else
linecheck.Enabled
= True
End If
End Sub
End Class
复制代码

程序包括16进制发送和接受,定时发送,换行接收,接收和发送数据字节统计

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值