반응형
예제 소스
이번에는 다음과 같이 이미지와 텍스트를 동시에 뿌려주는 커스텀 리스트뷰를 만들어봅시다.
실행화면
각 리스트 터치시 값들이 토스트 메시지로 출력됩니다.
(토스트 메시지가 너무 빨리 지나가서 캡쳐를 못하겠네요.)
image_layout.xml
이미지뷰 한개와 텍스트뷰 한개를 배치합니다.
이 레이아웃이 리스트뷰의 내용이 될 것입니다.
<?xml version="1.0" encoding="utf-8"?>
android:orientation="horizontal" android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/imageView"
android:layout_width="100dp"
android:layout_height="100dp"
android:layout_margin="10dp"
android:layout_weight="1"
app:srcCompat="@mipmap/heart" />
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TextView"
android:textAppearance="@style/TextAppearance.AppCompat.Display2" />
</LinearLayout>
ImageAdapter.java
리스트뷰의 어댑터를 만드는 클래스입니다.
package com.example.kch.tutorial5_list;
import android.content.Context;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;
/**
* Created by kch on 2017. 9. 23..
*/
public class ImageAdapter extends ArrayAdapter<String>{
ImageAdapter(Context context, String [] items){
super(context, R.layout.image_layout, items);
}
@NonNull
@Override
public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
LayoutInflater imageInflater = LayoutInflater.from(getContext());
//image_layout.xml을 View객체에 저장함
View view = imageInflater.inflate(R.layout.image_layout, parent, false);
//리스트뷰의 갯수대로 실행하게 되는데 생성자를 이용해서 만들었으므로 각각 position에 맞는 데이터를 일단 item에 저장함
String item = getItem(position);
TextView textView = (TextView)view.findViewById(R.id.textView);
ImageView imageView = (ImageView)view.findViewById(R.id.imageView);
//TextView에 설정 해주는 부분
textView.setText(item);//가져온 item을 텍스트뷰에 뿌려줌
imageView.setImageResource(R.mipmap.heart);//리소스에 저장해둔 이미지도 뿌려줌
return view;//뷰를 반환함
}
}
activity_main.xml
리스트뷰를 선언해주고 각종 속성들을 설정해줍니다.
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.kch.tutorial5_list.MainActivity">
<ListView
android:id="@+id/listview"
android:layout_width="368dp"
android:layout_height="495dp"
android:layout_marginBottom="8dp"
android:layout_marginLeft="8dp"
android:layout_marginRight="8dp"
android:layout_marginTop="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</android.support.constraint.ConstraintLayout>
MainActivity.java
실제 리스트뷰의 내용을 클릭했을때와 리스트뷰 내용들을 정의하고 보여줍니다.
package com.example.kch.tutorial5_list;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
String [] items = {"망고쥬스", "토마토쥬스", "포도쥬스"};
//리스트뷰의 내용을 만들기 위한 adapter를 만듬(Adapter패턴 사용)
ListAdapter adapter = new ImageAdapter(this, items);
ListView listView = (ListView)findViewById(R.id.listview);
listView.setAdapter(adapter);//만든 adapter를 리스트뷰에 설정해줌
//리스트뷰 리스너 설정
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int i, long id) {
// ItemClick/ItemSelect Code
String item = String.valueOf(parent.getItemAtPosition(i));//사용자가 터치한 아이템을 문자로 받아서 item객체에 저장함
Toast.makeText(MainActivity.this, item, Toast.LENGTH_SHORT).show();//터치한 아이템을 토스트메시지로 보여줌
}
});
}
}
'프로그래밍 > 안드로이드' 카테고리의 다른 글
안드로이드 - 8. 레이아웃(layout) (0) | 2017.10.06 |
---|---|
안드로이드 - 7. 이미지 버튼 만들기 (0) | 2017.10.03 |
안드로이드 - 6. 유튜브 재생하기 (2) | 2017.10.03 |
안드로이드 - 5. 인텐트를 이용한 화면 전환 (0) | 2017.09.29 |
안드로이드 - 3. 네비게이션 드로어(Navigation Drawer) 사용하기 (8) | 2017.09.23 |
안드로이드 - 2. AlertDialog 사용 예제 (0) | 2017.09.17 |
안드로이드 - 1. 간단한 계산기 만들기 (0) | 2017.09.17 |
안드로이드 - Node.js서버로 POST방식으로 데이터를 보내기 (1) | 2017.09.16 |