- AAC 音频编码
- H.264 视频编码(软硬编同时支持)
- 多分辨率编码支持
- 摄像头控制(朝向,闪光灯,前后摄像头)
- 摄像头控制(可以调用原生的系统api)
- 用户可自由设定音视频码率
- 根据网络带宽自适应调整视频的码率
- 支持 RTMP 协议直播推流
- 提供两种层次的API:简单易用的的kit类API 和 灵活的组件化API
- 能够与GPUImage无缝集成
- 提供GPU实现的内置美颜滤镜
- 支持背景音乐播放
- 支持混音
- 支持视频动态推流开关/纯音频推流
- 在线API 文档支持
- 支持耳返
- 支持画中画推流
- 支持预览和采集分辨率分别设置
- 支持一对一连麦
- 与系统播放器MPMoviePlayerController接口一致,可以无缝快速切换至KSYMediaPlayer;
- 本地全媒体格式支持, 并对主流的媒体格式(mp4, avi, wmv, flv, mkv, mov, rmvb 等 )进行优化;
- 支持广泛的流式视频格式, HLS, RTMP, HTTP Rseudo-Streaming 等;
- 低延时直播体验,配合金山云推流sdk,可以达到全程直播稳定的4秒内延时;
- 实现快速满屏播放,为用户带来更快捷优质的播放体验;
- 版本适配支持iOS 7.0以上版本;
- 业内一流的H.265解码;
- 小于2M大小的超轻量级直播sdk;
- 2016.02.25 上行网络自适应上线;
- 2016.03.26 内建美颜上线;
- 2016.04.11 支持四种混响模式的美声上线;
- 2016.05.18 耳返上线;
- 2016.06.12 画中画推流上线;
- 2016.06.27 支持短视频录制;
- 2016.08.04 两人连麦内测;
- 2016.08.24 支持纯音频推流,支持后台音频推流,支持视频动态发送开关;
- 2016.09.xx kit顶层库代码开源;
- 2016.09.xx 内建极致美颜上线;
- 2016.09.xx 高达50% cpu性能节省的场景编码上线;
- 最低支持iOS版本:iOS 7.0
- 最低支持iPhone型号:iPhone 4
- 支持CPU架构: armv7,armv7s,arm64(和i386,x86_64模拟器)
- 含有i386和x86_64模拟器版本的库文件,推流功能无法在模拟器上工作,播放功能完全支持模拟器。
本SDK 提供如下三种获取方式:
3.2.1 从github clone
目录结构如下所示:
- demo : demo工程为KSYLive ,演示本SDK的主要接口的使用
- doc/docset : appleDoc风格的接口文档,安装后可在xcode中直接看到方法和属性的文档
- doc/html : appleDoc风格的网页版接口文档,也可查看在线版
- framework/livegpu/libksygpulive.framework : 本SDK的静态库framework,集成时需要将该framework加入到项目中
$ git clone https://github.com/ksvc/KSYLive_iOS.git KSYLive_iOS
3.2.2 从oschina clone
对于部分地方访问github比较慢的情况,可以从oschina clone,获取的库内容和github一致。
$ git clone https://git.oschina.net/ksvc/KSYLive_iOS.git
通过Cocoapods 能将本SDK的静态库framework下载到本地,只需要将如下语句加入你的Podfile:
pod 'KSYGPULive_iOS', :git => 'https://github.com/ksvc/KSYLive_iOS.git'
执行 pod install 或者 pod update后,将SDK加入工程。
配置工程Podfile文件,添加KSYGPULive_iOS配置信息
pod 'KSYGPULive_iOS'
- SDK压缩包 将压缩包中framework下的libksygpulive.framework添加到XCode的工程,具体步骤为:
- 选中应用的Target,进入项目配置页面
- 切换到 Build Phases标签页
- 在Link Binary With Libraries 一栏中加入 libksygpulive.framework和第三方依赖库GPUImage.framework
- SDK Cocoapods 在Podfile中本SDK的条目,并执行了 pod install 之后, 本SDK就已经加入工程中,打开工程的workspace即可。
#import <GPUImage/GPUImage.h>
#import <libksygpulive/libksygpulive.h>
#import <libksygpulive/libksygpuimage.h>
以上三个头文件都是需要引入的:
- GPUImage.h是因为依赖第三方framework需要引入的
- libksygpulive.h 是本SDK中不依赖 GPUImage部分的头文件
- libksygpuimage.h 是依赖GPUImage部分的头文件
- 当自定义GPUImage时,GPUImage的版本要求是0.1.7
本SDK的版本号 主要通过核心类查询
NSLog(@"version: %@", [streamerBase getKSYVersion]);
NSLog(@"version: %@", [kit getKSYVersion]);
- 本framework已经包含播放SDK
且会跟播放SDK产生冲突,在集成前,请先保证将之前集成的KSY播放SDK移除 - 本framework可能与其他使用了FFmpeg的静态库冲突
- 本framework为静态库,虽然库的大小为20M+,但是最后链接后,对app的增量只有4M+
请见github库:https://github.com/ksvc/KSYMediaPlayer_iOS.git
- 主页:金山云
- 邮箱:[email protected]
- QQ讨论群:574179720
- Issues:https://github.com/ksvc/KSYLive_iOS/issues