基于JS开发微信网页录音功能的实例代码


Posted in Javascript onApril 30, 2019

具体代码如下所示:

wx.ready(function () {
    var startRecordflag = false
    var startTime = null

 //btnRecord 为录音按钮dom对象
    btnRecord.addEventListener('touchstart', function (event) {
      event.preventDefault();
      startTime = newDate().getTime();
      // 延时后录音,避免误操作
      recordTimer = setTimeout(function () {
        wx.startRecord({
          success: function () {
            var rainAllowRecord = sessionStorage.getItem("rainAllowRecord");//判断是否授权过允许使用录音功能
            if (!isEmpty(rainAllowRecord) && rainAllowRecord == "1") {
              //开始录音时的操作 如修改录音按钮样式等
            } else {
              //一般第一次时 都没有授权 弹出授权窗口后 无法终止录音过程 所以在这里设置rainAllowRecord 的值表示允许过录音 并且在第一次时主动停止录音
              sessionStorage.setItem("rainAllowRecord", "1");
              wx.stopRecord();
            }
            startRecordflag = true;
          },
          cancel: function () {
            startRecordflag = true;
            alert('用户拒绝授权录音');
          },
          complete: function () {
            startRecordflag = true;
          }
        });
      }, 300);
    });
    btnRecord.addEventListener('touchend', function (event) {
      event.preventDefault();
      // 间隔太短
      var timeDitance = newDate().getTime() - startTime;
      if (timeDitance < 300) {
        startTime = 0;
        // 不录音
        clearTimeout(recordTimer);
      } else {
        // 松手结束录音
        //startRecordflag 因为startRecord是个异步方法 防止没有进入startRecord 的回调就进入了这里
        var startRecordHandle = setInterval(function () {
          //startRecordflag为true 表示已经进入过startRecord的回调
          if (startRecordflag) {
            startRecordflag = false;
            clearInterval(startRecordHandle);
            wx.stopRecord({
              success: function (res) {
                voice.localId = res.localId;
                translateVoice();
              },
              fail: function (res) {
              }
            });
          }
        }, 0);
      }
    });
    wx.onVoiceRecordEnd({
      complete: function (res) {
        voice.localId = res.localId;
        alert('录音时间已超过一分钟');
      }
    });
    function translateVoice() {
      //调用微信的语音转文字接口
      wx.translateVoice({
        localId: voice.localId,
        isShowProgressTips: 0,
        complete: function (res) {
          if (res.hasOwnProperty('translateResult')) {
            alert('识别结果:' + res.translateResult);
          } else {
          }
        }
      });
    }
    function playVoice() {
      wx.playVoice({
        localId: voice.localId
      });
    }
  })

总结

以上所述是小编给大家介绍的基于JS开发微信网页录音功能的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
jQuery示例收集
Nov 05 Javascript
用js+iframe形成页面的一种遮罩效果的具体实现
Dec 31 Javascript
jquery的ajax简单结构示例代码
Feb 17 Javascript
JavaScript实现存储HTML字符串示例
Apr 21 Javascript
用js模拟struts2的多action调用示例
May 19 Javascript
BootStrap Validator 版本差异问题导致的submitHandler失效问题的解决方法
Dec 01 Javascript
[js高手之路]设计模式系列课程-发布者,订阅者重构购物车的实例
Aug 29 Javascript
Vue实现textarea固定输入行数与添加下划线样式的思路详解
Jun 28 Javascript
Angular6笔记之封装http的示例代码
Jul 27 Javascript
vue添加axios,并且指定baseurl的方法
Sep 19 Javascript
解决ant Design中this.props.form.validateFields未执行的问题
Oct 27 Javascript
node.js使用express-fileupload中间件实现文件上传
Jul 16 Javascript
vue前端框架—Mint UI详解(更适用于移动端)
Apr 30 #Javascript
详解Vue+ElementUI从零开始搭建自己的网站(一、环境搭建)
Apr 30 #Javascript
详解微信小程序用定时器实现倒计时效果
Apr 30 #Javascript
TypeScript开发Node.js程序的方法
Apr 30 #Javascript
js时间戳转yyyy-MM-dd HH-mm-ss工具类详解
Apr 30 #Javascript
Javascript读取上传文件内容/类型/字节数
Apr 30 #Javascript
详解微信小程序-扫一扫 wx.scanCode() 扫码大变身
Apr 30 #Javascript
You might like
探讨PHP JSON中文乱码的解决方法详解
2013/06/06 PHP
php正则替换处理HTML页面的方法
2015/06/17 PHP
php设计模式之观察者模式实例详解【星际争霸游戏案例】
2020/03/30 PHP
最新优化收藏到网摘代码(digg,diigo)
2007/02/07 Javascript
Prototype 工具函数 学习
2009/07/23 Javascript
JQuery插件Style定制化方法的分析与比较
2012/05/03 Javascript
编写针对IE的JS代码两种编写方法
2013/01/30 Javascript
js克隆对象、数组的常用方法介绍
2013/09/26 Javascript
JavaScript通过Date-Mask将日期转换成字符串的方法
2015/06/04 Javascript
javascript动画算法实例分析
2015/07/31 Javascript
基于bootstrap3和jquery的分页插件
2015/07/31 Javascript
jQuery的promise与deferred对象在异步回调中的作用
2016/05/03 Javascript
Ztree新增角色和编辑角色回显问题的解决
2016/10/25 Javascript
Bootstrap modal 多弹窗之叠加关闭阴影遮罩问题的解决方法
2017/02/27 Javascript
mui上拉加载更多下拉刷新数据的封装过程
2017/11/03 Javascript
实例详解vue.js浅度监听和深度监听及watch用法
2018/08/16 Javascript
基于vue实现web端超大数据量表格的卡顿解决
2019/04/02 Javascript
javascript实现贪吃蛇小练习
2020/07/05 Javascript
python实现dict版图遍历示例
2014/02/19 Python
Python解决鸡兔同笼问题的方法
2014/12/20 Python
Python聚类算法之DBSACN实例分析
2015/11/20 Python
Python模拟随机游走图形效果示例
2018/02/06 Python
TensorFlow实现非线性支持向量机的实现方法
2018/04/28 Python
python模拟点击网页按钮实现方法
2020/02/25 Python
如何在Windows中安装多个python解释器
2020/06/16 Python
CSS3实现swap交换动画
2016/01/19 HTML / CSS
Top Villas美国:豪华别墅出租和度假屋
2018/07/10 全球购物
机电专业个人求职信范文
2013/12/30 职场文书
协议书模板
2014/04/23 职场文书
纪念九一八事变演讲稿:牢记历史,捍卫主权
2014/09/14 职场文书
力克胡哲观后感
2015/06/10 职场文书
利用Python网络爬虫爬取各大音乐评论的代码
2021/04/13 Python
MySQL分库分表与分区的入门指南
2021/04/22 MySQL
详解python的内存分配机制
2021/05/10 Python
详细介绍python类及类的用法
2021/05/31 Python
Nginx下SSL证书安装部署步骤介绍
2021/12/06 Servers