summaryrefslogtreecommitdiffstats
path: root/examples
diff options
context:
space:
mode:
authorLibravatar shan <shankern@protonmail.com>2022-10-06 16:57:38 -0700
committerLibravatar shan <shankern@protonmail.com>2022-10-06 18:59:54 -0700
commit9c7bf417ac9c1ac72bcc55aa3cd5e8eb962243a2 (patch)
tree9e6b027d45bf858b8ed00d1e9285bdbcffb3b6e8 /examples
parentf4878a1a66a2e95e9430a8ccee8da823d2cb17ff (diff)
downloadiced-9c7bf417ac9c1ac72bcc55aa3cd5e8eb962243a2.tar.gz
iced-9c7bf417ac9c1ac72bcc55aa3cd5e8eb962243a2.tar.bz2
iced-9c7bf417ac9c1ac72bcc55aa3cd5e8eb962243a2.zip
Added support for gradients to respect current frame transform.
Diffstat (limited to 'examples')
-rw-r--r--examples/modern_art/src/main.rs33
-rw-r--r--examples/solar_system/src/main.rs40
2 files changed, 37 insertions, 36 deletions
diff --git a/examples/modern_art/src/main.rs b/examples/modern_art/src/main.rs
index 6a22b27f..0601fc44 100644
--- a/examples/modern_art/src/main.rs
+++ b/examples/modern_art/src/main.rs
@@ -1,12 +1,11 @@
-use rand::{Rng, thread_rng};
-use crate::canvas::{Cursor, Geometry};
-use iced::widget::canvas::{Cache, Fill, Frame, Gradient, fill};
-use iced::widget::{canvas, Canvas};
-use iced::Settings;
+use iced::widget::canvas::{
+ self, fill, Cache, Canvas, Cursor, Fill, Frame, Geometry, Gradient,
+};
use iced::{
executor, Application, Color, Command, Element, Length, Point, Rectangle,
- Renderer, Size, Theme,
+ Renderer, Size, Theme, Settings
};
+use rand::{thread_rng, Rng};
fn main() -> iced::Result {
ModernArt::run(Settings {
@@ -41,7 +40,7 @@ impl Application for ModernArt {
String::from("Modern Art")
}
- fn update(&mut self, _message: Self::Message) -> Command<Self::Message> {
+ fn update(&mut self, _message: Message) -> Command<Message> {
Command::none()
}
@@ -94,10 +93,7 @@ fn generate_box(frame: &mut Frame, bounds: Size) -> bool {
let mut i = 0;
while i <= stops {
- builder = builder.add_stop(
- i as f32 / stops as f32,
- random_color()
- );
+ builder = builder.add_stop(i as f32 / stops as f32, random_color());
i += 1;
}
@@ -106,7 +102,7 @@ fn generate_box(frame: &mut Frame, bounds: Size) -> bool {
let top_left = Point::new(
thread_rng().gen_range(0.0..bounds.width),
- thread_rng().gen_range(0.0..bounds.height)
+ thread_rng().gen_range(0.0..bounds.height),
);
let size = Size::new(
@@ -120,8 +116,8 @@ fn generate_box(frame: &mut Frame, bounds: Size) -> bool {
size,
Fill {
style: fill::Style::Solid(random_color()),
- .. Default::default()
- }
+ ..Default::default()
+ },
);
} else {
frame.fill_rectangle(
@@ -130,10 +126,13 @@ fn generate_box(frame: &mut Frame, bounds: Size) -> bool {
Fill {
style: fill::Style::Gradient(&gradient(
top_left,
- Point::new(top_left.x + size.width, top_left.y + size.height)
+ Point::new(
+ top_left.x + size.width,
+ top_left.y + size.height,
+ ),
)),
- .. Default::default()
- }
+ ..Default::default()
+ },
);
};
diff --git a/examples/solar_system/src/main.rs b/examples/solar_system/src/main.rs
index 5f90245c..73ddb01e 100644
--- a/examples/solar_system/src/main.rs
+++ b/examples/solar_system/src/main.rs
@@ -10,14 +10,14 @@ use iced::application;
use iced::executor;
use iced::theme::{self, Theme};
use iced::time;
-use iced::widget::canvas;
-use iced::widget::canvas::{Cursor, Path, Stroke, stroke};
+use iced::widget::canvas::{self, stroke, Cursor, Path, Stroke};
use iced::window;
use iced::{
Application, Color, Command, Element, Length, Point, Rectangle, Settings,
Size, Subscription, Vector,
};
+use crate::canvas::{fill, Fill, Gradient};
use std::time::Instant;
pub fn main() -> iced::Result {
@@ -178,7 +178,9 @@ impl<Message> canvas::Program<Message> for State {
frame.stroke(
&orbit,
Stroke {
- style: stroke::Style::Solid(Color::from_rgba8(0, 153, 255, 0.1)),
+ style: stroke::Style::Solid(Color::from_rgba8(
+ 0, 153, 255, 0.1,
+ )),
width: 1.0,
line_dash: canvas::LineDash {
offset: 0,
@@ -198,15 +200,23 @@ impl<Message> canvas::Program<Message> for State {
frame.translate(Vector::new(Self::ORBIT_RADIUS, 0.0));
let earth = Path::circle(Point::ORIGIN, Self::EARTH_RADIUS);
- let shadow = Path::rectangle(
- Point::new(0.0, -Self::EARTH_RADIUS),
- Size::new(
- Self::EARTH_RADIUS * 4.0,
- Self::EARTH_RADIUS * 2.0,
- ),
- );
- frame.fill(&earth, Color::from_rgb8(0x6B, 0x93, 0xD6));
+ let earth_fill = Gradient::linear(
+ Point::new(-Self::EARTH_RADIUS, 0.0),
+ Point::new(Self::EARTH_RADIUS, 0.0),
+ )
+ .add_stop(0.2, Color::from_rgb(0.15, 0.50, 1.0))
+ .add_stop(0.8, Color::from_rgb(0.0, 0.20, 0.47))
+ .build()
+ .unwrap();
+
+ frame.fill(
+ &earth,
+ Fill {
+ style: fill::Style::Gradient(&earth_fill),
+ ..Default::default()
+ },
+ );
frame.with_save(|frame| {
frame.rotate(rotation * 10.0);
@@ -215,14 +225,6 @@ impl<Message> canvas::Program<Message> for State {
let moon = Path::circle(Point::ORIGIN, Self::MOON_RADIUS);
frame.fill(&moon, Color::WHITE);
});
-
- frame.fill(
- &shadow,
- Color {
- a: 0.7,
- ..Color::BLACK
- },
- );
});
});