From a2eb0023dcaa30eab3f93088a7948abec534f3df Mon Sep 17 00:00:00 2001 From: Wayne Heaney <42350981+wheaney@users.noreply.github.com> Date: Sun, 16 Mar 2025 14:15:04 -0700 Subject: [PATCH 1/6] Add curved display support, v2.0.15 (#103) * Add curved display support * Add GNOME 48 support * Update backport build and setup process, add a GNOME-45 backport build --- .gitignore | 1 - .gitmodules | 8 + VERSION | 2 +- bin/breezy_gnome_setup | 9 +- bin/package_gnome | 31 +- gnome-44-max.patch | 477 -------------------- gnome/backports/gnome-44-max | 1 + gnome/backports/gnome-45 | 1 + gnome/src/extension.js | 2 + gnome/src/math.js | 45 ++ gnome/src/metadata.json | 2 +- gnome/src/virtualdisplayeffect.js | 236 ++++++---- gnome/src/virtualdisplaysactor.js | 308 ++++++------- ui/po/breezydesktop.pot | 158 ++++--- ui/po/de.po | 161 +++---- ui/po/es.po | 186 ++++---- ui/po/fr.po | 161 +++---- ui/po/it.po | 161 +++---- ui/po/ja.po | 173 +++---- ui/po/mo/de/LC_MESSAGES/breezydesktop.mo | Bin 9667 -> 9823 bytes ui/po/mo/es/LC_MESSAGES/breezydesktop.mo | Bin 15046 -> 15202 bytes ui/po/mo/fr/LC_MESSAGES/breezydesktop.mo | Bin 9736 -> 9893 bytes ui/po/mo/it/LC_MESSAGES/breezydesktop.mo | Bin 9778 -> 9868 bytes ui/po/mo/ja/LC_MESSAGES/breezydesktop.mo | Bin 16029 -> 16208 bytes ui/po/mo/pt_BR/LC_MESSAGES/breezydesktop.mo | Bin 14739 -> 14877 bytes ui/po/mo/ru/LC_MESSAGES/breezydesktop.mo | Bin 11183 -> 11412 bytes ui/po/mo/sv/LC_MESSAGES/breezydesktop.mo | Bin 9192 -> 9333 bytes ui/po/mo/uk_UA/LC_MESSAGES/breezydesktop.mo | Bin 11077 -> 11310 bytes ui/po/mo/zh_CN/LC_MESSAGES/breezydesktop.mo | Bin 13321 -> 13473 bytes ui/po/pl.po | 158 ++++--- ui/po/pt_BR.po | 165 +++---- ui/po/ru.po | 161 +++---- ui/po/sv.po | 161 +++---- ui/po/uk_UA.po | 161 +++---- ui/po/zh_CN.po | 164 +++---- ui/src/connecteddevice.py | 15 +- ui/src/gtk/connected-device.ui | 12 + 37 files changed, 1418 insertions(+), 1702 deletions(-) delete mode 100644 gnome-44-max.patch create mode 160000 gnome/backports/gnome-44-max create mode 160000 gnome/backports/gnome-45 diff --git a/.gitignore b/.gitignore index d50ac39..51c61dc 100644 --- a/.gitignore +++ b/.gitignore @@ -4,4 +4,3 @@ __pycache__ gschemas.compiled out/ *.po~ -gnome-44-max/ diff --git a/.gitmodules b/.gitmodules index e7a2906..4c613c2 100644 --- a/.gitmodules +++ b/.gitmodules @@ -11,3 +11,11 @@ [submodule "ui/modules/PyXRLinuxDriverIPC"] path = ui/modules/PyXRLinuxDriverIPC url = https://github.com/wheaney/PyXRLinuxDriverIPC.git +[submodule "gnome/backports/gnome-44-max"] + path = gnome/backports/gnome-44-max + url = https://github.com/wheaney/breezy-desktop + branch = gnome-44-max +[submodule "gnome/backports/gnome-45"] + path = gnome/backports/gnome-45 + url = https://github.com/wheaney/breezy-desktop + branch = gnome-45 diff --git a/VERSION b/VERSION index 3d45b5c..e6f474a 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -2.0.14 +2.0.15 \ No newline at end of file diff --git a/bin/breezy_gnome_setup b/bin/breezy_gnome_setup index fc0c3a0..f93c496 100755 --- a/bin/breezy_gnome_setup +++ b/bin/breezy_gnome_setup @@ -23,7 +23,13 @@ check_command "gnome-shell" ARCH=$(uname -m) FILE_NAME="breezyGNOME-$ARCH.tar.gz" -if [ "$(gnome-shell --version | cut -d' ' -f3 | cut -d'.' -f1)" -lt 45 ]; then +GNOME_VERSION=$(gnome-shell --version | cut -d' ' -f3 | cut -d'.' -f1) +VERSION_SPECIFIC_FILENAME="breezyGNOME-$GNOME_VERSION-$ARCH.tar.gz" +LATEST_RELEASE=$(curl -s "https://api.github.com/repos/wheaney/breezy-desktop/releases/latest") +if echo "$LATEST_RELEASE" | jq -e --arg filename "$VERSION_SPECIFIC_FILENAME" '.assets[] | select(.name == $filename)' > /dev/null; then + echo "Performing setup for GNOME $GNOME_VERSION ($ARCH)" + FILE_NAME=$VERSION_SPECIFIC_FILENAME +elif [ "$GNOME_VERSION" -lt 45 ]; then echo "Performing setup for GNOME 44 and below ($ARCH)" FILE_NAME="breezyGNOME-44-max-$ARCH.tar.gz" else @@ -32,7 +38,6 @@ fi start_dir=$(pwd) - # create temp directory tmp_dir=$(mktemp -d -t breezy-gnome-XXXXXXXXXX) pushd $tmp_dir > /dev/null diff --git a/bin/package_gnome b/bin/package_gnome index ce388c3..0750131 100755 --- a/bin/package_gnome +++ b/bin/package_gnome @@ -9,27 +9,29 @@ ARCH=${ARCH:-$(uname -m)} SCRIPT_DIR=$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" &>/dev/null && pwd) ROOT_DIR=$(realpath $SCRIPT_DIR/..) VULKAN_DIR=$ROOT_DIR/vulkan +UI_DIR=$ROOT_DIR/ui +XR_DRIVER_DIR=$ROOT_DIR/modules/XRLinuxDriver -if [ -z "$GNOME_44_MAX" ]; then +if [ -z "$GNOME_BACKPORT" ]; then # standard build for GNOME 45 and up echo "Building Breezy GNOME for $ARCH, GNOME versions 45 and up" GNOME_DIR=$ROOT_DIR/gnome BUILD_FILE_NAME=breezyGNOME-$ARCH.tar.gz else - # special patched build for GNOME 44 and below - echo "Building Breezy GNOME for $ARCH, GNOME versions 44 and below" + # special build process for backports + echo "Building Breezy GNOME backport \"$GNOME_BACKPORT\" for $ARCH" - # use a special directory for the GNOME 44 max build, ignored by git - GNOME_DIR=$ROOT_DIR/gnome-44-max - rm -rf $GNOME_DIR - mkdir $GNOME_DIR - BUILD_FILE_NAME=breezyGNOME-44-max-$ARCH.tar.gz + # strip the prefix "gnome-" from the backport name, if it's there + GNOME_BACKPORT_NAME=${GNOME_BACKPORT#gnome-} - # copy the GNOME extension source code to the new directory and apply - # a patch that makes it compatible with GNOME 44 and below - cp -ra $ROOT_DIR/gnome/* $GNOME_DIR + GNOME_DIR=$ROOT_DIR/gnome/backports/$GNOME_BACKPORT/gnome + UI_DIR=$ROOT_DIR/gnome/backports/$GNOME_BACKPORT/ui + BUILD_FILE_NAME=breezyGNOME-$GNOME_BACKPORT_NAME-$ARCH.tar.gz rm -rf $GNOME_DIR/build - git apply gnome-44-max.patch + + pushd $GNOME_DIR + git submodule update --init + popd fi GNOME_BUILD_DIR=$GNOME_DIR/build @@ -42,7 +44,6 @@ PACKAGE_DIR=$GNOME_BUILD_DIR/breezy_gnome rm -rf $PACKAGE_DIR mkdir -p $PACKAGE_DIR -XR_DRIVER_DIR=$ROOT_DIR/modules/XRLinuxDriver source $XR_DRIVER_DIR/bin/inject_ua # if a custom_banner image exists, copy it over the sombrero one @@ -92,9 +93,9 @@ pushd $GNOME_DIR/src GNOME_MANIFEST_LINE=$(find -L . -type f ! -name "*.compiled" -exec sha256sum {} \; | sort | sha256sum | sed 's/ .*//') popd -UI_BUILD_ARTIFACT=ui/out/breezyUI-$ARCH.tar.gz +UI_BUILD_ARTIFACT=$UI_DIR/out/breezyUI-$ARCH.tar.gz if [ ! -e "$UI_BUILD_ARTIFACT" ] || [ "$1" == "--rebuild-ui" ] || [ "$1" == "--rebuild-all" ]; then - pushd ui + pushd $UI_DIR bin/package $ARCH popd fi diff --git a/gnome-44-max.patch b/gnome-44-max.patch deleted file mode 100644 index 2b12d3c..0000000 --- a/gnome-44-max.patch +++ /dev/null @@ -1,477 +0,0 @@ -diff --git a/gnome-44-max/bin/setup b/gnome-44-max/bin/setup -index bd4c8b5..2cf0a03 100755 ---- a/gnome-44-max/bin/setup -+++ b/gnome-44-max/bin/setup -@@ -84,8 +84,10 @@ echo "Copying the manifest file to ${BREEZY_GNOME_DATA_DIR}" - mkdir -p $BREEZY_GNOME_DATA_DIR - cp manifest $BREEZY_GNOME_DATA_DIR - --echo "Installing the breezydesktop@xronlinux.com GNOME extension" --gnome-extensions install --force breezydesktop@xronlinux.com.shell-extension.zip -+EXTENSION_UUID="breezydesktop@xronlinux.com" -+echo "Installing the $EXTENSION_UUID GNOME extension" -+gnome-extensions install --force "$EXTENSION_UUID.shell-extension.zip" -+glib-compile-schemas "$GNOME_SHELL_DATA_DIR/extensions/$EXTENSION_UUID/schemas" - - echo "Installing the Breezy Desktop UI application" - cp -r breezy_ui/data/* $XDG_DATA_HOME -diff --git a/gnome-44-max/src/cursor.js b/gnome-44-max/src/cursor.js -index 36ad7ee..41102a0 100644 ---- a/gnome-44-max/src/cursor.js -+++ b/gnome-44-max/src/cursor.js -@@ -15,11 +15,11 @@ - // You should have received a copy of the GNU General Public License - // along with this program. If not, see . - --import Clutter from 'gi://Clutter'; --import GObject from 'gi://GObject'; -+const Clutter = imports.gi.Clutter; -+const GObject = imports.gi.GObject; - - // Copied almost verbatim from ui/magnifier.js. --export const MouseSpriteContent = GObject.registerClass({ -+var MouseSpriteContent = GObject.registerClass({ - Implements: [Clutter.Content], - }, class MouseSpriteContent extends GObject.Object { - _init() { -diff --git a/gnome-44-max/src/cursormanager.js b/gnome-44-max/src/cursormanager.js -index dd4a77d..bbb8872 100644 ---- a/gnome-44-max/src/cursormanager.js -+++ b/gnome-44-max/src/cursormanager.js -@@ -1,11 +1,15 @@ --import Clutter from 'gi://Clutter'; --import Meta from 'gi://Meta'; --import * as PointerWatcher from 'resource:///org/gnome/shell/ui/pointerWatcher.js'; --import { MouseSpriteContent } from './cursor.js'; --import Globals from './globals.js'; -+const Clutter = imports.gi.Clutter; -+const Meta = imports.gi.Meta; -+const PointerWatcher = imports.ui.pointerWatcher; -+ -+const ExtensionUtils = imports.misc.extensionUtils; -+const Me = ExtensionUtils.getCurrentExtension(); -+ -+const Globals = Me.imports.globals; -+const { MouseSpriteContent } = Me.imports.cursor; - - // Taken from https://github.com/jkitching/soft-brightness-plus --export class CursorManager { -+var CursorManager = class CursorManager { - constructor(targetMonitors, refreshRate) { - this._targetMonitors = targetMonitors; - this._refreshRate = refreshRate; -diff --git a/gnome-44-max/src/devicedatastream.js b/gnome-44-max/src/devicedatastream.js -index e396403..f047067 100644 ---- a/gnome-44-max/src/devicedatastream.js -+++ b/gnome-44-max/src/devicedatastream.js -@@ -1,8 +1,12 @@ --import Gio from 'gi://Gio'; --import GObject from 'gi://GObject'; -+const Gio = imports.gi.Gio; -+const GObject = imports.gi.GObject; - --import Globals from './globals.js'; --import { -+const ExtensionUtils = imports.misc.extensionUtils; -+const Me = ExtensionUtils.getCurrentExtension(); -+ -+const Globals = Me.imports.globals; -+const { isValidKeepAlive, getEpochSec, toSec } = Me.imports.time; -+const { - dataViewEnd, - dataViewUint8, - dataViewBigUint, -@@ -14,8 +18,7 @@ import { - FLOAT_SIZE, - UINT_SIZE, - UINT8_SIZE --} from "./ipc.js"; --import { isValidKeepAlive, getEpochSec, toSec } from "./time.js"; -+} = Me.imports.ipc; - - const IPC_FILE_PATH = "/dev/shm/breezy_desktop_imu"; - const KEEPALIVE_REFRESH_INTERVAL_SEC = 1; -@@ -75,7 +78,7 @@ function nextDebugIMUQuaternion(counter) { - return [x, y, z, w]; - } - --export const DeviceDataStream = GObject.registerClass({ -+var DeviceDataStream = GObject.registerClass({ - Properties: { - 'breezy-desktop-running': GObject.ParamSpec.boolean( - 'breezy-desktop-running', -diff --git a/gnome-44-max/src/extension.js b/gnome-44-max/src/extension.js -index b3363d5..d5be026 100644 ---- a/gnome-44-max/src/extension.js -+++ b/gnome-44-max/src/extension.js -@@ -1,28 +1,32 @@ --import Gio from 'gi://Gio'; --import GLib from 'gi://GLib'; --import Meta from 'gi://Meta'; --import Shell from 'gi://Shell'; --import St from 'gi://St'; -- --import { CursorManager } from './cursormanager.js'; --import { DeviceDataStream } from './devicedatastream.js'; --import Globals from './globals.js'; --import { Logger } from './logger.js'; --import { MonitorManager, NESTED_MONITOR_PRODUCT, SUPPORTED_MONITOR_PRODUCTS, VIRTUAL_MONITOR_PRODUCT } from './monitormanager.js'; --import { VirtualDisplaysActor } from './virtualdisplaysactor.js'; -- --import {Extension} from 'resource:///org/gnome/shell/extensions/extension.js'; --import * as Main from 'resource:///org/gnome/shell/ui/main.js'; -+const Clutter = imports.gi.Clutter; -+const Gio = imports.gi.Gio; -+const GLib = imports.gi.GLib; -+const Meta = imports.gi.Meta; -+const Shell = imports.gi.Shell; -+const St = imports.gi.St; -+ -+const Main = imports.ui.main; -+ -+const ExtensionUtils = imports.misc.extensionUtils; -+const Me = ExtensionUtils.getCurrentExtension(); -+ -+const Globals = Me.imports.globals; -+const { CursorManager } = Me.imports.cursormanager; -+const { DeviceDataStream } = Me.imports.devicedatastream; -+const { Logger } = Me.imports.logger; -+const { MonitorManager, NESTED_MONITOR_PRODUCT, SUPPORTED_MONITOR_PRODUCTS, VIRTUAL_MONITOR_PRODUCT } = Me.imports.monitormanager; -+const { VirtualDisplaysActor } = Me.imports.virtualdisplaysactor; -+ - - const BIN_HOME = GLib.getenv('XDG_BIN_HOME') || GLib.build_filenamev([GLib.get_home_dir(), '.local', 'bin']); - const XDG_CLI_PATH = GLib.build_filenamev([BIN_HOME, 'xr_driver_cli']); - const ALT_CLI_PATH = '/usr/bin/xr_driver_cli'; - --export default class BreezyDesktopExtension extends Extension { -- constructor(metadata, uuid) { -- super(metadata, uuid); -- -- this.settings = this.getSettings(); -+class BreezyDesktopExtension { -+ constructor(extensionPath) { -+ this.path = extensionPath; -+ -+ this.settings = ExtensionUtils.getSettings(); - - // Set/destroyed by enable/disable - this._cursor_manager = null; -@@ -645,6 +649,6 @@ export default class BreezyDesktopExtension extends Extension { - } - } - --function init() { -- return new Extension(); -+function init(meta) { -+ return new BreezyDesktopExtension(meta.path); - } -diff --git a/gnome-44-max/src/globals.js b/gnome-44-max/src/globals.js -index f11451c..4b5c65b 100644 ---- a/gnome-44-max/src/globals.js -+++ b/gnome-44-max/src/globals.js -@@ -1,7 +1,6 @@ --const Globals = { -+var Globals = { - logger: null, - ipc_file: null, // Gio.File instance, file exists if set - extension_dir: null, // string path - data_stream: null, // DeviceDataStream instance --} --export default Globals; -\ No newline at end of file -+} -\ No newline at end of file -diff --git a/gnome-44-max/src/ipc.js b/gnome-44-max/src/ipc.js -index a729368..d5f7ab0 100644 ---- a/gnome-44-max/src/ipc.js -+++ b/gnome-44-max/src/ipc.js -@@ -1,30 +1,30 @@ --export const UINT8_SIZE = 1; --export const BOOL_SIZE = UINT8_SIZE; --export const UINT_SIZE = 4; --export const FLOAT_SIZE = 4; -+var UINT8_SIZE = 1; -+var BOOL_SIZE = UINT8_SIZE; -+var UINT_SIZE = 4; -+var FLOAT_SIZE = 4; - --export const DATA_VIEW_INFO_OFFSET_INDEX = 0; --export const DATA_VIEW_INFO_SIZE_INDEX = 1; --export const DATA_VIEW_INFO_COUNT_INDEX = 2; -+var DATA_VIEW_INFO_OFFSET_INDEX = 0; -+var DATA_VIEW_INFO_SIZE_INDEX = 1; -+var DATA_VIEW_INFO_COUNT_INDEX = 2; - - // computes the end offset, exclusive --export function dataViewEnd(dataViewInfo) { -+function dataViewEnd(dataViewInfo) { - return dataViewInfo[DATA_VIEW_INFO_OFFSET_INDEX] + dataViewInfo[DATA_VIEW_INFO_SIZE_INDEX] * dataViewInfo[DATA_VIEW_INFO_COUNT_INDEX]; - } - --export function dataViewUint8(dataView, dataViewInfo) { -+function dataViewUint8(dataView, dataViewInfo) { - return dataView.getUint8(dataViewInfo[DATA_VIEW_INFO_OFFSET_INDEX]); - } - --export function dataViewUint(dataView, dataViewInfo) { -+function dataViewUint(dataView, dataViewInfo) { - return dataView.getUint32(dataViewInfo[DATA_VIEW_INFO_OFFSET_INDEX], true); - } - --export function dataViewBigUint(dataView, dataViewInfo) { -+function dataViewBigUint(dataView, dataViewInfo) { - return Number(dataView.getBigUint64(dataViewInfo[DATA_VIEW_INFO_OFFSET_INDEX], true)); - } - --export function dataViewUint32Array(dataView, dataViewInfo) { -+function dataViewUint32Array(dataView, dataViewInfo) { - const uintArray = [] - let offset = dataViewInfo[DATA_VIEW_INFO_OFFSET_INDEX]; - for (let i = 0; i < dataViewInfo[DATA_VIEW_INFO_COUNT_INDEX]; i++) { -@@ -34,7 +34,7 @@ export function dataViewUint32Array(dataView, dataViewInfo) { - return uintArray; - } - --export function dataViewUint8Array(dataView, dataViewInfo) { -+function dataViewUint8Array(dataView, dataViewInfo) { - const uintArray = [] - let offset = dataViewInfo[DATA_VIEW_INFO_OFFSET_INDEX]; - for (let i = 0; i < dataViewInfo[DATA_VIEW_INFO_SIZE_INDEX] * dataViewInfo[DATA_VIEW_INFO_COUNT_INDEX]; i++) { -@@ -44,11 +44,11 @@ export function dataViewUint8Array(dataView, dataViewInfo) { - return uintArray; - } - --export function dataViewFloat(dataView, dataViewInfo) { -+function dataViewFloat(dataView, dataViewInfo) { - return dataView.getFloat32(dataViewInfo[DATA_VIEW_INFO_OFFSET_INDEX], true); - } - --export function dataViewFloatArray(dataView, dataViewInfo) { -+function dataViewFloatArray(dataView, dataViewInfo) { - const floatArray = [] - let offset = dataViewInfo[DATA_VIEW_INFO_OFFSET_INDEX]; - for (let i = 0; i < dataViewInfo[DATA_VIEW_INFO_COUNT_INDEX]; i++) { -diff --git a/gnome-44-max/src/logger.js b/gnome-44-max/src/logger.js -index 5bdf115..138a98a 100644 ---- a/gnome-44-max/src/logger.js -+++ b/gnome-44-max/src/logger.js -@@ -14,15 +14,15 @@ - // You should have received a copy of the GNU General Public License - // along with this program. If not, see . - --import * as Config from 'resource:///org/gnome/shell/misc/config.js'; --import Gio from 'gi://Gio'; --import GLib from 'gi://GLib'; --import GObject from 'gi://GObject'; --import System from 'system'; -+const Config = imports.misc.config; -+const Gio = imports.gi.Gio; -+const GLib = imports.gi.GLib; -+const GObject = imports.gi.GObject; -+const System = imports.system; - - const LOG_DIR_NAME = 'breezy_gnome/logs/gjs'; - --export const Logger = GObject.registerClass({ -+var Logger = GObject.registerClass({ - GTypeName: 'Logger', - Properties: { - 'title': GObject.ParamSpec.string( -diff --git a/gnome-44-max/src/math.js b/gnome-44-max/src/math.js -index f1c9983..9a98c7b 100644 ---- a/gnome-44-max/src/math.js -+++ b/gnome-44-max/src/math.js -@@ -1,9 +1,9 @@ --export function degreeToRadian(degree) { -+function degreeToRadian(degree) { - return degree * Math.PI / 180; - } - - // FOV in radians is spherical, so doesn't follow Pythagoras' theorem --export function diagonalToCrossFOVs(diagonalFOVRadians, aspectRatio) { -+function diagonalToCrossFOVs(diagonalFOVRadians, aspectRatio) { - // first convert from a spherical FOV to a diagonal FOV on a flat plane at a generic distance of 1.0 - const flatDiagonalFOV = 2 * Math.tan(diagonalFOVRadians / 2); - -diff --git a/gnome-44-max/src/metadata.json b/gnome-44-max/src/metadata.json -index 0f8073b..bc26f97 100644 ---- a/gnome-44-max/src/metadata.json -+++ b/gnome-44-max/src/metadata.json -@@ -5,7 +5,7 @@ - "settings-schema": "com.xronlinux.BreezyDesktop", - "session-modes": ["user"], - "shell-version": [ -- "45", "46", "47" -+ "42", "43", "44" - ], - "url": "https://github.com/wheaney/breezy-desktop" - } -\ No newline at end of file -diff --git a/gnome-44-max/src/monitormanager.js b/gnome-44-max/src/monitormanager.js -index 4c57171..080924d 100644 ---- a/gnome-44-max/src/monitormanager.js -+++ b/gnome-44-max/src/monitormanager.js -@@ -16,16 +16,19 @@ - // You should have received a copy of the GNU General Public License - // along with this program. If not, see . - --import Gio from 'gi://Gio'; --import GObject from 'gi://GObject'; -+const Gio = imports.gi.Gio; -+const GObject = imports.gi.GObject; - --import * as Main from 'resource:///org/gnome/shell/ui/main.js'; -+const Main = imports.ui.main; - --import Globals from './globals.js'; -+const ExtensionUtils = imports.misc.extensionUtils; -+const Me = ExtensionUtils.getCurrentExtension(); - --export const NESTED_MONITOR_PRODUCT = 'MetaMonitor'; --export const VIRTUAL_MONITOR_PRODUCT = 'Virtual remote monitor'; --export const SUPPORTED_MONITOR_PRODUCTS = [ -+const Globals = Me.imports.globals; -+ -+var NESTED_MONITOR_PRODUCT = 'MetaMonitor'; -+var VIRTUAL_MONITOR_PRODUCT = 'Virtual remote monitor'; -+var SUPPORTED_MONITOR_PRODUCTS = [ - 'VITURE', - 'nreal air', - 'Air', -@@ -58,7 +61,7 @@ function getDisplayConfigProxy(extPath) { - return cachedDisplayConfigProxy; - } - --export function newDisplayConfig(extPath, callback) { -+function newDisplayConfig(extPath, callback) { - const DisplayConfigProxy = getDisplayConfigProxy(extPath); - new DisplayConfigProxy( - Gio.DBus.session, -@@ -366,7 +369,7 @@ function performOptimalModeCheck(displayConfigProxy, connectorName, headsetAsPri - } - - // Monitor change handling --export const MonitorManager = GObject.registerClass({ -+var MonitorManager = GObject.registerClass({ - Properties: { - 'use-optimal-monitor-config': GObject.ParamSpec.boolean( - 'use-optimal-monitor-config', -diff --git a/gnome-44-max/src/shader.js b/gnome-44-max/src/shader.js -index f70c96d..352be40 100644 ---- a/gnome-44-max/src/shader.js -+++ b/gnome-44-max/src/shader.js -@@ -1,6 +1,6 @@ --import Gio from 'gi://Gio'; -+const Gio = imports.gi.Gio; - --export function getShaderSource(path) { -+function getShaderSource(path) { - const file = Gio.file_new_for_path(path); - const data = file.load_contents(null); - -diff --git a/gnome-44-max/src/time.js b/gnome-44-max/src/time.js -index 8c17207..fdfdac1 100644 ---- a/gnome-44-max/src/time.js -+++ b/gnome-44-max/src/time.js -@@ -1,11 +1,11 @@ --export function getEpochSec() { -+function getEpochSec() { - return toSec(Date.now()); - } - --export function toSec(milliseconds) { -+function toSec(milliseconds) { - return Math.floor(milliseconds / 1000); - } - --export function isValidKeepAlive(dateSec) { -+function isValidKeepAlive(dateSec) { - return Math.abs(getEpochSec() - dateSec) <= 1; - } -\ No newline at end of file -diff --git a/gnome-44-max/src/virtualdisplayeffect.js b/gnome-44-max/src/virtualdisplayeffect.js -index 26be71e..42da807 100644 ---- a/gnome-44-max/src/virtualdisplayeffect.js -+++ b/gnome-44-max/src/virtualdisplayeffect.js -@@ -1,16 +1,18 @@ --import Clutter from 'gi://Clutter' --import Cogl from 'gi://Cogl'; --import GLib from 'gi://GLib'; --import GObject from 'gi://GObject'; --import Shell from 'gi://Shell'; -+const Clutter = imports.gi.Clutter; -+const Cogl = imports.gi.Cogl; -+const GLib = imports.gi.GLib; -+const GObject = imports.gi.GObject; -+const Shell = imports.gi.Shell; - --import Globals from './globals.js'; --import { degreeToRadian, diagonalToCrossFOVs } from './math.js'; -+const ExtensionUtils = imports.misc.extensionUtils; -+const Me = ExtensionUtils.getCurrentExtension(); - -+const Globals = Me.imports.globals; -+const { degreeToRadian, diagonalToCrossFOVs } = Me.imports.math; - - // these need to mirror the values in XRLinuxDriver - // https://github.com/wheaney/XRLinuxDriver/blob/main/src/plugins/smooth_follow.c#L31 --export const SMOOTH_FOLLOW_SLERP_TIMELINE_MS = 1000; -+var SMOOTH_FOLLOW_SLERP_TIMELINE_MS = 1000; - const SMOOTH_FOLLOW_SLERP_FACTOR = Math.pow(1-0.999, 1/SMOOTH_FOLLOW_SLERP_TIMELINE_MS); - - // this mirror's how the driver's slerp function progresses so our effect will match it -@@ -26,7 +28,7 @@ function lookAheadMS(imuDateMs, lookAheadCfg, override) { - return (override === -1 ? lookAheadCfg[0] : override) + dataAge; - } - --export const VirtualDisplayEffect = GObject.registerClass({ -+var VirtualDisplayEffect = GObject.registerClass({ - Properties: { - 'monitor-index': GObject.ParamSpec.int( - 'monitor-index', -diff --git a/gnome-44-max/src/virtualdisplaysactor.js b/gnome-44-max/src/virtualdisplaysactor.js -index 538fa8c..fa134f1 100644 ---- a/gnome-44-max/src/virtualdisplaysactor.js -+++ b/gnome-44-max/src/virtualdisplaysactor.js -@@ -1,18 +1,19 @@ --import Clutter from 'gi://Clutter' --import Cogl from 'gi://Cogl'; --import GdkPixbuf from 'gi://GdkPixbuf'; --import GLib from 'gi://GLib'; --import GObject from 'gi://GObject'; --import Mtk from 'gi://Mtk'; --import Shell from 'gi://Shell'; --import St from 'gi://St'; -+const Clutter = imports.gi.Clutter; -+const Cogl = imports.gi.Cogl; -+const GdkPixbuf = imports.gi.GdkPixbuf; -+const GLib = imports.gi.GLib; -+const GObject = imports.gi.GObject; -+const Shell = imports.gi.Shell; -+const St = imports.gi.St; - --import { VirtualDisplayEffect, SMOOTH_FOLLOW_SLERP_TIMELINE_MS } from './virtualdisplayeffect.js'; --import { degreeToRadian, diagonalToCrossFOVs } from './math.js'; -+const Main = imports.ui.main; - --import * as Main from 'resource:///org/gnome/shell/ui/main.js'; -+const ExtensionUtils = imports.misc.extensionUtils; -+const Me = ExtensionUtils.getCurrentExtension(); - --import Globals from './globals.js'; -+const { VirtualDisplayEffect, SMOOTH_FOLLOW_SLERP_TIMELINE_MS } = Me.imports.virtualdisplayeffect; -+const Globals = Me.imports.globals; -+const { degreeToRadian, diagonalToCrossFOVs } = Me.imports.math; - - function applyQuaternionToVector(vector, quaternion) { - const t = [ -@@ -394,7 +395,7 @@ function verticalMonitorSort(monitors) { - }); - } - --export const VirtualDisplaysActor = GObject.registerClass({ -+var VirtualDisplaysActor = GObject.registerClass({ - Properties: { - 'target-monitor': GObject.ParamSpec.jsobject( - 'target-monitor', diff --git a/gnome/backports/gnome-44-max b/gnome/backports/gnome-44-max new file mode 160000 index 0000000..1445122 --- /dev/null +++ b/gnome/backports/gnome-44-max @@ -0,0 +1 @@ +Subproject commit 144512201119b6b0522e59a44c7f83461f77f80d diff --git a/gnome/backports/gnome-45 b/gnome/backports/gnome-45 new file mode 160000 index 0000000..ce6f7dd --- /dev/null +++ b/gnome/backports/gnome-45 @@ -0,0 +1 @@ +Subproject commit ce6f7dd7e473100cf15d97e657cff54d0c17f62d diff --git a/gnome/src/extension.js b/gnome/src/extension.js index b3363d5..891bd16 100644 --- a/gnome/src/extension.js +++ b/gnome/src/extension.js @@ -233,6 +233,7 @@ export default class BreezyDesktopExtension extends Extension { virtual_monitors: virtualMonitors, monitor_wrapping_scheme: this.settings.get_string('monitor-wrapping-scheme'), monitor_spacing: this.settings.get_int('monitor-spacing'), + curved_display: this.settings.get_boolean('curved-display'), headset_display_as_viewport_center: this.settings.get_boolean('headset-display-as-viewport-center'), viewport_offset_x: this.settings.get_double('viewport-offset-x'), viewport_offset_y: this.settings.get_double('viewport-offset-y'), @@ -277,6 +278,7 @@ export default class BreezyDesktopExtension extends Extension { this._effect_settings_bindings = [ 'monitor-wrapping-scheme', + 'curved-display', 'headset-display-as-viewport-center', 'viewport-offset-x', 'viewport-offset-y', diff --git a/gnome/src/math.js b/gnome/src/math.js index f1c9983..0eebd6c 100644 --- a/gnome/src/math.js +++ b/gnome/src/math.js @@ -17,4 +17,49 @@ export function diagonalToCrossFOVs(diagonalFOVRadians, aspectRatio) { horizontal: 2 * Math.atan(Math.tan(flatHorizontalFOV / 2)), vertical: 2 * Math.atan(Math.tan(flatVerticalFOV / 2)) } +} + +const segmentsPerRadian = 20.0 / degreeToRadian(90.0); + +// displays are placed around a circle, these functions help determine radians and distances from the original +// FOV measurements scaled to the display dimensions +export const fovConversionFns = { + // convert curved FOV for flat displays + flat: { + // distance to an edge is the hypothenuse of the triangle where the opposite side is half the width of the reference fov screen + centerToFovEdgeDistance: (centerDistance, fovLength) => Math.sqrt(Math.pow(fovLength / 2, 2) + Math.pow(centerDistance, 2)), + fovEdgeToScreenCenterDistance: (edgeDistance, screenLength) => Math.sqrt(Math.pow(edgeDistance, 2) - Math.pow(screenLength / 2, 2)), + lengthToRadians: (fovRadians, fovLength, screenEdgeDistance, toLength) => Math.asin(toLength / 2 / screenEdgeDistance) * 2, + angleToLength: (fovRadians, fovLength, screenDistance, toAngleOpposite, toAngleAdjacent) => { + return toAngleOpposite / toAngleAdjacent * screenDistance + }, + radiansToSegments: (screenRadians) => 1 + }, + + // convert curved FOV for curved displays, scaling either involves no change or is linear + curved: { + centerToFovEdgeDistance: (centerDistance, fovLength) => centerDistance, + fovEdgeToScreenCenterDistance: (edgeDistance, screenLength) => edgeDistance, + lengthToRadians: (fovRadians, fovLength, screenEdgeDistance, toLength) => fovRadians / fovLength * toLength, + angleToLength: (fovRadians, fovLength, screenDistance, toAngleOpposite, toAngleAdjacent) => fovLength / fovRadians * Math.atan2(toAngleOpposite, toAngleAdjacent), + radiansToSegments: (screenRadians) => Math.ceil(screenRadians * segmentsPerRadian) + } +} + +export const applyQuaternionToVector = (vector, quaternion) => { + const t = [ + 2.0 * (quaternion[1] * vector[2] - quaternion[2] * vector[1]), + 2.0 * (quaternion[2] * vector[0] - quaternion[0] * vector[2]), + 2.0 * (quaternion[0] * vector[1] - quaternion[1] * vector[0]) + ]; + return [ + vector[0] + quaternion[3] * t[0] + quaternion[1] * t[2] - quaternion[2] * t[1], + vector[1] + quaternion[3] * t[1] + quaternion[2] * t[0] - quaternion[0] * t[2], + vector[2] + quaternion[3] * t[2] + quaternion[0] * t[1] - quaternion[1] * t[0] + ]; +} + +export const normalizeVector = (vector) => { + const length = Math.sqrt(vector[0] * vector[0] + vector[1] * vector[1] + vector[2] * vector[2]); + return [vector[0] / length, vector[1] / length, vector[2] / length]; } \ No newline at end of file diff --git a/gnome/src/metadata.json b/gnome/src/metadata.json index 0f8073b..f3064c8 100644 --- a/gnome/src/metadata.json +++ b/gnome/src/metadata.json @@ -5,7 +5,7 @@ "settings-schema": "com.xronlinux.BreezyDesktop", "session-modes": ["user"], "shell-version": [ - "45", "46", "47" + "46", "47", "48" ], "url": "https://github.com/wheaney/breezy-desktop" } \ No newline at end of file diff --git a/gnome/src/virtualdisplayeffect.js b/gnome/src/virtualdisplayeffect.js index 26be71e..eac98f2 100644 --- a/gnome/src/virtualdisplayeffect.js +++ b/gnome/src/virtualdisplayeffect.js @@ -5,7 +5,7 @@ import GObject from 'gi://GObject'; import Shell from 'gi://Shell'; import Globals from './globals.js'; -import { degreeToRadian, diagonalToCrossFOVs } from './math.js'; +import { degreeToRadian, diagonalToCrossFOVs, fovConversionFns } from './math.js'; // these need to mirror the values in XRLinuxDriver @@ -26,6 +26,89 @@ function lookAheadMS(imuDateMs, lookAheadCfg, override) { return (override === -1 ? lookAheadCfg[0] : override) + dataAge; } +// Create a mesh of vertices in a pattern suitable for TRIANGLE_STRIP +function createVertexMesh(fovDetails, monitorDetails, positionVectorNWU) { + let fovConversions = fovDetails.curvedDisplay ? fovConversionFns.curved : fovConversionFns.flat; + const sideEdgeDistancePixels = fovConversions.centerToFovEdgeDistance( + fovDetails.completeScreenDistancePixels, + fovDetails.widthPixels + ); + const horizontalRadians = fovConversions.lengthToRadians( + fovDetails.defaultDistanceHorizontalRadians, + fovDetails.widthPixels, + sideEdgeDistancePixels, + monitorDetails.width + ); + + const topEdgeDistancePixels = fovConversions.centerToFovEdgeDistance( + fovDetails.completeScreenDistancePixels, + fovDetails.heightPixels + ); + const verticalRadians = fovConversions.lengthToRadians( + fovDetails.defaultDistanceVerticalRadians, + fovDetails.heightPixels, + topEdgeDistancePixels, + monitorDetails.height + ); + + let horizontalWrap = fovDetails.monitorWrappingScheme === 'horizontal'; + let verticalWrap = fovDetails.monitorWrappingScheme === 'vertical'; + const xSegments = horizontalWrap ? fovConversions.radiansToSegments(horizontalRadians) : 1; + const ySegments = verticalWrap ? fovConversions.radiansToSegments(verticalRadians) : 1; + + const texXLeft = 0; + const texYTop = 0; + const texXRight = 1; + const texYBottom = 1; + + // curve the monitor placments based on the fov, wrapping, and texture coordinates + const radius = fovDetails.completeScreenDistancePixels; + function v(s, t) { + let zOffsetPixels = 0 + + const xOffset = s - 0.5; + let xOffsetPixels = monitorDetails.width * xOffset; + if (fovDetails.curvedDisplay && horizontalWrap) { + const xOffsetRadians = xOffset * horizontalRadians; + xOffsetPixels = Math.sin(xOffsetRadians) * radius; + zOffsetPixels = radius - Math.cos(xOffsetRadians) * radius; + } + const x = -positionVectorNWU[1] + xOffsetPixels; + + const yOffset = 0.5 - t; + let yOffsetPixels = monitorDetails.height * yOffset; + if (fovDetails.curvedDisplay && verticalWrap) { + const yOffsetRadians = yOffset * verticalRadians; + yOffsetPixels = Math.sin(yOffsetRadians) * radius; + zOffsetPixels = radius - Math.cos(yOffsetRadians) * radius; + } + const y = positionVectorNWU[2] + yOffsetPixels; + const z = -positionVectorNWU[0] + zOffsetPixels; + + return new Cogl.VertexP3T2({x, y, z, s, t}); + } + + const vertices = []; + for (let j = 0; j < ySegments; j++) { + const texY0 = texYTop - (texYTop - texYBottom) * j / ySegments; + const texY1 = texYTop - (texYTop - texYBottom) * (j + 1) / ySegments; + + const evenRow = j % 2 === 0; + for (let i = 0; i <= xSegments; i++) { + // even rows stitch left-to-right, odd rows stitch right-to-left + const colIndex = evenRow ? i : xSegments - i; + + const texX = texXLeft + (texXRight - texXLeft) * colIndex / xSegments; + + // bottom then top + vertices.push(v(texX, texY1)); + vertices.push(v(texX, texY0)); + } + } + + return vertices; +} + export const VirtualDisplayEffect = GObject.registerClass({ Properties: { 'monitor-index': GObject.ParamSpec.int( @@ -35,12 +118,24 @@ export const VirtualDisplayEffect = GObject.registerClass({ GObject.ParamFlags.READWRITE, 0, 100, 0 ), + 'monitor-details': GObject.ParamSpec.jsobject( + 'monitor-details', + 'Monitor Details', + 'Details about the monitor that this effect is applied to', + GObject.ParamFlags.READWRITE + ), 'monitor-placements': GObject.ParamSpec.jsobject( 'monitor-placements', 'Monitor Placements', 'Target and virtual monitor placement details, as relevant to rendering', GObject.ParamFlags.READWRITE ), + 'fov-details': GObject.ParamSpec.jsobject( + 'fov-details', + 'FOV Details', + 'Details about the field of view of the headset', + GObject.ParamFlags.READWRITE + ), 'target-monitor': GObject.ParamSpec.jsobject( 'target-monitor', 'Target Monitor', @@ -67,20 +162,6 @@ export const VirtualDisplayEffect = GObject.registerClass({ GObject.ParamFlags.READWRITE, 0, Number.MAX_SAFE_INTEGER, 0 ), - 'width': GObject.ParamSpec.int( - 'width', - 'Width', - 'Width of the viewport', - GObject.ParamFlags.READWRITE, - 1, 10000, 1920 - ), - 'height': GObject.ParamSpec.int( - 'height', - 'Height', - 'Height of the viewport', - GObject.ParamFlags.READWRITE, - 1, 10000, 1080 - ), 'focused-monitor-index': GObject.ParamSpec.int( 'focused-monitor-index', 'Focused Monitor Index', @@ -173,10 +254,11 @@ export const VirtualDisplayEffect = GObject.registerClass({ this.connect('notify::display-distance', this._update_display_distance.bind(this)); this.connect('notify::focused-monitor-index', this._update_display_distance.bind(this)); - this.connect('notify::monitor-placements', this._update_display_position_uniforms.bind(this)); - this.connect('notify::monitor-wrapping-scheme', this._update_display_position_uniforms.bind(this)); + this.connect('notify::monitor-placements', this._update_display_position.bind(this)); this.connect('notify::show-banner', this._handle_banner_update.bind(this)); this.connect('notify::smooth-follow-enabled', this._handle_smooth_follow_enabled_update.bind(this)); + + this._update_display_position(); } _is_focused() { @@ -194,7 +276,7 @@ export const VirtualDisplayEffect = GObject.registerClass({ if (this.no_distance_ease) { this._current_display_distance = desired_distance; - this._update_display_position_uniforms(); + this._update_display_position(); this.no_distance_ease = false; return; } @@ -231,7 +313,7 @@ export const VirtualDisplayEffect = GObject.registerClass({ this._current_display_distance = this._distance_ease_start + (1 - Math.cos(progress * Math.PI)) / 2 * (this._distance_ease_target - this._distance_ease_start); - this._update_display_position_uniforms(); + this._update_display_position(); }).bind(this)); this._distance_ease_timeline.start(); @@ -266,14 +348,14 @@ export const VirtualDisplayEffect = GObject.registerClass({ // this relies on the slerp function tuned to reach 100% in about 1 second const progress = smoothFollowSlerpProgress(toggleTimeOffsetMs); this._current_follow_ease_progress = from + (to - from) * progress; - this._update_display_position_uniforms(); + this._update_display_position(); }).bind(this)); this._follow_ease_timeline.connect('completed', (() => { this._current_follow_ease_progress = to; this._use_smooth_follow_origin = false; this.smooth_follow_toggle_epoch_ms = 0; - this._update_display_position_uniforms(); + this._update_display_position(); }).bind(this)); this._follow_ease_timeline.start(); @@ -294,35 +376,25 @@ export const VirtualDisplayEffect = GObject.registerClass({ } } - // follow_ease transitions this from a rotated display (0.0) to a centered/focused display (1.0) - _update_display_position_uniforms() { + // follow_ease transitions this from a rotated display (progress 0.0) to a centered/focused display (progress 1.0) + _update_display_position() { // this is in NWU coordinates - const monitorPlacement = this.monitor_placements[this.monitor_index]; - - // use the center vector with the distance applied to determine how much to move each coordinate, so they all move uniformly - const inverseAppliedDistance = 1.0 - this._current_display_distance / this.display_distance_default; - const distanceDelta = monitorPlacement.centerNoRotate.map(coord => coord * inverseAppliedDistance); - const noRotationVector = monitorPlacement.topLeftNoRotate.map((coord, index) => coord - distanceDelta[index]); - - // convert to CoGL's east-down-south coordinates and apply display distance + const monitorPlacement = this.monitor_placements[this.monitor_index]; + const noRotationVector = monitorPlacement.centerNoRotate.map(coord => coord * this._current_display_distance / this.display_distance_default); const inverse_follow_ease = 1.0 - this._current_follow_ease_progress; - if (this._current_follow_ease_progress === 0.0) { - this.set_uniform_float(this.get_uniform_location("u_display_position"), 3, - [-noRotationVector[1], -noRotationVector[2], -noRotationVector[0]]); - } else { - const focusDistanceNorth = monitorPlacement.centerOrigin[0] * inverseAppliedDistance; - const centerOriginVector = {...monitorPlacement.centerOrigin}; - centerOriginVector[0] -= focusDistanceNorth; - + let finalPositionVector = noRotationVector; + if (this._current_follow_ease_progress > 0.0) { // slerp from the rotated display to the centered display - const followVector = noRotationVector.map((coord, index) => coord * inverse_follow_ease + centerOriginVector[index] * this._current_follow_ease_progress); - this.set_uniform_float(this.get_uniform_location("u_display_position"), 3, - [-followVector[1], -followVector[2], -followVector[0]]); + finalPositionVector = noRotationVector.map(coord => coord * inverse_follow_ease); + finalPositionVector[0] = noRotationVector[0]; } + this._vertices = createVertexMesh(this.fov_details, this.monitor_details, finalPositionVector); const rotation_radians = this.monitor_placements[this.monitor_index].rotationAngleRadians; - this.set_uniform_float(this.get_uniform_location("u_rotation_x_radians"), 1, [rotation_radians.x * inverse_follow_ease]); - this.set_uniform_float(this.get_uniform_location("u_rotation_y_radians"), 1, [rotation_radians.y * inverse_follow_ease]); + if (this._initialized) { + this.set_uniform_float(this.get_uniform_location("u_rotation_x_radians"), 1, [rotation_radians.x * inverse_follow_ease]); + this.set_uniform_float(this.get_uniform_location("u_rotation_y_radians"), 1, [rotation_radians.y * inverse_follow_ease]); + } } _handle_banner_update() { @@ -349,7 +421,6 @@ export const VirtualDisplayEffect = GObject.registerClass({ uniform vec4 u_look_ahead_cfg; uniform mat4 u_projection_matrix; uniform float u_fov_vertical_radians; - uniform vec3 u_display_position; uniform float u_rotation_x_radians; uniform float u_rotation_y_radians; uniform vec2 u_display_resolution; @@ -415,23 +486,6 @@ export const VirtualDisplayEffect = GObject.registerClass({ if (!u_show_banner) { float aspect_ratio = u_display_resolution.x / u_display_resolution.y; - float cogl_position_width = cogl_position_mystery_factor * aspect_ratio / u_actor_to_display_ratios.y; - float cogl_position_height = cogl_position_width / aspect_ratio; - - float pos_z_factor = aspect_ratio / u_actor_to_display_ratios.y; - vec3 pos_factors = vec3( - cogl_position_width / u_display_resolution.x, - cogl_position_height / u_display_resolution.y, - cogl_position_mystery_factor * pos_z_factor / u_display_resolution.x - ); - world_pos.x -= u_display_position.x * pos_factors.x; - world_pos.y -= u_display_position.y * pos_factors.y; - world_pos.z = u_display_position.z * pos_factors.z; - - // if the perspective includes more than just our viewport actor, move vertices towards the center of the perspective so they'll be properly rotated - world_pos.x += u_actor_to_display_offsets.x * cogl_position_width / 2; - world_pos.y -= u_actor_to_display_offsets.y * cogl_position_height / 2; - vec3 complete_vector = applyXRotationToVector(world_pos.xyz, u_rotation_x_radians); complete_vector = applyYRotationToVector(complete_vector, u_rotation_y_radians); @@ -447,10 +501,9 @@ export const VirtualDisplayEffect = GObject.registerClass({ vec3 look_ahead_vector = applyLookAhead(rotated_vector_t0, velocity_t0, effective_look_ahead_ms); - vec3 adjusted_lens_vector = u_lens_vector * pos_factors; - world_pos = vec4(look_ahead_vector - adjusted_lens_vector, world_pos.w); + world_pos = vec4(look_ahead_vector - u_lens_vector, world_pos.w); - world_pos.z /= pos_z_factor; + world_pos.z /= aspect_ratio / u_actor_to_display_ratios.y; world_pos.x *= u_actor_to_display_ratios.y / u_actor_to_display_ratios.x; @@ -473,28 +526,29 @@ export const VirtualDisplayEffect = GObject.registerClass({ } vfunc_paint_target(node, paintContext) { - if (this.imu_snapshots) { - if (!this._initialized) { - const aspect = this.target_monitor.width / this.target_monitor.height; - const fovRadians = diagonalToCrossFOVs(degreeToRadian(Globals.data_stream.device_data.displayFov), aspect); - const projection_matrix = this.perspective( - fovRadians.horizontal, - aspect, - 0.0001, - 1000.0 - ); - this.set_uniform_matrix(this.get_uniform_location("u_projection_matrix"), false, 4, projection_matrix); - this.set_uniform_float(this.get_uniform_location("u_fov_vertical_radians"), 1, [fovRadians.vertical]); - this.set_uniform_float(this.get_uniform_location("u_display_resolution"), 2, [this.target_monitor.width, this.target_monitor.height]); - this.set_uniform_float(this.get_uniform_location("u_look_ahead_cfg"), 4, Globals.data_stream.device_data.lookAheadCfg); - this.set_uniform_float(this.get_uniform_location("u_actor_to_display_ratios"), 2, this.actor_to_display_ratios); - this.set_uniform_float(this.get_uniform_location("u_actor_to_display_offsets"), 2, this.actor_to_display_offsets); - this.set_uniform_float(this.get_uniform_location("u_lens_vector"), 3, this.lens_vector); - this._update_display_position_uniforms(); - this._handle_banner_update(); - this._initialized = true; - } + if (!this._initialized) { + this._initialized = true; + const aspect = this.target_monitor.width / this.target_monitor.height; + const fovRadians = diagonalToCrossFOVs(degreeToRadian(Globals.data_stream.device_data.displayFov), aspect); + const projection_matrix = this.perspective( + fovRadians.horizontal, + aspect, + 1.0, + 10000.0 + ); + this.set_uniform_matrix(this.get_uniform_location("u_projection_matrix"), false, 4, projection_matrix); + this.set_uniform_float(this.get_uniform_location("u_fov_vertical_radians"), 1, [fovRadians.vertical]); + this.set_uniform_float(this.get_uniform_location("u_display_resolution"), 2, [this.target_monitor.width, this.target_monitor.height]); + this.set_uniform_float(this.get_uniform_location("u_look_ahead_cfg"), 4, Globals.data_stream.device_data.lookAheadCfg); + this.set_uniform_float(this.get_uniform_location("u_actor_to_display_ratios"), 2, this.actor_to_display_ratios); + this.set_uniform_float(this.get_uniform_location("u_actor_to_display_offsets"), 2, this.actor_to_display_offsets); + this.set_uniform_float(this.get_uniform_location("u_lens_vector"), 3, this.lens_vector); + this._update_display_position(); + this._handle_banner_update(); + } + + if (this.imu_snapshots && !this.show_banner) { let lookAheadSet = false; if (!this._use_smooth_follow_origin && (!this.smooth_follow_enabled || this._is_focused() || this._current_follow_ease_progress > 0.0)) { if (this._current_follow_ease_progress > 0.0 && this._current_follow_ease_progress < 1.0) { @@ -518,8 +572,14 @@ export const VirtualDisplayEffect = GObject.registerClass({ Cogl.PipelineFilter.LINEAR ); } - } - super.vfunc_paint_target(node, paintContext); + // skip the actor's default rendering, draw our custom vertices instead + const framebuffer = paintContext.get_framebuffer(); + const coglContext = framebuffer.get_context(); + const primitive = Cogl.Primitive.new_p3t2(coglContext, Cogl.VerticesMode.TRIANGLE_STRIP, this._vertices); + primitive.draw(framebuffer, this.get_pipeline()); + } else { + super.vfunc_paint_target(node, paintContext); + } } }); \ No newline at end of file diff --git a/gnome/src/virtualdisplaysactor.js b/gnome/src/virtualdisplaysactor.js index 538fa8c..9099189 100644 --- a/gnome/src/virtualdisplaysactor.js +++ b/gnome/src/virtualdisplaysactor.js @@ -3,35 +3,21 @@ import Cogl from 'gi://Cogl'; import GdkPixbuf from 'gi://GdkPixbuf'; import GLib from 'gi://GLib'; import GObject from 'gi://GObject'; -import Mtk from 'gi://Mtk'; import Shell from 'gi://Shell'; import St from 'gi://St'; import { VirtualDisplayEffect, SMOOTH_FOLLOW_SLERP_TIMELINE_MS } from './virtualdisplayeffect.js'; -import { degreeToRadian, diagonalToCrossFOVs } from './math.js'; +import { applyQuaternionToVector, degreeToRadian, diagonalToCrossFOVs, fovConversionFns, normalizeVector } from './math.js'; import * as Main from 'resource:///org/gnome/shell/ui/main.js'; import Globals from './globals.js'; -function applyQuaternionToVector(vector, quaternion) { - const t = [ - 2.0 * (quaternion[1] * vector[2] - quaternion[2] * vector[1]), - 2.0 * (quaternion[2] * vector[0] - quaternion[0] * vector[2]), - 2.0 * (quaternion[0] * vector[1] - quaternion[1] * vector[0]) - ]; - return [ - vector[0] + quaternion[3] * t[0] + quaternion[1] * t[2] - quaternion[2] * t[1], - vector[1] + quaternion[3] * t[1] + quaternion[2] * t[0] - quaternion[0] * t[2], - vector[2] + quaternion[3] * t[2] + quaternion[0] * t[1] - quaternion[1] * t[0] - ]; -} - // if nothing is in focus, take it as soon as it crosses into the monitor's bounds const FOCUS_THRESHOLD = 0.95 / 2.0; // if we leave the monitor with some margin, unfocus even if no other monitor is in focus -const UNFOCUS_THRESHOLD = 1.2 / 2.0; +const UNFOCUS_THRESHOLD = 1.1 / 2.0; /** * Find the vector in the array that's closest to the quaternion rotation @@ -49,46 +35,56 @@ function findFocusedMonitor(quaternion, monitorVectors, currentFocusedIndex, foc const lookVector = [1.0, 0.0, 0.0]; // NWU vector pointing to the center of the screen const rotatedLookVector = applyQuaternionToVector(lookVector, quaternion); - const xzMagnitude = Math.sqrt(rotatedLookVector[0]*rotatedLookVector[0] + rotatedLookVector[2]*rotatedLookVector[2]); - const lookUpTheta = Math.atan2(rotatedLookVector[2], rotatedLookVector[0]); + // TODO - right now we're using the curved functions to figure out distances even for flat monitors + // because it will account for the monitors facing towards us, but this will lose some accuracy + const upConversionFns = fovDetails.monitorWrappingScheme === 'vertical' ? fovConversionFns.curved : fovConversionFns.flat; + const lookUpPixels = upConversionFns.angleToLength( + fovDetails.defaultDistanceVerticalRadians, + fovDetails.heightPixels, + fovDetails.completeScreenDistancePixels, + rotatedLookVector[2], + rotatedLookVector[0] + ); + const westConversionFns = fovDetails.monitorWrappingScheme === 'horizontal' ? fovConversionFns.curved : fovConversionFns.flat; + const lookWestPixels = westConversionFns.angleToLength( + fovDetails.defaultDistanceHorizontalRadians, + fovDetails.widthPixels, + fovDetails.completeScreenDistancePixels, + rotatedLookVector[1], + rotatedLookVector[0] + ); let closestIndex = -1; let closestDistance = Infinity; let currentFocusedDistance = Infinity; // find the vector closest to the rotated look vector - monitorVectors.forEach((vector, index) => { + monitorVectors.forEach((monitorVector, index) => { const monitor = monitorsDetails[index]; const monitorAspectRatio = monitor.width / monitor.height; - // weight the rotation about the y-axis between the two vectors, by the aspect ratio - const vectorUpTheta = Math.atan2(vector[2], vector[0]); - const upDelta = lookUpTheta - vectorUpTheta; - const newLookUpTheta = Math.tan(Math.max( - -Math.PI, - Math.min( - Math.PI, - upDelta * monitorAspectRatio + vectorUpTheta - ) - )); - const weightedLookVector = [ - xzMagnitude * Math.cos(newLookUpTheta), - rotatedLookVector[1], - xzMagnitude * Math.sin(newLookUpTheta) - ]; - - // find the distance between the monitor vector and weighted look vector - const distance = Math.acos( - Math.min(1.0, Math.max(-1.0, - vector[0] * weightedLookVector[0] + - vector[1] * weightedLookVector[1] + - vector[2] * weightedLookVector[2] - )) + // weight the up distance by the aspect ratio + const vectorUpPixels = upConversionFns.angleToLength( + fovDetails.defaultDistanceVerticalRadians, + fovDetails.heightPixels, + fovDetails.completeScreenDistancePixels, + monitorVector[2], + monitorVector[0] ); + const upDeltaPixels = (lookUpPixels - vectorUpPixels) * monitorAspectRatio; - // TODO - this assumes the display is facing towards us, need to account for looking in the "flat" direction - const distanceFromCenterPixels = fovDetails.completeScreenDistancePixels * Math.tan(distance); - const distanceFromCenterSizeRatio = distanceFromCenterPixels / monitor.width; + const vectorWestPixels = westConversionFns.angleToLength( + fovDetails.defaultDistanceHorizontalRadians, + fovDetails.widthPixels, + fovDetails.completeScreenDistancePixels, + monitorVector[1], + monitorVector[0] + ); + const westDeltaPixels = lookWestPixels - vectorWestPixels; + const totalDeltaPixels = Math.sqrt(upDeltaPixels * upDeltaPixels + westDeltaPixels * westDeltaPixels); + + // threshold is a percentage of width, and height was already properly weighted + const distanceFromCenterSizeRatio = totalDeltaPixels / monitor.width; if (currentFocusedIndex === index) { currentFocusedDistance = distanceFromCenterSizeRatio * focusedMonitorDistance; @@ -114,7 +110,7 @@ function findFocusedMonitor(quaternion, monitorVectors, currentFocusedIndex, foc /*** * @returns {Object} - containing `begin`, `center`, and `end` radians for rotating the given monitor */ -function monitorWrap(cachedMonitorRadians, radiusPixels, monitorSpacingPixels, monitorBeginPixel, monitorLengthPixels) { +function monitorWrap(cachedMonitorRadians, monitorSpacingPixels, monitorBeginPixel, monitorLengthPixels, lengthToRadianFn) { let closestWrapPixel = monitorBeginPixel; let closestWrap = cachedMonitorRadians[monitorBeginPixel]; if (closestWrap === undefined) { @@ -140,12 +136,11 @@ function monitorWrap(cachedMonitorRadians, radiusPixels, monitorSpacingPixels, m closestWrap = cachedMonitorRadians[closestWrapPixel]; } - const spacingRadians = Math.asin(monitorSpacingPixels / 2 / radiusPixels) * 2; + const spacingRadians = lengthToRadianFn(monitorSpacingPixels); if (closestWrapPixel !== monitorBeginPixel) { // there's a gap between the cached wrap value and this one const gapPixels = monitorBeginPixel - closestWrapPixel; - const gapHalfRadians = Math.asin(gapPixels / 2 / radiusPixels); - const gapRadians = gapHalfRadians * 2; + const gapRadians = lengthToRadianFn(gapPixels); // use Math.floor so if it's negative (this monitor is to the left of or above the closest) it will always // compenstate for the spacing that's needed at the right/bottom @@ -157,9 +152,9 @@ function monitorWrap(cachedMonitorRadians, radiusPixels, monitorSpacingPixels, m cachedMonitorRadians[closestWrapPixel] = closestWrap; } - const monitorHalfRadians = Math.asin(monitorLengthPixels / 2 / radiusPixels); - const centerRadians = closestWrap + monitorHalfRadians; - const endRadians = centerRadians + monitorHalfRadians; + const monitorRadians = lengthToRadianFn(monitorLengthPixels); + const centerRadians = closestWrap + monitorRadians / 2; + const endRadians = closestWrap + monitorRadians; // since we're computing the end values for this monitor, cache them too in case they line up with a future monitor const nextMonitorPixel = monitorBeginPixel + monitorLengthPixels; @@ -180,62 +175,53 @@ function monitorWrap(cachedMonitorRadians, radiusPixels, monitorSpacingPixels, m * @param {Object} fovDetails - contains reference widthPixels, heightPixels, horizontal and vertical radians, * and distance to the center of the screen * @param {Object[]} monitorDetailsList - contains x, y, width, height (coordinates from top-left) - * @param {string} monitorWrappingScheme - horizontal, vertical, none * @param {number} monitorSpacing - visual spacing between monitors, as a percentage of the viewport width - * @returns {Object[]} - contains NWU vectors pointing to `topLeftNoRotate` and `center` of each monitor - * and a `rotation` angle for the given wrapping scheme + * @returns {Object[]} - contains NWU vectors used for rendering and focused monitor detection */ -function monitorsToPlacements(fovDetails, monitorDetailsList, monitorWrappingScheme, monitorSpacing) { +function monitorsToPlacements(fovDetails, monitorDetailsList, monitorSpacing) { const monitorPlacements = []; const cachedMonitorRadians = {}; - Globals.logger.log_debug(`\t\t\tFOV Details: ${JSON.stringify(fovDetails)}, Monitor Wrapping Scheme: ${monitorWrappingScheme}`); + Globals.logger.log_debug(`\t\t\tFOV Details: ${JSON.stringify(fovDetails)}`); - if (monitorWrappingScheme === 'horizontal') { + const conversionFns = fovDetails.curvedDisplay ? fovConversionFns.curved : fovConversionFns.flat; + + if (fovDetails.monitorWrappingScheme === 'horizontal') { // monitors wrap around us horizontally - // distance to a horizontal edge is the hypothenuse of the triangle where the opposite side is half the width of the reference fov screen - const sideEdgeRadius = Math.sqrt(Math.pow(fovDetails.widthPixels / 2, 2) + Math.pow(fovDetails.completeScreenDistancePixels, 2)); + const sideEdgeRadius = conversionFns.centerToFovEdgeDistance(fovDetails.completeScreenDistancePixels, fovDetails.widthPixels); const monitorSpacingPixels = monitorSpacing * fovDetails.widthPixels; + const lengthToRadianFn = (targetWidth) => conversionFns.lengthToRadians( + fovDetails.defaultDistanceHorizontalRadians, + fovDetails.widthPixels, + sideEdgeRadius, + targetWidth + ); cachedMonitorRadians[0] = -fovDetails.defaultDistanceHorizontalRadians / 2; horizontalMonitorSort(monitorDetailsList).forEach(({monitorDetails, originalIndex}) => { - const monitorWrapDetails = monitorWrap(cachedMonitorRadians, sideEdgeRadius, monitorSpacingPixels, monitorDetails.x, monitorDetails.width); - const monitorCenterRadius = Math.sqrt(Math.pow(sideEdgeRadius, 2) - Math.pow(monitorDetails.width / 2, 2)); - const upTopPixels = monitorDetails.y + (monitorDetails.y / fovDetails.heightPixels) * monitorSpacingPixels; + const monitorWrapDetails = monitorWrap(cachedMonitorRadians, monitorSpacingPixels, monitorDetails.x, monitorDetails.width, lengthToRadianFn); + const monitorCenterRadius = conversionFns.fovEdgeToScreenCenterDistance(sideEdgeRadius, monitorDetails.width); + const upTopPixels = -monitorDetails.y - (monitorDetails.y / fovDetails.heightPixels) * monitorSpacingPixels; - // how to place the monitors at the origin (0, 0) - const westCenterOriginPixels = (monitorDetails.width - fovDetails.widthPixels) / 2; - const upCenterOriginPixels = (monitorDetails.height - fovDetails.heightPixels) / 2; + // offset for aligning this monitor's center with the fov-sized viewport's center + const upCenterOffsetPixels = (monitorDetails.height - fovDetails.heightPixels) / 2; - const upCenterPixels = upTopPixels + upCenterOriginPixels; + // this is where our monitor's center is in relation to an fov-sized viewport centered about (0, 0) + const upCenterPixels = upTopPixels - upCenterOffsetPixels; monitorPlacements.push({ originalIndex, - topLeftNoRotate: [ - monitorCenterRadius, - - // west stays aligned with the origin, will apply rotationAngleRadians value during rendering - -westCenterOriginPixels, - - // up is flat when wrapping horizontally, apply it here as a constant, not touched by rendering - -upTopPixels - ], centerNoRotate: [ monitorCenterRadius, - // west centered about the FOV center + // west is centered about the FOV center 0, // up is flat when wrapping horizontally - -upCenterPixels + upCenterPixels ], - centerOrigin: [ - monitorCenterRadius, - -westCenterOriginPixels, - upCenterOriginPixels - ], - centerLook: [ + centerLook: normalizeVector([ // north is adjacent where radius is the hypotenuse, using monitorWrapDetails.center as the radians monitorCenterRadius * Math.cos(monitorWrapDetails.center), @@ -243,68 +229,59 @@ function monitorsToPlacements(fovDetails, monitorDetailsList, monitorWrappingSch -monitorCenterRadius * Math.sin(monitorWrapDetails.center), // up is flat when wrapping horizontally - -upCenterPixels - ], + upCenterPixels + ]), rotationAngleRadians: { x: 0, y: -monitorWrapDetails.center } }); }); - } else if (monitorWrappingScheme === 'vertical') { + } else if (fovDetails.monitorWrappingScheme === 'vertical') { // monitors wrap around us vertically - // distance to the top edge is the hypothenuse of the triangle where the opposite side is half the height of the reference fov screen - const topEdgeRadius = Math.sqrt(Math.pow(fovDetails.heightPixels / 2, 2) + Math.pow(fovDetails.completeScreenDistancePixels, 2)); + const topEdgeRadius = conversionFns.centerToFovEdgeDistance(fovDetails.completeScreenDistancePixels, fovDetails.heightPixels); const monitorSpacingPixels = monitorSpacing * fovDetails.heightPixels; + const lengthToRadianFn = (targetHeight) => conversionFns.lengthToRadians( + fovDetails.defaultDistanceVerticalRadians, + fovDetails.heightPixels, + topEdgeRadius, + targetHeight + ); cachedMonitorRadians[0] = -fovDetails.defaultDistanceVerticalRadians / 2; verticalMonitorSort(monitorDetailsList).forEach(({monitorDetails, originalIndex}) => { - const monitorWrapDetails = monitorWrap(cachedMonitorRadians, topEdgeRadius, monitorSpacingPixels, monitorDetails.y, monitorDetails.height); - const monitorCenterRadius = Math.sqrt(Math.pow(topEdgeRadius, 2) - Math.pow(monitorDetails.height / 2, 2)); - const westPixels = monitorDetails.x + (monitorDetails.x / fovDetails.widthPixels) * monitorSpacingPixels; + const monitorWrapDetails = monitorWrap(cachedMonitorRadians, monitorSpacingPixels, monitorDetails.y, monitorDetails.height, lengthToRadianFn); + const monitorCenterRadius = conversionFns.fovEdgeToScreenCenterDistance(topEdgeRadius, monitorDetails.height); + const westLeftPixels = -monitorDetails.x - (monitorDetails.x / fovDetails.widthPixels) * monitorSpacingPixels; - // how to place the monitors at the origin (0, 0) - const westCenterOriginPixels = (monitorDetails.width - fovDetails.widthPixels) / 2; - const upCenterOriginPixels = (monitorDetails.height - fovDetails.heightPixels) / 2; + // offset for aligning this monitor's center with the fov-sized viewport's center + const westCenterOffsetPixels = (monitorDetails.width - fovDetails.widthPixels) / 2; - const westCenterPixels = westPixels + westCenterOriginPixels; + // this is where our monitor's center is in relation to an fov-sized viewport centered about (0, 0) + const westCenterPixels = westLeftPixels - westCenterOffsetPixels; monitorPlacements.push({ originalIndex, - topLeftNoRotate: [ - monitorCenterRadius, - - // west is flat when wrapping vertically, apply it here as a constant, not touched by rendering - westPixels, - - // up stays aligned with the origin, will apply rotationAngleRadians value during rendering - upCenterOriginPixels - ], centerNoRotate: [ monitorCenterRadius, // west is flat when wrapping horizontally westCenterPixels, - // west centered about the FOV center + // up is centered about the FOV center 0 ], - centerOrigin: [ - monitorCenterRadius, - -westCenterOriginPixels, - upCenterOriginPixels - ], - centerLook: [ + centerLook: normalizeVector([ // north is adjacent where radius is the hypotenuse, using monitorWrapDetails.center as the radians monitorCenterRadius * Math.cos(monitorWrapDetails.center), // west is flat when wrapping vertically - -westCenterPixels, + westCenterPixels, // up is opposite where radius is the hypotenuse, using monitorWrapDetails.center as the radians -monitorCenterRadius * Math.sin(monitorWrapDetails.center) - ], + ]), rotationAngleRadians: { x: -monitorWrapDetails.center, y: 0 @@ -316,38 +293,28 @@ function monitorsToPlacements(fovDetails, monitorDetailsList, monitorWrappingSch // monitors make a flat wall in front of us, no wrapping monitorDetailsList.forEach((monitorDetails, index) => { - const upPixels = monitorDetails.y + (monitorDetails.y / fovDetails.heightPixels) * monitorSpacingPixels; - const westPixels = monitorDetails.x + (monitorDetails.x / fovDetails.widthPixels) * monitorSpacingPixels; + const upTopPixels = -monitorDetails.y - (monitorDetails.y / fovDetails.heightPixels) * monitorSpacingPixels; + const westLeftPixels = -monitorDetails.x - (monitorDetails.x / fovDetails.widthPixels) * monitorSpacingPixels; - // how to place the monitors at the origin (0, 0) - const westCenterOriginPixels = (monitorDetails.width - fovDetails.widthPixels) / 2; - const upCenterOriginPixels = (monitorDetails.height - fovDetails.heightPixels) / 2; + // offsets for aligning this monitor's center with the fov-sized viewport's center + const westCenterOffsetPixels = (monitorDetails.width - fovDetails.widthPixels) / 2; + const upCenterOffsetPixels = (monitorDetails.height - fovDetails.heightPixels) / 2; - const westCenterPixels = westPixels + westCenterOriginPixels; - const upCenterPixels = upPixels + upCenterOriginPixels; + const westCenterPixels = westLeftPixels - westCenterOffsetPixels; + const upCenterPixels = upTopPixels - upCenterOffsetPixels; monitorPlacements.push({ originalIndex: index, - topLeftNoRotate: [ - fovDetails.completeScreenDistancePixels, - westPixels, - -upPixels - ], centerNoRotate: [ fovDetails.completeScreenDistancePixels, westCenterPixels, - -upCenterPixels + upCenterPixels ], - centerOrigin: [ + centerLook: normalizeVector([ fovDetails.completeScreenDistancePixels, - -westCenterOriginPixels, - upCenterOriginPixels - ], - centerLook: [ - fovDetails.completeScreenDistancePixels, - -westCenterPixels, - -upCenterPixels - ], + westCenterPixels, + upCenterPixels + ]), rotationAngleRadians: { x: 0, y: 0 @@ -408,6 +375,12 @@ export const VirtualDisplaysActor = GObject.registerClass({ 'Details about the virtual monitors', GObject.ParamFlags.READWRITE ), + 'fov-details': GObject.ParamSpec.jsobject( + 'fov-details', + 'FOV Details', + 'Details about the field of view of the headset', + GObject.ParamFlags.READWRITE + ), 'monitor-wrapping-scheme': GObject.ParamSpec.string( 'monitor-wrapping-scheme', 'Monitor Wrapping Scheme', @@ -454,6 +427,13 @@ export const VirtualDisplaysActor = GObject.registerClass({ 'Latest IMU quaternion snapshots and epoch timestamp for when it was collected', GObject.ParamFlags.READWRITE ), + 'curved-display': GObject.ParamSpec.boolean( + 'curved-display', + 'Curved Display', + 'Whether the displays are curved', + GObject.ParamFlags.READWRITE, + false + ), 'smooth-follow-enabled': GObject.ParamSpec.boolean( 'smooth-follow-enabled', 'Smooth follow enabled', @@ -583,6 +563,7 @@ export const VirtualDisplaysActor = GObject.registerClass({ this.target_monitor, ...this.virtual_monitors ]; + this.focused_monitor_index = -1; try { const calibratingBanner = GdkPixbuf.Pixbuf.new_from_file(`${Globals.extension_dir}/textures/calibrating.png`); @@ -656,6 +637,7 @@ export const VirtualDisplaysActor = GObject.registerClass({ notifyToFunction('monitor-wrapping-scheme', this._update_monitor_placements); notifyToFunction('monitor-spacing', this._update_monitor_placements); notifyToFunction('headset-display-as-viewport-center', this._update_monitor_placements); + notifyToFunction('curved-display', this._update_monitor_placements); notifyToFunction('viewport-offset-x', this._update_monitor_placements); notifyToFunction('viewport-offset-y', this._update_monitor_placements); notifyToFunction('show-banner', this._handle_banner_update); @@ -706,7 +688,9 @@ export const VirtualDisplaysActor = GObject.registerClass({ focused_monitor_index: this.focused_monitor_index, imu_snapshots: this.imu_snapshots, monitor_index: index, + monitor_details: monitor, monitor_placements: this.monitor_placements, + fov_details: this.fov_details, target_monitor: this.target_monitor, display_distance: this.display_distance, display_distance_default: this._display_distance_default(), @@ -732,6 +716,7 @@ export const VirtualDisplaysActor = GObject.registerClass({ [ 'monitor-placements', + 'fov-details', 'imu-snapshots', 'smooth-follow-enabled', 'smooth-follow-toggle-epoch-ms', @@ -785,11 +770,11 @@ export const VirtualDisplaysActor = GObject.registerClass({ const focusedMonitorIndex = findFocusedMonitor( currentPoseQuat, - this._monitorsAsNormalizedVectors, + this.monitor_placements.map(monitorVectors => monitorVectors.centerLook), this.focused_monitor_index, this.display_distance / this._display_distance_default(), this.smooth_follow_enabled, - this._fov_details(), + this.fov_details, this._all_monitors ); @@ -824,6 +809,8 @@ export const VirtualDisplaysActor = GObject.registerClass({ _fov_details() { const aspect = this.target_monitor.width / this.target_monitor.height; const fovRadians = diagonalToCrossFOVs(degreeToRadian(Globals.data_stream.device_data.displayFov), aspect); + + // adjusted angles based on how far away the screens are e.g. a closer screen takes up a larger slice of our FOV const defaultDistanceVerticalRadians = 2 * Math.atan(Math.tan(fovRadians.vertical / 2) / this._display_distance_default()); const defaultDistanceHorizontalRadians = 2 * Math.atan(Math.tan(fovRadians.horizontal / 2) / this._display_distance_default()); @@ -841,10 +828,29 @@ export const VirtualDisplaysActor = GObject.registerClass({ defaultDistanceVerticalRadians, defaultDistanceHorizontalRadians, lensDistancePixels, - completeScreenDistancePixels + completeScreenDistancePixels, + monitorWrappingScheme: this._actual_wrap_scheme(), + curvedDisplay: this.curved_display }; } + _actual_wrap_scheme() { + // use automatic wrapping if the none/flat wrapping option is selected and the display is supposed to be curved + const noneUseAutomatic = this.monitor_wrapping_scheme === 'none' && this.curved_display; + if (this.monitor_wrapping_scheme !== 'automatic' && !noneUseAutomatic) return this.monitor_wrapping_scheme; + + const minX = Math.min(...this._all_monitors.map(monitor => monitor.x)); + const maxX = Math.max(...this._all_monitors.map(monitor => monitor.x + monitor.width)); + const minY = Math.min(...this._all_monitors.map(monitor => monitor.y)); + const maxY = Math.max(...this._all_monitors.map(monitor => monitor.y + monitor.height)); + + if ((maxX - minX) / this.target_monitor.width >= (maxY - minY) / this.target_monitor.height) { + return 'horizontal'; + } else { + return 'vertical'; + } + } + _update_monitor_placements() { try { const minX = Math.min(...this._all_monitors.map(monitor => monitor.x)); @@ -859,20 +865,10 @@ export const VirtualDisplaysActor = GObject.registerClass({ const viewportXBegin = this.headset_display_as_viewport_center ? this.target_monitor.x : allDisplaysCenterXBegin; const viewportYBegin = this.headset_display_as_viewport_center ? this.target_monitor.y : allDisplaysCenterYBegin; - // collect minimum and maximum x and y values of monitors - let actualWrapScheme = this.monitor_wrapping_scheme; - if (actualWrapScheme === 'automatic') { - // check if there are more monitors in the horizontal or vertical direction, prefer horizontal if equal - if ((maxX - minX) / this.target_monitor.width >= (maxY - minY) / this.target_monitor.height) { - actualWrapScheme = 'horizontal'; - } else { - actualWrapScheme = 'vertical'; - } - } - const fovDetails = this._fov_details(); - this.lens_vector = [0.0, 0.0, -fovDetails.lensDistancePixels]; + this.fov_details = this._fov_details(); + this.lens_vector = [0.0, 0.0, -this.fov_details.lensDistancePixels]; this.monitor_placements = monitorsToPlacements( - fovDetails, + this.fov_details, // shift all monitors so they center around the viewport center, then adjusted by the offsets this._all_monitors.map(monitor => ({ @@ -881,16 +877,8 @@ export const VirtualDisplaysActor = GObject.registerClass({ width: monitor.width, height: monitor.height })), - actualWrapScheme, this.monitor_spacing / 1000.0 ); - - // normalize the center vectors - this._monitorsAsNormalizedVectors = this.monitor_placements.map(monitorVectors => { - const vector = monitorVectors.centerLook; - const length = Math.sqrt(vector[0] * vector[0] + vector[1] * vector[1] + vector[2] * vector[2]); - return [vector[0] / length, vector[1] / length, vector[2] / length]; - }); } catch (e) { Globals.logger.log(`ERROR: virtualdisplaysactor.js _update_monitor_placements ${e.message}\n${e.stack}`); } diff --git a/ui/po/breezydesktop.pot b/ui/po/breezydesktop.pot index 378d892..0da859e 100644 --- a/ui/po/breezydesktop.pot +++ b/ui/po/breezydesktop.pot @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 09:01-0700\n" +"POT-Creation-Date: 2025-03-16 13:02-0700\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" @@ -27,33 +27,33 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "" -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 msgid "Set Focused Display Distance" msgstr "" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 msgid "Set All Displays Distance" msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 msgid "Focused display" msgstr "" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 msgid "All displays" msgstr "" @@ -225,276 +225,284 @@ msgstr "" msgid "Keep the focused display near the center of your view." msgstr "" -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "" + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 msgid "Virtual displays" msgstr "" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 msgid "Rearrange displays" msgstr "" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 msgid "Display distances" msgstr "" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "" -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 msgid "Display angling" msgstr "" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 msgid "Display spacing" msgstr "" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." msgstr "" -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "" -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 msgid "Toggle zoom on focus shortcut" msgstr "" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 msgid "Quickly toggle zoom on focus mode." msgstr "" -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "" -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." msgstr "" -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 msgid "Remove virtual displays on disable" msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 msgid "All displays follow mode" msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " "movements, jumps ahead, or is very shaky." msgstr "" -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" diff --git a/ui/po/de.po b/ui/po/de.po index 501a1ce..f21c44a 100644 --- a/ui/po/de.po +++ b/ui/po/de.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 08:49-0700\n" +"POT-Creation-Date: 2025-03-15 16:43-0700\n" "PO-Revision-Date: 2024-08-02 20:54-0700\n" "Last-Translator: \n" "Language-Team: German \n" @@ -29,36 +29,36 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Diese Funktion wird von Ihrem Gerät derzeit nicht unterstützt." -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 #, fuzzy msgid "Set Focused Display Distance" msgstr "Display-Entfernung" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 #, fuzzy msgid "Set All Displays Distance" msgstr "Display-Entfernung" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 #, fuzzy msgid "Focused display" msgstr "Display-Entfernung" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 #, fuzzy msgid "All displays" msgstr "Gebogenes Display" @@ -232,148 +232,156 @@ msgstr "Folgemodus" msgid "Keep the focused display near the center of your view." msgstr "Halten Sie das virtuelle Display Nahe der Mitte Ihres Blickfelds." -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "Gebogenes Display" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "Zwischen flachen und gebogenen Displays wechseln." + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 #, fuzzy msgid "Virtual displays" msgstr "Gebogenes Display" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 #, fuzzy msgid "Rearrange displays" msgstr "Gebogenes Display" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "Einstellungen" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 #, fuzzy msgid "Display distances" msgstr "Display-Entfernung" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "Ändern" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "Folgemodus-Schwelle" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "Wie weit Sie wegschauen können, bevor das Display folgt." -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 #, fuzzy msgid "Display angling" msgstr "Display-Größe" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 #, fuzzy msgid "Display spacing" msgstr "Display-Größe" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "Tastenkombinationen" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "XR-Effekt an/aus Tastenkombination" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." @@ -382,41 +390,41 @@ msgstr "" "Effekt einmalig manuell aktiviert werden, um die Tastenkombination zu " "aktivieren." -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "Display-Zentrierung-Tastenkombination" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "Heften Sie das virtuelle Display an die aktuelle Position an." -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 #, fuzzy msgid "Toggle zoom on focus shortcut" msgstr "Folgemodus-Tastenkombination umschalten" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 #, fuzzy msgid "Quickly toggle zoom on focus mode." msgstr "Schnell den Folgemodus wechseln." -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "Folgemodus-Tastenkombination umschalten" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "Schnell den Folgemodus wechseln." -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "Erweiterte Einstellungen" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "Optimale Display-Konfiguration finden" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -424,87 +432,87 @@ msgstr "" "Ändern Sie die Display-Konfiguration der Brille automatisch zur maximalen " "Auflösung und besten Skalierung, wenn sie angeschlossen ist." -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "Höchste Bildwiederholrate verwenden" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Die Bildwiederholrate kann die Leistung beeinflussen, deaktivieren Sie dies, " "um sie manuell festzulegen." -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "Immer primäres Display" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Setzen Sie die Brille automatisch als primäres Display, wenn sie " "angeschlossen ist." -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Gebogenes Display" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 #, fuzzy msgid "All displays follow mode" msgstr "Gebogenes Display" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "Bewegungsvorausschau" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -515,15 +523,15 @@ msgstr "" "es sei denn, das virtuelle Display hängt hinter Ihren Kopfbewegungen " "hinterher, springt vor oder ist sehr wackelig." -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "Standard" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "Textskalierung" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "Text unter 1.0 skalieren simuliert ein höher aufgelöstes Display" @@ -729,9 +737,6 @@ msgstr "Über BreezyDesktop" #~ msgid "Widescreen mode" #~ msgstr "Breitbildmodus" -#~ msgid "Switch between flat and curved displays." -#~ msgstr "Zwischen flachen und gebogenen Displays wechseln." - #~ msgid "" #~ "Closer appears larger, further appears smaller. Controls depth when in " #~ "widescreen mode." diff --git a/ui/po/es.po b/ui/po/es.po index b037f9d..34377e9 100644 --- a/ui/po/es.po +++ b/ui/po/es.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 08:49-0700\n" +"POT-Creation-Date: 2025-03-15 16:43-0700\n" "PO-Revision-Date: 2024-08-02 20:55-0700\n" "Last-Translator: \n" "Language-Team: Spanish \n" @@ -28,34 +28,38 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Esta función no es compatible con tu dispositivo en este momento." -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 msgid "Set Focused Display Distance" msgstr "Ajusta Distancia de Enfoque de la Pantalla" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." -msgstr "Usa un valor más cercano para que la pantalla se acerque cuando la mires." +msgstr "" +"Usa un valor más cercano para que la pantalla se acerque cuando la mires." -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 msgid "Set All Displays Distance" msgstr "Ajusta Todas las Distancias de Pantalla" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." -msgstr "Usa un valor más alejado para que las pantallas se alejen cuando apartes la vista." +msgstr "" +"Usa un valor más alejado para que las pantallas se alejen cuando apartes la " +"vista." -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -"No se pueden agregar pantallas virtuales en esta máquina. Se requiere Wayland y xdg-desktop-portal." +"No se pueden agregar pantallas virtuales en esta máquina. Se requiere " +"Wayland y xdg-desktop-portal." -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 msgid "Focused display" msgstr "Pantalla enfocada" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 msgid "All displays" msgstr "Todas las pantallas" @@ -219,8 +223,8 @@ msgid "" " " msgstr "" "Acercar automáticamente una pantalla cuando la mires.\n" -"Establece tus distancias preferidas de enfoque y desenfoque en la sección " -"de Ajustes.\n" +"Establece tus distancias preferidas de enfoque y desenfoque en la sección de " +"Ajustes.\n" " " #: src/gtk/connected-device.ui:70 @@ -231,143 +235,153 @@ msgstr "Modo de seguimiento" msgid "Keep the focused display near the center of your view." msgstr "Mantener la pantalla enfocada cerca del centro de campo visual." -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "Pantalla curvada" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "Cambiar entre pantallas planas y curvadas." + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "Desactivar pantallas físicas" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." -msgstr "Desactivar automáticamente todas las pantallas físicas cuando el efecto XR esté habilitado." +msgstr "" +"Desactivar automáticamente todas las pantallas físicas cuando el efecto XR " +"esté habilitado." -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 msgid "Virtual displays" msgstr "Pantallas virtuales" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "1080p" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "1440p" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "Añadir personalizada" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "Eliminar resolución personalizada" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 msgid "Rearrange displays" msgstr "Reorganizar pantallas" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "Ajustes" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 msgid "Display distances" msgstr "Distancias de la pantalla" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "Ajusta cómo de cerca quieres que aparezcan las pantallas." -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "Cambiar" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "Umbral de seguimiento" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "Hasta qué punto puedes mirar antes de que la pantalla siga." -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 msgid "Display angling" msgstr "Inclinación de la pantalla" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "Cuando hay múltiples pantallas, elige cómo deben inclinarse hacia ti." -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "Automático" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "Inclinación lateral" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "Inclinación superior" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "Plano" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 msgid "Display spacing" msgstr "Separación de pantallas" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "Poner espacio vacío entre las pantallas, cuando haya varias." -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "Desplazamiento horizontal del visor" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "Mueve el visor a izquierda o derecha de su posición predeterminada." -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "izquierda" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "centro" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "derecha" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "Desplazamiento vertical del visor" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "Mueve el visor arriba o abajo de su posición predeterminada." -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "abajo" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "arriba" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "Atajos de teclado" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "Atajo encendido/apagado Efecto XR" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." @@ -375,39 +389,39 @@ msgstr "" "Activa o desactiva rápidamente el Efecto XR. Es posible que necesites " "activar el efecto manualmente una vez para habilitar el atajo." -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "Atajo para recentrar la pantalla" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "Fije la pantalla virtual en la posición actual." -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 msgid "Toggle zoom on focus shortcut" msgstr "Atajo para alternar el acercamiento al enfocar" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 msgid "Quickly toggle zoom on focus mode." msgstr "Modo para alternar rápidamente el acercamiento al enfocar." -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "Atajo para alternar el modo de seguimiento" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "Activar el modo de seguimiento." -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "Configuración Avanzada" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "Encuentre la configuración de pantalla óptima" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -416,21 +430,21 @@ msgstr "" "obtener la máxima resolución y la mejor escalabilidad cuando estén " "enchufadas." -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "Utilizar la frecuencia de actualización más alta" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "La frecuencia de actualización puede afectar el rendimiento, deshabilite " "esto para configurarlo manualmente." -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "Centrar en la pantalla de las gafas" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." @@ -438,64 +452,67 @@ msgstr "" "Centrar el visor en la pantalla de las gafas, incluso si la pantalla no está " "en el centro." -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "Siempre como pantalla principal" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Automáticamente configurar las gafas como pantalla principal al enchufarse." -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 msgid "Remove virtual displays on disable" msgstr "Eliminar pantallas virtuales al desactivar" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." -msgstr "Eliminar automáticamente las pantallas virtuales cuando se desactiva el efecto XR." +msgstr "" +"Eliminar automáticamente las pantallas virtuales cuando se desactiva el " +"efecto XR." -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "Activar la detección de toques múltiples" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." -msgstr "Activa el doble toque para recentrar y el triple toque para recalibrar." +msgstr "" +"Activa el doble toque para recentrar y el triple toque para recalibrar." -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 msgid "All displays follow mode" msgstr "Modo de seguimiento de todas las pantallas" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "El modo de seguimiento mueve todas las pantallas, no solo la enfocada." -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "Rastreo de movimiento de modo de seguimiento" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "Elige qué movimientos deben rastrearse en el modo de seguimiento." -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "Horizontal" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "Vertical" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "Inclinación/giro" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "Anticipación de movimiento" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -506,15 +523,15 @@ msgstr "" "predeterminado a menos que la pantalla virtual se retrase detrás de los " "movimientos de la cabeza, se adelante o sea muy inestable." -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "Predeterminado" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "Escalado de Texto" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" "Escalando el texto por debajo de 1.0 simulará una pantalla de mayor " @@ -719,9 +736,6 @@ msgstr "Acerca de BreezyDesktop" #~ msgid "Widescreen mode" #~ msgstr "Modo pantalla ancha" -#~ msgid "Switch between flat and curved displays." -#~ msgstr "Cambiar entre pantallas planas y curvadas." - #~ msgid "" #~ "Closer appears larger, further appears smaller. Controls depth when in " #~ "widescreen mode." diff --git a/ui/po/fr.po b/ui/po/fr.po index 623cecf..b0ebcd5 100644 --- a/ui/po/fr.po +++ b/ui/po/fr.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 08:49-0700\n" +"POT-Creation-Date: 2025-03-15 16:43-0700\n" "PO-Revision-Date: 2024-08-02 20:54-0700\n" "Last-Translator: \n" "Language-Team: French \n" @@ -31,36 +31,36 @@ msgstr "" "Cette fonctionnalité n'est actuellement pas prise en charge par votre " "appareil." -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 #, fuzzy msgid "Set Focused Display Distance" msgstr "Distance d'affichage" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 #, fuzzy msgid "Set All Displays Distance" msgstr "Distance d'affichage" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 #, fuzzy msgid "Focused display" msgstr "Distance d'affichage" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 #, fuzzy msgid "All displays" msgstr "Affichage incurvé" @@ -234,148 +234,156 @@ msgstr "Mode de suivi" msgid "Keep the focused display near the center of your view." msgstr "Gardez l'affichage virtuel près du centre de votre champ de vision." -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "Affichage incurvé" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "Basculez entre les affichages plats et incurvés." + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 #, fuzzy msgid "Virtual displays" msgstr "Affichage incurvé" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 #, fuzzy msgid "Rearrange displays" msgstr "Affichage incurvé" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "Réglages" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 #, fuzzy msgid "Display distances" msgstr "Distance d'affichage" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "Changer" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "Seuil de suivi" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "Distance jusqu'où vous pouvez regarder avant que l'affichage ne suive." -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 #, fuzzy msgid "Display angling" msgstr "Taille de l'affichage" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 #, fuzzy msgid "Display spacing" msgstr "Taille de l'affichage" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "Raccourcis clavier" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "Raccourci on/off de l'effet XR" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." @@ -383,41 +391,41 @@ msgstr "" "Activez ou désactivez rapidement l'effet XR. Il se peut que vous deviez " "activer l'effet manuellement une fois pour activer le raccourci." -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "Raccourci de recentrage de l'affichage" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "Fixez l'affichage virtuel à la position actuelle." -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 #, fuzzy msgid "Toggle zoom on focus shortcut" msgstr "Raccourci de basculement du mode de suivi" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 #, fuzzy msgid "Quickly toggle zoom on focus mode." msgstr "Basculer rapidement le mode de suivi." -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "Raccourci de basculement du mode de suivi" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "Basculer rapidement le mode de suivi." -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "Paramètres avancés" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "Trouver la configuration d'affichage optimale" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -426,87 +434,87 @@ msgstr "" "résolution maximale et une meilleure mise à l'échelle lorsque elles sont " "branchées." -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "Utiliser le taux de rafraîchissement le plus élevé" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Un taux de rafraîchissement élevé peut affecter les performances, désactivez-" "le pour le définir manuellement." -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "Affichage principal en permanence" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Définissez automatiquement les lunettes comme affichage principal " "lorsqu'elles sont branchées." -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Affichage incurvé" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 #, fuzzy msgid "All displays follow mode" msgstr "Affichage incurvé" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "Prédiction de mouvement" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -516,15 +524,15 @@ msgstr "" "le temps de rendu. Restez sur la valeur par défaut à moins que l'affichage " "virtuel ne soit lent, ne saute pas ou ne soit très instable." -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "Par défaut" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "Mise à l'échelle du texte" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" "Une mise à l'échelle du texte en dessous de 1.0 simulera un affichage de " @@ -731,9 +739,6 @@ msgstr "À propos de BreezyDesktop" #~ msgid "Widescreen mode" #~ msgstr "Mode grand écran" -#~ msgid "Switch between flat and curved displays." -#~ msgstr "Basculez entre les affichages plats et incurvés." - #~ msgid "" #~ "Closer appears larger, further appears smaller. Controls depth when in " #~ "widescreen mode." diff --git a/ui/po/it.po b/ui/po/it.po index b53a1f6..d37bccc 100644 --- a/ui/po/it.po +++ b/ui/po/it.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 08:49-0700\n" +"POT-Creation-Date: 2025-03-15 16:43-0700\n" "PO-Revision-Date: 2024-08-02 21:14-0700\n" "Last-Translator: \n" "Language-Team: Italian \n" @@ -29,36 +29,36 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Questa funzione non è attualmente supportata sul tuo dispositivo." -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 #, fuzzy msgid "Set Focused Display Distance" msgstr "Distanza del display" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 #, fuzzy msgid "Set All Displays Distance" msgstr "Distanza del display" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 #, fuzzy msgid "Focused display" msgstr "Distanza del display" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 #, fuzzy msgid "All displays" msgstr "Display curvo" @@ -232,148 +232,156 @@ msgstr "Modalità di inseguimento" msgid "Keep the focused display near the center of your view." msgstr "Mantieni il display virtuale vicino al centro del tuo campo visivo." -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "Passa da display piatti a curvi." + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 #, fuzzy msgid "Virtual displays" msgstr "Display curvo" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 #, fuzzy msgid "Rearrange displays" msgstr "Display curvo" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "Regolazioni" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 #, fuzzy msgid "Display distances" msgstr "Distanza del display" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "Cambia" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "Soglia di inseguimento" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "Quanto lontano puoi guardare prima che il display ti segua." -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 #, fuzzy msgid "Display angling" msgstr "Dimensione del display" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 #, fuzzy msgid "Display spacing" msgstr "Dimensione del display" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "Scorciatoie da tastiera" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "Scorciatoia per on/off dell'effetto XR" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." @@ -382,41 +390,41 @@ msgstr "" "abilitare l'effetto manualmente almeno una volta per abilitare la " "scorciatoia da tastiera." -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "Scorciatoia per ricentrare il display" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "Fissa il display virtuale alla posizione attuale." -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 #, fuzzy msgid "Toggle zoom on focus shortcut" msgstr "Scorciatoia per attivare/disattivare la modalità di inseguimento" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 #, fuzzy msgid "Quickly toggle zoom on focus mode." msgstr "Attivazione/disattivazione rapida della modalità di inseguimento." -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "Scorciatoia per attivare/disattivare la modalità di inseguimento" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "Attivazione/disattivazione rapida della modalità di inseguimento." -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "Impostazioni avanzate" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "Trova la configurazione ottimale del display" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -424,87 +432,87 @@ msgstr "" "Modifica automaticamente la configurazione del display degli occhiali per " "ottenere la massima risoluzione e la migliore scalabilità quando collegati." -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "Usa la frequenza di aggiornamento più elevata" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "La frequenza di aggiornamento potrebbe influire sulle prestazioni, " "disabilitala per impostarla manualmente." -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "Imposta sempre come display primario" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Imposta automaticamente gli occhiali come display primario quando sono " "collegati." -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Display curvo" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 #, fuzzy msgid "All displays follow mode" msgstr "Display curvo" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "Anticipo del movimento" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -515,15 +523,15 @@ msgstr "" "che il display virtuale non rimanga indietro rispetto ai tuoi movimenti, non " "salti in avanti o sia molto tremolante." -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "Predefinito" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "Ridimensionamento del testo" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" "Ridimensionando il testo sotto a 1.0 si simula una maggiore risoluzione del " @@ -729,9 +737,6 @@ msgstr "Informazioni su BreezyDesktop" #~ msgid "Widescreen mode" #~ msgstr "Modalità widescreen" -#~ msgid "Switch between flat and curved displays." -#~ msgstr "Passa da display piatti a curvi." - #~ msgid "" #~ "Closer appears larger, further appears smaller. Controls depth when in " #~ "widescreen mode." diff --git a/ui/po/ja.po b/ui/po/ja.po index b2ce894..c4f6772 100644 --- a/ui/po/ja.po +++ b/ui/po/ja.po @@ -11,7 +11,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 08:49-0700\n" +"POT-Creation-Date: 2025-03-15 16:43-0700\n" "PO-Revision-Date: 2024-08-02 20:55-0700\n" "Last-Translator: \n" "Language-Team: Japanese \n" @@ -31,33 +31,33 @@ msgstr "メガネを3Dモードに切り替え、表示の幅を2倍にします msgid "This feature is not currently supported for your device." msgstr "現在接続されているデバイスはこの機能に対応していません。" -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 msgid "Set Focused Display Distance" msgstr "フォーカスされたディスプレイ距離" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "近くに設定すると見たディスプレイにズームインします。" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 msgid "Set All Displays Distance" msgstr "すべてのディスプレイ距離" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "遠くに設定すると視線の外れたディスプレイがズームアウトします。" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "仮想ディスプレイが追加できません。" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 msgid "Focused display" msgstr "フォーカスされたディスプレイ" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 msgid "All displays" msgstr "すべてのディスプレイ" @@ -231,143 +231,151 @@ msgstr "フォローモード" msgid "Keep the focused display near the center of your view." msgstr "仮想ディスプレイを視界の中心近くに保ちます。" -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "曲面ディスプレイ" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "平面と曲面ディスプレイを切り替えます。" + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "物理ディスプレイの無効化" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "XRエフェクト有効時、自動的に物理ディスプレイを無効化する。" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 msgid "Virtual displays" msgstr "仮想ディスプレイ" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "1080p" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "1440p" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "カスタム解像度" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "カスタム解像度の削除" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 msgid "Rearrange displays" msgstr "ディスプレイの配置" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "調整" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 msgid "Display distances" msgstr "ディスプレイ距離" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "ディスプレイの表示距離を設定。" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "変更" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "フォローしきい値" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "ディスプレイがフォロー(追従)を開始するまでの距離" -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 msgid "Display angling" msgstr "ディスプレイの向き" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "複数のディスプレイがある場合、ディスプレイの向きを選択します。" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "自動" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "横向き" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "縦向き" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "平面" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 msgid "Display spacing" msgstr "ディスプレイの隙間" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "複数のディスプレイがある場合、ディスプレイ間の隙間を設定します。" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "表示域の水平オフセット" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "表示域を左右に移動させます。" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "左" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "中央" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "→" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "表示域の垂直オフセット" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "表示域を上下に移動させます。" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "下" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "上" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "キーボードショートカット" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "XRエフェクトの切り替え" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." @@ -375,39 +383,39 @@ msgstr "" "XRエフェクトの有効・無効を切り替えます。このショートカットを有効にするために" "手動で1回XRエフェクトを有効にする必要があります。" -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "ディスプレイを中央へ移動" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "仮想ディスプレイを現在の視点に固定します。" -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 msgid "Toggle zoom on focus shortcut" msgstr "フォーカス時のズーム切り替え" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 msgid "Quickly toggle zoom on focus mode." msgstr "フォーカス時のズームをすばやく切り替えます。" -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "フォローモードの切り替え" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "フォローモードのオン/オフをすばやく切り替えます。" -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "詳細設定" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "ディスプレイ設定を最適化する" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -415,83 +423,89 @@ msgstr "" "メガネ接続時、最大解像度と最適なスケーリングのためにディスプレイ設定を自動的" "に変更します。" -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "最大のリフレッシュレートを使用する" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "リフレッシュレートはパフォーマンスに影響を与える可能性があります。手動で設定" "する場合は無効にしてください。" -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "メガネのディスプレイを中央に" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." -msgstr "ディスプレイが中央にない場合でも、表示域をメガネのディスプレイの中央に配置します。" +msgstr "" +"ディスプレイが中央にない場合でも、表示域をメガネのディスプレイの中央に配置し" +"ます。" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "常にプライマリディスプレイにする" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "メガネ接続時、自動的にプライマリディスプレイにします。" -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 msgid "Remove virtual displays on disable" msgstr "無効時に仮想ディスプレイ削除" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "XRエフェクト無効時に仮想ディスプレイを自動的に削除します。" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "マルチタップ認識を有効化" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." -msgstr "ダブルタップで中央へ移動、トリプルタップで再キャリブレーションを有効にします。" +msgstr "" +"ダブルタップで中央へ移動、トリプルタップで再キャリブレーションを有効にしま" +"す。" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 msgid "All displays follow mode" msgstr "全画面フォローモード" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." -msgstr "フォローモードはフォーカスされてるディスプレイだけでなく全ての画面が移動します。" +msgstr "" +"フォローモードはフォーカスされてるディスプレイだけでなく全ての画面が移動しま" +"す。" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "フォローモード移動設定" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "フォローモードで追跡する方法を選択します。" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "水平" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "垂直" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "傾き・回転" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "動きの先読み" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -501,15 +515,15 @@ msgstr "" "ます。仮想ディスプレイが頭の動きに遅れたり、先に進んだり、非常に揺れたりする" "場合を除き、デフォルトのままで問題ありません。" -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "デフォルト" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "テキストスケーリング" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" "テキストを1.0未満にスケーリングすると、高解像度ディスプレイをシミュレートしま" @@ -712,9 +726,6 @@ msgstr "Breezy Desktopについて" #~ msgid "Widescreen mode" #~ msgstr "ワイドスクリーンモード" -#~ msgid "Switch between flat and curved displays." -#~ msgstr "平面と曲面ディスプレイを切り替えます。" - #~ msgid "" #~ "Closer appears larger, further appears smaller. Controls depth when in " #~ "widescreen mode." diff --git a/ui/po/mo/de/LC_MESSAGES/breezydesktop.mo b/ui/po/mo/de/LC_MESSAGES/breezydesktop.mo index 812e9502e3a15fc28187b3514492752b19fdd3a7..d3a9d90e81440c62796534cbaef0cacaa4916709 100644 GIT binary patch delta 2041 zcmY+^S!`5Q9LMoLWx61=*n(|=w%k&vIAUq7MM^2Hc0pOnzJ!oqnO<774&W4f8(M+?#31-LeclN9HKkEm2$L4J1K_20q>#}7~g{R@@C zG~OojQJIV43|xx*Y%`UIomhznuoj1rq}Y87lp@{T2W6-koxqtmj7ssZ$UAK&qie({ z>iiq1rTP%{;uEOUpTYGwhI&yoqg;%QsOR^g_R8UDz2B^|o(tn)JJf!ExHw@|4Z z#{~ZC`uDLOjLqIbEzLnH?Uj?Lft|%2Y}#LN2`;3wferq80n5($Z)cEy-S87{lVixf zuyJJY7Gav&#RaG(Dn_1V<;WPU&YfR_x^EL|LNVkW_Ac_XK`IYV;cIvm4`5Y5J~q-g zhwKZR$~UNymEd!@3>RQGY8M|v?SWCuW=1zr8Mw{X*8m@)He*&vc-?eVs*CVxEJqEj z4f!H1*hNFTd!Oq#f|}V$)DoOVrT!{vW}{e(cX0%xj8+5s)2V6d{w!2Ricl|#qB2>7 z8c-dQ$-r7@DD~Tr!P{QsXP;21{}d_{m$4r2<2tM=4KwxuMmg@sFYqFAiEU?RYhv$V z7k-5r*pxD}m(jyn`u<}ySPl!&!{bbMmrpq4>PqHJs>RJ6;rKNb@j zlnR&IvScgFjGC*6mk2E#EA^=OsaB(FC^e;oMy}bYyhyYX)r6Kv;HrKzAQq$~C zJcFx=N@At!TZ-C1`Wz?&zhz9S*Lte3q_%;`CD_QxGLiauViU2Ds3B721sdxIN;3;; z+GsVUx={Im=ru}cd?RR(`yAyl6+xv$8%l+tuCPb9LMo5u6vO}f8_etO;P?AqUfq5e=7e%EglG)@c+RSEVWcm00+)j`D*7v-A=XcIM=llEqey8`P_e-32v7QE_ zl@nu$r~SJqHh08DjH)93v!`=7-i!g7fSqvURC038=*n|_X9fSA> zl}K*1*&QrIpQiek4wEt;Ptgs-k;z&jPQ)Zs=0&LcHsBcCisWDp4#(r}`32N-uDIhj zFpKjRJdNK``TD)nhPD&cwL&#vnN-bD|#q7r(7D&0%hkEn|EpdX{jLW!ht2w*m5 zU?t|@F{B9g09BbbbPmw@Mn^N+#nVRPF;r&i7HSp-i2jYi+Vvj zW@8uXxyfX$y%9t$=~C2vRdLi`ot+HmLDlY!^{5hta4$Bx<9^nG94rO3Bv~A^H;PdS zRpBN!={}r~ueq4VhK@~S8M$7@OLYGp*IGaIXZbC}0Lj`l)ULgUT7rkjv+OyNgLSyq zf1rN%8#SXS%Emh^6;;7p4gsvdD%_8?_y*VE7Rtglu-gtDW!8$*u@k3ZJl~>rZ2@ZS z9gJp1M^K41u+_EsLa6IkQ6+A|G;BsC^a1(O>=$Y?`^NX4Pe)D2$)>|3tQ1x9ZKxUT z#2h?~&#(pcqLXAR&!Qd>LRF#(^`aJ31)rc2YC~199aZ`-NG|3LL@MN1Dji)YLRDZR z2JtAa!AGc4`IF72U^<3yEpo}eqGlGymfnszsKhSeBD{qZ)qWz?w}h15-(_IAzW+6J z^nxpxkGD}J>_$Ee3#78Hn8`tVq#QNA19_%Zqh@;1^)g=O{HA+eNp@O_t*FY@pe9_e zbKY-P>GVUDUrV9&*S}*m?dqw-JYo`|#_f>`sXtinF{ssx3Itf@ZL#Y6_-BQ$HZvbsudinF5k#8#np&O%~|JEn#0Yb)un z2_iMm#jL&y$nK78Z~fO%tqKXXbfScqNh~MS77(hVJ_A}^k9TlT-8!3R@FixI(p%IwjFGPzmlE^caSyI{`(j!6gzt diff --git a/ui/po/mo/es/LC_MESSAGES/breezydesktop.mo b/ui/po/mo/es/LC_MESSAGES/breezydesktop.mo index 048a704d2acb5f8773d9a4f2a996c73d10b0f9f8..a216226e9fa1d8d547e0457a51159f823b21ec16 100644 GIT binary patch delta 3363 zcmZA33rtpJ9LMoT<&}$a6}fnUR}@77@d79$L4suBB{jt>`67^)S0rA%kkX5m_wYux z*@~Jq&E+g(vYfhRE8ScrbEeBRBQq=Ky4dD2ZT9`0bJ(nB{Lklk&N=USp6CBO=jhp0 z*H`{j1X`e?8tOF9Z(tY>V|1Ev4yIr!CSfDy;XBv| zzsK4505#*8Om8gC!;{#Idfqff6^LaRPyeQhN)R?8$uQecGu-dA-$y<0B(gf@Q&flN zP!GC}8pth7#uU;(UuG)mxr?zcdQrdMit48c{YvSZR5ZiGn1kn#ESWCkU)Q5h14uxf zPj=ebsHMrnES!jY@I_R|5v+@h$81bO?UlKx0eIucziwF135{$MYDU{JANS%IyohAg zgv8q>pfWTH`7=cvG_W#s<4PQXyDOkG_0QobC zoYaVOQF~$vG8WT}y6*^TCKs>(zeD;kZeAt5O}QL~VJYgqji`+7MLoa8Plaro6R01y zV+!8F8Q6<;(a5WCEc#Hp`3TaNX+!?ZMGjhu-%;1^;{tRg*qJQHV%i5#6Zi%7Tz}U@ zdyT?TC*n{eOGe#TfJ*ILEWu^y!Zy@^PoX-zjM^g|=)<3oPlcK9w$CqhtU=ws23c~y z*+4~Wz8N)xov6LAAGO9Us185GuGog!-6xO@Z@xlh@CFw0fx3_SVCAzuG5lc8Ks!S# zlkEXFA^X!D!ce{cpHR^ZzeLU8n&Xe?qJ7)(4yxn7P!9+lY~P=Znm`(I$z-AiHqSX< zgSvk$Y7_59?TL3Wk^apEDueJh)J&p>*qbC3%V>|m`S=>Xfp_pA?qZ|N#O$HQOvde~ z56l&0dCg7CL>Im3ZOFy(xEx7}If{Ng_#%}+9G+_5kd4u#upX6}ooV)i-$HG+qo}q0 z0<{URqV~dF)Sih*w=*}?F$3wsWMK#{!Y6TgI{DXbZ{-BbWxhpq_z*KNVz~XF0@Pk8 zMx}5L(wFgKG44mDyaV<7yVxBAd5AI^hH59H29Sp1a7+gIKTf5N6Tvu)JOyDU=3^eJ z;|A0k?!q2;2wm8U%G?Po!ZVnM-ACG)DMH?4vj~-e1|+HGJ=9*gxQPdiqLOu8o+=LmU**th0AH%QFjgj1}OpL-6I1!cEHq-#V!6*#KGUjRY$5LTG znI)(jc4ID{M5XR7Mq_BUy~atX@54CMCMre!ZXIe(4`L+#irQ@Yeyd%Gx^EV;I;IhO z>;3vvEyeSqpPjCIj- zVlW2#J7zkTU>Ewg)=gi$I${b@O3WuzW)pjfC2COi*qCkTBb3t4vXzQD9^#yshV)?- zR>SNd77{NI>xp>6AHiW2@dQyws3?7lRH1YwUa@L+mNrn=$3?rkvphvbOQ+IIXk+R1 z>@3P+0ik6jIoA5Wh~2dQDoWEVVmeVy)DxX0oyy~c_Q3Yelc@JsWgbyOtR<2NwvYA3 ztiXN5PD0D2@)EJss@aD~r+;gs#Bq+#fK~E2dI_zY)?7ue-#X$sB9>?*1`;aE2z|)r z5YH3K36)*MW~-+EZ1Q#ybDg#}Z(q%S4Z&u#{tH!!9%3l*XbE!~RXC9dCdLyph;TyR zgj!-GQBCk_S(_QmVB%$BwHlPsHrCM}1Oo^Sq=aZ9HWDhy#A2d>NF^2!j~3oY>)(Sd zIFl$No+18UiZ~HM6cZzyixZIVN`mz<8ARh*VzP5lBob3w7xp|K6jr#Zc6DWiyJD%Y z#_OqX9o)M)Fv(qBS+}OLvf5qc_0+jN)fMi=|GCRIy!E4g4dLOQ>N=0t>#?qSDm<;} kX+H!Hs&!XZ*VR_KYn-b-HxI7%_}ulK_wn=K?9&1N0+V4>)Bpeg delta 3229 zcmZA3drVe!9LMo*+yn#>kehiyEyWv;7eGK!Lq!8J#d?(Rem7DI6-&!U4K&mgF`G`C z&P}sbbM20gV+>w!`x|(i;*!|C1zqZrenR^ zZ^ktCkD>;42FvktoQa8Cq>lUB5;{jXa2+RM1CJv=!7doV==8+Nn1ccAi?gr zi$T1GdXT|9ULlUab6AU=Z~&vq!T`o{e|ww`4{uedCtK+D*Pt%ch|G%ZK;5VXb)k1r z0|?`z_&ahB%ODN0I0PTYeAM@+qwW(#WpXKo^knsPim(OAj(zD)_zpFI+wS;pZvP+D zl*BMU`IwA*a5Cz~-#Bk#0sD7RHPV-P(g5;N=S|8a{~Fm;4(N$y;5e+oQFsu^rd@U3 zMrG&$Dusz`G~fZ4jfFT2tFZ{TqiW;=YRax)G5&!sVW2ztSBl;tuR5U(mEt>WG~!4; zR4t?<_q5rl^VXuCWIv9_6Ua5~7t|_>WHSh}QRh{lQeK0){xT$qwk1SIUp#4EJY2x8Fk&GsMMcy`=K**G@>@t zi9e!J`Zrc!d~bgp2T=o^jk;k2sx~&^YTSmr8tj2P9+&NZ-W7Fz25PGNpr*P%@&F;r zrK1muP;)yLqj4HWU=UT+)kuNcDpcwkaRM)-gQyqO4}Cb!7ye>?NP;D?BsAcmNd4Jl z)Bxw99&jbbX#H>WI%Z86%?CT3t*9ICM_u53)DyR%p5QX_XV=(hVE5heuKoSpq%K7zY3o%`DL9Ih(%eG=3 z9z(5yZ?P0RbN7BY6?NTu)B}8lA)Ro8PB&7RHQ2vk?hrqPC8(6upo(t=Dy2=RS~-l- zc*c1ixs+YNc)W*`@jfzUD;?^uo?6rt>>5h`19T2^Ko|NNRRh;isk@DQ*B)RQ=H&XR zu0vg*31je0R873)_D`V(a1O`dMLdm>+$;{yVk~|UAphg&T;_mooIu_**S%0vQh*v* zDJo@Ca3W5_65NN%%vEIN+C5YT5{C2s$5BXG*dpX3Yj%E&)7ifpqLWCcWQ0F=6{rhu z!X`YADw>HS%|_#5%*G?AqWcV2Vmng!Hi-hz0G4A4?!{?%94RCF(|z7M-+vQ^%IPR| zP1p?&q2~Al)O+C)s(5}z&1HOnpQ$QT?JRctZ=-H}7Rk2V!Zb`B|UDVW!Eb>1ejhf>*sHt0qZ{SK) zMk0#+nn}Y%t^Xc$^o2pFFXW--z8I6R%zYljWcKHyZdi{hzV(=no1OceCy_)q# z%9YI*h-Zj0VmP6eOf(a9#IwXUqLp||-%wFKPmCbu6CJHP9Tj3V5hQAfCPFolMW{_6 zv|Lp`YQ25DrKZ(ULp(*SCiH5bMWhfN?KzEj2cb2rwv5uM)f5z8FlXxV0qJ1`@9kp?=z<1&DE8kAFzQp4qc(UIq)6T6)^gXPLLZE>w$qE&1-eU3)0l}d zq43ZITLCXc5*i*L#0M&u;)}%aU@kJm_&=`pd62HHlSrSkBpU;`uGc*7B zpL2R(%gL?Y?Qrg4qtz4BiCfub9`--Qf%a*hSy7hRXLtwCjxn3T^)JSnO~N4z<2B63 z5qui&p&s!7L-+`v#T6OZCiTuQmAnU zaT@j_x!6}Y0WSsTS5eQo8C<`Om7L$lkFo3-o}*GF`SA+s1gq&@3g68 z7sCap-`_<|)qd2AkD*F`0k`7_>O~b~xdLOT=Xavk%Hc`WUvqq%3mSMa@CxdIH-dqq zs8T+_B>o#*-^+ZEn{}b4riX*p$_Z3r7qNy#dmZOvAr~uI;IS!wA|1ulUoYzAphV6f z(_>eVdu$l>;=8EQ|Awp^`wLZp5C^UDQq&jCMcua)OR)w^umxvhH#XuK9KeYl_1Hz{ z9O}h|>_Od7hVyY9F2V$^!G2UCKjV-1D^g{<%+l8)91a{oRdf_J{%=%5Sv)*~5oG$! ztEHnC)T6#^KPr(=0tYaM^RuXup2u3ehL>^jOn>p-M7?MPmCzm3_=l(ph8=$q7o*0N zAQks)j^D8;YBAO$f7Zo;q^%#9<0V{%zvCvH&F3iL-M9ijz=L=mwOwO8Yz{VIJNBTa zK%XCnGEDFPZaT{N2rk4^xDNuq3d|+c7;Z16 zdu-LfEx4MfBAAgU&CT>;L1zt8!Sqxp8MPOP8lr;Gl&C#N=1)|Eogl|h4QO+`2F-2c$L1&t~pZ6A(j!Z6N?GWX{J3-XM101-jvF1^wwrB zqb7)nw2j1zgjz1KGu`tKn+D&@>kSpG-PhjXHad;1$vtiH&cVmy59Q8s-gZ;(yKcg1 zYKy0wc%sp1_}{2x`CxbWm$Bj1O--#0E%9d8X-#Ovcc%thW{eBXa}%j{*J*Q;PCPRr U>G1ee(s5Hy#`2VRB41|z2L=b_qC{azc+Xx$LOWfaEXSWLrlxCF;wHLk-t+<{$KggL{_M&MyoV9hukZ{lR^!EF44 z3M4Dk>>d`NM@#)ngGHH#Su`LFS*%6kRE$AIUW6LA9;0zH5`%d$3{N=UTT$~|bNX*! zI^Q2+1O7zKQ$G@w>INE0;RWPl9r^+9qYFDx0X;{h?zQ7*RL1%-3PXuPfh2H=#SBcv zO3cLLND}NZDl@OpyO+if8d}kIW*d*kQK@Z1=C&`Gi~Y{;SwyQXT8Db@b}Yww)B}1j z1A9^P#u2s7MmB0oi&5jMBFMiQwRC8rea^sUR0=QRE^Kr9qu2*xuz1v#q;t{PScVFy z3Kw%o>o5@?@MAg$x|bgn$Rr-3=Pcl&Kq{ihKigroba0OyKs~qtmGX1Q@vuv%%v?vE z>Zhm`b)oL-#yI?jlQ4|IQ!oX$UmJ6MGqh(^zS;H9A(UScAC#aTF(cQGFeQGp!A zZaj@TbXz&o zWq1b_v5RG8U^pJb64dMY7N=o9?!?K=uGF_+HQq(7bOPy6z)3h07vV;||J!Jgb$fG6LqDTPAfmqjgeF~*8eUnaQa=i#%YTszLTCtw=a3bX_xO)cu$D$ O&BS4D->50ggZ=@_cBrWU diff --git a/ui/po/mo/it/LC_MESSAGES/breezydesktop.mo b/ui/po/mo/it/LC_MESSAGES/breezydesktop.mo index 56522b118b0cfc78f32556b15e016bea22e77034..4686867254bd41cc32a14b715c3ee65e3054a5af 100644 GIT binary patch delta 1698 zcmXxke@Inl9LMpma_`ZmX{n{Ravi-jM=kH13w6=@0o_^YT$(!CAg*28Za-X3OA7L? zMrh=SxHylfko_@65xqa%!DV=tKH;#Zi1LpTFR zF$4cXO)-HE{)2h=FY0&cJj8h17SPcTf}Cb!2OtUQP zM+J5PU&f!X82`qVm^CvQNDW@+x&hOaYBs+nDa%Ji>LSTn2` zah!!`z3Z=0^IY@BzsKcVkKze*vXk?ik}CB%Ix68Ml=YOb* zW$^X@7NP>F;N)U8zKSud!ZS!Q>=vpr;~3vh$Hy$ns2k_u8B}S%Mc!eLaW!TTrS8|D zmgoc2i@Q-JKZW)9BkDzYL|chPsQI^`_Q*ce(teUl{q^8!2INK5goECLBdAjTfgL#J zjn}gt#ANTImZpu9_Q1TlbU|*s# zzKU9cUs1dGCNh`(j@o3CsKC-GhxR}=DuDU82+J^tO{h{Izz=Z%KSzghY|?d{4*S9$ z;fwebmti5_Vi|74Rd^8f!XeBgqn}YP{*7o23C3qcGfe8#_K~XY;tys?WZoG)+a4lAorasqWxDzj<5-4OH8n7IR z(RxsUe1VJg{SVV|8F+w==w|^H;d`iwyKoJDhsxv$mZFchY44OH`_jVr5^h2M$=M;) z^L;pgCsBLqH6GHEufRNgHXG=ugj+R$U6_InO>3m}YEFFS52b8O4EekKVXhkzRZeiu z+w^q2L#v{_NqZ~N?&PM_C5|{1GitaF(KaN0aTd;0aylrC)hDK${J>^hZrl6u tzSgK4jdkqV71`fWI@pu5WcIvhWO~Hi6N_|q#@xvBCu609mx8^i&j67OxQYM( delta 1620 zcmXxkSx8h-9LMqhgfo-rWR2BmWolZs*OZd2mZgrSmR3g5gDnq1WDh-6RLG}IN_2RjobI(0<&j0++xgIIGS{#1mkE%7U z3d%^z<9=pg+~wxRwcTr$;4-Vhk9eZLSrY9#2bjgj&}N24gY~!yqPL2#4Z2T!q!R6+18wb7IW~;(k^YAY! zkhwmy8@LF)TIxS4EXur$q7H+Q#aaNzU@|K5JXF6mI082yF<2M};bG^w9yLyr(|!fB zcy7bv_zN}8!8lZ^k5f?!&me!+tQU9_qwpRophu|GJ$3wm%Ge)FL?2NokPL1qn2pnL zHO|6AND}N0Dl<(T3w8RB9WMvF!^kz(3CWxkRfiT7{ap3d`{zYJx7z z#*e6RQ;Aw6OpjLDY=imjr zh25ykoJ;Pt2?IR0pay#2w0ENp?I+Zs{pP&?g{;kdDZP$Ih74OC6@s*lI05&fGSH0q z_!<@9*i^F_n28s06Xs$Z%hYFDj+=2iY60(YIsQiGwo>**fmWgV@5hz;{x4HeWG*%^ z7n5)yR-#sL9;e_X)Zux7oJaeLV^O2=&&)DV{ikCC&PHYIIcl%ppw7~FROa0Lc!)lS zBq}cSP_#GNr;12}d#bA_((bNy^JwLfLQmSz5>>gDQf5)+Q}QEwJn^p5NUdjP^b($@ zQVJu_JjuQl)O3*mD~q_ifkfp)OUb14UCQaQNYER|DyF6c^j!*)HCh2>w$m7eE1kLs UweI$&#+X8-^I diff --git a/ui/po/mo/ja/LC_MESSAGES/breezydesktop.mo b/ui/po/mo/ja/LC_MESSAGES/breezydesktop.mo index 60fc913ccf6b3aaa90a3869b31c4f3dce8043fe1..e3fd491205490b22a72fc8824c2fe31499d2ccf2 100644 GIT binary patch delta 3359 zcmZA3drX#90LSs8f&v;Kh@c3*q8MIK6fvMo@}Ae!gg`~P7KTUyf=RvtdCx0p(VC5rRTs?0Ui5DYsrca zqftvU29t0K?!eWkj)Pej*$YQw3~H}rq6SbL!TjrjYEEcmYf(?M3CH42dAl2I{(6)Qs*#-M_(2h1oXEs4t$w zIJ|{(FqC!C$O|zU%TT-dFw&Pfj{KSP9JCa7P@g}*1?U^?%w#T3qP-vW05?(hb$9IR ztWgl^LfgY za0uST2^dXdBLx>Zlik@mGGfXhxIs?_Ff#s6kbN{0iR*clSbhH+VQ9X&OvR$ zOw@H1w!PJU{*m=4>U$?_`wCXjZXL$_r&7rp?o8P()Qu0JMtID&uh@1gYHEXcx%*)( zR^epS08XJ^*Pk&6Z(}!XL*3VZgkvyHrX47x81%%yxR(={OWMkYwb(Zj(nvYq=D4 z!)-VdzrlqV!hGp`DMsP})LNcG-M9ty{Y%#S7(qL7jPw0bsQ*vwL>KPH?)Vw{>;3EVH*{aV#ZOB!;lj4KI&bN_LU0q$^RW zBSqetbLejS_x>1Y(+syCvNWccXr1(LfC}5gtRgRyaI%KvK0a;`+PCZtmOfsax-SOd+Oft)E)NJ9%yQe f|Fdh*@6Ap6wB|$Svih9Cq4lLn;Z5680)77lmg8w% delta 3229 zcmZA3eN0zX9LMpmf`A|jC=VJaii)Ozpcvo-rh%!Xi1||l6%`*TEmZO${fVIFLx~ur zb7^z6Y_`?<*-}gAn*LK;)0sBQ71>OiuH{y4X3O56dylPk=J&qNx%d9gJ?DGQy?B1( zn;U}PCxo{eWiOFR91Ax)hov1kP^vqbrL;4fhc|IutXUf87j!Y}iVc{6t*DFE8K{o4Fdhq$F&oojE$ zMB0Z@13Qir@pGJkv2?P6=i5RmZ*k%h7Gpirk)L5_Y|rR4<9Hl^+1LkX;wW5?J@5nu z@N3jW1~I*S%*9W!79%l}QFX^`jNb~L>@~@Fi=7eT64U4c6AIAeoHtnMG1}a1M zQ7Me&paExMI_BdLtiS@?f!ZTyQA>6K3-Nbci`hNMzf$xbdDRW)P$|C2K_d?1qV_@( z@=U8j-M1PwlYKY_k05>8FQ~UDjKiatj=FCWD&>`^{ud)jw9P>(`r&>o#}I175v)r- zc17*pQlxJSApfk6gO;Efb^QQV;X9}dw(n_Hf@4tw-;V0{Fe>#QxOVV36^-Z|>c%!y zO7Gz$jPB*X#{twpt56TDN9~PGxDvM^p9Z_{&UZ}rug9V8Pev_uZ`4xvMYD>yS;fs_(5}qKhV_v{)~q^$Dx*@44Io% zW4PY`AQg?M3H9Jz&K6`fY#%B^AEP=rj}h30>gWb)U=f-A`BYS@Gf>xuIH#aC=W^6r zaR@VbzFnrG4*$dewi{qpgEMg(p2F9#c%Xm%TbxQehaIL5R3i?;7JL#UTx1 zU4yG>*J2_5h{{xIw*R}_Z1S&>6}S^MsCF&t#@CT$wfAuieuWyqc=D*%vl_eLN>s`l zQ3GyvzJcRuAH;k3GwS}f9RK&f<&gieoCqUd8hHuo0kx2$bvA}v@HEIA`Q2l*~TEdg4ey-wVj2mG#Tkro|D!OnAHKRMIHH;;H z>bM)KgTBrZOrgC5>A)IL|6lk4)A1+NcO-n2KY%2>L^~Zd@Vlt~6GuzdKb4BsIs?_w z5buK7Fw_i2xbwvrOM8NA&u~_vGB_8zVjU*oR&0mL$|^#?PkA-}v&;teM&AvW5?VvHh*zd_WHoFzG0i*UXQYYxF4tCu`w^OGIT4(~ zVF95sk6<5pWd_GOg5~m-rxcS36|L`bujU^%!a{-xdmo?|u`{9l^53F$pYKjoVWif7 zEtLjB?(CUdaLTS~P?_r6iGKN@0lo8723&bpn7 z<`6T91malf^ ccRCXlnv>WP8S0*PD=w6lbvq_Bt}wR4Kf%BzLjV8( diff --git a/ui/po/mo/pt_BR/LC_MESSAGES/breezydesktop.mo b/ui/po/mo/pt_BR/LC_MESSAGES/breezydesktop.mo index f9fdcaa0d57874f67416cb6e43b7bf904b8130aa..e49a76321c328f0663f2e62e63bb000cf0e4f7e4 100644 GIT binary patch delta 3312 zcmZA3eN5F=9LMovfC7pjf*^=qFijyq6ckhhd_Y7gB_BvAy~3#;bZ(Y8x2#;6x&E*=ZM{GDci5^kzxQ>{@BZ$2_@49oVQbyq zdhZY6{%;z}E}{={!rz#4SQf+wrM8{3bW7ri> zV*p;l&Un?fzq8)P2xGkFXDaIGG3v&!Fk}2M3ZpOgR9lf+5VRH%4M0Zk=Z zfi@g~*O4*I6AZ*~(h-ZXsNau3jWZgR$tmd7%1WqYVFQvKbI9Is3N?X?_WD)ZzJuD5 zdzgWbumzLZFAaRsdI5*i{uXsc0@)``AQp9BQZ)J3%+k4_6=h)#=HUozLb7Q-vtC4H z=r$^af1oBDLc@i9aR}yM7S^K9$N|)r9mSD&0~;|ihWslUuMqUvn*yUW0w)R8aKM=L$Ly#@^nhYvh zK{o1(0@NNCp$43TPoW2Ox+{gmX~?Ww4(n~Tb% z2RR0&3e{gT=HqT;4dy1Q-+*NDA4nxW+4&+7)j=_8fD+UmS0USJ*5P>EkLu`GR4RL> zIKLZ=x<3^=V?JsEMVN~vcnsT6;})lqe`TOF)p=peM-99ewdaRW9h^h0@EcUe*RTY? z#~GMGo_%|bJh^5+YK3Qz?3-Jti3X(^!{SXp)D}(gQpu&V7DMn9X5wXgJ#Z-RecF?d z#hT;RyXc}FMK7V4iJDLW#^ZaaiJ!r6yoAr=ZQD*ucdmQKQ(-JK3pK;ds1EmGG=74- zOUwo2IGCT1^J&5}oIj&ksFk;19)64w_#0}%e#0HpFpTybYc0;u^WQ{e8ed$;=WsAD zex5|L5;c)`PE{&}5*tv>7$gRt&<=QD^HczJ*_5gr0v- zmb0g;P#ra)ey|nwgWdM}+tv?I6FP!D@HlF~i>Nbl4I}Y}^>^$=yYon6I^omAazfjk zqUXP(yhNptm_TTyD!j_-al%Iaj^|sgzd|N_hsMqHHj>*-5-WsJMs? z#5O|3t5Z6F(0{p#2_2I8L=E94*cD%y#b+JCBAkq??K zF`4*xVY|I%p1q>KT1w+8VjVG&7)7wXzDK4fs<3Tl1))Q!wCe116m4HFv4EILtRWP<$5+a=FDAiQ95{dT0LVTSlC)N-;zAF9>zUQ&X*4JD0woz$zFirTH z^18!b5J^M;p<}6%N^Bi@LQ0b|1HVS%atCRbE+FTkURazZucmCBZe%Q@_IFsc|i+cGtVyHRZ1P|GBF! yrMzq&`9MH6E9zrhb{nRj)7Tug2}N4Rzp7X+M~L$NwK`hfA~o delta 3185 zcmZA3dra0<9LMo5$RpQB5H#_EC|&~bZg@dNloT(Kh=E$BNQi|ZdFg^uPi89FO)+P- zCFVxiaOJ=?({#FNI#>Qtb6qT3b5b@7)^g_3*8B7O9k{(@COvlRO0#hWGJYD~n)bIc?!Fkh3qU94fH+g!Vc_&H?ar)jWL*%;1ApvyV4$l%*k>v8E4`>Snk@j z*qwF*YGMa)7PjDgyn{8|-%1#5A020K8dkC#c@VqcAE*_FG0SvJ#Wb9OlW+z0!Vj<% zPooyno8=wDG>pW{*c00@3N^cU?r+glw4$Esz)aKt6Oq%fsi+$ipav>O-M9(|;Q?e! zyMP+_3iih9sNYAiEgCn7I+_&Jf-*2Pfl2`tcEdKh3mQ-p*z5Y6T>E3xQ5?rCJcm2* zAJmPvb6#=}j>Y|`-1rtXf$Q%3+o*{JlG%T)D24-^jEOi7i;-QlZO*-@9cn>s;c3)_ zFJnJ!$B~%8ms-#iRBmiQ9aTMMV>8xb8)}Ejda?hyppO037B}*t86QREz!%8amc-S% zZYXLcb1)B=AY<7+)YEemhv3(!>%!^OmM5ad?~81fO+fvwC`6^0N)>9x$8kKKM`dj% z4vMiXh~Am;p(7|jeP4`=a1m+;Kf&pE3pMe)zW%riQAbnh+BK*Nh3cs2!riDXJ%qFI z6b3Mu>d!O@b;Dt(+!%*zF&B9ySc~gF={$?N{sQW(zd;@K52yuP_4`BCK}BbK19ij5 zery{CQCXdUB(e=cZQVqy=0#MDz3^mzR?iPEaXu{C#`8#ML8VBZSq*A}TTw@{3j^4M zo%Q@TyN(v;5!8)Opl%WFtQ9Is?w_LmbV1H$qs4X3XTH%Avg{W~V-1qBIHZt+XVi;nbOs59Q*aEHp`L;_aVDNY=4kO`CfFS>C|_h7aX!h*21W={Oz7Aal0$sN~&` zQFy}jpGEz?eJJ~{8{D8nXB#!lYyhU>{g{s$s2;V2hfqKK40ZkI*cq>&Ch#lf;SD^3 zV~6`UZbvQjFPwlj!e3bS2=-rRT}X!pC`YZZ8a415T!6J$f?uM}IGugw3AKFG3d@k) zwmQ^A-$T}9pQ4WD8s=fjC_fn&<9OODLsaxd6RyTKWb(FPwC@(|NBc0w<3-ejt|EzV zxs0xfmti8Vz&ZH5YhQ5wgbZzeq9!=_K7YJW4wYm&9zZ=l%aG%>O*kJvLajJ5i$udT z?1mMniPk#b#{}9Joo!e``zFrC!m&IN*oaEX-;o7{tQ#+UCC5OF!(qrIEgLoCRj3v2 zLk-xBI?FKjj|ax0F&amraw8kx#yr$SFQJaI12xV~)b-&cLO{=d92I?$=uAOPC>^`v zDAWz}QMoZ2yJL~F5|xZ~7={ChwM3B64&5z!P0u8h*jlJcxSs#*#A3B5u|$Da^S6_H z^JcG=JWeR7I1#Tr#3zff*NI}U$Iq2b)L(IJC8xGq|551}bOhyuN*NL2c)U`|=W2pQ z7`f&B4d{U?%Is>d=6^f~6~rVWpLm++Ld+umTMB6`bsdkOcJW!_1!6jpt@9@jyo5_a z6^_@QB9x5U)*|9=(J@UXmJwc-l~6RU_Ph%LkpB9G8hQ$vg*mUx*) zMMYVzb6-Fx(W;1-2(r}sTMagq$k{n5wns?M!o$QoVh!;qF`v*wc(<&evW-~jIx2B9 z@fcA@3?@_}eEjFo)i*lzmQi`xM+s{$YTsUS9byO(Ae5FW!-=iL05x36b187O4^5kn&9!b+6wM={gLqV+>v$;TMYpJPVYPHS)`$zs@ zj$E#$%a^%w4(E<1nJCF>tu?ovN0*H@r7gs2ZraPA<^2B6x&4F9dtB#pKlk%;-_Lbl z52x0BTo=1ukiOq&YlsQN$x&vTaX|(@v^$w*g=uDg;qRCoHk-)!KUrpDF+ba^0H+~C zR)!DZV$>s6A-CEqI1bmN?%SFgkJ%nNx}gK}@e_Omzr;eki0|M4F2yP?&c#mDLJr{* zcpfL?4P1!fF{z1{VK2ukQTJu#n2p9l3|q|1qoWm;xD%x~jpH)ZiZ>uHZO!-?et^tj z2QUwhx#I-tIsI<@dz{Ph0Pe#Gv+FsBohPt>`7KT-g5S9lS23OALDWizP$|3R)Wyow zID8bRqZYCVJzR~YxE;&!DDv`l4V9rkQ7@9iO|c?6C3KY9CCEA3iyHqFwG|1}M3+#h z9!AwmgjJMb1L}dFp=#hPYU}z@6aV78>CXR)%GBL_^50A+g9_4(yODF&j!ON0d>Bul z7IG0gD8ipHjvKk?{gBysPEO@~7psh74?c-EQAJ(A+h{?vkTSAL)K;u5BLAA`bq07T z+vaRT=CCfDg~#z}yo$3i#OwZs^RNqxn1$W3ZhRIm;C%cWD=|u?w%|_GJh$*PFYtei z&f^T6D&{RPKu!Dy>can=IbLc{C!tbZgPQPdtitz@OYK|d5b90SdAPPNf=p#4*n!Kj zI*t9mLPtg6O-W^<0`;KRa0c#j?sLWhJr94Fb^_tcYlh}a6 zxDBiL#JDwPy>#jr7{n!5KHaPqKg4tRBWmS)S&dTq1-^(w?szH{sRzG-AK^FHhE*kI z^>_)H)1s_KnOci_-a(wA@4uIhs(uia^4pk2YV;bajchhvpIYG-)z?xs(Q5*#Pfs}rZ$PtqSUk)eJ!JO z@PMW-Cf$u|3)B{-Nd5y;A;%W*^RgSf4;i$@M1~t6gULq5lY6cM73(~L0=E#cicmo+ zQ`$Z?b~O3@tFIc-_Nunjw1um+|0!W@)xtV~bn6rKV=}U_nBfAhbysMGFlI5o8gjL68}= zzeLLrMbSeKQ4tkXNIeuS59vb$22o+u_jm8j!~ExS?lSkB^FRMPT^p{|2H(d=oHSYu zkw$cfn{8Ep7+;W9r?44sU@1=E=8@Qhn#gX<#V*Xk`&fb>Py?rrFuRA@ z$lUECMq)quEoe62UHFCBTnLMGXF3^mV=<1yQskLdkE3zBcYF{v&=K!^2hQdA9CqLv z)N{5lYuSRz*Z~~H_;%d8a26vtzJi+RRaB~Oc|Jj9=pCluH`GL;Mww+|D&}Dk7T`8y zO?C;DnGk9ry_kvv7*tAQc?x}7hq|yCwFL)J1D(XRcnud|IJ3}$icouAi`uGs)PVau z4|~_UP#NmM7QE=4Pl+f0^lc*fP;tz~M65tfU=y}ebbBy_K5p9YGrP@AleivWb~AB3 zPQ}BhBEE^5&2cUeB! zw`xYq$2u&+6Ih1NaTg|0p?dyNyukv_U=qixGu-i-f^>AlKF@Z{Dqu=VH>h2JBEy5m$4lmVkHBwnc&ty4~3u%JU~4s*h^rS{twqm*Z`$VSF2;bC(lUIqu9O znT=AJgNv}iJ3fbpIDU_9*qBSf;TL2KE1%+KXa_0-cTfZOqKf-BD$~)-Hj0dl!vwwm z*(^h^Ss`jA)u>eNMQuSRa=#T5YUzZERIQp|{>}g@Wai>L1DyW=8AHqzk{Fq}qPeWAp- R(<4JKGcH7i-sax({R6Z-n^ph- diff --git a/ui/po/mo/sv/LC_MESSAGES/breezydesktop.mo b/ui/po/mo/sv/LC_MESSAGES/breezydesktop.mo index aafc036e4ed0cd73296679bbc5d6ed18ba0e88cd..8aaa3b61a967800a563b81b422cd6a10a6f159dd 100644 GIT binary patch delta 2020 zcmY+^eQZs49LMo*t8PmlMini6I9GMWtZJQ7Q!S;%Xg#(3F`CjlOk2}lwDHH;vcyAV zG3{gz$QIgvCER6nTNWZB2r^l=ER%+1$pl%KNJSXg`*ZH;!Y}=v*YEu9dHDUlzwhbY zs)0prUuxW8qpc+}iCeK|E*>4qf%bX4S$d4w7kC#>Czxe1eq^}WDD1^lyoST@HYVad z)FU2Y0RP1_9Kw&fFC7_oZ7LnzP{d&*mf;v&f$6vzN8^XM20z1X*pCabKFKTvdr%Ym z1}EW7oPbZU6tk0~6L|-}=X@ikXsJ2e&El*8S)3K4W?bfvS7ILL)uJ$0?}a zx1zRc59-CoP^mwIEAck!MMcbV7M7!)-+`)?!=uQ*_V_CXbm3Xwi>L?Q^e=pXO64PL z!)N~ZcJ_n0*>2R2x|eA(D&ZPjOxe_hzl+qlLKq9)Rf zTJb4V6`x0?{u1iC8%Xx-PyhD;R1G{u{w$vKXd*$(#+j&<*P)8I72ENOOQ(uX1;0`k zb^vw5mza;eI2rHYTbRf6F@l2NHnLltp0YJv-pFVfug zbo7EPs1q_x}qW>cRd&CTR(L5=wnOuErYlY69nQehPK{->3-$a-$PWL%pB`wFQe& znXE-^K?`b2+VN9#(fj_>SRSdcEL0|@qcTy6deJ(JLEWs(yiTko)O6icLYdK|)m|m$ zdcA07)LlxMCM&S4kk(t)Zv3f|yN|5sL`5f+*f`IY)<3^^_9D#9*Vky)svxmD>gW531m0 zL?Q9EKc>A>C2B8dUB3s0mDWZ3M(S-9p?@CQbG0GF8$>NJjZl>jwm0dl>LHe*36Z$~a;)pd~FM3!KX^!sZBJGh3(i6AE6%c3M26?4#tnD z`+kMT9gE>=-4M?q7L#x&PQhVVf4g{P4}Yt;$7i$1)Mn$TlZ>Rx(&MrEuU6R1ThCQ zu@Yxu1Cj*mKxO6yI`wqE)6t4H@w7y2K&AE)@@(tELhSa==P_GtQ3dM7o3IQIpkD9> zbFdTj+|kThwULk7(qhzgRq^CsosA6WK|8z)n^7q|i`(#$H=e*gFb7LUZAlgf)y5*! zgsQNVBCW+t?BHZ91^t7Qda<9E=(-?siDf5{e@&p20j;zWRkby!lyCMftVNP!hrIJ= zPlp&6)*IJ4;}0~M%ZTkoByK~?P@ zJcl=s?X*f}tITXbt#~_XB@N#ADb#b$qb772**&|4N_hur3tl4=bnGh~r8YXrECq*S z4i@49tVh03YsYkaihJ=ls#tdiDKI>VYw;Fpg^3L6{&Z9(wqO7okyqLUEZ6sckB%}B z;G4+96x4;)s2A6xCbl2-;H#+A-$AAD0cxcmP+QT3&G-$qRr`~}890i{z(rIBZeoD< z+jBa-P&aF)6N%M?nl79`WE0~EHSKS{+Y9fhx{HWHLYdR*{%-}|z#I$`tl8bpBD5KV zI#cz-Yf7~WM@7l}+^<4enondBssXK9t*ogsGTB)Y{$a~-CNZ1P2B=L6;~tlCOd?b@ z%D1Ylr%|PD&Xi~6cAj@44HpxWiG|)+E~)~x7qq7C$f*4CaNqs+wt~L?Sx~rc>%(yh zv69FjrV~AF8lB}$bNqpv+N0aOTRxDy1z;Xp$xw?xv254$mHN}~9nND2`MhVX*%`#T*HiIel+&+N|5?#zE? z&$q7~S>*qkHDHTT<`cQZ;r?dtVQDf4%B>W$oPK7v@ft=WW+S=bT zhL2)CY9KSv!+BVY%W*R9Mka5+pfc2pn#d43`6H+lQc-Hlkv3b8y8Z=fDdMOXeUD1@ zRn&e-XA~t^hkD?4)E+p6TDtS77hiV%>DvEBW$K?y^4~%wnH{8#ZAhD~MWucVX5%5$ zK+fTAHsQ~B3_s$g@+7lyG#1eQKBF9mpQ8qP5jByUn2%9T*hV%1Nv4&KApd$%H5cR( zWOCMun!zXdH10w@_!2&k_wX)`XWA<2^Ifm89iJ1=0THgdigb>Ai2&jc>} zRJ7UFj56bA2RLW|-Oe6lvet_lzCYJ7a~oz%Xt>{qASSc?Jq3ENFG_m ziMWUX_}x@!v%DwzGEjzGve%KZSsUs>+fciAA8J5Hk)K`Qpk00yCt&WAW>c^RwFIA{ z+K=O#cnz0g1+%7$Z(mcX=0b>NIFf~`!6mo{kD_M0fCW}cn{gT*#tQ7kIxOaGt+*NM zF_r1oViP`&0nWjjs7y^Cs{#0CZ&BeBwY8|3Zp7q%W?!QA#6C8_aO^||Z$F??dJi?Q zEY^kFt&(_9^gLx_AfYcxUx~8z455AX0-;ZFCht#_*&L&;F0x(y6;wL4CsZ^O4N8Ua zCBByaiL?J7_$U(pBWjuKnw2?~LBvGDFXd28{I_V`v=qtiA{k2*GHv5sT^Z3%XM(A-@ocbL^+| zSlbr+ZSaptqrJL@6(2SHH7$Kp&=H&tS8+TZbO!Ow z8M)c9yiwaDbAx!eCR`o1dqG#YH8|-7XK6nZt`1IfZ&%Rag8h|y|@ z4B~W{S(El7*wA|XW+{Wrdhru}h%_6?`Nz>_!*Bo-@i+3bp@Yq0Fb(yHY~)tU$0RI3 z-B;zF584`bbi;Z~!0k93cVP-1$L)9%D>0Lchu}ukL|QNx591i@#@YA|HSnldvpblD z%-!B&6b_)@f@a^nj$fEX$DlZOra7n!OEDcQk!M;14#lnBaXV_D{oeUQSjh1?JcKV% z&)LkZWiu*cJ29T|?V#6j7Q;F2M9uUnDpj{Udr=vBgQ@rpHIe9evjC>y6fD7F+=8sh zE}}9MLM`M4rr~!CDy4Beg?+0YcAby{ZP(fNh?8 zz5c_f44uJd?C{Q~CX#>lZ7lgvaTH=QE=EmYEuN?7TJZ*^b5VuQ>OoJFBs8foLTQgC zYKSVv|KBvIR{XDNHPo9kIqJx%3uQvtQCsX{^HIgC#-g0cXU_kdUX$7qLd6JyI(8kW;%!XBQJiE2*EiKvK4HTnOvU}&j%>x=IE>!uj*~D3(=ZB4a4a6gaJ+%@ z@FD7s=Wu(8I3G`7E$V!;=#?L4U_Y*J@~HS@2{IU_5_N}lwtWP3!V}2snD0;*Jcl~b zZ>Wyk#%PRT7`T?1i8^mK_QwL$@fE1+RHI8nT2DoHco>uL95PDAi}Ba@A*c>SqP9od z_Gr}9jKxtn1$W^F)P;kY7ugR-V-#wwq@y}e5XSgxhxKew&&p7Dv=zr;4Zet%kx?~0 z`gx2*jnMPRpGo0E9m_x`uD}G`iAi_{wN^S&Q|Hg{C1YGT<6lfAj}024>!=+bB7bH8 z8`a}v)S8%q^u^So_B)EYlZ!YWe?_igoIFZ;nv(e#hH0q%N>L+PgF63y7Zpa^w4e^W zgfVybex9E&=;Fg9X^S=;4i2(avck?9eGul1y0ZQeCtZo{%esb zcbSb;H0R~0JJ^m|3w5YD-jBNAm)H%PQLDQJS@7lpY6M$xBrm8=Y^R;T{Cq(>Y>?-M zz8~zFf*aPm*j>-RSG1>x{-_HFp*rM1UyQIup++JGb>Sq`oy>V%;~Sm79sDL4ZcV-0S{dl-+ULwQSLBkBdyhD@*d z6Zta^7Suo-gUOhI>S!Ihrc!C7(j6ZmqhfqwjX937sGhf?zQ2oFbbnz0I#}BJKGGV8 z`aTi0|6J<=)CIFp$E`zkxNI2Xug9o`4LZ?P)PWtS1Mb*%K%D0>3`XrY$hH%3BJD}2 zp)I%H??IjCplyF{+sADC6h6!MKg2Qq+o(KXgL+mz+~ZDE5BH)@d;v9Q*H9URWuZifO0|)?1rV9lMC*&~=rHIuOD8Qi~)J`7`tR2*N7V0sBxVI%GX# zy@Kk%J=BOr(tCAaHtL3QQFmUAy3Rqn{WNl3mudG@%zd214qhyIZr-F?3sEOHfa=IG z>sbt;{S#`nw_3gFh4za=bts+>O<6XE<1*C9mbtex|2wFBz=l1j6FNqEet-~ zx9ueBSk#Fp*!C3E@zZU4ku@9Dp(W_RBIF;WsYEY5|4yP8PZ60x(#Qg$GLO`drD{-i zc`%h&NHp|arGknd(Xgw`A}_gXo`1hp)EAQX$$FyKw=0;B)no$E@T-K9#i~&B%H8I! z8S^1-BpPo1KRqt5Qp>TeT6~QRw{6jjj3-lxUO=o>vw?VP{#7)LZ;;nX7AYoOMQh<@ z!t|Q0T^n(XtMy@?`048+kZ|1dxejHVGnSWEJ5dGRsL{5<*mlkj-R`8Wh&~rjrHqp}&NA!c@$&yHe-x+2LnL{$jT=M^t!iFAXGD)ysrlLbjNzde9vWQG4U1b23 znN14=&-?eDw0hN=+#F|4e&Nc3%;KgYeQW)qoLRX=Yjbm#JM#)Mi=3IubDY`#*{g6w zQ)9&Cz`(YBjUDw3Z6BX%|MYm%rdS`p*p{ZY`qMXSwmtbx+o1zDPwr@Ksp|OX>zfr@ Q+Nv9VFDY#*OW5rFFDbEM761SM delta 3229 zcmZA3drZ}39LMo*f^t{E8(0criYS7TC`a>>rKXSb3Cfr? zt)=DCHD`5LGj*;^XT@6C%{5(X{exY!*>cUfY46WDUt8-L-{0$bewXL|`yCD}s$CfR zF)g;yNDah&L{qHUIV?@!K$@LwmVS@f9K3>SQ_Q+?eqKAX4!9B1uo3mhVNAmJu{EB? zHh9*{&F%&4Xcn@IWK_}bs2i=lSq#Ks7fixL?1`#4A5(EC(kCm$bS%ftSncIn>_qt> zs$<7-0-nL?m_j90v~Tmtyupd@a15?yIPw&>#a8rABTmIWSb*6$1Bc@}?1~>^5WhtY zq#wg8#zH)ai!ly!=v4+5U_9;Hcrpy$%1|Sl>*bZGifWKmu^p&}>QNQFgX%ySd*OAY z4eP=*#A6=bi$$pCr=Z#iqGoadhBUHjG6AedX2(AF8!n+b(BkK>dHD`%N!qYJMVN}a zaU81QAKagDFy-G+dnB86QU{7q_l-$s{?)UIoY07-;z*o{LvSB5oA!;{f|{XQs3}b0 zpbqC?78c_GEXM$DN9~cbs3p6AL-8+Mg9Tlge@)R5=2bVGLrw7&4(f3X7qu5UBW+p* z>b_N|k-UPV@Gw%R{epUnVmS20EYy7^s41U`s=pGMMB5Z1qX%EbG7O`7+=g{2#tx|6 zTZ+_eLFCV>IcN#$QP=lj1s+1pV5{zCV{tU9L{asK?-2=7My^#TgET4=n1W;=` z0$bx`Y=uG8t}aJ5xGh6XT@4Q6gR~D@D1X(%>?q~qtd9n?;Qr{;Z*+H~I()!AjInzE zkC9Q2notd&a?hY<;!{+^KcGhP2dbi*s2S6{Co@pz3sF-YK&|~))bl~q5-#!bHtb0I z_Bt6o7{)?8fsf!-oQ;LO&30h}7GQRc*#lUH`ao?#R?8ZZKWpN^WY}dKinmc64D^Y9 z0n1SBy@nwMVQ-N+fuH$>n%rnlcc4c6Hflugxu;PhX+~Al;$A~FbORHxEw6w&nvQyF zN>TMxp`Kgcm-*KNoBhOo)NA*q-}r%-Kf%$Q{~k4^8U3Oa<)SJY?B(HJp5Wyv*q`gO za3}6Wbu1$oKSxs6C4Y`=RRlPUj+dj1aT`F6Cbf%QUN zAAy>&64Vk^;y|nmkx`F6_8Xc}OVWasn4BMda3!kYdM}?u&D2F4gTJC09KZ&V<53OI z#gSNr>cBD7-e^XBDMMGuv?J4YL+69`HxJcN0JXbI-NmT;wxc?<7qwK)sQ3PB)Qn#B z^MB(Dly74iuIC~Be^D2a^=}}f2lo1f1MVSI#YepSE~*v=1xotj?Ixa5fs{l%8p%aJM$B@gQ)*}tp{Xn)lpZGn zL>)1eP|6}|h@FIzmWaOAJLTL`6-)p7mL^Yug2m`TFLZedBMqC!jMGr5+ zd}0Kl57%=@Nyl2SR=5>>=A#8zSt@sOVALFQSakeE%}P1;QHL^%;8785TK zdRz2MsH7b|oY4MJ%8U|u1N6a~NlYVF5VMFGL>h57Em4nm5KH|`C2k>}CbVmN6H2jB zBCqCSp5Ns1FGD14cQ@c>VwaaiKcY3EH%%#**hYkUszfRvMn-acJn&`DFLc+VUPGk^ ziM7Nk;(1~a@&8oMiEKaF;P!FX$;2$Ba9#38@!?sW_QZuVx-}<\n" "Language-Team: Polish \n" @@ -28,33 +28,33 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "" -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 msgid "Set Focused Display Distance" msgstr "" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 msgid "Set All Displays Distance" msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 msgid "Focused display" msgstr "" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 msgid "All displays" msgstr "" @@ -226,276 +226,284 @@ msgstr "" msgid "Keep the focused display near the center of your view." msgstr "" -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "" + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 msgid "Virtual displays" msgstr "" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 msgid "Rearrange displays" msgstr "" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 msgid "Display distances" msgstr "" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "" -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 msgid "Display angling" msgstr "" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 msgid "Display spacing" msgstr "" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." msgstr "" -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "" -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 msgid "Toggle zoom on focus shortcut" msgstr "" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 msgid "Quickly toggle zoom on focus mode." msgstr "" -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "" -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." msgstr "" -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 msgid "Remove virtual displays on disable" msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 msgid "All displays follow mode" msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " "movements, jumps ahead, or is very shaky." msgstr "" -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" diff --git a/ui/po/pt_BR.po b/ui/po/pt_BR.po index 843ebf3..f5d70f0 100644 --- a/ui/po/pt_BR.po +++ b/ui/po/pt_BR.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 08:49-0700\n" +"POT-Creation-Date: 2025-03-15 16:43-0700\n" "PO-Revision-Date: 2024-08-19 09:39-0700\n" "Last-Translator: \n" "Language-Team: Brazilian Portuguese \n" "Language-Team: Russian \n" @@ -29,36 +29,36 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Эта функция в настоящее время не поддерживается для вашего устройства." -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 #, fuzzy msgid "Set Focused Display Distance" msgstr "Расстояние дисплея" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 #, fuzzy msgid "Set All Displays Distance" msgstr "Расстояние дисплея" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 #, fuzzy msgid "Focused display" msgstr "Расстояние дисплея" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 #, fuzzy msgid "All displays" msgstr "Изогнутый дисплей" @@ -232,189 +232,197 @@ msgstr "Режим следования" msgid "Keep the focused display near the center of your view." msgstr "Поддерживает виртуальный дисплей вблизи центра вашего зрения." -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "Изогнутый дисплей" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "Переключается между плоскими и изогнутыми дисплеями." + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 #, fuzzy msgid "Virtual displays" msgstr "Изогнутый дисплей" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 #, fuzzy msgid "Rearrange displays" msgstr "Изогнутый дисплей" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "Настройки" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 #, fuzzy msgid "Display distances" msgstr "Расстояние дисплея" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "Изменить" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "Порог следования" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "" "Как далеко вы можете отвернуть взгляд, прежде чем дисплей последует за вами." -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 #, fuzzy msgid "Display angling" msgstr "Размер дисплея" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 #, fuzzy msgid "Display spacing" msgstr "Размер дисплея" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "Сочетания клавиш" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." msgstr "" -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "Сочетание клавиш для перецентровки дисплея" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "Фиксировать виртуальный дисплей в текущем положении." -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 #, fuzzy msgid "Toggle zoom on focus shortcut" msgstr "Сочетание клавиш для переключения режима следования" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 #, fuzzy msgid "Quickly toggle zoom on focus mode." msgstr "Быстро переключать режим следования." -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "Сочетание клавиш для переключения режима следования" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "Быстро переключать режим следования." -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "Дополнительные настройки" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "Найти оптимальную конфигурацию дисплея" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -422,87 +430,87 @@ msgstr "" "Автоматически изменять конфигурацию дисплея очков для максимального " "разрешения и лучшей масштабирования при подключении." -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "Использовать высшую частоту обновления" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Частота обновления может повлиять на производительность, отключите это, " "чтобы установить ее вручную." -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "Всегда основной дисплей" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Автоматически устанавливать очки в качестве основного дисплея при " "подключении." -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Изогнутый дисплей" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 #, fuzzy msgid "All displays follow mode" msgstr "Изогнутый дисплей" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "Прогнозирование движения" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -513,15 +521,15 @@ msgstr "" "виртуальный дисплей не отстает от движений вашей головы, не опережает или не " "очень трясётся." -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "По умолчанию" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" @@ -723,9 +731,6 @@ msgstr "О BreezyDesktop" #~ msgid "Widescreen mode" #~ msgstr "Режим широкого экрана" -#~ msgid "Switch between flat and curved displays." -#~ msgstr "Переключается между плоскими и изогнутыми дисплеями." - #~ msgid "" #~ "Closer appears larger, further appears smaller. Controls depth when in " #~ "widescreen mode." diff --git a/ui/po/sv.po b/ui/po/sv.po index e8b7ee4..de63a95 100644 --- a/ui/po/sv.po +++ b/ui/po/sv.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 08:49-0700\n" +"POT-Creation-Date: 2025-03-15 16:43-0700\n" "PO-Revision-Date: 2024-08-16 10:31-0700\n" "Last-Translator: \n" "Language-Team: Swedish \n" @@ -29,36 +29,36 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Din enhet stöder inte den här funktionen för tillfället." -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 #, fuzzy msgid "Set Focused Display Distance" msgstr "Avstånd till skärmen" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 #, fuzzy msgid "Set All Displays Distance" msgstr "Avstånd till skärmen" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 #, fuzzy msgid "Focused display" msgstr "Avstånd till skärmen" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 #, fuzzy msgid "All displays" msgstr "Böjd skärm" @@ -232,148 +232,156 @@ msgstr "Följningsläge" msgid "Keep the focused display near the center of your view." msgstr "Håll den virtuella skärmen nära mitten av din syn." -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "Böjd skärm" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "Växla mellan platt eller böjd skärm." + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 #, fuzzy msgid "Virtual displays" msgstr "Böjd skärm" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 #, fuzzy msgid "Rearrange displays" msgstr "Böjd skärm" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "Justeringar" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 #, fuzzy msgid "Display distances" msgstr "Avstånd till skärmen" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "Ändra" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "Automatisk följtröskel" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "Huvudrörelsetröskel för automatisk efterföljning." -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 #, fuzzy msgid "Display angling" msgstr "Skärmens storlek" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 #, fuzzy msgid "Display spacing" msgstr "Skärmens storlek" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "Tangentbordsgenvägar" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "XR-Effekt genväg på/av" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." @@ -381,41 +389,41 @@ msgstr "" "Skifta snabbt mellan att slå av eller på XR-Effekt. Du kan behöva slå på den " "manuellt en gång för att genvägen ska fungera." -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "Om-centrering tangentbordsgenväg" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "Fäst den virtuella skärmen i den nuvarande positionen." -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 #, fuzzy msgid "Toggle zoom on focus shortcut" msgstr "Växla följ läge kort" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 #, fuzzy msgid "Quickly toggle zoom on focus mode." msgstr "Växla snabbt följ läge." -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "Växla följ läge kort" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "Växla snabbt följ läge." -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "Avancerade inställningar" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "Hitta optimal konfiguration till skärmen" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -423,85 +431,85 @@ msgstr "" "Ändrar automatisk glasögonens skärmkonfiguration för maximal upplösning och " "bästa skälning när den är ansluten." -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "Använd högsta uppdateringsfrekvens" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Uppdateringsfrekvens kan påverka prestanda, inaktivera detta för att ställa " "in det manuellt." -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "Alltid primär skärm" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "Ställer automatisk glasögon som primär skärm när den är ansluten." -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Böjd skärm" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 #, fuzzy msgid "All displays follow mode" msgstr "Böjd skärm" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "Rörs förväntning" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -510,15 +518,15 @@ msgstr "" "Motverkar ingångsfördröjning genom förutsägelse av huvudrörelser.Behåll " "standardinställningen om inte skärmen skakar mycket eller rörsig konstigt." -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "Standard" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "Textskalning" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "Textskalning under 1.0 kommer att simulera en högre skärmupplösning" @@ -720,9 +728,6 @@ msgstr "Om BreezyDesktop" #~ msgid "Widescreen mode" #~ msgstr "Bredbildsläge" -#~ msgid "Switch between flat and curved displays." -#~ msgstr "Växla mellan platt eller böjd skärm." - #~ msgid "" #~ "Closer appears larger, further appears smaller. Controls depth when in " #~ "widescreen mode." diff --git a/ui/po/uk_UA.po b/ui/po/uk_UA.po index 109c2f5..c49f522 100644 --- a/ui/po/uk_UA.po +++ b/ui/po/uk_UA.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 08:49-0700\n" +"POT-Creation-Date: 2025-03-15 16:43-0700\n" "PO-Revision-Date: 2024-08-17 10:08-0700\n" "Last-Translator: \n" "Language-Team: Ukrainian \n" @@ -28,36 +28,36 @@ msgstr "Переключає окуляри в режим «бок о бок» msgid "This feature is not currently supported for your device." msgstr "Ця функція наразі не підтримується на вашому пристрої." -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 #, fuzzy msgid "Set Focused Display Distance" msgstr "Відстань дисплея" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 #, fuzzy msgid "Set All Displays Distance" msgstr "Відстань дисплея" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 #, fuzzy msgid "Focused display" msgstr "Відстань дисплея" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 #, fuzzy msgid "All displays" msgstr "Викривлений дисплей" @@ -231,190 +231,198 @@ msgstr "Режим слідування" msgid "Keep the focused display near the center of your view." msgstr "Зберігае віртуальний дисплей поблизу центру вашого зору." -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "Викривлений дисплей" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "Переключается між плоскими і викривленими дисплеями." + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 #, fuzzy msgid "Virtual displays" msgstr "Викривлений дисплей" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 #, fuzzy msgid "Rearrange displays" msgstr "Викривлений дисплей" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "Налаштування" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 #, fuzzy msgid "Display distances" msgstr "Відстань дисплея" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "Змінити" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "Поріг слідування" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "" "Як далеко ви можете відвернути ваш взор, перш ніж дисплей почне слідувати за " "вами." -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 #, fuzzy msgid "Display angling" msgstr "Розмір дисплея" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 #, fuzzy msgid "Display spacing" msgstr "Розмір дисплея" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "Сполучення клавіш" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." msgstr "" -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "Сполучення клавіш для центрування дисплея" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "Фіксувати віртуальний дисплей у поточній позиції." -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 #, fuzzy msgid "Toggle zoom on focus shortcut" msgstr "Сполучення клавіш для перемикання режиму слідування" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 #, fuzzy msgid "Quickly toggle zoom on focus mode." msgstr "Швидко перемикати режим слідування." -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "Сполучення клавіш для перемикання режиму слідування" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "Швидко перемикати режим слідування." -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "Додаткові налаштування" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "Знайти оптимальну конфігурацію дисплея" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -422,85 +430,85 @@ msgstr "" "Автоматично змінює конфігурацію дисплея окулярів для максимальної роздільної " "здатності і найкращого масштабування при підключенні." -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "Використовувати найвищу частоту оновлення" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Частота оновлення може вплинути на продуктивність, вимкніть це, щоб " "встановити її вручну." -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "Завжди основний дисплей" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "Автоматично встановлює окуляри як основний дисплей при підключенні." -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Викривлений дисплей" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 #, fuzzy msgid "All displays follow mode" msgstr "Викривлений дисплей" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "Прогнозування руху" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -511,15 +519,15 @@ msgstr "" "віртуальний дисплей відстає від рухів вашої голови, випереджає або дуже " "тремтить." -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "За замовчуванням" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" @@ -720,9 +728,6 @@ msgstr "Про BreezyDesktop" #~ msgid "Widescreen mode" #~ msgstr "Режим широкого екрану" -#~ msgid "Switch between flat and curved displays." -#~ msgstr "Переключается між плоскими і викривленими дисплеями." - #~ msgid "" #~ "Closer appears larger, further appears smaller. Controls depth when in " #~ "widescreen mode." diff --git a/ui/po/zh_CN.po b/ui/po/zh_CN.po index c70074f..73bf651 100644 --- a/ui/po/zh_CN.po +++ b/ui/po/zh_CN.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-12 08:49-0700\n" +"POT-Creation-Date: 2025-03-15 16:43-0700\n" "PO-Revision-Date: 2024-08-02 20:55-0700\n" "Last-Translator: \n" "Language-Team: Chinese (simplified) \n" @@ -26,34 +26,33 @@ msgstr "切换到并排模式,并将显示宽度翻倍。" msgid "This feature is not currently supported for your device." msgstr "您的设备目前不支援此功能。" -#: src/connecteddevice.py:141 +#: src/connecteddevice.py:142 msgid "Set Focused Display Distance" msgstr "设定注视中的屏幕的距离" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:143 msgid "Use a closer value so the display zooms in when you look at it." msgstr "近的数值会将您所看向的屏幕放大" -#: src/connecteddevice.py:149 +#: src/connecteddevice.py:150 msgid "Set All Displays Distance" msgstr "设定所有屏幕的距离" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:151 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "远的数值会将您所看向的屏幕缩小" -#: src/connecteddevice.py:266 +#: src/connecteddevice.py:267 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." -msgstr "" -"无法增加模拟显示。需要安装xdg-desktop-portal和Wayland" +msgstr "无法增加模拟显示。需要安装xdg-desktop-portal和Wayland" -#: src/connecteddevice.py:300 +#: src/connecteddevice.py:301 msgid "Focused display" msgstr "注视中的屏幕" -#: src/connecteddevice.py:306 +#: src/connecteddevice.py:307 msgid "All displays" msgstr "所有的屏幕" @@ -227,261 +226,269 @@ msgstr "跟随模式" msgid "Keep the focused display near the center of your view." msgstr "将注视中的屏幕保持在视野中心附近。" -#: src/gtk/connected-device.ui:81 src/gtk/no-device.ui:34 +#: src/gtk/connected-device.ui:81 +msgid "Curved display" +msgstr "曲面显示" + +#: src/gtk/connected-device.ui:82 +msgid "Switch between flat and curved displays." +msgstr "平板和曲面显示模式之间切换。" + +#: src/gtk/connected-device.ui:93 src/gtk/no-device.ui:34 msgid "Disable physical displays" msgstr "将所有具体屏幕关闭" -#: src/gtk/connected-device.ui:82 src/gtk/no-device.ui:35 +#: src/gtk/connected-device.ui:94 src/gtk/no-device.ui:35 msgid "" "Automatically disable all physical displays when the XR effect is enabled." msgstr "XR效果开启时将所有具体屏幕自动关闭" -#: src/gtk/connected-device.ui:92 +#: src/gtk/connected-device.ui:104 msgid "Virtual displays" msgstr "模拟屏幕" -#: src/gtk/connected-device.ui:108 +#: src/gtk/connected-device.ui:120 msgid "1080p" msgstr "1080p" -#: src/gtk/connected-device.ui:109 +#: src/gtk/connected-device.ui:121 msgid "1440p" msgstr "1440p" -#: src/gtk/connected-device.ui:110 +#: src/gtk/connected-device.ui:122 msgid "Add custom" msgstr "增加客制化解析度" -#: src/gtk/connected-device.ui:124 +#: src/gtk/connected-device.ui:136 msgid "Remove custom resolution" msgstr "删除客制化解析度" -#: src/gtk/connected-device.ui:144 +#: src/gtk/connected-device.ui:156 msgid "Rearrange displays" msgstr "改变屏幕顺序" -#: src/gtk/connected-device.ui:162 +#: src/gtk/connected-device.ui:174 msgid "Adjustments" msgstr "调整" -#: src/gtk/connected-device.ui:166 +#: src/gtk/connected-device.ui:178 msgid "Display distances" msgstr "屏幕距离" -#: src/gtk/connected-device.ui:167 +#: src/gtk/connected-device.ui:179 msgid "Set how close you want displays to appear." msgstr "设定您所希望屏幕离你的距离有多近" -#: src/gtk/connected-device.ui:188 src/gtk/connected-device.ui:209 -#: src/gtk/connected-device.ui:401 src/gtk/connected-device.ui:430 -#: src/gtk/connected-device.ui:459 src/gtk/connected-device.ui:488 +#: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 +#: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 +#: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 msgid "Change" msgstr "更改" -#: src/gtk/connected-device.ui:222 +#: src/gtk/connected-device.ui:234 msgid "Follow threshold" msgstr "跟随触发值" -#: src/gtk/connected-device.ui:223 +#: src/gtk/connected-device.ui:235 msgid "How far away you can look before the display follows." msgstr "显示内容开始进行跟随模式前您可以看得多远。" -#: src/gtk/connected-device.ui:246 +#: src/gtk/connected-device.ui:258 msgid "Display angling" msgstr "屏幕角度" -#: src/gtk/connected-device.ui:247 +#: src/gtk/connected-device.ui:259 msgid "" "When there are multiple displays, choose how they should angle towards you." msgstr "有多屏幕时,选择屏幕向您倾斜的角度" -#: src/gtk/connected-device.ui:261 +#: src/gtk/connected-device.ui:273 msgid "Automatic" msgstr "自动" -#: src/gtk/connected-device.ui:262 +#: src/gtk/connected-device.ui:274 msgid "Side-angled" msgstr "侧边弯曲" -#: src/gtk/connected-device.ui:263 +#: src/gtk/connected-device.ui:275 msgid "Top-angled" msgstr "上下弯曲" -#: src/gtk/connected-device.ui:264 +#: src/gtk/connected-device.ui:276 msgid "Flat" msgstr "平面" -#: src/gtk/connected-device.ui:274 +#: src/gtk/connected-device.ui:286 msgid "Display spacing" msgstr "屏幕之间缝隙的距差" -#: src/gtk/connected-device.ui:275 +#: src/gtk/connected-device.ui:287 msgid "Put empty space between displays, when there are multiple." msgstr "把多屏幕之间插入一个空间" -#: src/gtk/connected-device.ui:305 +#: src/gtk/connected-device.ui:317 msgid "Viewport horizontal offset" msgstr "眼镜视口特定水平偏移" -#: src/gtk/connected-device.ui:306 +#: src/gtk/connected-device.ui:318 msgid "Move the viewport to the left or right of its default position." msgstr "将眼镜视口从默认位置左右移动" -#: src/gtk/connected-device.ui:323 +#: src/gtk/connected-device.ui:335 msgid "left" msgstr "左" -#: src/gtk/connected-device.ui:325 src/gtk/connected-device.ui:355 +#: src/gtk/connected-device.ui:337 src/gtk/connected-device.ui:367 msgid "center" msgstr "中" -#: src/gtk/connected-device.ui:327 +#: src/gtk/connected-device.ui:339 msgid "right" msgstr "右" -#: src/gtk/connected-device.ui:335 +#: src/gtk/connected-device.ui:347 msgid "Viewport vertical offset" msgstr "眼镜视口特定垂直偏移" -#: src/gtk/connected-device.ui:336 +#: src/gtk/connected-device.ui:348 msgid "Move the viewport up or down from its default position." msgstr "将眼镜视口从默认位置上下移动" -#: src/gtk/connected-device.ui:353 +#: src/gtk/connected-device.ui:365 msgid "down" msgstr "下" -#: src/gtk/connected-device.ui:357 +#: src/gtk/connected-device.ui:369 msgid "up" msgstr "上" -#: src/gtk/connected-device.ui:372 src/gtk/connected-device.ui:378 +#: src/gtk/connected-device.ui:384 src/gtk/connected-device.ui:390 msgid "Keyboard Shortcuts" msgstr "键盘快捷键" -#: src/gtk/connected-device.ui:381 +#: src/gtk/connected-device.ui:393 msgid "XR Effect on/off shortcut" msgstr "XR效果 开/关 快捷键" -#: src/gtk/connected-device.ui:382 +#: src/gtk/connected-device.ui:394 msgid "" "Quickly enable or disable the XR Effect. You may need to enable the effect " "manually once in order to enable the shortcut." msgstr "快速启用或禁用 XR 效果。您可能需要先手动启用一次该效果,才能设此快捷键" -#: src/gtk/connected-device.ui:410 +#: src/gtk/connected-device.ui:422 msgid "Re-center display shortcut" msgstr "重新居中显示快捷键" -#: src/gtk/connected-device.ui:411 +#: src/gtk/connected-device.ui:423 msgid "Pin the virtual display to the current position." msgstr "将虚拟显示固定在当前位置。" -#: src/gtk/connected-device.ui:439 +#: src/gtk/connected-device.ui:451 msgid "Toggle zoom on focus shortcut" msgstr "切换注视自动放大模式快捷键" -#: src/gtk/connected-device.ui:440 +#: src/gtk/connected-device.ui:452 msgid "Quickly toggle zoom on focus mode." msgstr "快速地切换注视自动放大模式。" -#: src/gtk/connected-device.ui:468 +#: src/gtk/connected-device.ui:480 msgid "Toggle follow mode shortcut" msgstr "切换跟随模式快捷键" -#: src/gtk/connected-device.ui:469 +#: src/gtk/connected-device.ui:481 msgid "Quickly toggle follow mode." msgstr "快速切换跟随模式。" -#: src/gtk/connected-device.ui:504 src/gtk/connected-device.ui:514 +#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 msgid "Advanced Settings" msgstr "高级设定" -#: src/gtk/connected-device.ui:518 +#: src/gtk/connected-device.ui:530 msgid "Find optimal display config" msgstr "寻找最佳显示设定" -#: src/gtk/connected-device.ui:519 +#: src/gtk/connected-device.ui:531 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." msgstr "连接时,可以自动修改眼镜显示设定以表现出最大解析度和最佳的对比。" -#: src/gtk/connected-device.ui:529 +#: src/gtk/connected-device.ui:541 msgid "Use highest refresh rate" msgstr "使用最高刷新率" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:542 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "刷新率可能会影响性能,禁用此功能即可手动设置。" -#: src/gtk/connected-device.ui:540 +#: src/gtk/connected-device.ui:552 msgid "Center on glasses' display" msgstr "视口眼镜屏幕固定" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:553 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "将眼镜视口对齐眼镜的主要屏幕, 即便此屏幕不在正中间" -#: src/gtk/connected-device.ui:551 +#: src/gtk/connected-device.ui:563 msgid "Always primary display" msgstr "每次设置为主要显示" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:564 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "连接时,自动将眼镜设置为主要显示。" -#: src/gtk/connected-device.ui:562 +#: src/gtk/connected-device.ui:574 msgid "Remove virtual displays on disable" msgstr "自动模拟屏幕删除" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:575 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "XR效果关闭时自动删除所有模拟屏幕" -#: src/gtk/connected-device.ui:573 +#: src/gtk/connected-device.ui:585 msgid "Enable multi-tap detection" msgstr "开启多点触控检测" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:586 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "打开双击重新定位和三击重新校准手势" -#: src/gtk/connected-device.ui:584 +#: src/gtk/connected-device.ui:596 msgid "All displays follow mode" msgstr "全屏幕跟随模式" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:597 msgid "Follow mode moves all displays, not just the focused one." msgstr "让跟随模式移动所有的屏幕而不只是注视中的屏幕" -#: src/gtk/connected-device.ui:601 +#: src/gtk/connected-device.ui:613 msgid "Follow mode movement tracking" msgstr "跟随模式感应" -#: src/gtk/connected-device.ui:602 +#: src/gtk/connected-device.ui:614 msgid "Choose which movements should be tracked in follow mode." msgstr "选择那一些动作会被感应到" -#: src/gtk/connected-device.ui:617 +#: src/gtk/connected-device.ui:629 msgid "Horizontal" msgstr "水平动作" -#: src/gtk/connected-device.ui:637 +#: src/gtk/connected-device.ui:649 msgid "Vertical" msgstr "垂直动作" -#: src/gtk/connected-device.ui:657 +#: src/gtk/connected-device.ui:669 msgid "Tilt/roll" msgstr "倾斜及滚转动作" -#: src/gtk/connected-device.ui:675 +#: src/gtk/connected-device.ui:687 msgid "Movement look-ahead" msgstr "移动预测" -#: src/gtk/connected-device.ui:676 +#: src/gtk/connected-device.ui:688 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -490,15 +497,15 @@ msgstr "" "透过预测头部追踪位置,提前于渲染时间进行预测来抵消输入延迟。除非虚拟显示滞后" "于头部,提前跳动或非常抖动,请尽量使用默认设置。" -#: src/gtk/connected-device.ui:694 +#: src/gtk/connected-device.ui:706 msgid "Default" msgstr "默认" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:718 msgid "Text Scaling" msgstr "字体大小比例" -#: src/gtk/connected-device.ui:707 +#: src/gtk/connected-device.ui:719 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "字体缩放小于1.0,将模拟解析度更高的显示效果" @@ -696,9 +703,6 @@ msgstr "关于 Breezy Desktop" #~ msgid "Widescreen mode" #~ msgstr "宽屏模式" -#~ msgid "Switch between flat and curved displays." -#~ msgstr "平板和曲面显示模式之间切换。" - #~ msgid "" #~ "Closer appears larger, further appears smaller. Controls depth when in " #~ "widescreen mode." diff --git a/ui/src/connecteddevice.py b/ui/src/connecteddevice.py index 3a4f78e..28e8bce 100644 --- a/ui/src/connecteddevice.py +++ b/ui/src/connecteddevice.py @@ -36,6 +36,7 @@ class ConnectedDevice(Gtk.Box): follow_threshold_scale = Gtk.Template.Child() follow_threshold_adjustment = Gtk.Template.Child() follow_mode_switch = Gtk.Template.Child() + curved_display_switch = Gtk.Template.Child() top_features_group = Gtk.Template.Child() virtual_displays_row = Gtk.Template.Child() add_virtual_display_menu = Gtk.Template.Child() @@ -86,7 +87,7 @@ class ConnectedDevice(Gtk.Box): # self.display_size_scale, self.follow_mode_switch, self.follow_threshold_scale, - # self.curved_display_switch, + self.curved_display_switch, self.add_virtual_display_menu, self.add_virtual_display_button, self.change_all_displays_distance_button, @@ -109,7 +110,7 @@ class ConnectedDevice(Gtk.Box): # self.settings.bind('display-size', self.display_size_adjustment, 'value', Gio.SettingsBindFlags.DEFAULT) self.settings.bind('follow-threshold', self.follow_threshold_adjustment, 'value', Gio.SettingsBindFlags.DEFAULT) # self.settings.bind('widescreen-mode', self.widescreen_mode_switch, 'active', Gio.SettingsBindFlags.DEFAULT) - # self.settings.bind('curved-display', self.curved_display_switch, 'active', Gio.SettingsBindFlags.DEFAULT) + self.settings.bind('curved-display', self.curved_display_switch, 'active', Gio.SettingsBindFlags.DEFAULT) self.settings.bind('headset-display-as-viewport-center', self.headset_display_as_viewport_center_switch, 'active', Gio.SettingsBindFlags.DEFAULT) self.settings.bind('headset-as-primary', self.headset_as_primary_switch, 'active', Gio.SettingsBindFlags.DEFAULT) self.settings.bind('remove-virtual-displays-on-disable', self.remove_virtual_displays_on_disable_switch, 'active', Gio.SettingsBindFlags.DEFAULT) @@ -430,13 +431,3 @@ class ConnectedDevice(Gtk.Box): def _launch_display_settings(self, *args): self._settings_displays_app_info.launch() - -def reload_display_distance_toggle_button(widget): - distance = SettingsManager.get_instance().settings.get_double(widget.get_name()) - if distance: widget.set_label(str(distance)) - -def on_set_display_distance_toggle(widget): - settings = SettingsManager.get_instance().settings - distance = settings.get_double('display-distance') - settings.set_double(widget.get_name(), distance) - reload_display_distance_toggle_button(widget) diff --git a/ui/src/gtk/connected-device.ui b/ui/src/gtk/connected-device.ui index 4025201..9a465a6 100644 --- a/ui/src/gtk/connected-device.ui +++ b/ui/src/gtk/connected-device.ui @@ -76,6 +76,18 @@ + + + Curved display + Switch between flat and curved displays. + 2 + + + 3 + + + + Disable physical displays From b3f788f114387fc0548862cf268ca4aeaccdc433 Mon Sep 17 00:00:00 2001 From: Wayne Heaney <42350981+wheaney@users.noreply.github.com> Date: Sun, 16 Mar 2025 14:53:37 -0700 Subject: [PATCH 2/6] Update README.md --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 1754a7f..4543df7 100644 --- a/README.md +++ b/README.md @@ -14,7 +14,7 @@ There are two installations at the moment. **Note: Don't manually install either ## Breezy GNOME -Breezy GNOME is a virtual workspace solution for Linux desktops that use the GNOME desktop environment (support GNOME versions 42 through 47); see [non-GNOME setup](#non-gnome-setup) if you want to try it without a GNOME desktop environment. It currently supports multiple virtual monitors and multiple physical monitors. See [upcoming features](#upcoming-features) for more improvements on the horizon. +Breezy GNOME is a virtual workspace solution for Linux desktops that use the GNOME desktop environment (support GNOME versions 42 through 48); see [non-GNOME setup](#non-gnome-setup) if you want to try it without a GNOME desktop environment. It currently supports multiple virtual monitors and multiple physical monitors. See [upcoming features](#upcoming-features) for more improvements on the horizon. ### GNOME Setup @@ -47,7 +47,7 @@ Breezy GNOME is in AUR (but not pacman, yet). To install, run these commands fro Steam Deck's desktop mode runs KDE Plasma, so, for now, Breezy Desktop can only be run by launching a nested GNOME shell, and requires the read-only file system to be disabled to get setup. If you're interested, and *willing to accept any risks that come with disabling the read-only file system*, check out [the wiki entry](https://github.com/wheaney/breezy-desktop/wiki/Installing-on-Steam-Deck). ### Non-GNOME Setup -A workable solution (with some [QoL improvements needed](#upcoming-features)) is to use your preferred desktop environment with a GNOME window open in nested mode. To do this: +A workable demo -- but not a great long-term solutions -- is to use your preferred desktop environment with a GNOME window open in nested mode. To do this: 1. Install `gnome-shell` using your distros package manager (e.g. apt-get, pacman, dnf, etc...). This will currently only work with GNOME Shell versions 42-47, so check that using `gnome-shell --version` 2. Run the [GNOME setup](#gnome-setup) steps. You shouldn't need to log out and back in since GNOME will be running nested. 3. Launch the nested GNOME Shell using `MUTTER_DEBUG_DUMMY_MODE_SPECS="1920x1080@60" dbus-run-session -- gnome-shell --nested` From ada60201f14962c602ecba485e720f538d3bea9c Mon Sep 17 00:00:00 2001 From: wheaney <42350981+wheaney@users.noreply.github.com> Date: Sun, 16 Mar 2025 22:26:33 -0700 Subject: [PATCH 3/6] Add "cursor to focused display" shortcut, v2.1.0 --- VERSION | 2 +- gnome/src/cursormanager.js | 4 + gnome/src/extension.js | 13 +++ gnome/src/virtualdisplaysactor.js | 6 +- .../com.xronlinux.BreezyDesktop.gschema.xml | 9 +++ ui/po/breezydesktop.pot | 75 ++++++++++-------- ui/po/de.po | 75 ++++++++++-------- ui/po/es.po | 75 ++++++++++-------- ui/po/fr.po | 75 ++++++++++-------- ui/po/it.po | 75 ++++++++++-------- ui/po/ja.po | 75 ++++++++++-------- ui/po/mo/zh_CN/LC_MESSAGES/breezydesktop.mo | Bin 13473 -> 13491 bytes ui/po/pl.po | 75 ++++++++++-------- ui/po/pt_BR.po | 75 ++++++++++-------- ui/po/ru.po | 75 ++++++++++-------- ui/po/sv.po | 75 ++++++++++-------- ui/po/uk_UA.po | 75 ++++++++++-------- ui/po/zh_CN.po | 75 ++++++++++-------- ui/src/connecteddevice.py | 5 +- ui/src/gtk/connected-device.ui | 29 +++++++ 20 files changed, 569 insertions(+), 399 deletions(-) diff --git a/VERSION b/VERSION index e6f474a..50aea0e 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -2.0.15 \ No newline at end of file +2.1.0 \ No newline at end of file diff --git a/gnome/src/cursormanager.js b/gnome/src/cursormanager.js index dd4a77d..5a682b3 100644 --- a/gnome/src/cursormanager.js +++ b/gnome/src/cursormanager.js @@ -252,4 +252,8 @@ export class CursorManager { return null; } + + moveCursorTo(x, y) { + this._backend().get_default_seat().warp_pointer(x, y); + } } \ No newline at end of file diff --git a/gnome/src/extension.js b/gnome/src/extension.js index 891bd16..852e23e 100644 --- a/gnome/src/extension.js +++ b/gnome/src/extension.js @@ -310,6 +310,7 @@ export default class BreezyDesktopExtension extends Extension { this._add_settings_keybinding('recenter-display-shortcut', this._recenter_display.bind(this)); this._add_settings_keybinding('toggle-display-distance-shortcut', this._virtual_displays_actor._change_distance.bind(this._virtual_displays_actor)); this._add_settings_keybinding('toggle-follow-shortcut', this._toggle_follow_mode.bind(this)); + this._add_settings_keybinding('cursor-to-focused-display-shortcut', this._cursor_to_focused_display.bind(this)); this._fresh_session = false; } catch (e) { @@ -539,6 +540,16 @@ export default class BreezyDesktopExtension extends Extension { this._write_control('toggle_breezy_desktop_smooth_follow', 'true'); } + _cursor_to_focused_display() { + Globals.logger.log_debug('BreezyDesktopExtension _cursor_to_focused_display'); + if (this._virtual_displays_actor?.focused_monitor_details) { + const monitorDetails = this._virtual_displays_actor.focused_monitor_details; + const xMid = monitorDetails.x + monitorDetails.width / 2; + const yMid = monitorDetails.y + monitorDetails.height / 2; + this._cursor_manager.moveCursorTo(xMid, yMid); + } + } + // for_setup should be true if our intention is to immediately re-enable the extension _effect_disable(for_setup = false) { try { @@ -547,9 +558,11 @@ export default class BreezyDesktopExtension extends Extension { if (Globals.data_stream.smooth_follow_enabled) this._toggle_follow_mode(); + Main.wm.removeKeybinding('toggle-xr-effect-shortcut'); Main.wm.removeKeybinding('recenter-display-shortcut'); Main.wm.removeKeybinding('toggle-display-distance-shortcut'); Main.wm.removeKeybinding('toggle-follow-shortcut'); + Main.wm.removeKeybinding('cursor-to-focused-display-shortcut'); if (global.compositor?.enable_unredirect) { global.compositor.enable_unredirect(); diff --git a/gnome/src/virtualdisplaysactor.js b/gnome/src/virtualdisplaysactor.js index 9099189..b4eecbc 100644 --- a/gnome/src/virtualdisplaysactor.js +++ b/gnome/src/virtualdisplaysactor.js @@ -781,7 +781,11 @@ export const VirtualDisplaysActor = GObject.registerClass({ if (this.focused_monitor_index !== focusedMonitorIndex) { Globals.logger.log_debug(`Switching to monitor ${focusedMonitorIndex}`); this.focused_monitor_index = focusedMonitorIndex; - this.focused_monitor_details = this._all_monitors[focusedMonitorIndex]; + if (focusedMonitorIndex !== -1) { + this.focused_monitor_details = this._all_monitors[focusedMonitorIndex]; + } else { + this.focused_monitor_details = null; + } } } diff --git a/ui/data/com.xronlinux.BreezyDesktop.gschema.xml b/ui/data/com.xronlinux.BreezyDesktop.gschema.xml index 396f8d2..6704f6e 100644 --- a/ui/data/com.xronlinux.BreezyDesktop.gschema.xml +++ b/ui/data/com.xronlinux.BreezyDesktop.gschema.xml @@ -37,6 +37,15 @@ Shortcut to toggle follow mode. + + + period']]]> + + Move cursor to focused display + + Shortcut to move the cursor to the focused display. + + 1.05 diff --git a/ui/po/breezydesktop.pot b/ui/po/breezydesktop.pot index 0da859e..e1e7c9a 100644 --- a/ui/po/breezydesktop.pot +++ b/ui/po/breezydesktop.pot @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-16 13:02-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" @@ -27,33 +27,33 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 msgid "Set Focused Display Distance" msgstr "" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 msgid "Set All Displays Distance" msgstr "" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 msgid "Focused display" msgstr "" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 msgid "All displays" msgstr "" @@ -281,6 +281,7 @@ msgstr "" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "" @@ -399,110 +400,118 @@ msgstr "" msgid "Quickly toggle follow mode." msgstr "" -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 msgid "Remove virtual displays on disable" msgstr "" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 msgid "All displays follow mode" msgstr "" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " "movements, jumps ahead, or is very shaky." msgstr "" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" diff --git a/ui/po/de.po b/ui/po/de.po index f21c44a..378c99c 100644 --- a/ui/po/de.po +++ b/ui/po/de.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-15 16:43-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: 2024-08-02 20:54-0700\n" "Last-Translator: \n" "Language-Team: German \n" @@ -29,36 +29,36 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Diese Funktion wird von Ihrem Gerät derzeit nicht unterstützt." -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 #, fuzzy msgid "Set Focused Display Distance" msgstr "Display-Entfernung" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 #, fuzzy msgid "Set All Displays Distance" msgstr "Display-Entfernung" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 #, fuzzy msgid "Focused display" msgstr "Display-Entfernung" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 #, fuzzy msgid "All displays" msgstr "Gebogenes Display" @@ -291,6 +291,7 @@ msgstr "" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "Ändern" @@ -416,15 +417,23 @@ msgstr "Folgemodus-Tastenkombination umschalten" msgid "Quickly toggle follow mode." msgstr "Schnell den Folgemodus wechseln." -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "Erweiterte Einstellungen" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "Optimale Display-Konfiguration finden" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -432,87 +441,87 @@ msgstr "" "Ändern Sie die Display-Konfiguration der Brille automatisch zur maximalen " "Auflösung und besten Skalierung, wenn sie angeschlossen ist." -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "Höchste Bildwiederholrate verwenden" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Die Bildwiederholrate kann die Leistung beeinflussen, deaktivieren Sie dies, " "um sie manuell festzulegen." -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "Immer primäres Display" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Setzen Sie die Brille automatisch als primäres Display, wenn sie " "angeschlossen ist." -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Gebogenes Display" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 #, fuzzy msgid "All displays follow mode" msgstr "Gebogenes Display" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "Bewegungsvorausschau" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -523,15 +532,15 @@ msgstr "" "es sei denn, das virtuelle Display hängt hinter Ihren Kopfbewegungen " "hinterher, springt vor oder ist sehr wackelig." -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "Standard" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "Textskalierung" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "Text unter 1.0 skalieren simuliert ein höher aufgelöstes Display" diff --git a/ui/po/es.po b/ui/po/es.po index 34377e9..2b6ec5b 100644 --- a/ui/po/es.po +++ b/ui/po/es.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-15 16:43-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: 2024-08-02 20:55-0700\n" "Last-Translator: \n" "Language-Team: Spanish \n" @@ -28,26 +28,26 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Esta función no es compatible con tu dispositivo en este momento." -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 msgid "Set Focused Display Distance" msgstr "Ajusta Distancia de Enfoque de la Pantalla" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" "Usa un valor más cercano para que la pantalla se acerque cuando la mires." -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 msgid "Set All Displays Distance" msgstr "Ajusta Todas las Distancias de Pantalla" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" "Usa un valor más alejado para que las pantallas se alejen cuando apartes la " "vista." -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." @@ -55,11 +55,11 @@ msgstr "" "No se pueden agregar pantallas virtuales en esta máquina. Se requiere " "Wayland y xdg-desktop-portal." -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 msgid "Focused display" msgstr "Pantalla enfocada" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 msgid "All displays" msgstr "Todas las pantallas" @@ -293,6 +293,7 @@ msgstr "Ajusta cómo de cerca quieres que aparezcan las pantallas." #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "Cambiar" @@ -413,15 +414,23 @@ msgstr "Atajo para alternar el modo de seguimiento" msgid "Quickly toggle follow mode." msgstr "Activar el modo de seguimiento." -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "Configuración Avanzada" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "Encuentre la configuración de pantalla óptima" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -430,21 +439,21 @@ msgstr "" "obtener la máxima resolución y la mejor escalabilidad cuando estén " "enchufadas." -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "Utilizar la frecuencia de actualización más alta" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "La frecuencia de actualización puede afectar el rendimiento, deshabilite " "esto para configurarlo manualmente." -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "Centrar en la pantalla de las gafas" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." @@ -452,67 +461,67 @@ msgstr "" "Centrar el visor en la pantalla de las gafas, incluso si la pantalla no está " "en el centro." -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "Siempre como pantalla principal" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Automáticamente configurar las gafas como pantalla principal al enchufarse." -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 msgid "Remove virtual displays on disable" msgstr "Eliminar pantallas virtuales al desactivar" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" "Eliminar automáticamente las pantallas virtuales cuando se desactiva el " "efecto XR." -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "Activar la detección de toques múltiples" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" "Activa el doble toque para recentrar y el triple toque para recalibrar." -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 msgid "All displays follow mode" msgstr "Modo de seguimiento de todas las pantallas" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "El modo de seguimiento mueve todas las pantallas, no solo la enfocada." -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "Rastreo de movimiento de modo de seguimiento" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "Elige qué movimientos deben rastrearse en el modo de seguimiento." -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "Horizontal" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "Vertical" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "Inclinación/giro" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "Anticipación de movimiento" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -523,15 +532,15 @@ msgstr "" "predeterminado a menos que la pantalla virtual se retrase detrás de los " "movimientos de la cabeza, se adelante o sea muy inestable." -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "Predeterminado" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "Escalado de Texto" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" "Escalando el texto por debajo de 1.0 simulará una pantalla de mayor " diff --git a/ui/po/fr.po b/ui/po/fr.po index b0ebcd5..42c09f3 100644 --- a/ui/po/fr.po +++ b/ui/po/fr.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-15 16:43-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: 2024-08-02 20:54-0700\n" "Last-Translator: \n" "Language-Team: French \n" @@ -31,36 +31,36 @@ msgstr "" "Cette fonctionnalité n'est actuellement pas prise en charge par votre " "appareil." -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 #, fuzzy msgid "Set Focused Display Distance" msgstr "Distance d'affichage" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 #, fuzzy msgid "Set All Displays Distance" msgstr "Distance d'affichage" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 #, fuzzy msgid "Focused display" msgstr "Distance d'affichage" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 #, fuzzy msgid "All displays" msgstr "Affichage incurvé" @@ -293,6 +293,7 @@ msgstr "" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "Changer" @@ -417,15 +418,23 @@ msgstr "Raccourci de basculement du mode de suivi" msgid "Quickly toggle follow mode." msgstr "Basculer rapidement le mode de suivi." -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "Paramètres avancés" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "Trouver la configuration d'affichage optimale" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -434,87 +443,87 @@ msgstr "" "résolution maximale et une meilleure mise à l'échelle lorsque elles sont " "branchées." -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "Utiliser le taux de rafraîchissement le plus élevé" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Un taux de rafraîchissement élevé peut affecter les performances, désactivez-" "le pour le définir manuellement." -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "Affichage principal en permanence" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Définissez automatiquement les lunettes comme affichage principal " "lorsqu'elles sont branchées." -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Affichage incurvé" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 #, fuzzy msgid "All displays follow mode" msgstr "Affichage incurvé" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "Prédiction de mouvement" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -524,15 +533,15 @@ msgstr "" "le temps de rendu. Restez sur la valeur par défaut à moins que l'affichage " "virtuel ne soit lent, ne saute pas ou ne soit très instable." -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "Par défaut" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "Mise à l'échelle du texte" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" "Une mise à l'échelle du texte en dessous de 1.0 simulera un affichage de " diff --git a/ui/po/it.po b/ui/po/it.po index d37bccc..782d216 100644 --- a/ui/po/it.po +++ b/ui/po/it.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-15 16:43-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: 2024-08-02 21:14-0700\n" "Last-Translator: \n" "Language-Team: Italian \n" @@ -29,36 +29,36 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Questa funzione non è attualmente supportata sul tuo dispositivo." -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 #, fuzzy msgid "Set Focused Display Distance" msgstr "Distanza del display" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 #, fuzzy msgid "Set All Displays Distance" msgstr "Distanza del display" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 #, fuzzy msgid "Focused display" msgstr "Distanza del display" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 #, fuzzy msgid "All displays" msgstr "Display curvo" @@ -291,6 +291,7 @@ msgstr "" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "Cambia" @@ -416,15 +417,23 @@ msgstr "Scorciatoia per attivare/disattivare la modalità di inseguimento" msgid "Quickly toggle follow mode." msgstr "Attivazione/disattivazione rapida della modalità di inseguimento." -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "Impostazioni avanzate" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "Trova la configurazione ottimale del display" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -432,87 +441,87 @@ msgstr "" "Modifica automaticamente la configurazione del display degli occhiali per " "ottenere la massima risoluzione e la migliore scalabilità quando collegati." -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "Usa la frequenza di aggiornamento più elevata" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "La frequenza di aggiornamento potrebbe influire sulle prestazioni, " "disabilitala per impostarla manualmente." -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "Imposta sempre come display primario" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Imposta automaticamente gli occhiali come display primario quando sono " "collegati." -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Display curvo" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 #, fuzzy msgid "All displays follow mode" msgstr "Display curvo" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "Anticipo del movimento" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -523,15 +532,15 @@ msgstr "" "che il display virtuale non rimanga indietro rispetto ai tuoi movimenti, non " "salti in avanti o sia molto tremolante." -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "Predefinito" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "Ridimensionamento del testo" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" "Ridimensionando il testo sotto a 1.0 si simula una maggiore risoluzione del " diff --git a/ui/po/ja.po b/ui/po/ja.po index c4f6772..485f802 100644 --- a/ui/po/ja.po +++ b/ui/po/ja.po @@ -11,7 +11,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-15 16:43-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: 2024-08-02 20:55-0700\n" "Last-Translator: \n" "Language-Team: Japanese \n" @@ -31,33 +31,33 @@ msgstr "メガネを3Dモードに切り替え、表示の幅を2倍にします msgid "This feature is not currently supported for your device." msgstr "現在接続されているデバイスはこの機能に対応していません。" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 msgid "Set Focused Display Distance" msgstr "フォーカスされたディスプレイ距離" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "近くに設定すると見たディスプレイにズームインします。" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 msgid "Set All Displays Distance" msgstr "すべてのディスプレイ距離" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "遠くに設定すると視線の外れたディスプレイがズームアウトします。" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "仮想ディスプレイが追加できません。" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 msgid "Focused display" msgstr "フォーカスされたディスプレイ" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 msgid "All displays" msgstr "すべてのディスプレイ" @@ -287,6 +287,7 @@ msgstr "ディスプレイの表示距離を設定。" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "変更" @@ -407,15 +408,23 @@ msgstr "フォローモードの切り替え" msgid "Quickly toggle follow mode." msgstr "フォローモードのオン/オフをすばやく切り替えます。" -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "詳細設定" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "ディスプレイ設定を最適化する" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -423,21 +432,21 @@ msgstr "" "メガネ接続時、最大解像度と最適なスケーリングのためにディスプレイ設定を自動的" "に変更します。" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "最大のリフレッシュレートを使用する" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "リフレッシュレートはパフォーマンスに影響を与える可能性があります。手動で設定" "する場合は無効にしてください。" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "メガネのディスプレイを中央に" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." @@ -445,67 +454,67 @@ msgstr "" "ディスプレイが中央にない場合でも、表示域をメガネのディスプレイの中央に配置し" "ます。" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "常にプライマリディスプレイにする" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "メガネ接続時、自動的にプライマリディスプレイにします。" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 msgid "Remove virtual displays on disable" msgstr "無効時に仮想ディスプレイ削除" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "XRエフェクト無効時に仮想ディスプレイを自動的に削除します。" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "マルチタップ認識を有効化" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" "ダブルタップで中央へ移動、トリプルタップで再キャリブレーションを有効にしま" "す。" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 msgid "All displays follow mode" msgstr "全画面フォローモード" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "" "フォローモードはフォーカスされてるディスプレイだけでなく全ての画面が移動しま" "す。" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "フォローモード移動設定" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "フォローモードで追跡する方法を選択します。" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "水平" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "垂直" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "傾き・回転" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "動きの先読み" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -515,15 +524,15 @@ msgstr "" "ます。仮想ディスプレイが頭の動きに遅れたり、先に進んだり、非常に揺れたりする" "場合を除き、デフォルトのままで問題ありません。" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "デフォルト" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "テキストスケーリング" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" "テキストを1.0未満にスケーリングすると、高解像度ディスプレイをシミュレートしま" diff --git a/ui/po/mo/zh_CN/LC_MESSAGES/breezydesktop.mo b/ui/po/mo/zh_CN/LC_MESSAGES/breezydesktop.mo index c55149b218d67ed311357dd3d1cbae6b65bba680..97945008bd5f3f094339bd88df5335a1dffdc77c 100644 GIT binary patch delta 715 zcmXZZPe>GT6u|LE(V+BaL0yW3z=(o2cQqwQh+4!BcIXf&c<3NuEO_y-NRW;ME68r` zam6i`iH-K)pJ<85Kik#vBtd7Te&Ys91wqiw?`t0n^O^VN_ulW#Z-P`c^`_zZH$`M8 zCX&PBS43KI(R_)0#LF1LJ&fXS^w8^WdeZE`%j7%F+jxR_3blR~wf-5N!E(3w{}*hL z=p^wOFJXwicq-l;=oaexVZ4A7_z<&}|AV@5B+*zKEW{ zPZGL8yho%9hmlJrxkc~=YQYL>qjmF(*+3oO7*p$s^`H*$0QG~WQNO%|y3aey@A^Dw z$WV@->E8*hoTISV<`xMbgNQjiM0R{KtkVqph_atua~QS3 z8tVQ7^8!7@H&}#EW-3$YJ}>G(J|6m)^n(AX\n" "Language-Team: Polish \n" @@ -28,33 +28,33 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 msgid "Set Focused Display Distance" msgstr "" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 msgid "Set All Displays Distance" msgstr "" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 msgid "Focused display" msgstr "" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 msgid "All displays" msgstr "" @@ -282,6 +282,7 @@ msgstr "" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "" @@ -400,110 +401,118 @@ msgstr "" msgid "Quickly toggle follow mode." msgstr "" -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." msgstr "" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 msgid "Remove virtual displays on disable" msgstr "" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 msgid "All displays follow mode" msgstr "" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " "movements, jumps ahead, or is very shaky." msgstr "" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" diff --git a/ui/po/pt_BR.po b/ui/po/pt_BR.po index f5d70f0..3d6382f 100644 --- a/ui/po/pt_BR.po +++ b/ui/po/pt_BR.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-15 16:43-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: 2024-08-19 09:39-0700\n" "Last-Translator: \n" "Language-Team: Brazilian Portuguese \n" "Language-Team: Russian \n" @@ -29,36 +29,36 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Эта функция в настоящее время не поддерживается для вашего устройства." -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 #, fuzzy msgid "Set Focused Display Distance" msgstr "Расстояние дисплея" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 #, fuzzy msgid "Set All Displays Distance" msgstr "Расстояние дисплея" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 #, fuzzy msgid "Focused display" msgstr "Расстояние дисплея" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 #, fuzzy msgid "All displays" msgstr "Изогнутый дисплей" @@ -291,6 +291,7 @@ msgstr "" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "Изменить" @@ -414,15 +415,23 @@ msgstr "Сочетание клавиш для переключения режи msgid "Quickly toggle follow mode." msgstr "Быстро переключать режим следования." -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "Дополнительные настройки" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "Найти оптимальную конфигурацию дисплея" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -430,87 +439,87 @@ msgstr "" "Автоматически изменять конфигурацию дисплея очков для максимального " "разрешения и лучшей масштабирования при подключении." -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "Использовать высшую частоту обновления" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Частота обновления может повлиять на производительность, отключите это, " "чтобы установить ее вручную." -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "Всегда основной дисплей" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "" "Автоматически устанавливать очки в качестве основного дисплея при " "подключении." -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Изогнутый дисплей" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 #, fuzzy msgid "All displays follow mode" msgstr "Изогнутый дисплей" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "Прогнозирование движения" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -521,15 +530,15 @@ msgstr "" "виртуальный дисплей не отстает от движений вашей головы, не опережает или не " "очень трясётся." -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "По умолчанию" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" diff --git a/ui/po/sv.po b/ui/po/sv.po index de63a95..bc7a21c 100644 --- a/ui/po/sv.po +++ b/ui/po/sv.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-15 16:43-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: 2024-08-16 10:31-0700\n" "Last-Translator: \n" "Language-Team: Swedish \n" @@ -29,36 +29,36 @@ msgstr "" msgid "This feature is not currently supported for your device." msgstr "Din enhet stöder inte den här funktionen för tillfället." -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 #, fuzzy msgid "Set Focused Display Distance" msgstr "Avstånd till skärmen" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 #, fuzzy msgid "Set All Displays Distance" msgstr "Avstånd till skärmen" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 #, fuzzy msgid "Focused display" msgstr "Avstånd till skärmen" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 #, fuzzy msgid "All displays" msgstr "Böjd skärm" @@ -291,6 +291,7 @@ msgstr "" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "Ändra" @@ -415,15 +416,23 @@ msgstr "Växla följ läge kort" msgid "Quickly toggle follow mode." msgstr "Växla snabbt följ läge." -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "Avancerade inställningar" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "Hitta optimal konfiguration till skärmen" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -431,85 +440,85 @@ msgstr "" "Ändrar automatisk glasögonens skärmkonfiguration för maximal upplösning och " "bästa skälning när den är ansluten." -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "Använd högsta uppdateringsfrekvens" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Uppdateringsfrekvens kan påverka prestanda, inaktivera detta för att ställa " "in det manuellt." -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "Alltid primär skärm" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "Ställer automatisk glasögon som primär skärm när den är ansluten." -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Böjd skärm" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 #, fuzzy msgid "All displays follow mode" msgstr "Böjd skärm" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "Rörs förväntning" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -518,15 +527,15 @@ msgstr "" "Motverkar ingångsfördröjning genom förutsägelse av huvudrörelser.Behåll " "standardinställningen om inte skärmen skakar mycket eller rörsig konstigt." -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "Standard" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "Textskalning" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "Textskalning under 1.0 kommer att simulera en högre skärmupplösning" diff --git a/ui/po/uk_UA.po b/ui/po/uk_UA.po index c49f522..3169130 100644 --- a/ui/po/uk_UA.po +++ b/ui/po/uk_UA.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-15 16:43-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: 2024-08-17 10:08-0700\n" "Last-Translator: \n" "Language-Team: Ukrainian \n" @@ -28,36 +28,36 @@ msgstr "Переключає окуляри в режим «бок о бок» msgid "This feature is not currently supported for your device." msgstr "Ця функція наразі не підтримується на вашому пристрої." -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 #, fuzzy msgid "Set Focused Display Distance" msgstr "Відстань дисплея" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 #, fuzzy msgid "Set All Displays Distance" msgstr "Відстань дисплея" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 #, fuzzy msgid "Focused display" msgstr "Відстань дисплея" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 #, fuzzy msgid "All displays" msgstr "Викривлений дисплей" @@ -290,6 +290,7 @@ msgstr "" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "Змінити" @@ -414,15 +415,23 @@ msgstr "Сполучення клавіш для перемикання режи msgid "Quickly toggle follow mode." msgstr "Швидко перемикати режим слідування." -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "Додаткові налаштування" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "Знайти оптимальну конфігурацію дисплея" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." @@ -430,85 +439,85 @@ msgstr "" "Автоматично змінює конфігурацію дисплея окулярів для максимальної роздільної " "здатності і найкращого масштабування при підключенні." -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "Використовувати найвищу частоту оновлення" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "" "Частота оновлення може вплинути на продуктивність, вимкніть це, щоб " "встановити її вручну." -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "Завжди основний дисплей" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "Автоматично встановлює окуляри як основний дисплей при підключенні." -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 #, fuzzy msgid "Remove virtual displays on disable" msgstr "Викривлений дисплей" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 #, fuzzy msgid "All displays follow mode" msgstr "Викривлений дисплей" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "Прогнозування руху" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -519,15 +528,15 @@ msgstr "" "віртуальний дисплей відстає від рухів вашої голови, випереджає або дуже " "тремтить." -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "За замовчуванням" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "" diff --git a/ui/po/zh_CN.po b/ui/po/zh_CN.po index 73bf651..2dc7d4b 100644 --- a/ui/po/zh_CN.po +++ b/ui/po/zh_CN.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2025-03-15 16:43-0700\n" +"POT-Creation-Date: 2025-03-16 22:26-0700\n" "PO-Revision-Date: 2024-08-02 20:55-0700\n" "Last-Translator: \n" "Language-Team: Chinese (simplified) \n" @@ -26,33 +26,33 @@ msgstr "切换到并排模式,并将显示宽度翻倍。" msgid "This feature is not currently supported for your device." msgstr "您的设备目前不支援此功能。" -#: src/connecteddevice.py:142 +#: src/connecteddevice.py:145 msgid "Set Focused Display Distance" msgstr "设定注视中的屏幕的距离" -#: src/connecteddevice.py:143 +#: src/connecteddevice.py:146 msgid "Use a closer value so the display zooms in when you look at it." msgstr "近的数值会将您所看向的屏幕放大" -#: src/connecteddevice.py:150 +#: src/connecteddevice.py:153 msgid "Set All Displays Distance" msgstr "设定所有屏幕的距离" -#: src/connecteddevice.py:151 +#: src/connecteddevice.py:154 msgid "Use a farther value so the displays are zoomed out when you look away." msgstr "远的数值会将您所看向的屏幕缩小" -#: src/connecteddevice.py:267 +#: src/connecteddevice.py:270 msgid "" "Unable to add virtual displays on this machine. Wayland and xdg-desktop-" "portal are required." msgstr "无法增加模拟显示。需要安装xdg-desktop-portal和Wayland" -#: src/connecteddevice.py:301 +#: src/connecteddevice.py:304 msgid "Focused display" msgstr "注视中的屏幕" -#: src/connecteddevice.py:307 +#: src/connecteddevice.py:310 msgid "All displays" msgstr "所有的屏幕" @@ -282,6 +282,7 @@ msgstr "设定您所希望屏幕离你的距离有多近" #: src/gtk/connected-device.ui:200 src/gtk/connected-device.ui:221 #: src/gtk/connected-device.ui:413 src/gtk/connected-device.ui:442 #: src/gtk/connected-device.ui:471 src/gtk/connected-device.ui:500 +#: src/gtk/connected-device.ui:529 msgid "Change" msgstr "更改" @@ -400,95 +401,103 @@ msgstr "切换跟随模式快捷键" msgid "Quickly toggle follow mode." msgstr "快速切换跟随模式。" -#: src/gtk/connected-device.ui:516 src/gtk/connected-device.ui:526 +#: src/gtk/connected-device.ui:509 +msgid "Summon mouse cursor shortcut" +msgstr "" + +#: src/gtk/connected-device.ui:510 +msgid "Bring the mouse cursor to the center of the focused display." +msgstr "" + +#: src/gtk/connected-device.ui:545 src/gtk/connected-device.ui:555 msgid "Advanced Settings" msgstr "高级设定" -#: src/gtk/connected-device.ui:530 +#: src/gtk/connected-device.ui:559 msgid "Find optimal display config" msgstr "寻找最佳显示设定" -#: src/gtk/connected-device.ui:531 +#: src/gtk/connected-device.ui:560 msgid "" "Automatically modify the glasses display configuration for maximum " "resolution and best scaling when plugged in." msgstr "连接时,可以自动修改眼镜显示设定以表现出最大解析度和最佳的对比。" -#: src/gtk/connected-device.ui:541 +#: src/gtk/connected-device.ui:570 msgid "Use highest refresh rate" msgstr "使用最高刷新率" -#: src/gtk/connected-device.ui:542 +#: src/gtk/connected-device.ui:571 msgid "Refresh rate may affect performance, disable this to set it manually." msgstr "刷新率可能会影响性能,禁用此功能即可手动设置。" -#: src/gtk/connected-device.ui:552 +#: src/gtk/connected-device.ui:581 msgid "Center on glasses' display" msgstr "视口眼镜屏幕固定" -#: src/gtk/connected-device.ui:553 +#: src/gtk/connected-device.ui:582 msgid "" "Center the viewport on the glasses' display, even if the display is not in " "the middle." msgstr "将眼镜视口对齐眼镜的主要屏幕, 即便此屏幕不在正中间" -#: src/gtk/connected-device.ui:563 +#: src/gtk/connected-device.ui:592 msgid "Always primary display" msgstr "每次设置为主要显示" -#: src/gtk/connected-device.ui:564 +#: src/gtk/connected-device.ui:593 msgid "Automatically set the glasses as the primary display when plugged in." msgstr "连接时,自动将眼镜设置为主要显示。" -#: src/gtk/connected-device.ui:574 +#: src/gtk/connected-device.ui:603 msgid "Remove virtual displays on disable" msgstr "自动模拟屏幕删除" -#: src/gtk/connected-device.ui:575 +#: src/gtk/connected-device.ui:604 msgid "Automatically remove virtual displays when the XR effect is disabled." msgstr "XR效果关闭时自动删除所有模拟屏幕" -#: src/gtk/connected-device.ui:585 +#: src/gtk/connected-device.ui:614 msgid "Enable multi-tap detection" msgstr "开启多点触控检测" -#: src/gtk/connected-device.ui:586 +#: src/gtk/connected-device.ui:615 msgid "Enables double-tap to recenter and triple-tap to recalibrate." msgstr "打开双击重新定位和三击重新校准手势" -#: src/gtk/connected-device.ui:596 +#: src/gtk/connected-device.ui:625 msgid "All displays follow mode" msgstr "全屏幕跟随模式" -#: src/gtk/connected-device.ui:597 +#: src/gtk/connected-device.ui:626 msgid "Follow mode moves all displays, not just the focused one." msgstr "让跟随模式移动所有的屏幕而不只是注视中的屏幕" -#: src/gtk/connected-device.ui:613 +#: src/gtk/connected-device.ui:642 msgid "Follow mode movement tracking" msgstr "跟随模式感应" -#: src/gtk/connected-device.ui:614 +#: src/gtk/connected-device.ui:643 msgid "Choose which movements should be tracked in follow mode." msgstr "选择那一些动作会被感应到" -#: src/gtk/connected-device.ui:629 +#: src/gtk/connected-device.ui:658 msgid "Horizontal" msgstr "水平动作" -#: src/gtk/connected-device.ui:649 +#: src/gtk/connected-device.ui:678 msgid "Vertical" msgstr "垂直动作" -#: src/gtk/connected-device.ui:669 +#: src/gtk/connected-device.ui:698 msgid "Tilt/roll" msgstr "倾斜及滚转动作" -#: src/gtk/connected-device.ui:687 +#: src/gtk/connected-device.ui:716 msgid "Movement look-ahead" msgstr "移动预测" -#: src/gtk/connected-device.ui:688 +#: src/gtk/connected-device.ui:717 msgid "" "Counteracts input lag by predicting head-tracking position ahead of render " "time. Stick with default unless virtual display drags behind your head " @@ -497,15 +506,15 @@ msgstr "" "透过预测头部追踪位置,提前于渲染时间进行预测来抵消输入延迟。除非虚拟显示滞后" "于头部,提前跳动或非常抖动,请尽量使用默认设置。" -#: src/gtk/connected-device.ui:706 +#: src/gtk/connected-device.ui:735 msgid "Default" msgstr "默认" -#: src/gtk/connected-device.ui:718 +#: src/gtk/connected-device.ui:747 msgid "Text Scaling" msgstr "字体大小比例" -#: src/gtk/connected-device.ui:719 +#: src/gtk/connected-device.ui:748 msgid "Scaling text below 1.0 will simulate a higher resolution display" msgstr "字体缩放小于1.0,将模拟解析度更高的显示效果" diff --git a/ui/src/connecteddevice.py b/ui/src/connecteddevice.py index 28e8bce..ff4026a 100644 --- a/ui/src/connecteddevice.py +++ b/ui/src/connecteddevice.py @@ -56,6 +56,8 @@ class ConnectedDevice(Gtk.Box): toggle_display_distance_shortcut_label = Gtk.Template.Child() reassign_toggle_follow_shortcut_button = Gtk.Template.Child() toggle_follow_shortcut_label = Gtk.Template.Child() + reassign_cursor_to_focused_display_shortcut_button = Gtk.Template.Child() + cursor_to_focused_display_shortcut_label = Gtk.Template.Child() headset_display_as_viewport_center_switch = Gtk.Template.Child() headset_as_primary_switch = Gtk.Template.Child() remove_virtual_displays_on_disable_switch = Gtk.Template.Child() @@ -132,7 +134,8 @@ class ConnectedDevice(Gtk.Box): [self.reassign_toggle_xr_effect_shortcut_button, self.toggle_xr_effect_shortcut_label], [self.reassign_recenter_display_shortcut_button, self.recenter_display_shortcut_label], [self.reassign_toggle_display_distance_shortcut_button, self.toggle_display_distance_shortcut_label], - [self.reassign_toggle_follow_shortcut_button, self.toggle_follow_shortcut_label] + [self.reassign_toggle_follow_shortcut_button, self.toggle_follow_shortcut_label], + [self.reassign_cursor_to_focused_display_shortcut_button, self.cursor_to_focused_display_shortcut_label] ]) self.change_focused_display_distance_button.connect('clicked', diff --git a/ui/src/gtk/connected-device.ui b/ui/src/gtk/connected-device.ui index 9a465a6..df5ed11 100644 --- a/ui/src/gtk/connected-device.ui +++ b/ui/src/gtk/connected-device.ui @@ -504,6 +504,35 @@ + + + Summon mouse cursor shortcut + Bring the mouse cursor to the center of the focused display. + 2 + + + 30 + 30 + + + 3 + + + + + + + cursor-to-focused-display-shortcut + 3 + Change + + + + + + From 6cba049dc4c4a19b1af5014480f4f7f382708f27 Mon Sep 17 00:00:00 2001 From: wheaney <42350981+wheaney@users.noreply.github.com> Date: Mon, 17 Mar 2025 10:15:04 -0700 Subject: [PATCH 4/6] Update backports for the new mouse cursor shortcut --- gnome/backports/gnome-44-max | 2 +- gnome/backports/gnome-45 | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/gnome/backports/gnome-44-max b/gnome/backports/gnome-44-max index 1445122..b12a567 160000 --- a/gnome/backports/gnome-44-max +++ b/gnome/backports/gnome-44-max @@ -1 +1 @@ -Subproject commit 144512201119b6b0522e59a44c7f83461f77f80d +Subproject commit b12a567a3402b67aeb273aef60d14cbd3202ca83 diff --git a/gnome/backports/gnome-45 b/gnome/backports/gnome-45 index ce6f7dd..29218cd 160000 --- a/gnome/backports/gnome-45 +++ b/gnome/backports/gnome-45 @@ -1 +1 @@ -Subproject commit ce6f7dd7e473100cf15d97e657cff54d0c17f62d +Subproject commit 29218cd4f226f7bf63f2e1bb84f3facb38ef6f43 From 618dceaf10026c61f38cf357c48f18ccca1dffa1 Mon Sep 17 00:00:00 2001 From: wheaney <42350981+wheaney@users.noreply.github.com> Date: Mon, 17 Mar 2025 10:33:47 -0700 Subject: [PATCH 5/6] Fix gnome-44-max backport branch --- gnome/backports/gnome-44-max | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gnome/backports/gnome-44-max b/gnome/backports/gnome-44-max index b12a567..dd10f4e 160000 --- a/gnome/backports/gnome-44-max +++ b/gnome/backports/gnome-44-max @@ -1 +1 @@ -Subproject commit b12a567a3402b67aeb273aef60d14cbd3202ca83 +Subproject commit dd10f4ee505779467488258b95995580aab970a8 From fb38c89e4173166adf8dcc829324379d823e86df Mon Sep 17 00:00:00 2001 From: wheaney <42350981+wheaney@users.noreply.github.com> Date: Wed, 19 Mar 2025 12:22:15 -0700 Subject: [PATCH 6/6] Optimize monitor focus checking, fix toggle XR effect not working when disabled, v2.1.1 --- VERSION | 2 +- gnome/src/extension.js | 5 +- gnome/src/virtualdisplayeffect.js | 3 +- gnome/src/virtualdisplaysactor.js | 103 ++++++++++++++++++------------ 4 files changed, 67 insertions(+), 46 deletions(-) diff --git a/VERSION b/VERSION index 50aea0e..7c32728 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -2.1.0 \ No newline at end of file +2.1.1 \ No newline at end of file diff --git a/gnome/src/extension.js b/gnome/src/extension.js index 852e23e..6e5fb88 100644 --- a/gnome/src/extension.js +++ b/gnome/src/extension.js @@ -94,6 +94,8 @@ export default class BreezyDesktopExtension extends Extension { } } + this._add_settings_keybinding('toggle-xr-effect-shortcut', this._toggle_xr_effect.bind(this)); + this._setup(); } catch (e) { Globals.logger.log(`[ERROR] BreezyDesktopExtension enable ${e.message}\n${e.stack}`); @@ -306,7 +308,6 @@ export default class BreezyDesktopExtension extends Extension { Meta.disable_unredirect_for_display(global.display); } - this._add_settings_keybinding('toggle-xr-effect-shortcut', this._toggle_xr_effect.bind(this)); this._add_settings_keybinding('recenter-display-shortcut', this._recenter_display.bind(this)); this._add_settings_keybinding('toggle-display-distance-shortcut', this._virtual_displays_actor._change_distance.bind(this._virtual_displays_actor)); this._add_settings_keybinding('toggle-follow-shortcut', this._toggle_follow_mode.bind(this)); @@ -558,7 +559,6 @@ export default class BreezyDesktopExtension extends Extension { if (Globals.data_stream.smooth_follow_enabled) this._toggle_follow_mode(); - Main.wm.removeKeybinding('toggle-xr-effect-shortcut'); Main.wm.removeKeybinding('recenter-display-shortcut'); Main.wm.removeKeybinding('toggle-display-distance-shortcut'); Main.wm.removeKeybinding('toggle-follow-shortcut'); @@ -644,6 +644,7 @@ export default class BreezyDesktopExtension extends Extension { Globals.data_stream.disconnect(this._breezy_desktop_running_connection); this._breezy_desktop_running_connection = null; } + Main.wm.removeKeybinding('toggle-xr-effect-shortcut'); Gio.Settings.unbind(this.settings, 'debug'); Gio.Settings.unbind(this.settings, 'use-optimal-monitor-config'); Gio.Settings.unbind(this.settings, 'headset-as-primary'); diff --git a/gnome/src/virtualdisplayeffect.js b/gnome/src/virtualdisplayeffect.js index eac98f2..0cb8a16 100644 --- a/gnome/src/virtualdisplayeffect.js +++ b/gnome/src/virtualdisplayeffect.js @@ -329,8 +329,9 @@ export const VirtualDisplayEffect = GObject.registerClass({ if (this._follow_ease_timeline?.is_playing()) this._follow_ease_timeline.stop(); + const ease_to_focus = this.smooth_follow_enabled && this._is_focused(); const from = this._current_follow_ease_progress; - const to = this.smooth_follow_enabled && this._is_focused() ? 1.0 : 0.0; + const to = ease_to_focus ? 1.0 : 0.0; const toggleTime = this.smooth_follow_toggle_epoch_ms === 0 ? Date.now() : this.smooth_follow_toggle_epoch_ms; // would have been a slight delay between request and slerp actually starting diff --git a/gnome/src/virtualdisplaysactor.js b/gnome/src/virtualdisplaysactor.js index b4eecbc..c695d4b 100644 --- a/gnome/src/virtualdisplaysactor.js +++ b/gnome/src/virtualdisplaysactor.js @@ -19,6 +19,34 @@ const FOCUS_THRESHOLD = 0.95 / 2.0; // if we leave the monitor with some margin, unfocus even if no other monitor is in focus const UNFOCUS_THRESHOLD = 1.1 / 2.0; +// returns how far the look vector is from the center of the monitor, as a percentage of the monitor's width +function getMonitorDistance(fovDetails, lookUpPixels, lookWestPixels, monitorVector, monitorDetails, upAngleToLength, westAngleToLength) { + const monitorAspectRatio = monitorDetails.width / monitorDetails.height; + + // weight the up distance by the aspect ratio + const vectorUpPixels = upAngleToLength( + fovDetails.defaultDistanceVerticalRadians, + fovDetails.heightPixels, + fovDetails.completeScreenDistancePixels, + monitorVector[2], + monitorVector[0] + ); + const upDeltaPixels = (lookUpPixels - vectorUpPixels) * monitorAspectRatio; + + const vectorWestPixels = westAngleToLength( + fovDetails.defaultDistanceHorizontalRadians, + fovDetails.widthPixels, + fovDetails.completeScreenDistancePixels, + monitorVector[1], + monitorVector[0] + ); + const westDeltaPixels = lookWestPixels - vectorWestPixels; + const totalDeltaPixels = Math.sqrt(upDeltaPixels * upDeltaPixels + westDeltaPixels * westDeltaPixels); + + // threshold is a percentage of width, and height was already properly weighted + return totalDeltaPixels / monitorDetails.width; +} + /** * Find the vector in the array that's closest to the quaternion rotation * @@ -26,12 +54,11 @@ const UNFOCUS_THRESHOLD = 1.1 / 2.0; * @param {number[][]} monitorVectors - Array of monitor vectors [x, y, z] to search from * @param {number} currentFocusedIndex - Index of the currently focused monitor * @param {number} focusedMonitorDistance - Distance to the focused monitor, < 1.0 if zoomed in - * @param {boolean} smoothFollowEnabled - If true, always keep the current monitor in focus or choose the closest * @param {Object} fovDetails - Contains reference widthPixels, heightPixels, horizontal and vertical radians, and pixel distance to the center of the screen * @param {Object[]} monitorsDetails - Contains x, y, width, height (coordinates from top-left) for each monitor * @returns {number} Index of the closest vector, if it surpasses the previous closest index by a certain margin, otherwise the previous index */ -function findFocusedMonitor(quaternion, monitorVectors, currentFocusedIndex, focusedMonitorDistance, smoothFollowEnabled, fovDetails, monitorsDetails) { +function findFocusedMonitor(quaternion, monitorVectors, currentFocusedIndex, focusedMonitorDistance, fovDetails, monitorsDetails) { const lookVector = [1.0, 0.0, 0.0]; // NWU vector pointing to the center of the screen const rotatedLookVector = applyQuaternionToVector(lookVector, quaternion); @@ -56,55 +83,46 @@ function findFocusedMonitor(quaternion, monitorVectors, currentFocusedIndex, foc let closestIndex = -1; let closestDistance = Infinity; - let currentFocusedDistance = Infinity; + + // the currently focused monitor is the most likely to be the closest, check it first and exit early if it is + if (currentFocusedIndex !== -1) { + const focusedDistance = getMonitorDistance( + fovDetails, + lookUpPixels, + lookWestPixels, + monitorVectors[currentFocusedIndex], + monitorsDetails[currentFocusedIndex], + upConversionFns.angleToLength, + westConversionFns.angleToLength + ) * focusedMonitorDistance; + + if (focusedDistance < UNFOCUS_THRESHOLD) return currentFocusedIndex; + } // find the vector closest to the rotated look vector monitorVectors.forEach((monitorVector, index) => { - const monitor = monitorsDetails[index]; - const monitorAspectRatio = monitor.width / monitor.height; + if (index === currentFocusedIndex) return; - // weight the up distance by the aspect ratio - const vectorUpPixels = upConversionFns.angleToLength( - fovDetails.defaultDistanceVerticalRadians, - fovDetails.heightPixels, - fovDetails.completeScreenDistancePixels, - monitorVector[2], - monitorVector[0] + const distance = getMonitorDistance( + fovDetails, + lookUpPixels, + lookWestPixels, + monitorVector, + monitorsDetails[index], + upConversionFns.angleToLength, + westConversionFns.angleToLength ); - const upDeltaPixels = (lookUpPixels - vectorUpPixels) * monitorAspectRatio; - const vectorWestPixels = westConversionFns.angleToLength( - fovDetails.defaultDistanceHorizontalRadians, - fovDetails.widthPixels, - fovDetails.completeScreenDistancePixels, - monitorVector[1], - monitorVector[0] - ); - const westDeltaPixels = lookWestPixels - vectorWestPixels; - const totalDeltaPixels = Math.sqrt(upDeltaPixels * upDeltaPixels + westDeltaPixels * westDeltaPixels); - - // threshold is a percentage of width, and height was already properly weighted - const distanceFromCenterSizeRatio = totalDeltaPixels / monitor.width; - - if (currentFocusedIndex === index) { - currentFocusedDistance = distanceFromCenterSizeRatio * focusedMonitorDistance; - } - - if (distanceFromCenterSizeRatio < closestDistance) { + if (distance < closestDistance) { closestIndex = index; - closestDistance = distanceFromCenterSizeRatio; + closestDistance = distance; } }); - const keepCurrent = currentFocusedIndex !== -1 && (smoothFollowEnabled || currentFocusedDistance < UNFOCUS_THRESHOLD); - if (!keepCurrent) { - if (smoothFollowEnabled || closestDistance < FOCUS_THRESHOLD) return closestIndex; + if (closestDistance < FOCUS_THRESHOLD) return closestIndex; - // neither the current nor the closest will take focus, unfocus all displays - return -1; - } - - return currentFocusedIndex; + // neither the current nor the closest will take focus, unfocus all displays + return -1; } /*** @@ -761,7 +779,9 @@ export const VirtualDisplaysActor = GObject.registerClass({ if (this.show_banner) { this.focused_monitor_index = -1; this.focused_monitor_details = null; - } else if (this.imu_snapshots && (!this._smooth_follow_slerping || this.focused_monitor_index === -1)) { + } else if (this.imu_snapshots && + (!this.smooth_follow_enabled || this.focused_monitor_index === -1) && + (!this._smooth_follow_slerping || this.focused_monitor_index === -1)) { // if smooth follow is enabled, use the origin IMU data to inform the initial focused monitor // since it reflects where the user is looking in relation to the original monitor positions const currentPoseQuat = this.smooth_follow_enabled ? @@ -773,7 +793,6 @@ export const VirtualDisplaysActor = GObject.registerClass({ this.monitor_placements.map(monitorVectors => monitorVectors.centerLook), this.focused_monitor_index, this.display_distance / this._display_distance_default(), - this.smooth_follow_enabled, this.fov_details, this._all_monitors );