|
Packit |
a4058c |
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*- */
|
|
Packit |
a4058c |
/* GdkPixbuf library - Animation support
|
|
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_ANIMATION_H
|
|
Packit |
a4058c |
#define GDK_PIXBUF_ANIMATION_H
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#if defined(GDK_PIXBUF_DISABLE_SINGLE_INCLUDES) && !defined (GDK_PIXBUF_H_INSIDE) && !defined (GDK_PIXBUF_COMPILATION)
|
|
Packit |
a4058c |
#error "Only <gdk-pixbuf/gdk-pixbuf.h> can be included directly."
|
|
Packit |
a4058c |
#endif
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#include <glib-object.h>
|
|
Packit |
a4058c |
#include <gdk-pixbuf/gdk-pixbuf-core.h>
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
G_BEGIN_DECLS
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
/* Animation support */
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
/**
|
|
Packit |
a4058c |
* GdkPixbufAnimation:
|
|
Packit |
a4058c |
*
|
|
Packit |
a4058c |
* An opaque struct representing an animation.
|
|
Packit |
a4058c |
*/
|
|
Packit |
a4058c |
typedef struct _GdkPixbufAnimation GdkPixbufAnimation;
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
/**
|
|
Packit |
a4058c |
* GdkPixbufAnimationIter:
|
|
Packit |
a4058c |
*
|
|
Packit |
a4058c |
* An opaque struct representing an iterator which points to a
|
|
Packit |
a4058c |
* certain position in an animation.
|
|
Packit |
a4058c |
*/
|
|
Packit |
a4058c |
typedef struct _GdkPixbufAnimationIter GdkPixbufAnimationIter;
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#define GDK_TYPE_PIXBUF_ANIMATION (gdk_pixbuf_animation_get_type ())
|
|
Packit |
a4058c |
#define GDK_PIXBUF_ANIMATION(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_ANIMATION, GdkPixbufAnimation))
|
|
Packit |
a4058c |
#define GDK_IS_PIXBUF_ANIMATION(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_ANIMATION))
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#define GDK_TYPE_PIXBUF_ANIMATION_ITER (gdk_pixbuf_animation_iter_get_type ())
|
|
Packit |
a4058c |
#define GDK_PIXBUF_ANIMATION_ITER(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_ANIMATION_ITER, GdkPixbufAnimationIter))
|
|
Packit |
a4058c |
#define GDK_IS_PIXBUF_ANIMATION_ITER(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_ANIMATION_ITER))
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
GType gdk_pixbuf_animation_get_type (void) G_GNUC_CONST;
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#ifdef G_OS_WIN32
|
|
Packit |
a4058c |
/* API/ABI compat, see gdk-pixbuf-core.h for details */
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
GdkPixbufAnimation *gdk_pixbuf_animation_new_from_file_utf8 (const char *filename,
|
|
Packit |
a4058c |
GError **error);
|
|
Packit |
a4058c |
#endif
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
GdkPixbufAnimation *gdk_pixbuf_animation_new_from_file (const char *filename,
|
|
Packit |
a4058c |
GError **error);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_2_28
|
|
Packit |
a4058c |
GdkPixbufAnimation *gdk_pixbuf_animation_new_from_stream (GInputStream *stream,
|
|
Packit |
a4058c |
GCancellable *cancellable,
|
|
Packit |
a4058c |
GError **error);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_2_28
|
|
Packit |
a4058c |
void gdk_pixbuf_animation_new_from_stream_async (GInputStream *stream,
|
|
Packit |
a4058c |
GCancellable *cancellable,
|
|
Packit |
a4058c |
GAsyncReadyCallback callback,
|
|
Packit |
a4058c |
gpointer user_data);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_2_28
|
|
Packit |
a4058c |
GdkPixbufAnimation *gdk_pixbuf_animation_new_from_stream_finish (GAsyncResult*async_result,
|
|
Packit |
a4058c |
GError **error);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_2_28
|
|
Packit |
a4058c |
GdkPixbufAnimation *gdk_pixbuf_animation_new_from_resource(const char *resource_path,
|
|
Packit |
a4058c |
GError **error);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#ifndef GDK_PIXBUF_DISABLE_DEPRECATED
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
GDK_PIXBUF_DEPRECATED_IN_2_0_FOR(g_object_ref)
|
|
Packit |
a4058c |
GdkPixbufAnimation *gdk_pixbuf_animation_ref (GdkPixbufAnimation *animation);
|
|
Packit |
a4058c |
GDK_PIXBUF_DEPRECATED_IN_2_0_FOR(g_object_unref)
|
|
Packit |
a4058c |
void gdk_pixbuf_animation_unref (GdkPixbufAnimation *animation);
|
|
Packit |
a4058c |
#endif
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
int gdk_pixbuf_animation_get_width (GdkPixbufAnimation *animation);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
int gdk_pixbuf_animation_get_height (GdkPixbufAnimation *animation);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
gboolean gdk_pixbuf_animation_is_static_image (GdkPixbufAnimation *animation);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
GdkPixbuf *gdk_pixbuf_animation_get_static_image (GdkPixbufAnimation *animation);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
GdkPixbufAnimationIter *gdk_pixbuf_animation_get_iter (GdkPixbufAnimation *animation,
|
|
Packit |
a4058c |
const GTimeVal *start_time);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
GType gdk_pixbuf_animation_iter_get_type (void) G_GNUC_CONST;
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
int gdk_pixbuf_animation_iter_get_delay_time (GdkPixbufAnimationIter *iter);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
GdkPixbuf *gdk_pixbuf_animation_iter_get_pixbuf (GdkPixbufAnimationIter *iter);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
gboolean gdk_pixbuf_animation_iter_on_currently_loading_frame (GdkPixbufAnimationIter *iter);
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
gboolean gdk_pixbuf_animation_iter_advance (GdkPixbufAnimationIter *iter,
|
|
Packit |
a4058c |
const GTimeVal *current_time);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#ifdef GDK_PIXBUF_ENABLE_BACKEND
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
/**
|
|
Packit |
a4058c |
* GdkPixbufAnimationClass:
|
|
Packit |
a4058c |
* @parent_class: the parent class
|
|
Packit |
a4058c |
* @is_static_image: returns whether the given animation is just a static image.
|
|
Packit |
a4058c |
* @get_static_image: returns a static image representing the given animation.
|
|
Packit |
a4058c |
* @get_size: fills @width and @height with the frame size of the animation.
|
|
Packit |
a4058c |
* @get_iter: returns an iterator for the given animation.
|
|
Packit |
a4058c |
*
|
|
Packit |
a4058c |
* Modules supporting animations must derive a type from
|
|
Packit |
a4058c |
* #GdkPixbufAnimation, providing suitable implementations of the
|
|
Packit |
a4058c |
* virtual functions.
|
|
Packit |
a4058c |
*/
|
|
Packit |
a4058c |
typedef struct _GdkPixbufAnimationClass GdkPixbufAnimationClass;
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#define GDK_PIXBUF_ANIMATION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_ANIMATION, GdkPixbufAnimationClass))
|
|
Packit |
a4058c |
#define GDK_IS_PIXBUF_ANIMATION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_ANIMATION))
|
|
Packit |
a4058c |
#define GDK_PIXBUF_ANIMATION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_ANIMATION, GdkPixbufAnimationClass))
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
/* Private part of the GdkPixbufAnimation structure */
|
|
Packit |
a4058c |
struct _GdkPixbufAnimation {
|
|
Packit |
a4058c |
GObject parent_instance;
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
};
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
struct _GdkPixbufAnimationClass {
|
|
Packit |
a4058c |
GObjectClass parent_class;
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
/*< public >*/
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
gboolean (*is_static_image) (GdkPixbufAnimation *anim);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
GdkPixbuf* (*get_static_image) (GdkPixbufAnimation *anim);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
void (*get_size) (GdkPixbufAnimation *anim,
|
|
Packit |
a4058c |
int *width,
|
|
Packit |
a4058c |
int *height);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
GdkPixbufAnimationIter* (*get_iter) (GdkPixbufAnimation *anim,
|
|
Packit |
a4058c |
const GTimeVal *start_time);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
};
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
/**
|
|
Packit |
a4058c |
* GdkPixbufAnimationIterClass:
|
|
Packit |
a4058c |
* @parent_class: the parent class
|
|
Packit |
a4058c |
* @get_delay_time: returns the time in milliseconds that the current frame
|
|
Packit |
a4058c |
* should be shown.
|
|
Packit |
a4058c |
* @get_pixbuf: returns the current frame.
|
|
Packit |
a4058c |
* @on_currently_loading_frame: returns whether the current frame of @iter is
|
|
Packit |
a4058c |
* being loaded.
|
|
Packit |
a4058c |
* @advance: advances the iterator to @current_time, possibly changing the
|
|
Packit |
a4058c |
* current frame.
|
|
Packit |
a4058c |
*
|
|
Packit |
a4058c |
* Modules supporting animations must derive a type from
|
|
Packit |
a4058c |
* #GdkPixbufAnimationIter, providing suitable implementations of the
|
|
Packit |
a4058c |
* virtual functions.
|
|
Packit |
a4058c |
*/
|
|
Packit |
a4058c |
typedef struct _GdkPixbufAnimationIterClass GdkPixbufAnimationIterClass;
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#define GDK_PIXBUF_ANIMATION_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_PIXBUF_ANIMATION_ITER, GdkPixbufAnimationIterClass))
|
|
Packit |
a4058c |
#define GDK_IS_PIXBUF_ANIMATION_ITER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_PIXBUF_ANIMATION_ITER))
|
|
Packit |
a4058c |
#define GDK_PIXBUF_ANIMATION_ITER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_PIXBUF_ANIMATION_ITER, GdkPixbufAnimationIterClass))
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
struct _GdkPixbufAnimationIter {
|
|
Packit |
a4058c |
GObject parent_instance;
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
};
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
struct _GdkPixbufAnimationIterClass {
|
|
Packit |
a4058c |
GObjectClass parent_class;
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
/*< public >*/
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
int (*get_delay_time) (GdkPixbufAnimationIter *iter);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
GdkPixbuf* (*get_pixbuf) (GdkPixbufAnimationIter *iter);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
gboolean (*on_currently_loading_frame) (GdkPixbufAnimationIter *iter);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
gboolean (*advance) (GdkPixbufAnimationIter *iter,
|
|
Packit |
a4058c |
const GTimeVal *current_time);
|
|
Packit |
a4058c |
};
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
GType gdk_pixbuf_non_anim_get_type (void) G_GNUC_CONST;
|
|
Packit |
a4058c |
GDK_PIXBUF_AVAILABLE_IN_ALL
|
|
Packit |
a4058c |
GdkPixbufAnimation* gdk_pixbuf_non_anim_new (GdkPixbuf *pixbuf);
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#endif /* GDK_PIXBUF_ENABLE_BACKEND */
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
G_END_DECLS
|
|
Packit |
a4058c |
|
|
Packit |
a4058c |
#endif /* GDK_PIXBUF_ANIMATION_H */
|