Wire up styling to Slider in iced_native

This commit is contained in:
Héctor Ramón Jiménez 2021-10-20 15:50:42 +07:00
parent e00a2e9b2d
commit 11bcb13427
No known key found for this signature in database
GPG key ID: 140CC052C94F138E
9 changed files with 31 additions and 97 deletions

View file

@ -853,7 +853,7 @@ impl Controls {
speed as f32, speed as f32,
Message::SpeedChanged, Message::SpeedChanged,
) )
.style(style::Slider), .style(&style::Slider),
) )
.push(Text::new(format!("x{}", speed)).size(16)); .push(Text::new(format!("x{}", speed)).size(16));

View file

@ -90,7 +90,7 @@ impl Sandbox for Styling {
self.slider_value, self.slider_value,
Message::SliderChanged, Message::SliderChanged,
) )
.style(self.theme); .style(self.theme.into());
let progress_bar = let progress_bar =
ProgressBar::new(0.0..=100.0, self.slider_value).style(self.theme); ProgressBar::new(0.0..=100.0, self.slider_value).style(self.theme);
@ -221,11 +221,11 @@ mod style {
} }
} }
impl From<Theme> for Box<dyn slider::StyleSheet> { impl From<Theme> for &'static dyn slider::StyleSheet {
fn from(theme: Theme) -> Self { fn from(theme: Theme) -> Self {
match theme { match theme {
Theme::Light => Default::default(), Theme::Light => Default::default(),
Theme::Dark => dark::Slider.into(), Theme::Dark => &dark::Slider,
} }
} }
} }

View file

@ -1,13 +1,5 @@
//! Display an interactive selector of a single value from a range of values. //! Display an interactive selector of a single value from a range of values.
//! //!
//! A [`Slider`] has some local [`State`]. //! A [`Slider`] has some local [`State`].
use crate::Renderer;
pub use iced_graphics::slider::{Handle, HandleShape, Style, StyleSheet}; pub use iced_graphics::slider::{Handle, HandleShape, Style, StyleSheet};
pub use iced_native::slider::State; pub use iced_native::slider::{Slider, State};
/// An horizontal bar and a handle that selects a single value from a range of
/// values.
///
/// This is an alias of an `iced_native` slider with an `iced_wgpu::Renderer`.
pub type Slider<'a, T, Message> = iced_native::Slider<'a, T, Message, Renderer>;

View file

@ -1,24 +1,5 @@
//! Display an interactive selector of a single value from a range of values. //! Display an interactive selector of a single value from a range of values.
//! //!
//! A [`Slider`] has some local [`State`]. //! A [`Slider`] has some local [`State`].
use crate::{Backend, Renderer}; pub use iced_native::slider::{Slider, State};
use iced_native::slider;
pub use iced_native::slider::State;
pub use iced_style::slider::{Handle, HandleShape, Style, StyleSheet}; pub use iced_style::slider::{Handle, HandleShape, Style, StyleSheet};
/// An horizontal bar and a handle that selects a single value from a range of
/// values.
///
/// This is an alias of an `iced_native` slider with an `iced_wgpu::Renderer`.
pub type Slider<'a, T, Message, Backend> =
iced_native::Slider<'a, T, Message, Renderer<Backend>>;
impl<B> slider::Renderer for Renderer<B>
where
B: Backend,
{
type Style = Box<dyn StyleSheet>;
const DEFAULT_HEIGHT: u16 = 22;
}

View file

