X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/6bfb37ae9c010c866900239281d345efcdd611bd..1f6edcca9e83bfe6e4606c48e5cb27fb637ca400:/lib/gdi/lcd.cpp diff --git a/lib/gdi/lcd.cpp b/lib/gdi/lcd.cpp index 33eb619d..776173dd 100644 --- a/lib/gdi/lcd.cpp +++ b/lib/gdi/lcd.cpp @@ -1,6 +1,3 @@ -#if 0 -#ifndef DISABLE_LCD - #include #include @@ -14,7 +11,6 @@ #include #include #include -#include eDBoxLCD *eDBoxLCD::instance; @@ -41,40 +37,18 @@ int eLCD::lock() void eLCD::unlock() { - read( lcdfd, NULL, 0); - if ( errno == 9 ) - { - eDebug("reopen lcd"); - lcdfd=open("/dev/dbox/lcd0", O_RDWR); // reopen device - } - else - eDebug("do not reopen lcd.. errno = %d", errno); + read( lcdfd, NULL, 0); + if ( errno == 9 ) + { + eDebug("reopen lcd"); + lcdfd=open("/dev/dbox/lcd0", O_RDWR); // reopen device + } + else + eDebug("do not reopen lcd.. errno = %d", errno); - locked=0; + locked=0; } -/* void eLCD::line(ePoint start, ePoint dst, int color) -{ -int Ax=start.x(), // dieser code rult ganz ganz doll weil er ganz ganz fast ist und auch sehr gut dokumentiert is -Ay=start.y(), Bx=dst.x(), // t. es handelt sich immerhin um den weltbekannten bresenham algorithmus der nicht nur -By=dst.y(); int dX, dY, fbXincr, // sehr schnell ist sondern auch sehr gut dokumentiert und getestet wurde. nicht -fbYincr, fbXYincr, dPr, dPru, P; __u8 // nur auf dem LCD der dbox, sondern auch ueberall anders. und auch auf der -*AfbAddr = &buffer()[Ay*stride()+Ax]; __u8 // dbox mit LCD soll das teil nun tun, und ich denke das tut es. ausse -*BfbAddr = &buffer()[By*stride()+Bx]; fbXincr= // rdem hat dieser algo den vorteil dass man fehler sehr leicht fi -1; if ( (dX=Bx-Ax) >= 0) goto AFTERNEGX; dX=-dX; // ndet und beheben kann. das liegt nicht zuletzt an den komment -fbXincr=-1; AFTERNEGX: fbYincr=stride(); if ( (dY=By // aren. und ausserdem, je kuerzer der code, desto weniger k --Ay) >= 0) goto AFTERNEGY; fbYincr=-stride(); dY=-dY;AFTERNEGY: // ann daran falsch sein. erwaehnte ich schon, da -fbXYincr = fbXincr+fbYincr; if (dY > dX) goto YisIndependent; dPr = dY+ // s dieser tolle code wahnsinnig schnell -dY; P = -dX; dPru = P+P; dY = dX>>1; XLOOP: *AfbAddr=color; *BfbAddr=color; if ((P+=dPr) > 0) // ist? bye, tmbinc -goto RightAndUp; AfbAddr+=fbXincr; BfbAddr-=fbXincr; if ((dY=dY-1) > 0) goto XLOOP; *AfbAddr=color; if ((dX & 1) -== 0) return; *BfbAddr=color; return; RightAndUp: AfbAddr+=fbXYincr; BfbAddr-=fbXYincr; P+=dPru; if ((dY=dY-1) > -0) goto XLOOP; *AfbAddr=color; if ((dX & 1) == 0) return; *BfbAddr=color; return; YisIndependent: dPr = dX+dX; P -= -dY; dPru = P+P; dX = dY>>1; YLOOP: *AfbAddr=color; *BfbAddr=color; if ((P+=dPr) > 0) goto RightAndUp2; AfbAddr -+=fbYincr; BfbAddr-=fbYincr; if ((dX=dX-1) > 0) goto YLOOP; *AfbAddr=color; if ((dY & 1) == 0) return; *BfbAddr= -color;return; RightAndUp2: AfbAddr+=fbXYincr; BfbAddr-=fbXYincr; P+=dPru; if ((dX=dX-1) > 0) goto YLOOP; *AfbAddr -=color; if((dY & 1) == 0) return; *BfbAddr=color; return; // nun ist der tolle code leider zu ende. tut mir leid. -} */ - eDBoxLCD::eDBoxLCD(): eLCD(eSize(128, 64)) { #ifndef NO_LCD @@ -90,27 +64,7 @@ eDBoxLCD::eDBoxLCD(): eLCD(eSize(128, 64)) { int i=LCD_MODE_BIN; ioctl(lcdfd, LCD_IOCTL_ASC_MODE, &i); - int lcdbrightness=0, lcdcontrast=0; - - if( eConfig::getInstance()->getKey("/ezap/lcd/brightness", lcdbrightness) ) - { - lcdbrightness=130; - eConfig::getInstance()->setKey("/ezap/lcd/brightness", lcdbrightness); - } - if( eConfig::getInstance()->getKey("/ezap/lcd/contrast", lcdcontrast) ) - { - lcdcontrast=32; - eConfig::getInstance()->setKey("/ezap/lcd/contrast", lcdcontrast); - } - setLCDParameter(lcdbrightness, lcdcontrast); - int tmp; - if( eConfig::getInstance()->getKey("/ezap/lcd/inverted", tmp ) ) - { - inverted=0; - eConfig::getInstance()->setKey("/ezap/lcd/inverted", (int) 0 ); - } - else - inverted=(unsigned char)tmp; + inverted=0; } } @@ -120,7 +74,7 @@ void eDBoxLCD::setInverted(unsigned char inv) update(); } -int eDBoxLCD::setLCDParameter(int brightness, int contrast) +int eDBoxLCD::setLCDContrast(int contrast) { int fp; if((fp=open("/dev/dbox/fp0", O_RDWR))<=0) @@ -133,31 +87,21 @@ int eDBoxLCD::setLCDParameter(int brightness, int contrast) { eDebug("[LCD] can't set lcd contrast"); } - - if(ioctl(fp, FP_IOCTL_LCD_DIMM, &brightness)) - { - eDebug("[LCD] can't set lcd brightness"); - } - eDebug("[LCD] set brightness %d, contrast %d", brightness, contrast); return(0); } -int eDBoxLCD::switchLCD(int state) +int eDBoxLCD::setLCDBrightness(int brightness) { - int lcdbrightness, lcdcontrast, lcdstandby=0; - - eConfig::getInstance()->getKey("/ezap/lcd/contrast", lcdcontrast); - - if(state==0) + int fp; + if((fp=open("/dev/dbox/fp0", O_RDWR))<=0) { - eConfig::getInstance()->getKey("/ezap/lcd/standby", lcdstandby); - setLCDParameter(lcdstandby, lcdcontrast); + eDebug("[LCD] can't open /dev/dbox/fp0"); + return(-1); } - else + + if(ioctl(fp, FP_IOCTL_LCD_DIMM, &brightness)) { - eConfig::getInstance()->getKey("/ezap/lcd/brightness", lcdbrightness); - setLCDParameter(lcdbrightness, lcdcontrast); - + eDebug("[LCD] can't set lcd brightness"); } return(0); } @@ -165,7 +109,10 @@ int eDBoxLCD::switchLCD(int state) eDBoxLCD::~eDBoxLCD() { if (lcdfd>0) + { close(lcdfd); + lcdfd=0; + } } eDBoxLCD *eDBoxLCD::getInstance() @@ -175,38 +122,21 @@ eDBoxLCD *eDBoxLCD::getInstance() void eDBoxLCD::update() { - if (!locked) + unsigned char raw[120*8]; + int x, y, yy; + for (y=0; y<8; y++) { - unsigned char raw[120*8]; - int x, y, yy; - for (y=0; y<8; y++) + for (x=0; x<120; x++) { - for (x=0; x<120; x++) + int pix=0; + for (yy=0; yy<8; yy++) { - int pix=0; - for (yy=0; yy<8; yy++) - { - pix|=(_buffer[(y*8+yy)*128+x]>=108)<=108)<0) - write(lcdfd, raw, 120*8); } + if (lcdfd>0) + write(lcdfd, raw, 120*8); } -class eDBoxLCDHardware -{ - eDBoxLCD lcd; - gLCDDC lcddc; -public: - eDBoxLCDHardware(): lcddc(&lcd) - { - } -}; - -eAutoInitP0 init_eDBoxLCDHardware(eAutoInitNumbers::lowlevel, "d-Box LCD Hardware"); - -#endif //DISABLE_LCD -#endif