Android實現(xiàn)購物車添加商品特效
一、引言
以前在餓了么上面訂餐的時候,曾經(jīng)看到過這么一個特效,就是將商品加入訂單時,會有一個小球呈拋物線狀落入購物車中,然后購物車中的數(shù)量會改變。具體的效果如下圖。
效果很簡單,就是一個拋物線的動畫,那么我們應該用什么技術來實現(xiàn)呢?想了想,動畫層是不個錯的選擇!下面開始分析及實現(xiàn)
二、分析
當點擊購買按鈕的時候,我們在布局上加入一個動畫層,然后讓小球在動畫層上做拋物線運動,就可實現(xiàn)上圖中的效果了。
說到做拋物線運動,當然需要數(shù)學上的一點小知識。 拋物線的原理很簡單,其實就是X軸方向保持勻速線性運動,而Y軸做加速度運動就好了。
在android的動畫中,可以設置Interpolator屬性。 Interpolator 被用來修飾動畫效果,定義動畫的變化率,可以使存在的動畫效果accelerated(加速),decelerated(減速),repeated(重復),bounced(彈跳)等。而我們需要用到的就是LinearInterpolator線性勻速運動和AccelerateInterpolator加速度運動效果。
所以我們只要給小球分別設置X和Y方向上的TranslateAnimation平移動畫,在設置相應的Interpolator ,即可實現(xiàn)拋物線效果。
三、代碼實現(xiàn)
關于布局文件和ListView就不必多說了 在最后提供的源碼中都可以看到,我們這里主要講解在動畫層上實現(xiàn)拋物線動畫的功能。
holder.buyBtn.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 用來存儲按鈕的在屏幕的X、Y坐標 int[] startLocation = new int[2]; // 獲取購買按鈕的在屏幕的X、Y坐標(這也是動畫開始的坐標) v.getLocationInWindow(startLocation); //設置小球的圖片 ball = new ImageView(mContext); ball.setImageResource(R.drawable.sign); setAnim(ball, startLocation);// 開始執(zhí)行動畫 } });
這段代碼很簡單,就是設置小球的初始坐標,然后開始執(zhí)行動畫。
下面是執(zhí)行動畫的函數(shù)。
private void setAnim(final View v, int[] startLocation) { anim_mask_layout = null; //創(chuàng)建動畫層 anim_mask_layout = createAnimLayout(); //把動畫小球添加到動畫層 anim_mask_layout.addView(v); final View view = addViewToAnimLayout(anim_mask_layout, v,startLocation); // 存儲動畫結束位置的X、Y坐標 int[] endLocation = new int[2]; // shopCart是購物車 shopCart.getLocationInWindow(endLocation); // 計算位移 // 動畫位移的X坐標 int endX = 0 - startLocation[0] + 40; // 動畫位移的y坐標 int endY = endLocation[1] - startLocation[1]; //設置X方向上的平移動畫 TranslateAnimation translateAnimationX = new TranslateAnimation(0, endX, 0, 0); translateAnimationX.setInterpolator(new LinearInterpolator()); // 動畫重復執(zhí)行的次數(shù) translateAnimationX.setRepeatCount(0); translateAnimationX.setFillAfter(true); //設置Y方向上的平移動畫 TranslateAnimation translateAnimationY = new TranslateAnimation(0, 0, 0, endY); translateAnimationY.setInterpolator(new AccelerateInterpolator()); // 動畫重復執(zhí)行的次數(shù) translateAnimationY.setRepeatCount(0); translateAnimationX.setFillAfter(true); AnimationSet set = new AnimationSet(false); set.setFillAfter(false); set.addAnimation(translateAnimationY); set.addAnimation(translateAnimationX); set.setDuration(800);// 動畫的執(zhí)行時間 view.startAnimation(set); // 動畫監(jiān)聽事件 set.setAnimationListener(new AnimationListener() { // 動畫的開始 @Override public void onAnimationStart(Animation animation) { v.setVisibility(View.VISIBLE); } @Override public void onAnimationRepeat(Animation animation) { // TODO Auto-generated method stub } // 動畫的結束 @Override public void onAnimationEnd(Animation animation) { v.setVisibility(View.GONE); buyNum++;//讓購買數(shù)量加1 buyNumView.setText(buyNum + "");// buyNumView.setBadgePosition(BadgeView.POSITION_TOP_RIGHT); buyNumView.show(); } }); }
buyNumView是github上的一個組件BadgeView.就是那個購物車右上角顯示數(shù)字的標簽,在QQ和微信上都能看到這玩意。
下面是將小球添加到動畫層的代碼
private View addViewToAnimLayout(final ViewGroup parent, final View view, int[] location) { int x = location[0]; int y = location[1]; LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT); lp.leftMargin = x; lp.topMargin = y; view.setLayoutParams(lp); return view; }
主要的實現(xiàn)就是這樣了。大家也可以根據(jù)這個案例做一些改進,就可以做出其他的效果。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android中獲取sha1證書指紋數(shù)據(jù)的方法
大家都知道在Android開發(fā)中,經(jīng)常要獲取sha1證書指紋,所以這篇文章主要介紹在Android中如何使用命令獲取sha1證書指紋數(shù)據(jù)的方法,有需要的可以參考借鑒。2016-09-09Android入門之利用Spinner實現(xiàn)彈出選擇對話框
這篇文章主要為大家詳細介紹了Android里如何巧用Spinner做彈出選擇對話框,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的小伙伴可以了解一下2022-11-11Android提高之BLE開發(fā)Android手機搜索iBeacon基站
這篇文章主要介紹了BLE開發(fā)Android手機搜索iBeacon基站,需要的朋友可以參考下2014-08-08Android6.0藍牙出現(xiàn)無法掃描設備或閃退問題解決辦法
這篇文章主要介紹了Android6.0藍牙出現(xiàn)無法掃描設備或閃退問題解決辦法的相關資料,需要的朋友可以參考下2017-02-02Android ListView實現(xiàn)簡單列表功能
這篇文章主要為大家詳細介紹了Android ListView實現(xiàn)簡單列表功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08Android中手機錄屏并轉(zhuǎn)換GIF的兩種方式
本文主要介紹了android中手機錄屏并轉(zhuǎn)換GIF的兩種方式,具有一定的參考價值,下面跟著小編一起來看下吧2017-01-01Android開發(fā) -- 狀態(tài)欄通知Notification、NotificationManager詳解
本文主要講解狀態(tài)欄通知Notification、NotificationManager,小編覺得非常詳細,給大家一個參考,希望對大家學習有所幫助。2016-06-06