summaryrefslogtreecommitdiff
path: root/Libraries/LibDraw
diff options
context:
space:
mode:
authorAndreas Kling <awesomekling@gmail.com>2019-08-14 20:31:46 +0200
committerAndreas Kling <awesomekling@gmail.com>2019-08-14 20:31:46 +0200
commitb777f740a40a02e9a593da385b7e656da0925707 (patch)
treeb5cf9ac8048c8cb008750e99499bd4a30e0701ce /Libraries/LibDraw
parentf9b8a18fae316479033616354add908c3f2d27ca (diff)
downloadserenity-b777f740a40a02e9a593da385b7e656da0925707.zip
StylePainter: Move progress bar painting from GProgressBar to here
We need to be able to paint progress bars without having a widget. :^)
Diffstat (limited to 'Libraries/LibDraw')
-rw-r--r--Libraries/LibDraw/StylePainter.cpp29
-rw-r--r--Libraries/LibDraw/StylePainter.h1
2 files changed, 30 insertions, 0 deletions
diff --git a/Libraries/LibDraw/StylePainter.cpp b/Libraries/LibDraw/StylePainter.cpp
index 70971b77cf..8ef6bbabc3 100644
--- a/Libraries/LibDraw/StylePainter.cpp
+++ b/Libraries/LibDraw/StylePainter.cpp
@@ -226,3 +226,32 @@ void StylePainter::paint_window_frame(Painter& painter, const Rect& rect)
painter.draw_line(rect.bottom_left().translated(1, -1), rect.bottom_right().translated(-1, -1), mid_shade);
painter.draw_line(rect.bottom_left().translated(2, -2), rect.bottom_right().translated(-2, -2), base_color);
}
+
+void StylePainter::paint_progress_bar(Painter& painter, const Rect& rect, int min, int max, int value, const StringView& text)
+{
+ // First we fill the entire widget with the gradient. This incurs a bit of
+ // overdraw but ensures a consistent look throughout the progression.
+ Color start_color(110, 34, 9);
+ Color end_color(244, 202, 158);
+ painter.fill_rect_with_gradient(rect, start_color, end_color);
+
+ if (!text.is_null()) {
+ painter.draw_text(rect.translated(1, 1), text, TextAlignment::Center, Color::Black);
+ painter.draw_text(rect, text, TextAlignment::Center, Color::White);
+ }
+
+ float range_size = max - min;
+ float progress = (value - min) / range_size;
+
+ // Then we carve out a hole in the remaining part of the widget.
+ // We draw the text a third time, clipped and inverse, for sharp contrast.
+ float progress_width = progress * rect.width();
+ Rect hole_rect { (int)progress_width, 0, (int)(rect.width() - progress_width), rect.height() };
+ hole_rect.move_by(rect.location());
+ PainterStateSaver saver(painter);
+ painter.fill_rect(hole_rect, Color::White);
+
+ painter.add_clip_rect(hole_rect);
+ if (!text.is_null())
+ painter.draw_text(rect.translated(0, 0), text, TextAlignment::Center, Color::Black);
+}
diff --git a/Libraries/LibDraw/StylePainter.h b/Libraries/LibDraw/StylePainter.h
index 6bc85251ab..82bf8b0b24 100644
--- a/Libraries/LibDraw/StylePainter.h
+++ b/Libraries/LibDraw/StylePainter.h
@@ -30,6 +30,7 @@ public:
static void paint_surface(Painter&, const Rect&, bool paint_vertical_lines = true, bool paint_top_line = true);
static void paint_frame(Painter&, const Rect&, FrameShape, FrameShadow, int thickness, bool skip_vertical_lines = false);
static void paint_window_frame(Painter&, const Rect&);
+ static void paint_progress_bar(Painter&, const Rect&, int min, int max, int value, const StringView& text = {});
static Color hover_highlight_color() { return Color::from_rgb(0xe6e5e2); }
};