Intent中的四個(gè)重要屬性——Action、Data、Category、Extras

Intent中的四個(gè)重要屬性——Action、Data、Category、Extras

Intent作為聯(lián)系各Activity之間的紐帶,其作用并不僅僅只限于簡(jiǎn)單的數(shù)據(jù)傳遞。通過(guò)其自帶的屬性,其實(shí)可以方便的完成很多較為復(fù)雜的操 作。例如直接調(diào)用撥號(hào)功能、直接自動(dòng)調(diào)用合適的程序打開不同類型的文件等等。諸如此類,都可以通過(guò)設(shè)置Intent屬性來(lái)完成。

Intent主要有以下四個(gè)重要屬性,它們分別為:

Action:Action屬性的值為一個(gè)字符串,它代表了系統(tǒng)中已經(jīng)定義了一系列常用的動(dòng)作。通過(guò)setAction()方法或在清單文件AndroidManifest.xml中設(shè)置。默認(rèn)為:DEFAULT。

Data:Data通常是URI格式定義的操作數(shù)據(jù)。例如:tel:// 。通過(guò)setData()方法設(shè)置。

Category:Category屬性用于指定當(dāng)前動(dòng)作(Action)被執(zhí)行的環(huán)境。通過(guò)addCategory()方法或在清單文件AndroidManifest.xml中設(shè)置。默認(rèn)為:CATEGORY_DEFAULT。

Extras:Extras屬性主要用于傳遞目標(biāo)組件所需要的額外的數(shù)據(jù)。通過(guò)putExtras()方法設(shè)置。

四個(gè)屬性各自的常用值如下所示:

Action:

ACTION_MAIN:Android Application的入口,每個(gè)Android應(yīng)用必須且只能包含一個(gè)此類型的Action聲明。

ACTION_VIEW:系統(tǒng)根據(jù)不同的Data類型,通過(guò)已注冊(cè)的對(duì)應(yīng)Application顯示數(shù)據(jù)。

ACTION_EDIT:系統(tǒng)根據(jù)不同的Data類型,通過(guò)已注冊(cè)的對(duì)應(yīng)Application編輯示數(shù)據(jù)。

ACTION_DIAL:打開系統(tǒng)默認(rèn)的撥號(hào)程序,如果Data中設(shè)置了電話號(hào)碼,則自動(dòng)在撥號(hào)程序中輸入此號(hào)碼。

ACTION_CALL:直接呼叫Data中所帶的號(hào)碼。

ACTION_ANSWER:接聽(tīng)來(lái)電。

ACTION_SEND:由用戶指定發(fā)送方式進(jìn)行數(shù)據(jù)發(fā)送操作。

ACTION_SENDTO:系統(tǒng)根據(jù)不同的Data類型,通過(guò)已注冊(cè)的對(duì)應(yīng)Application進(jìn)行數(shù)據(jù)發(fā)送操作。

ACTION_BOOT_COMPLETED:Android系統(tǒng)在啟動(dòng)完畢后發(fā)出帶有此Action的廣播(Broadcast)。

ACTION_TIME_CHANGED:Android系統(tǒng)的時(shí)間發(fā)生改變后發(fā)出帶有此Action的廣播(Broadcast)。

ACTION_PACKAGE_ADDED:Android系統(tǒng)安裝了新的Application之后發(fā)出帶有此Action的廣播(Broadcast)。

ACTION_PACKAGE_CHANGED:Android系統(tǒng)中已存在的Application發(fā)生改變之后(如應(yīng)用更新操作)發(fā)出帶有此Action的廣播(Broadcast)。

ACTION_PACKAGE_REMOVED:卸載了Android系統(tǒng)已存在的Application之后發(fā)出帶有此Action的廣播(Broadcast)。

Category:

CATEGORY_DEFAULT:Android系統(tǒng)中默認(rèn)的執(zhí)行方式,按照普通Activity的執(zhí)行方式執(zhí)行。

CATEGORY_HOME:設(shè)置該組件為Home Activity。

CATEGORY_PREFERENCE:設(shè)置該組件為Preference。

CATEGORY_LAUNCHER:設(shè)置該組件為在當(dāng)前應(yīng)用程序啟動(dòng)器中優(yōu)先級(jí)最高的Activity,通常為入口ACTION_MAIN配合使用。

CATEGORY_BROWSABLE:設(shè)置該組件可以使用瀏覽器啟動(dòng)。

CATEGORY_GADGET:設(shè)置該組件可以內(nèi)嵌到另外的Activity中。

Extras:

EXTRA_BCC:存放郵件密送人地址的字符串?dāng)?shù)組。

EXTRA_CC:存放郵件抄送人地址的字符串?dāng)?shù)組。

EXTRA_EMAIL:存放郵件地址的字符串?dāng)?shù)組。

