mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Update winit to 0.28
Hopefully works better on wayland!
This commit is contained in:
parent
6fbca74e88
commit
f5445774de
629
Cargo.lock
generated
629
Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
@ -157,6 +157,8 @@ clap = { version = "4.2", features = ["derive"]}
|
||||
|
||||
[patch.crates-io]
|
||||
vek = { git = "https://github.com/yoanlcq/vek.git", rev = "84d5cb65841d46599a986c5477341bea4456be26" }
|
||||
# patch winit to support older raw-window-handle that works with old wgpu
|
||||
winit = { git = "https://github.com/Imberflur/winit.git", tag = "raw-window-handle-0.4-retro-support-v1" }
|
||||
# patch wgpu so we can use wgpu-profiler crate
|
||||
# wgpu = { git = "https://github.com/gfx-rs/wgpu.git", rev = "a92b8549a8e2cb9dac781bafc5ed32828f3caf46" }
|
||||
wgpu = { git = "https://github.com/pythonesque/wgpu.git", rev = "179ea209374a92837cde252f1d9ee01f628cae08" }
|
||||
@ -174,6 +176,9 @@ ntapi = { git = "https://github.com/MSxDOS/ntapi.git", rev = "9f56b149c9e2579673
|
||||
# gfx-backend-dx11 = { git = "https://github.com/gfx-rs/gfx.git", rev = "e305dcca3557923a6a8810162d8dd09cb45a43a6" }
|
||||
# gfx-backend-metal = { git = "https://github.com/gfx-rs/gfx.git", rev = "e305dcca3557923a6a8810162d8dd09cb45a43a6" }
|
||||
|
||||
# # Uncomment this to use a local fork of winit (for testing purposes)
|
||||
# winit = { path = "../winit" }
|
||||
|
||||
# # Uncomment this to use a local fork of wgpu (for testing purposes)
|
||||
# [patch.'https://github.com/gfx-rs/wgpu']
|
||||
# wgpu-core = { path = "../wgpu/wgpu-core" }
|
||||
|
@ -56,7 +56,7 @@ i18n-helpers = {package = "veloren-voxygen-i18n-helpers", path = "i18n-helpers"}
|
||||
voxygen-egui = {package = "veloren-voxygen-egui", path = "egui", optional = true }
|
||||
|
||||
# Graphics
|
||||
winit = {version = "0.25.0", features = ["serde"]}
|
||||
winit = {version = "0.28.6", features = ["serde"]}
|
||||
wgpu = { version = "=0.8.0", features = ["trace", "cross"] }
|
||||
wgpu-profiler = { git = "https://github.com/Imberflur/wgpu-profiler", tag = "wgpu-0.8" }
|
||||
bytemuck = { version="1.4", features=["derive"] }
|
||||
@ -71,16 +71,16 @@ cmake = "=0.1.45"
|
||||
conrod_core = {git = "https://gitlab.com/veloren/conrod.git", branch="copypasta_0.7"}
|
||||
conrod_winit = {git = "https://gitlab.com/veloren/conrod.git", branch="copypasta_0.7"}
|
||||
euc = "0.5.0"
|
||||
iced = {package = "iced_native", git = "https://github.com/Imberflur/iced", tag = "winit-0.25"}
|
||||
iced_winit = {git = "https://github.com/Imberflur/iced", tag = "winit-0.25"}
|
||||
window_clipboard = "0.2"
|
||||
iced = {package = "iced_native", git = "https://github.com/Imberflur/iced", tag = "veloren-winit-0.28"}
|
||||
iced_winit = {git = "https://github.com/Imberflur/iced", tag = "veloren-winit-0.28"}
|
||||
window_clipboard = "0.3"
|
||||
glyph_brush = "0.7.0"
|
||||
keyboard-keynames = "0.1.2"
|
||||
|
||||
# https://gitlab.com/Frinksy/keyboard-keynames/-/merge_requests/8
|
||||
keyboard-keynames = { git = "https://gitlab.com/Imbris/keyboard-keynames.git", tag = "veloren-winit-0.28" }
|
||||
# EGUI
|
||||
egui = {version = "0.12", optional = true }
|
||||
egui_wgpu_backend = {git = "https://github.com/hasenbanck/egui_wgpu_backend.git", rev = "63a002c6a9b6c016e45806dd065864431caab621", optional = true }
|
||||
egui_winit_platform = {version = "0.8", optional = true }
|
||||
egui_winit_platform = { git = "https://github.com/Imberflur/egui_winit_platform.git", tag = "veloren-winit-0.28", optional = true }
|
||||
|
||||
# ECS
|
||||
specs = { workspace = true, features = ["serde", "storage-event-control"] }
|
||||
@ -104,6 +104,7 @@ backtrace = "0.3.40"
|
||||
bincode = { workspace = true }
|
||||
chrono = { workspace = true }
|
||||
chumsky = "0.9"
|
||||
# TODO: unused
|
||||
cpal = "0.14"
|
||||
crossbeam-utils = { workspace = true }
|
||||
crossbeam-channel = { workspace = true }
|
||||
|
@ -12,7 +12,7 @@ be-dyn-lib = []
|
||||
client = {package = "veloren-client", path = "../../client"}
|
||||
common = {package = "veloren-common", path = "../../common"}
|
||||
egui = "0.12"
|
||||
egui_winit_platform = "0.8"
|
||||
egui_winit_platform = { git = "https://github.com/Imberflur/egui_winit_platform.git", tag = "veloren-winit-0.28" }
|
||||
lazy_static = { workspace = true }
|
||||
common-dynlib = {package = "veloren-common-dynlib", path = "../../common/dynlib", optional = true}
|
||||
|
||||
|
@ -1548,11 +1548,12 @@ impl<'a> Widget for Video<'a> {
|
||||
let bit_depths: Vec<u16> = correct_res
|
||||
.iter()
|
||||
.filter(
|
||||
|mode| match self.global_state.settings.graphics.fullscreen.refresh_rate {
|
||||
Some(refresh_rate) => mode.refresh_rate() == refresh_rate,
|
||||
|mode| match self.global_state.settings.graphics.fullscreen.refresh_rate_millihertz {
|
||||
Some(rate) => mode.refresh_rate_millihertz() == rate,
|
||||
None => true,
|
||||
},
|
||||
)
|
||||
// TODO: why do we sort by this and then map to it?
|
||||
.sorted_by_key(|mode| mode.bit_depth())
|
||||
.map(|mode| mode.bit_depth())
|
||||
.rev()
|
||||
@ -1601,7 +1602,7 @@ impl<'a> Widget for Video<'a> {
|
||||
}
|
||||
|
||||
// Refresh Rate
|
||||
let refresh_rates: Vec<u16> = correct_res
|
||||
let refresh_rates: Vec<u32> = correct_res
|
||||
.into_iter()
|
||||
.filter(
|
||||
|mode| match self.global_state.settings.graphics.fullscreen.bit_depth {
|
||||
@ -1609,8 +1610,9 @@ impl<'a> Widget for Video<'a> {
|
||||
None => true,
|
||||
},
|
||||
)
|
||||
.sorted_by_key(|mode| mode.refresh_rate())
|
||||
.map(|mode| mode.refresh_rate())
|
||||
// TODO: why do we sort by this and then map to it?
|
||||
.sorted_by_key(|mode| mode.refresh_rate_millihertz())
|
||||
.map(|mode| mode.refresh_rate_millihertz())
|
||||
.rev()
|
||||
.dedup()
|
||||
.collect();
|
||||
@ -1627,10 +1629,20 @@ impl<'a> Widget for Video<'a> {
|
||||
once(String::from(
|
||||
self.localized_strings.get_msg("common-automatic"),
|
||||
))
|
||||
.chain(refresh_rates.iter().map(|rate| format!("{}", rate)))
|
||||
.chain(
|
||||
refresh_rates
|
||||
.iter()
|
||||
.map(|&rate| format!("{:.1}", rate as f32 / 1000.0)),
|
||||
)
|
||||
.collect::<Vec<String>>()
|
||||
.as_slice(),
|
||||
match self.global_state.settings.graphics.fullscreen.refresh_rate {
|
||||
match self
|
||||
.global_state
|
||||
.settings
|
||||
.graphics
|
||||
.fullscreen
|
||||
.refresh_rate_millihertz
|
||||
{
|
||||
Some(refresh_rate) => refresh_rates
|
||||
.iter()
|
||||
.position(|rate| rate == &refresh_rate)
|
||||
@ -1647,7 +1659,7 @@ impl<'a> Widget for Video<'a> {
|
||||
.set(state.ids.refresh_rate, ui)
|
||||
{
|
||||
events.push(GraphicsChange::ChangeFullscreenMode(FullScreenSettings {
|
||||
refresh_rate: if clicked == 0 {
|
||||
refresh_rate_millihertz: if clicked == 0 {
|
||||
None
|
||||
} else {
|
||||
Some(refresh_rates[clicked - 1])
|
||||
|
@ -1028,9 +1028,21 @@ impl Window {
|
||||
pub fn is_cursor_grabbed(&self) -> bool { self.cursor_grabbed }
|
||||
|
||||
pub fn grab_cursor(&mut self, grab: bool) {
|
||||
use winit::window::CursorGrabMode;
|
||||
|
||||
self.cursor_grabbed = grab;
|
||||
self.window.set_cursor_visible(!grab);
|
||||
let _ = self.window.set_cursor_grab(grab);
|
||||
let res = if grab {
|
||||
self.window
|
||||
.set_cursor_grab(CursorGrabMode::Confined)
|
||||
.or_else(|_e| self.window.set_cursor_grab(CursorGrabMode::Locked))
|
||||
} else {
|
||||
self.window.set_cursor_grab(CursorGrabMode::None)
|
||||
};
|
||||
|
||||
if let Err(e) = res {
|
||||
error!(?e, ?grab, "Failed to toggle cursor grab");
|
||||
}
|
||||
}
|
||||
|
||||
/// Moves mouse cursor to center of screen
|
||||
@ -1073,7 +1085,7 @@ impl Window {
|
||||
&self,
|
||||
resolution: [u16; 2],
|
||||
bit_depth: Option<u16>,
|
||||
refresh_rate: Option<u16>,
|
||||
refresh_rate_millihertz: Option<u32>,
|
||||
correct_res: Option<Vec<VideoMode>>,
|
||||
correct_depth: Option<Option<VideoMode>>,
|
||||
correct_rate: Option<Option<VideoMode>>,
|
||||
@ -1103,14 +1115,14 @@ impl Window {
|
||||
.cloned()
|
||||
});
|
||||
|
||||
match refresh_rate {
|
||||
match refresh_rate_millihertz {
|
||||
// A bit depth and a refresh rate is given
|
||||
Some(rate) => {
|
||||
// analogous to correct_res
|
||||
let correct_rate = correct_rate.unwrap_or_else(|| {
|
||||
correct_res
|
||||
.iter()
|
||||
.find(|mode| mode.refresh_rate() == rate)
|
||||
.find(|mode| mode.refresh_rate_millihertz() == rate)
|
||||
.cloned()
|
||||
});
|
||||
|
||||
@ -1121,7 +1133,7 @@ impl Window {
|
||||
correct_res
|
||||
.iter()
|
||||
.filter(|mode| mode.bit_depth() == depth)
|
||||
.find(|mode| mode.refresh_rate() == rate)
|
||||
.find(|mode| mode.refresh_rate_millihertz() == rate)
|
||||
.cloned()
|
||||
.or_else(|| {
|
||||
if correct_depth.is_none() && correct_rate.is_none() {
|
||||
@ -1166,14 +1178,14 @@ impl Window {
|
||||
}
|
||||
},
|
||||
// No bit depth is given
|
||||
None => match refresh_rate {
|
||||
None => match refresh_rate_millihertz {
|
||||
// No bit depth and a refresh rate is given
|
||||
Some(rate) => {
|
||||
// analogous to correct_res
|
||||
let correct_rate = correct_rate.unwrap_or_else(|| {
|
||||
correct_res
|
||||
.iter()
|
||||
.find(|mode| mode.refresh_rate() == rate)
|
||||
.find(|mode| mode.refresh_rate_millihertz() == rate)
|
||||
.cloned()
|
||||
});
|
||||
|
||||
@ -1205,7 +1217,7 @@ impl Window {
|
||||
.into_iter()
|
||||
// Prefer bit depth over refresh rate
|
||||
.sorted_by_key(|mode| mode.bit_depth())
|
||||
.max_by_key(|mode| mode.refresh_rate()),
|
||||
.max_by_key(|mode| mode.refresh_rate_millihertz()),
|
||||
},
|
||||
}
|
||||
}
|
||||
@ -1214,7 +1226,7 @@ impl Window {
|
||||
&self,
|
||||
resolution: [u16; 2],
|
||||
bit_depth: Option<u16>,
|
||||
refresh_rate: Option<u16>,
|
||||
refresh_rate_millihertz: Option<u32>,
|
||||
) -> Option<VideoMode> {
|
||||
// (resolution, bit depth, refresh rate) represents a video mode
|
||||
// spec: as specified
|
||||
@ -1225,7 +1237,14 @@ impl Window {
|
||||
// (spec, spec, max), (spec, max, spec)
|
||||
// (spec, max, max)
|
||||
// (max, max, max)
|
||||
match self.select_video_mode_rec(resolution, bit_depth, refresh_rate, None, None, None) {
|
||||
match self.select_video_mode_rec(
|
||||
resolution,
|
||||
bit_depth,
|
||||
refresh_rate_millihertz,
|
||||
None,
|
||||
None,
|
||||
None,
|
||||
) {
|
||||
Some(mode) => Some(mode),
|
||||
// if there is no video mode with the specified resolution,
|
||||
// fall back to the video mode with max resolution, bit depth and refresh rate
|
||||
@ -1238,7 +1257,7 @@ impl Window {
|
||||
let mode = monitor
|
||||
.video_modes()
|
||||
// Prefer bit depth over refresh rate
|
||||
.sorted_by_key(|mode| mode.refresh_rate())
|
||||
.sorted_by_key(|mode| mode.refresh_rate_millihertz())
|
||||
.sorted_by_key(|mode| mode.bit_depth())
|
||||
.max_by_key(|mode| mode.size().width);
|
||||
|
||||
@ -1263,7 +1282,7 @@ impl Window {
|
||||
if let Some(video_mode) = self.select_video_mode(
|
||||
fullscreen.resolution,
|
||||
fullscreen.bit_depth,
|
||||
fullscreen.refresh_rate,
|
||||
fullscreen.refresh_rate_millihertz,
|
||||
) {
|
||||
winit::window::Fullscreen::Exclusive(video_mode)
|
||||
} else {
|
||||
@ -1411,7 +1430,7 @@ pub struct FullScreenSettings {
|
||||
pub mode: FullscreenMode,
|
||||
pub resolution: [u16; 2],
|
||||
pub bit_depth: Option<u16>,
|
||||
pub refresh_rate: Option<u16>,
|
||||
pub refresh_rate_millihertz: Option<u32>,
|
||||
}
|
||||
|
||||
impl Default for FullScreenSettings {
|
||||
@ -1421,7 +1440,7 @@ impl Default for FullScreenSettings {
|
||||
mode: FullscreenMode::Borderless,
|
||||
resolution: [1920, 1080],
|
||||
bit_depth: None,
|
||||
refresh_rate: None,
|
||||
refresh_rate_millihertz: None,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user