/* 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. * */ #ifndef HOPKINS_LINES_H #define HOPKINS_LINES_H #include "common/scummsys.h" #include "common/str.h" namespace Hopkins { class HopkinsEngine; struct LigneZoneItem { int count; int field2; int16 *zoneData; }; struct LigneItem { int _lineDataEndIdx; int field2; int field4; int field6; int field8; int16 *_lineData; }; struct SmoothItem { int field0; int field2; }; class LinesManager { private: HopkinsEngine *_vm; public: LigneZoneItem _zoneLine[401]; LigneItem Ligne[400]; SmoothItem SMOOTH[4000]; int _linesNumb; int NV_LIGNEDEP; int NV_LIGNEOFS; int NV_POSI; int NVPX; int NVPY; int SMOOTH_SENS; int SMOOTH_X, SMOOTH_Y; public: LinesManager(); void setParent(HopkinsEngine *vm); void clearAllZones(); int checkInventoryHotspots(int posX, int posY); int checkInventoryHotspotsRow(int posX, int minZoneNum, bool lastRow); void removeZoneLine(int idx); void addZoneLine(int idx, int a2, int a3, int a4, int a5, int bobZoneIdx); void resetLines(); void removeLine(int idx); void addLine(int idx, int a2, int a3, int a4, int a5, int a6, int a7); bool checkCollisionLine(int xp, int yp, int *foundDataIdx, int *foundLineIdx, int startLineIdx, int endLineIdx); void initRoute(); int CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6, int a7, int a8, int a9); int CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, int a7); bool MIRACLE(int a1, int a2, int a3, int a4, int a5); int GENIAL(int a1, int a2, int a3, int a4, int a5, int a6, int a7, int16 *a8, int a9); int16 *PARCOURS2(int srcX, int srcY, int destX, int destY); int PARC_PERS(int a1, int a2, int a3, int a4, int a5, int a6, int a7); int VERIF_SMOOTH(int a1, int a2, int a3, int a4); int SMOOTH_MOVE(int a3, int a4, int a5, int a6); bool PLAN_TEST(int paramX, int paramY, int a3, int a4, int a5); int TEST_LIGNE(int paramX, int paramY, int *a3, int *foundLineIdx, int *foundDataIdx); }; } // End of namespace Hopkins #endif /* HOPKINS_FONT_H */