Fixed up loose ends with the GdkRgb integration. Color selection areas are

dithered now, and dither patterns align correctly when scrolling.
This commit is contained in:
Raph Levien 1998-08-31 22:22:23 +00:00
parent 401df1a726
commit fe6c43af7c
17 changed files with 258 additions and 25 deletions

View File

@ -1,3 +1,17 @@
Mon Aug 31 15:15:01 1998 Raph Levien <raph@gimp.org>
* app/color_select.c (color_select_update_colors): made it use the
color_area rectangle draw so it dithers.
* app/color_area.[ch] (color_area_draw_rect): made it draw the color
rectangle with gdkrgb (so it gets dithered) rather than the
rectangle drawing primitive.
* app/gximage.[ch] (gximage_put): made it align dithers
* app/gdisplay.c (gdisplay_display_area): made it so that the
gximage_put routine gets dither alignment values
Mon Aug 31 16:51:35 CDT 1998 Larry Ewing <lewing@gimp.org> Mon Aug 31 16:51:35 CDT 1998 Larry Ewing <lewing@gimp.org>
* app/internal_procs.c: included in merge down changes * app/internal_procs.c: included in merge down changes

View File

@ -73,6 +73,45 @@ color_area_target (int x,
return -1; return -1;
} }
void
color_area_draw_rect (GdkDrawable *drawable,
GdkGC *gc,
gint x, gint y, gint width, gint height,
unsigned char r, unsigned char g, unsigned char b)
{
static unsigned char *color_area_rgb_buf = NULL;
static gint color_area_rgb_buf_size;
static gint rowstride;
gint xx, yy;
unsigned char *bp;
rowstride = 3 * ((width + 3) & -4);
if (color_area_rgb_buf == NULL ||
color_area_rgb_buf_size < height * rowstride)
{
if (color_area_rgb_buf)
g_free (color_area_rgb_buf);
color_area_rgb_buf = g_malloc (rowstride * height);
}
bp = color_area_rgb_buf;
for (xx = 0; xx < width; xx++)
{
*bp++ = r;
*bp++ = g;
*bp++ = b;
}
bp = color_area_rgb_buf;
for (yy = 1; yy < height; yy++)
{
bp += rowstride;
memcpy (bp, color_area_rgb_buf, rowstride);
}
gdk_draw_rgb_image (drawable, gc, x, y, width, height,
GDK_RGB_DITHER_MAX,
color_area_rgb_buf,
rowstride);
}
static void static void
color_area_draw (void) color_area_draw (void)
{ {
@ -82,6 +121,7 @@ color_area_draw (void)
int width, height; int width, height;
int def_width, def_height; int def_width, def_height;
int swap_width, swap_height; int swap_width, swap_height;
unsigned char r, g, b;
/* Check we haven't gotten initial expose yet, /* Check we haven't gotten initial expose yet,
* no point in drawing anything */ * no point in drawing anything */
@ -102,9 +142,16 @@ color_area_draw (void)
gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1, gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1,
0, 0, width, height); 0, 0, width, height);
#ifdef OLD_COLOR_AREA
gdk_gc_set_foreground (color_area_gc, &bg); gdk_gc_set_foreground (color_area_gc, &bg);
gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1, gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1,
(width - rect_w), (height - rect_h), rect_w, rect_h); (width - rect_w), (height - rect_h), rect_w, rect_h);
#else
palette_get_background (&r, &g, &b);
color_area_draw_rect (color_area_pixmap, color_area_gc,
(width - rect_w), (height - rect_h), rect_w, rect_h,
r, g, b);
#endif
if (active_color == FOREGROUND) if (active_color == FOREGROUND)
gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_OUT, gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_OUT,
@ -113,9 +160,16 @@ color_area_draw (void)
gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN, gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN,
(width - rect_w), (height - rect_h), rect_w, rect_h); (width - rect_w), (height - rect_h), rect_w, rect_h);
#ifdef OLD_COLOR_AREA
gdk_gc_set_foreground (color_area_gc, &fg); gdk_gc_set_foreground (color_area_gc, &fg);
gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1, gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1,
0, 0, rect_w, rect_h); 0, 0, rect_w, rect_h);
#else
palette_get_foreground (&r, &g, &b);
color_area_draw_rect (color_area_pixmap, color_area_gc,
0, 0, rect_w, rect_h,
r, g, b);
#endif
if (active_color == FOREGROUND) if (active_color == FOREGROUND)
gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN, gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN,

