| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210 |
- /*
- * Module: TXLivePushConfig @ TXLiteAVSDK
- *
- * Function: 腾讯云直播推流用 RTMP SDK 的参数配置模块
- *
- * Version: <:Version:>
- */
- #import <Foundation/NSObject.h>
- #if TARGET_OS_IPHONE
- #import <UIKit/UIKit.h>
- #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
|