summaryrefslogtreecommitdiffstats
path: root/wgpu/src/engine.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón Jiménez <hector@hecrj.dev>2024-04-03 21:07:54 +0200
committerLibravatar Héctor Ramón Jiménez <hector@hecrj.dev>2024-04-03 21:07:54 +0200
commitb05e61f5c8ae61c9f3c7cc08cded53901ebbccfd (patch)
tree3d35a011d94d4936f09b5a9be4031358a09c60da /wgpu/src/engine.rs
parent99a904112ca111f2ab0e60e30b6c369741b1653b (diff)
downloadiced-b05e61f5c8ae61c9f3c7cc08cded53901ebbccfd.tar.gz
iced-b05e61f5c8ae61c9f3c7cc08cded53901ebbccfd.tar.bz2
iced-b05e61f5c8ae61c9f3c7cc08cded53901ebbccfd.zip
Redesign `iced_wgpu` layering architecture
Diffstat (limited to 'wgpu/src/engine.rs')
-rw-r--r--wgpu/src/engine.rs79
1 files changed, 79 insertions, 0 deletions
diff --git a/wgpu/src/engine.rs b/wgpu/src/engine.rs
new file mode 100644
index 00000000..e45b62b2
--- /dev/null
+++ b/wgpu/src/engine.rs
@@ -0,0 +1,79 @@
+use crate::buffer;
+use crate::graphics::Antialiasing;
+use crate::primitive::pipeline;
+use crate::quad;
+use crate::text;
+use crate::triangle;
+
+#[allow(missing_debug_implementations)]
+pub struct Engine {
+ pub(crate) quad_pipeline: quad::Pipeline,
+ pub(crate) text_pipeline: text::Pipeline,
+ pub(crate) triangle_pipeline: triangle::Pipeline,
+ pub(crate) _pipeline_storage: pipeline::Storage,
+ #[cfg(any(feature = "image", feature = "svg"))]
+ pub(crate) image_pipeline: crate::image::Pipeline,
+ pub(crate) staging_belt: wgpu::util::StagingBelt,
+}
+
+impl Engine {
+ pub fn new(
+ _adapter: &wgpu::Adapter,
+ device: &wgpu::Device,
+ queue: &wgpu::Queue,
+ format: wgpu::TextureFormat,
+ antialiasing: Option<Antialiasing>, // TODO: Initialize AA pipelines lazily
+ ) -> Self {
+ let text_pipeline = text::Pipeline::new(device, queue, format);
+ let quad_pipeline = quad::Pipeline::new(device, format);
+ let triangle_pipeline =
+ triangle::Pipeline::new(device, format, antialiasing);
+
+ #[cfg(any(feature = "image", feature = "svg"))]
+ let image_pipeline = {
+ let backend = _adapter.get_info().backend;
+
+ crate::image::Pipeline::new(device, format, backend)
+ };
+
+ Self {
+ // TODO: Resize belt smartly (?)
+ // It would be great if the `StagingBelt` API exposed methods
+ // for introspection to detect when a resize may be worth it.
+ staging_belt: wgpu::util::StagingBelt::new(
+ buffer::MAX_WRITE_SIZE as u64,
+ ),
+ quad_pipeline,
+ text_pipeline,
+ triangle_pipeline,
+ _pipeline_storage: pipeline::Storage::default(),
+
+ #[cfg(any(feature = "image", feature = "svg"))]
+ image_pipeline,
+ }
+ }
+
+ #[cfg(any(feature = "image", feature = "svg"))]
+ pub fn image_cache(&self) -> &crate::image::cache::Shared {
+ self.image_pipeline.cache()
+ }
+
+ pub fn submit(
+ &mut self,
+ queue: &wgpu::Queue,
+ encoder: wgpu::CommandEncoder,
+ ) -> wgpu::SubmissionIndex {
+ self.staging_belt.finish();
+ let index = queue.submit(Some(encoder.finish()));
+ self.staging_belt.recall();
+
+ self.quad_pipeline.end_frame();
+ self.text_pipeline.end_frame();
+ self.triangle_pipeline.end_frame();
+
+ #[cfg(any(feature = "image", feature = "svg"))]
+ self.image_pipeline.end_frame();
+
+ index
+ }
+}