forked from openkylin/gimp
908 lines
22 KiB
Plaintext
908 lines
22 KiB
Plaintext
# 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 <https://www.gnu.org/licenses/>.
|
|
|
|
# "Perlized" from C source by Manish Singh <yosh@gimp.org>
|
|
|
|
sub brush_new {
|
|
$blurb = "Creates a new brush.";
|
|
$help = "This procedure creates a new, uninitialized brush.";
|
|
|
|
&mitch_pdb_misc('2004', '2.2');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The requested name of the new brush' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'actual_name', type => 'string',
|
|
desc => 'The actual new brush name. The returned value must be freed with g_free()' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpData *data = gimp_data_factory_data_new (gimp->brush_factory,
|
|
context, name);
|
|
|
|
if (data)
|
|
actual_name = g_strdup (gimp_object_get_name (data));
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_duplicate {
|
|
$blurb = "Duplicates a brush.";
|
|
$help = "This procedure creates an identical brush by a different name.";
|
|
|
|
&mitch_pdb_misc('2004', '2.2');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'copy_name', type => 'string',
|
|
desc => "The name of the brush's copy. The returned value must be freed with g_free()" }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
{
|
|
GimpBrush *brush_copy = (GimpBrush *)
|
|
gimp_data_factory_data_duplicate (gimp->brush_factory,
|
|
GIMP_DATA (brush));
|
|
|
|
if (brush_copy)
|
|
copy_name = g_strdup (gimp_object_get_name (brush_copy));
|
|
else
|
|
success = FALSE;
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_is_generated {
|
|
$blurb = "Tests if brush is generated.";
|
|
$help = "Returns TRUE if this brush is parametric, FALSE for other types.";
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'generated', type => 'boolean',
|
|
desc => 'TRUE if the brush is generated' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
generated = GIMP_IS_BRUSH_GENERATED (brush);
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_is_editable {
|
|
$blurb = "Tests if brush can be edited.";
|
|
$help = "Returns TRUE if you have permission to change the brush.";
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'editable', type => 'boolean',
|
|
desc => 'TRUE if the brush can be edited' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
editable = gimp_data_is_writable (GIMP_DATA (brush));
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_rename {
|
|
$blurb = "Renames a brush.";
|
|
$help = "This procedure renames a brush.";
|
|
|
|
&mitch_pdb_misc('2004', '2.2');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' },
|
|
{ name => 'new_name', type => 'string', non_empty => 1,
|
|
desc => 'The new name of the brush' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'actual_name', type => 'string',
|
|
desc => 'The actual new name of the brush. The returned value must be freed with g_free()' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_RENAME, error);
|
|
|
|
if (brush)
|
|
{
|
|
gimp_object_set_name (GIMP_OBJECT (brush), new_name);
|
|
actual_name = g_strdup (gimp_object_get_name (brush));
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_delete {
|
|
$blurb = "Deletes a brush.";
|
|
$help = "This procedure deletes a brush.";
|
|
|
|
&mitch_pdb_misc('2004', '2.2');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush && gimp_data_is_deletable (GIMP_DATA (brush)))
|
|
success = gimp_data_factory_data_delete (gimp->brush_factory,
|
|
GIMP_DATA (brush),
|
|
TRUE, error);
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_get_info {
|
|
$blurb = "Retrieves information about the specified brush.";
|
|
|
|
$help = <<'HELP';
|
|
This procedure retrieves information about the specified brush:
|
|
brush extents (width and height), color depth and mask depth.
|
|
HELP
|
|
|
|
&mitch_pdb_misc('2004', '2.2');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'width', type => 'int32', void_ret => 1,
|
|
desc => 'The brush width' },
|
|
{ name => 'height', type => 'int32',
|
|
desc => 'The brush height' },
|
|
{ name => 'mask_bpp', type => 'int32',
|
|
desc => 'The brush mask bpp' },
|
|
{ name => 'color_bpp', type => 'int32',
|
|
desc => 'The brush color bpp' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
{
|
|
GimpTempBuf *mask = gimp_brush_get_mask (brush);
|
|
GimpTempBuf *pixmap = gimp_brush_get_pixmap (brush);
|
|
const Babl *format;
|
|
|
|
format = gimp_babl_compat_u8_mask_format (
|
|
gimp_temp_buf_get_format (mask));
|
|
|
|
width = gimp_brush_get_width (brush);
|
|
height = gimp_brush_get_height (brush);
|
|
mask_bpp = babl_format_get_bytes_per_pixel (format);
|
|
|
|
if (pixmap)
|
|
{
|
|
format = gimp_babl_compat_u8_format (
|
|
gimp_temp_buf_get_format (pixmap));
|
|
|
|
color_bpp = babl_format_get_bytes_per_pixel (format);
|
|
}
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_get_pixels {
|
|
$blurb = 'Retrieves information about the specified brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure retrieves information about the specified brush. This
|
|
includes the brush extents (width and height) and its pixels data.
|
|
HELP
|
|
|
|
&mitch_pdb_misc('2004', '2.2');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'width', type => 'int32', void_ret => 1,
|
|
desc => 'The brush width' },
|
|
{ name => 'height', type => 'int32',
|
|
desc => 'The brush height' },
|
|
{ name => 'mask_bpp', type => 'int32',
|
|
desc => 'The brush mask bpp' },
|
|
{ name => 'mask_bytes', type => 'int8array',
|
|
desc => 'The brush mask data',
|
|
array => { desc => 'Length of brush mask data' } },
|
|
{ name => 'color_bpp', type => 'int32',
|
|
desc => 'The brush color bpp' },
|
|
{ name => 'color_bytes', type => 'int8array',
|
|
desc => 'The brush color data',
|
|
array => { desc => 'Length of brush color data' } }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
{
|
|
GimpTempBuf *mask = gimp_brush_get_mask (brush);
|
|
GimpTempBuf *pixmap = gimp_brush_get_pixmap (brush);
|
|
const Babl *format;
|
|
gpointer data;
|
|
|
|
format = gimp_babl_compat_u8_mask_format (
|
|
gimp_temp_buf_get_format (mask));
|
|
data = gimp_temp_buf_lock (mask, format, GEGL_ACCESS_READ);
|
|
|
|
width = gimp_temp_buf_get_width (mask);
|
|
height = gimp_temp_buf_get_height (mask);
|
|
mask_bpp = babl_format_get_bytes_per_pixel (format);
|
|
num_mask_bytes = gimp_temp_buf_get_height (mask) *
|
|
gimp_temp_buf_get_width (mask) * mask_bpp;
|
|
mask_bytes = g_memdup (data, num_mask_bytes);
|
|
|
|
gimp_temp_buf_unlock (mask, data);
|
|
|
|
if (pixmap)
|
|
{
|
|
format = gimp_babl_compat_u8_format (
|
|
gimp_temp_buf_get_format (pixmap));
|
|
data = gimp_temp_buf_lock (pixmap, format, GEGL_ACCESS_READ);
|
|
|
|
color_bpp = babl_format_get_bytes_per_pixel (format);
|
|
num_color_bytes = gimp_temp_buf_get_height (pixmap) *
|
|
gimp_temp_buf_get_width (pixmap) *
|
|
color_bpp;
|
|
color_bytes = g_memdup (data, num_color_bytes);
|
|
|
|
gimp_temp_buf_unlock (pixmap, data);
|
|
}
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_get_spacing {
|
|
$blurb = 'Gets the brush spacing.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure returns the spacing setting for the specified brush.
|
|
The return value is an integer between 0 and 1000 which represents
|
|
percentage of the maximum of the width and height of the mask.
|
|
HELP
|
|
|
|
&mitch_pdb_misc('2004', '2.2');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'spacing', type => '0 <= int32 <= 1000', void_ret => 1,
|
|
desc => 'The brush spacing' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
spacing = gimp_brush_get_spacing (brush);
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_get_shape {
|
|
$blurb = 'Gets the shape of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure gets the shape value for a generated brush. If
|
|
called for any other type of brush, it does not succeed. The
|
|
current possibilities are Circle (GIMP_BRUSH_GENERATED_CIRCLE),
|
|
Square (GIMP_BRUSH_GENERATED_SQUARE), and Diamond
|
|
(GIMP_BRUSH_GENERATED_DIAMOND). Other shapes are likely to be
|
|
added in the future.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'shape', type => 'enum GimpBrushGeneratedShape',
|
|
desc => 'The brush shape' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
shape = GIMP_BRUSH_GENERATED (brush)->shape;
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_get_radius {
|
|
$blurb = 'Gets the radius of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure gets the radius value for a generated brush. If
|
|
called for any other type of brush, it does not succeed.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'radius', type => 'float',
|
|
desc => 'The radius of the brush in pixels' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
radius = GIMP_BRUSH_GENERATED (brush)->radius;
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_get_spikes {
|
|
$blurb = 'Gets the number of spikes for a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure gets the number of spikes for a generated brush.
|
|
If called for any other type of brush, it does not succeed.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'spikes', type => 'int32',
|
|
desc => 'The number of spikes on the brush.' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
spikes = GIMP_BRUSH_GENERATED (brush)->spikes;
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_get_hardness {
|
|
$blurb = 'Gets the hardness of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure gets the hardness of a generated brush. The
|
|
hardness of a brush is the amount its intensity fades at the
|
|
outside edge, as a float between 0.0 and 1.0.
|
|
If called for any other type of brush, the function does not
|
|
succeed.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'hardness', type => 'float',
|
|
desc => 'The hardness of the brush.' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
hardness = GIMP_BRUSH_GENERATED (brush)->hardness;
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_get_aspect_ratio {
|
|
$blurb = 'Gets the aspect ratio of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure gets the aspect ratio of a generated brush.
|
|
If called for any other type of brush, it does not succeed.
|
|
The return value is a float between 0.0 and 1000.0.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'aspect_ratio', type => 'float',
|
|
desc => 'The aspect ratio of the brush.' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
aspect_ratio = GIMP_BRUSH_GENERATED (brush)->aspect_ratio;
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_get_angle {
|
|
$blurb = 'Gets the rotation angle of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure gets the angle of rotation for a generated brush.
|
|
If called for any other type of brush, it does not succeed.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'angle', type => 'float',
|
|
desc => 'The rotation angle of the brush in degree.' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_READ, error);
|
|
|
|
if (brush)
|
|
angle = GIMP_BRUSH_GENERATED (brush)->angle;
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_set_spacing {
|
|
$blurb = 'Sets the brush spacing.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure modifies the spacing setting for the specified brush.
|
|
The value should be a integer between 0 and 1000.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' },
|
|
{ name => 'spacing', type => '0 <= int32 <= 1000',
|
|
desc => 'The brush spacing' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
|
|
|
|
if (brush)
|
|
gimp_brush_set_spacing (brush, spacing);
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_set_shape {
|
|
$blurb = 'Sets the shape of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure sets the shape value for a generated brush. If
|
|
called for any other type of brush, it does not succeed. The
|
|
current possibilities are Circle (GIMP_BRUSH_GENERATED_CIRCLE),
|
|
Square (GIMP_BRUSH_GENERATED_SQUARE), and Diamond
|
|
(GIMP_BRUSH_GENERATED_DIAMOND). Other shapes are likely to be
|
|
added in the future.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' },
|
|
{ name => 'shape_in', type => 'enum GimpBrushGeneratedShape',
|
|
desc => 'The brush shape' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'shape_out', type => 'enum GimpBrushGeneratedShape',
|
|
desc => 'The brush shape actually assigned' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
|
|
|
|
if (brush)
|
|
{
|
|
gimp_brush_generated_set_shape (GIMP_BRUSH_GENERATED (brush),
|
|
shape_in);
|
|
shape_out = GIMP_BRUSH_GENERATED (brush)->shape;
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_set_radius {
|
|
$blurb = 'Sets the radius of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure sets the radius for a generated brush. If
|
|
called for any other type of brush, it does not succeed.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' },
|
|
{ name => 'radius_in', type => 'float',
|
|
desc => 'The desired brush radius in pixel' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'radius_out', type => 'float',
|
|
desc => 'The brush radius actually assigned' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
|
|
|
|
if (brush)
|
|
{
|
|
gimp_brush_generated_set_radius (GIMP_BRUSH_GENERATED (brush),
|
|
radius_in);
|
|
radius_out = GIMP_BRUSH_GENERATED (brush)->radius;
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_set_spikes {
|
|
$blurb = 'Sets the number of spikes for a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure sets the number of spikes for a generated brush. If
|
|
called for any other type of brush, it does not succeed.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' },
|
|
{ name => 'spikes_in', type => 'int32',
|
|
desc => 'The desired number of spikes' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'spikes_out', type => 'int32',
|
|
desc => 'The number of spikes actually assigned' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
|
|
|
|
if (brush)
|
|
{
|
|
gimp_brush_generated_set_spikes (GIMP_BRUSH_GENERATED (brush),
|
|
spikes_in);
|
|
spikes_out = GIMP_BRUSH_GENERATED (brush)->spikes;
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_set_hardness {
|
|
$blurb = 'Sets the hardness of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure sets the hardness for a generated brush. If
|
|
called for any other type of brush, it does not succeed.
|
|
The value should be a float between 0.0 and 1.0.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' },
|
|
{ name => 'hardness_in', type => 'float',
|
|
desc => 'The desired brush hardness' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'hardness_out', type => 'float',
|
|
desc => 'The brush hardness actually assigned' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
|
|
|
|
if (brush)
|
|
{
|
|
gimp_brush_generated_set_hardness (GIMP_BRUSH_GENERATED (brush),
|
|
hardness_in);
|
|
hardness_out = GIMP_BRUSH_GENERATED (brush)->hardness;
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_set_aspect_ratio {
|
|
$blurb = 'Sets the aspect ratio of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure sets the aspect ratio for a generated brush.
|
|
If called for any other type of brush, it does not succeed.
|
|
The value should be a float between 0.0 and 1000.0.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' },
|
|
{ name => 'aspect_ratio_in', type => 'float',
|
|
desc => 'The desired brush aspect ratio' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'aspect_ratio_out', type => 'float',
|
|
desc => 'The brush aspect ratio actually assigned' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
|
|
|
|
if (brush)
|
|
{
|
|
gimp_brush_generated_set_aspect_ratio (GIMP_BRUSH_GENERATED (brush),
|
|
aspect_ratio_in);
|
|
aspect_ratio_out = GIMP_BRUSH_GENERATED (brush)->aspect_ratio;
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub brush_set_angle {
|
|
$blurb = 'Sets the rotation angle of a generated brush.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure sets the rotation angle for a generated brush. If
|
|
called for any other type of brush, it does not succeed.
|
|
HELP
|
|
|
|
&bill_pdb_misc('2004', '2.4');
|
|
|
|
@inargs = (
|
|
{ name => 'name', type => 'string', non_empty => 1,
|
|
desc => 'The brush name' },
|
|
{ name => 'angle_in', type => 'float',
|
|
desc => 'The desired brush rotation angle in degree' }
|
|
);
|
|
|
|
@outargs = (
|
|
{ name => 'angle_out', type => 'float',
|
|
desc => 'The brush rotation angle actually assigned' }
|
|
);
|
|
|
|
%invoke = (
|
|
code => <<'CODE'
|
|
{
|
|
GimpBrush *brush = gimp_pdb_get_generated_brush (gimp, name, GIMP_PDB_DATA_ACCESS_WRITE, error);
|
|
|
|
if (brush)
|
|
{
|
|
gimp_brush_generated_set_angle (GIMP_BRUSH_GENERATED (brush),
|
|
angle_in);
|
|
angle_out = GIMP_BRUSH_GENERATED (brush)->angle;
|
|
}
|
|
else
|
|
success = FALSE;
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
|
|
@headers = qw(<string.h>
|
|
"gegl/gimp-babl-compat.h"
|
|
"core/gimp.h"
|
|
"core/gimpbrush.h"
|
|
"core/gimpbrushgenerated.h"
|
|
"core/gimpcontext.h"
|
|
"core/gimpdatafactory.h"
|
|
"core/gimptempbuf.h"
|
|
"gimppdb-utils.h");
|
|
|
|
@procs = qw(brush_new
|
|
brush_duplicate
|
|
brush_is_generated
|
|
brush_rename
|
|
brush_delete
|
|
brush_is_editable
|
|
brush_get_info
|
|
brush_get_pixels
|
|
brush_get_spacing brush_set_spacing
|
|
brush_get_shape brush_set_shape
|
|
brush_get_radius brush_set_radius
|
|
brush_get_spikes brush_set_spikes
|
|
brush_get_hardness brush_set_hardness
|
|
brush_get_aspect_ratio brush_set_aspect_ratio
|
|
brush_get_angle brush_set_angle);
|
|
|
|
%exports = (app => [@procs], lib => [@procs]);
|
|
|
|
$desc = 'Brush';
|
|
$doc_title = 'gimpbrush';
|
|
$doc_short_desc = 'Functions operating on a single brush.';
|
|
$doc_long_desc = 'Functions operating on a single brush.';
|
|
|
|
1;
|