微信小程序开发之麦克风动画 帧动画 放大 淡出

想做个录音机,第一步就卡在麦克风动画这里了.

先上gif.再吐槽.


① 上面gif中声波的动画是个半成品.没有循环播放.在微信小程序的开发文档上找了很久,也没找到循环模式的参数设置.用setInterval()并不执行动画.我在 微信小程序文档 动画最下面找到这么一行字.这个锅是不是可以甩出去了?

ps:如果有同学能实现动画循环,一定告诉我.


② 麦克风里面是个帧动画.没有前端的基础,只能用非主流的办法凑合了.

用wx:if{{}}判断js中定义的值是不是等于图片对应的数字来控制图片的显示和隐藏.css中应该有更好的方法.我css基础不牢,就不说了.


上代码:

1.index.wxml


[html]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. <!--index.wxml-->  
  2. <view  class="voice-style" bindtap="startSpeak">  
  3. <image class="bg-style" src="../../images/voice_icon_speaking_bg_normal.png" ></image>  
  4. <image class="bg-style" animation="{{spreakingAnimation}}" src="../../images/voice_video_loading_0.png"></image>  
  5. <image class="bg-style" animation="{{spreakingAnimation_1}}" src="../../images/voice_video_loading_0.png"></image>  
  6. <image class="bg-style" animation="{{spreakingAnimation_2}}" src="../../images/voice_video_loading_0.png"></image>  
  7. <image class="sound-style" src="../../images/voice_icon_speech_sound_1.png" ></image>  
  8. <image wx:if="{{j==2}}" class="sound-style" src="../../images/voice_icon_speech_sound_2.png" ></image>  
  9. <image wx:if="{{j==3}}" class="sound-style" src="../../images/voice_icon_speech_sound_3.png" ></image>  
  10. <image wx:if="{{j==4}}" class="sound-style" src="../../images/voice_icon_speech_sound_4.png" ></image>  
  11. <image wx:if="{{j==5}}"class="sound-style" src="../../images/voice_icon_speech_sound_5.png" ></image>  
  12. </view>  

2.index.js

[javascript]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. //index.js  
  2. //获取应用实例  
  3. var app = getApp()  
  4. Page({  
  5.   data: {  
  6.     spreakingAnimation: {},//放大动画  
  7.     j: 1,//帧动画初始图片  
  8.     isSpeaking: false,//是否在录音状态  
  9.   },  
  10.   onLoad: function () {  
  11.   },  
  12.   //点击开始说话  
  13.   startSpeak: function () {  
  14.     var _this = this;  
  15.     if (!this.data.isSpeaking) {  
  16.       speaking.call(this);  
  17.       this.setData({  
  18.         isSpeaking: true  
  19.       })  
  20.     } else {  
  21.       //去除帧动画循环  
  22.       clearInterval(this.timer)  
  23.       this.setData({  
  24.         isSpeaking: false,  
  25.         j: 1  
  26.       })  
  27.     }  
  28.   },  
  29. })  
  30.   
  31.   
  32. function speaking() {  
  33.   //话筒帧动画  
  34.   var i = 1;  
  35.   this.timer = setInterval(function () {  
  36.     i++;  
  37.     i = i % 5;  
  38.     _this.setData({  
  39.       j: i  
  40.     })  
  41.     return  
  42.   }, 200);  
  43.   //波纹放大,淡出动画  
  44.   var _this = this;  
  45.   var animation = wx.createAnimation({  
  46.     duration: 1000  
  47.   })  
  48.   animation.opacity(0).scale(3, 3).step();//修改透明度,放大  
  49.   this.setData({  
  50.     spreakingAnimation: animation.export()  
  51.   })  
  52.  setTimeout(function(){  
  53.     //波纹放大,淡出动画  
  54.   var animation = wx.createAnimation({  
  55.     duration: 1000  
  56.   })  
  57.   animation.opacity(0).scale(3, 3).step();//修改透明度,放大  
  58.   _this.setData({  
  59.     spreakingAnimation_1: animation.export()  
  60.   })  
  61.   },250)  
  62.    setTimeout(function(){  
  63.     //波纹放大,淡出动画  
  64.   var animation = wx.createAnimation({  
  65.     duration: 1000  
  66.   })  
  67.   animation.opacity(0).scale(3, 3).step();//修改透明度,放大  
  68.   _this.setData({  
  69.     spreakingAnimation_2: animation.export()  
  70.   })  
  71.   },500)  
  72. }  


3.index.wxss

[css]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. /**index.wxss**/  
  2. .voice-style {  
  3.   margin-top400px;  
  4.   display: flex;  
  5.   positionrelative;  
  6.   flex-direction: column;  
  7.   align-items: center;  
  8. }  
  9.   
  10. .bg-style {  
  11.   positionabsolute;  
  12.   width100px;  
  13.   height100px;  
  14. }  
  15. .sound-style{  
  16.   positionabsolute;  
  17.   width37.6px;  
  18.   height60px;  
  19.   margin-top20px;  
  20. }  


demo代码下载


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值