Now correctly draws XPM files with 16-bit color indexes.

git-svn-id: file:///fltk/svn/fltk/branches/branch-1.0@674 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
Bill Spitzak 1999-08-25 05:37:40 +00:00
parent 138c7287b2
commit 6b07587d74
2 changed files with 61 additions and 38 deletions

View File

@ -1,5 +1,5 @@
# #
# "$Id: Makefile,v 1.10.2.2 1999/04/19 14:01:23 mike Exp $" # "$Id: Makefile,v 1.10.2.3 1999/08/25 05:37:38 bill Exp $"
# #
# Fluid makefile for the Fast Light Tool Kit (FLTK). # Fluid makefile for the Fast Light Tool Kit (FLTK).
# #
@ -59,7 +59,7 @@ include ../makeinclude
$(CXX) -I.. $(CXXFLAGS) -o $@ $< -L../lib -lfltk $(LDLIBS) $(CXX) -I.. $(CXXFLAGS) -o $@ $< -L../lib -lfltk $(LDLIBS)
$(PROGRAM) : $(OBJECTS) ../lib/$(LIBNAME) $(PROGRAM) : $(OBJECTS) ../lib/$(LIBNAME)
$(CXX) $(CXXFLAGS) -o $(PROGRAM) $(OBJECTS) -L../lib -lfltk $(LDLIBS) $(CXX) $(LDFLAGS) -o $(PROGRAM) $(OBJECTS) -L../lib -lfltk $(LDLIBS)
clean : clean :
-@ rm -f *.o $(PROGRAM) $(CLEAN) core *~ makedepend -@ rm -f *.o $(PROGRAM) $(CLEAN) core *~ makedepend
@ -91,5 +91,5 @@ rebuild:
./fluid -c widget_panel.fl ./fluid -c widget_panel.fl
# #
# End of "$Id: Makefile,v 1.10.2.2 1999/04/19 14:01:23 mike Exp $". # End of "$Id: Makefile,v 1.10.2.3 1999/08/25 05:37:38 bill Exp $".
# #

View File

