ScummVM API documentation
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
scumm.h
1 /* ScummVM - Graphic Adventure Engine
2  *
3  * ScummVM is the legal property of its developers, whose names
4  * are too numerous to list here. Please refer to the COPYRIGHT
5  * file distributed with this source distribution.
6  *
7  * This program is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation, either version 3 of the License, or
10  * (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program. If not, see <http://www.gnu.org/licenses/>.
19  *
20  */
21 
22 #ifndef SCUMM_SCUMM_H
23 #define SCUMM_SCUMM_H
24 
25 #include "engines/engine.h"
26 
27 #include "common/endian.h"
28 #include "common/events.h"
29 #include "common/file.h"
30 #include "common/savefile.h"
31 #include "common/keyboard.h"
32 #include "common/mutex.h"
33 #include "common/random.h"
34 #include "common/rect.h"
35 #include "common/rendermode.h"
36 #include "common/serializer.h"
37 #include "common/str.h"
38 #include "common/textconsole.h"
39 #include "graphics/surface.h"
40 #include "graphics/sjis.h"
41 #include "graphics/palette.h"
42 
43 #include "scumm/file.h"
44 #include "scumm/gfx.h"
45 #include "scumm/detection.h"
46 #include "scumm/script.h"
47 
48 #ifdef __DS__
49 /* This disables the dual layer mode which is used in FM-Towns versions
50  * of SCUMM games and which emulates the behavior of the original code.
51  * The only purpose is code size reduction for certain backends.
52  * SCUMM 3 (FM-Towns) games will run in English in normal (DOS VGA) mode,
53  * which should work just fine in most situations. Some glitches might
54  * occur. Japanese mode and SCUMM 5 FM-Towns games will not work without
55  * dual layer (and 16 bit color) support.
56  */
57 #define DISABLE_TOWNS_DUAL_LAYER_MODE
58 #endif
59 
60 namespace GUI {
61 class Dialog;
62 }
63 using GUI::Dialog;
64 namespace Common {
65 class SeekableReadStream;
66 class WriteStream;
67 class SeekableWriteStream;
68 }
69 namespace Graphics {
70 class FontSJIS;
71 }
72 
85 namespace Scumm {
86 
87 class Actor;
88 class BaseCostumeLoader;
89 class BaseCostumeRenderer;
90 class BaseScummFile;
91 class CharsetRenderer;
92 class IMuse;
93 class IMuseDigital;
94 class MacGui;
95 class MusicEngine;
96 class Player_Towns;
97 class ScummEngine;
98 class ScummDebugger;
99 class Sound;
100 class Localizer;
101 class GlyphRenderer_v7;
102 
103 struct Box;
104 struct BoxCoords;
105 struct FindObjectInRoom;
106 
107 // Use g_scumm from error() ONLY
108 extern ScummEngine *g_scumm;
109 
110 /* System Wide Constants */
111 enum {
112  NUM_SENTENCE = 6,
113  NUM_SHADOW_PALETTE = 8
114 };
115 
116 /* SCUMM Debug Channels */
117 void debugC(int level, MSVC_PRINTF const char *s, ...) GCC_PRINTF(2, 3);
118 
119 struct VerbSlot;
120 struct ObjectData;
121 
122 enum {
130 
136 
143 
152  //
153 };
154 
155 enum {
156  MBS_LEFT_CLICK = 0x8000,
157  MBS_RIGHT_CLICK = 0x4000,
158  MBS_MOUSE_MASK = (MBS_LEFT_CLICK | MBS_RIGHT_CLICK),
159  MBS_MAX_KEY = 0x0200
160 };
161 
162 struct SentenceTab {
163  byte verb;
164  byte preposition;
165  uint16 objectA;
166  uint16 objectB;
167  uint8 freezeCount;
168 };
169 
170 struct StringSlot {
171  int16 xpos;
172  int16 ypos;
173  int16 right;
174  int16 height;
175  byte color;
176  byte charset;
177  bool center;
178  bool overhead;
179  bool no_talk_anim;
180  bool wrapping;
181 };
182 
184  // The 'default' values for this string slot. This is used so that the
185  // string slot can temporarily be set to different values, and then be
186  // easily reset to a previously set default.
187  StringSlot _default;
188 
189  void saveDefault() {
190  StringSlot &s = *this;
191  _default = s;
192  }
193 
194  void loadDefault() {
195  StringSlot &s = *this;
196  s = _default;
197  }
198 };
199 
201  bool _screenScroll;
202  uint _objectRedrawCount;
203  uint _objectStripRedrawCount;
204  uint _actorRedrawCount;
205  uint _actorLimbRedrawDrawCount;
206 
207 };
208 
209 enum WhereIsObject {
210  WIO_NOT_FOUND = -1,
211  WIO_INVENTORY = 0,
212  WIO_ROOM = 1,
213  WIO_GLOBAL = 2,
214  WIO_LOCAL = 3,
215  WIO_FLOBJECT = 4
216 };
217 
219  uint32 date;
220  uint16 time;
221  uint32 playtime;
222 };
223 
224 enum UserStates {
225  USERSTATE_SET_FREEZE = 0x01, // freeze scripts if USERSTATE_FREEZE_ON is set, unfreeze otherwise
226  USERSTATE_SET_CURSOR = 0x02, // shows cursor if USERSTATE_CURSOR_ON is set, hides it otherwise
227  USERSTATE_SET_IFACE = 0x04, // change user-interface (sentence-line, inventory, verb-area)
228  USERSTATE_FREEZE_ON = 0x08, // only interpreted if USERSTATE_SET_FREEZE is set
229  USERSTATE_CURSOR_ON = 0x10, // only interpreted if USERSTATE_SET_CURSOR is set
230  USERSTATE_IFACE_SENTENCE = 0x20, // only interpreted if USERSTATE_SET_IFACE is set
231  USERSTATE_IFACE_INVENTORY = 0x40, // only interpreted if USERSTATE_SET_IFACE is set
232  USERSTATE_IFACE_VERBS = 0x80 // only interpreted if USERSTATE_SET_IFACE is set
233 };
234 
235 #define USERSTATE_IFACE_ALL (USERSTATE_IFACE_SENTENCE | USERSTATE_IFACE_INVENTORY | USERSTATE_IFACE_VERBS)
236 
242 enum ResType {
243  rtInvalid = 0,
244  rtFirst = 1,
245  rtRoom = 1,
246  rtScript = 2,
247  rtCostume = 3,
248  rtSound = 4,
249  rtInventory = 5,
250  rtCharset = 6,
251  rtString = 7,
252  rtVerb = 8,
253  rtActorName = 9,
254  rtBuffer = 10,
255  rtScaleTable = 11,
256  rtTemp = 12,
257  rtFlObject = 13,
258  rtMatrix = 14,
259  rtBox = 15,
260  rtObjectName = 16,
261  rtRoomScripts = 17,
262  rtRoomImage = 18,
263  rtImage = 19,
264  rtTalkie = 20,
265  rtSpoolBuffer = 21,
266  rtLast = 21
267 };
268 
269 typedef uint16 ResId;
270 
271 class ResourceManager;
272 
313 #define PIT_BASE_FREQUENCY 1193182.0 // In Hz
314 #define PIT_V1_DIVISOR 65536.0
315 #define PIT_V2_4_DIVISOR 5041.0
316 #define PIT_V5_6_ORCHESTRATOR_DIVISOR 4096.0
317 #define PIT_V5_6_SUBTIMER_INC 3433.0
318 #define PIT_V5_SUBTIMER_THRESH 4167.0
319 #define PIT_V6_SAMNMAX_SUBTIMER_THRESH 4167.0
320 #define PIT_V6_DOTT_SUBTIMER_THRESH 4237.0
321 #define PIT_V7_ORCHESTRATOR_DIVISOR 3977.0
322 #define PIT_V7_SUBTIMER_INC 3977.0
323 #define PIT_V7_SUBTIMER_THRESH 4971.0
324 
325 #define LOOM_STEAM_CDDA_RATE 240.0
326 
340 #define AMIGA_NTSC_VBLANK_RATE 240.0
341 #define AMIGA_PAL_VBLANK_RATE 200.0
342 
347 #define GAME_PROPER_SAVE 201
348 #define GAME_FAILED_SAVE 202
349 #define GAME_PROPER_LOAD 203
350 #define GAME_FAILED_LOAD 204
351 
356 #define GUI_PAGE_MAIN 0
357 #define GUI_PAGE_SAVE 1
358 #define GUI_PAGE_LOAD 2
359 #define GUI_PAGE_RESTART 3 // Sega CD
360 #define GUI_PAGE_CODE_CONFIRM 4 // Sega CD
361 #define GUI_PAGE_INVALID_CODE 5 // Sega CD
362 
363 #define GUI_CTRL_FIRST_SG 1
364 #define GUI_CTRL_LAST_SG 9
365 #define GUI_CTRL_SAVE_BUTTON 10
366 #define GUI_CTRL_LOAD_BUTTON 11
367 #define GUI_CTRL_PLAY_BUTTON 12
368 #define GUI_CTRL_QUIT_BUTTON 13
369 #define GUI_CTRL_OK_BUTTON 14
370 #define GUI_CTRL_CANCEL_BUTTON 15
371 #define GUI_CTRL_ARROW_UP_BUTTON 16
372 #define GUI_CTRL_ARROW_DOWN_BUTTON 17
373 #define GUI_CTRL_PATH_BUTTON 18
374 #define GUI_CTRL_MUSIC_SLIDER 19
375 #define GUI_CTRL_SPEECH_SLIDER 20
376 #define GUI_CTRL_SFX_SLIDER 21
377 #define GUI_CTRL_TEXT_SPEED_SLIDER 22
378 #define GUI_CTRL_DISPLAY_TEXT_CHECKBOX 23
379 #define GUI_CTRL_SPOOLED_MUSIC_CHECKBOX 24
380 #define GUI_CTRL_OUTER_BOX 26
381 #define GUI_CTRL_INNER_BOX 27
382 
383 // Sega CD
384 #define GUI_CTRL_NUMPAD_1 1
385 #define GUI_CTRL_NUMPAD_2 2
386 #define GUI_CTRL_NUMPAD_3 3
387 #define GUI_CTRL_NUMPAD_4 4
388 #define GUI_CTRL_NUMPAD_5 5
389 #define GUI_CTRL_NUMPAD_6 6
390 #define GUI_CTRL_NUMPAD_7 7
391 #define GUI_CTRL_NUMPAD_8 8
392 #define GUI_CTRL_NUMPAD_9 9
393 #define GUI_CTRL_NUMPAD_0 10
394 #define GUI_CTRL_RESTART_BUTTON 13
395 #define GUI_CTRL_ARROW_LEFT_BUTTON 16
396 #define GUI_CTRL_ARROW_RIGHT_BUTTON 17
397 #define GUI_CTRL_NUMPAD_BACK 23
398 
399 enum GUIString {
400  gsPause = 0,
401  gsVersion = 1,
402  gsTextSpeedSlider = 2,
403  gsRestart = 3,
404  gsQuitPrompt = 4,
405  gsSave = 5,
406  gsLoad = 6,
407  gsPlay = 7,
408  gsCancel = 8,
409  gsQuit = 9,
410  gsOK = 10,
411  gsMustName = 11,
412  gsGameNotSaved = 12,
413  gsGameNotLoaded = 13,
414  gsSaving = 14,
415  gsLoading = 15,
416  gsNamePrompt = 16,
417  gsSelectLoadPrompt = 17,
418  gsReplacePrompt = 18,
419  gsYes = 20,
420  gsNo = 21,
421  gsIMuseBuffer = 22,
422  gsVoiceAndText = 23,
423  gsTextDisplayOnly = 24,
424  gsVoiceOnly = 25,
425  gsYesKey = 26,
426  gsMusicVolumeSlider = 27,
427  gsVoiceVolumeSlider = 28,
428  gsSfxVolumeSlider = 29,
429  gsHeap = 30,
430  gsSavePath = 31,
431  gsTitle = 32,
432  gsDisabled = 33,
433  gsMusic = 34,
434  gsVoice = 35,
435  gsSfx = 36,
436  gsTextSpeed = 37,
437  gsDisplayText = 38,
438  gsSpooledMusic = 39,
439  gsInsertSaveDisk = 40,
440  gsSnapOn = 41,
441  gsSnapOff = 42,
442  gsRecalJoystick = 43,
443  gsMouseMode = 44,
444  gsMouseOn = 45,
445  gsMouseOff = 46,
446  gsJoystickOn = 47,
447  gsJoystickOff = 48,
448  gsSoundsOn = 49,
449  gsSoundsOff = 50,
450  gsVGAMode = 51,
451  gsEGAMode = 52,
452  gsCGAMode = 53,
453  gsHerculesMode = 54,
454  gsTandyMode = 55,
455  gsCurrentPasscode = 56,
456  gsEnterPasscode = 57,
457  gsConfirmPasscode = 58,
458  gsInvalidPasscode = 59,
459  gsSlowFast = 60,
460  gsRestartGame = 61,
461  gsHeapExt = 62,
462 };
463 
465  int relativeCenterX;
466  int relativeCenterY;
467  int xPos;
468  int yPos;
469  int normalFillColor;
470  int topLineColor;
471  int bottomLineColor;
472  int leftLineColor;
473  int rightLineColor;
474  int normalTextColor;
475  int highlightedTextColor;
476  int highlightedFillColor;
477  bool centerText;
478  Common::String label;
479  bool doubleLinesFlag;
480 };
481 
482 enum ScummAction {
483  kScummActionNone,
484  kScummActionInsaneDownLeft,
485  kScummActionInsaneDown,
486  kScummActionInsaneDownRight,
487  kScummActionInsaneLeft,
488  kScummActionInsaneRight,
489  kScummActionInsaneUpLeft,
490  kScummActionInsaneUp,
491  kScummActionInsaneUpRight,
492  kScummActionInsaneAttack,
493  kScummActionInsaneSwitch,
494  kScummActionInsaneCheat,
495 
496  kScummActionCount
497 };
498 
499 extern const char *const insaneKeymapId;
500 
504 class ScummEngine : public Engine, public Common::Serializable {
505  friend class ScummDebugger;
506  friend class CharsetRenderer;
507  friend class CharsetRendererClassic;
508  friend class CharsetRendererTownsClassic;
509  friend class ResourceManager;
510  friend class MacGuiImpl;
511  friend class MacIndy3Gui;
512  friend class MacLoomGui;
513  friend class MacV5Gui;
514  friend class MacV6Gui;
515  friend class LogicHEBasketball;
516 
517 public:
518  /* Put often used variables at the top.
519  * That results in a shorter form of the opcode
520  * on some architectures. */
521  IMuse *_imuse = nullptr;
522  IMuseDigital *_imuseDigital = nullptr;
523  MusicEngine *_musicEngine = nullptr;
524  Player_Towns *_townsPlayer = nullptr;
525  Sound *_sound = nullptr;
526 
527  VerbSlot *_verbs = nullptr;
528  ObjectData *_objs = nullptr;
529 
530  // Core variables
531  GameSettings _game;
532  uint8 _gameMD5[16];
533 
536 
538  Gdi *_gdi = nullptr;
539 
541  ResourceManager *_res = nullptr;
542  int _insideCreateResource = 0; // Counter for HE sound
543 
544  bool _useOriginalGUI = true;
545  bool _enableAudioOverride = false;
546  bool _enableCOMISong = false;
547  bool _isAmigaPALSystem = false;
548  bool _quitFromScriptCmd = false;
549  bool _isHE995 = false;
550  bool _enableHECompetitiveOnlineMods = false;
551 
552  Common::Keymap *_insaneKeymap;
553 
554 protected:
556 
557  bool _needsSoundUnpause = false;
558 
559 public:
560  // Constructor / Destructor
561  ScummEngine(OSystem *syst, const DetectorResult &dr);
562  ~ScummEngine() override;
563 
564  // Engine APIs
565  Common::Error init();
566  Common::Error go();
567  Common::Error run() override {
568  Common::Error err;
569  err = init();
570  if (err.getCode() != Common::kNoError)
571  return err;
572  return go();
573  }
574 
575  void errorString(const char *buf_input, char *buf_output, int buf_output_size) override;
576  bool hasFeature(EngineFeature f) const override;
577  bool gameSupportsQuitDialogOverride() const;
578  void syncSoundSettings() override;
579 
580  Common::Error loadGameState(int slot) override;
581  bool canLoadGameStateCurrently(Common::U32String *msg = nullptr) override;
582  Common::Error saveGameState(int slot, const Common::String &desc, bool isAutosave = false) override;
583  bool canSaveGameStateCurrently(Common::U32String *msg = nullptr) override;
584 
585  void pauseEngineIntern(bool pause) override;
586 
587 protected:
588  virtual void setupScumm(const Common::Path &macResourceFile);
589  virtual void resetScumm();
590 
591  virtual void setupScummVars();
592  virtual void resetScummVars();
593  void setVideoModeVarToCurrentConfig();
594  void setSoundCardVarToCurrentConfig();
595 
596  void setupCharsetRenderer(const Common::Path &macFontFile);
597  void setupCostumeRenderer();
598 
599  virtual void loadLanguageBundle();
600  void loadCJKFont();
601  void loadKorFont();
602  void setupMusic(int midi);
603  void setTalkSpeed(int talkspeed);
604  int getTalkSpeed();
605 
606  // Scumm main loop & helper functions.
607  virtual void scummLoop(int delta);
608  virtual void scummLoop_updateScummVars();
609  virtual void scummLoop_handleSaveLoad();
610  virtual void scummLoop_handleDrawing();
611  virtual void scummLoop_handleActors() = 0;
612  virtual void scummLoop_handleEffects();
613  virtual void scummLoop_handleSound();
614 
615  virtual void runBootscript();
616 
617  virtual void terminateSaveMenuScript() {};
618 
619  // Event handling
620 public:
621  void beginTextInput();
622  void endTextInput();
623 
624  void parseEvents(); // Used by IMuseDigital::startSound
625 protected:
626  virtual void parseEvent(Common::Event event);
627 
628  void waitForTimer(int quarterFrames, bool freezeMacGui = false);
629  uint32 _lastWaitTime;
630 
631  void setTimerAndShakeFrequency();
632 
638  uint32 getIntegralTime(double fMsecs);
639  double _msecFractParts = 0.0;
640 
641  virtual void processInput();
642  virtual void processKeyboard(Common::KeyState lastKeyHit);
643  virtual void clearClickedStatus();
644 
645  // Cursor/palette
646  virtual void updateCursor();
647  virtual void animateCursor() {}
648  virtual void updatePalette();
649  virtual void setDefaultCursor() {};
650  virtual void setCursorTransparency(int a) {};
651  virtual void resetCursors() {}
652  virtual void setCursorHotspot(int x, int y) {}
653  virtual void setCursorFromBuffer(const byte *ptr, int width, int height, int pitch, bool preventScale = false) {}
654 
655 public:
656  void pauseGame();
657  void restart();
658  bool isUsingOriginalGUI() const;
659  bool isMessageBannerActive(); // For Indy4 Jap character shadows
660 
661  bool _isIndy4Jap = false;
662 
663 protected:
664  Dialog *_pauseDialog = nullptr;
665  Dialog *_messageDialog = nullptr;
666  Dialog *_versionDialog = nullptr;
667 
668  void confirmExitDialog();
669  void confirmRestartDialog();
670  void pauseDialog();
671  void messageDialog(const Common::U32String &message);
672  void versionDialog();
673 
674  // Original GUI
675  int32 _bannerColors[50]; // Colors for the original GUI
676  byte *_bannerMem = nullptr;
677  uint32 _bannerMemSize = 0;
678  int _bannerSaveYStart = 0;
679 
680  bool _messageBannerActive = false;
681  bool _comiQuitMenuIsOpen = false;
682  bool _closeBannerAndQueryQuitFlag = false;
683 
684  // The followings are needed for MI1 FM-Towns
685  byte *_textSurfBannerMem = nullptr;
686  uint32 _textSurfBannerMemSize = 0;
687 
688  InternalGUIControl _internalGUIControls[30];
689 
690  // Special GUI strings
691  const char _emptyMsg[1] = {'\0'};
692  const char _uncheckedBox[2] = {' ', '\0'};
693  const char _checkedBox[2] = {'x', '\0'};
694  const char _arrowUp[2] = {'\x18', '\0'};
695  const char _arrowDown[2] = {'\x19', '\0'};
696  const char _arrowLeft[2] = {'\x3c', '\0'};
697  const char _arrowRight[2] = {'\x3d', '\0'};
698 
699  Common::StringArray _savegameNames;
700  int _menuPage = 0;
701  int _mainMenuSavegameLabel = 1;
702  int _curDisplayedSaveSlotPage = 0;
703  int _firstSaveStateOfList = 0; // For LOOM VGA
704  bool _mainMenuIsActive = false;
705  bool _quitByGUIPrompt = false;
706  char _mainMenuMusicSlider[17];
707  char _mainMenuSpeechSlider[17];
708  char _mainMenuSfxSlider[17];
709  char _mainMenuTextSpeedSlider[17];
710  char _mainMenuSegaCDPasscode[5];
711  int _spooledMusicIsToBeEnabled = 1;
712  int _saveScriptParam = 0;
713  int _guiCursorAnimCounter = 0;
714  int _v5VoiceMode = 0;
715 
716  // Fake flags just for sub v5 GUIs
717  int _internalSpeakerSoundsAreOn = 1;
718  int _guiMouseFlag = 1;
719  int _guiJoystickFlag = 1;
720 
721  bool _mixerMutedByGUI = false;
722 
723  Graphics::Surface _savegameThumbnail;
724  byte *_tempTextSurface = nullptr;
725  byte *_tempMainSurface = nullptr;
726  byte *_tempVerbSurface = nullptr;
727  bool _postGUICharMask = false;
728 
729  // Saved cursor pre and post GUI
730  byte *_curGrabbedCursor = nullptr;
731  int8 _oldCursorState = 0;
732  int _curCursorState = 0;
733  int _curCursorWidth = 0;
734  int _curCursorHeight = 0;
735  int _curCursorHotspotX = 0;
736  int _curCursorHotspotY = 0;
737 
738  virtual void setSnailCursor() {}
739 
740  void initBanners();
741  Common::KeyState showBannerAndPause(int bannerId, int32 waitTime, const char *msg, ...);
742  Common::KeyState showOldStyleBannerAndPause(const char *msg, int color, int32 waitTime);
743  Common::KeyState printMessageAndPause(const char *msg, int color, int32 waitTime, bool drawOnSentenceLine);
744 
745  void clearBanner();
746  void setBannerColors(int bannerId, byte r, byte g, byte b);
747  virtual int getBannerColor(int bannerId);
748  void setUpInternalGUIControl(int id, int normalFillColor, int normalTextColor,
749  int topLineColor, int bottomLineColor, int leftLineColor, int rightLineColor,
750  int highlightedTextColor, int highlightedFillColor,
751  int anchorPointX, int anchorPointY, int x, int y, const char *label, bool centerFlag, bool unknownFlag);
752  void drawInternalGUIControl(int id, bool highlightColor);
753  int getInternalGUIControlFromCoordinates(int x, int y);
754  virtual bool isSmushActive() { return false; }
755  virtual bool isInsaneActive() { return false; }
756 
757  virtual void queryQuit(bool returnToLauncher);
758  virtual void queryRestart();
759  virtual const char *getGUIString(int stringId);
760  void waitForBannerInput(int32 waitTime, Common::KeyState &ks, bool &leftBtnClicked, bool &rightBtnClicked, bool handleMouseWheel = false);
761  virtual int getGUIStringHeight(const char *str);
762  virtual int getGUIStringWidth(const char *str);
763  virtual void drawGUIText(const char *buttonString, Common::Rect *clipRect, int textXPos, int textYPos, int textColor, bool centerFlag);
764  void getSliderString(int stringId, int value, char *sliderString, int size);
765  virtual int getMusicVolume();
766  virtual int getSpeechVolume();
767  virtual int getSFXVolume();
768  virtual void setMusicVolume(int volume);
769  virtual void setSpeechVolume(int volume);
770  virtual void setSFXVolume(int volume);
771  virtual void toggleVoiceMode();
772  virtual void handleLoadDuringSmush() {}
773  virtual void setSkipVideo(int value) {}
774 
775  void showMainMenu();
776  virtual void setUpMainMenuControls();
777  void setUpMainMenuControlsSegaCD();
778  void setUpMainMenuControlsIndy4Jap();
779  void drawMainMenuControls();
780  void drawMainMenuControlsSegaCD();
781  void updateMainMenuControls();
782  void updateMainMenuControlsSegaCD();
783  void drawMainMenuTitle(const char *title);
784  bool executeMainMenuOperation(int op, int mouseX, int mouseY, bool &hasLoadedState);
785  bool executeMainMenuOperationSegaCD(int op, int mouseX, int mouseY, bool &hasLoadedState);
786  bool shouldHighlightLabelAndWait(int clickedControl);
787  void fillSavegameLabels();
788  bool canWriteGame(int slotId);
789  bool userWriteLabelRoutine(Common::KeyState &ks, bool &leftMsClicked, bool &rightMsClicked);
790  void saveCursorPreMenu();
791  void restoreCursorPostMenu();
792  void saveSurfacesPreGUI();
793  void restoreSurfacesPostGUI();
794  void showDraftsInventory();
795  void setUpDraftsInventory();
796  void drawDraftsInventory();
797 
798 public:
799  char displayMessage(const char *altButton, MSVC_PRINTF const char *message, ...) GCC_PRINTF(3, 4);
800  bool displayMessageYesNo(MSVC_PRINTF const char *message, ...) GCC_PRINTF(2, 3);
801 
802 protected:
803  byte _fastMode = 0;
804 
805  byte _numActors = 0;
806  Actor **_actors = nullptr; // Has _numActors elements
807  Actor **_sortedActors = nullptr;
808 
809  byte *_arraySlot = nullptr;
810  uint16 *_inventory = nullptr;
811  uint16 *_newNames = nullptr;
812 public:
813  // VAR is a wrapper around scummVar, which attempts to include additional
814  // useful information should an illegal var access be detected.
815  #define VAR(x) scummVar(x, #x, __FILE__, __LINE__)
816  int32& scummVar(byte var, const char *varName, const char *file, int line) {
817  if (var == 0xFF) {
818  error("Illegal access to variable %s in file %s, line %d", varName, file, line);
819  }
820  return _scummVars[var];
821  }
822  int32 scummVar(byte var, const char *varName, const char *file, int line) const {
823  if (var == 0xFF) {
824  error("Illegal access to variable %s in file %s, line %d", varName, file, line);
825  }
826  return _scummVars[var];
827  }
828 
829 protected:
830  int16 _varwatch = 0;
831  int32 *_roomVars = nullptr;
832  int32 *_scummVars = nullptr;
833  byte *_bitVars = nullptr;
834 
835  /* Global resource tables */
836  int _numVariables = 0;
837  int _numBitVariables = 0;
838  int _numLocalObjects = 0;
839  int _numGlobalObjects = 0;
840  int _numArray = 0;
841  int _numVerbs = 0;
842  int _numFlObject = 0;
843  int _numInventory = 0;
844  int _numNewNames = 0;
845  int _numGlobalScripts = 0;
846  int _numRoomVariables = 0;
847  int _numPalettes = 0;
848  int _numSprites = 0;
849  int _numTalkies = 0;
850  int _numUnk = 0;
851  int _HEHeapSize = 0;
852 
853 public:
854  int _numLocalScripts = 60, _numImages = 0, _numRooms = 0, _numScripts = 0, _numSounds = 0; // Used by HE games
855  int _numCostumes = 0; // FIXME - should be protected, used by Actor::remapActorPalette
856  int32 _numCharsets = 0; // FIXME - should be protected, used by CharsetRenderer
857 
858  BaseCostumeLoader *_costumeLoader = nullptr;
859  BaseCostumeRenderer *_costumeRenderer = nullptr;
860 
861  int _NESCostumeSet = 0;
862  void NES_loadCostumeSet(int n);
863  byte *_NEScostdesc = nullptr, *_NEScostlens = nullptr, *_NEScostoffs = nullptr, *_NEScostdata = nullptr;
864  byte _NESPatTable[2][4096];
865  byte _NESPalette[2][16];
866  byte _NESBaseTiles = 0;
867 
868  int _NESStartStrip = 0;
869 
870 protected:
871  int _curPalIndex = 0;
872 
873 public:
874  byte _currentRoom = 0; // FIXME - should be protected but Actor::isInCurrentRoom uses it
875  int _roomResource = 0; // FIXME - should be protected but Sound::pauseSounds uses it
876  bool _egoPositioned = false; // Used by Actor::putActor, hence public
877 
878  FilenamePattern _filenamePattern;
879 
880  virtual Common::Path generateFilename(const int room) const;
881 
882 protected:
883  Common::KeyState _keyPressed;
884  bool _keyDownMap[512]; // FIXME - 512 is a guess. it's max(kbd.ascii)
885  bool _actionMap[kScummActionCount];
886 
887  Common::Point _mouse;
888  Common::Point _virtualMouse;
889 
890  uint16 _mouseAndKeyboardStat = 0;
891  byte _leftBtnPressed = 0, _rightBtnPressed = 0;
892 
893  int _mouseWheelFlag = 0; // For original save/load dialog only
894 
895  bool _setupIsComplete = false;
896 
901  uint32 _lastInputScriptTime = 0;
902 
904  int _bootParam = 0;
905 
906  // Various options useful for debugging
907  bool _dumpScripts = false;
908  bool _hexdumpScripts = false;
909  bool _showStack = false;
910  bool _debugMode = false;
911 
912  // Save/Load class - some of this may be GUI
913  byte _saveLoadFlag = 0, _saveLoadSlot = 0;
914  uint32 _lastSaveTime = 0;
915  bool _saveTemporaryState = false;
916  bool _pauseSoundsDuringSave = true;
917  bool _loadFromLauncher = false;
918  bool _videoModeChanged = false;
919  Common::String _saveLoadFileName;
920  Common::String _saveLoadDescription;
921 
922  bool saveState(Common::WriteStream *out, bool writeHeader = true);
923  bool saveState(int slot, bool compat, Common::String &fileName);
924  bool loadState(int slot, bool compat);
925  bool loadState(int slot, bool compat, Common::String &fileName);
926  void saveLoadWithSerializer(Common::Serializer &s) override;
927  void saveResource(Common::Serializer &ser, ResType type, ResId idx);
928  void loadResource(Common::Serializer &ser, ResType type, ResId idx);
929  void loadResourceOLD(Common::Serializer &ser, ResType type, ResId idx); // "Obsolete"
930 
931  void copyHeapSaveGameToFile(int slot, const char *saveName);
932  bool changeSavegameName(int slot, char *newName);
933  virtual Common::SeekableReadStream *openSaveFileForReading(int slot, bool compat, Common::String &fileName);
934  virtual Common::SeekableWriteStream *openSaveFileForWriting(int slot, bool compat, Common::String &fileName);
935 
936  Common::String makeSavegameName(int slot, bool temporary) const {
937  return makeSavegameName(_targetName, slot, temporary);
938  }
939 
940  int getKeyState(int key);
941  int getActionState(ScummAction action);
942 
943 public:
944  static Common::String makeSavegameName(const Common::String &target, int slot, bool temporary);
945 
946  bool getSavegameName(int slot, Common::String &desc);
947  void listSavegames(bool *marks, int num);
948 
949  void requestSave(int slot, const Common::String &name);
950  void requestLoad(int slot);
951 
952  Common::String getTargetName() const { return _targetName; }
953  bool canPauseSoundsDuringSave() const { return _pauseSoundsDuringSave; }
954 
955 // thumbnail + info stuff
956 public:
957  static bool querySaveMetaInfos(const char *target, int slot, int heversion, Common::String &desc, Graphics::Surface *&thumbnail, SaveStateMetaInfos *&timeInfos);
958 
959 protected:
960  void saveInfos(Common::WriteStream *file);
961  static bool loadInfos(Common::SeekableReadStream *file, SaveStateMetaInfos *stuff);
962 
963  /* Script VM - should be in Script class */
964  uint32 _localScriptOffsets[1024];
965  const byte *_scriptPointer = nullptr;
966  const byte *_scriptOrgPointer = nullptr;
967  const byte * const *_lastCodePtr = nullptr;
968  byte _opcode = 0;
969  bool _debug = false;
970  byte _currentScript = 0xFF; // Let debug() work on init stage
971  int _scummStackPos = 0;
972  int _vmStack[256];
973 
974  char _engineVersionString[50];
975  char _dataFileVersionString[50];
976 
977  OpcodeEntry _opcodes[256];
978 
979  virtual void setupOpcodes() = 0;
980  void executeOpcode(byte i);
981  const char *getOpcodeDesc(byte i);
982 
983  void initializeLocals(int slot, int *vars);
984  int getScriptSlot();
985 
986  void startScene(int room, Actor *a, int b);
987  bool startManiac();
988 
989 public:
990  void runScript(int script, bool freezeResistant, bool recursive, int *lvarptr, int cycle = 0);
991  void stopScript(int script);
992  void nukeArrays(byte scriptSlot);
993 
994 protected:
995  void runObjectScript(int script, int entry, bool freezeResistant, bool recursive, int *vars, int slot = -1, int cycle = 0);
996  void runScriptNested(int script);
997  void executeScript();
998  void updateScriptPtr();
999  virtual void runInventoryScript(int i);
1000  virtual void runInventoryScriptEx(int i);
1001  virtual void checkAndRunSentenceScript();
1002  void runExitScript();
1003  void runEntryScript();
1004  void runQuitScript();
1005  void runAllScripts();
1006  void freezeScripts(int scr);
1007  void unfreezeScripts();
1008 
1009  bool isScriptInUse(int script) const;
1010  bool isRoomScriptRunning(int script) const;
1011  bool isScriptRunning(int script) const;
1012 
1013  void killAllScriptsExceptCurrent();
1014  void killScriptsAndResources();
1015  void decreaseScriptDelay(int amount);
1016 
1017  void stopObjectCode();
1018  void stopObjectScript(int script);
1019 
1020  void getScriptBaseAddress();
1021  void resetScriptPointer();
1022  int getVerbEntrypoint(int obj, int entry);
1023 
1024  void refreshScriptPointer();
1025  byte fetchScriptByte();
1026  virtual uint fetchScriptWord();
1027  virtual int fetchScriptWordSigned();
1028  uint fetchScriptDWord();
1029  int fetchScriptDWordSigned();
1030  void ignoreScriptWord() { fetchScriptWord(); }
1031  void ignoreScriptByte() { fetchScriptByte(); }
1032  void push(int a);
1033  int pop();
1034  virtual int readVar(uint var);
1035  virtual void writeVar(uint var, int value);
1036  // SCUMM 1/2
1037  virtual void resetSentence() {}
1038 
1039 protected:
1040  virtual void beginCutscene(int *args);
1041  virtual void endCutscene();
1042  void abortCutscene();
1043  void beginOverride();
1044  void endOverride();
1045 
1046  void copyScriptString(byte *dst);
1047  int resStrLen(const byte *src);
1048  void doSentence(int c, int b, int a);
1049 
1050  /* Should be in Resource class */
1051  BaseScummFile *_fileHandle = nullptr;
1052  uint32 _fileOffset = 0;
1053 public:
1056  Common::Path _macCursorFile;
1057 
1058  bool openFile(BaseScummFile &file, const Common::Path &filename, bool resourceFile = false);
1059  ScummFile *instantiateScummFile(bool indexPAKFiles = true);
1060 
1061 protected:
1062  int _resourceHeaderSize = 8;
1063  byte _resourceMapper[128];
1064  const byte *_resourceLastSearchBuf; // FIXME: need to put it to savefile?
1065  uint32 _resourceLastSearchSize; // FIXME: need to put it to savefile?
1066 
1067  virtual void allocateArrays();
1068  void openRoom(int room);
1069  void closeRoom();
1070  void deleteRoomOffsets();
1071  virtual void readRoomsOffsets();
1072  void askForDisk(const Common::Path &filename, int disknum);
1073  bool openResourceFile(const Common::Path &filename, byte encByte);
1074 
1075  void loadPtrToResource(ResType type, ResId idx, const byte *ptr);
1076  virtual int readResTypeList(ResType type);
1077 // void allocResTypeData(ResType type, uint32 tag, int num, int mode);
1078 // byte *createResource(int type, int index, uint32 size);
1079  int loadResource(ResType type, ResId idx);
1080 // void nukeResource(ResType type, ResId idx);
1081  int getResourceRoomNr(ResType type, ResId idx);
1082  virtual uint32 getResourceRoomOffset(ResType type, ResId idx);
1083 
1084 public:
1085  int getResourceSize(ResType type, ResId idx);
1086  byte *getResourceAddress(ResType type, ResId idx);
1087  virtual byte *getStringAddress(ResId idx);
1088  byte *getStringAddressVar(int i);
1089  void ensureResourceLoaded(ResType type, ResId idx);
1090 
1091 protected:
1092  Common::Mutex _resourceAccessMutex; // Used in getResourceSize(), getResourceAddress() and findResource()
1093  // to avoid race conditions between the audio thread of Digital iMUSE
1094  // and the main SCUMM thread
1095 
1096  int readSoundResource(ResId idx);
1097  int readSoundResourceSmallHeader(ResId idx);
1098  bool isResourceInUse(ResType type, ResId idx) const;
1099 
1100  virtual void setupRoomSubBlocks();
1101  virtual void resetRoomSubBlocks();
1102 
1103  virtual void clearRoomObjects();
1104  virtual void resetRoomObjects();
1105  virtual void resetRoomObject(ObjectData *od, const byte *room, const byte *searchptr = NULL);
1106 
1107  virtual void readArrayFromIndexFile();
1108  virtual void readMAXS(int blockSize) = 0;
1109  virtual void readGlobalObjects();
1110  virtual void readIndexFile();
1111  virtual void readIndexBlock(uint32 block, uint32 itemsize);
1112  virtual void loadCharset(int i);
1113  void nukeCharset(int i);
1114 
1115  int _lastLoadedRoom = 0;
1116 public:
1117  const byte *findResourceData(uint32 tag, const byte *ptr);
1118  const byte *findResource(uint32 tag, const byte *ptr);
1119  void applyWorkaroundIfNeeded(ResType type, int idx);
1120  bool verifyMI2MacBootScript();
1121  bool verifyMI2MacBootScript(byte *buf, int size);
1122  bool tryPatchMI1CannibalScript(byte *buf, int size);
1123 
1124  int getResourceDataSize(const byte *ptr) const;
1125  void dumpResource(const char *tag, int index, const byte *ptr, int length = -1);
1126 
1127 public:
1128  /* Should be in Object class */
1129  byte OF_OWNER_ROOM = 0;
1130  int getInventorySlot();
1131  int findInventory(int owner, int index);
1132  int getInventoryCount(int owner);
1133 
1134 protected:
1135  byte *_objectOwnerTable = nullptr, *_objectRoomTable = nullptr, *_objectStateTable = nullptr;
1136  int _numObjectsInRoom = 0;
1137 
1138 public:
1139  uint32 *_classData = nullptr;
1140 
1141 protected:
1142  void markObjectRectAsDirty(int obj);
1143  virtual void loadFlObject(uint object, uint room);
1144  void nukeFlObjects(int min, int max);
1145  int findFlObjectSlot();
1146  int findLocalObjectSlot();
1147  void addObjectToInventory(uint obj, uint room);
1148  void updateObjectStates();
1149 public:
1150  bool getClass(int obj, int cls) const; // Used in actor.cpp, hence public
1151 protected:
1152  void putClass(int obj, int cls, bool set);
1153  int getState(int obj);
1154  void putState(int obj, int state);
1155  void setObjectState(int obj, int state, int x, int y);
1156  int getOwner(int obj) const;
1157  void putOwner(int obj, int owner);
1158  void setOwnerOf(int obj, int owner);
1159  void clearOwnerOf(int obj);
1160  int getObjectRoom(int obj) const;
1161  virtual bool objIsActor(int obj);
1162  virtual int objToActor(int obj);
1163  virtual int actorToObj(int actor);
1164  int getObjX(int obj);
1165  int getObjY(int obj);
1166  void getObjectWidth(int object, int &width) { int x, y, dir; getObjectXYPos(object, x, y, dir, width); }
1167  void getObjectXYPos(int object, int &x, int &y) { int dir, width; getObjectXYPos(object, x, y, dir, width); }
1168  void getObjectXYPos(int object, int &x, int &y, int &dir) { int width; getObjectXYPos(object, x, y, dir, width); }
1169  void getObjectXYPos(int object, int &x, int &y, int &dir, int &width);
1170  int getObjOldDir(int obj);
1171  int getObjNewDir(int obj);
1172  int getObjectIndex(int object) const;
1173  int getObjectImageCount(int object);
1174  int whereIsObject(int object) const;
1175  int findObject(int x, int y);
1176  void findObjectInRoom(FindObjectInRoom *fo, byte findWhat, uint object, uint room);
1177 public:
1178  int getObjectOrActorWidth(int object, int &width); // Used in v4 and below
1179  int getObjectOrActorXY(int object, int &x, int &y); // Used in actor.cpp, hence public
1180  int getDist(int x, int y, int x2, int y2); // Also used in actor.cpp
1181 protected:
1182 
1183  int getObjActToObjActDist(int a, int b); // Not sure how to handle
1184  const byte *getObjOrActorName(int obj); // these three..
1185  void setObjectName(int obj);
1186 
1187  void addObjectToDrawQue(int object);
1188  void removeObjectFromDrawQue(int object);
1189  void clearDrawObjectQueue();
1190  void processDrawQue();
1191 
1192  virtual void clearDrawQueues();
1193 
1194  uint32 getOBCDOffs(int object) const;
1195  byte *getOBCDFromObject(int obj, bool v0CheckInventory = true);
1196  const byte *getOBIMFromObjectData(const ObjectData &od);
1197  const byte *getObjectImage(const byte *ptr, int state);
1198  virtual int getObjectIdFromOBIM(const byte *obim);
1199 
1200 protected:
1201  /* Should be in Verb class */
1202  uint16 _verbMouseOver = 0;
1203  int8 _userPut = 0;
1204  uint16 _userState = 0;
1205 
1206  virtual void handleMouseOver(bool updateInventory);
1207  virtual void redrawVerbs();
1208  virtual void checkExecVerbs();
1209 
1210  void verbMouseOver(int verb);
1211  int findVerbAtPos(int x, int y) const;
1212  virtual void drawVerb(int verb, int mode);
1213  virtual void runInputScript(int clickArea, int val, int mode);
1214  void restoreVerbBG(int verb);
1215  void drawVerbBitmap(int verb, int x, int y);
1216  int getVerbSlot(int id, int mode) const;
1217  void killVerb(int slot);
1218  void setVerbObject(uint room, uint object, uint verb);
1219 
1220 public:
1221  bool isValidActor(int id) const;
1222 
1223  /* Should be in Actor class */
1224  Actor *derefActor(int id, const char *errmsg = 0) const;
1225  Actor *derefActorSafe(int id, const char *errmsg) const;
1226 
1227 protected:
1228  void walkActors();
1229  void playActorSounds();
1230  void redrawAllActors();
1231  virtual void setActorRedrawFlags();
1232  void putActors();
1233  void showActors();
1234  void resetV1ActorTalkColor();
1235  virtual void resetActorBgs();
1236  virtual void processActors();
1237  void processUpperActors();
1238  virtual int getActorFromPos(int x, int y);
1239 
1240 public:
1241  /* Actor talking stuff */
1242  byte _actorToPrintStrFor = 0, _V1TalkingActor = 0;
1243  int _sentenceNum = 0;
1244  SentenceTab _sentence[NUM_SENTENCE];
1245  StringTab _string[6];
1246  byte _haveMsg = 0;
1247  int16 _talkDelay = 0;
1248  int _NES_lastTalkingActor = 0;
1249  int _NES_talkColor = 0;
1250 
1251  virtual void actorTalk(const byte *msg);
1252  void stopTalk();
1253  int getTalkingActor(); // Wrapper around VAR_TALK_ACTOR for V1 Maniac
1254  void setTalkingActor(int variable);
1255 
1256  // Generic costume code
1257  bool isCostumeInUse(int i) const;
1258 
1259 protected:
1260  /* Should be in Graphics class? */
1261  uint16 _screenB = 0, _screenH = 0;
1262 public:
1263  int _roomHeight = 0, _roomWidth = 0;
1264  int _screenHeight = 0, _screenWidth = 0;
1265  VirtScreen _virtscr[4]; // Virtual screen areas
1266  CameraData camera; // 'Camera' - viewport
1267  bool _cameraIsFrozen = false;
1268 
1269  int _screenStartStrip = 0, _screenEndStrip = 0;
1270  int _screenTop = 0;
1271  bool _forceBannerVirtScreen = false;
1272 
1273  // For Mac versions of 320x200 games:
1274  // these versions rendered at 640x480 without any aspect ratio correction;
1275  // in order to correctly display the games as they should be, we perform some
1276  // offset corrections within the various rendering pipelines.
1277  //
1278  // The only reason I've made _useMacScreenCorrectHeight toggleable is because
1279  // maybe someday the screen correction can be activated or deactivated from the
1280  // ScummVM GUI; but currently I'm not taking that responsibility, after all the
1281  // work done on ensuring that old savegames translate correctly to the new setting... :-P
1282  bool _useMacScreenCorrectHeight = true;
1283  int _macScreenDrawOffset = 20;
1284 
1285  Common::RenderMode _renderMode;
1286  uint8 _bytesPerPixel = 1;
1287  Graphics::PixelFormat _outputPixelFormat;
1288 
1289 protected:
1290  ColorCycle _colorCycle[16]; // Palette cycles
1291  uint8 _colorUsedByCycle[256];
1292  Graphics::PaletteLookup _pl; // Used by the internal GUI
1293 
1294  uint32 _ENCD_offs = 0, _EXCD_offs = 0;
1295  uint32 _CLUT_offs = 0, _EPAL_offs = 0;
1296  uint32 _IM00_offs = 0, _PALS_offs = 0;
1297 
1298  //ender: fullscreen
1299  bool _fullRedraw = false, _bgNeedsRedraw = false;
1300  bool _screenEffectFlag = false, _completeScreenRedraw = false;
1301  bool _disableFadeInEffect = false;
1302 
1303  struct {
1304  int hotspotX, hotspotY, width, height;
1305  byte animate, animateIndex;
1306  int8 state;
1307  } _cursor;
1308 
1309  // HACK Double the array size to handle 16-bit images.
1310  // this should be dynamically allocated based on game depth instead.
1311  byte _grabbedCursor[16384];
1312  byte _macGrabbedCursor[16384 * 4]; // Double resolution cursor
1313  byte _currentCursor = 0;
1314 
1315  byte _newEffect = 0, _switchRoomEffect2 = 0, _switchRoomEffect = 0;
1316  bool _doEffect = false;
1317 
1318  bool _snapScroll = false;
1319 
1320  virtual void setBuiltinCursor(int index) {}
1321 public:
1322  bool isLightOn() const;
1323 
1324  virtual int getCurrentLights() const;
1325 
1326 protected:
1327  void initScreens(int b, int h);
1328  void initVirtScreen(VirtScreenNumber slot, int top, int width, int height, bool twobufs, bool scrollable);
1329  void initBGBuffers(int height);
1330  void initCycl(const byte *ptr); // Color cycle
1331 
1332  void decodeNESBaseTiles();
1333 
1334  void drawObject(int obj, int scrollType);
1335  void drawRoomObjects(int arg);
1336  void drawRoomObject(int i, int arg);
1337  void drawBox(int x, int y, int x2, int y2, int color);
1338  void drawLine(int x1, int y1, int x2, int y2, int color);
1339  void drawPixel(VirtScreen *vs, int x, int y, int16 color, bool useBackbuffer = false);
1340 
1341  void moveScreen(int dx, int dy, int height);
1342 
1343  void restoreBackground(Common::Rect rect, byte backcolor = 0);
1344  void redrawBGStrip(int start, int num);
1345  virtual void redrawBGAreas();
1346 
1347  void cameraMoved();
1348  void setCameraAtEx(int at);
1349  virtual void setCameraAt(int pos_x, int pos_y);
1350  virtual void setCameraFollows(Actor *a, bool setCamera = false);
1351  virtual void moveCamera();
1352  virtual void panCameraTo(int x, int y);
1353  void clampCameraPos(Common::Point *pt);
1354  void actorFollowCamera(int act);
1355 
1356  const byte *getPalettePtr(int palindex, int room);
1357 
1358  void setPaletteFromTable(const byte *ptr, int numcolor, int firstIndex = 0);
1359  void resetPalette();
1360 
1361  void setCurrentPalette(int pal);
1362  void setRoomPalette(int pal, int room);
1363  void setPCEPaletteFromPtr(const byte *ptr);
1364  void setAmigaPaletteFromPtr(const byte *ptr);
1365  virtual void setPaletteFromPtr(const byte *ptr, int numcolor = -1);
1366  void setV1ColorTable(int renderMode);
1367 
1368  virtual void setPalColor(int index, int r, int g, int b);
1369  void setDirtyColors(int min, int max);
1370  const byte *findPalInPals(const byte *pal, int index);
1371  void swapPalColors(int a, int b);
1372  virtual void copyPalColor(int dst, int src);
1373  void cyclePalette();
1374  void stopCycle(int i);
1375  virtual void palManipulateInit(int resID, int start, int end, int time);
1376  void palManipulate();
1377  uint32 findClosestPaletteColor(byte *palette, int paletteLength, byte r, byte g, byte b);
1378  void applyGrayscaleToPaletteRange(int min, int max); // For Sam&Max original noir mode
1379  bool haveToApplyMonkey1PaletteFix();
1380 
1381 public:
1382  uint8 *getHEPaletteSlot(uint16 palSlot);
1383  uint16 get16BitColor(uint8 r, uint8 g, uint8 b);
1384  uint32 getPaletteColorFromRGB(byte *palette, byte r, byte g, byte b);
1385  uint32 getPackedRGBColorFromPalette(byte *palette, uint32 color);
1386  void fetchBlackAndWhite(uint32 &black, uint32 &white, byte *palette, int paletteEntries);
1387  int remapPaletteColor(int r, int g, int b, int threshold); // Used by Actor::remapActorPalette
1388  void readPCEPalette(const byte **ptr, byte **dest, int numEntries);
1389  void colorPCEToRGB(uint16 color, byte *r, byte *g, byte *b);
1390  void setPCETextPalette(uint8 color);
1391 protected:
1392  void moveMemInPalRes(int start, int end, byte direction);
1393  void setShadowPalette(int slot, int redScale, int greenScale, int blueScale, int startColor, int endColor);
1394  void setShadowPalette(int redScale, int greenScale, int blueScale, int startColor, int endColor, int start, int end);
1395  virtual void darkenPalette(int redScale, int greenScale, int blueScale, int startColor, int endColor);
1396 
1397 public:
1398  void markRectAsDirty(VirtScreenNumber virt, int left, int right, int top, int bottom, int dirtybit = 0);
1399  void markRectAsDirty(VirtScreenNumber virt, const Common::Rect& rect, int dirtybit = 0) {
1400  markRectAsDirty(virt, rect.left, rect.right, rect.top, rect.bottom, dirtybit);
1401  }
1402 protected:
1403  // Screen rendering
1404  byte *_compositeBuf;
1405  byte *_hercCGAScaleBuf = nullptr;
1406  bool _enableEGADithering = false;
1407  bool _supportsEGADithering = false;
1408  bool _enableSegaShadowMode = false;
1409 
1410  virtual void drawDirtyScreenParts();
1411  void updateDirtyScreen(VirtScreenNumber slot);
1412  void drawStripToScreen(VirtScreen *vs, int x, int width, int top, int bottom);
1413 
1414  void mac_markScreenAsDirty(int x, int y, int w, int h);
1415  void mac_drawStripToScreen(VirtScreen *vs, int top, int x, int y, int width, int height);
1416  void mac_drawIndy3TextBox();
1417  void mac_undrawIndy3TextBox();
1418  void mac_undrawIndy3CreditsText();
1419  void mac_drawBufferToScreen(const byte *buffer, int pitch, int x, int y, int width, int height, bool epxRectangleExpansion = true);
1420  void mac_updateCompositeBuffer(const byte *buffer, int pitch, int x, int y, int width, int height);
1421  void mac_blitDoubleResImage(const byte *buffer, int pitch, int x, int y, int width, int height);
1422  void mac_applyDoubleResToBuffer(const byte *inputBuffer, byte *outputBuffer, int width, int height, int inputPitch, int outputPitch);
1423  void mac_blitEPXImage(const byte *buffer, int pitch, int x, int y, int width, int height, bool epxRectangleExpansion = true);
1424  void mac_applyEPXToBuffer(const byte *inputBuffer, byte *outputBuffer, int width, int height, int inputPitch, int outputPitch, int xOffset, int yOffset, int bufferWidth, int bufferHeight);
1425  void mac_scaleCursor(byte *&outCursor, int &outHotspotX, int &outHotspotY, int &outWidth, int &outHeight);
1426  void mac_toggleSmoothing();
1427 
1428  Common::KeyState mac_showOldStyleBannerAndPause(const char *msg, int32 waitTime);
1429 
1430  const byte *postProcessDOSGraphics(VirtScreen *vs, int &pitch, int &x, int &y, int &width, int &height) const;
1431  const byte *ditherVGAtoEGA(int &pitch, int &x, int &y, int &width, int &height) const;
1432 
1433 public:
1434  VirtScreen *findVirtScreen(int y);
1435  byte *getMaskBuffer(int x, int y, int z);
1436 
1437 protected:
1438  void fadeIn(int effect);
1439  void fadeOut(int effect);
1440 
1441  void dissolveEffectSelector();
1442  void transitionEffect(int a);
1443  void dissolveEffect(int width, int height);
1444  void scrollEffect(int dir);
1445 
1446  void updateScreenShakeEffect();
1447 
1448 public:
1449  double getTimerFrequency();
1450  double getAmigaMusicTimerFrequency(); // For setting up Players v2 and v3
1451 
1452 protected:
1453  bool _shakeEnabled = false;
1454  bool _shakeTempSavedState = false; // For saving and restoring before and after GUI calls
1455  uint _shakeFrame = 0;
1456  uint32 _shakeNextTick = 0;
1457  uint32 _shakeTickCounter = 0;
1458  double _shakeTimerRate;
1459  double _timerFrequency;
1460 
1461  void setShake(int mode);
1462 
1463  int _drawObjectQueNr = 0;
1464  byte _drawObjectQue[200];
1465 
1466  /* For each of the 410 screen strips, gfxUsageBits contains a
1467  * bitmask. The lower 80 bits each correspond to one actor and
1468  * signify if any part of that actor is currently contained in
1469  * that strip.
1470  *
1471  * If the leftmost bit is set, the strip (background) is dirty
1472  * needs to be redrawn.
1473  *
1474  * The second leftmost bit is set by restoreBlastObjectsRect() and
1475  * restoreBackground(), but I'm not yet sure why.
1476  */
1477  uint32 gfxUsageBits[410 * 3];
1478 
1479  void upgradeGfxUsageBits();
1480  void setGfxUsageBit(int strip, int bit);
1481  void clearGfxUsageBit(int strip, int bit);
1482 
1483  // speed optimization: inline due to frequent calling
1484  bool testGfxUsageBit(int strip, int bit) {
1485  assert(strip >= 0 && strip < ARRAYSIZE(gfxUsageBits) / 3);
1486  assert(1 <= bit && bit <= 96);
1487  bit--;
1488  return (gfxUsageBits[3 * strip + bit / 32] & (1 << (bit % 32))) != 0;
1489  }
1490 
1491  bool testGfxAnyUsageBits(int strip);
1492  bool testGfxObjectUsageBits(int strip); // Used for HE actors overlap calculations
1493  bool testGfxOtherUsageBits(int strip, int bit);
1494 
1495 public:
1496  byte _roomPalette[256];
1497  byte *_shadowPalette = nullptr;
1498  bool _skipDrawObject = 0;
1499  int _voiceMode = 0;
1500  int _soundEnabled = 0;
1501 
1502  // HE specific
1503  byte _HEV7ActorPalette[256];
1504  uint8 *_hePalettes = nullptr;
1505  uint16 _hePaletteSlot = 0;
1506  uint16 *_16BitPalette = nullptr;
1507 
1508  // Indy4 Amiga specific
1509  byte *_verbPalette = nullptr;
1510 
1511  ScummEngine_v0_Delays _V0Delay;
1512 
1513 protected:
1514  int _shadowPaletteSize = 0;
1515  byte _currentPalette[3 * 256];
1516  byte _darkenPalette[3 * 256];
1517  int _paletteChangedCounter = 1;
1518 
1519  int _palDirtyMin = 0, _palDirtyMax = 0;
1520 
1521  byte _palManipStart = 0, _palManipEnd = 0;
1522  uint16 _palManipCounter = 0;
1523  byte *_palManipPalette = nullptr;
1524  byte *_palManipIntermediatePal = nullptr;
1525 
1526  bool _haveActorSpeechMsg = false;
1527  bool _useTalkAnims = false;
1528  uint16 _defaultTextSpeed = 0;
1529  int _saveSound = 0;
1530  bool _native_mt32 = false;
1531  bool _copyProtection = false;
1532  bool _shadowPalRemap = false;
1533 
1534  // Indy4 Amiga specific
1535  uint16 _amigaFirstUsedColor = 0;
1536  byte _amigaPalette[3 * 64];
1537  void amigaPaletteFindFirstUsedColor();
1538  void mapRoomPalette(int idx);
1539  int remapRoomPaletteColor(int r, int g, int b);
1540  void mapVerbPalette(int idx);
1541  int remapVerbPaletteColor(int r, int g, int b);
1542 
1543  // EGA dithering mode color tables for certain VGA games like MI2, LOOM Talkie...
1544  byte *_egaColorMap[2];
1545 
1546 public:
1547  uint16 _extraBoxFlags[65];
1548 
1549  byte getNumBoxes();
1550  byte *getBoxMatrixBaseAddr();
1551  byte *getBoxConnectionBase(int box);
1552 
1553  int getNextBox(byte from, byte to);
1554 
1555  void setBoxFlags(int box, int val);
1556  void setBoxScale(int box, int b);
1557 
1558  bool checkXYInBoxBounds(int box, int x, int y);
1559 
1560  BoxCoords getBoxCoordinates(int boxnum);
1561 
1562  byte getMaskFromBox(int box);
1563  Box *getBoxBaseAddr(int box);
1564  byte getBoxFlags(int box);
1565  int getBoxScale(int box);
1566 
1567  int getScale(int box, int x, int y);
1568  int getScaleFromSlot(int slot, int x, int y);
1569 
1570 protected:
1571  // Scaling slots/items
1572  struct ScaleSlot {
1573  int x1, y1, scale1;
1574  int x2, y2, scale2;
1575  };
1576  friend void syncWithSerializer(Common::Serializer &, ScaleSlot &);
1577  ScaleSlot _scaleSlots[20];
1578  void setScaleSlot(int slot, int x1, int y1, int scale1, int x2, int y2, int scale2);
1579  void setBoxScaleSlot(int box, int slot);
1580  void convertScaleTableToScaleSlot(int slot);
1581 
1582  void calcItineraryMatrix(byte *itineraryMatrix, int num);
1583  void createBoxMatrix();
1584  virtual bool areBoxesNeighbors(int i, int j);
1585 
1586  /* String class */
1587 public:
1588  CharsetRenderer *_charset = nullptr;
1589  byte _charsetColorMap[16];
1590 
1596  int _textSurfaceMultiplier = 0;
1597 
1598  bool _useGammaCorrection = true;
1599 
1600  Graphics::Surface *_macScreen = nullptr;
1601  MacGui *_macGui = nullptr;
1602  bool _useMacGraphicsSmoothing = true;
1603  byte _completeScreenBuffer[320 * 200];
1604 
1605 protected:
1606  byte _charsetColor = 0;
1607  byte _charsetData[23][16];
1608 
1609  int _charsetBufPos = 0;
1610  byte _charsetBuffer[512];
1611 
1612  bool _keepText = false;
1613  byte _msgCount = 0;
1614 
1615  int _nextLeft = 0, _nextTop = 0;
1616 
1617  Localizer *_localizer = nullptr;
1618 
1619  void restoreCharsetBg();
1620  void clearCharsetMask();
1621  void clearTextSurface();
1622 
1623  virtual void initCharset(int charset);
1624 
1625  virtual void printString(int m, const byte *msg);
1626 
1627  virtual bool handleNextCharsetCode(Actor *a, int *c);
1628  virtual void drawSentence() {}
1629  virtual void displayDialog();
1630  int countNumberOfWaits(); // For SE speech support, from disasm
1631  bool newLine();
1632  void drawString(int a, const byte *msg);
1633  virtual void fakeBidiString(byte *ltext, bool ignoreVerb, int ltextSize) const;
1634  void wrapSegaCDText();
1635  void debugMessage(const byte *msg);
1636  virtual void showMessageDialog(const byte *msg);
1637 
1638  virtual int convertMessageToString(const byte *msg, byte *dst, int dstSize);
1639  int convertIntMessage(byte *dst, int dstSize, int var);
1640  int convertVerbMessage(byte *dst, int dstSize, int var);
1641  int convertNameMessage(byte *dst, int dstSize, int var);
1642  int convertStringMessage(byte *dst, int dstSize, int var);
1643 
1644 public:
1645  Common::Language _language; // Accessed by a hack in NutRenderer::loadFont
1646 
1647  // Used by class ScummDialog:
1648  virtual void translateText(const byte *text, byte *trans_buff, int transBufferSize);
1649  // Old Hebrew games require reversing the dialog text.
1650  bool reverseIfNeeded(const byte *text, byte *reverseBuf, int reverseBufSize) const;
1651  // Returns codepage that matches the game for languages that require it.
1652  Common::CodePage getDialogCodePage() const;
1653 
1654  // Somewhat hackish stuff for 2 byte support (Chinese/Japanese/Korean)
1655  bool _useCJKMode = false;
1656  bool _useMultiFont = false;
1657  int _numLoadedFont = 0;
1658  int _2byteShadow = 0;
1659  bool _force2ByteCharHeight = false;
1660 
1661  int _2byteHeight = 0;
1662  int _2byteWidth = 0;
1663  int _krStrPost = 0;
1664  byte _newLineCharacter = 0;
1665  byte *get2byteCharPtr(int idx);
1666 
1667  bool isScummvmKorTarget();
1668  bool hasLocalizer();
1669 
1670 //protected:
1671  byte *_2byteFontPtr = nullptr;
1672  byte *_2byteMultiFontPtr[20];
1673  int _2byteMultiHeight[20];
1674  int _2byteMultiWidth[20];
1675  int _2byteMultiShadow[20];
1676 
1677 private:
1678  struct TranslatedLine {
1679  uint32 originalTextOffset;
1680  uint32 translatedTextOffset;
1681  };
1682 
1683  struct TranslationRange {
1684  uint32 left;
1685  uint32 right;
1686 
1687  TranslationRange(uint32 left_, uint32 right_) : left(left_), right(right_) {}
1688  TranslationRange() : left(0), right(0) {}
1689  };
1690 
1691  struct TranslationRoom {
1693  };
1694 
1695  bool _existLanguageFile = false;
1696  bool _isRTL = false;
1697  byte *_languageBuffer = nullptr;
1698  int _numTranslatedLines = 0;
1699  TranslatedLine *_translatedLines = nullptr;
1700  uint16 *_languageLineIndex = nullptr;
1702 
1703  const byte *searchTranslatedLine(const byte *text, const TranslationRange &range, bool useIndex);
1704 
1705  virtual void createTextRenderer(GlyphRenderer_v7 *gr) {}
1706 
1707 public:
1708 
1709  /* Scumm Vars */
1710  byte VAR_KEYPRESS = 0xFF;
1711  byte VAR_SYNC = 0xFF;
1712  byte VAR_EGO = 0xFF;
1713  byte VAR_CAMERA_POS_X = 0xFF;
1714  byte VAR_HAVE_MSG = 0xFF;
1715  byte VAR_ROOM = 0xFF;
1716  byte VAR_OVERRIDE = 0xFF;
1717  byte VAR_MACHINE_SPEED = 0xFF;
1718  byte VAR_ME = 0xFF;
1719  byte VAR_NUM_ACTOR = 0xFF;
1720  byte VAR_CURRENT_LIGHTS = 0xFF;
1721  byte VAR_CURRENTDRIVE = 0xFF; // How about merging this with VAR_CURRENTDISK?
1722  byte VAR_CURRENTDISK = 0xFF;
1723  byte VAR_TMR_1 = 0xFF;
1724  byte VAR_TMR_2 = 0xFF;
1725  byte VAR_TMR_3 = 0xFF;
1726  byte VAR_MUSIC_TIMER = 0xFF;
1727  byte VAR_ACTOR_RANGE_MIN = 0xFF;
1728  byte VAR_ACTOR_RANGE_MAX = 0xFF;
1729  byte VAR_CAMERA_MIN_X = 0xFF;
1730  byte VAR_CAMERA_MAX_X = 0xFF;
1731  byte VAR_TIMER_NEXT = 0xFF;
1732  byte VAR_VIRT_MOUSE_X = 0xFF;
1733  byte VAR_VIRT_MOUSE_Y = 0xFF;
1734  byte VAR_ROOM_RESOURCE = 0xFF;
1735  byte VAR_LAST_SOUND = 0xFF;
1736  byte VAR_CUTSCENEEXIT_KEY = 0xFF;
1737  byte VAR_OPTIONS_KEY = 0xFF;
1738  byte VAR_TALK_ACTOR = 0xFF;
1739  byte VAR_CAMERA_FAST_X = 0xFF;
1740  byte VAR_SCROLL_SCRIPT = 0xFF;
1741  byte VAR_ENTRY_SCRIPT = 0xFF;
1742  byte VAR_ENTRY_SCRIPT2 = 0xFF;
1743  byte VAR_EXIT_SCRIPT = 0xFF;
1744  byte VAR_EXIT_SCRIPT2 = 0xFF;
1745  byte VAR_VERB_SCRIPT = 0xFF;
1746  byte VAR_SENTENCE_SCRIPT = 0xFF;
1747  byte VAR_INVENTORY_SCRIPT = 0xFF;
1748  byte VAR_CUTSCENE_START_SCRIPT = 0xFF;
1749  byte VAR_CUTSCENE_END_SCRIPT = 0xFF;
1750  byte VAR_CHARINC = 0xFF;
1751  byte VAR_WALKTO_OBJ = 0xFF;
1752  byte VAR_DEBUGMODE = 0xFF;
1753  byte VAR_HEAPSPACE = 0xFF;
1754  byte VAR_RESTART_KEY = 0xFF;
1755  byte VAR_PAUSE_KEY = 0xFF;
1756  byte VAR_MOUSE_X = 0xFF;
1757  byte VAR_MOUSE_Y = 0xFF;
1758  byte VAR_TIMER = 0xFF;
1759  byte VAR_TIMER_TOTAL = 0xFF;
1760  byte VAR_SOUNDCARD = 0xFF;
1761  byte VAR_VIDEOMODE = 0xFF;
1762  byte VAR_MAINMENU_KEY = 0xFF;
1763  byte VAR_FIXEDDISK = 0xFF;
1764  byte VAR_CURSORSTATE = 0xFF;
1765  byte VAR_USERPUT = 0xFF;
1766  byte VAR_SOUNDRESULT = 0xFF;
1767  byte VAR_TALKSTOP_KEY = 0xFF;
1768  byte VAR_FADE_DELAY = 0xFF;
1769  byte VAR_NOSUBTITLES = 0xFF;
1770 
1771  // V5+
1772  byte VAR_SOUNDPARAM = 0xFF;
1773  byte VAR_SOUNDPARAM2 = 0xFF;
1774  byte VAR_SOUNDPARAM3 = 0xFF;
1775  byte VAR_INPUTMODE = 0xFF;
1776  byte VAR_MEMORY_PERFORMANCE = 0xFF;
1777  byte VAR_VIDEO_PERFORMANCE = 0xFF;
1778  byte VAR_ROOM_FLAG = 0xFF;
1779  byte VAR_GAME_LOADED = 0xFF;
1780  byte VAR_NEW_ROOM = 0xFF;
1781 
1782  // V4/V5
1783  byte VAR_V5_TALK_STRING_Y = 0xFF;
1784 
1785  // V6+
1786  byte VAR_ROOM_WIDTH = 0xFF;
1787  byte VAR_ROOM_HEIGHT = 0xFF;
1788  byte VAR_SUBTITLES = 0xFF;
1789  byte VAR_V6_EMSSPACE = 0xFF;
1790 
1791  // V7/V8 specific variables
1792  byte VAR_CAMERA_POS_Y = 0xFF;
1793  byte VAR_CAMERA_MIN_Y = 0xFF;
1794  byte VAR_CAMERA_MAX_Y = 0xFF;
1795  byte VAR_CAMERA_THRESHOLD_X = 0xFF;
1796  byte VAR_CAMERA_THRESHOLD_Y = 0xFF;
1797  byte VAR_CAMERA_SPEED_X = 0xFF;
1798  byte VAR_CAMERA_SPEED_Y = 0xFF;
1799  byte VAR_CAMERA_ACCEL_X = 0xFF;
1800  byte VAR_CAMERA_ACCEL_Y = 0xFF;
1801  byte VAR_CAMERA_DEST_X = 0xFF;
1802  byte VAR_CAMERA_DEST_Y = 0xFF;
1803  byte VAR_CAMERA_FOLLOWED_ACTOR = 0xFF;
1804 
1805  // V7/V8 specific variables
1806  byte VAR_VERSION_KEY = 0xFF;
1807  byte VAR_DEFAULT_TALK_DELAY = 0xFF;
1808  byte VAR_CUSTOMSCALETABLE = 0xFF;
1809  byte VAR_BLAST_ABOVE_TEXT = 0xFF;
1810  byte VAR_VOICE_MODE = 0xFF;
1811  byte VAR_MUSIC_BUNDLE_LOADED = 0xFF;
1812  byte VAR_VOICE_BUNDLE_LOADED = 0xFF;
1813 
1814  byte VAR_LEFTBTN_DOWN = 0xFF; // V7/V8
1815  byte VAR_RIGHTBTN_DOWN = 0xFF; // V7/V8
1816  byte VAR_LEFTBTN_HOLD = 0xFF; // V6/V72HE/V7/V8
1817  byte VAR_RIGHTBTN_HOLD = 0xFF; // V6/V72HE/V7/V8
1818  byte VAR_PRE_SAVELOAD_SCRIPT = 0xFF; // V6/V7 (not HE)
1819  byte VAR_POST_SAVELOAD_SCRIPT = 0xFF; // V6/V7 (not HE)
1820  byte VAR_SAVELOAD_PAGE = 0xFF; // V8
1821  byte VAR_OBJECT_LABEL_FLAG = 0xFF; // V8
1822 
1823  // V6/V7 specific variables (FT & Sam & Max specific)
1824  byte VAR_CHARSET_MASK = 0xFF;
1825 
1826  // V6 specific variables
1827  byte VAR_V6_SOUNDMODE = 0xFF;
1828 
1829  // V1/V2 specific variables
1830  byte VAR_CHARCOUNT = 0xFF;
1831  byte VAR_VERB_ALLOWED = 0xFF;
1832  byte VAR_ACTIVE_VERB = 0xFF;
1833  byte VAR_ACTIVE_OBJECT1 = 0xFF;
1834  byte VAR_ACTIVE_OBJECT2 = 0xFF;
1835 
1836  // HE specific variables
1837  byte VAR_ALWAYS_REDRAW_ACTORS = 0xFF; // Used in setActorRedrawFlags()
1838  byte VAR_SKIP_RESET_TALK_ACTOR = 0xFF; // Used in setActorCostume()
1839 
1840  byte VAR_SOUND_CHANNEL = 0xFF; // Used in o_startSound()
1841  byte VAR_TALK_CHANNEL = 0xFF; // Used in playVoice()
1842  byte VAR_SOUND_TOKEN_OFFSET = 0xFF; // Used in handleSoundFrame()
1843  byte VAR_START_DYN_SOUND_CHANNELS = 0xFF; // Used in getNextDynamicChannel()
1844  byte VAR_SOUND_CALLBACK_SCRIPT = 0xFF;
1845 
1846  byte VAR_EARLY_TALKIE_CALLBACK = 0xFF;
1847  byte VAR_EARLY_CHAN_0_CALLBACK = 0xFF;
1848  byte VAR_EARLY_CHAN_1_CALLBACK = 0xFF;
1849  byte VAR_EARLY_CHAN_2_CALLBACK = 0xFF;
1850  byte VAR_EARLY_CHAN_3_CALLBACK = 0xFF;
1851 
1852  byte VAR_MAIN_SCRIPT = 0xFF; // Used in scummLoop()
1853 
1854  byte VAR_DEFAULT_SCRIPT_PRIORITY = 0xFF; // Used in runScript()/runObjectScript()
1855  byte VAR_LAST_SCRIPT_PRIORITY = 0xFF; // Used in runAllScripts()
1856 
1857  byte VAR_QUIT_SCRIPT = 0xFF; // Used in confirmExitDialog()
1858  byte VAR_ERROR_FLAG = 0xFF; // HE70-90
1859  byte VAR_OPERATION_FAILURE = 0xFF; // HE99+
1860 
1861  byte VAR_COLOR_BLACK = 0xFF;
1862 
1863  // Exists both in V7 and in V72HE:
1864  byte VAR_NUM_GLOBAL_OBJS = 0xFF;
1865 
1866 #ifdef USE_RGB_COLOR
1867  // FM-Towns / PC-Engine specific
1868  Graphics::FontSJIS *_cjkFont = nullptr;
1869 #endif
1870 
1871  // FM-Towns specific
1872 #ifndef DISABLE_TOWNS_DUAL_LAYER_MODE
1873 public:
1874  bool towns_isRectInStringBox(int x1, int y1, int x2, int y2);
1875  byte _townsPaletteFlags = 0;
1876  byte _townsCharsetColorMap[16];
1877 
1878 protected:
1879  void towns_drawStripToScreen(VirtScreen *vs, int dstX, int dstY, int srcX, int srcY, int w, int h);
1880  void towns_fillTopLayerRect(int x1, int y1, int x2, int y2, int col);
1881  void towns_swapVirtScreenArea(VirtScreen *vs, int x, int y, int w, int h);
1882  void towns_clearStrip(int strip);
1883 #ifdef USE_RGB_COLOR
1884  void towns_setPaletteFromPtr(const byte *ptr, int numcolor = -1);
1885  void towns_setTextPaletteFromPtr(const byte *ptr);
1886 #endif
1887  void towns_setupPalCycleField(int x1, int y1, int x2, int y2);
1888  void towns_processPalCycleField();
1889  void towns_resetPalCycleFields();
1890  void towns_restoreCharsetBg();
1891  void towns_scriptScrollEffect(int dir);
1892 
1893  void requestScroll(int dir);
1894  void scrollLeft() { requestScroll(-1); }
1895  void scrollRight() { requestScroll(1); }
1896  void towns_waitForScroll(int waitForDirection, int threshold = 0);
1897  void towns_updateGfx();
1898 
1899  Common::Rect _cyclRects[10];
1900  int _numCyclRects = 0;
1901  int _scrollRequest = 0;
1902  int _scrollDeltaAdjust = 0;
1903  bool _scrollNeedDeltaAdjust = 0;
1904  int _refreshDuration[20];
1905  int _refreshArrayPos = 0;
1906  bool _refreshNeedCatchUp = false;
1907  bool _enableSmoothScrolling = false;
1908  bool _forceFMTownsHiResMode = false;
1909  uint32 _scrollTimer = 0;
1910  uint32 _scrollDestOffset = 0;
1911  uint16 _scrollFeedStrips[3];
1912 
1913  Common::Rect _curStringRect;
1914 
1915  byte _townsOverrideShadowColor = 0;
1916  byte _textPalette[48];
1917  byte _townsClearLayerFlag = 1;
1918  byte _townsActiveLayerFlags = 3;
1919  static const uint8 _townsLayer2Mask[];
1920 
1921  TownsScreen *_townsScreen = nullptr;
1922 #else
1923  void scrollLeft() { redrawBGStrip(_gdi->_numStrips - 1, 1); }
1924  void scrollRight() { redrawBGStrip(0, 1); }
1925  void towns_updateGfx() {}
1926  void towns_waitForScroll(int waitForDirection, int threshold = 0) {}
1927  void towns_fillTopLayerRect(int x1, int y1, int x2, int y2, int col) {}
1928  void towns_swapVirtScreenArea(VirtScreen *vs, int x, int y, int w, int h) {}
1929 #endif // DISABLE_TOWNS_DUAL_LAYER_MODE
1930 };
1931 
1932 } // End of namespace Scumm
1933 
1934 #endif
#define ARRAYSIZE(x)
Definition: util.h:93
Definition: charset.h:70
Definition: macgui_impl.h:52
Definition: keymap.h:66
VirtScreenNumber
Definition: gfx.h:161
Definition: gfx.h:563
Definition: str.h:59
Definition: boxes.h:44
Definition: surface.h:67
EngineFeature
Definition: engine.h:253
Definition: stream.h:77
Definition: error.h:84
ErrorCode getCode() const
Definition: error.h:115
Definition: detection.h:118
Definition: script.h:31
Definition: gfx.h:138
Definition: pixelformat.h:138
Definition: macgui_v6.h:33
Definition: script.h:120
Definition: random.h:44
int16 right
Definition: rect.h:146
Definition: palette.h:170
RenderMode
Definition: rendermode.h:48
No error occurred.
Definition: error.h:48
Definition: scumm.h:151
Definition: rect.h:144
Common::Path _containerFile
Definition: scumm.h:1055
Definition: path.h:52
Definition: scumm.h:170
Definition: resource.h:75
Definition: music.h:40
ResType
Definition: scumm.h:242
Definition: stream.h:745
Definition: macgui_indy3.h:37
Definition: sound.h:59
Definition: scumm.h:135
Definition: system.h:46
void void void void void debugC(int level, uint32 debugChannel, MSVC_PRINTF const char *s,...) GCC_PRINTF(3
Definition: serializer.h:79
Definition: scumm.h:162
Definition: scumm.h:504
Definition: gfx.h:185
Definition: scumm.h:142
Graphics::Surface _textSurface
Definition: scumm.h:1595
Definition: scumm.h:183
int FORCEINLINE GCC_PRINTF(2, 0) int vsprintf_s(T(&dst)[N]
Definition: detection.h:45
Definition: ustr.h:57
Definition: scumm.h:218
Definition: player_towns.h:32
Definition: scumm.h:200
Definition: debugger.h:33
Definition: object.h:189
Definition: object.h:64
Definition: imuse.h:50
Definition: events.h:199
Definition: algorithm.h:29
Definition: formatinfo.h:28
Definition: mutex.h:67
Definition: rect.h:45
Definition: macgui_v5.h:33
int16 left
Definition: rect.h:145
Definition: serializer.h:308
Definition: charset.h:155
Definition: scumm.h:464
void NORETURN_PRE error(MSVC_PRINTF const char *s,...) GCC_PRINTF(1
Definition: actor.h:97
Definition: localizer.h:31
Definition: dialog.h:49
Definition: gfx.h:292
Definition: stream.h:351
Definition: base-costume.h:68
Definition: scumm.h:1572
Definition: macgui.h:39
Definition: keyboard.h:294
Common::Error run() override
Definition: scumm.h:567
Common::RandomSource _rnd
Definition: scumm.h:535
Definition: macgui_loom.h:33
Definition: system.h:161
Definition: base-costume.h:49
Definition: engine.h:144
Definition: actor.h:30
Definition: gfx.h:279
Definition: verbs.h:47
Definition: detection.h:132
Definition: file.h:36
Language
Definition: language.h:45