javascript - 如何使用 JavaScript/Tone.js 更改音高和播放速率?

标签 javascript performance audio pitch

我想同时完成两件事:

1) 更改播放速率声音文件到 1/2 速度

2) 降低间距 由五分之一

最后,我不想使用单独的按钮来播放结果 将其连接到音频标签 并使用那里的播放按钮。

下面是迄今为止我使用 Tone.js 得到的最接近的结果。我真的在为文档苦苦挣扎,但我知道 Tone.Transport.bpm.value = 60;将 bpm 从 120 更改为 60,Tone.PitchShift 将歌曲移调。我只是不知道如何将两者结合起来“叠加”效果。

以下是我关注的一些链接:

How to change the pitch with JavaScript?

https://tonejs.github.io/docs/r12/PitchShift

https://tonejs.github.io/docs/13.8.25/Transport

在此先感谢您的帮助!

<audio id="myAudio" controls preload="none">
      <source src="my_tune.m4a" type="audio/mp4" >
</audio>

<script src="https://unpkg.com/tone@next/build/Tone.js"></script>

<script>

Tone.Transport.bpm.value = 60;  // setting the bpm like this is not working. where to put this?


var player = new Tone.Player("my_tune.m4a").sync().start(0);
// is it possible to use audio tag instead of creating this player?

var pitchShift = new Tone.PitchShift({
    pitch: -5 // this is working and lowers pitch by a fifth
}).toMaster();

player.connect(pitchShift);
window.play = function() {
    Tone.Transport.start();
}

<script>

<button onclick="setPlaySpeed()" type="button">separate button</button><br>

最佳答案

更新:工作解决方案

我找到了一种可行的方法:首先设置播放速率。然后,在设置音高时,您需要计算要添加/减去多少音高偏移以补偿播放速率。在我的示例中,我必须为 0.5 的播放速率补偿 +12 音高偏移。

player = new Tone.Player("url/to/audio.mp3");
playback_rate = 0.5 // or 1 (I only implemented these two options)
transpose_by = 7 // up 7 half steps, -7 would be down 7 half steps

// set playback rate
player.playbackRate = playback_rate
player.toDestination();


// set pitch shift
if (playback_rate == 1){
    pitch_shift = new Tone.PitchShift({
    pitch: transpose_by.toString()
    }).toDestination();
} else { //if playbackrate == 0.5 add +12 to pitch to correct
    trans = transpose_by + 12
    trans = trans.toString()
    pitch_shift = new Tone.PitchShift({
    pitch: trans
  }).toDestination();
}
player.disconnect(); // disconnect old player (get overlay of two players otherwise if you repeat this)
player.connect(pitch_shift);

player.start()


在我的网站上查看实际操作:https://www.lickstack.com

不过,我仍然不知道如何将 Tone.js 播放器连接到音频元素。任何帮助,将不胜感激。在这里查看我的帖子:
create html <audio> element from Tone.js object

关于javascript - 如何使用 JavaScript/Tone.js 更改音高和播放速率?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59606613/

相关文章:

javascript - 带有 axios 的进度条

python - 如何在 Python 中获取 BPM 和速度音频功能

c++ - 使用 ALSA 库的音频捕获 - snd_pcm_open => No such file or directory

javascript - 类型 '(event: React.MouseEvent) => void' 不可分配给类型 '(e?: MouseEvent<Element, MouseEvent> | undefined) => void'

javascript - 从 JQuery ListNav 插件中排除特定元素

Android三重缓冲-预期行为?

java - 如何测量 Storm 拓扑中的延迟和吞吐量

Java 播放声音。有默认的系统声音吗?

javascript - 在 HTML Web 应用程序中显示实时网络摄像头数据

java - 优化嵌套 if 语句中的嵌套 for 循环