#include "opengl_panel.hpp" #include "utils.hpp" namespace sandbox { cube::cube() { hack::log()("create cube"); const std::filesystem::path vsp { "/mnt/raid/projects/vertex_engine/vertex_engine/bin/layers/opengl_panel/shaders/vertes.shader" }; const std::filesystem::path fsp { "/mnt/raid/projects/vertex_engine/vertex_engine/bin/layers/opengl_panel/shaders/frag.shader" }; add_shader(GL_VERTEX_SHADER, vsp); add_shader(GL_FRAGMENT_SHADER, fsp); shader_program::link(); m_vertices = { -0.1f, 0.0f, 0.7f, 0.1f, 0.0f, 0.7f, 0.1f, 0.0f, -0.7f, -0.1f, 0.0f, -0.7f, 0.0f, 0.3f, 0.0f }; m_indices = { 0, 1, 1, 4, 4, 0, 0, 3, 3, 4, 4, 2, 2, 1, 3, 2 }; buffer::link(); } void cube::use() { shader_program::use(); } void cube::set_scale(float val) { set("scale", val); } void cube::set_position(glm::vec3 val) { set("position", val); } void cube::set_color(glm::vec4 val) { set("color", val); } void cube::render() { buffer::render(); } void opengl_panel::on_attach() { hack::log()("on_attach"); } void opengl_panel::on_detach() { hack::log()("on_attach"); } void opengl_panel::render() { m_cb_1.use(); m_cam.update(m_cb_1); float r = std::sin(glfwGetTime()); float g = std::cos(glfwGetTime()); m_cb_1.set_color(glm::vec4{ 0.85f, 0.45f, 0.95f, 0.f }); // розовый m_cb_1.set_scale(1.0f + std::sin(glfwGetTime()) * 0.2f); m_cb_1.set_position(glm::vec3{ 0.f, 0.5, 0.f }); m_cb_1.render(); r = std::cos(glfwGetTime()); g = std::sin(glfwGetTime()); m_cb_2.use(); m_cam.update(m_cb_2); m_cb_2.set_color(glm::vec4{ 0.66f, 0.66f, 0.66f, 0.f }); // серый/белый m_cb_2.set_scale(1.0f - std::cos(glfwGetTime()) * 0.2f); m_cb_2.set_position(glm::vec3{ r, g, 0.f }); m_cb_2.render(); } void opengl_panel::on_event(VE::event e) { // для событий от перефирии if (e.m_type.type() == typeid(VE::event_type)) { auto t = std::any_cast(e.m_type); if (t == VE::event_type::MOUSE_CURSOR_POSITION) { auto [pos_x, pos_y] = std::any_cast>(e.m_data); m_cam.mouse_callback(pos_x, pos_y); } if (t == VE::event_type::KEY_REPEATE || t == VE::event_type::KEY_PRESSED) { auto key = std::any_cast(e.m_data); if (key == VE::key::W) m_cam.up(); if (key == VE::key::S) m_cam.down(); if (key == VE::key::A) m_cam.left(); if (key == VE::key::D) m_cam.right(); } } if (e.m_type.type() == typeid(test_event)) { auto t = std::any_cast(e.m_type); if (t == test_event::TEST_EVEN) hack::log()(std::any_cast(e.m_data)); } } }