mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 15:07:45 +00:00
PaintBrush: Use draw_line() when drawing continuously.
This commit is contained in:
parent
6aa4cb6740
commit
642c82fbff
2 changed files with 15 additions and 3 deletions
|
@ -30,10 +30,13 @@ void PaintableWidget::mousedown_event(GMouseEvent& event)
|
||||||
GPainter painter(*m_bitmap);
|
GPainter painter(*m_bitmap);
|
||||||
painter.set_pixel(event.position(), Color::Black);
|
painter.set_pixel(event.position(), Color::Black);
|
||||||
update({ event.position(), { 1, 1 } });
|
update({ event.position(), { 1, 1 } });
|
||||||
|
m_last_drawing_event_position = event.position();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PaintableWidget::mouseup_event(GMouseEvent&)
|
void PaintableWidget::mouseup_event(GMouseEvent& event)
|
||||||
{
|
{
|
||||||
|
if (event.button() == GMouseButton::Left)
|
||||||
|
m_last_drawing_event_position = { -1, -1 };
|
||||||
}
|
}
|
||||||
|
|
||||||
void PaintableWidget::mousemove_event(GMouseEvent& event)
|
void PaintableWidget::mousemove_event(GMouseEvent& event)
|
||||||
|
@ -43,7 +46,15 @@ void PaintableWidget::mousemove_event(GMouseEvent& event)
|
||||||
|
|
||||||
if (event.buttons() & GMouseButton::Left) {
|
if (event.buttons() & GMouseButton::Left) {
|
||||||
GPainter painter(*m_bitmap);
|
GPainter painter(*m_bitmap);
|
||||||
painter.set_pixel(event.position(), Color::Black);
|
|
||||||
update({ event.position(), { 1, 1 } });
|
if (m_last_drawing_event_position != Point(-1, -1)) {
|
||||||
|
painter.draw_line(m_last_drawing_event_position, event.position(), Color::Black);
|
||||||
|
update();
|
||||||
|
} else {
|
||||||
|
painter.set_pixel(event.position(), Color::Black);
|
||||||
|
update({ event.position(), { 1, 1 } });
|
||||||
|
}
|
||||||
|
|
||||||
|
m_last_drawing_event_position = event.position();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,5 +15,6 @@ private:
|
||||||
virtual void mouseup_event(GMouseEvent&) override;
|
virtual void mouseup_event(GMouseEvent&) override;
|
||||||
virtual void mousemove_event(GMouseEvent&) override;
|
virtual void mousemove_event(GMouseEvent&) override;
|
||||||
|
|
||||||
|
Point m_last_drawing_event_position { -1, -1 };
|
||||||
RetainPtr<GraphicsBitmap> m_bitmap;
|
RetainPtr<GraphicsBitmap> m_bitmap;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue