diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/creature.cpp | 64 | ||||
-rw-r--r-- | src/dna.cpp | 6 | ||||
-rw-r--r-- | src/list.cpp | 15 | ||||
-rw-r--r-- | src/main.cpp | 4 | ||||
-rw-r--r-- | src/quadtree.cpp | 18 | ||||
-rw-r--r-- | src/resource.cpp | 2 |
6 files changed, 54 insertions, 55 deletions
diff --git a/src/creature.cpp b/src/creature.cpp index 0484fd1..7e5d0f3 100644 --- a/src/creature.cpp +++ b/src/creature.cpp @@ -1,9 +1,9 @@ #include "creature.hpp" -Creature::Creature(Location t, Dna D) +Creature::Creature(Rectangle t, DNA D) { L = t; - mine = D; + myDNA = D; if(L.x == 0 && L.y == 0){ L.x = -30.0 + static_cast <float> (rand()) / (static_cast <float> (RAND_MAX/(30-(-30)))); @@ -15,7 +15,7 @@ Creature::Creature(Location t, Dna D) gfxData.y = L.y; type = CREATURE_TYPE; - health = mine.maxHealth/2; + health = myDNA.maxHealth/2; gender = rand() % 2; age = 0; pregnancyTime = 0; @@ -55,18 +55,18 @@ void Creature::Behavior() if(pregnate){ pregnancyTime++; - if(pregnancyTime > mine.expectedPregnancyTime) + if(pregnancyTime > myDNA.expectedPregnancyTime) pregnancyReady = true; } age++; - if(age > mine.expectedAge) + if(age > myDNA.expectedAge) health = 0; } void Creature::Priority() { - if(health < mine.maxHealth / 2){ + if(health < myDNA.maxHealth / 2){ hungry = true; able = false; } @@ -79,7 +79,7 @@ void Creature::Priority() void Creature::setTarget() { //std::random_shuffle(N.begin(),N.end()); - for(std::list <Entity*>::iterator it = N.begin(); it!=N.end(); it++){ + for(std::list <Entity*>::iterator it = nearMe.begin(); it!=nearMe.end(); it++){ if( (*it)->getType() == RESOURCE_TYPE && hungry){ target = *it; hasTarget = true; @@ -98,7 +98,7 @@ void Creature::setTarget() wander = true; float x = -30.0 + static_cast <float> (rand()) / (static_cast <float> (RAND_MAX/(30-(-30)))); float y = -30.0 + static_cast <float> (rand()) / (static_cast <float> (RAND_MAX/(30-(-30)))); - Location tmp; + Rectangle tmp; tmp.x = x; tmp.y = y; wTarget = tmp; @@ -107,7 +107,7 @@ void Creature::setTarget() void Creature::checkTarget() { - for(std::list <Entity*>::iterator it = N.begin(); it!=N.end(); it++) + for(std::list <Entity*>::iterator it = nearMe.begin(); it!=nearMe.end(); it++) if( target == *it ) return; @@ -118,73 +118,73 @@ void Creature::checkTarget() void Creature::Action() { if(hasTarget){ - if( Distance(L,target->getLocation()) < mine.reach && target->getType() == RESOURCE_TYPE){ - target->eat(mine.bite); - health+=mine.bite; + if( Distance(L,target->getRectangle()) < myDNA.reach && target->getType() == RESOURCE_TYPE){ + target->eat(myDNA.bite); + health+=myDNA.bite; amountAte++; - //if(L.w <= mine.sizeMax && mine.amountToGrow <= amountAte){ + //if(L.w <= myDNA.sizeMax && myDNA.amountToGrow <= amountAte){ // amountAte = 0; // L.w = L.h = L.w + 1; //} if(target->getAmount()<=0) hasTarget = false; } - else if( Distance(L,target->getLocation()) < mine.reach && target->getType() == CREATURE_TYPE && target->getGender() != gender ){ - target->impregnate(mine); + else if( Distance(L,target->getRectangle()) < myDNA.reach && target->getType() == CREATURE_TYPE && target->getGender() != gender ){ + target->impregnate(myDNA); hasTarget = false; } else - moveTowards(target->getLocation()); + moveTowards(target->getRectangle()); } else if(wander){ - if(Distance(L,wTarget) < mine.reach) + if(Distance(L,wTarget) < myDNA.reach) wander = false; else moveTowards(wTarget); } } -void Creature::moveTowards(Location t) +void Creature::moveTowards(Rectangle t) { if( L.x == t.x ){ if( L.y < t.y ) - L.y+=mine.speed; + L.y+=myDNA.speed; else - L.y-=mine.speed; + L.y-=myDNA.speed; } else if( L.y == t.y ){ if( L.x < t.x ) - L.x+=mine.speed; + L.x+=myDNA.speed; else - L.x-=mine.speed; + L.x-=myDNA.speed; } else if( L.x < t.x ){ if( L.y < t.y ){ - L.x+=mine.speed; - L.y+=mine.speed; + L.x+=myDNA.speed; + L.y+=myDNA.speed; } else{ - L.x+=mine.speed; - L.y-=mine.speed; + L.x+=myDNA.speed; + L.y-=myDNA.speed; } } else if ( L.x > t.x ){ if( L.y < t.y ){ - L.x-=mine.speed; - L.y+=mine.speed; + L.x-=myDNA.speed; + L.y+=myDNA.speed; } else{ - L.x-=mine.speed; - L.y-=mine.speed; + L.x-=myDNA.speed; + L.y-=myDNA.speed; } } } -void Creature::impregnate(Dna D) +void Creature::impregnate(DNA D) { if(!pregnate){ pregnate = true; pregnancyTime = 0; - childs = mine.combine(D); + childsDNA = myDNA.combine(D); } } diff --git a/src/dna.cpp b/src/dna.cpp index 1145276..bc51fd9 100644 --- a/src/dna.cpp +++ b/src/dna.cpp @@ -1,6 +1,6 @@ #include "dna.hpp" -Dna::Dna() +DNA::DNA() { maxHealth = CREATURE_MAX_HEALTH; speed = CREATURE_SPEED; @@ -13,9 +13,9 @@ Dna::Dna() sizeMax = CREATURE_SIZE_MAX; } -Dna Dna::combine(Dna D) +DNA DNA::combine(DNA D) { - Dna N; + DNA N; N.maxHealth = (this->maxHealth + D.maxHealth)/2; N.speed = (this->speed + D.speed)/2; diff --git a/src/list.cpp b/src/list.cpp index fab5813..e83822f 100644 --- a/src/list.cpp +++ b/src/list.cpp @@ -3,9 +3,8 @@ List::List() { int i; - Dna defaultDNA; - //SDL_Rect rect = {0,0,defaultDNA.sizeMax/5,defaultDNA.sizeMax/5}; - Location tmp; + DNA defaultDNA; + Rectangle tmp; tmp.x = tmp.y = 0; for(i=0;i<CREATURES;i++){ Creature X(tmp,defaultDNA); @@ -26,7 +25,7 @@ void List::Remove() { for(std::list<Creature>::iterator it = C.begin(); it!=C.end(); it++) if(it->getHealth()<=0){ - Location tmp = it->getLocation(); + Rectangle tmp = it->getRectangle(); Resource r = Resource(tmp); R.push_back(r); C.erase(it--); @@ -41,12 +40,12 @@ void List::Behavior() { for(std::list<Creature>::iterator it = C.begin(); it!=C.end(); it++){ std::list<Entity*> N = getNear(*it); - it->giveN(N); + it->giveNearMe(N); it->Behavior(); if(it->getPregnancyReady()){ - Dna D = it->getChildDNA(); - Location tmp = it->getLocation(); + DNA D = it->getChildsDNA(); + Rectangle tmp = it->getRectangle(); Creature X(tmp,D); C.push_back(X); it->hadPregnancy(); @@ -61,7 +60,7 @@ void List::Place() { tree.clear(); - Location tmp; + Rectangle tmp; tmp.x = tmp.y = 0; while(R.size() < MINIMUM_RESOURCES){ Resource Y(tmp); diff --git a/src/main.cpp b/src/main.cpp index e385f9f..eb4438f 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -55,10 +55,10 @@ int main() shader.Bind();
_spriteBatch.begin();
for(std::list<Creature>::iterator it = L.C.begin(); it != L.C.end(); it++)
- _spriteBatch.draw(it->gfxData);;
+ _spriteBatch.draw(it->getGFXD());;
for(std::list<Resource>::iterator it = L.R.begin(); it != L.R.end(); it++)
- _spriteBatch.draw(it->gfxData);;
+ _spriteBatch.draw(it->getGFXD());;
_spriteBatch.end();
_spriteBatch.renderBatch();
diff --git a/src/quadtree.cpp b/src/quadtree.cpp index e347e55..9fd4f0c 100644 --- a/src/quadtree.cpp +++ b/src/quadtree.cpp @@ -13,7 +13,7 @@ Quadtree::Quadtree(int pLevel, Rectangle pBounds){ gfxDataRect.r = 255;
gfxDataRect.g = 0;
gfxDataRect.b = 255;
- gfxDataRect.sides = pBounds.height;
+ gfxDataRect.sides = pBounds.h;
}
void Quadtree::clear(){
@@ -31,10 +31,10 @@ void Quadtree::clear(){ }
void Quadtree::split(){
- float subWidth = (bounds.getWidth() / 2);
- float subHeight = (bounds.getHeight() / 2);
- float x = bounds.getX();
- float y = bounds.getY();
+ float subWidth = (bounds.w / 2);
+ float subHeight = (bounds.h / 2);
+ float x = bounds.x;
+ float y = bounds.y;
Rectangle R0(x + subWidth/2, y + subHeight/2, subWidth, subHeight);
@@ -57,16 +57,16 @@ void Quadtree::clear(){ int Quadtree::getIndex(GraphicsData object) {
int index = -1;
- bool topQuadrant = (object.getY() > bounds.getY());
- bool bottomQuadrant = (object.getY() < bounds.getY());
+ bool topQuadrant = (object.y > bounds.y);
+ bool bottomQuadrant = (object.y < bounds.y);
- if (object.getX() < bounds.getX()) {
+ if (object.x < bounds.x) {
if (topQuadrant)
index = 1;
else if (bottomQuadrant)
index = 2;
}
- else if (object.getX() > bounds.getX()) {
+ else if (object.x > bounds.x) {
if (topQuadrant)
index = 0;
else if (bottomQuadrant)
diff --git a/src/resource.cpp b/src/resource.cpp index 31811ca..fdb4bf0 100644 --- a/src/resource.cpp +++ b/src/resource.cpp @@ -1,6 +1,6 @@ #include "resource.hpp" -Resource::Resource(Location t) +Resource::Resource(Rectangle t) { L = t; |