您好,登錄后才能下訂單哦!
這篇文章給大家介紹Android 應用中怎么獲取判斷處理權限,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
主要用到的幾個方法:
//檢查權限 int checkSelfPermission(String) //申請權限 void requestPermissions(int, String...) //是否應該顯示請求權限的說明 boolean shouldShowRequestPermissionRationale(String) //處理權限結果回調(diào) void onRequestPermissionsResult(int,String[],int[])
是否有權限常量標識:
PackageManager.PERMISSION_DENIED:拒絕了。 PackageManager.PERMISSION_GRANTED:授權了
上述四個方法中,前三個方法在support-v4的ActivityCompat中都有,建議使用兼容庫中的方法。最后一個方法是用戶授權或者拒絕某個權限組時系統(tǒng)會回調(diào)Activity或者Fragment中的方法。
1. checkSelfPermission(String)
檢查權限
1. 檢查某一個權限的當前狀態(tài),你應該在請求某個權限時檢查這個權限是否已經(jīng)被用戶授權,已經(jīng)授權的權限重復申請可能會讓用戶產(chǎn)生厭煩。
2. 該方法有一個參數(shù)是權限名稱,有一個int的返回值,用這個值與上面提到的兩個常量做比較可判斷檢查的權限當前的狀態(tài)。
if (ContextCompat.checkSelfPermission(context, Manifest.permission.READ_CONTACTS) != PackageManager.PERMISSION_GRANTED) { // 沒有權限,可以在這里重新申請權限。 }else{ // 有權限了。 }
2. requestPermissions(int, String…)
申請權限
請求用戶授權幾個權限,調(diào)用后系統(tǒng)會顯示一個請求用戶授權的提示對話框,App不能配置和修改這個對話框,如果需要提示用戶這個權限相關的信息或說明,需要在調(diào)用 requestPermissions() 之前處理
該方法有兩個參數(shù):
int requestCode: 會在回調(diào)onRequestPermissionsResult()時返回,用來判斷是哪個授權申請的回調(diào)。
String[] permissions: 權限數(shù)組,你需要申請的的權限的數(shù)組。
由于該方法是異步的,所以無返回值,當用戶處理完授權操作時,會回調(diào)Activity或者Fragment的onRequestPermissionsResult()方法。
ActivityCompat.requestPermissions(activity, new String[]{Manifest.permission.READ_CONTACTS}, MMM);
3. onRequestPermissionsResult(int,String[],int[])
處理權限結果回調(diào)
1. 該方法在Activity/Fragment中應該被重寫,當用戶處理完授權操作時,系統(tǒng)會自動回調(diào)該方法
2. 該方法有三個參數(shù):
int requestCode: 在調(diào)用requestPermissions()時的第一個參數(shù)。
String[] permissions: 權限數(shù)組,在調(diào)用requestPermissions()時的第二個參數(shù)。
int[] grantResults: 授權結果數(shù)組,對應permissions,具體值和上方提到的PackageManager中的兩個常量做比較。
@Override public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) { switch (requestCode) { case MMM: { if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { // 權限被用戶同意,可以做你要做的事情了。 } else { // 權限被用戶拒絕了,可以提示用戶,關閉界面等等。 } return; } } }
4. shouldShowRequestPermissionRationale(String)
是否應該顯示請求權限的說
1.第一次請求權限時,用戶拒絕了,調(diào)用shouldShowRequestPermissionRationale()后返回true,應該顯示一些為什么需要這個權限的說明。
2.用戶在第一次拒絕某個權限后,下次再次申請時,授權的dialog中將會出現(xiàn)“不再提醒”選項,一旦選中勾選了,那么下次申請將不會提示用戶。
3.第二次請求權限時,用戶拒絕了,并選擇了“不在提醒”的選項,調(diào)用shouldShowRequestPermissionRationale()后返回false。
4.設備的策略禁止當前應用獲取這個權限的授權:shouldShowRequestPermissionRationale()返回false 。
5.加這個提醒的好處在于,用戶拒絕過一次權限后我們再次申請時可以提醒該權限的重要性,面得再次申請時用戶勾選“不再提醒”并決絕,導致下次申請權限直接失敗。
if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_CONTACTS) != PackageManager.PERMISSION_GRANTED) {// 沒有權限。 if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.READ_CONTACTS)) { // 用戶拒絕過這個權限了,應該提示用戶,為什么需要這個權限。 } else { // 申請授權。 ActivityCompat.requestPermissions(thisActivity, new String[]{Manifest.permission.READ_CONTACTS}, MMM); } } ... @Override public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) { switch (requestCode) { case MMM: { if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { // 權限被用戶同意。 } else { // 權限被用戶拒絕了。 } return; } } }
關于Android 應用中怎么獲取判斷處理權限就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。