From 86faa70a708fb0bc8351609dc1e46c78440bcea9 Mon Sep 17 00:00:00 2001 From: Jason Tsai Date: Mon, 22 Jul 2024 13:17:27 +0800 Subject: [PATCH] fix(example): workaround to prevent winit crash when unfocused (#1323) * fix(example): workaround to prevent winit crash when unfocused * chore: remove changelog and unix resize event --- examples/winit.rs | 27 ++++++++++----------------- 1 file changed, 10 insertions(+), 17 deletions(-) diff --git a/examples/winit.rs b/examples/winit.rs index b67676416..9afd8104b 100644 --- a/examples/winit.rs +++ b/examples/winit.rs @@ -2,12 +2,13 @@ // SPDX-License-Identifier: Apache-2.0 // SPDX-License-Identifier: MIT +use dpi::{LogicalPosition, LogicalSize}; use winit::{ event::{Event, WindowEvent}, event_loop::{ControlFlow, EventLoop}, window::WindowBuilder, }; -use wry::WebViewBuilder; +use wry::{Rect, WebViewBuilder}; fn main() -> wry::Result<()> { #[cfg(any( @@ -39,9 +40,9 @@ fn main() -> wry::Result<()> { .build(&event_loop) .unwrap(); - #[allow(unused_mut)] - let mut builder = WebViewBuilder::new(&window); - let _webview = builder.with_url("https://tauri.app").build()?; + let webview = WebViewBuilder::new_as_child(&window) + .with_url("https://tauri.app") + .build()?; event_loop .run(move |event, evl| { @@ -59,23 +60,15 @@ fn main() -> wry::Result<()> { } match event { - #[cfg(any( - target_os = "linux", - target_os = "dragonfly", - target_os = "freebsd", - target_os = "netbsd", - target_os = "openbsd", - ))] Event::WindowEvent { event: WindowEvent::Resized(size), .. } => { - use wry::dpi::{PhysicalPosition, PhysicalSize}; - - _webview - .set_bounds(wry::Rect { - position: PhysicalPosition::new(0, 0).into(), - size: PhysicalSize::new(size.width, size.height).into(), + let size = size.to_logical::(window.scale_factor()); + webview + .set_bounds(Rect { + position: LogicalPosition::new(0, 0).into(), + size: LogicalSize::new(size.width, size.height).into(), }) .unwrap(); }