|
Packit Service |
2781ba |
/* This file is an image processing operation for GEGL
|
|
Packit Service |
2781ba |
*
|
|
Packit Service |
2781ba |
* GEGL is free software; you can redistribute it and/or
|
|
Packit Service |
2781ba |
* modify it under the terms of the GNU Lesser General Public
|
|
Packit Service |
2781ba |
* License as published by the Free Software Foundation; either
|
|
Packit Service |
2781ba |
* version 3 of the License, or (at your option) any later version.
|
|
Packit Service |
2781ba |
*
|
|
Packit Service |
2781ba |
* GEGL is distributed in the hope that it will be useful,
|
|
Packit Service |
2781ba |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit Service |
2781ba |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit Service |
2781ba |
* Lesser General Public License for more details.
|
|
Packit Service |
2781ba |
*
|
|
Packit Service |
2781ba |
* You should have received a copy of the GNU Lesser General Public
|
|
Packit Service |
2781ba |
* License along with GEGL; if not, see <http://www.gnu.org/licenses/>.
|
|
Packit Service |
2781ba |
*
|
|
Packit Service |
2781ba |
* Copyright 2006-2010 Øyvind Kolås <pippin@gimp.org>
|
|
Packit Service |
2781ba |
*/
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
#include "config.h"
|
|
Packit Service |
2781ba |
#include <glib/gi18n-lib.h>
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
#ifdef GEGL_CHANT_PROPERTIES
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
/* no properties */
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
#else
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
#define GEGL_CHANT_TYPE_POINT_COMPOSER3
|
|
Packit Service |
2781ba |
#define GEGL_CHANT_C_FILE "remap.c"
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
#include "gegl-chant.h"
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
static void prepare (GeglOperation *operation)
|
|
Packit Service |
2781ba |
{
|
|
Packit Service |
2781ba |
const Babl *format = babl_format ("RGBA float");
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
gegl_operation_set_format (operation, "input", format);
|
|
Packit Service |
2781ba |
gegl_operation_set_format (operation, "aux", format);
|
|
Packit Service |
2781ba |
gegl_operation_set_format (operation, "aux2", format);
|
|
Packit Service |
2781ba |
gegl_operation_set_format (operation, "output", format);
|
|
Packit Service |
2781ba |
}
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
static gboolean
|
|
Packit Service |
2781ba |
process (GeglOperation *op,
|
|
Packit Service |
2781ba |
void *in_buf,
|
|
Packit Service |
2781ba |
void *min_buf,
|
|
Packit Service |
2781ba |
void *max_buf,
|
|
Packit Service |
2781ba |
void *out_buf,
|
|
Packit Service |
2781ba |
glong n_pixels,
|
|
Packit Service |
2781ba |
const GeglRectangle *roi,
|
|
Packit Service |
2781ba |
gint level)
|
|
Packit Service |
2781ba |
{
|
|
Packit Service |
2781ba |
gint i;
|
|
Packit Service |
2781ba |
gfloat *in = in_buf;
|
|
Packit Service |
2781ba |
gfloat *min = min_buf;
|
|
Packit Service |
2781ba |
gfloat *max = max_buf;
|
|
Packit Service |
2781ba |
gfloat *out = out_buf;
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
for (i = 0; i < n_pixels; i++)
|
|
Packit Service |
2781ba |
{
|
|
Packit Service |
2781ba |
gint c;
|
|
Packit Service |
2781ba |
for (c = 0; c < 3; c++)
|
|
Packit Service |
2781ba |
{
|
|
Packit Service |
2781ba |
gfloat delta = max[c]-min[c];
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
if (delta > 0.0001 || delta < -0.0001)
|
|
Packit Service |
2781ba |
out[c] = (in[c]-min[c]) / delta;
|
|
Packit Service |
2781ba |
else
|
|
Packit Service |
2781ba |
out[c] = in[c];
|
|
Packit Service |
2781ba |
out[3] = in[3];
|
|
Packit Service |
2781ba |
}
|
|
Packit Service |
2781ba |
in += 4;
|
|
Packit Service |
2781ba |
out += 4;
|
|
Packit Service |
2781ba |
min += 4;
|
|
Packit Service |
2781ba |
max += 4;
|
|
Packit Service |
2781ba |
}
|
|
Packit Service |
2781ba |
return TRUE;
|
|
Packit Service |
2781ba |
}
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
static void
|
|
Packit Service |
2781ba |
gegl_chant_class_init (GeglChantClass *klass)
|
|
Packit Service |
2781ba |
{
|
|
Packit Service |
2781ba |
GeglOperationClass *operation_class;
|
|
Packit Service |
2781ba |
GeglOperationPointComposer3Class *point_composer3_class;
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
operation_class = GEGL_OPERATION_CLASS (klass);
|
|
Packit Service |
2781ba |
point_composer3_class = GEGL_OPERATION_POINT_COMPOSER3_CLASS (klass);
|
|
Packit Service |
2781ba |
operation_class->prepare = prepare;
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
point_composer3_class->process = process;
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
gegl_operation_class_set_keys (operation_class,
|
|
Packit Service |
2781ba |
"name" , "gegl:remap",
|
|
Packit Service |
2781ba |
"description",
|
|
Packit Service |
2781ba |
_("stretch components of pixels individually based on luminance envelopes"),
|
|
Packit Service |
2781ba |
"categories" , "compositors:porter-duff",
|
|
Packit Service |
2781ba |
NULL);
|
|
Packit Service |
2781ba |
}
|
|
Packit Service |
2781ba |
|
|
Packit Service |
2781ba |
#endif
|