Compare commits
5 Commits
Author | SHA1 | Date |
---|---|---|
Ковалев Роман Евгеньевич | df35cd6850 | |
Ковалев Роман Евгеньевич | 1cf48d9835 | |
Ковалев Роман Евгеньевич | f97f2f8690 | |
Ковалев Роман Евгеньевич | 3c3996e985 | |
Ковалев Роман Евгеньевич | 1fd082289d |
|
@ -80,8 +80,6 @@ class RBO
|
||||||
RBO(int w, int h, GLuint component = GL_DEPTH_COMPONENT); // Создает буфер рендера с заданными параметрами размеров и используемых компонент
|
RBO(int w, int h, GLuint component = GL_DEPTH_COMPONENT); // Создает буфер рендера с заданными параметрами размеров и используемых компонент
|
||||||
~RBO(); // Уничтожение буфера
|
~RBO(); // Уничтожение буфера
|
||||||
|
|
||||||
void reallocate(int w, int h, GLuint component = GL_DEPTH_COMPONENT); // Изменяет размеры буфера рендера
|
|
||||||
|
|
||||||
GLuint getHandler(); // Возвращает дескриптор буфера рендера
|
GLuint getHandler(); // Возвращает дескриптор буфера рендера
|
||||||
protected:
|
protected:
|
||||||
GLuint handler; // Дескриптор
|
GLuint handler; // Дескриптор
|
||||||
|
|
|
@ -23,8 +23,6 @@ class Texture
|
||||||
|
|
||||||
Texture& operator=(const Texture& other); // Оператор присваивания
|
Texture& operator=(const Texture& other); // Оператор присваивания
|
||||||
|
|
||||||
void reallocate(GLuint width, GLuint height, GLuint texType = TEX_DIFFUSE, GLint internalformat = GL_RGBA, GLint format = GL_RGBA, GLenum dataType = GL_FLOAT); // Пересоздает текстуру для имеющегося дескриптора
|
|
||||||
|
|
||||||
void use(); // Привязка текстуры
|
void use(); // Привязка текстуры
|
||||||
static void disable(GLuint type); // Отвязка текстуры по типу
|
static void disable(GLuint type); // Отвязка текстуры по типу
|
||||||
GLuint getType(); // Возвращает тип текстуры
|
GLuint getType(); // Возвращает тип текстуры
|
||||||
|
|
|
@ -189,13 +189,6 @@ RBO::~RBO()
|
||||||
glDeleteRenderbuffers(1, &handler);
|
glDeleteRenderbuffers(1, &handler);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Изменяет размеры буфера рендера
|
|
||||||
void RBO::reallocate(int w, int h, GLuint component)
|
|
||||||
{
|
|
||||||
glBindRenderbuffer(GL_RENDERBUFFER, handler); // Привязка элементного буфера
|
|
||||||
glRenderbufferStorage(GL_RENDERBUFFER, GL_DEPTH_COMPONENT, w, h);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Возвращает дескриптор буфера рендера
|
// Возвращает дескриптор буфера рендера
|
||||||
GLuint RBO::getHandler()
|
GLuint RBO::getHandler()
|
||||||
{
|
{
|
||||||
|
|
|
@ -115,13 +115,6 @@ Texture::~Texture()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Пересоздает текстуру для имеющегося дескриптора
|
|
||||||
void Texture::reallocate(GLuint width, GLuint height, GLuint texType, GLint internalformat, GLint format, GLenum dataType)
|
|
||||||
{
|
|
||||||
use();
|
|
||||||
glTexImage2D(GL_TEXTURE_2D, 0, internalformat, width, height, 0, format, dataType, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Привязка текстуры
|
// Привязка текстуры
|
||||||
void Texture::use()
|
void Texture::use()
|
||||||
{
|
{
|
||||||
|
|
39
src/main.cpp
39
src/main.cpp
|
@ -9,42 +9,14 @@
|
||||||
#include "Shader.h"
|
#include "Shader.h"
|
||||||
#include "Lights.h"
|
#include "Lights.h"
|
||||||
|
|
||||||
|
#define WINDOW_WIDTH 800
|
||||||
|
#define WINDOW_HEIGHT 600
|
||||||
#define WINDOW_CAPTION "OPENGL notes on rekovalev.site"
|
#define WINDOW_CAPTION "OPENGL notes on rekovalev.site"
|
||||||
|
|
||||||
// Указатели на текстуры для изменения размеров окна
|
|
||||||
Texture* pgPosition = NULL;
|
|
||||||
Texture* pgNormal = NULL;
|
|
||||||
Texture* pgDiffuseP = NULL;
|
|
||||||
Texture* pgAmbientSpecular = NULL;
|
|
||||||
RBO* pgrbo = NULL;
|
|
||||||
// Размеры окна
|
|
||||||
int WINDOW_WIDTH = 800;
|
|
||||||
int WINDOW_HEIGHT = 600;
|
|
||||||
|
|
||||||
// Функция-callback для изменения размеров буфера кадра в случае изменения размеров поверхности окна
|
// Функция-callback для изменения размеров буфера кадра в случае изменения размеров поверхности окна
|
||||||
void framebuffer_size_callback(GLFWwindow* window, int width, int height)
|
void framebuffer_size_callback(GLFWwindow* window, int width, int height)
|
||||||
{
|
{
|
||||||
glViewport(0, 0, width, height);
|
glViewport(0, 0, width, height);
|
||||||
|
|
||||||
// Изменение размеров текстур для G-буфера
|
|
||||||
if (pgPosition)
|
|
||||||
pgPosition->reallocate(width, height, 0, GL_RGB32F, GL_RGB);
|
|
||||||
if (pgNormal)
|
|
||||||
pgNormal->reallocate(width, height, 1, GL_RGB16F, GL_RGB);
|
|
||||||
if (pgDiffuseP)
|
|
||||||
pgDiffuseP->reallocate(width, height, 2, GL_RGBA16F);
|
|
||||||
if (pgAmbientSpecular)
|
|
||||||
pgAmbientSpecular->reallocate(width, height, 3);
|
|
||||||
// И буфера глубины
|
|
||||||
if (pgrbo)
|
|
||||||
pgrbo->reallocate(width, height);
|
|
||||||
|
|
||||||
// Запомним новые размеры окна
|
|
||||||
WINDOW_WIDTH = width;
|
|
||||||
WINDOW_HEIGHT = height;
|
|
||||||
|
|
||||||
// Изменим параметры перспективной матрицы проекции для камеры
|
|
||||||
Camera::current().setPerspective(CAMERA_FOVy, (float)width/height);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool firstMouse = true;
|
bool firstMouse = true;
|
||||||
|
@ -163,13 +135,6 @@ int main(void)
|
||||||
// Активируем базовый буфер кадра
|
// Активируем базовый буфер кадра
|
||||||
FBO::useDefault();
|
FBO::useDefault();
|
||||||
|
|
||||||
// Сохраним указатели на текстуры для изменения размеров окна
|
|
||||||
pgPosition = &gPosition;
|
|
||||||
pgNormal = &gNormal;
|
|
||||||
pgDiffuseP = &gDiffuseP;
|
|
||||||
pgAmbientSpecular = &gAmbientSpecular;
|
|
||||||
pgrbo = &grbo;
|
|
||||||
|
|
||||||
// Шейдер для расчета освещенности
|
// Шейдер для расчета освещенности
|
||||||
ShaderProgram lightShader;
|
ShaderProgram lightShader;
|
||||||
// Загрузка и компиляция шейдеров
|
// Загрузка и компиляция шейдеров
|
||||||
|
|
Loading…
Reference in New Issue