[gimp] pygimp: adds gimp_image_export functionality to gimp module
- From: João Sebastião de Oliveira Bueno Calligaris <jsbueno src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp] pygimp: adds gimp_image_export functionality to gimp module
- Date: Fri, 20 Jun 2014 20:57:03 +0000 (UTC)
commit e8550148e715f92e4b5ec554701f44c608cc92b2
Author: João S. O. Bueno <gwidion gmail com>
Date: Thu Jun 19 23:58:22 2014 -0300
pygimp: adds gimp_image_export functionality to gimp module
Implements gimp.image_export and gimp.export_dialog
plug-ins/pygimp/Makefile.am | 1 +
plug-ins/pygimp/gimpenumsmodule.c | 124 ++++++++++++++++++++++---------------
plug-ins/pygimp/gimpmodule.c | 110 ++++++++++++++++++++++++++++++++
3 files changed, 186 insertions(+), 49 deletions(-)
---
diff --git a/plug-ins/pygimp/Makefile.am b/plug-ins/pygimp/Makefile.am
index 8974769..4b2e36f 100644
--- a/plug-ins/pygimp/Makefile.am
+++ b/plug-ins/pygimp/Makefile.am
@@ -57,6 +57,7 @@ gimp_la_LIBADD = \
$(libgimp) \
$(libgimpcolor) \
$(libgimpbase) \
+ $(libgimpui) \
$(GLIB_LIBS) \
$(PYLINK_LIBS) \
$(RT_LIBS)
diff --git a/plug-ins/pygimp/gimpenumsmodule.c b/plug-ins/pygimp/gimpenumsmodule.c
index 2a94251..f87dd74 100644
--- a/plug-ins/pygimp/gimpenumsmodule.c
+++ b/plug-ins/pygimp/gimpenumsmodule.c
@@ -28,51 +28,51 @@
#include "pygimp-api.h"
#include "pygimp-util.h"
-
+#include "libgimp/gimpui.h"
static void
add_misc_enums(PyObject *m)
{
PyModule_AddIntConstant(m, "PARASITE_PERSISTENT",
- GIMP_PARASITE_PERSISTENT);
+ GIMP_PARASITE_PERSISTENT);
PyModule_AddIntConstant(m, "PARASITE_UNDOABLE",
- GIMP_PARASITE_UNDOABLE);
+ GIMP_PARASITE_UNDOABLE);
PyModule_AddIntConstant(m, "PARASITE_ATTACH_PARENT",
- GIMP_PARASITE_ATTACH_PARENT);
+ GIMP_PARASITE_ATTACH_PARENT);
PyModule_AddIntConstant(m, "PARASITE_PARENT_PERSISTENT",
- GIMP_PARASITE_PARENT_PERSISTENT);
+ GIMP_PARASITE_PARENT_PERSISTENT);
PyModule_AddIntConstant(m, "PARASITE_PARENT_UNDOABLE",
- GIMP_PARASITE_PARENT_UNDOABLE);
+ GIMP_PARASITE_PARENT_UNDOABLE);
PyModule_AddIntConstant(m, "PARASITE_ATTACH_GRANDPARENT",
- GIMP_PARASITE_ATTACH_GRANDPARENT);
+ GIMP_PARASITE_ATTACH_GRANDPARENT);
PyModule_AddIntConstant(m, "PARASITE_GRANDPARENT_PERSISTENT",
- GIMP_PARASITE_GRANDPARENT_PERSISTENT);
+ GIMP_PARASITE_GRANDPARENT_PERSISTENT);
PyModule_AddIntConstant(m, "PARASITE_GRANDPARENT_UNDOABLE",
- GIMP_PARASITE_GRANDPARENT_UNDOABLE);
+ GIMP_PARASITE_GRANDPARENT_UNDOABLE);
PyModule_AddIntConstant(m, "UNIT_PIXEL",
- GIMP_UNIT_PIXEL);
+ GIMP_UNIT_PIXEL);
PyModule_AddIntConstant(m, "UNIT_INCH",
- GIMP_UNIT_INCH);
+ GIMP_UNIT_INCH);
PyModule_AddIntConstant(m, "UNIT_MM",
- GIMP_UNIT_MM);
+ GIMP_UNIT_MM);
PyModule_AddIntConstant(m, "UNIT_POINT",
- GIMP_UNIT_POINT);
+ GIMP_UNIT_POINT);
PyModule_AddIntConstant(m, "UNIT_PICA",
- GIMP_UNIT_PICA);
+ GIMP_UNIT_PICA);
PyModule_AddIntConstant(m, "MIN_IMAGE_SIZE",
- GIMP_MIN_IMAGE_SIZE);
+ GIMP_MIN_IMAGE_SIZE);
PyModule_AddIntConstant(m, "MAX_IMAGE_SIZE",
- GIMP_MAX_IMAGE_SIZE);
+ GIMP_MAX_IMAGE_SIZE);
PyModule_AddObject(m, "MIN_RESOLUTION",
- PyFloat_FromDouble(GIMP_MIN_RESOLUTION));
+ PyFloat_FromDouble(GIMP_MIN_RESOLUTION));
PyModule_AddObject(m, "MAX_RESOLUTION",
- PyFloat_FromDouble(GIMP_MAX_RESOLUTION));
+ PyFloat_FromDouble(GIMP_MAX_RESOLUTION));
PyModule_AddObject(m, "MAX_MEMSIZE",
- PyLong_FromUnsignedLongLong(GIMP_MAX_MEMSIZE));
+ PyLong_FromUnsignedLongLong(GIMP_MAX_MEMSIZE));
PyModule_AddIntConstant(m, "PIXEL_FETCHER_EDGE_NONE",
GIMP_PIXEL_FETCHER_EDGE_NONE);
@@ -90,68 +90,94 @@ static void
add_compat_enums(PyObject *m)
{
PyModule_AddIntConstant(m, "ADD_WHITE_MASK",
- GIMP_ADD_MASK_WHITE);
+ GIMP_ADD_MASK_WHITE);
PyModule_AddIntConstant(m, "ADD_BLACK_MASK",
- GIMP_ADD_MASK_BLACK);
+ GIMP_ADD_MASK_BLACK);
PyModule_AddIntConstant(m, "ADD_ALPHA_MASK",
- GIMP_ADD_MASK_ALPHA);
+ GIMP_ADD_MASK_ALPHA);
PyModule_AddIntConstant(m, "ADD_ALPHA_TRANSFER_MASK",
- GIMP_ADD_MASK_ALPHA_TRANSFER);
+ GIMP_ADD_MASK_ALPHA_TRANSFER);
PyModule_AddIntConstant(m, "ADD_SELECTION_MASK",
- GIMP_ADD_MASK_SELECTION);
+ GIMP_ADD_MASK_SELECTION);
PyModule_AddIntConstant(m, "ADD_COPY_MASK",
- GIMP_ADD_MASK_COPY);
+ GIMP_ADD_MASK_COPY);
PyModule_AddIntConstant(m, "ADD_CHANNEL_MASK",
- GIMP_ADD_MASK_CHANNEL);
+ GIMP_ADD_MASK_CHANNEL);
PyModule_AddIntConstant(m, "FG_BG_RGB_MODE",
- GIMP_BLEND_FG_BG_RGB);
+ GIMP_BLEND_FG_BG_RGB);
PyModule_AddIntConstant(m, "FG_BG_HSV_MODE",
- GIMP_BLEND_FG_BG_HSV);
+ GIMP_BLEND_FG_BG_HSV);
PyModule_AddIntConstant(m, "FG_TRANSPARENT_MODE",
- GIMP_BLEND_FG_TRANSPARENT);
+ GIMP_BLEND_FG_TRANSPARENT);
PyModule_AddIntConstant(m, "CUSTOM_MODE",
- GIMP_BLEND_CUSTOM);
+ GIMP_BLEND_CUSTOM);
PyModule_AddIntConstant(m, "FG_BUCKET_FILL",
- GIMP_BUCKET_FILL_FG);
+ GIMP_BUCKET_FILL_FG);
PyModule_AddIntConstant(m, "BG_BUCKET_FILL",
- GIMP_BUCKET_FILL_BG);
+ GIMP_BUCKET_FILL_BG);
PyModule_AddIntConstant(m, "PATTERN_BUCKET_FILL",
- GIMP_BUCKET_FILL_PATTERN);
+ GIMP_BUCKET_FILL_PATTERN);
PyModule_AddIntConstant(m, "BLUR_CONVOLVE",
- GIMP_CONVOLVE_BLUR);
+ GIMP_CONVOLVE_BLUR);
PyModule_AddIntConstant(m, "SHARPEN_CONVOLVE",
- GIMP_CONVOLVE_SHARPEN);
+ GIMP_CONVOLVE_SHARPEN);
PyModule_AddIntConstant(m, "IMAGE_CLONE",
- GIMP_CLONE_IMAGE);
+ GIMP_CLONE_IMAGE);
PyModule_AddIntConstant(m, "PATTERN_CLONE",
- GIMP_CLONE_PATTERN);
+ GIMP_CLONE_PATTERN);
PyModule_AddIntConstant(m, "FOREGROUND-FILL",
- GIMP_FILL_FOREGROUND);
+ GIMP_FILL_FOREGROUND);
PyModule_AddIntConstant(m, "BACKGROUND-FILL",
- GIMP_FILL_BACKGROUND);
+ GIMP_FILL_BACKGROUND);
PyModule_AddIntConstant(m, "WHITE-FILL",
- GIMP_FILL_WHITE);
+ GIMP_FILL_WHITE);
PyModule_AddIntConstant(m, "TRANSPARENT-FILL",
- GIMP_FILL_TRANSPARENT);
+ GIMP_FILL_TRANSPARENT);
PyModule_AddIntConstant(m, "PATTERN-FILL",
- GIMP_FILL_PATTERN);
+ GIMP_FILL_PATTERN);
PyModule_AddIntConstant(m, "DODGE",
- GIMP_DODGE_BURN_TYPE_DODGE);
+ GIMP_DODGE_BURN_TYPE_DODGE);
PyModule_AddIntConstant(m, "BURN",
- GIMP_DODGE_BURN_TYPE_BURN);
+ GIMP_DODGE_BURN_TYPE_BURN);
PyModule_AddIntConstant(m, "SHADOWS",
- GIMP_TRANSFER_SHADOWS);
+ GIMP_TRANSFER_SHADOWS);
PyModule_AddIntConstant(m, "MIDTONES",
- GIMP_TRANSFER_MIDTONES);
+ GIMP_TRANSFER_MIDTONES);
PyModule_AddIntConstant(m, "HIGHLIGHTS",
- GIMP_TRANSFER_HIGHLIGHTS);
+ GIMP_TRANSFER_HIGHLIGHTS);
+
+ PyModule_AddIntConstant(m, "EXPORT_CAN_HANDLE_RGB",
+ GIMP_EXPORT_CAN_HANDLE_RGB);
+ PyModule_AddIntConstant(m, "EXPORT_CAN_HANDLE_GRAY",
+ GIMP_EXPORT_CAN_HANDLE_GRAY);
+ PyModule_AddIntConstant(m, "EXPORT_CAN_HANDLE_INDEXED",
+ GIMP_EXPORT_CAN_HANDLE_INDEXED);
+ PyModule_AddIntConstant(m, "EXPORT_CAN_HANDLE_BITMAP",
+ GIMP_EXPORT_CAN_HANDLE_BITMAP);
+ PyModule_AddIntConstant(m, "EXPORT_CAN_HANDLE_ALPHA",
+ GIMP_EXPORT_CAN_HANDLE_ALPHA);
+ PyModule_AddIntConstant(m, "EXPORT_CAN_HANDLE_LAYERS",
+ GIMP_EXPORT_CAN_HANDLE_LAYERS);
+ PyModule_AddIntConstant(m, "EXPORT_CAN_HANDLE_LAYERS_AS_ANIMATION",
+ GIMP_EXPORT_CAN_HANDLE_LAYERS_AS_ANIMATION);
+ PyModule_AddIntConstant(m, "EXPORT_CAN_HANDLE_LAYER_MASKS",
+ GIMP_EXPORT_CAN_HANDLE_LAYER_MASKS);
+ PyModule_AddIntConstant(m, "EXPORT_NEEDS_ALPHA",
+ GIMP_EXPORT_NEEDS_ALPHA);
+
+ PyModule_AddIntConstant(m, "EXPORT_CANCEL",
+ GIMP_EXPORT_CANCEL);
+ PyModule_AddIntConstant(m, "EXPORT_IGNORE",
+ GIMP_EXPORT_IGNORE);
+ PyModule_AddIntConstant(m, "EXPORT_EXPORT",
+ GIMP_EXPORT_EXPORT);
}
static void
@@ -166,7 +192,7 @@ add_registered_enums(PyObject *m)
pyg_enum_add_constants(m, GIMP_TYPE_CHECK_TYPE, "GIMP_");
for (i = 0; i < num_names; i++)
- pyg_enum_add_constants(m, g_type_from_name(names[i]), "GIMP_");
+ pyg_enum_add_constants(m, g_type_from_name(names[i]), "GIMP_");
}
@@ -198,5 +224,5 @@ init_gimpenums(void)
/* Check for errors */
if (PyErr_Occurred())
- Py_FatalError("can't initialize module _gimpenums");
+ Py_FatalError("can't initialize module _gimpenums");
}
diff --git a/plug-ins/pygimp/gimpmodule.c b/plug-ins/pygimp/gimpmodule.c
index 28367f2..1cce749 100644
--- a/plug-ins/pygimp/gimpmodule.c
+++ b/plug-ins/pygimp/gimpmodule.c
@@ -35,6 +35,10 @@
#include "pygimp-intl.h"
+#include "libgimp/gimpui.h"
+
+#include <gtk/gtk.h>
+
PyObject *pygimp_error;
@@ -1678,6 +1682,110 @@ id2vectors(PyObject *self, PyObject *args)
return Py_None;
}
+static PyObject *
+pygimp_export_image (PyObject *self, PyObject *args, PyObject *kwargs)
+{
+
+ PyGimpImage *img;
+ PyGimpDrawable *drw = NULL;
+ gchar *format_name = NULL;
+ unsigned int capabilities = -1;
+ GimpExportCapabilities result;
+ gint32 img_id;
+ gint32 drw_id;
+ PyObject *return_values;
+
+ static char *kwlist[] = { "image", "drawable", "format_name", "capabilities", NULL };
+ if (!PyArg_ParseTupleAndKeywords(args, kwargs, "O!|OsI:export_image", kwlist,
+ &PyGimpImage_Type, &img,
+ &drw,
+ &format_name,
+ &capabilities))
+ return NULL;
+ if (capabilities == -1) {
+ PyErr_SetString(PyExc_TypeError,
+ "the \"capabilities\" (4th) parameter must be set with "
+ "a combination of the "
+ "EXPORT_CAN_HANDLE_*/EXPORT_NEEDS_ALPHA values. "
+ "(check develeloper documentation on the C function "
+ "gimp_export_image for details)"
+ );
+ return NULL;
+ }
+
+ /* If no drawable is given, assume the active drawable */
+ if (drw == NULL) {
+ drw = (PyGimpDrawable *)PyObject_GetAttrString((PyObject *)img,
+ "active_drawable");
+ if ((PyObject *)drw == Py_None) {
+ PyErr_SetString(PyExc_ValueError,
+ "No active drawable in the image and no drawable "
+ " specified for export."
+ );
+ return NULL;
+ }
+ }
+ img_id = img->ID;
+ drw_id = drw->ID;
+
+ result = gimp_export_image(&img_id, &drw_id, format_name, capabilities);
+
+ if (img_id != img->ID) {
+ img = (PyGimpImage *)pygimp_image_new(img_id);
+ }
+ else {
+ Py_INCREF(img);
+ }
+ if (drw_id != drw->ID) {
+ drw = (PyGimpDrawable *)pygimp_drawable_new(NULL, drw_id);
+ }
+ else {
+ Py_INCREF(drw);
+ }
+
+ return_values = PyTuple_New(3);
+ PyTuple_SetItem(return_values, 0, PyInt_FromLong(result));
+ PyTuple_SetItem(return_values, 1, (PyObject *)img);
+ PyTuple_SetItem(return_values, 2, (PyObject *)drw);
+
+ return return_values;
+}
+
+static PyObject *
+pygimp_export_dialog_new (PyObject *self, PyObject *args, PyObject *kwargs)
+{
+ gchar *format_name;
+ gchar *role = NULL;
+ gchar *help_id = NULL;
+ GtkWidget *dialog = NULL;
+
+ static char *kwlist[] = { "format_name", "role", "help_id", NULL };
+ if (!PyArg_ParseTupleAndKeywords(args, kwargs, "s|ss:export_dialog", kwlist,
+ &format_name,
+ &role,
+ &help_id))
+ return NULL;
+
+ if (role == NULL) {
+ role = "gimp_export_image";
+ }
+
+ dialog = gimp_export_dialog_new(format_name, role, help_id);
+
+ /* pyobject_new handles NULL values */
+
+ return pygobject_new((GObject *)dialog);
+
+}
+
+/* No need to expose "gimp_export_dialog_get_content_area",
+ * because one just have to call the "get_content_area" method
+ * on the returned export_dialog
+ */
+
+static PyObject *
+pygimp_export_dialog_ (PyObject *self, PyObject *args, PyObject *kwargs)
+
/* List of methods defined in the module */
static struct PyMethodDef gimp_methods[] = {
@@ -1752,6 +1860,8 @@ static struct PyMethodDef gimp_methods[] = {
{"_id2drawable", (PyCFunction)id2drawable, METH_VARARGS},
{"_id2display", (PyCFunction)id2display, METH_VARARGS},
{"_id2vectors", (PyCFunction)id2vectors, METH_VARARGS},
+ {"export_image", (PyCFunction)pygimp_export_image, METH_VARARGS | METH_KEYWORDS},
+ {"export_dialog", (PyCFunction)pygimp_export_dialog_new, METH_VARARGS | METH_KEYWORDS},
{NULL, (PyCFunction)NULL, 0, NULL} /* sentinel */
};
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]