Various small improvements.

This commit is contained in:
Relintai 2024-03-31 10:21:41 +02:00
parent 7aa7a49bd4
commit 4b2076ce7b
14 changed files with 25 additions and 11 deletions

View File

@ -1,6 +1,7 @@
//--STRIP
#include "color_material.h"
#include "render_core/3rd_glad.h"
//--STRIP
void ColorMaterial::bind_uniforms() {

View File

@ -1,6 +1,7 @@
//--STRIP
#include "color_material_2d.h"
#include "render_core/3rd_glad.h"
//--STRIP
void ColorMaterial2D::bind_uniforms() {

View File

@ -1,5 +1,6 @@
//--STRIP
#include "colored_material.h"
#include "render_core/3rd_glad.h"
//--STRIP
void ColoredMaterial::bind_uniforms() {

View File

@ -1,5 +1,6 @@
//--STRIP
#include "font_material.h"
#include "render_core/3rd_glad.h"
//--STRIP
void FontMaterial::bind_uniforms() {

View File

@ -30,12 +30,12 @@ int FrameBuffer::create(const int p_width, const int p_height, const int p_msaa_
--msaa;
}
destroy();
_fbo_width = p_width;
_fbo_height = p_height;
_fbo_msaa_count = msaa;
destroy();
glGenFramebuffers(1, &_fbo);
glBindFramebuffer(GL_FRAMEBUFFER, _fbo);
@ -262,8 +262,8 @@ Vector2i FrameBuffer::get_size() const {
void FrameBuffer::blit_color_to(const uint32_t p_destination_framebuffer, const Rect2i &p_rect) {
ERR_FAIL_COND(!p_destination_framebuffer);
int width = p_rect.size.width == 0 ? p_rect.size.width : _fbo_width;
int height = p_rect.size.height == 0 ? p_rect.size.height : _fbo_height;
int width = p_rect.size.width == 0 ?_fbo_width : p_rect.size.width;
int height = p_rect.size.height == 0 ? _fbo_height : p_rect.size.height;
uint32_t fbo = get_gl_fbo();
@ -275,8 +275,8 @@ void FrameBuffer::blit_color_to(const uint32_t p_destination_framebuffer, const
void FrameBuffer::blit_depth_to(const uint32_t p_destination_framebuffer, const Rect2i &p_rect) {
ERR_FAIL_COND(!p_destination_framebuffer);
int width = p_rect.size.width == 0 ? p_rect.size.width : _fbo_width;
int height = p_rect.size.height == 0 ? p_rect.size.height : _fbo_height;
int width = p_rect.size.width == 0 ?_fbo_width : p_rect.size.width;
int height = p_rect.size.height == 0 ? _fbo_height : p_rect.size.height;
uint32_t fbo = get_gl_fbo();

View File

@ -2,6 +2,8 @@
#include "render_core/material.h"
#include <stdio.h>
#include "render_core/3rd_glad.h"
//--STRIP
void Material::bind() {
@ -58,6 +60,10 @@ Material::Material() {
shader = NULL;
}
Material::~Material() {
if (current_material == this) {
unbind();
current_material = NULL;
}
}
void Material::set_uniform(int32_t p_uniform, const Transform &p_transform) {

View File

@ -224,7 +224,7 @@ void Mesh::upload() {
normals_vbo_size = sizeof(float) * normals.size();
colors_vbo_size = sizeof(float) * colors.size();
uvs_vbo_size = sizeof(float) * uvs.size();
indices_vbo_size = sizeof(float) * indices.size();
indices_vbo_size = sizeof(uint32_t) * indices.size();
glBindBuffer(GL_ARRAY_BUFFER, VBO);
glBufferData(GL_ARRAY_BUFFER, vertices_vbo_size + normals_vbo_size + colors_vbo_size + uvs_vbo_size, NULL, GL_STATIC_DRAW);
@ -268,7 +268,7 @@ void Mesh::destroy() {
}
}
void Mesh::render() {
if (vertices.size() == 0) {
if (!vertices_vbo_size) {
return;
}

View File

@ -2,6 +2,8 @@
#include "render_core/shader.h"
#include <stdio.h>
#include "render_core/3rd_glad.h"
//--STRIP
bool Shader::bind() {
@ -124,7 +126,7 @@ void Shader::print_program_errors(const uint32_t p_program) {
glGetProgramInfoLog(p_program, max_length, &info_length, info_log);
if (info_length > 0) {
ERR_PRINT(String::utf8(info_log, max_length));
ERR_PRINT(String::utf8(info_log, info_length));
}
} else {
ERR_PRINT("print_program_errors: Not a program!\n");

View File

@ -5,7 +5,6 @@
//--STRIP
#include "core/hash_map.h"
#include "render_core/3rd_glad.h"
//--STRIP
class Shader {

View File

@ -7,6 +7,7 @@
#include "render_core/app_window.h"
#include "render_core/frame_buffer.h"
#include "render_core/3rd_glad.h"
//--STRIP
void Texture::create_from_image(const Ref<Image> &img) {

View File

@ -7,7 +7,6 @@
#include "core/vector2i.h"
#include "object/resource.h"
#include "render_core/3rd_glad.h"
#include "render_core/image.h"
//--STRIP

View File

@ -1,6 +1,7 @@
//--STRIP
#include "texture_material.h"
#include "render_core/3rd_glad.h"
//--STRIP
void TextureMaterial::bind_uniforms() {

View File

@ -1,5 +1,6 @@
//--STRIP
#include "texture_material_2d.h"
#include "render_core/3rd_glad.h"
//--STRIP
void TextureMaterial2D::bind_uniforms() {

View File

@ -1,5 +1,6 @@
//--STRIP
#include "transparent_texture_material.h"
#include "render_core/3rd_glad.h"
//--STRIP
void TransparentTextureMaterial::bind_uniforms() {