summaryrefslogtreecommitdiff
path: root/src/hexen/st_start.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/hexen/st_start.c')
-rw-r--r--src/hexen/st_start.c316
1 files changed, 316 insertions, 0 deletions
diff --git a/src/hexen/st_start.c b/src/hexen/st_start.c
new file mode 100644
index 00000000..897c1810
--- /dev/null
+++ b/src/hexen/st_start.c
@@ -0,0 +1,316 @@
+// Emacs style mode select -*- C++ -*-
+//-----------------------------------------------------------------------------
+//
+// Copyright(C) 1993-1996 Id Software, Inc.
+// Copyright(C) 1993-2008 Raven Software
+// Copyright(C) 2008 Simon Howard
+//
+// This program is free software; you can redistribute it and/or
+// modify it under the terms of the GNU General Public License
+// as published by the Free Software Foundation; either version 2
+// of the License, or (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
+// 02111-1307, USA.
+//
+//-----------------------------------------------------------------------------
+
+
+
+// HEADER FILES ------------------------------------------------------------
+
+#include <stdarg.h>
+
+#include "config.h"
+
+#include "h2def.h"
+#include "i_system.h"
+#include "i_videohr.h"
+#include "s_sound.h"
+#include "st_start.h"
+
+
+// MACROS ------------------------------------------------------------------
+#define ST_MAX_NOTCHES 32
+#define ST_NOTCH_WIDTH 16
+#define ST_NOTCH_HEIGHT 23
+#define ST_PROGRESS_X 64 // Start of notches x screen pos.
+#define ST_PROGRESS_Y 441 // Start of notches y screen pos.
+
+#define ST_NETPROGRESS_X 288
+#define ST_NETPROGRESS_Y 32
+#define ST_NETNOTCH_WIDTH 8
+#define ST_NETNOTCH_HEIGHT 16
+#define ST_MAX_NETNOTCHES 8
+
+byte *ST_LoadScreen(void);
+void ST_UpdateNotches(int notchPosition);
+void ST_UpdateNetNotches(int notchPosition);
+
+// PRIVATE DATA DEFINITIONS ------------------------------------------------
+static const byte *bitmap = NULL;
+int graphical_startup = 1;
+static boolean using_graphical_startup;
+
+static const byte notchTable[] = {
+ // plane 0
+ 0x00, 0x80, 0x01, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x40,
+ 0x02, 0x40, 0x02, 0x40, 0x02, 0x40, 0x02, 0x40, 0x02, 0x40, 0x03, 0xC0,
+ 0x0F, 0x90, 0x1B, 0x68, 0x3D, 0xBC, 0x3F, 0xFC, 0x20, 0x08, 0x20, 0x08,
+ 0x2F, 0xD8, 0x37, 0xD8, 0x37, 0xF8, 0x1F, 0xF8, 0x1C, 0x50,
+
+ // plane 1
+ 0x00, 0x80, 0x01, 0x80, 0x00, 0x00, 0x00, 0x00, 0x02, 0x40, 0x02, 0x40,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x01, 0xA0,
+ 0x30, 0x6C, 0x24, 0x94, 0x42, 0x4A, 0x60, 0x0E, 0x60, 0x06, 0x7F, 0xF6,
+ 0x7F, 0xF6, 0x7F, 0xF6, 0x5E, 0xF6, 0x38, 0x16, 0x23, 0xAC,
+
+ // plane 2
+ 0x00, 0x80, 0x01, 0x80, 0x01, 0x80, 0x00, 0x00, 0x02, 0x40, 0x02, 0x40,
+ 0x02, 0x40, 0x02, 0x40, 0x02, 0x40, 0x02, 0x40, 0x02, 0x40, 0x03, 0xE0,
+ 0x30, 0x6C, 0x24, 0x94, 0x52, 0x6A, 0x7F, 0xFE, 0x60, 0x0E, 0x60, 0x0E,
+ 0x6F, 0xD6, 0x77, 0xD6, 0x56, 0xF6, 0x38, 0x36, 0x23, 0xAC,
+
+ // plane 3
+ 0x00, 0x00, 0x00, 0x00, 0x01, 0x80, 0x01, 0x80, 0x01, 0x80, 0x01, 0x80,
+ 0x03, 0xC0, 0x03, 0xC0, 0x03, 0xC0, 0x03, 0xC0, 0x03, 0x80, 0x02, 0x40,
+ 0x0F, 0x90, 0x1B, 0x68, 0x3D, 0xB4, 0x1F, 0xF0, 0x1F, 0xF8, 0x1F, 0xF8,
+ 0x10, 0x28, 0x08, 0x28, 0x29, 0x08, 0x07, 0xE8, 0x1C, 0x50
+};
+
+
+// Red Network Progress notches
+static const byte netnotchTable[] = {
+ // plane 0
+ 0x80, 0x50, 0xD0, 0xf0, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0xD0, 0xF0, 0xC0,
+ 0x70, 0x50, 0x80, 0x60,
+
+ // plane 1
+ 0x60, 0xE0, 0xE0, 0xA0, 0xA0, 0xA0, 0xE0, 0xA0, 0xA0, 0xA0, 0xE0, 0xA0,
+ 0xA0, 0xE0, 0x60, 0x00,
+
+ // plane 2
+ 0x80, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x10, 0x00,
+ 0x10, 0x10, 0x80, 0x60,
+
+ // plane 3
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x00, 0x00, 0x00, 0x00
+};
+
+// CODE --------------------------------------------------------------------
+
+
+
+//--------------------------------------------------------------------------
+//
+// Startup Screen Functions
+//
+//--------------------------------------------------------------------------
+
+
+//==========================================================================
+//
+// ST_Init - Do the startup screen
+//
+//==========================================================================
+
+void ST_Init(void)
+{
+ byte *pal;
+ byte *buffer;
+
+ using_graphical_startup = false;
+
+ if (graphical_startup && !debugmode)
+ {
+ I_SetWindowTitleHR("Hexen startup - " PACKAGE_STRING);
+
+ // Set 640x480x16 mode
+ if (I_SetVideoModeHR())
+ {
+ using_graphical_startup = true;
+
+ S_StartSongName("orb", true);
+
+ I_ClearScreenHR();
+ I_InitPaletteHR();
+ I_BlackPaletteHR();
+
+ // Load graphic
+ buffer = ST_LoadScreen();
+ pal = buffer;
+ bitmap = buffer + 16 * 3;
+
+ I_SlamHR(bitmap);
+ I_FadeToPaletteHR(pal);
+ Z_Free(buffer);
+ }
+ }
+}
+
+void ST_Done(void)
+{
+ if (using_graphical_startup)
+ {
+ I_ClearScreenHR();
+ I_UnsetVideoModeHR();
+ }
+}
+
+
+//==========================================================================
+//
+// ST_UpdateNotches
+//
+//==========================================================================
+
+void ST_UpdateNotches(int notchPosition)
+{
+ int x = ST_PROGRESS_X + notchPosition * ST_NOTCH_WIDTH;
+ int y = ST_PROGRESS_Y;
+ I_SlamBlockHR(x, y, ST_NOTCH_WIDTH, ST_NOTCH_HEIGHT, notchTable);
+}
+
+
+//==========================================================================
+//
+// ST_UpdateNetNotches - indicates network progress
+//
+//==========================================================================
+
+void ST_UpdateNetNotches(int notchPosition)
+{
+ int x = ST_NETPROGRESS_X + notchPosition * ST_NETNOTCH_WIDTH;
+ int y = ST_NETPROGRESS_Y;
+ I_SlamBlockHR(x, y, ST_NETNOTCH_WIDTH, ST_NETNOTCH_HEIGHT, netnotchTable);
+}
+
+
+//==========================================================================
+//
+// ST_Progress - increments progress indicator
+//
+//==========================================================================
+
+void ST_Progress(void)
+{
+ // haleyjd FIXME: any way to get input here? SDL event loop?
+#ifdef __WATCOMC__
+ // Check for ESC press -- during startup all events eaten here
+ I_StartupReadKeys();
+#endif
+
+ if (using_graphical_startup)
+ {
+ static int notchPosition = 0;
+
+ if (notchPosition < ST_MAX_NOTCHES)
+ {
+ ST_UpdateNotches(notchPosition);
+ S_StartSound(NULL, SFX_STARTUP_TICK);
+ //I_Sleep(1000);
+ notchPosition++;
+ }
+ }
+
+ printf(".");
+}
+
+
+//==========================================================================
+//
+// ST_NetProgress - indicates network progress
+//
+//==========================================================================
+
+void ST_NetProgress(void)
+{
+ printf("*");
+
+ if (using_graphical_startup)
+ {
+ static int netnotchPosition = 0;
+
+ if (netnotchPosition < ST_MAX_NETNOTCHES)
+ {
+ ST_UpdateNetNotches(netnotchPosition);
+ S_StartSound(NULL, SFX_DRIP);
+ netnotchPosition++;
+ }
+ }
+}
+
+
+//==========================================================================
+//
+// ST_NetDone - net progress complete
+//
+//==========================================================================
+void ST_NetDone(void)
+{
+ if (using_graphical_startup)
+ {
+ S_StartSound(NULL, SFX_PICKUP_WEAPON);
+ }
+}
+
+
+//==========================================================================
+//
+// ST_Message - gives debug message
+//
+//==========================================================================
+
+void ST_Message(char *message, ...)
+{
+ va_list argptr;
+
+ va_start(argptr, message);
+ vprintf(message, argptr);
+ va_end(argptr);
+}
+
+//==========================================================================
+//
+// ST_RealMessage - gives user message
+//
+//==========================================================================
+
+void ST_RealMessage(char *message, ...)
+{
+ va_list argptr;
+
+ va_start(argptr, message);
+ vprintf(message, argptr);
+ va_end(argptr);
+}
+
+
+
+//==========================================================================
+//
+// ST_LoadScreen - loads startup graphic
+//
+//==========================================================================
+
+
+byte *ST_LoadScreen(void)
+{
+ int length, lump;
+ byte *buffer;
+
+ lump = W_GetNumForName("STARTUP");
+ length = W_LumpLength(lump);
+ buffer = (byte *) Z_Malloc(length, PU_STATIC, NULL);
+ W_ReadLump(lump, buffer);
+ return (buffer);
+}
+