FrmGradeAnalysis.cs 46 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991
  1. using Core.Mes.Client.Comm.Control;
  2. using Core.Mes.Client.Comm.Server;
  3. using Core.Mes.Client.Comm.Tool;
  4. using Core.StlMes.Client.PlnSaleOrd.BaseMethod;
  5. using Core.StlMes.Client.PlnSaleOrd.工序排产;
  6. using Core.StlMes.Client.PlnSaleOrd.炼钢计划.entity;
  7. using CoreFS.CA06;
  8. using Infragistics.Win;
  9. using Infragistics.Win.UltraWinEditors;
  10. using Infragistics.Win.UltraWinGrid;
  11. using System;
  12. using System.Collections;
  13. using System.Collections.Generic;
  14. using System.ComponentModel;
  15. using System.Data;
  16. using System.Drawing;
  17. using System.Linq;
  18. using System.Text;
  19. using System.Windows.Forms;
  20. using Core.StlMes.Client.PlnSaleOrd.炼钢计划;
  21. namespace Core.StlMes.Client.PlnSaleOrd.管坯优化
  22. {
  23. public partial class FrmGradeAnalysis : FrmBase
  24. {
  25. UltraComboEditor ucePlinCode = new UltraComboEditor();//铸造产线
  26. //private DataTable dtlz=new DataTable();
  27. private string dimarCic="";
  28. public FrmGradeAnalysis()
  29. {
  30. InitializeComponent();
  31. this.IsLoadUserView = true;
  32. }
  33. private void FrmGradeAnalysis_Load(object sender, EventArgs e)
  34. {
  35. BaseHelper.ForbidSort(ultraGridLenSig);
  36. BaseHelper.ForbidSort(ultraGrid1);
  37. PlanComm.setGridDigitalCol(ultraGridZgMs.DisplayLayout.Bands[0], 5, 2, "OUTDIAMETER",
  38. "WALLTHICK", "LEN_ROLL_MAX", "LEN_ROLL_MIN", "AIMOUTDIAMETER", "AIMLENGTH",
  39. "DIAMETER_GP", "LENGTH_GP", "ROLL_LENGTH", "DIAMETER_MANDREL", "AIMWALLTHICK",
  40. "LEN_GP_SINGLE", "LEN_CUTHEAD", "LEN_CUTEND", "TUBE_END_RATIO");
  41. PlanComm.setGridDigitalCol(ultraGridZgMs.DisplayLayout.Bands[0], 5, 3, "IN_WEIGHT_S",
  42. "WEIGTH_S", "BATCHED_WT", "FINISHWEIGHT", "WEIGTH_S_MIN", "GPREQ_WEIGHT", "FurnWt", "LjWeight", "Reall_WT", "ALLOWANCE");
  43. PlanComm.setGridDigitalCol(ultraGridZgMs.DisplayLayout.Bands[0], 5, 0, "FINISHNUM",
  44. "BATCHED_NUM", "NUM_S", "IN_NUM_S", "OUTNUM_CUT", "MULTIPLE_NUM", "PLAN_USETIME", "GPREQ_NUM", "PLANS_NUM", "FurnNum", "LjNum", "Reall_NUM");
  45. ultraGridZgMs.DisplayLayout.Bands[0].Columns["CRAFT_FILE_NO"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.EditButton;
  46. ultraGridZgMs.DisplayLayout.Bands[0].Columns["GRADENAME"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.EditButton;
  47. ultraGridAnaly.DisplayLayout.Bands[0].Columns["COMBINED"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.EditButton;
  48. ultraGridAnaly.DisplayLayout.Bands[0].Columns["GRADENAME"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.EditButton;
  49. PlanComm.setGridDigitalCol(ultraGridLenSig.DisplayLayout.Bands[0], 5, 3, "STDMIN", "STDMAX");
  50. DataTable dt1 = ServerHelper.GetData("com.steering.pss.plnsaleord.processOrder.base.BaseHelper.initPline", new object[] { "B", "", "" }, this.ob);
  51. UltraComboEditor uce = new UltraComboEditor();
  52. this.Controls.Add(uce);
  53. uce.Visible = false;
  54. uce.DropDownListWidth = -1;
  55. uce.DropDownStyle = DropDownStyle.DropDownList;
  56. uce.DataSource = dt1;
  57. uce.DisplayMember = "PLINE_NAME";
  58. uce.ValueMember = "PLINE_CODE";
  59. ultraGridZgMs.DisplayLayout.Bands[0].Columns["PLINE_CODE_ZZ"].EditorComponent = uce;
  60. ultraGridZgMs.DisplayLayout.Bands[0].Columns["PLINE_CODE_ZZ"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.DropDownList;
  61. }
  62. public override void ToolBar_Click(object sender, string ToolbarKey)
  63. {
  64. base.ToolBar_Click(sender, ToolbarKey);
  65. switch (ToolbarKey)
  66. {
  67. case "Query"://分析
  68. doQuery("0");
  69. break;
  70. case "Refresh"://刷新
  71. doQuery("1");
  72. break;
  73. case "Calculate"://计算
  74. doCalculate();
  75. break;
  76. case "UpadatePlin"://修改铸造产线
  77. doUpadatePlin();
  78. break;
  79. case "setFurnace"://预算
  80. doSetFurnace();
  81. break;
  82. case "Close":
  83. this.Close();
  84. break;
  85. default:
  86. break;
  87. }
  88. }
  89. /// <summary>
  90. /// 分析断面,钢种,钢种索引码
  91. /// </summary>
  92. private void doQuery(string falg)
  93. {
  94. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.getdoQueryGrade",
  95. new object[] { }, this.ob);
  96. GridHelper.CopyDataToDatatable(dt, dataTable2, true);
  97. //if (falg.Equals("0"))
  98. //{
  99. //dtlz = ServerHelper.GetData("com.steering.pss.plnsaleord.processO rder.base.ProducHelper.queryLZDataZg", new object[] { }, ob);
  100. //}
  101. if (dt.Rows.Count <= 0)
  102. {
  103. DataTable dt1 = new DataTable();
  104. GridHelper.CopyDataToDatatable(dt1, dataTable1, true);
  105. GridHelper.CopyDataToDatatable(dt1, dataTable3, true);
  106. }
  107. foreach(UltraGridRow row in ultraGridAnaly.Rows){
  108. if (dimarCic.Equals(row.Cells["DIAMETER_GP"].Text.ToString() + row.Cells["CIC_GP"].Text.ToString() + row.Cells["GRADENAME"].Text.ToString() + row.Cells["PLINE_NAME_ZZ"].Text.ToString()))
  109. {
  110. row.Activate();
  111. }
  112. }
  113. //doCalculate();
  114. //doSetFurnace();
  115. }
  116. /// <summary>
  117. /// 计算待冶炼吨,合计
  118. /// </summary>
  119. private void doCalculate()
  120. {
  121. UltraGridRow row = ultraGridAnaly.ActiveRow;
  122. if (row == null) return;
  123. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.doPlnZgQueryHj",
  124. new object[] { }, this.ob);
  125. //DataTable dtlz1 = ServerHelper.GetData("com.steering.pss.plnsaleord.processOrder.base.ProducHelper.queryLZDataZg", new object[] { }, ob);
  126. PlanComm.WaitFromOpen(this.Cursor);
  127. foreach (UltraGridRow ugrA in ultraGridAnaly.Rows)
  128. {
  129. string diameterGp = ugrA.Cells["DIAMETER_GP"].Value.ToString();
  130. string gradecode = ugrA.Cells["GRADECODE"].Value.ToString();
  131. string gradeName = ugrA.Cells["GRADENAME"].Value.ToString();
  132. string cicGp = ugrA.Cells["CIC_GP"].Value.ToString();
  133. string plineCodeZz = ugrA.Cells["PLINE_CODE_ZZ"].Value.ToString();
  134. #region 待冶炼吨
  135. double wt = 0;
  136. int num = 0;
  137. if (dt.Rows.Count > 0)
  138. {
  139. DataRow[] drsz = dt.Select("DIAMETER_GP ='" + diameterGp + "' AND GRADECODE='" + gradecode + "' AND CIC_GP='" + cicGp + "' AND PLINE_CODE_ZZ='" + plineCodeZz + "'");
  140. if (drsz != null && drsz.Length > 0)
  141. {
  142. for (int i = 0; i < drsz.Length; i++)
  143. {
  144. //double wtz = 0;
  145. double wtLj = 0;
  146. //double batWt = 0;
  147. //int numz = 0;
  148. int numLj = 0;
  149. //int numbat = 0;
  150. //if (dtlz.Rows.Count > 0)
  151. //{
  152. // DataRow[] drs = dtlz.Select("订单号 ='" + drsz[i]["PRO_PLAN_ID"].ToString() + "' AND 序号='" + drsz[i]["GX_PLAN_NO"].ToString() + "'");
  153. // if (drs != null && drs.Length > 0)
  154. // {
  155. // if (!drs[0]["装炉支"].ToString().Equals(""))
  156. // {
  157. // wtz = double.Parse(drs[0]["装炉吨"].ToString());
  158. // numz = int.Parse(drs[0]["装炉支"].ToString());
  159. // }
  160. // if (!drs[0]["LJ支"].ToString().Equals(""))
  161. // {
  162. // wtLj = double.Parse(drs[0]["LJ吨"].ToString());
  163. // numLj = int.Parse(drs[0]["LJ支"].ToString());
  164. // }
  165. // if (!drs[0]["出库支"].ToString().Equals(""))
  166. // {
  167. // batWt = double.Parse(drs[0]["出库吨"].ToString());
  168. // numbat = int.Parse(drs[0]["出库支"].ToString());
  169. // }
  170. // }
  171. //}
  172. if (drsz[i]["Lj_Num"].ToString().Equals("0"))
  173. {
  174. numLj = int.Parse(drsz[i]["MATCH_NUM_IN"].ToString());
  175. wtLj = double.Parse(drsz[i]["MATCH_WT_IN"].ToString());
  176. }
  177. else
  178. {
  179. numLj = int.Parse(drsz[i]["Lj_Num"].ToString());
  180. wtLj = double.Parse(drsz[i]["Lj_Weight"].ToString());
  181. }
  182. double gpWt = 0;
  183. double daiy = 0;
  184. int gpNUm = 0;
  185. int daiNum = 0;
  186. if (!drsz[i]["GPREQ_NUM"].Equals("0"))
  187. {
  188. gpWt = double.Parse(drsz[i]["GPREQ_WEIGHT"].ToString());
  189. gpNUm = int.Parse(drsz[i]["GPREQ_NUM"].ToString());
  190. }
  191. if (gpWt - wtLj > 0)
  192. {
  193. daiy = gpWt - wtLj;
  194. daiNum = gpNUm - numLj;
  195. }
  196. wt += daiy;
  197. num += daiNum;
  198. }
  199. ugrA.Cells["GPREQ_WEIGHT"].Value = wt.ToString("f3");
  200. ugrA.Cells["GPREQ_NUM"].Value = num;
  201. }
  202. else
  203. {
  204. ugrA.Cells["GPREQ_WEIGHT"].Value = "0";
  205. ugrA.Cells["GPREQ_NUM"].Value = "0";
  206. }
  207. }
  208. #endregion
  209. #region 合计
  210. double wthj = 0;
  211. if (dt.Rows.Count > 0)
  212. {
  213. DataRow[] drsz = dt.Select("DIAMETER_GP ='" + diameterGp + "'AND PLINE_CODE_ZZ='" + plineCodeZz + "' AND GRADECODE_ALL like '%" + gradeName + "%'AND CIC_GROUP_GP like ('%" + cicGp + "%')");
  214. if (drsz != null && drsz.Length > 0)
  215. {
  216. for (int j = 0; j < drsz.Length; j++)
  217. {
  218. //double wtz1 = 0;
  219. double wtLj1 = 0;
  220. //double batWt1 = 0;
  221. //if (dtlz.Rows.Count > 0)
  222. //{
  223. // DataRow[] drs = dtlz.Select("订单号 ='" + drsz[j]["PRO_PLAN_ID"].ToString() + "' AND 序号='" + drsz[j]["GX_PLAN_NO"].ToString() + "'");
  224. // if (drs != null && drs.Length > 0)
  225. // {
  226. // if (!drs[0]["装炉支"].ToString().Equals(""))
  227. // {
  228. // wtz1 = double.Parse(drs[0]["装炉吨"].ToString());
  229. // }
  230. // if (!drs[0]["LJ支"].ToString().Equals(""))
  231. // {
  232. // wtLj1 = double.Parse(drs[0]["LJ吨"].ToString());
  233. // }
  234. // if (!drs[0]["出库支"].ToString().Equals(""))
  235. // {
  236. // batWt1 = double.Parse(drs[0]["出库吨"].ToString());
  237. // }
  238. // }
  239. //}
  240. if (drsz[j]["Lj_Num"].ToString().Equals("0"))
  241. {
  242. //numLj = int.Parse(drsz[j]["MATCH_NUM_IN"].ToString());
  243. wtLj1 = double.Parse(drsz[j]["MATCH_WT_IN"].ToString());
  244. }
  245. else
  246. {
  247. //numLj = int.Parse(drsz[j]["Lj_Num"].ToString());
  248. wtLj1 = double.Parse(drsz[j]["Lj_Weight"].ToString());
  249. }
  250. double gpWt1 = 0;
  251. double daiy1 = 0;
  252. if (!drsz[j]["GPREQ_NUM"].Equals("0"))
  253. {
  254. gpWt1 = double.Parse(drsz[j]["GPREQ_WEIGHT"].ToString());
  255. }
  256. if (gpWt1 - wtLj1 > 0)
  257. {
  258. daiy1 = gpWt1 - wtLj1;
  259. }
  260. wthj += daiy1;
  261. }
  262. ugrA.Cells["COMBINED"].Value = wthj.ToString("f3");
  263. }
  264. else
  265. {
  266. ugrA.Cells["COMBINED"].Value = "0";
  267. }
  268. }
  269. #endregion
  270. }
  271. PlanComm.WaitFromColse(this.Cursor);
  272. ultraGridAnaly.UpdateData();
  273. dataTable2.DefaultView.RowFilter = "GPREQ_NUM > '0' ";
  274. DataTable dt1 = dataTable2.DefaultView.ToTable();
  275. GridHelper.CopyDataToDatatable(dt1, dataTable2, true);
  276. }
  277. private void doSetFurnace()
  278. {
  279. UltraGridRow row = ultraGridAnaly.ActiveRow;
  280. if (row == null) return;
  281. ArrayList list = new ArrayList();
  282. PlanComm.WaitFromOpen(this.Cursor);
  283. foreach (UltraGridRow ugrA in ultraGridAnaly.Rows)
  284. {
  285. string plineCodeZz = ugrA.Cells["PLINE_CODE_ZZ"].Text.ToString();
  286. string plineNameZz = ugrA.Cells["PLINE_NAME_ZZ"].Text.ToString();
  287. string gradeCode = ugrA.Cells["GRADECODE"].Text.ToString();
  288. string gradeName = ugrA.Cells["GRADENAME"].Text.ToString();
  289. string diameterGp = ugrA.Cells["DIAMETER_GP"].Value.ToString();
  290. string wt = ugrA.Cells["GPREQ_WEIGHT"].Value.ToString();
  291. if (wt.Equals(""))
  292. {
  293. wt = "0";
  294. }
  295. if (!plineCodeZz.Equals(""))
  296. {
  297. #region 查询铸机基础数据获取中包铸余
  298. PlnBasePlineLzEntity entity = GetBasePlineLz(plineCodeZz);
  299. string strZbLeftWt = "0";
  300. string strFlowNumMax = "0";
  301. string strFurnaceNumMax = "0";
  302. if (entity == null)
  303. {
  304. strZbLeftWt = "0";//中包铸余
  305. strFlowNumMax = "0";//最大流数
  306. strFurnaceNumMax = "0";
  307. }
  308. else
  309. {
  310. strZbLeftWt = entity.ZbLeftWt.ToString();
  311. strFlowNumMax = entity.FlowNumMax.ToString();
  312. strFurnaceNumMax = entity.FurnaceNumMax.ToString();
  313. }
  314. #endregion
  315. #region 查询首炉切头
  316. double cutLenBegin = 0;
  317. double endLenBegin = 0;
  318. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.doPlnZgQueryFurnace", new object[] { diameterGp }, this.ob);
  319. if (dt.Rows.Count > 0)
  320. {
  321. cutLenBegin = double.Parse(dt.Rows[0]["CUT_LEN_BEGIN"].ToString());
  322. endLenBegin = double.Parse(dt.Rows[0]["CUT_LEN_END_CH"].ToString());
  323. }
  324. else
  325. {
  326. MessageUtil.ShowTips("断面(" + diameterGp + ")没有维护连铸规格切头尾数据!");
  327. break;
  328. }
  329. #endregion
  330. #region 查询小时能力表最大浇次
  331. //DataTable dtSpec = null;
  332. //string spceCode = "";
  333. //string spceName = "";
  334. //string wlidZz = "";//铸造物料编码
  335. //string wldescZz = "";//铸造物料描述
  336. //dtSpec = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.CorePlnZgMStoGp.selectSpecDimater",
  337. // new object[] { diameterGp }, this.ob);
  338. //if (dtSpec == null || dtSpec.Rows.Count == 0)
  339. //{
  340. // return;
  341. //}
  342. //spceCode = dtSpec.Rows[0]["SPEC_CODE"].ToString();
  343. //spceName = dtSpec.Rows[0]["SPEC_NAME"].ToString();
  344. //wlidZz = "PA" + spceCode + gradeCode;
  345. //wldescZz = "PA" + spceName + "," + gradeName;
  346. ////查询小时能力表最大浇次
  347. //string maxJc = "";
  348. //DataTable dt1 = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.doPlnZgQueryMaxJc", new object[] { plineCodeZz, gradeCode, wlidZz }, this.ob);
  349. //if (dt1.Rows.Count > 0)
  350. //{
  351. // maxJc = dt1.Rows[0]["STOVE_CNT"].ToString();
  352. //}
  353. //else
  354. //{
  355. // MessageUtil.ShowTips("未找到小时能力表铸造投入产出!");
  356. // return;
  357. //}
  358. #endregion
  359. // 计算米单重
  360. double mSingleWeight = (7.8 * 3.1415926 / 4 * double.Parse(diameterGp) * double.Parse(diameterGp)) / 1000 / 1000;
  361. ugrA.Cells["CASTWEIGHT"].Value = (double.Parse(strFlowNumMax) * (cutLenBegin + endLenBegin) * mSingleWeight + double.Parse(strZbLeftWt)).ToString("f3");
  362. #region 出钢量上下限
  363. string plineCodeA = "";
  364. string plineNameA = "";
  365. if (plineNameZz.Equals("一炼铸机"))
  366. {
  367. plineCodeA = "C001";
  368. plineNameA = "一炼钢电炉";
  369. }
  370. else if (plineNameZz.Equals("二炼铸机"))
  371. {
  372. plineCodeA = "C003";
  373. plineNameA = "二炼钢电炉";
  374. }
  375. else
  376. {
  377. plineCodeA = "C006";
  378. plineNameA = "三炼钢电炉";
  379. }
  380. double minSteel = 0;
  381. double maxSteel = 0;
  382. //查询出钢量上下限
  383. DataTable dt2 = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.getBasePlineLg", new object[] { plineCodeA }, this.ob);
  384. if (dt2.Rows.Count > 0)
  385. {
  386. minSteel = double.Parse(dt2.Rows[0]["OUT_WT_MIN"].ToString());
  387. maxSteel = double.Parse(dt2.Rows[0]["OUT_WT_MAX"].ToString());
  388. }
  389. else
  390. {
  391. MessageUtil.ShowTips("铸造(" + plineNameZz + ")对应电炉(" + plineNameA + ")没有排产基础数据!");
  392. break;
  393. }
  394. ugrA.Cells["FURNACE_MIN"].Value = (double.Parse(wt) / maxSteel).ToString("f1");
  395. ugrA.Cells["FURNACE_MAX"].Value = (double.Parse(wt) / minSteel).ToString("f1");
  396. #endregion
  397. //ArrayList list1 = new ArrayList();
  398. //list1.Add(plineCodeZz);
  399. //list1.Add(plineNameZz);
  400. //list1.Add(strZbLeftWt);
  401. //list1.Add(strFlowNumMax);
  402. //list1.Add(strFurnaceNumMax);
  403. //list1.Add("1");
  404. //list1.Add(gradeCode);
  405. //list1.Add(gradeName);
  406. //list1.Add(diameterGp);
  407. //list1.Add(wt);
  408. //CoreClientParam ccp = new CoreClientParam();
  409. //ccp.ServerName = "com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis";
  410. //ccp.MethodName = "querySetFurn";
  411. //ccp.ServerParams = new object[] { list1 };
  412. //ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  413. //if (ccp.ReturnCode != -1)
  414. //{
  415. // string[] s = ccp.ReturnInfo.Split(',');
  416. // if (s.Length >= 4) {
  417. // ugrA.Cells["CASTWEIGHT"].Value = s[0];
  418. // ugrA.Cells["FURNACENUMBER"].Value = s[1];
  419. // ugrA.Cells["FIRST_FURNACE_Wt"].Value = s[2];
  420. // ugrA.Cells["TAIL_FURNACE_Wt"].Value = s[3];
  421. // }
  422. // else
  423. // {
  424. // if (ccp.ReturnInfo.Equals(""))
  425. // MessageUtil.ShowTips(ccp.ReturnInfo);
  426. // }
  427. //}
  428. }
  429. }
  430. PlanComm.WaitFromColse(this.Cursor);
  431. }
  432. /// <summary>
  433. /// 查询铸造基础表(最大流数,中包铸余)
  434. /// </summary>
  435. /// <param name="plinecode">铸机</param>
  436. /// <returns></returns>
  437. private PlnBasePlineLzEntity GetBasePlineLz(string plinecode)
  438. {
  439. List<PlnBasePlineLzEntity> listSource = EntityHelper.GetData<PlnBasePlineLzEntity>
  440. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelMakingPlanChange.getBasePlineLz", new object[] { plinecode }, ob);
  441. if (listSource == null || listSource.Count == 0)
  442. {
  443. return null;
  444. }
  445. else
  446. {
  447. return listSource[0];
  448. }
  449. }
  450. /// <summary>
  451. /// 修改铸造产线
  452. /// </summary>
  453. private void doUpadatePlin()
  454. {
  455. ultraGridZgMs.UpdateData();
  456. IQueryable<UltraGridRow> urows = ultraGridZgMs.Rows.AsQueryable().Where("CHC = 'True'");
  457. if (urows.Count() == 0)
  458. {
  459. MessageUtil.ShowTips("请勾选轧管订单详情。");
  460. return;
  461. }
  462. ArrayList list = new ArrayList();
  463. UltraGridRow row = ultraGridAnaly.ActiveRow;
  464. string diameter=row.Cells["DIAMETER_GP"].Text.ToString();
  465. string cicGp=row.Cells["CIC_GP"].Text.ToString() ;
  466. string gradeNmae=row.Cells["GRADENAME"].Text.ToString();
  467. string plineName = "";
  468. foreach (UltraGridRow urow in urows)
  469. {
  470. ArrayList list1 = new ArrayList();
  471. list1.Add(urow.Cells["PLINE_CODE_ZZ"].Value.ToString());
  472. list1.Add(urow.Cells["PLINE_CODE_ZZ"].Text.ToString());
  473. list1.Add(urow.Cells["PRO_PLAN_ID"].Value.ToString());
  474. list1.Add(urow.Cells["GX_PLAN_NO"].Value.ToString());
  475. list.Add(list1);
  476. if (plineName.Equals(""))
  477. {
  478. plineName = urow.Cells["PLINE_CODE_ZZ"].Text.ToString();
  479. }
  480. }
  481. CoreClientParam ccp = new CoreClientParam();
  482. ccp.ServerName = "com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis";
  483. ccp.MethodName = "doUpadatePlin";
  484. ccp.ServerParams = new object[] { list };
  485. ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  486. if (ccp.ReturnCode == -1) return;
  487. MessageUtil.ShowTips(ccp.ReturnInfo);
  488. if (ccp.ReturnInfo.Equals("修改成功!"))
  489. {
  490. dimarCic = diameter + cicGp + gradeNmae + plineName;
  491. doQuery("1");
  492. doCalculate();
  493. }
  494. }
  495. private void ultraGridAnaly_AfterRowActivate(object sender, EventArgs e)
  496. {
  497. UltraGridRow row = ultraGridAnaly.ActiveRow;
  498. if (row == null) return;
  499. string diameterGp=row.Cells["DIAMETER_GP"].Value.ToString();
  500. string gradecode=row.Cells["GRADECODE"].Value.ToString();
  501. string cicGp=row.Cells["CIC_GP"].Value.ToString();
  502. string plineCodeZz=row.Cells["PLINE_CODE_ZZ"].Value.ToString();
  503. doPlnZgQuery(diameterGp, gradecode, cicGp, "", "0", plineCodeZz);
  504. }
  505. //查询同钢种所有钢种索引码成分
  506. private void doGraderOrd(string[] cic, string[] desginKey, string[] indexSeq)
  507. {
  508. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.doQueryGradecOll",
  509. new object[] { cic, desginKey, indexSeq }, this.ob);
  510. DataTable dat= GetCrossTable(dt);
  511. ultraGrid1.DataSource = dat;
  512. ultraGrid1.DataBind();
  513. GridHelper.RefreshAndAutoSize(ultraGrid1);
  514. //this.ultraGrid1.DisplayLayout.Override.MergedCellStyle = MergedCellStyle.Always;
  515. this.ultraGrid1.DisplayLayout.Bands[0].Columns["钢种索引码"].MergedCellStyle = MergedCellStyle.Always;
  516. }
  517. /// 将DataTable的第二列的值转化为列(即将原来的行表,转化成交叉表,没有对应值则默认"0")
  518. /// <param name="dt"></param>
  519. /// <returns></returns>
  520. public static DataTable GetCrossTable(DataTable dt)
  521. {
  522. if (dt == null || dt.Columns.Count != 4 || dt.Rows.Count == 0)
  523. {
  524. return dt;
  525. }
  526. else
  527. {
  528. DataTable result = new DataTable();
  529. result.Columns.Add("钢种索引码");
  530. result.Columns.Add("上下限");
  531. DataTable dtColumns = dt.DefaultView.ToTable("dtColumns", true, dt.Columns[1].ColumnName);
  532. for (int i = 0; i < dtColumns.Rows.Count; i++)
  533. {
  534. string colName;
  535. if (dtColumns.Rows[1][0] is DateTime)
  536. {
  537. colName = Convert.ToDateTime(dtColumns.Rows[i][0]).ToString();
  538. }
  539. else
  540. {
  541. colName = dtColumns.Rows[i][0].ToString();
  542. }
  543. result.Columns.Add(colName);
  544. result.Columns[i + 1].DefaultValue = "";
  545. }
  546. DataTable distinct_object = dt.DefaultView.ToTable(true, "CIC");
  547. if (distinct_object.Rows.Count <= 0)
  548. {
  549. return result;
  550. }
  551. for (int i = 0; i < distinct_object.Rows.Count; i++)
  552. {
  553. string cic=distinct_object.Rows[i]["CIC"].ToString();
  554. DataRow[] drs = dt.Select("CIC='" + cic + "'");
  555. DataRow drNew = result.NewRow();
  556. drNew[0] = drs[0][0];
  557. drNew[1] = "下限";
  558. string rowName = drNew[0].ToString();
  559. foreach (DataRow dr in drs)
  560. {
  561. string colName = dr[1].ToString();
  562. string dValue1 = dr[2].ToString();
  563. if (dr[0].ToString().Equals(rowName, StringComparison.CurrentCultureIgnoreCase))
  564. {
  565. drNew[colName] = dValue1.ToString();
  566. }
  567. else
  568. {
  569. result.Rows.Add(drNew);
  570. drNew = result.NewRow();
  571. drNew[0] = dr[0];
  572. rowName = drNew[0].ToString();
  573. drNew[colName] = dValue1.ToString();
  574. }
  575. }
  576. result.Rows.Add(drNew);
  577. drNew = result.NewRow();
  578. drNew[0] = drs[0][0];
  579. drNew[1] = "上限";
  580. foreach (DataRow dr in drs)
  581. { string colName = dr[1].ToString();
  582. string dValue2 = dr[3].ToString();
  583. if (dr[0].ToString().Equals(rowName, StringComparison.CurrentCultureIgnoreCase))
  584. {
  585. drNew[colName] = dValue2.ToString();
  586. }
  587. else
  588. {
  589. result.Rows.Add(drNew);
  590. drNew = result.NewRow();
  591. drNew[1] = dr[0];
  592. rowName = drNew[1].ToString();
  593. drNew[colName] = dValue2.ToString();
  594. }
  595. }
  596. result.Rows.Add(drNew);
  597. }
  598. return result;
  599. }
  600. }
  601. /// <summary>
  602. /// 查询钢种成分元素
  603. /// </summary>
  604. private void dolenSingleGp(string cicGp, string proPlanId, string gxPlanNo)
  605. {
  606. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.doPlnZgQuerySingle",
  607. new object[] { cicGp, proPlanId, gxPlanNo }, this.ob);
  608. GridHelper.CopyDataToDatatable(dt, dataTable3, true);
  609. }
  610. /// <summary>
  611. /// 查询轧管订单详情
  612. /// </summary>
  613. private void doPlnZgQuery(string diameterGp, string gradecode, string cicGp, string lenGpSingle, string flag, string plineCodeZz)
  614. {
  615. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.doPlnZgQuery",
  616. new object[] { diameterGp, gradecode, cicGp, lenGpSingle, flag, plineCodeZz }, this.ob);
  617. GridHelper.CopyDataToDatatable(dt, dataTable4, true);
  618. foreach (UltraGridRow ugr in ultraGridZgMs.Rows)
  619. {
  620. //int numz = 0;
  621. //double wtz = 0;
  622. int numLj = 0;
  623. double wtLj = 0;
  624. //int batNum = 0;
  625. //double batWt = 0;
  626. //if (dtlz.Rows.Count > 0)
  627. //{
  628. // //DataTable dtlz = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.queryLZDataZg", new object[] { ugr.Cells["PRO_PLAN_ID"].Value.ToString(), ugr.Cells["GX_PLAN_NO"].Value.ToString() }, ob);
  629. // DataRow[] drs = dtlz.Select("订单号 ='" + ugr.Cells["PRO_PLAN_ID"].Value.ToString() + "' AND 序号='" + ugr.Cells["GX_PLAN_NO"].Value.ToString() + "'");
  630. // if (drs != null && drs.Length > 0)
  631. // {
  632. // //if(dtlz.Rows.Count>0){
  633. // if (!drs[0]["装炉支"].ToString().Equals(""))
  634. // {
  635. // ugr.Cells["FurnNum"].Value = drs[0]["装炉支"].ToString();
  636. // ugr.Cells["FurnWt"].Value = drs[0]["装炉吨"].ToString();
  637. // numz = int.Parse(ugr.Cells["FurnNum"].Value.ToString());
  638. // wtz = double.Parse(ugr.Cells["FurnWt"].Value.ToString());
  639. // }
  640. // else
  641. // {
  642. // numz = 0;
  643. // wtz = 0;
  644. // }
  645. // if (!drs[0]["LJ支"].ToString().Equals(""))
  646. // {
  647. // ugr.Cells["LjNum"].Value = drs[0]["LJ支"].ToString();
  648. // ugr.Cells["LjWeight"].Value = drs[0]["LJ吨"].ToString();
  649. // numLj = int.Parse(ugr.Cells["LjNum"].Value.ToString());
  650. // wtLj = double.Parse(ugr.Cells["LjWeight"].Value.ToString());
  651. // }
  652. // else
  653. // {
  654. // numLj = 0;
  655. // wtLj = 0;
  656. // }
  657. // if (!drs[0]["出库支"].ToString().Equals(""))
  658. // {
  659. // ugr.Cells["OUT_NUM"].Value = drs[0]["出库支"].ToString();
  660. // ugr.Cells["OUT_WT"].Value = drs[0]["出库吨"].ToString();
  661. // batNum = int.Parse(ugr.Cells["OUT_NUM"].Value.ToString());
  662. // batWt = double.Parse(ugr.Cells["OUT_WT"].Value.ToString());
  663. // }
  664. // else
  665. // {
  666. // batNum = 0;
  667. // batWt = 0;
  668. // }
  669. // }
  670. //}
  671. //if (ugr.Cells["LjNum"].Value.Equals("0"))
  672. //{
  673. // numLj = int.Parse(ugr.Cells["MATCH_NUM_IN"].Value.ToString());
  674. // wtLj = double.Parse(ugr.Cells["MATCH_WT_IN"].Value.ToString());
  675. //}
  676. //else
  677. //{
  678. numLj = int.Parse(ugr.Cells["LjNum"].Value.ToString());
  679. wtLj = double.Parse(ugr.Cells["LjWeight"].Value.ToString());
  680. //}
  681. int gpNum = 0;
  682. double gpWt = 0;
  683. if (ugr.Cells["GPREQ_NUM"].Text.Equals(""))
  684. {
  685. gpNum = 0;
  686. gpWt = 0;
  687. }
  688. else
  689. {
  690. gpNum = int.Parse(ugr.Cells["GPREQ_NUM"].Value.ToString());
  691. gpWt = double.Parse(ugr.Cells["GPREQ_WEIGHT"].Value.ToString());
  692. }
  693. if (gpNum - numLj < 0)
  694. {
  695. ugr.Cells["Reall_NUM"].Value = "0";
  696. }
  697. else
  698. {
  699. ugr.Cells["Reall_NUM"].Value = (gpNum - numLj).ToString();
  700. }
  701. if (gpWt - wtLj < 0)
  702. {
  703. ugr.Cells["Reall_WT"].Value = "0";
  704. }
  705. else
  706. {
  707. ugr.Cells["Reall_WT"].Value = (gpWt - wtLj).ToString();
  708. }
  709. if (!ugr.Cells["Reall_WT"].Text.ToString().Equals(""))
  710. {
  711. }
  712. string[] groupCic = null;
  713. if (!ugr.Cells["CIC_GROUP_GP"].Text.Equals(""))
  714. {
  715. groupCic = ugr.Cells["CIC_GROUP_GP"].Text.ToString().Split(',');
  716. }
  717. string cic = "";
  718. if (groupCic != null)
  719. {
  720. DataTable dtcic = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.getQueryGradeZl",
  721. new object[] { groupCic, "0" }, this.ob);
  722. if (dtcic.Rows.Count > 0)
  723. {
  724. for (int z = 0; z < dtcic.Rows.Count; z++)
  725. {
  726. cic += dtcic.Rows[z]["CIC"].ToString() + ",";
  727. }
  728. cic = cic.Substring(0, cic.Length - 1);
  729. }
  730. }
  731. ugr.Cells["CIC_GROUP_GP"].Value = cic;
  732. }
  733. if (dt.Rows.Count <= 0)
  734. {
  735. DataTable dt1 = new DataTable();
  736. GridHelper.CopyDataToDatatable(dt1, dataTable3, true);
  737. }
  738. }
  739. private void ultraGridZgMs_ClickCellButton(object sender, CellEventArgs e)
  740. {
  741. UltraGridRow row = ultraGridZgMs.ActiveRow;
  742. if (row == null) return;
  743. if (e.Cell.Column.Key.Equals("CRAFT_FILE_NO"))
  744. {
  745. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.CorePlnZgMStoGp.selectCraftPath",
  746. new object[] { row.GetValue("PRO_PLAN_ID"), row.GetValue("GX_PLAN_NO"), row.GetValue("CRAFT_FILE_NO"), row.GetValue("CRAFT_SEQ") }, this.ob);
  747. if (dt.Rows.Count > 0)
  748. {
  749. string filePath = dt.Rows[0]["CRAFT_PATH"].ToString();
  750. dlgOrderAskDown askDown = new dlgOrderAskDown(this.ob, filePath);
  751. askDown.Show();
  752. }
  753. }
  754. else if (e.Cell.Column.Key.Equals("GRADENAME"))
  755. {
  756. string ordLnDlyPk = row.GetValue("ORD_LN_DLY_PK");
  757. string proPlanId = row.GetValue("PRO_PLAN_ID");
  758. string gxPlanNo = row.GetValue("GX_PLAN_NO");
  759. string gradeCode = row.GetValue("GRADECODE");
  760. string gradeCodeAll = row.GetValue("GRADECODE_ALL");
  761. string diameter = row.GetValue("DIAMETER_GP");
  762. if (gradeCode.Equals(""))
  763. {
  764. return;
  765. }
  766. string[] groupCic = null;
  767. if (!row.GetValue("GRADECODE").Equals(""))
  768. {
  769. groupCic = row.Cells["CIC_GROUP_GP"].Text.ToString().Split(',');
  770. }
  771. string cicGp = row.GetValue("CIC_GP");
  772. string outsBilletfl = "";
  773. if (row.Cells["OUTS_BILLET_FL"].Text.ToString().Equals("自炼"))
  774. {
  775. outsBilletfl = "0";
  776. }
  777. else
  778. {
  779. outsBilletfl = "1";
  780. }
  781. //int numz = 0;
  782. //double wtz = 0;
  783. //if (!row.Cells["FurnNum"].Text.ToString().Equals(""))
  784. //{
  785. // numz = int.Parse(row.Cells["FurnNum"].Value.ToString());
  786. // wtz = double.Parse(row.Cells["FurnWt"].Value.ToString());
  787. //}
  788. int numLj = 0;
  789. double wtLj = 0;
  790. //if (!row.Cells["LjNum"].Text.ToString().Equals(""))
  791. //{
  792. numLj = int.Parse(row.Cells["LjNum"].Value.ToString());
  793. wtLj = double.Parse(row.Cells["LjWeight"].Value.ToString());
  794. //}
  795. //int batNum = 0;
  796. //double batWt = 0;
  797. //if (!row.Cells["OUT_NUM"].Text.ToString().Equals(""))
  798. //{
  799. // batNum = int.Parse(row.Cells["OUT_NUM"].Value.ToString());
  800. // batWt = double.Parse(row.Cells["OUT_WT"].Value.ToString());
  801. //}
  802. int num =numLj;
  803. FrmChangeGrade frmBomConfirm = new FrmChangeGrade(outsBilletfl, proPlanId, gxPlanNo, this.ob, groupCic, cicGp, gradeCodeAll, diameter,num);
  804. frmBomConfirm.ShowDialog();
  805. if (frmBomConfirm.DialogResult == System.Windows.Forms.DialogResult.OK)
  806. {
  807. bool flag = frmBomConfirm.Flag;
  808. if (flag)
  809. {
  810. dimarCic = diameter + frmBomConfirm.GradeNmaeCic + row.GetValue("PLINE_NAME_ZZ");
  811. doQuery("1");
  812. }//如果有修改数据,则刷新页面
  813. }
  814. }
  815. }
  816. private void ultraGridLenSig_ClickCellButton(object sender, CellEventArgs e)
  817. {
  818. UltraGridRow row = ultraGridAnaly.ActiveRow;
  819. UltraGridRow row1 = ultraGridLenSig.ActiveRow;
  820. if (row1 == null) return;
  821. if (e.Cell.Column.Key.Equals("Query"))
  822. {
  823. string diameterGp = row.Cells["DIAMETER_GP"].Value.ToString();
  824. string gradecode = row.Cells["GRADECODE"].Value.ToString();
  825. string cicGp = row.Cells["CIC_GP"].Value.ToString();
  826. string lenGpSingle = row1.Cells["LEN_GP_SINGLE"].Value.ToString();
  827. string plineCodeZz = row.Cells["PLINE_CODE_ZZ"].Value.ToString();
  828. doPlnZgQuery(diameterGp, gradecode, cicGp, lenGpSingle, "0", plineCodeZz);
  829. }
  830. }
  831. private void ultraGridAnaly_ClickCellButton(object sender, CellEventArgs e)
  832. {
  833. UltraGridRow ugrA = ultraGridAnaly.ActiveRow;
  834. if (ugrA == null) return;
  835. string diameterGp = ugrA.Cells["DIAMETER_GP"].Value.ToString();
  836. string gradecode = ugrA.Cells["GRADECODE"].Value.ToString();
  837. string gradeName = ugrA.Cells["GRADENAME"].Value.ToString();
  838. string cicGp = ugrA.Cells["CIC_GP"].Value.ToString();
  839. string plineCodeZz = ugrA.Cells["PLINE_CODE_ZZ"].Value.ToString();
  840. if (e.Cell.Column.Key.Equals("COMBINED"))
  841. {
  842. doPlnZgQuery(diameterGp, gradeName, cicGp, "", "1", plineCodeZz);
  843. }
  844. if (e.Cell.Column.Key.Equals("GRADENAME"))
  845. {
  846. string cicGpGroup = "";
  847. string desginKey = "";
  848. string indexSeq = "";
  849. //PlanComm.WaitFromOpen(this.Cursor);
  850. foreach (UltraGridRow ugrb in ultraGridAnaly.Rows)
  851. {
  852. if (gradecode.Equals(ugrb.Cells["gradecode"].Text.ToString()))
  853. {
  854. cicGpGroup += ugrb.Cells["CIC_GP"].Text.ToString().Trim() + ",";
  855. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.GpOptimize.FrmGradeAnalysis.doPlnZgQueryDesKEY", new object[] { ugrb.Cells["DIAMETER_GP"].Text.ToString().Trim(), ugrb.Cells["GRADECODE"].Value.ToString(), ugrb.Cells["CIC_GP"].Text.ToString().Trim(), ugrb.Cells["PLINE_CODE_ZZ"].Text.ToString().Trim() }, this.ob);
  856. if (dt.Rows.Count > 0)
  857. {
  858. desginKey += dt.Rows[0]["DESGIN_KEY"].ToString() + ",";
  859. indexSeq += dt.Rows[0]["INDEX_SEQ"].ToString() + ",";
  860. }
  861. }
  862. }
  863. cicGpGroup = cicGpGroup.Substring(0, cicGpGroup.Length - 1);
  864. string[] cicGpGrou = null;
  865. if (!cicGpGroup.Equals(""))
  866. {
  867. cicGpGrou = cicGpGroup.Split(',');
  868. }
  869. desginKey = desginKey.Substring(0, desginKey.Length - 1);
  870. string[] desginKey1 = null;
  871. if (!desginKey.Equals(""))
  872. {
  873. desginKey1 = desginKey.Split(',');
  874. }
  875. indexSeq = indexSeq.Substring(0, indexSeq.Length - 1);
  876. string[] indexSeq1 = null;
  877. if (!indexSeq.Equals(""))
  878. {
  879. indexSeq1 = indexSeq.Split(',');
  880. }
  881. doGraderOrd(cicGpGrou, desginKey1, indexSeq1);
  882. //PlanComm.WaitFromColse(this.Cursor);
  883. }
  884. }
  885. private void ultraGridZgMs_AfterRowActivate(object sender, EventArgs e)
  886. {
  887. UltraGridRow ugrA = ultraGridZgMs.ActiveRow;
  888. if (ugrA == null) return;
  889. string proPlanId = ugrA.Cells["PRO_PLAN_ID"].Value.ToString();
  890. string gxPlanNo = ugrA.Cells["GX_PLAN_NO"].Value.ToString();
  891. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.processOrder.base.BaseHelper.queryZzPlin",
  892. new object[] { proPlanId, gxPlanNo }, this.ob);
  893. if (dt == null || dt.Rows.Count == 0)
  894. {
  895. ugrA.Cells["PLINE_CODE_ZZ"].Value = "";
  896. return;
  897. }
  898. ugrA.Cells["PLINE_CODE_ZZ"].ValueList = PlanComm.GeneralValuelist(ref dt, "PLINE_CODE", "PLINE_NAME");
  899. UltraGridRow row = ultraGridAnaly.ActiveRow;
  900. string cicGp = row.Cells["CIC_GP"].Value.ToString();
  901. dolenSingleGp(cicGp, proPlanId, gxPlanNo);
  902. }
  903. private void ultraGridZgMs_CellChange(object sender, CellEventArgs e)
  904. {
  905. if (e.Cell.Column.Key.Equals("PLINE_CODE_ZZ"))
  906. {
  907. ultraGridZgMs.UpdateData();
  908. e.Cell.Row.Cells["PLINE_CODE_ZZ"].Value = e.Cell.Value.ToString();
  909. //e.Cell.Row.Cells["PLINE_CODE_ZZ"].Value = e.Cell.Text;
  910. e.Cell.Row.Cells["PLINE_NAME_ZZ"].Value = e.Cell.Text;
  911. foreach (UltraGridRow row in ultraGridZgMs.Rows)
  912. {
  913. if (Convert.ToBoolean(row.Cells["CHC"].Text) == true)
  914. {
  915. row.Cells["PLINE_CODE_ZZ"].Value = e.Cell.Value.ToString();
  916. //row.Cells["PLINE_CODE_ZZ"].Text = e.Cell.Text;
  917. row.Cells["PLINE_NAME_ZZ"].Value = e.Cell.Text;
  918. }
  919. }
  920. }
  921. }
  922. private void craftImg1_EditorButtonClick(object sender, EditorButtonEventArgs e)
  923. {
  924. UltraGridRow row = ultraGridAnaly.ActiveRow;
  925. UltraGridRow ugrA = ultraGridZgMs.ActiveRow;
  926. if (ugrA == null || row==null) return;
  927. ArrayList list = new ArrayList();
  928. list.Add(row.Cells["CIC_GP"].Text.ToString());
  929. list.Add(ugrA.Cells["PRO_PLAN_ID"].Value.ToString());
  930. list.Add("");
  931. list.Add("");
  932. list.Add(row.Cells["Gradecode"].Text.ToString());
  933. list.Add(row.Cells["Gradename"].Text.ToString());
  934. list.Add("");
  935. list.Add("");
  936. list.Add(ugrA.Cells["GX_PLAN_NO"].Value.ToString());
  937. FrmSteelProcessCard steCard = new FrmSteelProcessCard("", ob, list, "2");
  938. steCard.ShowDialog();
  939. bool flag = steCard.Falg;
  940. if (flag) { doQuery("1"); }
  941. }
  942. }
  943. }