天天看點

Android--intent詳解

【正文】

Intent元件雖然不是四大元件,但卻是連接配接四大元件的橋梁,學習好這個知識,也非常的重要。

一、什麼是Intent

1、Intent的概念:

  • Android中提供了Intent機制來協助應用間的互動與通訊,或者采用更準确的說法是,Intent不僅可用于應用程式之間,也可用于應用程式内部的activity,

    service和broadcast receiver之間的互動。Intent這個英語單詞的本意是“目的、意向、意圖”。

  • Intent是一種運作時綁定(runtime binding)機制,它能在程式運作的過程中連接配接兩個不同的元件。通過Intent,你的程式可以向Android表達某種請求或者意願,Android會根據意願的内容選擇适當的元件來響應。

activity、service和broadcast receiver之間是通過Intent進行通信的,而另外一個元件Content Provider本身就是一種通信機制,不需要通過Intent。我們來看下面這個圖就知道了:

Android--intent詳解

如果Activity1需要和Activity2進行聯系,二者不需要直接聯系,而是通過Intent作為橋梁。通俗來講,Intnet類似于中介、媒婆的角色。

2、對于向這三種元件發送intent有不同的機制:

  • 使用Context.startActivity() 或 Activity.startActivityForResult(),傳入一個intent來啟動一個activity。使用 Activity.setResult(),傳入一個intent來從activity中傳回結果。
  • 将intent對象傳給Context.startService()來啟動一個service或者傳消息給一個運作的service。将intent對象傳給 Context.bindService()來綁定一個service。
  • 将intent對象傳給 Context.sendBroadcast(),Context.sendOrderedBroadcast(),或者Context.sendStickyBroadcast()等廣播方法,則它們被傳給

    broadcast receiver。

二、Intent的相關屬性:

  • Intent由以下各個組成部分:
  • component(元件):目的元件
  • action(動作):用來表現意圖的行動
  • category(類别):用來表現動作的類别
  • data(資料):表示與動作要操縱的資料
  • type(資料類型):對于data範例的描寫
  • extras(擴充資訊):擴充資訊
  • Flags(标志位):期望這個意圖的運作模式

Intent類型分為顯式Intent(直接類型)、隐式Intent(間接類型)。官方建議使用隐式Intent。上述屬性中,component屬性為直接類型,其他均為間接類型。

相比與顯式Intent,隐式Intnet則含蓄了許多,它并不明确指出我們想要啟動哪一個活動,而是指定一系列更為抽象的action和category等資訊,然後交由系統去分析這個Intent,并幫我們找出合适的活動去啟動。

Activity 中 Intent Filter 的比對過程 :

Android--intent詳解

1、component(元件):目的元件

Component屬性明确指定Intent的目标元件的類名稱。(屬于直接Intent)

如果 component這個屬性有指定的話,将直接使用它指定的元件。指定了這個屬性以後,Intent的其它所有屬性都是可選的。

例如,啟動第二個Activity時,我們可以這樣來寫:

1         button1.setOnClickListener(new OnClickListener() {            
 2             @Override
 3             public void onClick(View v) {
 4                 //建立一個意圖對象
 5                 Intent intent = new Intent();
 6                 //建立元件,通過元件來響應
 7                 ComponentName component = new ComponentName(MainActivity.this, SecondActivity.class);
 8                 intent.setComponent(component);                
 9                 startActivity(intent);                
10             }
11         });      

如果寫的簡單一點,監聽事件onClick()方法裡可以這樣寫:

1                 Intent intent = new Intent();
2                 //setClass函數的第一個參數是一個Context對象
3                 //Context是一個類,Activity是Context類的子類,也就是說,所有的Activity對象,都可以向上轉型為Context對象
4                 //setClass函數的第二個參數是一個Class對象,在目前場景下,應該傳入需要被啟動的Activity類的class對象
5                 intent.setClass(MainActivity.this, SecondActivity.class);
6                 startActivity(intent);          

再簡單一點,可以這樣寫:(當然,也是最常見的寫法)

1                 Intent intent = new Intent(MainActivity.this,SecondActivity.class);
2                 startActivity(intent);      

2、Action(動作):用來表現意圖的行動

