Android(滑动控件RecyclerView)

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、效果图这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值