Skip to content

Commit

Permalink
Trying to make the dump a bit more usefull and slightly less cluttered
Browse files Browse the repository at this point in the history
  • Loading branch information
Godzil committed Mar 9, 2020
1 parent 15a8618 commit 4e241a1
Show file tree
Hide file tree
Showing 6 changed files with 83 additions and 26 deletions.
2 changes: 2 additions & 0 deletions source/include/smoothtriangle.h
Expand Up @@ -23,6 +23,8 @@ class SmoothTriangle : public Triangle

public:
SmoothTriangle(Point p1, Point p2, Point p3, Vector n1, Vector n2, Vector n3);

void dumpMe(FILE *fp);
};

#endif /* DORAYME_SMOOTHTRIANGLE_H */
15 changes: 14 additions & 1 deletion source/shapes/objfile.cpp
Expand Up @@ -214,7 +214,20 @@ void OBJFile::dumpMe(FILE * fp)
fprintf(fp, "\"Objects\": {\n");
this->baseGroup->dumpMe(fp);
fprintf(fp, "},\n");

fprintf(fp, "\"Vertices\": {\n");
for(i = 1; i < this->vertexCount + 1; i++)
{
fprintf(fp, "\"v[%d]\": { \"x\": %f, \"y\": %f, \"z\": %f },\n", i,
this->vertices(i).x, this->vertices(i).y, this->vertices(i).z);
}
fprintf(fp, "},\n");
fprintf(fp, "\"NormalVertices\": {\n");
for(i = 1; i < this->vertexNormalCount + 1; i++)
{
fprintf(fp, "\"vn[%d]\": { \"x\": %f, \"y\": %f, \"z\": %f },\n", i,
this->verticesNormal(i).x, this->verticesNormal(i).y, this->verticesNormal(i).z);
}
fprintf(fp, "},\n");
Shape::dumpMe(fp);
}

Expand Down
9 changes: 6 additions & 3 deletions source/shapes/shape.cpp
Expand Up @@ -91,9 +91,12 @@ BoundingBox Shape::getBounds()

void Shape::dumpMe(FILE *fp)
{
fprintf(fp, "\"Material\": {\n");
this->material.dumpMe(fp);
fprintf(fp, "},\n");
if (this->materialSet)
{
fprintf(fp, "\"Material\": {\n");
this->material.dumpMe(fp);
fprintf(fp, "},\n");
}
fprintf(fp, "\"DropShadow\": %d,\n", this->dropShadow);
fprintf(fp, "\"BoundingBox\": {\n");
this->getBounds().dumpMe(fp);
Expand Down
14 changes: 14 additions & 0 deletions source/shapes/smoothtriangle.cpp
Expand Up @@ -25,4 +25,18 @@ Tuple SmoothTriangle::localNormalAt(Tuple point, Intersection *hit)
return (this->n2 * hit->u +
this->n3 * hit->v +
this->n1 * (1 - hit->u - hit->v)).normalise();
}

void SmoothTriangle::dumpMe(FILE *fp)
{
Tuple t = this->n1;
fprintf(fp, "\"n1\": { \"x\": %f, \"y\": %f, \"z\": %f}, \n",
t.x, t.y, t.z);
t = this->n2;
fprintf(fp, "\"n2\": { \"x\": %f, \"y\": %f, \"z\": %f}, \n",
t.x, t.y, t.z);
t = this->n3;
fprintf(fp, "\"n3\": { \"x\": %f, \"y\": %f, \"z\": %f}, \n",
t.x, t.y, t.z);
Triangle::dumpMe(fp);
}
13 changes: 13 additions & 0 deletions source/shapes/triangle.cpp
Expand Up @@ -73,6 +73,8 @@ BoundingBox Triangle::getLocalBounds()
void Triangle::dumpMe(FILE *fp)
{
fprintf(fp, "\"Type\": \"Triangle\",\n");

/* World points*/
Tuple t = this->transformMatrix * this->p1;
fprintf(fp, "\"p1\": { \"x\": %f, \"y\": %f, \"z\": %f}, \n",
t.x, t.y, t.z);
Expand All @@ -82,5 +84,16 @@ void Triangle::dumpMe(FILE *fp)
t = this->transformMatrix * this->p3;
fprintf(fp, "\"p3\": { \"x\": %f, \"y\": %f, \"z\": %f}, \n",
t.x, t.y, t.z);

/* Local points */
t = this->p1;
fprintf(fp, "\"lp1\": { \"x\": %f, \"y\": %f, \"z\": %f}, \n",
t.x, t.y, t.z);
t = this->p2;
fprintf(fp, "\"lp2\": { \"x\": %f, \"y\": %f, \"z\": %f}, \n",
t.x, t.y, t.z);
t = this->p3;
fprintf(fp, "\"lp3\": { \"x\": %f, \"y\": %f, \"z\": %f}, \n",
t.x, t.y, t.z);
Shape::dumpMe(fp);
}
56 changes: 34 additions & 22 deletions tests/ch15_teapot_objfile.cpp
Expand Up @@ -36,44 +36,56 @@ int main()
/* ----------------------------- */

