Blame src/Distinct.c

Packit cd2a55
/*
Packit cd2a55
Packit cd2a55
Copyright 1990, 1998  The Open Group
Packit cd2a55
Packit cd2a55
Permission to use, copy, modify, distribute, and sell this software and its
Packit cd2a55
documentation for any purpose is hereby granted without fee, provided that
Packit cd2a55
the above copyright notice appear in all copies and that both that
Packit cd2a55
copyright notice and this permission notice appear in supporting
Packit cd2a55
documentation.
Packit cd2a55
Packit cd2a55
The above copyright notice and this permission notice shall be included in
Packit cd2a55
all copies or substantial portions of the Software.
Packit cd2a55
Packit cd2a55
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Packit cd2a55
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Packit cd2a55
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
Packit cd2a55
OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
Packit cd2a55
AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
Packit cd2a55
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Packit cd2a55
Packit cd2a55
Except as contained in this notice, the name of The Open Group shall not be
Packit cd2a55
used in advertising or otherwise to promote the sale, use or other dealings
Packit cd2a55
in this Software without prior written authorization from The Open Group.
Packit cd2a55
Packit cd2a55
*/
Packit cd2a55
Packit cd2a55
/*
Packit cd2a55
 * Author:  Keith Packard, MIT X Consortium
Packit cd2a55
 */
Packit cd2a55
Packit cd2a55
#ifdef HAVE_CONFIG_H
Packit cd2a55
#include <config.h>
Packit cd2a55
#endif
Packit cd2a55
#include <X11/Xlib.h>
Packit cd2a55
#include <stdlib.h>
Packit cd2a55
#include <X11/Xutil.h>
Packit cd2a55
#include <X11/Xmu/StdCmap.h>
Packit cd2a55
Packit cd2a55
/*
Packit cd2a55
 * Distinguishable colors routine.  Determines if two colors are
Packit cd2a55
 * distinguishable or not.  Somewhat arbitrary meaning.
Packit cd2a55
 */
Packit cd2a55
Packit cd2a55
#define MIN_DISTINGUISH	10000.0
Packit cd2a55
Packit cd2a55
Bool
Packit cd2a55
XmuDistinguishableColors(XColor	*colors, int count)
Packit cd2a55
{
Packit cd2a55
    double	    deltaRed, deltaGreen, deltaBlue;
Packit cd2a55
    double	    dist;
Packit cd2a55
    int		    i, j;
Packit cd2a55
Packit cd2a55
    for (i = 0; i < count - 1; i++)
Packit cd2a55
	for (j = i + 1; j < count; j++)
Packit cd2a55
	{
Packit cd2a55
     	    deltaRed = (double)colors[i].red - (double)colors[j].red;
Packit cd2a55
    	    deltaGreen = (double)colors[i].green - (double)colors[j].green;
Packit cd2a55
    	    deltaBlue = (double)colors[i].blue - (double)colors[j].blue;
Packit cd2a55
    	    dist = deltaRed * deltaRed +
Packit cd2a55
	       	   deltaGreen * deltaGreen +
Packit cd2a55
 	       	   deltaBlue * deltaBlue;
Packit cd2a55
	    if (dist <= MIN_DISTINGUISH * MIN_DISTINGUISH)
Packit cd2a55
		return False;
Packit cd2a55
	}
Packit cd2a55
    return True;
Packit cd2a55
}
Packit cd2a55
Packit cd2a55
Bool
Packit cd2a55
XmuDistinguishablePixels(Display *dpy, Colormap cmap,
Packit cd2a55
			 unsigned long *pixels, int  count)
Packit cd2a55
{
Packit cd2a55
    XColor  *defs;
Packit cd2a55
    int	    i, j;
Packit cd2a55
    Bool    ret;
Packit cd2a55
Packit cd2a55
    for (i = 0; i < count - 1; i++)
Packit cd2a55
	for (j = i + 1; j < count; j++)
Packit cd2a55
	    if (pixels[i] == pixels[j])
Packit cd2a55
		return False;
Packit cd2a55
    defs = (XColor *) malloc (count * sizeof (XColor));
Packit cd2a55
    if (!defs)
Packit cd2a55
	return False;
Packit cd2a55
    for (i = 0; i < count; i++)
Packit cd2a55
	defs[i].pixel = pixels[i];
Packit cd2a55
    XQueryColors (dpy, cmap, defs, count);
Packit cd2a55
    ret = XmuDistinguishableColors (defs, count);
Packit cd2a55
    free ((char *) defs);
Packit cd2a55
    return ret;
Packit cd2a55
}