android局部翻转动画,Android图片翻转动画简易实现代码

本文分享了一段Android代码,演示如何创建一个ImageView的点击翻转动画。通过设置ImageView的OnClickListener和使用 Rotate3d 动画,实现了单击图片时90度翻转的效果。代码简洁易懂,可以直接应用于项目中,对于需要添加翻转效果的开发者具有参考价值。
摘要由CSDN通过智能技术生成

下面给大家分享一个有趣的动画:这里比较适合一张图片的翻转,如果是多张图片,可以参考APIDemo里的例子,就是加个ArrayAdapter,还是简单的,也可以自己发挥修改,实现自己想要的。这里的代码基本上可以直接运行项目了。

在main.xml里加个ImageView,如

android:id="@+id/container"

android:layout_width="fill_parent"

android:layout_height="fill_parent">

android:id="@+id/image"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="Rotate"

android:textSize="50px"

android:layout_x="150px"

android:layout_y="30px"

android:src="@drawable/ro">

>

这个不需要解释吧,都可以看懂的

最后,还需要一个activity类

如:

public class TestRotate extends Activity implements OnClickListener{

private mageView imageview;

private ViewGroup mContainer;

/**

*这个变量设置的是图片,如果是多张图片,那么可以用数组,如

*private static final int IMAGE = new int[]{

* R.drawable.ro,

* R.drawable.icon

*};

*有多少图片就放多少,我这里做的只是一张图片的翻转

*

*/

private static final int IMAGE = R.drawable.ro;

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

imageview = (ImageView) findViewById(R.id.image);

mContainer = (ViewGroup) findViewById(R.id.container);

/**

* 设置最新显示的图片

* 如果是数组,那么可以写成IMAGE[int]

*

*/

imageview.setImageResource(IMAGE);

/**

*

* 设置ImageView的OnClickListener

*

*/

imageview.setClickable(true);

imageview.setFocusable(true);

imageview.setOnClickListener(this);

}

private void applyRotation(int position, float start, float end) {

// Find the center of the container

final float centerX = mContainer.getWidth() / 2.0f;

final float centerY = mContainer.getHeight() / 2.0f;

final Rotate3d rotation =

new Rotate3d(start, end, centerX, centerY, 310.0f, true);

rotation.setDuration(500);

rotation.setFillAfter(true);

rotation.setInterpolator(new AccelerateInterpolator());

rotation.setAnimationListener(new DisplayNextView(position));

mContainer.startAnimation(rotation);

}

@Override

public void onClick(View v) {

// TODO Auto-generated method stub

/**

*

* 调用这个方法,就是翻转图片

* 参数很简单,大家都应该看得懂

* 简单说下,第一个是位置,第二是开始的角度,第三个是结束的角度

* 这里需要说明的是,如果是要回到上一张

* 把第一个参数设置成-1就行了

*

*/

applyRotation(0,0,90);

}

private final class DisplayNextView implements Animation.AnimationListener {

private final int mPosition;

private DisplayNextView(int position) {

mPosition = position;

}

public void onAnimationStart(Animation animation) {

}

public void onAnimationEnd(Animation animation) {

mContainer.post(new SwapViews(mPosition));

}

public void onAnimationRepeat(Animation animation) {

}

}

/**

* This class is responsible for swapping the views and start the second

* half of the animation.

*/

private final class SwapViews implements Runnable {

private final int mPosition;

public SwapViews(int position) {

mPosition = position;

}

public void run() {

final float centerX = mContainer.getWidth() / 2.0f;

final float centerY = mContainer.getHeight() / 2.0f;

Rotate3d rotation;

if (mPosition > -1) {

imageview.setVisibility(View.VISIBLE);

imageview.requestFocus();

rotation = new Rotate3d(90, 180, centerX, centerY, 310.0f, false);

} else {

imageview.setVisibility(View.GONE);

rotation = new Rotate3d(90, 0, centerX, centerY, 310.0f, false);

}

rotation.setDuration(500);

rotation.setFillAfter(true);

rotation.setInterpolator(new DecelerateInterpolator());

mContainer.startAnimation(rotation);

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 翻转动画可以通过以下步骤实现: 1. 创建两个布局,一个正面布局和一个背面布局。 2. 在正面布局中添加一个翻转按钮,当用户点击该按钮时触发翻转动画。 3. 在翻转动画的XML文件中定义动画属性。您需要定义旋转轴,旋转角度和动画持续时间等属性。 4. 在Java代码中,使用Animation类的loadAnimation()方法加载动画,并将其应用于正面布局。 5. 为翻转按钮添加一个点击监听器,当用户点击按钮时,使用View类的startAnimation()方法启动动画。 6. 在动画的监听器中,检查当前布局显示的是正面还是背面,然后改变布局的可见性,以显示另一个布局。 以下是一个简单的示例代码,可以让您更好地理解如何实现Android翻转动画。 ``` // 加载动画 Animation animation = AnimationUtils.loadAnimation(this, R.anim.flip_animation); // 应用动画到正面布局 View frontLayout = findViewById(R.id.front_layout); frontLayout.setAnimation(animation); // 为翻转按钮添加点击监听器 Button flipButton = findViewById(R.id.flip_button); flipButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { // 启动动画 frontLayout.startAnimation(animation); } }); // 监听动画的开始和结束 animation.setAnimationListener(new Animation.AnimationListener() { @Override public void onAnimationStart(Animation animation) { } @Override public void onAnimationEnd(Animation animation) { // 检查当前布局显示的是正面还是背面 if (frontLayout.getVisibility() == View.VISIBLE) { // 如果是正面,隐藏正面显示背面 frontLayout.setVisibility(View.GONE); View backLayout = findViewById(R.id.back_layout); backLayout.setVisibility(View.VISIBLE); } else { // 如果是背面,隐藏背面显示正面 frontLayout.setVisibility(View.VISIBLE); View backLayout = findViewById(R.id.back_layout); backLayout.setVisibility(View.GONE); } } @Override public void onAnimationRepeat(Animation animation) { } }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值