fix more nfiflash media paths to be non-absolute (#620)
[enigma2.git] / lib / gui / ewidget.h
index 98b30087af32e545dd73d249b502fc80c4d61311..8af66b057e74b6ae18b39051bacbf1d041df0a63 100644 (file)
@@ -6,6 +6,8 @@
 #include <lib/gui/ewindowstyle.h> /* for eWindowStyle */
 #include <lib/gui/ewidgetanimation.h>
 
+#define MAX_LAYER 16
+
 class eWidgetDesktop;class eWidgetDesktop;
 
 class eWidget
@@ -20,6 +22,7 @@ public:
        
        ePoint position() const { return m_position; }
        eSize size() const { return m_size; }
+       eSize csize() const { return m_client_size; }
 
        void invalidate(const gRegion &region = gRegion::invalidRegion());
        
@@ -62,9 +65,11 @@ private:
        
        int m_vis;      
 
+       int m_layer;
+
        ePtrList<eWidget> m_childs;
        ePoint m_position;
-       eSize m_size;
+       eSize m_size, m_client_size;
                /* will be accounted when there's a client offset */
        eSize m_client_offset;
        eWidget *m_parent;
@@ -72,7 +77,7 @@ private:
        ePtr<eWindowStyle> m_style;
        
        void insertIntoParent();
-       void doPaint(gPainter &painter, const gRegion &region);
+       void doPaint(gPainter &painter, const gRegion &region, int layer);
        void recalcClipRegionsWhenVisible();
        
        void parentRemoved();
@@ -90,7 +95,7 @@ public:
 
                // all in local space!
        gRegion m_clip_region, m_visible_region, m_visible_with_childs;
-       struct eWidgetDesktopCompBuffer *m_comp_buffer;
+       struct eWidgetDesktopCompBuffer *m_comp_buffer[MAX_LAYER];
        
        enum eWidgetEvent
        {
@@ -101,8 +106,7 @@ public:
                
                evtParentChangedPosition,
                
-               evtWillShow,
-               evtWillHide,
+               evtParentVisibilityChanged,
                evtWillChangePosition, /* new size is eRect *data */
                evtWillChangeSize,
                
@@ -118,6 +122,8 @@ public:
 
                /* enable this if you need the absolute position of the widget */
        void setPositionNotifyChild(int n) { m_notify_child_on_position_change = 1; }
+
+       void notifyShowHide();
 };
 
 extern eWidgetDesktop *getDesktop(int which);