| 
 | 
	| 		|  |  | 
			
 Preface  Introduction  API Topic index  API Glossary  F.A.Q.  Copyright 
 
 | ASVisual | abstraction layer on top of X Visuals, focusing on color handling | 
 
 
 NAME
 asvisual
 - Defines abstraction layer on top of X Visuals, as well as 
several fundamental  color  datatypes.
SEE ALSO 
 Structures:
         ColorPair 
         ASScanline 
         ASVisual 
Functions :
   ASScanline  handling:
        prepare_scanline(), free_scanline()
   ASVisual  initialization :
        query_screen_visual(), setup_truecolor_visual(),
        setup_pseudo_visual(), setup_as_colormap(),create_asvisual(),
        destroy_asvisual()
   ASVisual  encoding/decoding :
        visual2visual_prop(), visual_prop2visual()
   ASVisual  convenience functions :
        create_visual_window(), create_visual_pixmap(),
        create_visual_ximage()
Other  libAfterImage  modules :
          ascmap .h  asfont .h  asimage .h  asvisual .h  blender .h  export .h
          import .h  transform .h  ximage .h
AUTHOR
 Sasha Vasko <sasha at aftercode dot net>
FUNCTION 
 Alpha channel adds visibility parameter to  color   value .
Alpha channel's  value  of 0xFF signifies complete visibility, while 0
makes pixel completely transparent.
SOURCE 
 
#define ALPHA_TRANSPARENT       0x00
#define ALPHA_SEMI_TRANSPARENT  0x7F
#define ALPHA_SOLID             0xFF
NAME
 ARGB32
 - main  color  datatype
FUNCTION 
  ARGB32  is fundamental datatype that hold 32bit  value  corresponding to
pixels  color  and transparency  value  (alpha channel) in ARGB
 colorspace . It is encoded as follows :
Lowermost 8 bits - Blue channel
bits 8 to 15     - Green channel
bits 16 to 23    - Red channel
bits 24 to 31    - Alpha channel
EXAMPLE 
  ASTile .1
SOURCE 
 
typedef CARD32  ARGB32 ;
#define ARGB32_White            0xFFFFFFFF
#define ARGB32_Black            0xFF000000
/* default  background   color  is #FF000000 : */
#define ARGB32_DEFAULT_BACK_COLOR   ARGB32_Black
#define ARGB32_ALPHA_CHAN       3
#define ARGB32_RED_CHAN         2
#define ARGB32_GREEN_CHAN       1
#define ARGB32_BLUE_CHAN        0
#define ARGB32_CHANNELS         4
#define MAKE_ARGB32(a,r,g,b)    ((( (CARD32)a)        <<24)| \
                                 ((((CARD32)r)&0x00FF)<<16)| \
                                 ((((CARD32)g)&0x00FF)<<8 )| \
                                 (( (CARD32)b)&0x00FF))
#define MAKE_ARGB32_GREY8(a,l)  (((a)<<24)|(((l)&0x00FF)<<16)| \
                                 (((l)&0x00FF)<<8)|((l)&0x00FF))
#define ARGB32_ALPHA8(c)        (((c)>>24)&0x00FF)
#define ARGB32_RED8(c)          (((c)>>16)&0x00FF)
#define ARGB32_GREEN8(c)        (((c)>>8 )&0x00FF)
#define ARGB32_BLUE8(c)         ( (c)     &0x00FF)
#define ARGB32_CHAN8(c,i)       (((c)>>((i)<<3))&0x00FF)
#define MAKE_ARGB32_CHAN8(v,i)  (((v)&0x0000FF)<<((i)<<3))
#define ARGB32_ALPHA16(c)       ((((c)>>16)&0x00FF00)|0x00FF)
#define ARGB32_RED16(c)         ((((c)>>8)&0x00FF00)|0x00FF)
#define ARGB32_GREEN16(c)       (( (c)    &0x00FF00)|0x00FF)
#define ARGB32_BLUE16(c)        ((((c)<<8)&0x00FF00)|0x00FF)
#define ARGB32_CHAN16(c,i)      ((ARGB32_CHAN8(c,i)<<8)|0x00FF)
#define MAKE_ARGB32_CHAN16(v,i) ((((v)&0x00FF00)>>8)<<((i)<<3))
 libAfterImage/ARGB32_manhattan_distance()NAME
 ARGB32_manhattan_distance()
 - This function can be used to evaluate closeness of 
