/*
* Copyright (C) 2024 Brett Terpstra
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
#include
#include "blt/gfx/renderer/resource_manager.h"
#include "blt/gfx/renderer/batch_2d_renderer.h"
#include "blt/gfx/renderer/camera.h"
#include
#include
#include
#include
#include
#include
constexpr blt::size_t PARTICLE_COUNT = 8192;
blt::gfx::matrix_state_manager global_matrices;
blt::gfx::resource_manager resources;
blt::gfx::batch_renderer_2d renderer_2d(resources, global_matrices);
blt::gfx::first_person_camera camera;
// use types for state that way you are not confused about what is happening?
class unique_vao_t
{
public:
unique_vao_t(): vaoID(0)
{}
void create()
{
#if blt_debug_has_flag(BLT_DEBUG_CONTRACTS)
BLT_CONTRACT(!vaoID, "VAO already created");
#endif
vaoID = 0;
glGenVertexArrays(1, &*vaoID);
}
private:
std::optional vaoID;
};
struct particle_t
{
blt::vec2 position;
blt::vec2 velocity;
blt::vec2 acceleration;
static particle_t make_particle()
{
blt::random::random_t random{std::random_device()()};
return {blt::vec2{random.get(0.0f, 500.0f), random.get(0.0f, 500.0f)}, blt::vec2{}, blt::vec2{}};
}
};
std::unique_ptr particle_vao;
std::unique_ptr particle_vbo;
std::unique_ptr alive_particles_ebo;
std::unique_ptr particle_shader;
std::vector alive_particles;
std::vector dead_particles;
std::vector particles;
void init(const blt::gfx::window_data&)
{
using namespace blt::gfx;
particle_shader = std::unique_ptr(shader_t::make(shader_particle_2d_vert, shader_particle_2d_frag));
for (blt::size_t i = 0; i < PARTICLE_COUNT; i++)
{
particles.push_back(particle_t::make_particle());
alive_particles.push_back(i);
}
particle_vbo = std::make_unique();
particle_vbo->create(GL_ARRAY_BUFFER);
particle_vbo->allocate(sizeof(particle_t) * particles.size(), GL_DYNAMIC_DRAW, particles.data());
alive_particles_ebo = std::make_unique();
alive_particles_ebo->create();
alive_particles_ebo->allocate(sizeof(blt::u32) * alive_particles.size(), GL_DYNAMIC_DRAW, alive_particles.data());
particle_vao = std::make_unique();
particle_vao->bindVBO(*particle_vbo, 0, 2, GL_FLOAT, sizeof(particle_t), 0);
particle_vao->bindElement(*alive_particles_ebo);
global_matrices.create_internals();
resources.load_resources();
renderer_2d.create();
}
void update(const blt::gfx::window_data& data)
{
global_matrices.update_perspectives(data.width, data.height, 90, 0.1, 2000);
camera.update();
camera.update_view(global_matrices);
global_matrices.update();
renderer_2d.render(data.width, data.height);
}
void destroy(const blt::gfx::window_data&)
{
global_matrices.cleanup();
resources.cleanup();
renderer_2d.cleanup();
blt::gfx::cleanup();
}
int main()
{
blt::gfx::init(blt::gfx::window_data{"My Sexy Window", init, update, destroy}.setSyncInterval(1));
}