diff options
| author | Sven Van den brande <sven.vandenbrande@outlook.com> | 2014-11-11 23:15:20 +0100 |
|---|---|---|
| committer | Sven Van den brande <sven.vandenbrande@outlook.com> | 2014-11-11 23:15:20 +0100 |
| commit | cbd2c2fc5435aead30513150fc9f50c86eebde49 (patch) | |
| tree | 01d3a826de7a038acf31788488356980dab60d26 /MediaBrowser.Server.Implementations/Photos/DynamicImageHelpers.cs | |
| parent | 4d0a47e5555e4b04967c679dd4e54e937a0bd7ca (diff) | |
| parent | 0dfac392e74c0c0688346eedf728eb4d68df68ec (diff) | |
Merge branch 'master' of https://github.com/MediaBrowser/MediaBrowser
Diffstat (limited to 'MediaBrowser.Server.Implementations/Photos/DynamicImageHelpers.cs')
| -rw-r--r-- | MediaBrowser.Server.Implementations/Photos/DynamicImageHelpers.cs | 29 |
1 files changed, 20 insertions, 9 deletions
diff --git a/MediaBrowser.Server.Implementations/Photos/DynamicImageHelpers.cs b/MediaBrowser.Server.Implementations/Photos/DynamicImageHelpers.cs index 2c5cedf65..1099bd170 100644 --- a/MediaBrowser.Server.Implementations/Photos/DynamicImageHelpers.cs +++ b/MediaBrowser.Server.Implementations/Photos/DynamicImageHelpers.cs @@ -10,7 +10,7 @@ namespace MediaBrowser.Server.Implementations.Photos { public static class DynamicImageHelpers { - public static async Task<Image> GetThumbCollage(List<string> files, + public static async Task<Stream> GetThumbCollage(List<string> files, IFileSystem fileSystem, int width, int height) @@ -23,8 +23,8 @@ namespace MediaBrowser.Server.Implementations.Photos const int rows = 1; const int cols = 3; - int cellWidth = 2 * (width / 3); - int cellHeight = height; + int cellWidth = 2 * (width / 3); + int cellHeight = height; var index = 0; var img = new Bitmap(width, height, PixelFormat.Format32bppPArgb); @@ -67,10 +67,10 @@ namespace MediaBrowser.Server.Implementations.Photos } } - return img; + return GetStream(img); } - - public static async Task<Image> GetSquareCollage(List<string> files, + + public static async Task<Stream> GetSquareCollage(List<string> files, IFileSystem fileSystem, int size) { @@ -122,12 +122,23 @@ namespace MediaBrowser.Server.Implementations.Photos } } - return img; + return GetStream(img); + } + + private static Task<Stream> GetSingleImage(List<string> files, IFileSystem fileSystem) + { + return Task.FromResult<Stream>(fileSystem.GetFileStream(files[0], FileMode.Open, FileAccess.Read, FileShare.Read)); } - private static Task<Image> GetSingleImage(List<string> files, IFileSystem fileSystem) + private static Stream GetStream(Image image) { - return GetImage(files[0], fileSystem); + var ms = new MemoryStream(); + + image.Save(ms, ImageFormat.Png); + + ms.Position = 0; + + return ms; } private static async Task<Image> GetImage(string file, IFileSystem fileSystem) |
