git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
remove debug
[enigma2.git]
/
lib
/
gui
/
ewidget.h
diff --git
a/lib/gui/ewidget.h
b/lib/gui/ewidget.h
index fbe5a92ae9c8683f1191b7170955bd14a5f9196b..6739f25e35ed28dbd34db83d13106782c58ef855 100644
(file)
--- a/
lib/gui/ewidget.h
+++ b/
lib/gui/ewidget.h
@@
-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
{
@@
-33,10
+36,19
@@
public:
int getStyle(ePtr<eWindowStyle> &style) { if (!m_style) return 1; style = m_style; return 0; }
void setStyle(eWindowStyle *style) { m_style = style; }
int getStyle(ePtr<eWindowStyle> &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()); }
/* ... */
/* untested code */
int isVisible() { return (m_vis & wVisShow) && ((!m_parent) || m_parent->isVisible()); }
/* ... */
+
+ int isTransparent() { return m_vis & wVisTransparent; }
+ eWidgetAnimation m_animation;
private:
eWidgetDesktop *m_desktop;
private:
eWidgetDesktop *m_desktop;
@@
-50,18
+62,33
@@
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;
+ void insertIntoParent();
void doPaint(gPainter &painter, const gRegion ®ion);
void recalcClipRegionsWhenVisible();
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;
+
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
{
@@
-77,9
+104,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();