Android中使用RecylerView实现聊天框效果

从Android 5.0开始,谷歌公司推出了一个用于大量数据展示的新控件RecylerView,可以用来代替传统的ListView,更加强大和灵活。在上篇文章给大家介绍了Android RecylerView入门教程,大家可以点击查看详情。

效果图如下:(其中,聊天框背景图用9-patch图,可以内容自适应调节。利用AndroidStudio自带的功能制作就行了,图片->右键->create 9-patch file。

其中要注意的是:

1、将9-patch图保存到drawable目录下才管用。

2、要将背景图片处理一下,缩放到足够小,它会自动伸缩。)

Android中使用RecylerView实现聊天框效果_第1张图片

Android中使用RecylerView实现聊天框效果_第2张图片

 

Android中使用RecylerView实现聊天框效果_第3张图片

1、activity_main.xml的代码如下:



  
  
    
    

2、layout_item_content.xml的代码如下:



  
    
  
  
    
  

3、RecyclerViewAdapter.java的代码如下:

package com.deepreality.recyclerviewdemo;
import android.content.Context;
import android.support.annotation.NonNull;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import android.widget.TextView;
import java.util.List;
public class RecyclerViewAdapter extends RecyclerView.Adapter {
  private Context mContext;
  private List tbChatContentList;
  private Tb_ChatContent tb_chatContent;
  static class ViewHolder extends RecyclerView.ViewHolder {
    private LinearLayout lLayoutReceive, lLayoutSend;
    private TextView tvReceive, tvSend;
    public ViewHolder(View itemView) {
      super(itemView);
      lLayoutReceive = itemView.findViewById(R.id.Layout_Item_Content_lLayoutReceive);
      lLayoutSend = itemView.findViewById(R.id.Layout_Item_Content_lLayoutSend);
      tvReceive = itemView.findViewById(R.id.Layout_Item_Content_tvContentReceive);
      tvSend = itemView.findViewById(R.id.Layout_Item_Content_tvContentSend);
    }
  }
  public RecyclerViewAdapter(Context mContext, List tbChatContentList) {
    this.mContext = mContext;
    this.tbChatContentList = tbChatContentList;
  }
  @NonNull
  @Override
  public RecyclerViewAdapter.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
    View view = LayoutInflater.from(mContext).inflate(R.layout.layout_item_content, parent, false);
    ViewHolder viewHolder = new ViewHolder(view);
    return viewHolder;
  }
  @Override
  public void onBindViewHolder(@NonNull RecyclerViewAdapter.ViewHolder holder, int position) {
    tb_chatContent = tbChatContentList.get(position);
    if (tb_chatContent.getType() == 0) {
      holder.lLayoutReceive.setVisibility(View.VISIBLE);
      holder.lLayoutSend.setVisibility(View.GONE);
      holder.tvReceive.setText(tb_chatContent.getContent());
    } else {
      holder.lLayoutReceive.setVisibility(View.GONE);
      holder.lLayoutSend.setVisibility(View.VISIBLE);
      holder.tvSend.setText(tb_chatContent.getContent());
    }
  }
  @Override
  public int getItemCount() {
    return tbChatContentList.size();
  }
}

4、MainActivity.java的代码如下:

package com.deepreality.recyclerviewdemo;
import android.content.Context;
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.widget.Button;
import android.widget.EditText;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
  private Context mContext;
  private RecyclerView rViewChat;
  private EditText etContent;
  private Button btnSend;
  private List tbChatContentList;
  private Tb_ChatContent tb_chatContent;
  private RecyclerViewAdapter recyclerViewAdapter;
  private String[] arrayContents = new String[]{"How are you", "Fine,Thank you.", "How are you"
      , "Fine,Thank you.", "How are you", "Fine,Thank you."};
  private int[] arrayTypes = new int[] {0, 1, 0, 1, 0, 1};
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    baseDataInit();
    bindViews();
    viewsAddListener();
    viewsDataInit();
  }
  private void baseDataInit() {
    mContext = this;
    tbChatContentList = new ArrayList<>();
  }
  private void bindViews() {
    rViewChat = findViewById(R.id.Main_rView);
    etContent = findViewById(R.id.Main_etContent);
    btnSend = findViewById(R.id.Main_btnSend);
  }
  private void viewsAddListener() {
    btnSend.setOnClickListener(this);
  }
  private void viewsDataInit() {
    rViewSetAdapter();
  }
  private void rViewSetAdapter() {
    for (int i = 0; i < arrayContents.length; i++) {
      tb_chatContent = new Tb_ChatContent(arrayContents[i], arrayTypes[i]);
      tbChatContentList.add(tb_chatContent);
    }
    //设置RecylerView的排列方式(线性,网格,瀑布流三种)
    LinearLayoutManager linearLayoutManager = new LinearLayoutManager(mContext);
    rViewChat.setLayoutManager(linearLayoutManager);
    //创建并绑定数据适配器
    recyclerViewAdapter = new RecyclerViewAdapter(mContext, tbChatContentList);
    rViewChat.setAdapter(recyclerViewAdapter);
  }
  @Override
  public void onClick(View v) {
    switch (v.getId()) {
      case R.id.Main_btnSend: {
        tb_chatContent = new Tb_ChatContent(etContent.getText().toString(), Tb_ChatContent.TYPE_SEND);
        tbChatContentList.add(tb_chatContent);
        //数据刷新
        recyclerViewAdapter.notifyDataSetChanged();
        //滑动到某一位置
        rViewChat.smoothScrollToPosition(tbChatContentList.size() - 1);
        break;
      }
      default:break;
    }
  }
}

总结

以上所述是小编给大家介绍的Android中使用RecylerView实现聊天框效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

你可能感兴趣的:(Android中使用RecylerView实现聊天框效果)