Android ListView存在多个item样式的处理方法

在项目开发的时候,相信大家可能会遇到一个ListView中出现多个不同的布局,遇到这个问题我的大致思路就是创建多个viewholder,在getViewType的时候设置不同位置的item用不同的viewholder,好了不废话那么多直接上代码:

package com.sunny.youdao;

import java.util.ArrayList;
import java.util.List;

import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.CheckBox;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;

public class MyAdapter extends BaseAdapter {

	private Context mContext;
	private LinearLayout linearLayout = null;
	private LayoutInflater inflater;
	private List<String> list = new ArrayList<String>();
	private TextView tex;
	private final int VIEW_TYPE = 3;
	private final int TYPE_1 = 0;
	private final int TYPE_2 = 1;
	private final int TYPE_3 = 2;

	public MyAdapter(Context context, List<String> list) {
		// TODO Auto-generated constructor stub
		this.mContext = context;
		this.list = list;
		inflater = LayoutInflater.from(mContext);
	}

	@Override
	public int getCount() {
		// TODO 自动生成的方法存根
		return list.size();
	}

	@Override
	public Object getItem(int position) {
		// TODO 自动生成的方法存根
		return list.get(position);
	}

	@Override
	public long getItemId(int position) {
		// TODO 自动生成的方法存根
		return position;
	}

	//每个convert view都会调用此方法,获得当前所需要的view样式
    @Override
    public int getItemViewType(int position) {
        // TODO Auto-generated method stub
        int viewtype = position%6;
        if(viewtype == 0)
        return TYPE_1;
        else if(viewtype < 3)
            return TYPE_2;
        else if(viewtype < 6)
            return TYPE_3;
        else
            return TYPE_1;
    }
    
    //返回样式的数量
    @Override
    public int getViewTypeCount() {
        // TODO Auto-generated method stub
        return 3;
    }

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		viewHolder1 holder1 = null;
		viewHolder2 holder2 = null;
		viewHolder3 holder3 = null;
		int type = getItemViewType(position);

		// 无convertView,需要new出各个控件
		if (convertView == null) {
			Log.e("convertView = ", "###convertView为空###");
			// 按当前所需的样式,确定new的布局
			switch (type) {
			case TYPE_1:
				convertView = inflater.inflate(R.layout.listitem1, parent,false);
				holder1 = new viewHolder1();
				holder1.textView = (TextView) convertView.findViewById(R.id.textview1);
				holder1.checkBox = (CheckBox) convertView.findViewById(R.id.checkbox);
				Log.e("convertView = ", "布局样式一");
				convertView.setTag(holder1);
				break;
			case TYPE_2:
				convertView = inflater.inflate(R.layout.listitem2, parent,false);
				holder2 = new viewHolder2();
				holder2.textView = (TextView) convertView.findViewById(R.id.textview2);
				Log.e("convertView = ", "布局样式二");
				convertView.setTag(holder2);
				break;
			case TYPE_3:
				convertView = inflater.inflate(R.layout.listitem3, parent,false);
				holder3 = new viewHolder3();
				holder3.textView = (TextView) convertView.findViewById(R.id.textview3);
				holder3.imageView = (ImageView) convertView.findViewById(R.id.imageview);
				Log.e("convertView = ", "布局样式三");
				convertView.setTag(holder3);
				break;
			}
		} else {
			// 有convertView,按样式,取得不用的布局
			switch (type) {
			case TYPE_1:
				holder1 = (viewHolder1) convertView.getTag();
				Log.e("convertView= ", "布局样式一");
				break;
			case TYPE_2:
				holder2 = (viewHolder2) convertView.getTag();
				Log.e("convertView= ", "布局样式二");
				break;
			case TYPE_3:
				holder3 = (viewHolder3) convertView.getTag();
				Log.e("convertView= ", "布局样式三");
				break;
			}
		}

		// 设置资源
		switch (type) {
		case TYPE_1:
			holder1.textView.setText(Integer.toString(position));
			holder1.checkBox.setChecked(true);
			break;
		case TYPE_2:
			holder2.textView.setText(Integer.toString(position));
			break;
		case TYPE_3:
			holder3.textView.setText(Integer.toString(position));
			holder3.imageView.setBackgroundResource(R.drawable.icon);
			break;
		}

		return convertView;
	}

	// 各个布局的控件资源
	class viewHolder1 {
		CheckBox checkBox;
		TextView textView;
	}

	class viewHolder2 {
		TextView textView;
	}

	class viewHolder3 {
		ImageView imageView;
		TextView textView;
	}

}

代码比较直观明了,注释也比较详细,就不在详细说明了,欢迎大家一块学习交流~

时间: 2024-12-08 19:53:28

