diff options
author | Joel Bodenmann <joel@unormal.org> | 2014-01-04 15:51:18 +0100 |
---|---|---|
committer | Joel Bodenmann <joel@unormal.org> | 2014-01-04 15:51:18 +0100 |
commit | bad22f5feea49a7417237aa70e2f6b9e349d91c2 (patch) | |
tree | 81bb7485d055fed8ef0ce4b5908e31b550a37f6e | |
parent | 12a7d7957b0d264ab44f2f17075a9cc3a524da43 (diff) | |
download | uGFX-bad22f5feea49a7417237aa70e2f6b9e349d91c2.tar.gz uGFX-bad22f5feea49a7417237aa70e2f6b9e349d91c2.tar.bz2 uGFX-bad22f5feea49a7417237aa70e2f6b9e349d91c2.zip |
working gwinGetVisible() and gwinGetEnabled()
-rw-r--r-- | include/gwin/gwin.h | 6 | ||||
-rw-r--r-- | src/gwin/gwin.c | 20 |
2 files changed, 19 insertions, 7 deletions
diff --git a/include/gwin/gwin.h b/include/gwin/gwin.h index b9d4f966..e5eb2e0b 100644 --- a/include/gwin/gwin.h +++ b/include/gwin/gwin.h @@ -50,9 +50,9 @@ typedef struct GWindowObject { font_t font; // @< The current font #endif #if GWIN_NEED_HIERARCHY - GHandle *parent; // @< The pointer to the parent (or NULL) - GHandle *sibling; // @< The pointer to a widgets brother - GHandle *child; // @< The pointer to a widgets child + GHandle parent; // @< The parent widget + GHandle sibling; // @< The widget to its left (add right later as well) + GHandle child; // @< The child widget #endif } GWindowObject, * GHandle; /* @} */ diff --git a/src/gwin/gwin.c b/src/gwin/gwin.c index 057fd6e0..6d47f3b5 100644 --- a/src/gwin/gwin.c +++ b/src/gwin/gwin.c @@ -219,7 +219,18 @@ void gwinSetVisible(GHandle gh, bool_t visible) { } bool_t gwinGetVisible(GHandle gh) { - return (gh->flags & GWIN_FLG_VISIBLE) ? TRUE : FALSE; + #if GWIN_NEED_HIERARCHY + // return TRUE if all widgets (itself + parents) are visble, false otherwise + GHandle e = gh; + while (e) { + if (!(e->flags & GWIN_FLG_VISIBLE)) + return FALSE; + e = e->parent; + }; + return TRUE; + #else + return (gh->flags & GWIN_FLG_VISIBLE) ? TRUE : FALSE; + #endif } void gwinSetEnabled(GHandle gh, bool_t enabled) { @@ -238,13 +249,14 @@ void gwinSetEnabled(GHandle gh, bool_t enabled) { bool_t gwinGetEnabled(GHandle gh) { #if GWIN_NEED_HIERARCHY + // return TRUE if all widgets (itself + parents) are enabled, false otherwise GHandle e = gh; while (e) { - if ( e->flags & GWIN_FLG_ENABLED); - return TRUE; + if (!(e->flags & GWIN_FLG_ENABLED)) + return FALSE; e = e->parent; }; - return FALSE; + return TRUE; #else return (gh->flags & GWIN_FLG_ENABLED) ? TRUE : FALSE; #endif |