mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2024-12-26 13:41:07 +00:00
fde4fecfd2
2000-12-16 Havoc Pennington <hp@pobox.com> * gtk/gdk-pixbuf-loader.h, gtk/gdk-pixbuf-loader.c: Port to GObject, can go back in gdk-pixbuf after setting up a gdk-pixbuf-marshal.h header over there. * gtk/gtktreeview.c: s/SEPERATOR/SEPARATOR/g; (gtk_tree_view_class_init): specify GTK_TYPE_ADJUSTMENT for signal args (gtk_tree_view_init): don't unset GTK_NO_WINDOW, it shouldn't be set (gtk_tree_view_realize_buttons): don't gtk_widget_show() buttons here, do it when we create the buttons later (gtk_tree_view_realize_buttons): add some g_return_if_fail (gtk_tree_view_map): paranoia checks that column->button is shown and unmapped (gtk_tree_view_size_request): only request visible children. Move header size calculation in here, for cleanliness, and to maintain invariants for child widgets if we eventually let users set different children inside the buttons (gtk_tree_view_map_buttons): factor out code to map buttons, since it was being called several times (gtk_tree_view_size_allocate_buttons): move_resize the drag windows instead of just moving them; their height may change if we allow random widgets in there, or the theme changes. (gtk_tree_view_size_allocate): move button size allocation above emitting the scroll signals, to ensure a sane state when we hit user code (gtk_tree_view_button_release): remove queue_resize after tree_view_set_size(), set_size() will handle any resize queuing that's needed (gtk_tree_view_focus_in): just queue a draw, don't fool with draw_focus goo (gtk_tree_view_focus): use gtk_get_current_event() and gdk_event_get_state() (gtk_tree_view_deleted): don't queue_resize() after calling set_size() (gtk_tree_view_build_tree): fix a "if (foo); {}" bug - i.e. remove semicolon (gtk_tree_view_create_button): show the button here (gtk_tree_view_button_clicked): actually emit the clicked signal on the column (_gtk_tree_view_set_size): return right away if the size is unchanged, as a cheesy optimization (gtk_tree_view_setup_model): rename set_model_realized to setup_model to match the flag that indicates whether we've called it (gtk_tree_view_get_hadjustment): create adjustment if it doesn't exist, because set_scroll_adjustment does that and it shouldn't matter what order you call these in (gtk_tree_view_get_vadjustment): ditto (gtk_tree_view_set_headers_visible): canonicalize the bool, for paranoia (gtk_tree_view_set_headers_visible): call gtk_tree_view_map_buttons() instead of using cut-and-paste code (gtk_tree_view_append_column): clarify whether the return value is the count of columns before or after, and do the increment separately from the return statement so you can tell from the code. (gtk_tree_view_remove_column): ditto (gtk_tree_view_insert_column): ditto (gtk_tree_view_get_column): remove g_return_if_fail for columns outside the existing range, the docs say that outside-range columns are allowed, so we handle them as documented. (Presumably this allows a nice loop with column != NULL as test.) (gtk_tree_view_move_to): document what 0.0, 0.5, 1.0 alignments mean (left/right/center etc.). (gtk_tree_view_collapse_all): only queue a draw if we're mapped (gtk_tree_view_expand_row): add docs (gtk_tree_view_collapse_row): add docs * gtk/gtktreeviewcolumn.c (gtk_tree_view_column_clicked): new function to emit the clicked signal on a column * gdk/gdkevents.c (gdk_event_get_state): new function, to get the state of an event (gdk_event_get_time): don't treat GDK_SCROLL as a button event, remove default case from switch so gcc will whine if we don't explicitly handle all event types * gtk/gtktreeselection.h: added some FIXME * gtk/gtktreeprivate.h (struct _GtkTreeViewPrivate): rename "columns" to "n_columns" and "column" to "columns" for clarity
301 lines
10 KiB
C
301 lines
10 KiB
C
/* GdkPixbuf library - Main header file
|
||
*
|
||
* Copyright (C) 1999 The Free Software Foundation
|
||
*
|
||
* Authors: Mark Crichton <crichton@gimp.org>
|
||
* Miguel de Icaza <miguel@gnu.org>
|
||
* Federico Mena-Quintero <federico@gimp.org>
|
||
* Havoc Pennington <hp@redhat.com>
|
||
*
|
||
* This library is free software; you can redistribute it and/or
|
||
* modify it under the terms of the GNU Lesser General Public
|
||
* License as published by the Free Software Foundation; either
|
||
* version 2 of the License, or (at your option) any later version.
|
||
*
|
||
* This library is distributed in the hope that it will be useful,
|
||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
* Lesser General Public License for more details.
|
||
*
|
||
* You should have received a copy of the GNU Lesser General Public
|
||
* License along with this library; if not, write to the
|
||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||
* Boston, MA 02111-1307, USA.
|
||
*/
|
||
|
||
#ifndef GDK_PIXBUF_H
|
||
#define GDK_PIXBUF_H
|
||
|
||
#include <glib.h>
|
||
#include <gdk-pixbuf/gdk-pixbuf-features.h>
|
||
#include <gobject/gobject.h>
|
||
|
||
#ifdef __cplusplus
|
||
extern "C" {
|
||
#endif
|
||
|
||
|
||
|
||
/* Alpha compositing mode */
|
||
typedef enum
|
||
{
|
||
GDK_PIXBUF_ALPHA_BILEVEL,
|
||
GDK_PIXBUF_ALPHA_FULL
|
||
} GdkPixbufAlphaMode;
|
||
|
||
/* Color spaces; right now only RGB is supported.
|
||
* Note that these values are encoded in inline pixbufs
|
||
* as ints, so don't reorder them
|
||
*/
|
||
typedef enum {
|
||
GDK_COLORSPACE_RGB
|
||
} GdkColorspace;
|
||
|
||
/* All of these are opaque structures */
|
||
typedef struct _GdkPixbuf GdkPixbuf;
|
||
typedef struct _GdkPixbufAnimation GdkPixbufAnimation;
|
||
typedef struct _GdkPixbufFrame GdkPixbufFrame;
|
||
|
||
#define GDK_TYPE_PIXBUF (gdk_pixbuf_get_type ())
|
||
#define GDK_PIXBUF(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF, GdkPixbuf))
|
||
#define GDK_IS_PIXBUF(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF))
|
||
|
||
#define GDK_TYPE_PIXBUF_ANIMATION (gdk_pixbuf_animation_get_type ())
|
||
#define GDK_PIXBUF_ANIMATION(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_PIXBUF_ANIMATION, GdkPixbufAnimation))
|
||
#define GDK_IS_PIXBUF_ANIMATION(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_PIXBUF_ANIMATION))
|
||
|
||
|
||
/* Handler that must free the pixel array */
|
||
typedef void (* GdkPixbufDestroyNotify) (guchar *pixels, gpointer data);
|
||
|
||
#define GDK_PIXBUF_ERROR gdk_pixbuf_error_quark ()
|
||
|
||
typedef enum {
|
||
/* image data hosed */
|
||
GDK_PIXBUF_ERROR_CORRUPT_IMAGE,
|
||
/* no mem to load image */
|
||
GDK_PIXBUF_ERROR_INSUFFICIENT_MEMORY,
|
||
/* bad option value passed to save routine */
|
||
GDK_PIXBUF_ERROR_BAD_OPTION_VALUE,
|
||
/* unsupported image type (sort of an ENOSYS) */
|
||
GDK_PIXBUF_ERROR_UNKNOWN_TYPE,
|
||
/* unsupported operation (load, save) for image type */
|
||
GDK_PIXBUF_ERROR_UNSUPPORTED_OPERATION,
|
||
GDK_PIXBUF_ERROR_FAILED
|
||
} GdkPixbufError;
|
||
|
||
GQuark gdk_pixbuf_error_quark () G_GNUC_CONST;
|
||
|
||
|
||
|
||
GType gdk_pixbuf_get_type (void) G_GNUC_CONST;
|
||
|
||
/* Reference counting */
|
||
|
||
GdkPixbuf *gdk_pixbuf_ref (GdkPixbuf *pixbuf);
|
||
void gdk_pixbuf_unref (GdkPixbuf *pixbuf);
|
||
|
||
/* GdkPixbuf accessors */
|
||
|
||
GdkColorspace gdk_pixbuf_get_colorspace (const GdkPixbuf *pixbuf);
|
||
int gdk_pixbuf_get_n_channels (const GdkPixbuf *pixbuf);
|
||
gboolean gdk_pixbuf_get_has_alpha (const GdkPixbuf *pixbuf);
|
||
int gdk_pixbuf_get_bits_per_sample (const GdkPixbuf *pixbuf);
|
||
guchar *gdk_pixbuf_get_pixels (const GdkPixbuf *pixbuf);
|
||
int gdk_pixbuf_get_width (const GdkPixbuf *pixbuf);
|
||
int gdk_pixbuf_get_height (const GdkPixbuf *pixbuf);
|
||
int gdk_pixbuf_get_rowstride (const GdkPixbuf *pixbuf);
|
||
|
||
|
||
|
||
/* Create a blank pixbuf with an optimal rowstride and a new buffer */
|
||
GdkPixbuf *gdk_pixbuf_new (GdkColorspace colorspace, gboolean has_alpha, int bits_per_sample,
|
||
int width, int height);
|
||
|
||
/* Copy a pixbuf */
|
||
|
||
GdkPixbuf *gdk_pixbuf_copy (const GdkPixbuf *pixbuf);
|
||
|
||
/* Create a pixbuf which points to the pixels of another pixbuf */
|
||
GdkPixbuf *gdk_pixbuf_new_subpixbuf (GdkPixbuf *src_pixbuf,
|
||
int src_x,
|
||
int src_y,
|
||
int width,
|
||
int height);
|
||
|
||
/* Simple loading */
|
||
|
||
GdkPixbuf *gdk_pixbuf_new_from_file (const char *filename,
|
||
GError **error);
|
||
|
||
GdkPixbuf *gdk_pixbuf_new_from_data (const guchar *data,
|
||
GdkColorspace colorspace,
|
||
gboolean has_alpha,
|
||
int bits_per_sample,
|
||
int width, int height,
|
||
int rowstride,
|
||
GdkPixbufDestroyNotify destroy_fn,
|
||
gpointer destroy_fn_data);
|
||
|
||
GdkPixbuf *gdk_pixbuf_new_from_xpm_data (const char **data);
|
||
|
||
/* Read an inline pixbuf */
|
||
GdkPixbuf *gdk_pixbuf_new_from_inline (const guchar *inline_pixbuf,
|
||
gboolean copy_pixels,
|
||
int length,
|
||
GError **error);
|
||
|
||
|
||
/* Saving */
|
||
|
||
gboolean gdk_pixbuf_save (GdkPixbuf *pixbuf,
|
||
const char *filename,
|
||
const char *type,
|
||
GError **error,
|
||
...);
|
||
|
||
gboolean gdk_pixbuf_savev (GdkPixbuf *pixbuf,
|
||
const char *filename,
|
||
const char *type,
|
||
char **option_keys,
|
||
char **option_values,
|
||
GError **error);
|
||
|
||
/* Adding an alpha channel */
|
||
GdkPixbuf *gdk_pixbuf_add_alpha (const GdkPixbuf *pixbuf, gboolean substitute_color,
|
||
guchar r, guchar g, guchar b);
|
||
|
||
/* Copy an area of a pixbuf onto another one */
|
||
void gdk_pixbuf_copy_area (const GdkPixbuf *src_pixbuf,
|
||
int src_x, int src_y,
|
||
int width, int height,
|
||
GdkPixbuf *dest_pixbuf,
|
||
int dest_x, int dest_y);
|
||
|
||
/* Brighten/darken and optionally make it pixelated-looking */
|
||
void gdk_pixbuf_saturate_and_pixelate (const GdkPixbuf *src,
|
||
GdkPixbuf *dest,
|
||
gfloat saturation,
|
||
gboolean pixelate);
|
||
|
||
|
||
|
||
/* Rendering to a drawable */
|
||
|
||
|
||
/* Scaling */
|
||
|
||
/* Interpolation modes */
|
||
typedef enum {
|
||
GDK_INTERP_NEAREST,
|
||
GDK_INTERP_TILES,
|
||
GDK_INTERP_BILINEAR,
|
||
GDK_INTERP_HYPER
|
||
} GdkInterpType;
|
||
|
||
void gdk_pixbuf_scale (const GdkPixbuf *src,
|
||
GdkPixbuf *dest,
|
||
int dest_x,
|
||
int dest_y,
|
||
int dest_width,
|
||
int dest_height,
|
||
double offset_x,
|
||
double offset_y,
|
||
double scale_x,
|
||
double scale_y,
|
||
GdkInterpType interp_type);
|
||
void gdk_pixbuf_composite (const GdkPixbuf *src,
|
||
GdkPixbuf *dest,
|
||
int dest_x,
|
||
int dest_y,
|
||
int dest_width,
|
||
int dest_height,
|
||
double offset_x,
|
||
double offset_y,
|
||
double scale_x,
|
||
double scale_y,
|
||
GdkInterpType interp_type,
|
||
int overall_alpha);
|
||
void gdk_pixbuf_composite_color (const GdkPixbuf *src,
|
||
GdkPixbuf *dest,
|
||
int dest_x,
|
||
int dest_y,
|
||
int dest_width,
|
||
int dest_height,
|
||
double offset_x,
|
||
double offset_y,
|
||
double scale_x,
|
||
double scale_y,
|
||
GdkInterpType interp_type,
|
||
int overall_alpha,
|
||
int check_x,
|
||
int check_y,
|
||
int check_size,
|
||
guint32 color1,
|
||
guint32 color2);
|
||
|
||
GdkPixbuf *gdk_pixbuf_scale_simple (const GdkPixbuf *src,
|
||
int dest_width,
|
||
int dest_height,
|
||
GdkInterpType interp_type);
|
||
|
||
GdkPixbuf *gdk_pixbuf_composite_color_simple (const GdkPixbuf *src,
|
||
int dest_width,
|
||
int dest_height,
|
||
GdkInterpType interp_type,
|
||
int overall_alpha,
|
||
int check_size,
|
||
guint32 color1,
|
||
guint32 color2);
|
||
|
||
|
||
|
||
/* Animation support */
|
||
|
||
/* GIF-like animation overlay modes for frames */
|
||
typedef enum {
|
||
GDK_PIXBUF_FRAME_RETAIN,
|
||
GDK_PIXBUF_FRAME_DISPOSE,
|
||
GDK_PIXBUF_FRAME_REVERT
|
||
} GdkPixbufFrameAction;
|
||
|
||
GType gdk_pixbuf_animation_get_type (void) G_GNUC_CONST;
|
||
|
||
GdkPixbufAnimation *gdk_pixbuf_animation_new_from_file (const char *filename,
|
||
GError **error);
|
||
|
||
GdkPixbufAnimation *gdk_pixbuf_animation_ref (GdkPixbufAnimation *animation);
|
||
void gdk_pixbuf_animation_unref (GdkPixbufAnimation *animation);
|
||
|
||
int gdk_pixbuf_animation_get_width (GdkPixbufAnimation *animation);
|
||
int gdk_pixbuf_animation_get_height (GdkPixbufAnimation *animation);
|
||
GList *gdk_pixbuf_animation_get_frames (GdkPixbufAnimation *animation);
|
||
int gdk_pixbuf_animation_get_num_frames (GdkPixbufAnimation *animation);
|
||
|
||
/* Frame accessors */
|
||
|
||
GdkPixbuf *gdk_pixbuf_frame_get_pixbuf (GdkPixbufFrame *frame);
|
||
int gdk_pixbuf_frame_get_x_offset (GdkPixbufFrame *frame);
|
||
int gdk_pixbuf_frame_get_y_offset (GdkPixbufFrame *frame);
|
||
int gdk_pixbuf_frame_get_delay_time (GdkPixbufFrame *frame);
|
||
GdkPixbufFrameAction gdk_pixbuf_frame_get_action (GdkPixbufFrame *frame);
|
||
GdkPixbufFrame *gdk_pixbuf_frame_copy (GdkPixbufFrame *frame);
|
||
void gdk_pixbuf_frame_free (GdkPixbufFrame *frame);
|
||
GType gdk_pixbuf_frame_get_type (void) G_GNUC_CONST;
|
||
#define GDK_TYPE_PIXBUF_FRAME gdk_pixbuf_frame_get_type ()
|
||
|
||
|
||
/* General (presently empty) initialization hooks, primarily for gnome-libs */
|
||
void gdk_pixbuf_preinit (gpointer app, gpointer modinfo);
|
||
void gdk_pixbuf_postinit (gpointer app, gpointer modinfo);
|
||
/* A more user-friendly init function */
|
||
void gdk_pixbuf_init (void);
|
||
|
||
|
||
|
||
#ifdef __cplusplus
|
||
}
|
||
#endif
|
||
|
||
#endif
|