OTSEDSOxford.cpp 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  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. // Quatification
  139. void COTSEDSOxford::SetQuantification(BOOL a_bQuantification)
  140. {
  141. // check oxford controller
  142. ASSERT(m_oxfordImpl);
  143. if (!m_oxfordImpl)
  144. {
  145. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::SetQuantification: invalid m_oxfordImpl."));
  146. return;
  147. }
  148. m_oxfordImpl->SetQuantificationFlag(a_bQuantification);
  149. }
  150. BOOL COTSEDSOxford::GetQuantification()
  151. {
  152. // check oxford controller
  153. ASSERT(m_oxfordImpl);
  154. if (!m_oxfordImpl)
  155. {
  156. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::GetQuantification: invalid m_oxfordImpl."));
  157. return FALSE;
  158. }
  159. //// collect x-Ray points (area scan)
  160. //return m_oxfordImpl->GetQuantificationFlag();
  161. return FALSE;
  162. }
  163. // Get number of channels
  164. DWORD COTSEDSOxford::GetNumberOfChannels(void)
  165. {
  166. return (DWORD)2000;
  167. }
  168. // Get the x-Ray data
  169. DWORD* COTSEDSOxford::GetXRayData()
  170. {
  171. return m_nRayData;
  172. }
  173. BOOL COTSEDSOxford::IsSupportQuantification()
  174. {
  175. return TRUE;
  176. }
  177. BOOL COTSEDSOxford::GetQuantificationMethods(std::vector<CString>& a_vMethods)
  178. {
  179. // check Oxford controller
  180. ASSERT(m_oxfordImpl);
  181. if (!m_oxfordImpl)
  182. {
  183. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::GetQuantificationMethods: invalid m_pOxfordImpl."));
  184. return FALSE;
  185. }
  186. //return m_oxfordImpl->GetQuantificationMethods(a_vMethods);
  187. return FALSE;
  188. }
  189. BOOL COTSEDSOxford::QuantifyXrayPoint(CPosXray* a_pXRayPoint, LPCTSTR a_sMethodName)
  190. {
  191. // check Oxford controller
  192. ASSERT(m_oxfordImpl);
  193. if (!m_oxfordImpl)
  194. {
  195. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::QuantifyXrayPoint: invalid m_pOxfordImpl."));
  196. return FALSE;
  197. }
  198. //return m_oxfordImpl->QuantifyXrayPoint(a_pXRayPoint, a_sMethodName);
  199. return FALSE;
  200. }
  201. BOOL COTSEDSOxford::QuantifySpectrumFile(LPCTSTR a_sFilePathName, LPCTSTR a_sMethodName, CElementChemistriesList& a_listElementChemistry)
  202. {
  203. // check Oxford controller
  204. ASSERT(m_oxfordImpl);
  205. if (!m_oxfordImpl)
  206. {
  207. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::QuantifySpectrumFile: invalid m_pOxfordImpl."));
  208. return FALSE;
  209. }
  210. return FALSE;
  211. //return m_oxfordImpl->QuantifySpectrumFile(a_sFilePathName, a_sMethodName, a_listElementChemistry);
  212. }
  213. BOOL COTSEDSOxford::QuantifySpectrumOut(DWORD a_nMilliseconds, long* a_pCounts, DWORD a_nBufferSize, CElementChemistriesList& a_listElementChemistry)
  214. {
  215. // check Oxford controller
  216. ASSERT(m_oxfordImpl);
  217. if (!m_oxfordImpl)
  218. {
  219. LogErrorTrace(__FILE__, __LINE__, _T("COTSEDSOxford::QuantifySpectrumOut: invalid m_pOxfordImpl."));
  220. return FALSE;
  221. }
  222. return FALSE;
  223. //return m_oxfordImpl->QuantifySpectrumOut(a_nMilliseconds, a_pCounts, a_nBufferSize, a_listElementChemistry);
  224. }
  225. }
  226. // namespace Controller