1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-26 00:37:35 +00:00

WindowServer: Allow clicking on windows in the window switcher

You can now switch between windows using your mouse to click them in
the window switcher. :^)
This commit is contained in:
Andreas Kling 2020-02-11 18:28:45 +01:00
parent 2ba06662b6
commit ba135dc0c0
2 changed files with 56 additions and 18 deletions

View file

@ -71,6 +71,24 @@ Window* WindowSwitcher::selected_window()
return m_windows[m_selected_index].ptr();
}
void WindowSwitcher::event(Core::Event& event)
{
if (!static_cast<Event&>(event).is_mouse_event())
return;
auto& mouse_event = static_cast<MouseEvent&>(event);
if (mouse_event.type() == Event::MouseDown) {
for (int i = 0; i < m_windows.size(); ++i) {
auto item_rect = this->item_rect(i);
if (item_rect.contains(mouse_event.position())) {
select_window_at_index(i);
break;
}
}
}
event.accept();
}
void WindowSwitcher::on_key_event(const KeyEvent& event)
{
if (event.type() == Event::KeyUp) {
@ -94,21 +112,40 @@ void WindowSwitcher::on_key_event(const KeyEvent& event)
}
ASSERT(!m_windows.is_empty());
int new_selected_index;
if (!event.shift()) {
m_selected_index = (m_selected_index + 1) % m_windows.size();
new_selected_index = (m_selected_index + 1) % m_windows.size();
} else {
m_selected_index = (m_selected_index - 1) % m_windows.size();
if (m_selected_index < 0)
m_selected_index = m_windows.size() - 1;
new_selected_index = (m_selected_index - 1) % m_windows.size();
if (new_selected_index < 0)
new_selected_index = m_windows.size() - 1;
}
ASSERT(m_selected_index < m_windows.size());
auto* highlight_window = m_windows.at(m_selected_index).ptr();
ASSERT(new_selected_index < m_windows.size());
select_window_at_index(new_selected_index);
}
void WindowSwitcher::select_window_at_index(int index)
{
m_selected_index = index;
auto* highlight_window = m_windows.at(index).ptr();
ASSERT(highlight_window);
WindowManager::the().set_highlight_window(highlight_window);
draw();
WindowManager::the().invalidate(m_rect);
}
Gfx::Rect WindowSwitcher::item_rect(int index) const
{
return {
padding(),
padding() + index * item_height(),
m_rect.width() - padding() * 2,
item_height()
};
}
void WindowSwitcher::draw()
{
auto palette = WindowManager::the().palette();
@ -117,12 +154,7 @@ void WindowSwitcher::draw()
painter.draw_rect({ {}, m_rect.size() }, palette.threed_shadow2());
for (int index = 0; index < m_windows.size(); ++index) {
auto& window = *m_windows.at(index);
Gfx::Rect item_rect {
padding(),
padding() + index * item_height(),
m_rect.width() - padding() * 2,
item_height()
};
auto item_rect = this->item_rect(index);
Color text_color;
Color rect_text_color;
if (index == m_selected_index) {