shader_type spatial; render_mode blend_mix,depth_draw_opaque,cull_back,diffuse_burley,specular_schlick_ggx; uniform vec4 albedo : hint_color; uniform sampler2D texture_grass : hint_albedo; uniform sampler2D texture_grass_25 : hint_albedo; uniform sampler2D texture_grass_height : hint_white; uniform sampler2D texture_dirt : hint_albedo; uniform sampler2D texture_dirt_height : hint_black; uniform sampler2D texture_hsv_mask : hint_white; uniform sampler2D texture_hsv2_mask : hint_white; uniform sampler2D texture_albedo_mix : hint_black; uniform sampler2D texture_mix_gradiant : hint_black; uniform sampler2D texture_mix_border : hint_black; uniform sampler2D texture_albedo_mix2 : hint_black; uniform float specular; uniform float metallic; uniform float roughness : hint_range(0,1); uniform float point_size : hint_range(0,128); uniform sampler2D texture_roughness : hint_white; uniform sampler2D texture_roughness_dirt : hint_white; uniform vec4 roughness_texture_channel; uniform sampler2D texture_normal : hint_normal; uniform sampler2D texture_normal_dirt : hint_normal; uniform float normal_scale : hint_range(-16,16); uniform sampler2D texture_ambient_occlusion : hint_white; uniform sampler2D texture_ambient_occlusion_dirt : hint_white; uniform vec4 ao_texture_channel; uniform float ao_light_affect; uniform vec3 uv1_scale; uniform vec3 uv1_offset; uniform vec3 uv2_scale; uniform vec3 uv2_offset; uniform vec3 hsv; uniform float grass_level = 1.0; uniform float angle = 0.0; varying vec2 base_uv; varying vec2 rotated_uv; varying vec2 rotated_uv_mask; varying float v_index; vec2 rotateUVmatrinx(vec2 uv, vec2 pivot, float rotation) { mat2 rotation_matrix=mat2( vec2(sin(rotation),-cos(rotation)), vec2(cos(rotation),sin(rotation)) ); uv -= pivot; uv= uv*rotation_matrix; uv += pivot; return uv; } vec2 rotateUV(vec2 uv, vec2 pivot, float rotation) { float sine = sin(rotation); float cosine = cos(rotation); uv -= pivot; uv.x = uv.x * cosine - uv.y * sine; uv.y = uv.x * sine + uv.y * cosine; uv += pivot; return uv; } vec3 rgb2hsv(vec3 c) { vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0); vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g)); vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r)); float d = q.x - min(q.w, q.y); float e = 1.0e-10; return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x); } vec3 hsv2rgb(vec3 c) { vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0); vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www); return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y); } void vertex() { v_index = mod(VERTEX.x, 1024.0/200.0); base_uv=UV*uv1_scale.xy+uv1_offset.xy; rotated_uv = rotateUVmatrinx(base_uv, vec2(0.5), (v_index)); // rotated_uv = base_uv; rotated_uv_mask = rotateUVmatrinx(UV, vec2(0.5), (v_index)); // rotated_uv_mask = UV; } void fragment() { // vec2 base_uv = UV; vec4 grass_tex = texture(texture_grass,base_uv); vec4 grass_25_tex = texture(texture_grass_25,base_uv); vec4 grass_height_tex = texture(texture_grass_height,base_uv); vec4 dirt_tex = texture(texture_dirt,base_uv); vec4 dirt_height_tex = texture(texture_dirt_height,base_uv); vec4 dirt_height_hsv_tex = texture(texture_dirt_height,rotated_uv_mask); vec4 hsv_mask_tex = texture(texture_hsv_mask,UV); vec4 hsv2_mask_tex = texture(texture_hsv2_mask,UV*vec2(1.0,1.0)); vec4 albedo_mix_tex; // if ( abs(v_index) > 1.28 ) // { // albedo_mix_tex = texture(texture_hsv_mask,UV); // } // else { albedo_mix_tex = texture(texture_albedo_mix,UV); } vec4 mix_gradiant_tex = texture(texture_mix_gradiant,vec2( albedo_mix_tex.r, albedo_mix_tex.r )); vec4 albedo_mix_tex_low = texture(texture_albedo_mix,UV*vec2(50.0,50.0)); vec4 mix_gradiant_low_tex = texture(texture_mix_gradiant,vec2( albedo_mix_tex_low.r, albedo_mix_tex_low.r )); vec4 mix_gradiant_border = texture(texture_mix_border,vec2( albedo_mix_tex_low.r, albedo_mix_tex_low.r )); vec4 albedo_mix_tex2 = texture(texture_albedo_mix2,base_uv); vec4 mix_gradiant2_tex = texture(texture_mix_gradiant,vec2( albedo_mix_tex2.r, albedo_mix_tex2.r )); // ALBEDO = albedo.rgb * grass_tex.rgb; // // vec3 hsv_albedo = rgb2hsv(ALBEDO); vec3 hsv_mask = rgb2hsv( hsv_mask_tex.rgb ); vec3 hsv2_mask = rgb2hsv( hsv2_mask_tex.rgb ); // hsv_albedo.x *= hsv.x; // hsv_albedo.y = hsv.y; // hsv_albedo.z *= hsv.z * (hsv_mask.z * hsv2_mask.z*2.0); // ALBEDO = hsv2rgb( hsv_albedo ); vec4 mix_mix = mix( mix_gradiant_tex, mix_gradiant_border, 0.5 ); float mix_level = clamp( mix_gradiant_tex.r-grass_level, 0.0, 1.0 ); // float mix_level = clamp( mix_gradiant_tex.r*mix_gradiant_border.r-grass_level, 0.0, 1.0 ); // if ( grass_height_tex.r > 0.5 ) // { //// mix_level = 0.0; // } // else // { // mix_level = 1.0; // } if ( mix_level > 0.0 && mix_level < 1.0 ) { if ( grass_height_tex.r < dirt_height_tex.r ) { // mix_level = 0.0; } else { // mix_level = 1.0; } } // mix_level *= mix_level; // mix_level *= mix_level; // mix_level *= mix_level; vec3 hsv_dirt = rgb2hsv(dirt_tex.rgb); // hsv_dirt.x += (hsv_mask.z)*0.1; hsv_dirt.y = hsv.y*(hsv_mask.z * hsv2_mask.z *2.0); hsv_dirt.z *= hsv.z*(hsv_mask.z * hsv2_mask.z *2.0); dirt_tex.rgb = hsv2rgb( hsv_dirt ); vec3 hsv_grass = rgb2hsv(grass_tex.rgb); // hsv_grass.x *= hsv.x; hsv_grass.y = hsv.y*(hsv_mask.z * hsv2_mask.z *2.0); hsv_grass.z *= hsv.z*(hsv_mask.z * hsv2_mask.z *2.0); grass_tex.rgb = hsv2rgb( hsv_grass ); vec3 hsv_grass_25 = rgb2hsv(grass_25_tex.rgb); hsv_grass_25.y = hsv.y*(hsv_mask.z * hsv2_mask.z *2.0); hsv_grass_25.z *= hsv.z*(hsv_mask.z * hsv2_mask.z *2.0); grass_25_tex.rgb = hsv2rgb( hsv_grass_25 ); ALBEDO = dirt_tex.rgb; if ( mix_level >= 1.0 ) { // ALBEDO = mix( ALBEDO, grass_tex.rgb, mix_level); } else if ( mix_level >= 0.5 ) { // ALBEDO = mix( ALBEDO, grass_25_tex.rgb, mix_gradiant_border.r*mix_level ); ALBEDO = mix( ALBEDO, grass_25_tex.rgb, mix_level ); } else { // ALBEDO = mix( ALBEDO, grass_25_tex.rgb, mix_level ); } ALBEDO = mix( ALBEDO, grass_tex.rgb, mix_level*mix_level*mix_level*mix_level); METALLIC = metallic; vec4 final_roughness = mix( texture(texture_roughness_dirt,base_uv),texture(texture_roughness,base_uv), mix_level ); ROUGHNESS = dot(final_roughness, roughness_texture_channel) * roughness; SPECULAR = specular; vec4 final_normal = mix( texture(texture_normal_dirt,base_uv),texture(texture_normal,base_uv), mix_level ); NORMALMAP = final_normal.rgb; NORMALMAP_DEPTH = normal_scale; vec4 final_ao = mix( texture(texture_ambient_occlusion_dirt,base_uv), texture(texture_ambient_occlusion,base_uv), mix_level ); AO = dot(final_ao,ao_texture_channel); AO_LIGHT_AFFECT = ao_light_affect; }