系出名门Android(4) - 活动(Activity), 服务(Service), 广播(Broadcast), 广播接收器(BroadcastReceiver)

简介:
[索引页]
[源码下载]


系出名门Android(4) - 活动(Activity), 服务(Service), 广播(Broadcast), 广播接收器(BroadcastReceiver)


作者: webabcd


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


1、演示 Activity 的基本用法,一个 Activity 启动另一个 Activity,启动另一个 Activity 时为其传递参数,被启动的 Activity 返回参数给启动者的 Activity
Main.java
package com.webabcd.activity; 

import android.app.Activity; 
import android.content.Intent; 
import android.os.Bundle; 
import android.util.Log; 
import android.view.View; 
import android.widget.Button; 
import android.widget.TextView; 

public  class Main  extends Activity { 
         
        TextView txt; 
         
         /** Called when the activity is first created. */ 
        @Override 
         public  void onCreate(Bundle savedInstanceState) { 
                 super.onCreate(savedInstanceState); 
                 this.setContentView(R.layout.main); 

                txt = (TextView)  this.findViewById(R.id.txt); 
                txt.setText( "Activity 1"); 

                Button btn = (Button)  this.findViewById(R.id.btn); 
                btn.setText( "启动另一个Activity"); 
                btn.setOnClickListener( new Button.OnClickListener() { 
                        @Override 
                         public  void onClick(View v) { 
                                 
                                 // 实例化 Intent,指定需要启动的 Activity 
                                Intent intent =  new Intent(); 
                                intent.setClass(Main. this, MyActivity. class); 

                                 // 实例化 Bundle,设置需要传递的参数 
                                Bundle bundle =  new Bundle(); 
                                bundle.putString( "name""webabcd"); 
                                bundle.putDouble( "salary", 100.13); 

                                 // 将需要传递的参数赋值给 Intent 对象 
                                intent.putExtras(bundle); 

                                 // startActivity(intent); // 启动指定的 Intent(不等待返回结果) 
                                 // Main.this.finish(); 
                                 
                                 // 启动指定的 Intent,并等待返回结果 
                                 // 其中第二个参数如果大于等于零,则返回结果时会回调 onActivityResult() 方法 
                                startActivityForResult(intent, 0); 
                        } 
                }); 
                 
                Log.d( "MyDebug""onCreate"); 
        } 
         
         // 被启动的 Activity 返回结果时的回调函数 
        @Override 
         protected  void onActivityResult( int requestCode,  int resultCode, Intent data) { 
                 if (resultCode == Activity.RESULT_OK){ 
                        Bundle bundle = data.getExtras(); 
                         
                        String name = bundle.getString( "name"); 
                         double salary = bundle.getDouble( "salary"); 
                         
                        txt.setText( "Activity 1" +  "\n名字:" + name +  "\n薪水:" + String.valueOf(salary)); 
                } 
        } 

        @Override 
         protected  void onStart() { 
                 // TODO Auto-generated method stub 
                 super.onStart(); 
                 
                Log.d( "MyDebug""onStart"); 
        } 

        @Override 
         protected  void onStop() { 
                 // TODO Auto-generated method stub 
                 super.onStop(); 
                 
                Log.d( "MyDebug""onStop"); 
        } 

        @Override 
         protected  void onRestart() { 
                 // TODO Auto-generated method stub 
                 super.onRestart(); 
                 
                Log.d( "MyDebug""onRestart"); 
        } 
         
        @Override 
         protected  void onPause() { 
                 // TODO Auto-generated method stub 
                 super.onPause(); 
                 
                Log.d( "MyDebug""onPause"); 
        } 

        @Override 
         protected  void onResume() { 
                 // TODO Auto-generated method stub 
                 super.onResume(); 
                 
                Log.d( "MyDebug""onResume"); 
        } 
         
        @Override 
         protected  void onDestroy() { 
                 // TODO Auto-generated method stub 
                 super.onDestroy(); 
                 
                Log.d( "MyDebug""onDestroy"); 
        } 
}
 
MyActivity.java
package com.webabcd.activity; 

import android.app.Activity; 
import android.content.Intent; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.Button; 
import android.widget.TextView; 

// 被另一个 Activity 所启动的 Activity 
public  class MyActivity  extends Activity { 
         
        Intent intent; 
         
         /** Called when the activity is first created. */ 
        @Override 
         public  void onCreate(Bundle savedInstanceState) { 
                 super.onCreate(savedInstanceState); 
                 this.setContentView(R.layout.main2); 

                 // 获取启动者传递过来的参数 
                intent =  this.getIntent(); 
                Bundle bundle = intent.getExtras();                 
                String name = bundle.getString( "name"); 
                 double salary = bundle.getDouble( "salary"); 
                 
                TextView txt = (TextView)  this.findViewById(R.id.txt); 
                txt.setText( "Activity 2" +  "\n名字:" + name +  "\n薪水:" + String.valueOf(salary)); 

                Button btn = (Button)  this.findViewById(R.id.btn); 
                btn.setText( "返回前一个Activity"); 
                btn.setOnClickListener( new Button.OnClickListener() { 
                         public  void onClick(View v) { 
                                 // 返回参数给启动者 
                                MyActivity. this.setResult(Activity.RESULT_OK, intent); 
                                MyActivity. this.finish(); 
                        } 
                }); 
        } 
}
 
AndroidManifest.xml
<? xml  version ="1.0"  encoding ="utf-8" ?> 
< manifest  xmlns:android ="http://schemas.android.com/apk/res/android" 
         package ="com.webabcd.activity"  android:versionCode ="1" 
         android:versionName ="1.0" > 
         < application  android:icon ="@drawable/icon"  android:label ="@string/app_name" > 
                 < activity  android:name =".Main"  android:label ="@string/app_name" > 
                         < intent-filter > 
                                 < action  android:name ="android.intent.action.MAIN"  /> 
                                 < category  android:name ="android.intent.category.LAUNCHER"  /> 
                         </ intent-filter > 
                 </ activity > 
                <!--  
                        如果有需要用到的 Activity ,则都要在这里做相应的配置 
                
--> 
                 < activity  android:name =".MyActivity"  android:label ="Activity 2"  /> 
         </ application > 
         < uses-sdk  android:minSdkVersion ="3"  /> 
</ manifest >
 
 
2、Service, Broadcast, BroadcastReceiver 的演示
Main.java
package com.webabcd.service; 

import android.app.Activity; 
import android.content.BroadcastReceiver; 
import android.content.ComponentName; 
import android.content.Context; 
import android.content.Intent; 
import android.content.IntentFilter; 
import android.content.ServiceConnection; 
import android.os.Bundle; 
import android.os.IBinder; 
import android.view.View; 
import android.view.View.OnClickListener; 
import android.widget.TextView; 

/* 
* startService() 和 bindService() 的区别    
* startService() - 正常理解就好 
* bindService() - 使当前上下文对象(本例中就是 Activity)通过一个 ServiceConnection 对象邦定到指定的 Service 。这样,如果上下文对象销毁了的话,那么其对应的 Service 也会被销毁 
*/
 
public  class Main  extends Activity  implements OnClickListener { 

         private TextView txtMsg; 
         
        @Override 
         public  void onCreate(Bundle savedInstanceState) { 
                 super.onCreate(savedInstanceState); 
                setContentView(R.layout.main); 

                setTitle( "android 之 service"); 

                 this.findViewById(R.id.btnStart).setOnClickListener( this); 
                 this.findViewById(R.id.btnStop).setOnClickListener( this); 
                 this.findViewById(R.id.btnBind).setOnClickListener( this); 
                 this.findViewById(R.id.btnUnbind).setOnClickListener( this); 
                 
                txtMsg = (TextView) this.findViewById(R.id.txtMsg); 
                 
                 // 实例化自定义的 BroadcastReceiver 
                receiver =  new UpdateReceiver(); 
                IntentFilter filter =  new IntentFilter(); 
                 // 为 BroadcastReceiver 指定 action ,使之用于接收同 action 的广播 
                filter.addAction( "com.webabcd.service.msg"); 
                 
                 // 以编程方式注册    BroadcastReceiver 。配置方式注册 BroadcastReceiver 的例子见 AndroidManifest.xml 文件 
                 // 一般在 OnStart 时注册,在 OnStop 时取消注册 
                 this.registerReceiver(receiver, filter); 
                 // this.unregisterReceiver(receiver); 
                 
        } 

        @Override 
         public  void onClick(View v) { 
                Intent intent =  new Intent(Main. this, MyService. class); 
                 switch (v.getId()) { 
                 case R.id.btnStart: 
                         this.startService(intent); 
                         break
                 case R.id.btnStop: 
                         this.stopService(intent); 
                         break
                 case R.id.btnBind: 
                         this.bindService(intent, conn, Context.BIND_AUTO_CREATE); 
                         break
                 case R.id.btnUnbind: 
                         this.unbindService(conn); 
                         break
                } 
        } 

         // bindService() 所需的 ServiceConnection 对象 
         private ServiceConnection conn =  new ServiceConnection() { 
                @Override 
                 public  void onServiceConnected(ComponentName className, IBinder service) { 
                         
                } 
                @Override 
                 public  void onServiceDisconnected(ComponentName className) { 
                         
                } 
        }; 
         
         private String msg=""; 
         private UpdateReceiver receiver; 
         // 实现一个 BroadcastReceiver,用于接收指定的 Broadcast 
         public  class UpdateReceiver  extends BroadcastReceiver{ 

                @Override 
                 public  void onReceive(Context context, Intent intent) { 
                        msg = intent.getStringExtra( "msg"); 
                         
                        txtMsg.append(msg +  "\n"); 
                } 
                 
        } 
}
 
MyService.java
package com.webabcd.service; 

import android.app.Service; 
import android.content.Intent; 
import android.os.IBinder; 
import android.util.Log; 

// 演示 Service 的生命周期。具体信息运行程序后在 LogCat 中查看 
public  class MyService  extends Service { 

        @Override 
         public IBinder onBind(Intent intent) { 
                 
                Log.d( "MyDebug""onBind"); 
                sendMsg( "onBind"); 
                 
                 // TODO Auto-generated method stub 
                 return  null
        } 

        @Override 
         public  void onCreate() { 
                 // TODO Auto-generated method stub 
                 super.onCreate(); 
                 
                Log.d( "MyDebug""onCreate"); 
                sendMsg( "onCreate"); 
        } 

        @Override 
         public  void onDestroy() { 
                 // TODO Auto-generated method stub 
                 super.onDestroy(); 
                 
                Log.d( "MyDebug""onDestroy"); 
                sendMsg( "onDestroy"); 
        } 

        @Override 
         public  void onRebind(Intent intent) { 
                 // TODO Auto-generated method stub 
                 super.onRebind(intent); 
                 
                Log.d( "MyDebug""onRebind"); 
                sendMsg( "onRebind"); 
        } 

        @Override 
         public  void onStart(Intent intent,  int startId) { 
                 super.onStart(intent, startId); 
                 
                Log.d( "MyDebug""onStart"); 
                sendMsg( "onStart"); 
        } 
         
        @Override 
         public  boolean onUnbind(Intent intent) { 
                 
                Log.d( "MyDebug""onUnbind"); 
                sendMsg( "onUnbind"); 
                 
                 // TODO Auto-generated method stub 
                 return  super.onUnbind(intent); 
        } 
         
         // 发送广播信息 
         private  void sendMsg(String msg){ 
                 // 指定广播目标的 action (注:指定了此 action 的 receiver 会接收此广播) 
                Intent intent =  new Intent( "com.webabcd.service.msg"); 
                 // 需要传递的参数 
                intent.putExtra( "msg", msg); 
                 // 发送广播 
                 this.sendBroadcast(intent); 
        } 
}
 
MyBootReceiver.java
package com.webabcd.service; 

import android.content.BroadcastReceiver; 
import android.content.Context; 
import android.content.Intent; 
import android.util.Log; 

public  class MyBootReceiver  extends BroadcastReceiver { 

         // 用于接收满足条件的 Broadcast(相应的 Broadcast 的注册信息详见 AndroidManifest.xml ,当系统启动完毕后会调用这个广播接收器) 
        @Override 
         public  void onReceive(Context arg0, Intent arg1) { 
                Log.d( "MyDebug""onReceive"); 
                 
                 // 启动服务 
                Intent service =  new Intent(arg0, MyService. class); 
                arg0.startService(service); 
        } 

}
 
AndroidManifest.xml
<? xml  version ="1.0"  encoding ="utf-8" ?> 
< manifest  xmlns:android ="http://schemas.android.com/apk/res/android" 
         package ="com.webabcd.service"  android:versionCode ="1" 
         android:versionName ="1.0" > 
         < application  android:icon ="@drawable/icon"  android:label ="@string/app_name" > 
                 < activity  android:name =".Main"  android:label ="@string/app_name" > 
                         < intent-filter > 
                                 < action  android:name ="android.intent.action.MAIN"  /> 
                                 < category  android:name ="android.intent.category.LAUNCHER"  /> 
                         </ intent-filter > 
                 </ activity > 
                 
                <!--  
                        如果有需要用到的 service ,则都要在这里做相应的配置 
                
--> 
                 < service  android:name =".MyService" > </ service > 
                 
                <!--  
                        注册一个 BroadcastReceiver 
                        其 intent-filter 为 android.intent.action.BOOT_COMPLETED(用于接收系统启动完毕的 Broadcast) 
                
--> 
                 < receiver  android:name =".MyBootReceiver" > 
                         < intent-filter > 
                                 < action  android:name ="android.intent.action.BOOT_COMPLETED"  /> 
                         </ intent-filter > 
                 </ receiver > 
         </ application > 
         
        <!--  
                接受系统启动完毕的 Broadcast 的权限 
        
--> 
         < uses-permission  android:name ="android.permission.RECEIVE_BOOT_COMPLETED"  /> 
         < uses-sdk  android:minSdkVersion ="3"  /> 
</ manifest >
 
 



          本文转自webabcd 51CTO博客,原文链接:http://blog.51cto.com/webabcd/342046 ,如需转载请自行联系原作者
相关文章
|
30天前
|
Android开发
Android面试之Activity启动流程简述
Android面试之Activity启动流程简述
77 6
|
1月前
|
消息中间件 Android开发 索引
Android面试高频知识点(4) 详解Activity的启动流程
Android面试高频知识点(4) 详解Activity的启动流程
26 3
|
1月前
|
缓存 前端开发 Android开发
Android实战之如何截取Activity或者Fragment的内容?
本文首发于公众号“AntDream”,介绍了如何在Android中截取Activity或Fragment的屏幕内容并保存为图片。包括截取整个Activity、特定控件或区域的方法,以及处理包含RecyclerView的复杂情况。
19 3
|
4月前
|
Android开发
Android面试题之Activity的启动模式和flag
Android Activity的四种启动模式:standard(默认,每次启动创建新实例),singleTop(栈顶复用,不走onCreate,调用onNewIntent),singleTask(栈内唯一,清除上方Activity)和singleInstance(单独栈内唯一)。启动模式在AndroidManifest.xml中配置,Intent Flags如FLAG_ACTIVITY_CLEAR_TOP和FLAG_ACTIVITY_SINGLE_TOP可实现类似功能。了解这些对于处理Activity栈管理至关重要。
52 0
|
1月前
|
Android开发
Android面试之Activity启动流程简述
Android面试之Activity启动流程简述
18 0
|
2月前
|
消息中间件 Android开发 索引
Android面试高频知识点(4) 详解Activity的启动流程
讲解Activity的启动流程了,Activity的启动流程相对复杂一下,涉及到了Activity中的生命周期方法,涉及到了Android体系的CS模式,涉及到了Android中进程通讯Binder机制等等, 首先介绍一下Activity,这里引用一下Android guide中对Activity的介绍:
50 4
|
3月前
|
XML Android开发 数据格式
android中两个Activity同时设定了intent-filter的category为android.intent.category.LAUNCHER,会发生什么情况?
本文通过案例分析了在Android中当两个Activity都设置了`android.intent.category.LAUNCHER`类别时,会导致它们同时在应用启动器的"所有应用"页面显示为不同的启动入口。
84 2
android中两个Activity同时设定了intent-filter的category为android.intent.category.LAUNCHER,会发生什么情况?
|
2月前
|
Android开发 开发者
Android面试之Activity启动流程简述
每个Android开发者都熟悉的Activity,但你是否了解它的启动流程呢?本文将带你深入了解。启动流程涉及四个关键角色:Launcher进程、SystemServer的AMS、应用程序的ActivityThread及Zygote进程。核心在于AMS与ActivityThread间的通信。文章详细解析了从Launcher启动Activity的过程,包括通过AIDL获取AMS、Zygote进程启动以及ActivityThread与AMS的通信机制。接着介绍了如何创建Application及Activity的具体步骤。整体流程清晰明了,帮助你更深入理解Activity的工作原理。
53 0
|
3月前
|
编解码 网络协议 Android开发
Android平台GB28181设备接入模块实现后台service按需回传摄像头数据到国标平台侧
我们在做Android平台GB28181设备对接模块的时候,遇到这样的技术需求,开发者希望能以后台服务的形式运行程序,国标平台侧没有视频回传请求的时候,仅保持信令链接,有发起视频回传请求或语音广播时,打开摄像头,并实时回传音视频数据或接收处理国标平台侧发过来的语音广播数据。
|
3月前
|
开发工具 Android开发
解决Manifest merger failed : android:exported needs to be explicitly specified for <activity>
解决Manifest merger failed : android:exported needs to be explicitly specified for <activity>
84 1