亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

Flutter中獲取屏幕及Widget的寬高示例代碼

2019-10-21 21:30:59
字體:
來源:轉載
供稿:網友

前言

我們平時在開發中的過程中通常都會獲取屏幕或者 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 的寬高,也就是屏幕的寬高

Flutter,屏幕,Widget,寬高,代碼

那么如果我們要需要知道上述紅色的 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

Flutter,屏幕,Widget,寬高,代碼

如果錯誤,還請指出,謝謝

完整源碼

參考鏈接

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久免费视频在线| 日韩美女在线播放| 亚洲国产高清福利视频| 久久国产精品久久久久| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲一区二区三区四区在线播放| 国产日韩在线看片| 久久久久久18| 粗暴蹂躏中文一区二区三区| 欧美性猛交xxxx| 色噜噜国产精品视频一区二区| 成人国产在线视频| 亚洲视频精品在线| 欧美一级视频一区二区| 欧美日韩国产成人在线观看| 久久影视电视剧凤归四时歌| 国内精品免费午夜毛片| 久久99国产精品久久久久久久久| 欧美激情亚洲精品| 亚洲成年网站在线观看| 亚洲风情亚aⅴ在线发布| 国产精品电影在线观看| 亚洲精品永久免费精品| 91欧美精品午夜性色福利在线| 91牛牛免费视频| 国产精品久久在线观看| 日韩视频―中文字幕| 久久久久亚洲精品国产| 亚洲全黄一级网站| 国产美女久久久| 精品国内自产拍在线观看| 午夜免费在线观看精品视频| 久久成人这里只有精品| 日韩亚洲欧美中文在线| 亚洲欧美制服综合另类| 一本色道久久综合狠狠躁篇的优点| 在线观看国产精品91| 亚洲精品成人久久| 亚洲欧美精品一区| 国产精品网站视频| 97福利一区二区| 久久亚洲精品网站| 精品亚洲男同gayvideo网站| 成人免费观看49www在线观看| 中文字幕免费精品一区高清| 有码中文亚洲精品| 欧美日韩国产一区二区| 日本一区二三区好的精华液| 综合激情国产一区| 日本亚洲欧美成人| 国产精品都在这里| 成人欧美一区二区三区在线| 欧美极品xxxx| 国产精品极品美女粉嫩高清在线| 亚洲国产日韩精品在线| 亚洲午夜色婷婷在线| 神马久久久久久| 国产欧美中文字幕| 动漫精品一区二区| 欧美激情伊人电影| 国产精欧美一区二区三区| 日韩电影视频免费| 国产性猛交xxxx免费看久久| 中文字幕免费国产精品| 久久成人在线视频| 91精品国产沙发| 国产欧美日韩免费看aⅴ视频| 成人欧美一区二区三区在线湿哒哒| 亚洲精品一区av在线播放| 亚洲综合在线中文字幕| 久久久之久亚州精品露出| 国产成+人+综合+亚洲欧洲| 日韩中文字幕久久| 欧美日韩免费一区| 欧美日韩在线影院| 欧美精品在线视频观看| 91成人性视频| 国内精品国产三级国产在线专| 91精品在线观看视频| 国产一区二区在线免费视频| 亚洲久久久久久久久久| 日韩高清电影免费观看完整| 日韩网站免费观看高清| 国产日韩换脸av一区在线观看| 日韩精品有码在线观看| 91手机视频在线观看| 中文字幕久久精品| 国产精品视频中文字幕91| 不用播放器成人网| 亚洲国产精品福利| 欧美在线视频播放| 欧美亚洲第一页| 亚洲视频在线免费观看| 国产成一区二区| 97超级碰碰碰| 国外成人性视频| 亚洲第一区在线观看| 欧美国产日韩二区| 日本一区二区不卡| 国产精品av免费在线观看| 成人一区二区电影| 国产在线精品一区免费香蕉| 成人av资源在线播放| 国产精品网站大全| 91精品视频一区| 久久成人人人人精品欧| 91久久国产综合久久91精品网站| 亚洲成人久久久| 欧美精品九九久久| 久久精品国产欧美激情| 亚洲第一区第一页| 国产女精品视频网站免费| 九九久久精品一区| 91性高湖久久久久久久久_久久99| 欧美一区在线直播| 亚洲国产精品va在线观看黑人| 欧美视频在线观看 亚洲欧| 国产日韩中文在线| 5278欧美一区二区三区| 日韩在线观看视频免费| 热re99久久精品国产66热| 福利二区91精品bt7086| 狠狠躁夜夜躁人人爽天天天天97| 国产精品777| 欧美激情一区二区三区成人| 成人午夜一级二级三级| 97国产在线视频| 国产精品麻豆va在线播放| 欧美日韩视频免费播放| 91成人国产在线观看| 午夜精品久久久久久久99热| 欧美亚州一区二区三区| 亚洲欧洲第一视频| 欧美成人精品h版在线观看| 日本免费一区二区三区视频观看| 久久精品国产亚洲一区二区| 97国产精品视频人人做人人爱| 久久精品视频导航| 久久精品视频va| 国产一区二区三区在线免费观看| 日韩欧美aⅴ综合网站发布| 国产日韩欧美黄色| 色悠悠国产精品| 国产+人+亚洲| 黄色一区二区三区| 欧美性在线视频| 国产精品免费一区豆花| 久久精品国产久精国产一老狼| 中文字幕国内精品| 欧美电影在线观看高清| 亚洲成色777777女色窝| 亚洲国产精品成人一区二区| 一本一道久久a久久精品逆3p| 中文字幕av一区中文字幕天堂| 国产精品专区一| 久久久久久亚洲精品中文字幕| 欧美日韩国产丝袜美女| 欧美午夜丰满在线18影院| 日韩av免费网站| 91丝袜美腿美女视频网站| 久久精品视频播放| 欧美激情一二区| 国产精品狠色婷| 日韩高清中文字幕|