继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Android中的Activity跳转动画效果梳理

明月笑刀无情
关注TA
已关注
手记 104
粉丝 16
获赞 56

Activity跳转不是生硬的跳转,其实它是可以产生动画的,本文讲的就是Activity跳转的时候产生的动画:

先给大家看下效果图:

5bb8d3670001db1e10801920.jpg5bb8d36800015da910801920.jpg5bb8d36a0001191c10801920.jpg5bb8d36b0001e70410801920.jpg5bb8d36b0001e70410801920.jpg

用overridePendingtransition(int inId, int outId)即可实现。inId是下一界面进入效果的xml文件的id,outId是当前界面退出效果的xml文件id

效果是用xml文件写的,首先要在res文件夹下建立anim文件夹,然后把动画效果xml文件放到里面去。 
下面是放大进入,缩小退出的xml文件:

<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android"

    android:interpolator="@android:anim/decelerate_interpolator">

    

      <alpha

        android:duration="2000"

        android:fromAlpha="0"

        android:toAlpha="1.0" />


    <scale

        android:duration="2000"

        android:fromXScale="2.0"

        android:fromYScale="2.0"

        android:pivotX="50%p"

        android:pivotY="50%p"

        android:toXScale="1.0"

        android:toYScale="1.0" />


</set>


<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android"

    android:interpolator="@android:anim/decelerate_interpolator"

    android:zAdjustment="top" >


    <scale

        android:duration="2000"

        android:fromXScale="1.0"

        android:fromYScale="1.0"

        android:pivotX="0"

        android:pivotY="0"

        android:toXScale="0"

        android:toYScale="0" />


    <alpha

        android:duration="2000"

        android:fromAlpha="1.0"

        android:toAlpha="0" />


</set>

上面是写在anim文件夹下的两个.xml

代码如下:

package com.hanwei.animation;


import android.app.Activity;

import android.content.Intent;

import android.os.Bundle;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;


public class MainActivity extends Activity {


@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

Button mButton = (Button) findViewById(R.id.btn);

mButton.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

// TODO Auto-generated method stub

Intent intent = new Intent(MainActivity.this, SecondActivity.class);

startActivity(intent);

switch (v.getId()) {

case R.id.btn://左上角缩小效果

overridePendingTransition(R.anim.one_narrow,

R.anim.second_narrow);//这是重点

break;


}

}

});

}

}

我只是以左上角渐变为例,其实还有很多效果,具体需要什么效果,还得自己去设计!

原文链接:http://www.apkbus.com/blog-784586-61373.html

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP