V10/vol2/Faces/ftg/how
window 0 0 400 400
def init() {
for (y = 0; y < Y; y++)
for (x = 0; x < X; x++)
new[x,y]=y*Z/(Y-1)
}
def mapper(t0, t1, f0, f1, h) {
int dy, blah
if (abs(t0-t1)>1)
{ mapper((t0+t1)/2, t1, (f0+f1)/2, f1, h)
mapper(t0, (t0+t1)/2, f0, (f0+f1)/2, h)
} else
new[t0, h] = $P2[f0, h]
}
def Mapp() {
int start1, start2, end1, end2, dy;
init()
for (y = 0; y < Y; y++)
{ x = 10;
while ($M1[x,yclamp(y-50)] > 128 && x < X)
x++;
start1 = x;
x = X-10;
while ($M1[x,yclamp(y-50)] > 128 && x > 0)
x--;
end1 = x;
x = 10;
while ($M2[x,y] < 128 && x < X)
x++;
start2 = x;
x = X-10
while ($M2[x,y] < 128 && x > 0)
x--;
end2 = x;
if (start1 < end1 && start2 < end2)
mapper(start1, end1, start2, end2, yclamp(y-32))
else
{ for (x = 0; x < X; x++)
new[x,y] = old[x,y]
}
}
}
x { init(); }
x new=old
x { Mapp(); }
x new=old