summaryrefslogtreecommitdiff
path: root/src/Xw/Xw_def_color.cxx
blob: 0dadee29f089e087f5800d3fcacb3fef1bb48c82 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100

#include <Xw_Extension.h>

	/* ifdef then trace on */
#ifdef TRACE
#define TRACE_DEF_COLOR
#endif

/*
   XW_STATUS Xw_def_color(acolormap,index,r,g,b):
   XW_EXT_COLORMAP *acolormap
   int index ;		Color index 0 >= x < MAXCOLOR
   float r,g,b ;	Red,Green,Blue color value 0. >= x <= 1.

	Update Color Extended colormap index with the specified R,G,B values .

	Returns ERROR if BadColor Index
	Returns SUCCESS if Successful      

*/

#ifdef XW_PROTOTYPE
XW_STATUS Xw_def_color (void* acolormap,
			int index,float r,float g,float b)
#else
XW_STATUS Xw_def_color (acolormap,index,r,g,b)
void *acolormap;
int index ;
float r,g,b ;
#endif /*XW_PROTOTYPE*/
{
XW_EXT_COLORMAP *pcolormap = (XW_EXT_COLORMAP*)acolormap ;
XColor color ;
int cclass,isapproximate;
unsigned long pixel;
XW_STATUS status = XW_SUCCESS;

       if ( !Xw_isdefine_colorindex(pcolormap,index) ) {
	    /*ERROR*Bad Color Index*/
	    Xw_set_error(1,"Xw_def_color",&index) ;
	    return (XW_ERROR) ;
        }

	if( pcolormap->mapping == Xw_TOM_READONLY ) {
	  cclass = StaticColor;
	} else {
	  cclass = _CCLASS;
	}

	switch (cclass) {
	    
	    case TrueColor :
		Xw_get_color_pixel(pcolormap,r,g,b,&pixel,&isapproximate) ;
	    	break ;

	    case PseudoColor :
    		if( pcolormap->mapping == Xw_TOM_COLORCUBE ) {
		  int kindex;
        	  if( (_CGINFO.red_mult > 0) && (fabs(r-g) < 0.01) && (fabs(r-b) < 0.01) ) {
          	    kindex = (int)(0.5+r*_CGINFO.red_max)*_CGINFO.red_mult;
          	    if( _CINFO.red_max > 0 ) 
				kindex += (_CINFO.red_max+1)*(_CINFO.green_max+1)*(_CINFO.blue_max+1);
        	  } else if( _CINFO.red_mult > 0 ) {
          	    kindex = ((int)(0.5+r*_CINFO.red_max))*_CINFO.red_mult+
                            ((int)(0.5+g*_CINFO.green_max))*_CINFO.green_mult+
                            ((int)(0.5+b*_CINFO.blue_max))*_CINFO.blue_mult;
        	  } else if( _CGINFO.red_mult > 0 ) {
          	    float l = (r+g+b)/3.;
          	    kindex = (int)(0.5+l*_CGINFO.red_max)*_CGINFO.red_mult;
        	  } else {
          	    kindex = 0;
        	  }
		  pixel = _CINFO.base_pixel + kindex;
		} else {
		    color.pixel = pixel = pcolormap->pixels[index] ;
	            color.red   = (unsigned short) (r * 0xFFFF) ;
	            color.green = (unsigned short) (g * 0xFFFF) ;
	            color.blue  = (unsigned short) (b * 0xFFFF) ;
	            color.flags = DoRed|DoGreen|DoBlue ;
	            XStoreColor(_CDISPLAY,_CINFO.colormap,&color) ;
		}
	    	break ;

	    case StaticColor :
	        status = Xw_alloc_color(pcolormap,r,g,b,&pixel,&isapproximate) ;
	    	break ;
	}

	if( status ) {
          pcolormap->define[index] = USERCOLOR ;
	  pcolormap->pixels[index] = pixel ;
	}

#ifdef TRACE_DEF_COLOR
if( Xw_get_trace() ) {
    printf(" %d = Xw_def_color(%lx,%d,%f,%f,%f)\n",status,(long ) pcolormap,index,r,g,b) ;
}
#endif
    return (status);
}