mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-25 18:39:18 +01:00
Fixed every issue found by clangd in MMGraphNode.
This commit is contained in:
parent
15ce82c23b
commit
5915042c20
@ -4,6 +4,14 @@
|
|||||||
#include "../nodes/mm_material.h"
|
#include "../nodes/mm_material.h"
|
||||||
#include "../nodes/mm_node.h"
|
#include "../nodes/mm_node.h"
|
||||||
#include "../nodes/mm_node_universal_property.h"
|
#include "../nodes/mm_node_universal_property.h"
|
||||||
|
#include "mat_maker_gd_editor.h"
|
||||||
|
|
||||||
|
#include "scene/gui/check_box.h"
|
||||||
|
#include "scene/gui/color_picker.h"
|
||||||
|
#include "scene/gui/label.h"
|
||||||
|
#include "scene/gui/line_edit.h"
|
||||||
|
#include "scene/gui/option_button.h"
|
||||||
|
#include "scene/gui/spin_box.h"
|
||||||
#include "scene/gui/texture_rect.h"
|
#include "scene/gui/texture_rect.h"
|
||||||
|
|
||||||
Ref<PackedScene> MMGraphNode::get_gradient_editor_scene() {
|
Ref<PackedScene> MMGraphNode::get_gradient_editor_scene() {
|
||||||
@ -42,22 +50,14 @@ Ref<MMNode> MMGraphNode::get_material_node() {
|
|||||||
return _node;
|
return _node;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ref<MMNode> MMGraphNode::get_node() {
|
Ref<MMNode> MMGraphNode::get_mm_node() {
|
||||||
return *_node;
|
return *_node;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::set_node(const Ref<MMNode> &val) {
|
void MMGraphNode::set_mm_node(const Ref<MMNode> &val) {
|
||||||
_node = val;
|
_node = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
Array MMGraphNode::get_properties() {
|
|
||||||
return properties;
|
|
||||||
}
|
|
||||||
|
|
||||||
void MMGraphNode::set_properties(const Array &val) {
|
|
||||||
properties = val;
|
|
||||||
}
|
|
||||||
|
|
||||||
MatMakerGDEditor *MMGraphNode::get_editor_node() {
|
MatMakerGDEditor *MMGraphNode::get_editor_node() {
|
||||||
return _editor_node;
|
return _editor_node;
|
||||||
}
|
}
|
||||||
@ -106,23 +106,28 @@ int MMGraphNode::add_slot_texture(const String &getter, const String &setter) {
|
|||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
int MMGraphNode::add_slot_texture_universal(const Ref<MMNodeUniversalProperty> &property) {
|
int MMGraphNode::add_slot_texture_universal(const Ref<MMNodeUniversalProperty> &p_property) {
|
||||||
|
Ref<MMNodeUniversalProperty> property = p_property;
|
||||||
|
|
||||||
TextureRect *t = memnew(TextureRect);
|
TextureRect *t = memnew(TextureRect);
|
||||||
t->set_custom_minimum_size(Vector2(128, 128));
|
t->set_custom_minimum_size(Vector2(128, 128));
|
||||||
t->set_expand(true);
|
t->set_expand(true);
|
||||||
t->set_stretch_mode(TextureRect::STRETCH_KEEP_ASPECT_CENTERED);
|
t->set_stretch_mode(TextureRect::STRETCH_KEEP_ASPECT_CENTERED);
|
||||||
int slot_idx = add_slot(property->input_slot_type, property.output_slot_type, "", "", t);
|
int slot_idx = add_slot(property->get_input_slot_type(), property->get_output_slot_type(), "", "", t);
|
||||||
Ref<Image> img = property->get_active_image();
|
Ref<Image> img = property->get_active_image();
|
||||||
Ref<ImageTexture> tex;
|
Ref<ImageTexture> tex;
|
||||||
tex.instance();
|
tex.instance();
|
||||||
|
|
||||||
if (img) {
|
if (img.is_valid()) {
|
||||||
tex->create_from_image(img, 0);
|
tex->create_from_image(img, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
t->set_texture(tex);
|
t->set_texture(tex);
|
||||||
properties.write[slot_idx].universal_property = property;
|
properties.write[slot_idx].universal_property = property;
|
||||||
property.connect("changed", self, "on_universal_texture_changed", [slot_idx]);
|
|
||||||
|
Vector<Variant> bindings;
|
||||||
|
bindings.push_back(slot_idx);
|
||||||
|
property->connect("changed", this, "on_universal_texture_changed", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -197,10 +202,12 @@ int MMGraphNode::add_slot_color(const String &getter, const String &setter) {
|
|||||||
|
|
||||||
int MMGraphNode::add_slot_color_universal(const Ref<MMNodeUniversalProperty> &property) {
|
int MMGraphNode::add_slot_color_universal(const Ref<MMNodeUniversalProperty> &property) {
|
||||||
ColorPickerButton *cp = memnew(ColorPickerButton);
|
ColorPickerButton *cp = memnew(ColorPickerButton);
|
||||||
int slot_idx = add_slot(property.input_slot_type, property.output_slot_type, "", "", cp);
|
int slot_idx = add_slot(property->get_input_slot_type(), property->get_output_slot_type(), "", "", cp);
|
||||||
cp->set_color(property->get_default_value());
|
cp->set_pick_color(property->get_default_value_const());
|
||||||
properties.write[slot_idx].universal_property = property;
|
properties.write[slot_idx].universal_property = property;
|
||||||
cp->connect("color_changed", this, "on_universal_color_changed", [slot_idx]);
|
Vector<Variant> bindings;
|
||||||
|
bindings.push_back(slot_idx);
|
||||||
|
cp->connect("color_changed", this, "on_universal_color_changed", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -213,21 +220,23 @@ int MMGraphNode::add_slot_label(const String &getter, const String &setter, cons
|
|||||||
int MMGraphNode::add_slot_line_edit(const String &getter, const String &setter, const String &slot_name, const String &placeholder) {
|
int MMGraphNode::add_slot_line_edit(const String &getter, const String &setter, const String &slot_name, const String &placeholder) {
|
||||||
VBoxContainer *bc = memnew(VBoxContainer);
|
VBoxContainer *bc = memnew(VBoxContainer);
|
||||||
Label *l = memnew(Label);
|
Label *l = memnew(Label);
|
||||||
l.set_text(slot_name);
|
l->set_text(slot_name);
|
||||||
bc.add_child(l);
|
bc->add_child(l);
|
||||||
LineEdit *le = LineEdit.new();
|
LineEdit *le = memnew(LineEdit);
|
||||||
le.set_placeholder_text(placeholder);
|
le->set_placeholder(placeholder);
|
||||||
bc.add_child(le);
|
bc->add_child(le);
|
||||||
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
||||||
le->set_text(_node->call(getter));
|
le->set_text(_node->call(getter));
|
||||||
le->connect("text_entered", this, "on_slot_line_edit_text_entered", [slot_idx]);
|
Vector<Variant> bindings;
|
||||||
|
bindings.push_back(slot_idx);
|
||||||
|
le->connect("text_entered", this, "on_slot_line_edit_text_entered", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
int MMGraphNode::add_slot_enum(const String &getter, const String &setter, const String &slot_name, const Array &values) {
|
int MMGraphNode::add_slot_enum(const String &getter, const String &setter, const String &slot_name, const Array &values) {
|
||||||
VBoxContainer *bc = memnew(VBoxContainer);
|
VBoxContainer *bc = memnew(VBoxContainer);
|
||||||
|
|
||||||
if (slot_name) {
|
if (slot_name != "") {
|
||||||
Label *l = memnew(Label);
|
Label *l = memnew(Label);
|
||||||
l->set_text(slot_name);
|
l->set_text(slot_name);
|
||||||
bc->add_child(l);
|
bc->add_child(l);
|
||||||
@ -242,8 +251,10 @@ int MMGraphNode::add_slot_enum(const String &getter, const String &setter, const
|
|||||||
|
|
||||||
bc->add_child(mb);
|
bc->add_child(mb);
|
||||||
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
||||||
mb->set_selected(_node->call(getter));
|
mb->select(_node->call(getter));
|
||||||
mb->connect("item_selected", this, "on_slot_enum_item_selected", [slot_idx]);
|
Vector<Variant> bindings;
|
||||||
|
bindings.push_back(slot_idx);
|
||||||
|
mb->connect("item_selected", this, "on_slot_enum_item_selected", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -253,13 +264,15 @@ int MMGraphNode::add_slot_int(const String &getter, const String &setter, const
|
|||||||
l->set_text(slot_name);
|
l->set_text(slot_name);
|
||||||
bc->add_child(l);
|
bc->add_child(l);
|
||||||
SpinBox *sb = memnew(SpinBox);
|
SpinBox *sb = memnew(SpinBox);
|
||||||
sb->set_rounded(true);
|
sb->set_use_rounded_values(true);
|
||||||
sb->set_min_value(prange.x);
|
sb->set_min(prange.x);
|
||||||
sb->set_max_value(prange.y);
|
sb->set_max(prange.y);
|
||||||
bc->add_child(sb);
|
bc->add_child(sb);
|
||||||
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
||||||
sb->set_value(_node->call(getter));
|
sb->set_value(_node->call(getter));
|
||||||
sb->connect("value_changed", this, "on_int_spinbox_value_changed", [slot_idx]);
|
Vector<Variant> bindings;
|
||||||
|
bindings.push_back(slot_idx);
|
||||||
|
sb->connect("value_changed", this, "on_int_spinbox_value_changed", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -268,14 +281,14 @@ int MMGraphNode::add_slot_bool(const String &getter, const String &setter, const
|
|||||||
cb->set_text(slot_name);
|
cb->set_text(slot_name);
|
||||||
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, cb);
|
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, cb);
|
||||||
cb->set_pressed(_node->call(getter));
|
cb->set_pressed(_node->call(getter));
|
||||||
cb->connect("toggled", _node, setter);
|
cb->connect("toggled", *_node, setter);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
int MMGraphNode::add_slot_label_universal(const Ref<MMNodeUniversalProperty> &property) {
|
int MMGraphNode::add_slot_label_universal(const Ref<MMNodeUniversalProperty> &property) {
|
||||||
Label *l = memnew(Label);
|
Label *l = memnew(Label);
|
||||||
l->set_text(property.slot_name);
|
l->set_text(property->get_slot_name());
|
||||||
int slot_idx = add_slot(property->input_slot_type, property->output_slot_type, "", "", l);
|
int slot_idx = add_slot(property->get_input_slot_type(), property->get_output_slot_type(), "", "", l);
|
||||||
properties.write[slot_idx].universal_property = property;
|
properties.write[slot_idx].universal_property = property;
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
@ -283,16 +296,18 @@ int MMGraphNode::add_slot_label_universal(const Ref<MMNodeUniversalProperty> &pr
|
|||||||
int MMGraphNode::add_slot_int_universal(const Ref<MMNodeUniversalProperty> &property) {
|
int MMGraphNode::add_slot_int_universal(const Ref<MMNodeUniversalProperty> &property) {
|
||||||
VBoxContainer *bc = memnew(VBoxContainer);
|
VBoxContainer *bc = memnew(VBoxContainer);
|
||||||
Label *l = memnew(Label);
|
Label *l = memnew(Label);
|
||||||
l->set_text(property->slot_name);
|
l->set_text(property->get_slot_name());
|
||||||
bc->add_child(l);
|
bc->add_child(l);
|
||||||
SpinBox *sb = memnew(SpinBox);
|
SpinBox *sb = memnew(SpinBox);
|
||||||
sb->set_rounded(true);
|
sb->set_use_rounded_values(true);
|
||||||
sb->set_min_value(property.value_range.x);
|
sb->set_min(property->get_value_range().x);
|
||||||
sb->set_max_value(property.value_range.y);
|
sb->set_max(property->get_value_range().y);
|
||||||
bc->add_child(sb);
|
bc->add_child(sb);
|
||||||
int slot_idx = add_slot(property->input_slot_type, property->output_slot_type, "", "", bc);
|
int slot_idx = add_slot(property->get_input_slot_type(), property->get_output_slot_type(), "", "", bc);
|
||||||
sb->set_value(property->get_default_value());
|
sb->set_value(property->get_default_value_const());
|
||||||
sb->connect("value_changed", this, "on_int_universal_spinbox_value_changed", [slot_idx]);
|
Vector<Variant> bindings;
|
||||||
|
bindings.push_back(slot_idx);
|
||||||
|
sb->connect("value_changed", this, "on_int_universal_spinbox_value_changed", bindings);
|
||||||
properties.write[slot_idx].universal_property = property;
|
properties.write[slot_idx].universal_property = property;
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
@ -305,30 +320,34 @@ int MMGraphNode::add_slot_float(const String &getter, const String &setter, cons
|
|||||||
SpinBox *sb = memnew(SpinBox);
|
SpinBox *sb = memnew(SpinBox);
|
||||||
bc->add_child(sb);
|
bc->add_child(sb);
|
||||||
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
||||||
sb->set_rounded(false);
|
sb->set_use_rounded_values(false);
|
||||||
sb->set_step(step);
|
sb->set_step(step);
|
||||||
sb->set_min_value(prange.x);
|
sb->set_min(prange.x);
|
||||||
sb->set_max_value(prange.y);
|
sb->set_max(prange.y);
|
||||||
sb->set_value(_node->call(getter));
|
sb->set_value(_node->call(getter));
|
||||||
sb->connect("value_changed", this, "on_float_spinbox_value_changed", [slot_idx]);
|
Vector<Variant> bindings;
|
||||||
|
bindings.push_back(slot_idx);
|
||||||
|
sb->connect("value_changed", this, "on_float_spinbox_value_changed", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
int MMGraphNode::add_slot_float_universal(const Ref<MMNodeUniversalProperty> &property) {
|
int MMGraphNode::add_slot_float_universal(const Ref<MMNodeUniversalProperty> &property) {
|
||||||
VBoxContainer *bc = memnew(VBoxContainer);
|
VBoxContainer *bc = memnew(VBoxContainer);
|
||||||
Label *l = memnew(Label);
|
Label *l = memnew(Label);
|
||||||
l->set_text(property->slot_name);
|
l->set_text(property->get_slot_name());
|
||||||
bc->add_child(l);
|
bc->add_child(l);
|
||||||
SpinBox *sb = memnew(SpinBox);
|
SpinBox *sb = memnew(SpinBox);
|
||||||
bc->add_child(sb);
|
bc->add_child(sb);
|
||||||
int slot_idx = add_slot(property->input_slot_type, property->output_slot_type, "", "", bc);
|
int slot_idx = add_slot(property->get_input_slot_type(), property->get_output_slot_type(), "", "", bc);
|
||||||
sb->set_rounded(false);
|
sb->set_use_rounded_values(false);
|
||||||
sb->set_step(property->value_step);
|
sb->set_step(property->get_value_step());
|
||||||
sb->set_min_value(property->value_range.x);
|
sb->set_min(property->get_value_range().x);
|
||||||
sb->set_max_value(property->value_range.y);
|
sb->set_max(property->get_value_range().y);
|
||||||
sb->set_value(property.get_default_value());
|
sb->set_value(property->get_default_value_const());
|
||||||
properties.write[slot_idx].universal_property = property;
|
properties.write[slot_idx].universal_property = property;
|
||||||
sb->connect("value_changed", this, "on_float_universal_spinbox_value_changed", [slot_idx]);
|
Vector<Variant> bindings;
|
||||||
|
bindings.push_back(slot_idx);
|
||||||
|
sb->connect("value_changed", this, "on_float_universal_spinbox_value_changed", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -342,19 +361,23 @@ int MMGraphNode::add_slot_vector2(const String &getter, const String &setter, co
|
|||||||
SpinBox *sby = memnew(SpinBox);
|
SpinBox *sby = memnew(SpinBox);
|
||||||
bc->add_child(sby);
|
bc->add_child(sby);
|
||||||
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
||||||
sbx->set_rounded(false);
|
sbx->set_use_rounded_values(false);
|
||||||
sby->set_rounded(false);
|
sby->set_use_rounded_values(false);
|
||||||
sbx->set_step(step);
|
sbx->set_step(step);
|
||||||
sby->set_step(step);
|
sby->set_step(step);
|
||||||
sbx->set_min_value(prange.x);
|
sbx->set_min(prange.x);
|
||||||
sbx->set_max_value(prange.y);
|
sbx->set_max(prange.y);
|
||||||
sby->set_min_value(prange.x);
|
sby->set_min(prange.x);
|
||||||
sby->set_max_value(prange.y);
|
sby->set_max(prange.y);
|
||||||
Vector2 val = _node->call(getter);
|
Vector2 val = _node->call(getter);
|
||||||
sbx->set_value(val.x);
|
sbx->set_value(val.x);
|
||||||
sby->set_value(val.y);
|
sby->set_value(val.y);
|
||||||
sbx->connect("value_changed", this, "on_vector2_spinbox_value_changed", [ slot_idx, sbx, sby ]);
|
Vector<Variant> bindings;
|
||||||
sby->connect("value_changed", this, "on_vector2_spinbox_value_changed", [ slot_idx, sbx, sby ]);
|
bindings.push_back(slot_idx);
|
||||||
|
bindings.push_back(sbx);
|
||||||
|
bindings.push_back(sby);
|
||||||
|
sbx->connect("value_changed", this, "on_vector2_spinbox_value_changed", bindings);
|
||||||
|
sby->connect("value_changed", this, "on_vector2_spinbox_value_changed", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -370,52 +393,63 @@ int MMGraphNode::add_slot_vector3(const String &getter, const String &setter, co
|
|||||||
SpinBox *sbz = memnew(SpinBox);
|
SpinBox *sbz = memnew(SpinBox);
|
||||||
bc->add_child(sbz);
|
bc->add_child(sbz);
|
||||||
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
int slot_idx = add_slot(MMNodeUniversalProperty::SLOT_TYPE_NONE, MMNodeUniversalProperty::SLOT_TYPE_NONE, getter, setter, bc);
|
||||||
sbx->set_rounded(false);
|
sbx->set_use_rounded_values(false);
|
||||||
sby->set_rounded(false);
|
sby->set_use_rounded_values(false);
|
||||||
sbz->set_rounded(false);
|
sbz->set_use_rounded_values(false);
|
||||||
sbx->set_step(step);
|
sbx->set_step(step);
|
||||||
sby->set_step(step);
|
sby->set_step(step);
|
||||||
sbz->set_step(step);
|
sbz->set_step(step);
|
||||||
sbx->set_min_value(prange.x);
|
sbx->set_min(prange.x);
|
||||||
sbx->set_max_value(prange.y);
|
sbx->set_max(prange.y);
|
||||||
sby->set_min_value(prange.x);
|
sby->set_min(prange.x);
|
||||||
sby->set_max_value(prange.y);
|
sby->set_max(prange.y);
|
||||||
sbz->set_min_value(prange.x);
|
sbz->set_min(prange.x);
|
||||||
sbz->set_max_value(prange.y);
|
sbz->set_max(prange.y);
|
||||||
Vector3 val = _node->call(getter);
|
Vector3 val = _node->call(getter);
|
||||||
sbx->set_value(val.x);
|
sbx->set_value(val.x);
|
||||||
sby->set_value(val.y);
|
sby->set_value(val.y);
|
||||||
sbz->set_value(val.z);
|
sbz->set_value(val.z);
|
||||||
sbx->connect("value_changed", this, "on_vector3_spinbox_value_changed", [ slot_idx, sbx, sby, sbz ]);
|
|
||||||
sby->connect("value_changed", this, "on_vector3_spinbox_value_changed", [ slot_idx, sbx, sby, sbz ]);
|
Vector<Variant> bindings;
|
||||||
sbz->connect("value_changed", this, "on_vector3_spinbox_value_changed", [ slot_idx, sbx, sby, sbz ]);
|
bindings.push_back(slot_idx);
|
||||||
|
bindings.push_back(sbx);
|
||||||
|
bindings.push_back(sby);
|
||||||
|
bindings.push_back(sbz);
|
||||||
|
sbx->connect("value_changed", this, "on_vector3_spinbox_value_changed", bindings);
|
||||||
|
sby->connect("value_changed", this, "on_vector3_spinbox_value_changed", bindings);
|
||||||
|
sbz->connect("value_changed", this, "on_vector3_spinbox_value_changed", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
int MMGraphNode::add_slot_vector2_universal(const Ref<MMNodeUniversalProperty> &property) {
|
int MMGraphNode::add_slot_vector2_universal(const Ref<MMNodeUniversalProperty> &property) {
|
||||||
VBoxContainer *bc = memnew(VBoxContainer);
|
VBoxContainer *bc = memnew(VBoxContainer);
|
||||||
Label *l = memnew(Label);
|
Label *l = memnew(Label);
|
||||||
l.text = property->slot_name;
|
l->set_text(property->get_slot_name());
|
||||||
bc.add_child(l);
|
bc->add_child(l);
|
||||||
SpinBox *sbx = memnew(SpinBox);
|
SpinBox *sbx = memnew(SpinBox);
|
||||||
bc.add_child(sbx);
|
bc->add_child(sbx);
|
||||||
SpinBox *sby = memnew(SpinBox);
|
SpinBox *sby = memnew(SpinBox);
|
||||||
bc.add_child(sby);
|
bc->add_child(sby);
|
||||||
int slot_idx = add_slot(property.input_slot_type, property.output_slot_type, "", "", bc);
|
int slot_idx = add_slot(property->get_input_slot_type(), property->get_output_slot_type(), "", "", bc);
|
||||||
sbx.set_rounded(false);
|
sbx->set_use_rounded_values(false);
|
||||||
sby.set_rounded(false);
|
sby->set_use_rounded_values(false);
|
||||||
sbx.set_step(property->value_step);
|
sbx->set_step(property->get_value_step());
|
||||||
sby.set_step(property->value_step);
|
sby->set_step(property->get_value_step());
|
||||||
sbx.set_min_value(property->value_range.x);
|
sbx->set_min(property->get_value_range().x);
|
||||||
sbx.set_max_value(property->value_range.y);
|
sbx->set_max(property->get_value_range().y);
|
||||||
sby.set_min_value(property->value_range.x);
|
sby->set_min(property->get_value_range().x);
|
||||||
sby.set_max_value(property->value_range.y);
|
sby->set_max(property->get_value_range().y);
|
||||||
Vector2 val = property->get_default_value();
|
Vector2 val = property->get_default_value_const();
|
||||||
sbx.set_value(val.x);
|
sbx->set_value(val.x);
|
||||||
sby.set_value(val.y);
|
sby->set_value(val.y);
|
||||||
properties.write[slot_idx].universal_property = property;
|
properties.write[slot_idx].universal_property = property;
|
||||||
sbx.connect("value_changed", self, "on_vector2_universal_spinbox_value_changed", [ slot_idx, sbx, sby ]);
|
|
||||||
sby.connect("value_changed", self, "on_vector2_universal_spinbox_value_changed", [ slot_idx, sbx, sby ]);
|
Vector<Variant> bindings;
|
||||||
|
bindings.push_back(slot_idx);
|
||||||
|
bindings.push_back(sbx);
|
||||||
|
bindings.push_back(sby);
|
||||||
|
sbx->connect("value_changed", this, "on_vector2_universal_spinbox_value_changed", bindings);
|
||||||
|
sby->connect("value_changed", this, "on_vector2_universal_spinbox_value_changed", bindings);
|
||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -430,7 +464,7 @@ int MMGraphNode::add_slot(const int input_type, const int output_type, const Str
|
|||||||
e.getter = getter;
|
e.getter = getter;
|
||||||
e.setter = setter;
|
e.setter = setter;
|
||||||
e.control = control;
|
e.control = control;
|
||||||
properties.push_back(arr);
|
properties.push_back(e);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Array arr;
|
Array arr;
|
||||||
@ -459,7 +493,10 @@ int MMGraphNode::add_slot(const int input_type, const int output_type, const Str
|
|||||||
return slot_idx;
|
return slot_idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MMGraphNode::connect_slot(const int slot_idx, const Node *to_node, const int to_slot_idx) {
|
bool MMGraphNode::connect_slot(const int slot_idx, Node *p_to_node, const int to_slot_idx) {
|
||||||
|
MMGraphNode *to_node = Object::cast_to<MMGraphNode>(p_to_node);
|
||||||
|
ERR_FAIL_COND_V(!to_node, false);
|
||||||
|
|
||||||
int from_property_index = -1;
|
int from_property_index = -1;
|
||||||
int to_property_index = -1;
|
int to_property_index = -1;
|
||||||
|
|
||||||
@ -474,8 +511,8 @@ bool MMGraphNode::connect_slot(const int slot_idx, const Node *to_node, const in
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < to_node.properties.size(); ++i) { //i in range(to_node.properties.size())
|
for (int i = 0; i < to_node->properties.size(); ++i) { //i in range(to_node.properties.size())
|
||||||
if (to_node.properties[i].input_type != -1) {
|
if (to_node->properties[i].input_type != -1) {
|
||||||
to_property_index += 1;
|
to_property_index += 1;
|
||||||
|
|
||||||
if (to_property_index == to_slot_idx) {
|
if (to_property_index == to_slot_idx) {
|
||||||
@ -488,13 +525,16 @@ bool MMGraphNode::connect_slot(const int slot_idx, const Node *to_node, const in
|
|||||||
}
|
}
|
||||||
|
|
||||||
_undo_redo->create_action("MMGD: connect_slot");
|
_undo_redo->create_action("MMGD: connect_slot");
|
||||||
_undo_redo->add_do_method(to_node->properties[to_property_index].universal_property, "set_input_property", properties[from_property_index].universal_property);
|
_undo_redo->add_do_method(*(to_node->properties.write[to_property_index].universal_property), "set_input_property", *(properties.write[from_property_index].universal_property));
|
||||||
_undo_redo->add_undo_method(to_node->properties[to_property_index].universal_property, "set_input_property", to_node->properties[to_property_index].universal_property->input_property);
|
_undo_redo->add_undo_method(*(to_node->properties.write[to_property_index].universal_property), "set_input_property", *(to_node->properties.write[to_property_index].universal_property->get_input_property()));
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MMGraphNode::disconnect_slot(const int slot_idx, const Node *to_node, const int to_slot_idx) {
|
bool MMGraphNode::disconnect_slot(const int slot_idx, Node *p_to_node, const int to_slot_idx) {
|
||||||
|
MMGraphNode *to_node = Object::cast_to<MMGraphNode>(p_to_node);
|
||||||
|
ERR_FAIL_COND_V(!to_node, false);
|
||||||
|
|
||||||
int from_property_index = -1;
|
int from_property_index = -1;
|
||||||
int to_property_index = -1;
|
int to_property_index = -1;
|
||||||
|
|
||||||
@ -510,9 +550,9 @@ bool MMGraphNode::disconnect_slot(const int slot_idx, const Node *to_node, const
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < to_node.properties.size(); ++i) { //i in range(to_node.properties.size())
|
for (int i = 0; i < to_node->properties.size(); ++i) { //i in range(to_node.properties.size())
|
||||||
|
|
||||||
if (to_node.properties[i].input_type != -1) {
|
if (to_node->properties[i].input_type != -1) {
|
||||||
to_property_index += 1;
|
to_property_index += 1;
|
||||||
|
|
||||||
if (to_property_index == to_slot_idx) {
|
if (to_property_index == to_slot_idx) {
|
||||||
@ -525,8 +565,8 @@ bool MMGraphNode::disconnect_slot(const int slot_idx, const Node *to_node, const
|
|||||||
}
|
}
|
||||||
|
|
||||||
_undo_redo->create_action("MMGD: disconnect_slot");
|
_undo_redo->create_action("MMGD: disconnect_slot");
|
||||||
_undo_redo->add_do_method(to_node->properties[to_property_index].universal_property, "unset_input_property");
|
_undo_redo->add_do_method(*(to_node->properties.write[to_property_index].universal_property), "unset_input_property");
|
||||||
_undo_redo->add_undo_method(to_node->properties[to_property_index].universal_property, "set_input_property", to_node->properties[to_property_index].universal_property->input_property);
|
_undo_redo->add_undo_method(*(to_node->properties.write[to_property_index].universal_property), "set_input_property", *(to_node->properties.write[to_property_index].universal_property->get_input_property()));
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -565,7 +605,7 @@ int MMGraphNode::get_output_property_graph_node_slot_index(const Variant &proper
|
|||||||
return property_index;
|
return property_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
Node MMGraphNode::get_property_control(const int slot_idx) {
|
Control *MMGraphNode::get_property_control(const int slot_idx) {
|
||||||
return properties[slot_idx].control;
|
return properties[slot_idx].control;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -573,18 +613,19 @@ void MMGraphNode::set_node(const Ref<MMMaterial> &material, const Ref<MMNode> &n
|
|||||||
_node = node;
|
_node = node;
|
||||||
_material = material;
|
_material = material;
|
||||||
|
|
||||||
if (!_node) {
|
if (!_node.is_valid()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
title = _node.get_class();
|
set_title(_node->get_class());
|
||||||
|
|
||||||
if (_node.get_script()) {
|
Ref<Script> script = _node->get_script();
|
||||||
title = _node.get_script().resource_path.get_file().get_basename();
|
if (script.is_valid()) {
|
||||||
|
set_title(script->get_path().get_file().get_basename());
|
||||||
}
|
}
|
||||||
|
|
||||||
_node.register_methods(self);
|
_node->register_methods(this);
|
||||||
offset = _node.get_graph_position();
|
set_offset(_node->get_graph_position());
|
||||||
|
|
||||||
//_node.connect("changed", self, "on_node_changed");
|
//_node.connect("changed", self, "on_node_changed");
|
||||||
}
|
}
|
||||||
@ -593,12 +634,12 @@ void MMGraphNode::propagate_node_change() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_dragged(const Vector2 &from, const Vector2 &to) {
|
void MMGraphNode::on_dragged(const Vector2 &from, const Vector2 &to) {
|
||||||
if (_node) {
|
if (_node.is_valid()) {
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
//_node.set_graph_position(offset);
|
//_node.set_graph_position(offset);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(_node, "set_graph_position", to);
|
_undo_redo->add_do_method(*_node, "set_graph_position", to);
|
||||||
_undo_redo->add_undo_method(_node, "set_graph_position", from);
|
_undo_redo->add_undo_method(*_node, "set_graph_position", from);
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
@ -612,75 +653,85 @@ void MMGraphNode::on_dragged(const Vector2 &from, const Vector2 &to) {
|
|||||||
// propagate_node_change();
|
// propagate_node_change();
|
||||||
// _ignore_change_event = false;
|
// _ignore_change_event = false;
|
||||||
|
|
||||||
void MMGraphNode::on_int_spinbox_value_changed(const float val, const Variant &slot_idx) {
|
void MMGraphNode::on_int_spinbox_value_changed(const float val, const int slot_idx) {
|
||||||
//_node.call(properties[slot_idx][4], int(val));
|
//_node.call(properties[slot_idx][4], int(val));
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(_node, properties[slot_idx].setter, int(val));
|
_undo_redo->add_do_method(*_node, properties[slot_idx].setter, int(val));
|
||||||
_undo_redo->add_undo_method(_node, properties[slot_idx].setter, _node.call(properties[slot_idx].getter));
|
_undo_redo->add_undo_method(*_node, properties[slot_idx].setter, _node->call(properties[slot_idx].getter));
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_float_spinbox_value_changed(const float val, const Variant &slot_idx) {
|
void MMGraphNode::on_float_spinbox_value_changed(const float val, const int slot_idx) {
|
||||||
//_node.call(properties[slot_idx][4], val);
|
//_node.call(properties[slot_idx][4], val);
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(_node, properties[slot_idx].setter, val);
|
_undo_redo->add_do_method(*_node, properties[slot_idx].setter, val);
|
||||||
_undo_redo->add_undo_method(_node, properties[slot_idx].setter, _node.call(properties[slot_idx].getter));
|
_undo_redo->add_undo_method(*_node, properties[slot_idx].setter, _node->call(properties[slot_idx].getter));
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_vector2_spinbox_value_changed(const float val, const Variant &slot_idx, const Variant &spinbox_x, const Variant &spinbox_y) {
|
void MMGraphNode::on_vector2_spinbox_value_changed(const float val, const int slot_idx, Node *p_spinbox_x, Node *p_spinbox_y) {
|
||||||
Vector2 vv = Vector2(spinbox_x.value, spinbox_y.value);
|
SpinBox *spinbox_x = Object::cast_to<SpinBox>(p_spinbox_x);
|
||||||
|
SpinBox *spinbox_y = Object::cast_to<SpinBox>(p_spinbox_y);
|
||||||
|
|
||||||
|
Vector2 vv = Vector2(spinbox_x->get_value(), spinbox_y->get_value());
|
||||||
//_node.call(properties[slot_idx][4], vv);
|
//_node.call(properties[slot_idx][4], vv);
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(_node, properties[slot_idx].setter, vv);
|
_undo_redo->add_do_method(*_node, properties[slot_idx].setter, vv);
|
||||||
_undo_redo->add_undo_method(_node, properties[slot_idx].setter, _node.call(properties[slot_idx].getter));
|
_undo_redo->add_undo_method(*_node, properties[slot_idx].setter, _node->call(properties[slot_idx].getter));
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_vector3_spinbox_value_changed(const float val, const Variant &slot_idx, const Variant &spinbox_x, const Variant &spinbox_y, const Variant &spinbox_z) {
|
void MMGraphNode::on_vector3_spinbox_value_changed(const float val, const int slot_idx, Node *p_spinbox_x, Node *p_spinbox_y, Node *p_spinbox_z) {
|
||||||
Vector3 vv = Vector3(spinbox_x.value, spinbox_y.value, spinbox_z.value);
|
SpinBox *spinbox_x = Object::cast_to<SpinBox>(p_spinbox_x);
|
||||||
|
SpinBox *spinbox_y = Object::cast_to<SpinBox>(p_spinbox_y);
|
||||||
|
SpinBox *spinbox_z = Object::cast_to<SpinBox>(p_spinbox_z);
|
||||||
|
|
||||||
|
Vector3 vv = Vector3(spinbox_x->get_value(), spinbox_y->get_value(), spinbox_z->get_value());
|
||||||
//_node.call(properties[slot_idx][4], vv);
|
//_node.call(properties[slot_idx][4], vv);
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(_node, properties[slot_idx].setter, vv);
|
_undo_redo->add_do_method(*_node, properties[slot_idx].setter, vv);
|
||||||
_undo_redo->add_undo_method(_node, properties[slot_idx].setter, _node.call(properties[slot_idx][3]));
|
_undo_redo->add_undo_method(*_node, properties[slot_idx].setter, _node->call(properties[slot_idx].getter));
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_int_universal_spinbox_value_changed(const float val, const Variant &slot_idx) {
|
void MMGraphNode::on_int_universal_spinbox_value_changed(const float val, const int slot_idx) {
|
||||||
//properties[slot_idx][6].set_default_value(int(val));
|
//properties[slot_idx][6].set_default_value(int(val));
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(properties[slot_idx].universal_property, "set_default_value", int(val));
|
_undo_redo->add_do_method(*(properties.write[slot_idx].universal_property), "set_default_value", int(val));
|
||||||
_undo_redo->add_undo_method(properties[slot_idx].universal_property, "set_default_value", properties[slot_idx].universal_property->get_default_value());
|
_undo_redo->add_undo_method(*(properties.write[slot_idx].universal_property), "set_default_value", properties.write[slot_idx].universal_property->get_default_value());
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_float_universal_spinbox_value_changed(const float val, const Variant &slot_idx) {
|
void MMGraphNode::on_float_universal_spinbox_value_changed(const float val, const int slot_idx) {
|
||||||
//properties[slot_idx][6].set_default_value(val);
|
//properties[slot_idx][6].set_default_value(val);
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(properties[slot_idx].universal_property, "set_default_value", val);
|
_undo_redo->add_do_method(*(properties.write[slot_idx].universal_property), "set_default_value", val);
|
||||||
_undo_redo->add_undo_method(properties[slot_idx].universal_property, "set_default_value", properties[slot_idx].universal_property->get_default_value());
|
_undo_redo->add_undo_method(*(properties.write[slot_idx].universal_property), "set_default_value", properties.write[slot_idx].universal_property->get_default_value());
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_vector2_universal_spinbox_value_changed(const float val, const Variant &slot_idx, const Variant &spinbox_x, const Variant &spinbox_y) {
|
void MMGraphNode::on_vector2_universal_spinbox_value_changed(const float val, const int slot_idx, Node *p_spinbox_x, Node *p_spinbox_y) {
|
||||||
Vector2 vv = Vector2(spinbox_x.value, spinbox_y.value);
|
SpinBox *spinbox_x = Object::cast_to<SpinBox>(p_spinbox_x);
|
||||||
|
SpinBox *spinbox_y = Object::cast_to<SpinBox>(p_spinbox_y);
|
||||||
|
|
||||||
|
Vector2 vv = Vector2(spinbox_x->get_value(), spinbox_y->get_value());
|
||||||
//properties[slot_idx][6].set_default_value(vv);
|
//properties[slot_idx][6].set_default_value(vv);
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(properties[slot_idx].universal_property, "set_default_value", vv);
|
_undo_redo->add_do_method(*(properties.write[slot_idx].universal_property), "set_default_value", vv);
|
||||||
_undo_redo->add_undo_method(properties[slot_idx].universal_property, "set_default_value", properties[slot_idx].universal_property->get_default_value());
|
_undo_redo->add_undo_method(*(properties.write[slot_idx].universal_property), "set_default_value", properties.write[slot_idx].universal_property->get_default_value());
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
@ -689,34 +740,40 @@ void MMGraphNode::on_slot_enum_item_selected(const int val, const int slot_idx)
|
|||||||
//_node.call(properties[slot_idx][4], val);
|
//_node.call(properties[slot_idx][4], val);
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(_node, properties[slot_idx].setter, val);
|
_undo_redo->add_do_method(*_node, properties[slot_idx].setter, val);
|
||||||
_undo_redo->add_undo_method(_node, properties[slot_idx].setter, _node.call(properties[slot_idx].getter));
|
_undo_redo->add_undo_method(*_node, properties[slot_idx].setter, _node->call(properties[slot_idx].getter));
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_universal_texture_changed(const int slot_idx) {
|
void MMGraphNode::on_universal_texture_changed(const int slot_idx) {
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
Ref<Image> img = properties[slot_idx].universal_property.get_active_image();
|
Ref<Image> img = properties.write[slot_idx].universal_property->get_active_image();
|
||||||
Ref<ImageTexture> tex = properties[slot_idx].control->get_texture();
|
|
||||||
|
|
||||||
if (img) {
|
if (img.is_valid()) {
|
||||||
properties[slot_idx].control->get_texture()->create_from_image(img, 0);
|
Ref<ImageTexture> tex = properties.write[slot_idx].control->call("get_texture");
|
||||||
|
tex->create_from_image(img, 0);
|
||||||
|
} else {
|
||||||
|
Ref<ImageTexture> it;
|
||||||
|
it.instance();
|
||||||
|
|
||||||
|
properties.write[slot_idx].control->call("set_texture", it);
|
||||||
}
|
}
|
||||||
properties[slot_idx].control->set_texture(ImageTexture.new());
|
|
||||||
}
|
|
||||||
|
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_universal_texture_changed_image_picker(const int slot_idx) {
|
void MMGraphNode::on_universal_texture_changed_image_picker(const int slot_idx) {
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
Ref<Image> img = properties[slot_idx].universal_property->get_active_image();
|
Ref<Image> img = properties.write[slot_idx].universal_property->get_active_image();
|
||||||
Ref<ImageTexture> tex = properties[slot_idx].control->get_texture_normal();
|
|
||||||
|
|
||||||
if (img.is_valid()) {
|
if (img.is_valid()) {
|
||||||
properties[slot_idx].control->get_texture_normal().create_from_image(img, 0);
|
Ref<ImageTexture> tex = properties.write[slot_idx].control->call("get_texture_normal");
|
||||||
|
tex->create_from_image(img, 0);
|
||||||
} else {
|
} else {
|
||||||
|
Ref<ImageTexture> it;
|
||||||
|
it.instance();
|
||||||
|
properties.write[slot_idx].control->call("set_texture", it);
|
||||||
}
|
}
|
||||||
|
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
@ -726,8 +783,8 @@ void MMGraphNode::on_slot_line_edit_text_entered(const String &text, const int s
|
|||||||
//_node.call(properties[slot_idx][4], text);
|
//_node.call(properties[slot_idx][4], text);
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(_node, properties[slot_idx].setter, text);
|
_undo_redo->add_do_method(*_node, properties[slot_idx].setter, text);
|
||||||
_undo_redo->add_undo_method(_node, properties[slot_idx].setter, _node.call(properties[slot_idx].getter));
|
_undo_redo->add_undo_method(*_node, properties[slot_idx].setter, _node->call(properties[slot_idx].getter));
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
@ -736,18 +793,18 @@ void MMGraphNode::on_universal_color_changed(const Color &c, const int slot_idx)
|
|||||||
//properties[slot_idx][6].set_default_value(c);
|
//properties[slot_idx][6].set_default_value(c);
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(properties[slot_idx].universal_property, "set_default_value", c);
|
_undo_redo->add_do_method(*(properties.write[slot_idx].universal_property), "set_default_value", c);
|
||||||
_undo_redo->add_undo_method(properties[slot_idx].universal_property, "set_default_value", properties[slot_idx].universal_property->get_default_value());
|
_undo_redo->add_undo_method(*(properties.write[slot_idx].universal_property), "set_default_value", properties.write[slot_idx].universal_property->get_default_value());
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MMGraphNode::on_universal_image_path_changed(const String &f, const int slot_idx) {
|
void MMGraphNode::on_universal_image_path_changed(const String &f, const int slot_idx) {
|
||||||
_node.call(properties[slot_idx][8], f);
|
_node->call(properties[slot_idx].alt_setter, f);
|
||||||
ignore_changes(true);
|
ignore_changes(true);
|
||||||
_undo_redo->create_action("MMGD: value changed");
|
_undo_redo->create_action("MMGD: value changed");
|
||||||
_undo_redo->add_do_method(properties[slot_idx].universal_property, "set_default_value", f);
|
_undo_redo->add_do_method(*(properties.write[slot_idx].universal_property), "set_default_value", f);
|
||||||
_undo_redo->add_undo_method(properties[slot_idx].universal_property, "set_default_value", properties[slot_idx].universal_property->get_default_value());
|
_undo_redo->add_undo_method(*(properties.write[slot_idx].universal_property), "set_default_value", properties.write[slot_idx].universal_property->get_default_value());
|
||||||
_undo_redo->commit_action();
|
_undo_redo->commit_action();
|
||||||
ignore_changes(false);
|
ignore_changes(false);
|
||||||
}
|
}
|
||||||
@ -756,12 +813,12 @@ void MMGraphNode::on_close_request() {
|
|||||||
Node *n = get_parent();
|
Node *n = get_parent();
|
||||||
|
|
||||||
while (n) {
|
while (n) {
|
||||||
if (n.has_method("on_graph_node_close_request")) {
|
if (n->has_method("on_graph_node_close_request")) {
|
||||||
n.call_deferred("on_graph_node_close_request", self);
|
n->call_deferred("on_graph_node_close_request", this);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
n = n.get_parent();
|
n = n->get_parent();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -815,23 +872,15 @@ void MMGraphNode::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("set_curve_edit_scene", "value"), &MMGraphNode::set_curve_edit_scene);
|
ClassDB::bind_method(D_METHOD("set_curve_edit_scene", "value"), &MMGraphNode::set_curve_edit_scene);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "curve_edit_scene", PROPERTY_HINT_RESOURCE_TYPE, "PackedScene"), "set_curve_edit_scene", "get_curve_edit_scene");
|
ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "curve_edit_scene", PROPERTY_HINT_RESOURCE_TYPE, "PackedScene"), "set_curve_edit_scene", "get_curve_edit_scene");
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("get_material"), &MMGraphNode::get_material);
|
ClassDB::bind_method(D_METHOD("get_mm_material"), &MMGraphNode::get_mm_material);
|
||||||
ClassDB::bind_method(D_METHOD("set_material", "value"), &MMGraphNode::set_material);
|
ClassDB::bind_method(D_METHOD("set_mm_material", "value"), &MMGraphNode::set_mm_material);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "material", PROPERTY_HINT_RESOURCE_TYPE, "MMMaterial"), "set_material", "get_material");
|
ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "mm_material", PROPERTY_HINT_RESOURCE_TYPE, "MMMaterial"), "set_mm_material", "get_mm_material");
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("get_material_node"), &MMGraphNode::get_material_node);
|
ClassDB::bind_method(D_METHOD("get_material_node"), &MMGraphNode::get_material_node);
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("get_node"), &MMGraphNode::get_node);
|
ClassDB::bind_method(D_METHOD("get_mm_node"), &MMGraphNode::get_mm_node);
|
||||||
ClassDB::bind_method(D_METHOD("set_node", "value"), &MMGraphNode::set_node);
|
ClassDB::bind_method(D_METHOD("set_mm_node", "value"), &MMGraphNode::set_mm_node);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "*_node", PROPERTY_HINT_RESOURCE_TYPE, "MMNode"), "set_node", "get_node");
|
ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "mm_node", PROPERTY_HINT_RESOURCE_TYPE, "MMNode"), "set_mm_node", "get_mm_node");
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("get_properties"), &MMGraphNode::get_properties);
|
|
||||||
ClassDB::bind_method(D_METHOD("set_properties", "value"), &MMGraphNode::set_properties);
|
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "properties"), "set_properties", "get_properties");
|
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("get_Variant"), &MMGraphNode::get_Variant);
|
|
||||||
ClassDB::bind_method(D_METHOD("set_Variant", "value"), &MMGraphNode::set_Variant);
|
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "Variant", PROPERTY_HINT_RESOURCE_TYPE, "Variant"), "set_Variant", "get_Variant");
|
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("get_ignore_change_event"), &MMGraphNode::get_ignore_change_event);
|
ClassDB::bind_method(D_METHOD("get_ignore_change_event"), &MMGraphNode::get_ignore_change_event);
|
||||||
ClassDB::bind_method(D_METHOD("set_ignore_change_event", "value"), &MMGraphNode::set_ignore_change_event);
|
ClassDB::bind_method(D_METHOD("set_ignore_change_event", "value"), &MMGraphNode::set_ignore_change_event);
|
||||||
@ -839,7 +888,6 @@ void MMGraphNode::_bind_methods() {
|
|||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("_init"), &MMGraphNode::_init);
|
ClassDB::bind_method(D_METHOD("_init"), &MMGraphNode::_init);
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("set_editor", "editor_node"), &MMGraphNode::set_editor);
|
|
||||||
ClassDB::bind_method(D_METHOD("ignore_changes", "val"), &MMGraphNode::ignore_changes);
|
ClassDB::bind_method(D_METHOD("ignore_changes", "val"), &MMGraphNode::ignore_changes);
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("add_slot_texture", "getter", "setter"), &MMGraphNode::add_slot_texture);
|
ClassDB::bind_method(D_METHOD("add_slot_texture", "getter", "setter"), &MMGraphNode::add_slot_texture);
|
||||||
@ -857,7 +905,7 @@ void MMGraphNode::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("add_slot_bool", "getter", "setter", "slot_name"), &MMGraphNode::add_slot_bool);
|
ClassDB::bind_method(D_METHOD("add_slot_bool", "getter", "setter", "slot_name"), &MMGraphNode::add_slot_bool);
|
||||||
ClassDB::bind_method(D_METHOD("add_slot_label_universal", "property"), &MMGraphNode::add_slot_label_universal);
|
ClassDB::bind_method(D_METHOD("add_slot_label_universal", "property"), &MMGraphNode::add_slot_label_universal);
|
||||||
ClassDB::bind_method(D_METHOD("add_slot_int_universal", "property"), &MMGraphNode::add_slot_int_universal);
|
ClassDB::bind_method(D_METHOD("add_slot_int_universal", "property"), &MMGraphNode::add_slot_int_universal);
|
||||||
ClassDB::bind_method(D_METHOD("add_slot_float", "getter", "setter", "slot_name", "step", "prange", " 1000)"), &MMGraphNode::add_slot_float, 0.1, Vector2(-1000));
|
ClassDB::bind_method(D_METHOD("add_slot_float", "getter", "setter", "slot_name", "step", "prange", " 1000)"), &MMGraphNode::add_slot_float, 0.1, Vector2(-1000, -1000));
|
||||||
ClassDB::bind_method(D_METHOD("add_slot_float_universal", "property"), &MMGraphNode::add_slot_float_universal);
|
ClassDB::bind_method(D_METHOD("add_slot_float_universal", "property"), &MMGraphNode::add_slot_float_universal);
|
||||||
ClassDB::bind_method(D_METHOD("add_slot_vector2", "getter", "setter", "slot_name", "step", "prange", " 1000)"), &MMGraphNode::add_slot_vector2, 0.1, Vector2(-1000, -1000));
|
ClassDB::bind_method(D_METHOD("add_slot_vector2", "getter", "setter", "slot_name", "step", "prange", " 1000)"), &MMGraphNode::add_slot_vector2, 0.1, Vector2(-1000, -1000));
|
||||||
ClassDB::bind_method(D_METHOD("add_slot_vector3", "getter", "setter", "slot_name", "step", "prange", " 1000)"), &MMGraphNode::add_slot_vector3, 0.1, Vector2(-1000, -1000));
|
ClassDB::bind_method(D_METHOD("add_slot_vector3", "getter", "setter", "slot_name", "step", "prange", " 1000)"), &MMGraphNode::add_slot_vector3, 0.1, Vector2(-1000, -1000));
|
||||||
|
@ -33,11 +33,8 @@ public:
|
|||||||
|
|
||||||
Ref<MMNode> get_material_node();
|
Ref<MMNode> get_material_node();
|
||||||
|
|
||||||
Ref<MMNode> get_node();
|
Ref<MMNode> get_mm_node();
|
||||||
void set_node(const Ref<MMNode> &val);
|
void set_mm_node(const Ref<MMNode> &val);
|
||||||
|
|
||||||
Array get_properties();
|
|
||||||
void set_properties(const Array &val);
|
|
||||||
|
|
||||||
MatMakerGDEditor *get_editor_node();
|
MatMakerGDEditor *get_editor_node();
|
||||||
void set_editor_node(MatMakerGDEditor *val);
|
void set_editor_node(MatMakerGDEditor *val);
|
||||||
@ -73,25 +70,25 @@ public:
|
|||||||
int add_slot_vector2_universal(const Ref<MMNodeUniversalProperty> &property);
|
int add_slot_vector2_universal(const Ref<MMNodeUniversalProperty> &property);
|
||||||
int add_slot(const int input_type, const int output_type, const String &getter, const String &setter, Control *control);
|
int add_slot(const int input_type, const int output_type, const String &getter, const String &setter, Control *control);
|
||||||
|
|
||||||
bool connect_slot(const int slot_idx, const Node *to_node, const int to_slot_idx);
|
bool connect_slot(const int slot_idx, Node *to_node, const int to_slot_idx);
|
||||||
bool disconnect_slot(const int slot_idx, const Node *to_node, const int to_slot_idx);
|
bool disconnect_slot(const int slot_idx, Node *to_node, const int to_slot_idx);
|
||||||
|
|
||||||
int get_input_property_graph_node_slot_index(const Variant &property);
|
int get_input_property_graph_node_slot_index(const Variant &property);
|
||||||
int get_output_property_graph_node_slot_index(const Variant &property);
|
int get_output_property_graph_node_slot_index(const Variant &property);
|
||||||
|
|
||||||
Node get_property_control(const int slot_idx);
|
Control *get_property_control(const int slot_idx);
|
||||||
void set_node(const Ref<MMMaterial> &material, const Ref<MMNode> &node);
|
void set_node(const Ref<MMMaterial> &material, const Ref<MMNode> &node);
|
||||||
|
|
||||||
void propagate_node_change();
|
void propagate_node_change();
|
||||||
|
|
||||||
void on_dragged(const Vector2 &from, const Vector2 &to);
|
void on_dragged(const Vector2 &from, const Vector2 &to);
|
||||||
void on_int_spinbox_value_changed(const float val, const Variant &slot_idx);
|
void on_int_spinbox_value_changed(const float val, const int slot_idx);
|
||||||
void on_float_spinbox_value_changed(const float val, const Variant &slot_idx);
|
void on_float_spinbox_value_changed(const float val, const int slot_idx);
|
||||||
void on_vector2_spinbox_value_changed(const float val, const Variant &slot_idx, const Variant &spinbox_x, const Variant &spinbox_y);
|
void on_vector2_spinbox_value_changed(const float val, const int slot_idx, Node *spinbox_x, Node *spinbox_y);
|
||||||
void on_vector3_spinbox_value_changed(const float val, const Variant &slot_idx, const Variant &spinbox_x, const Variant &spinbox_y, const Variant &spinbox_z);
|
void on_vector3_spinbox_value_changed(const float val, const int slot_idx, Node *spinbox_x, Node *spinbox_y, Node *spinbox_z);
|
||||||
void on_int_universal_spinbox_value_changed(const float val, const Variant &slot_idx);
|
void on_int_universal_spinbox_value_changed(const float val, const int slot_idx);
|
||||||
void on_float_universal_spinbox_value_changed(const float val, const Variant &slot_idx);
|
void on_float_universal_spinbox_value_changed(const float val, const int slot_idx);
|
||||||
void on_vector2_universal_spinbox_value_changed(const float val, const Variant &slot_idx, const Variant &spinbox_x, const Variant &spinbox_y);
|
void on_vector2_universal_spinbox_value_changed(const float val, const int slot_idx, Node *spinbox_x, Node *spinbox_y);
|
||||||
void on_slot_enum_item_selected(const int val, const int slot_idx);
|
void on_slot_enum_item_selected(const int val, const int slot_idx);
|
||||||
void on_universal_texture_changed(const int slot_idx);
|
void on_universal_texture_changed(const int slot_idx);
|
||||||
void on_universal_texture_changed_image_picker(const int slot_idx);
|
void on_universal_texture_changed_image_picker(const int slot_idx);
|
||||||
@ -117,8 +114,10 @@ protected:
|
|||||||
String getter;
|
String getter;
|
||||||
String setter;
|
String setter;
|
||||||
Control *control;
|
Control *control;
|
||||||
Ref<MMGraphNodeEntry> universal_property;
|
Ref<MMNodeUniversalProperty> universal_property;
|
||||||
Ref<Texture> texture;
|
Ref<Texture> texture;
|
||||||
|
String alt_getter;
|
||||||
|
String alt_setter;
|
||||||
|
|
||||||
MMGraphNodeEntry() {
|
MMGraphNodeEntry() {
|
||||||
slot_idx = 0;
|
slot_idx = 0;
|
||||||
|
@ -27,7 +27,7 @@ void MMNodeUniversalProperty::set_default_float(const float val) {
|
|||||||
default_float = val;
|
default_float = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector2 MMNodeUniversalProperty::get_default_vector2() {
|
Vector2 MMNodeUniversalProperty::get_default_vector2() const {
|
||||||
return default_vector2;
|
return default_vector2;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -35,7 +35,7 @@ void MMNodeUniversalProperty::set_default_vector2(const Vector2 &val) {
|
|||||||
default_vector2 = val;
|
default_vector2 = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector3 MMNodeUniversalProperty::get_default_vector3() {
|
Vector3 MMNodeUniversalProperty::get_default_vector3() const {
|
||||||
return default_vector3;
|
return default_vector3;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -43,7 +43,7 @@ void MMNodeUniversalProperty::set_default_vector3(const Vector3 &val) {
|
|||||||
default_vector3 = val;
|
default_vector3 = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
Color MMNodeUniversalProperty::get_default_color() {
|
Color MMNodeUniversalProperty::get_default_color() const {
|
||||||
return default_color;
|
return default_color;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,7 +99,7 @@ void MMNodeUniversalProperty::set_output_slot_type(const int val) {
|
|||||||
output_slot_type = val;
|
output_slot_type = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
String MMNodeUniversalProperty::get_slot_name() {
|
String MMNodeUniversalProperty::get_slot_name() const {
|
||||||
return slot_name;
|
return slot_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -115,7 +115,7 @@ void MMNodeUniversalProperty::set_value_step(const float val) {
|
|||||||
value_step = val;
|
value_step = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector2 MMNodeUniversalProperty::get_value_range() {
|
Vector2 MMNodeUniversalProperty::get_value_range() const {
|
||||||
return value_range;
|
return value_range;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -449,6 +449,41 @@ Variant MMNodeUniversalProperty::get_default_value(const Vector2 &uv) {
|
|||||||
return Variant();
|
return Variant();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Variant MMNodeUniversalProperty::get_default_value_const(const Vector2 &uv) const {
|
||||||
|
if (default_type == DEFAULT_TYPE_INT) {
|
||||||
|
return default_int;
|
||||||
|
} else if (default_type == DEFAULT_TYPE_FLOAT) {
|
||||||
|
return default_float;
|
||||||
|
} else if (default_type == DEFAULT_TYPE_VECTOR2) {
|
||||||
|
return default_vector2;
|
||||||
|
} else if (default_type == DEFAULT_TYPE_VECTOR3) {
|
||||||
|
return default_vector3;
|
||||||
|
} else if (default_type == DEFAULT_TYPE_COLOR) {
|
||||||
|
return default_color;
|
||||||
|
} else if (default_type == DEFAULT_TYPE_IMAGE) {
|
||||||
|
Ref<Image> image = default_image;
|
||||||
|
|
||||||
|
if (override_image.is_valid()) {
|
||||||
|
image = override_image;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!image.is_valid()) {
|
||||||
|
return default_color;
|
||||||
|
}
|
||||||
|
|
||||||
|
image->lock();
|
||||||
|
int x = uv.x * image->get_width();
|
||||||
|
int y = uv.y * image->get_height();
|
||||||
|
x = CLAMP(x, 0, image->get_width() - 1);
|
||||||
|
y = CLAMP(y, 0, image->get_width() - 1);
|
||||||
|
Color c = image->get_pixel(x, y);
|
||||||
|
image->unlock();
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
return Variant();
|
||||||
|
}
|
||||||
|
|
||||||
void MMNodeUniversalProperty::set_default_value(const Variant &val) {
|
void MMNodeUniversalProperty::set_default_value(const Variant &val) {
|
||||||
if (default_type == DEFAULT_TYPE_INT) {
|
if (default_type == DEFAULT_TYPE_INT) {
|
||||||
default_int = val;
|
default_int = val;
|
||||||
|
@ -44,13 +44,13 @@ public:
|
|||||||
float get_default_float() const;
|
float get_default_float() const;
|
||||||
void set_default_float(const float val);
|
void set_default_float(const float val);
|
||||||
|
|
||||||
Vector2 get_default_vector2();
|
Vector2 get_default_vector2() const;
|
||||||
void set_default_vector2(const Vector2 &val);
|
void set_default_vector2(const Vector2 &val);
|
||||||
|
|
||||||
Vector3 get_default_vector3();
|
Vector3 get_default_vector3() const;
|
||||||
void set_default_vector3(const Vector3 &val);
|
void set_default_vector3(const Vector3 &val);
|
||||||
|
|
||||||
Color get_default_color();
|
Color get_default_color() const;
|
||||||
void set_default_color(const Color &val);
|
void set_default_color(const Color &val);
|
||||||
|
|
||||||
Ref<Image> get_default_image();
|
Ref<Image> get_default_image();
|
||||||
@ -71,13 +71,13 @@ public:
|
|||||||
int get_output_slot_type() const;
|
int get_output_slot_type() const;
|
||||||
void set_output_slot_type(const int val);
|
void set_output_slot_type(const int val);
|
||||||
|
|
||||||
String get_slot_name();
|
String get_slot_name() const;
|
||||||
void set_slot_name(const String &val);
|
void set_slot_name(const String &val);
|
||||||
|
|
||||||
float get_value_step() const;
|
float get_value_step() const;
|
||||||
void set_value_step(const float val);
|
void set_value_step(const float val);
|
||||||
|
|
||||||
Vector2 get_value_range();
|
Vector2 get_value_range() const;
|
||||||
void set_value_range(const Vector2 &val);
|
void set_value_range(const Vector2 &val);
|
||||||
|
|
||||||
Ref<MMNodeUniversalProperty> get_input_property();
|
Ref<MMNodeUniversalProperty> get_input_property();
|
||||||
@ -101,6 +101,7 @@ public:
|
|||||||
void set_value(const Variant &val);
|
void set_value(const Variant &val);
|
||||||
Variant get_zero_value();
|
Variant get_zero_value();
|
||||||
Variant get_default_value(const Vector2 &uv = Vector2());
|
Variant get_default_value(const Vector2 &uv = Vector2());
|
||||||
|
Variant get_default_value_const(const Vector2 &uv = Vector2()) const;
|
||||||
void set_default_value(const Variant &val);
|
void set_default_value(const Variant &val);
|
||||||
Ref<Image> get_active_image();
|
Ref<Image> get_active_image();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user