This commit is contained in:
Paul 2001-05-08 22:09:00 +00:00
parent 666126b5e5
commit 0169a618eb
5 changed files with 94 additions and 29 deletions

View File

@ -46,8 +46,18 @@
#include "level\level.h" #include "level\level.h"
#endif #endif
#ifndef __SOUND_SOUND_H__
#include "sound\sound.h" #include "sound\sound.h"
#endif
#ifndef __SPEECH_DEFINES_H__
#include "sound\speech.h" #include "sound\speech.h"
#endif
#ifndef __LOCALE_TEXTDBASE_H__
#include "locale\textdbase.h"
#endif
/* Std Lib /* Std Lib
------- */ ------- */
@ -233,13 +243,16 @@ int CConversation::s_numRegisteredScripts=0;
class CScript *CConversation::s_currentScript=NULL; class CScript *CConversation::s_currentScript=NULL;
int CConversation::s_currentState=STATE_INACTIVE; int CConversation::s_currentState=STATE_INACTIVE;
int CConversation::s_currentQuestion=QUESTION_NONE; int CConversation::s_currentQuestion;
int CConversation::s_currentAnswer=ANSWER_NONE; int CConversation::s_currentAnswer;
int CConversation::s_currentSelectedAnswer=0; int CConversation::s_currentSelectedAnswer;
static int s_faceFrame=-1; int CConversation::s_faceFrame;
static int s_speechId=-1; int CConversation::s_speechId;
static int s_TextOffset=0; int CConversation::s_textOffset;
int CConversation::s_maxTextOffset;
static xmPlayingId s_playingSfxId;
/*---------------------------------------------------------------------- /*----------------------------------------------------------------------
@ -255,7 +268,7 @@ void CConversation::init()
s_textFontBank=new ("Conversation Font") FontBank(); s_textFontBank=new ("Conversation Font") FontBank();
s_textFontBank->initialise(&standardFont); s_textFontBank->initialise(&standardFont);
s_textFontBank->setOt(0); s_textFontBank->setOt(0);
s_textFontBank->setPrintArea(125,140,357,60); s_textFontBank->setPrintArea(TEXTBOX_X,TEXTBOX_Y,TEXTBOX_WIDTH,TEXTBOX_HEIGHT);
s_questionFontBank=new ("Conversation Font") FontBank(); s_questionFontBank=new ("Conversation Font") FontBank();
s_questionFontBank->initialise(&standardFont); s_questionFontBank->initialise(&standardFont);
@ -309,6 +322,12 @@ void CConversation::think(int _frames)
s_currentScript=NULL; s_currentScript=NULL;
s_currentState=STATE_INACTIVE; s_currentState=STATE_INACTIVE;
CSoundMediator::stopSpeech(); CSoundMediator::stopSpeech();
if(s_playingSfxId!=NOT_PLAYING)
{
CSoundMediator::stopAndUnlockSfx(s_playingSfxId);
s_playingSfxId=NOT_PLAYING;
}
s_playingSfxId=CSoundMediator::playSfx(CSoundMediator::SFX_FRONT_END__OK);
} }
} }
} }
@ -326,7 +345,7 @@ void CConversation::render()
{ {
renderText(); renderText();
renderQuestion(); renderQuestion();
drawSpeechBubbleBorder(125,140,357,80,0,s_faceFrame); drawSpeechBubbleBorder(TEXTBOX_X,TEXTBOX_Y,TEXTBOX_WIDTH,TEXTBOX_HEIGHT+TEXTBOX_QUESTIONHEIGHT,0,s_faceFrame);
} }
} }
@ -361,6 +380,8 @@ void CConversation::trigger(FileEquate _feScript)
ASSERT(!isActive()); ASSERT(!isActive());
s_playingSfxId=NOT_PLAYING;
// Is this script already registered? // Is this script already registered?
for(i=0;i<s_numRegisteredScripts;i++) for(i=0;i<s_numRegisteredScripts;i++)
{ {
@ -400,7 +421,9 @@ void CConversation::setCharacterAndText(int _characterId,int _textId)
{ {
s_faceFrame=(s_characterIconFrames[_characterId].m_frame); s_faceFrame=(s_characterIconFrames[_characterId].m_frame);
s_speechId=_textId; s_speechId=_textId;
s_TextOffset=0; s_textOffset=0;
s_maxTextOffset=s_textFontBank->getStringHeight((char*)TranslationDatabase::getString(s_speechId))-TEXTBOX_HEIGHT;
if(s_maxTextOffset<0)s_maxTextOffset=0;
for (int i=0; i<SpeechTableSize; i++) for (int i=0; i<SpeechTableSize; i++)
{ {
@ -447,17 +470,48 @@ int CConversation::getResponse()
---------------------------------------------------------------------- */ ---------------------------------------------------------------------- */
void CConversation::thinkText() void CConversation::thinkText()
{ {
int sfx=-1;
if(PadGetRepeat(0)&PAD_DOWN) if(PadGetRepeat(0)&PAD_DOWN)
{ {
s_TextOffset-=s_textFontBank->getCharHeight(); if(s_textOffset<s_maxTextOffset)
{
s_textOffset+=TEXT_STEP_SIZE;
if(s_textOffset>s_maxTextOffset)
{
s_textOffset=s_maxTextOffset;
}
sfx=CSoundMediator::SFX_FRONT_END__MOVE_CURSOR;
}
else
{
sfx=CSoundMediator::SFX_FRONT_END__ERROR;
}
} }
else if(PadGetRepeat(0)&PAD_UP) else if(PadGetRepeat(0)&PAD_UP)
{ {
s_TextOffset+=s_textFontBank->getCharHeight(); if(s_textOffset>0)
if(s_TextOffset>0)
{ {
s_TextOffset=0; s_textOffset-=TEXT_STEP_SIZE;
if(s_textOffset<0)
{
s_textOffset=0;
} }
sfx=CSoundMediator::SFX_FRONT_END__MOVE_CURSOR;
}
else
{
sfx=CSoundMediator::SFX_FRONT_END__ERROR;
}
}
if(sfx!=-1)
{
if(s_playingSfxId!=NOT_PLAYING)
{
CSoundMediator::stopAndUnlockSfx(s_playingSfxId);
}
s_playingSfxId=CSoundMediator::playSfx((CSoundMediator::SFXID)sfx,true);
} }
} }
@ -506,10 +560,10 @@ void CConversation::thinkQuestion()
---------------------------------------------------------------------- */ ---------------------------------------------------------------------- */
void CConversation::renderText() void CConversation::renderText()
{ {
RECT clipTextRegion={125,140,357,60}; RECT clipTextRegion={TEXTBOX_X,TEXTBOX_Y,TEXTBOX_WIDTH,TEXTBOX_HEIGHT};
PrimFullScreen(0); PrimFullScreen(0);
s_textFontBank->print(0,s_TextOffset,s_speechId); s_textFontBank->print(0,-s_textOffset,s_speechId);
PrimClip(&clipTextRegion,0); PrimClip(&clipTextRegion,0);
} }
@ -520,12 +574,12 @@ void CConversation::renderText()
Params: Params:
Returns: Returns:
---------------------------------------------------------------------- */ ---------------------------------------------------------------------- */
//drawSpeechBubbleBorder(TEXTBOX_X,TEXTBOX_Y,TEXTBOX_WIDTH,TEXTBOX_HEIGHT+TEXTBOX_QUESTIONHEIGHT,0,s_faceFrame);
void CConversation::renderQuestion() void CConversation::renderQuestion()
{ {
int xbase,y; int y;
xbase=(512-FRAME_WIDTH)/2; y=TEXTBOX_Y+TEXTBOX_HEIGHT+TEXTBOX_QUESTIONHEIGHT-s_questionFontBank->getCharHeight();
y=256-FRAME_BOTTOM_OFFSET-(TEXT_BORDER/2)-(s_questionFontBank->getCharHeight()/2);
switch(s_currentQuestion) switch(s_currentQuestion)
{ {
@ -533,7 +587,7 @@ void CConversation::renderQuestion()
{ {
s_questionFontBank->setColour(SELECT_TEXT_R,SELECT_TEXT_G,SELECT_TEXT_B); s_questionFontBank->setColour(SELECT_TEXT_R,SELECT_TEXT_G,SELECT_TEXT_B);
s_questionFontBank->setJustification(FontBank::JUST_RIGHT); s_questionFontBank->setJustification(FontBank::JUST_RIGHT);
s_questionFontBank->print(xbase+FRAME_WIDTH-TEXT_BORDER,y,STR__OK); s_questionFontBank->print(TEXTBOX_X+TEXTBOX_WIDTH,y,STR__OK);
} }
break; break;
@ -548,7 +602,7 @@ void CConversation::renderQuestion()
s_questionFontBank->setColour(UNSELECT_TEXT_R,UNSELECT_TEXT_G,UNSELECT_TEXT_B); s_questionFontBank->setColour(UNSELECT_TEXT_R,UNSELECT_TEXT_G,UNSELECT_TEXT_B);
} }
s_questionFontBank->setJustification(FontBank::JUST_LEFT); s_questionFontBank->setJustification(FontBank::JUST_LEFT);
s_questionFontBank->print(xbase+FRAME_HEIGHT,y,STR__YES); s_questionFontBank->print(TEXTBOX_X+TEXTBOX_WIDTH,y,STR__YES);
if(s_currentSelectedAnswer==1) if(s_currentSelectedAnswer==1)
{ {
@ -559,7 +613,7 @@ void CConversation::renderQuestion()
s_questionFontBank->setColour(UNSELECT_TEXT_R,UNSELECT_TEXT_G,UNSELECT_TEXT_B); s_questionFontBank->setColour(UNSELECT_TEXT_R,UNSELECT_TEXT_G,UNSELECT_TEXT_B);
} }
s_questionFontBank->setJustification(FontBank::JUST_RIGHT); s_questionFontBank->setJustification(FontBank::JUST_RIGHT);
s_questionFontBank->print(xbase+FRAME_WIDTH-TEXT_BORDER,y,STR__NO); s_questionFontBank->print(TEXTBOX_X,y,STR__NO);
} }
break; break;

