Merge pull request #61342 from reduz/reorganize-region-rect-editor
Reorganize Region Rect Editor
This commit is contained in:
commit
4dd6f56c82
5 changed files with 145 additions and 173 deletions
|
@ -77,6 +77,7 @@
|
||||||
<return type="void" />
|
<return type="void" />
|
||||||
<argument index="0" name="property" type="String" />
|
<argument index="0" name="property" type="String" />
|
||||||
<argument index="1" name="editor" type="Control" />
|
<argument index="1" name="editor" type="Control" />
|
||||||
|
<argument index="2" name="add_to_end" type="bool" default="false" />
|
||||||
<description>
|
<description>
|
||||||
Adds a property editor for an individual property. The [code]editor[/code] control must extend [EditorProperty].
|
Adds a property editor for an individual property. The [code]editor[/code] control must extend [EditorProperty].
|
||||||
</description>
|
</description>
|
||||||
|
|
|
@ -1008,12 +1008,11 @@ void EditorInspectorPlugin::add_custom_control(Control *control) {
|
||||||
added_editors.push_back(ae);
|
added_editors.push_back(ae);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditorInspectorPlugin::add_property_editor(const String &p_for_property, Control *p_prop) {
|
void EditorInspectorPlugin::add_property_editor(const String &p_for_property, Control *p_prop, bool p_add_to_end) {
|
||||||
ERR_FAIL_COND(Object::cast_to<EditorProperty>(p_prop) == nullptr);
|
|
||||||
|
|
||||||
AddedEditor ae;
|
AddedEditor ae;
|
||||||
ae.properties.push_back(p_for_property);
|
ae.properties.push_back(p_for_property);
|
||||||
ae.property_editor = p_prop;
|
ae.property_editor = p_prop;
|
||||||
|
ae.add_to_end = p_add_to_end;
|
||||||
added_editors.push_back(ae);
|
added_editors.push_back(ae);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1059,7 +1058,7 @@ void EditorInspectorPlugin::parse_end(Object *p_object) {
|
||||||
|
|
||||||
void EditorInspectorPlugin::_bind_methods() {
|
void EditorInspectorPlugin::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("add_custom_control", "control"), &EditorInspectorPlugin::add_custom_control);
|
ClassDB::bind_method(D_METHOD("add_custom_control", "control"), &EditorInspectorPlugin::add_custom_control);
|
||||||
ClassDB::bind_method(D_METHOD("add_property_editor", "property", "editor"), &EditorInspectorPlugin::add_property_editor);
|
ClassDB::bind_method(D_METHOD("add_property_editor", "property", "editor", "add_to_end"), &EditorInspectorPlugin::add_property_editor, DEFVAL(false));
|
||||||
ClassDB::bind_method(D_METHOD("add_property_editor_for_multiple_properties", "label", "properties", "editor"), &EditorInspectorPlugin::add_property_editor_for_multiple_properties);
|
ClassDB::bind_method(D_METHOD("add_property_editor_for_multiple_properties", "label", "properties", "editor"), &EditorInspectorPlugin::add_property_editor_for_multiple_properties);
|
||||||
|
|
||||||
GDVIRTUAL_BIND(_can_handle, "object")
|
GDVIRTUAL_BIND(_can_handle, "object")
|
||||||
|
@ -2894,89 +2893,101 @@ void EditorInspector::update_tree() {
|
||||||
doc_hint = descr;
|
doc_hint = descr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Vector<EditorInspectorPlugin::AddedEditor> editors;
|
||||||
|
Vector<EditorInspectorPlugin::AddedEditor> late_editors;
|
||||||
|
|
||||||
// Search for the inspector plugin that will handle the properties. Then add the correct property editor to it.
|
// Search for the inspector plugin that will handle the properties. Then add the correct property editor to it.
|
||||||
for (Ref<EditorInspectorPlugin> &ped : valid_plugins) {
|
for (Ref<EditorInspectorPlugin> &ped : valid_plugins) {
|
||||||
bool exclusive = ped->parse_property(object, p.type, p.name, p.hint, p.hint_string, p.usage, wide_editors);
|
bool exclusive = ped->parse_property(object, p.type, p.name, p.hint, p.hint_string, p.usage, wide_editors);
|
||||||
|
|
||||||
List<EditorInspectorPlugin::AddedEditor> editors = ped->added_editors; // Make a copy, since plugins may be used again in a sub-inspector.
|
for (const EditorInspectorPlugin::AddedEditor &F : ped->added_editors) {
|
||||||
ped->added_editors.clear();
|
if (F.add_to_end) {
|
||||||
|
late_editors.push_back(F);
|
||||||
for (const EditorInspectorPlugin::AddedEditor &F : editors) {
|
} else {
|
||||||
EditorProperty *ep = Object::cast_to<EditorProperty>(F.property_editor);
|
editors.push_back(F);
|
||||||
|
|
||||||
if (ep) {
|
|
||||||
// Set all this before the control gets the ENTER_TREE notification.
|
|
||||||
ep->object = object;
|
|
||||||
|
|
||||||
if (F.properties.size()) {
|
|
||||||
if (F.properties.size() == 1) {
|
|
||||||
//since it's one, associate:
|
|
||||||
ep->property = F.properties[0];
|
|
||||||
ep->property_path = property_prefix + F.properties[0];
|
|
||||||
ep->property_usage = p.usage;
|
|
||||||
//and set label?
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!F.label.is_empty()) {
|
|
||||||
ep->set_label(F.label);
|
|
||||||
} else {
|
|
||||||
// Use the existing one.
|
|
||||||
ep->set_label(property_label_string);
|
|
||||||
}
|
|
||||||
for (int i = 0; i < F.properties.size(); i++) {
|
|
||||||
String prop = F.properties[i];
|
|
||||||
|
|
||||||
if (!editor_property_map.has(prop)) {
|
|
||||||
editor_property_map[prop] = List<EditorProperty *>();
|
|
||||||
}
|
|
||||||
editor_property_map[prop].push_back(ep);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ep->set_draw_warning(draw_warning);
|
|
||||||
ep->set_use_folding(use_folding);
|
|
||||||
ep->set_checkable(checkable);
|
|
||||||
ep->set_checked(checked);
|
|
||||||
ep->set_keying(keying);
|
|
||||||
ep->set_read_only(property_read_only);
|
|
||||||
ep->set_deletable(deletable_properties || p.name.begins_with("metadata/"));
|
|
||||||
}
|
|
||||||
|
|
||||||
current_vbox->add_child(F.property_editor);
|
|
||||||
|
|
||||||
if (ep) {
|
|
||||||
// Eventually, set other properties/signals after the property editor got added to the tree.
|
|
||||||
bool update_all = (p.usage & PROPERTY_USAGE_UPDATE_ALL_IF_MODIFIED);
|
|
||||||
ep->connect("property_changed", callable_mp(this, &EditorInspector::_property_changed), varray(update_all));
|
|
||||||
ep->connect("property_keyed", callable_mp(this, &EditorInspector::_property_keyed));
|
|
||||||
ep->connect("property_deleted", callable_mp(this, &EditorInspector::_property_deleted), varray(), CONNECT_DEFERRED);
|
|
||||||
ep->connect("property_keyed_with_value", callable_mp(this, &EditorInspector::_property_keyed_with_value));
|
|
||||||
ep->connect("property_checked", callable_mp(this, &EditorInspector::_property_checked));
|
|
||||||
ep->connect("property_pinned", callable_mp(this, &EditorInspector::_property_pinned));
|
|
||||||
ep->connect("selected", callable_mp(this, &EditorInspector::_property_selected));
|
|
||||||
ep->connect("multiple_properties_changed", callable_mp(this, &EditorInspector::_multiple_properties_changed));
|
|
||||||
ep->connect("resource_selected", callable_mp(this, &EditorInspector::_resource_selected), varray(), CONNECT_DEFERRED);
|
|
||||||
ep->connect("object_id_selected", callable_mp(this, &EditorInspector::_object_id_selected), varray(), CONNECT_DEFERRED);
|
|
||||||
if (!doc_hint.is_empty()) {
|
|
||||||
ep->set_tooltip(property_prefix + p.name + "::" + doc_hint);
|
|
||||||
} else {
|
|
||||||
ep->set_tooltip(property_prefix + p.name);
|
|
||||||
}
|
|
||||||
ep->update_property();
|
|
||||||
ep->_update_pin_flags();
|
|
||||||
ep->update_revert_and_pin_status();
|
|
||||||
ep->update_cache();
|
|
||||||
|
|
||||||
if (current_selected && ep->property == current_selected) {
|
|
||||||
ep->select(current_focusable);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ped->added_editors.clear();
|
||||||
|
|
||||||
if (exclusive) {
|
if (exclusive) {
|
||||||
// If we know the plugin is exclusive, we don't need to go through other plugins.
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
editors.append_array(late_editors);
|
||||||
|
|
||||||
|
for (int i = 0; i < editors.size(); i++) {
|
||||||
|
EditorProperty *ep = Object::cast_to<EditorProperty>(editors[i].property_editor);
|
||||||
|
const Vector<String> &properties = editors[i].properties;
|
||||||
|
|
||||||
|
if (ep) {
|
||||||
|
// Set all this before the control gets the ENTER_TREE notification.
|
||||||
|
ep->object = object;
|
||||||
|
|
||||||
|
if (properties.size()) {
|
||||||
|
if (properties.size() == 1) {
|
||||||
|
//since it's one, associate:
|
||||||
|
ep->property = properties[0];
|
||||||
|
ep->property_path = property_prefix + properties[0];
|
||||||
|
ep->property_usage = p.usage;
|
||||||
|
//and set label?
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!editors[i].label.is_empty()) {
|
||||||
|
ep->set_label(editors[i].label);
|
||||||
|
} else {
|
||||||
|
// Use the existing one.
|
||||||
|
ep->set_label(property_label_string);
|
||||||
|
}
|
||||||
|
for (int j = 0; j < properties.size(); j++) {
|
||||||
|
String prop = properties[j];
|
||||||
|
|
||||||
|
if (!editor_property_map.has(prop)) {
|
||||||
|
editor_property_map[prop] = List<EditorProperty *>();
|
||||||
|
}
|
||||||
|
editor_property_map[prop].push_back(ep);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ep->set_draw_warning(draw_warning);
|
||||||
|
ep->set_use_folding(use_folding);
|
||||||
|
ep->set_checkable(checkable);
|
||||||
|
ep->set_checked(checked);
|
||||||
|
ep->set_keying(keying);
|
||||||
|
ep->set_read_only(property_read_only);
|
||||||
|
ep->set_deletable(deletable_properties || p.name.begins_with("metadata/"));
|
||||||
|
}
|
||||||
|
|
||||||
|
current_vbox->add_child(editors[i].property_editor);
|
||||||
|
|
||||||
|
if (ep) {
|
||||||
|
// Eventually, set other properties/signals after the property editor got added to the tree.
|
||||||
|
bool update_all = (p.usage & PROPERTY_USAGE_UPDATE_ALL_IF_MODIFIED);
|
||||||
|
ep->connect("property_changed", callable_mp(this, &EditorInspector::_property_changed), varray(update_all));
|
||||||
|
ep->connect("property_keyed", callable_mp(this, &EditorInspector::_property_keyed));
|
||||||
|
ep->connect("property_deleted", callable_mp(this, &EditorInspector::_property_deleted), varray(), CONNECT_DEFERRED);
|
||||||
|
ep->connect("property_keyed_with_value", callable_mp(this, &EditorInspector::_property_keyed_with_value));
|
||||||
|
ep->connect("property_checked", callable_mp(this, &EditorInspector::_property_checked));
|
||||||
|
ep->connect("property_pinned", callable_mp(this, &EditorInspector::_property_pinned));
|
||||||
|
ep->connect("selected", callable_mp(this, &EditorInspector::_property_selected));
|
||||||
|
ep->connect("multiple_properties_changed", callable_mp(this, &EditorInspector::_multiple_properties_changed));
|
||||||
|
ep->connect("resource_selected", callable_mp(this, &EditorInspector::_resource_selected), varray(), CONNECT_DEFERRED);
|
||||||
|
ep->connect("object_id_selected", callable_mp(this, &EditorInspector::_object_id_selected), varray(), CONNECT_DEFERRED);
|
||||||
|
if (!doc_hint.is_empty()) {
|
||||||
|
ep->set_tooltip(property_prefix + p.name + "::" + doc_hint);
|
||||||
|
} else {
|
||||||
|
ep->set_tooltip(property_prefix + p.name);
|
||||||
|
}
|
||||||
|
ep->update_property();
|
||||||
|
ep->_update_pin_flags();
|
||||||
|
ep->update_revert_and_pin_status();
|
||||||
|
ep->update_cache();
|
||||||
|
|
||||||
|
if (current_selected && ep->property == current_selected) {
|
||||||
|
ep->select(current_focusable);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!hide_metadata) {
|
if (!hide_metadata) {
|
||||||
|
|
|
@ -205,11 +205,13 @@ public:
|
||||||
class EditorInspectorPlugin : public RefCounted {
|
class EditorInspectorPlugin : public RefCounted {
|
||||||
GDCLASS(EditorInspectorPlugin, RefCounted);
|
GDCLASS(EditorInspectorPlugin, RefCounted);
|
||||||
|
|
||||||
|
public:
|
||||||
friend class EditorInspector;
|
friend class EditorInspector;
|
||||||
struct AddedEditor {
|
struct AddedEditor {
|
||||||
Control *property_editor = nullptr;
|
Control *property_editor = nullptr;
|
||||||
Vector<String> properties;
|
Vector<String> properties;
|
||||||
String label;
|
String label;
|
||||||
|
bool add_to_end = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
List<AddedEditor> added_editors;
|
List<AddedEditor> added_editors;
|
||||||
|
@ -226,7 +228,7 @@ protected:
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void add_custom_control(Control *control);
|
void add_custom_control(Control *control);
|
||||||
void add_property_editor(const String &p_for_property, Control *p_prop);
|
void add_property_editor(const String &p_for_property, Control *p_prop, bool p_add_to_end = false);
|
||||||
void add_property_editor_for_multiple_properties(const String &p_label, const Vector<String> &p_properties, Control *p_prop);
|
void add_property_editor_for_multiple_properties(const String &p_label, const Vector<String> &p_properties, Control *p_prop);
|
||||||
|
|
||||||
virtual bool can_handle(Object *p_object);
|
virtual bool can_handle(Object *p_object);
|
||||||
|
|
|
@ -37,6 +37,7 @@
|
||||||
#include "editor/editor_scale.h"
|
#include "editor/editor_scale.h"
|
||||||
#include "scene/gui/check_box.h"
|
#include "scene/gui/check_box.h"
|
||||||
#include "scene/gui/view_panner.h"
|
#include "scene/gui/view_panner.h"
|
||||||
|
#include "scene/resources/texture.h"
|
||||||
|
|
||||||
void draw_margin_line(Control *edit_draw, Vector2 from, Vector2 to) {
|
void draw_margin_line(Control *edit_draw, Vector2 from, Vector2 to) {
|
||||||
Vector2 line = (to - from).normalized() * 10;
|
Vector2 line = (to - from).normalized() * 10;
|
||||||
|
@ -228,8 +229,8 @@ void TextureRegionEditor::_region_draw() {
|
||||||
Size2 vmin = vscroll->get_combined_minimum_size();
|
Size2 vmin = vscroll->get_combined_minimum_size();
|
||||||
|
|
||||||
// Avoid scrollbar overlapping.
|
// Avoid scrollbar overlapping.
|
||||||
hscroll->set_anchor_and_offset(SIDE_RIGHT, ANCHOR_END, vscroll->is_visible() ? -vmin.width : 0);
|
hscroll->set_anchor_and_offset(SIDE_RIGHT, Control::ANCHOR_END, vscroll->is_visible() ? -vmin.width : 0);
|
||||||
vscroll->set_anchor_and_offset(SIDE_BOTTOM, ANCHOR_END, hscroll->is_visible() ? -hmin.height : 0);
|
vscroll->set_anchor_and_offset(SIDE_BOTTOM, Control::ANCHOR_END, hscroll->is_visible() ? -hmin.height : 0);
|
||||||
|
|
||||||
updating_scroll = false;
|
updating_scroll = false;
|
||||||
|
|
||||||
|
@ -817,8 +818,8 @@ void TextureRegionEditor::_notification(int p_what) {
|
||||||
zoom_reset->set_icon(get_theme_icon(SNAME("ZoomReset"), SNAME("EditorIcons")));
|
zoom_reset->set_icon(get_theme_icon(SNAME("ZoomReset"), SNAME("EditorIcons")));
|
||||||
zoom_in->set_icon(get_theme_icon(SNAME("ZoomMore"), SNAME("EditorIcons")));
|
zoom_in->set_icon(get_theme_icon(SNAME("ZoomMore"), SNAME("EditorIcons")));
|
||||||
|
|
||||||
vscroll->set_anchors_and_offsets_preset(PRESET_RIGHT_WIDE);
|
vscroll->set_anchors_and_offsets_preset(Control::PRESET_RIGHT_WIDE);
|
||||||
hscroll->set_anchors_and_offsets_preset(PRESET_BOTTOM_WIDE);
|
hscroll->set_anchors_and_offsets_preset(Control::PRESET_BOTTOM_WIDE);
|
||||||
[[fallthrough]];
|
[[fallthrough]];
|
||||||
}
|
}
|
||||||
case EditorSettings::NOTIFICATION_EDITOR_SETTINGS_CHANGED: {
|
case EditorSettings::NOTIFICATION_EDITOR_SETTINGS_CHANGED: {
|
||||||
|
@ -921,6 +922,7 @@ void TextureRegionEditor::edit(Object *p_obj) {
|
||||||
atlas_tex = Ref<AtlasTexture>(nullptr);
|
atlas_tex = Ref<AtlasTexture>(nullptr);
|
||||||
}
|
}
|
||||||
edit_draw->update();
|
edit_draw->update();
|
||||||
|
popup_centered_ratio();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TextureRegionEditor::_texture_changed() {
|
void TextureRegionEditor::_texture_changed() {
|
||||||
|
@ -977,6 +979,9 @@ Vector2 TextureRegionEditor::snap_point(Vector2 p_target) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
TextureRegionEditor::TextureRegionEditor() {
|
TextureRegionEditor::TextureRegionEditor() {
|
||||||
|
get_ok_button()->set_text(TTR("Close"));
|
||||||
|
VBoxContainer *vb = memnew(VBoxContainer);
|
||||||
|
add_child(vb);
|
||||||
node_sprite_2d = nullptr;
|
node_sprite_2d = nullptr;
|
||||||
node_sprite_3d = nullptr;
|
node_sprite_3d = nullptr;
|
||||||
node_ninepatch = nullptr;
|
node_ninepatch = nullptr;
|
||||||
|
@ -992,7 +997,7 @@ TextureRegionEditor::TextureRegionEditor() {
|
||||||
drag = false;
|
drag = false;
|
||||||
|
|
||||||
HBoxContainer *hb_tools = memnew(HBoxContainer);
|
HBoxContainer *hb_tools = memnew(HBoxContainer);
|
||||||
add_child(hb_tools);
|
vb->add_child(hb_tools);
|
||||||
hb_tools->add_child(memnew(Label(TTR("Snap Mode:"))));
|
hb_tools->add_child(memnew(Label(TTR("Snap Mode:"))));
|
||||||
|
|
||||||
snap_mode_button = memnew(OptionButton);
|
snap_mode_button = memnew(OptionButton);
|
||||||
|
@ -1076,12 +1081,12 @@ TextureRegionEditor::TextureRegionEditor() {
|
||||||
panner->set_callbacks(callable_mp(this, &TextureRegionEditor::_scroll_callback), callable_mp(this, &TextureRegionEditor::_pan_callback), callable_mp(this, &TextureRegionEditor::_zoom_callback));
|
panner->set_callbacks(callable_mp(this, &TextureRegionEditor::_scroll_callback), callable_mp(this, &TextureRegionEditor::_pan_callback), callable_mp(this, &TextureRegionEditor::_zoom_callback));
|
||||||
|
|
||||||
edit_draw = memnew(Panel);
|
edit_draw = memnew(Panel);
|
||||||
add_child(edit_draw);
|
vb->add_child(edit_draw);
|
||||||
edit_draw->set_v_size_flags(SIZE_EXPAND_FILL);
|
edit_draw->set_v_size_flags(Control::SIZE_EXPAND_FILL);
|
||||||
edit_draw->connect("draw", callable_mp(this, &TextureRegionEditor::_region_draw));
|
edit_draw->connect("draw", callable_mp(this, &TextureRegionEditor::_region_draw));
|
||||||
edit_draw->connect("gui_input", callable_mp(this, &TextureRegionEditor::_region_input));
|
edit_draw->connect("gui_input", callable_mp(this, &TextureRegionEditor::_region_input));
|
||||||
edit_draw->connect("focus_exited", callable_mp(panner.ptr(), &ViewPanner::release_pan_key));
|
edit_draw->connect("focus_exited", callable_mp(panner.ptr(), &ViewPanner::release_pan_key));
|
||||||
edit_draw->set_focus_mode(FOCUS_CLICK);
|
edit_draw->set_focus_mode(Control::FOCUS_CLICK);
|
||||||
|
|
||||||
draw_zoom = 1.0;
|
draw_zoom = 1.0;
|
||||||
edit_draw->set_clip_contents(true);
|
edit_draw->set_clip_contents(true);
|
||||||
|
@ -1119,88 +1124,40 @@ TextureRegionEditor::TextureRegionEditor() {
|
||||||
|
|
||||||
updating_scroll = false;
|
updating_scroll = false;
|
||||||
autoslice_is_dirty = true;
|
autoslice_is_dirty = true;
|
||||||
|
|
||||||
|
set_title(TTR("Region Editor"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void TextureRegionEditorPlugin::edit(Object *p_object) {
|
////////////////////////
|
||||||
region_editor->edit(p_object);
|
|
||||||
|
bool EditorInspectorPluginTextureRegion::can_handle(Object *p_object) {
|
||||||
|
return Object::cast_to<Sprite2D>(p_object) || Object::cast_to<Sprite3D>(p_object) || Object::cast_to<NinePatchRect>(p_object) || Object::cast_to<StyleBoxTexture>(p_object) || Object::cast_to<AtlasTexture>(p_object);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool TextureRegionEditorPlugin::handles(Object *p_object) const {
|
void EditorInspectorPluginTextureRegion::_region_edit(Object *p_object) {
|
||||||
return p_object->is_class("Sprite2D") || p_object->is_class("Sprite3D") || p_object->is_class("NinePatchRect") || p_object->is_class("StyleBoxTexture") || p_object->is_class("AtlasTexture");
|
texture_region_editor->edit(p_object);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TextureRegionEditorPlugin::_editor_visiblity_changed() {
|
bool EditorInspectorPluginTextureRegion::parse_property(Object *p_object, const Variant::Type p_type, const String &p_path, const PropertyHint p_hint, const String &p_hint_text, const uint32_t p_usage, const bool p_wide) {
|
||||||
manually_hidden = !region_editor->is_visible_in_tree();
|
if ((p_type == Variant::RECT2 || p_type == Variant::RECT2I)) {
|
||||||
}
|
if (((Object::cast_to<Sprite2D>(p_object) || Object::cast_to<Sprite3D>(p_object) || Object::cast_to<NinePatchRect>(p_object) || Object::cast_to<StyleBoxTexture>(p_object)) && p_path == "region_rect") || (Object::cast_to<AtlasTexture>(p_object) && p_path == "region")) {
|
||||||
|
Button *button = memnew(Button);
|
||||||
void TextureRegionEditorPlugin::make_visible(bool p_visible) {
|
button->set_text(TTR("Edit Region"));
|
||||||
if (p_visible) {
|
button->set_icon(texture_region_editor->get_theme_icon(SNAME("RegionEdit"), SNAME("EditorIcons")));
|
||||||
texture_region_button->show();
|
button->connect("pressed", callable_mp(this, &EditorInspectorPluginTextureRegion::_region_edit), varray(p_object));
|
||||||
bool is_node_configured = region_editor->is_stylebox() || region_editor->is_atlas_texture() || region_editor->is_ninepatch();
|
add_property_editor(p_path, button, true);
|
||||||
is_node_configured |= region_editor->get_sprite_2d() && region_editor->get_sprite_2d()->is_region_enabled();
|
|
||||||
is_node_configured |= region_editor->get_sprite_3d() && region_editor->get_sprite_3d()->is_region_enabled();
|
|
||||||
if ((is_node_configured && !manually_hidden) || texture_region_button->is_pressed()) {
|
|
||||||
EditorNode::get_singleton()->make_bottom_panel_item_visible(region_editor);
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if (region_editor->is_visible_in_tree()) {
|
|
||||||
EditorNode::get_singleton()->hide_bottom_panel();
|
|
||||||
manually_hidden = false;
|
|
||||||
}
|
|
||||||
texture_region_button->hide();
|
|
||||||
region_editor->edit(nullptr);
|
|
||||||
}
|
}
|
||||||
|
return false; //not exclusive
|
||||||
}
|
}
|
||||||
|
|
||||||
Dictionary TextureRegionEditorPlugin::get_state() const {
|
EditorInspectorPluginTextureRegion::EditorInspectorPluginTextureRegion() {
|
||||||
Dictionary state;
|
texture_region_editor = memnew(TextureRegionEditor);
|
||||||
state["snap_offset"] = region_editor->snap_offset;
|
EditorNode::get_singleton()->get_gui_base()->add_child(texture_region_editor);
|
||||||
state["snap_step"] = region_editor->snap_step;
|
|
||||||
state["snap_separation"] = region_editor->snap_separation;
|
|
||||||
state["snap_mode"] = region_editor->snap_mode;
|
|
||||||
return state;
|
|
||||||
}
|
|
||||||
|
|
||||||
void TextureRegionEditorPlugin::set_state(const Dictionary &p_state) {
|
|
||||||
Dictionary state = p_state;
|
|
||||||
if (state.has("snap_step")) {
|
|
||||||
Vector2 s = state["snap_step"];
|
|
||||||
region_editor->sb_step_x->set_value(s.x);
|
|
||||||
region_editor->sb_step_y->set_value(s.y);
|
|
||||||
region_editor->snap_step = s;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (state.has("snap_offset")) {
|
|
||||||
Vector2 ofs = state["snap_offset"];
|
|
||||||
region_editor->sb_off_x->set_value(ofs.x);
|
|
||||||
region_editor->sb_off_y->set_value(ofs.y);
|
|
||||||
region_editor->snap_offset = ofs;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (state.has("snap_separation")) {
|
|
||||||
Vector2 sep = state["snap_separation"];
|
|
||||||
region_editor->sb_sep_x->set_value(sep.x);
|
|
||||||
region_editor->sb_sep_y->set_value(sep.y);
|
|
||||||
region_editor->snap_separation = sep;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (state.has("snap_mode")) {
|
|
||||||
region_editor->_set_snap_mode(state["snap_mode"]);
|
|
||||||
region_editor->snap_mode_button->select(state["snap_mode"]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void TextureRegionEditorPlugin::_bind_methods() {
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TextureRegionEditorPlugin::TextureRegionEditorPlugin() {
|
TextureRegionEditorPlugin::TextureRegionEditorPlugin() {
|
||||||
manually_hidden = false;
|
Ref<EditorInspectorPluginTextureRegion> inspector_plugin;
|
||||||
|
inspector_plugin.instantiate();
|
||||||
region_editor = memnew(TextureRegionEditor);
|
add_inspector_plugin(inspector_plugin);
|
||||||
region_editor->set_custom_minimum_size(Size2(0, 200) * EDSCALE);
|
|
||||||
region_editor->hide();
|
|
||||||
region_editor->connect("visibility_changed", callable_mp(this, &TextureRegionEditorPlugin::_editor_visiblity_changed));
|
|
||||||
|
|
||||||
texture_region_button = EditorNode::get_singleton()->add_bottom_panel_item(TTR("TextureRegion"), region_editor);
|
|
||||||
texture_region_button->hide();
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,8 +41,8 @@
|
||||||
|
|
||||||
class ViewPanner;
|
class ViewPanner;
|
||||||
|
|
||||||
class TextureRegionEditor : public VBoxContainer {
|
class TextureRegionEditor : public AcceptDialog {
|
||||||
GDCLASS(TextureRegionEditor, VBoxContainer);
|
GDCLASS(TextureRegionEditor, AcceptDialog);
|
||||||
|
|
||||||
enum SnapMode {
|
enum SnapMode {
|
||||||
SNAP_NONE,
|
SNAP_NONE,
|
||||||
|
@ -142,26 +142,27 @@ public:
|
||||||
TextureRegionEditor();
|
TextureRegionEditor();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//
|
||||||
|
|
||||||
|
class EditorInspectorPluginTextureRegion : public EditorInspectorPlugin {
|
||||||
|
GDCLASS(EditorInspectorPluginTextureRegion, EditorInspectorPlugin);
|
||||||
|
|
||||||
|
TextureRegionEditor *texture_region_editor = nullptr;
|
||||||
|
|
||||||
|
void _region_edit(Object *p_object);
|
||||||
|
|
||||||
|
public:
|
||||||
|
virtual bool can_handle(Object *p_object) override;
|
||||||
|
virtual bool parse_property(Object *p_object, const Variant::Type p_type, const String &p_path, const PropertyHint p_hint, const String &p_hint_text, const uint32_t p_usage, const bool p_wide) override;
|
||||||
|
|
||||||
|
EditorInspectorPluginTextureRegion();
|
||||||
|
};
|
||||||
|
|
||||||
class TextureRegionEditorPlugin : public EditorPlugin {
|
class TextureRegionEditorPlugin : public EditorPlugin {
|
||||||
GDCLASS(TextureRegionEditorPlugin, EditorPlugin);
|
GDCLASS(TextureRegionEditorPlugin, EditorPlugin);
|
||||||
|
|
||||||
bool manually_hidden;
|
|
||||||
Button *texture_region_button = nullptr;
|
|
||||||
TextureRegionEditor *region_editor = nullptr;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
static void _bind_methods();
|
|
||||||
|
|
||||||
void _editor_visiblity_changed();
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual String get_name() const override { return "TextureRegion"; }
|
virtual String get_name() const override { return "TextureRegion"; }
|
||||||
bool has_main_screen() const override { return false; }
|
|
||||||
virtual void edit(Object *p_object) override;
|
|
||||||
virtual bool handles(Object *p_object) const override;
|
|
||||||
virtual void make_visible(bool p_visible) override;
|
|
||||||
void set_state(const Dictionary &p_state) override;
|
|
||||||
Dictionary get_state() const override;
|
|
||||||
|
|
||||||
TextureRegionEditorPlugin();
|
TextureRegionEditorPlugin();
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue