better display for linked nim-names
[enigma2.git] / lib / gui / ewidget.h
index cb39a000461cc355d7ee2c39934b20a6b82403a4..5cb139c505f354750f4c17dfb520409e877fb9af 100644 (file)
@@ -4,6 +4,9 @@
 #include <lib/gdi/grc.h> /* for gRegion */
 #include <lib/base/eptrlist.h> /* for eSmartPtrList */
 #include <lib/gui/ewindowstyle.h> /* for eWindowStyle */
 #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;
 
 class eWidget
 {
 
 class eWidget
 {
@@ -34,11 +37,13 @@ public:
        void setStyle(eWindowStyle *style) { m_style = style; }
        
        void setBackgroundColor(const gRGB &col);
        void setStyle(eWindowStyle *style) { m_style = style; }
        
        void setBackgroundColor(const gRGB &col);
+       void clearBackgroundColor();
        
                /* untested code */
        int isVisible() { return (m_vis & wVisShow) && ((!m_parent) || m_parent->isVisible()); }
                /* ... */
        
        
                /* untested code */
        int isVisible() { return (m_vis & wVisShow) && ((!m_parent) || m_parent->isVisible()); }
                /* ... */
        
+       eWidgetAnimation m_animation;
 private:
        eWidgetDesktop *m_desktop;
 
 private:
        eWidgetDesktop *m_desktop;
 
@@ -52,6 +57,8 @@ private:
        ePtrList<eWidget> m_childs;
        ePoint m_position;
        eSize m_size;
        ePtrList<eWidget> m_childs;
        ePoint m_position;
        eSize m_size;
+               /* will be accounted when there's a client offset */
+       eSize m_client_offset;
        eWidget *m_parent;
        
        ePtr<eWindowStyle> m_style;
        eWidget *m_parent;
        
        ePtr<eWindowStyle> m_style;
@@ -61,12 +68,16 @@ private:
        
        gRGB m_background_color;
        int m_have_background_color;
        
        gRGB m_background_color;
        int m_have_background_color;
+       
+       eWidget *m_current_focus, *m_focus_owner;
 protected:
        virtual ~eWidget();
 protected:
        virtual ~eWidget();
+       void mayKillFocus();
 public:
 
                // all in local space!
        gRegion m_clip_region, m_visible_region, m_visible_with_childs;
 public:
 
                // all in local space!
        gRegion m_clip_region, m_visible_region, m_visible_with_childs;
+       struct eWidgetDesktopCompBuffer *m_comp_buffer;
        
        enum eWidgetEvent
        {
        
        enum eWidgetEvent
        {
@@ -82,9 +93,13 @@ public:
                
                evtAction,
                
                
                evtAction,
                
+               evtFocusGot,
+               evtFocusLost,
+               
                evtUserWidget,
        };
        virtual int event(int event, void *data = 0, void *data2 = 0);
                evtUserWidget,
        };
        virtual int event(int event, void *data = 0, void *data2 = 0);
+       void setFocus(eWidget *focus);
 };
 
 extern eWidgetDesktop *getDesktop();
 };
 
 extern eWidgetDesktop *getDesktop();