Android12 呼出电话呼叫中挂断后铃声继续响一下的处理

2024-08-20 21:12

本文主要是介绍Android12 呼出电话呼叫中挂断后铃声继续响一下的处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


项目中遇到一个问题,测试同事测试电话时发现,呼出电话时,被呼叫电话非彩铃模式,本端设备播放“嗡~嗡~”正常呼叫音,未拨通时挂断电话,挂断后,在铃声未播放完成时会继续播放铃声,提出要优化为直接挂断,禁止有余音。最后搞定,我们总结下~

一捕获log:

呼出电话,然后挂断,记住响玲时间点,然后挂断。导出log。

二分析

  1. 设备有自定义手柄,该逻辑是需要根据手柄抬起/放下切换音频 通道,刚开始方案时声音从手柄切换到外放延迟3s,然后再切换音频通道。这样体验是可以的。但是连接蓝牙手柄时音频通道切换是走原生切换逻辑,说明该问题点不在音频通道切换这里。
  2. 分析log 根据导出来的log我们看下日志
    【outcallringingdeley0808_095957\ap\000-0808_095935】
    S064D87  08-08 09:59:56.406  1147  6829 I Telecom : CallsManager: setCallState DIALING -> DIALING, call: [Call id=TC@8//播放回铃音
    R06560B  08-08 09:59:58.474  1357  1357 I ImsPhoneCall: maybeChangeRingbackState: state=ALERTING
    R06560C  08-08 09:59:58.474  1357  1357 I ImsPhoneCall: isLocalTone: audioDirection=0, playRingback=true
    S06562F  08-08 09:59:58.503  1147  1539 I Telecom : RingbackPlayer: Playing the ringback tone for [Call id=TC@8, state=DIALING, tpac=ComponentInfo{com.android.phone/com.android.services.telephony.TelephonyConnectionService}, ***, UserHandle{0}, cmgr=ComponentInfo{com.android.phone/com.android.services.telephony.TelephonyConnectionService}, ***, UserHandle{0}, handle=tel:*********78, vidst=A, childs(0), has_parent(false), cap=[ sup_hld mut VTlrx VTltx VTlbi], prop=[ HD]].: CSW.SRR(cap)@Ds0//挂掉电话,停止播放
    M065BEF  08-08 10:00:07.488  6832  6832 I Dialer  : InCallFragment.onClick - end call button clicked
    S065C4A  08-08 10:00:07.531  1147  2776 I Telecom : TelecomUtils: isSupportByCarrierConfig key:carrier_feature_play_rbk_bool value:false: ICA.dC(cad)@Dwg
    S065C52  08-08 10:00:07.532  1147  2776 I Telecom : RingbackPlayer: Stopping the ringback tone for [Call id=TC@8, state=DISCONNECTING, tpac=ComponentInfo{com.android.phone/com.android.services.telephony.TelephonyConnectionService}, ***, UserHandle{0}, cmgr=ComponentInfo{com.android.phone/com.android.services.telephony.TelephonyConnectionService}, ***, UserHandle{0}, handle=tel:*********78, vidst=A, childs(0), has_parent(false), cap=[ sup_hld mut VTlrx VTltx VTlbi], prop=[ HD]].: ICA.dC(cad)@Dwg//又播放回铃音?(state=DISCONNECTING不应该进入播放回铃音)
    S065C79  08-08 10:00:07.546  1147  2776 I Telecom : RingbackPlayer: Playing the ringback tone for [Call id=TC@8, state=DISCONNECTING, tpac=ComponentInfo{com.android.phone/com.android.services.telephony.TelephonyConnectionService}, ***, UserHandle{0}, cmgr=ComponentInfo{com.android.phone/com.android.services.telephony.TelephonyConnectionService}, ***, UserHandle{0}, handle=tel:*********78, vidst=A, childs(0), has_parent(false), cap=[ sup_hld mut VTlrx VTltx VTlbi], prop=[ HD]].: ICA.dC(cad)@Dwg//再停止播放
    R066012  08-08 10:00:08.307  1357  1357 I ImsPhoneCall: maybeChangeRingbackState: state=DISCONNECTED
    R066013  08-08 10:00:08.307  1357  1357 I ImsPhoneCall: maybeChangeRingbackState: stop ringback
    M066030  08-08 10:00:08.337  1357  1357 V Telephony: MSG_RINGBACK_TONE
    S0660AD  08-08 10:00:08.397  1147  1214 I Telecom : RingbackPlayer: Stopping the ringback tone for [Call id=TC@8, state=DISCONNECTED, tpac=ComponentInfo{com.android.phone/com.android.services.telephony.TelephonyConnectionService}, ***, UserHandle{0}, cmgr=ComponentInfo{com.android.phone/com.android.services.telephony.TelephonyConnectionService}, ***, UserHandle{0}, handle=tel:*********78, vidst=A, childs(0), has_parent(false), cap=[ sup_hld mut VTlrx VTltx VTlbi], prop=[ HD]].: CSW.sDc(cap)@DxQ
    S06605A  08-08 10:00:08.365  1147  1214 I Telecom : CallsManager: setCallState DISCONNECTING -> DISCONNECTED, call: [Call id=TC@8, state=DISCONNECTING
    (20240813T07:20:08) 

    三修改方案

diff --git a/src/com/android/server/telecom/CallAudioManager.java b/src/com/android/server/telecom/CallAudioManager.java
index d4a3afd00..c2ec064be 100644
--- a/src/com/android/server/telecom/CallAudioManager.java
+++ b/src/com/android/server/telecom/CallAudioManager.java
@@ -108,10 +108,18 @@ public class CallAudioManager extends CallsManagerListenerBase {@Overridepublic void onCallStateChanged(Call call, int oldState, int newState) {
+        printLog("onCallStateChanged: oldState:" + oldState +",newState:" +newState);if (shouldIgnoreCallForAudio(call)) {// No audio management for calls in a conference, or external calls.return;}
+
+        if (oldState == newState) {
+           // State did not change, so no need to do anything.
+          printLog("oldState == newState,return:");
+           
+           return;
+        }Log.d(LOG_TAG, "Call state changed for TC@%s: %s -> %s", call.getId(),CallState.toString(oldState), CallState.toString(newState));@@ -124,15 +132,19 @@ public class CallAudioManager extends CallsManagerListenerBase {updateForegroundCall();if (shouldPlayDisconnectTone(oldState, newState)) {
+        printLog("onCallStateChanged: shouldPlayDisconnectTone(oldState, newState):" +shouldPlayDisconnectTone(oldState, newState));
+playToneForDisconnectedCall(call);}

参考文章

Android 通话流程相关分析

Android打电话流程

安卓10拨号流程详细总结

android N 拨打电话流程(MO)

这篇关于Android12 呼出电话呼叫中挂断后铃声继续响一下的处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1091188

相关文章

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

Thymeleaf:生成静态文件及异常处理java.lang.NoClassDefFoundError: ognl/PropertyAccessor

我们需要引入包: <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>sp

jenkins 插件执行shell命令时,提示“Command not found”处理方法

首先提示找不到“Command not found,可能我们第一反应是查看目标机器是否已支持该命令,不过如果相信能找到这里来的朋友估计遇到的跟我一样,其实目标机器是没有问题的通过一些远程工具执行shell命令是可以执行。奇怪的就是通过jenkinsSSH插件无法执行,经一番折腾各种搜索发现是jenkins没有加载/etc/profile导致。 【解决办法】: 需要在jenkins调用shell脚

明明的随机数处理问题分析与解决方案

明明的随机数处理问题分析与解决方案 引言问题描述解决方案数据结构设计具体步骤伪代码C语言实现详细解释读取输入去重操作排序操作输出结果复杂度分析 引言 明明生成了N个1到500之间的随机整数,我们需要对这些整数进行处理,删去重复的数字,然后进行排序并输出结果。本文将详细讲解如何通过算法、数据结构以及C语言来解决这个问题。我们将会使用数组和哈希表来实现去重操作,再利用排序算法对结果

【详细介绍一下GEE】

GEE(Google Earth Engine)是一个强大的云计算平台,它允许用户处理和分析大规模的地球科学数据集,如卫星图像、气候模型输出等。以下是对GEE用法的详细介绍: 一、平台访问与账户设置 访问GEE平台: 用户可以通过访问Google Earth Engine的官方网站来开始使用GEE。 创建账户: 用户需要注册并登录Google账户,然后申请访问GEE平台。申请过程可能需要提

8. 自然语言处理中的深度学习:从词向量到BERT

引言 深度学习在自然语言处理(NLP)领域的应用极大地推动了语言理解和生成技术的发展。通过从词向量到预训练模型(如BERT)的演进,NLP技术在机器翻译、情感分析、问答系统等任务中取得了显著成果。本篇博文将探讨深度学习在NLP中的核心技术,包括词向量、序列模型(如RNN、LSTM),以及BERT等预训练模型的崛起及其实际应用。 1. 词向量的生成与应用 词向量(Word Embedding)

使用协程实现高并发的I/O处理

文章目录 1. 协程简介1.1 什么是协程?1.2 协程的特点1.3 Python 中的协程 2. 协程的基本概念2.1 事件循环2.2 协程函数2.3 Future 对象 3. 使用协程实现高并发的 I/O 处理3.1 网络请求3.2 文件读写 4. 实际应用场景4.1 网络爬虫4.2 文件处理 5. 性能分析5.1 上下文切换开销5.2 I/O 等待时间 6. 最佳实践6.1 使用 as

Level3 — PART 3 — 自然语言处理与文本分析

目录 自然语言处理概要 分词与词性标注 N-Gram 分词 分词及词性标注的难点 法则式分词法 全切分 FMM和BMM Bi-direction MM 优缺点 统计式分词法 N-Gram概率模型 HMM概率模型 词性标注(Part-of-Speech Tagging) HMM 文本挖掘概要 信息检索(Information Retrieval) 全文扫描 关键词

PHP7扩展开发之数组处理

前言 这次,我们将演示如何在PHP扩展中如何对数组进行处理。要实现的PHP代码如下: <?phpfunction array_concat ($arr, $prefix) {foreach($arr as $key => $val) {if (isset($prefix[$key]) && is_string($val) && is_string($prefix[$key])) {$arr[