@ -1,14 +1,12 @@
use crate::button;
use crate::checkbox; use crate::checkbox;
use crate::pane_grid; use crate::pane_grid;
use crate::progress_bar; use crate::progress_bar;
use crate::radio; use crate::radio;
use crate::renderer::{self, Renderer}; use crate::renderer::{self, Renderer};
use crate::slider;
use crate::text; use crate::text;
use crate::text_input; use crate::text_input;
use crate::toggler; use crate::toggler;
use crate::{Font, Padding, Point, Rectangle, Size, Vector}; use crate::{Font, Point, Rectangle, Size, Vector};
/// A renderer that does nothing. /// A renderer that does nothing.
/// ///
@ -104,12 +102,6 @@ impl checkbox::Renderer for Null {
const DEFAULT_SPACING: u16 = 15; const DEFAULT_SPACING: u16 = 15;
} }
impl slider::Renderer for Null {
type Style = ();
const DEFAULT_HEIGHT: u16 = 30;
}
impl progress_bar::Renderer for Null { impl progress_bar::Renderer for Null {
type Style = (); type Style = ();

View file

@ -13,6 +13,8 @@ use crate::{
use std::hash::Hash; use std::hash::Hash;
use std::ops::RangeInclusive; use std::ops::RangeInclusive;
pub use iced_style::slider::{Handle, HandleShape, Style, StyleSheet};
/// An horizontal bar and a handle that selects a single value from a range of /// An horizontal bar and a handle that selects a single value from a range of
/// values. /// values.
/// ///
@ -23,9 +25,8 @@ use std::ops::RangeInclusive;
/// ///
/// # Example /// # Example
/// ``` /// ```
/// # use iced_native::{slider, renderer::Null}; /// # use iced_native::slider::{self, Slider};
/// # /// #
/// # pub type Slider<'a, T, Message> = iced_native::Slider<'a, T, Message, Null>;
/// #[derive(Clone)] /// #[derive(Clone)]
/// pub enum Message { /// pub enum Message {
/// SliderChanged(f32), /// SliderChanged(f32),
@ -39,7 +40,7 @@ use std::ops::RangeInclusive;
/// ///
/// ![Slider drawn by Coffee's renderer](https://github.com/hecrj/coffee/blob/bda9818f823dfcb8a7ad0ff4940b4d4b387b5208/images/ui/slider.png?raw=true) /// ![Slider drawn by Coffee's renderer](https://github.com/hecrj/coffee/blob/bda9818f823dfcb8a7ad0ff4940b4d4b387b5208/images/ui/slider.png?raw=true)
#[allow(missing_debug_implementations)] #[allow(missing_debug_implementations)]
pub struct Slider<'a, T, Message, Renderer: self::Renderer> { pub struct Slider<'a, T, Message> {
state: &'a mut State, state: &'a mut State,
range: RangeInclusive<T>, range: RangeInclusive<T>,
step: T, step: T,
@ -48,15 +49,16 @@ pub struct Slider<'a, T, Message, Renderer: self::Renderer> {
on_release: Option<Message>, on_release: Option<Message>,
width: Length, width: Length,
height: u16, height: u16,
style: Renderer::Style, style_sheet: &'a dyn StyleSheet,
} }
impl<'a, T, Message, Renderer> Slider<'a, T, Message, Renderer> impl<'a, T, Message> Slider<'a, T, Message>
where where
T: Copy + From<u8> + std::cmp::PartialOrd, T: Copy + From<u8> + std::cmp::PartialOrd,
Message: Clone, Message: Clone,
Renderer: self::Renderer,
{ {
pub const DEFAULT_HEIGHT: u16 = 22;
/// Creates a new [`Slider`]. /// Creates a new [`Slider`].
/// ///
/// It expects: /// It expects:
@ -95,8 +97,8 @@ where
on_change: Box::new(on_change), on_change: Box::new(on_change),
on_release: None, on_release: None,
width: Length::Fill, width: Length::Fill,
height: Renderer::DEFAULT_HEIGHT, height: Self::DEFAULT_HEIGHT,
style: Renderer::Style::default(), style_sheet: Default::default(),
} }
} }
@ -124,8 +126,8 @@ where
} }
/// Sets the style of the [`Slider`]. /// Sets the style of the [`Slider`].
pub fn style(mut self, style: impl Into<Renderer::Style>) -> Self { pub fn style(mut self, style_sheet: &'a dyn StyleSheet) -> Self {
self.style = style.into(); self.style_sheet = style_sheet;
self self
} }
@ -150,11 +152,11 @@ impl State {
} }
impl<'a, T, Message, Renderer> Widget<Message, Renderer> impl<'a, T, Message, Renderer> Widget<Message, Renderer>
for Slider<'a, T, Message, Renderer> for Slider<'a, T, Message>
where where
T: Copy + Into<f64> + num_traits::FromPrimitive, T: Copy + Into<f64> + num_traits::FromPrimitive,
Message: Clone, Message: Clone,
Renderer: self::Renderer, Renderer: crate::Renderer,
{ {
fn width(&self) -> Length { fn width(&self) -> Length {
self.width self.width
@ -275,30 +277,14 @@ where
} }
} }
/// The renderer of a [`Slider`]. impl<'a, T, Message, Renderer> From<Slider<'a, T, Message>>
///
/// Your [renderer] will need to implement this trait before being
/// able to use a [`Slider`] in your user interface.
///
/// [renderer]: crate::renderer
pub trait Renderer: crate::Renderer {
/// The style supported by this renderer.
type Style: Default;
/// The default height of a [`Slider`].
const DEFAULT_HEIGHT: u16;
}
impl<'a, T, Message, Renderer> From<Slider<'a, T, Message, Renderer>>
for Element<'a, Message, Renderer> for Element<'a, Message, Renderer>
where where
T: 'a + Copy + Into<f64> + num_traits::FromPrimitive, T: 'a + Copy + Into<f64> + num_traits::FromPrimitive,
Message: 'a + Clone, Message: 'a + Clone,
Renderer: 'a + self::Renderer, Renderer: 'a + crate::Renderer,
{ {
fn from( fn from(slider: Slider<'a, T, Message>) -> Element<'a, Message, Renderer> {
slider: Slider<'a, T, Message, Renderer>,
) -> Element<'a, Message, Renderer> {
Element::new(slider) Element::new(slider)
} }
} }

