diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/creature.cpp | 23 | ||||
-rw-r--r-- | src/entity.cpp | 31 | ||||
-rw-r--r-- | src/list.cpp | 7 | ||||
-rw-r--r-- | src/resource.cpp | 32 | ||||
-rw-r--r-- | src/window.cpp | 2 |
5 files changed, 57 insertions, 38 deletions
diff --git a/src/creature.cpp b/src/creature.cpp index ead0b2d..7e9011a 100644 --- a/src/creature.cpp +++ b/src/creature.cpp @@ -1,16 +1,18 @@ #include "creature.hpp" -Creature::Creature(Window m, std::string s) +Creature::Creature(Window m, int size) { - texture = loadTexture(s, m); - renderer = m.getRenderer(); - health = 500; - maxHealth = 1000; - - L.y=rand()%800; - L.x=rand()%1200; + Init(m); type = 1; + + rect.h = rect.w = size; + + L.x = rect.x; + L.y = rect.y; + health = 500; + maxHealth = 1000; + hungry = false; hasTarget = false; wander = false; @@ -42,6 +44,9 @@ void Creature::Priority() void Creature::setTarget() { + if(hasTarget) + return; + for(list <Entity*>::iterator it = N.begin(); it!=N.end(); it++){ if((*it)->getType() == 2 && hungry){ if(!hasTarget){ @@ -117,4 +122,6 @@ void Creature::Move(Location l) L.y-=speed; } } + rect.x = L.x; + rect.y = L.y; } diff --git a/src/entity.cpp b/src/entity.cpp index 4f60851..be3e792 100644 --- a/src/entity.cpp +++ b/src/entity.cpp @@ -1,18 +1,27 @@ #include "entity.hpp" -void Entity::Place() +void Entity::Init(Window m) +{ + renderer = m.getRenderer(); + rect.y = rand()%640; + rect.x = rand()%1080; +} + +void Entity::Init(Window m, Location z) { - SDL_Rect rect = {L.x, L.y, width/8, height/8}; - SDL_RenderCopyEx(renderer,texture,NULL,&rect,degrees,NULL,SDL_FLIP_NONE); + renderer = m.getRenderer(); + rect.y = z.y; + rect.x = z.x; } -SDL_Texture* Entity::loadTexture(string path, Window main) +void Entity::Place() { - SDL_Surface* surface = IMG_Load(path.c_str()); - SDL_SetColorKey(surface, SDL_TRUE, SDL_MapRGB(surface->format, 255, 255, 255)); - height = surface->h; - width = surface->w; - SDL_Texture* texture = SDL_CreateTextureFromSurface(main.getRenderer(),surface); - SDL_FreeSurface(surface); - return texture; + if(type == 1) + SDL_SetRenderDrawColor(renderer,255,0,255,255); + else + SDL_SetRenderDrawColor(renderer,0,255,0,255); + + SDL_RenderDrawRect(renderer, &rect); + + SDL_SetRenderDrawColor(renderer,0,0,0,255); } diff --git a/src/list.cpp b/src/list.cpp index e08531b..2fca4f4 100644 --- a/src/list.cpp +++ b/src/list.cpp @@ -5,12 +5,12 @@ List::List(Window m) int i; for(i=0;i<10;i++){ - Creature X(m,"img/Cbasic.png"); + Creature X(m,10); C.push_back(X); } for(i=0;i<100;i++){ - Resource Y(m,"img/Rbasic.png"); + Resource Y(m,5); R.push_back(Y); } @@ -41,7 +41,8 @@ void List::Behavior() if(it->getHealth()<=0){ Location z = it->getLocation(); - Resource r = Resource(main,"img/Cdead.png",z); + SDL_Rect rect = it->getRect(); + Resource r = Resource(main,rect.w,z); R.push_back(r); C.erase(it--); } diff --git a/src/resource.cpp b/src/resource.cpp index 08929bc..0c07be3 100644 --- a/src/resource.cpp +++ b/src/resource.cpp @@ -1,27 +1,29 @@ #include "resource.hpp" -Resource::Resource(Window m, std::string s) -{ - texture = loadTexture(s, m); - renderer = m.getRenderer(); - - L.y = rand()%800; - L.x = rand()%1200; +Resource::Resource(Window m, int size) +{ + Init(m); type = 2; + rect.h = rect.w = size; + + L.x = rect.x; + L.y = rect.y; + amount = 100; } -Resource::Resource(Window m, std::string s, Location z) +Resource::Resource(Window m, int size, Location z) { - texture = loadTexture(s, m); - renderer = m.getRenderer(); - - L.y = z.y; - L.x = z.x; + Init(m,z); type = 2; - - amount = 100; + + rect.h = rect.w = size; + + L.x = rect.x; + L.y = rect.y; + + amount = 200; } void Resource::eat() diff --git a/src/window.cpp b/src/window.cpp index 5df97cf..fccdef0 100644 --- a/src/window.cpp +++ b/src/window.cpp @@ -3,7 +3,7 @@ Window::Window() { SDL_Init(SDL_INIT_VIDEO); - main = SDL_CreateWindow("main",SDL_WINDOWPOS_UNDEFINED,SDL_WINDOWPOS_UNDEFINED,1280,800,SDL_WINDOW_SHOWN); + main = SDL_CreateWindow("main",SDL_WINDOWPOS_UNDEFINED,SDL_WINDOWPOS_UNDEFINED,1080,640,SDL_WINDOW_SHOWN); renderer = SDL_CreateRenderer(main,-1,SDL_RENDERER_ACCELERATED); SDL_SetRenderDrawColor(renderer, 0, 0, 0, 0); } |