aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--queen/cutaway.cpp81
-rw-r--r--queen/cutaway.h9
-rw-r--r--queen/graphics.cpp5
-rw-r--r--queen/graphics.h3
4 files changed, 96 insertions, 2 deletions
diff --git a/queen/cutaway.cpp b/queen/cutaway.cpp
index 3929c6ab5b..19b4d52cd0 100644
--- a/queen/cutaway.cpp
+++ b/queen/cutaway.cpp
@@ -632,6 +632,8 @@ byte *Cutaway::handleAnimation(byte *ptr, CutawayObject &object) {
if (object.animType == 1) {
// lines 1615-1636 in cutaway.c
+
+ debug(0, "----- Not normal cutaway animation (animType = %i) -----", object.animType);
if (/*(P_BNUM==1) &&*/ (_logic->currentRoom() == 47 || _logic->currentRoom() == 63)) {
// The oracle
@@ -678,6 +680,9 @@ byte *Cutaway::handleAnimation(byte *ptr, CutawayObject &object) {
if (object.animType != 1) {
// lines 1657-1761 in cutaway.c
+
+ debug(0, "----- Normal cutaway animation (animType = %i) -----", object.animType);
+
for (i = 0; i < frameCount; i++) {
BobSlot *bob = _graphics->bob(objAnim[i].object);
bob->active = true;
@@ -911,6 +916,12 @@ void Cutaway::run(char *nextFilename) {
// Do nothing?
break;
+ case OBJECT_TYPE_TEXT_SPEAK:
+ case OBJECT_TYPE_TEXT_DISPLAY_AND_SPEAK:
+ case OBJECT_TYPE_TEXT_DISPLAY:
+ handleText(objectType, object, sentence);
+ break;
+
default:
warning("Unhandled object type: %i", objectType);
break;
@@ -1182,7 +1193,6 @@ void Cutaway::talk(char *nextFilename) {
// Lines 2119-2131 in cutaway.c
if (0 == scumm_stricmp(right(_talkFile, 4), ".dog")) {
- warning("Cutaway::talk() used but not fully implemented");
nextFilename[0] = '\0';
Talk::talk(_talkFile, 0 /* XXX */, nextFilename, _graphics, _logic, _resource);
@@ -1228,4 +1238,73 @@ int Cutaway::makeComplexAnimation(int16 currentImage, Cutaway::CutawayAnim *objA
return currentImage + 1;
}
+void Cutaway::handleText(
+ ObjectType type,
+ CutawayObject &object,
+ const char *sentence) {
+ // lines 1776-1863 in cutaway.c
+
+ debug(0, "----- Write '%s' ----", sentence);
+
+ int spaces = countSpaces(type, sentence);
+
+ int x;
+ int flags;
+
+ if (OBJECT_TYPE_TEXT_DISPLAY == type) {
+ x = _graphics->textCenterX(sentence);
+ flags = 2;
+ }
+ else {
+ x = object.moveToX;
+ flags = 1;
+ }
+
+ BobSlot *bob =
+ _graphics->bob( _logic->findBob(abs(object.objectNumber)) );
+
+ _graphics->bobSetText(bob, sentence, x, object.moveToY, object.specialMove, flags);
+
+ if (OBJECT_TYPE_TEXT_SPEAK == type || OBJECT_TYPE_TEXT_DISPLAY_AND_SPEAK == type) {
+ // XXX: speak
+ }
+
+ int i;
+ for (i = 0; i < spaces; i++) {
+ _graphics->update();
+
+ if (OBJECT_TYPE_TEXT_SPEAK == type || OBJECT_TYPE_TEXT_DISPLAY_AND_SPEAK == type) {
+ // XXX: see if speaking is finished
+ }
+
+ if (_quit)
+ break;
+
+// XXX if(KEYVERB==101) {
+// XXX KEYVERB=0;
+// XXX break;
+// XXX }
+
+ }
+
+ _graphics->textClear(0,198);
+ _graphics->update();
+}
+
+int Cutaway::countSpaces(ObjectType type, const char *segment) {
+ int tmp = 0;
+
+ while (*segment++)
+ tmp++;
+
+ if (tmp < 10)
+ tmp = 10;
+
+ if (OBJECT_TYPE_TEXT_DISPLAY == type)
+ tmp *= 3;
+
+ return (tmp * 2) / _logic->talkSpeed();
+
+}
+
} // End of namespace Queen
diff --git a/queen/cutaway.h b/queen/cutaway.h
index 3782736be4..1155b6cde4 100644
--- a/queen/cutaway.h
+++ b/queen/cutaway.h
@@ -242,6 +242,12 @@ class Cutaway {
int index,
CutawayObject &object,
const char *sentence);
+
+ //! Perform text actions
+ void handleText(
+ ObjectType type,
+ CutawayObject &object,
+ const char *sentence);
//! Restore QueenLogic::_objectData from _personData
void restorePersonData();
@@ -270,6 +276,9 @@ class Cutaway {
//! Dump a CutawayObject with debug()
void dumpCutawayObject(int index, CutawayObject &object);
+ //! Used by handleText()
+ int countSpaces(ObjectType type, const char *segment);
+
//! Dump CutawayAnum data with debug()
static void dumpCutawayAnim(CutawayAnim &anim);
diff --git a/queen/graphics.cpp b/queen/graphics.cpp
index fb9d8d0288..2d433d3480 100644
--- a/queen/graphics.cpp
+++ b/queen/graphics.cpp
@@ -909,5 +909,10 @@ void Graphics::bobSetText(
textSet(lineX, y + 9 * i, lines[i]);
}
}
+
+int Graphics::textCenterX(const char *text) const {
+ return 160 - textWidth(text) / 2;
+}
+
} // End of namespace Queen
diff --git a/queen/graphics.h b/queen/graphics.h
index 6fe656e3cc..b92685485d 100644
--- a/queen/graphics.h
+++ b/queen/graphics.h
@@ -148,7 +148,8 @@ public:
void textSetCentered(uint16 y, const char *text, bool outlined = true);
void textDrawAll(); // drawtext()
void textClear(uint16 y1, uint16 y2); // blanktexts()
- uint16 textWidth(const char* text) const; // textlen()
+ uint16 textWidth(const char *text) const; // textlen()
+ int textCenterX(const char *text) const; // MIDDLE()
void frameErase(uint32 fslot);
void frameEraseAll(bool joe); // freeframes, freeallframes