mirror of
https://gitlab.com/sbrl/GalleryShare.git
synced 2018-06-12 22:45:16 +00:00
Send error images in case of exception.
Also make image sending code more robust.
This commit is contained in:
parent
4f1fc0f211
commit
de2117f9bf
2 changed files with 55 additions and 6 deletions
|
@ -227,8 +227,7 @@ namespace GalleryShare
|
||||||
{
|
{
|
||||||
// Send a thumbnail!
|
// Send a thumbnail!
|
||||||
Console.WriteLine("Sending thumbnail for '{0}'", requestedPath);
|
Console.WriteLine("Sending thumbnail for '{0}'", requestedPath);
|
||||||
cycle.Response.ContentType = "image/png";
|
await ThumbnailGenerator.SendThumbnailPng(requestedPath, thumbnailSize, cycle);
|
||||||
ThumbnailGenerator.GenerateThumbnailPng(requestedPath, thumbnailSize, cycle.Response.OutputStream);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,13 +5,16 @@ using System.IO;
|
||||||
|
|
||||||
using System.Drawing.Drawing2D;
|
using System.Drawing.Drawing2D;
|
||||||
using System.Drawing.Imaging;
|
using System.Drawing.Imaging;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
|
using System.Net;
|
||||||
|
|
||||||
namespace GalleryShare
|
namespace GalleryShare
|
||||||
{
|
{
|
||||||
public static class ThumbnailGenerator
|
public static class ThumbnailGenerator
|
||||||
{
|
{
|
||||||
public static void GenerateThumbnailPng(string imagePath, Size thumbnailBounds, Stream outputStream)
|
public static async Task SendThumbnailPng(string imagePath, Size thumbnailBounds, HttpListenerContext cycle)
|
||||||
{
|
{
|
||||||
|
Image imageToSend;
|
||||||
try {
|
try {
|
||||||
using (Bitmap rawImage = new Bitmap(imagePath)) {
|
using (Bitmap rawImage = new Bitmap(imagePath)) {
|
||||||
float scaleFactor = Math.Min(
|
float scaleFactor = Math.Min(
|
||||||
|
@ -23,7 +26,7 @@ namespace GalleryShare
|
||||||
(int)(rawImage.Height * scaleFactor)
|
(int)(rawImage.Height * scaleFactor)
|
||||||
);
|
);
|
||||||
|
|
||||||
using (Bitmap smallImage = new Bitmap(thumbnailSize.Width, thumbnailSize.Height))
|
Bitmap smallImage = new Bitmap(thumbnailSize.Width, thumbnailSize.Height);
|
||||||
using (Graphics context = Graphics.FromImage(smallImage)) {
|
using (Graphics context = Graphics.FromImage(smallImage)) {
|
||||||
context.CompositingMode = CompositingMode.SourceCopy;
|
context.CompositingMode = CompositingMode.SourceCopy;
|
||||||
context.InterpolationMode = InterpolationMode.HighQualityBicubic;
|
context.InterpolationMode = InterpolationMode.HighQualityBicubic;
|
||||||
|
@ -32,13 +35,60 @@ namespace GalleryShare
|
||||||
thumbnailSize
|
thumbnailSize
|
||||||
));
|
));
|
||||||
|
|
||||||
smallImage.Save(outputStream, ImageFormat.Png);
|
//smallImage.Save(outputStream, ImageFormat.Png);
|
||||||
|
imageToSend = smallImage;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception error)
|
catch (Exception error)
|
||||||
{
|
{
|
||||||
throw new NotImplementedException("Error images haven't been implemented yet.", error);
|
Console.WriteLine("[{0}] Error generating thumbnail {1}: {2}",
|
||||||
|
DateTime.Now.ToShortTimeString(),
|
||||||
|
imagePath,
|
||||||
|
error.Message
|
||||||
|
);
|
||||||
|
|
||||||
|
using (Font drawingFont = new Font("Sans-serif", 18f, FontStyle.Regular, GraphicsUnit.Pixel))
|
||||||
|
{
|
||||||
|
imageToSend = GenerateErrorImage(error.Message, drawingFont, Color.DarkGray, Color.Transparent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
byte[] imageData = GetImageBytesPng(imageToSend);
|
||||||
|
|
||||||
|
cycle.Response.ContentType = "image/png";
|
||||||
|
cycle.Response.ContentLength64 = imageData.LongLength;
|
||||||
|
|
||||||
|
await cycle.Response.OutputStream.WriteAsync(imageData, 0, imageData.Length);
|
||||||
|
|
||||||
|
imageToSend.Dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Image GenerateErrorImage(string errorText, Font textFont, Color foregroundColour, Color backgroundColour)
|
||||||
|
{
|
||||||
|
SizeF textSize = SizeF.Empty;
|
||||||
|
using(Image measuringImage = new Bitmap(1, 1))
|
||||||
|
using(Graphics measuringContext = Graphics.FromImage(measuringImage))
|
||||||
|
{
|
||||||
|
textSize = measuringContext.MeasureString(errorText, textFont);
|
||||||
|
}
|
||||||
|
|
||||||
|
Image resultImage = new Bitmap((int)textSize.Width, (int)textSize.Height);
|
||||||
|
using (Graphics resultContext = Graphics.FromImage(resultImage))
|
||||||
|
using (SolidBrush drawingBrush = new SolidBrush(foregroundColour))
|
||||||
|
{
|
||||||
|
resultContext.Clear(backgroundColour);
|
||||||
|
resultContext.DrawString(errorText, textFont, drawingBrush, 0f, 0f);
|
||||||
|
}
|
||||||
|
return resultImage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static byte[] GetImageBytesPng(Image sourceImage)
|
||||||
|
{
|
||||||
|
using (MemoryStream mStream = new MemoryStream())
|
||||||
|
{
|
||||||
|
sourceImage.Save(mStream, ImageFormat.Png);
|
||||||
|
return mStream.ToArray();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue