这是我需要AnimatedVectorDrawableCompat
实现的效果。
vector_drawable_anim.xml
<animated-vector xmlns:android="http://schemas.android.com/apk/res/android"
android:drawable="@drawable/vector_drawable">
<target
android:name="star"
android:animation="@animator/star_anim"/>
</animated-vector>
vector_drawable.xml
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="500px"
android:height="500px"
android:viewportHeight="500"
android:viewportWidth="500">
<group
android:name="star_group"
android:scaleX="5.0"
android:scaleY="5.0">
<path
android:name="star"
android:pathData="M 50.0,90.0 L 82.9193546357,27.2774101308 L 12.5993502926,35.8158045183 Z"
android:strokeColor="@color/colorAccent"
android:strokeWidth="1"/>
</group>
</vector>
star_anim.xml
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:ordering="sequentially">
<objectAnimator
android:duration="1000"
android:propertyName="trimPathStart"
android:valueFrom="1"
android:valueTo="0"/>
<objectAnimator
android:duration="1000"
android:propertyName="trimPathEnd"
android:valueFrom="1"
android:valueTo="0"/>
</set>
但AnimatorSet
无法设置repeatMode
。
如果我设置objectAnimator
&#39; repeatMode
,则第二个objectAnimator
不会显示。
我该怎么办?
答案 0 :(得分:1)
你可以在动画上设置一个监听器,一旦它再次完成start()
,就可以设置一个监听器:
AnimatedVectorDrawableCompat avdc = ...;
avdc.registerAnimationCallback(new Animatable2Compat.AnimationCallback() {
@Override
public void onAnimationEnd(Drawable drawable) {
avdc.start();
}
});
请注意,registerAnimationCallback()
可从支持库25.3.0开始提供。
答案 1 :(得分:1)
如果要将它循环到线程中直到ImageView被销毁呢?
完美的代码示例:
ImageView animatedImageView = (ImageView) findViewById(R.id.iv);
AnimatedVectorDrawableCompat animatedVectorDrawable = (AnimatedVectorDrawableCompat) animatedImageView.getDrawable();
new Thread(new Runnable() {
public void run() {
while (animatedImageView != null) {
try {
animatedImageView.post(new Runnable() {
@Override
public void run() {
animatedVectorDrawable.start();
}
});
Thread.sleep(500);
} catch (Exception e) {
e.printStackTrace();
}
}
}
}).start();
或者,您可以使用 azizbekian 后跟this git gist code sample提及的 registerAnimationCallback():
import android.app.Activity;
import android.graphics.drawable.Animatable;
import android.graphics.drawable.Animatable2;
import android.graphics.drawable.AnimatedVectorDrawable;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.widget.ImageView;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ImageView iv = (ImageView) findViewById(R.id.pin);
final AnimatedVectorDrawable avd = (AnimatedVectorDrawable) iv.getDrawable();
avd.registerAnimationCallback(new Animatable2.AnimationCallback() {
@Override
public void onAnimationEnd(Drawable drawable) {
avd.start();
}
});
avd.start();
}
}
答案 2 :(得分:0)
几乎你想要的东西,纯XML:
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:ordering="together">
<objectAnimator
android:duration="1000"
android:propertyName="trimPathStart"
android:repeatCount="infinite"
android:startOffset="1000"
android:valueFrom="1"
android:valueTo="0" />
<objectAnimator
android:duration="1000"
android:propertyName="trimPathStart"
android:repeatCount="infinite"
android:startOffset="1000"
android:repeatMode="reverse"
android:valueFrom="0"
android:valueTo="1" />
</set>
与您想要的不同之处在于路径修剪的方向。但它看起来很棒。