38 static dot_t dot[MAXDOT];
39 static init_t bl_ini[MAXINI],sp_ini[MAXINI];
40 static int bl_r,sp_r,sr_r,sxr[MAXSR],syr[MAXSR];
43 void DOT_savegame(int h) {
46 for(i=n=0;i<MAXDOT;++i) if(dot[i].t) ++n;
48 // printf("dots: %d\n",n);
49 for(i=0;i<MAXDOT;++i) if(dot[i].t) write(h,&dot[i],sizeof(dot_t));
52 void DOT_loadgame(int h) {
56 // printf("dots: %d\n",n);
57 read(h,dot,n*sizeof(dot_t));
58 // for(i=0;i<n;++i) printf("dot#%d %u\n",i,(unsigned)dot[i].t);
64 for(i=0;i<MAXDOT;++i) {dot[i].t=0;dot[i].o.r=0;dot[i].o.h=1;}
68 static void incldot(void) {
69 if(++ldot>=MAXDOT) ldot=0;
72 void DOT_alloc(void) {
76 for(i=0;i<MAXINI;++i) {
77 bl_ini[i].xv=random(BL_XV*2+1)-BL_XV;
78 bl_ini[i].yv=-random(BL_YV);
79 bl_ini[i].c=0xB0+random(16);
80 bl_ini[i].t=random(BL_MAXT-BL_MINT+1)+BL_MINT;
81 sp_ini[i].xv=random(SP_V*2+1)-SP_V;
82 sp_ini[i].yv=random(SP_V*2+1)-SP_V;
83 sp_ini[i].c=0xA0+random(6);
84 sp_ini[i].t=random(SP_MAXT-SP_MINT+1)+SP_MINT;
86 for(i=0;i<MAXSR;++i) {
87 sxr[i]=random(2*2+1)-2;
88 syr[i]=random(2*2+1)-2;
97 for(i=0;i<MAXDOT;++i) if(dot[i].t) {
98 xv=dot[i].o.xv+dot[i].o.vx;
99 yv=dot[i].o.yv+dot[i].o.vy;
100 s=Z_moveobj(&dot[i].o);
101 if(dot[i].t<254) --dot[i].t;
102 if(s&(Z_HITWATER|Z_FALLOUT)) {dot[i].t=0;continue;}
106 if(!xv) dot[i].o.vx=(rand()&1)?-1:1;
107 else dot[i].o.vx=Z_sign(dot[i].o.vx);
108 if(rand()%yv==0) dot[i].o.vx*=2;
113 if(dot[i].t>4 && dot[i].t!=255) dot[i].t=4;
116 dot[i].o.vx=Z_sign(xv)*2;
117 dot[i].o.yv=Z_sign(dot[i].o.yv);
118 if(dot[i].o.yv>=0) if(rand()&3) --dot[i].o.yv;
119 if(dot[i].o.yv>=0) if(rand()&1) --dot[i].o.yv;
121 if(s&Z_HITCEIL) {dot[i].o.xv=0;dot[i].o.yv=(random(100))?-2:0;}
126 void DOT_draw(void) {
129 for(i=0;i<MAXDOT;++i)
130 if(dot[i].t) V_dot(dot[i].o.x-w_x+100,dot[i].o.y-w_y+50+w_o,dot[i].c);
133 void DOT_add(int x,int y,char xv,char yv,byte c,byte t) {
136 if(!Z_canfit(x,y,0,1)) return;
138 dot[i].o.x=x;dot[i].o.y=y;
139 dot[i].o.xv=xv;dot[i].o.yv=yv;
140 dot[i].c=c;dot[i].t=t;
141 dot[i].o.vx=dot[i].o.vy=0;
145 void DOT_blood(int x,int y,int xv,int yv,int n) {
149 dx=x+sxr[sr_r];dy=y+syr[sr_r];
150 if(!Z_canfit(x,y,0,1)) continue;
152 dot[i].o.x=dx;dot[i].o.y=dy;
153 dot[i].o.xv=bl_ini[bl_r].xv+Z_dec(xv,3);
154 dot[i].o.yv=bl_ini[bl_r].yv+Z_dec(yv,3)-3;
155 dot[i].c=bl_ini[bl_r].c;
157 dot[i].o.vx=dot[i].o.vy=0;
158 if(++bl_r>=MAXINI) bl_r=0;
159 if(++sr_r>=MAXSR) sr_r=0;
164 void DOT_spark(int x,int y,int xv,int yv,int n) {
168 dx=x+sxr[sr_r];dy=y+syr[sr_r];
169 if(!Z_canfit(x,y,0,1)) continue;
171 dot[i].o.x=dx;dot[i].o.y=dy;
172 dot[i].o.xv=sp_ini[sp_r].xv-xv/4;
173 dot[i].o.yv=sp_ini[sp_r].yv-yv/4;
174 dot[i].c=sp_ini[sp_r].c;
175 dot[i].t=sp_ini[sp_r].t;
176 dot[i].o.vx=dot[i].o.vy=0;
177 if(++sp_r>=MAXINI) sp_r=0;
178 if(++sr_r>=MAXSR) sr_r=0;
183 void DOT_water(int x,int y,int xv,int yv,int n,int c) {
185 static byte ct[3]={0xC0,0x70,0xB0};
187 if(c<0 || c>=3) return;
190 dx=x+sxr[sr_r];dy=y+syr[sr_r];
191 if(!Z_canfit(x,y,0,1)) continue;
193 dot[i].o.x=dx;dot[i].o.y=dy;
194 dot[i].o.xv=bl_ini[bl_r].xv-Z_dec(xv,3);
195 dot[i].o.yv=bl_ini[bl_r].yv-abs(yv);
196 dot[i].c=bl_ini[bl_r].c-0xB0+c;
198 dot[i].o.vx=dot[i].o.vy=0;
199 if(++bl_r>=MAXINI) bl_r=0;
200 if(++sr_r>=MAXSR) sr_r=0;