當日常生活中,描述一個意願或願望的時候,總是有一個動詞在其中。比如:我想“做”三個俯卧撐;我要“寫” 一封情書,等等。在Intent中,Action就是描述做、寫等動作的,當你指明了一個Action,執行者就會依照這個動作的訓示,接受相關輸入,表現對應行為,産生符合的輸出。在Intent類中,定義了一批量的動作,比如ACTION_VIEW,ACTION_PICK等, 基本涵蓋了常用動作。加的動作越多,越精确。

Action 是一個使用者定義的字元串,用于描述一個 Android 應用程式元件,一個 Intent Filter 可以包含多個 Action。在 AndroidManifest.xml 的Activity 定義時,可以在其 <intent-filter >節點指定一個

Action清單用于辨別 Activity 所能接受的“動作”。

3、category(類别):用來表現動作的類别

Category屬性也是作為<intent-filter>子元素來聲明的。例如:

<intent-filter>

  <action android:name="com.vince.intent.MY_ACTION"></action>

  <category android:name="com.vince.intent.MY_CATEGORY"></category> 

  <category android:name="android.intent.category.DEFAULT"></category> 

</intent-filter>   

Action 和category通常是放在一起用的,是以這裡一起介紹一下。我們來先來舉一個例子:

建立一個工程檔案smyh006_Intent01,在預設檔案的基礎之上,建立檔案SecondActicity.java和activity_second.xml。

緊接着,我們要到清單檔案中進行注冊,打開AndroidManifest.xml,添加SecondActivity的action和category的過濾器:

1         <activity 
2             android:name=".SecondActivity">
3             <intent-filter>
4                  <action android:name="com.example.smyh006intent01.MY_ACTION"/>
5                  <category android:name="android.intent.category.DEFAULT" />
6             </intent-filter>            
7         </activity>      

上方代碼,表示SecondActicity可以比對第4行的MY_ACTION這個動作,此時,如果在其他的Acticity通過這個action的條件來查找,那SecondActicity就具備了這個條件。類似于相親時,我要求對方有哪些條件,然後對方這個SecondActicity恰巧滿足了這個條件(夠通俗了吧)。

注:如果沒有指定的category,則必須使用預設的DEFAULT(即上方第5行代碼)。

也就是說:隻有<action>和<category>中的内容同時能夠比對上Intent中指定的action和category時,這個活動才能響應Intent。如果使用的是DEFAULT這種預設的category,在稍後調用startActivity()方法的時候會自動将這個category添加到Intent中。

現在來修改MainActivity.java中按鈕的點選事件,代碼如下:

1         button1.setOnClickListener(new OnClickListener() {            
 2             @Override
 3             public void onClick(View v) {
 4                 //啟動另一個Activity,(通過action屬性進行查找)
 5                 Intent intent = new Intent();
 6                 //設定動作(實際action屬性就是一個字元串标記而已)
 7                 intent.setAction("com.example.smyh006intent01.MY_ACTION"); //方法:Intent android.content.Intent.setAction(String action)
 8                 startActivity(intent);        
 9             }
10         });      

上方代碼中,也可以換成下面這種簡潔的方式:

1         button1.setOnClickListener(new OnClickListener() {            
2             @Override
3             public void onClick(View v) {
4                 //啟動另一個Activity,(通過action屬性進行查找)
5                 Intent intent = new Intent("com.example.smyh006intent01.MY_ACTION");//方法: android.content.Intent.Intent(String action)                
6                 startActivity(intent);        
7             }
8         });      

上方第5行代碼:在這個Intent中,我并沒有指定具體哪一個Activity,我隻是指定了一個action的常量。是以說,隐式Intent的作用就表現的淋漓盡緻了。此時,點選MainActicity中的按鈕,就會跳到SecondActicity中去。

上述情況隻有SecondActicity比對成功。如果有多個元件比對成功,就會以對話框清單的方式讓使用者進行選擇。我們來詳細介紹一下:

我們建立檔案ThirdActicity.java和activity_third.xml,然後在清單檔案AndroidManifest.xml中添加ThirdActivity的action和category的過濾器:

1         <activity 
2             android:name=".ThirdActivity">
3             <intent-filter>
4                  <action android:name="com.example.smyh006intent01.MY_ACTION"/>
5                  <category android:name="android.intent.category.DEFAULT" />
6             </intent-filter>            
7         </activity>       

此時,運作程式,當點選MainActivity中的按鈕時,彈出如下界面:

