如何实现自定义列表视图文本动画

Ran*_*mar 6 android android-custom-view android-animation

我在android中创建购物应用程序.在我的应用程序中,我显示自定义列表视图中的项目列表.

如果客户选择项目,则所选项目文本从列表视图移动到购物车图像.如下图所示,

这种类型的动画是我的要求. 在此输入图像描述

但我的动画视图在自定义行结束时停止..就像这张图片一样.

在此输入图像描述

我的animation.xml代码,

<?xml version="1.0" encoding="utf-8"?>
 <set
xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/linear_interpolator"
android:fillAfter="true"
>

<translate
    android:fromYDelta="0%p"
    android:toYDelta="100%p"
    android:fromXDelta="0%p"
    android:toXDelta="100%p"
    android:duration="1000"

    />

<alpha
    android:duration="500"
    android:fromAlpha="1.0"
    android:interpolator="@android:anim/accelerate_interpolator"
    android:toAlpha="0.0" />

   <scale
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="3500"
    android:fromXScale="1.0"
    android:fromYScale="1.0"
    android:toXScale="0.0"
    android:toYScale="0.2" >
</scale>

</set>
Run Code Online (Sandbox Code Playgroud)

注意:如果有人想要更多代码我稍后发布..因为已经这个qtn需要更长的时间..

我的问题,

我的动画textview不能超出自定义行的范围.

那么如何将自定义行textview移动到图像的末尾(购物车图像)?

Mar*_*ton 7

目标是将视图从一个位置设置为另一个位置,因此首先我们需要获得两个点.您可以执行以下操作:

int[] screenLocation = new int[2];
textView.getLocationOnScreen(screenLocation);
int startX = screenLocation[0];
int startY = screenLocation[1];

int[] screenLocationB = new int[2];
cartView.getLocationOnScreen(screenLocationB);
int endX = screenLocationB[0];
int endY = screenLocationB[1];
Run Code Online (Sandbox Code Playgroud)

一旦你同时拥有textview的起始位置和你希望它结束​​的位置(cartview的位置),我们需要从下一个点的两点动画.我们可以通过在窗口图层或列表视图上方的framelayout上放置新的textview来实现此目的.

这里我们添加到窗口层:

WindowManager.LayoutParams layoutParams = new WindowManager.LayoutParams();
layoutParams.width = view.getMeasuredWidth();
layoutParams.height = view.getMeasuredHeight();
activity.addContentView(newTextView, layoutParams);
Run Code Online (Sandbox Code Playgroud)

接下来我们设置起始位置.

 newTextView.setTranslationX(startX);
 newTextView.setTranslationY(startY);
Run Code Online (Sandbox Code Playgroud)

最后我们动画.

 newTextView.animate().setDuration(300)
       .translationX(endX).translationY(endX).start()
Run Code Online (Sandbox Code Playgroud)