diff options
| author | Luke Pulverenti <luke.pulverenti@gmail.com> | 2014-11-10 23:26:53 -0500 |
|---|---|---|
| committer | Luke Pulverenti <luke.pulverenti@gmail.com> | 2014-11-10 23:26:53 -0500 |
| commit | 0dfac392e74c0c0688346eedf728eb4d68df68ec (patch) | |
| tree | 01d3a826de7a038acf31788488356980dab60d26 /MediaBrowser.Server.Implementations/Photos/DynamicImageHelpers.cs | |
| parent | 1fea9ad926801c85f436e34a8756bfdc41a43a0d (diff) | |
dlna genre images
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 2c5cedf65a..1099bd1709 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) |
