(前端项目实战) 微信 H5音乐项目总结

刚刚完成了一个 H5 项目,途中使用 audio 的时候遇到不少坑,所以写篇项目总结。

项目需求

要经过微信授权才能进入。所以只能在微信打开。

流程:

开场有个小的过渡效果,有 bgm

接着连续两张图片显示,有各自的 bgm

第二张图片,有文字,文字的显示要有打字的效果,附带 bgm

主场面

拥有各个小物品,像时钟、猫、电脑、手机、杂志、durex 等等

点击各个物品,对应的图片会切换,并且播放声音,最后显示一个确认框。时钟也会转动

点击关灯,进入下一个画面

接着又是图片的显示。图片会根据时钟的时间,显示不同的图片。也是简单的图片渐变显示、打字效果、弹幕和 bgm

最后是结果页,结果页有三个按钮,重新来一次,生成截图,外链

大概的需求就是这样,挺简单的。

遇到的问题

微信 ios 无法自动播放声音

这个处理起来不难。

// 微信配置后

wx.ready(() => {

  audio.play()

})

// 或者

document.addEventListener("WeixinJSBridgeReady", () =>{  

 WeixinJSBridge.invoke('getNetworkType', {}, () => {

   audio.play()

 })

}, false)

这样就会自动播放起来了。不过会等当前资源加载完毕的时候才播放。我这个项目因为资源挺多的,所以加载了相当一段时间,然后才会播放音乐。

非微信 ios 如何自动播放声音?

这个好像就处理不了了。只能通过用户对应用触发了交互,才能播放起音乐。

比如有个开始按钮,用户点击了这个按钮后,你就可以执行事件回调播放音乐。

音乐播放,会有延迟的效果

比如资源还没加载到,不能立刻播放。

// html

//js

function play(dom) {

 const oAudio = document.querySelector(dom)

 oAudio.play()

 oAudio.muted = true

}

我们可以先让它播放起来,这样资源就会提前加载了,设置了静音,这样就能保证声音不会被听到。而且 DOM 节点是要一直存在的,除非你不需要再播放这个音乐。

至于在什么时候提前加载资源,就要看你的项目需求去判断了。

ios 无法设置音量大小

这个真的是蛋疼。。。项目一开始的 bgm 是要比较大声的,后面的流程要降低音量

audio.volume = 0.5

安卓是没问题的,但是 ios 是无效的,就算在 dom 设置 volume 也是无效的。

苹果官网文档

在上面有一句话是说到这个问题:Thevolumeproperty is not settable in JavaScript. Reading thevolumeproperty always returns 1.

最后。。。只能用两个相同的 bgm 但是不同音量的文件解决。但是这个 bgm 的文件大小有 500kb 。。。

图片无法快速加载

可以在项目开始前,提前加载

const loadImg = (img) => {

 const isArray = Array.isArray(img)

 if (!isArray) {

   const oImg = new Image()

   oImg.src = img

   return new Promise(resolve => {

     oImg.onload = () => {

       resolve()

     }

   })

 }

 const arr = []

 img.forEach(v => {

   const oImg = new Image()

   oImg.src = v

   arr.push(new Promise(resolve => {

     oImg.onload = () => {

       resolve()

     }

   }))

 })

 return Promise.all(arr)

}

接受单个字符串或者数组参数,使用 promise 处理。

加载图片后,再触发动画

让图片加载完了,再触发动画

this.loadImg([img, img_1, img_2_1, img_2_2]).then(() => {

 setTimeout(() => {

   this.playMusic()

   this.setOne()

 }, 500)

})

这样就不会图都没有出来,动画就播完了。

截图功能

原本打算自己用 canvas 根据 dom 渲染到画布上,再 toDataURL 生成图片的,然后找到了一个比较好的库, html2canvas,简单快捷,一键生成。

html2canvas(document.querySelector('.app')).then(canvas => {

 // ...

})

里面还有个坑,,截图是不能有跨域的图片存在,否则会空白一片。因为项目最后截图的效果,只有一张图片,所以我先把图片转成 base64,再截屏就可以了。

createBase64() {

     const img = new Image()

     img.crossOrigin = true

     img.src = this.bg

     new Promise(resolve => {

       img.onload = () => {

         resolve()

       }

     }).then(() => {

       const oc = document.createElement('canvas')

       oc.width = img.width

       oc.height = img.height

       const ctx = oc.getContext('2d')

       ctx.drawImage(img, 0, 0)

       this.bg = oc.toDataURL()

     })

   }

页面布局

使用 rem 进行开发。

最外层 div 直接:

#app {

 position: absolute;

 top: 0;

 left: 0;

 width: 100%;

 height: 100vh;

 overflow: hidden;

}

不出现滚动条。

背景图就用 background

.bg {

 background-size: cover;

 background-position: center center;

}

然后其他一些比较散乱的,就用绝对定位

.cat {

 position: absolute;

 top: 50%;

 left: 50%;

}

先把对象定位到整个页面的中间,再用 margin / transform 进行调整位置。水平位置同理。

这些单个对象的,定位的策略就是已中心点为标准,进行定位。而不是以左上点或者左下点。

因为背景图也是直接显示中心部分的,所以单个对象的也要以中心点去定位。

限制资源大小

静态资源是 css, js, image, audio。css 还好,没用什么 ui 库。js 的话,只用了 vue 和 html2canvas。vue-router、vuex、mint-ui 这些都是统统去掉。

图片就用 gulp 配合 tinypng 进行压缩图片

const gulp = require('gulp')

const tiny = require('gulp-tinypng-nokey')

const gulpLoadPlugins = require('gulp-load-plugins')

// 还要安装 gulp-rename

const plugins = gulpLoadPlugins()

gulp.task('tinypng', function(cb) {

 gulp.src('src/assets/**/*.{jpg,jpeg,png,gif}')

   .pipe(tiny())

   .pipe(plugins.rename(function(path) {

     path.dirname = `/assets/${path.dirname}`

   }))

   .pipe(gulp.dest('./src'))

})

这样是会把原文件给覆盖掉的,如果你有必要的话,执行前要做好备份

音乐文件的话,因为是客户那边找的,可以进行压缩下,或者把不会播放到的部分给裁剪到。

裁剪的工具,我用的是 mac 的QuickTime player.app进行裁剪的。简单地裁剪是没问题的。如果像增加或者降低音乐的声音大小,用的是 这个网站,挺好用的。最后就是格式的转换,用的是MediaHuman Audio Converter.app

最后再把稍微大点的资源扔到类似七牛这种云服务器上,这样既能加快加载速度,又能减低服务器的压力。

总结

这次 H5 的开发,遇到比较麻烦的是 audio 这块。特别大部分 audio 问题是出自 ios 的。。。幸好有 iphone 进行开发测试,不然调试起来真的是麻烦大了。

静态资源扔到七牛后,加载速度快了很多。

至于网页和代码就不放出来了,现在还没上线,客户那边还在调细节~~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,527评论 5 470
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,314评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,535评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,006评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,961评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,220评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,664评论 3 392
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,351评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,481评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,397评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,443评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,123评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,713评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,801评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,010评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,494评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,075评论 2 341

推荐阅读更多精彩内容