博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

自定义下拉菜单模式Spinner与setDropDownViewResource

Posted on 2011-04-16 15:45  thomas.lee  阅读(1644)  评论(0编辑  收藏  举报

4.8 自定义下拉菜单模式Spinner与setDropDownViewResource

范例说明

Spinner就是下拉菜单,也等于swing的combo box、html的<select>,由于手机画面有限,要在有限的范围选择项目,下拉菜单是唯一、也是较好的选择。

Android提供的Spinner Widget的下拉菜单已经非常好用了,样式也还适用。但本范例的示范重点在于自定义下拉菜单里的样式,其关键在于调用setDropDownViewResource方法,以XML的方式定义下拉菜单要显示的模样。本范例除了自定义下拉菜单,还用程序设计了一段动画,当User以触控的方式单击这个自定义的Spinner时,会以一段动画提示User。

运行结果(见图4-8)

 
图4-8  自定义Spinner的下拉菜单模式,请注意菜单具有圆角的效果
范例程序
  1. src/irdc.ex04_08/EX04_08.java

在new ArrayAdapter中,我们将会使用ArrayAdapter(Context context, int textViewResourceId, T[] objects)这个Constructor,textViewResourceId使用Android提供的ResourceID,objects为必须传递的字符串数组(String Array)。

Adapter的setDropDownViewResource可以设置下拉菜单的显示方式,将该xml定义在res/layout目录下面,可针对下拉菜单中的TextView进行设置,如同本程序里的R.layout.myspinner_ dropdown即为自定义的下拉菜单TextView样式。除了改变下拉菜单样式外,也对Spinner做了一点动态效果,单击Spinner时,晃动Spinner再出现下拉菜单(myAnimation)。

  1. /* import程序略 */  
  2.  
  3. public class EX04_08 extends Activity  
  4. {  
  5.   private static final String[] countriesStr =  
  6.   { "北京市", "上海市", "天津市", "重庆市" };  
  7.   private TextView myTextView;  
  8.   private Spinner mySpinner;  
  9.   private ArrayAdapter<String> adapter;  
  10.   Animation myAnimation;  
  11.  
  12.   /** Called when the activity is first created. */  
  13.   @Override  
  14.   public void onCreate(Bundle savedInstanceState)  
  15.   {  
  16.     super.onCreate(savedInstanceState);  
  17.     /*加载main.xml Layout */  
  18.     setContentView(R.layout.main);  
  19.  
  20.     /* 以findViewById()取得对象 */  
  21.     myTextView = (TextView) findViewById(R.id.myTextView);  
  22.     mySpinner = (Spinner) findViewById(R.id.mySpinner);  
  23.  
  24.     adapter = new ArrayAdapter<String>(this,  
  25.         android.R.layout.simple_spinner_item, countriesStr);  
  26.     /* myspinner_dropdown为自定义下拉菜单样式定义在res/layout目录下 */  
  27.     adapter.setDropDownViewResource(R.layout.myspinner_dropdown);  
  28.  
  29.     /* 将ArrayAdapter添加Spinner对象中 */  
  30.     mySpinner.setAdapter(adapter);  
  31.  
  32.     /* 将mySpinner添加OnItemSelectedListener */  
  33.     mySpinner.setOnItemSelectedListener  
  34.      (new Spinner.OnItemSelectedListener()  
  35.     {  
  36.       @Override  
  37.       public void onItemSelected  
  38.        (AdapterView<?> arg0, View arg1, int arg2,  
  39.           long arg3)  
  40.       {  
  41.         /* 将所选mySpinner的值带入myTextView中 */  
  42.         myTextView.setText("选择的是" + countriesStr[arg2]);  
  43.         /* 将mySpinner显示 */  
  44.         arg0.setVisibility(View.VISIBLE);  
  45.       }  
  46.  
  47.       @Override  
  48.       public void onNothingSelected(AdapterView<?> arg0)  
  49.       {  
  50.         // TODO Auto-generated method stub  
  51.       }  
  52.     });  
  53.  
  54.     /* 取得Animation定义在res/anim目录下 */  
  55.     myAnimation = AnimationUtils.loadAnimation(this, R.anim.my_anim);  
  56.  
  57.     /* 将mySpinner添加OnTouchListener */  
  58.     mySpinner.setOnTouchListener(new Spinner.OnTouchListener()  
  59.     {  
  60.  
  61.       @Override  
  62.       public boolean onTouch(View v, MotionEvent event)  
  63.       {  
  64.         /* 将mySpinner运行Animation */  
  65.         v.startAnimation(myAnimation);  
  66.         /* 将mySpinner隐藏 */  
  67.         v.setVisibility(View.INVISIBLE);  
  68.         return false;  
  69.       }  
  70.  
  71.     });  
  72.  
  73.     mySpinner.setOnFocusChangeListener(new Spinner.OnFocusChangeListener()  
  74.     {  
  75.       @Override  
  76.       public void onFocusChange(View v, boolean hasFocus)  
  77.       {  
  78.         // TODO Auto-generated method stub  
  79.       }  
  80.     });  
  81.   }  

res/layout/myspinner_dropdown.xml

改变下拉菜单样子的XML,里面所使用的组件为TextView。

  1. <?xml version="1.0" encoding="utf-8"?>    
  2. <TextView 
  3.   xmlns:android="http://schemas.android.com/apk/res/android" 
  4.   android:id="@+id/text1,  
  5.   android:layout_width="wrap_content,  
  6.   android:layout_height="24sp,  
  7.   android:singleLine="true"   
  8.   style="?android:attr/spinnerDropDownItemStyle" /> 
  9. res/anim/my_anim.xml 

Android的动画(Animation)是由4种类型(Type)所组成:alpha、scale、translate以及rotate,以下的自定义动画将使用其中的两种。

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <set 
  3.   xmlns:android="http://schemas.android.com/apk/res/android"> 
  4.   <translate   
  5.     android:fromXDelta="0"   
  6.     android:toXDelta="-100%p"   
  7.     android:duration="300" 
  8.   > 
  9.   </translate> 
  10.   <alpha   
  11.     android:fromAlpha="1.0"   
  12.     android:toAlpha="0.0"   
  13.     android:duration="300"> 
  14.   </alpha> 
  15. </set> 

扩展学习

Animation主要有两种动态方式,一种是tweened animation(渐变动画),另一种是frame by frame animation(画面转换动画)。tweened animation则有以下4种基本转换方式。

,AlphaAnimation (transparency changes):透明度转换。

,RotateAnimation (rotations):旋转转换。

,ScaleAnimation (growing or shrinking):缩放转换。

,TranslateAnimation (position changes):位置转换。

定义好你想要的动画XML后,用AnimationUtils.loadAnimation将动画加载,并试图在想要加上动态效果的组件中使用startAnimation方法。