以下是我在日志中看到的内容:
16:33:20.236: Call is Dialing
16:33:21.088: AVAudioSessionInterruptionNotification
16:33:21.450: AVAudioSessionRouteChangeNotification
16:33:21.450: ....change reason CategoryChange
16:33:21.539: AVAudioEngineConfigurationChangeNotification
16:33:21.542: Starting Audio Engine
16:33:23.863: AVAudioSessionRouteChangeNotification
16:33:23.863: ....change reason OldDeviceUnavailable
16:33:23.860 ERROR: [0x100a70000] AVAudioIONodeImpl.mm:317: ___ZN13AVAudioIOUnit11GetHWFormatEjPj_block_invoke: required condition is false: hwFormat
*** Terminating app due to uncaught exception 'com.apple.coreaudio.avfaudio', reason: 'required condition is false: hwFormat'
我已订阅AVAudioEngineConfigurationChangeNotification
,AVAudioSessionInterruptionNotification
:
@objc private func handleAudioEngineConfigurationChangeNotification(notification: NSNotification) {
println2(notification.name)
makeEngineConnections()
startEngine()
}
@objc private func handleAudioSessionInterruptionNotification(notification: NSNotification) {
println2(notification.name)
if let interruptionType = AVAudioSessionInterruptionType(rawValue: notification.userInfo?[AVAudioSessionInterruptionTypeKey] as! UInt) {
switch interruptionType {
case .Began:
audioPlayerNode.stop()
case .Ended:
if let interruptionOptionValue = notification.userInfo?[AVAudioSessionInterruptionOptionKey] as? UInt {
let interruptionOption = AVAudioSessionInterruptionOptions(interruptionOptionValue)
if interruptionOption == AVAudioSessionInterruptionOptions.OptionShouldResume {
AVAudioSession.sharedInstance().setActive(true, error: nil)
startEngine()
}
}
}
}
}
func startEngine() {
println2("Starting Audio Engine")
var error: NSError?
if !audioEngine.running {
audioEngine.startAndReturnError(&error)
if let error = error {
println2("Error initializing Audio Engine: " + error.localizedDescription)
}
}
}
private func makeEngineConnections() {
let mainMixer = audioEngine.mainMixerNode
audioEngine.connect(audioPlayerNode, to: audioEqNode, format: mainMixer.outputFormatForBus(0))
audioEngine.connect(audioEqNode, to: audioTimePitch, format: mainMixer.outputFormatForBus(0))
audioEngine.connect(audioTimePitch, to: mainMixer, format: mainMixer.outputFormatForBus(0))
}
但它似乎不起作用。
如何避免此次崩溃?
答案 0 :(得分:1)
我怀疑问题在这里:
audioEngine.connect(audioTimePitch, to: mainMixer, format: mainMixer.outputFormatForBus(0))
此方法调用connect:to:fromBus:toBus:format:使用总线0作为源音频节点,使用总线0作为目标音频节点,但目的地是混音器的情况除外,在这种情况下destination是混音器的nextAvailableInputBus。