/* Floor */
Plane p = Plane();
Material planesMaterial = Material();
CheckersPattern checkered = CheckersPattern(Colour(0.35, 0.35, 0.35), Colour(0.4, 0.4, 0.4));
p.material.pattern = &checkered;
p.material.ambient = 1;
p.material.diffuse = 0;
p.material.specular = 0;
planesMaterial.pattern = &checkered;
planesMaterial.ambient = 1;
planesMaterial.diffuse = 0;
planesMaterial.specular = 0;


Plane p = Plane();
p.setMaterial(planesMaterial);
p.material.reflective = 0.1;
w.addObject(&p);

Plane p2 = Plane();
p2.setTransform(translation(0, 0, -10) * rotationX(M_PI/2));
p2.material.pattern = &checkered;
p2.material.ambient = 1;
p2.material.diffuse = 0;
p2.material.specular = 0;
p2.setMaterial(planesMaterial);
w.addObject(&p2);

Material lowPoly = Material();
lowPoly.colour = Colour(1, 0.3, 0.2);
lowPoly.shininess = 5;
lowPoly.specular = 0.4;

OBJFile teapot = OBJFile("teapot-low.obj");
teapot.setTransform(translation(7, 0, 3) * rotationY(M_PI*23/22) * rotationX(-M_PI/2) * scaling(0.3, 0.3, 0.3));
teapot.material.colour = Colour(1, 0.3, 0.2);
teapot.material.shininess = 5;
teapot.material.specular = 0.4;
w.addObject(&teapot);
teapot.setMaterial(lowPoly);
w.addObject(teapot.getBaseGroup());

FILE *fpOut = fopen("lowpoly_teapot.json", "wt");
if (fpOut)
{
teapot.dumpMe(fpOut);
fclose(fpOut);
}

OBJFile teapot2 = OBJFile("teapot-lowtri.obj");
teapot2.setTransform(translation(-7, 0, 3) * rotationY(-M_PI*46/22) * rotationX(-M_PI/2) * scaling(0.3, 0.3, 0.3));
teapot2.material.colour = Colour(1, 0.3, 0.2);
teapot2.material.shininess = 5;
teapot2.material.specular = 0.4;
w.addObject(&teapot2);
teapot2.setMaterial(lowPoly);;
w.addObject(teapot2.getBaseGroup());

Material highPoly = Material();
highPoly.colour = Colour(0.3, 1, 0.2);
highPoly.shininess = 5;
highPoly.specular = 0.4;
highPoly.reflective = 0.5;

OBJFile teapot3= OBJFile("teapot.obj");
teapot3.setTransform(translation(0, 0, -5) * rotationY(-M_PI) * rotationX(-M_PI/2) * scaling(0.4, 0.4, 0.4));
teapot3.material.colour = Colour(0.3, 1, 0.2);
teapot3.material.shininess = 5;
teapot3.material.specular = 0.4;
teapot3.material.reflective = 0.5;
w.addObject(&teapot3);
teapot3.setMaterial(highPoly);
w.addObject(teapot3.getBaseGroup());

/* ----------------------------- */

Expand Down

0 comments on commit 4e241a1

Please sign in to comment.