DataMuseum.dk

Presents historical artifacts from the history of:

DKUUG/EUUG Conference tapes

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about DKUUG/EUUG Conference tapes

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - download
Index: ┃ T c

⟦5263e4e3f⟧ TextFile

    Length: 1496 (0x5d8)
    Types: TextFile
    Names: »calcmap.c«

Derivation

└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki
    └─ ⟦526ad3590⟧ »EUUGD11/gnu-31mar87/X.V10.R4.tar.Z« 
        └─⟦2109abc41⟧ 
            └─ ⟦this⟧ »./X.V10R4/showimg/calcmap.c« 

TextFile

/* Calculates gray scale based on mouse offset from window center */
#include <X/Xlib.h>

#ifdef MC68000
#include <sys/types.h>
#endif

#include "shimg.h"
   
#define MIN(a,b) (((a) < (b)) ? (a) : (b))
#define MAX(a,b) (((a) > (b)) ? (a) : (b))

CalcMap(winfo,cmap,x,y,ncolors,flags,key)
	WindowInfo *winfo;
	Color *cmap;
	int x,y, key;
	int ncolors;
	u_short flags;
{
	register int intercept,slope,intensity,i;

	if(x<0 || y<=0 || x>=winfo->width-2 || y>winfo->height) return;

	intercept = (((x<<1) - winfo->width)<<16) / winfo->width;
	slope = ((winfo->height - y)<<16) / y;

	for(i=0; i<ncolors; i++) {
		intensity = (slope * i)/(ncolors-1) + intercept;
		intensity = MIN(65535,MAX(intensity,0));
		if(flags & VOP_Inverse)  intensity = 65535 - intensity;
		if(flags & VOP_RGB) 
		    switch((int)key) {
			case LeftButton:
				cmap[i].red = intensity; break;
			case MiddleButton:
				cmap[i].green = intensity; break;
			case RightButton:
				cmap[i].blue = intensity; break;
		    }
		else {
		    cmap[i].red = cmap[i].blue = cmap[i].green = intensity;
		}
	}
	return;
}

initcmap(ncolors,cmap,pixel,nplanes,flags)
     int ncolors, nplanes, pixel;
     Color *cmap;
     unsigned short flags;
{
     int i;

/* Initialize color map to slope 1, intercept 0 */
     for (i = 0; i < ncolors; i++) {
	cmap[i].pixel = pixel + i;
	cmap[i].red = cmap[i].green = cmap[i].blue =
	    ( (flags & VOP_Inverse) ? (65535 - (i << (16 - nplanes))) :
	      (i << (16 - nplanes)));
     }
     return;
}