欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android编程动态加载布局实例详解【附demo源码】

程序员文章站 2024-03-04 17:20:06
本文实例讲述了android编程动态加载布局的方法。分享给大家供大家参考,具体如下: 由于前段时间项目需要,需要在一个页面上加载根据不同的按钮加载不同的布局页面,当时想到...

本文实例讲述了android编程动态加载布局的方法。分享给大家供大家参考,具体如下:

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

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

Android编程动态加载布局实例详解【附demo源码】

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

<?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>

新建另外一个页面,用来区分此页面是动态加载的,代码如下:

<?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 每行数据,有不解的朋友可以查看前面listview相关文章 ,代码如下:

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

项目大纲如下图:

Android编程动态加载布局实例详解【附demo源码】

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

Android编程动态加载布局实例详解【附demo源码】

点击第一个按钮

Android编程动态加载布局实例详解【附demo源码】

点击第二个按钮

动态加载代码如下:

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 的动画效果使其更换界面更为自然,观赏性更强。

完整实例源码点击此处本站下载

更多关于android相关内容感兴趣的读者可查看本站专题:《android布局layout技巧总结》、《android开发入门与进阶教程》、《android调试技巧与常见问题解决方法汇总》、《android多媒体操作技巧汇总(音频,视频,录音等)》、《android基本组件用法总结》、《android视图view技巧总结》及《android控件用法总结

希望本文所述对大家android程序设计有所帮助。