2 static const char sccsid[] = "@(#)b_lockglue.c 4.11 98/06/16 xlockmore";
6 * BUBBLE3D (C) 1998 Richard W.M. Jones.
7 * b_lockglue.c: Glue to make this all work with xlockmore.
12 /* XXX This lot should eventually be made configurable using the
13 * options stuff below.
15 struct glb_config glb_config =
17 0, /* transparent_p */
19 2, /* subdivision_depth */
21 3, /* subdivision_depth */
23 5, /* nr_nudge_axes */
24 0.01, /* nudge_angle_factor */
25 0.20, /* nudge_factor */
26 0.1, /* rotation_factor */
27 8, /* create_bubbles_every */
29 {0.7, 0.8, 0.9, 1.0}, /* p_bubble_group */
33 0.005, /* min_speed */
34 1.5, /* scale_factor */
35 -4, /* screen_bottom */
37 {0.0, 0.0, 0.7, 0.3} /* bubble_colour */
41 # define DEFAULTS "*delay: 10000 \n" \
44 # define refresh_bubble3d 0
45 # define release_bubble3d 0
46 # define bubble3d_handle_event 0
47 #include "xlockmore.h"
56 #define DEF_TRANSPARENT "True"
57 #define DEF_BUBBLECOLOR "random"
59 static Bool transparent_p;
60 static char *bubble_color_str;
63 #define countof(x) (sizeof((x))/sizeof((*x)))
65 static XrmOptionDescRec opts[] = {
66 { "-transparent", ".transparent", XrmoptionNoArg, "True" },
67 { "+transparent", ".transparent", XrmoptionNoArg, "False" },
68 { "-color", ".bubblecolor", XrmoptionSepArg, 0 },
71 static argtype vars[] = {
72 {&transparent_p, "transparent", "Transparent", DEF_TRANSPARENT, t_Bool},
73 {&bubble_color_str, "bubblecolor", "BubbleColor", DEF_BUBBLECOLOR, t_String},
76 ENTRYPOINT ModeSpecOpt bubble3d_opts = {countof(opts), opts, countof(vars), vars, NULL};
79 ModStruct bubbles3d_description =
88 1000, 1, 2, 1, 64, 1.0, "",
89 "Richard Jones's GL bubbles",
94 #endif /* USE_MODULES */
97 GLXContext *glx_context;
101 static struct context *contexts = 0;
104 parse_color (ModeInfo *mi, const char *name, const char *s, GLfloat *a)
108 if (! XParseColor (MI_DISPLAY(mi), MI_COLORMAP(mi), s, &c))
110 fprintf (stderr, "%s: can't parse %s color %s", progname, name, s);
113 a[0] = c.red / 65536.0;
114 a[1] = c.green / 65536.0;
115 a[2] = c.blue / 65536.0;
119 init_colors(ModeInfo *mi)
121 if (strncasecmp(bubble_color_str, "auto", strlen("auto")) == 0) {
122 glb_config.bubble_colour[0] = ((float) (NRAND(100)) / 100.0);
123 glb_config.bubble_colour[1] = ((float) (NRAND(100)) / 100.0);
124 /* I keep more blue */
125 glb_config.bubble_colour[2] = ((float) (NRAND(50)) / 100.0) + 0.50;
126 } else if (strncasecmp(bubble_color_str, "random", strlen("random")) == 0) {
127 glb_config.bubble_colour[0] = -1.0;
129 parse_color(mi, "bubble", bubble_color_str, glb_config.bubble_colour);
134 init(struct context *c)
136 glb_config.transparent_p = transparent_p;
138 c->draw_context = glb_draw_init();
142 reshape_bubble3d(ModeInfo *mi, int w, int h)
144 glViewport(0, 0, (GLsizei) w, (GLsizei) h);
145 glMatrixMode(GL_PROJECTION);
147 gluPerspective(45, (GLdouble) w / (GLdouble) h, 3, 8);
148 glMatrixMode(GL_MODELVIEW);
150 glTranslatef(0, 0, -5);
154 do_display(struct context *c)
156 glb_draw_step(c->draw_context);
159 static void free_bubble3d(ModeInfo * mi);
162 init_bubble3d(ModeInfo * mi)
164 Display *display = MI_DISPLAY(mi);
165 Window window = MI_WINDOW(mi);
166 int screen = MI_SCREEN(mi);
169 MI_INIT (mi, contexts, free_bubble3d);
170 c = &contexts[screen];
171 c->glx_context = init_GL(mi);
173 if (c->glx_context != 0) {
175 reshape_bubble3d(mi, MI_WIDTH(mi), MI_HEIGHT(mi));
178 glXSwapBuffers(display, window);
184 draw_bubble3d(ModeInfo * mi)
186 struct context *c = &contexts[MI_SCREEN(mi)];
187 Display *display = MI_DISPLAY(mi);
188 Window window = MI_WINDOW(mi);
190 MI_IS_DRAWN(mi) = True;
195 glXMakeCurrent(display, window, *(c->glx_context));
197 glb_config.polygon_count = 0;
200 # ifdef HAVE_MOBILE /* Keep it the same relative size when rotated. */
202 GLfloat h = MI_HEIGHT(mi) / (GLfloat) MI_WIDTH(mi);
203 int o = (int) current_device_rotation();
204 if (o != 0 && o != 180 && o != -180)
205 glScalef (1/h, 1/h, 1/h);
206 glRotatef(o, 0, 0, 1);
212 mi->polygon_count = glb_config.polygon_count;
214 if (mi->fps_p) do_fps (mi);
216 glXSwapBuffers(display, window);
221 change_bubble3d(ModeInfo * mi)
225 #endif /* !STANDALONE */
228 free_bubble3d(ModeInfo * mi)
230 struct context *c = &contexts[MI_SCREEN(mi)];
232 glb_draw_end(c->draw_context);
235 XSCREENSAVER_MODULE ("Bubble3D", bubble3d)