two colors.
SYNOPSIS 
 long ARGB32_manhattan_distance (long a, long b);
INPUTS 
 RETURN VALUEa,b -  ARGB32   color  values to calculate Manhattan distance in between
 
 returns calculated Manhattan distance.
NAME IC_RED
 - red channel
IC_GREEN - green channel
IC_BLUE - blue channel
IC_ALPHA - alpha channel
IC_NUM_CHANNELS - number of supported channels
FUNCTION 
 Ids of the channels. These are basically synonyms to related  ARGB32 
channel numbers
SOURCE 
 
typedef enum
{
  IC_BLUE   = ARGB32_BLUE_CHAN ,
  IC_GREEN  = ARGB32_GREEN_CHAN,
  IC_RED    = ARGB32_RED_CHAN  ,
  IC_ALPHA  = ARGB32_ALPHA_CHAN,
  IC_NUM_CHANNELS = ARGB32_CHANNELS
}
ColorPart;
NAME
 ColorPair
 - convenient structure to hold pair of colors.
SOURCE 
 NAME
 ASScanline
 - structure to hold contents of the single scanline.
DESCRIPTION 
  ASScanline  holds data for the single scanline, split into channels
with 32 bits per pixel per channel. All the memory is allocated at
once, and then split in between channels. There are three ways to
access channel data :
1) using blue, green, red, alpha pointers.
2) using channels[] array of pointers - convenient in loops
4) using xc3, xc2, xc1 pointers. These are different from red, green,
blue in the way that xc3 will point to blue when BGR mode is specified
at the time of creation, otherwise it will point to red channel.
Likewise xc1 will point to red in BGR mode and blue otherwise.
xc2 always points to green channel's data. This is convenient while
writing XImages and when channels in source and destination has to be
reversed, while reading images from files.
Channel data is always aligned by 8 byte boundary allowing for
utilization of MMX, floating point and other 64bit registers for
transfer and processing.
SEE ALSO 
  ASImage 
SOURCE 
 
typedef struct  ASScanline 
{
#define SCL_DO_BLUE         (0x01<<ARGB32_BLUE_CHAN )
#define SCL_DO_GREEN        (0x01<<ARGB32_GREEN_CHAN)
#define SCL_DO_RED          (0x01<<ARGB32_RED_CHAN  )
#define SCL_DO_ALPHA        (0x01<<ARGB32_ALPHA_CHAN)
#define SCL_DO_COLOR        (SCL_DO_RED|SCL_DO_GREEN|SCL_DO_BLUE)
#define SCL_DO_ALL          (SCL_DO_RED|SCL_DO_GREEN|SCL_DO_BLUE| \
                             SCL_DO_ALPHA)
    CARD32         flags ;   /* combination of  the above values */
    CARD32        *buffer ;
    CARD32        *blue, *green, *red, *alpha ;
    CARD32        *channels[IC_NUM_CHANNELS];
    CARD32        *xc3, *xc2, *xc1; /* since some servers require
                                     * BGR mode here we  store  what
                                     * goes into what  color  component
                                     * in XImage */
     ARGB32          back_color;
    unsigned int   width, shift;
    unsigned int   offset_x ;
} ASScanline ;
 libAfterImage/prepare_scanline()NAME
 prepare_scanline()SYNOPSIS
 
  ASScanline  *prepare_scanline ( unsigned int width,
                               unsigned int shift,
                                ASScanline  *reusable_memory,
                               Bool BGR_mode);
INPUTS
 DESCRIPTIONwidth- width of the scanline.
shift- format of contained data. 0 means - 32bit unshifted
                  8 means - 24.8bit ( 8 bit left shifted ).
reusable_memory- preallocated object.
BGR_mode-  if  True will cause xc3 to point to Blue and xc1 to
                  point to red.
 
 This function allocates memory (  if  reusable_memory is NULL ) for
the new  ASScanline  structure. Structures buffers gets allocated to
hold scanline data of at least width pixel wide. Buffers are adjusted
to  start  on 8 byte boundary.
 libAfterImage/free_scanline()NAME
 free_scanline()SYNOPSIS
 
 void       free_scanline (  ASScanline  *sl, Bool reusable );
