PublicSteer.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using CoreFS.CA06;
  6. using System.Data;
  7. using Infragistics.Win.UltraWinGrid;
  8. using System.Windows.Forms;
  9. using Infragistics.Win.UltraWinEditors;
  10. using Core.Mes.Client.Comm;
  11. using System.Collections;
  12. using Core.Mes.Client.Comm.Server;
  13. namespace Core.StlMes.Client.Lims.Data.Steer
  14. {
  15. /// <summary>
  16. /// 自定义公共方法类
  17. /// </summary>
  18. class PublicSteer
  19. {
  20. public const string chemMax = "ANA_C ANA_SI ANA_MN ANA_P ANA_S ANA_NI ANA_CR ANA_MO ANA_CU ANA_AL ANA_V ANA_NB ANA_TI ANA_B ANA_PB ANA_SN ANA_AS ANA_SB ANA_BI ANA_O ANA_N ANA_H ANA_CA ANA_W ANA_ZR ANA_ZN ANA_CO ANA_ALS";
  21. public const string chemMin = "C Si Mn P S Ni Cr Mo Cu Al V Nb Ti B Pb Sn As Sb Bi O N H Ca W Zr Zn Co Als";
  22. /// <summary>
  23. /// 激活当前操作的列
  24. ///
  25. /// </summary>
  26. /// <param name="ultraGrid"></param>
  27. /// <param name="strPK"></param>主键
  28. public static void ActiveOperateRow(UltraGrid ultraGrid, string strPK, string strPKText)
  29. {
  30. for (int i = 0; i < ultraGrid.Rows.Count; i++)
  31. {
  32. if (ultraGrid.Rows[i].Cells[strPK].Text == strPKText)
  33. {
  34. ultraGrid.Rows[i].Activated = true;
  35. }
  36. }
  37. }
  38. /// <summary>
  39. /// 激活当前操作的列
  40. ///
  41. /// </summary>
  42. /// <param name="ultraGrid"></param>
  43. /// <param name="strPK"></param>多主键
  44. public static void ActiveOperateRow(UltraGrid ultraGrid, object[] strPK, object[] strPKText)
  45. {
  46. bool isEquals;
  47. for (int i = 0; i < ultraGrid.Rows.Count; i++)
  48. {
  49. isEquals = true;
  50. for (int j = 0; j < strPK.Length; j++)
  51. {
  52. if (ultraGrid.Rows[i].Cells[strPK[j].ToString()].Text != strPKText[j].ToString())
  53. {
  54. isEquals = false;
  55. break;
  56. }
  57. }
  58. if (isEquals == true)
  59. {
  60. ultraGrid.Rows[i].Activated = true;
  61. return;
  62. }
  63. }
  64. }
  65. //点击Grid编辑区显示基本信息
  66. public static void ShowBaseInfo(UltraGridRow ur, Panel panel)
  67. {
  68. if (ur != null)
  69. {
  70. foreach (UltraGridCell uc in ur.Cells)
  71. {
  72. if (panel.Controls.ContainsKey("txt" + uc.Column.Key) == true)//判定是否存在text
  73. {
  74. ((UltraTextEditor)panel.Controls["txt" + uc.Column.Key]).Text = uc.Text.Trim();
  75. }
  76. else if (panel.Controls.ContainsKey("ultra" + uc.Column.Key) == true)//判定是否存在text
  77. {
  78. ((UltraComboEditor)panel.Controls["ultra" + uc.Column.Key]).Text = uc.Text.Trim();
  79. }
  80. }
  81. }
  82. }
  83. //点击Grid编辑区显示基本信息
  84. public static void ShowBaseInfo(UltraGridRow ur, Panel panel, string strRule)
  85. {
  86. if (ur != null)
  87. {
  88. foreach (UltraGridCell uc in ur.Cells)
  89. {
  90. if (panel.Controls.ContainsKey("txt" + uc.Column.Key + strRule) == true)//判定是否存在text
  91. {
  92. ((UltraTextEditor)panel.Controls["txt" + uc.Column.Key + strRule]).Text = uc.Text.Trim();
  93. }
  94. else if (panel.Controls.ContainsKey("ultra" + uc.Column.Key + strRule) == true)//判定是否存在text
  95. {
  96. ((UltraComboEditor)panel.Controls["ultra" + uc.Column.Key + strRule]).Text = uc.Text.Trim();
  97. }
  98. }
  99. }
  100. }
  101. //点击Grid编辑区显示基本信息
  102. public static void ShowDataTaleInfo(DataTable dt, Panel panel)
  103. {
  104. foreach (DataColumn dc in dt.Columns)
  105. {
  106. if (panel.Controls.ContainsKey("txt" + dc.ColumnName) == true)//判定是否存在text
  107. {
  108. ((UltraTextEditor)panel.Controls["txt" + dc.ColumnName]).Text = dt.Rows[0][dc.ColumnName].ToString();
  109. }
  110. else if (panel.Controls.ContainsKey("ultra" + dc.ColumnName) == true)//判定是否存在text
  111. {
  112. ((UltraComboEditor)panel.Controls["ultra" + dc.ColumnName]).Text = dt.Rows[0][dc.ColumnName].ToString();
  113. }
  114. }
  115. }
  116. /// <summary>
  117. /// 隐藏空列
  118. /// </summary>
  119. /// <param name="strHidden"></param>本来就隐藏的列名集合
  120. /// <param name="ug"></param>需要操作的UltraGrid
  121. /// <param name="dt"></param>需要操作的dt
  122. private static void HideNullColumn(string strHidden, UltraGrid ultraGrid, DataTable dataTable)
  123. {
  124. if (strHidden != "")
  125. {
  126. foreach (DataColumn dc in dataTable.Columns)
  127. {
  128. if (strHidden.IndexOf(dc.ColumnName) >= 0)
  129. {
  130. continue;
  131. }
  132. foreach (DataRow dr in dataTable.Rows)
  133. {
  134. if (dr[dc].ToString() != "")
  135. {
  136. ultraGrid.DisplayLayout.Bands[0].Columns[dc.ColumnName].Hidden = false;
  137. break;
  138. }
  139. else
  140. {
  141. ultraGrid.DisplayLayout.Bands[0].Columns[dc.ColumnName].Hidden = true;
  142. }
  143. }
  144. }
  145. }
  146. else
  147. {
  148. foreach (DataColumn dc in dataTable.Columns)
  149. {
  150. foreach (DataRow dr in dataTable.Rows)
  151. {
  152. if (dr[dc].ToString() != "")
  153. {
  154. ultraGrid.DisplayLayout.Bands[0].Columns[dc.ColumnName].Hidden = false;
  155. break;
  156. }
  157. else
  158. {
  159. ultraGrid.DisplayLayout.Bands[0].Columns[dc.ColumnName].Hidden = true;
  160. }
  161. }
  162. }
  163. }
  164. }
  165. /// <summary>
  166. /// 设置列宽
  167. /// </summary>
  168. /// <param name="dt"></param>需要设置的UltraGrid
  169. /// <param name="haveNum"></param>不需要清除的列
  170. /// /// <param name="width"></param>宽度
  171. public static void ColumnsWidth(UltraGrid ultraGrid, int haveNum, int width)
  172. {
  173. int col = ultraGrid.DisplayLayout.Bands[0].Columns.Count;
  174. for (int i = haveNum; i < col; i++)
  175. {
  176. ultraGrid.DisplayLayout.Bands[0].Columns[i].Width = width;//设置列宽
  177. }
  178. }
  179. /// <summary>
  180. /// 设置列宽
  181. /// </summary>
  182. /// <param name="dt"></param>需要设置的UltraGrid
  183. /// <param name="haveNum"></param>不需要清除的列
  184. /// /// <param name="width"></param>宽度
  185. public static void ColumnsWidth(UltraGrid ultraGrid, int haveNum, int width, string[] noSet)
  186. {
  187. ArrayList al = new ArrayList();
  188. for (int i = 0; i < noSet.Length; i++)
  189. {
  190. al.Add(noSet[i]);
  191. }
  192. int col = ultraGrid.DisplayLayout.Bands[0].Columns.Count;
  193. for (int i = haveNum; i < col; i++)
  194. {
  195. if (!al.Contains(ultraGrid.DisplayLayout.Bands[0].Columns[i].ToString()))
  196. {
  197. ultraGrid.DisplayLayout.Bands[0].Columns[i].Width = width;//设置列宽
  198. }
  199. }
  200. }
  201. /// <summary>
  202. /// 刷新Grid数据并根据数据调整Grid列宽
  203. /// </summary>
  204. /// <param name="ultraGrid">需要处理的Grid</param>
  205. /// <param name="cols">不需要调整列宽的列</param>
  206. public static void RefreshAndAutoSizeColumns(Infragistics.Win.UltraWinGrid.UltraGrid ultraGrid, Infragistics.Win.UltraWinGrid.UltraGridColumn[] cols)
  207. {
  208. try
  209. {
  210. ultraGrid.DataBind();
  211. foreach (Infragistics.Win.UltraWinGrid.UltraGridBand band in ultraGrid.DisplayLayout.Bands)
  212. {
  213. foreach (Infragistics.Win.UltraWinGrid.UltraGridColumn column in band.Columns)
  214. {
  215. if (cols != null && cols.Contains(column))
  216. {
  217. column.PerformAutoResize(Infragistics.Win.UltraWinGrid.PerformAutoSizeType.AllRowsInBand);
  218. }
  219. }
  220. }
  221. ultraGrid.Refresh();
  222. }
  223. catch { }
  224. }
  225. /// <summary>
  226. /// UltraGrid可读
  227. /// </summary>
  228. /// <param name="ugr">UltraGrid</param>
  229. /// <param name="keys">可编辑列</param>
  230. public static void setOtherColumnReadOnly(UltraGrid ugr, string[] keys)
  231. {
  232. if (keys == null || keys.Length == 0)
  233. {
  234. foreach (UltraGridColumn ugc in ugr.DisplayLayout.Bands[0].Columns)
  235. {
  236. ugc.CellActivation = Activation.ActivateOnly;
  237. }
  238. }
  239. else
  240. {
  241. keys.ToArray();
  242. foreach (UltraGridColumn ugc in ugr.DisplayLayout.Bands[0].Columns)
  243. {
  244. if (!keys.Contains(ugc.Key))
  245. {
  246. ugc.CellActivation = Activation.ActivateOnly;
  247. }
  248. }
  249. }
  250. if (ugr.DisplayLayout.Bands[0].Columns.Exists("CHK"))
  251. {
  252. ugr.DisplayLayout.Bands[0].Columns["CHK"].DefaultCellValue = "False";
  253. ugr.DisplayLayout.Bands[0].Columns["CHK"].Header.CheckBoxVisibility = Infragistics.Win.UltraWinGrid.HeaderCheckBoxVisibility.Always;
  254. ugr.DisplayLayout.Bands[0].Columns["CHK"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.CheckBox;
  255. }
  256. }
  257. /// <summary>
  258. /// UltraGrid列是否隐藏
  259. /// </summary>isShow 为true则显示其他隐藏,false则隐藏其他显示
  260. /// <param name="ugr">UltraGrid</param>
  261. /// <param name="keys">隐藏列</param>
  262. public static void setColumnShowOrHidden(UltraGrid ugr, string[] keys, bool isShow)
  263. {
  264. if (keys == null || keys.Length == 0)
  265. {
  266. foreach (UltraGridColumn ugc in ugr.DisplayLayout.Bands[0].Columns)
  267. {
  268. ugc.Hidden = false;
  269. }
  270. }
  271. else
  272. {
  273. keys.ToArray();
  274. foreach (UltraGridColumn ugc in ugr.DisplayLayout.Bands[0].Columns)
  275. {
  276. if (keys.Contains(ugc.Key))
  277. {
  278. if (isShow)
  279. {
  280. ugc.Hidden = false;
  281. }
  282. else
  283. {
  284. ugc.Hidden = true;
  285. }
  286. }
  287. else
  288. {
  289. if (isShow)
  290. {
  291. ugc.Hidden = true;
  292. }
  293. }
  294. }
  295. }
  296. }
  297. //初始化列
  298. public static void InitColumns(object[] arrColumns, object[] arrCaption, DataTable dataTable1)
  299. {
  300. if (arrColumns.Length == 0 || arrColumns.Length != arrCaption.Length)
  301. {
  302. return;
  303. }
  304. dataTable1.Columns.Clear();//先清除
  305. DataColumn dc;
  306. for (int i = 0; i < arrColumns.Length; i++)
  307. {
  308. try
  309. {
  310. dc = new DataColumn(arrColumns[i].ToString());
  311. dc.Caption = arrCaption[i].ToString();
  312. if (dc.ColumnName == "CHK")
  313. {
  314. dc.DataType = typeof(bool);
  315. dc.DefaultValue = "False";
  316. }
  317. dataTable1.Columns.Add(dc);
  318. }
  319. catch
  320. {
  321. continue;
  322. }
  323. }
  324. }
  325. //初始化列
  326. public static void InitColumns(object[] arrColumns, object[] arrCaption, DataTable dataTable1, int num)
  327. {
  328. if (arrColumns.Length == 0 || arrColumns.Length != arrCaption.Length)
  329. {
  330. return;
  331. }
  332. int len = dataTable1.Columns.Count;
  333. for (int i = num; i <= len - num; i++)
  334. {
  335. dataTable1.Columns.RemoveAt(num);
  336. }
  337. DataColumn dc;
  338. for (int i = 0; i < arrColumns.Length; i++)
  339. {
  340. try
  341. {
  342. dc = new DataColumn(arrColumns[i].ToString());
  343. dc.Caption = arrCaption[i].ToString();
  344. dataTable1.Columns.Add(dc);
  345. if (dc.ColumnName == "CHK")
  346. {
  347. dc.DataType = typeof(bool);
  348. dc.DefaultValue = "False";
  349. }
  350. }
  351. catch
  352. {
  353. continue;
  354. }
  355. }
  356. }
  357. public static void InitColumns(string[] arrColumns, string[] arrCaption, DataTable dataTable, UltraGrid ultraGrid, string[] show, bool isShow, string[] ope)
  358. {
  359. InitColumns(arrColumns, arrCaption, dataTable);
  360. setColumnShowOrHidden(ultraGrid, show, isShow);
  361. setOtherColumnReadOnly(ultraGrid, ope);
  362. }
  363. //初始化列
  364. public static void InitColumns(string[] arrColumns, string[] chemMax, object[] arrCaption, string[] chemMin, DataTable dataTable1)
  365. {
  366. if (arrColumns.Length == 0 || arrColumns.Length != arrCaption.Length || chemMax.Length != chemMin.Length)
  367. {
  368. return;
  369. }
  370. dataTable1.Columns.Clear();//先清除
  371. DataColumn dc;
  372. for (int i = 0; i < arrColumns.Length; i++)
  373. {
  374. try
  375. {
  376. dc = new DataColumn(arrColumns[i].ToString());
  377. dc.Caption = arrCaption[i].ToString();
  378. dataTable1.Columns.Add(dc);
  379. if (dc.ColumnName == "CHK")
  380. {
  381. dc.DataType = typeof(bool);
  382. dc.DefaultValue = "False";
  383. }
  384. }
  385. catch
  386. {
  387. continue;
  388. }
  389. }
  390. for (int i = 0; i < chemMax.Length; i++)
  391. {
  392. try
  393. {
  394. dc = new DataColumn(chemMax[i]);
  395. dc.Caption = chemMin[i];
  396. dataTable1.Columns.Add(dc);
  397. }
  398. catch
  399. {
  400. continue;
  401. }
  402. }
  403. }
  404. //选择事件
  405. /// <summary>
  406. ///
  407. ///
  408. /// </summary>
  409. /// <param name="strHidden"></param>
  410. /// <param name="ug"></param>
  411. public static void SelectRow(UltraGrid ultraGrid)
  412. {
  413. if (ultraGrid.DisplayLayout.Bands[0].Columns.Exists("CHK"))
  414. {
  415. foreach (UltraGridRow uRow in ultraGrid.Selected.Rows)
  416. {
  417. if (uRow.GetType() != typeof(Infragistics.Win.UltraWinGrid.UltraGridGroupByRow))
  418. {
  419. uRow.Cells["CHK"].Value = true;
  420. }
  421. }
  422. }
  423. }
  424. //b保留修约位数
  425. public static string SavePoint(string value, int len)
  426. {
  427. if (value == "")
  428. {
  429. return "";
  430. }
  431. int position = value.IndexOf('.');
  432. if (position < 0)
  433. {
  434. return value + ".".PadRight(len + 1, '0');
  435. }
  436. else
  437. {
  438. return value.Substring(0, position + 1) + value.Substring(position + 1).PadRight(len, '0');
  439. }
  440. }
  441. }
  442. }