43 lines
1.3 KiB
C
43 lines
1.3 KiB
C
/* @(#)cms.h 1.1 94/10/31 SMI */
|
|
|
|
/*
|
|
* Copyright (c) 1983 by Sun Microsystems, Inc.
|
|
*/
|
|
|
|
/*
|
|
* A colormapseg is a segment of a colormap that was allocated
|
|
* to a user process. It is used to multiplex a colormap in a
|
|
* shared resource environment, i.e., multi-windows & multi-processes.
|
|
*
|
|
* The cms_addr serves as a base address of a pixel. Cms_addr is added
|
|
* with pixel values to get the true value of the colormap index.
|
|
* The value of a colormap entry is translated to the video signal that
|
|
* is sent to a monitor for a single pixel.
|
|
*
|
|
* Cms_size and cms_addr can be used by low level routines to provide some
|
|
* protection from using a part of the colormap not allocated to the cms
|
|
* by doing a bounds check on the pixel that is to be written.
|
|
*
|
|
* Cms_map is a structure that has pointers to the bytes of rgb for
|
|
* a corresponding colormapseg. The choice of this format enables
|
|
* fast read/write to most colormaps.
|
|
*/
|
|
|
|
#ifndef cms_DEFINED
|
|
|
|
#define cms_DEFINED
|
|
|
|
#define CMS_NAMESIZE 20
|
|
|
|
struct colormapseg {
|
|
int cms_size; /* size of this segment of the map */
|
|
int cms_addr; /* colormap addr of start of segment */
|
|
char cms_name[CMS_NAMESIZE]; /* name segment of map (for sharing)*/
|
|
};
|
|
|
|
struct cms_map {
|
|
unsigned char *cm_red, *cm_green, *cm_blue;
|
|
};
|
|
|
|
#endif
|