mirror of
https://github.com/Tonejs/Tone.js
synced 2025-01-22 00:25:00 +00:00
63 lines
1.3 KiB
HTML
63 lines
1.3 KiB
HTML
<html>
|
|
<head>
|
|
<title>PANNER</title>
|
|
|
|
<script type="text/javascript" src="../build/Tone.js"></script>
|
|
</head>
|
|
<body>
|
|
<button type="button">start</button>
|
|
<input type='range' value='50'>
|
|
<div id='left'>0</div>
|
|
<div id='right'>0</div>
|
|
<script type="text/javascript">
|
|
|
|
var pan = new Tone.Panner();
|
|
var sine = new Tone.Oscillator();
|
|
|
|
//connect it up
|
|
sine.connect(pan);
|
|
pan.toMaster();
|
|
|
|
//meters
|
|
var outputMeter = new Tone.Meter(2);
|
|
pan.connect(outputMeter);
|
|
|
|
//INTERFACE//
|
|
|
|
var button = document.querySelector("button");
|
|
|
|
button.onclick = function(){
|
|
if (!sine.started){
|
|
sine.start();
|
|
button.textContent = "stop";
|
|
} else {
|
|
sine.stop();
|
|
button.textContent = "start";
|
|
}
|
|
}
|
|
|
|
var left = document.querySelector("#left");
|
|
var right = document.querySelector("#right");
|
|
|
|
setInterval(function(){
|
|
left.textContent = "left: " + outputMeter.getDb(0).toFixed(2) + " db";
|
|
right.textContent = "right: " + outputMeter.getDb(1).toFixed(2) + " db";
|
|
}, 100);
|
|
|
|
|
|
var range = document.querySelector("input");
|
|
|
|
range.oninput = function(e){
|
|
var val = e.target.value;
|
|
pan.setPan(val/100, "+.1");
|
|
}
|
|
|
|
var mouseX, mouseY;
|
|
window.onmousemove = function(e) {
|
|
mouseX = e.x;
|
|
mouseY = e.y;
|
|
};
|
|
|
|
</script>
|
|
</body>
|
|
</html>
|