diff --git a/Actions/ChemicalWeighing/Mesnac.Action.ChemicalWeighing/FinishBatch/SaveHelper/AlarmSaveHelper.cs b/Actions/ChemicalWeighing/Mesnac.Action.ChemicalWeighing/FinishBatch/SaveHelper/AlarmSaveHelper.cs
index 81d7503..e4b2696 100644
--- a/Actions/ChemicalWeighing/Mesnac.Action.ChemicalWeighing/FinishBatch/SaveHelper/AlarmSaveHelper.cs
+++ b/Actions/ChemicalWeighing/Mesnac.Action.ChemicalWeighing/FinishBatch/SaveHelper/AlarmSaveHelper.cs
@@ -1,6 +1,7 @@
using DevExpress.Xpo.DB;
using HslCommunication;
using Mesnac.Codd.Session;
+using Mesnac.DoUtils;
using Mesnac.PlcUtils;
using System;
using System.Collections.Generic;
@@ -23,6 +24,8 @@ namespace Mesnac.Action.ChemicalWeighing.FinishBatch.SaveHelper
private static PlcBusiness plcBusiness = PlcBusiness.Instance;
+ private static DoControl doControl = DoControl.Instance;
+
///
/// 保存报警信息
///
@@ -123,6 +126,9 @@ namespace Mesnac.Action.ChemicalWeighing.FinishBatch.SaveHelper
{
sai.AlarmData = Convert.ToInt16(result.Content); //对起始字偏移,为当前字的报警值
+ //打开报警灯
+ doControl.DOControl(DoUtils.enumInfo.DOName.Red, DoUtils.enumInfo.DOOnOff.On);
+
//更新报警状态
Entity.PmtAlarmInfo alarmInfo = Cache.CacheHelper.GetPmtAlarmInfoFromCache(sai.AlramPLC, sai.AlarmBlock, sai.AlarmAddress, Convert.ToInt32(sai.AlarmBit));
if (alarmInfo != null)
diff --git a/Actions/ChemicalWeighing/Mesnac.Action.ChemicalWeighing/Mesnac.Action.ChemicalWeighing.csproj b/Actions/ChemicalWeighing/Mesnac.Action.ChemicalWeighing/Mesnac.Action.ChemicalWeighing.csproj
index 40e356d..bc6905a 100644
--- a/Actions/ChemicalWeighing/Mesnac.Action.ChemicalWeighing/Mesnac.Action.ChemicalWeighing.csproj
+++ b/Actions/ChemicalWeighing/Mesnac.Action.ChemicalWeighing/Mesnac.Action.ChemicalWeighing.csproj
@@ -733,6 +733,10 @@
{28acacf1-9936-4e97-a866-f84366ec5286}
Mesnac.Basic
+
+ {ad132cad-5288-44dc-a38f-4b0658fc228c}
+ Mesnac.DoUtils
+
{88eac8d1-8783-478c-ad9d-f916673b7004}
Mesnac.PlcUtils
diff --git a/Mesnac.DoUtils/DoControl.cs b/Mesnac.DoUtils/DoControl.cs
new file mode 100644
index 0000000..b58862c
--- /dev/null
+++ b/Mesnac.DoUtils/DoControl.cs
@@ -0,0 +1,152 @@
+using Mesnac.DoUtils.enumInfo;
+using System;
+using System.Collections.Generic;
+using System.IO.Ports;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using System.Xml.Linq;
+
+namespace Mesnac.DoUtils
+{
+ ///
+ /// 报警灯控制类
+ ///
+ public sealed class DoControl
+ {
+ public SerialPort serialPort;
+
+ private static readonly Lazy lazy = new Lazy(() => new DoControl());
+ public static DoControl Instance
+ {
+ get
+ {
+ return lazy.Value;
+ }
+ }
+
+ private DoControl()
+ {
+ serialPort.BaudRate = 115200;
+ serialPort.DataBits = 8;
+ serialPort.StopBits = StopBits.One;
+ serialPort.Parity = Parity.None;
+ serialPort = new SerialPort("COM5");
+ }
+
+ ///
+ /// 串口启动
+ ///
+ public void ComOn()
+ {
+ if (!serialPort.IsOpen)
+ {
+ serialPort.Open();
+ }
+ }
+ ///
+ /// 串口关闭
+ ///
+ public void ComOff()
+ {
+ if (serialPort.IsOpen)
+ {
+ serialPort.Close();
+ }
+ }
+
+ ///
+ /// DO1设备启动(红灯)
+ ///
+ public void redLightOn()
+ {
+ DOControl(DOName.Red, DOOnOff.On);
+ }
+
+ ///
+ /// DO2设备启动(绿灯)
+ ///
+ public void greenLightOn()
+ {
+ DOControl(DOName.Green, DOOnOff.On);
+ }
+
+ ///
+ /// DO3设备启动(蜂鸣器)
+ ///
+ public void buzzerOn()
+ {
+ DOControl(DOName.Buzzer, DOOnOff.On);
+ }
+
+ ///
+ /// DO1设备关闭(红灯)
+ ///
+ public void redLightOff()
+ {
+ DOControl(DOName.Red, DOOnOff.Off);
+ }
+
+ ///
+ /// DO2设备关闭(绿灯)
+ ///
+ public void greenLightOff()
+ {
+ DOControl(DOName.Green, DOOnOff.Off);
+ }
+
+ ///
+ /// DO3设备关闭(蜂鸣器)
+ ///
+ public void buzzerOff()
+ {
+ DOControl(DOName.Buzzer, DOOnOff.On);
+ }
+
+ ///
+ /// 重置串口和DO状态
+ ///
+ public void Reset()
+ {
+ SetOff();
+ ComOff();
+ }
+
+ ///
+ /// 重置DO状态
+ ///
+ public void SetOff()
+ {
+ foreach (DOName dOName in Enum.GetValues(typeof(DOName)))
+ {
+ DOControl(dOName, DOOnOff.Off);
+ }
+ }
+
+ ///
+ /// DO启停控制
+ ///
+ /// DegitalOut接口名称
+ /// 启停状态
+ public void DOControl(DOName dOName, DOOnOff dOOnOff)
+ {
+ //ComOn();
+ serialPort.Write(new byte[] { 0xE3, 0x01, 0x09, (byte)dOName, (byte)dOOnOff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 0, 12);
+ }
+
+ ///
+ /// 文本框传输数据控制COM5串口
+ ///
+ public void DOTestSend(string str)
+ {
+ //ComOn();
+ string[] strArray = str.Split(' ');
+ byte[] bytes = new byte[strArray.Length];
+ for (int i = 0; i < bytes.Length; i++)
+ {
+ bytes[i] = Convert.ToByte(strArray[i], 16);
+ }
+ serialPort.Write(bytes, 0, bytes.Length);
+ }
+ }
+}
\ No newline at end of file
diff --git a/Mesnac.DoUtils/Mesnac.DoUtils.csproj b/Mesnac.DoUtils/Mesnac.DoUtils.csproj
new file mode 100644
index 0000000..f979560
--- /dev/null
+++ b/Mesnac.DoUtils/Mesnac.DoUtils.csproj
@@ -0,0 +1,50 @@
+
+
+
+
+ Debug
+ AnyCPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}
+ Library
+ Properties
+ Mesnac.DoUtils
+ Mesnac.DoUtils
+ v4.5.2
+ 512
+ true
+
+
+ true
+ full
+ false
+ bin\Debug\
+ DEBUG;TRACE
+ prompt
+ 4
+
+
+ pdbonly
+ true
+ bin\Release\
+ TRACE
+ prompt
+ 4
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Mesnac.DoUtils/Properties/AssemblyInfo.cs b/Mesnac.DoUtils/Properties/AssemblyInfo.cs
new file mode 100644
index 0000000..dab90a9
--- /dev/null
+++ b/Mesnac.DoUtils/Properties/AssemblyInfo.cs
@@ -0,0 +1,36 @@
+using System.Reflection;
+using System.Runtime.CompilerServices;
+using System.Runtime.InteropServices;
+
+// 有关程序集的一般信息由以下
+// 控制。更改这些特性值可修改
+// 与程序集关联的信息。
+[assembly: AssemblyTitle("Mesnac.DoUtils")]
+[assembly: AssemblyDescription("")]
+[assembly: AssemblyConfiguration("")]
+[assembly: AssemblyCompany("")]
+[assembly: AssemblyProduct("Mesnac.DoUtils")]
+[assembly: AssemblyCopyright("Copyright © 2023")]
+[assembly: AssemblyTrademark("")]
+[assembly: AssemblyCulture("")]
+
+// 将 ComVisible 设置为 false 会使此程序集中的类型
+//对 COM 组件不可见。如果需要从 COM 访问此程序集中的类型
+//请将此类型的 ComVisible 特性设置为 true。
+[assembly: ComVisible(false)]
+
+// 如果此项目向 COM 公开,则下列 GUID 用于类型库的 ID
+[assembly: Guid("ad132cad-5288-44dc-a38f-4b0658fc228c")]
+
+// 程序集的版本信息由下列四个值组成:
+//
+// 主版本
+// 次版本
+// 生成号
+// 修订号
+//
+//可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值
+//通过使用 "*",如下所示:
+// [assembly: AssemblyVersion("1.0.*")]
+[assembly: AssemblyVersion("1.0.0.0")]
+[assembly: AssemblyFileVersion("1.0.0.0")]
diff --git a/Mesnac.DoUtils/enumInfo/DOName.cs b/Mesnac.DoUtils/enumInfo/DOName.cs
new file mode 100644
index 0000000..14a612b
--- /dev/null
+++ b/Mesnac.DoUtils/enumInfo/DOName.cs
@@ -0,0 +1,20 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Mesnac.DoUtils.enumInfo
+{
+ public enum DOName
+ {
+ Red = 0x01,
+ Green = 0x02,
+ Buzzer = 0x03,
+ dO_4 = 0x04,
+ dO_5 = 0x05,
+ dO_6 = 0x06,
+ dO_7 = 0x07,
+ dO_8 = 0x08,
+ }
+}
diff --git a/Mesnac.DoUtils/enumInfo/DOOnOff.cs b/Mesnac.DoUtils/enumInfo/DOOnOff.cs
new file mode 100644
index 0000000..1457a15
--- /dev/null
+++ b/Mesnac.DoUtils/enumInfo/DOOnOff.cs
@@ -0,0 +1,14 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Mesnac.DoUtils.enumInfo
+{
+ public enum DOOnOff
+ {
+ Off = 0x00,
+ On = 0x01
+ }
+}
diff --git a/SlnMix.VS2013.sln b/SlnMix.VS2013.sln
index 9e0c4ca..0dd68d4 100644
--- a/SlnMix.VS2013.sln
+++ b/SlnMix.VS2013.sln
@@ -162,6 +162,10 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "PlcUtils", "PlcUtils", "{DE
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Mesnac.PlcUtils", "Mesnac.PlcUtils\Mesnac.PlcUtils.csproj", "{88EAC8D1-8783-478C-AD9D-F916673B7004}"
EndProject
+Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "DoUtils", "DoUtils", "{9F21B6A6-9B19-4AAC-88EF-A430D8808540}"
+EndProject
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Mesnac.DoUtils", "Mesnac.DoUtils\Mesnac.DoUtils.csproj", "{AD132CAD-5288-44DC-A38F-4B0658FC228C}"
+EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
@@ -328,6 +332,18 @@ Global
{88EAC8D1-8783-478C-AD9D-F916673B7004}.Release|Mixed Platforms.Build.0 = Release|Any CPU
{88EAC8D1-8783-478C-AD9D-F916673B7004}.Release|x86.ActiveCfg = Release|Any CPU
{88EAC8D1-8783-478C-AD9D-F916673B7004}.Release|x86.Build.0 = Release|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Debug|Mixed Platforms.ActiveCfg = Debug|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Debug|Mixed Platforms.Build.0 = Debug|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Debug|x86.ActiveCfg = Debug|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Debug|x86.Build.0 = Debug|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Release|Any CPU.Build.0 = Release|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Release|Mixed Platforms.ActiveCfg = Release|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Release|Mixed Platforms.Build.0 = Release|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Release|x86.ActiveCfg = Release|Any CPU
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C}.Release|x86.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
@@ -357,6 +373,7 @@ Global
{D0C0324F-434E-47EB-8F7C-BA6CD7F233B4} = {DE938080-4A00-4686-9CE4-1C33FCA86346}
{6A2190C6-B530-4D5B-BD34-29EFB0431F67} = {66F3B234-E56C-4EF4-AB6D-BB6D91467855}
{88EAC8D1-8783-478C-AD9D-F916673B7004} = {DE8C4FC3-17D6-4217-8AB1-72ADE8D85810}
+ {AD132CAD-5288-44DC-A38F-4B0658FC228C} = {9F21B6A6-9B19-4AAC-88EF-A430D8808540}
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {125BF7F5-E6EF-487C-B939-0631965DB3C1}