Skip to content

Simple C++ one-header library for the creation of animated GIFs from image data.

License

Notifications You must be signed in to change notification settings

rversteegen/gif-h

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

79 Commits
 
 
 
 
 
 

Repository files navigation

gif-h

This one-header library offers a simple, very limited way to create animated GIFs directly in code. Those looking for particular cleverness are likely to be disappointed; it's pretty much a straight-ahead implementation of the GIF format with optional Floyd-Steinberg dithering. (It does at least use delta encoding - only the changed portions of each frame are saved.)

So resulting files are often quite large. The hope is that it will be handy nonetheless as a quick and easily-integrated way for programs to spit out animations.

There are two supported input formats, RGBA8 (the alpha is ignored), and 8-bit paletted (with a power-of-two palette size). (In the latter case you can save up to 768 bytes per frame by providing a global palette and reusing it for some frames.) You can freely mix 32-bit and 8-bit input frames, and even frames with differing sizes. Note that only 8-bit input frames can have transparent areas (producing a transparent GIF disables delta-coding).

Email me : ctangora -at- gmail -dot- com

Usage:

Create a GifWriter struct.

Pass the struct to GifBegin() to initialize values and write the file header.

Pass frames of the animation to GifWriteFrame() or GifWriteFrame8().

If necessary, call GifOverwriteLastDelay() to set the correct delay after-the-fact.

Finally, call GifEnd() to close the file handle and free memory.

About

Simple C++ one-header library for the creation of animated GIFs from image data.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 100.0%