0

我正在将 OS X 上的外部解码库中的音频写入 AIFF 文件,并且我能够使用OSSwapInt32()交换数据的字节顺序。

生成的 AIFF 文件(16 位 PCM 立体声)会播放,但左右声道交换了。

当我写每个缓冲区时,有什么方法可以交换通道吗?

这是相关的循环:

do
    {
        xmp_get_frame_info(writer_context, &writer_info);
        if (writer_info.loop_count > 0)
        break;


    writeModBuffer.mBuffers[0].mDataByteSize = writer_info.buffer_size;
    writeModBuffer.mBuffers[0].mNumberChannels = inputFormat.mChannelsPerFrame;

    // Set up our buffer to do the endianness swap
    void *new_buffer;
    new_buffer = malloc((writer_info.buffer_size) * inputFormat.mBytesPerFrame);
    int *ourBuffer = writer_info.buffer;
    int *ourNewBuffer = new_buffer;
    memset(new_buffer, 0, writer_info.buffer_size);
    int i;

    for (i = 0; i <= writer_info.buffer_size; i++)
    {
        ourNewBuffer[i] = OSSwapInt32(ourBuffer[i]);
    };

    writeModBuffer.mBuffers[0].mData = ourNewBuffer;
    frame_size = writer_info.buffer_size / inputFormat.mBytesPerFrame;

    err = ExtAudioFileWrite(writeModRef, frame_size, &writeModBuffer);

} while (xmp_play_frame(writer_context) == 0);
4

1 回答 1

0

This solution is very specific to 2 channel audio. I chose to do it at the same time you're looping to change the byte ordering to avoid an extra loop. I'm going through the loop 1/2 the number and processing two samples per iteration. The samples are interleaved so I copy from odd sample indexes into even sample indexes and vis-a-versa.

for (i = 0; i <= writer_info.buffer_size/2; i++)
{
    ourNewBuffer[i*2] = OSSwapInt32(ourBuffer[i*2 + 1]);
    ourNewBuffer[i*2 + 1] = OSSwapInt32(ourBuffer[i*2]);
};

An alternative is to use a table lookup for channel mapping.

于 2015-06-16T23:07:06.833 回答