《步驟化》 做個簡單的引導頁和啓動頁

                                                                                                      前言
   網絡上有許多優秀的'引導頁'教程,內容或者主要代碼都大同小異,唯有的區別就是每個人的想法不同,今天我參照網絡部分方法,寫個比較簡單的'歡迎頁'教程與大家一起學習,如果有需要的,可以跟着我的步驟,一步一步做出自己的引導頁,註釋已經很清楚了,不懂可以留言討論。
   編譯工具:android Studio 3.5
   所需資源:兩張格式爲1080*1920大小的不同圖案的圖片,並命名*a.jpg*,*b.jpg*;
   步驟開始:
   1.新建一個項目,並把準備好的兩張圖片*a.jpg*,*b.jpg*放到*app\src\main\res\drawable-v24*下。
   2.在項目的*app\src\main\java*下新建  *A.java,B.java,MainActivity2.java* 
      在項目的*app\src\main\res\layout*下新建頁面  *a.xml(引導頁),b.xml(啓動頁),activity_main2.xml(副頁面)*

在這裏插入圖片描述
3.打開a.xml (引導頁)並填充圖片a.jpg

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ImageView
        android:id="@+id/imageView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:scaleType="fitXY"
        //圖片全屏
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:srcCompat="@drawable/a"
        />
</androidx.constraintlayout.widget.ConstraintLayout>

打開A.java,並連接a.xml

package com.example.a201909271x;

import android.content.Intent;
import android.os.Bundle;

import androidx.appcompat.app.AppCompatActivity;

public class A extends AppCompatActivity {
    private final int SPLASH_DISPLAY_LENGHT=5000;
    //  在引導頁等待5秒,而後進入主頁面,時間可自行調整
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.a);
        new android.os.Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                //時間一到,用Intent跳轉方式將引導頁轉入主頁面MainActivity,
                Intent intent=new Intent(A.this,MainActivity.class);
                startActivity(intent);
                finish();
            }
        },SPLASH_DISPLAY_LENGHT);
    }
}

打開b.xml(啓動頁)並填充圖片b.jpg

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:scaleType="fitXY"
        //圖片全屏
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:srcCompat="@drawable/b"
        />
</androidx.constraintlayout.widget.ConstraintLayout>

打開B.java並連接b.xml

package com.example.a201909271x;
import android.content.Intent;
import android.os.Bundle;
import androidx.appcompat.app.AppCompatActivity;

public class B extends AppCompatActivity {
    private final int SPLASH_DISPLAY_LENGHT=10000;
    //與引導頁設定一樣,在啓動頁等待10秒,而後進入主頁面
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.b);

        new android.os.Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                //同理,時間一到,用Intent跳轉方式將啓動頁轉入主頁面MainActivity,
                Intent intent=new Intent(B.this,MainActivity.class);
                startActivity(intent);
                finish();
            }
        },SPLASH_DISPLAY_LENGHT);
    }
}

打開MainActivity2連接activity_main2,判斷是否第一次進入應用,並通過Intent方式跳轉

package com.example.a201909271x;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import androidx.appcompat.app.AppCompatActivity;
public class MainActivity2 extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);

        //先判斷是不是第一次啓動,如果是,則進入引導頁(歡迎頁);如果不是,則進入啓動頁;
        firstRun();
    }
    private void firstRun(){
        SharedPreferences sharedPreferences=getSharedPreferences("FirstRun",0);
        Boolean first_run=sharedPreferences.getBoolean("First",true);
        if(first_run){
            sharedPreferences.edit().putBoolean("First",false).commit();
            //判斷結束後,利用Intent跳轉方式進入引導頁或者啓動頁
            Intent intent=new Intent(MainActivity2.this,A.class);
            startActivity(intent);
            finish();
        }
        else {
            Intent intent=new Intent(MainActivity2.this,B.class);
            startActivity(intent);
            finish();
        }
    }
}

最後在mainfests下設置,重重之中的步驟

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.a201909271x">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity2">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".A"></activity>
        <activity android:name=".B"></activity>
        <activity android:name=".MainActivity"></activity>
    </application>

</manifest>

結語:整體的步驟就是這樣,值得注意activit_main2是副頁面,主要用來個頁面跳轉使用的,無需做其他所用

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章