用JS实现一个网页版节拍器

平时练尤克里里经常用到节拍器,突发奇想自己用js开发一个。
摘要由CSDN通过智能技术生成

平时练尤克里里经常用到节拍器,突发奇想自己用js开发一个。

最后实现的效果如下:https://ahao430.github.io/metronome/

代码见github仓库:https://github.com/ahao430/metronome

1. 需求分析

节拍器主要是可以设定不同的速度和节奏打拍子。看各种节拍器,有简单的,也有复杂的。

  • 设定不同的速度,每分钟多少拍

  • 选择节拍,比如4/4拍、3/4拍、6/8拍等等。

  • 选择节拍的节奏型,一拍一个,一拍两个,一拍三个(三连音),一拍四个,swing,等等。这个很多简易节拍器就没有了。

  • 切换不同的音色,比如敲击声、鼓声、人声等等。

这里拍速是指一分钟有多少拍。

而节拍是以几分音符为1拍,每小节几拍。这个不影响拍速,观察各种节拍器,这里会展示几个小点,每一拍一个点,其中第一拍第一下重声,后面的轻声。

节奏型决定每一拍响几下,以及这几下之前的节奏。比如这一拍响一下、响两下、响三下、响四下;如果是一个swing就是前8后16分音符的时长;也可能这个节奏型的时长是两拍,比如民谣扫弦的下----,下空下上。

2. 素材准备

这里没有UI,就简单的写下样式,没有做什么图。去找了个节拍器的图标做favicon,找了几个不同节奏型的图片(截图->裁剪o(╥﹏╥)o),最后音频素材扒到一个强一个弱的敲击声。

准备开工。

3. 开发实现

3.1 框架选型

这里选了 vue3,没啥特别的原因,就是平常经常用vue2和react,vue3没怎么用过,练练手。试试vue3+vite的开发体验。直接用官方脚手架开搞。

配置rem,引入amfe-flexible和ostcss-px2rem-exclude。

ui组件引入nutui。

3.2 模块设计

<script setup lang="ts">

import Speed from "./components/Speed.vue";

import Rhythm from "./components/Rhythm.vue";

import Beat from "./components/Beat.vue";

import Play from "./components/Play.vue";

</script>

<template>

<p class="title">节拍器</p>

<main>

<Speed></Speed>

<div class="flex">

<Beat></Beat>

<Rhythm></Rhythm>

</div>

<Play></Play>

</main>

</template>

将页面按照功能模块划分了几个组件,上面是调节拍速,中间是选择节拍和节奏型,最下面是播放。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
玄羽节拍器-一款简单易用的节拍器 第一次发帖,希望没有违规,对排版也不是很了解,大伙凑合凑合看看吧,要是实在难看我回头再看看咋美化吧23333 节拍器是利用摆的等时性控制节拍声来计时的仪器。取下节拍器面板,就看到一个标度尺。它标出摆振动时每分钟发出的节拍声次数(n)中有一摆杆,摆杆上有一可上下移动的摆锤。摆锤位置所对标尺数,就表示该摆每分钟振动的节拍数(一次全振动有两次节拍数),由此可算出摆的振动周期(T) T=(2×60)/n(秒) 源自百d百科: 节拍器 前段时间又回去看了遍轻音,然后就忍不住想要入手一把电吉他了。 刚好过完年手头有点压岁钱,就买了吧电吉他来练练手。 正好开始需要搭配节拍器练习了,然后又发现电脑端没有合适的节拍器(可能是我不会搜吧),手机端的又有广告,于是乎决定自动动手丰衣足食 节拍器支持以下拍号: 1/4、2/4、3/4、4/4、3/8、6/8 支持BPM最大最小值: 40-240 音调支持: 强音,次强音,弱音 节拍间隔计算公式为: 四分音符:60÷BPM*1000-变色间隔 八分音符:(60÷BPM*1000-变色间隔)÷2 60(秒)÷BPM*1000(单位换算为毫秒)-变色间隔(单位毫秒) (变色间隔:因为节拍器提供声音节奏的同时提供变色闪光打拍子,所以这里去掉显示颜色用的时间,以防影响后面的节拍间隔) 调用模块: 精易模块 (文本处理)、 超级模块(超级延时、线程) (其实模块可以只保留其中一个的,只是因为我这是自动加载模块,我也懒得去删除了,就这样用了) 写在最后:小弟我也是刚入门电吉他,对乐理和很多东西都不太了解,若是有大佬发现以上内容有什么问题还烦请和平指出,小弟也虚心请教(但是拒绝喷子和ETC) 为什么发布帖子过后吞了我好多内容。。。然后还得重新编辑。。。 以下是附件,包含源码(不含模块),编译好的节拍器(源码直接静态编译,无修改),调用音效(来源于互联网,已自行截去无用部分用于控制时长,侵删)

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值