X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fworld.hpp;h=9fb07798c3f976569d4052cb916dc359d702adca;hb=e7a968ef0ae496d1d45d63a25df59db31f9b966f;hp=9f29ab4ee4ff09b579689765b96872a2eb5f8766;hpb=5700ea3c08ea5e4a5c743f0413b65dc8eebfd220;p=blank.git diff --git a/src/world.hpp b/src/world.hpp index 9f29ab4..9fb0779 100644 --- a/src/world.hpp +++ b/src/world.hpp @@ -19,11 +19,13 @@ struct BlockType { bool visible; glm::vec3 color; + glm::vec3 outline_color; constexpr explicit BlockType( bool v = false, - const glm::vec3 &color = { 1, 1, 1 }) - : id(-1), visible(v), color(color) { } + const glm::vec3 &color = { 1, 1, 1 }, + const glm::vec3 &outline_color = { -1, -1, -1 }) + : id(-1), visible(v), color(color), outline_color(outline_color) { } static const BlockType DEFAULT; @@ -37,6 +39,18 @@ struct BlockType { void FillModel(const glm::vec3 &pos, Model &m) const { FillVBO(pos, m.vertices, m.colors, m.normals); + m.Invalidate(); + } + + + void FillOutlineVBO( + std::vector &vertices, + std::vector &colors + ) const; + + void FillOutlineModel(OutlineModel &m) const { + FillOutlineVBO(m.vertices, m.colors); + m.Invalidate(); } };