DeviceStatusInfo.cs 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. using System;
  2. using DevExpress.XtraEditors;
  3. using UAS_PLCDataReader.DataOperate;
  4. using UAS_PLCDataReader.Entity;
  5. using System.Data;
  6. using System.Text;
  7. using UAS_PLCDataReader.PublicMethod;
  8. using System.Windows.Forms;
  9. using System.Collections.Generic;
  10. namespace UAS_PLCDataReader.Device.Infomation
  11. {
  12. public partial class DeviceStatusInfo : XtraForm
  13. {
  14. DataHelper dh = SystemInf.dh;
  15. StringBuilder sql = new StringBuilder();
  16. string de_code = "";
  17. public DeviceStatusInfo()
  18. {
  19. InitializeComponent();
  20. }
  21. public DeviceStatusInfo(string DevcieCode)
  22. {
  23. InitializeComponent();
  24. de_code = DevcieCode;
  25. Text = DevcieCode;
  26. }
  27. private void DeviceStatusInfo_Load(object sender, EventArgs e)
  28. {
  29. //查询设备基础信息
  30. sql.Clear();
  31. sql.Append("select de_linecode,de_wccode,de_name,de_address,de_sourcecode,sc_name from device ");
  32. sql.Append("left join source on sc_code=de_sourcecode where de_code='" + de_code + "'");
  33. DataTable dt = (DataTable)dh.ExecuteSql(sql.ToString(), "select");
  34. if (dt.Rows.Count > 0)
  35. {
  36. BaseUtil.SetFormValue(Controls, dt);
  37. }
  38. //查询设备参数信息
  39. sql.Clear();
  40. sql.Append("select dc_name,case when dc_type='INQTY' then dr_qty when dc_type='OUTQTY' then dr_okqty end data ");
  41. sql.Append("from DEVICEPOLLINGCONFIG left join devicecommand on dpc_dccode = dc_code left join DEVICERUNSTATUS ");
  42. sql.Append("on dpc_decode = dr_decode where dpc_decode = '" + de_code + "'");
  43. GridDeivceStatusInfo.DataSource = (DataTable)dh.ExecuteSql(sql.ToString(), "select");
  44. sql.Clear();
  45. //查询设备运行日志
  46. sql.Append("select * from DEVICERUNRECORD");
  47. GridDeviceRunLog.DataSource = (DataTable)dh.ExecuteSql(sql.ToString(), "select");
  48. sql.Clear();
  49. sql.Append("select '接收'||nvl(dpg_senddatasize,0)||'字节' dpg_receivedatasize,'发送'||nvl(dpg_receivedatasize,0)||'字节' dpg_senddatasize");
  50. sql.Append(",dpg_onlinetime,dpg_offlinetime,'IP:'||dnc_ip dpg_interval,'端口:'|| dnc_port||',间隔'||dpg_interval||'S' dnc_port ");
  51. sql.Append("from devicepollinglog left join DEVICENETCONFIG on dnc_decode=dpg_decode ");
  52. sql.Append("where dpg_id=(select max(dpg_id) from devicepollinglog where dpg_decode='"+de_code+"')");
  53. dt = (DataTable)dh.ExecuteSql(sql.ToString(), "select");
  54. if (dt.Rows.Count > 0)
  55. {
  56. BaseUtil.SetFormValue(this.Controls, dt);
  57. }
  58. if (Main.ReturnData.ContainsKey(de_code))
  59. {
  60. dpg_interval.Text = Main.ReturnData[de_code].SendCount.ToString();
  61. dpg_runtime.Text = (DateTime.Now - Main.ReturnData[de_code].StartTime).TotalMinutes.ToString("f1") + "分钟";
  62. dpg_onlinetime.Text = Main.ReturnData[de_code].StartTime.ToString("yyyy-MM-dd HH:mm:ss");
  63. dpg_senddatasize.Text = Main.ReturnData[de_code].ReceiveDataSize.ToString();
  64. Dictionary<string, string> ItemData = Main.ReturnData[de_code].ItemData;
  65. if (ItemData != null && ItemData.Count > 0)
  66. {
  67. foreach (var item in ItemData)
  68. {
  69. switch (item.Key)
  70. {
  71. case "INQTY":
  72. INQTY.Text = item.Value;
  73. break;
  74. case "OUTQTY":
  75. OUTQTY.Text = item.Value;
  76. break;
  77. case "TEMPERATURE":
  78. break;
  79. default:
  80. break;
  81. }
  82. }
  83. }
  84. }
  85. }
  86. private void DeviceStatusInfo_KeyDown(object sender, KeyEventArgs e)
  87. {
  88. if (e.KeyCode == Keys.Escape)
  89. Close();
  90. }
  91. }
  92. }