Files
gimp/app/operations/gimpbrightnesscontrastconfig.c
Michael Natterer 9072bf331a app: rename GimpImageMapConfig to GimpSettings
It was misnamed from the beginning and has no relation to GimpImageMap
except that it happens to be used by GimpImageMapTools. Now it feels
less weird to potentially use it for other settings too.
2013-05-25 15:26:18 +02:00

211 lines
6.2 KiB
C

/* GIMP - The GNU Image Manipulation Program
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
*
* gimpbrightnesscontrastconfig.c
* Copyright (C) 2007 Michael Natterer <mitch@gimp.org>
*
* 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 <http://www.gnu.org/licenses/>.
*/
#include "config.h"
#include <gegl.h>
#include "libgimpmath/gimpmath.h"
#include "libgimpconfig/gimpconfig.h"
#include "operations-types.h"
#include "gimpbrightnesscontrastconfig.h"
#include "gimplevelsconfig.h"
enum
{
PROP_0,
PROP_BRIGHTNESS,
PROP_CONTRAST
};
static void gimp_brightness_contrast_config_get_property (GObject *object,
guint property_id,
GValue *value,
GParamSpec *pspec);
static void gimp_brightness_contrast_config_set_property (GObject *object,
guint property_id,
const GValue *value,
GParamSpec *pspec);
G_DEFINE_TYPE_WITH_CODE (GimpBrightnessContrastConfig,
gimp_brightness_contrast_config,
GIMP_TYPE_SETTINGS,
G_IMPLEMENT_INTERFACE (GIMP_TYPE_CONFIG, NULL))
#define parent_class gimp_brightness_contrast_config_parent_class
static void
gimp_brightness_contrast_config_class_init (GimpBrightnessContrastConfigClass *klass)
{
GObjectClass *object_class = G_OBJECT_CLASS (klass);
GimpViewableClass *viewable_class = GIMP_VIEWABLE_CLASS (klass);
object_class->set_property = gimp_brightness_contrast_config_set_property;
object_class->get_property = gimp_brightness_contrast_config_get_property;
viewable_class->default_stock_id = "gimp-tool-brightness-contrast";
GIMP_CONFIG_INSTALL_PROP_DOUBLE (object_class, PROP_BRIGHTNESS,
"brightness",
"Brightness",
-1.0, 1.0, 0.0, 0);
GIMP_CONFIG_INSTALL_PROP_DOUBLE (object_class, PROP_CONTRAST,
"contrast",
"Contrast",
-1.0, 1.0, 0.0, 0);
}
static void
gimp_brightness_contrast_config_init (GimpBrightnessContrastConfig *self)
{
}
static void
gimp_brightness_contrast_config_get_property (GObject *object,
guint property_id,
GValue *value,
GParamSpec *pspec)
{
GimpBrightnessContrastConfig *self = GIMP_BRIGHTNESS_CONTRAST_CONFIG (object);
switch (property_id)
{
case PROP_BRIGHTNESS:
g_value_set_double (value, self->brightness);
break;
case PROP_CONTRAST:
g_value_set_double (value, self->contrast);
break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
break;
}
}
static void
gimp_brightness_contrast_config_set_property (GObject *object,
guint property_id,
const GValue *value,
GParamSpec *pspec)
{
GimpBrightnessContrastConfig *self = GIMP_BRIGHTNESS_CONTRAST_CONFIG (object);
switch (property_id)
{
case PROP_BRIGHTNESS:
self->brightness = g_value_get_double (value);
break;
case PROP_CONTRAST:
self->contrast = g_value_get_double (value);
break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
break;
}
}
/* public functions */
GimpLevelsConfig *
gimp_brightness_contrast_config_to_levels_config (GimpBrightnessContrastConfig *config)
{
GimpLevelsConfig *levels;
gdouble brightness;
gdouble slant;
gdouble value;
g_return_val_if_fail (GIMP_IS_BRIGHTNESS_CONTRAST_CONFIG (config), NULL);
levels = g_object_new (GIMP_TYPE_LEVELS_CONFIG, NULL);
brightness = config->brightness / 2.0;
slant = tan ((config->contrast + 1) * G_PI_4);
if (config->brightness >= 0)
{
value = -0.5 * slant + brightness * slant + 0.5;
if (value < 0.0)
{
value = 0.0;
/* this slightly convoluted math follows by inverting the
* calculation of the brightness/contrast LUT in base/lut-funcs.h */
levels->low_input[GIMP_HISTOGRAM_VALUE] =
(- brightness * slant + 0.5 * slant - 0.5) / (slant - brightness * slant);
}
levels->low_output[GIMP_HISTOGRAM_VALUE] = value;
value = 0.5 * slant + 0.5;
if (value > 1.0)
{
value = 1.0;
levels->high_input[GIMP_HISTOGRAM_VALUE] =
(- brightness * slant + 0.5 * slant + 0.5) / (slant - brightness * slant);
}
levels->high_output[GIMP_HISTOGRAM_VALUE] = value;
}
else
{
value = 0.5 - 0.5 * slant;
if (value < 0.0)
{
value = 0.0;
levels->low_input[GIMP_HISTOGRAM_VALUE] =
(0.5 * slant - 0.5) / (slant + brightness * slant);
}
levels->low_output[GIMP_HISTOGRAM_VALUE] = value;
value = slant * brightness + slant * 0.5 + 0.5;
if (value > 1.0)
{
value = 1.0;
levels->high_input[GIMP_HISTOGRAM_VALUE] =
(0.5 * slant + 0.5) / (slant + brightness * slant);
}
levels->high_output[GIMP_HISTOGRAM_VALUE] = value;
}
return levels;
}