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
|
/*
* Color.h -- Header for color routines.
*
* Authors : Patrick Lecoanet.
* Creation date : Thu Dec 16 15:41:04 1999
*
* $Id$
*/
/*
* Copyright (c) 1993 - 1999 CENA, Patrick Lecoanet --
*
* This code is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This code is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this code; if not, write to the Free
* Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*
*/
#ifndef _Color_h
#define _Color_h
#include "Types.h"
typedef struct _GradientColor {
unsigned char position; /* Color starting position along the gradient axis.
* This is in percent of the gradient total size. */
unsigned char control; /* Middle-shade position in percent of this color
* size along the gradient axis. */
unsigned char alpha;
XColor *shades[1]; /* The real shades used to draw this color segment.
* The number of shades is constant for all the colors
* of a given gradient and is setup in num_shades. */
} ZnGradientColor;
typedef struct _Gradient {
int ref_count;
Tcl_HashEntry *hash;
char type; /* Either ZN_AXIAL_GRADIENT (lines) or
* ZN_RADIAL_GRADIENT (circles). */
union {
int angle; /* Angle spec for an axial gradient (Degrees). */
ZnPoint p; /* Center for a radial gradiant. */
} g;
int num_shades; /* Number of shades used for each color */
int num_colors; /* Number of colors in gradient spec. */
ZnGradientColor *colors[1];
} ZnGradient;
XColor *ZnGetColor(Tcl_Interp *interp, Tk_Window tkwin, Tk_Uid name);
XColor *ZnGetColorByValue(Tk_Window tkwin, XColor *color);
char *ZnNameOfColor(XColor *color);
void ZnFreeColor(XColor *color);
ZnGradient *ZnGetGradient(Tcl_Interp *interp, Tk_Window tkwin,
Tk_Uid name);
ZnGradient *ZnGetGradientByValue(ZnGradient *gradient);
ZnGradient *ZnGetReliefGradient(Tcl_Interp *interp, Tk_Window tkwin,
Tk_Uid name);
ZnBool ZnGradientFlat(ZnGradient *grad);
XColor *ZnGetGradientColor(Tk_Window tkwin, ZnGradient *gradient,
ZnReal position, int *alpha);
char *ZnNameOfGradient(ZnGradient *gradient);
void ZnFreeGradient(ZnGradient *gradient);
#endif /* _Color_h */
|