View File

@ -28,9 +28,17 @@ GtkWidget * color_area_create (int width,
GdkPixmap *swap_pixmap); GdkPixmap *swap_pixmap);
void color_area_update (void); void color_area_update (void);
/* Exported for use by color_select */
void
color_area_draw_rect (GdkDrawable *drawable,
GdkGC *gc,
gint x, gint y, gint width, gint height,
unsigned char r, unsigned char g, unsigned char b);
/* /*
* Global variables * Global variables
*/ */
extern int active_color; /* foreground (= 0) or background (= 1) */ extern int active_color; /* foreground (= 0) or background (= 1) */
#endif /* __COLOR_AREA_H__ */ #endif /* __COLOR_AREA_H__ */

View File

@ -24,6 +24,7 @@
#include "errors.h" #include "errors.h"
#include "gimprc.h" #include "gimprc.h"
#include "session.h" #include "session.h"
#include "color_area.h" /* for color_area_draw_rect */
#define XY_DEF_WIDTH 240 #define XY_DEF_WIDTH 240
#define XY_DEF_HEIGHT 240 #define XY_DEF_HEIGHT 240
@ -787,9 +788,15 @@ color_select_update_colors (ColorSelectP csp,
if (csp->gc) if (csp->gc)
{ {
#ifdef OLD_COLOR_AREA
gdk_gc_set_foreground (csp->gc, &color); gdk_gc_set_foreground (csp->gc, &color);
gdk_draw_rectangle (window, csp->gc, 1, gdk_draw_rectangle (window, csp->gc, 1,
0, 0, width, height); 0, 0, width, height);
#else
color_area_draw_rect (window, csp->gc,
0, 0, width, height,
red, green, blue);
#endif
} }
} }
} }

View File

@ -844,7 +844,9 @@ gdisplay_display_area (GDisplay *gdisp,
dy = (y2 - i < GXIMAGE_HEIGHT) ? y2 - i : GXIMAGE_HEIGHT; dy = (y2 - i < GXIMAGE_HEIGHT) ? y2 - i : GXIMAGE_HEIGHT;
render_image (gdisp, j - gdisp->disp_xoffset, i - gdisp->disp_yoffset, dx, dy); render_image (gdisp, j - gdisp->disp_xoffset, i - gdisp->disp_yoffset, dx, dy);
gximage_put (gdisp->canvas->window, gximage_put (gdisp->canvas->window,
j, i, dx, dy); j, i, dx, dy,
gdisp->offset_x,
gdisp->offset_y);
} }
} }

View File

@ -844,7 +844,9 @@ gdisplay_display_area (GDisplay *gdisp,
dy = (y2 - i < GXIMAGE_HEIGHT) ? y2 - i : GXIMAGE_HEIGHT; dy = (y2 - i < GXIMAGE_HEIGHT) ? y2 - i : GXIMAGE_HEIGHT;
render_image (gdisp, j - gdisp->disp_xoffset, i - gdisp->disp_yoffset, dx, dy); render_image (gdisp, j - gdisp->disp_xoffset, i - gdisp->disp_yoffset, dx, dy);
gximage_put (gdisp->canvas->window, gximage_put (gdisp->canvas->window,
j, i, dx, dy); j, i, dx, dy,
gdisp->offset_x,
gdisp->offset_y);
} }
} }

View File

@ -108,7 +108,7 @@ gximage_get_byte_order ()
} }
void void
gximage_put (GdkWindow *win, int x, int y, int w, int h) gximage_put (GdkWindow *win, int x, int y, int w, int h, int xdith, int ydith)
{ {
/* create the GC if it doesn't yet exist */ /* create the GC if it doesn't yet exist */
if (!gximage->gc) if (!gximage->gc)
@ -117,13 +117,15 @@ gximage_put (GdkWindow *win, int x, int y, int w, int h)
gdk_gc_set_exposures (gximage->gc, TRUE); gdk_gc_set_exposures (gximage->gc, TRUE);
} }
gdk_draw_rgb_image (win, gdk_draw_rgb_image_dithalign (win,
gximage->gc, gximage->gc,
x, x,
y, y,
w, w,
h, h,
GDK_RGB_DITHER_MAX, /* todo: make configurable */ /* todo: make configurable */
GDK_RGB_DITHER_MAX,
gximage->data, gximage->data,
GXIMAGE_WIDTH * 3); GXIMAGE_WIDTH * 3,
xdith, ydith);
} }

