TRUN box finished
This commit is contained in:
		
							parent
							
								
									aa352fbe60
								
							
						
					
					
						commit
						ff93aedb98
					
				
					 3 changed files with 72 additions and 2 deletions
				
			
		|  | @ -40,8 +40,8 @@ void Box_tfhd::WriteContent( ) { | |||
|   Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(curTrackId),4); | ||||
|   curoffset = 8; | ||||
|   if( curBaseDataOffset ) { | ||||
|     Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(curTrackId),curoffset); | ||||
|     Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(curTrackId),curoffset+4); | ||||
|     Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(0),curoffset); | ||||
|     Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(curBaseDataOffset),curoffset+4); | ||||
|     curoffset += 8; | ||||
|   } | ||||
|   if( curSampleDescriptionIndex ) { | ||||
|  |  | |||
							
								
								
									
										45
									
								
								MP4/box_trun.cpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								MP4/box_trun.cpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,45 @@ | |||
| #include "box_trun.h" | ||||
| 
 | ||||
| Box_trun::Box_trun( ) { | ||||
|   Container = new Box( 0x74666864 ); | ||||
|   SetDefaults( ); | ||||
| } | ||||
| 
 | ||||
| Box_trun::~Box_trun() { | ||||
|   delete Container; | ||||
| } | ||||
| 
 | ||||
| Box * Box_trun::GetBox() { | ||||
|   return Container; | ||||
| } | ||||
| 
 | ||||
| void Box_trun::SetDataOffset( uint32_t Offset ) { | ||||
|   curDataOffset = Offset; | ||||
| } | ||||
| 
 | ||||
| void Box_trun::WriteContent( ) { | ||||
|   uint32_t curoffset; | ||||
|   uint32_t flags = 0 & ( curDataOffset ? 0x1 : 0 ) & ( setSampleDuration ? 0x100 : 0 ) & ( setSampleSize ? 0x200 : 0 ); | ||||
|   Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(flags)); | ||||
|   Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(SampleInfo.size()),4); | ||||
|   curoffset = 8; | ||||
|   if( curDataOffset ) { | ||||
|     Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(curDataOffset),curoffset); | ||||
|     curoffset += 4; | ||||
|   } | ||||
|   for( uint32_t i = 0; i < SampleInfo.size(); i++ ) { | ||||
|     if( setSampleDuration ) { | ||||
|       Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(SampleInfo[i].SampleDuration),curoffset); | ||||
|       curoffset += 4; | ||||
|     } | ||||
|     if( setSampleSize ) { | ||||
|       Container->SetPayload((uint32_t)4,Box::uint32_to_uint8(SampleInfo[i].SampleSize),curoffset); | ||||
|       curoffset += 4; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| void Box_trun::SetDefaults( ) { | ||||
|   setSampleDuration = false; | ||||
|   setSampleSize = false; | ||||
| } | ||||
							
								
								
									
										25
									
								
								MP4/box_trun.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								MP4/box_trun.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,25 @@ | |||
| #include "box.h" | ||||
| #include <vector> | ||||
| 
 | ||||
| struct trun_sampleinformationstructure { | ||||
|   uint32_t SampleDuration; | ||||
|   uint32_t SampleSize; | ||||
| } | ||||
| 
 | ||||
| class Box_tfhd { | ||||
|   public: | ||||
|     Box_tfhd( ); | ||||
|     ~Box_tfhd(); | ||||
|     Box * GetBox(); | ||||
|     void SetDataOffset( uint32_t Offset = 0 ); | ||||
|     void AddSampleInformation( uint32_t SampleDuration = 0, uint32_t SampleSize = 0, uint32_t Offset = 0 ); | ||||
|     void WriteContent( ); | ||||
|   private: | ||||
|     void SetDefaults( ); | ||||
|     bool setSampleDuration; | ||||
|     bool setSampleSize; | ||||
|     uint32_t curDataOffset; | ||||
|     std::vector<trun_sampleinformationstructure> SampleInfo; | ||||
|     Box * Container; | ||||
| };//Box_ftyp Class
 | ||||
| 
 | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Erik Zandvliet
						Erik Zandvliet