中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android如何實現購物車添加商品特效

發布時間:2021-04-17 09:51:26 來源:億速云 閱讀:213 作者:小新 欄目:移動開發

這篇文章給大家分享的是有關Android如何實現購物車添加商品特效的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

一、引言

以前在餓了么上面訂餐的時候,曾經看到過這么一個特效,就是將商品加入訂單時,會有一個小球呈拋物線狀落入購物車中,然后購物車中的數量會改變。具體的效果如下圖。

Android如何實現購物車添加商品特效

效果很簡單,就是一個拋物線的動畫,那么我們應該用什么技術來實現呢?想了想,動畫層是不個錯的選擇!下面開始分析及實現

二、分析

當點擊購買按鈕的時候,我們在布局上加入一個動畫層,然后讓小球在動畫層上做拋物線運動,就可實現上圖中的效果了。
說到做拋物線運動,當然需要數學上的一點小知識。 拋物線的原理很簡單,其實就是X軸方向保持勻速線性運動,而Y軸做加速度運動就好了。
在android的動畫中,可以設置Interpolator屬性。 Interpolator 被用來修飾動畫效果,定義動畫的變化率,可以使存在的動畫效果accelerated(加速),decelerated(減速),repeated(重復),bounced(彈跳)等。而我們需要用到的就是LinearInterpolator線性勻速運動和AccelerateInterpolator加速度運動效果。
所以我們只要給小球分別設置X和Y方向上的TranslateAnimation平移動畫,在設置相應的Interpolator ,即可實現拋物線效果。

三、代碼實現

關于布局文件和ListView就不必多說了 在最后提供的源碼中都可以看到,我們這里主要講解在動畫層上實現拋物線動畫的功能。

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);// 開始執行動畫
  }
});

這段代碼很簡單,就是設置小球的初始坐標,然后開始執行動畫。
下面是執行動畫的函數。

private void setAnim(final View v, int[] startLocation) {
    anim_mask_layout = null;
    //創建動畫層
    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());
    // 動畫重復執行的次數
    translateAnimationX.setRepeatCount(0);
    translateAnimationX.setFillAfter(true);
    //設置Y方向上的平移動畫
    TranslateAnimation translateAnimationY = new TranslateAnimation(0, 0,
        0, endY);
    translateAnimationY.setInterpolator(new AccelerateInterpolator());
    // 動畫重復執行的次數
    translateAnimationY.setRepeatCount(0);
    translateAnimationX.setFillAfter(true);

    AnimationSet set = new AnimationSet(false);
    set.setFillAfter(false);
    set.addAnimation(translateAnimationY);
    set.addAnimation(translateAnimationX);
    set.setDuration(800);// 動畫的執行時間
    view.startAnimation(set);
    // 動畫監聽事件
    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++;//讓購買數量加1
        buyNumView.setText(buyNum + "");//
        buyNumView.setBadgePosition(BadgeView.POSITION_TOP_RIGHT);
        buyNumView.show();
      }
    });
}

buyNumView是github上的一個組件BadgeView.就是那個購物車右上角顯示數字的標簽,在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;
  }

主要的實現就是這樣了。大家也可以根據這個案例做一些改進,就可以做出其他的效果。

感謝各位的閱讀!關于“Android如何實現購物車添加商品特效”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

龙山县| 龙南县| 汉中市| 门源| 贵德县| 庆阳市| 巴南区| 玉环县| 永吉县| 堆龙德庆县| 兴海县| 浦江县| 衡山县| 房山区| 商都县| 宜章县| 武鸣县| 洱源县| 花莲市| 永靖县| 呼图壁县| 乐陵市| 新乡市| 忻城县| 张掖市| 尖扎县| 昆山市| 黄梅县| 西峡县| 北票市| 乌拉特前旗| 商城县| 个旧市| 乐昌市| 柳江县| 东乡族自治县| 农安县| 华池县| 油尖旺区| 庆云县| 柘荣县|