You are using ocs1
as function as well as oscillator object which is creating conflict.
JS:-
var ctx = new webkitAudioContext();
speakers = ctx.destination;
var osc1= ctx.createOscillator();
var osc2= ctx.createOscillator();
var osc3= ctx.createOscillator();
$(document).ready(function () {
var wF = {
0: "Sine",
1: "Square",
2: "Sawtooth",
3: "Triangle"
};
$('#play_pause_osc1').click(function () {
if ($(this).val() == "Play Osc1") {
$(this).val("Pause");
oscillator1Start();
} else {
$(this).val("Play Osc1");
osc1.disconnect();
}
});
$('#play_pause_osc2').click(function () {
if ($(this).val() == "Play Osc2") {
$(this).val("Pause");
oscillator2Start();
} else {
$(this).val("Play Osc2");
osc2.disconnect();
}
});
$('#play_pause_osc3').click(function () {
if ($(this).val() == "Play Osc3") {
$(this).val("Pause");
oscillator3Start();
} else {
$(this).val("Play Osc3");
osc3.disconnect();
}
});
$(function () {
$("#osc1_vol").slider({
min: 0,
max: 1,
value: 0.5,
step: 0.01,
slide: function (event, ui) {
$("#cur_vol_osc1").val(ui.value);
gainNode1.gain.value = $("#cur_vol_osc1").val();
}
});
$("#cur_vol_osc1").val($("#osc1_vol").slider("value"));
});
$(function () {
$("#osc2_vol").slider({
min: 0,
max: 1,
value: 0.5,
step: 0.01,
slide: function (event, ui) {
$("#cur_vol_osc2").val(ui.value);
gainNode2.gain.value = $("#cur_vol_osc2").val();
}
});
$("#cur_vol_osc2").val($("#osc2_vol").slider("value"));
});
$(function () {
$("#osc3_vol").slider({
min: 0,
max: 1,
value: 0.5,
step: 0.01,
slide: function (event, ui) {
$("#cur_vol_osc3").val(ui.value);
gainNode3.gain.value = $("#cur_vol_osc3").val();
}
});
$("#cur_vol_osc3").val($("#osc3_vol").slider("value"));
});
$(function () {
$("#osc1_pitch").slider({
min: 0,
max: 25000,
value: 440,
step: 0.01,
slide: function (event, ui) {
$("#cur_pitch_osc1").val(ui.value);
osc1.frequency.value = $("#cur_pitch_osc1").val();
}
});
$("#cur_pitch_osc1").val($("#osc1_pitch").slider("value"));
});
$(function () {
$("#osc2_pitch").slider({
min: 0,
max: 25000,
value: 440,
step: 0.01,
slide: function (event, ui) {
$("#cur_pitch_osc2").val(ui.value);
osc2.frequency.value = $("#cur_pitch_osc2").val();
}
});
$("#cur_pitch_osc2").val($("#osc2_pitch").slider("value"));
});
$(function () {
$("#osc3_pitch").slider({
min: 0,
max: 25000,
value: 440,
step: 0.01,
slide: function (event, ui) {
$("#cur_pitch_osc3").val(ui.value);
osc3.frequency.value = $("#cur_pitch_osc3").val();
}
});
$("#cur_pitch_osc3").val($("#osc3_pitch").slider("value"));
});
$(function () {
$("#osc1_detune").slider({
min: -4800,
max: 4800,
value: 0,
step: 0.01,
slide: function (event, ui) {
$("#cur_detune_osc1").val(ui.value);
osc1.detune.value = $("#cur_detune_osc1").val();
}
});
$("#cur_detune_osc1").val($("#osc1_detune").slider("value"));
});
$(function () {
$("#osc2_detune").slider({
min: -4800,
max: 4800,
value: 0,
step: 0.01,
slide: function (event, ui) {
$("#cur_detune_osc2").val(ui.value);
osc2.detune.value = $("#cur_detune_osc2").val();
}
});
$("#cur_detune_osc2").val($("#osc2_detune").slider("value"));
});
$(function () {
$("#osc3_detune").slider({
min: -4800,
max: 4800,
value: 0,
step: 0.01,
slide: function (event, ui) {
$("#cur_detune_osc3").val(ui.value);
osc3.detune.value = $("#cur_detune_osc3").val();
}
});
$("#cur_detune_osc3").val($("#osc3_detune").slider("value"));
});
$(function () {
$("#osc1_wave").slider({
min: 0,
max: 3,
value: 0,
step: 0.01,
slide: function (event, ui) {
$("#cur_wave_osc1").val(wF[ui.value]);
}
});
$("#cur_wave_osc1").val("Sine");
osc1.type = $("#osc1_wave").val();
});
$(function () {
$("#osc2_wave").slider({
min: 0,
max: 3,
value: 0,
step: 0.01,
slide: function (event, ui) {
$("#cur_wave_osc2").val(wF[ui.value]);
}
});
$("#cur_wave_osc2").val("Sine");
osc2.type = $("#osc2_wave").val();
});
$(function () {
$("#osc3_wave").slider({
min: 0,
max: 3,
value: 0,
step: 0.01,
slide: function (event, ui) {
$("#cur_wave_osc3").val(wF[ui.value]);
}
});
$("#cur_wave_osc3").val("Sine");
osc3.type = $("#osc3_wave").val();
});
});
function oscillator1Start() {
osc1 = ctx.createOscillator();
osc1.type = $("#osc1_wave").slider("value");
osc1.frequency.value;
osc1.detune.value;
gainNode1 = ctx.createGainNode();
osc1.connect(gainNode1);
gainNode1.connect(speakers);
gainNode1.gain.value;
osc1.start(0);
}
function oscillator2Start() {
osc2 = ctx.createOscillator();
osc2.type;
osc2.frequency.value;
osc2.detune.value;
gainNode2 = ctx.createGainNode();
osc2.connect(gainNode2);
gainNode2.connect(speakers);
gainNode2.gain.value;
osc2.start(0);
}
function oscillator3Start() {
osc3 = ctx.createOscillator();
osc3.type;
osc3.frequency.value;
osc3.detune.value;
gainNode3 = ctx.createGainNode();
osc3.connect(gainNode3);
gainNode3.connect(speakers);
gainNode3.gain.value;
osc3.start(0);
}