Added support for gradients as background variants + other optimizations.
This commit is contained in:
parent
669f7cc74b
commit
6551a0b2ab
41 changed files with 1658 additions and 1489 deletions
|
|
@ -1,4 +1,5 @@
|
|||
use crate::core::text;
|
||||
use crate::core::Gradient;
|
||||
use crate::core::{Background, Color, Font, Point, Rectangle, Size, Vector};
|
||||
use crate::graphics::backend;
|
||||
use crate::graphics::{Primitive, Viewport};
|
||||
|
|
@ -183,6 +184,9 @@ impl Backend {
|
|||
*color,
|
||||
))
|
||||
}
|
||||
Background::Gradient(gradient) => {
|
||||
into_gradient(*gradient, *bounds)
|
||||
}
|
||||
},
|
||||
anti_alias: true,
|
||||
..tiny_skia::Paint::default()
|
||||
|
|
@ -452,6 +456,47 @@ fn into_color(color: Color) -> tiny_skia::Color {
|
|||
.expect("Convert color from iced to tiny_skia")
|
||||
}
|
||||
|
||||
fn into_gradient<'a>(
|
||||
gradient: Gradient,
|
||||
bounds: Rectangle,
|
||||
) -> tiny_skia::Shader<'a> {
|
||||
let Gradient::Linear(linear) = gradient;
|
||||
let (start, end) = linear.angle.to_distance(&bounds);
|
||||
let stops: Vec<tiny_skia::GradientStop> = linear
|
||||
.color_stops
|
||||
.into_iter()
|
||||
.flatten()
|
||||
.map(|stop| {
|
||||
tiny_skia::GradientStop::new(
|
||||
stop.offset,
|
||||
tiny_skia::Color::from_rgba(
|
||||
stop.color.b,
|
||||
stop.color.g,
|
||||
stop.color.r,
|
||||
stop.color.a,
|
||||
)
|
||||
.expect("Create color"),
|
||||
)
|
||||
})
|
||||
.collect();
|
||||
|
||||
tiny_skia::LinearGradient::new(
|
||||
tiny_skia::Point {
|
||||
x: start.x,
|
||||
y: start.y,
|
||||
},
|
||||
tiny_skia::Point { x: end.x, y: end.y },
|
||||
if stops.is_empty() {
|
||||
vec![tiny_skia::GradientStop::new(0.0, tiny_skia::Color::BLACK)]
|
||||
} else {
|
||||
stops
|
||||
},
|
||||
tiny_skia::SpreadMode::Pad,
|
||||
tiny_skia::Transform::identity(),
|
||||
)
|
||||
.expect("Create linear gradient")
|
||||
}
|
||||
|
||||
fn rounded_rectangle(
|
||||
bounds: Rectangle,
|
||||
border_radius: [f32; 4],
|
||||
|
|
|
|||
|
|
@ -1,8 +1,8 @@
|
|||
use crate::core::Gradient;
|
||||
use crate::core::{Point, Rectangle, Size, Vector};
|
||||
use crate::graphics::geometry::fill::{self, Fill};
|
||||
use crate::graphics::geometry::stroke::{self, Stroke};
|
||||
use crate::graphics::geometry::{Path, Style, Text};
|
||||
use crate::graphics::Gradient;
|
||||
use crate::graphics::Primitive;
|
||||
|
||||
pub struct Frame {
|
||||
|
|
@ -231,18 +231,11 @@ pub fn into_paint(style: Style) -> tiny_skia::Paint<'static> {
|
|||
.expect("Create color"),
|
||||
),
|
||||
Style::Gradient(gradient) => match gradient {
|
||||
Gradient::Linear(linear) => tiny_skia::LinearGradient::new(
|
||||
tiny_skia::Point {
|
||||
x: linear.start.x,
|
||||
y: linear.start.y,
|
||||
},
|
||||
tiny_skia::Point {
|
||||
x: linear.end.x,
|
||||
y: linear.end.y,
|
||||
},
|
||||
linear
|
||||
Gradient::Linear(linear) => {
|
||||
let stops: Vec<tiny_skia::GradientStop> = linear
|
||||
.color_stops
|
||||
.into_iter()
|
||||
.flatten()
|
||||
.map(|stop| {
|
||||
tiny_skia::GradientStop::new(
|
||||
stop.offset,
|
||||
|
|
@ -255,11 +248,30 @@ pub fn into_paint(style: Style) -> tiny_skia::Paint<'static> {
|
|||
.expect("Create color"),
|
||||
)
|
||||
})
|
||||
.collect(),
|
||||
tiny_skia::SpreadMode::Pad,
|
||||
tiny_skia::Transform::identity(),
|
||||
)
|
||||
.expect("Create linear gradient"),
|
||||
.collect();
|
||||
|
||||
tiny_skia::LinearGradient::new(
|
||||
tiny_skia::Point {
|
||||
x: linear.start.x,
|
||||
y: linear.start.y,
|
||||
},
|
||||
tiny_skia::Point {
|
||||
x: linear.end.x,
|
||||
y: linear.end.y,
|
||||
},
|
||||
if stops.is_empty() {
|
||||
vec![tiny_skia::GradientStop::new(
|
||||
0.0,
|
||||
tiny_skia::Color::BLACK,
|
||||
)]
|
||||
} else {
|
||||
stops
|
||||
},
|
||||
tiny_skia::SpreadMode::Pad,
|
||||
tiny_skia::Transform::identity(),
|
||||
)
|
||||
.expect("Create linear gradient")
|
||||
}
|
||||
},
|
||||
},
|
||||
anti_alias: true,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue