DynamicImageHelpers.cs 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. using MediaBrowser.Common.IO;
  2. using System.Collections.Generic;
  3. using System.Drawing;
  4. using System.Drawing.Drawing2D;
  5. using System.Drawing.Imaging;
  6. using System.IO;
  7. namespace Emby.Drawing.GDI
  8. {
  9. public static class DynamicImageHelpers
  10. {
  11. public static void CreateThumbCollage(List<string> files,
  12. IFileSystem fileSystem,
  13. string file,
  14. int width,
  15. int height)
  16. {
  17. const int numStrips = 4;
  18. files = ImageHelpers.ProjectPaths(files, numStrips);
  19. const int rows = 1;
  20. int cols = numStrips;
  21. int cellWidth = 2 * (width / 3);
  22. int cellHeight = height;
  23. var index = 0;
  24. using (var img = new Bitmap(width, height, PixelFormat.Format32bppPArgb))
  25. {
  26. using (var graphics = Graphics.FromImage(img))
  27. {
  28. graphics.CompositingQuality = CompositingQuality.HighQuality;
  29. graphics.SmoothingMode = SmoothingMode.HighQuality;
  30. graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;
  31. graphics.PixelOffsetMode = PixelOffsetMode.HighQuality;
  32. graphics.CompositingMode = CompositingMode.SourceCopy;
  33. for (var row = 0; row < rows; row++)
  34. {
  35. for (var col = 0; col < cols; col++)
  36. {
  37. var x = col * (cellWidth / 2);
  38. var y = row * cellHeight;
  39. if (files.Count > index)
  40. {
  41. using (var fileStream = fileSystem.GetFileStream(files[index], FileMode.Open, FileAccess.Read, FileShare.Read, true))
  42. {
  43. using (var memoryStream = new MemoryStream())
  44. {
  45. fileStream.CopyTo(memoryStream);
  46. memoryStream.Position = 0;
  47. using (var imgtemp = Image.FromStream(memoryStream, true, false))
  48. {
  49. graphics.DrawImage(imgtemp, x, y, cellWidth, cellHeight);
  50. }
  51. }
  52. }
  53. }
  54. index++;
  55. }
  56. }
  57. img.Save(file);
  58. }
  59. }
  60. }
  61. public static void CreateSquareCollage(List<string> files,
  62. IFileSystem fileSystem,
  63. string file,
  64. int width,
  65. int height)
  66. {
  67. files = ImageHelpers.ProjectPaths(files, 4);
  68. const int rows = 2;
  69. const int cols = 2;
  70. int singleSize = width / 2;
  71. var index = 0;
  72. using (var img = new Bitmap(width, height, PixelFormat.Format32bppPArgb))
  73. {
  74. using (var graphics = Graphics.FromImage(img))
  75. {
  76. graphics.CompositingQuality = CompositingQuality.HighQuality;
  77. graphics.SmoothingMode = SmoothingMode.HighQuality;
  78. graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;
  79. graphics.PixelOffsetMode = PixelOffsetMode.HighQuality;
  80. graphics.CompositingMode = CompositingMode.SourceCopy;
  81. for (var row = 0; row < rows; row++)
  82. {
  83. for (var col = 0; col < cols; col++)
  84. {
  85. var x = col * singleSize;
  86. var y = row * singleSize;
  87. using (var fileStream = fileSystem.GetFileStream(files[index], FileMode.Open, FileAccess.Read, FileShare.Read, true))
  88. {
  89. using (var memoryStream = new MemoryStream())
  90. {
  91. fileStream.CopyTo(memoryStream);
  92. memoryStream.Position = 0;
  93. using (var imgtemp = Image.FromStream(memoryStream, true, false))
  94. {
  95. graphics.DrawImage(imgtemp, x, y, singleSize, singleSize);
  96. }
  97. }
  98. }
  99. index++;
  100. }
  101. }
  102. img.Save(file);
  103. }
  104. }
  105. }
  106. private static Stream GetStream(Image image)
  107. {
  108. var ms = new MemoryStream();
  109. image.Save(ms, ImageFormat.Png);
  110. ms.Position = 0;
  111. return ms;
  112. }
  113. }
  114. }