Android--intent詳解

相信大家看到了這個界面,應該就一目了然了。于是我們可以做出如下總結:

在自定義動作時,使用activity元件時,必須添加一個預設的類别

具體的實作為:

               <action android:name="com.example.action.MY_ACTION"/>

               <category android:name="android.intent.category.DEFAULT"/>

</intent-filter>

如果有多個元件被比對成功,就會以對話框清單的方式讓使用者進行選擇。

每個Intent中隻能指定一個action,但卻能指定多個category;類别越多,動作越具體,意圖越明确(類似于相親時,給對方提了很多要求)。

目前我們的Intent中隻有一個預設的category,現在可以通過intent.addCategory()方法來實作。修改MainActivity中按鈕的點選事件,代碼如下:

1         button1.setOnClickListener(new OnClickListener() {            
 2             @Override
 3             public void onClick(View v) {
 4                 //啟動另一個Activity,(通過action屬性進行查找)
 5                 Intent intent = new Intent();
 6                 //設定動作(實際action屬性就是一個字元串标記而已)
 7                 intent.setAction("com.example.smyh006intent01.MY_ACTION"); //方法:Intent android.content.Intent.setAction(String action)
 8                 intent.addCategory("com.example.smyh006intent01.MY_CATEGORY");
 9                 startActivity(intent);        
10             }
11         });      

既然在Intent中增加了一個category,那麼我們要在清單檔案中去聲明這個category,不然程式将無法運作。代碼如下:

1             android:name=".SecondActivity">
2             <intent-filter>
3                  <action android:name="com.example.smyh006intent01.MY_ACTION"/>
4                  <category android:name="android.intent.category.DEFAULT" />
5                  <category android:name="com.example.smyh006intent01.MY_CATEGORY" />
6             </intent-filter>            
7         </activity>      

此時,點選MainActicity中的按鈕,就會跳到SecondActicity中去。

總結如下:

自定義類别: 在Intent添加類别可以添加多個類别,那就要求被比對的元件必須同時滿足這多個類别,才能比對成功。操作Activity的時候,如果沒有類别,須加上預設類别

4、data(資料):表示與動作要操縱的資料

  • Data屬性是Android要通路的資料,和action和Category聲明方式相同,也是在<intent-filter>中。
  • 多個元件比對成功顯示優先級高的; 相同顯示清單。

Data是用一個uri對象來表示的,uri代表資料的位址,屬于一種辨別符。通常情況下,我們使用action+data屬性的組合來描述一個意圖:做什麼

使用隐式Intent,我們不僅可以啟動自己程式内的活動,還可以啟動其他程式的活動,這使得Android多個應用程式之間的功能共享成為了可能。比如應用程式中需要展示一個網頁,沒有必要自己去實作一個浏覽器(事實上也不太可能),而是隻需要條用系統的浏覽器來打開這個網頁就行了。

【執行個體】打開指定網頁:

MainActivity.java中,監聽器部分的核心代碼如下:

1         button1.setOnClickListener(new OnClickListener() {            
 2             @Override
 3             public void onClick(View v) {
 4                 Intent intent = new Intent();
 5                 intent.setAction(Intent.ACTION_VIEW);
 6                 Uri data = Uri.parse("http://www.baidu.com");
 7                 intent.setData(data);                
 8                 startActivity(intent);        
 9             }
10         });      

當然,上方代碼也可以簡寫成:

1         button1.setOnClickListener(new OnClickListener() {            
2             @Override
3             public void onClick(View v) {
4                 Intent intent = new Intent(Intent.ACTION_VIEW);
5                 intent.setData(Uri.parse("http://www.baidu.com"));                
6                 startActivity(intent);        
7             }
8         });      

第4行代碼:指定了Intent的action是 Intent.ACTION_VIEW,表示檢視的意思,這是一個Android系統内置的動作;

第5行代碼:通過Uri.parse()方法,将一個網址字元串解析成一個Uri對象,再調用intent的setData()方法将這個Uri對象傳遞進去。

當點選按鈕時,将跳到如下界面:

Android--intent詳解

此時, 調用的是系統預設的浏覽器,也就是說,隻調用了這一個元件。現在如果有多個元件得到了比對,應該是什麼情況呢?

我們修改修改清單檔案中對SecondAcivity的聲明:

