Android之anim跳轉動畫

Android中原生的界面跳轉看起來會很生硬,可以自定義切換動畫來更改界面跳轉的效果,
讓用戶有一種耳目一新的感覺。使用這種切換動畫可以設置Activity的移動、旋轉、縮放以及透明度的變化效果。
這裏會用到overridePendingTransition(int enterAnim, int exitAnim)這個方法,
該方法用於設置Activity界面切換時的動畫。
enterAnim表示另一個Acitivty進入時的動畫,exitAnim表示當前Activity退出時的動畫,需要創建兩個xml 文件來設定進入和退出的動畫效果。
步驟:
在res目錄下創建一個anim的文件夾(anim名字不要更改)
這裏寫圖片描述
然後在該目錄下創建xml文件
這裏寫圖片描述
這裏寫圖片描述
這裏寫圖片描述
這裏寫圖片描述

此時已經創建好了兩個anim xml文件
alpha(漸變動畫)動畫類型的常用動畫參數:
android:fromAlpha:起始透明度
android:toAlpha:結束透明度
1.0表示完全不透明 0.0表示完全透明
android:duration:播放時間 以毫秒爲單位
translate(平移動畫)常用動畫參數:
android:fromXDelta:動畫起始位置的橫座標
android:toXDelta:動畫起結束位置的橫座標
android:fromYDelta:動畫起始位置的縱座標
android:toYDelta:動畫結束位置的縱座標
android:duration:動畫的持續時間
其他不在贅述
然後新建兩個Activity分別爲 MainActivity和SecondActiviy,
兩個佈局文件activity_main.xml和activity_second.xml執行跳轉動畫
代碼如下:
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" 

    android:background="#f00">

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:text="跳轉" />

</RelativeLayout>

activity_second.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" 

    android:background="#0f0">

</RelativeLayout>

MainActivity.class

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 {
    Button btn;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btn=(Button) findViewById(R.id.button1);
        //設置監聽事件
        btn.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                //設置意圖
                Intent intent=new Intent(MainActivity.this,SecondActivity.class);

                //頁面跳轉,注意記得在AndroidManifest.xml文件中註冊SecondActivity
                startActivity(intent);

                //執行跳轉動畫
                overridePendingTransition(R.anim.enteranim,R.anim.exitanim);
            }
        });
    }  
}

SecondActivity.class

import android.app.Activity;
import android.os.Bundle;

public class SecondActivity extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_second);
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章