亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android啟動頁設(shè)置及動態(tài)權(quán)限跳轉(zhuǎn)問題解決

 更新時間:2022年04月18日 08:50:55   作者:zstar-_  
在我遇到這個實際問題之前,我一直認(rèn)為啟動頁的作用是美化產(chǎn)品,提升軟件逼格。但實際上,它更重要的是起到了一個攔截器的作用,這篇文章主要介紹了Android啟動頁設(shè)置以及動態(tài)權(quán)限跳轉(zhuǎn),需要的朋友可以參考下

啟動頁的作用

在我遇到這個實際問題之前,我一直認(rèn)為啟動頁的作用是美化產(chǎn)品,提升軟件逼格。但實際上,它更重要的是起到了一個攔截器的作用。比如,當(dāng)App首頁需要動態(tài)得從網(wǎng)上加載數(shù)據(jù)時,就必須請求網(wǎng)絡(luò)權(quán)限,如果沒有啟動頁,用戶將直接看到一堆空數(shù)據(jù)。因此,啟動頁主要有兩個作用:1、攔截用戶訪問,只有用戶授予必要的權(quán)限才準(zhǔn)入;2、為主頁動態(tài)數(shù)據(jù)加載爭取時間。

啟動頁跳轉(zhuǎn)

在提權(quán)限之前,首先把啟動頁延時跳轉(zhuǎn)解決。通過下面的代碼,可以實現(xiàn)延遲2秒鐘跳轉(zhuǎn)。

new android.os.Handler().postDelayed(new Runnable() {
         @Override
         public void run() {
             Intent mainIntent = new Intent(Splash.this,MainActivity.class);
             Splash.this.startActivity(mainIntent);
             Splash.this.finish();
         }
     },2000);

另外注意把啟動頁的這個Activity在Manifests中設(shè)置成默認(rèn)啟動頁面。

<activity android:name=".Splash"
    android:theme="@style/ThemeSplash">
    <intent-filter>
        <action android:name="android.intent.action.MAIN" />
        <category android:name="android.intent.category.LAUNCHER" />
    </intent-filter>
</activity>

啟動頁的xml使用默認(rèn)的頁面即可,這里通過引入主題的方式來設(shè)置啟動頁無標(biāo)題欄,并更換底圖。
在styles中添加:

<style name="ThemeSplash" parent="Theme.AppCompat.Light.NoActionBar">
        <!--<item name="android:background">@mipmap/ic_launcher</item>-->
        <item name="android:windowBackground">@drawable/qidong</item>
        <item name="android:windowNoTitle">true</item>
        <item name="android:windowFullscreen">true</item>
        <item name="windowActionBar">false</item>
        <item name="windowNoTitle">true</item>
    </style>

動態(tài)權(quán)限獲取

首先在Manifests中配置需要的權(quán)限。

 <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <!-- 這個權(quán)限用于訪問GPS定位 -->
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <!-- 用于訪問wifi網(wǎng)絡(luò)信息,wifi信息會用于進行網(wǎng)絡(luò)定位 -->
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <!-- 獲取運營商信息,用于支持提供運營商信息相關(guān)的接口 -->
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <!-- 這個權(quán)限用于獲取wifi的獲取權(quán)限,wifi信息會用來進行網(wǎng)絡(luò)定位 -->
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /> <!-- 寫入擴展存儲,向擴展卡寫入數(shù)據(jù),用于寫入離線定位數(shù)據(jù) -->
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <!-- 訪問網(wǎng)絡(luò),網(wǎng)絡(luò)定位需要上網(wǎng) -->
    <uses-permission android:name="android.permission.INTERNET" />

然后在啟動頁的Java文件中,創(chuàng)建權(quán)限列表:

 String[] permissions = new String[]{
            Manifest.permission.ACCESS_COARSE_LOCATION, // GPS定位權(quán)限
            Manifest.permission.ACCESS_FINE_LOCATION,  // 訪問wifi網(wǎng)絡(luò)權(quán)限
            Manifest.permission.ACCESS_WIFI_STATE,    // 獲取運營商權(quán)限
            Manifest.permission.ACCESS_NETWORK_STATE,    // 獲取wifi定位權(quán)限
            Manifest.permission.CHANGE_WIFI_STATE,      // 存儲權(quán)限
            Manifest.permission.WRITE_EXTERNAL_STORAGE,    // 訪問網(wǎng)絡(luò)權(quán)限
            Manifest.permission.INTERNET        // 網(wǎng)絡(luò)權(quán)限
    };

設(shè)定一個函數(shù)檢查權(quán)限,全部通過才放行(這個條件可根據(jù)實際情況修改)

