frmMeasureRstMgr.cs 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825
  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. //插入多数据源选项
  233. m_ReportApp.MoreSource = checkednode;
  234. m_ConditionChoose.SetDefaultConditionValue();
  235. m_ConditionChoose.DisCurrentPicProperty();//刷新
  236. if (e.Button == MouseButtons.Right)//判断按下鼠标右键
  237. {
  238. Point ClickPoint = new Point(e.X, e.Y);
  239. TreeNode CurrentNode = treeView1.GetNodeAt(ClickPoint);
  240. if (CurrentNode == null && null == CurrentNode.Parent)//判断选择的是不是一个节点
  241. {
  242. CurrentNode.ContextMenuStrip = contextMenuStrip2;
  243. }
  244. else
  245. {
  246. CurrentNode.ContextMenuStrip = contextMenuStrip1;
  247. m_WorkSampleNode = CurrentNode;
  248. }
  249. }
  250. this.Focus();
  251. }
  252. public void AddSampleResult(string str_path)
  253. {
  254. if (m_RstDataMgr.AddDataResult(str_path))
  255. {
  256. m_ConditionChoose.SetDefaultConditionValue();
  257. m_ConditionChoose.GetWorkingPictureConditionVal();
  258. m_ReportApp.m_RstWindow.Show(m_ReportApp.DockWindowPanel);
  259. //在treeview上添加测量结果
  260. m_TreeViewData.DisplayWorkSampleTree(this.m_RstDataMgr.ResultFilesList);
  261. //在grid上添加测量结果
  262. m_ConditionChoose.DisCurrentPicProperty();
  263. //根据标签索引 显示默认的数据图表for test
  264. m_ConditionChoose.ShowsTheDefaultPic();//显示图表
  265. }
  266. else
  267. {
  268. m_TreeViewData.DisplayWorkSampleTree(this.m_RstDataMgr.ResultFilesList);
  269. m_ConditionChoose.SetDefaultConditionValue();
  270. m_ConditionChoose.DisCurrentPicProperty();
  271. }
  272. }
  273. /// <summary>
  274. /// 树节点删除事件
  275. /// </summary>
  276. /// <param name="sender"></param>
  277. /// <param name="e"></param>
  278. private void RDeleteNode_Click_1(object sender, EventArgs e)
  279. {
  280. RemoveSample();
  281. }
  282. //ReportApp窗口给 RetMgrWindow 发送窗口删除样品回复
  283. public void RemoveSample()
  284. {
  285. if (this.treeView1.SelectedNode == null) return;
  286. string str1 = table["str1"].ToString();
  287. string str2 = table["str2"].ToString();
  288. string sDeleteSampleName = str1;
  289. var sDeletSName = this.treeView1.SelectedNode.Text;
  290. sDeleteSampleName += sDeletSName;
  291. sDeleteSampleName += str2;
  292. if (DialogResult.OK == MessageBox.Show(sDeleteSampleName, "Tip", MessageBoxButtons.OKCancel, MessageBoxIcon.Warning))
  293. {
  294. //删除当前选中的节点
  295. treeView1.Nodes.Remove(this.treeView1.SelectedNode); //移除当前工作样品
  296. if ("" == sDeletSName)
  297. {
  298. return;
  299. }
  300. //重新获取Treeview上的工作样品节点
  301. this.m_TreeViewData.GetTreeWorkSampleNode(sDeletSName);
  302. //设置工作样品焦点
  303. this.m_TreeViewData.ReSetWorkSampleFoucs();
  304. //当节点全部删除完时刷新树以及主窗口的控件
  305. if (treeView1.Nodes.Count == 0)
  306. {
  307. //treeView1.Nodes.Clear();
  308. //如果已经没有测量结果,则将报告程序初始化到刚打开的状态
  309. m_ReportApp.InitReportProState();
  310. }
  311. else
  312. {
  313. //重新加载grid窗口
  314. m_ConditionChoose.DisCurrentPicProperty();
  315. //删除树上的节点
  316. m_WorkSampleName = m_ReportApp.m_rstDataMgr.GetSampleName();
  317. m_TreeViewData.GetTreeWorkSampleNode(m_WorkSampleName);
  318. }
  319. }
  320. m_RstDataMgr.RemoveDataResult(sDeletSName);
  321. var rstlist = m_ConditionChoose.m_conditionData.GetComboDownListByItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE);
  322. rstlist.Remove(sDeletSName);
  323. m_ConditionChoose.m_conditionData.SetComboDownListByItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE, rstlist);
  324. if (rstlist.Count > 0)
  325. {
  326. m_ConditionChoose.m_conditionData.SetPropByPropItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE, rstlist[0]);
  327. m_ConditionChoose.m_conditionData.SetItemvalByItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE, 0);
  328. }
  329. m_ConditionChoose.DisCurrentPicProperty();
  330. }
  331. //切换当前工作样品
  332. //string sNewWorkSample : 新的工作样品名
  333. public void MeasureApp_SwitchSample(string sNewName)
  334. {
  335. m_TreeViewData.SetNewWorkSample(sNewName);
  336. }
  337. #endregion
  338. #region 相关树控件方法
  339. //是否为选择工作样品的节点(窗口切换)
  340. public void SelectWorkSampleNode()
  341. {
  342. try
  343. {
  344. //是否添加结果文件
  345. if (m_RstDataMgr.ResultFilesList.Count != 0)
  346. {
  347. if (m_RstDataMgr.GetWorkingResultId() != -1)
  348. if (m_RstDataMgr.ResultFilesList[m_RstDataMgr.GetWorkingResultId()] != null)
  349. {
  350. string workSampleName = m_RstDataMgr.ResultFilesList[m_RstDataMgr.GetWorkingResultId()].anotherFileName;
  351. //设置工作样品
  352. if (m_ReportApp.m_RstWindow.treeView1.Nodes.Count > 0)
  353. {
  354. foreach (TreeNode item in m_ReportApp.m_RstWindow.treeView1.Nodes)
  355. {
  356. //设置选择TreeNode
  357. if (item.Text == workSampleName)
  358. {
  359. m_ReportApp.m_RstWindow.treeView1.SelectedNode = item;
  360. break;
  361. }
  362. }
  363. }
  364. }
  365. }
  366. }
  367. catch (Exception)
  368. {
  369. }
  370. }
  371. /// <summary>
  372. /// 设置树控件各节点的状态
  373. /// </summary>
  374. /// <param name="TN"></param>
  375. /// <param name="flag"></param>
  376. private void DG_Check(TreeNode TN, bool flag)
  377. {
  378. if (TN.Nodes.Count > 0)
  379. {
  380. foreach (TreeNode childTN in TN.Nodes)
  381. {
  382. childTN.Checked = flag;
  383. DG_Check(childTN, flag);
  384. }
  385. }
  386. }
  387. /// <summary>
  388. /// 隐藏树节点,复选框
  389. /// </summary>
  390. /// <param name="tvw"></param>
  391. /// <param name="node"></param>
  392. public void HideCheckBox(TreeView tvw, TreeNode node)
  393. {
  394. TVITEM tvi = new TVITEM();
  395. tvi.hItem = node.Handle;
  396. tvi.mask = TVIF_STATE;
  397. tvi.stateMask = TVIS_STATEIMAGEMASK;
  398. tvi.state = 0;
  399. SendMessage(tvw.Handle, TVM_SETITEM, IntPtr.Zero, ref tvi);
  400. }
  401. #endregion
  402. #region 多数据源操作部份相关
  403. private void button1_Click(object sender, EventArgs e)
  404. {
  405. frmMultiSourceSelect frm_Mss = new frmMultiSourceSelect(this.treeView1);
  406. if (frm_Mss.ShowDialog() == DialogResult.OK)
  407. {
  408. //判断是否选择了两个以上的选项,
  409. int iselectcount = 0;
  410. //第一次更新各选项值
  411. for (int i = 0; i < frm_Mss.treeView1.Nodes.Count; i++)
  412. {
  413. this.treeView1.Nodes[i].Checked = frm_Mss.treeView1.Nodes[i].Checked;
  414. if (frm_Mss.treeView1.Nodes[i].Checked == true)
  415. {
  416. iselectcount++;
  417. }
  418. }
  419. //主动去更新让其选择上多数据源或非多数据源
  420. if (iselectcount >= 2)
  421. {
  422. //获取
  423. //OTSSampleMeaInfo SMInfo = new OTSSampleMeaInfo();
  424. //DataMgrFun dataMgr = m_ReportApp.m_DataMgrFun;
  425. //dataMgr.SetSampleParamVal(OTS_RETORT_PROP_GRID_ITEMS.DATA_SOURCE, OTS_ITEM_TYPES.COMBO, 0);
  426. //获取属性窗口更新显示
  427. //dataMgr.GetWorkSamplePropertyVal(ref SMInfo);
  428. //m_ReportApp.m_PropWindow.DisProperyWindow(SMInfo);
  429. //显示默认的图表
  430. //m_ReportApp.m_PropWindow.m_SampleGrid.ShowDataDiagram();
  431. }
  432. else
  433. {
  434. //单一选项时,也要对该属性窗口进行切换
  435. for (int i = 0; i < frm_Mss.treeView1.Nodes.Count; i++)
  436. {
  437. if (frm_Mss.treeView1.Nodes[i].Checked == true)
  438. {
  439. //OTSSampleMeaInfo SMInfo = new OTSSampleMeaInfo();
  440. //DataMgrFun dataMgr = m_ReportApp.m_DataMgrFun;
  441. //dataMgr.SetSampleParamVal(OTS_RETORT_PROP_GRID_ITEMS.DATA_SOURCE, OTS_ITEM_TYPES.COMBO, i);
  442. ////获取属性窗口更新显示
  443. //dataMgr.GetWorkSamplePropertyVal(ref SMInfo);
  444. //m_ReportApp.m_PropWindow.DisProperyWindow(SMInfo);
  445. ////显示默认的图表
  446. //m_ReportApp.m_PropWindow.m_SampleGrid.ShowDataDiagram();
  447. }
  448. }
  449. }
  450. }
  451. }
  452. #endregion
  453. private void 计算边界颗粒合成ToolStripMenuItem_Click(object sender, EventArgs e)
  454. {
  455. if (this.treeView1.SelectedNode == null) return;
  456. //string sDeleteSampleName = str1;
  457. var SampleName = this.treeView1.SelectedNode.Text;
  458. var resultfile= m_RstDataMgr.GetResultFileObjByName(SampleName);
  459. if (resultfile == null) return;
  460. var log = NLog.LogManager.GetCurrentClassLogger();
  461. log.Info("Merging big particles which are crossing the field edge!");
  462. this.Cursor = System.Windows.Forms.Cursors.WaitCursor;
  463. int scanfldsize = (int)resultfile.GetScanFieldSizeX();
  464. List<COTSParticleClr> mergedParticles = new List<COTSParticleClr>();
  465. double pixelSize = resultfile.GetPixelSize();
  466. Size s = new Size(resultfile.GetImageWidth(), resultfile.GetImageHeight());
  467. MergeBigBoundaryParticles(resultfile.List_OTSField, pixelSize, scanfldsize, s, ref mergedParticles);
  468. OTSCLRINTERFACE.ImageProForClr imgpro = new OTSCLRINTERFACE.ImageProForClr();
  469. foreach (COTSParticleClr part in mergedParticles)
  470. {
  471. imgpro.CalcuParticleImagePropertes(part, pixelSize);
  472. }
  473. string libname = resultfile.GetSTDName();
  474. int steelTech = resultfile.GetIncASteeltech();
  475. ClassifyParticle(mergedParticles, libname, m_ReportApp.m_RptConfigFile.Systype, steelTech);
  476. log.Info("begin merged particle data db saving...");
  477. SaveMergedParticles(mergedParticles,resultfile.GetResultDBPath());
  478. MessageBox.Show("边界颗粒合成完成!");
  479. this.Cursor = System.Windows.Forms.Cursors.Default;
  480. }
  481. public bool MergeBigBoundaryParticles(List<OTSCommon.Model.Field> allFields, double pixelSize, int scanFieldSize, System.Drawing.Size ResolutionSize, ref List<COTSParticleClr> mergedParts)
  482. {
  483. List<COTSFieldDataClr> fldclrs = new List<COTSFieldDataClr>();
  484. ImageProForClr imgpro = new ImageProForClr();
  485. foreach (var f in allFields)
  486. {
  487. COTSFieldDataClr fldclr = new COTSFieldDataClr();
  488. PointF p1 = f.GetOTSPosition();
  489. System.Drawing.Point p2 = new System.Drawing.Point((int)p1.X, (int)p1.Y);
  490. fldclr.SetPosition((int)p1.X, (int)p1.Y);
  491. fldclr.SetImageWidth(ResolutionSize.Width);
  492. fldclr.SetImageHeight(ResolutionSize.Height);
  493. var parts = f.ParticleList;
  494. foreach (var p in parts)
  495. {
  496. COTSParticleClr part = new COTSParticleClr();
  497. COTSFeatureClr fea = new COTSFeatureClr();
  498. List<COTSSegmentClr> segs = new List<COTSSegmentClr>();
  499. foreach (var s in p.SegmentList)
  500. {
  501. COTSSegmentClr seg = new COTSSegmentClr();
  502. seg.SetStart(s.Start);
  503. seg.SetHeight(s.Height);
  504. seg.SetLength(s.Length);
  505. segs.Add(seg);
  506. }
  507. fea.SetSegmentsList(segs,true);
  508. part.SetFeature(fea);
  509. var xray = part.GetXray();
  510. foreach (var ele in p.ElementList)
  511. {
  512. CElementChemistryClr eleclr = new CElementChemistryClr();
  513. eleclr.SetName(ele.Name);
  514. eleclr.SetPercentage(ele.Percentage);
  515. xray.AddQuantifyElement(eleclr);
  516. }
  517. part.SetFieldId(p.FieldId);
  518. part.SetAnalysisId(p.XrayId);
  519. part.SetXray(xray);
  520. part.SetActualArea(p.Area);
  521. part.SetAbsolutPos(new Point(p.PosX, p.PosY));
  522. part.CalCoverRect();
  523. part.CalXrayPos();
  524. fldclr.AddParticle(part);
  525. }
  526. fldclrs.Add(fldclr);
  527. }
  528. imgpro.MergeBigBoundaryParticles(fldclrs, pixelSize, scanFieldSize, ResolutionSize, mergedParts);
  529. return true;
  530. }
  531. private bool ClassifyParticle(List<COTSParticleClr> parts,string libname, OTS_SysType_ID systype,int steeltech)
  532. {
  533. bool r = true;
  534. try
  535. {
  536. if (systype == OTS_SysType_ID.IncA)
  537. {
  538. r= COffLineClassifyLogic.ClassifyIncA(parts, libname,steeltech);
  539. }
  540. else if (systype == OTS_SysType_ID.CleannessA)
  541. {
  542. r= COffLineClassifyLogic.ClassifyCleannessA(parts, libname);
  543. }
  544. return r;
  545. }
  546. catch (Exception e)
  547. {
  548. NLog.LogManager.GetCurrentClassLogger().Error("merged parts classify failed. " + e.Message);
  549. return false;
  550. }
  551. }
  552. public bool SaveMergedParticles(List<COTSParticleClr> mergedParts,string dbfile)
  553. {
  554. CIncAFileMgr pDBFileMgr = new CIncAFileMgr(dbfile);
  555. var mergedpartdb = pDBFileMgr.GetMergedParticleDB();
  556. foreach (COTSParticleClr part in mergedParts)
  557. {
  558. mergedpartdb.SaveAParticle(part, part.GetXray(), (Point)part.GetAbsolutPos());
  559. }
  560. CPosXrayDBMgr pXrayDBMgr = pDBFileMgr.GetPosXrayDBMgr();
  561. CElementChemistryDB xraydb = pXrayDBMgr.GetElementChemistryDB();
  562. List<CPosXrayClr> ches = new List<CPosXrayClr>();
  563. foreach (COTSParticleClr part in mergedParts)
  564. {
  565. ches.Add(part.GetXray());
  566. }
  567. xraydb.SaveElementChemistriesList(ches);
  568. return true;
  569. }
  570. private void ToolStripMenuItem_Zeroelementprocess_Click(object sender, EventArgs e)
  571. {
  572. if (this.treeView1.SelectedNode == null) return;
  573. var SampleName = this.treeView1.SelectedNode.Text;
  574. var resultfile = m_RstDataMgr.GetResultFileObjByName(SampleName);
  575. if (resultfile == null) return;
  576. var log = NLog.LogManager.GetCurrentClassLogger();
  577. log.Info("Start to Zeroelementprocess!");
  578. this.Cursor = System.Windows.Forms.Cursors.WaitCursor;
  579. List<COTSParticleClr> ParticleClrs = new List<COTSParticleClr>();
  580. ParticleClrs = GetParticleClrFromFields(resultfile.List_OTSField);
  581. if (m_ReportApp.m_RptConfigFile.Systype == OTS_SysType_ID.IncA)
  582. {
  583. if (resultfile.GetUseSysSTD())
  584. {
  585. OTSCLRINTERFACE.COTSClassifyEngineClr EngineClr = new COTSClassifyEngineClr(EngineType.InclutionEng, "NoSTDDB");
  586. ParticleClrs = ZeroElementProcess(EngineClr, ParticleClrs);
  587. }
  588. string libname = resultfile.GetSTDName();
  589. if (!libname.Contains(".db"))
  590. {
  591. libname += ".db";
  592. }
  593. if (libname.ToLower() != "nostddb" && libname.ToLower() != "nostddb.db")
  594. {
  595. if (!File.Exists(".\\Config\\SysData\\" + libname))
  596. {
  597. MessageBox.Show("未加载到标准库!");
  598. return;
  599. }
  600. OTSCLRINTERFACE.COTSClassifyEngineClr EngineClr2 = new COTSClassifyEngineClr(EngineType.ExpressionClassifyEng, libname);
  601. ParticleClrs = ZeroElementProcess(EngineClr2, ParticleClrs);
  602. }
  603. }
  604. else
  605. {
  606. string libname = resultfile.GetSTDName();
  607. if (!libname.Contains(".db"))
  608. {
  609. libname += ".db";
  610. }
  611. if (libname.ToLower() != "nostddb" && libname.ToLower() != "nostddb.db")
  612. {
  613. if (!File.Exists(".\\Config\\SysData\\" + libname))
  614. {
  615. MessageBox.Show("未加载到标准库!");
  616. return;
  617. }
  618. OTSCLRINTERFACE.COTSClassifyEngineClr EngineClr = new COTSClassifyEngineClr(EngineType.ExpressionClassifyEng, libname);
  619. ParticleClrs = ZeroElementProcess(EngineClr, ParticleClrs);
  620. }
  621. }
  622. log.Info("begin particle data db saving...");
  623. if(UpdateElementofParticles(ParticleClrs,resultfile.GetResultDBPath()))
  624. {
  625. MessageBox.Show("零元素归一化完毕,请重启报告以便数据生效!");
  626. }
  627. else
  628. {
  629. }
  630. this.Cursor = System.Windows.Forms.Cursors.Default;
  631. }
  632. List<COTSParticleClr> ZeroElementProcess(OTSCLRINTERFACE.COTSClassifyEngineClr ClassifyEngineClr, List<COTSParticleClr> allParticles)
  633. {
  634. //List<COTSParticleClr> ParticleClrs = new List<COTSParticleClr>();
  635. foreach (COTSParticleClr particleClr in allParticles)
  636. {
  637. ClassifyEngineClr.ZeroElementProcess(particleClr);
  638. //ParticleClrs.Add(particleClr);
  639. }
  640. return allParticles;
  641. }
  642. List<COTSParticleClr> GetParticleClrFromFields(List<OTSCommon.Model.Field> allFields)
  643. {
  644. List<COTSParticleClr> ParticleClrs = new List<COTSParticleClr>();
  645. foreach (var f in allFields)
  646. {
  647. var parts = f.ParticleList;
  648. foreach (var p in parts)
  649. {
  650. COTSParticleClr part = new COTSParticleClr();
  651. COTSFeatureClr fea = new COTSFeatureClr();
  652. part.SetFeature(fea);
  653. var xray = part.GetXray();
  654. foreach (var ele in p.ElementList)
  655. {
  656. CElementChemistryClr eleclr = new CElementChemistryClr();
  657. eleclr.SetName(ele.Name);
  658. eleclr.SetPercentage(ele.Percentage);
  659. xray.AddQuantifyElement(eleclr);
  660. }
  661. part.SetFieldId(p.FieldId);
  662. part.SetAnalysisId(p.XrayId);
  663. part.SetParticleId(p.ParticleId);
  664. part.SetXray(xray);
  665. ParticleClrs.Add(part);
  666. }
  667. }
  668. return ParticleClrs;
  669. }
  670. public bool UpdateElementofParticles(List<COTSParticleClr> Parts, string dbfile)
  671. {
  672. CIncAFileMgr pDBFileMgr = new CIncAFileMgr(dbfile);
  673. CPosXrayDBMgr pXrayDBMgr = pDBFileMgr.GetPosXrayDBMgr();
  674. CElementChemistryDB xraydb = pXrayDBMgr.GetElementChemistryDB();
  675. List<CPosXrayClr> ches = new List<CPosXrayClr>();
  676. foreach (COTSParticleClr part in Parts)
  677. {
  678. part.GetXray().SetIndex(part.GetParticleId());
  679. part.GetXray().SetScanFieldId(part.GetFieldId());
  680. ches.Add(part.GetXray());
  681. }
  682. xraydb.RemoveAllRows();
  683. try
  684. {
  685. xraydb.SaveElementChemistriesList(ches);
  686. }
  687. catch(Exception ex)
  688. {
  689. MessageBox.Show(ex.ToString());
  690. return false;
  691. }
  692. return true;
  693. }
  694. }
  695. }