View file

@ -79,17 +79,8 @@ impl StyleSheet for Default {
} }
} }
impl std::default::Default for Box<dyn StyleSheet> { impl std::default::Default for &'static dyn StyleSheet {
fn default() -> Self { fn default() -> Self {
Box::new(Default) &Default
}
}
impl<T> From<T> for Box<dyn StyleSheet>
where
T: 'static + StyleSheet,
{
fn from(style: T) -> Self {
Box::new(style)
} }
} }

View file

@ -41,7 +41,7 @@ pub struct Slider<'a, T, Message> {
#[allow(dead_code)] #[allow(dead_code)]
width: Length, width: Length,
#[allow(dead_code)] #[allow(dead_code)]
style: Box<dyn StyleSheet>, style_sheet: &'a dyn StyleSheet,
} }
impl<'a, T, Message> Slider<'a, T, Message> impl<'a, T, Message> Slider<'a, T, Message>
@ -85,7 +85,7 @@ where
step: T::from(1), step: T::from(1),
on_change: Rc::new(Box::new(on_change)), on_change: Rc::new(Box::new(on_change)),
width: Length::Fill, width: Length::Fill,
style: Default::default(), style_sheet: Default::default(),
} }
} }
@ -96,8 +96,8 @@ where
} }
/// Sets the style of the [`Slider`]. /// Sets the style of the [`Slider`].
pub fn style(mut self, style: impl Into<Box<dyn StyleSheet>>) -> Self { pub fn style(mut self, style_sheet: &'a dyn StyleSheet) -> Self {
self.style = style.into(); self.style_sheet = style_sheet.into();
self self
} }

View file

@ -1,13 +1,5 @@
//! Display an interactive selector of a single value from a range of values. //! Display an interactive selector of a single value from a range of values.
//! //!
//! A [`Slider`] has some local [`State`]. //! A [`Slider`] has some local [`State`].
use crate::Renderer;
pub use iced_graphics::slider::{Handle, HandleShape, Style, StyleSheet}; pub use iced_graphics::slider::{Handle, HandleShape, Style, StyleSheet};
pub use iced_native::slider::State; pub use iced_native::slider::{Slider, State};
/// An horizontal bar and a handle that selects a single value from a range of
/// values.
///
/// This is an alias of an `iced_native` slider with an `iced_wgpu::Renderer`.
pub type Slider<'a, T, Message> = iced_native::Slider<'a, T, Message, Renderer>;