OTSMeasureDisplayResult.cs 34 KB

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