Well, 1.2.x is for bugfixes to 1.2, so the question is
whether its considered a bug. I'm inclined to
consider it one, but I'm not really doing much in the
way of maintaining the 1.2 branch. Yosh, Sven?
Seth
--- Tamito KAJIYAMA
<[EMAIL PROTECTED]> wrote:
> Hi again,
>
> I've noticed that the new procedure gimp-levels-auto
> I've added
> does not yield exactly the same effect of the Auto
> button in the
> levels dialog. So, here is the revised patch to the
> GIMP 1.2.1
> source tree.
>
> BTW, I'd like to know if the patch is likely to be
> integrated
> into the GIMP. If it is not, I'd need to write an
> plug-in
> instead of a patch to the GIMP itself, since a
> plug-in is much
> more useful from user's point of view. Could you
> please tell
> me the likelihood?
>
> Thanks,
>
> --
> KAJIYAMA, Tamito <[EMAIL PROTECTED]>
>
> diff -ru gimp-1.2.1.orig/tools/pdbgen/pdb/color.pdb
> gimp-1.2.1/tools/pdbgen/pdb/color.pdb
> --- gimp-1.2.1.orig/tools/pdbgen/pdb/color.pdb Mon
> Dec 25 01:40:47 2000
> +++ gimp-1.2.1/tools/pdbgen/pdb/color.pdb Thu Mar 22
> 10:33:29 2001
> @@ -175,6 +175,137 @@
> }
> }
>
> +sub levels_auto {
> + $blurb = 'Modifies intensity levels in the
> specified drawable.';
> +
> + $help = <<'HELP';
> +This tool automatically adjusts intensity levels in
> the specified
> +drawable. This tool is only valid on RGB color and
> grayscale
> +images. It will not operate on indexed drawables.
> +HELP
> +
> + &std_pdb_misc;
> +
> + @inargs = (
> + &drawable_arg
> + );
> +
> + %invoke = (
> + vars => [ 'PixelRegion srcPR, destPR', 'int x1,
> y1, x2, y2',
> + 'GimpLut *lut', 'int i, j',
> + 'int low_input[5]',
> + 'int high_input[5]',
> + 'int low_output[5]',
> + 'int high_output[5]',
> + 'double gamma[5]',
> + 'int channel, channels[3], nchannels',
> + 'GimpHistogram *hist',
> + 'double count, new_count, percentage,
> next_percentage'],
> + code => <<'CODE'
> +{
> + if (gimp_drawable_is_indexed (drawable))
> + success = FALSE;
> + else
> + {
> + for (i = 0; i < 5; i++)
> + {
> + low_input[i] = 0;
> + high_input[i] = 255;
> + low_output[i] = 0;
> + high_output[i] = 255;
> + gamma[i] = 1.0;
> + }
> +
> + hist = gimp_histogram_new ();
> + gimp_histogram_calculate_drawable (hist,
> drawable);
> +
> + if (gimp_drawable_is_rgb (drawable))
> + {
> + nchannels = 3;
> + channels[0] = RED_LUT;
> + channels[1] = GREEN_LUT;
> + channels[2] = BLUE_LUT;
> + }
> + else
> + {
> + nchannels = 1;
> + channels[0] = GRAY_LUT;
> + }
> + for (j = 0; j < nchannels; j++)
> + {
> + channel = channels[j];
> +
> + count = gimp_histogram_get_count (hist, 0, 255);
> +
> + if (count == 0.0)
> + {
> + low_input[channel] = 0;
> + high_input[channel] = 0;
> + }
> + else
> + {
> + /* set the low input */
> + new_count = 0.0;
> + for (i = 0; i < 255; i++)
> + {
> + new_count += gimp_histogram_get_value(hist,
> channel, i);
> + percentage = new_count / count;
> + next_percentage =
> + (new_count + gimp_histogram_get_value (hist,
> channel,
> + i + 1)) / count;
> + if (fabs (percentage - 0.006) <
> + fabs (next_percentage - 0.006))
> + {
> + low_input[channel] = i + 1;
> + break;
> + }
> + }
> + /* set the high input */
> + new_count = 0.0;
> + for (i = 255; i > 0; i--)
> + {
> + new_count += gimp_histogram_get_value(hist,
> channel, i);
> + percentage = new_count / count;
> + next_percentage =
> + (new_count + gimp_histogram_get_value (hist,
> channel,
> + i - 1)) / count;
> + if (fabs (percentage - 0.006) <
> + fabs (next_percentage - 0.006))
> + {
> + high_input[channel] = i - 1;
> + break;
> + }
> + }
> + }
> + }
> +
> + gimp_histogram_free (hist);
> +
> + /* setup the lut */
> + lut = levels_lut_new (gamma, low_input,
> high_input,
> + low_output, high_output,
> + gimp_drawable_bytes (drawable));
> +
> + /* The application should occur only within
> selection bounds */
> + gimp_drawable_mask_bounds (drawable, &x1,
> &y1, &x2, &y2);
> +
> + pixel_region_init (&srcPR, gimp_drawable_data
> (drawable),
> + x1, y1, (x2 - x1), (y2 - y1), FALSE);
> + pixel_region_init (&destPR,
> gimp_drawable_shadow (drawable),
> + x1, y1, (x2 - x1), (y2 - y1), TRUE);
> +
> + pixel_regions_process_parallel ((p_func)
> gimp_lut_process, lut, 2,
> + &srcPR, &destPR);
> +
> + gimp_lut_free(lut);
> + gimp_drawable_merge_shadow (drawable, TRUE);
> + drawable_update (drawable, x1, y1, (x2 - x1),
> (y2 - y1));
> + }
> +}
> +CODE
> + );
> +}
> +
> sub posterize {
> $blurb = 'Posterize the specified drawable.';
>
> @@ -761,9 +892,9 @@
> );
> }
>
> -@headers = qw("gimpimage.h" "gimpdrawable.h"
> "gimplut.h" "lut_funcs.h");
> +@headers = qw("gimpimage.h" "gimpdrawable.h"
> "gimplut.h" "lut_funcs.h" "libgimp/gimpmath.h");
>
> -@procs = qw(brightness_contrast levels posterize
> desaturate equalize invert
> +@procs = qw(brightness_contrast levels levels_auto
> posterize desaturate equalize invert
> curves_spline curves_explicit color_balance
> histogram
>
=== message truncated ===
__________________________________________________
Do You Yahoo!?
Get email at your own domain with Yahoo! Mail.
http://personal.mail.yahoo.com/
_______________________________________________
Gimp-developer mailing list
[EMAIL PROTECTED]
http://lists.xcf.berkeley.edu/mailman/listinfo/gimp-developer