千家信息网

小程序聊天室功能怎么实现

发表于:2025-01-16 作者:千家信息网编辑
千家信息网最后更新 2025年01月16日,这篇"小程序聊天室功能怎么实现"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇"小程序聊
千家信息网最后更新 2025年01月16日小程序聊天室功能怎么实现

这篇"小程序聊天室功能怎么实现"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇"小程序聊天室功能怎么实现"文章吧。

首先在头部定义 ...


1.index.js 使用的是微信自带的api,首先在头部定义一个

const recorderManager = wx.getRecorderManager()//获取全局唯一的录音管理器const createInnerAudioContext = wx.createInnerAudioContext()//由于使用的是wx.getRecorderManager录音,所以在播放录音的时候需要使用此api播放录音
  // 需要用户同意授权录音 方法  _checkRecordAuth(cbOk, cbError) {    wx.getSetting({      success: (res) => {        if (!res.authSetting['scope.record']) {          wx.authorize({            scope: 'scope.record',            success: (res) => {              // 用户已经同意小程序使用录音功能,后续调用 wx.startRecord 接口不会弹窗询问              console.log('同意', res);            }, fail: res => {              console.log('拒绝', res);              cbError && cbError();            }          })        } else {          cbOk && cbOk();        }      }    })  },  // 长按  _longClickVoicebtn(e) {    var that = this;      that._checkRecordAuth(        () => {        //调出取消弹窗        that.setData({          text: '松开 发送',          isShowVoice1: true,          singleVoiceTimeCount: 0,          duration: "00:00",          is_clock: true,//长按时应设置为true,为可发送状态          startPoint: e.touches[0],//记录触摸点的坐标信息        });        //开始录音        recorderManager.start(options);        recorderManager.onStart(()=>{          let date = new Date();          let s = date.getTime();//注意:使用的是当前的时间戳 - 时长          console.log(s);          //记录时长          that.data.timer = setInterval(() => {            let voiceTimeCount = (new Date()).getTime() - s            voiceTimeCount = voiceTimeCount/1000            that.setData({              duration: formatSecond(voiceTimeCount),              singleVoiceTimeCount: voiceTimeCount            })          }, 100);        })             },       (res) => {        //录音失败        console.error('录音拒绝授权');        clearInterval(this.data.timer);        this._endRecord();        wx.showModal({          title: '您未授权语音功能',          content: '暂时不能使用语音',          confirmText: '去设置',          success: res => {            if (res.confirm) {              wx.openSetting({                success: res => {                  if (res.authSetting['scope.record']) {                  }                }              });            } else {            }          }        });      });  },// 移动 如果移动到tabar上面了,就显示 松开手指,取消发送  _sendVoiceMoveEvent(e) {      //计算距离,当滑动的垂直距离大于 tabBarHeight 时,则取消发送语音      if (Math.abs(e.touches[0].clientY - this.data.startPoint.clientY) > this.data.tabBarHeight) {        this.setData({          is_clock: false,//设置为不发送语音          isShowVoice2: true,          isShowVoice1: false,          cance: 1,  //已取消        })      } else {        this.setData({          is_clock: true,//设置为不发送语音          isShowVoice2: false,          isShowVoice1: true,          cance: 0,  //不取消        });    }  },  // 松开div 录音结束  _sendVoiceMoveEndEvent(e) {    console.log('松开div 录音结束')    var that = this    clearInterval(this.data.timer);      that.setData({        text: '按住 说话',        isShowVoice1: false,        isShowVoice2: false,        singleVoiceTimeCount: 0,        duration: "00:00"      });      recorderManager.stop()//结束录音      //对停止录音进行监控      recorderManager.onStop((res) => {                //此时先判断是否需要发送录音        if (that.data.is_clock == true) {          console.log('发送语音')          //对录音时长进行判断,少于2s的不进行发送,并做出提示          if (res.duration < 1000) {            that.showToast("录音时间太短,请长按录音");          } else {            //进行语音发送            const { tempFilePath, duration, fileSize } = res;            wx.showLoading({              title: '上传中...',              mask: true            })            uploadFile(tempFilePath).then(res => {              console.log(res);              this._sendMessage({                commentContent: res,                orgId: that.data.orgId,                resId: that.data.childId,                commentContentType: "audio",                fileSize: fileSize,                fileTime: parseInt(duration/1000)              })            })          }        }      })  },

2.wxml中,给view添加上

3、index.js 播放录音


createInnerAudioContext.autoplay = truecreateInnerAudioContext.src = src //src就是传的播放地址

以上就是关于"小程序聊天室功能怎么实现"这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注行业资讯频道。

语音 功能 内容 程序 聊天室 时长 头部 就是 文章 用户 知识 篇文章 移动 价值 信息 全局 地址 坐标 大部分 手指 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 如何远程连接云服务器 上海邦华网络技术有限公司 网络安全的字儿 戴尔服务器生产日期查询 酒店管理系统软件本地服务器 广东企业云空间解决方案云服务器 ctf网络安全大赛电视剧 兰州软件开发解决方案公司 北京软件开发培训收费标准 西安网络安全人才招聘 浙江大学考研网络安全专业分数线 软件开发思路模板 新乡市微粒互联网科技有限公司 php 数据库读写锁 为什么要用服务器跑深度学习代码 网络安全工程师青春饭 海口复兴城软件开发 贵阳市软件开发培训中心 微信发消息会不会经过服务器 年龄类型在数据库中的设置 网络安全专业知识试题 地铁网络安全时间 公安加密网络安全十不 超凡先锋卡在连接服务器 计算机网络技术实习体会 网络安全的问题 数据库出问题怎么修复数据库 删除表里某一条数据库 网络安全人才宣传 太和的网络服务器在哪里
0