当前位置: 首页 > news >正文

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

目录

  • 效果
  • 实现方案
    • 依赖库
    • 支持平台
    • 实现步骤
    • 注意事项
    • 话题扩展

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

效果

在这里插入图片描述

实现方案

依赖库

flutter_acrylic

支持平台

Windows, macOS & Linux

实现步骤

  1. 在pubspec.yaml中添加依赖
 dependencies:...flutter_acrylic: ^1.1.3
  1. 在main函数中初始化插件
Future<void> main() async {....WidgetsFlutterBinding.ensureInitialized();await Window.initialize();....runApp(const MyApp());
}
  1. 使用毛玻璃效果

毛玻璃效果配置选项:
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版本了?
2. 如何去掉窗口标题栏?

(1)标题栏不美观,想去掉怎么办?
(2)有需求需要在标题栏新增功能怎么办?

在这里插入图片描述

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

(1)就是关闭程序,重新运行即可;
(2)从控制FlutterWindow边框和标题栏方面探索

在这里插入图片描述

http://www.lryc.cn/news/249241.html

相关文章:

  • 基于C#实现优先队列
  • ssm+vue的仓库在线管理系统的设计与实现(有报告)。Javaee项目,ssm vue前后端分离项目。
  • 什么是木马
  • Pinia仓库统一管理
  • [论文阅读]VoxSet——Voxel Set Transformer
  • 【开源】基于Vue.js的医院门诊预约挂号系统的设计和实现
  • 1、Mysql架构与历史
  • 考试复习
  • 使用Docker一键安装MySQL与Nginx脚本
  • VMware系列:Vmware vSphere常见问题及解决办法
  • 基于web宠颐生宠物医院系统设计与实现
  • 二、Gitee使用方法
  • 【C++】string模拟
  • python高级练习题库实验1(A)部分
  • 数据库应用:MongoDB 数据备份与恢复
  • MySQL-函数
  • 【12】Python函数专题(下)
  • 国标GB28181协议/RTSP视频监控汇聚平台EasyCVR(V.3.4)页面UI大更新
  • 生成式AI与预测式AI的主要区别与实际应用
  • 【JavaEE】多线程 -- 死锁问题
  • XTU OJ 1339 Interprime 学习笔记
  • 【Web安全】xss攻击方式与绕过
  • 文件夹重命名技巧:用关键词替换文件夹名称指定内容的右侧文字
  • python pip安装第三方包时报错 error: Microsoft Visual C++ 14.0 or greater is required.
  • 对 .NET程序2G虚拟地址紧张崩溃 的最后一次反思
  • HCIA-RS基础-静态路由协议
  • LeetCode(46)汇总区间【区间】【简单】
  • 数据预处理:随机裁剪放缩
  • RabbitMQ 搭建和工作模式
  • 一起学docker系列之七docker容器卷技术