Android中多层动态嵌套布局的实现
1.概念:在开发⼀些复杂界⾯,尤其是开发平板电脑页⾯时,界⾯布局往往⽐⼿机布局复杂很多。此时就需要⽤到嵌套布局。同时为了达到某种效果,需要局部的页⾯能够动态的变化,最典型的就是在⼀个页⾯中使⽤多个ViewPager。当这些ViewPager所在的页⾯也是动态变化的时候,就需要实现多层LinearLayout的嵌套。⽐如⼀个标签页⾯,头部是静态的,内容部分是动态变化的,同时每个内容中⼜需要动态变化,代码实现时就需要通过多次添加来实现。
2.下⾯是⼀个简单的案例(该案例只是实现了多层嵌套的添加,如果需要实现动态的添加效果,只需通过控制条件改变每次添加的内容即可。)
PadTestActivity.java
package com.devin;
android layout布局import android.app.Activity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.widget.LinearLayout;
public class PadTestActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
setContentView(R.layout.main);
LayoutInflater inflater=getLayoutInflater();
//Add first page
LinearLayout myFirst = (LinearLayout) inflater.inflate(
R.layout.first, null).findViewById(First);
LinearLayout layoutMain = (LinearLayout)findViewById(R.id.LayoutMain);
layoutMain.addView(myFirst); //Show the page first
//Add second page
LinearLayout mySecond = (LinearLayout) inflater.inflate(
R.layout.second, null).findViewById(Second);
LinearLayout layoutFirst = (LinearLayout) findViewById(R.id.LayoutFirst);
layoutFirst.addView(mySecond);
//Add third page
LinearLayout myThird = (LinearLayout) inflater.inflate(
R.layout.third, null).findViewById(Third);
LinearLayout layoutSecond = (LinearLayout) findViewById(R.id.LayoutSecond);
layoutSecond.addView(myThird);
}
}
布局代码
l
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="schemas.android/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical">
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Main Page"/>
<LinearLayout
android:id="@+id/LayoutMain"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
</LinearLayout>
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Main Page"/>
</LinearLayout>
l
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="schemas.android/apk/res/android"
android:id="@+id/myFirst"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="First Page"/>
<LinearLayout
android:id="@+id/LayoutFirst"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
</LinearLayout>
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="First Page"/>
</LinearLayout>
l
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="schemas.android/apk/res/android" android:id="@+id/mySecond"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Second Page"/>
<LinearLayout
android:id="@+id/LayoutSecond"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
</LinearLayout>
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Second Page"/>
</LinearLayout>
l
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="schemas.android/apk/res/android" android:id="@+id/myThird"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Third Page"/>
<LinearLayout
android:id="@+id/LayoutThird"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
</LinearLayout>
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Third Page"/>
</LinearLayout>
PS:欢迎关注"Devin说",会不定期更新Java相关技术知识。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论