Flutter 软键盘导致界面重绘的问题

使用Flutter开发应用时,遇到在自定义百度地图页面输入时键盘遮挡导致页面空白的问题。解决方案是在Scaffold中设置resizeToAvoidBottomPadding为false,解决了重绘引发的加载异常。

用Flutter 开发的应用,在自己搭建的百度地图页面,点击进入一个界面输入内容,发现弹出键盘会出现在第一个百度页面出现空白的问题,并且在控制行抛出错误,

E/BufferQueueProducer(19941): [SurfaceTexture-0-19941-2](id:4de500000027,api:0,p:-1,c:19941) dequeueBuffer: BufferQueue has no connected producer

查找了资料发现,因为弹出的键盘导致页面进行了重绘,所以百度地图加载了异常,所以解决方案为

在Scafford  中设置 resizeToAvoidBottomPadding: false,

然后就显示正常了。

 

Flutter中,可以通过使用`WidgetsBinding`来监听软键盘的弹起和收起事件,同时使用`SingleChildScrollView`来为布局进行滚动以适应软键盘的高度。 要实现软键盘弹起布局,可以按照以下步骤进行: 1. 导入必要的包: ```dart import 'package:flutter/material.dart'; import 'package:flutter/scheduler.dart'; ``` 2. 创建一个`StatefulWidget`,该组件将包含你的布局: ```dart class MyLayout extends StatefulWidget { @override _MyLayoutState createState() => _MyLayoutState(); } class _MyLayoutState extends State<MyLayout> { // 声明一个控制器来获取文本输入框的焦点 final FocusNode _focusNode = FocusNode(); // 监听软键盘状态 @override void initState() { super.initState(); // 在布局构建完成后开始监听软键盘事件 SchedulerBinding.instance.addPostFrameCallback((_) { _focusNode.addListener(() { if (_focusNode.hasFocus) { // 获取焦点时,键盘弹起 _scrollToBottom(); } }); }); } // 滚动到底部 void _scrollToBottom() { SchedulerBinding.instance.addPostFrameCallback((_) { Scrollable.ensureVisible( _focusNode.currentContext!, duration: const Duration(milliseconds: 300), ); }); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text('Flutter软键盘弹起布局'), ), body: SingleChildScrollView( child: Column( children: <Widget>[ // your content here TextFormField( focusNode: _focusNode, // 将焦点设置给文本输入框 decoration: InputDecoration( labelText: '文本输入框', ), ), // more widgets... ], ), ), ); } } ``` 3. 在Flutter应用的入口处使用该布局: ```dart void main() { runApp(MyApp()); } class MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return MaterialApp( home: MyLayout(), ); } } ``` 通过以上步骤,可以实现一个监听软键盘弹起的布局。当文本输入框获得焦点时,布局可以自动滚动到底部以适应软键盘的高度。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值