diff --git a/editor/icons/StyleBoxGrid.svg b/editor/icons/StyleBoxGrid.svg new file mode 100644 index 00000000000..97024218814 --- /dev/null +++ b/editor/icons/StyleBoxGrid.svg @@ -0,0 +1 @@ + diff --git a/editor/icons/StyleBoxGridInvisible.svg b/editor/icons/StyleBoxGridInvisible.svg deleted file mode 100644 index 88f0585bfed..00000000000 --- a/editor/icons/StyleBoxGridInvisible.svg +++ /dev/null @@ -1 +0,0 @@ - diff --git a/editor/icons/StyleBoxGridVisible.svg b/editor/icons/StyleBoxGridVisible.svg deleted file mode 100644 index b13ee1023a0..00000000000 --- a/editor/icons/StyleBoxGridVisible.svg +++ /dev/null @@ -1 +0,0 @@ - diff --git a/editor/plugins/style_box_editor_plugin.cpp b/editor/plugins/style_box_editor_plugin.cpp index 37fec97c37b..c126aec0085 100644 --- a/editor/plugins/style_box_editor_plugin.cpp +++ b/editor/plugins/style_box_editor_plugin.cpp @@ -31,13 +31,93 @@ #include "style_box_editor_plugin.h" #include "editor/editor_scale.h" -#include "scene/gui/texture_button.h" +#include "scene/gui/button.h" bool StyleBoxPreview::grid_preview_enabled = true; void StyleBoxPreview::_grid_preview_toggled(bool p_active) { grid_preview_enabled = p_active; - preview->queue_redraw(); + queue_redraw(); +} + +void StyleBoxPreview::edit(const Ref &p_stylebox) { + if (stylebox.is_valid()) { + stylebox->disconnect("changed", callable_mp((CanvasItem *)this, &CanvasItem::queue_redraw)); + } + stylebox = p_stylebox; + if (stylebox.is_valid()) { + stylebox->connect("changed", callable_mp((CanvasItem *)this, &CanvasItem::queue_redraw)); + } + Ref sbt = stylebox; + grid_preview->set_visible(sbt.is_valid()); + queue_redraw(); +} + +void StyleBoxPreview::_notification(int p_what) { + switch (p_what) { + case NOTIFICATION_THEME_CHANGED: { + set_texture(get_theme_icon(SNAME("Checkerboard"), SNAME("EditorIcons"))); + grid_preview->set_icon(get_theme_icon(SNAME("StyleBoxGrid"), SNAME("EditorIcons"))); + } break; + case NOTIFICATION_DRAW: { + _redraw(); + } break; + } +} + +void StyleBoxPreview::_redraw() { + if (stylebox.is_valid()) { + float grid_button_width = get_theme_icon(SNAME("StyleBoxGrid"), SNAME("EditorIcons"))->get_size().x; + Rect2 preview_rect = get_rect(); + preview_rect = preview_rect.grow(-grid_button_width); + + // Re-adjust preview panel to fit all drawn content. + Rect2 drawing_rect = stylebox->get_draw_rect(preview_rect); + preview_rect.size -= drawing_rect.size - preview_rect.size; + preview_rect.position -= drawing_rect.position - preview_rect.position; + + draw_style_box(stylebox, preview_rect); + + Ref sbt = stylebox; + // Draw the "grid". Use white lines, as well as subtle black lines to ensure contrast. + if (sbt.is_valid() && grid_preview->is_pressed()) { + const Color dark_color = Color(0, 0, 0, 0.4); + const Color bright_color = Color(1, 1, 1, 0.8); + int x_left = drawing_rect.position.x + sbt->get_margin(SIDE_LEFT); + int x_right = drawing_rect.position.x + drawing_rect.size.width - sbt->get_margin(SIDE_RIGHT); + int y_top = drawing_rect.position.y + sbt->get_margin(SIDE_TOP); + int y_bottom = drawing_rect.position.y + drawing_rect.size.height - sbt->get_margin(SIDE_BOTTOM); + + draw_line(Point2(x_left + 2, 0), Point2(x_left + 2, get_size().height), dark_color); + draw_line(Point2(x_right + 1, 0), Point2(x_right + 1, get_size().height), dark_color); + draw_line(Point2(0, y_top + 2), Point2(get_size().width, y_top + 2), dark_color); + draw_line(Point2(0, y_bottom + 1), Point2(get_size().width, y_bottom + 1), dark_color); + + draw_line(Point2(x_left + 1, 0), Point2(x_left + 1, get_size().height), bright_color); + draw_line(Point2(x_right, 0), Point2(x_right, get_size().height), bright_color); + draw_line(Point2(0, y_top + 1), Point2(get_size().width, y_top + 1), bright_color); + draw_line(Point2(0, y_bottom), Point2(get_size().width, y_bottom), bright_color); + } + } +} + +StyleBoxPreview::StyleBoxPreview() { + set_clip_contents(true); + set_custom_minimum_size(Size2(0, 150) * EDSCALE); + set_stretch_mode(TextureRect::STRETCH_TILE); + set_texture_repeat(CanvasItem::TEXTURE_REPEAT_ENABLED); + set_anchors_and_offsets_preset(PRESET_FULL_RECT); + + grid_preview = memnew(Button); + grid_preview->set_toggle_mode(true); + grid_preview->connect("toggled", callable_mp(this, &StyleBoxPreview::_grid_preview_toggled)); + grid_preview->set_pressed(grid_preview_enabled); + grid_preview->set_flat(true); + grid_preview->add_theme_style_override("normal", memnew(StyleBoxEmpty)); + grid_preview->add_theme_style_override("hover", memnew(StyleBoxEmpty)); + grid_preview->add_theme_style_override("focus", memnew(StyleBoxEmpty)); + grid_preview->add_theme_style_override("pressed", memnew(StyleBoxEmpty)); + add_child(grid_preview); } bool EditorInspectorPluginStyleBox::can_handle(Object *p_object) { @@ -52,97 +132,6 @@ void EditorInspectorPluginStyleBox::parse_begin(Object *p_object) { add_custom_control(preview); } -void StyleBoxPreview::edit(const Ref &p_stylebox) { - if (stylebox.is_valid()) { - stylebox->disconnect("changed", callable_mp(this, &StyleBoxPreview::_sb_changed)); - } - stylebox = p_stylebox; - if (p_stylebox.is_valid()) { - preview->add_theme_style_override("panel", stylebox); - stylebox->connect("changed", callable_mp(this, &StyleBoxPreview::_sb_changed)); - } - Ref sbt = p_stylebox; - grid_preview->set_visible(sbt.is_valid()); - _sb_changed(); -} - -void StyleBoxPreview::_sb_changed() { - preview->queue_redraw(); -} - -void StyleBoxPreview::_notification(int p_what) { - switch (p_what) { - case NOTIFICATION_ENTER_TREE: - case NOTIFICATION_THEME_CHANGED: { - if (!is_inside_tree()) { - // TODO: This is a workaround because `NOTIFICATION_THEME_CHANGED` - // is getting called for some reason when the `TexturePreview` is - // getting destroyed, which causes `get_theme_font()` to return `nullptr`. - // See https://github.com/godotengine/godot/issues/50743. - break; - } - grid_preview->set_texture_normal(get_theme_icon(SNAME("StyleBoxGridInvisible"), SNAME("EditorIcons"))); - grid_preview->set_texture_pressed(get_theme_icon(SNAME("StyleBoxGridVisible"), SNAME("EditorIcons"))); - grid_preview->set_texture_hover(get_theme_icon(SNAME("StyleBoxGridVisible"), SNAME("EditorIcons"))); - checkerboard->set_texture(get_theme_icon(SNAME("Checkerboard"), SNAME("EditorIcons"))); - } break; - } -} - -void StyleBoxPreview::_redraw() { - if (stylebox.is_valid()) { - Ref grid_texture_disabled = get_theme_icon(SNAME("StyleBoxGridInvisible"), SNAME("EditorIcons")); - Rect2 preview_rect = preview->get_rect(); - preview_rect.position += grid_texture_disabled->get_size(); - preview_rect.size -= grid_texture_disabled->get_size() * 2; - - // Re-adjust preview panel to fit all drawn content - Rect2 draw_rect = stylebox->get_draw_rect(preview_rect); - preview_rect.size -= draw_rect.size - preview_rect.size; - preview_rect.position -= draw_rect.position - preview_rect.position; - - preview->draw_style_box(stylebox, preview_rect); - - Ref sbt = stylebox; - if (sbt.is_valid() && grid_preview->is_pressed()) { - for (int i = 0; i < 2; i++) { - Color c = i == 1 ? Color(1, 1, 1, 0.8) : Color(0, 0, 0, 0.4); - int x = draw_rect.position.x + sbt->get_margin(SIDE_LEFT) + (1 - i); - preview->draw_line(Point2(x, 0), Point2(x, preview->get_size().height), c); - int x2 = draw_rect.position.x + draw_rect.size.width - sbt->get_margin(SIDE_RIGHT) + (1 - i); - preview->draw_line(Point2(x2, 0), Point2(x2, preview->get_size().height), c); - int y = draw_rect.position.y + sbt->get_margin(SIDE_TOP) + (1 - i); - preview->draw_line(Point2(0, y), Point2(preview->get_size().width, y), c); - int y2 = draw_rect.position.y + draw_rect.size.height - sbt->get_margin(SIDE_BOTTOM) + (1 - i); - preview->draw_line(Point2(0, y2), Point2(preview->get_size().width, y2), c); - } - } - } -} - -void StyleBoxPreview::_bind_methods() { -} - -StyleBoxPreview::StyleBoxPreview() { - checkerboard = memnew(TextureRect); - checkerboard->set_stretch_mode(TextureRect::STRETCH_TILE); - checkerboard->set_texture_repeat(CanvasItem::TEXTURE_REPEAT_ENABLED); - checkerboard->set_custom_minimum_size(Size2(0.0, 150.0) * EDSCALE); - - preview = memnew(Control); - preview->set_clip_contents(true); - preview->connect("draw", callable_mp(this, &StyleBoxPreview::_redraw)); - checkerboard->add_child(preview); - preview->set_anchors_and_offsets_preset(PRESET_FULL_RECT); - - add_margin_child(TTR("Preview:"), checkerboard); - grid_preview = memnew(TextureButton); - preview->add_child(grid_preview); - grid_preview->set_toggle_mode(true); - grid_preview->connect("toggled", callable_mp(this, &StyleBoxPreview::_grid_preview_toggled)); - grid_preview->set_pressed(grid_preview_enabled); -} - StyleBoxEditorPlugin::StyleBoxEditorPlugin() { Ref inspector_plugin; inspector_plugin.instantiate(); diff --git a/editor/plugins/style_box_editor_plugin.h b/editor/plugins/style_box_editor_plugin.h index d589bd9fe2b..824f8db8e4b 100644 --- a/editor/plugins/style_box_editor_plugin.h +++ b/editor/plugins/style_box_editor_plugin.h @@ -33,28 +33,24 @@ #include "editor/editor_inspector.h" #include "editor/editor_plugin.h" -#include "scene/gui/option_button.h" #include "scene/gui/texture_rect.h" -#include "scene/resources/style_box.h" -class TextureButton; +class Button; +class StyleBox; -class StyleBoxPreview : public VBoxContainer { - GDCLASS(StyleBoxPreview, VBoxContainer); +class StyleBoxPreview : public TextureRect { + GDCLASS(StyleBoxPreview, TextureRect); - TextureRect *checkerboard = nullptr; - TextureButton *grid_preview = nullptr; - Control *preview = nullptr; + Button *grid_preview = nullptr; Ref stylebox; void _sb_changed(); void _redraw(); - void _notification(int p_what); static bool grid_preview_enabled; void _grid_preview_toggled(bool p_active); protected: - static void _bind_methods(); + void _notification(int p_what); public: void edit(const Ref &p_stylebox);