summaryrefslogtreecommitdiffstats
path: root/wgpu/src/image/atlas/entry.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2020-02-28 15:17:16 +0100
committerLibravatar GitHub <noreply@github.com>2020-02-28 15:17:16 +0100
commitbab7dbcaef5d637e6452ef814b78595d9004971c (patch)
treedb82ee28634d499749816f69eaac4f303d088c14 /wgpu/src/image/atlas/entry.rs
parent69c81aa50dc30bc7a05df4393e45bc3d478db8b5 (diff)
parent88d4cd097044077127e1b3aa8fcb04afed185491 (diff)
downloadiced-bab7dbcaef5d637e6452ef814b78595d9004971c.tar.gz
iced-bab7dbcaef5d637e6452ef814b78595d9004971c.tar.bz2
iced-bab7dbcaef5d637e6452ef814b78595d9004971c.zip
Merge pull request #154 from Maldela/atlas
Texture atlas
Diffstat (limited to 'wgpu/src/image/atlas/entry.rs')
-rw-r--r--wgpu/src/image/atlas/entry.rs26
1 files changed, 26 insertions, 0 deletions
diff --git a/wgpu/src/image/atlas/entry.rs b/wgpu/src/image/atlas/entry.rs
new file mode 100644
index 00000000..0310fc54
--- /dev/null
+++ b/wgpu/src/image/atlas/entry.rs
@@ -0,0 +1,26 @@
+use crate::image::atlas;
+
+#[derive(Debug)]
+pub enum Entry {
+ Contiguous(atlas::Allocation),
+ Fragmented {
+ size: (u32, u32),
+ fragments: Vec<Fragment>,
+ },
+}
+
+impl Entry {
+ #[cfg(feature = "image")]
+ pub fn size(&self) -> (u32, u32) {
+ match self {
+ Entry::Contiguous(allocation) => allocation.size(),
+ Entry::Fragmented { size, .. } => *size,
+ }
+ }
+}
+
+#[derive(Debug)]
+pub struct Fragment {
+ pub position: (u32, u32),
+ pub allocation: atlas::Allocation,
+}