• <ul id="cgeq2"></ul>
  • 歡迎您光臨深圳塔燈網(wǎng)絡(luò)科技有限公司!
    電話圖標 余先生:13699882642

    網(wǎng)站百科

    為您解碼網(wǎng)站建設(shè)的點點滴滴

    uniapp 用戶拒絕授權(quán)再次調(diào)起授權(quán)-語音識別、微信地址、微信附近地址

    發(fā)表日期:2019-11 文章編輯:小燈 瀏覽次數(shù):5103

    小程序重構(gòu),采用 uniapp 框架。記錄一下踩過的坑。關(guān)于用戶拒絕再次調(diào)起授權(quán),及如何識別語音識別、微信地址、附近地址的處理。

    語音識別 組件

    • 語音識別,小程序只有錄音功能,若要識別錄音文件,常規(guī)做法是把錄音文件傳遞給后端,然后由后端調(diào)用百度或訊飛語音識別接口,然后返回結(jié)果。
    • 但是微信小程序官方提供了“同聲傳譯”插件,支持前端直接識別??蓞⒖迹?a target="_blank">插件介紹、插件使用文檔
    • uniapp 插件配置,在 manifest.json 文件中,源碼模式,加入:
    ...
    "mp-weixin": {
        ...
        "plugins" : {
            // 語音識別 - 同聲傳譯
            "WechatSI" : {  
                "version" : "0.3.1",  
                "provider" : "wx069ba97219f66d99"  
            }  
        }
    }
    • 調(diào)用
    <template>
        <view @click="asrStart">語音識別</view>
        
        <view>{{arsRes}}</view>
        
        <!-- 語音識別 -->
        <wechat-asr ref="weixinAsr" @callback="asrResult"/>
    </template>
    
    <script>
    import WechatAsr from '@/components/wechatASR.vue';
    
    export default {
        components: {WechatAsr},
        data () {
            return {
                arsRes: ''
            }
        },
        methods: {
          // 語音識別
          asrStart () {
            this.$refs.weixinAsr.show();
          },
          asrResult (res) {
            this.arsRes = res;
          }
        }
    }
    </script>
    
    • 編寫組件,其中關(guān)于授權(quán),用戶若拒絕了,再次點擊,本來是會一直進入失敗的回調(diào)中,導(dǎo)致沒法再次打開授權(quán)界面。所以先獲取授權(quán)信息,針對沒有授權(quán)、授權(quán)拒絕、授權(quán)成功,分別再次處理。若授權(quán)拒絕,需要打開授權(quán)設(shè)置界面,讓用戶再次授權(quán)處理。
    <template>
      <!-- 微信語音識別 -->
      <view class="mask" v-show="isShow">
        <view class="weixin-asr">
          <view class="title">語音識別</view>
          <!-- 動畫 -->
          <view class="spinner">
            <view class="rect rect1"></view>
            <view class="rect rect2"></view>
            <view class="rect rect3"></view>
            <view class="rect rect4"></view>
            <view class="rect rect5"></view>
          </view>
          <view class="tip">說出姓名、電話和詳細地址</view>
          <button class="btn" type="default" @click="recordStop">說完了</button>
        </view>
      </view>
    </template>
    
    <script>
      const WechatSI = requirePlugin("WechatSI");
      const ASRManager = WechatSI.getRecordRecognitionManager();
      
      export default {
        data () {
          return {
            isShow: false
          }
        },
        onReady () {
          // 錄音開啟成功回調(diào)
          ASRManager.onStart = function (res) {
            _this.isShow = true;
          }
          
          const _this = this;
          // 識別錯誤事件  
          ASRManager.onError = (res) => {
            _this.isShow = false;
            console.log(res.msg);
          }
          
          // 錄音停止回調(diào)
          ASRManager.onStop = function (res) {        
            if (res && res.result) {
              _this.$emit('callback', res.result);
            } else {
              uni.showToast({
                icon: 'none',
                title: '抱歉,沒聽到您的聲音哦'
              })
            }
          }
        },
        methods: {
          data () {
            return {
              isShow: false,
            }
          },
          show () {
            const _this = this;
            // 獲取是否授權(quán)信息
            uni.getSetting({
              success(res) {
                if (res && res.authSetting && res.authSetting.hasOwnProperty('scope.record')) {
                  if (res.authSetting['scope.record']) {
                    start();
                  } else { // 拒絕授權(quán),打開授權(quán)設(shè)置
                    uni.openSetting({
                      success() {
                        start();
                      }
                    })
                  }
                } else {
                  start();
                }
              }
            })
            
            function start () {
              ASRManager.start({
                lang: "zh_CN"
              });
            }
          },
          // 錄音停止
          recordStop () {
            this.isShow = false;
            ASRManager.stop();
          }
        }
      }
    </script>
    
    <style lang="scss" scoped>
      .mask {
        position: fixed;
        top: 0;
        left: 0;
        z-index: 300;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, .54);
      }
      .weixin-asr {
        position: absolute;
        top: calc(50% - #{477upx / 2});
        left: 0;
        right: 0;
        margin: 0 auto;
        width: 560upx;
        height: 477upx;
        background: #fff;
        text-align: center;
        transform: .5s ease-out .5s;
        .title {
          margin-top: 42upx;
          color: #000;
          font-size: 34upx;
          font-weight: 500;
        }
        .spinner {
          margin: 50upx;
          height: 100upx;
        }
        .tip {
          color: #787878;
        }
        .btn {
          margin-top: 28upx;
          width: 225upx;
          height: 82upx;
          background: $theme1;
          color: #fff;
          font-size: 34upx;
          line-height: 82upx;
          border-radius: 82upx;
        }
      }
      
      .spinner {
        text-align: center;
      }
       
      .spinner > .rect {
        background-color: #EDAA35;
        height: 100%;
        border-radius: 13upx;
        width: 13upx;
        display: inline-block;
         
        -webkit-animation: stretchdelay 1.2s infinite ease-in-out;
        animation: stretchdelay 1.2s infinite ease-in-out;
        
        & + .rect {
          margin-left: 15upx;
        }
      }
       
      .spinner .rect2 {
        -webkit-animation-delay: -1.1s;
        animation-delay: -1.1s;
      }
       
      .spinner .rect3 {
        -webkit-animation-delay: -1.0s;
        animation-delay: -1.0s;
      }
       
      .spinner .rect4 {
        -webkit-animation-delay: -0.9s;
        animation-delay: -0.9s;
      }
       
      .spinner .rect5 {
        -webkit-animation-delay: -0.8s;
        animation-delay: -0.8s;
      }
       
      @-webkit-keyframes stretchdelay {
        0%, 40%, 100% { -webkit-transform: scaleY(0.4) } 
        20% { -webkit-transform: scaleY(1.0) }
      }
       
      @keyframes stretchdelay {
        0%, 40%, 100% {
          transform: scaleY(0.4);
          -webkit-transform: scaleY(0.4);
        }  20% {
          transform: scaleY(1.0);
          -webkit-transform: scaleY(1.0);
        }
      }
    </style>

    微信地址、附近地址

    它們的處理,和上面邏輯一樣,只是調(diào)用的 api 不一樣。

    邏輯也是先獲取授權(quán)信息,未授權(quán)、用戶拒絕授權(quán)、授權(quán)成功,在用戶拒絕授權(quán)時,打開授權(quán)設(shè)置頁面,沒授權(quán)由小程序主動調(diào)起授權(quán)彈窗。

    主要處理邏輯如下:

    • 微信地址
    chooseAddress (type) {
        const _this = this;
        if (type === 'weixin') {
          // 處理拒絕再次打開調(diào)用設(shè)置
          uni.getSetting({
            success (res) {
              if (res && res.authSetting && res.authSetting.hasOwnProperty('scope.address')) {
                if (res.authSetting['scope.address']) {
                  choose();
                } else {
                  uni.openSetting({
                    success () {
                      choose();
                    }
                  })
                }
              } else {
                choose();
              }
            }
          });
    
          function choose () {
            uni.chooseAddress({
              success(res) {
                if (res) {
                   // 調(diào)用接口將省市區(qū)轉(zhuǎn)換成項目需要的,帶id的,然后進行后續(xù)處理
                }
              }
            })
          }
        }
    }
    • 附近地址
    nearAddress () {
        const _this = this;
        // 處理拒絕再次打開調(diào)用設(shè)置
        uni.getSetting({
          success (res) {
            if (res && res.authSetting && res.authSetting.hasOwnProperty('scope.userLocation')) {
              if (res.authSetting['scope.userLocation']) {
                chooseLocation();
              } else {
                uni.openSetting({
                  success () {
                    chooseLocation();
                  }
                })
              }
            } else {
              chooseLocation();
            }
          }
        })
        
        function chooseLocation () {
          uni.chooseLocation({
            success: function (res) {
              if (res) {
                // 調(diào)用接口將省市區(qū)轉(zhuǎn)換成項目需要的,帶id的,然后進行后續(xù)處理
              }
            }
          });
        }
    }

    本頁內(nèi)容由塔燈網(wǎng)絡(luò)科技有限公司通過網(wǎng)絡(luò)收集編輯所得,所有資料僅供用戶學習參考,本站不擁有所有權(quán),如您認為本網(wǎng)頁中由涉嫌抄襲的內(nèi)容,請及時與我們聯(lián)系,并提供相關(guān)證據(jù),工作人員會在5工作日內(nèi)聯(lián)系您,一經(jīng)查實,本站立刻刪除侵權(quán)內(nèi)容。本文鏈接:http://www.juherenli.com/25233.html
    相關(guān)小程序
     八年  行業(yè)經(jīng)驗

    多一份參考,總有益處

    聯(lián)系深圳網(wǎng)站公司塔燈網(wǎng)絡(luò),免費獲得網(wǎng)站建設(shè)方案及報價

    咨詢相關(guān)問題或預(yù)約面談,可以通過以下方式與我們聯(lián)系

    業(yè)務(wù)熱線:余經(jīng)理:13699882642

    Copyright ? 2013-2018 Tadeng NetWork Technology Co., LTD. All Rights Reserved.    

    国产精品原创巨作av女教师| 无码精品一区二区三区| 亚洲精品国自产拍在线观看| 国产精品美女久久久久av超清| 久久精品国产亚洲7777| 老色鬼永久精品网站| 亚洲精品在线网站| 一本精品99久久精品77| 亚洲精品自偷自拍无码| 国内精品伊人久久久久av一坑 | 国产精品理论片在线观看| 亚洲国产精品一区| 国产精品盗摄一区二区在线| 99久久精品日本一区二区免费| 无码精品人妻一区二区三区中| 99免费精品视频| 精品一区二区无码AV| 国产成人一区二区动漫精品| 国产精品夜夜春夜夜爽久久小 | 国产精品自在拍一区二区不卡| 国产精品嫩草影院线路| 国产久热精品无码激情| 亚洲精品免费网站| 久久亚洲国产精品一区二区| 成人国内精品久久久久一区 | 日本久久久精品中文字幕| 久久这里只有精品视频99| heyzo加勒比高清国产精品| 国产精品一区二区香蕉| 国产精品乱子乱XXXX| 国产精品嫩草影院在线播放| 国产精品天干天干| 国产精品爽爽V在线观看无码| 日韩国产成人资源精品视频| 91精品国产一区| 91精品国产综合久久香蕉| 亚洲精品日韩专区silk | 精品中文字幕久久久久久| 国内精品videofree720| 国产精品第二页在线播放| 国产精品天天在线|