1、在build.gradle中添相应的依赖库(如图):
compile 'com.android.support:recyclerview-v7:23.4.0'
2、Fruit.java(实类)
//定义了一个水果的实类
public class Fruit {
private int imageView;
private String textView;
public Fruit(int imageView, String textView) {
this.imageView = imageView;
this.textView = textView;
}
public int getImageView() {
return imageView;
}
public String getTextView() {
return textView;
}
}
3、fruit_avtivity.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">
<!--定义存放图片和文字的布局-->
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp" />
</LinearLayout>
4、activity_main.xml(RecyclerView布局)
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.jcs.myfruitlistview.MainActivity">
<!--定义LisView-->
<ListView
android:id="@+id/list"
android:layout_width="match_parent"
android:layout_height="match_parent">
</ListView>
</LinearLayout>
5、 MainActivity.java
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
List<Fruit> list = new ArrayList<>();
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initList();
FruitAdapter fruitAdapter = new FruitAdapter(MainActivity.this, R.layout.fruit_activity, list);
final ListView listView = (ListView) findViewById(R.id.list);
//ListView增加适配器
listView.setAdapter(fruitAdapter);
//注册setOnItemClickListener()监听器
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
//在数组中获取Fruit的实例
Fruit fruit = list.get(i);
Toast.makeText(MainActivity.this, fruit.getTextView(), Toast.LENGTH_SHORT).show();
}
});
}
//实例化数组
private void initList() {
for (int i = 0; i < 10; i++) {
Fruit fruit1 = new Fruit(R.drawable.guan, "guan");
Fruit fruit2 = new Fruit(R.drawable.hua, "hua");
Fruit fruit3 = new Fruit(R.drawable.qin, "qin");
list.add(fruit1);
list.add(fruit2);
list.add(fruit3);
}
}
}
7、FruitAdapter.java(适配器)
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
List<Fruit> list = new ArrayList<>();
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initList();
FruitAdapter fruitAdapter = new FruitAdapter(MainActivity.this, R.layout.fruit_activity, list);
final ListView listView = (ListView) findViewById(R.id.list);
//ListView增加适配器
listView.setAdapter(fruitAdapter);
//注册setOnItemClickListener()监听器
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
//在数组中获取Fruit的实例
Fruit fruit = list.get(i);
Toast.makeText(MainActivity.this, fruit.getTextView(), Toast.LENGTH_SHORT).show();
}
});
}
//实例化数组
private void initList() {
for (int i = 0; i < 10; i++) {
Fruit fruit1 = new Fruit(R.drawable.guan, "guan");
Fruit fruit2 = new Fruit(R.drawable.hua, "hua");
Fruit fruit3 = new Fruit(R.drawable.qin, "qin");
list.add(fruit1);
list.add(fruit2);
list.add(fruit3);
}
}
}
8、效果图
9、设置水平布局
9.1 fruit_activity.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="100dp"
android:orientation="horizontal"
>
<!--设置每一个Fruit显示方式-->
<LinearLayout
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
</LinearLayout>
9.2 在MainActivity.java中增加一句
linearLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
9.3效果图
10、增加点击监听器
FruitApadter.java
package com.example.jcs.myrecyclerview;
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 android.widget.Toast;
import java.util.List;
/**
* Created by JCS on 2017/6/25.
*/
//继承RecyclerView.Adapter适配器(实现下面三个方法)
public class FruitAdapter extends RecyclerView.Adapter<FruitAdapter.ViewHolder> {
List<Fruit> list;
//定义内部类继承RecyclerView.ViewHolder
static class ViewHolder extends RecyclerView.ViewHolder {
//通过传来的view找到控件
ImageView imageView;
TextView textView;
View fruitView;
public ViewHolder(View itemView) {
super(itemView);
fruitView = itemView;
imageView = (ImageView) itemView.findViewById(R.id.imageView);
textView = (TextView) itemView.findViewById(R.id.textView);
}
}
//传来数据
public FruitAdapter(List<Fruit> list) {
this.list = list;
}
@Override
public ViewHolder onCreateViewHolder(final ViewGroup parent, final int viewType) {
//加载列的布局到RecyclerView(parent)中
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.fruit_activity, parent, false);
//实例化ViewHolder把布局传入(一定要final类型)
final ViewHolder viewHolder = new ViewHolder(view);
viewHolder.imageView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//获得点击的那个对象
int position = viewHolder.getAdapterPosition();
//找到对象的实例
Fruit fruit = list.get(position);
//打印
Toast.makeText(view.getContext(),fruit.getImageView(),Toast.LENGTH_SHORT).show();
}
});
viewHolder.textView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
int position = viewHolder.getAdapterPosition();
Fruit fruit = list.get(position);
Toast.makeText(view.getContext(),fruit.getTextView(),Toast.LENGTH_SHORT).show();
}
});
return viewHolder;
}
@Override
public void onBindViewHolder(ViewHolder holder, int position) {
//获取Fruit实例
Fruit fruit = list.get(position);
//设置控件的值
holder.imageView.setImageResource(fruit.getImageView());
holder.textView.setText(fruit.getTextView());
}
@Override
//获得数据的大小
public int getItemCount() {
return list.size();
}
}
10、效果图