Konfigurationsbeispiele

Auf dieser Seite finden Sie einige Konfigurationsbeispiele für die Codierung einer Eingabemediendatei (d. h. ein ElementaryStream).

Videostream

VideoStream-Properties haben keine Abhängigkeiten. Sie können Attribute wie Auflösung (Höhe und Breite), Bitrate und Framerate unabhängig festlegen.

{
  "videoStream": {
    "h264": {
      "profile": "high",
      "preset": "veryfast",
      "heightPixels": 360,
      "widthPixels": 640,
      "pixelFormat": "yuv420p",
      "bitrateBps": 550000,
      "rateControlMode": "vbr",
      "crfLevel": 21,
      "vbvSizeBits": 550000,
      "vbvFullnessBits": 495000,
      "gopDuration": "3s",
      "entropyCoder": "cabac",
      "bFrameCount": 3,
      "frameRate": 30,
      "aqStrength": 1
    }
  },
  "key": "video-stream0"
}

Audiostream

Bestimmte AudioStream-Attribute sind unterschiedlich. Der Attributwert channelCount muss der Anzahl der Layouts im Array channelLayout entsprechen. Dieser Wert muss auch der Anzahl der Kanäle in einem zugewiesenen Eingabestream entsprechen.

Einfacher Audiostream

Das folgende Beispiel zeigt einen nicht zugeordneten Audiostream ohne Ton.

{
  "audioStream": {
    "codec": "aac",
    "bitrateBps": 64000,
    "channelCount": 2,
    "channelLayout": [
      "fl",
      "fr"
    ],
    "sampleRateHertz": 48000
  },
  "key": "audio-stream0"
}

Audiostream mit Zuordnung

Im Folgenden finden Sie ein Beispiel für einen mit Audio verknüpften Audiostream. Die Ausgabe-Stereo-AudioStream besteht aus den folgenden Eingaben:

  • Track 1
    • Kanal 0
  • Track 1
    • Kanal 1

Beachten Sie, dass der Wert des Attributs channelCount der Anzahl der unter mapping definierten Objekte entsprechen muss, die jeweils einen eigenen outputChannel haben.

{
  "key":  "audio-stream0",
  "audioStream": {
    "codec": "aac",
    "bitrateBps": 64000,
    "channelCount": 2,
    "channelLayout": [
      "fl",
      "fr"
    ],
    "sampleRateHertz": 48000,
    "mapping": [
      {
        "atomKey": "atom0",
        "inputKey": "video_and_stereo_audio",
        "inputTrack": 1,
        "inputChannel": 0,
        "outputChannel": 0,
        "gainDb": 0
      },
      {
        "atomKey": "atom0",
        "inputKey": "video_and_stereo_audio",
        "inputTrack": 1,
        "inputChannel": 1,
        "outputChannel": 1,
        "gainDb": 0
      }
    ]
  }
}

Audiostream mit Mischpult

