当前位置:  编程技术>移动开发
本页文章导读:
    ▪Intents and Intent Filters-Intent Resolution        Intents and Intent Filters---Intent Resolution Intent ResolutionIntents 可以分成两类:    1、Explicit intents (显式intents-指定了目标组件名) designate the target component by its name (the component name field, mentioned earlier.........
    ▪ Intents and Intent Filters-Intent filters        Intents and Intent Filters--Intent filters Intent filters   To inform the system which implicit intents they can handle, activities, services, and broadcast receivers can have one or more intent filters. Each filter describes a capability of the com.........
    ▪ 批改WTK工作路径       修改WTK工作路径 自定义WTK工作路径 今天开始看如何编手机游戏,下了WTK,但是发现新建的项目无法更改保存路径,就上网找了下方法,现转载如下: 默认情况下,MIDP应用程序的项目都存储.........

[1]Intents and Intent Filters-Intent Resolution
    来源: 互联网  发布时间: 2014-02-18
Intents and Intent Filters---Intent Resolution
Intent Resolution

Intents 可以分成两类:

    1、Explicit intents (显式intents-指定了目标组件名) designate the target component by its name (the component name field, mentioned earlier, has a value set). Since component names would generally not be known to developers of other applications, explicit intents are typically used for application-internal messages — such as an activity starting a subordinate service or launching a sister activity.【翻译:显式intent通常是用于在一个应用中需要激活某个activity的时候使用。】

    2、Implicit intents(隐式intents-没有指定目标组件名) do not name a target (the field for the component name is blank). Implicit intents are often used to activate components in other applications.【翻译:隐式intent通常是在需要激活不同应用之间的某个activity的时候使用。】

   Android delivers an explicit intent to an instance of the designated target class. Nothing in the Intent object other than the component name matters for determining which component should get the intent.【翻译:Android系统在判定哪个组件响应一个显式intent的时候,intent实例中的组件名属性是最为关键的匹配判定依据】

   A different strategy is needed for implicit intents. In the absence of a designated target, the Android system must find the best component (or components) to handle the intent — a single activity or service to perform the requested action or the set of broadcast receivers to respond to the broadcast announcement. It does so by comparing the contents of the Intent object to intent filters, structures associated with components that can potentially receive intents. Filters advertise the capabilities of a component and delimit the intents it can handle. They open the component to the possibility of receiving implicit intents of the advertised type. If a component does not have any intent filters, it can receive only explicit intents. A component with filters can receive both explicit and implicit intents.

翻译:由于隐式intent没有指定目标组件名,这时候Android系统判定目标组件需要一个不同的匹配判定策略,借助该策略来告知 Android系统哪个最为适合的组件来响应该隐式intent,这个基本的判定策略是把当前intent内容与当前应用的manifest文件中的所有 intent过滤器做比对,intent过滤器的作用是声明某个组件所能响应的隐式intent类型。如果manifest文件中的组件声明中没有定义 intent过滤器,那么该组件只能响应显式intent;如果一个组件声明中定义了intent过滤器,那么该组件既可以响应隐式intent也可以响应显式intent。

Only three aspects of an Intent object are consulted when the object is tested against an intent filter:【翻译:针对隐式intent的判定策略只对intent实例中以下三类特征信息来和相关的过滤器做比对】

action
data (both URI and data type)
category

The extras and flags play no part in resolving which component receives an intent.( 翻译:extras和flags不是Android系统判定哪个目标组件响应隐式intent的依据。)

需要说明的是:显式intent依然是可以使用extras和flags属性来向目标组件传递数据和向Android 系统发送启动、管理目标组件的方式、方法指令的。换句话说,如果你是使用显式intent实例来激活目标组件(如activity)的时候,首先需要给你的intent设置目标组件名或在构造intent实例时候直接指定目标组件类名(称之为显式intent);然后,如果目标组件需要接受数据,就用 intent.putExtra方法设置要传递的数据;如果说你希望进一步通过当前intent实例告知运行环境系统如何创建或管理目标组件实例的话,就使用 intent.setFlags(flags)方法设置相应的控制指令。

    
[2] Intents and Intent Filters-Intent filters
    来源: 互联网  发布时间: 2014-02-18
Intents and Intent Filters--Intent filters
Intent filters

   To inform the system which implicit intents they can handle, activities, services, and broadcast receivers can have one or more intent filters. Each filter describes a capability of the component, a set of intents that the component is willing to receive. It, in effect, filters in intents of a desired type, while filtering out unwanted intents — but only unwanted implicit intents (those that don't name a target class). An explicit intent is always delivered to its target, no matter what it contains; the filter is not consulted. But an implicit intent is delivered to a component only if it can pass through one of the component's filters.

翻译:三类核心组件为了使得系统知晓哪些隐式intent对象可以被自己所响应,通常声明一个或多个intent过滤器,过滤器的作用是声明当前组件的能力,表示当前组件所能接受的intent对象。需要注意的是如果是显式intent,intent过滤器是不起任何作用的,这时候显式intent直接发送给目标组件实例(当然你可以使用extras和flags来传递必要的数据和发送相关的系统指令)。而对于隐式intent,只有当它通过某个 intent过滤器三个测试项的检测后才可以被发送到某个组件实例。

A component has separate filters for each job it can do, each face it can present to the user. For example, the NoteEditor activity of the sample Note Pad application has two filters — one for starting up with a specific note that the user can view or edit, and another for starting with a new, blank note that the user can fill in and save. (All of Note Pad's filters are described in the Note Pad Example section, later.)

翻译:一个组件可以执行不同类型的操作,在manifest文件中的组件元素的定义中,针对不同的操作可以分别多个intent过滤器子元素,例如在该系列文档中提供的Note Pad样例应用中的NoteEditor activity,就定义了两个过滤器,一个过滤器针对用户查阅或编辑Note的操作,另外一个过滤器针对用户新建Note的操作,换句话说表示该 activity可以执行两种不同类型的操作。

Filters and security   An intent filter cannot be relied on for security. While it opens a component to receiving only certain kinds of implicit intents, it does nothing to prevent explicit intents from targeting the component. Even though a filter restricts the intents a component will be asked to handle to certain actions and data sources, someone could always put together an explicit intent with a different action and data source, and name the component as the target.【翻译:intent过滤器不能用于安全控制管理,intent过滤器的作用是为某个隐式intent打开一个组件,它无法阻止显式intent直接启动目标组件。】

  An intent filter is an instance of the IntentFilter class. However, since the Android system must know about the capabilities of a component before it can launch that component, intent filters are generally not set up in Java code, but in the application's manifest file (AndroidManifest.xml) as <intent-filter> elements. (The one exception would be filters for broadcast receivers that are registered dynamically by calling Context.registerReceiver(); they are directly created as IntentFilter objects.)

翻译: intent filter是IntentFilter类的实例,然而,由于Android系统在它启动某个组件实例之前,就必须知道这个组件能做什么操作,所以intent过滤器的创建是不会使用Java代码来创建的的,而是在应用的manifest文件中直接定义intentFilter元素的。(这里有一个例外:直接通过Context.registerReceiver()方法动态注册的广播接收组件的过滤器是直接创建过滤器实例的。)

A filter has fields that parallel the action, data, and category fields of an Intent object. An implicit intent is tested against the filter in all three areas. To be delivered to the component that owns the filter, it must pass all three tests. If it fails even one of them, the Android system won't deliver it to the component — at least not on the basis of that filter. However, since a component can have multiple intent filters, an intent that does not pass through one of a component's filters might make it through on another.

翻译:一个过滤器中包含与隐式intent对等的三类信息(action, data, category),一个隐式intent要能够激活某个组件的前提是:必须通过某个过滤器这三项(action, data, category)比对测试,

Each of the three tests is described in detail below:

一、Action test
    An <intent-filter> element in the manifest file lists actions as <action> subelements. For example【翻译:manifest文件中的intent过滤器元素中可以如下定义action子元素:】:

   
引用
<intent-filter . . . >
        <action android:name="com.example.project.SHOW_CURRENT" />
        <action android:name="com.example.project.SHOW_RECENT" />
        <action android:name="com.example.project.SHOW_PENDING" />
        . . .
    </intent-filter>


    As the example shows, while an Intent object names just a single action, a filter may list more than one. The list cannot be empty; a filter must contain at least one <action> element, or it will block all intents.【翻译:上例中的过滤器至少应该有一个action,否则该过滤器将阻塞所有隐式intent。】

    To pass this test, the action specified in the Intent object must match one of the actions listed in the filter. If the object or the filter does not specify an action, the results are as follows: 【翻译:一个隐式intent要想通过某个intent过滤器的action测试,该intent实例的action必须能够和当前intent过滤器中的某个action匹配。如果intent实例或是intent过滤器中没有指定action的话,将会发生以下测试结果】:

        1、If the filter fails to list any actions, there is nothing for an intent to match, so all intents fail the test. No intents can get through the filter.【翻译:如果是intent过滤器中没有指定action,那么匹配肯定失败,导致该过滤器将阻塞所有隐式intent。】

        2、On the other hand, an Intent object that doesn't specify an action automatically passes the test — as long as the filter contains at least one action.【翻译:如果是intent实例中没有指定action的话,只要该过滤器声明了至少一个action的话,该intent实例将通过当前action测试。】


二、Category test
    An <intent-filter> element also lists categories as subelements. For example:【翻译:manifest文件中的intent过滤器元素中可以如下定义category子元素:】

  
引用
<intent-filter . . . >
        <category android:name="android.intent.category.DEFAULT" />
        <category android:name="android.intent.category.BROWSABLE" />
        . . .
    </intent-filter>


    Note that the constants described earlier for actions and categories are not used in the manifest file. The full string values are used instead. For instance, the "android.intent.category.BROWSABLE" string in the example above corresponds to the CATEGORY_BROWSABLE constant mentioned earlier in this document. Similarly, the string "android.intent.action.EDIT" corresponds to the ACTION_EDIT constant.【翻译:注意:在manifest文件中,过滤器元素中定义的action、category子元素不使用Android API中的常量名,而是直接使用常量值。】

    For an intent to pass the category test, every category in the Intent object must match a category in the filter. The filter can list additional categories, but it cannot omit any that are in the intent.

    翻译:一个intent实例要想通过类别测试的话,在当前这个intent实例中的每个类别信息都必须和当前的intent过滤器中的类别列表中的值匹配上,也就是说当前intent过滤器中可以有多于该intent实例中的类别信息个数。

    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.) See Using intent matching, later, for more on these filters.)

    翻译:原则上说,如果当前这个intent实例中没有类别信息的话,它总是可以通过类别测试的,绝大多数场合是这样的,但是也有个例外:由于 Android系统对于通过StartActivity()方法传递的隐式intent都会自动添加一个 android.intent.category.DEFAULT 类别属性信息,所以对于intent过滤器来说常常必须定义一个android.intent.category.DEFAULT 类别属性信息。对于那些定义了android.intent.action.MAIN 和 android.intent.category.LAUNCHER 类别的intent过滤器来说不是因为这个原因而在intent过滤器中定义了android.intent.category.LAUNCHER类别属性, 标记有这两个类别信息的intent过滤器有特殊的含义:要求当前intent过滤器所关联的组件(Activity)在设备发射屏以新task的方式被立即激活(按下menu键后),而且这时候包含android.intent.category.LAUNCHER 类别不是必须的。

三、Data test
    Like the action and categories, the data specification for an intent filter is contained in a subelement. And, as in those cases, the subelement can appear multiple times, or not at all. For example:

   
引用
<intent-filter . . . >
        <data android:mimeType="video/mpeg" android:scheme="http" . . . />
        <data android:mimeType="audio/mpeg" android:scheme="http" . . . />
        . . .
    </intent-filter>


    Each <data> element can specify a URI and a data type (MIME media type). There are separate attributes — scheme, host, port, and path — for each part of the URI:

    翻译:每个data元素由URI和data类型组成,其中URI是由:schema、host、Port、path四部分组成的。

    scheme://host:port/path

    For example, in the following URI,

    content://com.example.project:200/folder/subfolder/etc

    the scheme is "content", the host is "com.example.project", the port is "200", and the path is "folder/subfolder/etc". The host and port together constitute the URI authority; if a host is not specified, the port is ignored.

    翻译:上例中的scheme="content", host ="com.example.project", port ="200", path= "folder/subfolder/etc", URI中的host和Port组成了URI的authority,如果host未指定的话那么Port即使指定了也被系统忽略。

    Each of these attributes is optional, but they are not independent of each other: For an authority to be meaningful, a scheme must also be specified. For a path to be meaningful, both a scheme and an authority must be specified.

    翻译:URI中的各个组成部分是可选的,但是又是关联的,如果要使得URI的authority有意义,必须先指定scheme,要使得path有意义,又必须先指定URI的authority 。

    When the URI in an Intent object is compared to a URI specification in a filter, it's compared only to the parts of the URI actually mentioned in the filter. For example, if a filter specifies only a scheme, all URIs with that scheme match the filter. If a filter specifies a scheme and an authority but no path, all URIs with the same scheme and authority match, regardless of their paths. If a filter specifies a scheme, an authority, and a path, only URIs with the same scheme, authority, and path match. However, a path specification in the filter can contain wildcards to require only a partial match of the path.

    翻译:data测试中的URI测试通过的原则是:只要当前intent过滤器中列举出的URI部分与当前intent中的URI信息可以匹配即通过Uri测试。需要注意的是在intent过滤器的URI中的path定义中可以使用通配符

    The type attribute of a <data> element specifies the MIME type of the data. It's more common in filters than a URI. Both the Intent object and the filter can use a "*" wildcard for the subtype field — for example, "text/*" or "audio/*" — indicating any subtype matches.

    翻译:注意 在intent过滤器的data 类型定义中可以使用通配符

    The data test compares both the URI and the data type in the Intent object to a URI and data type specified in the filter. The rules are as follows:

       1. An Intent object that contains neither a URI nor a data type passes the test only if the filter likewise does not specify any URIs or data types.
       2. An Intent object that contains a URI but no data type (and a type cannot be inferred from the URI) passes the test only if its URI matches a URI in the filter and the filter likewise does not specify a type. This will be the case only for URIs like mailto: and tel: that do not refer to actual data.
       3. An Intent object that contains a data type but not a URI passes the test only if the filter lists the same data type and similarly does not specify a URI.
       4. An Intent object that contains both a URI and a data type (or a data type can be inferred from the URI) passes the data type part of the test only if its type matches a type listed in the filter. It passes the URI part of the test either if its URI matches a URI in the filter or if it has a content: or file: URI and the filter does not specify a URI. In other words, a component is presumed to support content: and file: data if its filter lists only a data type.

    翻译:data 测试基本原则如下:

       1. 如果一个Intent对象中既不包含URI也不包含data type,这时候如果当前intent过滤器同样也没有指定URI和data type的时候,data测试通过。

       2. 如果一个Intent对象中包含URI但是不包含date type(而且数据类型无法从URI中推断出),这时候如果当前intent过滤器同样只是指定了相应的URI的场合,data测试通过。以上场合仅仅适用于 URIs 是 mailto: 和 tel: 无法推断实际数据类型的时候。

       3. 如果一个Intent对象中包含date type但是不包含URI,这时候如果当前intent过滤器同样只是例举了相应的date type的场合,data测试通过。

       4. 如果一个Intent对象中同时包含URI和date type(或数据类型可以从URI中推断出),这时候如果当前intent过滤器列举了相应的date type的场合,data type部分的测试通过。如果当前intent过滤器也列举了相应的URI,则通过URI部分的测试。这时候如果说当前intent指定的data URI是content:或 file:的时候,即使当前过滤器没有指定URI,也通过URI部分的测试。换句话说,当组件过滤器中仅仅指定了data类型而没有明确指定URI的时候,组件是默认支持URI==content:或 file:的。

If an intent can pass through the filters of more than one activity or service, the user may be asked which component to activate. An exception is raised if no target can be found. 【翻译:如果一个intent通过一个以上的activity或service的过滤器测试的话,这时候系统将让用户选择哪个组件来响应该intent请求,如果没有找到目标组件来响应当前intent的话,将发生异常。】

Common cases

The last rule shown above for the data test, rule (d), reflects the expectation that components are able to get local data from a file or content provider. Therefore, their filters can list just a data type and do not need to explicitly name the content: and file: schemes. This is a typical case. A <data> element like the following, for example, tells Android that the component can get image data from a content provider and display it【翻译:上面说到的第四个原则使得组件能够从文件或内容提供器中读取本地数据,所以,作为过滤器可以仅仅例举数据类型、不需要明确指定content: 和file:schemes,这是很典型的,像下面的<data>元素中就是这样做的,它告知Android系统该组件可以从内容提供器中获得图像数据,然后显示相关的图像数据。】:

引用
<data android:mimeType="image/*" />


Since most available data is dispensed by content providers, filters that specify a data type but not a URI are perhaps the most common.【翻译:由于绝大多数数据都是由内容提供器提供的,那些指定了数据类型而没有指定URI的过滤器是这样的典型。】

Another common configuration is filters with a scheme and a data type. For example, a <data> element like the following tells Android that the component can get video data from the network and display it:【翻译:另外一个很常见的配置过滤器的方式是使用scheme 和数据类型来配置过滤器,例如下面的例子,告知Android系统该组件可以通过网络取得视频数据并显示该视频数据。】
引用

<data android:scheme="http" android:type="video/*" />


Consider, for example, what the browser application does when the user follows a link on a web page. It first tries to display the data (as it could if the link was to an HTML page). If it can't display the data, it puts together an implicit intent with the scheme and data type and tries to start an activity that can do the job. If there are no takers, it asks the download manager to download the data. That puts it under the control of a content provider, so a potentially larger pool of activities (those with filters that just name a data type) can respond.【翻译:想一下:当用户根据一个链接要显现相关的画面数据,这时候浏览器应用程序首先做的是显示数据,如果无法显示的话,将会创建一个隐式intent,其中包含了数据类型和schema等信息,然后请求一个activity来做数据显示工作,显示数据需要下载管理器先下载数据,然后把下载的数据交给某个内容提供器控制。。。】

Most applications also have a way to start fresh, without a reference to any particular data. Activities that can initiate applications have filters with "android.intent.action.MAIN" specified as the action. If they are to be represented in the application launcher, they also specify the "android.intent.category.LAUNCHER" category:【翻译:多数应用也有另外一种途径来启动更新(无需对任何数据的引用),activity实例可以设定它自己的action属性="android.intent.action.MAIN",如果这个实例需要在发射台上呈现出来的话,可以设定它的category属性="android.intent.category.LAUNCHER"】

引用
<intent-filter . . . >
    <action android:name="code android.intent.action.MAIN" />
    <category android:name="code android.intent.category.LAUNCHER" />
</intent-filter>

    
[3] 批改WTK工作路径
    来源: 互联网  发布时间: 2014-02-18
修改WTK工作路径

自定义WTK工作路径

今天开始看如何编手机游戏,下了WTK,但是发现新建的项目无法更改保存路径,就上网找了下方法,现转载如下:

默认情况下,MIDP应用程序的项目都存储在安装路径\apps目录下,开发者可能希望能够设定自已的开发目录。Ktoolar提供一种配置机制,允许用户修改开发路径,其方法是:

1.         在\wtklib\Windows\目录下找到ktools.properties并打开它。

2.         新建一个目录用来作为新的J2ME WTK应用程序目录。比如我是:E:\mobile_prj

3.         根据下面的格式在ktools.properties文件中加一行来改变默认的设置。kevm.apps.dir:<工程目录路径>

在目录路径中如果有反斜综字符(\),需要在它前面再加一个反斜线字符,而于目录路径中不能包含任何空格字符。例如:
kvem.apps.dir: E:\\mobile_prj

4.         保存ktools.properties文件,重新启动WTK使修改后的设置生效


    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3