MAC OS SDK 指南

1. 下载资源

2. 开发语言以及系统要求

  • 系统版本:MacOS 10.0;

3. 开发环境

  • Xcode 9.0及以上版本;
  • Apple开发证书或个人账号;

4. 搭建开发环境

4.1. 得到动态库

下载SDK,得到的AutoAIRtcSdk_mac.framework为动态库;

4.2. 创建新的工程

使用XCode创建一个新的工程AutoAIRtcSdk-mac-demo;

4.3. 加入动态库到工程中

将已下载的动态库AutoAIRtcSdk_mac.framework加入到AutoAIRtcSdk-mac-demo工程中Embedded Binaries;

4.4. 打开Xcode

将TARGETS>GENERAL>Deployment Target 设置为10.10及以上;

4.5. 编辑info.plist,申请摄像头、麦克风权限

Privacy - Camera Usage Description
Privacy - Microphone Usage Description

4.6. 打开网络请求相关权限

4.7. 集成成功

按照上述步骤完成AutoAIRtcSdk-mac-demo的前期SDK集成准备之后,执行编译 Commond + B,提示Build Success,表示SDK集成成功。

5. 初始化

建议在初始化 App 的同时,初始化 SDK。

5.1. 导入 SDK 头文件

5.2. 设置 userId 和 roomId,获取AppID;

AutoAIRtcEngine *engine = [[AutoAIRtcEngine alloc]
initWithUserId:userId appId:appId roomId:roomId token:@""]];

务必要设置代理对象,并实现代理回调方法,设置代理对象失败,会导致 App 收不到相关回调。

engine.delegate = self;

5.3. 调用接口初始化

使用之前需要对SDK进行相关设置,如果不设置,系统将会采用默认值。

self.engineMode = AutoAIRtcEngineModeTrival; 默认为测试模式
self.engine.isAutoPublish = YES;//加入房间后将自动发布本地音视频 默认为YES
self.engine.isAutoSubscribe = YES;//加入房间后将自动订阅远端音视频 默认为YES
self.engine.isDesktop = NO;//发布桌面或者摄像头 默认为NO:摄像头 YES:桌面

6. 建立通话

6.1. 加入房间

[self.engine joinRoomWithcompletionHandler:^(NSData *data, NSUrlResponse *response, NSError error) {
}];

6.2. 发布本地流

1)自动发布模式下,joinRoom成功后,随即发布本地流;
2)发布过程中可以监听以下事件获取发布状态,根据状态调用渲染或其他接口即可。

- (void)uCloudRtcEngine:(AutoAIRtcEngine *)manager didChangePublishState:(AutoAIRtcEnginePublishState)publishState {
    switch (publishState) {
        case AutoAIRtcEnginePublishStateUnPublish:
            self.isConnected = NO;
            break;
        case AutoAIRtcEnginePublishStatePublishing: {
            [self.bottomButton setTitle:@"正在发布..." forState:UIControlStateNormal];
        }
            break;
        case AutoAIRtcEnginePublishStatePublishSucceed:{
            self.isConnected = YES;
            [self.view makeToast:@"发布成功" duration:1.5 position:CSToastPositionCenter];
            [self.bottomButton setTitle:@"发布成功" forState:UIControlStateNormal];
        }
            break;
        case AutoAIRtcEnginePublishStateRepublishing: {
            [self.bottomButton setTitle:@"正在重新发布..." forState:UIControlStateNormal];
        }
            break;
        case AutoAIRtcEnginePublishStatePublishFailed: {
            self.isConnected = NO;
            [self.bottomButton setTitle:@"开始发布" forState:UIControlStateNormal];
        }
            break;
        case AutoAIRtcEnginePublishStatePublishStoped: {
            self.isConnected = NO;
            [self.view makeToast:@"发布已停止" duration:1.5 position:CSToastPositionCenter];
            [self.bottomButton setTitle:@"开始发布" forState:UIControlStateNormal];
        }
            break;
        default:
            break;
    }
}

6.3. 订阅远程流

1)自动订阅模式下,joinRoom成功后,即可订阅远程流;
2)订阅成功,在回调事件中调用渲染接口即可。

-(void)uCloudRtcEngine:(AutoAIRtcEngine *)channel didSubscribe:(AutoAIRtcStream *)stream{
     [self reloadVideos];
}

6.4. 离开房间

[self.engine leaveRoom];

6.5. 编译、运行,开始体验吧!