You need to enable JavaScript to run this app.
导航
发布公共流 StartPushPublicStream
最近更新时间:2024.08.02 11:10:45首次发布时间:2024.01.03 20:25:17

本文档 API 接口为最新版本接口,后续相关功能的新增都会在此更新,推荐使用最新版本接口。旧版接口文档请参考历史版本

在实时音视频通话场景中,若需向不在房间的用户发布音视频内容,你可通过调用此接口实现。

通过设定应用标识、公共流 ID 以及目标音视频流等信息,你能够指定音视频流及其布局方式,实现单路或最多 17 路音视频流的发布。此外,通过视频编码参数、视频布局定义以及任务空闲超时时间等设置,你能够灵活控制公共流的发布效果。调用此接口后,接口将返回操作结果。

如果媒体流状态发生变化,你在控制台上设置的回调地址会收到每个状态变化的回调。有关回调结果的详细说明,参看 PushPublicStream

你还可以通过客户端发布公共流,详见公共流的发布和订阅

注意事项

请求频率:QPS 不得超过 150。

请求说明

  • 请求方式:POST
  • 请求地址:https://rtc.volcengineapi.com?Action=StartPushPublicStream&Version=2023-11-01

调试

请求参数

下表仅列出该接口特有的请求参数和部分公共参数。更多信息请见公共参数

Query

参数
类型
是否必选
示例值
描述
Action
String
StartPushPublicStream
接口名称。当前 API 的名称为 StartPushPublicStream
Version
String
2023-11-01
接口版本。当前 API 的版本为 2023-11-01

Body

参数
类型
是否必选
示例值
描述
AppId
String
661e****543cf
你的音视频应用的唯一标志,参看获取 AppId
BusinessId
String
Bus****ss1
你创建的业务标识
PublicStreamId
String
PublicStream1
公共流 ID。你必须对每路公共流,设定 PublicStreamId 时命名规则符合正则表达式:[a-zA-Z0-9_@\-\.]{1,128}
TranscodeMode
Integer
0

公共流处理模式。支持取值及含义如下:
0:转码。
1:转封装。

TranscodeMode=1 时,

  • TargetStreams 只能指定一路流,且该路流的 UserId不能为空,需为对应房间用户的 UserId
  • ExcludeStreams 必须为空。
  • Encode.VideoConfig 设置不生效。
  • Layout 设置不生效。
TargetStreams
Object[]
-
为公共流指定单路或多路媒体流及对应参数,Stream 数组。最高支持 17 路。
UserId
String
user1
媒体流的发布方的用户 ID。
UserId 为空时,表示订阅房间内所有流。
UserId 需全局唯一。不同房间内的 UserId 不能重复。
StreamType
Integer
0

流类型。支持取值及含义如下:

  • 0:音视频流
  • 1:屏幕流
默认值为 0
Index
Integer
1
当选择自定义布局模式时,此字段必填。标记同一路公共流中不同的媒体流。
在同一个 TargetStreams 中,Stream.Index 是唯一的。
RoomId
String
Room1
发布公共流的用户所在的房间 ID
MediaType
Integer
0

流的媒体类型。支持取值及含义如下:

  • 0:音视频
  • 1:纯音频
  • 2:纯视频
默认值为 0
ExcludeStreams
Object[]
-
你可以通过本参数排除掉需要包含在公共流中的音视频流,即黑名单。参数默认为空。黑名单中的流不得超过 17 路。此参数中的 stream 不应和 TargetStreams 中重复。
UserId
String
user1
媒体流的发布方的用户 ID。
UserId 为空时,表示订阅房间内所有流。
UserId 需全局唯一。不同房间内的 UserId 不能重复。
StreamType
Integer
0

流类型。支持取值及含义如下:

  • 0:音视频流
  • 1:屏幕流
默认值为 0
Index
Integer
1
当选择自定义布局模式时,此字段必填。标记同一路公共流中不同的媒体流。
在同一个 TargetStreams 中,Stream.Index 是唯一的。
RoomId
String
Room1
发布公共流的用户所在的房间 ID
MediaType
Integer
0

流的媒体类型。支持取值及含义如下:

  • 0:音视频
  • 1:纯音频
  • 2:纯视频
默认值为 0
Encode
Object
-
媒体编码参数
VideoConfig
Object
-
视频编码配置
Width
Integer
640
输出画面的宽度。默认值为 640,范围为 [16, 1920],必须是偶数。
Height
Integer
480
输出画面的高度,默认值为 480。范围为 [16, 1920],必须是偶数。
FrameRate
Integer
15
输出视频帧率。取值范围为 [1,60],单位为 fps,默认为 15
Bitrate
Integer
256
最高输出视频码率。取值范围为 [0,10000],单位为 Kbps,默认值为00表示自适应码率。
VideoCodec
Integer
0

视频编码协议。支持取值及含义如下:

  • 0H.264
  • 5VP8。 如果选择 VP8 格式,请先联系火山技术支持配置。
默认值为0
Layout
Object
-
公共流包含多路媒体流时的布局参数。
LayoutMode
Integer
0

布局模式。支持取值及含义如下:

默认值为0
VerticalLayout
Object
-
垂直布局参数
MainStream
Object
-

指定在大窗口中显示的流及相关信息

1. 如果在 TargetStreams 中指定了某用户的音频和视频,但在 MainStream 只指定该用户的音频,则公共流中只包含该用户的音频,大窗口的区域置空。

2. 如果在 TargetStreams 中指定了某用户的视频,但在 MainStream 只指定该用户的音频,则公共流中不包含该用户的音频和视频,大窗口的区域置空。

3. 如果 MainStream 中指定的用户不存在,大窗口的区域置空。
UserId
String
user1
媒体流的发布方的用户 ID。
UserId 为空时,表示订阅房间内所有流。
UserId 需全局唯一。不同房间内的 UserId 不能重复。
StreamType
Integer
0

流类型。支持取值及含义如下:

  • 0:音视频流
  • 1:屏幕流
默认值为 0
Index
Integer
1
当选择自定义布局模式时,此字段必填。标记同一路公共流中不同的媒体流。
在同一个 TargetStreams 中,Stream.Index 是唯一的。
RoomId
String
Room1
发布公共流的用户所在的房间 ID
MediaType
Integer
0

流的媒体类型。支持取值及含义如下:

  • 0:音视频
  • 1:纯音频
  • 2:纯视频
默认值为 0
CustomLayout
Object
-
自定义布局参数
Regions
Object[]
-
自定义布局下,多路视频配置
StreamIndex
Integer
1
流标识。

StreamIndex 即 Stream.Index,用来指定布局设置将被应用到哪路流。
LocationX
Float
0
视频流对应区域左上角的横坐标相对整体画面的比例,取值的范围为 [0.0, 1.0),默认值为 0
LocationY
Float
0
视频流对应区域左上角的纵坐标相对整体画面的比例,取值的范围为 [0.0, 1.0),默认值为 0
WidthProportion
Float
0.5
视频流对应区域宽度相对整体画面的比例,取值的范围为 (0.0, 1.0]
HeightProportion
Float
0.5
视频流对应区域高度相对整体画面的比例,取值的范围为 (0.0, 1.0]
ZOrder
Integer
0
当画面有重叠时,使用此参数设置指定画面的图层顺序,取值范围为 [0, 100],默认值为 00 表示该区域图像位于最下层,100 表示该区域图像位于最上层。
Alpha
Float
1.0
画面的透明度,取值范围为 (0.0, 1.0],默认值为 1.00.0 表示完全透明,1.0 表示完全不透明。
RenderMode
Integer
0

