mirror of
https://github.com/DigvijaysinhGohil/Godot-Shader-Lib.git
synced 2025-01-08 10:23:24 +08:00
Koch Fractal node added
This commit is contained in:
parent
b41d1dff80
commit
b2ba78fa43
86
addons/ShaderLib/Procedural/Shapes/KochFractal.gd
Normal file
86
addons/ShaderLib/Procedural/Shapes/KochFractal.gd
Normal file
@ -0,0 +1,86 @@
|
||||
@tool
|
||||
class_name VisualShaderNodeProceduralKochFractal extends VisualShaderNodeCustom
|
||||
|
||||
func _init() -> void:
|
||||
output_port_for_preview = 0
|
||||
|
||||
func _get_name() -> String:
|
||||
return "KochFractal"
|
||||
|
||||
func _get_category() -> String:
|
||||
return "Procedural/Shapes"
|
||||
|
||||
func _get_description() -> String:
|
||||
return "Generates an koch curve similar to ice fractal shape based on input UV at the size specified by inputs width and height."
|
||||
|
||||
func _get_return_icon_type() -> PortType:
|
||||
return PORT_TYPE_SCALAR
|
||||
|
||||
func _get_input_port_count() -> int:
|
||||
return 5
|
||||
|
||||
func _get_input_port_name(port: int) -> String:
|
||||
match port:
|
||||
0:
|
||||
return "uv"
|
||||
1:
|
||||
return "thickness"
|
||||
2:
|
||||
return "iterations"
|
||||
3:
|
||||
return "widht"
|
||||
_:
|
||||
return "height"
|
||||
|
||||
func _get_input_port_type(port: int) -> PortType:
|
||||
match port:
|
||||
0:
|
||||
return PORT_TYPE_VECTOR_2D
|
||||
2:
|
||||
return PORT_TYPE_SCALAR_INT
|
||||
_:
|
||||
return PORT_TYPE_SCALAR
|
||||
|
||||
func _get_input_port_default_value(port: int) -> Variant:
|
||||
match port:
|
||||
1, 3, 4:
|
||||
return 1.0
|
||||
2:
|
||||
return 3
|
||||
_:
|
||||
return null
|
||||
|
||||
func _get_output_port_count() -> int:
|
||||
return 2
|
||||
|
||||
func _get_output_port_name(port: int) -> String:
|
||||
match port:
|
||||
0:
|
||||
return "out"
|
||||
_:
|
||||
return "uv"
|
||||
|
||||
func _get_output_port_type(port: int) -> PortType:
|
||||
match port:
|
||||
1:
|
||||
return PORT_TYPE_VECTOR_2D
|
||||
_:
|
||||
return PORT_TYPE_SCALAR
|
||||
|
||||
func _get_global_code(mode: Shader.Mode) -> String:
|
||||
var code: String = preload("KochFractal.gdshaderinc").code
|
||||
return code
|
||||
|
||||
func _get_code(input_vars: Array[String], output_vars: Array[String], mode: Shader.Mode, type: VisualShader.Type) -> String:
|
||||
var uv: String = "UV"
|
||||
|
||||
if input_vars[0]:
|
||||
uv = input_vars[0]
|
||||
|
||||
var thickness: String = input_vars[1]
|
||||
var iterations: String = input_vars[2]
|
||||
var width: String = input_vars[3]
|
||||
var height: String = input_vars[4]
|
||||
|
||||
return output_vars[0] + " = koch_fractal(%s, %s, %s, %s, %s, %s);" % [uv, thickness, iterations, width, height, output_vars[1]]
|
||||
|
36
addons/ShaderLib/Procedural/Shapes/KochFractal.gdshaderinc
Normal file
36
addons/ShaderLib/Procedural/Shapes/KochFractal.gdshaderinc
Normal file
@ -0,0 +1,36 @@
|
||||
vec2 koch_fractal_direction(float angle){
|
||||
return vec2(sin(angle), cos(angle));
|
||||
}
|
||||
|
||||
float koch_fractal(vec2 uv, float outline, int iteration, float shape_width, float shape_height, out vec2 koch_uv) {
|
||||
float tiling = 3.0;
|
||||
vec2 center = uv - vec2(.5);
|
||||
shape_width = .85 * (shape_width / 1.);
|
||||
shape_height = .85 * (shape_height / 1.);
|
||||
center.x /= shape_width;
|
||||
center.y /= shape_height;
|
||||
|
||||
center.x = abs(center.x);
|
||||
center.y += tan(.833 * PI) * .5;
|
||||
vec2 dir = koch_fractal_direction(.833 * PI);
|
||||
float dist = dot(center - vec2(tiling / (2. * tiling), 0), dir);
|
||||
center -= dir * max(0, dist) * 2.0;
|
||||
|
||||
dir = koch_fractal_direction(.6667 * PI);
|
||||
float scale = 1.0;
|
||||
center.x += .5;
|
||||
for(int i = 0; i < iteration; i++){
|
||||
center *= tiling;
|
||||
scale *= tiling;
|
||||
center.x -= .5 * tiling;
|
||||
|
||||
center.x = abs(center.x);
|
||||
center.x -= .5;
|
||||
center -= dir * min(0.0, dot(center, dir)) * 2.0;
|
||||
}
|
||||
|
||||
dist = length(center - vec2(clamp(center.x, -1.0, 1.0), 0));
|
||||
dist += step(outline / 100.0, dist / scale);
|
||||
koch_uv = center;
|
||||
return 1.0 - dist;
|
||||
}
|
@ -38,6 +38,7 @@ Delete the contents of **_addons/ShaderLib_** folder from your project. Make sur
|
||||
<h3> Shapes</h3>
|
||||
|
||||
<h4><a href="/documentation/Nodes/Procedural/Shapes/Ellipse.md">  Ellipse node</a></h4>
|
||||
<h4><a href="/documentation/Nodes/Procedural/Shapes/KochFractal.md">  Koch Fractal node</a></h4>
|
||||
<h4><a href="/documentation/Nodes/Procedural/Shapes/Polygon.md">  Polygon node</a></h4>
|
||||
<h4><a href="/documentation/Nodes/Procedural/Shapes/Rectangle.md">  Rectangle node</a></h4>
|
||||
<h4><a href="/documentation/Nodes/Procedural/Shapes/RoundedPolygon.md">  Rounded Polygon node</a></h4>
|
||||
|
18
documentation/Nodes/Procedural/Shapes/KochFractal.md
Normal file
18
documentation/Nodes/Procedural/Shapes/KochFractal.md
Normal file
@ -0,0 +1,18 @@
|
||||
# Ellipse node
|
||||
Generates an koch curve similar to ice fractal shape based on input UV at the size specified by inputs <b><i>width</i></b> and <b><i>height</i></b>. The generated shape can be offset or tiled by connecting a <b><i>[TilingAndOffset](/documentation/Nodes/UV/TilingAndOffset.md)</i></b> node. Note that in order to preserve the ability to offset the shape within the UV space the shape will not automatically repeat if tiled. To achieve a repeating effect first connect your <b><i>TilingAndOffset</i></b> output through a <b><i>Fract</i></b> node.
|
||||
<hr>
|
||||
|
||||
**Inputs**
|
||||
|Name|Type|Binding|Description|
|
||||
|---|---|---|---|
|
||||
|uv|vec2|UV|Input UV value|
|
||||
|thickness|float|none|Shape outline thickness|
|
||||
|iterations|int|none|Number of steps to repeat the fractal shape|
|
||||
|width|float|none|Fractal width|
|
||||
|height|float|none|Fractal height|
|
||||
|
||||
**Outputs**
|
||||
|Name|Type|Binding|Description|
|
||||
|---|---|---|---|
|
||||
|output|float|None|Output ellipse value|
|
||||
___
|
Loading…
x
Reference in New Issue
Block a user