]> git.localhorst.tv Git - blank.git/blobdiff - src/block.hpp
updated description and TODO list
[blank.git] / src / block.hpp
index 23c3979feba4ecd36d9867512901b81229a10fef..0d7d75a5dc8e68460f2413354763e3fbef2e4abf 100644 (file)
@@ -42,6 +42,30 @@ struct Block {
 
        const glm::mat4 &Transform() const;
 
+       Face GetFace() const { return Face(orient / 4); }
+       void SetFace(Face face) { orient = face * TURN_COUNT + GetTurn(); }
+       Turn GetTurn() const { return Turn(orient % 4); }
+       void SetTurn(Turn turn) { orient = GetFace() * TURN_COUNT + turn; }
+
+       static glm::tvec3<int> FaceNormal(Face face) {
+               switch (face) {
+                       case FACE_UP:
+                               return { 0, 1, 0 };
+                       case FACE_DOWN:
+                               return { 0, -1, 0 };
+                       case FACE_RIGHT:
+                               return { 1, 0, 0 };
+                       case FACE_LEFT:
+                               return { -1, 0, 0 };
+                       case FACE_FRONT:
+                               return { 0, 0, 1 };
+                       case FACE_BACK:
+                               return { 0, 0, -1 };
+                       default:
+                               return { 0, 0, 0 };
+               }
+       }
+
 };
 
 
@@ -54,15 +78,22 @@ struct BlockType {
 
        Block::Type id;
 
+       int luminosity;
+
        bool visible;
+       bool block_light;
 
        struct Faces {
-               bool up;
-               bool down;
-               bool right;
-               bool left;
-               bool front;
-               bool back;
+               bool face[Block::FACE_COUNT];
+               Faces &operator =(const Faces &other) {
+                       for (int i = 0; i < Block::FACE_COUNT; ++i) {
+                               face[i] = other.face[i];
+                       }
+                       return *this;
+               }
+               bool operator [](Block::Face f) const {
+                       return face[f];
+               }
        } fill;
 
        explicit BlockType(
@@ -73,6 +104,7 @@ struct BlockType {
 
        static const NullShape DEFAULT_SHAPE;
 
+       bool FaceFilled(const Block &, Block::Face) const;
 
        void FillModel(
                Model::Buffer &m,