画面的渲染模式。支持取值及含义如下:

  • 0 :按照指定的宽高直接缩放。如果原始画面宽高比与指定的宽高比不同,就会导致画面变形
  • 1 :按照显示区域的长宽比裁减视频,然后等比拉伸或缩小视频,占满显示区域。
  • 2 :按照原始画面的宽高比缩放视频,在显示区域居中显示。如果原始画面宽高比与指定的宽高比不同,就会导致画面有空缺,空缺区域为填充的背景色值。
  • 3 :按照指定的宽高直接缩放。如果原始画面宽高比与指定的宽高比不同,就会导致画面变形。
默认值为 0
目前 03 均为按照指定的宽高直接缩放,但我们推荐你使用 3 以便与客户端实现相同逻辑。
AlternateImage
String
-
占位图片的 url
SourceCrop
Object
-

源流剪切功能。公共流功能下, SourceCropAlternateImage 不生效。

注意

如果你填写了 LocationXLocationYWidthProportionHeightProportion 中的一个或多个参数,SourceCrop 下的其他参数也必须填写。

LocationX
Float
0
裁剪后得到的视频帧左上角的横坐标相对裁剪前整体画面的比例,取值的范围为 [0.0, 1.0)。默认值为 0.0
LocationY
Float
0
裁剪后得到的视频帧左上角的纵坐标相对裁剪前整体画面的比例,取值的范围为 [0.0, 1.0)。默认值为 0.0
WidthProportion
Float
0.5
裁剪后得到的视频帧宽度相对裁剪前整体画面宽度的比例,取值范围为 (0.0, 1.0]。默认值为 1.0
HeightProportion
Float
0.5
裁剪后得到的视频帧高度相对裁剪前整体画面宽度的比例,取值范围为 (0.0, 1.0]。默认值为 1.0
FrameInterpolationMode
Integer
0

补帧模式。支持取值及含义如下:

  • 0:补最后一帧,
  • 1:补黑帧。

默认值为0。自动布局模式下,该参数不生效。
补帧是指在音视频录制时,视频的帧率通常是固定的。但是,因为网络波动或其他原因,实际帧率可能无法达到预设的帧率。此时,需要补帧以保持视频流畅。补最后一帧意味着补充的视频帧和中断前的最后一帧相同,此时看到的画面可能会有短暂静止;补黑帧意味着补充的视频帧是全黑的。

如果同时配置AlternateimageFrameInterpolationMode ,优先使用 Alternateimage参数。

  • Region.StreamIndex 对应的视频流停止发布时, Region 对应的画布空间会根据设置填充占位图或补帧。但当视频流为屏幕流时,补帧模式不生效。
  • Region.StreamIndex 对应的视频流发布后停止采集或推送时, Region 对应的画布空间会填充上一帧。
  • Region.StreamIndex 对应的视频流发布时,设置的占位图或补顿模式不造成任何影响。
BackgroundColor
String
#000000
背整体屏幕(画布)的背景色,格式为 #RGB(16进制),默认值为 #000000(黑色), 范围为 #000000 ~ #ffffff (大小写均可)。

如果你设置了背景图片,背景图片会覆盖背景色。
BackgroundImage
String
http://xxxx.svg
背景图片的 URL。长度最大为 1024 byte。可以传入的图片的格式包括:JPG, JPEG, PNG。如果背景图片的宽高和整体屏幕的宽高不一致,背景图片会缩放到铺满屏幕。

如果你设置了背景图片,背景图片会覆盖背景色。
Control
Object
-
控制选项。
MaxIdleTime
Integer
180
任务的空闲超时时间,超过此时间后,任务自动终止。取值范围为 [10, 86400],单位为秒,默认值为 180。只在调用 StartPushPublicStream 时有效。
DataMsg
String
-
插入公共流的自定义信息,可用于随流信息同步,长度不超过 4 kB。
数据会添加到当前视频帧开始的连续 30 个视频帧中。
只在调用 UpdatePublicStreamParam 时有效。
UserCaptureStatsMode
Boolean
false

