title: WilddogVideoRoom
wilddogVideo
是 WilddogVideoRoom SDK 的主入口,不能直接创建 WilddogVideoRoom 实例,必须要通过 wilddogVideo.room(roomId)
方式获取。
WilddogVideoRoom 表示一个多人的视频会话,多个用户可以加入同一个 Room 进行音视频通话。
属性
roomId
定义
var roomInstance = wilddogVideo.room(roomId)
说明
Room 的唯一标识。
方法
connect
定义
roomInstance.connect();
说明
加入 Room。
disconnect
定义
roomInstance.disconnect();
说明
离开 Room。
publish
定义
roomInstance.publish(localStream,function(error){
if(error == null){
console.log('publish success');
localStream.attach(localEl);
}
});
说明
发布本地媒体流。发布成功后会触发其他客户端的 stream_added
事件。
参数
参数名 | 说明 |
---|---|
localStream | 本地媒体流。LocalStream |
unpublish
定义
roomInstance.unpublish(roomStream,function (error) {
if(error == null){
console.log('unpublish success');
}
})
说明
取消发布本地媒体流。取消发布成功会触发其他客户端的 stream_removed
事件。
参数
参数名 | 说明 |
---|---|
roomStream | 远端媒体流。 RoomStream |
subscribe
定义
roomInstance.subscribe(roomStream,function (error) {
if(error == null){
console.log('subscribe success');
}
})
说明
订阅在 stream_added
事件中获取的远端媒体流。订阅成功会触发本地的 stream_received
事件。
参数
参数名 | 说明 |
---|---|
roomStream | 远端媒体流 RoomStream |
unsubscribe
定义
roomInstance.unsubscribe(roomStream,function (error) {
if(error == null){
console.log('unsubscribe success');
}
})
说明
取消订阅指定的远端媒体流。
参数
参数名 | 说明 |
---|---|
roomStream | 远端媒体流 RoomStream |
startRecording()
定义
roomInstance.startRecording(callback);
说明
使用默认录制布局并且开始服务端录制功能。
startRecording(options)
说明
设置录制布局并且开始服务端录制功能。
定义
roomInstance.startRecording(options,callback) ;
参数
选项 | 类型 | 说明 | 示例 |
---|---|---|---|
fps | number | 视频帧率 (fps) | 15 |
bitrate | number | 比特率 (bps) | 300 |
canvasWidth | number | 视频宽度 (<=1920) | 960 |
canvasHeight | number | 视频高度 (<=1080) | 640 |
bgColor | number | 背景颜色 (十六进制) | 0xffffff |
streams | Object | 媒体流布局 | { “627620748239984100”: {“left”: 0 , “top”: 100, “width”: 300, “height”: 300, “zOrder”: 0-255} |
对于每路需要录制的流的参数配置:
选项 | 类型 | 说明 | 示例 |
---|---|---|---|
streamId | string | 流ID,在一个room中,每一路流都有一个唯一流ID | 627620748239984100 |
left | number | 此路视频流相对左侧坐标 | 0 |
top | number | 此路视频流相对顶部坐标 | 0 |
width | number | 此路视频宽度 | 100 |
height | number | 此路视频高度 | 150 |
zOrder | number | 图像叠放层次顺序,高层次将遮挡低层次图像。该值越小,则叠放层次越低,该值越大,则叠放层次越高,从小到大绘制(0-255) | 8 |
示例
var options = {
"fps":10,
"canvasWidth":1000,
"canvasHeight":1000,
"streams": {
"627620748239984100":{"left":0,"top":100,"width":300,"height":300,"zOrder":1},
"627620748239984101":{"left":0,"top":100,"width":300,"height":300,"zOrder":2}
}
}
//其中"627620748239984100","627620748239984101"为具体的streamId,可以从localStream和roomStream对象中获取
roomInstance.startRecording(options,function(url,error) {
if (error == null) {
console.log(url)
}
}) ;
stopRecording
定义
room.stopRecording(callback);
说明
结束服务端录制功能。
事件
WilddogVideoRoom 事件用于监听 Room 连接状态以及媒体流变化。
事件类型 | 事件 | 说明 |
---|---|---|
连接事件 | connected | 成功连接到 Room。 |
连接事件 | disconnected | 断开到 Room 的连接。 |
媒体流事件 | stream_added | 有远端流加入到 Room,此时的RoomStream 中不包含真正的媒体流,需要使用 subscribe 方法进行订阅方可获取真正的媒体流。 |
媒体流事件 | stream_removed | 有远端流停止发布。 |
媒体流事件 | stream_received | 成功订阅远端流,此时获取到真正的媒体流对象,可以进行播放。 |
错误事件 | error | 错误事件。 |
connected
示例
roomInstance.on('connected',function(){
console.log('connected success');
})
disconnected
示例
roomInstance.on('disconnected',function(){
console.log('disconnected success');
})
stream_added
参数
参数名 | 说明 |
---|---|
roomStream | RoomStream 类型远端参与者发送的媒体流 |
示例
roomInstance.on('stream_added',function(roomStream){
console.log('rommStream added' + roomStream);
})
stream_removed
参数
参数名 | 说明 |
---|---|
roomStream | RoomStream 类型远端参与者发送的媒体流 |
示例
roomInstance.on('stream_removed',function(roomStream){
console.log('rommStream removed' + roomStream);
})
stream_received
参数
参数名 | 说明 |
---|---|
roomStream | RoomStream 类型远端参与者发送的媒体流 |
示例
roomInstance.on('stream_received',function(roomStream){
console.log('rommStream received' + roomStream);
})
error
示例
//错误信息回调
roomInstance.on('error',function(error){
console.log('error is' + error);
})