Blame gdk-pixbuf/io-gif-animation.h

Packit a4058c
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */
Packit a4058c
/* GdkPixbuf library - GIF loader declarations
Packit a4058c
 *
Packit a4058c
 * Copyright (C) 1999 The Free Software Foundation
Packit a4058c
 *
Packit a4058c
 * Authors: Mark Crichton <crichton@gimp.org>
Packit a4058c
 *          Miguel de Icaza <miguel@gnu.org>
Packit a4058c
 *          Federico Mena-Quintero <federico@gimp.org>
Packit a4058c
 *          Havoc Pennington <hp@redhat.com>
Packit a4058c
 *
Packit a4058c
 * This library is free software; you can redistribute it and/or
Packit a4058c
 * modify it under the terms of the GNU Lesser General Public
Packit a4058c
 * License as published by the Free Software Foundation; either
Packit a4058c
 * version 2 of the License, or (at your option) any later version.
Packit a4058c
 *
Packit a4058c
 * This library is distributed in the hope that it will be useful,
Packit a4058c
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit a4058c
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit a4058c
 * Lesser General Public License for more details.
Packit a4058c
 *
Packit a4058c
 * You should have received a copy of the GNU Lesser General Public
Packit a4058c
 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
Packit a4058c
 */
Packit a4058c
Packit a4058c
#ifndef GDK_PIXBUF_GIF_H
Packit a4058c
#define GDK_PIXBUF_GIF_H
Packit a4058c
Packit a4058c
#include "gdk-pixbuf-animation.h"
Packit a4058c
Packit a4058c
typedef enum {
Packit a4058c
        /* Keep this frame and composite next frame over it */
Packit a4058c
        /* (GIF disposal method 1) */
Packit a4058c
	GDK_PIXBUF_FRAME_RETAIN,
Packit a4058c
        /* Revert to background color before compositing next frame */
Packit a4058c
        /* (GIF disposal method 2) */
Packit a4058c
	GDK_PIXBUF_FRAME_DISPOSE,
Packit a4058c
        /* Revert to previously-displayed composite image after
Packit a4058c
         * displaying this frame
Packit a4058c
         */
Packit a4058c
        /* (GIF disposal method 3) */
Packit a4058c
	GDK_PIXBUF_FRAME_REVERT
Packit a4058c
} GdkPixbufFrameAction;
Packit a4058c
Packit a4058c

Packit a4058c
Packit a4058c
typedef struct _GdkPixbufGifAnim GdkPixbufGifAnim;
Packit a4058c
typedef struct _GdkPixbufGifAnimClass GdkPixbufGifAnimClass;
Packit a4058c
typedef struct _GdkPixbufFrame GdkPixbufFrame;
Packit a4058c
Packit a4058c
#define GDK_TYPE_PIXBUF_GIF_ANIM              (gdk_pixbuf_gif_anim_get_type ())
Packit a4058c
#define GDK_PIXBUF_GIF_ANIM(object)           (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_GIF_ANIM, GdkPixbufGifAnim))
Packit a4058c
#define GDK_IS_PIXBUF_GIF_ANIM(object)        (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_GIF_ANIM))
Packit a4058c
Packit a4058c
#define GDK_PIXBUF_GIF_ANIM_CLASS(klass)      (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_GIF_ANIM, GdkPixbufGifAnimClass))
Packit a4058c
#define GDK_IS_PIXBUF_GIF_ANIM_CLASS(klass)   (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_GIF_ANIM))
Packit a4058c
#define GDK_PIXBUF_GIF_ANIM_GET_CLASS(obj)    (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_GIF_ANIM, GdkPixbufGifAnimClass))
Packit a4058c
Packit a4058c
/* Private part of the GdkPixbufGifAnim structure */
Packit a4058c
struct _GdkPixbufGifAnim {
Packit a4058c
        GdkPixbufAnimation parent_instance;
Packit a4058c
Packit a4058c
        /* Number of frames */
Packit a4058c
        int n_frames;
Packit a4058c
Packit a4058c
        /* Total length of animation */
Packit a4058c
        int total_time;
Packit a4058c
        
Packit a4058c
	/* List of GdkPixbufFrame structures */
Packit a4058c
        GList *frames;
Packit a4058c
Packit a4058c
	/* bounding box size */
Packit a4058c
	int width, height;
Packit a4058c
Packit a4058c
        guchar bg_red;
Packit a4058c
        guchar bg_green;
Packit a4058c
        guchar bg_blue;
Packit a4058c
        
Packit a4058c
        int loop;
Packit a4058c
        gboolean loading;
Packit a4058c
};
Packit a4058c
Packit a4058c
struct _GdkPixbufGifAnimClass {
Packit a4058c
        GdkPixbufAnimationClass parent_class;
Packit a4058c
        
Packit a4058c
};
Packit a4058c
Packit a4058c
GType gdk_pixbuf_gif_anim_get_type (void) G_GNUC_CONST;
Packit a4058c
Packit a4058c

Packit a4058c
Packit a4058c
typedef struct _GdkPixbufGifAnimIter GdkPixbufGifAnimIter;
Packit a4058c
typedef struct _GdkPixbufGifAnimIterClass GdkPixbufGifAnimIterClass;
Packit a4058c
Packit a4058c
Packit a4058c
#define GDK_TYPE_PIXBUF_GIF_ANIM_ITER              (gdk_pixbuf_gif_anim_iter_get_type ())
Packit a4058c
#define GDK_PIXBUF_GIF_ANIM_ITER(object)           (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_GIF_ANIM_ITER, GdkPixbufGifAnimIter))
Packit a4058c
#define GDK_IS_PIXBUF_GIF_ANIM_ITER(object)        (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_GIF_ANIM_ITER))
Packit a4058c
Packit a4058c
#define GDK_PIXBUF_GIF_ANIM_ITER_CLASS(klass)      (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_GIF_ANIM_ITER, GdkPixbufGifAnimIterClass))
Packit a4058c
#define GDK_IS_PIXBUF_GIF_ANIM_ITER_CLASS(klass)   (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_GIF_ANIM_ITER))
Packit a4058c
#define GDK_PIXBUF_GIF_ANIM_ITER_GET_CLASS(obj)    (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_GIF_ANIM_ITER, GdkPixbufGifAnimIterClass))
Packit a4058c
Packit a4058c
struct _GdkPixbufGifAnimIter {
Packit a4058c
        GdkPixbufAnimationIter parent_instance;
Packit a4058c
        
Packit a4058c
        GdkPixbufGifAnim   *gif_anim;
Packit a4058c
Packit a4058c
        GTimeVal            start_time;
Packit a4058c
        GTimeVal            current_time;
Packit a4058c
Packit a4058c
        /* Time in milliseconds into this run of the animation */
Packit a4058c
        gint                position;
Packit a4058c
        
Packit a4058c
        GList              *current_frame;
Packit a4058c
        
Packit a4058c
        gint                first_loop_slowness;
Packit a4058c
};
Packit a4058c
Packit a4058c
struct _GdkPixbufGifAnimIterClass {
Packit a4058c
        GdkPixbufAnimationIterClass parent_class;
Packit a4058c
Packit a4058c
};
Packit a4058c
Packit a4058c
GType gdk_pixbuf_gif_anim_iter_get_type (void) G_GNUC_CONST;
Packit a4058c
Packit a4058c

Packit a4058c
Packit a4058c
struct _GdkPixbufFrame {
Packit a4058c
	/* The pixbuf with this frame's image data */
Packit a4058c
	GdkPixbuf *pixbuf;
Packit a4058c
Packit a4058c
        /* Offsets for overlaying onto the GIF graphic area */
Packit a4058c
        int x_offset;
Packit a4058c
	int y_offset;
Packit a4058c
Packit a4058c
	/* Frame duration in ms */
Packit a4058c
	int delay_time;
Packit a4058c
Packit a4058c
        /* Sum of preceding delay times */
Packit a4058c
        int elapsed;
Packit a4058c
        
Packit a4058c
        /* Overlay mode */
Packit a4058c
	GdkPixbufFrameAction action;
Packit a4058c
Packit a4058c
        /* TRUE if the pixbuf has been modified since
Packit a4058c
         * the last frame composite operation
Packit a4058c
         */
Packit a4058c
        gboolean need_recomposite;
Packit a4058c
Packit a4058c
        /* TRUE if the background for this frame is transparent */
Packit a4058c
        gboolean bg_transparent;
Packit a4058c
        
Packit a4058c
        /* The below reflects the "use hell of a lot of RAM"
Packit a4058c
         * philosophy of coding
Packit a4058c
         */
Packit a4058c
        
Packit a4058c
        /* Cached composite image (the image you actually display
Packit a4058c
         * for this frame)
Packit a4058c
         */
Packit a4058c
        GdkPixbuf *composited;
Packit a4058c
Packit a4058c
        /* Cached revert image (the contents of the area
Packit a4058c
         * covered by the frame prior to compositing;
Packit a4058c
         * same size as pixbuf, not as the composite image; only
Packit a4058c
         * used for FRAME_REVERT frames)
Packit a4058c
         */
Packit a4058c
        GdkPixbuf *revert;
Packit a4058c
};
Packit a4058c
Packit a4058c
void gdk_pixbuf_gif_anim_frame_composite (GdkPixbufGifAnim *gif_anim,
Packit a4058c
                                          GdkPixbufFrame   *frame);
Packit a4058c
Packit a4058c
#endif