mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 09:47:35 +00:00
PaintBrush: Show which line thickness is selected in the tool menus
Put each tool's thickness altering actions into a GActionGroup and make them mutually exclusive so we get that nice radio button appearance. This all feel very clunky and we should move towards having something like a "tool settings" pane that gets populated by the currently active tool instead.
This commit is contained in:
parent
07075cd001
commit
1060d59ddd
10 changed files with 87 additions and 61 deletions
|
@ -115,18 +115,21 @@ void EllipseTool::on_contextmenu(GContextMenuEvent& event)
|
||||||
m_mode = Mode::Outline;
|
m_mode = Mode::Outline;
|
||||||
}));
|
}));
|
||||||
m_context_menu->add_separator();
|
m_context_menu->add_separator();
|
||||||
m_context_menu->add_action(GAction::create("1", [this](auto&) {
|
m_thickness_actions.set_exclusive(true);
|
||||||
m_thickness = 1;
|
auto insert_action = [&](int size, bool checked = false) {
|
||||||
}));
|
auto action = GAction::create(String::number(size), [this, size](auto& action) {
|
||||||
m_context_menu->add_action(GAction::create("2", [this](auto&) {
|
m_thickness = size;
|
||||||
m_thickness = 2;
|
action.set_checked(true);
|
||||||
}));
|
});
|
||||||
m_context_menu->add_action(GAction::create("3", [this](auto&) {
|
action->set_checkable(true);
|
||||||
m_thickness = 3;
|
action->set_checked(checked);
|
||||||
}));
|
m_thickness_actions.add_action(*action);
|
||||||
m_context_menu->add_action(GAction::create("4", [this](auto&) {
|
m_context_menu->add_action(move(action));
|
||||||
m_thickness = 4;
|
};
|
||||||
}));
|
insert_action(1, true);
|
||||||
|
insert_action(2);
|
||||||
|
insert_action(3);
|
||||||
|
insert_action(4);
|
||||||
}
|
}
|
||||||
m_context_menu->popup(event.screen_position());
|
m_context_menu->popup(event.screen_position());
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
|
|
||||||
#include "Tool.h"
|
#include "Tool.h"
|
||||||
#include <LibDraw/Point.h>
|
#include <LibDraw/Point.h>
|
||||||
|
#include <LibGUI/GActionGroup.h>
|
||||||
|
|
||||||
class GMenu;
|
class GMenu;
|
||||||
class Painter;
|
class Painter;
|
||||||
|
@ -58,5 +59,6 @@ private:
|
||||||
Point m_ellipse_end_position;
|
Point m_ellipse_end_position;
|
||||||
RefPtr<GMenu> m_context_menu;
|
RefPtr<GMenu> m_context_menu;
|
||||||
int m_thickness { 1 };
|
int m_thickness { 1 };
|
||||||
|
GActionGroup m_thickness_actions;
|
||||||
Mode m_mode { Mode::Outline };
|
Mode m_mode { Mode::Outline };
|
||||||
};
|
};
|
||||||
|
|
|
@ -86,18 +86,22 @@ void EraseTool::on_contextmenu(GContextMenuEvent& event)
|
||||||
|
|
||||||
m_context_menu->add_action(eraser_color_toggler);
|
m_context_menu->add_action(eraser_color_toggler);
|
||||||
m_context_menu->add_separator();
|
m_context_menu->add_separator();
|
||||||
m_context_menu->add_action(GAction::create("1", [this](auto&) {
|
|
||||||
m_thickness = 1;
|
m_thickness_actions.set_exclusive(true);
|
||||||
}));
|
auto insert_action = [&](int size, bool checked = false) {
|
||||||
m_context_menu->add_action(GAction::create("2", [this](auto&) {
|
auto action = GAction::create(String::number(size), [this, size](auto& action) {
|
||||||
m_thickness = 2;
|
m_thickness = size;
|
||||||
}));
|
action.set_checked(true);
|
||||||
m_context_menu->add_action(GAction::create("3", [this](auto&) {
|
});
|
||||||
m_thickness = 3;
|
action->set_checkable(true);
|
||||||
}));
|
action->set_checked(checked);
|
||||||
m_context_menu->add_action(GAction::create("4", [this](auto&) {
|
m_thickness_actions.add_action(*action);
|
||||||
m_thickness = 4;
|
m_context_menu->add_action(move(action));
|
||||||
}));
|
};
|
||||||
|
insert_action(1, true);
|
||||||
|
insert_action(2);
|
||||||
|
insert_action(3);
|
||||||
|
insert_action(4);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_context_menu->popup(event.screen_position());
|
m_context_menu->popup(event.screen_position());
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
|
|
||||||
#include "Tool.h"
|
#include "Tool.h"
|
||||||
#include <LibDraw/Point.h>
|
#include <LibDraw/Point.h>
|
||||||
|
#include <LibGUI/GActionGroup.h>
|
||||||
|
|
||||||
class GMenu;
|
class GMenu;
|
||||||
|
|
||||||
|
@ -48,4 +49,5 @@ private:
|
||||||
|
|
||||||
bool m_use_secondary_color { true };
|
bool m_use_secondary_color { true };
|
||||||
int m_thickness { 1 };
|
int m_thickness { 1 };
|
||||||
|
GActionGroup m_thickness_actions;
|
||||||
};
|
};
|
||||||
|
|
|
@ -131,18 +131,21 @@ void LineTool::on_contextmenu(GContextMenuEvent& event)
|
||||||
{
|
{
|
||||||
if (!m_context_menu) {
|
if (!m_context_menu) {
|
||||||
m_context_menu = GMenu::construct();
|
m_context_menu = GMenu::construct();
|
||||||
m_context_menu->add_action(GAction::create("1", [this](auto&) {
|
m_thickness_actions.set_exclusive(true);
|
||||||
m_thickness = 1;
|
auto insert_action = [&](int size, bool checked = false) {
|
||||||
}));
|
auto action = GAction::create(String::number(size), [this, size](auto& action) {
|
||||||
m_context_menu->add_action(GAction::create("2", [this](auto&) {
|
m_thickness = size;
|
||||||
m_thickness = 2;
|
action.set_checked(true);
|
||||||
}));
|
});
|
||||||
m_context_menu->add_action(GAction::create("3", [this](auto&) {
|
action->set_checkable(true);
|
||||||
m_thickness = 3;
|
action->set_checked(checked);
|
||||||
}));
|
m_thickness_actions.add_action(*action);
|
||||||
m_context_menu->add_action(GAction::create("4", [this](auto&) {
|
m_context_menu->add_action(move(action));
|
||||||
m_thickness = 4;
|
};
|
||||||
}));
|
insert_action(1, true);
|
||||||
|
insert_action(2);
|
||||||
|
insert_action(3);
|
||||||
|
insert_action(4);
|
||||||
}
|
}
|
||||||
m_context_menu->popup(event.screen_position());
|
m_context_menu->popup(event.screen_position());
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
|
|
||||||
#include "Tool.h"
|
#include "Tool.h"
|
||||||
#include <LibDraw/Point.h>
|
#include <LibDraw/Point.h>
|
||||||
|
#include <LibGUI/GActionGroup.h>
|
||||||
|
|
||||||
class GMenu;
|
class GMenu;
|
||||||
|
|
||||||
|
@ -51,6 +52,7 @@ private:
|
||||||
Point m_line_start_position;
|
Point m_line_start_position;
|
||||||
Point m_line_end_position;
|
Point m_line_end_position;
|
||||||
RefPtr<GMenu> m_context_menu;
|
RefPtr<GMenu> m_context_menu;
|
||||||
|
GActionGroup m_thickness_actions;
|
||||||
int m_thickness { 1 };
|
int m_thickness { 1 };
|
||||||
bool m_constrain_angle { false };
|
bool m_constrain_angle { false };
|
||||||
};
|
};
|
||||||
|
|
|
@ -77,18 +77,21 @@ void PenTool::on_contextmenu(GContextMenuEvent& event)
|
||||||
{
|
{
|
||||||
if (!m_context_menu) {
|
if (!m_context_menu) {
|
||||||
m_context_menu = GMenu::construct();
|
m_context_menu = GMenu::construct();
|
||||||
m_context_menu->add_action(GAction::create("1", [this](auto&) {
|
m_thickness_actions.set_exclusive(true);
|
||||||
m_thickness = 1;
|
auto insert_action = [&](int size, bool checked = false) {
|
||||||
}));
|
auto action = GAction::create(String::number(size), [this, size](auto& action) {
|
||||||
m_context_menu->add_action(GAction::create("2", [this](auto&) {
|
m_thickness = size;
|
||||||
m_thickness = 2;
|
action.set_checked(true);
|
||||||
}));
|
});
|
||||||
m_context_menu->add_action(GAction::create("3", [this](auto&) {
|
action->set_checkable(true);
|
||||||
m_thickness = 3;
|
action->set_checked(checked);
|
||||||
}));
|
m_thickness_actions.add_action(*action);
|
||||||
m_context_menu->add_action(GAction::create("4", [this](auto&) {
|
m_context_menu->add_action(move(action));
|
||||||
m_thickness = 4;
|
};
|
||||||
}));
|
insert_action(1, true);
|
||||||
|
insert_action(2);
|
||||||
|
insert_action(3);
|
||||||
|
insert_action(4);
|
||||||
}
|
}
|
||||||
m_context_menu->popup(event.screen_position());
|
m_context_menu->popup(event.screen_position());
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
|
|
||||||
#include "Tool.h"
|
#include "Tool.h"
|
||||||
#include <LibDraw/Point.h>
|
#include <LibDraw/Point.h>
|
||||||
|
#include <LibGUI/GActionGroup.h>
|
||||||
|
|
||||||
class GMenu;
|
class GMenu;
|
||||||
|
|
||||||
|
@ -47,4 +48,5 @@ private:
|
||||||
Point m_last_drawing_event_position { -1, -1 };
|
Point m_last_drawing_event_position { -1, -1 };
|
||||||
RefPtr<GMenu> m_context_menu;
|
RefPtr<GMenu> m_context_menu;
|
||||||
int m_thickness { 1 };
|
int m_thickness { 1 };
|
||||||
|
GActionGroup m_thickness_actions;
|
||||||
};
|
};
|
||||||
|
|
|
@ -103,18 +103,21 @@ void SprayTool::on_contextmenu(GContextMenuEvent& event)
|
||||||
{
|
{
|
||||||
if (!m_context_menu) {
|
if (!m_context_menu) {
|
||||||
m_context_menu = GMenu::construct();
|
m_context_menu = GMenu::construct();
|
||||||
m_context_menu->add_action(GAction::create("1", [this](auto&) {
|
m_thickness_actions.set_exclusive(true);
|
||||||
m_thickness = 1;
|
auto insert_action = [&](int size, bool checked = false) {
|
||||||
}));
|
auto action = GAction::create(String::number(size), [this, size](auto& action) {
|
||||||
m_context_menu->add_action(GAction::create("2", [this](auto&) {
|
m_thickness = size;
|
||||||
m_thickness = 2;
|
action.set_checked(true);
|
||||||
}));
|
});
|
||||||
m_context_menu->add_action(GAction::create("3", [this](auto&) {
|
action->set_checkable(true);
|
||||||
m_thickness = 3;
|
action->set_checked(checked);
|
||||||
}));
|
m_thickness_actions.add_action(*action);
|
||||||
m_context_menu->add_action(GAction::create("4", [this](auto&) {
|
m_context_menu->add_action(move(action));
|
||||||
m_thickness = 4;
|
};
|
||||||
}));
|
insert_action(1, true);
|
||||||
|
insert_action(2);
|
||||||
|
insert_action(3);
|
||||||
|
insert_action(4);
|
||||||
}
|
}
|
||||||
m_context_menu->popup(event.screen_position());
|
m_context_menu->popup(event.screen_position());
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,8 +27,9 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "Tool.h"
|
#include "Tool.h"
|
||||||
#include <LibGUI/GPainter.h>
|
|
||||||
#include <LibCore/CTimer.h>
|
#include <LibCore/CTimer.h>
|
||||||
|
#include <LibGUI/GActionGroup.h>
|
||||||
|
#include <LibGUI/GPainter.h>
|
||||||
|
|
||||||
class GMenu;
|
class GMenu;
|
||||||
|
|
||||||
|
@ -49,5 +50,6 @@ private:
|
||||||
Point m_last_pos;
|
Point m_last_pos;
|
||||||
Color m_color;
|
Color m_color;
|
||||||
RefPtr<GMenu> m_context_menu;
|
RefPtr<GMenu> m_context_menu;
|
||||||
|
GActionGroup m_thickness_actions;
|
||||||
int m_thickness { 1 };
|
int m_thickness { 1 };
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue