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


Posted in Javascript onApril 18, 2017

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

先上gif.再吐槽.

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

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

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

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

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

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

上代码:

1.index.wxml

<!--index.wxml--> 
<view class="voice-style" bindtap="startSpeak"> 
<image class="bg-style" src="../../images/voice_icon_speaking_bg_normal.png" ></image> 
<image class="bg-style" animation="{{spreakingAnimation}}" src="../../images/voice_video_loading_0.png"></image> 
<image class="bg-style" animation="{{spreakingAnimation_1}}" src="../../images/voice_video_loading_0.png"></image> 
<image class="bg-style" animation="{{spreakingAnimation_2}}" src="../../images/voice_video_loading_0.png"></image> 
<image class="sound-style" src="../../images/voice_icon_speech_sound_1.png" ></image> 
<image wx:if="{{j==2}}" class="sound-style" src="../../images/voice_icon_speech_sound_2.png" ></image> 
<image wx:if="{{j==3}}" class="sound-style" src="../../images/voice_icon_speech_sound_3.png" ></image> 
<image wx:if="{{j==4}}" class="sound-style" src="../../images/voice_icon_speech_sound_4.png" ></image> 
<image wx:if="{{j==5}}"class="sound-style" src="../../images/voice_icon_speech_sound_5.png" ></image> 
</view>

2.index.js

//index.js 
//获取应用实例 
var app = getApp() 
Page({ 
 data: { 
  spreakingAnimation: {},//放大动画 
  j: 1,//帧动画初始图片 
  isSpeaking: false,//是否在录音状态 
 }, 
 onLoad: function () { 
 }, 
 //点击开始说话 
 startSpeak: function () { 
  var _this = this; 
  if (!this.data.isSpeaking) { 
   speaking.call(this); 
   this.setData({ 
    isSpeaking: true 
   }) 
  } else { 
   //去除帧动画循环 
   clearInterval(this.timer) 
   this.setData({ 
    isSpeaking: false, 
    j: 1 
   }) 
  } 
 }, 
}) 

function speaking() { 
 //话筒帧动画 
 var i = 1; 
 this.timer = setInterval(function () { 
  i++; 
  i = i % 5; 
  _this.setData({ 
   j: i 
  }) 
  return 
 }, 200); 
 //波纹放大,淡出动画 
 var _this = this; 
 var animation = wx.createAnimation({ 
  duration: 1000 
 }) 
 animation.opacity(0).scale(3, 3).step();//修改透明度,放大 
 this.setData({ 
  spreakingAnimation: animation.export() 
 }) 
 setTimeout(function(){ 
  //波纹放大,淡出动画 
 var animation = wx.createAnimation({ 
  duration: 1000 
 }) 
 animation.opacity(0).scale(3, 3).step();//修改透明度,放大 
 _this.setData({ 
  spreakingAnimation_1: animation.export() 
 }) 
 },250) 
  setTimeout(function(){ 
  //波纹放大,淡出动画 
 var animation = wx.createAnimation({ 
  duration: 1000 
 }) 
 animation.opacity(0).scale(3, 3).step();//修改透明度,放大 
 _this.setData({ 
  spreakingAnimation_2: animation.export() 
 }) 
 },500) 
}

3.index.wxss

