diff options
author | Julien Templier | 2010-10-18 20:39:54 +0000 |
---|---|---|
committer | Julien Templier | 2010-10-18 20:39:54 +0000 |
commit | 6a67bfd85d33e0cf87267ab56e286bafc96ece27 (patch) | |
tree | 78d19e12626820f7c4402862f60635fe33d18738 /engines/lastexpress/entities/august.cpp | |
parent | f7645fea4504450370a81da4ea4d9248660860c9 (diff) | |
download | scummvm-rg350-6a67bfd85d33e0cf87267ab56e286bafc96ece27.tar.gz scummvm-rg350-6a67bfd85d33e0cf87267ab56e286bafc96ece27.tar.bz2 scummvm-rg350-6a67bfd85d33e0cf87267ab56e286bafc96ece27.zip |
LASTEXPRESS: Implement 3 more AI logic functions
svn-id: r53587
Diffstat (limited to 'engines/lastexpress/entities/august.cpp')
-rw-r--r-- | engines/lastexpress/entities/august.cpp | 111 |
1 files changed, 110 insertions, 1 deletions
diff --git a/engines/lastexpress/entities/august.cpp b/engines/lastexpress/entities/august.cpp index 419d716ced..8b0481f00f 100644 --- a/engines/lastexpress/entities/august.cpp +++ b/engines/lastexpress/entities/august.cpp @@ -2760,7 +2760,116 @@ IMPLEMENT_FUNCTION(67, August, chapter5Handler) ////////////////////////////////////////////////////////////////////////// IMPLEMENT_FUNCTION(68, August, function68) - error("August: callback function 68 not implemented!"); + switch (savepoint.action) { + default: + break; + + case kActionNone: + if (params->param1) { + UPDATE_PARAM(params->param4, getState()->timeTicks, 75); + + params->param1 = 0; + params->param2 = 1; + + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorNormal, kCursorNormal); + } + + params->param4 = 0; + break; + + case kActionKnock: + case kActionOpenDoor: + if (params->param1) { + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorNormal, kCursorNormal); + + setCallback(1); + setup_playSound(getSound()->justCheckingCath()); + } else { + setCallback(savepoint.action == kActionKnock ? 2 : 3); + setup_playSound(savepoint.action == kActionKnock ? "LIB012" : "LIB013"); + } + break; + + case kActionDefault: + getData()->entityPosition = kPosition_6470; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorHandKnock, kCursorHand); + break; + + case kActionDrawScene: + if (params->param1 || params->param2) { + params->param1 = 0; + params->param2 = 0; + params->param3 = 0; + + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorHandKnock, kCursorHand); + } + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + params->param1 = 0; + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorHandKnock, kCursorHand); + break; + + case 2: + case 3: + ++params->param3; + + switch (params->param3) { + default: + break; + + case 1: + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorNormal, kCursorNormal); + + setCallback(4); + setup_playSound("Aug5002"); + break; + + case 2: + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorNormal, kCursorNormal); + + setCallback(5); + setup_playSound("Aug5002A"); + break; + + case 3: + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorNormal, kCursorNormal); + + setCallback(6); + setup_playSound("Aug5002B"); + break; + } + break; + + case 4: + params->param1 = 1; + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorTalk, kCursorNormal); + break; + + case 5: + getObjects()->update(kObjectCompartment3, kEntityAugust, kObjectLocation1, kCursorHandKnock, kCursorHand); + break; + + case 6: + params->param2 = 1; + break; + } + break; + + case kAction203078272: + getSavePoints()->push(kEntityAugust, kEntityTatiana, kAction203078272); + + setup_unhookCars(); + break; + } } ////////////////////////////////////////////////////////////////////////// |