-made normalmaps easier in 2D, fixes #1467

This commit is contained in:
Juan Linietsky 2015-04-27 08:11:54 -03:00
parent 82cbee2d2d
commit 0adca0a7c9
6 changed files with 26 additions and 0 deletions

View file

@ -4609,6 +4609,10 @@ void RasterizerGLES2::_update_shader( Shader* p_shader) const {
if (fragment_flags.uses_normal) { if (fragment_flags.uses_normal) {
enablers.push_back("#define NORMAL_USED\n"); enablers.push_back("#define NORMAL_USED\n");
} }
if (fragment_flags.uses_normalmap) {
enablers.push_back("#define USE_NORMALMAP\n");
}
if (light_flags.uses_light) { if (light_flags.uses_light) {
enablers.push_back("#define USE_LIGHT_SHADER_CODE\n"); enablers.push_back("#define USE_LIGHT_SHADER_CODE\n");
} }

View file

@ -243,6 +243,10 @@ String ShaderCompilerGLES2::dump_node_code(SL::Node *p_node,int p_level,bool p_a
if (vnode->name==vname_normal) { if (vnode->name==vname_normal) {
uses_normal=true; uses_normal=true;
} }
if (vnode->name==vname_normalmap || vnode->name==vname_normalmap_depth) {
uses_normalmap=true;
uses_normal=true;
}
if (vnode->name==vname_screen_uv) { if (vnode->name==vname_screen_uv) {
uses_screen_uv=true; uses_screen_uv=true;
@ -810,6 +814,8 @@ ShaderCompilerGLES2::ShaderCompilerGLES2() {
mode_replace_table[4]["POSITION"]="gl_Position"; mode_replace_table[4]["POSITION"]="gl_Position";
mode_replace_table[4]["NORMAL"]="normal"; mode_replace_table[4]["NORMAL"]="normal";
mode_replace_table[4]["NORMALMAP"]="normal_map";
mode_replace_table[4]["NORMALMAP_DEPTH"]="normal_depth";
mode_replace_table[4]["UV"]="uv_interp"; mode_replace_table[4]["UV"]="uv_interp";
mode_replace_table[4]["SRC_COLOR"]="color_interp"; mode_replace_table[4]["SRC_COLOR"]="color_interp";
mode_replace_table[4]["COLOR"]="color"; mode_replace_table[4]["COLOR"]="color";
@ -861,6 +867,7 @@ ShaderCompilerGLES2::ShaderCompilerGLES2() {
vname_light="LIGHT"; vname_light="LIGHT";
vname_time="TIME"; vname_time="TIME";
vname_normalmap="NORMALMAP"; vname_normalmap="NORMALMAP";
vname_normalmap_depth="NORMALMAP_DEPTH";
vname_normal="NORMAL"; vname_normal="NORMAL";
vname_texpixel_size="TEXTURE_PIXEL_SIZE"; vname_texpixel_size="TEXTURE_PIXEL_SIZE";
vname_world_vec="WORLD_VERTEX"; vname_world_vec="WORLD_VERTEX";

View file

@ -72,6 +72,7 @@ private:
StringName vname_light; StringName vname_light;
StringName vname_time; StringName vname_time;
StringName vname_normalmap; StringName vname_normalmap;
StringName vname_normalmap_depth;
StringName vname_normal; StringName vname_normal;
StringName vname_texpixel_size; StringName vname_texpixel_size;
StringName vname_world_vec; StringName vname_world_vec;

View file

@ -207,7 +207,17 @@ void main() {
{ {
#if defined(USE_NORMALMAP)
vec3 normal_map=vec3(0.0,0.0,1.0);
float normal_depth=1.0;
#endif
FRAGMENT_SHADER_CODE FRAGMENT_SHADER_CODE
#if defined(USE_NORMALMAP)
normal = mix(vec3(0.0,0.0,1.0), normal_map * vec3(2.0,-2.0,1.0) - vec3( 1.0, -1.0, 0.0 ), normal_depth );
#endif
} }
#ifdef DEBUG_ENCODED_32 #ifdef DEBUG_ENCODED_32
highp float enc32 = dot( color,highp vec4(1.0 / (256.0 * 256.0 * 256.0),1.0 / (256.0 * 256.0),1.0 / 256.0,1) ); highp float enc32 = dot( color,highp vec4(1.0 / (256.0 * 256.0 * 256.0),1.0 / (256.0 * 256.0),1.0 / 256.0,1) );

View file

@ -1350,6 +1350,8 @@ const ShaderGraph::InOutParamInfo ShaderGraph::inout_param_info[]={
{MODE_CANVAS_ITEM,SHADER_TYPE_FRAGMENT,"Color","COLOR.rgb","",SLOT_TYPE_VEC,SLOT_OUT}, {MODE_CANVAS_ITEM,SHADER_TYPE_FRAGMENT,"Color","COLOR.rgb","",SLOT_TYPE_VEC,SLOT_OUT},
{MODE_CANVAS_ITEM,SHADER_TYPE_FRAGMENT,"Alpha","COLOR.a","",SLOT_TYPE_SCALAR,SLOT_OUT}, {MODE_CANVAS_ITEM,SHADER_TYPE_FRAGMENT,"Alpha","COLOR.a","",SLOT_TYPE_SCALAR,SLOT_OUT},
{MODE_CANVAS_ITEM,SHADER_TYPE_FRAGMENT,"Normal","NORMAL","",SLOT_TYPE_VEC,SLOT_OUT}, {MODE_CANVAS_ITEM,SHADER_TYPE_FRAGMENT,"Normal","NORMAL","",SLOT_TYPE_VEC,SLOT_OUT},
{MODE_CANVAS_ITEM,SHADER_TYPE_FRAGMENT,"NormalMap","NORMALMAP","",SLOT_TYPE_VEC,SLOT_OUT},
{MODE_CANVAS_ITEM,SHADER_TYPE_FRAGMENT,"NormalMapDepth","NORMALMAP_DEPTH","",SLOT_TYPE_SCALAR,SLOT_OUT},
//canvas item light in //canvas item light in
{MODE_CANVAS_ITEM,SHADER_TYPE_LIGHT,"Color","COLOR.rgb","",SLOT_TYPE_VEC,SLOT_IN}, {MODE_CANVAS_ITEM,SHADER_TYPE_LIGHT,"Color","COLOR.rgb","",SLOT_TYPE_VEC,SLOT_IN},
{MODE_CANVAS_ITEM,SHADER_TYPE_LIGHT,"Alpha","COLOR.a","",SLOT_TYPE_SCALAR,SLOT_IN}, {MODE_CANVAS_ITEM,SHADER_TYPE_LIGHT,"Alpha","COLOR.a","",SLOT_TYPE_SCALAR,SLOT_IN},

View file

@ -1145,6 +1145,8 @@ const ShaderLanguage::BuiltinsDef ShaderLanguage::ci_fragment_builtins_defs[]={
{ "SRC_COLOR", TYPE_VEC4}, { "SRC_COLOR", TYPE_VEC4},
{ "POSITION", TYPE_VEC4}, { "POSITION", TYPE_VEC4},
{ "NORMAL", TYPE_VEC3}, { "NORMAL", TYPE_VEC3},
{ "NORMALMAP", TYPE_VEC3},
{ "NORMALMAP_DEPTH", TYPE_FLOAT},
{ "UV", TYPE_VEC2}, { "UV", TYPE_VEC2},
{ "COLOR", TYPE_VEC4}, { "COLOR", TYPE_VEC4},
{ "TEXTURE", TYPE_TEXTURE}, { "TEXTURE", TYPE_TEXTURE},