module.exports = Behavior({ data: { currentId: '', }, properties: {}, pageLifetimes: { hide() { this.resetAudio() }, }, methods: { // 开始播放 playVideo({ currentTarget }) { this.setData({ currentId: currentTarget.dataset.id }) }, // 播放音频 playAudio({ currentTarget }) { if (this.data.currentId == currentTarget.dataset.id) { return this.innerAudioContext.stop(); } if (this.innerAudioContext) { this.innerAudioContext.stop(); } else { this.innerAudioContext = wx.createInnerAudioContext() this.innerAudioContext.onEnded(res => { this.setData({ currentId: '' }) }) this.innerAudioContext.onStop((res) => { this.setData({ currentId: '' }) }); } this.innerAudioContext.src = currentTarget.dataset.audio this.innerAudioContext.play(); this.setData({ currentId: currentTarget.dataset.id }) }, // 重置音频 resetAudio() { if (this.innerAudioContext) { this.innerAudioContext.stop(); } this.setData({ currentId: '' }) }, // 打开评论 openComment({ target }) { this.selectComponent('#comment').open(target.dataset.id) }, // 分享 creatShare(video) { console.log(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) } } } } } }) }) }, } })