INPUTS 
 DESCRIPTIONsl- pointer to previously allocated  ASScanline  structure to be
           deallocated.
reusable-  if  true then  ASScanline  object itself will not be
           deallocated.
 
 free_scanline() frees all the buffer memory allocated for  ASScanline .
If reusable is false then object itself in not freed. That is usable
for declaring  ASScanline  on stack.
NAME ASVisual
 - an abstraction layer on top of X Server Visual.
DESCRIPTION 
 This structure has been introduced in order to compensate for the
fact that X may have so many different types of Visuals. It provides
shortcuts to most Visual data, compensated for differences in Visuals.
For PseudoColor  visual  it also contains preallocated  set  of colors.
This  colormap  allows us to write XImages very fast and without
exhausting available X colors. This  colormap  consist of 8, 64, or 4096
colors and constitutes fraction of colors available in particular
colordepth. This colors are allocated to be evenly spread around RGB
spectrum. Thus when converting from internal presentation - all we
need to do is to discard unused bits, and use rest of them bits as
an index in our  colormap . Opposite conversion is much trickier and we
engage into nasty business of having hash table mapping pixel values
into colors, or straight table doing same in lower colordepths.
Idea is that we do all internal processing in 32bit colordepth, and
 ASVisual  provides us with means to convert it to actual X display
format. Respectively  ASVisual  has methods to write out XImage lines
and read XImage lines.
 ASVisual  creation is a tricky process. Basically first we have to go
through the  list  of available Visuals and choose the best suitable.
Then based on the type of this Visual we have to  setup  our data
members and method hooks. Several functions provided for that :
 query_screen_visual()    - will lookup best suitable  visual 
 setup_truecolor_visual() - will  setup  hooks  if   visual  is TrueColor
 setup_pseudo_visual()   - will  setup  hooks and data  if  Visual is
                            PseudoColor.
 setup_as_colormap()      - will preallocate colors for PseudoColor.
Alternative to the above is :
 create_asvisual()        - it encapsulates all of the above
                            functionality, and returns completely  set 
                            up  ASVisual  object.
Since Visual selected for  ASVisual  may differ from default
( we choose the best suitable ), all the window creation function
must provide  colormap  and some other parameters, like border  color 
for example. Thus we created some convenience functions.
These should be used instead of standard Xlib calls :
 create_visual_window() - to  create  window
 create_visual_pixmap() - to  create  pixmap
 create_visual_ximage() - to  create  XImage
 ASVisual  could be dealolocated and its resources freed with :
 destroy_asvisual()
EXAMPLE
 asview.c:  ASView 
SOURCE 
 
