/PLAudioStreamingKit

Pili Live Streaming SDK for iOS, AAC hardware encoding and RTMP publishing supported.

Primary LanguageCApache License 2.0Apache-2.0

PLAudioStreamingKit

PLAudioStreamingKit 是一个适用于 iOS 的 RTMP 直播推流 SDK,可高度定制化和二次开发。特色是支持 iOS 麦克风音频采样并进行 AAC 硬编码;同时,还支持后台持续推流。

功能特性

  • 硬件编解码
  • 多码率可选
  • AAC 音频编码
  • HeaderDoc 文档支持
  • 内置生成安全的 RTMP 推流地址
  • ARM64 支持
  • 支持 RTMP 协议直播推流
  • 支持后台推流

内容摘要

快速开始

先来看看 PLAudioStreamingKit 接入的步骤

配置工程

  • 配置你的 Podfile 文件,添加如下配置信息
pod 'PLAudioStreamingKit'
  • 安装 CocoaPods 依赖
pod install

pod update
  • Done! 运行你工程的 workspace

示例代码

在需要的地方添加

#import <PLAudioStreamingKit/PLAudioStreamingKit.h>

PLAudioStreamingSession 是核心类,你只需要关注并使用这个类就可以完成通过摄像头推流、预览的工作

推流前务必要先检查麦克风的授权,StreamingSession 的创建需要 Stream 对象和 Publish host

// Stream 对象,正常情况该对象是从自有的服务端请求拿到的
PLStream *stream = [PLStream streamWithJSON:@{@"id": @"STREAM_ID",
                                              @"title": @"STREAM_TITLE",
                                              @"hub": @"HUB_NAME",
                                              @"publishKey": @"PUBLISH_KEY",
                                              @"publishSecurity": @"dynamic", // or static
                                              @"disabled": @(NO)}];

// Publish host
NSString *publishHost = @"YOUR_RTMP_PUBLISH_HOST";

// 授权后执行
void (^permissionBlock)(void) = ^{
        PLAudioStreamingConfiguration *configuration = [PLAudioStreamingConfiguration defaultConfiguration];
        self.session = [[PLAudioStreamingSession alloc] initWithConfiguration:configuration
                                                                        stream:stream
                                                               rtmpPublishHost:publishHost];
        self.session.delegate = self;
};

void (^noPermissionBlock)(void) = ^{ // 处理未授权情况 };
    
// 检查麦克风是否有授权
PLAuthorizationStatus status = [PLAudioStreamingSession microphoneAuthorizationStatus];

if (PLAuthorizationStatusNotDetermined == status) {
    [PLAudioStreamingSession requestMicrophoneAccessWithCompletionHandler:^(BOOL granted) {
        granted ? permissionBlock() : noPermissionBlock();
    }];
} else if (PLAuthorizationStatusAuthorized == status) {
    permissionBlock();
} else {
	noPermissionBlock();
}

推流操作

// 开始推流,无论 security policy 是 static 还是 dynamic,都无需再单独计算推流地址
[self.session startWithCompleted:^(BOOL success) {
	// 这里的代码在主线程运行,所以可以放心对 UI 控件做操作
	if (success) {
		// 连接成功后的处理
		// 成功后,在这里才可以读取 self.session.pushURL,start 失败和之前不能确保读取到正确的 URL
	} else {
    	// 连接失败后的处理
	}
}];

// 停止推流
[self.session stop];

销毁推流 Session

[self.session destroy];

后台推流

PLAudioStreamingKit 提供了两种后台模式,分别为:

typedef NS_ENUM(NSUInteger, PLAudioStreamingBackgroundMode) {
    PLAudioStreamingBackgroundModeAutoStop = 0,
    PLAudioStreamingBackgroundModeKeepAlive,
    PLAudioStreamingBackgroundModeDefault = PLAudioStreamingBackgroundModeAutoStop
};

如需 App 进入后台后仍然可以持续推流,只需要简单的配置即可。

// 将 PLAudioStreamingSession 实例的 backgroundMode 设置为 PLAudioStreamingBackgroundModeKeepAlive
self.session.backgroundMode = PLAudioStreamingBackgroundModeKeepAlive;

开启工程的 Background Modes 中的 Audio and AirPlay

BackgroundMode

现在当你的 App 正在推流时,进入后台或关闭屏幕后,推流都将继续。

你可以通过实现 delegate 的方法来获取即将开始后台推流任务和即将结束后台推流任务的回调

- (void)audioStreamingSessionWillBeginBackgroundTask:(PLAudioStreamingSession *)session;
- (void)audioStreamingSession:(PLAudioStreamingSession *)session willEndBackgroundTask:(BOOL)isExpirationOccurred;

编码参数

初始化 PLAudioStreamingConfiguration 时,可以指定 Bitrate

typedef NS_ENUM(NSUInteger, PLStreamingAudioBitRate) {
    PLStreamingAudioBitRate_64Kbps = 64000,
    PLStreamingAudioBitRate_96Kbps = 96000,
    PLStreamingAudioBitRate_128Kbps = 128000,
    PLStreamingAudioBitRate_Default = PLStreamingAudioBitRate_128Kbps
};

默认的 configuration 使用 128Kbps 码率。

当前版本采样率恒定为 44100

文档支持

PLAudioStreamingKit 通过 HeaderDoc 直接实现文档支持。 开发者无需单独查阅文档,直接通过 Xcode 就可以查看接口和类的相关信息,减少不必要的麻烦。

Encode 推荐

系统要求

  • iOS Target : >= iOS 7

版本历史

  • 1.1.6 (Release Notes) && (API Diffs)
    • 修复 URL 错误时导致的崩溃
    • 去除 SIGPIPE 断点
    • 更新 Stream 结构
    • 更新初始化 StreamingSession 的接口
  • 1.1.5 (Release Notes) && (API Diffs)
    • 修复断网后停止流时导致的 UI 卡死
    • 修复停止推流时概率出现的 crash 问题
    • 修复反复进出持有 streamingSession 的 viewController 出现 IO 错误或者 crash 的问题
    • 修复开始推流时因主线程占用导致网络不佳时的卡顿问题
    • 添加 - (void)destroy 方法到 PLAudioStreamingSession
    • 恢复了 96Kbps 的音频码率
  • 1.1.4 (Release Notes) && (API Diffs)
    • 更新麦克风调用,提升启动和停用麦克风的效率
  • 1.1.3 (Release Notes) && (API Diffs)
    • 修复暂停麦克风时出现的卡顿问题
  • 1.1.2 (Release Notes) && (API Diffs)
    • 修复在未推流情况下进入后台仍占用音频资源的问题
  • 1.1.1 (Release Notes) && (API Diffs)
    • 添加后台推流支持
    • 添加后台任务的回调
  • 1.1.0 (Release Notes) && (API Diffs)
    • 添加了 PLStream 类,支持 Coding 协议便于打包存储
    • 更新 StreamingSession 创建方法,借助传递 PLStream 对象再无需推流时等待服务端生成推流地址
  • 1.0.2 (Release Notes) && (API Diffs)
    • 更新 repo 地址
  • 1.0.1 (Release Notes) && (API Diffs)
    • 修复杂音问题
  • 1.0.0 (Release Notes)
    • 发布 CocoaPods 版本