AVAudioSession+KSY.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. //
  2. // AVAudioSession+KSY.h
  3. // Pods
  4. //
  5. // Created by iVermisseDich on 2017/2/27.
  6. //
  7. //
  8. #import <AVFoundation/AVFoundation.h>
  9. #import "KSYTypeDef.h"
  10. /** iOS的AVAudioSession 属性配置工具类
  11. 1. 主要是保证推流时有采集和播放音频的权限 AVAudioSessionCategoryPlayAndRecord
  12. 2. 将一些常用的AVAudioSession的配置项提取为属性, 方便设置
  13. 3. 提供查询和修改当前音频采集设备相关的工具函数 比如查询是否有耳机
  14. */
  15. @interface AVAudioSession (KSY)
  16. /**
  17. @abstract 设置默认配置
  18. @discussion bInterruptOtherAudio : NO
  19. @discussion bDefaultToSpeaker : YES
  20. @discussion bAllowBluetooth : YES
  21. @discussion AVAudioSessionCategory : AVAudioSessionCategoryPlayAndRecord
  22. */
  23. - (void)setDefaultCfg;
  24. /**
  25. @abstract 是否打断其他后台的音乐播放 (默认为NO)
  26. @discussion 也可以理解为是否允许在其他后台音乐播放的同时进行采集
  27. @discussion YES:开始采集时,会打断其他的后台播放音乐,也会被其他音乐打断(采集过程中,启动其他音乐播放,音频采集被中止)
  28. @discussion NO: 可以与其他后台播放共存,相互之间不会被打断
  29. @discussion 参考 AVAudioSessionCategoryOptionMixWithOthers
  30. */
  31. @property (nonatomic, assign) BOOL bInterruptOtherAudio;
  32. /**
  33. @abstract 启动采集后,是否从扬声器播放声音 (默认为YES)
  34. @discussion 启动声音采集后,iOS系统的行为是默认从听筒播放声音的
  35. @discussion 将该属性设为YES, 则改为默认从扬声器播放
  36. @discussion 参考 AVAudioSessionCategoryOptionDefaultToSpeaker
  37. */
  38. @property (nonatomic, assign) BOOL bDefaultToSpeaker;
  39. /**
  40. @abstract 是否启用蓝牙设备 (默认为YES)
  41. @discussion 参考 AVAudioSessionCategoryOptionAllowBluetooth
  42. */
  43. @property (nonatomic, assign) BOOL bAllowBluetooth;
  44. /**
  45. @abstract 本SDK使用的AVAudioSession的类别 (默认为AVAudioSessionCategoryPlayAndRecord)
  46. @discussion 用于指定推流过程中需要采集和播放音频的权限
  47. @warning 如无必要请勿修改
  48. */
  49. @property (nonatomic, assign) NSString * AVAudioSessionCategory;
  50. #pragma mark - audio input ports
  51. /**
  52. @abstract 是否有蓝牙麦克风可用
  53. @return 是/否有蓝牙麦克风可用
  54. */
  55. + (BOOL)isBluetoothInputAvaible;
  56. /**
  57. @abstract 选择是否使用蓝牙麦克风
  58. @param onOrOff : YES 使用蓝牙麦克风 NO
  59. @return 是/否有蓝牙麦克风可用
  60. */
  61. + (BOOL)switchBluetoothInput:(BOOL)onOrOff;
  62. /**
  63. @abstract 是否有耳机麦克风可用
  64. @return 是/否有耳机麦克风
  65. */
  66. + (BOOL)isHeadsetInputAvaible;
  67. /**
  68. @abstract 查询当前是否有耳机(包括蓝牙耳机)
  69. */
  70. + (BOOL) isHeadsetPluggedIn;
  71. /**
  72. @abstract 当前使用的音频采集设备
  73. @discussion 当设置新值时, 如果修改成功, 重新查询为新值, 修改不成功值不变
  74. @discussion 参考 KSYMicType
  75. */
  76. @property KSYMicType currentMicType;
  77. @end