Add informational messages to various editors

This commit is contained in:
Michael Alexsander Silva Dias 2019-09-04 02:20:57 -03:00
parent b25b1fb600
commit 5f3a55acb7
13 changed files with 157 additions and 89 deletions

View file

@ -2466,6 +2466,7 @@ void AnimationTrackEdit::update_play_position() {
void AnimationTrackEdit::set_root(Node *p_root) { void AnimationTrackEdit::set_root(Node *p_root) {
root = p_root; root = p_root;
} }
void AnimationTrackEdit::_zoom_changed() { void AnimationTrackEdit::_zoom_changed() {
update(); update();
play_position->update(); play_position->update();
@ -3305,6 +3306,7 @@ Ref<Animation> AnimationTrackEditor::get_current_animation() const {
return animation; return animation;
} }
void AnimationTrackEditor::_root_removed(Node *p_root) { void AnimationTrackEditor::_root_removed(Node *p_root) {
root = NULL; root = NULL;
} }
@ -4079,6 +4081,8 @@ int AnimationTrackEditor::_confirm_insert(InsertData p_id, int p_last_track, boo
} }
void AnimationTrackEditor::show_select_node_warning(bool p_show) { void AnimationTrackEditor::show_select_node_warning(bool p_show) {
info_message->set_visible(p_show);
} }
bool AnimationTrackEditor::is_key_selected(int p_track, int p_key) const { bool AnimationTrackEditor::is_key_selected(int p_track, int p_key) const {
@ -5794,6 +5798,14 @@ AnimationTrackEditor::AnimationTrackEditor() {
timeline_vbox->set_h_size_flags(SIZE_EXPAND_FILL); timeline_vbox->set_h_size_flags(SIZE_EXPAND_FILL);
timeline_vbox->add_constant_override("separation", 0); timeline_vbox->add_constant_override("separation", 0);
info_message = memnew(Label);
info_message->set_text(TTR("Select an AnimationPlayer node to create and edit animations."));
info_message->set_valign(Label::VALIGN_CENTER);
info_message->set_align(Label::ALIGN_CENTER);
info_message->set_autowrap(true);
info_message->set_anchors_and_margins_preset(PRESET_WIDE, PRESET_MODE_KEEP_SIZE, 8 * EDSCALE);
main_panel->add_child(info_message);
timeline = memnew(AnimationTimelineEdit); timeline = memnew(AnimationTimelineEdit);
timeline->set_undo_redo(undo_redo); timeline->set_undo_redo(undo_redo);
timeline_vbox->add_child(timeline); timeline_vbox->add_child(timeline);

View file

@ -304,6 +304,8 @@ class AnimationTrackEditor : public VBoxContainer {
VBoxContainer *track_vbox; VBoxContainer *track_vbox;
AnimationBezierTrackEdit *bezier_edit; AnimationBezierTrackEdit *bezier_edit;
Label *info_message;
AnimationTimelineEdit *timeline; AnimationTimelineEdit *timeline;
HSlider *zoom; HSlider *zoom;
EditorSpinSlider *step; EditorSpinSlider *step;

View file

@ -132,6 +132,7 @@ void ImportDock::set_edit_path(const String &p_path) {
params->paths.push_back(p_path); params->paths.push_back(p_path);
import->set_disabled(false); import->set_disabled(false);
import_as->set_disabled(false); import_as->set_disabled(false);
preset->set_disabled(false);
imported->set_text(p_path.get_file()); imported->set_text(p_path.get_file());
} }
@ -287,6 +288,7 @@ void ImportDock::set_edit_multiple_paths(const Vector<String> &p_paths) {
params->paths = p_paths; params->paths = p_paths;
import->set_disabled(false); import->set_disabled(false);
import_as->set_disabled(false); import_as->set_disabled(false);
preset->set_disabled(false);
imported->set_text(itos(p_paths.size()) + TTR(" Files")); imported->set_text(itos(p_paths.size()) + TTR(" Files"));
} }
@ -367,6 +369,7 @@ void ImportDock::clear() {
import->set_disabled(true); import->set_disabled(true);
import_as->clear(); import_as->clear();
import_as->set_disabled(true); import_as->set_disabled(true);
preset->set_disabled(true);
params->values.clear(); params->values.clear();
params->properties.clear(); params->properties.clear();
params->update(); params->update();
@ -528,11 +531,13 @@ ImportDock::ImportDock() {
HBoxContainer *hb = memnew(HBoxContainer); HBoxContainer *hb = memnew(HBoxContainer);
add_margin_child(TTR("Import As:"), hb); add_margin_child(TTR("Import As:"), hb);
import_as = memnew(OptionButton); import_as = memnew(OptionButton);
import_as->set_disabled(true);
import_as->connect("item_selected", this, "_importer_selected"); import_as->connect("item_selected", this, "_importer_selected");
hb->add_child(import_as); hb->add_child(import_as);
import_as->set_h_size_flags(SIZE_EXPAND_FILL); import_as->set_h_size_flags(SIZE_EXPAND_FILL);
preset = memnew(MenuButton); preset = memnew(MenuButton);
preset->set_text(TTR("Preset...")); preset->set_text(TTR("Preset"));
preset->set_disabled(true);
preset->get_popup()->connect("index_pressed", this, "_preset_selected"); preset->get_popup()->connect("index_pressed", this, "_preset_selected");
hb->add_child(preset); hb->add_child(preset);
@ -545,6 +550,7 @@ ImportDock::ImportDock() {
add_child(hb); add_child(hb);
import = memnew(Button); import = memnew(Button);
import->set_text(TTR("Reimport")); import->set_text(TTR("Reimport"));
import->set_disabled(true);
import->connect("pressed", this, "_reimport_attempt"); import->connect("pressed", this, "_reimport_attempt");
hb->add_spacer(); hb->add_spacer();
hb->add_child(import); hb->add_child(import);

View file

@ -38,7 +38,7 @@
#include "editor/animation_track_editor.h" #include "editor/animation_track_editor.h"
#include "editor/editor_settings.h" #include "editor/editor_settings.h"
// For onion skinning // For onion skinning.
#include "editor/plugins/canvas_item_editor_plugin.h" #include "editor/plugins/canvas_item_editor_plugin.h"
#include "editor/plugins/spatial_editor_plugin.h" #include "editor/plugins/spatial_editor_plugin.h"
#include "scene/main/viewport.h" #include "scene/main/viewport.h"
@ -1088,20 +1088,6 @@ void AnimationPlayerEditor::_animation_key_editor_seek(float p_pos, bool p_drag)
EditorNode::get_singleton()->get_inspector()->refresh(); EditorNode::get_singleton()->get_inspector()->refresh();
} }
void AnimationPlayerEditor::_hide_anim_editors() {
player = NULL;
hide();
set_process(false);
track_editor->set_animation(Ref<Animation>());
track_editor->set_root(NULL);
track_editor->show_select_node_warning(true);
}
void AnimationPlayerEditor::_animation_about_to_show_menu() {
}
void AnimationPlayerEditor::_animation_tool_menu(int p_option) { void AnimationPlayerEditor::_animation_tool_menu(int p_option) {
String current; String current;
@ -1489,7 +1475,7 @@ void AnimationPlayerEditor::_prepare_onion_layers_2() {
player->seek(cpos, false); player->seek(cpos, false);
player->restore_animated_values(values_backup); player->restore_animated_values(values_backup);
// Restor state of main editors. // Restore state of main editors.
if (SpatialEditor::get_singleton()->is_visible()) { if (SpatialEditor::get_singleton()->is_visible()) {
// 3D // 3D
SpatialEditor::get_singleton()->set_state(spatial_edit_state); SpatialEditor::get_singleton()->set_state(spatial_edit_state);
@ -1519,7 +1505,7 @@ void AnimationPlayerEditor::_stop_onion_skinning() {
_free_onion_layers(); _free_onion_layers();
// Clean up the overlay // Clean up the overlay.
onion.can_overlay = false; onion.can_overlay = false;
plugin->update_overlays(); plugin->update_overlays();
} }
@ -1557,7 +1543,6 @@ void AnimationPlayerEditor::_bind_methods() {
ClassDB::bind_method(D_METHOD("_list_changed"), &AnimationPlayerEditor::_list_changed); ClassDB::bind_method(D_METHOD("_list_changed"), &AnimationPlayerEditor::_list_changed);
ClassDB::bind_method(D_METHOD("_animation_key_editor_seek"), &AnimationPlayerEditor::_animation_key_editor_seek); ClassDB::bind_method(D_METHOD("_animation_key_editor_seek"), &AnimationPlayerEditor::_animation_key_editor_seek);
ClassDB::bind_method(D_METHOD("_animation_key_editor_anim_len_changed"), &AnimationPlayerEditor::_animation_key_editor_anim_len_changed); ClassDB::bind_method(D_METHOD("_animation_key_editor_anim_len_changed"), &AnimationPlayerEditor::_animation_key_editor_anim_len_changed);
ClassDB::bind_method(D_METHOD("_hide_anim_editors"), &AnimationPlayerEditor::_hide_anim_editors);
ClassDB::bind_method(D_METHOD("_animation_duplicate"), &AnimationPlayerEditor::_animation_duplicate); ClassDB::bind_method(D_METHOD("_animation_duplicate"), &AnimationPlayerEditor::_animation_duplicate);
ClassDB::bind_method(D_METHOD("_blend_editor_next_changed"), &AnimationPlayerEditor::_blend_editor_next_changed); ClassDB::bind_method(D_METHOD("_blend_editor_next_changed"), &AnimationPlayerEditor::_blend_editor_next_changed);
ClassDB::bind_method(D_METHOD("_unhandled_key_input"), &AnimationPlayerEditor::_unhandled_key_input); ClassDB::bind_method(D_METHOD("_unhandled_key_input"), &AnimationPlayerEditor::_unhandled_key_input);
@ -1776,7 +1761,7 @@ AnimationPlayerEditor::AnimationPlayerEditor(EditorNode *p_editor, AnimationPlay
_update_player(); _update_player();
// Onion skinning // Onion skinning.
track_editor->connect("visibility_changed", this, "_editor_visibility_changed"); track_editor->connect("visibility_changed", this, "_editor_visibility_changed");

View file

@ -130,9 +130,9 @@ class AnimationPlayerEditor : public VBoxContainer {
AnimationTrackEditor *track_editor; AnimationTrackEditor *track_editor;
// Onion skinning // Onion skinning.
struct { struct {
// Settings // Settings.
bool enabled; bool enabled;
bool past; bool past;
bool future; bool future;
@ -142,11 +142,11 @@ class AnimationPlayerEditor : public VBoxContainer {
bool include_gizmos; bool include_gizmos;
int get_needed_capture_count() const { int get_needed_capture_count() const {
// 'Differences only' needs a capture of the present // 'Differences only' needs a capture of the present.
return (past && future ? 2 * steps : steps) + (differences_only ? 1 : 0); return (past && future ? 2 * steps : steps) + (differences_only ? 1 : 0);
} }
// Rendering // Rendering.
int64_t last_frame; int64_t last_frame;
int can_overlay; int can_overlay;
Size2 capture_size; Size2 capture_size;
@ -195,8 +195,6 @@ class AnimationPlayerEditor : public VBoxContainer {
void _update_player(); void _update_player();
void _blend_edited(); void _blend_edited();
void _hide_anim_editors();
void _animation_player_changed(Object *p_pl); void _animation_player_changed(Object *p_pl);
void _animation_key_editor_seek(float p_pos, bool p_drag); void _animation_key_editor_seek(float p_pos, bool p_drag);
@ -205,7 +203,6 @@ class AnimationPlayerEditor : public VBoxContainer {
void _unhandled_key_input(const Ref<InputEvent> &p_ev); void _unhandled_key_input(const Ref<InputEvent> &p_ev);
void _animation_tool_menu(int p_option); void _animation_tool_menu(int p_option);
void _onion_skinning_menu(int p_option); void _onion_skinning_menu(int p_option);
void _animation_about_to_show_menu();
void _editor_visibility_changed(); void _editor_visibility_changed();
bool _are_onion_layers_valid(); bool _are_onion_layers_valid();

View file

@ -376,7 +376,7 @@ void TileMapEditor::_sbox_input(const Ref<InputEvent> &p_ie) {
} }
// Implementation detail of TileMapEditor::_update_palette(); // Implementation detail of TileMapEditor::_update_palette();
// in modern C++ this could have been inside its body // In modern C++ this could have been inside its body.
namespace { namespace {
struct _PaletteEntry { struct _PaletteEntry {
int id; int id;
@ -393,10 +393,10 @@ void TileMapEditor::_update_palette() {
if (!node) if (!node)
return; return;
// Update the clear button // Update the clear button.
clear_transform_button->set_disabled(!flip_h && !flip_v && !transpose); clear_transform_button->set_disabled(!flip_h && !flip_v && !transpose);
// Update the palette // Update the palette.
Vector<int> selected = get_selected_tiles(); Vector<int> selected = get_selected_tiles();
int selected_single = palette->get_current(); int selected_single = palette->get_current();
int selected_manual = manual_palette->get_current(); int selected_manual = manual_palette->get_current();
@ -405,8 +405,15 @@ void TileMapEditor::_update_palette() {
manual_palette->hide(); manual_palette->hide();
Ref<TileSet> tileset = node->get_tileset(); Ref<TileSet> tileset = node->get_tileset();
if (tileset.is_null()) if (tileset.is_null()) {
search_box->set_text("");
search_box->set_editable(false);
info_message->show();
return; return;
}
search_box->set_editable(true);
info_message->hide();
List<int> tiles; List<int> tiles;
tileset->get_tile_list(&tiles); tileset->get_tile_list(&tiles);
@ -421,7 +428,6 @@ void TileMapEditor::_update_palette() {
bool sort_by_name = bool(EDITOR_DEF("editors/tile_map/sort_tiles_by_name", true)); bool sort_by_name = bool(EDITOR_DEF("editors/tile_map/sort_tiles_by_name", true));
palette->add_constant_override("hseparation", hseparation * EDSCALE); palette->add_constant_override("hseparation", hseparation * EDSCALE);
palette->add_constant_override("vseparation", 8 * EDSCALE);
palette->set_fixed_icon_size(Size2(min_size, min_size)); palette->set_fixed_icon_size(Size2(min_size, min_size));
palette->set_fixed_column_width(min_size * MAX(size_slider->get_value(), 1)); palette->set_fixed_column_width(min_size * MAX(size_slider->get_value(), 1));
@ -479,7 +485,7 @@ void TileMapEditor::_update_palette() {
region.position += (region.size + Vector2(spacing, spacing)) * tileset->autotile_get_icon_coordinate(entries[i].id); region.position += (region.size + Vector2(spacing, spacing)) * tileset->autotile_get_icon_coordinate(entries[i].id);
} }
// Transpose and flip // Transpose and flip.
palette->set_item_icon_transposed(palette->get_item_count() - 1, transpose); palette->set_item_icon_transposed(palette->get_item_count() - 1, transpose);
if (flip_h) { if (flip_h) {
region.size.x = -region.size.x; region.size.x = -region.size.x;
@ -488,14 +494,14 @@ void TileMapEditor::_update_palette() {
region.size.y = -region.size.y; region.size.y = -region.size.y;
} }
// Set region // Set region.
if (region.size != Size2()) if (region.size != Size2())
palette->set_item_icon_region(palette->get_item_count() - 1, region); palette->set_item_icon_region(palette->get_item_count() - 1, region);
// Set icon // Set icon.
palette->set_item_icon(palette->get_item_count() - 1, tex); palette->set_item_icon(palette->get_item_count() - 1, tex);
// Modulation // Modulation.
Color color = tileset->tile_get_modulate(entries[i].id); Color color = tileset->tile_get_modulate(entries[i].id);
palette->set_item_icon_modulate(palette->get_item_count() - 1, color); palette->set_item_icon_modulate(palette->get_item_count() - 1, color);
} }
@ -511,50 +517,47 @@ void TileMapEditor::_update_palette() {
palette->select(0); palette->select(0);
} }
if (sel_tile != TileMap::INVALID_CELL) { if (sel_tile != TileMap::INVALID_CELL && ((manual_autotile && tileset->tile_get_tile_mode(sel_tile) == TileSet::AUTO_TILE) || (!priority_atlastile && tileset->tile_get_tile_mode(sel_tile) == TileSet::ATLAS_TILE))) {
if ((manual_autotile && tileset->tile_get_tile_mode(sel_tile) == TileSet::AUTO_TILE) ||
(!priority_atlastile && tileset->tile_get_tile_mode(sel_tile) == TileSet::ATLAS_TILE)) {
const Map<Vector2, uint32_t> &tiles2 = tileset->autotile_get_bitmask_map(sel_tile); const Map<Vector2, uint32_t> &tiles2 = tileset->autotile_get_bitmask_map(sel_tile);
Vector<Vector2> entries2; Vector<Vector2> entries2;
for (const Map<Vector2, uint32_t>::Element *E = tiles2.front(); E; E = E->next()) { for (const Map<Vector2, uint32_t>::Element *E = tiles2.front(); E; E = E->next()) {
entries2.push_back(E->key()); entries2.push_back(E->key());
}
// Sort tiles in row-major order.
struct SwapComparator {
_FORCE_INLINE_ bool operator()(const Vector2 &v_l, const Vector2 &v_r) const {
return v_l.y != v_r.y ? v_l.y < v_r.y : v_l.x < v_r.x;
} }
// Sort tiles in row-major order };
struct SwapComparator { entries2.sort_custom<SwapComparator>();
_FORCE_INLINE_ bool operator()(const Vector2 &v_l, const Vector2 &v_r) const {
return v_l.y != v_r.y ? v_l.y < v_r.y : v_l.x < v_r.x;
}
};
entries2.sort_custom<SwapComparator>();
Ref<Texture> tex = tileset->tile_get_texture(sel_tile); Ref<Texture> tex = tileset->tile_get_texture(sel_tile);
for (int i = 0; i < entries2.size(); i++) { for (int i = 0; i < entries2.size(); i++) {
manual_palette->add_item(String()); manual_palette->add_item(String());
if (tex.is_valid()) { if (tex.is_valid()) {
Rect2 region = tileset->tile_get_region(sel_tile); Rect2 region = tileset->tile_get_region(sel_tile);
int spacing = tileset->autotile_get_spacing(sel_tile); int spacing = tileset->autotile_get_spacing(sel_tile);
region.size = tileset->autotile_get_size(sel_tile); // !! region.size = tileset->autotile_get_size(sel_tile); // !!
region.position += (region.size + Vector2(spacing, spacing)) * entries2[i]; region.position += (region.size + Vector2(spacing, spacing)) * entries2[i];
if (!region.has_no_area()) if (!region.has_no_area())
manual_palette->set_item_icon_region(manual_palette->get_item_count() - 1, region); manual_palette->set_item_icon_region(manual_palette->get_item_count() - 1, region);
manual_palette->set_item_icon(manual_palette->get_item_count() - 1, tex); manual_palette->set_item_icon(manual_palette->get_item_count() - 1, tex);
}
manual_palette->set_item_metadata(manual_palette->get_item_count() - 1, entries2[i]);
} }
manual_palette->set_item_metadata(manual_palette->get_item_count() - 1, entries2[i]);
} }
} }
if (manual_palette->get_item_count() > 0) { if (manual_palette->get_item_count() > 0) {
// Only show the manual palette if at least tile exists in it // Only show the manual palette if at least tile exists in it.
if (selected_manual == -1 || selected_single != palette->get_current()) if (selected_manual == -1 || selected_single != palette->get_current())
selected_manual = 0; selected_manual = 0;
if (selected_manual < manual_palette->get_item_count()) if (selected_manual < manual_palette->get_item_count())
@ -1951,6 +1954,7 @@ TileMapEditor::TileMapEditor(EditorNode *p_editor) {
add_child(priority_button); add_child(priority_button);
search_box = memnew(LineEdit); search_box = memnew(LineEdit);
search_box->set_placeholder(TTR("Filter tiles"));
search_box->set_h_size_flags(SIZE_EXPAND_FILL); search_box->set_h_size_flags(SIZE_EXPAND_FILL);
search_box->connect("text_entered", this, "_text_entered"); search_box->connect("text_entered", this, "_text_entered");
search_box->connect("text_changed", this, "_text_changed"); search_box->connect("text_changed", this, "_text_changed");
@ -1973,7 +1977,7 @@ TileMapEditor::TileMapEditor(EditorNode *p_editor) {
palette_container->set_custom_minimum_size(Size2(mw, 0)); palette_container->set_custom_minimum_size(Size2(mw, 0));
add_child(palette_container); add_child(palette_container);
// Add tile palette // Add tile palette.
palette = memnew(ItemList); palette = memnew(ItemList);
palette->set_h_size_flags(SIZE_EXPAND_FILL); palette->set_h_size_flags(SIZE_EXPAND_FILL);
palette->set_v_size_flags(SIZE_EXPAND_FILL); palette->set_v_size_flags(SIZE_EXPAND_FILL);
@ -1981,11 +1985,21 @@ TileMapEditor::TileMapEditor(EditorNode *p_editor) {
palette->set_icon_mode(ItemList::ICON_MODE_TOP); palette->set_icon_mode(ItemList::ICON_MODE_TOP);
palette->set_max_text_lines(2); palette->set_max_text_lines(2);
palette->set_select_mode(ItemList::SELECT_MULTI); palette->set_select_mode(ItemList::SELECT_MULTI);
palette->add_constant_override("vseparation", 8 * EDSCALE);
palette->connect("item_selected", this, "_palette_selected"); palette->connect("item_selected", this, "_palette_selected");
palette->connect("multi_selected", this, "_palette_multi_selected"); palette->connect("multi_selected", this, "_palette_multi_selected");
palette_container->add_child(palette); palette_container->add_child(palette);
// Add autotile override palette // Add message for when no texture is selected.
info_message = memnew(Label);
info_message->set_text(TTR("Give a TileSet resource to this TileMap to use its tiles."));
info_message->set_valign(Label::VALIGN_CENTER);
info_message->set_align(Label::ALIGN_CENTER);
info_message->set_autowrap(true);
info_message->set_anchors_and_margins_preset(PRESET_WIDE, PRESET_MODE_KEEP_SIZE, 8 * EDSCALE);
palette->add_child(info_message);
// Add autotile override palette.
manual_palette = memnew(ItemList); manual_palette = memnew(ItemList);
manual_palette->set_h_size_flags(SIZE_EXPAND_FILL); manual_palette->set_h_size_flags(SIZE_EXPAND_FILL);
manual_palette->set_v_size_flags(SIZE_EXPAND_FILL); manual_palette->set_v_size_flags(SIZE_EXPAND_FILL);
@ -1995,15 +2009,14 @@ TileMapEditor::TileMapEditor(EditorNode *p_editor) {
manual_palette->hide(); manual_palette->hide();
palette_container->add_child(manual_palette); palette_container->add_child(manual_palette);
// Add menu items // Add menu items.
toolbar = memnew(HBoxContainer); toolbar = memnew(HBoxContainer);
toolbar->hide(); toolbar->hide();
CanvasItemEditor::get_singleton()->add_control_to_menu_panel(toolbar); CanvasItemEditor::get_singleton()->add_control_to_menu_panel(toolbar);
// Separator
toolbar->add_child(memnew(VSeparator)); toolbar->add_child(memnew(VSeparator));
// Tools // Tools.
paint_button = memnew(ToolButton); paint_button = memnew(ToolButton);
paint_button->set_shortcut(ED_SHORTCUT("tile_map_editor/paint_tile", TTR("Paint Tile"), KEY_P)); paint_button->set_shortcut(ED_SHORTCUT("tile_map_editor/paint_tile", TTR("Paint Tile"), KEY_P));
paint_button->set_tooltip(TTR("Shift+LMB: Line Draw\nShift+Ctrl+LMB: Rectangle Paint")); paint_button->set_tooltip(TTR("Shift+LMB: Line Draw\nShift+Ctrl+LMB: Rectangle Paint"));
@ -2031,18 +2044,18 @@ TileMapEditor::TileMapEditor(EditorNode *p_editor) {
_update_button_tool(); _update_button_tool();
// Container to the right of the toolbar // Container to the right of the toolbar.
toolbar_right = memnew(HBoxContainer); toolbar_right = memnew(HBoxContainer);
toolbar_right->hide(); toolbar_right->hide();
toolbar_right->set_h_size_flags(SIZE_EXPAND_FILL); toolbar_right->set_h_size_flags(SIZE_EXPAND_FILL);
toolbar_right->set_alignment(BoxContainer::ALIGN_END); toolbar_right->set_alignment(BoxContainer::ALIGN_END);
CanvasItemEditor::get_singleton()->add_control_to_menu_panel(toolbar_right); CanvasItemEditor::get_singleton()->add_control_to_menu_panel(toolbar_right);
// Tile position // Tile position.
tile_info = memnew(Label); tile_info = memnew(Label);
toolbar_right->add_child(tile_info); toolbar_right->add_child(tile_info);
// Menu // Menu.
options = memnew(MenuButton); options = memnew(MenuButton);
options->set_text("TileMap"); options->set_text("TileMap");
options->set_icon(EditorNode::get_singleton()->get_gui_base()->get_icon("TileMap", "EditorIcons")); options->set_icon(EditorNode::get_singleton()->get_gui_base()->get_icon("TileMap", "EditorIcons"));
@ -2136,7 +2149,8 @@ void TileMapEditorPlugin::make_visible(bool p_visible) {
tile_map_editor->show(); tile_map_editor->show();
tile_map_editor->get_toolbar()->show(); tile_map_editor->get_toolbar()->show();
tile_map_editor->get_toolbar_right()->show(); tile_map_editor->get_toolbar_right()->show();
CanvasItemEditor::get_singleton()->set_current_tool(CanvasItemEditor::TOOL_SELECT); //Change to TOOL_SELECT when TileMap node is selected, to prevent accidental movement. // Change to TOOL_SELECT when TileMap node is selected, to prevent accidental movement.
CanvasItemEditor::get_singleton()->set_current_tool(CanvasItemEditor::TOOL_SELECT);
} else { } else {
tile_map_editor->hide(); tile_map_editor->hide();

View file

@ -82,6 +82,8 @@ class TileMapEditor : public VBoxContainer {
ItemList *palette; ItemList *palette;
ItemList *manual_palette; ItemList *manual_palette;
Label *info_message;
HBoxContainer *toolbar; HBoxContainer *toolbar;
HBoxContainer *toolbar_right; HBoxContainer *toolbar_right;

View file

@ -579,6 +579,14 @@ TileSetEditor::TileSetEditor(EditorNode *p_editor) {
scroll->set_v_size_flags(SIZE_EXPAND_FILL); scroll->set_v_size_flags(SIZE_EXPAND_FILL);
scroll->set_clip_contents(true); scroll->set_clip_contents(true);
empty_message = memnew(Label);
empty_message->set_text(TTR("Add or select a texture on the left panel to edit the tiles bound to it."));
empty_message->set_valign(Label::VALIGN_CENTER);
empty_message->set_align(Label::ALIGN_CENTER);
empty_message->set_autowrap(true);
empty_message->set_v_size_flags(SIZE_EXPAND_FILL);
main_vb->add_child(empty_message);
workspace_container = memnew(Control); workspace_container = memnew(Control);
scroll->add_child(workspace_container); scroll->add_child(workspace_container);
@ -627,7 +635,7 @@ TileSetEditor::TileSetEditor(EditorNode *p_editor) {
helper = memnew(TilesetEditorContext(this)); helper = memnew(TilesetEditorContext(this));
tile_names_visible = false; tile_names_visible = false;
// config scale // Config scale.
max_scale = 10.0f; max_scale = 10.0f;
min_scale = 0.1f; min_scale = 0.1f;
scale_ratio = 1.2f; scale_ratio = 1.2f;
@ -3123,12 +3131,28 @@ void TileSetEditor::update_workspace_tile_mode() {
} }
tools[SELECT_NEXT]->set_disabled(true); tools[SELECT_NEXT]->set_disabled(true);
tools[SELECT_PREVIOUS]->set_disabled(true); tools[SELECT_PREVIOUS]->set_disabled(true);
tools[ZOOM_OUT]->hide();
tools[ZOOM_1]->hide();
tools[ZOOM_IN]->hide();
tools[VISIBLE_INFO]->hide();
scroll->hide();
empty_message->show();
} else { } else {
for (int i = 1; i < WORKSPACE_MODE_MAX; i++) { for (int i = 1; i < WORKSPACE_MODE_MAX; i++) {
tool_workspacemode[i]->set_disabled(false); tool_workspacemode[i]->set_disabled(false);
} }
tools[SELECT_NEXT]->set_disabled(false); tools[SELECT_NEXT]->set_disabled(false);
tools[SELECT_PREVIOUS]->set_disabled(false); tools[SELECT_PREVIOUS]->set_disabled(false);
tools[ZOOM_OUT]->show();
tools[ZOOM_1]->show();
tools[ZOOM_IN]->show();
tools[VISIBLE_INFO]->show();
scroll->show();
empty_message->hide();
} }
if (workspace_mode != WORKSPACE_EDIT) { if (workspace_mode != WORKSPACE_EDIT) {

View file

@ -138,6 +138,7 @@ class TileSetEditor : public HSplitContainer {
int current_item_index; int current_item_index;
Sprite *preview; Sprite *preview;
ScrollContainer *scroll; ScrollContainer *scroll;
Label *empty_message;
Control *workspace_container; Control *workspace_container;
bool draw_handles; bool draw_handles;
Control *workspace_overlay; Control *workspace_overlay;

View file

@ -1028,17 +1028,15 @@ void ScriptEditorDebugger::_performance_draw() {
which.push_back(i); which.push_back(i);
} }
Ref<Font> graph_font = get_font("font", "TextEdit");
if (which.empty()) { if (which.empty()) {
String text = TTR("Pick one or more items from the list to display the graph."); info_message->show();
perf_draw->draw_string(graph_font, Point2i(MAX(0, perf_draw->get_size().x - graph_font->get_string_size(text).x), perf_draw->get_size().y + graph_font->get_ascent()) / 2, text, get_color("font_color", "Label"), perf_draw->get_size().x);
return; return;
} }
info_message->hide();
Ref<StyleBox> graph_sb = get_stylebox("normal", "TextEdit"); Ref<StyleBox> graph_sb = get_stylebox("normal", "TextEdit");
Ref<Font> graph_font = get_font("font", "TextEdit");
int cols = Math::ceil(Math::sqrt((float)which.size())); int cols = Math::ceil(Math::sqrt((float)which.size()));
int rows = Math::ceil((float)which.size() / cols); int rows = Math::ceil((float)which.size() / cols);
@ -1107,7 +1105,6 @@ void ScriptEditorDebugger::_notification(int p_what) {
forward->set_icon(get_icon("Forward", "EditorIcons")); forward->set_icon(get_icon("Forward", "EditorIcons"));
dobreak->set_icon(get_icon("Pause", "EditorIcons")); dobreak->set_icon(get_icon("Pause", "EditorIcons"));
docontinue->set_icon(get_icon("DebugContinue", "EditorIcons")); docontinue->set_icon(get_icon("DebugContinue", "EditorIcons"));
//scene_tree_refresh->set_icon( get_icon("Reload","EditorIcons"));
le_set->connect("pressed", this, "_live_edit_set"); le_set->connect("pressed", this, "_live_edit_set");
le_clear->connect("pressed", this, "_live_edit_clear"); le_clear->connect("pressed", this, "_live_edit_clear");
error_tree->connect("item_selected", this, "_error_selected"); error_tree->connect("item_selected", this, "_error_selected");
@ -2254,11 +2251,14 @@ ScriptEditorDebugger::ScriptEditorDebugger(EditorNode *p_editor) {
perf_monitors->set_column_title(0, TTR("Monitor")); perf_monitors->set_column_title(0, TTR("Monitor"));
perf_monitors->set_column_title(1, TTR("Value")); perf_monitors->set_column_title(1, TTR("Value"));
perf_monitors->set_column_titles_visible(true); perf_monitors->set_column_titles_visible(true);
hsp->add_child(perf_monitors);
perf_monitors->connect("item_edited", this, "_performance_select"); perf_monitors->connect("item_edited", this, "_performance_select");
hsp->add_child(perf_monitors);
perf_draw = memnew(Control); perf_draw = memnew(Control);
perf_draw->set_clip_contents(true);
perf_draw->connect("draw", this, "_performance_draw"); perf_draw->connect("draw", this, "_performance_draw");
hsp->add_child(perf_draw); hsp->add_child(perf_draw);
hsp->set_name(TTR("Monitors")); hsp->set_name(TTR("Monitors"));
hsp->set_split_offset(340 * EDSCALE); hsp->set_split_offset(340 * EDSCALE);
tabs->add_child(hsp); tabs->add_child(hsp);
@ -2292,6 +2292,14 @@ ScriptEditorDebugger::ScriptEditorDebugger(EditorNode *p_editor) {
perf_items.push_back(it); perf_items.push_back(it);
perf_max.write[i] = 0; perf_max.write[i] = 0;
} }
info_message = memnew(Label);
info_message->set_text(TTR("Pick one or more items from the list to display the graph."));
info_message->set_valign(Label::VALIGN_CENTER);
info_message->set_align(Label::ALIGN_CENTER);
info_message->set_autowrap(true);
info_message->set_anchors_and_margins_preset(PRESET_WIDE, PRESET_MODE_KEEP_SIZE, 8 * EDSCALE);
perf_draw->add_child(info_message);
} }
{ //vmem inspect { //vmem inspect
@ -2303,7 +2311,7 @@ ScriptEditorDebugger::ScriptEditorDebugger(EditorNode *p_editor) {
vmem_hb->add_child(memnew(Label(TTR("Total:") + " "))); vmem_hb->add_child(memnew(Label(TTR("Total:") + " ")));
vmem_total = memnew(LineEdit); vmem_total = memnew(LineEdit);
vmem_total->set_editable(false); vmem_total->set_editable(false);
vmem_total->set_custom_minimum_size(Size2(100, 1) * EDSCALE); vmem_total->set_custom_minimum_size(Size2(100, 0) * EDSCALE);
vmem_hb->add_child(vmem_total); vmem_hb->add_child(vmem_total);
vmem_refresh = memnew(ToolButton); vmem_refresh = memnew(ToolButton);
vmem_hb->add_child(vmem_refresh); vmem_hb->add_child(vmem_refresh);

View file

@ -134,6 +134,7 @@ class ScriptEditorDebugger : public Control {
Tree *perf_monitors; Tree *perf_monitors;
Control *perf_draw; Control *perf_draw;
Label *info_message;
Tree *vmem_tree; Tree *vmem_tree;
Button *vmem_refresh; Button *vmem_refresh;

View file

@ -884,9 +884,15 @@ void GridMapEditor::update_palette() {
if (mesh_library.is_null()) { if (mesh_library.is_null()) {
last_mesh_library = NULL; last_mesh_library = NULL;
search_box->set_text("");
search_box->set_editable(false);
info_message->show();
return; return;
} }
search_box->set_editable(true);
info_message->hide();
Vector<int> ids; Vector<int> ids;
ids = mesh_library->get_item_list(); ids = mesh_library->get_item_list();
@ -1296,6 +1302,7 @@ GridMapEditor::GridMapEditor(EditorNode *p_editor) {
search_box = memnew(LineEdit); search_box = memnew(LineEdit);
search_box->set_h_size_flags(SIZE_EXPAND_FILL); search_box->set_h_size_flags(SIZE_EXPAND_FILL);
search_box->set_placeholder(TTR("Filter meshes"));
hb->add_child(search_box); hb->add_child(search_box);
search_box->connect("text_changed", this, "_text_changed"); search_box->connect("text_changed", this, "_text_changed");
search_box->connect("gui_input", this, "_sbox_input"); search_box->connect("gui_input", this, "_sbox_input");
@ -1331,6 +1338,14 @@ GridMapEditor::GridMapEditor(EditorNode *p_editor) {
add_child(mesh_library_palette); add_child(mesh_library_palette);
mesh_library_palette->set_v_size_flags(SIZE_EXPAND_FILL); mesh_library_palette->set_v_size_flags(SIZE_EXPAND_FILL);
info_message = memnew(Label);
info_message->set_text(TTR("Give a MeshLibrary resource to this GridMap to use its meshes."));
info_message->set_valign(Label::VALIGN_CENTER);
info_message->set_align(Label::ALIGN_CENTER);
info_message->set_autowrap(true);
info_message->set_anchors_and_margins_preset(PRESET_WIDE, PRESET_MODE_KEEP_SIZE, 8 * EDSCALE);
mesh_library_palette->add_child(info_message);
edit_axis = Vector3::AXIS_Y; edit_axis = Vector3::AXIS_Y;
edit_floor[0] = -1; edit_floor[0] = -1;
edit_floor[1] = -1; edit_floor[1] = -1;
@ -1346,7 +1361,7 @@ GridMapEditor::GridMapEditor(EditorNode *p_editor) {
paste_mesh = VisualServer::get_singleton()->mesh_create(); paste_mesh = VisualServer::get_singleton()->mesh_create();
{ {
//selection mesh create // Selection mesh create.
PoolVector<Vector3> lines; PoolVector<Vector3> lines;
PoolVector<Vector3> triangles; PoolVector<Vector3> triangles;
@ -1424,7 +1439,6 @@ GridMapEditor::GridMapEditor(EditorNode *p_editor) {
inner_mat.instance(); inner_mat.instance();
inner_mat->set_albedo(Color(0.7, 0.7, 1.0, 0.2)); inner_mat->set_albedo(Color(0.7, 0.7, 1.0, 0.2));
//inner_mat->set_flag(SpatialMaterial::FLAG_ONTOP, true);
inner_mat->set_flag(SpatialMaterial::FLAG_UNSHADED, true); inner_mat->set_flag(SpatialMaterial::FLAG_UNSHADED, true);
inner_mat->set_feature(SpatialMaterial::FEATURE_TRANSPARENT, true); inner_mat->set_feature(SpatialMaterial::FEATURE_TRANSPARENT, true);
@ -1444,7 +1458,6 @@ GridMapEditor::GridMapEditor(EditorNode *p_editor) {
selection_floor_mat->set_on_top_of_alpha(); selection_floor_mat->set_on_top_of_alpha();
selection_floor_mat->set_flag(SpatialMaterial::FLAG_UNSHADED, true); selection_floor_mat->set_flag(SpatialMaterial::FLAG_UNSHADED, true);
selection_floor_mat->set_line_width(3.0); selection_floor_mat->set_line_width(3.0);
//selection_floor_mat->set_feature(SpatialMaterial::FEATURE_TRANSPARENT, true);
d[VS::ARRAY_VERTEX] = lines; d[VS::ARRAY_VERTEX] = lines;
VisualServer::get_singleton()->mesh_add_surface_from_arrays(selection_mesh, VS::PRIMITIVE_LINES, d); VisualServer::get_singleton()->mesh_add_surface_from_arrays(selection_mesh, VS::PRIMITIVE_LINES, d);

View file

@ -197,12 +197,16 @@ class GridMapEditor : public VBoxContainer {
RID instance; RID instance;
}; };
ItemList *mesh_library_palette;
Label *info_message;
EditorNode *editor;
void update_grid(); void update_grid();
void _configure(); void _configure();
void _menu_option(int); void _menu_option(int);
void update_palette(); void update_palette();
void _set_display_mode(int p_mode); void _set_display_mode(int p_mode);
ItemList *mesh_library_palette;
void _item_selected_cbk(int idx); void _item_selected_cbk(int idx);
void _update_cursor_transform(); void _update_cursor_transform();
void _update_cursor_instance(); void _update_cursor_instance();
@ -227,7 +231,6 @@ class GridMapEditor : public VBoxContainer {
void _delete_selection(); void _delete_selection();
void _fill_selection(); void _fill_selection();
EditorNode *editor;
bool do_input_action(Camera *p_camera, const Point2 &p_point, bool p_click); bool do_input_action(Camera *p_camera, const Point2 &p_point, bool p_click);
friend class GridMapEditorPlugin; friend class GridMapEditorPlugin;