Android四大基本组件分别是Activity,Service服务,Content Provider内容提供者,BroadcastReceiver广播接收器。
通常用于显示一个单独的界面,例如从app A点击某个按钮,跳到app B的某个界面,在此界面可以设置某些功能,设置完成之后这个界面就没有其他用途。这种场景就适合用activity。
具体实现就是app A在按钮响应事件中发送intent,app B中对此intent做响应,启动activity。
app B中Activity的具体启动如下:
step1: 在AndroidManifest.xml文件中加入下列描述。
step2: 创建test_activity.java在这个文件里面完成自己的代码.
public class test_activity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// 这个是intent发送之后启动这个activity自动调用的
super.onCreate(savedInstanceState);
setContentView(R.layout.voiprecord_settings);
// 此处可以加入自己的界面布局等东西
}
@Override
public void setContentView(View view) {
super.setContentView(view);
// do something here
}
}
如果app A还没完成,需要自己测试activity是否成功创建可以用下面的命令:
adb shell am start -a android.intent.action.RECORD_SETTINGS -n com.android.xxxx/com.android.xxxx.test_activity
参数解释:
-a: 表示action (android.intent.action.RECORD_SETTINGS)
-n: 表示packagename/activity的name,此处需要注意,这两者必须都有。
应用可以过滤自己感兴趣的广播事件并对此做出响应(例如启动activity,server等)。例如,在拨打电话的时候系统广播一个calling广播事件,然后录音app监听到有这个广播就停止录音。
那么广播是怎么发送出去的呢?
1. 普通广播的发送
Context.sendBroadcast(Intent myIntent)
2. 有序广播的发送
Context.sendOrderedBroadcast(intent, receiverPermission) 这个广播可以设置消息的优先级,优先处理高优先级的消息,同优先级先后随机
广播发送之后怎么被监听处理?
step1:在AndroidManifest.xml文件中加入下列描述。
step2: 创建MyBroadcastReceiver.java在这个文件里面完成自己的代码.
// eg: 收到消息后启动MyServer
import android.content.BroadcastReceiver;
public class MyBroadcastReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// 收到消息后自动调用onReceive
Intent serviceIntent = new Intent(context, MyServer.class);
// 传入MyServer.class
int state = intent.getIntExtra("state", 0);
serviceIntent.putExtra("state", state);
context.startService(serviceIntent); // 启动MyServer
}
}
// 注意!!! onReceive的生命周期只有10s左右,如果在此做超过10s的处理就会上报ANR。所以建议耗时的工作都放到server里面。
step3: 完成MyServer代码(MyServer.java)
public class MiuiMonitoringService extends Service {
@Override
public void onCreate() { // server启动之后最先执行的函数,在这里做一些初始话等工作
super.onCreate();
// 可以在此先做一些初始化工作
// 然后new 一个handler去处理监听到的广播
mHandler = new MyHandler();
}
private class MyHandler extends Handler {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
if (msg.what == calling_start) { // 例如收到了开始打电话
closesoundrecord(); // 关闭录音
} else if (msg.what == calling_stop) { // 收到了结束打电话
startsoundrecord(); // 开始录音
}
}
}
}
tips: 此处还有一个有意思的事情,app可以通过接收广播来启动server(静态广播),server启动之后还可以设置其他的广播监听事件(动态广播)。例如,我们发现打电话时启动Myserver,然后在server中,我们再去监听当前是否有耳机插入,如果有耳机插入再去其他操作。话不多说,看代码:
public class MiuiMonitoringService extends Service {
@Override
public void onCreate() {
super.onCreate();
getApplicationContext().registerReceiver(mIntentReceiver, new IntentFilter(AudioManager.ACTION_HEADSET_PLUG)); // 注册广播监听
}
private final BroadcastReceiver mIntentReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) { // 监听到有耳机插入事件
if (intent.getAction().equals(AudioManager.ACTION_HEADSET_PLUG)) {
// 响应事件
}
}
};
@Override
public void onDestroy() {
getApplicationContext().unregisterReceiver(mIntentReceiver); // onDestroy的时候需要反注册receiver
}
}
上面的broadcast里面我们已经大概了解过server。sever可以在broadcastreciver中被启动也可以在activity中被启动,也可以在其他server中被启动。
server的启动方法:
1. startService()
Intent serviceIntent = new Intent(context, MyServer.class); // 传入MyServer.class
int state = intent.getIntExtra("state", 0);
serviceIntent.putExtra("state", state);
context.startService(serviceIntent); // 启动MyServer
此方法启动的服务和调用者没有关系,即使调用者关闭了,服务仍然可以运行。此方法启动时,服务首次启动系统先调用服务的onCreate()-->onStart(),如果服务已经启动则只触发onStart()方法。停止服务要调用Context.stopService(),此时系统会调用onDestory()。
2. bindService()
mContext.bindService(new Intent().setComponent(new ComponentName(SYSTEM_SERVICE_PACKAGE,
SYSTEM_SERVICE_PACKAGE + ".TelecomCallService")),
new BinderServiceConnection(), Context.BIND_AUTO_CREATE);
此方法启动的服务与调用者绑定,只要调用者关闭服务就终止。服务首次启动系统先调用服务的onCreate()-->onBind(),如果服务已经启动再次调用不会再触发这2个方法。调用者退出时系统会调用服务的onUnbind()-->onDestory(),想主动解除绑定可使用Contex.unbindService(),系统依次调用onUnbind()-->onDestory()。
另外,app中的server都必须在AndroidManifast.xml中配置。
android平台提供了Content Provider使一个应用程序的指定数据集提供给其他应用程序。这些数据可以存储在文件系统中、在一个SQLite数据库、或以任何其他合理的方式,
其他应用可以通过ContentResolver类从该内容提供者中获取或存入数据.(相当于在应用外包了一层壳),
只有需要在多个应用程序间共享数据是才需要内容提供者。例如,通讯录数据被多个应用程序使用,且必须存储在一个内容提供者中
它的好处:统一数据访问方式。
此组件暂未用到,后面用到了会更新demo。