-
Notifications
You must be signed in to change notification settings - Fork 929
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
OSX: Default fullscreen-borderless window size is wrong? #2087
Comments
Yeah, I'm getting some weird results with that as well (on my machine, In general, most things on macOS don't work before the application has properly initialized ( Can you try it while actually running the application? For example using: use winit::{
event::{ElementState, Event, KeyboardInput, WindowEvent},
event_loop::{ControlFlow, EventLoop},
window::{Fullscreen, WindowBuilder},
};
fn main() {
let event_loop = EventLoop::new();
let window = WindowBuilder::new()
.with_fullscreen(Some(Fullscreen::Borderless(None)))
.build(&event_loop)
.unwrap();
event_loop.run(move |event, _, control_flow| {
*control_flow = ControlFlow::Wait;
match event {
// Any button press
Event::WindowEvent {
event: WindowEvent::KeyboardInput {
input: KeyboardInput {
state: ElementState::Pressed,
..
},
..
},
window_id,
} => {
for res in window.primary_monitor().unwrap().video_modes() {
println!("available: {:?}", res.size());
}
println!("current: {:?}", window.inner_size());
}
_ => (),
}
});
} |
@madsmtm
Also I just went to some random "what's my resolution" website and it reported 1440x900 (i.e. 2x the current size, which matches with the scale factor), so it seems like my system in general thinks I'm on 2880x1800. |
Well, at least it is now "just" a wrong scale calculation somewhere, compared to a "2880x1694 display" (I think it is accounting for the menu bar there). |
If I change my screen resolution in the Without really knowing anything about it, I think this is the "correct" result to return; in the end, something is going to render to the window based on what |
So what I'm trying to do is figuring out how to use it together with wgpu. It seems like if I set the gpu surface to anything smaller than 2880x1800, then I get a white border. But at the same time I want to present users with a selection of resolutions (specifically for people with large monitors who need to tune it down). Right now this is what I'm doing; I'm rendering to a texture 2560x1600 (or any chosen resolution), then I'm blitting that to the gpu surface (which is always 2880x1800 for me right now). Not sure if that's correct or not though (I'm guessing that means that in my application it's first upsampled a bit, and then downsampled again by the OS to match the display?). |
I'm pretty sure what you're doing here is the right way, but yes, it does mean there's some extra up n' downsampling going on. Alternatively you could allow the user to use |
yeah, that is the best approach - there is no great way of rendering at the physical pixel level in a Retina display mode that is not exactly 2x the size of the monitor. macOS and iOS do not support arbitrary ui scaling - all of apples ui elements have 1x (non-retina) 2x (retina) and 3x (super retina, iPhone only) versions, and the "physical" backing buffer is always 1x, 2x or 3x the "logical" display resolution, regardless of the pixel resolution of the monitor itself. window.inner_size() computes the "physical size" by multiplying the logical size returned by two - while going through the monitor for the list of its supported sizes returns the supported modes on the hardware level - completely separate from the logical display |
you could abuse #2050 and set the video mode to exclusive, then windowed, then borderless to set the resolution to a 1x mode :v (but that makes every other ui element and window look ugly) |
Hi,
Maybe I'm missing something, but this code:
Outputs:
on my MacBook Air M1 2020 (physical display resolution=2560x1600), running MacOs 12.0.1, using winit
0.26.0
.I.e. the current resolution is not among the available resolutions (and it's even larger than what my display supports).
The text was updated successfully, but these errors were encountered: