Class TEncodedImage
Unit
Declaration
type TEncodedImage = class(TObject)
Description
Abstract class for an image with unspecified, possibly compressed, memory format. The idea is that both uncompressed images (TCastleImage) and images compressed for GPU (TGPUCompressedImage) are derived from this class.
Hierarchy
- TObject
- TEncodedImage
Overview
Fields
FRawPixels: Pointer; |
Methods
destructor Destroy; override; |
|
function Size: Cardinal; virtual; abstract; |
|
function Dimensions: TVector3Cardinal; |
|
function IsEmpty: boolean; |
|
function HasAlpha: boolean; virtual; |
|
function AlphaChannel( const AlphaTolerance: Byte = DefaultAlphaTolerance): TAlphaChannel; virtual; |
|
function Rect: TRectangle; |
|
function CreateCopy: TEncodedImage; virtual; abstract; |
|
procedure FlipVertical; virtual; abstract; |
|
function ToFpImage: TInternalCastleFpImage; virtual; deprecated 'interoperability with FpImage may be dropped in the future'; |
Properties
property URL: string read FURL write FURL; |
|
property Width: Cardinal read FWidth; |
|
property Height: Cardinal read FHeight; |
|
property Depth: Cardinal read FDepth; |
|
property RawPixels: Pointer read FRawPixels; |
Description
Fields
FRawPixels: Pointer; |
|
Operate on this by Get/Realloc/FreeMem. It's always freed and nil'ed in destructor. |
Methods
destructor Destroy; override; |
|
function Size: Cardinal; virtual; abstract; |
|
Size of image contents in bytes. |
function Dimensions: TVector3Cardinal; |
|
function IsEmpty: boolean; |
|
Is an image empty.
|
function HasAlpha: boolean; virtual; |
|
Does an image have an alpha channel. You may also be interested in the AlphaChannel. AlphaChannel answers always atNone if Descendants implementors notes: in this class, TCastleImage, this returns |
function AlphaChannel( const AlphaTolerance: Byte = DefaultAlphaTolerance): TAlphaChannel; virtual; |
|
Check does an image have an alpha channel, and if yes analyze alpha channel: is it a single yes-no (only full or none values), or does it have alpha values in between?
This is quite useful for automatic detection how alpha textures should be displayed: for simple yes/no alpha, OpenGL alpha_test is a simple solution. For full range alpha, OpenGL blending should be used. Blending is a little problematic, since it requires special rendering order, since it doesn't cooperate nicely with Z-buffer. That's why we try to detect simple yes/no alpha textures, so that we're able to use simpler alpha test for them. We return "simple yes/no alpha channel" is all the alpha values (for every pixel) are 0, or 255, or (when AlphaTolerance <> 0) are close to them by AlphaTolerance. So, to be precise, alpha value must be <= AlphaTolerance, or >= 255 - AlphaTolerance. If any alpha value is between [AlphaTolerance + 1, 255 - AlphaTolerance - 1] then we return "full range alpha channel". Note that for AlphaTolerance >= 128, all images are treated as "simple yes/no alpha". Usually, you want to keep AlphaTolerance small. Descendants implementors notes: in this class, this simply always returns atNone. For descendants that have alpha channel, implement it, honouring AlphaTolerance as described. |
function Rect: TRectangle; |
|
Rectangle representing the inside of this image. Always (Left,Bottom) are zero, and (Width,Height) correspond to image sizes. |
function CreateCopy: TEncodedImage; virtual; abstract; |
|
Create a new image object that has exactly the same class and the same data (size, pixels) as this image. |
procedure FlipVertical; virtual; abstract; |
|
Mirror image vertically. |
Properties
property URL: string read FURL write FURL; |
|
|
property Width: Cardinal read FWidth; |
|
property Height: Cardinal read FHeight; |
|
property Depth: Cardinal read FDepth; |
|
property RawPixels: Pointer read FRawPixels; |
|
Generated by PasDoc 0.16.0.