make VideoWindow usable for main decoder too
[enigma2.git] / lib / gui / ewidget.h
index 8bd199f9d4a1548c47b85ee362c2374288e1b12e..98b30087af32e545dd73d249b502fc80c4d61311 100644 (file)
@@ -4,6 +4,7 @@
 #include <lib/gdi/grc.h> /* for gRegion */
 #include <lib/base/eptrlist.h> /* for eSmartPtrList */
 #include <lib/gui/ewindowstyle.h> /* for eWindowStyle */
+#include <lib/gui/ewidgetanimation.h>
 
 class eWidgetDesktop;class eWidgetDesktop;
 
@@ -12,7 +13,8 @@ class eWidget
        friend class eWidgetDesktop;
 public:
        eWidget(eWidget *parent);
-       
+       virtual ~eWidget();
+
        void move(ePoint pos);
        void resize(eSize size);
        
@@ -32,16 +34,24 @@ public:
        
        void destruct();
        
-       int getStyle(ePtr<eWindowStyle> &style) { if (!m_style) return 1; style = m_style; return 0; }
+       SWIG_VOID(int) getStyle(ePtr<eWindowStyle> &SWIG_NAMED_OUTPUT(style)) { if (!m_style) return 1; style = m_style; return 0; }
        void setStyle(eWindowStyle *style) { m_style = style; }
        
        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;
 
@@ -61,15 +71,20 @@ private:
        
        ePtr<eWindowStyle> m_style;
        
+       void insertIntoParent();
        void doPaint(gPainter &painter, const gRegion &region);
        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:
 
@@ -84,6 +99,8 @@ public:
                evtChangedPosition,
                evtChangedSize,
                
+               evtParentChangedPosition,
+               
                evtWillShow,
                evtWillHide,
                evtWillChangePosition, /* new size is eRect *data */
@@ -98,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