[Xr] API questions

Bill Spitzak spitzak at d2.com
Mon Jun 9 10:43:27 PDT 2003


On Sunday 08 June 2003 07:32 am, Damien Genet wrote:

> Do you also intend to offer non RGB color spaces ?

I would recommend that Xr offer only sRGB. (see www.srgb.org for details) As 
soon as you introduce other color spaces you end up with useless complexity 
as any such conversion can be done by a program before calling Xr. You also 
confuse programmers, who will then waste lots of time trying to figure out 
which of the color spaces is "best" or "fastest". Just offer one interface 
and avoid all this mess.

The reason for sRGB is that it is extremely easy to simulate it with 
reasonable accuracy on all current hardware, as storing it in 8 bits into a 
frame buffer is pretty accurate on everything made today, and all new 
hardware (ie lcd screens, digital cameras) is forced to conform to these 
standards so that it displays images correctly on existing systems. It also 
means that virtually all images are stored in sRGB and thus makes the 
conversion of an image to display in Xr trivial.

To allow devices to support any color space Xr does have to offer an 
interface that allows sRGB to be specified with values outside the 0-1 range. 
Not all interfaces need to, just for instance a floating-point one.

*maybe* the floating point interface should be in "linear sRGB". This is the 
same whitepoint and viewing conditions as sRGB, but does not include the 
gamma lookup function and thus luminance is in a linear relationship to the 
value. However I would not offer more than one floating-point interface, so 
whether it is better to do this or offer the consistency of sRGB for all 
interfaces is debatable.

I would like to see an interface that allows a color+alpha to be specified by 
a single 32-bit number, with 8 bits of each channel in sRGB. This would cover 
about 90% of the needs of programs to specify colors.

-- 
                   ,~,~,~,~ ~ ~ ~ ~
     /\_       _|_========___         Bill Spitzak
 ~~~/\/\\~~~~~~\____________/~~~~~~~~ spitzak at d2.com




More information about the cairo mailing list