aboutsummaryrefslogtreecommitdiff
path: root/Emby.Server.Implementations/Library/LibraryManager.cs
diff options
context:
space:
mode:
authorJesús Higueras <jesus@dabbleam.com>2020-03-23 20:05:49 +0100
committerVasily <just.one.man@yandex.ru>2020-05-18 23:21:37 +0300
commitb9fc0d26287e46017515e4ac3e569ca2c60f622f (patch)
tree7168d3272a2ead08c2cb6171d1d2f9dc794df262 /Emby.Server.Implementations/Library/LibraryManager.cs
parent2d2c1d94733a1959f84c1cc26f8051d0be35cfb4 (diff)
Add BlurHash support to backend
Diffstat (limited to 'Emby.Server.Implementations/Library/LibraryManager.cs')
-rw-r--r--Emby.Server.Implementations/Library/LibraryManager.cs30
1 files changed, 28 insertions, 2 deletions
diff --git a/Emby.Server.Implementations/Library/LibraryManager.cs b/Emby.Server.Implementations/Library/LibraryManager.cs
index 0b86b2db7..bc35b0410 100644
--- a/Emby.Server.Implementations/Library/LibraryManager.cs
+++ b/Emby.Server.Implementations/Library/LibraryManager.cs
@@ -21,6 +21,7 @@ using MediaBrowser.Common.Extensions;
using MediaBrowser.Common.Progress;
using MediaBrowser.Controller;
using MediaBrowser.Controller.Configuration;
+using MediaBrowser.Controller.Drawing;
using MediaBrowser.Controller.Dto;
using MediaBrowser.Controller.Entities;
using MediaBrowser.Controller.Entities.Audio;
@@ -35,6 +36,7 @@ using MediaBrowser.Controller.Resolvers;
using MediaBrowser.Controller.Sorting;
using MediaBrowser.Model.Configuration;
using MediaBrowser.Model.Dlna;
+using MediaBrowser.Model.Drawing;
using MediaBrowser.Model.Dto;
using MediaBrowser.Model.Entities;
using MediaBrowser.Model.IO;
@@ -110,6 +112,18 @@ namespace Emby.Server.Implementations.Library
private IBaseItemComparer[] Comparers { get; set; }
/// <summary>
+ /// Gets or sets the active item repository
+ /// </summary>
+ /// <value>The item repository.</value>
+ public IItemRepository ItemRepository { get; set; }
+
+ /// <summary>
+ /// Gets or sets the active image processor
+ /// </summary>
+ /// <value>The image processor.</value>
+ public IImageProcessor ImageProcessor { get; set; }
+
+ /// <summary>
/// Occurs when [item added].
/// </summary>
public event EventHandler<ItemChangeEventArgs> ItemAdded;
@@ -1817,7 +1831,19 @@ namespace Emby.Server.Implementations.Library
public void UpdateImages(BaseItem item)
{
- _itemRepository.SaveImages(item);
+ item.ImageInfos
+ .Where(i => (i.Width == 0 || i.Height == 0))
+ .ToList()
+ .ForEach(x =>
+ {
+ string blurhash = ImageProcessor.GetImageHash(x.Path);
+ ImageDimensions size = ImageProcessor.GetImageDimensions(item, x, true);
+ x.Width = size.Width;
+ x.Height = size.Height;
+ x.Hash = blurhash;
+ });
+
+ ItemRepository.SaveImages(item);
RegisterItem(item);
}
@@ -1839,7 +1865,7 @@ namespace Emby.Server.Implementations.Library
item.DateLastSaved = DateTime.UtcNow;
- RegisterItem(item);
+ UpdateImages(item);
}
_itemRepository.SaveItems(itemsList, cancellationToken);