隱式Intent概述
使用隱式intent啟動其他應用的activity時撤摸,描述要完成的任務庙曙,操作系統(tǒng)就會找到合適的應用,并啟動響應的activity
- 隱式Intent的主要組成部分
- 要執(zhí)行的操作(action):Intent常量
(例如,訪問某個URL即Intent.ACTION_VIEW
發(fā)送信息即Intent.ACTION_SEND) - 要訪問的數據的位置(data):可能是設備外資源吵冒,如網頁URL
可能是指向某個文件的URI或是指向ContentProvider中的某條記錄的URI - 操作涉及的數據類型:MIME形式的數據類型(text/html,audio/mepg3)通仇呐郑可以從數據位置推測出數據類型
- 可選類別(category):類別通常用來描述何時何地如何使用某個activity
例如:android.intent.category.LAUNCHER
表明activity應該顯示在頂級應用啟動器中
android.intnt.category.INFO
表明雖然activity向用戶顯示了包信息代态,但它不應該顯示在啟動器中
- 要執(zhí)行的操作(action):Intent常量
匹配時根據activity在配置文件中的intent過濾器設置來進行匹配
<activity android:name="……">
<intent-filter>
<action android:name="android.intent.action.VIEW"/>
<category android:name="android.intent.category.DEFAULT"/>
<data android:scheme="http"
android:host="www.sjsgdkasjd.com"/>
</intent-filter>
</activity>
隱式intent也可包含extra信息
顯式intent也可使用隱式intent的操作和數據部分慧起,表示讓特定activity去處理特定任務
發(fā)送crime report
- 用到的string資源
<string name="crime_report">%1$s!
The crime was dicovered on %2$s. %3$s,and %4$s
</string>
<string name="crime_report_solved">The case is solved</string>
<string name="crime_report_unsolved">The case is not solved</string>
<string name="crime_report_no_suspect">there is no suspect.</string>
<string name="crime_report_suspect">the suspect is %s.</string>
<string name="crime_report_subject">CriminalIntent Crime Report</string>
<string name="send_report">Send crime report via</string>
注意這下占位符的使用
- 在CrimeFragment.java中利用這寫string資源生成要發(fā)送的信息
private String getCrimeReport(){
String solvedString=null;
if(mCrime.getSolved()){
solvedString=getString(R.string.crime_report_solved);
}else{
solvedString=getString(R.string.crime_report_unsolved);
}
String dateFormat="EEE,MMM dd";
String dateString= DateFormat.format(dateFormat,mCrime.getDate()).toString();
String suspect=mCrime.getSuspect();
if(suspect==null){
suspect=getString(R.string.crime_report_no_suspect);
}else{
suspect=getString(R.string.crime_report_suspect,suspect);
}
String report=getString(R.string.crime_report,mCrime.getTitle(),dateString,solvedString,suspect);
return report;
}
???DateFormat不是很懂
- 使用隱式Intent
Intent i=new Intent(Intent.ACTION_SEND);
i.setType("text/plain");
//設置文本內容
i.putExtra(Intent.EXTRA_TEXT,getCrimeReport());
//設置主題內容
i.putExtra(Intent.EXTRA_SUBJECT,getString(R.string.crime_report_subject));
i=Intent.createChooser(i,getString(R.string.send_report));
startActivity(i);
setType設置文本類型,此處指純文本
createChooser使得每次都會彈出選擇使用應用的彈框祈远,以及可設置彈框頂部顯示的文字
???setType,createChooser不是很懂
獲取聯系人
操作:Intent.ACTION_PICK
數據獲取位置:ContactsContract.Contacts.CONTENT_URI
Android通過ContentProvider類提供了一個深度定制的API用于處理聯系人信息呆万,可以通過一個ContentResolver訪問ContentProvider
聯系人應用具有使用聯系人數據庫的全部權限,聯系人應用返回包含在Intent里的URI數據給父activity
URI數據定位符车份,指向用戶所選的聯系人
并在返回時添加一個Intent.FLAG_READ_URI_PERMISSION
標志谋减,用于告訴Android系統(tǒng),某應用中的父activity可以使用聯系人數據一次
- 使用隱式Intent
final Intent pickContact=new Intent(Intent.ACTION_PICK,
ContactsContract.Contacts.CONTENT_URI);
startActivityForResult(pickContact,REQUEST_CONTACT);
- 在onActivityResult里處理聯系人應用返回的數據
if (requestCode==REQUEST_CONTACT){
Uri contactUri=intent.getData();
//Specify which fields you want your query to return values for.
String[] queryFields=new String[]{
ContactsContract.Contacts.DISPLAY_NAME
};
//Perform your query-the contactUri is like a "where" clause here
Cursor c=getActivity().getContentResolver().query(contactUri,queryFields,null,null,null);
try{
if(c.getCount()==0)
return;
//Pull out the first column of the first row of data-
//that is your suspect's name
c.moveToFirst();
//getString里面?zhèn)魅氲膮凳橇刑? String suspect=c.getString(0);
mCrime.setSuspect(suspect);
mSuspectButton.setText(suspect);
}finally {
c.close();
}
}
使用PackageManager類進行自檢
使用隱式intent時扫沼,若操作系統(tǒng)找不到匹配的activity出爹,應用就會崩潰
所以一般要在onCreate,onCreateView時進行檢查,并判斷是否需要禁用觸發(fā)隱式intent的按鈕
Android設備上安裝了哪些組件以及包括哪些activity缎除,PackageManager全部知道
調用PackageManager的對象的resolveActivity(Intent intent,int flag)方法严就,可找到匹配給定Intent任務的activity
若搜到目標會返回ResolveInfo告知找到了哪個activity
PackageManager packageManager=getActivity().getPackageManager();
if(packageManager.resolveActivity(pickContact,
PackageManager.MATCH_DEFAULT_ONLY)==null){
mSuspectButton.setEnabled(false);
}
flag標志MATCH_DEFAULT_ONLY
限定只搜尋帶CATEGORY_DEFAULT標志的activity