HTTP Live fixes and optimalisations.
This commit is contained in:
		
							parent
							
								
									2f4095d7bc
								
							
						
					
					
						commit
						b79c41e413
					
				
					 1 changed files with 23 additions and 32 deletions
				
			
		|  | @ -63,8 +63,8 @@ namespace Connector_HTTP { | ||||||
|       int lastDuration = 0; |       int lastDuration = 0; | ||||||
|       bool writeOffset = true; |       bool writeOffset = true; | ||||||
|       for (int i = 0; i < fragIndices.size() - 1; i++){ |       for (int i = 0; i < fragIndices.size() - 1; i++){ | ||||||
|         Result << "#EXTINF:" << (metadata["keytime"][fragIndices[i + 1]].asInt() - lastDuration) / 1000 << ", no desc\r\n" << fragIndices[i] << "_" |         Result << "#EXTINF:" << (metadata["keytime"][fragIndices[i + 1]].asInt() - lastDuration) / 1000 << ", no desc\r\n" << fragIndices[i] + 1 | ||||||
|             << fragIndices[i + 1] - fragIndices[i] << ".ts\r\n"; |             << "_" << fragIndices[i + 1] - fragIndices[i] << ".ts\r\n"; | ||||||
|         lastDuration = metadata["keytime"][fragIndices[i + 1]].asInt(); |         lastDuration = metadata["keytime"][fragIndices[i + 1]].asInt(); | ||||||
|       } |       } | ||||||
|       Result << "#EXT-X-ENDLIST"; |       Result << "#EXT-X-ENDLIST"; | ||||||
|  | @ -288,30 +288,6 @@ namespace Connector_HTTP { | ||||||
|               haveAvcc = true; |               haveAvcc = true; | ||||||
|             } |             } | ||||||
|             if (Strm.lastType() == DTSC::VIDEO || Strm.lastType() == DTSC::AUDIO){ |             if (Strm.lastType() == DTSC::VIDEO || Strm.lastType() == DTSC::AUDIO){ | ||||||
|               if (Strm.lastType() == DTSC::VIDEO){ |  | ||||||
|                 DTMIData = Strm.lastData(); |  | ||||||
|                 IsKeyFrame = Strm.getPacket(0).isMember("keyframe"); |  | ||||||
|                 if (IsKeyFrame){ |  | ||||||
|                   TimeStamp = (Strm.getPacket(0)["time"].asInt() * 27000); |  | ||||||
|                 } |  | ||||||
|                 int TSType; |  | ||||||
|                 bool FirstPic = true; |  | ||||||
|                 while (DTMIData.size()){ |  | ||||||
|                   ThisNaluSize = (DTMIData[0] << 24) + (DTMIData[1] << 16) + (DTMIData[2] << 8) + DTMIData[3]; |  | ||||||
|                   DTMIData.erase(0, 4); //Erase the first four characters;
 |  | ||||||
|                   TSType = (int)DTMIData[0] & 0x1F; |  | ||||||
|                   if (TSType == 0x05){ |  | ||||||
|                     if (FirstPic){ |  | ||||||
|                       ToPack += avccbox.asAnnexB(); |  | ||||||
|                       FirstPic = false; |  | ||||||
|                     } |  | ||||||
|                   } |  | ||||||
|                   ToPack.append(TS::NalHeader, 4); |  | ||||||
|                   ToPack.append(DTMIData, 0, ThisNaluSize); |  | ||||||
|                   DTMIData.erase(0, ThisNaluSize); |  | ||||||
|                 } |  | ||||||
|                 WritePesHeader = true; |  | ||||||
|                 while (ToPack.size()){ |  | ||||||
|               if (PacketNumber == 0){ |               if (PacketNumber == 0){ | ||||||
|                 PackData.DefaultPAT(); |                 PackData.DefaultPAT(); | ||||||
|                 TSBuf.write(PackData.ToString(), 188); |                 TSBuf.write(PackData.ToString(), 188); | ||||||
|  | @ -319,6 +295,27 @@ namespace Connector_HTTP { | ||||||
|                 TSBuf.write(PackData.ToString(), 188); |                 TSBuf.write(PackData.ToString(), 188); | ||||||
|                 PacketNumber += 2; |                 PacketNumber += 2; | ||||||
|               } |               } | ||||||
|  |               if (Strm.lastType() == DTSC::VIDEO){ | ||||||
|  |                 DTMIData = Strm.lastData(); | ||||||
|  |                 IsKeyFrame = Strm.getPacket(0).isMember("keyframe"); | ||||||
|  |                 std::cout << Strm.getPacket(0)["time"].asInt() << std::endl; | ||||||
|  |                 if (IsKeyFrame){ | ||||||
|  |                   TimeStamp = (Strm.getPacket(0)["time"].asInt() * 27000); | ||||||
|  |                 } | ||||||
|  |                 ToPack += avccbox.asAnnexB(); | ||||||
|  |                 while (DTMIData.size()){ | ||||||
|  |                   ThisNaluSize = (DTMIData[0] << 24) + (DTMIData[1] << 16) + (DTMIData[2] << 8) + DTMIData[3]; | ||||||
|  |                   DTMIData.replace(0, 4, TS::NalHeader, 4); | ||||||
|  |                   if (ThisNaluSize + 4 == DTMIData.size()){ | ||||||
|  |                     ToPack.append(DTMIData); | ||||||
|  |                     break; | ||||||
|  |                   }else{ | ||||||
|  |                     ToPack.append(DTMIData, 0, ThisNaluSize + 4); | ||||||
|  |                     DTMIData.erase(0, ThisNaluSize + 4); | ||||||
|  |                   } | ||||||
|  |                 } | ||||||
|  |                 WritePesHeader = true; | ||||||
|  |                 while (ToPack.size()){ | ||||||
|                   PackData.Clear(); |                   PackData.Clear(); | ||||||
|                   PackData.PID(0x100); |                   PackData.PID(0x100); | ||||||
|                   PackData.ContinuityCounter(VideoCounter); |                   PackData.ContinuityCounter(VideoCounter); | ||||||
|  | @ -348,13 +345,6 @@ namespace Connector_HTTP { | ||||||
|                 ToPack = TS::GetAudioHeader(DTMIData.size(), Strm.metadata["audio"]["init"].asString()); |                 ToPack = TS::GetAudioHeader(DTMIData.size(), Strm.metadata["audio"]["init"].asString()); | ||||||
|                 ToPack += DTMIData; |                 ToPack += DTMIData; | ||||||
|                 while (ToPack.size()){ |                 while (ToPack.size()){ | ||||||
|                   if (PacketNumber == 0){ |  | ||||||
|                     PackData.DefaultPAT(); |  | ||||||
|                     TSBuf.write(PackData.ToString(), 188); |  | ||||||
|                     PackData.DefaultPMT(); |  | ||||||
|                     TSBuf.write(PackData.ToString(), 188); |  | ||||||
|                     PacketNumber += 2; |  | ||||||
|                   } |  | ||||||
|                   PackData.Clear(); |                   PackData.Clear(); | ||||||
|                   PackData.PID(0x101); |                   PackData.PID(0x101); | ||||||
|                   PackData.ContinuityCounter(AudioCounter); |                   PackData.ContinuityCounter(AudioCounter); | ||||||
|  | @ -368,6 +358,7 @@ namespace Connector_HTTP { | ||||||
|                     PackData.AdaptationField(1); |                     PackData.AdaptationField(1); | ||||||
|                     PackData.AddStuffing(PackData.BytesFree() - ToPack.size()); |                     PackData.AddStuffing(PackData.BytesFree() - ToPack.size()); | ||||||
|                   } |                   } | ||||||
|  |                   int before = ToPack.size(); | ||||||
|                   PackData.FillFree(ToPack); |                   PackData.FillFree(ToPack); | ||||||
|                   TSBuf.write(PackData.ToString(), 188); |                   TSBuf.write(PackData.ToString(), 188); | ||||||
|                   PacketNumber++; |                   PacketNumber++; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Thulinma
						Thulinma