index.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. import {
  2. getPkResult
  3. } from '~/api/works'
  4. import {
  5. setDuration
  6. } from '~/utils/util'
  7. import {
  8. userEvent
  9. } from '~/api/global'
  10. import event from '~/mixins/event'
  11. import share from '~/mixins/share'
  12. let innerAudioContext
  13. Page({
  14. behaviors: [share, event],
  15. /**
  16. * 页面的初始数据
  17. */
  18. data: {
  19. pkId: '',
  20. pkRecord: {},
  21. vState: false,
  22. vStart: '00:00',
  23. vEnd: '00:00',
  24. dState: false,
  25. dStart: '00:00',
  26. dEnd: '00:00',
  27. currentType: '',
  28. victory: {},
  29. defeated: {},
  30. equal: false,
  31. // 是否是分享进来的
  32. isPlayback: false
  33. },
  34. /**
  35. * 生命周期函数--监听页面加载
  36. */
  37. async onLoad(options) {
  38. let {
  39. pkRecord,
  40. pkRecordVOS
  41. } = await getPkResult(options.id)
  42. console.log(pkRecordVOS);
  43. this.setData({
  44. pkId: options.id,
  45. pkRecord,
  46. isplayback: options.playback || false
  47. })
  48. this.compareScore(pkRecordVOS)
  49. this.innerAudioContext = wx.createInnerAudioContext()
  50. this.innerAudioContext.onEnded(res => {
  51. let label = this.data.currentType == 'victory' ? 'vStart' : 'dStart'
  52. this.setData({
  53. [label]: '00:00',
  54. vState: false,
  55. dState: false,
  56. })
  57. })
  58. await userEvent({
  59. action: 'WXPKSCORE',
  60. })
  61. },
  62. compareScore(resultData) {
  63. let first = resultData[0]
  64. let second = resultData[1]
  65. let victory = first.userRead.score > second.userRead.score ? first : second
  66. let defeated = second.userRead.score < first.userRead.score ? second : first
  67. this.setData({
  68. equal: first.userReadExtend.businessType != 2 ? first.userRead.score == second.userRead.score : true,
  69. victory,
  70. defeated,
  71. vEnd: setDuration(victory.userRead.duration),
  72. dEnd: setDuration(defeated.userRead.duration),
  73. })
  74. },
  75. playAudio({
  76. currentTarget
  77. }) {
  78. let type = currentTarget.dataset.type
  79. // 重置音频对象
  80. if (type != this.data.currentType) {
  81. this.innerAudioContext.stop();
  82. }
  83. // 处理音频播放
  84. if (type == 'victory' && !this.data.vState) {
  85. if (this.data.currentType != 'victory') {
  86. this.innerAudioContext.src = this.data.victory.userRead.audioPath
  87. }
  88. this.setData({
  89. vState: true,
  90. dState: false
  91. })
  92. } else if (type == 'victory' && this.data.vState) {
  93. this.innerAudioContext.pause();
  94. return this.setData({
  95. vState: false
  96. })
  97. } else if (type == 'defeated' && !this.data.dState) {
  98. if (this.data.currentType != 'defeated') {
  99. this.innerAudioContext.src = this.data.defeated.userRead.audioPath;
  100. }
  101. this.setData({
  102. dState: true,
  103. vState: false
  104. })
  105. } else if (type == 'defeated' && this.data.dState) {
  106. this.innerAudioContext.pause();
  107. return this.setData({
  108. dState: false
  109. })
  110. }
  111. this.setData({
  112. currentType: type
  113. })
  114. // this.innerAudioContext.onCanplay(() => {
  115. this.innerAudioContext.play();
  116. // })
  117. this.innerAudioContext.onTimeUpdate(() => {
  118. let label = this.data.currentType == 'victory' ? 'vStart' : 'dStart'
  119. this.setData({
  120. [label]: setDuration(this.innerAudioContext.currentTime),
  121. })
  122. })
  123. },
  124. result({
  125. currentTarget
  126. }) {
  127. if (currentTarget.dataset.type == 'reading') {
  128. wx.redirectTo({
  129. url: `/pages/reading/index?videoId=${this.data.victory.userRead.exampleId}&readingType=pk`,
  130. })
  131. } else if (currentTarget.dataset.type == 'index') {
  132. wx.switchTab({
  133. url: '/pages/index/index',
  134. })
  135. } else {
  136. wx.redirectTo({
  137. url: `/pages/pkPage/index?videoId=${this.data.pkRecord.challengerUserReadId}&isShare=true`,
  138. })
  139. }
  140. },
  141. /**
  142. * 生命周期函数--监听页面卸载
  143. */
  144. onUnload() {
  145. this.innerAudioContext.destroy()
  146. },
  147. creatShare() {
  148. return new Promise((resolve, reject) => {
  149. let context = wx.createSelectorQuery();
  150. context
  151. .select('#share')
  152. .fields({
  153. node: true,
  154. size: true
  155. }).exec((res) => {
  156. const canvas = res[0].node;
  157. const ctx = canvas.getContext('2d');
  158. const dpr = 0.84;
  159. canvas.width = res[0].width * dpr;
  160. canvas.height = res[0].height * dpr;
  161. ctx.scale(dpr, dpr);
  162. ctx.font = '16px PingFang';
  163. let bgImg = canvas.createImage();
  164. bgImg.src = this.data.equal ? 'https://reader-wx.ai160.com/images/reader/v3/equal.png' : 'https://reader-wx.ai160.com/images/reader/v3/victory.png'
  165. bgImg.onload = () => {
  166. ctx.drawImage(bgImg, 0, 0, 375, 300);
  167. ctx.textAlign = "center";
  168. var lnamex = this.data.equal ? 100 : 100,
  169. lnamey = this.data.equal ? 125 : 115;
  170. var vName = this.data.victory.user.nickName || this.data.victory.user.eid
  171. if (vName.length > 4) {
  172. vName = vName.slice(0, 4) + '...'
  173. }
  174. ctx.fillText(vName, lnamex, lnamey)
  175. var rnamex = this.data.equal ? 280 : 280,
  176. rnamey = this.data.equal ? 125 : 140;
  177. var dName = this.data.defeated.user.nickName || this.data.defeated.user.eid
  178. if (dName.length > 4) {
  179. dName = dName.slice(0, 4) + '...'
  180. }
  181. ctx.fillText(dName, rnamex, rnamey)
  182. ctx.font = '19px PingFang';
  183. if (this.data.victory.userReadExtend.businessType != 2) {
  184. var lnumx = this.data.equal ? 100 : 100,
  185. lnumy = this.data.equal ? 150 : 140;
  186. ctx.fillText(this.data.victory.userRead.score + '分', lnumx, lnumy)
  187. var rnumx = this.data.equal ? 280 : 280,
  188. rnumy = this.data.equal ? 150 : 165;
  189. ctx.fillText(this.data.defeated.userRead.score + '分', rnumx, rnumy)
  190. }
  191. ctx.font = '13px PingFang';
  192. var ltimex = this.data.equal ? 136 : 136,
  193. ltimey = this.data.equal ? 252.5 : 239.5;
  194. ctx.fillText(this.data.vEnd, ltimex, ltimey)
  195. var rtimex = this.data.equal ? 320 : 320,
  196. rtimey = this.data.equal ? 253 : 267;
  197. ctx.fillText(this.data.dEnd, rtimex, rtimey)
  198. // 圆形位置 大小
  199. var size = 55;
  200. var lx = this.data.equal ? 71 : 72,
  201. ly = this.data.equal ? 45 : 38;
  202. var rx = this.data.equal ? 252 : 247,
  203. ry = this.data.equal ? 45 : 60;
  204. ctx.save(); // 保存
  205. ctx.arc(size / 2 + lx, size / 2 + ly, size / 2, 0, Math.PI * 2, false);
  206. ctx.arc(size / 2 + rx, size / 2 + ry, size / 2, 0, Math.PI * 2, false);
  207. ctx.clip();
  208. let leftImg = canvas.createImage();
  209. leftImg.src = this.data.victory.user.avatar
  210. leftImg.onerror = () => {
  211. loadRightImg()
  212. }
  213. leftImg.onload = () => {
  214. ctx.drawImage(leftImg, lx, ly, size, size)
  215. loadRightImg()
  216. }
  217. let loadRightImg = () => {
  218. let rightImg = canvas.createImage();
  219. rightImg.src = this.data.defeated.user.avatar
  220. rightImg.onload = () => {
  221. ctx.drawImage(rightImg, rx, ry, size, size)
  222. setTimeout(() => {
  223. wx.canvasToTempFilePath({
  224. canvas: canvas,
  225. success: (res) => {
  226. let userName = this.data.pkRecord.userReadId == this.data.victory.userRead.id ? this.data.victory.user.nickName || this.data.victory.user.eid : this.data.defeated.user.nickName || this.data.defeated.user.eid
  227. if (userName.length > 4) {
  228. userName = userName.slice(0, 4) + '...'
  229. }
  230. // #if MP
  231. resolve({
  232. title: `我挑战了${userName}的作品,这场比拼真精彩!点击加入战局!`,
  233. path: `/pages/pkResult/index?id=${this.data.pkId}&uid=${wx.getStorageSync('uid')}&playback=true`,
  234. imageUrl: res.tempFilePath
  235. })
  236. // #elif ANDROID
  237. resolve({
  238. title: `我挑战了${userName}的作品,这场比拼真精彩!点击加入战局!`,
  239. userName: 'gh_50f61361ad1d',
  240. path: `/pages/pkResult/index?id=${this.data.pkId}&uid=${wx.getStorageSync('uid')}&playback=true`,
  241. imagePath: res.tempFilePath,
  242. webpageUrl: 'http://www.efunbox.cn',
  243. withShareTicket: true,
  244. miniprogramType: 1,
  245. scene: 0,
  246. })
  247. // #endif
  248. },
  249. fail(res) {
  250. reject()
  251. }
  252. }, this)
  253. }, 500)
  254. }
  255. rightImg.onerror = () => {
  256. setTimeout(() => {
  257. wx.canvasToTempFilePath({
  258. canvas: canvas,
  259. success(res) {
  260. resolve({
  261. title: '我的新作品发布啦,快来捧场点赞!',
  262. path: `/pages/pkResult/index?uid=${wx.getStorageSync('uid')}`,
  263. imageUrl: res.tempFilePath
  264. })
  265. },
  266. fail(res) {
  267. reject()
  268. }
  269. }, this)
  270. }, 500)
  271. }
  272. }
  273. }
  274. })
  275. })
  276. },
  277. })