ImageEncoderHelper.cs 1.7 KB

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