我正在做一个例子,从左到右移动图像然后自己旋转。 我尝试过使用AnimationSet,但图像旋转不正确。它在一个循环中移动而不是自我。 如何解决这个问题?
我想要什么 MainActivity
@Override
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
AnimationSet set = new AnimationSet(true);
set.setFillAfter(true);
img_animation = (ImageView) findViewById(R.id.imgBanner);
Animation rotation = AnimationUtils.loadAnimation(this, R.anim.rotation);
rotation.setStartOffset(2000);
rotation.setDuration(2000);
TranslateAnimation moveLefttoRight = new TranslateAnimation(0, 200, 0, 0);
moveLefttoRight.setStartOffset(1000);
moveLefttoRight.setDuration(1000);
set.addAnimation(moveLefttoRight);
set.addAnimation(rotation);
img_animation.startAnimation(set);
}
Rotation.xml
<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:duration="1000"
android:fromDegrees="0"
android:interpolator="@android:anim/linear_interpolator"
android:pivotX="50%"
android:pivotY="50%"
android:toDegrees="90" />
activity_main.xml中
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<ImageView
android:id="@+id/imgBanner"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/banner" />
</RelativeLayout>
任何建议对我都有帮助
答案 0 :(得分:5)
尝试使用:
RotateAnimation anim = new RotateAnimation(0f, 360f,
Animation.RELATIVE_TO_SELF, 0.5f,
Animation.RELATIVE_TO_SELF, 0.5f);
因此它将相对于自身旋转。 希望这会有所帮助。
编辑:
image.clearAnimation();
RotateAnimation anim = new RotateAnimation(30, 360, image.getWidth()/2, image.getHeight()/2);
anim.setFillAfter(true);
anim.setRepeatCount(0);
anim.setDuration(10000);
image.startAnimation(anim);
我在演示应用程序中测试了这个。它工作得很好。希望这可以帮助你:)