add detune to rest of the voices
This commit is contained in:
parent
3773cfd778
commit
77af7d2576
18
synth.html
18
synth.html
|
@ -40,11 +40,11 @@
|
|||
<span id="detunevoice1display" class="text-sm text-gray-700 ml-2">0</span>
|
||||
</div>
|
||||
|
||||
<div style="padding: 5px">
|
||||
<!-- <div style="padding: 5px">
|
||||
<label for="filtervoice1" class="block text-sm font-medium text-gray-700 mb-1">filter voice</label>
|
||||
<input id="filtervoice1" type="range" min="700" max="1500" value="1000" step="1" class="slider bg-gray-300 h-2 rounded-full outline-none"/>
|
||||
<span id="filtervoice1display" class="text-sm text-gray-700 ml-2">0</span>
|
||||
</div>
|
||||
</div> -->
|
||||
|
||||
<div class="flex-container flex-grow border-2 border-gray-800 rounded-md p-4 m-4">
|
||||
<div id = "wave1viz" class="canvas-container">
|
||||
|
@ -78,6 +78,13 @@
|
|||
</fieldset>
|
||||
</div>
|
||||
|
||||
<div style="padding: 5px">
|
||||
<label for="detunevoice2" class="block text-sm font-medium text-gray-700 mb-1">detune voice</label>
|
||||
<input id="detunevoice2" type="range" min="-5" max="5" value="0" step=".1" class="slider bg-gray-300 h-2 rounded-full outline-none"/>
|
||||
<span id="detunevoice2display" class="text-sm text-gray-700 ml-2">0</span>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="flex-container flex-grow border-2 border-gray-800 rounded-md p-4 m-4">
|
||||
<div id = "wave2viz" class="canvas-container">
|
||||
<canvas id ="wave2canvas"></canvas>
|
||||
|
@ -109,6 +116,13 @@
|
|||
<button id="octaveup3" class="bg-gray-400 hover:bg-gray-500 text-gray-800 font-bold py-1 px-4">+</button>
|
||||
</fieldset>
|
||||
</div>
|
||||
|
||||
<div style="padding: 5px">
|
||||
<label for="detunevoice3" class="block text-sm font-medium text-gray-700 mb-1">detune voice</label>
|
||||
<input id="detunevoice3" type="range" min="-5" max="5" value="0" step=".1" class="slider bg-gray-300 h-2 rounded-full outline-none"/>
|
||||
<span id="detunevoice3display" class="text-sm text-gray-700 ml-2">0</span>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="flex-container flex-grow border-2 border-gray-800 rounded-md p-4 m-4">
|
||||
<div id = "wave3viz" class="canvas-container">
|
||||
|
|
18
synth.js
18
synth.js
|
@ -291,13 +291,17 @@ window.onload = function () {
|
|||
setupOctaveControls(i, synth); // Call setupOctaveControls for each voice
|
||||
}
|
||||
// detune
|
||||
const detuneSliderVoice1 = document.getElementById("detunevoice1");
|
||||
const detunevoice1Display = document.getElementById("detunevoice1display");
|
||||
detuneSliderVoice1.addEventListener("input", (event) => {
|
||||
let osc = synth.oscillators[0];
|
||||
let detune = parseFloat(detuneSliderVoice1.value);
|
||||
console.log(detune);
|
||||
updateFrequency(event, synth, osc, 0, null, null, detune);
|
||||
["1", "2", "3"].forEach((voiceNumber, index) => {
|
||||
const detuneSlider = document.getElementById(`detunevoice${voiceNumber}`);
|
||||
const detuneDisplay = document.getElementById(
|
||||
`detunevoice${voiceNumber}display`
|
||||
);
|
||||
detuneSlider.addEventListener("input", (event) => {
|
||||
let osc = synth.oscillators[index];
|
||||
let detune = parseFloat(detuneSlider.value);
|
||||
console.log(detune);
|
||||
updateFrequency(event, synth, osc, index, null, null, detune);
|
||||
});
|
||||
});
|
||||
|
||||
// const filterSliderVoice1 = document.getElementById("filtervoice1");
|
||||
|
|
Loading…
Reference in New Issue