简要解释一下activity、 intent 、intent filter、service、Broadcast、BroadcaseReceiver

本文主要是介绍简要解释一下activity、 intent 、intent filter、service、Broadcast、BroadcaseReceiver,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Activity
Android中,Activity是所有程序的根本,所有程序的流程都运行在Activity之中,Activity具有自己的生命周期(由系统控制生命周期,程序无法改变,但可以用onSaveInstanceState保存其状态)。
对于Activity,关键是其生命周期的把握(如那张经典的生命周期图=.=),其次就是状态的保存和恢复(onSaveInstanceStateonRestoreInstanceState),以及Activity之间的跳转和数据传输(intent)。

Activity中常用的函数有SetContentView()findViewById()finish()startActivity(),其生命周期涉及的函数有:
voidonCreate(BundlesavedInstanceState)
voidonStart()
voidonRestart()
voidonResume()
voidonPause()
voidonStop()
voidonDestroy()
注意的是,Activity的使用需要在Manifest文件中添加相应的<Activity>,并设置其属性和intent-filter。

Intent
Android中提供了Intent机制来协助应用间的交互与通讯,Intent负责对应用中一次操作的动作、动作涉及数据、附加数据进行描述,Android则根据此Intent的描述,负责找到对应的组件,将Intent传递给调用的组件,并完成组件的调用。Intent不仅可用于应用程序之间,也可用于应用程序内部的Activity/Service之间的交互。因此,Intent在这里起着一个媒体中介的作用,专门提供组件互相调用的相关信息,实现调用者与被调用者之间的解耦。在SDK中给出了Intent作用的表现形式为:

·通过Context.startActivity()orActivity.startActivityForResult()启动一个Activity;

·通过Context.startService()启动一个服务,或者通过Context.bindService()和后台服务交互;

·通过广播方法(比如Context.sendBroadcast(),Context.sendOrderedBroadcast(),Context.sendStickyBroadcast())发给broadcastreceivers。

Intent属性的设置,包括以下几点:(以下为XML中定义,当然也可以通过Intent类的方法来获取和设置)
(1)Action,也就是要执行的动作
SDk中定义了一些标准的动作,包括

onstant

Targetcomponent

Action

ACTION_CALL

activity

Initiateaphonecall.

ACTION_EDIT

activity

Displaydatafortheusertoedit.

ACTION_MAIN

activity

Startupastheinitialactivityofatask,withnodatainputandnoreturnedoutput.

ACTION_SYNC

activity

Synchronizedataonaserverwithdataonthemobiledevice.

ACTION_BATTERY_LOW

broadcastreceiver

Awarningthatthebatteryislow.

ACTION_HEADSET_PLUG

broadcastreceiver

Aheadsethasbeenpluggedintothedevice,orunpluggedfromit.

ACTION_SCREEN_ON

broadcastreceiver

Thescreenhasbeenturnedon.

ACTION_TIMEZONE_CHANGED

broadcastreceiver

Thesettingforthetimezonehaschanged.


