Flutter之Widget大小与位置

在某些需求下,我们需要获取Widget的大小或位置信息。但Widget对象本身没有大小及位置数据,那么想要拿到Widget的大小及位置信息,就需要通过与Widget对象相关联的RenderBox对象来获取。

下面就开始来获取Widget的大小与位置。

1、获取RenderBox对象

要想获取RenderBox对象,其实很简单。只需要调用BuildContextfindRenderObject方法即可。代码如下。

//context是一个BuildContext对象
RenderBox renderBox = context.findRenderObject();

但有时候,并不能顺利的拿到BuildContext对象,那该怎么办尼?这时候就需要给Widget对象设置一个Key,然后根据这个Key来拿到BuildContext对象,从而获取RenderBox对象,代码如下。

class MyHomePageState extends State<MyHomePage> {
  //定义一个key
  GlobalKey _key = GlobalKey();
  _getRenderBox() {
    //获取`RenderBox`对象
    RenderBox renderBox = _key.currentContext.findRenderObject();
  }
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      body: Column(
        children: <Widget>[
          Flexible(
            flex: 2,
            child: Container(
              //设置key
              key: _key,
              color: Colors.red,
            ),
          ),
        ],
      ),
    );
  }
}

但在使用的时候,我们会发现如

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值