InterFilter的匹配规则

先附上Activity常用的flags:
Flag_Activity_New_TASK:指定"singleTask"启动模式,效果与xml里指定相同。
Flag_Activity_SINGLE_TOP:指定"singleTop"模式,同上。
Flag_ACTIVITY_CLEAR_TOP:同任务栈中所有位于它之上的Activity全部出栈。一般配合singleTask(默认此效果)使用(调用onNewIntent),如果启动模式是"standard"模式启动,那么该包括自己和他之上Activity全部出栈,再重新创建该实例入栈。
Flag_ACTIVITY_EXCLUDE_FROM_RECENTS:此标记Activity不会出现在历史列表中,在某些情况中如果不希望用户通过历史列表返回到该Activity比较有用,等同于xml里"android:excludeFromRecents=true"。

启动Activity分显示和隐式两种,原则上一个intent不该既是显示调用又是隐式调用,如果两者共存,以显示调用为主。隐式调用需要通过intent去匹配目标组件的IntentFilter中所设置的过滤信息,如果不匹配,目标Activity无法启动。
IntentFilter有action,category,data三种。

IntentFilter中action,category,data可以有多个,所有的action,category,data分别构成不同类别,同一类别共同约束当前类别匹配过程。
一个Activity中可以有多个intent-filter,而一个Intent只要能匹配任何一组intent-filter即可。

action匹配规则:action是一个字符串,系统预定义了一些action,应用中也可以自定义action。
Intent的action必须和intent-filter里的action完全匹配,如果intent-filter里有多个action,那么Intent里的action只要能完全匹配任意一个即可。
注:action字符串区分大小写。

category匹配规则:category是一个字符串,系统预定义了一些category,应用中也可以自定义category。
与action不同的时,Intent中如果含有category,那么所有的category必须和intent-filter里的其中一个category相同。即Inten里出现了category,不管有多少个,所有的category必须和intent-filter里定义的category。
Intent里可以没有category,如果没有按上面的定义也可以匹配成功,这是因为系统会默认为Intent加上"android.intent.category.DEFAULT"这个category(注:如果Intent里没用category而又想隐式调用的话,必须在intent-filter里定义"android.intent.category.DEFAULT"这个category)。

data的匹配规则与action类似,不过结构比较复杂。
data由两部分组成:mimeTyoe(☞媒体类型),URI(包含数据较多)
URL构成:
Scheme:URL的模式,比如http,file,content等。如果URL里没指定,整个URL的其它参数无效,这也意味URL无效。
Host:URL的主机名,比如www.baidu.com,如果Host未指定,整个URL的其它参数无效,这也意味URI无效。
Port:URI的端口号,比如80,仅当URL中指定了Scheme和Host参数后,Port才是有效的。
Path,pathPatterm和pathPrefix:这三个参数表示路径信息,path表示完整路径信息;pathPatterm也表示路径完整信息,但是它可以包含通配符"",""表示0个或多个任意字符(注:由于正则表达式的规范,如果想表示真实的字符串""要写成"\",""要写成"\\");pathPrefix表示路径的前缀信息。
举例:

 
           
            

该规则指定了媒体类型为所有类型图片,那么Intent中的mimeType必须为"image/*"才能匹配。注:此时URI的默认值为content和file。所以intent里URI的schema必须为content或file才能匹配。

 Intent intent = new Intent();
 intent.setDataAndType(Uri.parse("file://abc"),"image/png");

注:如果为intent指定完整data,必须调用setDataAndType。不能先调用setData再调用setType,因为这两个方法会彼此清除对方的值。

intent-filter的匹配规则对Service和BroadcastReceiver同样使用,不过系统推荐对于Service尽量使用显示调用。

最后,当隐式调用启动Activity时候,最好做一下判断是否有Activity能匹配隐式启动,如果不做判断会抛出异常:


InterFilter的匹配规则_第1张图片
Paste_Image.png

判断方法有两种:
PackagerManager的resolveActivity或IntentresolveActivity方法。如果没有匹配的返回值为null.另PackagerManager的queryIntentActivitys方法则返回的成功匹配的Activity信息。
PackagerManager两个方法需要的flags要使用MATCH_DEFULT_ONLY这个标记。这个标记含义是仅匹配intent-filter里的android.intent.category.DEFAULT"这个category,意义在于只要返回值不为null,那么启动一定会成功。

你可能感兴趣的:(InterFilter的匹配规则)