是否有一种简单的(非layoutbuilder)方法来相对于屏幕大小(宽/高)来调整元素的大小?例如:我如何设置CardView的宽度为屏幕宽度的65%。
它不能在构建方法内部完成(显然),所以它必须推迟到构建后。是否有一个更好的地方来放置这样的逻辑?
是否有一种简单的(非layoutbuilder)方法来相对于屏幕大小(宽/高)来调整元素的大小?例如:我如何设置CardView的宽度为屏幕宽度的65%。
它不能在构建方法内部完成(显然),所以它必须推迟到构建后。是否有一个更好的地方来放置这样的逻辑?
当前回答
您可以将MediaQuery与小部件的当前上下文一起使用,并像这样获得宽度或高度 double width = MediaQuery.of(context).size.width double height = MediaQuery.of(context).size.height 然后,你可以把它乘以你想要的百分比
其他回答
您可以构建具有Flexible或Expanded子元素的列/行,这些子元素的flex值加起来等于您想要的百分比。
您可能还会发现AspectRatio小部件很有用。
首先确定屏幕的大小。
Size size = MediaQuery.of(context).size;
在此之后,你可以得到宽度,并将其与0.5相乘,以获得屏幕宽度的50%。
double width50 = size.width * 0.5;
但问题通常来自高度,默认情况下,当我们使用
double screenHeight = size.height;
我们得到的高度是全局高度,包括StatusBar + notch + AppBar高度。因此,为了获得设备的左侧高度,我们需要从总高度中减去填充高度(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
如果你正在使用GridView,你可以使用Ian Hickson的解决方案。
crossAxisCount: MediaQuery.of(context).size.width <= 400.0 ? 3 : MediaQuery.of(context).size.width >= 1000.0 ? 5 : 4
您可以将MediaQuery与小部件的当前上下文一起使用,并像这样获得宽度或高度 double width = MediaQuery.of(context).size.width double height = MediaQuery.of(context).size.height 然后,你可以把它乘以你想要的百分比
使用缩放器定义布局宽度和高度的百分比
dependencies:
scaler: ^1.1.0+1
在pubspec中设置后。Yaml您可以通过以下代码使用此功能-
import 'package:scaler/scaler.dart';
导入后使用this -
import 'package:scaler/scaler.dart';
@override
Widget build(BuildContext context) {
/**
* Container with 25% width of screen
* and 25% height of screen
*/
return Container(
height: Scaler.height(0.25, context),
width: Scaler.width(0.25, context),
child: Container()
);
}
更详细地说
https://pub.dev/packages/scaler