View File

@ -24,7 +24,8 @@
void gximage_init (void); void gximage_init (void);
void gximage_free (void); void gximage_free (void);
void gximage_put (GdkWindow *, int, int, int, int); void
gximage_put (GdkWindow *win, int x, int y, int w, int h, int xdith, int ydith);
guchar* gximage_get_data (void); guchar* gximage_get_data (void);
int gximage_get_bpp (void); int gximage_get_bpp (void);
int gximage_get_bpl (void); int gximage_get_bpl (void);

View File

@ -844,7 +844,9 @@ gdisplay_display_area (GDisplay *gdisp,
dy = (y2 - i < GXIMAGE_HEIGHT) ? y2 - i : GXIMAGE_HEIGHT; dy = (y2 - i < GXIMAGE_HEIGHT) ? y2 - i : GXIMAGE_HEIGHT;
render_image (gdisp, j - gdisp->disp_xoffset, i - gdisp->disp_yoffset, dx, dy); render_image (gdisp, j - gdisp->disp_xoffset, i - gdisp->disp_yoffset, dx, dy);
gximage_put (gdisp->canvas->window, gximage_put (gdisp->canvas->window,
j, i, dx, dy); j, i, dx, dy,
gdisp->offset_x,
gdisp->offset_y);
} }
} }

View File

@ -73,6 +73,45 @@ color_area_target (int x,
return -1; return -1;
} }
void
color_area_draw_rect (GdkDrawable *drawable,
GdkGC *gc,
gint x, gint y, gint width, gint height,
unsigned char r, unsigned char g, unsigned char b)
{
static unsigned char *color_area_rgb_buf = NULL;
static gint color_area_rgb_buf_size;
static gint rowstride;
gint xx, yy;
unsigned char *bp;
rowstride = 3 * ((width + 3) & -4);
if (color_area_rgb_buf == NULL ||
color_area_rgb_buf_size < height * rowstride)
{
if (color_area_rgb_buf)
g_free (color_area_rgb_buf);
color_area_rgb_buf = g_malloc (rowstride * height);
}
bp = color_area_rgb_buf;
for (xx = 0; xx < width; xx++)
{
*bp++ = r;
*bp++ = g;
*bp++ = b;
}
bp = color_area_rgb_buf;
for (yy = 1; yy < height; yy++)
{
bp += rowstride;
memcpy (bp, color_area_rgb_buf, rowstride);
}
gdk_draw_rgb_image (drawable, gc, x, y, width, height,
GDK_RGB_DITHER_MAX,
color_area_rgb_buf,
rowstride);
}
static void static void
color_area_draw (void) color_area_draw (void)
{ {
@ -82,6 +121,7 @@ color_area_draw (void)
int width, height; int width, height;
int def_width, def_height; int def_width, def_height;
int swap_width, swap_height; int swap_width, swap_height;
unsigned char r, g, b;
/* Check we haven't gotten initial expose yet, /* Check we haven't gotten initial expose yet,
* no point in drawing anything */ * no point in drawing anything */
@ -102,9 +142,16 @@ color_area_draw (void)
gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1, gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1,
0, 0, width, height); 0, 0, width, height);
#ifdef OLD_COLOR_AREA
gdk_gc_set_foreground (color_area_gc, &bg); gdk_gc_set_foreground (color_area_gc, &bg);
gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1, gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1,
(width - rect_w), (height - rect_h), rect_w, rect_h); (width - rect_w), (height - rect_h), rect_w, rect_h);
#else
palette_get_background (&r, &g, &b);
color_area_draw_rect (color_area_pixmap, color_area_gc,
(width - rect_w), (height - rect_h), rect_w, rect_h,
r, g, b);
#endif
if (active_color == FOREGROUND) if (active_color == FOREGROUND)
gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_OUT, gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_OUT,
@ -113,9 +160,16 @@ color_area_draw (void)
gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN, gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN,
(width - rect_w), (height - rect_h), rect_w, rect_h); (width - rect_w), (height - rect_h), rect_w, rect_h);
#ifdef OLD_COLOR_AREA
gdk_gc_set_foreground (color_area_gc, &fg); gdk_gc_set_foreground (color_area_gc, &fg);
gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1, gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1,
0, 0, rect_w, rect_h); 0, 0, rect_w, rect_h);
#else
palette_get_foreground (&r, &g, &b);
color_area_draw_rect (color_area_pixmap, color_area_gc,
0, 0, rect_w, rect_h,
r, g, b);
#endif
if (active_color == FOREGROUND) if (active_color == FOREGROUND)
gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN, gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN,

