리사이클뷰를 위한 사전작업
1.DB 테이블에 데이터가 있어야함.
2.하나의 행을 보여줄 XML을 작성 / 리사이클뷰를 보여줄 XML을 작성
리사이클뷰 원리
1.DB에서 가져온 하나의 행 정보를 기반으로 만든 XML을
2.어댑터클래스를 만들어 증식시킨다?(여러개로 만든다는것)
3.그리고 Activity에서 리사이클뷰로 보여주는 코드를 작성.
# 이것을 응용하면 사진앨범 같이 다차원의 배치도 가능함
adapter 코드
package com.leopard4.contactapp.adapter;
// 1. RecyclerView.Adapter 를 상속받는다.
// 2. 상속받은 클래스가 abstract 이므로, unimplemented method 오버라이드!
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
import com.leopard4.contactapp.R;
import com.leopard4.contactapp.model.Contact;
import java.util.List;
// 6. RecyclerView.Adapter 의 데이터 타입(<ContactAdapter.viewHolder>)을 적어주어야 한다.
//    우리가 만든 ViewHolder 로 적는다.
// 7. 빨간색 에러가 뜨면, 우리가만든 ViewHolder 로,
//    onCreateViewHolder, onBindViewHolder 함수도 변경해준다.
public class ContactAdapter extends RecyclerView.Adapter<ContactAdapter.viewHolder> {
    // 5. 어댑터 클래스의 멤버변수와 생성자를 만들어 준다.
    Context context;
    List<Contact> contactList;
    public ContactAdapter(Context context, List<Contact> contactList) {
        this.context = context;
        this.contactList = contactList;
    }
    // 8. 오버라이드 함수 3개를 전부 구현해 주면 끝!
    @NonNull
    @Override
    public ContactAdapter.viewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        // xml 파일을 연결하는 작업
        // 재사용 가능한 코드이므로 리턴클래스명, 파일명만 바꿔주자. (contact_row)
        View view = LayoutInflater.from(parent.getContext())
                .inflate(R.layout.contact_row, parent, false);
        return new ContactAdapter.viewHolder(view);
    }
    @Override
    public void onBindViewHolder(@NonNull ContactAdapter.viewHolder holder, int position) {
        // 뷰에 데이터를 셋팅한다!
        // 파라미터 holder = 행 하나하나를 의미한다. position = 몇번째 행인지를 의미한다.
        Contact contact = contactList.get(position);
        holder.txtName.setText( contact.name );
        holder.txtPhone.setText( contact.phone );
    }
    @Override
    public int getItemCount() {
        // 전체 데이터의 갯수를 적어준다.
        return contactList.size();
    }
    // 3. ViewHolder 클래스를 만든다.
    //    이 클래스는 row.xml 화면에 있는 뷰를 연결시키는 클래스다.
    //    ViewHolder 클래스는 RecyclerView.ViewHolder 를 상속받는다.
    public class viewHolder extends RecyclerView.ViewHolder {
        TextView txtName, txtPhone;
        ImageView imgDelete;
       
        // 4. 생성자를 만든다.
   	    //    생성자에서, 뷰를 연결시키는 코드를 작성하고,
        //    클릭 이벤트도 작성한다.
        public viewHolder(@NonNull View itemView) {
            super(itemView);
            txtName = itemView.findViewById(R.id.txtName);
            txtPhone = itemView.findViewById(R.id.txtPhone);
            imgDelete = itemView.findViewById(R.id.imgDelete);
        }
    }
}main 코드
package com.leopard4.contactapp;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import com.leopard4.contactapp.adapter.ContactAdapter;
import com.leopard4.contactapp.data.DatabaseHandler;
import com.leopard4.contactapp.model.Contact;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity {
    Button btnAdd;
    // 리사이클러뷰를 사용할때!
    // RecyclerView, Adapter, ArrayList(실제데이터) 를 셋트로 적어라!
    RecyclerView recyclerView;
    ContactAdapter adapter;
    ArrayList<Contact> contactList;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btnAdd = findViewById(R.id.btnAdd);
        // 리사이클러뷰를 화면에 연결하고,
        // 쌍으로 같이 다니는 코드도 작성
        recyclerView = findViewById(R.id.recyclerView);
        recyclerView.setHasFixedSize(true);
        recyclerView.setLayoutManager(new LinearLayoutManager(this));
        btnAdd.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(MainActivity.this, AddActivity.class);
                startActivity(intent);
            }
        });
        // DB에서 데이터를 가져와서, 리사이클러뷰에 뿌려준다.
        DatabaseHandler db = new DatabaseHandler(MainActivity.this);
        contactList = db.getAllContacts();
        db.close();
        // 어댑터를 생성하고,
        adapter = new ContactAdapter(MainActivity.this, contactList);
        // 리사이클러뷰에 셋팅
        recyclerView.setAdapter(adapter);
    }
} 
                    
                   
                    
                  