Esta página descreve como definir configurações durante a criação de canais de endpoint ou de entrada para recursos de transmissão ao vivo, como várias faixas de áudio, legendas e folhas de sprite.
Configurar por meio da criação de endpoints de entrada
É possível especificar configurações para os seguintes recursos durante a criação do endpoint de entrada:
Lista de permissões de IP
É possível restringir o acesso a endpoints de entrada especificando intervalos de IP de origem do stream de entrada, como o endereço IP do codificador. O pipeline de vídeo só aceita tráfego de endereços IP nesses intervalos. Os intervalos de IP precisam estar no formato de bloco CIDR.
Configure o campo securityRules
no recurso Input
:
{
"type": "RTMP_PUSH",
"securityRules": {
"ipRanges": ["1.2.3.4/32"]
}
}
Configurar com a criação de canais
Você pode especificar configurações para os seguintes recursos durante a criação do canal:
Vários fluxos de taxa de bits
É possível criar configurações avançadas de canal compatíveis com várias taxas de bits,
resoluções e frame rates. A configuração a seguir inclui dois muxStream
s na saída, um a 360p com um frame rate de 30 FPS (mux_video_360p30
) e outro a 720p com um frame rate de 60 FPS (mux_video_720p60
). Essa configuração também é compatível com várias taxas de bits de áudio.
Consulte Taxas de bits recomendadas para mais informações.
{
"inputAttachments":[
{
"key":"input-primary",
"input": "projects/PROJECT_NUMBER/locations/LOCATION/inputs/INPUT_ID"
}
],
"output":{
"uri": "gs://BUCKET_NAME"
},
"elementaryStreams": [
{
"key": "es_video_720p60",
"videoStream": {
"h264": {
"profile": "high",
"heightPixels": 720,
"widthPixels": 1280,
"bitrateBps": 5500000,
"frameRate": 60
}
}
},
{
"key": "es_video_360p30",
"videoStream": {
"h264": {
"profile": "high",
"heightPixels": 360,
"widthPixels": 640,
"bitrateBps": 400000,
"frameRate": 30
}
}
},
{
"key": "es_audio_160k",
"audioStream": {
"codec": "aac",
"channelCount": 2,
"bitrateBps": 160000
}
},
{
"key": "es_audio_64k",
"audioStream": {
"codec": "aac",
"channelCount": 2,
"bitrateBps": 64000
}
}
],
"muxStreams": [
{
"key": "mux_video_720p60",
"elementaryStreams": [
"es_video_720p60"
],
"segmentSettings": {
"segmentDuration": "2s"
}
},
{
"key": "mux_video_360p30",
"elementaryStreams": [
"es_video_360p30"
],
"segmentSettings": {
"segmentDuration": "2s"
}
},
{
"key": "mux_audio_160k",
"elementaryStreams": [
"es_audio_160k"
],
"segmentSettings": {
"segmentDuration": "2s"
}
},
{
"key": "mux_audio_64k",
"elementaryStreams": [
"es_audio_64k"
],
"segmentSettings": {
"segmentDuration": "2s"
}
}
],
"manifests": [
{
"fileName": "main.mpd",
"type": "DASH",
"muxStreams": [
"mux_video_720p60",
"mux_video_360p30",
"mux_audio_160k",
"mux_audio_64k"
],
"maxSegmentCount": 5
},
{
"fileName": "main.m3u8",
"type": "HLS",
"muxStreams": [
"mux_video_720p60",
"mux_video_360p30",
"mux_audio_160k",
"mux_audio_64k"
],
"maxSegmentCount": 5
}
]
}
Várias faixas de áudio
Se o stream de entrada contiver mais de uma faixa de áudio, use o objeto AudioMapping
para selecionar a faixa para cada AudioStream
.
{
"inputAttachments": [
{
"key": "MY-INPUT",
"input": "/projects/PROJECT-ID/locations/LOCATION/inputs/MY-INPUT",
}
],
"output": {
"uri": "gs://BUCKET_NAME/outputs/"
},
"elementaryStreams": [
{
"key": "es_video",
"videoStream": {
"h264": {
"heightPixels": 720,
"widthPixels": 1280,
"bitrateBps": 3000000,
"frameRate": 30
}
}
},
{
"key": "es_first_audio",
"audioStream": {
"codec": "aac",
"bitrateBps": 160000,
"mapping": [
{
"inputKey": "MY-INPUT",
"inputTrack": 1
}
]
}
},
{
"key": "es_second_audio",
"audioStream": {
"codec": "aac",
"bitrateBps": 160000,
"mapping": [
{
"inputKey": "MY-INPUT",
"inputTrack": 2
}
]
}
}
],
"muxStreams": [
{
"key": "mux_video",
"elementaryStreams": ["es_video"],
},
{
"key": "mux_first_audio",
"elementaryStreams": ["es_first_audio"],
},
{
"key": "mux_second_audio",
"elementaryStreams": ["es_second_audio"],
}
],
"manifests": [
{
"type": "DASH",
"muxStreams": [
"mux_video",
"mux_first_audio",
"mux_second_audio",
]
}
]
}
O Shaka Player não é compatível com os seguintes recursos de streams HLS com várias faixas de áudio:
Reprodução alternativa da faixa de áudio com segmentos do TS.
Seleção de faixa de áudio secundária e alternativa com segmentos fMP4.
Passagem das legendas CEA 608/708
Se os streams de entrada contiverem legendas CEA 608/708, será possível encaminhar as legendas para os streams de saída. Adicione o seguinte textStream
ao
elementaryStreams
ao criar um Channel
. Esse textStream
incorpora legendas CEA 608/708 em todos os streams de vídeo de saída e versões.
{
"key": "captions",
"textStream": {
"codec": "cea608"
}
}
Folhas de sprite
Para gerar uma folha de sprite, configure o campo spriteSheets
no
recurso Channel
.
{
"spriteSheets": [
{
"format": "jpeg",
"filePrefix": "sprite",
"interval": "2s",
"spriteWidthPixels": 320,
"spriteHeightPixels": 240,
"columnCount": 3,
"rowCount": 3,
"quality": 80
}
]
}