diff options
| author | 2024-05-07 21:22:29 +0200 | |
|---|---|---|
| committer | 2024-05-07 21:22:29 +0200 | |
| commit | 18b2f8845e5f488822f840c7e66a957af34b1862 (patch) | |
| tree | 172f7a05813331a9233b147b67b45417476ed5e0 /wgpu/src/window | |
| parent | db07b9ba9ef20c5995076992bf5592af12698000 (diff) | |
| parent | 5b6f3499e114c1694a5878466f8d46e7022e1bba (diff) | |
| download | iced-18b2f8845e5f488822f840c7e66a957af34b1862.tar.gz iced-18b2f8845e5f488822f840c7e66a957af34b1862.tar.bz2 iced-18b2f8845e5f488822f840c7e66a957af34b1862.zip | |
Merge pull request #2428 from iced-rs/feature/present-mode-env-var
Introduce `ICED_PRESENT_MODE` env var to pick a `wgpu::PresentMode`
Diffstat (limited to '')
| -rw-r--r-- | wgpu/src/window/compositor.rs | 25 | 
1 files changed, 15 insertions, 10 deletions
| diff --git a/wgpu/src/window/compositor.rs b/wgpu/src/window/compositor.rs index baf9f315..2e938c77 100644 --- a/wgpu/src/window/compositor.rs +++ b/wgpu/src/window/compositor.rs @@ -4,7 +4,8 @@ use crate::graphics::color;  use crate::graphics::compositor;  use crate::graphics::error;  use crate::graphics::{self, Viewport}; -use crate::{Engine, Renderer, Settings}; +use crate::settings::{self, Settings}; +use crate::{Engine, Renderer};  /// A window graphics backend for iced powered by `wgpu`.  #[allow(missing_debug_implementations)] @@ -270,15 +271,19 @@ impl graphics::Compositor for Compositor {          backend: Option<&str>,      ) -> Result<Self, graphics::Error> {          match backend { -            None | Some("wgpu") => Ok(new( -                Settings { -                    backends: wgpu::util::backend_bits_from_env() -                        .unwrap_or(wgpu::Backends::all()), -                    ..settings.into() -                }, -                compatible_window, -            ) -            .await?), +            None | Some("wgpu") => { +                let mut settings = Settings::from(settings); + +                if let Some(backends) = wgpu::util::backend_bits_from_env() { +                    settings.backends = backends; +                } + +                if let Some(present_mode) = settings::present_mode_from_env() { +                    settings.present_mode = present_mode; +                } + +                Ok(new(settings, compatible_window).await?) +            }              Some(backend) => Err(graphics::Error::GraphicsAdapterNotFound {                  backend: "wgpu",                  reason: error::Reason::DidNotMatch { | 
