aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClyne Sullivan <tullivan99@gmail.com>2016-01-12 07:40:29 -0500
committerClyne Sullivan <tullivan99@gmail.com>2016-01-12 07:40:29 -0500
commit1574754cdaca14d68459cc520b63b6b3c449ecbd (patch)
tree45964411f6e342386914e6688e31a5ccec6d4e5a
parentd3792c499ce9e33f314e06d102d2a0119108e8d3 (diff)
parente08983ddccf0beee79e63bdf3ef1b839ea947c7a (diff)
links / lamps
-rw-r--r--assets/lampPost1.pngbin0 -> 309 bytes
-rw-r--r--assets/townhall.pngbin0 -> 802 bytes
-rw-r--r--include/entities.h15
-rw-r--r--include/world.h4
-rw-r--r--src/entities.cpp102
-rw-r--r--src/ui.cpp3
-rw-r--r--src/world.cpp8
-rw-r--r--test.frag24
-rw-r--r--xml/playerSpawnHill1.xml1
9 files changed, 100 insertions, 57 deletions
diff --git a/assets/lampPost1.png b/assets/lampPost1.png
new file mode 100644
index 0000000..24f1807
--- /dev/null
+++ b/assets/lampPost1.png
Binary files differ
diff --git a/assets/townhall.png b/assets/townhall.png
new file mode 100644
index 0000000..7b510e8
--- /dev/null
+++ b/assets/townhall.png
Binary files differ
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 28d7a09..ef37365 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;
}
diff --git a/src/ui.cpp b/src/ui.cpp
index 64ebe92..0d01033 100644
--- a/src/ui.cpp
+++ b/src/ui.cpp
@@ -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 e2c6aa9..451a022 100644
--- a/src/world.cpp
+++ b/src/world.cpp
@@ -1057,9 +1057,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;
@@ -1067,11 +1067,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);
diff --git a/test.frag b/test.frag
index c6ff3c9..5c9054e 100644
--- a/test.frag
+++ b/test.frag
@@ -2,22 +2,23 @@
uniform sampler2D sampler;
uniform int numLight;
-uniform vec2 lightLocation[255];
+uniform vec2 lightLocation[1024];
uniform vec3 lightColor;
uniform float amb;
-// uniform float lightStrength;
-//uniform float screenHeight;
+
+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];
- //if(loc.x == 0.0f) continue;
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;
- //vec4 color = vec4(1.0f,1.0f,1.0f,1.0f);
color += vec4(attenuation, attenuation, attenuation, 1.0f) * vec4(lightColor, 1.0f);
- //color = color + vec4((vec3(lightColor.r + amb, lightColor.g + amb, lightColor.b + amb)*0.25f),1.0f);
}
vec2 coords = gl_TexCoord[0].st;
vec4 tex = texture2D(sampler, coords);
@@ -25,3 +26,12 @@ void main(){
color += vec4(amb,amb,amb,1.0f+amb);
gl_FragColor = tex * vec4(color)*tex.a;
}
+
+/* b values
+ .002 10
+ .008 50
+ .0005 200
+ .00008 500
+ .00002 1000
+ .00005 2000
+*/
diff --git a/xml/playerSpawnHill1.xml b/xml/playerSpawnHill1.xml
index fbf5d8d..5ad31b0 100644
--- a/xml/playerSpawnHill1.xml
+++ b/xml/playerSpawnHill1.xml
@@ -9,6 +9,7 @@
<npc name="Ralph" hasDialog="true" />
<npc name="Johnny" hasDialog="true" />
+ <structure type="6"/>
</World>