设为首页收藏本站优领域

优领域

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
优领域 优领域 IT领域 Android开发 查看内容

Intent 对象在 Android 开发中的应用

2011-11-3 23:19| 发布者: admin| 查看: 3180| 评论: 0

摘要: 简介:Android 是一个开放性移动开发平台,运行在该平台上的应用程序具有完全平等的地位。我们可以利用现有的应用来帮助我们实现想要的功能。Android 应用程序区别于以往传统应用的显著特征是程序没有唯一的启动入口 ...

      简介: Android 是一个开放性移动开发平台,运行在该平台上的应用程序具有完全平等的地位。我们可以利用现有的应用来帮助我们实现想要的功能。Android 应用程序区别于以往传统应用的显著特征是程序没有唯一的启动入口。应用程序由不同核心组件构成,各个组件之间通过消息传递机制进行交互。而 Intent 作为消息传递的载体在 Android 应用开发中具有独特而重要的地位。本文将详细介绍 Intent 对象及其在 Android 开发中的应用,通过本文的学习可使你了解如何使用 Intent 在应用程序之间传递信息,以及如何通过 Intent 显式或隐式的方式启动应用或服务。

      3G 智能手机的新宠 Android

      随着 3G 网络越来越普及,3G 智能手机已经成为我们日常生活必备的通信工具。2007 年 11 月 Google 宣布与其他手机生产商、芯片生产商、软硬件供应商以及移动运营商所组成的开放手机联盟(Open Handset Alliance OHA)推出名为 Android 开放手机软件平台。Android 相比其它手机操作系统具有无可比拟的系统开放性、应用程序平等性以及快速方便的程序开发特性,吸引了越来越多的团体或个人软件开发者投入到以 Android 为核心的智能手机应用开发当中。

      一般的 Android 应用程序主要由 Activity、BroadcastReceiver、Service、ContentProvider 四大核心组件构成:Activity 作为 Android 应用的表示层通过继承 android.app.Activity类实现应用程序每一屏的显示,其是直接和用户交互的窗口。Service 组件主要应用在需要长时间运行于后台且没有用户交互界面或间歇性交互的场合。例如音乐播放器,当退出播放器控制台进行其他操作时,音乐仍旧在后台持续播放。当需要停止播放时,则需要重新进入播放器控制台进行操作。这种间歇性的用户交互就是通过 Service 组件实现的。广播 Broadcast 在 Android 系统中有着非常广泛的使用,而用于接收和处理广播消息的组件就是 BroadcastReceiver。若希望应用能够在系统启动后就立刻自动运行时,该应用就必须要接收和处理 BOOT_COMPLETED 的广播消息。Android 与其他传统手机操作系统不太一样的另一特征是数据文件和数据库数据等数据信息对于 Android 应用来说都是私有的,若应用需要将私有的数据提供给其他应用时就需要使用 Content Provider 组件。应用程序使用该组件提供的一整套标准接口与数据交互而不需要关心数据的具体位置。

      这四种核心组件中除了 ContentProvider 需要使用 ContentReceiver 连接之外,其余三大核心组件都需要使用 Intent 消息互通。其支持 Android 设备上安装的任意应用程序组件间的交互,这就把设备从一个相互独立的应用集合转变为一个开放互联的移动平台。可见 Intent 在 Android 应用开发中具有非常重要的地位。


      组件间连接的纽带 Intent

      Intent 在 Android 的官方 API 文档中是这样描述的:It is a passive data structure holding an abstract description of an operation to be performed. 它是一种数据结构,抽象描述一次将要被执行的操作,其作用是在程序运行过程中连接两个不同的组件。应用程序通过 Intent 向 Android 系统发出某种请求信息,Android 根据请求的信息内容选择能够处理该请求的组件。例如:使用 Android 手机拨打电话,当按下拨号发送键就会向 Android 系统发送一个具有 CALL_BUTTON 行为的 Intent 对象。Android 系统根据该请求信息,从注册应用的 AndroidManifest.xml 中找到能够处理该请求的电话号码拨号程序。输入电话号码并再次按下拨号发送键时,拨号程序会将一个包含 ACTION_CALL 和电话号码数据的 Intent 请求发送给 Android 系统,之后 Android 系统查找合适的应用程序进行处理。

      Intent 对象通常使用六个主要组成部分来抽象描述的请求信息,它们是组件名称,行为,数据 / 数据类型,类别,附加信息和标示位:

      Intent 对象使用组件名称描述传递消息的目标组件。这种明确指定目标组件名称的 Intent 称之为显式 Intent,系统会将显式 Intent 直接发送给目标组件。由于显式 Intent 需要指定目标组件,所以其更多的使用在应用内部组件间消息的传递。

      Action 行为记录了 Intent 消息将要执行的行为字符串或者将要广播的行为字符串。Android 系统虽然已经在 Intent 类中以静态常量的形式预先定义了一系列与系统有关的行为,但同样支持使用自定义行为字符串来触发应用中其他的组件。需要注意的是自定义行为字符串需要使用应用的全包名形式命名。

      数据 / 数据类型保存了目标组件将要操作的数据和数据类型,这些信息以 URI 的形式表示存储在 Intent 中。如在上述例子中,ACTION_CALL 行为需要操作的电话号码就是以“tel://number”的形式保存。

      类别属性主要描述被请求组件或执行行为动作的额外信息。Android 系统也为类别定义了一系列的静态常量字符串来表示 Intent 不同类别。例如 android.intent.category.LAUNCHER表示目标组件是应用程序中最优先被执行的组件。

      为组件提供的扩展信息或额外的数据被保存在 Intent 对象的附加信息中。附加信息采用键值对的结构,以 Bundle 对象的形式保存在 Intent 当中。附加信息其实是一个类型安全的容器,其实现就是将 HashMap 做了一层封装。与 HashMap 不同点在于,HashMap 可以将任何类型数据保存进去,值可以为任何的 java 对象。而附加信息虽采用键值对,但值只能保存基本数据对象类型,如 char,boolean,string 等。

      标示位主要标示如何触发目标组件以及如何看待被触发的目标组件。例如标示被触发的组件应该属于哪一个任务或者触发的组件是否是最近的 activity 等等。标示位可以是多个标示符的组合。


      如何解析和过滤 Intent

      通过上面的学习我们了解 Intent 作为组件间信息传递的纽带,用于发送请求或广播行为。对于接受端组件而言,Android 系统如何解析 Intent 信息的内容并启动合适的目标组件来响应 Intent 请求呢?我们将在本节了解 Intent 对象的过滤原则。

      上节我们提到明确指定组件名称的 Intent 为显式 Intent,Android 系统会直接启动组件名称指定的目标组件来处理该请求。那对于没有明确指定目标组件的 Intent,我们则称之为隐式 Intent。由于隐式 Intent 没有明确的目标,所以必须靠 Android 系统帮助应用查找合适的目标组件来处理该请求。对于此类 Intent 消息的解析机制的具体选择方法是:通过检索注册在 AndroidManifest.xml 文件中用于定义各个组件能够处理 Intent 消息的所有 IntentFilter 过滤器,并将这些过滤器与 Intent 消息内容进行比较。如果隐式 Intent 请求的内容匹配某一组件中 IntentFilter 过滤器的过滤规则,那么 Android 系统就会选择该组件作为处理隐式 Intent 消息的目标组件。

      组件为了声明自己能够处理哪种类型的 Intent 消息,需要在注册自己的同时声明一个或者多个过滤器规则 IntentFilter。若没有声明过滤器,则该组件只能够处理显式 Intent 消息而无法处理隐式 Intent 消息,即仅能够接收明确目标组件名称的 Intent 消息;声明过滤器规则的组件两种类型的 Intent 消息都可以处理。

      通过比较解析隐式 Intent 消息时主要进行以下三层过滤:行为过滤 (action)、数据过滤 (data/type)、类别过滤 (category)。

  • 行为过滤:

      过滤器规则中至少包含一条 action 行为描述,不包含 action 行为描述的过滤器不会匹配任何 Intent 消息;

      过滤器规则中定义的某条 action 行为描述同 Intent 消息中的行为定义相匹配,则该过滤器匹配 Intent 消息;

      Intent 消息没有包含具体的 action 行为定义,只要过滤器规则中定义一条 action 行为描述,则该过滤器匹配 Intent 消息;

  • 数据过滤:

      Intent 消息没有包含任何 URI 数据或者具体数据内容的信息,仅能匹配不包含任何数据过滤信息的过滤器;

      Intent 中没有提供数据类型,系统将从数据中推算数据类型。Intent 消息中推算的数据类型如果包含在过滤器规则中声明的数据类型列表时,该消息匹配该过滤器,否则该消息将会被过滤器过滤;

      Intent 中的数据不是具体内容而是 URI 时,则需要该 URI 分为三部分进行过滤:schema、authority 和 path。只有上述三部分完全匹配过滤器规则声明时,该过滤器匹配该 Intent 消息;

      Intent 消息仅包含数据类型没有提供具体内容或者 URI 数据时,该 Intent 消息仅能匹配包含该数据类型声明且仅声明数据类型的 IntentFilter 过滤器;

  • 类别过滤:

      Intent 消息中定义的所有类别属性如果是过滤器规则中声明的类别列表的全集或子集时,该 Intent 消息才能匹配该过滤器,否则该 Intent 消息将会被该过滤器过滤掉;

      过滤器规则不声明任何类别信息,则仅能匹配不包含任何类别定义的 Intent 消息;


相关阅读

网站统计|优领域|优领域 ( 粤ICP备12011853号-1 )  

GMT+8, 2019-1-22 06:12 , Processed in 0.088946 second(s), 12 queries .

Copyright © 2008-2014 优领域

回顶部