X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/92f02a487b375ae936e7fa74b060bee9d495a106..fca263d581290c94fdfe4d7baae85d9532e27524:/lib/gui/ewidget.h diff --git a/lib/gui/ewidget.h b/lib/gui/ewidget.h index 89b3b38f..f7c611f6 100644 --- a/lib/gui/ewidget.h +++ b/lib/gui/ewidget.h @@ -4,13 +4,17 @@ #include /* for gRegion */ #include /* for eSmartPtrList */ #include /* for eWindowStyle */ +#include + +class eWidgetDesktop;class eWidgetDesktop; class eWidget { friend class eWidgetDesktop; public: eWidget(eWidget *parent); - + virtual ~eWidget(); + void move(ePoint pos); void resize(eSize size); @@ -36,10 +40,18 @@ public: void setBackgroundColor(const gRGB &col); void clearBackgroundColor(); + void setZPosition(int z); + void setTransparent(int transp); + /* untested code */ int isVisible() { return (m_vis & wVisShow) && ((!m_parent) || m_parent->isVisible()); } /* ... */ + + int isTransparent() { return m_vis & wVisTransparent; } + ePoint getAbsolutePosition(); + + eWidgetAnimation m_animation; private: eWidgetDesktop *m_desktop; @@ -59,20 +71,26 @@ private: ePtr m_style; + void insertIntoParent(); void doPaint(gPainter &painter, const gRegion ®ion); void recalcClipRegionsWhenVisible(); + void parentRemoved(); + gRGB m_background_color; int m_have_background_color; eWidget *m_current_focus, *m_focus_owner; + + int m_z_position; + int m_notify_child_on_position_change; protected: - virtual ~eWidget(); void mayKillFocus(); public: // all in local space! gRegion m_clip_region, m_visible_region, m_visible_with_childs; + struct eWidgetDesktopCompBuffer *m_comp_buffer; enum eWidgetEvent { @@ -81,6 +99,8 @@ public: evtChangedPosition, evtChangedSize, + evtParentChangedPosition, + evtWillShow, evtWillHide, evtWillChangePosition, /* new size is eRect *data */ @@ -95,8 +115,11 @@ public: }; virtual int event(int event, void *data = 0, void *data2 = 0); void setFocus(eWidget *focus); + + /* enable this if you need the absolute position of the widget */ + void setPositionNotifyChild(int n) { m_notify_child_on_position_change = 1; } }; -extern eWidgetDesktop *getDesktop(); +extern eWidgetDesktop *getDesktop(int which); #endif