Wire up styling to Slider in iced_native
This commit is contained in:
parent
e00a2e9b2d
commit
11bcb13427
9 changed files with 31 additions and 97 deletions
|
|
@ -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));
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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>;
|
|
||||||
|
|
|
||||||
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -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 = ();
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
///
|
///
|
||||||
/// 
|
/// 
|
||||||
#[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)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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>;
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue