- 浏览: 915627 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
天天来注册:
...
try catch finally 用法 -
tadpole_java:
谢谢你的分享。
二十七、Qt数据库(七)QSqlRelationalTableModel(转) -
359449749tan:
android之EditText文本监听(addTextChangedListener) -
michael_wang:
人过留名 多谢分享
Android NOtification 使用 -
wilsonchen:
wangqi0614 写道这个删除是删除所有的把?能不能值删除 ...
Android的SharedPreferences保存与删除数据简单实例
5 Basic Components
1. Activity
2. Service
3. Broadcast Receiver
4. Content Provider
5. Intent
Activity —— 应用表示层(基类Activity)
应用程序中的每个屏幕都是通过继承和扩展基类Activity来实现的。
同一应用中的每个Activity是相互独立的。程序启动后显示的第一幅画面是应用程序的第一个Activity(默认窗口),而后可以根据需要从这个Activity启动另一个新的Activity。
Activity利用View来实现应用中的GUI(用户直接通过GUI和应用程序做交互)。Activity窗口内的可见内容通过基类View提供。使用Activity.setContentView()方法设置当前Activity中的View对象。
l 每个View对象控制着窗口内的一个矩形空间;
l View是一种层次化结构,Parent View中的布局属性会被子View继承;
l 位于View层次关系最底层的子View对象所代表的矩形空间就是跟用户进行交互的地方
Activity状态回调:
l onCreate
l onStart
l onRestart
l onResume
l onPause
l onStop
l onDestroy
Service —— 没有可见的用户界面,但能够长时间运行于后台(基类Service)
运行于应用程序进程的主线程中,因此Service不会阻塞其他组件和用户界面。
Service是不能自己启动的,必须通过Context对象(如一个Activity)调用startService或bindService方法来启动(用这两种方法启动的Service的生命周期不同)。
1. 调用startService方法
a) 若Service没有启动,则首先会调用该Service的onCreate方法,然后再调用onStart方法。
b) 若Service已经启动,则会直接调用onStart方法
c) 该方法启动的Service,可以通过Context对象调用stopService来关闭,也可以通过Service自身调用stopSelf()或stopSelfResult()来关闭,关闭之前调用onDestory方法。
2. 调用bindService方法,使当前Context对象通过一个ServiceConnection的对象绑定到所指定的Service
a) 若Service没有启动,则首先会调用该Service的onCreate方法初始化启动,然后调用Service的onBind方法初始化绑定。
b) 如果绑定Service的Context对象被销毁时,被绑定的Service也会调用onUnbind 和 onDestroy方法停止运行
c) 注意: BroadcastReceiver是不能绑定服务的。
d) 一个绑定Service的Context对象还可以通过unbindService()来取消对服务的绑定。
e) 取消时,Service会调用unbind方法,若Service是通过bindService来启动的,还会调用onDestroy方法来停止服务。
Service状态回调:
l onCreate
l onStart
l onBind
l onRebind
l onUnbind
l onDestroy
Broadcast Receiver —— 用户接收广播通知的组件(基类BroadcastReceiver)
Android中的广播要么来自于系统,要么来自普通应用程序。
很多事件都可能导致系统广播,如手机所在时区发生变化,电池电量低,用户改变系统语言设置等。
来自普通应用程序,如一个应用程序通知其他应用程序某些数据已经下载完毕。
为了响应不同的事件通知,应用程序可以注册不同的Broadcast Receiver。所有的Broadcast Receiver都继承自基类BroadcastReceiver。
BroadcastReceiver自身并不实现图形用户界面,但是当它收到某个通知后,BroadcastReceiver可以启动Activity作为响应,或者通过NotificationMananger提醒用户。
BroadcastReceiver是对发送出来的Broadcast进行过滤接收并响应的一类组件。
发送Broadcast信息
1. 把要发送的信息和用于过滤得信息(如Action、Category)装入一个Intent对象
2. 调用Context.sendBroadcast()、sendOrderBroadcast()、sendStickyBroadcast()方法,广播该Intent对象
3. 使用sendBroadcast() 或sendStickyBroadcast()方法发出去的Intent,所有满足条件的BroadcastReceiver都会随机地执行其onReceive()方法;
4. 而sendOrderBroadcast()发出去的Intent,会根据BroadcastReceiver注册时IntentFilter设置的优先级的顺序来执行,相同优先级的BroadcastReceiver则是随机执行
5. sendStickyBroadcast()方法主要的不同是,Intent在发送后一直存在,并且在以后调用registerReceiver()注册相匹配的Intent时会把这个Intent直接返回。
6. 若在使用sendBroadcast()方法时指定了接收的权限,这只有在AndroidManifest.xml中用<uses-permission>标签声明了拥有此权限的BroadcastReceiver才会有可能接收到发送来Broadcast。
7. 若在注册BroadcastReciever时,指定了可接收的Broadcast的权限,则只有在包内的AndroidManifest.xml中用<uses-permission>标签声明了,拥有此权限的Context对象所发送的Broadcast才有可能被这个BroadcastReceiver所接收。
接收Broadcast消息
1. 继承BroadcastReceiver 类,并实现onReceive方法
2. 注册Broadcast Receiver(有2种方法:一种方法是,静态地在AndroidManifest.xml中用<receiver>标签声明,并在标签内用<intent-filter>标签设置过滤器; 另一种方法,动态地在代码中先定义并设置好一个IntentFilter对象,然后再需要注册的地方调用Context.registerReceiver()方法) (取消注册时,调用Context.unregisterReceiver()方法)
Content Provider —— 为解决应用程序间数据通信、共享的问题(基类ContentProvider)
在Android中,每个应用程序都是用自己的用户ID并在自己的进程中运行。这样的好处是,可以有效地保护系统及应用程序,避免被其他不正常德应用程序所影响,每个进程都拥有独立的进程地址空间和虚拟空间。
Content Provider可以将应用程序特定的数据提供给另一个应用程序使用。其数据存储方式可以是Android文件系统、SQLite数据库或者其他合理的方式。
当数据需要在应用程序间共享时,我们就可以利用ContentProvider为数据定义一个URI。之后,其他应用程序对数据进行查询或者修改时,只需要从当前上下文对象获得一个ContentResolver, 然后传入响应的URI就可以了。
Content Provider 继承自基类ContentProvider,并且实现了一组标准接口。通过这组接口,其他应用程序能对数据进行读写和存储。然而,需要使用数据的应用程序并不是直接调用这组方法,而是通过调用ContentResolver对象的方法来完成。ContentResolver对象可以与任意ContentProvider通信。
要为当前应用程序的私有数据定义URI,就需要专门定义一个继承自ContentProvider的类,然后根据不同的操作调用的方法去实现这些方法的功能。
ContentResolver类为应用程序提供了接入Content机制的方法。要构造一个ContentResolver对象可以为构造方法ContentResolver(Context context)传入一个Context对象,也可以直接通过Context对象调用getContentResolver()方法获得 —— 有的ContentResolver对象后,就可以通过调用其query()、insert()、update()等方法来对数据进行操作了。
一旦需要以上4种Android应用程序基本组件完成请求,Android会首先确认该组件所在进程是否运行,如果没有运行,Android将先启动进程,同时确认被请求组件的实例是否存在,否则将创建一个新的组件实例。
Intent —— 连接组件的纽带
以上4种基本组件中,除了Content Provider是通过Content Resolver激活外,其他3种组件Activity、Service和Broadcast Receiver都是由Intent异步消息激活的。
Intent在不同的组件之间传递消息,将一个组件的请求意图传给另一个组件。因此,Intent是包含具体请求信息的对象。
针对不同的组件,Intent所包含的消息内容有所不同,且不同组件的激活方式也不同, 且不同类型组件有传递Intent的不同方式。
Intent是一种运行时绑定(runtime binding)机制,它能够在程序运行的过程中连接两个不同的组件。通过Intent,你的程序可以向Android表到某种请求或者意愿,Android会根据意愿的内容选择适当的组件来处理请求。
l 激活一个新的Activity,或者让一个现有的Activity执行一个新的操作,可以通过调用如下两种方法(这两汇总方法需要传入的Intent参数称为Activity Action Intent):
1. Context.startActivity()
2. Activity.startActivityForResult()
l 启动一个新的服务,或者向一个已有的服务传递新的指令,可以调用如下两种方法:
1. Context.startService()
2. Context.bindService()
l 发送广播Intent(所有已注册的拥有与之相匹配IntenFilter的BroadcastReceiv就会被激活),可以调用如下三种方法:
1. Context.sendBroadcast()
2. Context.sendOrderBroadcast()
3. Context.sendStickBroadcast()
Intent一旦发出,Android都会准确找到相匹配的一个或多个Activity、Service或BroadcastReceiver作响应。所以,不同类型的Intent消息不会出现重叠,BroadcastIntent消息只会发送给BroadcastReceiver,而绝不可能发送给Activity或Server。有startActivity()传递的消息也只可能发送给Activity,由startService()传递的Intent只可能发送给Service。
Intent对象抽象地描述了执行操作,Intent的主要组成部分;
1. 目标组件名称。[可选项]
a) 组件名称是一个ComponentName对象,是目标组件类名和目标组件所在应用程序包的组合
b) 组件中的包名不一定要和manifes文件中包名完全匹配
c) 如果Intent消息中指明了目标组件的名称,这就是一个显示消息,Intent会传递给指明的组件。
d) 如果目标组件名称并没有指定,Android则通过Intent内的其他信息和已注册的IntentFilter的比较来选择合适的目标组件
2. Action [隐式比较]
a) 描述Intent所触发动作的名字字符串。
b) 理论上Action可以为任何字符串,而与Android系统应用有关的Action字符串以静态字符串常量的形式定义在了Intent类中。
3. Data [隐式比较]
a) 描述Intent要操作的的数据的URI和数据类型。
b) 正确设置Intent的数据对于Android寻找系统中匹配Intent请求的组件很重要。
4. Category [隐式比较]
a) 是对被请求组件的额外描述信息。
b) Android也在Intent类中定义了一组静态字符串常量表示Intent不同的类别。
5. Extra
a) 当我们使用Intent连接不同组件时,有时需要在Intent中附加额外的信息,以便将数据传递给目标Activity。
b) Extra用键值对结构保存在Intent对象当中,Intent对象通过调用方法putExtras() 和 getExtras()来存储和获取Extra
c) Extra是以Bundle对象的形式来保存的,Bundle对象提供了一系列put和get方法来设置、提取相应键值信息。
d) 在Intent类中同样为Android系统应用的一些Extra的键值定义了静态字符串常量。
6. Flag
决定Intent目标组件的因素:
n 在显式Intent消息中,决定目标组件的唯一要素就是组件名称(不用再定义其他Intent内容)
n 而隐式Intent消息中,由于没有目标组件名称,所以必须由Android系统帮助应用程序寻找与Intent请求意图最匹配的组件。
n 隐式Intent消息中目标组件具体选择方法是:android将Intent的请求内容和一个叫做IntentFilter的过滤器比较,IntentFilter中包含系统中所有可能的待选组件。如果IntentFilter中某一个组件匹配隐式Intent请求内容,那么Android就选择该组件作为该隐式Intent的目标组件。
IntenFilter
应用程序的组件为了告诉Android自己能响应、处理哪些隐式Intent请求,可以声明一个甚至多个IntentFilter。
每个IntentFilter描述该组件所能响应Intent请求的能力 —— 组件希望接收什么类型的请求行为,什么类型的请求数据。
隐式Intent和IntentFilter进行比较时的三要素:Action、Data、Category。
一个隐式Intent请求要能够传递给目标组件,必需通过以上三个方面的检查。如果任何一方面不匹配,Android都不会将该隐式Intent传递给目标组件。
<intent-filter>
<action android:name=””/>
<category android:name=””/>
<data android:type=”” android:scheme=”” android:authority=”” android:path=””/>
</intent-filter>
1. 动作测试
a) 一条 <intent-filter> 中至少应该包含一个<action>, 否则任何Intent请求都不能和该<intent-filter> 匹配。
b) 如果IntentFilter 中没有包含任何Actino类型,那么无论什么Intent请求都无法和这条IntentFilter匹配。
c) 如果Intent请求中没有设定Action类型,那么只要IntentFilter中包含有Action类型,这个Intent请求将顺利通过IntentFilter的测试。
2. 类别测试
a) 只有当Intent请求中所有的Category与组件中的某一个IntentFilter的category完全匹配,才会让该Intent请求通过测试,IntentFilter中的多余category声明并不会导致匹配失败。
b) 一个没有指定任何类别的IntentFilter仅仅只会匹配没有设置类别的Intent请求。
3. 数据测试
a) <data>元素指定了希望接受的Intent请求的数据URI和数据类型:URI被分成三部分类进行匹配,scheme、authority和 path.
b) 使用 setData设定的Intent请求的URI数据类型和scheme,必须与IntentFilter中指定的一致
若IntentFilter中还指定了authority或path,他们也需要相匹配才会通过测试。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/CrazyJeff_Liu/archive/2010/04/30/5545806.aspx
1. Activity
2. Service
3. Broadcast Receiver
4. Content Provider
5. Intent
Activity —— 应用表示层(基类Activity)
应用程序中的每个屏幕都是通过继承和扩展基类Activity来实现的。
同一应用中的每个Activity是相互独立的。程序启动后显示的第一幅画面是应用程序的第一个Activity(默认窗口),而后可以根据需要从这个Activity启动另一个新的Activity。
Activity利用View来实现应用中的GUI(用户直接通过GUI和应用程序做交互)。Activity窗口内的可见内容通过基类View提供。使用Activity.setContentView()方法设置当前Activity中的View对象。
l 每个View对象控制着窗口内的一个矩形空间;
l View是一种层次化结构,Parent View中的布局属性会被子View继承;
l 位于View层次关系最底层的子View对象所代表的矩形空间就是跟用户进行交互的地方
Activity状态回调:
l onCreate
l onStart
l onRestart
l onResume
l onPause
l onStop
l onDestroy
Service —— 没有可见的用户界面,但能够长时间运行于后台(基类Service)
运行于应用程序进程的主线程中,因此Service不会阻塞其他组件和用户界面。
Service是不能自己启动的,必须通过Context对象(如一个Activity)调用startService或bindService方法来启动(用这两种方法启动的Service的生命周期不同)。
1. 调用startService方法
a) 若Service没有启动,则首先会调用该Service的onCreate方法,然后再调用onStart方法。
b) 若Service已经启动,则会直接调用onStart方法
c) 该方法启动的Service,可以通过Context对象调用stopService来关闭,也可以通过Service自身调用stopSelf()或stopSelfResult()来关闭,关闭之前调用onDestory方法。
2. 调用bindService方法,使当前Context对象通过一个ServiceConnection的对象绑定到所指定的Service
a) 若Service没有启动,则首先会调用该Service的onCreate方法初始化启动,然后调用Service的onBind方法初始化绑定。
b) 如果绑定Service的Context对象被销毁时,被绑定的Service也会调用onUnbind 和 onDestroy方法停止运行
c) 注意: BroadcastReceiver是不能绑定服务的。
d) 一个绑定Service的Context对象还可以通过unbindService()来取消对服务的绑定。
e) 取消时,Service会调用unbind方法,若Service是通过bindService来启动的,还会调用onDestroy方法来停止服务。
Service状态回调:
l onCreate
l onStart
l onBind
l onRebind
l onUnbind
l onDestroy
Broadcast Receiver —— 用户接收广播通知的组件(基类BroadcastReceiver)
Android中的广播要么来自于系统,要么来自普通应用程序。
很多事件都可能导致系统广播,如手机所在时区发生变化,电池电量低,用户改变系统语言设置等。
来自普通应用程序,如一个应用程序通知其他应用程序某些数据已经下载完毕。
为了响应不同的事件通知,应用程序可以注册不同的Broadcast Receiver。所有的Broadcast Receiver都继承自基类BroadcastReceiver。
BroadcastReceiver自身并不实现图形用户界面,但是当它收到某个通知后,BroadcastReceiver可以启动Activity作为响应,或者通过NotificationMananger提醒用户。
BroadcastReceiver是对发送出来的Broadcast进行过滤接收并响应的一类组件。
发送Broadcast信息
1. 把要发送的信息和用于过滤得信息(如Action、Category)装入一个Intent对象
2. 调用Context.sendBroadcast()、sendOrderBroadcast()、sendStickyBroadcast()方法,广播该Intent对象
3. 使用sendBroadcast() 或sendStickyBroadcast()方法发出去的Intent,所有满足条件的BroadcastReceiver都会随机地执行其onReceive()方法;
4. 而sendOrderBroadcast()发出去的Intent,会根据BroadcastReceiver注册时IntentFilter设置的优先级的顺序来执行,相同优先级的BroadcastReceiver则是随机执行
5. sendStickyBroadcast()方法主要的不同是,Intent在发送后一直存在,并且在以后调用registerReceiver()注册相匹配的Intent时会把这个Intent直接返回。
6. 若在使用sendBroadcast()方法时指定了接收的权限,这只有在AndroidManifest.xml中用<uses-permission>标签声明了拥有此权限的BroadcastReceiver才会有可能接收到发送来Broadcast。
7. 若在注册BroadcastReciever时,指定了可接收的Broadcast的权限,则只有在包内的AndroidManifest.xml中用<uses-permission>标签声明了,拥有此权限的Context对象所发送的Broadcast才有可能被这个BroadcastReceiver所接收。
接收Broadcast消息
1. 继承BroadcastReceiver 类,并实现onReceive方法
2. 注册Broadcast Receiver(有2种方法:一种方法是,静态地在AndroidManifest.xml中用<receiver>标签声明,并在标签内用<intent-filter>标签设置过滤器; 另一种方法,动态地在代码中先定义并设置好一个IntentFilter对象,然后再需要注册的地方调用Context.registerReceiver()方法) (取消注册时,调用Context.unregisterReceiver()方法)
Content Provider —— 为解决应用程序间数据通信、共享的问题(基类ContentProvider)
在Android中,每个应用程序都是用自己的用户ID并在自己的进程中运行。这样的好处是,可以有效地保护系统及应用程序,避免被其他不正常德应用程序所影响,每个进程都拥有独立的进程地址空间和虚拟空间。
Content Provider可以将应用程序特定的数据提供给另一个应用程序使用。其数据存储方式可以是Android文件系统、SQLite数据库或者其他合理的方式。
当数据需要在应用程序间共享时,我们就可以利用ContentProvider为数据定义一个URI。之后,其他应用程序对数据进行查询或者修改时,只需要从当前上下文对象获得一个ContentResolver, 然后传入响应的URI就可以了。
Content Provider 继承自基类ContentProvider,并且实现了一组标准接口。通过这组接口,其他应用程序能对数据进行读写和存储。然而,需要使用数据的应用程序并不是直接调用这组方法,而是通过调用ContentResolver对象的方法来完成。ContentResolver对象可以与任意ContentProvider通信。
要为当前应用程序的私有数据定义URI,就需要专门定义一个继承自ContentProvider的类,然后根据不同的操作调用的方法去实现这些方法的功能。
ContentResolver类为应用程序提供了接入Content机制的方法。要构造一个ContentResolver对象可以为构造方法ContentResolver(Context context)传入一个Context对象,也可以直接通过Context对象调用getContentResolver()方法获得 —— 有的ContentResolver对象后,就可以通过调用其query()、insert()、update()等方法来对数据进行操作了。
一旦需要以上4种Android应用程序基本组件完成请求,Android会首先确认该组件所在进程是否运行,如果没有运行,Android将先启动进程,同时确认被请求组件的实例是否存在,否则将创建一个新的组件实例。
Intent —— 连接组件的纽带
以上4种基本组件中,除了Content Provider是通过Content Resolver激活外,其他3种组件Activity、Service和Broadcast Receiver都是由Intent异步消息激活的。
Intent在不同的组件之间传递消息,将一个组件的请求意图传给另一个组件。因此,Intent是包含具体请求信息的对象。
针对不同的组件,Intent所包含的消息内容有所不同,且不同组件的激活方式也不同, 且不同类型组件有传递Intent的不同方式。
Intent是一种运行时绑定(runtime binding)机制,它能够在程序运行的过程中连接两个不同的组件。通过Intent,你的程序可以向Android表到某种请求或者意愿,Android会根据意愿的内容选择适当的组件来处理请求。
l 激活一个新的Activity,或者让一个现有的Activity执行一个新的操作,可以通过调用如下两种方法(这两汇总方法需要传入的Intent参数称为Activity Action Intent):
1. Context.startActivity()
2. Activity.startActivityForResult()
l 启动一个新的服务,或者向一个已有的服务传递新的指令,可以调用如下两种方法:
1. Context.startService()
2. Context.bindService()
l 发送广播Intent(所有已注册的拥有与之相匹配IntenFilter的BroadcastReceiv就会被激活),可以调用如下三种方法:
1. Context.sendBroadcast()
2. Context.sendOrderBroadcast()
3. Context.sendStickBroadcast()
Intent一旦发出,Android都会准确找到相匹配的一个或多个Activity、Service或BroadcastReceiver作响应。所以,不同类型的Intent消息不会出现重叠,BroadcastIntent消息只会发送给BroadcastReceiver,而绝不可能发送给Activity或Server。有startActivity()传递的消息也只可能发送给Activity,由startService()传递的Intent只可能发送给Service。
Intent对象抽象地描述了执行操作,Intent的主要组成部分;
1. 目标组件名称。[可选项]
a) 组件名称是一个ComponentName对象,是目标组件类名和目标组件所在应用程序包的组合
b) 组件中的包名不一定要和manifes文件中包名完全匹配
c) 如果Intent消息中指明了目标组件的名称,这就是一个显示消息,Intent会传递给指明的组件。
d) 如果目标组件名称并没有指定,Android则通过Intent内的其他信息和已注册的IntentFilter的比较来选择合适的目标组件
2. Action [隐式比较]
a) 描述Intent所触发动作的名字字符串。
b) 理论上Action可以为任何字符串,而与Android系统应用有关的Action字符串以静态字符串常量的形式定义在了Intent类中。
3. Data [隐式比较]
a) 描述Intent要操作的的数据的URI和数据类型。
b) 正确设置Intent的数据对于Android寻找系统中匹配Intent请求的组件很重要。
4. Category [隐式比较]
a) 是对被请求组件的额外描述信息。
b) Android也在Intent类中定义了一组静态字符串常量表示Intent不同的类别。
5. Extra
a) 当我们使用Intent连接不同组件时,有时需要在Intent中附加额外的信息,以便将数据传递给目标Activity。
b) Extra用键值对结构保存在Intent对象当中,Intent对象通过调用方法putExtras() 和 getExtras()来存储和获取Extra
c) Extra是以Bundle对象的形式来保存的,Bundle对象提供了一系列put和get方法来设置、提取相应键值信息。
d) 在Intent类中同样为Android系统应用的一些Extra的键值定义了静态字符串常量。
6. Flag
决定Intent目标组件的因素:
n 在显式Intent消息中,决定目标组件的唯一要素就是组件名称(不用再定义其他Intent内容)
n 而隐式Intent消息中,由于没有目标组件名称,所以必须由Android系统帮助应用程序寻找与Intent请求意图最匹配的组件。
n 隐式Intent消息中目标组件具体选择方法是:android将Intent的请求内容和一个叫做IntentFilter的过滤器比较,IntentFilter中包含系统中所有可能的待选组件。如果IntentFilter中某一个组件匹配隐式Intent请求内容,那么Android就选择该组件作为该隐式Intent的目标组件。
IntenFilter
应用程序的组件为了告诉Android自己能响应、处理哪些隐式Intent请求,可以声明一个甚至多个IntentFilter。
每个IntentFilter描述该组件所能响应Intent请求的能力 —— 组件希望接收什么类型的请求行为,什么类型的请求数据。
隐式Intent和IntentFilter进行比较时的三要素:Action、Data、Category。
一个隐式Intent请求要能够传递给目标组件,必需通过以上三个方面的检查。如果任何一方面不匹配,Android都不会将该隐式Intent传递给目标组件。
<intent-filter>
<action android:name=””/>
<category android:name=””/>
<data android:type=”” android:scheme=”” android:authority=”” android:path=””/>
</intent-filter>
1. 动作测试
a) 一条 <intent-filter> 中至少应该包含一个<action>, 否则任何Intent请求都不能和该<intent-filter> 匹配。
b) 如果IntentFilter 中没有包含任何Actino类型,那么无论什么Intent请求都无法和这条IntentFilter匹配。
c) 如果Intent请求中没有设定Action类型,那么只要IntentFilter中包含有Action类型,这个Intent请求将顺利通过IntentFilter的测试。
2. 类别测试
a) 只有当Intent请求中所有的Category与组件中的某一个IntentFilter的category完全匹配,才会让该Intent请求通过测试,IntentFilter中的多余category声明并不会导致匹配失败。
b) 一个没有指定任何类别的IntentFilter仅仅只会匹配没有设置类别的Intent请求。
3. 数据测试
a) <data>元素指定了希望接受的Intent请求的数据URI和数据类型:URI被分成三部分类进行匹配,scheme、authority和 path.
b) 使用 setData设定的Intent请求的URI数据类型和scheme,必须与IntentFilter中指定的一致
若IntentFilter中还指定了authority或path,他们也需要相匹配才会通过测试。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/CrazyJeff_Liu/archive/2010/04/30/5545806.aspx
发表评论
-
android push
2011-11-16 15:24 1607所有技术的概要介绍,并讲解了android2.2的新功能C2D ... -
[Android UI界面] 怎么设置popupwindow动画效果?
2011-07-16 12:34 1120http://www.eoeandroid.com/threa ... -
android解析XML
2011-07-11 11:32 1874为移动设备构建 Java 应用程序 Michael ... -
对话框和浮动Activity
2011-07-06 12:07 957在Android中,我们可以通 ... -
升级android sdk时A folder failed to be renamed or moved 错误的解决
2011-06-28 09:22 1701Downloading Android SDK Tools, ... -
android push机制-C2DM
2011-06-27 16:54 1536http://bigcat.easymorse.com/?p= ... -
XML解析
2011-06-24 15:45 854HttpPost httpRequest=new HttpP ... -
android上传图片到服务器,求服务器那边和android的Activity的完整代码。
2011-06-22 12:30 3253服务器端servlet代码:public void doPos ... -
android HTTP 通信, XML 解析, 通过 Hander 实现异步消息处理 (1)
2011-06-08 16:44 1029介绍 在 Android 中与服务端做 HTTP 通信,解析 ... -
eclipse 中android中文doc配置
2011-05-13 14:39 982http://hi.baidu.com/huangbz321/ ... -
jesson.shen浅谈HTTP中实现UDP/TCP
2011-05-10 16:38 938http://350526.blog.51cto.com/34 ... -
android 网络编程
2011-05-04 19:54 781http://hi.baidu.com/lfcaolibin/ ... -
android解析xml文件的方式
2011-05-01 22:54 890http://hi.baidu.com/%B2%BD%C2%C ... -
android进程间通信:使用AIDL
2011-04-13 10:59 873http://blog.csdn.net/saintsword ... -
Android实现开机自动运行程序
2011-04-12 18:00 1129有些时候,应用需要在开机时就自动运行,例如某个自动从网上更新内 ... -
android 如何从sqlite读取数据到spinner下拉中显示
2011-04-12 14:56 5586import android.app.Activity; im ... -
Android的SharedPreferences保存与删除数据简单实例
2011-04-12 11:37 520451、创建SharedPreferences对象: Stri ... -
Android使用LayoutInflater动态加载布局和操作控件
2011-04-11 16:22 1003http://www.cnmsdn.com/html/2010 ... -
dialog
2011-04-08 18:32 856http://topic.csdn.net/u/2011031 ... -
Android NOtification 使用
2011-04-07 15:55 3852一、 Notification 简介 ...
相关推荐
在Android应用开发中,基本组件是构建应用程序的核心部分。这些组件是Android系统提供给开发者用于构建功能丰富的交互式应用的工具。...因此,掌握Android基本组件及其源码分析是成为一名专业Android开发者的必经之路。
【实验四-Android基本组件交互实验】 实验四的目的是让学生深入了解和熟练运用Android中的四大基本组件:Activity、Service和BroadcastReceiver。这些组件是构建Android应用的基础,理解和掌握它们的使用对于开发高...
以下是关于Android基本组件的详细解释: 1. **Activity(活动)**:Activity是Android应用的核心组件,它代表用户可见的屏幕或窗口。每个与用户交互的界面都是一个Activity实例。Activity可以启动、暂停、恢复或...
Android 基础组件交互实验旨在让学生熟悉 Android 基本组件的使用和实现,包括 Activity、Service 和 BroadcastReceiver。通过本实验,学生将掌握 Activity 的跳转、Service 的启动停止以及 BroadcastReceiver 的...
android入门级视频:Android基本组件介绍之Android应用的灵魂——Intent和Activity介绍与实例
在Android开发中,基本组件是构建用户界面的基础,它们提供了丰富的功能,使开发者能够创建出交互性强、用户体验良好的应用程序。本教程将深入讲解Android的基本组件,包括画廊(Gallery)、按钮(Button)以及布局...
### Android基本组件详解 在Android开发中,组件是构建用户界面和实现功能的基本单元。本文将详细介绍几种Android基本组件的功能与使用方法,包括`TextView`、`EditText`以及`TableLayout`。 #### TextView:...
在Android应用开发中,基本组件是构建用户界面和实现功能的核心元素。本篇文章将深入探讨Android的四大基本组件——Activity、EditText、TextView和Button,以及如何在多Activity环境中实现自由跳转。 首先,...
android图形界面编程,基本组件的设计使用方法 -the Android graphical programming interface, basic components are designed to use
bfrf trhbjvtgtryrurt
Android系统的核心架构主要由四大组件构成:Activity、Service、BroadcastReceiver和ContentProvider。这四大组件是构建Android应用程序的基础,理解并熟练运用它们是每个Android开发者必须掌握的关键技能。 首先,...
第7章 良好的学习开端——Android基本组件介绍之Android应用的灵魂——Intent和Activity介绍与实例 第7章 良好的学习开端——Android基本组件介绍之用好列表,做好程序——列表(ListView)介绍与实例 第7章 良好的...
首先,让我们详细了解一下组件化的基本概念。组件化的核心是将一个大型的Android应用拆分为多个功能明确、相互独立的模块,每个模块即为一个组件。这些组件可以单独开发、测试和部署,减少了耦合性,提高了代码的可...
Android组件是应用程序的基本构建块,主要包括Activity、Service、BroadcastReceiver和ContentProvider。自定义组件是在这些基础组件之上进行扩展,以满足特定需求或实现特殊视觉效果的视图(View)或视图组(ViewGroup...
在Android应用开发中,UI(用户界面)组件是构建应用程序不可或缺的部分。这些组件构成了用户与应用交互的视觉元素。以下是对“android ui组件大全”这个主题的详细解析: 标题:“android ui组件大全” 这个标题...
View是Android用户界面的基本元素,如按钮、文本框等。ViewGroup是容器,用于组合多个View,如布局文件中的LinearLayout、RelativeLayout等。开发者可以通过自定义View和ViewGroup来实现独特的界面效果。 10. **...
首先,我们需要了解自定义组件的基本步骤: 1. **创建View类的子类**:在Android中,所有的UI元素都继承自`View`或`ViewGroup`。自定义组件通常需要创建一个新的Java类,继承自`View`或`ViewGroup`。在这个例子中,...
书中强调,读者应有一定的Android基础知识,包括Java语言、面向对象编程以及基本的Android应用开发经验。书中的案例和代码可以帮助读者更好地理解和应用所学知识,解决实际开发中的问题。 作者鼓励读者通过电子邮件...