let innerAudioContext import { setDuration } from '~/utils/util' module.exports = Behavior({ data: { currentId: '', sliderValue: 0, currentTime: '00:00' }, properties: {}, pageLifetimes: { hide() { this.resetAudio() }, }, lifetimes: { attached() { this.innerAudioContext = wx.createInnerAudioContext() this.innerAudioContext.onTimeUpdate(res => { this.setData({ sliderValue: Math.round(this.innerAudioContext.currentTime / this.innerAudioContext.duration * 100), currentTime: setDuration(this.innerAudioContext.currentTime) }) }) this.innerAudioContext.onError(res => { console.log(res, 'rrrrrrrrrrrr'); }) this.innerAudioContext.onEnded(res => { this.resetAudio() }) } }, methods: { // 开始播放 playVideo({ currentTarget }) { this.setData({ currentId: currentTarget.dataset.id }) }, // 播放音频 playAudio({ currentTarget }) { if (this.data.currentId == currentTarget.dataset.id) { this.resetAudio() if (!currentTarget.dataset.isPkPage) { return } } if (this.innerAudioContext) { this.resetAudio() } this.setData({ currentId: currentTarget.dataset.id, currentTime: '00:00', sliderValue: 0 }) this.innerAudioContext.src = currentTarget.dataset.audio setTimeout(() => { this.innerAudioContext.play(); }, 200) }, // 设置音频播放进度 setSeek({ detail }) { this.innerAudioContext.pause(); this.innerAudioContext.seek(detail) setTimeout(() => { this.innerAudioContext.play() }, 300) }, // 重置音频 resetAudio() { if (this.innerAudioContext) { this.innerAudioContext.stop(); } this.setData({ currentId: '', sliderValue: 0 }) }, // 打开评论 openComment({ target }) { this.selectComponent('#comment').open(target.dataset.uid, target.dataset.id) }, // 打开设置类型的评论组件 openTypeComment({ target }) { this.selectComponent('#comment').open(wx.getStorageSync('uid'), target.dataset.id, target.dataset.type, target.dataset.onceId) }, // 分享 creatShare(video) { return new Promise((resolve, reject) => { let context = wx.createSelectorQuery(); context .select('#share') .fields({ node: true, size: true }).exec((res) => { const canvas = res[0].node; const ctx = canvas.getContext('2d'); const dpr = wx.getSystemInfoSync().pixelRatio; canvas.width = res[0].width * dpr; canvas.height = res[0].height * dpr; ctx.scale(dpr, dpr); ctx.font = '14px PingFang'; let pic = canvas.createImage(); pic.src = video.userRead.coverImg; //可以是本地,也可以是网络图片 pic.onload = () => { ctx.drawImage(pic, 0, 0, 375, 211); } let peiyin = canvas.createImage(); peiyin.src = '/static/peiyin.jpg'; peiyin.onload = () => { ctx.drawImage(peiyin, 0, 211, 375, 89); // 收藏,一个一个渲染 let sc = canvas.createImage(); sc.src = '/static/no_collect.png' sc.onload = () => { ctx.drawImage(sc, 12, 220, 20, 20) ctx.fillText('收藏', 36, 238) //分享 let fx = canvas.createImage(); fx.src = '/static/share.png' fx.onload = () => { ctx.drawImage(fx, 78, 220, 22, 22) ctx.fillText('分享', 104, 238) //点赞 let dz = canvas.createImage(); dz.src = video.isLike ? '/static/heart_colored.png' : '/static/heart.png' dz.onload = () => { ctx.drawImage(dz, 258, 222, 22, 22) ctx.fillText(video.likes, 284, 238) //评论 let pl = canvas.createImage(); pl.src = '/static/comment.png' pl.onload = () => { ctx.drawImage(pl, 318, 222, 22, 22) ctx.fillText(video.commentAmount, 340, 238) setTimeout(() => { wx.canvasToTempFilePath({ canvas: canvas, success(res) { resolve({ title: '我的新作品发布啦,快来捧场点赞!', path: `/pages/index?readId=${video.id}&uid=${wx.getStorageSync('uid')}`, imageUrl: res.tempFilePath }) }, fail(res) { reject() } }, this) }, 500) } } } } } }) }) }, } })