CStaticMethod.cs.svn-base 53 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. using System.Drawing;
  5. using System.Data;
  6. using System.Windows.Forms;
  7. using System.Collections;
  8. using CoreFS.CA06;
  9. using Core.LgMes.Client.lgClassModel;
  10. using Infragistics.Win.UltraWinGrid;
  11. using System.Runtime.InteropServices;
  12. using Core.Mes.Client.Common;
  13. using System.Text.RegularExpressions;
  14. namespace Core.LgMes.Client.Comm
  15. {
  16. public class CStaticMethod
  17. {
  18. /// <summary>
  19. /// 设置控件样式
  20. /// </summary>
  21. /// <param name="ulgrid"></param>
  22. /// <param name="intFlag">颜色标致</param>
  23. public static void SetUltraGridStyle(UltraGrid ulgrid,int intFlag)
  24. {
  25. Color CardBackColor =Color.PapayaWhip;
  26. Color RowBackColor = Color.LightBlue;
  27. switch (intFlag)
  28. {
  29. case 1:
  30. CardBackColor = Color.Honeydew;// Color.LightCyan;
  31. break;
  32. case 2:
  33. CardBackColor = Color.PapayaWhip;
  34. break;
  35. default:
  36. break;
  37. }
  38. ulgrid.DisplayLayout.Override.CardAreaAppearance.BackColor = CardBackColor; //卡片样式背景
  39. ulgrid.DisplayLayout.Override.HeaderAppearance.BackColor = CardBackColor; //表头背景
  40. ulgrid.DisplayLayout.Override.RowAppearance.BackColor = RowBackColor; //行的背景色
  41. //ulgrid.DisplayLayout.Override.CellAppearance.FontData.Bold = Infragistics.Win.DefaultableBoolean.True; //单元格字体加粗
  42. ulgrid.DisplayLayout.BorderStyle = Infragistics.Win.UIElementBorderStyle.None; //设置边框
  43. }
  44. //==========================================================
  45. // 获取子窗体弹出的位置坐标
  46. //==========================================================
  47. public static Point GetChildWindowLocation(Size ChildWindowSize)
  48. {
  49. int width = Cursor.Position.X + ChildWindowSize.Width - Screen.PrimaryScreen.Bounds.Width;
  50. int height = Cursor.Position.Y + ChildWindowSize.Height - Screen.PrimaryScreen.Bounds.Height + 30;
  51. width = (width > 0) ? (Cursor.Position.X - width) : Cursor.Position.X; // X坐标
  52. height = (height > 0) ? (Cursor.Position.Y - height + 10) : (Cursor.Position.Y + 10); // Y坐标
  53. return new Point(width, height);
  54. }
  55. public static void ResetTableRows(ref DataTable ATable, int newRowsCount)
  56. {
  57. int arows = Math.Abs(ATable.Rows.Count - newRowsCount);
  58. string[] sTmp = new string[ATable.Columns.Count];
  59. if (ATable.Rows.Count < newRowsCount)
  60. {
  61. for (int i = 0; i < arows; i++)
  62. ATable.Rows.Add(sTmp);
  63. }
  64. else
  65. {
  66. for (int i = arows - 1; i >= 0; i--)
  67. ATable.Rows[i].Delete();
  68. }
  69. }
  70. public static void AppendTableRows(ref DataTable ATable, int newRowsCount)
  71. {
  72. string[] sTmp = new string[ATable.Columns.Count];
  73. for (int i = 0; i < newRowsCount; i++)
  74. ATable.Rows.Add(sTmp);
  75. }
  76. /// <summary>
  77. /// 获取熔炼号函数
  78. /// </summary>
  79. /// <param name="heatProcessNumb"></param>
  80. /// <returns></returns>
  81. public static string getSmeltingID(string heatProcessNumb)
  82. {
  83. heatProcessNumb = heatProcessNumb.Trim();
  84. if (heatProcessNumb == "")
  85. return "";
  86. string subStr = heatProcessNumb.Substring((int)OBJLEN.nHeatProcessNo-(int)OBJLEN.nHeatNo, (int)OBJLEN.nHeatNo);
  87. return subStr;
  88. }
  89. /// <summary>
  90. /// 获取脱硫号函数
  91. /// </summary>
  92. /// <param name="heatProcessNumb"></param>
  93. /// <returns></returns>
  94. public static string getHudwIdID(string heatProcessNumb)
  95. {
  96. heatProcessNumb = heatProcessNumb.Trim();
  97. if (heatProcessNumb == "")
  98. return "";
  99. string subStr = heatProcessNumb.Substring((int)OBJLEN.nHudwProcessNo - (int)OBJLEN.nHudwId, (int)OBJLEN.nHudwId);
  100. return subStr;
  101. }
  102. /// <summary>i
  103. /// 转换熔炼号为中间带-的化学检验号
  104. /// </summary>
  105. /// <param name="SmeltID"></param>
  106. /// <returns></returns>
  107. public static string ConvertSmeltID(string SmeltID)
  108. {
  109. if (SmeltID.Trim().Equals(string.Empty))
  110. return "";
  111. string szStr = SmeltID.Substring(0, 3) + "-" + SmeltID.Substring(SmeltID.Length - 5);
  112. return szStr;
  113. }
  114. /// <summary>
  115. /// 作业路线转换
  116. /// </summary>
  117. /// <param name="szZYLX"></param>
  118. /// <returns></returns>
  119. public static string ConvertJobRoute(string szZYLX)
  120. {
  121. ArrayList ar = new ArrayList();
  122. string szLX = "";
  123. int nLen = 0;
  124. while (szZYLX.Length > 0)
  125. {
  126. nLen = szZYLX.IndexOf("LG", 1);
  127. if (nLen > 0)
  128. {
  129. szLX = szZYLX.Substring(0, nLen);
  130. szZYLX = szZYLX.Substring(nLen);
  131. }
  132. else
  133. {
  134. szLX = szZYLX.Substring(0);
  135. szZYLX = "";
  136. }
  137. ar.Add(szLX);
  138. }
  139. for (int i = 0; i < ar.Count; i++)
  140. {
  141. switch (ar[i].ToString())
  142. {
  143. case "LG2020000":
  144. szZYLX += "转炉->";
  145. break;
  146. case "LG20200001":
  147. szZYLX += "1#转炉->";
  148. break;
  149. case "LG20200002":
  150. szZYLX += "2#转炉->";
  151. break;
  152. case "LG20200003":
  153. szZYLX += "3#转炉->";
  154. break;
  155. case "LG2030000":
  156. szZYLX += "钢包站->";
  157. break;
  158. case "LG20300001":
  159. szZYLX += "1#钢包站->";
  160. break;
  161. case "LG20300002":
  162. szZYLX += "2#钢包站->";
  163. break;
  164. case "LG20300003":
  165. szZYLX += "3#钢包站->";
  166. break;
  167. case "LG2040000":
  168. szZYLX += "精炼炉->";
  169. break;
  170. case "LG20400001":
  171. szZYLX += "1#精炼炉->";
  172. break;
  173. case "LG20400002":
  174. szZYLX += "2#精炼炉->";
  175. break;
  176. case "LG20400003":
  177. szZYLX += "3#精炼炉->";
  178. break;
  179. case "LG2050000":
  180. szZYLX += "连铸机";
  181. break;
  182. case "LG20500001":
  183. szZYLX += "1#连铸机";
  184. break;
  185. case "LG20500002":
  186. szZYLX += "2#连铸机";
  187. break;
  188. case "LG20500003":
  189. szZYLX += "3#连铸机";
  190. break;
  191. case "LG20500004":
  192. szZYLX += "4#连铸机";
  193. break;
  194. default:
  195. break;
  196. }
  197. }
  198. return szZYLX;
  199. }
  200. /// <summary>
  201. /// 获取当前班次
  202. /// </summary>
  203. /// <returns></returns>
  204. public static string GetCurrentClass(CoreFS.CA06.OpeBase ope)
  205. {
  206. string strErr = "";
  207. string strSqlID = "GetCurrDuty.Select";
  208. Core.Mes.Client.Common.CommonClientToServer ccs = new Core.Mes.Client.Common.CommonClientToServer();
  209. ccs.ob = ope;
  210. //获取班次班别信息
  211. DataSet ds = ccs.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassCommonModule",
  212. "GetCurrDuty", strSqlID, out strErr);
  213. if (strErr == "" && ds != null)
  214. {
  215. if(ds.Tables[0]!=null && ds.Tables[0].Rows.Count>0)
  216. return ds.Tables[0].Rows[0][0].ToString();
  217. }
  218. return "";
  219. }
  220. /// <summary>
  221. /// 班次转换
  222. /// </summary>
  223. /// <returns></returns>
  224. public static string ClassConvert(string szClassID)
  225. {
  226. if (szClassID.Trim() == "")
  227. return "";
  228. if(szClassID.Length ==2)
  229. szClassID = szClassID.Substring(1);
  230. string szClassName = "";
  231. switch (szClassID)
  232. {
  233. case "1":
  234. szClassName = "甲";
  235. break;
  236. case "2":
  237. szClassName = "乙";
  238. break;
  239. case "3":
  240. szClassName = "丙";
  241. break;
  242. case "4":
  243. szClassName = "丁";
  244. break;
  245. default:
  246. break;
  247. }
  248. return szClassName;
  249. }
  250. /// <summary>
  251. /// 时间计算返回分
  252. /// </summary>
  253. /// <param name="startTime"></param>
  254. /// <param name="endTime"></param>
  255. /// <returns></returns>
  256. public static int caculateTime(DateTime startTime, DateTime endTime)
  257. {
  258. int lStayDuration = 0;
  259. TimeSpan odtSpan;
  260. if (endTime > startTime)
  261. {
  262. odtSpan = endTime - startTime;
  263. lStayDuration = Convert.ToInt32(System.Math.Round(odtSpan.TotalMinutes));
  264. }
  265. else if (startTime != endTime)
  266. {
  267. if (startTime > DateTime.Now)
  268. lStayDuration = 0;
  269. else
  270. {
  271. odtSpan = DateTime.Now - startTime;
  272. lStayDuration = Convert.ToInt32(System.Math.Round(odtSpan.TotalMinutes));
  273. }
  274. }
  275. return lStayDuration;
  276. }
  277. /// <summary>
  278. /// 时间计算返回秒
  279. /// </summary>
  280. /// <param name="startTime"></param>
  281. /// <param name="endTime"></param>
  282. /// <returns></returns>
  283. public static int caculateTimeSeconds(DateTime startTime, DateTime endTime)
  284. {
  285. int lStayDuration = 0;
  286. TimeSpan odtSpan;
  287. if (endTime > startTime)
  288. {
  289. odtSpan = endTime - startTime;
  290. lStayDuration = Convert.ToInt32(System.Math.Round(odtSpan.TotalSeconds));
  291. }
  292. else if (startTime != endTime)
  293. {
  294. if (startTime > DateTime.Now)
  295. lStayDuration = 0;
  296. else
  297. {
  298. odtSpan = DateTime.Now - startTime;
  299. lStayDuration = Convert.ToInt32(System.Math.Round(odtSpan.TotalSeconds));
  300. }
  301. }
  302. return lStayDuration;
  303. }
  304. /// <summary>
  305. /// 将秒转换成时间
  306. /// </summary>
  307. /// <param name="strSeconds"></param>
  308. /// <returns></returns>
  309. public static string caculateSecondsTime(string strSeconds)
  310. {
  311. string strTime = "0′0″";
  312. if (!string.IsNullOrEmpty(strSeconds) && strSeconds.Length > 0)
  313. {
  314. TimeSpan tsTime = new TimeSpan(0, 0, Convert.ToInt16(strSeconds));
  315. if (tsTime.Hours > 0)
  316. strTime = Convert.ToString(tsTime.Hours) + "′" + Convert.ToString(tsTime.Minutes)+ "′" + Convert.ToString(tsTime.Seconds) + "″";
  317. else
  318. strTime = Convert.ToString(tsTime.Minutes)+ "′" + Convert.ToString(tsTime.Seconds)+ "″";
  319. }
  320. return strTime;
  321. }
  322. /// <summary>
  323. /// 获取两个时间段的差值
  324. /// </summary>
  325. /// <param name="startTime"></param>
  326. /// <param name="endTime"></param>
  327. /// <returns></returns>
  328. public static int JudgeTime(DateTime startTime, DateTime endTime)
  329. {
  330. int lStayDuration = 0;
  331. TimeSpan odtSpan;
  332. if (endTime > startTime)
  333. {
  334. odtSpan = endTime - startTime;
  335. lStayDuration = Convert.ToInt32(System.Math.Round(odtSpan.TotalMinutes));
  336. }
  337. return lStayDuration;
  338. }
  339. /// <summary>
  340. /// 验证数据有效性(Number)
  341. /// </summary>
  342. /// <param name="szVal"></param>
  343. public static void CheckNumValidate(string szVal)
  344. {
  345. try
  346. {
  347. Convert.ToDecimal(szVal);
  348. }
  349. catch (Exception ex)
  350. {
  351. MessageBox.Show(ex.Message, "提示");
  352. }
  353. }
  354. /// <summary>
  355. /// 验证数据有效性(Double)
  356. /// </summary>
  357. /// <param name="AValue"></param>
  358. /// <returns></returns>
  359. public static bool IsDouble(string AValue)
  360. {
  361. try
  362. {
  363. Convert.ToDouble(AValue);
  364. return true;
  365. }
  366. catch
  367. {
  368. return false;
  369. }
  370. }
  371. /// <summary>
  372. /// 检查是否为当天的记录
  373. /// </summary>
  374. /// <param name="RemotingHelp"></param>
  375. /// <param name="szGW"></param>
  376. /// <param name="szBC"></param>
  377. /// <returns></returns>
  378. public static bool CheckIsTodayNote( string szTableName, string szWhere)
  379. {
  380. try
  381. {
  382. string szOut = "";//, szWhere = "";
  383. #region "在数据库里面查找炉号是否为当天生成的炉号记录"
  384. //szWhere = " where to_char(czsj, 'yyyy-MM-dd') = to_char(sysdate, 'yyyy-MM-dd') and lh='"+szLH+"'";
  385. //CallingMessage par = new CallingMessage();
  386. //par.ServerName = "lgResMgt";
  387. //par.AssemblyName = "Core.QG.Server.InfoCollect";
  388. //par.ClassName = "Core.QG.Server.InfoCollect.SendCommand";
  389. //par.MethodName = "QueryStove";
  390. //par.args = new object[] { szTableName, szWhere };
  391. object obj = null;// RemotingHelp.ExecuteMethod(par, out szOut);
  392. if (szOut == "" && obj != null)
  393. {
  394. DataTable dt = ((DataSet)obj).Tables[0];
  395. if (dt.Rows.Count > 0)
  396. {
  397. return true;
  398. }
  399. else
  400. {
  401. return false;
  402. }
  403. }
  404. #endregion
  405. }
  406. catch { }
  407. return false;
  408. }
  409. /// <summary>
  410. /// 检查是否有修改权限
  411. /// </summary>
  412. /// <param name="RemotingHelp"></param>
  413. /// <param name="szTableName"></param>
  414. /// <param name="szWhere"></param>
  415. /// <returns></returns>
  416. public static bool CheckIsPurview()
  417. {
  418. try
  419. {
  420. string szOut = "";//, szWhere = "";
  421. #region ""
  422. CoreFS.CA06.FrmBase ccf = new FrmBase();
  423. string szWhere = " and a.loginid='" + ccf.UserInfo.GetUserID() +"'";
  424. //CallingMessage par = new CallingMessage();
  425. //par.ServerName = "lgResMgt";
  426. //par.AssemblyName = "Core.QG.Server.InfoCollect";
  427. //par.ClassName = "Core.QG.Server.InfoCollect.SendCommand";
  428. //par.MethodName = "QueryUpdatePurview";
  429. //par.args = new object[] { szWhere };
  430. object obj = null;// RemotingHelp.ExecuteMethod(par, out szOut);
  431. if (szOut == "" && obj != null)
  432. {
  433. DataTable dt = ((DataSet)obj).Tables[0];
  434. if (dt.Rows.Count > 0 && dt.Rows[0]["UPDATEFLAG"].ToString() == "1")
  435. {
  436. return true;
  437. }
  438. else
  439. {
  440. return false;
  441. }
  442. }
  443. #endregion
  444. }
  445. catch { }
  446. return false;
  447. }
  448. /// <summary>
  449. /// 设置元素标准值
  450. /// </summary>
  451. /// <param name="row">表行数</param>
  452. /// <param name="dr">行记录</param>
  453. /// <param name="dt">被设置的表</param>
  454. public static void SetStandardElemData(int row, DataRow dr, ref DataTable dt)
  455. {
  456. try
  457. {
  458. // 取得元素名称
  459. string szEleName = dr["itemcode"].ToString();
  460. dt.Rows[row]["TYPESYMBOL"] = dr["STDSTYLE"].ToString() == "1" ? "内控" : (dr["STDSTYLE"].ToString() == "2" ? "放行" : "特殊");
  461. if (dr["stdmax"].ToString() != "" && dr["stdmin"].ToString() != "")
  462. dt.Rows[row][szEleName] = dr["stdmin"].ToString() + "~" + dr["stdmax"].ToString();
  463. else if (dr["stdmax"].ToString() != "" && dr["stdmin"].ToString() == "")
  464. dt.Rows[row][szEleName] = "≤ " + dr["stdmax"].ToString();
  465. else if (dr["stdmax"].ToString() == "" && dr["stdmin"].ToString() != "")
  466. dt.Rows[row][szEleName] = "> " + dr["stdmin"].ToString();
  467. }
  468. catch { }
  469. }
  470. /// <summary>
  471. /// 设置化学元素实时值(实绩用)
  472. /// </summary>
  473. /// <param name="row"></param>
  474. /// <param name="obj"></param>
  475. /// <param name="key"></param>
  476. /// <param name="dt"></param>
  477. public static void SetResCraftElemGridData(int row, JOB_CHEMELEMENT obj, string key, ref DataTable dt)
  478. {
  479. try
  480. {
  481. dt.Rows[0]["TYPESYMBOL"] = "内控";
  482. dt.Rows[1]["TYPESYMBOL"] = "放行";
  483. dt.Rows[2]["TYPESYMBOL"] = "特殊";
  484. if (row < dt.Rows.Count)
  485. {
  486. dt.Rows[row]["TYPESYMBOL"] = key;
  487. dt.Rows[row]["ASSAYDATE"] = obj.ASSAYDATE;
  488. dt.Rows[row]["C"] = obj.C;
  489. dt.Rows[row]["Si"] = obj.SI;
  490. dt.Rows[row]["Mn"] = obj.MN;
  491. dt.Rows[row]["P"] = obj.P;
  492. dt.Rows[row]["S"] = obj.S;
  493. dt.Rows[row]["Als"] = obj.ALS;
  494. dt.Rows[row]["V"] = obj.V;
  495. dt.Rows[row]["Nb"] = obj.NB;
  496. dt.Rows[row]["Ti"] = obj.TI;
  497. dt.Rows[row]["Ca"] = obj.CA;
  498. dt.Rows[row]["B"] = obj.B;
  499. dt.Rows[row]["Asn"] = obj.ASN;
  500. dt.Rows[row]["Sn"] = obj.SN;
  501. dt.Rows[row]["Cu"] = obj.CU;
  502. dt.Rows[row]["Sb"] = obj.SB;
  503. dt.Rows[row]["Alt"] = obj.ALT;
  504. dt.Rows[row]["Cr"] = obj.CR;
  505. dt.Rows[row]["Ni"] = obj.NI;
  506. dt.Rows[row]["Mo"] = obj.MO;
  507. dt.Rows[row]["O"] = obj.O;
  508. dt.Rows[row]["N"] = obj.N;
  509. dt.Rows[row]["H"] = obj.H;
  510. dt.Rows[row]["Ceq"] = obj.CEQ;
  511. dt.Rows[row]["Pcm"] = obj.PCM;
  512. dt.Rows[row]["Cev"] = obj.CEV;
  513. dt.Rows[row]["YXX"] = obj.YXX;
  514. }
  515. //C、Si、Mn、P、S、Als、V、Nb、Ti、As、Sn、Cu、Sb、Alt、O、N、H
  516. }
  517. catch (Exception ex)
  518. {
  519. string Msg = ex.Message;
  520. }
  521. }
  522. /// <summary>
  523. /// 设置化学元素实时值(总貌图用)
  524. /// </summary>
  525. /// <param name="row"></param>
  526. /// <param name="obj"></param>
  527. /// <param name="key"></param>
  528. /// <param name="dt"></param>
  529. public static void SetCraftElemGridData(int row, JOB_CHEMELEMENT obj, string key, ref DataTable dt)
  530. {
  531. try
  532. {
  533. dt.Rows[0]["TYPESYMBOL"] = "内控";
  534. dt.Rows[1]["TYPESYMBOL"] = "放行";
  535. dt.Rows[2]["TYPESYMBOL"] = "特殊";
  536. if (row < dt.Rows.Count)
  537. {
  538. dt.Rows[row]["TYPESYMBOL"] = key;
  539. dt.Rows[row]["C"] = obj.C;
  540. dt.Rows[row]["Si"] = obj.SI;
  541. dt.Rows[row]["Mn"] = obj.MN;
  542. dt.Rows[row]["P"] = obj.P;
  543. dt.Rows[row]["S"] = obj.S;
  544. dt.Rows[row]["Als"] = obj.ALS;
  545. dt.Rows[row]["V"] = obj.V;
  546. dt.Rows[row]["Nb"] = obj.NB;
  547. dt.Rows[row]["Ti"] = obj.TI;
  548. dt.Rows[row]["Ca"] = obj.CA;
  549. dt.Rows[row]["B"] = obj.B;
  550. dt.Rows[row]["Asn"] = obj.ASN;
  551. dt.Rows[row]["Sn"] = obj.SN;
  552. dt.Rows[row]["Cu"] = obj.CU;
  553. dt.Rows[row]["Sb"] = obj.SB;
  554. dt.Rows[row]["Alt"] = obj.ALT;
  555. dt.Rows[row]["Cr"] = obj.CR;
  556. dt.Rows[row]["Ni"] = obj.NI;
  557. dt.Rows[row]["Mo"] = obj.MO;
  558. dt.Rows[row]["O"] = obj.O;
  559. dt.Rows[row]["N"] = obj.N;
  560. dt.Rows[row]["H"] = obj.H;
  561. dt.Rows[row]["Ceq"] = obj.CEQ;
  562. dt.Rows[row]["Pcm"] = obj.PCM;
  563. dt.Rows[row]["Cev"] = obj.CEV;
  564. dt.Rows[row]["YXX"] = obj.YXX;
  565. dt.Rows[row]["MNS"] = obj.MNS;
  566. dt.Rows[row]["QD9"] = obj.QD9;
  567. dt.Rows[row]["BJFYL"] = obj.BJFYL;
  568. dt.Rows[row]["BJZHL"] = obj.BJZHL;
  569. dt.Rows[row]["BHZ"] = obj.BHZ;
  570. }
  571. //C、Si、Mn、P、S、Als、V、Nb、Ti、As、Sn、Cu、Sb、Alt、O、N、H
  572. }
  573. catch (Exception ex)
  574. {
  575. string Msg = ex.Message;
  576. }
  577. }
  578. /// <summary>
  579. /// 设置温度实时值
  580. /// </summary>
  581. /// <param name="dt"></param>
  582. public static void SetGridTemperature(ref DataTable dt, string szXMM, string szSDFW, string szSJZ, int row)
  583. {
  584. dt.Rows[row]["项目名"] = szXMM;
  585. dt.Rows[row]["设定范围"] = szSDFW;
  586. dt.Rows[row]["实际值"] = szSJZ;
  587. }
  588. /// <summary>
  589. /// 设置温度实时值
  590. /// </summary>
  591. /// <param name="dt"></param>
  592. public static void SetGridTemperature(ref DataTable dt, string szXmm, string szSDFW,string szSJZ,string szDate, int row)
  593. {
  594. dt.Rows[row]["项目名"] = szXmm;
  595. dt.Rows[row]["设定范围"] = szSDFW;
  596. dt.Rows[row]["实际值"] = szSJZ;
  597. dt.Rows[row]["采样时间"] =szDate;
  598. }
  599. /// <summary>
  600. /// 设置温度实时值
  601. /// </summary>
  602. /// <param name="dt"></param>
  603. public static void SetGridTemperature(ref DataTable dt, string szXmm, string szSDFW, string szSJZ, string szDLZ, string szDTZ, string szDYZ, string szDate, int row)
  604. {
  605. dt.Rows[row]["项目名"] = szXmm;
  606. dt.Rows[row]["设定范围"] = szSDFW;
  607. dt.Rows[row]["实际值"] = szSJZ;
  608. dt.Rows[row]["定铝值"] = szDLZ;
  609. dt.Rows[row]["定碳值"] = szDTZ;
  610. dt.Rows[row]["定氧值"] = szDYZ;
  611. dt.Rows[row]["采样时间"] = szDate;
  612. }
  613. /// <summary>
  614. /// 与标准值进行比对
  615. /// </summary>
  616. /// <param name="dtStd">工艺标准表</param>
  617. /// <param name="dtSource">被填充数据源的表</param>
  618. /// <param name="szCode">比对的编码</param>
  619. /// <param name="uGrd">被填充数据的GRID</param>
  620. /// <param name="uGrd">被填充的数据行</param>
  621. /// <param name="strName">岗位编码</param>
  622. public static void CompareStandard(DataTable dtStd, ref DataTable dtSource, string szCode, ref Infragistics.Win.UltraWinGrid.UltraGrid uGrd, int row,string strName)
  623. {
  624. DataRow[] dr = null;
  625. Decimal dZXZ = 0, dZDZ = 0, dVal = 0;
  626. if (dtStd != null && dtStd.Rows.Count > 0)
  627. {
  628. try
  629. {
  630. dr = dtStd.Select(" ITEM1 = '" + szCode +"' and Name_='"+ strName +"'");
  631. if (dr.Length > 0)
  632. {
  633. if (dr[0]["ITEM1MAX"].ToString() != "" && dr[0]["ITEM1MIN"].ToString() != "")
  634. dtSource.Rows[row]["设定范围"] = dr[0]["ITEM1MIN"].ToString() + "-" + dr[0]["ITEM1MAX"].ToString();
  635. else if (dr[0]["ITEM1MAX"].ToString() != "" && dr[0]["ITEM1MIN"].ToString() == "")
  636. dtSource.Rows[row]["设定范围"] = "≤ " + dr[0]["ITEM1MAX"].ToString();
  637. else if (dr[0]["ITEM1MAX"].ToString() == "" && dr[0]["ITEM1MIN"].ToString() != "")
  638. dtSource.Rows[row]["设定范围"] = "> " + dr[0]["ITEM1MIN"].ToString();
  639. if (!string.IsNullOrEmpty(dr[0]["ITEM1MIN"].ToString()))
  640. dZXZ = Convert.ToDecimal(dr[0]["ITEM1MIN"]);
  641. if(!string.IsNullOrEmpty(dr[0]["ITEM1MAX"].ToString()))
  642. dZDZ = Convert.ToDecimal(dr[0]["ITEM1MAX"]);
  643. //获取当前实际值
  644. if (!string.IsNullOrEmpty(uGrd.DisplayLayout.Rows[row].Cells["实际值"].Value.ToString()))
  645. dVal =Convert.ToDecimal(uGrd.DisplayLayout.Rows[row].Cells["实际值"].Value);
  646. if ((dVal > 0) && (dVal < dZXZ))
  647. {
  648. uGrd.DisplayLayout.Rows[row].Cells["实际值"].Appearance.ForeColor = Color.Red; // 下限报警红色显示
  649. dtSource.Rows[row]["提示"] = "x";
  650. uGrd.DisplayLayout.Rows[row].Cells["提示"].Appearance.ForeColor = Color.Red;
  651. }
  652. else if ((dVal > 0) && (dVal > dZDZ) && dZDZ > 0)
  653. {
  654. uGrd.DisplayLayout.Rows[row].Cells["实际值"].Appearance.ForeColor = Color.Red; // 上限报警蓝色显示
  655. dtSource.Rows[row]["提示"] = "x";
  656. uGrd.DisplayLayout.Rows[row].Cells["提示"].Appearance.ForeColor = Color.Red;
  657. }
  658. else
  659. uGrd.DisplayLayout.Rows[row].Cells["实际值"].Appearance.ForeColor = Color.Black;
  660. }
  661. }
  662. catch { }
  663. uGrd.Refresh();
  664. }
  665. }
  666. /// <summary>
  667. /// 与标准值进行比对
  668. /// </summary>
  669. /// <param name="dtStd">工艺标准表</param>
  670. /// <param name="dtSource">被填充数据源的表</param>
  671. /// <param name="szCode">比对的编码</param>
  672. /// <param name="uGrd">被填充数据的GRID</param>
  673. /// <param name="uGrd">被填充的数据行</param>
  674. /// <param name="strName">岗位编码</param>
  675. public static void CompareStandard2(DataTable dtStd, ref DataTable dtSource, string szCode, ref Infragistics.Win.UltraWinGrid.UltraGrid uGrd, int row, string strstation)
  676. {
  677. DataRow dr = null;
  678. Decimal dZXZ = 0, dZDZ = 0, dVal = 0;
  679. string factlines = "";//作业路线
  680. string stationline = "";//温度路线工艺
  681. string temperaturename = "";//需要的温度范围列名
  682. string temperature = "";//需要的温度范围
  683. if (dtStd != null && dtStd.Rows.Count > 0)
  684. {
  685. try
  686. {
  687. dr = dtStd.Rows[0];
  688. factlines = dr["factlines"].ToString();
  689. if (!"0".Contains(factlines.Substring(13,1)))
  690. {
  691. stationline = "EI";
  692. }
  693. else
  694. {
  695. if (!"0".Contains(factlines.Substring(11, 1)))
  696. {
  697. if (!"0".Contains(factlines.Substring(9, 1)))
  698. {
  699. stationline = "EF";
  700. }
  701. else
  702. {
  703. stationline = "F";
  704. }
  705. }
  706. else
  707. {
  708. if (!"0".Contains(factlines.Substring(9, 1)))
  709. {
  710. stationline = "E";
  711. }
  712. else
  713. {
  714. stationline = "D";
  715. }
  716. }
  717. }
  718. if ("BOF放钢温度".Contains(dtSource.Rows[row]["项目名"].ToString())
  719. ||(strstation + "出站温度").Contains(dtSource.Rows[row]["项目名"].ToString()))
  720. {
  721. temperaturename = "leavetempt" + szCode + "_" + stationline;
  722. }
  723. else
  724. {
  725. temperaturename = "arrivetempt" + szCode + "_" + stationline;
  726. }
  727. if (dtStd.Columns.Contains(temperaturename))
  728. temperature = dr[temperaturename].ToString();
  729. if (temperature != "")
  730. {
  731. dtSource.Rows[row]["设定范围"] = temperature;
  732. string[] temp = temperature.Split('-');
  733. for (int i = 0; i < temp.Length; i++)
  734. {
  735. if (i == 0)
  736. {
  737. dZXZ = Convert.ToDecimal(temp[0]);
  738. }
  739. else
  740. {
  741. dZDZ = Convert.ToDecimal(temp[i]);
  742. }
  743. }
  744. //获取当前实际值
  745. if (!string.IsNullOrEmpty(uGrd.DisplayLayout.Rows[row].Cells["实际值"].Value.ToString()))
  746. dVal = Convert.ToDecimal(uGrd.DisplayLayout.Rows[row].Cells["实际值"].Value);
  747. if ((dVal > 0) && (dVal < dZXZ))
  748. {
  749. uGrd.DisplayLayout.Rows[row].Cells["实际值"].Appearance.ForeColor = Color.Red; // 下限报警红色显示
  750. dtSource.Rows[row]["提示"] = "x";
  751. uGrd.DisplayLayout.Rows[row].Cells["提示"].Appearance.ForeColor = Color.Red;
  752. }
  753. if ((dVal > 0) && (dVal > dZDZ) && dZDZ > 0)
  754. {
  755. uGrd.DisplayLayout.Rows[row].Cells["实际值"].Appearance.ForeColor = Color.Red; // 上限报警蓝色显示
  756. dtSource.Rows[row]["提示"] = "x";
  757. uGrd.DisplayLayout.Rows[row].Cells["提示"].Appearance.ForeColor = Color.Red;
  758. }
  759. }
  760. else
  761. dtSource.Rows[row]["提示"] = "";
  762. }
  763. catch { }
  764. uGrd.Refresh();
  765. }
  766. }
  767. /// <summary>
  768. /// 设置Grid 的编辑性
  769. /// </summary>
  770. /// <param name="Grid"></param>
  771. public static void SetRowEdit(ref Infragistics.Win.UltraWinGrid.UltraGrid Grid)
  772. {
  773. foreach (Infragistics.Win.UltraWinGrid.UltraGridRow row in Grid.Rows)
  774. {
  775. row.Activation = Infragistics.Win.UltraWinGrid.Activation.NoEdit;
  776. }
  777. }
  778. /// <summary>
  779. /// 解析工艺路线
  780. /// </summary>
  781. /// <param name="strPlan_Lines">工艺编码路线</param>
  782. /// <returns></returns>
  783. public static string analysPlan_Lines(string strPlan_Lines)
  784. {
  785. string strLines = "";
  786. try
  787. {
  788. for (int i = 0; i < strPlan_Lines.Length; i += 1)
  789. {
  790. string StationCode = strPlan_Lines.Substring(i, 1);
  791. switch (StationCode)
  792. {
  793. case "A":
  794. strLines = strLines + "混铁炉";
  795. break;
  796. case "B":
  797. strLines = strLines + "->脱硫";
  798. break;
  799. case "C":
  800. strLines = strLines + "->转炉";
  801. break;
  802. case "D":
  803. strLines = strLines + "->吹氩站";
  804. break;
  805. case "E":
  806. strLines = strLines + "->精炼";
  807. break;
  808. case "F":
  809. strLines = strLines + "->RH炉";
  810. break;
  811. case "I":
  812. strLines = strLines + "->VD炉";
  813. break;
  814. case "G":
  815. strLines = strLines + "->连铸机";
  816. break;
  817. }
  818. }
  819. }
  820. catch
  821. {
  822. }
  823. if (strLines.Length < 2)
  824. return "";
  825. if (strLines.IndexOf("->", 0) == 0)
  826. {
  827. int len = strLines.Length;
  828. strLines = strLines.Substring(2, len - 2);
  829. }
  830. return strLines;
  831. }
  832. /// <summary>
  833. /// 解析作业路线
  834. /// </summary>
  835. /// <param name="craftPath">路线代码</param>
  836. /// <returns></returns>
  837. public static string analysPath(string craftPath)
  838. {
  839. string path = "";
  840. try
  841. {
  842. for (int i = 0; i < craftPath.Length; i += 2)
  843. {
  844. string StationCode = craftPath.Substring(i, 2);
  845. switch (StationCode)
  846. {
  847. case "A1":
  848. path = path + "1#混铁炉";
  849. break;
  850. case "A2":
  851. path = path + "2#混铁炉";
  852. break;
  853. case "B1":
  854. path = path + "->1#脱硫";
  855. break;
  856. case "B2":
  857. path = path + "->2#脱硫";
  858. break;
  859. case "C1":
  860. path = path + "->1#转炉";
  861. break;
  862. case "C2":
  863. path = path + "->2#转炉";
  864. break;
  865. case "C3":
  866. path = path + "->3#转炉";
  867. break;
  868. case "D1":
  869. path = path + "->1#吹氩站";
  870. break;
  871. case "D2":
  872. path = path + "->2#吹氩站";
  873. break;
  874. case "D3":
  875. path = path + "->3#吹氩站";
  876. break;
  877. case "E1":
  878. path = path + "->1#精炼";
  879. break;
  880. case "E2":
  881. path = path + "->2#精炼";
  882. break;
  883. case "E3":
  884. path = path + "->3#精炼";
  885. break;
  886. case "F1":
  887. path = path + "->1#RH炉";
  888. break;
  889. case "F2":
  890. path = path + "->2#RH炉";
  891. break;
  892. case "I1":
  893. path = path + "->1#VD炉";
  894. break;
  895. case "I2":
  896. path = path + "->2#VD炉";
  897. break;
  898. case "G1":
  899. path = path + "->1#连铸机";
  900. break;
  901. case "G2":
  902. path = path + "->2#连铸机";
  903. break;
  904. case "G3":
  905. path = path + "->3#连铸机";
  906. break;
  907. case "G4":
  908. path = path + "->4#连铸机";
  909. break;
  910. }
  911. }
  912. }
  913. catch
  914. {
  915. }
  916. if (path.Length < 2)
  917. return "";
  918. if (path.IndexOf("->", 0) == 0)
  919. {
  920. int len = path.Length;
  921. path = path.Substring(2, len - 2);
  922. }
  923. return path;
  924. }
  925. /// <summary>
  926. /// 根据岗位号获取工序
  927. /// </summary>
  928. /// <param name="_DEVICE_POSITION">岗位编码</param>
  929. /// <returns>工序代码</returns>
  930. public static string analysProcess(string _DEVICE_POSITION)
  931. {
  932. string strProcess = ""; //工序代码
  933. if (!string.IsNullOrEmpty(_DEVICE_POSITION))
  934. {
  935. switch (_DEVICE_POSITION.Substring(0, 3))
  936. {
  937. case "HMP":
  938. strProcess="B";
  939. break;
  940. case "BOF":
  941. strProcess = "C";
  942. break;
  943. case "CAS":
  944. strProcess = "D";
  945. break;
  946. case "LFS":
  947. strProcess = "E";
  948. break;
  949. case "RHS":
  950. strProcess = "F";
  951. break;
  952. case "CCM":
  953. strProcess = "G";
  954. break;
  955. case "VDS":
  956. strProcess = "I";
  957. break;
  958. default:
  959. break;
  960. }
  961. }
  962. return strProcess;
  963. }
  964. /// <summary>
  965. /// 根据岗位号获取工序中文名
  966. /// </summary>
  967. /// <param name="_DEVICE_POSITION">岗位编码</param>
  968. /// <returns>工序中文名</returns>
  969. public static string analysChineseName(string _DEVICE_POSITION)
  970. {
  971. string strChineseName = ""; //工序代码
  972. if (!string.IsNullOrEmpty(_DEVICE_POSITION))
  973. {
  974. switch (_DEVICE_POSITION.Substring(0, 3))
  975. {
  976. case "HMP":
  977. strChineseName = "脱硫站";
  978. break;
  979. case "BOF":
  980. strChineseName = "转炉";
  981. break;
  982. case "CAS":
  983. strChineseName = "吹氩站";
  984. break;
  985. case "LFS":
  986. strChineseName = "LF炉";
  987. break;
  988. case "RHS":
  989. strChineseName = "RH炉";
  990. break;
  991. case "VDS":
  992. strChineseName = "VD炉";
  993. break;
  994. case "CCM":
  995. strChineseName = "连铸机";
  996. break;
  997. default:
  998. break;
  999. }
  1000. }
  1001. return strChineseName;
  1002. }
  1003. /// <summary>
  1004. /// 根据代码解析工位名
  1005. /// </summary>
  1006. /// <param name="_DEVICE_POSITION">岗位编码,BOF01_FRONT</param>
  1007. /// <returns>工位中文名</returns>
  1008. public static string analysPosName(string _DEVICE_POSITION)
  1009. {
  1010. string strChineseName = ""; //工序代码
  1011. string strPos = ""; //岗位
  1012. string strWsID = ""; //工位
  1013. if (!string.IsNullOrEmpty(_DEVICE_POSITION))
  1014. {
  1015. strPos = _DEVICE_POSITION.Substring(0, 3);
  1016. strWsID = _DEVICE_POSITION.Substring(6);
  1017. switch (strWsID)
  1018. {
  1019. case "IDLE":
  1020. strChineseName = "缓冲位";
  1021. break;
  1022. case "FRONT":
  1023. if (strPos == "CAS" || strPos == "CCM")
  1024. strChineseName = "等待位";
  1025. else if (strPos == "LFS" || strPos == "RHS")
  1026. strChineseName = "1#小车位";
  1027. else if (strPos == "HMP") strChineseName = "小车位";
  1028. break;
  1029. case "DEVICE":
  1030. if (strPos == "BOF")
  1031. strChineseName = "吹炼位";
  1032. else if (strPos == "CCM")
  1033. strChineseName = "浇铸位";
  1034. else
  1035. strChineseName = "处理位";
  1036. break;
  1037. case "BACK":
  1038. if (strPos == "BOF")
  1039. strChineseName = "出钢位";
  1040. else
  1041. strChineseName = "2#小车位";
  1042. break;
  1043. case "OVER":
  1044. strChineseName = "生产结束";
  1045. break;
  1046. default:
  1047. break;
  1048. }
  1049. }
  1050. return strChineseName;
  1051. }
  1052. /// <summary>
  1053. /// 解析执行状态
  1054. /// </summary>
  1055. /// <param name="heatState">执行状态代码</param>
  1056. /// <returns></returns>
  1057. public static string analysHeat_State(string heatState)
  1058. {
  1059. string strHeat_State = "";
  1060. if (!string.IsNullOrEmpty(heatState.Trim()))
  1061. {
  1062. switch (heatState)
  1063. {
  1064. case "03":
  1065. strHeat_State = "计划状态";
  1066. break;
  1067. case "04":
  1068. strHeat_State = "正在转炉";
  1069. break;
  1070. case "05":
  1071. strHeat_State = "正在吹氩";
  1072. break;
  1073. case "06":
  1074. strHeat_State = "正在精炼炉";
  1075. break;
  1076. case "07":
  1077. strHeat_State = "正在RH炉";
  1078. break;
  1079. case "08":
  1080. strHeat_State = "正在连铸";
  1081. break;
  1082. case "09":
  1083. strHeat_State = "生产完成";
  1084. break;
  1085. default:
  1086. strHeat_State = "执行异常";
  1087. break;
  1088. }
  1089. }
  1090. return strHeat_State;
  1091. }
  1092. /// <summary>
  1093. /// 解析成分作业路线
  1094. /// </summary>
  1095. /// <param name="craftPath">成分编码</param>
  1096. /// <returns></returns>
  1097. public static string ChemelementPath(string craftPath)
  1098. {
  1099. string path = "";
  1100. try
  1101. {
  1102. string StationCode = craftPath.Substring(0, 1);
  1103. switch (StationCode)
  1104. {
  1105. case "B":
  1106. path = "脱硫";
  1107. break;
  1108. case "C":
  1109. path = "转炉";
  1110. break;
  1111. case "D":
  1112. if (craftPath.Substring(0, 2) == "DQ")
  1113. path = "CAS前";
  1114. else if (craftPath.Substring(0, 2) == "DH")
  1115. path = "CAS后";
  1116. break;
  1117. case "E":
  1118. path = "LF炉";
  1119. break;
  1120. case "F":
  1121. path = "RH炉";
  1122. break;
  1123. case "I":
  1124. path = "VD炉";
  1125. break;
  1126. case "G":
  1127. path = "连铸";
  1128. break;
  1129. }
  1130. }
  1131. catch
  1132. {
  1133. }
  1134. return path;
  1135. }
  1136. /// <summary>
  1137. /// 将长整型转换浮点型
  1138. /// </summary>
  1139. /// <param name="lgValue"></param>
  1140. /// <returns></returns>
  1141. public static float LongToFloat(long lgValue)
  1142. {
  1143. float flValue = 0;
  1144. try
  1145. {
  1146. if (lgValue >= 0)
  1147. {
  1148. byte[] btValue = CStaticMethod.LongToHex(lgValue);
  1149. flValue = CStaticMethod.HexToFloat(btValue);
  1150. }
  1151. }
  1152. catch { }
  1153. return flValue;
  1154. }
  1155. private static unsafe byte[] LongToHex(long lValue)
  1156. {
  1157. long[] lValuePtr = new long[1];
  1158. int sizeOfValue = Marshal.SizeOf(typeof(long));
  1159. byte[] byteValue = new byte[sizeOfValue];
  1160. lValuePtr[0] = lValue;
  1161. fixed (long* pTempValue = lValuePtr)
  1162. {
  1163. Marshal.Copy(new IntPtr(pTempValue), byteValue, 0, sizeOfValue);
  1164. }
  1165. return byteValue;
  1166. }
  1167. private static unsafe float HexToFloat(byte[] byteValue)
  1168. {
  1169. float[] fltValuePtr = new float[1];
  1170. int sizeOfValue = Marshal.SizeOf(typeof(float));
  1171. fixed (float* pTempValue = fltValuePtr)
  1172. {
  1173. Marshal.Copy(byteValue, 0, new IntPtr(pTempValue), sizeOfValue);
  1174. }
  1175. return fltValuePtr[0];
  1176. }
  1177. /// <summary>
  1178. /// 获取窗体工具栏信息
  1179. /// </summary>
  1180. /// <param name="strFromKey">窗体KEY</param>
  1181. /// <param name="strCustominfo">窗体自定议参数</param>
  1182. /// <param name="ob">URL</param>
  1183. /// <returns>LIST<structButton></returns>
  1184. public static List<structButton> GetFromToolInfo(string strFromKey, string strCustominfo,OpeBase ob)
  1185. {
  1186. string strErr = "";
  1187. List<structButton> sblist = new List<structButton>();
  1188. try
  1189. {
  1190. ArrayList arry = new ArrayList();
  1191. if (strCustominfo.Length > 0)
  1192. {
  1193. arry.Add("GetFromToolInfo_Custom.Select");//此ID为XML文件ID
  1194. arry.Add(strFromKey);
  1195. arry.Add(strCustominfo);
  1196. }
  1197. else
  1198. {
  1199. arry.Add("GetFromToolInfo.Select");//此ID为XML文件ID
  1200. arry.Add(strFromKey);
  1201. }
  1202. Core.Mes.Client.Common.CommonClientToServer ccTs = new Core.Mes.Client.Common.CommonClientToServer();
  1203. ccTs.ob = ob;
  1204. //获取指定岗位后台实时跟踪信息
  1205. DataSet ds = ccTs.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassCommonModule",
  1206. "GetFromToolInfo", arry, out strErr);
  1207. if (strErr == "" && ds != null)
  1208. {
  1209. if (ds.Tables[0].Rows.Count > 0)
  1210. {
  1211. foreach(DataRow dr in ds.Tables[0].Rows)
  1212. {
  1213. structButton sbut = new structButton();
  1214. sbut.Caption = dr["CAPTION"].ToString();
  1215. sbut.Key = dr["KEY"].ToString();
  1216. sbut.ImageKey = dr["IMAGE"].ToString();
  1217. sbut.Enable = true;
  1218. sblist.Add(sbut);
  1219. }
  1220. }
  1221. }
  1222. return sblist;
  1223. }
  1224. catch
  1225. {
  1226. return sblist;
  1227. }
  1228. }
  1229. /// <summary>
  1230. /// 获取作业温度标准
  1231. /// </summary>
  1232. /// <returns></returns>
  1233. public static DataTable GetJobStandardTemp(CoreFS.CA06.OpeBase ope,string strSteelCode)
  1234. {
  1235. string strErr = "";
  1236. ArrayList arry = new ArrayList();
  1237. arry.Add("GetJobStandardTemp.Select");//此ID为XML文件ID
  1238. arry.Add(strSteelCode);
  1239. Core.Mes.Client.Common.CommonClientToServer ccTs = new Core.Mes.Client.Common.CommonClientToServer();
  1240. ccTs.ob = ope;
  1241. //获取作业温度标准
  1242. DataSet ds = ccTs.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassCommonModule",
  1243. "GetJobStandardTemp", arry, out strErr);
  1244. if (strErr == "" && ds != null)
  1245. {
  1246. return ds.Tables[0];
  1247. }
  1248. return null;
  1249. }
  1250. /// <summary>
  1251. /// 获取作业温度标准2
  1252. /// </summary>
  1253. /// <returns></returns>
  1254. public static DataTable GetJobStandardTemp2(CoreFS.CA06.OpeBase ope, string strHeatno, string strSteelCode)
  1255. {
  1256. string strErr = "";
  1257. ArrayList arry = new ArrayList();
  1258. arry.Add("GetJobStandardTemp2.Select");//此ID为XML文件ID
  1259. arry.Add(strHeatno);
  1260. arry.Add(strSteelCode);
  1261. Core.Mes.Client.Common.CommonClientToServer ccTs = new Core.Mes.Client.Common.CommonClientToServer();
  1262. ccTs.ob = ope;
  1263. //获取作业温度标准
  1264. DataSet ds = ccTs.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassCommonModule",
  1265. "GetJobStandardTemp", arry, out strErr);
  1266. if (strErr == "" && ds != null)
  1267. {
  1268. return ds.Tables[0];
  1269. }
  1270. return null;
  1271. }
  1272. /// <summary>
  1273. /// 获取物料消耗标准
  1274. /// </summary>
  1275. /// <returns></returns>
  1276. public static DataTable GetJobStandardMateriel(CoreFS.CA06.OpeBase ope, string strSteelCode)
  1277. {
  1278. string strErr = "";
  1279. ArrayList arry = new ArrayList();
  1280. arry.Add("GetJobStandardMateriel.Select");//此ID为XML文件ID
  1281. arry.Add(strSteelCode);
  1282. Core.Mes.Client.Common.CommonClientToServer ccTs = new Core.Mes.Client.Common.CommonClientToServer();
  1283. ccTs.ob = ope;
  1284. //获取作业温度标准
  1285. DataSet ds = ccTs.ExecuteQueryFunctions("Core.LgMes.Server.LgJobMgt.ClassCommonModule",
  1286. "GetJobStandardMateriel", arry, out strErr);
  1287. if (strErr == "" && ds != null)
  1288. {
  1289. return ds.Tables[0];
  1290. }
  1291. return null;
  1292. }
  1293. }
  1294. /// <summary>
  1295. /// 枚举对象长度
  1296. /// </summary>
  1297. public enum OBJLEN : int
  1298. {
  1299. /// <summary>
  1300. /// 加热处理号长度
  1301. /// </summary>
  1302. nHeatProcessNo=15,
  1303. /// <summary>
  1304. /// 炉号长度
  1305. /// </summary>
  1306. nHeatNo = 10,
  1307. /// <summary>
  1308. /// 岗位编码长度
  1309. /// </summary>
  1310. nDevCode = 2,
  1311. /// <summary>
  1312. /// 处理次数长度
  1313. /// </summary>
  1314. nDealTime = 2,
  1315. /// <summary>
  1316. /// 岗位编码字母长度
  1317. /// </summary>
  1318. nDevStr=1,
  1319. /// <summary>
  1320. /// 脱硫处理号
  1321. /// </summary>
  1322. nHudwProcessNo=14,
  1323. /// <summary>
  1324. /// 脱硫号
  1325. /// </summary>
  1326. nHudwId=9
  1327. }
  1328. }