Make it possible to copy the Godot version identifier by clicking it
This closes #24317.
This commit is contained in:
parent
7e0a42a673
commit
be01025376
@ -37,6 +37,9 @@
|
||||
#include "core/version.h"
|
||||
#include "core/version_hash.gen.h"
|
||||
|
||||
// The metadata key used to store and retrieve the version text to copy to the clipboard.
|
||||
static const String META_TEXT_TO_COPY = "text_to_copy";
|
||||
|
||||
void EditorAbout::_theme_changed() {
|
||||
const Ref<Font> font = get_theme_font("source", "EditorFonts");
|
||||
const int font_size = get_theme_font_size("source_size", "EditorFonts");
|
||||
@ -63,7 +66,12 @@ void EditorAbout::_license_tree_selected() {
|
||||
_tpl_text->set_text(selected->get_metadata(0));
|
||||
}
|
||||
|
||||
void EditorAbout::_version_button_pressed() {
|
||||
DisplayServer::get_singleton()->clipboard_set(version_btn->get_meta(META_TEXT_TO_COPY));
|
||||
}
|
||||
|
||||
void EditorAbout::_bind_methods() {
|
||||
ClassDB::bind_method(D_METHOD("_version_button_pressed"), &EditorAbout::_version_button_pressed);
|
||||
}
|
||||
|
||||
TextureRect *EditorAbout::get_logo() const {
|
||||
@ -124,17 +132,32 @@ EditorAbout::EditorAbout() {
|
||||
_logo = memnew(TextureRect);
|
||||
hbc->add_child(_logo);
|
||||
|
||||
VBoxContainer *version_info_vbc = memnew(VBoxContainer);
|
||||
|
||||
// Add a dummy control node for spacing.
|
||||
Control *v_spacer = memnew(Control);
|
||||
version_info_vbc->add_child(v_spacer);
|
||||
|
||||
version_btn = memnew(LinkButton);
|
||||
String hash = String(VERSION_HASH);
|
||||
if (hash.length() != 0) {
|
||||
hash = "." + hash.left(9);
|
||||
}
|
||||
version_btn->set_text(VERSION_FULL_NAME + hash);
|
||||
// Set the text to copy in metadata as it slightly differs from the button's text.
|
||||
version_btn->set_meta(META_TEXT_TO_COPY, "v" VERSION_FULL_BUILD + hash);
|
||||
version_btn->set_underline_mode(LinkButton::UNDERLINE_MODE_ON_HOVER);
|
||||
version_btn->set_tooltip(TTR("Click to copy."));
|
||||
version_btn->connect("pressed", callable_mp(this, &EditorAbout::_version_button_pressed));
|
||||
version_info_vbc->add_child(version_btn);
|
||||
|
||||
Label *about_text = memnew(Label);
|
||||
about_text->set_v_size_flags(Control::SIZE_SHRINK_CENTER);
|
||||
about_text->set_text(VERSION_FULL_NAME + hash +
|
||||
String::utf8("\n\xc2\xa9 2007-2021 Juan Linietsky, Ariel Manzur.\n\xc2\xa9 2014-2021 ") +
|
||||
about_text->set_text(String::utf8("\xc2\xa9 2007-2021 Juan Linietsky, Ariel Manzur.\n\xc2\xa9 2014-2021 ") +
|
||||
TTR("Godot Engine contributors") + "\n");
|
||||
hbc->add_child(about_text);
|
||||
version_info_vbc->add_child(about_text);
|
||||
|
||||
hbc->add_child(version_info_vbc);
|
||||
|
||||
TabContainer *tc = memnew(TabContainer);
|
||||
tc->set_custom_minimum_size(Size2(950, 400) * EDSCALE);
|
||||
|
@ -34,6 +34,7 @@
|
||||
#include "scene/gui/control.h"
|
||||
#include "scene/gui/dialogs.h"
|
||||
#include "scene/gui/item_list.h"
|
||||
#include "scene/gui/link_button.h"
|
||||
#include "scene/gui/rich_text_label.h"
|
||||
#include "scene/gui/scroll_container.h"
|
||||
#include "scene/gui/separator.h"
|
||||
@ -53,8 +54,10 @@ class EditorAbout : public AcceptDialog {
|
||||
|
||||
private:
|
||||
void _license_tree_selected();
|
||||
void _version_button_pressed();
|
||||
ScrollContainer *_populate_list(const String &p_name, const List<String> &p_sections, const char *const *const p_src[], const int p_flag_single_column = 0);
|
||||
|
||||
LinkButton *version_btn;
|
||||
Tree *_tpl_tree;
|
||||
RichTextLabel *_license_text;
|
||||
RichTextLabel *_tpl_text;
|
||||
|
@ -46,11 +46,13 @@
|
||||
#include "core/string/print_string.h"
|
||||
#include "core/string/translation.h"
|
||||
#include "core/version.h"
|
||||
#include "core/version_hash.gen.h"
|
||||
#include "main/main.h"
|
||||
#include "scene/gui/center_container.h"
|
||||
#include "scene/gui/control.h"
|
||||
#include "scene/gui/dialogs.h"
|
||||
#include "scene/gui/file_dialog.h"
|
||||
#include "scene/gui/link_button.h"
|
||||
#include "scene/gui/menu_button.h"
|
||||
#include "scene/gui/panel.h"
|
||||
#include "scene/gui/panel_container.h"
|
||||
@ -184,6 +186,9 @@
|
||||
|
||||
EditorNode *EditorNode::singleton = nullptr;
|
||||
|
||||
// The metadata key used to store and retrieve the version text to copy to the clipboard.
|
||||
static const String META_TEXT_TO_COPY = "text_to_copy";
|
||||
|
||||
void EditorNode::disambiguate_filenames(const Vector<String> p_full_paths, Vector<String> &r_filenames) {
|
||||
// Keep track of a list of "index sets," i.e. sets of indices
|
||||
// within disambiguated_scene_names which contain the same name.
|
||||
@ -989,6 +994,10 @@ void EditorNode::_reload_project_settings() {
|
||||
void EditorNode::_vp_resized() {
|
||||
}
|
||||
|
||||
void EditorNode::_version_button_pressed() {
|
||||
DisplayServer::get_singleton()->clipboard_set(version_btn->get_meta(META_TEXT_TO_COPY));
|
||||
}
|
||||
|
||||
void EditorNode::_node_renamed() {
|
||||
if (get_inspector()) {
|
||||
get_inspector()->update_tree();
|
||||
@ -5559,6 +5568,8 @@ void EditorNode::_bind_methods() {
|
||||
ClassDB::bind_method("_screenshot", &EditorNode::_screenshot);
|
||||
ClassDB::bind_method("_save_screenshot", &EditorNode::_save_screenshot);
|
||||
|
||||
ClassDB::bind_method("_version_button_pressed", &EditorNode::_version_button_pressed);
|
||||
|
||||
ADD_SIGNAL(MethodInfo("play_pressed"));
|
||||
ADD_SIGNAL(MethodInfo("pause_pressed"));
|
||||
ADD_SIGNAL(MethodInfo("stop_pressed"));
|
||||
@ -6617,11 +6628,31 @@ EditorNode::EditorNode() {
|
||||
bottom_panel_hb_editors->set_h_size_flags(Control::SIZE_EXPAND_FILL);
|
||||
bottom_panel_hb->add_child(bottom_panel_hb_editors);
|
||||
|
||||
version_label = memnew(Label);
|
||||
version_label->set_text(VERSION_FULL_CONFIG);
|
||||
VBoxContainer *version_info_vbc = memnew(VBoxContainer);
|
||||
bottom_panel_hb->add_child(version_info_vbc);
|
||||
|
||||
// Add a dummy control node for vertical spacing.
|
||||
Control *v_spacer = memnew(Control);
|
||||
version_info_vbc->add_child(v_spacer);
|
||||
|
||||
version_btn = memnew(LinkButton);
|
||||
version_btn->set_text(VERSION_FULL_CONFIG);
|
||||
String hash = String(VERSION_HASH);
|
||||
if (hash.length() != 0) {
|
||||
hash = "." + hash.left(9);
|
||||
}
|
||||
// Set the text to copy in metadata as it slightly differs from the button's text.
|
||||
version_btn->set_meta(META_TEXT_TO_COPY, "v" VERSION_FULL_BUILD + hash);
|
||||
// Fade out the version label to be less prominent, but still readable
|
||||
version_label->set_self_modulate(Color(1, 1, 1, 0.6));
|
||||
bottom_panel_hb->add_child(version_label);
|
||||
version_btn->set_self_modulate(Color(1, 1, 1, 0.65));
|
||||
version_btn->set_underline_mode(LinkButton::UNDERLINE_MODE_ON_HOVER);
|
||||
version_btn->set_tooltip(TTR("Click to copy."));
|
||||
version_btn->connect("pressed", callable_mp(this, &EditorNode::_version_button_pressed));
|
||||
version_info_vbc->add_child(version_btn);
|
||||
|
||||
// Add a dummy control node for horizontal spacing.
|
||||
Control *h_spacer = memnew(Control);
|
||||
bottom_panel_hb->add_child(h_spacer);
|
||||
|
||||
bottom_panel_raise = memnew(Button);
|
||||
bottom_panel_raise->set_flat(true);
|
||||
|
@ -40,6 +40,7 @@
|
||||
#include "editor/inspector_dock.h"
|
||||
#include "editor/property_editor.h"
|
||||
#include "editor/scene_tree_dock.h"
|
||||
#include "scene/gui/link_button.h"
|
||||
|
||||
typedef void (*EditorNodeInitCallback)();
|
||||
typedef void (*EditorPluginInitializeCallback)();
|
||||
@ -424,7 +425,7 @@ private:
|
||||
HBoxContainer *bottom_panel_hb;
|
||||
HBoxContainer *bottom_panel_hb_editors;
|
||||
VBoxContainer *bottom_panel_vb;
|
||||
Label *version_label;
|
||||
LinkButton *version_btn;
|
||||
Button *bottom_panel_raise;
|
||||
|
||||
Tree *disk_changed_list;
|
||||
@ -477,6 +478,7 @@ private:
|
||||
void _close_messages();
|
||||
void _show_messages();
|
||||
void _vp_resized();
|
||||
void _version_button_pressed();
|
||||
|
||||
int _save_external_resources();
|
||||
|
||||
|
@ -2371,6 +2371,7 @@ void ProjectManager::_on_search_term_changed(const String &p_term) {
|
||||
void ProjectManager::_bind_methods() {
|
||||
ClassDB::bind_method("_unhandled_key_input", &ProjectManager::_unhandled_key_input);
|
||||
ClassDB::bind_method("_update_project_buttons", &ProjectManager::_update_project_buttons);
|
||||
ClassDB::bind_method("_version_button_pressed", &ProjectManager::_version_button_pressed);
|
||||
}
|
||||
|
||||
void ProjectManager::_open_asset_library() {
|
||||
@ -2378,6 +2379,10 @@ void ProjectManager::_open_asset_library() {
|
||||
tabs->set_current_tab(1);
|
||||
}
|
||||
|
||||
void ProjectManager::_version_button_pressed() {
|
||||
DisplayServer::get_singleton()->clipboard_set(version_btn->get_text());
|
||||
}
|
||||
|
||||
ProjectManager::ProjectManager() {
|
||||
// load settings
|
||||
if (!EditorSettings::get_singleton()) {
|
||||
@ -2601,15 +2606,30 @@ ProjectManager::ProjectManager() {
|
||||
settings_hb->set_h_grow_direction(Control::GROW_DIRECTION_BEGIN);
|
||||
settings_hb->set_anchors_and_offsets_preset(Control::PRESET_TOP_RIGHT);
|
||||
|
||||
Label *version_label = memnew(Label);
|
||||
// A VBoxContainer that contains a dummy Control node to adjust the LinkButton's vertical position.
|
||||
VBoxContainer *spacer_vb = memnew(VBoxContainer);
|
||||
settings_hb->add_child(spacer_vb);
|
||||
|
||||
Control *v_spacer = memnew(Control);
|
||||
spacer_vb->add_child(v_spacer);
|
||||
|
||||
version_btn = memnew(LinkButton);
|
||||
String hash = String(VERSION_HASH);
|
||||
if (hash.length() != 0) {
|
||||
hash = "." + hash.left(9);
|
||||
}
|
||||
version_label->set_text("v" VERSION_FULL_BUILD "" + hash);
|
||||
version_label->set_self_modulate(Color(1, 1, 1, 0.6));
|
||||
version_label->set_align(Label::ALIGN_CENTER);
|
||||
settings_hb->add_child(version_label);
|
||||
version_btn->set_text("v" VERSION_FULL_BUILD + hash);
|
||||
// Fade the version label to be less prominent, but still readable.
|
||||
version_btn->set_self_modulate(Color(1, 1, 1, 0.6));
|
||||
version_btn->set_underline_mode(LinkButton::UNDERLINE_MODE_ON_HOVER);
|
||||
version_btn->set_tooltip(TTR("Click to copy."));
|
||||
version_btn->connect("pressed", callable_mp(this, &ProjectManager::_version_button_pressed));
|
||||
spacer_vb->add_child(version_btn);
|
||||
|
||||
// Add a small horizontal spacer between the version and language buttons
|
||||
// to distinguish them.
|
||||
Control *h_spacer = memnew(Control);
|
||||
settings_hb->add_child(h_spacer);
|
||||
|
||||
language_btn = memnew(OptionButton);
|
||||
language_btn->set_flat(true);
|
||||
|
@ -89,6 +89,7 @@ class ProjectManager : public Control {
|
||||
ProjectDialog *npdialog;
|
||||
|
||||
OptionButton *language_btn;
|
||||
LinkButton *version_btn;
|
||||
|
||||
void _open_asset_library();
|
||||
void _scan_projects();
|
||||
@ -123,6 +124,7 @@ class ProjectManager : public Control {
|
||||
void _unhandled_key_input(const Ref<InputEvent> &p_ev);
|
||||
void _files_dropped(PackedStringArray p_files, int p_screen);
|
||||
|
||||
void _version_button_pressed();
|
||||
void _on_order_option_changed(int p_idx);
|
||||
void _on_tab_changed(int p_tab);
|
||||
void _on_search_term_changed(const String &p_term);
|
||||
|
Loading…
Reference in New Issue
Block a user