-
C#教程之C#串口通讯,复制粘贴就可用,仅仅介绍怎样最快的搭建一个串口通讯,异常拦
本站最新发布 C#从入门到精通
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
using System; using System.Collections.Generic; using System.IO.Ports; using System.Text; //串口通讯类 public class SerialPortManager { //声明一个静态的串口资源 private SerialPort ComDevice = new SerialPort(); public SerialPortManager() { var portList = SerialPort.GetPortNames();//获取当前搜索到的串口集合 ComDevice.DataReceived += new SerialDataReceivedEventHandler(Com_DataReceived); //绑定事件,接收到串口数据时触发 } /// <summary> /// 打开和关闭串口, /// 前端放个按钮调用这个方法 /// 串口名称用SerialPort.GetPortNames()拉取所有串口,上面构造有写 /// 下面相关的参数具体有些哪些百度下就知道了,这块只是举例,当然也可以直接用 /// </summary> /// <param name="serialPortName">串口名称</param> /// <returns></returns> public void openOrCloseSerialPort(string serialPortName) { //判断当前状态是打开还是关闭,开启的话就关闭,反之就开启 if (ComDevice.IsOpen == false) { //设置串口名称 ComDevice.PortName = serialPortName; //设置波特率 ComDevice.BaudRate = 115200; //设置数据位 ComDevice.DataBits = 8; //校验位设置 ComDevice.StopBits = StopBits.One; //停止位设置 ComDevice.Parity = Parity.None; //开启串口 ComDevice.Open(); } else { ComDevice.Close();//关闭串口 } } /// <summary> /// 串口数据读取方法,在构造时已经监听 /// </summary> private void Com_DataReceived(object sender, SerialDataReceivedEventArgs e) { byte[] ReDatas = new byte[ComDevice.BytesToRead]; ComDevice.Read(ReDatas, 0, ReDatas.Length); //接收到的字节流 var data = ReDatas; //根据自己需求转换 var str = new UTF8Encoding().GetString(ReDatas); } /// <summary> /// 发送数据方法 /// </summary> /// <param name="data">需要发送的字节流</param> public void Com_SendData(byte[] data) { if (ComDevice.IsOpen) { ComDevice.Write(data, 0, data.Length);//发送数据 } } }
栏目列表
最新更新
C# 面向对象
假设客车的座位数是9行4列,使用二维数
C#基于接口设计三层架构Unity篇
C#线程 入门
C#读取静态类常量属性和值
C# 插件式编程
C# 委托与事件有啥区别?
C#队列学习笔记:队列(Queue)和堆栈(Stack
linq 多表分组左连接查询查询统计
C#队列学习笔记:MSMQ入门一
C# 在Word中添加Latex 数学公式和符号
inncheck命令 – 检查语法
基于UDP的服务器端和客户端
再谈UDP和TCP
在socket编程中使用域名
网络数据传输时的大小端问题
socket编程实现文件传输功能
如何优雅地断开TCP连接?
图解TCP四次握手断开连接
详细分析TCP数据的传输过程
SqlServer 利用游标批量更新数据
BOS只读状态修改
SQL Server等待事件—PAGEIOLATCH_EX
数据库多行转换为单一列
获取数据表最后最后访问,修改,更新,
计算经历的时间
SQL查询结果自定义排序
修改数据库默认位置
日期简单加或减
从日期获取年,月或日