2007-06-01 19:19:37 +08:00
|
|
|
/* LIBGIMP - The GIMP Library
|
|
|
|
* Copyright (C) 1995-1997 Spencer Kimball and Peter Mattis
|
|
|
|
*
|
|
|
|
* GimpColorManaged interface
|
|
|
|
* Copyright (C) 2007 Sven Neumann <sven@gimp.org>
|
|
|
|
*
|
2009-01-18 06:28:01 +08:00
|
|
|
* This library is free software: you can redistribute it and/or
|
2007-06-01 19:19:37 +08:00
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
2009-01-18 06:28:01 +08:00
|
|
|
* version 3 of the License, or (at your option) any later version.
|
2007-06-01 19:19:37 +08:00
|
|
|
*
|
|
|
|
* This library 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
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2009-01-18 06:28:01 +08:00
|
|
|
* License along with this library. If not, see
|
2018-07-12 05:27:07 +08:00
|
|
|
* <https://www.gnu.org/licenses/>.
|
2007-06-01 19:19:37 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
2015-05-31 04:19:36 +08:00
|
|
|
#include <gio/gio.h>
|
|
|
|
#include <gegl.h>
|
2007-06-01 19:19:37 +08:00
|
|
|
|
|
|
|
#include "gimpcolortypes.h"
|
|
|
|
|
|
|
|
#include "gimpcolormanaged.h"
|
2015-06-03 15:41:23 +08:00
|
|
|
#include "gimpcolorprofile.h"
|
2007-06-01 19:19:37 +08:00
|
|
|
|
|
|
|
|
2010-06-30 01:46:37 +08:00
|
|
|
/**
|
2010-06-30 02:08:39 +08:00
|
|
|
* SECTION: gimpcolormanaged
|
2010-06-30 01:46:37 +08:00
|
|
|
* @title: GimpColorManaged
|
|
|
|
* @short_description: An interface dealing with color profiles.
|
|
|
|
*
|
|
|
|
* An interface dealing with color profiles.
|
|
|
|
**/
|
|
|
|
|
|
|
|
|
2007-06-01 19:19:37 +08:00
|
|
|
enum
|
|
|
|
{
|
|
|
|
PROFILE_CHANGED,
|
2022-06-01 04:59:31 +08:00
|
|
|
SIMULATION_PROFILE_CHANGED,
|
2022-08-10 23:01:15 +08:00
|
|
|
SIMULATION_INTENT_CHANGED,
|
|
|
|
SIMULATION_BPC_CHANGED,
|
2007-06-01 19:19:37 +08:00
|
|
|
LAST_SIGNAL
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2018-05-27 16:30:56 +08:00
|
|
|
G_DEFINE_INTERFACE (GimpColorManaged, gimp_color_managed, G_TYPE_OBJECT)
|
2007-06-01 19:19:37 +08:00
|
|
|
|
|
|
|
|
|
|
|
static guint gimp_color_managed_signals[LAST_SIGNAL] = { 0 };
|
|
|
|
|
|
|
|
|
2018-05-27 16:30:56 +08:00
|
|
|
/* private functions */
|
|
|
|
|
|
|
|
|
2007-06-01 19:19:37 +08:00
|
|
|
static void
|
2018-05-27 16:30:56 +08:00
|
|
|
gimp_color_managed_default_init (GimpColorManagedInterface *iface)
|
2007-06-01 19:19:37 +08:00
|
|
|
{
|
2018-05-27 16:30:56 +08:00
|
|
|
gimp_color_managed_signals[PROFILE_CHANGED] =
|
|
|
|
g_signal_new ("profile-changed",
|
|
|
|
G_TYPE_FROM_INTERFACE (iface),
|
|
|
|
G_SIGNAL_RUN_FIRST,
|
|
|
|
G_STRUCT_OFFSET (GimpColorManagedInterface,
|
|
|
|
profile_changed),
|
2020-01-12 18:06:05 +08:00
|
|
|
NULL, NULL, NULL,
|
2018-05-27 16:30:56 +08:00
|
|
|
G_TYPE_NONE, 0);
|
2022-06-01 04:59:31 +08:00
|
|
|
|
|
|
|
gimp_color_managed_signals[SIMULATION_PROFILE_CHANGED] =
|
|
|
|
g_signal_new ("simulation-profile-changed",
|
|
|
|
G_TYPE_FROM_INTERFACE (iface),
|
|
|
|
G_SIGNAL_RUN_FIRST,
|
|
|
|
G_STRUCT_OFFSET (GimpColorManagedInterface,
|
|
|
|
simulation_profile_changed),
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
2022-08-10 23:01:15 +08:00
|
|
|
|
|
|
|
gimp_color_managed_signals[SIMULATION_INTENT_CHANGED] =
|
|
|
|
g_signal_new ("simulation-intent-changed",
|
|
|
|
G_TYPE_FROM_INTERFACE (iface),
|
|
|
|
G_SIGNAL_RUN_FIRST,
|
|
|
|
G_STRUCT_OFFSET (GimpColorManagedInterface,
|
|
|
|
simulation_intent_changed),
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
|
|
|
gimp_color_managed_signals[SIMULATION_BPC_CHANGED] =
|
|
|
|
g_signal_new ("simulation-bpc-changed",
|
|
|
|
G_TYPE_FROM_INTERFACE (iface),
|
|
|
|
G_SIGNAL_RUN_FIRST,
|
|
|
|
G_STRUCT_OFFSET (GimpColorManagedInterface,
|
|
|
|
simulation_bpc_changed),
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
2007-06-01 19:19:37 +08:00
|
|
|
}
|
|
|
|
|
2018-05-27 16:30:56 +08:00
|
|
|
|
|
|
|
/* public functions */
|
|
|
|
|
|
|
|
|
2007-06-01 19:19:37 +08:00
|
|
|
/**
|
|
|
|
* gimp_color_managed_get_icc_profile:
|
|
|
|
* @managed: an object the implements the #GimpColorManaged interface
|
2020-05-04 08:10:55 +08:00
|
|
|
* @len: (out): return location for the number of bytes in the profile data
|
2007-06-01 19:19:37 +08:00
|
|
|
*
|
2020-05-04 08:10:55 +08:00
|
|
|
* Returns: (array length=len): A blob of data that represents an ICC color
|
|
|
|
* profile.
|
2007-06-01 19:19:37 +08:00
|
|
|
*
|
2015-06-01 03:18:09 +08:00
|
|
|
* Since: 2.4
|
2020-05-04 08:10:55 +08:00
|
|
|
*/
|
2007-06-01 19:19:37 +08:00
|
|
|
const guint8 *
|
|
|
|
gimp_color_managed_get_icc_profile (GimpColorManaged *managed,
|
|
|
|
gsize *len)
|
|
|
|
{
|
|
|
|
GimpColorManagedInterface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GIMP_IS_COLOR_MANAGED (managed), NULL);
|
|
|
|
g_return_val_if_fail (len != NULL, NULL);
|
|
|
|
|
|
|
|
*len = 0;
|
|
|
|
|
2019-07-19 01:14:52 +08:00
|
|
|
iface = GIMP_COLOR_MANAGED_GET_IFACE (managed);
|
2007-06-01 19:19:37 +08:00
|
|
|
|
|
|
|
if (iface->get_icc_profile)
|
|
|
|
return iface->get_icc_profile (managed, len);
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2015-05-13 06:43:16 +08:00
|
|
|
/**
|
|
|
|
* gimp_color_managed_get_color_profile:
|
|
|
|
* @managed: an object the implements the #GimpColorManaged interface
|
|
|
|
*
|
2015-05-31 04:19:36 +08:00
|
|
|
* This function always returns a #GimpColorProfile and falls back to
|
2017-06-04 03:03:25 +08:00
|
|
|
* gimp_color_profile_new_rgb_srgb() if the method is not implemented.
|
2015-05-13 06:43:16 +08:00
|
|
|
*
|
2019-08-03 06:10:14 +08:00
|
|
|
* Returns: (transfer full): The @managed's #GimpColorProfile.
|
2015-05-13 06:43:16 +08:00
|
|
|
*
|
2015-06-01 03:18:09 +08:00
|
|
|
* Since: 2.10
|
2015-05-13 06:43:16 +08:00
|
|
|
**/
|
2015-07-11 04:43:53 +08:00
|
|
|
GimpColorProfile *
|
2015-05-13 06:43:16 +08:00
|
|
|
gimp_color_managed_get_color_profile (GimpColorManaged *managed)
|
|
|
|
{
|
|
|
|
GimpColorManagedInterface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GIMP_IS_COLOR_MANAGED (managed), NULL);
|
|
|
|
|
2019-07-19 01:14:52 +08:00
|
|
|
iface = GIMP_COLOR_MANAGED_GET_IFACE (managed);
|
2015-05-13 06:43:16 +08:00
|
|
|
|
|
|
|
if (iface->get_color_profile)
|
|
|
|
return iface->get_color_profile (managed);
|
|
|
|
|
2015-09-03 07:36:02 +08:00
|
|
|
return NULL;
|
2015-05-13 06:43:16 +08:00
|
|
|
}
|
|
|
|
|
2007-06-01 19:19:37 +08:00
|
|
|
/**
|
2022-06-01 04:59:31 +08:00
|
|
|
* gimp_color_managed_get_simulation_profile:
|
2007-06-01 19:19:37 +08:00
|
|
|
* @managed: an object the implements the #GimpColorManaged interface
|
|
|
|
*
|
2022-06-01 04:59:31 +08:00
|
|
|
* This function always returns a #GimpColorProfile
|
|
|
|
*
|
|
|
|
* Returns: (transfer full): The @managed's simulation #GimpColorProfile.
|
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
GimpColorProfile *
|
|
|
|
gimp_color_managed_get_simulation_profile (GimpColorManaged *managed)
|
|
|
|
{
|
|
|
|
GimpColorManagedInterface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GIMP_IS_COLOR_MANAGED (managed), NULL);
|
|
|
|
|
|
|
|
iface = GIMP_COLOR_MANAGED_GET_IFACE (managed);
|
|
|
|
|
|
|
|
if (iface->get_simulation_profile)
|
|
|
|
return iface->get_simulation_profile (managed);
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2022-08-10 23:01:15 +08:00
|
|
|
/**
|
|
|
|
* gimp_color_managed_get_simulation_intent:
|
|
|
|
* @managed: an object the implements the #GimpColorManaged interface
|
|
|
|
*
|
|
|
|
* This function always returns a #GimpColorRenderingIntent
|
|
|
|
*
|
|
|
|
* Returns: The @managed's simulation #GimpColorRenderingIntent.
|
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
GimpColorRenderingIntent
|
|
|
|
gimp_color_managed_get_simulation_intent (GimpColorManaged *managed)
|
|
|
|
{
|
|
|
|
GimpColorManagedInterface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GIMP_IS_COLOR_MANAGED (managed),
|
|
|
|
GIMP_COLOR_RENDERING_INTENT_RELATIVE_COLORIMETRIC);
|
|
|
|
|
|
|
|
iface = GIMP_COLOR_MANAGED_GET_IFACE (managed);
|
|
|
|
|
|
|
|
if (iface->get_simulation_intent)
|
|
|
|
return iface->get_simulation_intent (managed);
|
|
|
|
|
|
|
|
return GIMP_COLOR_RENDERING_INTENT_RELATIVE_COLORIMETRIC;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_color_managed_get_simulation_bpc:
|
|
|
|
* @managed: an object the implements the #GimpColorManaged interface
|
|
|
|
*
|
|
|
|
* This function always returns a gboolean representing whether
|
|
|
|
* Black Point Compensation is enabled
|
|
|
|
*
|
|
|
|
* Returns: The @managed's simulation Black Point Compensation value.
|
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
gboolean
|
|
|
|
gimp_color_managed_get_simulation_bpc (GimpColorManaged *managed)
|
|
|
|
{
|
|
|
|
GimpColorManagedInterface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GIMP_IS_COLOR_MANAGED (managed), FALSE);
|
|
|
|
|
|
|
|
iface = GIMP_COLOR_MANAGED_GET_IFACE (managed);
|
|
|
|
|
|
|
|
if (iface->get_simulation_bpc)
|
|
|
|
return iface->get_simulation_bpc (managed);
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-06-01 04:59:31 +08:00
|
|
|
/**
|
|
|
|
* gimp_color_managed_profile_changed:
|
|
|
|
* @managed: an object that implements the #GimpColorManaged interface
|
|
|
|
*
|
2007-06-01 19:19:37 +08:00
|
|
|
* Emits the "profile-changed" signal.
|
|
|
|
*
|
2015-06-01 03:18:09 +08:00
|
|
|
* Since: 2.4
|
2007-06-01 19:19:37 +08:00
|
|
|
**/
|
|
|
|
void
|
|
|
|
gimp_color_managed_profile_changed (GimpColorManaged *managed)
|
|
|
|
{
|
|
|
|
g_return_if_fail (GIMP_IS_COLOR_MANAGED (managed));
|
|
|
|
|
|
|
|
g_signal_emit (managed, gimp_color_managed_signals[PROFILE_CHANGED], 0);
|
|
|
|
}
|
2022-06-01 04:59:31 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_color_managed_simulation_profile_changed:
|
|
|
|
* @managed: an object that implements the #GimpColorManaged interface
|
|
|
|
*
|
|
|
|
* Emits the "simulation-profile-changed" signal.
|
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
void
|
|
|
|
gimp_color_managed_simulation_profile_changed (GimpColorManaged *managed)
|
|
|
|
{
|
|
|
|
g_return_if_fail (GIMP_IS_COLOR_MANAGED (managed));
|
|
|
|
|
|
|
|
g_signal_emit (managed, gimp_color_managed_signals[SIMULATION_PROFILE_CHANGED], 0);
|
|
|
|
}
|
2022-08-10 23:01:15 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_color_managed_simulation_intent_changed:
|
|
|
|
* @managed: an object that implements the #GimpColorManaged interface
|
|
|
|
*
|
|
|
|
* Emits the "simulation-intent-changed" signal.
|
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
void
|
|
|
|
gimp_color_managed_simulation_intent_changed (GimpColorManaged *managed)
|
|
|
|
{
|
|
|
|
g_return_if_fail (GIMP_IS_COLOR_MANAGED (managed));
|
|
|
|
|
|
|
|
g_signal_emit (managed, gimp_color_managed_signals[SIMULATION_INTENT_CHANGED], 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_color_managed_simulation_bpc_changed:
|
|
|
|
* @managed: an object that implements the #GimpColorManaged interface
|
|
|
|
*
|
|
|
|
* Emits the "simulation-bpc-changed" signal.
|
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
void
|
|
|
|
gimp_color_managed_simulation_bpc_changed (GimpColorManaged *managed)
|
|
|
|
{
|
|
|
|
g_return_if_fail (GIMP_IS_COLOR_MANAGED (managed));
|
|
|
|
|
|
|
|
g_signal_emit (managed, gimp_color_managed_signals[SIMULATION_BPC_CHANGED], 0);
|
|
|
|
}
|