Add DNA to tree
This commit is contained in:
		| @@ -10,9 +10,11 @@ public: | |||||||
|   ~Canvas() = default; |   ~Canvas() = default; | ||||||
|   void init(int size); |   void init(int size); | ||||||
|   void deinit(); |   void deinit(); | ||||||
|   void newGen(RenderTexture2D& target); |   void newGen(RenderTexture2D &target); | ||||||
|  |  | ||||||
| private: | private: | ||||||
|   BackGround backGround; |   BackGround backGround; | ||||||
|   Tree tree; |   Tree tree; | ||||||
|  |  | ||||||
|  |   Dna dna = {0}; | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -3,14 +3,7 @@ | |||||||
| #include <list> | #include <list> | ||||||
| #include <raylib.h> | #include <raylib.h> | ||||||
|  |  | ||||||
| #define MAX_DEPTH 11 | #include "values/Dna.hpp" | ||||||
|  |  | ||||||
| struct Branch |  | ||||||
| { |  | ||||||
|   Color color; |  | ||||||
|   uint8_t numOfBranches; |  | ||||||
|   float lenghthRatio; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| struct DrawArgs | struct DrawArgs | ||||||
| { | { | ||||||
| @@ -27,16 +20,16 @@ public: | |||||||
|   Tree() = default; |   Tree() = default; | ||||||
|   ~Tree() = default; |   ~Tree() = default; | ||||||
|   void init(int size); |   void init(int size); | ||||||
|   void newGen(); |   void draw(Dna *dna); | ||||||
|  |  | ||||||
| private: | private: | ||||||
|  |   Dna *m_dna; | ||||||
|  |  | ||||||
|   int size = 0; |   int size = 0; | ||||||
|   Vector2 start = {0}; |   Vector2 start = {0}; | ||||||
|   std::vector<Branch> branches; |  | ||||||
|   std::list<DrawArgs> draw_calls; |   std::list<DrawArgs> draw_calls; | ||||||
|  |  | ||||||
|   void generateBranches(); |   void generateBranches(); | ||||||
|   void drawTree(); |  | ||||||
|   void drawBranch(); |   void drawBranch(); | ||||||
|   Vector2 drawLine(); |   Vector2 drawLine(); | ||||||
| }; | }; | ||||||
| @@ -1,4 +1,12 @@ | |||||||
|  | #ifndef DNA_H | ||||||
|  | #define DNA_H | ||||||
|  |  | ||||||
| #include <cinttypes> | #include <cinttypes> | ||||||
|  | #include <array> | ||||||
|  |  | ||||||
|  | #include <raylib.h> | ||||||
|  |  | ||||||
|  | #define MAX_DEPTH 11 | ||||||
|  |  | ||||||
| struct uint128 | struct uint128 | ||||||
| { | { | ||||||
| @@ -15,6 +23,13 @@ struct Moon | |||||||
|   float size; |   float size; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | struct Branch | ||||||
|  | { | ||||||
|  |   Color color; | ||||||
|  |   uint8_t numOfBranches; | ||||||
|  |   float lenghthRatio; | ||||||
|  | }; | ||||||
|  |  | ||||||
| struct Dna | struct Dna | ||||||
| { | { | ||||||
|   Moon moon; |   Moon moon; | ||||||
| @@ -22,6 +37,9 @@ struct Dna | |||||||
|   int time; |   int time; | ||||||
|   uint128 mountenSeed; |   uint128 mountenSeed; | ||||||
|   uint128 starSeed; |   uint128 starSeed; | ||||||
|  |   std::array<Branch, MAX_DEPTH> branches; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| Dna newDna(); | void newDna(Dna &dna); | ||||||
|  |  | ||||||
|  | #endif /* DNA_H */ | ||||||
|   | |||||||
| @@ -11,10 +11,10 @@ void Canvas::newGen(RenderTexture2D &target) | |||||||
|   BeginTextureMode(target); |   BeginTextureMode(target); | ||||||
|   ClearBackground(WHITE); |   ClearBackground(WHITE); | ||||||
|  |  | ||||||
|   Dna dna = newDna(); |   newDna(dna); | ||||||
|  |  | ||||||
|   backGround.draw(&dna); |   backGround.draw(&dna); | ||||||
|   tree.newGen(); |   tree.draw(&dna); | ||||||
|  |  | ||||||
|   EndTextureMode(); |   EndTextureMode(); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,7 +3,6 @@ | |||||||
| #include <raymath.h> | #include <raymath.h> | ||||||
| #include "canvas/Tree.hpp" | #include "canvas/Tree.hpp" | ||||||
| #include "Math.hpp" | #include "Math.hpp" | ||||||
| #include "values/mrand.hpp" |  | ||||||
|  |  | ||||||
| // Public | // Public | ||||||
| void Tree::init(int size) | void Tree::init(int size) | ||||||
| @@ -11,15 +10,18 @@ void Tree::init(int size) | |||||||
|   this->size = size; |   this->size = size; | ||||||
|   start.x = size / 2; |   start.x = size / 2; | ||||||
|   start.y = size; |   start.y = size; | ||||||
|  |  | ||||||
|   branches.assign(11, {}); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void Tree::newGen() | void Tree::draw(Dna *dna) | ||||||
| { | { | ||||||
|   generateBranches(); |   m_dna = dna; | ||||||
|  |   draw_calls.push_back({start, 0, (float)size / 4, 1}); | ||||||
|  |  | ||||||
|   drawTree(); |   while (!draw_calls.empty()) | ||||||
|  |   { | ||||||
|  |     drawBranch(); | ||||||
|  |     draw_calls.pop_front(); | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| // Private | // Private | ||||||
| @@ -40,7 +42,7 @@ Vector2 Tree::drawLine() | |||||||
|   for (float i = 0; i < 1; i += fstep) |   for (float i = 0; i < 1; i += fstep) | ||||||
|   { |   { | ||||||
|     Vector2 point = Vector2Lerp(arg.start, end, i); |     Vector2 point = Vector2Lerp(arg.start, end, i); | ||||||
|     Color color = ColorLerp(branches[arg.dep - 1].color, branches[arg.dep].color, i); |     Color color = ColorLerp(m_dna->branches[arg.dep - 1].color, m_dna->branches[arg.dep].color, i); | ||||||
|     DrawCircleV(point, thick, color); |     DrawCircleV(point, thick, color); | ||||||
|   } |   } | ||||||
|   return end; |   return end; | ||||||
| @@ -54,41 +56,13 @@ void Tree::drawBranch() | |||||||
|  |  | ||||||
|   Vector2 next = drawLine(); |   Vector2 next = drawLine(); | ||||||
|  |  | ||||||
|   float next_len = branches[arg.dep].lenghthRatio; |   float next_len = m_dna->branches[arg.dep].lenghthRatio; | ||||||
|   float sectors = branches[arg.dep].numOfBranches + 1; |   float sectors = m_dna->branches[arg.dep].numOfBranches + 1; | ||||||
|   float degres = 180.0f / sectors; |   float degres = 180.0f / sectors; | ||||||
|  |  | ||||||
|   for (size_t i = 0; i < branches[arg.dep].numOfBranches; i++) |   for (size_t i = 0; i < m_dna->branches[arg.dep].numOfBranches; i++) | ||||||
|   { |   { | ||||||
|     float newAngle = arg.angleDeg - 90 + (degres * (i + 1)); |     float newAngle = arg.angleDeg - 90 + (degres * (i + 1)); | ||||||
|     draw_calls.push_back({next, newAngle, arg.lenghth * next_len, arg.dep + 1}); |     draw_calls.push_back({next, newAngle, arg.lenghth * next_len, arg.dep + 1}); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| void Tree::drawTree() |  | ||||||
| { |  | ||||||
|   draw_calls.push_back({start, 0, (float)size / 4, 1}); |  | ||||||
|  |  | ||||||
|   while (!draw_calls.empty()) |  | ||||||
|   { |  | ||||||
|     drawBranch(); |  | ||||||
|     draw_calls.pop_front(); |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void Tree::generateBranches() |  | ||||||
| { |  | ||||||
|   for (size_t i = 0; i < MAX_DEPTH; i++) |  | ||||||
|   { |  | ||||||
|     uint8_t r = mrand::getValue(0, 255); |  | ||||||
|     uint8_t g = mrand::getValue(0, 255); |  | ||||||
|     uint8_t b = mrand::getValue(0, 255); |  | ||||||
|     branches[i].color = {r, g, b, 255}; |  | ||||||
|  |  | ||||||
|     branches[i].numOfBranches = mrand::getValue(1, 3); |  | ||||||
|  |  | ||||||
|     branches[i].lenghthRatio = ((float)mrand::getValue(600, 700)) / 1000.0f; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   branches[0].color = branches[1].color; |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -5,9 +5,8 @@ | |||||||
|  |  | ||||||
| #include <raymath.h> | #include <raymath.h> | ||||||
|  |  | ||||||
| Dna newDna() | void newDna(Dna &dna) | ||||||
| { | { | ||||||
|   Dna dna = {0}; |  | ||||||
|   dna.moon = {mrand::getFloat(), mrand::getFloat(), mrand::getFloat()}; |   dna.moon = {mrand::getFloat(), mrand::getFloat(), mrand::getFloat()}; | ||||||
|   dna.colorSet = mrand::getValue(0, 3); |   dna.colorSet = mrand::getValue(0, 3); | ||||||
|   dna.time = std::floor(Remap(mrand::getFloat(), 0, 1, 4, 0)); |   dna.time = std::floor(Remap(mrand::getFloat(), 0, 1, 4, 0)); | ||||||
| @@ -21,5 +20,19 @@ Dna newDna() | |||||||
|   dna.starSeed.c = mrand::getInt(); |   dna.starSeed.c = mrand::getInt(); | ||||||
|   dna.starSeed.d = mrand::getInt(); |   dna.starSeed.d = mrand::getInt(); | ||||||
|  |  | ||||||
|   return dna; |   for (size_t i = 0; i < MAX_DEPTH; i++) | ||||||
|  |   { | ||||||
|  |     uint8_t r = mrand::getValue(0, 255); | ||||||
|  |     uint8_t g = mrand::getValue(0, 255); | ||||||
|  |     uint8_t b = mrand::getValue(0, 255); | ||||||
|  |     dna.branches[i].color = {r, g, b, 255}; | ||||||
|  |  | ||||||
|  |     dna.branches[i].numOfBranches = mrand::getValue(1, 3); | ||||||
|  |  | ||||||
|  |     dna.branches[i].lenghthRatio = ((float)mrand::getValue(600, 700)) / 1000.0f; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   dna.branches[0].color = dna.branches[1].color; | ||||||
|  |  | ||||||
|  |   return; | ||||||
| } | } | ||||||
		Reference in New Issue
	
	Block a user