Genome::Properties<double> &GetProperties() noexcept { return properties; }
const Genome::Properties<double> &GetProperties() const noexcept { return properties; }
+ const Genome::PropertySet<double> &CurProps() const noexcept { return properties.props[cur_prop]; }
+ const Genome::PropertySet<double> &NextProps() const noexcept { return properties.props[std::min(5, cur_prop + 1)]; }
+
+ void BaseColor(const glm::dvec3 &c) noexcept { base_color = c; }
+ const glm::dvec3 &BaseColor() const noexcept { return base_color; }
+
+ void HighlightColor(const glm::dvec3 &c) noexcept { highlight_color = c; }
+ glm::dvec4 HighlightColor() const noexcept;
+
void Mass(double m) noexcept { mass = m; size = std::cbrt(mass / density); }
double Mass() const noexcept { return mass; }
- void Grow(double amount) noexcept;
+ void Ingest(int res, double amount) noexcept;
void Density(double d) noexcept { density = d; size = std::cbrt(mass / density); }
double Density() const noexcept { return density; }
double Size() const noexcept;
double Age() const noexcept;
+ std::string AgeName() const;
+ double AgeLerp(double from, double to) const noexcept;
// change of giving birth per tick
double Fertility() const noexcept;
Genome genome;
Genome::Properties<double> properties;
+ int cur_prop;
+
+ glm::dvec3 base_color;
+ glm::dvec3 highlight_color;
double mass;
double density;