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

如何做网站网页网络营销的方式与手段

如何做网站网页,网络营销的方式与手段,西安网站设计哪家好,wdcp 修改默认网站本文将介绍如何在鸿蒙应用中使用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/363257.html

相关文章:

  • 上海做网站要多少钱网站服务器ip地址查询
  • 网站开发公司售后服务百度开放云平台
  • 贵阳微网站建设公司哪家好怎么买到精准客户的电话
  • 河南高端网站高端网站建设营销方法有哪些
  • 成都网站服务2021年关键词排名
  • 作一手房用什么做网站谷歌seo推广服务
  • 网站建设dns解析设置百度品牌广告多少钱一个月
  • 网站建设论文范文网络舆情软件免费入口
  • 取消网站的通知书推广普通话
  • 广州网站建设信科公司同城推广平台有哪些
  • 青浦集团网站建设免费大数据网站
  • 自适应手机网站 css爱站网ip反域名查询
  • 网站建设报价模板今日头条新闻推荐
  • 做执法设备有哪些网站视频号视频怎么看下载链接
  • 武汉建设网站官网百度网页版
  • 网站的视频seo站长工具推广平台
  • 淄博网站制作设计上海小红书seo
  • 网站动图是怎么做的石嘴山网站seo
  • 宁波公司做企业网站赣州seo
  • 阿里云部署一个自己做的网站seo网络推广课程
  • 做房产网站需要了解什么东西关键词排名优化软件策略
  • 上海科技网站建设 今日头条
  • 做我男朋友好不好网站最佳搜索引擎磁力王
  • php动态网站开发习题答案app如何推广以及推广渠道
  • html+css网页设计作业seo深圳培训班
  • 做网站卖狗挣钱吗东莞seo排名优化
  • 北海网站建设大数据培训机构排名前十
  • wordpress 获取用户角色广州网站营销优化qq
  • 长宁做网站价格b站网站推广mmm
  • 我做淘宝网站卖东西怎么激活识别关键词软件