2001-10-09 14:30:12 +00:00
|
|
|
/* ScummVM - Scumm Interpreter
|
|
|
|
* Copyright (C) 2001 Ludvig Strigeus
|
2002-03-20 17:51:07 +00:00
|
|
|
* Copyright (C) 2001/2002 The ScummVM project
|
2001-10-09 14:30:12 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
2001-11-06 20:00:47 +00:00
|
|
|
* $Header$
|
2001-10-09 14:30:12 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2001-10-09 17:38:20 +00:00
|
|
|
#define NEED_SDL_HEADERS
|
|
|
|
|
2001-10-09 14:30:12 +00:00
|
|
|
#include "stdafx.h"
|
|
|
|
#include "scumm.h"
|
2001-11-09 18:54:15 +00:00
|
|
|
#include "gui.h"
|
2001-11-14 18:40:39 +00:00
|
|
|
#include "SDL_thread.h"
|
2002-03-25 08:46:24 +00:00
|
|
|
#include "gameDetector.h"
|
2001-11-05 19:21:49 +00:00
|
|
|
|
2002-03-16 05:33:25 +00:00
|
|
|
#include "cdmusic.h"
|
2002-04-05 00:00:46 +00:00
|
|
|
#include "mp3_cd.h"
|
2002-03-16 05:33:25 +00:00
|
|
|
|
2002-03-06 12:24:56 +00:00
|
|
|
static unsigned int scale;
|
2001-10-09 14:30:12 +00:00
|
|
|
|
2002-04-12 10:34:46 +00:00
|
|
|
/* FIXME: Global variable names should be prepended with g_
|
|
|
|
* Only member variables should have a _ in front of the name. */
|
|
|
|
|
|
|
|
Scumm *g_scumm;
|
2001-10-23 19:51:50 +00:00
|
|
|
ScummDebugger debugger;
|
2001-11-09 18:54:15 +00:00
|
|
|
Gui gui;
|
2002-03-21 00:40:18 +00:00
|
|
|
OSystem _system;
|
2002-03-25 08:51:34 +00:00
|
|
|
GameDetector detector;
|
2001-10-09 14:30:12 +00:00
|
|
|
|
2001-11-05 19:21:49 +00:00
|
|
|
SoundEngine sound;
|
2001-12-01 17:06:13 +00:00
|
|
|
SOUND_DRIVER_TYPE snd_driv;
|
2001-11-05 19:21:49 +00:00
|
|
|
|
2001-10-09 14:30:12 +00:00
|
|
|
static SDL_Surface *screen;
|
2002-04-11 17:19:16 +00:00
|
|
|
static SDL_CD *cdrom;
|
2001-10-09 14:30:12 +00:00
|
|
|
|
2002-03-10 07:48:01 +00:00
|
|
|
/* For 2xSAI */
|
|
|
|
static SDL_Surface *sdl_hwscreen;
|
|
|
|
static SDL_Surface *sdl_tmpscreen;
|
2002-04-11 17:19:16 +00:00
|
|
|
int Init_2xSaI(uint32 BitFormat);
|
|
|
|
void _2xSaI(uint8 *srcPtr, uint32 srcPitch, uint8 *deltaPtr, uint8 *dstPtr,
|
|
|
|
uint32 dstPitch, int width, int height);
|
|
|
|
void Super2xSaI(uint8 *srcPtr, uint32 srcPitch, uint8 *deltaPtr,
|
|
|
|
uint8 *dstPtr, uint32 dstPitch, int width, int height);
|
|
|
|
void SuperEagle(uint8 *srcPtr, uint32 srcPitch, uint8 *deltaPtr,
|
|
|
|
uint8 *dstPtr, uint32 dstPitch, int width, int height);
|
2002-03-10 08:09:44 +00:00
|
|
|
|
2002-03-10 07:48:01 +00:00
|
|
|
|
2001-12-28 15:26:28 +00:00
|
|
|
static int current_shake_pos;
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void resetCursor(void)
|
|
|
|
{
|
2002-03-09 13:48:02 +00:00
|
|
|
SDL_ShowCursor(SDL_ENABLE);
|
|
|
|
}
|
|
|
|
|
2001-11-10 20:51:55 +00:00
|
|
|
void updateScreen(Scumm *s);
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void updatePalette(Scumm *s)
|
|
|
|
{
|
2001-10-09 14:30:12 +00:00
|
|
|
SDL_Color colors[256];
|
|
|
|
int first = s->_palDirtyMin;
|
2002-03-24 17:02:31 +00:00
|
|
|
int num = s->_palDirtyMax - first + 1;
|
2001-10-09 14:30:12 +00:00
|
|
|
int i;
|
|
|
|
byte *data = s->_currentPalette;
|
2002-04-11 17:19:16 +00:00
|
|
|
|
|
|
|
data += first * 3;
|
|
|
|
for (i = 0; i < num; i++, data += 3) {
|
2001-12-11 13:34:15 +00:00
|
|
|
colors[i].r = data[0];
|
|
|
|
colors[i].g = data[1];
|
|
|
|
colors[i].b = data[2];
|
2001-10-09 14:30:12 +00:00
|
|
|
colors[i].unused = 0;
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2001-10-09 14:30:12 +00:00
|
|
|
SDL_SetColors(screen, colors, first, num);
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2001-10-09 14:30:12 +00:00
|
|
|
s->_palDirtyMax = -1;
|
|
|
|
s->_palDirtyMin = 0x3E8;
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
int mapKey(int key, byte mod)
|
|
|
|
{
|
|
|
|
if (key >= SDLK_F1 && key <= SDLK_F9) {
|
2001-11-09 18:54:15 +00:00
|
|
|
return key - SDLK_F1 + 315;
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (key >= 'a' && key <= 'z' && mod & KMOD_SHIFT) {
|
|
|
|
key &= ~0x20;
|
|
|
|
} else if (key >= SDLK_NUMLOCK && key <= SDLK_EURO)
|
2001-11-09 18:54:15 +00:00
|
|
|
return 0;
|
|
|
|
return key;
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void waitForTimer(Scumm *s, int msec_delay)
|
|
|
|
{
|
2001-10-09 14:30:12 +00:00
|
|
|
SDL_Event event;
|
2001-11-14 18:40:39 +00:00
|
|
|
uint32 start_time;
|
2001-11-05 19:21:49 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (s->_fastMode & 2)
|
2001-11-14 18:40:39 +00:00
|
|
|
msec_delay = 0;
|
2002-04-11 17:19:16 +00:00
|
|
|
else if (s->_fastMode & 1)
|
2001-11-14 18:40:39 +00:00
|
|
|
msec_delay = 10;
|
|
|
|
|
|
|
|
start_time = SDL_GetTicks();
|
|
|
|
|
|
|
|
do {
|
|
|
|
while (SDL_PollEvent(&event)) {
|
2002-04-11 17:19:16 +00:00
|
|
|
switch (event.type) {
|
2001-11-14 18:40:39 +00:00
|
|
|
case SDL_KEYDOWN:
|
|
|
|
s->_keyPressed = mapKey(event.key.keysym.sym, event.key.keysym.mod);
|
2002-04-11 17:19:16 +00:00
|
|
|
if (event.key.keysym.sym >= '0' && event.key.keysym.sym <= '9') {
|
2001-11-14 18:40:39 +00:00
|
|
|
s->_saveLoadSlot = event.key.keysym.sym - '0';
|
2002-04-11 17:19:16 +00:00
|
|
|
if (event.key.keysym.mod & KMOD_SHIFT) {
|
2001-11-14 18:40:39 +00:00
|
|
|
sprintf(s->_saveLoadName, "Quicksave %d", s->_saveLoadSlot);
|
|
|
|
s->_saveLoadFlag = 1;
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (event.key.keysym.mod & KMOD_CTRL)
|
2001-11-14 18:40:39 +00:00
|
|
|
s->_saveLoadFlag = 2;
|
|
|
|
s->_saveLoadCompatible = false;
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (event.key.keysym.sym == 'z'
|
|
|
|
&& event.key.keysym.mod & KMOD_CTRL) {
|
2001-11-14 18:40:39 +00:00
|
|
|
exit(1);
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (event.key.keysym.sym == 'f'
|
|
|
|
&& event.key.keysym.mod & KMOD_CTRL) {
|
2001-11-14 18:40:39 +00:00
|
|
|
s->_fastMode ^= 1;
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (event.key.keysym.sym == 'g'
|
|
|
|
&& event.key.keysym.mod & KMOD_CTRL) {
|
2001-11-14 18:40:39 +00:00
|
|
|
s->_fastMode ^= 2;
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (event.key.keysym.sym == 'd'
|
|
|
|
&& event.key.keysym.mod & KMOD_CTRL) {
|
2001-11-14 18:40:39 +00:00
|
|
|
debugger.attach(s);
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (event.key.keysym.sym == 's'
|
|
|
|
&& event.key.keysym.mod & KMOD_CTRL) {
|
2001-11-14 18:40:39 +00:00
|
|
|
s->resourceStats();
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (event.key.keysym.sym == SDLK_RETURN
|
|
|
|
&& event.key.keysym.mod & KMOD_ALT) {
|
|
|
|
if (!SDL_WM_ToggleFullScreen(screen))
|
2001-12-28 17:56:53 +00:00
|
|
|
warning("Full screen failed");
|
2001-11-14 18:40:39 +00:00
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
#if defined(__APPLE__) || defined(MACOS)
|
|
|
|
if (event.key.keysym.sym == 'q' && event.key.keysym.mod & KMOD_LMETA) {
|
2001-11-14 18:40:39 +00:00
|
|
|
exit(1);
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
#endif
|
2001-11-14 18:40:39 +00:00
|
|
|
break;
|
2002-04-11 17:19:16 +00:00
|
|
|
case SDL_MOUSEMOTION:{
|
|
|
|
int newx, newy;
|
|
|
|
if (scale == 3) {
|
|
|
|
newx = event.motion.x / 3;
|
|
|
|
newy = event.motion.y / 3;
|
|
|
|
} else if (scale == 2) {
|
|
|
|
newx = event.motion.x >> 1;
|
|
|
|
newy = event.motion.y >> 1;
|
|
|
|
} else {
|
|
|
|
newx = event.motion.x;
|
|
|
|
newy = event.motion.y;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (newx != s->mouse.x || newy != s->mouse.y) {
|
|
|
|
s->mouse.x = newx;
|
|
|
|
s->mouse.y = newy;
|
|
|
|
s->drawMouse();
|
|
|
|
updateScreen(s);
|
|
|
|
}
|
|
|
|
break;
|
2001-11-14 18:40:39 +00:00
|
|
|
}
|
|
|
|
case SDL_MOUSEBUTTONDOWN:
|
2002-04-11 17:19:16 +00:00
|
|
|
if (event.button.button == SDL_BUTTON_LEFT)
|
|
|
|
s->_leftBtnPressed |= msClicked | msDown;
|
|
|
|
else if (event.button.button == SDL_BUTTON_RIGHT)
|
|
|
|
s->_rightBtnPressed |= msClicked | msDown;
|
2001-11-14 18:40:39 +00:00
|
|
|
break;
|
2001-12-27 17:51:58 +00:00
|
|
|
case SDL_MOUSEBUTTONUP:
|
2002-04-11 17:19:16 +00:00
|
|
|
if (event.button.button == SDL_BUTTON_LEFT)
|
2001-12-27 17:51:58 +00:00
|
|
|
s->_leftBtnPressed &= ~msDown;
|
2002-04-11 17:19:16 +00:00
|
|
|
else if (event.button.button == SDL_BUTTON_RIGHT)
|
2001-12-27 17:51:58 +00:00
|
|
|
s->_rightBtnPressed &= ~msDown;
|
|
|
|
break;
|
|
|
|
|
2001-11-14 18:40:39 +00:00
|
|
|
case SDL_QUIT:
|
2001-11-11 16:54:45 +00:00
|
|
|
exit(1);
|
2001-11-14 18:40:39 +00:00
|
|
|
break;
|
2001-10-09 14:30:12 +00:00
|
|
|
}
|
|
|
|
}
|
2001-11-14 18:40:39 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
cd_music_loop(); // Loop CD Music if necessary
|
2002-03-16 05:33:25 +00:00
|
|
|
|
2001-11-14 18:40:39 +00:00
|
|
|
if (SDL_GetTicks() >= start_time + msec_delay)
|
|
|
|
break;
|
|
|
|
SDL_Delay(10);
|
|
|
|
} while (1);
|
2001-10-09 14:30:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#define MAX_DIRTY_RECTS 40
|
|
|
|
SDL_Rect dirtyRects[MAX_DIRTY_RECTS];
|
|
|
|
int numDirtyRects;
|
|
|
|
bool fullRedraw;
|
|
|
|
|
2001-10-10 10:02:33 +00:00
|
|
|
int old_mouse_x, old_mouse_y;
|
2001-11-06 20:00:47 +00:00
|
|
|
int old_mouse_h, old_mouse_w;
|
2002-04-11 17:19:16 +00:00
|
|
|
bool has_mouse, hide_mouse;
|
2001-11-06 20:00:47 +00:00
|
|
|
|
|
|
|
#define BAK_WIDTH 40
|
2001-12-27 17:51:58 +00:00
|
|
|
#define BAK_HEIGHT 40
|
2002-04-11 17:19:16 +00:00
|
|
|
byte old_backup[BAK_WIDTH * BAK_HEIGHT * 2];
|
2001-10-10 10:02:33 +00:00
|
|
|
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void addDirtyRect(int x, int y, int w, int h)
|
|
|
|
{
|
2001-10-10 10:02:33 +00:00
|
|
|
SDL_Rect *r;
|
2002-04-11 17:19:16 +00:00
|
|
|
if (numDirtyRects == MAX_DIRTY_RECTS)
|
2001-10-10 10:02:33 +00:00
|
|
|
fullRedraw = true;
|
|
|
|
else if (!fullRedraw) {
|
|
|
|
r = &dirtyRects[numDirtyRects++];
|
2002-04-11 17:19:16 +00:00
|
|
|
if (scale == 3) {
|
|
|
|
r->x = x * 3;
|
|
|
|
r->y = y * 3;
|
|
|
|
r->w = w * 3;
|
|
|
|
r->h = h * 3;
|
|
|
|
} else if (scale == 2) {
|
|
|
|
r->x = x * 2;
|
|
|
|
r->y = y * 2;
|
|
|
|
r->w = w * 2;
|
|
|
|
r->h = h * 2;
|
|
|
|
} else {
|
|
|
|
r->x = x;
|
|
|
|
r->y = y;
|
|
|
|
r->w = w;
|
|
|
|
r->h = h;
|
|
|
|
}
|
2001-10-10 10:02:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void addDirtyRectClipped(int x, int y, int w, int h)
|
|
|
|
{
|
|
|
|
if (x < 0) {
|
|
|
|
w += x;
|
|
|
|
x = 0;
|
|
|
|
}
|
|
|
|
if (y < 0) {
|
|
|
|
h += y;
|
|
|
|
y = 0;
|
|
|
|
}
|
|
|
|
if (w >= 320 - x)
|
|
|
|
w = 320 - x;
|
|
|
|
if (h >= 200 - y)
|
|
|
|
h = 200 - y;
|
|
|
|
if (w > 0 && h > 0)
|
|
|
|
addDirtyRect(x, y, w, h);
|
2001-10-10 10:02:33 +00:00
|
|
|
}
|
|
|
|
|
2001-12-28 15:26:28 +00:00
|
|
|
#define MAX(a,b) (((a)<(b)) ? (b) : (a))
|
|
|
|
#define MIN(a,b) (((a)>(b)) ? (b) : (a))
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void setShakePos(Scumm *s, int shake_pos)
|
|
|
|
{
|
2001-12-28 15:26:28 +00:00
|
|
|
int old_shake_pos = current_shake_pos;
|
|
|
|
int dirty_height, dirty_blackheight;
|
|
|
|
int dirty_top, dirty_blacktop;
|
2002-04-12 10:34:46 +00:00
|
|
|
|
2001-12-28 15:26:28 +00:00
|
|
|
if (shake_pos != old_shake_pos) {
|
|
|
|
current_shake_pos = shake_pos;
|
|
|
|
fullRedraw = true;
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2001-12-28 15:26:28 +00:00
|
|
|
/* Old shake pos was current_shake_pos, new is shake_pos.
|
|
|
|
* Move the screen up or down to account for the change.
|
|
|
|
*/
|
2002-04-12 10:34:46 +00:00
|
|
|
SDL_Rect dstr = { 0, shake_pos*scale, 320*scale, 200*scale };
|
|
|
|
SDL_Rect srcr = { 0, old_shake_pos*scale, 320*scale, 200*scale };
|
|
|
|
SDL_BlitSurface(screen, &srcr, screen, &dstr);
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2001-12-28 15:26:28 +00:00
|
|
|
/* Also adjust the mouse pointer backup Y coordinate.
|
|
|
|
* There is a minor mouse glitch when the mouse is moved
|
|
|
|
* at the blackness of the shake area, but it's hardly noticable */
|
|
|
|
old_mouse_y += shake_pos - old_shake_pos;
|
|
|
|
|
|
|
|
/* Refresh either the upper part of the screen,
|
|
|
|
* or the lower part */
|
|
|
|
if (shake_pos > old_shake_pos) {
|
2002-04-11 17:19:16 +00:00
|
|
|
dirty_height = MIN(shake_pos, 0) - MIN(old_shake_pos, 0);
|
|
|
|
dirty_top = -MIN(shake_pos, 0);
|
|
|
|
dirty_blackheight = MAX(shake_pos, 0) - MAX(old_shake_pos, 0);
|
|
|
|
dirty_blacktop = MAX(old_shake_pos, 0);
|
2001-12-28 15:26:28 +00:00
|
|
|
} else {
|
2002-04-11 17:19:16 +00:00
|
|
|
dirty_height = MAX(old_shake_pos, 0) - MAX(shake_pos, 0);
|
|
|
|
dirty_top = 200 - MAX(old_shake_pos, 0);
|
|
|
|
dirty_blackheight = MIN(old_shake_pos, 0) - MIN(shake_pos, 0);
|
|
|
|
dirty_blacktop = 200 + MIN(shake_pos, 0);
|
2001-12-28 15:26:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Fill the dirty area with blackness or the scumm image */
|
2002-04-12 10:34:46 +00:00
|
|
|
SDL_Rect blackrect = {0, dirty_blacktop*scale, 320*scale, dirty_blackheight*scale};
|
|
|
|
SDL_FillRect(screen, &blackrect, 0);
|
2002-03-06 12:24:56 +00:00
|
|
|
|
2002-04-12 10:34:46 +00:00
|
|
|
s->redrawLines(dirty_top, dirty_top + dirty_height);
|
2001-12-28 15:26:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-10-09 14:30:12 +00:00
|
|
|
/* Copy part of bitmap */
|
2002-04-11 17:19:16 +00:00
|
|
|
void blitToScreen(Scumm *s, byte *src, int x, int y, int w, int h)
|
|
|
|
{
|
2001-10-09 14:30:12 +00:00
|
|
|
byte *dst;
|
|
|
|
int i;
|
|
|
|
|
2001-10-10 10:02:33 +00:00
|
|
|
hide_mouse = true;
|
|
|
|
if (has_mouse) {
|
|
|
|
s->drawMouse();
|
|
|
|
}
|
|
|
|
|
2001-12-28 15:26:28 +00:00
|
|
|
/* Account for the shaking and do Y clipping */
|
|
|
|
y += current_shake_pos;
|
2002-04-11 17:19:16 +00:00
|
|
|
if (y < 0) {
|
|
|
|
h += y;
|
|
|
|
src -= y * 320;
|
|
|
|
y = 0;
|
|
|
|
}
|
|
|
|
if (h > 200 - y) {
|
|
|
|
h = 200 - y;
|
|
|
|
}
|
|
|
|
if (h <= 0)
|
|
|
|
return;
|
2001-12-28 15:26:28 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (SDL_LockSurface(screen) == -1)
|
2001-10-09 14:30:12 +00:00
|
|
|
error("SDL_LockSurface failed: %s.\n", SDL_GetError());
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (scale == 3) {
|
|
|
|
dst = (byte *)screen->pixels + y * 960 * 3 + x * 3;
|
|
|
|
addDirtyRect(x, y, w, h);
|
2002-03-06 12:24:56 +00:00
|
|
|
#ifdef DEBUG_CODE
|
2002-04-11 17:19:16 +00:00
|
|
|
byte black = GetAsyncKeyState(VK_SHIFT) < 0 ? 0 : 0xFF;
|
2002-03-06 12:24:56 +00:00
|
|
|
do {
|
2002-04-11 17:19:16 +00:00
|
|
|
i = 0;
|
|
|
|
do {
|
|
|
|
dst[i * 3] = dst[i * 3 + 1] = dst[i * 3 + 2] = src[i] & black;
|
|
|
|
} while (++i != w);
|
|
|
|
memcpy(dst + 960, dst, w * 3);
|
|
|
|
memcpy(dst + 960 + 960, dst, w * 3);
|
|
|
|
dst += 960 * 3;
|
|
|
|
src += 320;
|
|
|
|
} while (--h);
|
2001-10-09 14:30:12 +00:00
|
|
|
#else
|
2002-03-06 12:24:56 +00:00
|
|
|
do {
|
2002-04-11 17:19:16 +00:00
|
|
|
i = 0;
|
|
|
|
do {
|
|
|
|
dst[i * 3] = dst[i * 3 + 1] = dst[i * 3 + 2] = src[i];
|
|
|
|
} while (++i != w);
|
|
|
|
memcpy(dst + 960, dst, w * 3);
|
|
|
|
memcpy(dst + 960 + 960, dst, w * 3);
|
|
|
|
dst += 960 * 3;
|
|
|
|
src += 320;
|
|
|
|
} while (--h);
|
2002-03-06 12:24:56 +00:00
|
|
|
#endif
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (scale == 2) {
|
|
|
|
dst = (byte *)screen->pixels + y * 640 * 2 + x * 2;
|
|
|
|
addDirtyRect(x, y, w, h);
|
2001-12-29 12:45:54 +00:00
|
|
|
#ifdef DEBUG_CODE
|
2002-04-11 17:19:16 +00:00
|
|
|
byte black = GetAsyncKeyState(VK_SHIFT) < 0 ? 0 : 0xFF;
|
2001-12-29 12:45:54 +00:00
|
|
|
do {
|
2002-04-11 17:19:16 +00:00
|
|
|
i = 0;
|
|
|
|
do {
|
|
|
|
dst[i * 2] = dst[i * 2 + 1] = src[i] & black;
|
|
|
|
} while (++i != w);
|
|
|
|
memcpy(dst + 640, dst, w * 2);
|
|
|
|
dst += 640 * 2;
|
|
|
|
src += 320;
|
|
|
|
} while (--h);
|
2001-12-29 12:45:54 +00:00
|
|
|
#else
|
2001-10-09 14:30:12 +00:00
|
|
|
do {
|
2002-04-11 17:19:16 +00:00
|
|
|
i = 0;
|
|
|
|
do {
|
|
|
|
dst[i * 2] = dst[i * 2 + 1] = src[i];
|
|
|
|
} while (++i != w);
|
|
|
|
memcpy(dst + 640, dst, w * 2);
|
|
|
|
dst += 640 * 2;
|
|
|
|
src += 320;
|
|
|
|
} while (--h);
|
2001-12-29 12:45:54 +00:00
|
|
|
#endif
|
2002-04-11 17:19:16 +00:00
|
|
|
} else {
|
|
|
|
dst = (byte *)screen->pixels + y * 320 + x;
|
|
|
|
addDirtyRect(x, y, w, h);
|
|
|
|
do {
|
|
|
|
memcpy(dst, src, w);
|
|
|
|
dst += 320;
|
|
|
|
src += 320;
|
|
|
|
} while (--h);
|
2002-03-06 12:24:56 +00:00
|
|
|
}
|
2001-10-09 14:30:12 +00:00
|
|
|
|
|
|
|
SDL_UnlockSurface(screen);
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void Draw2xSaI(SDL_Rect * r, int vidmode)
|
|
|
|
{
|
2002-03-10 07:48:01 +00:00
|
|
|
if (SDL_BlitSurface(screen, r, sdl_tmpscreen, r) != 0)
|
|
|
|
error("SDL_BlitSurface failed");
|
|
|
|
|
|
|
|
SDL_LockSurface(sdl_tmpscreen);
|
|
|
|
SDL_LockSurface(sdl_hwscreen);
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
switch (vidmode) {
|
|
|
|
case VIDEO_2XSAI:
|
|
|
|
_2xSaI((byte *)sdl_tmpscreen->pixels + r->x * 2 + r->y * 640, 640, NULL,
|
|
|
|
(byte *)sdl_hwscreen->pixels + r->x * 4 + r->y * 640 * 4, 640 * 2,
|
|
|
|
r->w, r->h);
|
|
|
|
break;
|
|
|
|
case VIDEO_SUPERSAI:
|
|
|
|
Super2xSaI((byte *)sdl_tmpscreen->pixels + r->x * 2 + r->y * 640, 640,
|
|
|
|
NULL, (byte *)sdl_hwscreen->pixels + r->x * 4 + r->y * 640 * 4,
|
|
|
|
640 * 2, r->w, r->h);
|
|
|
|
break;
|
|
|
|
case VIDEO_SUPEREAGLE:
|
|
|
|
SuperEagle((byte *)sdl_tmpscreen->pixels + r->x * 2 + r->y * 640, 640,
|
|
|
|
NULL, (byte *)sdl_hwscreen->pixels + r->x * 4 + r->y * 640 * 4,
|
|
|
|
640 * 2, r->w, r->h);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
error("Unknown graphics mode %d", vidmode);
|
|
|
|
break;
|
2002-03-10 08:09:44 +00:00
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-10 07:48:01 +00:00
|
|
|
/* scale the rect to fit in SDL_UpdateRects */
|
|
|
|
r->x <<= 1;
|
|
|
|
r->y <<= 1;
|
|
|
|
r->w <<= 1;
|
|
|
|
r->h <<= 1;
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-10 07:48:01 +00:00
|
|
|
SDL_UnlockSurface(sdl_tmpscreen);
|
|
|
|
SDL_UnlockSurface(sdl_hwscreen);
|
|
|
|
SDL_UpdateRect(sdl_hwscreen, r->x, r->y, r->w, r->h);
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void updateScreen2xSaI(Scumm *s)
|
|
|
|
{
|
2002-03-10 07:48:01 +00:00
|
|
|
SDL_Rect r;
|
2001-11-05 19:21:49 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (s->_fastMode & 2)
|
2001-11-05 19:21:49 +00:00
|
|
|
return;
|
|
|
|
|
2001-10-10 10:02:33 +00:00
|
|
|
if (hide_mouse) {
|
|
|
|
hide_mouse = false;
|
|
|
|
s->drawMouse();
|
|
|
|
}
|
2001-12-28 15:26:28 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (s->_palDirtyMax != -1)
|
2001-10-09 14:30:12 +00:00
|
|
|
updatePalette(s);
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-10 07:48:01 +00:00
|
|
|
if (fullRedraw) {
|
2002-04-12 10:34:46 +00:00
|
|
|
r.x = 0;
|
2002-03-10 07:48:01 +00:00
|
|
|
r.y = 0;
|
|
|
|
r.w = 320;
|
|
|
|
r.h = 200;
|
2002-03-10 08:09:44 +00:00
|
|
|
Draw2xSaI(&r, s->_videoMode);
|
2002-03-10 07:48:01 +00:00
|
|
|
fullRedraw = false;
|
|
|
|
|
|
|
|
return;
|
|
|
|
} else if (numDirtyRects) {
|
|
|
|
SDL_Rect *dr;
|
|
|
|
int i;
|
2002-04-11 20:10:47 +00:00
|
|
|
for (i = 0; i < numDirtyRects; i++) {
|
2002-03-10 07:48:01 +00:00
|
|
|
dr = &dirtyRects[i];
|
2002-03-10 08:09:44 +00:00
|
|
|
Draw2xSaI(dr, s->_videoMode);
|
2002-03-10 07:48:01 +00:00
|
|
|
}
|
2001-10-17 11:30:19 +00:00
|
|
|
}
|
2002-03-10 07:48:01 +00:00
|
|
|
|
|
|
|
numDirtyRects = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void updateScreenScale(Scumm *s)
|
|
|
|
{
|
2001-10-17 11:30:19 +00:00
|
|
|
if (fullRedraw) {
|
2002-04-11 17:19:16 +00:00
|
|
|
SDL_UpdateRect(screen, 0, 0, 0, 0);
|
2001-12-27 17:51:58 +00:00
|
|
|
fullRedraw = false;
|
2001-10-09 14:30:12 +00:00
|
|
|
} else if (numDirtyRects) {
|
2002-04-11 17:19:16 +00:00
|
|
|
SDL_UpdateRects(screen, numDirtyRects, dirtyRects);
|
2001-10-09 14:30:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
numDirtyRects = 0;
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void updateScreen(Scumm *s)
|
|
|
|
{
|
|
|
|
if (s->_fastMode & 2)
|
2002-03-10 07:48:01 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
if (hide_mouse) {
|
|
|
|
hide_mouse = false;
|
|
|
|
s->drawMouse();
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (s->_palDirtyMax != -1) {
|
2002-03-10 07:48:01 +00:00
|
|
|
updatePalette(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (s->_videoMode == VIDEO_SCALE)
|
|
|
|
updateScreenScale(s);
|
|
|
|
else
|
2002-04-11 17:19:16 +00:00
|
|
|
updateScreen2xSaI(s);
|
2002-03-10 07:48:01 +00:00
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void drawMouse(Scumm *s, int xdraw, int ydraw, int w, int h, byte *buf,
|
|
|
|
bool visible)
|
|
|
|
{
|
|
|
|
int x, y;
|
|
|
|
byte *dst, *bak;
|
2001-11-06 20:00:47 +00:00
|
|
|
byte color;
|
|
|
|
|
|
|
|
if (hide_mouse)
|
|
|
|
visible = false;
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
assert(w <= BAK_WIDTH && h <= BAK_HEIGHT);
|
2001-12-27 17:51:58 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (SDL_LockSurface(screen) == -1)
|
2001-11-06 20:00:47 +00:00
|
|
|
error("SDL_LockSurface failed: %s.\n", SDL_GetError());
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (scale == 3) {
|
|
|
|
|
|
|
|
if (has_mouse) {
|
|
|
|
dst = (byte *)screen->pixels + old_mouse_y * 960 * 3 + old_mouse_x * 3;
|
|
|
|
bak = old_backup;
|
|
|
|
|
|
|
|
for (y = 0; y < old_mouse_h; y++, bak += BAK_WIDTH * 3, dst += 960 * 3) {
|
|
|
|
if ((uint) (old_mouse_y + y) < 200) {
|
|
|
|
for (x = 0; x < old_mouse_w; x++) {
|
|
|
|
if ((uint) (old_mouse_x + x) < 320) {
|
|
|
|
dst[x * 3 + 960] = dst[x * 3 + 960 + 960] = dst[x * 3] =
|
|
|
|
bak[x * 3];
|
|
|
|
dst[x * 3 + 960 + 1] = dst[x * 3 + 960 + 960 + 1] =
|
|
|
|
dst[x * 3 + 1] = bak[x * 3 + 1];
|
|
|
|
dst[x * 3 + 960 + 2] = dst[x * 3 + 960 + 960 + 2] =
|
|
|
|
dst[x * 3 + 2] = bak[x * 3 + 2];
|
|
|
|
}
|
2002-03-06 12:24:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (visible) {
|
|
|
|
ydraw += current_shake_pos;
|
|
|
|
|
|
|
|
dst = (byte *)screen->pixels + ydraw * 960 * 3 + xdraw * 3;
|
|
|
|
bak = old_backup;
|
|
|
|
|
|
|
|
for (y = 0; y < h; y++, dst += 960 * 3, bak += BAK_WIDTH * 3, buf += w) {
|
|
|
|
if ((uint) (ydraw + y) < 200) {
|
|
|
|
for (x = 0; x < w; x++) {
|
|
|
|
if ((uint) (xdraw + x) < 320) {
|
|
|
|
bak[x * 3] = dst[x * 3];
|
|
|
|
bak[x * 3 + 1] = dst[x * 3 + 1];
|
|
|
|
bak[x * 3 + 2] = dst[x * 3 + 2];
|
|
|
|
if ((color = buf[x]) != 0xFF) {
|
|
|
|
dst[x * 3] = color;
|
|
|
|
dst[x * 3 + 1] = color;
|
|
|
|
dst[x * 3 + 2] = color;
|
|
|
|
dst[x * 3 + 960] = color;
|
|
|
|
dst[x * 3 + 1 + 960] = color;
|
|
|
|
dst[x * 3 + 2 + 960] = color;
|
|
|
|
dst[x * 3 + 960 + 960] = color;
|
|
|
|
dst[x * 3 + 1 + 960 + 960] = color;
|
|
|
|
dst[x * 3 + 2 + 960 + 960] = color;
|
|
|
|
}
|
2002-03-06 12:24:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
} else if (scale == 2) {
|
|
|
|
|
|
|
|
if (has_mouse) {
|
|
|
|
dst = (byte *)screen->pixels + old_mouse_y * 640 * 2 + old_mouse_x * 2;
|
|
|
|
bak = old_backup;
|
|
|
|
|
|
|
|
for (y = 0; y < old_mouse_h; y++, bak += BAK_WIDTH * 2, dst += 640 * 2) {
|
|
|
|
if ((uint) (old_mouse_y + y) < 200) {
|
|
|
|
for (x = 0; x < old_mouse_w; x++) {
|
|
|
|
if ((uint) (old_mouse_x + x) < 320) {
|
|
|
|
dst[x * 2 + 640] = dst[x * 2] = bak[x * 2];
|
|
|
|
dst[x * 2 + 640 + 1] = dst[x * 2 + 1] = bak[x * 2 + 1];
|
|
|
|
}
|
2001-11-06 20:00:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (visible) {
|
|
|
|
ydraw += current_shake_pos;
|
|
|
|
|
|
|
|
dst = (byte *)screen->pixels + ydraw * 640 * 2 + xdraw * 2;
|
|
|
|
bak = old_backup;
|
|
|
|
|
|
|
|
for (y = 0; y < h; y++, dst += 640 * 2, bak += BAK_WIDTH * 2, buf += w) {
|
|
|
|
if ((uint) (ydraw + y) < 200) {
|
|
|
|
for (x = 0; x < w; x++) {
|
|
|
|
if ((uint) (xdraw + x) < 320) {
|
|
|
|
bak[x * 2] = dst[x * 2];
|
|
|
|
bak[x * 2 + 1] = dst[x * 2 + 1];
|
|
|
|
if ((color = buf[x]) != 0xFF) {
|
|
|
|
dst[x * 2] = color;
|
|
|
|
dst[x * 2 + 1] = color;
|
|
|
|
dst[x * 2 + 640] = color;
|
|
|
|
dst[x * 2 + 1 + 640] = color;
|
|
|
|
}
|
2001-11-06 20:00:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
} else {
|
|
|
|
if (has_mouse) {
|
|
|
|
dst = (byte *)screen->pixels + old_mouse_y * 320 + old_mouse_x;
|
|
|
|
bak = old_backup;
|
|
|
|
|
|
|
|
for (y = 0; y < old_mouse_h; y++, bak += BAK_WIDTH, dst += 320) {
|
|
|
|
if ((uint) (old_mouse_y + y) < 200) {
|
|
|
|
for (x = 0; x < old_mouse_w; x++) {
|
|
|
|
if ((uint) (old_mouse_x + x) < 320) {
|
|
|
|
dst[x] = bak[x];
|
|
|
|
}
|
2001-11-06 20:00:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
if (visible) {
|
|
|
|
ydraw += current_shake_pos;
|
|
|
|
|
|
|
|
dst = (byte *)screen->pixels + ydraw * 320 + xdraw;
|
|
|
|
bak = old_backup;
|
|
|
|
|
|
|
|
for (y = 0; y < h; y++, dst += 320, bak += BAK_WIDTH, buf += w) {
|
|
|
|
if ((uint) (ydraw + y) < 200) {
|
|
|
|
for (x = 0; x < w; x++) {
|
|
|
|
if ((uint) (xdraw + x) < 320) {
|
|
|
|
bak[x] = dst[x];
|
|
|
|
if ((color = buf[x]) != 0xFF) {
|
|
|
|
dst[x] = color;
|
|
|
|
}
|
2001-11-06 20:00:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SDL_UnlockSurface(screen);
|
|
|
|
|
|
|
|
if (has_mouse) {
|
|
|
|
has_mouse = false;
|
|
|
|
addDirtyRectClipped(old_mouse_x, old_mouse_y, old_mouse_w, old_mouse_h);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (visible) {
|
|
|
|
has_mouse = true;
|
|
|
|
addDirtyRectClipped(xdraw, ydraw, w, h);
|
|
|
|
old_mouse_x = xdraw;
|
|
|
|
old_mouse_y = ydraw;
|
|
|
|
old_mouse_w = w;
|
|
|
|
old_mouse_h = h;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void fill_sound(void *userdata, Uint8 * stream, int len)
|
|
|
|
{
|
2002-04-12 10:34:46 +00:00
|
|
|
g_scumm->mixWaves((int16 *) stream, len >> 1);
|
2001-11-05 19:21:49 +00:00
|
|
|
}
|
|
|
|
|
2002-03-18 11:50:09 +00:00
|
|
|
static int cd_track, cd_num_loops = 0, cd_start_frame, cd_end_frame;
|
2002-03-16 05:33:25 +00:00
|
|
|
|
|
|
|
// On my system, calling SDL_CDStatus all the time slows things down a
|
|
|
|
// lot and prevents music from playing at all :( So this saves the
|
|
|
|
// time the track is expected to be finished.
|
2002-03-18 11:50:09 +00:00
|
|
|
static Uint32 cd_end_time, cd_stop_time, cd_next_second;
|
2002-03-16 05:33:25 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void cd_play(Scumm *s, int track, int num_loops, int start_frame,
|
|
|
|
int end_frame)
|
|
|
|
{
|
2002-04-07 01:58:59 +00:00
|
|
|
|
2002-04-12 10:34:46 +00:00
|
|
|
/* FIXME: what does this code do? */
|
|
|
|
g_scumm->_vars[14] = 0;
|
2002-04-07 00:47:55 +00:00
|
|
|
|
2002-04-07 12:28:00 +00:00
|
|
|
if (!num_loops && !start_frame)
|
2002-04-07 01:58:59 +00:00
|
|
|
return;
|
|
|
|
|
2002-04-05 00:00:46 +00:00
|
|
|
#ifdef COMPRESSED_SOUND_FILE
|
2002-04-04 22:47:03 +00:00
|
|
|
|
2002-04-05 00:00:46 +00:00
|
|
|
if (mp3_cd_play(s, track, num_loops, start_frame, end_frame))
|
|
|
|
return;
|
2002-04-04 22:47:03 +00:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2002-03-18 11:50:09 +00:00
|
|
|
// warning("cd_play(%d,%d,%d,%d)", track, num_loops, start_frame, end_frame);
|
2002-04-11 17:19:16 +00:00
|
|
|
if (!cdrom)
|
|
|
|
return;
|
2002-03-16 05:33:25 +00:00
|
|
|
|
|
|
|
cd_track = track;
|
|
|
|
cd_num_loops = num_loops;
|
|
|
|
cd_start_frame = start_frame;
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-16 05:33:25 +00:00
|
|
|
SDL_CDStatus(cdrom);
|
2002-03-18 11:50:09 +00:00
|
|
|
SDL_CDPlayTracks(cdrom, track, start_frame, 0, end_frame);
|
|
|
|
cd_end_frame = end_frame;
|
2002-03-16 05:33:25 +00:00
|
|
|
cd_stop_time = 0;
|
2002-04-11 17:19:16 +00:00
|
|
|
cd_end_time = SDL_GetTicks() + cdrom->track[track].length * 1000 / CD_FPS;
|
2002-03-16 05:33:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Schedule the music to be stopped after 1/10 sec, unless another
|
|
|
|
// track is started in the meantime. (On my machine, stopping and
|
|
|
|
// then restarting the CD takes a few seconds.)
|
2002-04-11 17:19:16 +00:00
|
|
|
void cd_stop()
|
|
|
|
{
|
2002-03-16 05:33:25 +00:00
|
|
|
cd_stop_time = SDL_GetTicks() + 100;
|
|
|
|
cd_num_loops = 0;
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
int cd_is_running()
|
|
|
|
{
|
|
|
|
if (!cdrom)
|
|
|
|
return 0;
|
2002-03-16 05:33:25 +00:00
|
|
|
|
|
|
|
return (cd_num_loops != 0 && (SDL_GetTicks() < cd_end_time ||
|
2002-04-11 17:19:16 +00:00
|
|
|
SDL_CDStatus(cdrom) != CD_STOPPED));
|
2002-03-16 05:33:25 +00:00
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
static void cd_shutdown()
|
|
|
|
{
|
|
|
|
if (!cdrom)
|
|
|
|
return;
|
2002-03-16 05:33:25 +00:00
|
|
|
|
|
|
|
if (cd_num_loops != 0)
|
|
|
|
SDL_CDStop(cdrom);
|
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void cd_music_loop()
|
|
|
|
{
|
|
|
|
if (!cdrom)
|
|
|
|
return;
|
2002-03-18 11:50:09 +00:00
|
|
|
/* if (SDL_GetTicks() >= cd_next_second) {
|
|
|
|
/ printf("%d started at %d, fps\n", scumm._vars[14], cd_start_frame, CD_FPS);
|
|
|
|
//scumm._vars[14]++; //varmusicflag
|
|
|
|
cd_next_second = SDL_GetTicks() + 1;
|
|
|
|
} */
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-16 05:33:25 +00:00
|
|
|
if (cd_stop_time != 0 && SDL_GetTicks() >= cd_stop_time) {
|
|
|
|
SDL_CDStop(cdrom);
|
|
|
|
cd_num_loops = 0;
|
|
|
|
cd_stop_time = 0;
|
|
|
|
return;
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-16 05:33:25 +00:00
|
|
|
if (cd_num_loops == 0 || SDL_GetTicks() < cd_end_time)
|
|
|
|
return;
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-16 05:33:25 +00:00
|
|
|
if (cd_num_loops != 1 && SDL_CDStatus(cdrom) != CD_STOPPED) {
|
|
|
|
// Wait another second for it to be done
|
|
|
|
cd_end_time += 1000;
|
|
|
|
return;
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-16 05:33:25 +00:00
|
|
|
if (cd_num_loops > 0)
|
|
|
|
cd_num_loops--;
|
2002-03-18 11:50:09 +00:00
|
|
|
|
2002-03-16 05:33:25 +00:00
|
|
|
if (cd_num_loops != 0) {
|
2002-03-18 11:50:09 +00:00
|
|
|
SDL_CDPlayTracks(cdrom, cd_track, cd_start_frame, 0, cd_end_frame);
|
2002-04-11 17:19:16 +00:00
|
|
|
cd_end_time =
|
|
|
|
SDL_GetTicks() + cdrom->track[cd_track].length * 1000 / CD_FPS;
|
2002-03-16 05:33:25 +00:00
|
|
|
}
|
2002-02-19 03:11:46 +00:00
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
int music_thread(Scumm *s)
|
|
|
|
{
|
2001-11-14 18:40:39 +00:00
|
|
|
int old_time, cur_time;
|
2001-11-05 19:21:49 +00:00
|
|
|
|
2001-11-14 18:40:39 +00:00
|
|
|
old_time = SDL_GetTicks();
|
2001-11-05 19:21:49 +00:00
|
|
|
|
|
|
|
do {
|
2001-11-14 18:40:39 +00:00
|
|
|
SDL_Delay(10);
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2001-11-14 18:40:39 +00:00
|
|
|
cur_time = SDL_GetTicks();
|
|
|
|
while (old_time < cur_time) {
|
|
|
|
old_time += 10;
|
2002-04-11 17:19:16 +00:00
|
|
|
sound.on_timer();
|
2001-11-14 18:40:39 +00:00
|
|
|
}
|
|
|
|
} while (1);
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2001-11-14 18:40:39 +00:00
|
|
|
return 0;
|
2001-10-10 10:02:33 +00:00
|
|
|
}
|
|
|
|
|
2001-12-01 17:06:13 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void initGraphics(Scumm *s, bool fullScreen, unsigned int scaleFactor)
|
|
|
|
{
|
2001-11-05 19:21:49 +00:00
|
|
|
SDL_AudioSpec desired;
|
|
|
|
|
2002-03-06 12:24:56 +00:00
|
|
|
scale = scaleFactor;
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (SDL_Init(SDL_INIT_VIDEO | SDL_INIT_AUDIO) == -1) {
|
2001-10-09 19:02:28 +00:00
|
|
|
error("Could not initialize SDL: %s.\n", SDL_GetError());
|
2002-04-11 17:19:16 +00:00
|
|
|
exit(1);
|
2001-10-09 14:30:12 +00:00
|
|
|
}
|
2001-10-09 19:02:28 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (SDL_InitSubSystem(SDL_INIT_CDROM) == -1)
|
|
|
|
cdrom = NULL;
|
|
|
|
else {
|
|
|
|
cdrom = SDL_CDOpen(s->_cdrom);
|
2002-04-07 07:33:39 +00:00
|
|
|
/* Did if open? Check if cdrom is NULL */
|
2002-04-11 17:19:16 +00:00
|
|
|
if (!cdrom) {
|
2002-04-07 07:33:39 +00:00
|
|
|
warning("Couldn't open drive: %s\n", SDL_GetError());
|
|
|
|
}
|
|
|
|
}
|
2001-10-09 19:02:28 +00:00
|
|
|
/* Clean up on exit */
|
2002-04-11 17:19:16 +00:00
|
|
|
atexit(SDL_Quit);
|
2002-03-16 05:33:25 +00:00
|
|
|
atexit(cd_shutdown);
|
2002-03-09 13:48:02 +00:00
|
|
|
atexit(resetCursor);
|
2001-10-09 19:02:28 +00:00
|
|
|
|
2001-10-11 11:49:51 +00:00
|
|
|
char buf[512], *gameName;
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-25 08:51:34 +00:00
|
|
|
sprintf(buf, "ScummVM - %s", gameName = detector.getGameName());
|
2001-10-11 11:49:51 +00:00
|
|
|
free(gameName);
|
2001-11-05 19:21:49 +00:00
|
|
|
|
|
|
|
desired.freq = SAMPLES_PER_SEC;
|
|
|
|
desired.format = AUDIO_S16SYS;
|
|
|
|
desired.channels = 1;
|
|
|
|
desired.samples = 2048;
|
|
|
|
desired.callback = fill_sound;
|
|
|
|
SDL_OpenAudio(&desired, NULL);
|
|
|
|
SDL_PauseAudio(0);
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
SDL_WM_SetCaption(buf, buf);
|
2001-10-11 10:15:58 +00:00
|
|
|
SDL_ShowCursor(SDL_DISABLE);
|
2001-10-10 10:02:33 +00:00
|
|
|
|
2001-12-01 17:06:13 +00:00
|
|
|
if (!snd_driv.wave_based()) {
|
|
|
|
/* Create Music Thread */
|
2002-04-12 10:34:46 +00:00
|
|
|
SDL_CreateThread((int (*)(void *))&music_thread, s);
|
2001-12-01 17:06:13 +00:00
|
|
|
}
|
2001-12-28 15:26:28 +00:00
|
|
|
|
2002-03-10 08:09:44 +00:00
|
|
|
if (s->_videoMode == VIDEO_SCALE) {
|
2002-04-11 17:19:16 +00:00
|
|
|
screen =
|
|
|
|
SDL_SetVideoMode(320 * scale, 200 * scale, 8,
|
|
|
|
fullScreen ? (SDL_SWSURFACE | SDL_FULLSCREEN)
|
|
|
|
: (SDL_SWSURFACE | SDL_DOUBLEBUF));
|
2002-03-10 08:09:44 +00:00
|
|
|
} else {
|
2002-04-11 17:19:16 +00:00
|
|
|
uint16 *tmp_screen = (uint16 *)calloc(320 * 202 + 8, sizeof(uint16));
|
2002-03-10 07:48:01 +00:00
|
|
|
Init_2xSaI(565);
|
|
|
|
|
|
|
|
screen = SDL_CreateRGBSurface(SDL_SWSURFACE, 320, 200, 8, 0, 0, 0, 0);
|
2002-04-11 17:19:16 +00:00
|
|
|
sdl_hwscreen =
|
|
|
|
SDL_SetVideoMode(640, 400, 16,
|
|
|
|
fullScreen ? (SDL_SWSURFACE | SDL_FULLSCREEN)
|
|
|
|
: (SDL_SWSURFACE | SDL_DOUBLEBUF));
|
|
|
|
sdl_tmpscreen =
|
|
|
|
SDL_CreateRGBSurfaceFrom(tmp_screen + 320 + 4, 320, 200, 16, 320 * 2, 0,
|
|
|
|
0, 0, 0);
|
2002-03-10 07:48:01 +00:00
|
|
|
if (sdl_tmpscreen == NULL)
|
|
|
|
error("sdl_tmpscreen failed");
|
|
|
|
|
|
|
|
scale = 1;
|
2002-03-06 12:24:56 +00:00
|
|
|
}
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
// SDL_SWSURFACE 0x00000000 /* Surface is in system memory */
|
|
|
|
// SDL_HWSURFACE 0x00000001 /* Surface is in video memory */
|
|
|
|
// SDL_ASYNCBLIT 0x00000004 /* Use asynchronous blits if possible */
|
|
|
|
// SDL_ANYFORMAT 0x10000000 /* Allow any video depth/pixel-format */
|
|
|
|
// SDL_HWPALETTE 0x20000000 /* Surface has exclusive palette */
|
|
|
|
// SDL_DOUBLEBUF 0x40000000 /* Set up double-buffered video mode */
|
|
|
|
// SDL_FULLSCREEN 0x80000000 /* Surface is a full screen display */
|
|
|
|
// SDL_OPENGL 0x00000002 /* Create an OpenGL rendering context */
|
|
|
|
// SDL_OPENGLBLIT 0x0000000A /* Create an OpenGL rendering context and use it for blitting */
|
|
|
|
// SDL_RESIZABLE 0x00000010 /* This video mode may be resized */
|
|
|
|
// SDL_NOFRAME 0x00000020 /* No window caption or edge frame */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
printf("%d %d, %d %d, %d %d %d, %d %d %d %d %d\n",
|
|
|
|
sizeof(int8), sizeof(uint8),
|
|
|
|
sizeof(int16), sizeof(uint16),
|
|
|
|
sizeof(int32), sizeof(uint32),
|
|
|
|
sizeof(void *),
|
|
|
|
sizeof(Box), sizeof(MouseCursor), sizeof(CodeHeader),
|
|
|
|
sizeof(ImageHeader), sizeof(Scumm)
|
|
|
|
);
|
2001-10-09 19:02:28 +00:00
|
|
|
}
|
2001-10-09 14:30:12 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void setWindowName(Scumm *s)
|
|
|
|
{
|
|
|
|
char buf[512], *gameName;
|
|
|
|
|
|
|
|
sprintf(buf, "ScummVM - %s", gameName = detector.getGameName());
|
|
|
|
free(gameName);
|
|
|
|
SDL_WM_SetCaption(buf, buf);
|
2002-03-17 13:00:11 +00:00
|
|
|
}
|
2001-11-11 16:54:45 +00:00
|
|
|
|
|
|
|
#if !defined(__APPLE__)
|
2001-10-09 19:02:28 +00:00
|
|
|
#undef main
|
2001-11-11 16:54:45 +00:00
|
|
|
#endif
|
|
|
|
|
2002-03-14 13:57:28 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
void launcherLoop()
|
|
|
|
{
|
2002-03-14 13:57:28 +00:00
|
|
|
int last_time, new_time;
|
|
|
|
int delta = 0;
|
|
|
|
last_time = SDL_GetTicks();
|
|
|
|
|
2002-04-12 10:34:46 +00:00
|
|
|
gui.launcher(g_scumm);
|
2002-03-14 13:57:28 +00:00
|
|
|
do {
|
2002-04-12 10:34:46 +00:00
|
|
|
updateScreen(g_scumm);
|
2002-03-14 13:57:28 +00:00
|
|
|
|
|
|
|
new_time = SDL_GetTicks();
|
2002-04-12 10:34:46 +00:00
|
|
|
waitForTimer(g_scumm, delta * 15 + last_time - new_time);
|
2002-03-14 13:57:28 +00:00
|
|
|
last_time = SDL_GetTicks();
|
|
|
|
|
|
|
|
if (gui._active) {
|
2002-04-12 10:34:46 +00:00
|
|
|
gui.loop(g_scumm);
|
2002-03-14 13:57:28 +00:00
|
|
|
delta = 5;
|
|
|
|
} else
|
|
|
|
error("gui closed!");
|
2002-04-11 17:19:16 +00:00
|
|
|
} while (1);
|
2002-03-14 13:57:28 +00:00
|
|
|
|
|
|
|
};
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
#if defined(MACOS)
|
2002-03-09 13:48:02 +00:00
|
|
|
/* support for config file on macos */
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-09 13:48:02 +00:00
|
|
|
char *argitem;
|
|
|
|
char *argstr;
|
|
|
|
FILE *argf;
|
2002-04-11 17:19:16 +00:00
|
|
|
|
|
|
|
if ((argf = fopen("configuration.macos", "r")) == NULL) {
|
2002-03-09 13:48:02 +00:00
|
|
|
error("Can't open configuration file.\n");
|
|
|
|
exit(1);
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
|
|
|
|
argc = 0;
|
|
|
|
argstr = (char *)malloc(64);
|
2002-03-09 13:48:02 +00:00
|
|
|
argstr = fgets(argstr, 64, argf);
|
2002-04-11 17:19:16 +00:00
|
|
|
if ((argitem = strchr(argstr, '\n')) != NULL)
|
2002-03-09 13:48:02 +00:00
|
|
|
*argitem = '\0';
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-09 13:48:02 +00:00
|
|
|
argitem = strtok(argstr, " ");
|
2002-04-11 17:19:16 +00:00
|
|
|
|
|
|
|
while (argitem != NULL) {
|
|
|
|
argv = (char **)realloc(argv, (argc + 1) * 8);
|
|
|
|
argv[argc] = (char *)malloc(64);
|
2002-03-09 13:48:02 +00:00
|
|
|
strcpy(argv[argc], argitem);
|
2002-04-11 17:19:16 +00:00
|
|
|
argc++;
|
|
|
|
|
2002-03-09 13:48:02 +00:00
|
|
|
argitem = strtok(NULL, " ");
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-09 13:48:02 +00:00
|
|
|
free(argstr);
|
|
|
|
fclose(argf);
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-03-09 13:48:02 +00:00
|
|
|
#endif
|
2001-11-05 19:21:49 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
if (detector.detectMain(argc, argv))
|
|
|
|
return (-1);
|
2002-03-23 22:03:35 +00:00
|
|
|
|
2002-04-12 10:34:46 +00:00
|
|
|
/* Simon the Sorcerer? */
|
|
|
|
if (detector._gameId >= GID_SIMON_FIRST && detector._gameId <= GID_SIMON_LAST) {
|
|
|
|
/* Simon the Sorcerer. Completely different initialization */
|
|
|
|
} else {
|
|
|
|
Scumm *scumm = Scumm::createFromDetector(&detector);
|
|
|
|
g_scumm = scumm;
|
|
|
|
|
|
|
|
sound.initialize(scumm, &snd_driv);
|
|
|
|
|
|
|
|
/* bind to Gui */
|
|
|
|
scumm->_gui = &gui;
|
|
|
|
gui.init(scumm); /* Reinit GUI after loading a game */
|
|
|
|
|
|
|
|
/* Bind to OSystem */
|
|
|
|
scumm->_system = &_system;
|
|
|
|
_system.last_time = 0;
|
|
|
|
|
|
|
|
scumm->go();
|
2002-04-07 04:29:15 +00:00
|
|
|
}
|
2002-04-12 10:34:46 +00:00
|
|
|
|
2001-10-09 14:30:12 +00:00
|
|
|
return 0;
|
|
|
|
}
|
2001-10-11 10:15:58 +00:00
|
|
|
|
2002-02-19 18:04:21 +00:00
|
|
|
/************ ENDER: Temporary debug code for boxen **************/
|
2002-04-11 17:19:16 +00:00
|
|
|
int hlineColor(SDL_Surface * dst, Sint16 x1, Sint16 x2, Sint16 y,
|
|
|
|
Uint32 color)
|
|
|
|
{
|
|
|
|
Sint16 left, right, top, bottom;
|
|
|
|
Uint8 *pixel, *pixellast;
|
|
|
|
int dx;
|
|
|
|
int pixx, pixy;
|
|
|
|
Sint16 w;
|
|
|
|
Sint16 xtmp;
|
|
|
|
int result = -1;
|
|
|
|
Uint8 *colorptr;
|
|
|
|
|
|
|
|
/* Get clipping boundary */
|
|
|
|
left = dst->clip_rect.x;
|
|
|
|
right = dst->clip_rect.x + dst->clip_rect.w - 1;
|
|
|
|
top = dst->clip_rect.y;
|
|
|
|
bottom = dst->clip_rect.y + dst->clip_rect.h - 1;
|
|
|
|
|
|
|
|
/* Swap x1, x2 if required */
|
|
|
|
if (x1 > x2) {
|
|
|
|
xtmp = x1;
|
|
|
|
x1 = x2;
|
|
|
|
x2 = xtmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Visible */
|
|
|
|
if ((x1 > right) || (x2 < left) || (y < top) || (y > bottom)) {
|
|
|
|
return (0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Clip x */
|
|
|
|
if (x1 < left) {
|
|
|
|
x1 = left;
|
|
|
|
}
|
|
|
|
if (x2 > right) {
|
|
|
|
x2 = right;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Calculate width */
|
|
|
|
w = x2 - x1;
|
|
|
|
|
|
|
|
/* Sanity check on width */
|
|
|
|
if (w < 0) {
|
|
|
|
return (0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Setup color */
|
|
|
|
colorptr = (Uint8 *) & color;
|
|
|
|
if (SDL_BYTEORDER == SDL_BIG_ENDIAN) {
|
|
|
|
color =
|
|
|
|
SDL_MapRGBA(dst->format, colorptr[0], colorptr[1], colorptr[2],
|
|
|
|
colorptr[3]);
|
|
|
|
} else {
|
|
|
|
color =
|
|
|
|
SDL_MapRGBA(dst->format, colorptr[3], colorptr[2], colorptr[1],
|
|
|
|
colorptr[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Lock surface */
|
|
|
|
SDL_LockSurface(dst);
|
|
|
|
|
|
|
|
/* More variable setup */
|
|
|
|
dx = w;
|
|
|
|
pixx = dst->format->BytesPerPixel;
|
|
|
|
pixy = dst->pitch;
|
|
|
|
pixel = ((Uint8 *) dst->pixels) + pixx * (int)x1 + pixy * (int)y;
|
|
|
|
|
|
|
|
/* Draw */
|
|
|
|
switch (dst->format->BytesPerPixel) {
|
|
|
|
case 1:
|
|
|
|
memset(pixel, color, dx);
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
pixellast = pixel + dx + dx;
|
|
|
|
for (; pixel <= pixellast; pixel += pixx) {
|
|
|
|
*(Uint16 *) pixel = color;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
pixellast = pixel + dx + dx + dx;
|
|
|
|
for (; pixel <= pixellast; pixel += pixx) {
|
|
|
|
if (SDL_BYTEORDER == SDL_BIG_ENDIAN) {
|
|
|
|
pixel[0] = (color >> 16) & 0xff;
|
|
|
|
pixel[1] = (color >> 8) & 0xff;
|
|
|
|
pixel[2] = color & 0xff;
|
|
|
|
} else {
|
|
|
|
pixel[0] = color & 0xff;
|
|
|
|
pixel[1] = (color >> 8) & 0xff;
|
|
|
|
pixel[2] = (color >> 16) & 0xff;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default: /* case 4 */
|
|
|
|
dx = dx + dx;
|
|
|
|
pixellast = pixel + dx + dx;
|
|
|
|
for (; pixel <= pixellast; pixel += pixx) {
|
|
|
|
*(Uint32 *) pixel = color;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Unlock surface */
|
|
|
|
SDL_UnlockSurface(dst);
|
|
|
|
|
|
|
|
/* Set result code */
|
|
|
|
result = 0;
|
|
|
|
|
|
|
|
return (result);
|
2002-02-19 18:04:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int gfxPrimitivesCompareInt(const void *a, const void *b);
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
static int *gfxPrimitivesPolyInts = NULL;
|
|
|
|
static int gfxPrimitivesPolyAllocated = 0;
|
2002-02-19 18:04:21 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
int filledPolygonColor(SDL_Surface * dst, Sint16 * vx, Sint16 * vy, int n,
|
|
|
|
int color)
|
2002-02-19 18:04:21 +00:00
|
|
|
{
|
|
|
|
int result;
|
|
|
|
int i;
|
|
|
|
int y;
|
|
|
|
int miny, maxy;
|
|
|
|
int x1, y1;
|
|
|
|
int x2, y2;
|
|
|
|
int ind1, ind2;
|
|
|
|
int ints;
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-02-19 18:04:21 +00:00
|
|
|
/* Sanity check */
|
2002-04-11 17:19:16 +00:00
|
|
|
if (n < 3) {
|
|
|
|
return -1;
|
2002-02-19 18:04:21 +00:00
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-02-19 18:04:21 +00:00
|
|
|
/* Allocate temp array, only grow array */
|
|
|
|
if (!gfxPrimitivesPolyAllocated) {
|
2002-04-11 17:19:16 +00:00
|
|
|
gfxPrimitivesPolyInts = (int *)malloc(sizeof(int) * n);
|
|
|
|
gfxPrimitivesPolyAllocated = n;
|
2002-02-19 18:04:21 +00:00
|
|
|
} else {
|
2002-04-11 17:19:16 +00:00
|
|
|
if (gfxPrimitivesPolyAllocated < n) {
|
|
|
|
gfxPrimitivesPolyInts =
|
|
|
|
(int *)realloc(gfxPrimitivesPolyInts, sizeof(int) * n);
|
|
|
|
gfxPrimitivesPolyAllocated = n;
|
|
|
|
}
|
|
|
|
}
|
2002-02-19 18:04:21 +00:00
|
|
|
|
|
|
|
/* Determine Y maxima */
|
|
|
|
miny = vy[0];
|
|
|
|
maxy = vy[0];
|
2002-04-11 17:19:16 +00:00
|
|
|
for (i = 1; (i < n); i++) {
|
2002-02-19 18:04:21 +00:00
|
|
|
if (vy[i] < miny) {
|
2002-04-11 17:19:16 +00:00
|
|
|
miny = vy[i];
|
2002-02-19 18:04:21 +00:00
|
|
|
} else if (vy[i] > maxy) {
|
2002-04-11 17:19:16 +00:00
|
|
|
maxy = vy[i];
|
2002-02-19 18:04:21 +00:00
|
|
|
}
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-02-19 18:04:21 +00:00
|
|
|
/* Draw, scanning y */
|
2002-04-11 17:19:16 +00:00
|
|
|
result = 0;
|
|
|
|
for (y = miny; (y <= maxy); y++) {
|
2002-02-19 18:04:21 +00:00
|
|
|
ints = 0;
|
2002-04-11 17:19:16 +00:00
|
|
|
for (i = 0; (i < n); i++) {
|
2002-02-19 18:04:21 +00:00
|
|
|
if (!i) {
|
2002-04-11 17:19:16 +00:00
|
|
|
ind1 = n - 1;
|
2002-02-19 18:04:21 +00:00
|
|
|
ind2 = 0;
|
|
|
|
} else {
|
2002-04-11 17:19:16 +00:00
|
|
|
ind1 = i - 1;
|
2002-02-19 18:04:21 +00:00
|
|
|
ind2 = i;
|
|
|
|
}
|
|
|
|
y1 = vy[ind1];
|
|
|
|
y2 = vy[ind2];
|
|
|
|
if (y1 < y2) {
|
|
|
|
x1 = vx[ind1];
|
|
|
|
x2 = vx[ind2];
|
|
|
|
} else if (y1 > y2) {
|
|
|
|
y2 = vy[ind1];
|
|
|
|
y1 = vy[ind2];
|
|
|
|
x2 = vx[ind1];
|
|
|
|
x1 = vx[ind2];
|
|
|
|
} else {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if ((y >= y1) && (y < y2)) {
|
2002-04-11 17:19:16 +00:00
|
|
|
gfxPrimitivesPolyInts[ints++] = (y - y1) * (x2 - x1) / (y2 - y1) + x1;
|
2002-02-19 18:04:21 +00:00
|
|
|
} else if ((y == maxy) && (y > y1) && (y <= y2)) {
|
2002-04-11 17:19:16 +00:00
|
|
|
gfxPrimitivesPolyInts[ints++] = (y - y1) * (x2 - x1) / (y2 - y1) + x1;
|
2002-02-19 18:04:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
qsort(gfxPrimitivesPolyInts, ints, sizeof(int), gfxPrimitivesCompareInt);
|
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
for (i = 0; (i < ints); i += 2) {
|
|
|
|
result |=
|
|
|
|
hlineColor(dst, gfxPrimitivesPolyInts[i],
|
|
|
|
gfxPrimitivesPolyInts[i + 1], y, color);
|
2002-02-19 18:04:21 +00:00
|
|
|
}
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
|
|
|
|
return (result);
|
2002-02-19 18:04:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int gfxPrimitivesCompareInt(const void *a, const void *b)
|
|
|
|
{
|
2002-04-11 17:19:16 +00:00
|
|
|
return (*(const int *)a) - (*(const int *)b);
|
2002-02-19 18:04:21 +00:00
|
|
|
}
|
|
|
|
|
2002-04-12 10:34:46 +00:00
|
|
|
/* FIXME: What's the purpose of this function?
|
|
|
|
* Functions should start with a small letter.
|
|
|
|
*/
|
2002-04-11 17:19:16 +00:00
|
|
|
void BoxTest(int num)
|
|
|
|
{
|
2002-02-19 18:04:21 +00:00
|
|
|
BoxCoords box;
|
|
|
|
Sint16 rx1[4], ry1[4];
|
2002-04-11 17:19:16 +00:00
|
|
|
|
2002-04-12 10:34:46 +00:00
|
|
|
g_scumm->getBoxCoordinates(num, &box);
|
2002-04-11 17:19:16 +00:00
|
|
|
rx1[0] = box.ul.x * 2;
|
|
|
|
ry1[0] = box.ul.y * 2 + 32;
|
|
|
|
rx1[1] = box.ur.x * 2;
|
|
|
|
ry1[1] = box.ur.y * 2 + 32;
|
|
|
|
rx1[2] = box.ll.x * 2;
|
|
|
|
ry1[2] = box.ll.y * 2 + 32;
|
|
|
|
rx1[3] = box.lr.x * 2;
|
|
|
|
ry1[3] = box.lr.y * 2 + 32;
|
|
|
|
|
2002-02-19 18:04:21 +00:00
|
|
|
filledPolygonColor(screen, &rx1[0], &ry1[0], 4, 255);
|
2002-04-11 17:19:16 +00:00
|
|
|
SDL_UpdateRect(screen, 0, 0, 0, 0);
|
|
|
|
|
2002-02-19 18:04:21 +00:00
|
|
|
}
|
|
|
|
|
2002-04-12 10:34:46 +00:00
|
|
|
/* FIXME: 2xSAI Functions should be moved to a separate
|
|
|
|
* source file
|
|
|
|
*/
|
2002-03-10 07:48:01 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2002-03-21 00:40:18 +00:00
|
|
|
/********* ScummVM call back functions **********/
|
|
|
|
|
|
|
|
int OSystem::waitTick(int delta)
|
|
|
|
{
|
2002-04-11 17:19:16 +00:00
|
|
|
do {
|
2002-04-12 10:34:46 +00:00
|
|
|
updateScreen(g_scumm);
|
2002-03-24 00:44:28 +00:00
|
|
|
new_time = SDL_GetTicks();
|
2002-04-12 10:34:46 +00:00
|
|
|
waitForTimer(g_scumm, delta * 15 + last_time - new_time);
|
2002-03-24 00:44:28 +00:00
|
|
|
last_time = SDL_GetTicks();
|
2002-04-11 17:19:16 +00:00
|
|
|
if (gui._active) {
|
2002-04-12 10:34:46 +00:00
|
|
|
gui.loop(g_scumm);
|
2002-03-24 00:44:28 +00:00
|
|
|
delta = 5;
|
|
|
|
}
|
2002-04-11 17:19:16 +00:00
|
|
|
} while (gui._active);
|
2002-03-21 00:40:18 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
return (delta);
|
2002-03-21 00:40:18 +00:00
|
|
|
}
|
2002-03-25 22:46:32 +00:00
|
|
|
|
2002-04-11 17:19:16 +00:00
|
|
|
OSystem::OSystem()
|
|
|
|
{
|
2002-03-25 22:46:32 +00:00
|
|
|
last_time = SDL_GetTicks();
|
|
|
|
}
|