gpt4 book ai didi

swift - 了解 AudioStreamBasicDescription

转载 作者:行者123 更新时间:2023-11-28 05:37:28 26 4
gpt4 key购买 nike

我正在尝试了解 AudioStreamBasicDescription 结果。实际上,我能得到的东西对我来说都没有意义。例如:

AudioStreamBasicDescription(mSampleRate:44100.0,mFormatID:1819304813,mFormatFlags:41,mBytesPerPacket:4,mFramesPerPacket:1,mBytesPerFrame:4,mChannelsPerFrame:2,mBitsPerChannel:32,mReserved:0)

我期望的是:“每包字节数”和“每帧字节数”应该是 8 而不是 4:

4(32 位 float 的大小)x 2(每帧两个 channel )x 1(每个数据包 1 帧)= 8 字节

为什么是 4?

import CoreAudio
import AudioUnit

var inputUnitDescription = AudioComponentDescription(componentType: kAudioUnitType_Output,
componentSubType: kAudioUnitSubType_HALOutput,
componentManufacturer: kAudioUnitManufacturer_Apple,
componentFlags: 0,
componentFlagsMask: 0)
let defaultInput = AudioComponentFindNext(nil, &inputUnitDescription)

var inputUnit: AudioUnit?
AudioComponentInstanceNew(defaultInput!, &inputUnit)

var asbd = AudioStreamBasicDescription()
var propertySize = UInt32(MemoryLayout<AudioStreamBasicDescription>.size)
AudioUnitGetProperty(inputUnit!,
kAudioUnitProperty_StreamFormat,
kAudioUnitScope_Output,
1,
&asbd,
&propertySize)

dump(asbd)

最佳答案

你的 ABSD 有 mFormatFlags == 41 。

如果 (mFormatFlags & 32) != 0 ,这意味着格式包含 kAudioFormatFlagIsNonInterleaved 位。

非交错格式每帧仅返回一个数据通道,而不是 2 个。相反,您会得到多个缓冲区,每个缓冲区每帧只有一个 channel ,或 4 个字节(对于 Float32 格式),而不是 8 个。

关于swift - 了解 AudioStreamBasicDescription,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58192813/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com