mirror of
https://github.com/Relintai/material-maker.git
synced 2025-01-25 18:59:18 +01:00
Added types to ios nodes
This commit is contained in:
parent
f0a22b593f
commit
97e923e781
@ -37,12 +37,14 @@ var parameters = {}
|
|||||||
var seed_locked : bool = false
|
var seed_locked : bool = false
|
||||||
var seed_value : int = 0
|
var seed_value : int = 0
|
||||||
|
|
||||||
|
const PORT_TYPE_NAMES : Array = [ "f", "rgb", "rgba", "sdf2d", "sdf3d" ]
|
||||||
|
|
||||||
const PORT_TYPES : Dictionary = {
|
const PORT_TYPES : Dictionary = {
|
||||||
rgba = { type="vec4", paramdefs="vec2 uv", params="uv" },
|
f = { type="float", paramdefs="vec2 uv", params="uv", slot_type=0, color=Color(0.5, 0.5, 0.5) },
|
||||||
rgb = { type="vec3", paramdefs="vec2 uv", params="uv" },
|
rgb = { type="vec3", paramdefs="vec2 uv", params="uv", slot_type=0, color=Color(0.5, 0.5, 1.0) },
|
||||||
f = { type="float", paramdefs="vec2 uv", params="uv" },
|
rgba = { type="vec4", paramdefs="vec2 uv", params="uv", slot_type=0, color=Color(0.0, 0.5, 0.0, 0.5) },
|
||||||
sdf2d = { type="float", paramdefs="vec2 uv", params="uv" },
|
sdf2d = { type="float", paramdefs="vec2 uv", params="uv", slot_type=1, color=Color(1.0, 0.5, 0.0) },
|
||||||
sdf3d = { type="float", paramdefs="vec3 p", params="p" }
|
sdf3d = { type="float", paramdefs="vec3 p", params="p", slot_type=2, color=Color(1.0, 0.0, 0.0) }
|
||||||
}
|
}
|
||||||
|
|
||||||
func _ready() -> void:
|
func _ready() -> void:
|
||||||
|
@ -284,8 +284,8 @@ func create_subgraph(gens : Array) -> MMGenGraph:
|
|||||||
if port_index == -1:
|
if port_index == -1:
|
||||||
port_index = outputs.size()
|
port_index = outputs.size()
|
||||||
outputs.push_back(src_name)
|
outputs.push_back(src_name)
|
||||||
gen_outputs.ports.push_back( { name="port"+str(port_index), type="rgba" } )
|
var type = new_graph.get_node(c.from).get_output_defs()[c.from_port].type
|
||||||
print(gen_outputs.ports)
|
gen_outputs.ports.push_back( { name="port"+str(port_index), type=type } )
|
||||||
my_new_connections.push_back( { from=new_graph.name, from_port=port_index, to=c.to, to_port=c.to_port } )
|
my_new_connections.push_back( { from=new_graph.name, from_port=port_index, to=c.to, to_port=c.to_port } )
|
||||||
new_graph_connections.push_back( { from=c.from, from_port=c.from_port, to="gen_outputs", to_port=port_index } )
|
new_graph_connections.push_back( { from=c.from, from_port=c.from_port, to="gen_outputs", to_port=port_index } )
|
||||||
elif names.find(c.to) != -1:
|
elif names.find(c.to) != -1:
|
||||||
@ -293,7 +293,8 @@ func create_subgraph(gens : Array) -> MMGenGraph:
|
|||||||
if port_index == -1:
|
if port_index == -1:
|
||||||
port_index = inputs.size()
|
port_index = inputs.size()
|
||||||
inputs.push_back(src_name)
|
inputs.push_back(src_name)
|
||||||
gen_inputs.ports.push_back( { name="port"+str(port_index), type="rgba" } )
|
var type = get_node(c.from).get_output_defs()[c.from_port].type
|
||||||
|
gen_inputs.ports.push_back( { name="port"+str(port_index), type=type } )
|
||||||
my_new_connections.push_back( { from=c.from, from_port=c.from_port, to=new_graph.name, to_port=port_index } )
|
my_new_connections.push_back( { from=c.from, from_port=c.from_port, to=new_graph.name, to_port=port_index } )
|
||||||
new_graph_connections.push_back( { from="gen_inputs", from_port=port_index, to=c.to, to_port=c.to_port } )
|
new_graph_connections.push_back( { from="gen_inputs", from_port=port_index, to=c.to, to_port=c.to_port } )
|
||||||
else:
|
else:
|
||||||
|
@ -27,7 +27,7 @@ func get_type_name() -> String:
|
|||||||
func get_io_defs() -> Array:
|
func get_io_defs() -> Array:
|
||||||
var rv : Array = []
|
var rv : Array = []
|
||||||
for p in ports:
|
for p in ports:
|
||||||
rv.push_back({ name=p.name, type="rgba" })
|
rv.push_back({ name=p.name, type=p.type })
|
||||||
return rv
|
return rv
|
||||||
|
|
||||||
func get_input_defs() -> Array:
|
func get_input_defs() -> Array:
|
||||||
@ -54,6 +54,11 @@ func add_port() -> void:
|
|||||||
func set_port_name(i : int, n : String) -> void:
|
func set_port_name(i : int, n : String) -> void:
|
||||||
ports[i].name = n
|
ports[i].name = n
|
||||||
|
|
||||||
|
func set_port_type(i : int, t : String) -> void:
|
||||||
|
print(t)
|
||||||
|
ports[i].type = t
|
||||||
|
emit_signal("parameter_changed", "__update_all__", null)
|
||||||
|
|
||||||
func delete_port(i : int) -> void:
|
func delete_port(i : int) -> void:
|
||||||
ports.remove(i)
|
ports.remove(i)
|
||||||
var input_gen = get_parent() if name == "gen_inputs" else self
|
var input_gen = get_parent() if name == "gen_inputs" else self
|
||||||
|
@ -174,14 +174,12 @@ func update_node() -> void:
|
|||||||
var input = inputs[i]
|
var input = inputs[i]
|
||||||
var enable_left = false
|
var enable_left = false
|
||||||
var color_left = Color(0.5, 0.5, 0.5)
|
var color_left = Color(0.5, 0.5, 0.5)
|
||||||
|
var type_left = 0
|
||||||
if typeof(input) == TYPE_DICTIONARY:
|
if typeof(input) == TYPE_DICTIONARY:
|
||||||
enable_left = true
|
enable_left = true
|
||||||
match input.type:
|
color_left = MMGenBase.PORT_TYPES[input.type].color
|
||||||
"rgb": color_left = Color(0.5, 0.5, 1.0)
|
type_left = MMGenBase.PORT_TYPES[input.type].slot_type
|
||||||
"rgba": color_left = Color(0.0, 0.5, 0.0, 0.5)
|
set_slot(i, enable_left, type_left, color_left, false, 0, Color())
|
||||||
"sdf2d": color_left = Color(1.0, 0.5, 0.0, 1.0)
|
|
||||||
"sdf3d": color_left = Color(1.0, 0.0, 0.0, 1.0)
|
|
||||||
set_slot(i, enable_left, 0, color_left, false, 0, Color())
|
|
||||||
var hsizer : HBoxContainer = HBoxContainer.new()
|
var hsizer : HBoxContainer = HBoxContainer.new()
|
||||||
hsizer.size_flags_horizontal = SIZE_EXPAND | SIZE_FILL
|
hsizer.size_flags_horizontal = SIZE_EXPAND | SIZE_FILL
|
||||||
if input.has("label") and input.label != "":
|
if input.has("label") and input.label != "":
|
||||||
@ -247,17 +245,15 @@ func update_node() -> void:
|
|||||||
output_count = outputs.size()
|
output_count = outputs.size()
|
||||||
for i in range(output_count):
|
for i in range(output_count):
|
||||||
var output = outputs[i]
|
var output = outputs[i]
|
||||||
var enable_right = true
|
var enable_right : bool = true
|
||||||
var color_right = Color(0.5, 0.5, 0.5)
|
var color_right : Color = Color(0.5, 0.5, 0.5)
|
||||||
|
var type_right : int = 0
|
||||||
assert(typeof(output) == TYPE_DICTIONARY)
|
assert(typeof(output) == TYPE_DICTIONARY)
|
||||||
assert(output.has("type"))
|
assert(output.has("type"))
|
||||||
enable_right = true
|
enable_right = true
|
||||||
match output.type:
|
color_right = MMGenBase.PORT_TYPES[output.type].color
|
||||||
"rgb": color_right = Color(0.5, 0.5, 1.0)
|
type_right = MMGenBase.PORT_TYPES[output.type].slot_type
|
||||||
"rgba": color_right = Color(0.0, 0.5, 0.0, 0.5)
|
set_slot(i, is_slot_enabled_left(i), get_slot_type_left(i), get_slot_color_left(i), enable_right, type_right, color_right)
|
||||||
"sdf2d": color_right = Color(1.0, 0.5, 0.0, 1.0)
|
|
||||||
"sdf3d": color_right = Color(1.0, 0.0, 0.0, 1.0)
|
|
||||||
set_slot(i, is_slot_enabled_left(i), get_slot_type_left(i), get_slot_color_left(i), enable_right, 0, color_right)
|
|
||||||
var hsizer : HBoxContainer
|
var hsizer : HBoxContainer
|
||||||
while i >= get_child_count():
|
while i >= get_child_count():
|
||||||
hsizer = HBoxContainer.new()
|
hsizer = HBoxContainer.new()
|
||||||
|
@ -22,12 +22,14 @@ func update_node() -> void:
|
|||||||
title = generator.get_type_name()
|
title = generator.get_type_name()
|
||||||
var color = Color(0.0, 0.5, 0.0, 0.5)
|
var color = Color(0.0, 0.5, 0.0, 0.5)
|
||||||
for p in generator.get_io_defs():
|
for p in generator.get_io_defs():
|
||||||
|
color = MMGenBase.PORT_TYPES[p.type].color
|
||||||
set_slot(get_child_count(), generator.name != "gen_inputs", 0, color, generator.name != "gen_outputs", 0, color)
|
set_slot(get_child_count(), generator.name != "gen_inputs", 0, color, generator.name != "gen_outputs", 0, color)
|
||||||
var port : Control
|
var port : Control
|
||||||
if generator.is_editable():
|
if generator.is_editable():
|
||||||
port = preload("res://addons/material_maker/nodes/ios/port.tscn").instance()
|
port = preload("res://addons/material_maker/nodes/ios/port.tscn").instance()
|
||||||
if p.has("name"):
|
if p.has("name"):
|
||||||
port.set_label(p.name)
|
port.set_label(p.name)
|
||||||
|
port.set_type(p.type)
|
||||||
else:
|
else:
|
||||||
port = Label.new()
|
port = Label.new()
|
||||||
port.text = p.name
|
port.text = p.name
|
||||||
|
@ -3,6 +3,9 @@ extends HBoxContainer
|
|||||||
func set_label(l : String) -> void:
|
func set_label(l : String) -> void:
|
||||||
$Name.set_text(l)
|
$Name.set_text(l)
|
||||||
|
|
||||||
|
func set_type(t : String) -> void:
|
||||||
|
$Type.selected = MMGenBase.PORT_TYPE_NAMES.find(t)
|
||||||
|
|
||||||
func update_up_down_button() -> void:
|
func update_up_down_button() -> void:
|
||||||
var parent = get_parent()
|
var parent = get_parent()
|
||||||
if parent == null:
|
if parent == null:
|
||||||
@ -13,6 +16,9 @@ func update_up_down_button() -> void:
|
|||||||
func _on_Name_label_changed(new_label) -> void:
|
func _on_Name_label_changed(new_label) -> void:
|
||||||
get_parent().generator.set_port_name(get_index(), new_label)
|
get_parent().generator.set_port_name(get_index(), new_label)
|
||||||
|
|
||||||
|
func _on_Type_item_selected(ID) -> void:
|
||||||
|
get_parent().generator.set_port_type(get_index(), MMGenBase.PORT_TYPE_NAMES[ID])
|
||||||
|
|
||||||
func _on_Delete_pressed() -> void:
|
func _on_Delete_pressed() -> void:
|
||||||
get_parent().generator.delete_port(get_index())
|
get_parent().generator.delete_port(get_index())
|
||||||
|
|
||||||
|
@ -48,7 +48,18 @@ margin_left = 84.0
|
|||||||
margin_right = 114.0
|
margin_right = 114.0
|
||||||
margin_bottom = 20.0
|
margin_bottom = 20.0
|
||||||
rect_min_size = Vector2( 30, 0 )
|
rect_min_size = Vector2( 30, 0 )
|
||||||
|
|
||||||
|
[node name="Type" type="OptionButton" parent="."]
|
||||||
|
margin_left = 118.0
|
||||||
|
margin_right = 222.0
|
||||||
|
margin_bottom = 20.0
|
||||||
|
rect_min_size = Vector2( 102, 0 )
|
||||||
|
hint_tooltip = "Input flag"
|
||||||
|
text = "Greyscale"
|
||||||
|
items = [ "Greyscale", null, false, 0, null, "Color", null, false, 1, null, "RGBA", null, false, 2, null, "SDF2D", null, false, 3, null, "SDF3D", null, false, 4, null ]
|
||||||
|
selected = 0
|
||||||
[connection signal="pressed" from="Delete" to="." method="_on_Delete_pressed"]
|
[connection signal="pressed" from="Delete" to="." method="_on_Delete_pressed"]
|
||||||
[connection signal="pressed" from="Up" to="." method="_on_Up_pressed"]
|
[connection signal="pressed" from="Up" to="." method="_on_Up_pressed"]
|
||||||
[connection signal="pressed" from="Down" to="." method="_on_Down_pressed"]
|
[connection signal="pressed" from="Down" to="." method="_on_Down_pressed"]
|
||||||
[connection signal="label_changed" from="Name" to="." method="_on_Name_label_changed"]
|
[connection signal="label_changed" from="Name" to="." method="_on_Name_label_changed"]
|
||||||
|
[connection signal="item_selected" from="Type" to="." method="_on_Type_item_selected"]
|
||||||
|
Loading…
Reference in New Issue
Block a user