1         <activity 
2             android:name=".SecondActivity">
3             <intent-filter>
4                  <action android:name="android.intent.action.VIEW" />
5                  <category android:name="android.intent.category.DEFAULT" />
6                  <data android:scheme="http" android:host="www.baidu.com"/>                 
7             </intent-filter>            
8         </activity>      

現在,SecondActivity也比對成功了,我們運作程式,點選MainActicity的按鈕時,彈出如下界面供我們選擇:

Android--intent詳解

我們可以總結如下:

  • 當Intent比對成功的元件有多個時,顯示優先級高的元件,如果優先級相同,顯示清單讓使用者自己選擇
  • 優先級從-1000至1000,并且其中一個必須為負的才有效

注:系統預設的浏覽器并沒有做出優先級聲明,其優先級預設為正數。

優先級的配置如下:

在清單檔案中修改對SecondAcivity的聲明,即增加一行代碼,通過來android:priority設定優先級,如下:

1         <activity 
2             android:name=".SecondActivity">
3             <intent-filter android:priority="-1">
4                  <action android:name="android.intent.action.VIEW" />
5                  <category android:name="android.intent.category.DEFAULT" />
6                  <data android:scheme="http" android:host="www.baidu.com"/>                                  
7             </intent-filter>            
8         </activity>      

注:

Data屬性的聲明中要指定通路資料的Uri和MIME類型。可以在<data>元素中通過一些屬性來設定:

android:scheme、android:path、android:port、android:mimeType、android:host等,通過這些屬性來對應一個典型的Uri格式scheme://host:port/path。例如:http://www.google.com。

5、type(資料類型):對于data範例的描寫

如果Intent對象中既包含Uri又包含Type,那麼,在<intent-filter>中也必須二者都包含才能通過測試。

Type屬性用于明确指定Data屬性的資料類型或MIME類型,但是通常來說,當Intent不指定Data屬性時,Type屬性才會起作用,否則Android系統将會根據Data屬性值來分析資料的類型,是以無需指定Type屬性。

data和type屬性一般隻需要一個,通過setData方法會把type屬性設定為null,相反設定setType方法會把data設定為null,如果想要兩個屬性同時設定,要使用Intent.setDataAndType()方法。

【任務】:data+type屬性的使用 【執行個體】:播放指定路徑的mp3檔案。

具體如下:

建立工程檔案smyh006_Intent02,MainActivity.java中按鈕監聽事件部分的代碼如下:

1         button.setOnClickListener(new OnClickListener(){
 2             @Override
 3             public void onClick(View v) {
 4                 Intent intent = new Intent();
 5                 intent.setAction(Intent.ACTION_VIEW);
 6                 Uri data = Uri.parse("file:///storage/sdcard0/平凡之路.mp3");
 7                 //設定data+type屬性
 8                 intent.setDataAndType(data, "audio/mp3"); //方法:Intent android.content.Intent.setDataAndType(Uri data, String type)
 9                 startActivity(intent);                
10             }            
11         });      

代碼解釋:

第6行:"file://"表示查找檔案,後面再加上我的小米手機存儲卡的路徑:/storage/sdcard0,再加上具體歌曲的路徑。

第8行:設定data+type屬性  

運作後,當點選按鈕時,效果如下:

Android--intent詳解

上方界面中,使用的是小米系統預設的音樂播放器。

6、extras(擴充資訊):擴充資訊

是其它所有附加資訊的集合。使用extras可以為元件提供擴充資訊,比如,如果要執行“發送電子郵件”這個

動作,可以将電子郵件的标題、正文等儲存在extras裡,傳給電子郵件發送元件。

7、Flags(标志位):期望這個意圖的運作模式

一個程式啟動後系統會為這個程式配置設定一個task供其使用,另外同一個task裡面可以擁有不同應用程式的activity。那麼,同一個程式能不能擁有多個task?這就涉及到加載activity的啟動模式,這個需要單獨講一下。

注:android中一組邏輯上在一起的activity被叫做task,自己認為可以了解成一個activity堆棧。

三、Activity的啟動模式:(面試注意)

