1999-11-14 Michael Natterer <mitch@gimp.org> * app/airbrush.c * app/apptypes.h * app/brushes_cmds.c * tools/pdbgen/pdb/brushes.pdb * app/bucket_fill.c * app/clone.c * app/gimpbrushpipe.c * app/paint_core.c * app/patterns.h * app/patterns_cmds.c * tools/pdbgen/pdb/patterns.pdb: removed the GimpBrushP and GPatternP types and use ordinary pointers instead. The following stuff makes the "no_data" behaviour consistent. As a side-effect it should make the gimp work when there are _really_ no brushes/patterns/gradients. * app/brush_select.c * app/pattern_select.c: set the initial brush/pattern name to "No Brushes/Patterns available" instead of "Active". * app/devices.c: set the device contexts' brush/pattern/gradient names if we started with no_data, so we find them on refresh. * app/gimpbrushlist.c: set the name of the standard_brush to "Standard". * app/gimpcontext.c: don't replace the current brush/pattern/gradient's name if the new one to be set is the standard one. Together with the change in devices.c, this ensures that we get what is set in devicerc. Minor fixes. * app/gradient.c: changed gradients_init() to work like the other data init functions. Only insert a default gradient in the gradients list when the editor is opened (this means that the gradients now behave like brushes/patterns when we start with "no_data"). New function gradient_update() avoids tons of useless redraws of all clist gradient previews whenever the gradient editor wants to update it's large preview. * app/gradient_select.c: don't segfault when the user tries to drag from an empty gradient list. * app/patterns.c: set the index of the standard_pattern to -1 to indicate that it's not part of the pattern list.
223 lines
5.6 KiB
Plaintext
223 lines
5.6 KiB
Plaintext
# 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
|
|
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
# "Perlized" from C source by Manish Singh <yosh@gimp.org>
|
|
|
|
sub pattern_arg () {{
|
|
name => 'name',
|
|
type => 'string',
|
|
desc => 'The pattern name'
|
|
}}
|
|
|
|
sub dim_args () {
|
|
my @args;
|
|
foreach (qw(width height)) {
|
|
push @args, { name => $_, type => 'int32', desc => "The pattern $_" };
|
|
}
|
|
@args;
|
|
}
|
|
|
|
sub pattern_outargs {
|
|
foreach (@outargs) {
|
|
my $alias = "pattern->$_->{name}";
|
|
$alias = "g_strdup ($alias)" if $_->{type} eq 'string';
|
|
$alias =~ s/pattern/pattern->mask/ if $_->{name} =~ /width|height/;
|
|
$_->{alias} = $alias;
|
|
$_->{no_declare} = 1;
|
|
}
|
|
}
|
|
|
|
# The defs
|
|
|
|
sub patterns_get_pattern {
|
|
$blurb = 'Retrieve information about the currently active pattern.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure retrieves information about the currently active pattern. This
|
|
includes the pattern name, and the pattern extents (width and height). All
|
|
clone and bucket-fill operations with patterns will use this pattern to control
|
|
the application of paint to the image.
|
|
HELP
|
|
|
|
&std_pdb_misc;
|
|
|
|
@outargs = (
|
|
&pattern_arg,
|
|
&dim_args,
|
|
);
|
|
|
|
&pattern_outargs;
|
|
|
|
%invoke = (
|
|
vars => [ 'GPattern *pattern' ],
|
|
code => 'success = (pattern = gimp_context_get_pattern (NULL)) != NULL;'
|
|
);
|
|
}
|
|
|
|
sub patterns_set_pattern {
|
|
$blurb = 'Set the specified pattern as the active pattern.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure allows the active pattern mask to be set by specifying its name.
|
|
The name is simply a string which corresponds to one of the names of the
|
|
installed patterns. If there is no matching pattern found, this procedure will
|
|
return an error. Otherwise, the specified pattern becomes active and will be
|
|
used in all subsequent paint operations.
|
|
HELP
|
|
|
|
&std_pdb_misc;
|
|
|
|
@inargs = ( &pattern_arg );
|
|
|
|
%invoke = (
|
|
vars => [ 'GPattern *pattern', 'GSList *list' ],
|
|
code => <<'CODE'
|
|
{
|
|
success = FALSE;
|
|
|
|
for (list = pattern_list; list; list = g_slist_next (list))
|
|
{
|
|
pattern = (GPattern *) list->data;
|
|
|
|
if (!strcmp (pattern->name, name))
|
|
{
|
|
gimp_context_set_pattern (NULL, pattern);
|
|
success = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub patterns_list {
|
|
$blurb = 'Retrieve a complete listing of the available patterns.';
|
|
|
|
$help = <<'HELP';
|
|
This procedure returns a complete listing of available GIMP patterns. Each name
|
|
returned can be used as input to the 'gimp_patterns_set_pattern'.
|
|
HELP
|
|
|
|
&std_pdb_misc;
|
|
|
|
@outargs = (
|
|
{ name => 'pattern_list', type => 'stringarray',
|
|
desc => 'The list of pattern names',
|
|
alias => 'patterns',
|
|
array => { name => 'num_patterns',
|
|
desc => 'The number of patterns in the pattern list',
|
|
alias => 'num_patterns', no_declare => 1 } }
|
|
);
|
|
|
|
%invoke = (
|
|
vars => [ 'GSList *list = NULL', 'int i = 0' ],
|
|
code => <<'CODE'
|
|
{
|
|
patterns = g_new (char *, num_patterns);
|
|
|
|
success = (list = pattern_list) != NULL;
|
|
|
|
while (list)
|
|
{
|
|
patterns[i++] = g_strdup (((GPattern *) list->data)->name);
|
|
list = list->next;
|
|
}
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
sub patterns_get_pattern_data {
|
|
$blurb = <<'BLURB';
|
|
Retrieve information about the currently active pattern (including data).
|
|
BLURB
|
|
|
|
$help = <<'HELP';
|
|
This procedure retrieves information about the currently active pattern. This
|
|
includes the pattern name, and the pattern extents (width and height). It also
|
|
returns the pattern data.
|
|
HELP
|
|
|
|
$author = $copyright = 'Andy Thomas';
|
|
$date = '1998';
|
|
|
|
@inargs = ( &pattern_arg );
|
|
$inargs[0]->{desc} = 'the pattern name ("" means current active pattern)';
|
|
|
|
@outargs = (
|
|
&pattern_arg,
|
|
&dim_args,
|
|
);
|
|
|
|
&pattern_outargs;
|
|
|
|
push @outargs, { name => 'mask_bpp', type => 'int32', init => 1,
|
|
desc => 'Pattern bytes per pixel',
|
|
alias => 'pattern->mask->bytes', no_declare => 1 },
|
|
{ name => 'mask_data', type => 'int8array', init => 1,
|
|
desc => 'The pattern mask data',
|
|
array => { name => 'length', init => 1,
|
|
desc => 'Length of pattern mask data' } };
|
|
|
|
%invoke = (
|
|
headers => [ qw(<string.h>) ],
|
|
vars => [ 'GPattern *pattern = NULL' ],
|
|
code => <<'CODE'
|
|
{
|
|
if (strlen (name))
|
|
{
|
|
GSList *list;
|
|
|
|
success = FALSE;
|
|
|
|
for (list = pattern_list; list; list = g_slist_next (list))
|
|
{
|
|
pattern = (GPattern *) list->data;
|
|
|
|
if (!strcmp (pattern->name, name))
|
|
{
|
|
success = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
success = (pattern = gimp_context_get_pattern (NULL)) != NULL;
|
|
|
|
if (success)
|
|
{
|
|
length = pattern->mask->height * pattern->mask->width *
|
|
pattern->mask->bytes;
|
|
mask_data = g_new (guint8, length);
|
|
g_memmove (mask_data, temp_buf_data (pattern->mask), length);
|
|
}
|
|
}
|
|
CODE
|
|
);
|
|
}
|
|
|
|
@headers = qw("gimpcontext.h" "patterns.h");
|
|
|
|
@procs = qw(patterns_get_pattern patterns_set_pattern patterns_list
|
|
patterns_get_pattern_data);
|
|
%exports = (app => [@procs]);
|
|
|
|
$desc = 'Patterns';
|
|
|
|
1;
|