Android 如何實現(xiàn)動態(tài)申請權(quán)限
OverView
今天在復習的時候,突然復習到我們的相機操作,但是對于相機操作,對于我來說比較復雜的是對于權(quán)限的操作。所有我們需要對我們的相機操作進行一些筆記的整理,加深記憶。
開發(fā)環(huán)境
Android Studio 3.6
Android 11(R)
該筆記使用 java
權(quán)限申請的基礎知識
學習自:GOOGLE ANDROID DEVELOPERS
對于我們所需要申請的權(quán)限我們需要進行如下的操作。
我們需要將所有需要申請的權(quán)限添加到App/src/main/AndroidManifest.xml文件中。
但是權(quán)限也是分為常規(guī)的權(quán)限和危險的權(quán)限的,對于常規(guī)的權(quán)限我們的只需要在AndroidManifest.xml文件中添加就可以使用了,但是對于一些被視為危險權(quán)限的,我們就需要讓用戶來選擇時候同意申請。
接下來我們就看一下如何操作我們的危險權(quán)限吧。
如何判斷是否申請了權(quán)限
按照國際慣例我們先看一下源代碼:
private boolean checkPermission() { //first we need check this Drive has? CAMERA Permission if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.CAMERA}, CHECK_PERMISSION_CAMERA); return false; } else return true;}
這里我們使用我們的相機權(quán)限作為實例。
首先我們需要判斷我們的使用有相機權(quán)限,可以使用,申請完成后我們需要進行權(quán)限申請。我們將我們所需要的權(quán)限申請,并且傳入我們的指定代碼。這里我的CHECK_PERMISSION_CAMERA的值為1。
然后就是我們需要重寫我們的系統(tǒng)方法onRequestPermissionsResult
這個方法可以很好的來判斷用戶時候同意了我們的權(quán)限申請。
首先來看看我們的源代碼:
@Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); switch (requestCode) { case CHECK_PERMISSION_CAMERA: { if (grantResults.length > 0 && permissions[0].equals(PackageManager.PERMISSION_GRANTED)) {Toast.makeText(this, 'The camera permission application wes successful!', Toast.LENGTH_SHORT).show();dispatchTakePictureIntent(); } else {Toast.makeText(this, 'The camera permission application wes failed!', Toast.LENGTH_SHORT).show(); } } break; }}
這個就是我判斷用戶時候同意我們申請相機權(quán)限的全部代碼了。
這個也是非常的簡單,我們通過在申請的時候傳入的識別代碼來判斷,如果代碼通過后我們需要通過驗證grantResults的長度和權(quán)限數(shù)組中的索引位置來判斷用戶有沒有同意我們的權(quán)限申請。如果同意了我們就可以進行下一步操作。
這部分代碼還是非常的簡單的。關(guān)于動態(tài)權(quán)限的申請還是非常的簡單的。
以上這篇Android 如何實現(xiàn)動態(tài)申請權(quán)限就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向2. asp(vbs)Rs.Open和Conn.Execute的詳解和區(qū)別及&H0001的說明3. CSS hack用法案例詳解4. PHP設計模式中工廠模式深入詳解5. 用css截取字符的幾種方法詳解(css排版隱藏溢出文本)6. ASP+ajax實現(xiàn)頂一下、踩一下同支持與反對的實現(xiàn)代碼7. .NET中l(wèi)ambda表達式合并問題及解決方法8. ThinkPHP5實現(xiàn)JWT Token認證的過程(親測可用)9. asp中response.write("中文")或者js中文亂碼問題10. JSP數(shù)據(jù)交互實現(xiàn)過程解析
