aboutsummaryrefslogtreecommitdiff
path: root/generic/Color.h
blob: c7ac91e15e2ea51b2e3ffb5aebb6791daa48f911 (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
/*
 * 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 {
  int		position;	/* Color starting position along the gradient axis.
				 * This is in percent of the gradient total size. */
  int		control;	/* Middle-shade position in percent of this color
				 * size along the gradient axis. */
  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 {
  Screen	*screen;	/* Screen on which the gradient will be used. */
  Visual	*visual;	/* Visual for all windows and pixmaps using
				 * the gradient. */
  int		depth;		/* Number of bits per pixel of drawables where
				 * the gradient will be used. */
  Colormap	colormap;	/* Colormap out of which pixels are allocated. */
  int		ref_count;
  Tcl_HashEntry	*hash;
  ZnBool	realized;
  char		type;		/* Either ZN_AXIAL_GRADIENT (lines) or
				 * ZN_RADIAL_GRADIENT (circles). */
  union {
    int		angle;		/* Angle spec for an axial gradient (Degrees). */
    struct {
      int	x;		/* Center for a radial gradiant (percent of */
      int	y;		/* area size). */
    } c;
  } 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);
char *ZnNameOfGradient(ZnGradient *gradient);
void ZnFreeGradient(ZnGradient *gradient);
void ZnRealizeGradient(ZnGradient *grad, Tk_Window tkwin);


#endif /* _Color_h */