스피너 사용하기 (셀렉트박스 selectbox, 풀다운 메뉴)

프로그래밍/Android (Java)|2019. 4. 23. 11:03
반응형

스피너를 사용하며, 보여지는 제목 및 터치시 출력되는 세부 아이템에 줄간격, 폰트 사이즈, 라인 효과를 주는 방법입니다.

 

 

1. activity_main.xml

 

<Spinner
                android:id="@+id/spinner"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="45"
                android:textSize="14sp"
                android:layout_centerHorizontal="true"/>

 

 

2. MainActivity.java

 

public class Fragment2 extends Fragment {

 

    private Spinner spinner;
    ArrayList arrayList;
    ArrayAdapter arrayAdapter;

 

 

@Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

 

 

        arrayList = new ArrayList<>();
        arrayList.add("네이버");
        arrayList.add("다음");

        arrayAdapter = new ArrayAdapter(getActivity().getApplicationContext(), android.R.layout.simple_spinner_dropdown_item, arrayList) {

               // 누르기 전 보여지는 기본 폰트 스타일
            @Override
            public View getView(int position, View convertView, ViewGroup parent) {
                View view = super.getView(position, convertView, parent);
                TextView tv = (TextView) view;
                tv.setTextSize(14);
                return view;
            }

               // 누른 뒤 출력되는 리스트 폰트 스타일
            @Override
            public View getDropDownView(int position, View convertView, ViewGroup parent) {
                View view = super.getDropDownView(position, convertView, parent);
                TextView tv = (TextView) view;
                if(position == 0) {
                    tv.setTextColor(Color.GRAY); // 포지션 0 에 제목을 넣었으므로 흐리게 표현한다.
                    tv.setTextSize(14);
                }
                else {
                    tv.setTextColor(Color.BLACK);
                    tv.setTextSize(14);
                    tv.setBackground(ContextCompat.getDrawable(getActivity(), R.drawable.textlines)); // 아이템 상단에만 라인 생기도록 하였음 (첫번재 아이템 제외)
                }
                return view;
            }

        };

        arrayAdapter.setDropDownViewResource(R.layout.spinner_item); // 스피너 디자인 (폰트크기, 사이즈, 줄간격 등) 을 바꾸기 위해 별도 xml 파일 만듬

        spinner = (Spinner) view.findViewById(R.id.spinner);
        spinner.setAdapter(arrayAdapter);
        spinner.setSelection(choice_spinner, false); // 처음 페이지를 열었을때는 동작하지 않도록 설정 (false 부분) // choice_spinner 는 int
        spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {

            // 아이템을 선택한 경우 이벤트
            @Override
            public void onItemSelected(AdapterView<?> adapterView, View view, int i, long l) {
                  Toast.makeText(getActivity().getApplicationContext(), i + "선택", Toast.LENGTH_SHORT).show();
            }

            // 리스트만 열어보고 아이템을 선택하지 않은 경우
            @Override
             public void onNothingSelected(AdapterView<?> adapterView) {
            }

        });


        return view;
    }

 

 

3. textlines.xml (drawable 디렉토리)

 

<?xml version="1.0" encoding="utf-8"?>

<layer-list
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:android="http://schemas.android.com/aapt">

    <item
        android:bottom="-2dp"
        android:left="-2dp"
        android:right="-2dp"
        android:top="1px">


          <shape android:shape="rectangle">
            <stroke
                android:width="1dp"
                android:color="#EAEAEA" />

               <solid android:color="#FFFFFF" />

         </shape>

 

    </item>

</layer-list>

 

 

4. spinner_item.xml (drawable 디렉토리)

 

<?xml version="1.0" encoding="utf-8"?>

<TextView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textSize="14sp"
    android:padding="10dp"/>



        
    

반응형

댓글()