一、步骤
1、在layout创建两个布局,分别是自己的回答条,和对方的回答条。
2、创建ChatMessage这个类,成员变量有头像地址、聊天内容、所属类型(假设1表示对方,2表示自己)。
3、创建ChatBaseAdapter,故名思意继承BaseAdapter。就主要展示下getView()方法
private ArrayList<ChatMessage> mChatMessages; @Override public View getView(int position, View convertView, ViewGroup parent) { ChatViewHolder chatViewHolder = null; //获取当前View所处List容器中的数据 ChatMessage chatMessage = (ChatMessage)getItem(position); if (convertView == null){ chatViewHolder = new ChatViewHolder(); //当为1的时候,创建对方布局 if (getItemViewType(position) == 1) { convertView = LayoutInflater.from(mContext).inflate(R.layout.adapter_left, parent, false); chatViewHolder.ivIcon = (ImageView) convertView.findViewById(R.id.left_iv_icon); chatViewHolder.tvContent = (TextView) convertView.findViewById(R.id.left_tv_content); } //否则创建自己的布局 else { convertView = LayoutInflater.from(mContext).inflate(R.layout.adapter_right, parent, false); chatViewHolder.ivIcon = (ImageView) convertView.findViewById(R.id.right_iv_icon); chatViewHolder.tvContent = (TextView) convertView.findViewById(R.id.right_tv_content); } convertView.setTag(chatViewHolder); } else { chatViewHolder = (ChatViewHolder) convertView.getTag(); } //输入数据 chatViewHolder.ivIcon.setImageResource(chatMessage.getPictureUrl()); chatViewHolder.tvContent .setText(chatMessage.getTextContent()); return convertView; }
同时BaseAdapter还提供以下方法,确定ListView显示的布局的类型
@Override public int getItemViewType(int position) { return mChatMessages.get(position).getType(); } @Override public int getViewTypeCount() { return 2; }