package com.xiaoma.betweenactivityanimation; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; /** * @Title: BetweenActivityAnimationDemoActivity.java * @Package com.xiaoma.betweenactivityanimation * @Description: Activity之间跳转动画学习 如果怕动画太短看不清楚的, 可以把动画XML文件里面标签属性 during值设置的长些,吼吼 * @author XiaoMa */ public class BetweenActivityAnimationDemoActivity extends Activity implements OnClickListener { /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); init(); } private void init() { findViewById(R.id.button1).setOnClickListener(this); } @Override public void onClick(View v) { if (v.getId() == R.id.button1) { Intent intent = new Intent(getApplicationContext(), BetweenActivityAnimationDemoActivity2.class); startActivity(intent); /** * 对下面这个方法的官方解释如下,版本从2.0后开始哦 Call immediately after one of the * flavors of startActivity(Intent) or finish() to specify an * explicit transition animation to perform next. 用工具查到解释为: * 在startActivity(Intent)或finish()之法之后调用后,会立即用一个指定的描述动画的XML文件来执行 * 下一个Activity * * 下面两句是对这个方法两个参数的解释,在此之前小马也看了下别人讲的, 其实是错的,看官方的解释肯定没错,不懂英语的用工具查下 * 小马一直都说的,我英语很烂,我能查的你一定也能查得到 1.enterAnim A resource ID of the * animation resource to use for the incoming activity. Use 0 for no * animation. 2.exitAnim A resource ID of the animation resource to * use for the outgoing activity. Use 0 for no animation. 一:进入动画 * 一个动画资源,用于目标Activity 进入屏幕时的动画,此处写0代表无动画 二:退出动画 一个动画资源,用于当前Activity * 退出屏幕时的动画,此处写0代表无动画 * * 这个目标、当前怎么理解?比如:startActivity( A(当前)--> B(目标)) 《finish()一样》 * 下面参数中有一个为0,就表示A退出时无动画...一定把参数搞清楚,不然动画就搞晕了 * overridePendingTransition(R.anim.zoom_enter, 0); * 方法两个参数与目标、当前Activity对应关系如效果下方绿色图所示 */ overridePendingTransition(R.anim.zoom_enter, R.anim.zoom_exit); } } /** * 列几个安卓自带的动画效果,大家可以把上面 overridePendingTransition参数改下看看效果 实现淡入淡出的效果 * overridePendingTransition * (android.R.anim.fade_in,android.R.anim.fade_out); * overridePendingTransition * (android.R.anim.fade_in,android.R.anim.fade_out); * * 由左向右滑入的效果 * overridePendingTransition(android.R.anim.slide_in_left,android.R * .anim.slide_out_right); * overridePendingTransition(android.R.anim.slide_in_left * ,android.R.anim.slide_out_right); */ }