aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/titanic/pet_control/pet_control.h3
-rw-r--r--engines/titanic/pet_control/pet_frame.cpp27
-rw-r--r--engines/titanic/pet_control/pet_gfx_element.cpp4
-rw-r--r--engines/titanic/pet_control/pet_gfx_element.h2
-rw-r--r--engines/titanic/pet_control/pet_section.h5
-rw-r--r--engines/titanic/string.cpp6
-rw-r--r--engines/titanic/string.h2
7 files changed, 41 insertions, 8 deletions
diff --git a/engines/titanic/pet_control/pet_control.h b/engines/titanic/pet_control/pet_control.h
index 4f101caaf5..4fcfe6e7a4 100644
--- a/engines/titanic/pet_control/pet_control.h
+++ b/engines/titanic/pet_control/pet_control.h
@@ -39,7 +39,6 @@ namespace Titanic {
class CPetControl : public CGameObject {
private:
- PetArea _currentArea;
int _fieldC0;
int _locked;
int _fieldC8;
@@ -88,6 +87,8 @@ private:
*/
CRoomItem *getHiddenRoom();
public:
+ PetArea _currentArea;
+public:
CLASSDEF
CPetControl();
diff --git a/engines/titanic/pet_control/pet_frame.cpp b/engines/titanic/pet_control/pet_frame.cpp
index e94bc6c848..48a05cdd11 100644
--- a/engines/titanic/pet_control/pet_frame.cpp
+++ b/engines/titanic/pet_control/pet_frame.cpp
@@ -21,6 +21,7 @@
*/
#include "titanic/pet_control/pet_frame.h"
+#include "titanic/pet_control/pet_control.h"
namespace Titanic {
@@ -41,7 +42,23 @@ bool CPetFrame::setup(CPetControl *petControl) {
bool CPetFrame::setup() {
if (_petControl) {
- // TODO
+ _background.setup("PetBackground", _petControl, MODE_0);
+ _modeBackground.setup("PetModeBackground", _petControl, MODE_0);
+
+ for (int idx = 0; idx < 5; ++idx) {
+ CString resName = Common::String::format("PetMode%d", idx);
+ _modeButtons[idx].setup(resName, _petControl, MODE_0);
+ }
+
+ for (int idx = 0; idx < 6; ++idx) {
+ CString resName = Common::String::format("3Pettitle%d", idx);
+ _titles[idx].setup(resName, _petControl, MODE_0);
+ }
+
+ for (int idx = 0; idx < 7; ++idx) {
+ CString resName = Common::String::format("PetIndent%d", idx);
+ _titles[idx].setup(resName, _petControl, MODE_0);
+ }
}
return true;
@@ -98,7 +115,13 @@ void CPetFrame::setArea(PetArea newArea) {
}
void CPetFrame::drawFrame(CScreenManager *screenManager) {
- warning("TODO: CPetFrame::drawFrame");
+ _background.draw(screenManager);
+ _modeBackground.draw(screenManager);
+
+ for (int idx = 0; idx < 5; ++idx)
+ _modeButtons[idx].draw(screenManager);
+
+ _titles[_petControl->_currentArea].draw(screenManager);
}
} // End of namespace Titanic
diff --git a/engines/titanic/pet_control/pet_gfx_element.cpp b/engines/titanic/pet_control/pet_gfx_element.cpp
index 5f2f05e6c3..616db72377 100644
--- a/engines/titanic/pet_control/pet_gfx_element.cpp
+++ b/engines/titanic/pet_control/pet_gfx_element.cpp
@@ -44,7 +44,7 @@ void CPetGfxElement::setup(PetElementMode mode, const CString &name,
}
}
-void CPetGfxElement::setup(const CString &name, CPetControl *petControl) {
+void CPetGfxElement::setup(const CString &name, CPetControl *petControl, PetElementMode mode) {
if (!petControl)
return;
@@ -60,7 +60,7 @@ void CPetGfxElement::setup(const CString &name, CPetControl *petControl) {
}
CString resName = numString + name;
- setup(resName, petControl);
+ setup(mode, resName, petControl);
}
void CPetGfxElement::draw(CScreenManager *screenManager) {
diff --git a/engines/titanic/pet_control/pet_gfx_element.h b/engines/titanic/pet_control/pet_gfx_element.h
index b0bf6e4abe..a4c39c6d24 100644
--- a/engines/titanic/pet_control/pet_gfx_element.h
+++ b/engines/titanic/pet_control/pet_gfx_element.h
@@ -45,7 +45,7 @@ public:
/**
* Setup the element
*/
- virtual void setup(const CString &name, CPetControl *petControl);
+ virtual void setup(const CString &name, CPetControl *petControl, PetElementMode mode);
/**
* Draw the item
diff --git a/engines/titanic/pet_control/pet_section.h b/engines/titanic/pet_control/pet_section.h
index 77535662a6..2612d64a19 100644
--- a/engines/titanic/pet_control/pet_section.h
+++ b/engines/titanic/pet_control/pet_section.h
@@ -85,7 +85,10 @@ public:
/**
* Returns true if the object is in a valid state
*/
- virtual bool isValid(CPetControl *petControl) { return false; }
+ virtual bool isValid(CPetControl *petControl) {
+ // TODO: Switch back to false after implementing all sections
+ return true;
+ }
/**
* Load the data for the class from file
diff --git a/engines/titanic/string.cpp b/engines/titanic/string.cpp
index f29d2c7938..6b43e7992b 100644
--- a/engines/titanic/string.cpp
+++ b/engines/titanic/string.cpp
@@ -31,6 +31,12 @@ CString::CString(char c, uint32 len) : Common::String() {
(*this) += c;
}
+CString::CString(int val) : Common::String() {
+ char buffer[16];
+ itoa(val, buffer, 10);
+ *this += buffer;
+}
+
CString CString::left(uint count) const {
return (count > size()) ? CString() : CString(c_str(), c_str() + count);
}
diff --git a/engines/titanic/string.h b/engines/titanic/string.h
index 0c0c64e0be..c41130369b 100644
--- a/engines/titanic/string.h
+++ b/engines/titanic/string.h
@@ -46,7 +46,7 @@ public:
CString(const String &str) : Common::String(str) {}
CString(char c, uint32 len);
explicit CString(char c) : Common::String(c) {}
- explicit CString(int val) : Common::String(Common::String::format("%d", val)) {}
+ explicit CString(int val);
/**
* Returns the left n characters of the string