117 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
	
	
| #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(); }
 | |
| 
 | |
| 
 | |
|   // OPENGL_PANEL_LAYER
 | |
|   
 | |
|   void opengl_panel::on_attach() 
 | |
|   {
 | |
|     hack::log()("on_attach");
 | |
|   }
 | |
| 
 | |
|   void opengl_panel::update()
 | |
|   {
 | |
| 
 | |
|   }
 | |
| 
 | |
|   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<VE::event_type>(e.m_type);
 | |
|       if (t == VE::event_type::MOUSE_CURSOR_POSITION)
 | |
|       {
 | |
|         auto [pos_x, pos_y] = std::any_cast<std::pair<float, float>>(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<int>(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<test_event>(e.m_type);
 | |
|       if (t == test_event::TEST_EVEN)
 | |
|         hack::log()(std::any_cast<std::string>(e.m_data));
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 |