【移動應用開發(fā)技術】Android中怎么在程序運行時申請權限_第1頁
【移動應用開發(fā)技術】Android中怎么在程序運行時申請權限_第2頁
【移動應用開發(fā)技術】Android中怎么在程序運行時申請權限_第3頁
【移動應用開發(fā)技術】Android中怎么在程序運行時申請權限_第4頁
【移動應用開發(fā)技術】Android中怎么在程序運行時申請權限_第5頁
已閱讀5頁,還剩5頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

【移動應用開發(fā)技術】Android中怎么在程序運行時申請權限

這篇文章給大家介紹Android中怎么在程序運行時申請權限,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。這里我們以撥打電話申請權限來寫個小例子,也就是CALL_PHONE,因為撥打電話會涉及用戶手機的資費問題,因而被列為了危險權限,在Android6.0系統(tǒng)出現(xiàn)之前,撥打電話功能的實現(xiàn)其實非常簡單,修改activity_mainxml中的代碼,如下:<?xml

version="1.0"

encoding="utf-8"?>

<android.support.constraint.ConstraintLayout

xmlns:android="/apk/res/android"

xmlns:app="/apk/res-auto"

xmlns:tools="/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context="com.example.runtimepermissiontest.MainActivity">

<Button

android:id="@+id/make_call"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="Make

Call"

android:textAllCaps="false"/>

</android.support.constraint.ConstraintLayout>我們在布局文件中只定義了一個按鈕,當點擊按鈕時就會去觸發(fā)撥打電話的邏輯,接著修改MainActivity中的代碼,如下:public

class

MainActivity

extends

AppCompatActivity

{

@Override

protected

void

onCreate(Bundle

savedInstanceState)

{

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

Button

makeCall

=

findViewById(R.id.make_call);

makeCall.setOnClickListener(new

View.OnClickListener()

{

@Override

public

void

onClick(View

view)

{

try

{

Intent

intent

=

new

Intent(Intent.ACTION_CALL);

intent.setData(Uri.parse("tel:10000"));

startActivity(intent);

}catch

(SecurityException

e){

e.printStackTrace();

}

}

});

}

}可以看到,在按鈕的點擊事件中,我們構建了一個隱式Intent,Intent的action指定為Intent.ACTION_CALL,這是一個系統(tǒng)內(nèi)置的打電話的動作,然后在data部分指定了協(xié)議是tel,號碼是10000,表示打開撥號界面,這個是不需要聲明權限的,而Intent.ACTION_CALL則可以直接撥打電話,因此必須申明權限,另外為了防止程序崩潰,我們將所有操作都放在了異常捕獲代碼塊當中。那么接下來修改AndroidManifest.xml文件,在其中聲明如下權限:<?xml

version="1.0"

encoding="utf-8"?>

<manifest

xmlns:android="/apk/res/android"

package="com.example.runtimepermissiontest">

<uses-permission

android:name="android.permission.CALL_PHONE"

/>

<application

android:allowBackup="true"

android:icon="@mipmap/ic_launcher"

android:label="@string/app_name"

android:roundIcon="@mipmap/ic_launcher_round"

android:supportsRtl="true"

android:theme="@style/AppTheme">

<activity

android:name=".MainActivity">

<intent-filter>

<action

android:name="ent.action.MAIN"

/>

<category

android:name="ent.category.LAUNCHER"

/>

</intent-filter>

</activity>

</application>

</manifest>這樣我們就將撥打電話的功能實現(xiàn)了,并且在低于Android6.0系統(tǒng)的手機上都是可以正常運行的,但是如果我們在6.0或者更高版本系統(tǒng)的手機上運行,點擊MakeCall按鈕就沒有任何效果,這時觀察logcat中的日志,會報如下錯誤:錯誤信息中提示我們PermissionDenial,可以看出,是由于權限被禁止所導致的,因為6.0及以上系統(tǒng)在使用危險權限時都必須進行運行時權限處理。那么下面我們就來嘗試修復這個問題,修改MainActivity中的代碼,如下:public

