X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fblock.cpp;h=fa39790ee35e0e396224d12581ed102baba1083e;hb=b4995967309bf5570161db2287e27b84ca94ab9a;hp=02e8476c4a2af7cf9ec407fd76040acf8c057dba;hpb=804bde3fc09e4317eef629861638a68bfad3e343;p=blank.git diff --git a/src/block.cpp b/src/block.cpp index 02e8476..fa39790 100644 --- a/src/block.cpp +++ b/src/block.cpp @@ -1,36 +1,85 @@ #include "block.hpp" +#include "geometry.hpp" + +#include +#include + namespace blank { -const BlockType BlockType::DEFAULT; +namespace { + +const glm::mat4 block_transforms[Block::DIR_COUNT * Block::ROT_COUNT] = { + glm::mat4(1.0f), + glm::eulerAngleY(PI_0p5), + glm::eulerAngleY(PI), + glm::eulerAngleY(PI_1p5), + glm::eulerAngleX(PI), + glm::eulerAngleYX(PI_0p5, PI), + glm::eulerAngleYX(PI, PI), + glm::eulerAngleYX(PI_1p5, PI), + glm::eulerAngleZ(PI_0p5), + glm::eulerAngleYZ(PI_0p5, PI_0p5), + glm::eulerAngleYZ(PI, PI_0p5), + glm::eulerAngleYZ(PI_1p5, PI_0p5), + glm::eulerAngleZ(PI_1p5), + glm::eulerAngleYZ(PI_0p5, PI_1p5), + glm::eulerAngleYZ(PI, PI_1p5), + glm::eulerAngleYZ(PI_1p5, PI_1p5), + glm::eulerAngleX(PI_0p5), + glm::eulerAngleYX(PI_0p5, PI_0p5), + glm::eulerAngleYX(PI, PI_0p5), + glm::eulerAngleYX(PI_1p5, PI_0p5), + glm::eulerAngleX(PI_1p5), + glm::eulerAngleYX(PI_0p5, PI_1p5), + glm::eulerAngleYX(PI, PI_1p5), + glm::eulerAngleYX(PI_1p5, PI_1p5), +}; + +} + +const glm::mat4 &Block::Transform() const { + return block_transforms[orient]; +} + + const NullShape BlockType::DEFAULT_SHAPE; -void BlockType::FillVBO( - const glm::vec3 &pos, - std::vector &vertices, - std::vector &colors, - std::vector &normals +BlockType::BlockType(bool v, const glm::vec3 &col, const Shape *s) +: shape(s) +, color(col) +, outline_color(-1, -1, -1) +, id(0) +, visible(v) +, fill({ false, false, false, false, false, false }) { + +} + +void BlockType::FillModel( + Model::Buffer &buf, + const glm::mat4 &transform, + Model::Index idx_offset ) const { - shape->Vertices(vertices, pos); - colors.insert(colors.end(), shape->VertexCount(), color); - shape->Normals(normals); + shape->Vertices(buf.vertices, buf.normals, buf.indices, transform, idx_offset); + buf.colors.insert(buf.colors.end(), shape->VertexCount(), color); } -void BlockType::FillOutlineVBO( - std::vector &vertices, - std::vector &colors +void BlockType::FillOutlineModel( + OutlineModel &model, + const glm::vec3 &pos_offset, + OutlineModel::Index idx_offset ) const { - shape->Outline(vertices); - colors.insert(colors.end(), shape->OutlineCount(), outline_color); + shape->Outline(model.vertices, model.indices, pos_offset, idx_offset); + model.colors.insert(model.colors.end(), shape->OutlineCount(), outline_color); } BlockTypeRegistry::BlockTypeRegistry() { - Add(BlockType::DEFAULT); + Add(BlockType()); } -int BlockTypeRegistry::Add(const BlockType &t) { +Block::Type BlockTypeRegistry::Add(const BlockType &t) { int id = types.size(); types.push_back(t); types.back().id = id;