Skip to content

Latest commit

 

History

History
215 lines (161 loc) · 6.12 KB

README-ZH.md

File metadata and controls

215 lines (161 loc) · 6.12 KB

tray_manager

pub version

这个插件允许 Flutter 桌面应用定义系统托盘。


English | 简体中文


平台支持

Linux macOS Windows
✔️ ✔️ ✔️

截图

macOS Linux Windows
image

已知问题

与 app_links 不兼容

当同时使用 app_links 包和 tray_manager 时,可能会出现插件无法正常工作。这是因为低版本 app_links 在内部阻止了事件传播,导致菜单点击事件无法触发。

要解决此问题:

  1. 确保你的 app_links 包版本大于或等于 6.3.3
dependencies:
  app_links: ^6.3.3
  1. 使用 protocol_handler 包代替 app_links 包。

快速开始

安装

将此添加到你的软件包的 pubspec.yaml 文件:

dependencies:
  tray_manager: ^0.3.1

dependencies:
  tray_manager:
    git:
      url: https://github.com/leanflutter/tray_manager.git
      ref: main

Linux requirements

  • ayatana-appindicator3-0.1 or appindicator3-0.1

运行以下命令

sudo apt-get install libayatana-appindicator3-dev

sudo apt-get install appindicator3-0.1 libappindicator3-dev

用法

import 'package:flutter/material.dart' hide MenuItem;
import 'package:tray_manager/tray_manager.dart';

await trayManager.setIcon(
  Platform.isWindows
    ? 'images/tray_icon.ico'
    : 'images/tray_icon.png',
);
Menu menu = Menu(
  items: [
    MenuItem(
      key: 'show_window',
      label: 'Show Window',
    ),
    MenuItem.separator(),
    MenuItem(
      key: 'exit_app',
      label: 'Exit App',
    ),
  ],
);
await trayManager.setContextMenu(menu);

请看这个插件的示例应用,以了解完整的例子。

监听事件

import 'package:flutter/material.dart';
import 'package:tray_manager/tray_manager.dart';

class HomePage extends StatefulWidget {
  @override
  _HomePageState createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> with TrayListener {
  @override
  void initState() {
    trayManager.addListener(this);
    super.initState();
    _init();
  }

  @override
  void dispose() {
    trayManager.removeListener(this);
    super.dispose();
  }

  void _init() {
    // ...
  }

  @override
  Widget build(BuildContext context) {
    // ...
  }

  @override
  void onTrayIconMouseDown() {
    // do something, for example pop up the menu
    trayManager.popUpContextMenu();
  }

  @override
  void onTrayIconRightMouseDown() {
    // do something
  }

  @override
  void onTrayIconRightMouseUp() {
    // do something
  }

  @override
  void onTrayMenuItemClick(MenuItem menuItem) {
    if (menuItem.key == 'show_window') {
      // do something
    } else if (menuItem.key == 'exit_app') {
       // do something
    }
  }
}

谁在用使用它?

  • Airclap - 任何文件,任意设备,随意发送。简单好用的跨平台高速文件传输 APP。
  • Biyi (比译) - 一个便捷的翻译和词典应用程序。

API

TrayManager

Method Description Linux macOS Windows
destroy 立即销毁托盘图标 ✔️ ✔️ ✔️
setIcon 设置与此托盘图标相关的图片。 ✔️ ✔️ ✔️
setIconPosition 设置托盘图标的图标位置。 ✔️
setToolTip 设置此托盘图标的悬停文本。 ✔️ ✔️
setContextMenu 设置此图标的上下文菜单。 ✔️ ✔️ ✔️
popUpContextMenu 弹出托盘图标的上下文菜单。 ✔️ ✔️
getBounds 返回 Rect 这个托盘图标的边界。 ✔️ ✔️

许可证

MIT