From 2ad2be370e6464a660170ff19a0c74d6fb77e055 Mon Sep 17 00:00:00 2001 From: uruk Date: Fri, 13 Jun 2014 16:31:32 +0200 Subject: CGE2: Implement Hero::tick(). --- engines/cge2/hero.cpp | 57 ++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 56 insertions(+), 1 deletion(-) (limited to 'engines/cge2/hero.cpp') diff --git a/engines/cge2/hero.cpp b/engines/cge2/hero.cpp index 2671d0ea60..a4d0441569 100644 --- a/engines/cge2/hero.cpp +++ b/engines/cge2/hero.cpp @@ -239,7 +239,62 @@ Sprite *Hero::setContact() { } void Hero::tick() { - warning("STUB: Hero::tick()"); + int z = _pos3D._z.trunc(); + //-- maybe not exactly wid/2, but wid/3 ? + int d = ((_siz.x / 2) * _vm->_eye->_z.trunc()) / (_vm->_eye->_z.trunc() - z); + + if (_dir != kNoDir) { // just walking... + if (_flags._hold || _tracePtr < 0) + park(); + else { + Sprite *spr = setContact(); + if (spr) + _vm->feedSnail(spr, kNear, this); + } + } + //--------------------------------------------------------------- + if (_tracePtr >= 0) { + if (distance(_trace[_tracePtr]) <= _maxDist) + --_tracePtr; + + if (_tracePtr < 0) + park(); + else { + int stp = stepSize() / 2; + int dx = _trace[_tracePtr]._x.round() - _pos3D._x.round(); + int dz = _trace[_tracePtr]._z.round() - _pos3D._z.round(); + Dir dir = (dx > stp) ? kEE : ((-dx > stp) ? kWW : ((dz > stp) ? kNN : kSS)); + turn(dir); + } + } + + //--------------------------------------------------------------- + hStep(); + setCurrent(); + switch (_dir) { + case kSS: + if (_pos3D._z < stepSize() / 2) + park(); + break; + case kWW: + if (_pos2D.x <= d) + park(); + break; + case kNN: + if (_pos3D._z > kScrDepth) + park(); + break; + case kEE: + if (_pos2D.x >= kScrWidth - 1 - d) + park(); + break; + } + if (_flags._trim) + gotoxyz_(_pos2D); + if (_pos3D._z.trunc() != z) + _flags._zmov = true; + if (--_funDel == 0) + fun(); } int Hero::distance(V3D pos) { -- cgit v1.2.3