summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--examples/solar_system/src/main.rs10
-rw-r--r--graphics/src/gradient.rs26
-rw-r--r--graphics/src/widget/canvas/fill.rs15
-rw-r--r--graphics/src/widget/canvas/frame.rs3
-rw-r--r--graphics/src/widget/canvas/stroke.rs6
5 files changed, 27 insertions, 33 deletions
diff --git a/examples/solar_system/src/main.rs b/examples/solar_system/src/main.rs
index 10154621..b638c6d0 100644
--- a/examples/solar_system/src/main.rs
+++ b/examples/solar_system/src/main.rs
@@ -11,7 +11,7 @@ use iced::executor;
use iced::theme::{self, Theme};
use iced::time;
use iced::widget::canvas;
-use iced::widget::canvas::{Cursor, Path, Stroke, Fill, fill, Gradient, stroke, gradient::Position};
+use iced::widget::canvas::{Cursor, Path, Stroke, Gradient, stroke, gradient::Position};
use iced::window;
use iced::{
Application, Color, Command, Element, Length, Point, Rectangle, Settings,
@@ -212,13 +212,7 @@ impl<Message> canvas::Program<Message> for State {
.build()
.unwrap();
- frame.fill(
- &earth,
- Fill {
- style: fill::Style::Gradient(&earth_fill),
- ..Default::default()
- },
- );
+ frame.fill(&earth, &earth_fill);
frame.with_save(|frame| {
frame.rotate(rotation * 10.0);
diff --git a/graphics/src/gradient.rs b/graphics/src/gradient.rs
index e1984854..1446d7cf 100644
--- a/graphics/src/gradient.rs
+++ b/graphics/src/gradient.rs
@@ -1,10 +1,8 @@
//! For creating a Gradient.
mod linear;
-pub use crate::gradient::linear::{Linear, Position, Location};
-use crate::widget::canvas::frame::Transform;
-use crate::Color;
-use crate::widget::canvas::{Fill, fill};
+pub use crate::gradient::linear::{Linear, Location, Position};
+use crate::{Color, Point};
#[derive(Debug, Clone, PartialEq)]
/// A fill which transitions colors progressively along a direction, either linearly, radially (TBD),
@@ -30,23 +28,9 @@ impl Gradient {
linear::Builder::new(position.into())
}
- /// Modifies the start & end stops of the gradient to have a proper transform value.
- pub(crate) fn transform(mut self, transform: &Transform) -> Self {
- match &mut self {
- Gradient::Linear(linear) => {
- linear.start = transform.transform_point(linear.start);
- linear.end = transform.transform_point(linear.end);
- }
- }
- self
- }
-}
-
-impl<'a> Into<Fill<'a>> for &'a Gradient {
- fn into(self) -> Fill<'a> {
- Fill {
- style: fill::Style::Gradient(self),
- .. Default::default()
+ pub(crate) fn coords(&mut self) -> (&mut Point, &mut Point) {
+ match self {
+ Gradient::Linear(gradient) => (&mut gradient.start, &mut gradient.end)
}
}
}
diff --git a/graphics/src/widget/canvas/fill.rs b/graphics/src/widget/canvas/fill.rs
index cd56aa9e..477a7020 100644
--- a/graphics/src/widget/canvas/fill.rs
+++ b/graphics/src/widget/canvas/fill.rs
@@ -42,6 +42,15 @@ impl<'a> From<Color> for Fill<'a> {
}
}
+impl<'a> Into<Fill<'a>> for &'a Gradient {
+ fn into(self) -> Fill<'a> {
+ Fill {
+ style: Style::Gradient(self),
+ ..Default::default()
+ }
+ }
+}
+
/// The style of a [`Fill`].
#[derive(Debug, Clone)]
pub enum Style<'a> {
@@ -59,7 +68,11 @@ impl<'a> Style<'a> {
mesh::Style::Solid(*color)
},
Style::Gradient(gradient) => {
- mesh::Style::Gradient((*gradient).clone().transform(transform))
+ let mut gradient = (*gradient).clone();
+ let coordinates = gradient.coords();
+ transform.transform_point(coordinates.0);
+ transform.transform_point(coordinates.1);
+ mesh::Style::Gradient(gradient)
}
}
}
diff --git a/graphics/src/widget/canvas/frame.rs b/graphics/src/widget/canvas/frame.rs
index 6dd0d06a..d505cef7 100644
--- a/graphics/src/widget/canvas/frame.rs
+++ b/graphics/src/widget/canvas/frame.rs
@@ -38,12 +38,11 @@ pub(crate) struct Transform {
impl Transform {
/// Transforms the given [Point] by the transformation matrix.
- pub(crate) fn transform_point(&self, mut point: Point) -> Point {
+ pub(crate) fn transform_point(&self, point: &mut Point) {
let transformed =
self.raw.transform_point(Point2D::new(point.x, point.y));
point.x = transformed.x;
point.y = transformed.y;
- point
}
}
diff --git a/graphics/src/widget/canvas/stroke.rs b/graphics/src/widget/canvas/stroke.rs
index 5cb63a91..6e49f994 100644
--- a/graphics/src/widget/canvas/stroke.rs
+++ b/graphics/src/widget/canvas/stroke.rs
@@ -77,7 +77,11 @@ impl<'a> Style<'a> {
mesh::Style::Solid(*color)
},
Style::Gradient(gradient) => {
- mesh::Style::Gradient((*gradient).clone().transform(transform))
+ let mut gradient = (*gradient).clone();
+ let coordinates = gradient.coords();
+ transform.transform_point(coordinates.0);
+ transform.transform_point(coordinates.1);
+ mesh::Style::Gradient(gradient)
}
}
}