这篇文章主要介绍“Flutter开发怎么实现底部留言板”,在日常操作中,相信很多人在Flutter开发怎么实现底部留言板问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Flutter开发怎么实现底部留言板”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
其实这个技术就是运用了动画这个功能封装实现的
初始化封装
/*初始化状态*/
initState() {
super.initState();
/*创建动画控制类对象*/
controller = new AnimationController(
duration: const Duration(milliseconds: 1000),
vsync: this);
/*创建补间对象*/
tween = new Tween(begin: 0.0, end: 1.0)
.animate(controller) //返回Animation对象
..addListener(() { //添加监听
setState(() {
Provide.value<IndexProvide>(context).changHeight(tween.value);
// print(tween.value); //打印补间插值
});
});
// controller.forward(); //执行动画
}
import 'package:flutter/material.dart';
void main(){
runApp(
MaterialApp(
debugShowCheckedModeBanner: false,
home: cityContent(),
)
);
}
class cityContent extends StatefulWidget {
cityContent({Key key}) : super(key: key);
_cityContentState createState() => _cityContentState();
}
class _cityContentState extends State<cityContent> with SingleTickerProviderStateMixin{
Animation<double> tween;
AnimationController controller;
/*初始化状态*/
initState() {
super.initState();
/*创建动画控制类对象*/
controller = new AnimationController(
duration: const Duration(milliseconds: 1000),
vsync: this);
/*创建补间对象*/
tween = new Tween(begin: 0.0, end: 1.0)
.animate(controller) //返回Animation对象
..addListener(() { //添加监听
setState(() {
Provide.value<IndexProvide>(context).changHeight(tween.value);
// print(tween.value); //打印补间插值
});
});
// controller.forward(); //执行动画
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: Stack(
children: <Widget>[
InkWell(
onTap: (){
// 动作反方向执行,即关闭留言板
controller.reverse();
},
child: ListView(
children: <Widget>[
Center(
child: InkWell(
onTap: (){
controller.forward(); //执行动画,即打开留言板
},
child: Text(
'打开底部抽屉'
),
)
),
],
),
),
Positioned(
bottom: 0,
child: Container(
margin: EdgeInsets.fromLTRB(20, 0, 20, 0),
height: 400*controller.value,
width: 300,
color: Colors.grey.shade300,
child: ListView(
// physics: NeverScrollableScrollPhysics(),
children: <Widget>[
Container(
margin: EdgeInsets.only(left: 240),
child: InkWell(
onTap: (){
// 动作反方向执行,即关闭留言板
controller.reverse();
},
child: Icon(Icons.clear),
)
),
Center(
child: Text('留言列表'),
)
],
),
)
),
],
)
);
}
}
到此,关于“Flutter开发怎么实现底部留言板”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。