/* 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. * */ #include "common/system.h" #include "common/file.h" #include "graphics/primitives.h" // for Graphics::drawLine #include "parallaction/exec.h" #include "parallaction/input.h" #include "parallaction/parallaction.h" #include "parallaction/saveload.h" #include "parallaction/sound.h" namespace Parallaction { /* intro callables data members */ static uint16 _rightHandPositions[684] = { 0x0064, 0x0046, 0x006c, 0x0046, 0x0074, 0x0046, 0x007c, 0x0046, 0x0084, 0x0046, 0x008c, 0x0046, 0x0094, 0x0046, 0x009c, 0x0046, 0x00a4, 0x0046, 0x00ac, 0x0046, 0x00b4, 0x0046, 0x00bc, 0x0046, 0x00c4, 0x0046, 0x00cc, 0x0046, 0x00d4, 0x0046, 0x00dc, 0x0046, 0x00e4, 0x0046, 0x00ec, 0x0046, 0x00f4, 0x0046, 0x00fc, 0x0046, 0x0104, 0x0046, 0x00ff, 0x0042, 0x00ff, 0x004a, 0x00ff, 0x0052, 0x00ff, 0x005a, 0x00ff, 0x0062, 0x00ff, 0x006a, 0x00ff, 0x0072, 0x00ff, 0x007a, 0x00ff, 0x0082, 0x00ff, 0x008a, 0x00ff, 0x0092, 0x00ff, 0x009a, 0x00ff, 0x00a2, 0x0104, 0x0097, 0x00fc, 0x0097, 0x00f4, 0x0097, 0x00ec, 0x0097, 0x00e4, 0x0097, 0x00dc, 0x0097, 0x00d4, 0x0097, 0x00cc, 0x0097, 0x00c4, 0x0097, 0x00bc, 0x0097, 0x00b4, 0x0097, 0x00ac, 0x0097, 0x00a4, 0x0097, 0x009c, 0x0097, 0x0094, 0x0097, 0x008c, 0x0097, 0x0084, 0x0097, 0x007c, 0x0097, 0x0074, 0x0097, 0x006c, 0x0097, 0x0064, 0x0097, 0x0066, 0x0042, 0x0066, 0x004a, 0x0066, 0x0052, 0x0066, 0x005a, 0x0066, 0x0062, 0x0066, 0x006a, 0x0066, 0x0072, 0x0066, 0x007a, 0x0066, 0x0082, 0x0066, 0x008a, 0x0066, 0x0092, 0x0066, 0x009a, 0x0066, 0x00a2, 0x008c, 0x0091, 0x0099, 0x0042, 0x0099, 0x004a, 0x0099, 0x0052, 0x0099, 0x005a, 0x0099, 0x0062, 0x0099, 0x006a, 0x0099, 0x0072, 0x0099, 0x007a, 0x0099, 0x0082, 0x0099, 0x008a, 0x0099, 0x0092, 0x0099, 0x009a, 0x0099, 0x00a2, 0x00a0, 0x004d, 0x00cc, 0x0042, 0x00cc, 0x004a, 0x00cc, 0x0052, 0x00cc, 0x005a, 0x00cc, 0x0062, 0x00cc, 0x006a, 0x00cc, 0x0072, 0x00cc, 0x007a, 0x00cc, 0x0082, 0x00cc, 0x008a, 0x00cc, 0x0092, 0x00cc, 0x009a, 0x00cc, 0x00a2, 0x00ca, 0x0050, 0x00b1, 0x0050, 0x0081, 0x0052, 0x007e, 0x0052, 0x007c, 0x0055, 0x007c, 0x005c, 0x007e, 0x005e, 0x0080, 0x005e, 0x0082, 0x005c, 0x0082, 0x0054, 0x0080, 0x0052, 0x0078, 0x0052, 0x007c, 0x005e, 0x0077, 0x0061, 0x0074, 0x006e, 0x0074, 0x0078, 0x0076, 0x007a, 0x0079, 0x0078, 0x0079, 0x0070, 0x0078, 0x0070, 0x0078, 0x006b, 0x007b, 0x0066, 0x007a, 0x006f, 0x0084, 0x006f, 0x0085, 0x0066, 0x0086, 0x0070, 0x0085, 0x0070, 0x0085, 0x0079, 0x0088, 0x0079, 0x008a, 0x0078, 0x008a, 0x006c, 0x0087, 0x0061, 0x0085, 0x005f, 0x0082, 0x005f, 0x0080, 0x0061, 0x007e, 0x0061, 0x007b, 0x005f, 0x007c, 0x006f, 0x007c, 0x0071, 0x0079, 0x0074, 0x0079, 0x0089, 0x0076, 0x008c, 0x0076, 0x008e, 0x007a, 0x008e, 0x007f, 0x0089, 0x007f, 0x0083, 0x007e, 0x0083, 0x007e, 0x0077, 0x0080, 0x0077, 0x0080, 0x0083, 0x0080, 0x008b, 0x0084, 0x0090, 0x0088, 0x0090, 0x0088, 0x008e, 0x0085, 0x008b, 0x0085, 0x0074, 0x0082, 0x0071, 0x00b2, 0x0052, 0x00b0, 0x0054, 0x00b0, 0x0056, 0x00ae, 0x0058, 0x00af, 0x0059, 0x00af, 0x005e, 0x00b2, 0x0061, 0x00b5, 0x0061, 0x00b8, 0x005e, 0x00b8, 0x005a, 0x00b9, 0x0059, 0x00b9, 0x0058, 0x00b7, 0x0056, 0x00b7, 0x0054, 0x00b5, 0x0052, 0x00b2, 0x0052, 0x00ae, 0x005a, 0x00ab, 0x005b, 0x00ab, 0x006d, 0x00ae, 0x0072, 0x00b8, 0x0072, 0x00bc, 0x006d, 0x00bc, 0x005b, 0x00b9, 0x005a, 0x00bc, 0x005c, 0x00be, 0x005c, 0x00c1, 0x005f, 0x00c4, 0x0067, 0x00c4, 0x006d, 0x00c1, 0x0076, 0x00c0, 0x0077, 0x00bd, 0x0077, 0x00bb, 0x0075, 0x00bd, 0x0073, 0x00bb, 0x0072, 0x00be, 0x0070, 0x00be, 0x006a, 0x00a9, 0x006a, 0x00a9, 0x0070, 0x00ac, 0x0072, 0x00aa, 0x0073, 0x00ac, 0x0075, 0x00aa, 0x0077, 0x00a7, 0x0077, 0x00a3, 0x006d, 0x00a3, 0x0067, 0x00a6, 0x005f, 0x00a9, 0x005c, 0x00ab, 0x005c, 0x00ac, 0x0077, 0x00ac, 0x007c, 0x00ab, 0x007c, 0x00ab, 0x0084, 0x00ac, 0x0084, 0x00ac, 0x008b, 0x00a9, 0x008e, 0x00a9, 0x0090, 0x00ae, 0x0090, 0x00ae, 0x008d, 0x00b2, 0x008c, 0x00b2, 0x0087, 0x00b1, 0x0086, 0x00b1, 0x007b, 0x00b2, 0x0079, 0x00b4, 0x0079, 0x00b4, 0x007d, 0x00b5, 0x007d, 0x00b5, 0x0087, 0x00b4, 0x0087, 0x00b4, 0x008c, 0x00b6, 0x008c, 0x00b9, 0x0091, 0x00b4, 0x0091, 0x00bd, 0x008f, 0x00ba, 0x008c, 0x00ba, 0x0083, 0x00bb, 0x0082, 0x00bb, 0x0075, 0x00cc, 0x006e, 0x00d4, 0x006c, 0x00db, 0x0069, 0x00d9, 0x0068, 0x00d9, 0x0064, 0x00dc, 0x0064, 0x00dc, 0x0060, 0x00df, 0x0056, 0x00e5, 0x0052, 0x00e7, 0x0052, 0x00ec, 0x0056, 0x00ef, 0x005d, 0x00f1, 0x0065, 0x00f3, 0x0064, 0x00f3, 0x0069, 0x00f0, 0x0069, 0x00ec, 0x0065, 0x00ec, 0x005e, 0x00e9, 0x005f, 0x00e9, 0x005a, 0x00e7, 0x0058, 0x00e4, 0x0058, 0x00e3, 0x0054, 0x00e3, 0x0058, 0x00e1, 0x005c, 0x00e4, 0x0061, 0x00e7, 0x0061, 0x00e9, 0x005f, 0x00eb, 0x005d, 0x00e4, 0x0062, 0x00e0, 0x0064, 0x00e0, 0x0069, 0x00e2, 0x006b, 0x00e0, 0x0072, 0x00e0, 0x0077, 0x00ec, 0x0077, 0x00ec, 0x0071, 0x00ea, 0x006b, 0x00ec, 0x006a, 0x00ec, 0x0063, 0x00e7, 0x0063, 0x00e7, 0x0065, 0x00e1, 0x0069, 0x00e3, 0x0068, 0x00e6, 0x0069, 0x00ec, 0x005e, 0x00ea, 0x006b, 0x00e7, 0x006b, 0x00e7, 0x006a, 0x00e5, 0x006a, 0x00e5, 0x006b, 0x00e2, 0x006b, 0x00df, 0x006c, 0x00dc, 0x006f, 0x00dc, 0x0071, 0x00da, 0x0073, 0x00d8, 0x0073, 0x00d8, 0x006f, 0x00dc, 0x006b, 0x00dc, 0x0069, 0x00dd, 0x0068, 0x00ef, 0x0068, 0x00f0, 0x0069, 0x00f0, 0x006b, 0x00f4, 0x006f, 0x00f4, 0x0072, 0x00f3, 0x0073, 0x00f2, 0x0073, 0x00f0, 0x0071, 0x00f0, 0x006f, 0x00ec, 0x006b, 0x00ec, 0x007a, 0x00eb, 0x007b, 0x00eb, 0x007f, 0x00ec, 0x0080, 0x00ec, 0x0084, 0x00eb, 0x0085, 0x00eb, 0x008b, 0x00ec, 0x008c, 0x00ec, 0x008f, 0x00ed, 0x0091, 0x00e9, 0x0091, 0x00e9, 0x008f, 0x00e7, 0x008d, 0x00e7, 0x0090, 0x00e7, 0x0089, 0x00e8, 0x0088, 0x00e8, 0x0086, 0x00e7, 0x0085, 0x00e7, 0x007d, 0x00e6, 0x007c, 0x00e6, 0x0078, 0x00e5, 0x007d, 0x00e5, 0x0085, 0x00e4, 0x0086, 0x00e4, 0x0088, 0x00e5, 0x0089, 0x00e5, 0x0090, 0x00e5, 0x008b, 0x00e3, 0x0091, 0x00df, 0x0091, 0x00e0, 0x0090, 0x00e0, 0x008c, 0x00e2, 0x008b, 0x00e1, 0x0085, 0x00e0, 0x0084, 0x00e0, 0x0080, 0x00e1, 0x007f, 0x00e1, 0x007c, 0x00e0, 0x007b, 0x00e0, 0x0077 }; /* game callables */ void Parallaction_ns::_c_null(void *parm) { return; } void Parallaction_ns::_c_play_boogie(void *parm) { static uint16 flag = 1; if (flag == 0) return; flag = 0; _soundManI->setMusicFile("boogie2"); _soundManI->playMusic(); return; } void Parallaction_ns::_c_score(void *parm) { _score += 5; return; } void Parallaction_ns::_c_fade(void *parm) { Palette pal; _gfx->setPalette(pal); for (uint16 _di = 0; _di < 64; _di++) { pal.fadeTo(_gfx->_palette, 1); _gfx->setPalette(pal); _gfx->updateScreen(); _system->delayMillis(20); } return; } void Parallaction_ns::startMovingSarcophagus(ZonePtr sarc) { if (!_moveSarcGetZones[0]) { // bind sarcophagi zones _moveSarcGetZones[0] = _location.findZone("sarc1"); _moveSarcGetZones[1] = _location.findZone("sarc2"); _moveSarcGetZones[2] = _location.findZone("sarc3"); _moveSarcGetZones[3] = _location.findZone("sarc4"); _moveSarcGetZones[4] = _location.findZone("sarc5"); _moveSarcExaZones[0] = _location.findZone("sarc1exa"); _moveSarcExaZones[1] = _location.findZone("sarc2exa"); _moveSarcExaZones[2] = _location.findZone("sarc3exa"); _moveSarcExaZones[3] = _location.findZone("sarc4exa"); _moveSarcExaZones[4] = _location.findZone("sarc5exa"); } /* Each sarcophagus is made of 2 visible zones: one responds to 'get' actions, the other to 'examine'. We need to find out both so they can be moved. */ for (uint16 i = 0; i < 5; i++) { if (_moveSarcGetZones[i] == sarc) { _moveSarcExaZone = _moveSarcExaZones[i]; _moveSarcGetZone = _moveSarcGetZones[i]; } } // calculate destination for the sarcophagus int16 destX = _freeSarcophagusSlotX; _sarcophagusDeltaX = destX - _moveSarcGetZone->getX(); // x movement delta int16 destY = _moveSarcGetZone->getY() - (_sarcophagusDeltaX / 20); // gently degrade y when moving sideways // set the new empty position (maybe this should be done on stopMovingSarcophagus?) _freeSarcophagusSlotX = _moveSarcGetZone->getX(); // calculate which way and how many steps the character should move int16 numSteps = _sarcophagusDeltaX / 2; // default to right int16 delta = 2; // default to right if (_sarcophagusDeltaX < 0) { // move left numSteps = -numSteps; // keep numSteps positive delta = -delta; // make delta negative if moving to left } // GROSS HACK: since there is no obvious way to provide additional parameters to a script, // the game packs the data needed to calculate the position of the 'sposta' animation in // the coordinate fields of the animation itself, which are accessible from the scripts. // In detail: the sarcophagus destination coords are stored into Z and F, while the number // of calculated steps and step length in X and Y. See any of the sarc#.script files in // disk2 for details about unpacking. AnimationPtr a = _location.findAnimation("sposta"); a->forceXYZF(numSteps, delta, destX, destY); // start moving _movingSarcophagus = true; } void Parallaction_ns::stopMovingSarcophagus() { // moves both sarcophagus zones at the destination, so that the user // can interact with them _moveSarcGetZone->translate(_sarcophagusDeltaX, -_sarcophagusDeltaX / 20); _moveSarcExaZone->translate(_sarcophagusDeltaX, -_sarcophagusDeltaX / 20); // check if the puzzle has been completed, by verifying the position of // the sarcophagi if (_moveSarcGetZones[0]->getX() == 35 && _moveSarcGetZones[1]->getX() == 68 && _moveSarcGetZones[2]->getX() == 101 && _moveSarcGetZones[3]->getX() == 134 && _moveSarcGetZones[4]->getX() == 167) { AnimationPtr a = _location.findAnimation("finito"); a->_flags |= (kFlagsActive | kFlagsActing); setLocationFlags(0x20); // GROSS HACK: activates 'finito' flag in dinoit_museo.loc } // stop moving _movingSarcophagus = false; } void Parallaction_ns::_c_moveSarc(void *parm) { if (!_movingSarcophagus) { startMovingSarcophagus(*(ZonePtr *)parm); } else { stopMovingSarcophagus(); } } void Parallaction_ns::_c_contaFoglie(void *parm) { num_foglie++; if (num_foglie != 6) return; g_globalFlags |= 0x1000; return; } void Parallaction_ns::_c_zeroFoglie(void *parm) { num_foglie = 0; return; } void Parallaction_ns::_c_trasformata(void *parm) { g_engineFlags ^= kEngineTransformedDonna; // No need to invoke changeCharacter here, as // transformation happens on a location switch // and character change is automatically triggered. return; } void Parallaction_ns::_c_offMouse(void *parm) { _input->setMouseState(MOUSE_DISABLED); g_engineFlags |= kEngineBlockInput; } void Parallaction_ns::_c_onMouse(void *parm) { g_engineFlags &= ~kEngineBlockInput; _input->setMouseState(MOUSE_ENABLED_SHOW); } void Parallaction_ns::_c_setMask(void *parm) { if (!_gfx->_backgroundInfo->hasMask()) return; memset(_gfx->_backgroundInfo->_mask->data + 3600, 0, 3600); _gfx->_backgroundInfo->layers[1] = 500; return; } void Parallaction_ns::_c_endComment(void *param) { /* NOTE: this routine is only run when the full game is over. The following command in the scripts is QUIT, which causes the engine to exit and return to system. Since this routine is still *blocking*, QUIT is not executed until the user presses a mouse button. If the input is reconciled with the main loop then the command sequence must be suspended to avoid executing QUIT before this actual routine gets a chance to be run. See bug #2619824 for a similar situation. */ showLocationComment(_location._endComment, true); Palette pal(_gfx->_palette); pal.makeGrayscale(); for (uint di = 0; di < 64; di++) { _gfx->_palette.fadeTo(pal, 1); _gfx->setPalette(_gfx->_palette); _gfx->updateScreen(); _system->delayMillis(20); } _input->waitForButtonEvent(kMouseLeftUp); _gfx->freeDialogueObjects(); } void Parallaction_ns::_c_frankenstein(void *parm) { Palette pal0(_gfx->_palette); Palette pal1; for (uint16 i = 0; i < 32; i++) { pal0.setEntry(i, -1, 0, 0); // leaves reds unchanged while zeroing other components } for (uint16 _di = 0; _di < 30; _di++) { _system->delayMillis(20); _gfx->setPalette(pal0); _gfx->updateScreen(); _system->delayMillis(20); _gfx->setPalette(pal1); _gfx->updateScreen(); } _gfx->setPalette(_gfx->_palette); _gfx->updateScreen(); return; } void Parallaction_ns::_c_finito(void *parm) { _saveLoad->setPartComplete(_char.getBaseName()); cleanInventory(); cleanupGame(); _gfx->setPalette(_gfx->_palette); startEndPartSequence(); return; } void Parallaction_ns::_c_ridux(void *parm) { changeCharacter(g_minidinoName); return; } void Parallaction_ns::_c_testResult(void *parm) { if (_inTestResult) { // NOTE: _inTestResult has been added because the scripts call _c_testResult multiple times to cope with // the multiple buffering that was used in the original engine. _inTestResult now prevents the engine // from crashing when the scripts are executed. return; } _inTestResult = true; _gfx->freeLabels(); _gfx->updateScreen(); parseLocation("common"); destroyTestResultLabels(); _testResultLabels[0] = _gfx->createLabel(_menuFont, _location._slideText[0].c_str(), 1); _testResultLabels[1] = _gfx->createLabel(_menuFont, _location._slideText[1].c_str(), 1); _gfx->showLabel(_testResultLabels[0], CENTER_LABEL_HORIZONTAL, 38); _gfx->showLabel(_testResultLabels[1], CENTER_LABEL_HORIZONTAL, 58); return; } void Parallaction_ns::_c_offSound(void *) { _soundManI->stopSfx(0); _soundManI->stopSfx(1); _soundManI->stopSfx(2); _soundManI->stopSfx(3); } void Parallaction_ns::_c_startMusic(void *) { _soundManI->playMusic(); } void Parallaction_ns::_c_closeMusic(void *) { _soundManI->stopMusic(); } /* intro callables */ void Parallaction_ns::_c_startIntro(void *parm) { _rightHandAnim = _location.findAnimation("righthand"); if (getPlatform() == Common::kPlatformDOS) { _soundManI->setMusicFile("intro"); _soundManI->playMusic(); } g_engineFlags |= kEngineBlockInput; _input->setMouseState(MOUSE_DISABLED); _intro = true; } void Parallaction_ns::_c_endIntro(void *parm) { if (getFeatures() & GF_DEMO) { // NOTE: suspend command execution queue, to // avoid running the QUIT command before // credits are displayed. This solves bug // #2619824. // Execution of the command list will resume // as soon as runGameFrame is run. _cmdExec->suspend(); } startCreditSequence(); _intro = false; } void Parallaction_ns::_c_moveSheet(void *parm) { static uint16 x = 319; if (x > 66) x -= 16; Common::Rect r; r.left = x; r.top = 47; r.right = (x + 32 > 319) ? 319 : (x + 32); r.bottom = 199; _gfx->fillBackground(r, 1); if (x >= 104) return; r.left = x+215; r.top = 47; r.right = (x + 247 > 319) ? 319 : (x + 247); r.bottom = 199; _gfx->fillBackground(r, 12); return; } void zeroMask(int x, int y, int color, void *data) { BackgroundInfo *info = (BackgroundInfo *)data; uint16 _ax = x + y * info->_mask->w; info->_mask->data[_ax >> 2] &= ~(3 << ((_ax & 3) << 1)); } void Parallaction_ns::_c_sketch(void *parm) { static uint16 index = 1; uint16 newx; uint16 newy; uint16 oldy = _rightHandPositions[2*(index-1)+1]; uint16 oldx = _rightHandPositions[2*(index-1)]; // WORKAROUND: original code overflowed _rightHandPositions by trying // to access elements at positions 684 and 685. That used to happen // when index == 342. Code now checks for this possibility and assigns // the last valid value to the new coordinates for drawing without // accessing the array. if (index == 342) { newy = oldy; newx = oldx; } else { newy = _rightHandPositions[2*index+1]; newx = _rightHandPositions[2*index]; } if (_gfx->_backgroundInfo->hasMask()) { Graphics::drawLine(oldx, oldy, newx, newy, 0, zeroMask, _gfx->_backgroundInfo); } _rightHandAnim->setX(newx); _rightHandAnim->setY(newy - 20); index++; return; } void Parallaction_ns::_c_shade(void *parm) { Common::Rect r( _rightHandAnim->getX() - 36, _rightHandAnim->getY() - 36, _rightHandAnim->getX(), _rightHandAnim->getY() ); uint16 _di = r.left/4 + r.top * _gfx->_backgroundInfo->_mask->internalWidth; for (uint16 _si = r.top; _si < r.bottom; _si++) { memset(_gfx->_backgroundInfo->_mask->data + _di, 0, r.width()/4+1); _di += _gfx->_backgroundInfo->_mask->internalWidth; } return; } int16 projectorProgram[] = { 0, 50, 1, 50, 2, 49, 3, 49, 4, 48, 5, 48, 6, 47, 7, 47, 8, 46, 9, 46, 10, 45, 11, 45, 12, 44, 13, 44, 14, 43, 15, 43, 16, 42, 17, 42, 18, 41, 19, 41, 20, 40, 21, 40, 22, 39, 23, 39, 24, 38, 25, 38, 26, 37, 27, 37, 28, 36, 29, 36, 30, 35, 31, 35, 32, 34, 33, 34, 34, 33, 35, 33, 36, 32, 37, 32, 38, 31, 39, 31, 40, 30, 41, 30, 42, 29, 43, 29, 44, 28, 45, 28, 46, 27, 47, 27, 48, 26, 49, 26, 50, 25, 51, 25, 52, 24, 53, 24, 54, 23, 55, 23, 56, 22, 57, 22, 58, 21, 59, 21, 60, 20, 61, 20, 62, 19, 63, 19, 64, 18, 65, 18, 66, 17, 67, 17, 68, 16, 69, 16, 70, 15, 71, 15, 72, 14, 73, 14, 74, 13, 75, 13, 76, 12, 77, 12, 78, 11, 79, 11, 80, 10, 81, 10, 82, 9, 83, 9, 84, 8, 85, 8, 86, 7, 87, 7, 88, 6, 89, 6, 90, 5, 91, 5, 92, 4, 93, 4, 94, 3, 95, 3, 96, 2, 97, 2, 98, 1, 99, 1, 100, 0, 101, 0, 102, 1, 103, 1, 104, 2, 105, 2, 106, 3, 107, 3, 108, 4, 109, 4, 110, 5, 111, 5, 112, 6, 113, 6, 114, 7, 115, 7, 116, 8, 117, 8, 118, 9, 119, 9, 120, 10, 121, 10, 122, 11, 123, 11, 124, 12, 125, 12, 126, 13, 127, 13, 128, 14, 129, 14, 130, 15, 131, 15, 132, 16, 133, 16, 134, 17, 135, 17, 136, 18, 137, 18, 138, 19, 139, 19, 140, 20, 141, 20, 142, 21, 143, 21, 144, 22, 145, 22, 146, 23, 147, 23, 148, 24, 149, 24, 150, 25, 149, 25, 148, 25, 147, 25, 146, 25, 145, 25, 144, 25, 143, 25, 142, 25, 141, 25, 140, 25, 139, 25, 138, 25, 137, 25, 136, 25, 135, 25, 134, 25, 133, 25, 132, 25, 131, 25, 130, 25, 129, 25, 128, 25, 127, 25, 126, 25, 125, 25, 124, 25, 123, 25, 122, 25, 121, 25, 120, 25, 119, 25, 118, 25, 117, 25, 116, 25, 115, 25, 114, 25, 113, 25, 112, 25, 111, 25, 110, 25, -1, -1 }; void Parallaction_ns::_c_projector(void *) { _gfx->setHalfbriteMode(true); _gfx->setProjectorProgram(projectorProgram); } void Parallaction_ns::_c_HBOff(void *) { _gfx->setHalfbriteMode(false); } void Parallaction_ns::_c_HBOn(void *) { _gfx->setHalfbriteMode(true); } } // namespace Parallaction