MP4学习(十)ts-mp4源码阅读(8)其他box的解析

其他box的解析



常见的MP4结构图






其他box的解析流程


    解析过程是类似的:
        1、假设该box的名字叫xxx box,例如mdia box
        2、如果它是container box,就调用mp4_read_xxx_atom,该函数内部会调用mp4_read_atom,进行下面的操作
            (1)读取这个container box的头部
            (2)分别读取container box中的所有子box
        3、如果它是普通的box,就调用mp4_read_xxx_atom,进行下面操作:
            (1)读取该box的所有数据
            (2)如果有需要,就设置xxx box对应的结构体的成员的值


container box的解析


/*
** 对mdia box的处理,会转换成对mdhd box、hdlr、minf box的处理
** 也就是mp4_read_mdia_atom会间接调用 mp4_read_mdhd_atom、 mp4_read_hdlr_atom、mp4_read_minf_atom
*/
int
Mp4Meta::mp4_read_mdia_atom(int64_t atom_header_size, int64_t atom_data_size)
{
    Mp4Trak             *trak;

    trak = trak_vec[trak_num-1];

    trak->mdia_atom.buffer = TSIOBufferCreate();
    trak->mdia_atom.reader = TSIOBufferReaderAlloc(trak->mdia_atom.buffer);

    TSIOBufferCopy(trak->mdia_atom.buffer, meta_reader, atom_header_size, 0);
    mp4_meta_consume(atom_header_size);

	/* 
	** 内部根据mp4_mdia_atoms(即mdia box)的定义,分别调用:
	** mp4_read_mdhd_atom、mp4_read_hdlr_atom、mp4_read_minf_atom
	*/ 
    return mp4_read_atom(mp4_mdia_atoms, atom_data_size);
}



普通box的解析


int
Mp4Meta::mp4_read_tkhd_atom(int64_t atom_header_size, int64_t atom_data_size)
{
    int64_t             atom_size;
    Mp4Trak             *trak;

    atom_size = atom_header_size + atom_data_size;

    trak = trak_vec[trak_num-1];
    trak->tkhd_size = atom_size;

    trak->tkhd_atom.buffer = TSIOBufferCreate();
    trak->tkhd_atom.reader = TSIOBufferReaderAlloc(trak->tkhd_atom.buffer);

    TSIOBufferCopy(trak->tkhd_atom.buffer, meta_reader, atom_size, 0);
    mp4_meta_consume(atom_size);

	// 读取tkhd box,其中offsetof可以取出结构体中某个成员相对于起始地址的偏移量
    mp4_reader_set_32value(trak->tkhd_atom.reader,
                           offsetof(mp4_tkhd_atom, size), atom_size);

    return 1;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TS-Concat(Transport Stream Concatenation)是一种用于传输多节目流(MPTS)的技术,它允许将多个TS流串联在一起传输,从而实现多节目流的无缝切换。在接收端,需要对TS-Concat头部进行解析,以便正确地处理多节目流的数据。 TS-Concat头部由一个或多个TS-Concat段组成,每个TS-Concat段包含了拼接类型、拼接标识符、拼接长度等信息。在解析TS-Concat头部时,需要首先检查是否存在TS-Concat段,如果存在,则需要依次解析每个TS-Concat段。 具体的解析过程如下: 1. 检查TS-Concat头部是否存在,如果存在则提取出TS-Concat段的数量。 2. 对于每个TS-Concat段,首先解析拼接类型。拼接类型包括三种:点对点(Point-to-Point)、点对多(Point-to-Multipoint)和多对一(Multipoint-to-Point)。不同的拼接类型决定了后续的处理方式。 3. 解析拼接标识符和拼接长度。拼接标识符用于标识不同的拼接段,拼接长度表示该拼接段所包含的TS Packet数量。 4. 根据拼接类型和拼接标识符,进行PID映射。如果是点对点的拼接类型,则需要将原始的PID映射到新的PID;如果是点对多或多对一的拼接类型,则需要根据拼接标识符进行PID映射。 5. 根据拼接长度,判断拼接段的结束位置。如果拼接长度大于0,则表示该拼接段是TS流的一部分;否则表示该拼接段已经结束。 6. 重复步骤2-5,直到解析完所有的TS-Concat段。 总之,在接收端解析TS-Concat头部可以实现多节目流的无缝切换和多码率的传输,为数字电视广播等应用场景提供了更加灵活和高效的解决方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值