@hysc/meeting 4.0.2 → 4.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm/boom-core/src/BoomCore/BCClient/clientEventType.d.ts +11 -8
- package/esm/boom-meeting/src/BMChat/BMChatVM.d.ts +2 -1
- package/esm/boom-meeting/src/BMRoom/BMRoomInfo.d.ts +213 -0
- package/esm/boom-meeting/src/BMRoom/BMRoomVM.d.ts +302 -0
- package/esm/boom-meeting/src/BMRoom/attachEvents.d.ts +9 -2
- package/esm/boom-meeting/src/BMStream/BMStreamModelVM.d.ts +254 -0
- package/esm/boom-meeting/src/BMUser/BMUser.d.ts +12 -3
- package/esm/boom-meeting/src/BMUser/BMUserVM.d.ts +15 -11
- package/esm/boom-meeting/src/bjy-common/function/getErrorMessage.d.ts +1 -0
- package/esm/boom-meeting/src/constants.d.ts +38 -8
- package/esm/boom-meeting/src/error/RTCError.d.ts +20 -0
- package/esm/boom-meeting/src/error/errorType.d.ts +96 -0
- package/esm/boom-meeting/src/handleEvent/attachEvents.d.ts +35 -0
- package/esm/boom-meeting/src/handleEvent/handleParticipantEvent.d.ts +19 -0
- package/esm/boom-meeting/src/handleEvent/handleRoomEvent.d.ts +12 -0
- package/esm/boom-meeting/src/logger/logger.d.ts +86 -0
- package/esm/boom-meeting/src/util/Pqueue.d.ts +61 -0
- package/esm/boom-meeting/src/util/constant.d.ts +67 -0
- package/esm/boom-meeting/src/util/emitter.d.ts +4 -2
- package/esm/index.js +2 -2
- package/esm/index.js.map +3 -3
- package/esm/src/BMChat/BMChatVM.d.ts +25 -25
- package/esm/src/BMChat/BMMessageInfo.d.ts +31 -31
- package/esm/src/BMRoom/BMLiveVM.d.ts +35 -35
- package/esm/src/BMRoom/BMRoomInfo.d.ts +213 -213
- package/esm/src/BMRoom/BMRoomVM.d.ts +302 -302
- package/esm/src/BMRoom/attachEvents.d.ts +34 -34
- package/esm/src/BMStream/BMStreamModelVM.d.ts +254 -254
- package/esm/src/BMUser/BMUser.d.ts +156 -156
- package/esm/src/BMUser/BMUserVM.d.ts +141 -141
- package/esm/src/bjy-common/function/getErrorMessage.d.ts +1 -1
- package/esm/src/constants.d.ts +113 -113
- package/esm/src/error/RTCError.d.ts +20 -20
- package/esm/src/error/errorType.d.ts +96 -96
- package/esm/src/handleEvent/attachEvents.d.ts +35 -0
- package/esm/src/handleEvent/handleParticipantEvent.d.ts +19 -0
- package/esm/src/handleEvent/handleRoomEvent.d.ts +12 -0
- package/esm/src/logger/logger.d.ts +86 -86
- package/esm/src/util/Pqueue.d.ts +61 -61
- package/esm/src/util/constant.d.ts +67 -67
- package/esm/src/util/emitter.d.ts +20 -20
- package/esm/utils/BoomError.d.ts +21 -0
- package/esm/utils/ErrorTypes.d.ts +99 -0
- package/esm/utils/index.d.ts +9 -0
- package/package.json +4 -4
- package/umd/boom-core/src/BoomCore/BCClient/clientEventType.d.ts +11 -8
- package/umd/boom-meeting/src/BMChat/BMChatVM.d.ts +2 -1
- package/umd/boom-meeting/src/BMRoom/BMRoomInfo.d.ts +213 -0
- package/umd/boom-meeting/src/BMRoom/BMRoomVM.d.ts +302 -0
- package/umd/boom-meeting/src/BMRoom/attachEvents.d.ts +9 -2
- package/umd/boom-meeting/src/BMStream/BMStreamModelVM.d.ts +254 -0
- package/umd/boom-meeting/src/BMUser/BMUser.d.ts +12 -3
- package/umd/boom-meeting/src/BMUser/BMUserVM.d.ts +15 -11
- package/umd/boom-meeting/src/bjy-common/function/getErrorMessage.d.ts +1 -0
- package/umd/boom-meeting/src/constants.d.ts +38 -8
- package/umd/boom-meeting/src/error/RTCError.d.ts +20 -0
- package/umd/boom-meeting/src/error/errorType.d.ts +96 -0
- package/umd/boom-meeting/src/handleEvent/attachEvents.d.ts +35 -0
- package/umd/boom-meeting/src/handleEvent/handleParticipantEvent.d.ts +19 -0
- package/umd/boom-meeting/src/handleEvent/handleRoomEvent.d.ts +12 -0
- package/umd/boom-meeting/src/logger/logger.d.ts +86 -0
- package/umd/boom-meeting/src/util/Pqueue.d.ts +61 -0
- package/umd/boom-meeting/src/util/constant.d.ts +67 -0
- package/umd/boom-meeting/src/util/emitter.d.ts +4 -2
- package/umd/index.js +2 -2
- package/umd/utils/BoomError.d.ts +21 -0
- package/umd/utils/ErrorTypes.d.ts +99 -0
- package/umd/utils/index.d.ts +9 -0
|
@@ -1,254 +1,254 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @name: BMStreamModelVM
|
|
3
|
-
* @author: yangliye
|
|
4
|
-
* @date: 2022-04-27 15:25
|
|
5
|
-
* @description:BMStreamModelVM
|
|
6
|
-
* @update: 2022-04-27 15:25
|
|
7
|
-
* @description
|
|
8
|
-
* 这个模块的功能是去管理展示窗口的处理逻辑,主要包括创建streamModel,更新streamModel(主要是流相关信息的更新,和用户更新)
|
|
9
|
-
* 创建streamModel的操作:
|
|
10
|
-
* 初始化整个流程是根据bloud的用户来创建的
|
|
11
|
-
* 然后在根据brtc里面流的信息来更新对应的streamModel
|
|
12
|
-
* bloud的用户和brtc的流信息是根据uid来进行关联。
|
|
13
|
-
*
|
|
14
|
-
* 共享屏幕用户做了特殊处理,因为web端共享屏幕和移动端共享屏幕处理逻辑不一样
|
|
15
|
-
*/
|
|
16
|
-
/// <reference types="node" />
|
|
17
|
-
import BMStreamModel, { NoPlayerContainer } from "./BMStreamModel";
|
|
18
|
-
import BMUser from '../BMUser/BMUser';
|
|
19
|
-
import { SingleLocalStream, SingleRemoteStream, SingleStream } from '../type';
|
|
20
|
-
import BMRoom from '../BMRoom/BMRoom';
|
|
21
|
-
import { BehaviorSubject, Subject } from 'rxjs';
|
|
22
|
-
import { Device } from '@hysc/core/esm/BoomAdapter/type/value';
|
|
23
|
-
import BMSpeaker from './BMSpeaker';
|
|
24
|
-
import { ShareMediaOptions } from "@hysc/core/esm/BoomCore/BCClient/BCClient";
|
|
25
|
-
import { getHTMLMediaStreamOptions, Result, getMediaStreamInfo } from "./getHTMLMediaStreamOptions";
|
|
26
|
-
export declare function transShareScreen2User(userId: string): string;
|
|
27
|
-
export declare const pubFailedStreamMap: Map<string, import("@hysc/core/esm/BoomAdapter/singleMode/stream/RemoteStream").default>;
|
|
28
|
-
/**
|
|
29
|
-
* 全量的brtc流记录,把所有brtc用户推的流都做记录
|
|
30
|
-
* stream-added 的时候添加
|
|
31
|
-
* stream-removed 的时候删除
|
|
32
|
-
* mute/unmute-video/audio 的时候更新流
|
|
33
|
-
* 当用户进来的时候,去查看这个流对象,如果流存在,就给这个人添加流
|
|
34
|
-
*
|
|
35
|
-
*/
|
|
36
|
-
export declare const BRTCStreamMap: Map<string, import("@hysc/core/esm/BoomAdapter/singleMode/stream/RemoteStream").default>;
|
|
37
|
-
export declare const BRTCShareStreamMap: Map<string, import("@hysc/core/esm/BoomAdapter/singleMode/stream/RemoteStream").default>;
|
|
38
|
-
export default class BMStreamModelVM {
|
|
39
|
-
streamModels: Map<string, BMStreamModel>;
|
|
40
|
-
/**
|
|
41
|
-
* 因为投屏码用户进来以后,他是不在小窗口展示的,所以要把投屏的用户过滤掉给业务的展示
|
|
42
|
-
*/
|
|
43
|
-
streamModelsWatcher: BehaviorSubject<BMStreamModel[]>;
|
|
44
|
-
shareStreamModels: Map<string, BMStreamModel>;
|
|
45
|
-
shareStreamModelsWatcher: BehaviorSubject<BMStreamModel[]>;
|
|
46
|
-
localStreamErrorWatcher: Subject<string>;
|
|
47
|
-
localModel: BMStreamModel | null;
|
|
48
|
-
private room;
|
|
49
|
-
bloudStream: any;
|
|
50
|
-
audioStream: SingleLocalStream | undefined;
|
|
51
|
-
brtcStream: SingleLocalStream | undefined;
|
|
52
|
-
/**
|
|
53
|
-
* 本地是否在屏幕共享
|
|
54
|
-
*/
|
|
55
|
-
localIsShare: boolean;
|
|
56
|
-
_speaker_enable: boolean;
|
|
57
|
-
speakerEnableWatcher: BehaviorSubject<boolean>;
|
|
58
|
-
/**
|
|
59
|
-
* 混流
|
|
60
|
-
*/
|
|
61
|
-
mixStreamModelWatcher: BehaviorSubject<BMStreamModel | null>;
|
|
62
|
-
isShareWatcher: Subject<boolean>;
|
|
63
|
-
canvasTimer: NodeJS.Timeout | null;
|
|
64
|
-
/**
|
|
65
|
-
* 后面打开摄像头存储的流,主要是关闭摄像头的时候得把它清除掉
|
|
66
|
-
*/
|
|
67
|
-
videoStream: SingleLocalStream | null;
|
|
68
|
-
private _recorder;
|
|
69
|
-
private _isRecording;
|
|
70
|
-
private _slicingRecord;
|
|
71
|
-
isRecordingWatcher: BehaviorSubject<boolean>;
|
|
72
|
-
private _speaker;
|
|
73
|
-
private _speakerDetector;
|
|
74
|
-
private _speakers;
|
|
75
|
-
speakerWatcher: BehaviorSubject<BMUser | null>;
|
|
76
|
-
/**
|
|
77
|
-
* 窗口没有播放容器的错误处理
|
|
78
|
-
*/
|
|
79
|
-
noContainerWatcher: Subject<BMStreamModel>;
|
|
80
|
-
/**
|
|
81
|
-
* 窗口没有大窗口播放容器的错误处理
|
|
82
|
-
*/
|
|
83
|
-
noBigContainerWatcher: Subject<BMStreamModel>;
|
|
84
|
-
constructor();
|
|
85
|
-
private static filterStreamModels;
|
|
86
|
-
initWithRoom(room: BMRoom): this;
|
|
87
|
-
/**
|
|
88
|
-
* 设置扬声器是否打开
|
|
89
|
-
* @param enable
|
|
90
|
-
* @private
|
|
91
|
-
*/
|
|
92
|
-
private setSpeakerEnable;
|
|
93
|
-
getStreamModels(): Array<BMStreamModel>;
|
|
94
|
-
/**
|
|
95
|
-
* 获取streamModel
|
|
96
|
-
* @param userId 用户Id
|
|
97
|
-
* @returns
|
|
98
|
-
*/
|
|
99
|
-
getStreamModelByUId(userId: string): BMStreamModel | undefined;
|
|
100
|
-
getShareStreamModelByUId(userId: string): BMStreamModel | undefined;
|
|
101
|
-
getLocalStreamModel(): BMStreamModel | null;
|
|
102
|
-
createStreamModel(user: BMUser, stream?: SingleStream): BMStreamModel;
|
|
103
|
-
addStreamModel(streamModel: BMStreamModel): void;
|
|
104
|
-
addShareStreamModel(streamModel: BMStreamModel): void;
|
|
105
|
-
removeStreamModel(streamModel: BMStreamModel): void;
|
|
106
|
-
removeShareStreamModel(streamModel: BMStreamModel): void;
|
|
107
|
-
/**`
|
|
108
|
-
* 通过用户id删除streamModel
|
|
109
|
-
* @param userId
|
|
110
|
-
* @returns
|
|
111
|
-
*/
|
|
112
|
-
removeStreamModelByUId(userId: string): BMStreamModel | undefined;
|
|
113
|
-
remoteStreamPublished(stream: SingleRemoteStream): void;
|
|
114
|
-
/**
|
|
115
|
-
* 有人取消流触发,有人取消流之后brtc底层会把流销毁掉,除了流Id和userId,其他的信息都不稳定能取到
|
|
116
|
-
* @param stream
|
|
117
|
-
* @returns
|
|
118
|
-
*/
|
|
119
|
-
remoteStreamUnpublished(stream: SingleRemoteStream): BMStreamModel | undefined;
|
|
120
|
-
sortStreamModels(): BMStreamModel[];
|
|
121
|
-
updateStreamModel(streamModel: BMStreamModel, stream: SingleStream): void;
|
|
122
|
-
updateShareStreamModel(streamModel: BMStreamModel, stream: SingleStream): void;
|
|
123
|
-
/**
|
|
124
|
-
* 开关本地摄像头
|
|
125
|
-
* @param status true:开,false:关
|
|
126
|
-
* @param videoTrack 开启美颜之后,需要传递这个参数,携带美颜之后的videoTrack
|
|
127
|
-
*/
|
|
128
|
-
setLocalVideoEnable(status: boolean, videoTrack?: MediaStreamTrack): Promise<void>;
|
|
129
|
-
/**
|
|
130
|
-
* 开关本地麦克风
|
|
131
|
-
* @param status true:开,false:关
|
|
132
|
-
*/
|
|
133
|
-
setLocalAudioEnable(status: boolean): Promise<undefined>;
|
|
134
|
-
/**
|
|
135
|
-
* 该方法只是在入会的时候,同时开启音频和视频的时候使用,其他时候禁止使用该方法
|
|
136
|
-
* 切换音频和视频状态请使用 setLocalAudioEnable 和 setLocalVideoEnable
|
|
137
|
-
* @param audio
|
|
138
|
-
* @param video
|
|
139
|
-
*/
|
|
140
|
-
joinWithAudioAndAudio(audio: boolean, video: boolean): Promise<undefined>;
|
|
141
|
-
/**
|
|
142
|
-
* 切换扬声器
|
|
143
|
-
* @param device
|
|
144
|
-
*/
|
|
145
|
-
changeSpeaker(device: Device): Promise<void>;
|
|
146
|
-
/**
|
|
147
|
-
* 设置单个流的扬声器
|
|
148
|
-
* @param streamModel
|
|
149
|
-
*/
|
|
150
|
-
changeSingleStreamSpeaker(streamModel: BMStreamModel): Promise<void>;
|
|
151
|
-
changeAudioInput(device: Device): Promise<void>;
|
|
152
|
-
changeVideoInput(device: Device): Promise<void>;
|
|
153
|
-
/**
|
|
154
|
-
* 是否静音扬声器
|
|
155
|
-
* @param enable
|
|
156
|
-
*/
|
|
157
|
-
muteSpeaker(enable: boolean): Promise<undefined>;
|
|
158
|
-
/**
|
|
159
|
-
* 创建流并且发布
|
|
160
|
-
* @param audio 是否发布音频流
|
|
161
|
-
* @param video 是否发布视频流
|
|
162
|
-
* @param localModel 本地的streamModel
|
|
163
|
-
* @param videoTrack
|
|
164
|
-
* @private
|
|
165
|
-
*/
|
|
166
|
-
private createStreamAndPublish;
|
|
167
|
-
muteHandler(type: 'video' | 'audio'): Promise<void>;
|
|
168
|
-
/**
|
|
169
|
-
* 更改音视频状态或者取消发布
|
|
170
|
-
* @param type 更改类型
|
|
171
|
-
* @param mute 是否取消发布
|
|
172
|
-
* @param localModel 本地的streamModel
|
|
173
|
-
* @private
|
|
174
|
-
*/
|
|
175
|
-
private muteOrUnpublishStream;
|
|
176
|
-
/**
|
|
177
|
-
* 是否开启屏幕共享
|
|
178
|
-
* @param enable
|
|
179
|
-
* @param opts 开启屏幕共享参数
|
|
180
|
-
* @param customShare
|
|
181
|
-
* @param opts.audio 是否开启音频
|
|
182
|
-
* @param opts.source_name Electron 下窗口名称
|
|
183
|
-
* @param opts.width 共享屏幕宽度
|
|
184
|
-
* @param opts.height 共享屏幕高度
|
|
185
|
-
* @param opts.contentHint 视频的contentHint 可选值: '' | 'motion' | 'detail' | 'text'
|
|
186
|
-
*/
|
|
187
|
-
toggleShareScreen(enable: boolean, opts: any, customShare?: Result): Promise<
|
|
188
|
-
setShareScreenContentHint(contentHint: '' | 'motion' | 'detail' | 'text'): Promise<void>;
|
|
189
|
-
/**
|
|
190
|
-
* 排序变化之后的处理逻辑
|
|
191
|
-
*/
|
|
192
|
-
updateUserSort:
|
|
193
|
-
updateModelSort:
|
|
194
|
-
handleNoContainer: (info: NoPlayerContainer) => void;
|
|
195
|
-
/**
|
|
196
|
-
* 创建canvas,目的是为了捕获空track流,给brtc使用
|
|
197
|
-
*/
|
|
198
|
-
createCanvas(): void;
|
|
199
|
-
private canvasDisplay;
|
|
200
|
-
private static getCanvasStream;
|
|
201
|
-
private createVideoStream;
|
|
202
|
-
/**
|
|
203
|
-
* 启动录制
|
|
204
|
-
* @param {String} opts.filename - 录制文件名
|
|
205
|
-
* @param {Object} opts.capture - 采集属性
|
|
206
|
-
* @param {Number} opts.capture.width - 宽度
|
|
207
|
-
* @param {Number} opts.capture.height - 高度
|
|
208
|
-
* @param {Number} opts.capture.fps - 帧率
|
|
209
|
-
* @param {Number} opts.record - 编码属性
|
|
210
|
-
* @param {Number} opts.record.bitrate - 编码码率
|
|
211
|
-
* @param {String|undefined} opts.record.format - 编码格式
|
|
212
|
-
* @return {boolean}
|
|
213
|
-
*/
|
|
214
|
-
startRecord(opts: any): Promise<boolean | undefined>;
|
|
215
|
-
/**
|
|
216
|
-
* 添加流对象到录制器,用于音频轨道录制
|
|
217
|
-
* @param stream
|
|
218
|
-
*/
|
|
219
|
-
addToRecorder(stream: any): void;
|
|
220
|
-
/**
|
|
221
|
-
* 从录制器中删除流对象
|
|
222
|
-
* @param stream
|
|
223
|
-
*/
|
|
224
|
-
removeFromRecorder(stream: any): void;
|
|
225
|
-
/**
|
|
226
|
-
* 停止录制
|
|
227
|
-
*/
|
|
228
|
-
stopRecord(): Promise<void>;
|
|
229
|
-
/**
|
|
230
|
-
* 启用下一个录制分片
|
|
231
|
-
* @param filename - 下一分片文件名
|
|
232
|
-
*/
|
|
233
|
-
sliceRecord(filename: string): Promise<boolean | undefined>;
|
|
234
|
-
/**
|
|
235
|
-
* 启动说话人检测器
|
|
236
|
-
*/
|
|
237
|
-
startSpeakerDetector(): void;
|
|
238
|
-
addToDetector(speaker: BMSpeaker): void;
|
|
239
|
-
removeFromDetector(speakerId: string): void;
|
|
240
|
-
shareCustomMedia(enable: boolean, shareOptions: ShareMediaOptions): Promise<undefined>;
|
|
241
|
-
/**
|
|
242
|
-
* 根据videoElement 获取内部流数据
|
|
243
|
-
*/
|
|
244
|
-
getHTMLMediaStream: typeof getHTMLMediaStreamOptions;
|
|
245
|
-
getMediaStream: typeof getMediaStreamInfo;
|
|
246
|
-
/**
|
|
247
|
-
* brtc断网重连之后,不知道在断网期间有那些用户取消了推流,
|
|
248
|
-
* 然后如果是brtc的ws没重连上,然后自己走的重新入会重连的话,就会导致
|
|
249
|
-
* 可能存在本地的流有一部分可能是不存在的流了,这个方法就是在重连入会之后
|
|
250
|
-
* 把所有远端流清空
|
|
251
|
-
*/
|
|
252
|
-
resetAllRemoteStream(): void;
|
|
253
|
-
clearCache(): void;
|
|
254
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* @name: BMStreamModelVM
|
|
3
|
+
* @author: yangliye
|
|
4
|
+
* @date: 2022-04-27 15:25
|
|
5
|
+
* @description:BMStreamModelVM
|
|
6
|
+
* @update: 2022-04-27 15:25
|
|
7
|
+
* @description
|
|
8
|
+
* 这个模块的功能是去管理展示窗口的处理逻辑,主要包括创建streamModel,更新streamModel(主要是流相关信息的更新,和用户更新)
|
|
9
|
+
* 创建streamModel的操作:
|
|
10
|
+
* 初始化整个流程是根据bloud的用户来创建的
|
|
11
|
+
* 然后在根据brtc里面流的信息来更新对应的streamModel
|
|
12
|
+
* bloud的用户和brtc的流信息是根据uid来进行关联。
|
|
13
|
+
*
|
|
14
|
+
* 共享屏幕用户做了特殊处理,因为web端共享屏幕和移动端共享屏幕处理逻辑不一样
|
|
15
|
+
*/
|
|
16
|
+
/// <reference types="node" />
|
|
17
|
+
import BMStreamModel, { NoPlayerContainer } from "./BMStreamModel";
|
|
18
|
+
import BMUser from '../BMUser/BMUser';
|
|
19
|
+
import { SingleLocalStream, SingleRemoteStream, SingleStream } from '../type';
|
|
20
|
+
import BMRoom from '../BMRoom/BMRoom';
|
|
21
|
+
import { BehaviorSubject, Subject } from 'rxjs';
|
|
22
|
+
import { Device } from '@hysc/core/esm/BoomAdapter/type/value';
|
|
23
|
+
import BMSpeaker from './BMSpeaker';
|
|
24
|
+
import { ShareMediaOptions } from "@hysc/core/esm/BoomCore/BCClient/BCClient";
|
|
25
|
+
import { getHTMLMediaStreamOptions, Result, getMediaStreamInfo } from "./getHTMLMediaStreamOptions";
|
|
26
|
+
export declare function transShareScreen2User(userId: string): string;
|
|
27
|
+
export declare const pubFailedStreamMap: Map<string, import("@hysc/core/esm/BoomAdapter/singleMode/stream/RemoteStream").default>;
|
|
28
|
+
/**
|
|
29
|
+
* 全量的brtc流记录,把所有brtc用户推的流都做记录
|
|
30
|
+
* stream-added 的时候添加
|
|
31
|
+
* stream-removed 的时候删除
|
|
32
|
+
* mute/unmute-video/audio 的时候更新流
|
|
33
|
+
* 当用户进来的时候,去查看这个流对象,如果流存在,就给这个人添加流
|
|
34
|
+
*
|
|
35
|
+
*/
|
|
36
|
+
export declare const BRTCStreamMap: Map<string, import("@hysc/core/esm/BoomAdapter/singleMode/stream/RemoteStream").default>;
|
|
37
|
+
export declare const BRTCShareStreamMap: Map<string, import("@hysc/core/esm/BoomAdapter/singleMode/stream/RemoteStream").default>;
|
|
38
|
+
export default class BMStreamModelVM {
|
|
39
|
+
streamModels: Map<string, BMStreamModel>;
|
|
40
|
+
/**
|
|
41
|
+
* 因为投屏码用户进来以后,他是不在小窗口展示的,所以要把投屏的用户过滤掉给业务的展示
|
|
42
|
+
*/
|
|
43
|
+
streamModelsWatcher: BehaviorSubject<BMStreamModel[]>;
|
|
44
|
+
shareStreamModels: Map<string, BMStreamModel>;
|
|
45
|
+
shareStreamModelsWatcher: BehaviorSubject<BMStreamModel[]>;
|
|
46
|
+
localStreamErrorWatcher: Subject<string>;
|
|
47
|
+
localModel: BMStreamModel | null;
|
|
48
|
+
private room;
|
|
49
|
+
bloudStream: any;
|
|
50
|
+
audioStream: SingleLocalStream | undefined;
|
|
51
|
+
brtcStream: SingleLocalStream | undefined;
|
|
52
|
+
/**
|
|
53
|
+
* 本地是否在屏幕共享
|
|
54
|
+
*/
|
|
55
|
+
localIsShare: boolean;
|
|
56
|
+
_speaker_enable: boolean;
|
|
57
|
+
speakerEnableWatcher: BehaviorSubject<boolean>;
|
|
58
|
+
/**
|
|
59
|
+
* 混流
|
|
60
|
+
*/
|
|
61
|
+
mixStreamModelWatcher: BehaviorSubject<BMStreamModel | null>;
|
|
62
|
+
isShareWatcher: Subject<boolean>;
|
|
63
|
+
canvasTimer: NodeJS.Timeout | null;
|
|
64
|
+
/**
|
|
65
|
+
* 后面打开摄像头存储的流,主要是关闭摄像头的时候得把它清除掉
|
|
66
|
+
*/
|
|
67
|
+
videoStream: SingleLocalStream | null;
|
|
68
|
+
private _recorder;
|
|
69
|
+
private _isRecording;
|
|
70
|
+
private _slicingRecord;
|
|
71
|
+
isRecordingWatcher: BehaviorSubject<boolean>;
|
|
72
|
+
private _speaker;
|
|
73
|
+
private _speakerDetector;
|
|
74
|
+
private _speakers;
|
|
75
|
+
speakerWatcher: BehaviorSubject<BMUser | null>;
|
|
76
|
+
/**
|
|
77
|
+
* 窗口没有播放容器的错误处理
|
|
78
|
+
*/
|
|
79
|
+
noContainerWatcher: Subject<BMStreamModel>;
|
|
80
|
+
/**
|
|
81
|
+
* 窗口没有大窗口播放容器的错误处理
|
|
82
|
+
*/
|
|
83
|
+
noBigContainerWatcher: Subject<BMStreamModel>;
|
|
84
|
+
constructor();
|
|
85
|
+
private static filterStreamModels;
|
|
86
|
+
initWithRoom(room: BMRoom): this;
|
|
87
|
+
/**
|
|
88
|
+
* 设置扬声器是否打开
|
|
89
|
+
* @param enable
|
|
90
|
+
* @private
|
|
91
|
+
*/
|
|
92
|
+
private setSpeakerEnable;
|
|
93
|
+
getStreamModels(): Array<BMStreamModel>;
|
|
94
|
+
/**
|
|
95
|
+
* 获取streamModel
|
|
96
|
+
* @param userId 用户Id
|
|
97
|
+
* @returns
|
|
98
|
+
*/
|
|
99
|
+
getStreamModelByUId(userId: string): BMStreamModel | undefined;
|
|
100
|
+
getShareStreamModelByUId(userId: string): BMStreamModel | undefined;
|
|
101
|
+
getLocalStreamModel(): BMStreamModel | null;
|
|
102
|
+
createStreamModel(user: BMUser, stream?: SingleStream): BMStreamModel;
|
|
103
|
+
addStreamModel(streamModel: BMStreamModel): void;
|
|
104
|
+
addShareStreamModel(streamModel: BMStreamModel): void;
|
|
105
|
+
removeStreamModel(streamModel: BMStreamModel): void;
|
|
106
|
+
removeShareStreamModel(streamModel: BMStreamModel): void;
|
|
107
|
+
/**`
|
|
108
|
+
* 通过用户id删除streamModel
|
|
109
|
+
* @param userId
|
|
110
|
+
* @returns
|
|
111
|
+
*/
|
|
112
|
+
removeStreamModelByUId(userId: string): BMStreamModel | undefined;
|
|
113
|
+
remoteStreamPublished(stream: SingleRemoteStream): void;
|
|
114
|
+
/**
|
|
115
|
+
* 有人取消流触发,有人取消流之后brtc底层会把流销毁掉,除了流Id和userId,其他的信息都不稳定能取到
|
|
116
|
+
* @param stream
|
|
117
|
+
* @returns
|
|
118
|
+
*/
|
|
119
|
+
remoteStreamUnpublished(stream: SingleRemoteStream): BMStreamModel | undefined;
|
|
120
|
+
sortStreamModels(): BMStreamModel[];
|
|
121
|
+
updateStreamModel(streamModel: BMStreamModel, stream: SingleStream): void;
|
|
122
|
+
updateShareStreamModel(streamModel: BMStreamModel, stream: SingleStream): void;
|
|
123
|
+
/**
|
|
124
|
+
* 开关本地摄像头
|
|
125
|
+
* @param status true:开,false:关
|
|
126
|
+
* @param videoTrack 开启美颜之后,需要传递这个参数,携带美颜之后的videoTrack
|
|
127
|
+
*/
|
|
128
|
+
setLocalVideoEnable(status: boolean, videoTrack?: MediaStreamTrack): Promise<void>;
|
|
129
|
+
/**
|
|
130
|
+
* 开关本地麦克风
|
|
131
|
+
* @param status true:开,false:关
|
|
132
|
+
*/
|
|
133
|
+
setLocalAudioEnable(status: boolean): Promise<undefined>;
|
|
134
|
+
/**
|
|
135
|
+
* 该方法只是在入会的时候,同时开启音频和视频的时候使用,其他时候禁止使用该方法
|
|
136
|
+
* 切换音频和视频状态请使用 setLocalAudioEnable 和 setLocalVideoEnable
|
|
137
|
+
* @param audio
|
|
138
|
+
* @param video
|
|
139
|
+
*/
|
|
140
|
+
joinWithAudioAndAudio(audio: boolean, video: boolean): Promise<undefined>;
|
|
141
|
+
/**
|
|
142
|
+
* 切换扬声器
|
|
143
|
+
* @param device
|
|
144
|
+
*/
|
|
145
|
+
changeSpeaker(device: Device): Promise<void>;
|
|
146
|
+
/**
|
|
147
|
+
* 设置单个流的扬声器
|
|
148
|
+
* @param streamModel
|
|
149
|
+
*/
|
|
150
|
+
changeSingleStreamSpeaker(streamModel: BMStreamModel): Promise<void>;
|
|
151
|
+
changeAudioInput(device: Device): Promise<void>;
|
|
152
|
+
changeVideoInput(device: Device): Promise<void>;
|
|
153
|
+
/**
|
|
154
|
+
* 是否静音扬声器
|
|
155
|
+
* @param enable
|
|
156
|
+
*/
|
|
157
|
+
muteSpeaker(enable: boolean): Promise<undefined>;
|
|
158
|
+
/**
|
|
159
|
+
* 创建流并且发布
|
|
160
|
+
* @param audio 是否发布音频流
|
|
161
|
+
* @param video 是否发布视频流
|
|
162
|
+
* @param localModel 本地的streamModel
|
|
163
|
+
* @param videoTrack
|
|
164
|
+
* @private
|
|
165
|
+
*/
|
|
166
|
+
private createStreamAndPublish;
|
|
167
|
+
muteHandler(type: 'video' | 'audio'): Promise<void>;
|
|
168
|
+
/**
|
|
169
|
+
* 更改音视频状态或者取消发布
|
|
170
|
+
* @param type 更改类型
|
|
171
|
+
* @param mute 是否取消发布
|
|
172
|
+
* @param localModel 本地的streamModel
|
|
173
|
+
* @private
|
|
174
|
+
*/
|
|
175
|
+
private muteOrUnpublishStream;
|
|
176
|
+
/**
|
|
177
|
+
* 是否开启屏幕共享
|
|
178
|
+
* @param enable
|
|
179
|
+
* @param opts 开启屏幕共享参数
|
|
180
|
+
* @param customShare
|
|
181
|
+
* @param opts.audio 是否开启音频
|
|
182
|
+
* @param opts.source_name Electron 下窗口名称
|
|
183
|
+
* @param opts.width 共享屏幕宽度
|
|
184
|
+
* @param opts.height 共享屏幕高度
|
|
185
|
+
* @param opts.contentHint 视频的contentHint 可选值: '' | 'motion' | 'detail' | 'text'
|
|
186
|
+
*/
|
|
187
|
+
toggleShareScreen(enable: boolean, opts: any, customShare?: Result): Promise<boolean>;
|
|
188
|
+
setShareScreenContentHint(contentHint: '' | 'motion' | 'detail' | 'text'): Promise<void>;
|
|
189
|
+
/**
|
|
190
|
+
* 排序变化之后的处理逻辑
|
|
191
|
+
*/
|
|
192
|
+
updateUserSort: import("lodash-es").DebouncedFunc<() => void>;
|
|
193
|
+
updateModelSort: import("lodash-es").DebouncedFunc<() => void>;
|
|
194
|
+
handleNoContainer: (info: NoPlayerContainer) => void;
|
|
195
|
+
/**
|
|
196
|
+
* 创建canvas,目的是为了捕获空track流,给brtc使用
|
|
197
|
+
*/
|
|
198
|
+
createCanvas(): void;
|
|
199
|
+
private canvasDisplay;
|
|
200
|
+
private static getCanvasStream;
|
|
201
|
+
private createVideoStream;
|
|
202
|
+
/**
|
|
203
|
+
* 启动录制
|
|
204
|
+
* @param {String} opts.filename - 录制文件名
|
|
205
|
+
* @param {Object} opts.capture - 采集属性
|
|
206
|
+
* @param {Number} opts.capture.width - 宽度
|
|
207
|
+
* @param {Number} opts.capture.height - 高度
|
|
208
|
+
* @param {Number} opts.capture.fps - 帧率
|
|
209
|
+
* @param {Number} opts.record - 编码属性
|
|
210
|
+
* @param {Number} opts.record.bitrate - 编码码率
|
|
211
|
+
* @param {String|undefined} opts.record.format - 编码格式
|
|
212
|
+
* @return {boolean}
|
|
213
|
+
*/
|
|
214
|
+
startRecord(opts: any): Promise<boolean | undefined>;
|
|
215
|
+
/**
|
|
216
|
+
* 添加流对象到录制器,用于音频轨道录制
|
|
217
|
+
* @param stream
|
|
218
|
+
*/
|
|
219
|
+
addToRecorder(stream: any): void;
|
|
220
|
+
/**
|
|
221
|
+
* 从录制器中删除流对象
|
|
222
|
+
* @param stream
|
|
223
|
+
*/
|
|
224
|
+
removeFromRecorder(stream: any): void;
|
|
225
|
+
/**
|
|
226
|
+
* 停止录制
|
|
227
|
+
*/
|
|
228
|
+
stopRecord(): Promise<void>;
|
|
229
|
+
/**
|
|
230
|
+
* 启用下一个录制分片
|
|
231
|
+
* @param filename - 下一分片文件名
|
|
232
|
+
*/
|
|
233
|
+
sliceRecord(filename: string): Promise<boolean | undefined>;
|
|
234
|
+
/**
|
|
235
|
+
* 启动说话人检测器
|
|
236
|
+
*/
|
|
237
|
+
startSpeakerDetector(): void;
|
|
238
|
+
addToDetector(speaker: BMSpeaker): void;
|
|
239
|
+
removeFromDetector(speakerId: string): void;
|
|
240
|
+
shareCustomMedia(enable: boolean, shareOptions: ShareMediaOptions): Promise<undefined>;
|
|
241
|
+
/**
|
|
242
|
+
* 根据videoElement 获取内部流数据
|
|
243
|
+
*/
|
|
244
|
+
getHTMLMediaStream: typeof getHTMLMediaStreamOptions;
|
|
245
|
+
getMediaStream: typeof getMediaStreamInfo;
|
|
246
|
+
/**
|
|
247
|
+
* brtc断网重连之后,不知道在断网期间有那些用户取消了推流,
|
|
248
|
+
* 然后如果是brtc的ws没重连上,然后自己走的重新入会重连的话,就会导致
|
|
249
|
+
* 可能存在本地的流有一部分可能是不存在的流了,这个方法就是在重连入会之后
|
|
250
|
+
* 把所有远端流清空
|
|
251
|
+
*/
|
|
252
|
+
resetAllRemoteStream(): void;
|
|
253
|
+
clearCache(): void;
|
|
254
|
+
}
|