OTSEDSOxford.cpp 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. #include "stdafx.h"
  2. #include "OTSEDSOxford.h"
  3. #ifdef _DEBUG
  4. #define new DEBUG_NEW
  5. #endif
  6. namespace OTSController
  7. {
  8. COTSEDSOxford::COTSEDSOxford(void)
  9. {
  10. //LogTrace(__FILE__, __LINE__, _T("%s controller created"), (LPCTSTR)GetName());
  11. Init();
  12. }
  13. COTSEDSOxford::~COTSEDSOxford(void)
  14. {
  15. //LogTrace(__FILE__, __LINE__, _T("%s controller finished"), (LPCTSTR)GetName());
  16. }
  17. // initialisation
  18. BOOL COTSEDSOxford::Init()
  19. {
  20. // get bruker initialize controller
  21. if (!m_oxfordImpl)
  22. {
  23. // get Oxford controller
  24. m_oxfordImpl = OxfordImpl::GetInstance();
  25. }
  26. BOOL ifconnect=true;
  27. if (!m_oxfordImpl->IsConnected())
  28. {
  29. ifconnect=m_oxfordImpl->Connect();
  30. }
  31. return ifconnect;
  32. }
  33. BOOL COTSEDSOxford::CollectSpectrum(DWORD a_nMilliseconds)
  34. {
  35. if (!m_oxfordImpl)
  36. {
  37. ASSERT(m_oxfordImpl);
  38. if (!m_oxfordImpl)
  39. {
  40. return FALSE;
  41. }
  42. }
  43. if (!m_oxfordImpl->CollectXrayData(a_nMilliseconds, (long* )m_nRayData, (DWORD)EDSConst::XANA_CHANNELS))
  44. {
  45. LogErrorTrace(__FILE__, __LINE__, _T("Collect spectrum at %d milliseconds failed."), a_nMilliseconds);
  46. ASSERT(m_oxfordImpl);
  47. if (!m_oxfordImpl)
  48. {
  49. return FALSE;
  50. }
  51. }
  52. // return method return flag
  53. return true;
  54. }
  55. BOOL COTSEDSOxford::CollectSpectrum(DWORD a_nMilliseconds, const CPoint& a_oPoint)
  56. {
  57. if (!m_oxfordImpl)
  58. {
  59. ASSERT(m_oxfordImpl);
  60. if (!m_oxfordImpl)
  61. {
  62. return FALSE;
  63. }
  64. }
  65. if (!m_oxfordImpl->CollectXrayDataAtPos(a_oPoint.x, a_oPoint.y, a_nMilliseconds, (long*)m_nRayData, (DWORD)EDSConst::XANA_CHANNELS))
  66. {
  67. LogErrorTrace(__FILE__, __LINE__, _T("Collect spectrum at %d milliseconds failed."), a_nMilliseconds);
  68. ASSERT(m_oxfordImpl);
  69. if (!m_oxfordImpl)
  70. {
  71. return FALSE;
  72. }
  73. }
  74. return true;
  75. }
  76. BOOL COTSEDSOxford::CollectSpectrum(DWORD a_nMilliseconds, long* a_pCounts, DWORD a_nBufferSize)
  77. {
  78. if (!m_oxfordImpl)
  79. {
  80. ASSERT(m_oxfordImpl);
  81. if (!m_oxfordImpl)
  82. {
  83. return FALSE;
  84. }
  85. }
  86. if (!m_oxfordImpl->CollectXrayData(a_nMilliseconds, a_pCounts, a_nBufferSize))
  87. {
  88. LogErrorTrace(__FILE__, __LINE__, _T("Collect spectrum at %d milliseconds failed."), a_nMilliseconds);
  89. ASSERT(m_oxfordImpl);
  90. if (!m_oxfordImpl)
  91. {
  92. return FALSE;
  93. }
  94. }
  95. // return method return flag
  96. return true;
  97. }
  98. BOOL COTSEDSOxford::GetXRayByPoints(std::vector<CPosXrayPtr>& a_vXRayPoints, const DWORD a_nXRayAQTime)
  99. {
  100. // check Oxford controller
  101. ASSERT(m_oxfordImpl);
  102. if (!m_oxfordImpl)
  103. {
  104. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::GetXRayByPoints: invalid m_poxfordImpl."));
  105. return FALSE;
  106. }
  107. // collect x-ray points (point scan)
  108. if (!m_oxfordImpl->GetXRayByPoints(a_vXRayPoints, a_nXRayAQTime))
  109. {
  110. // failed to call Oxford controller CollectXRayPoints method.
  111. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::CollectXRayPoints: failed to call Oxford controller CollectXRayPoints method."));
  112. //return FALSE;
  113. }
  114. // ok, return TRUE
  115. return TRUE;
  116. }
  117. BOOL COTSEDSOxford::GetXRayByFeatures(std::vector<CPosXrayPtr>& a_listXRayPoints,
  118. std::vector<BrukerFeature>& a_listFeatures,
  119. const DWORD a_nXRayAQTime)
  120. {
  121. // check Oxford controller
  122. ASSERT(m_oxfordImpl);
  123. if (!m_oxfordImpl)
  124. {
  125. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::GetXRayByFeatures: invalid m_oxfordImpl."));
  126. return FALSE;
  127. }
  128. // collect x-Ray points (area scan)
  129. if (!m_oxfordImpl->GetXRayByFeatures(a_listXRayPoints, a_listFeatures, a_nXRayAQTime))
  130. {
  131. // failed to call oxford controller CollectXRayPointsByFeatures method.
  132. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::CollectXRayPointsByFeatures: failed to call Oxford controller CollectXRayPointsByFeatures method."));
  133. return FALSE;
  134. }
  135. // ok, return TRUE
  136. return TRUE;
  137. }
  138. BOOL COTSEDSOxford::StopXrayAcquistion()
  139. {
  140. ASSERT(m_oxfordImpl);
  141. if (!m_oxfordImpl)
  142. {
  143. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::GetXRayByFeatures: invalid m_oxfordImpl."));
  144. return FALSE;
  145. }
  146. m_oxfordImpl->StopCollectXrayData();
  147. }
  148. // Quatification
  149. void COTSEDSOxford::SetQuantification(BOOL a_bQuantification)
  150. {
  151. // check oxford controller
  152. ASSERT(m_oxfordImpl);
  153. if (!m_oxfordImpl)
  154. {
  155. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::SetQuantification: invalid m_oxfordImpl."));
  156. return;
  157. }
  158. m_oxfordImpl->SetQuantificationFlag(a_bQuantification);
  159. }
  160. BOOL COTSEDSOxford::GetQuantification()
  161. {
  162. // check oxford controller
  163. ASSERT(m_oxfordImpl);
  164. if (!m_oxfordImpl)
  165. {
  166. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::GetQuantification: invalid m_oxfordImpl."));
  167. return FALSE;
  168. }
  169. //// collect x-Ray points (area scan)
  170. //return m_oxfordImpl->GetQuantificationFlag();
  171. return FALSE;
  172. }
  173. // Get number of channels
  174. DWORD COTSEDSOxford::GetNumberOfChannels(void)
  175. {
  176. return (DWORD)2000;
  177. }
  178. // Get the x-Ray data
  179. DWORD* COTSEDSOxford::GetXRayData()
  180. {
  181. return m_nRayData;
  182. }
  183. BOOL COTSEDSOxford::IsSupportQuantification()
  184. {
  185. return TRUE;
  186. }
  187. BOOL COTSEDSOxford::GetQuantificationMethods(std::vector<CString>& a_vMethods)
  188. {
  189. // check Oxford controller
  190. ASSERT(m_oxfordImpl);
  191. if (!m_oxfordImpl)
  192. {
  193. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::GetQuantificationMethods: invalid m_pOxfordImpl."));
  194. return FALSE;
  195. }
  196. //return m_oxfordImpl->GetQuantificationMethods(a_vMethods);
  197. return FALSE;
  198. }
  199. BOOL COTSEDSOxford::QuantifyXrayPoint(CPosXray* a_pXRayPoint, LPCTSTR a_sMethodName)
  200. {
  201. // check Oxford controller
  202. ASSERT(m_oxfordImpl);
  203. if (!m_oxfordImpl)
  204. {
  205. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::QuantifyXrayPoint: invalid m_pOxfordImpl."));
  206. return FALSE;
  207. }
  208. //return m_oxfordImpl->QuantifyXrayPoint(a_pXRayPoint, a_sMethodName);
  209. return FALSE;
  210. }
  211. BOOL COTSEDSOxford::QuantifySpectrumFile(LPCTSTR a_sFilePathName, LPCTSTR a_sMethodName, CElementChemistriesList& a_listElementChemistry)
  212. {
  213. // check Oxford controller
  214. ASSERT(m_oxfordImpl);
  215. if (!m_oxfordImpl)
  216. {
  217. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::QuantifySpectrumFile: invalid m_pOxfordImpl."));
  218. return FALSE;
  219. }
  220. return FALSE;
  221. //return m_oxfordImpl->QuantifySpectrumFile(a_sFilePathName, a_sMethodName, a_listElementChemistry);
  222. }
  223. BOOL COTSEDSOxford::QuantifySpectrumOut(DWORD a_nMilliseconds, long* a_pCounts, DWORD a_nBufferSize, CElementChemistriesList& a_listElementChemistry)
  224. {
  225. // check Oxford controller
  226. ASSERT(m_oxfordImpl);
  227. if (!m_oxfordImpl)
  228. {
  229. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::QuantifySpectrumOut: invalid m_pOxfordImpl."));
  230. return FALSE;
  231. }
  232. return FALSE;
  233. //return m_oxfordImpl->QuantifySpectrumOut(a_nMilliseconds, a_pCounts, a_nBufferSize, a_listElementChemistry);
  234. }
  235. }
  236. // namespace Controller