aboutsummaryrefslogtreecommitdiff
path: root/engines/titanic/star_control/base_star.h
diff options
context:
space:
mode:
Diffstat (limited to 'engines/titanic/star_control/base_star.h')
-rw-r--r--engines/titanic/star_control/base_star.h35
1 files changed, 28 insertions, 7 deletions
diff --git a/engines/titanic/star_control/base_star.h b/engines/titanic/star_control/base_star.h
index 20dbacedb6..ad3ad13804 100644
--- a/engines/titanic/star_control/base_star.h
+++ b/engines/titanic/star_control/base_star.h
@@ -29,19 +29,45 @@
namespace Titanic {
struct CBaseStarEntry {
- int _field0;
+ byte _field0;
+ byte _field1;
+ byte _field2;
+ byte _field3;
double _value;
CBaseStarVal _val;
+ uint _data[5];
+
+ CBaseStarEntry();
+ void load(Common::SeekableReadStream &s);
};
class CBaseStar {
protected:
Common::Array<CBaseStarEntry> _data;
- int _fieldC;
CStarControlSub4 _sub4;
double _minVal;
double _maxVal;
double _range;
+protected:
+ /**
+ * Get a pointer to a data entry
+ */
+ CBaseStarEntry *getDataPtr(int index);
+
+ /**
+ * Load entry data from a passed stream
+ */
+ void loadData(Common::SeekableReadStream &s);
+
+ /**
+ * Load entry data from a specified resource
+ */
+ void loadData(const CString &resName);
+
+ /**
+ * Reset the data for an entry
+ */
+ void resetEntry(CBaseStarEntry &entry);
public:
CBaseStar();
virtual ~CBaseStar() {}
@@ -69,11 +95,6 @@ public:
void clear();
void initialize();
-
- /**
- * Get a pointer to a data entry
- */
- CBaseStarEntry *getDataPtr(int index);
};
} // End of namespace Titanic