Study/Android

Custom ListView

Kostrian 2015. 1. 29. 11:03

Custum ListView를 구현하기 위해서는 Adaptor의 구현이 필요하다.


listview_item.xml이라는 레이아웃을 만들어서 원하는 모양으로 보이게 만든다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<LinearLayout
...
    <ImageView
    ...
    />
 
    <LinearLayout
    ...
        <TextView
        .../>
 
        <TextView
        .../>
    </LinearLayout>
</LinearLayout>

이런식으로 xml을 만든다음 MainActivity클래스 안에 이너 클래스로 어뎁터와 그외 필요한 클래스를 생성한다.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
    // 아이템 정보를 담고 있을 데이터셋
    public class ListData {
        public String name;
        public String phone;
        public String imagePath;
    
        public ListData(String imagePath, String text1, String text2) {
            this.name = text1;
            this.phone = text2;
            this.imagePath = imagePath;
        }
    }
 
    // 위젯정보를 담고 있을 홀더    
    private class ViewHolder {
        public ImageView itemImage;
        public TextView name;
        public TextView phone;
    }
 
 
    private class Adapter extends BaseAdapter {
        // 리스트뷰에 들어갈 데이터를 담기 위한 어레이 리스트
        ArrayList<ListData> dataList = new ArrayList<ListData>();
        Context context;
 
        public Adapter(Context context) { this.context = context; }
 
        @Override
        public int getCount() { return dataList.size(); }
 
        @Override
        public Object getItem(int position) { return dataList.get(position); }
 
        @Override
        public long getItemId(int position) { return position; }
 
        // 리스트뷰에 데이터를 추가해주는 메서드
        public void addItem(String imagePath, String text1, String text2) {
            ListData listData= new ListData(imagePath, text1, text2);
            dataList.add(listData);
        }
 
        // 리스트뷰에서 데이터를 삭제해주는 메서드
        public void remove(int position) {
            dataList.remove(position);
            notifyDataSetChanged
        }
 
        // 이 메서드에서 리스트뷰에 listview_item.xml의 레이아웃을 붙여주는 작업을 한다.
        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            final ViewHolder viewHolder;
            // view의 재사용을 위한 작업
            if ( convertView == null ) {
                viewHolder = new ViewHolder();
                
                // 레이아웃을 가져오기 위한 도구(?)
                LayoutInflater layoutInflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                // 레이아웃을 가져옴
                convertView = layoutInflater.inflate(R.layout.listview_item, null);
                // 가져온 레이아웃에 위젯을 붙임
                viewHolder.itemImage = (ImageView)convertView.findViewById(R.id.itemImage);
                viewHolder.name = (TextView)convertView.findViewById(R.id.name);
                viewHolder.phone = (TextView)convertView.findViewById(R.id.phone);
 
                convertView.setTag(viewHolder);
            }
            else {
                viewHolder = (ViewHolder)convertView.getTag();
            }
            // 작업해줄 위치에 있는 데이터를 가져옴
            ListData listData = dataList.get(position);
 
            // 이미지 뷰에 붙여줄 이미지를 내부 저장소에서 가져와서 비트맵 객체로 만들어줌
            Bitmap bitmap = BitmapFactory.decodeFile(listData.imagePath);
 
            // 비트맵 생성에 성공하면 이미지뷰에 붙여줌
            if ( bitmap != null ) {
                viewHolder.itemImage.setVisibility(View.VISIBLE);
                viewHolder.itemImage.setImageBitmap(bitmap);
            }
            // 해당 경로에 이미지가 없어 비트맵 생성에 실패하면 기본이미지를 붙여줌
            else {
                Bitmap nullBit = BitmapFactory.decodeResource(getResources(), R.drawable.null_image);
                viewHolder.itemImage.setVisibility(View.VISIBLE);
                viewHolder.itemImage.setImageBitmap(nullBit);
            }
            // 데이터에 있는 텍스트들을 위젯에 붙여줌
            viewHolder.name.setText(listData.name);
            viewHolder.phone.setText(listData.phone);
            
            return convertView;
        }
    }


다음 onCreate에서 리스트뷰를 불러와 위에서 만든 어뎁터를 붙여주면 된다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
public class MainActivity extends Activity {
    private ListView listView;
    private Adapter adapter;
    
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        listView = (ListView)findViewById(R.id.listView);
        // 어뎁터를 생성한다.
        adapter = new Adapter(this);
        // 생성한 어뎁터를 리스트뷰에 달아준다.
        listView.setAdapter(adapter);
        
        // 리스트뷰에 데이터 추가
        adapter.add("null","AAA","AAAAAA");
        adapter.add("null","BBB","BBBBBB");
        adapter.add("null","CCC","CCCCCC");
    }
    
}


'Study > Android' 카테고리의 다른 글

MYSQL에서 안드로이드로 데이터 가져오기  (0) 2015.01.29
CheckBox & 갤러리 사진 선택  (0) 2015.01.29
Intent & SQLite  (0) 2015.01.29
Simple ListView  (0) 2015.01.29
onCreate & Event  (0) 2015.01.29