Android ListView存在多个item样式的处理方法的相关文章

android listView 的最后一个item显示(菜鸟新手,老鸟勿喷)

问题:一个listView显示不满全屏时,最后一个item会自动占满剩下的屏幕高度,而我们需要看到的是每个item布局所要占的高度一样. 解决办法:主要是把ListView布局里面的高度设置为:android:layout_height="fill_parent" : listView显示的每个item就占同样的高度了.

Android ListView动态刷新某项Item

使用ViewHolder来刷新某项数据,而不用每次都全部刷新数据. 继承BaseAdapter,新建ViewHolder类. public class TestListAdapter extends BaseAdapter { private Context mContext; private List<String> strList; public TestListAdapter(Context context, List<String> list) { super(); thi

【转】Android ListView加载不同的item布局

原创教程,转载请保留出处:http://www.eoeandroid.com/thread-72369-1-1.html 最近有需求需要在listView中载入不同的listItem布局,开始没有使用convertView,加载了多个item后导致了内存泄露,所以回来研究convertView在多个listItem布局时的缓存及应用,并且和大家分享 构造Adapter时,没有使用缓存的 convertView,导致内存泄露 示例代码:public View getView(int positio

android listview中item通过viewpager实现

android listview中item通过viewpager实现 android listview中item通过viewpager实现,每一个item都支持viewpager实现图片切换功能.本项目主要介绍多个viewpager加载图片和listview 上下滑动不卡顿问题.本项目由作者Flyco分享的分享地址:https://github.com/H07000223/FlycoBanner_Master.本项目找对应id封装一个ViewFindUtils类,通过如下代码找id    /**

【转】Android 使用Scroller实现绚丽的ListView左右滑动删除Item效果

原文网址:http://blog.csdn.net/xiaanming/article/details/17539199 我在上一篇文章中Android 带你从源码的角度解析Scroller的滚动实现原理从源码的角度介绍了Scroller的滚动实现原理,相信大家对Scroller的使用有一定的了解,这篇文章就给大家带来使用Scroller的小例子,来帮助大家更加熟悉的掌握Scroller的使用,掌握好了Scroller的使用我们就能实现很多滑动的效果.例如侧滑菜单,launcher,ListVi

android listview级联三菜单选择地区,本地数据库sqlite级联地区,item选中不变色

前言:因为找了N多网上的资源都没有好的解决方案,别人都是只给思路没给具体源码,真TMD纠结,干嘛求别人,自己动手才是真,最痛恨那些所谓大牛的作风,给了点点代码就让别人去想,你让我们这种小白情何于堪!!!!!!此例是基于listview来实现本地sqlite实现的! 二话不说,程序猿求的是有图有真相有源码!大家下载后有什么问题可以找到本人:QQ508181017 核心代码如下 1.数据库操作类 package com.icq.demo.db; import java.util.ArrayList;

本文出自xiaanming的博客(http://blog.csdn.net/xiaanming/article/details/18311877)Android 使用NineOldAndroids实现绚丽的ListView左右滑动删除Item效果

今天还是给大家带来自定义控件的编写,自定义一个ListView的左右滑动删除Item的效果,这个效果之前已经实现过了,有兴趣的可以看下Android 使用Scroller实现绚丽的ListView左右滑动删除Item效果,之前使用的是滑动类Scroller来实现的,但是看了下通知栏的左右滑动删除效果,确实很棒,当我们滑动Item超过一半的时候,item的透明度就变成了0,我们就知道抬起手指的时候item就被删除了,当item的透明度不为0的时候,我们抬起手指Item会回到起始位置,这样我们就知道

Android 使用NineOldAndroids实现绚丽的ListView左右滑动删除Item效果

今天还是给大家带来自定义控件的编写,自定义一个ListView的左右滑动删除Item的效果,这个效果之前已经实现过了,有兴趣的可以看下Android 使用Scroller实现绚丽的ListView左右滑动删除Item效果, 之前使用的是滑动类Scroller来实现的,但是看了下通知栏的左右滑动删除效果,确实很棒,当我们滑动Item超过一半的时候,item的透明度就变 成了0,我们就知道抬起手指的时候item就被删除了,当item的透明度不为0的时候,我们抬起手指Item会回到起始位置,这样我们就

Android ListView 多样式Item的一个注意点:(

闲来无事,在写一个多样式Item的ListView的Demo时,遇到了一个以前没遇过的问题; ╮( ̄▽ ̄")╭ 我们知道,ListView里可以有多种样式的item, 实现只需要重写: 1 @Override 2 public int getItemViewType(int position) { 3 int type = Integer.parseInt(mData.get(position).get(KEY_TYPE)); 4 switch (type) { 5 case TYPE_HEAD