OTSFieldData.h 2.6 KB

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