Android开发——IntentFilter的匹配规则

时间:2021-01-01 18:26:14

1.  IntentFilter中的过滤信息

启动Activity分为显式调用和隐式调用,前者没什么好讲的,后者需要Intent能够匹配目标组件的IntentFilter中所设置的过滤信息。包括actioncategorydata

一个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/infocontent://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方法

Android开发——IntentFilter的匹配规则