Android(六)Activity、请求码与结果码、Intent、广播、服务

<p><strong>一、创建新的</strong><strong>Activity</strong></p>
<p>在进行桌面开发时,我们可以通过一个窗口上的控件事件打开另一个新的窗口。在WEB应用开发时,我们也可以通过一个连接打开一个新的页面。通过添加新的窗口开完善或增强软件的功能,那么在Android应用开发中,我们应该怎样打开新的Activity?</p>
<p><strong>1.</strong><strong>添加新的Activity(创建Android工程:MainActivity)</strong></p>
<p>1).新建一个继承自Activity类的类NewActivity</p>
<p><strong>package</strong> com.changcheng.activity;</p>
<p><strong>import</strong> android.app.Activity;</p>
<p><strong>import</strong> android.os.Bundle;</p>
<p><strong>import</strong> android.view.View;</p>
<p><strong>import</strong> android.widget.Button;</p>
<p><strong>public</strong> <strong>class</strong> NewActivity <strong>extends</strong> Activity {</p>
<p>@Override</p>
<p><strong>protected</strong> <strong>void</strong> onCreate(Bundle savedInstanceState) {</p>
<p><strong>super</strong>.onCreate(savedInstanceState);</p>
<p>setContentView(R.layout.<em>new_activity</em>);</p>
<p>// 获取按钮并未按钮添加事件</p>
<p>Button button = (Button) <strong>this</strong>.findViewById(R.id.<em>newa_bt_close</em>);</p>
<p>button.setOnClickListener(<strong>new</strong> View.OnClickListener() {</p>
<p>@Override</p>
<p><strong>public</strong> <strong>void</strong> onClick(View v) {</p>
<p>NewActivity.<strong>this</strong>.finish();</p>
<p>}</p>
<p>});</p>
<p>}</p>
<p>}</p>
<p>2).AndroidManifest.xml文件中添加</p>
<p><!--l version=<-->"1.0" encoding=<em>"utf-8"</em>?></p>
<p>"http://schemas.android.com/apk/res/android"</p>
<p>package=<em>"com.changcheng.activity"</em></p>
<p>android:versionCode=<em>"1"</em></p>
<p>android:versionName=<em>"1.0"</em>></p>
<p>"@drawable/icon" android:label=<em>"@string/app_name"</em>></p>
<p>".MainActivity"</p>
<p>android:label=<em>"@string/app_name"</em>></p>
<p></p>
<p>"android.intent.action.MAIN" /></p>
<p>"android.intent.category.LAUNCHER" /></p>
<p></p>
<p></p>
<p><!-- 新的Activity --></p>
<p>".NewActivity"</p>
<p>android:label=<em>"@string/new_activity"</em> /></p>
<p></p>
<p>"7" /></p>
<p></p>
<p>3).newactivity.xml</p>
<p><!--l version=<-->"1.0" encoding=<em>"utf-8"</em>?></p>
<p>"http://schemas.android.com/apk/res/android"</p>
<p>android:orientation=<em>"vertical"</em> android:layout_width=<em>"fill_parent"</em> android:layout_height=<em>"fill_parent"</em>></p>
<p>"fill_parent"</p>
<p>android:layout_height=<em>"wrap_content"</em> android:text=<em>"@string/newa_activity"</em> /></p>
<p><!-- 关闭按钮 --></p>
<p></p>
<p>"fill_parent" </p>
<p>android:layout_height=<em>"wrap_content"</em> android:text=<em>"@string/newa_bt_close"</em></p>
<p>android:id=<em>"@+id/newa_bt_close"</em> /></p>
<p></p>
<p>4).strings.xml</p>
<p><!--l version=<-->"1.0" encoding=<em>"utf-8"</em>?></p>
<p></p>
<p>"hello">Hello World, MainActivity!</p>
<p>"app_name">创建新的Activity</p>
<p>"bt_open_new_activity">打开新的Activity</p>
<p>"new_activity">新的Activity</p>
<p>"newa_activity">新的Activity</p>
<p>"newa_bt_close">关闭</p>
<p></p>
<p>5).MainActivity.java</p>
<p><strong>package</strong> com.changcheng.activity;</p>
<p><strong>import</strong> android.app.Activity;</p>
<p><strong>import</strong> android.content.Intent;</p>
<p><strong>import</strong> android.os.Bundle;</p>
<p><strong>import</strong> android.view.View;</p>
<p><strong>import</strong> android.widget.Button;</p>
<p><strong>public</strong> <strong>class</strong> MainActivity <strong>extends</strong> Activity {</p>
<p>/** Called when the activity is first created. */</p>
<p>@Override</p>
<p><strong>public</strong> <strong>void</strong> onCreate(Bundle savedInstanceState) {</p>
<p><strong>super</strong>.onCreate(savedInstanceState);</p>
<p>setContentView(R.layout.<em>main</em>);</p>
<p>// 获取按钮,并为按钮添加单击的事件</p>
<p>Button button = (Button) <strong>this</strong>.findViewById(R.id.<em>bte_open_new_activity</em>);</p>
<p>button.setOnClickListener(<strong>new</strong> View.OnClickListener() {</p>
<p>@Override</p>
<p><strong>public</strong> <strong>void</strong> onClick(View v) {</p>
<p>// 创建显式意图</p>
<p>Intent intent = <strong>new</strong> Intent(MainActivity.<strong>this</strong>, NewActivity.<strong>class</strong>);</p>
<p>// 打开新的Activity</p>
<p>startActivity(intent);</p>
<p>}</p>
<p>});</p>
<p>}</p>
<p>}</p>
<p><strong>二、</strong><strong>Activity</strong><strong>之间传递参数</strong></p>
<p>在桌面程序中窗口之间,我们可以通过构造参数或全局变量来传递数据。在WEB应用中,我们可以通过域(request/response/session...)在页面之间传递数据。那如何在Android的Activity之间传递参数呢?</p>
<p>通过intent.putExtra方法为意图添加参数,打开新的Activity后可以通过this.getIntent().getStringExtra()等方法获取参数。</p>
<p><strong>三、请求码与结果码</strong></p>
<p><strong></strong>在上面的程序中我们通过startActivity(intent)打开一个新的Activity,Android为了减少组件间的耦合,所以使用了Intent(Intent在下面会有介绍)。所以我们在onClick事件打开的新Activity不与主Activity在一个线程中。但是,当新Activity被关闭后,会触发主Activity的onActivityResult事件。<strong> </strong></p>
<p><strong>1.请求码</strong></p>
<p>在一个业务中可能在两个按钮被单击事件中打开同一个Activity,但我们在onActivityResult事件中如何判断是哪个按钮打开了新的Activity?请求码就是为解决这个问题的,那么我们打开新的Activity时应该使用startActivityForResult(intent, 1);。其中的第二个参数就是请求码。</p>
<p>onActivityResult事件:</p>
<p>@Override</p>
<p><strong>protected</strong> <strong>void</strong> onActivityResult(<strong>int</strong> requestCode, <strong>int</strong> resultCode, Intent data) {</p>
<p>// <strong>TODO</strong> Auto-generated method stub</p>
<p><strong>super</strong>.onActivityResult(requestCode, resultCode, data);</p>
<p>}</p>
<p>在onactivityResult事件中,通过判断requestCode更可知道被关闭Activity是通过哪个位置打开的。</p>
<p><strong>2.</strong><strong>结果码</strong></p>
<p>在一个业务中可能要打开多个不同的Activity,那关闭Activity时在onactivityResult事件中我们如何知道关闭的是哪一个Activity呢?结果码就是为解决这个问题的,那么我们打开新的Activity时应该使用setResult(2, intent);或在关闭Activity前调用ActivityObj.setResult(2);。其中的第一个参数就是结果码。</p>
<p>在onactivityResult事件中,通过判断resultCode更可知道是哪个Activity被关闭了。</p>
<p><strong>三、</strong><strong>Intent</strong><strong>意图</strong></p>
<p>Android基本的设计理念是鼓励减少组件间的耦合,因此Android提供了Intent (意图) ,Intent提供了一种通用的消息系统,它允许在你的应用程序与其它的应用程序间传递Intent来执行动作和产生事件。使用Intent可以激活Android应用的三个核心组件:活动、服务和广播接收器。</p>
<p>Intent可以划分成显式意图和隐式意图:</p>
<p>1).显式意图:调用Intent.setComponent()或Intent.setClass()方法指定了组件名或类对象的Intent为显式意图,显式意图明确指定了Intent应该传递给哪个组件。比如我们上边的打开新的Activity程序。</p>
<p>2).隐式意图:没有调用Intent.setComponent()或Intent.setClass()方法指定组件名或类对象的Intent为隐式意图。 Android系统会根据隐式意图中设置的动作(action)、类别(category)、数据(URI和数据类型)找到最合适的组件来处理这个意图。通过隐式意图打开新的Activity:</p>
<p>AndroidManifest.xml:</p>
<p><!-- 新的Activity --></p>
<p>".NewActivity" android:label=<em>"@string/new_activity"</em>></p>
<p></p>
<p>"com.changcheng.activity.NewActivity"/></p>
<p>"android.intent.category.DEFAULT" /></p>
<p></p>
<p></p>
<p>MainActivity:</p>
<p>@Override</p>
<p><strong>public</strong> <strong>void</strong> onClick(View v) {</p>
<p>// 创建显式意图</p>
<p>Intent intent = <strong>new</strong> Intent("com.changcheng.activity.NewActivity");</p>
<p>//Intent intent = new Intent(MainActivity.this, NewActivity.class);</p>
<p>// 打开新的Activity</p>
<p>startActivity(intent);// 发送Intent时,意图里相当于有一个类别:android.intent.category.DEFAULT</p>
<p>}</p>
<p>在intent过滤器中还可以添加多个action和category,还可以添加data。具体使用在此就不做总结了,可以查看相关资料或帮助文档。</p>
<p>3).显式意图与隐式意图的应用场景:</p>
<p>在项目内部建议使用显式意图。</p>
<p>在应用与应用之间只能使用隐式意图。</p>
<p><strong>四、</strong><strong>Activity</strong><strong>的生命周期</strong></p>
<p>Activity有三个状态:</p>
<p>当它在屏幕前台时(位于当前任务堆栈的顶部),它是激活或运行状态。它就是响应用户操作的Activity。</p>
<p>当它失去焦点但仍然对用户可见时,它处于暂停状态。即在它之上有另外一个Activity。这个Activity也许是透明的,或者没有完全覆盖全屏,所以被暂停的Activity仍对用户可见。暂停的Activity仍然是存活状态(它保留着所有的状态和成员信息并保持和窗口管理器的连接),但系统处于极低内存时仍然可以杀死这个Activity。</p>
<p>完全被另一个Activity覆盖时则处于停止状态。它仍然保留所有的状态和成员信息。然而对用户是不可见的,所以它的窗口将被隐藏,如果其它地方需要内存,则系统经常会杀死这个Activity。</p>
<p>当Activity从一种状态转变到另一种状态时,会调用以下保护方法来通知这种变化:</p>
<p>void onCreate(Bundle savedInstanceState)</p>
<p>void onStart()</p>
<p>void onRestart()</p>
<p>void onResume()</p>
<p>void onPause()</p>
<p>void onStop()</p>
<p>void onDestroy()</p>
<p><img title="2010-03-05 传智播客—Android(六)Activity、请求码与结果码、Intent、广播、服务 - 长城 - 长城" src="http://lh4.ggpht.com/_FMPy3IVGHrs/S5MSUmG-3AI/AAAAAAAABm0/tmXgf61IE2o/2FEBB48DB7BF9CE95C7B6AEBC9630A2B3FC1C4F6.jpg?imgmax=800" border="0" alt="2010-03-05 传智播客—Android(六)Activity、请求码与结果码、Intent、广播、服务 - 长城 - 长城" width="538" height="668"><br>这七个事件定义了Activity的完整生命周期。实现这些事件方法可以帮助我们监视其中的三个嵌套生命周期循环:</p>
<p>1).Activity的完整生命周期自第一次调用onCreate()开始,直至调用onDestroy()为止。Activity在onCreate()中设置所有“全局”状态以完成初始化,而在onDestroy()中释放所有系统资源。例如,如果Activity有一个线程在后台运行从网络上下载数据,它会在onCreate()创建线程,而在 onDestroy()销毁线程。</p>
<p>2).Activity的可视生命周期自onStart()调用开始直到相应的onStop()调用结束。在此期间,用户可以在屏幕上看到Activity,尽管它也许并不是位于前台或者也不与用户进行交互。在这两个方法之间,我们可以保留用来向用户显示这个Activity所需的资源。例如,当用户不再看见我们显示的内容时,我们可以在onStart()中注册一个BroadcastReceiver来监控会影响UI的变化,而在onStop()中来注消。onStart() 和 onStop() 方法可以随着应用程序是否为用户可见而被多次调用。</p>
<p>3).Activity的前台生命周期自onResume()调用起,至相应的onPause()调用为止。在此期间,Activity位于前台最上面并与用户进行交互。Activity会经常在暂停和恢复之间进行状态转换——例如当设备转入休眠状态或者有新的Activity启动时,将调用onPause() 方法。当Activity获得结果或者接收到新的Intent时会调用onResume() 方法。关于前台生命周期循环的例子请见PPT下方备注栏。</p>
<p><strong>五、广播接收者</strong></p>
<p>广播接收者(BroadcastReceiver)用于异步接收广播Intent,广播Intent的发送是通过调用Context.sendBroadcast()、Context.sendOrderedBroadcast()或者Context.sendStickyBroadcast()来实现的。通常一个广播Intent可以被订阅了此Intent的多个广播接收者所接收,广播接收者和JMS中的Topic消息接收者很相似。要实现一个广播接收者方法如下:</p>
<p>1).继承BroadcastReceiver,并重写onReceive()方法。</p>
<p>2).订阅感兴趣的广播Intent,订阅方法有两种:</p>
<p>· 使用代码进行订阅:</p>
<p>IntentFilter filter = new IntentFilter("android.provider.Telephony.SMS_RECEIVED");</p>
<p>IncomingSMSReceiver receiver = new IncomingSMSReceiver();</p>
<p>registerReceiver(receiver, filter);</p>
<p>· 在AndroidManifest.xml文件中的节点里进行订阅:</p>
<p></p>
<p></p>
<p></p>
<p></p>
<p></p>
<p>通常一个BroadcastReceiver对象的生命周期不超过5秒,所以在BroadcastReceiver里不能做一些比较耗时的操作,如果需要完成一项比较耗时的工作,可以通过发送Intent给Activity或Service,由Activity或Service来完成。</p>
<p><strong>六、服务</strong></p>
<p>Android中的服务和windows中的服务是类似的东西,服务一般没有用户操作界面,它运行于系统中不容易被用户发觉,可以使用它开发如监控之类的程序。服务的开发比较简单,如下:</p>
<p>1.继承Service类</p>
<p>public class SMSService extends Service { }</p>
<p>2.在AndroidManifest.xml文件中的节点里对服务进行配置:</p>
<p></p>
<p>服务不能自己运行,需要通过调用Context.startService()或Context.bindService()方法启动服务。这两个方法都可以启动Service,但是它们的使用场合有所不同。使用startService()方法启用服务,调用者与服务之间没有关连,即使调用者退出了,服务仍然运行。使用bindService()方法启用服务,调用者与服务绑定在了一起,调用者一旦退出,服务也就终止。</p>
<p>如果打算采用Context.startService()方法启动服务,在服务未被创建时,系统会先调用服务的onCreate()方法,接着调用onStart()方法。如果调用startService()方法前服务已经被创建,多次调用startService()方法并不会导致多次创建服务,但会导致多次调用onStart()方法。采用startService()方法启动的服务,只能调用Context.stopService()方法结束服务,服务结束时会调用onDestroy()方法。</p>
<p>如果打算采用Context.bindService()方法启动服务,在服务未被创建时,系统会先调用服务的onCreate()方法,接着调用onBind()方法。这个时候调用者和服务绑定在一起,调用者退出了,系统就会先调用服务的onUnbind()方法,接着调用onDestroy()方法。如果调用bindService()方法前服务已经被绑定,多次调用bindService()方法并不会导致多次创建服务及绑定(也就是说onCreate()和onBind()方法并不会被多次调用)。如果调用者希望与正在绑定的服务解除绑定,可以调用unbindService()方法,调用该方法也会导致系统调用服务的onUnbind()-->onDestroy()方法。</p>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值