位置: 编程技术 - 正文

android布局优化(androidui布局)

编辑:rootadmin

推荐整理分享android布局优化(androidui布局),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:android的布局模式,android布局优化的方案,android 布局,优化安卓布局性能的方式有哪些,android 界面优化,android 优化,android 布局,androidui布局,内容如对您有帮助,希望把文章链接给更多的朋友!

在Android开发中,我们常用的布局方式主要有LinearLayout、RelativeLayout、FrameLayout等,通过这些布局我们可以实现各种各样的界面。与此同时,如何正确、高效的使用这些布局方式来组织UI控件,是我们构建优秀Android App的主要前提之一。本篇内容就主要围绕Android布局优化来讨论在日常开发中我们使用常用布局需要注意的一些方面,同时介绍一款SDK自带的UI性能检测工具HierarchyViewer。

布局原则

通过一些惯用、有效的布局原则,我们可以制作出加载效率高并且复用性高的UI。简单来说,在Android UI布局过程中,需要遵守的原则包括如下几点:

尽量多使用RelativeLayout,不要使用绝对布局AbsoluteLayout;将可复用的组件抽取出来并通过< include />标签使用;使用< ViewStub />标签来加载一些不常用的布局;使用< merge />标签减少布局的嵌套层次;

由于Android的碎片化程度很高,市面上存在的屏幕尺寸也是各式各样,使用RelativeLayout能使我们构建的布局适应性更强,构建出来的UI布局对多屏幕的适配效果越好,通过指定UI控件间的相对位置,使在不同屏幕上布局的表现能基本保持一致。当然,也不是所有情况下都得使用相对布局,根据具体情况来选择和其他布局方式的搭配来实现最优布局。

1、< include />的使用

在实际开发中,我们经常会遇到一些共用的UI组件,比如带返回按钮的导航栏,如果为每一个xml文件都设置这部分布局,一是重复的工作量大,二是如果有变更,那么每一个xml文件都得修改。还好,Android为我们提供了< include />标签,顾名思义,通过它,我们可以将这些共用的组件抽取出来单独放到一个xml文件中,然后使用< include />标签导入共用布局,这样,前面提到的两个问题都解决了。例如上面提到的例子,新建一个xml布局文件作为顶部导航的共用布局。

然后我们在需要引入导航栏的布局xml中通过< include />导入这个共用布局。

通过这种方式,我们既能提高UI的制作和复用效率,也能保证制作的UI布局更加规整和易维护。布局完成后我们运行一下,可以看到如下布局效果,这就是我们刚才完成的带导航栏的界面。

接着我们进入sdk目录下的tools文件夹下,找到HierarchyViewer并运行(此时保持你的模拟器或真机正在运行需要进行分析的App),双击我们正在显示的这个App所代表的进程。

接下来便会进入hierarchyviewer的界面,我们可以在这里很清晰看到正在运行的UI的布局层次结构以及它们之间的关系。

分析刚刚我们构建的导航栏布局,放大布局分析图可以看到,被include进来的common_navitationbar.xml根节点是一个RelativeLayout,而包含它的主界面main.xml根节点也是一个RelativeLayout,它前面还有一个FrameLayout等几个节点,FrameLayout就是Activity布局中默认的父布局节点,再往上是一个LinearLayout,这个LinearLayout就是包含Activity布局和状态栏的整个屏幕显示的布局父节点,这个LinearLayout还有一个子节点就是ViewStub,关于这个节点我们在后面会详细介绍。

2、< merge />的使用

< merge />标签的作用是合并UI布局,使用该标签能降低UI布局的嵌套层次。该标签的主要使用场景主要包括两个,第一是当xml文件的根布局是FrameLayout时,可以用merge作为根节点。理由是因为Activity的内容布局中,默认就用了一个FrameLayout作为xml布局根节点的父节点,这一点可以从上图中看到,main.xml的根节点是一个RelativeLayout,其父节点就是一个FrameLayout,如果我们在main.xml里面使用FrameLayout作为根节点的话,这时就可以使用merge来合并成一个FrameLayout,这样就降低了布局嵌套层次。

我们修改一下main.xml的内容,将根节点修改为merge标签。

重新运行并打开HierarchyViewer查看此时的布局层次结构,发现之前多出来的一个RelativeLayout就没有了,直接将common_navigationbar.xml里面的内容合并到了main.xml里面。

android布局优化(androidui布局)

使用< merge />的第二种情况是当用include标签导入一个共用布局时,如果父布局和子布局根节点为同一类型,可以使用merge将子节点布局的内容合并包含到父布局中,这样就可以减少一级嵌套层次。首先我们看看不使用merge的情况。我们新建一个布局文件commonnaviright.xml用来构建一个在导航栏右边的按钮布局。

然后修改common_navitationbar.xml的内容,添加一个include,将右侧按钮的布局导入:

运行后的效果如下图,在导航栏右侧添加了一个按钮“ok”

然后再运行HierarchyViewer看看现在的布局结构,发现commonnaviright.xml作为一个布局子节点嵌套在了common_navitationbar.xml下面。

这时我们再将commonnaviright.xml的根节点类型改为merge。

重新运行并打开HierarchyViewer查看布局结构,发现之前嵌套的一个RelativeLayout就没有了,这就是使用merge的效果,能降低布局的嵌套层次。

3、< ViewStub />的使用

也许有不少同学对ViewStub还比较陌生,首先来看看ViewStub在官方文档里是怎么介绍的:

