|
@@ -500,13 +500,6 @@ namespace MediaBrowser.Api.Playback.Hls
|
|
|
return ResultFactory.GetResult(playlistText, MimeTypes.GetMimeType("playlist.m3u8"), new Dictionary<string, string>());
|
|
|
}
|
|
|
|
|
|
- private bool IsLiveStream(StreamState state)
|
|
|
- {
|
|
|
- var isLiveStream = (state.RunTimeTicks ?? 0) == 0;
|
|
|
-
|
|
|
- return isLiveStream;
|
|
|
- }
|
|
|
-
|
|
|
private string GetMasterPlaylistFileText(StreamState state, int totalBitrate)
|
|
|
{
|
|
|
var builder = new StringBuilder();
|
|
@@ -828,7 +821,7 @@ namespace MediaBrowser.Api.Playback.Hls
|
|
|
args += " -bsf:v h264_mp4toannexb";
|
|
|
}
|
|
|
|
|
|
- args += " -flags -global_header -sc_threshold 0";
|
|
|
+ args += " -flags -global_header";
|
|
|
}
|
|
|
else
|
|
|
{
|
|
@@ -853,7 +846,7 @@ namespace MediaBrowser.Api.Playback.Hls
|
|
|
args += GetGraphicalSubtitleParam(state, codec);
|
|
|
}
|
|
|
|
|
|
- args += " -flags -global_header -sc_threshold 0";
|
|
|
+ args += " -flags -global_header";
|
|
|
}
|
|
|
|
|
|
if (EnableCopyTs(state) && args.IndexOf("-copyts", StringComparison.OrdinalIgnoreCase) == -1)
|
|
@@ -866,6 +859,7 @@ namespace MediaBrowser.Api.Playback.Hls
|
|
|
|
|
|
private bool EnableCopyTs(StreamState state)
|
|
|
{
|
|
|
+ //return state.SubtitleStream != null && state.SubtitleStream.IsTextSubtitleStream && state.VideoRequest.SubtitleMethod == SubtitleDeliveryMethod.Encode;
|
|
|
return true;
|
|
|
}
|
|
|
|
|
@@ -888,21 +882,26 @@ namespace MediaBrowser.Api.Playback.Hls
|
|
|
|
|
|
var mapArgs = state.IsOutputVideo ? GetMapArgs(state) : string.Empty;
|
|
|
|
|
|
- //var outputTsArg = Path.Combine(Path.GetDirectoryName(outputPath), Path.GetFileNameWithoutExtension(outputPath)) + "%d" + GetSegmentFileExtension(state);
|
|
|
-
|
|
|
- //return string.Format("{0} {10} {1} -map_metadata -1 -threads {2} {3} {4} {5} -f segment -max_delay 5000000 -avoid_negative_ts disabled -start_at_zero -segment_time {6} -segment_format mpegts -segment_list_type m3u8 -segment_start_number {7} -segment_list \"{8}\" -y \"{9}\"",
|
|
|
- // inputModifier,
|
|
|
- // GetInputArgument(state),
|
|
|
- // threads,
|
|
|
- // mapArgs,
|
|
|
- // GetVideoArguments(state),
|
|
|
- // GetAudioArguments(state),
|
|
|
- // state.SegmentLength.ToString(UsCulture),
|
|
|
- // startNumberParam,
|
|
|
- // outputPath,
|
|
|
- // outputTsArg,
|
|
|
- // toTimeParam
|
|
|
- // ).Trim();
|
|
|
+ var enableGenericSegmenter = false;
|
|
|
+
|
|
|
+ if (enableGenericSegmenter)
|
|
|
+ {
|
|
|
+ var outputTsArg = Path.Combine(Path.GetDirectoryName(outputPath), Path.GetFileNameWithoutExtension(outputPath)) + "%d" + GetSegmentFileExtension(state);
|
|
|
+
|
|
|
+ return string.Format("{0} {10} {1} -map_metadata -1 -threads {2} {3} {4} {5} -f segment -max_delay 5000000 -avoid_negative_ts disabled -start_at_zero -segment_time {6} -segment_format mpegts -segment_list_type m3u8 -segment_start_number {7} -segment_list \"{8}\" -y \"{9}\"",
|
|
|
+ inputModifier,
|
|
|
+ GetInputArgument(state),
|
|
|
+ threads,
|
|
|
+ mapArgs,
|
|
|
+ GetVideoArguments(state),
|
|
|
+ GetAudioArguments(state),
|
|
|
+ state.SegmentLength.ToString(UsCulture),
|
|
|
+ startNumberParam,
|
|
|
+ outputPath,
|
|
|
+ outputTsArg,
|
|
|
+ toTimeParam
|
|
|
+ ).Trim();
|
|
|
+ }
|
|
|
|
|
|
return string.Format("{0}{11} {1} -map_metadata -1 -threads {2} {3} {4}{5} {6} -max_delay 5000000 -avoid_negative_ts disabled -start_at_zero -hls_time {7} -start_number {8} -hls_list_size {9} -y \"{10}\"",
|
|
|
inputModifier,
|