是否有一种简单的(非LayoutBuilder)方式来相对于屏幕尺寸(宽度/高度)来调整元素的尺寸?例如:如何将CardView的宽度设置为屏幕宽度的65%。
它不能在build
方法内部完成(很明显),因此必须推迟到构建后再进行。有没有放置这样的逻辑的首选位置?
是否有一种简单的(非LayoutBuilder)方式来相对于屏幕尺寸(宽度/高度)来调整元素的尺寸?例如:如何将CardView的宽度设置为屏幕宽度的65%。
它不能在build
方法内部完成(很明显),因此必须推迟到构建后再进行。有没有放置这样的逻辑的首选位置?
Answers:
FractionallySizedBox
可能也有用。您也可以直接从屏幕宽度中读取屏幕宽度,MediaQuery.of(context).size
并根据该尺寸创建一个尺寸框
MediaQuery.of(context).size.width * 0.65
如果您确实想将大小调整为屏幕的一小部分,而不管布局是什么。
这是一个补充性答案,显示了上述两个解决方案的实现。
如果只有一个窗口小部件,则可以使用FractionallySizedBox
窗口小部件指定要填充的可用空间的百分比。在这里,绿色Container
设置为填充可用宽度的70%和可用高度的30%。
Widget myWidget() {
return FractionallySizedBox(
widthFactor: 0.7,
heightFactor: 0.3,
child: Container(
color: Colors.green,
),
);
}
该Expanded
窗口小部件允许小部件来填充可用的空间,水平地,如果它是在一排,或垂直地,如果它是在一列中。您可以将该flex
属性与多个小部件一起使用来赋予它们权重。在这里,绿色Container
占据了宽度的70%,黄色Container
占据了宽度的30%。
如果您想垂直进行操作,则只需替换Row
为即可Column
。
Widget myWidget() {
return Row(
children: <Widget>[
Expanded(
flex: 7,
child: Container(
color: Colors.green,
),
),
Expanded(
flex: 3,
child: Container(
color: Colors.yellow,
),
),
],
);
}
这是main.dart
代码供您参考。
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: Text("FractionallySizedBox"),
),
body: myWidget(),
),
);
}
}
// replace with example code above
Widget myWidget() {
return ...
}
Dialog
造型:)
这可能更清楚一些:
double width = MediaQuery.of(context).size.width;
double yourWidth = width * 0.65;
希望这能解决您的问题。
您可以使用弹性或扩展子项构建列/行,这些子项的弹性值加起来等于所需的百分比。
您可能还会发现AspectRatio小部件很有用。
MediaQuery.of(context).size.width
有很多方法可以做到这一点
1.使用MediaQuery: 它返回设备的全屏显示,包括appbar,toolbar
Container(
width: MediaQuery.of(context).size.width * 0.50,
height: MediaQuery.of(context).size.height*0.50,
color: Colors.blueAccent[400],
)
2.使用扩展:您可以按比例设置宽度/高度
Container(
height: MediaQuery.of(context).size.height * 0.50,
child: Row(
children: <Widget>[
Expanded(
flex: 70,
child: Container(
color: Colors.lightBlue[400],
),
),
Expanded(
flex: 30,
child: Container(
color: Colors.deepPurple[800],
),
)
],
),
)
首先获取屏幕尺寸。
Size size = MediaQuery.of(context).size;
之后,您可以得到width
并乘以0.5
50%的屏幕宽度。
double width50 = size.width * 0.5;
但是问题通常会出现height
,默认情况下,当我们使用
double screenHeight = size.height;
我们得到的高度是全局高度,其中包括StatusBar
+ notch
+ AppBar
高度。因此,为了获得设备的左侧高度,我们需要从总高度中减去padding
高度(StatusBar
+ notch
)和AppBar
高度。这是我们的方法。
double abovePadding = MediaQuery.of(context).padding.top;
double appBarHeight = appBar.preferredSize.height;
double leftHeight = screenHeight - abovePadding - appBarHeight;
现在,我们可以使用以下方法获得屏幕高度的50%。
double height50 = leftHeight * 0.5