반응형
[ 2020 안드로이드 스튜디오 ] 스피너 (spinner) 사용 예제
Android Studio Version 3.6.3
사용언어 JAVA
스피너를 사용하면 선택하기 전 View1과 선택하는 중 View2가 있습니다.
하지만 SDK에서 미리 만들어 제공하는 레이아웃을 사용하면 간단히 몇 줄의 코드만으로 스피너를 만들 수 있습니다.
STEP 1 xml 구성하기
- 스피너<Sppiner> 태그를 이용해 XML 레이아웃에 추가하고 어댑터 객체를 만들어 설정합니다.
- 스피너에 들어가는 각 아이템은 텍스트만 보여주는 경우가 많아서 안드로이드 SDK에서 미리 제공하는 XML레이아웃을 그대로 사용할 수 있습니다.
- ArraryAdapter는 아이템을 위한 여러 개의 데이터를 담아두기 위해 미리 만들어졌습니다.
- 스피너는 항목을 선택하기 위한 창이 별도로 있기 때문에 setDropDownViewResource 메소드를 이용해 별도 창에 보이는 각 아이템을 위한 레이아웃을 별도로 설정합니다.
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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"
tools:context=".MainActivity">
<Spinner
android:id="@+id/spinner"
android:layout_width="258dp"
android:layout_height="27dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="선택"
android:textSize="32sp"
app:layout_constraintBottom_toTopOf="@id/spinner"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
STEP 2 메인 액티비티 코드 작성하기
package com.example.myspinner;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Spinner;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
TextView textView;
//데이터를 배열에 넣어서 준비
String[] items = {"fish", "turtle", "seal"};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Spinner spinner = findViewById(R.id.spinner);
textView = findViewById(R.id.textView);
ArrayAdapter<String> adapter = new ArrayAdapter<String>(
//API에 만들어져 있는 R.layout.simple_spinner...를 씀
this,android.R.layout.simple_spinner_item, items
);
//미리 정의된 레이아웃 사용
adapter.setDropDownViewResource(android.R.layout.simple_spinner_item);
// 스피너 객체에다가 어댑터를 넣어줌
spinner.setAdapter(adapter);
spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
// 선택되면
@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
textView.setText(items[position]);
}
// 아무것도 선택되지 않은 상태일 때
@Override
public void onNothingSelected(AdapterView<?> parent) {
textView.setText("선택: ");
}
});
}
}
반응형
'컴퓨터 공학 > Android' 카테고리의 다른 글
네이버 부스트코스 안드로이드 프로그래밍 프로젝트3) 1화면전환~3수명주기 개념 연습문제 (420) | 2020.05.28 |
---|---|
[ 안드로이드 ] 자바 소스로 커스텀 버튼 만들기 (387) | 2020.05.22 |
[2020 안드로이드 스튜디오] 리스트뷰(ListView), 어댑터(Adapter) 이해 &기본예제 (394) | 2020.05.16 |
[2020 안드로이드 스튜디오] Drawable 드로어블 배경 효과 총정리 (410) | 2020.04.23 |
[2020 안드로이드 스튜디오] Drawable 드로어블 애니메이션 그라데이션 (422) | 2020.04.22 |
댓글