2001-10-22 Michael Natterer <mitch@gimp.org> General cleanup of the selection tools and their PDB wrappers: * app/core/Makefile.am * app/core/gimpimage-contiguous-region.[ch] * app/core/gimpimage-mask-select.[ch]: new files providing a clean, uniform API for the selection functionalities. Changed order of parameters to be consistent, removed code duplication. The region returned by the "by_color" function is not really contiguous but the API is so similar to "by_seed" and it's used in the same context so it's fair enough to put them together. Also, I'm not sure if the two is_pixel_sufficiently_different() I've optimized away were meant to do *exactly* the same. Added a comment there to remember the former difference. * app/core/gimpchannel.[ch] (gimp_channel_feather): removed the "output" channel parameter and made it optionally push an undo (like the other channel operations do). * app/core/gimpimage-mask.c: call gimp_channel_feather() with "push_undo == TRUE", removed some useless comments. * app/tools/gimpbycolorselecttool.[ch] * app/tools/gimpellipseselecttool.[ch] * app/tools/gimpfreeselecttool.[ch] * app/tools/gimpfuzzyselecttool.[ch] * app/tools/gimprectselecttool.[ch]: removed all the actual selection functionality and call the new gimp_image_mask_select_*() and gimp_image_contiguous_region_*() functions instead. * app/tools/gimpbezierselecttool.c * app/tools/gimpiscissorstool.c: use new function gimp_image_mask_select_channel() instead of doing the same manually. * app/tools/gimpbucketfilltool.c: find_contiguous_region() -> gimp_image_contiguous_region_by_seed(). * tools/pdbgen/Makefile.am * tools/pdbgen/groups.pl * tools/pdbgen/pdb/selection_tools.pdb: added new group "Selection Tools" which depends only on "core/" stuff (not on "tools/" any more, brrrr). * tools/pdbgen/pdb/text_tool.pdb: don't include "appenv.h" * tools/pdbgen/pdb/tools.pdb: removed the selection tools. * app/pdb/Makefile.am * app/pdb/selection_tools_cmds.c: new file. * app/pdb/internal_procs.c * app/pdb/text_tool_cmds.c * app/pdb/tools_cmds.c: regenerated. * libgimp/Makefile.am * libgimp/gimp_pdb.h * libgimp/gimpselectiontools_pdb.[ch]: new files. * libgimp/gimptools_pdb.[ch]: regenerated Misc cleanups: * app/app_procs.c: call splash_create() with "no_splash_image" as parameter. * app/display/gimpdisplay-render.c * app/display/gximage.c: don't include "appenv.h". * app/gui/gui.c: call session_restore() only if "restore_session" is TRUE. * app/gui/session.c: don't "if(restore_session)" here and don't include "appenv.h" * app/gui/splash.[ch]: added "gboolean show_image" parameter to splash_create(), don't include "appenv.h" * app/tools/gimppainttool.[ch]: added a "GimpGradient" parameter to gimp_paint_tool_get_color_from_gradient(). * app/tools/gimppaintbrushtool.c: pass the gradient. * app/tools/gimpselectiontool.c * app/tools/gimptransformtool.c * app/tools/tool_manager.c: s/GDisplay/GimpDisplay/. * app/widgets/gimpcontainergridview.[ch]: removed the "white_style" class variable and don't fiddle around with colors and styles... * themes/Default/gtkrc: ...do the same here with a simple rc style.
623 lines
16 KiB
C
623 lines
16 KiB
C
/* The GIMP -- an image manipulation program
|
|
* Copyright (C) 1995-2000 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
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
/* NOTE: This file is autogenerated by pdbgen.pl. */
|
|
|
|
#include "config.h"
|
|
|
|
|
|
#include <glib-object.h>
|
|
|
|
#include "libgimpbase/gimpbasetypes.h"
|
|
|
|
#include "pdb-types.h"
|
|
#include "procedural_db.h"
|
|
|
|
#include "core/core-types.h"
|
|
#include "core/gimpdrawable.h"
|
|
#include "core/gimpimage-mask-select.h"
|
|
#include "core/gimpimage.h"
|
|
|
|
#include "libgimpcolor/gimpcolor.h"
|
|
|
|
static ProcRecord by_color_select_proc;
|
|
static ProcRecord ellipse_select_proc;
|
|
static ProcRecord free_select_proc;
|
|
static ProcRecord fuzzy_select_proc;
|
|
static ProcRecord rect_select_proc;
|
|
|
|
void
|
|
register_selection_tools_procs (Gimp *gimp)
|
|
{
|
|
procedural_db_register (gimp, &by_color_select_proc);
|
|
procedural_db_register (gimp, &ellipse_select_proc);
|
|
procedural_db_register (gimp, &free_select_proc);
|
|
procedural_db_register (gimp, &fuzzy_select_proc);
|
|
procedural_db_register (gimp, &rect_select_proc);
|
|
}
|
|
|
|
static Argument *
|
|
by_color_select_invoker (Gimp *gimp,
|
|
Argument *args)
|
|
{
|
|
gboolean success = TRUE;
|
|
GimpDrawable *drawable;
|
|
GimpRGB color;
|
|
gint32 threshold;
|
|
gint32 operation;
|
|
gboolean antialias;
|
|
gboolean feather;
|
|
gdouble feather_radius;
|
|
gboolean sample_merged;
|
|
GimpImage *gimage;
|
|
|
|
drawable = gimp_drawable_get_by_ID (gimp, args[0].value.pdb_int);
|
|
if (drawable == NULL)
|
|
success = FALSE;
|
|
|
|
color = args[1].value.pdb_color;
|
|
|
|
threshold = args[2].value.pdb_int;
|
|
if (threshold < 0 || threshold > 255)
|
|
success = FALSE;
|
|
|
|
operation = args[3].value.pdb_int;
|
|
if (operation < CHANNEL_OP_ADD || operation > CHANNEL_OP_INTERSECT)
|
|
success = FALSE;
|
|
|
|
antialias = args[4].value.pdb_int ? TRUE : FALSE;
|
|
|
|
feather = args[5].value.pdb_int ? TRUE : FALSE;
|
|
|
|
feather_radius = args[6].value.pdb_float;
|
|
|
|
sample_merged = args[7].value.pdb_int ? TRUE : FALSE;
|
|
|
|
if (success)
|
|
{
|
|
gimage = gimp_drawable_gimage (GIMP_DRAWABLE (drawable));
|
|
|
|
gimp_image_mask_select_by_color (gimage, drawable,
|
|
sample_merged,
|
|
&color,
|
|
threshold,
|
|
operation, antialias,
|
|
feather,
|
|
feather_radius,
|
|
feather_radius);
|
|
}
|
|
|
|
return procedural_db_return_args (&by_color_select_proc, success);
|
|
}
|
|
|
|
static ProcArg by_color_select_inargs[] =
|
|
{
|
|
{
|
|
GIMP_PDB_DRAWABLE,
|
|
"drawable",
|
|
"The affected drawable"
|
|
},
|
|
{
|
|
GIMP_PDB_COLOR,
|
|
"color",
|
|
"The color to select"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"threshold",
|
|
"Threshold in intensity levels 0 <= threshold <= 255"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"operation",
|
|
"The selection operation: { ADD (0), SUB (1), REPLACE (2), INTERSECT (3) }"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"antialias",
|
|
"Antialiasing (TRUE or FALSE)"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"feather",
|
|
"Feather option for selections"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"feather_radius",
|
|
"Radius for feather operation"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"sample_merged",
|
|
"Use the composite image, not the drawable"
|
|
}
|
|
};
|
|
|
|
static ProcRecord by_color_select_proc =
|
|
{
|
|
"gimp_by_color_select",
|
|
"Create a selection by selecting all pixels (in the specified drawable) with the same (or similar) color to that specified.",
|
|
"This tool creates a selection over the specified image. A by-color selection is determined by the supplied color under the constraints of the specified threshold. Essentially, all pixels (in the drawable) that have color sufficiently close to the specified color (as determined by the threshold value) are included in the selection. The antialiasing parameter allows the final selection mask to contain intermediate values based on close misses to the threshold bar. Feathering can be enabled optionally and is controlled with the \"feather_radius\" parameter. If the sample_merged parameter is non-zero, the data of the composite image will be used instead of that for the specified drawable. This is equivalent to sampling for colors after merging all visible layers. In the case of a merged sampling, the supplied drawable is ignored.",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"1995-1996",
|
|
GIMP_INTERNAL,
|
|
8,
|
|
by_color_select_inargs,
|
|
0,
|
|
NULL,
|
|
{ { by_color_select_invoker } }
|
|
};
|
|
|
|
static Argument *
|
|
ellipse_select_invoker (Gimp *gimp,
|
|
Argument *args)
|
|
{
|
|
gboolean success = TRUE;
|
|
GimpImage *gimage;
|
|
gdouble x;
|
|
gdouble y;
|
|
gdouble width;
|
|
gdouble height;
|
|
gint32 operation;
|
|
gboolean antialias;
|
|
gboolean feather;
|
|
gdouble feather_radius;
|
|
|
|
gimage = gimp_image_get_by_ID (gimp, args[0].value.pdb_int);
|
|
if (gimage == NULL)
|
|
success = FALSE;
|
|
|
|
x = args[1].value.pdb_float;
|
|
|
|
y = args[2].value.pdb_float;
|
|
|
|
width = args[3].value.pdb_float;
|
|
if (width <= 0.0)
|
|
success = FALSE;
|
|
|
|
height = args[4].value.pdb_float;
|
|
if (height <= 0.0)
|
|
success = FALSE;
|
|
|
|
operation = args[5].value.pdb_int;
|
|
if (operation < CHANNEL_OP_ADD || operation > CHANNEL_OP_INTERSECT)
|
|
success = FALSE;
|
|
|
|
antialias = args[6].value.pdb_int ? TRUE : FALSE;
|
|
|
|
feather = args[7].value.pdb_int ? TRUE : FALSE;
|
|
|
|
feather_radius = args[8].value.pdb_float;
|
|
|
|
if (success)
|
|
gimp_image_mask_select_ellipse (gimage,
|
|
(gint) x, (gint) y,
|
|
(gint) width, (gint) height,
|
|
operation,
|
|
antialias,
|
|
feather,
|
|
feather_radius,
|
|
feather_radius);
|
|
|
|
return procedural_db_return_args (&ellipse_select_proc, success);
|
|
}
|
|
|
|
static ProcArg ellipse_select_inargs[] =
|
|
{
|
|
{
|
|
GIMP_PDB_IMAGE,
|
|
"image",
|
|
"The image"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"x",
|
|
"x coordinate of upper-left corner of ellipse bounding box"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"y",
|
|
"y coordinate of upper-left corner of ellipse bounding box"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"width",
|
|
"The width of the ellipse: 0 < width"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"height",
|
|
"The height of the ellipse: 0 < height"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"operation",
|
|
"The selection operation: { ADD (0), SUB (1), REPLACE (2), INTERSECT (3) }"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"antialias",
|
|
"Antialiasing (TRUE or FALSE)"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"feather",
|
|
"Feather option for selections"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"feather_radius",
|
|
"Radius for feather operation"
|
|
}
|
|
};
|
|
|
|
static ProcRecord ellipse_select_proc =
|
|
{
|
|
"gimp_ellipse_select",
|
|
"Create an elliptical selection over the specified image.",
|
|
"This tool creates an elliptical selection over the specified image. The elliptical region can be either added to, subtracted from, or replace the contents of the previous selection mask. If antialiasing is turned on, the edges of the elliptical region will contain intermediate values which give the appearance of a sharper, less pixelized edge. This should be set as TRUE most of the time. If the feather option is enabled, the resulting selection is blurred before combining. The blur is a gaussian blur with the specified feather radius.",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"1995-1996",
|
|
GIMP_INTERNAL,
|
|
9,
|
|
ellipse_select_inargs,
|
|
0,
|
|
NULL,
|
|
{ { ellipse_select_invoker } }
|
|
};
|
|
|
|
static Argument *
|
|
free_select_invoker (Gimp *gimp,
|
|
Argument *args)
|
|
{
|
|
gboolean success = TRUE;
|
|
GimpImage *gimage;
|
|
gint32 num_segs;
|
|
gdouble *segs;
|
|
gint32 operation;
|
|
gboolean antialias;
|
|
gboolean feather;
|
|
gdouble feather_radius;
|
|
|
|
gimage = gimp_image_get_by_ID (gimp, args[0].value.pdb_int);
|
|
if (gimage == NULL)
|
|
success = FALSE;
|
|
|
|
num_segs = args[1].value.pdb_int;
|
|
if (!(num_segs < 2))
|
|
num_segs /= 2;
|
|
else
|
|
success = FALSE;
|
|
|
|
segs = (gdouble *) args[2].value.pdb_pointer;
|
|
|
|
operation = args[3].value.pdb_int;
|
|
if (operation < CHANNEL_OP_ADD || operation > CHANNEL_OP_INTERSECT)
|
|
success = FALSE;
|
|
|
|
antialias = args[4].value.pdb_int ? TRUE : FALSE;
|
|
|
|
feather = args[5].value.pdb_int ? TRUE : FALSE;
|
|
|
|
feather_radius = args[6].value.pdb_float;
|
|
|
|
if (success)
|
|
gimp_image_mask_select_polygon (gimage,
|
|
num_segs,
|
|
(GimpVector2 *) segs,
|
|
operation,
|
|
antialias,
|
|
feather,
|
|
feather_radius,
|
|
feather_radius);
|
|
|
|
return procedural_db_return_args (&free_select_proc, success);
|
|
}
|
|
|
|
static ProcArg free_select_inargs[] =
|
|
{
|
|
{
|
|
GIMP_PDB_IMAGE,
|
|
"image",
|
|
"The image"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"num_segs",
|
|
"Number of points (count 1 coordinate as two points)"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOATARRAY,
|
|
"segs",
|
|
"Array of points: { p1.x, p1.y, p2.x, p2.y, ..., pn.x, pn.y}"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"operation",
|
|
"The selection operation: { ADD (0), SUB (1), REPLACE (2), INTERSECT (3) }"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"antialias",
|
|
"Antialiasing (TRUE or FALSE)"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"feather",
|
|
"Feather option for selections"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"feather_radius",
|
|
"Radius for feather operation"
|
|
}
|
|
};
|
|
|
|
static ProcRecord free_select_proc =
|
|
{
|
|
"gimp_free_select",
|
|
"Create a polygonal selection over the specified image.",
|
|
"This tool creates a polygonal selection over the specified image. The polygonal region can be either added to, subtracted from, or replace the contents of the previous selection mask. The polygon is specified through an array of floating point numbers and its length. The length of array must be 2n, where n is the number of points. Each point is defined by 2 floating point values which correspond to the x and y coordinates. If the final point does not connect to the starting point, a connecting segment is automatically added. If the feather option is enabled, the resulting selection is blurred before combining. The blur is a gaussian blur with the specified feather radius.",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"1995-1996",
|
|
GIMP_INTERNAL,
|
|
7,
|
|
free_select_inargs,
|
|
0,
|
|
NULL,
|
|
{ { free_select_invoker } }
|
|
};
|
|
|
|
static Argument *
|
|
fuzzy_select_invoker (Gimp *gimp,
|
|
Argument *args)
|
|
{
|
|
gboolean success = TRUE;
|
|
GimpDrawable *drawable;
|
|
gdouble x;
|
|
gdouble y;
|
|
gint32 threshold;
|
|
gint32 operation;
|
|
gboolean antialias;
|
|
gboolean feather;
|
|
gdouble feather_radius;
|
|
gboolean sample_merged;
|
|
GimpImage *gimage;
|
|
|
|
drawable = gimp_drawable_get_by_ID (gimp, args[0].value.pdb_int);
|
|
if (drawable == NULL)
|
|
success = FALSE;
|
|
|
|
x = args[1].value.pdb_float;
|
|
|
|
y = args[2].value.pdb_float;
|
|
|
|
threshold = args[3].value.pdb_int;
|
|
if (threshold < 0 || threshold > 255)
|
|
success = FALSE;
|
|
|
|
operation = args[4].value.pdb_int;
|
|
if (operation < CHANNEL_OP_ADD || operation > CHANNEL_OP_INTERSECT)
|
|
success = FALSE;
|
|
|
|
antialias = args[5].value.pdb_int ? TRUE : FALSE;
|
|
|
|
feather = args[6].value.pdb_int ? TRUE : FALSE;
|
|
|
|
feather_radius = args[7].value.pdb_float;
|
|
|
|
sample_merged = args[8].value.pdb_int ? TRUE : FALSE;
|
|
|
|
if (success)
|
|
{
|
|
gimage = gimp_drawable_gimage (GIMP_DRAWABLE (drawable));
|
|
|
|
gimp_image_mask_select_fuzzy (gimage,
|
|
drawable,
|
|
sample_merged,
|
|
x, y,
|
|
threshold,
|
|
operation,
|
|
antialias,
|
|
feather,
|
|
feather_radius,
|
|
feather_radius);
|
|
}
|
|
|
|
return procedural_db_return_args (&fuzzy_select_proc, success);
|
|
}
|
|
|
|
static ProcArg fuzzy_select_inargs[] =
|
|
{
|
|
{
|
|
GIMP_PDB_DRAWABLE,
|
|
"drawable",
|
|
"The affected drawable"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"x",
|
|
"x coordinate of initial seed fill point: (image coordinates)"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"y",
|
|
"y coordinate of initial seed fill point: (image coordinates)"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"threshold",
|
|
"Threshold in intensity levels 0 <= threshold <= 255"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"operation",
|
|
"The selection operation: { ADD (0), SUB (1), REPLACE (2), INTERSECT (3) }"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"antialias",
|
|
"Antialiasing (TRUE or FALSE)"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"feather",
|
|
"Feather option for selections"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"feather_radius",
|
|
"Radius for feather operation"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"sample_merged",
|
|
"Use the composite image, not the drawable"
|
|
}
|
|
};
|
|
|
|
static ProcRecord fuzzy_select_proc =
|
|
{
|
|
"gimp_fuzzy_select",
|
|
"Create a fuzzy selection starting at the specified coordinates on the specified drawable.",
|
|
"This tool creates a fuzzy selection over the specified image. A fuzzy selection is determined by a seed fill under the constraints of the specified threshold. Essentially, the color at the specified coordinates (in the drawable) is measured and the selection expands outwards from that point to any adjacent pixels which are not significantly different (as determined by the threshold value). This process continues until no more expansion is possible. The antialiasing parameter allows the final selection mask to contain intermediate values based on close misses to the threshold bar at pixels along the seed fill boundary. Feathering can be enabled optionally and is controlled with the \"feather_radius\" paramter. If the sample_merged parameter is non-zero, the data of the composite image will be used instead of that for the specified drawable. This is equivalent to sampling for colors after merging all visible layers. In the case of a merged sampling, the supplied drawable is ignored."
|
|
"If the sample is merged, the specified coordinates are relative to the image origin; otherwise, they are relative to the drawable's origin.",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"1995-1996",
|
|
GIMP_INTERNAL,
|
|
9,
|
|
fuzzy_select_inargs,
|
|
0,
|
|
NULL,
|
|
{ { fuzzy_select_invoker } }
|
|
};
|
|
|
|
static Argument *
|
|
rect_select_invoker (Gimp *gimp,
|
|
Argument *args)
|
|
{
|
|
gboolean success = TRUE;
|
|
GimpImage *gimage;
|
|
gdouble x;
|
|
gdouble y;
|
|
gdouble width;
|
|
gdouble height;
|
|
gint32 operation;
|
|
gboolean feather;
|
|
gdouble feather_radius;
|
|
|
|
gimage = gimp_image_get_by_ID (gimp, args[0].value.pdb_int);
|
|
if (gimage == NULL)
|
|
success = FALSE;
|
|
|
|
x = args[1].value.pdb_float;
|
|
|
|
y = args[2].value.pdb_float;
|
|
|
|
width = args[3].value.pdb_float;
|
|
if (width <= 0.0)
|
|
success = FALSE;
|
|
|
|
height = args[4].value.pdb_float;
|
|
if (height <= 0.0)
|
|
success = FALSE;
|
|
|
|
operation = args[5].value.pdb_int;
|
|
if (operation < CHANNEL_OP_ADD || operation > CHANNEL_OP_INTERSECT)
|
|
success = FALSE;
|
|
|
|
feather = args[6].value.pdb_int ? TRUE : FALSE;
|
|
|
|
feather_radius = args[7].value.pdb_float;
|
|
|
|
if (success)
|
|
gimp_image_mask_select_rectangle (gimage,
|
|
(gint) x, (gint) y,
|
|
(gint) width, (gint) height,
|
|
operation,
|
|
feather,
|
|
feather_radius,
|
|
feather_radius);
|
|
|
|
return procedural_db_return_args (&rect_select_proc, success);
|
|
}
|
|
|
|
static ProcArg rect_select_inargs[] =
|
|
{
|
|
{
|
|
GIMP_PDB_IMAGE,
|
|
"image",
|
|
"The image"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"x",
|
|
"x coordinate of upper-left corner of rectangle"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"y",
|
|
"y coordinate of upper-left corner of rectangle"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"width",
|
|
"The width of the rectangle: 0 < width"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"height",
|
|
"The height of the rectangle: 0 < height"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"operation",
|
|
"The selection operation: { ADD (0), SUB (1), REPLACE (2), INTERSECT (3) }"
|
|
},
|
|
{
|
|
GIMP_PDB_INT32,
|
|
"feather",
|
|
"Feather option for selections"
|
|
},
|
|
{
|
|
GIMP_PDB_FLOAT,
|
|
"feather_radius",
|
|
"Radius for feather operation"
|
|
}
|
|
};
|
|
|
|
static ProcRecord rect_select_proc =
|
|
{
|
|
"gimp_rect_select",
|
|
"Create a rectangular selection over the specified image;",
|
|
"This tool creates a rectangular selection over the specified image. The rectangular region can be either added to, subtracted from, or replace the contents of the previous selection mask. If the feather option is enabled, the resulting selection is blurred before combining. The blur is a gaussian blur with the specified feather radius.",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"Spencer Kimball & Peter Mattis",
|
|
"1995-1996",
|
|
GIMP_INTERNAL,
|
|
8,
|
|
rect_select_inargs,
|
|
0,
|
|
NULL,
|
|
{ { rect_select_invoker } }
|
|
};
|