Im Folgenden finden Sie ein Beispiel für einen gemischten Audiostream. Die Ausgabe-Stereo-AudioStream besteht aus den folgenden Eingaben:

  • Track 2
    • Kanal 0
    • Kanal 2
    • Kanal 4
  • Track 2
    • Kanal 1
    • Kanal 3
    • Kanal 5
{
  "key":  "audio-stream0",
  "audioStream":  {
    "codec":  "aac",
    "bitrateBps":  128000,
    "channelCount":  2,
    "mapping":  [
      {
        "atomKey": "atom0",
        "inputKey": "video_and_stereo_audio",
        "inputTrack": 2,
        "inputChannel": 0,
        "outputChannel": 0,
        "gainDb": 0
      },
      {
        "atomKey": "atom0",
        "inputKey": "video_and_stereo_audio",
        "inputTrack": 2,
        "inputChannel": 2,
        "outputChannel": 0,
        "gainDb": 0
      },
      {
        "atomKey": "atom0",
        "inputKey": "video_and_stereo_audio",
        "inputTrack": 2,
        "inputChannel": 4,
        "outputChannel": 0,
        "gainDb": 0
      },
      {
        "atomKey": "atom0",
        "inputKey": "video_and_stereo_audio",
        "inputTrack": 2,
        "inputChannel": 1,
        "outputChannel": 1,
        "gainDb": 0
      },
      {
        "atomKey": "atom0",
        "inputKey": "video_and_stereo_audio",
        "inputTrack": 2,
        "inputChannel": 3,
        "outputChannel": 1,
        "gainDb": 0
      },
      {
        "atomKey": "atom0",
        "inputKey": "video_and_stereo_audio",
        "inputTrack": 2,
        "inputChannel": 5,
        "outputChannel": 1,
        "gainDb": 0
      },
    "sampleRateHertz":  44100
  }
}

Textstream

TextStream-Properties haben keine Abhängigkeiten. Sie können Attribute unabhängig festlegen.

In Textstreams kann eine Bearbeitungsliste verwendet werden, um die Ausgabedatei zu ändern. In den folgenden Abschnitten wird die Verwendung der Bearbeitungsliste zum Bereitstellen von Untertiteln erläutert.

Das folgende Beispiel zeigt einen Textstream mit einem Atom in der Bearbeitungsliste.

{
  "editList":[
     {
        "key":"atom0",
        "inputs":[
           "video_input0",
           "caption_input0"
        ],
        "startTimeOffset":"0s",
        "endTimeOffset":"300s"
     }
  ],
  "elementaryStreams":[
    {
      "key": "cea-stream0",
      "textStream": {
        "codec": "cea708",
        "mapping": [
          {
            "atomKey": "atom0",
            "inputKey": "caption_input0",
            "inputTrack": 0
          }
        ]
      }
    }
  ]
}

Das folgende Beispiel zeigt einen Textstream mit zwei Atomen in der Bearbeitungsliste.

{
  "editList":[
     {
        "key":"atom0",
        "inputs":[
           "video_input0",
           "caption_input0"
        ],
        "startTimeOffset":"0s",
        "endTimeOffset":"300s"
     },
     {
        "key":"atom1",
        "inputs":[
           "video_input1",
           "caption_input1"
        ],
        "startTimeOffset":"0s",
        "endTimeOffset":"300s"
     }
  ],
  "elementaryStreams":[
    {
      "key": "cea-stream0",
      "textStream": {
        "codec": "cea708",
        "mapping": [
          {
          "atomKey": "atom0",
          "inputKey": "caption_input0",
          "inputTrack": 0
          },
          {
          "atomKey": "atom1",
          "inputKey": "caption_input1",
          "inputTrack": 0
          }
        ]
      }
    }
  ]
}

Erweitert

In den folgenden Abschnitten werden verschiedene erweiterte Konfigurationen beschrieben.

MuxStream und fmp4

Ein MuxStream, der den fmp4-Container verwendet, kann nur einen einzigen ElementaryStream enthalten. Verwenden Sie für diesen Container zwei MuxStreams: eine für Audio und eine für Videos:

"muxStreams":[
  {
    "key": "hd3-video",
    "container": "fmp4",
    "elementaryStreams":["video-stream1"]
  },
  {
    "key": "hd3-audio",
    "container": "fmp4",
    "elementaryStreams":["audio-stream1"]
  }
],

Streams in mehreren Manifesten wiederverwenden

Die folgende Beispielkonfiguration zeigt zwei Video- und eine Audiocodierung, die sowohl im HLS- als auch im DASH-Manifest verwendet werden:

{
  "config": {
    "inputs": [
      {
        "key": "input0",
        "uri": "gs://GCS_BUCKET_NAME/GCS_INPUT_VIDEO"
      }
    ],
    "elementaryStreams": [
      {
        "videoStream": {
          "h264": {
            "heightPixels": 360,
            "widthPixels": 640,
            "bitrateBps": 500000,
            "frameRate": 30
          }
        },
        "key": "video-stream0"
      },
      {
        "videoStream": {
          "h264": {
            "heightPixels": 720,
            "widthPixels": 1280,
            "bitrateBps": 3200000,
            "frameRate": 30
          }
        },
        "key": "video-stream1"
      },
      {
        "audioStream": {
          "codec": "aac",
          "bitrateBps": 64000,
          "sampleRateHertz": 48000
        },
        "key": "audio-stream0"
      }
    ],
    "muxStreams": [
      {
        "key": "video-only-sd",
        "container": "fmp4",
        "elementaryStreams": [
          "video-stream0"
        ]
      },
      {
        "key": "video-only-hd",
        "container": "fmp4",
        "elementaryStreams": [
          "video-stream1"
        ]
      },
      {
        "key": "audio-only",
        "container": "fmp4",
        "elementaryStreams": [
          "audio-stream0"
        ]
      }
    ],
    "manifests": [
      {
        "fileName": "manifest.m3u8",
        "type": "HLS",
        "muxStreams": [
          "video-only-sd",
          "video-only-hd",
          "audio-only"
        ]
      },
      {
        "fileName": "manifest.mpd",
        "type": "DASH",
        "muxStreams": [
          "video-only-sd",
          "video-only-hd",
          "audio-only"
        ]
      }
    ],
    "output": {
      "uri": "gs://GCS_BUCKET_NAME/GCS_OUTPUT_VIDEO"

    }
  }
}