Form_DevAlarm.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. using MainForm.ClassFile.ProjectClass;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.ComponentModel;
  5. using System.Data;
  6. using System.Drawing;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using System.Windows.Forms;
  11. namespace MainForm.FaForm
  12. {
  13. public partial class Form_DevAlarm : Form
  14. {
  15. #region 变量
  16. /// <summary>
  17. /// 日志
  18. /// </summary>
  19. public event AlarmMessageHandler MessageEvent;
  20. #endregion 变量
  21. #region 窗体事件
  22. public Form_DevAlarm()
  23. {
  24. InitializeComponent();
  25. }
  26. private void Form_DevAlarm_Load(object sender, EventArgs e)
  27. {
  28. #region 页面样式
  29. // 实时表
  30. dgv_Current.ColumnHeadersDefaultCellStyle.BackColor = Color.WhiteSmoke;
  31. dgv_Current.ColumnHeadersDefaultCellStyle.ForeColor = Color.Black;
  32. dgv_Current.RectColor = Color.Gainsboro;
  33. dgv_Current.GridColor = Color.Gainsboro;
  34. dgv_Current.BackgroundColor = Color.White;
  35. // 历史表
  36. dgv_History.ColumnHeadersDefaultCellStyle.BackColor = Color.WhiteSmoke;
  37. dgv_History.ColumnHeadersDefaultCellStyle.ForeColor = Color.Black;
  38. dgv_History.RectColor = Color.Gainsboro;
  39. dgv_History.GridColor = Color.Gainsboro;
  40. dgv_History.BackgroundColor = Color.White;
  41. #endregion 页面样式
  42. }
  43. private void Form_DevAlarm_VisibleChanged(object sender, EventArgs e)
  44. {
  45. if (!this.IsDisposed && this.Visible)
  46. {
  47. UpdDeviceStatus_Today(); // 加载设备运行数据
  48. UpdDeviceAlarm_History_48H(); // 加载报警数据
  49. }
  50. }
  51. #endregion 窗体事件
  52. #region 设备运行信息
  53. /// <summary>
  54. /// 更新设备运行信息-本次(废弃)
  55. /// </summary>
  56. /// <param name="lineWorkingData">设备信息</param>
  57. public void UpdDeviceStatus_ThisTime(LineWorkingData_ThisTime lineWorkingData)
  58. {
  59. if (this.InvokeRequired) // 当前线程不是控件UI线程时为true
  60. {
  61. this.Invoke(new Action<LineWorkingData_ThisTime>(UpdDeviceStatus_ThisTime), lineWorkingData);
  62. return;
  63. }
  64. RPrc_Normal.Value = lineWorkingData.NormalTimeLong < 24 ? Convert.ToInt32(lineWorkingData.NormalTimeLong) : 24; // 本次运行时间
  65. Lbl__Normal.Text = string.Concat("本次运行时间:", lineWorkingData.NormalTimeLong.ToString("0.00"), "小时");
  66. RPrc_Fault.Value = lineWorkingData.FaultTimeLong < 24 ? Convert.ToInt32(lineWorkingData.FaultTimeLong) : 24; // 本次故障时间
  67. Lbl_Fault.Text = string.Concat("本次故障时间:", lineWorkingData.FaultTimeLong.ToString("0.00"), "小时");
  68. RPrc_Standby.Value = lineWorkingData.StandbyTimeLong < 24 ? Convert.ToInt32(lineWorkingData.StandbyTimeLong) : 24; // 本次待机时间
  69. Lbl_Standby.Text = string.Concat("本次待机时间:", lineWorkingData.StandbyTimeLong.ToString("0.00"), "小时");
  70. RPrc_MaterialShortage.Value = lineWorkingData.MaterialShortageTimeLong < 24 ? Convert.ToInt32(lineWorkingData.MaterialShortageTimeLong) : 24; // 本次缺料时间
  71. Lbl_MaterialShortage.Text = string.Concat("本次缺料时间:", lineWorkingData.MaterialShortageTimeLong.ToString("0.00"), "小时");
  72. RPrc_Maintenance.Value = lineWorkingData.MaintenanceTimeLong < 24 ? Convert.ToInt32(lineWorkingData.MaintenanceTimeLong) : 24; // 本次维修时间
  73. Lbl_Maintenance.Text = string.Concat("本次维修时间:", lineWorkingData.MaintenanceTimeLong.ToString("0.00"), "小时");
  74. // 本次未知状态时间
  75. float unknown = lineWorkingData.BootTimeLong - lineWorkingData.NormalTimeLong
  76. - lineWorkingData.FaultTimeLong - lineWorkingData.StandbyTimeLong
  77. - lineWorkingData.MaterialShortageTimeLong;
  78. unknown = unknown < 24 ? unknown : 24;
  79. unknown = unknown < 0 ? 0 : unknown;
  80. RPrc_Unknown.Value = Convert.ToInt32(unknown);
  81. Lbl_Unknown.Text = string.Concat("本次未知状态时间:", unknown.ToString("0.00"), "小时");
  82. }
  83. /// <summary>
  84. /// 更新设备运行信息-本日
  85. /// </summary>
  86. public void UpdDeviceStatus_Today()
  87. {
  88. try
  89. {
  90. if (this.InvokeRequired) // 当前线程不是控件UI线程时为true
  91. {
  92. this.Invoke(new Action(UpdDeviceStatus_Today));
  93. return;
  94. }
  95. LineWorkingData_Today lineWorkingData_Today = new LineWorkingData_Today();
  96. DateTime dtNow = DateTime.Now;
  97. string dtStart = dtNow.ToString("yyyy-MM-dd") + " 00:00:00";
  98. string dtEnd = dtNow.ToString("yyyy-MM-dd") + " 23:59:59";
  99. string querySQL = @"SELECT [LineName] AS 线体名称
  100. ,SUM([BootTimeLong]) AS 本日开机时间
  101. ,SUM([NormalTimeLong]) AS 本日开机运行时间
  102. ,SUM([StandbyTimeLong]) AS 本日开机待机时间
  103. ,SUM([FaultTimeLong]) AS 本日开机故障时间
  104. ,SUM([MaterialShortageTimeLong]) AS 本日开机缺料时间
  105. ,SUM([MaintenanceTimeLong]) AS 本日开机维修时间
  106. ,SUM([FaultNumber]) AS 本日故障停机次数
  107. FROM [LineWorkingData]
  108. Where [CreateTime] between '{0}' and '{1}'
  109. And [LineName]='{2}'
  110. Group by [LineName]";
  111. querySQL = string.Format(querySQL, dtStart, dtEnd, GlobalContext.LineCode);
  112. DataSet ds = SQLHelper_New.Query(querySQL, null);
  113. if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
  114. {
  115. lineWorkingData_Today.线体名称 = ds.Tables[0].Rows[0][0].ToString();
  116. lineWorkingData_Today.本日开机时间 = ds.Tables[0].Rows[0][1] != null ? Convert.ToSingle(ds.Tables[0].Rows[0][1]) : 0;
  117. lineWorkingData_Today.本日开机运行时间 = ds.Tables[0].Rows[0][2] != null ? Convert.ToSingle(ds.Tables[0].Rows[0][2]) : 0;
  118. lineWorkingData_Today.本日开机待机时间 = ds.Tables[0].Rows[0][3] != null ? Convert.ToSingle(ds.Tables[0].Rows[0][3]) : 0;
  119. lineWorkingData_Today.本日开机故障时间 = ds.Tables[0].Rows[0][4] != null ? Convert.ToSingle(ds.Tables[0].Rows[0][4]) : 0;
  120. lineWorkingData_Today.本日开机缺料时间 = ds.Tables[0].Rows[0][5] != null ? Convert.ToSingle(ds.Tables[0].Rows[0][5]) : 0;
  121. lineWorkingData_Today.本日开机维修时间 = ds.Tables[0].Rows[0][6] != null ? Convert.ToSingle(ds.Tables[0].Rows[0][6]) : 0;
  122. lineWorkingData_Today.本日故障停机次数 = ds.Tables[0].Rows[0][7] != null ? Convert.ToInt32(ds.Tables[0].Rows[0][7]) : 0;
  123. }
  124. // 本日运行时间
  125. RPrc_Normal.Maximum = lineWorkingData_Today.本日开机时间 > lineWorkingData_Today.本日开机运行时间 ? Convert.ToInt32(lineWorkingData_Today.本日开机时间) : Convert.ToInt32(lineWorkingData_Today.本日开机运行时间);
  126. RPrc_Normal.Value = lineWorkingData_Today.本日开机运行时间 < 24 ? Convert.ToInt32(lineWorkingData_Today.本日开机运行时间) : 24;
  127. Lbl__Normal.Text = string.Concat("本日运行时间:", lineWorkingData_Today.本日开机运行时间.ToString("0.00"), "小时");
  128. // 本日故障时间
  129. RPrc_Fault.Maximum = lineWorkingData_Today.本日开机时间 > lineWorkingData_Today.本日开机故障时间 ? Convert.ToInt32(lineWorkingData_Today.本日开机时间) : Convert.ToInt32(lineWorkingData_Today.本日开机故障时间);
  130. RPrc_Fault.Value = lineWorkingData_Today.本日开机故障时间 < 24 ? Convert.ToInt32(lineWorkingData_Today.本日开机故障时间) : 24;
  131. Lbl_Fault.Text = string.Concat("本日故障时间:", lineWorkingData_Today.本日开机故障时间.ToString("0.00"), "小时");
  132. // 本日待机时间
  133. RPrc_Standby.Maximum = lineWorkingData_Today.本日开机时间 > lineWorkingData_Today.本日开机待机时间 ? Convert.ToInt32(lineWorkingData_Today.本日开机时间) : Convert.ToInt32(lineWorkingData_Today.本日开机待机时间);
  134. RPrc_Standby.Value = lineWorkingData_Today.本日开机待机时间 < 24 ? Convert.ToInt32(lineWorkingData_Today.本日开机待机时间) : 24;
  135. Lbl_Standby.Text = string.Concat("本日待机时间:", lineWorkingData_Today.本日开机待机时间.ToString("0.00"), "小时");
  136. // 本日缺料时间
  137. RPrc_MaterialShortage.Maximum = lineWorkingData_Today.本日开机时间 > lineWorkingData_Today.本日开机缺料时间 ? Convert.ToInt32(lineWorkingData_Today.本日开机时间) : Convert.ToInt32(lineWorkingData_Today.本日开机缺料时间);
  138. RPrc_MaterialShortage.Value = lineWorkingData_Today.本日开机缺料时间 < 24 ? Convert.ToInt32(lineWorkingData_Today.本日开机缺料时间) : 24;
  139. Lbl_MaterialShortage.Text = string.Concat("本日缺料时间:", lineWorkingData_Today.本日开机缺料时间.ToString("0.00"), "小时");
  140. // 本日维修时间
  141. RPrc_Maintenance.Maximum = lineWorkingData_Today.本日开机时间 > lineWorkingData_Today.本日开机维修时间 ? Convert.ToInt32(lineWorkingData_Today.本日开机时间) : Convert.ToInt32(lineWorkingData_Today.本日开机维修时间);
  142. RPrc_Maintenance.Value = lineWorkingData_Today.本日开机维修时间 < 24 ? Convert.ToInt32(lineWorkingData_Today.本日开机维修时间) : 24;
  143. Lbl_Maintenance.Text = string.Concat("本日维修时间:", lineWorkingData_Today.本日开机维修时间.ToString("0.00"), "小时");
  144. // 本日未知状态时间
  145. float unknown = lineWorkingData_Today.本日开机时间 - lineWorkingData_Today.本日开机运行时间
  146. - lineWorkingData_Today.本日开机故障时间 - lineWorkingData_Today.本日开机待机时间
  147. - lineWorkingData_Today.本日开机缺料时间;
  148. unknown = unknown < 24 ? unknown : 24;
  149. unknown = unknown < 0 ? 0 : unknown;
  150. RPrc_Unknown.Maximum = lineWorkingData_Today.本日开机时间 > unknown ? Convert.ToInt32(lineWorkingData_Today.本日开机时间) : Convert.ToInt32(unknown);
  151. RPrc_Unknown.Value = Convert.ToInt32(unknown);
  152. Lbl_Unknown.Text = string.Concat("本次未知状态时间:", unknown.ToString("0.00"), "小时");
  153. }
  154. catch (Exception ex)
  155. {
  156. string str = ex.StackTrace;
  157. AddMessage(LogType.Error, "设备报警统计面板初始化出错!异常位置:" + str.Substring(str.LastIndexOf("\\") + 1, str.Length - str.LastIndexOf("\\") - 1) + ";异常信息:" + ex.Message.ToString());
  158. }
  159. }
  160. /// <summary>
  161. /// 更新设备报警信息-48H内的历史报警信息
  162. /// </summary>
  163. public void UpdDeviceAlarm_History_48H()
  164. {
  165. try
  166. {
  167. if (this.InvokeRequired) // 当前线程不是控件UI线程时为true
  168. {
  169. this.Invoke(new Action(UpdDeviceAlarm_History_48H));
  170. return;
  171. }
  172. DateTime dateTime = DateTime.Now.AddDays(-2);
  173. //// dgv_Current
  174. //string querySQL1 = @"select
  175. //LineName 线体名称,
  176. //AlarmType 报警类型,
  177. //AlarmDesc 报警内容,
  178. //StartTime 开始时间
  179. //from AlarmData
  180. //where StartTime > '{0}'
  181. //and PersistTime = 0
  182. //order by StartTime desc";
  183. //querySQL1 = string.Format(querySQL1, dateTime);
  184. //SQLHelper.ExecuteNonDataSet(querySQL1, out DataSet ds, ConnString);
  185. //if (ds != null && ds.Tables.Count > 0)
  186. //{
  187. // dgv_Current.DataSource = ds.Tables[0].DefaultView;
  188. //}
  189. // dgv_History
  190. string querySQL2 = @"select
  191. LineName 线体名称,
  192. AlarmType 报警类型,
  193. AlarmDesc 报警内容,
  194. StartTime 开始时间,
  195. case when [PersistTime]=0 then '-' else cast([PersistTime] as varchar) end as 耗时
  196. from AlarmData
  197. where StartTime > '{0}'
  198. order by StartTime desc";
  199. querySQL2 = string.Format(querySQL2, dateTime);
  200. DataSet dsHis = SQLHelper_New.Query(querySQL2, null);
  201. if (dsHis != null && dsHis.Tables.Count > 0)
  202. {
  203. dgv_History.DataSource = dsHis.Tables[0].DefaultView;
  204. }
  205. }
  206. catch (Exception ex)
  207. {
  208. string str = ex.StackTrace;
  209. AddMessage(LogType.Error, "更新设备报警History信息出错!异常位置:" + str.Substring(str.LastIndexOf("\\") + 1, str.Length - str.LastIndexOf("\\") - 1) + ";异常信息:" + ex.Message.ToString());
  210. }
  211. }
  212. /// <summary>
  213. /// 更新设备报警信息-当前报警信息
  214. /// </summary>
  215. public void UpdDeviceAlarm_Cur(List<DeviceAlarm_Cur> deviceAlarm_Curs)
  216. {
  217. try
  218. {
  219. if (this.InvokeRequired) // 当前线程不是控件UI线程时为true
  220. {
  221. this.Invoke(new Action<List<DeviceAlarm_Cur>>(UpdDeviceAlarm_Cur), deviceAlarm_Curs);
  222. return;
  223. }
  224. if (deviceAlarm_Curs != null)
  225. {
  226. dgv_Current.DataSource = deviceAlarm_Curs;
  227. }
  228. }
  229. catch (Exception ex)
  230. {
  231. string str = ex.StackTrace;
  232. AddMessage(LogType.Error, "更新设备当前报警信息出错!异常位置:" + str.Substring(str.LastIndexOf("\\") + 1, str.Length - str.LastIndexOf("\\") - 1) + ";异常信息:" + ex.Message.ToString());
  233. }
  234. }
  235. #endregion 设备运行信息
  236. private void AddMessage(LogType logType, string msg)
  237. {
  238. MessageEvent?.Invoke(logType, msg);
  239. }
  240. }
  241. /// <summary>
  242. /// 当前设备报警
  243. /// </summary>
  244. public class DeviceAlarm_Cur
  245. {
  246. //LineName 线体名称,
  247. //AlarmType 报警类型,
  248. //AlarmDesc 报警内容,
  249. //StartTime 开始时间
  250. public string 线体名称 { set; get; }
  251. public string 报警类型 { set; get; }
  252. public string 报警内容 { set; get; }
  253. public DateTime 开始时间 { set; get; }
  254. }
  255. }