diff options
Diffstat (limited to 'MediaBrowser.Server.Implementations/Dto/DtoService.cs')
| -rw-r--r-- | MediaBrowser.Server.Implementations/Dto/DtoService.cs | 230 |
1 files changed, 10 insertions, 220 deletions
diff --git a/MediaBrowser.Server.Implementations/Dto/DtoService.cs b/MediaBrowser.Server.Implementations/Dto/DtoService.cs index 520ffd417..2296edcef 100644 --- a/MediaBrowser.Server.Implementations/Dto/DtoService.cs +++ b/MediaBrowser.Server.Implementations/Dto/DtoService.cs @@ -1,4 +1,5 @@ -using MediaBrowser.Common.Extensions; +using System.Threading; +using MediaBrowser.Common.Extensions; using MediaBrowser.Common.IO; using MediaBrowser.Controller.Channels; using MediaBrowser.Controller.Configuration; @@ -919,8 +920,12 @@ namespace MediaBrowser.Server.Implementations.Dto dto.AlbumPrimaryImageTag = GetImageCacheTag(albumParent, ImageType.Primary); } - dto.MediaSources = GetAudioMediaSources(audio); dto.MediaSourceCount = 1; + + if (fields.Contains(ItemFields.MediaSources)) + { + dto.MediaSources = GetMediaSources(audio); + } } var album = item as MusicAlbum; @@ -955,7 +960,7 @@ namespace MediaBrowser.Server.Implementations.Dto if (fields.Contains(ItemFields.MediaSources)) { - dto.MediaSources = GetVideoMediaSources(video); + dto.MediaSources = GetMediaSources(video); } if (fields.Contains(ItemFields.Chapters)) @@ -1144,14 +1149,14 @@ namespace MediaBrowser.Server.Implementations.Dto if (video != null) { - return GetVideoMediaSources(video); + return video.GetMediaSources(true).ToList(); } var audio = item as Audio; if (audio != null) { - return GetAudioMediaSources(audio); + return audio.GetMediaSources(true).ToList(); } var result = new List<MediaSourceInfo> @@ -1175,131 +1180,6 @@ namespace MediaBrowser.Server.Implementations.Dto return result; } - private List<MediaSourceInfo> GetVideoMediaSources(Video item) - { - var result = item.GetAlternateVersions().Select(GetVersionInfo).ToList(); - - result.Add(GetVersionInfo(item)); - - return result.OrderBy(i => - { - if (item.VideoType == VideoType.VideoFile) - { - return 0; - } - - return 1; - - }).ThenBy(i => i.Video3DFormat.HasValue ? 1 : 0) - .ThenByDescending(i => - { - var stream = i.VideoStream; - - return stream == null || stream.Width == null ? 0 : stream.Width.Value; - }) - .ToList(); - } - - private List<MediaSourceInfo> GetAudioMediaSources(Audio item) - { - var result = new List<MediaSourceInfo> - { - GetVersionInfo(item) - }; - - return result; - } - - private MediaSourceInfo GetVersionInfo(Video i) - { - var mediaStreams = _itemRepo.GetMediaStreams(new MediaStreamQuery { ItemId = i.Id }).ToList(); - - var info = new MediaSourceInfo - { - Id = i.Id.ToString("N"), - IsoType = i.IsoType, - LocationType = i.LocationType, - MediaStreams = mediaStreams, - Name = GetMediaSourceName(i, mediaStreams), - Path = GetMappedPath(i), - RunTimeTicks = i.RunTimeTicks, - Video3DFormat = i.Video3DFormat, - VideoType = i.VideoType, - Container = i.Container, - Size = i.Size, - Formats = (i.FormatName ?? string.Empty).Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).ToList(), - Timestamp = i.Timestamp - }; - - if (string.IsNullOrEmpty(info.Container)) - { - if (i.VideoType == VideoType.VideoFile || i.VideoType == VideoType.Iso) - { - var locationType = i.LocationType; - if (!string.IsNullOrWhiteSpace(i.Path) && locationType != LocationType.Remote && locationType != LocationType.Virtual) - { - info.Container = Path.GetExtension(i.Path).TrimStart('.'); - } - } - } - - try - { - var bitrate = i.TotalBitrate ?? - info.MediaStreams.Where(m => m.Type != MediaStreamType.Subtitle && !string.Equals(m.Codec, "mjpeg", StringComparison.OrdinalIgnoreCase)) - .Select(m => m.BitRate ?? 0) - .Sum(); - - if (bitrate > 0) - { - info.Bitrate = bitrate; - } - } - catch (OverflowException ex) - { - _logger.ErrorException("Error calculating total bitrate", ex); - } - - return info; - } - - private MediaSourceInfo GetVersionInfo(Audio i) - { - var info = new MediaSourceInfo - { - Id = i.Id.ToString("N"), - LocationType = i.LocationType, - MediaStreams = _itemRepo.GetMediaStreams(new MediaStreamQuery { ItemId = i.Id }).ToList(), - Name = i.Name, - Path = GetMappedPath(i), - RunTimeTicks = i.RunTimeTicks, - Container = i.Container, - Size = i.Size, - Formats = (i.FormatName ?? string.Empty).Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).ToList() - }; - - if (string.IsNullOrEmpty(info.Container)) - { - var locationType = i.LocationType; - if (!string.IsNullOrWhiteSpace(i.Path) && locationType != LocationType.Remote && locationType != LocationType.Virtual) - { - info.Container = Path.GetExtension(i.Path).TrimStart('.'); - } - } - - var bitrate = i.TotalBitrate ?? - info.MediaStreams.Where(m => m.Type == MediaStreamType.Audio) - .Select(m => m.BitRate ?? 0) - .Sum(); - - if (bitrate > 0) - { - info.Bitrate = bitrate; - } - - return info; - } - private string GetMappedPath(IHasMetadata item) { var path = item.Path; @@ -1317,96 +1197,6 @@ namespace MediaBrowser.Server.Implementations.Dto return path; } - private string GetMediaSourceName(Video video, List<MediaStream> mediaStreams) - { - var terms = new List<string>(); - - var videoStream = mediaStreams.FirstOrDefault(i => i.Type == MediaStreamType.Video); - var audioStream = mediaStreams.FirstOrDefault(i => i.Type == MediaStreamType.Audio); - - if (video.Video3DFormat.HasValue) - { - terms.Add("3D"); - } - - if (video.VideoType == VideoType.BluRay) - { - terms.Add("Bluray"); - } - else if (video.VideoType == VideoType.Dvd) - { - terms.Add("DVD"); - } - else if (video.VideoType == VideoType.HdDvd) - { - terms.Add("HD-DVD"); - } - else if (video.VideoType == VideoType.Iso) - { - if (video.IsoType.HasValue) - { - if (video.IsoType.Value == IsoType.BluRay) - { - terms.Add("Bluray"); - } - else if (video.IsoType.Value == IsoType.Dvd) - { - terms.Add("DVD"); - } - } - else - { - terms.Add("ISO"); - } - } - - if (videoStream != null) - { - if (videoStream.Width.HasValue) - { - if (videoStream.Width.Value >= 3800) - { - terms.Add("4K"); - } - else if (videoStream.Width.Value >= 1900) - { - terms.Add("1080P"); - } - else if (videoStream.Width.Value >= 1270) - { - terms.Add("720P"); - } - else if (videoStream.Width.Value >= 700) - { - terms.Add("480P"); - } - else - { - terms.Add("SD"); - } - } - } - - if (videoStream != null && !string.IsNullOrWhiteSpace(videoStream.Codec)) - { - terms.Add(videoStream.Codec.ToUpper()); - } - - if (audioStream != null) - { - var audioCodec = string.Equals(audioStream.Codec, "dca", StringComparison.OrdinalIgnoreCase) - ? audioStream.Profile - : audioStream.Codec; - - if (!string.IsNullOrEmpty(audioCodec)) - { - terms.Add(audioCodec.ToUpper()); - } - } - - return string.Join("/", terms.ToArray()); - } - private void SetProductionLocations(BaseItem item, BaseItemDto dto) { var hasProductionLocations = item as IHasProductionLocations; |
