Android采用消息推送实现类似微信视频接听

Android采用消息推送实现类似微信视频接听,第1张

概述Android采用消息推送实现类似微信视频接听 本文实例为大家分享了Android实现类似微信视频接听的具体代码,供大家参考,具体内容如下 1.背景需求:业务需要接入视频审核功能,在PC 端发起视频通话,移动端显示通话界面点击接听后进行1对1视频通话. 2.解决方案:因为项目没有IM功能.只集成了极光消息推送(极光消息推送接入参考官方文档,经过跟需求沟通,采用消息推送调起通话接听界面.再集成腾讯实时音视频SDK(具体集成方式参考官方文档).最终实现类似微信1对1通话功能. 3.技术实现: A:编写一个广播接收器,并且在 AndroidMani

本文实例为大家分享了AndroID实现类似微信视频接听的具体代码,供大家参考,具体内容如下

1、背景需求:业务需要接入视频审核功能,在PC 端发起视频通话,移动端显示通话界面点击接听后进行1对1视频通话。

2、解决方案:因为项目没有IM功能。只集成了极光消息推送(极光消息推送接入参考官方文档,经过跟需求沟通,采用消息推送调起通话接听界面。再集成腾讯实时音视频SDK(具体集成方式参考官方文档)。最终实现类似微信1对1通话功能。

3、技术实现:

A:编写一个广播接收器,并且在 AndroIDManifest中注册,这就是一个全局的广播接收器。应用退到后台或者应用进程被kill,只要极光的push进程是live,就能接受到消息,启动通话接听界面。

/** * Created on 2018/3/29 16:19 * @author baokang.jia * 极光推送广播接收器 */public class JiGuangPushReceiver extends broadcastReceiver {  private static final String TAG = "JPushReceiver";  @OverrIDe  public voID onReceive(Context context,Intent intent) {    Bundle bundle = intent.getExtras();    if (bundle == null) {      return;    }    //拿到锁屏管理者    KeyguardManager km = (KeyguardManager) context.getSystemService(Context.KEyguard_SERVICE);    if (km != null && km.iskeyguardlocked()) {  //为true就是锁屏状态下      startLoginorCallActivity(context,bundle);    } else {      if (JPushInterface.ACTION_REGISTRATION_ID.equals(intent.getAction())) {        String regID = bundle.getString(JPushInterface.EXTRA_REGISTRATION_ID);        LogUtil.d(TAG,"[MyReceiver] 接收Registration ID : " + regID);        //send the Registration ID to yours server...      } else if (JPushInterface.ACTION_MESSAGE_RECEIVED.equals(intent.getAction())) {        LogUtil.d(TAG,"[MyReceiver] 接收到推送下来的自定义消息: " + bundle.getString(JPushInterface.EXTRA_MESSAGE));      } else if (JPushInterface.ACTION_NOTIFICATION_RECEIVED.equals(intent.getAction())) {//接收到推送下来的通知        //启动通话界面        startLoginorCallActivity(context,bundle);      } else if (JPushInterface.ACTION_NOTIFICATION_OPENED.equals(intent.getAction())) {//点击通知栏        //启动通话界面        startLoginorCallActivity(context,bundle);        //清除所有状态的通知        JPushInterface.clearallNotifications(context);      } else if (JPushInterface.ACTION_RICHPUSH_CALLBACK.equals(intent.getAction())) {        LogUtil.d(TAG,"[MyReceiver] 用户收到到RICH PUSH CALLBACK: " + bundle.getString(JPushInterface.EXTRA_EXTRA));        //在这里根据 JPushInterface.EXTRA_EXTRA 的内容处理代码,比如打开新的Activity, 打开一个网页等..      }    }  }  /**   * 未登录跳转登录界面,   * else 启动通话接听界面   */  private voID startLoginorCallActivity(Context context,Bundle bundle) {    //EXTRA_EXTRA    String extras = bundle.getString(JPushInterface.EXTRA_EXTRA);    String userID = SPUtil.getString(context,Constants.LOGIN_USER_ID);    if (TextUtils.isEmpty(userID)) {      //启动登录界面      Intent intent = new Intent(context,LoginActivity.class);      intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);      context.startActivity(intent);    } else {      //启动通话接听界面      int notifyID = bundle.getInt(JPushInterface.EXTRA_NOTIFICATION_ID);      if (!TextUtils.isEmpty(extras) && extras.contains("androIDNotification extras key")){        ReceiveTalkActivity.startReceiveTalkActivity(context,extras,notifyID);      }    }  } }//在AndroIDManifest注册全局自定义广播接收器<receiver      androID:name=".event.JiGuangP`在这里插入代码片`ushReceiver"      androID:enabled="true"      androID:exported="false">      <intent-filter>        <action androID:name="cn.jpush.androID.intent.REGISTRATION" /> <!-- required 用户注册SDK的intent -->        <action androID:name="cn.jpush.androID.intent.MESSAGE_RECEIVED" /> <!-- required 用户接收SDK消息的intent -->        <action androID:name="cn.jpush.androID.intent.NOTIFICATION_RECEIVED" /> <!-- required 用户接收SDK通知栏信息的intent -->        <action androID:name="cn.jpush.androID.intent.NOTIFICATION_OPENED" /> <!-- required 用户打开自定义通知栏的intent -->        <action androID:name="cn.jpush.androID.intent.CONNECTION" /> <!-- 接收网络变化 连接/断开 since 1.6.3 -->        <category androID:name="${PACKAGE_name}" />      </intent-filter>    </receiver>

B:启动通话接听界面,启动接听界面后获取当前手机模式

AudioManager audio = (AudioManager) this.getSystemService(Context.AUdio_SERVICE);//手机模式,振动,精英、响铃,更具不同模式振动或者响铃,具体可参考以下的实现代码。//点击接听按钮后跳转腾讯视频通话界面
/** * Created on 2019/4/28 16:19 * @author baokang.jia * 视频预审接听界面 */public class ReceiveTalkActivity extends BaseActivity {  private static String PUSH_MSG_KEY = "push_msg_key";  private static String NOTIFICATION_ID_KEY = "notification_ID_key";  /**   * 腾讯云注册分配的appID   */  private int sdkAppID =  /**   * 检查运行时权限   */  private boolean mCheckPermissionResult = false;  private PushMsgBean mpushMsgBean;  /**   * 媒体播放   */  private MediaPlayer mMediaPlayer;  /**   * 震动   */  private Vibrator mVibrator;  @OverrIDe  protected voID onCreate(Bundle savedInstanceState) {    Window window = getwindow();    //悬浮窗    WindowVIEwUtil.setwindowfloatAndScreenOn(window,this);    super.onCreate(savedInstanceState);    //初始化倒计时器    initCountDownTimer();    //请求权限    requestMustPermission();    initVIEws();    //根据通知ID清除状态栏对应的通知    JPushInterface.clearallNotifications(this);    //持续震动和响铃    continuedVibratorAndMediaPlayer();  }  /**   * 60秒后关闭activity   */  private voID initCountDownTimer() {    long time = 30000;    long countDownInterval = 1000;    CountDownTimer downTimer = new CountDownTimer(time,countDownInterval) {      @OverrIDe      public voID onTick(long millisUntilFinished) {      }      @OverrIDe      public voID onFinish() {        finish();      }    };    downTimer.start();  }  @OverrIDe  protected int getLayoutID() {    return R.layout.activity_receive_talk;  }  @OverrIDe  protected boolean initToolbar() {    return false;  }  @OverrIDe  protected voID getIntent(Intent intent) {    String pushMsg = getIntent().getStringExtra(PUSH_MSG_KEY);    //notificationID = getIntent().getIntExtra(NOTIFICATION_ID_KEY,0);    parsePushMsg(pushMsg);  }  @OverrIDe  protected voID initVIEws() {    button btnCancel = findVIEwByID(R.ID.btn_cancel_call);    button btnAnswer = findVIEwByID(R.ID.btn_answer_call);    btnCancel.setonClickListener(v ->{      mVibrator.cancel();      mMediaPlayer.stop();      finish();    });    btnAnswer.setonClickListener(v -> {      mVibrator.cancel();      mMediaPlayer.stop();      if (mCheckPermissionResult) {        Intent intent = new Intent(this,TRTCMainActivity.class);        intent.putExtra("roomID",Integer.valueOf(mpushMsgBean.getRoomID()));        intent.putExtra("userID",mpushMsgBean.getUserID());        intent.putExtra("sdkAppID",sdkAppID);        intent.putExtra("userSig",mpushMsgBean.getUserSig());        startActivity(intent);        finish();      } else {        ToastUtil.longToast("需要的权限被拒绝,无法开启视频审核");      }    });  }  /**   * 持续响铃和震动   */  private voID continuedVibratorAndMediaPlayer() {    //获取媒体播放器    mMediaPlayer = new MediaPlayer();    try {      mMediaPlayer.setDataSource(this,ringtoneManager          .getDefaultUri(ringtoneManager.TYPE_ringtone));//这里我用的通知声音,还有其他的,大家可以点进去看      mMediaPlayer.prepare();    } catch (IOException e) {      e.printstacktrace();    }    //取得震动服务的句柄    mVibrator = (Vibrator)this. getSystemService(VIBRATOR_SERVICE);    //获取当前手机模式    AudioManager audio = (AudioManager) this.getSystemService(Context.AUdio_SERVICE);    if (audio != null) {      switch (audio.getRingerMode()) {        case AudioManager.RINGER_MODE_SILENT://静音          //do sth          break;        case AudioManager.RINGER_MODE_norMAL://响铃          mMediaPlayer.start();          mMediaPlayer.setLooPing(true); //循环播放          break;        case AudioManager.RINGER_MODE_VIBRATE://震动          //数组参数意义:第一个参数为等待指定时间后开始震动,          //震动时间为第二个参数。后边的参数依次为等待震动和震动的时间          //第二个参数为重复次数,-1为不重复,0为一直震动          if (mVibrator != null) {            mVibrator.vibrate( new long[]{1000,1000},0);          }          break;      }    }  }  private voID parsePushMsg(String pushMsg) {    if (!TextUtils.isEmpty(pushMsg)) {      CustomerMsg customerMsg = GsonUtil.fromJson(pushMsg,CustomerMsg.class);      String pushMsgContent = customerMsg.getPushMsgContent();      pushMsgContent = pushMsgContent.replace("\","");      LogUtil.d(Constants.LOG,"pushMsgContent="+pushMsgContent);      mpushMsgBean = GsonUtil.fromJson(pushMsgContent,PushMsgBean.class);    }  }  /**   * 申请应用必须的权限   */  private voID requestMustPermission() {    AndPermission.with(this)        .requestCode(Constants.REQUEST_CODE_PERMISSION)        .permission(            Manifest.permission.WRITE_EXTERNAL_STORAGE,Manifest.permission.CAMERA,Manifest.permission.RECORD_AUdio,Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.VIBRATE,Manifest.permission.disABLE_KEyguard,Manifest.permission.WAKE_LOCK        )        .rationale((requestCode,rationale) ->            //再次申请被拒绝的权限            AlertDialog.newBuilder(this)                .setTitle(R.string.Title_dialog)                .setMessage(R.string.message_permission_Failed)                .setPositivebutton(R.string.ok,(dialog,which) -> {                  dialog.cancel();                  rationale.resume();                })                .setNegativebutton(R.string.no,which) -> {                  dialog.cancel();                  rationale.cancel();                }).show())        .callback(new PermissionListener() {          @OverrIDe          public voID onSucceed(int requestCode,@NonNull List<String> grantPermissions) {            mCheckPermissionResult = true;          }          @OverrIDe          public voID onFailed(int requestCode,@NonNull List<String> denIEdPermissions) {            mCheckPermissionResult = false;          }        })        .start();  }  /**   * 界面未销毁,启动此界面时回调   */  @OverrIDe  protected voID onNewIntent(Intent intent) {    super.onNewIntent(intent);    String pushMsg = intent.getStringExtra(PUSH_MSG_KEY);    //notificationID = intent.getIntExtra(NOTIFICATION_ID_KEY,0);    parsePushMsg(pushMsg);  }  /**   * 提供给外部调用启动接听界面的activity   *   * @param cex   上下文对象   * @param pushMsg 消息内容   * @param notifyID 通知ID   */  public static voID startReceiveTalkActivity(Context cex,String pushMsg,int notifyID) {    Intent calintent = new Intent(cex,ReceiveTalkActivity.class);    //携带数据    calintent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);    calintent.putExtra(PUSH_MSG_KEY,pushMsg);    calintent.putExtra(NOTIFICATION_ID_KEY,notifyID);    cex.startActivity(calintent);  }  @OverrIDe  protected voID onDestroy() {    super.onDestroy();    mMediaPlayer.stop();    mVibrator.cancel();  }}//注册ReceiveTalkActivity, androID:launchMode="singleTask"<activity androID:name=".trtc.vIEw.ReceiveTalkActivity"      androID:launchMode="singleTask"      androID:screenorIEntation="portrait"      />

总结:项目中考虑时间和成本问题。没有接入IM功能。消息推送不可靠,极光的push进程被杀,是收不到消息。当打开app后,会蹦出很多通知。这只是简易的实现了在pc调起移动端进行视频通话。这有很多因素是没有考虑进去的,在此先记录下吧。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

总结

以上是内存溢出为你收集整理的Android采用消息推送实现类似微信视频接听全部内容,希望文章能够帮你解决Android采用消息推送实现类似微信视频接听所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1144302.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存