Merge pull request #877 from SoLongAndThanksForAllThePizza/flutter_desktop

feat: implemented remote control on desktop
This commit is contained in:
RustDesk 2022-06-27 16:53:57 +08:00 committed by GitHub
commit 6c4f5dc007
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 58 additions and 37 deletions

View File

@ -425,18 +425,35 @@ class CanvasModel with ChangeNotifier {
final size = MediaQueryData.fromWindow(ui.window).size;
final s1 = size.width / (parent.target?.ffiModel.display.width ?? 720);
final s2 = size.height / (parent.target?.ffiModel.display.height ?? 1280);
if (s == 'shrink') {
// Closure to perform shrink operation.
final shrinkOp = () {
final s = s1 < s2 ? s1 : s2;
if (s < 1) {
_scale = s;
}
} else if (s == 'stretch') {
};
// Closure to perform stretch operation.
final stretchOp = () {
final s = s1 > s2 ? s1 : s2;
if (s > 1) {
_scale = s;
}
};
// Closure to perform default operation(set the scale to 1.0).
final defaultOp = () {
_scale = 1.0;
};
if (s == 'shrink') {
shrinkOp();
} else if (s == 'stretch') {
stretchOp();
} else {
_scale = 1;
// On desktop, shrink is the default behavior.
if (isDesktop) {
shrinkOp();
} else {
defaultOp();
}
}
_x = (size.width - getDisplayWidth() * _scale) / 2;
_y = (size.height - getDisplayHeight() * _scale) / 2;
@ -459,6 +476,8 @@ class CanvasModel with ChangeNotifier {
}
void moveDesktopMouse(double x, double y) {
// On mobile platforms, move the canvas with the cursor.
if (!isDesktop) {
final size = MediaQueryData.fromWindow(ui.window).size;
final dw = getDisplayWidth() * _scale;
final dh = getDisplayHeight() * _scale;
@ -475,6 +494,7 @@ class CanvasModel with ChangeNotifier {
if (dxOffset != 0 || dyOffset != 0) {
notifyListeners();
}
}
parent.target?.cursorModel.moveLocal(x, y);
}
@ -714,6 +734,7 @@ class CursorModel with ChangeNotifier {
}
}
/// Update the cursor position.
void updateCursorPosition(Map<String, dynamic> evt) {
_x = double.parse(evt['x']);
_y = double.parse(evt['y']);