본문 바로가기
Android Studio

[Android Studio] 첫 안드로이드 앱 개발 시작해보기 - Spinner (12)

by jisayDeveloper 2023. 11. 10.
728x90
반응형
SMALL

부트스트랩의 드롭다운 기능이 안드로이드에서 spinner란 이름으로 사용할 수 있는데 구현해보겠습니다.

 

먼저 res 하위에 values 폴더에 드롭다운 항목으로 쓸 xml 파일을 만듭니다.

 

array.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string-array name="test">
        <item>심</item>
        <item>지</item>
        <item>석</item>
    </string-array>
</resources>

 

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MainActivity">

    <Spinner
            android:layout_width="150dp"
            android:layout_height="40dp"
            android:id="@+id/spinner"
            android:entries="@array/test">
    </Spinner>

    <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/tv_result"
            android:text="Spinner"/>
</LinearLayout>

spinner 메뉴에서 선택 내용을 TextView에 출력할겁니다.

 

MainActivity

package com.example.spinner;

import android.view.View;
import android.widget.AdapterView;
import android.widget.Spinner;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;

public class MainActivity extends AppCompatActivity {

    private Spinner spinner;
    private TextView tv_result;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        spinner = (Spinner) findViewById(R.id.spinner);
        tv_result = (TextView) findViewById(R.id.tv_result);

        spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
            @Override
            public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
                tv_result.setText(parent.getItemAtPosition(position).toString());
            }

            @Override
            public void onNothingSelected(AdapterView<?> parent) {

            }
        });
    }
}

spnner에 이벤트를 거는데 이때 평소에 하던 onClickListener가 아니라 setOnItemSelectedListener를 하면

선택할 때와 안 할때를 정의할 수 있습니다. setText를 통해 선택항목을 TextView에 출력합니다.

 

결과를 보겠습니다.

 

 

 

728x90
반응형
LIST