Android平台RTSP轻量级服务|RTMP推送摄像头或屏幕之音频接口设计

简介: 好多开发者在做Android平台录像或者RTSP轻量级服务、RTMP推送相关模块时,对需要设计哪些常用接口会心存疑惑,本文主要以大牛直播SDK(官方)为例,简单介绍下Android平台直播推送SDK所有音频相关的接口,感兴趣的开发者可以看看。

好多开发者在做Android平台录像或者RTSP轻量级服务、RTMP推送相关模块时,对需要设计哪些常用接口会心存疑惑,本文主要以大牛直播SDK(官方)为例,简单介绍下Android平台直播推送SDK所有音频相关的接口,感兴趣的开发者可以看看。


1. 设置audio编码类型,默认AAC,如需更低的码率,可设置SPEEX编码,一把考虑到录像等操作的通用性,建议选择AAC编码。

    /**
     * Set audio encoder type(设置音频编码类型)
     * 
     * @param type: if with 1:AAC, if with 2: SPEEX
     * 
     * @return {0} if successful
     */
    public native int SmartPublisherSetAudioCodecType(long handle, int type);

2. 设置AAC音频编码码率,不再赘述。

  /**
   * Set audio encoder bit-rate(设置音频编码码率), 当前只对AAC编码有效
   *
   * @param kbit_rate: 码率(单位是kbps), 如果是0的话将使用默认码率, 必须大于等于0
   *
   * @return {0} if successful
   */
  public native int SmartPublisherSetAudioBitRate(long handle, int kbit_rate);

3. 设置SPEEX音频编码质量,一般设置到8即可。

    /**
     * Set speex encoder quality(设置speex编码质量)
     * 
     * @param quality: range with (0, 10), default value is 8
     * 
     * @return {0} if successful
     */
    public native int SmartPublisherSetSpeexEncoderQuality(long handle, int quality);

4. 设置噪音抑制,噪音抑制可用于对采集到的audio数据如杂音背景音的消除

    /**
     * Set Audio Noise Suppression(设置音频噪音抑制)
     * 
     * @param isNS: if with 1:suppress, if with 0: does not suppress
     * 
     * @return {0} if successful
     */
    public native int SmartPublisherSetNoiseSuppression(long handle, int isNS);

5. 设置音频自动增益控制,AGC的目的是,系统可根据声音大小自动适当调整音量,使声音大小尽量保持一致

    /**
     * Set Audio AGC(设置音频自动增益控制)
     * 
     * @param isAGC: if with 1:AGC, if with 0: does not AGC
     * 
     * @return {0} if successful
     */
    public native int SmartPublisherSetAGC(long handle, int isAGC);

6. 设置回音消除,用于一对一互动场景下,消除音频回音

  /**
   * Set Audio Echo Cancellation(设置音频回音消除)
   *
   * @param isCancel: if with 1:Echo Cancellation, if with 0: does not cancel
   *
   * @param delay: echo delay(ms), if with 0, SDK will automatically estimate the delay.
   *
   * @return {0} if successful
   */
  public native int SmartPublisherSetEchoCancellation(long handle, int isCancel, int delay);

7. 设置混音,可用于比如两路音频混音场景,具体可参考一对一互动的demo

  /**
   * 设置混音,目前支持两路音频混音
   *
   * @param is_mix: 1混音, 0不混音, 默认不混音
   *
   * @return {0} if successful
   */
  public native int SmartPublisherSetAudioMix(long handle, int is_mix);

8. 实时静音,实时静音顾名思义,推送过程中,暂停音频推送

    /**
     * Set mute or not during publish stream(设置实时静音)
     * 
     * @param isMute: if with 1:mute, if with 0: does not mute
     * 
     * @return {0} if successful
     */
    public native int SmartPublisherSetMute(long handle, int isMute);


9. 用于设置输入音量,范围是[0.0, 5.0],除非麦克风采集到的audio过小,一般不建议放大,放大的话,会引入噪音等

  /**
   * 设置输入音量, 这个接口一般不建议调用, 在一些特殊情况下可能会用, 一般不建议放大音量
   *
   * @param index: 一般是0和1, 如果没有混音的只用0, 有混音的话, 0,1分别设置音量
   *
   * @param volume: 音量,默认是1.0,范围是[0.0, 5.0], 设置成0静音, 1音量不变
   *
   * @return {0} if successful
   */
  public native int SmartPublisherSetInputAudioVolume(long handle, int index, float volume);

