/* * Module: TXLivePushConfig @ TXLiteAVSDK * * Function: 腾讯云直播推流用 RTMP SDK 的参数配置模块 * * Version: <:Version:> */ #import #if TARGET_OS_IPHONE #import #endif #import "TXLiveSDKTypeDef.h" #define CUSTOM_MODE_AUDIO_CAPTURE 0X001 ///> 客户自定义音频采集 #define CUSTOM_MODE_VIDEO_CAPTURE 0X002 ///> 客户自定义视频采集 #define CUSTOM_MODE_AUDIO_PREPROCESS 0X004 ///> 客户自定义音频处理 #define CUSTOM_MODE_VIDEO_PREPROCESS 0X008 ///> 客户自定义视频处理 #define TXRTMPSDK_LINKMIC_STREAMTYPE_MAIN 1 ///> 连麦模式下主播的流 #define TXRTMPSDK_LINKMIC_STREAMTYPE_SUB 2 ///> 连麦模式下连麦观众的流 /** * 腾讯云直播推流用 RTMP SDK 的参数配置模块 * * 主要负责 TXLivePusher 对应的参数设置,其中绝大多数设置项在推流开始之后再设置是无效的。 */ @interface TXLivePushConfig : NSObject ///////////////////////////////////////////////////////////////////////////////// // // 常用设置项 // ///////////////////////////////////////////////////////////////////////////////// ///【字段含义】HOME 键所在方向,用来切换横竖屏推流,默认值:HOME_ORIENTATION_DOWN(竖屏推流)。 ///【特别说明】常用的还有 HOME_ORIENTATION_RIGHT 和 HOME_ORIENTATION_LEFT,也就是横屏推流。 /// 改变该字段的设置以后,本地摄像头的预览画面方向也会发生改变,请调用 TXLivePush 的 setRenderRotation 进行矫正。 @property(nonatomic, assign) int homeOrientation; ///【字段含义】是否允许点击曝光聚焦,默认值:NO。 @property(nonatomic, assign) BOOL touchFocus; ///【字段含义】是否允许双指手势放大预览画面,默认值:NO。 @property(nonatomic, assign) BOOL enableZoom; ///【字段含义】水印图片,设为 nil 等同于关闭水印。 @property(nonatomic, retain) TXImage *watermark; ///【字段含义】水印图片位置,水印大小为图片实际大小,待废弃,推荐使用 watermarkNormalization。 @property(nonatomic, assign) CGPoint watermarkPos; ///【字段含义】水印图片相对于推流分辨率的归一化坐标 ///【推荐取值】假设推流分辨率为:540x960,该字段设置为:(0.1,0.1,0.1,0.0),那么水印的实际像素坐标为: /// (540 × 0.1, 960 × 0.1, 水印宽度 × 0.1, 水印高度会被自动计算) ///【特别说明】watermarkNormalization 的优先级高于 watermarkPos。 @property(nonatomic, assign) CGRect watermarkNormalization; ///////////////////////////////////////////////////////////////////////////////// // // 垫片推流(App 切后台) // ///////////////////////////////////////////////////////////////////////////////// ///【字段含义】垫片推流的最大持续时间,单位秒,默认值:300s。 ///【特别说明】调用 TXLivePusher 的 pausePush() 接口,会暂停摄像头采集并进入垫片推流状态,如果该状态一直保持, /// 可能会消耗主播过多的手机流量,本字段用于指定垫片推流的最大持续时间,超过后即断开与云服务器的连接。 @property(nonatomic, assign) int pauseTime; ///【字段含义】垫片推流时的视频帧率,取值范围3 - 8,默认值:5 FPS。 @property(nonatomic, assign) int pauseFps; ///【字段含义】垫片推流时使用的图片素材,最大尺寸不能超过1920 x 1920。 @property(nonatomic, retain) TXImage *pauseImg; ///////////////////////////////////////////////////////////////////////////////// // // 音视频编码参数 // ///////////////////////////////////////////////////////////////////////////////// ///【字段含义】视频分辨率,默认值:VIDEO_RESOLUTION_TYPE_360_640。 ///【特别说明】推荐直接使用 TXLivePusher 的 setVideoQuality 接口调整画面质量。 @property(nonatomic, assign) int videoResolution; ///【字段含义】视频帧率,默认值:15FPS。 ///【特别说明】推荐直接使用 TXLivePusher 的 setVideoQuality 接口调整画面质量。 @property(nonatomic, assign) int videoFPS; ///【字段含义】视频编码 GOP,也就是常说的关键帧间隔,单位:秒;默认值:3s。 ///【特别说明】推荐直接使用 TXLivePusher 的 setVideoQuality 接口调整画面质量。 @property(nonatomic, assign) int videoEncodeGop; ///【字段含义】视频编码的平均码率,默认值:700kbps。 ///【特别说明】推荐直接使用 TXLivePusher 的 setVideoQuality 接口调整画面质量。 @property(nonatomic, assign) int videoBitratePIN; ///【字段含义】码率自适应开关,开启后,SDK 会根据网络情况自动调节视频码率,调节范围在 (videoBitrateMin - videoBitrateMax)。 ///【推荐取值】NO @property(nonatomic, assign) BOOL enableAutoBitrate; ///【字段含义】码率自适应算法 ///【推荐取值】AUTO_ADJUST_BITRATE_STRATEGY_1 @property(nonatomic, assign) int autoAdjustStrategy; ///【字段含义】码率自适应 - 最高码率,默认值:1000kpbs @property(nonatomic, assign) int videoBitrateMax; ///【字段含义】码率自适应 - 最低码率,默认值:400kpbs ///【推荐取值】不要设置太低的数值,过低的码率会导致运动画面出现大面积马赛克。 @property(nonatomic, assign) int videoBitrateMin; ///【字段含义】音频采样率,采样率越高音质越好,对于有音乐的场景请使用48000的采样率。 ///【推荐取值】AUDIO_SAMPLE_RATE_48000 @property(nonatomic, assign) int audioSampleRate; ///【字段含义】音频声道数,默认值:1(单声道)。 @property(nonatomic, assign) int audioChannels; ///【字段含义】是否开启耳返特效 ///【推荐取值】NO ///【特别说明】开启耳返会消耗更多的 CPU,只有在主播带耳机唱歌的时候才有必要开启此功能。 @property(nonatomic, assign) BOOL enableAudioPreview; ///【字段含义】是否为纯音频推流 ///【推荐取值】NO ///【特别说明】如果希望实现纯音频推流的功能,需要在推流前就设置该参数,否则播放端会有兼容性问题。 @property(nonatomic, assign) BOOL enablePureAudioPush; ///////////////////////////////////////////////////////////////////////////////// // // 网络相关参数 // ///////////////////////////////////////////////////////////////////////////////// ///【字段含义】推流遭遇网络连接断开时 SDK 默认重试的次数,取值范围1 - 10,默认值:3 @property(nonatomic, assign) int connectRetryCount; ///【字段含义】网络重连的时间间隔,单位秒,取值范围3 - 30,默认值:3 @property(nonatomic, assign) int connectRetryInterval; ///////////////////////////////////////////////////////////////////////////////// // // 自定义采集和处理 // ///////////////////////////////////////////////////////////////////////////////// ///【字段含义】自定义采集和自定义处理开关 ///【特别说明】该字段需要使用与运算符进行级联操作(自定义采集和自定义处理不能同时开启): /// 开启自定义视频采集:_config.customModeType |= CUSTOM_MODE_VIDEO_CAPTURE; /// 开启自定义音频采集:_config.customModeType |= CUSTOM_MODE_AUDIO_CAPTURE; @property(nonatomic, assign) int customModeType; ///【字段含义】仅开启自定义采集时有效,用于设置编码分辨率。 ///【特别说明】此值设置需与调用 sendVideoSampleBuffer 时传入的 SampleBuffer 的宽高比一致,否则会引起画面变形。 /// 如果指定 autoSampleBufferSize 为 YES,则不需要设置该字段。 @property(assign) CGSize sampleBufferSize; ///【字段含义】仅开启自定义采集时有效,YES 代表编码分辨率等于输入的 SampleBuffer 的分辨率,默认值:NO。 @property BOOL autoSampleBufferSize; ///////////////////////////////////////////////////////////////////////////////// // // 专业设置项(慎用) // ///////////////////////////////////////////////////////////////////////////////// ///【字段含义】是否开启噪声抑制(注意:早期版本引入了拼写错误,考虑到接口兼容一直没有修正,正确拼写应该是 ANS) ///【推荐取值】NO:ANS 对于直播环境中由其它设备外放的音乐是不友好的,通过 playBGM 设置的背景音不受影响。 ///【特别说明】如果直播场景只有主播在说话,ANS 有助于让主播的声音更清楚,但如果主播在吹拉弹唱,ANS 会损伤乐器的声音。 @property(nonatomic, assign) BOOL enableNAS; ///【字段含义】是否开启回声抑制 ///【推荐取值】NO:回声抑制会启用通话模式音量,导致音质变差,非连麦场景下请不要开启。 ///【特别说明】只有在连麦模式下才需要开启 AEC,如果是普通的直播,将主播的手机和观众的手机放在一起所产生的啸叫是正常现象。 @property(nonatomic, assign) BOOL enableAEC; ///【字段含义】开启视频硬件加速, 默认值:YES。 @property(nonatomic, assign) BOOL enableHWAcceleration; ///【字段含义】开启音频硬件加速, 默认值:YES。 @property(nonatomic, assign) BOOL enableAudioAcceleration; ///////////////////////////////////////////////////////////////////////////////// // // 待废弃设置项 // ///////////////////////////////////////////////////////////////////////////////// ///【字段含义】是否前置摄像头,待废弃,建议直接使用 TXLivePusher 的 frontCamera 属性和 switchCamera 函数。 @property(nonatomic, assign) BOOL frontCamera; ///【字段含义】美颜强度,待废弃,建议直接使用 TXLivePusher 的 setBeautyStyle 函数。 @property(nonatomic, assign) float beautyFilterDepth; ///【字段含义】美白强度,待废弃,建议直接使用 TXLivePusher 的 setBeautyStyle 函数。 @property(nonatomic, assign) float whiteningFilterDepth; ///【字段含义】是否开启就近选路,待废弃,默认值:YES。 @property(nonatomic, assign) BOOL enableNearestIP; ///【字段含义】RTMP 传输通道的类型,待废弃,默认值为:AUTO。 @property (nonatomic, assign) int rtmpChannelType; @end