IntentFilter匹配规则
IntentFilter是manifest文件中组件内部的一个标签,该标签描述了组件具备什么特性,如果您未配置intent-filters,那个该组件只能被显式启动。我们在mainfest中设置的ntent-filters如果可以匹配某个隐式Intent那么该组件就可以被启动。IntentFilter在做匹配时主要是根据action, type, category这三个属性且匹配优先级是:action>data>category
action匹配规则:
如果Intent指明定了action,则目标组件的IntentFilter的action列表中就必须包含有这个action,否则不能匹配。一个Intent Filter中可声明多个action,此时Intent中的action与其中的任一个action在字符串形式上完全相同即可匹配成功。
特殊情况:
如果filter中没有设置任何action 那么所有的intent匹配都会失败
如果action只和category组合使用(隐式调用的条件),intent中不指定action,那么无法启动目标组件
如果action和category、data组合使用,intent中不指定action但是filter中至少存在一个action 那么是可以匹配成功的
category的匹配规则:
Intent-filter可定义零到多个category标签intent中的定义的每一个category都需要匹配上intent-filter中的category标签,反之不成立(intent-filter中的category标签可能比intent中的定义的category多)。所以无论intent-filter中是否定义了category标签,未添加category的intent总能匹配上该intent-filter。
注意:
通过startActivity()或startActivityForResult()方法隐式启动的intent中,将自动被添加一个CATEGORY_DEFAULT的category,所以若您希望自己的activity能够被隐式启动,则需要在intent-filter中添加一个android.intent.category.DEFAULT的category标签。
data匹配规则:
intent filter可定义零到多个data标签每个data标签都能设置mimeType和URI 结构,其中URI可分成四部分:scheme, host, port 和 path。但是是有一个线性依赖:若scheme 未指定,则host被忽略;若host未指定,则port被忽略;
若scheme和host均未指定,则path被忽略;
在intent中添加的data只需要匹配一部分intent-filter中的data:
若filter只定义了scheme,则intent的data定义的URI中只要包含了相同的scheme,就能匹配;
若filter只定义了scheme和host,则intent的data定义的URI中只要包含了相同的scheme和host,就能匹配;
若filter只定义了scheme、host和port,则intent的data定义的URI中只要包含了相同的scheme、host和port,就能匹配