码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 微信小程序写一个录音机


    微信小程序写一个录音机

    代码:
    wxml:

    <view class="container">
      <view class="duration">{{duration}}view>
      <button bindtap="startRecord" class="btn">开始录音button>
      <button bindtap="stopRecord" class="btn">停止录音button>
      <button bindtap="playRecord" class="btn">播放录音button>
    view>
    <audio id="audio" src="{{recordPath}}" controls>audio>
    

    wxss:

    .container {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      height: 84vh;
    }
    
    .btn {
      margin: 10px;
      padding: 10px 20px;
      background-color: #4CAF50;
      color: white;
      border: none;
      border-radius: 5px;
    }
    
    .duration {
      margin-top: -50px;
      font-size: 24px;
    }
    
    

    js:

    let timer = null;
    Page({
      data: {
        isRecording: false,
        recordPath: '',
        duration: '00:00'
      },
      startRecord: function() {
        const recorderManager = wx.getRecorderManager();
        this.setData({
          isRecording: true,
          duration: '00:00'
        });
        let startTime = new Date().getTime();
        timer = setInterval(() => {
          let currentTime = new Date().getTime();
          let diff = currentTime - startTime;
        
          let m = Math.floor(diff / 60000 % 60);
          let s = Math.floor(diff / 1000 % 60);
          this.setData({
            duration: `${this.formatTime(m)}:${this.formatTime(s)}`
          });
        }, 1000);
        recorderManager.start({
          format: 'mp3'
        });
        recorderManager.onStart(() => {
          console.log('recorder start');
        });
        recorderManager.onStop((res) => {
          console.log('recorder stop', res);
          this.setData({
            recordPath: res.tempFilePath,
            isRecording: false
          });
        });
      },
      stopRecord: function() {
        const recorderManager = wx.getRecorderManager();
        clearInterval(timer);
        recorderManager.stop();
      },
      playRecord: function() {
        this.setData({
          // isRecording: true,
          duration: '录音播放'
        });
        const audioCtx = wx.createInnerAudioContext();
        audioCtx.src = this.data.recordPath;
        audioCtx.play();
      },
      formatTime: function(time) {
        return time < 10 ? `0${time}` : time;
      }
    });
    
    

    json:

    {
      "usingComponents": {},
      "navigationBarTitleText": "录音机"
    }
    

    以上就是实现一个录音机的小程序!

  • 相关阅读:
    js中哪些地方会用到window?
    汽车电子专业知识篇(四十三)-​带你一文通透CAN总线相关知识
    JSP JDBC访问数据库
    【每日一题】完美洗牌
    教你2023年计算机毕业设计怎么选题,创新点怎么写
    算法系列-链表
    GIS技术在医疗行业的应用:利用切片地图发布技术解决dmetrix数字病理切片在线浏览
    Spring Boot与Spring Security的跨域解决方案
    GIS实战应用案例100篇(七十九)-多规整合底图的制作要点
    热门开源项目推荐
  • 原文地址:https://blog.csdn.net/xj1216wt/article/details/139595187
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号