实例介绍
【实例简介】基于C#的串口通信上位机,标准的modbus协议,运行需下载Dev express组件(WINFrom平台最好的界面组件)
{
for (int i = 0; i < GetAddressValueLength(addr); i )
if (GetAddressValue(addr, stat) == null) //如果所添加的指令没有在MODBUS对应表中定义 直接退出
return;
SciAddCmd(ref gMBSci, addr, GetAddressValueLength(addr), stat);
}
/// <summary>
/// 串口参数配置
/// </summary>
/// <param name="commx">所用到的串口</param>
/// <param name="node"></param>
/// <param name="baud"></param>
public static void MBConfig(SerialPort commx, UInt16 node, UInt16 baud)
{
gBaud = baud;
gNode = node;
comm = commx;
SciClearRepeatCmd(ref gMBSci);
SciClearCmd(ref gMBSci);
}
/// <summary>
/// 读取串口中接收到的数据
/// </summary>
/// <param name="comm">所用到的串口</param>
public static void MBDataReceive()
{
if (comm == null) //如果串口没有被初始化直接退出
return;
SciSchedulingLock();
System.Threading.Thread.Sleep(20); //等待缓冲器满
buffLen = comm.BytesToRead; //获取缓冲区字节长度
if (buffLen > MB_MAX_LENGTH) //如果长度超出范围 直接退出
{
SciSchedulingUnlock();
return;
}
comm.Read(buff, 0, buffLen); //读取数据
if (gMBSci.cmd[gMBSci.index].stat == buff[1])
{
if (Crc16(buff, buffLen) == 0)
{
rBuff = new byte[buffLen];
Array.Copy(buff, rBuff, buffLen);
}
}
SciSchedulingUnlock();
}
/// <summary>
/// MODBUS的实时刷新任务,在定时器在实时调用此函数
/// 指令发送间隔时间等于实时器乘以10。 例:定时器5ms调用一次 指令发送间隔为50ms。
/// </summary>
/// <returns>返回当前功能读取指令回传 的功能码</returns>
public static int MBRefresh()
{
if (sciLock) //如果被加锁 直接退出
return 0;
mbRefreshTime ;
if (mbRefreshTime > 10)
{
mbRefreshTime = 0;
MBSchedRefresh();
}
return MBQuickRefresh();
}
【实例截图】Modbus协议可直接移植到其他平台,类已经封装好
{
for (int i = 0; i < GetAddressValueLength(addr); i )
if (GetAddressValue(addr, stat) == null) //如果所添加的指令没有在MODBUS对应表中定义 直接退出
return;
SciAddCmd(ref gMBSci, addr, GetAddressValueLength(addr), stat);
}
/// <summary>
/// 串口参数配置
/// </summary>
/// <param name="commx">所用到的串口</param>
/// <param name="node"></param>
/// <param name="baud"></param>
public static void MBConfig(SerialPort commx, UInt16 node, UInt16 baud)
{
gBaud = baud;
gNode = node;
comm = commx;
SciClearRepeatCmd(ref gMBSci);
SciClearCmd(ref gMBSci);
}
/// <summary>
/// 读取串口中接收到的数据
/// </summary>
/// <param name="comm">所用到的串口</param>
public static void MBDataReceive()
{
if (comm == null) //如果串口没有被初始化直接退出
return;
SciSchedulingLock();
System.Threading.Thread.Sleep(20); //等待缓冲器满
buffLen = comm.BytesToRead; //获取缓冲区字节长度
if (buffLen > MB_MAX_LENGTH) //如果长度超出范围 直接退出
{
SciSchedulingUnlock();
return;
}
comm.Read(buff, 0, buffLen); //读取数据
if (gMBSci.cmd[gMBSci.index].stat == buff[1])
{
if (Crc16(buff, buffLen) == 0)
{
rBuff = new byte[buffLen];
Array.Copy(buff, rBuff, buffLen);
}
}
SciSchedulingUnlock();
}
/// <summary>
/// MODBUS的实时刷新任务,在定时器在实时调用此函数
/// 指令发送间隔时间等于实时器乘以10。 例:定时器5ms调用一次 指令发送间隔为50ms。
/// </summary>
/// <returns>返回当前功能读取指令回传 的功能码</returns>
public static int MBRefresh()
{
if (sciLock) //如果被加锁 直接退出
return 0;
mbRefreshTime ;
if (mbRefreshTime > 10)
{
mbRefreshTime = 0;
MBSchedRefresh();
}
return MBQuickRefresh();
}
好例子网口号:伸出你的我的手 — 分享!
网友评论
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
支持(0) 盖楼(回复)
支持(0) 盖楼(回复)