PiuAnimation,piu~~~的一下,可用作加入购物车、保存截屏等动画特效
Pub.dev地址 piu_animation
GitHub地址: GitHub
Look
Simulator Screen Recording - iPhone 13 Pro - 2022-03-10 at 13.45.04.gif
无用功能第一弹:
悬停动画一【异步任务返回true】:
loading_true.gif
悬停动画二【异步任务返回false】:
loading_false.gif
添加方法【第一种,普通的缩放piu动画】
PiuAnimation.addAnimation(
rootKey, //主Widget GlobalKey
piuWidget, //Child
endOffset, //终点坐标
maxWidth: MediaQuery.of(context).size.width, //Child最大宽度
doSomethingBeginCallBack: () { //动画开始回调
print("动画开始");
},
doSomethingFinishCallBack: () { //动画结束回调
print("动画结束");
});
//其中还有动画时长、悬停最小宽度等属性设置
添加方法【第二种,悬停loading动画】
PiuAnimation.addAnimation(rootKey,piuWidget,endOffset,
maxWidth:MediaQuery.of(context).size.width,
loadingCallback:loadingCallBack,
doSomethingBeginCallBack:(){
print("动画开始");
},doSomethingFinishCallBack:(success){
if(success){
print("loading 成功 动画结束");
}else{
print("loading 失败 动画结束");
}
});
//异步方法定义,demo先通过delayed使用,正常业务逻辑中可以通过接口回调控制true和false
//任务成功
Future<bool> loadingSuccessFunction() {
return Future.delayed(const Duration(milliseconds: 2000),(){
return true;
});
}
//任务失败
Future<bool> loadingFieldFunction() {
return Future.delayed(const Duration(milliseconds: 2000),(){
return false;
});
}
使用方式详见main.dart
//通过GlobalKey获取终点坐标,及大小等
//demo终点坐标为按钮的中心点
RenderBox box = key.currentContext!.findRenderObject() as RenderBox;
var offset = box.localToGlobal(Offset.zero);
Offset endOffset =
Offset(offset.dx + box.size.width / 2, offset.dy + box.size.height / 2);