X-Git-Url: https://jasonwoof.com/gitweb/?p=vor.git;a=blobdiff_plain;f=rocks.c;h=59b401646797afd0b39668c6d31b3244e0390821;hp=19918edb3d143768ec352cf51d8692efb26ff209;hb=d2c7edfd9f15b74baba78b935b555f351b93728c;hpb=13f67bd0888b8b4ccec1a1fb5516074423d0ec32 diff --git a/rocks.c b/rocks.c index 19918ed..59b4016 100644 --- a/rocks.c +++ b/rocks.c @@ -25,6 +25,10 @@ struct shape rock_shapes[NROCKS]; // timers for rock generation. float rtimers[4]; +int32_t rcnt, lrcnt; +int32_t rsum, rsamples; +float ravg; + uint32_t nrocks; uint32_t nrocks_timer; uint32_t nrocks_inc_ticks = 2*60*1000/(F_ROCKS-I_ROCKS); @@ -64,18 +68,26 @@ reset_rocks(void) for(i = 0; i= 1) { + while(rtimers[i] >= 1) { + rtimers[i] -= 1; j=0; while(rockptr->active && j= MAXROCKS) rockptr = rock; j++; } if(!rockptr->active) { - rtimers[i] -= 1; rockptr->type_number = random() % NROCKS; rockptr->image = surf_rock[rockptr->type_number]; rockptr->shape = &rock_shapes[rockptr->type_number]; @@ -139,25 +182,35 @@ new_rocks(void) case RIGHT: rockptr->x = XSIZE; rockptr->y = rnd()*(YSIZE + rockptr->image->h); + + rockptr->dx = -weighted_rnd_range(rmin[i], rmax[i]) + screendx; + rockptr->dy = RDY*crnd(); break; case LEFT: rockptr->x = -rockptr->image->w; rockptr->y = rnd()*(YSIZE + rockptr->image->h); + + rockptr->dx = weighted_rnd_range(rmin[i], rmax[i]) + screendx; + rockptr->dy = RDY*crnd(); break; case BOTTOM: rockptr->x = rnd()*(XSIZE + rockptr->image->w); rockptr->y = YSIZE; + + rockptr->dx = RDX*crnd(); + rockptr->dy = -weighted_rnd_range(rmin[i], rmax[i]) + screendy; break; case TOP: rockptr->x = rnd()*(XSIZE + rockptr->image->w); rockptr->y = -rockptr->image->h; + + rockptr->dx = RDX*crnd(); + rockptr->dy = weighted_rnd_range(rmin[i], rmax[i]) + screendy; break; } - rockptr->dx = RDX*crnd(); - rockptr->dy = RDY*crnd(); - rockptr->active = 1; + rcnt++; } } } @@ -178,9 +231,19 @@ move_rocks(void) if(rock[i].x < -rock[i].image->w || rock[i].x >= XSIZE || rock[i].y < -rock[i].image->h || rock[i].y >= YSIZE) { rock[i].active = 0; + rcnt--; } } } + /* + if(lrcnt == -1 && rcnt == nrocks) lrcnt = 0; + if(rcnt != lrcnt && lrcnt != -1) { + lrcnt = rcnt; + rsum += rcnt-nrocks; rsamples++; + ravg = (float) rsum / rsamples; + printf("%.2f%%\n", 100.0 * ravg / nrocks); + } + */ } void