Dimension.h 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. #pragma once
  2. #include <Array.h>
  3. #include <Critical.h>
  4. #include <Trie.h>
  5. #include "Chunk.h"
  6. #include "Entity.h"
  7. class World;
  8. class Dimension : public virtual Framework::Model3DCollection
  9. {
  10. private:
  11. int id;
  12. Framework::RCTrie<Chunk>* chunks;
  13. Framework::Array<Chunk*> chunkList;
  14. Framework::RCArray<Entity>* entities;
  15. Framework::Critical cs;
  16. void getAddrOf(Framework::Punkt cPos, char* addr) const;
  17. void getAddrOfWorld(Framework::Punkt wPos, char* addr) const;
  18. public:
  19. Dimension();
  20. ~Dimension();
  21. void forAll(std::function<void(Model3D*)> f) override;
  22. void render(std::function<void(Model3D*)> f) override;
  23. bool tick(std::function<void(Model3D*)> f, double time) override;
  24. void setId(int id);
  25. void api(char* message);
  26. Block* zBlock(Framework::Vec3<int> location);
  27. Block* getBlock(Framework::Vec3<int> location);
  28. void addEntity(Entity* entity);
  29. void setChunk(Chunk* chunk, Framework::Punkt center);
  30. bool hasChunck(int x, int y) const;
  31. Chunk* zChunk(Framework::Punkt wPos) const;
  32. void removeDistantChunks(Framework::Punkt wPos);
  33. void setBlock(Block* block);
  34. void removeBlock(Block* zBlock);
  35. Entity* zEntity(int id);
  36. Entity* getEntity(int id);
  37. void removeEntity(int id);
  38. int getId() const;
  39. inline static Framework::Vec3<int> chunkCoordinates(
  40. Framework::Vec3<int> worldLocation)
  41. {
  42. Framework::Vec3<int> result = worldLocation;
  43. result.x = result.x % CHUNK_SIZE;
  44. result.y = result.y % CHUNK_SIZE;
  45. if (result.x < 0) result.x += CHUNK_SIZE;
  46. if (result.y < 0) result.y += CHUNK_SIZE;
  47. return result;
  48. }
  49. };