jellyfin/MediaBrowser.ServerApplication/ImageEncoderHelper.cs

59 lines
1.7 KiB
C#
Raw Normal View History

2016-11-11 19:55:12 +00:00
using System;
using Emby.Drawing;
2016-11-11 17:33:10 +00:00
using Emby.Drawing.Net;
using Emby.Drawing.ImageMagick;
2017-05-09 20:18:02 +00:00
using Emby.Drawing.Skia;
2016-11-11 17:33:10 +00:00
using Emby.Server.Core;
2016-11-18 21:06:00 +00:00
using Emby.Server.Implementations;
2016-11-11 19:55:12 +00:00
using MediaBrowser.Common.Configuration;
2016-11-11 17:33:10 +00:00
using MediaBrowser.Common.Net;
using MediaBrowser.Controller.Drawing;
using MediaBrowser.Model.IO;
using MediaBrowser.Model.Logging;
namespace MediaBrowser.Server.Startup.Common
{
public class ImageEncoderHelper
{
public static IImageEncoder GetImageEncoder(ILogger logger,
ILogManager logManager,
IFileSystem fileSystem,
StartupOptions startupOptions,
2016-11-11 19:55:12 +00:00
Func<IHttpClient> httpClient,
IApplicationPaths appPaths)
2016-11-11 17:33:10 +00:00
{
if (!startupOptions.ContainsOption("-enablegdi"))
{
2017-05-09 20:18:02 +00:00
try
{
2017-05-12 04:57:09 +00:00
return new SkiaEncoder(logManager.GetLogger("Skia"), appPaths, httpClient, fileSystem);
2017-05-09 20:18:02 +00:00
}
catch
{
2017-05-12 04:57:09 +00:00
logger.Error("Error loading Skia. Will revert to ImageMagick.");
2017-05-09 20:18:02 +00:00
}
2016-11-11 17:33:10 +00:00
try
{
2016-11-11 19:55:12 +00:00
return new ImageMagickEncoder(logManager.GetLogger("ImageMagick"), appPaths, httpClient, fileSystem);
2016-11-11 17:33:10 +00:00
}
catch
{
logger.Error("Error loading ImageMagick. Will revert to GDI.");
}
}
try
{
return new GDIImageEncoder(fileSystem, logManager.GetLogger("GDI"));
}
catch
{
logger.Error("Error loading GDI. Will revert to NullImageEncoder.");
}
return new NullImageEncoder();
}
}
}