OTSMeasureDisplayResult.cs 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744
  1. 
  2. using OTSModelSharp;
  3. using OTSDataType;
  4. using System;
  5. using System.Collections;
  6. using System.Collections.Generic;
  7. using System.ComponentModel;
  8. using System.Drawing;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Threading;
  12. using System.Windows.Forms;
  13. using static OTSDataType.otsdataconst;
  14. using static OTSModelSharp.STMSampleResultData;
  15. namespace OTSMeasureApp
  16. {
  17. class OTSMeasureDisplayResult
  18. {
  19. NLog.Logger log = NLog.LogManager.GetCurrentClassLogger();
  20. public enum ProgressState
  21. {
  22. MeasureCheckReport = 1,
  23. MeasureResult = 2
  24. }
  25. #region 变量生成汇总
  26. OTSIncAMeasureAppForm m_MeasureApp = null;
  27. //样品台窗口对象
  28. public OTSSamplespaceWindow m_OTSSamplespaceWindow = null;
  29. //测量进度信息窗口对象
  30. public MeasureCheckResultInfoWindow m_MeasureCheckReportInfoWindow = null;
  31. //测量结果信息窗口对象
  32. public OTSMeasureResultWindow m_OTSMeasureResultWindow = null;
  33. //在窗体TAB测量状态中显示BSE图
  34. public OTSMeasureStatusWindow m_OTSMeasureStatusWindow = null;
  35. public System.ComponentModel.BackgroundWorker m_bgWorker;
  36. //开始时间
  37. static string m_StartTimePara = "";
  38. //当前测试样品名称
  39. static string m_CurrentSampleName = "";
  40. ST_MSTMsg MeasureResultMsrData;
  41. //已完成帧图的绘制 根据位置-判断相差范围 四舍五入返回的数值有偏差
  42. static int minRange = -100;
  43. static int maxRange = 100;
  44. #endregion
  45. #region 构造方法
  46. public OTSMeasureDisplayResult( OTSIncAMeasureAppForm m_MeasureApps, BackgroundWorker a_bgWorker)
  47. {
  48. try
  49. {
  50. m_MeasureApp = m_MeasureApps;
  51. m_OTSSamplespaceWindow = m_MeasureApps.m_SamplepaceWindow;
  52. m_OTSMeasureResultWindow = m_MeasureApp.m_MeasureRetWindow;
  53. m_OTSMeasureStatusWindow = new OTSMeasureStatusWindow(m_MeasureApp);
  54. Control.CheckForIllegalCrossThreadCalls = false;
  55. //测量结束信息窗口对象
  56. m_MeasureCheckReportInfoWindow = new MeasureCheckResultInfoWindow();
  57. m_bgWorker = a_bgWorker;
  58. //设置报告更新是否可用
  59. m_bgWorker.WorkerReportsProgress = true;
  60. //设置支持取消操作是否可用
  61. m_bgWorker.WorkerSupportsCancellation = true;
  62. m_bgWorker.ProgressChanged += new ProgressChangedEventHandler(backgroundWorker_ProgressChanged);
  63. m_bgWorker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(backgroundWorker_RunWorkerCompleted);
  64. }
  65. catch (Exception ex)
  66. {
  67. log.Error("OTSIncAMeasureApp_OTSMeasureResult:--构造方法--错误日志:" + ex.ToString());
  68. }
  69. }
  70. #endregion
  71. #region 修改窗体控件的响应事件_ProgressChanged
  72. //这里就是通过响应消息,来处理界面的显示工作
  73. private void backgroundWorker_ProgressChanged(object sender, ProgressChangedEventArgs e)
  74. {
  75. try
  76. {
  77. #region 注释弹出当前测量信息窗体
  78. //注释弹出当前测量信息窗体
  79. //SMSR_RET_DATA smsrRectData = (SMSR_RET_DATA)sender;
  80. ////判断窗口是否打开
  81. //if (e.ProgressPercentage == 0)
  82. //{
  83. // if (!CheckFormIsOpen("MeasureProgressInfoWindow"))
  84. // {
  85. // if (measureProgressInfoWindow.IsDisposed)
  86. // {
  87. // //实例窗体
  88. // measureProgressInfoWindow = new MeasureProgressInfoWindow();
  89. // }
  90. // measureProgressInfoWindow.Activate();
  91. // measureProgressInfoWindow.Show();
  92. // //设置开始时间与当前样品名称
  93. // SetStartTime(startTimePara);
  94. // //SetSampleName(currentSampleName);
  95. // }
  96. //}
  97. #endregion
  98. if (e.ProgressPercentage == (int)ProgressState.MeasureCheckReport)
  99. {
  100. try
  101. {
  102. MeasureResultInfo(MeasureResultMsrData);
  103. }
  104. catch (Exception ex)
  105. {
  106. log.Error("OTSIncAMeasureApp_backgroundWorker_ProgressChanged:--打开测量结果列表窗口--错误日志:" + ex.ToString());
  107. }
  108. }
  109. //测量结果
  110. if (e.ProgressPercentage == (int)ProgressState.MeasureResult)
  111. {
  112. try
  113. {
  114. if (m_OTSMeasureResultWindow == null)
  115. {
  116. //实例窗体
  117. m_OTSMeasureResultWindow = m_MeasureApp.m_MeasureRetWindow;
  118. }
  119. //设置工作样品
  120. m_MeasureApp.m_ProjParam.SetWorkSample(OTSSamplespaceWindow.m_SampleSelectName);
  121. //获取工作样品信息
  122. COTSSample WSample = m_MeasureApp.m_ProjParam.GetWorkSample();
  123. CMsrDisplayResults cMsrResultsClr = WSample.GetMsrResults();
  124. //获取结果文件 颗粒列表信息
  125. List<CMsrResultItem> cMsrResultItemClrList = cMsrResultsClr.GetResultItems();
  126. //根据编号获取分类名称
  127. List<CMsrResultItem> cMsrResultItemClrListTemp = cMsrResultItemClrList;
  128. //设置测量状态数据列表
  129. SetMeasureListInfo(cMsrResultItemClrList);
  130. }
  131. catch (Exception ex)
  132. {
  133. log.Error("OTSIncAMeasureApp_backgroundWorker_ProgressChanged:--打开测量结果列表窗口--错误日志:" + ex.ToString());
  134. }
  135. }
  136. }
  137. catch (Exception ex)
  138. {
  139. log.Error("OTSIncAMeasureApp_backgroundWorker_ProgressChanged:--打开测量结果列表窗口--错误日志:" + ex.ToString());
  140. }
  141. }
  142. #endregion
  143. #region 处理完成的响应事件_RunWorkerCompleted
  144. //这里是后台工作完成后的消息处理,可以在这里进行后续的处理工作。
  145. private void backgroundWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
  146. {
  147. //m_bgWorker.CancelAsync();
  148. //m_bgWorker = null;
  149. }
  150. #endregion
  151. #region 判断窗口是否已经打开
  152. //判断窗口是否已经打开
  153. private bool CheckFormIsOpen(string Forms)
  154. {
  155. bool bResult = false;
  156. foreach (Form frm in Application.OpenForms)
  157. {
  158. if (frm.Name == Forms)
  159. {
  160. bResult = true;
  161. break;
  162. }
  163. }
  164. return bResult;
  165. }
  166. #endregion
  167. #region 打开测量结果窗口
  168. /// <summary>
  169. /// 打开测量结果窗口
  170. /// </summary>
  171. public void MeasureResultInfo(ST_MSTMsg sMSR)
  172. {
  173. //打开测量结果窗体
  174. if (m_MeasureCheckReportInfoWindow.IsDisposed)
  175. {
  176. m_MeasureCheckReportInfoWindow = new MeasureCheckResultInfoWindow();
  177. }
  178. m_MeasureCheckReportInfoWindow.Activate();
  179. m_MeasureCheckReportInfoWindow.Show();
  180. SetMeasureResultInfo(sMSR);
  181. }
  182. #endregion
  183. #region 显示BSE图片
  184. public void OTSMeasureStatusWindowFun(int width, int height, byte[] ImageData, OTSIncAMeasureAppForm m_MeasureApps)
  185. {
  186. //设置图像数据与状态
  187. OTSMeasureStatusWindow.bfResult = true;
  188. m_MeasureApps.m_MessureStatuWindow.bBseData = ImageData;
  189. //获取灰度图数据
  190. double[] dGrayLevelData = new double[255];
  191. dGrayLevelData = OTSImageData.GetStaticGaryData(ImageData, dGrayLevelData);
  192. m_MeasureApps.m_MessureStatuWindow.dGrayLevelData = dGrayLevelData;
  193. if (m_MeasureApps.m_MessureStatuWindow.panelXray.Visible)
  194. {
  195. m_MeasureApps.m_MessureStatuWindow.panelXray.Visible = false;
  196. }
  197. //删除点标记
  198. m_MeasureApps.m_MessureStatuWindow.DelElementPointGDIObjects();
  199. //显示BSE图
  200. m_MeasureApps.m_MessureStatuWindow.pbBSEImage.Show();
  201. //显示BSE图
  202. m_MeasureApps.m_MessureStatuWindow.ShowImage(width, height, ImageData);
  203. }
  204. #endregion
  205. #region 隐藏BSE图片
  206. #endregion
  207. #region 初始窗口对象
  208. int intFlag = 0;
  209. public void RunThreadLoadEvent()
  210. {
  211. if (intFlag == 0)
  212. {
  213. m_bgWorker.RunWorkerAsync();
  214. intFlag++;
  215. }
  216. }
  217. #endregion
  218. #region 设置测量状态列表数据
  219. /// <summary>
  220. /// 设置测量状态列表数据
  221. /// </summary>
  222. /// <param name="stratTime"></param>
  223. public void SetMeasureListInfo(IList list)
  224. {
  225. //设置开始时间
  226. if (list != null)
  227. {
  228. //获取测量状态Grid中的数据list
  229. m_OTSMeasureResultWindow.SetMeasureListInfo(list);
  230. }
  231. }
  232. #endregion
  233. #region 设置开始时间
  234. /// <summary>
  235. /// 设置开始时间
  236. /// </summary>
  237. /// <param name="stratTime"></param>
  238. public void SetStartTime(string stratTime)
  239. {
  240. //设置开始时间
  241. if (stratTime != null)
  242. {
  243. if (stratTime != "")
  244. {
  245. m_OTSMeasureResultWindow.SetStartTime(stratTime);
  246. }
  247. }
  248. }
  249. #endregion
  250. #region 设置结束时间
  251. /// <summary>
  252. /// 设置结束时间
  253. /// </summary>
  254. /// <param name="SetEndTime"></param>
  255. public void SetEndTime(string endTime)
  256. {
  257. //设置开始时间
  258. if (endTime != null)
  259. {
  260. if (endTime != "")
  261. {
  262. //设置结束时间
  263. m_MeasureCheckReportInfoWindow.SetEndTime(endTime);
  264. }
  265. }
  266. }
  267. #endregion
  268. #region 设置测量结束窗体中信息内容
  269. public void SetMeasureResultInfo(ST_MSTMsg SMsrData)
  270. {
  271. //设置开始时间
  272. string startTime = SMsrData.STMThreadStu.SMsrCompleteData.csMsrStartTime;
  273. //设置结束时间
  274. string endTime = SMsrData.STMThreadStu.SMsrCompleteData.csMsrEndTime;
  275. //设置测量数
  276. int completeSampleCount = SMsrData.STMThreadStu.SMsrCompleteData.iMsrCompleteSampleCount;
  277. //设置帧图数
  278. int completeFieldCount = SMsrData.STMThreadStu.SMsrCompleteData.iMsrCompleteFieldCount;
  279. //颗粒数
  280. int particleCount = SMsrData.STMThreadStu.SMsrCompleteData.iParticleCount;
  281. //用时
  282. TimeSpan measureTime = SMsrData.STMThreadStu.SMsrCompleteData.MsrUsedTime;
  283. string measureState = string.Empty;
  284. OTSSysMgrTools.Language lan = new OTSSysMgrTools.Language();
  285. Hashtable table= lan.GetNameTable("OTSMeasureResultWindow");
  286. //状态
  287. //switch (SMsrData.STMThreadStu.SMsrCompleteData.MsrStatus)
  288. switch (SMsrData.STMThreadStu.iMsrStatu)
  289. {
  290. case OTS_MSR_THREAD_STATUS.COMPLETED:
  291. measureState = table["state1"].ToString();
  292. break;
  293. case OTS_MSR_THREAD_STATUS.FAILED:
  294. measureState = table["state2"].ToString();
  295. break;
  296. case OTS_MSR_THREAD_STATUS.STOPPED:
  297. measureState = table["state3"].ToString();
  298. break;
  299. }
  300. //设置测量结果窗体信息
  301. string measureTimes = string.Empty;
  302. m_MeasureCheckReportInfoWindow.SetMeasureStateInfo(measureState, completeSampleCount, completeFieldCount, particleCount, startTime, measureTime, endTime, ref measureTimes);
  303. }
  304. #endregion
  305. #region 设置测量用时
  306. public void SetMeasureTime(TimeSpan tSpan)
  307. {
  308. m_OTSMeasureResultWindow.SetMeasureTime(tSpan);
  309. }
  310. #endregion
  311. #region 设置样品名称
  312. /// <summary>
  313. /// 设置样品名称
  314. /// </summary>
  315. /// <param name="SetSampleName"></param>
  316. public void SetSampleName(string sampleName)
  317. {
  318. //设置开始时间
  319. if (sampleName != null)
  320. {
  321. if (sampleName != "")
  322. {
  323. CStageManage.SetWorkSampleAndWorkMeasure(sampleName);
  324. double iWDistance = 0;
  325. double dMagni = 0;
  326. m_MeasureApp.m_ProjParam.GetWorkingSampleSEMData(ref iWDistance, ref dMagni);
  327. if (CMeasureWrapperThread.DoRunType == (int)MSR_THREAD_RunSTATUS.RUNMEASURE)
  328. {
  329. m_OTSMeasureResultWindow.SetSampleName(sampleName);
  330. }
  331. m_OTSSamplespaceWindow.Invalidate();
  332. }
  333. }
  334. }
  335. #endregion
  336. #region 更改已完成测量的帧图状态
  337. public void ChangeDoneMeasureState(Point CurrentFIELDOTSPoint, Color changeColor)
  338. {
  339. //获取帧图对象集合
  340. //m_SingleGDIObjects = OTSSamplespaceWindow.m_SingleGDIObjects;
  341. //根据完成的测量帧图 更改帧图的完成状态
  342. if (OTSSamplespaceWindow.m_SingleGDIObjects != null)
  343. {
  344. if (OTSSamplespaceWindow.m_SingleGDIObjects.Count > 0)
  345. {
  346. //已完成帧图的绘制 根据位置-判断相差范围 四舍五入返回的数值有偏差
  347. int minTempRange = minRange;
  348. int maxTempRange = maxRange;
  349. int XOffice = 0;
  350. int YOffice = 0;
  351. //以放大倍数 获取当前倍数扫描尺寸 与100倍扫描尺寸的比例
  352. int ScanFieldSize = m_MeasureApp.m_ProjParam.m_ResultData.GetWorkingSample().GetSEMDataMsr().GetScanFieldSize();
  353. int ScanFieldSize100 = m_MeasureApp.m_ProjParam.m_ResultData.GetWorkingSample().GetSEMDataMsr().GetScanFieldSize100();
  354. float Scale = Convert.ToSingle(ScanFieldSize100) / Convert.ToSingle(ScanFieldSize);
  355. if (Scale > 0)
  356. {
  357. minTempRange = Convert.ToInt32(minTempRange / Scale);
  358. maxTempRange = Convert.ToInt32(maxTempRange / Scale);
  359. }
  360. for (int i = OTSSamplespaceWindow.m_SingleGDIObjects.Count - 1; i >= 0; i--)
  361. {
  362. XOffice = OTSSamplespaceWindow.m_SingleGDIObjects[i].OTSX - CurrentFIELDOTSPoint.X;
  363. YOffice = OTSSamplespaceWindow.m_SingleGDIObjects[i].OTSY - CurrentFIELDOTSPoint.Y;
  364. if ((minTempRange < XOffice) && (XOffice < maxTempRange) && (minTempRange < YOffice) && (YOffice < maxTempRange))
  365. {
  366. //修改完成状态
  367. OTSSamplespaceWindow.m_SingleGDIObjects[i].SelColor = changeColor;
  368. break;
  369. }
  370. }
  371. }
  372. }
  373. }
  374. public static int ChangeCompleteFieldMeasureState(List<Point> CompleteFieldList, Color changeColor, OTSIncAMeasureAppForm m_MeasureApp)
  375. {
  376. int CompleteCount = 0;
  377. //根据完成的测量帧图 更改帧图的完成状态
  378. if (OTSSamplespaceWindow.m_SingleGDIObjects != null)
  379. {
  380. if (OTSSamplespaceWindow.m_SingleGDIObjects.Count > 0)
  381. {
  382. //已完成帧图的绘制 根据位置-判断相差范围 四舍五入返回的数值有偏差
  383. int minTempRange = minRange;
  384. int maxTempRange = maxRange;
  385. int XOffice = 0;
  386. int YOffice = 0;
  387. //以放大倍数 获取当前倍数扫描尺寸 与100倍扫描尺寸的比例
  388. int ScanFieldSize = m_MeasureApp.m_ProjParam.m_ResultData.GetWorkingSample().GetSEMDataMsr().GetScanFieldSize();
  389. int ScanFieldSize100 = m_MeasureApp.m_ProjParam.m_ResultData.GetWorkingSample().GetSEMDataMsr().GetScanFieldSize100();
  390. float Scale = ScanFieldSize100 / ScanFieldSize;
  391. minTempRange = Convert.ToInt32(minTempRange / Scale);
  392. maxTempRange = Convert.ToInt32(maxTempRange / Scale);
  393. for (int y = 0; y < CompleteFieldList.Count; y++)
  394. {
  395. for (int x = OTSSamplespaceWindow.m_SingleGDIObjects.Count - 1; x >= 0; x--)
  396. {
  397. XOffice = Convert.ToInt32((OTSSamplespaceWindow.m_SingleGDIObjects[x].OTSX - CompleteFieldList[y].X)/Scale);
  398. YOffice = Convert.ToInt32((OTSSamplespaceWindow.m_SingleGDIObjects[x].OTSY - CompleteFieldList[y].Y)/ Scale);
  399. if ((minTempRange < XOffice) && (XOffice < maxTempRange) && (minTempRange < YOffice) && (YOffice < maxTempRange))
  400. {
  401. //修改完成状态
  402. OTSSamplespaceWindow.m_SingleGDIObjects[x].SelColor = changeColor;
  403. CompleteCount++;
  404. break;
  405. }
  406. }
  407. }
  408. }
  409. }
  410. return CompleteCount;
  411. }
  412. #endregion
  413. #region 测量状态进度窗口
  414. public void MeasureStateProgressInfo(SAMPLEFIELDDATA FieldData)
  415. {
  416. //样品测量中的总帧图数
  417. int MeasureFieldTotalCount = FieldData.iMeasureFieldCount;
  418. //样品测量中当前已测量的帧图数
  419. int CompleteFieldCount = FieldData.iCompleteFieldCount;
  420. int ParticleCount = FieldData.iSParticleCount;
  421. if (CompleteFieldCount >= 0 && MeasureFieldTotalCount >= 0)
  422. {
  423. m_bgWorker.ReportProgress((int)ProgressState.MeasureResult);
  424. //设置当前进度信息(当前Field数量与Field总数)
  425. m_OTSMeasureResultWindow.SetCurrentProgressInfo(CompleteFieldCount, MeasureFieldTotalCount, ParticleCount);
  426. }
  427. }
  428. #endregion
  429. #region 设置样品孔中BSE图像信息
  430. /// <summary>
  431. /// 设置样品孔中BSE图像信息
  432. /// </summary>
  433. /// <param name="ImageData">获取显示BSE的图片数据</param>
  434. /// <param name="width">图片宽度</param>
  435. /// <param name="height">图片高度</param>
  436. /// <param name="fieldPos">Field位置</param>
  437. public void SetHoleBSEImageData(byte[] ImageData, int width, int height, Point fieldPos)
  438. {
  439. m_MeasureApp.m_SamplepaceWindow.AddHoleBSEImageData(ImageData, width, height, fieldPos);
  440. }
  441. #endregion
  442. #region 测量方法
  443. //运行测量状态方法
  444. public void RunMeasureState(ST_MSTMsg SMsrData)
  445. {
  446. try
  447. {
  448. //消息枚举 测量状态、测量结果
  449. ENUM_MSG_TYPE dataType = SMsrData.iMsgType;
  450. //测量状态:开始状态、完成状态(测量停止、测量失败、测量完成)
  451. OTS_MSR_THREAD_STATUS msrStatus = SMsrData.STMThreadStu.iMsrStatu;
  452. //获取当前线程执行类型 1:测量 2:获取样品孔图片
  453. int runThreadType = CMeasureWrapperThread.DoRunType;
  454. //获取需显示的grid信息
  455. OTSSamplePropertyInfo MeasureInfo = new OTSSamplePropertyInfo();
  456. m_MeasureApp.m_ProjParam.GetWorkSamplePerameter(m_MeasureApp.m_ProjParam.GetWorkSample(), ref MeasureInfo);
  457. switch (dataType)
  458. {
  459. //测量线程状态
  460. case ENUM_MSG_TYPE.MTHREADSTATUS:
  461. switch (msrStatus)
  462. {
  463. //测量状态在进行中-测量开始
  464. case OTS_MSR_THREAD_STATUS.INPROCESS:
  465. //当前线程执行类型 1:测量
  466. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNMEASURE)
  467. {
  468. string startTime = SMsrData.STMThreadStu.csMsrStartTime;
  469. //设置开始时间
  470. m_StartTimePara = startTime;
  471. }
  472. //判断信息来源 拍摄样品孔图片 或是 测量开始
  473. if (m_MeasureApp.m_MessageStates == MessageState.ShotBSEPicture)
  474. {
  475. //根据放大倍数、重新绘制帧图信息
  476. m_MeasureApp.m_SamplepaceWindow.showSingleInfo();
  477. }
  478. break;
  479. //测量状态已完成
  480. case OTS_MSR_THREAD_STATUS.COMPLETED:
  481. //当前线程执行类型 1:测量
  482. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNMEASURE)
  483. {
  484. string inprocessEndTime = SMsrData.STMThreadStu.csMsrEndTime;
  485. SetMeasureResultInfo(SMsrData);
  486. MeasureResultMsrData = SMsrData;
  487. m_bgWorker.ReportProgress((int)ProgressState.MeasureCheckReport, SMsrData);
  488. //激活跳转至报告程序按钮
  489. m_MeasureApp.rbPReport.Enabled = true;
  490. m_MeasureApp.rbReport.Enabled = true;
  491. }
  492. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNSampleHoleImage)
  493. {
  494. SetRestoreWorkingDistanceAndMagnification();
  495. }
  496. //测量完成,更新Grid显示的测量信息
  497. m_MeasureApp.m_SPropertyWindows.DisplaySampleMeasureInfo(MeasureInfo);
  498. break;
  499. //测量状态已失败
  500. case OTS_MSR_THREAD_STATUS.FAILED:
  501. //当前线程执行类型 1:测量
  502. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNMEASURE)
  503. {
  504. string failedEndTime = SMsrData.STMThreadStu.csMsrEndTime;
  505. SetMeasureResultInfo(SMsrData);
  506. MeasureResultMsrData = SMsrData;
  507. m_bgWorker.ReportProgress((int)ProgressState.MeasureCheckReport, SMsrData);
  508. }
  509. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNSampleHoleImage)
  510. {
  511. SetRestoreWorkingDistanceAndMagnification();
  512. }
  513. //测量失败,更新Grid显示的测量信息
  514. m_MeasureApp.m_SPropertyWindows.DisplaySampleMeasureInfo(MeasureInfo);
  515. break;
  516. //测量状态已停止
  517. case OTS_MSR_THREAD_STATUS.STOPPED:
  518. //当前线程执行类型 1:测量
  519. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNMEASURE)
  520. {
  521. string stopEndTime = SMsrData.STMThreadStu.csMsrEndTime;
  522. //打开测量结果窗口
  523. SetMeasureResultInfo(SMsrData);
  524. MeasureResultMsrData = SMsrData;
  525. m_bgWorker.ReportProgress((int)ProgressState.MeasureCheckReport, SMsrData);
  526. //激活跳转至报告程序按钮
  527. m_MeasureApp.rbPReport.Enabled = true;
  528. m_MeasureApp.rbReport.Enabled = true;
  529. }
  530. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNSampleHoleImage)
  531. {
  532. SetRestoreWorkingDistanceAndMagnification();
  533. }
  534. //测量停止,更新Grid显示的测量信息
  535. m_MeasureApp.m_SPropertyWindows.DisplaySampleMeasureInfo(MeasureInfo);
  536. break;
  537. }
  538. break;
  539. //测量结果
  540. case ENUM_MSG_TYPE.MSAMPLESTATUS:
  541. //获取测量状态样品信息
  542. OTS_MSR_SAMPLE_STATUS msrSampleStatu = SMsrData.STMSampleStu.iMsrSampleStatu;
  543. switch (msrSampleStatu)
  544. {
  545. case OTS_MSR_SAMPLE_STATUS.INPROCESS:
  546. //当前线程执行类型 1:测量
  547. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNMEASURE)
  548. {
  549. //获取样品名称
  550. string sampleName = SMsrData.STMSampleStu.cSampleName;
  551. //样品测量开始时间
  552. string csSampleMsrStartTime = SMsrData.STMSampleStu.csSampleMsrStartTime;
  553. //设置样品名称
  554. if (sampleName != null)
  555. {
  556. if (sampleName != "")
  557. {
  558. SetSampleName(sampleName);
  559. //设置开始时间
  560. SetStartTime(csSampleMsrStartTime);
  561. m_CurrentSampleName = sampleName;
  562. }
  563. }
  564. //切换样品
  565. m_MeasureApp.Rev_SoluWindowReqSwitchWSample_Event(sampleName);
  566. //设置样品名称
  567. m_OTSMeasureResultWindow.SetSampleName(sampleName);
  568. //填充帧图信息
  569. OTSSamplespaceWindow.ChangeSampleFillSingleInfo(sampleName);
  570. }
  571. else if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNSampleHoleImage)
  572. {
  573. //获取样品名称
  574. string sampleName = SMsrData.STMSampleStu.cSampleName;
  575. //设置样品名称
  576. if (sampleName == null)
  577. {
  578. if (sampleName.Equals(""))
  579. {
  580. if (m_MeasureApp.m_ProjParam.GetWorkSample() != null)
  581. {
  582. sampleName = m_MeasureApp.m_ProjParam.GetWorkSample().GetName();
  583. }
  584. }
  585. }
  586. SetSampleName(sampleName);
  587. }
  588. break;
  589. }
  590. break;
  591. case ENUM_MSG_TYPE.MSAMPLERESULT:
  592. //获取测量状态的Field与BSE信息
  593. MSAMPLE_RET retDataType = SMsrData.STMSampleRetData.iRetDataType;
  594. //判断测量状态提供Field与BSE信息
  595. switch (retDataType)
  596. {
  597. case MSAMPLE_RET.BSE_DATA:
  598. //当前线程执行类型 1:测量
  599. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNMEASURE)
  600. {
  601. //获取显示BSE的图片数据
  602. byte[] ImageData = SMsrData.STMSampleRetData.BSEData.lpBSEData;
  603. //图片宽度
  604. int width = SMsrData.STMSampleRetData.BSEData.iBSEDataWidth;
  605. //图片高度
  606. int height = SMsrData.STMSampleRetData.BSEData.iBSEDataHeight;
  607. //显示状态中的BSE图像控件
  608. if (!m_MeasureApp.m_MessureStatuWindow.pbBSEImage.Visible)
  609. {
  610. m_MeasureApp.m_MessureStatuWindow.pbBSEImage.Visible = true;
  611. }
  612. //调用测量状态TAB中窗体 显示BSE图片
  613. OTSMeasureStatusWindowFun(width, height, ImageData, m_MeasureApp);
  614. }
  615. else if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNSampleHoleImage)
  616. {
  617. //获取显示BSE的图片数据
  618. byte[] ImageData = SMsrData.STMSampleRetData.BSEData.lpBSEData;
  619. //图片宽度
  620. int width = SMsrData.STMSampleRetData.BSEData.iBSEDataWidth;
  621. //图片高度
  622. int height = SMsrData.STMSampleRetData.BSEData.iBSEDataHeight;
  623. //Field位置
  624. Point fieldPos = SMsrData.STMSampleRetData.BSEData.pos;
  625. //设置样品孔中BSE图像信息
  626. SetHoleBSEImageData(ImageData, width, height, fieldPos);
  627. }
  628. break;
  629. case MSAMPLE_RET.FIELD_DATA:
  630. //当前线程执行类型 1:测量
  631. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNMEASURE)
  632. {
  633. //设置测量当前用时
  634. if (SMsrData.STMSampleRetData.SFieldData.TUsedTime != null)
  635. {
  636. SetMeasureTime(SMsrData.STMSampleRetData.SFieldData.TUsedTime);
  637. }
  638. MeasureStateProgressInfo(SMsrData.STMSampleRetData.SFieldData);
  639. ChangeDoneMeasureState(SMsrData.STMSampleRetData.SFieldData.FieldPos, Color.Green);
  640. m_OTSSamplespaceWindow.Invalidate();
  641. }
  642. break;
  643. case MSAMPLE_RET.START_MSR_FIELD:
  644. //当前线程执行类型 1:测量
  645. if (runThreadType == (int)MSR_THREAD_RunSTATUS.RUNMEASURE)
  646. {
  647. ChangeDoneMeasureState(SMsrData.STMSampleRetData.SMsrField.FieldPos, Color.Yellow);
  648. //log.Warn("turn yellow!");
  649. m_OTSSamplespaceWindow.Invalidate();
  650. }
  651. break;
  652. }
  653. break;
  654. }
  655. }
  656. catch (Exception ex)
  657. {
  658. log.Error("RunMeasureState--错误信息:"+ ex.ToString());
  659. }
  660. }
  661. #endregion
  662. #region 设置原放大倍数与工作距离
  663. protected void SetRestoreWorkingDistanceAndMagnification()
  664. {
  665. //设置原放大倍数
  666. double m_SEMIWDistance = OTSSamplespaceWindow.m_SEMIWDistance;
  667. double m_SEMDMagni = OTSSamplespaceWindow.m_SEMDMagni;
  668. double m_PropIWDistance = OTSSamplespaceWindow.m_PropIWDistance;
  669. double m_PropDMagni = OTSSamplespaceWindow.m_PropDMagni;
  670. if (m_PropIWDistance != 0 && m_PropDMagni != 0)
  671. {
  672. m_MeasureApp.m_ProjParam.SetWorkingSampleSEMData(m_PropIWDistance, m_PropDMagni);
  673. }
  674. m_MeasureApp.m_SamplepaceWindow.SetSEMDATAMParameter(m_SEMDMagni,m_SEMIWDistance);
  675. }
  676. #endregion
  677. }
  678. }