上一篇博客中介绍了布局优化的工具,层级观察器Hierarchy Viewer和布局优化分析工具layoutopt。如果看过上篇博客的会注意到,layoutopt工具提示可以将<FrameLayout/>换成<merge/>。其实<merge/>标签在UI的结构优化中起着非常重要的作用,通过它可以删减多余的层级,达到优化UI的目的。

再来看一下上篇博客中使用的框架布局的树形结构图:

根节点和LinearLayout上面那个子树为android的窗口布局,后面的TextView即为标签。×××框内的这部分树形图即为我们的布局。可以发现红色框出的FrameLayout是另一个FrameLayout的唯一子元素,并且该父节点并没有额外的属性,也就是说,它是完全冗余的,这时候就要用<merge/>标签来解决这个问题。用<merge/>替换原来的<FrameLayout/>标签,修改后的布局代码如下:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <merge xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <TextView
  8. android:layout_width="300dip"
  9. android:layout_height="300dip"
  10. android:background="#00008B"
  11. android:layout_gravity="center"
  12. />
  13. <TextView
  14. android:layout_width="250dip"
  15. android:layout_height="250dip"
  16. android:background="#0000CD"
  17. android:layout_gravity="center"
  18. />
  19. <TextView
  20. android:layout_width="200dip"
  21. android:layout_height="200dip"
  22. android:background="#0000FF"
  23. android:layout_gravity="center"
  24. />
  25. <TextView
  26. android:layout_width="150dip"
  27. android:layout_height="150dip"
  28. android:background="#00BFFF"
  29. android:layout_gravity="center"
  30. />
  31. <TextView
  32. android:layout_width="100dip"
  33. android:layout_height="100dip"
  34. android:background="#00CED1"
  35. android:layout_gravity="center"
  36. />
  37. </merge>

再观察下它的树形图,如图所示,显然层次更简单了。

为什么会这样呢,因为Activity的根节点都是FrameLayout,所以用merge标签可以直接添加到这个FrameLayout而不要再增加一个FrameLayout节点。但是如果你的布局是以LinearLayout等为根节点,就不能这么做了。

<merge/>其实还有很多作用,它和<include/>标签就能完美的结合。<include/>标签用来实现代码的重用以及布局的模块化。如果UI中需要多次用到同一个布局, <include/>标签会大大提高我们的开发效率。看个例子:

新建一个共享布局:share.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <TextView
  8. android:layout_width="fill_parent"
  9. android:layout_height="wrap_content"
  10. android:text="这是一个共享布局"
  11. />
  12. </LinearLayout>

然后在需要使用这个布局的布局中使用<include/>标签,并且我们可以重写它的一些属性(下面的代码就重写了它的id):

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent">
  6. <include android:id="@+id/new" layout="@layout/share"></include>
  7. </LinearLayout>

如果在我们的布局中只需要使用共享布局的内容,这时候就可以用merge标签,这样使得布局更加高效灵活。

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <merge xmlns:android="http://schemas.android.com/apk/res/android"
  3. <include android:id="@+id/newone" layout="@layout/share"></include>
  4. <include android:id="@+id/newtwo" layout="@layout/share"></include>
  5. </merge>

有了<include/>标签,很容易就能做到共享和重用布局,可是很多情况下,一个布局中有很多View并不常用,这就造成了资源的浪费,android为此提供了ViewStub标签来解决这个问题。在默认情况下ViewStub下的标签都有visibility=GONE属性(不可见),更重要的是在这个标签下的内容不会占用任何的空间。其实ViewStub和include类似,不过区别就在于ViewStub只会在你需要的时候进入你的界面,viewStub通过inflate()方法来通知系统加载其内部的View。这样就可以让我们既享受到<include/>的便利,又不会产生过多没用的View。 还是看个例子:

其中share.xml前面已经介绍过了,main.xml的布局文件:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. 2  <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. 3     android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <Button
  8. android:id="@+id/show"
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:text="点击导入"
  12. />
  13. <ViewStub
  14. android:id="@+id/viewStub"
  15. android:layout="@layout/share"
  16. android:layout_width="wrap_content"
  17. android:layout_height="wrap_content"
  18. />
  19. </LinearLayout>

MyViewStub.java代码:

  1. package com.notice520.viewstub;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.view.View;
  5. import android.view.ViewStub;
  6. import android.view.View.OnClickListener;
  7. import android.widget.Button;
  8. public class MyViewStub extends Activity {
  9. private ViewStub mViewStub;
  10. private Button   showButton;
  11. /** Called when the activity is first created. */
  12. @Override
  13. public void onCreate(Bundle savedInstanceState) {
  14. super.onCreate(savedInstanceState);
  15. setContentView(R.layout.main);
  16. mViewStub = (ViewStub)findViewById(R.id.viewStub);//实例化ViewStub控件,这里可以看出我们必//须为ViewStub设定id
  17. showButton = (Button)findViewById(R.id.show);
  18. /*为按钮添加点击监听事件,后面的章节会介绍*/
  19. showButton.setOnClickListener(new OnClickListener(){
  20. @Override
  21. public void onClick(View v) {
  22. if (mViewStub != null) {
  23. mViewStub.inflate();  //点击即导入ViewStub标签的内容
  24. }
  25. }
  26. });
  27. }
  28. }

