码迷,mamicode.com
首页 > 其他好文 > 详细

flutter 监听软键盘的弹出和关闭

时间:2020-05-17 01:34:51      阅读:146      评论:0      收藏:0      [点我收藏+]

标签:dingo   sbin   blog   resize   而且   idc   oar   sdn   controls   

官方有一个keyboard_visibility 插件,但是不推荐用问题很多 (好像作者已经不更新了 而且编译会导致build.gradle 报错) 

https://pub.dev/packages/keyboard_visibility

需要监听软键盘的弹出和隐藏 主要用  WidgetsBindingObserver 这个继承类

...
class BottomKeyboardInputState extends State<BottomKeyboardInput> with WidgetsBindingObserver {  

  @override
  void initState() {
    // TODO: implement initState
   
    super.initState();
    //初始化
    WidgetsBinding.instance.addObserver(this);
   }



     @override
  void didChangeMetrics() {
    super.didChangeMetrics();
    WidgetsBinding.instance.addPostFrameCallback((_) {
      setState(() {
       

          if(MediaQuery.of(context).viewInsets.bottom==0){
            //关闭键盘

             
           }else{
            //显示键盘
          }
 
        

      });
    });
  }




   @override
  void dispose() {
    // TODO: implement dispose
    //销毁
    WidgetsBinding.instance.removeObserver(this);

    super.dispose();
  }

}
...

 

 
技术图片
//注意  

MediaQuery.of(context).viewInsets.bottom获取键盘高度如果无论如何都是0 就查看父级组件的

 child: Scaffold(
              resizeToAvoidBottomInset:false,//只要子组件需要监听键盘高度  父组件的所有该属性都应该设置false
              appBar: CenterTitleAppBar(
                title: ‘页面title‘,
              ),
              body: ContentPage(),
 ),

 

 
技术图片

 可以参考拓展

https://blog.csdn.net/weixin_34082177/article/details/91370675

flutter 监听软键盘的弹出和关闭

标签:dingo   sbin   blog   resize   而且   idc   oar   sdn   controls   

原文地址:https://www.cnblogs.com/tianmiaogongzuoshi/p/12902917.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!