android 购物车布局,Android 加入购物车动画

本文展示了如何在Android中创建一个流畅的购物车动画。通过使用ScaleAnimation和TranslateAnimation,将商品图片缩放并平移到购物车图标的位置,实现了简单的加入购物车效果。代码简洁易懂,实际运行效果流畅。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

6ab52046cd435cbf3c3cebf12dfd8342.gif

代码很简单

首先布局文件:

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">

android:id="@+id/iv_pic"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:src="@mipmap/pic"/>

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"/>

然后就是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);

}

});

}

}

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值