-
[RecyclerView] 안드로이드 리사이클러뷰 Header/Footer 달기Android/개발 2018. 11. 15. 21:16
안드로이드 RecyclerView 접기/펼치기 (Expandable RecyclerView)
RecyclerView(리사이클러뷰)의 Adapter는 getItemViewType이라는 메소드를 제공해 Header, Footer, Item을 구별할 수 있습니다. RecyclerView에서 Header와 Footer를 구현하기 위해서는 Adapter의 override 메소드인 getItemViewType, onCreateViewHolder, onBindViewHolder, getItemCount에서 각각의 뷰를 구분하고 구현해줘야 합니다.
그럼 이제부터 RecyclerView의 Header와 Footer를 구현하는 방법을 알아보도록 하겠습니다.
이 예제는 리사이클러뷰 접기/펼치기 예제를 베이스로 진행됩니다.
아직 리사이클러뷰 사용방법을 잘 모르신다면 리사이클러뷰 기본사용법 예제를 먼저 보시면 도움이 되실 것 같습니다^^
1. Header Layout, Footer Layout 구현
우선 Header와 Footer에 들어갈 layout을 만들어야합니다.
header.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:padding="16dp"
android:background="@color/colorPrimaryDark"
android:text="THIS IS HEADER"
android:textSize="16sp"
android:textColor="@color/colorPrimary"
android:textStyle="bold"/>
</LinearLayout>footer.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:padding="16dp"
android:background="@color/colorPrimaryDark"
android:text="THIS IS FOOTER"
android:textSize="16sp"
android:textColor="@color/colorPrimary"
android:textStyle="bold"/>
</LinearLayout>
2. Adapter의 Object를 ViewHolder로 수정
public class RecyclerAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {
public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {
- 이전 예제에서 ItemViewHolder만 사용했는데 이번 예제에선 HeaderViewHolder, FooterViewHolder도 같이 사용해야 하기 때문에 공통 부모 클래스인 ViewHolder로 수정합니다.
3. View Type 정의
private final int TYPE_HEADER = 0;
private final int TYPE_ITEM = 1;
private final int TYPE_FOOTER = 2;- View Type을 int 형식으로 정의합니다.
4. HeaderViewHolder, FooterViewHolder 클래스 정의
HeaderViewHolder
class HeaderViewHolder extends RecyclerView.ViewHolder {
HeaderViewHolder(View headerView) {
super(headerView);
}
}FooterViewHolder
class FooterViewHolder extends RecyclerView.ViewHolder {
FooterViewHolder(View footerView) {
super(footerView);
}
}- 이번 예제에서는 Header와 Footer에서 아무런 동작도 수행하지 않기때문에 생성자만 만들어줍니다.
5. getItemViewType() 메소드 정의
@Override
public int getItemViewType(int position) {
if (position == 0)
return TYPE_HEADER;
else if (position == listData.size() + 1)
return TYPE_FOOTER;
else
return TYPE_ITEM;
}- 이 메소드는 override 메소드로 position별로 item의 View Type을 정의합니다.
6. onCreateViewHolder() 메소드 수정
@NonNull
@Override
public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
context = parent.getContext();
RecyclerView.ViewHolder holder;
View view;
if (viewType == TYPE_HEADER) {
view = LayoutInflater.from(parent.getContext()).inflate(R.layout.header, parent, false);
holder = new HeaderViewHolder(view);
} else if (viewType == TYPE_FOOTER) {
view = LayoutInflater.from(parent.getContext()).inflate(R.layout.footer, parent, false);
holder = new FooterViewHolder(view);
} else {
view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item, parent, false);
holder = new ItemViewHolder(view);
}
return holder;
}- 2번째 인자로 넘어온 viewType은 4번의 getItemViewType에서 return된 viewType 입니다.
- viewType에 따라 사용할 ViewHolder를 return 합니다.
7. onBindViewHolder() 메소드 수정
@Override
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {
if (holder instanceof HeaderViewHolder) {
HeaderViewHolder headerViewHolder = (HeaderViewHolder) holder;
} else if (holder instanceof FooterViewHolder) {
FooterViewHolder footerViewHolder = (FooterViewHolder) holder;
} else {
// Item을 하나, 하나 보여주는(bind 되는) 함수입니다.
ItemViewHolder itemViewHolder = (ItemViewHolder) holder;
itemViewHolder.onBind(listData.get(position - 1), position);
}
}- onBindViewHolder에서 holder의 종류에 따라 수행 할 동작을 구현합니다.
- 이 예제에서는 Header와 Footer에서 아무런 동작도 하지 않고 ItemViewHolder에서만 동작을 수행합니다.
8. getItemCount() 메소드 수정
@Override
public int getItemCount() {
return listData.size() + 2;
}- ItemView에 들어갈 list의 개수와 Header, Footer 각각 1개씩을 추가해 +2를 해줍니다.
여기까지하면 간단한 Header와 Footer가 만들어집니다.
결과
Header
Footer
처음 만들땐 좀 복잡하다고 생각할 수 있지만 많이 하다보면 원리는 간단하고 생각보다 간편합니다^^ 그럼 모두 열심히 공부하시고 안드로이드 고수가 되봅시다!
궁금하신점은 댓글로 남겨주시면 답변드리겠습니다^^
안드로이드 RecyclerView 아이템 클릭 예제 보러가기
안드로이드 RecyclerView 접기/펴기 예제 보러가기
안드로이드 RecyclerView를 이용한 프로젝트 구경하기
'Android > 개발' 카테고리의 다른 글
[DataBinding] 안드로이드 DataBinding 기본 사용법 - 기본 예제 (1) 2020.01.29 [Kotlin] Kotlin vs. Java - 코틀린, 자바 차이점 비교 (1) 2020.01.27 [RecyclerView] 안드로이드 리사이클러뷰 접기/펼치기 (22) 2018.11.14 [RecyclerView] 안드로이드 리사이클러뷰 아이템 클릭 (13) 2018.11.13 [RecyclerView] 안드로이드 리사이클러뷰 기본 사용법 (12) 2018.11.13 댓글