mini refactor

This commit is contained in:
2023-08-16 15:58:01 -03:00
parent 6755d55342
commit 6f411c3c52
4 changed files with 68 additions and 40 deletions

View File

@@ -1,55 +1,30 @@
using ImageMagick;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc;
using TCC.Services;
namespace tcc_app.Controllers
namespace TCC.Controllers
{
[ApiController]
[Route("")]
public class ImageController : ControllerBase
{
private ImageService ImageService { get; set; }
public ImageController(ImageService imageService)
{
this.ImageService = imageService;
}
[HttpPost("blur")]
public async Task<IActionResult> BlurImage()
{
MemoryStream mstream = new MemoryStream();
await HttpContext.Request.Body.CopyToAsync(mstream);
mstream.Position = 0;
var image = new MagickImage(new MemoryStream(mstream.ToArray()));
var blurredImage = new MagickImage(image);
var pixels = image.GetPixels();
var blurredPixels = blurredImage.GetPixelsUnsafe();
foreach (var pixel in pixels)
{
int x = pixel.X,
y = pixel.Y;
long rTotal = 0, gTotal = 0, bTotal = 0;
int pixelCount = 0;
for (short offsetY = -5; offsetY <= 5; offsetY++)
{
for (short offsetX = -5; offsetX <= 5; offsetX++)
{
int newX = x + offsetX;
int newY = y + offsetY;
if (newX >= 0 && newX < image.Width && newY >= 0 && newY < image.Height)
{
var pixelColor = pixels[newX, newY];
rTotal += pixelColor.GetChannel(0);
gTotal += pixelColor.GetChannel(1);
bTotal += pixelColor.GetChannel(2);
pixelCount++;
}
}
}
blurredPixels[x, y].SetChannel(0, Convert.ToUInt16(rTotal / pixelCount));
blurredPixels[x, y].SetChannel(1, Convert.ToUInt16(gTotal / pixelCount));
blurredPixels[x, y].SetChannel(2, Convert.ToUInt16(bTotal / pixelCount));
}
var result = ImageService.BoxBlurImage(mstream, 5);
var blurredImageStream = new MemoryStream();
blurredImage.Write(blurredImageStream);
result.Write(blurredImageStream);
blurredImageStream.Position = 0;
return File(blurredImageStream, "image/png");