Activity有四種啟動模式:standard、singleTop、singleTask、singleInstance。可以在AndroidManifest.xml中activity标簽的屬性android:launchMode中設定該activity的加載模式。

  • standard模式:預設的模式,以這種模式加載時,每當啟動一個新的活動,必定會構造一個新的Activity執行個體放到傳回棧(目标task)的棧頂,不管這個Activity是否已經存在于傳回棧中;
  • singleTop模式:如果一個以singleTop模式啟動的activity的執行個體已經存在于傳回桟的桟頂,那麼再啟動這個Activity時,不會建立新的執行個體,而是重用位于棧頂的那個執行個體,并且會調用該執行個體的onNewIntent()方法将Intent對象傳遞到這個執行個體中;

注:如果以singleTop模式啟動的activity的一個執行個體已經存在于傳回桟中,但是不在桟頂,那麼它的行為和standard模式相同,也會建立多個執行個體;

  • singleTask模式:這種模式下,每次啟動一個activity時,系統首先會在傳回棧中檢查是否存在該活動的執行個體,如果存在,則直接使用該執行個體,并把這個活動之上的所有活動統統清除;如果沒有發現就會建立一個新的活動執行個體;
  • singleInstance模式:總是在新的任務中開啟,并且這個新的任務中有且隻有這一個執行個體,也就是說被該執行個體啟動的其他activity會自動運作于另一個任務中。當再次啟動該activity的執行個體時,會重新調用已存在的任務和執行個體。并且會調用這個執行個體的onNewIntent()方法,将Intent執行個體傳遞到該執行個體中。和singleTask相同,同一時刻在系統中隻會存在一個這樣的Activity執行個體。(singleInstance即單執行個體)

注:前面三種模式中,每個應用程式都有自己的傳回棧,同一個活動在不同的傳回棧中入棧時,必然是建立了新的執行個體。而使用singleInstance模式可以解決這個問題,在這種模式下會有一個單獨的傳回棧來管理這個活動,不管是哪一個應用程式來通路這個活動,都公用同一個傳回棧,也就解決了共享活動執行個體的問題。(此時可以實作任務之間的切換,而不是單獨某個棧中的執行個體切換)

其實我們不在清單檔案中設定,隻在代碼中通過flag來設定也是可以的,如下:

1         Intent intent = new Intent(MainActivity.this,SecondActivity.class);
2         //相當于singleTask
3         intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
4         startActivity(intent);      
1         Intent intent = new Intent(MainActivity.this,SecondActivity.class);
2         //相當于singleTop
3         intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
4         startActivity(intent);      

三、Intent的常見應用:

1、打開指定網頁:(直接複制的上面的代碼)

1         button1.setOnClickListener(new OnClickListener() {            
 2             @Override
 3             public void onClick(View v) {
 4                 Intent intent = new Intent();
 5                 intent.setAction(Intent.ACTION_VIEW);//方法:android.content.Intent.Intent(String action)
 6                 Uri data = Uri.parse("http://www.baidu.com");
 7                 intent.setData(data);                
 8                 startActivity(intent);        
 9             }
10         });      
1   button1.setOnClickListener(new OnClickListener() {            
2             @Override
3             public void onClick(View v) {
4                 Intent intent = new Intent(Intent.ACTION_VIEW);
5                 intent.setData(Uri.parse("http://www.baidu.com"));                
6                 startActivity(intent);        
7             }
8         });      

或者可以寫成:

1         button1.setOnClickListener(new OnClickListener() {            
2             @Override
3             public void onClick(View v) {
4                 Uri uri = Uri.parse("http://www.baidu.com");
5                 Intent intent = new Intent(Intent.ACTION_VIEW,uri);//方法: android.content.Intent.Intent(String action, Uri uri)        
6                 startActivity(intent);        
7             }
8         });      

2、打電話:

【方式一】打開撥打電話的界面:

1                 Intent intent = new Intent(Intent.ACTION_DIAL);
2                 intent.setData(Uri.parse("tel:10086"));
3                 startActivity(intent);        

運作程式後,點選按鈕,顯示如下界面:

Android--intent詳解

【方式二】直接撥打電話:

1                 Intent intent = new Intent(Intent.ACTION_CALL);
2                 intent.setData(Uri.parse("tel:10086"));
3                 startActivity(intent);      

要使用這個功能必須在配置檔案中加入權限:(加一行代碼)

1     <uses-sdk
2         android:minSdkVersion="8"
3         android:targetSdkVersion="16" />
4     <uses-permission android:name="android.permission.CALL_PHONE"/>      

3、發送短信:

【方式一】打開發送短信的界面:action+type

1         Intent intent = new Intent(Intent.ACTION_VIEW);
2         intent.setType("vnd.android-dir/mms-sms");
3         intent.putExtra("sms_body", "具體短信内容"); //"sms_body"為固定内容
4         startActivity(intent);       

【方式二】打開發短信的界面(同時指定電話号碼):action+data

1         Intent intent = new Intent(Intent.ACTION_SENDTO);
2         intent.setData(Uri.parse("smsto:18780260012"));
3         intent.putExtra("sms_body", "具體短信内容"); //"sms_body"為固定内容        
4         startActivity(intent);      

4、播放指定路徑音樂:action+data+type

1         Intent intent = new Intent(Intent.ACTION_VIEW);
2         Uri uri = Uri.parse("file:///storage/sdcard0/平凡之路.mp3"); ////路徑也可以寫成:"/storage/sdcard0/平凡之路.mp3"
3         intent.setDataAndType(uri, "audio/mp3"); //方法:Intent android.content.Intent.setDataAndType(Uri data, String type)
4         startActivity(intent);      

5、解除安裝程式:action+data(例如點選按鈕,解除安裝某個應用程式,根據包名來識别)

注:無論是安裝還是解除安裝,應用程式是根據包名package來識别的。

1         Intent intent = new Intent(Intent.ACTION_DELETE);
2         Uri data = Uri.parse("package:com.example.smyh006intent01");
3         intent.setData(data);
4         startActivity(intent);      

6、安裝程式:action+data+type

1         Intent intent = new Intent(Intent.ACTION_VIEW);
2         Uri data = Uri.fromFile(new File("/storage/sdcard0/AndroidTest/smyh006_Intent01.apk"));    //路徑不能寫成:"file:///storage/sdcard0/···"
3         intent.setDataAndType(data, "application/vnd.android.package-archive");  //Type的字元串為固定内容
4         startActivity(intent);      

注:第2行的路徑不能寫成:"file:///storage/sdcard0/···",不然報錯如下:

Android--intent詳解

疑問:通過下面的這種方式安裝程式,運作時為什麼會出錯呢?

1     //通過指定的action來安裝程式
2     public void installClickTwo(View view){
3         Intent intent = new Intent(Intent.ACTION_PACKAGE_ADDED);
4         Uri data = Uri.fromFile(new File("/storage/sdcard0/AndroidTest/smyh006_Intent01.apk"));    //路徑不能寫成:"file:///storage/sdcard0/···"
5         intent.setData(data);
6         startActivity(intent);
7     }      

綜上所述,完整版代碼如下:

1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:layout_width="match_parent"
 4     android:layout_height="match_parent"
 5     android:paddingBottom="@dimen/activity_vertical_margin"
 6     android:paddingLeft="@dimen/activity_horizontal_margin"
 7     android:paddingRight="@dimen/activity_horizontal_margin"
 8     android:paddingTop="@dimen/activity_vertical_margin"
 9     android:orientation="vertical"
10     tools:context=".MainActivity" >
11     <Button 
12         android:id="@+id/button1_browsePage"
13         android:layout_width="match_parent"
14         android:layout_height="wrap_content"
15         android:onClick="browsePageClick"
16         android:text="打開指定網頁"/>   
17     <Button 
18         android:id="@+id/button2_openDialPage"
19         android:layout_width="match_parent"
20         android:layout_height="wrap_content"
21         android:onClick="openDialPageClick"
22         android:text="打開撥号面闆"/>
23     <Button 
24         android:id="@+id/button3_dialPhone"
25         android:layout_width="match_parent"
26         android:layout_height="wrap_content"
27         android:onClick="dialPhoneClick"
28         android:text="直接撥打指定号碼"/>
29     <Button 
30         android:id="@+id/button4_openMsgPage"
31         android:layout_width="match_parent"
32         android:layout_height="wrap_content"
33         android:onClick="openMsgPageClick"
34         android:text="打開發短信的界面"/>
35     
36     
37      <Button 
38         android:id="@+id/button5_sendMsg"
39         android:layout_width="match_parent"
40         android:layout_height="wrap_content"
41         android:onClick="sendMsgClick"
42         android:text="給指定的人發短信"/>  
43         
44      <Button 
45         android:id="@+id/button6_playMusic"
46         android:layout_width="match_parent"
47         android:layout_height="wrap_content"
48         android:onClick="playMusicClick"
49         android:text="播放指定路徑音樂"/>      
50      
51      <Button 
52         android:id="@+id/button7_uninstall"
53         android:layout_width="match_parent"
54         android:layout_height="wrap_content"
55         android:onClick="uninstallClick"
56         android:text="解除安裝程式"/>    
57      <Button 
58         android:id="@+id/button8_install"
59         android:layout_width="match_parent"
60         android:layout_height="wrap_content"
61         android:onClick="installClick"
62         android:text="安裝程式"/>    
63         
64     
65 </LinearLayout>      

MainActivity.java代碼如下:

1 package com.example.m06intent01;
 2 import java.io.File;
 3 import android.app.Activity;
 4 import android.content.Intent;
 5 import android.net.Uri;
 6 import android.os.Bundle;
 7 import android.view.Menu;
 8 import android.view.View;
 9 public class MainActivity extends Activity {
10     @Override
11     protected void onCreate(Bundle savedInstanceState) {
12         super.onCreate(savedInstanceState);
13         setContentView(R.layout.activity_main);
14     }
15     //打開指定網頁
16     public void browsePageClick(View view){
17         Intent intent = new Intent(Intent.ACTION_VIEW);
18         intent.setData(Uri.parse("http://www.baidu.com/"));
19         startActivity(intent);  
20         
21     } 
22     
23     //打開撥号面闆
24     public void openDialPageClick(View view){
25         Intent intent = new Intent(Intent.ACTION_DIAL);
26         intent.setData(Uri.parse("tel:10086"));
27         startActivity(intent);        
28     }
29     
30     //直接撥打指定号碼
31     public void dialPhoneClick(View view){
32         Intent intent = new Intent(Intent.ACTION_CALL);
33         intent.setData(Uri.parse("tel:10086"));
34         startActivity(intent);        
35     }
36     
37     //打開發短信的界面:action+type
38     public void openMsgPageClick(View view){
39         Intent intent = new Intent(Intent.ACTION_VIEW);
40         intent.setType("vnd.android-dir/mms-sms");
41         intent.putExtra("sms_body", "具體短信内容"); //"sms_body"為固定内容
42         startActivity(intent);        
43     }   
44     
45     //打開發短信的界面(指定電話号碼):action+data
46     public void sendMsgClick(View view){
47         Intent intent = new Intent(Intent.ACTION_SENDTO);
48         intent.setData(Uri.parse("smsto:18780260012"));
49         intent.putExtra("sms_body", "具體短信内容"); //"sms_body"為固定内容        
50         startActivity(intent);        
51     }      
52     
53     //播放指定路徑音樂
54     public void playMusicClick(View view){
55         Intent intent = new Intent(Intent.ACTION_VIEW);
56         Uri uri = Uri.parse("file:///storage/sdcard0/平凡之路.mp3");  //路徑也可以寫成:"/storage/sdcard0/平凡之路.mp3"
57         intent.setDataAndType(uri, "audio/mp3"); //方法:Intent android.content.Intent.setDataAndType(Uri data, String type)
58         startActivity(intent);
59     } 
60     
61     //解除安裝某個應用程式,根據包名來識别
62     public void uninstallClick(View view){
63         Intent intent = new Intent(Intent.ACTION_DELETE);
64         Uri data = Uri.parse("package:com.example.smyh006intent01");
65         intent.setData(data);
66         startActivity(intent);
67     } 
68     
69     //安裝某個應用程式,根據apk的檔案名來識别
70     public void installClick(View view){
71         Intent intent = new Intent(Intent.ACTION_VIEW);
72         Uri data = Uri.fromFile(new File("/storage/sdcard0/AndroidTest/smyh006_Intent01.apk"));    //路徑不能寫成:"file:///storage/sdcard0/···"
73         intent.setDataAndType(data, "application/vnd.android.package-archive");  //Type的字元串為固定内容
74         startActivity(intent);
75     }
76     
77     
78     @Override
79     public boolean onCreateOptionsMenu(Menu menu) {
80         // Inflate the menu; this adds items to the action bar if it is present.
81         getMenuInflater().inflate(R.menu.main, menu);
82         return true;
83     }
84     
85 }      

運作後,主界面如下:

Android--intent詳解

繼續閱讀