frmMeasureRstMgr.cs 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830
  1. using OTS.WinFormsUI.Docking;
  2. using OTSCLRINTERFACE;
  3. using OTSCommon;
  4. using OTSCommon.Model;
  5. using OTSIncAReportApp.OTSDataMgrFunction;
  6. using OTSIncAReportApp.OTSSampleReportInfo;
  7. using OTSIncAReportApp.SysMgrTools;
  8. using OTSModelSharp;
  9. using OTSModelSharp.DTLBase;
  10. using System;
  11. using System.Collections;
  12. using System.Collections.Generic;
  13. using System.Drawing;
  14. using System.IO;
  15. using System.Runtime.InteropServices;
  16. using System.Windows.Forms;
  17. namespace OTSIncAReportApp
  18. {
  19. /// <summary>
  20. /// 显示测量结果树控件主窗体
  21. /// </summary>
  22. public partial class frmMeasureRstMgr : DockContent
  23. {
  24. #region 变量定义
  25. /// <summary>
  26. /// 主框架窗体,全局变量
  27. /// </summary>
  28. private frmReportApp m_ReportApp = null;
  29. private frmReportConditionChoose m_ConditionChoose;
  30. private ResultDataMgr m_RstDataMgr;
  31. /// <summary>
  32. /// 树窗口类
  33. /// </summary>
  34. private OTSTreeViewData m_TreeViewData = null;
  35. /// <summary>
  36. /// 测量结果样品节点
  37. /// </summary>
  38. public TreeNode m_WorkSampleNode = null;
  39. /// <summary>
  40. /// 工作样品属性参数
  41. /// </summary>
  42. public CTreeSampleRst m_WorkSampleParam = new CTreeSampleRst();
  43. /// <summary>
  44. /// 当前工作样品名
  45. /// </summary>
  46. private String m_WorkSampleName = "";
  47. /// <summary>
  48. /// 当前鼠标点击节点
  49. /// </summary>
  50. int treeNodeSample = -1;
  51. Hashtable table;
  52. #endregion
  53. #region 构造函数和窗体加载
  54. /// <summary>
  55. /// 构造函数
  56. /// </summary>
  57. /// <param name="reportApp"></param>
  58. public frmMeasureRstMgr(frmReportApp reportApp)
  59. {
  60. InitializeComponent();
  61. m_ReportApp = reportApp;
  62. m_ConditionChoose = reportApp.m_conditionChoose;
  63. m_RstDataMgr = reportApp.m_rstDataMgr;
  64. m_TreeViewData = new OTSTreeViewData(this);
  65. #region 国际化语言
  66. OTSCommon.Language lan = new OTSCommon.Language(this);
  67. table = lan.GetNameTable(this.Name);
  68. #endregion
  69. }
  70. /// <summary>
  71. /// 窗体加载
  72. /// </summary>
  73. /// <param name="sender"></param>
  74. /// <param name="e"></param>
  75. private void OTSMeasureRetMgrWindow_Load(object sender, EventArgs e)
  76. {
  77. treeView1.LabelEdit = true;//TreeView可编辑状态。
  78. }
  79. #endregion
  80. #region 外部接口函数及相关常量定义
  81. /// <summary>
  82. /// 发送消息
  83. /// </summary>
  84. /// <param name="hWnd"></param>
  85. /// <param name="Msg"></param>
  86. /// <param name="wParam"></param>
  87. /// <param name="lParam"></param>
  88. /// <returns></returns>
  89. [DllImport("user32.dll", CharSet = CharSet.Auto)]
  90. private static extern IntPtr SendMessage(IntPtr hWnd, int Msg, IntPtr wParam, ref TVITEM lParam);
  91. private const int TVIF_STATE = 0x8;
  92. private const int TVIS_STATEIMAGEMASK = 0xF000;
  93. private const int TV_FIRST = 0x1100;
  94. private const int TVM_SETITEM = TV_FIRST + 63;
  95. [StructLayout(LayoutKind.Sequential, Pack = 8, CharSet = CharSet.Auto)]
  96. private struct TVITEM
  97. {
  98. public int mask;
  99. public IntPtr hItem;
  100. public int state;
  101. public int stateMask;
  102. [MarshalAs(UnmanagedType.LPTStr)]
  103. public string lpszText;
  104. public int cchTextMax;
  105. public int iImage;
  106. public int iSelectedImage; public int cChildren; public IntPtr lParam;
  107. }
  108. #endregion
  109. #region 树控件相关事件
  110. /// <summary>
  111. /// 树控件点击是否选择右键
  112. /// </summary>
  113. /// <param name="sender"></param>
  114. /// <param name="e"></param>
  115. private void treeView1_Click(object sender, MouseEventArgs e)
  116. {
  117. if (e.Button == MouseButtons.Right)//判断你点的是不是右键
  118. {
  119. contextMenuStrip1.Show();
  120. }
  121. }
  122. /// <summary>
  123. /// 左键选择树节点事件
  124. /// </summary>
  125. /// <param name="sender"></param>
  126. /// <param name="e"></param>
  127. private void treeView1_AfterSelect(object sender, TreeViewEventArgs e)
  128. {
  129. //鼠标选中
  130. if (e.Action == TreeViewAction.ByMouse || e.Action == TreeViewAction.ByKeyboard)
  131. {
  132. if (e.Node.IsSelected)
  133. {
  134. //判断的选中的CHECKBOX和焦点都在当前被选择的节点上,切换当前工作样品
  135. m_WorkSampleNode = e.Node;
  136. treeView1.SelectedNode = e.Node; //当前被选中
  137. treeView1.Refresh();
  138. }
  139. }
  140. }
  141. /// <summary>
  142. /// 当Checkbox的状态发生变化时,响应事件
  143. /// </summary>
  144. /// <param name="sender"></param>
  145. /// <param name="e"></param>
  146. private void treeView1_AfterCheck(object sender, TreeViewEventArgs e)
  147. {
  148. if (e.Action == TreeViewAction.ByMouse)
  149. { //判断是否由鼠标触发的
  150. TreeNode TN = e.Node;//点击的节点
  151. if (TN.Checked)
  152. { //若是选中,遍历父节点,所属的父节点应为选中 {
  153. if (TN.Parent != null)
  154. {
  155. TN.Parent.Checked = true;
  156. if (TN.Parent.Parent != null)
  157. {
  158. TN.Parent.Parent.Checked = true;
  159. }
  160. }
  161. DG_Check(TN, true); //本身节点之下还有子节点,遍历,全选中
  162. }
  163. else
  164. { //若是取消选中
  165. DG_Check(TN, false);//本身节点之下还有子节点,遍历,全取消选中
  166. if (TN.Parent != null)
  167. {
  168. //若有父节点,判断此次取消选中后,是否兄弟节点也是没选中
  169. TreeNode TNP = TN.Parent;
  170. bool YXZ = false;//有选中的,以此来判断否兄弟节点也是没选中
  171. foreach (TreeNode childTN in TNP.Nodes)
  172. {
  173. if (childTN.Checked)
  174. {
  175. YXZ = true;//还有选中的兄弟节点
  176. break;
  177. }
  178. }
  179. TNP.Checked = YXZ;//将遍历结果赋给父节点
  180. }
  181. }
  182. }
  183. }
  184. /// <summary>
  185. /// 删除测量结果事件
  186. /// </summary>
  187. /// <param name="sender"></param>
  188. /// <param name="e"></param>
  189. private void RDeleteNode_Click(object sender, EventArgs e)
  190. {
  191. TreeNode tn = new TreeNode();
  192. tn = treeView1.SelectedNode;
  193. tn.Remove();
  194. }
  195. /// <summary>
  196. /// 显示树节点
  197. /// </summary>
  198. /// <param name="sender"></param>
  199. /// <param name="e"></param>
  200. private void treeView1_DrawNode(object sender, DrawTreeNodeEventArgs e)
  201. {
  202. e.DrawDefault = true;
  203. }
  204. /// <summary>
  205. /// 当鼠标点击选择了
  206. /// </summary>
  207. /// <param name="sender"></param>
  208. /// <param name="e"></param>
  209. public void TreeView1_NodeMouseClick(object sender, TreeNodeMouseClickEventArgs e)
  210. {
  211. TreeNode tn = (TreeNode)e.Node;
  212. treeNodeSample = e.Node.Index;
  213. string treeNodeName = e.Node.Text;
  214. //正常indexadd值应该哪个为true哪个给它
  215. int indexadd = e.Node.Index;
  216. string checkednode = "";
  217. foreach (TreeNode item in treeView1.Nodes)
  218. {
  219. if (item.Checked)
  220. {
  221. checkednode = checkednode + "+" + item.Text;
  222. }
  223. }
  224. if (checkednode.LastIndexOf("+") > 1)
  225. {
  226. checkednode = checkednode.Substring(1);
  227. }
  228. else
  229. {
  230. checkednode = "";
  231. }
  232. if (treeView1.Nodes.Count>1&&e.Button == MouseButtons.Left)//判断按下鼠标右键
  233. {
  234. //插入多数据源选项
  235. m_ReportApp.MoreSource = checkednode;
  236. m_ConditionChoose.SetDefaultConditionValue();
  237. m_ConditionChoose.DisCurrentPicProperty();//刷新
  238. }
  239. if (e.Button == MouseButtons.Right)//判断按下鼠标右键
  240. {
  241. Point ClickPoint = new Point(e.X, e.Y);
  242. TreeNode CurrentNode = treeView1.GetNodeAt(ClickPoint);
  243. if (CurrentNode == null && null == CurrentNode.Parent)//判断选择的是不是一个节点
  244. {
  245. CurrentNode.ContextMenuStrip = contextMenuStrip2;
  246. }
  247. else
  248. {
  249. CurrentNode.ContextMenuStrip = contextMenuStrip1;
  250. m_WorkSampleNode = CurrentNode;
  251. }
  252. }
  253. this.Focus();
  254. }
  255. public void AddSampleResult(string str_path)
  256. {
  257. if (m_RstDataMgr.AddDataResult(str_path))
  258. {
  259. m_ConditionChoose.SetDefaultConditionValue();
  260. m_ConditionChoose.GetWorkingPictureConditionVal();
  261. m_ReportApp.m_RstWindow.Show(m_ReportApp.DockWindowPanel);
  262. //在treeview上添加测量结果
  263. m_TreeViewData.DisplayWorkSampleTree(this.m_RstDataMgr.ResultFilesList);
  264. //在grid上添加测量结果
  265. m_ConditionChoose.DisCurrentPicProperty();
  266. //根据标签索引 显示默认的数据图表for test
  267. m_ConditionChoose.ShowsTheDefaultPic();//显示图表
  268. }
  269. else
  270. {
  271. m_TreeViewData.DisplayWorkSampleTree(this.m_RstDataMgr.ResultFilesList);
  272. m_ConditionChoose.SetDefaultConditionValue();
  273. m_ConditionChoose.DisCurrentPicProperty();
  274. }
  275. }
  276. /// <summary>
  277. /// 树节点删除事件
  278. /// </summary>
  279. /// <param name="sender"></param>
  280. /// <param name="e"></param>
  281. private void RDeleteNode_Click_1(object sender, EventArgs e)
  282. {
  283. RemoveSample();
  284. }
  285. //ReportApp窗口给 RetMgrWindow 发送窗口删除样品回复
  286. public void RemoveSample()
  287. {
  288. if (this.treeView1.SelectedNode == null) return;
  289. string str1 = table["str1"].ToString();
  290. string str2 = table["str2"].ToString();
  291. string sDeleteSampleName = str1;
  292. var sDeletSName = this.treeView1.SelectedNode.Text;
  293. sDeleteSampleName += sDeletSName;
  294. sDeleteSampleName += str2;
  295. if (DialogResult.OK == MessageBox.Show(sDeleteSampleName, "Tip", MessageBoxButtons.OKCancel, MessageBoxIcon.Warning))
  296. {
  297. //删除当前选中的节点
  298. treeView1.Nodes.Remove(this.treeView1.SelectedNode); //移除当前工作样品
  299. if ("" == sDeletSName)
  300. {
  301. return;
  302. }
  303. //重新获取Treeview上的工作样品节点
  304. this.m_TreeViewData.GetTreeWorkSampleNode(sDeletSName);
  305. //设置工作样品焦点
  306. this.m_TreeViewData.ReSetWorkSampleFoucs();
  307. //当节点全部删除完时刷新树以及主窗口的控件
  308. if (treeView1.Nodes.Count == 0)
  309. {
  310. //treeView1.Nodes.Clear();
  311. //如果已经没有测量结果,则将报告程序初始化到刚打开的状态
  312. m_ReportApp.InitReportProState();
  313. }
  314. else
  315. {
  316. //重新加载grid窗口
  317. m_ConditionChoose.DisCurrentPicProperty();
  318. //删除树上的节点
  319. m_WorkSampleName = m_ReportApp.m_rstDataMgr.GetSampleName();
  320. m_TreeViewData.GetTreeWorkSampleNode(m_WorkSampleName);
  321. }
  322. }
  323. m_RstDataMgr.RemoveDataResult(sDeletSName);
  324. var rstlist = m_ConditionChoose.m_conditionData.GetComboDownListByItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE);
  325. rstlist.Remove(sDeletSName);
  326. m_ConditionChoose.m_conditionData.SetComboDownListByItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE, rstlist);
  327. if (rstlist.Count > 0)
  328. {
  329. m_ConditionChoose.m_conditionData.SetPropByPropItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE, rstlist[0]);
  330. m_ConditionChoose.m_conditionData.SetItemvalByItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE, 0);
  331. }
  332. m_ConditionChoose.DisCurrentPicProperty();
  333. }
  334. //切换当前工作样品
  335. //string sNewWorkSample : 新的工作样品名
  336. public void MeasureApp_SwitchSample(string sNewName)
  337. {
  338. m_TreeViewData.SetNewWorkSample(sNewName);
  339. }
  340. #endregion
  341. #region 相关树控件方法
  342. //是否为选择工作样品的节点(窗口切换)
  343. public void SelectWorkSampleNode()
  344. {
  345. try
  346. {
  347. //是否添加结果文件
  348. if (m_RstDataMgr.ResultFilesList.Count != 0)
  349. {
  350. if (m_RstDataMgr.GetWorkingResultId() != -1)
  351. if (m_RstDataMgr.ResultFilesList[m_RstDataMgr.GetWorkingResultId()] != null)
  352. {
  353. string workSampleName = m_RstDataMgr.ResultFilesList[m_RstDataMgr.GetWorkingResultId()].anotherFileName;
  354. //设置工作样品
  355. if (m_ReportApp.m_RstWindow.treeView1.Nodes.Count > 0)
  356. {
  357. foreach (TreeNode item in m_ReportApp.m_RstWindow.treeView1.Nodes)
  358. {
  359. //设置选择TreeNode
  360. if (item.Text == workSampleName)
  361. {
  362. m_ReportApp.m_RstWindow.treeView1.SelectedNode = item;
  363. break;
  364. }
  365. }
  366. }
  367. }
  368. }
  369. }
  370. catch (Exception)
  371. {
  372. }
  373. }
  374. /// <summary>
  375. /// 设置树控件各节点的状态
  376. /// </summary>
  377. /// <param name="TN"></param>
  378. /// <param name="flag"></param>
  379. private void DG_Check(TreeNode TN, bool flag)
  380. {
  381. if (TN.Nodes.Count > 0)
  382. {
  383. foreach (TreeNode childTN in TN.Nodes)
  384. {
  385. childTN.Checked = flag;
  386. DG_Check(childTN, flag);
  387. }
  388. }
  389. }
  390. /// <summary>
  391. /// 隐藏树节点,复选框
  392. /// </summary>
  393. /// <param name="tvw"></param>
  394. /// <param name="node"></param>
  395. public void HideCheckBox(TreeView tvw, TreeNode node)
  396. {
  397. TVITEM tvi = new TVITEM();
  398. tvi.hItem = node.Handle;
  399. tvi.mask = TVIF_STATE;
  400. tvi.stateMask = TVIS_STATEIMAGEMASK;
  401. tvi.state = 0;
  402. SendMessage(tvw.Handle, TVM_SETITEM, IntPtr.Zero, ref tvi);
  403. }
  404. #endregion
  405. #region 多数据源操作部份相关
  406. private void button1_Click(object sender, EventArgs e)
  407. {
  408. frmMultiSourceSelect frm_Mss = new frmMultiSourceSelect(this.treeView1);
  409. if (frm_Mss.ShowDialog() == DialogResult.OK)
  410. {
  411. //判断是否选择了两个以上的选项,
  412. int iselectcount = 0;
  413. //第一次更新各选项值
  414. for (int i = 0; i < frm_Mss.treeView1.Nodes.Count; i++)
  415. {
  416. this.treeView1.Nodes[i].Checked = frm_Mss.treeView1.Nodes[i].Checked;
  417. if (frm_Mss.treeView1.Nodes[i].Checked == true)
  418. {
  419. iselectcount++;
  420. }
  421. }
  422. //主动去更新让其选择上多数据源或非多数据源
  423. if (iselectcount >= 2)
  424. {
  425. //获取
  426. //OTSSampleMeaInfo SMInfo = new OTSSampleMeaInfo();
  427. //DataMgrFun dataMgr = m_ReportApp.m_DataMgrFun;
  428. //dataMgr.SetSampleParamVal(OTS_RETORT_PROP_GRID_ITEMS.DATA_SOURCE, OTS_ITEM_TYPES.COMBO, 0);
  429. //获取属性窗口更新显示
  430. //dataMgr.GetWorkSamplePropertyVal(ref SMInfo);
  431. //m_ReportApp.m_PropWindow.DisProperyWindow(SMInfo);
  432. //显示默认的图表
  433. //m_ReportApp.m_PropWindow.m_SampleGrid.ShowDataDiagram();
  434. }
  435. else
  436. {
  437. //单一选项时,也要对该属性窗口进行切换
  438. for (int i = 0; i < frm_Mss.treeView1.Nodes.Count; i++)
  439. {
  440. if (frm_Mss.treeView1.Nodes[i].Checked == true)
  441. {
  442. //OTSSampleMeaInfo SMInfo = new OTSSampleMeaInfo();
  443. //DataMgrFun dataMgr = m_ReportApp.m_DataMgrFun;
  444. //dataMgr.SetSampleParamVal(OTS_RETORT_PROP_GRID_ITEMS.DATA_SOURCE, OTS_ITEM_TYPES.COMBO, i);
  445. ////获取属性窗口更新显示
  446. //dataMgr.GetWorkSamplePropertyVal(ref SMInfo);
  447. //m_ReportApp.m_PropWindow.DisProperyWindow(SMInfo);
  448. ////显示默认的图表
  449. //m_ReportApp.m_PropWindow.m_SampleGrid.ShowDataDiagram();
  450. }
  451. }
  452. }
  453. }
  454. }
  455. #endregion
  456. private void 计算边界颗粒合成ToolStripMenuItem_Click(object sender, EventArgs e)
  457. {
  458. if (this.treeView1.SelectedNode == null) return;
  459. //string sDeleteSampleName = str1;
  460. var SampleName = this.treeView1.SelectedNode.Text;
  461. var resultfile= m_RstDataMgr.GetResultFileObjByName(SampleName);
  462. if (resultfile == null) return;
  463. var log = NLog.LogManager.GetCurrentClassLogger();
  464. log.Info("Merging big particles which are crossing the field edge!");
  465. this.Cursor = System.Windows.Forms.Cursors.WaitCursor;
  466. int scanfldsize = (int)resultfile.GetScanFieldSizeX();
  467. List<COTSParticleClr> mergedParticles = new List<COTSParticleClr>();
  468. double pixelSize = resultfile.GetPixelSize();
  469. Size s = new Size(resultfile.GetImageWidth(), resultfile.GetImageHeight());
  470. MergeBigBoundaryParticles(resultfile.List_OTSField, pixelSize, scanfldsize, s, ref mergedParticles);
  471. OTSCLRINTERFACE.ImageProForClr imgpro = new OTSCLRINTERFACE.ImageProForClr();
  472. foreach (COTSParticleClr part in mergedParticles)
  473. {
  474. imgpro.CalcuParticleImagePropertes(part, pixelSize);
  475. }
  476. string libname = resultfile.GetSTDName();
  477. int steelTech = resultfile.GetIncASteeltech();
  478. ClassifyParticle(mergedParticles, libname, m_ReportApp.m_RptConfigFile.Systype, steelTech);
  479. log.Info("begin merged particle data db saving...");
  480. SaveMergedParticles(mergedParticles,resultfile.GetResultDBPath());
  481. MessageBox.Show("边界颗粒合成完成!");
  482. this.Cursor = System.Windows.Forms.Cursors.Default;
  483. }
  484. public bool MergeBigBoundaryParticles(List<OTSCommon.Model.Field> allFields, double pixelSize, int scanFieldSize, System.Drawing.Size ResolutionSize, ref List<COTSParticleClr> mergedParts)
  485. {
  486. List<COTSFieldDataClr> fldclrs = new List<COTSFieldDataClr>();
  487. ImageProForClr imgpro = new ImageProForClr();
  488. foreach (var f in allFields)
  489. {
  490. COTSFieldDataClr fldclr = new COTSFieldDataClr();
  491. PointF p1 = f.GetOTSPosition();
  492. System.Drawing.Point p2 = new System.Drawing.Point((int)p1.X, (int)p1.Y);
  493. fldclr.SetPosition((int)p1.X, (int)p1.Y);
  494. fldclr.SetImageWidth(ResolutionSize.Width);
  495. fldclr.SetImageHeight(ResolutionSize.Height);
  496. var parts = f.ParticleList;
  497. foreach (var p in parts)
  498. {
  499. COTSParticleClr part = new COTSParticleClr();
  500. COTSFeatureClr fea = new COTSFeatureClr();
  501. List<COTSSegmentClr> segs = new List<COTSSegmentClr>();
  502. foreach (var s in p.SegmentList)
  503. {
  504. COTSSegmentClr seg = new COTSSegmentClr();
  505. seg.SetStart(s.Start);
  506. seg.SetHeight(s.Height);
  507. seg.SetLength(s.Length);
  508. segs.Add(seg);
  509. }
  510. fea.SetSegmentsList(segs,true);
  511. part.SetFeature(fea);
  512. var xray = part.GetXray();
  513. foreach (var ele in p.ElementList)
  514. {
  515. CElementChemistryClr eleclr = new CElementChemistryClr();
  516. eleclr.SetName(ele.Name);
  517. eleclr.SetPercentage(ele.Percentage);
  518. xray.AddQuantifyElement(eleclr);
  519. }
  520. part.SetFieldId(p.FieldId);
  521. part.SetAnalysisId(p.XrayId);
  522. part.SetXray(xray);
  523. part.SetActualArea(p.Area);
  524. part.SetAbsolutPos(new Point(p.PosX, p.PosY));
  525. part.CalCoverRect();
  526. part.CalXrayPos();
  527. fldclr.AddParticle(part);
  528. }
  529. fldclrs.Add(fldclr);
  530. }
  531. imgpro.MergeBigBoundaryParticles(fldclrs, pixelSize, scanFieldSize, ResolutionSize, mergedParts);
  532. return true;
  533. }
  534. private bool ClassifyParticle(List<COTSParticleClr> parts,string libname, OTS_SysType_ID systype,int steeltech)
  535. {
  536. bool r = true;
  537. try
  538. {
  539. if (systype == OTS_SysType_ID.IncA)
  540. {
  541. r= COffLineClassifyLogic.ClassifyIncA(parts, libname,steeltech);
  542. }
  543. else if (systype == OTS_SysType_ID.CleannessA)
  544. {
  545. r= COffLineClassifyLogic.ClassifyCleannessA(parts, libname);
  546. }
  547. return r;
  548. }
  549. catch (Exception e)
  550. {
  551. NLog.LogManager.GetCurrentClassLogger().Error("merged parts classify failed. " + e.Message);
  552. return false;
  553. }
  554. }
  555. public bool SaveMergedParticles(List<COTSParticleClr> mergedParts,string dbfile)
  556. {
  557. CIncAFileMgr pDBFileMgr = new CIncAFileMgr(dbfile);
  558. var mergedpartdb = pDBFileMgr.GetMergedParticleDB();
  559. mergedpartdb.RemoveAllRows();
  560. foreach (COTSParticleClr part in mergedParts)
  561. {
  562. mergedpartdb.SaveAParticle(part, part.GetXray(), (Point)part.GetAbsolutPos());
  563. }
  564. CPosXrayDBMgr pXrayDBMgr = pDBFileMgr.GetPosXrayDBMgr();
  565. CElementChemistryDB xraydb = pXrayDBMgr.GetElementChemistryDB();
  566. List<CPosXrayClr> ches = new List<CPosXrayClr>();
  567. foreach (COTSParticleClr part in mergedParts)
  568. {
  569. ches.Add(part.GetXray());
  570. }
  571. xraydb.SaveElementChemistriesList_Batch(ches);
  572. return true;
  573. }
  574. private void ToolStripMenuItem_Zeroelementprocess_Click(object sender, EventArgs e)
  575. {
  576. if (this.treeView1.SelectedNode == null) return;
  577. var SampleName = this.treeView1.SelectedNode.Text;
  578. var resultfile = m_RstDataMgr.GetResultFileObjByName(SampleName);
  579. if (resultfile == null) return;
  580. var log = NLog.LogManager.GetCurrentClassLogger();
  581. log.Info("Start to Zeroelementprocess!");
  582. this.Cursor = System.Windows.Forms.Cursors.WaitCursor;
  583. List<COTSParticleClr> ParticleClrs = new List<COTSParticleClr>();
  584. ParticleClrs = GetParticleClrFromFields(resultfile.List_OTSField);
  585. if (m_ReportApp.m_RptConfigFile.Systype == OTS_SysType_ID.IncA)
  586. {
  587. if (resultfile.GetUseSysSTD())
  588. {
  589. OTSCLRINTERFACE.COTSClassifyEngineClr EngineClr = new COTSClassifyEngineClr(EngineType.InclutionEng, "NoSTDDB");
  590. ParticleClrs = ZeroElementProcess(EngineClr, ParticleClrs);
  591. }
  592. string libname = resultfile.GetSTDName();
  593. if (!libname.Contains(".db"))
  594. {
  595. libname += ".db";
  596. }
  597. if (libname.ToLower() != "nostddb" && libname.ToLower() != "nostddb.db")
  598. {
  599. if (!File.Exists(".\\Config\\SysData\\" + libname))
  600. {
  601. MessageBox.Show("未加载到标准库!");
  602. return;
  603. }
  604. OTSCLRINTERFACE.COTSClassifyEngineClr EngineClr2 = new COTSClassifyEngineClr(EngineType.ExpressionClassifyEng, libname);
  605. ParticleClrs = ZeroElementProcess(EngineClr2, ParticleClrs);
  606. }
  607. }
  608. else
  609. {
  610. string libname = resultfile.GetSTDName();
  611. if (!libname.Contains(".db"))
  612. {
  613. libname += ".db";
  614. }
  615. if (libname.ToLower() != "nostddb" && libname.ToLower() != "nostddb.db")
  616. {
  617. if (!File.Exists(".\\Config\\SysData\\" + libname))
  618. {
  619. MessageBox.Show("未加载到标准库!");
  620. return;
  621. }
  622. OTSCLRINTERFACE.COTSClassifyEngineClr EngineClr = new COTSClassifyEngineClr(EngineType.ExpressionClassifyEng, libname);
  623. ParticleClrs = ZeroElementProcess(EngineClr, ParticleClrs);
  624. }
  625. }
  626. log.Info("begin particle data db saving...");
  627. if(UpdateElementofParticles(ParticleClrs,resultfile.GetResultDBPath()))
  628. {
  629. MessageBox.Show("零元素归一化完毕,请重启报告以便数据生效!");
  630. }
  631. else
  632. {
  633. }
  634. this.Cursor = System.Windows.Forms.Cursors.Default;
  635. }
  636. List<COTSParticleClr> ZeroElementProcess(OTSCLRINTERFACE.COTSClassifyEngineClr ClassifyEngineClr, List<COTSParticleClr> allParticles)
  637. {
  638. foreach (COTSParticleClr particleClr in allParticles)
  639. {
  640. ClassifyEngineClr.ZeroElementProcess(particleClr);
  641. }
  642. return allParticles;
  643. }
  644. List<COTSParticleClr> GetParticleClrFromFields(List<OTSCommon.Model.Field> allFields)
  645. {
  646. List<COTSParticleClr> ParticleClrs = new List<COTSParticleClr>();
  647. foreach (var f in allFields)
  648. {
  649. var parts = f.ParticleList;
  650. foreach (var p in parts)
  651. {
  652. COTSParticleClr part = new COTSParticleClr();
  653. COTSFeatureClr fea = new COTSFeatureClr();
  654. part.SetFeature(fea);
  655. var xray = part.GetXray();
  656. foreach (var ele in p.ElementList)
  657. {
  658. CElementChemistryClr eleclr = new CElementChemistryClr();
  659. eleclr.SetName(ele.Name);
  660. eleclr.SetPercentage(ele.Percentage);
  661. xray.AddQuantifyElement(eleclr);
  662. }
  663. part.SetFieldId(p.FieldId);
  664. part.SetAnalysisId(p.XrayId);
  665. part.SetParticleId(p.ParticleId);
  666. part.SetXray(xray);
  667. ParticleClrs.Add(part);
  668. }
  669. }
  670. return ParticleClrs;
  671. }
  672. public bool UpdateElementofParticles(List<COTSParticleClr> Parts, string dbfile)
  673. {
  674. CIncAFileMgr pDBFileMgr = new CIncAFileMgr(dbfile);
  675. CPosXrayDBMgr pXrayDBMgr = pDBFileMgr.GetPosXrayDBMgr();
  676. CElementChemistryDB xraydb = pXrayDBMgr.GetElementChemistryDB();
  677. List<CPosXrayClr> ches = new List<CPosXrayClr>();
  678. foreach (COTSParticleClr part in Parts)
  679. {
  680. part.GetXray().SetIndex(part.GetParticleId());
  681. part.GetXray().SetScanFieldId(part.GetFieldId());
  682. ches.Add(part.GetXray());
  683. }
  684. xraydb.RemoveAllRows();
  685. try
  686. {
  687. xraydb.SaveElementChemistriesList_Batch(ches);
  688. }
  689. catch(Exception ex)
  690. {
  691. MessageBox.Show(ex.ToString());
  692. return false;
  693. }
  694. return true;
  695. }
  696. private void treeView1_NodeMouseHover(object sender, TreeNodeMouseHoverEventArgs e)
  697. {
  698. e.Node.ToolTipText = e.Node.Tag.ToString();
  699. }
  700. }
  701. }