View File

@ -56,10 +56,13 @@ public:
private: private:
enum enum
{ {
FRAME_WIDTH=400,
FRAME_HEIGHT=90, TEXTBOX_X=125,
FRAME_BOTTOM_OFFSET=40, TEXTBOX_Y=140,
TEXT_BORDER=20, TEXTBOX_WIDTH=357,
TEXTBOX_HEIGHT=50,
TEXTBOX_QUESTIONHEIGHT=16,
TEXT_STEP_SIZE=5,
OT_POS=0, OT_POS=0,
SELECT_TEXT_R=250, SELECT_TEXT_R=250,
SELECT_TEXT_G=250, SELECT_TEXT_G=250,
@ -142,6 +145,12 @@ private:
static int s_currentQuestion; static int s_currentQuestion;
static int s_currentAnswer; static int s_currentAnswer;
static int s_currentSelectedAnswer; static int s_currentSelectedAnswer;
static int s_faceFrame;
static int s_speechId;
static int s_textOffset;
static int s_maxTextOffset;
}; };

View File

@ -596,7 +596,7 @@ void CSoundMediator::setposition(xmPlayingId _playingId,VECTOR *pos)
Params: Params:
Returns: Returns:
---------------------------------------------------------------------- */ ---------------------------------------------------------------------- */
void CSoundMediator::stopSfx(xmPlayingId _playingId) void CSoundMediator::stopAndUnlockSfx(xmPlayingId _playingId)
{ {
s_xmplaySound->stopPlayingId(_playingId); s_xmplaySound->stopPlayingId(_playingId);
s_xmplaySound->unlockPlayingId(_playingId); s_xmplaySound->unlockPlayingId(_playingId);

View File

@ -187,7 +187,7 @@ public:
static void setSfxBank(SFXBANKID _bankId); static void setSfxBank(SFXBANKID _bankId);
static xmPlayingId playSfx(SFXID _sfxId,int _lock=false); static xmPlayingId playSfx(SFXID _sfxId,int _lock=false);
static void setposition(xmPlayingId _playingId,VECTOR *pos); static void setposition(xmPlayingId _playingId,VECTOR *pos);
static void stopSfx(xmPlayingId _playingId); static void stopAndUnlockSfx(xmPlayingId _playingId);
static void stopAllSfx(); static void stopAllSfx();
// Speech interface // Speech interface

View File

@ -697,6 +697,8 @@ void CXMPlaySound::stopPlayingId(xmPlayingId _playingId)
break; break;
case SILENT: case SILENT:
break;
case FREE: case FREE:
case CONTINUE: case CONTINUE:
ASSERT(0); ASSERT(0);