typedef struct  ASVisual 
{
    Display      *dpy;
    /* This envvar will be used to determine what X Visual 
     * (in hex) to use. If unset then best possible will 
     * be selected automagically : */
#define ASVISUAL_ID_ENVVAR "AFTERIMAGE_VISUAL_ID"
    XVisualInfo   visual_info;
    /* this things are calculated based on Visual : */
    unsigned long rshift, gshift, bshift;
    unsigned long rbits,  gbits,  bbits;
    unsigned long true_depth;   /* could be 15 when X reports 16 */
    Bool          BGR_mode;
    Bool          msb_first;
    /* we must have  colormap  so that we can safely  create  windows
     * with different visuals even  if  we are in TrueColor mode : */
    Colormap       colormap ;
    Bool          own_colormap; /* tells us to  free   colormap  when we
                                 * done */
    unsigned long black_pixel, white_pixel;
    /* for PseudoColor mode we need some more stuff : */
    enum {
        ACM_None = 0,
        ACM_3BPP,
        ACM_6BPP,
        ACM_12BPP
    } as_colormap_type ;    /* there can only be 64 or 4096 entries
                             * so far ( 6 or 12 bpp) */
    unsigned long *as_colormap; /* array of preallocated colors for
                                 * PseudoColor mode */
    union                       /* reverse  color  lookup tables : */
    {
         ARGB32               *xref;
        struct ASHashTable  *hash;
    }as_colormap_reverse ;
    /* different useful callbacks : */
    CARD32 (*color2pixel_func)    ( struct  ASVisual  *asv,
                                    CARD32 encoded_color,
                                    unsigned long *pixel);
    void   (*pixel2color_func)    ( struct  ASVisual  *asv,
                                    unsigned long pixel,
                                    CARD32 *red, CARD32 *green,
                                    CARD32 *blue);
    void   (*ximage2scanline_func)( struct  ASVisual  *asv, 
                                    XImage *xim,
                                     ASScanline  *sl, int y,
                                    unsigned char *xim_data );
    void   (*scanline2ximage_func)( struct  ASVisual  *asv, 
                                    XImage *xim,
                                     ASScanline  *sl, int y,
                                    unsigned char *xim_data );
#define ASGLX_Unavailable           0
#define ASGLX_Available             (0x01<<0)
#define ASGLX_DoubleBuffer          (0x01<<1)
#define ASGLX_RGBA                  (0x01<<2)
#define ASGLX_UseForImageTx         (0x01<<3)   
    ASFlagType glx_support ;    /* one of the above flags */
    void *glx_scratch_gc_indirect ; /* (GLXContext) */
    void *glx_scratch_gc_direct ;   /* (GLXContext) */
    Window scratch_window;
#ifndef X_DISPLAY_MISSING
#define ARGB2PIXEL(asv,argb,pixel)         \
    (asv)->color2pixel_func((asv),(argb),(pixel))
#define GET_SCANLINE(asv,xim,sl,y,xim_data) \
    (asv)->ximage2scanline_func((asv),(xim),(sl),(y),(xim_data))
#define PUT_SCANLINE(asv,xim,sl,y,xim_data) \
    (asv)->scanline2ximage_func((asv),(xim),(sl),(y),(xim_data))
#else
#define ARGB2PIXEL(asv,argb,pixel)         \
    do{ break; }while(0)
#define GET_SCANLINE(asv,xim,sl,y,xim_data) \
    do{ break; }while(0)
#define PUT_SCANLINE(asv,xim,sl,y,xim_data) \
    do{ break; }while(0)
#endif
} ASVisual ;
 libAfterImage/query_screen_visual()NAME
 query_screen_visual_id()
query_screen_visual()SYNOPSIS
 
 Bool query_screen_visual_id(  ASVisual  *asv, Display *dpy, int  screen ,
                          Window root, int default_depth,
                             VisualID visual_id, Colormap cmap );
Bool query_screen_visual(  ASVisual  *asv, Display *dpy, int  screen ,
                          Window root, int default_depth );
INPUTS
 RETURN VALUEasv- preallocated  ASVisual  structure.
dpy- valid pointer to opened X display.
screen-  screen  number on which to  query  visuals.
root- root window on that  screen .
default_depth-default colordepth of the  screen .
visual_id- optional ID of prefered Visual.
cmap- optional  colormap  to be used.
 
 True on success, False on failure
 ASVisual  structure pointed by asv will have the following data
members  set  on success :
dpy, visual_info,  colormap , own_colormap, black_pixel, white_pixel.
DESCRIPTION 
 query_screen_visual_id() will go though prioritized  list  of possible
Visuals and attempt to match those to what is available on the
specified  screen . If all items from  list  fail, then it goes about
querying default  visual .
query_screen_visual is identical to query_screen_visual_id with
visual_id and cmap  set  to 0.
Once X Visual has been identified, we  create  X  colormap  and allocate
white and black pixels from it.
 libAfterImage/setup_truecolor_visual()NAME
 setup_truecolor_visual()SYNOPSIS
 
 Bool setup_truecolor_visual(  ASVisual  *asv );
INPUTS 
 RETURN VALUEasv- preallocated  ASVisual  structure.
 
 True on success, False  if   visual  is not TrueColor.
DESCRIPTION 
 setup_truecolor_visual() checks  if  Visual is indeed TrueColor and  if 
so it goes about querying  color  masks, deducing real XImage
colordepth, and whether we work in BGR mode. It then goes about
setting up correct hooks to X IO functions.
 libAfterImage/setup_pseudo_visual()NAME
 setup_pseudo_visual()SYNOPSIS
 
 void setup_pseudo_visual(  ASVisual  *asv  );
INPUTS 
 DESCRIPTIONasv- preallocated  ASVisual  structure.
 
 setup_pseudo_visual() assumes that Visual is PseudoColor. It then
tries to decide as to how many colors preallocate, and goes about
setting up correct X IO hooks and possibly initialization of reverse
 colormap  in case  ASVisual  already has  colormap  preallocated.
 libAfterImage/setup_as_colormap()NAME
 setup_as_colormap()SYNOPSIS
 
 void setup_as_colormap(  ASVisual  *asv );
INPUTS 
 DESCRIPTIONasv- preallocated  ASVisual  structure.
 
 That has to be called in order to pre-allocate sufficient number of
colors. It uses  colormap  size identification supplied in  ASVisual 
structure. If colors where preallocated successfully - it will also
 create  reverse lookup  colormap .
 libAfterImage/create_asvisual_for_id()NAME
 create_asvisual_for_id()SYNOPSIS
 
  ASVisual  *create_asvisual_for_id( Display *dpy, int  screen ,
                                  int default_depth,
                                  VisualID visual_id, Colormap cmap,
                                   ASVisual  *reusable_memory );
INPUTS
 RETURN VALUEdpy- valid pointer to opened X display.
screen-  screen  number on which to  query  visuals.
root- root window on that  screen .
default_depth-default colordepth of the  screen .
visual_id- ID of X  visual  to use.
cmap- optional ID of the  colormap  to be used.
reusable_memory- pointer to preallocated  ASVisual  structure.
 
 Pointer to  ASVisual  structure initialized with enough information
to be able to deal with current X Visual.
DESCRIPTION 
 This function calls all the needed functions in order to  setup  new
 ASVisual  structure for the specified  screen  and  visual . If
reusable_memory is not null - it will not allocate new  ASVisual 
structure, but instead will use supplied one. Useful for allocating
 ASVisual  on stack.
This particular function will not do any autodetection and will use
Visual ID supplied. That is usefull when  libAfterImage  is used with
an app that has its own approach to Visual handling, and since Visuals
on all Windows, Pixmaps and colormaps must match, there is a need to
synchronise visuals used by an app and  libAfterImage .
 libAfterImage/create_asvisual()NAME
 create_asvisual()SYNOPSIS
 
  ASVisual  *create_asvisual( Display *dpy, int  screen ,
                           int default_depth,
                            ASVisual  *reusable_memory );
INPUTS
 RETURN VALUEdpy- valid pointer to opened X display.
screen-  screen  number on which to  query  visuals.
root- root window on that  screen .
default_depth-default colordepth of the  screen .
reusable_memory- pointer to preallocated  ASVisual  structure.
 
 Pointer to  ASVisual  structure initialized with enough information
to be able to deal with current X Visual.
DESCRIPTION 
 This function calls all the needed functions in order to  setup  new
 ASVisual  structure for the specified  screen . If reusable_memory is
not null - it will not allocate new  ASVisual  structure, but instead
will use supplied one. Useful for allocating  ASVisual  on stack.
It is different from create_asvisualfor_id() in that it will attempt
to autodetect best possible  visual  for the  screen . For example on some
SUN Solaris X servers there will be both 8bpp pseudocolor and 24bpp
truecolor, and default will be 8bpp. In this scenario  libAfterImage 
will detect and use 24bpp true  color   visual , thus producing much better
results.
 libAfterImage/destroy_asvisual()NAME
 destroy_asvisual()SYNOPSIS
 
 void destroy_asvisual(  ASVisual  *asv, Bool reusable );
INPUTS 
 DESCRIPTIONasv- valid  ASVisual  structure.
reusable-  if  True it will cause function to not  free  object
           itself.
 
 Cleanup function. Frees all the memory and deallocates all the
resources. If reusable is False it will also  free  the object, pointed
to by asv.
EXAMPLE 
 asview.c:  ASView .2
 libAfterImage/visual2visual_prop()NAME
 visual2visual_prop()SYNOPSIS
 
 Bool visual2visual_prop(  ASVisual  *asv, size_t *size,
                         unsigned long *version, unsigned long **data );
INPUTS
 RETURN VALUEasv- valid  ASVisual  structure.
 
 size         - size of the encoded memory block.
version      - version of the encoding
data         - actual encoded memory block
True on success, False on failure
DESCRIPTION 
 This function will encode  ASVisual  structure into memory block of
32 bit values, suitable for storing in X property.
 libAfterImage/visual_prop2visual()NAME
 visual_prop2visual()SYNOPSIS
 
 Bool visual_prop2visual(  ASVisual  *asv, Display *dpy, int  screen ,
                         size_t size,
                         unsigned long version, unsigned long *data );
INPUTS
 RETURN VALUEasv- valid  ASVisual  structure.
dpy- valid pointer to  open  X display.
screen-  screen  number.
size- encoded memory block's size.
version- version of encoding.
data- actual encoded memory block.
 
 True on success, False on failure
DESCRIPTION 
 visual_prop2visual() will read  ASVisual  data from the memory block
encoded by visual2visual_prop(). It could be used to read data from
X property and convert it into usable information - such as  colormap ,
 visual  info, etc.
Note: setup_truecolor_visual() or setup_pseudo_visual() has to be
invoked in order to complete  ASVisual   setup .
 libAfterImage/create_visual_window()NAME
 create_visual_window()SYNOPSIS
 
 Window  create_visual_window(  ASVisual  *asv, Window parent,
                              int x, int y,
                              unsigned int width, unsigned int height,
                              unsigned int border_width,
                              unsigned int wclass,
                              unsigned long mask,
                              XSetWindowAttributes *attributes );
INPUTS
 RETURN VALUEasv- pointer to the valid  ASVisual  structure.
parent- Window ID of the parent the window.
x,y          - initial position of the new window.
width,height - initial size of the new window.
border_width- initial border width of the new window.
wclass- Window class  - InputOnly or InputOutput.
mask- defines what attributes are  set .
attributes- different window attributes.
 
 ID of the newly created window on success. None on failure.
DESCRIPTION 
 create_visual_window() will do sanity checks on passed parameters,
it will then  add  mandatory attributes  if  needed, and attempt to
 create  window for the specified  ASVisual .
 libAfterImage/create_visual_gc()NAME
 create_visual_gc()SYNOPSIS
 
 GC      create_visual_gc(  ASVisual  *asv, Window root,
                          unsigned long mask, XGCValues *gcvalues );
INPUTS
 RETURN VALUEasv- pointer to the valid  ASVisual  structure.
root- Window ID of the root window of destination  screen 
mask,gcvalues - values for creation of new GC - see XCreateGC() for
                 details.
 
 New GC created for regular window on success. NULL on failure.
DESCRIPTION 
 create_visual_gc() will  create  temporary window for the  ASVisual 
specific depth and Visual and it will then  create  GC for such window.
Obtained GC should be good to be used for manipulation of windows and
Pixmaps created for the same  ASVisual .
 libAfterImage/create_visual_pixmap()NAME
 create_visual_pixmap()SYNOPSIS
 
 Pixmap  create_visual_pixmap(  ASVisual  *asv, Window root,
                              unsigned int width, unsigned int height,
                              unsigned int depth );
INPUTS
 RETURN VALUEasv- pointer to the valid  ASVisual  structure.
root- Window ID of the root window of destination  screen 
width,height  - size of the pixmap to  create .
depth- depth of the pixmap to  create . If 0 asv->true_depth
                 will be used.
 
 ID of the newly created pixmap on success. None on failure.
DESCRIPTION 
 create_visual_pixmap() will perform sanity checks on passed
parameters, and attempt to  create  pixmap for the specified  ASVisual ,
root and depth.
 libAfterImage/create_visual_ximage()NAME
 create_visual_ximage()SYNOPSIS
 
 XImage* create_visual_ximage(  ASVisual  *asv,
                              unsigned int width, unsigned int height,
                              unsigned int depth );
INPUTS
 RETURN VALUEasv- pointer to the valid  ASVisual  structure.
width,height  - size of the XImage to  create .
depth- depth of the XImage to  create . If 0 asv->true_depth
                 will be used.
 
 pointer to newly created XImage on success. NULL on failure.
DESCRIPTION 
 create_visual_ximage() will perform sanity checks on passed
parameters, and it will attempt to  create  XImage of sufficient size,
and specified colordepth. It will also  setup  hooks for XImage
deallocation to be handled by custom function.
 
 AfterStep Documentation   -   October 2005     ( 80% complete )
 |  |   |  |    |