2015-12-04 12:32:08 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
|
|
|
*
|
|
|
|
* ScummVM is the legal property of its developers, whose names
|
|
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
|
|
* file distributed with this source distribution.
|
|
|
|
*
|
|
|
|
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This code is based on Labyrinth of Time code with assistance of
|
|
|
|
*
|
|
|
|
* Copyright (c) 1993 Terra Nova Development
|
|
|
|
* Copyright (c) 2004 The Wyrmkeep Entertainment Co.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2015-12-08 19:10:26 +00:00
|
|
|
#ifndef LAB_DISPMAN_H
|
|
|
|
#define LAB_DISPMAN_H
|
2015-12-04 12:32:08 +00:00
|
|
|
|
|
|
|
namespace Lab {
|
|
|
|
|
|
|
|
class LabEngine;
|
2015-12-08 19:46:13 +00:00
|
|
|
class Image;
|
2015-12-04 12:32:08 +00:00
|
|
|
|
2015-12-07 06:48:54 +00:00
|
|
|
struct TextFont {
|
|
|
|
uint32 _dataLength;
|
|
|
|
uint16 _height;
|
|
|
|
byte _widths[256];
|
|
|
|
uint16 _offsets[256];
|
|
|
|
byte *_data;
|
|
|
|
};
|
|
|
|
|
2015-12-07 07:58:46 +00:00
|
|
|
enum TransitionType {
|
|
|
|
kTransitionNone,
|
|
|
|
kTransitionWipe,
|
|
|
|
kTransitionScrollWipe,
|
|
|
|
kTransitionScrollBlack,
|
|
|
|
kTransitionScrollBounce,
|
|
|
|
kTransitionTransporter,
|
|
|
|
kTransitionReadFirstFrame,
|
|
|
|
kTransitionReadNextFrame
|
|
|
|
};
|
|
|
|
|
2015-12-04 12:32:08 +00:00
|
|
|
class DisplayMan {
|
|
|
|
private:
|
|
|
|
LabEngine *_vm;
|
|
|
|
|
2015-12-20 00:55:19 +00:00
|
|
|
/**
|
|
|
|
* Does the fading of the Palette on the screen.
|
|
|
|
*/
|
2015-12-06 17:16:26 +00:00
|
|
|
uint16 fadeNumIn(uint16 num, uint16 res, uint16 counter);
|
|
|
|
uint16 fadeNumOut(uint16 num, uint16 res, uint16 counter);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Extracts the first word from a string.
|
|
|
|
*/
|
2015-12-20 00:21:06 +00:00
|
|
|
Common::String getWord(const char *mainBuffer);
|
2015-12-06 17:16:26 +00:00
|
|
|
|
2015-12-26 13:26:33 +00:00
|
|
|
void createBox(uint16 y2);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
2015-12-26 13:26:33 +00:00
|
|
|
* Sets up either a low-res or a high-res 256 color screen.
|
2015-12-20 00:55:19 +00:00
|
|
|
*/
|
2015-12-26 13:26:33 +00:00
|
|
|
void createScreen(bool hiRes);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Scrolls the display to black.
|
|
|
|
*/
|
2015-12-04 12:32:08 +00:00
|
|
|
void doScrollBlack();
|
|
|
|
void copyPage(uint16 width, uint16 height, uint16 nheight, uint16 startline, byte *mem);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Scrolls the display to a new picture from a black screen.
|
|
|
|
*/
|
2015-12-20 16:21:55 +00:00
|
|
|
void doScrollWipe(const Common::String filename);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Does the scroll bounce. Assumes bitmap already in memory.
|
|
|
|
*/
|
2015-12-04 12:32:08 +00:00
|
|
|
void doScrollBounce();
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Does the transporter wipe.
|
|
|
|
*/
|
2015-12-26 13:18:44 +00:00
|
|
|
void doTransWipe(const Common::String filename);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
2015-12-26 13:26:33 +00:00
|
|
|
/**
|
|
|
|
* Draws a vertical line.
|
|
|
|
*/
|
|
|
|
void drawHLine(uint16 x, uint16 y1, uint16 y2, byte color);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Draws a horizontal line.
|
|
|
|
*/
|
|
|
|
void drawVLine(uint16 x1, uint16 y, uint16 x2, byte color);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Draws the text to the screen.
|
|
|
|
*/
|
|
|
|
void drawText(TextFont *tf, uint16 x, uint16 y, uint16 color, const Common::String text);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a line of text for flowText; makes sure that its length is less than
|
|
|
|
* or equal to the maximum width.
|
|
|
|
*/
|
|
|
|
Common::String getLine(TextFont *tf, const char **mainBuffer, uint16 lineWidth);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the length of a text in the specified font.
|
|
|
|
*/
|
|
|
|
uint16 textLength(TextFont *font, const Common::String text);
|
|
|
|
|
|
|
|
bool _actionMessageShown;
|
|
|
|
Common::File *_curBitmap;
|
|
|
|
byte _curVgaPal[256 * 3];
|
|
|
|
byte *_currentDisplayBuffer;
|
|
|
|
|
|
|
|
public:
|
|
|
|
DisplayMan(LabEngine *lab);
|
|
|
|
virtual ~DisplayMan();
|
|
|
|
|
|
|
|
void loadPict(const Common::String filename);
|
|
|
|
void loadBackPict(const Common::String fileName, uint16 *highPal);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads in a picture into the display bitmap.
|
|
|
|
*/
|
|
|
|
void readPict(const Common::String filename, bool playOnce = true, bool onlyDiffData = false, byte *memoryBuffer = nullptr);
|
|
|
|
void freePict();
|
|
|
|
|
2015-12-20 00:55:19 +00:00
|
|
|
/**
|
|
|
|
* Does a certain number of pre-programmed wipes.
|
|
|
|
*/
|
2015-12-26 13:18:44 +00:00
|
|
|
void doTransition(TransitionType transitionType, const Common::String filename);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Changes the front screen to black.
|
|
|
|
*/
|
2015-12-04 12:32:08 +00:00
|
|
|
void blackScreen();
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Changes the front screen to white.
|
|
|
|
*/
|
2015-12-04 12:32:08 +00:00
|
|
|
void whiteScreen();
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Changes the entire screen to black.
|
|
|
|
*/
|
2015-12-04 12:32:08 +00:00
|
|
|
void blackAllScreen();
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Draws the control panel display.
|
|
|
|
*/
|
2015-12-04 12:32:08 +00:00
|
|
|
void drawPanel();
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets up the Labyrinth screens, and opens up the initial windows.
|
|
|
|
*/
|
2015-12-08 15:19:08 +00:00
|
|
|
void setUpScreens();
|
2015-12-23 02:19:59 +00:00
|
|
|
|
2015-12-23 22:06:10 +00:00
|
|
|
int longDrawMessage(Common::String str, bool isActionMessage);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Draws a message to the message box.
|
|
|
|
*/
|
2015-12-23 02:19:59 +00:00
|
|
|
void drawMessage(Common::String str, bool isActionMessage);
|
|
|
|
|
|
|
|
void setActionMessage(bool val) { _actionMessageShown = val; }
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Fills in a rectangle.
|
|
|
|
*/
|
2015-12-24 10:08:51 +00:00
|
|
|
void rectFill(uint16 x1, uint16 y1, uint16 x2, uint16 y2, byte color);
|
|
|
|
void rectFill(Common::Rect fillRect, byte color);
|
|
|
|
void rectFillScaled(uint16 x1, uint16 y1, uint16 x2, uint16 y2, byte color);
|
2015-12-20 00:55:19 +00:00
|
|
|
/**
|
|
|
|
* Dumps a chunk of text to an arbitrary box; flows it within that box and
|
|
|
|
* optionally centers it. Returns the number of characters that were processed.
|
|
|
|
* @note Every individual word MUST be int16 enough to fit on a line, and
|
|
|
|
* each line less than 255 characters.
|
|
|
|
* @param font Pointer on the font used
|
|
|
|
* @param spacing How much vertical spacing between the lines
|
|
|
|
* @param penColor Pen number to use for text
|
|
|
|
* @param backPen Background color
|
|
|
|
* @param fillBack Whether to fill the background
|
|
|
|
* @param centerh Whether to center the text horizontally
|
|
|
|
* @param centerv Whether to center the text vertically
|
|
|
|
* @param output Whether to output any text
|
|
|
|
* @param textRect Coords
|
|
|
|
* @param text The text itself
|
|
|
|
*/
|
|
|
|
int flowText(TextFont *font, int16 spacing, byte penColor, byte backPen, bool fillBack,
|
2015-12-24 10:27:56 +00:00
|
|
|
bool centerh, bool centerv, bool output, Common::Rect textRect, const char *text, Image *targetImage = nullptr);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
2015-12-04 12:32:08 +00:00
|
|
|
void screenUpdate();
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
2015-12-23 20:04:03 +00:00
|
|
|
* Converts a 16-color Amiga palette to a VGA palette, then sets
|
2015-12-20 00:55:19 +00:00
|
|
|
* the VGA palette.
|
|
|
|
*/
|
2015-12-23 20:04:03 +00:00
|
|
|
void setAmigaPal(uint16 *pal);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Writes any number of the 256 color registers.
|
|
|
|
* @param buf A char pointer which contains the selected color registers.
|
|
|
|
* Each value representing a color register occupies 3 bytes in the array. The
|
|
|
|
* order is red, green then blue. The first byte in the array is the red component
|
|
|
|
* of the first element selected. The length of the buffer is 3 times the number
|
|
|
|
* of registers selected.
|
|
|
|
* @param first The number of the first color register to write.
|
|
|
|
* @param numReg The number of registers to write.
|
|
|
|
*/
|
2015-12-14 11:40:19 +00:00
|
|
|
void writeColorRegs(byte *buf, uint16 first, uint16 numReg);
|
2015-12-14 21:50:09 +00:00
|
|
|
void setPalette(void *newPal, uint16 numColors);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Overlays a region on the screen using the desired pen color.
|
|
|
|
*/
|
2015-12-26 13:26:33 +00:00
|
|
|
void checkerBoardEffect(uint16 penColor, uint16 x1, uint16 y1, uint16 x2, uint16 y2);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the base address of the current VGA display.
|
|
|
|
*/
|
2015-12-06 13:36:49 +00:00
|
|
|
byte *getCurrentDrawingBuffer();
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Scrolls the display in the x direction by blitting.
|
|
|
|
* The _tempScrollData variable must be initialized to some memory, or this
|
|
|
|
* function will fail.
|
|
|
|
*/
|
2015-12-08 23:41:51 +00:00
|
|
|
void scrollDisplayX(int16 dx, uint16 x1, uint16 y1, uint16 x2, uint16 y2, byte *buffer);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Scrolls the display in the y direction by blitting.
|
|
|
|
*/
|
2015-12-08 23:41:51 +00:00
|
|
|
void scrollDisplayY(int16 dy, uint16 x1, uint16 y1, uint16 x2, uint16 y2, byte *buffer);
|
2015-12-23 22:41:53 +00:00
|
|
|
void fade(bool fadein);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Closes a font and frees all memory associated with it.
|
|
|
|
*/
|
2015-12-24 16:30:54 +00:00
|
|
|
void freeFont(TextFont **font);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the height of a specified font.
|
|
|
|
*/
|
2015-12-07 06:48:54 +00:00
|
|
|
uint16 textHeight(TextFont *tf);
|
2015-12-20 00:55:19 +00:00
|
|
|
|
2015-12-04 19:18:41 +00:00
|
|
|
bool _longWinInFront;
|
|
|
|
bool _lastMessageLong;
|
|
|
|
uint32 _screenBytesPerPage;
|
2015-12-06 13:36:49 +00:00
|
|
|
int _screenWidth;
|
|
|
|
int _screenHeight;
|
|
|
|
byte *_displayBuffer;
|
2015-12-14 07:59:16 +00:00
|
|
|
uint16 *_fadePalette;
|
2015-12-04 12:32:08 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // End of namespace Lab
|
|
|
|
|
2015-12-08 19:10:26 +00:00
|
|
|
#endif // LAB_DISPMAN_H
|