summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/creature.cpp81
-rw-r--r--src/dna.cpp14
-rw-r--r--src/list.cpp33
3 files changed, 66 insertions, 62 deletions
diff --git a/src/creature.cpp b/src/creature.cpp
index 9e51b04..7a86af9 100644
--- a/src/creature.cpp
+++ b/src/creature.cpp
@@ -1,34 +1,21 @@
#include "creature.hpp"
-Creature::Creature(Window m, SDL_Rect R)
+Creature::Creature(Window M, SDL_Rect R, Dna D)
{
- renderer = m.getRenderer();
- rect = R;
+ renderer = M.getRenderer();
+ rect = R;
+ mine = D;
if(rect.x == 0 && rect.y == 0){
- rect.x = rand()%WINDOW_X;
- rect.y = rand()%WINDOW_Y;
+ rect.x = rand()%WINDOW_X;
+ rect.y = rand()%WINDOW_Y;
}
- type = CREATURE_TYPE;
- health = CREATURE_START_HEALTH;
- maxHealth = CREATURE_MAX_HEALTH;
- reach = CREATURE_REACH;
- speed = CREATURE_SPEED;
- bestSense = CREATURE_BEST_SENSE;
- bite = CREATURE_BITE;
- amountToGrow = CREATURE_AMOUNT_TO_GROW;
- expectedPregnancyTime = CREATURE_EXPECTED_PREGNANCY_TIME;
- expectedAge = CREATURE_EXPECTED_AGE;
-
- gender = rand() % 2;
- age = 0;
- hungry = false;
- hasTarget = false;
- wander = false;
- pregnate = false;
- pregnancyReady = false;
- able = true;
+ type = CREATURE_TYPE;
+ health = mine.maxHealth/2;
+ gender = rand() % 2;
+ able = true;
+ pregnancyReady = false;
}
void Creature::Behavior()
@@ -46,18 +33,18 @@ void Creature::Behavior()
if(pregnate){
pregnancyTime++;
- if(pregnancyTime > expectedPregnancyTime)
+ if(pregnancyTime > mine.expectedPregnancyTime)
pregnancyReady = true;
}
age++;
- if(age > expectedAge)
+ if(age > mine.expectedAge)
health = 0;
}
void Creature::Priority()
{
- if(health < maxHealth/2){
+ if(health < mine.maxHealth / 2){
hungry = true;
able = false;
}
@@ -69,7 +56,7 @@ void Creature::Priority()
void Creature::setTarget()
{
- for(list <Entity*>::iterator it = N.begin(); it!=N.end(); it++){
+ for(std::list <Entity*>::iterator it = N.begin(); it!=N.end(); it++){
if( (*it)->getType() == RESOURCE_TYPE && hungry){
target = *it;
hasTarget = true;
@@ -93,7 +80,7 @@ void Creature::setTarget()
void Creature::checkTarget()
{
- for(list <Entity*>::iterator it = N.begin(); it!=N.end(); it++)
+ for(std::list <Entity*>::iterator it = N.begin(); it!=N.end(); it++)
if( target == *it )
return;
@@ -105,18 +92,18 @@ void Creature::checkTarget()
void Creature::Action()
{
if(hasTarget){
- if( Distance(rect,target->getRect()) < reach && target->getType() == RESOURCE_TYPE){
- target->eat(bite);
- health+=bite;
+ if( Distance(rect,target->getRect()) < mine.reach && target->getType() == RESOURCE_TYPE){
+ target->eat(mine.bite);
+ health+=mine.bite;
amountAte++;
- if(rect.w <= CREATURE_SIZE_MAX && amountToGrow <= amountAte){
+ if(rect.w <= mine.sizeMax && mine.amountToGrow <= amountAte){
amountAte = 0;
rect.w = rect.h = rect.w + 1;
}
if(target->getAmount()<=0)
hasTarget = false;
}
- else if( Distance(rect,target->getRect()) < reach && target->getType() == CREATURE_TYPE && target->getGender() != gender ){
+ else if( Distance(rect,target->getRect()) < mine.reach && target->getType() == CREATURE_TYPE && target->getGender() != gender ){
target->impregnate();
hasTarget = false;
}
@@ -124,7 +111,7 @@ void Creature::Action()
Move(target->getRect());
}
else if(wander){
- if(Distance(rect,wTarget) < reach)
+ if(Distance(rect,wTarget) < mine.reach)
wander = false;
else
Move(wTarget);
@@ -135,34 +122,34 @@ void Creature::Move(SDL_Rect R)
{
if( rect.x == R.x ){
if( rect.y < R.y )
- rect.y+=speed;
+ rect.y+=mine.speed;
else
- rect.y-=speed;
+ rect.y-=mine.speed;
}
else if( rect.y == R.y ){
if( rect.x < R.x )
- rect.x+=speed;
+ rect.x+=mine.speed;
else
- rect.x-=speed;
+ rect.x-=mine.speed;
}
else if( rect.x < R.x ){
if( rect.y < R.y ){
- rect.x+=speed;
- rect.y+=speed;
+ rect.x+=mine.speed;
+ rect.y+=mine.speed;
}
else{
- rect.x+=speed;
- rect.y-=speed;
+ rect.x+=mine.speed;
+ rect.y-=mine.speed;
}
}
else if ( rect.x > R.x ){
if( rect.y < R.y ){
- rect.x-=speed;
- rect.y+=speed;
+ rect.x-=mine.speed;
+ rect.y+=mine.speed;
}
else{
- rect.x-=speed;
- rect.y-=speed;
+ rect.x-=mine.speed;
+ rect.y-=mine.speed;
}
}
}
diff --git a/src/dna.cpp b/src/dna.cpp
new file mode 100644
index 0000000..36eda3d
--- /dev/null
+++ b/src/dna.cpp
@@ -0,0 +1,14 @@
+#include "dna.hpp"
+
+Dna::Dna()
+{
+ maxHealth = CREATURE_MAX_HEALTH;
+ speed = CREATURE_SPEED;
+ reach = CREATURE_REACH;
+ bestSense = CREATURE_BEST_SENSE;
+ bite = CREATURE_BITE;
+ amountToGrow = CREATURE_AMOUNT_TO_GROW;
+ expectedPregnancyTime = CREATURE_EXP_PREG_TIME;
+ expectedAge = CREATURE_EXP_AGE;
+ sizeMax = CREATURE_SIZE_MAX;
+}
diff --git a/src/list.cpp b/src/list.cpp
index d49f97a..edf3063 100644
--- a/src/list.cpp
+++ b/src/list.cpp
@@ -5,9 +5,10 @@ List::List(Window m)
main = m;
int i;
- SDL_Rect Rect = {0,0,CREATURE_SIZE_START,CREATURE_SIZE_START};
+ Dna defaultDNA;
+ SDL_Rect Rect = {0,0,defaultDNA.sizeMax/5,defaultDNA.sizeMax/5};
for(i=0;i<CREATURES;i++){
- Creature X(main,Rect);
+ Creature X(main,Rect,defaultDNA);
C.push_back(X);
}
@@ -21,7 +22,7 @@ List::List(Window m)
void List::Remove()
{
- for(list<Creature>::iterator it = C.begin(); it!=C.end(); it++)
+ for(std::list<Creature>::iterator it = C.begin(); it!=C.end(); it++)
if(it->getHealth()<=0){
SDL_Rect Rect = it->getRect();
Resource r = Resource(main,Rect);
@@ -29,27 +30,29 @@ void List::Remove()
C.erase(it--);
}
- for(list<Resource>::iterator it = R.begin(); it!=R.end(); it++)
+ for(std::list<Resource>::iterator it = R.begin(); it!=R.end(); it++)
if(it->getAmount()<=0)
R.erase(it--);
}
void List::Behavior()
{
- for(list<Creature>::iterator it = C.begin(); it!=C.end(); it++){
- list<Entity*> N = getNear(*it);
+ for(std::list<Creature>::iterator it = C.begin(); it!=C.end(); it++){
+ std::list<Entity*> N = getNear(*it);
it->giveN(N);
it->Behavior();
+
if(it->getPregnancyReady()){
+ Dna D = it->getDNA();
SDL_Rect Rect = it->getRect();
- Rect.h = Rect.w = CREATURE_SIZE_START;
- Creature X(main,Rect);
+ Rect.h = Rect.w = D.sizeMax / 5;
+ Creature X(main,Rect,D);
C.push_back(X);
it->hadPregnancy();
}
}
- for(list<Resource>::iterator it = R.begin(); it!=R.end(); it++)
+ for(std::list<Resource>::iterator it = R.begin(); it!=R.end(); it++)
it->grow();
}
@@ -61,22 +64,22 @@ void List::Place()
R.push_back(Y);
}
- for(list<Creature>::iterator it = C.begin(); it!=C.end(); it++)
+ for(std::list<Creature>::iterator it = C.begin(); it!=C.end(); it++)
it->Place();
- for(list<Resource>::iterator it = R.begin(); it!=R.end(); it++)
+ for(std::list<Resource>::iterator it = R.begin(); it!=R.end(); it++)
it->Place();
}
-list<Entity*> List::getNear(Creature nC)
+std::list<Entity*> List::getNear(Creature nC)
{
- list<Entity*> N;
+ std::list<Entity*> N;
- for(list <Resource>::iterator it = R.begin(); it!=R.end(); it++)
+ for(std::list<Resource>::iterator it = R.begin(); it!=R.end(); it++)
if( nC.getBestSense() > Distance(nC.getRect(),it->getRect()) )
N.push_back(&(*it));
- for(list <Creature>::iterator it = C.begin(); it!=C.end(); it++)
+ for(std::list<Creature>::iterator it = C.begin(); it!=C.end(); it++)
if( &nC == &(*it))
continue;
else if( nC.getBestSense() > Distance(nC.getRect(),it->getRect()) )