10. 对接外部实时采集的PCM数据,考虑到集成方便,我们提供了以下三个接口,注意PCM音频数据接口每10ms传第一次audio数据

  /**
   * 传递PCM音频数据给SDK, 每10ms音频数据传入一次
   * 
   *  @param pcmdata: pcm数据, 需要使用ByteBuffer.allocateDirect分配, ByteBuffer.isDirect()是true的才行.
   *  @param size: pcm数据大小
   *  @param sample_rate: 采样率,当前只支持{44100, 8000, 16000, 24000, 32000, 48000}, 推荐44100
   *  @param channel: 通道, 当前通道支持单通道(1)和双通道(2),推荐单通道(1)
   *  @param per_channel_sample_number: 这个请传入的是 sample_rate/100
   */
  public native int SmartPublisherOnPCMData(long handle, ByteBuffer pcmdata, int size, int sample_rate, int channel, int per_channel_sample_number);
  /**
   * 传递PCM音频数据给SDK, 每10ms音频数据传入一次
   *
   *  @param pcmdata: pcm数据, 需要使用ByteBuffer.allocateDirect分配, ByteBuffer.isDirect()是true的才行.
   *  @param offset: pcmdata的偏移
   *  @param size: pcm数据大小
   *  @param sample_rate: 采样率,当前只支持{44100, 8000, 16000, 24000, 32000, 48000}, 推荐44100
   *  @param channel: 通道, 当前通道支持单通道(1)和双通道(2),推荐单通道(1)
   *  @param per_channel_sample_number: 这个请传入的是 sample_rate/100
   */
  public native int SmartPublisherOnPCMDataV2(long handle, ByteBuffer pcmdata, int offset, int size, int sample_rate, int channel, int per_channel_sample_number);
  /**
   * 传递PCM音频数据给SDK, 每10ms音频数据传入一次
   *
   *  @param pcm_short_array: pcm数据, short是native endian order
   *  @param offset: 数组偏移
   *  @param len: 数组项数
   *  @param sample_rate: 采样率,当前只支持{44100, 8000, 16000, 24000, 32000, 48000}, 推荐44100
   *  @param channel: 通道, 当前通道支持单通道(1)和双通道(2),推荐单通道(1)
   *  @param per_channel_sample_number: 这个请传入的是 sample_rate/100
   */
  public native int SmartPublisherOnPCMShortArray(long handle, short[] pcm_short_array, int offset, int len, int sample_rate, int channel, int per_channel_sample_number);

11. 设置传远端数据,主要用于一对一环境下,拉流端拉到的audio,回调上来,通过推送端这个接口设置下去,完成整体的回音消除

  /**
   * Set far end pcm data
   * 
   * @param pcmdata : 16bit pcm data
   * @param sampleRate: audio sample rate
   * @param channel: auido channel
   * @param per_channel_sample_number: per channel sample numbers
   * @param is_low_latency: if with 0, it is not low_latency, if with 1, it is low_latency
   * @return {0} if successful
   */
  public native int SmartPublisherOnFarEndPCMData(long handle,  ByteBuffer pcmdata, int sampleRate, int channel, int per_channel_sample_number, int is_low_latency);

12. PCM混音音频数据接口,注意,每10ms音频数据传入一次

  /**
   * 传递PCM混音音频数据给SDK, 每10ms音频数据传入一次
   *
   *  @param stream_index: 当前只能传1, 传其他返回错误
   *  @param pcm_data: pcm数据, 需要使用ByteBuffer.allocateDirect分配, ByteBuffer.isDirect()是true的才行.
   *  @param offset: pcmdata的偏移
   *  @param size: pcm数据大小
   *  @param sample_rate: 采样率,当前只支持{44100, 8000, 16000, 24000, 32000, 48000}
   *  @param channels: 通道, 当前通道支持单通道(1)和双通道(2)
   *  @param per_channel_sample_number: 这个请传入的是 sample_rate/100
   */
  public native int SmartPublisherOnMixPCMData(long handle, int stream_index, ByteBuffer pcm_data, int offset, int size, int sample_rate, int channels, int per_channel_sample_number);
  /**
   * 传递PCM混音音频数据给SDK, 每10ms音频数据传入一次
   *
   *  @param stream_index: 当前只能传1, 传其他返回错误
   *  @param pcm_short_array: pcm数据, short是native endian order
   *  @param offset: 数组偏移
   *  @param len: 数组项数
   *  @param sample_rate: 采样率,当前只支持{44100, 8000, 16000, 24000, 32000, 48000}
   *  @param channels: 通道, 当前通道支持单通道(1)和双通道(2)
   *  @param per_channel_sample_number: 这个请传入的是 sample_rate/100
   */
  public native int SmartPublisherOnMixPCMShortArray(long handle, int stream_index, short[] pcm_short_array, int offset, int len, int sample_rate, int channels, int per_channel_sample_number);

