X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/ba02fb4aced5868d047a5bffbd2ed87583daee4d..ec6cfceaa66fc2243e08001178c70fb5db9fcc50:/main/enigma.cpp?ds=inline diff --git a/main/enigma.cpp b/main/enigma.cpp index d350f445..258c5ad2 100644 --- a/main/enigma.cpp +++ b/main/enigma.cpp @@ -1,3 +1,4 @@ +#define SDLDC #include #include #include @@ -9,6 +10,7 @@ #include #include +#include #include #include @@ -19,6 +21,15 @@ #include #include +#include + +#include + +#include + +#include + +#include #ifdef OBJECT_DEBUG int object_total_remaining; @@ -28,11 +39,6 @@ void object_dump() printf("%d items left\n", object_total_remaining); } #endif -using namespace std; - void print(const string &str, const char *c) - { - printf("%s (%s)\n", str.c_str(), c); - } void dumpRegion(const gRegion ®ion) { @@ -53,18 +59,71 @@ void dumpRegion(const gRegion ®ion) } } +eWidgetDesktop *wdsk; + +// typedef struct _object PyObject; + +void print(int i) +{ + printf("C++ says: it's a %d!!!\n", i); +} + +PSignal1 keyPressed; + +PSignal1 &keyPressedSignal() +{ + return keyPressed; +} + +void keyEvent(const eRCKey &key) +{ + ePtr ptr; + eActionMap::getInstance(ptr); + ptr->keyPressed(0, key.code, key.flags); +// if (!key.flags) +// keyPressed(key.code); +} + +/************************************************/ +#include +#include +#include +#include +#include class eMain: public eApplication, public Object { eInit init; + + ePtr m_mgr; + ePtr m_dvbdb; + + ePtr m_scan; + public: eMain() { init.setRunlevel(eAutoInitNumbers::main); + + /* TODO: put into init */ + m_dvbdb = new eDVBDB(); + m_mgr = new eDVBResourceManager(); + + m_mgr->setChannelList(m_dvbdb); + +// m_scan = new eComponentScan(); +// m_scan->start(); + + } + + ~eMain() + { + m_scan = 0; } }; -eWidgetDesktop *wdsk; +/************************************************/ + int main(int argc, char **argv) { @@ -73,93 +132,48 @@ int main(int argc, char **argv) #endif -#if 1 + ePython python; eMain main; +#if 1 +#ifdef SDLDC + ePtr my_dc; + gSDLDC::getInstance(my_dc); +#else ePtr my_dc; gFBDC::getInstance(my_dc); +#endif - gPainter p(my_dc); - - gRGB pal[256]; - pal[0] = 0; - pal[1] = 0xff00ff; - pal[2] = 0xffFFff; - pal[3] = 0x00ff00; - - for (int a=0; a<0x10; ++a) - pal[a | 0x10] = 0x111111 * a; - for (int a=0; a<0x10; ++a) - pal[a | 0x20] = (0x111100 * a) | 0xFF; - for (int a=0; a<0x10; ++a) - pal[a | 0x30] = (0x110011 * a) | 0xFF00; - for (int a=0; a<0x10; ++a) - pal[a | 0x40] = (0x001111 * a) | 0xFF0000; - p.setPalette(pal, 0, 256); - - fontRenderClass::getInstance()->AddFont("/dbox2/cdkroot/share/fonts/arial.ttf", "Arial", 100); + fontRenderClass::getInstance()->AddFont("/home/tmbinc/enigma2/fonts/arial.ttf", "Arial", 100); eWidgetDesktop dsk(eSize(720, 576)); wdsk = &dsk; - dsk.setDC(my_dc); - eWindow *wnd = new eWindow(&dsk); - wnd->move(ePoint(100, 100)); - wnd->resize(eSize(200, 200)); - wnd->show(); - eLabel *label = new eButton(wnd); - label->setText("Hello!!"); - label->move(ePoint(40, 40)); - label->resize(eSize(100, 40)); + dsk.setDC(my_dc); - label = new eButton(wnd); - label->setText("2nd!!"); - label->move(ePoint(40, 90)); - label->resize(eSize(100, 40)); + ePtr m_pm; + loadPNG(m_pm, "data/info-bg.png"); + if (!m_pm) + { + eDebug("can't load info-bg :)"); + } else + dsk.setPalette(*m_pm); -#if 0 - eWidget *bla2 = new eWidget(0); - dsk.addRootWidget(bla2, 0); - - bla2->move(ePoint(160, 160)); - bla2->resize(eSize(200, 200)); - bla2->show(); + dsk.setBackgroundColor(gRGB(0,0,0,0)); #endif -// dsk.recalcClipRegions(); -// dsk.paint(); -// dsk.invalidate(gRegion(eRect(0, 0, 720, 576))); - -// dumpRegion(wnd->m_visible_region); -// dumpRegion(label->m_visible_region); -// dumpRegion(label->m_visible_region); + /* redrawing is done in an idle-timer, so we have to set the context */ + dsk.setRedrawTask(main); - eDebug("painting!"); + eRCInput::getInstance()->keyEvent.connect(slot(keyEvent)); + printf("executing main\n"); - ePython python; - - printf("about to execute TEST :)\n"); - python.execute("mytest", "test"); - - sleep(2); -#endif + python.execute("mytest", "__main__"); -#if 0 - - // connections mit parametern: geht! :) - using namespace std; - using namespace SigC; - - - Signal1 printer; - int i; - for (i=1; iexec(); return 0; } @@ -169,3 +183,12 @@ eWidgetDesktop *getDesktop() return wdsk; } +void runMainloop() +{ + eApp->exec(); +} + +void quitMainloop() +{ + eApp->quit(0); +}