OTSFieldData.h 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. #pragma once
  2. #include "OTSParticle.h"
  3. namespace OTSDATA {
  4. class __declspec(dllexport) COTSFieldData : public xmls::ISlo
  5. {
  6. public:
  7. // constructor
  8. COTSFieldData(); // constructor
  9. COTSFieldData(const COTSFieldData&); // copy constructor
  10. COTSFieldData(COTSFieldData*); // copy constructor
  11. COTSFieldData& operator=(const COTSFieldData&); // =operator
  12. BOOL operator==(const COTSFieldData&); // ==operator
  13. virtual ~COTSFieldData(); // destructor
  14. //void Serialize(CArchive& ar); // serializatio
  15. virtual void Serialize(bool isStoring, tinyxml2::XMLDocument *classDoc, tinyxml2::XMLElement *rootNode);
  16. // ID
  17. int GetId() { return m_nID; }
  18. void SetId(int a_nID) { m_nID = a_nID; }
  19. // position (from field center manager)
  20. CPoint GetPosition() { return m_poiPos; }
  21. void SetPosition(CPoint a_poiPos) { m_poiPos = a_poiPos; }
  22. // field file folder
  23. CString GetFieldFileFolder() { return m_strFieldFileFolder; }
  24. void SetFieldFileFolder(CString a_strFieldFileFolder) { m_strFieldFileFolder = a_strFieldFileFolder; }
  25. // particle list
  26. COTSParticleList& GetParticleList() { return m_listParticles; }
  27. void SetParticleList(COTSParticleList& a_listParticles, BOOL a_bClear = TRUE);
  28. // particle list
  29. COTSParticleList& GetBigParticleList() { return m_listBigParticles; }
  30. void SetBigParticleList(COTSParticleList& a_listParticles, BOOL a_bClear = TRUE);
  31. void AddParticle(COTSParticlePtr a_Particle) { m_listBigParticles.push_back(a_Particle); };
  32. //get bordered particles
  33. COTSParticleList GetTopBorderedBigParticles();
  34. //get bordered particles
  35. COTSParticleList GetBottomBorderedBigParticles();
  36. //get bordered particles
  37. COTSParticleList GetLeftBorderedBigParticles();
  38. //get bordered particles
  39. COTSParticleList GetRightBorderedBigParticles();
  40. // is empty
  41. BOOL IsEmpty() { return m_listParticles.empty(); }
  42. long Width;
  43. long Height;
  44. protected:
  45. // cleanup
  46. void Cleanup();
  47. // initialization
  48. void Init();
  49. // duplication
  50. void Duplicate(const COTSFieldData& a_oSource);
  51. // ID
  52. int m_nID;
  53. // position (from field center manager)
  54. CPoint m_poiPos;
  55. // field file folder
  56. CString m_strFieldFileFolder;
  57. // particle list
  58. COTSParticleList m_listParticles;
  59. //valid big particles
  60. COTSParticleList m_listBigParticles;//used for merging with other field later.
  61. };
  62. typedef std::shared_ptr<COTSFieldData> __declspec(dllexport) COTSFieldDataPtr;
  63. typedef std::vector<COTSFieldDataPtr> __declspec(dllexport) COTSFieldDataList;
  64. }