如标题所述,我正在尝试创建一个基于jQuery/JavaScript的节拍器,并使用HTML
它“还行”,但我觉得
我希望节拍器在打开新选项卡并在那里进行其他操作时能“在后台”运行而不改变速度。此外,我想要一个确切的节拍器 ;)
这是我的测试环境:http://nie-wieder.net/metronom/test.html 目前,JS代码和HTML标记都在test.html源文件中,所以你可以在那里查看。
此外,这是我使用的相关(据我认为)js代码:
任何帮助都将是极好的,我现在已经没有更多的想法了。
<audio />
标签播放声音。它“还行”,但我觉得
setInterval
方法不够准确。我在这里搜索了一些帖子,但由于我对jQuery和JavaScript都很新,而且我没有找到可行的解决方案。同样适用于“打开新选项卡并且setInterval停止或延迟”的问题。我试图用stop(true,true)
来避免这个问题,但它没有像我预期的那样工作。我希望节拍器在打开新选项卡并在那里进行其他操作时能“在后台”运行而不改变速度。此外,我想要一个确切的节拍器 ;)
这是我的测试环境:http://nie-wieder.net/metronom/test.html 目前,JS代码和HTML标记都在test.html源文件中,所以你可以在那里查看。
此外,这是我使用的相关(据我认为)js代码:
$(document).ready(function() {
//vars
var intervalReference = 0;
var currentCount = 1;
var countIncrement = .5;
var smin = 10;
var smax =240;
var svalue = 120;
//soundchkbox
$(".sndchck").attr("disabled", true);
//preload sound
$.ajax({
url: "snd/tick.ogg",
success: function() {
$(".sndchck").removeAttr("disabled");
}
});
// tick event
var met = $("#bpm").slider({
value: 120,
min: smin,
max: smax,
step: 1,
change: function( event, ui ) {
var delay = (1000*60/ui.value)/2
clearInterval(intervalReference);
//seems to be the Problem for me
intervalReference = setInterval(function(){
var $cur_sd = $('#sub_div_'+currentCount);
$cur_sd
.stop(true,true)
.animate({opacity: 1},15,
function() {
//Play HTML5 Sound
if($('#sound_check:checked').val()){
$('#tick')
.stop(true,true)
.trigger("play");
}
$(this).
stop(true,true).
animate({opacity:0});
}
);
currentCount += countIncrement;
if(currentCount > 4.5) currentCount = 1
}, delay);
createMusicTag(ui);
}
});
});
任何帮助都将是极好的,我现在已经没有更多的想法了。