Android 动态加载布局

douandroid 2012-02-18

Android 动态加载布局 

由于前段时间项目需要,需要在一个页面上加载根据不同的按钮加载不同的布局页面,当时想到用tabhot。不过美工提供的界面图完全用不上tabhot,所以想到了动态加载的方法来解决这一需求。在这里我整理了一下,写了一个DEMO希望大家以后少走点弯路。

首先,我们先把界面的框架图画出来,示意图如下:

中间白色部门是一个线性布局文件,我喜欢在画图的时候用不同的颜色将一块布局标示出来,方便查看。布局文件代码如下:

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;  
    }  
  
}  

项目大纲如下图:

好了,到此我们的准备工作就己经完成,接下来就是要教大家如何实现动态加载上面所画的布局页面了,先看一下效果图:

点击第一个按钮:

点击第二个按钮:

动态加载代码如下:

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的开发技术。

Tip:因为是基于VIEW操作,因此你可以用Animation的动画效果使其更换界面更为自然,观赏性更强。

相关推荐