13. 用于编码后audio数据对接,主要是转发模块使用

  /**
   * 设置音频数据(AAC/PCMA/PCMU/SPEEX)
   *
   * @param codec_id:
   *
   *  NT_MEDIA_CODEC_ID_AUDIO_BASE = 0x10000,
   *  NT_MEDIA_CODEC_ID_PCMA = NT_MEDIA_CODEC_ID_AUDIO_BASE,
   *  NT_MEDIA_CODEC_ID_PCMU,
   *  NT_MEDIA_CODEC_ID_AAC,
   *  NT_MEDIA_CODEC_ID_SPEEX,
   *  NT_MEDIA_CODEC_ID_SPEEX_NB,
   *  NT_MEDIA_CODEC_ID_SPEEX_WB,
   *  NT_MEDIA_CODEC_ID_SPEEX_UWB,
   *
   * @param data audio数据
   *
   * @param size data length
   *
   * @param is_key_frame 是否I帧, if with key frame, please set 1, otherwise, set 0, audio忽略
   *
   * @param timestamp video timestamp
   *
   * @param parameter_info 用于AAC special config信息填充
   *
   * @param parameter_info_size parameter info size
   *
   * @return {0} if successful
   */
  public native int SmartPublisherPostAudioEncodedData(long handle, int codec_id, ByteBuffer data, int size, int is_key_frame, long timestamp,ByteBuffer parameter_info, int parameter_info_size);
  /**
   * 设置音频数据(AAC/PCMA/PCMU/SPEEX)
   *
   * @param codec_id:
   *
   *  NT_MEDIA_CODEC_ID_AUDIO_BASE = 0x10000,
   *  NT_MEDIA_CODEC_ID_PCMA = NT_MEDIA_CODEC_ID_AUDIO_BASE,
   *  NT_MEDIA_CODEC_ID_PCMU,
   *  NT_MEDIA_CODEC_ID_AAC,
   *  NT_MEDIA_CODEC_ID_SPEEX,
   *  NT_MEDIA_CODEC_ID_SPEEX_NB,
   *  NT_MEDIA_CODEC_ID_SPEEX_WB,
   *  NT_MEDIA_CODEC_ID_SPEEX_UWB,
   *
   * @param data audio数据
   *
   * @param offset data的偏移
   *
   * @param size data length
   *
   * @param is_key_frame 是否I帧, if with key frame, please set 1, otherwise, set 0, audio忽略
   *
   * @param timestamp video timestamp
   *
   * @param parameter_info 用于AAC special config信息填充
   *
   * @param parameter_info_size parameter info size
   *
   * @return {0} if successful
   */
  public native int SmartPublisherPostAudioEncodedDataV2(long handle, int codec_id,
                               ByteBuffer data, int offset, int size,
                               int is_key_frame, long timestamp,
                               byte[] parameter_info, int parameter_info_size);
    /**
     * 设置音频数据(AAC/PCMA/PCMU/SPEEX)
     *
     * @param codec_id:
     *
     *  NT_MEDIA_CODEC_ID_AUDIO_BASE = 0x10000,
     *  NT_MEDIA_CODEC_ID_PCMA = NT_MEDIA_CODEC_ID_AUDIO_BASE,
     *  NT_MEDIA_CODEC_ID_PCMU,
     *  NT_MEDIA_CODEC_ID_AAC,
     *  NT_MEDIA_CODEC_ID_SPEEX,
     *  NT_MEDIA_CODEC_ID_SPEEX_NB,
     *  NT_MEDIA_CODEC_ID_SPEEX_WB,
     *  NT_MEDIA_CODEC_ID_SPEEX_UWB,
     *
     * @param data audio数据
     *
     * @param offset data的偏移
     *
     * @param size data length
     *
     * @param is_key_frame 是否I帧, if with key frame, please set 1, otherwise, set 0, audio忽略
     *
     * @param timestamp video timestamp
     *
     * @param parameter_info 用于AAC special config信息填充
     *
     * @param parameter_info_size parameter info size
     *
     * @param sample_rate 采样率,如果需要录像的话必须传正确的值
     *
     *@param channels 通道数, 如果需要录像的话必须传正确的值, 一般是1或者2
     *
     * @return {0} if successful
     */
    public native int SmartPublisherPostAudioEncodedDataV3(long handle, int codec_id,
                                                           ByteBuffer data, int offset, int size,
                                                           int is_key_frame, long timestamp,
                                                           byte[] parameter_info, int parameter_info_size,
                                                           int sample_rate, int channels);

