summaryrefslogtreecommitdiff
path: root/LibGUI/GButton.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'LibGUI/GButton.cpp')
-rw-r--r--LibGUI/GButton.cpp50
1 files changed, 36 insertions, 14 deletions
diff --git a/LibGUI/GButton.cpp b/LibGUI/GButton.cpp
index 7496042fed..b78f0358fd 100644
--- a/LibGUI/GButton.cpp
+++ b/LibGUI/GButton.cpp
@@ -2,6 +2,7 @@
#include <LibGUI/GPainter.h>
#include <SharedGraphics/StylePainter.h>
#include <AK/StringBuilder.h>
+#include <LibGUI/GAction.h>
//#define GBUTTON_DEBUG
@@ -12,6 +13,8 @@ GButton::GButton(GWidget* parent)
GButton::~GButton()
{
+ if (m_action)
+ m_action->unregister_button({ }, *this);
}
void GButton::set_caption(const String& caption)
@@ -35,7 +38,7 @@ void GButton::paint_event(GPaintEvent& event)
GPainter painter(*this);
painter.add_clip_rect(event.rect());
- StylePainter::paint_button(painter, rect(), m_button_style, m_being_pressed, m_hovered, m_checkable && m_checked);
+ StylePainter::paint_button(painter, rect(), m_button_style, m_being_pressed, m_hovered, m_checkable && m_checked, is_enabled());
if (m_caption.is_empty() && !m_icon)
return;
@@ -46,8 +49,12 @@ void GButton::paint_event(GPaintEvent& event)
content_rect.move_by(1, 1);
icon_location.move_by(1, 1);
}
- if (m_icon)
- painter.blit(icon_location, *m_icon, m_icon->rect());
+ if (m_icon) {
+ if (is_enabled())
+ painter.blit(icon_location, *m_icon, m_icon->rect());
+ else
+ painter.blit_dimmed(icon_location, *m_icon, m_icon->rect());
+ }
auto& font = (m_checkable && m_checked) ? Font::default_bold_font() : this->font();
painter.draw_text(content_rect, m_caption, font, text_alignment(), foreground_color(), TextElision::Right);
}
@@ -55,10 +62,12 @@ void GButton::paint_event(GPaintEvent& event)
void GButton::mousemove_event(GMouseEvent& event)
{
if (event.buttons() == GMouseButton::Left) {
- bool being_pressed = rect().contains(event.position());
- if (being_pressed != m_being_pressed) {
- m_being_pressed = being_pressed;
- update();
+ if (is_enabled()) {
+ bool being_pressed = rect().contains(event.position());
+ if (being_pressed != m_being_pressed) {
+ m_being_pressed = being_pressed;
+ update();
+ }
}
}
GWidget::mousemove_event(event);
@@ -70,14 +79,18 @@ void GButton::mousedown_event(GMouseEvent& event)
dbgprintf("GButton::mouse_down_event: x=%d, y=%d, button=%u\n", event.x(), event.y(), (unsigned)event.button());
#endif
if (event.button() == GMouseButton::Left) {
- m_being_pressed = true;
- update();
+ if (is_enabled()) {
+ m_being_pressed = true;
+ update();
+ }
}
GWidget::mousedown_event(event);
}
void GButton::click()
{
+ if (!is_enabled())
+ return;
if (on_click)
on_click(*this);
}
@@ -88,11 +101,13 @@ void GButton::mouseup_event(GMouseEvent& event)
dbgprintf("GButton::mouse_up_event: x=%d, y=%d, button=%u\n", event.x(), event.y(), (unsigned)event.button());
#endif
if (event.button() == GMouseButton::Left) {
- bool was_being_pressed = m_being_pressed;
- m_being_pressed = false;
- update();
- if (was_being_pressed)
- click();
+ if (is_enabled()) {
+ bool was_being_pressed = m_being_pressed;
+ m_being_pressed = false;
+ update();
+ if (was_being_pressed)
+ click();
+ }
}
GWidget::mouseup_event(event);
}
@@ -108,3 +123,10 @@ void GButton::leave_event(CEvent&)
m_hovered = false;
update();
}
+
+void GButton::set_action(GAction& action)
+{
+ m_action = action.make_weak_ptr();
+ action.register_button({ }, *this);
+ set_enabled(action.is_enabled());
+}