Flutter关于软键盘的一些问题

news2025/1/15 13:11:43

Scaffold类有个resizeToAvoidBottomInset 属性,它的作用是当弹出软键盘的时候,可以自动调节body区域的高度,撑起body的内容,使其底部高度刚好为键盘的高度,这样一来就不至于让键盘覆盖内容。

Scaffold( /// ..... /// 当弹出软键盘的时候,是否自动调节body区域,默认为true resizeToAvoidBottomInset: true, /// .....
) 

resizeToAvoidBottomInset 默认值为true,自动调节body的高度,设置为false则停止这一行为。当然resizeToAvoidBottomInset 为ture,自动调节高度也是需要条件的:

1、body区域不能为一个滚动区域。

如使用了SingleChildScrollViewListView包裹,它就会失去自动调节的功能,道理很简单,因为一个非固定高度的组件它无法自动计算高度。

2、需要存在TextField组件

一般来说当存在TextField组件,才会出现软键盘,resizeToAvoidBottomInset 才会有作用。

body自动调节高度会存在一些组件重叠问题,引起界面错乱。因为body的高度改变了,如果body中的组件依赖于高度,就会产生畸变。所以为了避免这个问题你可以选择将resizeToAvoidBottomInset 设置为false,只是软键盘遮挡问题仍然存在。当然,还是有解决的方法的:

这个时候你可以通过判断键盘是否弹起,给body的底部增加一个SizedBox高度,就能解决这个问题。但,这里存在三个技术问题:

1、我要怎么判断键盘是否弹起?

继承WidgetsBindingObserver类,重写didChangeMetrics方法,该方法可用于检测页面的变化,软键盘的弹出和收起都会触发应该事件。然后通过判断MediaQuery.of(context).viewInsets.bottom的值来确定键盘是否弹起。当它的值大于0时,说明键盘弹起,反之为收起。

class _KeyboardDemoState extends State<KeyboardDemo>with WidgetsBindingObserver {// 键盘是否打开bool isKeyboardOpen = false;@overridevoid initState() {super.initState();// 注册监听WidgetsBinding.instance?.addObserver(this);}@overridevoid dispose() {super.dispose();// 移除监听WidgetsBinding.instance?.removeObserver(this);}/// 页面尺寸改变时回调@overridedidChangeMetrics() {super.didChangeMetrics();// 在页面重新渲染完成之后,通过MediaQuery.of(context).viewInsets.bottom获取软键盘高度WidgetsBinding.instance?.addPostFrameCallback((timeStamp) {isKeyboardOpen = MediaQuery.of(context).viewInsets.bottom > 0;});}/// .....
} 

2、我要怎么获取当前键盘的高度?

答案已经在上面说了,MediaQuery.of(context).viewInsets.bottom 就是获取当前软键盘的高度。

3、我要怎么关闭软键盘?

可能有人会说,这是个问题吗,直接点击软键盘上的三角图标不就行了。问出这个问题的人,估计是没有考虑过ios系统。

在iOS中,系统默认的软键盘是没有收起的按钮的。这个时候我们就要想个办法来处理软键盘收起问题。一般来说我们都会在键盘以外的区域增加一个单击事件,然后使用FocusManager.instance.primaryFocus?.unfocus()将键盘关闭。

GestureDetector( /// 点击内容包含透明区域 behavior: HitTestBehavior.opaque, onTap: () { /// 取消当前软键盘焦点并收起 FocusManager.instance.primaryFocus?.unfocus(); }
} 

那么,单击事件使用什么组件呢?这里还是有些讲究的,可以使用InkWell或者GestureDetectoronTap事件 ,但前者点击时会产生水波纹的效果 ,后者要注意点击区域,默认情况下GestureDetector的onTap单击事件点击区域是不包括透明区域的,需要将behavior属性设为 HitTestBehavior.opaque,包含透明区域,不然你可能在空白区域点半天,也没见键盘收起。当然,我比较推荐使用GestureDetector来处理单击事件。

完整代码:

import 'package:flutter/material.dart';

class KeyboardDemo extends StatefulWidget {final String inquiryCode;const KeyboardDemo({Key? key,required this.inquiryCode,}) : super(key: key);@overrideState<KeyboardDemo> createState() => _KeyboardDemoState();
}

