diff options
Diffstat (limited to '')
-rw-r--r-- | drv_X11.c | 525 |
1 files changed, 269 insertions, 256 deletions
@@ -1,4 +1,4 @@ -/* $Id: drv_X11.c,v 1.10 2005/01/18 06:30:23 reinelt Exp $ +/* $Id: drv_X11.c,v 1.11 2005/05/08 04:32:44 reinelt Exp $ * * new style X11 Driver for LCD4Linux * @@ -26,6 +26,9 @@ * * * $Log: drv_X11.c,v $ + * Revision 1.11 2005/05/08 04:32:44 reinelt + * CodingStyle added and applied + * * Revision 1.10 2005/01/18 06:30:23 reinelt * added (C) to all copyright statements * @@ -107,19 +110,19 @@ #include <dmalloc.h> #endif -static char Name[]="X11"; +static char Name[] = "X11"; -static char *fg_col,*bg_col,*hg_col; +static char *fg_col, *bg_col, *hg_col; -static int pixel = -1; /* pointsize in pixel */ -static int pgap = 0; /* gap between points */ -static int rgap = 0; /* row gap between lines */ -static int cgap = 0; /* column gap between characters */ -static int border = 0; /* window border */ +static int pixel = -1; /* pointsize in pixel */ +static int pgap = 0; /* gap between points */ +static int rgap = 0; /* row gap between lines */ +static int cgap = 0; /* column gap between characters */ +static int border = 0; /* window border */ -static int dimx, dimy; /* total window dimension in pixel */ +static int dimx, dimy; /* total window dimension in pixel */ -static unsigned char *drv_X11_FB=NULL; +static unsigned char *drv_X11_FB = NULL; static Display *dp; static int sc, dd; @@ -137,204 +140,214 @@ static Pixmap pm; static void drv_X11_blit(const int row, const int col, const int height, const int width) { - int r, c; - int dirty = 0; - - for (r=row; r<row+height && r<DROWS; r++) { - int y = border + (r/YRES)*rgap + r*(pixel+pgap); - for (c=col; c<col+width && c<DCOLS; c++) { - int x = border + (c/XRES)*cgap + c*(pixel+pgap); - unsigned char p = drv_generic_graphic_FB[r*LCOLS+c]; - if (drv_X11_FB[r*DCOLS+c] != p) { - XFillRectangle( dp, w, p? fg_gc:hg_gc, x, y, pixel, pixel); - drv_X11_FB[r*DCOLS+c] = p; - dirty=1; - } + int r, c; + int dirty = 0; + + for (r = row; r < row + height && r < DROWS; r++) { + int y = border + (r / YRES) * rgap + r * (pixel + pgap); + for (c = col; c < col + width && c < DCOLS; c++) { + int x = border + (c / XRES) * cgap + c * (pixel + pgap); + unsigned char p = drv_generic_graphic_FB[r * LCOLS + c]; + if (drv_X11_FB[r * DCOLS + c] != p) { + XFillRectangle(dp, w, p ? fg_gc : hg_gc, x, y, pixel, pixel); + drv_X11_FB[r * DCOLS + c] = p; + dirty = 1; + } + } + } + if (dirty) { + XSync(dp, False); } - } - if (dirty) { - XSync(dp, False); - } } static void drv_X11_expose(const int x, const int y, const int width, const int height) { - /* - * theory of operation: - * instead of the old, fully-featured but complicated update - * region calculation, we do an update of the whole display, - * but check before every pixel if the pixel region is inside - * the update region. - */ - - int r, c; - int x0, y0; - int x1, y1; - - x0 = x-pixel; - x1 = x+pixel+width; - y0 = y-pixel; - y1 = y+pixel+height; - - for (r=0; r<DROWS; r++) { - int yc = border + (r/YRES)*rgap + r*(pixel+pgap); - if (yc<y0 || yc>y1) continue; - for (c=0; c<DCOLS; c++) { - int xc = border + (c/XRES)*cgap + c*(pixel+pgap); - if (xc<x0 || xc>x1) continue; - XFillRectangle( dp, w, drv_generic_graphic_FB[r*LCOLS+c]? fg_gc:hg_gc, xc, yc, pixel, pixel); + /* + * theory of operation: + * instead of the old, fully-featured but complicated update + * region calculation, we do an update of the whole display, + * but check before every pixel if the pixel region is inside + * the update region. + */ + + int r, c; + int x0, y0; + int x1, y1; + + x0 = x - pixel; + x1 = x + pixel + width; + y0 = y - pixel; + y1 = y + pixel + height; + + for (r = 0; r < DROWS; r++) { + int yc = border + (r / YRES) * rgap + r * (pixel + pgap); + if (yc < y0 || yc > y1) + continue; + for (c = 0; c < DCOLS; c++) { + int xc = border + (c / XRES) * cgap + c * (pixel + pgap); + if (xc < x0 || xc > x1) + continue; + XFillRectangle(dp, w, drv_generic_graphic_FB[r * LCOLS + c] ? fg_gc : hg_gc, xc, yc, pixel, pixel); + } } - } - XSync(dp, False); + XSync(dp, False); } -static void drv_X11_timer (__attribute__((unused)) void *notused) +static void drv_X11_timer( __attribute__ ((unused)) + void *notused) { - XEvent ev; - - if (XCheckWindowEvent(dp, w, ExposureMask, &ev)==0) return; - if (ev.type==Expose) { - drv_X11_expose (ev.xexpose.x, ev.xexpose.y, ev.xexpose.width, ev.xexpose.height); - } + XEvent ev; + + if (XCheckWindowEvent(dp, w, ExposureMask, &ev) == 0) + return; + if (ev.type == Expose) { + drv_X11_expose(ev.xexpose.x, ev.xexpose.y, ev.xexpose.width, ev.xexpose.height); + } } -static int drv_X11_start (const char *section) +static int drv_X11_start(const char *section) { - char *s; - XSetWindowAttributes wa; - XSizeHints sh; - XColor dummy; - XEvent ev; - - - /* read display size from config */ - if (sscanf(s=cfg_get(section, "Size", "120x32"), "%dx%d", &DCOLS, &DROWS)!=2 || DCOLS<1 || DROWS<1) { - error ("%s: bad %s.Size '%s' from %s", Name, section, s, cfg_source()); + char *s; + XSetWindowAttributes wa; + XSizeHints sh; + XColor dummy; + XEvent ev; + + + /* read display size from config */ + if (sscanf(s = cfg_get(section, "Size", "120x32"), "%dx%d", &DCOLS, &DROWS) != 2 || DCOLS < 1 || DROWS < 1) { + error("%s: bad %s.Size '%s' from %s", Name, section, s, cfg_source()); + free(s); + return -1; + } free(s); - return -1; - } - free(s); - - if (sscanf(s=cfg_get(section, "font", "5x8"), "%dx%d", &XRES, &YRES)!=2 || XRES<1|| YRES<1) { - error ("%s: bad %s.font '%s' from %s", Name, section, s, cfg_source()); + + if (sscanf(s = cfg_get(section, "font", "5x8"), "%dx%d", &XRES, &YRES) != 2 || XRES < 1 || YRES < 1) { + error("%s: bad %s.font '%s' from %s", Name, section, s, cfg_source()); + free(s); + return -1; + } free(s); - return -1; - } - free(s); - - if (sscanf(s=cfg_get(section, "pixel", "4+1"), "%d+%d", &pixel, &pgap)!=2 || pixel<1 || pgap<0) { - error ("%s: bad %s.pixel '%s' from %s", Name, section, s, cfg_source()); + + if (sscanf(s = cfg_get(section, "pixel", "4+1"), "%d+%d", &pixel, &pgap) != 2 || pixel < 1 || pgap < 0) { + error("%s: bad %s.pixel '%s' from %s", Name, section, s, cfg_source()); + free(s); + return -1; + } free(s); - return -1; - } - free(s); - - if (sscanf(s=cfg_get(section, "gap", "-1x-1"), "%dx%d", &cgap, &rgap)!=2 || cgap<-1 || rgap<-1) { - error ("%s: bad %s.gap '%s' from %s", Name, section, s, cfg_source()); + + if (sscanf(s = cfg_get(section, "gap", "-1x-1"), "%dx%d", &cgap, &rgap) != 2 || cgap < -1 || rgap < -1) { + error("%s: bad %s.gap '%s' from %s", Name, section, s, cfg_source()); + free(s); + return -1; + } free(s); - return -1; - } - free(s); - - if (rgap<0) rgap=pixel+pgap; - if (cgap<0) cgap=pixel+pgap; - - if (cfg_number(section, "border", 0, 0, -1, &border)<0) return -1; - - fg_col = cfg_get(section, "foreground", "#000000"); - bg_col = cfg_get(section, "background", "#80d000"); - hg_col = cfg_get(section, "halfground", "#70c000"); - if (*fg_col=='\\') fg_col++; - if (*bg_col=='\\') bg_col++; - if (*hg_col=='\\') hg_col++; - - - drv_X11_FB = malloc(DCOLS*DROWS); - if (drv_X11_FB==NULL) { - error ("%s: framebuffer could not be allocated: malloc() failed", Name); - return -1; - } - - /* init with 255 so all 'halfground' pixels will be drawn */ - memset(drv_X11_FB, 255, DCOLS*DROWS*sizeof(*drv_X11_FB)); - - if ((dp=XOpenDisplay(NULL))==NULL) { - error ("%s: can't open display", Name); - return -1; - } - - sc = DefaultScreen(dp); - fg_gc = DefaultGC(dp, sc); - vi = DefaultVisual(dp, sc); - dd = DefaultDepth(dp, sc); - rw = DefaultRootWindow(dp); - cm = DefaultColormap(dp, sc); - - if (XAllocNamedColor(dp, cm, fg_col, &fg_xc, &dummy) == False) { - error ("%s: can't alloc foreground color '%s'", Name, fg_col); - return -1; - } - - if (XAllocNamedColor(dp, cm, bg_col, &bg_xc, &dummy)==False) { - error ("%s: can't alloc background color '%s'", Name, bg_col); - return -1; - } - - if (XAllocNamedColor(dp, cm, hg_col, &hg_xc, &dummy)==False) { - error ("%s: can't alloc halfground color '%s'", Name, hg_col); - return -1; - } - - dimx = DCOLS*pixel + (DCOLS-1)*pgap + (DCOLS/XRES-1)*cgap; - dimy = DROWS*pixel + (DROWS-1)*pgap + (DROWS/YRES-1)*rgap; - - wa.event_mask=ExposureMask; - - w = XCreateWindow(dp, rw, 0, 0, dimx+2*border, dimy+2*border, 0, 0, InputOutput, vi, CWEventMask, &wa); - - pm = XCreatePixmap(dp, w, dimx, dimy, dd); - - sh.min_width = sh.max_width = dimx+2*border; - sh.min_height = sh.max_height = dimy+2*border; - sh.flags = PPosition|PSize|PMinSize|PMaxSize; - - XSetWMProperties(dp, w, NULL, NULL, NULL, 0, &sh, NULL, NULL); - - - XSetForeground(dp, fg_gc, fg_xc.pixel); - XSetBackground(dp, fg_gc, bg_xc.pixel); - - bg_gc = XCreateGC(dp, w, 0, NULL); - XSetForeground(dp, bg_gc, bg_xc.pixel); - XSetBackground(dp, bg_gc, fg_xc.pixel); - - hg_gc = XCreateGC(dp, w, 0, NULL); - XSetForeground(dp, hg_gc, hg_xc.pixel); - XSetBackground(dp, hg_gc, fg_xc.pixel); - - XFillRectangle(dp, pm, bg_gc, 0, 0, dimx+2*border, dimy+2*border); - XSetWindowBackground(dp, w, bg_xc.pixel); - XClearWindow(dp, w); - - XStoreName(dp, w, "LCD4Linux"); - XMapWindow(dp, w); - - XFlush(dp); - - while(1) { - XNextEvent(dp,&ev); - if (ev.type==Expose && ev.xexpose.count==0) - break; - } - - /* regularly process X events */ - /* Fixme: make 20msec configurable */ - timer_add (drv_X11_timer, NULL, 20, 0); - - return 0; + + if (rgap < 0) + rgap = pixel + pgap; + if (cgap < 0) + cgap = pixel + pgap; + + if (cfg_number(section, "border", 0, 0, -1, &border) < 0) + return -1; + + fg_col = cfg_get(section, "foreground", "#000000"); + bg_col = cfg_get(section, "background", "#80d000"); + hg_col = cfg_get(section, "halfground", "#70c000"); + if (*fg_col == '\\') + fg_col++; + if (*bg_col == '\\') + bg_col++; + if (*hg_col == '\\') + hg_col++; + + + drv_X11_FB = malloc(DCOLS * DROWS); + if (drv_X11_FB == NULL) { + error("%s: framebuffer could not be allocated: malloc() failed", Name); + return -1; + } + + /* init with 255 so all 'halfground' pixels will be drawn */ + memset(drv_X11_FB, 255, DCOLS * DROWS * sizeof(*drv_X11_FB)); + + if ((dp = XOpenDisplay(NULL)) == NULL) { + error("%s: can't open display", Name); + return -1; + } + + sc = DefaultScreen(dp); + fg_gc = DefaultGC(dp, sc); + vi = DefaultVisual(dp, sc); + dd = DefaultDepth(dp, sc); + rw = DefaultRootWindow(dp); + cm = DefaultColormap(dp, sc); + + if (XAllocNamedColor(dp, cm, fg_col, &fg_xc, &dummy) == False) { + error("%s: can't alloc foreground color '%s'", Name, fg_col); + return -1; + } + + if (XAllocNamedColor(dp, cm, bg_col, &bg_xc, &dummy) == False) { + error("%s: can't alloc background color '%s'", Name, bg_col); + return -1; + } + + if (XAllocNamedColor(dp, cm, hg_col, &hg_xc, &dummy) == False) { + error("%s: can't alloc halfground color '%s'", Name, hg_col); + return -1; + } + + dimx = DCOLS * pixel + (DCOLS - 1) * pgap + (DCOLS / XRES - 1) * cgap; + dimy = DROWS * pixel + (DROWS - 1) * pgap + (DROWS / YRES - 1) * rgap; + + wa.event_mask = ExposureMask; + + w = XCreateWindow(dp, rw, 0, 0, dimx + 2 * border, dimy + 2 * border, 0, 0, InputOutput, vi, CWEventMask, &wa); + + pm = XCreatePixmap(dp, w, dimx, dimy, dd); + + sh.min_width = sh.max_width = dimx + 2 * border; + sh.min_height = sh.max_height = dimy + 2 * border; + sh.flags = PPosition | PSize | PMinSize | PMaxSize; + + XSetWMProperties(dp, w, NULL, NULL, NULL, 0, &sh, NULL, NULL); + + + XSetForeground(dp, fg_gc, fg_xc.pixel); + XSetBackground(dp, fg_gc, bg_xc.pixel); + + bg_gc = XCreateGC(dp, w, 0, NULL); + XSetForeground(dp, bg_gc, bg_xc.pixel); + XSetBackground(dp, bg_gc, fg_xc.pixel); + + hg_gc = XCreateGC(dp, w, 0, NULL); + XSetForeground(dp, hg_gc, hg_xc.pixel); + XSetBackground(dp, hg_gc, fg_xc.pixel); + + XFillRectangle(dp, pm, bg_gc, 0, 0, dimx + 2 * border, dimy + 2 * border); + XSetWindowBackground(dp, w, bg_xc.pixel); + XClearWindow(dp, w); + + XStoreName(dp, w, "LCD4Linux"); + XMapWindow(dp, w); + + XFlush(dp); + + while (1) { + XNextEvent(dp, &ev); + if (ev.type == Expose && ev.xexpose.count == 0) + break; + } + + /* regularly process X events */ + /* Fixme: make 20msec configurable */ + timer_add(drv_X11_timer, NULL, 20, 0); + + return 0; } @@ -362,86 +375,86 @@ static int drv_X11_start (const char *section) /* list models */ -int drv_X11_list (void) +int drv_X11_list(void) { - printf ("any"); - return 0; + printf("any"); + return 0; } /* initialize driver & display */ -int drv_X11_init (const char *section, const int quiet) +int drv_X11_init(const char *section, const int quiet) { - WIDGET_CLASS wc; - int ret; - - /* real worker functions */ - drv_generic_graphic_real_blit = drv_X11_blit; - - /* start display */ - if ((ret=drv_X11_start (section))!=0) - return ret; - - /* initialize generic graphic driver */ - if ((ret=drv_generic_graphic_init(section, Name))!=0) - return ret; - - /* initially expose window */ - drv_generic_graphic_clear(); - drv_X11_expose (0, 0, dimx+2*border, dimy+2*border); - - if (!quiet) { - char buffer[40]; - qprintf(buffer, sizeof(buffer), "%s %dx%d", Name, DCOLS, DROWS); - if (drv_generic_graphic_greet (buffer, NULL)) { - sleep (3); - drv_generic_graphic_clear(); + WIDGET_CLASS wc; + int ret; + + /* real worker functions */ + drv_generic_graphic_real_blit = drv_X11_blit; + + /* start display */ + if ((ret = drv_X11_start(section)) != 0) + return ret; + + /* initialize generic graphic driver */ + if ((ret = drv_generic_graphic_init(section, Name)) != 0) + return ret; + + /* initially expose window */ + drv_generic_graphic_clear(); + drv_X11_expose(0, 0, dimx + 2 * border, dimy + 2 * border); + + if (!quiet) { + char buffer[40]; + qprintf(buffer, sizeof(buffer), "%s %dx%d", Name, DCOLS, DROWS); + if (drv_generic_graphic_greet(buffer, NULL)) { + sleep(3); + drv_generic_graphic_clear(); + } } - } - - /* register text widget */ - wc=Widget_Text; - wc.draw=drv_generic_graphic_draw; - widget_register(&wc); - - /* register icon widget */ - wc=Widget_Icon; - wc.draw=drv_generic_graphic_icon_draw; - widget_register(&wc); - - /* register bar widget */ - wc=Widget_Bar; - wc.draw=drv_generic_graphic_bar_draw; - widget_register(&wc); - - /* register plugins */ - /* none at the moment... */ - - - return 0; + + /* register text widget */ + wc = Widget_Text; + wc.draw = drv_generic_graphic_draw; + widget_register(&wc); + + /* register icon widget */ + wc = Widget_Icon; + wc.draw = drv_generic_graphic_icon_draw; + widget_register(&wc); + + /* register bar widget */ + wc = Widget_Bar; + wc.draw = drv_generic_graphic_bar_draw; + widget_register(&wc); + + /* register plugins */ + /* none at the moment... */ + + + return 0; } /* close driver & display */ -int drv_X11_quit (const __attribute__((unused)) int quiet) { - - info("%s: shutting down.", Name); - drv_generic_graphic_quit(); - - if (drv_X11_FB) { - free (drv_X11_FB); - drv_X11_FB=NULL; - } - - return (0); +int drv_X11_quit(const __attribute__ ((unused)) + int quiet) +{ + + info("%s: shutting down.", Name); + drv_generic_graphic_quit(); + + if (drv_X11_FB) { + free(drv_X11_FB); + drv_X11_FB = NULL; + } + + return (0); } DRIVER drv_X11 = { - name: Name, - list: drv_X11_list, - init: drv_X11_init, - quit: drv_X11_quit, + name:Name, + list:drv_X11_list, + init:drv_X11_init, + quit:drv_X11_quit, }; - - |