使用 C++ 制作人库 - Amazon Kinesis Video Streams

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

使用 C++ 制作人库

你可以使用 Amazon Kinesis Video Streams 提供的 C++ 制作器库来编写应用程序代码,将媒体数据从设备发送到 Kinesis 视频流。

物体模型

C++ 库提供了以下对象来管理向 Kinesis 视频流发送数据:

  • KinesisVideoProducer: 包含有关您的媒体来源和 AWS 凭据的信息,并维护回调以报告 Kinesis Video Streams 事件。

  • KinesisVideoStream: 代表 Kinesis 视频流。包含有关视频流参数的信息,例如名称、数据保留期和媒体内容类型。

将媒体放入直播中

您可以使用 C++ 库提供的方法(例如PutFrame)将数据放入KinesisVideoStream对象中。随后,该库将管理数据的内部状态,这可包含以下任务:

  • 执行身份验证。

  • 监视网络延迟。如果延迟太高,库可能会选择丢弃帧。

  • 跟踪正在进行的流式处理的状态。

回调接口

此层公开一组回调接口,使其能够与应用程序层进行通信。这些回调接口包括:

  • 服务回调 interface (CallbackProvider):该库在创建流、获取流描述和删除流时调用通过此接口获取的事件。

  • 客户端就绪状态或低存储事件接口 (ClientCallbackProvider):当客户端准备就绪或检测到可用存储空间或内存可能用完时,库会在此接口上调用事件。

  • 流事件回调接口 (StreamCallbackProvider):当直播事件发生时,该库会调用此接口上的事件,例如直播进入就绪状态、丢帧或直播错误。

Kinesis Video Streams 为这些接口提供了默认实现。您也可以提供自己的自定义实现,例如,如果您需要自定义网络逻辑或想要向用户界面公开低存储条件。

有关制作器库中回调的更多信息,请参阅制作人SDK回调

步骤:使用 C++ 制作器 SDK

此过程演示如何在 C++ 应用程序中使用 Kinesis Video Streams 客户端和媒体源向你的 Kinesis 视频流发送数据。

该过程包括以下步骤:

主题