useAudioRightWrong.js 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. import { nextTick } from "vue";
  2. let audioContext = null;
  3. let code = null; // 身份标识
  4. audioContext = uni.createInnerAudioContext(); // 单例模式[3](@ref)
  5. audioContext.onEnded(() => {
  6. // 播放结束
  7. uni.$emit('result-audio-ended', code)
  8. })
  9. audioContext.onPlay(() => {
  10. // 播放
  11. uni.$emit('result-audio-play', code);
  12. });
  13. audioContext.onError((err) => {
  14. // 播放
  15. uni.$emit('result-audio-ended', code)
  16. uni.showToast({
  17. title: '音频播放异常,已重置.'
  18. })
  19. });
  20. const audioList = {
  21. right: '/static/mp3/newYingyu/right-tip.mp3',
  22. wrong: '/static/mp3/newYingyu/error-tip.mp3'
  23. }
  24. export const resultImageList = {
  25. right: '/static/images/study/cjdc/right-tip-img-gif',
  26. wrong: '/static/images/study/cjdc/error-tip-img-gif'
  27. }
  28. function createAudioNew() {
  29. audioContext = uni.createInnerAudioContext(); // 单例模式[3](@ref)
  30. audioContext.onEnded(() => {
  31. // 播放结束
  32. uni.$emit('result-audio-ended', code)
  33. })
  34. audioContext.onPlay(() => {
  35. // 播放
  36. uni.$emit('result-audio-play', code);
  37. });
  38. audioContext.onError((err) => {
  39. // 播放
  40. console.log('errr',err)
  41. uni.$emit('result-audio-ended', code);
  42. uni.showToast({
  43. title: '音频播放异常,已重置.'
  44. })
  45. });
  46. }
  47. export class resultAudioPlayer {
  48. // 播放音频
  49. play(codeT, code1) {
  50. code = {
  51. code1,
  52. codeT
  53. };
  54. if (audioContext.src === audioList[codeT] && !audioContext.paused) return;
  55. audioContext.stop();
  56. audioContext.destroy();
  57. audioContext = null;
  58. nextTick(() => {
  59. createAudioNew();
  60. audioContext.src = audioList[codeT];
  61. audioContext.play();
  62. })
  63. }
  64. // 暂停播放
  65. pause() {
  66. audioContext?.pause();
  67. }
  68. // 停止播放(释放资源)
  69. stop() {
  70. audioContext?.stop();
  71. audioContext = null;
  72. }
  73. }