概述
官网对Intent的action、data和category的说明
public Intent setAction (String action)
Added in API level 1
Set the general action to be performed.
Parameters
action An action name, such as ACTION_VIEW. Application-specific actions should be prefixed with the vendor's package name.
Returns
Returns the same Intent object, for chaining multiple calls into a single statement.
public Intent setData (Uri data)
Added in API level 1
Set the data this intent is operating on. This method automatically clears any type that was previously set by setType(String) or setTypeAndNormalize(String).
Note: scheme matching in the Android framework is case-sensitive, unlike the formal RFC. As a result, you should always write your Uri with a lower case scheme, or use normalizeScheme() or setDataAndNormalize(Uri) to ensure that the scheme is converted to lower case.
Parameters
data The Uri of the data this intent is now targeting.
Returns
Returns the same Intent object, for chaining multiple calls into a single statement.
public Intent addCategory (String category)
Added in API level 1
Add a new category to the intent. Categories provide additional detail about the action the intent performs. When resolving an intent, only activities that provide all of the requested categories will be used.
Parameters
category The desired category. This can be either one of the predefined Intent categories, or a custom category in your own namespace.
Returns
Returns the same Intent object, for chaining multiple calls into a single statement.
可以看出action, data, category都是可以自定义的。
Only three aspects of an Intent object are consulted when the object is tested against an intent filter:
action
data (both URI and data type)
category
The extras and flags play no part in resolving which component receives an intent.
系统根据IntentFilter决定哪个元件可以接收哪个Intent, Intent是否匹配的判定只跟action,data和category有关。
自定义action的官方命名规范:
You can also define your own action strings for activating the components in your application. Those you invent should include the application package as a prefix — for example: "com.example.project.SHOW_COLOR
".
category需要注意的地方
In principle, therefore, an Intent object with no categories should always pass this test, regardless of what's in the filter.
That's mostly true. However, with one exception, Android treats all implicit intents passed to startActivity()
as if they contained at least one category: "android.intent.category.DEFAULT" (the CATEGORY_DEFAULT constant).
Therefore, activities that are willing to receive implicit intents must include "android.intent.category.DEFAULT"
in their intent filters. (Filters with "android.intent.action.MAIN" and "android.intent.category.LAUNCHER" settings are the exception.
They mark activities that begin new tasks and that are represented on the launcher screen.
They can include "android.intent.category.DEFAULT" in the list of categories, but don't need to.)
最后
以上就是精明小白菜为你收集整理的android Intent匹配,自定义action data category的全部内容,希望文章能够帮你解决android Intent匹配,自定义action data category所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复