FULLPIPE: Implement sceneHandler22_fromStool()

This commit is contained in:
Eugene Sandulenko 2014-01-02 22:56:24 +02:00
parent 9ee4cf899b
commit fdad3971e5
2 changed files with 13 additions and 4 deletions

View File

@ -755,6 +755,7 @@ namespace Fullpipe {
#define QU_SC22_FALLBROOM 1786
#define QU_SC22_FALLSACK 1791
#define QU_SC22_FALLSACK_GMA 2613
#define QU_SC22_FROMSTOOL 1800
#define QU_SC22_SHOWSTOOL 1793
#define QU_MSH_MOVE 1812
#define ST_GRFM_AFTER 3472

View File

@ -153,15 +153,20 @@ void sceneHandler22_handleDown() {
g_fp->_behaviorManager->setBehaviorEnabled(g_vars->scene22_bag, ST_MSH_SIT, QU_MSH_MOVE, 0);
}
void sceneHandler22_sub01(ExCommand *cmd) {
warning("STUB: sceneHandler22_sub01(cmd)");
void sceneHandler22_fromStool(ExCommand *cmd) {
if (g_fp->_aniMan->isIdle() && !(g_fp->_aniMan->_flags & 0x100)) {
MessageQueue *mq = new MessageQueue(g_fp->_currentScene->getMessageQueueById(QU_SC22_FROMSTOOL), 0, 0);
mq->addExCommandToEnd(new ExCommand(cmd));
mq->setFlags(mq->getFlags() | 1);
mq->chain(0);
}
}
void sceneHandler22_sub02(ExCommand *cmd) {
warning("STUB: sceneHandler22_sub02(cmd)");
}
int sceneHandler22(ExCommand *cmd) {
if (cmd->_messageKind != 17)
return 0;
@ -206,10 +211,12 @@ int sceneHandler22(ExCommand *cmd) {
case 29:
if (!g_vars->scene22_var08) {
StaticANIObject *ani = g_fp->_currentScene->getStaticANIObjectAtPos(cmd->_sceneClickX, cmd->_sceneClickY);
if (ani && ani->_id == ANI_HANDLE_L) {
sceneHandler22_sub02(cmd);
return 0;
}
if (!g_vars->scene22_var07) {
if (!ani || !canInteractAny(g_fp->_aniMan, ani, cmd->_keyCode)) {
int picId = g_fp->_currentScene->getPictureObjectIdAtPos(cmd->_sceneClickX, cmd->_sceneClickY);
@ -225,8 +232,9 @@ int sceneHandler22(ExCommand *cmd) {
}
return 0;
}
if (g_fp->_aniMan->_statics->_staticsId == ST_MAN_RIGHT && !g_fp->_aniMan->_movement) {
sceneHandler22_sub01(cmd);
sceneHandler22_fromStool(cmd);
return 0;
}