mirror of https://github.com/SixLabors/ImageSharp
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
113 lines
4.2 KiB
113 lines
4.2 KiB
// Copyright (c) Six Labors.
|
|
// Licensed under the Apache License, Version 2.0.
|
|
|
|
using System;
|
|
using System.Numerics;
|
|
|
|
using SixLabors.ImageSharp.PixelFormats;
|
|
using SixLabors.ImageSharp.Processing;
|
|
|
|
using Xunit;
|
|
|
|
namespace SixLabors.ImageSharp.Tests.Processing.Processors.Effects
|
|
{
|
|
[GroupOutput("Effects")]
|
|
public class PixelShaderTest
|
|
{
|
|
[Theory]
|
|
[WithFile(TestImages.Png.CalliphoraPartial, PixelTypes.Rgba32)]
|
|
public void FullImage<TPixel>(TestImageProvider<TPixel> provider)
|
|
where TPixel : unmanaged, IPixel<TPixel>
|
|
{
|
|
provider.RunValidatingProcessorTest(
|
|
x => x.ProcessPixelRowsAsVector4(
|
|
span =>
|
|
{
|
|
for (int i = 0; i < span.Length; i++)
|
|
{
|
|
Vector4 v4 = span[i];
|
|
float avg = (v4.X + v4.Y + v4.Z) / 3f;
|
|
span[i] = new Vector4(avg);
|
|
}
|
|
}),
|
|
appendPixelTypeToFileName: false);
|
|
}
|
|
|
|
[Theory]
|
|
[WithFile(TestImages.Png.CalliphoraPartial, PixelTypes.Rgba32)]
|
|
public void InBox<TPixel>(TestImageProvider<TPixel> provider)
|
|
where TPixel : unmanaged, IPixel<TPixel>
|
|
{
|
|
provider.RunRectangleConstrainedValidatingProcessorTest(
|
|
(x, rect) => x.ProcessPixelRowsAsVector4(
|
|
span =>
|
|
{
|
|
for (int i = 0; i < span.Length; i++)
|
|
{
|
|
Vector4 v4 = span[i];
|
|
float avg = (v4.X + v4.Y + v4.Z) / 3f;
|
|
span[i] = new Vector4(avg);
|
|
}
|
|
}, rect));
|
|
}
|
|
|
|
[Theory]
|
|
[WithFile(TestImages.Png.CalliphoraPartial, PixelTypes.Rgba32)]
|
|
public void PositionAwareFullImage<TPixel>(TestImageProvider<TPixel> provider)
|
|
where TPixel : unmanaged, IPixel<TPixel>
|
|
{
|
|
provider.RunValidatingProcessorTest(
|
|
c => c.ProcessPixelRowsAsVector4(
|
|
(span, offset) =>
|
|
{
|
|
int y = offset.Y;
|
|
int x = offset.X;
|
|
for (int i = 0; i < span.Length; i++)
|
|
{
|
|
float
|
|
sine = MathF.Sin(y),
|
|
cosine = MathF.Cos(x + i),
|
|
sum = sine + cosine,
|
|
abs = MathF.Abs(sum),
|
|
a = 0.5f + (abs / 2); // Max value for sin(y) + cos(x) is 2
|
|
|
|
Vector4 v4 = span[i];
|
|
float avg = (v4.X + v4.Y + v4.Z) / 3f;
|
|
var gray = new Vector4(avg, avg, avg, a);
|
|
|
|
span[i] = Vector4.Clamp(gray, Vector4.Zero, Vector4.One);
|
|
}
|
|
}),
|
|
appendPixelTypeToFileName: false);
|
|
}
|
|
|
|
[Theory]
|
|
[WithFile(TestImages.Png.CalliphoraPartial, PixelTypes.Rgba32)]
|
|
public void PositionAwareInBox<TPixel>(TestImageProvider<TPixel> provider)
|
|
where TPixel : unmanaged, IPixel<TPixel>
|
|
{
|
|
provider.RunRectangleConstrainedValidatingProcessorTest(
|
|
(c, rect) => c.ProcessPixelRowsAsVector4(
|
|
(span, offset) =>
|
|
{
|
|
int y = offset.Y;
|
|
int x = offset.X;
|
|
for (int i = 0; i < span.Length; i++)
|
|
{
|
|
float
|
|
sine = MathF.Sin(y),
|
|
cosine = MathF.Cos(x + i),
|
|
sum = sine + cosine,
|
|
abs = MathF.Abs(sum),
|
|
a = 0.5f + (abs / 2);
|
|
|
|
Vector4 v4 = span[i];
|
|
float avg = (v4.X + v4.Y + v4.Z) / 3f;
|
|
var gray = new Vector4(avg, avg, avg, a);
|
|
|
|
span[i] = Vector4.Clamp(gray, Vector4.Zero, Vector4.One);
|
|
}
|
|
}, rect));
|
|
}
|
|
}
|
|
}
|
|
|