add 'layers' (in buffered mode, which is not working at the moment).
[enigma2.git] / lib / gui / ewidgetdesktop.h
index f88efa8823552cec5deb2baaa1870e28c1b8a706..7a0a36a78a2ecab54d7c2d77ee5669afaae5b1a1 100644 (file)
@@ -44,7 +44,10 @@ public:
        
        void recalcClipRegions(eWidget *root);
        
-       void invalidate(const gRegion &region);
+       void invalidateWidgetLayer(const gRegion &region, const eWidget *widget, int layer);
+       void invalidateWidget(const gRegion &region, const eWidget *widget, int layer = -1);
+       void invalidate(const gRegion &region, const eWidget *widget = 0, int layer = -1);
+       void paintLayer(eWidget *widget, int layer);
        void paint();
        void setDC(gDC *dc);
        
@@ -54,7 +57,8 @@ public:
        void setPalette(gPixmap &pm);
        
        void setRedrawTask(eMainloop &ml);
-       
+
+       void makeCompatiblePixmap(ePtr<gPixmap> &pm);
        void makeCompatiblePixmap(gPixmap &pm);
        
        enum {
@@ -63,6 +67,9 @@ public:
        };
        
        void setCompositionMode(int mode);
+       
+       int getStyleID() { return m_style_id; }
+       void setStyleID(int id) { m_style_id = id; }
 private:
        ePtrList<eWidget> m_root;
        void calcWidgetClipRegion(eWidget *widget, gRegion &parent_visible);
@@ -76,13 +83,15 @@ private:
        
        eWidgetDesktopCompBuffer m_screen;
        
-       void createBufferForWidget(eWidget *widget);
-       void removeBufferForWidget(eWidget *widget);
+       void createBufferForWidget(eWidget *widget, int layer);
+       void removeBufferForWidget(eWidget *widget, int layer);
        
        void redrawComposition(int notifed);
        void notify();
        
        void clearVisibility(eWidget *widget);
+       
+       int m_style_id;
 };
 
 #endif