Android 加入购物车动画

做了一个加入购物车动画,代码比较简单,先看下效果,可能因录制git图片软件问题,录制的git图片有些卡顿,实际效果流畅性还是不错的。

代码很简单

首先布局文件:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">

   <ImageView
       android:id="@+id/iv_pic"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:src="@mipmap/pic"/>

    <ImageView
        android:id="@+id/iv_cart"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:layout_centerInParent="true"
        android:layout_alignParentBottom="true"
        android:src="@mipmap/car"/>
</RelativeLayout>

然后就是MainActivity.java文件了

package com.iningke.demo;

import android.app.Activity;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.KeyEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.Animation;
import android.view.animation.AnimationSet;
import android.view.animation.AnimationUtils;
import android.view.animation.ScaleAnimation;
import android.view.animation.TranslateAnimation;
import android.widget.ImageView;
import android.widget.LinearLayout;

import java.io.File;

public class MainActivity extends Activity {
    ImageView img,iv_cart;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        img = (ImageView) findViewById(R.id.iv_pic);
        iv_cart = (ImageView)findViewById(R.id.iv_cart);

        img.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //缩放
                Animation animation = new ScaleAnimation(
                        2f, 0.2f, 2f, 0.2f, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
                animation.setDuration(500);
                animation.setFillAfter(true);

                //位移
                int[] startLocation = new int[2];
                int[] endLocation = new int[2];
                img.getLocationInWindow(startLocation);
                iv_cart.getLocationInWindow(endLocation); //获取购物车图标在屏幕位置
                Log.e("==", "starX:" + startLocation[0] + "endX:" + endLocation[0] + "starY:" + startLocation[1] + "endY:" + startLocation[1]);

                Animation animationXy = new TranslateAnimation(
                        startLocation[0],endLocation[0]-(iv_cart.getWidth()/3),
                        startLocation[1],endLocation[1] - (iv_cart.getHeight()*2/3));   //正好让图片进入到购物车
                animationXy.setDuration(1000);
                animationXy.setRepeatCount(0);

                AnimationSet set = new AnimationSet(false);
                set.addAnimation(animation);
                set.setFillAfter(true);
                set.addAnimation(animationXy);

                img.startAnimation(set);
            }
        });
    }
}

哈哈,效果就是这样,想要下载源码的朋友可以点击下载

转载于:https://my.oschina.net/u/2008084/blog/799205

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android电商应用中加入购物车动画可以通过以下步骤实现: 1. 在布局文件中创建一个ImageView或者其他的动画控件。 2. 创建一个Drawable资源文件,用于定义加入购物车动画效果。 3. 在Java代码中获取ImageView控件,并使用AnimationUtils加载Drawable资源文件,然后将动画绑定到ImageView上。 4. 在加入购物车的点击事件中启动动画,将商品图片从列表中的位置移动到购物车的位置,并同时播放加入购物车动画效果。 以下是一个简单的示例代码: 1. 在布局文件中添加ImageView控件: ``` <ImageView android:id="@+id/cartIcon" android:layout_width="64dp" android:layout_height="64dp" android:src="@drawable/cart_icon" android:layout_alignParentBottom="true" android:layout_alignParentRight="true" android:layout_marginRight="16dp" android:layout_marginBottom="16dp"/> ``` 2. 创建Drawable资源文件cart_add.xml: ``` <?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true"> <scale android:fromXScale="1.0" android:fromYScale="1.0" android:toXScale="1.5" android:toYScale="1.5" android:pivotX="50%" android:pivotY="50%" android:duration="300" android:interpolator="@android:anim/accelerate_interpolator"/> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="300" android:startOffset="300" android:interpolator="@android:anim/accelerate_interpolator"/> </set> ``` 3. 在Java代码中获取ImageView控件并绑定动画: ``` ImageView cartIcon = findViewById(R.id.cartIcon); Animation animation = AnimationUtils.loadAnimation(this, R.anim.cart_add); cartIcon.setAnimation(animation); ``` 4. 在加入购物车的点击事件中启动动画: ``` buttonAddToCart.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 将商品图片从列表中的位置移动到购物车的位置 // ... // 播放加入购物车动画效果 cartIcon.startAnimation(animation); } }); ``` 以上是一个简单的示例,您可以根据实际需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值