class

MainActivity

extends

AppCompatActivity

{

@Override

protected

void

onCreate(Bundle

savedInstanceState)

{

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

Button

makeCall

=

findViewById(R.id.make_call);

makeCall.setOnClickListener(new

View.OnClickListener()

{

@Override

public

void

onClick(View

view)

{

if

(ContextCompat.checkSelfPermission(MainActivity.this,

Manifest.permission.CALL_PHONE)

!=

PackageManager.PERMISSION_GRANTED){

ActivityCompat.requestPermissions(MainActivity.this,new

String[]{Manifest.permission.CALL_PHONE},1);

}else

{

call();

}

}

});

}

private

void

call(){

try

{

Intent

intent

=

new

Intent(Intent.ACTION_CALL);

intent.setData(Uri.parse("tel:10000"));

startActivity(intent);

}catch

(SecurityException

e){

e.printStackTrace();

}

}

@Override

public

void

onRequestPermissionsResult(int

requestCode,

@NonNull

String[]

permissions,

@NonNull

int[]

grantResults)

{

switch

(requestCode){

case

1:

if

(grantResults.length

>

0

&&

grantResults[0]

==

PackageManager.PERMISSION_GRANTED){

call();

}else

{

Toast.makeText(this,"You

denied

the

permission",Toast.LENGTH_SHORT).show();

}

break;

default:

break;

}

}

}上面的代碼將運行權限的完成流程都覆蓋了,下面我們來具體解析一下,說白了,運行時權限的核心就是在程序運行過程中由用戶授權我們?nèi)?zhí)行某些危險操作,程序是不可以擅自做主去執(zhí)行這些危險操作的,因此,第一步就是要去判斷用戶是不是已經(jīng)給過我們授權了,借助的是ContextCompat.checkSelfPermission()方法,checkSelfPermission()方法接收兩個參數(shù),第一個參數(shù)是Context,這個沒什么好說的,第二個參數(shù)是具體的權限名,比如打電話的權限名就是Manifest.permission.CALL_PHONE,然后使用方法的返回值和packageManager.PERMISSION_CRANTED做比較,相等就說明用戶已經(jīng)授權,不等就表示用戶沒有授權。如果已經(jīng)授權的話就簡單了,直接去執(zhí)行撥打電話的邏輯操作就可以了,這里我們把撥打電話的邏輯封裝到call()方法中,如果沒有授權的話,則需要調(diào)用ActivityCompat.requestPermissions()方法來向用戶申請授權,requestPermissions()方法接收3個參數(shù),第一個參數(shù)要求是Activity的實例,第二個參數(shù)是一個String數(shù)組,我們把要申請的權限名放在數(shù)組中即可,第三個參數(shù)是請求碼,只要是唯一值就可以了,這里傳入1。調(diào)用完了requestPermissions()方法之后,系統(tǒng)會彈出一個申請權限的對話框,然后用戶可以選擇同意或拒絕我們的權限申請,不論是哪種結果,最終都會回調(diào)到onRequestPermissionsResult()方法中,而授權的結果則封裝在grantResults參數(shù)當中,這里我們只需要判斷一下最后的授權結果,如果用戶同意的話就調(diào)用call()方法來撥打電話,如果用戶拒絕的話我們只能放棄操作,并且彈出一條失敗提示?,F(xiàn)在重新運行一下程序,并點擊MakeCall按鈕,效果如圖:

由于用戶還沒有授權過我們撥打電話權限,因此第一次運行會彈出這樣一個權限申請的對話框,用戶可以選擇同意或者拒絕,比如說這里點擊了DENY,結果如圖:由于用戶沒有同意授權,我們只能彈出一個操作失敗的提示,下面我們再次點擊MakeCall,任然會彈出權限申請的對話框,這次點擊ALLOW,結果如圖:可以看到,這次我們就成功進入到撥打電話界面了,并且由于

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論