14. 用于编码后的音频数据回调,方便对接第三方系统

  /**
   * Start output Encoded Data(用于编码后的音视频数据回调)
   *
   * @return {0} if successful
   */
  public native int SmartPublisherStartOutputEncodedData(long handle);
  /**
   *  Stop output Encoded Data
   *
   * @return {0} if successful
   */
  public native int SmartPublisherStopOutputEncodedData(long handle);

总结


细数下来,光audio相关的接口也有20个,可见开发个Android平台RTMP直播推送模块多么麻烦,当然因为本文提到的RTMP推送,实际使用的公司或开发者群体比较大,如果只是项目需求,好多是用不到的,可以适当精简,做个小而美的模块,不失是个很好的选择。

相关文章
|
1月前
|
Java Android开发 Swift
安卓与iOS开发对比:平台选择对项目成功的影响
【10月更文挑战第4天】在移动应用开发的世界中,选择合适的平台是至关重要的。本文将深入探讨安卓和iOS两大主流平台的开发环境、用户基础、市场份额和开发成本等方面的差异,并分析这些差异如何影响项目的最终成果。通过比较这两个平台的优势与挑战,开发者可以更好地决定哪个平台更适合他们的项目需求。
109 1
|
2月前
|
IDE Android开发 iOS开发
探索Android与iOS开发的差异:平台选择对项目成功的影响
【9月更文挑战第27天】在移动应用开发的世界中,Android和iOS是两个主要的操作系统平台。每个系统都有其独特的开发环境、工具和用户群体。本文将深入探讨这两个平台的关键差异点,并分析这些差异如何影响应用的性能、用户体验和最终的市场表现。通过对比分析,我们将揭示选择正确的开发平台对于确保项目成功的重要作用。
|
29天前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
82 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
2月前
|
开发工具 Android开发 iOS开发
安卓与iOS开发环境对比:选择适合你的平台
【9月更文挑战第26天】在移动应用开发的广阔天地中,安卓和iOS是两大巨头。它们各自拥有独特的优势和挑战,影响着开发者的选择和决策。本文将深入探讨这两个平台的开发环境,帮助你理解它们的核心差异,并指导你根据个人或项目需求做出明智的选择。无论你是初学者还是资深开发者,了解这些平台的异同都至关重要。让我们一起探索,找到最适合你的那片开发天地。
|
2月前
|
Android开发 开发者
Android平台无纸化同屏如何实现实时录像功能
Android平台无纸化同屏,如果需要本地录像的话,实现难度不大,只要复用之前开发的录像模块的就可以,对我们来说,同屏采集这块,只是数据源不同而已,如果是自采集的其他数据,我们一样可以编码录像。
|
2月前
|
安全 API 开发工具
Android平台RTMP推送|轻量级RTSP服务如何实现麦克风|扬声器声音采集切换
Android平台扬声器播放声音的采集,在无纸化同屏等场景下,意义很大,早期低版本的Android设备,是没法直接采集扬声器audio的(从Android 10开始支持),所以,如果需要采集扬声器audio,需要先做系统版本判断,添加相应的权限。
|
Android开发
Android RTMP直播推流方案选择
1. 技术科普: RTMP是Real Time Messaging Protocol(实时消息传输协议)的首字母缩写。
2513 0
|
3天前
|
搜索推荐 Android开发 开发者
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。
|
5天前
|
Android开发 Swift iOS开发
探索安卓与iOS开发的差异和挑战
【10月更文挑战第37天】在移动应用开发的广阔舞台上,安卓和iOS这两大操作系统扮演着主角。它们各自拥有独特的特性、优势以及面临的开发挑战。本文将深入探讨这两个平台在开发过程中的主要差异,从编程语言到用户界面设计,再到市场分布的不同影响,旨在为开发者提供一个全面的视角,帮助他们更好地理解并应对在不同平台上进行应用开发时可能遇到的难题和机遇。
|
7天前
|
XML 存储 Java
探索安卓开发之旅:从新手到专家
【10月更文挑战第35天】在数字化时代,安卓应用的开发成为了一个热门话题。本文旨在通过浅显易懂的语言,带领初学者了解安卓开发的基础知识,同时为有一定经验的开发者提供进阶技巧。我们将一起探讨如何从零开始构建第一个安卓应用,并逐步深入到性能优化和高级功能的实现。无论你是编程新手还是希望提升技能的开发者,这篇文章都将为你提供有价值的指导和灵感。