X-Git-Url: https://git.artsoft.org/?p=rocksndiamonds.git;a=blobdiff_plain;f=src%2Flibgame%2Fsystem.c;h=bc7d5a13c304116bacf57da84c57e721dc069ae5;hp=eff8576cf417ccf793b11304a209ebe58cf32b80;hb=998be01ad92a672b69b11e24d472f6c0c076817f;hpb=e582c697ddb8c9cd9d5d345beaf83c1916b849fa diff --git a/src/libgame/system.c b/src/libgame/system.c index eff8576c..bc7d5a13 100644 --- a/src/libgame/system.c +++ b/src/libgame/system.c @@ -207,15 +207,20 @@ inline Bitmap CreateBitmap(int width, int height, int depth) #else Pixmap pixmap; - if (!(pixmap = XCreatePixmap(display, window->drawable, - width, height, real_depth))) + if ((pixmap = XCreatePixmap(display, window->drawable, + width, height, real_depth)) + == None) Error(ERR_EXIT, "cannot create pixmap"); + new_bitmap->drawable = pixmap; if (window == NULL) Error(ERR_EXIT, "Window GC needed for Bitmap -- create Window first"); + new_bitmap->gc = window->gc; + new_bitmap->line_gc[0] = window->line_gc[0]; + new_bitmap->line_gc[1] = window->line_gc[1]; #endif return new_bitmap; @@ -339,6 +344,91 @@ inline void DrawSimpleWhiteLine(Bitmap bitmap, int from_x, int from_y, #endif } +#if !defined(TARGET_X11_NATIVE) +inline void DrawLine(Bitmap bitmap, int from_x, int from_y, + int to_x, int to_y, Pixel pixel, int line_width) +{ + int x, y; + + for (x=0; xsurface, + from_x + dx, from_y + dy, to_x + dx, to_y + dy, pixel); +#elif defined(TARGET_ALLEGRO) + AllegroDrawLine(bitmap->drawable, from_x + dx, from_y + dy, + to_x + dx, to_y + dy, pixel); +#endif + } + } +} +#endif + +inline void DrawLines(Bitmap bitmap, struct XY *points, int num_points, + Pixel pixel) +{ +#if !defined(TARGET_X11_NATIVE) + int line_width = 4; + int i; + + for (i=0; isurface, points, num_points, pixel); + */ +#else + XSetForeground(display, bitmap->line_gc[1], pixel); + XDrawLines(display, bitmap->drawable, bitmap->line_gc[1], + (XPoint *)points, num_points, CoordModeOrigin); + /* + XSetForeground(display, gc, BlackPixel(display, screen)); + */ +#endif +} + +inline Pixel GetPixelFromRGB(Bitmap bitmap, unsigned int color_r, + unsigned int color_g, unsigned int color_b) +{ + Pixel pixel; + +#if defined(TARGET_SDL) + pixel = SDL_MapRGB(bitmap->surface->format, color_r, color_g, color_b); +#elif defined(TARGET_X11_NATIVE) + XColor xcolor; + + xcolor.flags = DoRed | DoGreen | DoBlue; + xcolor.red = (color_r << 8); + xcolor.green = (color_g << 8); + xcolor.blue = (color_b << 8); + XAllocColor(display, cmap, &xcolor); + pixel = xcolor.pixel; +#endif + + return pixel; +} + +inline Pixel GetPixelFromRGBcompact(Bitmap bitmap, unsigned int color) +{ + unsigned int color_r = (color >> 16) & 0xff; + unsigned int color_g = (color >> 8) & 0xff; + unsigned int color_b = (color >> 0) & 0xff; + + return GetPixelFromRGB(bitmap, color_r, color_g, color_b); +} + /* execute all pending screen drawing operations */ inline void FlushDisplay(void) {