APP收款语音播报功能讲解

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 比起主动扫码能确定收款多少与是否到账,扫二维码支付场景不能直接确认,需要核对客户付款截屏,目前微信、支付宝在扫二维码支付后,均支持收款方自动播报收款到账信息,为了秦丝APP有更好体验,也需要加入该功能。

一、背景

比起主动扫码能确定收款多少与是否到账,扫二维码支付场景不能直接确认,需要核对客户付款截屏,目前微信、支付宝在扫二维码支付后,均支持收款方自动播报收款到账信息,为了秦丝APP有更好体验,也需要加入该功能。

二、方案

目前实现的收款语音播报功能采用片段组合读音的方案,简单的解释就是根据收款的金额,提取相应数值语音播报,分别包括0-9,十-亿及一些单位或者标注发音等19个语音文件。
比起传统语音合成方案,无需幅度增加app的大小,灵活控制语速。

三、实现

1、触发:在收到收款单号推送后,请求收款金额

2、解析:根据收款金额,解析成一个语音文件对象的数组
以999999.99为例,拆解小数点左右两边部分后分开解析,小数点左边部分又以万为单位拆分,先解析万以内数字,然后再讲万以上的部分又当成万以内的解析加万语音片段,亿、兆类似。小数点后面的部分则从不加单位解析。

// 获取数字转语音文件的队列
function getArrayByNumber(num) {
    num = num + "";
    if (/^(0|[1-9]\d*)(.\d*[1-9])?$/.test(num)) {
        var nums = num.split("."), pointAfter = nums[1], flag = 0;
        num = Number(nums[0]);
        num = dealNum(num);
        num.unshift(unitsOther.get);
        if(pointAfter) {
            nums = pointAfter.split('');
            num.push(unitsOther.point);
            nums.map(function (val) {
                num.push(units[Number(val)]);
            });
            num.push(unitsOther.yuan);
        } else {
            num.push(unitsOther.yuan);
            num.push(unitsOther.it);
        }
        return num;
    } else {
        return [audios.zero];
    }
}

// 获取万以上的解析数组
function dealNum(num) {
    var currNum, level = 0;
    var arr = [],arrTemp, addZero;
    if(num === 0){
        return [units[0]];
    }
    while (num > 0) {
        currNum = num % WAN;
        if (currNum) {
            if (addZero) {
                arr.unshift(units[0]);
            }
            if (level === 2) {
                arr = [unitsUpWan[2]].concat(arr);
            } else if (level) {
                arr = [unitsUpWan[1]].concat(arr);
            }
            arrTemp = dealNumInWan(currNum);
            addZero = arrTemp[0];
            arr = arrTemp[1].concat(arr);
        }
        level++;
        num = Math.floor(num / WAN);
    }
    return arr;
}

// 获取万以内的解析数组
function dealNumInWan(num) {
    var zero, firstIsZero = num / QIAN < 1 && num > 0;
    var arr = [], currNum, unit = 0;
    while (num > 0) {
        currNum = num % SHI;
        if (currNum) {
            zero === undefined && (zero = false);
            if (unit) {
                if (zero) {
                    arr.unshift(units[0]);
                    zero = false;
                }
                arr.unshift(unitsInWan[unit]);
            }
            arr.unshift(units[currNum]);
        } else {
            zero === false && (zero = true);
        }
        unit++;
        num = Math.floor(num / SHI);
    }
    return [firstIsZero, arr];
}

Audio 对象是一个语音文件对象,每个语音对应有个对象,里面有文件的路径与播放时长,时长是自己设置的每个语音对应有个对象,里面有文件的路径与播放时长,时长是自己设置,时间极短的语音如果有了延时就不会连续播放,时间duration这里需要稍微根据实际情况进行调整

// 语音文件路径与语音文件需用时间的钩子
var audios = {
    zero: {
        src: "media/0.wav",
        duration: 800
    },
    one: {
        src: "media/1.wav",
        duration: 800
    },
    two: {
        src: "media/2.wav",
        duration: 800
    },
    three: {
        src: "media/3.wav",
        duration: 800
    }
……
    nine: {
        src: "media/9.wav",
        duration: 800
    },
    point: {
        src: "media/point.wav",
        duration: 800
    },
    ten: {
        src: "media/ten.wav",
        duration: 700
    },
    hd: {
        src: "media/hd.wav",
        duration: 700
    },
    td: {
        src: "media/td.wav",
        duration: 700
    },
    ttd: {
        src: "media/ttd.wav",
        duration: 700
    },
    hm: {
        src: "media/hm.wav",
        duration: 700
    },
    yuan: {
        src: "media/yuan.wav",
        duration: 700
    },
    it: {
        src: "media/it.wav",
        duration: 700
    },
    get: {
        src: "media/get.wav",
        duration: 1800
    }
};

// 数字转换成语音文件的数组方案
var unitsInWan = ["", audios.ten, audios.hd, audios.td];
var unitsUpWan = ["", audios.ttd, audios.hm, audios.ttd];
var units = [audios.zero, audios.one, audios.two, audios.three, audios.four, audios.five, audios.six, audios.seven, audios.eight, audios.nine];
var unitsOther = {
    "point": audios.point,
    "yuan": audios.yuan,
    "it": audios.it,
    "get": audios.get
};

3、播报:递归方式逐个播放片段

