Android 에서 Spinner 를 사용 하여 드 롭 다운 목록 기능 구현

Spinner
Spinner 는 목록 선택 상자 로 사용자 가 선택 한 후에 목록 을 보 여 줍 니 다.Spinner 는 View Group 의 간접 하위 클래스 로 다른 Android 컨트롤 과 마찬가지 로 데 이 터 는 Adapter 를 사용 하여 패키지 해 야 합 니 다.
1,데모 전시 사진
这里写图片描述
2,레이아웃 코드

//(layout)activity_main
<LinearLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:id="@+id/activity_main"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context="com.test.spinner.MainActivity">
 <LinearLayout
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:orientation="horizontal">
  <TextView
   android:textSize="20sp"
   android:layout_margin="10dp"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:text="      MVP:"/>
  <TextView
   android:id="@+id/text"
   android:textSize="20sp"
   android:layout_marginTop="10dp"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"/>
 </LinearLayout>
 <Spinner
  android:visibility="gone"
  android:id="@+id/spinner"
  android:layout_marginLeft="10dp"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content">
 </Spinner>
</LinearLayout>
-------------------------------------------------------------------
//(layout)item
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:gravity="center_vertical">
 <ImageView
  android:id="@+id/imageView"
  android:layout_width="80dp"
  android:layout_height="80dp"/>
 <TextView
  android:id="@+id/textView"
  android:layout_marginLeft="20dp"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"/>
</LinearLayout>
3,Activity 코드

//MainActivity
import android.content.Context;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.SimpleAdapter;
import android.widget.Spinner;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import static com.test.spinner.R.id.simpleAdapter;
public class MainActivity extends AppCompatActivity {
 private Context mContext = MainActivity.this;
 private Spinner mSpinner;
 private ArrayAdapter<String> mArrayAdapter;
 private TextView mTextView;
 private SimpleAdapter mSimpleAdapter;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
  initData();
 }
 private void initView(){
  mSpinner = (Spinner) findViewById(R.id.spinner);
  mTextView = (TextView) findViewById(R.id.text);
 }
 private void initData(){
  //      
  List<String> list = new ArrayList<>();
  list.add("  ");
  list.add("    ");
  list.add("   ");
  list.add("     ");
  List<Map<String ,Object>> maps = new ArrayList<>();
  int[] icon = {R.mipmap.pic1 , R.mipmap.pic2, R.mipmap.pic3, R.mipmap.pic4};
  String[] iconName = {"  " , "    " , "   " , "     "};
  //      
  mArrayAdapter = new ArrayAdapter<>(mContext ,
    android.R.layout.simple_spinner_item , list);
  mArrayAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
  mSimpleAdapter = new SimpleAdapter(mContext,
    maps , R.layout.item , new String[]{"image" , "text"} , new int[]{R.id.imageView ,R.id.textView});
  for(int i = 0 ; i < icon.length ; i++){
   Map<String ,Object> map = new HashMap<>();
   map.put("image", icon[i]);
   map.put("text" , iconName[i]);
   maps.add(map);
  }
 }
 @Override
 public boolean onCreateOptionsMenu(Menu menu) {
  getMenuInflater().inflate(R.menu.main , menu);
  return true;
 }
 @Override
 public boolean onOptionsItemSelected(MenuItem item) {
  switch (item.getItemId()){
   case R.id.arrayAdapter:
    mSpinner.setVisibility(View.VISIBLE);
    mSpinner.setAdapter(mArrayAdapter);
    //      
    mSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
     @Override
     public void onItemSelected(AdapterView<?> adapterView, View view, int position, long id) {
      mTextView.setText(mArrayAdapter.getItem(position));
     }
     @Override
     public void onNothingSelected(AdapterView<?> adapterView) {
     }
    });
    break;
   case simpleAdapter:
    mSpinner.setVisibility(View.VISIBLE);
    mSpinner.setAdapter(mSimpleAdapter);
    //      
    mSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
     @Override
     public void onItemSelected(AdapterView<?> adapterView, View view, int position, long id) {
      mTextView.setText(mSimpleAdapter.getItem(position)+"");
     }
     @Override
     public void onNothingSelected(AdapterView<?> adapterView) {
     }
    });
    break;
   default:
    break;
  }
  return super.onOptionsItemSelected(item);
 }
}
위 에서 말 한 것 은 편집장 이 소개 한 안 드 로 이 드 에서 Spinner 를 사용 하여 드 롭 다운 목록 기능 을 실현 하 는 것 입 니 다.여러분 에 게 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 면 메 시 지 를 남 겨 주세요.편집장 은 신속하게 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!

좋은 웹페이지 즐겨찾기