`
大象06
  • 浏览: 119474 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

Android中对布局的翻转,如何保持布局不颠倒

 
阅读更多

最近在研究iphone上的翻转效果,就是类似于passbook里面的查看票据的时候,正面是一种布局,点击某个按钮会翻转到背面,然后呈现的又是另一个布局。就在想怎么用到android里面呢?正好,最近项目有这个需求。于是便上网搜寻有关android的翻转动画的资料。在网上找到原来apidemos里面就提供了翻转动画,不过是针对图片的翻转,但是我想只要有动画就是一样的调用,管它图片还是布局呢,最后还不是xxx.startAnimation。翻转动画如下,如果没有apidemos的童鞋可以直接拿去用。

package com.huiian.kelu.util;

import android.graphics.Camera;
import android.graphics.Matrix;
import android.view.animation.Animation;
import android.view.animation.Transformation;

public class Rotate3dAnimation extends Animation {
	private final float fromDegrees;
	private final float toDegrees;
	private final float centerX;
	private final float centerY;
	private final float depthZ;
	private final boolean reverse;
	private Camera camera;

	public Rotate3dAnimation(float fromDegrees, float toDegrees, float centerX,
			float centerY, float depthZ, boolean reverse) {
		this.fromDegrees = fromDegrees;
		this.toDegrees = toDegrees;
		this.centerX = centerX;
		this.centerY = centerY;
		this.depthZ = depthZ;
		this.reverse = reverse;
	}

	@Override
	public void initialize(int width, int height, int parentWidth,
			int parentHeight) {
		super.initialize(width, height, parentWidth, parentHeight);
		camera = new Camera();
	}

	@Override
	protected void applyTransformation(float interpolatedTime, Transformation t) {
		final float fromDegrees = this.fromDegrees;
		float degrees = fromDegrees
				+ ((toDegrees - fromDegrees) * interpolatedTime);
		final float centerX = this.centerX;
		final float centerY = this.centerY;
		final Camera camera = this.camera;
		final Matrix matrix = t.getMatrix();
		camera.save();
		if (reverse) {
			camera.translate(0.0f, 0.0f, depthZ * interpolatedTime);
		} else {
			camera.translate(0.0f, 0.0f, depthZ * (1.0f - interpolatedTime));
		}
		camera.rotateY(degrees);
		camera.getMatrix(matrix);
		camera.restore();

		matrix.preTranslate(-centerX, -centerY);
		matrix.postTranslate(centerX, centerY);
	}
}

 

       有了这个动画类之后,就可以像调用android基本动画的方式来调用了,因为大家可以看到这个翻转动画是继承于Animation的。那具体该如何实现布局的翻转呢?首先你的布局代码是:

    <FrameLayout
        android:id="@id/main_fl"
        android:layout_width="214dp"
        android:layout_height="246dp"
        android:layout_centerInParent="true"
        android:orientation="vertical"
        android:visibility="invisible" >

        <include layout="@layout/zheng" />

        <include layout="@layout/fan" />
    </FrameLayout>

 
        一个正,一个反,剩下的你自己布局就行。

        剩下的在Activity里面的用法apidemos也给出了,大家只需要把一些布局替换成自己的就行了。好了,这个时候坑爹的来了,因为你会发现翻转过去的布局是倒着的,我被这个鬼东西折腾了好久,因为我发现apidemos里面的例子也是这样的,它的图片也是倒的。这让人情何以堪。于是试了许久终于解决了。首先我们定义一个记录正反的bool值

private boolean nowZhengFan = true;// 默认当前是正面

 
然后我们是点击布局来切换正反面的,所以将布局设置OnClickListener监听。然后在onClick方法里面写:

case R.id.main_fl:
if(nowZhengFan) {
applyRotation(0, 0, 90);
} else {
applyRotation(-1, 360, 270);
}
break;

 

private void applyRotation(int position, float start, float end) {
		float centerX = mainFL.getWidth() / 2.0f;
		float centerY = mainFL.getWidth() / 2.0f;
		final Rotate3dAnimation animation = new Rotate3dAnimation(start, end,
				centerX, centerY, 310.0f, true);
		animation.setDuration(500);
		animation.setFillAfter(false);
		animation.setInterpolator(new AccelerateInterpolator());
		animation.setAnimationListener(new DisplayNextView(position, true));
		mainFL.startAnimation(animation);
	}

	private class DisplayNextView implements AnimationListener {

		private int position;
		private boolean b;
		
		public DisplayNextView(int pos,boolean b) {
			this.b = b;
			this.position = pos;
		}
		
		@Override
		public void onAnimationEnd(Animation animation) {
			mainFL.post(new Swap(position));
		}

		@Override
		public void onAnimationRepeat(Animation animation) {

		}

		@Override
		public void onAnimationStart(Animation animation) {

		}

	}

	private class Swap implements Runnable {

		private int position;
		
		public Swap(int pos) {
			this.position = pos;
		}
		@Override
		public void run() {
			float centerX = missionFL.getWidth() / 2.0f;
			float centerY = missionFL.getWidth() / 2.0f;
			Rotate3dAnimation rotation = null;
			if(position > -1) {
				rotation = new Rotate3dAnimation(270, 360, centerX, centerY, 310.0f, false);
				zheng.setVisibility(View.GONE);
				fan.setVisibility(View.VISIBLE);
				nowZhengFan = false;
			} else {
				rotation = new Rotate3dAnimation(90, 0, centerX, centerY, 310.0f, false);
				zheng.setVisibility(View.VISIBLE);
				fan.setVisibility(View.GONE);
				nowZhengFan = true;
			}

			rotation.setDuration(500);
			rotation.setFillAfter(false);
			rotation.setInterpolator(new DecelerateInterpolator());
			mainFL.startAnimation(rotation);
		}
	}

 
这里的关键是点击之后的第一次翻转是0--90度,然后调用swap进行第二次翻转,apidemos里面的是90-180度,但是这样就会导致布局是反的,于是要改成270-360度,这样就ok了。如果是翻回去,那么就是在点击之后是360-270度,这样就成功了。大家可以试试。

 

分享到:
评论

相关推荐

    Android studio 实现图片翻转

    6. **布局设计**:在实现翻转效果时,通常会使用`FrameLayout`或`RelativeLayout`来承载翻转的图片,确保翻转过程中其他元素不受影响。 7. **触摸事件处理**:为了响应用户的翻转操作,需要在Activity或Fragment中...

    Android代码-双面翻转 View 效果

    "Android代码-双面翻转 View 效果"是一个示例项目,它展示了如何在Android应用中实现一个视图(View)的翻转动画,通常用于卡片式界面或者切换界面元素时,给人一种平滑且引人入胜的视觉体验。这个项目名为"Flip...

    android 控件翻转切换布局(转)

    在Android开发中,实现控件翻转切换布局是一种常见的交互设计,可以为用户带来独特的视觉体验。这种效果常用于卡片式界面、轮播图或图片查看器等场景。标题“android 控件翻转切换布局(转)”暗示我们将讨论如何在...

    android 控件翻转切换布局

    在Android开发中,控件的翻转切换布局是一种常见的交互设计,可以为用户带来独特的视觉体验。本主题将深入探讨如何实现这样的效果,主要涉及的知识点包括自定义View、动画处理以及布局管理。 首先,我们要了解...

    android自定义的翻转textview

    在Android开发中,自定义视图是提升用户体验和实现独特设计的重要手段。本文将深入探讨如何创建一个自定义的翻转TextView,名为AnimTextView,它能实现文本的动态翻转效果,为用户界面增添生动性。 首先,让我们...

    android 两个activity 翻转动画切换

    在Android开发中,Activity之间的切换可以通过自定义动画来实现更加丰富的视觉效果,比如翻转动画。这不仅可以提高用户的交互体验,还能为应用增添独特的风格。本文将深入探讨如何实现两个Activity之间的翻转动画...

    android图片翻转动画

    在布局文件中,为ImageView添加`android:translationZ`属性,设置一个非零值,例如`android:translationZ="4dp"`,这样可以使图片在翻转时产生深度感。 此外,如果想要更复杂的翻转效果,例如在不同的轴线上翻转或...

    Android实现3D翻转动画

    在Android开发中,为了增强用户体验,常常会使用各种动画效果,其中3D翻转动画是一种常见且引人注目的交互方式。本节我们将深入探讨如何在Android中实现3D翻转动画,以及如何将其实现封装成一个可复用的类。 首先,...

    Android 翻转动画 ,像硬币一样的翻转动画

    总结起来,实现Android中的硬币翻转动画,需要创建补间动画XML文件,定义翻转前后状态,然后在代码中加载动画并设置监听器来控制动画的循环播放。同时,添加点击事件监听器可以进一步定制交互行为,为用户提供更丰富...

    Android 利用Camera实现中轴3D卡牌翻转效果

    Camera类在Android中主要用于控制设备的摄像头,它可以捕获图片、录制视频,但在这个特定的效果中,我们并不实际使用摄像头拍摄图像,而是利用Camera的旋转和平移功能来创建一种3D视觉效果。 要实现3D卡牌翻转,...

    android实现2D图片翻转

    在Android平台上,实现2D图片翻转是一种常见的动画效果,可以增强用户界面的交互性和视觉吸引力。本教程将深入探讨如何使用Android的普通动画(Property Animation)系统来创建这种效果,特别是关注`ScaleAnimation`...

    android 3d翻转View

    在Android开发中,3D翻转效果是一种常见的动画效果,常用于界面切换或者元素展示,为用户带来更生动、更具视觉吸引力的交互体验。这里我们主要探讨如何实现一个基于Android的3D翻转View。 首先,3D翻转是通过...

    css3产品展示卡片布局翻转特效

    在本案例中,我们关注的是“css3产品展示卡片布局翻转特效”。这个特效是为在线产品展示设计的,特别是适用于云服务器等技术产品的介绍。它通过卡片布局吸引用户的注意力,并在鼠标悬停时实现卡片的翻转效果,以揭示...

    android中图片翻转Demo

    如果需要在内存中对图片进行翻转,可以先将`Bitmap`从`ImageView`获取,然后创建一个新的`Matrix`,执行翻转操作,最后再将翻转后的`Bitmap`设置回`ImageView`。这种方式适用于需要在不显示的情况下处理图片的情况...

    android图片翻转效果

    android卡片翻转效果,使用view的draw方法直接绘制,节省性能,如果放到liestview或者recycleview中的话,请自行稍加修改,不要使用bitmap来做存储即可,本想0分,但是目前至少要选1分,没法办

    android 自适应屏幕翻转

    1. **在`AndroidManifest.xml`中设置`configChanges`属性**:通过添加`configChanges="orientation|keyboardHidden"`属性,可以告诉Android系统,该Activity可以处理配置变化而不重启,从而避免`onCreate()`的重复...

    安卓使用kotlin语言实现布局翻转效果

    通过查看和学习这些代码,你可以更直观地理解如何在Android应用中集成Kotlin翻转动画。 总之,通过使用Kotlin和Android的动画系统,我们可以轻松地实现布局的翻转效果,为用户带来更加生动和交互式的体验。不断探索...

    Android代码-Android 横向翻转效果,支持双面的 View 场景

    总之,`EasyFlipView`是一个强大的工具,帮助开发者在Android应用中实现具有吸引力的横向翻转效果,为用户带来生动的双面内容展示。通过深入理解其工作原理和灵活运用,可以将这一特性融入到各种创新的UI设计中,...

    Android 翻转手机即换静音或震动

    【Android 翻转手机即换静音或震动】是一个基于Android平台的应用程序,它允许用户通过简单地翻转他们的设备来切换手机的铃声模式,例如从响铃切换到振动或者静音模式。这个应用可能包含以下核心知识点: 1. **...

    Android点击翻转控件.zip

    在Android开发中,点击翻转控件是一种常见的交互设计,它可以为用户提供新颖的视觉效果,增强用户界面的吸引力。这个“Android点击翻转控件”项目提供了一个实现此类功能的源码实例,可以帮助开发者深入理解如何在...

Global site tag (gtag.js) - Google Analytics