class _KeyboardDemoState extends State<KeyboardDemo>with WidgetsBindingObserver {// 键盘是否打开bool isKeyboardOpen = false;@overridevoid initState() {super.initState();// 注册监听WidgetsBinding.instance?.addObserver(this);}@overridevoid dispose() {super.dispose();// 移除监听WidgetsBinding.instance?.removeObserver(this);}/// 页面尺寸改变时回调@overridedidChangeMetrics() {super.didChangeMetrics();// 在页面重新渲染完成之后,通过MediaQuery.of(context).viewInsets.bottom获取软键盘高度WidgetsBinding.instance?.addPostFrameCallback((timeStamp) {isKeyboardOpen = MediaQuery.of(context).viewInsets.bottom > 0;});}@overrideWidget build(BuildContext context) {return Scaffold(appBar: PreferredSize(preferredSize: const Size.fromHeight(5),child: Container(color: Colors.white,),),/// 当弹出软键盘的时候,是否自动调节body区域,默认为trueresizeToAvoidBottomInset: false,body: GestureDetector(/// 点击内容包含透明区域behavior: HitTestBehavior.opaque,onTap: () {/// 取消当前软键盘焦点并收起FocusManager.instance.primaryFocus?.unfocus();},child: Column(mainAxisAlignment: MainAxisAlignment.spaceBetween,children: [SizedBox(height: 200,child: Container(margin: const EdgeInsets.all(12),padding: const EdgeInsets.all(12),decoration: BoxDecoration(border: Border.all(width: 1.r,color: Colors.black,)),child: const TextField(decoration: InputDecoration(hintText: '请输入内容',border: InputBorder.none,),),),),Container(width: double.infinity,margin: EdgeInsets.only(bottom: MediaQuery.of(context).viewInsets.bottom),child: ElevatedButton(onPressed: () {},child: const Text('确定'),),),],),),);}
} 

最后

最近找到一个VUE的文档,它将VUE的各个知识点进行了总结,整理成了《Vue 开发必须知道的36个技巧》。内容比较详实,对各个知识点的讲解也十分到位。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/142952.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

教你如何搭建CRM—商机管理系统的demo

1、简介 1.1、案例简介 本文将介绍&#xff0c;如何搭建CRM-商机管理。 1.2、应用场景 CRM-商机管理应用完整记录所有商机资料&#xff0c;合理的对商机进行销售阶段的变更&#xff0c;实现商机管理智能化。 2、设置方法 2.1、表单搭建 1&#xff09;新建主表【商机】表…

进程间通信——共享内存

目录 1 概念 2 操作流程 fork(获取key值) shmget(申请对象) shmat(内存映射) 读写共享内存&#xff1a;类似堆区内存的直接读写 shmdt(解除映射) shmctl(删除对象) 范例&#xff1a; 1 概念 共享内存是进程间通信中最简单最高效的方式之一。共享内存允许两个或更多进程…

使用Python的Selenium进行网络自动化的入门教程

使用Python的Selenium进行网络自动化入门 自动化可以被看作是在使用电子机器或机器人来执行任务的过程中去除人力的过程。 在这篇文章中&#xff0c;我们将研究网络流程的自动化。 让软件机器人在网络上自动执行流程和任务的能力被称为网络自动化。 使用网络自动化&#xf…

2022年协议转让投资策略研究报告

第一章 协议转让的概念 协议转让是指双方当事人就转让标的物所有权达成协议&#xff0c;是典型的商业交易方式。而在破产案件中&#xff0c;则是一种有别于拍卖和以物抵债的处置财产的方式。根据《企业破产法》第112条&#xff0c;变价出售财产应当通过拍卖进行。但是&#xf…

云原生|kubernetes|安全漏扫神器trivy的部署和使用

前言&#xff1a; 云原生领域内的安全漏扫工具有clair和trivy是比较常用的&#xff0c;而安全漏扫工具是可以和harbor这样的私有仓库集成的&#xff0c;自harbor-1.21版以后都是默认使用trivy这个漏扫工具的&#xff0c;而在此之前是使用clair的。 那么&#xff0c;本文将就什…

实验十七 VLAN间的三层通信

实验十七 VLAN间的三层通信配置要求&#xff1a;通过三层交换机实现VLAN间互通通过单臂路由实现VLAN间互通网络拓扑图&#xff1a;操作步骤&#xff1a;一、 通过三层交换机实现VLAN间互通1、配置交换机LSW1的接口为trunk接口&#xff0c;g0/0/1口允许vlan 10通过&#xff0c;g…

构建器/生成器模式Builder

1.意图&#xff1a;将一个复杂对象的构建与它的表示分离&#xff0c;使得同样的构建过程可以创建不同的表示。 2.结构 Builder为创建一个Product对象的各个部件指定抽象接口。 ConcreteBuilder实现Builder的接口以构造和装配该产品的各个部件&#xff0c;定义并明确它所创建的…

实验十五 IS-IS协议基本配置

实验十五 IS-IS协议基本配置IS-IS(中间系统到中间系统)协议与OSPF(开放最短路径优先)协议有许多类似之处&#xff0c; 如都是链路状态的IGP路由协议&#xff0c;采用的都SPF路由算法&#xff0c;都划分了区域。为了支持大规模 的路由网络&#xff0c;IS-IS在自治系统内采用骨丁…

四、MySQL 存储引擎及数据类型

