frmHmpJob.cs 77 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Text;
  7. using System.Windows.Forms;
  8. using System.Threading;
  9. using Core.LgMes.Client.lgClassModel;
  10. using System.Collections;
  11. using System.Reflection;
  12. using CoreFS.CA06;
  13. using Core.Mes.Client.Common;
  14. using Core.LgMes.Client.LgIntegrationQuery;
  15. using Core.LgMes.Client.LgResMgt;
  16. using Core.LgMes.Client.Report;
  17. namespace Core.LgMes.Client.LgJobMgt
  18. {
  19. public partial class frmHmpJob : CommonClientToServer
  20. {
  21. #region " Class Member Variable"
  22. private string _heatProcessNo = ""; // 加热处理号
  23. private string _hudWid = ""; // 脱硫处理号
  24. private DataTable _dtCraftElement = null; // 工艺化学成分信息表
  25. private DataTable _dtStdElement = null; // 标准成分表
  26. private CommandClass _commClass; // 消息发送类
  27. private string _DEVICE_POSITION = "HMP01"; // 设备位置
  28. private int _DEVICE_POS = 1; // 设备号
  29. private Thread _getDataThread; // 取数据线程
  30. private Thread _setDataThread; // 刷新数据线程
  31. private bool _bIfGetData = true; // 控制取数据线程循环的标志
  32. private bool _bIfSetData = true; // 控制刷新数据线程循环的标志
  33. private bool _bResetDataFlag = false; // 清空所有数据标志,True表示已经清空
  34. private ArrayList _listHeatProcess = null; // 存储加热处理号的数组列表
  35. private Wsid _wsID; // 脱硫工位号 (区分双工位同时脱硫的情况)
  36. private string _devPos = ""; // 当前设备位置的全称
  37. private TrackObjectInfo _tmpObjTrack; // 实时跟踪信息类 用于存放当前实时跟踪信息 起一个中间过渡的缓冲
  38. private TrackObjectInfo _objTrackBuffer; // 用于实时刷新实时跟踪信息的缓冲区
  39. private CraftElement _tmpObjCraftEle; // 存放铁水成分信息的类
  40. private CraftElement _objCraftEleBuffer; // 用于实时刷新铁水成分信息的缓冲区
  41. private Hashtable _htOptInfo; // 用于存储脱硫操作信息的表字段数据
  42. private delegate void SetDataThreadDelegate(); // 刷新数据线程的一个委托方法,目的是达到界面所有数据刷新同步
  43. private string _szWorkBit = "3"; // 初始化为 3 (1 为1#小车; 2 为2# 小车; 3为钢包位)
  44. private string[] ArrayIronRow4 = new string[25] { "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" }; //保存发送到转炉铁水数据
  45. private string _strSendSucceededForBof1 = "";
  46. private string _strSendSucceededForBof2 = "";
  47. private string _strSendSucceededForBof3 = "";
  48. private string strCheckNo = ""; //化学成分编码
  49. #endregion
  50. #region " Enum "
  51. private enum Wsid
  52. {
  53. wdFirst,
  54. wdSecond
  55. }
  56. #endregion
  57. #region " Construct Function "
  58. public frmHmpJob()
  59. {
  60. InitializeComponent();
  61. CheckForIllegalCrossThreadCalls = false;
  62. // 初始化成员变量
  63. _commClass = new CommandClass();
  64. _tmpObjTrack = new TrackObjectInfo();
  65. _objTrackBuffer = new TrackObjectInfo();
  66. _tmpObjCraftEle = new CraftElement();
  67. _objCraftEleBuffer = new CraftElement();
  68. _htOptInfo = new Hashtable();
  69. _wsID = Wsid.wdFirst; // 默认1#工位
  70. }
  71. #endregion
  72. #region " Init Form Element"
  73. private void frmHmpJob_Load(object sender, EventArgs e)
  74. {
  75. //GenerateTableFrame();
  76. GetDevicePosition();
  77. SetUserControlDelegate();
  78. StartUpThread();
  79. }
  80. /// <summary>
  81. /// 获取当前设备的后台实时跟踪信息
  82. /// </summary>
  83. private void GetTrackInfoData()
  84. {
  85. string strErr = "";
  86. ArrayList arry = new ArrayList();
  87. arry.Add("ReceiveTrackObjectData.Select");//此ID为XML文件ID
  88. arry.Add(_DEVICE_POSITION);
  89. //获取指定岗位后台实时跟踪信息
  90. DataSet ds = this.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassTrackObjectInfo",
  91. "ReceiveTrackObjectData", arry, out strErr);
  92. if (strErr == "" && ds != null)
  93. {
  94. DataSetToTrackObject(ref ds, ref _tmpObjTrack);
  95. }
  96. }
  97. /// <summary>
  98. /// 获得加热处理号
  99. /// </summary>
  100. private void GetHeatProcessList()
  101. {
  102. try
  103. {
  104. this._listHeatProcess = new ArrayList();
  105. string Key = "";
  106. string szDevice = "", szBack = "", szFront = "";
  107. RealDataTrackObjectInfor objTrack;
  108. Key = _DEVICE_POSITION + "_DEVICE";
  109. objTrack = (RealDataTrackObjectInfor)_objTrackBuffer.hList[Key];
  110. szDevice = (!string.IsNullOrEmpty(objTrack.OBJECTID)) ? objTrack.OBJECTID + objTrack.DEVICESTATES : "";
  111. Key = _DEVICE_POSITION + "_BACK";
  112. objTrack = (RealDataTrackObjectInfor)_objTrackBuffer.hList[Key];
  113. szBack = (!string.IsNullOrEmpty(objTrack.OBJECTID)) ? objTrack.OBJECTID + objTrack.DEVICESTATES : "";
  114. Key = _DEVICE_POSITION + "_FRONT";
  115. objTrack = (RealDataTrackObjectInfor)_objTrackBuffer.hList[Key];
  116. szFront = (!string.IsNullOrEmpty(objTrack.OBJECTID)) ? objTrack.OBJECTID + objTrack.DEVICESTATES : "";
  117. _listHeatProcess.Add(szFront); //Front (1#脱硫1小车位)
  118. _listHeatProcess.Add(szDevice); //device (1#脱硫工位)
  119. _listHeatProcess.Add(szBack); //Back (1#脱硫2小车位)
  120. }
  121. catch (Exception ex)
  122. {
  123. string msg = ex.Message;
  124. _listHeatProcess = null;
  125. }
  126. }
  127. /// <summary>
  128. /// 对获取到的加热处理号进行判断
  129. /// </summary>
  130. private void JudgeHeatProcess()
  131. {
  132. try
  133. {
  134. if (_listHeatProcess.Count < 3)
  135. return;
  136. _heatProcessNo = "";
  137. _devPos = "";
  138. _hudWid = "";
  139. //Device 1#脱硫工位
  140. if (_wsID == Wsid.wdFirst && _listHeatProcess[1].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  141. {
  142. string strHeat = _listHeatProcess[1].ToString();
  143. _heatProcessNo = strHeat.Substring(0, (int)OBJLEN.nHudwProcessNo);
  144. _devPos = GetDevDeviceCodeOfHmp(_DEVICE_POS);
  145. _hudWid = (_heatProcessNo.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(_heatProcessNo) : "";
  146. }
  147. //Front 2#脱硫工位
  148. if ((_heatProcessNo == "" && _listHeatProcess[0].ToString().Length > (int)OBJLEN.nHudwProcessNo) ||
  149. (_wsID == Wsid.wdSecond && _listHeatProcess[0].ToString().Length > (int)OBJLEN.nHudwProcessNo))
  150. {
  151. string strHeat = _listHeatProcess[0].ToString();
  152. _heatProcessNo = strHeat.Substring(0, (int)OBJLEN.nHudwProcessNo);
  153. _devPos = GetDevFrontCodeOfHmp(_DEVICE_POS);
  154. _hudWid = (_heatProcessNo.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(_heatProcessNo) : "";
  155. }
  156. //Back 脱硫2#小车位
  157. if (_heatProcessNo == "" && _listHeatProcess[2].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  158. {
  159. string strHeat = _listHeatProcess[2].ToString();
  160. _heatProcessNo = strHeat.Substring(0, (int)OBJLEN.nHudwProcessNo);
  161. _devPos = GetDevBackCodeOfHmp(_DEVICE_POS);
  162. _hudWid = (_heatProcessNo.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(_heatProcessNo) : "";
  163. }
  164. }
  165. catch
  166. {
  167. return;
  168. }
  169. }
  170. /// <summary>
  171. /// 获取设备位置信息
  172. /// </summary>
  173. private void GetDevPosInfo()
  174. {
  175. try
  176. {
  177. string strState = "";
  178. if (_listHeatProcess[0].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  179. {
  180. string strHeat = _listHeatProcess[0].ToString();
  181. strState = strHeat.Substring((int)OBJLEN.nHudwProcessNo);
  182. }
  183. else if (_listHeatProcess[1].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  184. {
  185. string strHeat = _listHeatProcess[1].ToString();
  186. strState = strHeat.Substring((int)OBJLEN.nHudwProcessNo);
  187. }
  188. else if (_listHeatProcess[2].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  189. {
  190. string strHeat = _listHeatProcess[2].ToString();
  191. strState = strHeat.Substring((int)OBJLEN.nHudwProcessNo);
  192. }
  193. if (_htOptInfo.Contains("TP"))
  194. _htOptInfo.Remove("TP");
  195. _htOptInfo.Add("TP", SetPic(strState)); // 图片
  196. if (_listHeatProcess.Count >= 3)
  197. {
  198. string szID = _listHeatProcess[0].ToString();
  199. string strFrontPos = ""; //上道工序
  200. szID = _listHeatProcess[0].ToString();
  201. szID = (szID.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(szID.Substring(0, (int)OBJLEN.nHudwProcessNo)) : "";
  202. if (_htOptInfo.Contains("FRONT"))
  203. _htOptInfo.Remove("FRONT");
  204. _htOptInfo.Add("FRONT", szID); // 1#小车位
  205. //处理位信息
  206. RealDataTrackObjectInfor objTrack = (RealDataTrackObjectInfor)_objTrackBuffer.hList["HMP0" + _DEVICE_POS + "_DEVICE"];
  207. szID = _listHeatProcess[1].ToString();
  208. szID = (szID.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(szID.Substring(0, (int)OBJLEN.nHudwProcessNo)) : "";
  209. if (_listHeatProcess[1].ToString().Length > (int)OBJLEN.nHudwProcessNo && _listHeatProcess[1].ToString().Substring(0, (int)OBJLEN.nHudwProcessNo) == objTrack.OBJECTID.ToString())
  210. strFrontPos = objTrack.FRONTPOS.ToString();
  211. if (strFrontPos == "HMP0" + _DEVICE_POS + "_BACK")
  212. {
  213. if (_htOptInfo.Contains("DEVICE2"))
  214. _htOptInfo.Remove("DEVICE2");
  215. _htOptInfo.Add("DEVICE2", szID); // 2#处理位
  216. if (_htOptInfo.Contains("DEVICE"))
  217. _htOptInfo.Remove("DEVICE");
  218. }
  219. else
  220. {
  221. if (_htOptInfo.Contains("DEVICE"))
  222. _htOptInfo.Remove("DEVICE");
  223. _htOptInfo.Add("DEVICE", szID); // 1#处理位
  224. if (_htOptInfo.Contains("DEVICE2"))
  225. _htOptInfo.Remove("DEVICE2");
  226. }
  227. szID = _listHeatProcess[2].ToString();
  228. szID = (szID.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(szID.Substring(0, (int)OBJLEN.nHudwProcessNo)) : "";
  229. if (_htOptInfo.Contains("BACK"))
  230. _htOptInfo.Remove("BACK");
  231. _htOptInfo.Add("BACK", szID); // 2#小车位
  232. }
  233. }
  234. catch { }
  235. }
  236. #region " From DataSet To Buffer "
  237. private void DataSetToTrackObject(ref DataSet ds, ref TrackObjectInfo obj)
  238. {
  239. try
  240. {
  241. obj.ClearElement();
  242. PropertyInfo[] PropertyInfos = null;
  243. foreach (DataRow dr in ds.Tables[0].Rows)
  244. {
  245. RealDataTrackObjectInfor detail = new RealDataTrackObjectInfor();
  246. if (PropertyInfos == null)
  247. {
  248. PropertyInfos = detail.GetType().GetProperties();
  249. }
  250. //给各个属性赋值
  251. foreach (PropertyInfo oPropertyInfo in PropertyInfos)
  252. {
  253. try
  254. {
  255. if (dr[oPropertyInfo.Name] != System.DBNull.Value)
  256. {
  257. oPropertyInfo.SetValue(detail, dr[oPropertyInfo.Name.ToString()], null);
  258. }
  259. }
  260. catch (Exception ex)
  261. {
  262. MessageBox.Show(ex.Message);
  263. }
  264. }
  265. obj.Add(ref detail);
  266. }//end foreach
  267. _objTrackBuffer.DataHarmonize(ref obj);
  268. }
  269. catch (Exception ex)
  270. {
  271. string Msg = ex.Message;
  272. }
  273. finally
  274. {
  275. }
  276. }
  277. private void DataSetToCraftElement(ref DataSet ds, ref CraftElement obj)
  278. {
  279. try
  280. {
  281. obj.ClearElement();
  282. PropertyInfo[] PropertyInfos = null;
  283. foreach (DataRow dr in ds.Tables[0].Rows)
  284. {
  285. JOB_CHEMELEMENT detail = new JOB_CHEMELEMENT();
  286. if (PropertyInfos == null)
  287. {
  288. PropertyInfos = detail.GetType().GetProperties();
  289. }
  290. //给各个属性赋值
  291. foreach (PropertyInfo oPropertyInfo in PropertyInfos)
  292. {
  293. try
  294. {
  295. if (dr[oPropertyInfo.Name] != System.DBNull.Value)
  296. {
  297. oPropertyInfo.SetValue(detail, dr[oPropertyInfo.Name.ToString()], null);
  298. }
  299. }
  300. catch (Exception ex)
  301. {
  302. MessageBox.Show(ex.Message);
  303. }
  304. }
  305. obj.Add(ref detail);
  306. }//end foreach
  307. _objCraftEleBuffer.DataHarmonize(ref obj);
  308. }
  309. catch (Exception ex)
  310. {
  311. string Msg = ex.Message;
  312. }
  313. finally
  314. {
  315. }
  316. }
  317. #endregion
  318. #endregion
  319. #region " Thread Handle "
  320. /// <summary>
  321. /// 启动线程主程序
  322. /// </summary>
  323. private void StartUpThread()
  324. {
  325. ThreadStart ts = new ThreadStart(GetDataThread);
  326. _getDataThread = new Thread(ts);
  327. _getDataThread.Name = "GetDataThread " + _DEVICE_POSITION;
  328. _getDataThread.Start();
  329. System.Threading.Thread.Sleep(1000);
  330. ThreadStart ts1 = new ThreadStart(SetDataThread);
  331. _setDataThread = new Thread(ts1);
  332. _setDataThread.Name = "SetDataThread " + _DEVICE_POSITION;
  333. _setDataThread.Start();
  334. }
  335. /// <summary>
  336. /// 取数据线程程序
  337. /// </summary>
  338. private void GetDataThread()
  339. {
  340. while (_bIfGetData)
  341. {
  342. if (!this.On_Off_Thread)
  343. {
  344. System.Threading.Thread.Sleep(500);
  345. continue;
  346. }
  347. try
  348. {
  349. this.Invoke(new SetDataThreadDelegate(GetDataFromServer));
  350. Thread.Sleep(2000);
  351. }
  352. catch { }
  353. }
  354. }
  355. /// <summary>
  356. /// 刷新数据线程程序
  357. /// </summary>
  358. private void SetDataThread()
  359. {
  360. while (_bIfSetData)
  361. {
  362. if (!this.On_Off_Thread)//this.On_Off_Thread
  363. {
  364. System.Threading.Thread.Sleep(500);
  365. continue;
  366. }
  367. try
  368. {
  369. this.Invoke(new SetDataThreadDelegate(SetDataOperate));
  370. Thread.Sleep(1000);
  371. }
  372. catch { }
  373. }
  374. }
  375. private void GetDataFromServer()
  376. {
  377. GetTrackInfoData();
  378. GetHeatProcessList();
  379. JudgeHeatProcess();
  380. GetOptInfo();
  381. GetCraftEleInfo();
  382. GetDevPosInfo();//岗位信息
  383. getoverhmpdate();//获取脱完硫的铁水信息
  384. getelement(); //获取成分信息
  385. GetCVTHeatno();//获取炼钢炉号
  386. }
  387. private void SetDataOperate()
  388. {
  389. lock (this)
  390. {
  391. if (this._heatProcessNo == "")
  392. {
  393. ResetAllData();
  394. return;
  395. }
  396. _bResetDataFlag = false;
  397. FillCraftElement();
  398. FillUserControlData();
  399. }
  400. }
  401. #endregion
  402. #region " Delegate "
  403. /// <summary>
  404. /// 异常操作
  405. /// </summary>
  406. /// <param name="sender"></param>
  407. /// <param name="e"></param>
  408. private void ucHmpDevInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  409. {
  410. string[] bufferArray = { "", "", "", "" };
  411. string strMsg = "";
  412. switch (e.Cell.Column.Key)
  413. {
  414. case "FRONT":
  415. {
  416. if (e.Cell.Text != string.Empty && _listHeatProcess[0].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  417. {
  418. string strCurtPos = "HMP0" + _DEVICE_POS.ToString() + "_FRONT";
  419. string sFrontHeatNo = _listHeatProcess[0].ToString().Substring(0, (int)OBJLEN.nHudwProcessNo);
  420. ClassManualOperate.arryHeatNo = _listHeatProcess;
  421. ClassManualOperate.ManualOperateEntrance(sFrontHeatNo, strCurtPos, this.ob, _objTrackBuffer);
  422. }
  423. }
  424. break;
  425. case "DEVICE":
  426. {
  427. if (e.Cell.Text != string.Empty && _listHeatProcess[1].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  428. {
  429. string strCurtPos = "HMP0" + _DEVICE_POS.ToString() + "_DEVICE";
  430. string sCurHeatNo = _listHeatProcess[1].ToString().Substring(0, (int)OBJLEN.nHudwProcessNo);
  431. ClassManualOperate.arryHeatNo = _listHeatProcess;
  432. ClassManualOperate.ManualOperateEntrance(sCurHeatNo, strCurtPos, this.ob, _objTrackBuffer);
  433. }
  434. }
  435. break;
  436. default:
  437. break;
  438. }
  439. }
  440. private void ucBaseInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  441. {
  442. string strHudwID = "";
  443. string strDevice = "";
  444. System.Windows.Forms.DialogResult drValue;
  445. switch (e.Cell.Column.Key)
  446. {
  447. case "HEATPROCESSNO": // 脱硫工位
  448. if (string.IsNullOrEmpty(_heatProcessNo))
  449. {
  450. drValue = MessageBox.Show("是否确认要手动加载新的脱硫作业信息?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
  451. if (drValue == DialogResult.Yes)
  452. {
  453. strDevice = "_FRONT";
  454. strHudwID = Getdeslagidfromresults();
  455. if (!string.IsNullOrEmpty(strHudwID))
  456. {
  457. this._commClass.obComm = this.ob;
  458. this._commClass.setChargingCommand("MOLSTL", _DEVICE_POSITION + strDevice, strHudwID);
  459. SetDataValue("ARRIVETIME", "DATE", DateTime.Now.ToString(), strHudwID);
  460. }
  461. }
  462. }
  463. else
  464. MessageBox.Show("当前脱硫岗位正在生产不能加载!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  465. break;
  466. case "HUDWID": //取消脱硫号
  467. if (!string.IsNullOrEmpty(_heatProcessNo))
  468. {
  469. drValue = MessageBox.Show("是否确认要取消【"+ _htOptInfo["HUDWID"].ToString() +"】脱硫信息,取消后无法恢复请确认?", "警告", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
  470. if (drValue == DialogResult.Yes)
  471. {
  472. string strSqlID = "CancelHmpJobInfo.Cancel"; //SQLID
  473. string strErr = "";
  474. Hashtable ht = new Hashtable();
  475. ht.Add("I1", _heatProcessNo); //加热处理号
  476. ht.Add("O1", "");
  477. ht.Add("O2", "");
  478. CommonClientToServer ccTs = new CommonClientToServer();
  479. ccTs.ob = ob;
  480. string strRCode = ccTs.ExecuteProcedureFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  481. "CancelHmpJobInfo", strSqlID, ht, out strErr);
  482. if (strErr != "")
  483. {
  484. MessageBox.Show("取消误加载脱硫作业信息失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  485. return;
  486. }
  487. }
  488. }
  489. else
  490. MessageBox.Show("当前脱硫岗位没有生产!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  491. break;
  492. case "SHIFTCODE": // 班次
  493. string szBC = _htOptInfo.Contains("SHIFTCODE") ? _htOptInfo["SHIFTCODE"].ToString() : "";
  494. ClassCellButton(e.Cell, szBC);
  495. break;
  496. default:
  497. break;
  498. }
  499. }
  500. private void ucBaseInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  501. {
  502. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  503. return;
  504. if (MessageBox.Show("是否确认要修改脱硫处理号?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Warning) == DialogResult.Yes)
  505. {
  506. ucBaseInfo1.ultraGrid1.UpdateData();
  507. if (ucBaseInfo1.ultraGrid1.ActiveCell.Text.ToString().Length == 9)
  508. {
  509. string keyStr = ucBaseInfo1.ultraGrid1.ActiveCell.Column.Key;
  510. string valueStr;
  511. try
  512. {
  513. if (ucBaseInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  514. {
  515. valueStr = ucBaseInfo1.ultraGrid1.ActiveCell.Text.ToString();
  516. SetDataValue(keyStr, "VARCHAR2", valueStr, _heatProcessNo);
  517. }
  518. }
  519. catch (Exception ex)
  520. {
  521. string Msg = ex.Message;
  522. MessageBox.Show("保存失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  523. }
  524. }
  525. else
  526. MessageBox.Show("脱硫处理号格式不正确(例:K11-00001)!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
  527. }
  528. }
  529. private void ucHmpInInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  530. {
  531. string strIronpwrapNo = ""; //铁包包号
  532. string strIronpotgrosswgt = ""; //铁水毛重
  533. string strIronpottarewgt = "";//铁罐皮重
  534. string strIronwgt = "";//铁水重量
  535. string strIronsource = ""; //铁水来源
  536. string strEquipmentno = "";//工位号
  537. string strHudwID = ""; //脱硫处理号
  538. string strTemptur = ""; //温度
  539. string strHeatProcessNO = ""; //加热处理号
  540. switch (e.Cell.Column.Key)
  541. {
  542. case "IRONSOURCE": // 铁水来源
  543. string szJZSK = "";
  544. if (_htOptInfo.Contains("ARRIVETIME"))
  545. {
  546. if (_htOptInfo != null && _htOptInfo["ARRIVETIME"] != null && !string.IsNullOrEmpty(_htOptInfo["ARRIVETIME"].ToString()))
  547. {
  548. szJZSK = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  549. frmHMPIron frm = new frmHMPIron(szJZSK, _DEVICE_POSITION);
  550. frm.Location = CStaticMethod.GetChildWindowLocation(frm.Size);
  551. frm.ob = this.ob;
  552. frm.ShowDialog();
  553. // if (!string.IsNullOrEmpty(frm._strIronwrapid))
  554. string strErr = "";
  555. if (frm._strIronwrapid.Trim().Length > 0 && frm._strIronpotwgt.Trim().Length > 0)
  556. {
  557. string strSqlID = "HmpJobIronMolirnSource.Update"; //SQLID
  558. Hashtable ht = new Hashtable();
  559. ht.Add("I1", _heatProcessNo); //加热处理号
  560. ht.Add("I2", _htOptInfo["HUDWID"].ToString()); //脱硫号
  561. ht.Add("I3", frm._strMisid); //铁水来源(铁水来源主键)
  562. ht.Add("I4", frm._strIronwrapid); //铁包号
  563. ht.Add("I5", frm._strIronpotgrosswgt); //铁水毛重
  564. ht.Add("I6", frm._strIronpottarewgt); //铁水皮重
  565. ht.Add("I7", frm._strIronpotwgt); //铁水重量
  566. ht.Add("I8", frm._strIrontemperature); //铁水温度
  567. ht.Add("I9", frm._strRsWgt); //回炉钢水
  568. ht.Add("O1", "");
  569. ht.Add("O2", "");
  570. CommonClientToServer ccTs = new CommonClientToServer();
  571. ccTs.ob = ob;
  572. string strRCode = ccTs.ExecuteProcedureFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  573. "HmpJobIronMolirnSource", strSqlID, ht, out strErr);
  574. if (strErr != "")
  575. {
  576. MessageBox.Show("数据保存失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  577. return;
  578. }
  579. }
  580. }
  581. else
  582. MessageBox.Show("进铁时刻不能为空值,请设置进铁时刻!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  583. }
  584. break;
  585. case "ARRIVETIME": // 进站时刻
  586. SetCellDateTime(e.Cell, "STL_HMP_OPTINFO", e.Cell.Column.Key.ToString());
  587. break;
  588. default:
  589. break;
  590. }
  591. }
  592. private void ucHmpOutInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  593. {
  594. switch (e.Cell.Column.Key)
  595. {
  596. case "MOLIRNLEAVE": // 铁水去向
  597. if (_htOptInfo.Contains("HUDWID"))
  598. {
  599. frmMolirnleave frm = new frmMolirnleave();
  600. frm.Location = CStaticMethod.GetChildWindowLocation(frm.Size);
  601. frm.ShowDialog();
  602. if (!string.IsNullOrEmpty(frm.strStationCode) && !string.IsNullOrEmpty(_heatProcessNo))
  603. {
  604. SetDataValue("MOLIRNLEAVE", "VARCHAR2", frm.strStationCode, _heatProcessNo);
  605. }
  606. }
  607. break;
  608. case "LEAVETIME": // 出站时刻
  609. SetCellDateTime(e.Cell, "JOB_HMP_OPTINFO", e.Cell.Column.Key.ToString());
  610. break;
  611. default:
  612. break;
  613. }
  614. }
  615. private void ucHmpTimeInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  616. {
  617. SetCellDateTime(e.Cell, "JOB_HMP_OPTINFO", e.Cell.Column.Key.ToString());
  618. }
  619. private void ucHmpTimeInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  620. {
  621. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  622. return;
  623. ucHmpTimeInfo1.ultraGrid1.UpdateData();
  624. string keyStr = ucHmpTimeInfo1.ultraGrid1.ActiveCell.Column.Key;
  625. DateTime valueStr;
  626. if (ucHmpTimeInfo1.ultraGrid1.ActiveCell.Column.DataType == typeof(System.DateTime))
  627. {
  628. try
  629. {
  630. if (ucHmpTimeInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  631. {
  632. valueStr = (DateTime)ucHmpTimeInfo1.ultraGrid1.ActiveCell.Value;
  633. SetDataValue(keyStr, "DATE", valueStr.ToString("yyyy-MM-dd HH:mm"), _heatProcessNo);
  634. ucHmpTimeInfo1.ultraGrid1.ActiveCell.Value = valueStr;
  635. }
  636. else
  637. SetDataValue(keyStr, "DATE", "", _heatProcessNo);
  638. }
  639. catch (Exception ex)
  640. {
  641. string Msg = ex.Message;
  642. MessageBox.Show("日期输入格式错误,请改正!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  643. }
  644. }
  645. }
  646. private void ucHmpInInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  647. {
  648. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  649. return;
  650. ucHmpInInfo1.ultraGrid1.UpdateData();
  651. string keyStr = ucHmpInInfo1.ultraGrid1.ActiveCell.Column.Key;
  652. DateTime valueStr;
  653. if (ucHmpInInfo1.ultraGrid1.ActiveCell.Column.DataType == typeof(System.DateTime))
  654. {
  655. try
  656. {
  657. if (ucHmpInInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  658. {
  659. valueStr = (DateTime)ucHmpInInfo1.ultraGrid1.ActiveCell.Value;
  660. SetDataValue(keyStr, "DATE", valueStr.ToString("yyyy-MM-dd HH:mm"), _heatProcessNo);
  661. ucHmpInInfo1.ultraGrid1.ActiveCell.Value = valueStr;
  662. }
  663. else
  664. {
  665. SetDataValue(keyStr, "DATE", null, _heatProcessNo);
  666. }
  667. }
  668. catch (Exception ex)
  669. {
  670. string Msg = ex.Message;
  671. MessageBox.Show("日期输入格式错误,请改正!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  672. }
  673. }
  674. else
  675. {
  676. string strValue = "";
  677. if (ucHmpInInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  678. {
  679. strValue = ucHmpInInfo1.ultraGrid1.ActiveCell.Value.ToString();
  680. ucHmpInInfo1.ultraGrid1.ActiveCell.Value = strValue;
  681. }
  682. SetDataValue(keyStr, "VARCHAR2", strValue, _heatProcessNo);
  683. }
  684. }
  685. private void ucHmpOutInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  686. {
  687. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  688. return;
  689. ucHmpOutInfo1.ultraGrid1.UpdateData();
  690. string keyStr = ucHmpOutInfo1.ultraGrid1.ActiveCell.Column.Key;
  691. DateTime valueStr;
  692. if (ucHmpOutInfo1.ultraGrid1.ActiveCell.Column.DataType == typeof(System.DateTime))
  693. {
  694. try
  695. {
  696. if (ucHmpOutInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  697. {
  698. valueStr = (DateTime)ucHmpOutInfo1.ultraGrid1.ActiveCell.Value;
  699. SetDataValue(keyStr, "DATE", valueStr.ToString("yyyy-MM-dd HH:mm"), _heatProcessNo);
  700. ucHmpOutInfo1.ultraGrid1.ActiveCell.Value = valueStr;
  701. }
  702. else
  703. SetDataValue(keyStr, "DATE", null, _heatProcessNo);
  704. }
  705. catch (Exception ex)
  706. {
  707. string Msg = ex.Message;
  708. MessageBox.Show("日期输入格式错误,请改正!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  709. }
  710. }
  711. else
  712. {
  713. string strValue = "";
  714. if (ucHmpOutInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  715. {
  716. strValue = ucHmpOutInfo1.ultraGrid1.ActiveCell.Value.ToString();
  717. ucHmpOutInfo1.ultraGrid1.ActiveCell.Value = strValue;
  718. }
  719. SetDataValue(keyStr, "VARCHAR2", strValue, _heatProcessNo);
  720. }
  721. }
  722. private void ucHmpDevInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  723. {
  724. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  725. return;
  726. ucHmpDevInfo1.ultraGrid1.UpdateData();
  727. string keyStr = ucHmpDevInfo1.ultraGrid1.ActiveCell.Column.Key;
  728. string valueStr;
  729. try
  730. {
  731. if (ucHmpDevInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  732. {
  733. valueStr = ucHmpDevInfo1.ultraGrid1.ActiveCell.Text.ToString();
  734. SetDataValue(keyStr, "VARCHAR2", valueStr, _heatProcessNo);
  735. }
  736. }
  737. catch (Exception ex)
  738. {
  739. string Msg = ex.Message;
  740. MessageBox.Show("保存失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  741. }
  742. }
  743. /// <summary>
  744. /// 时间显示框,在需要更改日期的时候弹出日期选择框
  745. /// </summary>
  746. /// <param name="cell"></param>
  747. /// <param name="strTableName"></param>
  748. /// <param name="strColumnName"></param>
  749. private void SetCellDateTime(Infragistics.Win.UltraWinGrid.UltraGridCell cell, string strTableName, string strColumnName)
  750. {
  751. frmSetTime frm = new frmSetTime(cell.Value);
  752. frm.Location = CStaticMethod.GetChildWindowLocation(frm.Size);
  753. frm.ShowDialog();
  754. if (_heatProcessNo.Length >= 11 && frm._returnTime > new DateTime(2000, 1, 1, 0, 0, 0, 0))
  755. {
  756. DateTime dt = frm._returnTime;
  757. cell.Value = dt;
  758. try
  759. {
  760. SetDataValue(strColumnName, "DATE", dt.ToString("yyyy-MM-dd HH:mm"), _heatProcessNo);
  761. }
  762. catch
  763. {
  764. MessageBox.Show("日期输入格式错误,请改正!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  765. }
  766. }
  767. }
  768. private void ClassCellButton(Infragistics.Win.UltraWinGrid.UltraGridCell cell, string strDuty)
  769. {
  770. frmClassSelect frm = new frmClassSelect(_heatProcessNo, strDuty);
  771. frm.Location = CStaticMethod.GetChildWindowLocation(frm.Size);
  772. frm.ShowDialog();
  773. if (frm._changeFlag)
  774. {
  775. cell.Value = frm._dutyID;
  776. if (_heatProcessNo.Length >= 11)
  777. {
  778. RealDataCommand realDataCommand = new RealDataCommand();
  779. realDataCommand.COMMANDTYPE = "SCHEDULE_SET";
  780. realDataCommand.OBJECTTYPE = "PROCVALUE";
  781. realDataCommand.OBJECTPOS = _devPos;
  782. realDataCommand.OBJECTID = _heatProcessNo;
  783. realDataCommand.OBJECTLINKTABLE = "JOB_HMP_OPTINFO";
  784. realDataCommand.OBJECTLINKKEY1 = _hudWid;//CStaticMethod.getSmeltingID(_heatProcessNo);
  785. realDataCommand.OBJECTLINKKEY2 = "SHIFTCODE";
  786. realDataCommand.VALUETYPE = "VARCHAR2";
  787. realDataCommand.STR_VALUE = frm._dutyID;
  788. string szOut = "";
  789. //hengxing
  790. //CallingMessage par = new CallingMessage();
  791. //par.ServerName = "lgJobMgt";
  792. //par.AssemblyName = "Core.LgMes.Server.lgJobMgt";
  793. //par.ClassName = "Core.LgMes.Server.lgJobMgt.classSendCommand";
  794. //par.MethodName = "UpdateTableField";
  795. //par.args = new object[] { realDataCommand };
  796. //ClientCommon._RemotingHelp.ExecuteMethod(par, out szOut);
  797. if (szOut != "")
  798. MessageBox.Show("命令发送不成功!");
  799. }
  800. }
  801. }
  802. #endregion
  803. #region " Commonly Function "
  804. /// <summary>
  805. /// 根据窗体名称获取设备位置
  806. /// </summary>
  807. private void GetDevicePosition()
  808. {
  809. if (this.Text == "") return;
  810. string str = this.Text.Substring(0, 1);
  811. switch (str)
  812. {
  813. case "1":
  814. _DEVICE_POSITION = "HMP01";
  815. _DEVICE_POS = 1;
  816. break;
  817. case "2":
  818. _DEVICE_POSITION = "HMP02";
  819. _DEVICE_POS = 2;
  820. break;
  821. case "3":
  822. _DEVICE_POSITION = "HMP03";
  823. _DEVICE_POS = 3;
  824. break;
  825. default:
  826. break;
  827. }
  828. }
  829. private string GetDevDeviceCodeOfHmp(int nDevNo)
  830. {
  831. string strDevID = "";
  832. switch (nDevNo)
  833. {
  834. case (int)DeviceCode.HMP:
  835. strDevID = "HMP_DEVICE";
  836. break;
  837. case (int)DeviceCode.HMP01:
  838. case (int)DeviceCode.HMP02:
  839. case (int)DeviceCode.HMP03:
  840. strDevID = String.Format("HMP{0,2}_DEVICE", nDevNo);
  841. break;
  842. }
  843. strDevID = strDevID.Replace(" ", "0");
  844. return strDevID;
  845. }
  846. private string GetDevBackCodeOfHmp(int nDevNo)
  847. {
  848. string strDevID = "";
  849. switch (nDevNo)
  850. {
  851. case (int)DeviceCode.HMP:
  852. strDevID = "HMP_BACK";
  853. break;
  854. case (int)DeviceCode.HMP01:
  855. case (int)DeviceCode.HMP02:
  856. case (int)DeviceCode.HMP03:
  857. strDevID = String.Format("HMP{0,2}_BACK", nDevNo);
  858. break;
  859. }
  860. strDevID = strDevID.Replace(" ", "0");
  861. return strDevID;
  862. }
  863. private string GetDevOverCodeOfHmp(int nDevNo)
  864. {
  865. string strDevID = "";
  866. switch (nDevNo)
  867. {
  868. case (int)DeviceCode.HMP:
  869. strDevID = "HMP_OVER";
  870. break;
  871. case (int)DeviceCode.HMP01:
  872. case (int)DeviceCode.HMP02:
  873. case (int)DeviceCode.HMP03:
  874. strDevID = String.Format("HMP{0,2}_OVER", nDevNo);
  875. break;
  876. }
  877. strDevID = strDevID.Replace(" ", "0");
  878. return strDevID;
  879. }
  880. private string GetDevFrontCodeOfHmp(int nDevNo)
  881. {
  882. string strDevID = "";
  883. switch (nDevNo)
  884. {
  885. case (int)DeviceCode.HMP:
  886. strDevID = "HMP_OVER";
  887. break;
  888. case (int)DeviceCode.HMP01:
  889. case (int)DeviceCode.HMP02:
  890. case (int)DeviceCode.HMP03:
  891. strDevID = String.Format("HMP{0,2}_FRONT", nDevNo);
  892. break;
  893. }
  894. strDevID = strDevID.Replace(" ", "0");
  895. return strDevID;
  896. }
  897. /// <summary>
  898. /// 获取脱硫操作数据
  899. /// </summary>
  900. private void GetOptInfo()
  901. {
  902. if (_heatProcessNo == "")
  903. return;
  904. #region "取脱硫操作数据"
  905. try
  906. {
  907. string strErr = "";
  908. ArrayList arry = new ArrayList();
  909. arry.Add("GetHmpOptInfo.Select");//此ID为XML文件ID
  910. arry.Add(_heatProcessNo);
  911. arry.Add("0" + _DEVICE_POS);
  912. //查询转炉作业信息
  913. DataSet ds = this.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  914. "GetHmpOptInfo", arry, out strErr);
  915. if (strErr == "" && ds != null)
  916. {
  917. DataTable tb = ds.Tables[0];
  918. if (tb.Rows.Count > 0)
  919. {
  920. for (int i = 0; i < tb.Columns.Count; i++)
  921. {
  922. if (_htOptInfo.Contains(tb.Columns[i].ColumnName))
  923. _htOptInfo.Remove(tb.Columns[i].ColumnName);
  924. _htOptInfo.Add(tb.Columns[i].ColumnName, tb.Rows[0][i].ToString());
  925. }
  926. }
  927. else
  928. _htOptInfo.Clear();
  929. }
  930. }
  931. catch { }
  932. #endregion
  933. }
  934. /// <summary>
  935. /// 获取铁水成分样
  936. /// </summary>
  937. private void GetCraftEleInfo()
  938. {
  939. if (_hudWid == "")
  940. return;
  941. string szOut = "", szWhere = " WHERE substr(CHECKNO,0,9) = '" + _hudWid + "' and substr(CHECKNO,10,1)='B' and substr(checkno,length(checkno),1) ='I'";
  942. //hengxing
  943. //CallingMessage par = new CallingMessage();
  944. //par.ServerName = "lgJobMgt";
  945. //par.AssemblyName = "Core.LgMes.Server.lgJobMgt";
  946. //par.ClassName = "Core.LgMes.Server.lgJobMgt.classTrackObjectInfo";
  947. //par.MethodName = "ReceiveCraftElement";
  948. //par.args = new object[] { szWhere };
  949. object obj = null;// ClientCommon._RemotingHelp.ExecuteMethod(par, out szOut);
  950. if (szOut == "" && obj != null)
  951. {
  952. DataSet ds = obj as DataSet;
  953. this.DataSetToCraftElement(ref ds, ref _tmpObjCraftEle);
  954. }
  955. }
  956. /// <summary>
  957. /// 获取手动加载的脱硫号
  958. /// </summary>
  959. /// <returns></returns>
  960. private string Getdeslagidfromresults()
  961. {
  962. string strErr = "";
  963. string strHudwID = "";
  964. ArrayList arry = new ArrayList();
  965. arry.Add("Getdeslagidfromresults.Select");//此ID为XML文件ID
  966. arry.Add(_DEVICE_POSITION);
  967. //获取指定岗位后台实时跟踪信息
  968. DataSet dsHudwID = this.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  969. "Getdeslagidfromresults", arry, out strErr);
  970. if (strErr == "" && dsHudwID != null)
  971. {
  972. if (dsHudwID.Tables[0].Rows.Count > 0 && dsHudwID.Tables[0].Rows[0]["HudwID"] != null && !string.IsNullOrEmpty(dsHudwID.Tables[0].Rows[0]["HudwID"].ToString()))
  973. strHudwID = dsHudwID.Tables[0].Rows[0]["HudwID"].ToString();
  974. }
  975. return strHudwID;
  976. }
  977. /// <summary>
  978. /// 填充化学成分信息界面数据
  979. /// </summary>
  980. private void FillCraftElement()
  981. {
  982. try
  983. {
  984. lock (this)
  985. {
  986. int nRows = 0;
  987. nRows = _objCraftEleBuffer.hList.Count;
  988. //if (_dtStdElement != null && _dtStdElement.Rows.Count > 0)
  989. //{
  990. // nRows++;
  991. //}
  992. CStaticMethod.ResetTableRows(ref _dtCraftElement, nRows);
  993. int i = 0;
  994. #region " 内控标准"
  995. //if (_dtStdElement != null && this._dtStdElement.Tables.Contains("NK") && this._dtStdElement.Tables["NK"].Rows.Count > 0)
  996. //{
  997. // for (int j = 0; j < this._dtStdElement.Tables["NK"].Rows.Count; j++)
  998. // {
  999. // DataRow dr = this._dtStdElement.Tables["NK"].Rows[j];
  1000. // SetStandardElemData(i, dr);
  1001. // }
  1002. // i++;
  1003. //}
  1004. #endregion
  1005. #region " 实时值"
  1006. for (int j = 0; j < _objCraftEleBuffer.hList.Count; j++, i++)
  1007. {
  1008. JOB_CHEMELEMENT obj = (JOB_CHEMELEMENT)_objCraftEleBuffer.hList[j];
  1009. CStaticMethod.SetCraftElemGridData(i, obj, obj.CHECKNO, ref _dtCraftElement);
  1010. }
  1011. #endregion
  1012. }
  1013. }
  1014. catch (Exception ex)
  1015. {
  1016. string Msg = ex.Message;
  1017. }
  1018. }
  1019. /// <summary>
  1020. /// 填充用户控件上面的数据
  1021. /// </summary>
  1022. private void FillUserControlData()
  1023. {
  1024. ucBaseInfo1.SetData(_htOptInfo);
  1025. ucHmpInInfo1.SetData(_htOptInfo);
  1026. ucHmpTimeInfo1.SetData(_htOptInfo);
  1027. ucHmpDevInfo1.SetData(_htOptInfo);
  1028. ucHmpOutInfo1.SetData(_htOptInfo);
  1029. }
  1030. /// <summary>
  1031. /// 设置用户控件委托
  1032. /// </summary>
  1033. private void SetUserControlDelegate()
  1034. {
  1035. ucBaseInfo1.ultraGrid1.ClickCellButton += new Infragistics.Win.UltraWinGrid.CellEventHandler(ucBaseInfo1_ClickCellButton);
  1036. ucBaseInfo1.ultraGrid1.KeyDown += new KeyEventHandler(ucBaseInfo1_KeyDown);
  1037. ucHmpInInfo1.ultraGrid1.ClickCellButton += new Infragistics.Win.UltraWinGrid.CellEventHandler(ucHmpInInfo1_ClickCellButton);
  1038. ucHmpTimeInfo1.ultraGrid1.ClickCellButton += new Infragistics.Win.UltraWinGrid.CellEventHandler(ucHmpTimeInfo1_ClickCellButton);
  1039. ucHmpOutInfo1.ultraGrid1.ClickCellButton += new Infragistics.Win.UltraWinGrid.CellEventHandler(ucHmpOutInfo1_ClickCellButton);
  1040. ucHmpDevInfo1.ultraGrid1.ClickCellButton += new Infragistics.Win.UltraWinGrid.CellEventHandler(ucHmpDevInfo1_ClickCellButton);
  1041. ucHmpInInfo1.ultraGrid1.KeyDown += new KeyEventHandler(ucHmpInInfo1_KeyDown);
  1042. ucHmpTimeInfo1.ultraGrid1.KeyDown += new KeyEventHandler(ucHmpTimeInfo1_KeyDown);
  1043. ucHmpOutInfo1.ultraGrid1.KeyDown += new KeyEventHandler(ucHmpOutInfo1_KeyDown);
  1044. ucHmpDevInfo1.ultraGrid1.KeyDown += new KeyEventHandler(ucHmpDevInfo1_KeyDown);
  1045. }
  1046. /// <summary>
  1047. /// 清除所有界面Grid中的实时数据
  1048. /// </summary>
  1049. private void ClearGridData()
  1050. {
  1051. try
  1052. {
  1053. _dtCraftElement.Rows.Clear();
  1054. }
  1055. catch { }
  1056. }
  1057. /// <summary>
  1058. /// 重置界面用户控件的数据
  1059. /// </summary>
  1060. private void ResetAllData()
  1061. {
  1062. if (!_bResetDataFlag) // 如果已经清空,则直接返回
  1063. {
  1064. ucBaseInfo1.ResetData();
  1065. ucHmpInInfo1.ResetData();
  1066. ucHmpTimeInfo1.ResetData();
  1067. ucHmpDevInfo1.ResetData();
  1068. ucHmpOutInfo1.ResetData();
  1069. _htOptInfo.Clear();
  1070. ClearGridData();
  1071. _bResetDataFlag = true;
  1072. }
  1073. }
  1074. #endregion
  1075. #region " Button Event "
  1076. private void btnSEND1_Click(object sender, EventArgs e)
  1077. {
  1078. if (ArrayIronRow4[0].Trim().Length > 0)
  1079. {
  1080. if (txtCVT1.Text == null) return;
  1081. ArrayIronRow4[4] = txtCVT1.Text;
  1082. ArrayIronRow4[5] = "BOF01";
  1083. SendIronToCvt();
  1084. ArrayIronRow4[0] = "";
  1085. ArrayIronRow4[1] = "";
  1086. ArrayIronRow4[2] = "";
  1087. ArrayIronRow4[3] = "";
  1088. ArrayIronRow4[4] = "";
  1089. ArrayIronRow4[5] = "";
  1090. ArrayIronRow4[6] = "";
  1091. ArrayIronRow4[7] = "";
  1092. ArrayIronRow4[8] = "";
  1093. ArrayIronRow4[9] = "";
  1094. }
  1095. else
  1096. MessageBox.Show("选择要发送的已脱硫信息!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  1097. }
  1098. private void btnSEND2_Click(object sender, EventArgs e)
  1099. {
  1100. if (ArrayIronRow4[0].Trim().Length > 0)
  1101. {
  1102. if (txtCVT2.Text == null) return;
  1103. ArrayIronRow4[4] = txtCVT2.Text;
  1104. ArrayIronRow4[5] = "BOF02";
  1105. SendIronToCvt();
  1106. ArrayIronRow4[0] = "";
  1107. ArrayIronRow4[1] = "";
  1108. ArrayIronRow4[2] = "";
  1109. ArrayIronRow4[3] = "";
  1110. ArrayIronRow4[4] = "";
  1111. ArrayIronRow4[5] = "";
  1112. ArrayIronRow4[6] = "";
  1113. ArrayIronRow4[7] = "";
  1114. ArrayIronRow4[8] = "";
  1115. ArrayIronRow4[9] = "";
  1116. }
  1117. else
  1118. MessageBox.Show("选择要发送的已脱硫信息!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  1119. }
  1120. private void btnSEND3_Click(object sender, EventArgs e)
  1121. {
  1122. if (ArrayIronRow4[0].Trim().Length > 0)
  1123. {
  1124. if (txtCVT3.Text == null) return;
  1125. ArrayIronRow4[4] = txtCVT3.Text;
  1126. ArrayIronRow4[5] = "BOF03";
  1127. SendIronToCvt();
  1128. ArrayIronRow4[0] = "";
  1129. ArrayIronRow4[1] = "";
  1130. ArrayIronRow4[2] = "";
  1131. ArrayIronRow4[3] = "";
  1132. ArrayIronRow4[4] = "";
  1133. ArrayIronRow4[5] = "";
  1134. ArrayIronRow4[6] = "";
  1135. ArrayIronRow4[7] = "";
  1136. ArrayIronRow4[8] = "";
  1137. ArrayIronRow4[9] = "";
  1138. }
  1139. else
  1140. MessageBox.Show("选择要发送的已脱硫信息!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  1141. }
  1142. /// <summary>
  1143. /// 功能按钮控制区
  1144. /// </summary>
  1145. /// <param name="sender"></param>
  1146. /// <param name="ToolbarKey"></param>
  1147. public override void ToolBar_Click(object sender, string ToolbarKey)
  1148. {
  1149. switch (ToolbarKey)
  1150. {
  1151. case "Result": // lgResMgt
  1152. string szStr = _DEVICE_POS.ToString() + "#铁水预处理实绩";
  1153. foreach (Form mdiChild in this.MdiParent.MdiChildren)
  1154. {
  1155. if (mdiChild.Text == szStr)
  1156. {
  1157. mdiChild.Activate();
  1158. return;
  1159. }
  1160. }
  1161. frmHmpResults frmSJSJ = new frmHmpResults();
  1162. frmSJSJ.MdiParent = this.MdiParent;
  1163. frmSJSJ.Text = szStr;
  1164. frmSJSJ.Tag = frmSJSJ.Text;
  1165. frmSJSJ.Key = "Core.LgMes.Client.LgResMgt.frmHmpResults";
  1166. frmSJSJ.CustomInfo = _DEVICE_POSITION;
  1167. frmSJSJ.Toolbar = CStaticMethod.GetFromToolInfo(frmSJSJ.Key, frmSJSJ.CustomInfo, this.ob);
  1168. frmSJSJ.ob = this.ob;
  1169. frmSJSJ.Show();
  1170. break;
  1171. case "ChemicElem": // 化学成分
  1172. string szEle = "化学成分查询";
  1173. foreach (Form mdiChild in this.MdiParent.MdiChildren)
  1174. {
  1175. if (mdiChild.Text == szEle)
  1176. {
  1177. mdiChild.Activate();
  1178. return;
  1179. }
  1180. }
  1181. frmLgElements frmHXCF = new frmLgElements();
  1182. frmHXCF.MdiParent = this.MdiParent;
  1183. frmHXCF.Text = szEle;
  1184. frmHXCF.Tag = frmHXCF.Text;
  1185. frmHXCF._devPos = _DEVICE_POSITION;
  1186. frmHXCF.Key = "Core.LgMes.Client.LgIntegrationQuery.frmLgElements";
  1187. frmHXCF.Toolbar = CStaticMethod.GetFromToolInfo(frmHXCF.Key, "", this.ob);
  1188. frmHXCF.ob = this.ob;
  1189. frmHXCF.Show();
  1190. break;
  1191. case "SftRcd": // 班组记录
  1192. string szRcd = "脱硫站操作记录";
  1193. foreach (Form mdiChild in this.MdiParent.MdiChildren)
  1194. {
  1195. if (mdiChild.Text == szRcd)
  1196. {
  1197. mdiChild.Activate();
  1198. return;
  1199. }
  1200. }
  1201. reportHMPData frmReport = new reportHMPData();
  1202. frmReport.MdiParent = this.MdiParent;
  1203. frmReport.Text = szRcd;
  1204. frmReport.Tag = frmReport.Text;
  1205. frmReport.Key = "Core.LgMes.Client.Report.reportHMPData";
  1206. frmReport.Toolbar = CStaticMethod.GetFromToolInfo(frmReport.Key, "", this.ob);
  1207. frmReport.ob = this.ob;
  1208. frmReport.Show();
  1209. break;
  1210. case "btnJobStd": // 作业标准
  1211. string szOR = "操作规程管理";
  1212. foreach (Form mdiChild in this.MdiParent.MdiChildren)
  1213. {
  1214. if (mdiChild.Text == szOR)
  1215. {
  1216. mdiChild.Activate();
  1217. return;
  1218. }
  1219. }
  1220. //Core.LgMes.Client.LgIntegrationQuery.frmOperateRule frmOR = new Core.LgMes.Client.LgIntegrationQuery.frmOperateRule();
  1221. //frmOR.MdiParent = this.MdiParent;
  1222. //frmOR.Key = "Core.LgMes.Client.LgIntegrationQuery.frmOperateRule";
  1223. //frmOR.Text = "操作规程管理";
  1224. //frmOR.blValue = false;
  1225. //frmOR.Show();
  1226. break;
  1227. case "JobPlan": // 作业计划
  1228. string szPlan = "作业计划查询";
  1229. foreach (Form mdiChild in this.MdiParent.MdiChildren)
  1230. {
  1231. if (mdiChild.Text == szPlan)
  1232. {
  1233. mdiChild.Activate();
  1234. return;
  1235. }
  1236. }
  1237. frmSchedulingQuery frmZYJH = new frmSchedulingQuery();
  1238. frmZYJH.MdiParent = this.MdiParent;
  1239. frmZYJH.Text = szPlan;
  1240. frmZYJH.Tag = frmZYJH.Text;
  1241. frmZYJH.Key = "Core.LgMes.Client.LgIntegrationQuery.frmSchedulingQuery";
  1242. frmZYJH.Toolbar = CStaticMethod.GetFromToolInfo(frmZYJH.Key, "", this.ob);
  1243. frmZYJH.ob = this.ob;
  1244. frmZYJH.Show();
  1245. break;
  1246. case "butIronElements":
  1247. string szIron = "铁水成分";
  1248. foreach (Form mdiChild in this.MdiParent.MdiChildren)
  1249. {
  1250. if (mdiChild.Text == szIron)
  1251. {
  1252. mdiChild.Activate();
  1253. return;
  1254. }
  1255. }
  1256. //Core.LgMes.Client.LgIntegrationQuery.FrmIronEleQry frmIron = new Core.LgMes.Client.LgIntegrationQuery.FrmIronEleQry();
  1257. //frmIron.MdiParent = this.MdiParent;
  1258. //frmIron.Text = szIron;
  1259. //frmIron.Tag = frmIron.Text;
  1260. //frmIron.Key = "Core.LgMes.Client.LgIntegrationQuery.FrmIronEleQry";
  1261. //frmIron.Show();
  1262. break;
  1263. case "Exit":
  1264. this.Close();
  1265. break;
  1266. default:
  1267. break;
  1268. }
  1269. }
  1270. #endregion
  1271. #region " 公共函数 "
  1272. /// <summary>
  1273. /// 更新指定字段的值
  1274. /// </summary>
  1275. /// <param name="strColumn_Name">字段名</param>
  1276. /// <param name="strColumn_Type">字段类型(区分时间DATE就行。)</param>
  1277. /// <param name="strValue"></param>
  1278. /// <param name="strHudwID"></param>
  1279. private void SetDataValue(string strColumn_Name, string strColumn_Type, string strValue, string strHudwID)
  1280. {
  1281. string strErr = "";
  1282. ClassManualUpdateInfo.UpdateHmpTableField(strHudwID, "STL_HMP_OPTINFO", strColumn_Name, strColumn_Type, strValue, this.ob);
  1283. if (strErr != "")
  1284. {
  1285. MessageBox.Show("数据保存失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  1286. return;
  1287. }
  1288. }
  1289. /// <summary>
  1290. /// 根据设备状态设置图片显示
  1291. /// </summary>
  1292. /// <param name="strState"></param>
  1293. /// <returns></returns>
  1294. private Image SetPic(string strState)
  1295. {
  1296. int index = 0;
  1297. switch (strState)
  1298. {
  1299. case "IDLE":
  1300. index = 0;
  1301. break;
  1302. case "DESLAGING":
  1303. index = 1;
  1304. break;
  1305. case "REPAIR":
  1306. index = 2;
  1307. break;
  1308. case "WORK":
  1309. index = 1;
  1310. break;
  1311. default:
  1312. index = 0;
  1313. break;
  1314. }
  1315. try
  1316. {
  1317. return this.imageList1.Images[index];
  1318. }
  1319. catch { }
  1320. return this.imageList1.Images[0];
  1321. //空闲
  1322. //工作
  1323. //倒钢
  1324. //维修
  1325. //兑废钢
  1326. //兑铁水
  1327. }
  1328. #endregion
  1329. #region "guoguoadd"
  1330. /// <summary>
  1331. /// 发送铁水信息到转炉
  1332. /// </summary>
  1333. private void SendIronToCvt()
  1334. {
  1335. string strError = "";
  1336. string strWz = "";
  1337. string strSqlID = ""; //sqlId
  1338. string strErr = ""; //错误信息
  1339. strSqlID = "SendHmpIronToBof.Update"; //SQLID
  1340. Hashtable ht = new Hashtable();
  1341. ht.Add("I1", ArrayIronRow4[0]); //脱硫号
  1342. ht.Add("I2", ArrayIronRow4[1]); //铁水温度
  1343. ht.Add("I3", ArrayIronRow4[2]); //铁包号
  1344. ht.Add("I4", ArrayIronRow4[3]); //铁水重量
  1345. ht.Add("I5", ArrayIronRow4[4]); //发送炉号
  1346. ht.Add("I6", ArrayIronRow4[5]); //发送岗位编码(BOF)
  1347. ht.Add("I7", ArrayIronRow4[6]); //回炉号
  1348. ht.Add("I8", ArrayIronRow4[7]); //回炉重量
  1349. ht.Add("I9", ArrayIronRow4[8]); //S值
  1350. ht.Add("I10", ArrayIronRow4[9]);//化学检验号
  1351. CommonClientToServer ccTs = new CommonClientToServer();
  1352. ccTs.ob = ob;
  1353. string strRCode = ccTs.ExecuteProcedureFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  1354. "SendHmpIronToBof", strSqlID, ht, out strErr);
  1355. if (strErr != "")
  1356. MessageBox.Show("脱硫发送铁水到转炉失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
  1357. else
  1358. {
  1359. strWz = ArrayIronRow4[5];
  1360. switch (strWz)
  1361. {
  1362. case "BOF01":
  1363. _strSendSucceededForBof1 = "Y";
  1364. break;
  1365. case "BOF02":
  1366. _strSendSucceededForBof2 = "Y";
  1367. break;
  1368. case "BOF03":
  1369. _strSendSucceededForBof3 = "Y";
  1370. break;
  1371. default:
  1372. break;
  1373. }
  1374. MessageBox.Show("脱硫发送铁水到转炉成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  1375. }
  1376. }
  1377. /// <summary>
  1378. /// 获取完毕脱硫信息
  1379. /// </summary>
  1380. private void getoverhmpdate()
  1381. {
  1382. string wsid = "0" + this.Text.Substring(0, 1);
  1383. string strErr = "";
  1384. try
  1385. {
  1386. ArrayList arry = new ArrayList();
  1387. arry.Add("GetOverHmpdate.Select");//此ID为XML文件ID
  1388. arry.Add(wsid);
  1389. //查询脱硫完成信息
  1390. DataSet ds = this.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  1391. "GetOverHmpdate", arry, out strErr);
  1392. if (strErr == "" && ds != null)
  1393. {
  1394. ultraDataSource1.Rows.Clear();
  1395. if (ds.Tables.Count > 0)
  1396. {
  1397. foreach (DataRow dr in ds.Tables[0].Rows)
  1398. {
  1399. ultraDataSource1.Rows.Add(new object[] {
  1400. dr["HUDWID"].ToString(),
  1401. dr["MOLIRNLEAVE"].ToString(),
  1402. dr["IRONPWRAPNO"].ToString(),
  1403. dr["DFRSTARTTIME"],
  1404. dr["DFRENDTIME"],
  1405. CStaticMethod.caculateSecondsTime(dr["DFRTIME"].ToString()),
  1406. dr["DFRWGT"].ToString(),
  1407. dr["FRONTTEMPERATURE"].ToString(),
  1408. dr["SWBTEMPERATURE"].ToString(),
  1409. dr["IRONWGT"].ToString(),
  1410. dr["ARRIVEWGTTIME"],
  1411. dr["ARRIVEWGT"].ToString(),
  1412. dr["LEAVEWGTTIME"],
  1413. dr["LEAVEWGT"].ToString(),
  1414. dr["RSSTOVENO"].ToString(),
  1415. dr["RSWGT"].ToString(),
  1416. dr["SWFTEMPERATURE"].ToString(),
  1417. dr["IRONSOURCE"].ToString(),
  1418. });
  1419. }
  1420. }
  1421. }
  1422. }
  1423. catch
  1424. { }
  1425. }
  1426. /// <summary>
  1427. /// 获取当前脱硫成分信息
  1428. /// </summary>
  1429. private void getelement()
  1430. {
  1431. string strErr = "";
  1432. string strItemName = "";
  1433. string strHudwID = "";
  1434. try
  1435. {
  1436. if (_htOptInfo["HUDWID"] ==null )
  1437. return;
  1438. if (_htOptInfo["HUDWID"].ToString().Length == 0) return;
  1439. strHudwID = _htOptInfo["HUDWID"].ToString();
  1440. ArrayList arry = new ArrayList();
  1441. arry.Add("ReceiveHmpCraftElement.Select");//此ID为XML文件ID
  1442. arry.Add(strHudwID);
  1443. arry.Add("I");
  1444. arry.Add(strHudwID);
  1445. arry.Add("I");
  1446. arry.Add(strHudwID);
  1447. arry.Add("I");
  1448. arry.Add(strHudwID);
  1449. arry.Add("I");
  1450. CommonClientToServer cctos = new CommonClientToServer();
  1451. cctos.ob = ob;
  1452. //查询化学成分信息
  1453. DataSet ds = cctos.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  1454. "ReceiveHmpCraftElement", arry, out strErr);
  1455. if (strErr == "" && ds != null)
  1456. {
  1457. ultraDataSource2.Rows.Clear();
  1458. if (ds.Tables.Count > 0)
  1459. {
  1460. foreach (DataRow dr in ds.Tables[0].Rows)
  1461. {
  1462. if (dr["CHECKNO"].ToString().Substring(2, 1) == "3")
  1463. strItemName = "平台";
  1464. else
  1465. {
  1466. if (dr["CHECKNO"].ToString().Substring(13, 1) == "2")
  1467. strItemName = "脱硫前";
  1468. else
  1469. strItemName = "脱硫后[" + dr["CHECKNO"].ToString().Substring(13,1) + "]";
  1470. }
  1471. ultraDataSource2.Rows.Add(new object[] {
  1472. dr["heatno"].ToString(),
  1473. dr["c"].ToString(),
  1474. dr["si"].ToString(),
  1475. dr["mn"].ToString(),
  1476. dr["p"].ToString(),
  1477. dr["s"].ToString(),
  1478. dr["asn"].ToString(),
  1479. dr["ni"].ToString(),
  1480. dr["Cu"].ToString(),
  1481. dr["Sn"].ToString(),
  1482. dr["sb"].ToString(),
  1483. dr["CHECKNO"].ToString(),
  1484. strItemName
  1485. });
  1486. }
  1487. }
  1488. }
  1489. }
  1490. catch
  1491. { }
  1492. }
  1493. /// <summary>
  1494. /// 获取当前脱硫成分信息
  1495. /// </summary>
  1496. private void Getoverelement(string strHudwId)
  1497. {
  1498. string strErr = "";
  1499. string strItemName = "";
  1500. try
  1501. {
  1502. if (strHudwId == "")
  1503. return;
  1504. ArrayList arry = new ArrayList();
  1505. arry.Add("ReceiveHmpOverElement.Select");//此ID为XML文件ID
  1506. arry.Add(strHudwId);
  1507. arry.Add("I");
  1508. arry.Add(strHudwId);
  1509. arry.Add("I");
  1510. arry.Add(strHudwId);
  1511. arry.Add("I");
  1512. arry.Add(strHudwId);
  1513. arry.Add("I");
  1514. CommonClientToServer cctos = new CommonClientToServer();
  1515. cctos.ob = ob;
  1516. //查询化学成分信息
  1517. DataSet ds = cctos.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  1518. "ReceiveHmpCraftElement", arry, out strErr);
  1519. if (strErr == "" && ds != null)
  1520. {
  1521. ultraDataSource2.Rows.Clear();
  1522. if (ds.Tables.Count > 0)
  1523. {
  1524. foreach (DataRow dr in ds.Tables[0].Rows)
  1525. {
  1526. if (dr["CHECKNO"].ToString().Substring(2, 1) == "3")
  1527. strItemName = "平台";
  1528. else
  1529. {
  1530. if (dr["CHECKNO"].ToString().Substring(13, 1) == "2")
  1531. strItemName = "脱硫前";
  1532. else
  1533. strItemName = "脱硫后[" + dr["CHECKNO"].ToString().Substring(13, 1) + "]";
  1534. }
  1535. ultraDataSource2.Rows.Add(new object[] {
  1536. dr["heatno"].ToString(),
  1537. dr["c"].ToString(),
  1538. dr["si"].ToString(),
  1539. dr["mn"].ToString(),
  1540. dr["p"].ToString(),
  1541. dr["s"].ToString(),
  1542. dr["asn"].ToString(),
  1543. dr["ni"].ToString(),
  1544. dr["Cu"].ToString(),
  1545. dr["Sn"].ToString(),
  1546. dr["sb"].ToString(),
  1547. dr["CHECKNO"].ToString(),
  1548. strItemName
  1549. });
  1550. }
  1551. }
  1552. }
  1553. }
  1554. catch
  1555. { }
  1556. }
  1557. /// <summary>
  1558. /// 获取炉号
  1559. /// </summary>
  1560. private void GetCVTHeatno()
  1561. {
  1562. try
  1563. {
  1564. this.txtCVT1.Text = "";
  1565. this.txtCVT1.Appearance.BackColor = Color.LightGray;
  1566. this.txtCVT2.Text = "";
  1567. this.txtCVT2.Appearance.BackColor = Color.LightGray;
  1568. this.txtCVT3.Text = "";
  1569. this.txtCVT3.Appearance.BackColor = Color.LightGray;
  1570. string strErr = "";
  1571. string strSqlID = "GetCVTHMPCurrentHeatNo.Select";//此ID为XML文件ID
  1572. //查询转炉正在生产炉号信息
  1573. DataSet ds = this.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  1574. "GetCVTHMPCurrentHeatNo", strSqlID, out strErr);
  1575. if (strErr == "")
  1576. {
  1577. if (ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
  1578. {
  1579. for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
  1580. {
  1581. string v_LH = "";
  1582. string v_POS = ds.Tables[0].Rows[i]["objectid"].ToString().Substring(0, 1);
  1583. string v_POSID = ds.Tables[0].Rows[i]["objectpos"].ToString().Substring(3, 2);
  1584. // if (ds.Tables[0].Rows[i]["objectid"].ToString().Substring(0, 1) == "V") v_LH = "V" + v_LH;
  1585. if (v_POS == "C")
  1586. {
  1587. v_LH = CStaticMethod.getSmeltingID(ds.Tables[0].Rows[i]["objectid"].ToString());
  1588. if (v_POSID == "01")
  1589. {
  1590. if (_strSendSucceededForBof1 == "" || _strSendSucceededForBof1 == "N") ExistSendIronToBof(v_LH, "1");
  1591. if (_strSendSucceededForBof1 == "Y") txtCVT1.Appearance.BackColor = Color.LightBlue;
  1592. this.txtCVT1.Text = v_LH;
  1593. }
  1594. if (v_POSID == "02")
  1595. {
  1596. try
  1597. {
  1598. if (_strSendSucceededForBof2 == "" || _strSendSucceededForBof2 == "N") ExistSendIronToBof(v_LH, "2");
  1599. if (_strSendSucceededForBof2 == "Y") txtCVT2.Appearance.BackColor = Color.LightBlue;
  1600. this.txtCVT2.Text = v_LH;
  1601. }
  1602. catch
  1603. {
  1604. }
  1605. }
  1606. if (v_POSID == "03")
  1607. {
  1608. if (_strSendSucceededForBof3 == "" || _strSendSucceededForBof3 == "N") ExistSendIronToBof(v_LH, "3");
  1609. if (_strSendSucceededForBof3 == "Y") txtCVT3.Appearance.BackColor = Color.LightBlue;
  1610. this.txtCVT3.Text = v_LH;
  1611. }
  1612. }
  1613. }
  1614. }
  1615. if (txtCVT1.Text.Trim().Length == 0) _strSendSucceededForBof1 = "N";
  1616. if (txtCVT2.Text.Trim().Length == 0) _strSendSucceededForBof2 = "N";
  1617. if (txtCVT3.Text.Trim().Length == 0) _strSendSucceededForBof3 = "N";
  1618. }
  1619. }
  1620. catch (Exception EE)
  1621. {
  1622. }
  1623. }
  1624. #endregion
  1625. #region "gridevent"
  1626. private void ultraGrid1_Click(object sender, EventArgs e)
  1627. {
  1628. try
  1629. {
  1630. Infragistics.Win.UltraWinGrid.UltraGridRow aRow = ultraGrid1.ActiveRow;
  1631. Getoverelement(aRow.Cells["HUDWID"].Text);
  1632. //if (aRow == null) return;
  1633. //ultSelectIron.Text = aRow.Cells["HUDWID"].Text;
  1634. //ArrayIronRow4[0] = aRow.Cells["HUDWID"].Text;
  1635. //ArrayIronRow4[1] = aRow.Cells["SWBTEMPERATURE"].Value.ToString() != System.DBNull.Value.ToString() ? aRow.Cells["SWBTEMPERATURE"].Text : "0";
  1636. //ArrayIronRow4[2] = aRow.Cells["IRONPWRAPNO"].Value.ToString() != System.DBNull.Value.ToString() ? aRow.Cells["IRONPWRAPNO"].Text : "";
  1637. //ArrayIronRow4[3] = aRow.Cells["IRONWGT"].Value.ToString() != System.DBNull.Value.ToString() ? aRow.Cells["IRONWGT"].Text : "0";
  1638. //ArrayIronRow4[6] = aRow.Cells["RSSTOVENO"].Text;
  1639. //ArrayIronRow4[7] = aRow.Cells["RSWGT"].Value.ToString() != System.DBNull.Value.ToString() ? aRow.Cells["RSWGT"].Text : "0";
  1640. }
  1641. catch
  1642. {
  1643. }
  1644. }
  1645. #endregion
  1646. private void btnGLCF_Click(object sender, EventArgs e)
  1647. {
  1648. //Core.LgMes.Client.LgResMgt.JinTie frm = new Core.LgMes.Client.LgResMgt.JinTie();
  1649. //frm.Location = CStaticMethod.GetChildWindowLocation(frm.Size);
  1650. //frm.AutoSize = true;
  1651. //frm.blGLCF = true;
  1652. //frm.strWhere = "where to_char(WTIME,'yyyy-MM-dd')>='" + DateTime.Now.ToString("yyyy-MM-dd") + "' and to_char(WTIME,'yyyy-MM-dd')<='" + DateTime.Now.ToString("yyyy-MM-dd") + "'";
  1653. //// frm.button1_Click(null, null);
  1654. //frm.ShowDialog();
  1655. }
  1656. /// <summary>
  1657. /// 判断是否已发送过铁水信息
  1658. /// </summary>
  1659. /// <param name="strID"></param>
  1660. /// <param name="strPos"></param>
  1661. private void ExistSendIronToBof(string strID, string strPos)
  1662. {
  1663. string strErr = "";
  1664. string strCount = "";
  1665. ArrayList arry = new ArrayList();
  1666. arry.Add("ExistSendIronToBof");//此ID为XML文件ID
  1667. arry.Add(strID);
  1668. arry.Add(strID);
  1669. //查询脱硫完成信息
  1670. DataSet ds = this.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  1671. "ExistSendIronToBof", arry, out strErr);
  1672. if (strErr == "" && ds != null)
  1673. {
  1674. if (Convert.ToInt32(ds.Tables[0].Rows[0]["intCount"]) > 0)
  1675. strCount = "Y";
  1676. else
  1677. strCount = "N";
  1678. switch (strPos)
  1679. {
  1680. case "1":
  1681. _strSendSucceededForBof1 = strCount;
  1682. break;
  1683. case "2":
  1684. _strSendSucceededForBof2 = strCount;
  1685. break;
  1686. case "3":
  1687. _strSendSucceededForBof3 = strCount;
  1688. break;
  1689. default:
  1690. break;
  1691. }
  1692. }
  1693. }
  1694. private void ulgridElement_Click(object sender, EventArgs e)
  1695. {
  1696. try
  1697. {
  1698. Infragistics.Win.UltraWinGrid.UltraGridRow ultrRow = ulgridElement.ActiveRow;
  1699. if (ultrRow != null)
  1700. {
  1701. ArrayIronRow4[9] = ultrRow.Cells["CheckNo"].Value.ToString();
  1702. ArrayIronRow4[8] = ultrRow.Cells["S"].Value.ToString() != System.DBNull.Value.ToString() ? ultrRow.Cells["S"].Value.ToString() : "0";
  1703. ultHeatNO.Text = ultrRow.Cells["heatno"].Value.ToString();
  1704. strCheckNo = ultrRow.Cells["CheckNo"].Value.ToString();
  1705. }
  1706. }
  1707. catch
  1708. {
  1709. }
  1710. }
  1711. private void ultraGrid1_DoubleClickRow(object sender, Infragistics.Win.UltraWinGrid.DoubleClickRowEventArgs e)
  1712. {
  1713. if (ultraGrid1.ActiveRow != null)
  1714. {
  1715. frmSendIron frmSIron = new frmSendIron();
  1716. frmSIron.ob = this.ob;
  1717. frmSIron.strKR_Charge_NO = ultraGrid1.ActiveRow.Cells["HUDWID"].Value.ToString();
  1718. frmSIron.StartPosition = FormStartPosition.CenterParent;
  1719. frmSIron.ShowDialog();
  1720. }
  1721. }
  1722. }
  1723. }