如何在android中创建“添加到购物车”动画?

时间:2017-02-07 00:02:49

标签: android animation android-animation

我的应用看起来有点像这样(https://dribbble.com/shots/2189587-Add-to-cart

我想同样将产品的快照移到下面的购物车中。我之前从未使用动画,所以我正在努力了解这一点。

对于您的答案,假设产品图像位于ImageView中,购物车按钮是右下角的浮动操作按钮。

我的页面代码在这里:

<?xml version="1.0" encoding="utf-8"?> <layout xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" xmlns:android="http://schemas.android.com/apk/res/android"> <data> <variable name="product" type="com.example.irtazasafi.ilovezappos.Result"/> </data> <LinearLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:weightSum="1" android:background="@color/cardview_light_background" android:gravity="center"> <ImageView android:layout_width="fill_parent" android:layout_height="50dp" android:background="@color/cardview_light_background" android:src="@mipmap/zappos" android:textAlignment="center"/> <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@{product.getProductId()}" android:textAlignment="center" /> <android.support.design.widget.CoordinatorLayout android:id="@+id/test" android:layout_width="wrap_content" android:layout_height="wrap_content"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@{product.getPercentOff()}" android:textSize="20sp" android:layout_marginRight="250dp" android:textColor="@color/colorAccent" android:id="@+id/discountAmount"/> </android.support.design.widget.CoordinatorLayout> <ImageView android:layout_width="200dp" android:layout_height="200dp" android:layout_marginTop="10dp" android:id="@+id/productImage" android:scaleType="centerCrop" android:backgroundTint="@color/cardview_light_background" android:background="@color/cardview_light_background" /> <TextView android:layout_marginTop="5dp" android:layout_width="fill_parent" android:layout_height="43dp" android:background="?android:attr/colorPrimary" android:text="@{product.getBrandName()}" android:textColor="@android:color/black" android:textSize="35sp" android:textAlignment="center"/> <TextView android:layout_marginTop="0dp" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="?android:attr/colorPrimary" android:text="@{product.getProductName()}" android:textColor="@android:color/black" android:textSize="15sp" android:textAlignment="center"/> <TextView android:layout_marginTop="0dp" android:layout_width="fill_parent" android:layout_height="25dp" android:background="?android:attr/colorPrimary" android:text="@{product.getOriginalPrice()}" android:textColor="@android:color/black" android:textSize="20sp" android:textAlignment="center" android:id="@+id/origPrice"/> <TextView android:layout_marginTop="0dp" android:layout_width="fill_parent" android:layout_height="25dp" android:background="?android:attr/colorPrimary" android:text="@{product.getPrice()}" android:textColor="@android:color/black" android:textSize="15sp" android:textAlignment="center" android:id="@+id/currPrice"/> <android.support.design.widget.CoordinatorLayout android:id="@+id/main_content" android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.design.widget.FloatingActionButton android:layout_width="54dp" android:layout_height="54dp" android:layout_gravity="bottom|right" android:src="@mipmap/ic_add_shopping_cart_black_24dp" android:layout_marginBottom="40dp" android:layout_marginRight="30dp" app:backgroundTint="@android:color/holo_blue_light" android:id="@+id/cartadd" android:onClick="addToCart"/> </android.support.design.widget.CoordinatorLayout> </LinearLayout> layout>

提前致谢!

2 个答案:

答案 0 :(得分:2)

理论上,我会尝试一些想法:

  1. 拥有2个ImageView:一个在您的RecyclerView中,一个在与FAB相同的层次结构级别(在xml布局中)。隐藏第二个。

  2. 单击产品后,将所单击图像的位图复制到第二个ImageView

  3. 检索相对于您的FAB容器的产品图片的X和Y - 在您的父级中递归getX和getY您的视图,直到您在父级中为止(不要忘记删除) RecyclerView中的scrollX和scrollY)

  4. 将第二张图片放回X和Y检索

  5. 等待您的图像布局(getViewTreeObserver()。addOnPredrawListener())并应用动画将其移动到FAB的中心。您需要缩小图像并进行翻译(获取FAB的x和y以了解您的目的地)

  6. 添加onAnimationEndListener,在FAB顶部显示+1

  7. 将向下翻译动画应用到+1视图(+1将在FAB顶部绘制,但由于图标和+1为白色,因此应该没问题)

  8. 祝你好运,这是相当多的工作!

答案 1 :(得分:2)

请检查,我认为这可以帮助您更好

link fly to cart animation

fly animation