nuclear@0: /* nuclear@0: A simple interactive mandelbrot fractal explorer nuclear@0: Copyright (C) John Tsiombikas nuclear@0: nuclear@0: This program is free software: you can redistribute it and/or modify nuclear@0: it under the terms of the GNU General Public License as published by nuclear@0: the Free Software Foundation, either version 3 of the License, or nuclear@0: (at your option) any later version. nuclear@0: nuclear@0: This program is distributed in the hope that it will be useful, nuclear@0: but WITHOUT ANY WARRANTY; without even the implied warranty of nuclear@0: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the nuclear@0: GNU General Public License for more details. nuclear@0: nuclear@0: You should have received a copy of the GNU General Public License nuclear@0: along with this program. If not, see . nuclear@0: */ nuclear@0: #include "mbrot.h" nuclear@0: #include "palette.h" nuclear@0: nuclear@0: static int mandelbrot(double cx, double cy, int iter); nuclear@0: nuclear@0: void draw_mandelbrot(unsigned char *pix, int xsz, int ysz, struct area *area, int iter) nuclear@0: { nuclear@0: int i, j; nuclear@0: double x, y, dx, dy; nuclear@0: nuclear@0: dx = area->width / (double)xsz; nuclear@0: dy = area->height / (double)ysz; nuclear@0: nuclear@0: y = area->y; nuclear@0: for(i=0; ix; nuclear@0: for(j=0; j 2 */ nuclear@0: if((x * x + y * y) > 4.0) { nuclear@0: break; nuclear@0: } nuclear@0: } nuclear@0: nuclear@0: return i; nuclear@0: }