广播中alertDialog弹窗的显示以及隐藏

- 广播的使用:

第一步:定义一个广播接收者(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);
        }
    }
};
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值