运行效果如图所示,当点击按钮后,导入的布局就会显示,如图所示。这里要注意的是,其实很多时候我们不需要保留ViewStub的引用(这个例子中我们在字段里保留了ViewStub的引用),因为当ViewStub inflate后,这个ViewStub就从View层次中移除了。在读者深入学习后,会经常用到infate()方法来导入布局加载到原来的view 上,那时候你会发现用ViewStub是个比那更好的办法。但是要注意的是,ViewStub还不支持<merge/>标签。

 

好了,今天就写到这了。希望对大家有帮助,有问题可以留言交流。欢迎转载,但是请注明出处。

转载于:https://blog.51cto.com/notice501/640956

android UI进阶之布局的优化(二)相关推荐

  1. android UI进阶之布局的优化

    好久没更新博客了,趁着清明来写点什么. 今天来讲下如何使用android中提供的工具优化我们的布局.首先我们写一个最简单的框架布局. <?xml version="1.0"  ...

  2. Android 开发 -- 开发第一个安卓程序、Android UI开发(布局的创建:相对布局和线性布局、控件单位:px pt dp sp、常用控件 、常见对话框、ListView)

    文章目录 1. 开发第一个Hello World程序 1.1 开发程序 1.2 认识程序中的文件 1.3 Android程序结构 1.4 安卓程序打包 2. Android UI开发 2.1 布局的创 ...

  3. android UI进阶之仿iphone的tab效果(二)

    今天把这个仿iphone效果的tab写完,这个例子参考国外rolle3k共享的代码,感谢rolle3k. 上篇博客我们写了一个Itab类,介绍了背景的绘制和简单的一个图的贴图方法.我们继续来完成Ita ...

  4. Android UI进阶之旅9 Material Design之沉浸式设计

    ###沉浸式设计基本概念 官方的沉浸式Translucent定义:就是让整个APP沉浸(充斥了整个屏幕)在屏幕里面,没有显示状态栏,甚至没有显示底部导航栏. 平时大家所讨论的沉浸式:比如QQ的顶部To ...

  5. android UI进阶之实现listview中checkbox的多选与记录

    今天继续和大家分享涉及到listview的内容.在很多时候,我们会用到listview和checkbox配合来提供给用户一些选择操作.比如在一个 清单页面,我们需要记录用户勾选了哪些条目.这个的实现并 ...

  6. android UI进阶之style和theme的使用

    今天来和大家分享一下android中UI设计里面常会用到的style和theme. 首先,style和theme都是资源,android提供了很多这样的默认资源.你可以来使用它们.同时你也可以自己定义 ...

  7. (转)android UI进阶之用ViewPager实现欢迎引导页面

    ViewPager需要android-support-v4.jar这个包的支持,来自google提供的一个附加包.大家搜下即可. ViewPager主要用来组织一组数据,并且通过左右滑动的方式来展示. ...

  8. android UI进阶之实现listview的分页加载

    上篇博文和大家分享了下拉刷新,这是一个用户体验非常好的操作方式.新浪微薄就是使用这种方式的典型. 还有个问题,当用户从网络上读取微薄的时候,如果一下子全部加载用户未读的微薄这将耗费比较长的时间,造成不 ...

  9. (转) android UI进阶之用gallery实现可滑动的Tab

    首先我们需要写Gallery的适配器.这里我们要注意的是Gallery有一个特点,就是起始一个元素的左边会留下一块空位,如下图所示: 这样我们的Tab显然不是很完美,如何解决?开始想的就是去看gall ...

最新文章

  1. Java多层的异常捕获
  2. 云服务器 VNC 远程连接
  3. 简要分析电话光端机的常见问题
  4. java fast math,Java FastMath.signum方法代码示例
  5. c#學習筆記--Visual Studio 使用
  6. mysql 撤销删除_线上磁盘告警,mysql无法释放空间,踩了个大坑,大家记得别踩坑...
  7. 能不能在FOR循环中执行SQL?
  8. PHP 5.6 已结束安全支持,你升级到 PHP 7 系列了吗?
  9. python竞赛内存_python的内存机制
  10. 医学统计学笔记之设计
  11. 【VB.net】大地测量——白塞尔大地解算程序设计
  12. 初识AutoIt v3
  13. 有关“凸”方面的概念:凸(集/函数/优化/二次规划)
  14. 计算机二级考试高级应用软件版本,计算机二级高级办公软件考哪个版本
  15. 苹果手机系统更新信号无服务器,苹果手机经常显示无信号该如何解决你会吗?...
  16. android wifi驱动加载失败怎么办,请教WIFI连接失败问题,如何解决
  17. 晨跑、午后跑和夜跑对身体的影响及优缺点
  18. 计算机课师生互动过多,《计算机应用基础》课师生互动教学策略的个案研究.doc...
  19. 10_JavaScript数据结构与算法(十)哈希表
  20. 为什么只有20%香港人愿意使用移动支付?

热门文章

  1. 一分钟解决idea端口占用问题
  2. C# Process执行bat
  3. 从技术走向管理的注意要点
  4. L4,C16:差1墩,从张数最多的套上去找
  5. 大学基础课程之重要性
  6. 用python连接redis时错误InvalidResponse: Protocol Erro...
  7. 如何到达永生?揭示科学之美
  8. nginx---ngix虚拟主机配置实例
  9. Lync日常维护之四:部分管理操作
  10. C#正则表达式整理备忘