drawable: add fallback function.
This commit is contained in:
@@ -20,6 +20,8 @@
|
||||
|
||||
static GWENHYWFAR_CB void _freeData(void *bp, void *p);
|
||||
|
||||
static int _drawFallback(AQDG_OBJECT *object, AQDG_DRAW_CONTEXT *g);
|
||||
|
||||
|
||||
|
||||
/* ------------------------------------------------------------------------------------------------
|
||||
@@ -41,6 +43,7 @@ AQDG_OBJECT *AQDG_DrawableObject_new(AQDG_OBJECT *parent, uint32_t options)
|
||||
GWEN_INHERIT_SETDATA(AQDG_OBJECT, AQDG_OBJECT_DRAWABLE, object, xo, _freeData);
|
||||
|
||||
AQDG_Object_SetOptions(object, options);
|
||||
xo->drawFn=_drawFallback;
|
||||
|
||||
if (parent && GWEN_INHERIT_ISOFTYPE(AQDG_OBJECT, AQDG_OBJECT_DRAWABLE, parent)) {
|
||||
xo->fontId=AQDG_DrawableObject_GetFontId(parent);
|
||||
@@ -198,10 +201,20 @@ int AQDG_DrawableObject_Draw(AQDG_OBJECT *object, AQDG_DRAW_CONTEXT *g)
|
||||
AQDG_OBJECT_DRAWABLE *xo;
|
||||
|
||||
xo=GWEN_INHERIT_GETDATA(AQDG_OBJECT, AQDG_OBJECT_DRAWABLE, object);
|
||||
if (xo) {
|
||||
if (xo->drawFn)
|
||||
if (xo && xo->drawFn)
|
||||
return xo->drawFn(object, g);
|
||||
else {
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
|
||||
int _drawFallback(AQDG_OBJECT *object, AQDG_DRAW_CONTEXT *g)
|
||||
{
|
||||
AQDG_OBJECT_DRAWABLE *xo;
|
||||
|
||||
xo=GWEN_INHERIT_GETDATA(AQDG_OBJECT, AQDG_OBJECT_DRAWABLE, object);
|
||||
if (xo) {
|
||||
AQDG_OBJECT *child;
|
||||
|
||||
AQDG_Draw_Context_DrawFilledRect(g,
|
||||
@@ -217,8 +230,6 @@ int AQDG_DrawableObject_Draw(AQDG_OBJECT *object, AQDG_DRAW_CONTEXT *g)
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -230,3 +241,4 @@ int AQDG_DrawableObject_Draw(AQDG_OBJECT *object, AQDG_DRAW_CONTEXT *g)
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user