ImageEncoderHelper.cs 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. using System;
  2. using Emby.Drawing;
  3. using Emby.Drawing.Net;
  4. using Emby.Drawing.ImageMagick;
  5. using Emby.Drawing.Skia;
  6. using Emby.Server.Core;
  7. using Emby.Server.Implementations;
  8. using MediaBrowser.Common.Configuration;
  9. using MediaBrowser.Common.Net;
  10. using MediaBrowser.Controller.Drawing;
  11. using MediaBrowser.Model.IO;
  12. using MediaBrowser.Model.Logging;
  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. {
  24. if (!startupOptions.ContainsOption("-enablegdi"))
  25. {
  26. try
  27. {
  28. return new SkiaEncoder(logManager.GetLogger("Skia"), appPaths, httpClient, fileSystem);
  29. }
  30. catch
  31. {
  32. logger.Error("Error loading Skia. Will revert to ImageMagick.");
  33. }
  34. try
  35. {
  36. return new ImageMagickEncoder(logManager.GetLogger("ImageMagick"), appPaths, httpClient, fileSystem);
  37. }
  38. catch
  39. {
  40. logger.Error("Error loading ImageMagick. Will revert to GDI.");
  41. }
  42. }
  43. try
  44. {
  45. return new GDIImageEncoder(fileSystem, logManager.GetLogger("GDI"));
  46. }
  47. catch
  48. {
  49. logger.Error("Error loading GDI. Will revert to NullImageEncoder.");
  50. }
  51. return new NullImageEncoder();
  52. }
  53. }
  54. }