すべてのプロダクト
Search
ドキュメントセンター

ApsaraVideo Media Processing:スナップショットのキャプチャ

最終更新日:Jan 12, 2025

ビデオのスナップショット機能を使用すると、ビデオの特定の時点における特定のサイズのスナップショットをキャプチャできます。スナップショットは、ビデオのサムネイル、スプライト、プログレスバーのサムネイルなどのシナリオで使用されます。スナップショットをキャプチャする時点、連続する 2 つの スナップショット間の間隔、キャプチャする スナップショットの数、キャプチャする スナップショットの種類、複数の スナップショットを 1 つの画像スプライトに合成するかどうかを指定できます。スナップショットジョブは、ApsaraVideo Media Processing(MPS)コンソールで、または API または SDK を使用して送信できます。このトピックでは、MPS SDK for Node.js V2.0 を使用してスナップショットをキャプチャする例を示します。

サンプルコード

'use strict';


const Mts20140618 = require('@alicloud/mts20140618');
const OpenApi = require('@alicloud/openapi-client');
const Util = require('@alicloud/tea-util');
const Tea = require('@alicloud/tea-typescript');

class Client {

    /**
     * AccessKey ID と AccessKey シークレットを使用してクライアントを初期化します。
     * @return Client
     * @throws Exception
     */
    static createClient() {

        let config = new OpenApi.Config({
                // 必須。 ALIBABA_CLOUD_ACCESS_KEY_ID 環境変数が設定されていることを確認します。
                accessKeyId: process.env['ALIBABA_CLOUD_ACCESS_KEY_ID'],
                // 必須。 ALIBABA_CLOUD_ACCESS_KEY_SECRET 環境変数が設定されていることを確認します。
                accessKeySecret: process.env['ALIBABA_CLOUD_ACCESS_KEY_SECRET'],
        });

        config.endpoint = `mts.cn-qingdao.aliyuncs.com`;
        return new Mts20140618.default(config);
    }

    static async main(args) {
        let client = Client.createClient();
        let submitSnapshotJobRequest = new Mts20140618.SubmitSnapshotJobRequest({
                // ジョブ入力。
                input: '{"Bucket":"example-bucket","Location":"example-location","Object":"example%2Ftest.flv"}',
                // スナップショットジョブの構成。
                snapshotConfig: '{"OutputFile":{"Bucket":"example-001","Location":"example-location","Object":"{Count}.jpg"},"Time":"5","Num":"10","Interval":"20"}',
                // ユーザー定義データ。
                userData: 'testid-001',
                // MPS キューの ID。
                pipelineId: 'dd3dae411e704030b921e52698e5****',
    });
        let runtime = new Util.RuntimeOptions({ });
        try {
            // 必要に応じて、API 操作のレスポンスを表示するための独自のコードを記述します。
            await client.submitSnapshotJobWithOptions(submitSnapshotJobRequest, runtime);
        } catch (error) {
            // 実際のビジネスシナリオでは、例外を慎重に処理し、プロジェクトで例外を無視しないでください。この例では、エラーメッセージは参照用にのみ表示されます。
            // エラーメッセージ。
            console.log(error.message);
            // 対応するエラー診断ページの URL。
            console.log(error.data["Recommend"]);
            Util.default.assertAsString(error.message);
        }
    }

}

exports.Client = Client;
Client.main(process.argv.slice(2));

参照