Android實現動畫效果的自定義下拉菜單功能
我們在購物APP裡面設置收貨地址時,都會有讓我們選擇省份及城市的下拉菜單項。今天我將使用Android原生的 Spinner 控件來實現一個自定義的下拉菜單功能,並配上一個透明漸變動畫效果。
要實現的功能及思路如下:
下拉菜單樣式是自定義的、非原生效果:需要使用 setDropDownViewResource 方法來設置下拉視圖的佈局樣式。該方法需要傳入佈局資源,該佈局需要定義每個 Item 的屬性,比如寬高和文字顏色等(為瞭使效果明顯,我將每個 Item 的高度設置為 50 dp,文字設置為藍色)點擊這個 Spinner 控件時,讓其運行一段“從左到右、逐漸顯示”的漸變動畫:我通過 xml 的方式來定義這個動畫,需要包含 translate(位移) 和 alpha(透明度) 兩個TAG,並設置相應的屬性值下拉菜單的內容列表要展示在 Spinner 裡面,需要通過適配器 Adapter 跟 Spinner 進行綁定:可以直接使用Android原生的 ArrayAdapter選擇任意一個 Item 後,將其內容展示在界面上,告知用戶選擇的內容:需要實現 Spinner 的 onItemSelected 監聽回調
源碼如下:
1、主Activity(註意代碼中的註釋,不然你會遇到一些坑!)
public class SpinnerDemo extends Activity { private static final String[] countries = {"北京", "上海", "廣州", "深圳", "成都", "杭州"}; private TextView mTextView; private Spinner mSpinner; private ArrayAdapter<String> mAdapter; private Animation mAnimation; @Override protected void onCreate(Bundle onSavedInstance) { super.onCreate(onSavedInstance); setContentView(R.layout.spinner_demo); mTextView = findViewById(R.id.textView9); mSpinner = findViewById(R.id.spinner); mAdapter = new ArrayAdapter<>(this, android.R.layout.simple_spinner_item, countries); // 自定義的下拉視圖佈局樣式 mAdapter.setDropDownViewResource(R.layout.spinner_drop_down); // 設置數據的適配器 mSpinner.setAdapter(mAdapter); mSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { @Override public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { mTextView.setText("你選擇的是:" + countries[position]); // 一定要設置父視圖可見,否則 在選擇後,Spinner會消失 parent.setVisibility(View.VISIBLE); } @Override public void onNothingSelected(AdapterView<?> parent) { } }); // 通過 xml 的形式來定義動畫 mAnimation = AnimationUtils.loadAnimation(this, R.anim.my_anim); mSpinner.setOnTouchListener(new Spinner.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { // 點擊 Spinner 後,運行動畫 v.startAnimation(mAnimation); return false; } }); } }
2、佈局文件 spinner_demo.xml 如下:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:id="@+id/textView9"/> <Spinner android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/spinner" android:layout_gravity="center" android:layout_marginTop="15dp"/> </LinearLayout>
3、自定義的下拉視圖樣式佈局文件 spinner_drop_down.xml 如下:
<?xml version="1.0" encoding="utf-8"?> <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="wrap_content" android:layout_height="50dp" android:textColor="@color/colorBlue" android:singleLine="true" style="?android:attr/spinnerDropDownItemStyle"> </TextView>
4、自定義動畫 xml 文件如下:
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="0" android:toXDelta="50%p" android:duration="2000"/> <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="2000"/> </set>
5、效果圖如下:
到此這篇關於Android實現動畫效果的自定義下拉菜單功能的文章就介紹到這瞭,更多相關android自定義下拉菜單內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Android下拉列表框Spinner使用方法詳解
- Android實現文字消除效果
- Android Studio實現簡易進制轉換計算器
- Android seekbar實現可拖動進度條
- Android studio實現簡易的計算器功能