Tone.js/examples/convolver.html

94 lines
2.1 KiB
HTML
Raw Normal View History

<!DOCTYPE html>
<html>
<head>
2014-10-28 16:18:06 +00:00
<meta charset="utf-8">
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
<script type="text/javascript" src="./deps/jquery.min.js"></script>
<script type="text/javascript" src="./deps/jquery-ui.js"></script>
<script type="text/javascript" src="./deps/jquery.ui.touch-punch.js"></script>
<script type="text/javascript" src="../build/Tone.js"></script>
<script type="text/javascript" src="./Widgets.js"></script>
<script type="text/javascript" src="./ExampleList.js"></script>
<link rel="stylesheet" type="text/css" href="./style/widgets.css">
<link rel="stylesheet" type="text/css" href="./style/jquery-ui.css">
</head>
<body>
2014-10-28 16:18:06 +00:00
<div id="Container">
<div id="Explanation">
Convolver
<br>
<br>
Press START to hear a note through a Convolution reverb effect.
The Berlin tunnel impulse response courtesy of Gabe Liberti, <a href="http://www.studioindefinit.com/" target="_blank">Studio Indefinit</a>.
</div>
<div id="Content">
<div id="Loading">Loading...</div>
</div>
</div>
<script type="text/javascript">
2014-10-28 16:18:06 +00:00
/* globals Tone, GUI */
2014-10-28 16:18:06 +00:00
var loadCount = 0;
2014-10-28 16:18:06 +00:00
function testLoad(){
loadCount++;
if (loadCount === 2){
$("#Loading").remove();
}
}
2014-10-28 16:18:06 +00:00
var player = new Tone.Player("./audio/casio/A1.mp3", function(){
testLoad();
});
player.retrigger = true;
2014-10-28 16:18:06 +00:00
var convolver = new Tone.Convolver({
url : "./audio/IRs/berlin_tunnel_ir.wav",
onload : function(){
testLoad();
},
});
//Effects sends and returns
player.connect(convolver);
convolver.toMaster();
2014-10-28 16:18:06 +00:00
// GUI //
2014-10-28 16:18:06 +00:00
new GUI.TopBar(Tone);
var container = $("#Content");
2014-10-28 16:18:06 +00:00
// Momentary play
new GUI.Momentary(container, function(on){
if (on){
player.start();
}
}, "Start", "Start");
// dryWet slider
var wetnessSlider = new GUI.Slider(container, function(val){
convolver.setWet(val, 0);
return val*100;
}, 1, "dry/wet", "%");
wetnessSlider.render(1);
2014-10-28 16:18:06 +00:00
</script>
<style type="text/css">
#Content {
width: 300px;
height: 300px;
text-align: center;
}
2014-10-28 16:18:06 +00:00
.Slider{
margin-top: 10px;
width: 100%;
}
</style>
</body>
</html>