gimp/plug-ins/gimpressionist/plasma.c

79 lines
1.9 KiB
C
Raw Normal View History

1999-08-27 06:29:37 +08:00
#include <stdlib.h>
#include <time.h>
#include <math.h>
#include "ppmtool.h"
int pfix(int n)
{
if(n<1) return 1;
if(n>255) return 255;
return n;
}
1999-08-30 05:06:26 +08:00
#define PIXEL(y,x,z) p->col[(y)*rowstride+(x)*3+z]
1999-08-27 06:29:37 +08:00
void mkplasma_sub(struct ppm *p, int x1, int x2, int y1, int y2, float turb)
{
1999-08-30 05:06:26 +08:00
int rowstride = p->width * 3;
int r=0;
1999-08-27 06:29:37 +08:00
int xr, yr, nx, ny;
xr = abs(x1-x2);
yr = abs(y1-y2);
if((xr==0) && (yr==0)) return;
nx = (x1+x2)/2;
ny = (y1+y2)/2;
1999-08-30 05:06:26 +08:00
if(!PIXEL(y1,nx,r))
PIXEL(y1,nx,r) = pfix((PIXEL(y1,x1,r)+PIXEL(y1,x2,r))/2.0+
1999-08-27 06:29:37 +08:00
turb*(rand()%xr-xr/2.0));
1999-08-30 05:06:26 +08:00
if(!PIXEL(y2,nx,r))
PIXEL(y2,nx,r) = pfix((PIXEL(y2,x1,r)+PIXEL(y2,x2,r))/2.0+
1999-08-27 06:29:37 +08:00
turb*(rand()%xr-xr/2.0));
1999-08-30 05:06:26 +08:00
if(!PIXEL(ny,x1,r))
PIXEL(ny,x1,r) = pfix((PIXEL(y1,x1,r)+PIXEL(y2,x1,r))/2.0+
1999-08-27 06:29:37 +08:00
turb*(rand()%yr-yr/2.0));
1999-08-30 05:06:26 +08:00
if(!PIXEL(ny,x2,r))
PIXEL(ny,x2,r) = pfix((PIXEL(y1,x2,r)+PIXEL(y2,x2,r))/2.0+
1999-08-27 06:29:37 +08:00
turb*(rand()%yr-yr/2.0));
1999-08-30 05:06:26 +08:00
if(!PIXEL(ny,nx,r))
PIXEL(ny,nx,r) =
pfix((PIXEL(y1,x1,r)+PIXEL(y1,x2,r)+PIXEL(y2,x1,r)+
PIXEL(y2,x2,r))/4.0+turb*(rand()%(xr+yr)/2.0-(xr+yr)/4.0));
1999-08-27 06:29:37 +08:00
if(xr>1) {
mkplasma_sub(p,x1,nx,y1,ny, turb);
mkplasma_sub(p,nx,x2,y1,ny, turb);
}
if(yr>1) {
mkplasma_sub(p,x1,nx,ny,y2, turb);
mkplasma_sub(p,nx,x2,ny,y2, turb);
}
}
void mkplasma_red(struct ppm *p, float turb)
{
int x=0, y=0;
1999-08-30 05:06:26 +08:00
int rowstride = p->width * 3;
1999-08-27 06:29:37 +08:00
for(x = 0; x < p->width; x++)
for(y = 0; y < p->height; y++)
1999-08-30 05:06:26 +08:00
PIXEL(y,x,0) = 0;
1999-08-27 06:29:37 +08:00
x--; y--;
1999-08-30 05:06:26 +08:00
PIXEL(0,0,0) = 1+rand()%255;
PIXEL(y,0,0) = 1+rand()%255;
PIXEL(0,x,0) = 1+rand()%255;
PIXEL(y,x,0) = 1+rand()%255;
1999-08-27 06:29:37 +08:00
mkplasma_sub(p, 0, x, 0, y, turb);
}
void mkgrayplasma(struct ppm *p, float turb)
{
1999-08-30 05:06:26 +08:00
int y,l;
1999-08-27 06:29:37 +08:00
mkplasma_red(p, turb);
1999-08-30 05:06:26 +08:00
l = p->width * 3 * p->height;
for(y = 0; y < l; y += 3)
p->col[y+1] = p->col[y+2] = p->col[y];
1999-08-27 06:29:37 +08:00
}