隐式Intent概述
使用隐式intent启动其他应用的activity时,描述要完成的任务,操作系统就会找到合适的应用,并启动响应的activity
- 隐式Intent的主要组成部分
- 要执行的操作(action):Intent常量
(例如,访问某个URL即Intent.ACTION_VIEW
发送信息即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向用户显示了包信息,但它不应该显示在启动器中
- 要执行的操作(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去处理特定任务
发送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资源生成要发送的信息
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系统,某应用中的父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里面传入的参数是列号
String suspect=c.getString(0);
mCrime.setSuspect(suspect);
mSuspectButton.setText(suspect);
}finally {
c.close();
}
}
使用PackageManager类进行自检
使用隐式intent时,若操作系统找不到匹配的activity,应用就会崩溃
所以一般要在onCreate,onCreateView时进行检查,并判断是否需要禁用触发隐式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