X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/768202cf6feb2555ce4a2aaba7e1206a06783247..6c9c38fad67675a3ddb4063e5c706eddd444f21f:/lib/dvb_ci/dvbci_mmi.cpp diff --git a/lib/dvb_ci/dvbci_mmi.cpp b/lib/dvb_ci/dvbci_mmi.cpp index 463c91bd..b652da89 100644 --- a/lib/dvb_ci/dvbci_mmi.cpp +++ b/lib/dvb_ci/dvbci_mmi.cpp @@ -1,6 +1,30 @@ /* DVB CI MMI */ #include +#include + +/* +PyObject *list = PyList_New(len); +for (i=0; immi_session = this; +} + +eDVBCIMMISession::~eDVBCIMMISession() +{ + slot->mmi_session = 0; +} int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, int len) { @@ -24,10 +48,18 @@ int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, i { unsigned char *d=(unsigned char*)data; unsigned char *max=((unsigned char*)d) + len; + int pos = 0; printf("Tmenu_last\n"); if (d > max) break; int n=*d++; + + //FIXME: slotid + if(tag[2] == 0x09) + eDVBCI_UI::getInstance()->mmiScreenBegin(0, 0); + else + eDVBCI_UI::getInstance()->mmiScreenBegin(0, 1); + if (n == 0xFF) n=0; else @@ -44,10 +76,19 @@ int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, i printf("%d bytes text\n", textlen); if ((d+textlen) > max) break; + + char str[textlen + 1]; + memcpy(str, ((char*)d), textlen); + str[textlen] = '\0'; + + eDVBCI_UI::getInstance()->mmiScreenAddText(0, pos++, str); + while (textlen--) printf("%c", *d++); printf("\n"); } + //FIXME: slotid + eDVBCI_UI::getInstance()->mmiScreenFinish(0); break; } default: @@ -90,3 +131,22 @@ int eDVBCIMMISession::doAction() return 0; } +int eDVBCIMMISession::stopMMI() +{ + printf("eDVBCIMMISession::stopMMI()\n"); + + unsigned char tag[]={0x9f, 0x88, 0x00}; + unsigned char data[]={0x00}; + sendAPDU(tag, data, 1); +} + +int eDVBCIMMISession::answerText(int answer) +{ + printf("eDVBCIMMISession::answerText(%d)\n",answer); + + unsigned char tag[]={0x9f, 0x88, 0x0B}; + unsigned char data[]={0x00}; + data[0] = answer & 0xff; + sendAPDU(tag, data, 1); +} +