EXTRA_SUBJECT:存放郵件主題字符串。

EXTRA_TEXT:存放郵件內(nèi)容。

EXTRA_KEY_EVENT:以KeyEvent對(duì)象方式存放觸發(fā)Intent的按鍵。

EXTRA_PHONE_NUMBER:存放調(diào)用ACTION_CALL時(shí)的電話號(hào)碼。

Data:

tel://:號(hào)碼數(shù)據(jù)格式,后跟電話號(hào)碼。

mailto://:郵件數(shù)據(jù)格式,后跟郵件收件人地址。

smsto://:短息數(shù)據(jù)格式,后跟短信接收號(hào)碼。

content://:內(nèi)容數(shù)據(jù)格式,后跟需要讀取的內(nèi)容。

file://:文件數(shù)據(jù)格式,后跟文件路徑。

market://search?q=pname:pkgname:市場(chǎng)數(shù)據(jù)格式,在Google Market里搜索包名為pkgname的應(yīng)用。

        geo://latitude,longitude:經(jīng)緯數(shù)據(jù)格式,在地圖上顯示經(jīng)緯度指定的位置。

在intent-filter中指定data屬性的實(shí)際目的是:要求接收的Intent中的data必須符合intent-filter中指定的data屬性,這樣達(dá)到反向限定Intent的作用。

例如:在AndroidManifest.xml 中進(jìn)行如下設(shè)置:
<activity android:name=".TestActivity">
<intent-filter>
<action android:name="com.jony.test"/>
<data android:scheme="file"/>
</intent-filter>
</activity>
那么啟動(dòng)該Activity的Intent必須進(jìn)行如下設(shè)置:

Intent intent = new Intent();
Uri uri = Uri.parse("file://com.android.test:520/mnt/sdcard");
intent.setData(uri);
data屬性解析:android:scheme、android:host、android:port、android:path、android:mimeType

data的前四個(gè)屬性構(gòu)成了URI的組成部分,mimeType設(shè)置了數(shù)據(jù)的類型

data元素組成的URI模型如下:

scheme://host:port/path
舉例說(shuō)明:

URI file://com.android.jony.test:520/mnt/sdcard

scheme-->file:

host-->com.android.jony.test

port-->520

path-->mnt/sdcard
其中host和port為URI的authority,如果沒(méi)有指定host,port將被忽略

data的各屬性并不是獨(dú)立的,data的各屬性構(gòu)成了URI的整個(gè)組成部分。要使authority(host和port)有意義,必須指定scheme;要使path有意義,必須使scheme和authority(host和port)有意義。

URI和intent-filter匹配:
Intent中URI和intent-filter進(jìn)行比較的時(shí)候只會(huì)進(jìn)行部分的比較:

(1)當(dāng)intent-filter中只設(shè)置了scheme,只會(huì)比較URI的scheme部分;

(2)當(dāng)intent-filter中只設(shè)置了scheme和authority,那么只會(huì)匹配URI中的scheme和authority;

(3)當(dāng)intent-filter中設(shè)置了scheme、authority和path,那么只會(huì)匹配URI中的scheme、authority、path;(path可以使用通配符進(jìn)行匹配)

(4)當(dāng)intent-filter中設(shè)置了mimeType,還會(huì)進(jìn)行數(shù)據(jù)類型的匹配。

總結(jié):

(1)在AndroidMainfest.xml 中對(duì)每一個(gè)Activity都做了說(shuō)明——intent-filter,intent-filter聲明了需要接收怎樣的Intent,當(dāng)發(fā)送的 Intent和intent-filter中定義的相符合,就會(huì)啟動(dòng)相應(yīng)的Activity;

(2)當(dāng)有多個(gè)Activity符合發(fā)送的Intent時(shí),Android系統(tǒng)會(huì)列出所有滿足Intent的Activity,用戶可以通過(guò)選擇進(jìn)行相關(guān)的操作;

(3)在一個(gè)Activity的intent-filter中可以有多個(gè)action、多個(gè)category、多個(gè)data,這樣可以有多種組合與 Intent進(jìn)行匹配。注意:如果在一個(gè)Activity中有多個(gè)Intent進(jìn)行匹配的時(shí)候,建議使用多個(gè)intent-filter與Intent進(jìn) 行匹配。猜測(cè):這樣應(yīng)該可以提高Intent的匹配速度。

(4)data屬性,這是一個(gè)進(jìn)行反向限制Intent的操作,要求Intent的data必須是intent-filter中聲明的數(shù)據(jù)之一(應(yīng) 為在一個(gè)intent-filter中可以設(shè)置多個(gè)data)。注意:如果要啟動(dòng)目標(biāo)Activity,但是指定的data數(shù)據(jù)類型與Activity中 data數(shù)據(jù)類型不匹配,將會(huì)造成ActivityNotFoundException異常。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容