OTSSample.cpp 55 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211
  1. // OTSSample.cpp : implementation file
  2. //
  3. #include "stdafx.h"
  4. #include "OTSData.h"
  5. #include "OTSSample.h"
  6. #include "OTSDATAresource.h"
  7. #include "MultiLang.h"
  8. namespace OTSMODEL {
  9. //using namespace std;
  10. using namespace OTSDATA;
  11. // constructor
  12. COTSSample::COTSSample()
  13. {
  14. // initialization
  15. Init();
  16. }
  17. // copy constructor
  18. COTSSample::COTSSample(const COTSSample& a_oSource)
  19. {
  20. // can't copy itself
  21. if (&a_oSource == this)
  22. {
  23. return;
  24. }
  25. // copy data over
  26. Duplicate(a_oSource);
  27. }
  28. // copy constructor
  29. COTSSample::COTSSample(COTSSample* a_poSource)
  30. {
  31. // input check
  32. ASSERT(a_poSource);
  33. if (!a_poSource)
  34. {
  35. return;
  36. }
  37. // can't copy itself
  38. if (a_poSource == this)
  39. {
  40. return;
  41. }
  42. // copy data over
  43. Duplicate(*a_poSource);
  44. }
  45. // =operator
  46. COTSSample& COTSSample::operator=(const COTSSample& a_oSource)
  47. {
  48. // cleanup
  49. Cleanup();
  50. // copy the class data over
  51. Duplicate(a_oSource);
  52. // return class
  53. return *this;
  54. }
  55. // destructor
  56. COTSSample::~COTSSample()
  57. {
  58. // cleanup
  59. Cleanup();
  60. }
  61. // ==operator
  62. BOOL COTSSample::operator==(const COTSSample& a_oSource)
  63. {
  64. return m_strName.Compare(a_oSource.m_strName) == 0 &&
  65. m_strHoleName == a_oSource.m_strHoleName &&
  66. m_bParamLock == a_oSource.m_bParamLock &&
  67. m_bSwitch == a_oSource.m_bSwitch &&
  68. *(m_poMsrParams.get()) == *(a_oSource.m_poMsrParams.get()) &&
  69. *(m_poMsrArea.get()) == *(a_oSource.m_poMsrArea.get()) &&
  70. *(m_poSEMDataMsr.get()) == *(a_oSource.m_poSEMDataMsr.get()) &&
  71. *(m_poMsrStatus.get()) == *(a_oSource.m_poMsrStatus.get()) &&
  72. *(m_poMsrResults.get()) == *(a_oSource.m_poMsrResults.get());
  73. }
  74. // COTSSample member functions
  75. // public
  76. // serialization
  77. void COTSSample::Serialize(bool isStoring, tinyxml2::XMLDocument * classDoc, tinyxml2::XMLElement * rootNode)
  78. {
  79. xmls::xString xstrName;
  80. xmls::xString xstrHoleName;
  81. xmls::xBool xbParamlock;
  82. xmls::xBool xbSwitch;
  83. xmls::Slo slo;
  84. slo.Register("SampleName", &xstrName);
  85. slo.Register("HoleName", &xstrHoleName);
  86. slo.Register("ParamLock", &xbParamlock);
  87. slo.Register("Switch", &xbSwitch);
  88. slo.Register("MsrParams", m_poMsrParams.get());
  89. slo.Register("MsrArea", m_poMsrArea.get());
  90. slo.Register("SEMDataMsr", m_poSEMDataMsr.get());
  91. /*slo.Register("MsrStatus", m_poMsrStatus.get());
  92. slo.Register("MsrResults", m_poMsrResults.get());*/
  93. if (isStoring)
  94. {
  95. xstrName = m_strName;
  96. xstrHoleName = m_strHoleName;
  97. xbParamlock = m_bParamLock;
  98. xbSwitch = m_bSwitch;
  99. slo.Serialize(true, classDoc, rootNode);
  100. }
  101. else
  102. {
  103. slo.Serialize(false, classDoc, rootNode);
  104. m_strName = xstrName.value().c_str();
  105. m_strHoleName = xstrHoleName.value().c_str();
  106. m_bParamLock = xbParamlock.value();
  107. m_bSwitch = xbSwitch.value();
  108. }
  109. }
  110. // measurement parameter
  111. void COTSSample::SetMsrParams(CMsrParamsPtr a_poMsrParams)
  112. {
  113. // make sure that measure parameters is always valid
  114. if(!a_poMsrParams)
  115. {
  116. m_poMsrParams = CMsrParamsPtr(new CMsrParams());
  117. }
  118. else
  119. {
  120. m_poMsrParams = CMsrParamsPtr(new CMsrParams(a_poMsrParams.get()));
  121. }
  122. }
  123. // measurement area
  124. void COTSSample::SetMsrArea(CDomainPtr a_poMsrArea)
  125. {
  126. // make sure that measure area is always valid
  127. if (!a_poMsrArea)
  128. {
  129. m_poMsrArea = CDomainPtr(new CDomain());
  130. }
  131. else
  132. {
  133. m_poMsrArea = CDomainPtr(new CDomain(a_poMsrArea.get()));
  134. }
  135. }
  136. // SEM data (measurement)
  137. void COTSSample::SetSEMDataMsr(CSEMDataMsrPtr a_poSEMDataMsr)
  138. {
  139. // make sure that measure SEM data is always valid
  140. if (!a_poSEMDataMsr)
  141. {
  142. m_poSEMDataMsr = CSEMDataMsrPtr(new CSEMDataMsr());
  143. }
  144. else
  145. {
  146. m_poSEMDataMsr = CSEMDataMsrPtr(new CSEMDataMsr(a_poSEMDataMsr.get()));
  147. }
  148. }
  149. // measure status
  150. void COTSSample::SetMsrStatus(CMsrSampleStatusPtr a_poMsrStatus)
  151. {
  152. // make sure that measure status is always valid
  153. if (!a_poMsrStatus)
  154. {
  155. m_poMsrStatus = CMsrSampleStatusPtr(new CMsrSampleStatus());
  156. }
  157. else
  158. {
  159. m_poMsrStatus = CMsrSampleStatusPtr(new CMsrSampleStatus(a_poMsrStatus.get()));
  160. }
  161. }
  162. // measure results
  163. void COTSSample::SetMsrResults(CMsrResultsPtr a_poMsrResults)
  164. {
  165. // make sure that measure results is always valid
  166. if (!a_poMsrResults)
  167. {
  168. m_poMsrResults = CMsrResultsPtr(new CMsrResults());
  169. }
  170. else
  171. {
  172. m_poMsrResults = CMsrResultsPtr(new CMsrResults(a_poMsrResults.get()));
  173. }
  174. }
  175. // fields
  176. void COTSSample::SetFieldsData(COTSFieldDataList& a_listFieldData)
  177. {
  178. m_listFieldData.clear();
  179. for (auto pFieldData : a_listFieldData)
  180. {
  181. //COTSFieldDataPtr pFieldDataNew = COTSFieldDataPtr(new COTSFieldData(*pFieldData.get()));
  182. COTSFieldDataPtr pFieldDataNew = pFieldData;
  183. m_listFieldData.push_back(pFieldDataNew);
  184. }
  185. }
  186. // has measure results test
  187. BOOL COTSSample::HasMeasureResult()
  188. {
  189. // result items is not empty
  190. BOOL bHasResult = !(m_poMsrResults->GetResultItems().empty());
  191. return bHasResult;
  192. }
  193. // property item groups list
  194. void COTSSample::SetPropItemGrps()
  195. {
  196. // clean the list and all items in it
  197. for (auto poItemGroup : m_listPropItemGrps)
  198. {
  199. poItemGroup->GetItemsList().clear();
  200. }
  201. m_listPropItemGrps.clear();
  202. // add item groups
  203. for (int i = (int)OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::MIN; i <= (int)OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::MAX; i++)
  204. {
  205. // create a property items group
  206. CPropItemGrpPtr poItemGroup = SetPropertyItemGrp((OTS_SAMPLE_PROP_GRID_ITEM_GROUPS)i);
  207. // add property items group into property item groups list
  208. if(poItemGroup)
  209. {
  210. m_listPropItemGrps.push_back(poItemGroup);
  211. }
  212. }
  213. }
  214. CPropItemGrpPtr COTSSample::GetPropItemGrpByIndex(int a_nIndex)
  215. {
  216. CPropItemGrpPtr poPropItemGrp = nullptr;
  217. if (0 < a_nIndex || a_nIndex < (int)m_listPropItemGrps.size())
  218. {
  219. poPropItemGrp = m_listPropItemGrps[a_nIndex];
  220. }
  221. return poPropItemGrp;
  222. }
  223. CPropItemGrpPtr COTSSample::GetPropItemGrpById(OTS_SAMPLE_PROP_GRID_ITEM_GROUPS a_nId)
  224. {
  225. CPropItemGrpPtr poPropItemGrp = nullptr;
  226. auto itr = std::find_if(m_listPropItemGrps.begin(), m_listPropItemGrps.end(), [a_nId](CPropItemGrpPtr& p) { return p->GetGroupId() == a_nId; });
  227. if (itr != m_listPropItemGrps.end())
  228. {
  229. // found the property item group
  230. poPropItemGrp = *itr;
  231. }
  232. return poPropItemGrp;
  233. }
  234. CPropItemGrpPtr COTSSample::UpdatePropItemGrp(OTS_SAMPLE_PROP_GRID_ITEM_GROUPS a_nId)
  235. {
  236. CPropItemGrpPtr poPropItemGrp = nullptr;
  237. auto itr = std::find_if(m_listPropItemGrps.begin(), m_listPropItemGrps.end(), [a_nId](CPropItemGrpPtr& p) { return p->GetGroupId() == a_nId; });
  238. if (itr != m_listPropItemGrps.end())
  239. {
  240. // found the property item group
  241. poPropItemGrp = *itr;
  242. // create a property items group
  243. CPropItemGrpPtr poItemGroupNew = SetPropertyItemGrp(a_nId);
  244. // update the property item group
  245. if (poItemGroupNew)
  246. {
  247. *(poPropItemGrp.get()) = *(poItemGroupNew.get());
  248. }
  249. }
  250. return poPropItemGrp;
  251. }
  252. CPropItemPtr COTSSample::GetPropItemById(OTS_SAMPLE_PROP_GRID_ITEMS a_nId)
  253. {
  254. CPropItemPtr pPropItem = nullptr;
  255. if (m_listPropItemGrps.size() > 0)
  256. {
  257. for (auto poPropItemGrp : m_listPropItemGrps)
  258. {
  259. CPropItemsList& listPropItems = poPropItemGrp->GetItemsList();
  260. auto itr = std::find_if(listPropItems.begin(), listPropItems.end(), [a_nId](CPropItemPtr& poPropItem) { return poPropItem->GetSmplItemId() == a_nId; });
  261. if (listPropItems.size() > 0)
  262. {
  263. if (itr != listPropItems.end())
  264. {
  265. // found the property item
  266. pPropItem = *itr;
  267. }
  268. }
  269. }
  270. }
  271. return pPropItem;
  272. }
  273. CString COTSSample::GetItemValueStr(OTS_SAMPLE_PROP_GRID_ITEMS ItemID)
  274. {
  275. //CString strItemID = ItemId;
  276. CString valStr="";
  277. CPropItemPtr itm = this->GetPropItemById(ItemID);
  278. switch ((OTS_ITEM_TYPES)itm->GetTypeId())
  279. {
  280. case OTS_ITEM_TYPES::BOOL:
  281. {
  282. BOOL bflag;
  283. if (GetPropBOOLData(ItemID, bflag))
  284. {
  285. valStr.Format(_T("%d"), bflag);
  286. /*valStr = CString(bflag.ToString());*/
  287. }
  288. }
  289. break;
  290. case OTS_ITEM_TYPES::INT:
  291. {
  292. int iVal = 0;
  293. if (GetPropIntData(ItemID, iVal))
  294. {
  295. valStr .Format(_T("%d"),iVal);
  296. }
  297. }
  298. break;
  299. case OTS_ITEM_TYPES::DOUBLE:
  300. {
  301. DOUBLE dVal = 0;
  302. if (GetPropDoubleData(ItemID, dVal))
  303. {
  304. valStr.Format (_T("%.2f"),dVal);//µãºóÃæ¼¸¸ö0¾Í±£Áô¼¸Î»
  305. }
  306. }
  307. break;
  308. case OTS_ITEM_TYPES::STRING:
  309. {
  310. CString StrVal = "";
  311. if (GetPropStringData(ItemID,StrVal))
  312. {
  313. valStr = StrVal;
  314. }
  315. }
  316. break;
  317. case OTS_ITEM_TYPES::COMBO:
  318. {
  319. std::vector <CString> StrVal ;
  320. if (GetPropComboStrings(ItemID, StrVal))
  321. {
  322. int index = 0;
  323. GetPropComboData(ItemID, index);
  324. if (index > (int)StrVal.size())
  325. {
  326. valStr = StrVal[0];
  327. break;
  328. }
  329. valStr = StrVal[index];
  330. }
  331. }
  332. break;
  333. case OTS_ITEM_TYPES::TIME:
  334. {
  335. COleDateTime dt ;
  336. if (GetPropTimeData(ItemID, dt))
  337. {
  338. valStr = dt.Format("%Y-%m-%d %H:%M:%S");
  339. }
  340. }
  341. break;
  342. case OTS_ITEM_TYPES::TIME_SPAN:
  343. {
  344. COleDateTimeSpan TimeSpanValue ;
  345. if (GetPropTimeSpanData(ItemID, TimeSpanValue))
  346. {
  347. int v = (int)TimeSpanValue.GetTotalSeconds();
  348. valStr.Format(_T("%d"), v);
  349. }
  350. }
  351. break;
  352. case OTS_ITEM_TYPES::FILE_LIST:
  353. {
  354. //CMsrParams object represent a project param file. It includes PartSTD file ImgProcessParam ImgScanParam XrayParam four parts content.
  355. int iPos = -1;
  356. std::vector <CString> sFileNameList ;
  357. if (OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_PARAM_FILE_NAME == (OTS_SAMPLE_PROP_GRID_ITEMS)ItemID)
  358. {
  359. valStr = m_poMsrParams->GetName();
  360. }
  361. if (OTS_SAMPLE_PROP_GRID_ITEMS::STD_FILE_NAME == (OTS_SAMPLE_PROP_GRID_ITEMS)ItemID)
  362. {
  363. valStr = m_poMsrParams->GetPartSTDData()->GetName();
  364. }
  365. }
  366. break;
  367. default:
  368. break;
  369. }
  370. return valStr;
  371. }
  372. std::vector<CString> COTSSample::GetItemComboDownList(OTS_SAMPLE_PROP_GRID_ITEMS ItemID)
  373. {
  374. //CString strItemID = ItemId;
  375. std::vector<CString> listStr;
  376. listStr.clear ();
  377. CPropItemPtr itm = this->GetPropItemById(ItemID);
  378. switch ((OTS_ITEM_TYPES)itm->GetTypeId())
  379. {
  380. case OTS_ITEM_TYPES::BOOL:
  381. break;
  382. case OTS_ITEM_TYPES::INT:
  383. break;
  384. case OTS_ITEM_TYPES::DOUBLE:
  385. break;
  386. case OTS_ITEM_TYPES::STRING:
  387. break;
  388. case OTS_ITEM_TYPES::COMBO:
  389. {
  390. if (GetPropComboStrings(ItemID, listStr))
  391. {
  392. }
  393. }
  394. break;
  395. case OTS_ITEM_TYPES::TIME:
  396. break;
  397. case OTS_ITEM_TYPES::TIME_SPAN:
  398. break;
  399. case OTS_ITEM_TYPES::FILE_LIST:
  400. {
  401. }
  402. break;
  403. default:
  404. break;
  405. }
  406. return listStr;
  407. }
  408. // BOOL data
  409. BOOL COTSSample::GetPropBOOLData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, BOOL& a_bValue)
  410. {
  411. switch (a_nId)
  412. {
  413. case OTS_SAMPLE_PROP_GRID_ITEMS::SWITCH:
  414. {
  415. a_bValue = m_bSwitch;
  416. }
  417. break;
  418. default:
  419. {
  420. // something wrong, return FALSE
  421. return FALSE;
  422. }
  423. break;
  424. }
  425. // ok, return TRUE
  426. return TRUE;
  427. }
  428. BOOL COTSSample::SetPropBOOLData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, BOOL a_bValue)
  429. {
  430. switch (a_nId)
  431. {
  432. case OTS_SAMPLE_PROP_GRID_ITEMS::SWITCH:
  433. {
  434. m_bSwitch = a_bValue;
  435. }
  436. break;
  437. default:
  438. {
  439. // something wrong, return FALSE
  440. return FALSE;
  441. }
  442. break;
  443. }
  444. // failed, return FALSE
  445. return TRUE;
  446. }
  447. // int data (16)
  448. BOOL COTSSample::GetPropIntData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, int& a_nValue)
  449. {
  450. switch (a_nId)
  451. {
  452. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_PARTICLE:
  453. {
  454. a_nValue = m_poMsrParams->GetImageScanParam()->GetStopParamParticles();
  455. }
  456. break;
  457. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_FIELD:
  458. {
  459. a_nValue = m_poMsrParams->GetImageScanParam()->GetStopParamFields();
  460. }
  461. break;
  462. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_TIME:
  463. {
  464. a_nValue = m_poMsrParams->GetImageScanParam()->GetStopParamMeasTime();
  465. }
  466. break;
  467. /*case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MIN:
  468. {
  469. a_nValue = m_poMsrParams->GetImageProcessParam()->GetIncArea().GetStart();
  470. }
  471. break;
  472. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MAX:
  473. {
  474. a_nValue = m_poMsrParams->GetImageProcessParam()->GetIncArea().GetEnd();
  475. }
  476. break;*/
  477. case OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MIN:
  478. {
  479. a_nValue = m_poMsrParams->GetImageProcessParam()->GetBGGray().GetStart();
  480. }
  481. break;
  482. case OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MAX:
  483. {
  484. a_nValue = m_poMsrParams->GetImageProcessParam()->GetBGGray().GetEnd();
  485. }
  486. break;
  487. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MIN:
  488. {
  489. a_nValue = m_poMsrParams->GetImageProcessParam()->GetParticleGray().GetStart();
  490. }
  491. break;
  492. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MAX:
  493. {
  494. a_nValue = m_poMsrParams->GetImageProcessParam()->GetParticleGray().GetEnd();
  495. }
  496. break;
  497. case OTS_SAMPLE_PROP_GRID_ITEMS::LOW_COUNTS:
  498. {
  499. a_nValue = m_poMsrParams->GetXRayParam()->GetXRaySearchCount();
  500. }
  501. break;
  502. case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_COUNTS:
  503. {
  504. a_nValue = m_poMsrParams->GetXRayParam()->GetAnalyExpCount();
  505. }
  506. break;
  507. case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_RESOLUTION:
  508. {
  509. a_nValue = (int)m_poMsrParams->GetXRayParam()->GetMidAnalyAQTime();
  510. }
  511. break;
  512. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_FIELDS:
  513. {
  514. a_nValue = m_poSEMDataMsr->GetTotalFields();
  515. }
  516. break;
  517. case OTS_SAMPLE_PROP_GRID_ITEMS::COMPLETED_FIELDS:
  518. {
  519. a_nValue = m_poMsrStatus->GetCompletedFields();
  520. }
  521. break;
  522. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_AREA:
  523. {
  524. a_nValue = m_poMsrResults->GetMeasuredArea();
  525. }
  526. break;
  527. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE:
  528. {
  529. a_nValue = m_poMsrResults->GetTotalParticleNumber();
  530. }
  531. break;
  532. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE_AREA:
  533. {
  534. a_nValue = m_poMsrResults->GetTotalParticleArea();
  535. }
  536. break;
  537. default:
  538. {
  539. // something wrong, return FALSE
  540. return FALSE;
  541. }
  542. break;
  543. }
  544. // ok, return TRUE
  545. return TRUE;
  546. }
  547. BOOL COTSSample::SetPropIntData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, int a_nValue)
  548. {
  549. switch (a_nId)
  550. {
  551. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_PARTICLE:
  552. {
  553. // value validation
  554. if (STOP_PARAM_PARTICLE_MIN > a_nValue || a_nValue > STOP_PARAM_PARTICLE_MAX )
  555. {
  556. return FALSE;
  557. }
  558. if (m_poMsrParams->GetImageScanParam()->GetStopParamParticles() != a_nValue)
  559. {
  560. m_poMsrParams->GetImageScanParam()->SetStopParamParticles(a_nValue);
  561. m_poMsrStatus->SetStatus(OTS_MSR_SAMPLE_STATUS::UNMEASURED);
  562. }
  563. }
  564. break;
  565. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_FIELD:
  566. {
  567. if (STOP_PARAM_FIELD_MIN > a_nValue || a_nValue > STOP_PARAM_FIELD_MAX )
  568. {
  569. return FALSE;
  570. }
  571. if (m_poMsrParams->GetImageScanParam()->GetStopParamFields() != a_nValue)
  572. {
  573. m_poMsrParams->GetImageScanParam()->SetStopParamFields(a_nValue);
  574. m_poMsrStatus->SetStatus(OTS_MSR_SAMPLE_STATUS::UNMEASURED);
  575. }
  576. }
  577. break;
  578. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_TIME:
  579. {
  580. if (STOP_PARAM_MSR_TINE_MIN > a_nValue || a_nValue > STOP_PARAM_MSR_TINE_MAX)
  581. {
  582. return FALSE;
  583. }
  584. if (m_poMsrParams->GetImageScanParam()->GetStopParamMeasTime() != a_nValue)
  585. {
  586. m_poMsrParams->GetImageScanParam()->SetStopParamMeasTime(a_nValue);
  587. m_poMsrStatus->SetStatus(OTS_MSR_SAMPLE_STATUS::UNMEASURED);
  588. }
  589. }
  590. break;
  591. /*case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MIN:
  592. {
  593. if (PARTICLE_AREA_MIN > a_nValue || a_nValue > PARTICLE_AREA_MAX)
  594. {
  595. return FALSE;
  596. }
  597. CIntRange oIncArea = m_poMsrParams->GetImageProcessParam()->GetIncArea();
  598. oIncArea.SetStart(a_nValue);
  599. m_poMsrParams->GetImageProcessParam()->SetIncArea(oIncArea);
  600. }
  601. break;
  602. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MAX:
  603. {
  604. if (PARTICLE_AREA_MIN > a_nValue || a_nValue > PARTICLE_AREA_MAX)
  605. {
  606. return FALSE;
  607. }
  608. CIntRange oIncArea = m_poMsrParams->GetImageProcessParam()->GetIncArea();
  609. oIncArea.SetEnd(a_nValue);
  610. m_poMsrParams->GetImageProcessParam()->SetIncArea(oIncArea);
  611. }
  612. break;*/
  613. case OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MIN:
  614. {
  615. if (GRAY_LEVEL_MIN > a_nValue || a_nValue > GRAY_LEVEL_MAX)
  616. {
  617. return FALSE;
  618. }
  619. if (m_poMsrParams == nullptr)
  620. {
  621. return FALSE;
  622. }
  623. COTSImageProcessParamPtr pImageProcessParam = m_poMsrParams->GetImageProcessParam();
  624. if (pImageProcessParam == nullptr)
  625. {
  626. return FALSE;
  627. }
  628. CIntRange oBGGray = m_poMsrParams->GetImageProcessParam()->GetBGGray();
  629. oBGGray.SetStart(a_nValue);
  630. m_poMsrParams->GetImageProcessParam()->SetBGGray(oBGGray);
  631. }
  632. break;
  633. case OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MAX:
  634. {
  635. if (GRAY_LEVEL_MIN > a_nValue || a_nValue > GRAY_LEVEL_MAX)
  636. {
  637. return FALSE;
  638. }
  639. CIntRange oBGGray = m_poMsrParams->GetImageProcessParam()->GetBGGray();
  640. oBGGray.SetEnd(a_nValue);
  641. m_poMsrParams->GetImageProcessParam()->SetBGGray(oBGGray);
  642. }
  643. break;
  644. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MIN:
  645. {
  646. if (GRAY_LEVEL_MIN > a_nValue || a_nValue > GRAY_LEVEL_MAX)
  647. {
  648. return FALSE;
  649. }
  650. CIntRange oParticleGray = m_poMsrParams->GetImageProcessParam()->GetParticleGray();
  651. oParticleGray.SetStart(a_nValue);
  652. m_poMsrParams->GetImageProcessParam()->SetParticleGray(oParticleGray);
  653. }
  654. break;
  655. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MAX:
  656. {
  657. if (GRAY_LEVEL_MIN > a_nValue || a_nValue > GRAY_LEVEL_MAX)
  658. {
  659. return FALSE;
  660. }
  661. CIntRange oParticleGray = m_poMsrParams->GetImageProcessParam()->GetParticleGray();
  662. oParticleGray.SetEnd(a_nValue);
  663. m_poMsrParams->GetImageProcessParam()->SetParticleGray(oParticleGray);
  664. }
  665. break;
  666. case OTS_SAMPLE_PROP_GRID_ITEMS::LOW_COUNTS:
  667. {
  668. if (COUNTS_MIN > a_nValue)
  669. {
  670. return FALSE;
  671. }
  672. m_poMsrParams->GetXRayParam()->SetXRaySearchCount(a_nValue);
  673. }
  674. break;
  675. case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_COUNTS:
  676. {
  677. if (COUNTS_MIN > a_nValue)
  678. {
  679. return FALSE;
  680. }
  681. m_poMsrParams->GetXRayParam()->SetAnalyExpCount(a_nValue);
  682. }
  683. break;
  684. case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_RESOLUTION:
  685. {
  686. //a_nValue = (int)m_poMsrParams->GetXRayParam()->GetAnalySpeed();
  687. m_poMsrParams->GetXRayParam()->SetMidAnalyAQTime(a_nValue);
  688. }
  689. break;
  690. // read only properties, treat same as default
  691. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_FIELDS:
  692. case OTS_SAMPLE_PROP_GRID_ITEMS::COMPLETED_FIELDS:
  693. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_AREA:
  694. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE:
  695. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE_AREA:
  696. default:
  697. {
  698. // something wrong, return FALSE
  699. return FALSE;
  700. }
  701. break;
  702. }
  703. // ok, return TRUE
  704. return TRUE;
  705. }
  706. // double data (4)
  707. BOOL COTSSample::GetPropDoubleData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, double& a_dValue)
  708. {
  709. switch (a_nId)
  710. {
  711. case OTS_SAMPLE_PROP_GRID_ITEMS::MAGNIFICATION:
  712. {
  713. a_dValue = m_poSEMDataMsr->GetMagnification();
  714. }
  715. break;
  716. case OTS_SAMPLE_PROP_GRID_ITEMS::PIXEL_SIZE:
  717. {
  718. a_dValue = CalculatePixelSize();
  719. }
  720. break;
  721. case OTS_SAMPLE_PROP_GRID_ITEMS::WORKING_DISTANCE:
  722. {
  723. a_dValue = m_poSEMDataMsr->GetWorkingDistance();
  724. }
  725. break;
  726. case OTS_SAMPLE_PROP_GRID_ITEMS::RADIO:
  727. {
  728. a_dValue = m_poMsrResults->GetRadio();
  729. }
  730. break;
  731. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MIN:
  732. {
  733. a_dValue = m_poMsrParams->GetImageProcessParam()->GetIncArea().GetStart();
  734. }
  735. break;
  736. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MAX:
  737. {
  738. a_dValue = m_poMsrParams->GetImageProcessParam()->GetIncArea().GetEnd();
  739. }
  740. break;
  741. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_TO_MEASURE_AREA:
  742. {
  743. DOUBLE dFieldArea = 0; // this area should be the field area
  744. dFieldArea = CalculateAFieldArea();
  745. a_dValue = (DOUBLE)m_poSEMDataMsr->GetTotalFields() * dFieldArea;//
  746. }
  747. break;
  748. default:
  749. {
  750. // something wrong, return FALSE
  751. return FALSE;
  752. }
  753. break;
  754. }
  755. // ok, return TRUE
  756. return TRUE;
  757. }
  758. BOOL COTSSample::SetPropDoubleData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, double a_dValue)
  759. {
  760. switch (a_nId)
  761. {
  762. case OTS_SAMPLE_PROP_GRID_ITEMS::MAGNIFICATION:
  763. {
  764. // value validation
  765. if (a_dValue < MAGNIFICATION_MIN || a_dValue > MAGNIFICATION_MAX)
  766. {
  767. return FALSE;
  768. }
  769. m_poSEMDataMsr->SetMagnification(a_dValue);
  770. }
  771. break;
  772. case OTS_SAMPLE_PROP_GRID_ITEMS::PIXEL_SIZE:
  773. {
  774. if (a_dValue < PIXELSIZE_MIN || a_dValue > PIXELSIZE_MAX)
  775. {
  776. return FALSE;
  777. }
  778. int nScanFieldSize = CalculateScanFileSize(a_dValue);
  779. m_poSEMDataMsr->SetScanFieldSize(nScanFieldSize);
  780. }
  781. break;
  782. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MIN:
  783. {
  784. if (PARTICLE_AREA_MIN > a_dValue || a_dValue > PARTICLE_AREA_MAX)
  785. {
  786. return FALSE;
  787. }
  788. CDoubleRange oIncArea = m_poMsrParams->GetImageProcessParam()->GetIncArea();
  789. oIncArea.SetStart(a_dValue);
  790. m_poMsrParams->GetImageProcessParam()->SetIncArea(oIncArea);
  791. }
  792. break;
  793. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MAX:
  794. {
  795. if (PARTICLE_AREA_MIN > a_dValue || a_dValue > PARTICLE_AREA_MAX)
  796. {
  797. return FALSE;
  798. }
  799. CDoubleRange oIncArea = m_poMsrParams->GetImageProcessParam()->GetIncArea();
  800. oIncArea.SetEnd(a_dValue);
  801. m_poMsrParams->GetImageProcessParam()->SetIncArea(oIncArea);
  802. }
  803. break;
  804. // read only property, tread as default.
  805. case OTS_SAMPLE_PROP_GRID_ITEMS::WORKING_DISTANCE:
  806. case OTS_SAMPLE_PROP_GRID_ITEMS::RADIO:
  807. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_TO_MEASURE_AREA:
  808. default:
  809. {
  810. // something wrong, return FALSE
  811. return FALSE;
  812. }
  813. break;
  814. }
  815. // ok, return TRUE
  816. return TRUE;
  817. }
  818. // string data (7)
  819. BOOL COTSSample::GetPropStringData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, CString& a_strValue)
  820. {
  821. AFX_MANAGE_STATE(AfxGetStaticModuleState());
  822. switch (a_nId)
  823. {
  824. case OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_NAME:
  825. {
  826. a_strValue = m_strName;
  827. }
  828. break;
  829. case OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_HOLE_NAME:
  830. {
  831. a_strValue = m_strHoleName;
  832. }
  833. break;
  834. case OTS_SAMPLE_PROP_GRID_ITEMS::MAGNIFICATION:
  835. {
  836. a_strValue = NOT_APPLIED;
  837. }
  838. break;
  839. case OTS_SAMPLE_PROP_GRID_ITEMS::PIXEL_SIZE:
  840. {
  841. a_strValue = NOT_APPLIED;
  842. }
  843. break;
  844. case OTS_SAMPLE_PROP_GRID_ITEMS::WORKING_DISTANCE:
  845. {
  846. a_strValue = NOT_APPLIED;
  847. }
  848. break;
  849. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_FIELDS:
  850. {
  851. a_strValue = NOT_APPLIED;
  852. }
  853. break;
  854. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_TO_MEASURE_AREA:
  855. {
  856. a_strValue = NOT_APPLIED;
  857. }
  858. break;
  859. case OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_STATAU:
  860. {
  861. OTS_MSR_SAMPLE_STATUS nStatus = m_poMsrStatus->GetStatus();
  862. CString strStatus;
  863. strStatus= MultiLang::GetInstance().GetCStringByKey(IDS_MEASURE_STATUS_FIRST + (int)nStatus);
  864. a_strValue = strStatus;
  865. }
  866. break;
  867. default:
  868. {
  869. // something wrong, return FALSE
  870. return FALSE;
  871. }
  872. break;
  873. }
  874. // ok, return TRUE
  875. return TRUE;
  876. }
  877. BOOL COTSSample::SetPropStringData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, CString a_strValue)
  878. {
  879. switch (a_nId)
  880. {
  881. case OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_NAME:
  882. {
  883. //we think the samplename as the Identification of the sample,if we change the name then reset the status.
  884. //so we can remeasure the sample by change the sample name.
  885. if (m_strName != a_strValue)
  886. {
  887. m_strName = a_strValue;
  888. m_poMsrStatus = CMsrSampleStatusPtr(new CMsrSampleStatus());
  889. }
  890. }
  891. break;
  892. // read only property, tread as default.
  893. case OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_HOLE_NAME:
  894. case OTS_SAMPLE_PROP_GRID_ITEMS::MAGNIFICATION:
  895. case OTS_SAMPLE_PROP_GRID_ITEMS::PIXEL_SIZE:
  896. case OTS_SAMPLE_PROP_GRID_ITEMS::WORKING_DISTANCE:
  897. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_FIELDS:
  898. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_TO_MEASURE_AREA:
  899. case OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_STATAU:
  900. default:
  901. {
  902. // something wrong, return FALSE
  903. return FALSE;
  904. }
  905. break;
  906. }
  907. // ok, return TRUE
  908. return TRUE;
  909. }
  910. // combo data (7)
  911. BOOL COTSSample::GetPropComboData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, int& a_nValue)
  912. {
  913. switch (a_nId)
  914. {
  915. case OTS_SAMPLE_PROP_GRID_ITEMS::START_MODE:
  916. {
  917. a_nValue = (int)m_poMsrParams->GetImageScanParam()->GetStartImageMode();
  918. }
  919. break;
  920. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_MODE:
  921. {
  922. a_nValue = (int)m_poMsrParams->GetImageScanParam()->GetStopMode();
  923. }
  924. break;
  925. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_SPEED:
  926. {
  927. a_nValue = (int)m_poMsrParams->GetImageScanParam()->GetScanImageSpeed();
  928. }
  929. break;
  930. case OTS_SAMPLE_PROP_GRID_ITEMS::IMAGE_RESOLUTION:
  931. {
  932. a_nValue = (int)m_poMsrParams->GetImageScanParam()->GetImagePixelSize();
  933. }
  934. break;
  935. case OTS_SAMPLE_PROP_GRID_ITEMS::SEARCH_RESOLUTION:
  936. {
  937. a_nValue = (int)m_poMsrParams->GetXRayParam()->GetSearchSpeed();
  938. }
  939. break;
  940. /*case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_RESOLUTION:
  941. {
  942. a_nValue = (int)m_poMsrParams->GetXRayParam()->GetAnalySpeed();
  943. }
  944. break;*/
  945. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_MODE:
  946. {
  947. a_nValue = (int)m_poMsrParams->GetXRayParam()->GetScanMode();
  948. }
  949. break;
  950. case OTS_SAMPLE_PROP_GRID_ITEMS::STEEL_TECHNOLOGY:
  951. {
  952. a_nValue = (int)m_poMsrParams->GetSteelTechnology();
  953. }
  954. break;
  955. default:
  956. {
  957. // something wrong, return FALSE
  958. return FALSE;
  959. }
  960. break;
  961. }
  962. // ok, return TRUE
  963. return TRUE;
  964. }
  965. BOOL COTSSample::SetPropComboData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, int a_nValue)
  966. {
  967. switch (a_nId)
  968. {
  969. case OTS_SAMPLE_PROP_GRID_ITEMS::START_MODE:
  970. {
  971. if (OTS_GET_IMAGE_MODE::MIN > (OTS_GET_IMAGE_MODE)a_nValue || (OTS_GET_IMAGE_MODE)a_nValue > OTS_GET_IMAGE_MODE::MAX)
  972. {
  973. return FALSE;
  974. }
  975. m_poMsrParams->GetImageScanParam()->SetStartImageMode((OTS_GET_IMAGE_MODE)a_nValue);
  976. }
  977. break;
  978. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_MODE:
  979. {
  980. if (OTS_MEASURE_STOP_MODE::MIN > (OTS_MEASURE_STOP_MODE)a_nValue || (OTS_MEASURE_STOP_MODE)a_nValue > OTS_MEASURE_STOP_MODE::MAX)
  981. {
  982. return FALSE;
  983. }
  984. if (m_poMsrParams->GetImageScanParam()->GetStopMode() != (OTS_MEASURE_STOP_MODE)a_nValue)
  985. {
  986. m_poMsrParams->GetImageScanParam()->SetStopMode((OTS_MEASURE_STOP_MODE)a_nValue);
  987. m_poMsrStatus->SetStatus(OTS_MSR_SAMPLE_STATUS::UNMEASURED);
  988. }
  989. }
  990. break;
  991. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_SPEED:
  992. {
  993. if (OTS_THREE_TIES_OPTIONS::MIN > (OTS_THREE_TIES_OPTIONS)a_nValue || (OTS_THREE_TIES_OPTIONS)a_nValue > OTS_THREE_TIES_OPTIONS::MAX)
  994. {
  995. return FALSE;
  996. }
  997. m_poMsrParams->GetImageScanParam()->SetScanImageSpeed((OTS_THREE_TIES_OPTIONS)a_nValue);
  998. }
  999. break;
  1000. case OTS_SAMPLE_PROP_GRID_ITEMS::IMAGE_RESOLUTION:
  1001. {
  1002. if (OTS_FIVE_TIES_OPTIONS::MIN > (OTS_FIVE_TIES_OPTIONS)a_nValue || (OTS_FIVE_TIES_OPTIONS)a_nValue > OTS_FIVE_TIES_OPTIONS::MAX)
  1003. {
  1004. return FALSE;
  1005. }
  1006. m_poMsrParams->GetImageScanParam()->SetImagePixelSize((OTS_FIVE_TIES_OPTIONS)a_nValue);
  1007. }
  1008. break;
  1009. case OTS_SAMPLE_PROP_GRID_ITEMS::SEARCH_RESOLUTION:
  1010. {
  1011. if (OTS_THREE_TIES_OPTIONS::MIN > (OTS_THREE_TIES_OPTIONS)a_nValue || (OTS_THREE_TIES_OPTIONS)a_nValue > OTS_THREE_TIES_OPTIONS::MAX)
  1012. {
  1013. return FALSE;
  1014. }
  1015. m_poMsrParams->GetXRayParam()->SetSearchSpeed((OTS_THREE_TIES_OPTIONS)a_nValue);
  1016. }
  1017. break;
  1018. /*case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_RESOLUTION:
  1019. {
  1020. if (OTS_THREE_TIES_OPTIONS::MIN > (OTS_THREE_TIES_OPTIONS)a_nValue || (OTS_THREE_TIES_OPTIONS)a_nValue > OTS_THREE_TIES_OPTIONS::MAX)
  1021. {
  1022. return FALSE;
  1023. }
  1024. m_poMsrParams->GetXRayParam()->SetAnalySpeed((OTS_THREE_TIES_OPTIONS)a_nValue);
  1025. }
  1026. break;*/
  1027. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_MODE:
  1028. {
  1029. if (OTS_X_RAY_SCAN_MODE::MIN > (OTS_X_RAY_SCAN_MODE)a_nValue || (OTS_X_RAY_SCAN_MODE)a_nValue > OTS_X_RAY_SCAN_MODE::MAX)
  1030. {
  1031. return FALSE;
  1032. }
  1033. m_poMsrParams->GetXRayParam()->SetScanMode((OTS_X_RAY_SCAN_MODE)a_nValue);
  1034. }
  1035. break;
  1036. case OTS_SAMPLE_PROP_GRID_ITEMS::STEEL_TECHNOLOGY:
  1037. {
  1038. if (STEEL_TECHNOLOGY::MIN > (STEEL_TECHNOLOGY)a_nValue || (STEEL_TECHNOLOGY)a_nValue > STEEL_TECHNOLOGY::MAX)
  1039. {
  1040. return FALSE;
  1041. }
  1042. m_poMsrParams->SetSteelTechnology((STEEL_TECHNOLOGY)a_nValue);
  1043. }
  1044. break;
  1045. default:
  1046. {
  1047. // something wrong, return FALSE
  1048. return FALSE;
  1049. }
  1050. break;
  1051. }
  1052. // ok, return TRUE
  1053. return TRUE;
  1054. }
  1055. BOOL COTSSample::GetPropComboStrings(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, std::vector<CString>& a_listComboStrings)
  1056. {
  1057. AFX_MANAGE_STATE(AfxGetStaticModuleState());
  1058. // clear the strings list
  1059. a_listComboStrings.clear();
  1060. // set the strings list
  1061. CString strItem;
  1062. switch (a_nId)
  1063. {
  1064. case OTS_SAMPLE_PROP_GRID_ITEMS::START_MODE:
  1065. {
  1066. for(int i = (int)OTS_GET_IMAGE_MODE::MIN; i <= (int)OTS_GET_IMAGE_MODE::MAX; ++i)
  1067. {
  1068. strItem= MultiLang::GetInstance().GetCStringByKey(IDS_IMAGE_MODE_FIRST + i);
  1069. a_listComboStrings.push_back(strItem);
  1070. }
  1071. }
  1072. break;
  1073. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_MODE:
  1074. {
  1075. for(int i = (int)OTS_MEASURE_STOP_MODE::MIN; i <= (int)OTS_MEASURE_STOP_MODE::MAX; ++i)
  1076. {
  1077. strItem= MultiLang::GetInstance().GetCStringByKey(IDS_MEASURE_STOP_MODE_FIRST + i);
  1078. a_listComboStrings.push_back(strItem);
  1079. }
  1080. }
  1081. break;
  1082. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_SPEED:
  1083. case OTS_SAMPLE_PROP_GRID_ITEMS::SEARCH_RESOLUTION:
  1084. //case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_RESOLUTION:
  1085. {
  1086. for(int i = (int)OTS_THREE_TIES_OPTIONS::MIN; i <= (int)OTS_THREE_TIES_OPTIONS::MAX; ++i)
  1087. {
  1088. strItem= MultiLang::GetInstance().GetCStringByKey(IDS_THREE_TIES_OPTIONS_FIRST + i);
  1089. a_listComboStrings.push_back(strItem);
  1090. }
  1091. }
  1092. break;
  1093. case OTS_SAMPLE_PROP_GRID_ITEMS::IMAGE_RESOLUTION:
  1094. {
  1095. for (int i = (int)OTS_FIVE_TIES_OPTIONS::MIN; i <= (int)OTS_FIVE_TIES_OPTIONS::MAX; ++i)
  1096. {
  1097. strItem = RESOLUTION_STRINGS[RESOLUTION_ID_FIRST_TIE + i];
  1098. a_listComboStrings.push_back(strItem);
  1099. }
  1100. }
  1101. break;
  1102. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_MODE:
  1103. {
  1104. for (int i = (int)OTS_X_RAY_SCAN_MODE::MIN; i <= (int)OTS_X_RAY_SCAN_MODE::MAX; ++i)
  1105. {
  1106. strItem= MultiLang::GetInstance().GetCStringByKey(IDS_X_RAY_SCAN_MODE_FIRST + i);
  1107. a_listComboStrings.push_back(strItem);
  1108. }
  1109. }
  1110. break;
  1111. case OTS_SAMPLE_PROP_GRID_ITEMS::STEEL_TECHNOLOGY:
  1112. {
  1113. for (int i = (int)STEEL_TECHNOLOGY::MIN; i <= (int)STEEL_TECHNOLOGY::MAX; ++i)
  1114. {
  1115. strItem= MultiLang::GetInstance().GetCStringByKey(IDS_STEEL_TECHNOLOGY + i);
  1116. a_listComboStrings.push_back(strItem);
  1117. }
  1118. }
  1119. break;
  1120. default:
  1121. {
  1122. // something wrong, return FALSE
  1123. return FALSE;
  1124. }
  1125. break;
  1126. }
  1127. // ok, return TRUE
  1128. return TRUE;
  1129. }
  1130. // time data
  1131. BOOL COTSSample::GetPropTimeData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, COleDateTime& a_oValue)
  1132. {
  1133. switch (a_nId)
  1134. {
  1135. case OTS_SAMPLE_PROP_GRID_ITEMS::START_TIME:
  1136. {
  1137. a_oValue = m_poMsrStatus->GetStartTime();
  1138. }
  1139. break;
  1140. case OTS_SAMPLE_PROP_GRID_ITEMS::FINISH_TIME:
  1141. {
  1142. a_oValue = m_poMsrStatus->GetEndTime();
  1143. }
  1144. break;
  1145. default:
  1146. {
  1147. // something wrong, return FALSE
  1148. return FALSE;
  1149. }
  1150. break;
  1151. }
  1152. // ok, return TRUE
  1153. return TRUE;
  1154. }
  1155. BOOL COTSSample::SetPropTimeData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, COleDateTime /*a_oValue*/)
  1156. {
  1157. switch (a_nId)
  1158. {
  1159. // read only property, tread as default.
  1160. case OTS_SAMPLE_PROP_GRID_ITEMS::START_TIME:
  1161. case OTS_SAMPLE_PROP_GRID_ITEMS::FINISH_TIME:
  1162. default:
  1163. {
  1164. // something wrong, return FALSE
  1165. return FALSE;
  1166. }
  1167. break;
  1168. }
  1169. // ok, return TRUE
  1170. return TRUE;
  1171. }
  1172. // time span data (1)
  1173. BOOL COTSSample::GetPropTimeSpanData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, COleDateTimeSpan& a_oValue)
  1174. {
  1175. switch (a_nId)
  1176. {
  1177. case OTS_SAMPLE_PROP_GRID_ITEMS::USED_TIME:
  1178. {
  1179. a_oValue = m_poMsrStatus->GetUsedTime();
  1180. }
  1181. break;
  1182. default:
  1183. {
  1184. // something wrong, return FALSE
  1185. return FALSE;
  1186. }
  1187. break;
  1188. }
  1189. // ok, return TRUE
  1190. return TRUE;
  1191. }
  1192. BOOL COTSSample::SetPropTimeSpanData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, COleDateTimeSpan /*a_oValue*/)
  1193. {
  1194. switch (a_nId)
  1195. {
  1196. // read only property, tread as default.
  1197. case OTS_SAMPLE_PROP_GRID_ITEMS::USED_TIME:
  1198. default:
  1199. {
  1200. // something wrong, return FALSE
  1201. return FALSE;
  1202. }
  1203. break;
  1204. }
  1205. // ok, return TRUE
  1206. return TRUE;
  1207. }
  1208. // file list data (2)
  1209. BOOL COTSSample::GetPropFileListData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, CString& a_strFileName)
  1210. {
  1211. switch (a_nId)
  1212. {
  1213. case OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_PARAM_FILE_NAME:
  1214. {
  1215. a_strFileName = m_poMsrParams->GetName();
  1216. }
  1217. break;
  1218. case OTS_SAMPLE_PROP_GRID_ITEMS::STD_FILE_NAME:
  1219. {
  1220. a_strFileName = m_poMsrParams->GetPartSTDData()->GetName();
  1221. }
  1222. break;
  1223. default:
  1224. {
  1225. // something wrong, return FALSE
  1226. return FALSE;
  1227. }
  1228. break;
  1229. }
  1230. // ok, return TRUE
  1231. return TRUE;
  1232. }
  1233. BOOL COTSSample::SetPropFileListData(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, CString a_strFileName)
  1234. {
  1235. switch (a_nId)
  1236. {
  1237. case OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_PARAM_FILE_NAME:
  1238. {
  1239. m_poMsrParams->SetName(a_strFileName);
  1240. }
  1241. break;
  1242. case OTS_SAMPLE_PROP_GRID_ITEMS::STD_FILE_NAME:
  1243. {
  1244. m_poMsrParams->GetPartSTDData()->SetName(a_strFileName);
  1245. }
  1246. break;
  1247. default:
  1248. {
  1249. // something wrong, return FALSE
  1250. return FALSE;
  1251. }
  1252. break;
  1253. }
  1254. // ok, return TRUE
  1255. return TRUE;
  1256. }
  1257. // get related property
  1258. BOOL COTSSample::GetRelatedPropItem(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, OTS_SAMPLE_PROP_GRID_ITEMS& a_nRelatedPropId)
  1259. {
  1260. switch (a_nId)
  1261. {
  1262. // general group
  1263. case OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_NAME:
  1264. case OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_HOLE_NAME:
  1265. case OTS_SAMPLE_PROP_GRID_ITEMS::SWITCH:
  1266. case OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_PARAM_FILE_NAME:
  1267. case OTS_SAMPLE_PROP_GRID_ITEMS::STD_FILE_NAME:
  1268. // image param group
  1269. case OTS_SAMPLE_PROP_GRID_ITEMS::START_MODE:
  1270. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_MODE:
  1271. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_PARTICLE:
  1272. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_FIELD:
  1273. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_TIME:
  1274. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_SPEED:
  1275. {
  1276. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::INVALID;
  1277. return FALSE;
  1278. }
  1279. case OTS_SAMPLE_PROP_GRID_ITEMS::IMAGE_RESOLUTION:
  1280. {
  1281. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::PIXEL_SIZE;
  1282. }
  1283. break;
  1284. // image process param
  1285. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MIN:
  1286. {
  1287. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MAX;
  1288. }
  1289. break;
  1290. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MAX:
  1291. {
  1292. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MIN;
  1293. }
  1294. break;
  1295. case OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MIN:
  1296. {
  1297. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MAX;
  1298. }
  1299. break;
  1300. case OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MAX:
  1301. {
  1302. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MIN;
  1303. }
  1304. break;
  1305. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MIN:
  1306. {
  1307. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MAX;
  1308. }
  1309. break;
  1310. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MAX:
  1311. {
  1312. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MIN;
  1313. }
  1314. break;
  1315. // x-ray param
  1316. case OTS_SAMPLE_PROP_GRID_ITEMS::SEARCH_RESOLUTION:
  1317. case OTS_SAMPLE_PROP_GRID_ITEMS::LOW_COUNTS:
  1318. case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_RESOLUTION:
  1319. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_MODE:
  1320. case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_COUNTS:
  1321. {
  1322. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::INVALID;
  1323. return FALSE;
  1324. }
  1325. break;
  1326. // SEM data
  1327. case OTS_SAMPLE_PROP_GRID_ITEMS::MAGNIFICATION:
  1328. {
  1329. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::PIXEL_SIZE;
  1330. }
  1331. break;
  1332. case OTS_SAMPLE_PROP_GRID_ITEMS::PIXEL_SIZE:
  1333. {
  1334. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::MAGNIFICATION;
  1335. }
  1336. break;
  1337. case OTS_SAMPLE_PROP_GRID_ITEMS::WORKING_DISTANCE:
  1338. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_FIELDS:
  1339. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_TO_MEASURE_AREA:
  1340. // measure status
  1341. case OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_STATAU:
  1342. case OTS_SAMPLE_PROP_GRID_ITEMS::START_TIME:
  1343. case OTS_SAMPLE_PROP_GRID_ITEMS::USED_TIME:
  1344. case OTS_SAMPLE_PROP_GRID_ITEMS::FINISH_TIME:
  1345. case OTS_SAMPLE_PROP_GRID_ITEMS::COMPLETED_FIELDS:
  1346. // measure results
  1347. case OTS_SAMPLE_PROP_GRID_ITEMS::RADIO:
  1348. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_AREA:
  1349. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE:
  1350. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE_AREA:
  1351. {
  1352. a_nRelatedPropId = OTS_SAMPLE_PROP_GRID_ITEMS::INVALID;
  1353. return FALSE;
  1354. }
  1355. break;
  1356. default:
  1357. {
  1358. // something wrong, return FALSE
  1359. return FALSE;
  1360. }
  1361. break;
  1362. }
  1363. // ok, return TRUE
  1364. return TRUE;
  1365. }
  1366. // get related property item group
  1367. BOOL COTSSample::GetRelatedPropItemGrp(OTS_SAMPLE_PROP_GRID_ITEMS a_nId, OTS_SAMPLE_PROP_GRID_ITEM_GROUPS& a_nRelatedPropGrpId)
  1368. {
  1369. switch (a_nId)
  1370. {
  1371. // general group
  1372. case OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_NAME:
  1373. case OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_HOLE_NAME:
  1374. case OTS_SAMPLE_PROP_GRID_ITEMS::SWITCH:
  1375. case OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_PARAM_FILE_NAME:
  1376. case OTS_SAMPLE_PROP_GRID_ITEMS::STD_FILE_NAME:
  1377. // image param group
  1378. case OTS_SAMPLE_PROP_GRID_ITEMS::START_MODE:
  1379. {
  1380. a_nRelatedPropGrpId = OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::INVALID;
  1381. return FALSE;
  1382. }
  1383. break;
  1384. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_MODE:
  1385. {
  1386. a_nRelatedPropGrpId = OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::IMAGE;
  1387. }
  1388. break;
  1389. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_PARTICLE:
  1390. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_FIELD:
  1391. case OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_TIME:
  1392. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_SPEED:
  1393. case OTS_SAMPLE_PROP_GRID_ITEMS::IMAGE_RESOLUTION:
  1394. // image process param
  1395. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MIN:
  1396. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MAX:
  1397. case OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MIN:
  1398. case OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MAX:
  1399. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MIN:
  1400. case OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MAX:
  1401. // x-ray param
  1402. case OTS_SAMPLE_PROP_GRID_ITEMS::SEARCH_RESOLUTION:
  1403. case OTS_SAMPLE_PROP_GRID_ITEMS::LOW_COUNTS:
  1404. case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_RESOLUTION:
  1405. case OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_MODE:
  1406. case OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_COUNTS:
  1407. case OTS_SAMPLE_PROP_GRID_ITEMS::WORKING_DISTANCE:
  1408. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_FIELDS:
  1409. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_TO_MEASURE_AREA:
  1410. // measure status
  1411. case OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_STATAU:
  1412. case OTS_SAMPLE_PROP_GRID_ITEMS::START_TIME:
  1413. case OTS_SAMPLE_PROP_GRID_ITEMS::USED_TIME:
  1414. case OTS_SAMPLE_PROP_GRID_ITEMS::FINISH_TIME:
  1415. case OTS_SAMPLE_PROP_GRID_ITEMS::COMPLETED_FIELDS:
  1416. // measure results
  1417. case OTS_SAMPLE_PROP_GRID_ITEMS::RADIO:
  1418. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_AREA:
  1419. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE:
  1420. case OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE_AREA:
  1421. {
  1422. a_nRelatedPropGrpId = OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::INVALID;
  1423. return FALSE;
  1424. }
  1425. break;
  1426. default:
  1427. {
  1428. // something wrong, return FALSE
  1429. return FALSE;
  1430. }
  1431. break;
  1432. }
  1433. // ok, return TRUE
  1434. return TRUE;
  1435. }
  1436. // calculate pixel size
  1437. double COTSSample::CalculatePixelSize()
  1438. {
  1439. // pixel size
  1440. double dPixelSize = 0.0;
  1441. // make sure SEM is valid
  1442. if (!(*(m_poSEMDataMsr.get()) == CSEMDataMsr()))
  1443. {
  1444. // get scan field size
  1445. int nScanFieldSize = m_poSEMDataMsr->GetScanFieldSize();
  1446. // get image size
  1447. OTS_FIVE_TIES_OPTIONS nImageSizeId = m_poMsrParams->GetImageScanParam()->GetImagePixelSize();
  1448. long nResulotionId = RESOLUTION_ID_FIRST_TIE + (long)nImageSizeId;
  1449. int nImageSize = RESOLUTION_VALUE[nResulotionId].cx;
  1450. // calculate pixel size
  1451. dPixelSize = (double)nScanFieldSize / (double)nImageSize;
  1452. }
  1453. // return pixel size
  1454. return dPixelSize;
  1455. }
  1456. // calculate pixel size
  1457. double COTSSample::CalculateAFieldArea()
  1458. {
  1459. // pixel size
  1460. double dAFieldArea = 0.0;
  1461. // make sure SEM is valid
  1462. if (!(*(m_poSEMDataMsr.get()) == CSEMDataMsr()))
  1463. {
  1464. // get image size
  1465. OTS_FIVE_TIES_OPTIONS nImageSizeId = m_poMsrParams->GetImageScanParam()->GetImagePixelSize();
  1466. long nResulotionId = RESOLUTION_ID_FIRST_TIE + (long)nImageSizeId;
  1467. int nImageSize = RESOLUTION_VALUE[nResulotionId].cx;
  1468. // pixel size (micros)
  1469. double dPixelSize = 0;
  1470. dPixelSize = CalculatePixelSize();
  1471. // calculate pixel size
  1472. dAFieldArea = (double)nImageSize * (double)nImageSize * 0.75 * dPixelSize * dPixelSize * 0.000001;// mm^2
  1473. }
  1474. // return pixel size
  1475. return dAFieldArea;
  1476. }
  1477. BOOL COTSSample::GetBSESize(int& a_nWidth, int& a_nHeight)
  1478. {
  1479. // scan parameters
  1480. CMsrParamsPtr pMsrParam = GetMsrParams();
  1481. ASSERT(pMsrParam);
  1482. if (!pMsrParam)
  1483. {
  1484. return FALSE;
  1485. }
  1486. COTSImageScanParamPtr pImgScanParam = pMsrParam->GetImageScanParam();
  1487. ASSERT(pImgScanParam);
  1488. if (!pImgScanParam)
  1489. {
  1490. return FALSE;
  1491. }
  1492. // get image size
  1493. OTS_FIVE_TIES_OPTIONS nImageSizeId = pImgScanParam->GetImagePixelSize();
  1494. int nResulotionId = RESOLUTION_ID_FIRST_TIE + (int)nImageSizeId;
  1495. CSize sizePixelImage = RESOLUTION_VALUE[nResulotionId];
  1496. // get scan field size
  1497. a_nWidth = sizePixelImage.cx;
  1498. a_nHeight = sizePixelImage.cy;
  1499. return TRUE;
  1500. }
  1501. // protected
  1502. // cleanup
  1503. void COTSSample::Cleanup()
  1504. {
  1505. // need to do nothing at the moment
  1506. }
  1507. // initialization
  1508. void COTSSample::Init()
  1509. {
  1510. m_strName = _T("");
  1511. m_strHoleName = _T("");
  1512. m_bParamLock = FALSE;
  1513. m_bSwitch = TRUE;
  1514. m_poMsrParams = CMsrParamsPtr(new CMsrParams());
  1515. m_poMsrArea = CDomainPtr(new CDomain());
  1516. m_poSEMDataMsr = CSEMDataMsrPtr(new CSEMDataMsr());
  1517. m_poMsrStatus = CMsrSampleStatusPtr(new CMsrSampleStatus());
  1518. m_poMsrResults = CMsrResultsPtr(new CMsrResults());
  1519. }
  1520. // duplication
  1521. void COTSSample::Duplicate(const COTSSample& a_oSource)
  1522. {
  1523. // initialization
  1524. Init();
  1525. // copy data over
  1526. m_strName = a_oSource.m_strName;
  1527. m_strHoleName = a_oSource.m_strHoleName;
  1528. m_bParamLock = a_oSource.m_bParamLock;
  1529. m_bSwitch = a_oSource.m_bSwitch;
  1530. m_poMsrParams = CMsrParamsPtr(new CMsrParams(a_oSource.m_poMsrParams.get()));
  1531. m_poMsrArea = CDomainPtr(new CDomain(a_oSource.m_poMsrArea.get()));
  1532. m_poSEMDataMsr = CSEMDataMsrPtr(new CSEMDataMsr(a_oSource.m_poSEMDataMsr.get()));
  1533. m_poMsrStatus = CMsrSampleStatusPtr(new CMsrSampleStatus(a_oSource.m_poMsrStatus.get()));
  1534. m_poMsrResults = CMsrResultsPtr(new CMsrResults(a_oSource.m_poMsrResults.get()));
  1535. m_listPropItemGrps = a_oSource.m_listPropItemGrps;
  1536. }
  1537. // create a property items group
  1538. CPropItemGrpPtr COTSSample::SetPropertyItemGrp(OTS_SAMPLE_PROP_GRID_ITEM_GROUPS a_nGrpId)
  1539. {
  1540. AFX_MANAGE_STATE(AfxGetStaticModuleState());
  1541. // property items group name
  1542. CString strGrpName;
  1543. strGrpName = MultiLang::GetInstance().GetCStringByKey(IDS_SAMPLE_ITEM_GROUP_NAME_FIRST + (int)a_nGrpId);
  1544. // property items group
  1545. CPropItemGrpPtr poPropItemGrp(new CPropItemGrp());
  1546. // group name and id
  1547. poPropItemGrp->SetName(strGrpName);
  1548. poPropItemGrp->SetGroupId(a_nGrpId);
  1549. // items list
  1550. CPropItemsList a_listPropItems;
  1551. // set group items list
  1552. OTS_SAMPLE_PROP_GRID_ITEMS nItemId;
  1553. CPropItemPtr poPropItem;
  1554. BOOL bShow = TRUE;
  1555. switch (a_nGrpId)
  1556. {
  1557. case OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::GENERAL:
  1558. {
  1559. // name
  1560. poPropItem = CPropItemPtr(new CPropItem());
  1561. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_NAME;
  1562. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::STRING, FALSE,TRUE);
  1563. a_listPropItems.push_back(poPropItem);
  1564. // hole
  1565. poPropItem = CPropItemPtr(new CPropItem());
  1566. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::SAMPLE_HOLE_NAME;
  1567. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::STRING, TRUE, TRUE);
  1568. a_listPropItems.push_back(poPropItem);
  1569. // switch
  1570. poPropItem = CPropItemPtr(new CPropItem());
  1571. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::SWITCH;
  1572. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::BOOL, FALSE, TRUE);
  1573. a_listPropItems.push_back(poPropItem);
  1574. // parameter file name
  1575. /* poPropItem = CPropItemPtr(new CPropItem());
  1576. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_PARAM_FILE_NAME;
  1577. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::FILE_LIST, FALSE, TRUE);
  1578. a_listPropItems.push_back(poPropItem);*/
  1579. // STD file name
  1580. poPropItem = CPropItemPtr(new CPropItem());
  1581. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::STD_FILE_NAME;
  1582. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::FILE_LIST, FALSE, TRUE);
  1583. a_listPropItems.push_back(poPropItem);
  1584. // Steel technology
  1585. poPropItem = CPropItemPtr(new CPropItem());
  1586. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::STEEL_TECHNOLOGY;
  1587. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::COMBO, FALSE, TRUE);
  1588. a_listPropItems.push_back(poPropItem);
  1589. }
  1590. break;
  1591. case OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::IMAGE:
  1592. {
  1593. // start mode
  1594. COTSImageScanParamPtr pScanParam = m_poMsrParams->GetImageScanParam();
  1595. bShow = pScanParam->GetShowStartImageMode();
  1596. if (bShow)
  1597. {
  1598. poPropItem = CPropItemPtr(new CPropItem());
  1599. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::START_MODE;
  1600. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::COMBO, FALSE, bShow);
  1601. a_listPropItems.push_back(poPropItem);
  1602. }
  1603. // stop mode
  1604. bShow = pScanParam->GetShowStopMode();
  1605. if (bShow)
  1606. {
  1607. poPropItem = CPropItemPtr(new CPropItem());
  1608. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::STOP_MODE;
  1609. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::COMBO, FALSE, bShow);
  1610. a_listPropItems.push_back(poPropItem);
  1611. }
  1612. // stop parameter
  1613. switch (m_poMsrParams->GetImageScanParam()->GetStopMode())
  1614. {
  1615. case OTS_MEASURE_STOP_MODE::ParticleMode:
  1616. {
  1617. // particle
  1618. bShow = pScanParam->GetShowParticles();
  1619. if (bShow)
  1620. {
  1621. poPropItem = CPropItemPtr(new CPropItem());
  1622. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_PARTICLE;
  1623. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE, bShow);
  1624. a_listPropItems.push_back(poPropItem);
  1625. }
  1626. }
  1627. break;
  1628. case OTS_MEASURE_STOP_MODE::FieldMode:
  1629. {
  1630. // field
  1631. bShow = pScanParam->GetShowParamFields();
  1632. if (bShow)
  1633. {
  1634. poPropItem = CPropItemPtr(new CPropItem());
  1635. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_FIELD;
  1636. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE, bShow);
  1637. a_listPropItems.push_back(poPropItem);
  1638. }
  1639. }
  1640. break;
  1641. case OTS_MEASURE_STOP_MODE::TimeMode:
  1642. {
  1643. // used time
  1644. bShow = pScanParam->GetShowMeasTime();
  1645. if (bShow)
  1646. {
  1647. poPropItem = CPropItemPtr(new CPropItem());
  1648. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::STOP_PARAM_TIME;
  1649. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE, bShow);
  1650. a_listPropItems.push_back(poPropItem);
  1651. }
  1652. }
  1653. break;
  1654. case OTS_MEASURE_STOP_MODE::CoverMode:
  1655. default:
  1656. {
  1657. // no stop parameter item
  1658. }
  1659. break;
  1660. }
  1661. // scan speed
  1662. bShow = pScanParam->GetShowImageSpeed();
  1663. if (bShow)
  1664. {
  1665. poPropItem = CPropItemPtr(new CPropItem());
  1666. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_SPEED;
  1667. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::COMBO, FALSE, bShow);
  1668. a_listPropItems.push_back(poPropItem);
  1669. }
  1670. // image resolution
  1671. bShow = pScanParam->GetShowPixelSize();
  1672. if (bShow)
  1673. {
  1674. poPropItem = CPropItemPtr(new CPropItem());
  1675. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::IMAGE_RESOLUTION;
  1676. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::COMBO, FALSE, bShow);
  1677. a_listPropItems.push_back(poPropItem);
  1678. }
  1679. }
  1680. break;
  1681. case OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::IMAGE_PROCESS:
  1682. {
  1683. COTSImageProcessParamPtr pProcParam = m_poMsrParams->GetImageProcessParam();
  1684. // particle area min
  1685. bShow = pProcParam->GetShowAreaLow();
  1686. if (bShow)
  1687. {
  1688. poPropItem = CPropItemPtr(new CPropItem());
  1689. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MIN;
  1690. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::DOUBLE, FALSE, bShow);
  1691. a_listPropItems.push_back(poPropItem);
  1692. }
  1693. // particle area max
  1694. bShow = pProcParam->GetShowAreaUp();
  1695. if (bShow)
  1696. {
  1697. poPropItem = CPropItemPtr(new CPropItem());
  1698. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_AREA_MAX;
  1699. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::DOUBLE, FALSE, bShow);
  1700. a_listPropItems.push_back(poPropItem);
  1701. }
  1702. // BG gray level min
  1703. bShow = pProcParam->GetShowBGLow();
  1704. if (bShow)
  1705. {
  1706. poPropItem = CPropItemPtr(new CPropItem());
  1707. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MIN;
  1708. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE, bShow);
  1709. a_listPropItems.push_back(poPropItem);
  1710. }
  1711. // BG gray level max
  1712. bShow = pProcParam->GetShowBGUp();
  1713. if (bShow)
  1714. {
  1715. poPropItem = CPropItemPtr(new CPropItem());
  1716. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::BG_GRAY_MAX;
  1717. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE, bShow);
  1718. a_listPropItems.push_back(poPropItem);
  1719. }
  1720. // particle gray level min
  1721. bShow = pProcParam->GetShowPGLow();
  1722. if (bShow)
  1723. {
  1724. poPropItem = CPropItemPtr(new CPropItem());
  1725. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MIN;
  1726. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE, bShow);
  1727. a_listPropItems.push_back(poPropItem);
  1728. }
  1729. // particle gray level max
  1730. bShow = pProcParam->GetShowPGUp();
  1731. if (bShow)
  1732. {
  1733. poPropItem = CPropItemPtr(new CPropItem());
  1734. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::PARTICLE_GRAY_MAX;
  1735. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE, bShow);
  1736. a_listPropItems.push_back(poPropItem);
  1737. }
  1738. }
  1739. break;
  1740. case OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::XRAY:
  1741. {/* search xray function is not work in this release*/
  1742. // search x-ray resolution
  1743. //poPropItem = CPropItemPtr(new CPropItem());
  1744. //nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::SEARCH_RESOLUTION;
  1745. //poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::COMBO, FALSE);
  1746. //a_listPropItems.push_back(poPropItem);
  1747. //// low counts
  1748. //poPropItem = CPropItemPtr(new CPropItem());
  1749. //nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::LOW_COUNTS;
  1750. //poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE);
  1751. //a_listPropItems.push_back(poPropItem);
  1752. COTSXRayParamPtr pXrayParam = m_poMsrParams->GetXRayParam();
  1753. // analysis
  1754. bShow = pXrayParam->GetShowSpeed();
  1755. if (bShow)
  1756. {
  1757. poPropItem = CPropItemPtr(new CPropItem());
  1758. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_RESOLUTION;
  1759. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE, bShow);
  1760. a_listPropItems.push_back(poPropItem);
  1761. }
  1762. // scan mode
  1763. bShow = pXrayParam->GetShowScanMode();
  1764. if (bShow)
  1765. {
  1766. poPropItem = CPropItemPtr(new CPropItem());
  1767. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::SCAN_MODE;
  1768. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::COMBO, FALSE, bShow);
  1769. a_listPropItems.push_back(poPropItem);
  1770. }
  1771. // analysis counts
  1772. bShow = pXrayParam->GetShowExpCount();
  1773. if (bShow)
  1774. {
  1775. poPropItem = CPropItemPtr(new CPropItem());
  1776. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::ANALYSIS_COUNTS;
  1777. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, FALSE, bShow);
  1778. a_listPropItems.push_back(poPropItem);
  1779. }
  1780. }
  1781. break;
  1782. case OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::SEM:
  1783. {
  1784. // does SEM data (measure) set?
  1785. if (*(m_poSEMDataMsr.get()) == CSEMDataMsr())
  1786. {
  1787. // not set
  1788. // magnification
  1789. poPropItem = CPropItemPtr(new CPropItem());
  1790. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::MAGNIFICATION;
  1791. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::STRING, TRUE, TRUE);
  1792. a_listPropItems.push_back(poPropItem);
  1793. // pixel size
  1794. poPropItem = CPropItemPtr(new CPropItem());
  1795. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::PIXEL_SIZE;
  1796. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::STRING, TRUE, TRUE);
  1797. a_listPropItems.push_back(poPropItem);
  1798. // working distance
  1799. poPropItem = CPropItemPtr(new CPropItem());
  1800. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::WORKING_DISTANCE;
  1801. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::STRING, TRUE, TRUE);
  1802. a_listPropItems.push_back(poPropItem);
  1803. // total field
  1804. poPropItem = CPropItemPtr(new CPropItem());
  1805. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_FIELDS;
  1806. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, TRUE, TRUE);
  1807. a_listPropItems.push_back(poPropItem);
  1808. // total area
  1809. poPropItem = CPropItemPtr(new CPropItem());
  1810. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_TO_MEASURE_AREA;
  1811. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::DOUBLE, TRUE, TRUE);
  1812. a_listPropItems.push_back(poPropItem);
  1813. }
  1814. else
  1815. {
  1816. // set
  1817. // magnification
  1818. poPropItem = CPropItemPtr(new CPropItem());
  1819. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::MAGNIFICATION;
  1820. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::DOUBLE, FALSE, TRUE);
  1821. a_listPropItems.push_back(poPropItem);
  1822. // pixel size
  1823. poPropItem = CPropItemPtr(new CPropItem());
  1824. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::PIXEL_SIZE;
  1825. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::DOUBLE, FALSE, TRUE);
  1826. a_listPropItems.push_back(poPropItem);
  1827. // working distance
  1828. poPropItem = CPropItemPtr(new CPropItem());
  1829. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::WORKING_DISTANCE;
  1830. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::DOUBLE, TRUE, TRUE);
  1831. a_listPropItems.push_back(poPropItem);
  1832. // total field
  1833. poPropItem = CPropItemPtr(new CPropItem());
  1834. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_FIELDS;
  1835. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, TRUE, TRUE);
  1836. a_listPropItems.push_back(poPropItem);
  1837. // total area
  1838. poPropItem = CPropItemPtr(new CPropItem());
  1839. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_TO_MEASURE_AREA;
  1840. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::DOUBLE, TRUE, TRUE);
  1841. a_listPropItems.push_back(poPropItem);
  1842. }
  1843. }
  1844. break;
  1845. case OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::MEASURE_STATUS:
  1846. {
  1847. // measure status
  1848. poPropItem = CPropItemPtr(new CPropItem());
  1849. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::MEASURE_STATAU;
  1850. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::STRING, TRUE, TRUE);
  1851. a_listPropItems.push_back(poPropItem);
  1852. // has measure result?
  1853. if (HasMeasureResult())
  1854. {
  1855. // start time
  1856. poPropItem = CPropItemPtr(new CPropItem());
  1857. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::START_TIME;
  1858. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::TIME, TRUE, TRUE);
  1859. a_listPropItems.push_back(poPropItem);
  1860. // used time
  1861. poPropItem = CPropItemPtr(new CPropItem());
  1862. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::USED_TIME;
  1863. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::TIME_SPAN, TRUE, TRUE);
  1864. a_listPropItems.push_back(poPropItem);
  1865. // finish time
  1866. poPropItem = CPropItemPtr(new CPropItem());
  1867. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::FINISH_TIME;
  1868. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::TIME, TRUE, TRUE);
  1869. a_listPropItems.push_back(poPropItem);
  1870. // completed fields
  1871. poPropItem = CPropItemPtr(new CPropItem());
  1872. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::COMPLETED_FIELDS;
  1873. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, TRUE, TRUE);
  1874. a_listPropItems.push_back(poPropItem);
  1875. }
  1876. }
  1877. break;
  1878. case OTS_SAMPLE_PROP_GRID_ITEM_GROUPS::MEASURE_RESULTS:
  1879. {
  1880. // has measure result?
  1881. if (HasMeasureResult())
  1882. {
  1883. // radio
  1884. poPropItem = CPropItemPtr(new CPropItem());
  1885. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::RADIO;
  1886. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::DOUBLE, TRUE, TRUE);
  1887. a_listPropItems.push_back(poPropItem);
  1888. // total measured area
  1889. poPropItem = CPropItemPtr(new CPropItem());
  1890. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_AREA;
  1891. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, TRUE, TRUE);
  1892. a_listPropItems.push_back(poPropItem);
  1893. // total particles
  1894. poPropItem = CPropItemPtr(new CPropItem());
  1895. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE;
  1896. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, TRUE, TRUE);
  1897. a_listPropItems.push_back(poPropItem);
  1898. // total particle area
  1899. poPropItem = CPropItemPtr(new CPropItem());
  1900. nItemId = OTS_SAMPLE_PROP_GRID_ITEMS::TOTAL_PARTICLE_AREA;
  1901. poPropItem->SetSmplParameter(nItemId, OTS_ITEM_TYPES::INT, TRUE, TRUE);
  1902. a_listPropItems.push_back(poPropItem);
  1903. }
  1904. }
  1905. break;
  1906. default:
  1907. {
  1908. // something wrong here, return nullptr
  1909. return nullptr;
  1910. }
  1911. }
  1912. poPropItemGrp->SetItemsList(a_listPropItems);
  1913. // return property items group
  1914. return poPropItemGrp;
  1915. }
  1916. // calculate scan field size
  1917. int COTSSample::CalculateScanFileSize(double a_dPixelSize)
  1918. {
  1919. // scan field size
  1920. int nScanFiledSize = 0;
  1921. // make sure SEM is valid
  1922. if (!(*(m_poSEMDataMsr.get()) == CSEMDataMsr()))
  1923. {
  1924. // get image size
  1925. OTS_FIVE_TIES_OPTIONS nImageSizeId = m_poMsrParams->GetImageScanParam()->GetImagePixelSize();
  1926. long nResulotionId = RESOLUTION_ID_FIRST_TIE + (long)nImageSizeId;
  1927. int nImageSize = RESOLUTION_VALUE[nResulotionId].cx;
  1928. // calculate scan field size
  1929. nScanFiledSize = (int)((a_dPixelSize * (double)nImageSize) + 0.5);
  1930. }
  1931. // return scan field size
  1932. return nScanFiledSize;
  1933. }
  1934. }