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

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

       

  • 相关阅读:
    python3.6.4源码安装
    centos 6 中恢复删除的文件
    mysql5.6.8源码安装
    zookeeper集群搭建
    vmware 12中安装苹果系统
    docker被入侵后.............
    关于docker
    关于redis
    人生的价值 幸福感
    c# 泛型
  • 原文地址:https://www.cnblogs.com/xingmeng/p/2652013.html
Copyright © 2011-2022 走看看