private void checkPermissions(){
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            int q1 = ContextCompat.checkSelfPermission(getContext(), permissions[0]);
            int q2 = ContextCompat.checkSelfPermission(getContext(), permissions[1]);
            int q3 = ContextCompat.checkSelfPermission(getContext(), permissions[2]);
            int q4 = ContextCompat.checkSelfPermission(getContext(), permissions[3]);
            int q5 = ContextCompat.checkSelfPermission(getContext(), permissions[4]);
            int q6 = ContextCompat.checkSelfPermission(getContext(), permissions[5]);
            int q7 = ContextCompat.checkSelfPermission(getContext(), permissions[6]);
            // 權(quán)限是否已經(jīng)授權(quán) GRANTED---授權(quán)  DINIED---拒絕
            if (q1 != PackageManager.PERMISSION_GRANTED ||
                    q2 != PackageManager.PERMISSION_GRANTED ||
                    q3 != PackageManager.PERMISSION_GRANTED ||
                    q4 != PackageManager.PERMISSION_GRANTED ||
                    q5 != PackageManager.PERMISSION_GRANTED ||
                    q6 != PackageManager.PERMISSION_GRANTED ||
                    q7 != PackageManager.PERMISSION_GRANTED) {
                // 如果沒有授予該權(quán)限,就去提示用戶請求
                startRequestPermission();
            }
            else{
                //獲取權(quán)限成功,跳轉(zhuǎn)
                new android.os.Handler().postDelayed(new Runnable() {
                    @Override
                    public void run() {
                        Intent mainIntent = new Intent(Splash.this,MainActivity.class);
                        Splash.this.startActivity(mainIntent);
                        Splash.this.finish();
                    }
                },2000);
            }
        }
    }

如果用戶點擊拒絕,則引導(dǎo)用戶進行權(quán)限請求。

 private void startRequestPermission() {
        ActivityCompat.requestPermissions(this, permissions, 321);
    }
@Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if (requestCode == 321) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                if (grantResults[0] != PackageManager.PERMISSION_GRANTED) {
                    //如果沒有獲取權(quán)限,那么可以提示用戶去設(shè)置界面--->應(yīng)用權(quán)限開啟權(quán)限
                    Toast toast = Toast.makeText(this, "請到設(shè)置界面授予權(quán)限再啟動", Toast.LENGTH_LONG);
                    toast.setGravity(Gravity.CENTER, 0, 0);
                    toast.show();
                } else {
                    //獲取權(quán)限成功,跳轉(zhuǎn)
                    new android.os.Handler().postDelayed(new Runnable() {
                        @Override
                        public void run() {
                            Intent mainIntent = new Intent(Splash.this,MainActivity.class);
                            Splash.this.startActivity(mainIntent);
                            Splash.this.finish();
                        }
                    },2000);
                }
            }
        }
    }

完整啟動頁控制程序

Splash.java

package com.baidu.location.demo;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
import android.Manifest;
import android.content.pm.PackageManager;
import android.os.Build;
import android.os.Bundle;
import android.content.Intent;
import android.view.Gravity;
import android.widget.Toast;
import static com.baidu.mapapi.BMapManager.getContext;
public class Splash extends AppCompatActivity {
    String[] permissions = new String[]{
            Manifest.permission.ACCESS_COARSE_LOCATION, // GPS定位權(quán)限
            Manifest.permission.ACCESS_FINE_LOCATION,  // 訪問wifi網(wǎng)絡(luò)權(quán)限
            Manifest.permission.ACCESS_WIFI_STATE,    // 獲取運營商權(quán)限
            Manifest.permission.ACCESS_NETWORK_STATE,    // 獲取wifi定位權(quán)限
            Manifest.permission.CHANGE_WIFI_STATE,      // 存儲權(quán)限
            Manifest.permission.WRITE_EXTERNAL_STORAGE,    // 訪問網(wǎng)絡(luò)權(quán)限
            Manifest.permission.INTERNET        // 網(wǎng)絡(luò)權(quán)限
    };
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_splash);
        checkPermissions();
    }
    private void checkPermissions(){
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            int q1 = ContextCompat.checkSelfPermission(getContext(), permissions[0]);
            int q2 = ContextCompat.checkSelfPermission(getContext(), permissions[1]);
            int q3 = ContextCompat.checkSelfPermission(getContext(), permissions[2]);
            int q4 = ContextCompat.checkSelfPermission(getContext(), permissions[3]);
            int q5 = ContextCompat.checkSelfPermission(getContext(), permissions[4]);
            int q6 = ContextCompat.checkSelfPermission(getContext(), permissions[5]);
            int q7 = ContextCompat.checkSelfPermission(getContext(), permissions[6]);
            // 權(quán)限是否已經(jīng)授權(quán) GRANTED---授權(quán)  DINIED---拒絕
            if (q1 != PackageManager.PERMISSION_GRANTED ||
                    q2 != PackageManager.PERMISSION_GRANTED ||
                    q3 != PackageManager.PERMISSION_GRANTED ||
                    q4 != PackageManager.PERMISSION_GRANTED ||
                    q5 != PackageManager.PERMISSION_GRANTED ||
                    q6 != PackageManager.PERMISSION_GRANTED ||
                    q7 != PackageManager.PERMISSION_GRANTED) {
                // 如果沒有授予該權(quán)限,就去提示用戶請求
                startRequestPermission();
            }
            else{
                //獲取權(quán)限成功,跳轉(zhuǎn)
                new android.os.Handler().postDelayed(new Runnable() {
                    @Override
                    public void run() {
                        Intent mainIntent = new Intent(Splash.this,MainActivity.class);
                        Splash.this.startActivity(mainIntent);
                        Splash.this.finish();
                    }
                },2000);
            }
        }
    }
    private void startRequestPermission() {
        ActivityCompat.requestPermissions(this, permissions, 321);
    }
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if (requestCode == 321) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                if (grantResults[0] != PackageManager.PERMISSION_GRANTED) {
                    //如果沒有獲取權(quán)限,那么可以提示用戶去設(shè)置界面--->應(yīng)用權(quán)限開啟權(quán)限
                    Toast toast = Toast.makeText(this, "請到設(shè)置界面授予權(quán)限再啟動", Toast.LENGTH_LONG);
                    toast.setGravity(Gravity.CENTER, 0, 0);
                    toast.show();
                } else {
                    //獲取權(quán)限成功,跳轉(zhuǎn)
                    new android.os.Handler().postDelayed(new Runnable() {
                        @Override
                        public void run() {
                            Intent mainIntent = new Intent(Splash.this,MainActivity.class);
                            Splash.this.startActivity(mainIntent);
                            Splash.this.finish();
                        }
                    },2000);
                }
            }
        }
    }
}

