From cd43c61b27ec97ffb961becf4c3c83f275128960 Mon Sep 17 00:00:00 2001 From: vlad Date: Thu, 6 Apr 2023 20:35:43 +0300 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=20=D0=BF=D1=83=D0=BD=D0=BA=D1=82=206=20=D0=BB=D0=B0?= =?UTF-8?q?=D0=B1=D1=8B=202?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lab2/CMakeLists.txt | 3 + lab2/src/render/render-6.cpp | 106 +++++++++++++++++++++++++++++++++++ 2 files changed, 109 insertions(+) create mode 100644 lab2/src/render/render-6.cpp diff --git a/lab2/CMakeLists.txt b/lab2/CMakeLists.txt index b0b773f..4674552 100644 --- a/lab2/CMakeLists.txt +++ b/lab2/CMakeLists.txt @@ -43,3 +43,6 @@ target_link_libraries(${PROJECT_NAME}_4 ${LIBS}) add_executable(${PROJECT_NAME}_5 ${CORE_SOURCES} src/render/render-5.cpp) target_link_libraries(${PROJECT_NAME}_5 ${LIBS}) + +add_executable(${PROJECT_NAME}_6 ${CORE_SOURCES} src/render/render-6.cpp) +target_link_libraries(${PROJECT_NAME}_6 ${LIBS}) diff --git a/lab2/src/render/render-6.cpp b/lab2/src/render/render-6.cpp new file mode 100644 index 0000000..04c2078 --- /dev/null +++ b/lab2/src/render/render-6.cpp @@ -0,0 +1,106 @@ +// +// Created by vlad on 23.03.23. +// + +#include "render.h" +#include "../graphics/MeshLoader.h" +#include "../graphics/Shader.h" + +#include + +static Mesh* mesh_xyz; +static Mesh* mesh_sphere; +static Mesh* mesh_cone; + +static Shader* shader; + + +static void drawSnowman(const glm::mat4& model) { + // снеговик, типа собран + + // нижний шар + shader->uniformMatrix("model", model); + mesh_sphere->draw(); + + // шар 2 + auto translate = glm::translate(glm::mat4(1.0f), glm::vec3(0, 1.5,0)); + auto scale = glm::scale(glm::mat4(1.0f), glm::vec3(0.5, 0.5 ,0.5)); + shader->uniformMatrix("model", model * translate * scale); + mesh_sphere->draw(); + + // глаз X- (со смещением по Z) + translate = glm::translate(glm::mat4(1.0f), glm::vec3(-0.25, 1.75, 0.25)); + scale = glm::scale(glm::mat4(1.0f), glm::vec3(0.25, 0.25,0.25)); + shader->uniformMatrix("model", model * translate * scale); + mesh_sphere->draw(); + + // глаз X+ (со смещением по Z) + translate = glm::translate(glm::mat4(1.0f), glm::vec3(0.25, 1.75, 0.25)); + shader->uniformMatrix("model", model * translate * scale); + mesh_sphere->draw(); + + // нос, (со смещением по Z) + translate = glm::translate(glm::mat4(1.0f), glm::vec3(0, 1.5, 0.5)); + auto rotate = glm::rotate(glm::mat4(1.0f), glm::radians(90.0f), glm::vec3(1, 0, 0)); + shader->uniformMatrix("model", model * translate * scale * rotate); + mesh_cone->draw(); +} + + +void renderScene(Camera& cam) { + auto projview = cam.getProjection() * cam.getView(); + shader->use(); + shader->uniformMatrix("projview", projview); + + // мировой центр + shader->uniformMatrix("model", glm::mat4(1.0f)); + mesh_xyz->draw(); + + // вот тут добавились матрицы вращения + static float rotation_angle = 0.0f; + auto rotate_global = glm::rotate(glm::mat4(1.0f), rotation_angle, glm::vec3(0, 1, 0)); + auto rotate_local = glm::rotate(glm::mat4(1.0f), rotation_angle * 4, glm::vec3(1, 1, 1)); + rotation_angle += 0.0001f; + + // тут то же самое что и в пункте 3 и 4, только translate другой + auto translate = glm::translate(glm::mat4(1.0f), glm::normalize(glm::vec3(1, 1, 1)) * 1.7f); + auto scale_0_7 = glm::scale(glm::mat4(1.0f), glm::vec3(0.7, 0.7,0.7));; + + drawSnowman(rotate_global * rotate_local); + drawSnowman(rotate_global * translate * scale_0_7 * rotate_local); + drawSnowman(rotate_global * translate * scale_0_7 * translate * scale_0_7 * rotate_local); +} + +int loadResources() { + mesh_xyz = MeshLoader::loadMesh("res/xyz"); + if (mesh_xyz == nullptr) { + std::cerr << "Failed to load 'xyz' mesh!" << std::endl; + return -1; + } + + mesh_sphere = MeshLoader::loadMesh("res/sphere"); + if (mesh_sphere == nullptr) { + std::cerr << "Failed to load 'sphere' mesh!" << std::endl; + return -1; + } + + mesh_cone = MeshLoader::loadMesh("res/cone"); + if (mesh_cone == nullptr) { + std::cerr << "Failed to load 'cone' mesh!" << std::endl; + return -1; + } + + shader = Shader::loadShader("res/main-colored.vsh", "res/main-colored.fsh"); + if (shader == nullptr) { + return -1; + } + + return 0; +} + +void unloadResources() { + delete mesh_xyz; + delete mesh_cone; + delete mesh_sphere; + delete shader; +} \ No newline at end of file