TypeLib Xojo support Plugin |
|
RawBitmap Class
A class to handle bitmaps on memory block level without dependency to Xojo’s Graphics functions.
Xojo’s console pictures suffer from loss of data because of the 7 bit alpha channel and their also extremely slow since their console images need to allocate one buffer per line in the image.
Xojo’s desktop pictures also are not consistent since some platforms use pre-multiplied alphas and others not. The premultiplied alphas also loose precision which makes them not suitable for most image processing.
See more info on the Xojo’s premultiplied alphas at:
Premultiplied alpha channels in Xojo
Object
RawBitmap
class RawBitmap
Constructors
RawBitmap | Constructs a new 4 channel RawBitmap with a given width and given height. |
RawBitmap | Constructs a new RawBitmap with a given width, given height and given number of channels. |
RawBitmap | Constructs a new RawBitmap with a given width, given height, given number of channels and given rowBytes value. |
RawBitmap | Constructs a RawBitmap with a given color space. This constructor can either take external MemoryBlock or handle allocating the MemoryBlock buffer. |
Properties
Channels | Returns the number of channels in the bitmap. |
ColorSpace | Returns info on what kind of colorspace the RawBitmap has. (RGB, Gray or CMYK). This can be any value from the RawBitmap.ColorSpaces enum. |
Depth | Returns the depth per channel of the bitmap. |
HasAlphaChannel | Returns true if the RawBitmap has alpha channel, else false. |
HasICCColorProfile | Returns true if the RawBitmap has ICC Color profile, else false |
Height | Returns the height of the Bitmap in pixels. |
HorizontalResolution | Returns the horizontal resolution of the image. (This can be set if the image was for example read from Jpg) |
ICCColorProfileName | Returns set value of the name of the ICC Color profile. |
ICCProfileData | Returns the raw ICC Color profile data if the RawBitmap contains ICC profile. |
ImageFormat | Returns the format of the color components in the RawBitmap |
IsFloatPixelMap | Returns true if the pixel map is based on floats. |
IsValid | Returns true if creating instance of the RawBitmap created valid instance, else false. |
MemoryBlock | Returns the memory block that is under the hood in the RawBitmap. |
PixelBytes | Returns number of bytes per pixel in the image. |
Premultiplied | Returns true if the bitmap is known to be premultiplied. |
RowBytes | Returns the number of bytes in each row of the bitmap. |
VerticalResolution | Returns the vertical resolution of the image. (This can be set if the image was for example read from Jpg) |
Width | Returns the width of the Bitmap in pixels. |
Methods
ClearICCColorProfile | Removes ICC color profile from the RawBitmap |
Clone | Clones the RawBitmap and optionally adds alpha channel. |
Convert | Converts between RawBitmap formats. |
CopyICCColorProfileFrom | Copies ICC profile from other RawBitmap instance and puts it on this instance of the RawBitmap |
Crop | Crops the image, returning a new RawBitmap with the result or nil if no parts of the image were within the Crop parameters. |
DrawBitmap | Draws a RawBitmap into the RawBitmap |
DrawEllipse | Draws non filled ellipse. |
DrawLine | Draws a line at given location into the RawBitmap with a given color. |
DrawLineAntialiased | Draws antialiased line at given location into the RawBitmap with a given color. |
DrawPixel | Draws pixel on the RawBitmap, doing alpha blending as needed depending on the color passed in, |
DrawRect | Draws non filled rectangle. |
Fill | Fills the Bitmap with given color, optionally using mask. |
FillRect | Draws filled rectangle of given color |
FillRectAlpha | Draws only the alpha channel of filled rectangle |
FloodFill | Advanced flood fill method that takes fill color, location, tolerance and do normal straight fill or straight and diagonal. |
FloodFillTask | Advanced flood fill method that takes fill color, location, tolerance and do normal straight fill or straight and diagonal. This variant of the method does not perform the task but rather returns a EinhugurRuntime.Task object to execute the routine in a native thread. |
GenerateFloodFillMask | Generates magic wand mask by using flood fill algorithm. |
GetPixelComponents | Gets component floating point values for given pixel |
Pixel | Sets or gets the color of a pixel in the RawBitmap. |
PixelAlpha | Sets or gets the alpha value for pixel at given location |
SetPixelComponents | Sets component floating point values for given pixel |
Unpremultiply | Unpremultiplies the RawBitmap if it is premultiplied. |
Delegates
ProgressDelegate (console safe) | Delegate type to be used with various of bitmap operations. |
Enumerations
RawBitmapFormat | Enum that represents the format of the color components.
The constants are named as follows:
g - Stands for grayscale channel.
A - Stands for alpha channel.
R - Stands for red channel.
G - Stands for green channel.
B - Stands for blue channel.
X - Stands for unused channel.
C - Stands for cyan channel.
M - Stands for magenta channel.
Y - Stands for yellow channel.
K - Stands for key channel. (used in CMYK color spaces)
|
ColorSpaces | A enum that has definitions of color spaces. |
Supported Platforms:
macOS Intel 64 bitmacOS Apple SiliconWindows 32 bitWindows 64 bitWindows ARM 64 bitLinux 32 bitLinux 64 bitLinux ARM 32 bitLinux ARM 64 bitiOS