• 三狮军团首秀 只有两千多球迷观战 2019-05-19
  • 人民网2017呼和浩特徒步迎新活动--内蒙古频道--人民网 2019-05-19
  • 【品牌资讯】环球网斩获“全国行业新闻网站传播力2017年6月榜”多项冠军 2019-05-15
  • 深化对经济工作主线的认识 从供需关系看供给侧结构性改革 2019-05-15
  • 格拉斯哥艺术学院起火 4年前曾遭火灾仍在整修 2019-05-14
  • 回复@地瓜干17世:猪临死才会嚎叫呢~ 2019-05-14
  • 婺源古村溪中发现鹰嘴龟 2019-05-08
  • 编辑评测:高夫净源控油平衡露 极速补水长效控油 2019-05-08
  • 四部门发文规范特色小镇建设防止“新瓶装旧酒” 2019-05-02
  • 【地球的盛会文明的聚会艺术的盛宴四海一家足球为人类和平幸福而荣耀!!!普京是当今人类世界最优秀的一代伟人俄罗斯赢啦!!!】 2019-04-29
  • 学习新思想,千万师生同上一堂课 2019-04-28
  • 你这种个体户都干不了的老蚕也配谈计划?真是笑死人不偿命哦? 2019-04-23
  • 感人!的哥带着患病父亲出车 孝心感动乘客 2019-04-23
  • 图解:习近平在纪念马克思诞辰200周年大会上讲话的16个金句 2019-04-16
  • 感触名家笔下的端午文化 吃香粽原来可以这样"文艺" 2019-04-16
  • 山西11选5前三值选遗漏:Flutter中获取屏幕及Widget的宽高示例代码

    山西体彩11选5直选遗漏 www.caxru.com  更新时间:2019年03月10日 16:54:07   作者:刘斯龙   我要评论

    这篇文章主要给大家介绍了关于Flutter中如何获取屏幕及Widget的宽高的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者使用Flutter具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

    前言

    我们平时在开发中的过程中通常都会获取屏幕或者 widget 的宽高用来做一些事情,在 Flutter 中,我们有两种方法来获取 widget 的宽高。

    MediaQuery

    一般情况下,我们会使用如下方式去获取 widget 的宽高:

    final size =MediaQuery.of(context).size;
    final width =size.width;
    final height =size.height; 

    但是如果不注意,这种写法很容易报错,例如下面的写法就会报错:

    import 'package:flutter/material.dart';
    
    class GetWidgetWidthAndHeiget extends StatelessWidget {
     @override
     Widget build(BuildContext context) {
     final size =MediaQuery.of(context).size;
     final width =size.width;
     final height =size.height;
     print('width is $width; height is $height');
     return MaterialApp(
      home: Scaffold(
      appBar: AppBar(
       title: Text('Width & Height'),
      ),
      body: Container(
       width: width / 2,
       height: height / 2,
      ),
      ),
     );
     }
    }

    在代码中,我们是想获取屏幕的宽和高,然后将屏幕宽高的一半分别赋值给 Container 的宽和高,但上述代码并不能成功运行,会报如下错误:

    flutter: The following assertion was thrown building GetWidgetWidthAndHeiget(dirty):
    flutter: MediaQuery.of() called with a context that does not contain a MediaQuery.
    flutter: No MediaQuery ancestor could be found starting from the context that was passed to MediaQuery.of().
    flutter: This can happen because you do not have a WidgetsApp or MaterialApp widget (those widgets introduce
    flutter: a MediaQuery), or it can happen if the context you use comes from a widget above those widgets.

    从错误异常中我们可以大概了解到有两种情况会导致上述异常:

    • 当没有 WidgetsApp or MaterialApp 的时候,我们使用 MediaQuery.of(context) 来获取数据。
    • 当我们在当前小部件中使用了上一个小部件的 context,来使用 MediaQuery.of(context) 获取数据的时候。

    我们上述的代码很显然是属于第一种情况,也就是说我们在使用 MediaQuery.of(context) 的地方并没有一个 WidgetsApp or MaterialApp 来提供数据。

    解决方法就是将 MediaQuery.of(context) 挪到 MaterialApp 内,如下:

    import 'package:flutter/material.dart';
    
    class GetWidgetWidthAndHeiget extends StatelessWidget {
     @override
     Widget build(BuildContext context) {
     return MaterialApp(
      home: HomePage(),
     );
     }
    }
    
    class HomePage extends StatelessWidget {
     @override
     Widget build(BuildContext context) {
     final size = MediaQuery.of(context).size;
     final width = size.width;
     final height = size.height;
     print('width is $width; height is $height');
     return Scaffold(
      appBar: AppBar(
      title: Text('Width & Height'),
      ),
      body: Center(
      child: Container(
       color: Colors.redAccent,
       width: width / 2,
       height: height / 2,
      ),
      ),
     );
     }
    }

    运行效果及输出如下:

    flutter: width is 414.0; height is 896.0

    上述代码中,我们获取的是 MaterialApp 的宽高,也就是屏幕的宽高


    那么如果我们要需要知道上述红色的 Container 容器的宽高怎么办呢?这里我们可以使用 GlobalKey

    GlobalKey

    使用 GlobalKey 的步骤如下:

    • 声明一个 GlobalKey final GlobalKey globalKey = GlobalKey();
    • 给 widget 设置 GlobalKey key: globalKey
    • 通过 globalKey 来获取该 widget 的 size
    final containerWidth = globalKey.currentContext.size.width;
    final containerHeight = globalKey.currentContext.size.height;
    print('Container widht is $containerWidth, height is $containerHeight');

    修改过后的 HomePage 代码如下:

    class HomePage extends StatelessWidget {
    
     final GlobalKey globalKey = GlobalKey();
    
     void _getWH() {
     final containerWidth = globalKey.currentContext.size.width;
     final containerHeight = globalKey.currentContext.size.height;
     print('Container widht is $containerWidth, height is $containerHeight');
     }
    
     @override
     Widget build(BuildContext context) {
     final size = MediaQuery.of(context).size;
     final width = size.width;
     final height = size.height;
     print('width is $width; height is $height');
     return Scaffold(
      appBar: AppBar(
      title: Text('Width & Height'),
      ),
      body: Center(
      child: Container(
       key: globalKey,
       color: Colors.redAccent,
       width: width / 2,
       height: height / 2,
      ),
      ),
      floatingActionButton: FloatingActionButton(
      onPressed: _getWH,
      child: Icon(Icons.adjust),
      ),
     );
     }
    }

    上述代码中,我们将声明的 globalKey 设置给了 Container , 当我们点击页面中的 FloatingActionButton 的时候,就会使用 globalKey 来获取 Container 的宽高,也就是_getWH() 中执行的代码。

    运行结果及输出如下:

    flutter: Container widht is 207.0, height is 448.0

    如果错误,还请指出,谢谢

    完整源码

    参考链接

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

    相关文章

    最新评论

  • 三狮军团首秀 只有两千多球迷观战 2019-05-19
  • 人民网2017呼和浩特徒步迎新活动--内蒙古频道--人民网 2019-05-19
  • 【品牌资讯】环球网斩获“全国行业新闻网站传播力2017年6月榜”多项冠军 2019-05-15
  • 深化对经济工作主线的认识 从供需关系看供给侧结构性改革 2019-05-15
  • 格拉斯哥艺术学院起火 4年前曾遭火灾仍在整修 2019-05-14
  • 回复@地瓜干17世:猪临死才会嚎叫呢~ 2019-05-14
  • 婺源古村溪中发现鹰嘴龟 2019-05-08
  • 编辑评测:高夫净源控油平衡露 极速补水长效控油 2019-05-08
  • 四部门发文规范特色小镇建设防止“新瓶装旧酒” 2019-05-02
  • 【地球的盛会文明的聚会艺术的盛宴四海一家足球为人类和平幸福而荣耀!!!普京是当今人类世界最优秀的一代伟人俄罗斯赢啦!!!】 2019-04-29
  • 学习新思想,千万师生同上一堂课 2019-04-28
  • 你这种个体户都干不了的老蚕也配谈计划?真是笑死人不偿命哦? 2019-04-23
  • 感人!的哥带着患病父亲出车 孝心感动乘客 2019-04-23
  • 图解:习近平在纪念马克思诞辰200周年大会上讲话的16个金句 2019-04-16
  • 感触名家笔下的端午文化 吃香粽原来可以这样"文艺" 2019-04-16
  • 爱彩网2018app下载 腾讯分分彩电脑软件 六合彩白小姐 香港六合彩官方 苹果北京pk10下载软件 2017051期福彩中奖号 排列5开奖结果查询 体彩七星彩 北京pk10三码公式教程 双色球中奖查询器拍照 安徽时时彩走势 双色球开奖走势图 彩票论坛首页 浙江大乐透走势图 北京赛车富贵开奖 3d2017102期詹天佑分析