Introduction to GIFLIB

Eric Steven Raymond


Table of Contents

Utilities
Viewers
Conversion Utilities
Test Pattern Generators
Image Manipulation Components
Report Generators
GIF Composition Tools
C Code Templates
Library Functions
The GIF Standard
Package Status

GIFLIB is a package of portable tools and library routines for working with GIF images.

The Graphics Interchange Format(c) specification is the copyrighted property of CompuServe Incorporated. GIF(sm) is a service mark property of CompuServe Incorporated.

This package has been released under an X Consortium-like open-source license. Use and copy as you see fit. If you make useful changes, add new tools, or find and fix bugs, please send your mods to the maintainers for general distribution.

The util directory includes programs to clip, rotate, scale, and position GIF images. These are no replacement for an interactive graphics editor, but they can be very useful for scripted image generation or transformation.

The library includes program-callable entry points for reading and writing GIF files, an 8x8 utility font for embedding text in GIFs, and an error handler. GIF manipulation can be done at a relatively low level by sequential I/O (which automatically does/undoes image compression) or at a higher level by slurping an entire GIF into allocated core.

This library speaks both GIF87a and GIF89. The differences between GIF87 and GIF89 are minor: in the latter, the interpretation of some extension block types is defined. The library never needs to actually interpret these, but giftext notices them.

Utilities

Here is a summary of the utilities in this package. If you're looking at this page through a web browser, each utility name should be a hotlink to HTML documentation.

Viewers

gif2x11

display images saved as GIF files under X window system.

Conversion Utilities

gif2rgb

convert images saved as GIF to 24-bit RGB image(s)

raw2gif

convert raw 8-bit image data into GIF files

rgb2gif

convert 24 bit images to a GIF image using color quantization

Test Pattern Generators

gifbg

generate a single-color test pattern GIF

gifcolor

generate color test patterns

gifwedge

create a test GIF image resembling a color monitor test pattern

Image Manipulation Components

gifasm

assemble multiple GIFs into one, or burst a multiple-image GIF

gifclip

clip or crop a GIF image

gifclrmp

modify GIF image colormaps

gifcomb

combine 2 GIF images of exactly the same size into one

giffix

clumsily attempts to fix truncated GIF images

gifflip

flip GIF image along X or Y axis or rotate by 90 degrees

gifinter

convert between interlaced and non interlaced images

gifovly

generate one composite GIF from a multiple-image GIF

gifpos

change a GIF's screen size or recondition it.

gifrotat

rotate a GIF through any desired angle

gifrsize

resize a GIF by deletion or duplication of bits

Report Generators

giftext

print (text only) general information about a GIF

gifhisto

generate color-frequency histogram from a GIF

GIF Composition Tools

icon2gif

converter/deconverter to/from an editable text format

text2gif

generate GIF images out of regular text in 8x8 font

gifinto

end-of-pipe fitting for GIF-processing pipelines

gifcompose

use giflib tools to compose images

C Code Templates

giffiltr

template code for filtering a GIF sequentially

gifspnge

template code for filtering a GIF with in-core operations

Under MS-DOS, most filters will print the current input scan line number (counting up) whenever they read image input, and will print output image line number (counting down) when they dump output. Utilities that only read or write always print in increasing order. Utilities (like GifPos that only change positions) that copy the image as a block of compressed data will print nothing --- they cannot identify a scan line number, and are enough faster that the feedback to the user doesn't seem necessary.

Library Functions

The library contains two groups of C functions. One group does sequential I/O on the stream-oriented GIF format. The other supports grabbing an entire GIF into allocated core, operating on it in core, and then writing the modified in-core GIF out to disk.

Unless you are on extremely memory-limited machine you probably want to use the second group.

Detailed documentation on the library entry points is in gif_lib.html. Library error codes are described in liberror.html

The GIF Standard

The doc subdirectory includes flat-ASCII descriptions of GIF89 format and Lempel-Ziv Compression.

Package Status

GIFLIB's current maintainer is Eric S. Raymond. You can find his home page at http://www.ccil.org/esr.

GIFLIB is not under active development, but bug fixes are being accepted.