parent
9ddc88400e
commit
bb8144bb01
@ -1,49 +0,0 @@
|
|||||||
use std::sync::Arc;
|
|
||||||
use crate::canvas::managed::handles::{CanvasImageHandle, CanvasTextureHandle};
|
|
||||||
|
|
||||||
pub struct CompuSprite {
|
|
||||||
pub vertices: [(f32, f32, f32); 6],
|
|
||||||
pub ti_position: [(f32, f32); 6],
|
|
||||||
|
|
||||||
position: (f32, f32),
|
|
||||||
size: (f32, f32),
|
|
||||||
color: (f32, f32, f32, f32),
|
|
||||||
image_handle: Arc<CanvasImageHandle>,
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
impl CompuSprite {
|
|
||||||
pub fn new(position: (f32, f32),
|
|
||||||
size: (f32, f32),
|
|
||||||
depth: u32,
|
|
||||||
image_size: (f32, f32),
|
|
||||||
image_handle: Arc<CanvasImageHandle>) -> CompuSprite {
|
|
||||||
|
|
||||||
let normalized_depth = (depth as f32 / 255.0);
|
|
||||||
|
|
||||||
CompuSprite {
|
|
||||||
vertices: [
|
|
||||||
(position.0, position.1 , normalized_depth), // top left
|
|
||||||
(position.0, position.1 + size.1 , normalized_depth), // bottom left
|
|
||||||
(position.0 + size.0, position.1 + size.1, normalized_depth), // bottom right
|
|
||||||
(position.0, position.1 , normalized_depth), // top left
|
|
||||||
(position.0 + size.0, position.1 + size.1, normalized_depth), // bottom right
|
|
||||||
(position.0 + size.0, position.1 , normalized_depth), // top right
|
|
||||||
],
|
|
||||||
|
|
||||||
ti_position: [
|
|
||||||
(0.0 , 0.0 ), // top left
|
|
||||||
(0.0 , image_size.1), // bottom left
|
|
||||||
(image_size.0, image_size.1), // bottom right
|
|
||||||
(0.0 , 0.0 ), // top left
|
|
||||||
(image_size.0, image_size.1), // bottom right
|
|
||||||
(image_size.0, 0.0 ), // top right
|
|
||||||
],
|
|
||||||
position: position,
|
|
||||||
size: size,
|
|
||||||
color: (0.0, 0.0, 0.0, 0.0),
|
|
||||||
image_handle: image_handle.clone(),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,5 +1,4 @@
|
|||||||
|
|
||||||
pub mod compu_buffer;
|
pub mod compu_buffer;
|
||||||
pub mod compu_sprite;
|
|
||||||
pub mod compu_kernel;
|
pub mod compu_kernel;
|
||||||
pub mod handles;
|
pub mod handles;
|
@ -0,0 +1,59 @@
|
|||||||
|
use std::sync::Arc;
|
||||||
|
use crate::canvas::managed::handles::{CanvasImageHandle, CanvasTextureHandle};
|
||||||
|
use crate::canvas::canvas_frame::Drawable;
|
||||||
|
use crate::util::vertex::{VertexTypes, ImageVertex3D};
|
||||||
|
|
||||||
|
pub struct CompuSprite {
|
||||||
|
|
||||||
|
pub verts: VertexTypes,
|
||||||
|
|
||||||
|
position: (f32, f32),
|
||||||
|
size: (f32, f32),
|
||||||
|
color: (f32, f32, f32, f32),
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CompuSprite {
|
||||||
|
pub fn new(position: (f32, f32),
|
||||||
|
size: (f32, f32),
|
||||||
|
depth: u32,
|
||||||
|
image_size: (f32, f32),
|
||||||
|
image_handle: Arc<CanvasImageHandle>) -> CompuSprite {
|
||||||
|
|
||||||
|
let normalized_depth = (depth as f32 / 255.0);
|
||||||
|
|
||||||
|
let verts = vec![
|
||||||
|
ImageVertex3D {
|
||||||
|
v_position: [position.0, position.1, normalized_depth], // top left
|
||||||
|
ti_position: [-0.0, -0.0] },
|
||||||
|
ImageVertex3D {
|
||||||
|
v_position: [position.0, position.1 + size.1, normalized_depth], // bottom left
|
||||||
|
ti_position: [-0.0, image_size.1] },
|
||||||
|
ImageVertex3D {
|
||||||
|
v_position: [position.0 + size.0, position.1 + size.1, normalized_depth], // bottom right
|
||||||
|
ti_position: [image_size.0, image_size.1] },
|
||||||
|
ImageVertex3D {
|
||||||
|
v_position: [position.0, position.1, normalized_depth], // top left
|
||||||
|
ti_position: [-0.0, -0.0] },
|
||||||
|
ImageVertex3D {
|
||||||
|
v_position: [position.0 + size.0, position.1 + size.1, normalized_depth], // bottom right
|
||||||
|
ti_position: [image_size.0, image_size.1] },
|
||||||
|
ImageVertex3D {
|
||||||
|
v_position: [position.0 + size.0, position.1, normalized_depth], // top right
|
||||||
|
ti_position: [image_size.0, -0.0] },
|
||||||
|
];
|
||||||
|
|
||||||
|
CompuSprite {
|
||||||
|
verts: VertexTypes::ImageType(verts, image_handle.clone()),
|
||||||
|
position: position,
|
||||||
|
size: size,
|
||||||
|
color: (0.0, 0.0, 0.0, 0.0),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Drawable for CompuSprite {
|
||||||
|
fn get(&self) -> VertexTypes {
|
||||||
|
self.verts.clone()
|
||||||
|
}
|
||||||
|
}
|
@ -1,3 +1,4 @@
|
|||||||
pub mod polygon;
|
pub mod polygon;
|
||||||
pub mod sprite;
|
pub mod sprite;
|
||||||
pub mod rect;
|
pub mod rect;
|
||||||
|
pub mod compu_sprite;
|
Loading…
Reference in new issue