タイトルで述べたように、私は<audio />
サウンドを再生するためにHTMLタグと一緒にjQuery/JavaScriptベースのメトロノームを作成しようとしています。
「大丈夫」ですが、このsetInterval
方法は十分に正確に機能していないようです。ここでいくつかのスレッドを検索しましたが、jQueryとJavaScriptの両方に慣れておらず、実用的な解決策が見つかりませんでした。「新しいタブを開いてsetIntervalが停止または遅れる」についても同じです-問題。でそれを防ごうとしましstop(true,true)
たが、思った通りに動きませんでした。
新しいタブを開いてそこで何かをするときにテンポを変更せずに、メトロノームを「バックグラウンド」で実行したいと思います。また、私は確かに正確なメトロノームが欲しいです;)
これが私のテスト環境です: http: //nie-wieder.net/metronom/test.html
現時点では、JS-CodeとHTML-markupはすべて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);
}
});
});
どんな助けでも素晴らしいでしょう、私は今のところアイデアがありません。