mirror of
https://github.com/rustdesk/rustdesk.git
synced 2025-01-18 07:43:01 +08:00
flutter_desktop: fix canvas height - tabBarHeight
Signed-off-by: fufesou <shuanglongchen@yeah.net>
This commit is contained in:
parent
0dd55d6ef1
commit
d4c735bc3a
1
flutter/lib/consts.dart
Normal file
1
flutter/lib/consts.dart
Normal file
@ -0,0 +1 @@
|
|||||||
|
double kDesktopRemoteTabBarHeight = 48.0;
|
@ -906,8 +906,10 @@ class _PeerTabbedPageState extends State<_PeerTabbedPage>
|
|||||||
if (_tabController.indexIsChanging) {
|
if (_tabController.indexIsChanging) {
|
||||||
switch (_tabController.index) {
|
switch (_tabController.index) {
|
||||||
case 0:
|
case 0:
|
||||||
|
gFFI.bind.mainLoadRecentPeers();
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
|
gFFI.bind.mainLoadFavPeers();
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
gFFI.bind.mainDiscover();
|
gFFI.bind.mainDiscover();
|
||||||
|
@ -3,9 +3,11 @@ import 'dart:math';
|
|||||||
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_hbb/common.dart';
|
import 'package:flutter_hbb/common.dart';
|
||||||
|
import 'package:flutter_hbb/consts.dart';
|
||||||
import 'package:flutter_hbb/desktop/pages/remote_page.dart';
|
import 'package:flutter_hbb/desktop/pages/remote_page.dart';
|
||||||
import 'package:flutter_hbb/desktop/widgets/titlebar_widget.dart';
|
import 'package:flutter_hbb/desktop/widgets/titlebar_widget.dart';
|
||||||
import 'package:flutter_hbb/utils/multi_window_manager.dart';
|
import 'package:flutter_hbb/utils/multi_window_manager.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
import 'package:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
|
|
||||||
import '../../models/model.dart';
|
import '../../models/model.dart';
|
||||||
@ -70,6 +72,42 @@ class _ConnectionTabPageState extends State<ConnectionTabPage>
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
|
final tabBar = TabBar(
|
||||||
|
isScrollable: true,
|
||||||
|
labelColor: Colors.white,
|
||||||
|
physics: NeverScrollableScrollPhysics(),
|
||||||
|
indicatorColor: Colors.white,
|
||||||
|
tabs: connectionIds
|
||||||
|
.map((e) => Tab(
|
||||||
|
child: Row(
|
||||||
|
mainAxisSize: MainAxisSize.min,
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
Text(e),
|
||||||
|
SizedBox(
|
||||||
|
width: 4,
|
||||||
|
),
|
||||||
|
InkWell(
|
||||||
|
onTap: () {
|
||||||
|
onRemoveId(e);
|
||||||
|
},
|
||||||
|
child: Icon(
|
||||||
|
Icons.highlight_remove,
|
||||||
|
size: 20,
|
||||||
|
))
|
||||||
|
],
|
||||||
|
),
|
||||||
|
))
|
||||||
|
.toList());
|
||||||
|
final tabBarView = TabBarView(
|
||||||
|
children: connectionIds
|
||||||
|
.map((e) => Container(
|
||||||
|
child: RemotePage(
|
||||||
|
key: ValueKey(e),
|
||||||
|
id: e,
|
||||||
|
tabBarHeight: kDesktopRemoteTabBarHeight,
|
||||||
|
))) //RemotePage(key: ValueKey(e), id: e))
|
||||||
|
.toList());
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
body: DefaultTabController(
|
body: DefaultTabController(
|
||||||
initialIndex: initialIndex,
|
initialIndex: initialIndex,
|
||||||
@ -78,43 +116,9 @@ class _ConnectionTabPageState extends State<ConnectionTabPage>
|
|||||||
child: Column(
|
child: Column(
|
||||||
children: [
|
children: [
|
||||||
DesktopTitleBar(
|
DesktopTitleBar(
|
||||||
child: TabBar(
|
child: Container(height: kDesktopRemoteTabBarHeight, child: tabBar),
|
||||||
isScrollable: true,
|
|
||||||
labelColor: Colors.white,
|
|
||||||
physics: NeverScrollableScrollPhysics(),
|
|
||||||
indicatorColor: Colors.white,
|
|
||||||
tabs: connectionIds
|
|
||||||
.map((e) => Tab(
|
|
||||||
child: Row(
|
|
||||||
mainAxisSize: MainAxisSize.min,
|
|
||||||
crossAxisAlignment: CrossAxisAlignment.center,
|
|
||||||
children: [
|
|
||||||
Text(e),
|
|
||||||
SizedBox(
|
|
||||||
width: 4,
|
|
||||||
),
|
|
||||||
InkWell(
|
|
||||||
onTap: () {
|
|
||||||
onRemoveId(e);
|
|
||||||
},
|
|
||||||
child: Icon(
|
|
||||||
Icons.highlight_remove,
|
|
||||||
size: 20,
|
|
||||||
))
|
|
||||||
],
|
|
||||||
),
|
|
||||||
))
|
|
||||||
.toList()),
|
|
||||||
),
|
),
|
||||||
Expanded(
|
Expanded(child: tabBarView),
|
||||||
child: TabBarView(
|
|
||||||
children: connectionIds
|
|
||||||
.map((e) => Container(
|
|
||||||
child: RemotePage(
|
|
||||||
key: ValueKey(e),
|
|
||||||
id: e))) //RemotePage(key: ValueKey(e), id: e))
|
|
||||||
.toList()),
|
|
||||||
)
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
@ -16,6 +16,7 @@ import 'package:wakelock/wakelock.dart';
|
|||||||
// import 'package:window_manager/window_manager.dart';
|
// import 'package:window_manager/window_manager.dart';
|
||||||
|
|
||||||
import '../../common.dart';
|
import '../../common.dart';
|
||||||
|
import '../../consts.dart';
|
||||||
import '../../mobile/widgets/dialog.dart';
|
import '../../mobile/widgets/dialog.dart';
|
||||||
import '../../mobile/widgets/overlay.dart';
|
import '../../mobile/widgets/overlay.dart';
|
||||||
import '../../models/model.dart';
|
import '../../models/model.dart';
|
||||||
@ -23,9 +24,11 @@ import '../../models/model.dart';
|
|||||||
final initText = '\1' * 1024;
|
final initText = '\1' * 1024;
|
||||||
|
|
||||||
class RemotePage extends StatefulWidget {
|
class RemotePage extends StatefulWidget {
|
||||||
RemotePage({Key? key, required this.id}) : super(key: key);
|
RemotePage({Key? key, required this.id, required this.tabBarHeight})
|
||||||
|
: super(key: key);
|
||||||
|
|
||||||
final String id;
|
final String id;
|
||||||
|
final double tabBarHeight;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
_RemotePageState createState() => _RemotePageState();
|
_RemotePageState createState() => _RemotePageState();
|
||||||
@ -53,10 +56,12 @@ class _RemotePageState extends State<RemotePage>
|
|||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
super.initState();
|
super.initState();
|
||||||
final ffi = Get.put(FFI(), tag: widget.id);
|
var ffitmp = FFI();
|
||||||
|
ffitmp.canvasModel.tabBarHeight = super.widget.tabBarHeight;
|
||||||
|
final ffi = Get.put(ffitmp, tag: widget.id);
|
||||||
// note: a little trick
|
// note: a little trick
|
||||||
ffi.ffiModel.platformFFI = gFFI.ffiModel.platformFFI;
|
ffi.ffiModel.platformFFI = gFFI.ffiModel.platformFFI;
|
||||||
ffi.connect(widget.id);
|
ffi.connect(widget.id, tabBarHeight: super.widget.tabBarHeight);
|
||||||
WidgetsBinding.instance.addPostFrameCallback((_) {
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
||||||
SystemChrome.setEnabledSystemUIMode(SystemUiMode.manual, overlays: []);
|
SystemChrome.setEnabledSystemUIMode(SystemUiMode.manual, overlays: []);
|
||||||
showLoading(translate('Connecting...'));
|
showLoading(translate('Connecting...'));
|
||||||
@ -236,11 +241,12 @@ class _RemotePageState extends State<RemotePage>
|
|||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
super.build(context);
|
super.build(context);
|
||||||
|
Provider.of<CanvasModel>(context, listen: false).tabBarHeight =
|
||||||
|
super.widget.tabBarHeight;
|
||||||
final pi = Provider.of<FfiModel>(context).pi;
|
final pi = Provider.of<FfiModel>(context).pi;
|
||||||
final hideKeyboard = isKeyboardShown() && _showEdit;
|
final hideKeyboard = isKeyboardShown() && _showEdit;
|
||||||
final showActionButton = !_showBar || hideKeyboard;
|
final showActionButton = !_showBar || hideKeyboard;
|
||||||
final keyboard = _ffi.ffiModel.permissions['keyboard'] != false;
|
final keyboard = _ffi.ffiModel.permissions['keyboard'] != false;
|
||||||
|
|
||||||
return WillPopScope(
|
return WillPopScope(
|
||||||
onWillPop: () async {
|
onWillPop: () async {
|
||||||
clientClose();
|
clientClose();
|
||||||
@ -296,7 +302,6 @@ class _RemotePageState extends State<RemotePage>
|
|||||||
Widget getRawPointerAndKeyBody(bool keyboard, Widget child) {
|
Widget getRawPointerAndKeyBody(bool keyboard, Widget child) {
|
||||||
return Listener(
|
return Listener(
|
||||||
onPointerHover: (e) {
|
onPointerHover: (e) {
|
||||||
debugPrint("onPointerHover ${e}");
|
|
||||||
if (e.kind != ui.PointerDeviceKind.mouse) return;
|
if (e.kind != ui.PointerDeviceKind.mouse) return;
|
||||||
if (!_isPhysicalMouse) {
|
if (!_isPhysicalMouse) {
|
||||||
setState(() {
|
setState(() {
|
||||||
@ -304,11 +309,11 @@ class _RemotePageState extends State<RemotePage>
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
if (_isPhysicalMouse) {
|
if (_isPhysicalMouse) {
|
||||||
_ffi.handleMouse(getEvent(e, 'mousemove'));
|
_ffi.handleMouse(getEvent(e, 'mousemove'),
|
||||||
|
tabBarHeight: super.widget.tabBarHeight);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onPointerDown: (e) {
|
onPointerDown: (e) {
|
||||||
debugPrint("onPointerDown ${e}");
|
|
||||||
if (e.kind != ui.PointerDeviceKind.mouse) {
|
if (e.kind != ui.PointerDeviceKind.mouse) {
|
||||||
if (_isPhysicalMouse) {
|
if (_isPhysicalMouse) {
|
||||||
setState(() {
|
setState(() {
|
||||||
@ -317,25 +322,25 @@ class _RemotePageState extends State<RemotePage>
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (_isPhysicalMouse) {
|
if (_isPhysicalMouse) {
|
||||||
_ffi.handleMouse(getEvent(e, 'mousedown'));
|
_ffi.handleMouse(getEvent(e, 'mousedown'),
|
||||||
|
tabBarHeight: super.widget.tabBarHeight);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onPointerUp: (e) {
|
onPointerUp: (e) {
|
||||||
debugPrint("onPointerUp ${e}");
|
|
||||||
if (e.kind != ui.PointerDeviceKind.mouse) return;
|
if (e.kind != ui.PointerDeviceKind.mouse) return;
|
||||||
if (_isPhysicalMouse) {
|
if (_isPhysicalMouse) {
|
||||||
_ffi.handleMouse(getEvent(e, 'mouseup'));
|
_ffi.handleMouse(getEvent(e, 'mouseup'),
|
||||||
|
tabBarHeight: super.widget.tabBarHeight);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onPointerMove: (e) {
|
onPointerMove: (e) {
|
||||||
debugPrint("onPointerMove ${e}");
|
|
||||||
if (e.kind != ui.PointerDeviceKind.mouse) return;
|
if (e.kind != ui.PointerDeviceKind.mouse) return;
|
||||||
if (_isPhysicalMouse) {
|
if (_isPhysicalMouse) {
|
||||||
_ffi.handleMouse(getEvent(e, 'mousemove'));
|
_ffi.handleMouse(getEvent(e, 'mousemove'),
|
||||||
|
tabBarHeight: super.widget.tabBarHeight);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onPointerSignal: (e) {
|
onPointerSignal: (e) {
|
||||||
debugPrint("onPointerSignal ${e}");
|
|
||||||
if (e is PointerScrollEvent) {
|
if (e is PointerScrollEvent) {
|
||||||
var dx = e.scrollDelta.dx;
|
var dx = e.scrollDelta.dx;
|
||||||
var dy = e.scrollDelta.dy;
|
var dy = e.scrollDelta.dy;
|
||||||
@ -557,7 +562,7 @@ class _RemotePageState extends State<RemotePage>
|
|||||||
void showActions(String id) async {
|
void showActions(String id) async {
|
||||||
final size = MediaQuery.of(context).size;
|
final size = MediaQuery.of(context).size;
|
||||||
final x = 120.0;
|
final x = 120.0;
|
||||||
final y = size.height;
|
final y = size.height - super.widget.tabBarHeight;
|
||||||
final more = <PopupMenuItem<String>>[];
|
final more = <PopupMenuItem<String>>[];
|
||||||
final pi = _ffi.ffiModel.pi;
|
final pi = _ffi.ffiModel.pi;
|
||||||
final perms = _ffi.ffiModel.permissions;
|
final perms = _ffi.ffiModel.permissions;
|
||||||
@ -672,7 +677,6 @@ class _RemotePageState extends State<RemotePage>
|
|||||||
if (!keyboard) {
|
if (!keyboard) {
|
||||||
return SizedBox();
|
return SizedBox();
|
||||||
}
|
}
|
||||||
final size = MediaQuery.of(context).size;
|
|
||||||
var wrap = (String text, void Function() onPressed,
|
var wrap = (String text, void Function() onPressed,
|
||||||
[bool? active, IconData? icon]) {
|
[bool? active, IconData? icon]) {
|
||||||
return TextButton(
|
return TextButton(
|
||||||
@ -788,7 +792,7 @@ class _RemotePageState extends State<RemotePage>
|
|||||||
sendPrompt(widget.id, isMac, 'VK_S');
|
sendPrompt(widget.id, isMac, 'VK_S');
|
||||||
}),
|
}),
|
||||||
];
|
];
|
||||||
final space = size.width > 320 ? 4.0 : 2.0;
|
final space = MediaQuery.of(context).size.width > 320 ? 4.0 : 2.0;
|
||||||
return Container(
|
return Container(
|
||||||
color: Color(0xAA000000),
|
color: Color(0xAA000000),
|
||||||
padding: EdgeInsets.only(
|
padding: EdgeInsets.only(
|
||||||
|
@ -64,6 +64,11 @@ class _PeerWidgetState extends State<_PeerWidget> with WindowListener {
|
|||||||
_queryCoun = 0;
|
_queryCoun = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void onWindowMinimize() {
|
||||||
|
_queryCoun = _maxQueryCount;
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final space = 8.0;
|
final space = 8.0;
|
||||||
@ -110,19 +115,23 @@ class _PeerWidgetState extends State<_PeerWidget> with WindowListener {
|
|||||||
final now = DateTime.now();
|
final now = DateTime.now();
|
||||||
if (!setEquals(_curPeers, _lastQueryPeers)) {
|
if (!setEquals(_curPeers, _lastQueryPeers)) {
|
||||||
if (now.difference(_lastChangeTime) > Duration(seconds: 1)) {
|
if (now.difference(_lastChangeTime) > Duration(seconds: 1)) {
|
||||||
gFFI.ffiModel.platformFFI.ffiBind
|
if (_curPeers.length > 0) {
|
||||||
.queryOnlines(ids: _curPeers.toList(growable: false));
|
gFFI.ffiModel.platformFFI.ffiBind
|
||||||
_lastQueryPeers = {..._curPeers};
|
.queryOnlines(ids: _curPeers.toList(growable: false));
|
||||||
_lastQueryTime = DateTime.now();
|
_lastQueryPeers = {..._curPeers};
|
||||||
_queryCoun = 0;
|
_lastQueryTime = DateTime.now();
|
||||||
|
_queryCoun = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (_queryCoun < _maxQueryCount) {
|
if (_queryCoun < _maxQueryCount) {
|
||||||
if (now.difference(_lastQueryTime) > Duration(seconds: 20)) {
|
if (now.difference(_lastQueryTime) > Duration(seconds: 20)) {
|
||||||
gFFI.ffiModel.platformFFI.ffiBind
|
if (_curPeers.length > 0) {
|
||||||
.queryOnlines(ids: _curPeers.toList(growable: false));
|
gFFI.ffiModel.platformFFI.ffiBind
|
||||||
_lastQueryTime = DateTime.now();
|
.queryOnlines(ids: _curPeers.toList(growable: false));
|
||||||
_queryCoun += 1;
|
_lastQueryTime = DateTime.now();
|
||||||
|
_queryCoun += 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -193,7 +202,6 @@ class DiscoveredPeerWidget extends BasePeerWidget {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
debugPrint("DiscoveredPeerWidget build");
|
|
||||||
final widget = super.build(context);
|
final widget = super.build(context);
|
||||||
gFFI.bind.mainLoadLanPeers();
|
gFFI.bind.mainLoadLanPeers();
|
||||||
return widget;
|
return widget;
|
||||||
|
@ -405,7 +405,6 @@ class RecentPeerCard extends BasePeerCard {
|
|||||||
: super(peer: peer, key: key, type: PeerType.recent);
|
: super(peer: peer, key: key, type: PeerType.recent);
|
||||||
|
|
||||||
Future<List<PopupMenuItem<String>>> _getPopupMenuItems() async {
|
Future<List<PopupMenuItem<String>>> _getPopupMenuItems() async {
|
||||||
debugPrint("call RecentPeerCard _getPopupMenuItems");
|
|
||||||
return [
|
return [
|
||||||
PopupMenuItem<String>(
|
PopupMenuItem<String>(
|
||||||
child: Text(translate('Connect')), value: 'connect'),
|
child: Text(translate('Connect')), value: 'connect'),
|
||||||
@ -427,7 +426,6 @@ class FavoritePeerCard extends BasePeerCard {
|
|||||||
: super(peer: peer, key: key, type: PeerType.fav);
|
: super(peer: peer, key: key, type: PeerType.fav);
|
||||||
|
|
||||||
Future<List<PopupMenuItem<String>>> _getPopupMenuItems() async {
|
Future<List<PopupMenuItem<String>>> _getPopupMenuItems() async {
|
||||||
debugPrint("call FavoritePeerCard _getPopupMenuItems");
|
|
||||||
return [
|
return [
|
||||||
PopupMenuItem<String>(
|
PopupMenuItem<String>(
|
||||||
child: Text(translate('Connect')), value: 'connect'),
|
child: Text(translate('Connect')), value: 'connect'),
|
||||||
@ -451,7 +449,6 @@ class DiscoveredPeerCard extends BasePeerCard {
|
|||||||
: super(peer: peer, key: key, type: PeerType.discovered);
|
: super(peer: peer, key: key, type: PeerType.discovered);
|
||||||
|
|
||||||
Future<List<PopupMenuItem<String>>> _getPopupMenuItems() async {
|
Future<List<PopupMenuItem<String>>> _getPopupMenuItems() async {
|
||||||
debugPrint("call DiscoveredPeerCard _getPopupMenuItems");
|
|
||||||
return [
|
return [
|
||||||
PopupMenuItem<String>(
|
PopupMenuItem<String>(
|
||||||
child: Text(translate('Connect')), value: 'connect'),
|
child: Text(translate('Connect')), value: 'connect'),
|
||||||
@ -473,7 +470,6 @@ class AddressBookPeerCard extends BasePeerCard {
|
|||||||
: super(peer: peer, key: key, type: PeerType.ab);
|
: super(peer: peer, key: key, type: PeerType.ab);
|
||||||
|
|
||||||
Future<List<PopupMenuItem<String>>> _getPopupMenuItems() async {
|
Future<List<PopupMenuItem<String>>> _getPopupMenuItems() async {
|
||||||
debugPrint("call AddressBookPeerCard _getPopupMenuItems");
|
|
||||||
return [
|
return [
|
||||||
PopupMenuItem<String>(
|
PopupMenuItem<String>(
|
||||||
child: Text(translate('Connect')), value: 'connect'),
|
child: Text(translate('Connect')), value: 'connect'),
|
||||||
|
@ -22,7 +22,8 @@ class DesktopTitleBar extends StatelessWidget {
|
|||||||
child: Row(
|
child: Row(
|
||||||
children: [
|
children: [
|
||||||
Expanded(
|
Expanded(
|
||||||
child: child ?? Offstage(),)
|
child: child ?? Offstage(),
|
||||||
|
)
|
||||||
// const WindowButtons()
|
// const WindowButtons()
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
|
@ -213,13 +213,13 @@ class _ConnectionPageState extends State<ConnectionPage> {
|
|||||||
|
|
||||||
/// Get all the saved peers.
|
/// Get all the saved peers.
|
||||||
Widget getPeers() {
|
Widget getPeers() {
|
||||||
final size = MediaQuery.of(context).size;
|
final windowWidth = MediaQuery.of(context).size.width;
|
||||||
final space = 8.0;
|
final space = 8.0;
|
||||||
var width = size.width - 2 * space;
|
var width = windowWidth - 2 * space;
|
||||||
final minWidth = 320.0;
|
final minWidth = 320.0;
|
||||||
if (size.width > minWidth + 2 * space) {
|
if (windowWidth > minWidth + 2 * space) {
|
||||||
final n = (size.width / (minWidth + 2 * space)).floor();
|
final n = (windowWidth / (minWidth + 2 * space)).floor();
|
||||||
width = size.width / n - 2 * space;
|
width = windowWidth / n - 2 * space;
|
||||||
}
|
}
|
||||||
final cards = <Widget>[];
|
final cards = <Widget>[];
|
||||||
var peers = gFFI.peers();
|
var peers = gFFI.peers();
|
||||||
|
@ -349,7 +349,7 @@ class ImageModel with ChangeNotifier {
|
|||||||
|
|
||||||
ImageModel(this.parent);
|
ImageModel(this.parent);
|
||||||
|
|
||||||
void onRgba(Uint8List rgba) {
|
void onRgba(Uint8List rgba, double tabBarHeight) {
|
||||||
if (_waitForImage) {
|
if (_waitForImage) {
|
||||||
_waitForImage = false;
|
_waitForImage = false;
|
||||||
SmartDialog.dismiss();
|
SmartDialog.dismiss();
|
||||||
@ -363,22 +363,24 @@ class ImageModel with ChangeNotifier {
|
|||||||
if (parent.target?.id != pid) return;
|
if (parent.target?.id != pid) return;
|
||||||
try {
|
try {
|
||||||
// my throw exception, because the listener maybe already dispose
|
// my throw exception, because the listener maybe already dispose
|
||||||
update(image);
|
update(image, tabBarHeight);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
print('update image: $e');
|
print('update image: $e');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void update(ui.Image? image) {
|
void update(ui.Image? image, double tabBarHeight) {
|
||||||
if (_image == null && image != null) {
|
if (_image == null && image != null) {
|
||||||
if (isWebDesktop) {
|
if (isWebDesktop) {
|
||||||
parent.target?.canvasModel.updateViewStyle();
|
parent.target?.canvasModel.updateViewStyle();
|
||||||
} else {
|
} else {
|
||||||
final size = MediaQueryData.fromWindow(ui.window).size;
|
final size = MediaQueryData.fromWindow(ui.window).size;
|
||||||
final xscale = size.width / image.width;
|
final canvasWidth = size.width;
|
||||||
final yscale = size.height / image.height;
|
final canvasHeight = size.height - tabBarHeight;
|
||||||
parent.target?.canvasModel.scale = max(xscale, yscale);
|
final xscale = canvasWidth / image.width;
|
||||||
|
final yscale = canvasHeight / image.height;
|
||||||
|
parent.target?.canvasModel.scale = min(xscale, yscale);
|
||||||
}
|
}
|
||||||
if (parent.target != null) {
|
if (parent.target != null) {
|
||||||
initializeCursorAndCanvas(parent.target!);
|
initializeCursorAndCanvas(parent.target!);
|
||||||
@ -395,6 +397,8 @@ class ImageModel with ChangeNotifier {
|
|||||||
if (image != null) notifyListeners();
|
if (image != null) notifyListeners();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// mobile only
|
||||||
|
// for desktop, height should minus tabbar height
|
||||||
double get maxScale {
|
double get maxScale {
|
||||||
if (_image == null) return 1.5;
|
if (_image == null) return 1.5;
|
||||||
final size = MediaQueryData.fromWindow(ui.window).size;
|
final size = MediaQueryData.fromWindow(ui.window).size;
|
||||||
@ -403,6 +407,8 @@ class ImageModel with ChangeNotifier {
|
|||||||
return max(1.5, max(xscale, yscale));
|
return max(1.5, max(xscale, yscale));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// mobile only
|
||||||
|
// for desktop, height should minus tabbar height
|
||||||
double get minScale {
|
double get minScale {
|
||||||
if (_image == null) return 1.5;
|
if (_image == null) return 1.5;
|
||||||
final size = MediaQueryData.fromWindow(ui.window).size;
|
final size = MediaQueryData.fromWindow(ui.window).size;
|
||||||
@ -416,6 +422,7 @@ class CanvasModel with ChangeNotifier {
|
|||||||
double _x = 0;
|
double _x = 0;
|
||||||
double _y = 0;
|
double _y = 0;
|
||||||
double _scale = 1.0;
|
double _scale = 1.0;
|
||||||
|
double _tabBarHeight = 0.0;
|
||||||
String id = ""; // TODO multi canvas model
|
String id = ""; // TODO multi canvas model
|
||||||
|
|
||||||
WeakReference<FFI> parent;
|
WeakReference<FFI> parent;
|
||||||
@ -428,6 +435,9 @@ class CanvasModel with ChangeNotifier {
|
|||||||
|
|
||||||
double get scale => _scale;
|
double get scale => _scale;
|
||||||
|
|
||||||
|
set tabBarHeight(double h) => _tabBarHeight = h;
|
||||||
|
double get tabBarHeight => _tabBarHeight;
|
||||||
|
|
||||||
void updateViewStyle() async {
|
void updateViewStyle() async {
|
||||||
final s =
|
final s =
|
||||||
await parent.target?.bind.getSessionOption(id: id, arg: 'view-style');
|
await parent.target?.bind.getSessionOption(id: id, arg: 'view-style');
|
||||||
@ -435,8 +445,10 @@ class CanvasModel with ChangeNotifier {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final size = MediaQueryData.fromWindow(ui.window).size;
|
final size = MediaQueryData.fromWindow(ui.window).size;
|
||||||
final s1 = size.width / (parent.target?.ffiModel.display.width ?? 720);
|
final canvasWidth = size.width;
|
||||||
final s2 = size.height / (parent.target?.ffiModel.display.height ?? 1280);
|
final canvasHeight = size.height - _tabBarHeight;
|
||||||
|
final s1 = canvasWidth / (parent.target?.ffiModel.display.width ?? 720);
|
||||||
|
final s2 = canvasHeight / (parent.target?.ffiModel.display.height ?? 1280);
|
||||||
// Closure to perform shrink operation.
|
// Closure to perform shrink operation.
|
||||||
final shrinkOp = () {
|
final shrinkOp = () {
|
||||||
final s = s1 < s2 ? s1 : s2;
|
final s = s1 < s2 ? s1 : s2;
|
||||||
@ -467,8 +479,8 @@ class CanvasModel with ChangeNotifier {
|
|||||||
defaultOp();
|
defaultOp();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_x = (size.width - getDisplayWidth() * _scale) / 2;
|
_x = (canvasWidth - getDisplayWidth() * _scale) / 2;
|
||||||
_y = (size.height - getDisplayHeight() * _scale) / 2;
|
_y = (canvasHeight - getDisplayHeight() * _scale) / 2;
|
||||||
notifyListeners();
|
notifyListeners();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -491,15 +503,17 @@ class CanvasModel with ChangeNotifier {
|
|||||||
// On mobile platforms, move the canvas with the cursor.
|
// On mobile platforms, move the canvas with the cursor.
|
||||||
if (!isDesktop) {
|
if (!isDesktop) {
|
||||||
final size = MediaQueryData.fromWindow(ui.window).size;
|
final size = MediaQueryData.fromWindow(ui.window).size;
|
||||||
|
final canvasWidth = size.width;
|
||||||
|
final canvasHeight = size.height - _tabBarHeight;
|
||||||
final dw = getDisplayWidth() * _scale;
|
final dw = getDisplayWidth() * _scale;
|
||||||
final dh = getDisplayHeight() * _scale;
|
final dh = getDisplayHeight() * _scale;
|
||||||
var dxOffset = 0;
|
var dxOffset = 0;
|
||||||
var dyOffset = 0;
|
var dyOffset = 0;
|
||||||
if (dw > size.width) {
|
if (dw > canvasWidth) {
|
||||||
dxOffset = (x - dw * (x / size.width) - _x).toInt();
|
dxOffset = (x - dw * (x / canvasWidth) - _x).toInt();
|
||||||
}
|
}
|
||||||
if (dh > size.height) {
|
if (dh > canvasHeight) {
|
||||||
dyOffset = (y - dh * (y / size.height) - _y).toInt();
|
dyOffset = (y - dh * (y / canvasHeight) - _y).toInt();
|
||||||
}
|
}
|
||||||
_x += dxOffset;
|
_x += dxOffset;
|
||||||
_y += dyOffset;
|
_y += dyOffset;
|
||||||
@ -524,8 +538,11 @@ class CanvasModel with ChangeNotifier {
|
|||||||
if (isWebDesktop) {
|
if (isWebDesktop) {
|
||||||
updateViewStyle();
|
updateViewStyle();
|
||||||
} else {
|
} else {
|
||||||
_x = 0;
|
final size = MediaQueryData.fromWindow(ui.window).size;
|
||||||
_y = 0;
|
final canvasWidth = size.width;
|
||||||
|
final canvasHeight = size.height - _tabBarHeight;
|
||||||
|
_x = (canvasWidth - getDisplayWidth() * _scale) / 2;
|
||||||
|
_y = (canvasHeight - getDisplayHeight() * _scale) / 2;
|
||||||
}
|
}
|
||||||
notifyListeners();
|
notifyListeners();
|
||||||
}
|
}
|
||||||
@ -933,7 +950,8 @@ class FFI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Connect with the given [id]. Only transfer file if [isFileTransfer].
|
/// Connect with the given [id]. Only transfer file if [isFileTransfer].
|
||||||
void connect(String id, {bool isFileTransfer = false}) {
|
void connect(String id,
|
||||||
|
{bool isFileTransfer = false, double tabBarHeight = 0.0}) {
|
||||||
if (!isFileTransfer) {
|
if (!isFileTransfer) {
|
||||||
chatModel.resetClientMode();
|
chatModel.resetClientMode();
|
||||||
canvasModel.id = id;
|
canvasModel.id = id;
|
||||||
@ -954,7 +972,7 @@ class FFI {
|
|||||||
print('json.decode fail(): $e');
|
print('json.decode fail(): $e');
|
||||||
}
|
}
|
||||||
} else if (message is Rgba) {
|
} else if (message is Rgba) {
|
||||||
imageModel.onRgba(message.field0);
|
imageModel.onRgba(message.field0, tabBarHeight);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}();
|
}();
|
||||||
@ -979,7 +997,7 @@ class FFI {
|
|||||||
}
|
}
|
||||||
bind.sessionClose(id: id);
|
bind.sessionClose(id: id);
|
||||||
id = "";
|
id = "";
|
||||||
imageModel.update(null);
|
imageModel.update(null, 0.0);
|
||||||
cursorModel.clear();
|
cursorModel.clear();
|
||||||
ffiModel.clear();
|
ffiModel.clear();
|
||||||
canvasModel.clear();
|
canvasModel.clear();
|
||||||
@ -1027,8 +1045,7 @@ class FFI {
|
|||||||
|
|
||||||
RustdeskImpl get bind => ffiModel.platformFFI.ffiBind;
|
RustdeskImpl get bind => ffiModel.platformFFI.ffiBind;
|
||||||
|
|
||||||
handleMouse(Map<String, dynamic> evt) {
|
handleMouse(Map<String, dynamic> evt, {double tabBarHeight = 0.0}) {
|
||||||
debugPrint("mouse ${evt.toString()}");
|
|
||||||
var type = '';
|
var type = '';
|
||||||
var isMove = false;
|
var isMove = false;
|
||||||
switch (evt['type']) {
|
switch (evt['type']) {
|
||||||
@ -1046,7 +1063,7 @@ class FFI {
|
|||||||
}
|
}
|
||||||
evt['type'] = type;
|
evt['type'] = type;
|
||||||
var x = evt['x'];
|
var x = evt['x'];
|
||||||
var y = max(0.0, (evt['y'] as double) - 50.0);
|
var y = max(0.0, (evt['y'] as double) - tabBarHeight);
|
||||||
if (isMove) {
|
if (isMove) {
|
||||||
canvasModel.moveDesktopMouse(x, y);
|
canvasModel.moveDesktopMouse(x, y);
|
||||||
}
|
}
|
||||||
|
@ -276,10 +276,9 @@ async fn handle_received_peers(mut rx: UnboundedReceiver<config::DiscoveryPeer>)
|
|||||||
peers.insert(0, peer);
|
peers.insert(0, peer);
|
||||||
if last_write_time.elapsed().as_millis() > 300 {
|
if last_write_time.elapsed().as_millis() > 300 {
|
||||||
config::LanPeers::store(&peers);
|
config::LanPeers::store(&peers);
|
||||||
last_write_time = Instant::now();
|
|
||||||
|
|
||||||
#[cfg(feature = "flutter")]
|
#[cfg(feature = "flutter")]
|
||||||
crate::flutter_ffi::main_load_lan_peers();
|
crate::flutter_ffi::main_load_lan_peers();
|
||||||
|
last_write_time = Instant::now();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
@ -290,5 +289,7 @@ async fn handle_received_peers(mut rx: UnboundedReceiver<config::DiscoveryPeer>)
|
|||||||
}
|
}
|
||||||
|
|
||||||
config::LanPeers::store(&peers);
|
config::LanPeers::store(&peers);
|
||||||
|
#[cfg(feature = "flutter")]
|
||||||
|
crate::flutter_ffi::main_load_lan_peers();
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user