File: HSLtoRGB.c

package info (click to toggle)
gridengine 6.2-4
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 51,532 kB
  • ctags: 51,172
  • sloc: ansic: 418,155; java: 37,080; sh: 22,593; jsp: 7,699; makefile: 5,292; csh: 4,244; xml: 2,901; cpp: 2,086; perl: 1,895; tcl: 1,188; lisp: 669; ruby: 642; yacc: 393; lex: 266
file content (78 lines) | stat: -rw-r--r-- 1,825 bytes parent folder | download | duplicates (3)
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
/* 
 * Motif Tools Library, Version 3.1
 * $Id$
 * 
 * Written by David Flanagan.
 * Copyright (c) 1992-2001 by David Flanagan.
 * All Rights Reserved.  See the file COPYRIGHT for details.
 * This is open source software.  See the file LICENSE for details.
 * There is no warranty for this software.  See NO_WARRANTY for details.
 *
 * $Log$
 * Revision 1.1.1.1  2001/07/18 11:06:02  root
 * Initial checkin.
 *
 * Revision 1.2  2001/06/12 16:25:28  andre
 * *** empty log message ***
 *
 *
 */

#include <Xmt/Xmt.h>

/*
 * RGB <--> HSL conversions were modified from code with the
 * following attributions;
 *
 *    A Fast HSL-to-RGB Transform
 *    by Ken Fishkin, Pixar Inc., January 1989.
 *    from "Graphics Gems", Academic Press, 1990
 */


/*
 * 0 <= h <= 359
 * 0 <= s,l <= 100
 * 0 <= r,g,b <= 65535
 */
#if NeedFunctionPrototypes
void XmtHSLToRGB(unsigned h, unsigned s, unsigned l,
		 unsigned *r, unsigned *g, unsigned *b)
#else
void XmtHSLToRGB(h, s, l, r, g, b)
unsigned int h;
unsigned int s;
unsigned int l;
unsigned int *r;
unsigned int *g;
unsigned int *b;
#endif
{
    int v;
    int m, sv, fract, vsf, mid1, mid2, sextant;

    v = (l < 50) ? (l * (s + 100) / 100) : (l + s - (l * s / 100));
    if (v <= 0) { *r = *g = *b = 0; return;}

    m = l + l - v;
    sv = 100 * (v - m) / v;

    sextant = h/60;
    fract = 100 * (h - (sextant * 60)) / 60;
    vsf = v * sv * fract / 10000;
    mid1 = m + vsf;
    mid2 = v - vsf;

    switch (sextant) {
	case 0: *r = v; *g = mid1; *b = m; break;
	case 1: *r = mid2; *g = v; *b = m; break;
	case 2: *r = m; *g = v; *b = mid1; break;
	case 3: *r = m; *g = mid2; *b = v; break;
	case 4: *r = mid1; *g = m; *b = v; break;
	case 5: *r = v; *g = m; *b = mid2; break;
    }

    *r = (*r * 65535) / 100;
    *g = (*g * 65535) / 100;
    *b = (*b * 65535) / 100;
}