반응형
모바일 단말에서 가장 많이 사용되는 UI 모양 중의 하나가 리스트이다
안드로이드에서는 여러 개의 아이템 중에 하나를 선택할 수 있는 리스트 모양의 위젯을 특별히 선택 위젯이라고 부른다
선택 위젯을 일반 위젯과 구분하는 이유는 선택 위젯이 어댑터 패턴을 사용하기 때문이다
선택 위젯에 데이터를 넣을 때 위젯이 아닌 어댑터에 설정해야 하며 화면에 보이는 뷰도 어댑터에서 만든다
즉, 리스트 모양의 뷰에 보이는 각각의 아이템은 뷰가 아닌 어댑터에서 관리한다
리스트 모양으로 보여줄 수 있는 위젯인 리사이클러뷰는 상하 스크롤뿐만 아니라 좌우 스크롤도 가능하며, 각각의 아이템이 화면에 보일 때 메모리를 효율적으로 사용하도록 캐시 메커니즘이 구현되어 있다
person_item.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<androidx.cardview.widget.CardView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:cardBackgroundColor="#FFFFFFFF"
app:cardCornerRadius="10dp"
app:cardElevation="5dp"
app:cardUseCompatPadding="true" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<ImageView
android:id="@+id/imageView"
android:layout_width="80dp"
android:layout_height="80dp"
android:padding="5dp"
app:srcCompat="@mipmap/ic_launcher" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_margin="5dp"
android:layout_weight="1"
android:orientation="vertical">
<TextView
android:id="@+id/textView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="이름"
android:textSize="30sp" />
<TextView
android:id="@+id/textView2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="전화번호"
android:textColor="#FF0000FF"
android:textSize="25sp" />
</LinearLayout>
</LinearLayout>
</androidx.cardview.widget.CardView>
</LinearLayout>
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
Person.java
package com.example.a44_recyclerview;
public class Person {
String name;
String mobile;
public Person(String name, String mobile) {
this.name = name;
this.mobile = mobile;
}
public String getName() {
return name;
}
public String getMobile() {
return mobile;
}
public void setName(String name) {
this.name = name;
}
public void setMobile(String mobile) {
this.mobile = mobile;
}
}
PersonAdapter.java
package com.example.a44_recyclerview;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import androidx.recyclerview.widget.RecyclerView;
import java.util.ArrayList;
public class PersonAdapter extends RecyclerView.Adapter<PersonAdapter.ViewHolder> {
ArrayList<Person> items = new ArrayList<Person>();
// 뷰홀더를 새로 만들어야할 때마다 이 메소드를 호출
// 뷰홀더와 그에 연결된 뷰를 생성하고 초기화하지만 뷰의 컨텐츠를 채우지 않음
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
LayoutInflater inflater = LayoutInflater.from(parent.getContext());
View itemView = inflater.inflate(R.layout.person_item, parent, false);
return new ViewHolder(itemView);
}
// 데이터와 연결할 때 이 메소드를 호출
@Override
public void onBindViewHolder(PersonAdapter.ViewHolder holder, int position) {
Person item = items.get(position);
holder.setItem(item);
}
// 어댑터에서 관리하는 아이템의 개수를 반환
@Override
public int getItemCount() {
return items.size();
}
public void addItem(Person item) {
items.add(item);
}
public Person getItem(int position) {
return items.get(position);
}
public void setItems(ArrayList<Person> items) {
this.items = items;
}
public void setItem(int position, Person item) {
items.set(position, item);
}
static class ViewHolder extends RecyclerView.ViewHolder {
TextView textView;
TextView textView2;
// 뷰홀더 생성자로 전달되는 뷰 객체 참조
public ViewHolder(View itemView) {
super(itemView);
textView = itemView.findViewById(R.id.textView);
textView2 = itemView.findViewById(R.id.textView2);
}
public void setItem(Person item) {
textView.setText(item.getName());
textView2.setText(item.getMobile());
}
}
}
MainActivity
package com.example.a44_recyclerview;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import android.os.Bundle;
import android.widget.LinearLayout;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
RecyclerView recyclerView = findViewById(R.id.recyclerView);
// 리사이클러뷰가 보일 기본적인 형태를 설정
// 자주 사용하는 형태는 세로 방향, 가로 방향, 격자 모양
// 리스트 모양으로 표시할 때는 세로 방향 스크롤을 사용하는데, LinearLayoutManager 객체를 사용하면서 방향을 VERTICAL로 설정했기 때문에 세로로 보이게 됨
// 가로로 하려면 HORIZONTAL, 격자 모양으로 하려면 GridLayoutManager 객체를 사용하면서 칼럼의 수 지정하면 됨
LinearLayoutManager layoutManager = new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false);
recyclerView.setLayoutManager(layoutManager);
PersonAdapter adapter = new PersonAdapter();
adapter.addItem(new Person("김민수", "010-1000-1000"));
adapter.addItem(new Person("김하늘", "010-2000-2000"));
adapter.addItem(new Person("홍길동", "010-3000-3000"));
recyclerView.setAdapter(adapter);
}
}
반응형
'안드로이드' 카테고리의 다른 글
스피너 (0) | 2021.10.26 |
---|---|
리사이클러뷰에 리스너 설정 (0) | 2021.10.26 |
새로운 레이아웃 만들기, 카드뷰 넣기 (0) | 2021.10.26 |
새로운 뷰 만들기 (0) | 2021.10.26 |
나인 패치 (0) | 2021.10.26 |