This commit is contained in:
griffi-gh 2023-11-23 21:27:11 +01:00
parent 09a7426ac2
commit b893193753
3 changed files with 57 additions and 13 deletions

10
Cargo.lock generated
View file

@ -112,15 +112,6 @@ version = "1.0.75"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a4668cab20f66d8d020e1fbc0ebe47217433c1b6c8f2040faf858554e394ace6" checksum = "a4668cab20f66d8d020e1fbc0ebe47217433c1b6c8f2040faf858554e394ace6"
[[package]]
name = "approx"
version = "0.5.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "cab112f0a86d568ea0e627cc1d6be74a1e9cd55214684db5561995f6dad897c6"
dependencies = [
"num-traits",
]
[[package]] [[package]]
name = "arrayref" name = "arrayref"
version = "0.3.7" version = "0.3.7"
@ -680,7 +671,6 @@ version = "0.24.2"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b5418c17512bdf42730f9032c74e1ae39afc408745ebb2acf72fbc4691c17945" checksum = "b5418c17512bdf42730f9032c74e1ae39afc408745ebb2acf72fbc4691c17945"
dependencies = [ dependencies = [
"approx",
"serde", "serde",
] ]

View file

@ -7,7 +7,7 @@ publish = false
[dependencies] [dependencies]
hashbrown = "0.14" hashbrown = "0.14"
nohash-hasher = "0.2" nohash-hasher = "0.2"
glam = { version = "0.24", features = ["approx"] } glam = "0.24"
glium = { git = "https://github.com/glium/glium", rev = "968fc92378caf", optional = true } glium = { git = "https://github.com/glium/glium", rev = "968fc92378caf", optional = true }
fontdue = { version = "0.7", optional = true } fontdue = { version = "0.7", optional = true }
rect_packer = { version = "0.2.1", optional = true } rect_packer = { version = "0.2.1", optional = true }
@ -21,7 +21,7 @@ winit = "0.29"
[features] [features]
default = ["builtin_elements", "texture_manager", "text_rendering", "builtin_font", "backend_glium"] default = ["builtin_elements", "texture_manager", "text_rendering", "builtin_font", "backend_glium"]
backend_glium = ["dep:glium"] backend_glium = ["dep:glium"]
texture_manager = [] texture_manager = ["dep:rect_packer"]
text_rendering = ["dep:fontdue", "texture_manager"] text_rendering = ["dep:fontdue", "texture_manager"]
builtin_font = ["text_rendering"] builtin_font = ["text_rendering"]
builtin_elements = [] builtin_elements = []

View file

@ -1,3 +1,57 @@
struct TextureSpace { use rect_packer::{Packer, Config as PackerConfig};
use glam::{IVec2, ivec2};
#[derive(Clone, Copy)]
pub struct TextureAllocation {
// pub index: usize,
pub position: IVec2,
pub size: IVec2,
in_texture_size: IVec2,
}
impl TextureAllocation {
pub fn uv(&self) -> (f32, f32, f32, f32) {
let p0 = self.position.as_vec2() / self.in_texture_size.as_vec2();
let p1 = (self.position + self.size).as_vec2() / self.in_texture_size.as_vec2();
(p0.x, p0.y, p1.x, p1.y)
}
}
pub struct TextureSpace {
size: IVec2,
packer: Packer,
// allocations: Vec<TextureAllocation>,
}
impl TextureSpace {
pub fn new(size: IVec2) -> Self {
Self {
size,
packer: Packer::new(PackerConfig {
width: size.x,
height: size.y,
border_padding: 1,
rectangle_padding: 1,
}),
// allocations: Vec::new(),
}
}
pub fn size(&self) -> IVec2 {
self.size
}
pub fn allocate(&mut self, size: IVec2) -> Option<TextureAllocation> {
let position = self.packer.pack(size.x, size.y, false)
.map(|rect| ivec2(rect.x, rect.y))?;
Some(TextureAllocation {
position,
size,
in_texture_size: self.size
})
}
// pub fn lookup(&self, index: usize) -> Option<TextureAllocation> {
// self.allocations.get(index).copied()
// }
} }