wxml代码:
- <!-- 录音 -->
- <view>
- <!-- 预览 -->
- <view wx:if="{{voice}}">
- <view class='yy_box'>
- <view class='yy_box_bg' bindtap='play'>
- <view class="yy_box_icon {{onPlay?'audio-animation':''}}"></view>
- </view>
- <text>{{playDuration}}"</text>
- </view>
- </view>
- <!-- 录音按钮 -->
- <view class='recorder'>
- <button bindtouchstart='recorderS' bindtouchend='recorderE'>按住说话</button>
- </view>
- </view>
- </view>
wxss代码:
- .yy_box {
- display: flex;
- align-items: center;
- }
- .yy_box_bg {
- width: 130px;
- height: 30px;
- background-color: #9eea6a;
- margin: 0 10px;
- border-radius: 5px;
- }
- .yy_box_bg::before {
- content: '';
- display: block;
- width: 0;
- height: 0;
- border-top: 5px solid transparent;
- border-right: 10px solid #9eea6a;
- border-bottom: 5px solid transparent;
- position: relative;
- left: -10px;
- top: 10px;
- }
- .yy_box_icon {
- width: 11.5px;
- height: 14.5px;
- background: url() no-repeat;
- background-size: 11.5px 43.5px;
- background-position: 0 -29px; /* 默认第三张 */
- position: relative;
- left: 15px;
- top: -2px;
- }
- .audio-animation {
- animation: voiceplay 2s infinite step-start;
- }
- @keyframes voiceplay{
- 0%, 100%{
- background-position: 0 -29px;
- }
- 33.333%{
- background-position: 0 0;
- }
- 66.666%{
- background-position: 0 -14.5px;
- }
- }
- .yy_box text {
- color: #999;
- }
js代码:
- data: {
- recorderTempFilePath:'', // 录音地址
- playDuration: '', // 播放时间
- onPlay:false, // 播放状态样式判断
- voice: false, // 预览语音显示
- },
- // 按住录音
- recorderS:function(){
- const options = {
- duration: 600000,
- sampleRate: 44100,
- numberOfChannels: 1,
- encodeBitRate: 192000,
- format: 'mp3',
- frameSize: 50
- }
- // 开始录音
- recorderManager.start(options);
- recorderManager.onStart(() => {
- // console.log('recorder start')
- wx.showLoading({
- title: '录音中...',
- })
- })
- //错误回调
- recorderManager.onError((res) => {
- console.log(res);
- wx.hideLoading();
- wx.showToast({
- title: res,
- icon: 'success',
- duration: 1000
- })
- })
- },
- // 录音结束
- recorderE:function(){
- let that = this;
- // 结束录音
- recorderManager.stop();
- recorderManager.onStop((res) => {
- wx.hideLoading();
- wx.showToast({
- title: '录音结束',
- icon: 'success',
- duration: 1000
- })
- // console.log('recorder stop', res)
- const { tempFilePath, duration } = res
- let recorderTempFilePath = tempFilePath;
- let playDuration = Math.ceil(duration / 1000);
- that.setData({
- recorderTempFilePath: recorderTempFilePath,
- playDuration: playDuration,
- voice: true
- })
- })
- },
- // 播放录音
- play:function(){
- let that = this;
- let recorderTempFilePath = that.data.recorderTempFilePath;
- innerAudioContext.autoplay = true
- innerAudioContext.src = recorderTempFilePath
- innerAudioContext.onPlay(() => {
- // console.log('开始播放')
- that.setData({
- onPlay:true
- })
- })
- innerAudioContext.onError((res) => {
- // console.log(res.errMsg)
- // console.log(res.errCode)
- wx.showToast({
- title: res.errMsg,
- icon: 'success',
- duration: 2000
- })
- })
- // 播放结束
- innerAudioContext.onEnded((res)=>{
- that.setData({
- onPlay: false
- })
- })
- },