关于intent-filter匹配规则的一些学习记录
Intent-filter
应用程序组件通知Android系统,它们能为其他组件的动作请求提供服务。
intent-filter与action、category、data关系
<activity android:name="com.test.testActivity">
<intent-filter>
<action .../>
<category .../>
<data .../>
</intent-filter>
</activity>
Action匹配
- 一条
<intent-filter>
规则至少应该包含一个<action>
,否则Intent请求服务匹配 - 通过
intent.setAction("action.test1")
进行匹配
<activity android:name="com.test.OneActivity">
<intent-filter>
<action android:name="action.test1" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
Action
-
ACTION_MAIN
:Android Application的入口,每个Android应用必须且只能包含一个此类型的Action声明。 -
ACTION_VIEW
:系统根据不同的Data类型,通过已注册的对应Application显示数据。 -
ACTION_EDIT
:系统根据不同的Data类型,通过已注册的对应Application编辑示数据。 -
ACTION_DIAL
:打开系统默认的拨号程序,如果Data中设置了电话号码,则自动在拨号程序中输入此号码。 -
ACTION_CALL
:直接呼叫Data中所带的号码。 -
ACTION_ANSWER
:接听来电。 -
ACTION_SEND
:由用户指定发送方式进行数据发送操作。 -
ACTION_SENDTO
:系统根据不同的Data类型,通过已注册的对应Application进行数据发送操作。 -
ACTION_BOOT_COMPLETED
:Android系统在启动完毕后发出带有此Action的广播(Broadcast)。 -
ACTION_TIME_CHANGED
:Android系统的时间发生改变后发出带有此Action的广播(Broadcast)。 -
ACTION_PACKAGE_ADDED
:Android系统安装了新的Application之后发出带有此Action的广播(Broadcast)。 -
ACTION_PACKAGE_CHANGED
:Android系统中已存在的Application发生改变之后(如应用更新操作)发出带有此Action的广播(Broadcast)。 -
ACTION_PACKAGE_REMOVED
:卸载了Android系统已存在的Application之后发出带有此Action的广播(Broadcast)。
Category匹配
Category属性是一个执行Action的附加信息。
- 通过
intent.addCategory("category.test1")
进行匹配
<activity android:name="com.test.OneActivity">
<intent-filter>
<action android:name="action.test1" />
<category android:name="category.test1"/>
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
Category
-
CATEGORY_DEFAULT
Android系统中默认的执行方式,按照普通Activity的执行方式执行。 -
CATEGORY_HOME
设置该组件为Home Activity。 -
CATEGORY_PREFERENCE
设置该组件为Preference。 -
CATEGORY_LAUNCHER
设置该组件为在当前应用程序启动器中优先级最高的Activity,通常为入口ACTION_MAIN配合使用。 -
CATEGORY_BROWSABLE
设置该组件可以使用浏览器启动。 -
CATEGORY_GADGET
设置该组件可以内嵌到另外的Activity中。
data匹配
<data android:scheme="http"
android:host="localhost.com"
android:port="8080"
android:path="index"
android:pathPattern="xxx"
android:pathPrefix="xxx"
android:mimeType="xxx"/>
data规则:
scheme://host:port/path or pathPrefix or pathPattern
content://com.test:500/folder/subfolder/etc
http://www.localhost.com:8080/index/page1
属性:
- Scheme: URI的模式。如果URI中没有指定Scheme.那么整个URI无效。默认值为content 和 file。
- Host: URI的host。比如www.baidu.com
- Port: URI端口,当URI指定了scheme 和 host 参数时port参数才有意义
-
path: 用来匹配完整的路径,如
http://localhost.com/blog/abc.html
这里将 path 设置为 /blog/abc.html 才能够进行匹配; - pathPrefix: 用来匹配路径的开头部分,拿上面的 Uri 来说,这里将 pathPrefix 设置为 /blog 就能进行匹配了;
- pathPattern: 用表达式来匹配整个路径。
-
mimeType: 当使用 Intent.setType("text/plain") ,那么系统将会匹配到所有注册 android:mimeType="text/plain" 的 Activity
- setType 调用后设置 mimeType,然后将 data 置为 null;
- setData 调用后设置 data,然后将 mimeType 置为 null;
- setDataAndType 调用后才会同时设置 data 与 mimeType