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-10 19:56:59 +00:00
|
|
|
|
return new SkiaEncoder(logManager.GetLogger("ImageMagick"), appPaths, httpClient, fileSystem);
|
2017-05-09 20:18:02 +00:00
|
|
|
|
}
|
|
|
|
|
catch
|
|
|
|
|
{
|
|
|
|
|
logger.Error("Error loading ImageMagick. Will revert to GDI.");
|
|
|
|
|
}
|
|
|
|
|
|
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();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|