Add informational messages to various editors
This commit is contained in:
parent
b25b1fb600
commit
5f3a55acb7
13 changed files with 157 additions and 89 deletions
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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");
|
||||||
|
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue