1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
|
/* ----------------------------------------------------------------------
* p_plug_in_gauss_iter_ALT
* ----------------------------------------------------------------------
*/
gint p_plug_in_gauss_iter_ALT(GimpRunMode run_mode, gint32 total_steps, gdouble current_step, gint32 len_struct)
{
typedef enum
{
BLUR_IIR,
BLUR_RLE
} BlurMethod;
typedef struct t_plug_in_gauss_Vals
{
gdouble horizontal;
gdouble vertical;
BlurMethod method;
} t_plug_in_gauss_Vals;
t_plug_in_gauss_Vals buf, *buf_from, *buf_to;
if(len_struct != sizeof(t_plug_in_gauss_Vals))
{
fprintf(stderr, "ERROR: p_plug_in_gauss_iter_ALT stored Data missmatch in size %d != %d\n",
(int)len_struct, sizeof(t_plug_in_gauss_Vals) );
return -1; /* ERROR */
}
gimp_get_data("plug-in-gauss-ITER-FROM", g_plugin_data_from);
gimp_get_data("plug-in-gauss-ITER-TO", g_plugin_data_to);
buf_from = (t_plug_in_gauss_Vals *)&g_plugin_data_from[0];
buf_to = (t_plug_in_gauss_Vals *)&g_plugin_data_to[0];
memcpy(&buf, buf_from, sizeof(buf));
p_delta_gdouble(&buf.horizontal, buf_from->horizontal, buf_to->horizontal, total_steps, current_step);
p_delta_gdouble(&buf.vertical, buf_from->vertical, buf_to->vertical, total_steps, current_step);
gimp_set_data("plug-in-gauss", &buf, sizeof(buf));
return 0; /* OK */
}
|