scummvm/engines/fullpipe/motion.cpp

322 lines
7.1 KiB
C++
Raw Normal View History

/* 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 "fullpipe/fullpipe.h"
#include "common/file.h"
#include "common/array.h"
#include "common/list.h"
#include "fullpipe/objects.h"
#include "fullpipe/motion.h"
#include "fullpipe/messages.h"
2013-09-18 22:30:06 +04:00
#include "fullpipe/gameloader.h"
namespace Fullpipe {
bool MotionController::load(MfcArchive &file) {
// Is originally empty file.readClass();
debug(5, "MotionController::load()");
return true;
}
bool MctlCompound::load(MfcArchive &file) {
debug(5, "MctlCompound::load()");
int count = file.readUint32LE();
debug(6, "MctlCompound::count = %d", count);
for (int i = 0; i < count; i++) {
2013-07-06 22:56:11 +03:00
debug(6, "CompoundArray[%d]", i);
MctlCompoundArrayItem *obj = (MctlCompoundArrayItem *)file.readClass();
2013-07-06 22:56:11 +03:00
int count1 = file.readUint32LE();
2013-06-18 17:07:28 -04:00
2013-07-06 22:56:11 +03:00
debug(6, "ConnectionPoint::count: %d", count1);
for (int j = 0; j < count1; j++) {
debug(6, "ConnectionPoint[%d]", j);
MctlConnectionPoint *obj1 = (MctlConnectionPoint *)file.readClass();
2013-06-18 17:07:28 -04:00
2013-07-06 22:56:11 +03:00
obj->_connectionPoints.push_back(*obj1);
}
2013-06-18 17:07:28 -04:00
2013-07-06 22:56:11 +03:00
obj->_field_20 = file.readUint32LE();
obj->_field_24 = file.readUint32LE();
2013-06-18 17:07:28 -04:00
2013-07-06 22:56:11 +03:00
debug(6, "graphReact");
obj->_movGraphReactObj = (MovGraphReact *)file.readClass();
2013-06-18 17:07:28 -04:00
2013-07-06 22:56:11 +03:00
_motionControllers.push_back(*obj);
}
return true;
}
2013-09-24 23:24:33 +03:00
int MctlCompound::addObject(StaticANIObject *obj) {
warning("STUB: MctlCompound::addObject()");
2013-09-24 23:24:33 +03:00
return 0;
}
int MctlCompound::removeObject(StaticANIObject *obj) {
warning("STUB: MctlCompound::removeObject()");
return 0;
}
void MctlCompound::initMovGraph2() {
warning("STUB: MctlCompound::initMovGraph2()");
}
2013-09-24 23:24:33 +03:00
void MctlCompound::freeItems() {
warning("STUB: MctlCompound::freeItems()");
}
MessageQueue *MctlCompound::method34(StaticANIObject *subj, int xpos, int ypos, int flag, int staticsId) {
warning("STUB: MctlCompound::method34()");
return 0;
}
MessageQueue *MctlCompound::method4C(StaticANIObject *subj, int xpos, int ypos, int flag, int staticsId) {
warning("STUB: MctlCompound::method4C()");
return 0;
}
bool MctlCompoundArray::load(MfcArchive &file) {
debug(5, "MctlCompoundArray::load()");
int count = file.readUint32LE();
debug(0, "MctlCompoundArray::count = %d", count);
assert(0);
return true;
}
int MovGraph_messageHandler(ExCommand *cmd);
int MovGraphCallback(int a1, int a2, int a3) {
warning("STUB: MovgraphCallback");
return 0;
}
MovGraph::MovGraph() {
2013-07-06 22:56:11 +03:00
_itemsCount = 0;
_items = 0;
_callback1 = MovGraphCallback;
2013-07-06 22:56:11 +03:00
_field_44 = 0;
insertMessageHandler(MovGraph_messageHandler, getMessageHandlersCount() - 1, 129);
_objtype = kObjTypeMovGraph;
}
bool MovGraph::load(MfcArchive &file) {
debug(5, "MovGraph::load()");
2013-07-06 22:56:11 +03:00
_links.load(file);
_nodes.load(file);
2013-07-06 22:56:11 +03:00
return true;
}
2013-09-24 23:24:33 +03:00
int MovGraph::addObject(StaticANIObject *obj) {
warning("STUB: MovGraph::addObject()");
2013-09-24 23:24:33 +03:00
return 0;
}
double MovGraph::calcDistance(Common::Point *point, MovGraphLink *link, int flag) {
warning("STUB: MovGraph::calcDistance()");
return 0;
}
MovGraphNode *MovGraph::calcOffset(int ox, int oy) {
warning("STUB: MovGraph::calcOffset()");
return 0;
}
MovGraphLink::MovGraphLink() {
2013-07-06 22:56:11 +03:00
_distance = 0;
_angle = 0;
_flags = 0x10000000;
_movGraphNode2 = 0;
_movGraphNode1 = 0;
_field_3C = 0;
_field_38 = 0;
_movGraphReact = 0;
2013-08-14 21:11:12 +03:00
_name = 0;
2013-06-16 16:10:46 +03:00
}
bool MovGraphLink::load(MfcArchive &file) {
debug(5, "MovGraphLink::load()");
2013-07-06 22:56:11 +03:00
_dwordArray1.load(file);
_dwordArray2.load(file);
2013-06-16 16:10:46 +03:00
2013-07-06 22:56:11 +03:00
_flags = file.readUint32LE();
2013-06-16 16:10:46 +03:00
2013-07-06 22:56:11 +03:00
debug(8, "GraphNode1");
_movGraphNode1 = (MovGraphNode *)file.readClass();
2013-07-06 22:56:11 +03:00
debug(8, "GraphNode2");
_movGraphNode2 = (MovGraphNode *)file.readClass();
2013-06-16 16:10:46 +03:00
2013-07-06 22:56:11 +03:00
_distance = file.readDouble();
_angle = file.readDouble();
2013-06-16 16:10:46 +03:00
2013-07-06 22:56:11 +03:00
debug(8, "distance: %g, angle: %g", _distance, _angle);
2013-06-16 16:10:46 +03:00
_movGraphReact = (MovGraphReact *)file.readClass();
2013-07-06 22:56:11 +03:00
_name = file.readPascalString();
2013-06-16 16:10:46 +03:00
2013-07-06 22:56:11 +03:00
return true;
2013-06-16 16:10:46 +03:00
}
bool MovGraphNode::load(MfcArchive &file) {
debug(5, "MovGraphNode::load()");
2013-07-06 22:56:11 +03:00
_field_14 = file.readUint32LE();
_x = file.readUint32LE();
_y = file.readUint32LE();
_distance = file.readUint32LE();
2013-06-16 16:10:46 +03:00
2013-07-06 22:56:11 +03:00
return true;
2013-06-16 16:10:46 +03:00
}
ReactParallel::ReactParallel() {
2013-07-06 22:56:11 +03:00
_x1 = 0;
_x2 = 0;
_dy = 0;
_dx = 0;
_points = 0;
_y1 = 0;
_y2 = 0;
}
bool ReactParallel::load(MfcArchive &file) {
debug(5, "ReactParallel::load()");
2013-07-06 22:56:11 +03:00
_x1 = file.readUint32LE();
_y1 = file.readUint32LE();
_x2 = file.readUint32LE();
_y2 = file.readUint32LE();
_dx = file.readUint32LE();
_dy = file.readUint32LE();
2013-07-06 22:56:11 +03:00
createRegion();
2013-07-06 22:56:11 +03:00
return true;
}
void ReactParallel::createRegion() {
2013-07-06 22:56:11 +03:00
_points = (Common::Point **)malloc(sizeof(Common::Point *) * 4);
for (int i = 0; i < 4; i++)
_points[i] = new Common::Point;
double at = atan2((double)(_x1 - _x2), (double)(_y1 - _y2)) + 1.570796;
2013-07-06 22:56:11 +03:00
double sn = sin(at);
double cs = cos(at);
2013-07-06 22:56:11 +03:00
_points[0]->x = (int16)(_x1 - _dx * cs);
_points[0]->y = (int16)(_y1 - _dx * sn);
2013-07-06 22:56:11 +03:00
_points[1]->x = (int16)(_x2 - _dx * cs);
_points[1]->y = (int16)(_y2 - _dx * sn);
2013-07-06 22:56:11 +03:00
_points[2]->x = (int16)(_x1 + _dy * cs);
_points[2]->y = (int16)(_y2 + _dy * sn);
2013-07-06 22:56:11 +03:00
_points[3]->x = (int16)(_x1 + _dy * cs);
_points[3]->y = (int16)(_y1 + _dy * sn);
2013-07-06 22:56:11 +03:00
// GdiObject::Attach(_rgn, CreatePolygonRgn(_points, 4, 2);
}
ReactPolygonal::ReactPolygonal() {
2013-07-06 22:56:11 +03:00
_field_C = 0;
_points = 0;
_pointCount = 0;
_field_10 = 0;
}
bool ReactPolygonal::load(MfcArchive &file) {
debug(5, "ReactPolygonal::load()");
2013-07-06 22:56:11 +03:00
_field_C = file.readUint32LE();
_field_10 = file.readUint32LE();
_pointCount = file.readUint32LE();
2013-07-06 22:56:11 +03:00
if (_pointCount > 0) {
_points = (Common::Point **)malloc(sizeof(Common::Point *) * _pointCount);
2013-07-06 22:56:11 +03:00
for (int i = 0; i < _pointCount; i++) {
_points[i] = new Common::Point;
2013-07-06 22:56:11 +03:00
_points[i]->x = file.readUint32LE();
_points[i]->y = file.readUint32LE();
}
2013-07-06 22:56:11 +03:00
}
2013-07-06 22:56:11 +03:00
createRegion();
2013-07-06 22:56:11 +03:00
return true;
}
void ReactPolygonal::createRegion() {
2013-07-06 22:56:11 +03:00
if (_points) {
2013-07-06 22:56:11 +03:00
// GdiObject::Attach(_rgn, CreatePolygonRgn(_points, _pointCount, 2);
}
}
int startWalkTo(int objId, int objKey, int x, int y, int a5) {
2013-09-18 22:30:06 +04:00
MctlCompound *mc = getSc2MctlCompoundBySceneId(g_fullpipe->_currentScene->_sceneId);
if (mc)
return (mc->method34(g_fullpipe->_currentScene->getStaticANIObject1ById(objId, objKey), x, y, a5, 0) != 0);
return 0;
}
int doSomeAnimation(int objId, int objKey, int a3) {
warning("STUB: doSomeAnimation(%d, %d, %d)", objId, objKey, a3);
return 0;
}
int doSomeAnimation2(int objId, int objKey) {
return doSomeAnimation(objId, objKey, 0);
}
} // End of namespace Fullpipe