Web Audio API 再生サウンドの音量を変更する

Web Audio API で再生しているサウンドの音量を変更するコードを紹介します。

概要

Web Audio APIで再生されているサウンドの音量を変更するには、再生開始時にGainNodeオブジェクトに接続して再生を開始します。再生中にGainNodeオブジェクトのGainの値を変更するとサウンドの音量を変更できます。

プログラム例

コード

下記のHTMLファイルを作成します。
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
	<meta charset="utf-8" />
  <meta name="viewport" content="width=device-width, user-scale=yes, initial-scale=1.0, maximum-scale=5.0" />

  <script type="text/javascript">
    var request, source, stopflag=0, gainNode;

    window.onload = function () {
      request = new XMLHttpRequest();
      request.open("GET", "sound2.mp3", true);
      request.responseType = "arraybuffer";
      request.onload = completeOnLoad;
      request.send();
    };

    function completeOnLoad() {
      window.AudioContext = window.AudioContext || window.webkitAudioContext;
      context = new AudioContext();
      
      // オーディオをデコード
      context.decodeAudioData(request.response, function (buf) {
        source.buffer = buf;
        source.loop = false;

      });

      source = context.createBufferSource();

      var elem = document.getElementById("Play");
      elem.addEventListener("click", playStart, false);

      var elem2 = document.getElementById("Pause");
      elem2.addEventListener("click", playPause, false);

      var elem3 = document.getElementById("vUP");
      elem3.addEventListener("click", playVolumnUp, false);

      var elem4 = document.getElementById("vDOWN");
      elem4.addEventListener("click", playVolumnDown, false);
}

    function playStart() {
        gainNode = context.createGain();
        source.connect(gainNode);
        gainNode.connect(context.destination);
        gainNode.gain.value = 0.1;
        source.start(0);
    }

    function playPause() {
        if (stopflag == 0) {
            context.suspend();
            stopflag = 1;
        } else {
            context.resume();
            stopflag = 0;
        }
      }

    function playVolumnUp() {
        gainNode.gain.value = gainNode.gain.value + 0.1;
        var elemv = document.getElementById("volvalue");
        elemv.innerHTML = gainNode.gain.value.toFixed(2);
    }

      function playVolumnDown() {
        gainNode.gain.value = gainNode.gain.value - 0.1;
        var elemv = document.getElementById("volvalue");
        elemv.innerHTML = gainNode.gain.value.toFixed(2);
    }
  </script>

</head>
<body>
    <a id="Play" href="javascript:void(0);">再生</a><br />
    <a id="Pause" href="javascript:void(0);">停止/再開</a><br />
    音量 : <a id="vUP" href="javascript:void(0);">[+]</a>&nbsp;<a id="vDOWN" href="javascript:void(0);">[-]</a><br />
    <div id="volvalue"></div>
</body>
</html>

解説

Web Audio APIを利用したサウンド再生については「Web Audio API を利用してWebブラウザーでオーディオファイルを再生する (Microsoft Edge, Google Chrome用)」または「iOSのMobile SafariでWeb Audio API を利用してサウンドを再生する」の記事を参照してください。

再生開始時に、AudioContextオブジェクトのcreateGain()メソッドを呼び出し、GainNodeオブジェクトを作成します。オーディオソースのconnectメソッドを呼び出し、作成したGainNodeオブジェクトをオーディオソースに接続します。接続後、GainNodeオブジェクトのconnectメソッドを呼び出し、AudioContextオブジェクトに接続します。GainNodeオブジェクトのgainプロパティの値を設定します。gainプロパティの値が音量になります。設定後、オーディオソースのstartメソッドを呼び再生を開始します。
function playStart() {
  gainNode = context.createGain();
  source.connect(gainNode);
  gainNode.connect(context.destination);
  gainNode.gain.value = 0.1;
  source.start(0);
}

今回の例では、リンクのクリックにより、音量を上げ下げします。現在のGainNodeオブジェクトのgain値に0.1を加算、または減算して音量の上げ下げをします。また、現在の音量の値を画面に表示します。
function playVolumnUp() {
  gainNode.gain.value = gainNode.gain.value + 0.1;
  var elemv = document.getElementById("volvalue");
  elemv.innerHTML = gainNode.gain.value.toFixed(2);
}

function playVolumnDown() {
  gainNode.gain.value = gainNode.gain.value - 0.1;
  var elemv = document.getElementById("volvalue");
  elemv.innerHTML = gainNode.gain.value.toFixed(2);
}

実行結果

上記のHTMLページをWebブラウザで表示します。下図の画面が表示されます。[再生]リンクをクリックするとサウンドの再生が始まります。


サウンドの再生中に[音量]の[+]のリンクをクリックします。音量が徐々に大きくなることが確認できます。


[-]のリンクをクリックすると音量が小さくなります。値が"0"になると音量も0になりサウンドが聞こえなくなります。

参考

GainNodeを利用しない場合
function playStart() {
  source.connect(context.destination);
  source.start(0);
}

上記のコードではオーディオソースからAudioContextへ直接接続している状態になります。


GainNodeを利用する場合
function playStart() {
  gainNode = context.createGain();

  source.connect(gainNode);
  gainNode.connect(context.destination);
  gainNode.gain.value = 0.1;
  source.start(0);
}

上記のコードではオーディオソースからGainNodeオブジェクトに接続し、GainNodeオブジェクトからAudioContextへ接続している状態になります。


著者
iPentec.com の代表。ハードウェア、サーバー投資、管理などを担当。
Office 365やデータベースの記事なども担当。
掲載日: 2019-09-01
iPentec all rights reserverd.