aboutsummaryrefslogtreecommitdiff
path: root/engines/titanic/pet_control
diff options
context:
space:
mode:
Diffstat (limited to 'engines/titanic/pet_control')
-rw-r--r--engines/titanic/pet_control/pet_control.cpp21
-rw-r--r--engines/titanic/pet_control/pet_control.h14
-rw-r--r--engines/titanic/pet_control/pet_frame.cpp2
-rw-r--r--engines/titanic/pet_control/pet_section.h2
-rw-r--r--engines/titanic/pet_control/pet_show_translation.cpp128
-rw-r--r--engines/titanic/pet_control/pet_show_translation.h57
-rw-r--r--engines/titanic/pet_control/pet_text.cpp8
-rw-r--r--engines/titanic/pet_control/pet_text.h5
-rw-r--r--engines/titanic/pet_control/pet_translation.cpp23
-rw-r--r--engines/titanic/pet_control/pet_translation.h19
10 files changed, 257 insertions, 22 deletions
diff --git a/engines/titanic/pet_control/pet_control.cpp b/engines/titanic/pet_control/pet_control.cpp
index 2ab30af5de..95438ce81e 100644
--- a/engines/titanic/pet_control/pet_control.cpp
+++ b/engines/titanic/pet_control/pet_control.cpp
@@ -52,7 +52,7 @@ CPetControl::CPetControl() : CGameObject(),
_sections[PET_ROOMS] = &_rooms;
_sections[PET_REAL_LIFE] = &_realLife;
_sections[PET_STARFIELD] = &_starfield;
- _sections[PET_MESSAGE] = &_message;
+ _sections[PET_TRANSLATION] = &_translation;
}
void CPetControl::save(SimpleFile *file, int indent) {
@@ -87,7 +87,7 @@ void CPetControl::setup() {
_inventory.setup(this);
_starfield.setup(this);
_realLife.setup(this);
- _message.setup(this);
+ _translation.setup(this);
_frame.setup(this);
}
@@ -98,7 +98,7 @@ bool CPetControl::isValid() {
_inventory.isValid(this) &&
_starfield.isValid(this) &&
_realLife.isValid(this) &&
- _message.isValid(this) &&
+ _translation.isValid(this) &&
_frame.isValid(this);
}
@@ -109,7 +109,7 @@ void CPetControl::loadAreas(SimpleFile *file, int param) {
_inventory.load(file, param);
_starfield.load(file, param);
_realLife.load(file, param);
- _message.load(file, param);
+ _translation.load(file, param);
_frame.load(file, param);
}
@@ -120,7 +120,7 @@ void CPetControl::saveAreas(SimpleFile *file, int indent) {
_inventory.save(file, indent);
_starfield.save(file, indent);
_realLife.save(file, indent);
- _message.save(file, indent);
+ _translation.save(file, indent);
_frame.save(file, indent);
}
@@ -165,7 +165,7 @@ void CPetControl::loaded() {
_inventory.postLoad();
_starfield.postLoad();
_realLife.postLoad();
- _message.postLoad();
+ _translation.postLoad();
_frame.postLoad();
}
@@ -386,6 +386,15 @@ void CPetControl::displayMessage(const CString &str, int param) const {
_sections[_currentArea]->displayMessage(msg);
}
+void CPetControl::addTranslation(StringId id1, StringId id2) {
+ setArea(PET_TRANSLATION);
+ _translation.addTranslation(_strings[id1], _strings[id2]);
+}
+
+void CPetControl::clearTranslation() {
+ _translation.clearTranslation();
+}
+
CGameObject *CPetControl::getFirstObject() const {
return dynamic_cast<CGameObject *>(getFirstChild());
}
diff --git a/engines/titanic/pet_control/pet_control.h b/engines/titanic/pet_control/pet_control.h
index c4b65457e2..454fc0991b 100644
--- a/engines/titanic/pet_control/pet_control.h
+++ b/engines/titanic/pet_control/pet_control.h
@@ -31,7 +31,7 @@
#include "titanic/pet_control/pet_conversations.h"
#include "titanic/pet_control/pet_frame.h"
#include "titanic/pet_control/pet_inventory.h"
-#include "titanic/pet_control/pet_message.h"
+#include "titanic/pet_control/pet_translation.h"
#include "titanic/pet_control/pet_starfield.h"
#include "titanic/pet_control/pet_real_life.h"
#include "titanic/pet_control/pet_remote.h"
@@ -61,7 +61,7 @@ private:
CPetRemote _remote;
CPetRooms _rooms;
CPetRealLife _realLife;
- CPetMessage _message;
+ CPetTranslation _translation;
CPetFrame _frame;
CString _activeNPCName;
CString _remoteTargetName;
@@ -242,6 +242,16 @@ public:
void displayMessage(const CString &str, int param = 0) const;
/**
+ * Switches to the Translation display, and adds a line to it's content
+ */
+ void addTranslation(StringId id1, StringId id2);
+
+ /**
+ * Clears the translation display
+ */
+ void clearTranslation();
+
+ /**
* Get the first game object stored in the PET
*/
CGameObject *getFirstObject() const;
diff --git a/engines/titanic/pet_control/pet_frame.cpp b/engines/titanic/pet_control/pet_frame.cpp
index bc1a8e93b6..7375c69436 100644
--- a/engines/titanic/pet_control/pet_frame.cpp
+++ b/engines/titanic/pet_control/pet_frame.cpp
@@ -126,7 +126,7 @@ bool CPetFrame::setPetControl(CPetControl *petControl) {
void CPetFrame::setArea(PetArea newArea) {
resetArea();
- if (newArea < PET_MESSAGE)
+ if (newArea < PET_TRANSLATION)
_modeButtons[PET_AREAS[newArea]].setMode(MODE_SELECTED);
}
diff --git a/engines/titanic/pet_control/pet_section.h b/engines/titanic/pet_control/pet_section.h
index 8bc427e842..dc2f70b76f 100644
--- a/engines/titanic/pet_control/pet_section.h
+++ b/engines/titanic/pet_control/pet_section.h
@@ -30,7 +30,7 @@ namespace Titanic {
enum PetArea {
PET_INVENTORY = 0, PET_CONVERSATION = 1, PET_REMOTE = 2,
- PET_ROOMS = 3, PET_REAL_LIFE = 4, PET_STARFIELD = 5, PET_MESSAGE = 6
+ PET_ROOMS = 3, PET_REAL_LIFE = 4, PET_STARFIELD = 5, PET_TRANSLATION = 6
};
class CPetControl;
diff --git a/engines/titanic/pet_control/pet_show_translation.cpp b/engines/titanic/pet_control/pet_show_translation.cpp
new file mode 100644
index 0000000000..2a3b024324
--- /dev/null
+++ b/engines/titanic/pet_control/pet_show_translation.cpp
@@ -0,0 +1,128 @@
+/* ScummVM - Graphic Adventure Engine
+ *
+ * ScummVM is the legal property of its developers, whose names
+ * are too numerous to list here. Please refer to the COPYRIGHT
+ * file distributed with this source distribution.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ */
+
+#include "titanic/pet_control/pet_show_translation.h"
+#include "titanic/pet_control/pet_control.h"
+
+namespace Titanic {
+
+BEGIN_MESSAGE_MAP(CPetShowTranslation, CGameObject)
+ ON_MESSAGE(EnterViewMsg)
+ ON_MESSAGE(LeaveViewMsg)
+ ON_MESSAGE(ChangeSeasonMsg)
+ ON_MESSAGE(ArboretumGateMsg)
+END_MESSAGE_MAP()
+
+
+void CPetShowTranslation::save(SimpleFile *file, int indent) {
+ file->writeNumberLine(1, indent);
+ CGameObject::save(file, indent);
+}
+
+void CPetShowTranslation::load(SimpleFile *file) {
+ file->readNumber();
+ CGameObject::load(file);
+}
+
+bool CPetShowTranslation::EnterViewMsg(CEnterViewMsg *msg) {
+ CPetControl *pet = getPetControl();
+ if (!pet)
+ return true;
+
+ CString viewName = getFullViewName();
+ CString nodeView = msg->_newView->getNodeViewName();
+
+ if (viewName == "Arboretum.Node 2.N" || viewName == "FrozenArboretum.Node 2.N") {
+ switch (stateGetSeason()) {
+ case SEASON_SUMMER:
+ pet->addTranslation(DE_SUMMER_ARBORETUM, DE_SUMMER);
+ break;
+
+ case SEASON_AUTUMN:
+ pet->addTranslation(DE_AUTUMN_ARBORETUM, DE_AUTUMN);
+ break;
+
+ case SEASON_WINTER:
+ pet->addTranslation(DE_WINTER_ARBORETUM, DE_WINTER);
+ break;
+
+ case SEASON_SPRING:
+ pet->addTranslation(DE_SPRING_ARBORETUM, DE_SPRING);
+ break;
+
+ default:
+ break;
+ }
+
+ pet->addTranslation(DE_ARBORETUM_MSG1, DE_ARBORETUM_MSG2);
+ } else if (compareRoomNameTo("Bridge")) {
+ if (nodeView == "Node 3.N") {
+ pet->addTranslation(DE_BRIDGE_MSG1, DE_BRIDGE_MSG2);
+ pet->addTranslation(DE_BRIDGE_MSG3, DE_BRIDGE_MSG4);
+ pet->addTranslation(DE_BRIDGE_MSG5, DE_BRIDGE_MSG6);
+ pet->addTranslation(DE_BRIDGE_MSG7, DE_BRIDGE_MSG8);
+ } else if (nodeView == "Node 4.N") {
+ pet->addTranslation(DE_BRIDGE_MSG9, DE_BRIDGE_MSG10);
+ }
+ } else if (compareRoomNameTo("PromenadeDeck")) {
+ if (nodeView == "Node 2.S") {
+ pet->addTranslation(DE_PROMENADE_DECK_MSG1, DE_PROMENADE_DECK_MSG2);
+ pet->addTranslation(DE_PROMENADE_DECK_MSG3, DE_PROMENADE_DECK_MSG4);
+ pet->addTranslation(DE_PROMENADE_DECK_MSG5, DE_PROMENADE_DECK_MSG6);
+ pet->addTranslation(DE_PROMENADE_DECK_MSG7, DE_PROMENADE_DECK_MSG8);
+ pet->addTranslation(DE_PROMENADE_DECK_MSG9, DE_PROMENADE_DECK_MSG10);
+ }
+ } else if (compareRoomNameTo("SgtLobby")) {
+ if (nodeView == "Node 17.S") {
+ pet->addTranslation(DE_SGTLOBBY_MSG1, DE_SGTLOBBY_MSG2);
+ pet->addTranslation(DE_SGTLOBBY_MSG3, DE_SGTLOBBY_MSG4);
+ pet->addTranslation(DE_SGTLOBBY_MSG5, DE_SGTLOBBY_MSG6);
+ pet->addTranslation(DE_SGTLOBBY_MSG7, DE_SGTLOBBY_MSG8);
+ }
+ } else if (compareRoomNameTo("Titania")) {
+ if (nodeView == "Node 9.N") {
+ pet->addTranslation(DE_TITANIA_MSG1, DE_TITANIA_MSG2);
+ } else if (nodeView == "Node 10.N") {
+ pet->addTranslation(DE_TITANIA_MSG3, DE_TITANIA_MSG4);
+ } else if (nodeView == "Node 11.N") {
+ pet->addTranslation(DE_TITANIA_MSG5, DE_TITANIA_MSG6);
+ } else if (nodeView == "Node 13.N") {
+ pet->addTranslation(DE_TITANIA_MSG7, DE_TITANIA_MSG8);
+ }
+ }
+
+ return true;
+}
+
+bool CPetShowTranslation::LeaveViewMsg(CLeaveViewMsg *msg) {
+ return true;
+}
+
+bool CPetShowTranslation::ChangeSeasonMsg(CChangeSeasonMsg *msg) {
+ return true;
+}
+
+bool CPetShowTranslation::ArboretumGateMsg(CArboretumGateMsg *msg) {
+ return true;
+}
+
+} // End of namespace Titanic
diff --git a/engines/titanic/pet_control/pet_show_translation.h b/engines/titanic/pet_control/pet_show_translation.h
new file mode 100644
index 0000000000..cef9708616
--- /dev/null
+++ b/engines/titanic/pet_control/pet_show_translation.h
@@ -0,0 +1,57 @@
+/* ScummVM - Graphic Adventure Engine
+ *
+ * ScummVM is the legal property of its developers, whose names
+ * are too numerous to list here. Please refer to the COPYRIGHT
+ * file distributed with this source distribution.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ */
+
+#ifndef TITANIC_PET_SHOW_TRANSLATION_H
+#define TITANIC_PET_SHOW_TRANSLATION_H
+
+#include "titanic/core/game_object.h"
+
+namespace Titanic {
+
+/**
+ * Used by the German version to show contextual translation of
+ * English background text throughout the game
+ */
+class CPetShowTranslation: public CGameObject {
+ DECLARE_MESSAGE_MAP;
+ bool EnterViewMsg(CEnterViewMsg *msg);
+ bool LeaveViewMsg(CLeaveViewMsg *msg);
+ bool ChangeSeasonMsg(CChangeSeasonMsg *msg);
+ bool ArboretumGateMsg(CArboretumGateMsg *msg);
+public:
+ CLASSDEF;
+ CPetShowTranslation() : CGameObject() {}
+
+ /**
+ * Save the data for the class to file
+ */
+ virtual void save(SimpleFile *file, int indent);
+
+ /**
+ * Load the data for the class from file
+ */
+ virtual void load(SimpleFile *file);
+};
+
+} // End of namespace Titanic
+
+#endif /* TITANIC_PET_SHOW_TRANSLATION_H */
diff --git a/engines/titanic/pet_control/pet_text.cpp b/engines/titanic/pet_control/pet_text.cpp
index 32a6a9af57..2c20396cd9 100644
--- a/engines/titanic/pet_control/pet_text.cpp
+++ b/engines/titanic/pet_control/pet_text.cpp
@@ -61,6 +61,11 @@ void CPetText::setLineColor(uint lineNum, uint col) {
}
void CPetText::setLineColor(uint lineNum, byte r, byte g, byte b) {
+ _array[lineNum]._rgb = getColorText(r, g, b);
+ _stringsMerged = false;
+}
+
+CString CPetText::getColorText(byte r, byte g, byte b) {
char buffer[6];
if (!r)
r = 1;
@@ -75,9 +80,8 @@ void CPetText::setLineColor(uint lineNum, byte r, byte g, byte b) {
buffer[3] = b;
buffer[4] = TEXTCMD_SET_COLOR;
buffer[5] = '\0';
- _array[lineNum]._rgb = buffer;
- _stringsMerged = false;
+ return CString(buffer);
}
void CPetText::load(SimpleFile *file, int param) {
diff --git a/engines/titanic/pet_control/pet_text.h b/engines/titanic/pet_control/pet_text.h
index ba199a3ae5..0a6bb2d03d 100644
--- a/engines/titanic/pet_control/pet_text.h
+++ b/engines/titanic/pet_control/pet_text.h
@@ -151,6 +151,11 @@ public:
void setLineColor(uint lineNum, byte r, byte g, byte b);
/**
+ * Gets the text string representing a color encoding
+ */
+ static CString getColorText(byte r, byte g, byte b);
+
+ /**
* Set the color for a line
*/
void setLineColor(uint lineNum, uint col);
diff --git a/engines/titanic/pet_control/pet_translation.cpp b/engines/titanic/pet_control/pet_translation.cpp
index 783c9019e2..fe6c37c8ab 100644
--- a/engines/titanic/pet_control/pet_translation.cpp
+++ b/engines/titanic/pet_control/pet_translation.cpp
@@ -20,11 +20,12 @@
*
*/
-#include "titanic/pet_control/pet_message.h"
+#include "titanic/pet_control/pet_translation.h"
+#include "titanic/pet_control/pet_control.h"
namespace Titanic {
-CPetMessage::CPetMessage() {
+CPetTranslation::CPetTranslation() {
Rect rect1(0, 0, 580, 70);
rect1.translate(32, 368);
_message.setBounds(rect1);
@@ -37,21 +38,33 @@ CPetMessage::CPetMessage() {
_tooltip.setHasBorder(false);
}
-bool CPetMessage::setup(CPetControl *petControl) {
+bool CPetTranslation::setup(CPetControl *petControl) {
if (petControl && setupControl(petControl))
return reset();
return false;
}
-void CPetMessage::draw(CScreenManager *screenManager) {
+void CPetTranslation::draw(CScreenManager *screenManager) {
_message.draw(screenManager);
_tooltip.draw(screenManager);
}
-bool CPetMessage::setupControl(CPetControl *petControl) {
+bool CPetTranslation::setupControl(CPetControl *petControl) {
if (petControl)
_petControl = petControl;
return true;
}
+void CPetTranslation::clearTranslation() {
+ _message.setup();
+}
+
+void CPetTranslation::addTranslation(const CString &str1, const CString &str2) {
+ CString msg = CString::format("%s%s - %s%s",
+ CPetText::getColorText(0, 0x80, 0).c_str(), str1.c_str(),
+ CPetText::getColorText(0, 0, 0).c_str(), str2.c_str());
+ _message.addLine(msg);
+ _petControl->makeDirty();
+}
+
} // End of namespace Titanic
diff --git a/engines/titanic/pet_control/pet_translation.h b/engines/titanic/pet_control/pet_translation.h
index 499f274c54..2fcc758b44 100644
--- a/engines/titanic/pet_control/pet_translation.h
+++ b/engines/titanic/pet_control/pet_translation.h
@@ -20,15 +20,15 @@
*
*/
-#ifndef TITANIC_PET_MESSAGE_H
-#define TITANIC_PET_MESSAGE_H
+#ifndef TITANIC_PET_TRANSLATION_H
+#define TITANIC_PET_TRANSLATION_H
#include "titanic/pet_control/pet_section.h"
#include "titanic/pet_control/pet_text.h"
namespace Titanic {
-class CPetMessage : public CPetSection {
+class CPetTranslation : public CPetSection {
private:
CPetText _message;
CPetText _tooltip;
@@ -38,7 +38,7 @@ private:
*/
bool setupControl(CPetControl *petControl);
public:
- CPetMessage();
+ CPetTranslation();
/**
* Sets up the section
@@ -89,8 +89,17 @@ public:
*/
virtual CPetText *getText() { return &_tooltip; }
+ /**
+ * Clear any current translation text
+ */
+ void clearTranslation();
+
+ /**
+ * Adds a line to the translation display
+ */
+ void addTranslation(const CString &str1, const CString &str2);
};
} // End of namespace Titanic
-#endif /* TITANIC_PET_MESSAGE_H */
+#endif /* TITANIC_PET_TRANSLATION_H */