Flutter桌面应用开发之毛玻璃效果

目录

毛玻璃效果:毛玻璃效果是一种模糊化的视觉效果,常用于图像处理和界面设计中。它可以通过在图像或界面元素上应用高斯模糊来实现。使用毛玻璃效果可以增加图像或界面元素的柔和感,同时减少细节的清晰度。

效果

实现方案

依赖库

flutter_acrylic

支持平台

Windows, macOS & Linux

实现步骤

  1. 在pubspec.yaml中添加依赖

    dependencies:
    ...
    flutter_acrylic: ^1.1.3

  2. 在main函数中初始化插件

    Future<void> main() async {
    ....
    WidgetsFlutterBinding.ensureInitialized();
    await Window.initialize();
    ....
    runApp(const MyApp());
    }

  3. 使用毛玻璃效果

毛玻璃效果配置选项:

WindowEffect.acrylic:Windows 10 1803 及以上版本

WindowEffect.aero:Windows 10 1803以下版本

复制代码
Future<void> _applyAcrylicV1() async {
 
  Color color =
  Platform.isWindows ? const Color(0xb3ffffff) : Colors.transparent;
  //effect:背景效果
  //color:毛玻璃背景颜色及透明度
  //dark:是否是暗色模式
  await Window.setEffect(effect: WindowEffect.acrylic, color: color, dark: true);
}
  1. 配置Scaffold的背景颜色为透明

    Scaffold(
    backgroundColor: Colors.transparent,
    ...
    );

注意事项

1.必须配置Scaffold的背景颜色为透明,否则毛玻璃效果无法出现,如下图

  1. Windows不同版本必须选择对应的配置选项,否则会有性能问题。如在Windows 10 1803以下版本使用WindowEffect.acrylic,拖动窗口会严重卡顿;
  2. 开发环境为Window 10时,已运行程序点击Run重新运行,会导致毛玻璃效果异常,显示FlutterWindow的边框和标题栏;

(1)Flutter Hot Reload不会导致该问题;

(2)Release 版本不存在该问题;

(3)开发环境为Window11不存在该问题;

话题扩展

1.如何获取Windows版本?

Windows不同版本必须选择对应的配置选项,那又如何获取Windows版本了?

  1. 如何去掉窗口标题栏?

(1)标题栏不美观,想去掉怎么办?

(2)有需求需要在标题栏新增功能怎么办?

  1. 开发环境为Window 10的情况下,如何规避毛玻璃效果下显示FlutterWindow的边框和标题栏?

(1)就是关闭程序,重新运行即可;

(2)从控制FlutterWindow边框和标题栏方面探索

相关推荐
CodeOfCC1 天前
flutter-elinux 编译linux arm64程序
linux·flutter
kirk_wang1 天前
Flutter艺术探索-StatelessWidget与StatefulWidget区别与使用场景
flutter·移动开发·跨平台
搬砖的kk1 天前
Flutter OH 3.35.7 Dev 版本发布 | 快速体验指南
flutter
未来猫咪花1 天前
tp_router: 再也不用手动写路由表了
flutter
程序员老刘·1 天前
ArkUI-X 6.0 跨平台框架能否取代 Flutter?
flutter·鸿蒙系统·跨平台开发·客户端开发
哈__1 天前
Flutter For OpenHarmony 鸿蒙 PC 开发入门:环境搭建 + 工程初始化(附 PC 端专属配置)
flutter·华为·harmonyos
前端不太难1 天前
Flutter 列表 rebuild 的真正边界在哪里
flutter·状态模式
kirk_wang1 天前
Flutter艺术探索-Flutter常用UI组件:Text、Image、Button详解
flutter·移动开发·跨平台
前端不太难1 天前
为什么 Debug 模式下 Flutter 列表“看起来很卡”
flutter·状态模式
Ycocol1 天前
Flutter项目运行在浏览器无法访问
前端·flutter