aboutsummaryrefslogtreecommitdiff
path: root/generic/Color.h
blob: 3eedf4dc4d0128d2b68fa10411f38f9f487922de (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
/*
 * 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;		/* The color alpha channel in percent */
  unsigned char	mid_alpha;
  XColor	*rgb;		/* The actual color description */
  XColor	*mid_rgb;
} 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_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, int alpha);
ZnBool ZnGradientFlat(ZnGradient *grad);
XColor *ZnGetGradientColor(ZnGradient *gradient,
			   ZnReal position, int *alpha);
char *ZnNameOfGradient(ZnGradient *gradient);
void ZnFreeGradient(ZnGradient *gradient);
void ZnDeleteGradientName(char *name);
ZnBool ZnGradientNameExists(char *name);
ZnBool ZnNameGradient(Tcl_Interp *interp, Tk_Window tkwin,
		      char *grad_descr, char *name);
int ZnComposeAlpha(int alpha1, int alpha2);

#endif /* _Color_h */