/* Copyright (C) 2001-2006 Artifex Software, Inc. All Rights Reserved. This software is provided AS-IS with no warranty, either express or implied. This software is distributed under license and may not be copied, modified or distributed except as expressly authorized under the terms of that license. Refer to licensing information at http://www.artifex.com/ or contact Artifex Software, Inc., 7 Mt. Lassen Drive - Suite A-134, San Rafael, CA 94903, U.S.A., +1(415)492-9861, for further information. */ /* $Id$ */ /* State and interface definitions for a spot analyzer device. */ /* * A spot analyzer device performs an analyzis while handling an output * of the trapezoid fill algorithm for 2 purposes : * a glyph grid fitting, and * a glyph antialiased rendering any number of alpha bits. * Currently we only implement a vertical stem recognition for the grid fitting. */ #ifndef gzspotan_INCLUDED # define gzspotan_INCLUDED #include "gxdevcli.h" #ifndef segment_DEFINED # define segment_DEFINED typedef struct segment_s segment; /* gzpath.h */ #endif #ifndef gx_device_spot_analyzer_DEFINED # define gx_device_spot_analyzer_DEFINED typedef struct gx_device_spot_analyzer_s gx_device_spot_analyzer; #endif /* -------------- Structures ----------------------------- */ typedef struct gx_san_trap_s gx_san_trap; typedef struct gx_san_trap_contact_s gx_san_trap_contact; /* A trapezoid. */ struct gx_san_trap_s { /* Buffer link : */ gx_san_trap *link; /* Buffer link. */ /* The geometry : */ fixed ybot, ytop; fixed xlbot, xrbot, xltop, xrtop; /* The spot topology representation : */ gx_san_trap_contact *upper; /* Neighbours of the upper band. */ const segment *l; /* Outline pointer : left boundary. */ const segment *r; /* Outline pointer : right boundary. */ int dir_l, dir_r; /* Outline direction : left, right. */ bool leftmost, rightmost; /* The topology reconstrustor work data : */ gx_san_trap *next; /* Next with same ytop. */ gx_san_trap *prev; /* Prev with same ytop. */ /* The stem recognizer work data : */ bool visited; int fork; }; #define private_st_san_trap() /* When GC is invoked, only the buffer link is valid. */\ gs_private_st_ptrs1(st_san_trap, gx_san_trap, "gx_san_trap", \ san_trap_enum_ptrs, san_trap_reloc_ptrs, link) /* A contact of 2 trapezoids. */ /* Represents a neighbourship through a band boundary. */ struct gx_san_trap_contact_s { /* Buffer link : */ gx_san_trap_contact *link; /* Buffer link. */ gx_san_trap_contact *next; /* Next element of the same relation, a cyclic list. */ gx_san_trap_contact *prev; /* Prev element of the same relation, a cyclic list. */ gx_san_trap *upper, *lower; /* A contacting pair. */ }; #define private_st_san_trap_contact() /* When GC is invoked, only the buffer link is valid. */\ gs_private_st_ptrs1(st_san_trap_contact, gx_san_trap_contact, "gx_san_trap_contact",\ san_trap_contact_enum_ptrs, san_trap_contact_reloc_ptrs, link) /* A stem section. */ typedef struct gx_san_sect_s gx_san_sect; struct gx_san_sect_s { fixed xl, yl, xr, yr; const segment *l, *r; int side_mask; }; /* A spot analyzer device. */ struct gx_device_spot_analyzer_s { gx_device_common; int lock; /* Buffers : */ gx_san_trap *trap_buffer, *trap_buffer_last, *trap_free; gx_san_trap_contact *cont_buffer, *cont_buffer_last, *cont_free; int trap_buffer_count; int cont_buffer_count; /* The topology reconstrustor work data (no GC invocations) : */ gx_san_trap *bot_band; gx_san_trap *top_band; gx_san_trap *bot_current; /* The stem recognizer work data (no GC invocations) : */ fixed xmin, xmax; }; extern_st(st_device_spot_analyzer); #define public_st_device_spot_analyzer() /* When GC is invoked, only the buffer links are valid. */\ gs_public_st_suffix_add4_final(st_device_spot_analyzer, gx_device_spot_analyzer,\ "gx_device_spot_analyzer", device_spot_analyzer_enum_ptrs,\ device_spot_analyzer_reloc_ptrs, gx_device_finalize, st_device,\ trap_buffer, trap_buffer_last, cont_buffer, cont_buffer_last) /* -------------- Interface methods ----------------------------- */ /* Obtain a spot analyzer device. */ int gx_san__obtain(gs_memory_t *mem, gx_device_spot_analyzer **ppadev); /* Obtain a spot analyzer device. */ void gx_san__release(gx_device_spot_analyzer **ppadev); /* Start accumulating a path. */ void gx_san_begin(gx_device_spot_analyzer *padev); /* Store a tarpezoid. */ /* Assumes an Y-band scanning order with increasing X inside a band. */ int gx_san_trap_store(gx_device_spot_analyzer *padev, fixed ybot, fixed ytop, fixed xlbot, fixed xrbot, fixed xltop, fixed xrtop, const segment *l, const segment *r, int dir_l, int dir_r); /* Finish accumulating a path. */ void gx_san_end(const gx_device_spot_analyzer *padev); /* Generate stems. */ int gx_san_generate_stems(gx_device_spot_analyzer *padev, bool overall_hints, void *client_data, int (*handler)(void *client_data, gx_san_sect *ss)); /* -------------- Other external symbols ------------------------ */ /* is_spotan_device() in gxfill.c uses san_open */ /* to identify the spot analyzer device */ dev_proc_open_device(san_open); #endif /* gzspotan_INCLUDED */