function startAAudio(number, index, audiosArr) {
    audiosArr || (audiosArr = getArrayByNumber(number));
    realMedia = new Media(extUrl + audiosArr[index].src);
    setTimeout(function () {
        realMedia.stop();
        realMedia.release();
        index++;
        if (audiosArr[index]) {
            startAAudio(number, index, audiosArr);
        } else {
            realMedia = undefined;
            if(number = audioList.shift()) { // 如果有队列中有新的语音则播放下一则语音
                setTimeout(function () { // 连续收款加点时间间隔
                    startAAudio(number, 0);
                },2000);
            }
        }
    }, audiosArr[index].duration);
    realMedia.play();
}

注意

需要用到媒体播放插件cordova-plugin-media

目录
相关文章
|
13天前
|
安全 定位技术 API
婚恋交友系统匹配功能 婚恋相亲软件实现定位 语音社交app红娘系统集成高德地图SDK
在婚恋交友系统中集成高德地图,可实现用户定位、导航及基于地理位置的匹配推荐等功能。具体步骤如下: 1. **注册账号**:访问高德开放平台,注册并创建应用。 2. **获取API Key**:记录API Key以备开发使用。 3. **集成SDK**:根据开发平台下载并集成高德地图SDK。 4. **配置功能**:实现定位、导航及基于位置的匹配推荐。 5. **注意事项**:保护用户隐私,确保API Key安全,定期更新地图数据,添加错误处理机制。 6. **测试优化**:完成集成后进行全面测试,并根据反馈优化功能。 通过以上步骤,提升用户体验,提供更便捷的服务。
|
17天前
|
PHP
全新uniapp小说漫画APP小说源码/会员阅读/月票功能
价值980的uniapp小说漫画APP小说源码/会员阅读/月票功能
65 20
|
13天前
|
前端开发 数据库 UED
uniapp开发,前后端分离的陪玩系统优势,陪玩app功能特点,线上聊天线下陪玩,只要4800
前后端分离的陪玩系统将前端(用户界面)和后端(服务器逻辑)分开开发,前者负责页面渲染与用户交互,后者处理数据并提供接口。该架构提高开发效率、优化用户体验、增强可扩展性和稳定性,降低维护成本,提升安全性。玩家可发布陪玩需求,陪玩人员发布服务信息,支持在线聊天、预约及线下陪玩功能,满足多样化需求。[演示链接](https://www.51duoke.cn/games/?id=7)
|
15天前
|
移动开发 小程序 前端开发
使用php开发圈子系统特点,如何获取圈子系统源码,社交圈子运营以及圈子系统的功能特点,圈子系统,允许二开,免费源码,APP 小程序 H5
开发一个圈子系统(也称为社交网络或社群系统)可以是一个复杂但非常有趣的项目。以下是一些关键特点和步骤,帮助你理解如何开发、获取源码以及运营一个圈子系统。
88 3
|
15天前
|
小程序 安全 网络安全
清晰易懂!陪玩系统源码搭建的核心功能,陪玩小程序、陪玩app的搭建步骤!
陪玩系统源码包含多种约单方式、实时语音互动、直播间与聊天室、大神申请与抢单、动态互动与社交及在线支付与评价等核心功能。搭建步骤包括环境准备、源码上传与解压、数据库配置、域名与SSL证书绑定、伪静态配置及后台管理。注意事项涵盖源码安全性、二次开发、合规性和技术支持。确保平台安全、合规并提供良好用户体验是关键。
|
2月前
|
监控 安全 开发者
山东布谷科技:关于直播源码|语音源码|一对一直播源码提交App Store的流程及重构经验
分享提交直播源码,一对一直播源码,语音源码到Appstore的重构经验!
|
2月前
|
NoSQL 应用服务中间件 PHP
布谷一对一直播源码服务器环境配置及app功能
一对一直播源码阿里云服务器环境配置及要求
|
2月前
|
小程序 数据挖掘 UED
开发1个上门家政小程序APP系统,都有哪些功能?
在快节奏的现代生活中,家政服务已成为许多家庭的必需品。针对传统家政服务存在的问题,如服务质量不稳定、价格不透明等,我们历时两年开发了一套全新的上门家政系统。该系统通过完善信用体系、提供奖励机制、优化复购体验、多渠道推广和多样化盈利模式,解决了私单、复购、推广和盈利四大痛点,全面提升了服务质量和用户体验,旨在成为家政行业的领导者。
|
2月前
|
机器人
布谷直播App系统源码开发之后台管理功能详解
直播系统开发搭建管理后台功能详解!
|
4月前
|
移动开发 Android开发 数据安全/隐私保护
移动应用与系统的技术演进:从开发到操作系统的全景解析随着智能手机和平板电脑的普及,移动应用(App)已成为人们日常生活中不可或缺的一部分。无论是社交、娱乐、购物还是办公,移动应用都扮演着重要的角色。而支撑这些应用运行的,正是功能强大且复杂的移动操作系统。本文将深入探讨移动应用的开发过程及其背后的操作系统机制,揭示这一领域的技术演进。
本文旨在提供关于移动应用与系统技术的全面概述,涵盖移动应用的开发生命周期、主要移动操作系统的特点以及它们之间的竞争关系。我们将探讨如何高效地开发移动应用,并分析iOS和Android两大主流操作系统的技术优势与局限。同时,本文还将讨论跨平台解决方案的兴起及其对移动开发领域的影响。通过这篇技术性文章,读者将获得对移动应用开发及操作系统深层理解的钥匙。
115 12