@ -1,5 +1,5 @@
// //
// "$Id: fl_draw_pixmap.cxx,v 1.4.2.1 1999/07/27 17:24:13 bill Exp $" // "$Id: fl_draw_pixmap.cxx,v 1.4.2.2 1999/08/25 05:37:40 bill Exp $"
// //
// Pixmap drawing code for the Fast Light Tool Kit (FLTK). // Pixmap drawing code for the Fast Light Tool Kit (FLTK).
// //
@ -55,20 +55,23 @@ int fl_measure_pixmap(/*const*/char * const *data, int &w, int &h) {
// The callback from fl_draw_image to get a row of data passes this: // The callback from fl_draw_image to get a row of data passes this:
struct pixmap_data { struct pixmap_data {
int w, h; int w, h;
char*const* data; const uchar*const* data;
U64 colors[256]; union {
U64 colors[256];
U64* byte1[256];
};
}; };
// callback for 1 byte per pixel: // callback for 1 byte per pixel:
static void cb1(void*v, int x, int y, int w, uchar* buf) { static void cb1(void*v, int x, int y, int w, uchar* buf) {
pixmap_data& d = *(pixmap_data*)v; pixmap_data& d = *(pixmap_data*)v;
const char* p = d.data[y]+x; const uchar* p = d.data[y]+x;
U64* q = (U64*)buf; U64* q = (U64*)buf;
for (int X=(w+1)/2; X--; p += 2) { for (int X=(w+1)/2; X--; p += 2) {
#if WORDS_BIGENDIAN #if WORDS_BIGENDIAN
*q++ = (d.colors[p[0]&255]<<32) | d.colors[p[1]&255]; *q++ = (d.colors[p[0]]<<32) | d.colors[p[1]];
#else #else
*q++ = (d.colors[p[1]&255]<<32) | d.colors[p[0]&255]; *q++ = (d.colors[p[1]]<<32) | d.colors[p[0]];
#endif #endif
} }
} }
@ -76,15 +79,17 @@ static void cb1(void*v, int x, int y, int w, uchar* buf) {
// callback for 2 bytes per pixel: // callback for 2 bytes per pixel:
static void cb2(void*v, int x, int y, int w, uchar* buf) { static void cb2(void*v, int x, int y, int w, uchar* buf) {
pixmap_data& d = *(pixmap_data*)v; pixmap_data& d = *(pixmap_data*)v;
const char* p = d.data[y]+2*x; const uchar* p = d.data[y]+2*x;
U64* q = (U64*)buf; U64* q = (U64*)buf;
for (int X=(w+1)/2; X--;) { for (int X=(w+1)/2; X--;) {
int index = *p++; int t = *p++; index += (t<<4)+(t>>4); U64* colors = d.byte1[*p++];
int index1= *p++; t = *p++; index1 += (t<<4)+(t>>4); int index = *p++;
U64* colors1 = d.byte1[*p++];
int index1 = *p++;
#if WORDS_BIGENDIAN #if WORDS_BIGENDIAN
*q++ = (d.colors[index&255]<<32) | d.colors[index1&255]; *q++ = (colors[index]<<32) | colors1[index1];
#else #else
*q++ = (d.colors[index1&255]<<32) | d.colors[index&255]; *q++ = (colors1[index1]<<32) | colors[index];
#endif #endif
} }
} }
@ -94,26 +99,29 @@ static void cb2(void*v, int x, int y, int w, uchar* buf) {
// The callback from fl_draw_image to get a row of data passes this: // The callback from fl_draw_image to get a row of data passes this:
struct pixmap_data { struct pixmap_data {
int w, h; int w, h;
char*const* data; const uchar*const* data;
U32 colors[256]; union {
U32 colors[256];
U32* byte1[256];
};
}; };
// callback for 1 byte per pixel: // callback for 1 byte per pixel:
static void cb1(void*v, int x, int y, int w, uchar* buf) { static void cb1(void*v, int x, int y, int w, uchar* buf) {
pixmap_data& d = *(pixmap_data*)v; pixmap_data& d = *(pixmap_data*)v;
const char* p = d.data[y]+x; const uchar* p = d.data[y]+x;
U32* q = (U32*)buf; U32* q = (U32*)buf;
for (int X=w; X--;) *q++ = d.colors[(*p++)&255]; for (int X=w; X--;) *q++ = d.colors[*p++];
} }
// callback for 2 bytes per pixel: // callback for 2 bytes per pixel:
static void cb2(void*v, int x, int y, int w, uchar* buf) { static void cb2(void*v, int x, int y, int w, uchar* buf) {
pixmap_data& d = *(pixmap_data*)v; pixmap_data& d = *(pixmap_data*)v;
const char* p = d.data[y]+2*x; const uchar* p = d.data[y]+2*x;
U32* q = (U32*)buf; U32* q = (U32*)buf;
for (int X=w; X--;) { for (int X=w; X--;) {
int index = *p++; int t = *p++; index += (t<<4)+(t>>4); U32* colors = d.byte1[*p++];
*q++ = d.colors[index&255]; *q++ = colors[*p++];
} }
} }
@ -126,15 +134,15 @@ extern int fl_parse_color(const char*, uchar&, uchar&, uchar&);
uchar **fl_mask_bitmap; // if non-zero, create bitmap and store pointer here uchar **fl_mask_bitmap; // if non-zero, create bitmap and store pointer here
int fl_draw_pixmap(/*const*/char*const* data, int x, int y, Fl_Color bg) { int fl_draw_pixmap(/*const*/char*const* di, int x, int y, Fl_Color bg) {
pixmap_data d; pixmap_data d;
if (!fl_measure_pixmap(data, d.w, d.h)) return 0; if (!fl_measure_pixmap(di, d.w, d.h)) return 0;
data++; const uchar*const* data = (uchar**)(di+1);
int transparent_index = -1; int transparent_index = -1;
if (ncolors < 0) { // fltk (non standard) compressed colormap if (ncolors < 0) { // fltk (non standard) compressed colormap
ncolors = -ncolors; ncolors = -ncolors;
const char *p = *data++; const uchar *p = *data++;
// if first color is ' ' it is transparent (put it later to make // if first color is ' ' it is transparent (put it later to make
// it not be transparent): // it not be transparent):
if (*p == ' ') { if (*p == ' ') {
@ -152,7 +160,7 @@ int fl_draw_pixmap(/*const*/char*const* data, int x, int y, Fl_Color bg) {
} }
// read all the rest of the colors: // read all the rest of the colors:
for (int i=0; i < ncolors; i++) { for (int i=0; i < ncolors; i++) {
uchar* c = (uchar*)&d.colors[(*p++)&255]; uchar* c = (uchar*)&d.colors[*p++];
#ifdef U64 #ifdef U64
*(U64*)c = 0; *(U64*)c = 0;
#if WORDS_BIGENDIAN #if WORDS_BIGENDIAN
@ -165,15 +173,29 @@ int fl_draw_pixmap(/*const*/char*const* data, int x, int y, Fl_Color bg) {
*c = 0; *c = 0;
} }
} else { // normal XPM colormap with names } else { // normal XPM colormap with names
if (chars_per_pixel>1) memset(d.byte1, 0, sizeof(d.byte1));
for (int i=0; i<ncolors; i++) { for (int i=0; i<ncolors; i++) {
const char *p = *data++; const uchar *p = *data++;
// the first 1 or 2 characters are the color index: // the first 1 or 2 characters are the color index:
int index = *p++; int index = *p++;
if (chars_per_pixel>1) {int t = *p++; index += (t<<4)+(t>>4);} uchar* c;
if (chars_per_pixel>1) {
#ifdef U64
U64* colors = d.byte1[index];
if (!colors) colors = d.byte1[index] = new U64[256];
#else
U32* colors = d.byte1[index];
if (!colors) colors = d.byte1[index] = new U32[256];
#endif
c = (uchar*)&colors[*p];
index = (index<<8)+*p++;
} else {
c = (uchar *)&d.colors[index];
}
// look for "c word", or last word if none: // look for "c word", or last word if none:
const char *previous_word = p; const uchar *previous_word = p;
for (;;) { for (;;) {
while (*p && isspace(*p)) p++; char what = *p++; while (*p && isspace(*p)) p++; uchar what = *p++;
while (*p && !isspace(*p)) p++; while (*p && !isspace(*p)) p++;
while (*p && isspace(*p)) p++; while (*p && isspace(*p)) p++;
if (!*p) {p = previous_word; break;} if (!*p) {p = previous_word; break;}
@ -181,7 +203,6 @@ int fl_draw_pixmap(/*const*/char*const* data, int x, int y, Fl_Color bg) {
previous_word = p; previous_word = p;
while (*p && !isspace(*p)) p++; while (*p && !isspace(*p)) p++;
} }
uchar *c = (uchar *)&d.colors[index&255];
#ifdef U64 #ifdef U64
*(U64*)c = 0; *(U64*)c = 0;
#if WORDS_BIGENDIAN #if WORDS_BIGENDIAN
@ -192,13 +213,13 @@ int fl_draw_pixmap(/*const*/char*const* data, int x, int y, Fl_Color bg) {
if (fl_parse_color(p, c[0], c[1], c[2])) {; if (fl_parse_color(p, c[0], c[1], c[2])) {;
#else #else
XColor x; XColor x;
if (XParseColor(fl_display, fl_colormap, p, &x)) { if (XParseColor(fl_display, fl_colormap, (const char*)p, &x)) {
c[0] = x.red>>8; c[1] = x.green>>8; c[2] = x.blue>>8; c[0] = x.red>>8; c[1] = x.green>>8; c[2] = x.blue>>8;
#endif #endif
} else { // assumme "None" or "#transparent" for any errors } else { // assumme "None" or "#transparent" for any errors
// this should be transparent... // this should be transparent...
Fl::get_color(bg, c[0], c[1], c[2]); Fl::get_color(bg, c[0], c[1], c[2]);
transparent_index = index&255; transparent_index = index;
} }
} }
} }
@ -207,10 +228,10 @@ int fl_draw_pixmap(/*const*/char*const* data, int x, int y, Fl_Color bg) {
// build the mask bitmap used by Fl_Pixmap: // build the mask bitmap used by Fl_Pixmap:
if (fl_mask_bitmap && transparent_index >= 0) { if (fl_mask_bitmap && transparent_index >= 0) {
int W = (d.w+7)/8; int W = (d.w+7)/8;
uchar *bitmap = new uchar[W * d.h]; uchar* bitmap = new uchar[W * d.h];
*fl_mask_bitmap = bitmap; *fl_mask_bitmap = bitmap;
for (int y = 0; y < d.h; y++) { for (int y = 0; y < d.h; y++) {
uchar* p = (uchar*)data[y]; const uchar* p = data[y];
if (chars_per_pixel <= 1) { if (chars_per_pixel <= 1) {
for (int x = 0; x < W; x++) { for (int x = 0; x < W; x++) {
int b = (*p++ != transparent_index); int b = (*p++ != transparent_index);
@ -227,8 +248,9 @@ int fl_draw_pixmap(/*const*/char*const* data, int x, int y, Fl_Color bg) {
for (int x = 0; x < W; x++) { for (int x = 0; x < W; x++) {
int b = 0; int b = 0;
for (int i = 0; i < 8; i++) { for (int i = 0; i < 8; i++) {
int index = *p++; int t = *p++; index += (t<<4)+(t>>4); int index = *p++;
if ((index&255) != transparent_index) b |= (1<<i); index = (index<<8) | (*p++);
if (index != transparent_index) b |= (1<<i);
} }
*bitmap++ = b; *bitmap++ = b;
} }
@ -237,9 +259,10 @@ int fl_draw_pixmap(/*const*/char*const* data, int x, int y, Fl_Color bg) {
} }
fl_draw_image(chars_per_pixel==1 ? cb1 : cb2, &d, x, y, d.w, d.h, 4); fl_draw_image(chars_per_pixel==1 ? cb1 : cb2, &d, x, y, d.w, d.h, 4);
if (chars_per_pixel > 1) for (int i = 0; i < 256; i++) delete d.byte1[i];
return 1; return 1;
} }
// //
// End of "$Id: fl_draw_pixmap.cxx,v 1.4.2.1 1999/07/27 17:24:13 bill Exp $". // End of "$Id: fl_draw_pixmap.cxx,v 1.4.2.2 1999/08/25 05:37:40 bill Exp $".
// //