From 23a4b0cc3ab09d58127a73b12c43aff37e5056ef Mon Sep 17 00:00:00 2001 From: drumsetmonkey Date: Wed, 13 Jan 2016 07:31:16 -0500 Subject: Fire Pit --- include/entities.h | 10 ++++++++-- include/world.h | 2 +- main.cpp | 19 ++++++++++++++----- src/common.cpp | 1 - src/entities.cpp | 26 +++++++++++++++++--------- src/ui.cpp | 19 +++++++++++++++++++ src/world.cpp | 34 +++++++++++++--------------------- xml/playerSpawnHill1.xml | 2 +- 8 files changed, 73 insertions(+), 40 deletions(-) diff --git a/include/entities.h b/include/entities.h index d7ad2c0..fe0d014 100644 --- a/include/entities.h +++ b/include/entities.h @@ -43,7 +43,8 @@ enum BUILD_SUB{ HOUSE3 = 3, HOUSE4 = 4, FOUNTAIN = 5, - LAMP_POST = 6 + LAMP_POST = 6, + FIRE_PIT = 7 }; typedef struct { @@ -83,6 +84,8 @@ public: Color color; int duration; bool canMove; + bool fountain; + bool gravity; Particles(float x, float y, float w, float h, float vx, float vy, Color c, int d){ loc.x = (x); loc.y = (y); @@ -94,6 +97,8 @@ public: color.green = (c.green); color.blue = (c.blue); duration = d; + fountain = false; + gravity = true; } ~Particles(){} void draw(){ @@ -102,8 +107,9 @@ public: } bool kill(float delta){ duration -= delta; - if(duration <= 0) + if(duration <= 0){ return true; + } else return false; } }; diff --git a/include/world.h b/include/world.h index ef37365..7f22cba 100644 --- a/include/world.h +++ b/include/world.h @@ -177,7 +177,7 @@ public: std::vector light; void addStructure(BUILD_SUB sub,float x,float y,World *inside); - void addVillage(int bCount, int npcMin, int npcMax,World *inside); + void addVillage(int x, int y, int bCount, int npcMin, int npcMax,World *inside); void addMob(int t,float x,float y); void addMob(int t,float x,float y,void (*hey)(Mob *)); void addNPC(float x,float y); diff --git a/main.cpp b/main.cpp index 79c7250..8254d9b 100644 --- a/main.cpp +++ b/main.cpp @@ -937,17 +937,26 @@ void logic(){ o->interact(); objectInteracting=false; } - } } - } } } for(auto &b : currentWorld->build){ - if(b->bsubtype == FOUNTAIN){ - for(int r = 0; r < (rand()%20)+10;r++) - currentWorld->addParticle(rand()%HLINE*3 + b->loc.x + b->width/2,b->loc.y + b->height, HLINE,HLINE, rand()%2 == 0?-(rand()%7)*.01:(rand()%7)*.01,((4+rand()%6)*.05), {0,0,1.0f}, 2500); + switch(b->bsubtype){ + case FOUNTAIN: + for(int r = 0; r < (rand()%20)+10;r++){ + currentWorld->addParticle(rand()%HLINE*3 + b->loc.x + b->width/2,b->loc.y + b->height, HLINE,HLINE, rand()%2 == 0?-(rand()%7)*.01:(rand()%7)*.01,((4+rand()%6)*.05), {0,0,1.0f}, 2500); + currentWorld->particles.back()->fountain = true; + } + break; + case FIRE_PIT: + for(int r = 0; r < (rand()%20)+10;r++){ + currentWorld->addParticle(rand()%(int)(b->width) + b->loc.x, b->loc.y, HLINE, HLINE, rand()%2 == 0?-(rand()%7)*.01:(rand()%7)*.01,((4+rand()%6)*.05), {1.0f,0.0f,0.0f}, 100); + currentWorld->particles.back()->gravity = false; + } + break; + default: break; } } diff --git a/src/common.cpp b/src/common.cpp index 6307790..ead2dc3 100644 --- a/src/common.cpp +++ b/src/common.cpp @@ -84,7 +84,6 @@ void strVectorSortAlpha(std::vector *v){ change = false; for(unsigned int i=0;isize()-1;i++){ if(v[0][i] > v[0][i+1]){ - std::cout<<"swap "< "<addNPC(loc.x + i * HLINE ,100); - } break; case FOUNTAIN: - tex = new Texturec(1, sTexLoc[s].c_str()); + tex = new Texturec(1, sTexLoc[sub].c_str()); width = 50 * HLINE; height = 40 * HLINE; break; case LAMP_POST: - tex = new Texturec(1, sTexLoc[s].c_str()); + tex = new Texturec(1, sTexLoc[sub].c_str()); width = 10 * HLINE; height = 40 * HLINE; oi->addLight({x+SCREEN_WIDTH/2,y+30*HLINE},{1.0f,1.0f,1.0f}); break; + case FIRE_PIT: + tex = new Texturec(1, sTexLoc[sub].c_str()); + width = 12 * HLINE; + height = 12 * HLINE; + break; default: break; } diff --git a/src/ui.cpp b/src/ui.cpp index 0d01033..4212307 100644 --- a/src/ui.cpp +++ b/src/ui.cpp @@ -824,6 +824,25 @@ DONE: break; case SDLK_g: currentWorld->addStructure(LAMP_POST, player->loc.x, player->loc.y, currentWorld); + break; + case SDLK_h: + currentWorld->addStructure(TOWN_HALL, player->loc.x, player->loc.y, currentWorld); + break; + case SDLK_j: + currentWorld->addStructure(FOUNTAIN, player->loc.x, player->loc.y, currentWorld); + break; + case SDLK_v: + currentWorld->addVillage(player->loc.x, player->loc.y, 5, 10, 100, currentWorld); + break; + case SDLK_b: + currentWorld->addStructure(FIRE_PIT, player->loc.x, player->loc.y, currentWorld); + break; + case SDLK_F12: + std::cout << "Took screenshot" << std::endl; + // Make the BYTE array, factor of 3 because it's RBG. + static GLubyte* pixels = new GLubyte[ 3 * SCREEN_WIDTH * SCREEN_HEIGHT]; + glReadPixels(0, 0, SCREEN_WIDTH, SCREEN_HEIGHT, GL_RGB, GL_UNSIGNED_BYTE, pixels); + break; default: break; diff --git a/src/world.cpp b/src/world.cpp index 451a022..e56720d 100644 --- a/src/world.cpp +++ b/src/world.cpp @@ -231,9 +231,12 @@ void World::deleteEntities(void){ entity.pop_back(); } while(!particles.empty()){ - delete particles.back(); + //delete particles.back(); particles.pop_back(); } + while(!light.empty()){ + light.pop_back(); + } } World::~World(void){ @@ -426,14 +429,13 @@ void World::update(Player *p,unsigned int delta){ uint oh = 0; for(auto &pa : particles){ if(pa->kill(deltaTime)){ - delete pa; + //delete pa; particles.erase(particles.begin()+oh); }else if(pa->canMove){ pa->loc.y += pa->vely * deltaTime; pa->loc.x += pa->velx * deltaTime; - for(auto &b : build){ - if(b->bsubtype==FOUNTAIN){ + if(b->bsubtype==FOUNTAIN && pa->fountain){ if(pa->loc.x >= b->loc.x && pa->loc.x <= b->loc.x+b->width){ if(pa->loc.y <= b->loc.y + b->height*.25){ delete pa; @@ -442,8 +444,7 @@ void World::update(Player *p,unsigned int delta){ } } } - } - oh++; + }oh++; }oh=0; if(ui::dialogImportant){ @@ -1048,7 +1049,7 @@ LOOOOP: part->velx = 0; part->canMove = false; }else{ - if(part->vely > -2)part->vely-=.003 * deltaTime; + if(!part->gravity && part->vely > -2)part->vely-=.003 * deltaTime; } what++; }what=0; @@ -1067,21 +1068,12 @@ void World::addStructure(BUILD_SUB sub, float x,float y,World *inside){ entity.push_back(build.back()); } -void World::addVillage(int bCount, int npcMin, int npcMax,World *inside){ +void World::addVillage(int x, int y, int bCount, int npcMin, int npcMax,World *inside){ std::cout << npcMin << ", " << npcMax << std::endl; - //int xwasd; - for(int i = 0; i < bCount; i++){ - addStructure(HOUSE,x_start + (i * 300),100,inside); - /*std::cout<<"1\n"; - HERE: - xwasd = (rand()%(int)x+1000*HLINE); - for(auto &bu : build){ - if(xwasd > bu->loc.x && xwasd < bu->loc.x+bu->width)goto HERE; - } - std::cout<<"2\n"; - addStructure(t,HOUSE,xwasd,y,inside); - std::cout<<"3\n";*/ - } + this->addStructure(TOWN_HALL, x,y, inside); + bCount--; + this->addStructure(LAMP_POST, x-3*HLINE,y, this); + this->addStructure(LAMP_POST, x+53*HLINE,y, this); } void World::addMob(int t,float x,float y){ mob.push_back(new Mob(t)); diff --git a/xml/playerSpawnHill1.xml b/xml/playerSpawnHill1.xml index 5ad31b0..c8ea827 100644 --- a/xml/playerSpawnHill1.xml +++ b/xml/playerSpawnHill1.xml @@ -37,6 +37,6 @@ - My name's Johnny. + ****FREE WIRELESS KEYBOARD**JAM PACKED FULL OF GOODIES TOO MUCH TO MENTION** SUPPLIED WITH ANDROID TV BOX BLACK **CUSTOM BUILT XBMC APPLE TV AIRPLAY SYSTEM ** FULLY LOADED QUAD CORE**4K KITKAT ULTRA-HD XBMC ALL FREE ONE OFF PURCHASE FOR THE BOX FREE TV FREE MUSIC FREE MOVIES FREE SPORTS FREE GAMES FREE XXX NEXT GENERATION ANDROID TV BOX FASTEST ON THE MARKET TO DATE RELEASE 2015 FREE WORLDWIDE TV AT YOUR FINGER TIPS WIFI AND ETHERNET CONNECTION 5 Ghz WIFI -- cgit v1.2.3