PaintBitmap Class Reference

#include <c4d_painter.h>

Inheritance diagram for PaintBitmap:

Detailed Description

The base class of all paint classes. Can be a texture, material, layer or mask.

Public Member Functions

Int32 GetBw () const
 
Int32 GetBh () const
 
PaintTextureGetPaintTexture ()
 
const PaintTextureGetPaintTexture () const
 
PaintBitmapGetParent ()
 
const PaintBitmapGetParent () const
 
PaintLayerGetLayerDownFirst ()
 
const PaintLayerGetLayerDownFirst () const
 
PaintLayerGetLayerDownLast ()
 
const PaintLayerGetLayerDownLast () const
 
PaintLayerGetAlphaFirst ()
 
const PaintLayerGetAlphaFirst () const
 
PaintLayerGetAlphaLast ()
 
const PaintLayerGetAlphaLast () const
 
PaintLayerBmpAddAlphaChannel (Int32 bitdepth, PaintLayer *prev=nullptr, Bool undo=true, Bool activate=true)
 
Bool AskApplyAlphaMask () const
 
void ApplyAlphaMask (Int32 x, Int32 y, Int32 cnt, PIX *bits, COLORMODE mode, Bool inverted, Int32 flags) const
 
PaintLayerMaskFindSelectionMask (PaintBitmap **toplevel, Int32 *bitdepth)
 
COLORMODE GetColorMode () const
 
UInt32 GetDirty (DIRTYFLAGS flags) const
 
void UpdateRefresh (Int32 xmin, Int32 ymin, Int32 xmax, Int32 ymax, UInt32 flags)
 
void UpdateRefreshAll (UInt32 flags, Bool reallyall)
 
Bool ReCalc (BaseThread *thread, Int32 x1, Int32 y1, Int32 x2, Int32 y2, BaseBitmap *bmp, Int32 flags, UInt32 showbit)
 
- Public Member Functions inherited from BaseList2D
void SetBit (Int32 mask)
 
Bool GetBit (Int32 mask) const
 
void DelBit (Int32 mask)
 
void ToggleBit (Int32 mask)
 
Int32 GetAllBits () const
 
void SetAllBits (Int32 bits)
 
void SetBitEx (Int32 mask, Int32 flags)
 
const CharGetViewportRenderId (VIEWPORT_RENDER_ID typeId) const
 
BaseList2DGetNext ()
 
const BaseList2DGetNext () const
 
BaseList2DGetPred ()
 
const BaseList2DGetPred () const
 
BaseContainer GetData ()
 
void SetData (const BaseContainer &bc, Bool add=true)
 
const BaseContainerGetDataInstanceRef () const
 
BaseContainerGetDataInstanceRef ()
 
const BaseContainerGetDataInstance () const
 
BaseContainerGetDataInstance ()
 
String GetName () const
 
void SetName (const maxon::String &name, Bool setDirty=true)
 
String GetBubbleHelp ()
 
Bool TransferGoal (BaseList2D *dst, Bool undolink)
 
Bool TransferMarker (BaseList2D *dst) const
 
Bool CopyDynamicDescriptionFrom (const BaseList2D *src)
 
Bool Scale (Float scale)
 
Bool Edit ()
 
void GetIcon (IconData *dat)
 
GeListHeadGetNLARoot (Bool create)
 
BaseList2DAnimationLayerRemap (BaseObject **layer=nullptr)
 
String GetTypeName () const
 
const BaseList2DGetMain () const
 
BaseList2DGetMain ()
 
void InsertTrackSorted (CTrack *track)
 
Bool AddEventNotification (BaseList2D *bl, NOTIFY_EVENT eventid, NOTIFY_EVENT_FLAG flags, const BaseContainer *data)
 
Bool RemoveEventNotification (const BaseDocument *doc, BaseList2D *bl, NOTIFY_EVENT eventid)
 
Bool FindEventNotification (const BaseDocument *doc, BaseList2D *bl, NOTIFY_EVENT eventid)
 
Bool SetDescIDState (const DescID &id, DESCIDSTATE descidstate)
 
DESCIDSTATE GetDescIDState (const DescID &id, Bool tolerant) const
 
GeListHeadGetOverrideRoot (Bool create)
 
BaseOverrideGetFirstOverride ()
 
GeListHeadGetShaderRepositoryRoot (Bool create)
 
GeListHeadGetHiddenShaderRoot (Bool create)
 
maxon::NimbusForwardRef GetNimbusRef (const maxon::Id &spaceId) const
 
maxon::Result< maxon::NimbusForwardRefPrivateGetOrCreateNimbusRef (const maxon::Id &spaceId)
 
void RemoveNimbusRef (const maxon::Id &spaceId)
 
maxon::Result< maxon::HashMap< maxon::Id, maxon::NimbusForwardRef > > GetAllNimbusRefs () const
 
Bool IsNodeBased () const
 
maxon::Result< BoolGetAccessedObjects (METHOD_ID method, AccessedObjectsCallback &access) const
 
maxon::Result< BoolGetAccessedObjectsRec (ACCESSED_OBJECTS_MASK read, ACCESSED_OBJECTS_MASK write, METHOD_ID method, Bool withSiblings, Bool withChildren, AccessedObjectsCallback &access) const
 
maxon::Result< BoolGetAccessedObjectsOfHierarchy (ACCESSED_OBJECTS_MASK read, ACCESSED_OBJECTS_MASK write, METHOD_ID method, AccessedObjectsCallback &access) const
 
maxon::Result< BoolGetAccessedObjectsOfChildren (ACCESSED_OBJECTS_MASK read, ACCESSED_OBJECTS_MASK write, METHOD_ID method, AccessedObjectsCallback &access) const
 
maxon::Result< BoolGetAccessedObjectsOfFirstChildHierarchy (ACCESSED_OBJECTS_MASK read, ACCESSED_OBJECTS_MASK write, METHOD_ID method, AccessedObjectsCallback &access) const
 
maxon::Result< maxon::GenericDataGroupChanges ()
 
void GetMarkerStampEx (UInt32 *l1, UInt32 *l2)
 
const GeMarkerGetMarker () const
 
void SetMarker (const GeMarker &m)
 
Bool AddUniqueID (Int32 appid, const Char *const mem, Int bytes)
 
Bool FindUniqueID (Int32 appid, const Char *&mem, Int &bytes) const
 
Int32 GetUniqueIDCount () const
 
Bool GetUniqueIDIndex (Int32 idx, Int32 &id, const Char *&mem, Int &bytes) const
 
Bool SetAnimatedParameter (const CTrack *track, const DescID &id, const GeData &t_data1, const GeData &t_data2, Float mix, DESCFLAGS_SET flags)
 
Bool GetAnimatedParameter (const DescID &id, GeData &t_data1, GeData &t_data2, Float &mix, DESCFLAGS_GET flags) const
 
BaseShaderGetFirstShader () const
 
void InsertShader (BaseShader *shader, BaseShader *pred=nullptr)
 
void ClearKeyframeSelection ()
 
Bool FindKeyframeSelection (const DescID &id)
 
Bool SetKeyframeSelection (const DescID &id, Bool selection)
 
Bool KeyframeSelectionContent ()
 
LayerObjectGetLayerObject (const BaseDocument *doc)
 
const LayerObjectGetLayerObject (const BaseDocument *doc) const
 
Bool SetLayerObject (const LayerObject *layer)
 
const LayerDataGetLayerData (const BaseDocument *doc, Bool rawdata=false) const
 
Bool SetLayerData (BaseDocument *doc, const LayerData &data)
 
GeListHeadGetCTrackRoot (Bool create)
 
const GeListHeadGetCTrackRoot () const
 
const CTrackGetFirstCTrack () const
 
CTrackGetFirstCTrack ()
 
const CTrackFindCTrack (const DescID &id) const
 
CTrackFindCTrack (const DescID &id)
 
- Public Member Functions inherited from GeListNode
GeListNodeGetNext ()
 
const GeListNodeGetNext () const
 
GeListNodeGetPred ()
 
const GeListNodeGetPred () const
 
GeListNodeGetDown ()
 
const GeListNodeGetDown () const
 
GeListNodeGetUp ()
 
const GeListNodeGetUp () const
 
GeListNodeGetDownLast ()
 
const GeListNodeGetDownLast () const
 
void InsertBefore (GeListNode *bl)
 
void InsertAfter (GeListNode *bl)
 
void InsertUnder (GeListNode *bl)
 
void InsertUnderLast (GeListNode *bl)
 
void Remove ()
 
void FlushChilds ()
 
void MoveChildrenTo (GeListNode *dest)
 
GeListHeadGetListHead ()
 
const GeListHeadGetListHead () const
 
Int32 GetNodeID (Int32 index=0) const
 
template<typename CAST >
const CAST * GetNodeData (Int32 index=0) const
 
template<typename CAST >
CAST * GetNodeData (Int32 index=0)
 
void SetCustomData (GeListNode *node)
 
GeListNodeGetCustomData ()
 
const GeListNodeGetCustomData () const
 
const BaseDocumentGetDocument () const
 
BaseDocumentGetDocument ()
 
maxon::Result< BoolGetBranchInfo (const maxon::ValueReceiver< const BranchInfo & > &info, GETBRANCHINFO flags) const
 
Bool IsDocumentRelated () const
 
Int32 GetInfo () const
 
Bool GetNBit (NBIT bit) const
 
UInt32 GetNBitMask (Int32 index) const
 
Bool ChangeNBit (NBIT bit, NBITCONTROL bitmode)
 
- Public Member Functions inherited from C4DAtomGoal
Bool HasLinks () const
 
- Public Member Functions inherited from C4DAtom
Int32 GetType () const
 
Int32 GetRealType () const
 
Int32 GetDiskType () const
 
Bool IsInstanceOf (Int32 id) const
 
Int32 GetClassification () const
 
Bool Message (Int32 type, void *data=nullptr)
 
Bool MultiMessage (MULTIMSG_ROUTE flags, Int32 type, void *data)
 
C4DAtomGetClone (COPYFLAGS flags, AliasTrans *trn) const
 
Bool CopyTo (C4DAtom *dst, COPYFLAGS flags, AliasTrans *trn) const
 
Bool Read (HyperFile *hf, Int32 id, Int32 level)
 
Bool Write (HyperFile *hf) const
 
Bool ReadObject (HyperFile *hf, Bool readheader)
 
Bool WriteObject (HyperFile *hf) const
 
Bool GetDescription (Description *description, DESCFLAGS_DESC flags) const
 
Bool GetParameter (const DescID &id, GeData &t_data, DESCFLAGS_GET flags) const
 
Bool SetParameter (const DescID &id, const GeData &t_data, DESCFLAGS_SET flags)
 
DynamicDescriptionGetDynamicDescriptionWritable ()
 
const DynamicDescriptionGetDynamicDescription () const
 
Bool CopyDynamicDescriptionFrom (const BaseList2D *src)
 
Bool GetEnabling (const DescID &id, const GeData &t_data, DESCFLAGS_ENABLE flags, const BaseContainer *itemdesc) const
 
Bool TranslateDescID (const DescID &id, DescID &res_id, C4DAtom *&res_at)
 
UInt32 GetDirty (DIRTYFLAGS flags) const
 
void SetDirty (DIRTYFLAGS flags)
 
UInt32 GetHDirty (HDIRTYFLAGS mask) const
 
void SetHDirty (HDIRTYFLAGS mask)
 

Static Public Member Functions

static Bool ConvertBits (Int32 cnt, const PIX *src, Int32 srcinc, COLORMODE srcmode, PIX *dst, Int32 dstinc, COLORMODE dstmode, Int32 dithery, Int32 ditherx)
 
- Static Public Member Functions inherited from BaseList2D
static BaseList2DAlloc (Int32 type)
 
static void Free (BaseList2D *&bl)
 

Private Member Functions

 PaintBitmap ()
 
 ~PaintBitmap ()
 

Additional Inherited Members

- Static Public Attributes inherited from BaseList2D
static const Int32 SETBIT_FLAG_NODIRTY
 
static const Int32 SETBIT_FLAG_REMOVE
 

Constructor & Destructor Documentation

◆ PaintBitmap()

PaintBitmap ( )
private

◆ ~PaintBitmap()

~PaintBitmap ( )
private

Member Function Documentation

◆ GetBw()

Int32 GetBw ( ) const

Retrieves the width of the paint bitmap.

Returns
The width of the paint bitmap.

◆ GetBh()

Int32 GetBh ( ) const

Retrieves the height of the paint bitmap.

Returns
The height of the paint bitmap.

◆ GetPaintTexture() [1/2]

PaintTexture* GetPaintTexture ( )

Retrieves the paint texture if possible.

Returns
The paint texture, otherwise nullptr.

◆ GetPaintTexture() [2/2]

const PaintTexture* GetPaintTexture ( ) const

◆ GetParent() [1/2]

PaintBitmap* GetParent ( )

Retrieves the parent if available. This can be a layer or a texture for instance.

Returns
The parent, otherwise nullptr.

◆ GetParent() [2/2]

const PaintBitmap* GetParent ( ) const

◆ GetLayerDownFirst() [1/2]

PaintLayer* GetLayerDownFirst ( )

Retrieves the first child layer.

Returns
The first child layer, or nullptr if there is none.

◆ GetLayerDownFirst() [2/2]

const PaintLayer* GetLayerDownFirst ( ) const

◆ GetLayerDownLast() [1/2]

PaintLayer* GetLayerDownLast ( )

Retrieves the last child layer.

Returns
The last child layer, or nullptr if there is none.

◆ GetLayerDownLast() [2/2]

const PaintLayer* GetLayerDownLast ( ) const

◆ GetAlphaFirst() [1/2]

PaintLayer* GetAlphaFirst ( )

Retrieves the first alpha channel layer.

Returns
The first alpha channel layer, or nullptr if there is none.

◆ GetAlphaFirst() [2/2]

const PaintLayer* GetAlphaFirst ( ) const

◆ GetAlphaLast() [1/2]

PaintLayer* GetAlphaLast ( )

Retrieves the last alpha channel layer.

Returns
The last alpha channel layer, or nullptr if there is none.

◆ GetAlphaLast() [2/2]

const PaintLayer* GetAlphaLast ( ) const

◆ AddAlphaChannel()

PaintLayerBmp* AddAlphaChannel ( Int32  bitdepth,
PaintLayer prev = nullptr,
Bool  undo = true,
Bool  activate = true 
)

Adds an alpha channel to the layer.

Parameters
[in]bitdepthThe bit depth of the alpha channel: BITDEPTH
[in]prevAn optional point to insert the alpha channel.
[in]undotrue to create an undo on the undo stack, otherwise false.
[in]activatetrue to activate alpha channel.
Returns
The added alpha channel, or nullptr if it failed.

◆ AskApplyAlphaMask()

Bool AskApplyAlphaMask ( ) const

Checks if the alpha mask can be applied.

Returns
true if the alpha mask can be applied, otherwise false.

◆ ApplyAlphaMask()

void ApplyAlphaMask ( Int32  x,
Int32  y,
Int32  cnt,
PIX bits,
COLORMODE  mode,
Bool  inverted,
Int32  flags 
) const

Applies the alpha mask.

Parameters
[in]xThe X coordinate of the starting point.
[in]yThe Y coordinate of the starting point.
[in]cntThe length of the masked line.
[in]bitsThe masked pixels.
[in]modeThe color mode (only with alpha channel): COLORMODE
[in]invertedtrue to apply an inverted alpha mask.
[in]flagsThe flags: GETPIXEL

◆ FindSelectionMask()

PaintLayerMask* FindSelectionMask ( PaintBitmap **  toplevel,
Int32 bitdepth 
)

Finds the selection mask.

Parameters
[in]toplevelThe root level. PaintMaterial if the selection is in a material, otherwise PaintTexture.
[in]bitdepthThe bit depth of the selection mask.
Returns
The selection mask, or nullptr if there is none.

◆ GetColorMode()

COLORMODE GetColorMode ( ) const

Retrieves the color mode of the paint bitmap.

Returns
The color mode: COLORMODE

◆ GetDirty()

UInt32 GetDirty ( DIRTYFLAGS  flags) const

Retrieves the dirty count.

Parameters
[in]flagsReserved, must be DIRTYFLAGS::NONE.
Returns
The dirty count, incremented when the paint bitmap changes.

◆ UpdateRefresh()

void UpdateRefresh ( Int32  xmin,
Int32  ymin,
Int32  xmax,
Int32  ymax,
UInt32  flags 
)

Refreshes an area of the paint bitmap. Must be done after modifying it.

Parameters
[in]xminThe left coordinate of the refreshed area.
[in]yminThe top coordinate of the refreshed area.
[in]xmaxThe right coordinate of the refreshed area.
[in]ymaxThe bottom coordinate of the refreshed area.
[in]flagsThe flags: UPDATE

◆ UpdateRefreshAll()

void UpdateRefreshAll ( UInt32  flags,
Bool  reallyall 
)

Refreshes the complete paint bitmap. Has to be done after modifying it.

Parameters
[in]flagsThe flags: UPDATE
[in]reallyallIf true an infinite bounding box is used for the refresh.
If false the bounding box of the layer is used, this is much faster.

◆ ReCalc()

Bool ReCalc ( BaseThread thread,
Int32  x1,
Int32  y1,
Int32  x2,
Int32  y2,
BaseBitmap bmp,
Int32  flags,
UInt32  showbit 
)

Creates a flattened bitmap of the paint bitmap.

Parameters
[in]threadPass the thread to be used for the calculation.
[in]x1The left coordinate of the calculation window.
[in]y1The top coordinate of the calculation window.
[in]x2The right coordinate of the calculation window.
[in]y2The bottom coordinate of the calculation window.
[out]bmpThe flattened bitmap.
[in]flagsThe flags: RECALC
[in]showbitMust be set to 0.
Returns
true if successful, otherwise false.

◆ ConvertBits()

static Bool ConvertBits ( Int32  cnt,
const PIX src,
Int32  srcinc,
COLORMODE  srcmode,
PIX dst,
Int32  dstinc,
COLORMODE  dstmode,
Int32  dithery,
Int32  ditherx 
)
static

Converts pixel data.

Parameters
[in]cntThe number of pixels to convert.
[in]srcThe pixel source buffer.
[in]srcincThe source step size.
[in]srcmodeThe source color mode: COLORMODE
[out]dstThe pixel destination buffer.
[in]dstincThe destination step size.
[in]dstmodeThe destination color mode: COLORMODE
[in]ditheryIf NOTOK no dithering is applied, otherwise pass the Y pixel coordinate.
[in]ditherxIf NOTOK no dithering is applied, otherwise pass the X pixel coordinate.
Returns
true if successful, otherwise false.