gpt4 book ai didi

iphone - 使用 AQ 和音频文件流动态检测和流式传输 AAC

转载 作者:搜寻专家 更新时间:2023-10-30 20:27:06 25 4
gpt4 key购买 nike

我目前正在播放 MP3 和 AAC 广播电台。我正在读取 ICY/HTTP header ,并且在检测内容类型中的音频/aac 或音频/aacp 时,我提供 kAudioFileAAC_ADTSType 作为 AudioFileStreamOpen 的线索,否则我给它 kAudioFileMP3Type。

它工作得很好,问题是当电台正在播放 AAC 时,但没有在 HTTP header 中将音频/aacp 作为内容类型发送。当发生这种情况时,我通常使用 mp3 线索创建音频文件流(0 作为线索也没有什么不同),然后音频文件流的属性回调表明流认为它正在读取 MP3,格式列表回调也从不发生,当时间到了创建音频队列失败。

有没有办法让 AudioFileStream 与 A​​AC 一起工作,而无需在其构造函数中传递 AAC 提示,或者除了在我的电台数据库中以某种方式标记它们之外,是否有人对如何检测这些电台有任何其他想法?每次我正常失败时,我也不想尝试创建一个带有 AAC 的新音频文件流作为提示。

最佳答案

我有一段时间没看过这段代码了,但我认为它应该可以解决问题。

// the file stream parser is now ready to produce audio packets.
// get the stream format.
AudioFormatListItem afli = GetFirstPlayableAudioFormatForFile(inAudioFileStream);
AudioStreamBasicDescription asbd = afli.mASBD;
...
// create the audio queue
err = AudioQueueNewOutput(&asbd, MyAudioQueueOutputCallback, myData, NULL, NULL, 0, &myData->audioQueue);

GetFirstPlayableAudioFormatForFile 实现:

AudioFormatListItem GetFirstPlayableAudioFormatForFile(AudioFileStreamID inAudioFileStream)
{
AudioFormatListItem *formatListPtr = NULL;
AudioFormatListItem formatItem = {0};
UInt32 propertySize;

OSStatus status = noErr;

if (NULL == inAudioFileStream) return formatItem;

status = AudioFileStreamGetPropertyInfo(inAudioFileStream, kAudioFileStreamProperty_FormatList, &propertySize, NULL);
if (noErr == status) {

// allocate memory for the format list items
formatListPtr = (AudioFormatListItem *)malloc(propertySize);
if (NULL == formatListPtr) return formatItem;

// get the list of Audio Format List Item's
status = AudioFileStreamGetProperty(inAudioFileStream, kAudioFileStreamProperty_FormatList, &propertySize, formatListPtr);
if (noErr == status) {
// print out some helpful information
UInt32 numFormats = propertySize / sizeof(AudioFormatListItem);
printf ("This file has a %d layered data format:\n", (int)numFormats);
/*for (unsigned int i = 0; i < numFormats; ++i) {
CAStreamBasicDescription(formatListPtr[i].mASBD).Print();
}*/

UInt32 itemIndex;
UInt32 indexSize = sizeof(itemIndex);

// get the index number of the first playable format -- this index number will be for
// the highest quality layer the platform is capable of playing
status = AudioFormatGetProperty(kAudioFormatProperty_FirstPlayableFormatFromList, propertySize,
formatListPtr, &indexSize, &itemIndex);
if (noErr == status) {
printf ("Returning AudioFormatListItem at index %d.\n", (int)itemIndex);
// copy the format item at index we want returned
formatItem = formatListPtr[itemIndex];
}
}

free(formatListPtr);
} else {
AudioStreamBasicDescription asbd;
UInt32 asbdSize = sizeof(asbd);
/*status = */AudioFileStreamGetProperty(inAudioFileStream, kAudioFileStreamProperty_DataFormat, &asbdSize, &asbd);
//if (err) { errorDidOccur(myData, err, @"get kAudioFileStreamProperty_DataFormat"); return err; }

formatItem.mASBD = asbd;
}


return formatItem;
}

关于iphone - 使用 AQ 和音频文件流动态检测和流式传输 AAC,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5290696/

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