2025-02-06 01:05:44 +01:00

216 lines
4.8 KiB
C++

#include <cinttypes>
#include <cmath>
#include "Vapp.hpp"
#include "values/Dna.hpp"
#include <rlImGui.h>
#include <imgui.h>
#include <raylib.h>
const char select_user_id[] = "SELECT USER_ID FROM user_table GROUP BY USER_ID;";
constexpr int sizeOfCanvas = 1000;
void Vapp::init()
{
bigTexture = LoadRenderTexture(sizeOfCanvas * 4, sizeOfCanvas * 4);
treeTexture = LoadRenderTexture(sizeOfCanvas, sizeOfCanvas);
canvas.init(sizeOfCanvas);
DnaManager::setUp(&manager, 0);
sql::init();
sql::open(DB_NAME, &db);
sqlite3_stmt *stmt;
sql::prepare_v2(db, select_user_id, -1, &stmt, NULL);
while (sql::step(stmt) != SQL_DONE)
{
int type = sql::column_type(stmt, 0);
if (type != SQL_NULL)
{
int64_t user_id = sql::column_int64(stmt, 0);
ids.push_back(user_id);
}
}
sql::prepare_v2(db, max_gen, -1, &get_gen_num, nullptr);
}
void Vapp::update()
{
if (update_gen && selected_id >= 0)
{
sql::bind_int64(get_gen_num, 1, ids[selected_id]);
while (sql::step(get_gen_num) != SQL_DONE)
{
int type = sql::column_type(get_gen_num, 0);
if (type != SQL_NULL)
{
gens = sql::column_int64(get_gen_num, 0);
}
}
sql::reset(get_gen_num);
update_gen = false;
}
switch (stageOfDrawing)
{
case DrawingStage::setup:
setUpManager();
stageOfDrawing = DrawingStage::drawTree;
drawTreeIndex = 0;
drawX = 0;
drawY = 0;
canvas.newGen(treeTexture, &manager.vector[drawTreeIndex]);
break;
case DrawingStage::drawTree:
if (canvas.tick(treeTexture))
{
stageOfDrawing = DrawingStage::drawBig;
}
break;
case DrawingStage::drawBig:
BeginTextureMode(bigTexture);
DrawTexture(treeTexture.texture, drawX * sizeOfCanvas, drawY * sizeOfCanvas, WHITE);
EndTextureMode();
drawTreeIndex++;
if (drawTreeIndex < NUM_PER_GEN)
{
canvas.newGen(treeTexture, &manager.vector[drawTreeIndex]);
stageOfDrawing = DrawingStage::drawTree;
}
else
{
stageOfDrawing = DrawingStage::done;
}
drawX++;
if (drawX == 4)
{
drawY++;
drawX = 0;
}
if (drawY == 4)
{
drawY = 0;
}
break;
case DrawingStage::done:
enableAll = true;
break;
default:
break;
}
}
void Vapp::draw()
{
ClearBackground(RAYWHITE);
DrawTextureEx(bigTexture.texture, Vector2(0,0), 0.0f, 0.25f, WHITE);
ImGui::DockSpaceOverViewport(0, NULL, ImGuiDockNodeFlags_PassthruCentralNode);
if (ImGui::BeginMainMenuBar())
{
ImGui::MenuItem("Demo Window", nullptr, &showDemoWindow, enableAll);
ImGui::MenuItem("Selection", nullptr, &showSelection, enableAll);
if (ImGui::MenuItem("Draw", nullptr, false, enableAll))
{
enableAll = false;
showSelection = false;
stageOfDrawing = DrawingStage::setup;
}
ImGui::EndMainMenuBar();
}
if (showDemoWindow)
ImGui::ShowDemoWindow(&showDemoWindow);
if (showSelection)
{
ImGui::Begin("Selection", &showSelection);
if (ImGui::BeginListBox("##list_id", ImVec2(ImGui::GetContentRegionAvail().x * 0.5f, -FLT_MIN)))
{
for (int n = 0; n < ids.size(); n++)
{
const bool is_selected = (selected_id == n);
if (ImGui::Selectable(TextFormat("%d", ids[n]), is_selected))
{
selected_id = n;
gens = -1;
update_gen = true;
}
}
ImGui::EndListBox();
}
ImGui::SameLine();
if (ImGui::BeginListBox("##list_gen", ImVec2(-FLT_MIN, -FLT_MIN)))
{
for (int n = 0; n <= gens; n++)
{
const bool is_selected = (selected_gen == n);
if (ImGui::Selectable(TextFormat("%d", n), is_selected))
selected_gen = n;
}
ImGui::EndListBox();
}
ImGui::End();
}
}
void Vapp::deinit()
{
UnloadRenderTexture(treeTexture);
UnloadRenderTexture(bigTexture);
canvas.deinit();
sql::close(db);
sql::shutdown();
}
void Vapp::setUpManager()
{
sqlite3_stmt *get_gen_stmt;
sql::prepare_v2(db, get_gen, -1, &get_gen_stmt, NULL);
DnaManager::cleanUp(&manager, selected_id);
int lodedGen = -1;
while (lodedGen < selected_gen)
{
sql::bind_int64(get_gen_stmt, 1, manager.id);
sql::bind_int64(get_gen_stmt, 2, manager.generation);
bool new_gen = false;
while (sql::step(get_gen_stmt) != SQL_DONE)
{
int64_t pos = sql::column_int64(get_gen_stmt, 1);
int64_t liked = sql::column_int64(get_gen_stmt, 2);
UiUnit unit = DnaManager::next(&manager);
if ((unit.index != pos))
{
// DOTO: SET ERROR
sql::finalize(get_gen_stmt);
return;
}
unit.liked = (Liked)liked;
new_gen = DnaManager::like(unit, &manager);
}
if (manager.generation < selected_gen)
{
DnaManager::newGen(&manager);
}
sql::reset(get_gen_stmt);
lodedGen++;
}
sql::finalize(get_gen_stmt);
}