聊天ListView使用ViewHolder

        聊天界面会展示至少两种布局,即收到消息和发送消息。这样一个ListView与平时使用的ListView的最大不同,在于它有两个不同的布局:收到的布局和发送的布局。需要利用Adapter实现这样的效果。即需要在获取布局的时候判断该获取哪个布局。

public abstract class

BaseAdapter

extends Object
implements ListAdapter SpinnerAdapter
java.lang.Object
   ↳android.widget.BaseAdapter

BaseAdapter这个类中提供了两个方法:

public intgetItemViewType (int position)
Added in API level 1

Get the type of View that will be created by getView(int, View, ViewGroup) for the specified item.

Parameters
positionThe position of the item within the adapter's data set whose view type we want.
Returns  返回第position个Item是何种类型

 

public intgetViewTypeCount ()
Added in API level 1

Returns the number of types of Views that will be created by getView(int, View, ViewGroup). Each type represents a set of views that can be converted ingetView(int, View, ViewGroup). If the adapter always returns the same type of View for all items, this method should return 1.

This method will only be called when when the adapter is set on the the AdapterView.

Returns 返回不同布局的数目
  • The number of types of Views that will be created by this adapter

首先需要实现两个布局——发送和接收

chat_item_itemin.xml

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal" 
    android:gravity="center_vertical"
    android:padding="10dp"
    android:layout_height="match_parent"
    android:layout_width="match_parent">
    
    <ImageView
        android:id ="@+id/icon_in"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/ic"/>
    
    <TextView
        android:id="@+id/text_in"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:textSize="20sp"/>"
    

</LinearLayout>


chat_item_itemout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center_vertical|right"
    android:orientation="horizontal"
    android:padding="10dp">


    <TextView
        android:id="@+id/text_out"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:textSize="20sp" />

    <ImageView
        android:id="@+id/icon_out"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/ic_launcher" />

</LinearLayout>


 

 

为了封装聊天内容,便于在Adapter中获取数据信息,封装一个Bean类来保存聊天信息。编写javabean就是编写一个java的类,所以只要会写类就能编写一个bean,这个类创建的一个对象称做一个bean。为了能让使用这个bean的应用程序构建工具(比如JSP引擎)知道这个bean的属性和方法,只需在类的方法命名上遵守以下规则:

1. 如果类的成员变量的名字是xxx,那么为了更改或获取成员变量的值,即更改或获取属性,在类中可以使用两个方法:

getXxx(),用来获取属性xxx。

setXxx(),用来修改属性xxx。

2. 对于boolean类型的成员变量,即布尔逻辑类型的属性,允许使用"is"代替上面的"get"和"set"。

3. 类中方法的访问属性都必须是public的。

4. 类中如果有构造方法,那么这个构造方法也是public的并且是无参数的。

 

ChatItemListViewBean.java

package sunny.example.ahfourlistviewchat;

//封装一个Bean来保存聊天信息
import android.graphics.Bitmap;
public class ChatItemListViewBean {

	private int type;
	private String text;
	private Bitmap icon;
	
	public ChatItemListViewBean(){
		
	}
	
	public int getType(){
		return type;
	}
	//在使用时setType 如bean1.setType(0);
	public void setType(int type){
		this.type = type;
	}
	
	public String getText(){
		return text;
	}
	
	public void setText(String text){
		this.text = text;
	}
	
	public Bitmap getIcon(){
		return icon;
	}
	
	public void setIcon(Bitmap icon){
		this.icon = icon;
	}
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="5dp">

    <ListView
        android:id="@+id/listView_chat"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:divider="@null"
        android:listSelector="@android:color/transparent" />

</LinearLayout>

 

ChatItemListViewTest.java

package sunny.example.ahfourlistviewchat;

import android.support.v7.app.ActionBarActivity;
import android.widget.ListView;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import java.util.List;
import java.util.ArrayList;
public class ChatItemListViewTest extends ActionBarActivity{

	private ListView mListView;
	protected void onCreate(Bundle savedInstanceState){
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		mListView = (ListView)findViewById(R.id.listView_chat);
		ChatItemListViewBean bean1 = new ChatItemListViewBean();
		bean1.setType(0);
		bean1.setIcon(BitmapFactory.decodeResource(getResources(), R.drawable.ic_launcher));
		bean1.setText("Hello. How are you?");
		
		ChatItemListViewBean bean2 = new ChatItemListViewBean();
		bean2.setType(1);
		bean2.setIcon(BitmapFactory.decodeResource(getResources(), R.drawable.ic_launcher));
		bean2.setText("Fine. Thank you");
		
		List<ChatItemListViewBean> data = new ArrayList<ChatItemListViewBean>();
		data.add(bean1);
		data.add(bean2);
		mListView.setAdapter(new ChatItemListViewAdapter(this,data));
	}
}



 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值