frmHmpJob.cs 77 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962
  1. using System;
  2. using System.Data;
  3. using System.Drawing;
  4. using System.Windows.Forms;
  5. using System.Threading;
  6. using Core.LgMes.Client.lgClassModel;
  7. using System.Collections;
  8. using System.Reflection;
  9. using Core.Mes.Client.Common;
  10. using Core.LgMes.Client.LgIntegrationQuery;
  11. using Core.LgMes.Client.Report;
  12. using Core.LgMes.Client.Comm;
  13. using Core.LgMes.Client.LgResMgt;
  14. namespace Core.LgMes.Client.LgJobMgt
  15. {
  16. public partial class frmHmpJob : CommonClientToServer
  17. {
  18. #region " Class Member Variable"
  19. private string _heatProcessNo = ""; // 加热处理号
  20. private string _hudWid = ""; // 脱硫处理号
  21. private DataTable _dtCraftElement = null; // 工艺化学成分信息表
  22. private DataTable _dtStdElement = null; // 标准成分表
  23. private CommandClass _commClass; // 消息发送类
  24. private string _DEVICE_POSITION = "HMP01"; // 设备位置
  25. private int _DEVICE_POS = 1; // 设备号
  26. private Thread _getDataThread; // 取数据线程
  27. private Thread _setDataThread; // 刷新数据线程
  28. private bool _bIfGetData = true; // 控制取数据线程循环的标志
  29. private bool _bIfSetData = true; // 控制刷新数据线程循环的标志
  30. private bool _bResetDataFlag = false; // 清空所有数据标志,True表示已经清空
  31. private ArrayList _listHeatProcess = null; // 存储加热处理号的数组列表
  32. private Wsid _wsID; // 脱硫工位号 (区分双工位同时脱硫的情况)
  33. private string _devPos = ""; // 当前设备位置的全称
  34. private TrackObjectInfo _tmpObjTrack; // 实时跟踪信息类 用于存放当前实时跟踪信息 起一个中间过渡的缓冲
  35. private TrackObjectInfo _objTrackBuffer; // 用于实时刷新实时跟踪信息的缓冲区
  36. private CraftElement _tmpObjCraftEle; // 存放铁水成分信息的类
  37. private CraftElement _objCraftEleBuffer; // 用于实时刷新铁水成分信息的缓冲区
  38. private Hashtable _htOptInfo; // 用于存储脱硫操作信息的表字段数据
  39. private delegate void SetDataThreadDelegate(); // 刷新数据线程的一个委托方法,目的是达到界面所有数据刷新同步
  40. private string _szWorkBit = "3"; // 初始化为 3 (1 为1#小车; 2 为2# 小车; 3为钢包位)
  41. private string[] ArrayIronRow4 = new string[25] { "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" }; //保存发送到转炉铁水数据
  42. private string _strSendSucceededForBof1 = "";
  43. private string _strSendSucceededForBof2 = "";
  44. private string _strSendSucceededForBof3 = "";
  45. private string strCheckNo = ""; //化学成分编码
  46. #endregion
  47. #region " Enum "
  48. private enum Wsid
  49. {
  50. wdFirst,
  51. wdSecond
  52. }
  53. #endregion
  54. #region " Construct Function "
  55. public frmHmpJob()
  56. {
  57. InitializeComponent();
  58. CheckForIllegalCrossThreadCalls = false;
  59. // 初始化成员变量
  60. _commClass = new CommandClass();
  61. _tmpObjTrack = new TrackObjectInfo();
  62. _objTrackBuffer = new TrackObjectInfo();
  63. _tmpObjCraftEle = new CraftElement();
  64. _objCraftEleBuffer = new CraftElement();
  65. _htOptInfo = new Hashtable();
  66. _wsID = Wsid.wdFirst; // 默认1#工位
  67. }
  68. #endregion
  69. #region " Init Form Element"
  70. private void frmHmpJob_Load(object sender, EventArgs e)
  71. {
  72. //GenerateTableFrame();
  73. GetDevicePosition();
  74. SetUserControlDelegate();
  75. StartUpThread();
  76. }
  77. /// <summary>
  78. /// 获取当前设备的后台实时跟踪信息
  79. /// </summary>
  80. private void GetTrackInfoData()
  81. {
  82. string strErr = "";
  83. ArrayList arry = new ArrayList();
  84. arry.Add("ReceiveTrackObjectData.Select");//此ID为XML文件ID
  85. arry.Add(_DEVICE_POSITION);
  86. //获取指定岗位后台实时跟踪信息
  87. DataSet ds = this.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassTrackObjectInfo",
  88. "ReceiveTrackObjectData", arry, out strErr);
  89. if (strErr == "" && ds != null)
  90. {
  91. DataSetToTrackObject(ref ds, ref _tmpObjTrack);
  92. }
  93. }
  94. /// <summary>
  95. /// 获得加热处理号
  96. /// </summary>
  97. private void GetHeatProcessList()
  98. {
  99. try
  100. {
  101. this._listHeatProcess = new ArrayList();
  102. string Key = "";
  103. string szDevice = "", szBack = "", szFront = "";
  104. RealDataTrackObjectInfor objTrack;
  105. Key = _DEVICE_POSITION + "_DEVICE";
  106. objTrack = (RealDataTrackObjectInfor)_objTrackBuffer.hList[Key];
  107. szDevice = (!string.IsNullOrEmpty(objTrack.OBJECTID)) ? objTrack.OBJECTID + objTrack.DEVICESTATES : "";
  108. Key = _DEVICE_POSITION + "_BACK";
  109. objTrack = (RealDataTrackObjectInfor)_objTrackBuffer.hList[Key];
  110. szBack = (!string.IsNullOrEmpty(objTrack.OBJECTID)) ? objTrack.OBJECTID + objTrack.DEVICESTATES : "";
  111. Key = _DEVICE_POSITION + "_FRONT";
  112. objTrack = (RealDataTrackObjectInfor)_objTrackBuffer.hList[Key];
  113. szFront = (!string.IsNullOrEmpty(objTrack.OBJECTID)) ? objTrack.OBJECTID + objTrack.DEVICESTATES : "";
  114. _listHeatProcess.Add(szFront); //Front (1#脱硫1小车位)
  115. _listHeatProcess.Add(szDevice); //device (1#脱硫工位)
  116. _listHeatProcess.Add(szBack); //Back (1#脱硫2小车位)
  117. }
  118. catch (Exception ex)
  119. {
  120. string msg = ex.Message;
  121. _listHeatProcess = null;
  122. }
  123. }
  124. /// <summary>
  125. /// 对获取到的加热处理号进行判断
  126. /// </summary>
  127. private void JudgeHeatProcess()
  128. {
  129. try
  130. {
  131. if (_listHeatProcess.Count < 3)
  132. return;
  133. _heatProcessNo = "";
  134. _devPos = "";
  135. _hudWid = "";
  136. //Device 1#脱硫工位
  137. if (_wsID == Wsid.wdFirst && _listHeatProcess[1].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  138. {
  139. string strHeat = _listHeatProcess[1].ToString();
  140. _heatProcessNo = strHeat.Substring(0, (int)OBJLEN.nHudwProcessNo);
  141. _devPos = GetDevDeviceCodeOfHmp(_DEVICE_POS);
  142. _hudWid = (_heatProcessNo.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(_heatProcessNo) : "";
  143. }
  144. //Front 2#脱硫工位
  145. if ((_heatProcessNo == "" && _listHeatProcess[0].ToString().Length > (int)OBJLEN.nHudwProcessNo) ||
  146. (_wsID == Wsid.wdSecond && _listHeatProcess[0].ToString().Length > (int)OBJLEN.nHudwProcessNo))
  147. {
  148. string strHeat = _listHeatProcess[0].ToString();
  149. _heatProcessNo = strHeat.Substring(0, (int)OBJLEN.nHudwProcessNo);
  150. _devPos = GetDevFrontCodeOfHmp(_DEVICE_POS);
  151. _hudWid = (_heatProcessNo.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(_heatProcessNo) : "";
  152. }
  153. //Back 脱硫2#小车位
  154. if (_heatProcessNo == "" && _listHeatProcess[2].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  155. {
  156. string strHeat = _listHeatProcess[2].ToString();
  157. _heatProcessNo = strHeat.Substring(0, (int)OBJLEN.nHudwProcessNo);
  158. _devPos = GetDevBackCodeOfHmp(_DEVICE_POS);
  159. _hudWid = (_heatProcessNo.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(_heatProcessNo) : "";
  160. }
  161. }
  162. catch
  163. {
  164. return;
  165. }
  166. }
  167. /// <summary>
  168. /// 获取设备位置信息
  169. /// </summary>
  170. private void GetDevPosInfo()
  171. {
  172. try
  173. {
  174. string strState = "";
  175. if (_listHeatProcess[0].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  176. {
  177. string strHeat = _listHeatProcess[0].ToString();
  178. strState = strHeat.Substring((int)OBJLEN.nHudwProcessNo);
  179. }
  180. else if (_listHeatProcess[1].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  181. {
  182. string strHeat = _listHeatProcess[1].ToString();
  183. strState = strHeat.Substring((int)OBJLEN.nHudwProcessNo);
  184. }
  185. else if (_listHeatProcess[2].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  186. {
  187. string strHeat = _listHeatProcess[2].ToString();
  188. strState = strHeat.Substring((int)OBJLEN.nHudwProcessNo);
  189. }
  190. if (_htOptInfo.Contains("TP"))
  191. _htOptInfo.Remove("TP");
  192. _htOptInfo.Add("TP", SetPic(strState)); // 图片
  193. if (_listHeatProcess.Count >= 3)
  194. {
  195. string szID = _listHeatProcess[0].ToString();
  196. string strFrontPos = ""; //上道工序
  197. szID = _listHeatProcess[0].ToString();
  198. szID = (szID.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(szID.Substring(0, (int)OBJLEN.nHudwProcessNo)) : "";
  199. if (_htOptInfo.Contains("FRONT"))
  200. _htOptInfo.Remove("FRONT");
  201. _htOptInfo.Add("FRONT", szID); // 1#小车位
  202. //处理位信息
  203. RealDataTrackObjectInfor objTrack = (RealDataTrackObjectInfor)_objTrackBuffer.hList["HMP0" + _DEVICE_POS + "_DEVICE"];
  204. szID = _listHeatProcess[1].ToString();
  205. szID = (szID.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(szID.Substring(0, (int)OBJLEN.nHudwProcessNo)) : "";
  206. if (_listHeatProcess[1].ToString().Length > (int)OBJLEN.nHudwProcessNo && _listHeatProcess[1].ToString().Substring(0, (int)OBJLEN.nHudwProcessNo) == objTrack.OBJECTID.ToString())
  207. strFrontPos = objTrack.FRONTPOS.ToString();
  208. if (strFrontPos == "HMP0" + _DEVICE_POS + "_BACK")
  209. {
  210. if (_htOptInfo.Contains("DEVICE2"))
  211. _htOptInfo.Remove("DEVICE2");
  212. _htOptInfo.Add("DEVICE2", szID); // 2#处理位
  213. if (_htOptInfo.Contains("DEVICE"))
  214. _htOptInfo.Remove("DEVICE");
  215. }
  216. else
  217. {
  218. if (_htOptInfo.Contains("DEVICE"))
  219. _htOptInfo.Remove("DEVICE");
  220. _htOptInfo.Add("DEVICE", szID); // 1#处理位
  221. if (_htOptInfo.Contains("DEVICE2"))
  222. _htOptInfo.Remove("DEVICE2");
  223. }
  224. szID = _listHeatProcess[2].ToString();
  225. szID = (szID.Length > (int)OBJLEN.nHudwId) ? CStaticMethod.getHudwIdID(szID.Substring(0, (int)OBJLEN.nHudwProcessNo)) : "";
  226. if (_htOptInfo.Contains("BACK"))
  227. _htOptInfo.Remove("BACK");
  228. _htOptInfo.Add("BACK", szID); // 2#小车位
  229. }
  230. }
  231. catch { }
  232. }
  233. #region " From DataSet To Buffer "
  234. private void DataSetToTrackObject(ref DataSet ds, ref TrackObjectInfo obj)
  235. {
  236. try
  237. {
  238. obj.ClearElement();
  239. PropertyInfo[] PropertyInfos = null;
  240. foreach (DataRow dr in ds.Tables[0].Rows)
  241. {
  242. RealDataTrackObjectInfor detail = new RealDataTrackObjectInfor();
  243. if (PropertyInfos == null)
  244. {
  245. PropertyInfos = detail.GetType().GetProperties();
  246. }
  247. //给各个属性赋值
  248. foreach (PropertyInfo oPropertyInfo in PropertyInfos)
  249. {
  250. try
  251. {
  252. if (dr[oPropertyInfo.Name] != System.DBNull.Value)
  253. {
  254. oPropertyInfo.SetValue(detail, dr[oPropertyInfo.Name.ToString()], null);
  255. }
  256. }
  257. catch (Exception ex)
  258. {
  259. MessageBox.Show(ex.Message);
  260. }
  261. }
  262. obj.Add(ref detail);
  263. }//end foreach
  264. _objTrackBuffer.DataHarmonize(ref obj);
  265. }
  266. catch (Exception ex)
  267. {
  268. string Msg = ex.Message;
  269. }
  270. finally
  271. {
  272. }
  273. }
  274. private void DataSetToCraftElement(ref DataSet ds, ref CraftElement obj)
  275. {
  276. try
  277. {
  278. obj.ClearElement();
  279. PropertyInfo[] PropertyInfos = null;
  280. foreach (DataRow dr in ds.Tables[0].Rows)
  281. {
  282. JOB_CHEMELEMENT detail = new JOB_CHEMELEMENT();
  283. if (PropertyInfos == null)
  284. {
  285. PropertyInfos = detail.GetType().GetProperties();
  286. }
  287. //给各个属性赋值
  288. foreach (PropertyInfo oPropertyInfo in PropertyInfos)
  289. {
  290. try
  291. {
  292. if (dr[oPropertyInfo.Name] != System.DBNull.Value)
  293. {
  294. oPropertyInfo.SetValue(detail, dr[oPropertyInfo.Name.ToString()], null);
  295. }
  296. }
  297. catch (Exception ex)
  298. {
  299. MessageBox.Show(ex.Message);
  300. }
  301. }
  302. obj.Add(ref detail);
  303. }//end foreach
  304. _objCraftEleBuffer.DataHarmonize(ref obj);
  305. }
  306. catch (Exception ex)
  307. {
  308. string Msg = ex.Message;
  309. }
  310. finally
  311. {
  312. }
  313. }
  314. #endregion
  315. #endregion
  316. #region " Thread Handle "
  317. /// <summary>
  318. /// 启动线程主程序
  319. /// </summary>
  320. private void StartUpThread()
  321. {
  322. ThreadStart ts = new ThreadStart(GetDataThread);
  323. _getDataThread = new Thread(ts);
  324. _getDataThread.Name = "GetDataThread " + _DEVICE_POSITION;
  325. _getDataThread.Start();
  326. System.Threading.Thread.Sleep(1000);
  327. ThreadStart ts1 = new ThreadStart(SetDataThread);
  328. _setDataThread = new Thread(ts1);
  329. _setDataThread.Name = "SetDataThread " + _DEVICE_POSITION;
  330. _setDataThread.Start();
  331. }
  332. /// <summary>
  333. /// 取数据线程程序
  334. /// </summary>
  335. private void GetDataThread()
  336. {
  337. while (_bIfGetData)
  338. {
  339. if (!this.On_Off_Thread)
  340. {
  341. System.Threading.Thread.Sleep(500);
  342. continue;
  343. }
  344. try
  345. {
  346. this.Invoke(new SetDataThreadDelegate(GetDataFromServer));
  347. Thread.Sleep(2000);
  348. }
  349. catch { }
  350. }
  351. }
  352. /// <summary>
  353. /// 刷新数据线程程序
  354. /// </summary>
  355. private void SetDataThread()
  356. {
  357. while (_bIfSetData)
  358. {
  359. if (!this.On_Off_Thread)//this.On_Off_Thread
  360. {
  361. System.Threading.Thread.Sleep(500);
  362. continue;
  363. }
  364. try
  365. {
  366. this.Invoke(new SetDataThreadDelegate(SetDataOperate));
  367. Thread.Sleep(1000);
  368. }
  369. catch { }
  370. }
  371. }
  372. private void GetDataFromServer()
  373. {
  374. GetTrackInfoData();
  375. GetHeatProcessList();
  376. JudgeHeatProcess();
  377. GetOptInfo();
  378. GetCraftEleInfo();
  379. GetDevPosInfo();//岗位信息
  380. getoverhmpdate();//获取脱完硫的铁水信息
  381. getelement(); //获取成分信息
  382. GetCVTHeatno();//获取炼钢炉号
  383. }
  384. private void SetDataOperate()
  385. {
  386. lock (this)
  387. {
  388. if (this._heatProcessNo == "")
  389. {
  390. ResetAllData();
  391. return;
  392. }
  393. _bResetDataFlag = false;
  394. FillCraftElement();
  395. FillUserControlData();
  396. }
  397. }
  398. #endregion
  399. #region " Delegate "
  400. /// <summary>
  401. /// 异常操作
  402. /// </summary>
  403. /// <param name="sender"></param>
  404. /// <param name="e"></param>
  405. private void ucHmpDevInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  406. {
  407. string[] bufferArray = { "", "", "", "" };
  408. string strMsg = "";
  409. switch (e.Cell.Column.Key)
  410. {
  411. case "FRONT":
  412. {
  413. if (e.Cell.Text != string.Empty && _listHeatProcess[0].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  414. {
  415. string strCurtPos = "HMP0" + _DEVICE_POS.ToString() + "_FRONT";
  416. string sFrontHeatNo = _listHeatProcess[0].ToString().Substring(0, (int)OBJLEN.nHudwProcessNo);
  417. ClassManualOperate.arryHeatNo = _listHeatProcess;
  418. ClassManualOperate.ManualOperateEntrance(sFrontHeatNo, strCurtPos, this.ob, _objTrackBuffer);
  419. }
  420. }
  421. break;
  422. case "DEVICE":
  423. {
  424. if (e.Cell.Text != string.Empty && _listHeatProcess[1].ToString().Length > (int)OBJLEN.nHudwProcessNo)
  425. {
  426. string strCurtPos = "HMP0" + _DEVICE_POS.ToString() + "_DEVICE";
  427. string sCurHeatNo = _listHeatProcess[1].ToString().Substring(0, (int)OBJLEN.nHudwProcessNo);
  428. ClassManualOperate.arryHeatNo = _listHeatProcess;
  429. ClassManualOperate.ManualOperateEntrance(sCurHeatNo, strCurtPos, this.ob, _objTrackBuffer);
  430. }
  431. }
  432. break;
  433. default:
  434. break;
  435. }
  436. }
  437. private void ucBaseInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  438. {
  439. string strHudwID = "";
  440. string strDevice = "";
  441. System.Windows.Forms.DialogResult drValue;
  442. switch (e.Cell.Column.Key)
  443. {
  444. case "HEATPROCESSNO": // 脱硫工位
  445. if (string.IsNullOrEmpty(_heatProcessNo))
  446. {
  447. drValue = MessageBox.Show("是否确认要手动加载新的脱硫作业信息?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
  448. if (drValue == DialogResult.Yes)
  449. {
  450. strDevice = "_FRONT";
  451. strHudwID = Getdeslagidfromresults();
  452. if (!string.IsNullOrEmpty(strHudwID))
  453. {
  454. this._commClass.obComm = this.ob;
  455. this._commClass.setChargingCommand("MOLSTL", _DEVICE_POSITION + strDevice, strHudwID);
  456. SetDataValue("ARRIVETIME", "DATE", DateTime.Now.ToString(), strHudwID);
  457. }
  458. }
  459. }
  460. else
  461. MessageBox.Show("当前脱硫岗位正在生产不能加载!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  462. break;
  463. case "HUDWID": //取消脱硫号
  464. if (!string.IsNullOrEmpty(_heatProcessNo))
  465. {
  466. drValue = MessageBox.Show("是否确认要取消【"+ _htOptInfo["HUDWID"].ToString() +"】脱硫信息,取消后无法恢复请确认?", "警告", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
  467. if (drValue == DialogResult.Yes)
  468. {
  469. string strSqlID = "CancelHmpJobInfo.Cancel"; //SQLID
  470. string strErr = "";
  471. Hashtable ht = new Hashtable();
  472. ht.Add("I1", _heatProcessNo); //加热处理号
  473. ht.Add("O1", "");
  474. ht.Add("O2", "");
  475. CommonClientToServer ccTs = new CommonClientToServer();
  476. ccTs.ob = ob;
  477. string strRCode = ccTs.ExecuteProcedureFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  478. "CancelHmpJobInfo", strSqlID, ht, out strErr);
  479. if (strErr != "")
  480. {
  481. MessageBox.Show("取消误加载脱硫作业信息失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  482. return;
  483. }
  484. }
  485. }
  486. else
  487. MessageBox.Show("当前脱硫岗位没有生产!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  488. break;
  489. case "SHIFTCODE": // 班次
  490. string szBC = _htOptInfo.Contains("SHIFTCODE") ? _htOptInfo["SHIFTCODE"].ToString() : "";
  491. ClassCellButton(e.Cell, szBC);
  492. break;
  493. default:
  494. break;
  495. }
  496. }
  497. private void ucBaseInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  498. {
  499. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  500. return;
  501. if (MessageBox.Show("是否确认要修改脱硫处理号?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Warning) == DialogResult.Yes)
  502. {
  503. ucBaseInfo1.ultraGrid1.UpdateData();
  504. if (ucBaseInfo1.ultraGrid1.ActiveCell.Text.ToString().Length == 9)
  505. {
  506. string keyStr = ucBaseInfo1.ultraGrid1.ActiveCell.Column.Key;
  507. string valueStr;
  508. try
  509. {
  510. if (ucBaseInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  511. {
  512. valueStr = ucBaseInfo1.ultraGrid1.ActiveCell.Text.ToString();
  513. SetDataValue(keyStr, "VARCHAR2", valueStr, _heatProcessNo);
  514. }
  515. }
  516. catch (Exception ex)
  517. {
  518. string Msg = ex.Message;
  519. MessageBox.Show("保存失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  520. }
  521. }
  522. else
  523. MessageBox.Show("脱硫处理号格式不正确(例:K11-00001)!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
  524. }
  525. }
  526. private void ucHmpInInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  527. {
  528. string strIronpwrapNo = ""; //铁包包号
  529. string strIronpotgrosswgt = ""; //铁水毛重
  530. string strIronpottarewgt = "";//铁罐皮重
  531. string strIronwgt = "";//铁水重量
  532. string strIronsource = ""; //铁水来源
  533. string strEquipmentno = "";//工位号
  534. string strHudwID = ""; //脱硫处理号
  535. string strTemptur = ""; //温度
  536. string strHeatProcessNO = ""; //加热处理号
  537. switch (e.Cell.Column.Key)
  538. {
  539. case "IRONSOURCE": // 铁水来源
  540. string szJZSK = "";
  541. if (_htOptInfo.Contains("ARRIVETIME"))
  542. {
  543. if (_htOptInfo != null && _htOptInfo["ARRIVETIME"] != null && !string.IsNullOrEmpty(_htOptInfo["ARRIVETIME"].ToString()))
  544. {
  545. szJZSK = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  546. frmHMPIron frm = new frmHMPIron(szJZSK, _DEVICE_POSITION);
  547. frm.Location = CStaticMethod.GetChildWindowLocation(frm.Size);
  548. frm.ob = this.ob;
  549. frm.ShowDialog();
  550. // if (!string.IsNullOrEmpty(frm._strIronwrapid))
  551. string strErr = "";
  552. if (frm._strIronwrapid.Trim().Length > 0 && frm._strIronpotwgt.Trim().Length > 0)
  553. {
  554. string strSqlID = "HmpJobIronMolirnSource.Update"; //SQLID
  555. Hashtable ht = new Hashtable();
  556. ht.Add("I1", _heatProcessNo); //加热处理号
  557. ht.Add("I2", _htOptInfo["HUDWID"].ToString()); //脱硫号
  558. ht.Add("I3", frm._strMisid); //铁水来源(铁水来源主键)
  559. ht.Add("I4", frm._strIronwrapid); //铁包号
  560. ht.Add("I5", frm._strIronpotgrosswgt); //铁水毛重
  561. ht.Add("I6", frm._strIronpottarewgt); //铁水皮重
  562. ht.Add("I7", frm._strIronpotwgt); //铁水重量
  563. ht.Add("I8", frm._strIrontemperature); //铁水温度
  564. ht.Add("I9", frm._strRsWgt); //回炉钢水
  565. ht.Add("O1", "");
  566. ht.Add("O2", "");
  567. CommonClientToServer ccTs = new CommonClientToServer();
  568. ccTs.ob = ob;
  569. string strRCode = ccTs.ExecuteProcedureFunctions("Core.LgMes.Server.LgJobMgt.ClassHmpJob",
  570. "HmpJobIronMolirnSource", strSqlID, ht, out strErr);
  571. if (strErr != "")
  572. {
  573. MessageBox.Show("数据保存失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  574. return;
  575. }
  576. }
  577. }
  578. else
  579. MessageBox.Show("进铁时刻不能为空值,请设置进铁时刻!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
  580. }
  581. break;
  582. case "ARRIVETIME": // 进站时刻
  583. SetCellDateTime(e.Cell, "STL_HMP_OPTINFO", e.Cell.Column.Key.ToString());
  584. break;
  585. default:
  586. break;
  587. }
  588. }
  589. private void ucHmpOutInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  590. {
  591. switch (e.Cell.Column.Key)
  592. {
  593. case "MOLIRNLEAVE": // 铁水去向
  594. if (_htOptInfo.Contains("HUDWID"))
  595. {
  596. frmMolirnleave frm = new frmMolirnleave();
  597. frm.Location = CStaticMethod.GetChildWindowLocation(frm.Size);
  598. frm.ShowDialog();
  599. if (!string.IsNullOrEmpty(frm.strStationCode) && !string.IsNullOrEmpty(_heatProcessNo))
  600. {
  601. SetDataValue("MOLIRNLEAVE", "VARCHAR2", frm.strStationCode, _heatProcessNo);
  602. }
  603. }
  604. break;
  605. case "LEAVETIME": // 出站时刻
  606. SetCellDateTime(e.Cell, "JOB_HMP_OPTINFO", e.Cell.Column.Key.ToString());
  607. break;
  608. default:
  609. break;
  610. }
  611. }
  612. private void ucHmpTimeInfo1_ClickCellButton(object sender, Infragistics.Win.UltraWinGrid.CellEventArgs e)
  613. {
  614. SetCellDateTime(e.Cell, "JOB_HMP_OPTINFO", e.Cell.Column.Key.ToString());
  615. }
  616. private void ucHmpTimeInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  617. {
  618. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  619. return;
  620. ucHmpTimeInfo1.ultraGrid1.UpdateData();
  621. string keyStr = ucHmpTimeInfo1.ultraGrid1.ActiveCell.Column.Key;
  622. DateTime valueStr;
  623. if (ucHmpTimeInfo1.ultraGrid1.ActiveCell.Column.DataType == typeof(System.DateTime))
  624. {
  625. try
  626. {
  627. if (ucHmpTimeInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  628. {
  629. valueStr = (DateTime)ucHmpTimeInfo1.ultraGrid1.ActiveCell.Value;
  630. SetDataValue(keyStr, "DATE", valueStr.ToString("yyyy-MM-dd HH:mm"), _heatProcessNo);
  631. ucHmpTimeInfo1.ultraGrid1.ActiveCell.Value = valueStr;
  632. }
  633. else
  634. SetDataValue(keyStr, "DATE", "", _heatProcessNo);
  635. }
  636. catch (Exception ex)
  637. {
  638. string Msg = ex.Message;
  639. MessageBox.Show("日期输入格式错误,请改正!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  640. }
  641. }
  642. }
  643. private void ucHmpInInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  644. {
  645. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  646. return;
  647. ucHmpInInfo1.ultraGrid1.UpdateData();
  648. string keyStr = ucHmpInInfo1.ultraGrid1.ActiveCell.Column.Key;
  649. DateTime valueStr;
  650. if (ucHmpInInfo1.ultraGrid1.ActiveCell.Column.DataType == typeof(System.DateTime))
  651. {
  652. try
  653. {
  654. if (ucHmpInInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  655. {
  656. valueStr = (DateTime)ucHmpInInfo1.ultraGrid1.ActiveCell.Value;
  657. SetDataValue(keyStr, "DATE", valueStr.ToString("yyyy-MM-dd HH:mm"), _heatProcessNo);
  658. ucHmpInInfo1.ultraGrid1.ActiveCell.Value = valueStr;
  659. }
  660. else
  661. {
  662. SetDataValue(keyStr, "DATE", null, _heatProcessNo);
  663. }
  664. }
  665. catch (Exception ex)
  666. {
  667. string Msg = ex.Message;
  668. MessageBox.Show("日期输入格式错误,请改正!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  669. }
  670. }
  671. else
  672. {
  673. string strValue = "";
  674. if (ucHmpInInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  675. {
  676. strValue = ucHmpInInfo1.ultraGrid1.ActiveCell.Value.ToString();
  677. ucHmpInInfo1.ultraGrid1.ActiveCell.Value = strValue;
  678. }
  679. if (keyStr.ToUpper() != "ARRIVEWGT")
  680. SetDataValue(keyStr, "VARCHAR2", strValue, _heatProcessNo);
  681. }
  682. }
  683. private void ucHmpOutInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  684. {
  685. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  686. return;
  687. ucHmpOutInfo1.ultraGrid1.UpdateData();
  688. string keyStr = ucHmpOutInfo1.ultraGrid1.ActiveCell.Column.Key;
  689. DateTime valueStr;
  690. if (ucHmpOutInfo1.ultraGrid1.ActiveCell.Column.DataType == typeof(System.DateTime))
  691. {
  692. try
  693. {
  694. if (ucHmpOutInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  695. {
  696. valueStr = (DateTime)ucHmpOutInfo1.ultraGrid1.ActiveCell.Value;
  697. SetDataValue(keyStr, "DATE", valueStr.ToString("yyyy-MM-dd HH:mm"), _heatProcessNo);
  698. ucHmpOutInfo1.ultraGrid1.ActiveCell.Value = valueStr;
  699. }
  700. else
  701. SetDataValue(keyStr, "DATE", null, _heatProcessNo);
  702. }
  703. catch (Exception ex)
  704. {
  705. string Msg = ex.Message;
  706. MessageBox.Show("日期输入格式错误,请改正!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  707. }
  708. }
  709. else
  710. {
  711. string strValue = "";
  712. if (ucHmpOutInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  713. {
  714. strValue = ucHmpOutInfo1.ultraGrid1.ActiveCell.Value.ToString();
  715. ucHmpOutInfo1.ultraGrid1.ActiveCell.Value = strValue;
  716. }
  717. if (keyStr.ToUpper() != "LEAVEWGT")
  718. SetDataValue(keyStr, "VARCHAR2", strValue, _heatProcessNo);
  719. }
  720. }
  721. private void ucHmpDevInfo1_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
  722. {
  723. if (e.KeyCode != Keys.Enter || _heatProcessNo.Length < 14)
  724. return;
  725. ucHmpDevInfo1.ultraGrid1.UpdateData();
  726. string keyStr = ucHmpDevInfo1.ultraGrid1.ActiveCell.Column.Key;
  727. string valueStr;
  728. try
  729. {
  730. if (ucHmpDevInfo1.ultraGrid1.ActiveCell.Value.ToString() != "")
  731. {
  732. valueStr = ucHmpDevInfo1.ultraGrid1.ActiveCell.Text.ToString();
  733. SetDataValue(keyStr, "VARCHAR2", valueStr, _heatProcessNo);
  734. }
  735. }
  736. catch (Exception ex)
  737. {
  738. string Msg = ex.Message;
  739. MessageBox.Show("保存失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  740. }
  741. }
  742. /// <summary>
  743. /// 时间显示框,在需要更改日期的时候弹出日期选择框
  744. /// </summary>
  745. /// <param name="cell"></param>
  746. /// <param name="strTableName"></param>
  747. /// <param name="strColumnName"></param>
  748. private void SetCellDateTime(Infragistics.Win.UltraWinGrid.UltraGridCell cell, string strTableName, string strColumnName)
  749. {
  750. frmSetTime frm = new frmSetTime(cell.Value);
  751. frm.Location = CStaticMethod.GetChildWindowLocation(frm.Size);
  752. frm.ShowDialog();
  753. if (_heatProcessNo.Length >= 11 && frm._returnTime > new DateTime(2000, 1, 1, 0, 0, 0, 0))
  754. {
  755. DateTime dt = frm._returnTime;
  756. cell.Value = dt;
  757. try
  758. {
  759. SetDataValue(strColumnName, "DATE", dt.ToString("yyyy-MM-dd HH:mm"), _heatProcessNo);
  760. }
  761. catch
  762. {
  763. MessageBox.Show("日期输入格式错误,请改正!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  764. }
  765. }
  766. }
  767. private void ClassCellButton(Infragistics.Win.UltraWinGrid.UltraGridCell cell, string strDuty)
  768. {
  769. frmClassSelect frm = new frmClassSelect(_heatProcessNo, strDuty);
  770. frm.Location = CStaticMethod.GetChildWindowLocation(frm.Size);
  771. frm.ShowDialog();
  772. if (frm._changeFlag)
  773. {
  774. cell.Value = frm._dutyID;
  775. if (_heatProcessNo.Length >= 11)
  776. {
  777. RealDataCommand realDataCommand = new RealDataCommand();
  778. realDataCommand.COMMANDTYPE = "SCHEDULE_SET";
  779. realDataCommand.OBJECTTYPE = "PROCVALUE";
  780. realDataCommand.OBJECTPOS = _devPos;
  781. realDataCommand.OBJECTID = _heatProcessNo;
  782. realDataCommand.OBJECTLINKTABLE = "JOB_HMP_OPTINFO";
  783. realDataCommand.OBJECTLINKKEY1 = _hudWid;//CStaticMethod.getSmeltingID(_heatProcessNo);
  784. realDataCommand.OBJECTLINKKEY2 = "SHIFTCODE";
  785. realDataCommand.VALUETYPE = "VARCHAR2";
  786. realDataCommand.STR_VALUE = frm._dutyID;
  787. string szOut = "";
  788. //hengxing
  789. //CallingMessage par = new CallingMessage();
  790. //par.ServerName = "lgJobMgt";
  791. //par.AssemblyName = "Core.LgMes.Server.lgJobMgt";
  792. //par.ClassName = "Core.LgMes.Server.lgJobMgt.classSendCommand";
  793. //par.MethodName = "UpdateTableField";
  794. //par.args = new object[] { realDataCommand };
  795. //ClientCommon._RemotingHelp.ExecuteMethod(par, out szOut);
  796. if (szOut != "")
  797. MessageBox.Show("命令发送不成功!");
  798. }
  799. }
  800. }
  801. #endregion
  802. #region " Commonly Function "
  803. /// <summary>
  804. /// 根据窗体名称获取设备位置
  805. /// </summary>
  806. private void GetDevicePosition()
  807. {
  808. if (this.Text == "") return;
  809. string str = this.CustomInfo.Trim();//this.Text.Substring(0, 1);
  810. str = str.Substring(str.Length - 1, 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. }