Skip to content

Commit

Permalink
Merge pull request #1155 from AlisCode/refactor/decouple_image
Browse files Browse the repository at this point in the history
Decouple `image::Handle` from `iced_native` and lower trait bound on `text::Renderer::Font`
  • Loading branch information
hecrj authored Dec 13, 2021
2 parents bc15bfd + d06e6bf commit e24eaa7
Show file tree
Hide file tree
Showing 12 changed files with 62 additions and 48 deletions.
2 changes: 2 additions & 0 deletions graphics/src/widget/image.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ impl<B> image::Renderer for Renderer<B>
where
B: Backend + backend::Image,
{
type Handle = image::Handle;

fn dimensions(&self, handle: &image::Handle) -> (u32, u32) {
self.backend().dimensions(handle)
}
Expand Down
9 changes: 7 additions & 2 deletions native/src/image.rs
Original file line number Diff line number Diff line change
Expand Up @@ -115,10 +115,15 @@ impl std::fmt::Debug for Data {
///
/// [renderer]: crate::renderer
pub trait Renderer: crate::Renderer {
/// The image Handle to be displayed. Iced exposes its own default implementation of a [`Handle`]
///
/// [`Handle`]: Self::Handle
type Handle: Clone + Hash;

/// Returns the dimensions of an image for the given [`Handle`].
fn dimensions(&self, handle: &Handle) -> (u32, u32);
fn dimensions(&self, handle: &Self::Handle) -> (u32, u32);

/// Draws an image with the given [`Handle`] and inside the provided
/// `bounds`.
fn draw(&mut self, handle: Handle, bounds: Rectangle);
fn draw(&mut self, handle: Self::Handle, bounds: Rectangle);
}
2 changes: 1 addition & 1 deletion native/src/overlay/menu.rs
Original file line number Diff line number Diff line change
Expand Up @@ -454,7 +454,7 @@ where
..bounds
},
size: f32::from(text_size),
font: self.font,
font: self.font.clone(),
color: if is_selected {
self.style.selected_text_color
} else {
Expand Down
2 changes: 1 addition & 1 deletion native/src/text.rs
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ impl Hit {
/// A renderer capable of measuring and drawing [`Text`].
pub trait Renderer: crate::Renderer {
/// The font type used.
type Font: Default + Copy;
type Font: Default + Clone;

/// The icon font of the backend.
const ICON_FONT: Self::Font;
Expand Down
4 changes: 2 additions & 2 deletions native/src/widget/checkbox.rs
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,7 @@ where
)
.push(
Text::new(&self.label)
.font(self.font)
.font(self.font.clone())
.width(self.width)
.size(self.text_size.unwrap_or(renderer.default_size())),
)
Expand Down Expand Up @@ -261,7 +261,7 @@ where
style,
label_layout,
&self.label,
self.font,
self.font.clone(),
self.text_size,
self.text_color.or(Some(custom_style.text_color)),
alignment::Horizontal::Left,
Expand Down
22 changes: 13 additions & 9 deletions native/src/widget/image.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
pub mod viewer;
pub use viewer::Viewer;

use crate::image::{self, Handle};
use crate::image;
use crate::layout;
use crate::renderer;
use crate::{Element, Hasher, Layout, Length, Point, Rectangle, Size, Widget};
Expand All @@ -15,19 +15,20 @@ use std::hash::Hash;
///
/// ```
/// # use iced_native::widget::Image;
/// # use iced_native::image;
/// #
/// let image = Image::new("resources/ferris.png");
/// let image = Image::<image::Handle>::new("resources/ferris.png");
/// ```
///
/// <img src="https://github.com/hecrj/iced/blob/9712b319bb7a32848001b96bd84977430f14b623/examples/resources/ferris.png?raw=true" width="300">
#[derive(Debug, Hash)]
pub struct Image {
pub struct Image<Handle> {
handle: Handle,
width: Length,
height: Length,
}

impl Image {
impl<Handle> Image<Handle> {
/// Creates a new [`Image`] with the given path.
pub fn new<T: Into<Handle>>(handle: T) -> Self {
Image {
Expand All @@ -50,9 +51,10 @@ impl Image {
}
}

impl<Message, Renderer> Widget<Message, Renderer> for Image
impl<Message, Renderer, Handle> Widget<Message, Renderer> for Image<Handle>
where
Renderer: image::Renderer,
Renderer: image::Renderer<Handle = Handle>,
Handle: Clone + Hash,
{
fn width(&self) -> Length {
self.width
Expand Down Expand Up @@ -108,11 +110,13 @@ where
}
}

impl<'a, Message, Renderer> From<Image> for Element<'a, Message, Renderer>
impl<'a, Message, Renderer, Handle> From<Image<Handle>>
for Element<'a, Message, Renderer>
where
Renderer: image::Renderer,
Renderer: image::Renderer<Handle = Handle>,
Handle: Clone + Hash + 'a,
{
fn from(image: Image) -> Element<'a, Message, Renderer> {
fn from(image: Image<Handle>) -> Element<'a, Message, Renderer> {
Element::new(image)
}
}
28 changes: 15 additions & 13 deletions native/src/widget/image/viewer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,22 +13,20 @@ use std::hash::Hash;

/// A frame that displays an image with the ability to zoom in/out and pan.
#[allow(missing_debug_implementations)]
pub struct Viewer<'a> {
pub struct Viewer<'a, Handle> {
state: &'a mut State,
padding: u16,
width: Length,
height: Length,
min_scale: f32,
max_scale: f32,
scale_step: f32,
handle: image::Handle,
handle: Handle,
}

impl<'a> Viewer<'a> {
/// Creates a new [`Viewer`] with the given [`State`] and [`Handle`].
///
/// [`Handle`]: image::Handle
pub fn new(state: &'a mut State, handle: image::Handle) -> Self {
impl<'a, Handle> Viewer<'a, Handle> {
/// Creates a new [`Viewer`] with the given [`State`].
pub fn new(state: &'a mut State, handle: Handle) -> Self {
Viewer {
state,
padding: 0,
Expand Down Expand Up @@ -89,7 +87,7 @@ impl<'a> Viewer<'a> {
/// will be respected.
fn image_size<Renderer>(&self, renderer: &Renderer, bounds: Size) -> Size
where
Renderer: image::Renderer,
Renderer: image::Renderer<Handle = Handle>,
{
let (width, height) = renderer.dimensions(&self.handle);

Expand All @@ -114,9 +112,11 @@ impl<'a> Viewer<'a> {
}
}

impl<'a, Message, Renderer> Widget<Message, Renderer> for Viewer<'a>
impl<'a, Message, Renderer, Handle> Widget<Message, Renderer>
for Viewer<'a, Handle>
where
Renderer: image::Renderer,
Renderer: image::Renderer<Handle = Handle>,
Handle: Clone + Hash,
{
fn width(&self) -> Length {
self.width
Expand Down Expand Up @@ -394,12 +394,14 @@ impl State {
}
}

impl<'a, Message, Renderer> From<Viewer<'a>> for Element<'a, Message, Renderer>
impl<'a, Message, Renderer, Handle> From<Viewer<'a, Handle>>
for Element<'a, Message, Renderer>
where
Renderer: 'a + image::Renderer,
Renderer: 'a + image::Renderer<Handle = Handle>,
Message: 'a,
Handle: Clone + Hash + 'a,
{
fn from(viewer: Viewer<'a>) -> Element<'a, Message, Renderer> {
fn from(viewer: Viewer<'a, Handle>) -> Element<'a, Message, Renderer> {
Element::new(viewer)
}
}
8 changes: 4 additions & 4 deletions native/src/widget/pick_list.rs
Original file line number Diff line number Diff line change
Expand Up @@ -174,15 +174,15 @@ where
.pad(self.padding);

let text_size = self.text_size.unwrap_or(renderer.default_size());
let font = self.font;
let font = self.font.clone();

let max_width = match self.width {
Length::Shrink => {
let measure = |label: &str| -> u32 {
let (width, _) = renderer.measure(
label,
text_size,
font,
font.clone(),
Size::new(f32::INFINITY, f32::INFINITY),
);

Expand Down Expand Up @@ -397,7 +397,7 @@ where
size: f32::from(
self.text_size.unwrap_or(renderer.default_size()),
),
font: self.font,
font: self.font.clone(),
color: is_selected
.then(|| style.text_color)
.unwrap_or(style.placeholder_color),
Expand Down Expand Up @@ -427,7 +427,7 @@ where
)
.width(bounds.width.round() as u16)
.padding(self.padding)
.font(self.font)
.font(self.font.clone())
.style(self.style_sheet.menu());

if let Some(text_size) = self.text_size {
Expand Down
2 changes: 1 addition & 1 deletion native/src/widget/radio.rs
Original file line number Diff line number Diff line change
Expand Up @@ -279,7 +279,7 @@ where
style,
label_layout,
&self.label,
self.font,
self.font.clone(),
self.text_size,
self.text_color,
alignment::Horizontal::Left,
Expand Down
6 changes: 3 additions & 3 deletions native/src/widget/text.rs
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,7 @@ where
let bounds = limits.max();

let (width, height) =
renderer.measure(&self.content, size, self.font, bounds);
renderer.measure(&self.content, size, self.font.clone(), bounds);

let size = limits.resolve(Size::new(width, height));

Expand All @@ -144,7 +144,7 @@ where
style,
layout,
&self.content,
self.font,
self.font.clone(),
self.size,
self.color,
self.horizontal_alignment,
Expand Down Expand Up @@ -227,7 +227,7 @@ impl<Renderer: text::Renderer> Clone for Text<Renderer> {
content: self.content.clone(),
size: self.size,
color: self.color,
font: self.font,
font: self.font.clone(),
width: self.width,
height: self.height,
horizontal_alignment: self.horizontal_alignment,
Expand Down
21 changes: 11 additions & 10 deletions native/src/widget/text_input.rs
Original file line number Diff line number Diff line change
Expand Up @@ -219,7 +219,7 @@ where
&value,
size,
position,
self.font,
self.font.clone(),
);

(
Expand Down Expand Up @@ -251,7 +251,7 @@ where
&value,
size,
left,
self.font,
self.font.clone(),
);

let (right_position, right_offset) =
Expand All @@ -261,7 +261,7 @@ where
&value,
size,
right,
self.font,
self.font.clone(),
);

let width = right_position - left_position;
Expand Down Expand Up @@ -300,7 +300,7 @@ where
&text
},
size,
self.font,
self.font.clone(),
);

let render = |renderer: &mut Renderer| {
Expand All @@ -319,7 +319,7 @@ where
} else {
self.style_sheet.value_color()
},
font: self.font,
font: self.font.clone(),
bounds: Rectangle {
y: text_bounds.center_y(),
width: f32::INFINITY,
Expand Down Expand Up @@ -414,7 +414,7 @@ where
find_cursor_position(
renderer,
text_layout.bounds(),
self.font,
self.font.clone(),
self.size,
&value,
&self.state,
Expand All @@ -434,7 +434,7 @@ where
let position = find_cursor_position(
renderer,
text_layout.bounds(),
self.font,
self.font.clone(),
self.size,
&self.value,
&self.state,
Expand Down Expand Up @@ -481,7 +481,7 @@ where
let position = find_cursor_position(
renderer,
text_layout.bounds(),
self.font,
self.font.clone(),
self.size,
&value,
&self.state,
Expand Down Expand Up @@ -962,13 +962,14 @@ where
{
let size = size.unwrap_or(renderer.default_size());

let offset = offset(renderer, text_bounds, font, size, &value, &state);
let offset =
offset(renderer, text_bounds, font.clone(), size, &value, &state);

renderer
.hit_test(
&value.to_string(),
size.into(),
font,
font.clone(),
Size::INFINITY,
Point::new(x + offset, text_bounds.height / 2.0),
true,
Expand Down
4 changes: 2 additions & 2 deletions native/src/widget/toggler.rs
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,7 @@ where
row = row.push(
Text::new(label)
.horizontal_alignment(self.text_alignment)
.font(self.font)
.font(self.font.clone())
.width(self.width)
.size(self.text_size.unwrap_or(renderer.default_size())),
);
Expand Down Expand Up @@ -229,7 +229,7 @@ where
style,
label_layout,
&label,
self.font,
self.font.clone(),
self.text_size,
None,
self.text_alignment,
Expand Down

0 comments on commit e24eaa7

Please sign in to comment.