zoukankan      html  css  js  c++  java
  • 小程序语音识别接口

    .wxml代码

    <view class="voice-button" bindtouchstart="recordStart" bindtouchend="recordEnd">
              <image class="pic-img"  src="/resource/image/voice.png"></image>
              <view class="pic-text">长按说话</view>
    </view>

    .wxss代码

    .voice-button{
    float: right;
    text-align: center;
    }
    .pic-img{
    width: 132rpx;
    height: 132rpx;
    }
    .pic-text{
    font-size: 26rpx;
    }

    .js代码

    .js页面
      /* 语音功能 */
      //这个是监听语音识别的方法,只要写了bindtouchstart和bindtouchend对应的方法就可自动触发,需注意的是,最好写var that = this;因为会发生指向问题,从而触发不到这个方法。
      initRecord: function(){
        let that = this;
        //有新的识别内容返回,则会调用此事件
        // manager.onRecognize = (res) => {
        //   var recText = this.sendRecord(res.tempFilePath);
        //   console.log('语音识别中');
        //   console.log(result);
        //   this.setData({
        //     inputVal: recText
        //   });
        // }
    
        // 识别结束事件
        manager.onStop ((res) => {
          console.log('监听识别结束');
          console.log(res.tempFilePath)
          that.sendRecord(res.tempFilePath);//识别结束执行上传语音事件
        })
    
        // 识别错误事件
        manager.onError ((res) => {
    
          that.setData({
           //这里的参数根据项目要求自行设置
          })
    
        })
      },
      //识别开始
      recordStart: function(){
        let that = this;
        manager.start({
          duration: 30000,//指定录音的时长,单位 ms
          sampleRate: 16000,//采样率
          numberOfChannels: 1,//录音通道数
          encodeBitRate: 96000,//编码码率
          format: 'mp3',//音频格式,有效值 aac/mp3
          frameSize: 50,//指定帧大小,单位 KB
        })
        that.setData({
            //这里的参数根据项目要求自行设置
        });
        console.log('识别开始')
      },
      //识别结束
      recordEnd: function(){
        manager.stop();
        console.log('识别结束')
      },
      //上传语音方法
      sendRecord: function (src) {
        let that = this;
        app.uploadFile({
          url: url,//这里写语音识别的接口
          method: 'POST',
          filePath: src,
          name: 'file',
          formData: {
            file:src
          },
          header:{
            'Content-Type': 'application/x-www-form-urlencoded'
          },
          success: function (result) {
            console.log('识别结果')
            console.log(result)
            //必须解析
            var res = JSON.parse(result.data);
            console.log(res)
            if(res.success){
              var data = res.item;
              let recText ;
              if(data.length>0){
                recText = data.replace(/。/ig, '');
                that.setData({
                   //这里的参数根据项目要求自行设置
                })
              }else{
                that.setData({
                   //这里的参数根据项目要求自行设置
                });
                app.msg('无识别结果')
                return false;
              }
            }else{
              that.setData({
                listening: false
              });
              app.msg(res.message)
              return false;
            }
          },
          fail: function (err) {
            app.msg(res.message)
            return false;
          }
        });
      },
  • 相关阅读:
    iOS- Swift:使用FMDB进行数据库操作(线程安全:增删改查)
    iOS- Swift:如何使用iOS8中的UIAlertController
    iOS- Swift和Object-C的混合编程
    iOS- 再谈ARC里内存问题,ARC里数组、对象内存得不到释放?
    iOS- 如何建立索引实现本地文本搜索引擎,允许容错搜索?
    iOS- 全方位解析.crash文件崩溃报告
    iOS- 关于AVAudioSession的使用——后台播放音乐
    iOS- Autolayout自动布局
    iOS- 详解如何使用ZBarSDK集成扫描二维码/条形码,点我!
    419. Roman to Integer【medium】
  • 原文地址:https://www.cnblogs.com/xiaoqi2018/p/10893978.html
Copyright © 2011-2022 走看看