文章目录一、前置知识二、MySQL 存储引擎(先了解&#xff0c;初步有个印象)2.1 MySQL 存储引擎的概念2.2 查询 MySQL 中支持的存储引擎2.3 InnoDB 存储引擎2.4 MyISAM 存储引擎2.5 MEMORY 存储引擎2.6 如何选择 MySQL 存储引擎&#xff1f;三、MySQL 数据类型3.1 数字类型3.2 日…

Dataway让SpringBoot不在需要Controller、Service、DAO、Mapper了

Dataway介绍 Dataway 是基于 DataQL 服务聚合能力&#xff0c;为应用提供的一个接口配置工具。使得使用者无需开发任何代码就配置一个满足需求的接口。整个接口配置、测试、冒烟、发布。一站式都通过 Dataway 提供的 UI 界面完成。UI 会以 Jar 包方式提供并集成到应用中并和应用…

君子签用区块链打造电子合同证据链闭环,提升电子合同证据效力

电子合同作为电子证据的主要表现形式&#xff0c;采用电子合同发生纠纷时&#xff0c;相关的电子合同数据成为证据证明的关键。运用区块链去中心化、分布式存储、加密可溯源等技术特性&#xff0c;让电子合同的整个过程都可以在互联网上安全地进行&#xff0c;帮助打通数据信任…

JavaERP系统源码+数据库,业务闭环、灵活稳定的企业级ERP系统,真正的财务业务一体化系统

JavaERP系统源码数据库&#xff0c;业务闭环、灵活稳定的企业级ERP系统&#xff0c;真正的财务业务一体化系统 完整代码下载地址&#xff1a;JavaERP系统源码数据库 产品展示 社区版 主界面 权限模块 职员与组织 科目结构 库存管理 库存盘点 订单管理 出入库管理 凭…

【Spring【AOP】】——21、@EnableAspectJAutoProxy注解详解?

&#x1f4eb;作者简介&#xff1a;zhz小白 公众号&#xff1a;小白的Java进阶之路 专业技能&#xff1a; 1、Java基础&#xff0c;并精通多线程的开发&#xff0c;熟悉JVM原理 2、熟悉Java基础&#xff0c;并精通多线程的开发&#xff0c;熟悉JVM原理&#xff0c;具备⼀定的线…

Docker二进制安装

目录 1、选择安装目录 2、了解默认安装 3、Docker网络了解 docker官网 1、选择安装目录 安装包下载 链接&#xff1a;https://pan.baidu.com/s/1mbUl2XLnlN4xZuHbvRF-vg?pwdpdoq 提取码&#xff1a;pdoq docker官网 1、选择安装目录 docker指定数据存储目录到 /data/…

mysql 乐观锁和悲观锁

悲观锁介绍&#xff08;百科&#xff09;&#xff1a; 悲观锁&#xff0c;正如其名&#xff0c;它指的是对数据被外界&#xff08;包括本系统当前的其他事务&#xff0c;以及来自外部系统的事务处理&#xff09;修改持保守态度&#xff0c;因此&#xff0c;在整个数据处理过程中…

二叉树的一些练习题

前言 二叉树的简单题目&#xff0c;通过画栈帧图去理解过程。画一画&#xff0c;走一走递归过程&#xff0c;理解会更加深刻。 二叉树练习题前言二叉树的创建二叉树先序遍历创建PreCreat二叉树层次创建LevelCreat二叉树的销毁BinaryTreeDestory二叉树求节点个数BinaryTreeSize二…

关于C语言输入输出的逗号问题(小细节)

C语言的输入输出必须要遵循scanf和printf的格式&#xff0c;就是你是什么格式你就要输入什么。 一、输入问题 #include <stdio.h> int main() { int a,b;scanf("%d,%d",&a,&b);printf("ab%d",ab);return 0; } 这个程序我们可以看到它运行…

【雷达开源数据集 | 代尔夫特数据集(VOD),4D雷达、激光雷达和相机数据】

本文编辑&#xff1a;调皮哥的小助理 1、介绍 代尔夫特视图 &#xff08;VoD&#xff09; 数据集是一种新颖的汽车数据集&#xff0c;包含 8600 帧同步和校准的 64 层 LiDAR、&#xff08;立体&#xff09;摄像头和 31D 雷达数据&#xff0c;这些数据是在复杂的城市交通中采集…

《编码 - 代码分析》代码结构分析

1 代码结构分析概述 在编写代码时&#xff0c;要求要结构清晰、接口简单。如果代码结构过于复杂&#xff0c;会带来很多问题&#xff1a;代码很难被理解&#xff0c;不方便编写测试用例&#xff0c;容易隐藏错误&#xff0c;出现问题难以定位&#xff0c;修改代码容易产生新的…

基于Java+SpringBoot+vue+elementui的校园文具商城系统详细设计和实现

基于JavaSpringBootvueelementui的校园文具商城系统详细设计和实现 博主介绍&#xff1a;5年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 超级帅帅吴 欢迎点赞 收藏 ⭐留言 文末获取源码联系方式 文章目录基…