当然,也可以自定义动作(自定义的动作在使用时,需要加上包名作为前缀,如"com.example.project.SHOW_COLOR”),并可定义相应的Activity来处理我们的自定义动作。
(2)Data,也就是执行动作要操作的数据
Android中采用指向数据的一个URI来表示,如在联系人应用中,一个指向某联系人的URI可能为:content://contacts/1。对于不同的动作,其URI数据的类型是不同的(可以设置type属性指定特定类型数据),如ACTION_EDIT指定Data为文件URI,打电话为tel:URI,访问网络为http:URI,而由contentprovider提供的数据则为content:URIs。
(3)type(数据类型),显式指定Intent的数据类型(MIME)。一般Intent的数据类型能够根据数据本身进行判定,但是通过设置这个属性,可以强制采用显式指定的类型而不再进行推导。
(4)category(类别),被执行动作的附加信息。例如LAUNCHER_CATEGORY表示Intent的接受者应该在Launcher中作为顶级应用出现;而ALTERNATIVE_CATEGORY表示当前的Intent是一系列的可选动作中的一个,这些动作可以在同一块数据上执行。还有其他的为

Constant

Meaning

CATEGORY_BROWSABLE

Thetargetactivitycanbesafelyinvokedbythebrowsertodisplaydatareferencedbyalink—forexample,animageorane-mailmessage.

CATEGORY_GADGET

Theactivitycanbeembeddedinsideofanotheractivitythathostsgadgets.

CATEGORY_HOME

Theactivitydisplaysthehomescreen,thefirstscreentheuserseeswhenthedeviceisturnedonorwhentheHOMEkeyispressed.

CATEGORY_LAUNCHER

Theactivitycanbetheinitialactivityofataskandislistedinthetop-levelapplicationlauncher.

CATEGORY_PREFERENCE

Thetargetactivityisapreferencepanel.


(5)component(组件),指定Intent的的目标组件的类名称。通常Android会根据Intent中包含的其它属性的信息,比如action、data/type、category进行查找,最终找到一个与之匹配的目标组件。但是,如果component这个属性有指定的话,将直接使用它指定的组件,而不再执行上述查找过程。指定了这个属性以后,Intent的其它所有属性都是可选的。
(6)extras(附加信息),是其它所有附加信息的集合。使用extras可以为组件提供扩展信息,比如,如果要执行“发送电子邮件”这个动作,可以将电子邮件的标题、正文等保存在extras里,传给电子邮件发送组件。
理解Intent的关键之一是理解清楚Intent的两种基本用法:一种是显式的Intent,即在构造Intent对象时就指定接收者;另一种是隐式的Intent,即Intent的发送者在构造Intent对象时,并不知道也不关心接收者是谁,有利于降低发送者和接收者之间的耦合。
对于显式Intent,Android不需要去做解析,因为目标组件已经很明确,Android需要解析的是那些隐式Intent,通过解析,将Intent映射给可以处理此Intent的Activity、IntentReceiver或Service。
Intent解析机制主要是通过查找已注册在AndroidManifest.xml中的所有IntentFilter及其中定义的Intent,最终找到匹配的Intent。在这个解析过程中,Android是通过Intent的action、type、category这三个属性来进行判断的,判断方法如下:

·如果Intent指明定了action,则目标组件的IntentFilter的action列表中就必须包含有这个action,否则不能匹配;

·如果Intent没有提供type,系统将从data中得到数据类型。和action一样,目标组件的数据类型列表中必须包含Intent的数据类型,否则不能匹配。

·如果Intent中的数据不是content:类型的URI,而且Intent也没有明确指定它的type,将根据Intent中数据的scheme(比如http:或者mailto:)进行匹配。同上,Intent的scheme必须出现在目标组件的scheme列表中。

·如果Intent指定了一个或多个category,这些类别必须全部出现在组建的类别列表中。比如Intent中包含了两个类别:LAUNCHER_CATEGORY和ALTERNATIVE_CATEGORY,解析得到的目标组件必须至少包含这两个类别。

Intent-Filter的定义
一些属性设置的例子:
<actionandroid:name="com.example.project.SHOW_CURRENT"/>
<categoryandroid:name="android.intent.category.DEFAULT"/>
<dataandroid:mimeType="video/mpeg"android:scheme="http".../>
<dataandroid:mimeType="image/*"/>
<dataandroid:scheme="http"android:type="video/*"/>
完整的实例
<activityandroid:name="NotesList"android:label="@string/title_notes_list">
<intent-filter>
<actionandroid:name="android.intent.action.MAIN"/>
<categoryandroid:name="android.intent.category.LAUNCHER"/>
</intent-filter>
<intent-filter>
<actionandroid:name="android.intent.action.VIEW"/>
<actionandroid:name="android.intent.action.EDIT"/>
<actionandroid:name="android.intent.action.PICK"/>
<categoryandroid:name="android.intent.category.DEFAULT"/>
<dataandroid:mimeType="vnd.android.cursor.dir/vnd.google.note"/>
</intent-filter>
<intent-filter>
<actionandroid:name="android.intent.action.GET_CONTENT"/>
<categoryandroid:name="android.intent.category.DEFAULT"/>
<dataandroid:mimeType="vnd.android.cursor.item/vnd.google.note"/>
</intent-filter>
</activity>
Intent用法实例
1.无参数Activity跳转
Intentit=newIntent(Activity.Main.this,Activity2.class);
startActivity(it);
2.向下一个Activity传递数据(使用Bundle和Intent.putExtras)
Intentit=newIntent(Activity.Main.this,Activity2.class);
Bundlebundle=newBundle();
bundle.putString("name","ThisisfromMainActivity!");
it.putExtras(bundle);//it.putExtra(“test”,"shuju”);
startActivity(it);//startActivityForResult(it,REQUEST_CODE);
对于数据的获取可以采用:
Bundlebundle=getIntent().getExtras();Stringname=bundle.getString("name");
3.向上一个Activity返回结果(使用setResult,针对startActivityForResult(it,REQUEST_CODE)启动的Activity)
Intentintent=getIntent();
Bundlebundle2=newBundle();
bundle2.putString("name","ThisisfromShowMsg!");
intent.putExtras(bundle2);
setResult(RESULT_OK,intent);
4.回调上一个Activity的结果处理函数(onActivityResult)
@OverrideprotectedvoidonActivityResult(intrequestCode,intresultCode,Intentdata){
//TODOAuto-generatedmethodstub
super.onActivityResult(requestCode,resultCode,data);
if(requestCode==REQUEST_CODE){
if(resultCode==RESULT_CANCELED)
setTitle("cancle");
elseif(resultCode==RESULT_OK){
Stringtemp=null;
Bundlebundle=data.getExtras();
if(bundle!=null)temp=bundle.getString("name");
setTitle(temp);
}
}
}
下面是转载来的其他的一些Intent用法实例(转自javaeye)
显示网页
1.Uriuri=Uri.parse("http://google.com");
2.Intentit=newIntent(Intent.ACTION_VIEW,uri);
3.startActivity(it);
显示地图
1.Uriuri=Uri.parse("geo:38.899533,-77.036476");
2.Intentit=newIntent(Intent.ACTION_VIEW,uri);
3.startActivity(it);
4.//其他geoURI範例
5.//geo:latitude,longitude
6.//geo:latitude,longitude?z=zoom
7.//geo:0,0?q=my+street+address
8.//geo:0,0?q=business+near+city
9.//google.streetview:cbll=lat,lng&cbp=1,yaw,,pitch,zoom&mz=mapZoom
路径规划
1.Uriuri=Uri.parse("http://maps.google.com/maps?f=d&saddr=startLat%20startLng&daddr=endLat%20endLng&hl=en");
2.Intentit=newIntent(Intent.ACTION_VIEW,uri);
3.startActivity(it);
4.//wherestartLat,startLng,endLat,endLngarealongwith6decimalslike:50.123456
打电话
1.//叫出拨号程序
2.Uriuri=Uri.parse("tel:0800000123");
3.Intentit=newIntent(Intent.ACTION_DIAL,uri);
4.startActivity(it);
1.//直接打电话出去
2.Uriuri=Uri.parse("tel:0800000123");
3.Intentit=newIntent(Intent.ACTION_CALL,uri);
4.startActivity(it);
5.//用這個,要在AndroidManifest.xml中,加上
6.//<uses-permissionid="android.permission.CALL_PHONE"/>
传送SMS/MMS
1.//调用短信程序
2.Intentit=newIntent(Intent.ACTION_VIEW,uri);
3.it.putExtra("sms_body","TheSMStext");
4.it.setType("vnd.android-dir/mms-sms");
5.startActivity(it);
1.//传送消息
2.Uriuri=Uri.parse("smsto://0800000123");
3.Intentit=newIntent(Intent.ACTION_SENDTO,uri);
4.it.putExtra("sms_body","TheSMStext");
5.startActivity(it);
1.//传送MMS
2.Uriuri=Uri.parse("content://media/external/images/media/23");
3.Intentit=newIntent(Intent.ACTION_SEND);
4.it.putExtra("sms_body","sometext");
5.it.putExtra(Intent.EXTRA_STREAM,uri);
6.it.setType("image/png");
7.startActivity(it);
传送Email
1.Uriuri=Uri.parse("mailto:xxx@abc.com");
2.Intentit=newIntent(Intent.ACTION_SENDTO,uri);
3.startActivity(it);
1.Intentit=newIntent(Intent.ACTION_SEND);
2.it.putExtra(Intent.EXTRA_EMAIL,"me@abc.com");
3.it.putExtra(Intent.EXTRA_TEXT,"Theemailbodytext");
4.it.setType("text/plain");
5.startActivity(Intent.createChooser(it,"ChooseEmailClient"));
1.Intentit=newIntent(Intent.ACTION_SEND);
2.String[]tos={"me@abc.com"};
3.String[]ccs={"you@abc.com"};
4.it.putExtra(Intent.EXTRA_EMAIL,tos);
5.it.putExtra(Intent.EXTRA_CC,ccs);
6.it.putExtra(Intent.EXTRA_TEXT,"Theemailbodytext");
7.it.putExtra(Intent.EXTRA_SUBJECT,"Theemailsubjecttext");
8.it.setType("message/rfc822");
9.startActivity(Intent.createChooser(it,"ChooseEmailClient"));
1.//传送附件
2.Intentit=newIntent(Intent.ACTION_SEND);
3.it.putExtra(Intent.EXTRA_SUBJECT,"Theemailsubjecttext");
4.it.putExtra(Intent.EXTRA_STREAM,"file:///sdcard/mysong.mp3");
5.sendIntent.setType("audio/mp3");
6.startActivity(Intent.createChooser(it,"ChooseEmailClient"));
播放多媒体
Uriuri=Uri.parse("file:///sdcard/song.mp3");
Intentit=newIntent(Intent.ACTION_VIEW,uri);
it.setType("audio/mp3");
startActivity(it);
Uriuri=Uri.withAppendedPath(MediaStore.Audio.Media.INTERNAL_CONTENT_URI,"1");
Intentit=newIntent(Intent.ACTION_VIEW,uri);
startActivity(it);
Market相关
1.//寻找某个应用
2.Uriuri=Uri.parse("market://search?q=pname:pkg_name");
3.Intentit=newIntent(Intent.ACTION_VIEW,uri);
4.startActivity(it);
5.//wherepkg_nameisthefullpackagepathforanapplication
1.//显示某个应用的相关信息
2.Uriuri=Uri.parse("market://details?id=app_id");
3.Intentit=newIntent(Intent.ACTION_VIEW,uri);
4.startActivity(it);
5.//whereapp_idistheapplicationID,findtheID
6.//byclickingonyourapplicationonMarkethome
7.//page,andnoticetheIDfromtheaddressbar
Uninstall应用程序
1.Uriuri=Uri.fromParts("package",strPackageName,null);
2.Intentit=newIntent(Intent.ACTION_DELETE,uri);
3.startActivity(it);

service

service是没有界面的长生命周期的代码。一个很好的例子是媒体播放器从列表中播放歌曲。在一个媒体播放器程序中,大概要有一个或多个活动(activity)来供用户选择歌曲并播放它。然而,音乐的回放就不能使用活动(activity)了,因为用户希望他导航到其他界面时音乐继续播放。这种情况下,媒体播放器活动(activity)要用Context.startService()启动一个服务来在后台运行保持音乐的播放。系统将保持这个音乐回放服务的运行直到它结束。注意一下,你要用Context.bindService()方法连接服务(如果它没有运行,要先启动它)。当连接到服务后,你可以通过服务暴露的一个接口和它通信。对于音乐服务,它允许你暂停、倒带,等等。

Broadcast和BroadcaseReceiver

Android BroadcastReceiver 简介
在 Android 中使用 Activity, Service, Broadcast, BroadcastReceiver
活动(Activity) - 用于表现功能
服务(Service) - 相当于后台运行的 Activity
广播(Broadcast) - 用于发送广播
广播接收器(BroadcastReceiver) - 用于接收广播
Intent - 用于连接以上各个组件,并在其间传递消息

BroadcastReceiver
在Android中,Broadcast是一种广泛运用的在应用程序之间传输信息的机制。而BroadcastReceiver是对发送出来的 Broadcast进行过滤接受并响应的一类组件。下面将详细的阐述如何发送Broadcast和使用BroadcastReceiver过

滤接收的过程:
首先在需要发送信息的地方,把要发送的信息和用于过滤的信息(如Action、Category)装入一个Intent对象,然后通过调用 Context.sendBroadcast()、sendOrderBroadcast()或sendStickyBroadcast()方法,把 Intent对象以广播方式发送出去。
当Intent发送以后,所有已经注册的BroadcastReceiver会检查注册时的IntentFilter是否与发送的Intent相匹配,若 匹配则就会调用BroadcastReceiver的onReceive()方法。所以当我们定义一个BroadcastReceiver的时候,都需要 实现onReceive()方法。



注册BroadcastReceiver有两种方式:
一种方式是,静态的在AndroidManifest.xml中用<receiver>标签生命注册,并在标签内用<intent- filter>标签设置过滤器。

另一种方式是,动态的在代码中先定义并设置好一个IntentFilter对象,然后在需要注册的地方调 Context.registerReceiver()方法,如果取消时就调用Context.unregisterReceiver()方法。

不管是用xml注册的还是用代码注册的,在程序退出的时候没有特殊需要都得注销,否则下次启动程序可能会有多个BroadcastReceiver

另外,若在使用sendBroadcast()的方法是指定了接收权限,则只有在AndroidManifest.xml中用<uses- permission>标签声明了拥有此权限的BroascastReceiver才会有可能接收到发送来的Broadcast。

同样,若在注册BroadcastReceiver时指定了可接收的Broadcast的权限,则只有在包内的AndroidManifest.xml中 用<uses-permission>标签声明了,拥有此权限的Context对象所发送的Broadcast才能被这个 BroadcastReceiver所接收。

动态注册:
IntentFilter intentFilter = new IntentFilter();
intentFilter.addAction(String);--为 BroadcastReceiver指定action,使之用于接收同action的广播 registerReceiver(BroadcastReceiver,intentFilter);
一般:在onStart中注册,onStop中取消unregisterReceiver

发送广播消息:extends Service
指定广播目标Action:Intent Intent = new Intent(action-String)
--指定了此action的receiver会接收此广播
需传递参数(可选) putExtra();
发送:sendBroadcast(Intent);

引用:

http://ycl248.blog.163.com/blog/static/3634280620106239617577/

http://litonggang.iteye.com/blog/519574

http://lhc966.iteye.com/blog/803647

这篇关于简要解释一下activity、 intent 、intent filter、service、Broadcast、BroadcaseReceiver的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/799588

相关文章

我与Bloom filter

1 海量网页判断用Bloom Filter 面试的时候,一个面试官问我说:“有一个网络爬虫,爬虫程序会不停地爬取页面上的每一个网页,并把爬取后的网页给存储起来,那么爬虫如何判定现在在爬的网页有没有被爬过。” 我当时卡住了半天回答不上来。 面试官给我说用Bloom Filter。 Bloom Filter把爬取过的网页映射到Bloom Filter内,如果再爬取到该网页,Bloom Filt

国产数据库 - 内核特性 - CloudberryDB中的Runtime Filter

国产数据库 - 内核特性 - CloudberryDB中的Runtime Filter 今年5月份GreenPlum官方将GitHub仓库代码全部删除,各个分支的issues和bugs讨论等信息全部清除,仅将master分支代码进行归档。对于国内应用GPDB的用户来说,这是一个挑战性事件,对与后期维护、升级等都变得非常困难。有幸HashData开源了基于GP衍生版本CloudberryDB版本,

Service在Android中的作用:技术难点、面试官关注点、回答吸引力与代码举例

在Android开发中,Service是一个重要的后台服务组件,它允许应用程序在后台执行长时间运行的操作,而无需与用户进行直接交互。Service在多种场景下发挥着关键作用,下面我们将从技术难点、面试官关注点、回答吸引力和代码举例四个方面,对Service的作用进行详细阐述。 一、技术难点 生命周期管理:Service的生命周期相对独立,与Activity和Fragment等组件不同。因此

滴滴插件化VirtualAPK框架原理解析(二)之Service 管理

在前一篇博客滴滴插件化框架VirtualAPK原理解析(一)之插件Activity管理 中VirtualAPK是如何对Activity进行管理的,本篇博客,我们继续来学习这个框架,这次我们学习的是如何去管理Service。 Freedom框架,我个人手写的0反射插件化框架 Service工作原理分析 说道如何对Service进行插件化,肯定得先了解Service的工作过程,不然何谈插件化?所

滴滴插件化框架VirtualAPK原理解析(一)之插件Activity管理

上周末,滴滴与360都开源了各自的插件化框架,VirtualAPK与RePlugin,作为一个插件化方面的狂热研究者,在周末就迫不及待的下载了Virtualapk框架来进行研究,本篇博客带来的是VirtualAPK原理解析的第一篇Activity管理,博客只是自己的理解,小弟才疏学浅,可能有很多理解不对的地方,欢迎各位大神指出。(看博客之前,请大家先下载VirtualVirtualAPKapk的项

SRS4.0源码分析-SrsRtmpConn::stream_service_cycle

SRS 的社群来了,想加入微信社群的朋友请购买《SRS原理》电子书,里有更高级的内容与答疑服务。 本文采用的 SRS 版本是 4.0-b8 , 下载地址:github 本文讲解 SrsRtmpConn::stream_service_cycle() 函数的实现原理。流程图如下: 上面的流程图中有几个重点: 重点1,这里插个题 在调 stream_service_cycle()

Kubernetes之Service详解

本文尝试从Service暴露服务方式、Service控制器实现原理、使用规范等方面对Kubernetes 中的Service进行详细介绍。 一、Kubernetes 中的pod有哪些暴露服务的方式 各种 Kubernetes 中暴露服务的方式都有其独特的优缺点,根据具体的使用场景和需求,选择合适的方式非常重要。下面是对每种方式的优缺点简要总结: 1. Service (服务) Clust

Python高阶函数map、reduce、filter应用

定义 map映射函数 map()通过接收一个函数F和一个可迭代序列,作用是F依次作用序列的每个元素,并返回一个新的list。reduce递归映射函数 reduce()把一个函数作用在一个序列上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做函数运算。filter过滤函数 filter()与map()类似,接收一个函数F和一个可迭代序列,只不过这里的函数F是条件判断函数。

Linux Ubuntu 24.04制作可用systemctl操控的service

在/etc/systemd/system/目录下创建一个新的<your_service_name>.service文件,例如buda.service,里面填入以下内容: (特别要注意设置WorkingDirectory, 这将决定exe程序中的相对路径的解析结果。) [Unit]Description=buda website serverAfter=network.target[Serv

K8S - 实现statefulset 有状态service的灰度发布

什么是灰度发布 Canary Release 参考 理解 什么是 滚动更新,蓝绿部署,灰度发布 以及它们的区别 配置partition in updateStrategy/rollingUpdate 这次我为修改了 statefulset 的1个yaml file statefulsets/stateful-nginx-without-pvc.yaml: ---apiVersio