ImageEncoderHelper.cs 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. using System;
  2. using Emby.Drawing;
  3. using Emby.Drawing.ImageMagick;
  4. using Emby.Server.Core;
  5. using Emby.Server.Implementations;
  6. using MediaBrowser.Common.Configuration;
  7. using MediaBrowser.Common.Net;
  8. using MediaBrowser.Controller.Drawing;
  9. using MediaBrowser.Model.IO;
  10. using MediaBrowser.Model.Logging;
  11. using Emby.Drawing.Skia;
  12. namespace MediaBrowser.Server.Startup.Common
  13. {
  14. public class ImageEncoderHelper
  15. {
  16. public static IImageEncoder GetImageEncoder(ILogger logger,
  17. ILogManager logManager,
  18. IFileSystem fileSystem,
  19. StartupOptions startupOptions,
  20. Func<IHttpClient> httpClient,
  21. IApplicationPaths appPaths)
  22. {
  23. if (!startupOptions.ContainsOption("-enablegdi"))
  24. {
  25. try
  26. {
  27. return new SkiaEncoder(logManager.GetLogger("Skia"), appPaths, httpClient, fileSystem);
  28. }
  29. catch
  30. {
  31. logger.Error("Error loading Skia. Will revert to ImageMagick.");
  32. }
  33. try
  34. {
  35. return new ImageMagickEncoder(logManager.GetLogger("ImageMagick"), appPaths, httpClient, fileSystem);
  36. }
  37. catch
  38. {
  39. logger.Error("Error loading ImageMagick. Will revert to GDI.");
  40. }
  41. }
  42. return new NullImageEncoder();
  43. }
  44. }
  45. }