RecyclerView万能适配器
效果如下
一、框架引入
先在项目的 build.gradle(Project:XXXX) 的 repositories 添加:
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
然后在Module的 build.gradle(Module:app) 的 dependencies 添加:
dependencies {
......
compile 'com.github.CymChad:BaseRecyclerViewAdapterHelper:2.9.22'
}
注意: 一旦出现加载失败的情况,只有两种情况:
一是:配置没配置好
配置没配置好,有几种情况:
- 只配置了 dependencies
- 配置 repositories,但是位置错了,build.gradle(Project:XXXX) 文件下的repositories有两个,一个是buildscript下面的,一个是allprojects下面的,要配置到allprojects下面才是对的。
- 版本号前面多一个v,这个是我的锅,在2.1.2版本之前都是带v的,之后(包含2.1.2)都不需要带v。
二是:网络原因
第一步:在布局文件中引入RecyclerView
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".base.Main4Activity">
<android.support.v7.widget.RecyclerView
android:id="@+id/recycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</RelativeLayout>
第二步:编写条目布局文件
item_rv.xml
<?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"
android:padding="5dp">
<ImageView
android:id="@+id/iv_img"
android:layout_width="150dp"
android:layout_height="80dp" />
<TextView
android:id="@+id/tv_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:layout_marginLeft="10dp"
android:layout_marginTop="10dp"
android:layout_toRightOf="@+id/iv_img"
android:text="我是标题"
android:textColor="#f00"
android:textSize="20sp" />
<TextView
android:id="@+id/tv_content"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/tv_title"
android:layout_marginLeft="15dp"
android:layout_marginTop="10dp"
android:layout_toRightOf="@id/iv_img"
android:text="我是描述" />
</RelativeLayout>
第三步:编写数据实体类型
Model.java
package com.example.myrecyclelistview.base;
public class Model {
private String title;
private String content;
private String imgUrl;
public Model() {
}
public Model(String title, String content, String imgUrl) {
this.title = title;
this.content = content;
this.imgUrl = imgUrl;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getContent() {
return content;
}
public void setContent(String content) {
this.content = content;
}
public String getImgUrl() {
return imgUrl;
}
public void setImgUrl(String imgUrl) {
this.imgUrl = imgUrl;
}
}
第四步:编写适配器
MyAdapter.java
package com.example.myrecyclelistview.base;
import android.support.annotation.LayoutRes;
import android.support.annotation.Nullable;
import com.chad.library.adapter.base.BaseQuickAdapter;
import com.chad.library.adapter.base.BaseViewHolder;
import com.example.myrecyclelistview.R;
import java.util.List;
public class MyAdapter_M4 extends BaseQuickAdapter<Model> {
public MyAdapter_M4(@LayoutRes int layoutResId, @Nullable List<Model> data) {
super(layoutResId, data);
}
@Override
protected void convert(BaseViewHolder helper, Model item) {
//可链式调用赋值
helper.setText(R.id.tv_title, item.getTitle())
.setText(R.id.tv_content, item.getContent())
.setImageResource(R.id.iv_img, R.mipmap.ic_launcher);
//获取当前条目position
//int position = helper.getLayoutPosition();
}
}
最后一步:在Activity中使用该适配器
MainActivity.java
package com.example.myrecyclelistview.base;
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.Toast;
import com.chad.library.adapter.base.BaseQuickAdapter;
import com.example.myrecyclelistview.MainActivity;
import com.example.myrecyclelistview.MyAdapter;
import com.example.myrecyclelistview.R;
import java.util.ArrayList;
import java.util.List;
public class Main4Activity extends AppCompatActivity {
private RecyclerView recyclerView;
private List<Model> datas;
private MyAdapter_M4 adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main4);
//初始化RecyclerView
recyclerView = (RecyclerView) findViewById(R.id.recycler_view);
//模拟的数据(实际开发中一般是从网络获取的)
datas = new ArrayList<>();
Model model;
for (int i = 0; i < 15; i++) {
model = new Model();
model.setTitle("我是第" + i + "条标题");
model.setContent("第" + i + "条内容");
datas.add(model);
}
//创建布局管理
LinearLayoutManager layoutManager = new LinearLayoutManager(this);
layoutManager.setOrientation(LinearLayoutManager.VERTICAL);
recyclerView.setLayoutManager(layoutManager);
//创建适配器
adapter = new MyAdapter_M4(R.layout.item_rv, datas);
//给RecyclerView设置适配器
recyclerView.setAdapter(adapter);
/**
* 该适配器提供了5种动画效果(渐显、缩放、从下到上,从左到右、从右到左)
* public static final int ALPHAIN = 0x00000001;
* public static final int SCALEIN = 0x00000002;
* public static final int SLIDEIN_BOTTOM = 0x00000003;
* public static final int SLIDEIN_LEFT = 0x00000004;
* public static final int SLIDEIN_RIGHT = 0x00000005;
*/
//开启动画(默认为渐显效果)
adapter.openLoadAnimation();
/**
* 使用缩放动画
* 更换动画效果
*/
// adapter.openLoadAnimation(BaseQuickAdapter.SCALEIN);
//条目点击事件
adapter.setOnRecyclerViewItemClickListener(new BaseQuickAdapter.OnRecyclerViewItemClickListener() {
@Override
public void onItemClick(View view, int i) {
Toast.makeText(Main4Activity.this, "点击了第" + (i + 1) + "条条目", Toast.LENGTH_SHORT).show();
}
});
//条目长按事件
adapter.setOnRecyclerViewItemLongClickListener(new BaseQuickAdapter.OnRecyclerViewItemLongClickListener() {
@Override
public boolean onItemLongClick(View view, int i) {
Toast.makeText(Main4Activity.this, "长按了第" + (i + 1) + "条条目", Toast.LENGTH_SHORT).show();
return true;
}
});
}
}