Flutter实战项目-第八篇 监听键盘弹起
生活随笔
收集整理的這篇文章主要介紹了
Flutter实战项目-第八篇 监听键盘弹起
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
概要
- 監(jiān)聽?wèi)?yīng)用軟鍵盤收齊彈出
一、WidgetsBindingObserver
????????WidgetsBindingObserver類可以使用于監(jiān)聽頁面的生命周期,根據(jù)用戶時(shí)間需求響應(yīng)響應(yīng)時(shí)間。
?didChangeMetrics在頁面高度發(fā)生變化的時(shí)候會觸發(fā)該回調(diào)。
class Chat extends StatefulWidget {const Chat({ Key? key }) : super(key: key);static const routeName = '/chat';@overrideState<Chat> createState() => _ChatState(); }class _ChatState extends State<Chat> with WidgetsBindingObserver{@overridevoid initState() {super.initState();//初始化WidgetsBinding.instance?.addObserver(this);}@overridevoid didChangeMetrics() {super.didChangeMetrics();WidgetsBinding.instance?.addPostFrameCallback((_) {setState(() {if(MediaQuery.of(context).viewInsets.bottom==0){//關(guān)閉鍵盤}else{//顯示鍵盤}});});}@overridevoid dispose() {scrollController.dispose();WidgetsBinding.instance?.removeObserver(this);super.dispose();}Widget build(BuildContext context) {return Containe();} }總結(jié)
以上是生活随笔為你收集整理的Flutter实战项目-第八篇 监听键盘弹起的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 李耳(老子)
- 下一篇: php药膳 源码,-道家药膳