improv(input): revise touchpad settings and descriptions
This commit is contained in:
parent
cf0c6494c3
commit
b39092f146
13 changed files with 113 additions and 145 deletions
39
Cargo.lock
generated
39
Cargo.lock
generated
|
|
@ -2143,16 +2143,15 @@ dependencies = [
|
|||
|
||||
[[package]]
|
||||
name = "generator"
|
||||
version = "0.7.6"
|
||||
version = "0.7.5"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "b5b25e5b3e733153bcab35ee4671b46604b42516163cae442d1601cb716f2ac5"
|
||||
checksum = "5cc16584ff22b460a382b7feec54b23d2908d858152e5739a120b949293bd74e"
|
||||
dependencies = [
|
||||
"cc",
|
||||
"cfg-if",
|
||||
"libc",
|
||||
"log",
|
||||
"rustversion",
|
||||
"windows 0.53.0",
|
||||
"windows 0.48.0",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
|
|
@ -6059,21 +6058,20 @@ checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f"
|
|||
|
||||
[[package]]
|
||||
name = "windows"
|
||||
version = "0.52.0"
|
||||
version = "0.48.0"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "e48a53791691ab099e5e2ad123536d0fff50652600abaf43bbf952894110d0be"
|
||||
checksum = "e686886bc078bc1b0b600cac0147aadb815089b6e4da64016cbd754b6342700f"
|
||||
dependencies = [
|
||||
"windows-core 0.52.0",
|
||||
"windows-targets 0.52.4",
|
||||
"windows-targets 0.48.5",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "windows"
|
||||
version = "0.53.0"
|
||||
version = "0.52.0"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "efc5cf48f83140dcaab716eeaea345f9e93d0018fb81162753a3f76c3397b538"
|
||||
checksum = "e48a53791691ab099e5e2ad123536d0fff50652600abaf43bbf952894110d0be"
|
||||
dependencies = [
|
||||
"windows-core 0.53.0",
|
||||
"windows-core",
|
||||
"windows-targets 0.52.4",
|
||||
]
|
||||
|
||||
|
|
@ -6086,25 +6084,6 @@ dependencies = [
|
|||
"windows-targets 0.52.4",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "windows-core"
|
||||
version = "0.53.0"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "9dcc5b895a6377f1ab9fa55acedab1fd5ac0db66ad1e6c7f47e28a22e446a5dd"
|
||||
dependencies = [
|
||||
"windows-result",
|
||||
"windows-targets 0.52.4",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "windows-result"
|
||||
version = "0.1.0"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "cd19df78e5168dfb0aedc343d1d1b8d422ab2db6756d2dc3fef75035402a3f64"
|
||||
dependencies = [
|
||||
"windows-targets 0.52.4",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "windows-sys"
|
||||
version = "0.48.0"
|
||||
|
|
|
|||
15
Cargo.toml
15
Cargo.toml
|
|
@ -27,12 +27,17 @@ git = "https://github.com/smithay/client-toolkit/"
|
|||
package = "smithay-client-toolkit"
|
||||
rev = "2e9bf9f"
|
||||
|
||||
[profile.dev]
|
||||
debug = true
|
||||
lto = false
|
||||
opt-level = 3
|
||||
|
||||
[profile.release]
|
||||
opt-level = 3
|
||||
|
||||
# For development and testing purposes
|
||||
# [patch.'https://github.com/pop-os/libcosmic']
|
||||
# # libcosmic = { git = "https://github.com/pop-os/libcosmic?rev=slider", branch = "slider" }
|
||||
# # cosmic-config = { git = "https://github.com/pop-os/libcosmic?rev=slider", branch = "slider" }
|
||||
# libcosmic = { path = "../libcosmic" }
|
||||
# cosmic-config = { path = "../libcosmic/cosmic-config" }
|
||||
#[patch.'https://github.com/pop-os/libcosmic']
|
||||
#libcosmic = { git = "https://github.com/pop-os/libcosmic?rev=slider", branch = "slider" }
|
||||
#cosmic-config = { git = "https://github.com/pop-os/libcosmic?rev=slider", branch = "slider" }
|
||||
#libcosmic = { path = "../libcosmic" }
|
||||
#cosmic-config = { path = "../libcosmic/cosmic-config" }
|
||||
|
|
|
|||
|
|
@ -17,7 +17,7 @@ cosmic-settings-time = { path = "../pages/time" }
|
|||
derivative = "2.2.0"
|
||||
derive_setters = "0.1.6"
|
||||
dirs = "5.0.1"
|
||||
generator = "0.7.5"
|
||||
generator = "=0.7.5"
|
||||
i18n-embed-fl = "0.7.0"
|
||||
itertools = "0.12.0"
|
||||
libcosmic = {workspace = true}
|
||||
|
|
|
|||
1
app/profile.json
Normal file
1
app/profile.json
Normal file
File diff suppressed because one or more lines are too long
|
|
@ -122,7 +122,7 @@ fn popover_button(input_source: &InputSource, expanded: bool) -> cosmic::Element
|
|||
.on_press(on_press);
|
||||
|
||||
if expanded {
|
||||
cosmic::widget::popover(button, popover_menu()).into()
|
||||
cosmic::widget::popover(button).popup(popover_menu()).into()
|
||||
} else {
|
||||
button.into()
|
||||
}
|
||||
|
|
|
|||
|
|
@ -7,7 +7,8 @@ use cosmic::{
|
|||
};
|
||||
use cosmic_comp_config::{
|
||||
input::{
|
||||
AccelConfig, AccelProfile, InputConfig, ScrollConfig, ScrollMethod, TapButtonMap, TapConfig,
|
||||
AccelConfig, AccelProfile, ClickMethod, InputConfig, ScrollConfig, ScrollMethod,
|
||||
TapButtonMap, TapConfig,
|
||||
},
|
||||
XkbConfig,
|
||||
};
|
||||
|
|
@ -23,9 +24,11 @@ crate::cache_dynamic_lazy! {
|
|||
static ACCELERATION_DESC: String = fl!("acceleration-desc");
|
||||
static DISABLE_WHILE_TYPING: String = fl!("disable-while-typing");
|
||||
static PRIMARY_BUTTON: String = fl!("primary-button");
|
||||
static SCROLLING_EDGE: String = fl!("scrolling", "edge");
|
||||
static SCROLLING_NATURAL_DESC: String = fl!("scrolling", "natural-desc");
|
||||
static SCROLLING_NATURAL: String = fl!("scrolling", "natural");
|
||||
static SCROLLING_SPEED: String = fl!("scrolling", "speed");
|
||||
static SCROLLING_TWO_FINGER: String = fl!("scrolling", "two-finger");
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug)]
|
||||
|
|
@ -35,11 +38,11 @@ pub enum Message {
|
|||
DisableWhileTyping(bool, bool),
|
||||
ExpandInputSourcePopover(Option<String>),
|
||||
OpenSpecialCharacterDialog(keyboard::SpecialKey),
|
||||
PinchToZoom(bool),
|
||||
PrimaryButtonSelected(cosmic::widget::segmented_button::Entity, bool),
|
||||
SetAcceleration(bool, bool),
|
||||
SetMouseSpeed(f64, bool),
|
||||
SetNaturalScroll(bool, bool),
|
||||
SetSecondaryClickBehavior(Option<ClickMethod>, bool),
|
||||
SetScrollFactor(f64, bool),
|
||||
SetScrollMethod(Option<ScrollMethod>, bool),
|
||||
SpecialCharacterSelect(Option<&'static str>),
|
||||
|
|
@ -154,6 +157,12 @@ impl Page {
|
|||
.natural_scroll = Some(enabled);
|
||||
}),
|
||||
|
||||
Message::SetSecondaryClickBehavior(click_method, touchpad) => {
|
||||
self.update_input(touchpad, |x| {
|
||||
x.click_method = click_method;
|
||||
})
|
||||
}
|
||||
|
||||
Message::SetScrollFactor(value, touchpad) => self.update_input(touchpad, |x| {
|
||||
x.scroll_config
|
||||
.get_or_insert(ScrollConfig::default())
|
||||
|
|
@ -231,8 +240,6 @@ impl Page {
|
|||
}
|
||||
}
|
||||
|
||||
Message::PinchToZoom(_enabled) => {}
|
||||
|
||||
Message::TapToClick(enabled) => {
|
||||
self.update_input(true, |conf| {
|
||||
conf.tap_config
|
||||
|
|
|
|||
|
|
@ -1,7 +1,7 @@
|
|||
use cosmic::iced::Alignment;
|
||||
use cosmic::widget::{self, row, settings, text};
|
||||
use cosmic::{Apply, Element};
|
||||
use cosmic_comp_config::input::{AccelProfile, ScrollMethod};
|
||||
use cosmic_comp_config::input::{AccelProfile, ClickMethod, ScrollMethod};
|
||||
use cosmic_settings_page::Section;
|
||||
use cosmic_settings_page::{self as page, section};
|
||||
use slotmap::SlotMap;
|
||||
|
|
@ -9,14 +9,12 @@ use slotmap::SlotMap;
|
|||
use super::Message;
|
||||
|
||||
crate::cache_dynamic_lazy! {
|
||||
static EDGE_SCROLLING_DESC: String = fl!("edge-scrolling", "desc");
|
||||
static EDGE_SCROLLING: String = fl!("edge-scrolling");
|
||||
static TWO_FINGER_SCROLLING: String = fl!("two-finger-scrolling");
|
||||
static PINCH_TO_ZOOM_DESC: String = fl!("pinch-to-zoom", "desc");
|
||||
static PINCH_TO_ZOOM: String = fl!("pinch-to-zoom");
|
||||
static TAP_TO_CLICK_DESC: String = fl!("tap-to-click", "desc");
|
||||
static CLICK_BEHAVIOR_CLICK_FINGER: String = fl!("click-behavior", "click-finger");
|
||||
static CLICK_BEHAVIOR_BUTTON_AREAS: String = fl!("click-behavior", "button-areas");
|
||||
|
||||
static TAP_TO_CLICK: String = fl!("tap-to-click");
|
||||
static TAPPING_AND_PINCHING: String = fl!("tapping-and-pinching");
|
||||
static TAP_TO_CLICK_DESC: String = fl!("tap-to-click", "desc");
|
||||
|
||||
static TOUCHPAD_ACCELERAION: String = fl!("touchpad", "acceleration");
|
||||
static TOUCHPAD_SPEED: String = fl!("touchpad", "speed");
|
||||
|
||||
|
|
@ -42,7 +40,7 @@ impl page::Page<crate::pages::Message> for Page {
|
|||
) -> Option<page::Content> {
|
||||
Some(vec![
|
||||
sections.insert(touchpad()),
|
||||
sections.insert(tapping_and_pinching()),
|
||||
sections.insert(click_behavior()),
|
||||
sections.insert(scrolling()),
|
||||
sections.insert(swiping()),
|
||||
])
|
||||
|
|
@ -86,11 +84,11 @@ fn touchpad() -> Section<crate::pages::Message> {
|
|||
+ 1.0)
|
||||
* 50.0;
|
||||
|
||||
let slider = widget::slider(10.0..=90.0, value, |value| {
|
||||
let slider = widget::slider(10.0..=80.0, value, |value| {
|
||||
Message::SetMouseSpeed((value / 50.0) - 1.0, true)
|
||||
})
|
||||
.width(250.0)
|
||||
.breakpoints(&[50.0]);
|
||||
.breakpoints(&[45.0]);
|
||||
|
||||
row::with_capacity(2)
|
||||
.align_items(Alignment::Center)
|
||||
|
|
@ -121,21 +119,51 @@ fn touchpad() -> Section<crate::pages::Message> {
|
|||
})
|
||||
}
|
||||
|
||||
fn tapping_and_pinching() -> Section<crate::pages::Message> {
|
||||
fn click_behavior() -> Section<crate::pages::Message> {
|
||||
Section::default()
|
||||
.title(fl!("tapping-and-pinching"))
|
||||
.title(fl!("click-behavior"))
|
||||
.descriptions(vec![
|
||||
CLICK_BEHAVIOR_CLICK_FINGER.as_str().into(),
|
||||
CLICK_BEHAVIOR_BUTTON_AREAS.as_str().into(),
|
||||
TAP_TO_CLICK.as_str().into(),
|
||||
TAP_TO_CLICK_DESC.as_str().into(),
|
||||
PINCH_TO_ZOOM.as_str().into(),
|
||||
PINCH_TO_ZOOM_DESC.as_str().into(),
|
||||
])
|
||||
.view::<Page>(|binder, _page, _section| {
|
||||
.view::<Page>(|binder, _page, section| {
|
||||
let page = binder
|
||||
.page::<super::Page>()
|
||||
.expect("input devices page not found");
|
||||
|
||||
settings::view_section(&*TAPPING_AND_PINCHING)
|
||||
settings::view_section(&*section.title)
|
||||
// Secondary click via two fingers, and middle-click via three fingers
|
||||
.add(
|
||||
settings::item::builder(&*CLICK_BEHAVIOR_CLICK_FINGER).toggler(
|
||||
page.input_touchpad
|
||||
.click_method
|
||||
.as_ref()
|
||||
.map_or(false, |x| matches!(x, ClickMethod::Clickfinger)),
|
||||
|enabled| {
|
||||
Message::SetSecondaryClickBehavior(
|
||||
enabled.then_some(ClickMethod::Clickfinger),
|
||||
true,
|
||||
)
|
||||
},
|
||||
),
|
||||
)
|
||||
// Secondary and middle-click via button areas.
|
||||
.add(
|
||||
settings::item::builder(&*CLICK_BEHAVIOR_BUTTON_AREAS).toggler(
|
||||
page.input_touchpad
|
||||
.click_method
|
||||
.as_ref()
|
||||
.map_or(false, |x| matches!(x, ClickMethod::ButtonAreas)),
|
||||
|enabled| {
|
||||
Message::SetSecondaryClickBehavior(
|
||||
enabled.then_some(ClickMethod::ButtonAreas),
|
||||
true,
|
||||
)
|
||||
},
|
||||
),
|
||||
)
|
||||
.add(
|
||||
settings::item::builder(&*TAP_TO_CLICK).toggler(
|
||||
page.input_touchpad
|
||||
|
|
@ -145,7 +173,6 @@ fn tapping_and_pinching() -> Section<crate::pages::Message> {
|
|||
Message::TapToClick,
|
||||
),
|
||||
)
|
||||
.add(settings::item::builder(&*PINCH_TO_ZOOM).toggler(false, Message::PinchToZoom))
|
||||
.apply(Element::from)
|
||||
.map(crate::pages::Message::Input)
|
||||
})
|
||||
|
|
@ -155,12 +182,11 @@ fn scrolling() -> Section<crate::pages::Message> {
|
|||
Section::default()
|
||||
.title(fl!("scrolling"))
|
||||
.descriptions(vec![
|
||||
super::SCROLLING_TWO_FINGER.as_str().into(),
|
||||
super::SCROLLING_EDGE.as_str().into(),
|
||||
super::SCROLLING_SPEED.as_str().into(),
|
||||
super::SCROLLING_NATURAL.as_str().into(),
|
||||
super::SCROLLING_NATURAL_DESC.as_str().into(),
|
||||
TWO_FINGER_SCROLLING.as_str().into(),
|
||||
EDGE_SCROLLING.as_str().into(),
|
||||
EDGE_SCROLLING_DESC.as_str().into(),
|
||||
])
|
||||
.view::<Page>(|binder, _page, section| {
|
||||
let page = binder
|
||||
|
|
@ -169,6 +195,33 @@ fn scrolling() -> Section<crate::pages::Message> {
|
|||
let theme = cosmic::theme::active();
|
||||
|
||||
settings::view_section(§ion.title)
|
||||
// Two-finger scrolling toggle
|
||||
.add(
|
||||
settings::item::builder(&*super::SCROLLING_TWO_FINGER).toggler(
|
||||
page.input_touchpad
|
||||
.scroll_config
|
||||
.as_ref()
|
||||
.map_or(false, |x| matches!(x.method, Some(ScrollMethod::TwoFinger))),
|
||||
|enabled| {
|
||||
Message::SetScrollMethod(
|
||||
enabled.then_some(ScrollMethod::TwoFinger),
|
||||
true,
|
||||
)
|
||||
},
|
||||
),
|
||||
)
|
||||
// Edge scrolling toggle
|
||||
.add(
|
||||
settings::item::builder(&*super::SCROLLING_EDGE).toggler(
|
||||
page.input_touchpad
|
||||
.scroll_config
|
||||
.as_ref()
|
||||
.map_or(false, |x| matches!(x.method, Some(ScrollMethod::Edge))),
|
||||
|enabled| {
|
||||
Message::SetScrollMethod(enabled.then_some(ScrollMethod::Edge), true)
|
||||
},
|
||||
),
|
||||
)
|
||||
// Scroll speed slider
|
||||
.add(settings::item(&*super::SCROLLING_SPEED, {
|
||||
let value = page
|
||||
|
|
@ -205,38 +258,6 @@ fn scrolling() -> Section<crate::pages::Message> {
|
|||
|enabled| Message::SetNaturalScroll(enabled, true),
|
||||
),
|
||||
)
|
||||
// Two-finger scrolling toggle
|
||||
.add(
|
||||
settings::item::builder(&*TWO_FINGER_SCROLLING).toggler(
|
||||
page.input_touchpad
|
||||
.scroll_config
|
||||
.as_ref()
|
||||
.map_or(false, |x| matches!(x.method, Some(ScrollMethod::TwoFinger))),
|
||||
|enabled| {
|
||||
Message::SetScrollMethod(
|
||||
enabled.then_some(ScrollMethod::TwoFinger),
|
||||
true,
|
||||
)
|
||||
},
|
||||
),
|
||||
)
|
||||
// Edge scrolling toggle
|
||||
.add(
|
||||
settings::item::builder(&*EDGE_SCROLLING)
|
||||
.description(&*EDGE_SCROLLING_DESC)
|
||||
.toggler(
|
||||
page.input_touchpad
|
||||
.scroll_config
|
||||
.as_ref()
|
||||
.map_or(false, |x| matches!(x.method, Some(ScrollMethod::Edge))),
|
||||
|enabled| {
|
||||
Message::SetScrollMethod(
|
||||
enabled.then_some(ScrollMethod::Edge),
|
||||
true,
|
||||
)
|
||||
},
|
||||
),
|
||||
)
|
||||
.apply(Element::from)
|
||||
.map(crate::pages::Message::Input)
|
||||
})
|
||||
|
|
|
|||
|
|
@ -84,15 +84,10 @@ pub fn page_list_item<'a, Message: 'static + Clone>(
|
|||
icon: &'a str,
|
||||
message: Message,
|
||||
) -> Element<'a, Message> {
|
||||
let control = row::with_children(vec![
|
||||
horizontal_space(Length::Fill).into(),
|
||||
icon::from_name("go-next-symbolic").size(16).into(),
|
||||
]);
|
||||
|
||||
cosmic::widget::settings::item::builder(title)
|
||||
.description(description)
|
||||
.icon(icon::from_name(icon).size(16))
|
||||
.control(control)
|
||||
.control(icon::from_name("go-next-symbolic").size(16))
|
||||
.spacing(16)
|
||||
.apply(container)
|
||||
.padding([20, 24])
|
||||
|
|
|
|||
|
|
@ -368,6 +368,8 @@ primary-button = Primary button
|
|||
.right = Right
|
||||
|
||||
scrolling = Scrolling
|
||||
.two-finger = Scroll with two fingers
|
||||
.edge = Scroll along the edge with one finger
|
||||
.speed = Scrolling speed
|
||||
.natural = Natural scrolling
|
||||
.natural-desc = Scroll the content, instead of the view
|
||||
|
|
@ -403,8 +405,9 @@ mouse = Mouse
|
|||
|
||||
## Input: Touchpad
|
||||
|
||||
edge-scrolling = Edge scrolling
|
||||
.desc = Scroll using the edge of the touchpad.
|
||||
click-behavior = Click Behavior
|
||||
.click-finger = Secondary click with two fingers and middle-click with three fingers
|
||||
.button-areas = Secondary click in bottom right corner and middle-click in bottom center
|
||||
|
||||
pinch-to-zoom = Pinch to zoom
|
||||
.desc = Use two fingers to zoom into content, for applications that support zoom.
|
||||
|
|
@ -412,15 +415,11 @@ pinch-to-zoom = Pinch to zoom
|
|||
tap-to-click = Tap to click
|
||||
.desc = Enables single-finger tap for primary click, two-finger tap for secondary click, and three-finger tap for middle click.
|
||||
|
||||
tapping-and-pinching = Tapping and Pinching
|
||||
|
||||
touchpad = Touchpad
|
||||
.acceleration = Enable touchpad acceleration
|
||||
.desc = Touchpad speed, click options, gestures.
|
||||
.speed = Touchpad speed
|
||||
|
||||
two-finger-scrolling = Two-finger scrolling
|
||||
|
||||
## Input: Gestures
|
||||
|
||||
swiping = Swiping
|
||||
|
|
|
|||
|
|
@ -403,24 +403,6 @@ mouse = Mouse
|
|||
|
||||
## Input: Touchpad
|
||||
|
||||
edge-scrolling = Edge scrolling
|
||||
.desc = Scroll using the edge of the touchpad.
|
||||
|
||||
pinch-to-zoom = Pinch to zoom
|
||||
.desc = Use two fingers to zoom into content, for applications that support zoom.
|
||||
|
||||
tap-to-click = Tap to click
|
||||
.desc = Enables single-finger tap for primary click, two-finger tap for secondary click, and three-finger tap for middle click.
|
||||
|
||||
tapping-and-pinching = Tapping and Pinching
|
||||
|
||||
touchpad = Touchpad
|
||||
.acceleration = Enable touchpad acceleration
|
||||
.desc = Touchpad speed, click options, gestures.
|
||||
.speed = Touchpad speed
|
||||
|
||||
two-finger-scrolling = Two-finger scrolling
|
||||
|
||||
## Input: Gestures
|
||||
|
||||
swiping = Swiping
|
||||
|
|
|
|||
|
|
@ -403,24 +403,17 @@ mouse = Rato
|
|||
|
||||
## Input: Touchpad
|
||||
|
||||
edge-scrolling = Deslocação nas margens
|
||||
.desc = Deslocar utilizando a extremidade do painel tátil.
|
||||
|
||||
pinch-to-zoom = Apertar para ampliar
|
||||
.desc = Utilize dois dedos para fazer zoom no conteúdo, para aplicações que suportem ampliação.
|
||||
|
||||
tap-to-click = Tocar para clicar
|
||||
.desc = Permite o toque com um dedo para o clique principal, o toque com dois dedos para o clique secundário e o toque com três dedos para o clique no botão do meio.
|
||||
|
||||
tapping-and-pinching = Tocar e apertar
|
||||
|
||||
touchpad = Painel tátil
|
||||
.acceleration = Ativar a aceleração do painel tátil
|
||||
.desc = Velocidade do painel tátil, opções de clique, gestos.
|
||||
.speed = Velocidade do painel tátil
|
||||
|
||||
two-finger-scrolling = Deslocação com dois dedos
|
||||
|
||||
## Input: Gestures
|
||||
|
||||
swiping = Deslizar
|
||||
|
|
|
|||
|
|
@ -403,24 +403,17 @@ mouse = Миш
|
|||
|
||||
## Input: Touchpad
|
||||
|
||||
edge-scrolling = Померање са ивицама
|
||||
.desc = Померајте помоћу ивица додирне табле.
|
||||
|
||||
pinch-to-zoom = Стисните прсте за зумирање
|
||||
.desc = Користите два прста за зумирање садржаја, за апликације које подржавају зумирање.
|
||||
|
||||
tap-to-click = Додир за клик
|
||||
.desc = Омогућава додир једним прстом за примарни клик, два прста за секундарни клик и три прста за средњи клик.
|
||||
|
||||
tapping-and-pinching = Додир и зумирање
|
||||
|
||||
touchpad = Додирна табла
|
||||
.desc = Брзина додирне табле, опције клика, покрети.
|
||||
.speed = Брзина додирне табле
|
||||
.acceleration = Омогући убрзање додирне табле
|
||||
|
||||
two-finger-scrolling = Померање са два прста
|
||||
|
||||
## Input: Gestures
|
||||
|
||||
swiping = Покрети
|
||||
|
|
|
|||
|
|
@ -403,24 +403,17 @@ mouse = Miš
|
|||
|
||||
## Input: Touchpad
|
||||
|
||||
edge-scrolling = Pomeranje sa ivicama
|
||||
.desc = Pomerajte pomoću ivica dodirne table.
|
||||
|
||||
pinch-to-zoom = Stisnite prste za zumiranje
|
||||
.desc = Koristite dva prsta za zumiranje sadržaja, za aplikacije koje podržavaju zumiranje.
|
||||
|
||||
tap-to-click = Dodir za klik
|
||||
.desc = Omogućava dodir jednim prstom za primarni klik, dva prsta za sekundarni klik i tri prsta za srednji klik.
|
||||
|
||||
tapping-and-pinching = Dodir i zumiranje
|
||||
|
||||
touchpad = Dodirna tabla
|
||||
.desc = Brzina dodirne table, opcije klika, pokreti.
|
||||
.speed = Brzina dodirne table
|
||||
.acceleration = Omogući ubrzanje dodirne table
|
||||
|
||||
two-finger-scrolling = Pomeranje sa dva prsta
|
||||
|
||||
## Input: Gestures
|
||||
|
||||
swiping = Pokreti
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue