- 广播的使用:
第一步:定义一个广播接收者(BroadcastReceiver)
public class CancelBroadcast extends BroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
//将其设为true
CancelCall.cancel="true";
}
}
第二步:在manifest里面注册该广播
<receiver android:name=".CancelBroadcast" >
<intent-filter>
<action android:name="com.cravechina.iot.crave.CANCEL" />
</intent-filter>
</receiver>
第三步:触发广播的响应
if(message.Message.equals("cancelCall")){
Intent intent1=new Intent("com.cravechina.iot.crave.CANCEL");
sendBroadcast(intent1);
String i=CancelCall.cancel;
System.out.println(i);
}
以上就是广播的基本使用,下面进入正题
在广播中alertDialog弹窗以及调用系统铃声的实现:
public class VideoChatBroadcast extends BroadcastReceiver{
private MediaPlayer mediaPlayer;
AlertDialog alertDialog;
@Override
public void onReceive(final Context context, Intent intent) {
//进来要将这个值设为false
CancelCall.cancel="false";
Bundle bundle = intent.getExtras();
final String url=bundle.getString("msg");
AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(context);
//调用铃声
mediaPlayer = new MediaPlayer();
try {
mediaPlayer.setDataSource(context, RingtoneManager
.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION));
mediaPlayer.setLooping(true); //设置循环
mediaPlayer.prepare();
mediaPlayer.start();
} catch (Exception e) {
e.printStackTrace();
}
dialogBuilder.setTitle("提示");
dialogBuilder.setMessage("有人来电");
dialogBuilder.setCancelable(false);
dialogBuilder.setPositiveButton("接听", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
Intent intent=new Intent(context,VideoChat2Activity.class);
intent.putExtra("msg", url);
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intent);
mediaPlayer.stop();
mediaPlayer.release();
}
});
dialogBuilder.setNegativeButton("拒绝", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
mediaPlayer.stop();
mediaPlayer.release();
dialog.dismiss();
//拒绝接听还需要发送消息给手机端,告知拒绝 了
cancelMessage(context);
}
});
alertDialog = dialogBuilder.create();
// 需要设置AlertDialog的类型,保证在广播接收器中可以正常弹出
alertDialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);
alertDialog.show();
//计时器
mHandler.postDelayed(mRunnable, 1000);
}
private void cancelMessage(final Context context) {
//拿到自己的token
SharedPreferences sp=context.getSharedPreferences("config", context.MODE_PRIVATE);
String token=sp.getString("token", null);
//拿到设备的token
SharedPreferences sp2=context.getSharedPreferences("deviceData", context.MODE_PRIVATE);
String deviceToken=sp2.getString("deviceToken", null);
//设备token集合
ArrayList<String>tokenList=new ArrayList<String>();
tokenList.add(deviceToken);
//拿到取消的消息
String msg="cancelCall";
//base64编码
msg=Base64.encodeToString(msg.getBytes(),Base64.DEFAULT);
RequestParams params=new RequestParams();
//添加请求头
params.setHeader("X-Client-Token", token);
params.setHeader("Content-Type", "application/json");
params.setHeader("Cache-Control", "no-cache");
Map<String, Object> map =new HashMap<String, Object>();
map.put("msg", msg);
map.put("flag", 2);
map.put("callback", 1);
map.put("access_tokens", tokenList);
//转换成json
Gson gson=new Gson();
String result=gson.toJson(map);
try {
params.setBodyEntity(new StringEntity(result));
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// gson.toJson(map, Map.class);
HttpUtils utils=new HttpUtils();
utils.send(HttpMethod.POST, GlobalUrl.CANCEL_CALL_URL, params,new RequestCallBack<String>() {
@Override
public void onFailure(HttpException arg0, String arg1) {
Toast.makeText(context, "发送失败", Toast.LENGTH_SHORT).show();
}
@Override
public void onSuccess(ResponseInfo<String> arg0) {
Toast.makeText(context, "发送失败", Toast.LENGTH_SHORT).show();
// UIUtils.showToast(VideoChatActivity.this, “发送成功”);
}
});
}
// }
String cancel;
Handler mHandler=new Handler();
Runnable mRunnable=new Runnable() {
@Override
public void run() {
mHandler.postDelayed(mRunnable, 1000);
cancel=CancelCall.cancel;
System.out.println("cancel1:"+cancel);
if(cancel.equals("true")){
if(mediaPlayer.isPlaying()){
mediaPlayer.stop();
mediaPlayer.release();
}
alertDialog.dismiss();
//停止handler
mHandler.removeCallbacks(mRunnable);
}
}
};
}
以上代码是广播接收者中的弹窗的实现以及隐藏;同样的,这个广播也需要注册与触发。
注册:
<!-- 注册广播 -->
<receiver android:name="com.cravechina.iot.cravehome.broadcast.VideoChatBroadcast" >
<intent-filter>
<action android:name="com.cravechina.iot.crave.VIDEOCHAT" />
</intent-filter>
</receiver>
触发:
Intent intent = new Intent("com.cravechina.iot.crave.VIDEOCHAT");
Bundle bundle = new Bundle();
bundle.putString("msg",message.Message);//这里可以传送数据
intent.putExtras(bundle);
sendBroadcast(intent);
以上就是弹窗的显示与隐藏。
这时候项目还有一个需求,弹窗需要在接到某个消息的情况下自动隐藏,也就是类似电话被挂断时的效果:
我的做法就是定义一个全局变量,在做一个广播,当接收到消息变化的时候,广播就发送这个全局变量发生了改变,然后在弹窗的广播里面写一个计时器一直在取这个全局变量,当发现发生了变化则弹窗消失。
下面是代码:
定义的全局变量:
public class CancelCall {
public static String cancel="false";
}
广播就是上面的两个,第一个是广播全局变量的变化,第二个就是计时器获取变量之后绝对弹窗的状态
当第一个广播收到消息的时候,将这个全局变量的值改变,然后第二个播通过计时器获取的值也改变了,弹窗的转台就发送了改变。
计时器获取全局变量:
String cancel;
Handler mHandler=new Handler();
Runnable mRunnable=new Runnable() {
@Override
public void run() {
mHandler.postDelayed(mRunnable, 1000);
cancel=CancelCall.cancel;
System.out.println("cancel1:"+cancel);
if(cancel.equals("true")){
if(mediaPlayer.isPlaying()){
mediaPlayer.stop();
mediaPlayer.release();
}
alertDialog.dismiss();
//停止handler
mHandler.removeCallbacks(mRunnable);
}
}
};