1997-11-25 06:05:25 +08:00
|
|
|
/* The GIMP -- an image manipulation program
|
|
|
|
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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 General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
1998-04-13 13:44:11 +08:00
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
1997-11-25 06:05:25 +08:00
|
|
|
*/
|
|
|
|
#ifndef __LAYER_H__
|
|
|
|
#define __LAYER_H__
|
|
|
|
|
Actually use the enum types GimpImageType, GimpImageBaseType,
* app/*.[ch]: Actually use the enum types GimpImageType,
GimpImageBaseType, LayerModeEffects, PaintApplicationMode,
BrushApplicationMode, GimpFillType and ConvertPaletteType, instead
of just int or gint. Hopefully I catched most of the places
where these should be used.
Add an enum ConvolutionType, suffix the too general constants
NORMAL, ABSOLUTE and NEGATIVE with _CONVOL. Use NORMAL_MODE
instead of NORMAL in some places (this was what was intended). Fix
some minor gccisms.
* app/apptypes.h: New file. This file contains the above
enumeration types, and some opaque struct typedefs. It was
necessary to collect these in one header that doesn't include
other headers, because when we started using the above mentioned
types in the headers, all hell broke loose because of the
spaghetti-like cross-inclusion mess between headers.
(An example: Header A includes header B, which includes header C
which includes A. B uses a type defined in A. This is not defined,
because A hasn't defined it yet at the point where it includes B,
and A included from B of course is skipped as we already are
reading A.)
1999-08-19 07:41:39 +08:00
|
|
|
#include "apptypes.h"
|
1998-01-22 15:02:57 +08:00
|
|
|
#include "drawable.h"
|
1997-11-25 06:05:25 +08:00
|
|
|
#include "boundary.h"
|
|
|
|
#include "channel.h"
|
|
|
|
#include "temp_buf.h"
|
|
|
|
#include "tile_manager.h"
|
|
|
|
|
1998-08-16 08:34:20 +08:00
|
|
|
#include "layerF.h"
|
1997-11-25 06:05:25 +08:00
|
|
|
|
1999-08-22 19:45:31 +08:00
|
|
|
/* structure declarations */
|
1997-11-25 06:05:25 +08:00
|
|
|
|
1999-08-22 19:45:31 +08:00
|
|
|
#define GIMP_TYPE_LAYER (gimp_layer_get_type ())
|
|
|
|
#define GIMP_LAYER(obj) (GTK_CHECK_CAST ((obj), GIMP_TYPE_LAYER, GimpLayer))
|
|
|
|
#define GIMP_LAYER_CLASS(klass) (GTK_CHECK_CLASS_CAST ((klass), GIMP_TYPE_LAYER, GimpLayerClass))
|
|
|
|
#define GIMP_IS_LAYER(obj) (GTK_CHECK_TYPE ((obj), GIMP_TYPE_LAYER))
|
|
|
|
#define GIMP_IS_LAYER_CLASS(klass) (GTK_CHECK_CLASS_TYPE ((klass), GIMP_TYPE_LAYER))
|
1998-06-28 16:01:38 +08:00
|
|
|
|
1999-08-22 19:45:31 +08:00
|
|
|
#define GIMP_TYPE_LAYER_MASK (gimp_layer_mask_get_type ())
|
|
|
|
#define GIMP_LAYER_MASK(obj) (GTK_CHECK_CAST ((obj), GIMP_TYPE_LAYER_MASK, GimpLayerMask))
|
|
|
|
#define GIMP_LAYER_MASK_CLASS(klass) (GTK_CHECK_CLASS_CAST ((klass), GIMP_TYPE_LAYER_MASK, GimpLayerMaskClass))
|
|
|
|
#define GIMP_IS_LAYER_MASK(obj) (GTK_CHECK_TYPE ((obj), GIMP_TYPE_LAYER_MASK))
|
|
|
|
#define GIMP_IS_LAYER_MASK_CLASS(klass) (GTK_CHECK_CLASS_TYPE ((klass), GIMP_TYPE_LAYER_MASK))
|
1997-11-25 06:05:25 +08:00
|
|
|
|
1999-08-22 19:45:31 +08:00
|
|
|
GtkType gimp_layer_get_type (void);
|
1998-06-28 16:01:38 +08:00
|
|
|
GtkType gimp_layer_mask_get_type (void);
|
1997-11-25 06:05:25 +08:00
|
|
|
|
|
|
|
/* Special undo types */
|
|
|
|
|
|
|
|
struct _layer_undo
|
|
|
|
{
|
Honest, guv, it's not a feature - it's a tightly integrated package of
Mon Sep 20 12:51:30 EDT 1999 Austin Donnelly <austin@gimp.org>
Honest, guv, it's not a feature - it's a tightly integrated
package of undo system cleanups and fixes.
NEW FILES:
* app/undo_history.c: window showing recent undo (and redo) steps
available.
* app/undo_types.h: broken out of undo.h to fix circular includes.
MODIFIED FILES:
* app/Makefile.am: compile undo_history.c
* app/channel.h: use enum for channel undo type, not just magic
numbers.
* app/layer.h: same for layer undos.
* app/commands.c: edit_show_undo_history_cmd_callback() function to
pull up undo history window.
* app/commands.h: prototype for above.
* app/gdisplay.c: make undo / redo menu items sensitive according
to whether they would do anything. Would be easy to change
the text to say what would be undone/redone, but I don't know
the GTK.
* app/gimpimage.c: new signal emitted by gimage:
UNDO_EVENT. gimp_image_undo_event() function to emit it.
* app/gimpimage.h: prototype for above.
* app/gimpimageP.h: pushing_undo_group member is now an undo_type,
not an int. Keep undo history widget here too (if created).
* app/menus.c: add "Edit/Undo history..." to image menu.
* app/undo.c: new types: enums undo_type and undo_state rather than
ints and magic numbers. All undo_pop_* and undo_free_*
functions made static. New static function
undo_type_to_name(). Issue undo event signals on various
important events (eg undo pushed, undo popped etc).
undo_push() now takes a "dirties_image" arg to say whether
image should be dirtied. Layer moves now dirty the image. A
couple of g_return_if_fails () on undo_pop and undo_redo to
assert we're not in the middle of an undo group.
undo_get_{undo,redo}_name() to peek at names of top items on
undo and redo stacks resp. undo_map_over_{undo,redo}_stack()
to run a function for each item or group on stack. Layer and
channel undos use symbolic names rather than 0 or 1. Array
mapping undo types to names.
* app/undo.h: split out undo types to undo_types.h. Prototypes
for functions described above. undo_event_t enum.
undo_history_new() prototype lives here too.
Random other fixes:
* app/gimpdrawable.c
* app/image_render.c: default labels in switches to keep egcs happy.
* app/nav_window.c: some fixes to (sort of) cope with image res !=
screen res. Still needs work to handle non-square pixels
properly.
* app/paths_dialog.c: bad idea to call gimp_image_dirty()
directly. Even though it's currently commented out.
1999-09-21 01:15:20 +08:00
|
|
|
Layer *layer; /* the actual layer */
|
|
|
|
gint prev_position; /* former position in list */
|
|
|
|
Layer *prev_layer; /* previous active layer */
|
1997-11-25 06:05:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct _layer_mask_undo
|
|
|
|
{
|
Honest, guv, it's not a feature - it's a tightly integrated package of
Mon Sep 20 12:51:30 EDT 1999 Austin Donnelly <austin@gimp.org>
Honest, guv, it's not a feature - it's a tightly integrated
package of undo system cleanups and fixes.
NEW FILES:
* app/undo_history.c: window showing recent undo (and redo) steps
available.
* app/undo_types.h: broken out of undo.h to fix circular includes.
MODIFIED FILES:
* app/Makefile.am: compile undo_history.c
* app/channel.h: use enum for channel undo type, not just magic
numbers.
* app/layer.h: same for layer undos.
* app/commands.c: edit_show_undo_history_cmd_callback() function to
pull up undo history window.
* app/commands.h: prototype for above.
* app/gdisplay.c: make undo / redo menu items sensitive according
to whether they would do anything. Would be easy to change
the text to say what would be undone/redone, but I don't know
the GTK.
* app/gimpimage.c: new signal emitted by gimage:
UNDO_EVENT. gimp_image_undo_event() function to emit it.
* app/gimpimage.h: prototype for above.
* app/gimpimageP.h: pushing_undo_group member is now an undo_type,
not an int. Keep undo history widget here too (if created).
* app/menus.c: add "Edit/Undo history..." to image menu.
* app/undo.c: new types: enums undo_type and undo_state rather than
ints and magic numbers. All undo_pop_* and undo_free_*
functions made static. New static function
undo_type_to_name(). Issue undo event signals on various
important events (eg undo pushed, undo popped etc).
undo_push() now takes a "dirties_image" arg to say whether
image should be dirtied. Layer moves now dirty the image. A
couple of g_return_if_fails () on undo_pop and undo_redo to
assert we're not in the middle of an undo group.
undo_get_{undo,redo}_name() to peek at names of top items on
undo and redo stacks resp. undo_map_over_{undo,redo}_stack()
to run a function for each item or group on stack. Layer and
channel undos use symbolic names rather than 0 or 1. Array
mapping undo types to names.
* app/undo.h: split out undo types to undo_types.h. Prototypes
for functions described above. undo_event_t enum.
undo_history_new() prototype lives here too.
Random other fixes:
* app/gimpdrawable.c
* app/image_render.c: default labels in switches to keep egcs happy.
* app/nav_window.c: some fixes to (sort of) cope with image res !=
screen res. Still needs work to handle non-square pixels
properly.
* app/paths_dialog.c: bad idea to call gimp_image_dirty()
directly. Even though it's currently commented out.
1999-09-21 01:15:20 +08:00
|
|
|
Layer *layer; /* the layer */
|
|
|
|
gboolean apply_mask; /* apply mask? */
|
|
|
|
gboolean edit_mask; /* edit mask or layer? */
|
|
|
|
gboolean show_mask; /* show the mask? */
|
|
|
|
LayerMask *mask; /* the layer mask */
|
|
|
|
gint mode; /* the application mode */
|
1997-11-25 06:05:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct _fs_to_layer_undo
|
|
|
|
{
|
1999-08-22 19:45:31 +08:00
|
|
|
Layer *layer; /* the layer */
|
|
|
|
GimpDrawable *drawable; /* drawable of floating sel */
|
1997-11-25 06:05:25 +08:00
|
|
|
};
|
|
|
|
|
1999-08-22 19:45:31 +08:00
|
|
|
/* function declarations */
|
1997-11-25 06:05:25 +08:00
|
|
|
|
2000-05-13 01:07:54 +08:00
|
|
|
Layer * layer_new (GimpImage *gimage,
|
|
|
|
gint width,
|
|
|
|
gint height,
|
|
|
|
GimpImageType type,
|
|
|
|
gchar *name,
|
|
|
|
gint opacity,
|
|
|
|
LayerModeEffects mode);
|
|
|
|
Layer * layer_copy (Layer *layer,
|
|
|
|
gboolean add_alpha);
|
|
|
|
Layer * layer_ref (Layer *layer);
|
|
|
|
void layer_unref (Layer *layer);
|
|
|
|
|
|
|
|
Layer * layer_new_from_tiles (GimpImage *gimage,
|
|
|
|
GimpImageType layer_type,
|
|
|
|
TileManager *tiles,
|
|
|
|
gchar *name,
|
|
|
|
gint opacity,
|
|
|
|
LayerModeEffects mode);
|
|
|
|
gboolean layer_check_scaling (Layer *layer,
|
|
|
|
gint new_width,
|
|
|
|
gint new_height);
|
|
|
|
LayerMask * layer_create_mask (Layer *layer,
|
|
|
|
AddMaskType add_mask_type);
|
|
|
|
LayerMask * layer_add_mask (Layer *layer,
|
|
|
|
LayerMask *mask);
|
|
|
|
Layer * layer_get_ID (gint ID);
|
|
|
|
void layer_delete (Layer *layer);
|
|
|
|
void layer_removed (Layer *layer,
|
|
|
|
gpointer data);
|
|
|
|
void layer_apply_mask (Layer *layer,
|
|
|
|
MaskApplyMode mode);
|
|
|
|
void layer_temporarily_translate (Layer *layer,
|
|
|
|
gint off_x,
|
|
|
|
gint off_y);
|
|
|
|
void layer_translate (Layer *layer,
|
|
|
|
gint off_x,
|
|
|
|
gint off_y);
|
|
|
|
void layer_add_alpha (Layer *layer);
|
|
|
|
gboolean layer_scale_by_factors (Layer *layer,
|
|
|
|
gdouble w_factor,
|
|
|
|
gdouble h_factor);
|
|
|
|
void layer_scale (Layer *layer,
|
|
|
|
gint new_width,
|
|
|
|
gint new_height,
|
|
|
|
gboolean local_origin);
|
|
|
|
void layer_resize (Layer *layer,
|
|
|
|
gint new_width,
|
|
|
|
gint new_height,
|
|
|
|
gint offx,
|
|
|
|
gint offy);
|
|
|
|
void layer_resize_to_image (Layer *layer);
|
|
|
|
BoundSeg * layer_boundary (Layer *layer,
|
|
|
|
gint *num_segs);
|
|
|
|
void layer_invalidate_boundary (Layer *layer);
|
|
|
|
gint layer_pick_correlate (Layer *layer,
|
|
|
|
gint x,
|
|
|
|
gint y);
|
|
|
|
|
|
|
|
LayerMask * layer_mask_new (GimpImage *gimage,
|
|
|
|
gint width,
|
|
|
|
gint height,
|
|
|
|
gchar *name,
|
|
|
|
gint opacity,
|
|
|
|
guchar *col);
|
|
|
|
LayerMask * layer_mask_copy (LayerMask *layer_mask);
|
|
|
|
void layer_mask_delete (LayerMask *layer_mask);
|
|
|
|
LayerMask * layer_mask_get_ID (gint ID);
|
|
|
|
LayerMask * layer_mask_ref (LayerMask *layer_mask);
|
|
|
|
void layer_mask_unref (LayerMask *layer_mask);
|
|
|
|
void layer_mask_set_layer (LayerMask *layer_mask,
|
|
|
|
Layer *layer);
|
|
|
|
Layer * layer_mask_get_layer (LayerMask *layer_mask);
|
1998-01-22 15:02:57 +08:00
|
|
|
|
1999-08-22 19:45:31 +08:00
|
|
|
/* access functions */
|
1997-11-25 06:05:25 +08:00
|
|
|
|
2000-05-13 01:07:54 +08:00
|
|
|
void layer_set_name (Layer *layer,
|
|
|
|
gchar *name);
|
|
|
|
gchar * layer_get_name (Layer *layer);
|
|
|
|
guchar * layer_data (Layer *layer);
|
|
|
|
LayerMask * layer_get_mask (Layer *layer);
|
|
|
|
gboolean layer_has_alpha (Layer *layer);
|
|
|
|
gboolean layer_is_floating_sel (Layer *layer);
|
|
|
|
gboolean layer_linked (Layer *layer);
|
|
|
|
TempBuf * layer_preview (Layer *layer,
|
|
|
|
gint width,
|
|
|
|
gint height);
|
|
|
|
TempBuf * layer_mask_preview (Layer *layer,
|
|
|
|
gint width,
|
|
|
|
gint height);
|
|
|
|
|
|
|
|
void layer_invalidate_previews (GimpImage *gimage);
|
|
|
|
Tattoo layer_get_tattoo (const Layer *layer);
|
|
|
|
void layer_set_tattoo (const Layer *layer,
|
|
|
|
Tattoo value);
|
1998-01-22 15:02:57 +08:00
|
|
|
|
1999-08-22 19:45:31 +08:00
|
|
|
#define drawable_layer GIMP_IS_LAYER
|
1998-06-30 23:31:32 +08:00
|
|
|
#define drawable_layer_mask GIMP_IS_LAYER_MASK
|
1998-01-22 15:02:57 +08:00
|
|
|
|
2000-05-13 01:07:54 +08:00
|
|
|
void channel_layer_alpha (Channel *mask,
|
|
|
|
Layer *layer);
|
1999-08-22 19:45:31 +08:00
|
|
|
/* from channel.c */
|
2000-05-13 01:07:54 +08:00
|
|
|
void channel_layer_mask (Channel *mask,
|
|
|
|
Layer *layer);
|
1998-01-22 15:02:57 +08:00
|
|
|
|
1997-11-25 06:05:25 +08:00
|
|
|
#endif /* __LAYER_H__ */
|