所以我想将 -1 到 +1 范围内的浮点数正确缩放为 AUGraph 所期望的格式,其流格式设置如下:
size_t bytesPerSample = sizeof (AudioUnitSampleType); // is 4 bytes
stereoStreamFormat.mFormatID = kAudioFormatLinearPCM;
stereoStreamFormat.mFormatFlags = kAudioFormatFlagsAudioUnitCanonical;
stereoStreamFormat.mBytesPerPacket = bytesPerSample;
stereoStreamFormat.mFramesPerPacket = 1;
stereoStreamFormat.mBytesPerFrame = bytesPerSample;
stereoStreamFormat.mChannelsPerFrame = 2;
stereoStreamFormat.mBitsPerChannel = 8 * bytesPerSample;
stereoStreamFormat.mSampleRate = graphSampleRate; // 44.1k
这个问题帮助我设置了图表,但是当我像这样投射浮点数时:
sampleValueLeft = (Fixed) (floatVal * 32767.0f);
// there doesn't seem to be any difference whether i cast into
// SInt16 or SInt32 (which the Fixed type is defined to be)..
它工作,信号听起来不错,但很安静。所以我做错了缩放?以更大的数字缩放会扰乱信号。听起来不像削波,输出音量也没有变高。我不打算深入研究定点数学,我所需要的只是一个可以转换成正确格式的单行。
谢谢你!
编辑:我一直在使用不同的流格式,在此之前我无法弄清楚如何正确使用立体声信号。使用这种不同的设置,我对输出音量没有任何问题,所以我认为增益问题一定与缩放有关......