mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 02:07:35 +00:00
PixelPaint: Pass doubleclick events to tools
This commit is contained in:
parent
7b163573e6
commit
20f6485311
3 changed files with 11 additions and 0 deletions
|
@ -356,6 +356,14 @@ void ImageEditor::mousedown_event(GUI::MouseEvent& event)
|
||||||
m_active_tool->on_mousedown(m_active_layer.ptr(), tool_event);
|
m_active_tool->on_mousedown(m_active_layer.ptr(), tool_event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ImageEditor::doubleclick_event(GUI::MouseEvent& event)
|
||||||
|
{
|
||||||
|
auto layer_event = m_active_layer ? event_adjusted_for_layer(event, *m_active_layer) : event;
|
||||||
|
auto image_event = event_with_pan_and_scale_applied(event);
|
||||||
|
Tool::MouseEvent tool_event(Tool::MouseEvent::Action::DoubleClick, layer_event, image_event, event);
|
||||||
|
m_active_tool->on_doubleclick(m_active_layer.ptr(), tool_event);
|
||||||
|
}
|
||||||
|
|
||||||
void ImageEditor::mousemove_event(GUI::MouseEvent& event)
|
void ImageEditor::mousemove_event(GUI::MouseEvent& event)
|
||||||
{
|
{
|
||||||
m_mouse_position = event.position();
|
m_mouse_position = event.position();
|
||||||
|
|
|
@ -125,6 +125,7 @@ private:
|
||||||
|
|
||||||
virtual void paint_event(GUI::PaintEvent&) override;
|
virtual void paint_event(GUI::PaintEvent&) override;
|
||||||
virtual void second_paint_event(GUI::PaintEvent&) override;
|
virtual void second_paint_event(GUI::PaintEvent&) override;
|
||||||
|
virtual void doubleclick_event(GUI::MouseEvent&) override;
|
||||||
virtual void mousedown_event(GUI::MouseEvent&) override;
|
virtual void mousedown_event(GUI::MouseEvent&) override;
|
||||||
virtual void mousemove_event(GUI::MouseEvent&) override;
|
virtual void mousemove_event(GUI::MouseEvent&) override;
|
||||||
virtual void mouseup_event(GUI::MouseEvent&) override;
|
virtual void mouseup_event(GUI::MouseEvent&) override;
|
||||||
|
|
|
@ -27,6 +27,7 @@ public:
|
||||||
class MouseEvent {
|
class MouseEvent {
|
||||||
public:
|
public:
|
||||||
enum class Action {
|
enum class Action {
|
||||||
|
DoubleClick,
|
||||||
MouseDown,
|
MouseDown,
|
||||||
MouseMove,
|
MouseMove,
|
||||||
MouseUp
|
MouseUp
|
||||||
|
@ -53,6 +54,7 @@ public:
|
||||||
GUI::MouseEvent& m_raw_event;
|
GUI::MouseEvent& m_raw_event;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
virtual void on_doubleclick(Layer*, MouseEvent&) { }
|
||||||
virtual void on_mousedown(Layer*, MouseEvent&) { }
|
virtual void on_mousedown(Layer*, MouseEvent&) { }
|
||||||
virtual void on_mousemove(Layer*, MouseEvent&) { }
|
virtual void on_mousemove(Layer*, MouseEvent&) { }
|
||||||
virtual void on_mouseup(Layer*, MouseEvent&) { }
|
virtual void on_mouseup(Layer*, MouseEvent&) { }
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue