|
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
|