media.seekTo

オーディオファイル中の再生位置を動かします。

media.seekTo(milliseconds);

パラメーター

  • milliseconds: 再生位置を動かす先の位置をミリ秒単位で表します

概要

media.seekTo 関数は Media オブジェクトのオーディオファイルの現在再生位置を更新する非同期関数です。 Media オブジェクト内の position パラメーターの値も更新します。

サポートされているプラットフォーム

  • Android
  • BlackBerry WebWorks (OS 6.0 以上)
  • iOS
  • Windows Phone 7 (Mango)
  • Tizen

使用例

    // オーディオプレイヤー
    //
    var my_media = new Media(src, onSuccess, onError);
    my_media.play();
    // 5秒後に、10秒の位置まで移動
    setTimeout(function() {
        my_media.seekTo(10000);
    }, 5000);

Full Example

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
                  "http://www.w3.org/TR/html4/strict.dtd">
    <html>
      <head>
        <title>メディアの使用例</title>

        <script type="text/javascript" charset="utf-8" src="cordova-2.1.0.js"></script>
        <script type="text/javascript" charset="utf-8">

        // Cordova の読み込み完了まで待機
        //
        document.addEventListener("deviceready", onDeviceReady, false);

        // Cordova 準備完了
        //
        function onDeviceReady() {
            playAudio("http://audio.ibeat.org/content/p1rj1s/p1rj1s_-_rockGuitar.mp3");
        }

        // オーディオプレイヤー
        //
        var my_media = null;
        var mediaTimer = null;

        // オーディオ再生
        //
        function playAudio(src) {
            // src から Media オブジェクトを作成
            my_media = new Media(src, onSuccess, onError);

            // オーディオ再生
            my_media.play();
            // メディアの再生位置を一秒ごとに更新
            mediaTimer = setInterval(function() {
                // 再生位置を取得
                my_media.getCurrentPosition(
                    // 呼び出し成功
                    function(position) {
                        if (position > -1) {
                            setAudioPosition(position + " sec");
                        }
                    },
                    // 呼び出し失敗
                    function(e) {
                        console.log("Error getting pos=" + e);
                    }
                );
            }, 1000);
            // 5秒後に、10秒の位置まで移動
            setTimeout(function() {
                my_media.seekTo(10000);
            }, 5000);
        }

        // オーディオ停止
        //
        function stopAudio() {
            if (my_media) {
                my_media.stop();
            }
            clearInterval(mediaTimer);
            mediaTimer = null;
        }

        // 成功時のコールバック関数
        //
        function onSuccess() {
            console.log("playAudio():Audio Success");
        }

        // エラー時のコールバック関数
        //
        function onError(error) {
            alert('コード: '        + error.code    + '\n' +
                  'メッセージ: '    + error.message + '\n');
        }

        // 再生位置をセット
        //
        function setAudioPosition(position) {
            document.getElementById('audio_position').innerHTML = position;
        }

        </script>
      </head>
      <body>
        <a href="#" class="btn large" onclick="playAudio('http://audio.ibeat.org/content/p1rj1s/p1rj1s_-_rockGuitar.mp3');">再生</a>
        <a href="#" class="btn large" onclick="stopAudio();">停止</a>
        <p id="audio_position"></p>
      </body>
    </html>

BlackBerry WebWorks に関する注意点

  • この API は BlackBerry OS 5 デバイスではサポートされていません。