Blob Blame History Raw
/*
 * $Id: getcolor.h,v 1.10 2010/10/06 00:19:50 sfeam Exp $
 */

/* GNUPLOT - getcolor.h */

/* Routines + constants for mapping interval [0,1] into another [0,1] to be
 * used to get RGB triplets from gray (palette of smooth colours).
 *
 * Note: The code in getcolor.h,.c cannot be inside color.h,.c since gplt_x11.c
 * compiles with getcolor.o, so it cannot load the other huge staff.
 *
 */

/*[
 *
 * Petr Mikulik, since December 1998
 * Copyright: open source as much as possible
 *
]*/


#ifndef GETCOLOR_H
#define GETCOLOR_H

#include "syscfg.h"
#include "color.h"

enum color_models_id {
    C_MODEL_RGB = 'r',
    C_MODEL_HSV = 'h',
    C_MODEL_CMY = 'c',
    C_MODEL_XYZ = 'x'
};


/* main gray --> rgb color mapping */
void rgb1_from_gray __PROTO(( double gray, rgb_color *color ));
void rgb255_from_rgb1 __PROTO(( rgb_color rgb1, rgb255_color *rgb255 ));
/* main gray --> rgb color mapping as above, with take care of palette maxcolors */
void rgb1maxcolors_from_gray __PROTO(( double gray, rgb_color *color ));
void rgb255maxcolors_from_gray __PROTO(( double gray, rgb255_color *rgb255 ));
double quantize_gray __PROTO(( double gray ));

/* HSV --> RGB user-visible function hsv2rgb(h,s,v) */
unsigned int hsv2rgb __PROTO(( rgb_color *color ));

/* used to (de-)serialize color/gradient information */
char *gradient_entry_to_str __PROTO(( gradient_struct *gs ));
void str_to_gradient_entry __PROTO(( char *s, gradient_struct *gs ));

/* check if two palettes p1 and p2 differ */
int palettes_differ __PROTO(( t_sm_palette *p1, t_sm_palette *p2 ));

/* construct minimal gradient to approximate palette */
gradient_struct *approximate_palette __PROTO(( t_sm_palette *palette, int maxsamples, double allowed_deviation, int *gradient_num ));

double GetColorValueFromFormula __PROTO((int formula, double x));

extern const char *ps_math_color_formulae[];

#endif /* GETCOLOR_H */

/* eof getcolor.h */