3 #include <stdlib.h> // abs()
24 static vgaimg
*scrnh
[3]; // TITLEPIC INTERPIC ENDPIC
25 static vgaimg
*ltn
[2][2];
28 static vgaimg
*smk_spr
[SMSN
];
29 static vgaimg
*smk_fspr
[FLSN
];
31 static vgaimg
*fx_spr
[15];
32 static char fx_sprd
[15];
34 static vgaimg
*wp_spr
[49*2];
35 static char wp_sprd
[49*2];
37 static vgaimg
*item_spr
[58];
38 static char item_sprd
[58];
40 static vgaimg
*plr_spr
[27*2];
41 static char plr_sprd
[27*2];
42 static vgaimg
*plr_wpn
[11][6];
44 static vgaimg
*pl_spr
[2];
45 static vgaimg
*mn_spr
[MN_TN
][29*2];
46 static char mn_sprd
[MN_TN
][29*2];
47 static vgaimg
*mn_fspr
[8];
48 static vgaimg
*mn_sgun
[2];
51 static vgaimg
*sth
[22], *bfh
[160 - '!'], *sfh
[160 - '!'], *stone
, *stone2
, *keys
[3];
52 static int prx
= 0, pry
= 0;
54 static vgaimg
*msklh
[2], *mbarl
, *mbarm
, *mbarr
, *mbaro
, *mslotl
, *mslotm
, *mslotr
;
56 static int gammaa
= 0;
57 static char main_pal
[256][3];
58 static char std_pal
[256][3];
59 static byte gamcor
[5][64]={
64 static vgaimg
*walp
[256];
66 static byte walani
[256];
67 static int anih
[ANIT
][5];
68 static byte anic
[ANIT
];
69 static int max_textures
;
72 extern byte bright
[256]; // vga.c
73 extern byte mixmap
[256][256]; // vga.c
74 extern byte clrmap
[256*12]; // vga.c
76 extern int g_trans
; // game.c
77 extern byte transdraw
; // game.c
78 extern int sky_type
; // view.c
79 extern int lt_time
, lt_type
, lt_side
, lt_ypos
, lt_force
; // game.c
81 extern byte savname
[7][24]; // files.c
82 extern char g_music
[8]; // game.c
83 extern short snd_vol
; // sound.c
84 extern short mus_vol
; // music.c
88 static void *Z_getspr (char n
[4], int s
, int d
, char *dir
) {
89 int h
= F_getsprid(n
, s
, d
);
91 *dir
= (h
& 0x8000) ? 1 : 0;
93 return V_getvgaimg(h
);
96 static void Z_putbfch (int c
) {
98 if (c
> 32 && c
< 160) {
111 static void Z_putsfch(int c
) {
113 if (c
> 32 && c
< 160) {
126 static void Z_gotoxy (int x
, int y
) {
131 static void Z_printbf(char *s
, ...) {
136 vsprintf(buf
, s
, ap
);
138 for (i
= 0; buf
[i
]; ++i
) {
146 Z_putbfch((byte
)buf
[i
]);
151 static void Z_printsf (char *s
, ...) {
156 vsprintf(buf
, s
, ap
);
158 for (i
= 0; buf
[i
]; ++i
) {
166 Z_putsfch((byte
)buf
[i
]);
171 static void Z_drawspr (int x
, int y
, void *p
, char d
) {
173 V_spr2(x
- w_x
+ WD
/ 2, y
- w_y
+ HT
/ 2 + 1 + w_o
, p
);
175 V_spr(x
- w_x
+ WD
/ 2, y
- w_y
+ HT
/ 2 + 1 + w_o
, p
);
179 static void Z_clrst (void) {
180 V_pic(SCRW
- 120, w_o
, stone
);
181 int y
= ((vgaimg
*)stone
)->h
;
183 V_pic(SCRW
- 120, w_o
+ y
, stone2
);
184 y
+= ((vgaimg
*)stone
)->h
;
188 static void Z_drawstlives (char n
) {
189 V_setrect(SCRW
- 40, 30, w_o
, 40);
190 V_spr(SCRW
- 35, w_o
+ 17, sth
[n
]);
193 static void Z_drawstkeys (byte k
) {
195 V_setrect(SCRW
- 120, 70, w_o
+ 77, 23);
196 for (k
>>= 4, n
= 0, x
= SCRW
- 75; n
< 3; ++n
, k
>>= 1, x
+= 9) {
198 V_spr(x
, w_o
+ 91, keys
[n
]);
203 static void Z_drawstair (int a
) {
204 V_setrect(SCRW
- 120, 120, w_o
+ 49, 2);
209 a
= a
* 100 / MAXAIR
;
210 V_clr(SCRW
- 110, a
, w_o
+ 49, 2, 0xC8);
214 static void Z_drawstprcnt (int y
, int n
) {
217 V_setrect(SCRW
- 120, 70, y
* 19 + 7 + w_o
, 19);
218 sprintf(s
, "%3d%%", n
);
221 for (i
= 0; i
< l
; ++i
, x
+= 14) {
222 if (s
[i
] >='0' && s
[i
] <= '9') {
224 } else if (s
[i
] == '-') {
226 } else if (s
[i
] == '%') {
232 V_spr(x
, y
* 19 + 7 + w_o
, sth
[c
]);
237 static void Z_drawstnum (int n
) {
240 V_setrect(SCRW
- 50, 50, w_o
+ 77, 23);
244 x
= (115 - l
* 14) + SCRW
- 120;
245 for (i
= 0; i
< l
; ++i
, x
+= 14) {
246 if (s
[i
] >= '0' && s
[i
] <= '9') {
248 } else if (s
[i
] == '-') {
250 } else if(s
[i
] == '%') {
256 V_spr(x
, w_o
+ 77 + 5, sth
[c
]);
262 static void Z_drawstwpn (int n
, int a
) {
266 V_setrect(SCRW
- 120, 120, w_o
+ 58, 23);
268 V_spr(SCRW
- 88, w_o
+ 58 + 19, sth
[i
+ 12]);
273 x
= SCRW
- 10 - l
* 14;
274 for (i
= 0; i
< l
; ++i
, x
+= 14) {
275 if (s
[i
] >= '0' && s
[i
] <= '9') {
277 } else if (s
[i
] == '-') {
279 } else if (s
[i
] == '%') {
285 V_spr(x
, w_o
+ 58 + 2, sth
[c
]);
291 static void Z_drawmanspr (int x
, int y
, void *p
, char d
, byte color
) {
293 V_manspr2(x
- w_x
+ WD
/ 2, y
- w_y
+ HT
/ 2 + 1 + w_o
, p
, color
);
295 V_manspr(x
- w_x
+ WD
/ 2, y
- w_y
+ HT
/ 2 + 1 + w_o
, p
, color
);
299 static void Z_drawfld (byte
*fld
, int bg
) {
302 for (y
= 0; y
< FLDH
; y
++) {
303 for (x
= 0; x
< FLDW
; x
++) {
304 int sx
= x
* CELW
- w_x
+ WD
/ 2;
305 int sy
= y
* CELH
- w_y
+ HT
/ 2 + 1 + w_o
;
308 int spc
= R_get_special_id(id
);
311 byte
*cmap
= clrmap
+ (spc
+ 7) * 256;
312 V_remap_rect(sx
, sy
, CELW
, CELH
, cmap
);
315 V_pic(sx
, sy
, walp
[id
]);
325 static int gm_tm
= 0; // ???
327 static vgaimg
*PL_getspr (int s
, int d
) {
328 return plr_spr
[(s
- 'A') * 2 + d
];
331 static int GM_draw (void) {
332 enum {MENU
, MSG
}; // copypasted from menu.c!
334 CANCEL
, NEWGAME
, LOADGAME
, SAVEGAME
, OPTIONS
, QUITGAME
, QUIT
, ENDGAME
, ENDGM
,
335 PLR1
, PLR2
, COOP
, DM
, VOLUME
, GAMMA
, LOAD
, SAVE
, PLCOLOR
, PLCEND
, MUSIC
, INTERP
,
336 SVOLM
, SVOLP
, MVOLM
, MVOLP
, GAMMAM
, GAMMAP
, PL1CM
, PL1CP
, PL2CM
, PL2CP
337 }; // copypasted from menu.c!
340 V_setrect(0, SCRW
, 0, SCRH
);
341 if (!mnu
&& !gm_redraw
) {
348 if (mnu
->type
== MENU
) {
349 y
= (200 - mnu
-> n
* 16 - 20) / 2;
350 Z_gotoxy(mnu
->x
, y
- 10); Z_printbf(mnu
->ttl
);
351 for (i
= 0; i
< mnu
->n
; ++i
) {
352 if (mnu
->t
[i
] == LOAD
|| mnu
->t
[i
] == SAVE
) {
354 V_spr(mnu
->x
, j
, mslotl
);
355 for (k
= 8; k
< 184; k
+= 8) {
356 V_spr(mnu
->x
+ k
, j
, mslotm
);
358 V_spr(mnu
->x
+184,j
,mslotr
);
359 Z_gotoxy(mnu
->x
+4,j
-8);
360 if (input
&& i
== save_mnu
.cur
) {
361 Z_printsf("%s_", ibuf
);
363 Z_printsf("%s", savname
[i
]);
366 Z_gotoxy(mnu
->x
+ (mnu
->t
[i
] >= SVOLM
? (mnu
->t
[i
] >= PL1CM
? 50 : 152) : 0), y
+ i
* 16 + 20);
367 Z_printbf(mnu
->m
[i
]);
369 if (mnu
->t
[i
] == MUSIC
) {
370 Z_printbf(" '%.8s'",g_music
);
371 } else if(mnu
->t
[i
] == INTERP
) {
372 Z_printbf("%s", fullscreen
? "ON" : "OFF");
373 } else if(mnu
->t
[i
] >= PL1CM
) {
374 V_manspr(mnu
->x
+ (mnu
->t
[i
] == PL1CM
? 15 : 35), y
+ i
* 16 + 20 + 14, PL_getspr(*panimp
, 0), pcolortab
[(mnu
->t
[i
] == PL1CM
) ? p1color
: p2color
]);
375 } else if(mnu
->t
[i
] >= SVOLM
) {
377 V_spr(mnu
->x
, j
, mbarl
);
378 for (k
= 8; k
< 144; k
+= 8) {
379 V_spr(mnu
->x
+ k
, j
, mbarm
);
381 V_spr(mnu
->x
+ 144, j
, mbarr
);
383 case SVOLM
: k
= snd_vol
; break;
384 case MVOLM
: k
= mus_vol
; break;
385 case GAMMAM
: k
= gammaa
<< 5; break;
387 V_spr(mnu
->x
+ 8 + k
, j
, mbaro
);
390 V_spr(mnu
->x
- 25, y
+ mnu
->cur
* 16 + 20 - 8, msklh
[(gm_tm
/ 6) & 1]);
392 Z_gotoxy((320 - strlen(mnu
->ttl
) * 7) / 2, 90); Z_printsf(mnu
->ttl
);
393 Z_gotoxy(136, 100); Z_printsf("(Y/N)");
400 static void DOT_draw (void) {
402 for (i
= 0; i
< MAXDOT
; ++i
) {
404 V_dot(dot
[i
].o
.x
- w_x
+ WD
/ 2, dot
[i
].o
.y
- w_y
+ HT
/ 2 + 1 + w_o
, dot
[i
].c
);
411 static void IT_draw (void) {
413 for (i
= 0; i
< MAXITEM
; ++i
) {
415 if (it
[i
].t
&& it
[i
].s
>= 0) {
416 switch(it
[i
].t
& 0x7FFF) {
418 s
= it
[i
].s
/ 9 + 18;
421 s
= it
[i
].s
/ 9 + 20;
424 s
= it
[i
].s
/ 2 + 22;
427 s
= it
[i
].s
/ 2 + 26;
433 s
= it
[i
].s
/ 2 + (it
[i
].t
- I_SUPER
) * 4 + 35;
435 case I_GOR1
: case I_FCAN
:
436 s
= it
[i
].s
/ 2 + (it
[i
].t
- I_GOR1
) * 3 + 51;
447 s
= (it
[i
].t
& 0x7FFF) - I_KEYR
+ 31;
453 s
= (it
[i
].t
& 0x7FFF) - 1;
457 Z_drawspr(it
[i
].o
.x
, it
[i
].o
.y
, item_spr
[s
], item_sprd
[s
]);
464 static int standspr (player_t
*p
) {
467 } else if (p
->f
& PLF_DOWN
) {
474 static int wpnspr (player_t
*p
) {
477 } else if(p
->f
& PLF_DOWN
) {
484 static void PL_draw (player_t
*p
) {
485 enum {STAND
, GO
, DIE
, SLOP
, DEAD
, MESS
, OUT
, FALL
}; // copypasted from player.c!
486 static int wytab
[] = {-1, -2, -1, 0};
493 if (p
->f
& PLF_FIRE
) {
496 } else if (p
->pain
) {
519 s
= plr_goanim
[p
->s
/ 8];
520 w
= (p
->f
& PLF_FIRE
) ? 'B' : 'A';
522 wy
= 1 + wytab
[s
- 'A'];
526 s
= plr_dieanim
[p
->s
];
529 s
= plr_slopanim
[p
->s
];
539 Z_drawspr(p
->o
.x
+ wx
, p
->o
.y
+ wy
, plr_wpn
[p
->wpn
][w
- 'A'], p
->d
);
542 Z_drawmanspr(p
->o
.x
, p
->o
.y
, plr_spr
[(s
- 'A') * 2 + p
->d
], plr_sprd
[(s
- 'A') * 2 + p
->d
], p
->color
);
546 static void PL_drawst (player_t
*p
) {
548 V_setrect(WD
, 120, w_o
, HT
);
550 if (p
->drawst
& PL_DRAWAIR
) {
551 if (p
->air
< PL_AIR
) {
555 if (p
->drawst
& PL_DRAWLIFE
) {
556 Z_drawstprcnt(0, p
->life
);
558 if (p
->drawst
& PL_DRAWARMOR
) {
559 Z_drawstprcnt(1, p
->armor
);
561 if (p
->drawst
& PL_DRAWWPN
) {
583 Z_drawstwpn(p
->wpn
, i
);
585 if (p
->drawst
& PL_DRAWFRAG
) {
586 Z_drawstnum(p
->frag
);
588 if (p
->drawst
& PL_DRAWKEYS
) {
589 Z_drawstkeys(p
->keys
);
592 if (p
->drawst
& PL_DRAWLIVES
) {
593 Z_drawstlives(p
->lives
);
598 /* --- monster --- */
600 #define MANCOLOR 0xD0
602 static void MN_draw (void) {
603 enum {SLEEP
, GO
, RUN
, CLIMB
, DIE
, DEAD
, ATTACK
, SHOOT
, PAIN
, WAIT
, REVIVE
, RUNOUT
}; // copypasted from monster.c!
605 for (i
= 0; i
< MAXMN
; ++i
) {
607 if (mn
[i
].t
>= MN_PL_DEAD
) {
608 Z_drawmanspr(mn
[i
].o
.x
, mn
[i
].o
.y
, pl_spr
[mn
[i
].t
- MN_PL_DEAD
], 0, mn
[i
].d
);
611 if ((mn
[i
].t
!= MN_SOUL
&& mn
[i
].t
!= MN_PAIN
) || mn
[i
].st
!= DEAD
) {
612 if (mn
[i
].t
!= MN_MAN
) {
613 Z_drawspr(mn
[i
].o
.x
, mn
[i
].o
.y
, mn_spr
[mn
[i
].t
- 1][(mn
[i
].ap
[mn
[i
].ac
] - 'A') * 2 + mn
[i
].d
], mn_sprd
[mn
[i
].t
- 1][(mn
[i
].ap
[mn
[i
].ac
] - 'A') * 2 + mn
[i
].d
]);
615 if (mn
[i
].ap
[mn
[i
].ac
] == 'E' || mn
[i
].ap
[mn
[i
].ac
] == 'F') {
616 Z_drawspr(mn
[i
].o
.x
, mn
[i
].o
.y
, mn_sgun
[mn
[i
].ap
[mn
[i
].ac
] - 'E'], mn
[i
].d
);
618 Z_drawmanspr(mn
[i
].o
.x
, mn
[i
].o
.y
, mn_spr
[mn
[i
].t
- 1][(mn
[i
].ap
[mn
[i
].ac
] - 'A') * 2 + mn
[i
].d
], mn_sprd
[mn
[i
].t
- 1][(mn
[i
].ap
[mn
[i
].ac
] - 'A') * 2 + mn
[i
].d
], MANCOLOR
);
621 if (mn
[i
].t
== MN_VILE
&& mn
[i
].st
== SHOOT
) {
622 Z_drawspr(mn
[i
].tx
, mn
[i
].ty
, mn_fspr
[mn
[i
].ac
/ 3], 0);
630 static void WP_draw (void) {
631 enum {NONE
, ROCKET
, PLASMA
, APLASMA
, BALL1
, BALL2
, BALL7
, BFGBALL
, BFGHIT
, MANF
, REVF
, FIRE
}; // copypasted from weapons.c!
633 for (i
= 0; i
< MAXWPN
; ++i
) {
644 d
= wp
[i
].o
.xv
> 0 ? 1 : 0;
692 d
= wp
[i
].o
.xv
>= 0 ? 1 : 0;
696 d
=(wp
[i
].o
.xv
>=0)?1:0;break;
707 s
= wp
[i
].s
/ 2 + 26;
711 Z_drawspr(wp
[i
].o
.x
, wp
[i
].o
.y
, wp_spr
[s
* 2 + d
], wp_sprd
[s
* 2 + d
]);
718 static void SMK_draw (void) {
720 for (i
= 0; i
< MAXSMOK
; ++i
) {
725 if (s
>= (SMSN
- 1) * 3) {
728 s
= SMSN
- 1 - s
/ 3;
730 V_sprf((sm
[i
].x
>> 8) - w_x
+ WD
/ 2, (sm
[i
].y
>> 8) - w_y
+ HT
/ 2 + 1 + w_o
, smk_spr
[s
], &smoke_sprf
);
739 V_sprf((sm
[i
].x
>> 8) - w_x
+ WD
/ 2, (sm
[i
].y
>> 8) - w_y
+ HT
/ 2 + 1 + w_o
, smk_fspr
[s
], &flame_sprf
);
748 static void FX_draw (void) {
749 enum {NONE
, TFOG
, IFOG
, BUBL
}; // copypasted from fx.c
751 for (i
= 0; i
< MAXFX
; ++i
) {
758 s
= fx
[i
].s
/ 2 + 10;
761 V_dot((fx
[i
].x
>> 8) - w_x
+ WD
/ 2, (fx
[i
].y
>> 8) - w_y
+ HT
/ 2 + 1 + w_o
, 0xC0 + fx
[i
].s
);
765 Z_drawspr(fx
[i
].x
, fx
[i
].y
, fx_spr
[s
], fx_sprd
[s
]);
772 static void W_adjust (void) {
773 int MAXX
= FLDW
* CELW
- WD
/ 2;
774 int MAXY
= FLDH
* CELH
- HT
/ 2;
775 if (w_x
< WD
/ 2) w_x
= WD
/ 2;
776 if (w_y
< HT
/ 2) w_y
= HT
/ 2;
777 if (w_x
> MAXX
) w_x
= MAXX
;
778 if (w_y
> MAXY
) w_y
= MAXY
;
781 static void W_draw(void) {
783 V_setrect(0, WD
, w_o
+ 1, HT
);
785 vgaimg
*img
= (vgaimg
*)horiz
;
792 V_rotspr(x
, y
, img
, d
);
795 } while (y
< HT
+ w_o
);
802 V_spr(0, w_o
+ lt_ypos
, ltn
[lt_type
][lt_time
< -5 ? 0 : 1]);
804 V_spr2(WD
- 1, w_o
+ lt_ypos
, ltn
[lt_type
][lt_time
< -5 ? 0 : 1]);
809 V_clr(0, WD
, w_o
+ 1, HT
, 0x97);
811 Z_drawfld((byte
*)fldb
, 1);
822 Z_drawfld((byte
*)fldf
, 0);
824 if (lt_time
== -4 || lt_time
== -2) {
825 V_remap_rect(0, WD
, w_o
+ 1, HT
, clrmap
+ 256 * 11);
834 static void drawview (player_t
*p
) {
835 if (p
->looky
< -SCRH
/ 4) {
836 p
->looky
= -SCRH
/ 4;
837 } else if (p
->looky
> SCRH
/ 4) {
841 w_y
= p
->o
.y
- 12 + p
->looky
;
846 static int get_pu_st (int t
) {
849 } else if((t
/ 9) & 1) {
856 static void pl_info (player_t
*p
, int y
) {
857 dword t
= p
->kills
* 10920 / g_time
;
858 Z_gotoxy(25, y
); Z_printbf("KILLS");
859 Z_gotoxy(25, y
+ 15); Z_printbf("KPM");
860 Z_gotoxy(25, y
+ 30); Z_printbf("SECRETS %u / %u", p
->secrets
, sw_secrets
);
861 Z_gotoxy(255, y
); Z_printbf("%u", p
->kills
);
862 Z_gotoxy(255, y
+ 15); Z_printbf("%u.%u", t
/ 10, t
% 10);
865 static void W_act (void) {
867 if (g_time
% 3 == 0) {
868 for (i
= 1; i
< 256; ++i
) {
872 if (anih
[a
][anic
[a
]] == -1) {
875 walp
[i
] = V_getvgaimg(anih
[a
][anic
[a
]]);
885 if (g_trans
&& !transdraw
) {
898 V_pic(0, 0, scrnh
[0]);
903 V_clr(0, SCRW
, 0, SCRH
, 0);
904 V_pic(0, 0, scrnh
[2]);
909 V_clr(0, SCRW
, 0, SCRH
, 0);
910 V_pic(0, 0, scrnh
[1]);
912 Z_printbf("LEVEL COMPLETE");
913 Z_calc_time(g_time
, &hr
, &mn
, &sc
);
915 Z_printbf("TIME %u:%02u:%02u", hr
, mn
, sc
);
919 Z_printbf("PLAYER ONE");
920 Z_gotoxy(80, h
+ 70);
921 Z_printbf("PLAYER TWO");
926 pl_info(&pl2
, h
+ 70);
932 if (g_st
!= GS_GAME
) {
937 V_copytoscr(0, SCRW
, 0, SCRH
);
963 V_copytoscr(0,SCRW
,0,SCRH
);
968 h
= get_pu_st(pl1
.invl
) * 6;
969 } else if (pl1
.pain
< 15) {
971 } else if (pl1
.pain
< 35) {
973 } else if (pl1
.pain
< 55) {
975 } else if (pl1
.pain
< 75) {
977 } else if (pl1
.pain
< 95) {
983 V_maptoscr(0, SCRW
- 120, 1, _2pl
? SCRH
/ 2 - 2 : SCRH
- 2, clrmap
+ h
* 256);
985 V_copytoscr(0, SCRW
- 120, 1, _2pl
? SCRH
/ 2 - 2 : SCRH
- 2);
988 V_copytoscr(SCRW
- 120, 120, 0, _2pl
? SCRH
/ 2 : SCRH
);
993 h
= get_pu_st(pl2
.invl
) * 6;
994 } else if (pl2
.pain
< 15) {
996 } else if (pl2
.pain
< 35) {
998 } else if (pl2
.pain
< 55) {
1000 } else if (pl2
.pain
< 75) {
1002 } else if (pl2
.pain
< 95) {
1008 V_maptoscr(0, SCRW
- 120, SCRH
/ 2 + 1, SCRH
/ 2 - 2, clrmap
+ h
* 256);
1010 V_copytoscr(0, SCRW
- 120, SCRH
/ 2 + 1, SCRH
/ 2 - 2);
1013 V_copytoscr(SCRW
- 120, 120, SCRH
/ 2, SCRH
/ 2);
1019 void R_alloc (void) {
1022 logo("R_alloc: загрузка графики\n");
1024 scrnh
[0] = V_loadvgaimg("TITLEPIC");
1025 scrnh
[1] = V_loadvgaimg("INTERPIC");
1026 scrnh
[2] = V_loadvgaimg("ENDPIC");
1027 cd_scr
= M_lock(F_getresid("CD1PIC"));
1028 for (i
= 0; i
< 2; ++i
) {
1029 sprintf(s
, "LTN%c", i
+ '1');
1030 for (j
= 0; j
< 2; ++j
) {
1031 ltn
[i
][j
] = Z_getspr(s
, j
, 0, NULL
);
1035 for (i
= 0; i
< SMSN
; ++i
) {
1036 smk_spr
[i
] = Z_getspr("SMOK", i
, 0, NULL
);
1038 for (i
= 0; i
< FLSN
; ++i
) {
1039 smk_fspr
[i
] = Z_getspr("FLAM", i
, 0, NULL
);
1042 for (i
= 0; i
< 10; ++i
) {
1043 fx_spr
[i
] = Z_getspr("TFOG", i
, 0, fx_sprd
+ i
);
1045 for (; i
< 15; ++i
) {
1046 fx_spr
[i
] = Z_getspr("IFOG", i
- 10, 0, fx_sprd
+ i
);
1049 for (i
= 0; i
< 4; ++i
) {
1050 wp_spr
[i
* 2] = Z_getspr("MISL", i
, 1, wp_sprd
+ i
* 2);
1051 wp_spr
[i
* 2 + 1] = Z_getspr("MISL", i
, 2, wp_sprd
+ i
* 2 + 1);
1053 for (; i
< 6; ++i
) {
1054 wp_spr
[i
* 2] = Z_getspr("PLSS", i
- 4, 1, wp_sprd
+ i
* 2);
1055 wp_spr
[i
* 2 + 1] = Z_getspr("PLSS", i
- 4, 2, wp_sprd
+ i
* 2 + 1);
1057 for (; i
< 11; ++i
) {
1058 wp_spr
[i
* 2] = Z_getspr("PLSE", i
- 6, 1, wp_sprd
+ i
* 2);
1059 wp_spr
[i
* 2 + 1] = Z_getspr("PLSE", i
- 6, 2, wp_sprd
+ i
* 2 + 1);
1061 for (; i
< 13; ++i
) {
1062 wp_spr
[i
* 2] = Z_getspr("APLS", i
- 11, 1, wp_sprd
+ i
* 2);
1063 wp_spr
[i
* 2 + 1] = Z_getspr("APLS", i
- 11, 2, wp_sprd
+ i
* 2 + 1);
1065 for (; i
< 18; ++i
) {
1066 wp_spr
[i
* 2] = Z_getspr("APBX", i
- 13, 1, wp_sprd
+ i
* 2);
1067 wp_spr
[i
* 2 + 1] = Z_getspr("APBX", i
- 13, 2, wp_sprd
+ i
* 2 + 1);
1069 for(; i
< 20; ++i
) {
1070 wp_spr
[i
* 2] = Z_getspr("BFS1", i
- 18, 1, wp_sprd
+ i
* 2);
1071 wp_spr
[i
* 2 + 1] = Z_getspr("BFS1", i
- 18, 2, wp_sprd
+ i
* 2 + 1);
1073 for (; i
< 26; ++i
) {
1074 wp_spr
[i
* 2] = Z_getspr("BFE1", i
- 20, 1, wp_sprd
+ i
* 2);
1075 wp_spr
[i
* 2 + 1] = Z_getspr("BFE1", i
- 20, 2, wp_sprd
+ i
* 2 + 1);
1077 for (; i
< 30; ++i
) {
1078 wp_spr
[i
* 2] = Z_getspr("BFE2", i
- 26, 1, wp_sprd
+ i
* 2);
1079 wp_spr
[i
* 2 + 1] = Z_getspr("BFE2", i
- 26, 2, wp_sprd
+ i
* 2 + 1);
1081 for (; i
< 32; ++i
) {
1082 wp_spr
[i
* 2] = Z_getspr("MISL", i
- 30 + 4, 1, wp_sprd
+ i
* 2);
1083 wp_spr
[i
* 2 + 1] = Z_getspr("MISL", i
- 30 + 4, 2, wp_sprd
+ i
* 2 + 1);
1085 for (; i
< 37; ++i
) {
1086 wp_spr
[i
* 2] = Z_getspr("BAL1", i
- 32, 1, wp_sprd
+ i
* 2);
1087 wp_spr
[i
* 2 + 1] = Z_getspr("BAL1", i
- 32, 2, wp_sprd
+ i
* 2 + 1);
1089 for (; i
< 42; ++i
) {
1090 wp_spr
[i
* 2] = Z_getspr("BAL7", i
- 37, 1, wp_sprd
+ i
* 2);
1091 wp_spr
[i
* 2 + 1] = Z_getspr("BAL7", i
- 37, 2, wp_sprd
+ i
* 2 + 1);
1093 for (; i
< 47; ++i
) {
1094 wp_spr
[i
* 2] = Z_getspr("BAL2", i
- 42, 1, wp_sprd
+ i
* 2);
1095 wp_spr
[i
* 2 + 1] = Z_getspr("BAL2", i
- 42, 2, wp_sprd
+ i
* 2 + 1);
1097 for (; i
< 49; ++i
) {
1098 wp_spr
[i
* 2] = Z_getspr("MANF", i
- 47, 1, wp_sprd
+ i
* 2);
1099 wp_spr
[i
* 2 + 1] = Z_getspr("MANF", i
- 47, 2, wp_sprd
+ i
* 2 + 1);
1102 static char snm
[18][4] = {
1103 "CLIP", "SHEL", "ROCK", "CELL", "AMMO", "SBOX", "BROK", "CELP",
1104 "STIM", "MEDI", "BPAK",
1105 "CSAW", "SHOT", "SGN2", "MGUN", "LAUN", "PLAS", "BFUG"
1107 static char n4
[4][4] = {
1108 "SOUL", "SMRT", "SMGT", "SMBT"
1110 static char n3
[2][4] = {
1113 for (i
= 0; i
< 18; ++i
) {
1114 item_spr
[i
] = Z_getspr(snm
[i
], 0, 0, item_sprd
+ i
);
1116 for (; i
< 20; ++i
) {
1117 item_spr
[i
] = Z_getspr("ARM1", i
- 18, 0, item_sprd
+ i
);
1118 item_spr
[i
+ 2] = Z_getspr("ARM2", i
- 18, 0, item_sprd
+ i
);
1121 for (; i
< 26; ++i
) {
1122 item_spr
[i
] = Z_getspr("MEGA", i
- 22, 0, item_sprd
+ i
);
1124 for (; i
< 30; ++i
) {
1125 item_spr
[i
] = Z_getspr("PINV", i
- 26, 0, item_sprd
+ i
);
1127 item_spr
[30] = Z_getspr("AQUA", 0, 0, item_sprd
+ 30);
1128 item_spr
[31] = Z_getspr("KEYR", 0, 0, item_sprd
+ 31);
1129 item_spr
[32] = Z_getspr("KEYG", 0, 0, item_sprd
+ 32);
1130 item_spr
[33] = Z_getspr("KEYB", 0, 0, item_sprd
+ 33);
1131 item_spr
[34] = Z_getspr("SUIT", 0, 0, item_sprd
+ 34);
1132 for (n
= 35, j
= 0; j
< 4; ++j
) {
1133 for (i
= 0; i
< 4; ++i
, ++n
) {
1134 item_spr
[n
] = Z_getspr(n4
[j
], i
, 0, item_sprd
+ n
);
1137 for (j
= 0; j
< 2; ++j
) {
1138 for (i
= 0; i
< 3; ++i
, ++n
) {
1139 item_spr
[n
] = Z_getspr(n3
[j
], i
, 0, item_sprd
+ n
);
1142 item_spr
[57] = Z_getspr("GUN2", 0, 0, item_sprd
+ 57);
1144 for (i
= 0; i
< 27; ++i
) {
1145 plr_spr
[i
* 2] = Z_getspr("PLAY", i
, 1, plr_sprd
+ i
* 2);
1146 plr_spr
[i
* 2 + 1] = Z_getspr("PLAY", i
, 2, plr_sprd
+ i
* 2 + 1);
1148 strncpy(s
, "PWPx", 4);
1149 for (i
= 1; i
< 11; ++i
) {
1150 s
[3] = (i
< 10 ? '0' : 'A' - 10) + i
;
1151 for (j
= 0; j
< 6; ++j
) {
1152 plr_wpn
[i
][j
] = Z_getspr(s
, j
, 1, NULL
);
1156 static char msn
[MN_TN
][4] = {
1157 "SARG", "TROO", "POSS", "SPOS", "CYBR", "CPOS", "BOSS", "BOS2", "HEAD", "SKUL",
1158 "PAIN", "SPID", "BSPI", "FATT", "SKEL", "VILE", "FISH", "BAR1", "ROBO", "PLAY"
1160 static int mms
[MN_TN
] = {
1161 14*2, 21*2, 21*2, 21*2, 16*2, 20*2, 15*2, 15*2, 12*2, 11*2, 13*2, 19*2, 16*2,
1162 20*2, 17*2, 29*2, 6*2, 2*2, 17*2, 23*2
1164 mn_sgun
[0] = Z_getspr("PWP4", 0, 1, NULL
);
1165 mn_sgun
[1] = Z_getspr("PWP4", 1, 1, NULL
);
1166 for (j
= 0; j
< MN_TN
; ++j
) {
1167 for (i
= 0; i
< mms
[j
]; ++i
) {
1168 mn_spr
[j
][i
] = Z_getspr(msn
[j
], i
/ 2, (i
& 1) + 1, &mn_sprd
[j
][i
]);
1170 if (j
== MN_BARREL
- 1) {
1171 for (i
= 4; i
< 14; ++i
) {
1172 mn_spr
[j
][i
] = Z_getspr("BEXP", i
/ 2 - 2, (i
& 1) + 1, &mn_sprd
[j
][i
]);
1176 for (i
= 0; i
< 8; ++i
) {
1177 mn_fspr
[i
] = Z_getspr("FIRE", i
, 0, NULL
);
1179 pl_spr
[0] = Z_getspr("PLAY", 'N' - 'A', 0, NULL
);
1180 pl_spr
[1] = Z_getspr("PLAY", 'W' - 'A', 0, NULL
);
1182 static char mnm
[22][8]={
1183 "STTNUM0","STTNUM1","STTNUM2","STTNUM3","STTNUM4",
1184 "STTNUM5","STTNUM6","STTNUM7","STTNUM8","STTNUM9",
1185 "STTMINUS","STTPRCNT",
1186 "FISTA0","CSAWA0","PISTA0","SHOTA0","SGN2A0","MGUNA0","LAUNA0",
1187 "PLASA0","BFUGA0","GUN2A0"
1189 stone
=V_loadvgaimg("STONE");
1190 stone2
=V_loadvgaimg("STONE2");
1191 keys
[0]=V_loadvgaimg("KEYRA0");
1192 keys
[1]=V_loadvgaimg("KEYGA0");
1193 keys
[2]=V_loadvgaimg("KEYBA0");
1194 for (i
= 0; i
< 22; ++i
) {
1195 sth
[i
] = V_loadvgaimg(mnm
[i
]);
1197 strcpy(s
, "STBF_*");
1198 for (i
= '!'; i
< 160; ++i
) {
1200 bfh
[i
- '!'] = V_getvgaimg(F_findres(s
));
1202 for (i
= '!'; i
< 160; ++i
) {
1203 sprintf(s
, "STCFN%03d", i
);
1204 sfh
[i
- '!'] = V_getvgaimg(F_findres(s
));
1206 strcpy(s
, "WINUM*");
1207 for (i
= '0'; i
<= '9'; ++i
) {
1209 bfh
[i
- '!'] = V_loadvgaimg(s
);
1211 bfh
[':' - '!'] = V_loadvgaimg("WICOLON");
1213 msklh
[0] = V_loadvgaimg("M_SKULL1");
1214 msklh
[1] = V_loadvgaimg("M_SKULL2");
1215 mbarl
= V_loadvgaimg("M_THERML");
1216 mbarm
= V_loadvgaimg("M_THERMM");
1217 mbarr
= V_loadvgaimg("M_THERMR");
1218 mbaro
= V_loadvgaimg("M_THERMO");
1219 mslotl
= V_loadvgaimg("M_LSLEFT");
1220 mslotm
= V_loadvgaimg("M_LSCNTR");
1221 mslotr
= V_loadvgaimg("M_LSRGHT");
1223 static char *anm
[ANIT
- 1][5] = {
1224 {"WALL22_1", "WALL23_1", "WALL23_2", NULL
, NULL
},
1225 {"WALL58_1", "WALL58_2", "WALL58_3", NULL
, NULL
},
1226 {"W73A_1", "W73A_2", NULL
, NULL
, NULL
},
1227 {"RP2_1", "RP2_2", "RP2_3", "RP2_4", NULL
}
1229 for (i
= 1; i
< ANIT
; i
++) {
1230 for (j
= 0; anm
[i
- 1][j
]; j
++) {
1231 anih
[i
][j
] = F_getresid(anm
[i
- 1][j
]);
1239 void R_get_name (int n
, char s
[8]) {
1240 if (walh
[n
] == -1) {
1242 } else if (walh
[n
] == -2) {
1243 memcpy(s
, "_WATER_", 8);
1244 s
[7] = (char)((intptr_t)walp
[n
] - 1 + '0');
1246 F_getresname(s
, walh
[n
] & 0x7FFF);
1250 static short getani (char n
[8]) {
1251 if (strncasecmp(n
, "WALL22_1", 8) == 0) {
1253 } else if (strncasecmp(n
, "WALL58_1", 8) == 0) {
1255 } else if (strncasecmp(n
, "W73A_1", 8) == 0) {
1257 } else if (strncasecmp(n
, "RP2_1", 8) == 0) {
1264 int R_get_special_id (int n
) {
1265 assert(n
>= 0 && n
< 256);
1266 intptr_t x
= (intptr_t)walp
[n
] - 1;
1267 return x
> 0 && x
<= 3 ? x
: 0;
1270 void R_begin_load (void) {
1272 for (i
= 0; i
< max_textures
; i
++) {
1273 // if (walp[i] != NULL && walh[i] >= 0) {
1274 // M_unlock(walp[i]);
1281 memset(anic
, 0, sizeof(anic
));
1285 void R_load (char s
[8], int f
) {
1286 assert(max_textures
< 256);
1288 walh
[max_textures
] = -1;
1289 walp
[max_textures
] = NULL
;
1291 if (strncasecmp(s
, "_WATER_", 7) == 0) {
1292 walh
[max_textures
] = -2;
1293 walp
[max_textures
] = (void*)((intptr_t)s
[7] - '0' + 1);
1295 walh
[max_textures
] = F_getresid(s
);
1296 walp
[max_textures
] = V_getvgaimg(walh
[max_textures
]);
1298 walh
[max_textures
] |= 0x8000;
1300 if (s
[0] == 'S' && s
[1] == 'W' && s
[4] == '_') {
1301 walswp
[max_textures
] = 0;
1304 walani
[max_textures
] = getani(s
);
1309 void R_end_load (void) {
1313 for (i
= 1; i
< 256 && j
< 256; i
++) {
1314 if (walswp
[i
] == 0) {
1317 g
= F_getresid(s
) | (walh
[i
] & 0x8000);
1319 while (k
< 256 && walh
[k
] != g
) {
1326 walp
[k
] = V_getvgaimg(g
);
1327 walf
[k
] = g
& 0x8000 ? 1 : 0;
1335 void R_loadsky (int sky
) {
1340 horiz
= V_loadvgaimg(s
);
1343 void R_setgamma(int g
) {
1345 g
= g
< 0 ? 0 : (g
> 4 ? 4 : g
);
1347 for (t
= 0; t
< 256; ++t
) {
1348 std_pal
[t
][0]=gamcor
[gammaa
][main_pal
[t
][0]];
1349 std_pal
[t
][1]=gamcor
[gammaa
][main_pal
[t
][1]];
1350 std_pal
[t
][2]=gamcor
[gammaa
][main_pal
[t
][2]];
1355 int R_getgamma (void) {
1359 void R_toggle_fullscreen (void) {
1360 fullscreen
= !fullscreen
;
1366 F_loadres(F_getresid("PLAYPAL"), main_pal
, 0, 768);
1367 for (i
= 0; i
< 256; ++i
) {
1368 bright
[i
] = ((int) main_pal
[i
][0] + main_pal
[i
][1] + main_pal
[i
][2]) * 8 / (63 * 3);
1370 F_loadres(F_getresid("MIXMAP"), mixmap
, 0, 0x10000);
1371 F_loadres(F_getresid("COLORMAP"), clrmap
, 0, 256*12);
1372 logo("V_init: настройка видео\n");
1373 if (V_init() != 0) {
1374 ERR_failinit("Не могу установить видеорежим VGA");
1376 //R_setgamma(gammaa);
1377 V_setrect(0, SCRW
, 0, SCRH
);
1379 V_clr(0, SCRW
, 0, SCRH
, 0);
1383 void R_done (void) {