X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fgui%2Fewindow.cpp;h=01f889ffd20cb8cad11db728eb43243e829d033e;hp=1114d2587fc85230976aae3cfd709ddfec17e9bd;hb=44433f650cd3e5f9f66253b74d194fcb01578595;hpb=77c45c9d2cabd3c1dc028c41d26573ac62147a34 diff --git a/lib/gui/ewindow.cpp b/lib/gui/ewindow.cpp index 1114d25..01f889f 100644 --- a/lib/gui/ewindow.cpp +++ b/lib/gui/ewindow.cpp @@ -2,10 +2,26 @@ #include #include +#include + +#include eWindow::eWindow(eWidgetDesktop *desktop): eWidget(0) { - setStyle(new eWindowStyleSimple()); + m_flags = 0; + /* ask style manager for current style */ + ePtr mgr; + eWindowStyleManager::getInstance(mgr); + + ePtr style; + if (mgr) + mgr->getStyle(style); + + /* when there is either no style manager or no style, revert to simple style. */ + if (!style) + style = new eWindowStyleSimple(); + + setStyle(style); /* we are the parent for the child window. */ /* as we are in the constructor, this is thread safe. */ @@ -27,30 +43,49 @@ void eWindow::setTitle(const std::string &string) event(evtTitleChanged); } +void eWindow::setFlag(int flags) +{ + m_flags |= flags; +} + +void eWindow::clearFlag(int flags) +{ + m_flags &= ~flags; +} + int eWindow::event(int event, void *data, void *data2) { switch (event) { case evtWillChangeSize: { - ePtr style; - if (!getStyle(style)) + eSize &new_size = *static_cast(data); + eSize &offset = *static_cast(data2); + if (!(m_flags & wfNoBorder)) { - const eSize &new_size = *static_cast(data); + ePtr style; + if (!getStyle(style)) + { // eDebug("eWindow::evtWillChangeSize to %d %d", new_size.width(), new_size.height()); - style->handleNewSize(this, new_size); + style->handleNewSize(this, new_size, offset); + } + } else + { + m_child->resize(new_size); } break; } case evtPaint: { - ePtr style; - if (!getStyle(style)) + if (!(m_flags & wfNoBorder)) { - gPainter &painter = *static_cast(data2); - style->paintWindowDecoration(this, painter, m_title); - } else - eDebug("no style :("); + ePtr style; + if (!getStyle(style)) + { + gPainter &painter = *static_cast(data2); + style->paintWindowDecoration(this, painter, m_title); + } + } return 0; } default: