Skip to content

Commit 9788b3d

Browse files
committed
Merge pull request #100569 from arkology/texture-preview-borders
Show "transparent background" texture only behind actual texture in `TexturePreview` class + add borders for readability
2 parents 1639174 + db4ae2a commit 9788b3d

File tree

3 files changed

+57
-7
lines changed

3 files changed

+57
-7
lines changed

editor/plugins/camera_3d_editor_plugin.cpp

+1
Original file line numberDiff line numberDiff line change
@@ -91,6 +91,7 @@ Camera3DPreview::Camera3DPreview(Camera3D *p_camera) :
9191
TextureRect *display = get_texture_display();
9292
display->set_texture(sub_viewport->get_texture());
9393
sub_viewport->connect("size_changed", callable_mp((CanvasItem *)display, &CanvasItem::queue_redraw));
94+
sub_viewport->get_texture()->connect_changed(callable_mp((TexturePreview *)this, &Camera3DPreview::_update_texture_display_ratio));
9495

9596
ProjectSettings::get_singleton()->connect("settings_changed", callable_mp(this, &Camera3DPreview::_update_sub_viewport_size));
9697
_update_sub_viewport_size();

editor/plugins/texture_editor_plugin.cpp

+47-7
Original file line numberDiff line numberDiff line change
@@ -32,6 +32,8 @@
3232

3333
#include "editor/editor_string_names.h"
3434
#include "editor/themes/editor_scale.h"
35+
#include "scene/gui/aspect_ratio_container.h"
36+
#include "scene/gui/color_rect.h"
3537
#include "scene/gui/label.h"
3638
#include "scene/gui/texture_rect.h"
3739
#include "scene/resources/animated_texture.h"
@@ -61,11 +63,25 @@ void TexturePreview::_notification(int p_what) {
6163
metadata_label->add_theme_font_override(SceneStringName(font), metadata_label_font);
6264
}
6365

66+
bg_rect->set_color(get_theme_color(SNAME("dark_color_2"), EditorStringName(Editor)));
6467
checkerboard->set_texture(get_editor_theme_icon(SNAME("Checkerboard")));
68+
cached_outline_color = get_theme_color(SNAME("extra_border_color_1"), EditorStringName(Editor));
6569
} break;
6670
}
6771
}
6872

73+
void TexturePreview::_draw_outline() {
74+
const float outline_width = Math::round(EDSCALE);
75+
const Rect2 outline_rect = Rect2(Vector2(), texture_display->get_size()).grow(outline_width * 0.5);
76+
texture_display->draw_rect(outline_rect, cached_outline_color, false, outline_width);
77+
}
78+
79+
void TexturePreview::_update_texture_display_ratio() {
80+
if (texture_display->get_texture().is_valid()) {
81+
centering_container->set_ratio(texture_display->get_texture()->get_size().aspect());
82+
}
83+
}
84+
6985
void TexturePreview::_update_metadata_label_text() {
7086
const Ref<Texture2D> texture = texture_display->get_texture();
7187

@@ -124,25 +140,49 @@ void TexturePreview::_update_metadata_label_text() {
124140
}
125141

126142
TexturePreview::TexturePreview(Ref<Texture2D> p_texture, bool p_show_metadata) {
143+
set_custom_minimum_size(Size2(0.0, 256.0) * EDSCALE);
144+
145+
bg_rect = memnew(ColorRect);
146+
147+
add_child(bg_rect);
148+
149+
margin_container = memnew(MarginContainer);
150+
const float outline_width = Math::round(EDSCALE);
151+
margin_container->add_theme_constant_override("margin_right", outline_width);
152+
margin_container->add_theme_constant_override("margin_top", outline_width);
153+
margin_container->add_theme_constant_override("margin_left", outline_width);
154+
margin_container->add_theme_constant_override("margin_bottom", outline_width);
155+
add_child(margin_container);
156+
157+
centering_container = memnew(AspectRatioContainer);
158+
margin_container->add_child(centering_container);
159+
127160
checkerboard = memnew(TextureRect);
161+
checkerboard->set_expand_mode(TextureRect::EXPAND_IGNORE_SIZE);
128162
checkerboard->set_stretch_mode(TextureRect::STRETCH_TILE);
129163
checkerboard->set_texture_repeat(CanvasItem::TEXTURE_REPEAT_ENABLED);
130-
checkerboard->set_custom_minimum_size(Size2(0.0, 256.0) * EDSCALE);
131-
add_child(checkerboard);
164+
centering_container->add_child(checkerboard);
132165

133166
texture_display = memnew(TextureRect);
134167
texture_display->set_texture_filter(TEXTURE_FILTER_NEAREST_WITH_MIPMAPS);
135168
texture_display->set_texture(p_texture);
136-
texture_display->set_anchors_preset(TextureRect::PRESET_FULL_RECT);
137-
texture_display->set_stretch_mode(TextureRect::STRETCH_KEEP_ASPECT_CENTERED);
138169
texture_display->set_expand_mode(TextureRect::EXPAND_IGNORE_SIZE);
139-
add_child(texture_display);
170+
centering_container->add_child(texture_display);
171+
172+
texture_display->connect(SceneStringName(draw), callable_mp(this, &TexturePreview::_draw_outline));
173+
174+
if (p_texture.is_valid()) {
175+
_update_texture_display_ratio();
176+
p_texture->connect_changed(callable_mp(this, &TexturePreview::_update_texture_display_ratio));
177+
}
140178

141179
if (p_show_metadata) {
142180
metadata_label = memnew(Label);
143181

144-
_update_metadata_label_text();
145-
p_texture->connect_changed(callable_mp(this, &TexturePreview::_update_metadata_label_text));
182+
if (p_texture.is_valid()) {
183+
_update_metadata_label_text();
184+
p_texture->connect_changed(callable_mp(this, &TexturePreview::_update_metadata_label_text));
185+
}
146186

147187
// It's okay that these colors are static since the grid color is static too.
148188
metadata_label->add_theme_color_override(SceneStringName(font_color), Color(1, 1, 1));

editor/plugins/texture_editor_plugin.h

+9
Original file line numberDiff line numberDiff line change
@@ -36,6 +36,8 @@
3636
#include "scene/gui/margin_container.h"
3737
#include "scene/resources/texture.h"
3838

39+
class AspectRatioContainer;
40+
class ColorRect;
3941
class TextureRect;
4042

4143
class TexturePreview : public MarginContainer {
@@ -44,13 +46,20 @@ class TexturePreview : public MarginContainer {
4446
private:
4547
TextureRect *texture_display = nullptr;
4648

49+
MarginContainer *margin_container = nullptr;
50+
AspectRatioContainer *centering_container = nullptr;
51+
ColorRect *bg_rect = nullptr;
4752
TextureRect *checkerboard = nullptr;
4853
Label *metadata_label = nullptr;
4954

55+
Color cached_outline_color;
56+
57+
void _draw_outline();
5058
void _update_metadata_label_text();
5159

5260
protected:
5361
void _notification(int p_what);
62+
void _update_texture_display_ratio();
5463

5564
public:
5665
TextureRect *get_texture_display();

0 commit comments

Comments
 (0)