android 【通话】设备被叫通话过程中,设备灭屏,过30秒左右,辅助机讲话,测试机无声音

18 篇文章 0 订阅

现象描述

【通话】设备被叫通话过程中,设备灭屏,过30秒左右,辅助机讲话,测试机无声音
开启QIT loglit后不可复现; 连接QXDM后不可复现,无法抓取相应log

问题分析

从上面描述看,已经无法导出有用的log信息,供上层来分析了 !!!
总的感觉时设备在屏灭一段时间后,进入了休眠状态。导致底层硬件出问题了。
由于驱动已经底层不懂,只能从上层来添加wake lock来尝试解决。

解决方案

在InCallActivity界面监听Intent.ACTION_SCREEN_OFF Intent.ACTION_SCREEN_ON 广播消息。并添加wake lock

/*meig:jicong.wang add for bug 7454 start {@*/
import android.os.PowerManager;
import android.content.BroadcastReceiver;
import android.content.IntentFilter;
/*meig:jicong.wang add for bug 7454 end @}*/
...
  /*meig:jicong.wang add for bug 7454 start {@*/
  private PowerManager mPowerManager;
  private PowerManager.WakeLock mWakeLock = null;
  private BroadcastReceiver mScreenReceiver = new BroadcastReceiver() {
      @Override
      public void onReceive(Context context, Intent intent) {
          String action = intent.getAction();
          LogUtil.d("InCallActivity action = ", action);
           if (action.equals("android.intent.action.SCREEN_OFF")) {
                wakeLockAcquire();
           } else if(action.equals("android.intent.action.SCREEN_ON")){
                wakeLockRelease();
           }
      }
  };
  private void wakeLockAcquire(){
    if (null != mWakeLock){
        mWakeLock.acquire();
        LogUtil.d("InCallActivity"," mWakeLock acquire");
    }
  }
  private void wakeLockRelease(){
    if (mWakeLock != null && mWakeLock.isHeld()) {
        mWakeLock.release();
        LogUtil.d("InCallActivity"," mWakeLock release");
    }
  }

...
  @Override
  protected void onCreate(Bundle icicle) {
    LogUtil.i("InCallActivity.onCreate", "");
    super.onCreate(icicle);
    ...
    /*meig:jicong.wang add for bug 7454 start {@*/
    mPowerManager = (PowerManager) getSystemService(Context.POWER_SERVICE);
    mWakeLock = mPowerManager.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "InCallActivity");
    IntentFilter filter = new IntentFilter();
    filter.addAction(Intent.ACTION_SCREEN_OFF);
    filter.addAction(Intent.ACTION_SCREEN_ON);
    registerReceiver(mScreenReceiver, filter);
    /*meig:jicong.wang add for bug 7454 end @}*/
 }              

  @Override
  protected void onDestroy() {
    LogUtil.i("InCallActivity.onDestroy", "");
    super.onDestroy();
    common.onDestroy();
  /*meig:jicong.wang add for bug 7454 start @}*/
    wakeLockRelease();
    unregisterReceiver(mScreenReceiver);
  /*meig:jicong.wang add for bug 7454 end @}*/
    }     
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值