recycleview多item布局的实现(简单聊天界面)
来源:互联网 发布:金山卫士 源码 编辑:程序博客网 时间:2024/05/21 20:21
因项目需求,需要在一个列表中实现多个不同的布局方式 ,模拟了一个聊天界面
recycleview多item布局最主要的还是adapter部分,也就是适配器的写法
适配器代码如下:
package com.example.lenovo.myapplication;import android.content.Context;import android.media.Image;import android.support.v7.widget.RecyclerView;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.ImageView;import android.widget.TextView;import java.util.List;/** * Created by lenovo on 2017/3/1. */public class MessageAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> { private LayoutInflater mLayoutInflater; private Context mContext; private List<Message> mDatas; public MessageAdapter(Context context,List<Message> mDatas) { this.mContext =context; this.mDatas =mDatas; mLayoutInflater =LayoutInflater.from(mContext); } @Override public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { if(viewType==Message.TYPE_ME){ return new MeItemViewHolder(mLayoutInflater.inflate(R.layout.rightshouyei_item,parent,false)) ; }else{ return new OtherItemViewHolder(mLayoutInflater.inflate(R.layout.leftshouye_item,parent,false)); } } @Override public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) { if(holder instanceof MeItemViewHolder){ ((MeItemViewHolder) holder).imageView.setImageResource(R.mipmap.ic_launcher); ((MeItemViewHolder) holder).textView.setText("我说什么"+mDatas.get(position).getMessage()); }else if(holder instanceof OtherItemViewHolder){ ((OtherItemViewHolder) holder).imageView.setImageResource(R.mipmap.ic_launcher); ((OtherItemViewHolder) holder).textView.setText("他说什么"+mDatas.get(position).getMessage()); } } @Override public int getItemCount() { return mDatas.size(); } @Override public int getItemViewType(int position) { return mDatas.get(position).getType(); } static class MeItemViewHolder extends RecyclerView.ViewHolder{ TextView textView; ImageView imageView; public MeItemViewHolder(View itemView) { super(itemView); textView = (TextView) itemView.findViewById(R.id.tv_right); imageView = (ImageView) itemView.findViewById(R.id.iv_right); } } static class OtherItemViewHolder extends RecyclerView.ViewHolder{ TextView textView; ImageView imageView; public OtherItemViewHolder(View itemView) { super(itemView); textView = (TextView) itemView.findViewById(R.id.tv_left); imageView = (ImageView) itemView.findViewById(R.id.iv_left); } }}
1、继承recycleview.adapter并将recycleview.viewHolder作为泛型传入,重写他的四个方法 onCreateViewHolder(返回viewHolder对象) 、onBindViewHolder(为相应的view绑定数据) 、getItemCount(返回item的个数,即数据的数目)、getItemViewType(返回当前的recycleview有多少种类型的布局)
2、onCreateViewHolder(ViewGroup parent, int viewType)这里的第二个参数就是View的类型,可以根据这个类型判断去创建不同item的ViewHolder
3、定义不同的内部类继承recycleview.viewHolder,当前我定义了两种不同的布局,如果有更多不同布局可自行扩展
不同的布局item自行设置,item布局如下:
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content"> <ImageView android:id="@+id/iv_left" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@mipmap/ic_launcher"/> <TextView android:id="@+id/tv_left" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_marginLeft="20dp" android:gravity="center" android:text="他说什么话"/></LinearLayout>
<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content"> <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:src="@mipmap/ic_launcher" android:id="@+id/iv_right" android:layout_marginRight="16dp" android:layout_marginEnd="16dp" android:layout_alignParentRight="true" android:layout_alignParentEnd="true"> </ImageView> <TextView android:id="@+id/tv_right" android:layout_width="wrap_content" android:layout_height="wrap_content" android:maxLines="2" android:ellipsize="end" android:gravity="right" android:text="他说什么不知的" android:layout_marginTop="20dp" android:layout_alignParentTop="true" android:layout_toLeftOf="@+id/iv_right" android:layout_toStartOf="@+id/iv_right" android:layout_marginRight="16dp" android:layout_marginEnd="16dp" /></RelativeLayout>
主布局如下:
<?xml version="1.0" encoding="utf-8"?><FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_shouye_acitivity" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.example.lenovo.myapplication.ShouyeAcitivity"> <RelativeLayout android:layout_width="match_parent" android:layout_height="match_parent"> <LinearLayout android:id="@+id/lin_input" android:layout_width="match_parent" android:layout_height="50dp" android:layout_alignParentBottom="true" android:background="@color/white" android:orientation="horizontal"> <EditText android:id="@+id/et_context" android:layout_width="0dp" android:hint="该说点什么" android:layout_height="match_parent" android:layout_weight="6" /> <Button android:id="@+id/bt_send" android:layout_width="wrap_content" android:layout_height="match_parent" android:text="发送" /> </LinearLayout> <android.support.v7.widget.RecyclerView android:id="@+id/rv_test" android:layout_width="match_parent" android:layout_above="@id/lin_input" android:layout_height="match_parent" /> </RelativeLayout></FrameLayout>
这里有个问题EditText获取焦点会自动调用软键盘,这时软键盘顶出来会把输入框和发送按钮遮住一部分,设置Framlayout分层可以有效解决这个问题,然后在AndroidManifest.xml文件中设置该activity属性android:windowSoftInputMode="adjustResize"
主界面会缩放,用来放置软键盘
package com.example.lenovo.myapplication;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.support.v7.widget.LinearLayoutManager;import android.support.v7.widget.RecyclerView;import android.view.View;import android.view.WindowManager;import android.widget.Button;import android.widget.EditText;import java.util.ArrayList;import java.util.List;import butterknife.BindView;import butterknife.ButterKnife;import butterknife.OnClick;public class ShouyeAcitivity extends AppCompatActivity { @BindView(R.id.rv_test) RecyclerView recyclerView; @BindView(R.id.bt_send) Button bt_send; @BindView(R.id.et_context) EditText et_context; private MessageAdapter adapter; private List<Message> messages =new ArrayList<>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_shouye_acitivity);// getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE); ButterKnife.bind(this); initdata(); LinearLayoutManager layoutManager =new LinearLayoutManager(this); adapter =new MessageAdapter(ShouyeAcitivity.this,messages); layoutManager.setOrientation(LinearLayoutManager.VERTICAL); recyclerView.setLayoutManager(layoutManager); recyclerView.setAdapter(adapter); } public void initdata(){ Message message1 =new Message("说什么呢,我也不知的",Message.TYPE_ME); Message message2 =new Message("说什么呢,我也不知的",Message.TYPE_OTHER); Message message3 =new Message("说什么呢,我也不知的",Message.TYPE_OTHER); Message message4 =new Message("说什么呢,我也不知的",Message.TYPE_ME); Message message5 =new Message("说什么呢,我也不知的",Message.TYPE_ME); Message message6 =new Message("说什么呢,我也不知的",Message.TYPE_OTHER); Message message7 =new Message("说什么呢,我也不知的",Message.TYPE_ME); messages.add(message1); messages.add(message2); messages.add(message3); messages.add(message4); messages.add(message5); messages.add(message6); messages.add(message7); } @OnClick(R.id.bt_send) public void onClick(View view){ switch (view.getId()){ case R.id.bt_send: if(!et_context.getText().equals("") && et_context.getText()!=null){ Message message =new Message(et_context.getText().toString(),Message.TYPE_ME); messages.add(message); adapter.notifyItemInserted(messages.size()-1);//有新消息时刷新recycleview中的显示 recyclerView.scrollToPosition(messages.size()-1);//将recycleview定位到最后一行 et_context.setText(""); } break; default: break; } }}
一个简单的聊天界面
1 0
- recycleview多item布局的实现(简单聊天界面)
- 使用recycleview实现item多布局踩的坑
- RecycleView多Item布局
- RecycleView实现混合Item布局
- 关于如何通过recycleview实现聊天界面的效果
- 类似QQ聊天界面,ListView的item显示不同布局
- 关于recycleview的item的布局问题
- RecycleView实现多布局
- RecycleView简单实现滑动删除Item
- 关于Recycleview返回多个item布局
- 简单实现带界面的一对一聊天
- 一个简单聊天界面的UI实现
- RecycleView的简单实现
- RecycleView的多布局
- recycleView的多布局
- Android开发笔记之RecycleView加载不同item布局的实现
- RecycleView实现复杂的布局
- 仿QQ聊天-listView的item多布局
- 分析支付宝客户端的插件机制
- 关于内存泄漏的一些小常识
- 游戏跨服架构进化之路
- tensorflow 分类问题
- PgSQL · 特性分析 · PostgreSQL Aurora方案与DEMO
- recycleview多item布局的实现(简单聊天界面)
- 最精简的XML格式与数组的互相转换
- 设备和模块的分类
- javascript面向对象
- del node
- poj 2484
- 计算机视觉之图像分割——分水岭算法WaterShed
- iBET Win Poker Game Card Lucky Draw Giveaway
- Matlab 5. 常用的数据处理函数:cat,zscore,permute,bsxfun,floor,.*和*。