到此這篇關(guān)于Android:啟動頁設(shè)置以及動態(tài)權(quán)限跳轉(zhuǎn)的文章就介紹到這了,更多相關(guān)android啟動頁動態(tài)權(quán)限跳轉(zhuǎn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Android App中使用LinearLayout進行居中布局的實例講解

    Android App中使用LinearLayout進行居中布局的實例講解

    這篇文章主要介紹了Android App中使用LinearLayout進行居中布局的實例講解,文中分別介紹了水平居中和垂直居中的相關(guān)線性布局,需要的朋友可以參考下
    2016-04-04
  • Android 文件數(shù)據(jù)存儲實例詳解

    Android 文件數(shù)據(jù)存儲實例詳解

    這篇文章主要介紹了Android 文件數(shù)據(jù)存儲實例詳解的相關(guān)資料,這里附有實例代碼,幫助大家學(xué)習(xí)理解,需要的朋友可以參考下
    2016-12-12
  • Android RecyclerView實現(xiàn)滑動刪除

    Android RecyclerView實現(xiàn)滑動刪除

    這篇文章主要為大家詳細(xì)介紹了Android RecyclerView實現(xiàn)滑動刪除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • Android?Flutter實現(xiàn)頁面切換轉(zhuǎn)場動畫效果

    Android?Flutter實現(xiàn)頁面切換轉(zhuǎn)場動畫效果

    Hero組件非常適合從列表、概覽頁切換到詳情頁轉(zhuǎn)場動畫場合。本文將利用Hero組件制作一個簡單的頁面切換轉(zhuǎn)場動畫效果,感興趣的可以了解一下
    2022-06-06
  • android使用RxJava實現(xiàn)預(yù)加載

    android使用RxJava實現(xiàn)預(yù)加載

    這篇文章主要為大家詳細(xì)介紹了android使用RxJava實現(xiàn)預(yù)加載的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • Flutter 快速實現(xiàn)聊天會話列表效果示例詳解

    Flutter 快速實現(xiàn)聊天會話列表效果示例詳解

    這篇文章主要為大家介紹了Flutter 快速實現(xiàn)聊天會話列表效果示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • Android編程之軟件的安裝和卸載方法

    Android編程之軟件的安裝和卸載方法

    這篇文章主要介紹了Android編程之軟件的安裝和卸載方法,涉及Android編程實現(xiàn)軟件的安裝、權(quán)限修改及卸載的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-12-12
  • 詳解Android中Notification的使用方法

    詳解Android中Notification的使用方法

    這篇文章主要介紹了Android中Notification的使用方法,最典型的應(yīng)用就是未看短信和未接來電的顯示,還有QQ微信,想要深入了解Notification的朋友可以參考本文
    2015-12-12
  • 百度語音識別(Baidu Voice) Android studio版本詳解

    百度語音識別(Baidu Voice) Android studio版本詳解

    這篇文章主要介紹了百度語音識別(Baidu Voice) Android studio版本詳解的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • Android編程實現(xiàn)開始及停止service的方法

    Android編程實現(xiàn)開始及停止service的方法

    這篇文章主要介紹了Android編程實現(xiàn)開始及停止service的方法,涉及Android針對service的開始、停止、綁定等操作相關(guān)技巧與注意事項,需要的朋友可以參考下
    2016-01-01

最新評論