• 视频聊天插件:AnyChat使用攻略之iOS开发指南


    AnyChat使用攻略之iOS开发指南

    这套攻略主要指导刚开始使用AnyChat SDK For iOS的同学,快速搭建SDK环境,和实现音视频开发流程.
    (需要工程案例文件可联系我们)


    在iOS平台上使用AnyChat客户端SDK,需要注意以下几点。
    (以附带的工程为例子讲解—环境: iOS7.0 ,Xcode5.1.1)


    1,首先下载最新的AnyChat for iOS SDK(点击打开下载页面);


    2,解压缩下载的SDK包,如下图所示:


    3,iOS工程本身必须要引用5个框架。
    在xcode软件菜单的Project-->Build Phases-->Link Binary With Libraryes里面增加库,如图:
    引用的5个库具体,如图所示:

    (有不少同学,出现编译Undefined symbols for architecture i386:"_AVCaptureSessionPreset1280x720", referenced from:……等类似错误,是因为忘记添加所示的iOS Framework.)



    4,进入刚下载的官方SDK包里面,目录是【sdklibs】,也是要全部添加到你的工程里面。
    可以通过在xcode的左下角如图:
    地方添加引用工程外的库文件,
    (别忘了【sdklibsaudioprocess】目录下还有几个.a静态库文件。 下图中库文件数量和最新 SDK包里的库文件数量会有所不同,以最新 SDK 包为标准),

    在添加完成库的时候编译下,如果按流畅走,应该是有一个小警告,不影响正常运行的.警告如下:
    (warning: ignoring file /Users/bairuitech/Desktop/AnyChatIOS/libvad.a, file was built for archive which is not the architecture being linked (i386): /Users/bairuitech/Desktop/AnyChatIOS/libvad.a) ,
    这个libvad.a 文件 可以先删除,这项目真是没需要到.


    5,另外需要配置C++环境,以下两个步骤解决:

    第一步:Build Settings-->Apple LLVM 5.1 - Language - C++ --> C++ Standard Library,
    设置为:libstdc++(GNU C++ standard library)

    第二步:Project-->Build Phases-->Link Binary With Libraryes里面增加库:libstdc++.dylib

    第三步:在“Project-->Build Phases-->Link Binary With Libraryes”里面添加库“libstdc++.6.dylib”,如下图所示:
    然后Clean工程,然后重新Build。
    如果没有配置C++环境,就会在编译时候出现类似 Undefined symbols for architecture i386:"std::_List_node_base::hook(std::_List_node_base*)", referenced from:…….等类似错误,是因为在链接(Link)过程中出错,缺少c++静态库或不兼容.



    6,配置调试器环境。
    为了兼容不同设备的内核,请在如图地方设置:

    修改Build Active Architecture Only选项为Yes,或者修改Valid Architectures选项为armv7,两个方法选一个即可。

    如果没配置的话,在调试时会出现以下错误:
    、Undefined symbols for architecture x86_64:  "_OBJC_CLASS_$_AnyChatPlatform", referenced from:  objc-class-ref in AnchatViewController.old :symbol(s) not found for architecture x86_64 clang: error: linker command failed with exit code 1 (use -v to see invocation)



    7,SDK解压包的【sdkinclude】目录里面是AnyChat的Objective-c SDK协议文件. 如图:
    在制作过程中,工程都需要引用此协议到代码.h头文件处。
    #import "AnyChatPlatform.h"
    #import "AnyChatDefine.h"
    #import "AnyChatErrorCode.h"

    (如果要获取本地视频另外还需要引用 #import "AVFoundation.h" )


    8, 在应用程序启动时(AppDelegate),设置默认端口和IP地址参数(为了连接服务器做准备)。
    ServerIP           : “demo.anychat.cn”
    ServerPort         : “8906”


    9,程序加载前,做初始化系统和配置登录连接,主要以下方法:

    [AnyChatPlatform InitSDK:0];  // 初始化系统
    [AnyChatPlatform Connect: ServerIP : ServerPort;   // 连接服务器参数
    [AnyChatPlatform Login: UserName : @""];   // 登录系统   (UserName参数:登录自定义的用户名)
    (以上步骤完成后,运行登录成功会在控制台打印显示 Connection to streaming media server successfully!)

    [AnyChatPlatform EnterRoom:1 :@""];  //进入房间
    (EnterRoom的值在例子中是设置了第一个房间,目前有6个房间可以自己重新选择)

    通过[AnyChatPlatform GetOnlineUser]方法,获取返回值是一个远程用户ID的列表数组
    (可以通过此数组获取第一用户ID与他视频聊天。)



    10,
    1),在显示视图中需要添加AnyChatNotifyMessageDelegate协议,必须实现以下7个方法。

    // 连接服务器消息
    - (void) OnAnyChatConnect:(BOOL) bSuccess;
    // 用户登陆消息
    - (void) OnAnyChatLogin:(int) dwUserId : (int) dwErrorCode;
    // 用户进入房间消息
    - (void) OnAnyChatEnterRoom:(int) dwRoomId : (int) dwErrorCode;
    // 房间在线用户消息
    - (void) OnAnyChatOnlineUser:(int) dwUserNum : (int) dwRoomId;
    // 用户进入房间消息
    - (void) OnAnyChatUserEnterRoom:(int) dwUserId;
    // 用户退出房间消息
    - (void) OnAnyChatUserLeaveRoom:(int) dwUserId;
    // 网络断开消息
    - (void) OnAnyChatLinkClose:(int) dwErrorCode;

    (注意两个事件处理:1当有用户进出房间时触发的事件,2用户自己进房间先后顺序的事件处理。)



    2),工程里实现了SDK的状态改变事件协议AnyChatStateChangeDelegate,以此为案例和同学们复习一下iOS开发语法,怎样实现协议与委托的三部曲.(ios开发老手可略过,此协议对于视频聊天不是必须实现的)

    首先是在实现协议的类.h头文件中添加,你要引用的协议<AnyChatStateChangeDelegate>.
    然后该协议里面有5个委托方法必须实现在类的.m文件中(在AnyChatPlatform.h中可以查到那5个方法),
    最后这步是很多iOS初学者忘记的,就是设置委托代理是谁 (如:_cxsAnyChatPlatform.stateChangeDelegate = self;)



    11, 在视图现实获取视频图像,只需要在现实的地方添加UIImageView,通过以下方法操作,

    [AnyChatPlatform UserSpeakControl: userid:YES];   // 操作用户语音
    [AnyChatPlatform SetVideoPos:userid: 自定义的UIImageView对象:0:0:0:0]; // 设置视频显示位置默认为零时,会自动调节为UIImageView同等大小
    [AnyChatPlatform UserCameraControl:userid : YES];  // 操作用户视频

    注意:在整过视频聊天过程中,有几个地方调用以上3个方法,
    1)-(void) OnAnyChatEnterRoom:(int) dwRoomId : (int) dwErrorCode;在收到该委托方法之后,可打开本地用户的音视频.
    2)-(void) OnAnyChatOnlineUser:(int) dwUserNum : (int) dwRoomId;在收到该委托方法之后,可打开当前房间在线用户的音视频.
    3)-(void) OnAnyChatUserEnterRoom:(int) dwUserId;在收到该委托方法之后,可打开当前进入房间用户的音视频.

  • 相关阅读:
    Kubernetes DNS服务配置案例
    Dockerfile常用指令
    Docker常用命令
    Kubernetes常用命令
    阿里云ECS安装Kubernetes问题收集与解答
    712. Minimum ASCII Delete Sum for Two Strings
    845. Longest Mountain in Array
    815. Bus Routes
    204. Count Primes
    190. Reverse Bits
  • 原文地址:https://www.cnblogs.com/melons/p/5792028.html
Copyright © 2020-2023  润新知