// pages/peoblem_report/peoblem_report.js const app = getApp(); const { formatNumber } = require('../../utils/util.js') Page({ /** * 页面的初始数据 */ data: { baseImgUrl: app.globalData.baseImgUrl, thumbnail: app.globalData.thumbnail, voiceKeyIndex:-1, imgNum:3, isPlay:0, times:0, isMusic:0, isEnd:0, voiceKeyList:[] }, /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { // console.log(options) this.setData(options); this.getPuzzleReport(); }, /** * 生命周期函数--监听页面初次渲染完成 */ onReady: function () { }, /** * 生命周期函数--监听页面显示 */ onShow: function () { }, /** * 生命周期函数--监听页面隐藏 */ onHide: function () { let pages = getCurrentPages(); const {isMusic,voiceKeyList, voiceKeyIndex}=this.data console.log( '生命周期函数--监听页面隐藏'+isMusic) // this.setData({isEnd:1}) // this.innerAudioContext.destroy(); if(isMusic){ this.stopPlay() // this.innerAudioContext.onStop(() => { this.innerAudioContext.stop(); clearInterval(this.setIntervalAudio) this.pauseAudio(voiceKeyList, voiceKeyIndex) // }) } }, /** * 生命周期函数--监听页面卸载 */ onUnload: function () { const {isMusic,voiceKeyList, voiceKeyIndex}=this.data console.log( '生命周期函数--监听页面卸载'+isMusic) // this.setData({isEnd:1}) // this.innerAudioContext.destroy(); if(isMusic){ this.stopPlay() // this.innerAudioContext.onStop(() => { this.innerAudioContext.stop(); clearInterval(this.setIntervalAudio) this.pauseAudio(voiceKeyList, voiceKeyIndex) // }) } }, /** * 页面相关事件处理函数--监听用户下拉动作 */ onPullDownRefresh: function () { }, /** * 页面上拉触底事件的处理函数 */ onReachBottom: function () { }, /** * 用户点击右上角分享 */ onShareAppMessage: function () { const { problemId } = this.data var url=''; if (problemId) { url = `pages/problem_report/problem_report?type=9&problemId=${problemId}` return { title: `难题详情报告`, path: url, success: res => { wx.showToast({ title: '转发成功', icon: 'success' }) }, fail: res => { wx.showToast({ title: '转发失败', icon: 'none' }) } } } else { if (app.sharePageDefaultCtl) { return app.sharePageDefaultCtl() } } }, //查看图片 viewImageCtl: app.viewImageCtl, // 获取难题详情 getPuzzleReport:function(){ const postData = { fn: this.getPuzzleReport, param: { ...arguments } } const { problemPictureId, nodes, answerNodes } = this.data; wx.showLoading({ title: '加载中', }) const fn = res => { wx.hideLoading() const { derverFileKey, problemFeedbackVideoPath, problemPictureId, problemPicturePath, recommendedQuestions, similarQuestions, teacherMessage,fileKeys,voiceKeyList} = res.data; const voiceListTemp = (res => { for (let i in res) { res[i].voiceType = 0 res[i].durationNum = 0; res[i].progress = 0; res[i].isHands = false; // res[i].audioTotal = formatNumber(Math.floor(voiceList[i].duration / 60)) + ':' + formatNumber(Math.floor(voiceList[i].duration % 60)); } return res })(voiceKeyList) const correctListTemp = (res => { for (let i in res) { if (res[i].question.indexOf("img") != -1){ res[i].question = res[i].question.replace(/\ { for (let i in res) { if (res[i].analysis.indexOf("img") != -1) { res[i].analysis = res[i].analysis.replace(/\2) { that.endSetInter(); if(setTime==3&&!isEnd){ setTimeout( function () { that.startSetInter() }, 1000) } } }, /** * 结束计时 */ endSetInter:function(){ var that = this; clearTimeout(that.data.setInter) that.setData({ times: 0}) }, /** * 结束计时 */ stopPlay:function(){ var that = this; that.endSetInter(); that.setData({ imgNum:3}) console.log('结束') }, /** * 音频控制按钮 */ audioCtl: function (e) { const { index } = e.currentTarget.dataset const { voiceKeyList, voiceKeyIndex} = this.data const { voiceType } = voiceKeyList[index]; this.setData({isMusic:1}) var that=this // console.log(index,voiceKeyIndex,voiceType) if (index == voiceKeyIndex) { if (voiceType == 1) { console.log('1---停止') that.stopPlay() if (this.innerAudioContext) this.innerAudioContext.stop() } else if (voiceType == 2) { console.log('1---播放') if (this.innerAudioContext) this.innerAudioContext.play() } else { this.audioManager() } } else { const temp = {} temp['voiceKeyIndex'] = index this.setData(temp) this.audioManager() } }, /** * 开始播放语音 */ playAudio: function (voiceKeyList, voiceKeyIndex) { const { voiceKey, voiceType, durationNum, duration, progress } = voiceKeyList[voiceKeyIndex]; console.log('开始播放语音') this.startSetInter() const temp = {} temp[`voiceKeyList[${voiceKeyIndex}].voiceType`] = 1; temp[`voiceKeyList[${voiceKeyIndex}].isHands`] = true; this.setData(temp) let d = voiceType == 2 ? durationNum - 1 : duration if (this.setIntervalAudio) { clearInterval(this.setIntervalAudio) } // console.log(d) this.setIntervalAudio = setInterval(() => { if (d > 0) { d-- temp[`voiceKeyList[${voiceKeyIndex}].durationNum`] = d temp[`voiceKeyList[${voiceKeyIndex}].progress`] = Math.floor((duration - d) / duration * 100) this.setData(temp) } else { clearInterval(this.setIntervalAudio) } }, 1000) }, /** * 暂停播放语音 */ pauseAudio: function (voiceKeyList, voiceKeyIndex) { console.log('2---停止') const {isEnd}=this.data this.setData({isEnd:!isEnd}) const temp = {} temp[`voiceKeyList[${voiceKeyIndex}].voiceType`] = 2 this.setData(temp) }, /** * 结束播放语音 */ endAudio: function (voiceKeyList, voiceKeyIndex, listIndex) { console.log('3---停止') const {isEnd}=this.data this.setData({isEnd:!isEnd}) const { voiceKey, voiceType, durationNum, duration, progress } = voiceKeyList[voiceKeyIndex] this.stopPlay() const temp = {} temp[`voiceKeyList[${voiceKeyIndex}].voiceType`] = 0 temp[`voiceKeyList[${voiceKeyIndex}].duration`] = duration temp[`voiceKeyList[${voiceKeyIndex}].progress`] = 0 temp[`voiceKeyList[${voiceKeyIndex}].isHands`] = false; this.setData(temp) }, /** * 语音播放管理器 */ audioManager: function () { const { voiceKeyList, voiceKeyIndex, baseImgUrl } = this.data if (this.innerAudioContext) { this.innerAudioContext.destroy() clearInterval(this.setIntervalAudio) for (const i in voiceKeyList) { const temp = {}; temp[`voiceKeyList[${i}].voiceType`] = 0; this.setData(temp) } } const { voiceKey } = voiceKeyList[voiceKeyIndex] if (!voiceKey) return this.innerAudioContext = wx.createInnerAudioContext() this.innerAudioContext.autoplay = true this.innerAudioContext.src = baseImgUrl+voiceKey console.log(baseImgUrl + voiceKey) this.innerAudioContext.onPlay(() => { this.playAudio(voiceKeyList, voiceKeyIndex) }) this.innerAudioContext.onStop(() => { clearInterval(this.setIntervalAudio) this.pauseAudio(voiceKeyList, voiceKeyIndex) }) this.innerAudioContext.onEnded(() => { this.innerAudioContext.destroy() clearInterval(this.setIntervalAudio) this.endAudio(voiceKeyList, voiceKeyIndex) }) this.innerAudioContext.onError(res => { console.log(res) wx.showToast({ title: '播放语音失败', icon: 'none' }) }) }, /** * 结束语音 */ nextAudio: function () { const { voiceKeyList, voiceKeyIndex} = this.data; this.stopPlay() if (voiceKeyIndex != -1 && listIndex != -1) { const { voiceKey, voiceType, durationNum, duration, progress } = voiceKeyList[voiceKeyIndex] const temp = {} temp[`voiceKeyList[${voiceKeyIndex}].voiceType`] = 0 temp[`voiceKeyList[${voiceKeyIndex}].duration`] = duration temp[`voiceKeyList[${voiceKeyIndex}].progress`] = 0 if (this.innerAudioContext) this.innerAudioContext.pause() this.setData(temp) } }, })