当前位置: 首页 > wzjs >正文

域名解析暂时失败网站整站优化推广方案

域名解析暂时失败,网站整站优化推广方案,专门做离异相亲的网站,网站建设 无锡本文将介绍如何在鸿蒙应用中使用ArkTS实现通话监听和录音功能,利用harmony-utils工具库简化开发流程。 工具库地址 一、功能概述 本实现包含以下核心功能: 通话状态监听:检测来电、去电和通话中状态 音频流监控:通过麦克风使用…

本文将介绍如何在鸿蒙应用中使用ArkTS实现通话监听和录音功能,利用harmony-utils工具库简化开发流程。

工具库地址

一、功能概述

本实现包含以下核心功能:

  1. 通话状态监听:检测来电、去电和通话中状态

  2. 音频流监控:通过麦克风使用情况判断是否在通话

  3. 权限管理:动态申请麦克风和通话记录权限

  4. 状态管理:15秒宽限期后执行锁定操作

二、完整实现代码

import { PermissionUtil, ToastUtil } from "@pura/harmony-utils";
import { audio } from "@kit.AudioKit";
import { call, observer } from "@kit.TelephonyKit";@Entry
@Component
struct CallMonitorPage {private stillTalking: boolean = false; // 是否在通话中aboutToDisappear() {// 释放资源let am = audio.getAudioManager();let audioStreamManager = am.getStreamManager();audioStreamManager.off('audioCapturerChange');observer.off('callStateChange')}// 检测到通话后的处理private hearPhone() {if (this.stillTalking) return;ToastUtil.showToast('检测到通话中,15秒后将锁定页面~');this.stillTalking = true;setTimeout(() => {if (this.stillTalking) {// 这里可以添加锁定页面的逻辑ToastUtil.showToast('页面已锁定,请结束通话后继续');}}, 15000);}// 申请录音监听权限async useAudioStreamManager() {// 1. 检查麦克风权限PermissionUtil.checkRequestPermissions("ohos.permission.MICROPHONE").then((res) => {if (!res) {// 2. 如果没有权限则申请PermissionUtil.requestPermissionOnSetting("ohos.permission.MICROPHONE").then((res) => {if (!res) {ToastUtil.showToast('请给予录音权限~');}this.onHear();});} else {this.onHear();}});// 3. 检查通话记录权限PermissionUtil.checkRequestPermissions("ohos.permission.READ_CALL_LOG").then(() => {// 4. 检查当前是否有通话if (call.getCallStateSync()) {this.hearPhone();}// 5. 监听主卡槽通话状态变化observer.on('callStateChange', { slotId: 0 }, (data) => {this.handleCallStateChange(data);});// 6. 监听副卡槽通话状态变化observer.on('callStateChange', { slotId: 1 }, (data) => {this.handleCallStateChange(data);});});}// 处理通话状态变化private handleCallStateChange(data) {// 来电状态if (data.state === 0) {this.stillTalking = false;return;}// 通话中状态(包括保持状态)if ([3].includes(data.state)) {this.hearPhone();}}// 监听音频流变化private onHear() {let am = audio.getAudioManager();let audioStreamManager = am.getStreamManager();// 检查当前是否有音频活动if (audioStreamManager.isActiveSync(0)) {this.hearPhone();}// 监听音频捕获变化audioStreamManager.on('audioCapturerChange', () => {setTimeout(() => {if (audioStreamManager.isActiveSync(0)) {// 通话中this.hearPhone();} else {this.stillTalking = false;}}, 500);});}build() {Column() {Button('开始监听通话').onClick(() => {this.useAudioStreamManager();}).margin(20).width('80%')}.width('100%').height('100%')}
}
其中系统来电采用observer.on('callStateChange')监听,而微信来电使用audioStreamManager.on('audioCapturerChange')有没有在录音来监听,理论其他APP也是可以监听到的

三、权限配置

module.json5中添加以下权限声明:

json

{"module": {"requestPermissions": [{"name": "ohos.permission.MICROPHONE","reason": "需要录音权限"}]}
}

四、核心API说明

API说明
call.getCallStateSync()获取当前通话状态
observer.on('callStateChange')监听通话状态变化
audioStreamManager.isActiveSync(0)检测音频流是否活跃
PermissionUtil.checkRequestPermissions()检查并申请权限
PermissionUtil.requestPermissionOnSetting()二次申请权限

五、通话状态值说明

-1无效状态,当获取呼叫状态失败时返回。
0表示没有正在进行的呼叫。
1表示来电正在振铃或等待。
2表示至少有一个呼叫处于拨号、通话中或呼叫保持状态,并且没有新的来电振铃或等待。
3表示来电已经接听。

六、实现原理

  1. 双重检测机制

    • 通过系统通话状态API直接检测

    • 通过音频流变化间接检测

  2. 权限管理

    • 使用harmony-utils简化权限申请流程

    • 优雅处理权限拒绝情况

  3. 状态管理

    • 设置15秒宽限期,避免误判

    • 使用标志位防止重复处理

http://www.dtcms.com/wzjs/117820.html

相关文章:

  • 一个人网站运营怎么做头条今日头条新闻
  • 网站设计制作代码市场营销策划
  • 网站建设公司 北京竞价广告是什么意思
  • 外包公司做网站价格目前最火的自媒体平台
  • 做毕设的网站搜索引擎营销sem
  • 网页设计作业文件夹压缩包专业seo站长工具
  • 网站相关推荐怎么做网址域名注册
  • 创新创业教育课程网站建设方案烟台网站建设
  • wordpress如何修改博客模板优化关键词排名哪家好
  • 做餐饮企业网站的费用seo搜索引擎优化试题及答案
  • php做网站seo三人行网站
  • 网站项目分析怎么做 方法有哪些泉州关键词排名
  • 国内专业的室内设计网站网推和地推的区别
  • 云智网站建设公司外贸网站建设报价
  • 苏州网站建设布局网站优化排名易下拉效率
  • 建设银行官方网站云服务中心怎么做电商创业
  • 宁波网站推广工作室电话网络加速器
  • 网站建设主要产品百度收录网站要多久
  • 广州的企业网站建设网站百度不收录的原因
  • 网站主机租用多少钱上海app网络推广公司电话
  • 做外贸接私单的网站职业技术培训
  • 网站开发形式选择百度小说风云榜排名
  • 国外红人营销网站搜索引擎优化实训心得
  • 基于web的网站开发开题报告谷歌seo网站排名优化
  • 自己建网站有什么用深圳白帽优化
  • 那种软件可以做视频网站代做网页设计平台
  • 公司域名让做网站的公司网络推广方案
  • 个人做网站要注意什么条件百度卖货平台
  • 青岛网站设计百度搜索热词查询
  • 仿制单页面网站多少钱广告推广网站