static const char sccsid[] = "@(#)flurry.c 4.07 97/11/24 xlockmore";
#endif
-#define DEF_PRESET "classic"
+#define DEF_PRESET "random"
#define DEF_BRIGHTNESS "8"
-#include <X11/Intrinsic.h>
-
-# define PROGCLASS "Flurry"
-# define HACK_INIT init_flurry
-# define HACK_DRAW draw_flurry
-# define HACK_RESHAPE reshape_flurry
-# define flurry_opts xlockmore_opts
-# define DEFAULTS "*showFPS: False \n" \
- "*preset: " DEF_PRESET " \n"
+# define DEFAULTS "*delay: 10000 \n" \
+ "*showFPS: False \n"
+# define release_flurry 0
+# define flurry_handle_event xlockmore_no_events
# include "xlockmore.h" /* from the xscreensaver distribution */
#ifdef USE_GL
#define countof(x) (sizeof((x))/sizeof((*x)))
-ModeSpecOpt flurry_opts = {countof(opts), opts, countof(vars), vars, NULL};
+ENTRYPOINT ModeSpecOpt flurry_opts = {countof(opts), opts, countof(vars), vars, NULL};
#ifdef USE_MODULES
ModStruct flurry_description = {
"flurry",
"init_flurry",
"draw_flurry",
- "release_flurry",
+ NULL,
"draw_flurry",
"init_flurry",
- NULL,
+ "free_flurry",
&flurry_opts,
1000, 1, 2, 1, 4, 1.0,
"",
#endif
-#include <sys/time.h>
-
#include "flurry.h"
global_info_t *flurry_info = NULL;
-static double gTimeCounter = 0.0;
-
+static
double currentTime(void) {
struct timeval tv;
# ifdef GETTIMEOFDAY_TWO_ARGS
return (double)tv.tv_sec + (double)tv.tv_usec / 1000000.0;
}
-void OTSetup (void) {
- if (gTimeCounter == 0.0) {
- gTimeCounter = currentTime();
- }
-}
-
-double TimeInSecondsSinceStart (void) {
- return currentTime() - gTimeCounter;
+double TimeInSecondsSinceStart (const global_info_t *global) {
+ return currentTime() - global->gTimeCounter;
}
#if 0
#endif
#endif
+
+static
void delete_flurry_info(flurry_info_t *flurry)
{
int i;
{
free(flurry->spark[i]);
}
- free(flurry);
+ /* free(flurry); */
}
+static
flurry_info_t *new_flurry_info(global_info_t *global, int streams, ColorModes colour, float thickness, float speed, double bf)
{
int i,k;
flurry->flurryRandomSeed = RandFlt(0.0, 300.0);
flurry->fOldTime = 0;
- flurry->fTime = TimeInSecondsSinceStart() + flurry->flurryRandomSeed;
+ flurry->dframe = 0;
+ flurry->fTime = TimeInSecondsSinceStart(global) + flurry->flurryRandomSeed;
flurry->fDeltaTime = flurry->fTime - flurry->fOldTime;
flurry->numStreams = streams;
return flurry;
}
+static
void GLSetupRC(global_info_t *global)
{
/* setup the defaults for OpenGL */
glViewport(0,0,(int) global->sys_glWidth,(int) global->sys_glHeight);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
- gluOrtho2D(0,global->sys_glWidth,0,global->sys_glHeight);
+ glOrtho(0,global->sys_glWidth,0,global->sys_glHeight,-1,1);
glMatrixMode(GL_MODELVIEW);
glLoadIdentity();
- glClearColor(0.0,0.0,0.0,1.0);
glClear(GL_COLOR_BUFFER_BIT);
glEnableClientState(GL_COLOR_ARRAY);
#endif /* 0 */
}
+static
void GLRenderScene(global_info_t *global, flurry_info_t *flurry, double b)
{
int i;
flurry->dframe++;
flurry->fOldTime = flurry->fTime;
- flurry->fTime = TimeInSecondsSinceStart() + flurry->flurryRandomSeed;
+ flurry->fTime = TimeInSecondsSinceStart(global) + flurry->flurryRandomSeed;
flurry->fDeltaTime = flurry->fTime - flurry->fOldTime;
flurry->drag = (float) pow(0.9965,flurry->fDeltaTime*85.0);
glDisable(GL_TEXTURE_2D);
}
+static
void GLResize(global_info_t *global, float w, float h)
{
global->sys_glWidth = w;
}
/* new window size or exposure */
-void reshape_flurry(ModeInfo *mi, int width, int height)
+ENTRYPOINT void reshape_flurry(ModeInfo *mi, int width, int height)
{
global_info_t *global = flurry_info + MI_SCREEN(mi);
glViewport(0.0, 0.0, width, height);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
- gluOrtho2D(0, width, 0, height);
+ glOrtho(0, width, 0, height,-1,1);
glMatrixMode(GL_MODELVIEW);
-
- glClearColor(0.0, 0.0, 0.0, 1.0);
glClear(GL_COLOR_BUFFER_BIT);
-
glFlush();
-
GLResize(global, (float)width, (float)height);
}
-void
+ENTRYPOINT void
init_flurry(ModeInfo * mi)
{
int screen = MI_SCREEN(mi);
PRESET_MAX
} preset_num;
- if (flurry_info == NULL) {
- OTSetup();
- if ((flurry_info = (global_info_t *) calloc(MI_NUM_SCREENS(mi),
- sizeof (global_info_t))) == NULL)
- return;
- }
+ MI_INIT (mi, flurry_info);
global = &flurry_info[screen];
+ global->gTimeCounter = currentTime();
+
global->window = MI_WINDOW(mi);
global->flurry = NULL;
case PRESET_FIRE: {
flurry_info_t *flurry;
- flurry = new_flurry_info(global, 12, slowCyclicColorMode, 10000.0, 0.0, 1.0);
+ flurry = new_flurry_info(global, 12, slowCyclicColorMode, 10000.0, 0.2, 1.0);
flurry->next = global->flurry;
global->flurry = flurry;
break;
} else {
MI_CLEARWINDOW(mi);
}
+
+ global->first = 1;
+ global->oldFrameTime = -1;
}
-void
+ENTRYPOINT void
draw_flurry(ModeInfo * mi)
{
- static int first = 1;
- static double oldFrameTime = -1;
double newFrameTime;
double deltaFrameTime = 0;
double brite;
Window window = MI_WINDOW(mi);
newFrameTime = currentTime();
- if (oldFrameTime == -1) {
+ if (global->oldFrameTime == -1) {
/* special case the first frame -- clear to black */
alpha = 1.0;
} else {
* than that and the blending causes the display to
* saturate, which looks really ugly.
*/
- if (newFrameTime - oldFrameTime < 1/60.0) {
- usleep(MAX_(1,(int)(20000 * (newFrameTime - oldFrameTime))));
+ if (newFrameTime - global->oldFrameTime < 1/60.0) {
+ usleep(MAX_(1,(int)(20000 * (newFrameTime - global->oldFrameTime))));
return;
}
- deltaFrameTime = newFrameTime - oldFrameTime;
+ deltaFrameTime = newFrameTime - global->oldFrameTime;
alpha = 5.0 * deltaFrameTime;
}
- oldFrameTime = newFrameTime;
+ global->oldFrameTime = newFrameTime;
if (alpha > 0.2) alpha = 0.2;
if (!global->glx_context)
return;
- if (first) {
+ if (global->first) {
MakeTexture();
- first = 0;
+ global->first = 0;
}
glDrawBuffer(GL_BACK);
glXMakeCurrent(display, window, *(global->glx_context));
glXSwapBuffers(display, window);
}
-void
-release_flurry(ModeInfo * mi)
+ENTRYPOINT void
+free_flurry(ModeInfo * mi)
{
- if (flurry_info != NULL) {
- int screen;
-
- for (screen = 0; screen < MI_NUM_SCREENS(mi); screen++) {
- global_info_t *global = &flurry_info[screen];
- flurry_info_t *flurry;
+ global_info_t *global = &flurry_info[MI_SCREEN(mi)];
+ flurry_info_t *flurry;
- if (global->glx_context) {
- glXMakeCurrent(MI_DISPLAY(mi), global->window, *(global->glx_context));
- }
+ if (global->glx_context) {
+ glXMakeCurrent(MI_DISPLAY(mi), global->window, *(global->glx_context));
+ }
- for (flurry = global->flurry; flurry; flurry=flurry->next) {
- delete_flurry_info(flurry);
- }
- }
- (void) free((void *) flurry_info);
- flurry_info = NULL;
+ for (flurry = global->flurry; flurry; flurry=flurry->next) {
+ delete_flurry_info(flurry);
}
- FreeAllGL(mi);
}
+XSCREENSAVER_MODULE ("Flurry", flurry)
+
#endif