mirror of https://github.com/wayvr-org/wayvr.git
Compare commits
6 Commits
618bc8281c
...
c358cee954
| Author | SHA1 | Date |
|---|---|---|
|
|
c358cee954 | |
|
|
7e2033edd7 | |
|
|
51f3126cae | |
|
|
f6d6ff067f | |
|
|
2f6131f8d0 | |
|
|
c7037f8941 |
|
|
@ -0,0 +1 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 24 24"><!-- Icon from Material Symbols by Google - https://github.com/google/material-design-icons/blob/master/LICENSE --><path fill="currentColor" d="m12 22l-4.25-4.25l1.425-1.425L11 18.15V13H5.875L7.7 14.8l-1.45 1.45L2 12l4.225-4.225L7.65 9.2L5.85 11H11V5.85L9.175 7.675L7.75 6.25L12 2l4.25 4.25l-1.425 1.425L13 5.85V11h5.125L16.3 9.2l1.45-1.45L22 12l-4.25 4.25l-1.425-1.425L18.15 13H13v5.125l1.8-1.825l1.45 1.45z"/></svg>
|
||||||
|
After Width: | Height: | Size: 500 B |
|
|
@ -0,0 +1,46 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<svg
|
||||||
|
width="32"
|
||||||
|
height="32"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
version="1.1"
|
||||||
|
id="svg1"
|
||||||
|
sodipodi:docname="gravity.svg"
|
||||||
|
inkscape:version="1.4.4 (dcaf3e7d9e, 2026-05-05)"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg">
|
||||||
|
<sodipodi:namedview
|
||||||
|
id="namedview1"
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#000000"
|
||||||
|
borderopacity="0.25"
|
||||||
|
inkscape:showpageshadow="2"
|
||||||
|
inkscape:pageopacity="0.0"
|
||||||
|
inkscape:pagecheckerboard="0"
|
||||||
|
inkscape:deskcolor="#d1d1d1"
|
||||||
|
inkscape:zoom="23.234375"
|
||||||
|
inkscape:cx="17.861466"
|
||||||
|
inkscape:cy="22.488231"
|
||||||
|
inkscape:window-width="1582"
|
||||||
|
inkscape:window-height="1302"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="0"
|
||||||
|
inkscape:window-maximized="0"
|
||||||
|
inkscape:current-layer="svg1" />
|
||||||
|
<defs
|
||||||
|
id="defs1" />
|
||||||
|
<!-- Icon from Material Symbols by Google - https://github.com/google/material-design-icons/blob/master/LICENSE -->
|
||||||
|
<!-- Modified it a little bit, there's no "space gravity" icon available. -->
|
||||||
|
<path
|
||||||
|
fill="currentColor"
|
||||||
|
d="m 15.76786,18.274928 -1.391472,0.295932 -0.674684,-2.9751 -3.051267,-0.735557 -2.4062791,-3.292082 -0.8846145,1.824345 1.561484,2.213127 -1.1706157,0.808349 -1.9932655,-2.862487 1.752944,-3.7745856 Q 7.740355,9.2978686 8.2693798,9.1366908 8.7984057,8.9755132 9.3446883,8.9671549 9.9537305,8.9704882 10.547911,8.8283107 11.142091,8.6861403 11.667399,8.364791 12.192707,8.0434408 12.541821,7.5511898 12.890935,7.0589389 13.170167,6.5208564 l 1.228561,0.6477209 q -0.321651,0.575352 -0.696034,1.1164692 -0.374382,0.5411172 -0.890945,0.9726251 -0.466314,0.3718768 -0.998843,0.6112737 -0.532529,0.2393967 -1.117089,0.3386867 L 12,12 l 2.176682,-1.469824 4.352172,0.934365 -0.326914,1.35612 -3.582453,-0.734464 -2.11263,1.442217 2.281549,0.535655 z M 7.5517982,8.9044443 Q 7.0233673,9.1322023 6.4853273,8.9182692 5.9472884,8.7043353 5.7186139,8.1755407 5.4899403,7.6467461 5.7054294,7.108795 5.9209195,6.5708439 6.4475175,6.3423563 6.9741154,6.1138698 7.5149037,6.3288971 8.0556931,6.5439235 8.2807018,7.07126 8.5057095,7.5985974 8.2948017,8.1383704 8.0838948,8.6781445 7.5517982,8.9044443"
|
||||||
|
id="path1"
|
||||||
|
style="stroke-width:0.697484" />
|
||||||
|
<path
|
||||||
|
id="path2"
|
||||||
|
style="fill:none;stroke:currentColor;stroke-width:2.43525;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:0, 7.30575"
|
||||||
|
d="M 22.480952,12 C 22.480952,17.78847 17.78847,22.480952 12,22.480952 6.2115299,22.480952 1.5190477,17.78847 1.5190477,12 1.5190475,6.2115298 6.2115298,1.5190477 12,1.5190477 c 0.653263,0 1.292568,0.059766 1.912744,0.1741274 C 18.787854,2.5921561 22.480952,6.8647934 22.480952,12 Z"
|
||||||
|
sodipodi:nodetypes="ssssss" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 2.8 KiB |
|
|
@ -13,13 +13,13 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<template name="SliderSetting">
|
<template name="SliderSetting">
|
||||||
<label text="${text}" translation="${translation}" />
|
<Slider id="${id}" width="200" height="24" min_value="${min}" max_value="${max}" step="${step}" value="${value}" tooltip="${tooltip}" />
|
||||||
<Slider id="${id}" width="250" height="24" min_value="${min}" max_value="${max}" step="${step}" value="${value}" tooltip="${tooltip}" />
|
<label text="${text}" weight="bold" translation="${translation}" />
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<template name="RangeSetting">
|
<template name="RangeSetting">
|
||||||
<label text="${text}" translation="${translation}" />
|
<Slider id="${id}" width="200" height="24" min_value="${min}" max_value="${max}" step="${step}" value="${value}" value2="${value2}" tooltip="${tooltip}" />
|
||||||
<Slider id="${id}" width="250" height="24" min_value="${min}" max_value="${max}" step="${step}" value="${value}" value2="${value2}" tooltip="${tooltip}" />
|
<label text="${text}" weight="bold" translation="${translation}" />
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<template name="SelectSetting">
|
<template name="SelectSetting">
|
||||||
|
|
@ -56,6 +56,7 @@
|
||||||
<Tab name="skybox" translation="APP_SETTINGS.SKYBOX" sprite_src_builtin="dashboard/globe.svg" />
|
<Tab name="skybox" translation="APP_SETTINGS.SKYBOX" sprite_src_builtin="dashboard/globe.svg" />
|
||||||
<Tab name="features" translation="APP_SETTINGS.FEATURES" sprite_src_builtin="dashboard/options.svg" />
|
<Tab name="features" translation="APP_SETTINGS.FEATURES" sprite_src_builtin="dashboard/options.svg" />
|
||||||
<Tab name="controls" translation="APP_SETTINGS.CONTROLS" sprite_src_builtin="dashboard/controller.svg" />
|
<Tab name="controls" translation="APP_SETTINGS.CONTROLS" sprite_src_builtin="dashboard/controller.svg" />
|
||||||
|
<Tab name="space_drag" translation="APP_SETTINGS.SPACE_DRAG" sprite_src_builtin="dashboard/drag.svg" />
|
||||||
<Tab name="misc" translation="APP_SETTINGS.MISC" sprite_src_builtin="dashboard/blocks.svg" />
|
<Tab name="misc" translation="APP_SETTINGS.MISC" sprite_src_builtin="dashboard/blocks.svg" />
|
||||||
<Tab name="autostart_apps" translation="APP_SETTINGS.AUTOSTART_APPS" sprite_src_builtin="dashboard/apps.svg" />
|
<Tab name="autostart_apps" translation="APP_SETTINGS.AUTOSTART_APPS" sprite_src_builtin="dashboard/apps.svg" />
|
||||||
<Tab name="troubleshooting" translation="APP_SETTINGS.TROUBLESHOOTING" sprite_src_builtin="dashboard/cpu.svg" />
|
<Tab name="troubleshooting" translation="APP_SETTINGS.TROUBLESHOOTING" sprite_src_builtin="dashboard/cpu.svg" />
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,14 @@
|
||||||
|
<layout>
|
||||||
|
<include src="../t_group_box.xml" />
|
||||||
|
|
||||||
|
<elements>
|
||||||
|
<div id="common_options_parent" flex_direction="column" gap="8"/>
|
||||||
|
<rectangle macro="group_box">
|
||||||
|
<GroupBoxTitle src_builtin="dashboard/gravity.svg" translation="APP_SETTINGS.SPACE_GRAVITY_GRAVITY" />
|
||||||
|
<div id="gravity_enabled_parent"/>
|
||||||
|
<div id="space_gravity_parent" flex_direction="column" gap="8">
|
||||||
|
<!-- filled-in at runtime -->
|
||||||
|
</div>
|
||||||
|
</rectangle>
|
||||||
|
</elements>
|
||||||
|
</layout>
|
||||||
|
|
@ -55,6 +55,7 @@
|
||||||
"DELETE_ALL_CONFIGS_HELP": "Remove all configuration files from conf.d",
|
"DELETE_ALL_CONFIGS_HELP": "Remove all configuration files from conf.d",
|
||||||
"DOUBLE_CURSOR_FIX": "Double cursor fix",
|
"DOUBLE_CURSOR_FIX": "Double cursor fix",
|
||||||
"DOUBLE_CURSOR_FIX_HELP": "Enable this if you see 2 cursors",
|
"DOUBLE_CURSOR_FIX_HELP": "Enable this if you see 2 cursors",
|
||||||
|
"ENABLED": "Enabled",
|
||||||
"FEATURES": "Features",
|
"FEATURES": "Features",
|
||||||
"FOCUS_FOLLOWS_MOUSE_MODE": "Mouse move on trigger touch",
|
"FOCUS_FOLLOWS_MOUSE_MODE": "Mouse move on trigger touch",
|
||||||
"HANDSFREE_POINTER": "Handsfree mode",
|
"HANDSFREE_POINTER": "Handsfree mode",
|
||||||
|
|
@ -72,9 +73,10 @@
|
||||||
"LONG_PRESS_DURATION": "Long press duration",
|
"LONG_PRESS_DURATION": "Long press duration",
|
||||||
"LOOK_AND_FEEL": "Look & Feel",
|
"LOOK_AND_FEEL": "Look & Feel",
|
||||||
"MISC": "Miscellaneous",
|
"MISC": "Miscellaneous",
|
||||||
"NO_SKYMAPS_FOUND": "No skymaps found",
|
|
||||||
"NOTIFICATIONS_ENABLED": "Enable notifications",
|
"NOTIFICATIONS_ENABLED": "Enable notifications",
|
||||||
"NOTIFICATIONS_SOUND_ENABLED": "Notification sounds",
|
"NOTIFICATIONS_SOUND_ENABLED": "Notification sounds",
|
||||||
|
"NOT_SUPPORTED": "Not supported",
|
||||||
|
"NO_SKYMAPS_FOUND": "No skymaps found",
|
||||||
"OPAQUE_BACKGROUND": "Opaque background",
|
"OPAQUE_BACKGROUND": "Opaque background",
|
||||||
"OPTION": {
|
"OPTION": {
|
||||||
"AUTO": "Automatic",
|
"AUTO": "Automatic",
|
||||||
|
|
@ -103,8 +105,19 @@
|
||||||
"SETS_ON_WATCH": "Sets on watch",
|
"SETS_ON_WATCH": "Sets on watch",
|
||||||
"SKYBOX": "Skybox",
|
"SKYBOX": "Skybox",
|
||||||
"SKYMAP_ALREADY_DOWNLOADED": "This skymap is already downloaded. Select desired action.",
|
"SKYMAP_ALREADY_DOWNLOADED": "This skymap is already downloaded. Select desired action.",
|
||||||
|
"SPACE_DRAG": "Space drag",
|
||||||
"SPACE_DRAG_MULTIPLIER": "Space drag multiplier",
|
"SPACE_DRAG_MULTIPLIER": "Space drag multiplier",
|
||||||
"SPACE_DRAG_UNLOCKED": "Allow space drag on all axes",
|
"SPACE_DRAG_UNLOCKED": "Allow space drag on all axes",
|
||||||
|
"SPACE_GRAVITY_DAMPING": "Damping",
|
||||||
|
"SPACE_GRAVITY_DAMPING_HELP": "Artificial drag to slow down movement. 0.1 - high drag, 1.0 - no drag",
|
||||||
|
"SPACE_GRAVITY_FLING_STRENGTH": "Fling strength",
|
||||||
|
"SPACE_GRAVITY_FLING_STRENGTH_HELP": "Intensity multiplier of gravitational launch force after space-drag.\n0.0 - no movement at all, 2.0 - double intensity",
|
||||||
|
"SPACE_GRAVITY_GRAVITY": "Gravity",
|
||||||
|
"SPACE_GRAVITY_GRAVITY_HELP": "Amount of downwards force. 0.0 - no gravity",
|
||||||
|
"SPACE_GRAVITY_GROUND_FRICTION": "Ground friction",
|
||||||
|
"SPACE_GRAVITY_GROUND_FRICTION_HELP": "Amount of friction slowing you down if you're touching the ground.\n0.0 - no friction (just like on ice), 1.0 - rough surface",
|
||||||
|
"SPACE_GRAVITY_FLOOR_HEIGHT": "Floor height",
|
||||||
|
"SPACE_GRAVITY_FLOOR_HEIGHT_HELP": "The Y position where the floor is. Gravity stops when you reach this height.",
|
||||||
"SPACE_ROTATE_UNLOCKED": "Allow space rotate on all axes",
|
"SPACE_ROTATE_UNLOCKED": "Allow space rotate on all axes",
|
||||||
"TROUBLESHOOTING": "Troubleshooting",
|
"TROUBLESHOOTING": "Troubleshooting",
|
||||||
"UI_GRADIENT_INTENSITY": "UI Gradient intensity",
|
"UI_GRADIENT_INTENSITY": "UI Gradient intensity",
|
||||||
|
|
|
||||||
|
|
@ -295,8 +295,8 @@ impl AppList {
|
||||||
state: &Rc<RefCell<State>>,
|
state: &Rc<RefCell<State>>,
|
||||||
parser_state: &mut ParserState,
|
parser_state: &mut ParserState,
|
||||||
) -> anyhow::Result<()> {
|
) -> anyhow::Result<()> {
|
||||||
// load 4 entries for a single frame at most
|
// load 30 entries for a single frame at most
|
||||||
for _ in 0..4 {
|
for _ in 0..30 {
|
||||||
if let Some(entry) = self.entries_to_mount.pop_front() {
|
if let Some(entry) = self.entries_to_mount.pop_front() {
|
||||||
let globals = frontend.layout.state.globals.clone();
|
let globals = frontend.layout.state.globals.clone();
|
||||||
let button = self.mount_entry(frontend, parser_state, &doc_params(globals.clone()), &entry)?;
|
let button = self.mount_entry(frontend, parser_state, &doc_params(globals.clone()), &entry)?;
|
||||||
|
|
|
||||||
|
|
@ -39,29 +39,32 @@ mod tab_features;
|
||||||
mod tab_look_and_feel;
|
mod tab_look_and_feel;
|
||||||
mod tab_misc;
|
mod tab_misc;
|
||||||
mod tab_skybox;
|
mod tab_skybox;
|
||||||
|
mod tab_space_drag;
|
||||||
mod tab_troubleshooting;
|
mod tab_troubleshooting;
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
enum TabNameEnum {
|
enum TabNameEnum {
|
||||||
LookAndFeel,
|
|
||||||
Features,
|
|
||||||
Controls,
|
|
||||||
Misc,
|
|
||||||
AutostartApps,
|
AutostartApps,
|
||||||
Troubleshooting,
|
Controls,
|
||||||
|
Features,
|
||||||
|
LookAndFeel,
|
||||||
|
Misc,
|
||||||
Skybox,
|
Skybox,
|
||||||
|
SpaceDrag,
|
||||||
|
Troubleshooting,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TabNameEnum {
|
impl TabNameEnum {
|
||||||
fn from_string(s: &str) -> Option<Self> {
|
fn from_string(s: &str) -> Option<Self> {
|
||||||
match s {
|
match s {
|
||||||
"look_and_feel" => Some(TabNameEnum::LookAndFeel),
|
|
||||||
"features" => Some(TabNameEnum::Features),
|
|
||||||
"controls" => Some(TabNameEnum::Controls),
|
|
||||||
"misc" => Some(TabNameEnum::Misc),
|
|
||||||
"autostart_apps" => Some(TabNameEnum::AutostartApps),
|
"autostart_apps" => Some(TabNameEnum::AutostartApps),
|
||||||
"troubleshooting" => Some(TabNameEnum::Troubleshooting),
|
"controls" => Some(TabNameEnum::Controls),
|
||||||
|
"features" => Some(TabNameEnum::Features),
|
||||||
|
"look_and_feel" => Some(TabNameEnum::LookAndFeel),
|
||||||
|
"misc" => Some(TabNameEnum::Misc),
|
||||||
"skybox" => Some(TabNameEnum::Skybox),
|
"skybox" => Some(TabNameEnum::Skybox),
|
||||||
|
"space_drag" => Some(TabNameEnum::SpaceDrag),
|
||||||
|
"troubleshooting" => Some(TabNameEnum::Troubleshooting),
|
||||||
_ => None,
|
_ => None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -69,18 +72,18 @@ impl TabNameEnum {
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
enum Task {
|
enum Task {
|
||||||
UpdateBool(SettingType, bool),
|
|
||||||
UpdateFloat(SettingType, f32),
|
|
||||||
UpdateInt(SettingType, i32),
|
|
||||||
SettingUpdated(SettingType),
|
|
||||||
OpenContextMenu(Vec2, Vec<context_menu::Cell>),
|
|
||||||
ClearPipewireTokens,
|
ClearPipewireTokens,
|
||||||
ClearSavedState,
|
ClearSavedState,
|
||||||
DeleteAllConfigs,
|
DeleteAllConfigs,
|
||||||
|
OpenContextMenu(Vec2, Vec<context_menu::Cell>),
|
||||||
|
RemoveAutostartApp(Rc<str>),
|
||||||
ResetPlayspace,
|
ResetPlayspace,
|
||||||
RestartSoftware,
|
RestartSoftware,
|
||||||
RemoveAutostartApp(Rc<str>),
|
|
||||||
SetTab(TabNameEnum),
|
SetTab(TabNameEnum),
|
||||||
|
SettingUpdated(SettingType),
|
||||||
|
UpdateBool(SettingType, bool),
|
||||||
|
UpdateFloat(SettingType, f32),
|
||||||
|
UpdateInt(SettingType, i32),
|
||||||
}
|
}
|
||||||
|
|
||||||
struct SettingsMountParams<'a> {
|
struct SettingsMountParams<'a> {
|
||||||
|
|
@ -90,10 +93,20 @@ struct SettingsMountParams<'a> {
|
||||||
feats: InterfaceFeats,
|
feats: InterfaceFeats,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct SettingUpdatedParams<'a> {
|
||||||
|
layout: &'a mut Layout,
|
||||||
|
config: &'a GeneralConfig,
|
||||||
|
setting_type: SettingType,
|
||||||
|
}
|
||||||
|
|
||||||
trait SettingsTab {
|
trait SettingsTab {
|
||||||
fn update(&mut self, _par: &mut ViewUpdateParams) -> anyhow::Result<()> {
|
fn update(&mut self, _par: &mut ViewUpdateParams) -> anyhow::Result<()> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn setting_updated(&mut self, _sup: &mut SettingUpdatedParams) -> anyhow::Result<()> {
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct TabSettings<T> {
|
pub struct TabSettings<T> {
|
||||||
|
|
@ -203,12 +216,21 @@ impl<T> Tab<T> for TabSettings<T> {
|
||||||
changed = Some(ConfigChangeKind::OverlayConfig);
|
changed = Some(ConfigChangeKind::OverlayConfig);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Task::SettingUpdated(setting) => match setting {
|
Task::SettingUpdated(setting) => {
|
||||||
SettingType::UiAnimationSpeed | SettingType::UiGradientIntensity | SettingType::UiRoundMultiplier => {
|
if let Some(tab) = &mut self.current_tab {
|
||||||
// todo: currently, wayvr restart is required to apply these changes (WguiTheme is Rc)
|
tab.setting_updated(&mut SettingUpdatedParams {
|
||||||
|
layout: &mut frontend.layout,
|
||||||
|
config: frontend.interface.general_config(data),
|
||||||
|
setting_type: setting,
|
||||||
|
})?;
|
||||||
}
|
}
|
||||||
_ => { /* do nothing */ }
|
match setting {
|
||||||
},
|
SettingType::UiAnimationSpeed | SettingType::UiGradientIntensity | SettingType::UiRoundMultiplier => {
|
||||||
|
// todo: currently, wayvr restart is required to apply these changes (WguiTheme is Rc)
|
||||||
|
}
|
||||||
|
_ => { /* do nothing */ }
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -247,7 +269,7 @@ impl<T> Tab<T> for TabSettings<T> {
|
||||||
|
|
||||||
// Sorted alphabetically
|
// Sorted alphabetically
|
||||||
#[allow(clippy::enum_variant_names)]
|
#[allow(clippy::enum_variant_names)]
|
||||||
#[derive(Clone, Copy, AsRefStr, EnumString)]
|
#[derive(Clone, Copy, Eq, PartialEq, AsRefStr, EnumString)]
|
||||||
enum SettingType {
|
enum SettingType {
|
||||||
AllowSliding,
|
AllowSliding,
|
||||||
BlockGameInput,
|
BlockGameInput,
|
||||||
|
|
@ -258,6 +280,7 @@ enum SettingType {
|
||||||
Clock12h,
|
Clock12h,
|
||||||
DoubleCursorFix,
|
DoubleCursorFix,
|
||||||
FocusFollowsMouseMode,
|
FocusFollowsMouseMode,
|
||||||
|
GridOpacity,
|
||||||
HandsfreePointer,
|
HandsfreePointer,
|
||||||
HideGrabHelp,
|
HideGrabHelp,
|
||||||
HideUsername,
|
HideUsername,
|
||||||
|
|
@ -277,6 +300,12 @@ enum SettingType {
|
||||||
SetsOnWatch,
|
SetsOnWatch,
|
||||||
SpaceDragMultiplier,
|
SpaceDragMultiplier,
|
||||||
SpaceDragUnlocked,
|
SpaceDragUnlocked,
|
||||||
|
SpaceGravityDamping,
|
||||||
|
SpaceGravityEnabled,
|
||||||
|
SpaceGravityFlingStrength,
|
||||||
|
SpaceGravityGravity,
|
||||||
|
SpaceGravityGroundFriction,
|
||||||
|
SpaceGravityFloorHeight,
|
||||||
SpaceRotateUnlocked,
|
SpaceRotateUnlocked,
|
||||||
UiAnimationSpeed,
|
UiAnimationSpeed,
|
||||||
UiGradientIntensity,
|
UiGradientIntensity,
|
||||||
|
|
@ -284,7 +313,6 @@ enum SettingType {
|
||||||
UprightScreenFix,
|
UprightScreenFix,
|
||||||
UsePassthrough,
|
UsePassthrough,
|
||||||
UseSkybox,
|
UseSkybox,
|
||||||
GridOpacity,
|
|
||||||
WatchViewAngleMax,
|
WatchViewAngleMax,
|
||||||
WatchViewAngleMin,
|
WatchViewAngleMin,
|
||||||
XrClickSensitivity,
|
XrClickSensitivity,
|
||||||
|
|
@ -302,29 +330,30 @@ impl SettingType {
|
||||||
|
|
||||||
pub fn mut_bool(self, config: &mut GeneralConfig) -> &mut bool {
|
pub fn mut_bool(self, config: &mut GeneralConfig) -> &mut bool {
|
||||||
match self {
|
match self {
|
||||||
Self::InvertScrollDirectionX => &mut config.invert_scroll_direction_x,
|
|
||||||
Self::InvertScrollDirectionY => &mut config.invert_scroll_direction_y,
|
|
||||||
Self::NotificationsEnabled => &mut config.notifications_enabled,
|
|
||||||
Self::NotificationsSoundEnabled => &mut config.notifications_sound_enabled,
|
|
||||||
Self::KeyboardSoundEnabled => &mut config.keyboard_sound_enabled,
|
|
||||||
Self::UprightScreenFix => &mut config.upright_screen_fix,
|
|
||||||
Self::DoubleCursorFix => &mut config.double_cursor_fix,
|
|
||||||
Self::SetsOnWatch => &mut config.sets_on_watch,
|
|
||||||
Self::HideGrabHelp => &mut config.hide_grab_help,
|
|
||||||
Self::AllowSliding => &mut config.allow_sliding,
|
Self::AllowSliding => &mut config.allow_sliding,
|
||||||
Self::FocusFollowsMouseMode => &mut config.focus_follows_mouse_mode,
|
|
||||||
Self::LeftHandedMouse => &mut config.left_handed_mouse,
|
|
||||||
Self::BlockGameInput => &mut config.block_game_input,
|
Self::BlockGameInput => &mut config.block_game_input,
|
||||||
Self::BlockGameInputIgnoreWatch => &mut config.block_game_input_ignore_watch,
|
Self::BlockGameInputIgnoreWatch => &mut config.block_game_input_ignore_watch,
|
||||||
Self::BlockPosesOnKbdInteraction => &mut config.block_poses_on_kbd_interaction,
|
Self::BlockPosesOnKbdInteraction => &mut config.block_poses_on_kbd_interaction,
|
||||||
Self::UseSkybox => &mut config.use_skybox,
|
|
||||||
Self::UsePassthrough => &mut config.use_passthrough,
|
|
||||||
Self::ScreenRenderDown => &mut config.screen_render_down,
|
|
||||||
Self::SpaceDragUnlocked => &mut config.space_drag_unlocked,
|
|
||||||
Self::SpaceRotateUnlocked => &mut config.space_rotate_unlocked,
|
|
||||||
Self::Clock12h => &mut config.clock_12h,
|
Self::Clock12h => &mut config.clock_12h,
|
||||||
|
Self::DoubleCursorFix => &mut config.double_cursor_fix,
|
||||||
|
Self::FocusFollowsMouseMode => &mut config.focus_follows_mouse_mode,
|
||||||
|
Self::HideGrabHelp => &mut config.hide_grab_help,
|
||||||
Self::HideUsername => &mut config.hide_username,
|
Self::HideUsername => &mut config.hide_username,
|
||||||
|
Self::InvertScrollDirectionX => &mut config.invert_scroll_direction_x,
|
||||||
|
Self::InvertScrollDirectionY => &mut config.invert_scroll_direction_y,
|
||||||
|
Self::KeyboardSoundEnabled => &mut config.keyboard_sound_enabled,
|
||||||
|
Self::LeftHandedMouse => &mut config.left_handed_mouse,
|
||||||
|
Self::NotificationsEnabled => &mut config.notifications_enabled,
|
||||||
|
Self::NotificationsSoundEnabled => &mut config.notifications_sound_enabled,
|
||||||
Self::OpaqueBackground => &mut config.opaque_background,
|
Self::OpaqueBackground => &mut config.opaque_background,
|
||||||
|
Self::ScreenRenderDown => &mut config.screen_render_down,
|
||||||
|
Self::SetsOnWatch => &mut config.sets_on_watch,
|
||||||
|
Self::SpaceDragUnlocked => &mut config.space_drag_unlocked,
|
||||||
|
Self::SpaceGravityEnabled => &mut config.space_gravity_enabled,
|
||||||
|
Self::SpaceRotateUnlocked => &mut config.space_rotate_unlocked,
|
||||||
|
Self::UprightScreenFix => &mut config.upright_screen_fix,
|
||||||
|
Self::UsePassthrough => &mut config.use_passthrough,
|
||||||
|
Self::UseSkybox => &mut config.use_skybox,
|
||||||
Self::XwaylandByDefault => &mut config.xwayland_by_default,
|
Self::XwaylandByDefault => &mut config.xwayland_by_default,
|
||||||
_ => panic!("Requested bool for non-bool SettingType"),
|
_ => panic!("Requested bool for non-bool SettingType"),
|
||||||
}
|
}
|
||||||
|
|
@ -332,18 +361,23 @@ impl SettingType {
|
||||||
|
|
||||||
pub fn mut_f32(self, config: &mut GeneralConfig) -> &mut f32 {
|
pub fn mut_f32(self, config: &mut GeneralConfig) -> &mut f32 {
|
||||||
match self {
|
match self {
|
||||||
|
Self::GridOpacity => &mut config.grid_opacity,
|
||||||
|
Self::LongPressDuration => &mut config.long_press_duration,
|
||||||
|
Self::PointerLerpFactor => &mut config.pointer_lerp_factor,
|
||||||
|
Self::ScrollSpeed => &mut config.scroll_speed,
|
||||||
|
Self::SpaceDragMultiplier => &mut config.space_drag_multiplier,
|
||||||
|
Self::SpaceGravityDamping => &mut config.space_gravity_damping,
|
||||||
|
Self::SpaceGravityFlingStrength => &mut config.space_gravity_fling_strength,
|
||||||
|
Self::SpaceGravityGravity => &mut config.space_gravity_gravity,
|
||||||
|
Self::SpaceGravityGroundFriction => &mut config.space_gravity_ground_friction,
|
||||||
|
Self::SpaceGravityFloorHeight => &mut config.space_gravity_floor_height,
|
||||||
Self::UiAnimationSpeed => &mut config.ui_animation_speed,
|
Self::UiAnimationSpeed => &mut config.ui_animation_speed,
|
||||||
Self::UiGradientIntensity => &mut config.ui_gradient_intensity,
|
Self::UiGradientIntensity => &mut config.ui_gradient_intensity,
|
||||||
Self::UiRoundMultiplier => &mut config.ui_round_multiplier,
|
Self::UiRoundMultiplier => &mut config.ui_round_multiplier,
|
||||||
Self::ScrollSpeed => &mut config.scroll_speed,
|
|
||||||
Self::LongPressDuration => &mut config.long_press_duration,
|
|
||||||
Self::XrClickSensitivity => &mut config.xr_click_sensitivity,
|
|
||||||
Self::XrClickSensitivityRelease => &mut config.xr_click_sensitivity_release,
|
|
||||||
Self::SpaceDragMultiplier => &mut config.space_drag_multiplier,
|
|
||||||
Self::PointerLerpFactor => &mut config.pointer_lerp_factor,
|
|
||||||
Self::GridOpacity => &mut config.grid_opacity,
|
|
||||||
Self::WatchViewAngleMax => &mut config.watch_view_angle_max,
|
Self::WatchViewAngleMax => &mut config.watch_view_angle_max,
|
||||||
Self::WatchViewAngleMin => &mut config.watch_view_angle_min,
|
Self::WatchViewAngleMin => &mut config.watch_view_angle_min,
|
||||||
|
Self::XrClickSensitivity => &mut config.xr_click_sensitivity,
|
||||||
|
Self::XrClickSensitivityRelease => &mut config.xr_click_sensitivity_release,
|
||||||
_ => panic!("Requested f32 for non-f32 SettingType"),
|
_ => panic!("Requested f32 for non-f32 SettingType"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -438,6 +472,12 @@ impl SettingType {
|
||||||
Self::SetsOnWatch => Ok("APP_SETTINGS.SETS_ON_WATCH"),
|
Self::SetsOnWatch => Ok("APP_SETTINGS.SETS_ON_WATCH"),
|
||||||
Self::SpaceDragMultiplier => Ok("APP_SETTINGS.SPACE_DRAG_MULTIPLIER"),
|
Self::SpaceDragMultiplier => Ok("APP_SETTINGS.SPACE_DRAG_MULTIPLIER"),
|
||||||
Self::SpaceDragUnlocked => Ok("APP_SETTINGS.SPACE_DRAG_UNLOCKED"),
|
Self::SpaceDragUnlocked => Ok("APP_SETTINGS.SPACE_DRAG_UNLOCKED"),
|
||||||
|
Self::SpaceGravityDamping => Ok("APP_SETTINGS.SPACE_GRAVITY_DAMPING"),
|
||||||
|
Self::SpaceGravityEnabled => Ok("APP_SETTINGS.ENABLED"),
|
||||||
|
Self::SpaceGravityFlingStrength => Ok("APP_SETTINGS.SPACE_GRAVITY_FLING_STRENGTH"),
|
||||||
|
Self::SpaceGravityGravity => Ok("APP_SETTINGS.SPACE_GRAVITY_GRAVITY"),
|
||||||
|
Self::SpaceGravityGroundFriction => Ok("APP_SETTINGS.SPACE_GRAVITY_GROUND_FRICTION"),
|
||||||
|
Self::SpaceGravityFloorHeight => Ok("APP_SETTINGS.SPACE_GRAVITY_FLOOR_HEIGHT"),
|
||||||
Self::SpaceRotateUnlocked => Ok("APP_SETTINGS.SPACE_ROTATE_UNLOCKED"),
|
Self::SpaceRotateUnlocked => Ok("APP_SETTINGS.SPACE_ROTATE_UNLOCKED"),
|
||||||
Self::UiAnimationSpeed => Ok("APP_SETTINGS.ANIMATION_SPEED"),
|
Self::UiAnimationSpeed => Ok("APP_SETTINGS.ANIMATION_SPEED"),
|
||||||
Self::UiGradientIntensity => Ok("APP_SETTINGS.UI_GRADIENT_INTENSITY"),
|
Self::UiGradientIntensity => Ok("APP_SETTINGS.UI_GRADIENT_INTENSITY"),
|
||||||
|
|
@ -466,13 +506,18 @@ impl SettingType {
|
||||||
Self::KeyboardMiddleClick => Some("APP_SETTINGS.KEYBOARD_MIDDLE_CLICK_HELP"),
|
Self::KeyboardMiddleClick => Some("APP_SETTINGS.KEYBOARD_MIDDLE_CLICK_HELP"),
|
||||||
Self::LeftHandedMouse => Some("APP_SETTINGS.LEFT_HANDED_MOUSE_HELP"),
|
Self::LeftHandedMouse => Some("APP_SETTINGS.LEFT_HANDED_MOUSE_HELP"),
|
||||||
Self::ScreenRenderDown => Some("APP_SETTINGS.SCREEN_RENDER_DOWN_HELP"),
|
Self::ScreenRenderDown => Some("APP_SETTINGS.SCREEN_RENDER_DOWN_HELP"),
|
||||||
|
Self::SpaceGravityDamping => Some("APP_SETTINGS.SPACE_GRAVITY_DAMPING_HELP"),
|
||||||
|
Self::SpaceGravityFlingStrength => Some("APP_SETTINGS.SPACE_GRAVITY_FLING_STRENGTH_HELP"),
|
||||||
|
Self::SpaceGravityFloorHeight => Some("APP_SETTINGS.SPACE_GRAVITY_FLOOR_HEIGHT_HELP"),
|
||||||
|
Self::SpaceGravityGravity => Some("APP_SETTINGS.SPACE_GRAVITY_GRAVITY_HELP"),
|
||||||
|
Self::SpaceGravityGroundFriction => Some("APP_SETTINGS.SPACE_GRAVITY_GROUND_FRICTION_HELP"),
|
||||||
Self::UprightScreenFix => Some("APP_SETTINGS.UPRIGHT_SCREEN_FIX_HELP"),
|
Self::UprightScreenFix => Some("APP_SETTINGS.UPRIGHT_SCREEN_FIX_HELP"),
|
||||||
Self::UsePassthrough => Some("APP_SETTINGS.USE_PASSTHROUGH_HELP"),
|
Self::UsePassthrough => Some("APP_SETTINGS.USE_PASSTHROUGH_HELP"),
|
||||||
Self::UseSkybox => Some("APP_SETTINGS.USE_SKYBOX_HELP"),
|
Self::UseSkybox => Some("APP_SETTINGS.USE_SKYBOX_HELP"),
|
||||||
|
Self::WatchViewAngleMax => Some("APP_SETTINGS.WATCH_VIEW_ANGLE_HELP"),
|
||||||
|
Self::WatchViewAngleMin => Some("APP_SETTINGS.WATCH_VIEW_ANGLE_HELP"),
|
||||||
Self::XrClickSensitivity => Some("APP_SETTINGS.XR_CLICK_SENSITIVITY_HELP"),
|
Self::XrClickSensitivity => Some("APP_SETTINGS.XR_CLICK_SENSITIVITY_HELP"),
|
||||||
Self::XrClickSensitivityRelease => Some("APP_SETTINGS.XR_CLICK_SENSITIVITY_HELP"),
|
Self::XrClickSensitivityRelease => Some("APP_SETTINGS.XR_CLICK_SENSITIVITY_HELP"),
|
||||||
Self::WatchViewAngleMin => Some("APP_SETTINGS.WATCH_VIEW_ANGLE_HELP"),
|
|
||||||
Self::WatchViewAngleMax => Some("APP_SETTINGS.WATCH_VIEW_ANGLE_HELP"),
|
|
||||||
_ => None,
|
_ => None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -575,6 +620,9 @@ impl<T> TabSettings<T> {
|
||||||
TabNameEnum::Features => {
|
TabNameEnum::Features => {
|
||||||
self.current_tab = Some(Box::new(tab_features::State::mount(settings_mount_params)?));
|
self.current_tab = Some(Box::new(tab_features::State::mount(settings_mount_params)?));
|
||||||
}
|
}
|
||||||
|
TabNameEnum::SpaceDrag => {
|
||||||
|
self.current_tab = Some(Box::new(tab_space_drag::State::mount(settings_mount_params)?));
|
||||||
|
}
|
||||||
TabNameEnum::Controls => {
|
TabNameEnum::Controls => {
|
||||||
self.current_tab = Some(Box::new(tab_controls::State::mount(settings_mount_params)?));
|
self.current_tab = Some(Box::new(tab_controls::State::mount(settings_mount_params)?));
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
use crate::tab::settings::{
|
use crate::tab::settings::{
|
||||||
macros::{options_category, options_checkbox, options_range_f32, options_slider_f32},
|
|
||||||
SettingType, SettingsMountParams, SettingsTab,
|
SettingType, SettingsMountParams, SettingsTab,
|
||||||
|
macros::{options_category, options_checkbox, options_range_f32},
|
||||||
};
|
};
|
||||||
|
|
||||||
pub struct State {}
|
pub struct State {}
|
||||||
|
|
@ -13,15 +13,6 @@ impl State {
|
||||||
options_checkbox(par.mp, c, SettingType::NotificationsEnabled)?;
|
options_checkbox(par.mp, c, SettingType::NotificationsEnabled)?;
|
||||||
options_checkbox(par.mp, c, SettingType::NotificationsSoundEnabled)?;
|
options_checkbox(par.mp, c, SettingType::NotificationsSoundEnabled)?;
|
||||||
options_checkbox(par.mp, c, SettingType::KeyboardSoundEnabled)?;
|
options_checkbox(par.mp, c, SettingType::KeyboardSoundEnabled)?;
|
||||||
if !par.feats.openxr || par.feats.monado {
|
|
||||||
// monado or openvr
|
|
||||||
options_checkbox(par.mp, c, SettingType::SpaceDragUnlocked)?;
|
|
||||||
options_slider_f32(par.mp, c, SettingType::SpaceDragMultiplier, -10.0, 10.0, 0.5)?;
|
|
||||||
}
|
|
||||||
if par.feats.monado {
|
|
||||||
// openvr can only ever rotate yaw
|
|
||||||
options_checkbox(par.mp, c, SettingType::SpaceRotateUnlocked)?;
|
|
||||||
}
|
|
||||||
if !par.feats.openxr || par.feats.monado {
|
if !par.feats.openxr || par.feats.monado {
|
||||||
// monado or openvr
|
// monado or openvr
|
||||||
options_checkbox(par.mp, c, SettingType::BlockGameInput)?;
|
options_checkbox(par.mp, c, SettingType::BlockGameInput)?;
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,138 @@
|
||||||
|
use wgui::{
|
||||||
|
assets::AssetPath,
|
||||||
|
i18n::Translation,
|
||||||
|
layout::{Layout, LayoutTask, WidgetID},
|
||||||
|
parser::{Fetchable, ParseDocumentParams},
|
||||||
|
};
|
||||||
|
|
||||||
|
use crate::{
|
||||||
|
tab::settings::{
|
||||||
|
SettingType, SettingsMountParams, SettingsTab,
|
||||||
|
macros::{options_category, options_checkbox, options_slider_f32},
|
||||||
|
},
|
||||||
|
util::wgui_simple,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub struct State {
|
||||||
|
id_space_gravity_parent: WidgetID,
|
||||||
|
}
|
||||||
|
|
||||||
|
fn set_visible(parent: WidgetID, layout: &mut Layout, n: bool) {
|
||||||
|
layout.tasks.push(LayoutTask::SetWidgetVisible(parent, n));
|
||||||
|
}
|
||||||
|
|
||||||
|
impl SettingsTab for State {
|
||||||
|
fn setting_updated(&mut self, sup: &mut super::SettingUpdatedParams) -> anyhow::Result<()> {
|
||||||
|
if sup.setting_type == SettingType::SpaceGravityEnabled {
|
||||||
|
set_visible(
|
||||||
|
self.id_space_gravity_parent,
|
||||||
|
sup.layout,
|
||||||
|
sup.config.space_gravity_enabled,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl State {
|
||||||
|
pub fn mount(par: SettingsMountParams) -> anyhow::Result<State> {
|
||||||
|
let c = options_category(par.mp, par.id_parent, "APP_SETTINGS.SPACE_DRAG", "dashboard/drag.svg")?;
|
||||||
|
|
||||||
|
let globals = par.mp.layout.state.globals.clone();
|
||||||
|
|
||||||
|
let tab_state = wgui::parser::parse_from_assets(
|
||||||
|
&ParseDocumentParams {
|
||||||
|
globals,
|
||||||
|
path: AssetPath::BuiltIn("gui/tab/settings_tab_space_drag.xml"),
|
||||||
|
extra: Default::default(),
|
||||||
|
},
|
||||||
|
par.mp.layout,
|
||||||
|
c,
|
||||||
|
)?;
|
||||||
|
|
||||||
|
let id_common_options_parent = tab_state.get_widget_id("common_options_parent")?;
|
||||||
|
let id_gravity_enabled_parent = tab_state.get_widget_id("gravity_enabled_parent")?;
|
||||||
|
let id_space_gravity_parent = tab_state.get_widget_id("space_gravity_parent")?;
|
||||||
|
|
||||||
|
if !par.feats.openxr || par.feats.monado {
|
||||||
|
// monado or openvr
|
||||||
|
options_checkbox(par.mp, id_common_options_parent, SettingType::SpaceDragUnlocked)?;
|
||||||
|
|
||||||
|
options_slider_f32(
|
||||||
|
par.mp,
|
||||||
|
id_common_options_parent,
|
||||||
|
SettingType::SpaceDragMultiplier,
|
||||||
|
-10.0,
|
||||||
|
10.0,
|
||||||
|
0.5,
|
||||||
|
)?;
|
||||||
|
}
|
||||||
|
|
||||||
|
if par.feats.monado {
|
||||||
|
// openvr can only ever rotate yaw
|
||||||
|
options_checkbox(par.mp, id_common_options_parent, SettingType::SpaceRotateUnlocked)?;
|
||||||
|
}
|
||||||
|
|
||||||
|
if par.feats.monado {
|
||||||
|
/* space gravity section */
|
||||||
|
options_checkbox(par.mp, id_gravity_enabled_parent, SettingType::SpaceGravityEnabled)?;
|
||||||
|
|
||||||
|
options_slider_f32(
|
||||||
|
par.mp,
|
||||||
|
id_space_gravity_parent,
|
||||||
|
SettingType::SpaceGravityGravity,
|
||||||
|
0.0,
|
||||||
|
10.0,
|
||||||
|
0.5,
|
||||||
|
)?;
|
||||||
|
options_slider_f32(
|
||||||
|
par.mp,
|
||||||
|
id_space_gravity_parent,
|
||||||
|
SettingType::SpaceGravityDamping,
|
||||||
|
0.1,
|
||||||
|
1.0,
|
||||||
|
0.01,
|
||||||
|
)?;
|
||||||
|
options_slider_f32(
|
||||||
|
par.mp,
|
||||||
|
id_space_gravity_parent,
|
||||||
|
SettingType::SpaceGravityFlingStrength,
|
||||||
|
0.0,
|
||||||
|
3.0,
|
||||||
|
0.1,
|
||||||
|
)?;
|
||||||
|
options_slider_f32(
|
||||||
|
par.mp,
|
||||||
|
id_space_gravity_parent,
|
||||||
|
SettingType::SpaceGravityGroundFriction,
|
||||||
|
0.0,
|
||||||
|
1.0,
|
||||||
|
0.01,
|
||||||
|
)?;
|
||||||
|
options_slider_f32(
|
||||||
|
par.mp,
|
||||||
|
id_space_gravity_parent,
|
||||||
|
SettingType::SpaceGravityFloorHeight,
|
||||||
|
-5.0,
|
||||||
|
5.0,
|
||||||
|
0.1,
|
||||||
|
)?;
|
||||||
|
} else {
|
||||||
|
wgui_simple::create_label(
|
||||||
|
par.mp.layout,
|
||||||
|
id_gravity_enabled_parent,
|
||||||
|
Translation::from_translation_key("APP_SETTINGS.NOT_SUPPORTED"),
|
||||||
|
)?;
|
||||||
|
}
|
||||||
|
|
||||||
|
set_visible(
|
||||||
|
id_space_gravity_parent,
|
||||||
|
par.mp.layout,
|
||||||
|
par.mp.config.space_gravity_enabled,
|
||||||
|
);
|
||||||
|
|
||||||
|
Ok(State {
|
||||||
|
id_space_gravity_parent,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -6,12 +6,11 @@ use std::{
|
||||||
use wgui::{
|
use wgui::{
|
||||||
assets::AssetPath,
|
assets::AssetPath,
|
||||||
components::button::ComponentButton,
|
components::button::ComponentButton,
|
||||||
event::{EventAlterables, StyleSetRequest},
|
event::EventAlterables,
|
||||||
globals::WguiGlobals,
|
globals::WguiGlobals,
|
||||||
i18n::Translation,
|
i18n::Translation,
|
||||||
layout::{Layout, LayoutTask, LayoutTasks, WidgetID},
|
layout::{Layout, LayoutTask, LayoutTasks, WidgetID},
|
||||||
parser::{Fetchable, ParseDocumentParams, ParserState},
|
parser::{Fetchable, ParseDocumentParams, ParserState},
|
||||||
taffy::Display,
|
|
||||||
widget::label::WidgetLabel,
|
widget::label::WidgetLabel,
|
||||||
};
|
};
|
||||||
use wlx_common::config::GeneralConfig;
|
use wlx_common::config::GeneralConfig;
|
||||||
|
|
@ -232,15 +231,7 @@ impl State {
|
||||||
let popup = popup.upgrade().unwrap(); // safe
|
let popup = popup.upgrade().unwrap(); // safe
|
||||||
let popup = popup.borrow_mut();
|
let popup = popup.borrow_mut();
|
||||||
let mounted_popup = popup.mounted_popup.as_ref().unwrap(); // safe;
|
let mounted_popup = popup.mounted_popup.as_ref().unwrap(); // safe;
|
||||||
|
alterables.set_widget_visible(mounted_popup.id_root, idx == self.popup_stack.len() - 1);
|
||||||
alterables.set_style(
|
|
||||||
mounted_popup.id_root,
|
|
||||||
StyleSetRequest::Display(if idx == self.popup_stack.len() - 1 {
|
|
||||||
Display::Flex
|
|
||||||
} else {
|
|
||||||
Display::None
|
|
||||||
}),
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -112,10 +112,7 @@ impl View {
|
||||||
fn fill_list(&mut self, layout: &mut Layout, games: Vec<steam_utils::RunningGame>) -> anyhow::Result<()> {
|
fn fill_list(&mut self, layout: &mut Layout, games: Vec<steam_utils::RunningGame>) -> anyhow::Result<()> {
|
||||||
if games.is_empty() {
|
if games.is_empty() {
|
||||||
// hide self
|
// hide self
|
||||||
layout.tasks.push(LayoutTask::SetWidgetStyle(
|
layout.tasks.push(LayoutTask::SetWidgetVisible(self.parent_id, false));
|
||||||
self.parent_id,
|
|
||||||
StyleSetRequest::Display(Display::None),
|
|
||||||
));
|
|
||||||
return Ok(());
|
return Ok(());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -13,7 +13,6 @@ use wgui::{
|
||||||
checkbox::ComponentCheckbox,
|
checkbox::ComponentCheckbox,
|
||||||
},
|
},
|
||||||
drawing::Color,
|
drawing::Color,
|
||||||
event::StyleSetRequest,
|
|
||||||
font_config::WguiFontConfig,
|
font_config::WguiFontConfig,
|
||||||
globals::WguiGlobals,
|
globals::WguiGlobals,
|
||||||
i18n::Translation,
|
i18n::Translation,
|
||||||
|
|
@ -134,14 +133,9 @@ impl TestbedGeneric {
|
||||||
let div_visibility = parser_state.fetch_widget(&layout.state, "div_visibility")?;
|
let div_visibility = parser_state.fetch_widget(&layout.state, "div_visibility")?;
|
||||||
|
|
||||||
cb_visible.on_toggle(Box::new(move |common, evt| {
|
cb_visible.on_toggle(Box::new(move |common, evt| {
|
||||||
common.alterables.set_style(
|
common
|
||||||
div_visibility.id,
|
.alterables
|
||||||
StyleSetRequest::Display(if evt.checked {
|
.set_widget_visible(div_visibility.id, evt.checked);
|
||||||
taffy::Display::Flex
|
|
||||||
} else {
|
|
||||||
taffy::Display::None
|
|
||||||
}),
|
|
||||||
);
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,5 @@
|
||||||
pub mod input;
|
pub mod input;
|
||||||
|
pub mod playspace_common;
|
||||||
|
|
||||||
#[cfg(feature = "openvr")]
|
#[cfg(feature = "openvr")]
|
||||||
pub mod openvr;
|
pub mod openvr;
|
||||||
|
|
|
||||||
|
|
@ -146,8 +146,12 @@ pub fn openvr_run(
|
||||||
let mut lines = LinePool::new(app.gfx.clone())?;
|
let mut lines = LinePool::new(app.gfx.clone())?;
|
||||||
let pointer_lines = [lines.allocate(), lines.allocate()];
|
let pointer_lines = [lines.allocate(), lines.allocate()];
|
||||||
let mut current_lines = Vec::with_capacity(2);
|
let mut current_lines = Vec::with_capacity(2);
|
||||||
|
let mut last_frame_time = Instant::now();
|
||||||
|
|
||||||
'main_loop: loop {
|
'main_loop: loop {
|
||||||
|
let now = Instant::now();
|
||||||
|
app.delta_time = (now.duration_since(last_frame_time).as_secs_f32()).clamp(0.001, 0.2); // 5 - 1000 fps
|
||||||
|
last_frame_time = now;
|
||||||
let _ = overlay_mgr.wait_frame_sync(frame_timeout);
|
let _ = overlay_mgr.wait_frame_sync(frame_timeout);
|
||||||
|
|
||||||
if !RUNNING.load(Ordering::Relaxed) {
|
if !RUNNING.load(Ordering::Relaxed) {
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@ use ovr_overlay::{
|
||||||
};
|
};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
backend::{input::InputState, task::PlayspaceTask},
|
backend::{input::InputState, playspace_common, task::PlayspaceTask},
|
||||||
state::AppState,
|
state::AppState,
|
||||||
windowing::manager::OverlayWindowManager,
|
windowing::manager::OverlayWindowManager,
|
||||||
};
|
};
|
||||||
|
|
@ -137,16 +137,7 @@ impl PlayspaceMover {
|
||||||
}
|
}
|
||||||
|
|
||||||
let overlay_offset = data.pose.inverse().transform_vector3a(relative_pos) * -1.0;
|
let overlay_offset = data.pose.inverse().transform_vector3a(relative_pos) * -1.0;
|
||||||
|
playspace_common::shift_overlays(overlays, overlay_offset);
|
||||||
overlays.values_mut().for_each(|overlay| {
|
|
||||||
let Some(state) = overlay.config.active_state.as_mut() else {
|
|
||||||
return;
|
|
||||||
};
|
|
||||||
if state.positioning.moves_with_space() {
|
|
||||||
state.transform.translation += overlay_offset;
|
|
||||||
overlay.config.dirty = true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
data.pose.translation += relative_pos;
|
data.pose.translation += relative_pos;
|
||||||
data.hand_pose = new_hand;
|
data.hand_pose = new_hand;
|
||||||
|
|
|
||||||
|
|
@ -94,7 +94,7 @@ pub fn openxr_run(
|
||||||
|
|
||||||
app.monado_state_init();
|
app.monado_state_init();
|
||||||
|
|
||||||
let mut playspace = app.monado_state.as_mut().and_then(|m| {
|
let mut playspace_mover = app.monado_state.as_mut().and_then(|m| {
|
||||||
playspace::PlayspaceMover::new(&mut m.ipc)
|
playspace::PlayspaceMover::new(&mut m.ipc)
|
||||||
.map_err(|e| log::warn!("Will not use Monado playspace mover: {e}"))
|
.map_err(|e| log::warn!("Will not use Monado playspace mover: {e}"))
|
||||||
.ok()
|
.ok()
|
||||||
|
|
@ -155,8 +155,12 @@ pub fn openxr_run(
|
||||||
|
|
||||||
let mut main_session_visible = false;
|
let mut main_session_visible = false;
|
||||||
let mut environment_blend_mode = modes[0];
|
let mut environment_blend_mode = modes[0];
|
||||||
|
let mut last_frame_time = Instant::now();
|
||||||
|
|
||||||
'main_loop: loop {
|
'main_loop: loop {
|
||||||
|
let now = Instant::now();
|
||||||
|
app.delta_time = (now.duration_since(last_frame_time).as_secs_f32()).clamp(0.001, 0.2); // 5 - 1000 fps
|
||||||
|
last_frame_time = now;
|
||||||
let cur_frame = FRAME_COUNTER.fetch_add(1, Ordering::Relaxed);
|
let cur_frame = FRAME_COUNTER.fetch_add(1, Ordering::Relaxed);
|
||||||
|
|
||||||
if !RUNNING.load(Ordering::Relaxed) {
|
if !RUNNING.load(Ordering::Relaxed) {
|
||||||
|
|
@ -296,8 +300,8 @@ pub fn openxr_run(
|
||||||
.enqueue(TaskType::Overlay(OverlayTask::ToggleDashboard));
|
.enqueue(TaskType::Overlay(OverlayTask::ToggleDashboard));
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(ref mut space_mover) = playspace {
|
if let Some(ref mut playspace_mover) = playspace_mover {
|
||||||
space_mover.update(&mut overlays, &mut app);
|
playspace_mover.update(&mut overlays, &mut app);
|
||||||
}
|
}
|
||||||
|
|
||||||
for o in overlays.values_mut() {
|
for o in overlays.values_mut() {
|
||||||
|
|
@ -481,8 +485,8 @@ pub fn openxr_run(
|
||||||
overlays.handle_task(&mut app, task)?;
|
overlays.handle_task(&mut app, task)?;
|
||||||
}
|
}
|
||||||
TaskType::Playspace(task) => {
|
TaskType::Playspace(task) => {
|
||||||
if let Some(playspace) = playspace.as_mut() {
|
if let Some(playspace_mover) = playspace_mover.as_mut() {
|
||||||
playspace.handle_task(&mut app, task);
|
playspace_mover.handle_task(&mut app, task);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
TaskType::OpenXR(task) => {
|
TaskType::OpenXR(task) => {
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,11 @@ use libmonado::{MndResult, Monado, Pose, ReferenceSpaceType};
|
||||||
use wgui::log::LogErr;
|
use wgui::log::LogErr;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
backend::{input::InputState, task::PlayspaceTask},
|
backend::{
|
||||||
|
input::InputState,
|
||||||
|
playspace_common::{self, SpaceGravity, SpaceGravityUpdateParams},
|
||||||
|
task::PlayspaceTask,
|
||||||
|
},
|
||||||
state::AppState,
|
state::AppState,
|
||||||
windowing::manager::OverlayWindowManager,
|
windowing::manager::OverlayWindowManager,
|
||||||
};
|
};
|
||||||
|
|
@ -19,6 +23,7 @@ struct MoverData<T> {
|
||||||
pub(super) struct PlayspaceMover {
|
pub(super) struct PlayspaceMover {
|
||||||
drag: Option<MoverData<Vec3A>>,
|
drag: Option<MoverData<Vec3A>>,
|
||||||
rotate: Option<MoverData<Quat>>,
|
rotate: Option<MoverData<Quat>>,
|
||||||
|
gravity: SpaceGravity,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl PlayspaceMover {
|
impl PlayspaceMover {
|
||||||
|
|
@ -35,6 +40,7 @@ impl PlayspaceMover {
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
drag: None,
|
drag: None,
|
||||||
rotate: None,
|
rotate: None,
|
||||||
|
gravity: SpaceGravity::new(),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -140,21 +146,27 @@ impl PlayspaceMover {
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(mut data) = self.drag.take() {
|
if let Some(mut data) = self.drag.take() {
|
||||||
let pointer = &app.input_state.pointers[data.hand];
|
|
||||||
if !pointer.now.space_drag {
|
|
||||||
log::info!("End space drag");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let new_hand = data
|
let new_hand = data
|
||||||
.pose
|
.pose
|
||||||
.transform_point3a(app.input_state.pointers[data.hand].raw_pose.translation);
|
.transform_point3a(app.input_state.pointers[data.hand].raw_pose.translation);
|
||||||
|
|
||||||
let relative_pos = if app.session.config.space_drag_unlocked {
|
let relative_pos = if app.session.config.space_drag_unlocked {
|
||||||
new_hand - data.hand_pose
|
new_hand - data.hand_pose
|
||||||
} else {
|
} else {
|
||||||
vec3a(0., new_hand.y - data.hand_pose.y, 0.)
|
vec3a(0., new_hand.y - data.hand_pose.y, 0.)
|
||||||
} * app.session.config.space_drag_multiplier;
|
} * app.session.config.space_drag_multiplier;
|
||||||
|
let pointer = &app.input_state.pointers[data.hand];
|
||||||
|
|
||||||
|
if !pointer.now.space_drag {
|
||||||
|
self.gravity.mark_end_drag(
|
||||||
|
&app.session.config,
|
||||||
|
relative_pos,
|
||||||
|
data.pose.translation,
|
||||||
|
app.delta_time,
|
||||||
|
);
|
||||||
|
|
||||||
|
log::info!("End space drag");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if relative_pos.length_squared() > 1000.0 {
|
if relative_pos.length_squared() > 1000.0 {
|
||||||
log::warn!("Space drag too fast, ignoring");
|
log::warn!("Space drag too fast, ignoring");
|
||||||
|
|
@ -162,16 +174,7 @@ impl PlayspaceMover {
|
||||||
}
|
}
|
||||||
|
|
||||||
let overlay_offset = data.pose.inverse().transform_vector3a(relative_pos) * -1.0;
|
let overlay_offset = data.pose.inverse().transform_vector3a(relative_pos) * -1.0;
|
||||||
|
playspace_common::shift_overlays(overlays, overlay_offset);
|
||||||
overlays.values_mut().for_each(|overlay| {
|
|
||||||
let Some(state) = overlay.config.active_state.as_mut() else {
|
|
||||||
return;
|
|
||||||
};
|
|
||||||
if state.positioning.moves_with_space() {
|
|
||||||
state.transform.translation += overlay_offset;
|
|
||||||
}
|
|
||||||
overlay.config.dirty = true;
|
|
||||||
});
|
|
||||||
|
|
||||||
data.pose.translation += relative_pos;
|
data.pose.translation += relative_pos;
|
||||||
data.hand_pose = new_hand;
|
data.hand_pose = new_hand;
|
||||||
|
|
@ -207,6 +210,20 @@ impl PlayspaceMover {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if let Some(res) = self.gravity.update(SpaceGravityUpdateParams {
|
||||||
|
dt: app.delta_time,
|
||||||
|
dragging: self.drag.is_some(),
|
||||||
|
config: &app.session.config,
|
||||||
|
floor_height: app.session.config.space_gravity_floor_height,
|
||||||
|
}) {
|
||||||
|
apply_offset(
|
||||||
|
Affine3A::from_translation(res.playspace_pos.into()),
|
||||||
|
&mut monado.ipc,
|
||||||
|
);
|
||||||
|
|
||||||
|
playspace_common::shift_overlays(overlays, -res.playspace_pos_offset);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn recenter(&mut self, input: &InputState, monado: &mut Monado) {
|
pub fn recenter(&mut self, input: &InputState, monado: &mut Monado) {
|
||||||
|
|
@ -232,6 +249,8 @@ impl PlayspaceMover {
|
||||||
let _ = monado
|
let _ = monado
|
||||||
.set_reference_space_offset(ReferenceSpaceType::Stage, pose)
|
.set_reference_space_offset(ReferenceSpaceType::Stage, pose)
|
||||||
.inspect_err(|e| log::warn!("Could not recenter due to libmonado error: {e:?}"));
|
.inspect_err(|e| log::warn!("Could not recenter due to libmonado error: {e:?}"));
|
||||||
|
|
||||||
|
self.gravity.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn reset_offset(&mut self, monado: &mut Monado) {
|
pub fn reset_offset(&mut self, monado: &mut Monado) {
|
||||||
|
|
@ -244,6 +263,7 @@ impl PlayspaceMover {
|
||||||
self.rotate = None;
|
self.rotate = None;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
self.gravity.reset();
|
||||||
apply_offset(Affine3A::IDENTITY, monado);
|
apply_offset(Affine3A::IDENTITY, monado);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,101 @@
|
||||||
|
use glam::Vec3A;
|
||||||
|
use wlx_common::config::GeneralConfig;
|
||||||
|
|
||||||
|
use crate::windowing::manager::OverlayWindowManager;
|
||||||
|
|
||||||
|
pub struct SpaceGravityUpdateParams<'a> {
|
||||||
|
pub dt: f32,
|
||||||
|
pub dragging: bool,
|
||||||
|
pub config: &'a GeneralConfig,
|
||||||
|
pub floor_height: f32,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct SpaceGravity {
|
||||||
|
velocity: Vec3A,
|
||||||
|
space_pos: Vec3A,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn shift_overlays<OverlayData>(
|
||||||
|
overlays: &mut OverlayWindowManager<OverlayData>,
|
||||||
|
overlay_offset: Vec3A,
|
||||||
|
) {
|
||||||
|
overlays.values_mut().for_each(|overlay| {
|
||||||
|
let Some(state) = overlay.config.active_state.as_mut() else {
|
||||||
|
return;
|
||||||
|
};
|
||||||
|
if state.positioning.moves_with_space() {
|
||||||
|
state.transform.translation += overlay_offset;
|
||||||
|
}
|
||||||
|
overlay.config.dirty = true;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct SpaceGravityUpdateResult {
|
||||||
|
pub playspace_pos: Vec3A,
|
||||||
|
pub playspace_pos_offset: Vec3A, // position difference compared to previous update() call
|
||||||
|
}
|
||||||
|
|
||||||
|
impl SpaceGravity {
|
||||||
|
pub fn new() -> Self {
|
||||||
|
Self {
|
||||||
|
velocity: Vec3A::default(),
|
||||||
|
space_pos: Vec3A::default(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn mark_end_drag(
|
||||||
|
&mut self,
|
||||||
|
config: &GeneralConfig,
|
||||||
|
hand_pos_diff: Vec3A,
|
||||||
|
space_pos: Vec3A,
|
||||||
|
dt: f32,
|
||||||
|
) {
|
||||||
|
if config.space_gravity_enabled {
|
||||||
|
self.velocity = hand_pos_diff * config.space_gravity_fling_strength / dt;
|
||||||
|
self.space_pos = space_pos;
|
||||||
|
} else {
|
||||||
|
self.reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn reset(&mut self) {
|
||||||
|
self.velocity = Vec3A::default();
|
||||||
|
self.space_pos = Vec3A::default();
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn update(&mut self, par: SpaceGravityUpdateParams) -> Option<SpaceGravityUpdateResult> {
|
||||||
|
if par.dragging || !par.config.space_gravity_enabled {
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
|
||||||
|
let prev_pos = self.space_pos;
|
||||||
|
|
||||||
|
self.velocity.y += par.config.space_gravity_gravity * par.dt;
|
||||||
|
|
||||||
|
// terminal velocity
|
||||||
|
self.velocity.y = self.velocity.y.min(200.0);
|
||||||
|
|
||||||
|
self.velocity *= (par.config.space_gravity_damping).powf(par.dt * 10.0);
|
||||||
|
|
||||||
|
self.space_pos += self.velocity * par.dt;
|
||||||
|
|
||||||
|
self.space_pos.y = self.space_pos.y.min(par.floor_height);
|
||||||
|
|
||||||
|
if self.space_pos.y >= par.floor_height
|
||||||
|
/* at floor height or below */
|
||||||
|
{
|
||||||
|
// apply ground friction
|
||||||
|
self.velocity *= 1.0 - par.config.space_gravity_ground_friction * par.dt * 10.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if self.velocity.length_squared() > 0.00003 {
|
||||||
|
// Space position changed
|
||||||
|
return Some(SpaceGravityUpdateResult {
|
||||||
|
playspace_pos: self.space_pos,
|
||||||
|
playspace_pos_offset: self.space_pos - prev_pos,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
None
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -165,6 +165,12 @@ pub struct AutoSettings {
|
||||||
pub screen_render_down: bool,
|
pub screen_render_down: bool,
|
||||||
pub pointer_lerp_factor: f32,
|
pub pointer_lerp_factor: f32,
|
||||||
pub space_drag_unlocked: bool,
|
pub space_drag_unlocked: bool,
|
||||||
|
pub space_gravity_damping: f32,
|
||||||
|
pub space_gravity_enabled: bool,
|
||||||
|
pub space_gravity_fling_strength: f32,
|
||||||
|
pub space_gravity_gravity: f32,
|
||||||
|
pub space_gravity_ground_friction: f32,
|
||||||
|
pub space_gravity_floor_height: f32,
|
||||||
pub space_rotate_unlocked: bool,
|
pub space_rotate_unlocked: bool,
|
||||||
pub clock_12h: bool,
|
pub clock_12h: bool,
|
||||||
pub hide_username: bool,
|
pub hide_username: bool,
|
||||||
|
|
@ -220,6 +226,12 @@ pub fn save_settings(config: &GeneralConfig) -> anyhow::Result<()> {
|
||||||
screen_render_down: config.screen_render_down,
|
screen_render_down: config.screen_render_down,
|
||||||
pointer_lerp_factor: config.pointer_lerp_factor,
|
pointer_lerp_factor: config.pointer_lerp_factor,
|
||||||
space_drag_unlocked: config.space_drag_unlocked,
|
space_drag_unlocked: config.space_drag_unlocked,
|
||||||
|
space_gravity_damping: config.space_gravity_damping,
|
||||||
|
space_gravity_enabled: config.space_gravity_enabled,
|
||||||
|
space_gravity_fling_strength: config.space_gravity_fling_strength,
|
||||||
|
space_gravity_gravity: config.space_gravity_gravity,
|
||||||
|
space_gravity_ground_friction: config.space_gravity_ground_friction,
|
||||||
|
space_gravity_floor_height: config.space_gravity_floor_height,
|
||||||
space_rotate_unlocked: config.space_rotate_unlocked,
|
space_rotate_unlocked: config.space_rotate_unlocked,
|
||||||
clock_12h: config.clock_12h,
|
clock_12h: config.clock_12h,
|
||||||
hide_username: config.hide_username,
|
hide_username: config.hide_username,
|
||||||
|
|
|
||||||
|
|
@ -33,7 +33,6 @@ use wgui::{
|
||||||
self, CustomAttribsInfoOwned, Fetchable, ParseDocumentExtra, ParserState, parse_color_hex,
|
self, CustomAttribsInfoOwned, Fetchable, ParseDocumentExtra, ParserState, parse_color_hex,
|
||||||
},
|
},
|
||||||
renderer_vk::{context::Context as WguiContext, text::custom_glyph::CustomGlyphData},
|
renderer_vk::{context::Context as WguiContext, text::custom_glyph::CustomGlyphData},
|
||||||
taffy,
|
|
||||||
widget::{
|
widget::{
|
||||||
EventResult, image::WidgetImage, label::WidgetLabel, rectangle::WidgetRectangle,
|
EventResult, image::WidgetImage, label::WidgetLabel, rectangle::WidgetRectangle,
|
||||||
sprite::WidgetSprite,
|
sprite::WidgetSprite,
|
||||||
|
|
@ -552,15 +551,7 @@ pub fn apply_custom_command<T>(
|
||||||
.parser_state
|
.parser_state
|
||||||
.get_widget_id(element)
|
.get_widget_id(element)
|
||||||
.context("No widget with such id.")?;
|
.context("No widget with such id.")?;
|
||||||
|
com.alterables.set_widget_visible(wid, *visible);
|
||||||
let display = if *visible {
|
|
||||||
taffy::Display::Flex
|
|
||||||
} else {
|
|
||||||
taffy::Display::None
|
|
||||||
};
|
|
||||||
|
|
||||||
com.alterables
|
|
||||||
.set_style(wid, wgui::event::StyleSetRequest::Display(display));
|
|
||||||
com.alterables.mark_redraw();
|
com.alterables.mark_redraw();
|
||||||
}
|
}
|
||||||
ModifyPanelCommand::SetValue(value_str) => {
|
ModifyPanelCommand::SetValue(value_str) => {
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,7 @@
|
||||||
use glam::{Affine3A, Quat, Vec3};
|
use glam::{Affine3A, Quat, Vec3};
|
||||||
use std::sync::{Arc, LazyLock};
|
use std::sync::{Arc, LazyLock};
|
||||||
use wgui::event::{EventAlterables, StyleSetRequest};
|
use wgui::event::EventAlterables;
|
||||||
use wgui::parser::Fetchable;
|
use wgui::parser::Fetchable;
|
||||||
use wgui::taffy;
|
|
||||||
use wlx_common::windowing::{OverlayWindowState, Positioning};
|
use wlx_common::windowing::{OverlayWindowState, Positioning};
|
||||||
|
|
||||||
use crate::gui::panel::GuiPanel;
|
use crate::gui::panel::GuiPanel;
|
||||||
|
|
@ -84,13 +83,7 @@ pub fn create_grab_help(app: &mut AppState) -> anyhow::Result<OverlayWindowConfi
|
||||||
};
|
};
|
||||||
|
|
||||||
for id in &all {
|
for id in &all {
|
||||||
let display = if *id == show_id {
|
alterables.set_widget_visible(*id, *id == show_id);
|
||||||
taffy::Display::Flex
|
|
||||||
} else {
|
|
||||||
taffy::Display::None
|
|
||||||
};
|
|
||||||
|
|
||||||
alterables.set_style(*id, StyleSetRequest::Display(display));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
panel.layout.process_alterables(alterables)?;
|
panel.layout.process_alterables(alterables)?;
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
use wgui::{event::StyleSetRequest, parser::Fetchable, taffy};
|
use wgui::parser::Fetchable;
|
||||||
use wlx_common::{common::LeftRight, windowing::Positioning};
|
use wlx_common::{common::LeftRight, windowing::Positioning};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
|
|
@ -47,26 +47,12 @@ pub fn new_pos_tab_handler(
|
||||||
})
|
})
|
||||||
}),
|
}),
|
||||||
Some(Box::new(move |common, state| {
|
Some(Box::new(move |common, state| {
|
||||||
let interpolation_disp = if state.has_lerp {
|
|
||||||
taffy::Display::Flex
|
|
||||||
} else {
|
|
||||||
taffy::Display::None
|
|
||||||
};
|
|
||||||
|
|
||||||
common.alterables.set_style(
|
|
||||||
interpolation_id,
|
|
||||||
StyleSetRequest::Display(interpolation_disp),
|
|
||||||
);
|
|
||||||
|
|
||||||
let align_to_hmd_disp = if state.has_align {
|
|
||||||
taffy::Display::Flex
|
|
||||||
} else {
|
|
||||||
taffy::Display::None
|
|
||||||
};
|
|
||||||
|
|
||||||
common
|
common
|
||||||
.alterables
|
.alterables
|
||||||
.set_style(align_to_hmd_id, StyleSetRequest::Display(align_to_hmd_disp));
|
.set_widget_visible(interpolation_id, state.has_lerp);
|
||||||
|
common
|
||||||
|
.alterables
|
||||||
|
.set_widget_visible(align_to_hmd_id, state.has_align);
|
||||||
})),
|
})),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -72,15 +72,9 @@ impl ButtonPaneTabSwitcher {
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
|
|
||||||
let display = if visible {
|
|
||||||
taffy::Display::Flex
|
|
||||||
} else {
|
|
||||||
taffy::Display::None
|
|
||||||
};
|
|
||||||
|
|
||||||
common
|
common
|
||||||
.alterables
|
.alterables
|
||||||
.set_style(data.get_rect(), StyleSetRequest::Display(display));
|
.set_widget_visible(data.get_rect(), visible);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn reset(&mut self, common: &mut CallbackDataCommon) {
|
pub fn reset(&mut self, common: &mut CallbackDataCommon) {
|
||||||
|
|
|
||||||
|
|
@ -4,9 +4,7 @@ use glam::{Affine3A, Quat, Vec3, vec3};
|
||||||
use wgui::{
|
use wgui::{
|
||||||
assets::AssetPath,
|
assets::AssetPath,
|
||||||
components::button::ComponentButton,
|
components::button::ComponentButton,
|
||||||
event::StyleSetRequest,
|
|
||||||
parser::{Fetchable, ParseDocumentParams},
|
parser::{Fetchable, ParseDocumentParams},
|
||||||
taffy,
|
|
||||||
};
|
};
|
||||||
use wlx_common::{
|
use wlx_common::{
|
||||||
common::LeftRight,
|
common::LeftRight,
|
||||||
|
|
@ -163,10 +161,10 @@ pub fn create_watch(app: &mut AppState) -> anyhow::Result<OverlayWindowConfig> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn sets_or_overlays(panel: &mut GuiPanel<WatchState>, app: &mut AppState) {
|
fn sets_or_overlays(panel: &mut GuiPanel<WatchState>, app: &mut AppState) {
|
||||||
let display = if app.session.config.sets_on_watch {
|
let visible = if app.session.config.sets_on_watch {
|
||||||
[taffy::Display::None, taffy::Display::Flex]
|
[false, true]
|
||||||
} else {
|
} else {
|
||||||
[taffy::Display::Flex, taffy::Display::None]
|
[true, false]
|
||||||
};
|
};
|
||||||
|
|
||||||
let widget = [
|
let widget = [
|
||||||
|
|
@ -184,6 +182,6 @@ fn sets_or_overlays(panel: &mut GuiPanel<WatchState>, app: &mut AppState) {
|
||||||
panel
|
panel
|
||||||
.layout
|
.layout
|
||||||
.alterables
|
.alterables
|
||||||
.set_style(widget[i], StyleSetRequest::Display(display[i]));
|
.set_widget_visible(widget[i], visible[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -117,6 +117,21 @@
|
||||||
## can rotate in any axis. Imagine horizon mode².
|
## can rotate in any axis. Imagine horizon mode².
|
||||||
#space_rotate_unlocked: false
|
#space_rotate_unlocked: false
|
||||||
|
|
||||||
|
## Space gravity: downward acceleration speed
|
||||||
|
#space_gravity_gravity: 2.0
|
||||||
|
|
||||||
|
## Space gravity: velocity damping (0.98 = gentle slowdown, 0.5 = heavy drag)
|
||||||
|
#space_gravity_damping: 0.98
|
||||||
|
|
||||||
|
## Space gravity: multiplier for "throwing" yourself via space drag momentum
|
||||||
|
#space_gravity_fling_strength: 1.0
|
||||||
|
|
||||||
|
## Space gravity: floor height (Y position where gravity stops)
|
||||||
|
#space_gravity_floor_height: 0.0
|
||||||
|
|
||||||
|
## Space gravity: ground friction when touching the floor
|
||||||
|
#space_gravity_ground_friction: 1.0
|
||||||
|
|
||||||
## Monado/WiVRn only. Use passthrough camera if the headset supports it.
|
## Monado/WiVRn only. Use passthrough camera if the headset supports it.
|
||||||
## If disabled, the skybox will be shown.
|
## If disabled, the skybox will be shown.
|
||||||
#use_passthrough: true
|
#use_passthrough: true
|
||||||
|
|
|
||||||
|
|
@ -71,6 +71,8 @@ pub struct AppState {
|
||||||
|
|
||||||
#[cfg(feature = "openxr")]
|
#[cfg(feature = "openxr")]
|
||||||
pub monado_state: Option<backend::openxr::monado_state::MonadoState>,
|
pub monado_state: Option<backend::openxr::monado_state::MonadoState>,
|
||||||
|
|
||||||
|
pub delta_time: f32,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(unused_mut)]
|
#[allow(unused_mut)]
|
||||||
|
|
@ -188,6 +190,8 @@ impl AppState {
|
||||||
|
|
||||||
#[cfg(feature = "openxr")]
|
#[cfg(feature = "openxr")]
|
||||||
monado_state: None,
|
monado_state: None,
|
||||||
|
|
||||||
|
delta_time: 1.0 / 120.0,
|
||||||
};
|
};
|
||||||
|
|
||||||
if let Some(error_toast) = hid_error {
|
if let Some(error_toast) = hid_error {
|
||||||
|
|
|
||||||
|
|
@ -123,14 +123,7 @@ fn refresh_all(common: &mut CallbackDataCommon, data: &Data, state: &mut State)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Cursor
|
// Cursor
|
||||||
common.alterables.set_style(
|
common.alterables.set_widget_visible(data.id_rect_cursor, state.focused);
|
||||||
data.id_rect_cursor,
|
|
||||||
StyleSetRequest::Display(if state.focused {
|
|
||||||
taffy::Display::Flex
|
|
||||||
} else {
|
|
||||||
taffy::Display::None
|
|
||||||
}),
|
|
||||||
);
|
|
||||||
|
|
||||||
state.first_refresh = false;
|
state.first_refresh = false;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -346,8 +346,8 @@ impl State {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const BODY_COLOR: drawing::Color = drawing::Color::new(0.6, 0.65, 0.7, 0.2);
|
const BODY_COLOR: drawing::Color = drawing::Color::new(0.6, 0.65, 0.7, 0.1);
|
||||||
const BODY_BORDER_COLOR: drawing::Color = drawing::Color::new(0.4, 0.45, 0.5, 1.0);
|
const BODY_BORDER_COLOR: drawing::Color = drawing::Color::new(0.4, 0.45, 0.5, 0.6);
|
||||||
const HANDLE_BORDER_COLOR: drawing::Color = drawing::Color::new(0.85, 0.85, 0.85, 1.0);
|
const HANDLE_BORDER_COLOR: drawing::Color = drawing::Color::new(0.85, 0.85, 0.85, 1.0);
|
||||||
const HANDLE_BORDER_COLOR_HOVERED: drawing::Color = drawing::Color::new(0.0, 0.0, 0.0, 1.0);
|
const HANDLE_BORDER_COLOR_HOVERED: drawing::Color = drawing::Color::new(0.0, 0.0, 0.0, 1.0);
|
||||||
const HANDLE_COLOR: drawing::Color = drawing::Color::new(1.0, 1.0, 1.0, 1.0);
|
const HANDLE_COLOR: drawing::Color = drawing::Color::new(1.0, 1.0, 1.0, 1.0);
|
||||||
|
|
|
||||||
|
|
@ -138,6 +138,17 @@ impl EventAlterables {
|
||||||
self.style_set_requests.push((widget_id, request));
|
self.style_set_requests.push((widget_id, request));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn set_widget_visible(&mut self, widget_id: WidgetID, visible: bool) {
|
||||||
|
self.style_set_requests.push((
|
||||||
|
widget_id,
|
||||||
|
StyleSetRequest::Display(if visible {
|
||||||
|
taffy::Display::Flex
|
||||||
|
} else {
|
||||||
|
taffy::Display::None
|
||||||
|
}),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
pub fn mark_dirty(&mut self, widget_id: WidgetID) {
|
pub fn mark_dirty(&mut self, widget_id: WidgetID) {
|
||||||
self.dirty_widgets.push(widget_id);
|
self.dirty_widgets.push(widget_id);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,7 @@ use crate::{
|
||||||
drawing::{
|
drawing::{
|
||||||
self, ANSI_BOLD_CODE, ANSI_RESET_CODE, Boundary, PushScissorStackResult, push_scissor_stack, push_transform_stack,
|
self, ANSI_BOLD_CODE, ANSI_RESET_CODE, Boundary, PushScissorStackResult, push_scissor_stack, push_transform_stack,
|
||||||
},
|
},
|
||||||
event::{self, CallbackDataCommon, Event, EventAlterables},
|
event::{self, CallbackDataCommon, Event, EventAlterables, StyleSetRequest},
|
||||||
globals::WguiGlobals,
|
globals::WguiGlobals,
|
||||||
sound::WguiSoundType,
|
sound::WguiSoundType,
|
||||||
task::Tasks,
|
task::Tasks,
|
||||||
|
|
@ -149,6 +149,7 @@ pub type LayoutDispatchFunc = Box<dyn FnOnce(&mut CallbackDataCommon) -> anyhow:
|
||||||
pub enum LayoutTask {
|
pub enum LayoutTask {
|
||||||
RemoveWidget(WidgetID),
|
RemoveWidget(WidgetID),
|
||||||
SetWidgetStyle(WidgetID, event::StyleSetRequest),
|
SetWidgetStyle(WidgetID, event::StyleSetRequest),
|
||||||
|
SetWidgetVisible(WidgetID, bool), // if true, sets Display to Flex; None, otherwise
|
||||||
ModifyLayoutState(LayoutModifyStateFunc),
|
ModifyLayoutState(LayoutModifyStateFunc),
|
||||||
PlaySound(WguiSoundType),
|
PlaySound(WguiSoundType),
|
||||||
Dispatch(LayoutDispatchFunc),
|
Dispatch(LayoutDispatchFunc),
|
||||||
|
|
@ -746,6 +747,16 @@ impl Layout {
|
||||||
LayoutTask::SetWidgetStyle(widget_id, style_request) => {
|
LayoutTask::SetWidgetStyle(widget_id, style_request) => {
|
||||||
self.set_style_request(widget_id, &style_request);
|
self.set_style_request(widget_id, &style_request);
|
||||||
}
|
}
|
||||||
|
LayoutTask::SetWidgetVisible(widget_id, visible) => {
|
||||||
|
self.set_style_request(
|
||||||
|
widget_id,
|
||||||
|
&StyleSetRequest::Display(if visible {
|
||||||
|
taffy::Display::Flex
|
||||||
|
} else {
|
||||||
|
taffy::Display::None
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
}
|
||||||
LayoutTask::SetFocus(weak) => {
|
LayoutTask::SetFocus(weak) => {
|
||||||
if let Some(c) = weak.upgrade() {
|
if let Some(c) = weak.upgrade() {
|
||||||
self.set_focus(Some(&components::Component(c)))?;
|
self.set_focus(Some(&components::Component(c)))?;
|
||||||
|
|
|
||||||
|
|
@ -36,10 +36,8 @@ pub fn parse_widget_label<'a>(
|
||||||
params.content = Translation::from_raw_text(value);
|
params.content = Translation::from_raw_text(value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
"translation" => {
|
"translation" if !value.is_empty() => {
|
||||||
if !value.is_empty() {
|
params.content = Translation::from_translation_key(value);
|
||||||
params.content = Translation::from_translation_key(value);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -165,6 +165,10 @@ const fn def_point3() -> f32 {
|
||||||
0.3
|
0.3
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const fn def_zero() -> f32 {
|
||||||
|
0.0
|
||||||
|
}
|
||||||
|
|
||||||
const fn def_osc_port() -> u16 {
|
const fn def_osc_port() -> u16 {
|
||||||
9000
|
9000
|
||||||
}
|
}
|
||||||
|
|
@ -336,6 +340,24 @@ pub struct GeneralConfig {
|
||||||
#[serde(default = "def_false")]
|
#[serde(default = "def_false")]
|
||||||
pub space_rotate_unlocked: bool,
|
pub space_rotate_unlocked: bool,
|
||||||
|
|
||||||
|
#[serde(default = "def_false")]
|
||||||
|
pub space_gravity_enabled: bool,
|
||||||
|
|
||||||
|
#[serde(default = "def_one")]
|
||||||
|
pub space_gravity_gravity: f32,
|
||||||
|
|
||||||
|
#[serde(default = "def_one")]
|
||||||
|
pub space_gravity_damping: f32,
|
||||||
|
|
||||||
|
#[serde(default = "def_one")]
|
||||||
|
pub space_gravity_fling_strength: f32,
|
||||||
|
|
||||||
|
#[serde(default = "def_one")]
|
||||||
|
pub space_gravity_ground_friction: f32,
|
||||||
|
|
||||||
|
#[serde(default = "def_zero")]
|
||||||
|
pub space_gravity_floor_height: f32,
|
||||||
|
|
||||||
#[serde(default)]
|
#[serde(default)]
|
||||||
pub alt_click_down: Vec<String>,
|
pub alt_click_down: Vec<String>,
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue