Добавлен пункт 7 лабы 2
This commit is contained in:
parent
cd43c61b27
commit
7adb050064
@ -46,3 +46,6 @@ 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})
|
||||
|
||||
add_executable(${PROJECT_NAME}_7 ${CORE_SOURCES} src/render/render-7.cpp)
|
||||
target_link_libraries(${PROJECT_NAME}_7 ${LIBS})
|
||||
|
115
lab2/src/render/render-7.cpp
Normal file
115
lab2/src/render/render-7.cpp
Normal file
@ -0,0 +1,115 @@
|
||||
//
|
||||
// Created by vlad on 23.03.23.
|
||||
//
|
||||
|
||||
#include "render.h"
|
||||
#include "../graphics/MeshLoader.h"
|
||||
#include "../graphics/Shader.h"
|
||||
|
||||
#include <glm/ext/matrix_transform.hpp>
|
||||
|
||||
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 = glm::rotate(glm::mat4(1.0f), rotation_angle, glm::vec3(0, 1, 0));
|
||||
rotation_angle += 0.0004f;
|
||||
|
||||
// тут нужен нужен translate_x+, translate_x-, translate_up
|
||||
auto translate_xp = glm::translate(glm::mat4(1.0f), glm::vec3(1.7, 0, 0));
|
||||
auto translate_xm = glm::translate(glm::mat4(1.0f), glm::vec3(-1.7, 0, 0));
|
||||
auto translate_up = glm::translate(glm::mat4(1.0f), glm::vec3(0, 1, 0));
|
||||
auto scale_0_7 = glm::scale(glm::mat4(1.0f), glm::vec3(0.7, 0.7,0.7));
|
||||
|
||||
// базовая матрица, = центр снеговика + вращение
|
||||
auto base = translate_xp * rotate;
|
||||
|
||||
// первый снеговик, смещаем взад (X-) и смещаем наверх
|
||||
drawSnowman(base * translate_xm * translate_up);
|
||||
|
||||
// второй снеговик, масштабируем, смещаем вверх
|
||||
drawSnowman(base * scale_0_7 * translate_up);
|
||||
|
||||
// третий снеговик, смещаем в X+ и смещаем наверх
|
||||
drawSnowman(base * scale_0_7 * translate_xp * scale_0_7 * translate_up);
|
||||
}
|
||||
|
||||
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;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user