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


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 相关文章推荐
javascript oop开发滑动(slide)菜单控件
Aug 25 Javascript
jQuery之选择组件的深入解析
Jun 19 Javascript
javascript实现多栏闭合展开式广告位菜单效果实例
Aug 05 Javascript
点评js异步加载的4种方式
Dec 22 Javascript
Angularjs CURD 详解及实例代码
Sep 14 Javascript
js实现1,2,3,5数字按照概率生成
Sep 12 Javascript
Javascript中prototype与__proto__的关系详解
Mar 11 Javascript
一个Vue页面的内存泄露分析详解
Jun 25 Javascript
vue+element项目中过滤输入框特殊字符小结
Aug 07 Javascript
Vue.js暴露方法给WebView的使用操作
Sep 07 Javascript
Vue——前端生成二维码的示例
Dec 19 Vue.js
vue中使用mockjs配置和使用方式
Apr 06 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的博客ping服务代码
2012/02/04 PHP
PHP与SQL语句常用大全
2016/12/10 PHP
php字符串截取函数mb_substr用法实例分析
2019/06/25 PHP
javascript Array.prototype.slice使用说明
2010/10/11 Javascript
增强用户体验友好性之jquery easyui window 窗口关闭时的提示
2012/06/22 Javascript
不要使用jQuery触发原生事件的方法
2014/03/03 Javascript
jQuery平滑旋转幻灯片特效代码分享
2015/09/07 Javascript
理解javascript中的MVC模式
2016/01/28 Javascript
JavaScript中数组去除重复的三种方法
2016/04/22 Javascript
EXT中单击button按钮grid添加一行(光标位置可设置)的实例代码
2016/06/02 Javascript
JavaScript中的Reflect对象详解(ES6新特性)
2016/07/22 Javascript
jQuery Validate 校验多个相同name的方法
2017/05/18 jQuery
Angular2.js实现表单验证详解
2017/06/23 Javascript
vue-cli开发环境实现跨域请求的方法
2018/04/07 Javascript
vue单文件组件lint error自动fix与styleLint报错自动fix详解
2019/01/08 Javascript
vue 实现小程序或商品秒杀倒计时
2019/04/14 Javascript
vue路由的配置和页面切换详解
2020/09/09 Javascript
Angular处理未可知异常错误的方法详解
2021/01/17 Javascript
Python3基础之基本运算符概述
2014/08/13 Python
Python import自定义模块方法
2015/02/12 Python
Python日期时间模块datetime详解与Python 日期时间的比较,计算实例代码
2018/09/14 Python
python实现kNN算法识别手写体数字的示例代码
2019/08/16 Python
用Python实现校园通知更新提醒功能
2019/11/23 Python
Python HTTP下载文件并显示下载进度条功能的实现
2020/04/02 Python
python实现企业微信定时发送文本消息的实例代码
2020/11/25 Python
CSS3 box-sizing属性
2009/04/17 HTML / CSS
全国道德模范事迹
2014/02/01 职场文书
工商管理自荐书
2014/07/06 职场文书
作弊检讨书
2015/01/27 职场文书
党员个人总结范文
2015/02/14 职场文书
寒假安全保证书
2015/02/28 职场文书
幼儿园家长工作总结2015
2015/04/25 职场文书
党支部评议意见
2015/06/02 职场文书
十七岁的单车观后感
2015/06/12 职场文书
js实现上传图片到服务器
2021/04/11 Javascript
sql注入教程之类型以及提交注入
2021/08/02 MySQL