mirror of https://github.com/SixLabors/ImageSharp
Browse Source
Former-commit-id: dd83c793aea242e533c04f1ed0526319e3608c7b Former-commit-id: 27cfda9e96a3148eb9345992050880cfa830dbd5 Former-commit-id: 4d4eb638fed3de06a05eca59d161acdd2d389b7faf/merge-core
2 changed files with 34 additions and 0 deletions
@ -0,0 +1,33 @@ |
|||
// <copyright file="Lanczos5Resampler.cs" company="James South">
|
|||
// Copyright © James South and contributors.
|
|||
// Licensed under the Apache License, Version 2.0.
|
|||
// </copyright>
|
|||
|
|||
namespace ImageProcessor.Samplers |
|||
{ |
|||
/// <summary>
|
|||
/// The function implements the Lanczos kernel algorithm as described on
|
|||
/// <see href="https://en.wikipedia.org/wiki/Lanczos_resampling#Algorithm">Wikipedia</see>
|
|||
/// </summary>
|
|||
public class Lanczos5Resampler : IResampler |
|||
{ |
|||
/// <inheritdoc/>
|
|||
public double Radius => 5; |
|||
|
|||
/// <inheritdoc/>
|
|||
public double GetValue(double x) |
|||
{ |
|||
if (x < 0) |
|||
{ |
|||
x = -x; |
|||
} |
|||
|
|||
if (x < 5) |
|||
{ |
|||
return ImageMaths.SinC(x) * ImageMaths.SinC(x / 5f); |
|||
} |
|||
|
|||
return 0; |
|||
} |
|||
} |
|||
} |
|||
Loading…
Reference in new issue