diff options
author | 2020-01-04 14:28:29 +0100 | |
---|---|---|
committer | 2020-01-04 14:28:29 +0100 | |
commit | 8311500ac03a95927022d8eec8178ba7d87b0010 (patch) | |
tree | 2423a758d4d639d22170b7dbc8413a246f448584 /wgpu | |
parent | e4de2132e993ec6656da52063faf09bcfb978207 (diff) | |
parent | 43de28ae1515ace34758656f228444898459d85b (diff) | |
download | iced-8311500ac03a95927022d8eec8178ba7d87b0010.tar.gz iced-8311500ac03a95927022d8eec8178ba7d87b0010.tar.bz2 iced-8311500ac03a95927022d8eec8178ba7d87b0010.zip |
Merge pull request #141 from Songtronix/songtronix/progressbar-widget
Progress bar widget
Diffstat (limited to 'wgpu')
-rw-r--r-- | wgpu/src/renderer/widget.rs | 1 | ||||
-rw-r--r-- | wgpu/src/renderer/widget/progress_bar.rs | 47 |
2 files changed, 48 insertions, 0 deletions
diff --git a/wgpu/src/renderer/widget.rs b/wgpu/src/renderer/widget.rs index f82631d5..32187c10 100644 --- a/wgpu/src/renderer/widget.rs +++ b/wgpu/src/renderer/widget.rs @@ -2,6 +2,7 @@ mod button; mod checkbox; mod column; mod image; +mod progress_bar; mod radio; mod row; mod scrollable; diff --git a/wgpu/src/renderer/widget/progress_bar.rs b/wgpu/src/renderer/widget/progress_bar.rs new file mode 100644 index 00000000..8ed4bab7 --- /dev/null +++ b/wgpu/src/renderer/widget/progress_bar.rs @@ -0,0 +1,47 @@ +use crate::{Primitive, Renderer}; +use iced_native::{progress_bar, Background, Color, MouseCursor, Rectangle}; + +impl progress_bar::Renderer for Renderer { + const DEFAULT_HEIGHT: u16 = 30; + + fn draw( + &self, + bounds: Rectangle, + range: std::ops::RangeInclusive<f32>, + value: f32, + background: Option<Background>, + active_color: Option<Color>, + ) -> Self::Output { + let (range_start, range_end) = range.into_inner(); + let active_progress_width = bounds.width + * ((value - range_start) / (range_end - range_start).max(1.0)); + + let background = Primitive::Group { + primitives: vec![Primitive::Quad { + bounds: Rectangle { ..bounds }, + background: background + .unwrap_or(Background::Color([0.6, 0.6, 0.6].into())) + .into(), + border_radius: 5, + }], + }; + + let active_progress = Primitive::Quad { + bounds: Rectangle { + width: active_progress_width, + ..bounds + }, + background: Background::Color( + active_color.unwrap_or([0.0, 0.95, 0.0].into()), + ), + border_radius: 5, + }; + + ( + Primitive::Group { + primitives: vec![background, active_progress], + }, + MouseCursor::OutOfBounds, + ) + } +} |