您的位置:首页 > 移动开发 > Android开发

Android开发——IntentFilter的匹配规则

2016-07-28 16:08 225 查看
1.  IntentFilter中的过滤信息
启动Activity分为显式调用和隐式调用,前者没什么好讲的,后者需要Intent能够匹配目标组件的IntentFilter中所设置的过滤信息。包括action、category、data。
一个Activity中可以有多个IntentFilter,一个Intent只要能匹配任何其中一组IntentFilter即可成功启动该Activity。
本文原创,转载请注明出处:http://blog.csdn.net/seu_calvin/article/details/52056337

1.1 Action
Action区分大小写。一个过滤规则中可以有多个Action。那么只要Intent中的Action能和过滤规则中的任何一个相同即可匹配成功。若Intent中未指定Action,那么匹配失败。
Action可以直接通过Intent intent = new Intent("<action>");来为Intent设置。

 
1.2 Category
Category要求Intent中,可以没有Category,因为startActivity或者startActivityForResult的时候,会默认为Intent加上android.intent.category.DEFAULT这个Category。这个在匹配规则里肯定是有的。如果Activity中不含有这个默认的Category,是无法接收隐式Intent的。
但是如果你一旦有Category,不管有几个,都要和过滤规则中的任何一个Category相同。
Category可以通过intent.addCategory("<category>");来为Intent设置。

 
1.3 Data
1.3.1  Data语法规则<data //合起来写作用一样
android:scheme = "string"
android:host = "string"
android:port = "string"
android:pathPattern = "string"
android:pathPrefix = "string"
android:mimeType = "string"/>Data由mimeType和URI两部分组成。
mimeType指媒体类型,比如image/jpeg、audio/mpeg4-generic以及video/*等。可表示图片、文本、视频等不同的媒体格式。

URI中包含的数据比较多。结构和举例如下:
<scheme>://<host>:<port>/[<path>|<pathPrefix>|<pathPattern>]
//举例如下 http://www.baidu.com:80/search/info content://com.example.project:200/folder/subfolder/etc
Scheme:URI模式,比如http、file、content等。若URL没有指定Scheme,那么整个URL的其他参数无效。整个URL也无效。
Host:URI主机名,未指定的话,结果同上。
PORT:URI端口号,前两者指定时,该参数才有效。
Path、pathPrefix、pathPattern:表示路径信息。第一个表示完整路径。第二个也表示完整路径,但它里面可以包含通配符。由于正则表达式的规范,"\"要表示为"\\\\"。第三个表示路径前缀信息。

1.3.2  Data匹配规则

和Action一样,必须含有。并且能够完全匹配过滤规则中的某一个Data。
需要注意的是,若要为Intent指定完整的data,必须调用setDataAndType方法,不能先调用setData再调用setType,因为两者可以互相清除对方的值。

有一种匹配时的特殊情况需要注意:
若匹配规则中只有mimeType没有指定URI
mimeType必须匹配,虽然规则中没有指定URI,但是默认值为content和file(没有http)。

因此我们的URI的Scheme部分必须指定为content或者file。

2.  隐式匹配前进行判断

如果未找到可以匹配的Intent,便会报错。为了防止这种情况,我们需要在隐式匹配前进行判断,是否存在可以匹配的Activity。方法有两种。

(1)PackageManager的resolveActivity方法
(2)Intent的resolveActivity方法
如果它们找不到可以匹配的Activity,便会返回Null。当然需要指定好参数信息,这两个方法,第一个参数为intent,第二个为flag,必须指定为MATCH_DEFAULT_ONLY。
这个标志位可以筛选出Activity中含有android.intent.category.DEFAULT这个Category。因为不含有这个,是无法响应隐式Intent的。
这样才能保证只要不返回Null,一定可以启动成功。找到就返回最佳匹配的Activity信息。
如果想返回所有可匹配的Activity信息。可以使用PackageManager的queryIntentActivities方法。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: