mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-20 08:17:17 +01:00
Ported: Add hint_transparent to use a transparent black placeholder texture - Calinou
ab9a95f266
This commit is contained in:
parent
2a13c65298
commit
f1619cad4f
@ -30,8 +30,8 @@
|
|||||||
|
|
||||||
#include "rasterizer_canvas_gles2.h"
|
#include "rasterizer_canvas_gles2.h"
|
||||||
|
|
||||||
#include "core/os/os.h"
|
|
||||||
#include "core/config/project_settings.h"
|
#include "core/config/project_settings.h"
|
||||||
|
#include "core/os/os.h"
|
||||||
#include "drivers/gles2/rasterizer_gles2.h"
|
#include "drivers/gles2/rasterizer_gles2.h"
|
||||||
#include "drivers/gles_common/rasterizer_asserts.h"
|
#include "drivers/gles_common/rasterizer_asserts.h"
|
||||||
#include "rasterizer_scene_gles2.h"
|
#include "rasterizer_scene_gles2.h"
|
||||||
@ -1678,6 +1678,9 @@ void RasterizerCanvasGLES2::_legacy_canvas_render_item(Item *p_ci, RenderItemSta
|
|||||||
case ShaderLanguage::ShaderNode::Uniform::HINT_BLACK: {
|
case ShaderLanguage::ShaderNode::Uniform::HINT_BLACK: {
|
||||||
glBindTexture(GL_TEXTURE_2D, storage->resources.black_tex);
|
glBindTexture(GL_TEXTURE_2D, storage->resources.black_tex);
|
||||||
} break;
|
} break;
|
||||||
|
case ShaderLanguage::ShaderNode::Uniform::HINT_TRANSPARENT: {
|
||||||
|
glBindTexture(GL_TEXTURE_2D, storage->resources.transparent_tex);
|
||||||
|
} break;
|
||||||
case ShaderLanguage::ShaderNode::Uniform::HINT_ANISO: {
|
case ShaderLanguage::ShaderNode::Uniform::HINT_ANISO: {
|
||||||
glBindTexture(GL_TEXTURE_2D, storage->resources.aniso_tex);
|
glBindTexture(GL_TEXTURE_2D, storage->resources.aniso_tex);
|
||||||
} break;
|
} break;
|
||||||
@ -2040,6 +2043,9 @@ void RasterizerCanvasGLES2::render_joined_item(const BItemJoined &p_bij, RenderI
|
|||||||
case ShaderLanguage::ShaderNode::Uniform::HINT_BLACK: {
|
case ShaderLanguage::ShaderNode::Uniform::HINT_BLACK: {
|
||||||
glBindTexture(GL_TEXTURE_2D, storage->resources.black_tex);
|
glBindTexture(GL_TEXTURE_2D, storage->resources.black_tex);
|
||||||
} break;
|
} break;
|
||||||
|
case ShaderLanguage::ShaderNode::Uniform::HINT_TRANSPARENT: {
|
||||||
|
glBindTexture(GL_TEXTURE_2D, storage->resources.transparent_tex);
|
||||||
|
} break;
|
||||||
case ShaderLanguage::ShaderNode::Uniform::HINT_ANISO: {
|
case ShaderLanguage::ShaderNode::Uniform::HINT_ANISO: {
|
||||||
glBindTexture(GL_TEXTURE_2D, storage->resources.aniso_tex);
|
glBindTexture(GL_TEXTURE_2D, storage->resources.aniso_tex);
|
||||||
} break;
|
} break;
|
||||||
|
@ -1392,6 +1392,9 @@ bool RasterizerSceneGLES2::_setup_material(RasterizerStorageGLES2::Material *p_m
|
|||||||
case ShaderLanguage::ShaderNode::Uniform::HINT_BLACK: {
|
case ShaderLanguage::ShaderNode::Uniform::HINT_BLACK: {
|
||||||
glBindTexture(GL_TEXTURE_2D, storage->resources.black_tex);
|
glBindTexture(GL_TEXTURE_2D, storage->resources.black_tex);
|
||||||
} break;
|
} break;
|
||||||
|
case ShaderLanguage::ShaderNode::Uniform::HINT_TRANSPARENT: {
|
||||||
|
glBindTexture(GL_TEXTURE_2D, storage->resources.transparent_tex);
|
||||||
|
} break;
|
||||||
case ShaderLanguage::ShaderNode::Uniform::HINT_ANISO: {
|
case ShaderLanguage::ShaderNode::Uniform::HINT_ANISO: {
|
||||||
glBindTexture(GL_TEXTURE_2D, storage->resources.aniso_tex);
|
glBindTexture(GL_TEXTURE_2D, storage->resources.aniso_tex);
|
||||||
} break;
|
} break;
|
||||||
|
@ -30,8 +30,8 @@
|
|||||||
|
|
||||||
#include "rasterizer_storage_gles2.h"
|
#include "rasterizer_storage_gles2.h"
|
||||||
|
|
||||||
#include "core/math/transform.h"
|
|
||||||
#include "core/config/project_settings.h"
|
#include "core/config/project_settings.h"
|
||||||
|
#include "core/math/transform.h"
|
||||||
#include "rasterizer_canvas_gles2.h"
|
#include "rasterizer_canvas_gles2.h"
|
||||||
#include "rasterizer_scene_gles2.h"
|
#include "rasterizer_scene_gles2.h"
|
||||||
#include "servers/visual/shader_language.h"
|
#include "servers/visual/shader_language.h"
|
||||||
@ -6096,32 +6096,45 @@ void RasterizerStorageGLES2::initialize() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
//default textures
|
// Generate default textures.
|
||||||
|
|
||||||
|
// Opaque white color.
|
||||||
glGenTextures(1, &resources.white_tex);
|
glGenTextures(1, &resources.white_tex);
|
||||||
unsigned char whitetexdata[8 * 8 * 3];
|
unsigned char whitetexdata[8 * 8 * 3];
|
||||||
for (int i = 0; i < 8 * 8 * 3; i++) {
|
for (int i = 0; i < 8 * 8 * 3; i++) {
|
||||||
whitetexdata[i] = 255;
|
whitetexdata[i] = 255;
|
||||||
}
|
}
|
||||||
|
|
||||||
glActiveTexture(GL_TEXTURE0);
|
glActiveTexture(GL_TEXTURE0);
|
||||||
glBindTexture(GL_TEXTURE_2D, resources.white_tex);
|
glBindTexture(GL_TEXTURE_2D, resources.white_tex);
|
||||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 8, 8, 0, GL_RGB, GL_UNSIGNED_BYTE, whitetexdata);
|
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 8, 8, 0, GL_RGB, GL_UNSIGNED_BYTE, whitetexdata);
|
||||||
glGenerateMipmap(GL_TEXTURE_2D);
|
glGenerateMipmap(GL_TEXTURE_2D);
|
||||||
glBindTexture(GL_TEXTURE_2D, 0);
|
glBindTexture(GL_TEXTURE_2D, 0);
|
||||||
|
|
||||||
|
// Opaque black color.
|
||||||
glGenTextures(1, &resources.black_tex);
|
glGenTextures(1, &resources.black_tex);
|
||||||
unsigned char blacktexdata[8 * 8 * 3];
|
unsigned char blacktexdata[8 * 8 * 3];
|
||||||
for (int i = 0; i < 8 * 8 * 3; i++) {
|
for (int i = 0; i < 8 * 8 * 3; i++) {
|
||||||
blacktexdata[i] = 0;
|
blacktexdata[i] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
glActiveTexture(GL_TEXTURE0);
|
glActiveTexture(GL_TEXTURE0);
|
||||||
glBindTexture(GL_TEXTURE_2D, resources.black_tex);
|
glBindTexture(GL_TEXTURE_2D, resources.black_tex);
|
||||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 8, 8, 0, GL_RGB, GL_UNSIGNED_BYTE, blacktexdata);
|
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 8, 8, 0, GL_RGB, GL_UNSIGNED_BYTE, blacktexdata);
|
||||||
glGenerateMipmap(GL_TEXTURE_2D);
|
glGenerateMipmap(GL_TEXTURE_2D);
|
||||||
glBindTexture(GL_TEXTURE_2D, 0);
|
glBindTexture(GL_TEXTURE_2D, 0);
|
||||||
|
|
||||||
|
// Transparent black color.
|
||||||
|
glGenTextures(1, &resources.transparent_tex);
|
||||||
|
unsigned char transparenttexdata[8 * 8 * 4];
|
||||||
|
for (int i = 0; i < 8 * 8 * 4; i++) {
|
||||||
|
transparenttexdata[i] = 0;
|
||||||
|
}
|
||||||
|
glActiveTexture(GL_TEXTURE0);
|
||||||
|
glBindTexture(GL_TEXTURE_2D, resources.transparent_tex);
|
||||||
|
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, 8, 8, 0, GL_RGBA, GL_UNSIGNED_BYTE, transparenttexdata);
|
||||||
|
glGenerateMipmap(GL_TEXTURE_2D);
|
||||||
|
glBindTexture(GL_TEXTURE_2D, 0);
|
||||||
|
|
||||||
|
// Opaque "flat" normal map color.
|
||||||
glGenTextures(1, &resources.normal_tex);
|
glGenTextures(1, &resources.normal_tex);
|
||||||
unsigned char normaltexdata[8 * 8 * 3];
|
unsigned char normaltexdata[8 * 8 * 3];
|
||||||
for (int i = 0; i < 8 * 8 * 3; i += 3) {
|
for (int i = 0; i < 8 * 8 * 3; i += 3) {
|
||||||
@ -6129,13 +6142,13 @@ void RasterizerStorageGLES2::initialize() {
|
|||||||
normaltexdata[i + 1] = 128;
|
normaltexdata[i + 1] = 128;
|
||||||
normaltexdata[i + 2] = 255;
|
normaltexdata[i + 2] = 255;
|
||||||
}
|
}
|
||||||
|
|
||||||
glActiveTexture(GL_TEXTURE0);
|
glActiveTexture(GL_TEXTURE0);
|
||||||
glBindTexture(GL_TEXTURE_2D, resources.normal_tex);
|
glBindTexture(GL_TEXTURE_2D, resources.normal_tex);
|
||||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 8, 8, 0, GL_RGB, GL_UNSIGNED_BYTE, normaltexdata);
|
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 8, 8, 0, GL_RGB, GL_UNSIGNED_BYTE, normaltexdata);
|
||||||
glGenerateMipmap(GL_TEXTURE_2D);
|
glGenerateMipmap(GL_TEXTURE_2D);
|
||||||
glBindTexture(GL_TEXTURE_2D, 0);
|
glBindTexture(GL_TEXTURE_2D, 0);
|
||||||
|
|
||||||
|
// Opaque "flat" flowmap color.
|
||||||
glGenTextures(1, &resources.aniso_tex);
|
glGenTextures(1, &resources.aniso_tex);
|
||||||
unsigned char anisotexdata[8 * 8 * 3];
|
unsigned char anisotexdata[8 * 8 * 3];
|
||||||
for (int i = 0; i < 8 * 8 * 3; i += 3) {
|
for (int i = 0; i < 8 * 8 * 3; i += 3) {
|
||||||
@ -6143,7 +6156,6 @@ void RasterizerStorageGLES2::initialize() {
|
|||||||
anisotexdata[i + 1] = 128;
|
anisotexdata[i + 1] = 128;
|
||||||
anisotexdata[i + 2] = 0;
|
anisotexdata[i + 2] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
glActiveTexture(GL_TEXTURE0);
|
glActiveTexture(GL_TEXTURE0);
|
||||||
glBindTexture(GL_TEXTURE_2D, resources.aniso_tex);
|
glBindTexture(GL_TEXTURE_2D, resources.aniso_tex);
|
||||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 8, 8, 0, GL_RGB, GL_UNSIGNED_BYTE, anisotexdata);
|
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 8, 8, 0, GL_RGB, GL_UNSIGNED_BYTE, anisotexdata);
|
||||||
|
@ -109,6 +109,7 @@ public:
|
|||||||
struct Resources {
|
struct Resources {
|
||||||
GLuint white_tex;
|
GLuint white_tex;
|
||||||
GLuint black_tex;
|
GLuint black_tex;
|
||||||
|
GLuint transparent_tex;
|
||||||
GLuint normal_tex;
|
GLuint normal_tex;
|
||||||
GLuint aniso_tex;
|
GLuint aniso_tex;
|
||||||
|
|
||||||
|
@ -35,8 +35,8 @@
|
|||||||
#include "core/containers/ordered_hash_map.h"
|
#include "core/containers/ordered_hash_map.h"
|
||||||
#include "core/object/script_language.h"
|
#include "core/object/script_language.h"
|
||||||
#include "core/string/string_name.h"
|
#include "core/string/string_name.h"
|
||||||
#include "core/typedefs.h"
|
|
||||||
#include "core/string/ustring.h"
|
#include "core/string/ustring.h"
|
||||||
|
#include "core/typedefs.h"
|
||||||
#include "core/variant/variant.h"
|
#include "core/variant/variant.h"
|
||||||
|
|
||||||
class ShaderLanguage {
|
class ShaderLanguage {
|
||||||
@ -156,6 +156,7 @@ public:
|
|||||||
TK_RENDER_MODE,
|
TK_RENDER_MODE,
|
||||||
TK_HINT_WHITE_TEXTURE,
|
TK_HINT_WHITE_TEXTURE,
|
||||||
TK_HINT_BLACK_TEXTURE,
|
TK_HINT_BLACK_TEXTURE,
|
||||||
|
TK_HINT_TRANSPARENT_TEXTURE,
|
||||||
TK_HINT_NORMAL_TEXTURE,
|
TK_HINT_NORMAL_TEXTURE,
|
||||||
TK_HINT_ANISO_TEXTURE,
|
TK_HINT_ANISO_TEXTURE,
|
||||||
TK_HINT_ALBEDO_TEXTURE,
|
TK_HINT_ALBEDO_TEXTURE,
|
||||||
@ -642,6 +643,7 @@ public:
|
|||||||
HINT_NORMAL,
|
HINT_NORMAL,
|
||||||
HINT_BLACK,
|
HINT_BLACK,
|
||||||
HINT_WHITE,
|
HINT_WHITE,
|
||||||
|
HINT_TRANSPARENT,
|
||||||
HINT_ANISO,
|
HINT_ANISO,
|
||||||
HINT_MAX
|
HINT_MAX
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user