Android啟動頁設置及動態(tài)權限跳轉問題解決
啟動頁的作用
在我遇到這個實際問題之前,我一直認為啟動頁的作用是美化產品,提升軟件逼格。但實際上,它更重要的是起到了一個攔截器的作用。比如,當App首頁需要動態(tài)得從網上加載數(shù)據(jù)時,就必須請求網絡權限,如果沒有啟動頁,用戶將直接看到一堆空數(shù)據(jù)。因此,啟動頁主要有兩個作用:1、攔截用戶訪問,只有用戶授予必要的權限才準入;2、為主頁動態(tài)數(shù)據(jù)加載爭取時間。
啟動頁跳轉
在提權限之前,首先把啟動頁延時跳轉解決。通過下面的代碼,可以實現(xiàn)延遲2秒鐘跳轉。
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中設置成默認啟動頁面。
<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使用默認的頁面即可,這里通過引入主題的方式來設置啟動頁無標題欄,并更換底圖。
在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)權限獲取
首先在Manifests中配置需要的權限。
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <!-- 這個權限用于訪問GPS定位 --> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <!-- 用于訪問wifi網絡信息,wifi信息會用于進行網絡定位 --> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <!-- 獲取運營商信息,用于支持提供運營商信息相關的接口 --> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <!-- 這個權限用于獲取wifi的獲取權限,wifi信息會用來進行網絡定位 --> <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /> <!-- 寫入擴展存儲,向擴展卡寫入數(shù)據(jù),用于寫入離線定位數(shù)據(jù) --> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <!-- 訪問網絡,網絡定位需要上網 --> <uses-permission android:name="android.permission.INTERNET" />
然后在啟動頁的Java文件中,創(chuàng)建權限列表:
String[] permissions = new String[]{ Manifest.permission.ACCESS_COARSE_LOCATION, // GPS定位權限 Manifest.permission.ACCESS_FINE_LOCATION, // 訪問wifi網絡權限 Manifest.permission.ACCESS_WIFI_STATE, // 獲取運營商權限 Manifest.permission.ACCESS_NETWORK_STATE, // 獲取wifi定位權限 Manifest.permission.CHANGE_WIFI_STATE, // 存儲權限 Manifest.permission.WRITE_EXTERNAL_STORAGE, // 訪問網絡權限 Manifest.permission.INTERNET // 網絡權限 };
設定一個函數(shù)檢查權限,全部通過才放行(這個條件可根據(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]); // 權限是否已經授權 GRANTED---授權 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) { // 如果沒有授予該權限,就去提示用戶請求 startRequestPermission(); } else{ //獲取權限成功,跳轉 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) { //如果沒有獲取權限,那么可以提示用戶去設置界面--->應用權限開啟權限 Toast toast = Toast.makeText(this, "請到設置界面授予權限再啟動", Toast.LENGTH_LONG); toast.setGravity(Gravity.CENTER, 0, 0); toast.show(); } else { //獲取權限成功,跳轉 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定位權限 Manifest.permission.ACCESS_FINE_LOCATION, // 訪問wifi網絡權限 Manifest.permission.ACCESS_WIFI_STATE, // 獲取運營商權限 Manifest.permission.ACCESS_NETWORK_STATE, // 獲取wifi定位權限 Manifest.permission.CHANGE_WIFI_STATE, // 存儲權限 Manifest.permission.WRITE_EXTERNAL_STORAGE, // 訪問網絡權限 Manifest.permission.INTERNET // 網絡權限 }; @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]); // 權限是否已經授權 GRANTED---授權 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) { // 如果沒有授予該權限,就去提示用戶請求 startRequestPermission(); } else{ //獲取權限成功,跳轉 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) { //如果沒有獲取權限,那么可以提示用戶去設置界面--->應用權限開啟權限 Toast toast = Toast.makeText(this, "請到設置界面授予權限再啟動", Toast.LENGTH_LONG); toast.setGravity(Gravity.CENTER, 0, 0); toast.show(); } else { //獲取權限成功,跳轉 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); } } } } }
到此這篇關于Android:啟動頁設置以及動態(tài)權限跳轉的文章就介紹到這了,更多相關android啟動頁動態(tài)權限跳轉內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Android App中使用LinearLayout進行居中布局的實例講解
這篇文章主要介紹了Android App中使用LinearLayout進行居中布局的實例講解,文中分別介紹了水平居中和垂直居中的相關線性布局,需要的朋友可以參考下2016-04-04Android RecyclerView實現(xiàn)滑動刪除
這篇文章主要為大家詳細介紹了Android RecyclerView實現(xiàn)滑動刪除,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-07-07Android?Flutter實現(xiàn)頁面切換轉場動畫效果
Hero組件非常適合從列表、概覽頁切換到詳情頁轉場動畫場合。本文將利用Hero組件制作一個簡單的頁面切換轉場動畫效果,感興趣的可以了解一下2022-06-06Flutter 快速實現(xiàn)聊天會話列表效果示例詳解
這篇文章主要為大家介紹了Flutter 快速實現(xiàn)聊天會話列表效果示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10百度語音識別(Baidu Voice) Android studio版本詳解
這篇文章主要介紹了百度語音識別(Baidu Voice) Android studio版本詳解的相關資料,需要的朋友可以參考下2016-09-09Android編程實現(xiàn)開始及停止service的方法
這篇文章主要介紹了Android編程實現(xiàn)開始及停止service的方法,涉及Android針對service的開始、停止、綁定等操作相關技巧與注意事項,需要的朋友可以參考下2016-01-01