这篇文章主要为大家详细介绍了Flutter开发实现底部留言板,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了Flutter实现底部留言板的具体代码,供大家参考,具体内容如下
前言
现在大家基本上都会去接触抖音那款app,其中抖音中的留言区域的效果也是要前几天工作的需求,看了网上对这块并没有什么博客介绍。只能自己封装编写了。
主要技术
其实这个技术就是运用了动画这个功能封装实现的
实例代码分析
初始化封装
/*初始化状态*/
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('留言列表'),
)
],
),
)
),
],
)
);
}
}
现在这个大部分的功能是现在的,不过还是差一个手势的问题。我有一个初步的想法是结合状态管理可以做的,不过有一个bug,就是用手势来改变留言板的高度的时候,动画状态没有初始化。希望知道的小伙伴跟我探讨探讨。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程学习网。
沃梦达教程
本文标题为:Flutter开发实现底部留言板


基础教程推荐
猜你喜欢
- MVVMLight项目Model View结构及全局视图模型注入器 2023-05-07
- Flutter进阶之实现动画效果(三) 2022-10-28
- IOS获取系统相册中照片的示例代码 2023-01-03
- Android开发Compose集成高德地图实例 2023-06-15
- iOS Crash常规跟踪方法及Bugly集成运用详细介绍 2023-01-18
- Android实现短信验证码输入框 2023-04-29
- iOS开发使用XML解析网络数据 2022-11-12
- iOS开发 全机型适配解决方法 2023-01-14
- Android Compose自定义TextField实现自定义的输入框 2023-05-13
- iOS中如何判断当前网络环境是2G/3G/4G/5G/WiFi 2023-06-18