X-Git-Url: http://git.hungrycats.org/cgi-bin/gitweb.cgi?p=xscreensaver;a=blobdiff_plain;f=hacks%2Fcrystal.c;h=5ceb91f6f2a2f29d2b1a862c8fe2703fe3d14f9e;hp=15c01ba3ffb718c2fee0622dc668f405d0d6ab4f;hb=07faf451b99879183ed7e909e43a0e065be1ee7f;hpb=ffd8c0873576a9e3065696a624dce6b766b77062 diff --git a/hacks/crystal.c b/hacks/crystal.c index 15c01ba3..5ceb91f6 100644 --- a/hacks/crystal.c +++ b/hacks/crystal.c @@ -69,17 +69,13 @@ static const char sccsid[] = "@(#)crystal.c 4.12 98/09/10 xlockmore"; */ #ifdef STANDALONE -# define PROGCLASS "Crystal" -# define HACK_INIT init_crystal -# define HACK_DRAW draw_crystal -# define crystal_opts xlockmore_opts # define DEFAULTS "*delay: 60000 \n" \ "*count: -500 \n" \ "*cycles: 200 \n" \ "*size: -15 \n" \ - "*ncolors: 100 \n" \ - "*fullrandom: True \n" \ - "*verbose: False \n" + "*ncolors: 100 \n" +# define reshape_crystal 0 +# define crystal_handle_event 0 # include "xlockmore.h" /* in xscreensaver distribution */ #else /* STANDALONE */ # include "xlock.h" /* in xlockmore distribution */ @@ -96,11 +92,10 @@ static const char sccsid[] = "@(#)crystal.c 4.12 98/09/10 xlockmore"; #define DEF_MAXSIZE "False" #define DEF_CYCLE "True" -#define min(a,b) ((a) <= (b) ? (a) : (b)) +#undef NRAND +#define NRAND(n) ( (n) ? (int) (LRAND() % (n)) : 0) -#ifdef STANDALONE -void release_crystal(ModeInfo * mi); -#endif +#define min(a,b) ((a) <= (b) ? (a) : (b)) static int nx, ny; @@ -143,7 +138,7 @@ static OptionStruct desc[] = {"-/+shift", "turn on/off colour cycling"} }; -ModeSpecOpt crystal_opts = +ENTRYPOINT ModeSpecOpt crystal_opts = {sizeof opts / sizeof opts[0], opts, sizeof vars / sizeof vars[0], vars, desc}; #ifdef USE_MODULES @@ -560,13 +555,21 @@ crystal_drawatom(ModeInfo * mi, crystalatom * atom0) } } -void +ENTRYPOINT void init_crystal(ModeInfo * mi); +ENTRYPOINT void release_crystal(ModeInfo * mi); + + +ENTRYPOINT void draw_crystal(ModeInfo * mi) { Display *display = MI_DISPLAY(mi); crystalstruct *cryst = &crystals[MI_SCREEN(mi)]; int i; +#ifdef HAVE_COCOA /* Don't second-guess Quartz's double-buffering */ + XClearWindow(MI_DISPLAY(mi), MI_WINDOW(mi)); +#endif + if (cryst->no_colors) { release_crystal(mi); init_crystal(mi); @@ -618,7 +621,7 @@ draw_crystal(ModeInfo * mi) XSetFunction(display, cryst->gc, GXcopy); } -void +ENTRYPOINT void refresh_crystal(ModeInfo * mi) { Display *display = MI_DISPLAY(mi); @@ -785,7 +788,7 @@ refresh_crystal(ModeInfo * mi) XSetFunction(display, cryst->gc, GXcopy); } -void +ENTRYPOINT void release_crystal(ModeInfo * mi) { Display *display = MI_DISPLAY(mi); @@ -821,7 +824,7 @@ release_crystal(ModeInfo * mi) } } -void +ENTRYPOINT void init_crystal(ModeInfo * mi) { Display *display = MI_DISPLAY(mi); @@ -980,9 +983,12 @@ init_crystal(ModeInfo * mi) cryst->offset_w = (int) (cryst->b * 0.5); } } else { + int max_repeat = 10; cryst->offset_w = -1; - while (cryst->offset_w < 4 || (int) (cryst->offset_w - cryst->b * - sin((cryst->gamma - 90) * PI_RAD)) < 4) { + while (max_repeat-- && + (cryst->offset_w < 4 || (int) (cryst->offset_w - cryst->b * + sin((cryst->gamma - 90) * PI_RAD)) < 4) + ) { cryst->b = NRAND((int) (cryst->win_height / (cos((cryst->gamma - 90) * PI_RAD))) - cell_min) + cell_min; if (cryst->planegroup > 8) @@ -1259,6 +1265,7 @@ init_crystal(ModeInfo * mi) crystal_setupatom(atom0, cryst->gamma); crystal_drawatom(mi, atom0); } - XSync(display, False); XSetFunction(display, cryst->gc, GXcopy); } + +XSCREENSAVER_MODULE ("Crystal", crystal)