72 lines
1.9 KiB
C#
Raw Normal View History

2022-05-01 00:33:22 -05:00
using System;
namespace ConfusedPolarBear.Plugin.IntroSkipper;
/// <summary>
/// Result of fingerprinting and analyzing two episodes in a season.
/// All times are measured in seconds relative to the beginning of the media file.
/// </summary>
public class Intro
{
2022-05-13 01:13:13 -05:00
/// <summary>
/// Initializes a new instance of the <see cref="Intro"/> class.
/// </summary>
/// <param name="episode">Episode.</param>
2022-05-16 23:08:20 -05:00
/// <param name="intro">Introduction time range.</param>
public Intro(Guid episode, TimeRange intro)
2022-05-13 01:13:13 -05:00
{
EpisodeId = episode;
2022-05-16 23:08:20 -05:00
IntroStart = intro.Start;
IntroEnd = intro.End;
}
/// <summary>
/// Initializes a new instance of the <see cref="Intro"/> class.
/// </summary>
/// <param name="episode">Episode.</param>
public Intro(Guid episode)
{
EpisodeId = episode;
IntroStart = 0;
IntroEnd = 0;
2022-05-13 01:13:13 -05:00
}
/// <summary>
/// Initializes a new instance of the <see cref="Intro"/> class.
/// </summary>
public Intro()
{
}
2022-05-01 01:24:57 -05:00
/// <summary>
/// Gets or sets the Episode ID.
2022-05-01 01:24:57 -05:00
/// </summary>
public Guid EpisodeId { get; set; }
2022-05-01 00:33:22 -05:00
/// <summary>
2022-05-13 01:13:13 -05:00
/// Gets a value indicating whether this introduction is valid or not.
/// Invalid results must not be returned through the API.
2022-05-01 00:33:22 -05:00
/// </summary>
2022-05-13 01:13:13 -05:00
public bool Valid => IntroEnd > 0;
2022-05-01 00:33:22 -05:00
/// <summary>
/// Gets or sets the introduction sequence start time.
2022-05-01 00:33:22 -05:00
/// </summary>
public double IntroStart { get; set; }
/// <summary>
/// Gets or sets the introduction sequence end time.
2022-05-01 00:33:22 -05:00
/// </summary>
public double IntroEnd { get; set; }
/// <summary>
/// Gets or sets the recommended time to display the skip intro prompt.
2022-05-01 00:33:22 -05:00
/// </summary>
public double ShowSkipPromptAt { get; set; }
/// <summary>
/// Gets or sets the recommended time to hide the skip intro prompt.
2022-05-01 00:33:22 -05:00
/// </summary>
public double HideSkipPromptAt { get; set; }
}