feat: whiteboard, macos (#12780)
Signed-off-by: fufesou <linlong1266@gmail.com>
This commit is contained in:
@@ -3697,13 +3697,17 @@ impl Connection {
|
||||
self.update_terminal_persistence(q == BoolOption::Yes).await;
|
||||
}
|
||||
}
|
||||
#[cfg(target_os = "windows")]
|
||||
#[cfg(any(target_os = "windows", target_os = "macos"))]
|
||||
if let Ok(q) = o.show_my_cursor.enum_value() {
|
||||
if q != BoolOption::NotSet {
|
||||
use crate::whiteboard;
|
||||
self.show_my_cursor = q == BoolOption::Yes;
|
||||
#[cfg(target_os = "windows")]
|
||||
let is_win10_or_greater = crate::platform::windows::is_win_10_or_greater();
|
||||
#[cfg(not(target_os = "windows"))]
|
||||
let is_win10_or_greater = false;
|
||||
if q == BoolOption::Yes {
|
||||
if crate::platform::windows::is_win_10_or_greater() {
|
||||
if !cfg!(target_os = "windows") || is_win10_or_greater {
|
||||
whiteboard::register_whiteboard(whiteboard::get_key_cursor(self.inner.id));
|
||||
} else {
|
||||
let mut msg_out = Message::new();
|
||||
@@ -3718,7 +3722,7 @@ impl Connection {
|
||||
self.send(msg_out).await;
|
||||
}
|
||||
} else {
|
||||
if crate::platform::windows::is_win_10_or_greater() {
|
||||
if !cfg!(target_os = "windows") || is_win10_or_greater {
|
||||
whiteboard::unregister_whiteboard(whiteboard::get_key_cursor(
|
||||
self.inner.id,
|
||||
));
|
||||
@@ -4878,7 +4882,7 @@ mod raii {
|
||||
scrap::wayland::pipewire::try_close_session();
|
||||
}
|
||||
Self::check_wake_lock();
|
||||
#[cfg(target_os = "windows")]
|
||||
#[cfg(any(target_os = "windows", target_os = "macos"))]
|
||||
{
|
||||
use crate::whiteboard;
|
||||
whiteboard::unregister_whiteboard(whiteboard::get_key_cursor(self.0));
|
||||
|
||||
@@ -2,7 +2,7 @@
|
||||
use super::rdp_input::client::{RdpInputKeyboard, RdpInputMouse};
|
||||
use super::*;
|
||||
use crate::input::*;
|
||||
#[cfg(target_os = "windows")]
|
||||
#[cfg(any(target_os = "windows", target_os = "macos"))]
|
||||
use crate::whiteboard;
|
||||
#[cfg(target_os = "macos")]
|
||||
use dispatch::Queue;
|
||||
@@ -204,6 +204,7 @@ impl LockModesHandler {
|
||||
}
|
||||
|
||||
let mut num_lock_changed = false;
|
||||
#[allow(unused)]
|
||||
let mut event_num_enabled = false;
|
||||
if is_numpad_key {
|
||||
let local_num_enabled = en.get_key_state(enigo::Key::NumLock);
|
||||
@@ -999,7 +1000,7 @@ pub fn handle_mouse_(
|
||||
if simulate {
|
||||
handle_mouse_simulation_(evt, conn);
|
||||
}
|
||||
#[cfg(target_os = "windows")]
|
||||
#[cfg(any(target_os = "windows", target_os = "macos"))]
|
||||
if _show_cursor {
|
||||
handle_mouse_show_cursor_(evt, conn, username, argb);
|
||||
}
|
||||
@@ -1148,7 +1149,7 @@ pub fn handle_mouse_simulation_(evt: &MouseEvent, conn: i32) {
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(target_os = "windows")]
|
||||
#[cfg(any(target_os = "windows", target_os = "macos"))]
|
||||
pub fn handle_mouse_show_cursor_(evt: &MouseEvent, conn: i32, username: String, argb: u32) {
|
||||
let buttons = evt.mask >> 3;
|
||||
let evt_type = evt.mask & 0x7;
|
||||
|
||||
Reference in New Issue
Block a user