Merge pull request #81160 from paddy-exe/canvas-uv-world-space
Add render mode to use world coordinates in canvas item shader
This commit is contained in:
commit
9a1b4f338b
5 changed files with 13 additions and 2 deletions
|
@ -199,6 +199,10 @@ void main() {
|
||||||
#ifdef USE_POINT_SIZE
|
#ifdef USE_POINT_SIZE
|
||||||
float point_size = 1.0;
|
float point_size = 1.0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef USE_WORLD_VERTEX_COORDS
|
||||||
|
vertex = (model_matrix * vec4(vertex, 0.0, 1.0)).xy;
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
#CODE : VERTEX
|
#CODE : VERTEX
|
||||||
}
|
}
|
||||||
|
@ -207,7 +211,7 @@ void main() {
|
||||||
pixel_size_interp = abs(read_draw_data_dst_rect.zw) * vertex_base;
|
pixel_size_interp = abs(read_draw_data_dst_rect.zw) * vertex_base;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined(SKIP_TRANSFORM_USED)
|
#if !defined(SKIP_TRANSFORM_USED) && !defined(USE_WORLD_VERTEX_COORDS)
|
||||||
vertex = (model_matrix * vec4(vertex, 0.0, 1.0)).xy;
|
vertex = (model_matrix * vec4(vertex, 0.0, 1.0)).xy;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -1184,6 +1184,7 @@ MaterialStorage::MaterialStorage() {
|
||||||
actions.render_mode_defines["skip_vertex_transform"] = "#define SKIP_TRANSFORM_USED\n";
|
actions.render_mode_defines["skip_vertex_transform"] = "#define SKIP_TRANSFORM_USED\n";
|
||||||
actions.render_mode_defines["unshaded"] = "#define MODE_UNSHADED\n";
|
actions.render_mode_defines["unshaded"] = "#define MODE_UNSHADED\n";
|
||||||
actions.render_mode_defines["light_only"] = "#define MODE_LIGHT_ONLY\n";
|
actions.render_mode_defines["light_only"] = "#define MODE_LIGHT_ONLY\n";
|
||||||
|
actions.render_mode_defines["world_vertex_coords"] = "#define USE_WORLD_VERTEX_COORDS\n";
|
||||||
|
|
||||||
actions.global_buffer_array_variable = "global_shader_uniforms";
|
actions.global_buffer_array_variable = "global_shader_uniforms";
|
||||||
|
|
||||||
|
|
|
@ -2480,6 +2480,7 @@ RendererCanvasRenderRD::RendererCanvasRenderRD() {
|
||||||
actions.render_mode_defines["skip_vertex_transform"] = "#define SKIP_TRANSFORM_USED\n";
|
actions.render_mode_defines["skip_vertex_transform"] = "#define SKIP_TRANSFORM_USED\n";
|
||||||
actions.render_mode_defines["unshaded"] = "#define MODE_UNSHADED\n";
|
actions.render_mode_defines["unshaded"] = "#define MODE_UNSHADED\n";
|
||||||
actions.render_mode_defines["light_only"] = "#define MODE_LIGHT_ONLY\n";
|
actions.render_mode_defines["light_only"] = "#define MODE_LIGHT_ONLY\n";
|
||||||
|
actions.render_mode_defines["world_vertex_coords"] = "#define USE_WORLD_VERTEX_COORDS\n";
|
||||||
|
|
||||||
actions.custom_samplers["TEXTURE"] = "texture_sampler";
|
actions.custom_samplers["TEXTURE"] = "texture_sampler";
|
||||||
actions.custom_samplers["NORMAL_TEXTURE"] = "texture_sampler";
|
actions.custom_samplers["NORMAL_TEXTURE"] = "texture_sampler";
|
||||||
|
|
|
@ -180,6 +180,10 @@ void main() {
|
||||||
#ifdef USE_POINT_SIZE
|
#ifdef USE_POINT_SIZE
|
||||||
float point_size = 1.0;
|
float point_size = 1.0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef USE_WORLD_VERTEX_COORDS
|
||||||
|
vertex = (model_matrix * vec4(vertex, 0.0, 1.0)).xy;
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
#CODE : VERTEX
|
#CODE : VERTEX
|
||||||
}
|
}
|
||||||
|
@ -188,7 +192,7 @@ void main() {
|
||||||
pixel_size_interp = abs(draw_data.dst_rect.zw) * vertex_base;
|
pixel_size_interp = abs(draw_data.dst_rect.zw) * vertex_base;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined(SKIP_TRANSFORM_USED)
|
#if !defined(SKIP_TRANSFORM_USED) && !defined(USE_WORLD_VERTEX_COORDS)
|
||||||
vertex = (model_matrix * vec4(vertex, 0.0, 1.0)).xy;
|
vertex = (model_matrix * vec4(vertex, 0.0, 1.0)).xy;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -321,6 +321,7 @@ ShaderTypes::ShaderTypes() {
|
||||||
shader_modes[RS::SHADER_CANVAS_ITEM].modes.push_back({ PNAME("blend"), "mix", "add", "sub", "mul", "premul_alpha", "disabled" });
|
shader_modes[RS::SHADER_CANVAS_ITEM].modes.push_back({ PNAME("blend"), "mix", "add", "sub", "mul", "premul_alpha", "disabled" });
|
||||||
shader_modes[RS::SHADER_CANVAS_ITEM].modes.push_back({ PNAME("unshaded") });
|
shader_modes[RS::SHADER_CANVAS_ITEM].modes.push_back({ PNAME("unshaded") });
|
||||||
shader_modes[RS::SHADER_CANVAS_ITEM].modes.push_back({ PNAME("light_only") });
|
shader_modes[RS::SHADER_CANVAS_ITEM].modes.push_back({ PNAME("light_only") });
|
||||||
|
shader_modes[RS::SHADER_CANVAS_ITEM].modes.push_back({ PNAME("world_vertex_coords") });
|
||||||
}
|
}
|
||||||
|
|
||||||
/************ PARTICLES **************************/
|
/************ PARTICLES **************************/
|
||||||
|
|
Loading…
Reference in a new issue