mirror of https://github.com/GNOME/gimp.git
138 lines
3.6 KiB
C
138 lines
3.6 KiB
C
#ifdef HAVE_CONFIG_H
|
|
#include "config.h"
|
|
#else
|
|
#define HAVE_DIRENT_H
|
|
#define HAVE_UNISTD_H
|
|
#endif
|
|
#include <string.h>
|
|
#include <gtk/gtk.h>
|
|
#ifdef HAVE_UNISTD_H
|
|
#include <unistd.h>
|
|
#endif
|
|
#include "gimpressionist.h"
|
|
#include "ppmtool.h"
|
|
#include <libgimp/stdplugins-intl.h>
|
|
|
|
GtkWidget *previewprev = NULL;
|
|
GtkWidget *previewbutton = NULL;
|
|
GtkWidget *resetpreviewbutton = NULL;
|
|
|
|
void drawalpha(struct ppm *p, struct ppm *a)
|
|
{
|
|
int x, y, g;
|
|
double v;
|
|
int gridsize = 16;
|
|
int rowstride = p->width * 3;
|
|
|
|
for(y = 0; y < p->height; y++) {
|
|
for(x = 0; x < p->width; x++) {
|
|
int k = y*rowstride + x*3;
|
|
if(!a->col[k]) continue;
|
|
v = 1.0 - a->col[k] / 255.0;
|
|
g = ((x/gridsize+y/gridsize)%2)*60+100;
|
|
p->col[k+0] *= v;
|
|
p->col[k+1] *= v;
|
|
p->col[k+2] *= v;
|
|
v = 1.0-v;
|
|
p->col[k+0] += g*v;
|
|
p->col[k+1] += g*v;
|
|
p->col[k+2] += g*v;
|
|
}
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
void updatepreviewprev(GtkWidget *wg, void *d)
|
|
{
|
|
int i;
|
|
char buf[PREVIEWSIZE*3];
|
|
static struct ppm p = {0,0,NULL};
|
|
static struct ppm a = {0,0,NULL};
|
|
static struct ppm backup = {0,0,NULL};
|
|
static struct ppm abackup = {0,0,NULL};
|
|
|
|
if(!infile.col && d) grabarea();
|
|
|
|
if(!infile.col && !d) {
|
|
memset(buf, 0, PREVIEWSIZE*3);
|
|
for(i = 0; i < PREVIEWSIZE; i++) {
|
|
gtk_preview_draw_row (GTK_PREVIEW(previewprev), buf, 0, i, PREVIEWSIZE);
|
|
}
|
|
} else {
|
|
if(!backup.col) {
|
|
copyppm(&infile, &backup);
|
|
if((backup.width != PREVIEWSIZE) || (backup.height != PREVIEWSIZE))
|
|
resize_fast(&backup, PREVIEWSIZE, PREVIEWSIZE);
|
|
if(img_has_alpha) {
|
|
copyppm(&inalpha, &abackup);
|
|
if((abackup.width != PREVIEWSIZE) || (abackup.height != PREVIEWSIZE))
|
|
resize_fast(&abackup, PREVIEWSIZE, PREVIEWSIZE);
|
|
}
|
|
}
|
|
if(!p.col) {
|
|
copyppm(&backup, &p);
|
|
if(img_has_alpha)
|
|
copyppm(&abackup, &a);
|
|
}
|
|
if(d) {
|
|
storevals();
|
|
|
|
if(d != (void *)2)
|
|
repaint(&p, &a);
|
|
}
|
|
if(img_has_alpha)
|
|
drawalpha(&p, &a);
|
|
|
|
for(i = 0; i < PREVIEWSIZE; i++) {
|
|
memset(buf,0,PREVIEWSIZE*3);
|
|
/*for(j = 0; j < p.width; j++)*/
|
|
gtk_preview_draw_row(GTK_PREVIEW(previewprev), (guchar *)&p.col[i*PREVIEWSIZE*3], 0, i, PREVIEWSIZE);
|
|
}
|
|
killppm(&p);
|
|
if(img_has_alpha)
|
|
killppm(&a);
|
|
}
|
|
gtk_widget_draw (previewprev, NULL);
|
|
}
|
|
|
|
GtkWidget* create_preview()
|
|
{
|
|
GtkWidget *box1, *box2, *tmpw;
|
|
|
|
box1 = gtk_vbox_new(FALSE, 0);
|
|
gtk_container_border_width (GTK_CONTAINER (box1), 5);
|
|
|
|
tmpw = gtk_label_new( _("Preview"));
|
|
gtk_box_pack_start(GTK_BOX(box1), tmpw, FALSE, FALSE, 0);
|
|
gtk_widget_show(tmpw);
|
|
|
|
previewprev = tmpw = gtk_preview_new (GTK_PREVIEW_COLOR);
|
|
gtk_preview_size(GTK_PREVIEW (tmpw), PREVIEWSIZE, PREVIEWSIZE);
|
|
gtk_box_pack_start(GTK_BOX (box1), tmpw, FALSE, FALSE, 5);
|
|
gtk_widget_show(tmpw);
|
|
|
|
box2 = gtk_hbox_new(TRUE, 0);
|
|
|
|
previewbutton = tmpw = gtk_button_new_with_label( _("Update"));
|
|
gtk_signal_connect(GTK_OBJECT(tmpw), "clicked",
|
|
(GtkSignalFunc)updatepreviewprev, (void *)1);
|
|
gtk_box_pack_start (GTK_BOX (box2), tmpw, TRUE, TRUE, 0);
|
|
gtk_widget_show(tmpw);
|
|
gtk_tooltips_set_tip(GTK_TOOLTIPS(tooltips), tmpw, _("Refresh the Preview window"), NULL);
|
|
|
|
resetpreviewbutton = tmpw = gtk_button_new_with_label( _("Reset"));
|
|
gtk_signal_connect(GTK_OBJECT(tmpw), "clicked",
|
|
(GtkSignalFunc)updatepreviewprev, (void *)2);
|
|
gtk_box_pack_start (GTK_BOX (box2), tmpw, TRUE, TRUE, 0);
|
|
gtk_widget_show(tmpw);
|
|
gtk_tooltips_set_tip(GTK_TOOLTIPS(tooltips), tmpw, _("Revert to the original image"), NULL);
|
|
|
|
gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, FALSE, 0);
|
|
gtk_widget_show(box2);
|
|
|
|
updatepreviewprev(NULL, 0);
|
|
|
|
return box1;
|
|
}
|