OTSSampleData.cs 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466
  1. using OTSDataType;
  2. using OTSModelSharp.ResourceManage;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Drawing;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading;
  9. using System.Threading.Tasks;
  10. namespace OTSMeasureApp
  11. {
  12. enum OTS_X_AXIS_DIRECTION
  13. {
  14. LEFT_TOWARD = 0,
  15. RIGHT_TOWARD = 1
  16. };
  17. enum OTS_Y_AXIS_DIRECTION
  18. {
  19. UP_TOWARD = 0,
  20. DOWN_TOWARD = 1
  21. };
  22. //样品孔信息,包括样品孔名称,样品孔形状,样品口坐标
  23. public class OTSSampleHoleInfo
  24. {
  25. public String sSHoleName; //样品孔名称
  26. public int iSHoleShape; // 样品口形状 1: 矩形; 0: 圆形
  27. // public Point sSHoleStartPoint; // 样品孔起点坐标
  28. // public Point sSHoleEndPoint; //样品孔终点坐标
  29. public Rectangle HoleRect; //样品孔大小
  30. }
  31. // 用于绘制样品台的数据
  32. public class StageDrawingData
  33. {
  34. public StageDrawingData()
  35. {
  36. sSHoleInfoList = new List<OTSSampleHoleInfo>();
  37. }
  38. //绘制样品台形状信息
  39. //样品台名称
  40. public String sStageName; //样品台名称
  41. public int bStageShape; // 样品台形状。 1: 矩形; 0: 圆形
  42. // public Point PSStageStartPos; //样品台起点坐标
  43. // public Point PSStageEndPos; //样品台终点坐标
  44. public Rectangle StageDomain; //样品台的大小
  45. public int bSampleShape; //标样形状 1: 矩形; 0: 圆形
  46. // public Point PSSampleStartPos; // 标样起点坐标
  47. // public Point PSSampleEndPos; //
  48. public Rectangle SampleRect; //标样大小
  49. public List<OTSSampleHoleInfo> sSHoleInfoList; //样品孔信息List
  50. //绘制样品台坐标信息
  51. public int iScanFieldSize100; //放大倍数为100倍时的屏幕尺寸
  52. public int iXAxisDir; // X轴方向 ,参看 enum OTS_X_AXIS_DIRECTION
  53. public int iXAxisStartVal; //X轴起点值
  54. public int iXAxisEndVal; //X轴终点值
  55. public int iYAxisDir; //Y轴方向,,参看enum OTS_Y_AXIS_DIRECTION
  56. public int iYAxisStartVal; //Y轴起点值
  57. public int iYAxisEndVal; //Y轴终点值.
  58. }
  59. public class TestSampleInfo
  60. {
  61. OTSIncAMeasureAppForm m_MeasureApp = null;
  62. public TestSampleInfo(OTSIncAMeasureAppForm Mapp)
  63. {
  64. m_MeasureApp = Mapp;
  65. }
  66. // 测试标题栏的显示
  67. public OTSSamplePropertyInfo TestShowGrid(String sSampleName,bool bFlag=false)
  68. {
  69. OTSSamplePropertyInfo m_SMInfo = new OTSSamplePropertyInfo();
  70. m_SMInfo.sSampleSoluName = "Project";
  71. //样品名
  72. SamplePropertyData sData = new SamplePropertyData();
  73. sData.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.SAMPLE_NAME;
  74. sData.iSampleValType = OTS_ITEM_TYPES.STRING;
  75. sData.sSCaptionName = "样品名";
  76. sData.SampleVal = sSampleName;
  77. sData.bReadOnly = true;
  78. m_SMInfo.SampleDataList.Add(sData);
  79. //样品孔名称
  80. SamplePropertyData sData1 = new SamplePropertyData();
  81. sData1.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.SAMPLE_HOLE_NAME;
  82. sData1.iSampleValType = OTS_ITEM_TYPES.STRING;
  83. sData1.sSCaptionName = "样品孔名称";
  84. sData1.SampleVal = "样品孔1";
  85. sData1.bReadOnly = true;
  86. m_SMInfo.SampleDataList.Add(sData1);
  87. //Switch
  88. SamplePropertyData sData2 = new SamplePropertyData();
  89. sData2.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.SWITCH;
  90. sData2.iSampleValType = OTS_ITEM_TYPES.BOOL;
  91. sData2.sSCaptionName = "开关";
  92. if((string)sData.SampleVal == "Sample3" || (string)sData.SampleVal == "Sample4" || (string)sData.SampleVal == "Sample2")
  93. {
  94. sData2.SampleVal = true;
  95. m_SMInfo.bSwitch = true;
  96. }
  97. else
  98. {
  99. sData2.SampleVal = bFlag;
  100. m_SMInfo.bSwitch = false;
  101. }
  102. m_SMInfo.SampleDataList.Add(sData2);
  103. //样品测量参数文件名
  104. SamplePropertyData sData3 = new SamplePropertyData();
  105. sData3.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.MEASURE_PARAM_FILE_NAME;
  106. sData3.iSampleValType = OTS_ITEM_TYPES.COMBO;
  107. sData3.sSCaptionName = "样品测量参数文件名";
  108. List<string> m_FileList = new List<string>();
  109. m_FileList.Add("文件1");
  110. m_FileList.Add("文件2");
  111. m_FileList.Add("文件3");
  112. m_FileList.Add("文件4");
  113. sData3.SampleVal = m_FileList;
  114. m_SMInfo.SampleDataList.Add(sData3);
  115. //颗粒分析标准库名
  116. SamplePropertyData sData4 = new SamplePropertyData();
  117. sData4.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.STD_FILE_NAME;
  118. sData4.iSampleValType = OTS_ITEM_TYPES.COMBO;
  119. sData4.sSCaptionName = "颗粒分析标准库名";
  120. // sData4.SampleVal = "\\Config\\SysData\\OTSStage.stg";
  121. List<string> m_LibList = new List<string>();
  122. m_LibList.Add("标准库1");
  123. m_LibList.Add("标准库2");
  124. m_LibList.Add("标准库3");
  125. m_LibList.Add("标准库4");
  126. sData4.SampleVal = m_LibList;
  127. m_SMInfo.SampleDataList.Add(sData4);
  128. //图像扫描参数组(Image)
  129. //开始模式
  130. SamplePropertyData sData5 = new SamplePropertyData();
  131. sData5.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.START_MODE;
  132. sData5.iSampleValType = OTS_ITEM_TYPES.COMBO;
  133. sData5.sSCaptionName = "开始模式";
  134. List<string> m_ValList = new List<string>();
  135. m_ValList.Add("中心");
  136. m_ValList.Add("自上而下");
  137. m_ValList.Add("自下而上");
  138. m_ValList.Add("随机");
  139. sData5.SampleVal = m_ValList;
  140. m_SMInfo.SampleDataList.Add(sData5);
  141. //停止模式
  142. SamplePropertyData sData6 = new SamplePropertyData();
  143. sData6.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.STOP_MODE;
  144. sData6.iSampleValType = OTS_ITEM_TYPES.COMBO;
  145. sData6.sSCaptionName = "停止模式";
  146. List<string> m_ValList1 = new List<string>();
  147. m_ValList1.Add("覆盖测量区域");
  148. m_ValList1.Add("幁图数");
  149. m_ValList1.Add("颗粒数");
  150. m_ValList1.Add("时间");
  151. sData6.SampleVal = m_ValList1;
  152. m_SMInfo.SampleDataList.Add(sData6);
  153. //扫描速度
  154. SamplePropertyData sData7 = new SamplePropertyData();
  155. sData7.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.SCAN_SPEED;
  156. sData7.iSampleValType = OTS_ITEM_TYPES.COMBO;
  157. sData7.sSCaptionName = "停止模式";
  158. List<string> m_ValList2 = new List<string>();
  159. m_ValList2.Add("高");
  160. m_ValList2.Add("中");
  161. m_ValList2.Add("低");
  162. sData7.SampleVal = m_ValList2;
  163. m_SMInfo.SampleDataList.Add(sData7);
  164. //扫描图尺寸
  165. SamplePropertyData sData8 = new SamplePropertyData();
  166. sData8.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.IMAGE_RESOLUTION;
  167. sData8.iSampleValType = OTS_ITEM_TYPES.COMBO;
  168. sData8.sSCaptionName = "扫描图尺寸";
  169. List<string> m_ValList3 = new List<string>();
  170. m_ValList3.Add("点扫描");
  171. m_ValList3.Add("面扫描");
  172. sData8.SampleVal = m_ValList3;
  173. m_SMInfo.SampleDataList.Add(sData8);
  174. // 图像处理参数(Image Process)
  175. //颗粒面积最小范围
  176. SamplePropertyData sData9 = new SamplePropertyData();
  177. sData9.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.PARTICLE_AREA_MIN;
  178. sData9.iSampleValType = OTS_ITEM_TYPES.INT;
  179. sData9.sSCaptionName = "颗粒面积最小范围";
  180. sData9.SampleVal = 10;
  181. m_SMInfo.SampleDataList.Add(sData9);
  182. //颗粒面积最大范围
  183. SamplePropertyData sData10 = new SamplePropertyData();
  184. sData10.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.PARTICLE_AREA_MAX;
  185. sData10.iSampleValType = OTS_ITEM_TYPES.INT;
  186. sData10.sSCaptionName = "颗粒面积最大范围";
  187. sData10.SampleVal = 50;
  188. m_SMInfo.SampleDataList.Add(sData10);
  189. //背景灰度最小范围
  190. SamplePropertyData sData11 = new SamplePropertyData();
  191. sData11.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.BG_GRAY_MIN;
  192. sData11.iSampleValType = OTS_ITEM_TYPES.INT;
  193. sData11.sSCaptionName = "背景灰度最小范围";
  194. sData11.SampleVal = 20;
  195. m_SMInfo.SampleDataList.Add(sData11);
  196. //背景灰度最大范围
  197. SamplePropertyData sData12 = new SamplePropertyData();
  198. sData12.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.BG_GRAY_MAX;
  199. sData12.iSampleValType = OTS_ITEM_TYPES.INT;
  200. sData12.sSCaptionName = "背景灰度最大范围";
  201. sData12.SampleVal = 60;
  202. m_SMInfo.SampleDataList.Add(sData12);
  203. //颗粒灰度最小范围
  204. SamplePropertyData sData13 = new SamplePropertyData();
  205. sData13.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.BG_GRAY_MAX;
  206. sData13.iSampleValType = OTS_ITEM_TYPES.INT;
  207. sData13.sSCaptionName = "颗粒灰度最小范围";
  208. sData13.SampleVal = 30;
  209. m_SMInfo.SampleDataList.Add(sData13);
  210. //颗粒灰度最大范围
  211. SamplePropertyData sData14 = new SamplePropertyData();
  212. sData14.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.BG_GRAY_MAX;
  213. sData14.iSampleValType = OTS_ITEM_TYPES.INT;
  214. sData14.sSCaptionName = "颗粒灰度最大范围";
  215. sData14.SampleVal = 70;
  216. m_SMInfo.SampleDataList.Add(sData14);
  217. //x-ray参数组(x-ray)
  218. //搜索x-ray精度
  219. SamplePropertyData sData15 = new SamplePropertyData();
  220. sData15.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.SEARCH_RESOLUTION;
  221. sData15.iSampleValType = OTS_ITEM_TYPES.COMBO;
  222. sData15.sSCaptionName = "搜索x-ray精度";
  223. List<string> m_ValList4 = new List<string>();
  224. m_ValList4.Add("低");
  225. m_ValList4.Add("中");
  226. m_ValList4.Add("高");
  227. // m_ValList3.Add("时间");
  228. sData15.SampleVal = m_ValList4;
  229. m_SMInfo.SampleDataList.Add(sData15);
  230. //x - ray最低计数
  231. SamplePropertyData sData16 = new SamplePropertyData();
  232. sData16.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.LOW_COUNTS;
  233. sData16.iSampleValType = OTS_ITEM_TYPES.INT;
  234. sData16.sSCaptionName = "XRay最低计数";
  235. sData16.SampleVal = 100;
  236. m_SMInfo.SampleDataList.Add(sData16);
  237. //分析x-ray精度
  238. SamplePropertyData sData17 = new SamplePropertyData();
  239. sData17.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.ANALYSIS_RESOLUTION;
  240. sData17.iSampleValType = OTS_ITEM_TYPES.COMBO;
  241. sData17.sSCaptionName = "分析XRay精度";
  242. List<string> m_ValList5 = new List<string>();
  243. m_ValList5.Add("低");
  244. m_ValList5.Add("中");
  245. m_ValList5.Add("高");
  246. // m_ValList3.Add("时间");
  247. sData17.SampleVal = m_ValList5;
  248. m_SMInfo.SampleDataList.Add(sData17);
  249. // x-ray扫描方式
  250. SamplePropertyData sData18 = new SamplePropertyData();
  251. sData18.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.SCAN_MODE;
  252. sData18.iSampleValType = OTS_ITEM_TYPES.COMBO;
  253. sData18.sSCaptionName = "XRay扫描方式";
  254. List<string> m_ValList6 = new List<string>();
  255. m_ValList6.Add("点扫描");
  256. m_ValList6.Add("面扫描");
  257. //m_ValList6.Add("高");
  258. // m_ValList3.Add("时间");
  259. sData18.SampleVal = m_ValList6;
  260. m_SMInfo.SampleDataList.Add(sData18);
  261. //分析x-ray计数期望值
  262. SamplePropertyData sData19 = new SamplePropertyData();
  263. sData19.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.ANALYSIS_COUNTS;
  264. sData19.iSampleValType = OTS_ITEM_TYPES.INT;
  265. sData19.sSCaptionName = "分析XRay计数期望值";
  266. sData19.SampleVal = 800;
  267. m_SMInfo.SampleDataList.Add(sData19);
  268. //SEM工作参数组(SEM Data)
  269. //放大倍数
  270. SamplePropertyData sData20 = new SamplePropertyData();
  271. sData20.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.MAGNIFICATION;
  272. sData20.iSampleValType = OTS_ITEM_TYPES.STRING;
  273. sData20.sSCaptionName = "放大倍数";
  274. sData20.SampleVal = "100";
  275. m_SMInfo.SampleDataList.Add(sData20);
  276. //测量精度
  277. SamplePropertyData sData21 = new SamplePropertyData();
  278. sData21.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.PIXEL_SIZE;
  279. sData21.iSampleValType = OTS_ITEM_TYPES.STRING;
  280. sData21.sSCaptionName = "测量精度";
  281. sData21.SampleVal = "高精度";
  282. m_SMInfo.SampleDataList.Add(sData21);
  283. //工作距离
  284. SamplePropertyData sData22 = new SamplePropertyData();
  285. sData22.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.WORKING_DISTANCE;
  286. sData22.iSampleValType = OTS_ITEM_TYPES.STRING;
  287. sData22.sSCaptionName = "工作距离";
  288. sData22.SampleVal = "200";
  289. m_SMInfo.SampleDataList.Add(sData22);
  290. //覆盖测量区域帧图数
  291. SamplePropertyData sData23 = new SamplePropertyData();
  292. sData23.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.TOTAL_FIELDS;
  293. sData23.iSampleValType = OTS_ITEM_TYPES.STRING;
  294. sData23.sSCaptionName = "覆盖测量区域帧图数";
  295. sData23.SampleVal = "4000";
  296. m_SMInfo.SampleDataList.Add(sData23);
  297. //样品测量状态(Measure status)
  298. //测量状态
  299. SamplePropertyData sData24 = new SamplePropertyData();
  300. sData24.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.MEASURE_STATAU;
  301. sData24.iSampleValType = OTS_ITEM_TYPES.STRING;
  302. sData24.sSCaptionName = "测量状态";
  303. sData24.SampleVal = "未测量";
  304. m_SMInfo.SampleDataList.Add(sData24);
  305. //测量开始时间
  306. DateTime dt = DateTime.Now;
  307. String sDate = dt.ToString();
  308. // MessageBox.Show(sDate);
  309. SamplePropertyData sData25 = new SamplePropertyData();
  310. sData25.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.START_TIME;
  311. sData25.iSampleValType = OTS_ITEM_TYPES.STRING;
  312. sData25.sSCaptionName = "测量开始事件";
  313. sData25.SampleVal = sDate;
  314. m_SMInfo.SampleDataList.Add(sData25);
  315. //Thread.Sleep(1000);
  316. //已经测量时间
  317. DateTime dt1 = DateTime.Now;
  318. String sDate1 = this.DateDiff(dt1, dt);
  319. // MessageBox.Show(sDate);
  320. SamplePropertyData sData26 = new SamplePropertyData();
  321. sData26.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.USED_TIME;
  322. sData26.iSampleValType = OTS_ITEM_TYPES.STRING;
  323. sData26.sSCaptionName = "已经测量时间";
  324. sData26.SampleVal = sDate1;
  325. m_SMInfo.SampleDataList.Add(sData26);
  326. //完成时间
  327. SamplePropertyData sData27 = new SamplePropertyData();
  328. sData27.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.FINISH_TIME;
  329. sData27.iSampleValType = OTS_ITEM_TYPES.STRING;
  330. sData27.sSCaptionName = "完成时间";
  331. sData27.SampleVal = dt1.ToString();
  332. m_SMInfo.SampleDataList.Add(sData27);
  333. //完成幁图数
  334. SamplePropertyData sData28 = new SamplePropertyData();
  335. sData28.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.COMPLETED_FIELDS;
  336. sData28.iSampleValType = OTS_ITEM_TYPES.INT;
  337. sData28.sSCaptionName = "完成幁图数";
  338. sData28.SampleVal = 1800;
  339. m_SMInfo.SampleDataList.Add(sData28);
  340. //样品测量结果(Measure Result)
  341. //比率
  342. SamplePropertyData sData29 = new SamplePropertyData();
  343. sData29.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.RATIO;
  344. sData29.iSampleValType = OTS_ITEM_TYPES.DOUBLE;
  345. sData29.sSCaptionName = "比率";
  346. sData29.SampleVal = 3.14;
  347. m_SMInfo.SampleDataList.Add(sData29);
  348. //测量面积
  349. SamplePropertyData sData30 = new SamplePropertyData();
  350. sData30.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.TOTAL_AREA;
  351. sData30.iSampleValType = OTS_ITEM_TYPES.DOUBLE;
  352. sData30.sSCaptionName = "测量面积";
  353. sData30.SampleVal = 120;
  354. m_SMInfo.SampleDataList.Add(sData30);
  355. //颗粒数
  356. SamplePropertyData sData31 = new SamplePropertyData();
  357. sData31.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.TOTAL_PARTICLE;
  358. sData31.iSampleValType = OTS_ITEM_TYPES.INT;
  359. sData31.sSCaptionName = "颗粒数";
  360. sData31.SampleVal = 8000;
  361. m_SMInfo.SampleDataList.Add(sData31);
  362. //颗粒面积
  363. SamplePropertyData sData32 = new SamplePropertyData();
  364. sData32.iSampleId = OTS_SAMPLE_PROP_GRID_ITEMS.TOTAL_PARTICLE_AREA;
  365. sData32.iSampleValType = OTS_ITEM_TYPES.DOUBLE;
  366. sData32.sSCaptionName = "颗粒面积";
  367. sData32.SampleVal = 8000;
  368. m_SMInfo.SampleDataList.Add(sData32);
  369. return m_SMInfo;
  370. }
  371. //获取两个时间差
  372. private string DateDiff(DateTime DateTime1, DateTime DateTime2)
  373. {
  374. string dateDiff = null;
  375. try
  376. {
  377. TimeSpan ts1 = new TimeSpan(DateTime1.Ticks);
  378. TimeSpan ts2 = new TimeSpan(DateTime2.Ticks);
  379. TimeSpan ts = ts1.Subtract(ts2).Duration();
  380. dateDiff = ts.Days.ToString() + "天"
  381. + ts.Hours.ToString() + "小时"
  382. + ts.Minutes.ToString() + "分钟"
  383. + ts.Seconds.ToString() + "秒";
  384. }
  385. catch
  386. {
  387. }
  388. return dateDiff;
  389. }
  390. }
  391. }