fe60ccd7d5d598fcd374ed8b08300199.png

写业务代码经常会碰到要自己实现一些设计交给的小动画,今天我们就来看下小喇叭那种类似倒过来的wifi图标一样的效果:

format,png

语音播放效果

对于这个有几种实现方案:一种是直接把图标.png文件放在下面,然后再在上面覆盖一层跟它弧度相似的圆形div,通过css的animation去控制那个覆盖的div从左向右移动,从而实现出这种效果(其实还是有区别的,用div控制移动就会出现一个一个逐渐出现且,会同时消失的场景,而不是这种波浪式的递推)另外一种是把这个图标切分成三块,通过布局调整每个小图标的间距,然后通过js去控制每个小图标的出现顺序以及时间,这种方法的好处就是很灵活,而且代码编写起来也比较直观。但是我们作为一个前端攻城狮不能老写偏中后台的逻辑代码,总得学会用css装饰自己吧,更何况现在css3的出现,页面的动画变得可以像ppt一样舒服了。所以我介绍下最后一种方式,就是用div块去设定border然后再给div一个border-radius:50%,做出三个圆调整好位置,然后用一个矩形的div转变角度去盖住这三个圆,最后通过css3的animation去控制渐进渐出,从而实现上图的效果!

话不多说上代码:

769327d7457015322bfbf1ea40f2c671.png

div结构

1dabeee2dc264a8c7c32e0b28080ebac.png

css代码外部div块以及圆环通用样式

91c35b835e6702f09dad67f3c95ae5fc.png

css代码每个小环的大小、位置以及动画定义

1e7613cbe4ebb75032a58079fc9e976a.png

渐进渐出动画效果定义

文末附上完整代码:

微信语音样式

margin: 0;

padding: 0;

}

.box {

width: 120px;

height: 120px;

box-sizing: border-box;

position: relative;

margin: 50px auto;

}

.wifi-symbol {

width: 50px;

height: 50px;

box-sizing: border-box;

overflow: hidden;

transform: rotate(135deg);

}

.wifi-circle {

border: 5px solid #999999;

border-radius: 50%;

position: absolute;

}

.first {

width: 5px;

height: 5px;

background: #cccccc;

top: 45px;

left: 45px;

}

.second {

width: 25px;

height: 25px;

top: 35px;

left: 35px;

animation: fadeInOut 1s infinite 0.2s;.

}

.third {

width: 40px;

height: 40px;

top: 25px;

left: 25px;

animation: fadeInOut 1s infinite 0.4s;

}

@keyframes fadeInOut {

0% {

opacity: 0; /*初始状态 透明度为0*/

}

100% {

opacity: 1; /*结尾状态 透明度为1*/

}

}

复制代码

方案二

微信语音播放动画:// html

复制代码

css3:

.voice{

padding-top: 12px;

padding-left: 10px;

margin: 100px auto;

height: 35px;

width: 150px;

background: #1bbc9b;

border-radius: 0 7px 7px;

}

.bg {

background:url() right 0 no-repeat;

width: 24px;

height: 24px;

background-size: 400%;

}

.voicePlay {

animation-name: voicePlay;

animation-duration: 1s;

animation-direction: normal;

animation-iteration-count: infinite;

animation-timing-function: steps(3);

}

@keyframes voicePlay {

0% {

background-position: 0;

}

100% {

background-position: 100%;

}

}复制代码

bb4b6e95996456cb4a20ea649ef971cd.png

方案3  ---

html5 audio

思路

关于播放动画,这个很简单,我们可以用css3的逐帧动画来实现。关于逐帧动画,我之前的文章也写过:www.haorooms.com/post/zhuzhe…

图片如下:

3ceaabb8e7839f391faffd2978dc2cac.png

除了动画之外,剩下的就是js对audio的控制了。

html5 audio

关于html5 audio标签,有很多属性,大家可以搜索一下,例如preload、autoplay、loop、controls等等。让其隐藏,我们可以添加一个隐藏参数,代码如下:复制代码

这样,这个audio 就可以隐藏显示,接下来我们就可以用js对其进行操作控制了。

audio常用方法addTextTrack() 向音频/视频添加新的文本轨道

canPlayType() 检测浏览器是否能播放指定的音频/视频类型

load() 重新加载音频/视频元素

play() 开始播放音频/视频

pause() 暂停当前播放的音频/视频复制代码

audio常用事件

事件对我们非常有用,可以通过判断音频是否加载完成,来进行动画的操作,例如,我们点击录音,先有一个加载loading动画,然后在变成我们前面所讲的逐帧动画。abort 当音频/视频的加载已放弃时

canplay 当浏览器可以播放音频/视频时

canplaythrough 当浏览器可在不因缓冲而停顿的情况下进行播放时

durationchange 当音频/视频的时长已更改时

emptied 当目前的播放列表为空时

ended 当目前的播放列表已结束时

error 当在音频/视频加载期间发生错误时

loadeddata 当浏览器已加载音频/视频的当前帧时

loadedmetadata 当浏览器已加载音频/视频的元数据时

loadstart 当浏览器开始查找音频/视频时

pause 当音频/视频已暂停时

play 当音频/视频已开始或不再暂停时

playing 当音频/视频在已因缓冲而暂停或停止后已就绪时

progress 当浏览器正在下载音频/视频时

ratechange 当音频/视频的播放速度已更改时

seeked 当用户已移动/跳跃到音频/视频中的新位置时

seeking 当用户开始移动/跳跃到音频/视频中的新位置时

stalled 当浏览器尝试获取媒体数据,但数据不可用时

suspend 当浏览器刻意不获取媒体数据时

timeupdate 当目前的播放位置已更改时

volumechange 当音量已更改时

waiting 当视频由于需要缓冲下一帧而停止复制代码

例如如下代码:audio.onloadedmetadata = function () {

$(_this).removeClass("loading");

$(_this).addClass("playing");

}复制代码

当音频文件已经加载到浏览器之后,去除加载动画,增加播放动画。

js 操作音频文件播放暂停

如下代码可以控制audio播放还是暂停var audio = document.getElementById('haorooms');

if(audio!==null){

//检测播放是否已暂停.audio.paused 在播放器播放时返回false.

alert(audio.paused);

if(audio.paused) {

audio.play();//audio.play();// 这个就是播放

}else{

audio.pause();// 这个就是暂停

}

} 复制代码

当然也可以通过jquery轻松操作!var audio = $(that).children("audio")[0];//获取,这段代码直接从我们文件中copy而来,可以直接写$("audio")[0]

audio.load();//加载

audio.play();//播放

audio.pause();//暂停复制代码

值得注意的是,我们可以用定时器来让语音播放结束之后,动画去掉。

定时器可以用setTimeout来写!关于setTimeout,可以看我之前的文章!

定时器是一个变量!var second=$(that).data("second");//获取音频秒数

_this.dshiqi=setTimeout(function(){ //dshiqi是外层定义好的一个变量!

$(that).removeClass("playing");//播放完毕去除动画

},second*1000)复制代码

记得在每次切换点击的时候,清除之前的定时器clearTimeout(_this.dshiqi);复制代码

不清除定时器,来回点击录音,会有问题!

上面就是对html5的audio实现高仿微信语音播放效果简单总结,欢迎留言交流!

ps :好多朋友问有没有demo,找了一下,发现只有一个很挫的静态页面,是之前用jquery写的,大家将就着看下吧!

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