/**index.wxss**/ 
.voice-style { 
 margin-top: 400px; 
 display: flex; 
 position: relative; 
 flex-direction: column; 
 align-items: center; 
} 
.bg-style { 
 position: absolute; 
 width: 100px; 
 height: 100px; 
} 
.sound-style{ 
 position: absolute; 
 width: 37.6px; 
 height: 60px; 
 margin-top: 20px; 
}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
jQuery图片播放8款精美插件分享
Feb 17 Javascript
简介JavaScript中valueOf()方法的使用
Jun 05 Javascript
JavaScript实现级联菜单的方法
Jun 29 Javascript
给Easyui-Datebox设置隐藏或者不可用的解决方法
May 26 Javascript
node实现简单的反向代理服务器
Jul 26 Javascript
bootstrap-table.js扩展分页工具栏(增加跳转到xx页)功能
Dec 28 Javascript
jQuery实现的滑块滑动导航效果示例
Jun 04 jQuery
详解基于Vue的支持数据双向绑定的select组件
Sep 02 Javascript
利用Vue的v-for和v-bind实现列表颜色切换
Jul 17 Javascript
解决vue+router路由跳转不起作用的一项原因
Jul 19 Javascript
基于ant design日期控件使用_仅月份的操作
Oct 27 Javascript
vue 给数组添加新对象并赋值
Apr 20 Vue.js
JavaScript错误处理和堆栈追踪详解
Apr 18 #Javascript
微信小程序开发之从相册获取图片 使用相机拍照 本地图片上传
Apr 18 #Javascript
微信小程序实战之自定义抽屉菜单(7)
Apr 18 #Javascript
微信小程序--onShareAppMessage分享参数用处(页面分享)
Apr 18 #Javascript
微信小程序实战之自定义toast(6)
Apr 18 #Javascript
Jquery-data的三种用法
Apr 18 #jQuery
微信小程序实战之登录页面制作(5)
Mar 30 #Javascript
You might like
使用纯php代码实现页面伪静态的方法
2015/07/25 PHP
Yii2中使用join、joinwith多表关联查询
2016/06/30 PHP
PHP实现微信退款功能
2018/10/02 PHP
editable.js 基于jquery的表格的编辑插件
2011/10/24 Javascript
jQuery判断对象是否存在的方法
2015/02/05 Javascript
AngularJS中的指令全面解析(必看)
2016/05/20 Javascript
jQuery模拟实现的select点击选择效果【附demo源码下载】
2016/11/09 Javascript
jquery对象与DOM对象转化
2017/02/08 Javascript
从零开始学习Node.js系列教程之基于connect和express框架的多页面实现数学运算示例
2017/04/13 Javascript
详解webpack的配置文件entry与output
2017/08/21 Javascript
Vue注册组件命名时不能用大写的原因浅析
2019/04/25 Javascript
ES6 let和const定义变量与常量的应用实例分析
2019/06/27 Javascript
微信小程序HTTP接口请求封装代码实例
2019/09/05 Javascript
小程序实现背景音乐播放和暂停
2020/06/19 Javascript
JS中队列和双端队列实现及应用详解
2020/09/29 Javascript
Python实现提取文章摘要的方法
2015/04/21 Python
在Django的上下文中设置变量的方法
2015/07/20 Python
一个基于flask的web应用诞生(1)
2017/04/11 Python
Python实现一个转存纯真IP数据库的脚本分享
2017/05/21 Python
Python基于OpenCV库Adaboost实现人脸识别功能详解
2018/08/25 Python
Python3.4 splinter(模拟填写表单)使用方法
2018/10/13 Python
python自定义函数实现最大值的输出方法
2019/07/09 Python
python的pstuil模块使用方法总结
2019/07/26 Python
Python 矩阵转置的几种方法小结
2019/12/02 Python
VELTRA台湾:世界自由行专家
2017/08/15 全球购物
Uber Eats台湾:寻找附近提供送餐服务的餐厅
2018/05/07 全球购物
服务员自我评价
2014/01/25 职场文书
小学少先队活动方案
2014/02/18 职场文书
合作协议书模板2014
2014/09/26 职场文书
公安机关纪律作风整顿个人剖析材料材料
2014/10/10 职场文书
2015年社会实践个人总结
2015/03/06 职场文书
2015年综治维稳工作总结
2015/04/07 职场文书
银行文明优质服务培训心得体会
2016/01/09 职场文书
《我的伯父鲁迅先生》教学反思
2016/02/16 职场文书
使用Vue3+Vant组件实现App搜索历史记录功能(示例代码)
2021/06/09 Vue.js
pytorch中的 .view()函数的用法介绍
2022/03/17 Python