mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-09-29 16:21:29 +00:00
Mandelbrot: Allow panning with the arrow keys
This commit is contained in:
parent
0f33d2a36d
commit
52340dc78a
Notes:
sideshowbarker
2024-07-17 01:28:15 +09:00
Author: https://github.com/ronak69 Commit: https://github.com/SerenityOS/serenity/commit/52340dc78a Pull-request: https://github.com/SerenityOS/serenity/pull/22457 Reviewed-by: https://github.com/Hendiadyoin1 Reviewed-by: https://github.com/LucasChollet ✅ Reviewed-by: https://github.com/nico
|
@ -233,6 +233,8 @@ private:
|
||||||
Mandelbrot() = default;
|
Mandelbrot() = default;
|
||||||
|
|
||||||
virtual void paint_event(GUI::PaintEvent&) override;
|
virtual void paint_event(GUI::PaintEvent&) override;
|
||||||
|
virtual void keydown_event(GUI::KeyEvent& event) override;
|
||||||
|
virtual void keyup_event(GUI::KeyEvent& event) override;
|
||||||
virtual void mousedown_event(GUI::MouseEvent& event) override;
|
virtual void mousedown_event(GUI::MouseEvent& event) override;
|
||||||
virtual void mousemove_event(GUI::MouseEvent& event) override;
|
virtual void mousemove_event(GUI::MouseEvent& event) override;
|
||||||
virtual void mouseup_event(GUI::MouseEvent& event) override;
|
virtual void mouseup_event(GUI::MouseEvent& event) override;
|
||||||
|
@ -298,6 +300,44 @@ void Mandelbrot::paint_event(GUI::PaintEvent& event)
|
||||||
painter.draw_rect(Gfx::IntRect::from_two_points(m_selection_start, m_selection_end), Color::Blue);
|
painter.draw_rect(Gfx::IntRect::from_two_points(m_selection_start, m_selection_end), Color::Blue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Mandelbrot::keydown_event(GUI::KeyEvent& event)
|
||||||
|
{
|
||||||
|
switch (event.key()) {
|
||||||
|
case KeyCode::Key_Left:
|
||||||
|
m_set.pan_by(Gfx::IntPoint { 10, 0 });
|
||||||
|
break;
|
||||||
|
case KeyCode::Key_Right:
|
||||||
|
m_set.pan_by(Gfx::IntPoint { -10, 0 });
|
||||||
|
break;
|
||||||
|
case KeyCode::Key_Up:
|
||||||
|
m_set.pan_by(Gfx::IntPoint { 0, 10 });
|
||||||
|
break;
|
||||||
|
case KeyCode::Key_Down:
|
||||||
|
m_set.pan_by(Gfx::IntPoint { 0, -10 });
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
GUI::Widget::keydown_event(event);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_panning = true;
|
||||||
|
update();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Mandelbrot::keyup_event(GUI::KeyEvent& event)
|
||||||
|
{
|
||||||
|
switch (event.key()) {
|
||||||
|
case KeyCode::Key_Left:
|
||||||
|
case KeyCode::Key_Right:
|
||||||
|
case KeyCode::Key_Up:
|
||||||
|
case KeyCode::Key_Down:
|
||||||
|
m_panning = false;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
GUI::Widget::keydown_event(event);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Mandelbrot::mousedown_event(GUI::MouseEvent& event)
|
void Mandelbrot::mousedown_event(GUI::MouseEvent& event)
|
||||||
{
|
{
|
||||||
if (event.button() == GUI::MouseButton::Primary) {
|
if (event.button() == GUI::MouseButton::Primary) {
|
||||||
|
|
Loading…
Reference in a new issue