Android 動態加載佈局

 

因爲前段時間項目須要,須要在一個頁面上加載根據不一樣的按鈕加載不一樣的佈局頁面,當時想到用 tabhot 。不過美工提供的界面圖徹底用不上tabhot ,因此想到了動態加載的方法來解決這一需求。在這裏我整理了一下,寫了一個 DEMO 但願你們之後少走點彎路。
首先,咱們先把界面的框架圖畫出來,示意圖以下:

java

 

中間白色部門是一個線性佈局文件,我喜歡在畫圖的時候用不一樣的顏色將一塊佈局標示出來,方便查看。佈局文件代碼以下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="fill_parent"
    android:layout_height="fill_parent"> 
    <LinearLayout android:orientation="horizontal"
        android:layout_width="wrap_content" android:layout_height="wrap_content">
        <Button android:text="加載ListView" android:id="@+id/Button01"
            android:layout_width="wrap_content" android:layout_height="wrap_content">
        </Button>
        <Button android:text="加載另一個頁面" android:id="@+id/Button02"
            android:layout_width="wrap_content" android:layout_height="wrap_content"></Button>
    </LinearLayout>
    <LinearLayout android:id="@+id/LinearLayout01" android:background="#FFFFFF"
        android:layout_width="fill_parent" android:layout_height="fill_parent"></LinearLayout>
</LinearLayout>
 從上面的效果圖能夠看出,那塊白色的線性佈局是用來動態加載傳進來的佈局文件。好了,咱們就來作若是把佈局文件動態的加載進來。下面咱們一步一步來實現這個效果,首先,先把須要的 XML  勾畫出來,分爲步驟以下。
  • 新建一個佈局用來存放 ListView 頁面,代碼以下:

<?xml version="1.0" encoding="UTF-8"?>
<LinearLayout android:id="@+id/layout"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <ListView android:id="@+id/ListView01" android:layout_width="wrap_content"
        android:layout_height="wrap_content"></ListView>
</LinearLayout>
 新建一個 ListView 每一行數據的樣式,代碼以下:

 

<?xml version="1.0" encoding="UTF-8"?>
<LinearLayout android:id="@+id/LinearLayout01"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <TextView android:text="@+id/TextView01" android:id="@+id/TextView01"
        android:layout_width="wrap_content" android:layout_height="wrap_content"></TextView>
</LinearLayout>

 新建另一個頁面,用來區分此頁面是動態加載的,代碼以下: android

 

 

<?xml version="1.0" encoding="UTF-8"?>
<LinearLayout android:id="@+id/hellolayout"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <TextView android:text="HELLO"  
        android:layout_width="wrap_content" android:layout_height="wrap_content"></TextView>
</LinearLayout>

 實現ListView 的添充數據,這裏不詳細介紹如何填充ListView 每行數據,代碼以下: app

 

package com.terry; 
 

import java.util.ArrayList;
import java.util.HashMap;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

public class listAdapter extends BaseAdapter {

    ArrayList<HashMap<String, Object>> list = new ArrayList<HashMap<String, Object>>();

    private LayoutInflater inflater;
    public listAdapter(Context contex)
    {
        inflater=LayoutInflater.from(contex);
        HashMap<String, Object> map=new HashMap<String, Object>();
        for (int i = 0; i < 10; i++) {
            map.put("name", "例子");
            list.add(map);
        }
        
    }
    
    @Override
    public int getCount() {
        // TODO Auto-generated method stub
        return list.size();
    }

    @Override
    public Object getItem(int position) {
        // TODO Auto-generated method stub
        return list.get(position);
    }

    @Override
    public long getItemId(int position) {
        // TODO Auto-generated method stub
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // TODO Auto-generated method stub
        final viewHolder myHolder;
        if (convertView==null) {
            myHolder=new viewHolder();
            convertView=inflater.inflate(R.layout.list_view_row, null);
            myHolder.tv=(TextView)convertView.findViewById(R.id.TextView01);
            convertView.setTag(myHolder);
        }
        else
        {
            myHolder=(viewHolder)convertView.getTag();
        }
        myHolder.tv.setText(list.get(position).get("name").toString());
        return convertView;
    }

}

 好了,到此咱們的準備工做就己經完成,接下來就是要教你們如何實現動態加載上面所畫的佈局頁面了,先看一下效果圖: 框架

 

動態加載代碼以下:ide

 

 

package com.terry; 
 

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.TextView;

public class dynaActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        final LayoutInflater inflater = LayoutInflater.from(this);
        Button btn = (Button) findViewById(R.id.Button01);
        Button btn2 = (Button) findViewById(R.id.Button02);
        final LinearLayout lin = (LinearLayout) findViewById(R.id.LinearLayout01);
        btn.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                LinearLayout layout = (LinearLayout) inflater.inflate(
                        R.layout.listview, null).findViewById(R.id.layout);
                ListView lv=(ListView)layout.getChildAt(0);
                lv.setAdapter(new listAdapter(dynaActivity.this));
                lin.removeAllViews();
                lin.addView(layout);
            }
        });
        
        btn2.setOnClickListener(new OnClickListener() {
            
            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                LinearLayout layout = (LinearLayout) inflater.inflate(
                        R.layout.hello, null).findViewById(R.id.hellolayout);
                 TextView lv=(TextView)layout.getChildAt(0);
                 lv.setTextColor(Color.RED);
                lin.removeAllViews();
                lin.addView(layout);
            }
        });
    }
}
 

 

  • 上面經過使用LayoutInflater  每次點擊按鈕時候去讀取佈局文件,而後找到佈局文件裏面的各個VIEW 操做完VIEW 後加載進咱們setContentView 方面裏面的要放的佈局文件裏面,每次動態加載文件必需 調用 removeAllViews方法,清除以前的加載進來的 View 。是否是很簡單?固然動態加載VIEW 還有許多種方法,多嘗試不一樣寫法。可能會領會不同的心得,祝你早上掌握android 的開發技術。