diff options
| author | Luke <luke.pulverenti@gmail.com> | 2017-04-23 17:25:32 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-04-23 17:25:32 -0400 |
| commit | a0dc26b88172f10efa6dbf0ff6c3dffd9733d097 (patch) | |
| tree | 9596ee46fcd9072a582c20a76c3090ddf6bfe723 /MediaBrowser.ServerApplication/ImageEncoderHelper.cs | |
| parent | 82b86449cb4083ab8d875b22f40beb93d2f821f8 (diff) | |
| parent | c34ff57e1c188e3eda57a626077e804b36665dff (diff) | |
Merge pull request #2594 from MediaBrowser/dev
Dev
Diffstat (limited to 'MediaBrowser.ServerApplication/ImageEncoderHelper.cs')
| -rw-r--r-- | MediaBrowser.ServerApplication/ImageEncoderHelper.cs | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/MediaBrowser.ServerApplication/ImageEncoderHelper.cs b/MediaBrowser.ServerApplication/ImageEncoderHelper.cs new file mode 100644 index 000000000..ddbde2f66 --- /dev/null +++ b/MediaBrowser.ServerApplication/ImageEncoderHelper.cs @@ -0,0 +1,48 @@ +using System; +using Emby.Drawing; +using Emby.Drawing.Net; +using Emby.Drawing.ImageMagick; +using Emby.Server.Core; +using Emby.Server.Implementations; +using MediaBrowser.Common.Configuration; +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, + Func<IHttpClient> httpClient, + IApplicationPaths appPaths) + { + if (!startupOptions.ContainsOption("-enablegdi")) + { + try + { + return new ImageMagickEncoder(logManager.GetLogger("ImageMagick"), appPaths, httpClient, fileSystem); + } + 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(); + } + } +} |
