From 20b3eedd8825ba8a52ce4a1b991b215d0a0a6789 Mon Sep 17 00:00:00 2001 From: Felix Domke Date: Fri, 25 Nov 2005 01:09:17 +0000 Subject: [PATCH] widget: add - untested, as usual - z ordering --- lib/gui/ewidget.cpp | 28 +++++++++++++++++++++++++++- lib/gui/ewidget.h | 6 ++++++ 2 files changed, 33 insertions(+), 1 deletion(-) diff --git a/lib/gui/ewidget.cpp b/lib/gui/ewidget.cpp index 8cb7d4ae..f71d7e1d 100644 --- a/lib/gui/ewidget.cpp +++ b/lib/gui/ewidget.cpp @@ -8,6 +8,7 @@ eWidget::eWidget(eWidget *parent): m_animation(this), m_parent(parent ? parent-> m_vis = 0; m_desktop = 0; m_have_background_color = 0; + m_z_position = 0; m_client_offset = eSize(0, 0); @@ -16,7 +17,7 @@ eWidget::eWidget(eWidget *parent): m_animation(this), m_parent(parent ? parent-> if (m_parent) { - m_parent->m_childs.push_back(this); + insertIntoParent(); m_parent->getStyle(m_style); } @@ -165,6 +166,17 @@ void eWidget::clearBackgroundColor() m_have_background_color = 0; } +void eWidget::setZPosition(int z) +{ + m_z_position = z; + if (!m_parent) + return; + + m_parent->m_childs.remove(this); + + insertIntoParent(); /* now at the new Z position */ +} + void eWidget::mayKillFocus() { setFocus(0); @@ -192,6 +204,20 @@ eWidget::~eWidget() } } +void eWidget::insertIntoParent() +{ + ePtrList::iterator i = m_parent->m_childs.begin(); + + for(;;) + { + if ((i == m_parent->m_childs.end()) || (i->m_z_position > m_z_position)) + { + m_parent->m_childs.insert(i, this); + return; + } + } +} + void eWidget::doPaint(gPainter &painter, const gRegion &r) { if (m_visible_with_childs.empty()) diff --git a/lib/gui/ewidget.h b/lib/gui/ewidget.h index 5cb139c5..879e5eaa 100644 --- a/lib/gui/ewidget.h +++ b/lib/gui/ewidget.h @@ -39,6 +39,8 @@ public: void setBackgroundColor(const gRGB &col); void clearBackgroundColor(); + void setZPosition(int z); + /* untested code */ int isVisible() { return (m_vis & wVisShow) && ((!m_parent) || m_parent->isVisible()); } /* ... */ @@ -63,6 +65,7 @@ private: ePtr m_style; + void insertIntoParent(); void doPaint(gPainter &painter, const gRegion ®ion); void recalcClipRegionsWhenVisible(); @@ -70,6 +73,9 @@ private: int m_have_background_color; eWidget *m_current_focus, *m_focus_owner; + + int m_z_position; + protected: virtual ~eWidget(); void mayKillFocus(); -- 2.30.2