diff options
author | drumsetmonkey <abelleisle@roadrunner.com> | 2016-01-12 07:37:19 -0500 |
---|---|---|
committer | drumsetmonkey <abelleisle@roadrunner.com> | 2016-01-12 07:37:19 -0500 |
commit | e08983ddccf0beee79e63bdf3ef1b839ea947c7a (patch) | |
tree | f6906803251ae27bd17bcc11685a6d7bde88cfbb | |
parent | 6bf27552a564297cd8aaf1e3c24d9320438bdcc5 (diff) |
Light posts
-rw-r--r-- | assets/lampPost1.png | bin | 0 -> 309 bytes | |||
-rw-r--r-- | assets/townhall.png | bin | 0 -> 802 bytes | |||
-rw-r--r-- | include/entities.h | 15 | ||||
-rw-r--r-- | include/world.h | 4 | ||||
-rw-r--r-- | src/entities.cpp | 102 | ||||
-rw-r--r-- | src/ui.cpp | 3 | ||||
-rw-r--r-- | src/world.cpp | 8 | ||||
-rw-r--r-- | test.frag | 22 | ||||
-rw-r--r-- | xml/playerSpawnHill1.xml | 1 |
9 files changed, 101 insertions, 54 deletions
diff --git a/assets/lampPost1.png b/assets/lampPost1.png Binary files differnew file mode 100644 index 0000000..24f1807 --- /dev/null +++ b/assets/lampPost1.png diff --git a/assets/townhall.png b/assets/townhall.png Binary files differnew file mode 100644 index 0000000..7b510e8 --- /dev/null +++ b/assets/townhall.png diff --git a/include/entities.h b/include/entities.h index f26863e..d7ad2c0 100644 --- a/include/entities.h +++ b/include/entities.h @@ -37,12 +37,13 @@ enum MOB_SUB { }; enum BUILD_SUB{ - TOWN_HALL = 1, - HOUSE, - HOUSE2, - HOUSE3, - HOUSE4, - FOUNTAIN + TOWN_HALL = 0, + HOUSE = 1, + HOUSE2 = 2, + HOUSE3 = 3, + HOUSE4 = 4, + FOUNTAIN = 5, + LAMP_POST = 6 }; typedef struct { @@ -211,7 +212,7 @@ public: Structures(); ~Structures(); - unsigned int spawn(_TYPE, BUILD_SUB, float, float, World *); + unsigned int spawn(BUILD_SUB, float, float, World *); char *save(void); void load(char *s); diff --git a/include/world.h b/include/world.h index 0e85462..7eb8c02 100644 --- a/include/world.h +++ b/include/world.h @@ -176,8 +176,8 @@ public: std::vector<Particles *> particles; std::vector<Light > light; - void addStructure(_TYPE t,BUILD_SUB sub,float x,float y,World *inside); - void addVillage(int bCount, int npcMin, int npcMax,_TYPE t,World *inside); + void addStructure(BUILD_SUB sub,float x,float y,World *inside); + void addVillage(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/src/entities.cpp b/src/entities.cpp index 57a20ef..627946b 100644 --- a/src/entities.cpp +++ b/src/entities.cpp @@ -13,6 +13,14 @@ extern Player *player; extern const char *itemName; +std::string sTexLoc[] = { "assets/townhall.png", + "assets/house1.png", + "assets/house2.png", + "assets/house1.png", + "assets/house1.png", + "assets/fountain1.png", + "assets/lampPost1.png"}; + void getRandomName(Entity *e){ unsigned int tempNum,max=0; char *bufs; @@ -119,9 +127,6 @@ Structures::Structures(){ //sets the structure type alive = false; near = false; - tex = new Texturec(3,"assets/house1.png", "assets/house2.png", "assets/fountain1.png"); - ntex = new Texturec(1, "assets/house1N.png"); - inWorld = NULL; name = NULL; @@ -282,7 +287,7 @@ void Entity::draw(void){ //draws the entities case MS_DOOR: case MS_PAGE: default: - glActiveTexture(GL_TEXTURE0 + 0); + glActiveTexture(GL_TEXTURE0); tex->bind(0); break; } @@ -290,27 +295,25 @@ void Entity::draw(void){ //draws the entities case STRUCTURET: for(auto &strt : currentWorld->build){ if(this == strt){ - if(strt->bsubtype == HOUSE){ - glActiveTexture(GL_TEXTURE1); - ntex->bind(0); - //When rendering an objectwith this program. - glActiveTexture(GL_TEXTURE0 + 0); - tex->bind(0); - //glBindSampler(0, linearFiltering); - - - }else if(strt->bsubtype == HOUSE2){ - glActiveTexture(GL_TEXTURE0 + 0); - tex->bind(1); - }else if(strt->bsubtype == FOUNTAIN){ - glActiveTexture(GL_TEXTURE0 + 0); - tex->bind(2); + switch(strt->bsubtype){ + /*case HOUSE: + glActiveTexture(GL_TEXTURE1); + ntex->bind(0); + //When rendering an objectwith this program. + glActiveTexture(GL_TEXTURE0); + tex->bind(0); + //glBindSampler(0, linearFiltering); + break;*/ + default: + glActiveTexture(GL_TEXTURE0); + tex->bind(0); + break; } } } break; default: - glActiveTexture(GL_TEXTURE0 + 0); + glActiveTexture(GL_TEXTURE0); tex->bind(0); break; } @@ -442,16 +445,16 @@ void Object::interact(void){ * point to have non-normal traits so it could be invisible or invincible... */ -unsigned int Structures::spawn(_TYPE t, BUILD_SUB sub, float x, float y, World *oi){ +unsigned int Structures::spawn(BUILD_SUB sub, float x, float y, World *oi){ loc.x = x; loc.y = y; - type = t; - + type = STRUCTURET; + alive = true; - width = 50 * HLINE; - height = 40 * HLINE; bsubtype = sub; + int s = -1; + s = sub; inWorld = oi; @@ -459,20 +462,45 @@ unsigned int Structures::spawn(_TYPE t, BUILD_SUB sub, float x, float y, World * * tempN is the amount of entities that will be spawned in the village. Currently the village * will spawn bewteen 2 and 7 villagers for the starting hut. */ - + /* tex = new Texturec(7,"assets/townhall.png", + "assets/house1.png", + "assets/house2.png", + "assets/house1.png", + "assets/house1.png", + "assets/fountain1.png", + "assets/lampPost1.png")*/; + unsigned int tempN = (getRand() % 5 + 2); - - for(unsigned int i = 0;i < tempN;i++){ - - /* - * This is where the entities actually spawn. A new entity is created - * with type NPC. - */ - - inWorld->addNPC(loc.x + i * HLINE ,100); - + switch(s){ + case HOUSE: + tex = new Texturec(1, sTexLoc[s].c_str()); + width = 50 * HLINE; + height = 40 * HLINE; + for(unsigned int i = 0;i < tempN;i++){ + + /* + * This is where the entities actually spawn. A new entity is created + * with type NPC. + */ + + oi->addNPC(loc.x + i * HLINE ,100); + + } + break; + case FOUNTAIN: + tex = new Texturec(1, sTexLoc[s].c_str()); + width = 50 * HLINE; + height = 40 * HLINE; + break; + case LAMP_POST: + tex = new Texturec(1, sTexLoc[s].c_str()); + width = 10 * HLINE; + height = 40 * HLINE; + oi->addLight({x+SCREEN_WIDTH/2,y+30*HLINE},{1.0f,1.0f,1.0f}); + break; + default: + break; } - return 0; } @@ -822,6 +822,9 @@ DONE: case SDLK_f: currentWorld->addLight({player->loc.x + SCREEN_WIDTH/2, player->loc.y},{1.0f,1.0f,1.0f}); break; + case SDLK_g: + currentWorld->addStructure(LAMP_POST, player->loc.x, player->loc.y, currentWorld); + break; default: break; } diff --git a/src/world.cpp b/src/world.cpp index e66fb0d..b06802c 100644 --- a/src/world.cpp +++ b/src/world.cpp @@ -1055,9 +1055,9 @@ LOOOOP: goto LOOOOP; } } -void World::addStructure(_TYPE t,BUILD_SUB sub, float x,float y,World *inside){ +void World::addStructure(BUILD_SUB sub, float x,float y,World *inside){ build.push_back(new Structures()); - build.back()->spawn(t,sub,x,y,this); + build.back()->spawn(sub,x,y,this); build.back()->inWorld=this; build.back()->inside = (World *)inside; ((IndoorWorld *)inside)->outside = this; @@ -1065,11 +1065,11 @@ void World::addStructure(_TYPE t,BUILD_SUB sub, float x,float y,World *inside){ entity.push_back(build.back()); } -void World::addVillage(int bCount, int npcMin, int npcMax,_TYPE t,World *inside){ +void World::addVillage(int bCount, int npcMin, int npcMax,World *inside){ std::cout << npcMin << ", " << npcMax << std::endl; //int xwasd; for(int i = 0; i < bCount; i++){ - addStructure(t,HOUSE,x_start + (i * 300),100,inside); + addStructure(HOUSE,x_start + (i * 300),100,inside); /*std::cout<<"1\n"; HERE: xwasd = (rand()%(int)x+1000*HLINE); @@ -1,17 +1,22 @@ -#version 130
+#version 120
uniform sampler2D sampler;
uniform int numLight;
-uniform vec2 lightLocation[255];
+uniform vec2 lightLocation[1024];
uniform vec3 lightColor;
uniform float amb;
+float b = .0005;
+float minLight = .05;
+float radius = sqrt(1.0 / (b * minLight));
+
void main(){
vec4 color = vec4(0.0f,0.0f,0.0f,0.0f);
for(int i = 0; i < numLight; i++){
vec2 loc = lightLocation[i];
float dist = length(loc - gl_FragCoord.xy);
- float attenuation=1.0/(1.0+0.01*dist+0.00000000001*dist*dist);
+ //float attenuation=1.0/(1.0+0.01*dist+0.00000000001*dist*dist);
+ float attenuation = clamp(1.0 - dist*dist/(radius*radius), 0.0, 1.0); attenuation *= attenuation;
color += vec4(attenuation, attenuation, attenuation, 1.0f) * vec4(lightColor, 1.0f);
}
@@ -20,4 +25,13 @@ void main(){ color += vec4(amb,amb,amb,1.0f+amb);
gl_FragColor = tex * vec4(color)*tex.a;
-}
\ No newline at end of file +}
+
+/*b values
+ .002 10
+ .008 50
+ .0005 200
+ .00008 500
+ .00002 1000
+ .00005 2000
+*/
\ No newline at end of file diff --git a/xml/playerSpawnHill1.xml b/xml/playerSpawnHill1.xml index 5a0e51f..60f7e7a 100644 --- a/xml/playerSpawnHill1.xml +++ b/xml/playerSpawnHill1.xml @@ -7,6 +7,7 @@ <npc name="Ralph" hasDialog="true" /> <npc name="Johnny" hasDialog="true" /> + <structure type="6"/> </World> |