View File

@ -28,9 +28,17 @@ GtkWidget * color_area_create (int width,
GdkPixmap *swap_pixmap); GdkPixmap *swap_pixmap);
void color_area_update (void); void color_area_update (void);
/* Exported for use by color_select */
void
color_area_draw_rect (GdkDrawable *drawable,
GdkGC *gc,
gint x, gint y, gint width, gint height,
unsigned char r, unsigned char g, unsigned char b);
/* /*
* Global variables * Global variables
*/ */
extern int active_color; /* foreground (= 0) or background (= 1) */ extern int active_color; /* foreground (= 0) or background (= 1) */
#endif /* __COLOR_AREA_H__ */ #endif /* __COLOR_AREA_H__ */

View File

@ -24,6 +24,7 @@
#include "errors.h" #include "errors.h"
#include "gimprc.h" #include "gimprc.h"
#include "session.h" #include "session.h"
#include "color_area.h" /* for color_area_draw_rect */
#define XY_DEF_WIDTH 240 #define XY_DEF_WIDTH 240
#define XY_DEF_HEIGHT 240 #define XY_DEF_HEIGHT 240
@ -787,9 +788,15 @@ color_select_update_colors (ColorSelectP csp,
if (csp->gc) if (csp->gc)
{ {
#ifdef OLD_COLOR_AREA
gdk_gc_set_foreground (csp->gc, &color); gdk_gc_set_foreground (csp->gc, &color);
gdk_draw_rectangle (window, csp->gc, 1, gdk_draw_rectangle (window, csp->gc, 1,
0, 0, width, height); 0, 0, width, height);
#else
color_area_draw_rect (window, csp->gc,
0, 0, width, height,
red, green, blue);
#endif
} }
} }
} }

View File

@ -108,7 +108,7 @@ gximage_get_byte_order ()
} }
void void
gximage_put (GdkWindow *win, int x, int y, int w, int h) gximage_put (GdkWindow *win, int x, int y, int w, int h, int xdith, int ydith)
{ {
/* create the GC if it doesn't yet exist */ /* create the GC if it doesn't yet exist */
if (!gximage->gc) if (!gximage->gc)
@ -117,13 +117,15 @@ gximage_put (GdkWindow *win, int x, int y, int w, int h)
gdk_gc_set_exposures (gximage->gc, TRUE); gdk_gc_set_exposures (gximage->gc, TRUE);
} }
gdk_draw_rgb_image (win, gdk_draw_rgb_image_dithalign (win,
gximage->gc, gximage->gc,
x, x,
y, y,
w, w,
h, h,
GDK_RGB_DITHER_MAX, /* todo: make configurable */ /* todo: make configurable */
GDK_RGB_DITHER_MAX,
gximage->data, gximage->data,
GXIMAGE_WIDTH * 3); GXIMAGE_WIDTH * 3,
xdith, ydith);
} }

View File

@ -24,7 +24,8 @@
void gximage_init (void); void gximage_init (void);
void gximage_free (void); void gximage_free (void);
void gximage_put (GdkWindow *, int, int, int, int); void
gximage_put (GdkWindow *win, int x, int y, int w, int h, int xdith, int ydith);
guchar* gximage_get_data (void); guchar* gximage_get_data (void);
int gximage_get_bpp (void); int gximage_get_bpp (void);
int gximage_get_bpl (void); int gximage_get_bpl (void);

View File

@ -73,6 +73,45 @@ color_area_target (int x,
return -1; return -1;
} }
void
color_area_draw_rect (GdkDrawable *drawable,
GdkGC *gc,
gint x, gint y, gint width, gint height,
unsigned char r, unsigned char g, unsigned char b)
{
static unsigned char *color_area_rgb_buf = NULL;
static gint color_area_rgb_buf_size;
static gint rowstride;
gint xx, yy;
unsigned char *bp;
rowstride = 3 * ((width + 3) & -4);
if (color_area_rgb_buf == NULL ||
color_area_rgb_buf_size < height * rowstride)
{
if (color_area_rgb_buf)
g_free (color_area_rgb_buf);
color_area_rgb_buf = g_malloc (rowstride * height);
}
bp = color_area_rgb_buf;
for (xx = 0; xx < width; xx++)
{
*bp++ = r;
*bp++ = g;
*bp++ = b;
}
bp = color_area_rgb_buf;
for (yy = 1; yy < height; yy++)
{
bp += rowstride;
memcpy (bp, color_area_rgb_buf, rowstride);
}
gdk_draw_rgb_image (drawable, gc, x, y, width, height,
GDK_RGB_DITHER_MAX,
color_area_rgb_buf,
rowstride);
}
static void static void
color_area_draw (void) color_area_draw (void)
{ {
@ -82,6 +121,7 @@ color_area_draw (void)
int width, height; int width, height;
int def_width, def_height; int def_width, def_height;
int swap_width, swap_height; int swap_width, swap_height;
unsigned char r, g, b;
/* Check we haven't gotten initial expose yet, /* Check we haven't gotten initial expose yet,
* no point in drawing anything */ * no point in drawing anything */
@ -102,9 +142,16 @@ color_area_draw (void)
gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1, gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1,
0, 0, width, height); 0, 0, width, height);
#ifdef OLD_COLOR_AREA
gdk_gc_set_foreground (color_area_gc, &bg); gdk_gc_set_foreground (color_area_gc, &bg);
gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1, gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1,
(width - rect_w), (height - rect_h), rect_w, rect_h); (width - rect_w), (height - rect_h), rect_w, rect_h);
#else
palette_get_background (&r, &g, &b);
color_area_draw_rect (color_area_pixmap, color_area_gc,
(width - rect_w), (height - rect_h), rect_w, rect_h,
r, g, b);
#endif
if (active_color == FOREGROUND) if (active_color == FOREGROUND)
gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_OUT, gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_OUT,
@ -113,9 +160,16 @@ color_area_draw (void)
gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN, gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN,
(width - rect_w), (height - rect_h), rect_w, rect_h); (width - rect_w), (height - rect_h), rect_w, rect_h);
#ifdef OLD_COLOR_AREA
gdk_gc_set_foreground (color_area_gc, &fg); gdk_gc_set_foreground (color_area_gc, &fg);
gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1, gdk_draw_rectangle (color_area_pixmap, color_area_gc, 1,
0, 0, rect_w, rect_h); 0, 0, rect_w, rect_h);
#else
palette_get_foreground (&r, &g, &b);
color_area_draw_rect (color_area_pixmap, color_area_gc,
0, 0, rect_w, rect_h,
r, g, b);
#endif
if (active_color == FOREGROUND) if (active_color == FOREGROUND)
gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN, gtk_draw_shadow (color_area->style, color_area_pixmap, GTK_STATE_NORMAL, GTK_SHADOW_IN,

View File

@ -28,9 +28,17 @@ GtkWidget * color_area_create (int width,
GdkPixmap *swap_pixmap); GdkPixmap *swap_pixmap);
void color_area_update (void); void color_area_update (void);
/* Exported for use by color_select */
void
color_area_draw_rect (GdkDrawable *drawable,
GdkGC *gc,
gint x, gint y, gint width, gint height,
unsigned char r, unsigned char g, unsigned char b);
/* /*
* Global variables * Global variables
*/ */
extern int active_color; /* foreground (= 0) or background (= 1) */ extern int active_color; /* foreground (= 0) or background (= 1) */
#endif /* __COLOR_AREA_H__ */ #endif /* __COLOR_AREA_H__ */

View File

@ -24,6 +24,7 @@
#include "errors.h" #include "errors.h"
#include "gimprc.h" #include "gimprc.h"
#include "session.h" #include "session.h"
#include "color_area.h" /* for color_area_draw_rect */
#define XY_DEF_WIDTH 240 #define XY_DEF_WIDTH 240
#define XY_DEF_HEIGHT 240 #define XY_DEF_HEIGHT 240
@ -787,9 +788,15 @@ color_select_update_colors (ColorSelectP csp,
if (csp->gc) if (csp->gc)
{ {
#ifdef OLD_COLOR_AREA
gdk_gc_set_foreground (csp->gc, &color); gdk_gc_set_foreground (csp->gc, &color);
gdk_draw_rectangle (window, csp->gc, 1, gdk_draw_rectangle (window, csp->gc, 1,
0, 0, width, height); 0, 0, width, height);
#else
color_area_draw_rect (window, csp->gc,
0, 0, width, height,
red, green, blue);
#endif
} }
} }
} }