|
|
This class includes various QImage based graphical effects.
Everything is static, so there is no need to create an instance of this class. You can just call the static methods. They are encapsulated here merely to provide a common namespace.
enum GradientType { VerticalGradient, HorizontalGradient, DiagonalGradient, CrossDiagonalGradient, PyramidGradient, RectangleGradient, PipeCrossGradient, EllipticGradient } | GradientType |
enum RGBComponent { Red, Green, Blue, Gray, All } | RGBComponent |
enum Lighting {NorthLite, NWLite, WestLite, SWLite, SouthLite, SELite, EastLite, NELite} | Lighting |
enum ModulationType { Intensity, Saturation, HueShift, Contrast } | ModulationType |
enum NoiseType { UniformNoise=0, GaussianNoise, MultiplicativeGaussianNoise, ImpulseNoise, LaplacianNoise, PoissonNoise} | NoiseType |
enum RotateDirection { Rotate90, Rotate180, Rotate270 } | RotateDirection |
QImage gradient (const QSize &size, const QColor &ca,
const QColor &cb, GradientType type, int ncols=3)
| gradient |
[static]
Create a gradient from color a to color b of the specified type.
Parameters:
size | The desired size of the gradient. |
ca | Color a |
cb | Color b |
type | The type of gradient. |
ncols | The number of colors to use when not running on a truecolor display. The gradient will be dithered to this number of colors. Pass 0 to prevent dithering. |
QImage unbalancedGradient (const QSize &size, const QColor &ca,
const QColor &cb, GradientType type, int xfactor = 100,
int yfactor = 100, int ncols = 3)
| unbalancedGradient |
[static]
Create an unbalanced gradient.
An unbalanced gradient is a gradient where the transition from color a to color b is not linear, but in this case, exponential.
Parameters:
size | The desired size of the gradient. |
ca | Color a |
cb | Color b |
type | The type of gradient. |
xfactor | The x decay length. Use a value between -200 and 200. |
yfactor | The y decay length. |
ncols | The number of colors. See KPixmapEffect:gradient. |
QImage& blend (const QColor& clr, QImage& dst, float opacity)
| blend |
[static]
Blends a color into the destination image, using an opacity value for blending one into another. Very fast direct pixel manipulation is used.
Parameters:
clr | source color to be blended into the destination image. |
dst | destination image in which the source will be blended into. |
opacity | opacity (in percent) which determines how much the source color will be blended into the destination image. |
Returns: The destination image (dst) containing the result.
QImage& blend (QImage& src, QImage& dst, float opacity)
| blend |
[static]
Blend the src image into the destination image, using an opacity value for blending one into another. Very fast direct pixel manipulation is used.
Parameters:
src | source image to be blended into the destination image. |
dst | destination image in which the source will be blended into. |
opacity | opacity (in percent) which determines how much the source image will be blended into the destination image. |
Returns: The destination image (dst) containing the result.
QImage& blend (QImage &image, float initial_intensity,
const QColor &bgnd, GradientType eff,
bool anti_dir=false)
| blend |
[static]
Blend the provided image into a background of the indicated color.
Parameters:
initial_intensity | this parameter takes values from -1 to 1: a) if positive: how much to fade the image in its less affected spot b) if negative: roughly indicates how much of the image remains unaffected |
bgnd | indicates the color of the background to blend in |
eff | lets you choose what kind of blending you like |
anti_dir | blend in the opposite direction (makes no much sense with concentric blending effects) |
image | must be 32bpp |
QImage& blend (QImage &image1,QImage &image2,
GradientType gt, int xf=100, int yf=100)
| blend |
[static]
Blend an image into another one, using a gradient type for blending from one to another.
Parameters:
image1 | source1 and result of blending |
image2 | source2 of blending |
gt | gradient type for blending between source1 and source2 |
xf | x decay length for unbalanced gradient tpye |
yf | y decay length for unbalanced gradient tpye |
QImage& blend (QImage &image1, QImage &image2,
QImage &blendImage, RGBComponent channel)
| blend |
[static]
Blend an image into another one, using a color channel of a third image for the decision of blending from one to another.
Parameters:
image1 | Source 1 and result of blending |
image2 | Source 2 of blending |
blendImage | If the gray value of of pixel is 0, the result for this pixel is that of image1; for a gray value of 1, the pixel of image2 is used; for a value inbetween, a corresponding blending is used. |
channel | The RBG channel to use for the blending decision. |
bool blend (const QImage & upper, const QImage & lower, QImage & output)
| blend |
[static]
Blend an image into another one, using alpha in the expected way.
bool blend (int &x, int &y, const QImage & upper, const QImage & lower, QImage & output)
| blend |
[static]
Blend an image into another one, using alpha in the expected way and
over coordinates x
and y
with respect to the lower image.
The output is a QImage which is the upper
image already blended
with the lower
one, so its size will be (in general) the same than
upper
instead of the same size than lower
like the method above.
In fact, the size of output
is like upper's one only when it can be
painted on lower, if there has to be some clipping, output's size will
be the clipped area and x and y will be set to the correct up-left corner
where the clipped rectangle begins.
bool blendOnLower (int x, int y, const QImage & upper, const QImage & lower)
| blendOnLower |
[static]
Blend an image into another one, using alpha in the expected way and
over coordinates x
and y
with respect to the lower image.
The output is painted in the own lower
image. This is an optimization
of the blend method above provided by convenience.
QImage& channelIntensity (QImage &image, float percent,
RGBComponent channel)
| channelIntensity |
[static]
Modifies the intensity of a pixmap's RGB channel component.
Parameters:
image | The QImage to process. |
percent | Percent value. Use a negative value to dim. |
channel | Which channel(s) should be modified |
Returns: The image
, provided for convenience.
QImage& fade (QImage &img, float val, const QColor &color)
| fade |
[static]
Fade an image to a certain background color.
The number of colors will not be changed.
Parameters:
image | The QImage to process. |
val | The strength of the effect. 0 <= val <= 1. |
color | The background color. |
Returns: Returns the image(), provided for convenience.
QImage& flatten (QImage &image, const QColor &ca,
const QColor &cb, int ncols=0)
| flatten |
[static]
This recolors a pixmap. The most dark color will become color a, the most bright one color b, and in between.
Parameters:
image | A QImage to process. |
ca | Color a |
cb | Color b |
QImage& hash (QImage &image, Lighting lite=NorthLite,
unsigned int spacing=0)
| hash |
[static]
Build a hash on any given QImage
Parameters:
image | The QImage to process |
lite | The hash faces the indicated lighting (cardinal poles). |
spacing | How many unmodified pixels inbetween hashes. |
Returns: Returns the image(), provided for convenience.
QImage& intensity (QImage &image, float percent)
| intensity |
[static]
Either brighten or dim the image by a specified percent. For example, .50 will modify the colors by 50%.
Parameters:
image | The QImage to process. |
percent | The percent value. Use a negative value to dim. |
Returns: Returns The image(), provided for convenience.
QImage& modulate (QImage &image, QImage &modImage, bool reverse,
ModulationType type, int factor, RGBComponent channel)
| modulate |
[static]
Modulate the image with a color channel of another image.
Parameters:
image | The QImage to modulate and result. |
modImage | The QImage to use for modulation. |
reverse | Invert the meaning of image/modImage; result is image! |
type | The modulation Type to use. |
factor | The modulation amplitude; with 0 no effect [-200;200]. |
channel | The RBG channel of image2 to use for modulation. |
Returns: Returns the image(), provided for convenience.
QImage& toGray (QImage &image, bool fast = false)
| toGray |
[static]
Convert an image to grayscale.
Parameters:
image | The QImage to process. |
fast | Set to true in order to use a faster but non-photographic
quality algorithm. Appropriate for things such as toolbar icons.
|
Returns: Returns the image(), provided for convenience.
QImage& desaturate (QImage &image, float desat = 0.3)
| desaturate |
[static]
Desaturate an image evenly.
Parameters:
image | The QImage to process. |
desat | A value between 0 and 1 setting the degree of desaturation |
Returns: Returns the image(), provided for convenience.
QImage& contrast (QImage &image, int c)
| contrast |
[static]
Fast, but low quality contrast of an image. Also see contrastHSV.
Parameters:
image | The QImage to process. |
c | A contrast value between -255 to 255. |
Returns: The image(), provided for convenience.
QImage& dither (QImage &img, const QColor *palette, int size)
| dither |
[static]
Dither an image using Floyd-Steinberg dithering for low-color situations.
Parameters:
image | The QImage to process. |
palette | The color palette to use |
size | The size of the palette |
Returns: Returns the image(), provided for convenience.
QImage& selectedImage ( QImage &img, const QColor &col )
| selectedImage |
[static]
Calculate the image for a selected image, for instance a selected icon on the desktop.
Parameters:
img | the QImage to select |
col | the selected color, usually from QColorGroup::highlight(). |
void contrastHSV (QImage &img, bool sharpen=true)
| contrastHSV |
[static]
High quality, expensive HSV contrast. You can do a faster one by just taking a intensity threshold (ie: 128) and incrementing RGB color channels above it and decrementing those below it, but this gives much better results.
Parameters:
img | The QImage to process. |
sharpen | If true sharpness is increase, (spiffed). Otherwise it is decreased, (dulled). |
void normalize (QImage &img)
| normalize |
[static]
Normalizes the pixel values to span the full range of color values. This is a contrast enhancement technique.
void equalize (QImage &img)
| equalize |
[static]
Performs histogram equalization on the reference image.
void threshold (QImage &img, unsigned int value=128)
| threshold |
[static]
Thresholds the reference image. You can also threshold images by using ThresholdDither in the various QPixmap/QImage convert methods, but this lets you specify a threshold value.
Parameters:
img | The QImage to process. |
value | The threshold value. |
void solarize (QImage &img, double factor=50.0)
| solarize |
[static]
Produces a 'solarization' effect seen when exposing a photographic film to light during the development process.
Parameters:
img | The QImage to process. |
factor | The extent of the solarization (0-99.9) |
QImage emboss (QImage &src)
| emboss |
[static]
Embosses the source image. This involves highlighting the edges and applying various other enhancements in order to get a metal effect.
Parameters:
src | The QImage to process. |
Returns: The embossed image. The original is not changed.
QImage despeckle (QImage &src)
| despeckle |
[static]
Minimizes speckle noise in the source image using the 8 hull algorithm.
Parameters:
src | The QImage to process. |
Returns: The despeckled image. The original is not changed.
QImage charcoal (QImage &src, double factor=50.0)
| charcoal |
[static]
Produces a neat little "charcoal" effect.
Parameters:
src | The QImage to process. |
factor | The factor for detecting lines (0-99.0). |
Returns: The charcoal image. The original is not changed.
QImage rotate (QImage &src, RotateDirection r)
| rotate |
[static]
Rotates the image by the specified amount
Parameters:
src | The QImage to process. |
r | The rotate direction. |
Returns: The rotated image. The original is not changed.
QImage sample (QImage &src, int w, int h)
| sample |
[static]
Scales an image using simple pixel sampling. This does not produce nearly as nice a result as QImage::smoothScale(), but has the advantage of being much faster - only a few milliseconds.
Parameters:
src | The QImage to process. |
w | The new width. |
h | The new height. |
Returns: The scaled image. The original is not changed.
QImage addNoise (QImage &src, NoiseType type = GaussianNoise)
| addNoise |
[static]
Adds noise to an image.
Parameters:
src | The QImage to process. |
type | The algorithm used to generate the noise. |
Returns: The image with noise added. The original is not changed.
QImage blur (QImage &src, double factor=50.0)
| blur |
[static]
Blurs an image by convolving pixel neighborhoods.
Parameters:
src | The QImage to process. |
factor | The percent weight to give to the center pixel. |
Returns: The blurred image. The original is not changed.
QImage edge (QImage &src, double factor=50.0)
| edge |
[static]
Detects edges in an image using pixel neighborhoods and an edge detection mask.
Parameters:
src | The QImage to process. |
factor | The percent weight to give to the center pixel. |
Returns: The image with edges detected. The original is not changed.
QImage implode (QImage &src, double factor=30.0,
unsigned int background = 0xFFFFFFFF)
| implode |
[static]
Implodes an image by a specified percent.
Parameters:
src | The QImage to process. |
factor | The extent of the implosion. |
background | An RGBA value to use for the background. After the effect some pixels may be "empty". This value is used for those pixels. |
Returns: The imploded image. The original is not changed.
QImage oilPaint (QImage &src, int radius=3)
| oilPaint |
[static]
Produces an oil painting effect.
Parameters:
src | The QImage to process. |
radius | The radius of the pixel neighborhood used in applying the effect. |
Returns: The new image. The original is not changed.
QImage sharpen (QImage &src, double factor=30.0)
| sharpen |
[static]
Sharpens the pixels in the image using pixel neighborhoods.
Parameters:
src | The QImage to process. |
factor | The percent weight to give to the center pixel. |
Returns: The sharpened image. The original is not changed.
QImage spread (QImage &src, unsigned int amount=3)
| spread |
[static]
Randomly displaces pixels.
Parameters:
src | The QImage to process. |
amount | The vicinity for choosing a random pixel to swap. |
Returns: The image with pixels displaced. The original is not changed.
QImage shade (QImage &src, bool color_shading=true, double azimuth=30.0,
double elevation=30.0)
| shade |
[static]
Shades the image using a distance light source.
Parameters:
src | The QImage to process. |
color_shading | If true do color shading, otherwise do grayscale. |
azimuth | Determines the light source and direction. |
elevation | Determines the light source and direction. |
Returns: The shaded image. The original is not changed.
QImage swirl (QImage &src, double degrees=50.0, unsigned int background =
0xFFFFFFFF)
| swirl |
[static]
Swirls the image by a specified amount
Parameters:
src | The QImage to process. |
degrees | The tightness of the swirl. |
background | An RGBA value to use for the background. After the effect some pixels may be "empty". This value is used for those pixels. |
Returns: The swirled image. The original is not changed.
QImage wave (QImage &src, double amplitude=25.0, double frequency=150.0,
unsigned int background = 0xFFFFFFFF)
| wave |
[static]
Modifies the pixels along a sine wave.
Parameters:
src | The QImage to process. |
amplitude | The amplitude of the sine wave. |
wavelength | The frequency of the sine wave. |
Returns: The new image. The original is not changed.
Generated by: caleb on tcdevel on Tue Jan 28 12:54:01 2003, using kdoc $. |