LibGUI: Tooltip no longer exceeds screen width, now truncates
This commit is contained in:
parent
d1d1f4f251
commit
f0e9fd09b4
Notes:
sideshowbarker
2024-07-18 16:59:47 +09:00
Author: https://github.com/matthewbjones Commit: https://github.com/SerenityOS/serenity/commit/f0e9fd09b45 Pull-request: https://github.com/SerenityOS/serenity/pull/7707
1 changed files with 9 additions and 1 deletions
|
@ -27,7 +27,13 @@ public:
|
|||
void set_tooltip(const String& tooltip)
|
||||
{
|
||||
m_label->set_text(Gfx::parse_ampersand_string(tooltip));
|
||||
set_rect(rect().x(), rect().y(), m_label->min_width() + 10, m_label->font().glyph_height() + 8);
|
||||
int tooltip_width = m_label->min_width() + 10;
|
||||
|
||||
Gfx::IntRect desktop_rect = Desktop::the().rect();
|
||||
if (tooltip_width > desktop_rect.width())
|
||||
tooltip_width = desktop_rect.width();
|
||||
|
||||
set_rect(rect().x(), rect().y(), tooltip_width, m_label->font().glyph_height() + 8);
|
||||
}
|
||||
|
||||
private:
|
||||
|
@ -196,6 +202,8 @@ void Application::tooltip_show_timer_did_fire()
|
|||
if (adjusted_pos.y() + m_tooltip_window->height() >= desktop_rect.height() - margin) {
|
||||
adjusted_pos = adjusted_pos.translated(0, -(m_tooltip_window->height() * 2));
|
||||
}
|
||||
if (adjusted_pos.x() < 0)
|
||||
adjusted_pos.set_x(0);
|
||||
|
||||
m_tooltip_window->move_to(adjusted_pos);
|
||||
m_tooltip_window->show();
|
||||
|
|
Loading…
Add table
Reference in a new issue