ref: a83a58dac35a9723d02f7b36361f07f41ace5cde
dir: /r_sky.c/
#include <u.h> #include <libc.h> #include "dat.h" #include "quakedef.h" #include "fns.h" int iskyspeed = 8; int iskyspeed2 = 2; float skyspeed, skyspeed2; float skytime; byte *r_skysource[2]; int r_skymade, skyw, skyh; /* ============= R_InitSky ============== */ void R_InitSky (texture_t *mt) { int x, y, w, n; byte *src; src = (byte *)mt + mt->offsets[0]; w = mt->width; skyh = mt->height; if(w == skyh){ // probably without a mask? skyw = w; n = skyw*skyh; r_skysource[0] = Hunk_Alloc(n); r_skysource[1] = r_skysource[0]; memmove(r_skysource[0], src, n); return; } skyw = w/2; n = skyw*skyh; r_skysource[0] = Hunk_Alloc(n*2); r_skysource[1] = r_skysource[0] + n; for(y=0 ; y<skyh; y++){ for(x=0 ; x<skyw; x++){ r_skysource[0][y*skyw + x] = src[y*w + skyw + x]; r_skysource[1][y*skyw + x] = src[y*w + x]; } } } /* ============= R_SetSkyFrame ============== */ void R_SetSkyFrame (void) { int g, s1, s2; float temp; skyspeed = iskyspeed; skyspeed2 = iskyspeed2; g = GreatestCommonDivisor (iskyspeed, iskyspeed2); s1 = iskyspeed / g; s2 = iskyspeed2 / g; temp = skyh * s1 * s2; skytime = cl.time - ((int)(cl.time / temp) * temp); r_skymade = 0; }