是否开启房间用户采集状态回调。开启后会通过 onPublicStreamDataMessageReceived 回调。

  • true:开启房间用户采集状态回调。
  • false:不开启房间用户采集状态回调。
默认值为false
VolumeIndicationMode
Boolean
false

是否开启音量指示模式。

  • true:开启音量提示。
  • false:不开启音量提示。
默认值为false
StreamPublishStatsMode
Boolean
false

是否开启房间用户发布状态回调。开启后会通过 onPublicStreamDataMessageReceived 回调。

  • true:开启房间用户发布状态回调。
  • false:不开启房间用户发布状态回调。
默认值为false
UserCaptureStatsInterval
Integer
2000
房间用户采集状态回调间隔,仅在纯音频时生效。取值范围为 [1000,2147483647],单位为毫秒,默认值为 2000
VolumeIndicationInterval
Integer
2000
音量指示的回调间隔。最小值为 100,单位为毫秒,默认值为 2000
VideoConfig.FrameRate 大于 10 fps 时,回调间隔才能达到 100ms。
StreamPublishStatsInterval
Integer
2000
房间用户发布状态回调间隔,仅在纯音频时生效。取值范围为 [1000,2147483647],单位为毫秒,默认值为 2000

返回参数

本接口无特有的返回参数。公共返回参数请见返回结构
其中返回值 Result 仅在请求成功时返回 ok,失败时为空。

请求示例

POST https://rtc.volcengineapi.com?Action=StartPushPublicStream&Version=2023-11-01
{
    "AppId": "You****pId",
    "PublicStreamId": "Your_PublicStreamId",
    "TargetStreams": [
        {
            "Index": 1,
            "RoomId": "Your_RoomId",
            "UserId": "a",
            "MediaType": 0,
            "StreamType": 0
        },
        {
            "Index": 2,
            "RoomId": "Your_RoomId",
            "UserId": "b",
            "MediaType": 0,
            "StreamType": 0
        },
        {
            "Index": 3,
            "RoomId": "Your_RoomId",
            "UserId": "c",
            "MediaType": 0,
            "StreamType": 0
        },
        {
            "Index": 4,
            "RoomId": "Your_RoomId",
            "UserId": "d",
            "MediaType": 0,
            "StreamType": 0
        }
    ],
    "Control": {
        "MaxIdleTime": 180
    },
    "Encode": {
        "VideoConfig": {
            "Width": 414,
            "Height": 736,
            "FrameRate": 30
        }
    },
    "Layout": {
        "LayoutMode": 2,
        "CustomLayout": {
            "Regions": [
                {
                    "StreamIndex": 1,
                    "WidthProportion": 0.503,
                    "HeightProportion": 0.335,
                    "LocationX": 0,
                    "LocationY": 0,
                    "RenderMode": 1
                },
                {
                    "StreamIndex": 2,
                    "WidthProportion": 0.503,
                    "HeightProportion": 0.335,
                    "LocationX": 0,
                    "LocationY": 0.33333334,
                    "RenderMode": 1
                },
                {
                    "StreamIndex": 3,
                    "WidthProportion": 0.503,
                    "HeightProportion": 0.335,
                    "LocationX": 0,
                    "LocationY": 0.66666667,
                    "RenderMode": 1
                },
                {
                    "StreamIndex": 4,
                    "WidthProportion": 0.503,
                    "HeightProportion": 0.335,
                    "LocationX": 0.5,
                    "LocationY": 0,
                    "RenderMode": 1
                }
            ]
        }
    }
}

返回示例

{
    "Result": "ok",
    "ResponseMetadata": {
        "RequestId": "20230****10420",
        "Action": "StartPushPublicStream",
        "Version": "2023-11-01",
        "Service": "rtc",
        "Region": "cn-north-1"
    }
}

错误码

您可访问公共错误码,获取更多错误码信息。