输入:来自嵌入式系统的编码器芯片的ogg / vorbis流。
问题:创建一秒钟的输出块而不进行代码转换。
问题:正在“中间”读取流,因此带有BOS(流的开头)的第一页不可用。由于编码器芯片始终具有相同的参数,因此我想使用从头开始读取的流(参考流)的BOS页面重新创建BOS页面。
我正在尝试使用vcut。我对其进行了修改,以便创建一秒钟的无限块。这很容易,并且可以与BOS一起处理文件和流。我还对它进行了修改,以便将参考流的第一页写入文件,然后在不使用BOS读取生产流之前对其进行读取。这样,将填充vs-> header。当我检测到页面序列号更改时,会对其进行更改,以使vcut和libogg不会出现异常:
int process_page(vcut_state *s, ogg_page *page) {
...
else if(vs->serial != ogg_page_serialno(page))
{
// fprintf(stderr, _("Multiplexed bitstreams are not supported.\n"));
vs->stream_in.serialno = ogg_page_serialno(page);
vs->serial = ogg_page_serialno(page);
vs->granulepos = -1;
vs->initial_granpos = 0;
// ogg_stream_init(&vs->stream_in, vs->serial);
// vorbis_info_init(&vs->vi);
// vorbis_comment_init(&vs->vc);
s->vorbis_init = 1;
}
但是,这种巨大的破解不起作用。如何解决这个问题?
实际上有效:请参见VS1053 split ogg。
我需要考虑的是,从溪流中间开始阅读时,颗粒度自然很高。因此,这是我的逻辑错误。
在process_audio_packet中,我添加了:
int process_audio_packet(vcut_state *s,
vcut_vorbis_stream *vs, ogg_packet *packet)
{
...
if(packet->granulepos >= 0)
{
if (!firstNonZeroGranule) { // my addition
firstNonZeroGranule = 1;
vs->initial_granpos = packet->granulepos - bs;
if(vs->initial_granpos < 0)
vs->initial_granpos = 0;
} else if(vs->granulepos == 0 && packet->granulepos != bs) {
...