Merge pull request #80555 from GrammAcc/fix-80507
AssetLib: Fix long plugin names breaking the UI
This commit is contained in:
commit
2d6cee48f6
4 changed files with 30 additions and 2 deletions
|
@ -64,6 +64,21 @@ void EditorAssetLibraryItem::configure(const String &p_title, int p_asset_id, co
|
||||||
price->set_text(p_cost);
|
price->set_text(p_cost);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: Refactor this method to use the TextServer.
|
||||||
|
void EditorAssetLibraryItem::clamp_width(int p_max_width) {
|
||||||
|
int text_pixel_width = title->get_button_font().ptr()->get_string_size(title->get_text()).x * EDSCALE;
|
||||||
|
|
||||||
|
String full_text = title->get_text();
|
||||||
|
title->set_tooltip_text(full_text);
|
||||||
|
|
||||||
|
if (text_pixel_width > p_max_width) {
|
||||||
|
// Truncate title text to within the current column width.
|
||||||
|
int max_length = p_max_width / (text_pixel_width / full_text.length());
|
||||||
|
String truncated_text = full_text.left(max_length - 3) + "...";
|
||||||
|
title->set_text(truncated_text);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void EditorAssetLibraryItem::set_image(int p_type, int p_index, const Ref<Texture2D> &p_image) {
|
void EditorAssetLibraryItem::set_image(int p_type, int p_index, const Ref<Texture2D> &p_image) {
|
||||||
ERR_FAIL_COND(p_type != EditorAssetLibrary::IMAGE_QUEUE_ICON);
|
ERR_FAIL_COND(p_type != EditorAssetLibrary::IMAGE_QUEUE_ICON);
|
||||||
ERR_FAIL_COND(p_index != 0);
|
ERR_FAIL_COND(p_index != 0);
|
||||||
|
@ -1008,11 +1023,11 @@ HBoxContainer *EditorAssetLibrary::_make_pages(int p_page, int p_page_count, int
|
||||||
}
|
}
|
||||||
|
|
||||||
//do the mario
|
//do the mario
|
||||||
int from = p_page - 5;
|
int from = p_page - (5 / EDSCALE);
|
||||||
if (from < 0) {
|
if (from < 0) {
|
||||||
from = 0;
|
from = 0;
|
||||||
}
|
}
|
||||||
int to = from + 10;
|
int to = from + (10 / EDSCALE);
|
||||||
if (to > p_page_count) {
|
if (to > p_page_count) {
|
||||||
to = p_page_count;
|
to = p_page_count;
|
||||||
}
|
}
|
||||||
|
@ -1279,6 +1294,7 @@ void EditorAssetLibrary::_http_request_completed(int p_status, int p_code, const
|
||||||
EditorAssetLibraryItem *item = memnew(EditorAssetLibraryItem);
|
EditorAssetLibraryItem *item = memnew(EditorAssetLibraryItem);
|
||||||
asset_items->add_child(item);
|
asset_items->add_child(item);
|
||||||
item->configure(r["title"], r["asset_id"], category_map[r["category_id"]], r["category_id"], r["author"], r["author_id"], r["cost"]);
|
item->configure(r["title"], r["asset_id"], category_map[r["category_id"]], r["category_id"], r["author"], r["author_id"], r["cost"]);
|
||||||
|
item->clamp_width(asset_items_column_width);
|
||||||
item->connect("asset_selected", callable_mp(this, &EditorAssetLibrary::_select_asset));
|
item->connect("asset_selected", callable_mp(this, &EditorAssetLibrary::_select_asset));
|
||||||
item->connect("author_selected", callable_mp(this, &EditorAssetLibrary::_select_author));
|
item->connect("author_selected", callable_mp(this, &EditorAssetLibrary::_select_author));
|
||||||
item->connect("category_selected", callable_mp(this, &EditorAssetLibrary::_select_category));
|
item->connect("category_selected", callable_mp(this, &EditorAssetLibrary::_select_category));
|
||||||
|
@ -1413,6 +1429,8 @@ void EditorAssetLibrary::_update_asset_items_columns() {
|
||||||
if (new_columns != asset_items->get_columns()) {
|
if (new_columns != asset_items->get_columns()) {
|
||||||
asset_items->set_columns(new_columns);
|
asset_items->set_columns(new_columns);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
asset_items_column_width = (get_size().x / new_columns) - (100 * EDSCALE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditorAssetLibrary::disable_community_support() {
|
void EditorAssetLibrary::disable_community_support() {
|
||||||
|
|
|
@ -80,6 +80,8 @@ protected:
|
||||||
public:
|
public:
|
||||||
void configure(const String &p_title, int p_asset_id, const String &p_category, int p_category_id, const String &p_author, int p_author_id, const String &p_cost);
|
void configure(const String &p_title, int p_asset_id, const String &p_category, int p_category_id, const String &p_author, int p_author_id, const String &p_cost);
|
||||||
|
|
||||||
|
void clamp_width(int p_max_width);
|
||||||
|
|
||||||
EditorAssetLibraryItem();
|
EditorAssetLibraryItem();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -305,6 +307,8 @@ class EditorAssetLibrary : public PanelContainer {
|
||||||
|
|
||||||
void _install_external_asset(String p_zip_path, String p_title);
|
void _install_external_asset(String p_zip_path, String p_title);
|
||||||
|
|
||||||
|
int asset_items_column_width = 0;
|
||||||
|
|
||||||
void _update_asset_items_columns();
|
void _update_asset_items_columns();
|
||||||
|
|
||||||
friend class EditorAssetLibraryItemDescription;
|
friend class EditorAssetLibraryItemDescription;
|
||||||
|
|
|
@ -130,6 +130,10 @@ LinkButton::UnderlineMode LinkButton::get_underline_mode() const {
|
||||||
return underline_mode;
|
return underline_mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Ref<Font> LinkButton::get_button_font() const {
|
||||||
|
return theme_cache.font;
|
||||||
|
}
|
||||||
|
|
||||||
void LinkButton::pressed() {
|
void LinkButton::pressed() {
|
||||||
if (uri.is_empty()) {
|
if (uri.is_empty()) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -104,6 +104,8 @@ public:
|
||||||
void set_underline_mode(UnderlineMode p_underline_mode);
|
void set_underline_mode(UnderlineMode p_underline_mode);
|
||||||
UnderlineMode get_underline_mode() const;
|
UnderlineMode get_underline_mode() const;
|
||||||
|
|
||||||
|
Ref<Font> get_button_font() const;
|
||||||
|
|
||||||
LinkButton(const String &p_text = String());
|
LinkButton(const String &p_text = String());
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue