mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-04-21 12:05:15 +00:00
LibGUI: Move tooltip window rects if they don't end up on screen
This makes the quick launch button tooltips actually readable. :^)
This commit is contained in:
parent
e1862fe2f5
commit
2d18fc8052
Notes:
sideshowbarker
2024-07-19 10:57:35 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/2d18fc8052e
1 changed files with 14 additions and 1 deletions
|
@ -1,5 +1,6 @@
|
|||
#include <LibGUI/GAction.h>
|
||||
#include <LibGUI/GApplication.h>
|
||||
#include <LibGUI/GDesktop.h>
|
||||
#include <LibGUI/GLabel.h>
|
||||
#include <LibGUI/GMenuBar.h>
|
||||
#include <LibGUI/GPainter.h>
|
||||
|
@ -106,7 +107,19 @@ void GApplication::show_tooltip(const StringView& tooltip, const Point& screen_l
|
|||
m_tooltip_window->set_double_buffering_enabled(false);
|
||||
}
|
||||
m_tooltip_window->set_tooltip(tooltip);
|
||||
m_tooltip_window->move_to(screen_location);
|
||||
|
||||
Rect desktop_rect = GDesktop::the().rect();
|
||||
|
||||
const int margin = 30;
|
||||
Point adjusted_pos = screen_location;
|
||||
if (adjusted_pos.x() + m_tooltip_window->width() >= desktop_rect.width() - margin) {
|
||||
adjusted_pos = adjusted_pos.translated(-m_tooltip_window->width(), 0);
|
||||
}
|
||||
if (adjusted_pos.y() + m_tooltip_window->height() >= desktop_rect.height() - margin) {
|
||||
adjusted_pos = adjusted_pos.translated(0, -(m_tooltip_window->height() * 2));
|
||||
}
|
||||
|
||||
m_tooltip_window->move_to(adjusted_pos);
|
||||
m_tooltip_window->show();
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue