網站首頁 編程語言 正文
啟動頁的作用
在我遇到這個實際問題之前,我一直認為啟動頁的作用是美化產品,提升軟件逼格。但實際上,它更重要的是起到了一個攔截器的作用。比如,當App首頁需要動態得從網上加載數據時,就必須請求網絡權限,如果沒有啟動頁,用戶將直接看到一堆空數據。因此,啟動頁主要有兩個作用:1、攔截用戶訪問,只有用戶授予必要的權限才準入;2、為主頁動態數據加載爭取時間。
啟動頁跳轉
在提權限之前,首先把啟動頁延時跳轉解決。通過下面的代碼,可以實現延遲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>
動態權限獲取
首先在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" /> <!-- 寫入擴展存儲,向擴展卡寫入數據,用于寫入離線定位數據 -->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <!-- 訪問網絡,網絡定位需要上網 -->
<uses-permission android:name="android.permission.INTERNET" />
然后在啟動頁的Java文件中,創建權限列表:
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 // 網絡權限
};
設定一個函數檢查權限,全部通過才放行(這個條件可根據實際情況修改)
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);
}
}
}
}
}
原文鏈接:https://blog.csdn.net/qq1198768105/article/details/124238656
相關推薦
- 2022-06-12 Centos系統搭建MongoDB數據庫_MongoDB
- 2023-06-20 在VScode里面添加Python解釋器的詳細步驟_python
- 2022-05-27 C++智能指針之shared_ptr詳解_C 語言
- 2023-02-07 Go?singleflight使用以及原理_Golang
- 2023-01-20 Python中用try-except-finally處理異常問題_python
- 2022-06-19 WPF項目在設計界面調用后臺代碼_實用技巧
- 2022-04-11 C++中為什么要使用動態內存_C 語言
- 2022-04-20 C語言函數棧幀的創建和銷毀詳解_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支