我正在尝试使用Android的动画框架让我的ImageView以菱形图案移动。这是我的animation.xml:
<set xmlns:android="http://schemas.android.com/apk/res/android" android:shareInterpolator="true">
<translate
android:fromXDelta="40%p" android:toXDelta="90%p"
android:fromYDelta="10%p" android:toYDelta="40%p"
android:duration="500" android:startOffset="0"/>
<translate
android:fromXDelta="90%p" android:toXDelta="40%p"
android:fromYDelta="40%p" android:toYDelta="90%p"
android:duration="500" android:startOffset="500"/>
<translate
android:fromXDelta="40%p" android:toXDelta="10%p"
android:fromYDelta="90%p" android:toYDelta="40%p"
android:duration="500" android:startOffset="1000"/>
<translate
android:fromXDelta="10%p" android:toXDelta="40%p"
android:fromYDelta="40%p" android:toYDelta="10%p"
android:duration="500" android:startOffset="1500"/>
</set>
我的布局:
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent">
<ImageView
android:id="@+id/img"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/icon"/>
</FrameLayout>
我的onStart:
protected void onStart() {
super.onStart();
ImageView img = (ImageView)findViewById(R.id.img);
Animation a = AnimationUtils.loadAnimation(this, R.anim.diamond);
img.startAnimation(a);
}
当我启动我的应用程序时,我看到的是一个空白屏幕2秒钟,然后我的图像弹出到屏幕的左上角。如果我删除除了一个翻译动画之外的所有动画,我会看到图像以对角线移动。
我更愿意使用XML来定义动画,而不是Java。
有没有人对如何看到整个动画有任何见解?
-Dan
答案 0 :(得分:15)
动画属性与它们开始时的位置有关。这可能更接近你想要的东西:
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" android:shareInterpolator="true">
<translate
android:fromXDelta="40%p" android:toXDelta="90%p"
android:fromYDelta="10%p" android:toYDelta="40%p"
android:duration="500" android:startOffset="0"/>
<translate
android:fromXDelta="0%p" android:toXDelta="-50%p"
android:fromYDelta="0%p" android:toYDelta="50%p"
android:duration="500" android:startOffset="500"/>
<translate
android:fromXDelta="0%p" android:toXDelta="-30%p"
android:fromYDelta="0%p" android:toYDelta="-50%p"
android:duration="500" android:startOffset="1000"/>
<translate
android:fromXDelta="0%p" android:toXDelta="30%p"
android:fromYDelta="0%p" android:toYDelta="-30%p"
android:duration="500" android:startOffset="1500"/>
</set>
答案 1 :(得分:1)
试试这个:
Animation anim = AnimationUtils.loadAnimation(getApplicationContext(), R.anim.diamond);
findViewById(R.id.img).setAnimation(anim);
anim.start();
您还应该更改动画以一个接一个地加载。我认为你创造的那套将会尝试一次播放所有的动画,而且效果不会很好。
使用像这样的animationListener:
anim.setAnimationListener(new Animation.AnimationListener() {
public void onAnimationStart(Animation animation) {
}
public void onAnimationEnd(Animation animation) {
Animation anim = AnimationUtils.loadAnimation(getApplicationContext(), R.anim.diamond2);
findViewById(R.id.img).setAnimation(anim);
anim.start();
}
public void onAnimationRepeat(Animation animation) {
}
});
答案 2 :(得分:1)
使用它可以使用它,我测试了它
<set xmlns:android="http://schemas.android.com/apk/res/android" android:shareInterpolator="true">
<translate
android:fromXDelta="40%p" android:toXDelta="90%p"
android:fromYDelta="10%p" android:toYDelta="40%p"
android:duration="500" android:startOffset="0"
/>
<translate
android:fromXDelta="0%p" android:toXDelta="-40%p"
android:fromYDelta="0%p" android:toYDelta="40%p"
android:duration="500" android:startOffset="500"/>
<translate
android:fromXDelta="0%p" android:toXDelta="-40%p"
android:fromYDelta="0%p" android:toYDelta="-40%p"
android:duration="500" android:startOffset="1000"/>
<translate
android:fromXDelta="0%p" android:toXDelta="40%p"
android:fromYDelta="0%p" android:toYDelta="-40%p"
android:duration="500" android:startOffset="1500"/>
</set>
答案 3 :(得分:0)
使用此动画xml代码。它有效:
<set xmlns:android="http://schemas.android.com/apk/res/android" android:shareInterpolator="true">
<translate
android:fromXDelta="40%" android:toXDelta="90%"
android:fromYDelta="10%" android:toYDelta="40%"
android:duration="500" android:startOffset="0"/>
<translate
android:fromXDelta="90%" android:toXDelta="40%"
android:fromYDelta="40%" android:toYDelta="90%"
android:duration="500" android:startOffset="500"/>
<translate
android:fromXDelta="40%" android:toXDelta="10%"
android:fromYDelta="90%" android:toYDelta="40%"
android:duration="500" android:startOffset="1000"/>
<translate
android:fromXDelta="10%" android:toXDelta="40%"
android:fromYDelta="40%" android:toYDelta="10%"
android:duration="500" android:startOffset="1500"/>
</set>