From e42129241681dde7adae7d20697e7b421682fbb4 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 27 Apr 2024 18:23:22 +0200 Subject: Adding upstream version 2.10.22. Signed-off-by: Daniel Baumann --- pdb/groups/item_transform.pdb | 890 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 890 insertions(+) create mode 100644 pdb/groups/item_transform.pdb (limited to 'pdb/groups/item_transform.pdb') diff --git a/pdb/groups/item_transform.pdb b/pdb/groups/item_transform.pdb new file mode 100644 index 0000000..81ee417 --- /dev/null +++ b/pdb/groups/item_transform.pdb @@ -0,0 +1,890 @@ +# GIMP - The GNU 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 3 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, see . + +# "Perlized" from C source by Manish Singh + +# Item Transformations + +# shortcuts + +sub transform_invoke { + my ($progress_text, $assemble_matrix, $check) = @_; + my $success_check = <<"CODE"; + success = gimp_pdb_item_is_attached (item, NULL, + GIMP_PDB_ITEM_CONTENT | + GIMP_PDB_ITEM_POSITION, error); +CODE + + if ($check) { + $success_check = <<"CODE" + success = (gimp_pdb_item_is_attached (item, NULL, + GIMP_PDB_ITEM_CONTENT | + GIMP_PDB_ITEM_POSITION, error) && + $check); +CODE + } + + %invoke = ( + code => <<"CODE" +{ + gint x, y, width, height; + +$success_check + + if (success && + gimp_item_mask_intersect (item, &x, &y, &width, &height)) + { + GimpPDBContext *pdb_context = GIMP_PDB_CONTEXT (context); + GimpImage *image = gimp_item_get_image (item); + GimpChannel *mask = gimp_image_get_mask (image); + GimpMatrix3 matrix; + gint off_x, off_y; + + gimp_item_get_offset (item, &off_x, &off_y); + x += off_x; + y += off_y; + + /* Assemble the transformation matrix */ +$assemble_matrix + + if (progress) + gimp_progress_start (progress, FALSE, _(\"$progress_text\")); + + if (GIMP_IS_DRAWABLE (item) && + item != GIMP_ITEM (mask) && + ! gimp_viewable_get_children (GIMP_VIEWABLE (item)) && + ! gimp_channel_is_empty (mask)) + { + GimpDrawable *drawable; + + drawable = gimp_drawable_transform_affine (GIMP_DRAWABLE (item), + context, &matrix, + pdb_context->transform_direction, + pdb_context->interpolation, + pdb_context->transform_resize, + progress); + + if (drawable) + item = GIMP_ITEM (drawable); + else + success = FALSE; + } + else if (gimp_item_get_linked (item)) + { + gimp_item_linked_transform (item, context, &matrix, + pdb_context->transform_direction, + pdb_context->interpolation, + pdb_context->transform_resize, + progress); + } + else + { + gimp_item_transform (item, context, &matrix, + pdb_context->transform_direction, + pdb_context->interpolation, + gimp_item_get_clip ( + item, pdb_context->transform_resize), + progress); + } + + if (progress) + gimp_progress_end (progress); + } +} +CODE + ) +} + +# The defs + +sub item_transform_translate { + $blurb = 'Translate the item by the specified offsets.'; + + $help = <<'HELP'; +This procedure translates the item by the amounts specified in the +off_x and off_y arguments. These can be negative, and are considered +offsets from the current position. The offsets will be rounded to the +nearest pixel unless the item is a path. + + +If the item is attached to an image and has its linked flag set to +TRUE, all additional items contained in the image which have the +linked flag set to TRUE will also be translated by the specified +offsets. +HELP + + &mitch_pdb_misc('2018', '2.10'); + + @inargs = ( + { name => 'item', type => 'item', + desc => 'The item' }, + { name => 'off_x', type => 'float', + desc => "Offset in x direction" }, + { name => 'off_y', type => 'float', + desc => "Offset in y direction" } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The translated item' } + ); + + %invoke = ( + code => <<'CODE' +{ + if (gimp_pdb_item_is_modifiable (item, + GIMP_PDB_ITEM_POSITION, error)) + { + if (gimp_item_get_linked (item) && gimp_item_is_attached (item)) + { + gimp_item_linked_translate (item, off_x, off_y, TRUE); + } + else + { + gimp_item_translate (item, off_x, off_y, TRUE); + } + } + else + success = FALSE; +} +CODE + ); +} + +sub item_transform_flip_simple { + $blurb = <<'BLURB'; +Flip the specified item either vertically or horizontally. +BLURB + + $help = <<'HELP'; +This procedure flips the specified item. + + +If a selection exists and the item is a drawable, the portion of the +drawable which lies under the selection is cut from the drawable and +made into a floating selection which is then flipped. If auto_center +is set to TRUE, the flip is around the selection's center. Otherwise, +the coordinate of the axis needs to be specified. The return value is +the ID of the flipped floating selection. + + +If there is no selection or the item is not a drawable, the entire +item will be flipped around its center if auto_center is set to TRUE, +otherwise the coordinate of the axis needs to be specified. +Additionally, if the item has its linked flag set to TRUE, all +additional items contained in the image which have the linked flag set +to TRUE will also be flipped around the same axis. The return value +will be equal to the item ID supplied as input. + + +This procedure is affected by the following context setters: +gimp_context_set_transform_resize(). +HELP + + &mitch_pdb_misc('2004', '2.2'); + + @inargs = ( + { name => 'item', type => 'item', + desc => 'The affected item' }, + { name => 'flip_type', + type => 'enum GimpOrientationType (no GIMP_ORIENTATION_UNKNOWN)', + desc => 'Type of flip' }, + { name => 'auto_center', type => 'boolean', + desc => 'Whether to automatically position the axis in the selection center' }, + { name => 'axis', type => 'float', + desc => 'coord. of flip axis' } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The flipped item' } + ); + + %invoke = ( + code => <<'CODE' +{ + gint x, y, width, height; + + success = gimp_pdb_item_is_attached (item, NULL, + GIMP_PDB_ITEM_CONTENT | + GIMP_PDB_ITEM_POSITION, error); + + if (success && + gimp_item_mask_intersect (item, &x, &y, &width, &height)) + { + GimpPDBContext *pdb_context = GIMP_PDB_CONTEXT (context); + GimpImage *image = gimp_item_get_image (item); + GimpChannel *mask = gimp_image_get_mask (image); + gint off_x, off_y; + + gimp_item_get_offset (item, &off_x, &off_y); + x += off_x; + y += off_y; + + gimp_transform_get_flip_axis (x, y, width, height, + flip_type, auto_center, &axis); + + if (GIMP_IS_DRAWABLE (item) && + item != GIMP_ITEM (mask) && + ! gimp_viewable_get_children (GIMP_VIEWABLE (item)) && + ! gimp_channel_is_empty (mask)) + { + GimpDrawable *drawable; + + drawable = gimp_drawable_transform_flip (GIMP_DRAWABLE (item), context, + flip_type, axis, + pdb_context->transform_resize); + + if (drawable) + item = GIMP_ITEM (drawable); + else + success = FALSE; + } + else if (gimp_item_get_linked (item)) + { + gimp_item_linked_flip (item, context, + flip_type, axis, + pdb_context->transform_resize); + } + else + { + gimp_item_flip (item, context, + flip_type, axis, + gimp_item_get_clip ( + item, pdb_context->transform_resize)); + } + } +} +CODE + ); +} + + +sub item_transform_flip { + $blurb = <<'BLURB'; +Flip the specified item around a given line. +BLURB + + $help = <<'HELP'; +This procedure flips the specified item. + + +If a selection exists and the item is a drawable, the portion of the +drawable which lies under the selection is cut from the drawable and +made into a floating selection which is then flipped. The axis to flip +around is specified by specifying two points from that line. The +return value is the ID of the flipped floating selection. + + +If there is no selection or the item is not a drawable, the entire +item will be flipped around the specified axis. Additionally, if the +item has its linked flag set to TRUE, all additional items contained +in the image which have the linked flag set to TRUE will also be +flipped around the same axis. The return value will be equal to the +item ID supplied as input. + + +This procedure is affected by the following context setters: +gimp_context_set_interpolation(), gimp_context_set_transform_direction(), +gimp_context_set_transform_resize(). +HELP + + &mitch_pdb_misc('2010', '2.8'); + + @inargs = ( + { name => 'item', type => 'item', + desc => 'The affected item' }, + { name => 'x0', type => 'float', + desc => 'horz. coord. of one end of axis' }, + { name => 'y0', type => 'float', + desc => 'vert. coord. of one end of axis' }, + { name => 'x1', type => 'float', + desc => 'horz. coord. of other end of axis' }, + { name => 'y1', type => 'float', + desc => 'vert. coord. of other end of axis' } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The flipped item' } + ); + + transform_invoke ("Flipping", < 'item', type => 'item', + desc => 'The affected item' }, + { name => 'x0', type => 'float', + desc => 'The new x coordinate of upper-left corner of original + bounding box' }, + { name => 'y0', type => 'float', + desc => 'The new y coordinate of upper-left corner of original + bounding box' }, + { name => 'x1', type => 'float', + desc => 'The new x coordinate of upper-right corner of original + bounding box' }, + { name => 'y1', type => 'float', + desc => 'The new y coordinate of upper-right corner of original + bounding box' }, + { name => 'x2', type => 'float', + desc => 'The new x coordinate of lower-left corner of original + bounding box' }, + { name => 'y2', type => 'float', + desc => 'The new y coordinate of lower-left corner of original + bounding box' }, + { name => 'x3', type => 'float', + desc => 'The new x coordinate of lower-right corner of original + bounding box' }, + { name => 'y3', type => 'float', + desc => 'The new y coordinate of lower-right corner of original + bounding box' } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The transformed item' } + ); + + transform_invoke ("Perspective", < 'item', type => 'item', + desc => 'The affected item' }, + { name => 'rotate_type', type => 'enum GimpRotationType', + desc => 'Type of rotation' }, + { name => 'auto_center', type => 'boolean', + desc => 'Whether to automatically rotate around the selection center' }, + { name => 'center_x', type => 'float', + desc => 'The hor. coordinate of the center of rotation' }, + { name => 'center_y', type => 'float', + desc => 'The vert. coordinate of the center of rotation' } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The rotated item' } + ); + + %invoke = ( + code => <<'CODE' +{ + gint x, y, width, height; + + success = gimp_pdb_item_is_attached (item, NULL, + GIMP_PDB_ITEM_CONTENT | + GIMP_PDB_ITEM_POSITION, error); + + if (success && + gimp_item_mask_intersect (item, &x, &y, &width, &height)) + { + GimpPDBContext *pdb_context = GIMP_PDB_CONTEXT (context); + GimpImage *image = gimp_item_get_image (item); + GimpChannel *mask = gimp_image_get_mask (image); + gint off_x, off_y; + + gimp_item_get_offset (item, &off_x, &off_y); + x += off_x; + y += off_y; + + gimp_transform_get_rotate_center (x, y, width, height, + auto_center, ¢er_x, ¢er_y); + + if (GIMP_IS_DRAWABLE (item) && + item != GIMP_ITEM (mask) && + ! gimp_viewable_get_children (GIMP_VIEWABLE (item)) && + ! gimp_channel_is_empty (mask)) + { + GimpDrawable *drawable; + + drawable = gimp_drawable_transform_rotate (GIMP_DRAWABLE (item), + context, + rotate_type, + center_x, center_y, + pdb_context->transform_resize); + + if (drawable) + item = GIMP_ITEM (drawable); + else + success = FALSE; + } + else if (gimp_item_get_linked (item)) + { + gimp_item_linked_rotate (item, context, + rotate_type, + center_x, center_y, + pdb_context->transform_resize); + } + else + { + gimp_item_rotate (item, context, + rotate_type, + center_x, center_y, + gimp_item_get_clip ( + item, pdb_context->transform_resize)); + } + } +} +CODE + ); +} + + +sub item_transform_rotate { + $blurb = <<'BLURB'; +Rotate the specified item about given coordinates through the +specified angle. +BLURB + + $help = <<'HELP'; +This function rotates the specified item. + + +If a selection exists and the item is a drawable, the portion of the +drawable which lies under the selection is cut from the drawable and +made into a floating selection which is then rotated by the specified +amount. If auto_center is set to TRUE, the rotation is around the +selection's center. Otherwise, the coordinate of the center point +needs to be specified. The return value is the ID of the rotated +floating selection. + + +If there is no selection or the item is not a drawable, the entire +item will be rotated around its center if auto_center is set to TRUE, +otherwise the coordinate of the center point needs to be specified. +Additionally, if the item has its linked flag set to TRUE, all +additional items contained in the image which have the linked flag set +to TRUE will also be rotated around the same center point. The return +value will be equal to the item ID supplied as input. + + +This procedure is affected by the following context setters: +gimp_context_set_interpolation(), gimp_context_set_transform_direction(), +gimp_context_set_transform_resize(). +HELP + + &mitch_pdb_misc('2010', '2.8'); + + @inargs = ( + { name => 'item', type => 'item', + desc => 'The affected item' }, + { name => 'angle', type => 'float', + desc => 'The angle of rotation (radians)' }, + { name => 'auto_center', type => 'boolean', + desc => 'Whether to automatically rotate around the selection center' }, + { name => 'center_x', type => 'float', + desc => 'The hor. coordinate of the center of rotation' }, + { name => 'center_y', type => 'float', + desc => 'The vert. coordinate of the center of rotation' } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The rotated item' } + ); + + transform_invoke ("Rotating", < 'item', type => 'item', + desc => 'The affected item' }, + { name => 'x0', type => 'float', + desc => 'The new x coordinate of the upper-left corner of the + scaled region' }, + { name => 'y0', type => 'float', + desc => 'The new y coordinate of the upper-left corner of the + scaled region' }, + { name => 'x1', type => 'float', + desc => 'The new x coordinate of the lower-right corner of the + scaled region' }, + { name => 'y1', type => 'float', + desc => 'The new y coordinate of the lower-right corner of the + scaled region' } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The scaled item' } + ); + + transform_invoke ("Scaling", < 'item', type => 'item', + desc => 'The affected item' }, + { name => 'shear_type', + type => 'enum GimpOrientationType (no GIMP_ORIENTATION_UNKNOWN)', + desc => 'Type of shear' }, + { name => 'magnitude', type => 'float', + desc => 'The magnitude of the shear' } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The sheared item' } + ); + + transform_invoke ("Shearing", < 'item', type => 'item', + desc => 'The affected item' }, + { name => 'source_x', type => 'float', + desc => 'X coordinate of the transformation center' }, + { name => 'source_y', type => 'float', + desc => 'Y coordinate of the transformation center' }, + { name => 'scale_x', type => 'float', + desc => 'Amount to scale in x direction' }, + { name => 'scale_y', type => 'float', + desc => 'Amount to scale in y direction' }, + { name => 'angle', type => 'float', + desc => 'The angle of rotation (radians)' }, + { name => 'dest_x', type => 'float', + desc => 'X coordinate of where the center goes' }, + { name => 'dest_y', type => 'float', + desc => 'Y coordinate of where the center goes' } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The transformed item' } + ); + + transform_invoke ("2D Transform", < 'item', type => 'item', + desc => 'The affected item' }, + { name => 'coeff_0_0', type => 'float', + desc => 'coefficient (0,0) of the transformation matrix' }, + { name => 'coeff_0_1', type => 'float', + desc => 'coefficient (0,1) of the transformation matrix' }, + { name => 'coeff_0_2', type => 'float', + desc => 'coefficient (0,2) of the transformation matrix' }, + { name => 'coeff_1_0', type => 'float', + desc => 'coefficient (1,0) of the transformation matrix' }, + { name => 'coeff_1_1', type => 'float', + desc => 'coefficient (1,1) of the transformation matrix' }, + { name => 'coeff_1_2', type => 'float', + desc => 'coefficient (1,2) of the transformation matrix' }, + { name => 'coeff_2_0', type => 'float', + desc => 'coefficient (2,0) of the transformation matrix' }, + { name => 'coeff_2_1', type => 'float', + desc => 'coefficient (2,1) of the transformation matrix' }, + { name => 'coeff_2_2', type => 'float', + desc => 'coefficient (2,2) of the transformation matrix' } + ); + + @outargs = ( + { name => 'item', type => 'item', no_declare => 1, + desc => 'The transformed item' } + ); + + transform_invoke ("2D Transforming", < [@procs], lib => [@procs]); + +$desc = 'Transformation procedures'; +$doc_title = 'gimpitemtransform'; +$doc_short_desc = 'Functions to perform transformations on items.'; +$doc_long_desc = 'Functions to perform transformations on items.'; + +1; -- cgit v1.2.3