前言
Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面。
IT界著名的尼古拉斯·高尔包曾说:轮子是IT进步的阶梯!热门的框架千篇一律,好用轮子万里挑一!Flutter作为这两年开始崛起的跨平台开发框架,其第三方生态相比其他成熟框架还略有不足,但轮子的数量也已经很多了。本系列文章挑选日常app开发常用的轮子分享出来,给大家提高搬砖效率,同时也希望flutter的生态越来越完善,轮子越来越多。
本系列文章准备了超过50个轮子推荐,工作原因,尽量每1-2天出一篇文章。
tip:本系列文章合适已有部分flutter基础的开发者,入门请戳:flutter官网
正文
轮子
- 轮子名称:bot_toast
- 轮子概述:真正意义上的Toast,可以在任何你需要的时候调用,不会有任何限制(自动管理context).
- 轮子作者:vivaskerror@gmail.com
- 推荐指数:★★★★★
- 常用指数:★★★★★
-
效果预览:
安装
dependencies:
bot_toast: ^2.0.0+2
import 'package:bot_toast/bot_toast.dart';
概述
真正意义上的Toast,可以在任何你需要的时候调用,不会有任何限制! (这是他最重要的特点,跟别的Toast库不同的地方)
功能丰富,支持显示通知,文本,加载,附属等类型Toast
支持在弹出各种自定义Toast,或者说你可以弹出任何Widget,只要它符合flutter代码的要求即可
Api简单易用,基本上没有必要参数(包括BuildContext),基本上都是可选参数
纯flutter实现,不容易带来兼容问题
使用
初始化BotToast
//1.使用BotToastInit直接包裹MaterialApp
BotToastInit(
child:MaterialApp(
title: 'BotToast Demo',
navigatorObservers: [BotToastNavigatorObserver()],//2.注册路由观察者
home: XxxxPage(),
)
);
ps:这是我最喜欢的一点,直接在app根入口观察路由,自动管理当前的context,后续调用时无需再关心context,可以在任意地方调用。比如:在http工具类里进行全局错误拦截时弹出toast提示。
最简单的使用方式
BotToast.showText(text:"xxxx"); //弹出一个文本框;
BotToast.showSimpleNotification(title: "init"); //弹出简单通知Toast
BotToast.showLoading(); //弹出一个加载动画
//弹出一个定位Toast
BotToast.showAttachedWidget(
attachedWidget: (_) => Card(
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Icon(
Icons.favorite,
color: Colors.redAccent,
),
),
),
duration: Duration(seconds: 2),
target: Offset(520, 520));s
定制化使用
这款插件支持非常详细的定制化参数设置,内容太多,我就不贴出来了,详情请看:https://github.com/MMMzq/bot_toast/blob/master/API.md。
定制化效果图:
-
Notification风格定制
-
Attached风格定制
-
CustomAnimation风格定制
-
Loading风格定制
-
Text风格定制
-
CustomWidget风格定制