Ejemplo: análisis y renderización de fragmentos de Kinesis Video Streams - Amazon Kinesis Video Streams

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

Ejemplo: análisis y renderización de fragmentos de Kinesis Video Streams

Transmita usando la biblioteca de analizadoresContiene una aplicación de demostración denominada KinesisVideoRendererExample que muestra cómo analizar y renderizar fragmentos de transmisiones de vídeo de Amazon Kinesis. El ejemplo se utiliza JCodecpara decodificar los fotogramas codificados en H.264 que se ingieren con la aplicación. Ejemplo: complemento para SDK GStreamer productores de Kinesis Video Streams: kvssink Después de decodificar el marco utilizandoJCodec, la imagen visible se renderiza utilizando. JFrame

Este ejemplo le muestra cómo hacer lo siguiente:

  • Recupere fotogramas de una transmisión de vídeo de Kinesis utilizando GetMedia API y renderice la transmisión para su visualización.

  • Vea el contenido de vídeo de las transmisiones en una aplicación personalizada en lugar de utilizar la consola de Kinesis Video Streams.

También puede usar las clases de este ejemplo para ver contenido de transmisión de vídeo de Kinesis que no esté codificado como H.264, como una secuencia de JPEG archivos que no requieren decodificación antes de mostrarse.

El siguiente procedimiento demuestra cómo configurar y utilizar la aplicación de demostración Renderer.

Requisitos previos

Para examinar y utilizar la biblioteca de ejemplos de Renderer, debe tener lo siguiente:

Ejemplo de ejecución del renderizador

  1. Cree un directorio y, a continuación, clone el código fuente del ejemplo desde el GitHub repositorio.

    git clone https://github.com/aws/amazon-kinesis-video-streams-parser-library
  2. Abra el Java IDE que esté utilizando (por ejemplo, Eclipse o IDEAIntelliJ) e importe el proyecto Apache Maven que ha descargado:

    • En Eclipse: seleccione File, Import, Maven, Existing Maven Projects. Vaya al directorio kinesis-video-streams-parser-lib.

    • En IntelliJ Idea: seleccione Import. Vaya al archivo pom.xml en la raíz del paquete descargado.

      nota

      Si IntelliJ no encuentra sus dependencias, es posible que tenga que hacer lo siguiente:

      • Compilación limpia: elija File (Archivo), Settings (Configuración), Build, Execution, Deployment (Compilación, ejecución, implementación), Compiler (Compilador). Compruebe que esté seleccionada la opción Borrar el directorio de salida al reconstruir y, a continuación, elija Compilar, compilar proyecto.

      • Vuelva a importar el proyecto: abra el menú contextual (clic con el botón derecho) del proyecto y seleccione Maven, Reimport (Volver a importar).

    Para obtener más información, consulte la IDE documentación relacionada.

  3. Desde su JavaIDE, abrasrc/test/java/com.amazonaws.kinesisvideo.parser/examples/KinesisVideoRendererExampleTest.

  4. Elimine la directiva @Ignore del archivo.

  5. Actualice el .stream parámetro con el nombre de la transmisión de vídeo de Kinesis.

  6. Ejecute la prueba KinesisVideoRendererExample.

Cómo funciona

Envío de datos MKV

El ejemplo envía MKV datos de muestra desde el rendering_example_video.mkv archivo y se utilizan PutMedia para enviar datos de vídeo a una transmisión denominada render-example-stream.

La aplicación crea un PutMediaWorker:

PutMediaWorker putMediaWorker = PutMediaWorker.create(getRegion(), getCredentialsProvider(), getStreamName(), inputStream, streamOps.amazonKinesisVideo); executorService.submit(putMediaWorker);

Para obtener más información acerca de la clase PutMediaWorker, consulte Llama PutMedia en la documentación de Transmita usando la biblioteca de analizadores.

Análisis de MKV fragmentos para convertirlos en fotogramas

A continuación, el ejemplo recupera y analiza los MKV fragmentos de la secuencia mediante: GetMediaWorker

GetMediaWorker getMediaWorker = GetMediaWorker.create(getRegion(), getCredentialsProvider(), getStreamName(), new StartSelector().withStartSelectorType(StartSelectorType.EARLIEST), streamOps.amazonKinesisVideo, getMediaProcessingArgumentsLocal.getFrameVisitor()); executorService.submit(getMediaWorker);

Para obtener más información acerca de la clase GetMediaWorker, consulte Llama GetMedia en la documentación de Transmita usando la biblioteca de analizadores.

Decodificando y visualizando el fotograma

A continuación, el ejemplo decodifica y muestra el marco utilizando JFrame.

El siguiente ejemplo de código procede de la clase KinesisVideoFrameViewer, que amplía JFrame:

public void setImage(BufferedImage bufferedImage) { image = bufferedImage; repaint(); }

La imagen se muestra como una instancia de java.awt.image. BufferedImage. Para ver ejemplos que ilustran cómo trabajar con BufferedImage, consulte Reading/Loading an Image.