mirror of https://github.com/ErsatzTV/ErsatzTV.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
111 lines
4.2 KiB
111 lines
4.2 KiB
using ErsatzTV.Core.Domain; |
|
using ErsatzTV.Core.Domain.Filler; |
|
using ErsatzTV.Core.Interfaces.Scheduling; |
|
using Microsoft.Extensions.Logging; |
|
|
|
namespace ErsatzTV.Core.Scheduling; |
|
|
|
public class PlayoutModeSchedulerOne : PlayoutModeSchedulerBase<ProgramScheduleItemOne> |
|
{ |
|
public PlayoutModeSchedulerOne(ILogger logger) : base(logger) |
|
{ |
|
} |
|
|
|
public override Tuple<PlayoutBuilderState, List<PlayoutItem>> Schedule( |
|
PlayoutBuilderState playoutBuilderState, |
|
Dictionary<CollectionKey, IMediaCollectionEnumerator> collectionEnumerators, |
|
ProgramScheduleItemOne scheduleItem, |
|
ProgramScheduleItem nextScheduleItem, |
|
DateTimeOffset hardStop, |
|
CancellationToken cancellationToken) |
|
{ |
|
IMediaCollectionEnumerator contentEnumerator = |
|
collectionEnumerators[CollectionKey.ForScheduleItem(scheduleItem)]; |
|
foreach (MediaItem mediaItem in contentEnumerator.Current) |
|
{ |
|
// find when we should start this item, based on the current time |
|
DateTimeOffset itemStartTime = GetStartTimeAfter(playoutBuilderState, scheduleItem); |
|
if (itemStartTime >= hardStop) |
|
{ |
|
playoutBuilderState = playoutBuilderState with { CurrentTime = hardStop }; |
|
break; |
|
} |
|
|
|
TimeSpan itemDuration = DurationForMediaItem(mediaItem); |
|
List<MediaChapter> itemChapters = ChaptersForMediaItem(mediaItem); |
|
|
|
var playoutItem = new PlayoutItem |
|
{ |
|
MediaItemId = mediaItem.Id, |
|
Start = itemStartTime.UtcDateTime, |
|
Finish = itemStartTime.UtcDateTime + itemDuration, |
|
InPoint = TimeSpan.Zero, |
|
OutPoint = itemDuration, |
|
GuideGroup = playoutBuilderState.NextGuideGroup, |
|
FillerKind = scheduleItem.GuideMode == GuideMode.Filler |
|
? FillerKind.GuideMode |
|
: FillerKind.None, |
|
CustomTitle = scheduleItem.CustomTitle, |
|
WatermarkId = scheduleItem.WatermarkId, |
|
PreferredAudioLanguageCode = scheduleItem.PreferredAudioLanguageCode, |
|
PreferredAudioTitle = scheduleItem.PreferredAudioTitle, |
|
PreferredSubtitleLanguageCode = scheduleItem.PreferredSubtitleLanguageCode, |
|
SubtitleMode = scheduleItem.SubtitleMode |
|
}; |
|
|
|
List<PlayoutItem> playoutItems = AddFiller( |
|
playoutBuilderState, |
|
collectionEnumerators, |
|
scheduleItem, |
|
playoutItem, |
|
itemChapters, |
|
true, |
|
cancellationToken); |
|
|
|
PlayoutBuilderState nextState = playoutBuilderState with |
|
{ |
|
CurrentTime = playoutItems.Max(pi => pi.FinishOffset) |
|
}; |
|
|
|
nextState.ScheduleItemsEnumerator.MoveNext(); |
|
contentEnumerator.MoveNext(); |
|
|
|
// LogScheduledItem(scheduleItem, mediaItem, itemStartTime); |
|
|
|
// only play one item from collection, so always advance to the next item |
|
// _logger.LogDebug( |
|
// "Advancing to next schedule item after playout mode {PlayoutMode}", |
|
// "One"); |
|
|
|
DateTimeOffset nextItemStart = GetFillerStartTimeAfter(nextState, nextScheduleItem, hardStop); |
|
|
|
if (scheduleItem.TailFiller != null) |
|
{ |
|
(nextState, playoutItems) = AddTailFiller( |
|
nextState, |
|
collectionEnumerators, |
|
scheduleItem, |
|
playoutItems, |
|
nextItemStart, |
|
cancellationToken); |
|
} |
|
|
|
if (scheduleItem.FallbackFiller != null) |
|
{ |
|
(nextState, playoutItems) = AddFallbackFiller( |
|
nextState, |
|
collectionEnumerators, |
|
scheduleItem, |
|
playoutItems, |
|
nextItemStart, |
|
cancellationToken); |
|
} |
|
|
|
nextState = nextState with { NextGuideGroup = nextState.IncrementGuideGroup }; |
|
|
|
return Tuple(nextState, playoutItems); |
|
} |
|
|
|
return Tuple(playoutBuilderState, new List<PlayoutItem>()); |
|
} |
|
}
|
|
|