frmMeasureRstMgr.cs 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835
  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. var prm = new COTSImgProcPrmClr();
  472. //prm.SetOverlapParam(resultfile.get)
  473. OTSCLRINTERFACE.ImageProForClr imgpro = new OTSCLRINTERFACE.ImageProForClr(prm);
  474. foreach (COTSParticleClr part in mergedParticles)
  475. {
  476. imgpro.CalcuParticleImagePropertes(part, pixelSize);
  477. }
  478. string libname = resultfile.GetSTDName();
  479. int steelTech = resultfile.GetIncASteeltech();
  480. ClassifyParticle(mergedParticles, libname, m_ReportApp.m_RptConfigFile.Systype, steelTech);
  481. log.Info("begin merged particle data db saving...");
  482. SaveMergedParticles(mergedParticles,resultfile.GetResultDBPath());
  483. MessageBox.Show("边界颗粒合成完成!");
  484. this.Cursor = System.Windows.Forms.Cursors.Default;
  485. }
  486. public bool MergeBigBoundaryParticles(List<OTSCommon.Model.Field> allFields, double pixelSize, int scanFieldSize, System.Drawing.Size ResolutionSize, ref List<COTSParticleClr> mergedParts)
  487. {
  488. List<COTSFieldDataClr> fldclrs = new List<COTSFieldDataClr>();
  489. var prm = new COTSImgProcPrmClr();
  490. ImageProForClr imgpro = new ImageProForClr(prm);
  491. foreach (var f in allFields)
  492. {
  493. COTSFieldDataClr fldclr = new COTSFieldDataClr();
  494. PointF p1 = f.GetOTSPosition();
  495. System.Drawing.Point p2 = new System.Drawing.Point((int)p1.X, (int)p1.Y);
  496. fldclr.SetPosition((int)p1.X, (int)p1.Y);
  497. fldclr.SetImageWidth(ResolutionSize.Width);
  498. fldclr.SetImageHeight(ResolutionSize.Height);
  499. var parts = f.ParticleList;
  500. foreach (var p in parts)
  501. {
  502. COTSParticleClr part = new COTSParticleClr();
  503. COTSFeatureClr fea = new COTSFeatureClr();
  504. List<COTSSegmentClr> segs = new List<COTSSegmentClr>();
  505. foreach (var s in p.SegmentList)
  506. {
  507. COTSSegmentClr seg = new COTSSegmentClr();
  508. seg.SetStart(s.Start);
  509. seg.SetHeight(s.Height);
  510. seg.SetLength(s.Length);
  511. segs.Add(seg);
  512. }
  513. fea.SetSegmentsList(segs,true);
  514. part.SetFeature(fea);
  515. var xray = part.GetXray();
  516. foreach (var ele in p.ElementList)
  517. {
  518. CElementChemistryClr eleclr = new CElementChemistryClr();
  519. eleclr.SetName(ele.Name);
  520. eleclr.SetPercentage(ele.Percentage);
  521. xray.AddQuantifyElement(eleclr);
  522. }
  523. part.SetFieldId(p.FieldId);
  524. part.SetAnalysisId(p.XrayId);
  525. part.SetXray(xray);
  526. part.SetActualArea(p.Area);
  527. part.SetSEMPos(new Point(p.PosX, p.PosY));
  528. part.CalCoverRectFromSegment();
  529. part.CalXrayPos();
  530. fldclr.AddParticle(part);
  531. }
  532. fldclrs.Add(fldclr);
  533. }
  534. imgpro.MergeBigBoundaryParticles(fldclrs, pixelSize, scanFieldSize, ResolutionSize, mergedParts);
  535. return true;
  536. }
  537. private bool ClassifyParticle(List<COTSParticleClr> parts,string libname, OTS_SysType_ID systype,int steeltech)
  538. {
  539. bool r = true;
  540. try
  541. {
  542. if (systype == OTS_SysType_ID.IncA)
  543. {
  544. r= COffLineClassifyLogic.ClassifyIncA(parts, libname,steeltech);
  545. }
  546. else if (systype == OTS_SysType_ID.CleannessA)
  547. {
  548. r= COffLineClassifyLogic.ClassifyCleannessA(parts, libname);
  549. }
  550. return r;
  551. }
  552. catch (Exception e)
  553. {
  554. NLog.LogManager.GetCurrentClassLogger().Error("merged parts classify failed. " + e.Message);
  555. return false;
  556. }
  557. }
  558. public bool SaveMergedParticles(List<COTSParticleClr> mergedParts,string dbfile)
  559. {
  560. CIncAFileMgr pDBFileMgr = new CIncAFileMgr(dbfile);
  561. var mergedpartdb = pDBFileMgr.GetMergedParticleDB();
  562. mergedpartdb.RemoveAllRows();
  563. foreach (COTSParticleClr part in mergedParts)
  564. {
  565. mergedpartdb.SaveAParticle(part, part.GetXray(), (Point)part.GetSEMPos());
  566. }
  567. CPosXrayDBMgr pXrayDBMgr = pDBFileMgr.GetPosXrayDBMgr();
  568. CElementChemistryDB xraydb = pXrayDBMgr.GetElementChemistryDB();
  569. List<CPosXrayClr> ches = new List<CPosXrayClr>();
  570. foreach (COTSParticleClr part in mergedParts)
  571. {
  572. ches.Add(part.GetXray());
  573. }
  574. xraydb.SaveElementChemistriesList_Batch(ches);
  575. return true;
  576. }
  577. private void ToolStripMenuItem_Zeroelementprocess_Click(object sender, EventArgs e)
  578. {
  579. if (this.treeView1.SelectedNode == null) return;
  580. var SampleName = this.treeView1.SelectedNode.Text;
  581. var resultfile = m_RstDataMgr.GetResultFileObjByName(SampleName);
  582. if (resultfile == null) return;
  583. var log = NLog.LogManager.GetCurrentClassLogger();
  584. log.Info("Start to Zeroelementprocess!");
  585. this.Cursor = System.Windows.Forms.Cursors.WaitCursor;
  586. List<COTSParticleClr> ParticleClrs = new List<COTSParticleClr>();
  587. ParticleClrs = GetParticleClrFromFields(resultfile.List_OTSField);
  588. if (m_ReportApp.m_RptConfigFile.Systype == OTS_SysType_ID.IncA)
  589. {
  590. if (resultfile.GetUseSysSTD())
  591. {
  592. OTSCLRINTERFACE.COTSClassifyEngineClr EngineClr = new COTSClassifyEngineClr(EngineType.InclutionEng, "NoSTDDB");
  593. ParticleClrs = ZeroElementProcess(EngineClr, ParticleClrs);
  594. }
  595. string libname = resultfile.GetSTDName();
  596. if (!libname.Contains(".db"))
  597. {
  598. libname += ".db";
  599. }
  600. if (libname.ToLower() != "nostddb" && libname.ToLower() != "nostddb.db")
  601. {
  602. if (!File.Exists(".\\Config\\SysData\\" + libname))
  603. {
  604. MessageBox.Show("未加载到标准库!");
  605. return;
  606. }
  607. OTSCLRINTERFACE.COTSClassifyEngineClr EngineClr2 = new COTSClassifyEngineClr(EngineType.ExpressionClassifyEng, libname);
  608. ParticleClrs = ZeroElementProcess(EngineClr2, ParticleClrs);
  609. }
  610. }
  611. else
  612. {
  613. string libname = resultfile.GetSTDName();
  614. if (!libname.Contains(".db"))
  615. {
  616. libname += ".db";
  617. }
  618. if (libname.ToLower() != "nostddb" && libname.ToLower() != "nostddb.db")
  619. {
  620. if (!File.Exists(".\\Config\\SysData\\" + libname))
  621. {
  622. MessageBox.Show("未加载到标准库!");
  623. return;
  624. }
  625. OTSCLRINTERFACE.COTSClassifyEngineClr EngineClr = new COTSClassifyEngineClr(EngineType.ExpressionClassifyEng, libname);
  626. ParticleClrs = ZeroElementProcess(EngineClr, ParticleClrs);
  627. }
  628. }
  629. log.Info("begin particle data db saving...");
  630. if(UpdateElementofParticles(ParticleClrs,resultfile.GetResultDBPath()))
  631. {
  632. MessageBox.Show("零元素归一化完毕,请重启报告以便数据生效!");
  633. }
  634. else
  635. {
  636. }
  637. this.Cursor = System.Windows.Forms.Cursors.Default;
  638. }
  639. List<COTSParticleClr> ZeroElementProcess(OTSCLRINTERFACE.COTSClassifyEngineClr ClassifyEngineClr, List<COTSParticleClr> allParticles)
  640. {
  641. foreach (COTSParticleClr particleClr in allParticles)
  642. {
  643. ClassifyEngineClr.ZeroElementProcess(particleClr);
  644. }
  645. return allParticles;
  646. }
  647. List<COTSParticleClr> GetParticleClrFromFields(List<OTSCommon.Model.Field> allFields)
  648. {
  649. List<COTSParticleClr> ParticleClrs = new List<COTSParticleClr>();
  650. foreach (var f in allFields)
  651. {
  652. var parts = f.ParticleList;
  653. foreach (var p in parts)
  654. {
  655. COTSParticleClr part = new COTSParticleClr();
  656. COTSFeatureClr fea = new COTSFeatureClr();
  657. part.SetFeature(fea);
  658. var xray = part.GetXray();
  659. foreach (var ele in p.ElementList)
  660. {
  661. CElementChemistryClr eleclr = new CElementChemistryClr();
  662. eleclr.SetName(ele.Name);
  663. eleclr.SetPercentage(ele.Percentage);
  664. xray.AddQuantifyElement(eleclr);
  665. }
  666. part.SetFieldId(p.FieldId);
  667. part.SetAnalysisId(p.XrayId);
  668. part.SetParticleId(p.ParticleId);
  669. part.SetXray(xray);
  670. ParticleClrs.Add(part);
  671. }
  672. }
  673. return ParticleClrs;
  674. }
  675. public bool UpdateElementofParticles(List<COTSParticleClr> Parts, string dbfile)
  676. {
  677. CIncAFileMgr pDBFileMgr = new CIncAFileMgr(dbfile);
  678. CPosXrayDBMgr pXrayDBMgr = pDBFileMgr.GetPosXrayDBMgr();
  679. CElementChemistryDB xraydb = pXrayDBMgr.GetElementChemistryDB();
  680. List<CPosXrayClr> ches = new List<CPosXrayClr>();
  681. foreach (COTSParticleClr part in Parts)
  682. {
  683. part.GetXray().SetIndex(part.GetParticleId());
  684. part.GetXray().SetScanFieldId(part.GetFieldId());
  685. ches.Add(part.GetXray());
  686. }
  687. xraydb.RemoveAllRows();
  688. try
  689. {
  690. xraydb.SaveElementChemistriesList_Batch(ches);
  691. }
  692. catch(Exception ex)
  693. {
  694. MessageBox.Show(ex.ToString());
  695. return false;
  696. }
  697. return true;
  698. }
  699. private void treeView1_NodeMouseHover(object sender, TreeNodeMouseHoverEventArgs e)
  700. {
  701. e.Node.ToolTipText = e.Node.Tag.ToString();
  702. }
  703. }
  704. }