X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/127c6c59e89dbdf96a93659104efd91428569a06..7373f39fe2ebe1b5007ed56ddd86d9ce0ad3efb7:/lib/gui/ewindowstyle.h diff --git a/lib/gui/ewindowstyle.h b/lib/gui/ewindowstyle.h index 3c9c805b..5008cd6e 100644 --- a/lib/gui/ewindowstyle.h +++ b/lib/gui/ewindowstyle.h @@ -7,13 +7,13 @@ class gFont; #include -class eWindowStyle: public iObject +class eWindowStyle_ENUMS { +#ifdef SWIG + eWindowStyle_ENUMS(); + ~eWindowStyle_ENUMS(); +#endif public: - virtual void handleNewSize(eWindow *wnd, eSize &size, eSize &offset) = 0; - virtual void paintWindowDecoration(eWindow *wnd, gPainter &painter, const std::string &title) = 0; - virtual void paintBackground(gPainter &painter, const ePoint &offset, const eSize &size) = 0; - virtual void setStyle(gPainter &painter, int what) = 0; enum { styleLabel, styleListboxSelected, @@ -21,24 +21,39 @@ public: styleListboxMarked, styleListboxMarkedAndSelected }; - - virtual void drawFrame(gPainter &painter, const eRect &frame, int type) = 0; - + enum { frameButton, frameListboxEntry }; - + enum { fontStatic, fontButton, fontTitlebar }; - +}; + +SWIG_IGNORE(eWindowStyle); +class eWindowStyle: public eWindowStyle_ENUMS, public iObject +{ +#ifdef SWIG + eWindowStyle(); +#endif +public: +#ifndef SWIG + virtual void handleNewSize(eWindow *wnd, eSize &size, eSize &offset) = 0; + virtual void paintWindowDecoration(eWindow *wnd, gPainter &painter, const std::string &title) = 0; + virtual void paintBackground(gPainter &painter, const ePoint &offset, const eSize &size) = 0; + virtual void setStyle(gPainter &painter, int what) = 0; + virtual void drawFrame(gPainter &painter, const eRect &frame, int type) = 0; virtual RESULT getFont(int what, ePtr &font) = 0; +#endif virtual ~eWindowStyle() = 0; }; +SWIG_TEMPLATE_TYPEDEF(ePtr, eWindowStylePtr); +SWIG_IGNORE(eWindowStyleManager); class eWindowStyleManager: public iObject { DECLARE_REF(eWindowStyleManager); @@ -50,21 +65,27 @@ public: #ifndef SWIG eWindowStyleManager(); ~eWindowStyleManager(); + static SWIG_VOID(int) getInstance(ePtr &SWIG_NAMED_OUTPUT(mgr)) { mgr = m_instance; if (!mgr) return -1; return 0; } #endif - void getStyle(ePtr &style); - void setStyle(eWindowStyle *style); - static int getInstance(ePtr &mgr) { mgr = m_instance; if (!mgr) return -1; return 0; } + void getStyle(int style_id, ePtr &SWIG_OUTPUT); + void setStyle(int style_id, eWindowStyle *style); private: static eWindowStyleManager *m_instance; - ePtr m_current_style; + std::map > m_current_style; }; +SWIG_TEMPLATE_TYPEDEF(ePtr, eWindowStyleManager); +SWIG_EXTEND(ePtr, + static ePtr getInstance() + { + extern ePtr NewWindowStylePtr(void); + return NewWindowStylePtr(); + } +); -TEMPLATE_TYPEDEF(ePtr, eWindowStyleManagerPtr); - +#ifndef SWIG class eWindowStyleSimple: public eWindowStyle { DECLARE_REF(eWindowStyleSimple); -private: ePtr m_fnt; gColor m_border_color_tl, m_border_color_br, m_title_color_back, m_title_color, m_background_color; @@ -78,5 +99,6 @@ public: void drawFrame(gPainter &painter, const eRect &frame, int what); RESULT getFont(int what, ePtr &font); }; +#endif #endif