VIDManager.cs 43 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971
  1. using Aitex.Common.Util;
  2. using Aitex.Core.RT.DataCenter;
  3. using Aitex.Core.RT.Event;
  4. using Aitex.Core.RT.Log;
  5. using Aitex.Core.Util;
  6. using Aitex.Core.Utilities;
  7. using MECF.Framework.Common.Equipment;
  8. using MECF.Framework.Common.SCCore;
  9. using MECF.Framework.Common.Utilities;
  10. using System;
  11. using System.Collections.Generic;
  12. using System.IO;
  13. using System.Linq;
  14. using System.Xml;
  15. using System.Xml.Serialization;
  16. namespace MECF.Framework.Common.FAServices
  17. {
  18. /// <summary>
  19. /// 所有ID 的命名规则:
  20. ///
  21. /// Module(1-399) + Type(1-80) + Unit(1-99) + Parameter (1-999)
  22. ///
  23. /// 最小 1 01 01 001 = 10101001
  24. ///
  25. /// 最大 399 99 99 999 = 3 999 999 999
  26. ///
  27. /// "PPP" 一部分的就是按参数 module=1, type=1, unit=1, parameter="AAA"
  28. ///
  29. ///
  30. /// </summary>
  31. ///
  32. ///
  33. public class VIDGenerator
  34. {
  35. public string Type { get; set; }
  36. public string SourceFileName { get; set; }
  37. public List<VIDItem> VIDList = new List<VIDItem>();
  38. public Dictionary<string, int> _moduleIndex = new Dictionary<string, int>();
  39. public Dictionary<string, Dictionary<string, Dictionary<string, Dictionary<string, int>>>> moduleTypeUnitParamIndex = new Dictionary<string, Dictionary<string, Dictionary<string, Dictionary<string, int>>>>();
  40. public Dictionary<string, int> _index = new Dictionary<string, int>();
  41. private string _defaultPathFile;
  42. private string _type;
  43. public VIDGenerator(string type, string defaultPathFile)
  44. {
  45. _type = type;
  46. _defaultPathFile = defaultPathFile;
  47. }
  48. public void Initialize()
  49. {
  50. XmlDocument xml = new XmlDocument();
  51. try
  52. {
  53. EnumLoop<ModuleName>.ForEach((item) =>
  54. {
  55. moduleTypeUnitParamIndex[item.ToString()] = new Dictionary<string, Dictionary<string, Dictionary<string, int>>>();
  56. });
  57. xml.Load(_defaultPathFile);
  58. VIDList = CustomXmlSerializer.Deserialize<List<VIDItem>>(xml.OuterXml);
  59. foreach (var VIDItem in VIDList)
  60. {
  61. //_moduleTypeIndex[VIDItem.Type] = VIDItem.TypeIndex;
  62. //_moduleTypeUnitIndex[VIDItem.Unit] = VIDItem.UnitIndex;
  63. //_parameterIndex[VIDItem.Parameter] = VIDItem.ParameterIndex;
  64. if (!moduleTypeUnitParamIndex.ContainsKey(VIDItem.Module))
  65. {
  66. moduleTypeUnitParamIndex[VIDItem.Module] = new Dictionary<string, Dictionary<string, Dictionary<string, int>>>();
  67. }
  68. if (!moduleTypeUnitParamIndex[VIDItem.Module].ContainsKey(VIDItem.Type))
  69. {
  70. moduleTypeUnitParamIndex[VIDItem.Module][VIDItem.Type] = new Dictionary<string, Dictionary<string, int>>();
  71. }
  72. if (!moduleTypeUnitParamIndex[VIDItem.Module][VIDItem.Type].ContainsKey(VIDItem.Unit))
  73. {
  74. moduleTypeUnitParamIndex[VIDItem.Module][VIDItem.Type][VIDItem.Unit] = new Dictionary<string, int>();
  75. }
  76. moduleTypeUnitParamIndex[VIDItem.Module][VIDItem.Type][VIDItem.Unit][VIDItem.Parameter] = VIDItem.Index;
  77. _index[VIDItem.Name] = VIDItem.Index;
  78. }
  79. //XmlNodeList itemNodes = xml.SelectNodes("DataItems/DataItem");
  80. //foreach (var itemNode in itemNodes)
  81. //{
  82. // XmlElement element = itemNode as XmlElement;
  83. // if (element == null)
  84. // continue;
  85. // string name = element.GetAttribute("name").Trim();
  86. // string index = element.GetAttribute("index").Trim();
  87. // if (string.IsNullOrEmpty(name) || string.IsNullOrEmpty(index) || (index.Length != 9 && index.Length != 8))
  88. // continue;
  89. // var item = ParseName(name);
  90. // _moduleTypeIndex[$"{item.Item1}.{item.Item2}"] = int.Parse(index.Substring(index.Length - 7, 2));
  91. // _moduleTypeUnitIndex[$"{item.Item1}.{item.Item2}.{item.Item3}"] = int.Parse(index.Substring(index.Length - 5, 2));
  92. // _parameterIndex[$"{item.Item1}.{item.Item2}.{item.Item3}.{item.Item4}"] =
  93. // int.Parse(index.Substring(index.Length - 3, 3));
  94. // if (!_max.ContainsKey($"{item.Item1}"))
  95. // _max[$"{item.Item1}"] = 0;
  96. // _max[$"{item.Item1}"] =
  97. // Math.Max(_moduleTypeIndex[$"{item.Item1}.{item.Item2}"], _max[$"{item.Item1}"]);
  98. // if (!_max.ContainsKey($"{item.Item1}.{item.Item2}"))
  99. // _max[$"{item.Item1}.{item.Item2}"] = 0;
  100. // _max[$"{item.Item1}.{item.Item2}"] =
  101. // Math.Max(_moduleTypeUnitIndex[$"{item.Item1}.{item.Item2}.{item.Item3}"], _max[$"{item.Item1}.{item.Item2}"]);
  102. // if (!_max.ContainsKey($"{item.Item1}.{item.Item2}.{item.Item3}"))
  103. // _max[$"{item.Item1}.{item.Item2}.{item.Item3}"] = 0;
  104. // _max[$"{item.Item1}.{item.Item2}.{item.Item3}"] =
  105. // Math.Max(_parameterIndex[$"{item.Item1}.{item.Item2}.{item.Item3}.{item.Item4}"], _max[$"{item.Item1}.{item.Item2}.{item.Item3}"]);
  106. // _index[name] = int.Parse(index);
  107. //}
  108. }
  109. catch (Exception ex)
  110. {
  111. LOG.Write(ex);
  112. }
  113. EnumLoop<ModuleName>.ForEach((item) =>
  114. {
  115. _moduleIndex[item.ToString()] = ((int)item) + 1;
  116. });
  117. }
  118. public Tuple<string, string, string, string> ParseName(string name)
  119. {
  120. if (string.IsNullOrEmpty(name))
  121. return null;
  122. string module = ModuleName.System.ToString();
  123. string type = "";
  124. string unit = "";
  125. string parameter = "";
  126. string[] names = name.Split('.');
  127. if (names.Length >= 1)
  128. {
  129. parameter = names[names.Length - 1];
  130. if (names.Length >= 2)
  131. {
  132. if (_moduleIndex.ContainsKey(names[0]))
  133. {
  134. module = names[0];
  135. if (names.Length >= 3)
  136. {
  137. unit = names[names.Length - 2];
  138. if (names.Length >= 4)
  139. {
  140. for (int j = 1; j < names.Length - 2; j++)
  141. {
  142. type += names[j];
  143. if (j != names.Length - 3)
  144. type += ".";
  145. }
  146. }
  147. }
  148. }
  149. else
  150. {
  151. //module = module;
  152. unit = names[names.Length - 2];
  153. if (names.Length >= 3)
  154. {
  155. for (int j = 0; j < names.Length - 2; j++)
  156. {
  157. type += names[j];
  158. if (j != names.Length - 3)
  159. type += ".";
  160. }
  161. }
  162. }
  163. }
  164. }
  165. return Tuple.Create(module, type, unit, parameter);
  166. }
  167. public void GenerateId(List<VIDItem> dataList)
  168. {
  169. List<VIDItem> newList = new List<VIDItem>();
  170. foreach (var data in dataList)
  171. {
  172. if (!_index.ContainsKey(data.Name))
  173. newList.Add(data);
  174. }
  175. if (newList.Count > 0)
  176. {
  177. AssignNewId(newList);
  178. VIDList = VIDList.Concat(newList).OrderBy(x => x.Index).ToList();
  179. if (File.Exists(_defaultPathFile))
  180. CustomXmlSerializer.Serialize(VIDList, _defaultPathFile);
  181. }
  182. }
  183. private void AssignNewId(List<VIDItem> dataList)
  184. {
  185. if (dataList.Count == 0)
  186. return;
  187. dataList = dataList.OrderBy(x => x.Name).ToList();
  188. foreach (var data in dataList)
  189. {
  190. data.Name = data.Name;
  191. if (!moduleTypeUnitParamIndex.ContainsKey(data.Module))
  192. {
  193. moduleTypeUnitParamIndex[data.Module] = new Dictionary<string, Dictionary<string, Dictionary<string, int>>>();
  194. moduleTypeUnitParamIndex[data.Module][data.Type] = new Dictionary<string, Dictionary<string, int>>();
  195. moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit] = new Dictionary<string, int>();
  196. data.ModuleIndex = moduleTypeUnitParamIndex.Keys.ToList().FindIndex(x => x == data.Module) + 1;
  197. data.TypeIndex = 1;
  198. data.UnitIndex = 1;
  199. data.ParameterIndex = 1;
  200. moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter] = int.Parse($"{ data.ModuleIndex}{data.TypeIndex.ToString().PadLeft(2, '0')}{data.UnitIndex.ToString().PadLeft(2, '0')}{ data.ParameterIndex.ToString().PadLeft(3, '0')}");
  201. data.Index = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter];
  202. continue;
  203. }
  204. if (!moduleTypeUnitParamIndex[data.Module].ContainsKey(data.Type))
  205. {
  206. moduleTypeUnitParamIndex[data.Module][data.Type] = new Dictionary<string, Dictionary<string, int>>();
  207. moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit] = new Dictionary<string, int>();
  208. data.ModuleIndex = moduleTypeUnitParamIndex.Keys.ToList().FindIndex(x => x == data.Module) + 1;
  209. data.TypeIndex = moduleTypeUnitParamIndex[data.Module].Count;
  210. data.UnitIndex = 1;
  211. data.ParameterIndex = 1;
  212. moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter] = int.Parse($"{ data.ModuleIndex}{data.TypeIndex.ToString().PadLeft(2, '0')}{data.UnitIndex.ToString().PadLeft(2, '0')}{ data.ParameterIndex.ToString().PadLeft(3, '0')}");
  213. data.Index = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter];
  214. continue;
  215. }
  216. if (!moduleTypeUnitParamIndex[data.Module][data.Type].ContainsKey(data.Unit))
  217. {
  218. moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit] = new Dictionary<string, int>();
  219. data.ModuleIndex = moduleTypeUnitParamIndex.Keys.ToList().FindIndex(x => x == data.Module) + 1;
  220. data.TypeIndex = moduleTypeUnitParamIndex[data.Module].Keys.ToList().FindIndex(x => x == data.Type) + 2;
  221. data.UnitIndex = moduleTypeUnitParamIndex[data.Module][data.Type].Count;
  222. data.ParameterIndex = 1;
  223. moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter] = int.Parse($"{ data.ModuleIndex}{data.TypeIndex.ToString().PadLeft(2, '0')}{data.UnitIndex.ToString().PadLeft(2, '0')}{ data.ParameterIndex.ToString().PadLeft(3, '0')}");
  224. data.Index = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter];
  225. continue;
  226. }
  227. moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter] = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit].Last().Value + 1;
  228. data.Index = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter];
  229. }
  230. //XmlDocument xml = new XmlDocument();
  231. //try
  232. //{
  233. // xml.Load(_defaultPathFile);
  234. // XmlNode itemNodes = xml.SelectSingleNode("DataItems");
  235. // itemNodes.RemoveAll();
  236. // Dictionary<int, string> orderedName = _index.OrderBy(o => o.Value).ToDictionary(p => p.Value, o => o.Key);
  237. // foreach (var name in orderedName)
  238. // {
  239. // XmlElement subNode = xml.CreateElement("DataItem");
  240. // subNode.SetAttribute("name", name.Value);
  241. // subNode.SetAttribute("index", name.Key.ToString());
  242. // itemNodes.AppendChild(subNode);
  243. // }
  244. // xml.Save(_defaultPathFile);
  245. //}
  246. //catch (Exception ex)
  247. //{
  248. // LOG.Write(ex);
  249. //}
  250. }
  251. }
  252. public class VIDManager : Singleton<VIDManager>
  253. {
  254. public void Initialize(string equipName, bool enableGem300Events = false, bool needReGenerateGemModelXml = false)
  255. {
  256. if (!System.Diagnostics.Debugger.IsAttached)
  257. return;
  258. //SVID
  259. var svid = new VIDGenerator("SVID", $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_SVID.xml");
  260. svid.Initialize();
  261. svid.GenerateId(Singleton<DataManager>.Instance.VidDataList);
  262. ExportSvid(svid.VIDList, true, true);
  263. //ECID
  264. var ecid = new VIDGenerator("ECID", $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_ECID.xml");
  265. ecid.Initialize();
  266. ecid.GenerateId(SystemConfigManager.Instance.VidConfigList);
  267. ExportEcid(ecid.VIDList);
  268. //CEID
  269. List<VIDItem> ceids = new List<VIDItem>();
  270. foreach (var eventItem in Singleton<EventManager>.Instance.VidEventList)
  271. {
  272. if (UniversalEvents.UniversalEventsDictionary.ContainsKey(eventItem.Name))
  273. {
  274. ceids.Add(UniversalEvents.UniversalEventsDictionary[eventItem.Name]);
  275. }
  276. else if (enableGem300Events && Gem300Events.Gem300EventsDictionary.ContainsKey(eventItem.Name))
  277. {
  278. ceids.Add(Gem300Events.Gem300EventsDictionary[eventItem.Name]);
  279. }
  280. }
  281. ceids = ceids.OrderBy(x => x.Index).ToList();
  282. CustomXmlSerializer.Serialize(ceids, $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_CEID.xml");
  283. ExportCeid(ceids);
  284. //ALID
  285. var alid = new VIDGenerator("ALID", $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_ALID.xml");
  286. alid.Initialize();
  287. alid.GenerateId(Singleton<EventManager>.Instance.VidAlarmList);
  288. ExportAlid(alid.VIDList);
  289. //DVID, to be designed
  290. Dictionary<string, VIDItem> dvids = new Dictionary<string, VIDItem>();
  291. foreach (var eventItem in ceids)
  292. {
  293. if (eventItem.LinkableVid == null)
  294. continue;
  295. foreach (var LinkableVid in eventItem.LinkableVid)
  296. {
  297. string dvidName = ((DataVariables.DataName)LinkableVid).ToString();
  298. if (DataVariables.DataVariablesDictionary.ContainsKey(dvidName))
  299. dvids[dvidName] = DataVariables.DataVariablesDictionary[dvidName];
  300. }
  301. }
  302. var dvidList = dvids.Values.ToList().OrderBy(x => x.Index).ToList();
  303. CustomXmlSerializer.Serialize(dvidList, $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_DVID.xml");
  304. ExportDvid(dvidList);
  305. //ReGenerate GemModel.Xml
  306. if (needReGenerateGemModelXml)
  307. ReGenerateGemModelXml(svid.VIDList, ecid.VIDList, dvidList, ceids, alid.VIDList, equipName);
  308. }
  309. private List<VIDItem> OriginalSvids = new List<VIDItem>()
  310. {
  311. new VIDItem(){Name = "AlarmsEnabled",Index = 1,DataType = "List"},
  312. new VIDItem(){Name = "AlarmsSet",Index = 2,DataType = "List"},
  313. new VIDItem(){Name = "Clock",Index = 3,DataType = "Ascii"},
  314. new VIDItem(){Name = "ControlState",Index = 4,DataType = "U4"},
  315. new VIDItem(){Name = "EventsEnabled",Index = 5,DataType = "List"},
  316. new VIDItem(){Name = "PPExecName",Index = 6,DataType = "Ascii"},
  317. new VIDItem(){Name = "PreviousProcessState",Index = 7,DataType = "U1"},
  318. new VIDItem(){Name = "ProcessState",Index = 8,DataType = "U1"},
  319. new VIDItem(){Name = "SpoolCountActual",Index = 9,DataType = "U4"},
  320. new VIDItem(){Name = "SpoolCountTotal",Index = 10,DataType = "U4"},
  321. new VIDItem(){Name = "SpoolFullTime",Index = 11,DataType = "Ascii"},
  322. new VIDItem(){Name = "SpoolStartTime",Index = 12,DataType = "Ascii"},
  323. new VIDItem(){Name = "SpoolState",Index = 13,DataType = "Ascii"},
  324. new VIDItem(){Name = "SpoolSubstate",Index = 14,DataType = "Ascii"},
  325. };
  326. private List<VIDItem> OriginalEcids = new List<VIDItem>()
  327. {
  328. new VIDItem(){Name = "EstablishCommunicationsTimeout",Index = 2000,DataType = "U2",Description = "2"},
  329. new VIDItem(){Name = "MaxSpoolTransmit",Index = 2001,DataType = "U4",Description = "100"},
  330. new VIDItem(){Name = "OverWriteSpool",Index = 2003,DataType = "Boolean",Description = "FALSE"},
  331. new VIDItem(){Name = "MaxSpoolCapacity",Index = 2005,DataType = "U4",Description = "100"},
  332. new VIDItem(){Name = "SpoolEnabled",Index = 2006,DataType = "Boolean",Description = "False"},
  333. new VIDItem(){Name = "TimeFormat",Index = 2007,DataType = "U1",Description = "0"},
  334. };
  335. private void ExportAlid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  336. {
  337. var lists = dataList.OrderBy(x => x.ModuleIndex).ThenBy(x => x.Name).ToList();
  338. bool? result = defaultPath;
  339. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  340. if (!defaultPath)
  341. {
  342. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  343. dlg.DefaultExt = ".xlsx"; // Default file extension
  344. dlg.FileName = $"Equipment_VIDs_{DateTime.Now:yyyyMMdd_HHmmss}";
  345. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  346. result = dlg.ShowDialog();// Show open file dialog box
  347. savePath = dlg.FileName;
  348. }
  349. if (result == true)
  350. {
  351. System.Data.DataSet ds = new System.Data.DataSet();
  352. ds.Tables.Add(new System.Data.DataTable("ALID(Alarm ID)"));
  353. ds.Tables[0].Columns.Add("ALID");
  354. ds.Tables[0].Columns.Add("Name");
  355. ds.Tables[0].Columns.Add("Description");
  356. ds.Tables[0].Columns.Add("AlarmSet");
  357. ds.Tables[0].Columns.Add("AlarmClear");
  358. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  359. foreach (var item in lists)
  360. {
  361. var row = ds.Tables[0].NewRow();
  362. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  363. IdDictionary[item.ModuleIndex] = 0;
  364. row[0] = item.Index;
  365. row[1] = item.Name;
  366. if (string.IsNullOrEmpty(item.Description))
  367. {
  368. var arr = item.Name.Split('.');
  369. for (int i = 0; i < arr.Length; i++)
  370. row[2] += $"{arr[i]} ";
  371. }
  372. else
  373. {
  374. row[2] = item.Description;
  375. }
  376. row[3] = $"10{item.ModuleIndex.ToString().PadLeft(3, '0')}01";
  377. row[4] = $"20{item.ModuleIndex.ToString().PadLeft(3, '0')}01";
  378. ds.Tables[0].Rows.Add(row);
  379. }
  380. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  381. {
  382. LOG.Write($"Export failed, {reason}");
  383. return;
  384. }
  385. LOG.Write($"Export succeed, file save as {savePath}");
  386. }
  387. }
  388. private void ExportCeid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  389. {
  390. var lists = dataList.OrderBy(x => x.Index).ToList();
  391. bool? result = defaultPath;
  392. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  393. if (!defaultPath)
  394. {
  395. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  396. dlg.DefaultExt = ".xlsx"; // Default file extension
  397. dlg.FileName = $"Equipment_VIDs_{DateTime.Now:yyyyMMdd_HHmmss}";
  398. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  399. result = dlg.ShowDialog();// Show open file dialog box
  400. savePath = dlg.FileName;
  401. }
  402. if (result == true)
  403. {
  404. System.Data.DataSet ds = new System.Data.DataSet();
  405. ds.Tables.Add(new System.Data.DataTable("CEID(Collection Events)"));
  406. ds.Tables[0].Columns.Add("CEID");
  407. ds.Tables[0].Columns.Add("Name");
  408. ds.Tables[0].Columns.Add("LinkableVID");
  409. ds.Tables[0].Columns.Add("Description");
  410. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  411. foreach (var item in lists)
  412. {
  413. var row = ds.Tables[0].NewRow();
  414. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  415. IdDictionary[item.ModuleIndex] = 0;
  416. row[0] = item.Index;
  417. row[1] = item.Name;
  418. if (item.LinkableVid != null)
  419. {
  420. string LinkableVidDescription = String.Empty;
  421. for (int i = 0; i < item.LinkableVid.Length; i++)
  422. {
  423. LinkableVidDescription += $"{(DataVariables.DataName)item.LinkableVid[i]} = {item.LinkableVid[i]} \r\n";
  424. }
  425. row[2] = LinkableVidDescription;
  426. }
  427. if (string.IsNullOrEmpty(item.Description))
  428. {
  429. var arr = item.Name.Split('.');
  430. for (int i = 0; i < arr.Length; i++)
  431. row[3] += $"{arr[i]} ";
  432. }
  433. else
  434. {
  435. row[3] = item.Description;
  436. }
  437. ds.Tables[0].Rows.Add(row);
  438. }
  439. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  440. {
  441. LOG.Write($"Export failed, {reason}");
  442. return;
  443. }
  444. LOG.Write($"Export succeed, file save as {savePath}");
  445. }
  446. }
  447. private void ExportEcid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  448. {
  449. var lists = dataList.OrderBy(x => x.Index).ToList();
  450. bool? result = defaultPath;
  451. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  452. if (!defaultPath)
  453. {
  454. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  455. dlg.DefaultExt = ".xlsx"; // Default file extension
  456. dlg.FileName = $"Equipment_VIDs_{DateTime.Now:yyyyMMdd_HHmmss}";
  457. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  458. result = dlg.ShowDialog();// Show open file dialog box
  459. savePath = dlg.FileName;
  460. }
  461. if (result == true)
  462. {
  463. System.Data.DataSet ds = new System.Data.DataSet();
  464. ds.Tables.Add(new System.Data.DataTable("ECID(Equipment Constant)"));
  465. ds.Tables[0].Columns.Add("ECID");
  466. ds.Tables[0].Columns.Add("Name");
  467. ds.Tables[0].Columns.Add("Format");
  468. ds.Tables[0].Columns.Add("Description");
  469. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  470. foreach (var item in lists)
  471. {
  472. var row = ds.Tables[0].NewRow();
  473. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  474. IdDictionary[item.ModuleIndex] = 0;
  475. row[0] = item.Index;
  476. row[1] = item.Name;
  477. row[2] = VIDItemType2GemDataType(item.DataType);
  478. if (string.IsNullOrEmpty(item.Description))
  479. {
  480. var arr = item.Name.Split('.');
  481. for (int i = 0; i < arr.Length; i++)
  482. row[3] += $"{arr[i]} ";
  483. }
  484. else
  485. {
  486. row[3] = item.Description;
  487. }
  488. ds.Tables[0].Rows.Add(row);
  489. }
  490. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  491. {
  492. LOG.Write($"Export failed, {reason}");
  493. return;
  494. }
  495. LOG.Write($"Export succeed, file save as {savePath}");
  496. }
  497. }
  498. private void ExportSvid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  499. {
  500. var lists = dataList.OrderBy(x => x.Index).ToList();
  501. bool? result = defaultPath;
  502. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  503. if (!defaultPath)
  504. {
  505. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  506. dlg.DefaultExt = ".xlsx"; // Default file extension
  507. dlg.FileName = $"Chamber_Status_Variable_{DateTime.Now:yyyyMMdd_HHmmss}";
  508. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  509. result = dlg.ShowDialog();// Show open file dialog box
  510. savePath = dlg.FileName;
  511. }
  512. if (result == true)
  513. {
  514. System.Data.DataSet ds = new System.Data.DataSet();
  515. ds.Tables.Add(new System.Data.DataTable("SVID(Status Variable)"));
  516. ds.Tables[0].Columns.Add("SVID");
  517. ds.Tables[0].Columns.Add("Name");
  518. ds.Tables[0].Columns.Add("Format");
  519. ds.Tables[0].Columns.Add("Description");
  520. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  521. foreach (var item in lists)
  522. {
  523. var row = ds.Tables[0].NewRow();
  524. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  525. IdDictionary[item.ModuleIndex] = 0;
  526. row[0] = item.Index;
  527. row[1] = item.Name;
  528. row[2] = VIDItemType2GemDataType(item.DataType);
  529. if (string.IsNullOrEmpty(item.Description))
  530. {
  531. var arr = item.Name.Split('.');
  532. for (int i = 0; i < arr.Length; i++)
  533. row[3] += $"{arr[i]} ";
  534. }
  535. else
  536. {
  537. row[3] = item.Description;
  538. }
  539. ds.Tables[0].Rows.Add(row);
  540. }
  541. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  542. {
  543. LOG.Write($"Export failed, {reason}");
  544. return;
  545. }
  546. LOG.Write($"Export succeed, file save as {savePath}");
  547. }
  548. }
  549. private void ExportDvid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  550. {
  551. var lists = dataList.OrderBy(x => x.Index).ToList();
  552. bool? result = defaultPath;
  553. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  554. if (!defaultPath)
  555. {
  556. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  557. dlg.DefaultExt = ".xlsx"; // Default file extension
  558. dlg.FileName = $"Data_Variable_{DateTime.Now:yyyyMMdd_HHmmss}";
  559. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  560. result = dlg.ShowDialog();// Show open file dialog box
  561. savePath = dlg.FileName;
  562. }
  563. if (result == true)
  564. {
  565. System.Data.DataSet ds = new System.Data.DataSet();
  566. ds.Tables.Add(new System.Data.DataTable("DVID(Data Variable)"));
  567. ds.Tables[0].Columns.Add("DVID");
  568. ds.Tables[0].Columns.Add("Name");
  569. ds.Tables[0].Columns.Add("Format");
  570. ds.Tables[0].Columns.Add("Description");
  571. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  572. foreach (var item in lists)
  573. {
  574. var row = ds.Tables[0].NewRow();
  575. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  576. IdDictionary[item.ModuleIndex] = 0;
  577. row[0] = item.Index;
  578. row[1] = item.Name;
  579. row[2] = VIDItemType2GemDataType(item.DataType);
  580. if (string.IsNullOrEmpty(item.Description))
  581. {
  582. var arr = item.Name.Split('.');
  583. for (int i = 0; i < arr.Length; i++)
  584. row[3] += $"{arr[i]} ";
  585. }
  586. else
  587. {
  588. row[3] = item.Description;
  589. }
  590. ds.Tables[0].Rows.Add(row);
  591. }
  592. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  593. {
  594. LOG.Write($"Export failed, {reason}");
  595. return;
  596. }
  597. LOG.Write($"Export succeed, file save as {savePath}");
  598. }
  599. }
  600. private void ReGenerateGemModelXml(List<VIDItem> Svids, List<VIDItem> Ecids, List<VIDItem> Dvids, List<VIDItem> Ceids, List<VIDItem> Alids, string equipName)
  601. {
  602. XmlDocument xml = new XmlDocument();
  603. string _defaultPathFile = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}{equipName}GemModel.xml";
  604. try
  605. {
  606. xml.Load(_defaultPathFile);
  607. if (Svids != null)
  608. {
  609. XmlNode itemNodes = xml.SelectSingleNode("Equipment/StatusVariables");
  610. itemNodes.RemoveAll();
  611. foreach (var svid in OriginalSvids)
  612. {
  613. XmlElement subNode = xml.CreateElement("SVID");
  614. subNode.SetAttribute("id", svid.Index.ToString());
  615. subNode.SetAttribute("valueType", svid.DataType);
  616. subNode.SetAttribute("logicalName", svid.Name);
  617. subNode.SetAttribute("value", "");
  618. subNode.SetAttribute("eventTrigger", "");
  619. subNode.SetAttribute("units", "");
  620. subNode.SetAttribute("description", svid.Description);
  621. subNode.SetAttribute("isArray", "false");
  622. itemNodes.AppendChild(subNode);
  623. }
  624. foreach (var svid in Svids)
  625. {
  626. XmlElement subNode = xml.CreateElement("SVID");
  627. subNode.SetAttribute("id", svid.Index.ToString());
  628. subNode.SetAttribute("valueType", VIDItemType2GemDataType(svid.DataType));
  629. subNode.SetAttribute("logicalName", svid.Name);
  630. subNode.SetAttribute("value", "");
  631. subNode.SetAttribute("eventTrigger", "");
  632. subNode.SetAttribute("units", "");
  633. subNode.SetAttribute("description", svid.Description);
  634. subNode.SetAttribute("isArray", "false");
  635. itemNodes.AppendChild(subNode);
  636. }
  637. }
  638. if (Ecids != null)
  639. {
  640. XmlNode itemNodes = xml.SelectSingleNode("Equipment/EquipmentConstants");
  641. itemNodes.RemoveAll();
  642. foreach (var ecid in OriginalEcids)
  643. {
  644. XmlElement subNode = xml.CreateElement("ECID");
  645. subNode.SetAttribute("id", ecid.Index.ToString());
  646. subNode.SetAttribute("valueType", ecid.DataType);
  647. subNode.SetAttribute("logicalName", ecid.Name);
  648. subNode.SetAttribute("value", ecid.Description);
  649. subNode.SetAttribute("min", "0");
  650. subNode.SetAttribute("max", "100");
  651. subNode.SetAttribute("eventTrigger", "");
  652. subNode.SetAttribute("units", "");
  653. subNode.SetAttribute("description", "");
  654. subNode.SetAttribute("isArray", "false");
  655. itemNodes.AppendChild(subNode);
  656. }
  657. foreach (var ecid in Ecids)
  658. {
  659. XmlElement subNode = xml.CreateElement("ECID");
  660. subNode.SetAttribute("id", ecid.Index.ToString());
  661. subNode.SetAttribute("valueType", VIDItemType2GemDataType(ecid.DataType));
  662. subNode.SetAttribute("logicalName", ecid.Name);
  663. subNode.SetAttribute("value", "");
  664. subNode.SetAttribute("min", "");
  665. subNode.SetAttribute("max", "");
  666. subNode.SetAttribute("eventTrigger", "");
  667. subNode.SetAttribute("units", "");
  668. subNode.SetAttribute("description", ecid.Description);
  669. subNode.SetAttribute("isArray", "false");
  670. itemNodes.AppendChild(subNode);
  671. }
  672. }
  673. if (Dvids != null)
  674. {
  675. XmlNode itemNodes = xml.SelectSingleNode("Equipment/DataVariables");
  676. itemNodes.RemoveAll();
  677. foreach (var dvids in Dvids)
  678. {
  679. if (dvids.Index < 500)
  680. continue;
  681. XmlElement subNode = xml.CreateElement("DVID");
  682. subNode.SetAttribute("id", dvids.Index.ToString());
  683. subNode.SetAttribute("valueType", VIDItemType2GemDataType(dvids.DataType));
  684. subNode.SetAttribute("logicalName", dvids.Name);
  685. subNode.SetAttribute("value", "");
  686. subNode.SetAttribute("eventTrigger", "");
  687. subNode.SetAttribute("description", dvids.Description);
  688. subNode.SetAttribute("isArray", "false");
  689. itemNodes.AppendChild(subNode);
  690. }
  691. }
  692. var moduleAlarmEventsDictionary = new Dictionary<int, string>();
  693. if (Alids != null)
  694. {
  695. XmlNode itemNodes = xml.SelectSingleNode("Equipment/Alarms");
  696. itemNodes.RemoveAll();
  697. foreach (var alid in Alids)
  698. {
  699. XmlElement subNode = xml.CreateElement("ALID");
  700. subNode.SetAttribute("id", alid.Index.ToString());
  701. subNode.SetAttribute("logicalName", alid.Name);
  702. subNode.SetAttribute("description", alid.Description);
  703. subNode.SetAttribute("category", "EquipmentStatusWarning");
  704. subNode.SetAttribute("enabled", "false");
  705. subNode.SetAttribute("eventSet", $"10{alid.ModuleIndex.ToString().PadLeft(3, '0')}01");
  706. subNode.SetAttribute("eventClear", $"20{alid.ModuleIndex.ToString().PadLeft(3, '0')}01");
  707. itemNodes.AppendChild(subNode);
  708. moduleAlarmEventsDictionary[alid.ModuleIndex] = alid.Module;
  709. }
  710. }
  711. if (Ceids != null)
  712. {
  713. int reportID = 0;
  714. Dictionary<string, int> reportDictionary = new Dictionary<string, int>();
  715. XmlNode RPTIDNodes = xml.SelectSingleNode("Equipment/DataCollections/RPTIDs");
  716. RPTIDNodes.RemoveAll();
  717. foreach (var ceid in Ceids)
  718. {
  719. XmlElement RPTID = xml.CreateElement("RPTID");
  720. if (ceid.LinkableVid != null)
  721. {
  722. string reportKey = string.Join(",", ceid.LinkableVid);
  723. if (!reportDictionary.ContainsKey(reportKey))
  724. {
  725. reportID += 1;
  726. reportDictionary[reportKey] = reportID;
  727. RPTID.SetAttribute("id", reportID.ToString());
  728. RPTID.SetAttribute("logicalName", $"DefaultDefinedReport_{reportID}");
  729. foreach (var vid in ceid.LinkableVid)
  730. {
  731. XmlElement ReportVariable = xml.CreateElement("ReportVariable");
  732. ReportVariable.SetAttribute("id", vid.ToString());
  733. ReportVariable.SetAttribute("varType", vid < 500 ? "StatusVariable" : "DataVariable");
  734. ReportVariable.SetAttribute("logicalName", ((DataVariables.DataName)vid).ToString());
  735. RPTID.AppendChild(ReportVariable);
  736. }
  737. RPTIDNodes.AppendChild(RPTID);
  738. }
  739. }
  740. }
  741. XmlNode CEIDNodes = xml.SelectSingleNode("Equipment/DataCollections/CEIDs");
  742. CEIDNodes.RemoveAll();
  743. foreach (var ceid in Ceids)
  744. {
  745. XmlElement CEID = xml.CreateElement("CEID");
  746. CEID.SetAttribute("id", ceid.Index.ToString());
  747. CEID.SetAttribute("logicalName", ceid.Name);
  748. CEID.SetAttribute("description", ceid.Description);
  749. CEID.SetAttribute("enabled", "true");
  750. if (ceid.LinkableVid != null)
  751. {
  752. string reportKey = string.Join(",", ceid.LinkableVid);
  753. XmlElement RPTID = xml.CreateElement("RPTID");
  754. RPTID.SetAttribute("id", reportDictionary[reportKey].ToString());
  755. RPTID.SetAttribute("logicalName", $"DefaultDefinedReport_{reportDictionary[reportKey]}");
  756. foreach (var vid in ceid.LinkableVid)
  757. {
  758. XmlElement ReportVariable = xml.CreateElement("ReportVariable");
  759. ReportVariable.SetAttribute("id", vid.ToString());
  760. ReportVariable.SetAttribute("varType", vid < 500 ? "StatusVariable" : "DataVariable");
  761. ReportVariable.SetAttribute("logicalName", ((DataVariables.DataName)vid).ToString());
  762. RPTID.AppendChild(ReportVariable);
  763. }
  764. CEID.AppendChild(RPTID);
  765. }
  766. CEIDNodes.AppendChild(CEID);
  767. }
  768. foreach (var alarmEvent in moduleAlarmEventsDictionary)
  769. {
  770. XmlElement EventSet = xml.CreateElement("CEID");
  771. EventSet.SetAttribute("id", $"10{alarmEvent.Key.ToString().PadLeft(3, '0')}01");
  772. EventSet.SetAttribute("logicalName", $"__SYSTEM__10{alarmEvent.Key.ToString().PadLeft(3, '0')}01__ALARMSET");
  773. EventSet.SetAttribute("description", $"Alarm Set : {alarmEvent.Value} Error");
  774. EventSet.SetAttribute("enabled", "true");
  775. CEIDNodes.AppendChild(EventSet);
  776. XmlElement EventClear = xml.CreateElement("CEID");
  777. EventClear.SetAttribute("id", $"20{alarmEvent.Key.ToString().PadLeft(3, '0')}01");
  778. EventClear.SetAttribute("logicalName", $"__SYSTEM__20{alarmEvent.Key.ToString().PadLeft(3, '0')}01__ALARMCLEAR");
  779. EventClear.SetAttribute("description", $"Alarm Clear : {alarmEvent.Value} Error");
  780. EventClear.SetAttribute("enabled", "true");
  781. CEIDNodes.AppendChild(EventClear);
  782. }
  783. }
  784. xml.Save(_defaultPathFile);
  785. }
  786. catch (Exception ex)
  787. {
  788. LOG.Write(ex);
  789. }
  790. }
  791. string VIDItemType2GemDataType(string VIDItemType)
  792. {
  793. switch (VIDItemType.Replace("System.", ""))
  794. {
  795. case "List":
  796. return "List";
  797. case "I1":
  798. return "I1";
  799. case "I4":
  800. return "I4";
  801. case "U1":
  802. return "U1";
  803. case "U2":
  804. return "U2";
  805. case "U4":
  806. return "U4";
  807. case "Int":
  808. case "Integer":
  809. return "I4";
  810. case "Bool":
  811. case "Boolean":
  812. return "Boolean";
  813. case "Float":
  814. case "Single":
  815. case "Double":
  816. case "F8":
  817. return "F8";
  818. case "Binary":
  819. return "Binary";
  820. default:
  821. return "Ascii";
  822. }
  823. }
  824. }
  825. }