new shaders
This commit is contained in:
		
							parent
							
								
									c4115b3569
								
							
						
					
					
						commit
						7ada6a0f2c
					
				
					 24 changed files with 567 additions and 124 deletions
				
			
		
							
								
								
									
										51
									
								
								shaders/010_edge_detection/edge_detection.gdshader
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								shaders/010_edge_detection/edge_detection.gdshader
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,51 @@ | |||
| shader_type spatial; | ||||
| render_mode unshaded; | ||||
| 
 | ||||
| uniform sampler2D SCREEN_TEXTURE: hint_screen_texture, repeat_disable, filter_nearest; | ||||
| 
 | ||||
| vec3 convolution(sampler2D tex, vec2 uv, vec2 pixel_size) { | ||||
| 	vec3 conv = vec3(0.0, 0.0, 0.0); | ||||
| 
 | ||||
| 	for (int row = 0; row < 3; row++) { | ||||
| 		for (int col = 0; col < 3; col++) { | ||||
| 			conv += texture(tex, uv + vec2(float(col - 1), float(row - 1)) * pixel_size).rgb; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return conv; | ||||
| } | ||||
| 
 | ||||
| void fragment() { | ||||
| 	// All surrounding pixels | ||||
| 	vec3 pixels[9]; | ||||
| 	// [0, 1, 2] | ||||
| 	// [3, 4, 5] | ||||
| 	// [6, 7, 8] | ||||
| 	for (int row = 0; row < 3; row++) { | ||||
| 		for (int col = 0; col < 3; col++) { | ||||
| 			vec2 uv = SCREEN_UV + vec2(float(col - 1), float(row - 1)) * 1.0 / VIEWPORT_SIZE;// SCREEN_PIXEL_SIZE; | ||||
| 			pixels[row * 3 + col] = convolution(SCREEN_TEXTURE, uv, 1.0 / VIEWPORT_SIZE); //SCREEN_PIXEL_SIZE); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Apply Sobel Operator | ||||
| 	// Sobel Edge Horizontal | ||||
| 	vec3 gx = ( | ||||
| 		pixels[0] * -1.0 + pixels[3] * -2.0 + pixels[6] * -1.0 + | ||||
| 		pixels[2] * 1.0 + pixels[5] * 2.0 + pixels[8] * 1.0 | ||||
| 	); | ||||
| 
 | ||||
| 	// Sobel Edge Vertical | ||||
| 	vec3 gy = ( | ||||
| 		pixels[0] * -1.0 + pixels[1] * -2.0 + pixels[2] * -1.0 + | ||||
| 		pixels[6] * 1.0 + pixels[7] * 2.0 + pixels[8] * 1.0 | ||||
| 	); | ||||
| 
 | ||||
| 	vec3 sobel = sqrt(gx * gx + gy * gy); | ||||
| 
 | ||||
| 	float alpha = sobel.r + sobel.g + sobel.b; | ||||
| 	alpha /= 3.0; | ||||
| 
 | ||||
| 	ALPHA = alpha; | ||||
| 	ALBEDO = sobel; | ||||
| } | ||||
							
								
								
									
										25
									
								
								shaders/010_edge_detection/edge_detection.tscn
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								shaders/010_edge_detection/edge_detection.tscn
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,25 @@ | |||
| [gd_scene load_steps=6 format=3 uid="uid://drgqrnj1otb25"] | ||||
| 
 | ||||
| [ext_resource type="Shader" path="res://shaders/010_edge_detection/edge_detection.gdshader" id="1_34hnr"] | ||||
| 
 | ||||
| [sub_resource type="ShaderMaterial" id="ShaderMaterial_vbj21"] | ||||
| 
 | ||||
| [sub_resource type="SphereMesh" id="SphereMesh_wnbfj"] | ||||
| material = SubResource("ShaderMaterial_vbj21") | ||||
| 
 | ||||
| [sub_resource type="ShaderMaterial" id="ShaderMaterial_855vq"] | ||||
| render_priority = 0 | ||||
| shader = ExtResource("1_34hnr") | ||||
| 
 | ||||
| [sub_resource type="QuadMesh" id="QuadMesh_sbqxy"] | ||||
| size = Vector2(1.6, 2) | ||||
| 
 | ||||
| [node name="EdgeDetection" type="Node3D"] | ||||
| 
 | ||||
| [node name="MeshInstance3D" type="MeshInstance3D" parent="."] | ||||
| mesh = SubResource("SphereMesh_wnbfj") | ||||
| 
 | ||||
| [node name="MeshInstance3D2" type="MeshInstance3D" parent="."] | ||||
| transform = Transform3D(1, 0, 0, 0, 0.965926, -0.258819, 0, 0.258819, 0.965926, 0, 0.322139, 0.653597) | ||||
| material_override = SubResource("ShaderMaterial_855vq") | ||||
| mesh = SubResource("QuadMesh_sbqxy") | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Luca
						Luca