首页 > 其他分享 >第四百四十三回

第四百四十三回

时间:2024-04-05 22:33:22浏览次数:38  
标签:viewPadding MediaQueryData 成员 获取 参数 屏幕 四十三 第四

文章目录


我们在上一章回中介绍了"自定义Action菜单"相关的内容,本章回中将介绍如何获取屏幕相关参数.闲话休提,让我们一起Talk Flutter吧。

在这里插入图片描述

1. 概念介绍

我们在本章回中介绍的屏幕参数主要指屏幕的尺寸、方向和亮度。这些参数在程序开发中会被用到,当然了使用频率最高的要数屏幕的尺寸。本章回中将详细介绍获取这些
参数的方法,同时分享一些相关的经验。

2. 思路与方法

2.1 整体思路

获取屏幕参数的思路就是读取屏幕的参数值,这时需要使用MediaQueryData类的成员,这些成员中包含了相关的屏幕参数值,开发人员只需要获取到这些值就可以。常
用的成员如下所示:

  • viewInsets:它表示被系统功能界面遮挡的功能区域大小,比如常见的键盘区域大小;
  • viewPadding:它表示页面最上方的状态栏和底部安全区域的大小;
  • padding:它和viewPadding功能相同,只是在细节上有差别;
  • size:它表示屏幕的大小,也就是通常说的屏幕分辨率;
    我们在上面中提到了viewPadding和padding成员在细节上有差别,主要的差别在于padding中bottom的值会在键盘弹出后变为0,而viewPadding中botttom的
    值不会变。

2.2 使用方法

有了思路后,我们介绍具体的实现方法,详细如下:

  • 通过MediaQuery的of方法获取MediaQueryData对象;
  • 在MediaQueryData对象中获取相应的成员;
  • 在成员中读取屏幕参数值;

3. 示例代码

    double statusBarHeight = MediaQuery.of(context).padding.top;
    double screenWidth = MediaQuery.of(context).size.width;
    double screenHeight = MediaQuery.of(context).size.height;

上面的示例代码中演示了如何获取屏幕的长度和宽度,其它的屏幕参数大家可以自己动手去获取。我们在这里就不演示了,我们重点说一下top对应值,它表示屏幕最上方
状态栏的高度,就是显示手机信号所在区域的高度,很多人容易把页面上方AppBar的高度与它混淆。其实它的高度值大约是AppBar的一半,比如我在自己的真机上测试
后发现top对应的值是36,而且AppBar的高度值是56。

4. 内容总结

最后,我们对本章回的内容做一个全面的总结:

  • 屏幕参数主要存放在MediaQueryData类的成员中;
  • 获取屏幕参数时直接读取MediaQueryData类的成员值就可以;
  • 不同的屏幕参数对应的不同的成员,有些成员在功能上相同,但是细节上不同;
    看官们,与"如何获取屏幕相关参数"相关的内容就介绍到这里,欢迎大家在评论区交流与讨论!

标签:viewPadding,MediaQueryData,成员,获取,参数,屏幕,四十三,第四
From: https://blog.csdn.net/talk_8/article/details/137410533

相关文章

  • 第四章 总体设计
    第四章总体设计怎样实现目标系统【考核内容】总体设计的概念、设计步骤;模块化的概念、作用,模块化程度与软件开发工作量的关系;Miller法则,模块独立性的重要性,模块耦合及其分类,模块内聚及其分类,模块设计的几条启发式规则及与之相关的概念(深度、宽度、扇出、扇入、作用域);结构图的......
  • 红日8第四层(两台)
    第四层(DC) 20.11.11.129+一个nat网卡对外访问的192.168.75.136(前面扫描到这个是windows-server2012)在第三层过来时记得加上网段然后就可以用nmap扫描发现了135,445,139等端口,漏洞扫描发现了ms17_010用模块扫描一下发现了真的有ms17_010use0 到use1都不行(怀疑......
  • (译) 理解 Elixir 中的宏 Macro, 第四部分:深入化
    ElixirMacros系列文章译文[1](译)UnderstandingElixirMacros,Part1Basics[2](译)UnderstandingElixirMacros,Part2-MacroTheory[3](译)UnderstandingElixirMacros,Part3-GettingintotheAST[4](译)UnderstandingElixirMacros,Part4-Div......
  • Java集合框架详解:List、Set、Map及其实现类的使用与特性 第四章
    目录一、Java集合框架的选择与优化选择策略性能优化二、结论一、Java集合框架的选择与优化选择策略根据数据特性和应用需求,选择合适的Java集合类型应考虑以下几个关键因素:是否允许重复:不允许重复:如果元素必须唯一,应选择Set接口的实现类,如HashSet(无序,查找速度快)或T......
  • 第四章总结
    1、组件的定义及属性    组件是页面视图层(WXML)的基本组成单元,组件组合可以构建功能强大的页面结构。小程序框架为开发者提供了容器视图、基础内容、表单、导航、多媒体、地图、画布、开放能力等。8类(30多个)组件。    每一个组件都由一对标签组成,有开始标签和......
  • PTA数据结构第四章7-2 变身(八进制转成十进制)
    分数20作者 陈晓梅单位 广东外语外贸大学题目给出一个由18位八进制数字组成的序列,要求每六位转成一个十进制数并输出。输入格式:18位八进制数字组成的序列。输出格式:输出转换后的三个十进制数,以空格分隔,行末不能有空格。输入样例:000023452230567134输出样例:......
  • 第一届“长城杯”信息安全铁人三项赛初赛-第四场-pwn-all
    第一届“长城杯”信息安全铁人三项赛初赛-第四场-pwn-all这次打了个第二。onetime逆向分析经典菜单堆,free分支存在uaf,然后第五个分支和第一个分支可以达成fastbinattack漏洞利用利用fastbinattack申请0x60208d,然后修改分支判断变量与p指针,做到利用show分支泄露和修改atoi......
  • 【浙江工业大学主办,嘉宾阵容强大 | IEEE出版,往届均已检索!!】第四届IEEE电子,电路和信息
    第四届IEEE电子,电路和信息工程国际学术会议(ECIE2024)将于2024年5月24日至26日于杭州举行。ECIE2024致力于为电子,电路和信息工程等相关领域的学者,工程师和从业人员提供一个分享最新研究成果的平台。会议征稿主题主要包括但不限于单片机技术,电工技术,电力系统通信,信息与通信工程,......
  • React Native简介和环境配置,差点挂在第四面
    ReactNative目前需要NodeJS5.0或更高版本。本文发布时Homebrew默认安装的是最新版本,一般都满足要求。brewinstallnode安装完node后建议设置npm镜像以加速后面的过程(或使用科学上网工具)。注意:不要使用cnpm!cnpm安装的模块路径比较奇怪,packager不能正常识别!npmconfig......
  • 第四章页面组件操作题
    1,使用canvas组件实现“奥运五环”的绘制。代码如下wxml:<canvascanvas-id="wuhuan"></canvas>js:Page({onLoad:function(options){constctx=wx.createCanvasContext('wuhuan');//设置五环颜色constcolors=["blue",&quo......