Changed gradient::Packed to be repr(C) for direct gpu upload.

This commit is contained in:
Bingus 2023-05-26 10:07:52 -07:00
parent 413526ad09
commit 902e333148
No known key found for this signature in database
GPG key ID: 5F84D2AA40A9F170
5 changed files with 31 additions and 22 deletions

View file

@ -116,13 +116,17 @@ impl Linear {
data[42] = self.end.x; data[42] = self.end.x;
data[43] = self.end.y; data[43] = self.end.y;
Packed { data } Packed(data)
} }
} }
/// Packed [`Gradient`] data for use in shader code. /// Packed [`Gradient`] data for use in shader code.
#[derive(Debug)] #[derive(Debug, Copy, Clone, PartialEq)]
pub struct Packed { #[repr(C)]
/// The packed [`Gradient`] data. pub struct Packed([f32; 44]);
pub data: [f32; 44],
impl From<[f32; 44]> for Packed {
fn from(value: [f32; 44]) -> Self {
Self(value)
}
} }

View file

@ -4,6 +4,7 @@ use crate::core::image;
use crate::core::svg; use crate::core::svg;
use crate::core::text; use crate::core::text;
use crate::core::{Background, Color, Font, Rectangle, Size, Vector}; use crate::core::{Background, Color, Font, Rectangle, Size, Vector};
use crate::gradient;
use bytemuck::{Pod, Zeroable}; use bytemuck::{Pod, Zeroable};
use std::sync::Arc; use std::sync::Arc;
@ -258,7 +259,7 @@ pub struct GradientVertex2D {
pub position: [f32; 2], pub position: [f32; 2],
/// The packed vertex data of the gradient. /// The packed vertex data of the gradient.
pub gradient: [f32; 44], pub gradient: gradient::Packed,
} }
#[allow(unsafe_code)] #[allow(unsafe_code)]

View file

@ -505,7 +505,7 @@ impl tessellation::FillVertexConstructor<primitive::GradientVertex2D>
primitive::GradientVertex2D { primitive::GradientVertex2D {
position: [position.x, position.y], position: [position.x, position.y],
gradient: self.gradient.data, gradient: self.gradient,
} }
} }
} }
@ -521,7 +521,7 @@ impl tessellation::StrokeVertexConstructor<primitive::GradientVertex2D>
primitive::GradientVertex2D { primitive::GradientVertex2D {
position: [position.x, position.y], position: [position.x, position.y],
gradient: self.gradient.data, gradient: self.gradient,
} }
} }
} }

View file

@ -13,6 +13,7 @@ pub use text::Text;
use crate::core; use crate::core;
use crate::core::alignment; use crate::core::alignment;
use crate::core::{Background, Color, Font, Point, Rectangle, Size, Vector}; use crate::core::{Background, Color, Font, Point, Rectangle, Size, Vector};
use crate::graphics::gradient;
use crate::graphics::{Primitive, Viewport}; use crate::graphics::{Primitive, Viewport};
/// A group of primitives that should be clipped together. /// A group of primitives that should be clipped together.
@ -312,30 +313,33 @@ impl<'a> Layer<'a> {
} }
/// Packs the [`Gradient`] for use in shader code. /// Packs the [`Gradient`] for use in shader code.
fn pack_gradient(gradient: &core::Gradient, bounds: Rectangle) -> [f32; 44] { fn pack_gradient(
gradient: &core::Gradient,
bounds: Rectangle,
) -> gradient::Packed {
match gradient { match gradient {
core::Gradient::Linear(linear) => { core::Gradient::Linear(linear) => {
let mut pack: [f32; 44] = [0.0; 44]; let mut data: [f32; 44] = [0.0; 44];
for (index, stop) in linear.stops.iter().enumerate() { for (index, stop) in linear.stops.iter().enumerate() {
let [r, g, b, a] = let [r, g, b, a] =
stop.map_or(Color::default(), |s| s.color).into_linear(); stop.map_or(Color::default(), |s| s.color).into_linear();
pack[index * 4] = r; data[index * 4] = r;
pack[(index * 4) + 1] = g; data[(index * 4) + 1] = g;
pack[(index * 4) + 2] = b; data[(index * 4) + 2] = b;
pack[(index * 4) + 3] = a; data[(index * 4) + 3] = a;
pack[32 + index] = stop.map_or(2.0, |s| s.offset); data[32 + index] = stop.map_or(2.0, |s| s.offset);
} }
let (start, end) = linear.angle.to_distance(&bounds); let (start, end) = linear.angle.to_distance(&bounds);
pack[40] = start.x; data[40] = start.x;
pack[41] = start.y; data[41] = start.y;
pack[42] = end.x; data[42] = end.x;
pack[43] = end.y; data[43] = end.y;
pack data.into()
} }
} }
} }

View file

@ -1,5 +1,5 @@
//! A rectangle with certain styled properties. //! A rectangle with certain styled properties.
use crate::graphics::gradient;
use bytemuck::{Pod, Zeroable}; use bytemuck::{Pod, Zeroable};
/// The properties of a quad. /// The properties of a quad.
@ -38,7 +38,7 @@ pub struct Solid {
#[repr(C)] #[repr(C)]
pub struct Gradient { pub struct Gradient {
/// The background gradient data of the quad. /// The background gradient data of the quad.
pub gradient: [f32; 44], pub gradient: gradient::Packed,
/// The [`Quad`] data of the [`Gradient`]. /// The [`Quad`] data of the [`Gradient`].
pub quad: Quad, pub quad: Quad,