Put briefing globals in 'briefing' struct, pass this by parameter

This commit is contained in:
kreatordxx 2010-03-09 02:41:34 +00:00
parent bf23430dd7
commit 40cfd30bd7
2 changed files with 198 additions and 161 deletions

View file

@ -1,5 +1,9 @@
D1X-Rebirth Changelog D1X-Rebirth Changelog
20100309
--------
main/titles.c: Put briefing globals in 'briefing' struct, pass this by parameter
20100304 20100304
-------- --------
main/piggy.c, main/text.c, main/text.h: Fixed some Piggy- and Text-loading routines for Shareware, Destination Saturn and 1.0 Registered; Full support for End-Briefing on non-registered still missing however main/piggy.c, main/text.c, main/text.h: Fixed some Piggy- and Text-loading routines for Shareware, Destination Saturn and 1.0 Registered; Full support for End-Briefing on non-registered still missing however

View file

@ -62,13 +62,11 @@ void set_briefing_fontcolor ();
#define MAX_BRIEFING_COLORS 7 #define MAX_BRIEFING_COLORS 7
#define SHAREWARE_ENDING_FILENAME "ending.tex" #define SHAREWARE_ENDING_FILENAME "ending.tex"
#define DEFAULT_BRIEFING_BKG "brief03.pcx"
char CurBriefScreenName[15]="brief03.pcx";
char * Briefing_text;
int Briefing_text_colors[MAX_BRIEFING_COLORS]; int Briefing_text_colors[MAX_BRIEFING_COLORS];
int Current_color = 0; int Current_color = 0;
int Erase_color; int Erase_color;
grs_bitmap briefing_bm;
// added by Jan Bobrowski for variable-size menu screen // added by Jan Bobrowski for variable-size menu screen
static int rescale_x(int x) static int rescale_x(int x)
@ -322,34 +320,57 @@ char * get_briefing_screen( int level_num )
return NULL; return NULL;
} }
int Briefing_text_x, Briefing_text_y; typedef struct msgstream {
int x;
int y;
int color;
int ch;
} __pack__ msgstream;
void init_char_pos(int x, int y) typedef struct briefing
{ {
Briefing_text_x = x; grs_bitmap background;
Briefing_text_y = y; char background_name[16];
char *text;
int text_x, text_y;
msgstream messagestream[2048];
grs_canvas *robot_canv;
vms_angvec robot_angles;
char bitmap_name[32];
sbyte door_dir, door_div_count, animating_bitmap_type;
} briefing;
void briefing_init(briefing *br)
{
strcpy(br->background_name, DEFAULT_BRIEFING_BKG);
br->robot_canv = NULL;
br->bitmap_name[0] = '\0';
br->door_dir = 1;
br->door_div_count = 0;
br->animating_bitmap_type = 0;
} }
grs_canvas *Robot_canv = NULL; void init_char_pos(briefing *br, int x, int y)
vms_angvec Robot_angles; {
br->text_x = x;
br->text_y = y;
}
char Bitmap_name[32] = "";
#define EXIT_DOOR_MAX 14 #define EXIT_DOOR_MAX 14
#define OTHER_THING_MAX 10 // Adam: This is the number of frames in your new animating thing. #define OTHER_THING_MAX 10 // Adam: This is the number of frames in your new animating thing.
#define DOOR_DIV_INIT 6 #define DOOR_DIV_INIT 6
sbyte Door_dir=1, Door_div_count=0, Animating_bitmap_type=0;
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
void show_animated_bitmap(void) void show_animated_bitmap(briefing *br)
{ {
grs_canvas *curcanv_save, *bitmap_canv=0; grs_canvas *curcanv_save, *bitmap_canv=0;
grs_bitmap *bitmap_ptr; grs_bitmap *bitmap_ptr;
// Only plot every nth frame. // Only plot every nth frame.
if (Door_div_count) { if (br->door_div_count) {
if (Bitmap_name[0] != 0) { if (br->bitmap_name[0] != 0) {
bitmap_index bi; bitmap_index bi;
bi = piggy_find_bitmap(Bitmap_name); bi = piggy_find_bitmap(br->bitmap_name);
bitmap_ptr = &GameBitmaps[bi.index]; bitmap_ptr = &GameBitmaps[bi.index];
PIGGY_PAGE_IN( bi ); PIGGY_PAGE_IN( bi );
#ifdef OGL #ifdef OGL
@ -358,27 +379,27 @@ void show_animated_bitmap(void)
gr_bitmapm(rescale_x(220), rescale_y(45), bitmap_ptr); gr_bitmapm(rescale_x(220), rescale_y(45), bitmap_ptr);
#endif #endif
} }
Door_div_count--; br->door_div_count--;
return; return;
} }
Door_div_count = DOOR_DIV_INIT; br->door_div_count = DOOR_DIV_INIT;
if (Bitmap_name[0] != 0) { if (br->bitmap_name[0] != 0) {
char *pound_signp; char *pound_signp;
int num, dig1, dig2; int num, dig1, dig2;
bitmap_index bi; bitmap_index bi;
switch (Animating_bitmap_type) { switch (br->animating_bitmap_type) {
case 0: bitmap_canv = gr_create_sub_canvas(grd_curcanv, rescale_x(220), rescale_y(45), 64, 64); break; case 0: bitmap_canv = gr_create_sub_canvas(grd_curcanv, rescale_x(220), rescale_y(45), 64, 64); break;
case 1: bitmap_canv = gr_create_sub_canvas(grd_curcanv, rescale_x(220), rescale_y(45), 94, 94); break; // Adam: Change here for your new animating bitmap thing. 94, 94 are bitmap size. case 1: bitmap_canv = gr_create_sub_canvas(grd_curcanv, rescale_x(220), rescale_y(45), 94, 94); break; // Adam: Change here for your new animating bitmap thing. 94, 94 are bitmap size.
default: Int3(); // Impossible, illegal value for Animating_bitmap_type default: Int3(); // Impossible, illegal value for br->animating_bitmap_type
} }
curcanv_save = grd_curcanv; curcanv_save = grd_curcanv;
grd_curcanv = bitmap_canv; grd_curcanv = bitmap_canv;
pound_signp = strchr(Bitmap_name, '#'); pound_signp = strchr(br->bitmap_name, '#');
Assert(pound_signp != NULL); Assert(pound_signp != NULL);
dig1 = *(pound_signp+1); dig1 = *(pound_signp+1);
@ -388,15 +409,15 @@ void show_animated_bitmap(void)
else else
num = (dig1-'0')*10 + (dig2-'0'); num = (dig1-'0')*10 + (dig2-'0');
switch (Animating_bitmap_type) { switch (br->animating_bitmap_type) {
case 0: case 0:
num += Door_dir; num += br->door_dir;
if (num > EXIT_DOOR_MAX) { if (num > EXIT_DOOR_MAX) {
num = EXIT_DOOR_MAX; num = EXIT_DOOR_MAX;
Door_dir = -1; br->door_dir = -1;
} else if (num < 0) { } else if (num < 0) {
num = 0; num = 0;
Door_dir = 1; br->door_dir = 1;
} }
break; break;
case 1: case 1:
@ -416,7 +437,7 @@ void show_animated_bitmap(void)
*(pound_signp+2) = 0; *(pound_signp+2) = 0;
} }
bi = piggy_find_bitmap(Bitmap_name); bi = piggy_find_bitmap(br->bitmap_name);
bitmap_ptr = &GameBitmaps[bi.index]; bitmap_ptr = &GameBitmaps[bi.index];
PIGGY_PAGE_IN( bi ); PIGGY_PAGE_IN( bi );
#ifdef OGL #ifdef OGL
@ -427,14 +448,14 @@ void show_animated_bitmap(void)
grd_curcanv = curcanv_save; grd_curcanv = curcanv_save;
d_free(bitmap_canv); d_free(bitmap_canv);
switch (Animating_bitmap_type) { switch (br->animating_bitmap_type) {
case 0: case 0:
if (num == EXIT_DOOR_MAX) { if (num == EXIT_DOOR_MAX) {
Door_dir = -1; br->door_dir = -1;
Door_div_count = 64; br->door_div_count = 64;
} else if (num == 0) { } else if (num == 0) {
Door_dir = 1; br->door_dir = 1;
Door_div_count = 64; br->door_div_count = 64;
} }
break; break;
case 1: case 1:
@ -463,37 +484,37 @@ void show_briefing_bitmap(grs_bitmap *bmp)
} }
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
void show_spinning_robot_frame(int robot_num) void show_spinning_robot_frame(briefing *br, int robot_num)
{ {
grs_canvas *curcanv_save; grs_canvas *curcanv_save;
if (robot_num != -1) { if (robot_num != -1) {
Robot_angles.h += 150; br->robot_angles.h += 150;
curcanv_save = grd_curcanv; curcanv_save = grd_curcanv;
grd_curcanv = Robot_canv; grd_curcanv = br->robot_canv;
Assert(Robot_info[robot_num].model_num != -1); Assert(Robot_info[robot_num].model_num != -1);
draw_model_picture(Robot_info[robot_num].model_num, &Robot_angles); draw_model_picture(Robot_info[robot_num].model_num, &br->robot_angles);
grd_curcanv = curcanv_save; grd_curcanv = curcanv_save;
} }
} }
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
void init_spinning_robot(void) //(int x,int y,int w,int h) void init_spinning_robot(briefing *br) //(int x,int y,int w,int h)
{ {
int x = rescale_x(138); int x = rescale_x(138);
int y = rescale_y(55); int y = rescale_y(55);
int w = rescale_x(166); int w = rescale_x(166);
int h = rescale_y(138); int h = rescale_y(138);
Robot_canv = gr_create_sub_canvas(grd_curcanv, x, y, w, h); br->robot_canv = gr_create_sub_canvas(grd_curcanv, x, y, w, h);
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
// Returns char width. // Returns char width.
// If show_robot_flag set, then show a frame of the spinning robot. // If show_robot_flag set, then show a frame of the spinning robot.
int show_char_delay(char the_char, int delay, int robot_num, int cursor_flag) int show_char_delay(briefing *br, char the_char, int delay, int robot_num, int cursor_flag)
{ {
int w, h, aw; int w, h, aw;
char message[2]; char message[2];
@ -516,17 +537,17 @@ int show_char_delay(char the_char, int delay, int robot_num, int cursor_flag)
if (cursor_flag) if (cursor_flag)
{ {
gr_set_fontcolor(Briefing_text_colors[Current_color], -1); gr_set_fontcolor(Briefing_text_colors[Current_color], -1);
gr_printf(Briefing_text_x, Briefing_text_y, "_" ); gr_printf(br->text_x, br->text_y, "_" );
} }
for (i=0; i<2; i++) for (i=0; i<2; i++)
{ {
if (Bitmap_name[0] != 0) if (br->bitmap_name[0] != 0)
show_animated_bitmap(); show_animated_bitmap(br);
while (timer_get_fixed_seconds() < start_time + delay/2); while (timer_get_fixed_seconds() < start_time + delay/2);
if (robot_num != -1) if (robot_num != -1)
show_spinning_robot_frame(robot_num); show_spinning_robot_frame(br, robot_num);
start_time = timer_get_fixed_seconds(); start_time = timer_get_fixed_seconds();
} }
@ -535,13 +556,13 @@ int show_char_delay(char the_char, int delay, int robot_num, int cursor_flag)
if (cursor_flag) if (cursor_flag)
{ {
gr_set_fontcolor(Erase_color, -1); gr_set_fontcolor(Erase_color, -1);
gr_printf(Briefing_text_x, Briefing_text_y, "_" ); gr_printf(br->text_x, br->text_y, "_" );
} }
} }
// Draw the character // Draw the character
gr_set_fontcolor(Briefing_text_colors[Current_color], -1); gr_set_fontcolor(Briefing_text_colors[Current_color], -1);
gr_printf(Briefing_text_x+1, Briefing_text_y, message ); gr_printf(br->text_x+1, br->text_y, message );
return w; return w;
} }
@ -576,25 +597,25 @@ void bald_guy_cheat(int key)
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
// loads a briefing screen // loads a briefing screen
int load_briefing_screen( char *fname ) int load_briefing_screen(briefing *br, char *fname)
{ {
int pcx_error; int pcx_error;
if (briefing_bm.bm_data != NULL) if (br->background.bm_data != NULL)
gr_free_bitmap_data(&briefing_bm); gr_free_bitmap_data(&br->background);
gr_init_bitmap_data(&briefing_bm); gr_init_bitmap_data(&br->background);
strcpy (CurBriefScreenName,fname); strcpy (br->background_name,fname);
if (!stricmp(fname, "brief02h.pcx") && baldguy_cheat) if (!stricmp(fname, "brief02h.pcx") && baldguy_cheat)
if ( bald_guy_load(new_baldguy_pcx, &briefing_bm, BM_LINEAR, gr_palette) == 0) if ( bald_guy_load(new_baldguy_pcx, &br->background, BM_LINEAR, gr_palette) == 0)
return 0; return 0;
if ((pcx_error = pcx_read_bitmap(fname, &briefing_bm, BM_LINEAR, gr_palette))!=PCX_ERROR_NONE) if ((pcx_error = pcx_read_bitmap(fname, &br->background, BM_LINEAR, gr_palette))!=PCX_ERROR_NONE)
Error( "Error loading briefing screen <%s>, PCX load error: %s (%i)\n",fname, pcx_errormsg(pcx_error), pcx_error); Error( "Error loading briefing screen <%s>, PCX load error: %s (%i)\n",fname, pcx_errormsg(pcx_error), pcx_error);
show_fullscr(&briefing_bm); show_fullscr(&br->background);
gr_palette_load(gr_palette); gr_palette_load(gr_palette);
@ -676,7 +697,7 @@ void get_message_name(char **message, char *result)
} }
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
void flash_cursor(int cursor_flag) void flash_cursor(briefing *br, int cursor_flag)
{ {
if (cursor_flag == 0) if (cursor_flag == 0)
return; return;
@ -686,36 +707,27 @@ void flash_cursor(int cursor_flag)
else else
gr_set_fontcolor(Erase_color, -1); gr_set_fontcolor(Erase_color, -1);
gr_printf(Briefing_text_x, Briefing_text_y, "_" ); gr_printf(br->text_x, br->text_y, "_" );
} }
typedef struct msgstream { void redraw_messagestream(msgstream *stream, int count)
int x;
int y;
int color;
int ch;
} __pack__ msgstream;
msgstream messagestream[2048];
void redraw_messagestream(int count)
{ {
char msgbuf[2]; char msgbuf[2];
int i; int i;
for (i=0; i<count; i++) { for (i=0; i<count; i++) {
msgbuf[0] = messagestream[i].ch; msgbuf[0] = stream[i].ch;
msgbuf[1] = 0; msgbuf[1] = 0;
if (messagestream[i-1].color != messagestream[i].color) if (stream[i-1].color != stream[i].color)
gr_set_fontcolor(messagestream[i].color,-1); gr_set_fontcolor(stream[i].color,-1);
gr_printf(messagestream[i].x+1,messagestream[i].y,"%s",msgbuf); gr_printf(stream[i].x+1,stream[i].y,"%s",msgbuf);
} }
} }
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
// Return true if message got aborted by user (pressed ESC), else return false. // Return true if message got aborted by user (pressed ESC), else return false.
// Draws text, images and bitmaps actually // Draws text, images and bitmaps actually
int show_briefing(int screen_num, char *message) int show_briefing(briefing *br, int screen_num, char *message)
{ {
int prev_ch=-1; int prev_ch=-1;
int ch, done=0; int ch, done=0;
@ -731,8 +743,8 @@ int show_briefing(int screen_num, char *message)
grs_bitmap guy_bitmap; grs_bitmap guy_bitmap;
int streamcount=0, guy_bitmap_show=0; int streamcount=0, guy_bitmap_show=0;
strncpy(fname, CurBriefScreenName, 15);//fname = CurBriefScreenName; strncpy(fname, br->background_name, 15);//fname = br->background_name;
Bitmap_name[0] = 0; br->bitmap_name[0] = 0;
Current_color = 0; Current_color = 0;
gr_set_curfont( GAME_FONT ); gr_set_curfont( GAME_FONT );
@ -743,7 +755,7 @@ int show_briefing(int screen_num, char *message)
bsp->text_uly = rescale_y(bsp->text_uly); bsp->text_uly = rescale_y(bsp->text_uly);
bsp->text_width = rescale_x(bsp->text_width); bsp->text_width = rescale_x(bsp->text_width);
bsp->text_height = rescale_y(bsp->text_height); bsp->text_height = rescale_y(bsp->text_height);
init_char_pos(bsp->text_ulx, bsp->text_uly); init_char_pos(br, bsp->text_ulx, bsp->text_uly);
while (!done) { while (!done) {
ch = *message++; ch = *message++;
@ -763,48 +775,48 @@ int show_briefing(int screen_num, char *message)
tab_stop*=(1+HIRESMODE); tab_stop*=(1+HIRESMODE);
prev_ch = 10; // read to eoln prev_ch = 10; // read to eoln
} else if (ch == 'R') { } else if (ch == 'R') {
if (Robot_canv != NULL) if (br->robot_canv != NULL)
{ {
d_free(Robot_canv); d_free(br->robot_canv);
Robot_canv=NULL; br->robot_canv=NULL;
} }
init_spinning_robot(); init_spinning_robot(br);
robot_num = get_message_num(&message); robot_num = get_message_num(&message);
while (*message++ != 10) while (*message++ != 10)
; ;
prev_ch = 10; // read to eoln prev_ch = 10; // read to eoln
} else if (ch == 'N') { } else if (ch == 'N') {
if (Robot_canv != NULL) if (br->robot_canv != NULL)
{ {
d_free(Robot_canv); d_free(br->robot_canv);
Robot_canv=NULL; br->robot_canv=NULL;
} }
get_message_name(&message, Bitmap_name); get_message_name(&message, br->bitmap_name);
strcat(Bitmap_name, "#0"); strcat(br->bitmap_name, "#0");
Animating_bitmap_type = 0; br->animating_bitmap_type = 0;
prev_ch = 10; prev_ch = 10;
} else if (ch == 'O') { } else if (ch == 'O') {
if (Robot_canv != NULL) if (br->robot_canv != NULL)
{ {
d_free(Robot_canv); d_free(br->robot_canv);
Robot_canv=NULL; br->robot_canv=NULL;
} }
get_message_name(&message, Bitmap_name); get_message_name(&message, br->bitmap_name);
strcat(Bitmap_name, "#0"); strcat(br->bitmap_name, "#0");
Animating_bitmap_type = 1; br->animating_bitmap_type = 1;
prev_ch = 10; prev_ch = 10;
} else if (ch == 'B') { } else if (ch == 'B') {
char bitmap_name[32]; char bitmap_name[32];
ubyte temp_palette[768]; ubyte temp_palette[768];
int iff_error; int iff_error;
if (Robot_canv != NULL) if (br->robot_canv != NULL)
{ {
d_free(Robot_canv); d_free(br->robot_canv);
Robot_canv=NULL; br->robot_canv=NULL;
} }
get_message_name(&message, bitmap_name); get_message_name(&message, bitmap_name);
@ -828,16 +840,16 @@ int show_briefing(int screen_num, char *message)
; ;
timer_delay2(50); timer_delay2(50);
gr_flip(); gr_flip();
show_fullscr(&briefing_bm); show_fullscr(&br->background);
redraw_messagestream(streamcount); redraw_messagestream(br->messagestream, streamcount);
if (guy_bitmap_show) if (guy_bitmap_show)
show_briefing_bitmap(&guy_bitmap); show_briefing_bitmap(&guy_bitmap);
flash_cursor(flashing_cursor); flash_cursor(br, flashing_cursor);
if (robot_num != -1) if (robot_num != -1)
show_spinning_robot_frame(robot_num); show_spinning_robot_frame(br, robot_num);
if (Bitmap_name[0] != 0) if (br->bitmap_name[0] != 0)
show_animated_bitmap(); show_animated_bitmap(br);
start_time += KEY_DELAY_DEFAULT/2; start_time += KEY_DELAY_DEFAULT/2;
} }
@ -861,11 +873,11 @@ int show_briefing(int screen_num, char *message)
prev_ch = 10; prev_ch = 10;
} else if (ch == '$' || ch == ';') { // Print a $/; } else if (ch == '$' || ch == ';') { // Print a $/;
prev_ch = ch; prev_ch = ch;
Briefing_text_x += show_char_delay(ch, delay_count, robot_num, flashing_cursor); br->text_x += show_char_delay(br, ch, delay_count, robot_num, flashing_cursor);
} }
} else if (ch == '\t') { // Tab } else if (ch == '\t') { // Tab
if (Briefing_text_x - bsp->text_ulx < tab_stop) if (br->text_x - bsp->text_ulx < tab_stop)
Briefing_text_x = bsp->text_ulx + tab_stop; br->text_x = bsp->text_ulx + tab_stop;
} else if ((ch == ';') && (prev_ch == 10)) { } else if ((ch == ';') && (prev_ch == 10)) {
while (*message++ != 10) while (*message++ != 10)
; ;
@ -875,12 +887,12 @@ int show_briefing(int screen_num, char *message)
} else if (ch == 10) { } else if (ch == 10) {
if (prev_ch != '\\') { if (prev_ch != '\\') {
prev_ch = ch; prev_ch = ch;
Briefing_text_y += FSPACY(5)+FSPACY(5)*3/5; br->text_y += FSPACY(5)+FSPACY(5)*3/5;
Briefing_text_x = bsp->text_ulx; br->text_x = bsp->text_ulx;
if (Briefing_text_y > bsp->text_uly + bsp->text_height) { if (br->text_y > bsp->text_uly + bsp->text_height) {
load_briefing_screen(Briefing_screens[screen_num].bs_name); load_briefing_screen(br, Briefing_screens[screen_num].bs_name);
Briefing_text_x = bsp->text_ulx; br->text_x = bsp->text_ulx;
Briefing_text_y = bsp->text_uly; br->text_y = bsp->text_uly;
} }
} else { } else {
if (ch == 13) //Can this happen? Above says ch==10 if (ch == 13) //Can this happen? Above says ch==10
@ -888,23 +900,23 @@ int show_briefing(int screen_num, char *message)
prev_ch = ch; prev_ch = ch;
} }
} else { } else {
messagestream[streamcount].x = Briefing_text_x; br->messagestream[streamcount].x = br->text_x;
messagestream[streamcount].y = Briefing_text_y; br->messagestream[streamcount].y = br->text_y;
messagestream[streamcount].color = Briefing_text_colors[Current_color]; br->messagestream[streamcount].color = Briefing_text_colors[Current_color];
messagestream[streamcount].ch = ch; br->messagestream[streamcount].ch = ch;
if (delay_count) { if (delay_count) {
gr_flip(); gr_flip();
show_fullscr(&briefing_bm); show_fullscr(&br->background);
redraw_messagestream(streamcount); redraw_messagestream(br->messagestream, streamcount);
if (flashing_cursor) if (flashing_cursor)
gr_printf(Briefing_text_x + FSPACX(7),Briefing_text_y,"_"); gr_printf(br->text_x + FSPACX(7),br->text_y,"_");
} }
if (guy_bitmap_show) if (guy_bitmap_show)
show_briefing_bitmap(&guy_bitmap); show_briefing_bitmap(&guy_bitmap);
streamcount++; streamcount++;
prev_ch = ch; prev_ch = ch;
Briefing_text_x += show_char_delay(ch, delay_count, robot_num, flashing_cursor); br->text_x += show_char_delay(br, ch, delay_count, robot_num, flashing_cursor);
} }
@ -925,12 +937,12 @@ int show_briefing(int screen_num, char *message)
if ((key_check == KEY_SPACEBAR) || (key_check == KEY_ENTER)) if ((key_check == KEY_SPACEBAR) || (key_check == KEY_ENTER))
delay_count = 0; delay_count = 0;
if (Briefing_text_x > bsp->text_ulx + bsp->text_width) { if (br->text_x > bsp->text_ulx + bsp->text_width) {
Briefing_text_x = bsp->text_ulx; br->text_x = bsp->text_ulx;
Briefing_text_y += bsp->text_uly; br->text_y += bsp->text_uly;
} }
if ((new_page) || (Briefing_text_y > bsp->text_uly + bsp->text_height)) { if ((new_page) || (br->text_y > bsp->text_uly + bsp->text_height)) {
fix start_time = 0; fix start_time = 0;
int keypress; int keypress;
@ -941,15 +953,15 @@ int show_briefing(int screen_num, char *message)
; ;
timer_delay2(50); timer_delay2(50);
gr_flip(); gr_flip();
show_fullscr(&briefing_bm); show_fullscr(&br->background);
redraw_messagestream(streamcount); redraw_messagestream(br->messagestream, streamcount);
if (guy_bitmap_show) if (guy_bitmap_show)
show_briefing_bitmap(&guy_bitmap); show_briefing_bitmap(&guy_bitmap);
flash_cursor(flashing_cursor); flash_cursor(br, flashing_cursor);
if (robot_num != -1) if (robot_num != -1)
show_spinning_robot_frame(robot_num); show_spinning_robot_frame(br, robot_num);
if (Bitmap_name[0] != 0) if (br->bitmap_name[0] != 0)
show_animated_bitmap(); show_animated_bitmap(br);
start_time += KEY_DELAY_DEFAULT/2; start_time += KEY_DELAY_DEFAULT/2;
} }
@ -963,9 +975,9 @@ int show_briefing(int screen_num, char *message)
rval = 1; rval = 1;
done = 1; done = 1;
} }
load_briefing_screen(fname); load_briefing_screen(br, fname);
Briefing_text_x = bsp->text_ulx; br->text_x = bsp->text_ulx;
Briefing_text_y = bsp->text_uly; br->text_y = bsp->text_uly;
streamcount=0; streamcount=0;
if (guy_bitmap_show) { if (guy_bitmap_show) {
@ -977,21 +989,21 @@ int show_briefing(int screen_num, char *message)
} }
} }
if (Robot_canv != NULL) if (br->robot_canv != NULL)
{d_free(Robot_canv); Robot_canv=NULL;} {d_free(br->robot_canv); br->robot_canv=NULL;}
d_free(bsp); d_free(bsp);
if (briefing_bm.bm_data != NULL) if (br->background.bm_data != NULL)
gr_free_bitmap_data (&briefing_bm); gr_free_bitmap_data (&br->background);
return rval; return rval;
} }
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// Return a pointer to the start of text for screen #screen_num. // Return a pointer to the start of text for screen #screen_num.
char * get_briefing_message(int screen_num) char * get_briefing_message(briefing *br, int screen_num)
{ {
char *tptr = Briefing_text; char *tptr = br->text;
int cur_screen=0; int cur_screen=0;
int ch; int ch;
@ -1056,18 +1068,18 @@ int load_screen_text(char *filename, char **buf)
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// Return true if message got aborted, else return false. // Return true if message got aborted, else return false.
int show_briefing_text(int screen_num) int show_briefing_text(briefing *br, int screen_num)
{ {
char *message_ptr; char *message_ptr;
message_ptr = get_briefing_message(Briefing_screens[screen_num].message_num); message_ptr = get_briefing_message(br, Briefing_screens[screen_num].message_num);
if (message_ptr==NULL) if (message_ptr==NULL)
return (0); return (0);
set_briefing_fontcolor(); set_briefing_fontcolor();
return show_briefing(screen_num, message_ptr); return show_briefing(br, screen_num, message_ptr);
} }
void set_briefing_fontcolor () void set_briefing_fontcolor ()
@ -1100,17 +1112,17 @@ void set_briefing_fontcolor ()
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// Return true if screen got aborted by user, else return false. // Return true if screen got aborted by user, else return false.
int show_briefing_screen( int screen_num, int allow_keys) int show_briefing_screen(briefing *br, int screen_num, int allow_keys)
{ {
int rval=0; int rval=0;
gr_init_bitmap_data (&briefing_bm); gr_init_bitmap_data (&br->background);
load_briefing_screen(Briefing_screens_LH[screen_num].bs_name); load_briefing_screen(br, Briefing_screens_LH[screen_num].bs_name);
show_fullscr(&briefing_bm ); show_fullscr(&br->background );
gr_palette_load(gr_palette); gr_palette_load(gr_palette);
rval = show_briefing_text(screen_num); rval = show_briefing_text(br, screen_num);
return rval; return rval;
} }
@ -1121,13 +1133,23 @@ void do_briefing_screens(char *filename, int level_num)
{ {
int abort_briefing_screens = 0; int abort_briefing_screens = 0;
int cur_briefing_screen = 0; int cur_briefing_screen = 0;
briefing *br;
if (!filename || !*filename) if (!filename || !*filename)
return; return;
if (!load_screen_text(filename, &Briefing_text)) MALLOC(br, briefing, 1);
if (!br)
return; return;
briefing_init(br);
if (!load_screen_text(filename, &br->text))
{
d_free(br);
return;
}
songs_play_song( SONG_BRIEFING, 1 ); songs_play_song( SONG_BRIEFING, 1 );
set_screen_mode( SCREEN_MENU ); set_screen_mode( SCREEN_MENU );
@ -1137,7 +1159,7 @@ void do_briefing_screens(char *filename, int level_num)
if (level_num == 1) { if (level_num == 1) {
while ((!abort_briefing_screens) && (Briefing_screens[cur_briefing_screen].level_num == 0)) { while ((!abort_briefing_screens) && (Briefing_screens[cur_briefing_screen].level_num == 0)) {
abort_briefing_screens = show_briefing_screen(cur_briefing_screen, 0); abort_briefing_screens = show_briefing_screen(br, cur_briefing_screen, 0);
cur_briefing_screen++; cur_briefing_screen++;
} }
} }
@ -1145,11 +1167,12 @@ void do_briefing_screens(char *filename, int level_num)
if (!abort_briefing_screens) { if (!abort_briefing_screens) {
for (cur_briefing_screen = 0; cur_briefing_screen < MAX_BRIEFING_SCREEN; cur_briefing_screen++) for (cur_briefing_screen = 0; cur_briefing_screen < MAX_BRIEFING_SCREEN; cur_briefing_screen++)
if (Briefing_screens[cur_briefing_screen].level_num == level_num) if (Briefing_screens[cur_briefing_screen].level_num == level_num)
if (show_briefing_screen(cur_briefing_screen, 0)) if (show_briefing_screen(br, cur_briefing_screen, 0))
break; break;
} }
d_free(Briefing_text); d_free(br->text);
d_free(br);
key_flush(); key_flush();
} }
@ -1158,57 +1181,72 @@ void do_briefing_screens(char *filename, int level_num)
void do_registered_end_game(void) void do_registered_end_game(void)
{ {
int cur_briefing_screen; int cur_briefing_screen;
briefing *br;
if (!Ending_text_filename[0]) //no filename? if (!Ending_text_filename[0]) //no filename?
return; return;
MALLOC(br, briefing, 1);
if (!br)
return;
briefing_init(br);
if ((Game_mode & GM_MULTI) && !(Game_mode & GM_MULTI_COOP)) if ((Game_mode & GM_MULTI) && !(Game_mode & GM_MULTI_COOP))
{ {
// Special ending for deathmatch!! // Special ending for deathmatch!!
int len = 40; int len = 40;
MALLOC(Briefing_text, char, len); MALLOC(br->text, char, len);
sprintf(Briefing_text, "Test"); sprintf(br->text, "Test");
} }
load_screen_text(Ending_text_filename, &Briefing_text); load_screen_text(Ending_text_filename, &br->text);
for (cur_briefing_screen = 0; cur_briefing_screen < MAX_BRIEFING_SCREEN; cur_briefing_screen++) for (cur_briefing_screen = 0; cur_briefing_screen < MAX_BRIEFING_SCREEN; cur_briefing_screen++)
if (Briefing_screens[cur_briefing_screen].level_num == REGISTERED_ENDING_LEVEL_NUM) if (Briefing_screens[cur_briefing_screen].level_num == REGISTERED_ENDING_LEVEL_NUM)
if (show_briefing_screen(cur_briefing_screen, 0)) if (show_briefing_screen(br, cur_briefing_screen, 0))
break; break;
d_free(Briefing_text); d_free(br->text);
d_free(br);
} }
#endif #endif
void do_shareware_end_game(void) void do_shareware_end_game(void)
{ {
int cur_briefing_screen; int cur_briefing_screen;
briefing *br;
#ifdef NETWORK #ifdef NETWORK
if ((Game_mode & GM_MULTI) && !(Game_mode & GM_MULTI_COOP)) if ((Game_mode & GM_MULTI) && !(Game_mode & GM_MULTI_COOP))
{ {
MALLOC(Briefing_text, char, 4); // Dummy
kmatrix_view(1); kmatrix_view(1);
return; return;
} }
else else
#endif #endif
{ {
MALLOC(br, briefing, 1);
if (!br)
return;
briefing_init(br);
#ifdef DEST_SAT #ifdef DEST_SAT
load_screen_text(Ending_text_filename, &Briefing_text); load_screen_text(Ending_text_filename, &br->text);
#else #else
load_screen_text(SHAREWARE_ENDING_FILENAME, &Briefing_text); load_screen_text(SHAREWARE_ENDING_FILENAME, &br->text);
#endif #endif
} }
for (cur_briefing_screen = 0; cur_briefing_screen < MAX_BRIEFING_SCREEN; cur_briefing_screen++) for (cur_briefing_screen = 0; cur_briefing_screen < MAX_BRIEFING_SCREEN; cur_briefing_screen++)
if (Briefing_screens[cur_briefing_screen].level_num == SHAREWARE_ENDING_LEVEL_NUM) if (Briefing_screens[cur_briefing_screen].level_num == SHAREWARE_ENDING_LEVEL_NUM)
if (show_briefing_screen(cur_briefing_screen, 0)) if (show_briefing_screen(br, cur_briefing_screen, 0))
break; break;
d_free(Briefing_text); d_free(br->text);
d_free(br);
} }
void do_end_game(void) void do_end_game(void)
@ -1228,11 +1266,6 @@ void do_end_game(void)
#endif #endif
#endif #endif
if (Briefing_text) {
d_free(Briefing_text);
Briefing_text = NULL;
}
key_flush(); key_flush();
Function_mode = FMODE_MENU; Function_mode = FMODE_MENU;