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

发布时间 - 2026-01-11 00:42:39    点击率:

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

先上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; 
} 

demo代码下载

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


# 小程序  # 麦克风动画  # 微信小程序-图片、录音、音频播放、音乐播放、视频、文件代码实例  # 微信小程序录音与播放录音功能  # 微信小程序开发之录音机 音频播放 动画实例 (真机可用)  # 微信小程序录音文件格式silk遇到的问题及解决方法  # 微信小程序实现录音时的麦克风动画效果实例  # 是个  # 文档  # 我在  # 去了  # 告诉我  # 也没  # 就不  # 说了  # 很久  # 找了  # 只能用  # 卡在  # 参数设置  # 非主流  # 甩出  # 应用实例  # 一行字  # 想做个  # lt  # image 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel安装步骤详细教程_Laravel环境搭建指南  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  详解Oracle修改字段类型方法总结  香港服务器租用每月最低只需15元?  如何在阿里云虚拟主机上快速搭建个人网站?  jquery插件bootstrapValidator表单验证详解  Laravel如何与Pusher实现实时通信?(WebSocket示例)  Laravel如何使用Blade模板引擎?(完整语法和示例)  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践  如何获取免费开源的自助建站系统源码?  iOS正则表达式验证手机号、邮箱、身份证号等  Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  如何撰写建站申请书?关键要点有哪些?  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  PythonWeb开发入门教程_Flask快速构建Web应用  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  如何快速辨别茅台真假?关键步骤解析  非常酷的网站设计制作软件,酷培ai教育官方网站?  Java类加载基本过程详细介绍  JS中对数组元素进行增删改移的方法总结  Laravel distinct去重查询_Laravel Eloquent去重方法  图册素材网站设计制作软件,图册的导出方式有几种?  Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  Android自定义控件实现温度旋转按钮效果  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  在Oracle关闭情况下如何修改spfile的参数  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  文字头像制作网站推荐软件,醒图能自动配文字吗?  浅谈Javascript中的Label语句  Android滚轮选择时间控件使用详解  Laravel如何使用Sanctum进行API认证?(SPA实战)  Laravel如何发送系统通知?(Notification渠道示例)  Laravel API资源类怎么用_Laravel API Resource数据转换  利用python获取某年中每个月的第一天和最后一天  Linux安全能力提升路径_长期防护思维说明【指导】  java获取注册ip实例  Laravel如何处理异常和错误?(Handler示例)  浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】  Laravel Session怎么存储_Laravel Session驱动配置详解  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  如何批量查询域名的建站时间记录?  三星网站视频制作教程下载,三星w23网页如何全屏?