A ViewStub is an invisible, zero-sized View that can be used to lazily inflate layout resources at runtime. When a ViewStub is made visible, or when inflate() is invoked, the layout resource is inflated. The ViewStub then replaces itself in its parent with the inflated View or Views. Therefore, the ViewStub exists in the view hierarchy until setVisibility(int) or inflate() is invoked. The inflated View is added to the ViewStub's parent with the ViewStub's layout parameters.

大致意思是:ViewStub是一个不可见的,能在运行期间延迟加载的大小为0的View,它直接继承于View。当对一个ViewStub调用inflate()方法或设置它可见时,系统会加载在ViewStub标签中引入的我们自己定义的View,然后填充在父布局当中。也就是说,在对ViewStub调用inflate()方法或设置visible之前,它是不占用布局空间和系统资源的。它的使用场景可以是在我们需要加载并显示一些不常用的View时,例如一些网络异常的提示信息等。

我们新建一个xml文件用来显示一个提示信息:

然后在main.xml里面加入ViewStub的标签引入上面的布局:

修改MainActivity.java的代码,我们这里设置为点击右上角按钮的时候显示自定义的common_msg.xml的内容。

代码中我们通过flag来切换显示和隐藏common_msg.xml的内容,然后我们运行一下并点击右上角按钮来切换,效果如下:

总结

好了,到目前为止,我们就介绍了Android中关于布局优化的一些内容以及工具HierarchyViewer的使用。将前文提及的布局原则再列一下,欢迎大家补充更多的关于Android布局优化的实用原则。

尽量多使用RelativeLayout,不要使用绝对布局AbsoluteLayout;将可复用的组件抽取出来并通过< include />标签使用;使用< ViewStub />标签来加载一些不常用的布局;使用< merge />标签减少布局的嵌套层次;

[置顶] 已发布的计算器界面布局分享,可自动适配不同分辨率 本人所写的Hy计算器,已在豌豆荚发布,在此公开界面布局代码,并配注释。该界面布局通过自动压缩计算器显示屏的大小,可以使得按键的布局在不同

android apk版本更新 androidapk版本更新/***获取版本名称**@returnversion*/privateStringgetVersionName(){try{//获取packagemanager的实例PackageManagerpackageManager=getPackageManager();//getPackageName()是你

Http TCP 协议 Http协议•基于TCP无状态的应用层协议•请求组成:请求行、消息报头、消息报文•响应组成:状态行、消息报头、响应正文常见请求、响应消息报头Cont

标签: androidui布局

本文链接地址:https://www.jiuchutong.com/biancheng/378113.html 转载请保留说明!

上一篇:Android 如何直播RTMP流(安卓机怎么直播)

下一篇:android apk版本更新(android 更新apk)

  • 税前弥补亏损是净利润吗
  • 税务师考试的报名费怎么还没有退成功
  • 专项附加扣除可以随时填报吗
  • 金税盘是每天有5次机会吗
  • 预付和预收可以合并吗
  • 计提利息收入分录怎么写
  • 发票上的不含税单价怎么算的
  • 社保费个人承担部分
  • 离职人员个税申报如何处理
  • 2019年小微企业六税两费减免
  • 残疾人一次性奖金
  • 递延收益涉税
  • 营业执照年审后日期会变吗
  • 销售发票的会计分录怎么做?
  • 超市里的摊位租金贵吗
  • 代管商品物资登记制度
  • 开工程服务发票后怎么成本
  • 一般纳税人有按季申报的吗
  • 营改增后哪些费用可以抵扣
  • 营改增账务处理举例
  • 外地预缴个人所得税如何入账及申报
  • 企业所得税利润怎么算
  • 进口货物退税流程
  • 工程完工财务要做些什么
  • 集体企业属于事业单位吗
  • 1697508432
  • 2021年季度所得税申报表填报说明
  • 个人接受捐赠要开发票吗
  • 面对通过网络涌入的大量信息,我们应该学会
  • 小规模纳税人免税额度是多少
  • macbook如何安装
  • 工程用的东西有什么
  • 以产品抵债会计分录
  • 本地连接受限制无法连接
  • 固定资产前期购买的后期入账怎么入?
  • 收费公路通行费财政电子票据可以抵扣吗
  • 资产和负债的计税基础金额的确认思维导图
  • 怎么让win7不锁定
  • 加利福尼亚riverside
  • wordpress添加css
  • php升级到php7注意的问题
  • TypeError: Cannot read properties of null (reading ‘insertBefore‘) vue项目报错
  • 企业为员工购买
  • 增值税即征即退操作流程
  • php @method
  • 什么是成本会计
  • 大前端入门指南
  • vue的常见面试题
  • php websocket教程
  • 定额发票和增值税发票
  • 评价股权转让要交什么税
  • 季度申报所得税时可以用以前年度亏损吗
  • 现代服务增值税纳税义务发生时间
  • 物流破损拒收的理由
  • 网站升级改造方案
  • 借条这样写才有效
  • 无偿受让股权是利好吗
  • 消防设备要多少钱
  • 经营租赁筹建期怎么计算
  • sql如何进行事务操作
  • 购买防伪税控设备
  • 运输公司赔偿账务处理
  • 白条入账的新会计政策
  • 国外工程合同类型
  • 交易性金融资产公允价值变动计入
  • linux的压缩包
  • centos6 dhcp
  • win10系统打开ie浏览器变百度怎么改回ie浏览器了
  • 安装ubuntu不支持nvidia显卡
  • get请求的url
  • unity获取鼠标点击的位置
  • 运用python编写程序
  • string和stringbuffer创建后都可以修改
  • android模拟器无法运行
  • 税票开票员的职责
  • 土地闲置是否需要缴纳土地使用税
  • 四川国税发票手机查询
  • 三证合一后还要做什么
  • 零税率,免税不免增值税
  • 商铺收税多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设