11ab64890Smrg 21ab64890Smrg/* 31ab64890Smrg * Code and supporting documentation (c) Copyright 1990 1991 Tektronix, Inc. 41ab64890Smrg * All Rights Reserved 561b2299dSmrg * 61ab64890Smrg * This file is a component of an X Window System-specific implementation 71ab64890Smrg * of Xcms based on the TekColor Color Management System. Permission is 81ab64890Smrg * hereby granted to use, copy, modify, sell, and otherwise distribute this 91ab64890Smrg * software and its documentation for any purpose and without fee, provided 101ab64890Smrg * that this copyright, permission, and disclaimer notice is reproduced in 111ab64890Smrg * all copies of this software and in supporting documentation. TekColor 121ab64890Smrg * is a trademark of Tektronix, Inc. 1361b2299dSmrg * 141ab64890Smrg * Tektronix makes no representation about the suitability of this software 151ab64890Smrg * for any purpose. It is provided "as is" and with all faults. 1661b2299dSmrg * 171ab64890Smrg * TEKTRONIX DISCLAIMS ALL WARRANTIES APPLICABLE TO THIS SOFTWARE, 181ab64890Smrg * INCLUDING THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A 191ab64890Smrg * PARTICULAR PURPOSE. IN NO EVENT SHALL TEKTRONIX BE LIABLE FOR ANY 201ab64890Smrg * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER 211ab64890Smrg * RESULTING FROM LOSS OF USE, DATA, OR PROFITS, WHETHER IN AN ACTION OF 221ab64890Smrg * CONTRACT, NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN 231ab64890Smrg * CONNECTION WITH THE USE OR THE PERFORMANCE OF THIS SOFTWARE. 241ab64890Smrg * 251ab64890Smrg * 261ab64890Smrg * NAME 271ab64890Smrg * XcmsRtoX.c 281ab64890Smrg * 291ab64890Smrg * DESCRIPTION 301ab64890Smrg * Convert color specifications in XcmsRGB format in one array of 311ab64890Smrg * XcmsColor structures to RGB in an array of XColor structures. 321ab64890Smrg * 331ab64890Smrg * 341ab64890Smrg */ 351ab64890Smrg 361ab64890Smrg#ifdef HAVE_CONFIG_H 371ab64890Smrg#include <config.h> 381ab64890Smrg#endif 391ab64890Smrg#include "Xlibint.h" 401ab64890Smrg#include "Xcmsint.h" 411ab64890Smrg#include "Cv.h" 421ab64890Smrg 431ab64890Smrg/* 441ab64890Smrg * LOCAL VARIABLES 451ab64890Smrg */ 461ab64890Smrg 471ab64890Smrgstatic unsigned short const MASK[17] = { 481ab64890Smrg 0x0000, /* 0 bitsPerRGB */ 491ab64890Smrg 0x8000, /* 1 bitsPerRGB */ 501ab64890Smrg 0xc000, /* 2 bitsPerRGB */ 511ab64890Smrg 0xe000, /* 3 bitsPerRGB */ 521ab64890Smrg 0xf000, /* 4 bitsPerRGB */ 531ab64890Smrg 0xf800, /* 5 bitsPerRGB */ 541ab64890Smrg 0xfc00, /* 6 bitsPerRGB */ 551ab64890Smrg 0xfe00, /* 7 bitsPerRGB */ 561ab64890Smrg 0xff00, /* 8 bitsPerRGB */ 571ab64890Smrg 0xff80, /* 9 bitsPerRGB */ 581ab64890Smrg 0xffc0, /* 10 bitsPerRGB */ 591ab64890Smrg 0xffe0, /* 11 bitsPerRGB */ 601ab64890Smrg 0xfff0, /* 12 bitsPerRGB */ 611ab64890Smrg 0xfff8, /* 13 bitsPerRGB */ 621ab64890Smrg 0xfffc, /* 14 bitsPerRGB */ 631ab64890Smrg 0xfffe, /* 15 bitsPerRGB */ 641ab64890Smrg 0xffff /* 16 bitsPerRGB */ 651ab64890Smrg}; 661ab64890Smrg 671ab64890Smrg 681ab64890Smrg 691ab64890Smrg/************************************************************************ 701ab64890Smrg * * 711ab64890Smrg * API PRIVATE ROUTINES * 721ab64890Smrg * * 731ab64890Smrg ************************************************************************/ 741ab64890Smrg 751ab64890Smrg/* 761ab64890Smrg * NAME 7761b2299dSmrg * _XcmsRGB_to_XColor - 781ab64890Smrg * 791ab64890Smrg * SYNOPSIS 801ab64890Smrg */ 811ab64890Smrgvoid 821ab64890Smrg_XcmsRGB_to_XColor( 831ab64890Smrg XcmsColor *pColors, 841ab64890Smrg XColor *pXColors, 851ab64890Smrg unsigned int nColors) 861ab64890Smrg/* 871ab64890Smrg * DESCRIPTION 881ab64890Smrg * Translates a color specification in XcmsRGBFormat in a XcmsColor 891ab64890Smrg * structure to an XColor structure. 901ab64890Smrg * 911ab64890Smrg * RETURNS 921ab64890Smrg * void. 931ab64890Smrg */ 941ab64890Smrg{ 951ab64890Smrg for (; nColors--; pXColors++, pColors++) { 961ab64890Smrg pXColors->pixel = pColors->pixel; 971ab64890Smrg pXColors->red = pColors->spec.RGB.red; 981ab64890Smrg pXColors->green = pColors->spec.RGB.green; 991ab64890Smrg pXColors->blue = pColors->spec.RGB.blue; 1001ab64890Smrg pXColors->flags = (DoRed | DoGreen | DoBlue); 1011ab64890Smrg } 1021ab64890Smrg} 1031ab64890Smrg 1041ab64890Smrg 1051ab64890Smrg/* 1061ab64890Smrg * NAME 1071ab64890Smrg * _XColor_to_XcmsRGB 1081ab64890Smrg * 1091ab64890Smrg * SYNOPSIS 1101ab64890Smrg */ 1111ab64890Smrgvoid 1121ab64890Smrg_XColor_to_XcmsRGB( 1131ab64890Smrg XcmsCCC ccc, 1141ab64890Smrg XColor *pXColors, 1151ab64890Smrg XcmsColor *pColors, 1161ab64890Smrg unsigned int nColors) 1171ab64890Smrg/* 1181ab64890Smrg * DESCRIPTION 1191ab64890Smrg * Translates an RGB color specification in an XColor 1201ab64890Smrg * structure to an XcmsRGB structure. 1211ab64890Smrg * 1221ab64890Smrg * IMPORTANT NOTE: Bit replication that may have been caused 1231ab64890Smrg * with ResolveColor() routine in the X Server is undone 1241ab64890Smrg * here if requested! For example, if red = 0xcaca and the 1251ab64890Smrg * bits_per_rgb is 8, then spec.RGB.red will be 0xca00. 1261ab64890Smrg * 1271ab64890Smrg * RETURNS 1281ab64890Smrg * void 1291ab64890Smrg */ 1301ab64890Smrg{ 1311ab64890Smrg int bits_per_rgb = ccc->visual->bits_per_rgb; 1321ab64890Smrg 1331ab64890Smrg for (; nColors--; pXColors++, pColors++) { 1341ab64890Smrg pColors->spec.RGB.red = (pXColors->red & MASK[bits_per_rgb]); 1351ab64890Smrg pColors->spec.RGB.green = (pXColors->green & MASK[bits_per_rgb]); 1361ab64890Smrg pColors->spec.RGB.blue = (pXColors->blue & MASK[bits_per_rgb]); 1371ab64890Smrg pColors->format = XcmsRGBFormat; 1381ab64890Smrg pColors->pixel = pXColors->pixel; 1391ab64890Smrg } 1401ab64890Smrg} 1411ab64890Smrg 1421ab64890Smrg 1431ab64890Smrg/* 1441ab64890Smrg * NAME 1451ab64890Smrg * _XcmsResolveColor 1461ab64890Smrg * 1471ab64890Smrg * SYNOPSIS 1481ab64890Smrg */ 1491ab64890Smrgvoid 1501ab64890Smrg_XcmsResolveColor( 1511ab64890Smrg XcmsCCC ccc, 1521ab64890Smrg XcmsColor *pXcmsColor) 1531ab64890Smrg/* 1541ab64890Smrg * DESCRIPTION 1551ab64890Smrg * Uses the X Server ResolveColor() algorithm to 1561ab64890Smrg * modify values to closest values supported by hardware. 1571ab64890Smrg * Old algorithm simply masked low-order bits. The new algorithm 1581ab64890Smrg * has the effect of replicating significant bits into lower order 1591ab64890Smrg * bits in order to stretch the hardware value into all 16 bits. 1601ab64890Smrg * 1611ab64890Smrg * On a display with N-bit DACs, the "hardware" color is computed as: 1621ab64890Smrg * 1631ab64890Smrg * ((unsignedlong)(ClientValue >> (16-N)) * 0xFFFF) / ((1 << N) - 1) 16461b2299dSmrg * 1651ab64890Smrg * 1661ab64890Smrg * RETURNS 1671ab64890Smrg * void. 1681ab64890Smrg */ 1691ab64890Smrg{ 1701ab64890Smrg int shift; 1711ab64890Smrg int max_color; 1721ab64890Smrg 1731ab64890Smrg shift = 16 - ccc->visual->bits_per_rgb; 1741ab64890Smrg max_color = (1 << ccc->visual->bits_per_rgb) - 1; 1751ab64890Smrg 1761ab64890Smrg 1771ab64890Smrg pXcmsColor->spec.RGB.red = 1781ab64890Smrg ((unsigned long)(pXcmsColor->spec.RGB.red >> shift) * 0xFFFF) 1791ab64890Smrg / max_color; 1801ab64890Smrg pXcmsColor->spec.RGB.green = 1811ab64890Smrg ((unsigned long)(pXcmsColor->spec.RGB.green >> shift) * 0xFFFF) 1821ab64890Smrg / max_color; 1831ab64890Smrg pXcmsColor->spec.RGB.blue = 1841ab64890Smrg ((unsigned long)(pXcmsColor->spec.RGB.blue >> shift) * 0xFFFF) 1851ab64890Smrg / max_color; 1861ab64890Smrg} 1871ab64890Smrg 1881ab64890Smrg 1891ab64890Smrg/* 1901ab64890Smrg * NAME 1911ab64890Smrg * _XcmsUnresolveColor 1921ab64890Smrg * 1931ab64890Smrg * SYNOPSIS 1941ab64890Smrg */ 1951ab64890Smrgvoid 1961ab64890Smrg_XcmsUnresolveColor( 1971ab64890Smrg XcmsCCC ccc, 1981ab64890Smrg XcmsColor *pColor) 1991ab64890Smrg/* 2001ab64890Smrg * DESCRIPTION 2011ab64890Smrg * Masks out insignificant bits. 2021ab64890Smrg * 2031ab64890Smrg * RETURNS 2041ab64890Smrg * void. 2051ab64890Smrg * 2061ab64890Smrg * ASSUMPTIONS 2071ab64890Smrg * format == XcmsRGBFormat 2081ab64890Smrg */ 2091ab64890Smrg{ 2101ab64890Smrg int bits_per_rgb = ccc->visual->bits_per_rgb; 2111ab64890Smrg 2121ab64890Smrg pColor->spec.RGB.red &= MASK[bits_per_rgb]; 2131ab64890Smrg pColor->spec.RGB.green &= MASK[bits_per_rgb]; 2141ab64890Smrg pColor->spec.RGB.blue &= MASK[bits_per_rgb]; 2151ab64890Smrg} 2161ab64890Smrg 2171ab64890Smrg 2181ab64890Smrg/* 2191ab64890Smrg * NAME 2201ab64890Smrg * _XUnresolveColor 2211ab64890Smrg * 2221ab64890Smrg * SYNOPSIS 2231ab64890Smrg */ 2241ab64890Smrgvoid 2251ab64890Smrg_XUnresolveColor( 2261ab64890Smrg XcmsCCC ccc, 2271ab64890Smrg XColor *pXColor) 2281ab64890Smrg/* 2291ab64890Smrg * DESCRIPTION 2301ab64890Smrg * Masks out insignificant bits. 2311ab64890Smrg * 2321ab64890Smrg * RETURNS 2331ab64890Smrg * void. 2341ab64890Smrg */ 2351ab64890Smrg{ 2361ab64890Smrg int bits_per_rgb = ccc->visual->bits_per_rgb; 2371ab64890Smrg 2381ab64890Smrg pXColor->red &= MASK[bits_per_rgb]; 2391ab64890Smrg pXColor->green &= MASK[bits_per_rgb]; 2401ab64890Smrg pXColor->blue &= MASK[bits_per_rgb]; 2411ab64890Smrg} 2421ab64890Smrg 243