diff --git a/src/Model.cpp b/src/Model.cpp index 89c8339..de90918 100644 --- a/src/Model.cpp +++ b/src/Model.cpp @@ -268,6 +268,9 @@ GrouptedModel loadOBJtoGroupted(const char* filename, const char* mtl_directory, std::string err; + // Значение гамма-коррекции + extern float inv_gamma; + // Если в процессе загрузки возникли ошибки - выдадим исключение if (!tinyobj::LoadObj(&attrib, &shapes, &materials, &err, filename, mtl_directory)) throw std::runtime_error(err); @@ -367,8 +370,8 @@ GrouptedModel loadOBJtoGroupted(const char* filename, const char* mtl_directory, s->set_texture(specular); // Материал - s->material.ka = glm::vec3(materials[materials_ids[i]].ambient[0], materials[materials_ids[i]].ambient[1], materials[materials_ids[i]].ambient[2]); - s->material.kd = glm::vec3(materials[materials_ids[i]].diffuse[0], materials[materials_ids[i]].diffuse[1], materials[materials_ids[i]].diffuse[2]); + s->material.ka = pow(glm::vec3(materials[materials_ids[i]].ambient[0], materials[materials_ids[i]].ambient[1], materials[materials_ids[i]].ambient[2]), glm::vec3(1/inv_gamma)); + s->material.kd = pow(glm::vec3(materials[materials_ids[i]].diffuse[0], materials[materials_ids[i]].diffuse[1], materials[materials_ids[i]].diffuse[2]), glm::vec3(1/inv_gamma)); s->material.ks = glm::vec3(materials[materials_ids[i]].specular[0], materials[materials_ids[i]].specular[1], materials[materials_ids[i]].specular[2]); s->material.p = (materials[materials_ids[i]].shininess > 0.0f) ? 1000.0f / materials[materials_ids[i]].shininess : 1000.0f; } diff --git a/src/main.cpp b/src/main.cpp index e851b65..9305004 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -16,6 +16,9 @@ #define WINDOW_HEIGHT 600 #define WINDOW_CAPTION "OPENGL notes on rekovalev.site" +// Значение гамма-коррекции +float inv_gamma = 1/2.2; + // Функция-callback для изменения размеров буфера кадра в случае изменения размеров поверхности окна void framebuffer_size_callback(GLFWwindow* window, int width, int height) { @@ -390,7 +393,6 @@ int main(void) skyboxShader.bindTextures(skybox_shader_names, sizeof(skybox_shader_names)/sizeof(const char*)); // Значение гамма-коррекции - float inv_gamma = 1/2.2; UBO gamma(&inv_gamma, sizeof(inv_gamma), 4); // Пока не произойдет событие запроса закрытия окна