File: RaytraceTriangle.cpp

package info (click to toggle)
structure-synth 1.5.0-2
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 2,268 kB
  • ctags: 1,966
  • sloc: cpp: 10,209; python: 164; makefile: 71; sh: 15
file content (119 lines) | stat: -rw-r--r-- 3,794 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#include "RaytraceTriangle.h"

#include "SyntopiaCore/Math/Vector3.h"

using namespace SyntopiaCore::Math;

namespace SyntopiaCore {
	namespace GLEngine {
		using namespace SyntopiaCore::Math;


		RaytraceTriangle::RaytraceTriangle(Vector3f p1, Vector3f p2, Vector3f p3, Vector3f n1, Vector3f n2, Vector3f n3) 
			:  p1(p1),p2(p2),p3(p3),n1(n1),n2(n2),n3(n3) , cullBackFaces(true)
		{

				// We will use barycentric coordiantes.
				Vector3f p12 = p2-p1;
				Vector3f p13 = p3-p1;
				Vector3f p312 = (p12/p12.sqrLength())*Vector3f::dot(p12,p13);
				Vector3f pn3 = p13-p312;
				npn3 = pn3/pn3.sqrLength();

				Vector3f p32 = p2-p3;
				Vector3f p31 = p1-p3;
				Vector3f p132 = (p32/p32.sqrLength())*Vector3f::dot(p32,p31);
				Vector3f pn1 = p31-p132;
				npn1 = pn1/pn1.sqrLength();
	
				Vector3f p213 = (p13/p13.sqrLength())*Vector3f::dot(p13,p12);
				Vector3f pn2 = p12-p213;
				npn2 = pn2/pn2.sqrLength();

				if (npn1.sqrLength() * 0 != 0 || npn2.sqrLength() * 0 != 0 || npn3.sqrLength() * 0 != 0 ||
					p13.sqrLength() < 1E-8 || p12.sqrLength() < 1E-8 || p32.sqrLength() < 1E-8) {
					//INFO(QString("Bad Triangle (%0): %1, %2, %3").arg((p3-p2).sqrLength()).arg(p1.toString()).arg(p2.toString()).arg(p3.toString()));
					bad = true;
				} else {
					bad = false;
				}

				n1.normalize();
				n2.normalize();
				n3.normalize();

				n = Vector3f::cross(p13,p12);
			}



			
			void RaytraceTriangle::expandBoundingBox(Vector3f& from,Vector3f& to) {
				Vector3f p = p1;
				for (int i = 0; i < 3; i++) {
					if (i==1) p=p2;
					if (i==2) p=p3;
					if ( p.x() < from.x()) from.x() = p.x();
					if ( p.y() < from.y()) from.y() = p.y();
					if ( p.z() < from.z()) from.z() = p.z();
					if ( p.x() > to.x()) to.x() = p.x();
					if ( p.y() > to.y()) to.y() = p.y();
					if ( p.z() > to.z()) to.z() = p.z();
				}
			}



			//bool RayTraceTriangle::getIntersectionAndNormal(const Vector3f& startPoint, const Vector3f& lineDirection, double& intersection, Vector3f& normal, Vector3f& color, float& alpha ) {

			bool RaytraceTriangle::intersectsRay(RayInfo* ri) {
				if (bad) return false;

				if (cullBackFaces && Vector3f::dot(n,ri->lineDirection)>0) return false;
		
				float is  = Vector3f::dot(n, p1-ri->startPoint)/Vector3f::dot(n, ri->lineDirection);
				Vector3f ip = ri->startPoint +  ri->lineDirection * is;

				float k312 = Vector3f::dot((ip-p1),npn3);
				if (k312 > 1 || k312 <= 0) return false;
				float k132 = Vector3f::dot((ip-p3),npn1);
				if (k132 > 1 || k132 <= 0) return false;
				float k213 = Vector3f::dot((ip-p1),npn2);
				if (k213 > 1 || k213 <= 0) return false;

				ri->intersection = is;
				ri->normal = n3*k312+ n1*k132+n2*k213;
				if (!cullBackFaces && Vector3f::dot( ri->normal , ri->lineDirection)>0) ri->normal=-ri->normal;
				
				float c0 = k312*color3[0]+k132*color1[0]+k213*color2[0];
				float c1 = k312*color3[1]+k132*color1[1]+k213*color2[1];
				float c2 = k312*color3[2]+k132*color1[2]+k213*color2[2];
				float a = 1; //k312*color3[3]+k132*color1[3]+k213*color2[3];
				ri->color[0] = c0;
				ri->color[1] = c1;
				ri->color[2] = c2;
				ri->color[3] = a;
				return true;
			}


			

			RaytraceTriangle::~RaytraceTriangle(void) {  }

			void RaytraceTriangle::Vertex4(Vector3f p1,Vector3f p2,Vector3f p3,Vector3f p4,bool reverse, QVector<RaytraceTriangle>& list, float r, float g, float b, float a) {
			Vector3f n = -Vector3f::cross(p2-p1, p4-p1);
			if (reverse) n=-n;
			n.normalize();
			RaytraceTriangle r1(p1,p2,p4,n,n,n);
			r1.n = n;
			r1.setColor(r,g,b,a);
			list.append(r1);
			RaytraceTriangle r2(p3,p4,p2,n,n,n);
			r2.setColor(r,g,b,a);
			r2.n = n;
			list.append(r2);
		}
	}
}