C# 轻量级工业温湿度监控系统(含数据库与源码)

项目介绍

一套基于 Windows 平台开发的工业温湿度集中监控系统,主要服务于拥有多个监测站点(最多6个)的中小型制造或仓储场景。

系统通过 Modbus TCP 协议与现场控制器通信,实时获取各站点的温度、湿度数据,并同步展示设备运行状态。'

整个系统以桌面应用形式部署,无需复杂服务器环境,便于在工控机上直接安装使用。

项目功能

1、实时监控界面

动态刷新六个站点的温湿度数值及设备连接状态,辅以滚动报警条提示当前异常;

2、参数设置模块

允许配置通信地址、端口及各类报警阈值;

3、配方管理

支持保存多套温湿度控制策略(每套包含6个站点的上下限及报警使能状态),可一键下发至设备;

4、历史趋势模块

定时采集并存储数据,用户可按时间段查询并对比曲线;

5、报警追溯

自动记录所有触发与恢复事件,支持导出为报表;

6、用户管理

基于角色权限控制各功能模块的访问,确保操作安全。

项目特点

项目特点在于其实用性与工程化思维。

系统采用本地文件(INI 和 Excel)管理设备配置、变量定义与配方数据,避免了数据库依赖,在资源有限的工控环境中运行更稳定。

界面设计简洁直观,操作逻辑贴近一线人员习惯------例如配方名称直接对应 .ini 文件名,修改即存盘,应用即写入设备寄存器。

同时,系统内置自动重连机制和数据有效性校验,即便网络短暂中断也能快速恢复,保障监控连续性。

项目技术

  • 主窗体(FrmMain)通过后台任务持续轮询设备数据,利用 ObservableCollection 实现报警信息的自动刷新;

  • 数据解析部分封装了 BitLibShortLibFloatLib 等工具类,精准处理不同数据类型在字节流中的偏移与字节序;

  • 配方管理窗体(FrmRecipe)展示了典型的 CRUD 操作:从界面上读取6个站点的参数,序列化为 JSON 存入本地 INI 文件;应用时将浮点值乘以10转为 short 类型,按固定顺序打包写入 Modbus 寄存器(起始地址36)。

这种设计既保证了配置灵活性,又满足了工业协议对数据格式的严格要求。

项目代码

复制代码
/// <summary>
/// 初始化设备参数
/// </summary>
/// <returns></returns>
private Device LoadDevice()
{
    Device device = new Device();
    try
    {
        if (!File.Exists(strDevicePath))
        {
            CommonMethods.AddLog(1, "Device.ini文件不存在!");
            returnnull;
        }

        device.IPAddress = IniConfigHelper.ReadIniData("设备IP", "IP", "127.0.0.1", strDevicePath);
        device.Port = IniConfigHelper.ReadIniData("设备端口号", "Port", "502", strDevicePath);
        device.CurrentRecipe = IniConfigHelper.ReadIniData("配方", "配方名称", "", strDevicePath);

        device.GroupList = LoadGroupList();
        return device;
    }
    catch (Exception)
    {
        CommonMethods.AddLog(1, "加载设备信息异常!");
    }
    returnnull;
}

/// <summary>
/// 获取通信组和变量
/// </summary>
/// <returns></returns>
private List<Group> LoadGroupList()
{
    try
    {
        if (!File.Exists(strVariablePath))
        {
            CommonMethods.AddLog(1, "Variable.xlsx文件不存在!");
            returnnull;
        }
        if (!File.Exists(strGroupPath))
        {
            CommonMethods.AddLog(1, "Group.xlsx文件不存在!");
            returnnull;
        }
        List<Group> groups = MiniExcel.Query<Group>(strGroupPath).ToList();
        List<Variable> variables = MiniExcel.Query<Variable>(strVariablePath).ToList();

        foreach (vargroupin groups)
        {
            group.VarList = variables.FindAll(v => v.GroupName == group.GroupName);
        }
        return groups;
    }
    catch (Exception)
    {
        CommonMethods.AddLog(1, "加载xlsx文件异常!");
    }
    returnnull;
}

项目效果

系统启动后自动加载设备配置与变量定义,建立通信连接,并开始每秒采集一次数据。当某站点温湿度超出设定范围,不仅界面立即弹出提示,还会在日志中记录触发/消除事件,供后续追溯。

配方切换过程流畅,写入成功后自动更新当前配方名称,确保操作闭环。整个流程无卡顿、无数据丢失,充分满足7×24小时连续运行需求。

系统登录

集中监控

参数设置

配方管理

报警追溯

历史趋势

用户管理

变量配置

项目源码

项目源码结构清晰,核心逻辑集中在 FrmMainDeviceCommunication 方法和 FrmRecipebtnUseRecipe_Click 方法中:

  • 前者体现了工业通信的典型模式:循环读取 → 解析变量 → 触发报警 → 断线重连;

  • 后者则展示了如何将用户配置转化为设备可识别的寄存器数据。

代码未使用高级框架,但模块划分合理、错误处理到位、注释充分,具备良好的可维护性和扩展潜力。

相关推荐
倔强的石头_12 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Scout-leaf3 天前
WPF新手村教程(三)—— 路由事件
c#·wpf
用户298698530143 天前
程序员效率工具:Spire.Doc如何助你一键搞定Word表格排版
后端·c#·.net
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
mudtools4 天前
搭建一套.net下能落地的飞书考勤系统
后端·c#·.net
玩泥巴的4 天前
搭建一套.net下能落地的飞书考勤系统
c#·.net·二次开发·飞书
唐宋元明清21884 天前
.NET 本地Db数据库-技术方案选型
windows·c#