install page use custom titlebar
Signed-off-by: 21pages <pages21@163.com>
This commit is contained in:
parent
4ce0a8852b
commit
7b80269dab
@ -1,7 +1,9 @@
|
|||||||
import 'package:file_picker/file_picker.dart';
|
import 'package:file_picker/file_picker.dart';
|
||||||
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/desktop/widgets/tabbar_widget.dart';
|
||||||
import 'package:flutter_hbb/models/platform_model.dart';
|
import 'package:flutter_hbb/models/platform_model.dart';
|
||||||
|
import 'package:flutter_hbb/models/state_model.dart';
|
||||||
import 'package:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
import 'package:url_launcher/url_launcher_string.dart';
|
import 'package:url_launcher/url_launcher_string.dart';
|
||||||
import 'package:window_manager/window_manager.dart';
|
import 'package:window_manager/window_manager.dart';
|
||||||
@ -13,7 +15,51 @@ class InstallPage extends StatefulWidget {
|
|||||||
State<InstallPage> createState() => _InstallPageState();
|
State<InstallPage> createState() => _InstallPageState();
|
||||||
}
|
}
|
||||||
|
|
||||||
class _InstallPageState extends State<InstallPage> with WindowListener {
|
class _InstallPageState extends State<InstallPage> {
|
||||||
|
final tabController = DesktopTabController(tabType: DesktopTabType.main);
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
Get.put<DesktopTabController>(tabController);
|
||||||
|
const lable = "install";
|
||||||
|
tabController.add(TabInfo(
|
||||||
|
key: lable,
|
||||||
|
label: lable,
|
||||||
|
closable: false,
|
||||||
|
page: _InstallPageBody(
|
||||||
|
key: const ValueKey(lable),
|
||||||
|
)));
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void dispose() {
|
||||||
|
super.dispose();
|
||||||
|
Get.delete<DesktopTabController>();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return DragToResizeArea(
|
||||||
|
resizeEdgeSize: stateGlobal.resizeEdgeSize.value,
|
||||||
|
child: Container(
|
||||||
|
child: Scaffold(
|
||||||
|
backgroundColor: Theme.of(context).colorScheme.background,
|
||||||
|
body: DesktopTab(controller: tabController)),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class _InstallPageBody extends StatefulWidget {
|
||||||
|
const _InstallPageBody({Key? key}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<_InstallPageBody> createState() => _InstallPageBodyState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _InstallPageBodyState extends State<_InstallPageBody>
|
||||||
|
with WindowListener {
|
||||||
late final TextEditingController controller;
|
late final TextEditingController controller;
|
||||||
final RxBool startmenu = true.obs;
|
final RxBool startmenu = true.obs;
|
||||||
final RxBool desktopicon = true.obs;
|
final RxBool desktopicon = true.obs;
|
||||||
|
@ -53,6 +53,7 @@ enum DesktopTabType {
|
|||||||
remoteScreen,
|
remoteScreen,
|
||||||
fileTransfer,
|
fileTransfer,
|
||||||
portForward,
|
portForward,
|
||||||
|
install,
|
||||||
}
|
}
|
||||||
|
|
||||||
class DesktopTabState {
|
class DesktopTabState {
|
||||||
@ -249,8 +250,9 @@ class DesktopTab extends StatelessWidget {
|
|||||||
this.unSelectedTabBackgroundColor,
|
this.unSelectedTabBackgroundColor,
|
||||||
}) : super(key: key) {
|
}) : super(key: key) {
|
||||||
tabType = controller.tabType;
|
tabType = controller.tabType;
|
||||||
isMainWindow =
|
isMainWindow = tabType == DesktopTabType.main ||
|
||||||
tabType == DesktopTabType.main || tabType == DesktopTabType.cm;
|
tabType == DesktopTabType.cm ||
|
||||||
|
tabType == DesktopTabType.install;
|
||||||
}
|
}
|
||||||
|
|
||||||
static RxString labelGetterAlias(String peerId) {
|
static RxString labelGetterAlias(String peerId) {
|
||||||
@ -361,7 +363,8 @@ class DesktopTab extends StatelessWidget {
|
|||||||
/// - hide single item when only has one item (home) on [DesktopTabPage].
|
/// - hide single item when only has one item (home) on [DesktopTabPage].
|
||||||
bool isHideSingleItem() {
|
bool isHideSingleItem() {
|
||||||
return state.value.tabs.length == 1 &&
|
return state.value.tabs.length == 1 &&
|
||||||
controller.tabType == DesktopTabType.main;
|
(controller.tabType == DesktopTabType.main ||
|
||||||
|
controller.tabType == DesktopTabType.install);
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget _buildBar() {
|
Widget _buildBar() {
|
||||||
@ -759,7 +762,8 @@ class _ListView extends StatelessWidget {
|
|||||||
/// - hide single item when only has one item (home) on [DesktopTabPage].
|
/// - hide single item when only has one item (home) on [DesktopTabPage].
|
||||||
bool isHideSingleItem() {
|
bool isHideSingleItem() {
|
||||||
return state.value.tabs.length == 1 &&
|
return state.value.tabs.length == 1 &&
|
||||||
controller.tabType == DesktopTabType.main;
|
controller.tabType == DesktopTabType.main ||
|
||||||
|
controller.tabType == DesktopTabType.install;
|
||||||
}
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
|
@ -293,16 +293,19 @@ void runInstallPage() async {
|
|||||||
await windowManager.ensureInitialized();
|
await windowManager.ensureInitialized();
|
||||||
await initEnv(kAppTypeMain);
|
await initEnv(kAppTypeMain);
|
||||||
_runApp('', const InstallPage(), MyTheme.currentThemeMode());
|
_runApp('', const InstallPage(), MyTheme.currentThemeMode());
|
||||||
windowManager.waitUntilReadyToShow(
|
WindowOptions windowOptions =
|
||||||
WindowOptions(size: Size(800, 600), center: true), () async {
|
getHiddenTitleBarWindowOptions(size: Size(800, 600), center: true);
|
||||||
|
windowManager.waitUntilReadyToShow(windowOptions, () async {
|
||||||
windowManager.show();
|
windowManager.show();
|
||||||
windowManager.focus();
|
windowManager.focus();
|
||||||
windowManager.setOpacity(1);
|
windowManager.setOpacity(1);
|
||||||
windowManager.setAlignment(Alignment.center); // ensure
|
windowManager.setAlignment(Alignment.center); // ensure
|
||||||
|
windowManager.setTitle(getWindowName());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
WindowOptions getHiddenTitleBarWindowOptions({Size? size}) {
|
WindowOptions getHiddenTitleBarWindowOptions(
|
||||||
|
{Size? size, bool center = false}) {
|
||||||
var defaultTitleBarStyle = TitleBarStyle.hidden;
|
var defaultTitleBarStyle = TitleBarStyle.hidden;
|
||||||
// we do not hide titlebar on win7 because of the frame overflow.
|
// we do not hide titlebar on win7 because of the frame overflow.
|
||||||
if (kUseCompatibleUiMode) {
|
if (kUseCompatibleUiMode) {
|
||||||
@ -310,7 +313,7 @@ WindowOptions getHiddenTitleBarWindowOptions({Size? size}) {
|
|||||||
}
|
}
|
||||||
return WindowOptions(
|
return WindowOptions(
|
||||||
size: size,
|
size: size,
|
||||||
center: false,
|
center: center,
|
||||||
backgroundColor: Colors.transparent,
|
backgroundColor: Colors.transparent,
|
||||||
skipTaskbar: false,
|
skipTaskbar: false,
|
||||||
titleBarStyle: defaultTitleBarStyle,
|
titleBarStyle: defaultTitleBarStyle,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user