LMMS
Loading...
Searching...
No Matches
juce::PixelARGB Class Reference

#include <juce_PixelFormats.h>

Classes

struct  Components

Public Types

enum  { indexA = 3 , indexR = 2 , indexG = 1 , indexB = 0 }

Public Member Functions

 PixelARGB () noexcept=default
 PixelARGB (uint8 a, uint8 r, uint8 g, uint8 b) noexcept
forcedinline uint32 getNativeARGB () const noexcept
forcedinline uint32 getInARGBMaskOrder () const noexcept
uint32 getInARGBMemoryOrder () const noexcept
forcedinline uint32 getEvenBytes () const noexcept
forcedinline uint32 getOddBytes () const noexcept
forcedinline uint8 getAlpha () const noexcept
forcedinline uint8 getRed () const noexcept
forcedinline uint8 getGreen () const noexcept
forcedinline uint8 getBlue () const noexcept
template<class Pixel>
forcedinline void set (const Pixel &src) noexcept
void setARGB (uint8 a, uint8 r, uint8 g, uint8 b) noexcept
template<class Pixel>
forcedinline void blend (const Pixel &src) noexcept
forcedinline void blend (PixelRGB src) noexcept
template<class Pixel>
forcedinline void blend (const Pixel &src, uint32 extraAlpha) noexcept
template<class Pixel>
forcedinline void tween (const Pixel &src, uint32 amount) noexcept
forcedinline void setAlpha (uint8 newAlpha) noexcept
forcedinline void multiplyAlpha (int multiplier) noexcept
forcedinline void multiplyAlpha (float multiplier) noexcept
PixelARGB getUnpremultiplied () const noexcept
forcedinline void premultiply () noexcept
forcedinline void unpremultiply () noexcept
forcedinline void desaturate () noexcept

Private Member Functions

 PixelARGB (uint32 internalValue) noexcept

Private Attributes

struct juce::PixelARGB::Components JUCE_PACKED
union { 
   uint32   internal 
   Components   components 
}; 

Detailed Description

Represents a 32-bit INTERNAL pixel with premultiplied alpha, and can perform compositing operations with it.

This is used internally by the imaging classes.

See also
PixelRGB

@tags{Graphics}

Member Enumeration Documentation

◆ anonymous enum

anonymous enum

The indexes of the different components in the byte layout of this type of colour.

Enumerator
indexA 
indexR 
indexG 
indexB 

Constructor & Destructor Documentation

◆ PixelARGB() [1/3]

juce::PixelARGB::PixelARGB ( )
defaultnoexcept

Creates a pixel without defining its colour.

◆ PixelARGB() [2/3]

juce::PixelARGB::PixelARGB ( uint8 a,
uint8 r,
uint8 g,
uint8 b )
inlinenoexcept

◆ PixelARGB() [3/3]

juce::PixelARGB::PixelARGB ( uint32 internalValue)
inlineprivatenoexcept

Member Function Documentation

◆ blend() [1/3]

template<class Pixel>
forcedinline void juce::PixelARGB::blend ( const Pixel & src)
inlinenoexcept

Blends another pixel onto this one.

This takes into account the opacity of the pixel being overlaid, and blends it accordingly.

◆ blend() [2/3]

template<class Pixel>
forcedinline void juce::PixelARGB::blend ( const Pixel & src,
uint32 extraAlpha )
inlinenoexcept

Blends another pixel onto this one, applying an extra multiplier to its opacity.

The opacity of the pixel being overlaid is scaled by the extraAlpha factor before being used, so this can blend semi-transparently from a PixelRGB argument.

◆ blend() [3/3]

forcedinline void juce::PixelARGB::blend ( PixelRGB src)
noexcept

Blends another pixel onto this one.

This takes into account the opacity of the pixel being overlaid, and blends it accordingly.

◆ desaturate()

forcedinline void juce::PixelARGB::desaturate ( )
inlinenoexcept

◆ getAlpha()

forcedinline uint8 juce::PixelARGB::getAlpha ( ) const
inlinenoexcept

◆ getBlue()

forcedinline uint8 juce::PixelARGB::getBlue ( ) const
inlinenoexcept

◆ getEvenBytes()

forcedinline uint32 juce::PixelARGB::getEvenBytes ( ) const
inlinenoexcept

Return channels with an even index and insert zero bytes between them. This is useful for blending operations. The exact channels which are returned is platform dependent.

◆ getGreen()

forcedinline uint8 juce::PixelARGB::getGreen ( ) const
inlinenoexcept

◆ getInARGBMaskOrder()

forcedinline uint32 juce::PixelARGB::getInARGBMaskOrder ( ) const
inlinenoexcept

Returns a uint32 which will be in argb order as if constructed with the following mask operation ((alpha << 24) | (red << 16) | (green << 8) | blue).

◆ getInARGBMemoryOrder()

uint32 juce::PixelARGB::getInARGBMemoryOrder ( ) const
inlinenoexcept

Returns a uint32 which when written to memory, will be in the order a, r, g, b. In other words, if the return-value is read as a uint8 array then the elements will be in the order of a, r, g, b

◆ getNativeARGB()

forcedinline uint32 juce::PixelARGB::getNativeARGB ( ) const
inlinenoexcept

Returns a uint32 which represents the pixel in a platform dependent format.

◆ getOddBytes()

forcedinline uint32 juce::PixelARGB::getOddBytes ( ) const
inlinenoexcept

Return channels with an odd index and insert zero bytes between them. This is useful for blending operations. The exact channels which are returned is platform dependent.

◆ getRed()

forcedinline uint8 juce::PixelARGB::getRed ( ) const
inlinenoexcept

◆ getUnpremultiplied()

PixelARGB juce::PixelARGB::getUnpremultiplied ( ) const
inlinenoexcept

◆ multiplyAlpha() [1/2]

forcedinline void juce::PixelARGB::multiplyAlpha ( float multiplier)
inlinenoexcept

◆ multiplyAlpha() [2/2]

forcedinline void juce::PixelARGB::multiplyAlpha ( int multiplier)
inlinenoexcept

Multiplies the colour's alpha value with another one.

◆ premultiply()

forcedinline void juce::PixelARGB::premultiply ( )
inlinenoexcept

Premultiplies the pixel's RGB values by its alpha.

◆ set()

template<class Pixel>
forcedinline void juce::PixelARGB::set ( const Pixel & src)
inlinenoexcept

Copies another pixel colour over this one.

This doesn't blend it - this colour is simply replaced by the other one.

◆ setAlpha()

forcedinline void juce::PixelARGB::setAlpha ( uint8 newAlpha)
inlinenoexcept

Replaces the colour's alpha value with another one.

◆ setARGB()

void juce::PixelARGB::setARGB ( uint8 a,
uint8 r,
uint8 g,
uint8 b )
inlinenoexcept

Sets the pixel's colour from individual components.

◆ tween()

template<class Pixel>
forcedinline void juce::PixelARGB::tween ( const Pixel & src,
uint32 amount )
inlinenoexcept

Blends another pixel with this one, creating a colour that is somewhere between the two, as specified by the amount.

◆ unpremultiply()

forcedinline void juce::PixelARGB::unpremultiply ( )
inlinenoexcept

Unpremultiplies the pixel's RGB values.

Member Data Documentation

◆ [union]

union { ... } juce::PixelARGB

◆ components

Components juce::PixelARGB::components

◆ internal

uint32 juce::PixelARGB::internal

◆ JUCE_PACKED

struct juce::PixelARGB::Components juce::PixelARGB::JUCE_PACKED
private

The documentation for this class was generated from the following file: