Represents a filter kernel to use in convoluting an image. More...
#include <juce_ImageConvolutionKernel.h>
Public Member Functions | |
ImageConvolutionKernel (int size) | |
Creates an empty convolution kernel. More... | |
~ImageConvolutionKernel () | |
Destructor. More... | |
void | applyToImage (Image &destImage, const Image &sourceImage, const Rectangle< int > &destinationArea) const |
Applies the kernel to an image. More... | |
void | clear () |
Resets all values in the kernel to zero. More... | |
void | createGaussianBlur (float blurRadius) |
Initialises the kernel for a gaussian blur. More... | |
int | getKernelSize () const |
Returns the size of the kernel. More... | |
float | getKernelValue (int x, int y) const noexcept |
Returns one of the kernel values. More... | |
void | rescaleAllValues (float multiplier) |
Multiplies all values in the kernel by a value. More... | |
void | setKernelValue (int x, int y, float value) noexcept |
Sets the value of a specific cell in the kernel. More... | |
void | setOverallSum (float desiredTotalSum) |
Rescales all values in the kernel to make the total add up to a fixed value. More... | |
Private Attributes | |
const int | size |
HeapBlock< float > | values |
Represents a filter kernel to use in convoluting an image.
@tags{Graphics}
juce::ImageConvolutionKernel::ImageConvolutionKernel | ( | int | size | ) |
Creates an empty convolution kernel.
size | the length of each dimension of the kernel, so e.g. if the size is 5, it will create a 5x5 kernel |
juce::ImageConvolutionKernel::~ImageConvolutionKernel | ( | ) |
Destructor.
void juce::ImageConvolutionKernel::applyToImage | ( | Image & | destImage, |
const Image & | sourceImage, | ||
const Rectangle< int > & | destinationArea | ||
) | const |
Applies the kernel to an image.
destImage | the image that will receive the resultant convoluted pixels. |
sourceImage | the source image to read from - this can be the same image as the destination, but if different, it must be exactly the same size and format. |
destinationArea | the region of the image to apply the filter to |
void juce::ImageConvolutionKernel::clear | ( | ) |
Resets all values in the kernel to zero.
void juce::ImageConvolutionKernel::createGaussianBlur | ( | float | blurRadius | ) |
Initialises the kernel for a gaussian blur.
blurRadius | this may be larger or smaller than the kernel's actual size but this will obviously be wasteful or clip at the edges. Ideally the kernel should be just larger than (blurRadius * 2). |
|
inline |
Returns the size of the kernel.
E.g. if it's a 3x3 kernel, this returns 3.
References juce::gl::size.
Returns one of the kernel values.
void juce::ImageConvolutionKernel::rescaleAllValues | ( | float | multiplier | ) |
Multiplies all values in the kernel by a value.
Sets the value of a specific cell in the kernel.
The x and y parameters must be in the range 0 < x < getKernelSize().
void juce::ImageConvolutionKernel::setOverallSum | ( | float | desiredTotalSum | ) |
Rescales all values in the kernel to make the total add up to a fixed value.
This will multiply all values in the kernel by (desiredTotalSum / currentTotalSum).
|
private |