Turned the heightmap loading around so the level now is like the png. The wall backsides dont seem to have textures...
This commit is contained in:
parent
87b9634703
commit
eab9270b94
@ -69,19 +69,19 @@ int main( int argc, char *argv[] ){
|
|||||||
}
|
}
|
||||||
printf("Iterating over the png.\n");
|
printf("Iterating over the png.\n");
|
||||||
//iterate over all pixels of the image
|
//iterate over all pixels of the image
|
||||||
for(unsigned int rowNum = 0; rowNum < height; rowNum++){
|
|
||||||
for(unsigned int columnNum = 0; columnNum < width; columnNum++){
|
for(unsigned int columnNum = 0; columnNum < width; columnNum++){
|
||||||
|
for(unsigned int rowNum = 0; rowNum < height; rowNum++){
|
||||||
unsigned int pixel = (rowNum*width+columnNum)*4;
|
unsigned int pixel = (rowNum*width+columnNum)*4;
|
||||||
//if there is a composition here, adjust the xml and image
|
//if there is a composition here, adjust the xml and image
|
||||||
if(image[pixel]!=0 && image[pixel]!=255){
|
if(image[pixel]!=0 && image[pixel]!=255){
|
||||||
if(image[pixel+1]==0 && image[pixel+2]==0){//composition has no ID
|
if(image[pixel+1]==0 && image[pixel+2]==0){//composition has no ID
|
||||||
std::vector<int> newID;
|
std::vector<int> newID;
|
||||||
newID = conv.newComposition(image[pixel], 0.5+rowNum-0.5*height, 0.5+columnNum-0.5*width);
|
newID = conv.newComposition(image[pixel], 0.5+columnNum-0.5*width, 0.5+rowNum-0.5*height);
|
||||||
idFound[newID[0]][newID[1]] = true;
|
idFound[newID[0]][newID[1]] = true;
|
||||||
image[pixel+1] = newID[0];
|
image[pixel+1] = newID[0];
|
||||||
image[pixel+2] = newID[1];
|
image[pixel+2] = newID[1];
|
||||||
}else{//composition has an ID
|
}else{//composition has an ID
|
||||||
conv.updateComposition(image[pixel+1], image[pixel+2], 0.5+rowNum-0.5*height, 0.5+columnNum-0.5*width);
|
conv.updateComposition(image[pixel+1], image[pixel+2], 0.5+columnNum-0.5*width, 0.5+rowNum-0.5*height);
|
||||||
idFound[image[pixel+1]][image[pixel+2]] = true;
|
idFound[image[pixel+1]][image[pixel+2]] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -226,7 +226,7 @@
|
|||||||
<yOffset>20.0</yOffset>
|
<yOffset>20.0</yOffset>
|
||||||
<zOffset>0.0</zOffset>
|
<zOffset>0.0</zOffset>
|
||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>0.0</yRot>
|
<yRot>90.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.5</scale>
|
<scale>1.5</scale>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
@ -243,7 +243,7 @@
|
|||||||
<yOffset>20.0</yOffset>
|
<yOffset>20.0</yOffset>
|
||||||
<zOffset>0.0</zOffset>
|
<zOffset>0.0</zOffset>
|
||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>90.0</yRot>
|
<yRot>0.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.5</scale>
|
<scale>1.5</scale>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
@ -264,7 +264,7 @@
|
|||||||
<yOffset>20.0</yOffset>
|
<yOffset>20.0</yOffset>
|
||||||
<zOffset>0.0</zOffset>
|
<zOffset>0.0</zOffset>
|
||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>0.0</yRot>
|
<yRot>90.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.5</scale>
|
<scale>1.5</scale>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
@ -314,7 +314,7 @@
|
|||||||
<yOffset>20.0</yOffset>
|
<yOffset>20.0</yOffset>
|
||||||
<zOffset>0.0</zOffset>
|
<zOffset>0.0</zOffset>
|
||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>90.0</yRot>
|
<yRot>0.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.5</scale>
|
<scale>1.5</scale>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
@ -364,7 +364,7 @@
|
|||||||
<yOffset>25.0</yOffset>
|
<yOffset>25.0</yOffset>
|
||||||
<zOffset>0.0</zOffset>
|
<zOffset>0.0</zOffset>
|
||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>0.0</yRot>
|
<yRot>90.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.48</scale>
|
<scale>1.48</scale>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
@ -381,7 +381,7 @@
|
|||||||
<yOffset>25.0</yOffset>
|
<yOffset>25.0</yOffset>
|
||||||
<zOffset>0.0</zOffset>
|
<zOffset>0.0</zOffset>
|
||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>90.0</yRot>
|
<yRot>0.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.48</scale>
|
<scale>1.48</scale>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
@ -415,7 +415,7 @@
|
|||||||
<yOffset>25.0</yOffset>
|
<yOffset>25.0</yOffset>
|
||||||
<zOffset>0.0</zOffset>
|
<zOffset>0.0</zOffset>
|
||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>0.0</yRot>
|
<yRot>90.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.5</scale>
|
<scale>1.5</scale>
|
||||||
<mass>100.0</mass>
|
<mass>100.0</mass>
|
||||||
@ -432,7 +432,7 @@
|
|||||||
<yOffset>25.0</yOffset>
|
<yOffset>25.0</yOffset>
|
||||||
<zOffset>0.0</zOffset>
|
<zOffset>0.0</zOffset>
|
||||||
<xRot>0.0</xRot>
|
<xRot>0.0</xRot>
|
||||||
<yRot>90.0</yRot>
|
<yRot>0.0</yRot>
|
||||||
<zRot>0.0</zRot>
|
<zRot>0.0</zRot>
|
||||||
<scale>1.5</scale>
|
<scale>1.5</scale>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 2.3 KiB After Width: | Height: | Size: 3.6 KiB |
14012
data/levels/Level1.xml
14012
data/levels/Level1.xml
File diff suppressed because it is too large
Load Diff
@ -8283,7 +8283,7 @@
|
|||||||
<rColour>1.0</rColour>
|
<rColour>1.0</rColour>
|
||||||
<gColour>1.0</gColour>
|
<gColour>1.0</gColour>
|
||||||
<bColour>0.9</bColour>
|
<bColour>0.9</bColour>
|
||||||
<intensity>0.2</intensity>
|
<intensity>0.6</intensity>
|
||||||
</directionalLight>
|
</directionalLight>
|
||||||
|
|
||||||
<terrain>
|
<terrain>
|
||||||
|
@ -10,9 +10,9 @@ function trigger(objectToChange)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local strength = 100
|
local strength = 100
|
||||||
local xPos = 81.5
|
local xPos = 17.5
|
||||||
local yPos = 35
|
local yPos = 35
|
||||||
local zPos = 17.5
|
local zPos = 81.5
|
||||||
level:moveObject(objectToChange, strength, xPos, yPos, zPos)
|
level:moveObject(objectToChange, strength, xPos, yPos, zPos)
|
||||||
|
|
||||||
global.triggeredOpenFirstDoorUndo = false
|
global.triggeredOpenFirstDoorUndo = false
|
||||||
|
@ -10,9 +10,9 @@ function trigger(objectToChange)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local strength = 100
|
local strength = 100
|
||||||
local xPos = 81.5
|
local xPos = 17.5
|
||||||
local yPos = 25
|
local yPos = 25
|
||||||
local zPos = 17.5
|
local zPos = 81.5
|
||||||
level:moveObject(objectToChange, strength, xPos, yPos, zPos)
|
level:moveObject(objectToChange, strength, xPos, yPos, zPos)
|
||||||
|
|
||||||
global.triggeredOpenFirstDoor = false
|
global.triggeredOpenFirstDoor = false
|
||||||
|
10
terrain.cc
10
terrain.cc
@ -18,11 +18,11 @@ void Terrain::load() {
|
|||||||
if (error) {
|
if (error) {
|
||||||
std::cout << "Decoder error " << error << " from Terrain::load: " << lodepng_error_text(error) << std::endl;
|
std::cout << "Decoder error " << error << " from Terrain::load: " << lodepng_error_text(error) << std::endl;
|
||||||
}
|
}
|
||||||
this->heightmap = new float*[this->heightmapHeight]; //initialize the heightmap
|
this->heightmap = new float*[this->heightmapWidth]; //initialize the heightmap
|
||||||
for(unsigned int rowNum = 0; rowNum < this->heightmapHeight; rowNum++){ //read in the heightmap
|
for(unsigned int columnNum = 0; columnNum < this->heightmapWidth; columnNum++){ //read in the heightmap
|
||||||
this->heightmap[rowNum] = new float[this->heightmapWidth];
|
this->heightmap[columnNum] = new float[this->heightmapHeight];
|
||||||
for(unsigned int columnNum = 0; columnNum < this->heightmapWidth; columnNum++){
|
for(unsigned int rowNum = 0; rowNum < this->heightmapHeight; rowNum++){
|
||||||
this->heightmap[rowNum][columnNum] = (float)(image[(rowNum*heightmapWidth+columnNum)*4]) / 6; //<--heightmap is scaled here
|
this->heightmap[columnNum][rowNum] = (float)(image[(rowNum*heightmapWidth+columnNum)*4]) / 6; //<--heightmap is scaled here
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this->makeTriangleMesh();
|
this->makeTriangleMesh();
|
||||||
|
Loading…
Reference in New Issue
Block a user