IEMConferenceManager.h 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158
  1. /*!
  2. * \~chinese
  3. * @header IEMConferenceManager.h
  4. * @abstract 此协议定义了多人实时音频/视频通话相关操作
  5. * @author Hyphenate
  6. * @version 3.00
  7. *
  8. * \~english
  9. * @header IEMConferenceManager.h
  10. * @abstract This protocol defines a multiplayer real-time audio / video call related operation
  11. * @author Hyphenate
  12. * @version 3.00
  13. */
  14. #ifndef IEMConferenceManager_h
  15. #define IEMConferenceManager_h
  16. #import <Foundation/Foundation.h>
  17. #import <AVFoundation/AVFoundation.h>
  18. #import "EMCallConference.h"
  19. #import "EMConferenceManagerDelegate.h"
  20. #import "EMCallVideoView.h"
  21. #import "EMWaterMarkOption.h"
  22. #import "EMWhiteboard.h"
  23. /*!
  24. * \~chinese
  25. * 加入房间时使用的配置信息
  26. *
  27. * \~english
  28. * The configuration used while join the room
  29. */
  30. @interface RoomConfig:NSObject
  31. /*!
  32. * \~chinese
  33. * 会议类型
  34. *
  35. * \~english
  36. * The type of conference
  37. */
  38. @property (nonatomic) EMConferenceType confrType;
  39. /*!
  40. * \~chinese
  41. * 录制时是否合并数据流
  42. *
  43. * \~english
  44. * Whether to merge data streams while recording
  45. */
  46. @property (nonatomic) BOOL isMerge;
  47. /*!
  48. * \~chinese
  49. * 是否开启服务端录制
  50. *
  51. * \~english
  52. * Whether to record data streams
  53. */
  54. @property (nonatomic) BOOL isRecord;
  55. /*!
  56. * \~chinese
  57. * 是否支持微信小程序
  58. *
  59. * \~english
  60. * Weather to support wechat mini program
  61. */
  62. @property (nonatomic) BOOL isSupportWechatMiniProgram;
  63. /*!
  64. * \~chinese
  65. * 会议中使用的昵称
  66. *
  67. * \~english
  68. * The nickName userd in conference
  69. */
  70. @property (nonatomic) NSString* nickName;
  71. /*!
  72. * \~chinese
  73. * 成员扩展信息
  74. *
  75. * \~english
  76. * The extension info of member
  77. */
  78. @property (nonatomic) NSString* ext;
  79. /*!
  80. * \~chinese
  81. * 会议最大主播数
  82. *
  83. * \~english
  84. * The limit count of talkers
  85. */
  86. @property (nonatomic) NSInteger maxTalkerCount ;
  87. /*!
  88. * \~chinese
  89. * 会议最大视频上传数
  90. *
  91. * \~english
  92. * The limit count of video streams
  93. */
  94. @property (nonatomic) NSInteger maxVideoCount;
  95. /*!
  96. * \~chinese
  97. * 会议最大观众数
  98. *
  99. * \~english
  100. * The limit count of audience
  101. */
  102. @property (nonatomic) NSInteger maxAudienceCount;
  103. @end
  104. @class EMError;
  105. /*!
  106. * \~chinese
  107. * 多人会议场景
  108. *
  109. * \~english
  110. * Conference mode
  111. */
  112. typedef enum {
  113. EMConferenceModeNormal = 0, /*! \~chinese 人数较少 \~english A small number of people for video conferencing */
  114. EMConferenceModeLarge, /*! \~chinese 人数较多 \~english A large number of people for video conferencing */
  115. } EMConferenceMode EM_DEPRECATED_IOS(3_1_0, 3_4_3, "Use -DELETE");
  116. /*!
  117. * \~chinese
  118. * 多人实时音频/视频通话相关操作
  119. *
  120. * \~english
  121. * Multi-user real-time audio / video call related operations
  122. */
  123. @protocol IEMConferenceManager <NSObject>
  124. @optional
  125. #pragma mark - Delegate
  126. /*!
  127. * \~chinese
  128. * 添加回调代理
  129. *
  130. * @param aDelegate 要添加的代理
  131. * @param aQueue 执行代理方法的队列
  132. *
  133. * \~english
  134. * Add delegate
  135. *
  136. * @param aDelegate Delegate
  137. * @param aQueue The queue of call delegate method
  138. */
  139. - (void)addDelegate:(id<EMConferenceManagerDelegate>)aDelegate
  140. delegateQueue:(dispatch_queue_t)aQueue;
  141. /*!
  142. * \~chinese
  143. * 移除回调代理
  144. *
  145. * @param aDelegate 要移除的代理
  146. *
  147. * \~english
  148. * Remove delegate
  149. *
  150. * @param aDelegate Delegate
  151. */
  152. - (void)removeDelegate:(id<EMConferenceManagerDelegate>)aDelegate;
  153. #pragma mark - Conference
  154. /*!
  155. * \~chinese
  156. * 设置应用Appkey, 环信ID, 环信ID对应的Token
  157. *
  158. * @param aAppkey 应用在环信注册的Appkey
  159. * @param aUserName 环信ID
  160. * @param aToken 环信ID对应的Token
  161. *
  162. * \~english
  163. * Setup MemberName
  164. *
  165. * @param aAppkey AppKey in Hyphenate
  166. * @param aUserName The Hyphenate ID
  167. * @param aToken The token of Hyphenate ID
  168. */
  169. - (void)setAppkey:(NSString *)aAppkey
  170. username:(NSString *)aUsername
  171. token:(NSString *)aToken;
  172. /*!
  173. * \~chinese
  174. * 构建MemberName
  175. *
  176. * @param aAppkey 应用在环信注册的Appkey
  177. * @param aUserName 环信ID
  178. *
  179. * @result MemberName
  180. *
  181. * \~english
  182. * Setup MemberName
  183. *
  184. * @param aAppkey AppKey in Hyphenate
  185. * @param aUserName The Hyphenate ID
  186. *
  187. * @result MemberName
  188. */
  189. - (NSString *)getMemberNameWithAppkey:(NSString *)aAppkey
  190. username:(NSString *)aUserName;
  191. /*!
  192. * \~chinese
  193. * 判断会议是否存在
  194. *
  195. * @param aConfId 会议ID(EMCallConference.confId)
  196. * @param aPassword 会议密码
  197. * @param aCompletionBlock 完成的回调
  198. *
  199. * \~english
  200. * Determine if the conference exists
  201. *
  202. * @param aConfId Conference ID (EMCallConference.confId)
  203. * @param aPassword The password of the conference
  204. * @param aCompletionBlock The callback block of completion
  205. */
  206. - (void)getConference:(NSString *)aConfId
  207. password:(NSString *)aPassword
  208. completion:(void (^)(EMCallConference *aCall, EMError *aError))aCompletionBlock;
  209. /*!
  210. * \~chinese
  211. * 创建并加入会议
  212. *
  213. * @param aType 会议类型
  214. * @param aPassword 会议密码
  215. * @param aCompletionBlock 完成的回调
  216. *
  217. * \~english
  218. * Create and join a conference
  219. *
  220. * @param aType The type of the conference
  221. * @param aPassword The password of the conference
  222. * @param aCompletionBlock The callback block of completion
  223. */
  224. - (void)createAndJoinConferenceWithType:(EMConferenceType)aType
  225. password:(NSString *)aPassword
  226. completion:(void (^)(EMCallConference *aCall, NSString *aPassword, EMError *aError))aCompletionBlock;
  227. /*!
  228. * \~chinese
  229. * 创建并加入会议
  230. *
  231. * @param aType 会议类型
  232. * @param aPassword 会议密码
  233. * @param isRecord 是否开启服务端录制
  234. * @param isMerge 录制时是否合并数据流
  235. * @param aCompletionBlock 完成的回调
  236. *
  237. * \~english
  238. * Create and join a conference
  239. *
  240. * @param aType The type of the conference
  241. * @param aPassword The password of the conference
  242. * @param isRecord Whether to record using a server
  243. * @param isMerge Whether to merge data streams while recording
  244. * @param aCompletionBlock The callback block of completion
  245. */
  246. - (void)createAndJoinConferenceWithType:(EMConferenceType)aType
  247. password:(NSString *)aPassword
  248. record:(BOOL)isRecord
  249. mergeStream:(BOOL)isMerge
  250. completion:(void (^)(EMCallConference *aCall, NSString *aPassword, EMError *aError))aCompletionBlock;
  251. /*!
  252. * \~chinese
  253. * 创建并加入会议,支持微信小程序设置
  254. *
  255. * @param aType 会议类型
  256. * @param aPassword 会议密码
  257. * @param isRecord 是否开启服务端录制
  258. * @param isMerge 录制时是否合并数据流
  259. * @param isSupportWechatMiniProgram 是否支持微信小程序
  260. * @param aCompletionBlock 完成的回调
  261. *
  262. * \~english
  263. * Create and join a conference
  264. *
  265. * @param aType The type of the conference
  266. * @param aPassword The password of the conference
  267. * @param isRecord Whether to record using a server
  268. * @param isMerge Whether to merge data streams while recording
  269. * @param isSupportWechatMiniProgram Weather to support client on wechat mini program
  270. * @param aCompletionBlock The callback block of completion
  271. */
  272. - (void)createAndJoinConferenceWithType:(EMConferenceType)aType
  273. password:(NSString *)aPassword
  274. record:(BOOL)isRecord
  275. mergeStream:(BOOL)isMerge
  276. isSupportWechatMiniProgram:(BOOL)isSupportWechatMiniProgram
  277. completion:(void (^)(EMCallConference *aCall, NSString *aPassword, EMError *aError))aCompletionBlock;
  278. /*!
  279. * \~chinese
  280. * 加入已有会议
  281. *
  282. * @param aConfId 会议ID(EMCallConference.confId)
  283. * @param aPassword 会议密码
  284. * @param aCompletionBlock 完成的回调
  285. *
  286. * \~english
  287. * Join a conference
  288. *
  289. * @param aConfId Conference ID (EMCallConference.confId)
  290. * @param aPassword The password of the conference
  291. * @param aCompletionBlock The callback block of completion
  292. */
  293. - (void)joinConferenceWithConfId:(NSString *)aConfId
  294. password:(NSString *)aPassword
  295. completion:(void (^)(EMCallConference *aCall, EMError *aError))aCompletionBlock;
  296. /*!
  297. * \~chinese
  298. * 加入房间
  299. *
  300. * @param roomName 房间名称
  301. * @param aPassword 房间密码
  302. * @param role 加入房间使用的角色
  303. * @param aCompletionBlock 完成的回调
  304. *
  305. * \~english
  306. * Join a Room
  307. *
  308. * @param roomName Room Name
  309. * @param aPassword The password of the room
  310. * @param role The role user used
  311. * @param aCompletionBlock The callback block of completion
  312. */
  313. -(void)joinRoom:(NSString*)roomName
  314. password:(NSString*)aPassword
  315. role:(EMConferenceRole)role
  316. completion:(void (^)(EMCallConference *aCall, EMError *aError))aCompletionBlock;
  317. /*!
  318. * \~chinese
  319. * 加入房间
  320. *
  321. * @param roomName 房间名称
  322. * @param aPassword 房间密码
  323. * @param role 加入房间使用的角色
  324. * @param roomConfig 加入房间使用的配置
  325. * @param aCompletionBlock 完成的回调
  326. *
  327. * \~english
  328. * Join a Room
  329. *
  330. * @param roomName Room Name
  331. * @param aPassword The password of the room
  332. * @param role The role user used
  333. * @param roomConfig The configuration used while join the room
  334. * @param aCompletionBlock The callback block of completion
  335. */
  336. -(void)joinRoom:(NSString*)roomName
  337. password:(NSString*)aPassword
  338. role:(EMConferenceRole)role
  339. roomConfig:(RoomConfig*)roomConfig
  340. completion:(void (^)(EMCallConference *aCall, EMError *aError))aCompletionBlock;
  341. /*!
  342. * \~chinese
  343. * 加入已有会议
  344. *
  345. * @param aTicket 加入会议的凭证
  346. * @param aCompletionBlock 完成的回调
  347. *
  348. * \~english
  349. * Join a conference
  350. *
  351. * @param aTicket Conference Tickets
  352. * @param aCompletionBlock The callback block of completion
  353. */
  354. - (void)joinConferenceWithTicket:(NSString *)aTicket
  355. completion:(void (^)(EMCallConference *aCall, EMError *aError))aCompletionBlock;
  356. /*!
  357. * \~chinese
  358. * 上传本地摄像头的数据流
  359. *
  360. * @param aCall 会议实例(自己创建的无效)
  361. * @param aStreamParam 数据流的配置项
  362. * @param aCompletionBlock 完成的回调
  363. *
  364. * \~english
  365. * Publish the data stream of the local camera
  366. *
  367. * @param aCall EMConference instance (invalid by yourself)
  368. * @param aStreamParam The config of stream
  369. * @param aCompletionBlock The callback block of completion
  370. */
  371. - (void)publishConference:(EMCallConference *)aCall
  372. streamParam:(EMStreamParam *)aStreamParam
  373. completion:(void (^)(NSString *aPubStreamId, EMError *aError))aCompletionBlock;
  374. /*!
  375. * \~chinese
  376. * 取消上传本地摄像头的数据流
  377. *
  378. * @param aCall 会议实例(自己创建的无效)
  379. * @param aStreamId 数据流ID(在[IEMConferenceManager publishConference:pubConfig:completion:]返回)
  380. * @param aCompletionBlock 完成的回调
  381. *
  382. * \~english
  383. * Cancel the publish of the local camera's data stream
  384. *
  385. * @param aCall EMConference instance (invalid by yourself)
  386. * @param aStreamId Stream id (in [IEMConferenceManager publishConference:pubConfig:completion:] return)
  387. * @param aCompletionBlock The callback block of completion
  388. */
  389. - (void)unpublishConference:(EMCallConference *)aCall
  390. streamId:(NSString *)aStreamId
  391. completion:(void (^)(EMError *aError))aCompletionBlock;
  392. /*!
  393. * \~chinese
  394. * 订阅其他人的数据流
  395. *
  396. * @param aCall 会议实例(自己创建的无效)
  397. * @param aStreamId 数据流ID (在[EMConferenceManagerDelegate streamDidUpdate:addStream]中返回)
  398. * @param aRemoteView 视频显示页面
  399. * @param aCompletionBlock 完成的回调
  400. *
  401. * \~english
  402. * Subscribe to other user`s data streams
  403. *
  404. * @param aCall EMConference instance (invalid by yourself)
  405. * @param aStreamId Stream id (in [EMConferenceManagerDelegate streamDidUpdate:addStream] return )
  406. * @param aRemoteView Video display view
  407. * @param aCompletionBlock The callback block of completion
  408. */
  409. - (void)subscribeConference:(EMCallConference *)aCall
  410. streamId:(NSString *)aStreamId
  411. remoteVideoView:(EMCallRemoteVideoView *)aRemoteView
  412. completion:(void (^)(EMError *aError))aCompletionBlock;
  413. /*!
  414. * \~chinese
  415. * 取消订阅的数据流
  416. *
  417. * @param aCall 会议实例(自己创建的无效)
  418. * @param aStreamId 数据流ID
  419. * @param aCompletionBlock 完成的回调
  420. *
  421. * \~english
  422. * Unsubscribe data stream
  423. *
  424. * @param aCall EMConference instance (invalid by yourself)
  425. * @param aStreamId Stream id
  426. * @param aCompletionBlock The callback block of completion
  427. */
  428. - (void)unsubscribeConference:(EMCallConference *)aCall
  429. streamId:(NSString *)aStreamId
  430. completion:(void (^)(EMError *aError))aCompletionBlock;
  431. /*!
  432. * \~chinese
  433. * 改变成员角色,需要管理员权限
  434. * 用户角色: Admin > Talker > Audience
  435. * 当角色升级时,用户需要给管理员发送申请,管理通过该接口改变用户接口.
  436. * 当角色降级时,用户直接调用该接口即可.
  437. * 注意: 暂时不支持Admin降级自己
  438. *
  439. * @param aConfId 会议ID(EMCallConference.confId)
  440. * @param aMember 成员
  441. * @param aRole 成员角色
  442. * @param aCompletionBlock 完成的回调
  443. *
  444. * \~english
  445. * Changing member roles, requires administrator privileges
  446. * Role: Admin > Talker > Audience
  447. * When role upgrade, you need to send a request to Admin, only Admin can upgrade a role.
  448. * When role degrade, you can degrade with this method yourself.
  449. * Attention: Admin can not degrade self.
  450. *
  451. * @param aConfId Conference ID (EMCallConference.confId)
  452. * @param aMember Member
  453. * @param aRole The Role
  454. * @param aCompletionBlock The callback block of completion
  455. */
  456. - (void)changeMemberRoleWithConfId:(NSString *)aConfId
  457. member:(EMCallMember *)aMember
  458. role:(EMConferenceRole)toRole
  459. completion:(void (^)(EMError *aError))aCompletionBlock;
  460. /*!
  461. * \~chinese
  462. * 踢人,需要管理员权限
  463. *
  464. * @param aConfId 会议ID(EMCallConference.confId)
  465. * @param aMemberNameList 成员名列表
  466. * @param aCompletionBlock 完成的回调
  467. *
  468. * \~english
  469. * Kick members, requires administrator privileges
  470. *
  471. * @param aConfId Conference ID (EMCallConference.confId)
  472. * @param aMemberNameList Member Name list
  473. * @param aCompletionBlock The callback block of completion
  474. */
  475. - (void)kickMemberWithConfId:(NSString *)aConfId
  476. memberNames:(NSArray<NSString *> *)aMemberNameList
  477. completion:(void (^)(EMError *aError))aCompletionBlock;
  478. /*!
  479. * \~chinese
  480. * 销毁会议,需要管理员权限
  481. *
  482. * @param aConfId 会议ID(EMCallConference.confId)
  483. * @param aCompletionBlock 完成的回调
  484. *
  485. * \~english
  486. * Destroy conference, requires administrator privileges
  487. *
  488. * @param aConfId Conference ID (EMCallConference.confId)
  489. * @param aCompletionBlock The callback block of completion
  490. */
  491. - (void)destroyConferenceWithId:(NSString *)aConfId
  492. completion:(void (^)(EMError *aError))aCompletionBlock;
  493. /*!
  494. * \~chinese
  495. * 离开会议(创建者可以离开,最后一个人离开,会议销毁)
  496. *
  497. * @param aCall 会议实例(自己创建的无效)
  498. * @param aCompletionBlock 完成的回调
  499. *
  500. * \~english
  501. * Leave the conference (the creator can leave, the last person to leave, the conference is destroyed)
  502. *
  503. * @param aCall EMConference instance (invalid by yourself)
  504. * @param aCompletionBlock The callback block of completion
  505. */
  506. - (void)leaveConference:(EMCallConference *)aCall
  507. completion:(void (^)(EMError *aError))aCompletionBlock;
  508. /*!
  509. * \~chinese
  510. * 开始监听说话者
  511. *
  512. * @param aCall 会议实例(自己创建的无效)
  513. * @param aTimeMillisecond 返回回调的间隔,单位毫秒,传0使用300毫秒[EMConferenceManagerDelegate conferenceTalkerDidChange:talkingStreamIds:]
  514. * @param aCompletionBlock 完成的回调
  515. *
  516. * \~english
  517. * Start listening to the speaker
  518. *
  519. * @param aCall EMConference instance (invalid by yourself)
  520. * @param aTimeMillisecond The interval of callbacks [EMConferenceManagerDelegate conferenceTalkerDidChange:talkingStreamIds:], Unit milliseconds, pass 0 using 300 milliseconds
  521. * @param aCompletionBlock The callback block of completion
  522. */
  523. - (void)startMonitorSpeaker:(EMCallConference *)aCall
  524. timeInterval:(long long)aTimeMillisecond
  525. completion:(void (^)(EMError *aError))aCompletionBlock;
  526. /*!
  527. * \~chinese
  528. * 结束监听说话者
  529. *
  530. * @param aCall 会议实例(自己创建的无效)
  531. *
  532. * \~english
  533. * Stop listening to the speaker
  534. *
  535. * @param aCall EMConference instance (invalid by yourself)
  536. */
  537. - (void)stopMonitorSpeaker:(EMCallConference *)aCall;
  538. #pragma mark - Update
  539. /*!
  540. * \~chinese
  541. * 切换前后摄像头
  542. *
  543. * @param aCall 会议实例(自己创建的无效)
  544. *
  545. * \~english
  546. * Switch the camera before and after
  547. *
  548. * @param aCall EMConference instance (invalid by yourself)
  549. */
  550. - (void)updateConferenceWithSwitchCamera:(EMCallConference *)aCall;
  551. /*!
  552. * \~chinese
  553. * 设置是否静音
  554. *
  555. * @param aCall 会议实例(自己创建的无效)
  556. * @param aIsMute 是否静音
  557. *
  558. * \~english
  559. * Set whether to mute
  560. *
  561. * @param aCall EMConference instance (invalid by yourself)
  562. * @param aIsMute Is mute
  563. */
  564. - (void)updateConference:(EMCallConference *)aCall
  565. isMute:(BOOL)aIsMute;
  566. /*!
  567. * \~chinese
  568. * 设置视频是否可用
  569. *
  570. * @param aCall 会议实例(自己创建的无效)
  571. * @param aEnableVideo 视频是否可用
  572. *
  573. * \~english
  574. * Set whether the video is available
  575. *
  576. * @param aCall EMConference instance (invalid by yourself)
  577. * @param aEnableVideo Whether the video is available
  578. */
  579. - (void)updateConference:(EMCallConference *)aCall
  580. enableVideo:(BOOL)aEnableVideo;
  581. /*!
  582. * \~chinese
  583. * 更新视频显示页面
  584. *
  585. * @param aCall 会议实例
  586. * @param aStreamId 数据流ID
  587. * @param aRemoteView 显示页面
  588. * @param aCompletionBlock 完成的回调
  589. *
  590. * \~english
  591. * Update remote video view
  592. *
  593. * @param aCall EMConference instance
  594. * @param aStreamId Stream id
  595. * @param aRemoteView Video display view
  596. * @param aCompletionBlock The callback block of completion
  597. */
  598. - (void)updateConference:(EMCallConference *)aCall
  599. streamId:(NSString *)aStreamId
  600. remoteVideoView:(EMCallRemoteVideoView *)aRemoteView
  601. completion:(void (^)(EMError *aError))aCompletionBlock;
  602. /*!
  603. * \~chinese
  604. * 更新视频最大码率
  605. *
  606. * @param aCall 会议实例
  607. * @param aMaxVideoKbps 最大码率
  608. *
  609. * \~english
  610. * Update video maximum bit rate
  611. *
  612. * @param aCall EMConference instance
  613. * @param aMaxVideoKbps Maximum bit rate
  614. */
  615. - (void)updateConference:(EMCallConference *)aCall
  616. maxVideoKbps:(int)aMaxVideoKbps;
  617. #pragma mark - Input Video Data
  618. /*!
  619. * \~chinese
  620. * 自定义本地视频数据
  621. *
  622. * @param aSampleBuffer 视频采样缓冲区
  623. * @param aRotation 旋转方向
  624. * @param aCall 会议实例
  625. * @param aPubStreamId 调用接口[EMConferenceManager publishConference:streamParam:completion],如果成功则会在回调中返回该值
  626. * @param aCompletionBlock 完成后的回调
  627. *
  628. * \~english
  629. * Customize local video data
  630. *
  631. * @param aSampleBuffer Video sample buffer
  632. * @param aRotation UIDeviceOrientation
  633. * @param aCallId [EMCallSession callId]
  634. * @param aCompletionBlock The callback block of completion
  635. */
  636. - (void)inputVideoSampleBuffer:(CMSampleBufferRef)aSampleBuffer
  637. rotation:(UIDeviceOrientation)aRotation
  638. conference:(EMCallConference *)aCall
  639. publishedStreamId:(NSString *)aPubStreamId
  640. completion:(void (^)(EMError *aError))aCompletionBlock;
  641. /*!
  642. * \~chinese
  643. * 自定义本地视频数据
  644. *
  645. * @param aPixelBuffer 视频像素缓冲区
  646. * @param aTime 视频原始数据时间戳,CMTime time = CMSampleBufferGetPresentationTimeStamp((CMSampleBufferRef)sampleBuffer);
  647. * @param aRotation 旋转方向
  648. * @param aCall 会议实例
  649. * @param aPubStreamId 调用接口[EMConferenceManager publishConference:streamParam:completion],如果成功则会在回调中返回该值
  650. * @param aCompletionBlock 完成后的回调
  651. *
  652. * \~english
  653. * Customize local video data
  654. *
  655. * @param aPixelBuffer Video pixel buffer
  656. * @param aCallId [EMCallSession callId]
  657. * @param aTime CMTime time = CMSampleBufferGetPresentationTimeStamp((CMSampleBufferRef)sampleBuffer);
  658. * @param aRotation UIDeviceOrientation
  659. * @param aCompletionBlock The callback block of completion
  660. */
  661. - (void)inputVideoPixelBuffer:(CVPixelBufferRef)aPixelBuffer
  662. sampleBufferTime:(CMTime)aTime
  663. rotation:(UIDeviceOrientation)aRotation
  664. conference:(EMCallConference *)aCall
  665. publishedStreamId:(NSString *)aPubStreamId
  666. completion:(void (^)(EMError *aError))aCompletionBlock;
  667. /**
  668. * \~chinese
  669. * 设置频道属性,该会议中的所有人(包括自己)都会收到
  670. * {@link EMConferenceManagerDelegate#conferenceAttributeUpdated:attributeAction:attributeKey:}回调.
  671. * 该方法需要在加入会议后调用.
  672. *
  673. * @param attrKey
  674. * @param attrValue
  675. * @param aCompletionBlock
  676. *
  677. * \~english
  678. * Set conference attribute,All members in this conference(include myself) will receive a callback
  679. * in {@link EMConferenceManagerDelegate#conferenceAttributeUpdated:attributeAction:attributeKey:}.
  680. * this method can only be used after join a conference.
  681. *
  682. * @param attrKey
  683. * @param attrValue
  684. * @param aCompletionBlock
  685. */
  686. - (void)setConferenceAttribute:(NSString *)attrKey
  687. value:(NSString *)attrValue
  688. completion:(void(^)(EMError *aError))aCompletionBlock;
  689. /**
  690. * \~chinese
  691. * 删除频道属性,该会议中的所有人(包括自己)都会收到
  692. * {@link EMConferenceManagerDelegate#conferenceAttributeUpdated:attributeAction:attributeKey:}回调.
  693. * 该方法需要在加入会议后调用.
  694. *
  695. * @param aKey
  696. * @param aCompletionBlock
  697. *
  698. * \~english
  699. * Delete conference attribute,All members in this conference(include myself) will receive a callback
  700. * in {@link EMConferenceManagerDelegate#conferenceAttributeUpdated:attributeAction:attributeKey:}.
  701. * this method can only be used after join a conference.
  702. *
  703. * @param aKey
  704. * @param aCompletionBlock
  705. */
  706. - (void)deleteAttributeWithKey:(NSString *)aKey
  707. completion:(void(^)(EMError *aError))aCompletionBlock;
  708. /**
  709. * \~chinese
  710. * 创建白板房间
  711. * @param aUsername 用户名
  712. * @param aToken 用户的token
  713. * @param aRoomName 房间名
  714. * @param aPassword 房间的密码
  715. * @param aCompletionBlock 请求完成的回调
  716. *
  717. * \~english
  718. * create room for whiteboard
  719. * @param aUsername username
  720. * @param aToken user's token
  721. * @param aRoomName room name for whiteboard
  722. * @param aPassword password for room
  723. * @param aCompletionBlock callback
  724. */
  725. - (void)createWhiteboardRoomWithUsername:(NSString *)aUsername
  726. userToken:(NSString *)aToken
  727. roomName:(NSString *)aRoomName
  728. roomPassword:(NSString *)aPassword
  729. completion:(void(^)(EMWhiteboard *aWhiteboard, EMError *aError))aCompletionBlock;
  730. /**
  731. * \~chinese
  732. * 销毁白板房间
  733. * @param aUsername 用户名
  734. * @param aToken 用户的token
  735. * @param aRoomId 房间id
  736. * @param aCompletionBlock 请求完成的回调
  737. *
  738. * \~english
  739. * create room for whiteboard
  740. * @param aUsername username
  741. * @param aToken user's token
  742. * @param aRoomId room id for whiteboard
  743. * @param aCompletionBlock callback
  744. */
  745. - (void)destroyWhiteboardRoomWithUsername:(NSString *)aUsername
  746. userToken:(NSString *)aToken
  747. roomId:(NSString *)aRoomId
  748. completion:(void(^)(EMError *aError))aCompletionBlock;
  749. /**
  750. * \~chinese
  751. * 通过白板id加入房间
  752. * @param aRoomId 房间id
  753. * @param aUsername 用户名
  754. * @param aToken 用户的token
  755. * @param aPassword 房间的密码
  756. * @param aCompletionBlock 请求完成的回调
  757. *
  758. * \~english
  759. * join whiteboard room with id
  760. * @param aRoomId room id for whiteboard
  761. * @param aUsername username
  762. * @param aToken user's token
  763. * @param aPassword password for room
  764. * @param aCompletionBlock callback
  765. */
  766. - (void)joinWhiteboardRoomWithId:(NSString *)aRoomId
  767. username:(NSString *)aUsername
  768. userToken:(NSString *)aToken
  769. roomPassword:(NSString *)aPassword
  770. completion:(void(^)(EMWhiteboard *aWhiteboard, EMError *aError))aCompletionBlock;
  771. /**
  772. * \~chinese
  773. * 通过白板名称加入房间
  774. * @param aRoomName 房间名
  775. * @param aUsername 用户名
  776. * @param aToken 用户的token
  777. * @param aPassword 房间的密码
  778. * @param aCompletionBlock 请求完成的回调
  779. *
  780. * \~english
  781. * join whiteboard room with name
  782. * @param aRoomName room name for whiteboard
  783. * @param aUsername username
  784. * @param aToken user's token
  785. * @param aPassword password for room
  786. * @param aCompletionBlock callback
  787. */
  788. - (void)joinWhiteboardRoomWithName:(NSString *)aRoomName
  789. username:(NSString *)aUsername
  790. userToken:(NSString *)aToken
  791. roomPassword:(NSString *)aPassword
  792. completion:(void(^)(EMWhiteboard *aWhiteboard, EMError *aError))aCompletionBlock;
  793. /**
  794. * \~chinese
  795. * 开启本地伴音功能,请在加入会议成功后调用,该伴音配置只存在于该会议存在期间.
  796. *
  797. * @param filePath 文件路径
  798. * @param loop 指定音频文件循环播放的次数:
  799. * 正整数:循环的次数
  800. * -1:无限循环
  801. * @param isSendMix 是否启动远端伴音 启动后播放的音乐对方也可以听到
  802. *
  803. * @return {@link EMError#EM_NO_ERROR} - 成功
  804. * {@link EMError#CALL_CONFERENCE_NO_EXIST} - 未加入会议
  805. * {@link EMError#CALL_INVALID_PARAMS} - 路径参数下的音频文件不存在
  806. *
  807. * \~english
  808. * Start local audio mixing, this method can only be used after join a conference and only worked
  809. * during this conference exists.
  810. *
  811. * @param filePath Audio file path.
  812. * If file path is start with /assets/, we will find in assets/ dir.
  813. * Otherwise, we will find in absolute path.
  814. * @param loop loop mode (0 = no loop, -1 = loop forever)
  815. * @param isSendMix send mixed audio
  816. *
  817. * @return {@link EMError#EM_NO_ERROR} - Success
  818. * {@link EMError#CALL_CONFERENCE_NO_EXIST} - Not in a conference.
  819. * {@link EMError#CALL_INVALID_PARAMS} - File not exists.
  820. */
  821. - (EMError *)startAudioMixing:(NSURL *)aFileURL loop:(int)aLoop sendMix:(BOOL)isSendMix;
  822. /**
  823. * \~chinese
  824. * 关闭本地混音功能,请在加入会议成功后调用
  825. *
  826. * @return {@link EMError#EM_NO_ERROR} - 成功
  827. * {@link EMError#CALL_CONFERENCE_NO_EXIST} - 未加入会议
  828. *
  829. * \~english
  830. * Stop local audio mixing,this method can only be used after join a conference.
  831. *
  832. * @return {@link EMError#EM_NO_ERROR} - Success
  833. * {@link EMError#CALL_CONFERENCE_NO_EXIST} - Not in a conference.
  834. */
  835. - (EMError *)stopAudioMixing;
  836. /**
  837. * \~chinese
  838. * 设置伴奏音量,请在加入会议成功后调用
  839. *
  840. * @param volume 伴奏音量范围为 0~100。默认 100 为原始文件音量
  841. *
  842. * @return {@link EMError#EM_NO_ERROR} - 成功
  843. * {@link EMError#CALL_CONFERENCE_NO_EXIST} - 未加入会议
  844. *
  845. * \~english
  846. * Adjust audio mixing volume,this method can only be used after join a conference.
  847. *
  848. * @param volume scope: 0~100. Default volume is 100, which is the original audio file volume.
  849. *
  850. * @return {@link EMError#EM_NO_ERROR} - Success
  851. * {@link EMError#CALL_CONFERENCE_NO_EXIST} - Not in a conference.
  852. */
  853. - (EMError *)adjustAudioMixingVolume:(int)aVolume;
  854. /**
  855. * \~chinese
  856. * mute远端音频
  857. *
  858. * @param aStreamId 要操作的Steam id
  859. * @param isMute 是否静音
  860. *
  861. * \~english
  862. * Mute remote audio
  863. *
  864. * @param aStreamId Steam id
  865. * @param isMute is mute
  866. */
  867. - (void)muteRemoteAudio:(NSString *)aStreamId mute:(BOOL)isMute;
  868. /**
  869. * \~chinese
  870. * mute远端视频
  871. *
  872. * @param aStreamId 要操作的Steam id
  873. * @param isMute 是否显示
  874. *
  875. * \~english
  876. * Mute remote video
  877. *
  878. * @param aStreamId Steam id
  879. * @param isMute is mute
  880. */
  881. - (void)muteRemoteVideo:(NSString *)aStreamId mute:(BOOL)isMute;
  882. /**
  883. * \~chinese
  884. * 启用统计
  885. *
  886. * @param enable 是否启用统计
  887. *
  888. * \~english
  889. * enable statistics
  890. * @params enable enable statistics
  891. */
  892. - (void)enableStatistics:(BOOL)isEnable;
  893. #pragma mark - 自定义音频数据
  894. /*!
  895. * \~chinese
  896. * 自定义外部音频数据,PCM格式,一个音频采样16bit,每次最大100ms数据
  897. *
  898. * @param data 外部音频数据
  899. *
  900. * \~english
  901. * Customize external audio data,PCM format,each audio sample contail 16 bits,the maxinum data durateion is 100ms
  902. *
  903. * @param data Custom audio data,format with PCM
  904. */
  905. - (int) inputCustomAudioData:(NSData*)data;
  906. #pragma mark - Watermark
  907. /*!
  908. * \~chinese
  909. * 开启水印功能
  910. *
  911. * @param option 水印配置项,包括图片url,marginX,marginY以及起始点
  912. *
  913. * \~english
  914. * Enable water mark feature
  915. *
  916. * @param origin the option of watermark picture,include url,margingX,marginY,margin point
  917. */
  918. - (void)addVideoWatermark:(EMWaterMarkOption*)option;
  919. /*!
  920. * \~chinese
  921. * 取消水印功能
  922. *
  923. * \~english
  924. * Disable water mark feature
  925. *
  926. */
  927. - (void)clearVideoWatermark;
  928. #pragma mark - EM_DEPRECATED_IOS 3.5.2
  929. /*!
  930. * \~chinese
  931. * 自定义本地视频数据
  932. *
  933. * @param aSampleBuffer 视频采样缓冲区
  934. * @param aCall 会议实例
  935. * @param aPubStreamId 调用接口[EMConferenceManager publishConference:streamParam:completion],如果成功则会在回调中返回该值
  936. * @param aFormat 视频格式
  937. * @param aRotation 旋转角度0~360,默认0
  938. * @param aCompletionBlock 完成后的回调
  939. *
  940. * \~englishat
  941. * Customize local video da
  942. *
  943. * @param aSampleBuffer Video sample buffer
  944. * @param aCall EMConference instance
  945. * @param aPubStreamId [EMConferenceManager publishConference:streamParam:completion], If successful, the value will be returned in the callback
  946. * @param aFormat Video format
  947. * @param aRotation Rotation angle 0~360, default 0
  948. * @param aCompletionBlock The callback block of completion
  949. */
  950. - (void)inputVideoSampleBuffer:(CMSampleBufferRef)aSampleBuffer
  951. conference:(EMCallConference *)aCall
  952. publishedStreamId:(NSString *)aPubStreamId
  953. format:(EMCallVideoFormat)aFormat
  954. rotation:(int)aRotation
  955. completion:(void (^)(EMError *aError))aCompletionBlock EM_DEPRECATED_IOS(3_2_2, 3_5_2, "Delete, Use -inputVideoSampleBuffer:rotation:conference:publishedStreamId:completion:");
  956. /*!
  957. * \~chinese
  958. * 自定义本地视频数据
  959. *
  960. * @param aPixelBuffer 视频像素缓冲区
  961. * @param aCall 会议实例
  962. * @param aPubStreamId 调用接口[EMConferenceManager publishConference:streamParam:completion],如果成功则会在回调中返回该值
  963. * @param aFormat 视频格式
  964. * @param aRotation 旋转角度0~360,默认0
  965. * @param aCompletionBlock 完成后的回调
  966. *
  967. * \~english
  968. * Customize local video data
  969. *
  970. * @param aPixelBuffer Video pixel buffer
  971. * @param aCall EMConference instance
  972. * @param aPubStreamId [EMConferenceManager publishConference:streamParam:completion], If successful, the value will be returned in the callback
  973. * @param aFormat Video format
  974. * @param aRotation Rotation angle 0~360, default 0
  975. * @param aCompletionBlock The callback block of completion
  976. */
  977. - (void)inputVideoPixelBuffer:(CVPixelBufferRef)aPixelBuffer
  978. conference:(EMCallConference *)aCall
  979. publishedStreamId:(NSString *)aPubStreamId
  980. format:(EMCallVideoFormat)aFormat
  981. rotation:(int)aRotation
  982. completion:(void (^)(EMError *aError))aCompletionBlock EM_DEPRECATED_IOS(3_2_2, 3_5_2, "Delete, Use -inputVideoPixelBuffer:sampleBufferTime:rotation:conference:publishedStreamId:completion:");
  983. /*!
  984. * \~chinese
  985. * 自定义本地视频数据
  986. *
  987. * @param aData 视频数据
  988. * @param aCall 会议实例
  989. * @param aPubStreamId 调用接口[EMConferenceManager publishConference:streamParam:completion],如果成功则会在回调中返回该值
  990. * @param aWidth 宽度
  991. * @param aHeight 高度
  992. * @param aFormat 视频格式
  993. * @param aRotation 旋转角度0~360,默认0
  994. * @param aCompletionBlock 完成后的回调
  995. *
  996. * \~english
  997. * Customize local video data
  998. *
  999. * @param aData Video data
  1000. * @param aCall EMConference instance
  1001. * @param aPubStreamId [EMConferenceManager publishConference:streamParam:completion], If successful, the value will be returned in the callback
  1002. * @param aWidth Width
  1003. * @param aHeight Height
  1004. * @param aFormat Video format
  1005. * @param aRotation Rotation angle 0~360, default 0
  1006. * @param aCompletionBlock The callback block of completion
  1007. */
  1008. - (void)inputVideoData:(NSData *)aData
  1009. conference:(EMCallConference *)aCall
  1010. publishedStreamId:(NSString *)aPubStreamId
  1011. widthInPixels:(size_t)aWidth
  1012. heightInPixels:(size_t)aHeight
  1013. format:(EMCallVideoFormat)aFormat
  1014. rotation:(int)aRotation
  1015. completion:(void (^)(EMError *aError))aCompletionBlock EM_DEPRECATED_IOS(3_2_2, 3_5_2, "Delete");
  1016. #pragma mark - EM_DEPRECATED_IOS 3.4.3
  1017. /*!
  1018. * \~chinese
  1019. * 多人会议场景
  1020. *
  1021. * \~english
  1022. * Conference mode
  1023. */
  1024. @property (nonatomic) EMConferenceMode mode EM_DEPRECATED_IOS(3_1_0, 3_4_3, "Use -DELETE");
  1025. /*!
  1026. * \~chinese
  1027. * 创建并加入会议
  1028. *
  1029. * @param aPassword 会议密码
  1030. * @param aCompletionBlock 完成的回调
  1031. *
  1032. * \~english
  1033. * Create and join a conference
  1034. *
  1035. * @param aPassword The password of the conference
  1036. * @param aCompletionBlock The callback block of completion
  1037. */
  1038. - (void)createAndJoinConferenceWithPassword:(NSString *)aPassword
  1039. completion:(void (^)(EMCallConference *aCall, NSString *aPassword, EMError *aError))aCompletionBlock EM_DEPRECATED_IOS(3_1_0, 3_4_3, "Use -[EMConferenceManagerDelegate createAndJoinConferenceWithType:password:completion:]");
  1040. /*!
  1041. * \~chinese
  1042. * 邀请人加入会议
  1043. *
  1044. * @param aCall 会议实例(自己创建的无效)
  1045. * @param aUserName 被邀请人的环信ID
  1046. * @param aPassword 会议密码
  1047. * @param aExt 扩展信息
  1048. * @param aCompletionBlock 完成的回调
  1049. *
  1050. * \~english
  1051. * Invite user join the conference
  1052. *
  1053. * @param aCall EMConference instance (invalid by yourself)
  1054. * @param aUserName The Hyphenate ID of the invited user
  1055. * @param aPassword The password of the conference
  1056. * @param aExt Extended Information
  1057. * @param aCompletionBlock The callback block of completion
  1058. */
  1059. - (void)inviteUserToJoinConference:(EMCallConference *)aCall
  1060. userName:(NSString *)aUserName
  1061. password:(NSString *)aPassword
  1062. ext:(NSString *)aExt
  1063. error:(EMError **)pError EM_DEPRECATED_IOS(3_1_0, 3_4_3, "Use -DELETE, 在demo层自定义实现");
  1064. /*!
  1065. * \~chinese
  1066. * 改变成员角色,需要管理员权限
  1067. *
  1068. * @param aConfId 会议ID(EMCallConference.confId)
  1069. * @param aMemberNameList 成员名列表
  1070. * @param aRole 成员角色
  1071. * @param aCompletionBlock 完成的回调
  1072. *
  1073. * \~english
  1074. * Changing member roles, requires administrator privileges
  1075. *
  1076. * @param aConfId Conference ID (EMCallConference.confId)
  1077. * @param aMemberNameList Member Name list
  1078. * @param aRole The Role
  1079. * @param aCompletionBlock The callback block of completion
  1080. */
  1081. - (void)changeMemberRoleWithConfId:(NSString *)aConfId
  1082. memberNames:(NSArray<NSString *> *)aMemberNameList
  1083. role:(EMConferenceRole)aRole
  1084. completion:(void (^)(EMError *aError))aCompletionBlock EM_DEPRECATED_IOS(3_5_0, 3_6_0, "Use -[changeMemberRoleWithConfId:memberName:role:completion]");
  1085. @end
  1086. #endif /* IEMConferenceManager_h */