作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Flutter 中使用 OrientationBuilder 打开键盘时如何避免方向改变?
确实,当键盘出现时,即使我们不旋转手机,OrientationBuilder 的方向属性也会更改为横向。
图片:
代码:
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: OrientationBuilder(builder: (context, orientation) {
var _children = [
Expanded(
child: Center(
child: Text('Orientation : $orientation',
textAlign: TextAlign.center))),
Flexible(
child: Container(color: Colors.blue, child: TextField())),
Flexible(child: Container(color: Colors.yellow)),
];
if (orientation == Orientation.portrait) {
return Column(
mainAxisAlignment: MainAxisAlignment.spaceAround,
children: _children);
} else {
return Row(
mainAxisAlignment: MainAxisAlignment.spaceAround,
children: _children);
}
})),
);
}
}
最佳答案
如何在使用 OrientationBuilder 打开键盘时避免方向改变,在 Scaffold
小部件中将 resizeToAvoidBottomInset 设置为 false
;
图片:
代码:
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
resizeToAvoidBottomInset: false, // Here
body: SafeArea(
child: Padding(
padding: const EdgeInsets.all(20.0),
child: OrientationBuilder(builder: (context, orientation) {
return Column(
children: [
Text('Orientation = $orientation',
style: TextStyle(
fontSize: 20, fontWeight: FontWeight.bold)),
TextField(
decoration: InputDecoration(
hintText: 'tap me',
),
)
],
);
}),
),
)),
);
}
}
关于flutter - 在 Flutter 中使用 OrientationBuilder 打开键盘时如何避免方向改变?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66692514/
在 Flutter 中使用 OrientationBuilder 打开键盘时如何避免方向改变? 确实,当键盘出现时,即使我们不旋转手机,OrientationBuilder 的方向属性也会更改为横向。
我是一名优秀的程序员,十分优秀!