Android/Java การสร้าง RecyclerView เบื้องต้น

A flexible view for providing a limited window into a large data set.

ไฟล์ที่เกี่ยวข้อง

  • build.gradle (Module: app)
  • activity_main.xml
  • MainActivity.java
  • values/colors.xml
  • drawable/item_state.xml
  • layout/custom_layout.xml
  • CustomItem.java
  • CustomHolder.java
  • CustomAdapter.java

build.gradle (Module: app)

apply plugin: 'com.android.application'

android {
    compileSdkVersion 29
    buildToolsVersion "29.0.0"
    defaultConfig {
        applicationId "com.phaisarn.myapplication"
        minSdkVersion 21
        targetSdkVersion 29
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'androidx.appcompat:appcompat:1.0.2'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test:runner:1.2.0'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'

    implementation 'androidx.recyclerview:recyclerview:1.0.0'
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
    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=".MainActivity">

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/recyclerView"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</androidx.constraintlayout.widget.ConstraintLayout>

MainActivity.java

package com.phaisarn.myapplication;

import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;

import android.os.Bundle;
import android.view.View;
import android.widget.Toast;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        final ArrayList<CustomItem> items = new ArrayList<>();
        items.add(new CustomItem(R.drawable.ic_1, "Seiri", "สะสาง"));
        items.add(new CustomItem(R.drawable.ic_2, "Seiton", "สะดวก"));
        items.add(new CustomItem(R.drawable.ic_3, "Seiso", "สะอาด"));
        items.add(new CustomItem(R.drawable.ic_4, "Seiketsu", "สุขลักษณะ"));
        items.add(new CustomItem(R.drawable.ic_5, "Shitsuke", "สร้างนิสัย"));

        CustomAdapter adapter = new CustomAdapter(this, items);
        RecyclerView rcv = findViewById(R.id.recyclerView);
        rcv.setAdapter(adapter);
        rcv.setLayoutManager(new LinearLayoutManager(this));

        adapter.setOnClickListener(new CustomAdapter.OnItemClickListener() {
            @Override
            public void onItemClick(View item, int position) {
                String str = items.get(position).textJp;
                Toast.makeText(getBaseContext(), str, Toast.LENGTH_SHORT).show();
            }
        });
    }
}

colors.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="colorPrimary">#008577</color>
    <color name="colorPrimaryDark">#00574B</color>
    <color name="colorAccent">#D81B60</color>

    <color name="item_active">#ffffc5</color>
    <color name="item_normal">#ffffff</color>
</resources>

item_state.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:exitFadeDuration="500">

    <item
        android:drawable="@color/item_active"
        android:state_pressed="true" />

    <item android:drawable="@color/item_normal" />
</selector>

custom_layout.xml

<GridLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginBottom="3dp"
    android:background="@drawable/item_state"
    android:orientation="horizontal"
    android:padding="5dp">

    <ImageView
        android:id="@+id/imageView"
        android:layout_gravity="center_vertical"
        android:src="@drawable/ic_1" />

    <TextView
        android:id="@+id/textView_jp"
        android:layout_columnWeight="1"
        android:layout_gravity="center_vertical"
        android:layout_marginLeft="10dp"
        android:text="Seiri"
        android:textColor="#007"
        android:textSize="20sp" />

    <TextView
        android:id="@+id/textView_th"
        android:layout_gravity="center_vertical"
        android:layout_marginRight="10dp"
        android:text="สะสาง"
        android:textColor="#aaa"
        android:textSize="18sp" />

</GridLayout>

CustomItem.java

package com.phaisarn.myapplication;

public class CustomItem {
    public int imgId;
    public String textJp;
    public String textTh;

    public CustomItem(int imgId, String textJp, String textTh) {
        this.imgId = imgId;
        this.textJp = textJp;
        this.textTh = textTh;
    }
}

CustomHolder.java

package com.phaisarn.myapplication;

import android.view.View;
import android.widget.ImageView;
import android.widget.TextView;

import androidx.recyclerview.widget.RecyclerView;

public class CustomHolder extends RecyclerView.ViewHolder {
    public ImageView imageView;
    public TextView textViewJp;
    public TextView textViewTh;

    public CustomHolder(View convertView) {
        super(convertView);
        imageView = convertView.findViewById(R.id.imageView);
        textViewJp = convertView.findViewById(R.id.textView_jp);
        textViewTh = convertView.findViewById(R.id.textView_th);
    }
}

CustomAdapter.java

package com.phaisarn.myapplication;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import androidx.recyclerview.widget.RecyclerView;

import java.util.List;

public class CustomAdapter extends RecyclerView.Adapter<CustomHolder> {
    private Context mContext;
    private List<CustomItem> mItems;

    public CustomAdapter(Context context, List<CustomItem> items) {  //กำหนดเป็น ArrayList เหมือนเดิมก็ได้
        mContext = context;
        mItems = items;
    }

    public interface OnItemClickListener {
        void onItemClick(View item, int position);
    }

    private OnItemClickListener mListener;

    public void setOnClickListener(OnItemClickListener listener) {
        mListener = listener;
    }

    @Override
    public int getItemCount() {
        return mItems.size();
    }

    @Override
    public CustomHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        LayoutInflater inflater = LayoutInflater.from(mContext);
        final View view = inflater.inflate(R.layout.custom_layout, parent, false);
        final CustomHolder vHolder = new CustomHolder(view);

            /*
            view.setOnClickListener(new View.OnClickListener() {
                  @Override
                  public void onClick(View view) {
                        int pos = vHolder.getAdapterPosition();
                        String str = vHolder.textViewJp.getText().toString();
                        str += "  :  " + vHolder.textViewTh.getText().toString();
                        if(pos != RecyclerView.NO_POSITION) {
                              Toast.makeText(mContext, str, Toast.LENGTH_SHORT).show();
                        }
                  }
            });
            */

        view.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                if (mListener != null) {
                    int pos = vHolder.getAdapterPosition();
                    if (pos != RecyclerView.NO_POSITION) {
                        mListener.onItemClick(view, pos);
                    }
                }
            }
        });

        return vHolder;
    }

    @Override
    public void onBindViewHolder(CustomHolder vHolder, int position) {
        CustomItem item = mItems.get(position);
        vHolder.imageView.setImageResource(item.imgId);
        vHolder.textViewJp.setText(item.textJp);
        vHolder.textViewTh.setText(item.textTh);
    }
}

รูปที่ใช้

Link