multi_window_manager 1.1.4 copy "multi_window_manager: ^1.1.4" to clipboard
multi_window_manager: ^1.1.4 copied to clipboard

Flutter desktop plugin for creating and managing multiple windows, including resizing, repositioning, and inter-window communication.

example/lib/main.dart

import 'dart:convert';

import 'package:bot_toast/bot_toast.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:multi_window_manager/multi_window_manager.dart';
import 'package:multi_window_manager_example/pages/home.dart';
import 'package:multi_window_manager_example/utils/config.dart';

void main(List<String> args) async {
  if (kDebugMode) {
    print(args);
  }

  WidgetsFlutterBinding.ensureInitialized();

  final windowId = args.isEmpty ? 0 : int.tryParse(args[0]) ?? 0;
  final Map<String, dynamic> argsMap =
      args.isEmpty ? {} : {'arg1': args[1], 'arg2': args[2]};
  final isReusable =
      args.length > 3 ? jsonDecode(args[3])['isReusable'] : false;
  windowId == 0
      ? await MultiWindowManager.ensureInitialized(windowId)
      : await MultiWindowManager.ensureInitializedSecondary(
          windowId,
          isEnabledReuse: isReusable,
        );

  WindowOptions windowOptions = WindowOptions(
    size: const Size(800, 600),
    center: true,
    backgroundColor: Colors.transparent,
    skipTaskbar: false,
    titleBarStyle: TitleBarStyle.hidden,
    windowButtonVisibility: false,
    title: 'Window ID ${MultiWindowManager.current.id}',
  );
  MultiWindowManager.current.waitUntilReadyToShow(windowOptions, () async {
    await MultiWindowManager.current.show();
    await MultiWindowManager.current.focus();
  });

  runApp(MyApp(
    isSecondary: windowId != 0,
    args: argsMap,
  ));
}

class MyApp extends StatefulWidget {
  const MyApp({super.key, required this.isSecondary, required this.args});

  final Map<String, dynamic> args;
  final bool isSecondary;

  @override
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  ThemeMode _themeMode = ThemeMode.light;

  @override
  void initState() {
    sharedConfigManager.addListener(_configListen);
    super.initState();
  }

  @override
  void dispose() {
    sharedConfigManager.removeListener(_configListen);
    super.dispose();
  }

  void _configListen() {
    _themeMode = sharedConfig.themeMode;
    setState(() {});
  }

  @override
  Widget build(BuildContext context) {
    final virtualWindowFrameBuilder = VirtualWindowFrameInit();
    final botToastBuilder = BotToastInit();

    return MaterialApp(
      debugShowCheckedModeBanner: false,
      themeMode: _themeMode,
      builder: (context, child) {
        child = virtualWindowFrameBuilder(context, child);
        child = botToastBuilder(context, child);
        return child;
      },
      navigatorObservers: [BotToastNavigatorObserver()],
      home: widget.isSecondary
          ? ReusableWindow(
              initialArgs: widget.args,
              windowOptions: WindowOptions(
                size: const Size(800, 600),
                center: true,
                backgroundColor: Colors.transparent,
                skipTaskbar: false,
                titleBarStyle: TitleBarStyle.hidden,
                windowButtonVisibility: false,
                title: 'Window ID ${MultiWindowManager.current.id}',
              ),
              loadingBuilder: (context) => const Center(
                child: SizedBox(
                  height: 60,
                  width: 60,
                  child: CircularProgressIndicator(),
                ),
              ),
              builder: (context, args) {
                final Map<String, dynamic> argsMap =
                    args.isEmpty ? {} : {'arg1': args[0], 'arg2': args[1]};
                debugPrint('args: $args');

                return const HomePage();
              },
            )
          : const HomePage(),
    );
  }
}
2
likes
140
points
378
downloads

Documentation

API reference

Publisher

unverified uploader

Weekly Downloads

Flutter desktop plugin for creating and managing multiple windows, including resizing, repositioning, and inter-window communication.

Repository (GitHub)
View/report issues

Topics

#window #window-resize #window-manager #multi-window #desktop

License

MIT (license)

Dependencies

flutter, meta, path, screen_retriever

More

Packages that depend on multi_window_manager

Packages that implement multi_window_manager