|
@@ -12,21 +12,21 @@ this.length();b>0?this.multiplyScalar(1/b):this.set(0,0,0);return this},setPosit
|
|
|
1.0E-4&&Math.abs(this.z)<1.0E-4},clone:function(){return new THREE.Vector3(this.x,this.y,this.z)}};THREE.Vector4=function(b,d,c,f){this.set(b||0,d||0,c||0,f||1)};
|
|
|
THREE.Vector4.prototype={set:function(b,d,c,f){this.x=b;this.y=d;this.z=c;this.w=f;return this},copy:function(b){this.set(b.x,b.y,b.z,b.w||1);return this},add:function(b,d){this.set(b.x+d.x,b.y+d.y,b.z+d.z,b.w+d.w);return this},addSelf:function(b){this.set(this.x+b.x,this.y+b.y,this.z+b.z,this.w+b.w);return this},sub:function(b,d){this.set(b.x-d.x,b.y-d.y,b.z-d.z,b.w-d.w);return this},subSelf:function(b){this.set(this.x-b.x,this.y-b.y,this.z-b.z,this.w-b.w);return this},multiplyScalar:function(b){this.set(this.x*
|
|
|
b,this.y*b,this.z*b,this.w*b);return this},divideScalar:function(b){this.set(this.x/b,this.y/b,this.z/b,this.w/b);return this},lerpSelf:function(b,d){this.set(this.x+(b.x-this.x)*d,this.y+(b.y-this.y)*d,this.z+(b.z-this.z)*d,this.w+(b.w-this.w)*d)},clone:function(){return new THREE.Vector4(this.x,this.y,this.z,this.w)}};THREE.Ray=function(b,d){this.origin=b||new THREE.Vector3;this.direction=d||new THREE.Vector3};
|
|
|
-THREE.Ray.prototype={intersectScene:function(b){var d,c,f=b.objects,g=[];b=0;for(d=f.length;b<d;b++){c=f[b];c instanceof THREE.Mesh&&(g=g.concat(this.intersectObject(c)))}g.sort(function(h,j){return h.distance-j.distance});return g},intersectObject:function(b){function d(I,G,U,D){D=D.clone().subSelf(G);U=U.clone().subSelf(G);var M=I.clone().subSelf(G);I=D.dot(D);G=D.dot(U);D=D.dot(M);var O=U.dot(U);U=U.dot(M);M=1/(I*O-G*G);O=(O*D-G*U)*M;I=(I*U-G*D)*M;return O>0&&I>0&&O+I<1}var c,f,g,h,j,k,n,p,o,x,
|
|
|
-A,t=b.geometry,C=t.vertices,F=[];c=0;for(f=t.faces.length;c<f;c++){g=t.faces[c];x=this.origin.clone();A=this.direction.clone();n=b.matrixWorld;h=n.multiplyVector3(C[g.a].position.clone());j=n.multiplyVector3(C[g.b].position.clone());k=n.multiplyVector3(C[g.c].position.clone());n=g instanceof THREE.Face4?n.multiplyVector3(C[g.d].position.clone()):null;p=b.matrixRotationWorld.multiplyVector3(g.normal.clone());o=A.dot(p);if(o<0){p=p.dot((new THREE.Vector3).sub(h,x))/o;x=x.addSelf(A.multiplyScalar(p));
|
|
|
-if(g instanceof THREE.Face3){if(d(x,h,j,k)){g={distance:this.origin.distanceTo(x),point:x,face:g,object:b};F.push(g)}}else if(g instanceof THREE.Face4&&(d(x,h,j,n)||d(x,j,k,n))){g={distance:this.origin.distanceTo(x),point:x,face:g,object:b};F.push(g)}}}return F}};
|
|
|
-THREE.Rectangle=function(){function b(){h=f-d;j=g-c}var d,c,f,g,h,j,k=!0;this.getX=function(){return d};this.getY=function(){return c};this.getWidth=function(){return h};this.getHeight=function(){return j};this.getLeft=function(){return d};this.getTop=function(){return c};this.getRight=function(){return f};this.getBottom=function(){return g};this.set=function(n,p,o,x){k=!1;d=n;c=p;f=o;g=x;b()};this.addPoint=function(n,p){if(k){k=!1;d=n;c=p;f=n;g=p}else{d=d<n?d:n;c=c<p?c:p;f=f>n?f:n;g=g>p?g:p}b()};
|
|
|
-this.add3Points=function(n,p,o,x,A,t){if(k){k=!1;d=n<o?n<A?n:A:o<A?o:A;c=p<x?p<t?p:t:x<t?x:t;f=n>o?n>A?n:A:o>A?o:A;g=p>x?p>t?p:t:x>t?x:t}else{d=n<o?n<A?n<d?n:d:A<d?A:d:o<A?o<d?o:d:A<d?A:d;c=p<x?p<t?p<c?p:c:t<c?t:c:x<t?x<c?x:c:t<c?t:c;f=n>o?n>A?n>f?n:f:A>f?A:f:o>A?o>f?o:f:A>f?A:f;g=p>x?p>t?p>g?p:g:t>g?t:g:x>t?x>g?x:g:t>g?t:g}b()};this.addRectangle=function(n){if(k){k=!1;d=n.getLeft();c=n.getTop();f=n.getRight();g=n.getBottom()}else{d=d<n.getLeft()?d:n.getLeft();c=c<n.getTop()?c:n.getTop();f=f>n.getRight()?
|
|
|
+THREE.Ray.prototype={intersectScene:function(b){var d,c,f=b.objects,g=[];b=0;for(d=f.length;b<d;b++){c=f[b];c instanceof THREE.Mesh&&(g=g.concat(this.intersectObject(c)))}g.sort(function(h,j){return h.distance-j.distance});return g},intersectObject:function(b){function d(E,J,T,z){z=z.clone().subSelf(J);T=T.clone().subSelf(J);var K=E.clone().subSelf(J);E=z.dot(z);J=z.dot(T);z=z.dot(K);var L=T.dot(T);T=T.dot(K);K=1/(E*L-J*J);L=(L*z-J*T)*K;E=(E*T-J*z)*K;return L>0&&E>0&&L+E<1}var c,f,g,h,j,k,n,p,o,t,
|
|
|
+y,v=b.geometry,B=v.vertices,C=[];c=0;for(f=v.faces.length;c<f;c++){g=v.faces[c];t=this.origin.clone();y=this.direction.clone();n=b.matrixWorld;h=n.multiplyVector3(B[g.a].position.clone());j=n.multiplyVector3(B[g.b].position.clone());k=n.multiplyVector3(B[g.c].position.clone());n=g instanceof THREE.Face4?n.multiplyVector3(B[g.d].position.clone()):null;p=b.matrixRotationWorld.multiplyVector3(g.normal.clone());o=y.dot(p);if(o<0){p=p.dot((new THREE.Vector3).sub(h,t))/o;t=t.addSelf(y.multiplyScalar(p));
|
|
|
+if(g instanceof THREE.Face3){if(d(t,h,j,k)){g={distance:this.origin.distanceTo(t),point:t,face:g,object:b};C.push(g)}}else if(g instanceof THREE.Face4&&(d(t,h,j,n)||d(t,j,k,n))){g={distance:this.origin.distanceTo(t),point:t,face:g,object:b};C.push(g)}}}return C}};
|
|
|
+THREE.Rectangle=function(){function b(){h=f-d;j=g-c}var d,c,f,g,h,j,k=!0;this.getX=function(){return d};this.getY=function(){return c};this.getWidth=function(){return h};this.getHeight=function(){return j};this.getLeft=function(){return d};this.getTop=function(){return c};this.getRight=function(){return f};this.getBottom=function(){return g};this.set=function(n,p,o,t){k=!1;d=n;c=p;f=o;g=t;b()};this.addPoint=function(n,p){if(k){k=!1;d=n;c=p;f=n;g=p}else{d=d<n?d:n;c=c<p?c:p;f=f>n?f:n;g=g>p?g:p}b()};
|
|
|
+this.add3Points=function(n,p,o,t,y,v){if(k){k=!1;d=n<o?n<y?n:y:o<y?o:y;c=p<t?p<v?p:v:t<v?t:v;f=n>o?n>y?n:y:o>y?o:y;g=p>t?p>v?p:v:t>v?t:v}else{d=n<o?n<y?n<d?n:d:y<d?y:d:o<y?o<d?o:d:y<d?y:d;c=p<t?p<v?p<c?p:c:v<c?v:c:t<v?t<c?t:c:v<c?v:c;f=n>o?n>y?n>f?n:f:y>f?y:f:o>y?o>f?o:f:y>f?y:f;g=p>t?p>v?p>g?p:g:v>g?v:g:t>v?t>g?t:g:v>g?v:g}b()};this.addRectangle=function(n){if(k){k=!1;d=n.getLeft();c=n.getTop();f=n.getRight();g=n.getBottom()}else{d=d<n.getLeft()?d:n.getLeft();c=c<n.getTop()?c:n.getTop();f=f>n.getRight()?
|
|
|
f:n.getRight();g=g>n.getBottom()?g:n.getBottom()}b()};this.inflate=function(n){d-=n;c-=n;f+=n;g+=n;b()};this.minSelf=function(n){d=d>n.getLeft()?d:n.getLeft();c=c>n.getTop()?c:n.getTop();f=f<n.getRight()?f:n.getRight();g=g<n.getBottom()?g:n.getBottom();b()};this.instersects=function(n){return Math.min(f,n.getRight())-Math.max(d,n.getLeft())>=0&&Math.min(g,n.getBottom())-Math.max(c,n.getTop())>=0};this.empty=function(){k=!0;g=f=c=d=0;b()};this.isEmpty=function(){return k}};
|
|
|
THREE.Matrix3=function(){this.m=[]};THREE.Matrix3.prototype={transpose:function(){var b,d=this.m;b=d[1];d[1]=d[3];d[3]=b;b=d[2];d[2]=d[6];d[6]=b;b=d[5];d[5]=d[7];d[7]=b;return this},transposeIntoArray:function(b){var d=this.m;b[0]=d[0];b[1]=d[3];b[2]=d[6];b[3]=d[1];b[4]=d[4];b[5]=d[7];b[6]=d[2];b[7]=d[5];b[8]=d[8];return this}};
|
|
|
-THREE.Matrix4=function(b,d,c,f,g,h,j,k,n,p,o,x,A,t,C,F){this.set(b||1,d||0,c||0,f||0,g||0,h||1,j||0,k||0,n||0,p||0,o||1,x||0,A||0,t||0,C||0,F||1);this.flat=Array(16);this.m33=new THREE.Matrix3};
|
|
|
-THREE.Matrix4.prototype={set:function(b,d,c,f,g,h,j,k,n,p,o,x,A,t,C,F){this.n11=b;this.n12=d;this.n13=c;this.n14=f;this.n21=g;this.n22=h;this.n23=j;this.n24=k;this.n31=n;this.n32=p;this.n33=o;this.n34=x;this.n41=A;this.n42=t;this.n43=C;this.n44=F;return this},identity:function(){this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);return this},copy:function(b){this.set(b.n11,b.n12,b.n13,b.n14,b.n21,b.n22,b.n23,b.n24,b.n31,b.n32,b.n33,b.n34,b.n41,b.n42,b.n43,b.n44);return this},lookAt:function(b,d,c){var f=THREE.Matrix4.__v1,
|
|
|
+THREE.Matrix4=function(b,d,c,f,g,h,j,k,n,p,o,t,y,v,B,C){this.set(b||1,d||0,c||0,f||0,g||0,h||1,j||0,k||0,n||0,p||0,o||1,t||0,y||0,v||0,B||0,C||1);this.flat=Array(16);this.m33=new THREE.Matrix3};
|
|
|
+THREE.Matrix4.prototype={set:function(b,d,c,f,g,h,j,k,n,p,o,t,y,v,B,C){this.n11=b;this.n12=d;this.n13=c;this.n14=f;this.n21=g;this.n22=h;this.n23=j;this.n24=k;this.n31=n;this.n32=p;this.n33=o;this.n34=t;this.n41=y;this.n42=v;this.n43=B;this.n44=C;return this},identity:function(){this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);return this},copy:function(b){this.set(b.n11,b.n12,b.n13,b.n14,b.n21,b.n22,b.n23,b.n24,b.n31,b.n32,b.n33,b.n34,b.n41,b.n42,b.n43,b.n44);return this},lookAt:function(b,d,c){var f=THREE.Matrix4.__v1,
|
|
|
g=THREE.Matrix4.__v2,h=THREE.Matrix4.__v3;h.sub(b,d).normalize();if(h.length()===0)h.z=1;f.cross(c,h).normalize();if(f.length()===0){h.x+=1.0E-4;f.cross(c,h).normalize()}g.cross(h,f).normalize();this.n11=f.x;this.n12=g.x;this.n13=h.x;this.n21=f.y;this.n22=g.y;this.n23=h.y;this.n31=f.z;this.n32=g.z;this.n33=h.z;return this},multiplyVector3:function(b){var d=b.x,c=b.y,f=b.z,g=1/(this.n41*d+this.n42*c+this.n43*f+this.n44);b.x=(this.n11*d+this.n12*c+this.n13*f+this.n14)*g;b.y=(this.n21*d+this.n22*c+this.n23*
|
|
|
f+this.n24)*g;b.z=(this.n31*d+this.n32*c+this.n33*f+this.n34)*g;return b},multiplyVector4:function(b){var d=b.x,c=b.y,f=b.z,g=b.w;b.x=this.n11*d+this.n12*c+this.n13*f+this.n14*g;b.y=this.n21*d+this.n22*c+this.n23*f+this.n24*g;b.z=this.n31*d+this.n32*c+this.n33*f+this.n34*g;b.w=this.n41*d+this.n42*c+this.n43*f+this.n44*g;return b},rotateAxis:function(b){var d=b.x,c=b.y,f=b.z;b.x=d*this.n11+c*this.n12+f*this.n13;b.y=d*this.n21+c*this.n22+f*this.n23;b.z=d*this.n31+c*this.n32+f*this.n33;b.normalize();
|
|
|
-return b},crossVector:function(b){var d=new THREE.Vector4;d.x=this.n11*b.x+this.n12*b.y+this.n13*b.z+this.n14*b.w;d.y=this.n21*b.x+this.n22*b.y+this.n23*b.z+this.n24*b.w;d.z=this.n31*b.x+this.n32*b.y+this.n33*b.z+this.n34*b.w;d.w=b.w?this.n41*b.x+this.n42*b.y+this.n43*b.z+this.n44*b.w:1;return d},multiply:function(b,d){var c=b.n11,f=b.n12,g=b.n13,h=b.n14,j=b.n21,k=b.n22,n=b.n23,p=b.n24,o=b.n31,x=b.n32,A=b.n33,t=b.n34,C=b.n41,F=b.n42,I=b.n43,G=b.n44,U=d.n11,D=d.n12,M=d.n13,O=d.n14,Q=d.n21,Ia=d.n22,
|
|
|
-ua=d.n23,Aa=d.n24,da=d.n31,e=d.n32,ga=d.n33,Ba=d.n34;this.n11=c*U+f*Q+g*da;this.n12=c*D+f*Ia+g*e;this.n13=c*M+f*ua+g*ga;this.n14=c*O+f*Aa+g*Ba+h;this.n21=j*U+k*Q+n*da;this.n22=j*D+k*Ia+n*e;this.n23=j*M+k*ua+n*ga;this.n24=j*O+k*Aa+n*Ba+p;this.n31=o*U+x*Q+A*da;this.n32=o*D+x*Ia+A*e;this.n33=o*M+x*ua+A*ga;this.n34=o*O+x*Aa+A*Ba+t;this.n41=C*U+F*Q+I*da;this.n42=C*D+F*Ia+I*e;this.n43=C*M+F*ua+I*ga;this.n44=C*O+F*Aa+I*Ba+G;return this},multiplyToArray:function(b,d,c){this.multiply(b,d);c[0]=this.n11;c[1]=
|
|
|
+return b},crossVector:function(b){var d=new THREE.Vector4;d.x=this.n11*b.x+this.n12*b.y+this.n13*b.z+this.n14*b.w;d.y=this.n21*b.x+this.n22*b.y+this.n23*b.z+this.n24*b.w;d.z=this.n31*b.x+this.n32*b.y+this.n33*b.z+this.n34*b.w;d.w=b.w?this.n41*b.x+this.n42*b.y+this.n43*b.z+this.n44*b.w:1;return d},multiply:function(b,d){var c=b.n11,f=b.n12,g=b.n13,h=b.n14,j=b.n21,k=b.n22,n=b.n23,p=b.n24,o=b.n31,t=b.n32,y=b.n33,v=b.n34,B=b.n41,C=b.n42,E=b.n43,J=b.n44,T=d.n11,z=d.n12,K=d.n13,L=d.n14,M=d.n21,Ga=d.n22,
|
|
|
+sa=d.n23,ya=d.n24,aa=d.n31,e=d.n32,ea=d.n33,za=d.n34;this.n11=c*T+f*M+g*aa;this.n12=c*z+f*Ga+g*e;this.n13=c*K+f*sa+g*ea;this.n14=c*L+f*ya+g*za+h;this.n21=j*T+k*M+n*aa;this.n22=j*z+k*Ga+n*e;this.n23=j*K+k*sa+n*ea;this.n24=j*L+k*ya+n*za+p;this.n31=o*T+t*M+y*aa;this.n32=o*z+t*Ga+y*e;this.n33=o*K+t*sa+y*ea;this.n34=o*L+t*ya+y*za+v;this.n41=B*T+C*M+E*aa;this.n42=B*z+C*Ga+E*e;this.n43=B*K+C*sa+E*ea;this.n44=B*L+C*ya+E*za+J;return this},multiplyToArray:function(b,d,c){this.multiply(b,d);c[0]=this.n11;c[1]=
|
|
|
this.n21;c[2]=this.n31;c[3]=this.n41;c[4]=this.n12;c[5]=this.n22;c[6]=this.n32;c[7]=this.n42;c[8]=this.n13;c[9]=this.n23;c[10]=this.n33;c[11]=this.n43;c[12]=this.n14;c[13]=this.n24;c[14]=this.n34;c[15]=this.n44;return this},multiplySelf:function(b){this.multiply(this,b);return this},multiplyScalar:function(b){this.n11*=b;this.n12*=b;this.n13*=b;this.n14*=b;this.n21*=b;this.n22*=b;this.n23*=b;this.n24*=b;this.n31*=b;this.n32*=b;this.n33*=b;this.n34*=b;this.n41*=b;this.n42*=b;this.n43*=b;this.n44*=
|
|
|
-b;return this},determinant:function(){var b=this.n11,d=this.n12,c=this.n13,f=this.n14,g=this.n21,h=this.n22,j=this.n23,k=this.n24,n=this.n31,p=this.n32,o=this.n33,x=this.n34,A=this.n41,t=this.n42,C=this.n43,F=this.n44;return f*j*p*A-c*k*p*A-f*h*o*A+d*k*o*A+c*h*x*A-d*j*x*A-f*j*n*t+c*k*n*t+f*g*o*t-b*k*o*t-c*g*x*t+b*j*x*t+f*h*n*C-d*k*n*C-f*g*p*C+b*k*p*C+d*g*x*C-b*h*x*C-c*h*n*F+d*j*n*F+c*g*p*F-b*j*p*F-d*g*o*F+b*h*o*F},transpose:function(){var b;b=this.n21;this.n21=this.n12;this.n12=b;b=this.n31;this.n31=
|
|
|
+b;return this},determinant:function(){var b=this.n11,d=this.n12,c=this.n13,f=this.n14,g=this.n21,h=this.n22,j=this.n23,k=this.n24,n=this.n31,p=this.n32,o=this.n33,t=this.n34,y=this.n41,v=this.n42,B=this.n43,C=this.n44;return f*j*p*y-c*k*p*y-f*h*o*y+d*k*o*y+c*h*t*y-d*j*t*y-f*j*n*v+c*k*n*v+f*g*o*v-b*k*o*v-c*g*t*v+b*j*t*v+f*h*n*B-d*k*n*B-f*g*p*B+b*k*p*B+d*g*t*B-b*h*t*B-c*h*n*C+d*j*n*C+c*g*p*C-b*j*p*C-d*g*o*C+b*h*o*C},transpose:function(){var b;b=this.n21;this.n21=this.n12;this.n12=b;b=this.n31;this.n31=
|
|
|
this.n13;this.n13=b;b=this.n32;this.n32=this.n23;this.n23=b;b=this.n41;this.n41=this.n14;this.n14=b;b=this.n42;this.n42=this.n24;this.n24=b;b=this.n43;this.n43=this.n34;this.n43=b;return this},clone:function(){var b=new THREE.Matrix4;b.n11=this.n11;b.n12=this.n12;b.n13=this.n13;b.n14=this.n14;b.n21=this.n21;b.n22=this.n22;b.n23=this.n23;b.n24=this.n24;b.n31=this.n31;b.n32=this.n32;b.n33=this.n33;b.n34=this.n34;b.n41=this.n41;b.n42=this.n42;b.n43=this.n43;b.n44=this.n44;return b},flatten:function(){this.flat[0]=
|
|
|
this.n11;this.flat[1]=this.n21;this.flat[2]=this.n31;this.flat[3]=this.n41;this.flat[4]=this.n12;this.flat[5]=this.n22;this.flat[6]=this.n32;this.flat[7]=this.n42;this.flat[8]=this.n13;this.flat[9]=this.n23;this.flat[10]=this.n33;this.flat[11]=this.n43;this.flat[12]=this.n14;this.flat[13]=this.n24;this.flat[14]=this.n34;this.flat[15]=this.n44;return this.flat},flattenToArray:function(b){b[0]=this.n11;b[1]=this.n21;b[2]=this.n31;b[3]=this.n41;b[4]=this.n12;b[5]=this.n22;b[6]=this.n32;b[7]=this.n42;
|
|
|
b[8]=this.n13;b[9]=this.n23;b[10]=this.n33;b[11]=this.n43;b[12]=this.n14;b[13]=this.n24;b[14]=this.n34;b[15]=this.n44;return b},flattenToArrayOffset:function(b,d){b[d]=this.n11;b[d+1]=this.n21;b[d+2]=this.n31;b[d+3]=this.n41;b[d+4]=this.n12;b[d+5]=this.n22;b[d+6]=this.n32;b[d+7]=this.n42;b[d+8]=this.n13;b[d+9]=this.n23;b[d+10]=this.n33;b[d+11]=this.n43;b[d+12]=this.n14;b[d+13]=this.n24;b[d+14]=this.n34;b[d+15]=this.n44;return b},setTranslation:function(b,d,c){this.set(1,0,0,b,0,1,0,d,0,0,1,c,0,0,
|
|
@@ -34,9 +34,9 @@ b[8]=this.n13;b[9]=this.n23;b[10]=this.n33;b[11]=this.n43;b[12]=this.n14;b[13]=t
|
|
|
1-c,h=b.x,j=b.y,k=b.z,n=g*h,p=g*j;this.set(n*h+c,n*j-f*k,n*k+f*j,0,n*j+f*k,p*j+c,p*k-f*h,0,n*k-f*j,p*k+f*h,g*k*k+c,0,0,0,0,1);return this},setPosition:function(b){this.n14=b.x;this.n24=b.y;this.n34=b.z;return this},setRotationFromEuler:function(b){var d=b.x,c=b.y,f=b.z;b=Math.cos(d);d=Math.sin(d);var g=Math.cos(c);c=Math.sin(c);var h=Math.cos(f);f=Math.sin(f);var j=b*c,k=d*c;this.n11=g*h;this.n12=-g*f;this.n13=c;this.n21=k*h+b*f;this.n22=-k*f+b*h;this.n23=-d*g;this.n31=-j*h+d*f;this.n32=j*f+d*h;this.n33=
|
|
|
b*g;return this},setRotationFromQuaternion:function(b){var d=b.x,c=b.y,f=b.z,g=b.w,h=d+d,j=c+c,k=f+f;b=d*h;var n=d*j;d*=k;var p=c*j;c*=k;f*=k;h*=g;j*=g;g*=k;this.n11=1-(p+f);this.n12=n-g;this.n13=d+j;this.n21=n+g;this.n22=1-(b+f);this.n23=c-h;this.n31=d-j;this.n32=c+h;this.n33=1-(b+p);return this},scale:function(b){var d=b.x,c=b.y;b=b.z;this.n11*=d;this.n12*=c;this.n13*=b;this.n21*=d;this.n22*=c;this.n23*=b;this.n31*=d;this.n32*=c;this.n33*=b;this.n41*=d;this.n42*=c;this.n43*=b;return this},extractPosition:function(b){this.n14=
|
|
|
b.n14;this.n24=b.n24;this.n34=b.n34},extractRotation:function(b,d){var c=1/d.x,f=1/d.y,g=1/d.z;this.n11=b.n11*c;this.n21=b.n21*c;this.n31=b.n31*c;this.n12=b.n12*f;this.n22=b.n22*f;this.n32=b.n32*f;this.n13=b.n13*g;this.n23=b.n23*g;this.n33=b.n33*g}};
|
|
|
-THREE.Matrix4.makeInvert=function(b,d){var c=b.n11,f=b.n12,g=b.n13,h=b.n14,j=b.n21,k=b.n22,n=b.n23,p=b.n24,o=b.n31,x=b.n32,A=b.n33,t=b.n34,C=b.n41,F=b.n42,I=b.n43,G=b.n44;d===undefined&&(d=new THREE.Matrix4);d.n11=n*t*F-p*A*F+p*x*I-k*t*I-n*x*G+k*A*G;d.n12=h*A*F-g*t*F-h*x*I+f*t*I+g*x*G-f*A*G;d.n13=g*p*F-h*n*F+h*k*I-f*p*I-g*k*G+f*n*G;d.n14=h*n*x-g*p*x-h*k*A+f*p*A+g*k*t-f*n*t;d.n21=p*A*C-n*t*C-p*o*I+j*t*I+n*o*G-j*A*G;d.n22=g*t*C-h*A*C+h*o*I-c*t*I-g*o*G+c*A*G;d.n23=h*n*C-g*p*C-h*j*I+c*p*I+g*j*G-c*n*G;
|
|
|
-d.n24=g*p*o-h*n*o+h*j*A-c*p*A-g*j*t+c*n*t;d.n31=k*t*C-p*x*C+p*o*F-j*t*F-k*o*G+j*x*G;d.n32=h*x*C-f*t*C-h*o*F+c*t*F+f*o*G-c*x*G;d.n33=g*p*C-h*k*C+h*j*F-c*p*F-f*j*G+c*k*G;d.n34=h*k*o-f*p*o-h*j*x+c*p*x+f*j*t-c*k*t;d.n41=n*x*C-k*A*C-n*o*F+j*A*F+k*o*I-j*x*I;d.n42=f*A*C-g*x*C+g*o*F-c*A*F-f*o*I+c*x*I;d.n43=g*k*C-f*n*C-g*j*F+c*n*F+f*j*I-c*k*I;d.n44=f*n*o-g*k*o+g*j*x-c*n*x-f*j*A+c*k*A;d.multiplyScalar(1/b.determinant());return d};
|
|
|
-THREE.Matrix4.makeInvert3x3=function(b){var d=b.m33,c=d.m,f=b.n33*b.n22-b.n32*b.n23,g=-b.n33*b.n21+b.n31*b.n23,h=b.n32*b.n21-b.n31*b.n22,j=-b.n33*b.n12+b.n32*b.n13,k=b.n33*b.n11-b.n31*b.n13,n=-b.n32*b.n11+b.n31*b.n12,p=b.n23*b.n12-b.n22*b.n13,o=-b.n23*b.n11+b.n21*b.n13,x=b.n22*b.n11-b.n21*b.n12;b=b.n11*f+b.n21*j+b.n31*p;if(b==0)throw"matrix not invertible";b=1/b;c[0]=b*f;c[1]=b*g;c[2]=b*h;c[3]=b*j;c[4]=b*k;c[5]=b*n;c[6]=b*p;c[7]=b*o;c[8]=b*x;return d};
|
|
|
+THREE.Matrix4.makeInvert=function(b,d){var c=b.n11,f=b.n12,g=b.n13,h=b.n14,j=b.n21,k=b.n22,n=b.n23,p=b.n24,o=b.n31,t=b.n32,y=b.n33,v=b.n34,B=b.n41,C=b.n42,E=b.n43,J=b.n44;d===undefined&&(d=new THREE.Matrix4);d.n11=n*v*C-p*y*C+p*t*E-k*v*E-n*t*J+k*y*J;d.n12=h*y*C-g*v*C-h*t*E+f*v*E+g*t*J-f*y*J;d.n13=g*p*C-h*n*C+h*k*E-f*p*E-g*k*J+f*n*J;d.n14=h*n*t-g*p*t-h*k*y+f*p*y+g*k*v-f*n*v;d.n21=p*y*B-n*v*B-p*o*E+j*v*E+n*o*J-j*y*J;d.n22=g*v*B-h*y*B+h*o*E-c*v*E-g*o*J+c*y*J;d.n23=h*n*B-g*p*B-h*j*E+c*p*E+g*j*J-c*n*J;
|
|
|
+d.n24=g*p*o-h*n*o+h*j*y-c*p*y-g*j*v+c*n*v;d.n31=k*v*B-p*t*B+p*o*C-j*v*C-k*o*J+j*t*J;d.n32=h*t*B-f*v*B-h*o*C+c*v*C+f*o*J-c*t*J;d.n33=g*p*B-h*k*B+h*j*C-c*p*C-f*j*J+c*k*J;d.n34=h*k*o-f*p*o-h*j*t+c*p*t+f*j*v-c*k*v;d.n41=n*t*B-k*y*B-n*o*C+j*y*C+k*o*E-j*t*E;d.n42=f*y*B-g*t*B+g*o*C-c*y*C-f*o*E+c*t*E;d.n43=g*k*B-f*n*B-g*j*C+c*n*C+f*j*E-c*k*E;d.n44=f*n*o-g*k*o+g*j*t-c*n*t-f*j*y+c*k*y;d.multiplyScalar(1/b.determinant());return d};
|
|
|
+THREE.Matrix4.makeInvert3x3=function(b){var d=b.m33,c=d.m,f=b.n33*b.n22-b.n32*b.n23,g=-b.n33*b.n21+b.n31*b.n23,h=b.n32*b.n21-b.n31*b.n22,j=-b.n33*b.n12+b.n32*b.n13,k=b.n33*b.n11-b.n31*b.n13,n=-b.n32*b.n11+b.n31*b.n12,p=b.n23*b.n12-b.n22*b.n13,o=-b.n23*b.n11+b.n21*b.n13,t=b.n22*b.n11-b.n21*b.n12;b=b.n11*f+b.n21*j+b.n31*p;if(b==0)throw"matrix not invertible";b=1/b;c[0]=b*f;c[1]=b*g;c[2]=b*h;c[3]=b*j;c[4]=b*k;c[5]=b*n;c[6]=b*p;c[7]=b*o;c[8]=b*t;return d};
|
|
|
THREE.Matrix4.makeFrustum=function(b,d,c,f,g,h){var j;j=new THREE.Matrix4;j.n11=2*g/(d-b);j.n12=0;j.n13=(d+b)/(d-b);j.n14=0;j.n21=0;j.n22=2*g/(f-c);j.n23=(f+c)/(f-c);j.n24=0;j.n31=0;j.n32=0;j.n33=-(h+g)/(h-g);j.n34=-2*h*g/(h-g);j.n41=0;j.n42=0;j.n43=-1;j.n44=0;return j};THREE.Matrix4.makePerspective=function(b,d,c,f){var g;b=c*Math.tan(b*Math.PI/360);g=-b;return THREE.Matrix4.makeFrustum(g*d,b*d,g,b,c,f)};
|
|
|
THREE.Matrix4.makeOrtho=function(b,d,c,f,g,h){var j,k,n,p;j=new THREE.Matrix4;k=d-b;n=c-f;p=h-g;j.n11=2/k;j.n12=0;j.n13=0;j.n14=-((d+b)/k);j.n21=0;j.n22=2/n;j.n23=0;j.n24=-((c+f)/n);j.n31=0;j.n32=0;j.n33=-2/p;j.n34=-((h+g)/p);j.n41=0;j.n42=0;j.n43=0;j.n44=1;return j};THREE.Matrix4.__v1=new THREE.Vector3;THREE.Matrix4.__v2=new THREE.Vector3;THREE.Matrix4.__v3=new THREE.Vector3;
|
|
|
THREE.Object3D=function(){this.parent=undefined;this.children=[];this.up=new THREE.Vector3(0,1,0);this.position=new THREE.Vector3;this.rotation=new THREE.Vector3;this.scale=new THREE.Vector3(1,1,1);this.rotationAutoUpdate=!0;this.matrix=new THREE.Matrix4;this.matrixWorld=new THREE.Matrix4;this.matrixRotationWorld=new THREE.Matrix4;this.matrixAutoUpdate=!0;this.matrixWorldNeedsUpdate=!0;this.quaternion=new THREE.Quaternion;this.useQuaternion=!1;this.boundRadius=0;this.boundRadiusScale=1;this.visible=
|
|
@@ -47,7 +47,7 @@ undefined&&b.parent.removeChild(b);b.parent=this;this.children.push(b);for(var d
|
|
|
d,c)}};THREE.Quaternion=function(b,d,c,f){this.set(b||0,d||0,c||0,f!==undefined?f:1)};
|
|
|
THREE.Quaternion.prototype={set:function(b,d,c,f){this.x=b;this.y=d;this.z=c;this.w=f;return this},setFromEuler:function(b){var d=0.5*Math.PI/360,c=b.x*d,f=b.y*d,g=b.z*d;b=Math.cos(f);f=Math.sin(f);d=Math.cos(-g);g=Math.sin(-g);var h=Math.cos(c);c=Math.sin(c);var j=b*d,k=f*g;this.w=j*h-k*c;this.x=j*c+k*h;this.y=f*d*h+b*g*c;this.z=b*g*h-f*d*c;return this},calculateW:function(){this.w=-Math.sqrt(Math.abs(1-this.x*this.x-this.y*this.y-this.z*this.z));return this},inverse:function(){this.x*=-1;this.y*=
|
|
|
-1;this.z*=-1;return this},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w)},normalize:function(){var b=Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w);if(b==0)this.w=this.z=this.y=this.x=0;else{b=1/b;this.x*=b;this.y*=b;this.z*=b;this.w*=b}return this},multiplySelf:function(b){var d=this.x,c=this.y,f=this.z,g=this.w,h=b.x,j=b.y,k=b.z;b=b.w;this.x=d*b+g*h+c*k-f*j;this.y=c*b+g*j+f*h-d*k;this.z=f*b+g*k+d*j-c*h;this.w=g*b-d*h-c*j-f*k;return this},
|
|
|
-multiplyVector3:function(b,d){d||(d=b);var c=b.x,f=b.y,g=b.z,h=this.x,j=this.y,k=this.z,n=this.w,p=n*c+j*g-k*f,o=n*f+k*c-h*g,x=n*g+h*f-j*c;c=-h*c-j*f-k*g;d.x=p*n+c*-h+o*-k-x*-j;d.y=o*n+c*-j+x*-h-p*-k;d.z=x*n+c*-k+p*-j-o*-h;return d}};
|
|
|
+multiplyVector3:function(b,d){d||(d=b);var c=b.x,f=b.y,g=b.z,h=this.x,j=this.y,k=this.z,n=this.w,p=n*c+j*g-k*f,o=n*f+k*c-h*g,t=n*g+h*f-j*c;c=-h*c-j*f-k*g;d.x=p*n+c*-h+o*-k-t*-j;d.y=o*n+c*-j+t*-h-p*-k;d.z=t*n+c*-k+p*-j-o*-h;return d}};
|
|
|
THREE.Quaternion.slerp=function(b,d,c,f){var g=b.w*d.w+b.x*d.x+b.y*d.y+b.z*d.z;if(Math.abs(g)>=1){c.w=b.w;c.x=b.x;c.y=b.y;c.z=b.z;return c}var h=Math.acos(g),j=Math.sqrt(1-g*g);if(Math.abs(j)<0.0010){c.w=0.5*(b.w+d.w);c.x=0.5*(b.x+d.x);c.y=0.5*(b.y+d.y);c.z=0.5*(b.z+d.z);return c}g=Math.sin((1-f)*h)/j;f=Math.sin(f*h)/j;c.w=b.w*g+d.w*f;c.x=b.x*g+d.x*f;c.y=b.y*g+d.y*f;c.z=b.z*g+d.z*f;return c};THREE.Vertex=function(b){this.position=b||new THREE.Vector3};
|
|
|
THREE.Face3=function(b,d,c,f,g,h){this.a=b;this.b=d;this.c=c;this.normal=f instanceof THREE.Vector3?f:new THREE.Vector3;this.vertexNormals=f instanceof Array?f:[];this.color=g instanceof THREE.Color?g:new THREE.Color;this.vertexColors=g instanceof Array?g:[];this.vertexTangents=[];this.materials=h instanceof Array?h:[h];this.centroid=new THREE.Vector3};
|
|
|
THREE.Face4=function(b,d,c,f,g,h,j){this.a=b;this.b=d;this.c=c;this.d=f;this.normal=g instanceof THREE.Vector3?g:new THREE.Vector3;this.vertexNormals=g instanceof Array?g:[];this.color=h instanceof THREE.Color?h:new THREE.Color;this.vertexColors=h instanceof Array?h:[];this.vertexTangents=[];this.materials=j instanceof Array?j:[j];this.centroid=new THREE.Vector3};THREE.UV=function(b,d){this.set(b||0,d||0)};
|
|
@@ -56,16 +56,16 @@ THREE.Geometry.prototype={computeCentroids:function(){var b,d,c;b=0;for(d=this.f
|
|
|
c.centroid.addSelf(this.vertices[c.d].position);c.centroid.divideScalar(4)}}},computeFaceNormals:function(b){var d,c,f,g,h,j,k=new THREE.Vector3,n=new THREE.Vector3;f=0;for(g=this.faces.length;f<g;f++){h=this.faces[f];if(b&&h.vertexNormals.length){k.set(0,0,0);d=0;for(c=h.vertexNormals.length;d<c;d++)k.addSelf(h.vertexNormals[d]);k.divideScalar(3)}else{d=this.vertices[h.a];c=this.vertices[h.b];j=this.vertices[h.c];k.sub(j.position,c.position);n.sub(d.position,c.position);k.crossSelf(n)}k.isZero()||
|
|
|
k.normalize();h.normal.copy(k)}},computeVertexNormals:function(){var b,d,c,f;if(this.__tmpVertices==undefined){f=this.__tmpVertices=Array(this.vertices.length);b=0;for(d=this.vertices.length;b<d;b++)f[b]=new THREE.Vector3;b=0;for(d=this.faces.length;b<d;b++){c=this.faces[b];if(c instanceof THREE.Face3)c.vertexNormals=[new THREE.Vector3,new THREE.Vector3,new THREE.Vector3];else if(c instanceof THREE.Face4)c.vertexNormals=[new THREE.Vector3,new THREE.Vector3,new THREE.Vector3,new THREE.Vector3]}}else{f=
|
|
|
this.__tmpVertices;b=0;for(d=this.vertices.length;b<d;b++)f[b].set(0,0,0)}b=0;for(d=this.faces.length;b<d;b++){c=this.faces[b];if(c instanceof THREE.Face3){f[c.a].addSelf(c.normal);f[c.b].addSelf(c.normal);f[c.c].addSelf(c.normal)}else if(c instanceof THREE.Face4){f[c.a].addSelf(c.normal);f[c.b].addSelf(c.normal);f[c.c].addSelf(c.normal);f[c.d].addSelf(c.normal)}}b=0;for(d=this.vertices.length;b<d;b++)f[b].normalize();b=0;for(d=this.faces.length;b<d;b++){c=this.faces[b];if(c instanceof THREE.Face3){c.vertexNormals[0].copy(f[c.a]);
|
|
|
-c.vertexNormals[1].copy(f[c.b]);c.vertexNormals[2].copy(f[c.c])}else if(c instanceof THREE.Face4){c.vertexNormals[0].copy(f[c.a]);c.vertexNormals[1].copy(f[c.b]);c.vertexNormals[2].copy(f[c.c]);c.vertexNormals[3].copy(f[c.d])}}},computeTangents:function(){function b(ea,va,Ca,ka,aa,ra,Ga){k=ea.vertices[va].position;n=ea.vertices[Ca].position;p=ea.vertices[ka].position;o=j[aa];x=j[ra];A=j[Ga];t=n.x-k.x;C=p.x-k.x;F=n.y-k.y;I=p.y-k.y;G=n.z-k.z;U=p.z-k.z;D=x.u-o.u;M=A.u-o.u;O=x.v-o.v;Q=A.v-o.v;Ia=1/(D*
|
|
|
-Q-M*O);e.set((Q*t-O*C)*Ia,(Q*F-O*I)*Ia,(Q*G-O*U)*Ia);ga.set((D*C-M*t)*Ia,(D*I-M*F)*Ia,(D*U-M*G)*Ia);Aa[va].addSelf(e);Aa[Ca].addSelf(e);Aa[ka].addSelf(e);da[va].addSelf(ga);da[Ca].addSelf(ga);da[ka].addSelf(ga)}var d,c,f,g,h,j,k,n,p,o,x,A,t,C,F,I,G,U,D,M,O,Q,Ia,ua,Aa=[],da=[],e=new THREE.Vector3,ga=new THREE.Vector3,Ba=new THREE.Vector3,Ja=new THREE.Vector3,Ka=new THREE.Vector3;d=0;for(c=this.vertices.length;d<c;d++){Aa[d]=new THREE.Vector3;da[d]=new THREE.Vector3}d=0;for(c=this.faces.length;d<c;d++){h=
|
|
|
-this.faces[d];j=this.faceVertexUvs[0][d];if(h instanceof THREE.Face3)b(this,h.a,h.b,h.c,0,1,2);else if(h instanceof THREE.Face4){b(this,h.a,h.b,h.c,0,1,2);b(this,h.a,h.b,h.d,0,1,3)}}var wa=["a","b","c","d"];d=0;for(c=this.faces.length;d<c;d++){h=this.faces[d];for(f=0;f<h.vertexNormals.length;f++){Ka.copy(h.vertexNormals[f]);g=h[wa[f]];ua=Aa[g];Ba.copy(ua);Ba.subSelf(Ka.multiplyScalar(Ka.dot(ua))).normalize();Ja.cross(h.vertexNormals[f],ua);g=Ja.dot(da[g]);g=g<0?-1:1;h.vertexTangents[f]=new THREE.Vector4(Ba.x,
|
|
|
-Ba.y,Ba.z,g)}}this.hasTangents=!0},computeBoundingBox:function(){var b;if(this.vertices.length>0){this.boundingBox={x:[this.vertices[0].position.x,this.vertices[0].position.x],y:[this.vertices[0].position.y,this.vertices[0].position.y],z:[this.vertices[0].position.z,this.vertices[0].position.z]};for(var d=1,c=this.vertices.length;d<c;d++){b=this.vertices[d];if(b.position.x<this.boundingBox.x[0])this.boundingBox.x[0]=b.position.x;else if(b.position.x>this.boundingBox.x[1])this.boundingBox.x[1]=b.position.x;
|
|
|
+c.vertexNormals[1].copy(f[c.b]);c.vertexNormals[2].copy(f[c.c])}else if(c instanceof THREE.Face4){c.vertexNormals[0].copy(f[c.a]);c.vertexNormals[1].copy(f[c.b]);c.vertexNormals[2].copy(f[c.c]);c.vertexNormals[3].copy(f[c.d])}}},computeTangents:function(){function b(ca,ta,Aa,ia,Z,pa,Ea){k=ca.vertices[ta].position;n=ca.vertices[Aa].position;p=ca.vertices[ia].position;o=j[Z];t=j[pa];y=j[Ea];v=n.x-k.x;B=p.x-k.x;C=n.y-k.y;E=p.y-k.y;J=n.z-k.z;T=p.z-k.z;z=t.u-o.u;K=y.u-o.u;L=t.v-o.v;M=y.v-o.v;Ga=1/(z*M-
|
|
|
+K*L);e.set((M*v-L*B)*Ga,(M*C-L*E)*Ga,(M*J-L*T)*Ga);ea.set((z*B-K*v)*Ga,(z*E-K*C)*Ga,(z*T-K*J)*Ga);ya[ta].addSelf(e);ya[Aa].addSelf(e);ya[ia].addSelf(e);aa[ta].addSelf(ea);aa[Aa].addSelf(ea);aa[ia].addSelf(ea)}var d,c,f,g,h,j,k,n,p,o,t,y,v,B,C,E,J,T,z,K,L,M,Ga,sa,ya=[],aa=[],e=new THREE.Vector3,ea=new THREE.Vector3,za=new THREE.Vector3,Ha=new THREE.Vector3,Ia=new THREE.Vector3;d=0;for(c=this.vertices.length;d<c;d++){ya[d]=new THREE.Vector3;aa[d]=new THREE.Vector3}d=0;for(c=this.faces.length;d<c;d++){h=
|
|
|
+this.faces[d];j=this.faceVertexUvs[0][d];if(h instanceof THREE.Face3)b(this,h.a,h.b,h.c,0,1,2);else if(h instanceof THREE.Face4){b(this,h.a,h.b,h.c,0,1,2);b(this,h.a,h.b,h.d,0,1,3)}}var ua=["a","b","c","d"];d=0;for(c=this.faces.length;d<c;d++){h=this.faces[d];for(f=0;f<h.vertexNormals.length;f++){Ia.copy(h.vertexNormals[f]);g=h[ua[f]];sa=ya[g];za.copy(sa);za.subSelf(Ia.multiplyScalar(Ia.dot(sa))).normalize();Ha.cross(h.vertexNormals[f],sa);g=Ha.dot(aa[g]);g=g<0?-1:1;h.vertexTangents[f]=new THREE.Vector4(za.x,
|
|
|
+za.y,za.z,g)}}this.hasTangents=!0},computeBoundingBox:function(){var b;if(this.vertices.length>0){this.boundingBox={x:[this.vertices[0].position.x,this.vertices[0].position.x],y:[this.vertices[0].position.y,this.vertices[0].position.y],z:[this.vertices[0].position.z,this.vertices[0].position.z]};for(var d=1,c=this.vertices.length;d<c;d++){b=this.vertices[d];if(b.position.x<this.boundingBox.x[0])this.boundingBox.x[0]=b.position.x;else if(b.position.x>this.boundingBox.x[1])this.boundingBox.x[1]=b.position.x;
|
|
|
if(b.position.y<this.boundingBox.y[0])this.boundingBox.y[0]=b.position.y;else if(b.position.y>this.boundingBox.y[1])this.boundingBox.y[1]=b.position.y;if(b.position.z<this.boundingBox.z[0])this.boundingBox.z[0]=b.position.z;else if(b.position.z>this.boundingBox.z[1])this.boundingBox.z[1]=b.position.z}}},computeBoundingSphere:function(){for(var b=this.boundingSphere===null?0:this.boundingSphere.radius,d=0,c=this.vertices.length;d<c;d++)b=Math.max(b,this.vertices[d].position.length());this.boundingSphere=
|
|
|
{radius:b}}};THREE.GeometryIdCounter=0;
|
|
|
-THREE.Spline=function(b){function d(t,C,F,I,G,U,D){t=(F-t)*0.5;I=(I-C)*0.5;return(2*(C-F)+t+I)*D+(-3*(C-F)-2*t-I)*U+t*G+C}this.points=b;var c=[],f={x:0,y:0,z:0},g,h,j,k,n,p,o,x,A;this.initFromArray=function(t){this.points=[];for(var C=0;C<t.length;C++)this.points[C]={x:t[C][0],y:t[C][1],z:t[C][2]}};this.getPoint=function(t){g=(this.points.length-1)*t;h=Math.floor(g);j=g-h;c[0]=h==0?h:h-1;c[1]=h;c[2]=h>this.points.length-2?h:h+1;c[3]=h>this.points.length-3?h:h+2;p=this.points[c[0]];o=this.points[c[1]];
|
|
|
-x=this.points[c[2]];A=this.points[c[3]];k=j*j;n=j*k;f.x=d(p.x,o.x,x.x,A.x,j,k,n);f.y=d(p.y,o.y,x.y,A.y,j,k,n);f.z=d(p.z,o.z,x.z,A.z,j,k,n);return f};this.getControlPointsArray=function(){var t,C,F=this.points.length,I=[];for(t=0;t<F;t++){C=this.points[t];I[t]=[C.x,C.y,C.z]}return I};this.getLength=function(t){var C,F,I=C=C=0,G=new THREE.Vector3,U=new THREE.Vector3,D=[],M=0;D[0]=0;t||(t=100);F=this.points.length*t;G.copy(this.points[0]);for(t=1;t<F;t++){C=t/F;position=this.getPoint(C);U.copy(position);
|
|
|
-M+=U.distanceTo(G);G.copy(position);C*=this.points.length-1;C=Math.floor(C);if(C!=I){D[C]=M;I=C}}D[D.length]=M;return{chunks:D,total:M}};this.reparametrizeByArcLength=function(t){var C,F,I,G,U,D,M=[],O=new THREE.Vector3,Q=this.getLength();M.push(O.copy(this.points[0]).clone());for(C=1;C<this.points.length;C++){F=Q.chunks[C]-Q.chunks[C-1];D=Math.ceil(t*F/Q.total);G=(C-1)/(this.points.length-1);U=C/(this.points.length-1);for(F=1;F<D-1;F++){I=G+F*(1/D)*(U-G);position=this.getPoint(I);M.push(O.copy(position).clone())}M.push(O.copy(this.points[C]).clone())}this.points=
|
|
|
-M}};
|
|
|
+THREE.Spline=function(b){function d(v,B,C,E,J,T,z){v=(C-v)*0.5;E=(E-B)*0.5;return(2*(B-C)+v+E)*z+(-3*(B-C)-2*v-E)*T+v*J+B}this.points=b;var c=[],f={x:0,y:0,z:0},g,h,j,k,n,p,o,t,y;this.initFromArray=function(v){this.points=[];for(var B=0;B<v.length;B++)this.points[B]={x:v[B][0],y:v[B][1],z:v[B][2]}};this.getPoint=function(v){g=(this.points.length-1)*v;h=Math.floor(g);j=g-h;c[0]=h==0?h:h-1;c[1]=h;c[2]=h>this.points.length-2?h:h+1;c[3]=h>this.points.length-3?h:h+2;p=this.points[c[0]];o=this.points[c[1]];
|
|
|
+t=this.points[c[2]];y=this.points[c[3]];k=j*j;n=j*k;f.x=d(p.x,o.x,t.x,y.x,j,k,n);f.y=d(p.y,o.y,t.y,y.y,j,k,n);f.z=d(p.z,o.z,t.z,y.z,j,k,n);return f};this.getControlPointsArray=function(){var v,B,C=this.points.length,E=[];for(v=0;v<C;v++){B=this.points[v];E[v]=[B.x,B.y,B.z]}return E};this.getLength=function(v){var B,C,E=B=B=0,J=new THREE.Vector3,T=new THREE.Vector3,z=[],K=0;z[0]=0;v||(v=100);C=this.points.length*v;J.copy(this.points[0]);for(v=1;v<C;v++){B=v/C;position=this.getPoint(B);T.copy(position);
|
|
|
+K+=T.distanceTo(J);J.copy(position);B*=this.points.length-1;B=Math.floor(B);if(B!=E){z[B]=K;E=B}}z[z.length]=K;return{chunks:z,total:K}};this.reparametrizeByArcLength=function(v){var B,C,E,J,T,z,K=[],L=new THREE.Vector3,M=this.getLength();K.push(L.copy(this.points[0]).clone());for(B=1;B<this.points.length;B++){C=M.chunks[B]-M.chunks[B-1];z=Math.ceil(v*C/M.total);J=(B-1)/(this.points.length-1);T=B/(this.points.length-1);for(C=1;C<z-1;C++){E=J+C*(1/z)*(T-J);position=this.getPoint(E);K.push(L.copy(position).clone())}K.push(L.copy(this.points[B]).clone())}this.points=
|
|
|
+K}};
|
|
|
THREE.AnimationHandler=function(){var b=[],d={},c={};c.update=function(g){for(var h=0;h<b.length;h++)b[h].update(g)};c.addToUpdate=function(g){b.indexOf(g)===-1&&b.push(g)};c.removeFromUpdate=function(g){g=b.indexOf(g);g!==-1&&b.splice(g,1)};c.add=function(g){d[g.name]!==undefined&&console.log("THREE.AnimationHandler.add: Warning! "+g.name+" already exists in library. Overwriting.");d[g.name]=g;if(g.initialized!==!0){for(var h=0;h<g.hierarchy.length;h++){for(var j=0;j<g.hierarchy[h].keys.length;j++){if(g.hierarchy[h].keys[j].time<0)g.hierarchy[h].keys[j].time=
|
|
|
0;if(g.hierarchy[h].keys[j].rot!==undefined&&!(g.hierarchy[h].keys[j].rot instanceof THREE.Quaternion)){var k=g.hierarchy[h].keys[j].rot;g.hierarchy[h].keys[j].rot=new THREE.Quaternion(k[0],k[1],k[2],k[3])}}if(g.hierarchy[h].keys[0].morphTargets!==undefined){k={};for(j=0;j<g.hierarchy[h].keys.length;j++)for(var n=0;n<g.hierarchy[h].keys[j].morphTargets.length;n++){var p=g.hierarchy[h].keys[j].morphTargets[n];k[p]=-1}g.hierarchy[h].usedMorphTargets=k;for(j=0;j<g.hierarchy[h].keys.length;j++){var o=
|
|
|
{};for(p in k){for(n=0;n<g.hierarchy[h].keys[j].morphTargets.length;n++)if(g.hierarchy[h].keys[j].morphTargets[n]===p){o[p]=g.hierarchy[h].keys[j].morphTargetsInfluences[n];break}n===g.hierarchy[h].keys[j].morphTargets.length&&(o[p]=0)}g.hierarchy[h].keys[j].morphTargetsInfluences=o}}for(j=1;j<g.hierarchy[h].keys.length;j++)if(g.hierarchy[h].keys[j].time===g.hierarchy[h].keys[j-1].time){g.hierarchy[h].keys.splice(j,1);j--}for(j=1;j<g.hierarchy[h].keys.length;j++)g.hierarchy[h].keys[j].index=j}j=parseInt(g.length*
|
|
@@ -75,11 +75,11 @@ THREE.Animation.prototype.play=function(b,d){if(!this.isPlaying){this.isPlaying=
|
|
|
g instanceof THREE.Bone?g.skinMatrix:g.matrix}var h=g.animationCache.prevKey;g=g.animationCache.nextKey;h.pos=this.data.hierarchy[c].keys[0];h.rot=this.data.hierarchy[c].keys[0];h.scl=this.data.hierarchy[c].keys[0];g.pos=this.getNextKeyWith("pos",c,1);g.rot=this.getNextKeyWith("rot",c,1);g.scl=this.getNextKeyWith("scl",c,1)}this.update(0)}this.isPaused=!1;THREE.AnimationHandler.addToUpdate(this)};
|
|
|
THREE.Animation.prototype.pause=function(){this.isPaused?THREE.AnimationHandler.addToUpdate(this):THREE.AnimationHandler.removeFromUpdate(this);this.isPaused=!this.isPaused};
|
|
|
THREE.Animation.prototype.stop=function(){this.isPlaying=!1;this.isPaused=!1;THREE.AnimationHandler.removeFromUpdate(this);for(var b=0;b<this.hierarchy.length;b++)if(this.hierarchy[b].animationCache!==undefined){if(this.hierarchy[b]instanceof THREE.Bone)this.hierarchy[b].skinMatrix=this.hierarchy[b].animationCache.originalMatrix;else this.hierarchy[b].matrix=this.hierarchy[b].animationCache.originalMatrix;delete this.hierarchy[b].animationCache}};
|
|
|
-THREE.Animation.prototype.update=function(b){if(this.isPlaying){var d=["pos","rot","scl"],c,f,g,h,j,k,n,p,o=this.data.JIT.hierarchy,x,A;this.currentTime+=b*this.timeScale;A=this.currentTime;x=this.currentTime%=this.data.length;p=parseInt(Math.min(x*this.data.fps,this.data.length*this.data.fps),10);for(var t=0,C=this.hierarchy.length;t<C;t++){b=this.hierarchy[t];n=b.animationCache;if(this.JITCompile&&o[t][p]!==undefined)if(b instanceof THREE.Bone){b.skinMatrix=o[t][p];b.matrixAutoUpdate=!1;b.matrixWorldNeedsUpdate=
|
|
|
-!1}else{b.matrix=o[t][p];b.matrixAutoUpdate=!1;b.matrixWorldNeedsUpdate=!0}else{if(this.JITCompile)if(b instanceof THREE.Bone)b.skinMatrix=b.animationCache.originalMatrix;else b.matrix=b.animationCache.originalMatrix;for(var F=0;F<3;F++){c=d[F];j=n.prevKey[c];k=n.nextKey[c];if(k.time<=A){if(x<A)if(this.loop){j=this.data.hierarchy[t].keys[0];for(k=this.getNextKeyWith(c,t,1);k.time<x;){j=k;k=this.getNextKeyWith(c,t,k.index+1)}}else{this.stop();return}else{do{j=k;k=this.getNextKeyWith(c,t,k.index+1)}while(k.time<
|
|
|
-x)}n.prevKey[c]=j;n.nextKey[c]=k}b.matrixAutoUpdate=!0;b.matrixWorldNeedsUpdate=!0;f=(x-j.time)/(k.time-j.time);g=j[c];h=k[c];if(f<0||f>1){console.log("THREE.Animation.update: Warning! Scale out of bounds:"+f+" on bone "+t);f=f<0?0:1}if(c==="pos"){c=b.position;if(this.interpolationType===THREE.AnimationHandler.LINEAR){c.x=g[0]+(h[0]-g[0])*f;c.y=g[1]+(h[1]-g[1])*f;c.z=g[2]+(h[2]-g[2])*f}else if(this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD){this.points[0]=
|
|
|
-this.getPrevKeyWith("pos",t,j.index-1).pos;this.points[1]=g;this.points[2]=h;this.points[3]=this.getNextKeyWith("pos",t,k.index+1).pos;f=f*0.33+0.33;g=this.interpolateCatmullRom(this.points,f);c.x=g[0];c.y=g[1];c.z=g[2];if(this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD){f=this.interpolateCatmullRom(this.points,f*1.01);this.target.set(f[0],f[1],f[2]);this.target.subSelf(c);this.target.y=0;this.target.normalize();f=Math.atan2(this.target.x,this.target.z);b.rotation.set(0,f,0)}}}else if(c===
|
|
|
-"rot")THREE.Quaternion.slerp(g,h,b.quaternion,f);else if(c==="scl"){c=b.scale;c.x=g[0]+(h[0]-g[0])*f;c.y=g[1]+(h[1]-g[1])*f;c.z=g[2]+(h[2]-g[2])*f}}}}if(this.JITCompile&&o[0][p]===undefined){this.hierarchy[0].update(undefined,!0);for(t=0;t<this.hierarchy.length;t++)o[t][p]=this.hierarchy[t]instanceof THREE.Bone?this.hierarchy[t].skinMatrix.clone():this.hierarchy[t].matrix.clone()}}};
|
|
|
+THREE.Animation.prototype.update=function(b){if(this.isPlaying){var d=["pos","rot","scl"],c,f,g,h,j,k,n,p,o=this.data.JIT.hierarchy,t,y;this.currentTime+=b*this.timeScale;y=this.currentTime;t=this.currentTime%=this.data.length;p=parseInt(Math.min(t*this.data.fps,this.data.length*this.data.fps),10);for(var v=0,B=this.hierarchy.length;v<B;v++){b=this.hierarchy[v];n=b.animationCache;if(this.JITCompile&&o[v][p]!==undefined)if(b instanceof THREE.Bone){b.skinMatrix=o[v][p];b.matrixAutoUpdate=!1;b.matrixWorldNeedsUpdate=
|
|
|
+!1}else{b.matrix=o[v][p];b.matrixAutoUpdate=!1;b.matrixWorldNeedsUpdate=!0}else{if(this.JITCompile)if(b instanceof THREE.Bone)b.skinMatrix=b.animationCache.originalMatrix;else b.matrix=b.animationCache.originalMatrix;for(var C=0;C<3;C++){c=d[C];j=n.prevKey[c];k=n.nextKey[c];if(k.time<=y){if(t<y)if(this.loop){j=this.data.hierarchy[v].keys[0];for(k=this.getNextKeyWith(c,v,1);k.time<t;){j=k;k=this.getNextKeyWith(c,v,k.index+1)}}else{this.stop();return}else{do{j=k;k=this.getNextKeyWith(c,v,k.index+1)}while(k.time<
|
|
|
+t)}n.prevKey[c]=j;n.nextKey[c]=k}b.matrixAutoUpdate=!0;b.matrixWorldNeedsUpdate=!0;f=(t-j.time)/(k.time-j.time);g=j[c];h=k[c];if(f<0||f>1){console.log("THREE.Animation.update: Warning! Scale out of bounds:"+f+" on bone "+v);f=f<0?0:1}if(c==="pos"){c=b.position;if(this.interpolationType===THREE.AnimationHandler.LINEAR){c.x=g[0]+(h[0]-g[0])*f;c.y=g[1]+(h[1]-g[1])*f;c.z=g[2]+(h[2]-g[2])*f}else if(this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD){this.points[0]=
|
|
|
+this.getPrevKeyWith("pos",v,j.index-1).pos;this.points[1]=g;this.points[2]=h;this.points[3]=this.getNextKeyWith("pos",v,k.index+1).pos;f=f*0.33+0.33;g=this.interpolateCatmullRom(this.points,f);c.x=g[0];c.y=g[1];c.z=g[2];if(this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD){f=this.interpolateCatmullRom(this.points,f*1.01);this.target.set(f[0],f[1],f[2]);this.target.subSelf(c);this.target.y=0;this.target.normalize();f=Math.atan2(this.target.x,this.target.z);b.rotation.set(0,f,0)}}}else if(c===
|
|
|
+"rot")THREE.Quaternion.slerp(g,h,b.quaternion,f);else if(c==="scl"){c=b.scale;c.x=g[0]+(h[0]-g[0])*f;c.y=g[1]+(h[1]-g[1])*f;c.z=g[2]+(h[2]-g[2])*f}}}}if(this.JITCompile&&o[0][p]===undefined){this.hierarchy[0].update(undefined,!0);for(v=0;v<this.hierarchy.length;v++)o[v][p]=this.hierarchy[v]instanceof THREE.Bone?this.hierarchy[v].skinMatrix.clone():this.hierarchy[v].matrix.clone()}}};
|
|
|
THREE.Animation.prototype.interpolateCatmullRom=function(b,d){var c=[],f=[],g,h,j,k,n,p;g=(b.length-1)*d;h=Math.floor(g);g-=h;c[0]=h==0?h:h-1;c[1]=h;c[2]=h>b.length-2?h:h+1;c[3]=h>b.length-3?h:h+2;h=b[c[0]];k=b[c[1]];n=b[c[2]];p=b[c[3]];c=g*g;j=g*c;f[0]=this.interpolate(h[0],k[0],n[0],p[0],g,c,j);f[1]=this.interpolate(h[1],k[1],n[1],p[1],g,c,j);f[2]=this.interpolate(h[2],k[2],n[2],p[2],g,c,j);return f};
|
|
|
THREE.Animation.prototype.interpolate=function(b,d,c,f,g,h,j){b=(c-b)*0.5;f=(f-d)*0.5;return(2*(d-c)+b+f)*j+(-3*(d-c)-2*b-f)*h+b*g+d};THREE.Animation.prototype.getNextKeyWith=function(b,d,c){var f=this.data.hierarchy[d].keys;if(this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD)c=c<f.length-1?c:f.length-1;else c%=f.length;for(;c<f.length;c++)if(f[c][b]!==undefined)return f[c];return this.data.hierarchy[d].keys[0]};
|
|
|
THREE.Animation.prototype.getPrevKeyWith=function(b,d,c){var f=this.data.hierarchy[d].keys;for(c=this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD?c>0?c:0:c>=0?c:c+f.length;c>=0;c--)if(f[c][b]!==undefined)return f[c];return this.data.hierarchy[d].keys[f.length-1]};
|
|
@@ -138,65 +138,65 @@ THREE.LOD.prototype.supr=THREE.Object3D.prototype;THREE.LOD.prototype.add=functi
|
|
|
THREE.LOD.prototype.update=function(b,d,c){this.matrixAutoUpdate&&(d|=this.updateMatrix());if(d||this.matrixWorldNeedsUpdate){b?this.matrixWorld.multiply(b,this.matrix):this.matrixWorld.copy(this.matrix);this.matrixWorldNeedsUpdate=!1;d=!0}if(this.LODs.length>1){b=c.matrixWorldInverse;b=-(b.n31*this.position.x+b.n32*this.position.y+b.n33*this.position.z+b.n34);this.LODs[0].object3D.visible=!0;for(var f=1;f<this.LODs.length;f++)if(b>=this.LODs[f].visibleAtDistance){this.LODs[f-1].object3D.visible=
|
|
|
!1;this.LODs[f].object3D.visible=!0}else break;for(;f<this.LODs.length;f++)this.LODs[f].object3D.visible=!1}for(b=0;b<this.children.length;b++)this.children[b].update(this.matrixWorld,d,c)};THREE.ShadowVolume=function(b,d){THREE.Mesh.call(this,b.geometry,d?[new THREE.ShadowVolumeDynamicMaterial]:[new THREE.ShadowVolumeDynamicMaterial]);b.addChild(this);this.calculateShadowVolumeGeometry(b.geometry)};THREE.ShadowVolume.prototype=new THREE.Mesh;THREE.ShadowVolume.prototype.constructor=THREE.ShadowVolume;
|
|
|
THREE.ShadowVolume.prototype.supr=THREE.Mesh.prototype;
|
|
|
-THREE.ShadowVolume.prototype.calculateShadowVolumeGeometry=function(b){this.geometry=new THREE.Geometry;this.geometry.boundingSphere=b.boundingSphere;this.geometry.edgeFaces=[];var d=this.geometry.vertices,c=this.geometry.faces,f=this.geometry.edgeFaces,g=b.faces;b=b.vertices;var h=g.length,j,k,n,p,o,x=["a","b","c","d"];for(n=0;n<h;n++){k=d.length;j=g[n];if(j instanceof THREE.Face4){p=4;k=new THREE.Face4(k,k+1,k+2,k+3)}else{p=3;k=new THREE.Face3(k,k+1,k+2)}k.normal.copy(j.normal);c.push(k);for(k=
|
|
|
-0;k<p;k++){o=b[j[x[k]]];d.push(new THREE.Vertex(o.position.clone()))}}for(h=0;h<g.length-1;h++){b=c[h];for(j=h+1;j<g.length;j++){k=c[j];k=this.facesShareEdge(d,b,k);if(k!==undefined){k=new THREE.Face4(k.indices[0],k.indices[3],k.indices[2],k.indices[1]);k.normal.set(1,0,0);f.push(k)}}}};
|
|
|
-THREE.ShadowVolume.prototype.facesShareEdge=function(b,d,c){var f,g,h,j,k,n,p,o,x,A,t,C,F,I=0,G=["a","b","c","d"];f=d instanceof THREE.Face4?4:3;g=c instanceof THREE.Face4?4:3;for(C=0;C<f;C++){h=d[G[C]];k=b[h];for(F=0;F<g;F++){j=c[G[F]];n=b[j];if(Math.abs(k.position.x-n.position.x)<1.0E-4&&Math.abs(k.position.y-n.position.y)<1.0E-4&&Math.abs(k.position.z-n.position.z)<1.0E-4){I++;if(I===1){p=k;o=n;x=h;A=j;t=G[C]}if(I===2){t+=G[C];return t==="ad"||t==="ac"?{faces:[d,c],vertices:[p,o,n,k],indices:[x,
|
|
|
-A,j,h],vertexTypes:[1,2,2,1],extrudable:!0}:{faces:[d,c],vertices:[p,k,n,o],indices:[x,h,j,A],vertexTypes:[1,1,2,2],extrudable:!0}}}}}};THREE.Scene=function(){THREE.Object3D.call(this);this.matrixAutoUpdate=!1;this.fog=null;this.objects=[];this.lights=[];this.sounds=[];this.__objectsAdded=[];this.__objectsRemoved=[]};THREE.Scene.prototype=new THREE.Object3D;THREE.Scene.prototype.constructor=THREE.Scene;THREE.Scene.prototype.supr=THREE.Object3D.prototype;
|
|
|
+THREE.ShadowVolume.prototype.calculateShadowVolumeGeometry=function(b){this.geometry=new THREE.Geometry;this.geometry.boundingSphere=b.boundingSphere;this.geometry.edgeFaces=[];var d=this.geometry.vertices,c=this.geometry.faces,f=this.geometry.edgeFaces,g=b.faces;b=b.vertices;var h=g.length,j,k,n,p,o,t=["a","b","c","d"];for(n=0;n<h;n++){k=d.length;j=g[n];if(j instanceof THREE.Face4){p=4;k=new THREE.Face4(k,k+1,k+2,k+3)}else{p=3;k=new THREE.Face3(k,k+1,k+2)}k.normal.copy(j.normal);c.push(k);for(k=
|
|
|
+0;k<p;k++){o=b[j[t[k]]];d.push(new THREE.Vertex(o.position.clone()))}}for(h=0;h<g.length-1;h++){b=c[h];for(j=h+1;j<g.length;j++){k=c[j];k=this.facesShareEdge(d,b,k);if(k!==undefined){k=new THREE.Face4(k.indices[0],k.indices[3],k.indices[2],k.indices[1]);k.normal.set(1,0,0);f.push(k)}}}};
|
|
|
+THREE.ShadowVolume.prototype.facesShareEdge=function(b,d,c){var f,g,h,j,k,n,p,o,t,y,v,B,C,E=0,J=["a","b","c","d"];f=d instanceof THREE.Face4?4:3;g=c instanceof THREE.Face4?4:3;for(B=0;B<f;B++){h=d[J[B]];k=b[h];for(C=0;C<g;C++){j=c[J[C]];n=b[j];if(Math.abs(k.position.x-n.position.x)<1.0E-4&&Math.abs(k.position.y-n.position.y)<1.0E-4&&Math.abs(k.position.z-n.position.z)<1.0E-4){E++;if(E===1){p=k;o=n;t=h;y=j;v=J[B]}if(E===2){v+=J[B];return v==="ad"||v==="ac"?{faces:[d,c],vertices:[p,o,n,k],indices:[t,
|
|
|
+y,j,h],vertexTypes:[1,2,2,1],extrudable:!0}:{faces:[d,c],vertices:[p,k,n,o],indices:[t,h,j,y],vertexTypes:[1,1,2,2],extrudable:!0}}}}}};THREE.Scene=function(){THREE.Object3D.call(this);this.matrixAutoUpdate=!1;this.fog=null;this.objects=[];this.lights=[];this.sounds=[];this.__objectsAdded=[];this.__objectsRemoved=[]};THREE.Scene.prototype=new THREE.Object3D;THREE.Scene.prototype.constructor=THREE.Scene;THREE.Scene.prototype.supr=THREE.Object3D.prototype;
|
|
|
THREE.Scene.prototype.addChild=function(b){this.supr.addChild.call(this,b);this.addChildRecurse(b)};THREE.Scene.prototype.addChildRecurse=function(b){if(b instanceof THREE.Light)this.lights.indexOf(b)===-1&&this.lights.push(b);else if(b instanceof THREE.Sound)this.sounds.indexOf(b)===-1&&this.sounds.push(b);else if(!(b instanceof THREE.Camera||b instanceof THREE.Bone)&&this.objects.indexOf(b)===-1){this.objects.push(b);this.__objectsAdded.push(b)}for(var d=0;d<b.children.length;d++)this.addChildRecurse(b.children[d])};
|
|
|
THREE.Scene.prototype.removeChild=function(b){this.supr.removeChild.call(this,b);this.removeChildRecurse(b)};THREE.Scene.prototype.removeChildRecurse=function(b){if(b instanceof THREE.Light){var d=this.lights.indexOf(b);d!==-1&&this.lights.splice(d,1)}else if(b instanceof THREE.Sound){d=this.sounds.indexOf(b);d!==-1&&this.sounds.splice(d,1)}else if(!(b instanceof THREE.Camera)){d=this.objects.indexOf(b);if(d!==-1){this.objects.splice(d,1);this.__objectsRemoved.push(b)}}for(d=0;d<b.children.length;d++)this.removeChildRecurse(b.children[d])};
|
|
|
THREE.Scene.prototype.addObject=THREE.Scene.prototype.addChild;THREE.Scene.prototype.removeObject=THREE.Scene.prototype.removeChild;THREE.Scene.prototype.addLight=THREE.Scene.prototype.addChild;THREE.Scene.prototype.removeLight=THREE.Scene.prototype.removeChild;THREE.Fog=function(b,d,c){this.color=new THREE.Color(b);this.near=d||1;this.far=c||1E3};THREE.FogExp2=function(b,d){this.color=new THREE.Color(b);this.density=d!==undefined?d:2.5E-4};
|
|
|
-THREE.Projector=function(){function b(){var e=n[k]=n[k]||new THREE.RenderableVertex;k++;return e}function d(e,ga){return ga.z-e.z}function c(e,ga){var Ba=0,Ja=1,Ka=e.z+e.w,wa=ga.z+ga.w,ea=-e.z+e.w,va=-ga.z+ga.w;if(Ka>=0&&wa>=0&&ea>=0&&va>=0)return!0;else if(Ka<0&&wa<0||ea<0&&va<0)return!1;else{if(Ka<0)Ba=Math.max(Ba,Ka/(Ka-wa));else wa<0&&(Ja=Math.min(Ja,Ka/(Ka-wa)));if(ea<0)Ba=Math.max(Ba,ea/(ea-va));else va<0&&(Ja=Math.min(Ja,ea/(ea-va)));if(Ja<Ba)return!1;else{e.lerpSelf(ga,Ba);ga.lerpSelf(e,1-
|
|
|
-Ja);return!0}}}var f,g,h=[],j,k,n=[],p,o,x=[],A,t=[],C,F,I=[],G,U,D=[],M=new THREE.Vector4,O=new THREE.Vector4,Q=new THREE.Matrix4,Ia=new THREE.Matrix4,ua=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],Aa=new THREE.Vector4,da=new THREE.Vector4;this.projectVector=function(e,ga){Q.multiply(ga.projectionMatrix,ga.matrixWorldInverse);Q.multiplyVector3(e);return e};this.unprojectVector=function(e,ga){Q.multiply(ga.matrixWorld,THREE.Matrix4.makeInvert(ga.projectionMatrix));
|
|
|
-Q.multiplyVector3(e);return e};this.projectObjects=function(e,ga,Ba){ga=[];var Ja,Ka,wa;g=0;Ka=e.objects;e=0;for(Ja=Ka.length;e<Ja;e++){wa=Ka[e];var ea;if(!(ea=!wa.visible))if(ea=wa instanceof THREE.Mesh){a:{ea=void 0;for(var va=wa.matrixWorld,Ca=-wa.geometry.boundingSphere.radius*Math.max(wa.scale.x,Math.max(wa.scale.y,wa.scale.z)),ka=0;ka<6;ka++){ea=ua[ka].x*va.n14+ua[ka].y*va.n24+ua[ka].z*va.n34+ua[ka].w;if(ea<=Ca){ea=!1;break a}}ea=!0}ea=!ea}if(!ea){ea=h[g]=h[g]||new THREE.RenderableObject;g++;
|
|
|
-f=ea;M.copy(wa.position);Q.multiplyVector3(M);f.object=wa;f.z=M.z;ga.push(f)}}Ba&&ga.sort(d);return ga};this.projectScene=function(e,ga,Ba){var Ja=[],Ka=ga.near,wa=ga.far,ea,va,Ca,ka,aa,ra,Ga,la,pa,Ha,Ta,ab,Xa,Ua,N,ca,sa;U=F=A=o=0;ga.matrixAutoUpdate&&ga.updateMatrix();e.update(undefined,!1,ga);Q.multiply(ga.projectionMatrix,ga.matrixWorldInverse);ua[0].set(Q.n41-Q.n11,Q.n42-Q.n12,Q.n43-Q.n13,Q.n44-Q.n14);ua[1].set(Q.n41+Q.n11,Q.n42+Q.n12,Q.n43+Q.n13,Q.n44+Q.n14);ua[2].set(Q.n41+Q.n21,Q.n42+Q.n22,
|
|
|
-Q.n43+Q.n23,Q.n44+Q.n24);ua[3].set(Q.n41-Q.n21,Q.n42-Q.n22,Q.n43-Q.n23,Q.n44-Q.n24);ua[4].set(Q.n41-Q.n31,Q.n42-Q.n32,Q.n43-Q.n33,Q.n44-Q.n34);ua[5].set(Q.n41+Q.n31,Q.n42+Q.n32,Q.n43+Q.n33,Q.n44+Q.n34);for(ea=0;ea<6;ea++){pa=ua[ea];pa.divideScalar(Math.sqrt(pa.x*pa.x+pa.y*pa.y+pa.z*pa.z))}pa=this.projectObjects(e,ga,!0);e=0;for(ea=pa.length;e<ea;e++){Ha=pa[e].object;if(Ha.visible){Ta=Ha.matrixWorld;ab=Ha.matrixRotationWorld;Xa=Ha.materials;Ua=Ha.overdraw;k=0;if(Ha instanceof THREE.Mesh){N=Ha.geometry;
|
|
|
-ka=N.vertices;ca=N.faces;N=N.faceVertexUvs;va=0;for(Ca=ka.length;va<Ca;va++){j=b();j.positionWorld.copy(ka[va].position);Ta.multiplyVector3(j.positionWorld);j.positionScreen.copy(j.positionWorld);Q.multiplyVector4(j.positionScreen);j.positionScreen.x/=j.positionScreen.w;j.positionScreen.y/=j.positionScreen.w;j.visible=j.positionScreen.z>Ka&&j.positionScreen.z<wa}ka=0;for(va=ca.length;ka<va;ka++){Ca=ca[ka];if(Ca instanceof THREE.Face3){aa=n[Ca.a];ra=n[Ca.b];Ga=n[Ca.c];if(aa.visible&&ra.visible&&Ga.visible&&
|
|
|
-(Ha.doubleSided||Ha.flipSided!=(Ga.positionScreen.x-aa.positionScreen.x)*(ra.positionScreen.y-aa.positionScreen.y)-(Ga.positionScreen.y-aa.positionScreen.y)*(ra.positionScreen.x-aa.positionScreen.x)<0)){la=x[o]=x[o]||new THREE.RenderableFace3;o++;p=la;p.v1.copy(aa);p.v2.copy(ra);p.v3.copy(Ga)}else continue}else if(Ca instanceof THREE.Face4){aa=n[Ca.a];ra=n[Ca.b];Ga=n[Ca.c];la=n[Ca.d];if(aa.visible&&ra.visible&&Ga.visible&&la.visible&&(Ha.doubleSided||Ha.flipSided!=((la.positionScreen.x-aa.positionScreen.x)*
|
|
|
-(ra.positionScreen.y-aa.positionScreen.y)-(la.positionScreen.y-aa.positionScreen.y)*(ra.positionScreen.x-aa.positionScreen.x)<0||(ra.positionScreen.x-Ga.positionScreen.x)*(la.positionScreen.y-Ga.positionScreen.y)-(ra.positionScreen.y-Ga.positionScreen.y)*(la.positionScreen.x-Ga.positionScreen.x)<0))){sa=t[A]=t[A]||new THREE.RenderableFace4;A++;p=sa;p.v1.copy(aa);p.v2.copy(ra);p.v3.copy(Ga);p.v4.copy(la)}else continue}p.normalWorld.copy(Ca.normal);ab.multiplyVector3(p.normalWorld);p.centroidWorld.copy(Ca.centroid);
|
|
|
-Ta.multiplyVector3(p.centroidWorld);p.centroidScreen.copy(p.centroidWorld);Q.multiplyVector3(p.centroidScreen);Ga=Ca.vertexNormals;aa=0;for(ra=Ga.length;aa<ra;aa++){la=p.vertexNormalsWorld[aa];la.copy(Ga[aa]);ab.multiplyVector3(la)}aa=0;for(ra=N.length;aa<ra;aa++)if(sa=N[aa][ka]){Ga=0;for(la=sa.length;Ga<la;Ga++)p.uvs[aa][Ga]=sa[Ga]}p.meshMaterials=Xa;p.faceMaterials=Ca.materials;p.overdraw=Ua;p.z=p.centroidScreen.z;Ja.push(p)}}else if(Ha instanceof THREE.Line){Ia.multiply(Q,Ta);ka=Ha.geometry.vertices;
|
|
|
-aa=b();aa.positionScreen.copy(ka[0].position);Ia.multiplyVector4(aa.positionScreen);va=1;for(Ca=ka.length;va<Ca;va++){aa=b();aa.positionScreen.copy(ka[va].position);Ia.multiplyVector4(aa.positionScreen);ra=n[k-2];Aa.copy(aa.positionScreen);da.copy(ra.positionScreen);if(c(Aa,da)){Aa.multiplyScalar(1/Aa.w);da.multiplyScalar(1/da.w);Ta=I[F]=I[F]||new THREE.RenderableLine;F++;C=Ta;C.v1.positionScreen.copy(Aa);C.v2.positionScreen.copy(da);C.z=Math.max(Aa.z,da.z);C.materials=Ha.materials;Ja.push(C)}}}else if(Ha instanceof
|
|
|
-THREE.Particle){O.set(Ha.position.x,Ha.position.y,Ha.position.z,1);Q.multiplyVector4(O);O.z/=O.w;if(O.z>0&&O.z<1){Ta=D[U]=D[U]||new THREE.RenderableParticle;U++;G=Ta;G.x=O.x/O.w;G.y=O.y/O.w;G.z=O.z;G.rotation=Ha.rotation.z;G.scale.x=Ha.scale.x*Math.abs(G.x-(O.x+ga.projectionMatrix.n11)/(O.w+ga.projectionMatrix.n14));G.scale.y=Ha.scale.y*Math.abs(G.y-(O.y+ga.projectionMatrix.n22)/(O.w+ga.projectionMatrix.n24));G.materials=Ha.materials;Ja.push(G)}}}}Ba&&Ja.sort(d);return Ja}};
|
|
|
-THREE.DOMRenderer=function(){THREE.Renderer.call(this);var b=null,d=new THREE.Projector,c,f,g,h;this.domElement=document.createElement("div");this.setSize=function(j,k){c=j;f=k;g=c/2;h=f/2};this.render=function(j,k){var n,p,o,x,A,t,C,F;b=d.projectScene(j,k);n=0;for(p=b.length;n<p;n++){A=b[n];if(A instanceof THREE.RenderableParticle){C=A.x*g+g;F=A.y*h+h;o=0;for(x=A.material.length;o<x;o++){t=A.material[o];if(t instanceof THREE.ParticleDOMMaterial){t=t.domElement;t.style.left=C+"px";t.style.top=F+"px"}}}}}};
|
|
|
-THREE.CanvasRenderer=function(){function b(ta){if(t!=ta)o.globalAlpha=t=ta}function d(ta){if(C!=ta){switch(ta){case THREE.NormalBlending:o.globalCompositeOperation="source-over";break;case THREE.AdditiveBlending:o.globalCompositeOperation="lighter";break;case THREE.SubtractiveBlending:o.globalCompositeOperation="darker"}C=ta}}function c(ta){if(F!=ta)o.strokeStyle=F=ta}var f=null,g=new THREE.Projector,h=document.createElement("canvas"),j,k,n,p,o=h.getContext("2d"),x=new THREE.Color(0),A=0,t=1,C=0,
|
|
|
-F=null,I=null,G=null,U=null,D=null,M,O,Q,Ia,ua=new THREE.RenderableVertex,Aa=new THREE.RenderableVertex,da,e,ga,Ba,Ja,Ka,wa,ea,va,Ca,ka,aa,ra=new THREE.Color,Ga=new THREE.Color,la=new THREE.Color,pa=new THREE.Color,Ha=new THREE.Color,Ta,ab,Xa,Ua,N,ca,sa,Ea,ia,ma,m=new THREE.Rectangle,B=new THREE.Rectangle,z=new THREE.Rectangle,w=!1,y=new THREE.Color,P=new THREE.Color,H=new THREE.Color,J=new THREE.Color,K=new THREE.Vector3,E,L,X,qa,W,Fa,La=16;E=document.createElement("canvas");E.width=E.height=2;L=
|
|
|
-E.getContext("2d");L.fillStyle="rgba(0,0,0,1)";L.fillRect(0,0,2,2);X=L.getImageData(0,0,2,2);qa=X.data;W=document.createElement("canvas");W.width=W.height=La;Fa=W.getContext("2d");Fa.translate(-La/2,-La/2);Fa.scale(La,La);La--;this.domElement=h;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setSize=function(ta,za){j=ta;k=za;n=j/2;p=k/2;h.width=j;h.height=k;m.set(-n,-p,n,p);t=1;C=0;D=U=G=I=F=null};this.setClearColor=function(ta,za){x=ta;A=za};this.setClearColorHex=function(ta,za){x.setHex(ta);
|
|
|
-A=za};this.clear=function(){o.setTransform(1,0,0,-1,n,p);if(!B.isEmpty()){B.inflate(1);B.minSelf(m);if(x.hex==0&&A==0)o.clearRect(B.getX(),B.getY(),B.getWidth(),B.getHeight());else{d(THREE.NormalBlending);b(1);o.fillStyle="rgba("+Math.floor(x.r*255)+","+Math.floor(x.g*255)+","+Math.floor(x.b*255)+","+A+")";o.fillRect(B.getX(),B.getY(),B.getWidth(),B.getHeight())}B.empty()}};this.render=function(ta,za){function db(T){var ja,na,Y,ya=T.lights;P.setRGB(0,0,0);H.setRGB(0,0,0);J.setRGB(0,0,0);T=0;for(ja=
|
|
|
-ya.length;T<ja;T++){na=ya[T];Y=na.color;if(na instanceof THREE.AmbientLight){P.r+=Y.r;P.g+=Y.g;P.b+=Y.b}else if(na instanceof THREE.DirectionalLight){H.r+=Y.r;H.g+=Y.g;H.b+=Y.b}else if(na instanceof THREE.PointLight){J.r+=Y.r;J.g+=Y.g;J.b+=Y.b}}}function Z(T,ja,na,Y){var ya,xa,ha,V,Ma=T.lights;T=0;for(ya=Ma.length;T<ya;T++){xa=Ma[T];ha=xa.color;if(xa instanceof THREE.DirectionalLight){V=na.dot(xa.position);if(!(V<=0)){V*=xa.intensity;Y.r+=ha.r*V;Y.g+=ha.g*V;Y.b+=ha.b*V}}else if(xa instanceof THREE.PointLight){V=
|
|
|
-na.dot(K.sub(xa.position,ja).normalize());if(!(V<=0)){V*=xa.distance==0?1:1-Math.min(ja.distanceTo(xa.position)/xa.distance,1);if(V!=0){V*=xa.intensity;Y.r+=ha.r*V;Y.g+=ha.g*V;Y.b+=ha.b*V}}}}}function fa(T,ja,na){b(na.opacity);d(na.blending);var Y,ya,xa,ha,V,Ma;if(na instanceof THREE.ParticleBasicMaterial){if(na.map){ha=na.map.image;V=ha.width>>1;Ma=ha.height>>1;na=ja.scale.x*n;xa=ja.scale.y*p;Y=na*V;ya=xa*Ma;z.set(T.x-Y,T.y-ya,T.x+Y,T.y+ya);if(m.instersects(z)){o.save();o.translate(T.x,T.y);o.rotate(-ja.rotation);
|
|
|
-o.scale(na,-xa);o.translate(-V,-Ma);o.drawImage(ha,0,0);o.restore()}}}else if(na instanceof THREE.ParticleCanvasMaterial){Y=ja.scale.x*n;ya=ja.scale.y*p;z.set(T.x-Y,T.y-ya,T.x+Y,T.y+ya);if(m.instersects(z)){c(na.color.__styleString);xa=na.color.__styleString;if(I!=xa)o.fillStyle=I=xa;o.save();o.translate(T.x,T.y);o.rotate(-ja.rotation);o.scale(Y,ya);na.program(o);o.restore()}}}function oa(T,ja,na,Y){b(Y.opacity);d(Y.blending);o.beginPath();o.moveTo(T.positionScreen.x,T.positionScreen.y);o.lineTo(ja.positionScreen.x,
|
|
|
-ja.positionScreen.y);o.closePath();if(Y instanceof THREE.LineBasicMaterial){ra.__styleString=Y.color.__styleString;T=Y.linewidth;if(G!=T)o.lineWidth=G=T;T=Y.linecap;if(U!=T)o.lineCap=U=T;T=Y.linejoin;if(D!=T)o.lineJoin=D=T;c(ra.__styleString);o.stroke();z.inflate(Y.linewidth*2)}}function Na(T,ja,na,Y,ya,xa,ha,V,Ma){b(V.opacity);d(V.blending);da=T.positionScreen.x;e=T.positionScreen.y;ga=ja.positionScreen.x;Ba=ja.positionScreen.y;Ja=na.positionScreen.x;Ka=na.positionScreen.y;R(da,e,ga,Ba,Ja,Ka);if(V instanceof
|
|
|
-THREE.MeshBasicMaterial)if(V.map){if(V.map.mapping instanceof THREE.UVMapping){Ua=ha.uvs[0];Qa(da,e,ga,Ba,Ja,Ka,V.map.image,Ua[Y].u,Ua[Y].v,Ua[ya].u,Ua[ya].v,Ua[xa].u,Ua[xa].v)}}else if(V.envMap){if(V.envMap.mapping instanceof THREE.SphericalReflectionMapping){T=za.matrixWorldInverse;K.copy(ha.vertexNormalsWorld[0]);N=(K.x*T.n11+K.y*T.n12+K.z*T.n13)*0.5+0.5;ca=-(K.x*T.n21+K.y*T.n22+K.z*T.n23)*0.5+0.5;K.copy(ha.vertexNormalsWorld[1]);sa=(K.x*T.n11+K.y*T.n12+K.z*T.n13)*0.5+0.5;Ea=-(K.x*T.n21+K.y*T.n22+
|
|
|
-K.z*T.n23)*0.5+0.5;K.copy(ha.vertexNormalsWorld[2]);ia=(K.x*T.n11+K.y*T.n12+K.z*T.n13)*0.5+0.5;ma=-(K.x*T.n21+K.y*T.n22+K.z*T.n23)*0.5+0.5;Qa(da,e,ga,Ba,Ja,Ka,V.envMap.image,N,ca,sa,Ea,ia,ma)}}else V.wireframe?fb(V.color.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Pa(V.color.__styleString);else if(V instanceof THREE.MeshLambertMaterial){if(V.map&&!V.wireframe){if(V.map.mapping instanceof THREE.UVMapping){Ua=ha.uvs[0];Qa(da,e,ga,Ba,Ja,Ka,V.map.image,Ua[Y].u,Ua[Y].v,Ua[ya].u,
|
|
|
-Ua[ya].v,Ua[xa].u,Ua[xa].v)}d(THREE.SubtractiveBlending)}if(w)if(!V.wireframe&&V.shading==THREE.SmoothShading&&ha.vertexNormalsWorld.length==3){Ga.r=la.r=pa.r=P.r;Ga.g=la.g=pa.g=P.g;Ga.b=la.b=pa.b=P.b;Z(Ma,ha.v1.positionWorld,ha.vertexNormalsWorld[0],Ga);Z(Ma,ha.v2.positionWorld,ha.vertexNormalsWorld[1],la);Z(Ma,ha.v3.positionWorld,ha.vertexNormalsWorld[2],pa);Ha.r=(la.r+pa.r)*0.5;Ha.g=(la.g+pa.g)*0.5;Ha.b=(la.b+pa.b)*0.5;Xa=jb(Ga,la,pa,Ha);Qa(da,e,ga,Ba,Ja,Ka,Xa,0,0,1,0,0,1)}else{y.r=P.r;y.g=P.g;
|
|
|
-y.b=P.b;Z(Ma,ha.centroidWorld,ha.normalWorld,y);ra.r=V.color.r*y.r;ra.g=V.color.g*y.g;ra.b=V.color.b*y.b;ra.updateStyleString();V.wireframe?fb(ra.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Pa(ra.__styleString)}else V.wireframe?fb(V.color.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Pa(V.color.__styleString)}else if(V instanceof THREE.MeshDepthMaterial){Ta=za.near;ab=za.far;Ga.r=Ga.g=Ga.b=1-gb(T.positionScreen.z,Ta,ab);la.r=la.g=la.b=1-
|
|
|
-gb(ja.positionScreen.z,Ta,ab);pa.r=pa.g=pa.b=1-gb(na.positionScreen.z,Ta,ab);Ha.r=(la.r+pa.r)*0.5;Ha.g=(la.g+pa.g)*0.5;Ha.b=(la.b+pa.b)*0.5;Xa=jb(Ga,la,pa,Ha);Qa(da,e,ga,Ba,Ja,Ka,Xa,0,0,1,0,0,1)}else if(V instanceof THREE.MeshNormalMaterial){ra.r=bb(ha.normalWorld.x);ra.g=bb(ha.normalWorld.y);ra.b=bb(ha.normalWorld.z);ra.updateStyleString();V.wireframe?fb(ra.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Pa(ra.__styleString)}}function $(T,ja,na,Y,ya,xa,ha,V,Ma){b(V.opacity);
|
|
|
-d(V.blending);if(V.map||V.envMap){Na(T,ja,Y,0,1,3,ha,V,Ma);Na(ya,na,xa,1,2,3,ha,V,Ma)}else{da=T.positionScreen.x;e=T.positionScreen.y;ga=ja.positionScreen.x;Ba=ja.positionScreen.y;Ja=na.positionScreen.x;Ka=na.positionScreen.y;wa=Y.positionScreen.x;ea=Y.positionScreen.y;va=ya.positionScreen.x;Ca=ya.positionScreen.y;ka=xa.positionScreen.x;aa=xa.positionScreen.y;if(V instanceof THREE.MeshBasicMaterial){Sa(da,e,ga,Ba,Ja,Ka,wa,ea);V.wireframe?fb(V.color.__styleString,V.wireframeLinewidth,V.wireframeLinecap,
|
|
|
-V.wireframeLinejoin):Pa(V.color.__styleString)}else if(V instanceof THREE.MeshLambertMaterial)if(w)if(!V.wireframe&&V.shading==THREE.SmoothShading&&ha.vertexNormalsWorld.length==4){Ga.r=la.r=pa.r=Ha.r=P.r;Ga.g=la.g=pa.g=Ha.g=P.g;Ga.b=la.b=pa.b=Ha.b=P.b;Z(Ma,ha.v1.positionWorld,ha.vertexNormalsWorld[0],Ga);Z(Ma,ha.v2.positionWorld,ha.vertexNormalsWorld[1],la);Z(Ma,ha.v4.positionWorld,ha.vertexNormalsWorld[3],pa);Z(Ma,ha.v3.positionWorld,ha.vertexNormalsWorld[2],Ha);Xa=jb(Ga,la,pa,Ha);R(da,e,ga,Ba,
|
|
|
-wa,ea);Qa(da,e,ga,Ba,wa,ea,Xa,0,0,1,0,0,1);R(va,Ca,Ja,Ka,ka,aa);Qa(va,Ca,Ja,Ka,ka,aa,Xa,1,0,1,1,0,1)}else{y.r=P.r;y.g=P.g;y.b=P.b;Z(Ma,ha.centroidWorld,ha.normalWorld,y);ra.r=V.color.r*y.r;ra.g=V.color.g*y.g;ra.b=V.color.b*y.b;ra.updateStyleString();Sa(da,e,ga,Ba,Ja,Ka,wa,ea);V.wireframe?fb(ra.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Pa(ra.__styleString)}else{Sa(da,e,ga,Ba,Ja,Ka,wa,ea);V.wireframe?fb(V.color.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):
|
|
|
-Pa(V.color.__styleString)}else if(V instanceof THREE.MeshNormalMaterial){ra.r=bb(ha.normalWorld.x);ra.g=bb(ha.normalWorld.y);ra.b=bb(ha.normalWorld.z);ra.updateStyleString();Sa(da,e,ga,Ba,Ja,Ka,wa,ea);V.wireframe?fb(ra.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Pa(ra.__styleString)}else if(V instanceof THREE.MeshDepthMaterial){Ta=za.near;ab=za.far;Ga.r=Ga.g=Ga.b=1-gb(T.positionScreen.z,Ta,ab);la.r=la.g=la.b=1-gb(ja.positionScreen.z,Ta,ab);pa.r=pa.g=pa.b=1-gb(Y.positionScreen.z,
|
|
|
-Ta,ab);Ha.r=Ha.g=Ha.b=1-gb(na.positionScreen.z,Ta,ab);Xa=jb(Ga,la,pa,Ha);R(da,e,ga,Ba,wa,ea);Qa(da,e,ga,Ba,wa,ea,Xa,0,0,1,0,0,1);R(va,Ca,Ja,Ka,ka,aa);Qa(va,Ca,Ja,Ka,ka,aa,Xa,1,0,1,1,0,1)}}}function R(T,ja,na,Y,ya,xa){o.beginPath();o.moveTo(T,ja);o.lineTo(na,Y);o.lineTo(ya,xa);o.lineTo(T,ja);o.closePath()}function Sa(T,ja,na,Y,ya,xa,ha,V){o.beginPath();o.moveTo(T,ja);o.lineTo(na,Y);o.lineTo(ya,xa);o.lineTo(ha,V);o.lineTo(T,ja);o.closePath()}function fb(T,ja,na,Y){if(G!=ja)o.lineWidth=G=ja;if(U!=na)o.lineCap=
|
|
|
-U=na;if(D!=Y)o.lineJoin=D=Y;c(T);o.stroke();z.inflate(ja*2)}function Pa(T){if(I!=T)o.fillStyle=I=T;o.fill()}function Qa(T,ja,na,Y,ya,xa,ha,V,Ma,Ya,Wa,kb,Za){var hb,ib;hb=ha.width-1;ib=ha.height-1;V*=hb;Ma*=ib;Ya*=hb;Wa*=ib;kb*=hb;Za*=ib;na-=T;Y-=ja;ya-=T;xa-=ja;Ya-=V;Wa-=Ma;kb-=V;Za-=Ma;hb=Ya*Za-kb*Wa;if(hb!=0){ib=1/hb;hb=(Za*na-Wa*ya)*ib;Wa=(Za*Y-Wa*xa)*ib;na=(Ya*ya-kb*na)*ib;Y=(Ya*xa-kb*Y)*ib;T=T-hb*V-na*Ma;ja=ja-Wa*V-Y*Ma;o.save();o.transform(hb,Wa,na,Y,T,ja);o.clip();o.drawImage(ha,0,0);o.restore()}}
|
|
|
-function jb(T,ja,na,Y){var ya=~~(T.r*255),xa=~~(T.g*255);T=~~(T.b*255);var ha=~~(ja.r*255),V=~~(ja.g*255);ja=~~(ja.b*255);var Ma=~~(na.r*255),Ya=~~(na.g*255);na=~~(na.b*255);var Wa=~~(Y.r*255),kb=~~(Y.g*255);Y=~~(Y.b*255);qa[0]=ya<0?0:ya>255?255:ya;qa[1]=xa<0?0:xa>255?255:xa;qa[2]=T<0?0:T>255?255:T;qa[4]=ha<0?0:ha>255?255:ha;qa[5]=V<0?0:V>255?255:V;qa[6]=ja<0?0:ja>255?255:ja;qa[8]=Ma<0?0:Ma>255?255:Ma;qa[9]=Ya<0?0:Ya>255?255:Ya;qa[10]=na<0?0:na>255?255:na;qa[12]=Wa<0?0:Wa>255?255:Wa;qa[13]=kb<0?0:
|
|
|
-kb>255?255:kb;qa[14]=Y<0?0:Y>255?255:Y;L.putImageData(X,0,0);Fa.drawImage(E,0,0);return W}function gb(T,ja,na){T=(T-ja)/(na-ja);return T*T*(3-2*T)}function bb(T){T=(T+1)*0.5;return T<0?0:T>1?1:T}function cb(T,ja){var na=ja.x-T.x,Y=ja.y-T.y,ya=1/Math.sqrt(na*na+Y*Y);na*=ya;Y*=ya;ja.x+=na;ja.y+=Y;T.x-=na;T.y-=Y}var Oa,eb,Da,S,Ra,Va,lb,$a;this.autoClear?this.clear():o.setTransform(1,0,0,-1,n,p);f=g.projectScene(ta,za,this.sortElements);(w=ta.lights.length>0)&&db(ta);Oa=0;for(eb=f.length;Oa<eb;Oa++){Da=
|
|
|
-f[Oa];z.empty();if(Da instanceof THREE.RenderableParticle){M=Da;M.x*=n;M.y*=p;S=0;for(Ra=Da.materials.length;S<Ra;){$a=Da.materials[S++];$a.opacity!=0&&fa(M,Da,$a,ta)}}else if(Da instanceof THREE.RenderableLine){M=Da.v1;O=Da.v2;M.positionScreen.x*=n;M.positionScreen.y*=p;O.positionScreen.x*=n;O.positionScreen.y*=p;z.addPoint(M.positionScreen.x,M.positionScreen.y);z.addPoint(O.positionScreen.x,O.positionScreen.y);if(m.instersects(z)){S=0;for(Ra=Da.materials.length;S<Ra;){$a=Da.materials[S++];$a.opacity!=
|
|
|
-0&&oa(M,O,Da,$a,ta)}}}else if(Da instanceof THREE.RenderableFace3){M=Da.v1;O=Da.v2;Q=Da.v3;M.positionScreen.x*=n;M.positionScreen.y*=p;O.positionScreen.x*=n;O.positionScreen.y*=p;Q.positionScreen.x*=n;Q.positionScreen.y*=p;if(Da.overdraw){cb(M.positionScreen,O.positionScreen);cb(O.positionScreen,Q.positionScreen);cb(Q.positionScreen,M.positionScreen)}z.add3Points(M.positionScreen.x,M.positionScreen.y,O.positionScreen.x,O.positionScreen.y,Q.positionScreen.x,Q.positionScreen.y);if(m.instersects(z)){S=
|
|
|
-0;for(Ra=Da.meshMaterials.length;S<Ra;){$a=Da.meshMaterials[S++];if($a instanceof THREE.MeshFaceMaterial){Va=0;for(lb=Da.faceMaterials.length;Va<lb;)($a=Da.faceMaterials[Va++])&&$a.opacity!=0&&Na(M,O,Q,0,1,2,Da,$a,ta)}else $a.opacity!=0&&Na(M,O,Q,0,1,2,Da,$a,ta)}}}else if(Da instanceof THREE.RenderableFace4){M=Da.v1;O=Da.v2;Q=Da.v3;Ia=Da.v4;M.positionScreen.x*=n;M.positionScreen.y*=p;O.positionScreen.x*=n;O.positionScreen.y*=p;Q.positionScreen.x*=n;Q.positionScreen.y*=p;Ia.positionScreen.x*=n;Ia.positionScreen.y*=
|
|
|
-p;ua.positionScreen.copy(O.positionScreen);Aa.positionScreen.copy(Ia.positionScreen);if(Da.overdraw){cb(M.positionScreen,O.positionScreen);cb(O.positionScreen,Ia.positionScreen);cb(Ia.positionScreen,M.positionScreen);cb(Q.positionScreen,ua.positionScreen);cb(Q.positionScreen,Aa.positionScreen)}z.addPoint(M.positionScreen.x,M.positionScreen.y);z.addPoint(O.positionScreen.x,O.positionScreen.y);z.addPoint(Q.positionScreen.x,Q.positionScreen.y);z.addPoint(Ia.positionScreen.x,Ia.positionScreen.y);if(m.instersects(z)){S=
|
|
|
-0;for(Ra=Da.meshMaterials.length;S<Ra;){$a=Da.meshMaterials[S++];if($a instanceof THREE.MeshFaceMaterial){Va=0;for(lb=Da.faceMaterials.length;Va<lb;)($a=Da.faceMaterials[Va++])&&$a.opacity!=0&&$(M,O,Q,Ia,ua,Aa,Da,$a,ta)}else $a.opacity!=0&&$(M,O,Q,Ia,ua,Aa,Da,$a,ta)}}}B.addRectangle(z)}o.setTransform(1,0,0,1,0,0)}};
|
|
|
-THREE.SVGRenderer=function(){function b(wa,ea,va){var Ca,ka,aa,ra;Ca=0;for(ka=wa.lights.length;Ca<ka;Ca++){aa=wa.lights[Ca];if(aa instanceof THREE.DirectionalLight){ra=ea.normalWorld.dot(aa.position)*aa.intensity;if(ra>0){va.r+=aa.color.r*ra;va.g+=aa.color.g*ra;va.b+=aa.color.b*ra}}else if(aa instanceof THREE.PointLight){Aa.sub(aa.position,ea.centroidWorld);Aa.normalize();ra=ea.normalWorld.dot(Aa)*aa.intensity;if(ra>0){va.r+=aa.color.r*ra;va.g+=aa.color.g*ra;va.b+=aa.color.b*ra}}}}function d(wa,ea,
|
|
|
-va,Ca,ka,aa){ga=f(Ba++);ga.setAttribute("d","M "+wa.positionScreen.x+" "+wa.positionScreen.y+" L "+ea.positionScreen.x+" "+ea.positionScreen.y+" L "+va.positionScreen.x+","+va.positionScreen.y+"z");if(ka instanceof THREE.MeshBasicMaterial)D.__styleString=ka.color.__styleString;else if(ka instanceof THREE.MeshLambertMaterial)if(U){M.r=O.r;M.g=O.g;M.b=O.b;b(aa,Ca,M);D.r=ka.color.r*M.r;D.g=ka.color.g*M.g;D.b=ka.color.b*M.b;D.updateStyleString()}else D.__styleString=ka.color.__styleString;else if(ka instanceof
|
|
|
-THREE.MeshDepthMaterial){ua=1-ka.__2near/(ka.__farPlusNear-Ca.z*ka.__farMinusNear);D.setRGB(ua,ua,ua)}else ka instanceof THREE.MeshNormalMaterial&&D.setRGB(g(Ca.normalWorld.x),g(Ca.normalWorld.y),g(Ca.normalWorld.z));ka.wireframe?ga.setAttribute("style","fill: none; stroke: "+D.__styleString+"; stroke-width: "+ka.wireframeLinewidth+"; stroke-opacity: "+ka.opacity+"; stroke-linecap: "+ka.wireframeLinecap+"; stroke-linejoin: "+ka.wireframeLinejoin):ga.setAttribute("style","fill: "+D.__styleString+"; fill-opacity: "+
|
|
|
-ka.opacity);k.appendChild(ga)}function c(wa,ea,va,Ca,ka,aa,ra){ga=f(Ba++);ga.setAttribute("d","M "+wa.positionScreen.x+" "+wa.positionScreen.y+" L "+ea.positionScreen.x+" "+ea.positionScreen.y+" L "+va.positionScreen.x+","+va.positionScreen.y+" L "+Ca.positionScreen.x+","+Ca.positionScreen.y+"z");if(aa instanceof THREE.MeshBasicMaterial)D.__styleString=aa.color.__styleString;else if(aa instanceof THREE.MeshLambertMaterial)if(U){M.r=O.r;M.g=O.g;M.b=O.b;b(ra,ka,M);D.r=aa.color.r*M.r;D.g=aa.color.g*
|
|
|
-M.g;D.b=aa.color.b*M.b;D.updateStyleString()}else D.__styleString=aa.color.__styleString;else if(aa instanceof THREE.MeshDepthMaterial){ua=1-aa.__2near/(aa.__farPlusNear-ka.z*aa.__farMinusNear);D.setRGB(ua,ua,ua)}else aa instanceof THREE.MeshNormalMaterial&&D.setRGB(g(ka.normalWorld.x),g(ka.normalWorld.y),g(ka.normalWorld.z));aa.wireframe?ga.setAttribute("style","fill: none; stroke: "+D.__styleString+"; stroke-width: "+aa.wireframeLinewidth+"; stroke-opacity: "+aa.opacity+"; stroke-linecap: "+aa.wireframeLinecap+
|
|
|
-"; stroke-linejoin: "+aa.wireframeLinejoin):ga.setAttribute("style","fill: "+D.__styleString+"; fill-opacity: "+aa.opacity);k.appendChild(ga)}function f(wa){if(da[wa]==null){da[wa]=document.createElementNS("http://www.w3.org/2000/svg","path");Ka==0&&da[wa].setAttribute("shape-rendering","crispEdges")}return da[wa]}function g(wa){return wa<0?Math.min((1+wa)*0.5,0.5):0.5+Math.min(wa*0.5,0.5)}var h=null,j=new THREE.Projector,k=document.createElementNS("http://www.w3.org/2000/svg","svg"),n,p,o,x,A,t,
|
|
|
-C,F,I=new THREE.Rectangle,G=new THREE.Rectangle,U=!1,D=new THREE.Color(16777215),M=new THREE.Color(16777215),O=new THREE.Color(0),Q=new THREE.Color(0),Ia=new THREE.Color(0),ua,Aa=new THREE.Vector3,da=[],e=[],ga,Ba,Ja,Ka=1;this.domElement=k;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setQuality=function(wa){switch(wa){case "high":Ka=1;break;case "low":Ka=0}};this.setSize=function(wa,ea){n=wa;p=ea;o=n/2;x=p/2;k.setAttribute("viewBox",-o+" "+-x+" "+n+" "+p);k.setAttribute("width",
|
|
|
-n);k.setAttribute("height",p);I.set(-o,-x,o,x)};this.clear=function(){for(;k.childNodes.length>0;)k.removeChild(k.childNodes[0])};this.render=function(wa,ea){var va,Ca,ka,aa,ra,Ga,la,pa;this.autoClear&&this.clear();h=j.projectScene(wa,ea,this.sortElements);Ja=Ba=0;if(U=wa.lights.length>0){la=wa.lights;O.setRGB(0,0,0);Q.setRGB(0,0,0);Ia.setRGB(0,0,0);va=0;for(Ca=la.length;va<Ca;va++){ka=la[va];aa=ka.color;if(ka instanceof THREE.AmbientLight){O.r+=aa.r;O.g+=aa.g;O.b+=aa.b}else if(ka instanceof THREE.DirectionalLight){Q.r+=
|
|
|
-aa.r;Q.g+=aa.g;Q.b+=aa.b}else if(ka instanceof THREE.PointLight){Ia.r+=aa.r;Ia.g+=aa.g;Ia.b+=aa.b}}}va=0;for(Ca=h.length;va<Ca;va++){la=h[va];G.empty();if(la instanceof THREE.RenderableParticle){A=la;A.x*=o;A.y*=-x;ka=0;for(aa=la.materials.length;ka<aa;)ka++}else if(la instanceof THREE.RenderableLine){A=la.v1;t=la.v2;A.positionScreen.x*=o;A.positionScreen.y*=-x;t.positionScreen.x*=o;t.positionScreen.y*=-x;G.addPoint(A.positionScreen.x,A.positionScreen.y);G.addPoint(t.positionScreen.x,t.positionScreen.y);
|
|
|
-if(I.instersects(G)){ka=0;for(aa=la.materials.length;ka<aa;)if((pa=la.materials[ka++])&&pa.opacity!=0){ra=A;Ga=t;var Ha=Ja++;if(e[Ha]==null){e[Ha]=document.createElementNS("http://www.w3.org/2000/svg","line");Ka==0&&e[Ha].setAttribute("shape-rendering","crispEdges")}ga=e[Ha];ga.setAttribute("x1",ra.positionScreen.x);ga.setAttribute("y1",ra.positionScreen.y);ga.setAttribute("x2",Ga.positionScreen.x);ga.setAttribute("y2",Ga.positionScreen.y);if(pa instanceof THREE.LineBasicMaterial){D.__styleString=
|
|
|
-pa.color.__styleString;ga.setAttribute("style","fill: none; stroke: "+D.__styleString+"; stroke-width: "+pa.linewidth+"; stroke-opacity: "+pa.opacity+"; stroke-linecap: "+pa.linecap+"; stroke-linejoin: "+pa.linejoin);k.appendChild(ga)}}}}else if(la instanceof THREE.RenderableFace3){A=la.v1;t=la.v2;C=la.v3;A.positionScreen.x*=o;A.positionScreen.y*=-x;t.positionScreen.x*=o;t.positionScreen.y*=-x;C.positionScreen.x*=o;C.positionScreen.y*=-x;G.addPoint(A.positionScreen.x,A.positionScreen.y);G.addPoint(t.positionScreen.x,
|
|
|
-t.positionScreen.y);G.addPoint(C.positionScreen.x,C.positionScreen.y);if(I.instersects(G)){ka=0;for(aa=la.meshMaterials.length;ka<aa;){pa=la.meshMaterials[ka++];if(pa instanceof THREE.MeshFaceMaterial){ra=0;for(Ga=la.faceMaterials.length;ra<Ga;)(pa=la.faceMaterials[ra++])&&pa.opacity!=0&&d(A,t,C,la,pa,wa)}else pa&&pa.opacity!=0&&d(A,t,C,la,pa,wa)}}}else if(la instanceof THREE.RenderableFace4){A=la.v1;t=la.v2;C=la.v3;F=la.v4;A.positionScreen.x*=o;A.positionScreen.y*=-x;t.positionScreen.x*=o;t.positionScreen.y*=
|
|
|
--x;C.positionScreen.x*=o;C.positionScreen.y*=-x;F.positionScreen.x*=o;F.positionScreen.y*=-x;G.addPoint(A.positionScreen.x,A.positionScreen.y);G.addPoint(t.positionScreen.x,t.positionScreen.y);G.addPoint(C.positionScreen.x,C.positionScreen.y);G.addPoint(F.positionScreen.x,F.positionScreen.y);if(I.instersects(G)){ka=0;for(aa=la.meshMaterials.length;ka<aa;){pa=la.meshMaterials[ka++];if(pa instanceof THREE.MeshFaceMaterial){ra=0;for(Ga=la.faceMaterials.length;ra<Ga;)(pa=la.faceMaterials[ra++])&&pa.opacity!=
|
|
|
-0&&c(A,t,C,F,la,pa,wa)}else pa&&pa.opacity!=0&&c(A,t,C,F,la,pa,wa)}}}}}};
|
|
|
+THREE.Projector=function(){function b(){var e=n[k]=n[k]||new THREE.RenderableVertex;k++;return e}function d(e,ea){return ea.z-e.z}function c(e,ea){var za=0,Ha=1,Ia=e.z+e.w,ua=ea.z+ea.w,ca=-e.z+e.w,ta=-ea.z+ea.w;if(Ia>=0&&ua>=0&&ca>=0&&ta>=0)return!0;else if(Ia<0&&ua<0||ca<0&&ta<0)return!1;else{if(Ia<0)za=Math.max(za,Ia/(Ia-ua));else ua<0&&(Ha=Math.min(Ha,Ia/(Ia-ua)));if(ca<0)za=Math.max(za,ca/(ca-ta));else ta<0&&(Ha=Math.min(Ha,ca/(ca-ta)));if(Ha<za)return!1;else{e.lerpSelf(ea,za);ea.lerpSelf(e,1-
|
|
|
+Ha);return!0}}}var f,g,h=[],j,k,n=[],p,o,t=[],y,v=[],B,C,E=[],J,T,z=[],K=new THREE.Vector4,L=new THREE.Vector4,M=new THREE.Matrix4,Ga=new THREE.Matrix4,sa=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],ya=new THREE.Vector4,aa=new THREE.Vector4;this.projectVector=function(e,ea){M.multiply(ea.projectionMatrix,ea.matrixWorldInverse);M.multiplyVector3(e);return e};this.unprojectVector=function(e,ea){M.multiply(ea.matrixWorld,THREE.Matrix4.makeInvert(ea.projectionMatrix));
|
|
|
+M.multiplyVector3(e);return e};this.projectObjects=function(e,ea,za){ea=[];var Ha,Ia,ua;g=0;Ia=e.objects;e=0;for(Ha=Ia.length;e<Ha;e++){ua=Ia[e];var ca;if(!(ca=!ua.visible))if(ca=ua instanceof THREE.Mesh){a:{ca=void 0;for(var ta=ua.matrixWorld,Aa=-ua.geometry.boundingSphere.radius*Math.max(ua.scale.x,Math.max(ua.scale.y,ua.scale.z)),ia=0;ia<6;ia++){ca=sa[ia].x*ta.n14+sa[ia].y*ta.n24+sa[ia].z*ta.n34+sa[ia].w;if(ca<=Aa){ca=!1;break a}}ca=!0}ca=!ca}if(!ca){ca=h[g]=h[g]||new THREE.RenderableObject;g++;
|
|
|
+f=ca;K.copy(ua.position);M.multiplyVector3(K);f.object=ua;f.z=K.z;ea.push(f)}}za&&ea.sort(d);return ea};this.projectScene=function(e,ea,za){var Ha=[],Ia=ea.near,ua=ea.far,ca,ta,Aa,ia,Z,pa,Ea,ja,na,Fa,Ra,Za,Va,Sa,N,$,qa;T=C=y=o=0;ea.matrixAutoUpdate&&ea.updateMatrix();e.update(undefined,!1,ea);M.multiply(ea.projectionMatrix,ea.matrixWorldInverse);sa[0].set(M.n41-M.n11,M.n42-M.n12,M.n43-M.n13,M.n44-M.n14);sa[1].set(M.n41+M.n11,M.n42+M.n12,M.n43+M.n13,M.n44+M.n14);sa[2].set(M.n41+M.n21,M.n42+M.n22,M.n43+
|
|
|
+M.n23,M.n44+M.n24);sa[3].set(M.n41-M.n21,M.n42-M.n22,M.n43-M.n23,M.n44-M.n24);sa[4].set(M.n41-M.n31,M.n42-M.n32,M.n43-M.n33,M.n44-M.n34);sa[5].set(M.n41+M.n31,M.n42+M.n32,M.n43+M.n33,M.n44+M.n34);for(ca=0;ca<6;ca++){na=sa[ca];na.divideScalar(Math.sqrt(na.x*na.x+na.y*na.y+na.z*na.z))}na=this.projectObjects(e,ea,!0);e=0;for(ca=na.length;e<ca;e++){Fa=na[e].object;if(Fa.visible){Ra=Fa.matrixWorld;Za=Fa.matrixRotationWorld;Va=Fa.materials;Sa=Fa.overdraw;k=0;if(Fa instanceof THREE.Mesh){N=Fa.geometry;ia=
|
|
|
+N.vertices;$=N.faces;N=N.faceVertexUvs;ta=0;for(Aa=ia.length;ta<Aa;ta++){j=b();j.positionWorld.copy(ia[ta].position);Ra.multiplyVector3(j.positionWorld);j.positionScreen.copy(j.positionWorld);M.multiplyVector4(j.positionScreen);j.positionScreen.x/=j.positionScreen.w;j.positionScreen.y/=j.positionScreen.w;j.visible=j.positionScreen.z>Ia&&j.positionScreen.z<ua}ia=0;for(ta=$.length;ia<ta;ia++){Aa=$[ia];if(Aa instanceof THREE.Face3){Z=n[Aa.a];pa=n[Aa.b];Ea=n[Aa.c];if(Z.visible&&pa.visible&&Ea.visible&&
|
|
|
+(Fa.doubleSided||Fa.flipSided!=(Ea.positionScreen.x-Z.positionScreen.x)*(pa.positionScreen.y-Z.positionScreen.y)-(Ea.positionScreen.y-Z.positionScreen.y)*(pa.positionScreen.x-Z.positionScreen.x)<0)){ja=t[o]=t[o]||new THREE.RenderableFace3;o++;p=ja;p.v1.copy(Z);p.v2.copy(pa);p.v3.copy(Ea)}else continue}else if(Aa instanceof THREE.Face4){Z=n[Aa.a];pa=n[Aa.b];Ea=n[Aa.c];ja=n[Aa.d];if(Z.visible&&pa.visible&&Ea.visible&&ja.visible&&(Fa.doubleSided||Fa.flipSided!=((ja.positionScreen.x-Z.positionScreen.x)*
|
|
|
+(pa.positionScreen.y-Z.positionScreen.y)-(ja.positionScreen.y-Z.positionScreen.y)*(pa.positionScreen.x-Z.positionScreen.x)<0||(pa.positionScreen.x-Ea.positionScreen.x)*(ja.positionScreen.y-Ea.positionScreen.y)-(pa.positionScreen.y-Ea.positionScreen.y)*(ja.positionScreen.x-Ea.positionScreen.x)<0))){qa=v[y]=v[y]||new THREE.RenderableFace4;y++;p=qa;p.v1.copy(Z);p.v2.copy(pa);p.v3.copy(Ea);p.v4.copy(ja)}else continue}p.normalWorld.copy(Aa.normal);Za.multiplyVector3(p.normalWorld);p.centroidWorld.copy(Aa.centroid);
|
|
|
+Ra.multiplyVector3(p.centroidWorld);p.centroidScreen.copy(p.centroidWorld);M.multiplyVector3(p.centroidScreen);Ea=Aa.vertexNormals;Z=0;for(pa=Ea.length;Z<pa;Z++){ja=p.vertexNormalsWorld[Z];ja.copy(Ea[Z]);Za.multiplyVector3(ja)}Z=0;for(pa=N.length;Z<pa;Z++)if(qa=N[Z][ia]){Ea=0;for(ja=qa.length;Ea<ja;Ea++)p.uvs[Z][Ea]=qa[Ea]}p.meshMaterials=Va;p.faceMaterials=Aa.materials;p.overdraw=Sa;p.z=p.centroidScreen.z;Ha.push(p)}}else if(Fa instanceof THREE.Line){Ga.multiply(M,Ra);ia=Fa.geometry.vertices;Z=b();
|
|
|
+Z.positionScreen.copy(ia[0].position);Ga.multiplyVector4(Z.positionScreen);ta=1;for(Aa=ia.length;ta<Aa;ta++){Z=b();Z.positionScreen.copy(ia[ta].position);Ga.multiplyVector4(Z.positionScreen);pa=n[k-2];ya.copy(Z.positionScreen);aa.copy(pa.positionScreen);if(c(ya,aa)){ya.multiplyScalar(1/ya.w);aa.multiplyScalar(1/aa.w);Ra=E[C]=E[C]||new THREE.RenderableLine;C++;B=Ra;B.v1.positionScreen.copy(ya);B.v2.positionScreen.copy(aa);B.z=Math.max(ya.z,aa.z);B.materials=Fa.materials;Ha.push(B)}}}else if(Fa instanceof
|
|
|
+THREE.Particle){L.set(Fa.position.x,Fa.position.y,Fa.position.z,1);M.multiplyVector4(L);L.z/=L.w;if(L.z>0&&L.z<1){Ra=z[T]=z[T]||new THREE.RenderableParticle;T++;J=Ra;J.x=L.x/L.w;J.y=L.y/L.w;J.z=L.z;J.rotation=Fa.rotation.z;J.scale.x=Fa.scale.x*Math.abs(J.x-(L.x+ea.projectionMatrix.n11)/(L.w+ea.projectionMatrix.n14));J.scale.y=Fa.scale.y*Math.abs(J.y-(L.y+ea.projectionMatrix.n22)/(L.w+ea.projectionMatrix.n24));J.materials=Fa.materials;Ha.push(J)}}}}za&&Ha.sort(d);return Ha}};
|
|
|
+THREE.DOMRenderer=function(){THREE.Renderer.call(this);var b=null,d=new THREE.Projector,c,f,g,h;this.domElement=document.createElement("div");this.setSize=function(j,k){c=j;f=k;g=c/2;h=f/2};this.render=function(j,k){var n,p,o,t,y,v,B,C;b=d.projectScene(j,k);n=0;for(p=b.length;n<p;n++){y=b[n];if(y instanceof THREE.RenderableParticle){B=y.x*g+g;C=y.y*h+h;o=0;for(t=y.material.length;o<t;o++){v=y.material[o];if(v instanceof THREE.ParticleDOMMaterial){v=v.domElement;v.style.left=B+"px";v.style.top=C+"px"}}}}}};
|
|
|
+THREE.CanvasRenderer=function(){function b(ra){if(v!=ra)o.globalAlpha=v=ra}function d(ra){if(B!=ra){switch(ra){case THREE.NormalBlending:o.globalCompositeOperation="source-over";break;case THREE.AdditiveBlending:o.globalCompositeOperation="lighter";break;case THREE.SubtractiveBlending:o.globalCompositeOperation="darker"}B=ra}}function c(ra){if(C!=ra)o.strokeStyle=C=ra}var f=null,g=new THREE.Projector,h=document.createElement("canvas"),j,k,n,p,o=h.getContext("2d"),t=new THREE.Color(0),y=0,v=1,B=0,
|
|
|
+C=null,E=null,J=null,T=null,z=null,K,L,M,Ga,sa=new THREE.RenderableVertex,ya=new THREE.RenderableVertex,aa,e,ea,za,Ha,Ia,ua,ca,ta,Aa,ia,Z,pa=new THREE.Color,Ea=new THREE.Color,ja=new THREE.Color,na=new THREE.Color,Fa=new THREE.Color,Ra,Za,Va,Sa,N,$,qa,Ca,ga,ka,m=new THREE.Rectangle,A=new THREE.Rectangle,x=new THREE.Rectangle,u=!1,w=new THREE.Color,O=new THREE.Color,F=new THREE.Color,G=new THREE.Color,H=new THREE.Vector3,D,I,V,oa,U,Da,Ja=16;D=document.createElement("canvas");D.width=D.height=2;I=D.getContext("2d");
|
|
|
+I.fillStyle="rgba(0,0,0,1)";I.fillRect(0,0,2,2);V=I.getImageData(0,0,2,2);oa=V.data;U=document.createElement("canvas");U.width=U.height=Ja;Da=U.getContext("2d");Da.translate(-Ja/2,-Ja/2);Da.scale(Ja,Ja);Ja--;this.domElement=h;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setSize=function(ra,xa){j=ra;k=xa;n=j/2;p=k/2;h.width=j;h.height=k;m.set(-n,-p,n,p);v=1;B=0;z=T=J=E=C=null};this.setClearColor=function(ra,xa){t=ra;y=xa};this.setClearColorHex=function(ra,xa){t.setHex(ra);y=xa};
|
|
|
+this.clear=function(){o.setTransform(1,0,0,-1,n,p);if(!A.isEmpty()){A.inflate(1);A.minSelf(m);if(t.hex==0&&y==0)o.clearRect(A.getX(),A.getY(),A.getWidth(),A.getHeight());else{d(THREE.NormalBlending);b(1);o.fillStyle="rgba("+Math.floor(t.r*255)+","+Math.floor(t.g*255)+","+Math.floor(t.b*255)+","+y+")";o.fillRect(A.getX(),A.getY(),A.getWidth(),A.getHeight())}A.empty()}};this.render=function(ra,xa){function bb(R){var ha,la,W,wa=R.lights;O.setRGB(0,0,0);F.setRGB(0,0,0);G.setRGB(0,0,0);R=0;for(ha=wa.length;R<
|
|
|
+ha;R++){la=wa[R];W=la.color;if(la instanceof THREE.AmbientLight){O.r+=W.r;O.g+=W.g;O.b+=W.b}else if(la instanceof THREE.DirectionalLight){F.r+=W.r;F.g+=W.g;F.b+=W.b}else if(la instanceof THREE.PointLight){G.r+=W.r;G.g+=W.g;G.b+=W.b}}}function X(R,ha,la,W){var wa,va,fa,S,Ka=R.lights;R=0;for(wa=Ka.length;R<wa;R++){va=Ka[R];fa=va.color;if(va instanceof THREE.DirectionalLight){S=la.dot(va.position);if(!(S<=0)){S*=va.intensity;W.r+=fa.r*S;W.g+=fa.g*S;W.b+=fa.b*S}}else if(va instanceof THREE.PointLight){S=
|
|
|
+la.dot(H.sub(va.position,ha).normalize());if(!(S<=0)){S*=va.distance==0?1:1-Math.min(ha.distanceTo(va.position)/va.distance,1);if(S!=0){S*=va.intensity;W.r+=fa.r*S;W.g+=fa.g*S;W.b+=fa.b*S}}}}}function da(R,ha,la){b(la.opacity);d(la.blending);var W,wa,va,fa,S,Ka;if(la instanceof THREE.ParticleBasicMaterial){if(la.map){fa=la.map.image;S=fa.width>>1;Ka=fa.height>>1;la=ha.scale.x*n;va=ha.scale.y*p;W=la*S;wa=va*Ka;x.set(R.x-W,R.y-wa,R.x+W,R.y+wa);if(m.instersects(x)){o.save();o.translate(R.x,R.y);o.rotate(-ha.rotation);
|
|
|
+o.scale(la,-va);o.translate(-S,-Ka);o.drawImage(fa,0,0);o.restore()}}}else if(la instanceof THREE.ParticleCanvasMaterial){W=ha.scale.x*n;wa=ha.scale.y*p;x.set(R.x-W,R.y-wa,R.x+W,R.y+wa);if(m.instersects(x)){c(la.color.__styleString);va=la.color.__styleString;if(E!=va)o.fillStyle=E=va;o.save();o.translate(R.x,R.y);o.rotate(-ha.rotation);o.scale(W,wa);la.program(o);o.restore()}}}function ma(R,ha,la,W){b(W.opacity);d(W.blending);o.beginPath();o.moveTo(R.positionScreen.x,R.positionScreen.y);o.lineTo(ha.positionScreen.x,
|
|
|
+ha.positionScreen.y);o.closePath();if(W instanceof THREE.LineBasicMaterial){pa.__styleString=W.color.__styleString;R=W.linewidth;if(J!=R)o.lineWidth=J=R;R=W.linecap;if(T!=R)o.lineCap=T=R;R=W.linejoin;if(z!=R)o.lineJoin=z=R;c(pa.__styleString);o.stroke();x.inflate(W.linewidth*2)}}function La(R,ha,la,W,wa,va,fa,S,Ka){b(S.opacity);d(S.blending);aa=R.positionScreen.x;e=R.positionScreen.y;ea=ha.positionScreen.x;za=ha.positionScreen.y;Ha=la.positionScreen.x;Ia=la.positionScreen.y;P(aa,e,ea,za,Ha,Ia);if(S instanceof
|
|
|
+THREE.MeshBasicMaterial)if(S.map){if(S.map.mapping instanceof THREE.UVMapping){Sa=fa.uvs[0];Oa(aa,e,ea,za,Ha,Ia,S.map.image,Sa[W].u,Sa[W].v,Sa[wa].u,Sa[wa].v,Sa[va].u,Sa[va].v)}}else if(S.envMap){if(S.envMap.mapping instanceof THREE.SphericalReflectionMapping){R=xa.matrixWorldInverse;H.copy(fa.vertexNormalsWorld[0]);N=(H.x*R.n11+H.y*R.n12+H.z*R.n13)*0.5+0.5;$=-(H.x*R.n21+H.y*R.n22+H.z*R.n23)*0.5+0.5;H.copy(fa.vertexNormalsWorld[1]);qa=(H.x*R.n11+H.y*R.n12+H.z*R.n13)*0.5+0.5;Ca=-(H.x*R.n21+H.y*R.n22+
|
|
|
+H.z*R.n23)*0.5+0.5;H.copy(fa.vertexNormalsWorld[2]);ga=(H.x*R.n11+H.y*R.n12+H.z*R.n13)*0.5+0.5;ka=-(H.x*R.n21+H.y*R.n22+H.z*R.n23)*0.5+0.5;Oa(aa,e,ea,za,Ha,Ia,S.envMap.image,N,$,qa,Ca,ga,ka)}}else S.wireframe?db(S.color.__styleString,S.wireframeLinewidth,S.wireframeLinecap,S.wireframeLinejoin):Na(S.color.__styleString);else if(S instanceof THREE.MeshLambertMaterial){if(S.map&&!S.wireframe){if(S.map.mapping instanceof THREE.UVMapping){Sa=fa.uvs[0];Oa(aa,e,ea,za,Ha,Ia,S.map.image,Sa[W].u,Sa[W].v,Sa[wa].u,
|
|
|
+Sa[wa].v,Sa[va].u,Sa[va].v)}d(THREE.SubtractiveBlending)}if(u)if(!S.wireframe&&S.shading==THREE.SmoothShading&&fa.vertexNormalsWorld.length==3){Ea.r=ja.r=na.r=O.r;Ea.g=ja.g=na.g=O.g;Ea.b=ja.b=na.b=O.b;X(Ka,fa.v1.positionWorld,fa.vertexNormalsWorld[0],Ea);X(Ka,fa.v2.positionWorld,fa.vertexNormalsWorld[1],ja);X(Ka,fa.v3.positionWorld,fa.vertexNormalsWorld[2],na);Fa.r=(ja.r+na.r)*0.5;Fa.g=(ja.g+na.g)*0.5;Fa.b=(ja.b+na.b)*0.5;Va=hb(Ea,ja,na,Fa);Oa(aa,e,ea,za,Ha,Ia,Va,0,0,1,0,0,1)}else{w.r=O.r;w.g=O.g;
|
|
|
+w.b=O.b;X(Ka,fa.centroidWorld,fa.normalWorld,w);pa.r=S.color.r*w.r;pa.g=S.color.g*w.g;pa.b=S.color.b*w.b;pa.updateStyleString();S.wireframe?db(pa.__styleString,S.wireframeLinewidth,S.wireframeLinecap,S.wireframeLinejoin):Na(pa.__styleString)}else S.wireframe?db(S.color.__styleString,S.wireframeLinewidth,S.wireframeLinecap,S.wireframeLinejoin):Na(S.color.__styleString)}else if(S instanceof THREE.MeshDepthMaterial){Ra=xa.near;Za=xa.far;Ea.r=Ea.g=Ea.b=1-eb(R.positionScreen.z,Ra,Za);ja.r=ja.g=ja.b=1-
|
|
|
+eb(ha.positionScreen.z,Ra,Za);na.r=na.g=na.b=1-eb(la.positionScreen.z,Ra,Za);Fa.r=(ja.r+na.r)*0.5;Fa.g=(ja.g+na.g)*0.5;Fa.b=(ja.b+na.b)*0.5;Va=hb(Ea,ja,na,Fa);Oa(aa,e,ea,za,Ha,Ia,Va,0,0,1,0,0,1)}else if(S instanceof THREE.MeshNormalMaterial){pa.r=$a(fa.normalWorld.x);pa.g=$a(fa.normalWorld.y);pa.b=$a(fa.normalWorld.z);pa.updateStyleString();S.wireframe?db(pa.__styleString,S.wireframeLinewidth,S.wireframeLinecap,S.wireframeLinejoin):Na(pa.__styleString)}}function Y(R,ha,la,W,wa,va,fa,S,Ka){b(S.opacity);
|
|
|
+d(S.blending);if(S.map||S.envMap){La(R,ha,W,0,1,3,fa,S,Ka);La(wa,la,va,1,2,3,fa,S,Ka)}else{aa=R.positionScreen.x;e=R.positionScreen.y;ea=ha.positionScreen.x;za=ha.positionScreen.y;Ha=la.positionScreen.x;Ia=la.positionScreen.y;ua=W.positionScreen.x;ca=W.positionScreen.y;ta=wa.positionScreen.x;Aa=wa.positionScreen.y;ia=va.positionScreen.x;Z=va.positionScreen.y;if(S instanceof THREE.MeshBasicMaterial){Qa(aa,e,ea,za,Ha,Ia,ua,ca);S.wireframe?db(S.color.__styleString,S.wireframeLinewidth,S.wireframeLinecap,
|
|
|
+S.wireframeLinejoin):Na(S.color.__styleString)}else if(S instanceof THREE.MeshLambertMaterial)if(u)if(!S.wireframe&&S.shading==THREE.SmoothShading&&fa.vertexNormalsWorld.length==4){Ea.r=ja.r=na.r=Fa.r=O.r;Ea.g=ja.g=na.g=Fa.g=O.g;Ea.b=ja.b=na.b=Fa.b=O.b;X(Ka,fa.v1.positionWorld,fa.vertexNormalsWorld[0],Ea);X(Ka,fa.v2.positionWorld,fa.vertexNormalsWorld[1],ja);X(Ka,fa.v4.positionWorld,fa.vertexNormalsWorld[3],na);X(Ka,fa.v3.positionWorld,fa.vertexNormalsWorld[2],Fa);Va=hb(Ea,ja,na,Fa);P(aa,e,ea,za,
|
|
|
+ua,ca);Oa(aa,e,ea,za,ua,ca,Va,0,0,1,0,0,1);P(ta,Aa,Ha,Ia,ia,Z);Oa(ta,Aa,Ha,Ia,ia,Z,Va,1,0,1,1,0,1)}else{w.r=O.r;w.g=O.g;w.b=O.b;X(Ka,fa.centroidWorld,fa.normalWorld,w);pa.r=S.color.r*w.r;pa.g=S.color.g*w.g;pa.b=S.color.b*w.b;pa.updateStyleString();Qa(aa,e,ea,za,Ha,Ia,ua,ca);S.wireframe?db(pa.__styleString,S.wireframeLinewidth,S.wireframeLinecap,S.wireframeLinejoin):Na(pa.__styleString)}else{Qa(aa,e,ea,za,Ha,Ia,ua,ca);S.wireframe?db(S.color.__styleString,S.wireframeLinewidth,S.wireframeLinecap,S.wireframeLinejoin):
|
|
|
+Na(S.color.__styleString)}else if(S instanceof THREE.MeshNormalMaterial){pa.r=$a(fa.normalWorld.x);pa.g=$a(fa.normalWorld.y);pa.b=$a(fa.normalWorld.z);pa.updateStyleString();Qa(aa,e,ea,za,Ha,Ia,ua,ca);S.wireframe?db(pa.__styleString,S.wireframeLinewidth,S.wireframeLinecap,S.wireframeLinejoin):Na(pa.__styleString)}else if(S instanceof THREE.MeshDepthMaterial){Ra=xa.near;Za=xa.far;Ea.r=Ea.g=Ea.b=1-eb(R.positionScreen.z,Ra,Za);ja.r=ja.g=ja.b=1-eb(ha.positionScreen.z,Ra,Za);na.r=na.g=na.b=1-eb(W.positionScreen.z,
|
|
|
+Ra,Za);Fa.r=Fa.g=Fa.b=1-eb(la.positionScreen.z,Ra,Za);Va=hb(Ea,ja,na,Fa);P(aa,e,ea,za,ua,ca);Oa(aa,e,ea,za,ua,ca,Va,0,0,1,0,0,1);P(ta,Aa,Ha,Ia,ia,Z);Oa(ta,Aa,Ha,Ia,ia,Z,Va,1,0,1,1,0,1)}}}function P(R,ha,la,W,wa,va){o.beginPath();o.moveTo(R,ha);o.lineTo(la,W);o.lineTo(wa,va);o.lineTo(R,ha);o.closePath()}function Qa(R,ha,la,W,wa,va,fa,S){o.beginPath();o.moveTo(R,ha);o.lineTo(la,W);o.lineTo(wa,va);o.lineTo(fa,S);o.lineTo(R,ha);o.closePath()}function db(R,ha,la,W){if(J!=ha)o.lineWidth=J=ha;if(T!=la)o.lineCap=
|
|
|
+T=la;if(z!=W)o.lineJoin=z=W;c(R);o.stroke();x.inflate(ha*2)}function Na(R){if(E!=R)o.fillStyle=E=R;o.fill()}function Oa(R,ha,la,W,wa,va,fa,S,Ka,Wa,Ua,ib,Xa){var fb,gb;fb=fa.width-1;gb=fa.height-1;S*=fb;Ka*=gb;Wa*=fb;Ua*=gb;ib*=fb;Xa*=gb;la-=R;W-=ha;wa-=R;va-=ha;Wa-=S;Ua-=Ka;ib-=S;Xa-=Ka;fb=Wa*Xa-ib*Ua;if(fb!=0){gb=1/fb;fb=(Xa*la-Ua*wa)*gb;Ua=(Xa*W-Ua*va)*gb;la=(Wa*wa-ib*la)*gb;W=(Wa*va-ib*W)*gb;R=R-fb*S-la*Ka;ha=ha-Ua*S-W*Ka;o.save();o.transform(fb,Ua,la,W,R,ha);o.clip();o.drawImage(fa,0,0);o.restore()}}
|
|
|
+function hb(R,ha,la,W){var wa=~~(R.r*255),va=~~(R.g*255);R=~~(R.b*255);var fa=~~(ha.r*255),S=~~(ha.g*255);ha=~~(ha.b*255);var Ka=~~(la.r*255),Wa=~~(la.g*255);la=~~(la.b*255);var Ua=~~(W.r*255),ib=~~(W.g*255);W=~~(W.b*255);oa[0]=wa<0?0:wa>255?255:wa;oa[1]=va<0?0:va>255?255:va;oa[2]=R<0?0:R>255?255:R;oa[4]=fa<0?0:fa>255?255:fa;oa[5]=S<0?0:S>255?255:S;oa[6]=ha<0?0:ha>255?255:ha;oa[8]=Ka<0?0:Ka>255?255:Ka;oa[9]=Wa<0?0:Wa>255?255:Wa;oa[10]=la<0?0:la>255?255:la;oa[12]=Ua<0?0:Ua>255?255:Ua;oa[13]=ib<0?0:
|
|
|
+ib>255?255:ib;oa[14]=W<0?0:W>255?255:W;I.putImageData(V,0,0);Da.drawImage(D,0,0);return U}function eb(R,ha,la){R=(R-ha)/(la-ha);return R*R*(3-2*R)}function $a(R){R=(R+1)*0.5;return R<0?0:R>1?1:R}function ab(R,ha){var la=ha.x-R.x,W=ha.y-R.y,wa=1/Math.sqrt(la*la+W*W);la*=wa;W*=wa;ha.x+=la;ha.y+=W;R.x-=la;R.y-=W}var Ma,cb,Ba,Q,Pa,Ta,jb,Ya;this.autoClear?this.clear():o.setTransform(1,0,0,-1,n,p);f=g.projectScene(ra,xa,this.sortElements);(u=ra.lights.length>0)&&bb(ra);Ma=0;for(cb=f.length;Ma<cb;Ma++){Ba=
|
|
|
+f[Ma];x.empty();if(Ba instanceof THREE.RenderableParticle){K=Ba;K.x*=n;K.y*=p;Q=0;for(Pa=Ba.materials.length;Q<Pa;){Ya=Ba.materials[Q++];Ya.opacity!=0&&da(K,Ba,Ya,ra)}}else if(Ba instanceof THREE.RenderableLine){K=Ba.v1;L=Ba.v2;K.positionScreen.x*=n;K.positionScreen.y*=p;L.positionScreen.x*=n;L.positionScreen.y*=p;x.addPoint(K.positionScreen.x,K.positionScreen.y);x.addPoint(L.positionScreen.x,L.positionScreen.y);if(m.instersects(x)){Q=0;for(Pa=Ba.materials.length;Q<Pa;){Ya=Ba.materials[Q++];Ya.opacity!=
|
|
|
+0&&ma(K,L,Ba,Ya,ra)}}}else if(Ba instanceof THREE.RenderableFace3){K=Ba.v1;L=Ba.v2;M=Ba.v3;K.positionScreen.x*=n;K.positionScreen.y*=p;L.positionScreen.x*=n;L.positionScreen.y*=p;M.positionScreen.x*=n;M.positionScreen.y*=p;if(Ba.overdraw){ab(K.positionScreen,L.positionScreen);ab(L.positionScreen,M.positionScreen);ab(M.positionScreen,K.positionScreen)}x.add3Points(K.positionScreen.x,K.positionScreen.y,L.positionScreen.x,L.positionScreen.y,M.positionScreen.x,M.positionScreen.y);if(m.instersects(x)){Q=
|
|
|
+0;for(Pa=Ba.meshMaterials.length;Q<Pa;){Ya=Ba.meshMaterials[Q++];if(Ya instanceof THREE.MeshFaceMaterial){Ta=0;for(jb=Ba.faceMaterials.length;Ta<jb;)(Ya=Ba.faceMaterials[Ta++])&&Ya.opacity!=0&&La(K,L,M,0,1,2,Ba,Ya,ra)}else Ya.opacity!=0&&La(K,L,M,0,1,2,Ba,Ya,ra)}}}else if(Ba instanceof THREE.RenderableFace4){K=Ba.v1;L=Ba.v2;M=Ba.v3;Ga=Ba.v4;K.positionScreen.x*=n;K.positionScreen.y*=p;L.positionScreen.x*=n;L.positionScreen.y*=p;M.positionScreen.x*=n;M.positionScreen.y*=p;Ga.positionScreen.x*=n;Ga.positionScreen.y*=
|
|
|
+p;sa.positionScreen.copy(L.positionScreen);ya.positionScreen.copy(Ga.positionScreen);if(Ba.overdraw){ab(K.positionScreen,L.positionScreen);ab(L.positionScreen,Ga.positionScreen);ab(Ga.positionScreen,K.positionScreen);ab(M.positionScreen,sa.positionScreen);ab(M.positionScreen,ya.positionScreen)}x.addPoint(K.positionScreen.x,K.positionScreen.y);x.addPoint(L.positionScreen.x,L.positionScreen.y);x.addPoint(M.positionScreen.x,M.positionScreen.y);x.addPoint(Ga.positionScreen.x,Ga.positionScreen.y);if(m.instersects(x)){Q=
|
|
|
+0;for(Pa=Ba.meshMaterials.length;Q<Pa;){Ya=Ba.meshMaterials[Q++];if(Ya instanceof THREE.MeshFaceMaterial){Ta=0;for(jb=Ba.faceMaterials.length;Ta<jb;)(Ya=Ba.faceMaterials[Ta++])&&Ya.opacity!=0&&Y(K,L,M,Ga,sa,ya,Ba,Ya,ra)}else Ya.opacity!=0&&Y(K,L,M,Ga,sa,ya,Ba,Ya,ra)}}}A.addRectangle(x)}o.setTransform(1,0,0,1,0,0)}};
|
|
|
+THREE.SVGRenderer=function(){function b(ua,ca,ta){var Aa,ia,Z,pa;Aa=0;for(ia=ua.lights.length;Aa<ia;Aa++){Z=ua.lights[Aa];if(Z instanceof THREE.DirectionalLight){pa=ca.normalWorld.dot(Z.position)*Z.intensity;if(pa>0){ta.r+=Z.color.r*pa;ta.g+=Z.color.g*pa;ta.b+=Z.color.b*pa}}else if(Z instanceof THREE.PointLight){ya.sub(Z.position,ca.centroidWorld);ya.normalize();pa=ca.normalWorld.dot(ya)*Z.intensity;if(pa>0){ta.r+=Z.color.r*pa;ta.g+=Z.color.g*pa;ta.b+=Z.color.b*pa}}}}function d(ua,ca,ta,Aa,ia,Z){ea=
|
|
|
+f(za++);ea.setAttribute("d","M "+ua.positionScreen.x+" "+ua.positionScreen.y+" L "+ca.positionScreen.x+" "+ca.positionScreen.y+" L "+ta.positionScreen.x+","+ta.positionScreen.y+"z");if(ia instanceof THREE.MeshBasicMaterial)z.__styleString=ia.color.__styleString;else if(ia instanceof THREE.MeshLambertMaterial)if(T){K.r=L.r;K.g=L.g;K.b=L.b;b(Z,Aa,K);z.r=ia.color.r*K.r;z.g=ia.color.g*K.g;z.b=ia.color.b*K.b;z.updateStyleString()}else z.__styleString=ia.color.__styleString;else if(ia instanceof THREE.MeshDepthMaterial){sa=
|
|
|
+1-ia.__2near/(ia.__farPlusNear-Aa.z*ia.__farMinusNear);z.setRGB(sa,sa,sa)}else ia instanceof THREE.MeshNormalMaterial&&z.setRGB(g(Aa.normalWorld.x),g(Aa.normalWorld.y),g(Aa.normalWorld.z));ia.wireframe?ea.setAttribute("style","fill: none; stroke: "+z.__styleString+"; stroke-width: "+ia.wireframeLinewidth+"; stroke-opacity: "+ia.opacity+"; stroke-linecap: "+ia.wireframeLinecap+"; stroke-linejoin: "+ia.wireframeLinejoin):ea.setAttribute("style","fill: "+z.__styleString+"; fill-opacity: "+ia.opacity);
|
|
|
+k.appendChild(ea)}function c(ua,ca,ta,Aa,ia,Z,pa){ea=f(za++);ea.setAttribute("d","M "+ua.positionScreen.x+" "+ua.positionScreen.y+" L "+ca.positionScreen.x+" "+ca.positionScreen.y+" L "+ta.positionScreen.x+","+ta.positionScreen.y+" L "+Aa.positionScreen.x+","+Aa.positionScreen.y+"z");if(Z instanceof THREE.MeshBasicMaterial)z.__styleString=Z.color.__styleString;else if(Z instanceof THREE.MeshLambertMaterial)if(T){K.r=L.r;K.g=L.g;K.b=L.b;b(pa,ia,K);z.r=Z.color.r*K.r;z.g=Z.color.g*K.g;z.b=Z.color.b*
|
|
|
+K.b;z.updateStyleString()}else z.__styleString=Z.color.__styleString;else if(Z instanceof THREE.MeshDepthMaterial){sa=1-Z.__2near/(Z.__farPlusNear-ia.z*Z.__farMinusNear);z.setRGB(sa,sa,sa)}else Z instanceof THREE.MeshNormalMaterial&&z.setRGB(g(ia.normalWorld.x),g(ia.normalWorld.y),g(ia.normalWorld.z));Z.wireframe?ea.setAttribute("style","fill: none; stroke: "+z.__styleString+"; stroke-width: "+Z.wireframeLinewidth+"; stroke-opacity: "+Z.opacity+"; stroke-linecap: "+Z.wireframeLinecap+"; stroke-linejoin: "+
|
|
|
+Z.wireframeLinejoin):ea.setAttribute("style","fill: "+z.__styleString+"; fill-opacity: "+Z.opacity);k.appendChild(ea)}function f(ua){if(aa[ua]==null){aa[ua]=document.createElementNS("http://www.w3.org/2000/svg","path");Ia==0&&aa[ua].setAttribute("shape-rendering","crispEdges")}return aa[ua]}function g(ua){return ua<0?Math.min((1+ua)*0.5,0.5):0.5+Math.min(ua*0.5,0.5)}var h=null,j=new THREE.Projector,k=document.createElementNS("http://www.w3.org/2000/svg","svg"),n,p,o,t,y,v,B,C,E=new THREE.Rectangle,
|
|
|
+J=new THREE.Rectangle,T=!1,z=new THREE.Color(16777215),K=new THREE.Color(16777215),L=new THREE.Color(0),M=new THREE.Color(0),Ga=new THREE.Color(0),sa,ya=new THREE.Vector3,aa=[],e=[],ea,za,Ha,Ia=1;this.domElement=k;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setQuality=function(ua){switch(ua){case "high":Ia=1;break;case "low":Ia=0}};this.setSize=function(ua,ca){n=ua;p=ca;o=n/2;t=p/2;k.setAttribute("viewBox",-o+" "+-t+" "+n+" "+p);k.setAttribute("width",n);k.setAttribute("height",
|
|
|
+p);E.set(-o,-t,o,t)};this.clear=function(){for(;k.childNodes.length>0;)k.removeChild(k.childNodes[0])};this.render=function(ua,ca){var ta,Aa,ia,Z,pa,Ea,ja,na;this.autoClear&&this.clear();h=j.projectScene(ua,ca,this.sortElements);Ha=za=0;if(T=ua.lights.length>0){ja=ua.lights;L.setRGB(0,0,0);M.setRGB(0,0,0);Ga.setRGB(0,0,0);ta=0;for(Aa=ja.length;ta<Aa;ta++){ia=ja[ta];Z=ia.color;if(ia instanceof THREE.AmbientLight){L.r+=Z.r;L.g+=Z.g;L.b+=Z.b}else if(ia instanceof THREE.DirectionalLight){M.r+=Z.r;M.g+=
|
|
|
+Z.g;M.b+=Z.b}else if(ia instanceof THREE.PointLight){Ga.r+=Z.r;Ga.g+=Z.g;Ga.b+=Z.b}}}ta=0;for(Aa=h.length;ta<Aa;ta++){ja=h[ta];J.empty();if(ja instanceof THREE.RenderableParticle){y=ja;y.x*=o;y.y*=-t;ia=0;for(Z=ja.materials.length;ia<Z;)ia++}else if(ja instanceof THREE.RenderableLine){y=ja.v1;v=ja.v2;y.positionScreen.x*=o;y.positionScreen.y*=-t;v.positionScreen.x*=o;v.positionScreen.y*=-t;J.addPoint(y.positionScreen.x,y.positionScreen.y);J.addPoint(v.positionScreen.x,v.positionScreen.y);if(E.instersects(J)){ia=
|
|
|
+0;for(Z=ja.materials.length;ia<Z;)if((na=ja.materials[ia++])&&na.opacity!=0){pa=y;Ea=v;var Fa=Ha++;if(e[Fa]==null){e[Fa]=document.createElementNS("http://www.w3.org/2000/svg","line");Ia==0&&e[Fa].setAttribute("shape-rendering","crispEdges")}ea=e[Fa];ea.setAttribute("x1",pa.positionScreen.x);ea.setAttribute("y1",pa.positionScreen.y);ea.setAttribute("x2",Ea.positionScreen.x);ea.setAttribute("y2",Ea.positionScreen.y);if(na instanceof THREE.LineBasicMaterial){z.__styleString=na.color.__styleString;ea.setAttribute("style",
|
|
|
+"fill: none; stroke: "+z.__styleString+"; stroke-width: "+na.linewidth+"; stroke-opacity: "+na.opacity+"; stroke-linecap: "+na.linecap+"; stroke-linejoin: "+na.linejoin);k.appendChild(ea)}}}}else if(ja instanceof THREE.RenderableFace3){y=ja.v1;v=ja.v2;B=ja.v3;y.positionScreen.x*=o;y.positionScreen.y*=-t;v.positionScreen.x*=o;v.positionScreen.y*=-t;B.positionScreen.x*=o;B.positionScreen.y*=-t;J.addPoint(y.positionScreen.x,y.positionScreen.y);J.addPoint(v.positionScreen.x,v.positionScreen.y);J.addPoint(B.positionScreen.x,
|
|
|
+B.positionScreen.y);if(E.instersects(J)){ia=0;for(Z=ja.meshMaterials.length;ia<Z;){na=ja.meshMaterials[ia++];if(na instanceof THREE.MeshFaceMaterial){pa=0;for(Ea=ja.faceMaterials.length;pa<Ea;)(na=ja.faceMaterials[pa++])&&na.opacity!=0&&d(y,v,B,ja,na,ua)}else na&&na.opacity!=0&&d(y,v,B,ja,na,ua)}}}else if(ja instanceof THREE.RenderableFace4){y=ja.v1;v=ja.v2;B=ja.v3;C=ja.v4;y.positionScreen.x*=o;y.positionScreen.y*=-t;v.positionScreen.x*=o;v.positionScreen.y*=-t;B.positionScreen.x*=o;B.positionScreen.y*=
|
|
|
+-t;C.positionScreen.x*=o;C.positionScreen.y*=-t;J.addPoint(y.positionScreen.x,y.positionScreen.y);J.addPoint(v.positionScreen.x,v.positionScreen.y);J.addPoint(B.positionScreen.x,B.positionScreen.y);J.addPoint(C.positionScreen.x,C.positionScreen.y);if(E.instersects(J)){ia=0;for(Z=ja.meshMaterials.length;ia<Z;){na=ja.meshMaterials[ia++];if(na instanceof THREE.MeshFaceMaterial){pa=0;for(Ea=ja.faceMaterials.length;pa<Ea;)(na=ja.faceMaterials[pa++])&&na.opacity!=0&&c(y,v,B,C,ja,na,ua)}else na&&na.opacity!=
|
|
|
+0&&c(y,v,B,C,ja,na,ua)}}}}}};
|
|
|
THREE.ShaderChunk={fog_pars_fragment:"#ifdef USE_FOG\nuniform vec3 fogColor;\n#ifdef FOG_EXP2\nuniform float fogDensity;\n#else\nuniform float fogNear;\nuniform float fogFar;\n#endif\n#endif",fog_fragment:"#ifdef USE_FOG\nfloat depth = gl_FragCoord.z / gl_FragCoord.w;\n#ifdef FOG_EXP2\nconst float LOG2 = 1.442695;\nfloat fogFactor = exp2( - fogDensity * fogDensity * depth * depth * LOG2 );\nfogFactor = 1.0 - clamp( fogFactor, 0.0, 1.0 );\n#else\nfloat fogFactor = smoothstep( fogNear, fogFar, depth );\n#endif\ngl_FragColor = mix( gl_FragColor, vec4( fogColor, gl_FragColor.w ), fogFactor );\n#endif",envmap_pars_fragment:"#ifdef USE_ENVMAP\nvarying vec3 vReflect;\nuniform float reflectivity;\nuniform samplerCube envMap;\nuniform int combine;\n#endif",
|
|
|
envmap_fragment:"#ifdef USE_ENVMAP\nvec4 cubeColor = textureCube( envMap, vec3( -vReflect.x, vReflect.yz ) );\nif ( combine == 1 ) {\ngl_FragColor = vec4( mix( gl_FragColor.xyz, cubeColor.xyz, reflectivity ), opacity );\n} else {\ngl_FragColor = gl_FragColor * cubeColor;\n}\n#endif",envmap_pars_vertex:"#ifdef USE_ENVMAP\nvarying vec3 vReflect;\nuniform float refractionRatio;\nuniform bool useRefract;\n#endif",envmap_vertex:"#ifdef USE_ENVMAP\nvec4 mPosition = objectMatrix * vec4( position, 1.0 );\nvec3 nWorld = mat3( objectMatrix[0].xyz, objectMatrix[1].xyz, objectMatrix[2].xyz ) * normal;\nif ( useRefract ) {\nvReflect = refract( normalize( mPosition.xyz - cameraPosition ), normalize( nWorld.xyz ), refractionRatio );\n} else {\nvReflect = reflect( normalize( mPosition.xyz - cameraPosition ), normalize( nWorld.xyz ) );\n}\n#endif",
|
|
|
map_particle_pars_fragment:"#ifdef USE_MAP\nuniform sampler2D map;\n#endif",map_particle_fragment:"#ifdef USE_MAP\ngl_FragColor = gl_FragColor * texture2D( map, gl_PointCoord );\n#endif",map_pars_fragment:"#ifdef USE_MAP\nvarying vec2 vUv;\nuniform sampler2D map;\n#endif",map_pars_vertex:"#ifdef USE_MAP\nvarying vec2 vUv;\n#endif",map_fragment:"#ifdef USE_MAP\ngl_FragColor = gl_FragColor * texture2D( map, vUv );\n#endif",map_vertex:"#ifdef USE_MAP\nvUv = uv;\n#endif",lightmap_pars_fragment:"#ifdef USE_LIGHTMAP\nvarying vec2 vUv2;\nuniform sampler2D lightMap;\n#endif",
|
|
@@ -222,104 +222,104 @@ THREE.ShaderChunk.color_pars_fragment,THREE.ShaderChunk.map_pars_fragment,THREE.
|
|
|
vertexShader:["#define PHONG\nvarying vec3 vLightWeighting;\nvarying vec3 vViewPosition;\nvarying vec3 vNormal;",THREE.ShaderChunk.map_pars_vertex,THREE.ShaderChunk.lightmap_pars_vertex,THREE.ShaderChunk.envmap_pars_vertex,THREE.ShaderChunk.lights_pars_vertex,THREE.ShaderChunk.color_pars_vertex,THREE.ShaderChunk.skinning_pars_vertex,THREE.ShaderChunk.morphtarget_pars_vertex,"void main() {\nvec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );",THREE.ShaderChunk.map_vertex,THREE.ShaderChunk.lightmap_vertex,
|
|
|
THREE.ShaderChunk.envmap_vertex,THREE.ShaderChunk.color_vertex,"#ifndef USE_ENVMAP\nvec4 mPosition = objectMatrix * vec4( position, 1.0 );\n#endif\nvViewPosition = cameraPosition - mPosition.xyz;\nvec3 transformedNormal = normalize( normalMatrix * normal );\nvNormal = transformedNormal;",THREE.ShaderChunk.lights_vertex,THREE.ShaderChunk.skinning_vertex,THREE.ShaderChunk.morphtarget_vertex,THREE.ShaderChunk.default_vertex,"}"].join("\n")},particle_basic:{uniforms:THREE.UniformsLib.particle,fragmentShader:["uniform vec3 psColor;\nuniform float opacity;",
|
|
|
THREE.ShaderChunk.color_pars_fragment,THREE.ShaderChunk.map_particle_pars_fragment,THREE.ShaderChunk.fog_pars_fragment,"void main() {\ngl_FragColor = vec4( psColor, opacity );",THREE.ShaderChunk.map_particle_fragment,THREE.ShaderChunk.color_fragment,THREE.ShaderChunk.fog_fragment,"}"].join("\n"),vertexShader:["uniform float size;\nuniform float scale;",THREE.ShaderChunk.color_pars_vertex,"void main() {",THREE.ShaderChunk.color_vertex,"vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );\n#ifdef USE_SIZEATTENUATION\ngl_PointSize = size * ( scale / length( mvPosition.xyz ) );\n#else\ngl_PointSize = size;\n#endif\ngl_Position = projectionMatrix * mvPosition;\n}"].join("\n")}};
|
|
|
-THREE.WebGLRenderer=function(b){function d(m,B,z){var w,y,P,H=m.vertices,J=H.length,K=m.colors,E=K.length,L=m.__vertexArray,X=m.__colorArray,qa=m.__sortArray,W=m.__dirtyVertices,Fa=m.__dirtyColors;if(z.sortParticles){Ha.multiplySelf(z.matrixWorld);for(w=0;w<J;w++){y=H[w].position;Xa.copy(y);Ha.multiplyVector3(Xa);qa[w]=[Xa.z,w]}qa.sort(function(La,ta){return ta[0]-La[0]});for(w=0;w<J;w++){y=H[qa[w][1]].position;P=w*3;L[P]=y.x;L[P+1]=y.y;L[P+2]=y.z}for(w=0;w<E;w++){P=w*3;color=K[qa[w][1]];X[P]=color.r;
|
|
|
-X[P+1]=color.g;X[P+2]=color.b}}else{if(W)for(w=0;w<J;w++){y=H[w].position;P=w*3;L[P]=y.x;L[P+1]=y.y;L[P+2]=y.z}if(Fa)for(w=0;w<E;w++){color=K[w];P=w*3;X[P]=color.r;X[P+1]=color.g;X[P+2]=color.b}}if(W||z.sortParticles){e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,L,B)}if(Fa||z.sortParticles){e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,X,B)}}function c(m,B){m.uniforms=Uniforms.clone(B.uniforms);m.vertexShader=B.vertexShader;m.fragmentShader=
|
|
|
-B.fragmentShader}function f(m,B,z,w,y){w.__webglProgram||wa.initMaterial(w,B,z,y);var P=w.program,H=P.uniforms,J=w.uniforms;if(P!=Ba){e.useProgram(P);Ba=P}e.uniformMatrix4fv(H.projectionMatrix,!1,Ta);if(z&&(w instanceof THREE.MeshBasicMaterial||w instanceof THREE.MeshLambertMaterial||w instanceof THREE.MeshPhongMaterial||w instanceof THREE.LineBasicMaterial||w instanceof THREE.ParticleBasicMaterial||w.fog)){J.fogColor.value.setHex(z.color.hex);if(z instanceof THREE.Fog){J.fogNear.value=z.near;J.fogFar.value=
|
|
|
-z.far}else if(z instanceof THREE.FogExp2)J.fogDensity.value=z.density}if(w instanceof THREE.MeshPhongMaterial||w instanceof THREE.MeshLambertMaterial||w.lights){var K,E,L=0,X=0,qa=0,W,Fa,La,ta,za=Ua,db=za.directional.colors,Z=za.directional.positions,fa=za.point.colors,oa=za.point.positions,Na=za.point.distances,$=0,R=0;z=E=ta=0;for(K=B.length;z<K;z++){E=B[z];W=E.color;Fa=E.position;La=E.intensity;ta=E.distance;if(E instanceof THREE.AmbientLight){L+=W.r;X+=W.g;qa+=W.b}else if(E instanceof THREE.DirectionalLight){ta=
|
|
|
-$*3;db[ta]=W.r*La;db[ta+1]=W.g*La;db[ta+2]=W.b*La;Z[ta]=Fa.x;Z[ta+1]=Fa.y;Z[ta+2]=Fa.z;$+=1}else if(E instanceof THREE.PointLight){E=R*3;fa[E]=W.r*La;fa[E+1]=W.g*La;fa[E+2]=W.b*La;oa[E]=Fa.x;oa[E+1]=Fa.y;oa[E+2]=Fa.z;Na[R]=ta;R+=1}}for(z=$*3;z<db.length;z++)db[z]=0;for(z=R*3;z<fa.length;z++)fa[z]=0;za.point.length=R;za.directional.length=$;za.ambient[0]=L;za.ambient[1]=X;za.ambient[2]=qa;z=Ua;J.enableLighting.value=z.directional.length+z.point.length;J.ambientLightColor.value=z.ambient;J.directionalLightColor.value=
|
|
|
-z.directional.colors;J.directionalLightDirection.value=z.directional.positions;J.pointLightColor.value=z.point.colors;J.pointLightPosition.value=z.point.positions;J.pointLightDistance.value=z.point.distances}if(w instanceof THREE.MeshBasicMaterial||w instanceof THREE.MeshLambertMaterial||w instanceof THREE.MeshPhongMaterial){J.diffuse.value.setRGB(w.color.r,w.color.g,w.color.b);J.opacity.value=w.opacity;J.map.texture=w.map;J.lightMap.texture=w.lightMap;J.envMap.texture=w.envMap;J.reflectivity.value=
|
|
|
-w.reflectivity;J.refractionRatio.value=w.refractionRatio;J.combine.value=w.combine;J.useRefract.value=w.envMap&&w.envMap.mapping instanceof THREE.CubeRefractionMapping}if(w instanceof THREE.LineBasicMaterial){J.diffuse.value.setRGB(w.color.r,w.color.g,w.color.b);J.opacity.value=w.opacity}else if(w instanceof THREE.ParticleBasicMaterial){J.psColor.value.setRGB(w.color.r,w.color.g,w.color.b);J.opacity.value=w.opacity;J.size.value=w.size;J.scale.value=ga.height/2;J.map.texture=w.map}else if(w instanceof
|
|
|
-THREE.MeshPhongMaterial){J.ambient.value.setRGB(w.ambient.r,w.ambient.g,w.ambient.b);J.specular.value.setRGB(w.specular.r,w.specular.g,w.specular.b);J.shininess.value=w.shininess}else if(w instanceof THREE.MeshDepthMaterial){J.mNear.value=m.near;J.mFar.value=m.far;J.opacity.value=w.opacity}else if(w instanceof THREE.MeshNormalMaterial)J.opacity.value=w.opacity;for(var Sa in J)if(X=P.uniforms[Sa]){K=J[Sa];L=K.type;z=K.value;if(L=="i")e.uniform1i(X,z);else if(L=="f")e.uniform1f(X,z);else if(L=="fv1")e.uniform1fv(X,
|
|
|
-z);else if(L=="fv")e.uniform3fv(X,z);else if(L=="v2")e.uniform2f(X,z.x,z.y);else if(L=="v3")e.uniform3f(X,z.x,z.y,z.z);else if(L=="v4")e.uniform4f(X,z.x,z.y,z.z,z.w);else if(L=="c")e.uniform3f(X,z.r,z.g,z.b);else if(L=="t"){e.uniform1i(X,z);if(K=K.texture)if(K.image instanceof Array&&K.image.length==6){if(K.image.length==6){if(K.needsUpdate){if(K.__webglInit){e.bindTexture(e.TEXTURE_CUBE_MAP,K.image.__webglTextureCube);for(L=0;L<6;++L)e.texSubImage2D(e.TEXTURE_CUBE_MAP_POSITIVE_X+L,0,0,0,e.RGBA,e.UNSIGNED_BYTE,
|
|
|
-K.image[L])}else{K.image.__webglTextureCube=e.createTexture();e.bindTexture(e.TEXTURE_CUBE_MAP,K.image.__webglTextureCube);for(L=0;L<6;++L)e.texImage2D(e.TEXTURE_CUBE_MAP_POSITIVE_X+L,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,K.image[L]);K.__webglInit=!0}O(e.TEXTURE_CUBE_MAP,K,K.image[0]);e.bindTexture(e.TEXTURE_CUBE_MAP,null);K.needsUpdate=!1}e.activeTexture(e.TEXTURE0+z);e.bindTexture(e.TEXTURE_CUBE_MAP,K.image.__webglTextureCube)}}else Q(K,z)}}e.uniformMatrix4fv(H.modelViewMatrix,!1,y._modelViewMatrixArray);
|
|
|
-e.uniformMatrix3fv(H.normalMatrix,!1,y._normalMatrixArray);(w instanceof THREE.MeshShaderMaterial||w instanceof THREE.MeshPhongMaterial||w.envMap)&&e.uniform3f(H.cameraPosition,m.position.x,m.position.y,m.position.z);(w instanceof THREE.MeshShaderMaterial||w.envMap||w.skinning)&&e.uniformMatrix4fv(H.objectMatrix,!1,y._objectMatrixArray);(w instanceof THREE.MeshPhongMaterial||w instanceof THREE.MeshLambertMaterial||w instanceof THREE.MeshShaderMaterial||w.skinning)&&e.uniformMatrix4fv(H.viewMatrix,
|
|
|
-!1,ab);if(w instanceof THREE.ShadowVolumeDynamicMaterial){m=J.directionalLightDirection.value;m[0]=-B.position.x;m[1]=-B.position.y;m[2]=-B.position.z;e.uniform3fv(H.directionalLightDirection,m);e.uniformMatrix4fv(H.objectMatrix,!1,y._objectMatrixArray);e.uniformMatrix4fv(H.viewMatrix,!1,ab)}if(w.skinning){e.uniformMatrix4fv(H.cameraInverseMatrix,!1,ab);e.uniformMatrix4fv(H.boneGlobalMatrices,!1,y.boneMatrices)}return P}function g(m,B,z,w,y,P){if(w.opacity!=0){var H;m=f(m,B,z,w,P).attributes;if(w.morphTargets){B=
|
|
|
-w.program.attributes;P.morphTargetBase!==-1?e.bindBuffer(e.ARRAY_BUFFER,y.__webglMorphTargetsBuffers[P.morphTargetBase]):e.bindBuffer(e.ARRAY_BUFFER,y.__webglVertexBuffer);e.vertexAttribPointer(B.position,3,e.FLOAT,!1,0,0);if(P.morphTargetForcedOrder.length){z=0;for(var J=P.morphTargetForcedOrder,K=P.morphTargetInfluences;z<w.numSupportedMorphTargets&&z<J.length;){e.bindBuffer(e.ARRAY_BUFFER,y.__webglMorphTargetsBuffers[J[z]]);e.vertexAttribPointer(B["morphTarget"+z],3,e.FLOAT,!1,0,0);P.__webglMorphTargetInfluences[z]=
|
|
|
-K[J[z]];z++}}else{J=[];var E=-1,L=0;K=P.morphTargetInfluences;var X,qa=K.length;z=0;for(P.morphTargetBase!==-1&&(J[P.morphTargetBase]=!0);z<w.numSupportedMorphTargets;){for(X=0;X<qa;X++)if(!J[X]&&K[X]>E){L=X;E=K[L]}e.bindBuffer(e.ARRAY_BUFFER,y.__webglMorphTargetsBuffers[L]);e.vertexAttribPointer(B["morphTarget"+z],3,e.FLOAT,!1,0,0);P.__webglMorphTargetInfluences[z]=E;J[L]=1;E=-1;z++}}e.uniform1fv(w.program.uniforms.morphTargetInfluences,P.__webglMorphTargetInfluences)}else{e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
-y.__webglVertexBuffer);e.vertexAttribPointer(m.position,3,e.FLOAT,!1,0,0)}if(y.__webglCustomAttributes)for(H in y.__webglCustomAttributes)if(m[H]>=0){B=y.__webglCustomAttributes[H];e.bindBuffer(e.ARRAY_BUFFER,B.buffer);e.vertexAttribPointer(m[H],B.size,e.FLOAT,!1,0,0)}if(m.color>=0){e.bindBuffer(e.ARRAY_BUFFER,y.__webglColorBuffer);e.vertexAttribPointer(m.color,3,e.FLOAT,!1,0,0)}if(m.normal>=0){e.bindBuffer(e.ARRAY_BUFFER,y.__webglNormalBuffer);e.vertexAttribPointer(m.normal,3,e.FLOAT,!1,0,0)}if(m.tangent>=
|
|
|
-0){e.bindBuffer(e.ARRAY_BUFFER,y.__webglTangentBuffer);e.vertexAttribPointer(m.tangent,4,e.FLOAT,!1,0,0)}if(m.uv>=0)if(y.__webglUVBuffer){e.bindBuffer(e.ARRAY_BUFFER,y.__webglUVBuffer);e.vertexAttribPointer(m.uv,2,e.FLOAT,!1,0,0);e.enableVertexAttribArray(m.uv)}else e.disableVertexAttribArray(m.uv);if(m.uv2>=0)if(y.__webglUV2Buffer){e.bindBuffer(e.ARRAY_BUFFER,y.__webglUV2Buffer);e.vertexAttribPointer(m.uv2,2,e.FLOAT,!1,0,0);e.enableVertexAttribArray(m.uv2)}else e.disableVertexAttribArray(m.uv2);
|
|
|
-if(w.skinning&&m.skinVertexA>=0&&m.skinVertexB>=0&&m.skinIndex>=0&&m.skinWeight>=0){e.bindBuffer(e.ARRAY_BUFFER,y.__webglSkinVertexABuffer);e.vertexAttribPointer(m.skinVertexA,4,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,y.__webglSkinVertexBBuffer);e.vertexAttribPointer(m.skinVertexB,4,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,y.__webglSkinIndicesBuffer);e.vertexAttribPointer(m.skinIndex,4,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,y.__webglSkinWeightsBuffer);e.vertexAttribPointer(m.skinWeight,
|
|
|
-4,e.FLOAT,!1,0,0)}if(P instanceof THREE.Mesh)if(w.wireframe){e.lineWidth(w.wireframeLinewidth);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,y.__webglLineBuffer);e.drawElements(e.LINES,y.__webglLineCount,e.UNSIGNED_SHORT,0)}else{e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,y.__webglFaceBuffer);e.drawElements(e.TRIANGLES,y.__webglFaceCount,e.UNSIGNED_SHORT,0)}else if(P instanceof THREE.Line){P=P.type==THREE.LineStrip?e.LINE_STRIP:e.LINES;e.lineWidth(w.linewidth);e.drawArrays(P,0,y.__webglLineCount)}else if(P instanceof
|
|
|
-THREE.ParticleSystem)e.drawArrays(e.POINTS,0,y.__webglParticleCount);else P instanceof THREE.Ribbon&&e.drawArrays(e.TRIANGLE_STRIP,0,y.__webglVertexCount)}}function h(m,B){if(!m.__webglVertexBuffer)m.__webglVertexBuffer=e.createBuffer();if(!m.__webglNormalBuffer)m.__webglNormalBuffer=e.createBuffer();if(m.hasPos){e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,m.positionArray,e.DYNAMIC_DRAW);e.enableVertexAttribArray(B.attributes.position);e.vertexAttribPointer(B.attributes.position,
|
|
|
-3,e.FLOAT,!1,0,0)}if(m.hasNormal){e.bindBuffer(e.ARRAY_BUFFER,m.__webglNormalBuffer);e.bufferData(e.ARRAY_BUFFER,m.normalArray,e.DYNAMIC_DRAW);e.enableVertexAttribArray(B.attributes.normal);e.vertexAttribPointer(B.attributes.normal,3,e.FLOAT,!1,0,0)}e.drawArrays(e.TRIANGLES,0,m.count);m.count=0}function j(m){if(ea!=m.doubleSided){m.doubleSided?e.disable(e.CULL_FACE):e.enable(e.CULL_FACE);ea=m.doubleSided}if(va!=m.flipSided){m.flipSided?e.frontFace(e.CW):e.frontFace(e.CCW);va=m.flipSided}}function k(m){if(ka!=
|
|
|
-m){m?e.enable(e.DEPTH_TEST):e.disable(e.DEPTH_TEST);ka=m}}function n(m){pa[0].set(m.n41-m.n11,m.n42-m.n12,m.n43-m.n13,m.n44-m.n14);pa[1].set(m.n41+m.n11,m.n42+m.n12,m.n43+m.n13,m.n44+m.n14);pa[2].set(m.n41+m.n21,m.n42+m.n22,m.n43+m.n23,m.n44+m.n24);pa[3].set(m.n41-m.n21,m.n42-m.n22,m.n43-m.n23,m.n44-m.n24);pa[4].set(m.n41-m.n31,m.n42-m.n32,m.n43-m.n33,m.n44-m.n34);pa[5].set(m.n41+m.n31,m.n42+m.n32,m.n43+m.n33,m.n44+m.n34);var B;for(m=0;m<6;m++){B=pa[m];B.divideScalar(Math.sqrt(B.x*B.x+B.y*B.y+B.z*
|
|
|
-B.z))}}function p(m){for(var B=m.matrixWorld,z=-m.geometry.boundingSphere.radius*Math.max(m.scale.x,Math.max(m.scale.y,m.scale.z)),w=0;w<6;w++){m=pa[w].x*B.n14+pa[w].y*B.n24+pa[w].z*B.n34+pa[w].w;if(m<=z)return!1}return!0}function o(m,B){m.list[m.count]=B;m.count+=1}function x(m){var B,z,w=m.object,y=m.opaque,P=m.transparent;P.count=0;m=y.count=0;for(B=w.materials.length;m<B;m++){z=w.materials[m];z.transparent?o(P,z):o(y,z)}}function A(m){var B,z,w,y,P=m.object,H=m.buffer,J=m.opaque,K=m.transparent;
|
|
|
-K.count=0;m=J.count=0;for(w=P.materials.length;m<w;m++){B=P.materials[m];if(B instanceof THREE.MeshFaceMaterial){B=0;for(z=H.materials.length;B<z;B++)(y=H.materials[B])&&(y.transparent?o(K,y):o(J,y))}else(y=B)&&(y.transparent?o(K,y):o(J,y))}}function t(m,B){return B.z-m.z}function C(m){e.enable(e.POLYGON_OFFSET_FILL);e.polygonOffset(0.1,1);e.enable(e.STENCIL_TEST);e.depthMask(!1);e.colorMask(!1,!1,!1,!1);e.stencilFunc(e.ALWAYS,1,255);e.stencilOpSeparate(e.BACK,e.KEEP,e.INCR,e.KEEP);e.stencilOpSeparate(e.FRONT,
|
|
|
-e.KEEP,e.DECR,e.KEEP);var B,z=m.lights.length,w,y=m.lights,P=[],H,J,K,E,L,X=m.__webglShadowVolumes.length;for(B=0;B<z;B++){w=m.lights[B];if(w instanceof THREE.DirectionalLight){P[0]=-w.position.x;P[1]=-w.position.y;P[2]=-w.position.z;for(L=0;L<X;L++){w=m.__webglShadowVolumes[L].object;H=m.__webglShadowVolumes[L].buffer;J=w.materials[0];J.program||wa.initMaterial(J,y,undefined,w);J=J.program;K=J.uniforms;E=J.attributes;if(Ba!==J){e.useProgram(J);Ba=J;e.uniformMatrix4fv(K.projectionMatrix,!1,Ta);e.uniformMatrix4fv(K.viewMatrix,
|
|
|
-!1,ab);e.uniform3fv(K.directionalLightDirection,P)}w.matrixWorld.flattenToArray(w._objectMatrixArray);e.uniformMatrix4fv(K.objectMatrix,!1,w._objectMatrixArray);e.bindBuffer(e.ARRAY_BUFFER,H.__webglVertexBuffer);e.vertexAttribPointer(E.position,3,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,H.__webglNormalBuffer);e.vertexAttribPointer(E.normal,3,e.FLOAT,!1,0,0);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,H.__webglFaceBuffer);e.cullFace(e.FRONT);e.drawElements(e.TRIANGLES,H.__webglFaceCount,e.UNSIGNED_SHORT,
|
|
|
-0);e.cullFace(e.BACK);e.drawElements(e.TRIANGLES,H.__webglFaceCount,e.UNSIGNED_SHORT,0)}}}e.disable(e.POLYGON_OFFSET_FILL);e.colorMask(!0,!0,!0,!0);e.stencilFunc(e.NOTEQUAL,0,255);e.stencilOp(e.KEEP,e.KEEP,e.KEEP);e.disable(e.DEPTH_TEST);Ca="";Ba=ia.program;e.useProgram(ia.program);e.uniformMatrix4fv(ia.projectionLocation,!1,Ta);e.uniform1f(ia.darknessLocation,ia.darkness);e.bindBuffer(e.ARRAY_BUFFER,ia.vertexBuffer);e.vertexAttribPointer(ia.vertexLocation,3,e.FLOAT,!1,0,0);e.enableVertexAttribArray(ia.vertexLocation);
|
|
|
-e.blendFunc(e.ONE,e.ONE_MINUS_SRC_ALPHA);e.blendEquation(e.FUNC_ADD);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ia.elementBuffer);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0);e.disable(e.STENCIL_TEST);e.enable(e.DEPTH_TEST);e.depthMask(Ka)}function F(m,B){var z,w,y,P=m.__webglLensFlares.length,H,J,K;H=new THREE.Vector3;var E=la/Ga;J=Ga*0.5;K=la*0.5;var L=16/la,X=[L*E,L],qa=[1,1,0];L=[1,1];var W,Fa=ma.readBackPixels,La,ta,za=ma.uniforms;z=ma.attributes;e.useProgram(ma.program);Ba=ma.program;Ca="";e.uniform1i(za.map,
|
|
|
-0);e.activeTexture(e.TEXTURE0);e.uniform1f(za.opacity,1);e.uniform1f(za.rotation,0);e.uniform2fv(za.scale,X);e.bindBuffer(e.ARRAY_BUFFER,ma.vertexBuffer);e.vertexAttribPointer(z.vertex,2,e.FLOAT,!1,16,0);e.vertexAttribPointer(z.uv,2,e.FLOAT,!1,16,8);e.bindTexture(e.TEXTURE_2D,ma.tempTexture);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ma.elementBuffer);e.disable(e.CULL_FACE);e.depthMask(!1);for(y=0;y<P;y++){z=m.__webglLensFlares[y].object;H.set(z.matrixWorld.n14,z.matrixWorld.n24,z.matrixWorld.n34);B.matrixWorldInverse.multiplyVector3(H);
|
|
|
-w=H.z;B.projectionMatrix.multiplyVector3(H);qa[0]=H.x;qa[1]=H.y;qa[2]=H.z;L[0]=qa[0]*J+J;L[1]=qa[1]*K+K;e.copyTexSubImage2D(e.TEXTURE_2D,0,0,0,L[0]-8,L[1]-8,16,16);e.uniform3fv(za.screenPosition,qa);e.uniform1i(za.renderPink,1);e.enable(e.DEPTH_TEST);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0);try{e.readPixels(L[0]-8,L[1]-8,16,16,e.RGBA,e.UNSIGNED_BYTE,ma.readBackPixels)}catch(db){console.log("WebGLRenderer.renderLensFlare: readPixels failed!")}e.getError()&&console.log("WebGLRenderer.renderLensFlare: readPixels failed!");
|
|
|
-sampleDistance=parseInt(5*(1-Math.max(0,Math.min(-w,B.far))/B.far),10)+2;w=sampleDistance*4;W=sampleDistance*64;ta=0;La=28-w+(448-W);ma.readBackPixels[La+0]===255&&ma.readBackPixels[La+1]===0&&ma.readBackPixels[La+2]===255&&(ta+=0.2);La=28+w+(448-W);Fa[La+0]===255&&Fa[La+1]===0&&Fa[La+2]===255&&(ta+=0.2);La=28+w+(448+W);Fa[La+0]===255&&Fa[La+1]===0&&Fa[La+2]===255&&(ta+=0.2);La=28-w+(448+W);Fa[La+0]===255&&Fa[La+1]===0&&Fa[La+2]===255&&(ta+=0.2);La=476;Fa[La+0]===255&&Fa[La+1]===0&&Fa[La+2]===255&&
|
|
|
-(ta+=0.2);z.positionScreen.x=qa[0];z.positionScreen.y=qa[1];z.positionScreen.z=qa[2];z.customUpdateCallback?z.customUpdateCallback(ta,z):z.updateLensFlares(ta);e.uniform1i(za.renderPink,0);e.disable(e.DEPTH_TEST);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)}for(y=0;y<P;y++){z=m.__webglLensFlares[y].object;H=0;for(J=z.lensFlares.length;H<J;H++){K=z.lensFlares[H];if(K.opacity>0.0010&&K.scale>0.0010){qa[0]=K.x;qa[1]=K.y;qa[2]=K.z;L=K.size*K.scale/la;X[0]=L*E;X[1]=L;e.uniform3fv(za.screenPosition,
|
|
|
-qa);e.uniform1f(za.rotation,K.rotation);e.uniform2fv(za.scale,X);e.uniform1f(za.opacity,K.opacity);M(K.blending);Q(K.texture,0);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)}}}e.enable(e.CULL_FACE);e.enable(e.DEPTH_TEST);e.depthMask(Ka)}function I(m,B){m._modelViewMatrix.multiplyToArray(B.matrixWorldInverse,m.matrixWorld,m._modelViewMatrixArray);THREE.Matrix4.makeInvert3x3(m._modelViewMatrix).transposeIntoArray(m._normalMatrixArray)}function G(m){var B,z,w,y,P;if(m instanceof THREE.Mesh){z=m.geometry;
|
|
|
-for(B in z.geometryGroups){w=z.geometryGroups[B];P=!1;for(y in w.__webglCustomAttributes)if(w.__webglCustomAttributes[y].needsUpdate){P=!0;break}if(z.__dirtyVertices||z.__dirtyMorphTargets||z.__dirtyElements||z.__dirtyUvs||z.__dirtyNormals||z.__dirtyColors||z.__dirtyTangents||P){P=e.DYNAMIC_DRAW;var H=void 0,J=void 0,K=void 0,E=void 0;K=void 0;var L=void 0,X=void 0,qa=void 0,W=void 0,Fa=void 0,La=void 0,ta=void 0,za=void 0,db=void 0,Z=void 0,fa=void 0,oa=void 0,Na=void 0;X=void 0;qa=void 0;E=void 0;
|
|
|
-W=void 0;E=void 0;Z=void 0;fa=void 0;X=void 0;Z=void 0;fa=void 0;oa=void 0;Na=void 0;Z=void 0;fa=void 0;oa=void 0;Na=void 0;Z=void 0;fa=void 0;oa=void 0;Na=void 0;Z=void 0;fa=void 0;oa=void 0;E=void 0;W=void 0;L=void 0;K=void 0;K=void 0;var $=void 0,R=void 0,Sa=void 0,fb=void 0,Pa=0,Qa=0,jb=0,gb=0,bb=0,cb=0,Oa=0,eb=0,Da=0,S=0,Ra=0;$=0;var Va=w.__vertexArray,lb=w.__uvArray,$a=w.__uv2Array,T=w.__normalArray,ja=w.__tangentArray,na=w.__colorArray,Y=w.__skinVertexAArray,ya=w.__skinVertexBArray,xa=w.__skinIndexArray,
|
|
|
-ha=w.__skinWeightArray,V=w.__morphTargetsArrays,Ma=w.__webglCustomAttributes;R=void 0;var Ya=w.__faceArray,Wa=w.__lineArray,kb=w.__needsSmoothNormals;La=w.__vertexColorType;Fa=w.__uvType;ta=w.__normalType;var Za=m.geometry,hb=Za.__dirtyVertices,ib=Za.__dirtyElements,tb=Za.__dirtyUvs,ub=Za.__dirtyNormals,vb=Za.__dirtyTangents,wb=Za.__dirtyColors,xb=Za.__dirtyMorphTargets,pb=Za.vertices,yb=w.faces,Bb=Za.faces,zb=Za.faceVertexUvs[0],Ab=Za.faceVertexUvs[1],qb=Za.skinVerticesA,rb=Za.skinVerticesB,sb=Za.skinIndices,
|
|
|
-nb=Za.skinWeights,ob=Za.edgeFaces,mb=Za.morphTargets;if(Ma)for(fb in Ma)Ma[fb].offset=0;H=0;for(J=yb.length;H<J;H++){K=yb[H];E=Bb[K];zb&&(za=zb[K]);Ab&&(db=Ab[K]);K=E.vertexNormals;L=E.normal;X=E.vertexColors;qa=E.color;W=E.vertexTangents;if(E instanceof THREE.Face3){if(hb){Z=pb[E.a].position;fa=pb[E.b].position;oa=pb[E.c].position;Va[Qa]=Z.x;Va[Qa+1]=Z.y;Va[Qa+2]=Z.z;Va[Qa+3]=fa.x;Va[Qa+4]=fa.y;Va[Qa+5]=fa.z;Va[Qa+6]=oa.x;Va[Qa+7]=oa.y;Va[Qa+8]=oa.z;Qa+=9}if(Ma)for(fb in Ma){R=Ma[fb];if(R.needsUpdate){$=
|
|
|
-R.offset;if(R.size===1){R.array[$+0]=R.value[E.a];R.array[$+1]=R.value[E.b];R.array[$+2]=R.value[E.c];R.offset+=3}else{Z=R.value[E.a];fa=R.value[E.b];oa=R.value[E.c];if(R.size===2){R.array[$+0]=Z.x;R.array[$+1]=Z.y;R.array[$+2]=fa.x;R.array[$+3]=fa.y;R.array[$+4]=oa.x;R.array[$+5]=oa.y;R.offset+=6}else if(R.size===3){R.array[$+0]=Z.x;R.array[$+1]=Z.y;R.array[$+2]=Z.z;R.array[$+3]=fa.x;R.array[$+4]=fa.y;R.array[$+5]=fa.z;R.array[$+6]=oa.x;R.array[$+7]=oa.y;R.array[$+8]=oa.z;R.offset+=9}else{R.array[$+
|
|
|
-0]=Z.x;R.array[$+1]=Z.y;R.array[$+2]=Z.z;R.array[$+3]=Z.w;R.array[$+4]=fa.x;R.array[$+5]=fa.y;R.array[$+6]=fa.z;R.array[$+7]=fa.w;R.array[$+8]=oa.x;R.array[$+9]=oa.y;R.array[$+10]=oa.z;R.array[$+11]=oa.w;R.offset+=12}}}}if(xb){$=0;for(R=mb.length;$<R;$++){Z=mb[$].vertices[E.a].position;fa=mb[$].vertices[E.b].position;oa=mb[$].vertices[E.c].position;Sa=V[$];Sa[Ra+0]=Z.x;Sa[Ra+1]=Z.y;Sa[Ra+2]=Z.z;Sa[Ra+3]=fa.x;Sa[Ra+4]=fa.y;Sa[Ra+5]=fa.z;Sa[Ra+6]=oa.x;Sa[Ra+7]=oa.y;Sa[Ra+8]=oa.z}Ra+=9}if(nb.length){Z=
|
|
|
-nb[E.a];fa=nb[E.b];oa=nb[E.c];ha[S]=Z.x;ha[S+1]=Z.y;ha[S+2]=Z.z;ha[S+3]=Z.w;ha[S+4]=fa.x;ha[S+5]=fa.y;ha[S+6]=fa.z;ha[S+7]=fa.w;ha[S+8]=oa.x;ha[S+9]=oa.y;ha[S+10]=oa.z;ha[S+11]=oa.w;Z=sb[E.a];fa=sb[E.b];oa=sb[E.c];xa[S]=Z.x;xa[S+1]=Z.y;xa[S+2]=Z.z;xa[S+3]=Z.w;xa[S+4]=fa.x;xa[S+5]=fa.y;xa[S+6]=fa.z;xa[S+7]=fa.w;xa[S+8]=oa.x;xa[S+9]=oa.y;xa[S+10]=oa.z;xa[S+11]=oa.w;Z=qb[E.a];fa=qb[E.b];oa=qb[E.c];Y[S]=Z.x;Y[S+1]=Z.y;Y[S+2]=Z.z;Y[S+3]=1;Y[S+4]=fa.x;Y[S+5]=fa.y;Y[S+6]=fa.z;Y[S+7]=1;Y[S+8]=oa.x;Y[S+9]=
|
|
|
-oa.y;Y[S+10]=oa.z;Y[S+11]=1;Z=rb[E.a];fa=rb[E.b];oa=rb[E.c];ya[S]=Z.x;ya[S+1]=Z.y;ya[S+2]=Z.z;ya[S+3]=1;ya[S+4]=fa.x;ya[S+5]=fa.y;ya[S+6]=fa.z;ya[S+7]=1;ya[S+8]=oa.x;ya[S+9]=oa.y;ya[S+10]=oa.z;ya[S+11]=1;S+=12}if(wb&&La){if(X.length==3&&La==THREE.VertexColors){E=X[0];Z=X[1];fa=X[2]}else fa=Z=E=qa;na[Da]=E.r;na[Da+1]=E.g;na[Da+2]=E.b;na[Da+3]=Z.r;na[Da+4]=Z.g;na[Da+5]=Z.b;na[Da+6]=fa.r;na[Da+7]=fa.g;na[Da+8]=fa.b;Da+=9}if(vb&&Za.hasTangents){X=W[0];qa=W[1];E=W[2];ja[Oa]=X.x;ja[Oa+1]=X.y;ja[Oa+2]=X.z;
|
|
|
-ja[Oa+3]=X.w;ja[Oa+4]=qa.x;ja[Oa+5]=qa.y;ja[Oa+6]=qa.z;ja[Oa+7]=qa.w;ja[Oa+8]=E.x;ja[Oa+9]=E.y;ja[Oa+10]=E.z;ja[Oa+11]=E.w;Oa+=12}if(ub&&ta)if(K.length==3&&kb)for(W=0;W<3;W++){L=K[W];T[cb]=L.x;T[cb+1]=L.y;T[cb+2]=L.z;cb+=3}else for(W=0;W<3;W++){T[cb]=L.x;T[cb+1]=L.y;T[cb+2]=L.z;cb+=3}if(tb&&za!==undefined&&Fa)for(W=0;W<3;W++){K=za[W];lb[jb]=K.u;lb[jb+1]=K.v;jb+=2}if(tb&&db!==undefined&&Fa)for(W=0;W<3;W++){K=db[W];$a[gb]=K.u;$a[gb+1]=K.v;gb+=2}if(ib){Ya[bb]=Pa;Ya[bb+1]=Pa+1;Ya[bb+2]=Pa+2;bb+=3;Wa[eb]=
|
|
|
-Pa;Wa[eb+1]=Pa+1;Wa[eb+2]=Pa;Wa[eb+3]=Pa+2;Wa[eb+4]=Pa+1;Wa[eb+5]=Pa+2;eb+=6;Pa+=3}}else if(E instanceof THREE.Face4){if(hb){Z=pb[E.a].position;fa=pb[E.b].position;oa=pb[E.c].position;Na=pb[E.d].position;Va[Qa]=Z.x;Va[Qa+1]=Z.y;Va[Qa+2]=Z.z;Va[Qa+3]=fa.x;Va[Qa+4]=fa.y;Va[Qa+5]=fa.z;Va[Qa+6]=oa.x;Va[Qa+7]=oa.y;Va[Qa+8]=oa.z;Va[Qa+9]=Na.x;Va[Qa+10]=Na.y;Va[Qa+11]=Na.z;Qa+=12}if(Ma)for(fb in Ma){R=Ma[fb];if(R.needsUpdate){$=R.offset;if(R.size===1){R.array[$+0]=R.value[E.a];R.array[$+1]=R.value[E.b];
|
|
|
-R.array[$+2]=R.value[E.c];R.array[$+2]=R.value[E.d];R.offset+=4}else{Z=R.value[E.a];fa=R.value[E.b];oa=R.value[E.c];Na=R.value[E.d];if(R.size===2){R.array[$+0]=Z.x;R.array[$+1]=Z.y;R.array[$+2]=fa.x;R.array[$+3]=fa.y;R.array[$+4]=oa.x;R.array[$+5]=oa.y;R.array[$+6]=Na.x;R.array[$+7]=Na.y;R.offset+=8}else if(R.size===3){R.array[$+0]=Z.x;R.array[$+1]=Z.y;R.array[$+2]=Z.z;R.array[$+3]=fa.x;R.array[$+4]=fa.y;R.array[$+5]=fa.z;R.array[$+6]=oa.x;R.array[$+7]=oa.y;R.array[$+8]=oa.z;R.array[$+9]=Na.x;R.array[$+
|
|
|
-10]=Na.y;R.array[$+11]=Na.z;R.offset+=12}else{R.array[$+0]=Z.x;R.array[$+1]=Z.y;R.array[$+2]=Z.z;R.array[$+3]=Z.w;R.array[$+4]=fa.x;R.array[$+5]=fa.y;R.array[$+6]=fa.z;R.array[$+7]=fa.w;R.array[$+8]=oa.x;R.array[$+9]=oa.y;R.array[$+10]=oa.z;R.array[$+11]=oa.w;R.array[$+12]=Na.x;R.array[$+13]=Na.y;R.array[$+14]=Na.z;R.array[$+15]=Na.w;R.offset+=16}}}}if(xb){$=0;for(R=mb.length;$<R;$++){Z=mb[$].vertices[E.a].position;fa=mb[$].vertices[E.b].position;oa=mb[$].vertices[E.c].position;Na=mb[$].vertices[E.d].position;
|
|
|
-Sa=V[$];Sa[Ra+0]=Z.x;Sa[Ra+1]=Z.y;Sa[Ra+2]=Z.z;Sa[Ra+3]=fa.x;Sa[Ra+4]=fa.y;Sa[Ra+5]=fa.z;Sa[Ra+6]=oa.x;Sa[Ra+7]=oa.y;Sa[Ra+8]=oa.z;Sa[Ra+9]=Na.x;Sa[Ra+10]=Na.y;Sa[Ra+11]=Na.z}Ra+=12}if(nb.length){Z=nb[E.a];fa=nb[E.b];oa=nb[E.c];Na=nb[E.d];ha[S]=Z.x;ha[S+1]=Z.y;ha[S+2]=Z.z;ha[S+3]=Z.w;ha[S+4]=fa.x;ha[S+5]=fa.y;ha[S+6]=fa.z;ha[S+7]=fa.w;ha[S+8]=oa.x;ha[S+9]=oa.y;ha[S+10]=oa.z;ha[S+11]=oa.w;ha[S+12]=Na.x;ha[S+13]=Na.y;ha[S+14]=Na.z;ha[S+15]=Na.w;Z=sb[E.a];fa=sb[E.b];oa=sb[E.c];Na=sb[E.d];xa[S]=Z.x;xa[S+
|
|
|
-1]=Z.y;xa[S+2]=Z.z;xa[S+3]=Z.w;xa[S+4]=fa.x;xa[S+5]=fa.y;xa[S+6]=fa.z;xa[S+7]=fa.w;xa[S+8]=oa.x;xa[S+9]=oa.y;xa[S+10]=oa.z;xa[S+11]=oa.w;xa[S+12]=Na.x;xa[S+13]=Na.y;xa[S+14]=Na.z;xa[S+15]=Na.w;Z=qb[E.a];fa=qb[E.b];oa=qb[E.c];Na=qb[E.d];Y[S]=Z.x;Y[S+1]=Z.y;Y[S+2]=Z.z;Y[S+3]=1;Y[S+4]=fa.x;Y[S+5]=fa.y;Y[S+6]=fa.z;Y[S+7]=1;Y[S+8]=oa.x;Y[S+9]=oa.y;Y[S+10]=oa.z;Y[S+11]=1;Y[S+12]=Na.x;Y[S+13]=Na.y;Y[S+14]=Na.z;Y[S+15]=1;Z=rb[E.a];fa=rb[E.b];oa=rb[E.c];E=rb[E.d];ya[S]=Z.x;ya[S+1]=Z.y;ya[S+2]=Z.z;ya[S+3]=
|
|
|
-1;ya[S+4]=fa.x;ya[S+5]=fa.y;ya[S+6]=fa.z;ya[S+7]=1;ya[S+8]=oa.x;ya[S+9]=oa.y;ya[S+10]=oa.z;ya[S+11]=1;ya[S+12]=E.x;ya[S+13]=E.y;ya[S+14]=E.z;ya[S+15]=1;S+=16}if(wb&&La){if(X.length==4&&La==THREE.VertexColors){E=X[0];Z=X[1];fa=X[2];X=X[3]}else X=fa=Z=E=qa;na[Da]=E.r;na[Da+1]=E.g;na[Da+2]=E.b;na[Da+3]=Z.r;na[Da+4]=Z.g;na[Da+5]=Z.b;na[Da+6]=fa.r;na[Da+7]=fa.g;na[Da+8]=fa.b;na[Da+9]=X.r;na[Da+10]=X.g;na[Da+11]=X.b;Da+=12}if(vb&&Za.hasTangents){X=W[0];qa=W[1];E=W[2];W=W[3];ja[Oa]=X.x;ja[Oa+1]=X.y;ja[Oa+
|
|
|
-2]=X.z;ja[Oa+3]=X.w;ja[Oa+4]=qa.x;ja[Oa+5]=qa.y;ja[Oa+6]=qa.z;ja[Oa+7]=qa.w;ja[Oa+8]=E.x;ja[Oa+9]=E.y;ja[Oa+10]=E.z;ja[Oa+11]=E.w;ja[Oa+12]=W.x;ja[Oa+13]=W.y;ja[Oa+14]=W.z;ja[Oa+15]=W.w;Oa+=16}if(ub&&ta)if(K.length==4&&kb)for(W=0;W<4;W++){L=K[W];T[cb]=L.x;T[cb+1]=L.y;T[cb+2]=L.z;cb+=3}else for(W=0;W<4;W++){T[cb]=L.x;T[cb+1]=L.y;T[cb+2]=L.z;cb+=3}if(tb&&za!==undefined&&Fa)for(W=0;W<4;W++){K=za[W];lb[jb]=K.u;lb[jb+1]=K.v;jb+=2}if(tb&&db!==undefined&&Fa)for(W=0;W<4;W++){K=db[W];$a[gb]=K.u;$a[gb+1]=K.v;
|
|
|
-gb+=2}if(ib){Ya[bb]=Pa;Ya[bb+1]=Pa+1;Ya[bb+2]=Pa+3;Ya[bb+3]=Pa+1;Ya[bb+4]=Pa+2;Ya[bb+5]=Pa+3;bb+=6;Wa[eb]=Pa;Wa[eb+1]=Pa+1;Wa[eb+2]=Pa;Wa[eb+3]=Pa+3;Wa[eb+4]=Pa+1;Wa[eb+5]=Pa+2;Wa[eb+6]=Pa+2;Wa[eb+7]=Pa+3;eb+=8;Pa+=4}}}if(ob){H=0;for(J=ob.length;H<J;H++){Ya[bb]=ob[H].a;Ya[bb+1]=ob[H].b;Ya[bb+2]=ob[H].c;Ya[bb+3]=ob[H].a;Ya[bb+4]=ob[H].c;Ya[bb+5]=ob[H].d;bb+=6}}if(hb){e.bindBuffer(e.ARRAY_BUFFER,w.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,Va,P)}if(Ma)for(fb in Ma){R=Ma[fb];if(R.needsUpdate){e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
-R.buffer);e.bufferData(e.ARRAY_BUFFER,R.array,P);R.needsUpdate=!1}}if(xb){$=0;for(R=mb.length;$<R;$++){e.bindBuffer(e.ARRAY_BUFFER,w.__webglMorphTargetsBuffers[$]);e.bufferData(e.ARRAY_BUFFER,V[$],P)}}if(wb&&Da>0){e.bindBuffer(e.ARRAY_BUFFER,w.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,na,P)}if(ub){e.bindBuffer(e.ARRAY_BUFFER,w.__webglNormalBuffer);e.bufferData(e.ARRAY_BUFFER,T,P)}if(vb&&Za.hasTangents){e.bindBuffer(e.ARRAY_BUFFER,w.__webglTangentBuffer);e.bufferData(e.ARRAY_BUFFER,ja,P)}if(tb&&
|
|
|
-jb>0){e.bindBuffer(e.ARRAY_BUFFER,w.__webglUVBuffer);e.bufferData(e.ARRAY_BUFFER,lb,P)}if(tb&&gb>0){e.bindBuffer(e.ARRAY_BUFFER,w.__webglUV2Buffer);e.bufferData(e.ARRAY_BUFFER,$a,P)}if(ib){e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,w.__webglFaceBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,Ya,P);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,w.__webglLineBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,Wa,P)}if(S>0){e.bindBuffer(e.ARRAY_BUFFER,w.__webglSkinVertexABuffer);e.bufferData(e.ARRAY_BUFFER,Y,P);e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
-w.__webglSkinVertexBBuffer);e.bufferData(e.ARRAY_BUFFER,ya,P);e.bindBuffer(e.ARRAY_BUFFER,w.__webglSkinIndicesBuffer);e.bufferData(e.ARRAY_BUFFER,xa,P);e.bindBuffer(e.ARRAY_BUFFER,w.__webglSkinWeightsBuffer);e.bufferData(e.ARRAY_BUFFER,ha,P)}}}z.__dirtyVertices=!1;z.__dirtyMorphTargets=!1;z.__dirtyElements=!1;z.__dirtyUvs=!1;z.__dirtyNormals=!1;z.__dirtyTangents=!1;z.__dirtyColors=!1}else if(m instanceof THREE.Ribbon){z=m.geometry;if(z.__dirtyVertices||z.__dirtyColors){m=z;B=e.DYNAMIC_DRAW;La=m.vertices;
|
|
|
-w=m.colors;ta=La.length;P=w.length;za=m.__vertexArray;H=m.__colorArray;db=m.__dirtyColors;if(m.__dirtyVertices){for(J=0;J<ta;J++){Fa=La[J].position;y=J*3;za[y]=Fa.x;za[y+1]=Fa.y;za[y+2]=Fa.z}e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,za,B)}if(db){for(J=0;J<P;J++){color=w[J];y=J*3;H[y]=color.r;H[y+1]=color.g;H[y+2]=color.b}e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,H,B)}}z.__dirtyVertices=!1;z.__dirtyColors=!1}else if(m instanceof
|
|
|
-THREE.Line){z=m.geometry;if(z.__dirtyVertices||z.__dirtyColors){m=z;B=e.DYNAMIC_DRAW;La=m.vertices;w=m.colors;ta=La.length;P=w.length;za=m.__vertexArray;H=m.__colorArray;db=m.__dirtyColors;if(m.__dirtyVertices){for(J=0;J<ta;J++){Fa=La[J].position;y=J*3;za[y]=Fa.x;za[y+1]=Fa.y;za[y+2]=Fa.z}e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,za,B)}if(db){for(J=0;J<P;J++){color=w[J];y=J*3;H[y]=color.r;H[y+1]=color.g;H[y+2]=color.b}e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);
|
|
|
-e.bufferData(e.ARRAY_BUFFER,H,B)}}z.__dirtyVertices=!1;z.__dirtyColors=!1}else if(m instanceof THREE.ParticleSystem){z=m.geometry;(z.__dirtyVertices||z.__dirtyColors||m.sortParticles)&&d(z,e.DYNAMIC_DRAW,m);z.__dirtyVertices=!1;z.__dirtyColors=!1}}function U(m){function B(qa){var W=[];z=0;for(w=qa.length;z<w;z++)qa[z]==undefined?W.push("undefined"):W.push(qa[z].id);return W.join("_")}var z,w,y,P,H,J,K,E,L={},X=m.morphTargets!==undefined?m.morphTargets.length:0;m.geometryGroups={};y=0;for(P=m.faces.length;y<
|
|
|
-P;y++){H=m.faces[y];J=H.materials;K=B(J);L[K]==undefined&&(L[K]={hash:K,counter:0});E=L[K].hash+"_"+L[K].counter;m.geometryGroups[E]==undefined&&(m.geometryGroups[E]={faces:[],materials:J,vertices:0,numMorphTargets:X});H=H instanceof THREE.Face3?3:4;if(m.geometryGroups[E].vertices+H>65535){L[K].counter+=1;E=L[K].hash+"_"+L[K].counter;m.geometryGroups[E]==undefined&&(m.geometryGroups[E]={faces:[],materials:J,vertices:0,numMorphTargets:X})}m.geometryGroups[E].faces.push(y);m.geometryGroups[E].vertices+=
|
|
|
-H}}function D(m,B,z){m.push({buffer:B,object:z,opaque:{list:[],count:0},transparent:{list:[],count:0}})}function M(m){if(m!=Ca){switch(m){case THREE.AdditiveBlending:e.blendEquation(e.FUNC_ADD);e.blendFunc(e.SRC_ALPHA,e.ONE);break;case THREE.SubtractiveBlending:e.blendEquation(e.FUNC_ADD);e.blendFunc(e.ZERO,e.ONE_MINUS_SRC_COLOR);break;case THREE.MultiplyBlending:e.blendEquation(e.FUNC_ADD);e.blendFunc(e.ZERO,e.SRC_COLOR);break;default:e.blendEquationSeparate(e.FUNC_ADD,e.FUNC_ADD);e.blendFuncSeparate(e.SRC_ALPHA,
|
|
|
-e.ONE_MINUS_SRC_ALPHA,e.ONE,e.ONE_MINUS_SRC_ALPHA)}Ca=m}}function O(m,B,z){if((z.width&z.width-1)==0&&(z.height&z.height-1)==0){e.texParameteri(m,e.TEXTURE_WRAP_S,da(B.wrapS));e.texParameteri(m,e.TEXTURE_WRAP_T,da(B.wrapT));e.texParameteri(m,e.TEXTURE_MAG_FILTER,da(B.magFilter));e.texParameteri(m,e.TEXTURE_MIN_FILTER,da(B.minFilter));e.generateMipmap(m)}else{e.texParameteri(m,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE);e.texParameteri(m,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE);e.texParameteri(m,e.TEXTURE_MAG_FILTER,
|
|
|
-Aa(B.magFilter));e.texParameteri(m,e.TEXTURE_MIN_FILTER,Aa(B.minFilter))}}function Q(m,B){if(m.needsUpdate){if(m.__webglInit){e.bindTexture(e.TEXTURE_2D,m.__webglTexture);e.texSubImage2D(e.TEXTURE_2D,0,0,0,e.RGBA,e.UNSIGNED_BYTE,m.image)}else{m.__webglTexture=e.createTexture();e.bindTexture(e.TEXTURE_2D,m.__webglTexture);e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,m.image);m.__webglInit=!0}O(e.TEXTURE_2D,m,m.image);e.bindTexture(e.TEXTURE_2D,null);m.needsUpdate=!1}e.activeTexture(e.TEXTURE0+
|
|
|
-B);e.bindTexture(e.TEXTURE_2D,m.__webglTexture)}function Ia(m){if(m&&!m.__webglFramebuffer){m.__webglFramebuffer=e.createFramebuffer();m.__webglRenderbuffer=e.createRenderbuffer();m.__webglTexture=e.createTexture();e.bindRenderbuffer(e.RENDERBUFFER,m.__webglRenderbuffer);e.renderbufferStorage(e.RENDERBUFFER,e.DEPTH_COMPONENT16,m.width,m.height);e.bindTexture(e.TEXTURE_2D,m.__webglTexture);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,da(m.wrapS));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,da(m.wrapT));
|
|
|
-e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,da(m.magFilter));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,da(m.minFilter));e.texImage2D(e.TEXTURE_2D,0,da(m.format),m.width,m.height,0,da(m.format),da(m.type),null);e.bindFramebuffer(e.FRAMEBUFFER,m.__webglFramebuffer);e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,m.__webglTexture,0);e.framebufferRenderbuffer(e.FRAMEBUFFER,e.DEPTH_ATTACHMENT,e.RENDERBUFFER,m.__webglRenderbuffer);e.bindTexture(e.TEXTURE_2D,null);e.bindRenderbuffer(e.RENDERBUFFER,
|
|
|
-null);e.bindFramebuffer(e.FRAMEBUFFER,null)}var B,z;if(m){B=m.__webglFramebuffer;z=m.width;m=m.height}else{B=null;z=Ga;m=la}if(B!=Ja){e.bindFramebuffer(e.FRAMEBUFFER,B);e.viewport(aa,ra,z,m);Ja=B}}function ua(m,B){var z;if(m=="fragment")z=e.createShader(e.FRAGMENT_SHADER);else m=="vertex"&&(z=e.createShader(e.VERTEX_SHADER));e.shaderSource(z,B);e.compileShader(z);if(!e.getShaderParameter(z,e.COMPILE_STATUS)){console.error(e.getShaderInfoLog(z));console.error(B);return null}return z}function Aa(m){switch(m){case THREE.NearestFilter:case THREE.NearestMipMapNearestFilter:case THREE.NearestMipMapLinearFilter:return e.NEAREST;
|
|
|
-default:return e.LINEAR}}function da(m){switch(m){case THREE.RepeatWrapping:return e.REPEAT;case THREE.ClampToEdgeWrapping:return e.CLAMP_TO_EDGE;case THREE.MirroredRepeatWrapping:return e.MIRRORED_REPEAT;case THREE.NearestFilter:return e.NEAREST;case THREE.NearestMipMapNearestFilter:return e.NEAREST_MIPMAP_NEAREST;case THREE.NearestMipMapLinearFilter:return e.NEAREST_MIPMAP_LINEAR;case THREE.LinearFilter:return e.LINEAR;case THREE.LinearMipMapNearestFilter:return e.LINEAR_MIPMAP_NEAREST;case THREE.LinearMipMapLinearFilter:return e.LINEAR_MIPMAP_LINEAR;
|
|
|
+THREE.WebGLRenderer=function(b){function d(m,A,x){var u,w,O,F=m.vertices,G=F.length,H=m.colors,D=H.length,I=m.__vertexArray,V=m.__colorArray,oa=m.__sortArray,U=m.__dirtyVertices,Da=m.__dirtyColors;if(x.sortParticles){Fa.multiplySelf(x.matrixWorld);for(u=0;u<G;u++){w=F[u].position;Va.copy(w);Fa.multiplyVector3(Va);oa[u]=[Va.z,u]}oa.sort(function(Ja,ra){return ra[0]-Ja[0]});for(u=0;u<G;u++){w=F[oa[u][1]].position;O=u*3;I[O]=w.x;I[O+1]=w.y;I[O+2]=w.z}for(u=0;u<D;u++){O=u*3;color=H[oa[u][1]];V[O]=color.r;
|
|
|
+V[O+1]=color.g;V[O+2]=color.b}}else{if(U)for(u=0;u<G;u++){w=F[u].position;O=u*3;I[O]=w.x;I[O+1]=w.y;I[O+2]=w.z}if(Da)for(u=0;u<D;u++){color=H[u];O=u*3;V[O]=color.r;V[O+1]=color.g;V[O+2]=color.b}}if(U||x.sortParticles){e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,I,A)}if(Da||x.sortParticles){e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,V,A)}}function c(m,A){m.uniforms=Uniforms.clone(A.uniforms);m.vertexShader=A.vertexShader;m.fragmentShader=
|
|
|
+A.fragmentShader}function f(m,A,x,u,w){u.__webglProgram||ua.initMaterial(u,A,x,w);var O=u.program,F=O.uniforms,G=u.uniforms;if(O!=za){e.useProgram(O);za=O}e.uniformMatrix4fv(F.projectionMatrix,!1,Ra);if(x&&(u instanceof THREE.MeshBasicMaterial||u instanceof THREE.MeshLambertMaterial||u instanceof THREE.MeshPhongMaterial||u instanceof THREE.LineBasicMaterial||u instanceof THREE.ParticleBasicMaterial||u.fog)){G.fogColor.value.setHex(x.color.hex);if(x instanceof THREE.Fog){G.fogNear.value=x.near;G.fogFar.value=
|
|
|
+x.far}else if(x instanceof THREE.FogExp2)G.fogDensity.value=x.density}if(u instanceof THREE.MeshPhongMaterial||u instanceof THREE.MeshLambertMaterial||u.lights){var H,D,I=0,V=0,oa=0,U,Da,Ja,ra,xa=Sa,bb=xa.directional.colors,X=xa.directional.positions,da=xa.point.colors,ma=xa.point.positions,La=xa.point.distances,Y=0,P=0;x=D=ra=0;for(H=A.length;x<H;x++){D=A[x];U=D.color;Da=D.position;Ja=D.intensity;ra=D.distance;if(D instanceof THREE.AmbientLight){I+=U.r;V+=U.g;oa+=U.b}else if(D instanceof THREE.DirectionalLight){ra=
|
|
|
+Y*3;bb[ra]=U.r*Ja;bb[ra+1]=U.g*Ja;bb[ra+2]=U.b*Ja;X[ra]=Da.x;X[ra+1]=Da.y;X[ra+2]=Da.z;Y+=1}else if(D instanceof THREE.PointLight){D=P*3;da[D]=U.r*Ja;da[D+1]=U.g*Ja;da[D+2]=U.b*Ja;ma[D]=Da.x;ma[D+1]=Da.y;ma[D+2]=Da.z;La[P]=ra;P+=1}}for(x=Y*3;x<bb.length;x++)bb[x]=0;for(x=P*3;x<da.length;x++)da[x]=0;xa.point.length=P;xa.directional.length=Y;xa.ambient[0]=I;xa.ambient[1]=V;xa.ambient[2]=oa;x=Sa;G.enableLighting.value=x.directional.length+x.point.length;G.ambientLightColor.value=x.ambient;G.directionalLightColor.value=
|
|
|
+x.directional.colors;G.directionalLightDirection.value=x.directional.positions;G.pointLightColor.value=x.point.colors;G.pointLightPosition.value=x.point.positions;G.pointLightDistance.value=x.point.distances}if(u instanceof THREE.MeshBasicMaterial||u instanceof THREE.MeshLambertMaterial||u instanceof THREE.MeshPhongMaterial){G.diffuse.value.setRGB(u.color.r,u.color.g,u.color.b);G.opacity.value=u.opacity;G.map.texture=u.map;G.lightMap.texture=u.lightMap;G.envMap.texture=u.envMap;G.reflectivity.value=
|
|
|
+u.reflectivity;G.refractionRatio.value=u.refractionRatio;G.combine.value=u.combine;G.useRefract.value=u.envMap&&u.envMap.mapping instanceof THREE.CubeRefractionMapping}if(u instanceof THREE.LineBasicMaterial){G.diffuse.value.setRGB(u.color.r,u.color.g,u.color.b);G.opacity.value=u.opacity}else if(u instanceof THREE.ParticleBasicMaterial){G.psColor.value.setRGB(u.color.r,u.color.g,u.color.b);G.opacity.value=u.opacity;G.size.value=u.size;G.scale.value=ea.height/2;G.map.texture=u.map}else if(u instanceof
|
|
|
+THREE.MeshPhongMaterial){G.ambient.value.setRGB(u.ambient.r,u.ambient.g,u.ambient.b);G.specular.value.setRGB(u.specular.r,u.specular.g,u.specular.b);G.shininess.value=u.shininess}else if(u instanceof THREE.MeshDepthMaterial){G.mNear.value=m.near;G.mFar.value=m.far;G.opacity.value=u.opacity}else if(u instanceof THREE.MeshNormalMaterial)G.opacity.value=u.opacity;for(var Qa in G)if(V=O.uniforms[Qa]){H=G[Qa];I=H.type;x=H.value;if(I=="i")e.uniform1i(V,x);else if(I=="f")e.uniform1f(V,x);else if(I=="fv1")e.uniform1fv(V,
|
|
|
+x);else if(I=="fv")e.uniform3fv(V,x);else if(I=="v2")e.uniform2f(V,x.x,x.y);else if(I=="v3")e.uniform3f(V,x.x,x.y,x.z);else if(I=="v4")e.uniform4f(V,x.x,x.y,x.z,x.w);else if(I=="c")e.uniform3f(V,x.r,x.g,x.b);else if(I=="t"){e.uniform1i(V,x);if(H=H.texture)if(H.image instanceof Array&&H.image.length==6){if(H.image.length==6){if(H.needsUpdate){if(H.__webglInit){e.bindTexture(e.TEXTURE_CUBE_MAP,H.image.__webglTextureCube);for(I=0;I<6;++I)e.texSubImage2D(e.TEXTURE_CUBE_MAP_POSITIVE_X+I,0,0,0,e.RGBA,e.UNSIGNED_BYTE,
|
|
|
+H.image[I])}else{H.image.__webglTextureCube=e.createTexture();e.bindTexture(e.TEXTURE_CUBE_MAP,H.image.__webglTextureCube);for(I=0;I<6;++I)e.texImage2D(e.TEXTURE_CUBE_MAP_POSITIVE_X+I,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,H.image[I]);H.__webglInit=!0}L(e.TEXTURE_CUBE_MAP,H,H.image[0]);e.bindTexture(e.TEXTURE_CUBE_MAP,null);H.needsUpdate=!1}e.activeTexture(e.TEXTURE0+x);e.bindTexture(e.TEXTURE_CUBE_MAP,H.image.__webglTextureCube)}}else M(H,x)}}e.uniformMatrix4fv(F.modelViewMatrix,!1,w._modelViewMatrixArray);
|
|
|
+e.uniformMatrix3fv(F.normalMatrix,!1,w._normalMatrixArray);(u instanceof THREE.MeshShaderMaterial||u instanceof THREE.MeshPhongMaterial||u.envMap)&&e.uniform3f(F.cameraPosition,m.position.x,m.position.y,m.position.z);(u instanceof THREE.MeshShaderMaterial||u.envMap||u.skinning)&&e.uniformMatrix4fv(F.objectMatrix,!1,w._objectMatrixArray);(u instanceof THREE.MeshPhongMaterial||u instanceof THREE.MeshLambertMaterial||u instanceof THREE.MeshShaderMaterial||u.skinning)&&e.uniformMatrix4fv(F.viewMatrix,
|
|
|
+!1,Za);if(u instanceof THREE.ShadowVolumeDynamicMaterial){m=G.directionalLightDirection.value;m[0]=-A.position.x;m[1]=-A.position.y;m[2]=-A.position.z;e.uniform3fv(F.directionalLightDirection,m);e.uniformMatrix4fv(F.objectMatrix,!1,w._objectMatrixArray);e.uniformMatrix4fv(F.viewMatrix,!1,Za)}if(u.skinning){e.uniformMatrix4fv(F.cameraInverseMatrix,!1,Za);e.uniformMatrix4fv(F.boneGlobalMatrices,!1,w.boneMatrices)}return O}function g(m,A,x,u,w,O){if(u.opacity!=0){var F;m=f(m,A,x,u,O).attributes;if(u.morphTargets){A=
|
|
|
+u.program.attributes;O.morphTargetBase!==-1?e.bindBuffer(e.ARRAY_BUFFER,w.__webglMorphTargetsBuffers[O.morphTargetBase]):e.bindBuffer(e.ARRAY_BUFFER,w.__webglVertexBuffer);e.vertexAttribPointer(A.position,3,e.FLOAT,!1,0,0);if(O.morphTargetForcedOrder.length){x=0;for(var G=O.morphTargetForcedOrder,H=O.morphTargetInfluences;x<u.numSupportedMorphTargets&&x<G.length;){e.bindBuffer(e.ARRAY_BUFFER,w.__webglMorphTargetsBuffers[G[x]]);e.vertexAttribPointer(A["morphTarget"+x],3,e.FLOAT,!1,0,0);O.__webglMorphTargetInfluences[x]=
|
|
|
+H[G[x]];x++}}else{G=[];var D=-1,I=0;H=O.morphTargetInfluences;var V,oa=H.length;x=0;for(O.morphTargetBase!==-1&&(G[O.morphTargetBase]=!0);x<u.numSupportedMorphTargets;){for(V=0;V<oa;V++)if(!G[V]&&H[V]>D){I=V;D=H[I]}e.bindBuffer(e.ARRAY_BUFFER,w.__webglMorphTargetsBuffers[I]);e.vertexAttribPointer(A["morphTarget"+x],3,e.FLOAT,!1,0,0);O.__webglMorphTargetInfluences[x]=D;G[I]=1;D=-1;x++}}e.uniform1fv(u.program.uniforms.morphTargetInfluences,O.__webglMorphTargetInfluences)}else{e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
+w.__webglVertexBuffer);e.vertexAttribPointer(m.position,3,e.FLOAT,!1,0,0)}if(w.__webglCustomAttributes)for(F in w.__webglCustomAttributes)if(m[F]>=0){A=w.__webglCustomAttributes[F];e.bindBuffer(e.ARRAY_BUFFER,A.buffer);e.vertexAttribPointer(m[F],A.size,e.FLOAT,!1,0,0)}if(m.color>=0){e.bindBuffer(e.ARRAY_BUFFER,w.__webglColorBuffer);e.vertexAttribPointer(m.color,3,e.FLOAT,!1,0,0)}if(m.normal>=0){e.bindBuffer(e.ARRAY_BUFFER,w.__webglNormalBuffer);e.vertexAttribPointer(m.normal,3,e.FLOAT,!1,0,0)}if(m.tangent>=
|
|
|
+0){e.bindBuffer(e.ARRAY_BUFFER,w.__webglTangentBuffer);e.vertexAttribPointer(m.tangent,4,e.FLOAT,!1,0,0)}if(m.uv>=0)if(w.__webglUVBuffer){e.bindBuffer(e.ARRAY_BUFFER,w.__webglUVBuffer);e.vertexAttribPointer(m.uv,2,e.FLOAT,!1,0,0);e.enableVertexAttribArray(m.uv)}else e.disableVertexAttribArray(m.uv);if(m.uv2>=0)if(w.__webglUV2Buffer){e.bindBuffer(e.ARRAY_BUFFER,w.__webglUV2Buffer);e.vertexAttribPointer(m.uv2,2,e.FLOAT,!1,0,0);e.enableVertexAttribArray(m.uv2)}else e.disableVertexAttribArray(m.uv2);
|
|
|
+if(u.skinning&&m.skinVertexA>=0&&m.skinVertexB>=0&&m.skinIndex>=0&&m.skinWeight>=0){e.bindBuffer(e.ARRAY_BUFFER,w.__webglSkinVertexABuffer);e.vertexAttribPointer(m.skinVertexA,4,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,w.__webglSkinVertexBBuffer);e.vertexAttribPointer(m.skinVertexB,4,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,w.__webglSkinIndicesBuffer);e.vertexAttribPointer(m.skinIndex,4,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,w.__webglSkinWeightsBuffer);e.vertexAttribPointer(m.skinWeight,
|
|
|
+4,e.FLOAT,!1,0,0)}if(O instanceof THREE.Mesh)if(u.wireframe){e.lineWidth(u.wireframeLinewidth);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,w.__webglLineBuffer);e.drawElements(e.LINES,w.__webglLineCount,e.UNSIGNED_SHORT,0)}else{e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,w.__webglFaceBuffer);e.drawElements(e.TRIANGLES,w.__webglFaceCount,e.UNSIGNED_SHORT,0)}else if(O instanceof THREE.Line){O=O.type==THREE.LineStrip?e.LINE_STRIP:e.LINES;e.lineWidth(u.linewidth);e.drawArrays(O,0,w.__webglLineCount)}else if(O instanceof
|
|
|
+THREE.ParticleSystem)e.drawArrays(e.POINTS,0,w.__webglParticleCount);else O instanceof THREE.Ribbon&&e.drawArrays(e.TRIANGLE_STRIP,0,w.__webglVertexCount)}}function h(m,A){if(!m.__webglVertexBuffer)m.__webglVertexBuffer=e.createBuffer();if(!m.__webglNormalBuffer)m.__webglNormalBuffer=e.createBuffer();if(m.hasPos){e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,m.positionArray,e.DYNAMIC_DRAW);e.enableVertexAttribArray(A.attributes.position);e.vertexAttribPointer(A.attributes.position,
|
|
|
+3,e.FLOAT,!1,0,0)}if(m.hasNormal){e.bindBuffer(e.ARRAY_BUFFER,m.__webglNormalBuffer);e.bufferData(e.ARRAY_BUFFER,m.normalArray,e.DYNAMIC_DRAW);e.enableVertexAttribArray(A.attributes.normal);e.vertexAttribPointer(A.attributes.normal,3,e.FLOAT,!1,0,0)}e.drawArrays(e.TRIANGLES,0,m.count);m.count=0}function j(m){if(ca!=m.doubleSided){m.doubleSided?e.disable(e.CULL_FACE):e.enable(e.CULL_FACE);ca=m.doubleSided}if(ta!=m.flipSided){m.flipSided?e.frontFace(e.CW):e.frontFace(e.CCW);ta=m.flipSided}}function k(m){if(ia!=
|
|
|
+m){m?e.enable(e.DEPTH_TEST):e.disable(e.DEPTH_TEST);ia=m}}function n(m){na[0].set(m.n41-m.n11,m.n42-m.n12,m.n43-m.n13,m.n44-m.n14);na[1].set(m.n41+m.n11,m.n42+m.n12,m.n43+m.n13,m.n44+m.n14);na[2].set(m.n41+m.n21,m.n42+m.n22,m.n43+m.n23,m.n44+m.n24);na[3].set(m.n41-m.n21,m.n42-m.n22,m.n43-m.n23,m.n44-m.n24);na[4].set(m.n41-m.n31,m.n42-m.n32,m.n43-m.n33,m.n44-m.n34);na[5].set(m.n41+m.n31,m.n42+m.n32,m.n43+m.n33,m.n44+m.n34);var A;for(m=0;m<6;m++){A=na[m];A.divideScalar(Math.sqrt(A.x*A.x+A.y*A.y+A.z*
|
|
|
+A.z))}}function p(m){for(var A=m.matrixWorld,x=-m.geometry.boundingSphere.radius*Math.max(m.scale.x,Math.max(m.scale.y,m.scale.z)),u=0;u<6;u++){m=na[u].x*A.n14+na[u].y*A.n24+na[u].z*A.n34+na[u].w;if(m<=x)return!1}return!0}function o(m,A){m.list[m.count]=A;m.count+=1}function t(m){var A,x,u=m.object,w=m.opaque,O=m.transparent;O.count=0;m=w.count=0;for(A=u.materials.length;m<A;m++){x=u.materials[m];x.transparent?o(O,x):o(w,x)}}function y(m){var A,x,u,w,O=m.object,F=m.buffer,G=m.opaque,H=m.transparent;
|
|
|
+H.count=0;m=G.count=0;for(u=O.materials.length;m<u;m++){A=O.materials[m];if(A instanceof THREE.MeshFaceMaterial){A=0;for(x=F.materials.length;A<x;A++)(w=F.materials[A])&&(w.transparent?o(H,w):o(G,w))}else(w=A)&&(w.transparent?o(H,w):o(G,w))}}function v(m,A){return A.z-m.z}function B(m){e.enable(e.POLYGON_OFFSET_FILL);e.polygonOffset(0.1,1);e.enable(e.STENCIL_TEST);e.depthMask(!1);e.colorMask(!1,!1,!1,!1);e.stencilFunc(e.ALWAYS,1,255);e.stencilOpSeparate(e.BACK,e.KEEP,e.INCR,e.KEEP);e.stencilOpSeparate(e.FRONT,
|
|
|
+e.KEEP,e.DECR,e.KEEP);var A,x=m.lights.length,u,w=m.lights,O=[],F,G,H,D,I,V=m.__webglShadowVolumes.length;for(A=0;A<x;A++){u=m.lights[A];if(u instanceof THREE.DirectionalLight){O[0]=-u.position.x;O[1]=-u.position.y;O[2]=-u.position.z;for(I=0;I<V;I++){u=m.__webglShadowVolumes[I].object;F=m.__webglShadowVolumes[I].buffer;G=u.materials[0];G.program||ua.initMaterial(G,w,undefined,u);G=G.program;H=G.uniforms;D=G.attributes;if(za!==G){e.useProgram(G);za=G;e.uniformMatrix4fv(H.projectionMatrix,!1,Ra);e.uniformMatrix4fv(H.viewMatrix,
|
|
|
+!1,Za);e.uniform3fv(H.directionalLightDirection,O)}u.matrixWorld.flattenToArray(u._objectMatrixArray);e.uniformMatrix4fv(H.objectMatrix,!1,u._objectMatrixArray);e.bindBuffer(e.ARRAY_BUFFER,F.__webglVertexBuffer);e.vertexAttribPointer(D.position,3,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,F.__webglNormalBuffer);e.vertexAttribPointer(D.normal,3,e.FLOAT,!1,0,0);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,F.__webglFaceBuffer);e.cullFace(e.FRONT);e.drawElements(e.TRIANGLES,F.__webglFaceCount,e.UNSIGNED_SHORT,
|
|
|
+0);e.cullFace(e.BACK);e.drawElements(e.TRIANGLES,F.__webglFaceCount,e.UNSIGNED_SHORT,0)}}}e.disable(e.POLYGON_OFFSET_FILL);e.colorMask(!0,!0,!0,!0);e.stencilFunc(e.NOTEQUAL,0,255);e.stencilOp(e.KEEP,e.KEEP,e.KEEP);e.disable(e.DEPTH_TEST);Aa="";za=ga.program;e.useProgram(ga.program);e.uniformMatrix4fv(ga.projectionLocation,!1,Ra);e.uniform1f(ga.darknessLocation,ga.darkness);e.bindBuffer(e.ARRAY_BUFFER,ga.vertexBuffer);e.vertexAttribPointer(ga.vertexLocation,3,e.FLOAT,!1,0,0);e.enableVertexAttribArray(ga.vertexLocation);
|
|
|
+e.blendFunc(e.ONE,e.ONE_MINUS_SRC_ALPHA);e.blendEquation(e.FUNC_ADD);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ga.elementBuffer);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0);e.disable(e.STENCIL_TEST);e.enable(e.DEPTH_TEST);e.depthMask(Ia)}function C(m,A){var x,u,w,O=m.__webglLensFlares.length,F,G,H;F=new THREE.Vector3;var D=ja/Ea;G=Ea*0.5;H=ja*0.5;var I=16/ja,V=[I*D,I],oa=[1,1,0];I=[1,1];var U,Da=ka.readBackPixels,Ja,ra,xa=ka.uniforms;x=ka.attributes;e.useProgram(ka.program);za=ka.program;Aa="";e.uniform1i(xa.map,
|
|
|
+0);e.activeTexture(e.TEXTURE0);e.uniform1f(xa.opacity,1);e.uniform1f(xa.rotation,0);e.uniform2fv(xa.scale,V);e.bindBuffer(e.ARRAY_BUFFER,ka.vertexBuffer);e.vertexAttribPointer(x.vertex,2,e.FLOAT,!1,16,0);e.vertexAttribPointer(x.uv,2,e.FLOAT,!1,16,8);e.bindTexture(e.TEXTURE_2D,ka.tempTexture);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ka.elementBuffer);e.disable(e.CULL_FACE);e.depthMask(!1);for(w=0;w<O;w++){x=m.__webglLensFlares[w].object;F.set(x.matrixWorld.n14,x.matrixWorld.n24,x.matrixWorld.n34);A.matrixWorldInverse.multiplyVector3(F);
|
|
|
+u=F.z;A.projectionMatrix.multiplyVector3(F);oa[0]=F.x;oa[1]=F.y;oa[2]=F.z;I[0]=oa[0]*G+G;I[1]=oa[1]*H+H;e.copyTexSubImage2D(e.TEXTURE_2D,0,0,0,I[0]-8,I[1]-8,16,16);e.uniform3fv(xa.screenPosition,oa);e.uniform1i(xa.renderPink,1);e.enable(e.DEPTH_TEST);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0);try{e.readPixels(I[0]-8,I[1]-8,16,16,e.RGBA,e.UNSIGNED_BYTE,ka.readBackPixels)}catch(bb){console.log("WebGLRenderer.renderLensFlare: readPixels failed!")}e.getError()&&console.log("WebGLRenderer.renderLensFlare: readPixels failed!");
|
|
|
+sampleDistance=parseInt(5*(1-Math.max(0,Math.min(-u,A.far))/A.far),10)+2;u=sampleDistance*4;U=sampleDistance*64;ra=0;Ja=28-u+(448-U);ka.readBackPixels[Ja+0]===255&&ka.readBackPixels[Ja+1]===0&&ka.readBackPixels[Ja+2]===255&&(ra+=0.2);Ja=28+u+(448-U);Da[Ja+0]===255&&Da[Ja+1]===0&&Da[Ja+2]===255&&(ra+=0.2);Ja=28+u+(448+U);Da[Ja+0]===255&&Da[Ja+1]===0&&Da[Ja+2]===255&&(ra+=0.2);Ja=28-u+(448+U);Da[Ja+0]===255&&Da[Ja+1]===0&&Da[Ja+2]===255&&(ra+=0.2);Ja=476;Da[Ja+0]===255&&Da[Ja+1]===0&&Da[Ja+2]===255&&
|
|
|
+(ra+=0.2);x.positionScreen.x=oa[0];x.positionScreen.y=oa[1];x.positionScreen.z=oa[2];x.customUpdateCallback?x.customUpdateCallback(ra,x):x.updateLensFlares(ra);e.uniform1i(xa.renderPink,0);e.disable(e.DEPTH_TEST);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)}for(w=0;w<O;w++){x=m.__webglLensFlares[w].object;F=0;for(G=x.lensFlares.length;F<G;F++){H=x.lensFlares[F];if(H.opacity>0.0010&&H.scale>0.0010){oa[0]=H.x;oa[1]=H.y;oa[2]=H.z;I=H.size*H.scale/ja;V[0]=I*D;V[1]=I;e.uniform3fv(xa.screenPosition,
|
|
|
+oa);e.uniform1f(xa.rotation,H.rotation);e.uniform2fv(xa.scale,V);e.uniform1f(xa.opacity,H.opacity);K(H.blending);M(H.texture,0);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)}}}e.enable(e.CULL_FACE);e.enable(e.DEPTH_TEST);e.depthMask(Ia)}function E(m,A){m._modelViewMatrix.multiplyToArray(A.matrixWorldInverse,m.matrixWorld,m._modelViewMatrixArray);THREE.Matrix4.makeInvert3x3(m._modelViewMatrix).transposeIntoArray(m._normalMatrixArray)}function J(m){var A,x,u,w,O;if(m instanceof THREE.Mesh){x=m.geometry;
|
|
|
+for(A in x.geometryGroups){u=x.geometryGroups[A];O=!1;for(w in u.__webglCustomAttributes)if(u.__webglCustomAttributes[w].needsUpdate){O=!0;break}if(x.__dirtyVertices||x.__dirtyMorphTargets||x.__dirtyElements||x.__dirtyUvs||x.__dirtyNormals||x.__dirtyColors||x.__dirtyTangents||O){O=e.DYNAMIC_DRAW;var F=void 0,G=void 0,H=void 0,D=void 0;H=void 0;var I=void 0,V=void 0,oa=void 0,U=void 0,Da=void 0,Ja=void 0,ra=void 0,xa=void 0,bb=void 0,X=void 0,da=void 0,ma=void 0,La=void 0;V=void 0;oa=void 0;D=void 0;
|
|
|
+U=void 0;D=void 0;X=void 0;da=void 0;V=void 0;X=void 0;da=void 0;ma=void 0;La=void 0;X=void 0;da=void 0;ma=void 0;La=void 0;X=void 0;da=void 0;ma=void 0;La=void 0;X=void 0;da=void 0;ma=void 0;D=void 0;U=void 0;I=void 0;H=void 0;H=void 0;var Y=void 0,P=void 0,Qa=void 0,db=void 0,Na=0,Oa=0,hb=0,eb=0,$a=0,ab=0,Ma=0,cb=0,Ba=0,Q=0,Pa=0;Y=0;var Ta=u.__vertexArray,jb=u.__uvArray,Ya=u.__uv2Array,R=u.__normalArray,ha=u.__tangentArray,la=u.__colorArray,W=u.__skinVertexAArray,wa=u.__skinVertexBArray,va=u.__skinIndexArray,
|
|
|
+fa=u.__skinWeightArray,S=u.__morphTargetsArrays,Ka=u.__webglCustomAttributes;P=void 0;var Wa=u.__faceArray,Ua=u.__lineArray,ib=u.__needsSmoothNormals;Ja=u.__vertexColorType;Da=u.__uvType;ra=u.__normalType;var Xa=m.geometry,fb=Xa.__dirtyVertices,gb=Xa.__dirtyElements,rb=Xa.__dirtyUvs,sb=Xa.__dirtyNormals,tb=Xa.__dirtyTangents,ub=Xa.__dirtyColors,vb=Xa.__dirtyMorphTargets,nb=Xa.vertices,wb=u.faces,zb=Xa.faces,xb=Xa.faceVertexUvs[0],yb=Xa.faceVertexUvs[1],ob=Xa.skinVerticesA,pb=Xa.skinVerticesB,qb=Xa.skinIndices,
|
|
|
+lb=Xa.skinWeights,mb=Xa.edgeFaces,kb=Xa.morphTargets;if(Ka)for(db in Ka)Ka[db].offset=0;F=0;for(G=wb.length;F<G;F++){H=wb[F];D=zb[H];xb&&(xa=xb[H]);yb&&(bb=yb[H]);H=D.vertexNormals;I=D.normal;V=D.vertexColors;oa=D.color;U=D.vertexTangents;if(D instanceof THREE.Face3){if(fb){X=nb[D.a].position;da=nb[D.b].position;ma=nb[D.c].position;Ta[Oa]=X.x;Ta[Oa+1]=X.y;Ta[Oa+2]=X.z;Ta[Oa+3]=da.x;Ta[Oa+4]=da.y;Ta[Oa+5]=da.z;Ta[Oa+6]=ma.x;Ta[Oa+7]=ma.y;Ta[Oa+8]=ma.z;Oa+=9}if(Ka)for(db in Ka){P=Ka[db];if(P.needsUpdate){Y=
|
|
|
+P.offset;if(P.size===1){P.array[Y+0]=P.value[D.a];P.array[Y+1]=P.value[D.b];P.array[Y+2]=P.value[D.c];P.offset+=3}else{X=P.value[D.a];da=P.value[D.b];ma=P.value[D.c];if(P.size===2){P.array[Y+0]=X.x;P.array[Y+1]=X.y;P.array[Y+2]=da.x;P.array[Y+3]=da.y;P.array[Y+4]=ma.x;P.array[Y+5]=ma.y;P.offset+=6}else if(P.size===3){P.array[Y+0]=X.x;P.array[Y+1]=X.y;P.array[Y+2]=X.z;P.array[Y+3]=da.x;P.array[Y+4]=da.y;P.array[Y+5]=da.z;P.array[Y+6]=ma.x;P.array[Y+7]=ma.y;P.array[Y+8]=ma.z;P.offset+=9}else{P.array[Y+
|
|
|
+0]=X.x;P.array[Y+1]=X.y;P.array[Y+2]=X.z;P.array[Y+3]=X.w;P.array[Y+4]=da.x;P.array[Y+5]=da.y;P.array[Y+6]=da.z;P.array[Y+7]=da.w;P.array[Y+8]=ma.x;P.array[Y+9]=ma.y;P.array[Y+10]=ma.z;P.array[Y+11]=ma.w;P.offset+=12}}}}if(vb){Y=0;for(P=kb.length;Y<P;Y++){X=kb[Y].vertices[D.a].position;da=kb[Y].vertices[D.b].position;ma=kb[Y].vertices[D.c].position;Qa=S[Y];Qa[Pa+0]=X.x;Qa[Pa+1]=X.y;Qa[Pa+2]=X.z;Qa[Pa+3]=da.x;Qa[Pa+4]=da.y;Qa[Pa+5]=da.z;Qa[Pa+6]=ma.x;Qa[Pa+7]=ma.y;Qa[Pa+8]=ma.z}Pa+=9}if(lb.length){X=
|
|
|
+lb[D.a];da=lb[D.b];ma=lb[D.c];fa[Q]=X.x;fa[Q+1]=X.y;fa[Q+2]=X.z;fa[Q+3]=X.w;fa[Q+4]=da.x;fa[Q+5]=da.y;fa[Q+6]=da.z;fa[Q+7]=da.w;fa[Q+8]=ma.x;fa[Q+9]=ma.y;fa[Q+10]=ma.z;fa[Q+11]=ma.w;X=qb[D.a];da=qb[D.b];ma=qb[D.c];va[Q]=X.x;va[Q+1]=X.y;va[Q+2]=X.z;va[Q+3]=X.w;va[Q+4]=da.x;va[Q+5]=da.y;va[Q+6]=da.z;va[Q+7]=da.w;va[Q+8]=ma.x;va[Q+9]=ma.y;va[Q+10]=ma.z;va[Q+11]=ma.w;X=ob[D.a];da=ob[D.b];ma=ob[D.c];W[Q]=X.x;W[Q+1]=X.y;W[Q+2]=X.z;W[Q+3]=1;W[Q+4]=da.x;W[Q+5]=da.y;W[Q+6]=da.z;W[Q+7]=1;W[Q+8]=ma.x;W[Q+9]=
|
|
|
+ma.y;W[Q+10]=ma.z;W[Q+11]=1;X=pb[D.a];da=pb[D.b];ma=pb[D.c];wa[Q]=X.x;wa[Q+1]=X.y;wa[Q+2]=X.z;wa[Q+3]=1;wa[Q+4]=da.x;wa[Q+5]=da.y;wa[Q+6]=da.z;wa[Q+7]=1;wa[Q+8]=ma.x;wa[Q+9]=ma.y;wa[Q+10]=ma.z;wa[Q+11]=1;Q+=12}if(ub&&Ja){if(V.length==3&&Ja==THREE.VertexColors){D=V[0];X=V[1];da=V[2]}else da=X=D=oa;la[Ba]=D.r;la[Ba+1]=D.g;la[Ba+2]=D.b;la[Ba+3]=X.r;la[Ba+4]=X.g;la[Ba+5]=X.b;la[Ba+6]=da.r;la[Ba+7]=da.g;la[Ba+8]=da.b;Ba+=9}if(tb&&Xa.hasTangents){V=U[0];oa=U[1];D=U[2];ha[Ma]=V.x;ha[Ma+1]=V.y;ha[Ma+2]=V.z;
|
|
|
+ha[Ma+3]=V.w;ha[Ma+4]=oa.x;ha[Ma+5]=oa.y;ha[Ma+6]=oa.z;ha[Ma+7]=oa.w;ha[Ma+8]=D.x;ha[Ma+9]=D.y;ha[Ma+10]=D.z;ha[Ma+11]=D.w;Ma+=12}if(sb&&ra)if(H.length==3&&ib)for(U=0;U<3;U++){I=H[U];R[ab]=I.x;R[ab+1]=I.y;R[ab+2]=I.z;ab+=3}else for(U=0;U<3;U++){R[ab]=I.x;R[ab+1]=I.y;R[ab+2]=I.z;ab+=3}if(rb&&xa!==undefined&&Da)for(U=0;U<3;U++){H=xa[U];jb[hb]=H.u;jb[hb+1]=H.v;hb+=2}if(rb&&bb!==undefined&&Da)for(U=0;U<3;U++){H=bb[U];Ya[eb]=H.u;Ya[eb+1]=H.v;eb+=2}if(gb){Wa[$a]=Na;Wa[$a+1]=Na+1;Wa[$a+2]=Na+2;$a+=3;Ua[cb]=
|
|
|
+Na;Ua[cb+1]=Na+1;Ua[cb+2]=Na;Ua[cb+3]=Na+2;Ua[cb+4]=Na+1;Ua[cb+5]=Na+2;cb+=6;Na+=3}}else if(D instanceof THREE.Face4){if(fb){X=nb[D.a].position;da=nb[D.b].position;ma=nb[D.c].position;La=nb[D.d].position;Ta[Oa]=X.x;Ta[Oa+1]=X.y;Ta[Oa+2]=X.z;Ta[Oa+3]=da.x;Ta[Oa+4]=da.y;Ta[Oa+5]=da.z;Ta[Oa+6]=ma.x;Ta[Oa+7]=ma.y;Ta[Oa+8]=ma.z;Ta[Oa+9]=La.x;Ta[Oa+10]=La.y;Ta[Oa+11]=La.z;Oa+=12}if(Ka)for(db in Ka){P=Ka[db];if(P.needsUpdate){Y=P.offset;if(P.size===1){P.array[Y+0]=P.value[D.a];P.array[Y+1]=P.value[D.b];
|
|
|
+P.array[Y+2]=P.value[D.c];P.array[Y+2]=P.value[D.d];P.offset+=4}else{X=P.value[D.a];da=P.value[D.b];ma=P.value[D.c];La=P.value[D.d];if(P.size===2){P.array[Y+0]=X.x;P.array[Y+1]=X.y;P.array[Y+2]=da.x;P.array[Y+3]=da.y;P.array[Y+4]=ma.x;P.array[Y+5]=ma.y;P.array[Y+6]=La.x;P.array[Y+7]=La.y;P.offset+=8}else if(P.size===3){P.array[Y+0]=X.x;P.array[Y+1]=X.y;P.array[Y+2]=X.z;P.array[Y+3]=da.x;P.array[Y+4]=da.y;P.array[Y+5]=da.z;P.array[Y+6]=ma.x;P.array[Y+7]=ma.y;P.array[Y+8]=ma.z;P.array[Y+9]=La.x;P.array[Y+
|
|
|
+10]=La.y;P.array[Y+11]=La.z;P.offset+=12}else{P.array[Y+0]=X.x;P.array[Y+1]=X.y;P.array[Y+2]=X.z;P.array[Y+3]=X.w;P.array[Y+4]=da.x;P.array[Y+5]=da.y;P.array[Y+6]=da.z;P.array[Y+7]=da.w;P.array[Y+8]=ma.x;P.array[Y+9]=ma.y;P.array[Y+10]=ma.z;P.array[Y+11]=ma.w;P.array[Y+12]=La.x;P.array[Y+13]=La.y;P.array[Y+14]=La.z;P.array[Y+15]=La.w;P.offset+=16}}}}if(vb){Y=0;for(P=kb.length;Y<P;Y++){X=kb[Y].vertices[D.a].position;da=kb[Y].vertices[D.b].position;ma=kb[Y].vertices[D.c].position;La=kb[Y].vertices[D.d].position;
|
|
|
+Qa=S[Y];Qa[Pa+0]=X.x;Qa[Pa+1]=X.y;Qa[Pa+2]=X.z;Qa[Pa+3]=da.x;Qa[Pa+4]=da.y;Qa[Pa+5]=da.z;Qa[Pa+6]=ma.x;Qa[Pa+7]=ma.y;Qa[Pa+8]=ma.z;Qa[Pa+9]=La.x;Qa[Pa+10]=La.y;Qa[Pa+11]=La.z}Pa+=12}if(lb.length){X=lb[D.a];da=lb[D.b];ma=lb[D.c];La=lb[D.d];fa[Q]=X.x;fa[Q+1]=X.y;fa[Q+2]=X.z;fa[Q+3]=X.w;fa[Q+4]=da.x;fa[Q+5]=da.y;fa[Q+6]=da.z;fa[Q+7]=da.w;fa[Q+8]=ma.x;fa[Q+9]=ma.y;fa[Q+10]=ma.z;fa[Q+11]=ma.w;fa[Q+12]=La.x;fa[Q+13]=La.y;fa[Q+14]=La.z;fa[Q+15]=La.w;X=qb[D.a];da=qb[D.b];ma=qb[D.c];La=qb[D.d];va[Q]=X.x;va[Q+
|
|
|
+1]=X.y;va[Q+2]=X.z;va[Q+3]=X.w;va[Q+4]=da.x;va[Q+5]=da.y;va[Q+6]=da.z;va[Q+7]=da.w;va[Q+8]=ma.x;va[Q+9]=ma.y;va[Q+10]=ma.z;va[Q+11]=ma.w;va[Q+12]=La.x;va[Q+13]=La.y;va[Q+14]=La.z;va[Q+15]=La.w;X=ob[D.a];da=ob[D.b];ma=ob[D.c];La=ob[D.d];W[Q]=X.x;W[Q+1]=X.y;W[Q+2]=X.z;W[Q+3]=1;W[Q+4]=da.x;W[Q+5]=da.y;W[Q+6]=da.z;W[Q+7]=1;W[Q+8]=ma.x;W[Q+9]=ma.y;W[Q+10]=ma.z;W[Q+11]=1;W[Q+12]=La.x;W[Q+13]=La.y;W[Q+14]=La.z;W[Q+15]=1;X=pb[D.a];da=pb[D.b];ma=pb[D.c];D=pb[D.d];wa[Q]=X.x;wa[Q+1]=X.y;wa[Q+2]=X.z;wa[Q+3]=
|
|
|
+1;wa[Q+4]=da.x;wa[Q+5]=da.y;wa[Q+6]=da.z;wa[Q+7]=1;wa[Q+8]=ma.x;wa[Q+9]=ma.y;wa[Q+10]=ma.z;wa[Q+11]=1;wa[Q+12]=D.x;wa[Q+13]=D.y;wa[Q+14]=D.z;wa[Q+15]=1;Q+=16}if(ub&&Ja){if(V.length==4&&Ja==THREE.VertexColors){D=V[0];X=V[1];da=V[2];V=V[3]}else V=da=X=D=oa;la[Ba]=D.r;la[Ba+1]=D.g;la[Ba+2]=D.b;la[Ba+3]=X.r;la[Ba+4]=X.g;la[Ba+5]=X.b;la[Ba+6]=da.r;la[Ba+7]=da.g;la[Ba+8]=da.b;la[Ba+9]=V.r;la[Ba+10]=V.g;la[Ba+11]=V.b;Ba+=12}if(tb&&Xa.hasTangents){V=U[0];oa=U[1];D=U[2];U=U[3];ha[Ma]=V.x;ha[Ma+1]=V.y;ha[Ma+
|
|
|
+2]=V.z;ha[Ma+3]=V.w;ha[Ma+4]=oa.x;ha[Ma+5]=oa.y;ha[Ma+6]=oa.z;ha[Ma+7]=oa.w;ha[Ma+8]=D.x;ha[Ma+9]=D.y;ha[Ma+10]=D.z;ha[Ma+11]=D.w;ha[Ma+12]=U.x;ha[Ma+13]=U.y;ha[Ma+14]=U.z;ha[Ma+15]=U.w;Ma+=16}if(sb&&ra)if(H.length==4&&ib)for(U=0;U<4;U++){I=H[U];R[ab]=I.x;R[ab+1]=I.y;R[ab+2]=I.z;ab+=3}else for(U=0;U<4;U++){R[ab]=I.x;R[ab+1]=I.y;R[ab+2]=I.z;ab+=3}if(rb&&xa!==undefined&&Da)for(U=0;U<4;U++){H=xa[U];jb[hb]=H.u;jb[hb+1]=H.v;hb+=2}if(rb&&bb!==undefined&&Da)for(U=0;U<4;U++){H=bb[U];Ya[eb]=H.u;Ya[eb+1]=H.v;
|
|
|
+eb+=2}if(gb){Wa[$a]=Na;Wa[$a+1]=Na+1;Wa[$a+2]=Na+3;Wa[$a+3]=Na+1;Wa[$a+4]=Na+2;Wa[$a+5]=Na+3;$a+=6;Ua[cb]=Na;Ua[cb+1]=Na+1;Ua[cb+2]=Na;Ua[cb+3]=Na+3;Ua[cb+4]=Na+1;Ua[cb+5]=Na+2;Ua[cb+6]=Na+2;Ua[cb+7]=Na+3;cb+=8;Na+=4}}}if(mb){F=0;for(G=mb.length;F<G;F++){Wa[$a]=mb[F].a;Wa[$a+1]=mb[F].b;Wa[$a+2]=mb[F].c;Wa[$a+3]=mb[F].a;Wa[$a+4]=mb[F].c;Wa[$a+5]=mb[F].d;$a+=6}}if(fb){e.bindBuffer(e.ARRAY_BUFFER,u.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,Ta,O)}if(Ka)for(db in Ka){P=Ka[db];if(P.needsUpdate){e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
+P.buffer);e.bufferData(e.ARRAY_BUFFER,P.array,O);P.needsUpdate=!1}}if(vb){Y=0;for(P=kb.length;Y<P;Y++){e.bindBuffer(e.ARRAY_BUFFER,u.__webglMorphTargetsBuffers[Y]);e.bufferData(e.ARRAY_BUFFER,S[Y],O)}}if(ub&&Ba>0){e.bindBuffer(e.ARRAY_BUFFER,u.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,la,O)}if(sb){e.bindBuffer(e.ARRAY_BUFFER,u.__webglNormalBuffer);e.bufferData(e.ARRAY_BUFFER,R,O)}if(tb&&Xa.hasTangents){e.bindBuffer(e.ARRAY_BUFFER,u.__webglTangentBuffer);e.bufferData(e.ARRAY_BUFFER,ha,O)}if(rb&&
|
|
|
+hb>0){e.bindBuffer(e.ARRAY_BUFFER,u.__webglUVBuffer);e.bufferData(e.ARRAY_BUFFER,jb,O)}if(rb&&eb>0){e.bindBuffer(e.ARRAY_BUFFER,u.__webglUV2Buffer);e.bufferData(e.ARRAY_BUFFER,Ya,O)}if(gb){e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,u.__webglFaceBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,Wa,O);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,u.__webglLineBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,Ua,O)}if(Q>0){e.bindBuffer(e.ARRAY_BUFFER,u.__webglSkinVertexABuffer);e.bufferData(e.ARRAY_BUFFER,W,O);e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
+u.__webglSkinVertexBBuffer);e.bufferData(e.ARRAY_BUFFER,wa,O);e.bindBuffer(e.ARRAY_BUFFER,u.__webglSkinIndicesBuffer);e.bufferData(e.ARRAY_BUFFER,va,O);e.bindBuffer(e.ARRAY_BUFFER,u.__webglSkinWeightsBuffer);e.bufferData(e.ARRAY_BUFFER,fa,O)}}}x.__dirtyVertices=!1;x.__dirtyMorphTargets=!1;x.__dirtyElements=!1;x.__dirtyUvs=!1;x.__dirtyNormals=!1;x.__dirtyTangents=!1;x.__dirtyColors=!1}else if(m instanceof THREE.Ribbon){x=m.geometry;if(x.__dirtyVertices||x.__dirtyColors){m=x;A=e.DYNAMIC_DRAW;Ja=m.vertices;
|
|
|
+u=m.colors;ra=Ja.length;O=u.length;xa=m.__vertexArray;F=m.__colorArray;bb=m.__dirtyColors;if(m.__dirtyVertices){for(G=0;G<ra;G++){Da=Ja[G].position;w=G*3;xa[w]=Da.x;xa[w+1]=Da.y;xa[w+2]=Da.z}e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,xa,A)}if(bb){for(G=0;G<O;G++){color=u[G];w=G*3;F[w]=color.r;F[w+1]=color.g;F[w+2]=color.b}e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,F,A)}}x.__dirtyVertices=!1;x.__dirtyColors=!1}else if(m instanceof
|
|
|
+THREE.Line){x=m.geometry;if(x.__dirtyVertices||x.__dirtyColors){m=x;A=e.DYNAMIC_DRAW;Ja=m.vertices;u=m.colors;ra=Ja.length;O=u.length;xa=m.__vertexArray;F=m.__colorArray;bb=m.__dirtyColors;if(m.__dirtyVertices){for(G=0;G<ra;G++){Da=Ja[G].position;w=G*3;xa[w]=Da.x;xa[w+1]=Da.y;xa[w+2]=Da.z}e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,xa,A)}if(bb){for(G=0;G<O;G++){color=u[G];w=G*3;F[w]=color.r;F[w+1]=color.g;F[w+2]=color.b}e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);
|
|
|
+e.bufferData(e.ARRAY_BUFFER,F,A)}}x.__dirtyVertices=!1;x.__dirtyColors=!1}else if(m instanceof THREE.ParticleSystem){x=m.geometry;(x.__dirtyVertices||x.__dirtyColors||m.sortParticles)&&d(x,e.DYNAMIC_DRAW,m);x.__dirtyVertices=!1;x.__dirtyColors=!1}}function T(m){function A(oa){var U=[];x=0;for(u=oa.length;x<u;x++)oa[x]==undefined?U.push("undefined"):U.push(oa[x].id);return U.join("_")}var x,u,w,O,F,G,H,D,I={},V=m.morphTargets!==undefined?m.morphTargets.length:0;m.geometryGroups={};w=0;for(O=m.faces.length;w<
|
|
|
+O;w++){F=m.faces[w];G=F.materials;H=A(G);I[H]==undefined&&(I[H]={hash:H,counter:0});D=I[H].hash+"_"+I[H].counter;m.geometryGroups[D]==undefined&&(m.geometryGroups[D]={faces:[],materials:G,vertices:0,numMorphTargets:V});F=F instanceof THREE.Face3?3:4;if(m.geometryGroups[D].vertices+F>65535){I[H].counter+=1;D=I[H].hash+"_"+I[H].counter;m.geometryGroups[D]==undefined&&(m.geometryGroups[D]={faces:[],materials:G,vertices:0,numMorphTargets:V})}m.geometryGroups[D].faces.push(w);m.geometryGroups[D].vertices+=
|
|
|
+F}}function z(m,A,x){m.push({buffer:A,object:x,opaque:{list:[],count:0},transparent:{list:[],count:0}})}function K(m){if(m!=Aa){switch(m){case THREE.AdditiveBlending:e.blendEquation(e.FUNC_ADD);e.blendFunc(e.SRC_ALPHA,e.ONE);break;case THREE.SubtractiveBlending:e.blendEquation(e.FUNC_ADD);e.blendFunc(e.ZERO,e.ONE_MINUS_SRC_COLOR);break;case THREE.MultiplyBlending:e.blendEquation(e.FUNC_ADD);e.blendFunc(e.ZERO,e.SRC_COLOR);break;default:e.blendEquationSeparate(e.FUNC_ADD,e.FUNC_ADD);e.blendFuncSeparate(e.SRC_ALPHA,
|
|
|
+e.ONE_MINUS_SRC_ALPHA,e.ONE,e.ONE_MINUS_SRC_ALPHA)}Aa=m}}function L(m,A,x){if((x.width&x.width-1)==0&&(x.height&x.height-1)==0){e.texParameteri(m,e.TEXTURE_WRAP_S,aa(A.wrapS));e.texParameteri(m,e.TEXTURE_WRAP_T,aa(A.wrapT));e.texParameteri(m,e.TEXTURE_MAG_FILTER,aa(A.magFilter));e.texParameteri(m,e.TEXTURE_MIN_FILTER,aa(A.minFilter));e.generateMipmap(m)}else{e.texParameteri(m,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE);e.texParameteri(m,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE);e.texParameteri(m,e.TEXTURE_MAG_FILTER,
|
|
|
+ya(A.magFilter));e.texParameteri(m,e.TEXTURE_MIN_FILTER,ya(A.minFilter))}}function M(m,A){if(m.needsUpdate){if(m.__webglInit){e.bindTexture(e.TEXTURE_2D,m.__webglTexture);e.texSubImage2D(e.TEXTURE_2D,0,0,0,e.RGBA,e.UNSIGNED_BYTE,m.image)}else{m.__webglTexture=e.createTexture();e.bindTexture(e.TEXTURE_2D,m.__webglTexture);e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,m.image);m.__webglInit=!0}L(e.TEXTURE_2D,m,m.image);e.bindTexture(e.TEXTURE_2D,null);m.needsUpdate=!1}e.activeTexture(e.TEXTURE0+
|
|
|
+A);e.bindTexture(e.TEXTURE_2D,m.__webglTexture)}function Ga(m){if(m&&!m.__webglFramebuffer){m.__webglFramebuffer=e.createFramebuffer();m.__webglRenderbuffer=e.createRenderbuffer();m.__webglTexture=e.createTexture();e.bindRenderbuffer(e.RENDERBUFFER,m.__webglRenderbuffer);e.renderbufferStorage(e.RENDERBUFFER,e.DEPTH_COMPONENT16,m.width,m.height);e.bindTexture(e.TEXTURE_2D,m.__webglTexture);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,aa(m.wrapS));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,aa(m.wrapT));
|
|
|
+e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,aa(m.magFilter));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,aa(m.minFilter));e.texImage2D(e.TEXTURE_2D,0,aa(m.format),m.width,m.height,0,aa(m.format),aa(m.type),null);e.bindFramebuffer(e.FRAMEBUFFER,m.__webglFramebuffer);e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,m.__webglTexture,0);e.framebufferRenderbuffer(e.FRAMEBUFFER,e.DEPTH_ATTACHMENT,e.RENDERBUFFER,m.__webglRenderbuffer);e.bindTexture(e.TEXTURE_2D,null);e.bindRenderbuffer(e.RENDERBUFFER,
|
|
|
+null);e.bindFramebuffer(e.FRAMEBUFFER,null)}var A,x;if(m){A=m.__webglFramebuffer;x=m.width;m=m.height}else{A=null;x=Ea;m=ja}if(A!=Ha){e.bindFramebuffer(e.FRAMEBUFFER,A);e.viewport(Z,pa,x,m);Ha=A}}function sa(m,A){var x;if(m=="fragment")x=e.createShader(e.FRAGMENT_SHADER);else m=="vertex"&&(x=e.createShader(e.VERTEX_SHADER));e.shaderSource(x,A);e.compileShader(x);if(!e.getShaderParameter(x,e.COMPILE_STATUS)){console.error(e.getShaderInfoLog(x));console.error(A);return null}return x}function ya(m){switch(m){case THREE.NearestFilter:case THREE.NearestMipMapNearestFilter:case THREE.NearestMipMapLinearFilter:return e.NEAREST;
|
|
|
+default:return e.LINEAR}}function aa(m){switch(m){case THREE.RepeatWrapping:return e.REPEAT;case THREE.ClampToEdgeWrapping:return e.CLAMP_TO_EDGE;case THREE.MirroredRepeatWrapping:return e.MIRRORED_REPEAT;case THREE.NearestFilter:return e.NEAREST;case THREE.NearestMipMapNearestFilter:return e.NEAREST_MIPMAP_NEAREST;case THREE.NearestMipMapLinearFilter:return e.NEAREST_MIPMAP_LINEAR;case THREE.LinearFilter:return e.LINEAR;case THREE.LinearMipMapNearestFilter:return e.LINEAR_MIPMAP_NEAREST;case THREE.LinearMipMapLinearFilter:return e.LINEAR_MIPMAP_LINEAR;
|
|
|
case THREE.ByteType:return e.BYTE;case THREE.UnsignedByteType:return e.UNSIGNED_BYTE;case THREE.ShortType:return e.SHORT;case THREE.UnsignedShortType:return e.UNSIGNED_SHORT;case THREE.IntType:return e.INT;case THREE.UnsignedShortType:return e.UNSIGNED_INT;case THREE.FloatType:return e.FLOAT;case THREE.AlphaFormat:return e.ALPHA;case THREE.RGBFormat:return e.RGB;case THREE.RGBAFormat:return e.RGBA;case THREE.LuminanceFormat:return e.LUMINANCE;case THREE.LuminanceAlphaFormat:return e.LUMINANCE_ALPHA}return 0}
|
|
|
-var e,ga=document.createElement("canvas"),Ba=null,Ja=null,Ka=!0,wa=this,ea=null,va=null,Ca=null,ka=null,aa=0,ra=0,Ga=0,la=0,pa=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],Ha=new THREE.Matrix4,Ta=new Float32Array(16),ab=new Float32Array(16),Xa=new THREE.Vector4,Ua={ambient:[0,0,0],directional:{length:0,colors:[],positions:[]},point:{length:0,colors:[],positions:[],distances:[]}},N=!0,ca=!0,sa=new THREE.Color(0),Ea=0;if(b){if(b.stencil!=
|
|
|
-undefined)N=b.stencil;if(b.antialias!==undefined)ca=b.antialias;b.clearColor!==undefined&&sa.setHex(b.clearColor);if(b.clearAlpha!==undefined)Ea=b.clearAlpha}this.maxMorphTargets=8;this.domElement=ga;this.autoClear=!0;this.sortObjects=!0;(function(m,B,z,w){try{if(!(e=ga.getContext("experimental-webgl",{antialias:m,stencil:w})))throw"Error creating WebGL context.";}catch(y){console.error(y)}e.clearColor(0,0,0,1);e.clearDepth(1);e.enable(e.DEPTH_TEST);e.depthFunc(e.LEQUAL);e.frontFace(e.CCW);e.cullFace(e.BACK);
|
|
|
-e.enable(e.CULL_FACE);e.enable(e.BLEND);e.blendEquation(e.FUNC_ADD);e.blendFunc(e.SRC_ALPHA,e.ONE_MINUS_SRC_ALPHA);e.clearColor(B.r,B.g,B.b,z)})(ca,sa,Ea,N);this.context=e;if(N){var ia={};ia.vertices=new Float32Array(12);ia.faces=new Uint16Array(6);ia.darkness=0.5;ia.vertices[0]=-2;ia.vertices[1]=-1;ia.vertices[2]=-1;ia.vertices[3]=2;ia.vertices[4]=-1;ia.vertices[5]=-1;ia.vertices[6]=2;ia.vertices[7]=1;ia.vertices[8]=-1;ia.vertices[9]=-2;ia.vertices[10]=1;ia.vertices[11]=-1;ia.faces[0]=0;ia.faces[1]=
|
|
|
-1;ia.faces[2]=2;ia.faces[3]=0;ia.faces[4]=2;ia.faces[5]=3;ia.vertexBuffer=e.createBuffer();ia.elementBuffer=e.createBuffer();e.bindBuffer(e.ARRAY_BUFFER,ia.vertexBuffer);e.bufferData(e.ARRAY_BUFFER,ia.vertices,e.STATIC_DRAW);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ia.elementBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,ia.faces,e.STATIC_DRAW);ia.program=e.createProgram();e.attachShader(ia.program,ua("fragment",THREE.ShaderLib.shadowPost.fragmentShader));e.attachShader(ia.program,ua("vertex",THREE.ShaderLib.shadowPost.vertexShader));
|
|
|
-e.linkProgram(ia.program);ia.vertexLocation=e.getAttribLocation(ia.program,"position");ia.projectionLocation=e.getUniformLocation(ia.program,"projectionMatrix");ia.darknessLocation=e.getUniformLocation(ia.program,"darkness")}var ma={};ma.vertices=new Float32Array(16);ma.faces=new Uint16Array(6);ma.transparency=0.5;b=0;ma.vertices[b++]=-1;ma.vertices[b++]=-1;ma.vertices[b++]=0;ma.vertices[b++]=0;ma.vertices[b++]=1;ma.vertices[b++]=-1;ma.vertices[b++]=1;ma.vertices[b++]=0;ma.vertices[b++]=1;ma.vertices[b++]=
|
|
|
-1;ma.vertices[b++]=1;ma.vertices[b++]=1;ma.vertices[b++]=-1;ma.vertices[b++]=1;ma.vertices[b++]=0;ma.vertices[b++]=1;b=0;ma.faces[b++]=0;ma.faces[b++]=1;ma.faces[b++]=2;ma.faces[b++]=0;ma.faces[b++]=2;ma.faces[b++]=3;ma.vertexBuffer=e.createBuffer();ma.elementBuffer=e.createBuffer();ma.tempTexture=e.createTexture();ma.readBackPixels=new Uint8Array(1024);e.bindBuffer(e.ARRAY_BUFFER,ma.vertexBuffer);e.bufferData(e.ARRAY_BUFFER,ma.vertices,e.STATIC_DRAW);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ma.elementBuffer);
|
|
|
-e.bufferData(e.ELEMENT_ARRAY_BUFFER,ma.faces,e.STATIC_DRAW);e.bindTexture(e.TEXTURE_2D,ma.tempTexture);e.texImage2D(e.TEXTURE_2D,0,e.RGB,16,16,0,e.RGB,e.UNSIGNED_BYTE,null);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.NEAREST);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.NEAREST);ma.program=e.createProgram();e.attachShader(ma.program,ua("fragment",THREE.ShaderLib.lensFlare.fragmentShader));
|
|
|
-e.attachShader(ma.program,ua("vertex",THREE.ShaderLib.lensFlare.vertexShader));e.linkProgram(ma.program);ma.attributes={};ma.uniforms={};ma.attributes.vertex=e.getAttribLocation(ma.program,"position");ma.attributes.uv=e.getAttribLocation(ma.program,"UV");ma.uniforms.map=e.getUniformLocation(ma.program,"map");ma.uniforms.opacity=e.getUniformLocation(ma.program,"opacity");ma.uniforms.scale=e.getUniformLocation(ma.program,"scale");ma.uniforms.rotation=e.getUniformLocation(ma.program,"rotation");ma.uniforms.screenPosition=
|
|
|
-e.getUniformLocation(ma.program,"screenPosition");ma.uniforms.renderPink=e.getUniformLocation(ma.program,"renderPink");this.setSize=function(m,B){ga.width=m;ga.height=B;this.setViewport(0,0,ga.width,ga.height)};this.setViewport=function(m,B,z,w){aa=m;ra=B;Ga=z;la=w;e.viewport(aa,ra,Ga,la)};this.setScissor=function(m,B,z,w){e.scissor(m,B,z,w)};this.enableScissorTest=function(m){m?e.enable(e.SCISSOR_TEST):e.disable(e.SCISSOR_TEST)};this.enableDepthBufferWrite=function(m){Ka=m;e.depthMask(m)};this.setClearColorHex=
|
|
|
-function(m,B){var z=new THREE.Color(m);e.clearColor(z.r,z.g,z.b,B)};this.setClearColor=function(m,B){e.clearColor(m.r,m.g,m.b,B)};this.clear=function(){e.clear(e.COLOR_BUFFER_BIT|e.DEPTH_BUFFER_BIT|e.STENCIL_BUFFER_BIT)};this.setStencilShadowDarkness=function(m){ia.darkness=m};this.initMaterial=function(m,B,z,w){var y,P,H,J;if(m instanceof THREE.MeshDepthMaterial)c(m,THREE.ShaderLib.depth);else if(m instanceof THREE.ShadowVolumeDynamicMaterial)c(m,THREE.ShaderLib.shadowVolumeDynamic);else if(m instanceof
|
|
|
-THREE.MeshNormalMaterial)c(m,THREE.ShaderLib.normal);else if(m instanceof THREE.MeshBasicMaterial)c(m,THREE.ShaderLib.basic);else if(m instanceof THREE.MeshLambertMaterial)c(m,THREE.ShaderLib.lambert);else if(m instanceof THREE.MeshPhongMaterial)c(m,THREE.ShaderLib.phong);else if(m instanceof THREE.LineBasicMaterial)c(m,THREE.ShaderLib.basic);else m instanceof THREE.ParticleBasicMaterial&&c(m,THREE.ShaderLib.particle_basic);if(!m.program){var K,E,L;K=L=J=0;for(H=B.length;K<H;K++){E=B[K];E instanceof
|
|
|
-THREE.DirectionalLight&&L++;E instanceof THREE.PointLight&&J++}if(J+L<=4)B=L;else{B=Math.ceil(4*L/(J+L));J=4-B}J={directional:B,point:J};B=50;if(w!==undefined&&w instanceof THREE.SkinnedMesh)B=w.bones.length;H={map:m.map,envMap:m.envMap,lightMap:m.lightMap,vertexColors:m.vertexColors,fog:z,sizeAttenuation:m.sizeAttenuation,skinning:m.skinning,morphTargets:m.morphTargets,maxDirLights:J.directional,maxPointLights:J.point,maxBones:B};z=m.fragmentShader;J=m.vertexShader;B=e.createProgram();K=["#ifdef GL_ES\nprecision highp float;\n#endif",
|
|
|
-"#define MAX_DIR_LIGHTS "+H.maxDirLights,"#define MAX_POINT_LIGHTS "+H.maxPointLights,H.fog?"#define USE_FOG":"",H.fog instanceof THREE.FogExp2?"#define FOG_EXP2":"",H.map?"#define USE_MAP":"",H.envMap?"#define USE_ENVMAP":"",H.lightMap?"#define USE_LIGHTMAP":"",H.vertexColors?"#define USE_COLOR":"","uniform mat4 viewMatrix;\nuniform vec3 cameraPosition;\n"].join("\n");H=[e.getParameter(e.MAX_VERTEX_TEXTURE_IMAGE_UNITS)>0?"#define VERTEX_TEXTURES":"","#define MAX_DIR_LIGHTS "+H.maxDirLights,"#define MAX_POINT_LIGHTS "+
|
|
|
-H.maxPointLights,"#define MAX_BONES "+H.maxBones,H.map?"#define USE_MAP":"",H.envMap?"#define USE_ENVMAP":"",H.lightMap?"#define USE_LIGHTMAP":"",H.vertexColors?"#define USE_COLOR":"",H.skinning?"#define USE_SKINNING":"",H.morphTargets?"#define USE_MORPHTARGETS":"",H.sizeAttenuation?"#define USE_SIZEATTENUATION":"","uniform mat4 objectMatrix;\nuniform mat4 modelViewMatrix;\nuniform mat4 projectionMatrix;\nuniform mat4 viewMatrix;\nuniform mat3 normalMatrix;\nuniform vec3 cameraPosition;\nuniform mat4 cameraInverseMatrix;\nattribute vec3 position;\nattribute vec3 normal;\nattribute vec2 uv;\nattribute vec2 uv2;\n#ifdef USE_COLOR\nattribute vec3 color;\n#endif\n#ifdef USE_MORPHTARGETS\nattribute vec3 morphTarget0;\nattribute vec3 morphTarget1;\nattribute vec3 morphTarget2;\nattribute vec3 morphTarget3;\nattribute vec3 morphTarget4;\nattribute vec3 morphTarget5;\nattribute vec3 morphTarget6;\nattribute vec3 morphTarget7;\n#endif\n#ifdef USE_SKINNING\nattribute vec4 skinVertexA;\nattribute vec4 skinVertexB;\nattribute vec4 skinIndex;\nattribute vec4 skinWeight;\n#endif\n"].join("\n");
|
|
|
-e.attachShader(B,ua("fragment",K+z));e.attachShader(B,ua("vertex",H+J));e.linkProgram(B);e.getProgramParameter(B,e.LINK_STATUS)||console.error("Could not initialise shader\nVALIDATE_STATUS: "+e.getProgramParameter(B,e.VALIDATE_STATUS)+", gl error ["+e.getError()+"]");B.uniforms={};B.attributes={};m.program=B;z=["viewMatrix","modelViewMatrix","projectionMatrix","normalMatrix","objectMatrix","cameraPosition","cameraInverseMatrix","boneGlobalMatrices","morphTargetInfluences"];for(y in m.uniforms)z.push(y);
|
|
|
-y=m.program;J=0;for(B=z.length;J<B;J++){K=z[J];y.uniforms[K]=e.getUniformLocation(y,K)}z=["position","normal","uv","uv2","tangent","color","skinVertexA","skinVertexB","skinIndex","skinWeight"];for(y=0;y<this.maxMorphTargets;y++)z.push("morphTarget"+y);for(P in m.attributes)z.push(P);y=m.program;J=0;for(B=z.length;J<B;J++){K=z[J];y.attributes[K]=e.getAttribLocation(y,K)}y=m.program.attributes;e.enableVertexAttribArray(y.position);y.color>=0&&e.enableVertexAttribArray(y.color);y.normal>=0&&e.enableVertexAttribArray(y.normal);
|
|
|
-y.tangent>=0&&e.enableVertexAttribArray(y.tangent);if(m.skinning&&y.skinVertexA>=0&&y.skinVertexB>=0&&y.skinIndex>=0&&y.skinWeight>=0){e.enableVertexAttribArray(y.skinVertexA);e.enableVertexAttribArray(y.skinVertexB);e.enableVertexAttribArray(y.skinIndex);e.enableVertexAttribArray(y.skinWeight)}for(P in m.attributes)y[P]>=0&&e.enableVertexAttribArray(y[P]);if(m.morphTargets){m.numSupportedMorphTargets=0;if(y.morphTarget0>=0){e.enableVertexAttribArray(y.morphTarget0);m.numSupportedMorphTargets++}if(y.morphTarget1>=
|
|
|
-0){e.enableVertexAttribArray(y.morphTarget1);m.numSupportedMorphTargets++}if(y.morphTarget2>=0){e.enableVertexAttribArray(y.morphTarget2);m.numSupportedMorphTargets++}if(y.morphTarget3>=0){e.enableVertexAttribArray(y.morphTarget3);m.numSupportedMorphTargets++}if(y.morphTarget4>=0){e.enableVertexAttribArray(y.morphTarget4);m.numSupportedMorphTargets++}if(y.morphTarget5>=0){e.enableVertexAttribArray(y.morphTarget5);m.numSupportedMorphTargets++}if(y.morphTarget6>=0){e.enableVertexAttribArray(y.morphTarget6);
|
|
|
-m.numSupportedMorphTargets++}if(y.morphTarget7>=0){e.enableVertexAttribArray(y.morphTarget7);m.numSupportedMorphTargets++}w.__webglMorphTargetInfluences=new Float32Array(this.maxMorphTargets);y=0;for(P=this.maxMorphTargets;y<P;y++)w.__webglMorphTargetInfluences[y]=0}}m.__webglProgram=!0};this.render=function(m,B,z,w){var y,P,H,J,K,E,L,X,qa=m.lights,W=m.fog;B.matrixAutoUpdate&&B.updateMatrix();m.update(undefined,!1,B);B.matrixWorldInverse.flattenToArray(ab);B.projectionMatrix.flattenToArray(Ta);Ha.multiply(B.projectionMatrix,
|
|
|
-B.matrixWorldInverse);n(Ha);this.initWebGLObjects(m);Ia(z);(this.autoClear||w)&&this.clear();K=m.__webglObjects.length;for(w=0;w<K;w++){y=m.__webglObjects[w];L=y.object;if(L.visible)if(!(L instanceof THREE.Mesh)||p(L)){L.matrixWorld.flattenToArray(L._objectMatrixArray);I(L,B);A(y);y.render=!0;if(this.sortObjects){Xa.copy(L.position);Ha.multiplyVector3(Xa);y.z=Xa.z}}else y.render=!1;else y.render=!1}this.sortObjects&&m.__webglObjects.sort(t);E=m.__webglObjectsImmediate.length;for(w=0;w<E;w++){y=m.__webglObjectsImmediate[w];
|
|
|
-L=y.object;if(L.visible){L.matrixAutoUpdate&&L.matrixWorld.flattenToArray(L._objectMatrixArray);I(L,B);x(y)}}M(THREE.NormalBlending);for(w=0;w<K;w++){y=m.__webglObjects[w];if(y.render){L=y.object;X=y.buffer;H=y.opaque;j(L);for(y=0;y<H.count;y++){J=H.list[y];k(J.depthTest);g(B,qa,W,J,X,L)}}}for(w=0;w<E;w++){y=m.__webglObjectsImmediate[w];L=y.object;if(L.visible){H=y.opaque;j(L);for(y=0;y<H.count;y++){J=H.list[y];k(J.depthTest);P=f(B,qa,W,J,L);L.render(function(Fa){h(Fa,P)})}}}for(w=0;w<K;w++){y=m.__webglObjects[w];
|
|
|
-if(y.render){L=y.object;X=y.buffer;H=y.transparent;j(L);for(y=0;y<H.count;y++){J=H.list[y];M(J.blending);k(J.depthTest);g(B,qa,W,J,X,L)}}}for(w=0;w<E;w++){y=m.__webglObjectsImmediate[w];L=y.object;if(L.visible){H=y.transparent;j(L);for(y=0;y<H.count;y++){J=H.list[y];M(J.blending);k(J.depthTest);P=f(B,qa,W,J,L);L.render(function(Fa){h(Fa,P)})}}}N&&m.__webglShadowVolumes.length&&m.lights.length&&C(m);m.__webglLensFlares.length&&F(m,B);if(z&&z.minFilter!==THREE.NearestFilter&&z.minFilter!==THREE.LinearFilter){e.bindTexture(e.TEXTURE_2D,
|
|
|
-z.__webglTexture);e.generateMipmap(e.TEXTURE_2D);e.bindTexture(e.TEXTURE_2D,null)}};this.initWebGLObjects=function(m){if(!m.__webglObjects){m.__webglObjects=[];m.__webglObjectsImmediate=[];m.__webglShadowVolumes=[];m.__webglLensFlares=[]}for(;m.__objectsAdded.length;){var B=m.__objectsAdded[0],z=m,w=void 0,y=void 0,P=void 0;if(B._modelViewMatrix==undefined){B._modelViewMatrix=new THREE.Matrix4;B._normalMatrixArray=new Float32Array(9);B._modelViewMatrixArray=new Float32Array(16);B._objectMatrixArray=
|
|
|
-new Float32Array(16);B.matrixWorld.flattenToArray(B._objectMatrixArray)}if(B instanceof THREE.Mesh){y=B.geometry;y.geometryGroups==undefined&&U(y);for(w in y.geometryGroups){P=y.geometryGroups[w];if(!P.__webglVertexBuffer){var H=P;H.__webglVertexBuffer=e.createBuffer();H.__webglNormalBuffer=e.createBuffer();H.__webglTangentBuffer=e.createBuffer();H.__webglColorBuffer=e.createBuffer();H.__webglUVBuffer=e.createBuffer();H.__webglUV2Buffer=e.createBuffer();H.__webglSkinVertexABuffer=e.createBuffer();
|
|
|
-H.__webglSkinVertexBBuffer=e.createBuffer();H.__webglSkinIndicesBuffer=e.createBuffer();H.__webglSkinWeightsBuffer=e.createBuffer();H.__webglFaceBuffer=e.createBuffer();H.__webglLineBuffer=e.createBuffer();if(H.numMorphTargets){var J=void 0,K=void 0;H.__webglMorphTargetsBuffers=[];J=0;for(K=H.numMorphTargets;J<K;J++)H.__webglMorphTargetsBuffers.push(e.createBuffer())}H=P;J=B;var E=void 0,L=void 0,X=void 0;X=void 0;var qa=void 0,W=void 0,Fa=void 0,La=Fa=K=0;L=void 0;X=void 0;var ta=void 0;E=void 0;
|
|
|
-L=void 0;qa=J.geometry;ta=qa.faces;W=H.faces;E=0;for(L=W.length;E<L;E++){X=W[E];X=ta[X];if(X instanceof THREE.Face3){K+=3;Fa+=1;La+=3}else if(X instanceof THREE.Face4){K+=4;Fa+=2;La+=4}}E=H;L=J;ta=void 0;W=void 0;var za=void 0,db=void 0;za=void 0;X=[];ta=0;for(W=L.materials.length;ta<W;ta++){za=L.materials[ta];if(za instanceof THREE.MeshFaceMaterial){za=0;for(l=E.materials.length;za<l;za++)(db=E.materials[za])&&X.push(db)}else(db=za)&&X.push(db)}E=X;a:{L=void 0;ta=void 0;W=E.length;for(L=0;L<W;L++){ta=
|
|
|
-E[L];if(ta.map||ta.lightMap||ta instanceof THREE.MeshShaderMaterial){L=!0;break a}}L=!1}a:{ta=E;W=void 0;X=void 0;za=ta.length;for(W=0;W<za;W++){X=ta[W];if(!(X instanceof THREE.MeshBasicMaterial&&!X.envMap||X instanceof THREE.MeshDepthMaterial)){ta=X&&X.shading!=undefined&&X.shading==THREE.SmoothShading?THREE.SmoothShading:THREE.FlatShading;break a}}ta=!1}a:{W=void 0;X=void 0;za=E.length;for(W=0;W<za;W++){X=E[W];if(X.vertexColors){X=X.vertexColors;break a}}X=!1}H.__vertexArray=new Float32Array(K*
|
|
|
-3);if(ta)H.__normalArray=new Float32Array(K*3);if(qa.hasTangents)H.__tangentArray=new Float32Array(K*4);if(X)H.__colorArray=new Float32Array(K*3);if(L){if(qa.faceUvs.length>0||qa.faceVertexUvs.length>0)H.__uvArray=new Float32Array(K*2);if(qa.faceUvs.length>1||qa.faceVertexUvs.length>1)H.__uv2Array=new Float32Array(K*2)}if(J.geometry.skinWeights.length&&J.geometry.skinIndices.length){H.__skinVertexAArray=new Float32Array(K*4);H.__skinVertexBArray=new Float32Array(K*4);H.__skinIndexArray=new Float32Array(K*
|
|
|
-4);H.__skinWeightArray=new Float32Array(K*4)}H.__faceArray=new Uint16Array(Fa*3+(J.geometry.edgeFaces?J.geometry.edgeFaces.length*6:0));H.__lineArray=new Uint16Array(La*2);if(H.numMorphTargets){H.__morphTargetsArrays=[];qa=0;for(W=H.numMorphTargets;qa<W;qa++)H.__morphTargetsArrays.push(new Float32Array(K*3))}H.__needsSmoothNormals=ta==THREE.SmoothShading;H.__uvType=L;H.__vertexColorType=X;H.__normalType=ta;H.__webglFaceCount=Fa*3+(J.geometry.edgeFaces?J.geometry.edgeFaces.length*6:0);H.__webglLineCount=
|
|
|
-La*2;qa=0;for(W=E.length;qa<W;qa++)if(E[qa].attributes){H.__webglCustomAttributes={};for(a in E[qa].attributes){L=E[qa].attributes[a];Fa=1;if(L.type==="v2")Fa=2;else if(L.type==="v3")Fa=3;else if(L.type==="v4")Fa=4;else L.type==="c"&&(Fa=3);L.size=Fa;L.needsUpdate=!0;L.array=new Float32Array(K*Fa);L.buffer=e.createBuffer();H.__webglCustomAttributes[a]=L}}y.__dirtyVertices=!0;y.__dirtyMorphTargets=!0;y.__dirtyElements=!0;y.__dirtyUvs=!0;y.__dirtyNormals=!0;y.__dirtyTangents=!0;y.__dirtyColors=!0}B instanceof
|
|
|
-THREE.ShadowVolume?D(z.__webglShadowVolumes,P,B):D(z.__webglObjects,P,B)}}else if(B instanceof THREE.LensFlare)D(z.__webglLensFlares,undefined,B);else if(B instanceof THREE.Ribbon){y=B.geometry;if(!y.__webglVertexBuffer){w=y;w.__webglVertexBuffer=e.createBuffer();w.__webglColorBuffer=e.createBuffer();w=y;P=w.vertices.length;w.__vertexArray=new Float32Array(P*3);w.__colorArray=new Float32Array(P*3);w.__webglVertexCount=P;y.__dirtyVertices=!0;y.__dirtyColors=!0}D(z.__webglObjects,y,B)}else if(B instanceof
|
|
|
-THREE.Line){y=B.geometry;if(!y.__webglVertexBuffer){w=y;w.__webglVertexBuffer=e.createBuffer();w.__webglColorBuffer=e.createBuffer();w=y;P=w.vertices.length;w.__vertexArray=new Float32Array(P*3);w.__colorArray=new Float32Array(P*3);w.__webglLineCount=P;y.__dirtyVertices=!0;y.__dirtyColors=!0}D(z.__webglObjects,y,B)}else if(B instanceof THREE.ParticleSystem){y=B.geometry;if(!y.__webglVertexBuffer){w=y;w.__webglVertexBuffer=e.createBuffer();w.__webglColorBuffer=e.createBuffer();w=y;P=w.vertices.length;
|
|
|
-w.__vertexArray=new Float32Array(P*3);w.__colorArray=new Float32Array(P*3);w.__sortArray=[];w.__webglParticleCount=P;y.__dirtyVertices=!0;y.__dirtyColors=!0}D(z.__webglObjects,y,B)}else THREE.MarchingCubes!==undefined&&B instanceof THREE.MarchingCubes&&z.__webglObjectsImmediate.push({object:B,opaque:{list:[],count:0},transparent:{list:[],count:0}});m.__objectsAdded.splice(0,1)}for(;m.__objectsRemoved.length;){B=m.__objectsRemoved[0];z=m;y=void 0;w=void 0;for(y=z.__webglObjects.length-1;y>=0;y--){w=
|
|
|
-z.__webglObjects[y].object;B==w&&z.__webglObjects.splice(y,1)}m.__objectsRemoved.splice(0,1)}B=0;for(z=m.__webglObjects.length;B<z;B++)G(m.__webglObjects[B].object,m);B=0;for(z=m.__webglShadowVolumes.length;B<z;B++)G(m.__webglShadowVolumes[B].object,m);B=0;for(z=m.__webglLensFlares.length;B<z;B++)G(m.__webglLensFlares[B].object,m)};this.setFaceCulling=function(m,B){if(m){!B||B=="ccw"?e.frontFace(e.CCW):e.frontFace(e.CW);if(m=="back")e.cullFace(e.BACK);else m=="front"?e.cullFace(e.FRONT):e.cullFace(e.FRONT_AND_BACK);
|
|
|
+var e,ea=document.createElement("canvas"),za=null,Ha=null,Ia=!0,ua=this,ca=null,ta=null,Aa=null,ia=null,Z=0,pa=0,Ea=0,ja=0,na=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],Fa=new THREE.Matrix4,Ra=new Float32Array(16),Za=new Float32Array(16),Va=new THREE.Vector4,Sa={ambient:[0,0,0],directional:{length:0,colors:[],positions:[]},point:{length:0,colors:[],positions:[],distances:[]}},N=!0,$=!0,qa=new THREE.Color(0),Ca=0;if(b){if(b.stencil!=
|
|
|
+undefined)N=b.stencil;if(b.antialias!==undefined)$=b.antialias;b.clearColor!==undefined&&qa.setHex(b.clearColor);if(b.clearAlpha!==undefined)Ca=b.clearAlpha}this.maxMorphTargets=8;this.domElement=ea;this.autoClear=!0;this.sortObjects=!0;(function(m,A,x,u){try{if(!(e=ea.getContext("experimental-webgl",{antialias:m,stencil:u})))throw"Error creating WebGL context.";}catch(w){console.error(w)}e.clearColor(0,0,0,1);e.clearDepth(1);e.enable(e.DEPTH_TEST);e.depthFunc(e.LEQUAL);e.frontFace(e.CCW);e.cullFace(e.BACK);
|
|
|
+e.enable(e.CULL_FACE);e.enable(e.BLEND);e.blendEquation(e.FUNC_ADD);e.blendFunc(e.SRC_ALPHA,e.ONE_MINUS_SRC_ALPHA);e.clearColor(A.r,A.g,A.b,x)})($,qa,Ca,N);this.context=e;if(N){var ga={};ga.vertices=new Float32Array(12);ga.faces=new Uint16Array(6);ga.darkness=0.5;ga.vertices[0]=-2;ga.vertices[1]=-1;ga.vertices[2]=-1;ga.vertices[3]=2;ga.vertices[4]=-1;ga.vertices[5]=-1;ga.vertices[6]=2;ga.vertices[7]=1;ga.vertices[8]=-1;ga.vertices[9]=-2;ga.vertices[10]=1;ga.vertices[11]=-1;ga.faces[0]=0;ga.faces[1]=
|
|
|
+1;ga.faces[2]=2;ga.faces[3]=0;ga.faces[4]=2;ga.faces[5]=3;ga.vertexBuffer=e.createBuffer();ga.elementBuffer=e.createBuffer();e.bindBuffer(e.ARRAY_BUFFER,ga.vertexBuffer);e.bufferData(e.ARRAY_BUFFER,ga.vertices,e.STATIC_DRAW);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ga.elementBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,ga.faces,e.STATIC_DRAW);ga.program=e.createProgram();e.attachShader(ga.program,sa("fragment",THREE.ShaderLib.shadowPost.fragmentShader));e.attachShader(ga.program,sa("vertex",THREE.ShaderLib.shadowPost.vertexShader));
|
|
|
+e.linkProgram(ga.program);ga.vertexLocation=e.getAttribLocation(ga.program,"position");ga.projectionLocation=e.getUniformLocation(ga.program,"projectionMatrix");ga.darknessLocation=e.getUniformLocation(ga.program,"darkness")}var ka={};ka.vertices=new Float32Array(16);ka.faces=new Uint16Array(6);ka.transparency=0.5;b=0;ka.vertices[b++]=-1;ka.vertices[b++]=-1;ka.vertices[b++]=0;ka.vertices[b++]=0;ka.vertices[b++]=1;ka.vertices[b++]=-1;ka.vertices[b++]=1;ka.vertices[b++]=0;ka.vertices[b++]=1;ka.vertices[b++]=
|
|
|
+1;ka.vertices[b++]=1;ka.vertices[b++]=1;ka.vertices[b++]=-1;ka.vertices[b++]=1;ka.vertices[b++]=0;ka.vertices[b++]=1;b=0;ka.faces[b++]=0;ka.faces[b++]=1;ka.faces[b++]=2;ka.faces[b++]=0;ka.faces[b++]=2;ka.faces[b++]=3;ka.vertexBuffer=e.createBuffer();ka.elementBuffer=e.createBuffer();ka.tempTexture=e.createTexture();ka.readBackPixels=new Uint8Array(1024);e.bindBuffer(e.ARRAY_BUFFER,ka.vertexBuffer);e.bufferData(e.ARRAY_BUFFER,ka.vertices,e.STATIC_DRAW);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ka.elementBuffer);
|
|
|
+e.bufferData(e.ELEMENT_ARRAY_BUFFER,ka.faces,e.STATIC_DRAW);e.bindTexture(e.TEXTURE_2D,ka.tempTexture);e.texImage2D(e.TEXTURE_2D,0,e.RGB,16,16,0,e.RGB,e.UNSIGNED_BYTE,null);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.NEAREST);e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.NEAREST);ka.program=e.createProgram();e.attachShader(ka.program,sa("fragment",THREE.ShaderLib.lensFlare.fragmentShader));
|
|
|
+e.attachShader(ka.program,sa("vertex",THREE.ShaderLib.lensFlare.vertexShader));e.linkProgram(ka.program);ka.attributes={};ka.uniforms={};ka.attributes.vertex=e.getAttribLocation(ka.program,"position");ka.attributes.uv=e.getAttribLocation(ka.program,"UV");ka.uniforms.map=e.getUniformLocation(ka.program,"map");ka.uniforms.opacity=e.getUniformLocation(ka.program,"opacity");ka.uniforms.scale=e.getUniformLocation(ka.program,"scale");ka.uniforms.rotation=e.getUniformLocation(ka.program,"rotation");ka.uniforms.screenPosition=
|
|
|
+e.getUniformLocation(ka.program,"screenPosition");ka.uniforms.renderPink=e.getUniformLocation(ka.program,"renderPink");this.setSize=function(m,A){ea.width=m;ea.height=A;this.setViewport(0,0,ea.width,ea.height)};this.setViewport=function(m,A,x,u){Z=m;pa=A;Ea=x;ja=u;e.viewport(Z,pa,Ea,ja)};this.setScissor=function(m,A,x,u){e.scissor(m,A,x,u)};this.enableScissorTest=function(m){m?e.enable(e.SCISSOR_TEST):e.disable(e.SCISSOR_TEST)};this.enableDepthBufferWrite=function(m){Ia=m;e.depthMask(m)};this.setClearColorHex=
|
|
|
+function(m,A){var x=new THREE.Color(m);e.clearColor(x.r,x.g,x.b,A)};this.setClearColor=function(m,A){e.clearColor(m.r,m.g,m.b,A)};this.clear=function(){e.clear(e.COLOR_BUFFER_BIT|e.DEPTH_BUFFER_BIT|e.STENCIL_BUFFER_BIT)};this.setStencilShadowDarkness=function(m){ga.darkness=m};this.initMaterial=function(m,A,x,u){var w,O,F,G;if(m instanceof THREE.MeshDepthMaterial)c(m,THREE.ShaderLib.depth);else if(m instanceof THREE.ShadowVolumeDynamicMaterial)c(m,THREE.ShaderLib.shadowVolumeDynamic);else if(m instanceof
|
|
|
+THREE.MeshNormalMaterial)c(m,THREE.ShaderLib.normal);else if(m instanceof THREE.MeshBasicMaterial)c(m,THREE.ShaderLib.basic);else if(m instanceof THREE.MeshLambertMaterial)c(m,THREE.ShaderLib.lambert);else if(m instanceof THREE.MeshPhongMaterial)c(m,THREE.ShaderLib.phong);else if(m instanceof THREE.LineBasicMaterial)c(m,THREE.ShaderLib.basic);else m instanceof THREE.ParticleBasicMaterial&&c(m,THREE.ShaderLib.particle_basic);if(!m.program){var H,D,I;H=I=G=0;for(F=A.length;H<F;H++){D=A[H];D instanceof
|
|
|
+THREE.DirectionalLight&&I++;D instanceof THREE.PointLight&&G++}if(G+I<=4)A=I;else{A=Math.ceil(4*I/(G+I));G=4-A}G={directional:A,point:G};A=50;if(u!==undefined&&u instanceof THREE.SkinnedMesh)A=u.bones.length;F={map:m.map,envMap:m.envMap,lightMap:m.lightMap,vertexColors:m.vertexColors,fog:x,sizeAttenuation:m.sizeAttenuation,skinning:m.skinning,morphTargets:m.morphTargets,maxDirLights:G.directional,maxPointLights:G.point,maxBones:A};x=m.fragmentShader;G=m.vertexShader;A=e.createProgram();H=["#ifdef GL_ES\nprecision highp float;\n#endif",
|
|
|
+"#define MAX_DIR_LIGHTS "+F.maxDirLights,"#define MAX_POINT_LIGHTS "+F.maxPointLights,F.fog?"#define USE_FOG":"",F.fog instanceof THREE.FogExp2?"#define FOG_EXP2":"",F.map?"#define USE_MAP":"",F.envMap?"#define USE_ENVMAP":"",F.lightMap?"#define USE_LIGHTMAP":"",F.vertexColors?"#define USE_COLOR":"","uniform mat4 viewMatrix;\nuniform vec3 cameraPosition;\n"].join("\n");F=[e.getParameter(e.MAX_VERTEX_TEXTURE_IMAGE_UNITS)>0?"#define VERTEX_TEXTURES":"","#define MAX_DIR_LIGHTS "+F.maxDirLights,"#define MAX_POINT_LIGHTS "+
|
|
|
+F.maxPointLights,"#define MAX_BONES "+F.maxBones,F.map?"#define USE_MAP":"",F.envMap?"#define USE_ENVMAP":"",F.lightMap?"#define USE_LIGHTMAP":"",F.vertexColors?"#define USE_COLOR":"",F.skinning?"#define USE_SKINNING":"",F.morphTargets?"#define USE_MORPHTARGETS":"",F.sizeAttenuation?"#define USE_SIZEATTENUATION":"","uniform mat4 objectMatrix;\nuniform mat4 modelViewMatrix;\nuniform mat4 projectionMatrix;\nuniform mat4 viewMatrix;\nuniform mat3 normalMatrix;\nuniform vec3 cameraPosition;\nuniform mat4 cameraInverseMatrix;\nattribute vec3 position;\nattribute vec3 normal;\nattribute vec2 uv;\nattribute vec2 uv2;\n#ifdef USE_COLOR\nattribute vec3 color;\n#endif\n#ifdef USE_MORPHTARGETS\nattribute vec3 morphTarget0;\nattribute vec3 morphTarget1;\nattribute vec3 morphTarget2;\nattribute vec3 morphTarget3;\nattribute vec3 morphTarget4;\nattribute vec3 morphTarget5;\nattribute vec3 morphTarget6;\nattribute vec3 morphTarget7;\n#endif\n#ifdef USE_SKINNING\nattribute vec4 skinVertexA;\nattribute vec4 skinVertexB;\nattribute vec4 skinIndex;\nattribute vec4 skinWeight;\n#endif\n"].join("\n");
|
|
|
+e.attachShader(A,sa("fragment",H+x));e.attachShader(A,sa("vertex",F+G));e.linkProgram(A);e.getProgramParameter(A,e.LINK_STATUS)||console.error("Could not initialise shader\nVALIDATE_STATUS: "+e.getProgramParameter(A,e.VALIDATE_STATUS)+", gl error ["+e.getError()+"]");A.uniforms={};A.attributes={};m.program=A;x=["viewMatrix","modelViewMatrix","projectionMatrix","normalMatrix","objectMatrix","cameraPosition","cameraInverseMatrix","boneGlobalMatrices","morphTargetInfluences"];for(w in m.uniforms)x.push(w);
|
|
|
+w=m.program;G=0;for(A=x.length;G<A;G++){H=x[G];w.uniforms[H]=e.getUniformLocation(w,H)}x=["position","normal","uv","uv2","tangent","color","skinVertexA","skinVertexB","skinIndex","skinWeight"];for(w=0;w<this.maxMorphTargets;w++)x.push("morphTarget"+w);for(O in m.attributes)x.push(O);w=m.program;G=0;for(A=x.length;G<A;G++){H=x[G];w.attributes[H]=e.getAttribLocation(w,H)}w=m.program.attributes;e.enableVertexAttribArray(w.position);w.color>=0&&e.enableVertexAttribArray(w.color);w.normal>=0&&e.enableVertexAttribArray(w.normal);
|
|
|
+w.tangent>=0&&e.enableVertexAttribArray(w.tangent);if(m.skinning&&w.skinVertexA>=0&&w.skinVertexB>=0&&w.skinIndex>=0&&w.skinWeight>=0){e.enableVertexAttribArray(w.skinVertexA);e.enableVertexAttribArray(w.skinVertexB);e.enableVertexAttribArray(w.skinIndex);e.enableVertexAttribArray(w.skinWeight)}for(O in m.attributes)w[O]>=0&&e.enableVertexAttribArray(w[O]);if(m.morphTargets){m.numSupportedMorphTargets=0;if(w.morphTarget0>=0){e.enableVertexAttribArray(w.morphTarget0);m.numSupportedMorphTargets++}if(w.morphTarget1>=
|
|
|
+0){e.enableVertexAttribArray(w.morphTarget1);m.numSupportedMorphTargets++}if(w.morphTarget2>=0){e.enableVertexAttribArray(w.morphTarget2);m.numSupportedMorphTargets++}if(w.morphTarget3>=0){e.enableVertexAttribArray(w.morphTarget3);m.numSupportedMorphTargets++}if(w.morphTarget4>=0){e.enableVertexAttribArray(w.morphTarget4);m.numSupportedMorphTargets++}if(w.morphTarget5>=0){e.enableVertexAttribArray(w.morphTarget5);m.numSupportedMorphTargets++}if(w.morphTarget6>=0){e.enableVertexAttribArray(w.morphTarget6);
|
|
|
+m.numSupportedMorphTargets++}if(w.morphTarget7>=0){e.enableVertexAttribArray(w.morphTarget7);m.numSupportedMorphTargets++}u.__webglMorphTargetInfluences=new Float32Array(this.maxMorphTargets);w=0;for(O=this.maxMorphTargets;w<O;w++)u.__webglMorphTargetInfluences[w]=0}}m.__webglProgram=!0};this.render=function(m,A,x,u){var w,O,F,G,H,D,I,V,oa=m.lights,U=m.fog;A.matrixAutoUpdate&&A.updateMatrix();m.update(undefined,!1,A);A.matrixWorldInverse.flattenToArray(Za);A.projectionMatrix.flattenToArray(Ra);Fa.multiply(A.projectionMatrix,
|
|
|
+A.matrixWorldInverse);n(Fa);this.initWebGLObjects(m);Ga(x);(this.autoClear||u)&&this.clear();H=m.__webglObjects.length;for(u=0;u<H;u++){w=m.__webglObjects[u];I=w.object;if(I.visible)if(!(I instanceof THREE.Mesh)||p(I)){I.matrixWorld.flattenToArray(I._objectMatrixArray);E(I,A);y(w);w.render=!0;if(this.sortObjects){Va.copy(I.position);Fa.multiplyVector3(Va);w.z=Va.z}}else w.render=!1;else w.render=!1}this.sortObjects&&m.__webglObjects.sort(v);D=m.__webglObjectsImmediate.length;for(u=0;u<D;u++){w=m.__webglObjectsImmediate[u];
|
|
|
+I=w.object;if(I.visible){I.matrixAutoUpdate&&I.matrixWorld.flattenToArray(I._objectMatrixArray);E(I,A);t(w)}}K(THREE.NormalBlending);for(u=0;u<H;u++){w=m.__webglObjects[u];if(w.render){I=w.object;V=w.buffer;F=w.opaque;j(I);for(w=0;w<F.count;w++){G=F.list[w];k(G.depthTest);g(A,oa,U,G,V,I)}}}for(u=0;u<D;u++){w=m.__webglObjectsImmediate[u];I=w.object;if(I.visible){F=w.opaque;j(I);for(w=0;w<F.count;w++){G=F.list[w];k(G.depthTest);O=f(A,oa,U,G,I);I.render(function(Da){h(Da,O)})}}}for(u=0;u<H;u++){w=m.__webglObjects[u];
|
|
|
+if(w.render){I=w.object;V=w.buffer;F=w.transparent;j(I);for(w=0;w<F.count;w++){G=F.list[w];K(G.blending);k(G.depthTest);g(A,oa,U,G,V,I)}}}for(u=0;u<D;u++){w=m.__webglObjectsImmediate[u];I=w.object;if(I.visible){F=w.transparent;j(I);for(w=0;w<F.count;w++){G=F.list[w];K(G.blending);k(G.depthTest);O=f(A,oa,U,G,I);I.render(function(Da){h(Da,O)})}}}N&&m.__webglShadowVolumes.length&&m.lights.length&&B(m);m.__webglLensFlares.length&&C(m,A);if(x&&x.minFilter!==THREE.NearestFilter&&x.minFilter!==THREE.LinearFilter){e.bindTexture(e.TEXTURE_2D,
|
|
|
+x.__webglTexture);e.generateMipmap(e.TEXTURE_2D);e.bindTexture(e.TEXTURE_2D,null)}};this.initWebGLObjects=function(m){if(!m.__webglObjects){m.__webglObjects=[];m.__webglObjectsImmediate=[];m.__webglShadowVolumes=[];m.__webglLensFlares=[]}for(;m.__objectsAdded.length;){var A=m.__objectsAdded[0],x=m,u=void 0,w=void 0,O=void 0;if(A._modelViewMatrix==undefined){A._modelViewMatrix=new THREE.Matrix4;A._normalMatrixArray=new Float32Array(9);A._modelViewMatrixArray=new Float32Array(16);A._objectMatrixArray=
|
|
|
+new Float32Array(16);A.matrixWorld.flattenToArray(A._objectMatrixArray)}if(A instanceof THREE.Mesh){w=A.geometry;w.geometryGroups==undefined&&T(w);for(u in w.geometryGroups){O=w.geometryGroups[u];if(!O.__webglVertexBuffer){var F=O;F.__webglVertexBuffer=e.createBuffer();F.__webglNormalBuffer=e.createBuffer();F.__webglTangentBuffer=e.createBuffer();F.__webglColorBuffer=e.createBuffer();F.__webglUVBuffer=e.createBuffer();F.__webglUV2Buffer=e.createBuffer();F.__webglSkinVertexABuffer=e.createBuffer();
|
|
|
+F.__webglSkinVertexBBuffer=e.createBuffer();F.__webglSkinIndicesBuffer=e.createBuffer();F.__webglSkinWeightsBuffer=e.createBuffer();F.__webglFaceBuffer=e.createBuffer();F.__webglLineBuffer=e.createBuffer();if(F.numMorphTargets){var G=void 0,H=void 0;F.__webglMorphTargetsBuffers=[];G=0;for(H=F.numMorphTargets;G<H;G++)F.__webglMorphTargetsBuffers.push(e.createBuffer())}F=O;G=A;var D=void 0,I=void 0,V=void 0;V=void 0;var oa=void 0,U=void 0,Da=void 0,Ja=Da=H=0;I=void 0;V=void 0;var ra=void 0;D=void 0;
|
|
|
+I=void 0;oa=G.geometry;ra=oa.faces;U=F.faces;D=0;for(I=U.length;D<I;D++){V=U[D];V=ra[V];if(V instanceof THREE.Face3){H+=3;Da+=1;Ja+=3}else if(V instanceof THREE.Face4){H+=4;Da+=2;Ja+=4}}D=F;I=G;ra=void 0;U=void 0;var xa=void 0,bb=void 0;xa=void 0;V=[];ra=0;for(U=I.materials.length;ra<U;ra++){xa=I.materials[ra];if(xa instanceof THREE.MeshFaceMaterial){xa=0;for(l=D.materials.length;xa<l;xa++)(bb=D.materials[xa])&&V.push(bb)}else(bb=xa)&&V.push(bb)}D=V;a:{I=void 0;ra=void 0;U=D.length;for(I=0;I<U;I++){ra=
|
|
|
+D[I];if(ra.map||ra.lightMap||ra instanceof THREE.MeshShaderMaterial){I=!0;break a}}I=!1}a:{ra=D;U=void 0;V=void 0;xa=ra.length;for(U=0;U<xa;U++){V=ra[U];if(!(V instanceof THREE.MeshBasicMaterial&&!V.envMap||V instanceof THREE.MeshDepthMaterial)){ra=V&&V.shading!=undefined&&V.shading==THREE.SmoothShading?THREE.SmoothShading:THREE.FlatShading;break a}}ra=!1}a:{U=void 0;V=void 0;xa=D.length;for(U=0;U<xa;U++){V=D[U];if(V.vertexColors){V=V.vertexColors;break a}}V=!1}F.__vertexArray=new Float32Array(H*
|
|
|
+3);if(ra)F.__normalArray=new Float32Array(H*3);if(oa.hasTangents)F.__tangentArray=new Float32Array(H*4);if(V)F.__colorArray=new Float32Array(H*3);if(I){if(oa.faceUvs.length>0||oa.faceVertexUvs.length>0)F.__uvArray=new Float32Array(H*2);if(oa.faceUvs.length>1||oa.faceVertexUvs.length>1)F.__uv2Array=new Float32Array(H*2)}if(G.geometry.skinWeights.length&&G.geometry.skinIndices.length){F.__skinVertexAArray=new Float32Array(H*4);F.__skinVertexBArray=new Float32Array(H*4);F.__skinIndexArray=new Float32Array(H*
|
|
|
+4);F.__skinWeightArray=new Float32Array(H*4)}F.__faceArray=new Uint16Array(Da*3+(G.geometry.edgeFaces?G.geometry.edgeFaces.length*6:0));F.__lineArray=new Uint16Array(Ja*2);if(F.numMorphTargets){F.__morphTargetsArrays=[];oa=0;for(U=F.numMorphTargets;oa<U;oa++)F.__morphTargetsArrays.push(new Float32Array(H*3))}F.__needsSmoothNormals=ra==THREE.SmoothShading;F.__uvType=I;F.__vertexColorType=V;F.__normalType=ra;F.__webglFaceCount=Da*3+(G.geometry.edgeFaces?G.geometry.edgeFaces.length*6:0);F.__webglLineCount=
|
|
|
+Ja*2;oa=0;for(U=D.length;oa<U;oa++)if(D[oa].attributes){F.__webglCustomAttributes={};for(a in D[oa].attributes){I=D[oa].attributes[a];Da=1;if(I.type==="v2")Da=2;else if(I.type==="v3")Da=3;else if(I.type==="v4")Da=4;else I.type==="c"&&(Da=3);I.size=Da;I.needsUpdate=!0;I.array=new Float32Array(H*Da);I.buffer=e.createBuffer();F.__webglCustomAttributes[a]=I}}w.__dirtyVertices=!0;w.__dirtyMorphTargets=!0;w.__dirtyElements=!0;w.__dirtyUvs=!0;w.__dirtyNormals=!0;w.__dirtyTangents=!0;w.__dirtyColors=!0}A instanceof
|
|
|
+THREE.ShadowVolume?z(x.__webglShadowVolumes,O,A):z(x.__webglObjects,O,A)}}else if(A instanceof THREE.LensFlare)z(x.__webglLensFlares,undefined,A);else if(A instanceof THREE.Ribbon){w=A.geometry;if(!w.__webglVertexBuffer){u=w;u.__webglVertexBuffer=e.createBuffer();u.__webglColorBuffer=e.createBuffer();u=w;O=u.vertices.length;u.__vertexArray=new Float32Array(O*3);u.__colorArray=new Float32Array(O*3);u.__webglVertexCount=O;w.__dirtyVertices=!0;w.__dirtyColors=!0}z(x.__webglObjects,w,A)}else if(A instanceof
|
|
|
+THREE.Line){w=A.geometry;if(!w.__webglVertexBuffer){u=w;u.__webglVertexBuffer=e.createBuffer();u.__webglColorBuffer=e.createBuffer();u=w;O=u.vertices.length;u.__vertexArray=new Float32Array(O*3);u.__colorArray=new Float32Array(O*3);u.__webglLineCount=O;w.__dirtyVertices=!0;w.__dirtyColors=!0}z(x.__webglObjects,w,A)}else if(A instanceof THREE.ParticleSystem){w=A.geometry;if(!w.__webglVertexBuffer){u=w;u.__webglVertexBuffer=e.createBuffer();u.__webglColorBuffer=e.createBuffer();u=w;O=u.vertices.length;
|
|
|
+u.__vertexArray=new Float32Array(O*3);u.__colorArray=new Float32Array(O*3);u.__sortArray=[];u.__webglParticleCount=O;w.__dirtyVertices=!0;w.__dirtyColors=!0}z(x.__webglObjects,w,A)}else THREE.MarchingCubes!==undefined&&A instanceof THREE.MarchingCubes&&x.__webglObjectsImmediate.push({object:A,opaque:{list:[],count:0},transparent:{list:[],count:0}});m.__objectsAdded.splice(0,1)}for(;m.__objectsRemoved.length;){A=m.__objectsRemoved[0];x=m;w=void 0;u=void 0;for(w=x.__webglObjects.length-1;w>=0;w--){u=
|
|
|
+x.__webglObjects[w].object;A==u&&x.__webglObjects.splice(w,1)}m.__objectsRemoved.splice(0,1)}A=0;for(x=m.__webglObjects.length;A<x;A++)J(m.__webglObjects[A].object,m);A=0;for(x=m.__webglShadowVolumes.length;A<x;A++)J(m.__webglShadowVolumes[A].object,m);A=0;for(x=m.__webglLensFlares.length;A<x;A++)J(m.__webglLensFlares[A].object,m)};this.setFaceCulling=function(m,A){if(m){!A||A=="ccw"?e.frontFace(e.CCW):e.frontFace(e.CW);if(m=="back")e.cullFace(e.BACK);else m=="front"?e.cullFace(e.FRONT):e.cullFace(e.FRONT_AND_BACK);
|
|
|
e.enable(e.CULL_FACE)}else e.disable(e.CULL_FACE)};this.supportsVertexTextures=function(){return e.getParameter(e.MAX_VERTEX_TEXTURE_IMAGE_UNITS)>0}};
|
|
|
THREE.WebGLRenderTarget=function(b,d,c){this.width=b;this.height=d;c=c||{};this.wrapS=c.wrapS!==undefined?c.wrapS:THREE.ClampToEdgeWrapping;this.wrapT=c.wrapT!==undefined?c.wrapT:THREE.ClampToEdgeWrapping;this.magFilter=c.magFilter!==undefined?c.magFilter:THREE.LinearFilter;this.minFilter=c.minFilter!==undefined?c.minFilter:THREE.LinearMipMapLinearFilter;this.format=c.format!==undefined?c.format:THREE.RGBFormat;this.type=c.type!==undefined?c.type:THREE.UnsignedByteType};
|
|
|
THREE.SoundRenderer=function(){this.volume=1;this.domElement=document.createElement("div");this.domElement.id="THREESound";this.cameraPosition=new THREE.Vector3;this.soundPosition=new THREE.Vector3;this.render=function(b,d,c){c&&b.update(undefined,!1,d);c=b.sounds;var f,g=c.length;for(f=0;f<g;f++){b=c[f];this.soundPosition.set(b.matrixWorld.n14,b.matrixWorld.n24,b.matrixWorld.n34);this.soundPosition.subSelf(d.position);if(b.isPlaying&&b.isLoaded){b.isAddedToDOM||b.addToDOM(this.domElement);b.calculateVolumeAndPan(this.soundPosition)}}}};
|
|
@@ -327,18 +327,18 @@ THREE.RenderableVertex=function(){this.positionWorld=new THREE.Vector3;this.posi
|
|
|
THREE.RenderableFace3=function(){this.v1=new THREE.RenderableVertex;this.v2=new THREE.RenderableVertex;this.v3=new THREE.RenderableVertex;this.centroidWorld=new THREE.Vector3;this.centroidScreen=new THREE.Vector3;this.normalWorld=new THREE.Vector3;this.vertexNormalsWorld=[new THREE.Vector3,new THREE.Vector3,new THREE.Vector3];this.faceMaterials=this.meshMaterials=null;this.overdraw=!1;this.uvs=[[]];this.z=null};
|
|
|
THREE.RenderableFace4=function(){this.v1=new THREE.RenderableVertex;this.v2=new THREE.RenderableVertex;this.v3=new THREE.RenderableVertex;this.v4=new THREE.RenderableVertex;this.centroidWorld=new THREE.Vector3;this.centroidScreen=new THREE.Vector3;this.normalWorld=new THREE.Vector3;this.vertexNormalsWorld=[new THREE.Vector3,new THREE.Vector3,new THREE.Vector3,new THREE.Vector3];this.faceMaterials=this.meshMaterials=null;this.overdraw=!1;this.uvs=[[]];this.z=null};
|
|
|
THREE.RenderableObject=function(){this.z=this.object=null};THREE.RenderableParticle=function(){this.rotation=this.z=this.y=this.x=null;this.scale=new THREE.Vector2;this.materials=null};THREE.RenderableLine=function(){this.z=null;this.v1=new THREE.RenderableVertex;this.v2=new THREE.RenderableVertex;this.materials=null};
|
|
|
-var GeometryUtils={merge:function(b,d){var c=d instanceof THREE.Mesh,f=b.vertices.length,g=c?d.geometry:d,h=b.vertices,j=g.vertices,k=b.faces,n=g.faces,p=b.faceVertexUvs[0];g=g.faceVertexUvs[0];c&&d.matrixAutoUpdate&&d.updateMatrix();for(var o=0,x=j.length;o<x;o++){var A=new THREE.Vertex(j[o].position.clone());c&&d.matrix.multiplyVector3(A.position);h.push(A)}o=0;for(x=n.length;o<x;o++){j=n[o];var t,C,F=j.vertexNormals;A=j.vertexColors;if(j instanceof THREE.Face3)t=new THREE.Face3(j.a+f,j.b+f,j.c+
|
|
|
-f);else j instanceof THREE.Face4&&(t=new THREE.Face4(j.a+f,j.b+f,j.c+f,j.d+f));t.normal.copy(j.normal);c=0;for(h=F.length;c<h;c++){C=F[c];t.vertexNormals.push(C.clone())}t.color.copy(j.color);c=0;for(h=A.length;c<h;c++){C=A[c];t.vertexColors.push(C.clone())}t.materials=j.materials.slice();t.centroid.copy(j.centroid);k.push(t)}o=0;for(x=g.length;o<x;o++){f=g[o];k=[];c=0;for(h=f.length;c<h;c++)k.push(new THREE.UV(f[c].u,f[c].v));p.push(k)}}},ImageUtils={loadTexture:function(b,d,c){var f=new Image,g=
|
|
|
-new THREE.Texture(f,d);f.onload=function(){g.needsUpdate=!0;c&&c(this)};f.src=b;return g},loadTextureCube:function(b,d,c){var f,g=[],h=new THREE.Texture(g,d);d=g.loadCount=0;for(f=b.length;d<f;++d){g[d]=new Image;g[d].onload=function(){g.loadCount+=1;if(g.loadCount==6)h.needsUpdate=!0;c&&c(this)};g[d].src=b[d]}return h}},SceneUtils={loadScene:function(b,d,c,f){var g=new Worker(b);g.postMessage(0);var h=THREE.Loader.prototype.extractUrlbase(b);g.onmessage=function(j){function k(Ca,ka){return ka=="relativeToHTML"?
|
|
|
-Ca:h+"/"+Ca}function n(){for(t in da.objects)if(!ea.objects[t]){U=da.objects[t];if(Q=ea.geometries[U.geometry]){Aa=[];for(va=0;va<U.materials.length;va++)Aa[va]=ea.materials[U.materials[va]];D=U.position;r=U.rotation;q=U.quaternion;s=U.scale;q=0;Aa.length==0&&(Aa[0]=new THREE.MeshFaceMaterial);object=new THREE.Mesh(Q,Aa);object.position.set(D[0],D[1],D[2]);if(q){object.quaternion.set(q[0],q[1],q[2],q[3]);object.useQuaternion=!0}else object.rotation.set(r[0],r[1],r[2]);object.scale.set(s[0],s[1],s[2]);
|
|
|
-object.visible=U.visible;ea.scene.addObject(object);ea.objects[t]=object}}}function p(Ca){return function(ka){ea.geometries[Ca]=ka;n();Ba-=1;o()}}function o(){f({total_models:Ka,total_textures:wa,loaded_models:Ka-Ba,loaded_textures:wa-Ja},ea);Ba==0&&Ja==0&&c(ea)}var x,A,t,C,F,I,G,U,D,M,O,Q,Ia,ua,Aa,da,e,ga,Ba,Ja,Ka,wa,ea;da=j.data;e=new THREE.BinaryLoader;ga=new THREE.JSONLoader;Ja=Ba=0;ea={scene:new THREE.Scene,geometries:{},materials:{},textures:{},objects:{},cameras:{},lights:{},fogs:{}};j=function(){Ja-=
|
|
|
-1;o()};for(F in da.cameras){M=da.cameras[F];if(M.type=="perspective")Ia=new THREE.Camera(M.fov,M.aspect,M.near,M.far);else if(M.type=="ortho"){Ia=new THREE.Camera;Ia.projectionMatrix=THREE.Matrix4.makeOrtho(M.left,M.right,M.top,M.bottom,M.near,M.far)}D=M.position;M=M.target;Ia.position.set(D[0],D[1],D[2]);Ia.target.position.set(M[0],M[1],M[2]);ea.cameras[F]=Ia}for(C in da.lights){F=da.lights[C];Ia=F.color!==undefined?F.color:16777215;M=F.intensity!==undefined?F.intensity:1;if(F.type=="directional"){D=
|
|
|
-F.direction;light=new THREE.DirectionalLight(Ia,M);light.position.set(D[0],D[1],D[2]);light.position.normalize()}else if(F.type=="point"){D=F.position;light=new THREE.PointLight(Ia,M);light.position.set(D[0],D[1],D[2])}ea.scene.addLight(light);ea.lights[C]=light}for(I in da.fogs){C=da.fogs[I];if(C.type=="linear")ua=new THREE.Fog(0,C.near,C.far);else C.type=="exp2"&&(ua=new THREE.FogExp2(0,C.density));M=C.color;ua.color.setRGB(M[0],M[1],M[2]);ea.fogs[I]=ua}if(ea.cameras&&da.defaults.camera)ea.currentCamera=
|
|
|
-ea.cameras[da.defaults.camera];if(ea.fogs&&da.defaults.fog)ea.scene.fog=ea.fogs[da.defaults.fog];M=da.defaults.bgcolor;ea.bgColor=new THREE.Color;ea.bgColor.setRGB(M[0],M[1],M[2]);ea.bgColorAlpha=da.defaults.bgalpha;for(x in da.geometries){I=da.geometries[x];if(I.type=="bin_mesh"||I.type=="ascii_mesh")Ba+=1}Ka=Ba;for(x in da.geometries){I=da.geometries[x];if(I.type=="cube"){Q=new Cube(I.width,I.height,I.depth,I.segmentsWidth,I.segmentsHeight,I.segmentsDepth,null,I.flipped,I.sides);ea.geometries[x]=
|
|
|
-Q}else if(I.type=="plane"){Q=new Plane(I.width,I.height,I.segmentsWidth,I.segmentsHeight);ea.geometries[x]=Q}else if(I.type=="sphere"){Q=new Sphere(I.radius,I.segmentsWidth,I.segmentsHeight);ea.geometries[x]=Q}else if(I.type=="cylinder"){Q=new Cylinder(I.numSegs,I.topRad,I.botRad,I.height,I.topOffset,I.botOffset);ea.geometries[x]=Q}else if(I.type=="torus"){Q=new Torus(I.radius,I.tube,I.segmentsR,I.segmentsT);ea.geometries[x]=Q}else if(I.type=="icosahedron"){Q=new Icosahedron(I.subdivisions);ea.geometries[x]=
|
|
|
-Q}else if(I.type=="bin_mesh")e.load({model:k(I.url,da.urlBaseType),callback:p(x)});else I.type=="ascii_mesh"&&ga.load({model:k(I.url,da.urlBaseType),callback:p(x)})}for(G in da.textures){x=da.textures[G];Ja+=x.url instanceof Array?x.url.length:1}wa=Ja;for(G in da.textures){x=da.textures[G];if(x.mapping!=undefined&&THREE[x.mapping]!=undefined)x.mapping=new THREE[x.mapping];if(x.url instanceof Array){I=[];for(var va=0;va<x.url.length;va++)I[va]=k(x.url[va],da.urlBaseType);I=ImageUtils.loadTextureCube(I,
|
|
|
-x.mapping,j)}else{I=ImageUtils.loadTexture(k(x.url,da.urlBaseType),x.mapping,j);if(THREE[x.minFilter]!=undefined)I.minFilter=THREE[x.minFilter];if(THREE[x.magFilter]!=undefined)I.magFilter=THREE[x.magFilter]}ea.textures[G]=I}for(A in da.materials){G=da.materials[A];for(O in G.parameters)if(O=="envMap"||O=="map"||O=="lightMap")G.parameters[O]=ea.textures[G.parameters[O]];else if(O=="shading")G.parameters[O]=G.parameters[O]=="flat"?THREE.FlatShading:THREE.SmoothShading;else if(O=="blending")G.parameters[O]=
|
|
|
-THREE[G.parameters[O]]?THREE[G.parameters[O]]:THREE.NormalBlending;else O=="combine"&&(G.parameters[O]=G.parameters[O]=="MixOperation"?THREE.MixOperation:THREE.MultiplyOperation);G=new THREE[G.type](G.parameters);ea.materials[A]=G}n();d(ea)}},addMesh:function(b,d,c,f,g,h,j,k,n,p){d=new THREE.Mesh(d,p);d.scale.x=d.scale.y=d.scale.z=c;d.position.x=f;d.position.y=g;d.position.z=h;d.rotation.x=j;d.rotation.y=k;d.rotation.z=n;b.addObject(d);return d},addPanoramaCubeWebGL:function(b,d,c){var f=ShaderUtils.lib.cube;
|
|
|
+var GeometryUtils={merge:function(b,d){var c=d instanceof THREE.Mesh,f=b.vertices.length,g=c?d.geometry:d,h=b.vertices,j=g.vertices,k=b.faces,n=g.faces,p=b.faceVertexUvs[0];g=g.faceVertexUvs[0];c&&d.matrixAutoUpdate&&d.updateMatrix();for(var o=0,t=j.length;o<t;o++){var y=new THREE.Vertex(j[o].position.clone());c&&d.matrix.multiplyVector3(y.position);h.push(y)}o=0;for(t=n.length;o<t;o++){j=n[o];var v,B,C=j.vertexNormals;y=j.vertexColors;if(j instanceof THREE.Face3)v=new THREE.Face3(j.a+f,j.b+f,j.c+
|
|
|
+f);else j instanceof THREE.Face4&&(v=new THREE.Face4(j.a+f,j.b+f,j.c+f,j.d+f));v.normal.copy(j.normal);c=0;for(h=C.length;c<h;c++){B=C[c];v.vertexNormals.push(B.clone())}v.color.copy(j.color);c=0;for(h=y.length;c<h;c++){B=y[c];v.vertexColors.push(B.clone())}v.materials=j.materials.slice();v.centroid.copy(j.centroid);k.push(v)}o=0;for(t=g.length;o<t;o++){f=g[o];k=[];c=0;for(h=f.length;c<h;c++)k.push(new THREE.UV(f[c].u,f[c].v));p.push(k)}}},ImageUtils={loadTexture:function(b,d,c){var f=new Image,g=
|
|
|
+new THREE.Texture(f,d);f.onload=function(){g.needsUpdate=!0;c&&c(this)};f.src=b;return g},loadTextureCube:function(b,d,c){var f,g=[],h=new THREE.Texture(g,d);d=g.loadCount=0;for(f=b.length;d<f;++d){g[d]=new Image;g[d].onload=function(){g.loadCount+=1;if(g.loadCount==6)h.needsUpdate=!0;c&&c(this)};g[d].src=b[d]}return h}},SceneUtils={loadScene:function(b,d,c,f){var g=new Worker(b);g.postMessage(0);var h=THREE.Loader.prototype.extractUrlbase(b);g.onmessage=function(j){function k(Aa,ia){return ia=="relativeToHTML"?
|
|
|
+Aa:h+"/"+Aa}function n(){for(v in aa.objects)if(!ca.objects[v]){T=aa.objects[v];if(M=ca.geometries[T.geometry]){ya=[];for(ta=0;ta<T.materials.length;ta++)ya[ta]=ca.materials[T.materials[ta]];z=T.position;r=T.rotation;q=T.quaternion;s=T.scale;q=0;ya.length==0&&(ya[0]=new THREE.MeshFaceMaterial);object=new THREE.Mesh(M,ya);object.position.set(z[0],z[1],z[2]);if(q){object.quaternion.set(q[0],q[1],q[2],q[3]);object.useQuaternion=!0}else object.rotation.set(r[0],r[1],r[2]);object.scale.set(s[0],s[1],s[2]);
|
|
|
+object.visible=T.visible;ca.scene.addObject(object);ca.objects[v]=object}}}function p(Aa){return function(ia){ca.geometries[Aa]=ia;n();za-=1;o()}}function o(){f({total_models:Ia,total_textures:ua,loaded_models:Ia-za,loaded_textures:ua-Ha},ca);za==0&&Ha==0&&c(ca)}var t,y,v,B,C,E,J,T,z,K,L,M,Ga,sa,ya,aa,e,ea,za,Ha,Ia,ua,ca;aa=j.data;e=new THREE.BinaryLoader;ea=new THREE.JSONLoader;Ha=za=0;ca={scene:new THREE.Scene,geometries:{},materials:{},textures:{},objects:{},cameras:{},lights:{},fogs:{}};j=function(){Ha-=
|
|
|
+1;o()};for(C in aa.cameras){K=aa.cameras[C];if(K.type=="perspective")Ga=new THREE.Camera(K.fov,K.aspect,K.near,K.far);else if(K.type=="ortho"){Ga=new THREE.Camera;Ga.projectionMatrix=THREE.Matrix4.makeOrtho(K.left,K.right,K.top,K.bottom,K.near,K.far)}z=K.position;K=K.target;Ga.position.set(z[0],z[1],z[2]);Ga.target.position.set(K[0],K[1],K[2]);ca.cameras[C]=Ga}for(B in aa.lights){C=aa.lights[B];Ga=C.color!==undefined?C.color:16777215;K=C.intensity!==undefined?C.intensity:1;if(C.type=="directional"){z=
|
|
|
+C.direction;light=new THREE.DirectionalLight(Ga,K);light.position.set(z[0],z[1],z[2]);light.position.normalize()}else if(C.type=="point"){z=C.position;light=new THREE.PointLight(Ga,K);light.position.set(z[0],z[1],z[2])}ca.scene.addLight(light);ca.lights[B]=light}for(E in aa.fogs){B=aa.fogs[E];if(B.type=="linear")sa=new THREE.Fog(0,B.near,B.far);else B.type=="exp2"&&(sa=new THREE.FogExp2(0,B.density));K=B.color;sa.color.setRGB(K[0],K[1],K[2]);ca.fogs[E]=sa}if(ca.cameras&&aa.defaults.camera)ca.currentCamera=
|
|
|
+ca.cameras[aa.defaults.camera];if(ca.fogs&&aa.defaults.fog)ca.scene.fog=ca.fogs[aa.defaults.fog];K=aa.defaults.bgcolor;ca.bgColor=new THREE.Color;ca.bgColor.setRGB(K[0],K[1],K[2]);ca.bgColorAlpha=aa.defaults.bgalpha;for(t in aa.geometries){E=aa.geometries[t];if(E.type=="bin_mesh"||E.type=="ascii_mesh")za+=1}Ia=za;for(t in aa.geometries){E=aa.geometries[t];if(E.type=="cube"){M=new Cube(E.width,E.height,E.depth,E.segmentsWidth,E.segmentsHeight,E.segmentsDepth,null,E.flipped,E.sides);ca.geometries[t]=
|
|
|
+M}else if(E.type=="plane"){M=new Plane(E.width,E.height,E.segmentsWidth,E.segmentsHeight);ca.geometries[t]=M}else if(E.type=="sphere"){M=new Sphere(E.radius,E.segmentsWidth,E.segmentsHeight);ca.geometries[t]=M}else if(E.type=="cylinder"){M=new Cylinder(E.numSegs,E.topRad,E.botRad,E.height,E.topOffset,E.botOffset);ca.geometries[t]=M}else if(E.type=="torus"){M=new Torus(E.radius,E.tube,E.segmentsR,E.segmentsT);ca.geometries[t]=M}else if(E.type=="icosahedron"){M=new Icosahedron(E.subdivisions);ca.geometries[t]=
|
|
|
+M}else if(E.type=="bin_mesh")e.load({model:k(E.url,aa.urlBaseType),callback:p(t)});else E.type=="ascii_mesh"&&ea.load({model:k(E.url,aa.urlBaseType),callback:p(t)})}for(J in aa.textures){t=aa.textures[J];Ha+=t.url instanceof Array?t.url.length:1}ua=Ha;for(J in aa.textures){t=aa.textures[J];if(t.mapping!=undefined&&THREE[t.mapping]!=undefined)t.mapping=new THREE[t.mapping];if(t.url instanceof Array){E=[];for(var ta=0;ta<t.url.length;ta++)E[ta]=k(t.url[ta],aa.urlBaseType);E=ImageUtils.loadTextureCube(E,
|
|
|
+t.mapping,j)}else{E=ImageUtils.loadTexture(k(t.url,aa.urlBaseType),t.mapping,j);if(THREE[t.minFilter]!=undefined)E.minFilter=THREE[t.minFilter];if(THREE[t.magFilter]!=undefined)E.magFilter=THREE[t.magFilter]}ca.textures[J]=E}for(y in aa.materials){J=aa.materials[y];for(L in J.parameters)if(L=="envMap"||L=="map"||L=="lightMap")J.parameters[L]=ca.textures[J.parameters[L]];else if(L=="shading")J.parameters[L]=J.parameters[L]=="flat"?THREE.FlatShading:THREE.SmoothShading;else if(L=="blending")J.parameters[L]=
|
|
|
+THREE[J.parameters[L]]?THREE[J.parameters[L]]:THREE.NormalBlending;else L=="combine"&&(J.parameters[L]=J.parameters[L]=="MixOperation"?THREE.MixOperation:THREE.MultiplyOperation);J=new THREE[J.type](J.parameters);ca.materials[y]=J}n();d(ca)}},addMesh:function(b,d,c,f,g,h,j,k,n,p){d=new THREE.Mesh(d,p);d.scale.x=d.scale.y=d.scale.z=c;d.position.x=f;d.position.y=g;d.position.z=h;d.rotation.x=j;d.rotation.y=k;d.rotation.z=n;b.addObject(d);return d},addPanoramaCubeWebGL:function(b,d,c){var f=ShaderUtils.lib.cube;
|
|
|
f.uniforms.tCube.texture=c;c=new THREE.MeshShaderMaterial({fragmentShader:f.fragmentShader,vertexShader:f.vertexShader,uniforms:f.uniforms});d=new THREE.Mesh(new Cube(d,d,d,1,1,1,null,!0),c);b.addObject(d);return d},addPanoramaCube:function(b,d,c){var f=[];f.push(new THREE.MeshBasicMaterial({map:new THREE.Texture(c[0])}));f.push(new THREE.MeshBasicMaterial({map:new THREE.Texture(c[1])}));f.push(new THREE.MeshBasicMaterial({map:new THREE.Texture(c[2])}));f.push(new THREE.MeshBasicMaterial({map:new THREE.Texture(c[3])}));
|
|
|
f.push(new THREE.MeshBasicMaterial({map:new THREE.Texture(c[4])}));f.push(new THREE.MeshBasicMaterial({map:new THREE.Texture(c[5])}));d=new THREE.Mesh(new Cube(d,d,d,1,1,f,!0),new THREE.MeshFaceMaterial);b.addObject(d);return d},addPanoramaCubePlanes:function(b,d,c){var f=d/2;d=new Plane(d,d);var g=Math.PI,h=Math.PI/2;SceneUtils.addMesh(b,d,1,0,0,-f,0,0,0,new THREE.MeshBasicMaterial({map:new THREE.Texture(c[5])}));SceneUtils.addMesh(b,d,1,-f,0,0,0,h,0,new THREE.MeshBasicMaterial({map:new THREE.Texture(c[0])}));
|
|
|
SceneUtils.addMesh(b,d,1,f,0,0,0,-h,0,new THREE.MeshBasicMaterial({map:new THREE.Texture(c[1])}));SceneUtils.addMesh(b,d,1,0,f,0,h,0,g,new THREE.MeshBasicMaterial({map:new THREE.Texture(c[2])}));SceneUtils.addMesh(b,d,1,0,-f,0,-h,0,g,new THREE.MeshBasicMaterial({map:new THREE.Texture(c[3])}))},showHierarchy:function(b,d){SceneUtils.traverseHierarchy(b,function(c){c.visible=d})},traverseHierarchy:function(b,d){var c,f,g=b.children.length;for(f=0;f<g;f++){c=b.children[f];d(c);SceneUtils.traverseHierarchy(c,
|
|
@@ -360,76 +360,76 @@ this.mouseY=this.mouseX=this.autoSpeedFactor=0;this.moveForward=!1;this.moveBack
|
|
|
var c=this.lookSpeed;this.activeLook||(c=0);this.lon+=this.mouseX*c;this.lookVertical&&(this.lat-=this.mouseY*c);this.lat=Math.max(-85,Math.min(85,this.lat));this.phi=(90-this.lat)*Math.PI/180;this.theta=this.lon*Math.PI/180;c=this.target.position;var f=this.position;c.x=f.x+100*Math.sin(this.phi)*Math.cos(this.theta);c.y=f.y+100*Math.cos(this.phi);c.z=f.z+100*Math.sin(this.phi)*Math.sin(this.theta);this.supr.update.call(this)};this.domElement.addEventListener("contextmenu",function(c){c.preventDefault()},
|
|
|
!1);this.domElement.addEventListener("mousemove",d(this,this.onMouseMove),!1);this.domElement.addEventListener("mousedown",d(this,this.onMouseDown),!1);this.domElement.addEventListener("mouseup",d(this,this.onMouseUp),!1);this.domElement.addEventListener("keydown",d(this,this.onKeyDown),!1);this.domElement.addEventListener("keyup",d(this,this.onKeyUp),!1)};THREE.QuakeCamera.prototype=new THREE.Camera;THREE.QuakeCamera.prototype.constructor=THREE.QuakeCamera;THREE.QuakeCamera.prototype.supr=THREE.Camera.prototype;
|
|
|
THREE.QuakeCamera.prototype.translate=function(b,d){this.matrix.rotateAxis(d);if(this.noFly)d.y=0;this.position.addSelf(d.multiplyScalar(b));this.target.position.addSelf(d.multiplyScalar(b))};
|
|
|
-THREE.PathCamera=function(b){function d(p,o,x,A){var t={name:x,fps:0.6,length:A,hierarchy:[]},C,F=o.getControlPointsArray(),I=o.getLength(),G=F.length,U=0;C=G-1;o={parent:-1,keys:[]};o.keys[0]={time:0,pos:F[0],rot:[0,0,0,1],scl:[1,1,1]};o.keys[C]={time:A,pos:F[C],rot:[0,0,0,1],scl:[1,1,1]};for(C=1;C<G-1;C++){U=A*I.chunks[C]/I.total;o.keys[C]={time:U,pos:F[C]}}t.hierarchy[0]=o;THREE.AnimationHandler.add(t);return new THREE.Animation(p,x,THREE.AnimationHandler.CATMULLROM_FORWARD,!1)}function c(p,o){var x,
|
|
|
-A,t=new THREE.Geometry;for(x=0;x<p.points.length*o;x++){A=x/(p.points.length*o);A=p.getPoint(A);t.vertices[x]=new THREE.Vertex(new THREE.Vector3(A.x,A.y,A.z))}return t}function f(p,o){var x=c(o,10),A=c(o,10),t=new THREE.LineBasicMaterial({color:16711680,linewidth:3});lineObj=new THREE.Line(x,t);particleObj=new THREE.ParticleSystem(A,new THREE.ParticleBasicMaterial({color:16755200,size:3}));lineObj.scale.set(1,1,1);p.addChild(lineObj);particleObj.scale.set(1,1,1);p.addChild(particleObj);A=new Sphere(1,
|
|
|
-16,8);t=new THREE.MeshBasicMaterial({color:65280});for(i=0;i<o.points.length;i++){x=new THREE.Mesh(A,t);x.position.copy(o.points[i]);x.updateMatrix();p.addChild(x)}}THREE.Camera.call(this,b.fov,b.aspect,b.near,b.far,b.target);this.id="PathCamera"+THREE.PathCameraIdCounter++;this.duration=1E4;this.waypoints=[];this.useConstantSpeed=!0;this.resamplingCoef=50;this.debugPath=new THREE.Object3D;this.debugDummy=new THREE.Object3D;this.animationParent=new THREE.Object3D;this.lookSpeed=0.0050;this.lookVertical=
|
|
|
+THREE.PathCamera=function(b){function d(p,o,t,y){var v={name:t,fps:0.6,length:y,hierarchy:[]},B,C=o.getControlPointsArray(),E=o.getLength(),J=C.length,T=0;B=J-1;o={parent:-1,keys:[]};o.keys[0]={time:0,pos:C[0],rot:[0,0,0,1],scl:[1,1,1]};o.keys[B]={time:y,pos:C[B],rot:[0,0,0,1],scl:[1,1,1]};for(B=1;B<J-1;B++){T=y*E.chunks[B]/E.total;o.keys[B]={time:T,pos:C[B]}}v.hierarchy[0]=o;THREE.AnimationHandler.add(v);return new THREE.Animation(p,t,THREE.AnimationHandler.CATMULLROM_FORWARD,!1)}function c(p,o){var t,
|
|
|
+y,v=new THREE.Geometry;for(t=0;t<p.points.length*o;t++){y=t/(p.points.length*o);y=p.getPoint(y);v.vertices[t]=new THREE.Vertex(new THREE.Vector3(y.x,y.y,y.z))}return v}function f(p,o){var t=c(o,10),y=c(o,10),v=new THREE.LineBasicMaterial({color:16711680,linewidth:3});lineObj=new THREE.Line(t,v);particleObj=new THREE.ParticleSystem(y,new THREE.ParticleBasicMaterial({color:16755200,size:3}));lineObj.scale.set(1,1,1);p.addChild(lineObj);particleObj.scale.set(1,1,1);p.addChild(particleObj);y=new Sphere(1,
|
|
|
+16,8);v=new THREE.MeshBasicMaterial({color:65280});for(i=0;i<o.points.length;i++){t=new THREE.Mesh(y,v);t.position.copy(o.points[i]);t.updateMatrix();p.addChild(t)}}THREE.Camera.call(this,b.fov,b.aspect,b.near,b.far,b.target);this.id="PathCamera"+THREE.PathCameraIdCounter++;this.duration=1E4;this.waypoints=[];this.useConstantSpeed=!0;this.resamplingCoef=50;this.debugPath=new THREE.Object3D;this.debugDummy=new THREE.Object3D;this.animationParent=new THREE.Object3D;this.lookSpeed=0.0050;this.lookVertical=
|
|
|
!0;this.lookHorizontal=!0;this.verticalAngleMap={srcRange:[0,6.28],dstRange:[0,6.28]};this.horizontalAngleMap={srcRange:[0,6.28],dstRange:[0,6.28]};this.domElement=document;if(b){if(b.duration!==undefined)this.duration=b.duration*1E3;if(b.waypoints!==undefined)this.waypoints=b.waypoints;if(b.useConstantSpeed!==undefined)this.useConstantSpeed=b.useConstantSpeed;if(b.resamplingCoef!==undefined)this.resamplingCoef=b.resamplingCoef;if(b.createDebugPath!==undefined)this.createDebugPath=b.createDebugPath;
|
|
|
if(b.createDebugDummy!==undefined)this.createDebugDummy=b.createDebugDummy;if(b.lookSpeed!==undefined)this.lookSpeed=b.lookSpeed;if(b.lookVertical!==undefined)this.lookVertical=b.lookVertical;if(b.lookHorizontal!==undefined)this.lookHorizontal=b.lookHorizontal;if(b.verticalAngleMap!==undefined)this.verticalAngleMap=b.verticalAngleMap;if(b.horizontalAngleMap!==undefined)this.horizontalAngleMap=b.horizontalAngleMap;if(b.domElement!==undefined)this.domElement=b.domElement}this.theta=this.phi=this.lon=
|
|
|
-this.lat=this.mouseY=this.mouseX=0;this.windowHalfX=window.innerWidth/2;this.windowHalfY=window.innerHeight/2;var g=Math.PI*2,h=Math.PI/180;this.update=function(p,o,x){var A,t;this.lookHorizontal&&(this.lon+=this.mouseX*this.lookSpeed);this.lookVertical&&(this.lat-=this.mouseY*this.lookSpeed);this.lon=Math.max(0,Math.min(360,this.lon));this.lat=Math.max(-85,Math.min(85,this.lat));this.phi=(90-this.lat)*h;this.theta=this.lon*h;A=this.phi%g;this.phi=A>=0?A:A+g;A=this.verticalAngleMap.srcRange;t=this.verticalAngleMap.dstRange;
|
|
|
-this.phi=(this.phi-A[0])*(t[1]-t[0])/(A[1]-A[0])+t[0];A=this.horizontalAngleMap.srcRange;t=this.horizontalAngleMap.dstRange;this.theta=(this.theta-A[0])*(t[1]-t[0])/(A[1]-A[0])+t[0];A=this.target.position;A.x=100*Math.sin(this.phi)*Math.cos(this.theta);A.y=100*Math.cos(this.phi);A.z=100*Math.sin(this.phi)*Math.sin(this.theta);this.supr.update.call(this,p,o,x)};this.onMouseMove=function(p){this.mouseX=p.clientX-this.windowHalfX;this.mouseY=p.clientY-this.windowHalfY};this.spline=new THREE.Spline;this.spline.initFromArray(this.waypoints);
|
|
|
+this.lat=this.mouseY=this.mouseX=0;this.windowHalfX=window.innerWidth/2;this.windowHalfY=window.innerHeight/2;var g=Math.PI*2,h=Math.PI/180;this.update=function(p,o,t){var y,v;this.lookHorizontal&&(this.lon+=this.mouseX*this.lookSpeed);this.lookVertical&&(this.lat-=this.mouseY*this.lookSpeed);this.lon=Math.max(0,Math.min(360,this.lon));this.lat=Math.max(-85,Math.min(85,this.lat));this.phi=(90-this.lat)*h;this.theta=this.lon*h;y=this.phi%g;this.phi=y>=0?y:y+g;y=this.verticalAngleMap.srcRange;v=this.verticalAngleMap.dstRange;
|
|
|
+this.phi=(this.phi-y[0])*(v[1]-v[0])/(y[1]-y[0])+v[0];y=this.horizontalAngleMap.srcRange;v=this.horizontalAngleMap.dstRange;this.theta=(this.theta-y[0])*(v[1]-v[0])/(y[1]-y[0])+v[0];y=this.target.position;y.x=100*Math.sin(this.phi)*Math.cos(this.theta);y.y=100*Math.cos(this.phi);y.z=100*Math.sin(this.phi)*Math.sin(this.theta);this.supr.update.call(this,p,o,t)};this.onMouseMove=function(p){this.mouseX=p.clientX-this.windowHalfX;this.mouseY=p.clientY-this.windowHalfY};this.spline=new THREE.Spline;this.spline.initFromArray(this.waypoints);
|
|
|
this.useConstantSpeed&&this.spline.reparametrizeByArcLength(this.resamplingCoef);if(this.createDebugDummy){b=new THREE.MeshLambertMaterial({color:30719});var j=new THREE.MeshLambertMaterial({color:65280}),k=new Cube(10,10,20),n=new Cube(2,2,10);this.animationParent=new THREE.Mesh(k,b);b=new THREE.Mesh(n,j);b.position.set(0,10,0);this.animation=d(this.animationParent,this.spline,this.id,this.duration);this.animationParent.addChild(this);this.animationParent.addChild(this.target);this.animationParent.addChild(b)}else{this.animation=
|
|
|
d(this.animationParent,this.spline,this.id,this.duration);this.animationParent.addChild(this.target);this.animationParent.addChild(this)}this.createDebugPath&&f(this.debugPath,this.spline);this.domElement.addEventListener("mousemove",function(p,o){return function(){o.apply(p,arguments)}}(this,this.onMouseMove),!1)};THREE.PathCamera.prototype=new THREE.Camera;THREE.PathCamera.prototype.constructor=THREE.PathCamera;THREE.PathCamera.prototype.supr=THREE.Camera.prototype;THREE.PathCameraIdCounter=0;
|
|
|
-var Cube=function(b,d,c,f,g,h,j,k,n){function p(I,G,U,D,M,O,Q,Ia){var ua,Aa,da=f||1,e=g||1,ga=M/2,Ba=O/2,Ja=o.vertices.length;if(I=="x"&&G=="y"||I=="y"&&G=="x")ua="z";else if(I=="x"&&G=="z"||I=="z"&&G=="x"){ua="y";e=h||1}else if(I=="z"&&G=="y"||I=="y"&&G=="z"){ua="x";da=h||1}var Ka=da+1,wa=e+1;M/=da;var ea=O/e;for(Aa=0;Aa<wa;Aa++)for(O=0;O<Ka;O++){var va=new THREE.Vector3;va[I]=(O*M-ga)*U;va[G]=(Aa*ea-Ba)*D;va[ua]=Q;o.vertices.push(new THREE.Vertex(va))}for(Aa=0;Aa<e;Aa++)for(O=0;O<da;O++){o.faces.push(new THREE.Face4(O+
|
|
|
-Ka*Aa+Ja,O+Ka*(Aa+1)+Ja,O+1+Ka*(Aa+1)+Ja,O+1+Ka*Aa+Ja,null,null,Ia));o.faceVertexUvs[0].push([new THREE.UV(O/da,Aa/e),new THREE.UV(O/da,(Aa+1)/e),new THREE.UV((O+1)/da,(Aa+1)/e),new THREE.UV((O+1)/da,Aa/e)])}}THREE.Geometry.call(this);var o=this,x=b/2,A=d/2,t=c/2;k=k?-1:1;if(j!==undefined)if(j instanceof Array)this.materials=j;else{this.materials=[];for(var C=0;C<6;C++)this.materials.push([j])}else this.materials=[];this.sides={px:!0,nx:!0,py:!0,ny:!0,pz:!0,nz:!0};if(n!=undefined)for(var F in n)this.sides[F]!=
|
|
|
-undefined&&(this.sides[F]=n[F]);this.sides.px&&p("z","y",1*k,-1,c,d,-x,this.materials[0]);this.sides.nx&&p("z","y",-1*k,-1,c,d,x,this.materials[1]);this.sides.py&&p("x","z",1*k,1,b,c,A,this.materials[2]);this.sides.ny&&p("x","z",1*k,-1,b,c,-A,this.materials[3]);this.sides.pz&&p("x","y",1*k,-1,b,d,t,this.materials[4]);this.sides.nz&&p("x","y",-1*k,-1,b,d,-t,this.materials[5]);(function(){for(var I=[],G=[],U=0,D=o.vertices.length;U<D;U++){for(var M=o.vertices[U],O=!1,Q=0,Ia=I.length;Q<Ia;Q++){var ua=
|
|
|
-I[Q];if(M.position.x==ua.position.x&&M.position.y==ua.position.y&&M.position.z==ua.position.z){G[U]=Q;O=!0;break}}if(!O){G[U]=I.length;I.push(new THREE.Vertex(M.position.clone()))}}U=0;for(D=o.faces.length;U<D;U++){M=o.faces[U];M.a=G[M.a];M.b=G[M.b];M.c=G[M.c];M.d=G[M.d]}o.vertices=I})();this.computeCentroids();this.computeFaceNormals()};Cube.prototype=new THREE.Geometry;Cube.prototype.constructor=Cube;
|
|
|
-var Cylinder=function(b,d,c,f,g,h){function j(o,x,A){k.vertices.push(new THREE.Vertex(new THREE.Vector3(o,x,A)))}THREE.Geometry.call(this);var k=this,n=Math.PI,p=f/2;for(f=0;f<b;f++)j(Math.sin(2*n*f/b)*d,Math.cos(2*n*f/b)*d,-p);for(f=0;f<b;f++)j(Math.sin(2*n*f/b)*c,Math.cos(2*n*f/b)*c,p);for(f=0;f<b;f++)k.faces.push(new THREE.Face4(f,f+b,b+(f+1)%b,(f+1)%b));if(c>0){j(0,0,-p-(h||0));for(f=b;f<b+b/2;f++)k.faces.push(new THREE.Face4(2*b,(2*f-2*b)%b,(2*f-2*b+1)%b,(2*f-2*b+2)%b))}if(d>0){j(0,0,p+(g||0));
|
|
|
+var Cube=function(b,d,c,f,g,h,j,k,n){function p(E,J,T,z,K,L,M,Ga){var sa,ya,aa=f||1,e=g||1,ea=K/2,za=L/2,Ha=o.vertices.length;if(E=="x"&&J=="y"||E=="y"&&J=="x")sa="z";else if(E=="x"&&J=="z"||E=="z"&&J=="x"){sa="y";e=h||1}else if(E=="z"&&J=="y"||E=="y"&&J=="z"){sa="x";aa=h||1}var Ia=aa+1,ua=e+1;K/=aa;var ca=L/e;for(ya=0;ya<ua;ya++)for(L=0;L<Ia;L++){var ta=new THREE.Vector3;ta[E]=(L*K-ea)*T;ta[J]=(ya*ca-za)*z;ta[sa]=M;o.vertices.push(new THREE.Vertex(ta))}for(ya=0;ya<e;ya++)for(L=0;L<aa;L++){o.faces.push(new THREE.Face4(L+
|
|
|
+Ia*ya+Ha,L+Ia*(ya+1)+Ha,L+1+Ia*(ya+1)+Ha,L+1+Ia*ya+Ha,null,null,Ga));o.faceVertexUvs[0].push([new THREE.UV(L/aa,ya/e),new THREE.UV(L/aa,(ya+1)/e),new THREE.UV((L+1)/aa,(ya+1)/e),new THREE.UV((L+1)/aa,ya/e)])}}THREE.Geometry.call(this);var o=this,t=b/2,y=d/2,v=c/2;k=k?-1:1;if(j!==undefined)if(j instanceof Array)this.materials=j;else{this.materials=[];for(var B=0;B<6;B++)this.materials.push([j])}else this.materials=[];this.sides={px:!0,nx:!0,py:!0,ny:!0,pz:!0,nz:!0};if(n!=undefined)for(var C in n)this.sides[C]!=
|
|
|
+undefined&&(this.sides[C]=n[C]);this.sides.px&&p("z","y",1*k,-1,c,d,-t,this.materials[0]);this.sides.nx&&p("z","y",-1*k,-1,c,d,t,this.materials[1]);this.sides.py&&p("x","z",1*k,1,b,c,y,this.materials[2]);this.sides.ny&&p("x","z",1*k,-1,b,c,-y,this.materials[3]);this.sides.pz&&p("x","y",1*k,-1,b,d,v,this.materials[4]);this.sides.nz&&p("x","y",-1*k,-1,b,d,-v,this.materials[5]);(function(){for(var E=[],J=[],T=0,z=o.vertices.length;T<z;T++){for(var K=o.vertices[T],L=!1,M=0,Ga=E.length;M<Ga;M++){var sa=
|
|
|
+E[M];if(K.position.x==sa.position.x&&K.position.y==sa.position.y&&K.position.z==sa.position.z){J[T]=M;L=!0;break}}if(!L){J[T]=E.length;E.push(new THREE.Vertex(K.position.clone()))}}T=0;for(z=o.faces.length;T<z;T++){K=o.faces[T];K.a=J[K.a];K.b=J[K.b];K.c=J[K.c];K.d=J[K.d]}o.vertices=E})();this.computeCentroids();this.computeFaceNormals()};Cube.prototype=new THREE.Geometry;Cube.prototype.constructor=Cube;
|
|
|
+var Cylinder=function(b,d,c,f,g,h){function j(o,t,y){k.vertices.push(new THREE.Vertex(new THREE.Vector3(o,t,y)))}THREE.Geometry.call(this);var k=this,n=Math.PI,p=f/2;for(f=0;f<b;f++)j(Math.sin(2*n*f/b)*d,Math.cos(2*n*f/b)*d,-p);for(f=0;f<b;f++)j(Math.sin(2*n*f/b)*c,Math.cos(2*n*f/b)*c,p);for(f=0;f<b;f++)k.faces.push(new THREE.Face4(f,f+b,b+(f+1)%b,(f+1)%b));if(c>0){j(0,0,-p-(h||0));for(f=b;f<b+b/2;f++)k.faces.push(new THREE.Face4(2*b,(2*f-2*b)%b,(2*f-2*b+1)%b,(2*f-2*b+2)%b))}if(d>0){j(0,0,p+(g||0));
|
|
|
for(f=b+b/2;f<2*b;f++)k.faces.push(new THREE.Face4(2*b+1,(2*f-2*b+2)%b+b,(2*f-2*b+1)%b+b,(2*f-2*b)%b+b))}this.computeCentroids();this.computeFaceNormals()};Cylinder.prototype=new THREE.Geometry;Cylinder.prototype.constructor=Cylinder;
|
|
|
-var Icosahedron=function(b){function d(x,A,t){var C=Math.sqrt(x*x+A*A+t*t);return g.vertices.push(new THREE.Vertex(new THREE.Vector3(x/C,A/C,t/C)))-1}function c(x,A,t,C){C.faces.push(new THREE.Face3(x,A,t))}function f(x,A){var t=g.vertices[x].position,C=g.vertices[A].position;return d((t.x+C.x)/2,(t.y+C.y)/2,(t.z+C.z)/2)}var g=this,h=new THREE.Geometry,j;this.subdivisions=b||0;THREE.Geometry.call(this);b=(1+Math.sqrt(5))/2;d(-1,b,0);d(1,b,0);d(-1,-b,0);d(1,-b,0);d(0,-1,b);d(0,1,b);d(0,-1,-b);d(0,
|
|
|
+var Icosahedron=function(b){function d(t,y,v){var B=Math.sqrt(t*t+y*y+v*v);return g.vertices.push(new THREE.Vertex(new THREE.Vector3(t/B,y/B,v/B)))-1}function c(t,y,v,B){B.faces.push(new THREE.Face3(t,y,v))}function f(t,y){var v=g.vertices[t].position,B=g.vertices[y].position;return d((v.x+B.x)/2,(v.y+B.y)/2,(v.z+B.z)/2)}var g=this,h=new THREE.Geometry,j;this.subdivisions=b||0;THREE.Geometry.call(this);b=(1+Math.sqrt(5))/2;d(-1,b,0);d(1,b,0);d(-1,-b,0);d(1,-b,0);d(0,-1,b);d(0,1,b);d(0,-1,-b);d(0,
|
|
|
1,-b);d(b,0,-1);d(b,0,1);d(-b,0,-1);d(-b,0,1);c(0,11,5,h);c(0,5,1,h);c(0,1,7,h);c(0,7,10,h);c(0,10,11,h);c(1,5,9,h);c(5,11,4,h);c(11,10,2,h);c(10,7,6,h);c(7,1,8,h);c(3,9,4,h);c(3,4,2,h);c(3,2,6,h);c(3,6,8,h);c(3,8,9,h);c(4,9,5,h);c(2,4,11,h);c(6,2,10,h);c(8,6,7,h);c(9,8,1,h);for(b=0;b<this.subdivisions;b++){j=new THREE.Geometry;for(var k in h.faces){var n=f(h.faces[k].a,h.faces[k].b),p=f(h.faces[k].b,h.faces[k].c),o=f(h.faces[k].c,h.faces[k].a);c(h.faces[k].a,n,o,j);c(h.faces[k].b,p,n,j);c(h.faces[k].c,
|
|
|
o,p,j);c(n,p,o,j)}h.faces=j.faces}g.faces=h.faces;delete h;delete j;this.computeCentroids();this.computeFaceNormals();this.computeVertexNormals()};Icosahedron.prototype=new THREE.Geometry;Icosahedron.prototype.constructor=Icosahedron;
|
|
|
function Lathe(b,d,c){THREE.Geometry.call(this);this.steps=d||12;this.angle=c||2*Math.PI;d=this.angle/this.steps;for(var f=[],g=[],h=[],j=[],k=0;k<b.length;k++){this.vertices.push(new THREE.Vertex(b[k]));f[k]=b[k].clone();g[k]=this.vertices.length-1}for(var n=(new THREE.Matrix4).setRotationZ(d),p=0;p<=this.angle+0.0010;p+=d){for(k=0;k<f.length;k++)if(p<this.angle){f[k]=n.multiplyVector3(f[k].clone());this.vertices.push(new THREE.Vertex(f[k]));h[k]=this.vertices.length-1}else h=j;p==0&&(j=g);for(k=
|
|
|
0;k<g.length-1;k++){this.faces.push(new THREE.Face4(h[k],h[k+1],g[k+1],g[k]));this.faceVertexUvs[0].push([new THREE.UV(p/c,k/b.length),new THREE.UV(p/c,(k+1)/b.length),new THREE.UV((p-d)/c,(k+1)/b.length),new THREE.UV((p-d)/c,k/b.length)])}g=h;h=[]}this.computeCentroids();this.computeFaceNormals();this.computeVertexNormals()}Lathe.prototype=new THREE.Geometry;Lathe.prototype.constructor=Lathe;
|
|
|
var Plane=function(b,d,c,f){THREE.Geometry.call(this);var g,h=b/2,j=d/2;c=c||1;f=f||1;var k=c+1,n=f+1;b/=c;var p=d/f;for(g=0;g<n;g++)for(d=0;d<k;d++)this.vertices.push(new THREE.Vertex(new THREE.Vector3(d*b-h,-(g*p-j),0)));for(g=0;g<f;g++)for(d=0;d<c;d++){this.faces.push(new THREE.Face4(d+k*g,d+k*(g+1),d+1+k*(g+1),d+1+k*g));this.faceVertexUvs[0].push([new THREE.UV(d/c,g/f),new THREE.UV(d/c,(g+1)/f),new THREE.UV((d+1)/c,(g+1)/f),new THREE.UV((d+1)/c,g/f)])}this.computeCentroids();this.computeFaceNormals()};
|
|
|
Plane.prototype=new THREE.Geometry;Plane.prototype.constructor=Plane;
|
|
|
-var Sphere=function(b,d,c){THREE.Geometry.call(this);var f,g=Math.PI,h=Math.max(3,d||8),j=Math.max(2,c||6);d=[];for(c=0;c<j+1;c++){f=c/j;var k=b*Math.cos(f*g),n=b*Math.sin(f*g),p=[],o=0;for(f=0;f<h;f++){var x=2*f/h,A=n*Math.sin(x*g);x=n*Math.cos(x*g);(c==0||c==j)&&f>0||(o=this.vertices.push(new THREE.Vertex(new THREE.Vector3(x,k,A)))-1);p.push(o)}d.push(p)}var t,C,F;g=d.length;for(c=0;c<g;c++){h=d[c].length;if(c>0)for(f=0;f<h;f++){p=f==h-1;j=d[c][p?0:f+1];k=d[c][p?h-1:f];n=d[c-1][p?h-1:f];p=d[c-1][p?
|
|
|
-0:f+1];A=c/(g-1);t=(c-1)/(g-1);C=(f+1)/h;x=f/h;o=new THREE.UV(1-C,A);A=new THREE.UV(1-x,A);x=new THREE.UV(1-x,t);var I=new THREE.UV(1-C,t);if(c<d.length-1){t=this.vertices[j].position.clone();C=this.vertices[k].position.clone();F=this.vertices[n].position.clone();t.normalize();C.normalize();F.normalize();this.faces.push(new THREE.Face3(j,k,n,[new THREE.Vector3(t.x,t.y,t.z),new THREE.Vector3(C.x,C.y,C.z),new THREE.Vector3(F.x,F.y,F.z)]));this.faceVertexUvs[0].push([o,A,x])}if(c>1){t=this.vertices[j].position.clone();
|
|
|
-C=this.vertices[n].position.clone();F=this.vertices[p].position.clone();t.normalize();C.normalize();F.normalize();this.faces.push(new THREE.Face3(j,n,p,[new THREE.Vector3(t.x,t.y,t.z),new THREE.Vector3(C.x,C.y,C.z),new THREE.Vector3(F.x,F.y,F.z)]));this.faceVertexUvs[0].push([o,x,I])}}}this.computeCentroids();this.computeFaceNormals();this.computeVertexNormals();this.boundingSphere={radius:b}};Sphere.prototype=new THREE.Geometry;Sphere.prototype.constructor=Sphere;
|
|
|
+var Sphere=function(b,d,c){THREE.Geometry.call(this);var f,g=Math.PI,h=Math.max(3,d||8),j=Math.max(2,c||6);d=[];for(c=0;c<j+1;c++){f=c/j;var k=b*Math.cos(f*g),n=b*Math.sin(f*g),p=[],o=0;for(f=0;f<h;f++){var t=2*f/h,y=n*Math.sin(t*g);t=n*Math.cos(t*g);(c==0||c==j)&&f>0||(o=this.vertices.push(new THREE.Vertex(new THREE.Vector3(t,k,y)))-1);p.push(o)}d.push(p)}var v,B,C;g=d.length;for(c=0;c<g;c++){h=d[c].length;if(c>0)for(f=0;f<h;f++){p=f==h-1;j=d[c][p?0:f+1];k=d[c][p?h-1:f];n=d[c-1][p?h-1:f];p=d[c-1][p?
|
|
|
+0:f+1];y=c/(g-1);v=(c-1)/(g-1);B=(f+1)/h;t=f/h;o=new THREE.UV(1-B,y);y=new THREE.UV(1-t,y);t=new THREE.UV(1-t,v);var E=new THREE.UV(1-B,v);if(c<d.length-1){v=this.vertices[j].position.clone();B=this.vertices[k].position.clone();C=this.vertices[n].position.clone();v.normalize();B.normalize();C.normalize();this.faces.push(new THREE.Face3(j,k,n,[new THREE.Vector3(v.x,v.y,v.z),new THREE.Vector3(B.x,B.y,B.z),new THREE.Vector3(C.x,C.y,C.z)]));this.faceVertexUvs[0].push([o,y,t])}if(c>1){v=this.vertices[j].position.clone();
|
|
|
+B=this.vertices[n].position.clone();C=this.vertices[p].position.clone();v.normalize();B.normalize();C.normalize();this.faces.push(new THREE.Face3(j,n,p,[new THREE.Vector3(v.x,v.y,v.z),new THREE.Vector3(B.x,B.y,B.z),new THREE.Vector3(C.x,C.y,C.z)]));this.faceVertexUvs[0].push([o,t,E])}}}this.computeCentroids();this.computeFaceNormals();this.computeVertexNormals();this.boundingSphere={radius:b}};Sphere.prototype=new THREE.Geometry;Sphere.prototype.constructor=Sphere;
|
|
|
var Torus=function(b,d,c,f){this.radius=b||100;this.tube=d||40;this.segmentsR=c||8;this.segmentsT=f||6;b=[];THREE.Geometry.call(this);for(d=0;d<=this.segmentsR;++d)for(c=0;c<=this.segmentsT;++c){f=c/this.segmentsT*2*Math.PI;var g=d/this.segmentsR*2*Math.PI;this.vertices.push(new THREE.Vertex(new THREE.Vector3((this.radius+this.tube*Math.cos(g))*Math.cos(f),(this.radius+this.tube*Math.cos(g))*Math.sin(f),this.tube*Math.sin(g))));b.push([c/this.segmentsT,1-d/this.segmentsR])}for(d=1;d<=this.segmentsR;++d)for(c=
|
|
|
1;c<=this.segmentsT;++c){f=(this.segmentsT+1)*d+c;g=(this.segmentsT+1)*d+c-1;var h=(this.segmentsT+1)*(d-1)+c-1,j=(this.segmentsT+1)*(d-1)+c;this.faces.push(new THREE.Face4(f,g,h,j));this.faceVertexUvs[0].push([new THREE.UV(b[f][0],b[f][1]),new THREE.UV(b[g][0],b[g][1]),new THREE.UV(b[h][0],b[h][1]),new THREE.UV(b[j][0],b[j][1])])}delete b;this.computeCentroids();this.computeFaceNormals();this.computeVertexNormals()};Torus.prototype=new THREE.Geometry;Torus.prototype.constructor=Torus;
|
|
|
-var TorusKnot=function(b,d,c,f,g,h,j){function k(x,A,t,C,F,I){A=t/C*x;t=Math.cos(A);return new THREE.Vector3(F*(2+t)*0.5*Math.cos(x),F*(2+t)*Math.sin(x)*0.5,I*F*Math.sin(A)*0.5)}THREE.Geometry.call(this);this.radius=b||200;this.tube=d||40;this.segmentsR=c||64;this.segmentsT=f||8;this.p=g||2;this.q=h||3;this.heightScale=j||1;this.grid=Array(this.segmentsR);c=new THREE.Vector3;f=new THREE.Vector3;h=new THREE.Vector3;for(b=0;b<this.segmentsR;++b){this.grid[b]=Array(this.segmentsT);for(d=0;d<this.segmentsT;++d){var n=
|
|
|
+var TorusKnot=function(b,d,c,f,g,h,j){function k(t,y,v,B,C,E){y=v/B*t;v=Math.cos(y);return new THREE.Vector3(C*(2+v)*0.5*Math.cos(t),C*(2+v)*Math.sin(t)*0.5,E*C*Math.sin(y)*0.5)}THREE.Geometry.call(this);this.radius=b||200;this.tube=d||40;this.segmentsR=c||64;this.segmentsT=f||8;this.p=g||2;this.q=h||3;this.heightScale=j||1;this.grid=Array(this.segmentsR);c=new THREE.Vector3;f=new THREE.Vector3;h=new THREE.Vector3;for(b=0;b<this.segmentsR;++b){this.grid[b]=Array(this.segmentsT);for(d=0;d<this.segmentsT;++d){var n=
|
|
|
b/this.segmentsR*2*this.p*Math.PI;j=d/this.segmentsT*2*Math.PI;g=k(n,j,this.q,this.p,this.radius,this.heightScale);n=k(n+0.01,j,this.q,this.p,this.radius,this.heightScale);c.x=n.x-g.x;c.y=n.y-g.y;c.z=n.z-g.z;f.x=n.x+g.x;f.y=n.y+g.y;f.z=n.z+g.z;h.cross(c,f);f.cross(h,c);h.normalize();f.normalize();n=this.tube*Math.cos(j);j=this.tube*Math.sin(j);g.x+=n*f.x+j*h.x;g.y+=n*f.y+j*h.y;g.z+=n*f.z+j*h.z;this.grid[b][d]=this.vertices.push(new THREE.Vertex(new THREE.Vector3(g.x,g.y,g.z)))-1}}for(b=0;b<this.segmentsR;++b)for(d=
|
|
|
0;d<this.segmentsT;++d){h=(b+1)%this.segmentsR;j=(d+1)%this.segmentsT;g=this.grid[b][d];c=this.grid[h][d];f=this.grid[b][j];h=this.grid[h][j];j=new THREE.UV(b/this.segmentsR,d/this.segmentsT);n=new THREE.UV((b+1)/this.segmentsR,d/this.segmentsT);var p=new THREE.UV(b/this.segmentsR,(d+1)/this.segmentsT),o=new THREE.UV((b+1)/this.segmentsR,(d+1)/this.segmentsT);this.faces.push(new THREE.Face3(g,c,f));this.faceVertexUvs[0].push([j,n,p]);this.faces.push(new THREE.Face3(h,f,c));this.faceVertexUvs[0].push([o,
|
|
|
p,n])}this.computeCentroids();this.computeFaceNormals();this.computeVertexNormals()};TorusKnot.prototype=new THREE.Geometry;TorusKnot.prototype.constructor=TorusKnot;THREE.Loader=function(b){this.statusDomElement=(this.showStatus=b)?THREE.Loader.prototype.addStatusElement():null;this.onLoadStart=function(){};this.onLoadProgress=function(){};this.onLoadComplete=function(){}};
|
|
|
THREE.Loader.prototype={addStatusElement:function(){var b=document.createElement("div");b.style.position="absolute";b.style.right="0px";b.style.top="0px";b.style.fontSize="0.8em";b.style.textAlign="left";b.style.background="rgba(0,0,0,0.25)";b.style.color="#fff";b.style.width="120px";b.style.padding="0.5em 0.5em 0.5em 0.5em";b.style.zIndex=1E3;b.innerHTML="Loading ...";return b},updateProgress:function(b){var d="Loaded ";d+=b.total?(100*b.loaded/b.total).toFixed(0)+"%":(b.loaded/1E3).toFixed(2)+" KB";
|
|
|
-this.statusDomElement.innerHTML=d},extractUrlbase:function(b){b=b.split("/");b.pop();return b.join("/")},init_materials:function(b,d,c){b.materials=[];for(var f=0;f<d.length;++f)b.materials[f]=[THREE.Loader.prototype.createMaterial(d[f],c)]},createMaterial:function(b,d){function c(k){k=Math.log(k)/Math.LN2;return Math.floor(k)==k}function f(k,n){var p=new Image;p.onload=function(){if(!c(this.width)||!c(this.height)){var o=Math.pow(2,Math.round(Math.log(this.width)/Math.LN2)),x=Math.pow(2,Math.round(Math.log(this.height)/
|
|
|
-Math.LN2));k.image.width=o;k.image.height=x;k.image.getContext("2d").drawImage(this,0,0,o,x)}else k.image=this;k.needsUpdate=!0};p.src=n}var g,h,j;g="MeshLambertMaterial";h={color:15658734,opacity:1,map:null,lightMap:null,vertexColors:b.vertexColors?THREE.VertexColors:!1,wireframe:b.wireframe};if(b.shading)if(b.shading=="Phong")g="MeshPhongMaterial";else b.shading=="Basic"&&(g="MeshBasicMaterial");if(b.mapDiffuse&&d){j=document.createElement("canvas");h.map=new THREE.Texture(j);h.map.sourceFile=b.mapDiffuse;
|
|
|
+this.statusDomElement.innerHTML=d},extractUrlbase:function(b){b=b.split("/");b.pop();return b.join("/")},init_materials:function(b,d,c){b.materials=[];for(var f=0;f<d.length;++f)b.materials[f]=[THREE.Loader.prototype.createMaterial(d[f],c)]},createMaterial:function(b,d){function c(k){k=Math.log(k)/Math.LN2;return Math.floor(k)==k}function f(k,n){var p=new Image;p.onload=function(){if(!c(this.width)||!c(this.height)){var o=Math.pow(2,Math.round(Math.log(this.width)/Math.LN2)),t=Math.pow(2,Math.round(Math.log(this.height)/
|
|
|
+Math.LN2));k.image.width=o;k.image.height=t;k.image.getContext("2d").drawImage(this,0,0,o,t)}else k.image=this;k.needsUpdate=!0};p.src=n}var g,h,j;g="MeshLambertMaterial";h={color:15658734,opacity:1,map:null,lightMap:null,vertexColors:b.vertexColors?THREE.VertexColors:!1,wireframe:b.wireframe};if(b.shading)if(b.shading=="Phong")g="MeshPhongMaterial";else b.shading=="Basic"&&(g="MeshBasicMaterial");if(b.mapDiffuse&&d){j=document.createElement("canvas");h.map=new THREE.Texture(j);h.map.sourceFile=b.mapDiffuse;
|
|
|
f(h.map,d+"/"+b.mapDiffuse)}else if(b.colorDiffuse){j=(b.colorDiffuse[0]*255<<16)+(b.colorDiffuse[1]*255<<8)+b.colorDiffuse[2]*255;h.color=j;h.opacity=b.transparency}else if(b.DbgColor)h.color=b.DbgColor;if(b.mapLightmap&&d){j=document.createElement("canvas");h.lightMap=new THREE.Texture(j);h.lightMap.sourceFile=b.mapLightmap;f(h.lightMap,d+"/"+b.mapLightmap)}return new THREE[g](h)}};THREE.JSONLoader=function(b){THREE.Loader.call(this,b)};THREE.JSONLoader.prototype=new THREE.Loader;
|
|
|
THREE.JSONLoader.prototype.constructor=THREE.JSONLoader;THREE.JSONLoader.prototype.supr=THREE.Loader.prototype;THREE.JSONLoader.prototype.load=function(b){var d=this,c=b.model,f=b.callback,g=b.texture_path?b.texture_path:this.extractUrlbase(c);b=new Worker(c);b.onmessage=function(h){d.createModel(h.data,f,g);d.onLoadComplete()};this.onLoadStart();b.postMessage((new Date).getTime())};
|
|
|
-THREE.JSONLoader.prototype.createModel=function(b,d,c){var f=new THREE.Geometry;this.init_materials(f,b.materials,c);(function(){if(b.version===undefined||b.version!=2)console.error("Deprecated file format.");else{var g,h,j,k,n,p,o,x,A,t,C,F,I,G=b.faces;p=b.vertices;var U=b.normals,D=b.colors,M=0;for(g=0;g<b.uvs.length;g++)b.uvs[g].length&&M++;for(g=0;g<M;g++){f.faceUvs[g]=[];f.faceVertexUvs[g]=[]}k=0;for(n=p.length;k<n;){C=new THREE.Vertex;C.position.x=p[k++];C.position.y=p[k++];C.position.z=p[k++];
|
|
|
-f.vertices.push(C)}k=0;for(n=G.length;k<n;){A=G[k++];t=A&1;j=A&2;g=A&4;h=A&8;o=A&16;p=A&32;C=A&64;A&=128;if(t){t=new THREE.Face4;t.a=G[k++];t.b=G[k++];t.c=G[k++];t.d=G[k++];nVertices=4}else{t=new THREE.Face3;t.a=G[k++];t.b=G[k++];t.c=G[k++];nVertices=3}if(j){j=G[k++];t.materials=f.materials[j]}j=f.faces.length;if(g)for(g=0;g<M;g++){F=b.uvs[g];x=G[k++];u=F[x*2];v=F[x*2+1];f.faceUvs[g][j]=new THREE.UV(u,v)}if(h)for(g=0;g<M;g++){F=b.uvs[g];I=[];for(h=0;h<nVertices;h++){x=G[k++];u=F[x*2];v=F[x*2+1];I[h]=
|
|
|
-new THREE.UV(u,v)}f.faceVertexUvs[g][j]=I}if(o){o=G[k++]*3;h=new THREE.Vector3;h.x=U[o++];h.y=U[o++];h.z=U[o];t.normal=h}if(p)for(g=0;g<nVertices;g++){o=G[k++]*3;h=new THREE.Vector3;h.x=U[o++];h.y=U[o++];h.z=U[o];t.vertexNormals.push(h)}if(C){p=new THREE.Color(G[k++]);t.color=p}if(A)for(g=0;g<nVertices;g++){p=G[k++];p=new THREE.Color(D[p]);t.vertexColors.push(p)}f.faces.push(t)}}})();(function(){var g,h,j,k;if(b.skinWeights){g=0;for(h=b.skinWeights.length;g<h;g+=2){j=b.skinWeights[g];k=b.skinWeights[g+
|
|
|
-1];f.skinWeights.push(new THREE.Vector4(j,k,0,0))}}if(b.skinIndices){g=0;for(h=b.skinIndices.length;g<h;g+=2){j=b.skinIndices[g];k=b.skinIndices[g+1];f.skinIndices.push(new THREE.Vector4(j,k,0,0))}}f.bones=b.bones;f.animation=b.animation})();(function(){if(b.morphTargets!==undefined){var g,h,j,k;g=0;for(h=b.morphTargets.length;g<h;g++){f.morphTargets[g]={};f.morphTargets[g].name=b.morphTargets[g].name;f.morphTargets[g].vertices=[];dstVertices=f.morphTargets[g].vertices;srcVertices=b.morphTargets[g].vertices;
|
|
|
-j=0;for(k=srcVertices.length;j<k;j+=3)dstVertices.push(new THREE.Vertex(new THREE.Vector3(srcVertices[j],srcVertices[j+1],srcVertices[j+2])))}}})();f.computeCentroids();f.computeFaceNormals();d(f)};THREE.BinaryLoader=function(b){THREE.Loader.call(this,b)};THREE.BinaryLoader.prototype=new THREE.Loader;THREE.BinaryLoader.prototype.constructor=THREE.BinaryLoader;THREE.BinaryLoader.prototype.supr=THREE.Loader.prototype;
|
|
|
+THREE.JSONLoader.prototype.createModel=function(b,d,c){var f=new THREE.Geometry;this.init_materials(f,b.materials,c);(function(){if(b.version===undefined||b.version!=2)console.error("Deprecated file format.");else{var g,h,j,k,n,p,o,t,y,v,B,C,E,J,T,z=b.faces;p=b.vertices;var K=b.normals,L=b.colors,M=0;for(g=0;g<b.uvs.length;g++)b.uvs[g].length&&M++;for(g=0;g<M;g++){f.faceUvs[g]=[];f.faceVertexUvs[g]=[]}k=0;for(n=p.length;k<n;){o=new THREE.Vertex;o.position.x=p[k++];o.position.y=p[k++];o.position.z=
|
|
|
+p[k++];f.vertices.push(o)}k=0;for(n=z.length;k<n;){v=z[k++];p=v&1;j=v&2;g=v&4;h=v&8;t=v&16;o=v&32;B=v&64;v&=128;if(p){C=new THREE.Face4;C.a=z[k++];C.b=z[k++];C.c=z[k++];C.d=z[k++];p=4}else{C=new THREE.Face3;C.a=z[k++];C.b=z[k++];C.c=z[k++];p=3}if(j){j=z[k++];C.materials=f.materials[j]}j=f.faces.length;if(g)for(g=0;g<M;g++){E=b.uvs[g];y=z[k++];T=E[y*2];y=E[y*2+1];f.faceUvs[g][j]=new THREE.UV(T,y)}if(h)for(g=0;g<M;g++){E=b.uvs[g];J=[];for(h=0;h<p;h++){y=z[k++];T=E[y*2];y=E[y*2+1];J[h]=new THREE.UV(T,
|
|
|
+y)}f.faceVertexUvs[g][j]=J}if(t){t=z[k++]*3;h=new THREE.Vector3;h.x=K[t++];h.y=K[t++];h.z=K[t];C.normal=h}if(o)for(g=0;g<p;g++){t=z[k++]*3;h=new THREE.Vector3;h.x=K[t++];h.y=K[t++];h.z=K[t];C.vertexNormals.push(h)}if(B){o=new THREE.Color(z[k++]);C.color=o}if(v)for(g=0;g<p;g++){o=z[k++];o=new THREE.Color(L[o]);C.vertexColors.push(o)}f.faces.push(C)}}})();(function(){var g,h,j,k;if(b.skinWeights){g=0;for(h=b.skinWeights.length;g<h;g+=2){j=b.skinWeights[g];k=b.skinWeights[g+1];f.skinWeights.push(new THREE.Vector4(j,
|
|
|
+k,0,0))}}if(b.skinIndices){g=0;for(h=b.skinIndices.length;g<h;g+=2){j=b.skinIndices[g];k=b.skinIndices[g+1];f.skinIndices.push(new THREE.Vector4(j,k,0,0))}}f.bones=b.bones;f.animation=b.animation})();(function(){if(b.morphTargets!==undefined){var g,h,j,k;g=0;for(h=b.morphTargets.length;g<h;g++){f.morphTargets[g]={};f.morphTargets[g].name=b.morphTargets[g].name;f.morphTargets[g].vertices=[];dstVertices=f.morphTargets[g].vertices;srcVertices=b.morphTargets[g].vertices;j=0;for(k=srcVertices.length;j<
|
|
|
+k;j+=3)dstVertices.push(new THREE.Vertex(new THREE.Vector3(srcVertices[j],srcVertices[j+1],srcVertices[j+2])))}}})();f.computeCentroids();f.computeFaceNormals();d(f)};THREE.BinaryLoader=function(b){THREE.Loader.call(this,b)};THREE.BinaryLoader.prototype=new THREE.Loader;THREE.BinaryLoader.prototype.constructor=THREE.BinaryLoader;THREE.BinaryLoader.prototype.supr=THREE.Loader.prototype;
|
|
|
THREE.BinaryLoader.prototype={load:function(b){var d=b.model,c=b.callback,f=b.texture_path?b.texture_path:THREE.Loader.prototype.extractUrlbase(d),g=b.bin_path?b.bin_path:THREE.Loader.prototype.extractUrlbase(d);b=(new Date).getTime();d=new Worker(d);var h=this.showProgress?THREE.Loader.prototype.updateProgress:null;d.onmessage=function(j){THREE.BinaryLoader.prototype.loadAjaxBuffers(j.data.buffers,j.data.materials,c,g,f,h)};d.onerror=function(j){alert("worker.onerror: "+j.message+"\n"+j.data);j.preventDefault()};
|
|
|
d.postMessage(b)},loadAjaxBuffers:function(b,d,c,f,g,h){var j=new XMLHttpRequest,k=f+"/"+b,n=0;j.onreadystatechange=function(){if(j.readyState==4)j.status==200||j.status==0?THREE.BinaryLoader.prototype.createBinModel(j.responseText,c,g,d):alert("Couldn't load ["+k+"] ["+j.status+"]");else if(j.readyState==3){if(h){n==0&&(n=j.getResponseHeader("Content-Length"));h({total:n,loaded:j.responseText.length})}}else j.readyState==2&&(n=j.getResponseHeader("Content-Length"))};j.open("GET",k,!0);j.overrideMimeType("text/plain; charset=x-user-defined");
|
|
|
-j.setRequestHeader("Content-Type","text/plain");j.send(null)},createBinModel:function(b,d,c,f){var g=function(h){function j(N,ca){var sa=o(N,ca),Ea=o(N,ca+1),ia=o(N,ca+2),ma=o(N,ca+3),m=(ma<<1&255|ia>>7)-127;sa|=(ia&127)<<16|Ea<<8;if(sa==0&&m==-127)return 0;return(1-2*(ma>>7))*(1+sa*Math.pow(2,-23))*Math.pow(2,m)}function k(N,ca){var sa=o(N,ca),Ea=o(N,ca+1),ia=o(N,ca+2);return(o(N,ca+3)<<24)+(ia<<16)+(Ea<<8)+sa}function n(N,ca){var sa=o(N,ca);return(o(N,ca+1)<<8)+sa}function p(N,ca){var sa=o(N,ca);
|
|
|
-return sa>127?sa-256:sa}function o(N,ca){return N.charCodeAt(ca)&255}function x(N){var ca,sa,Ea;ca=k(b,N);sa=k(b,N+Q);Ea=k(b,N+Ia);N=n(b,N+ua);THREE.BinaryLoader.prototype.f3(G,ca,sa,Ea,N)}function A(N){var ca,sa,Ea,ia,ma,m;ca=k(b,N);sa=k(b,N+Q);Ea=k(b,N+Ia);ia=n(b,N+ua);ma=k(b,N+Aa);m=k(b,N+da);N=k(b,N+e);THREE.BinaryLoader.prototype.f3n(G,M,ca,sa,Ea,ia,ma,m,N)}function t(N){var ca,sa,Ea,ia;ca=k(b,N);sa=k(b,N+ga);Ea=k(b,N+Ba);ia=k(b,N+Ja);N=n(b,N+Ka);THREE.BinaryLoader.prototype.f4(G,ca,sa,Ea,ia,
|
|
|
-N)}function C(N){var ca,sa,Ea,ia,ma,m,B,z;ca=k(b,N);sa=k(b,N+ga);Ea=k(b,N+Ba);ia=k(b,N+Ja);ma=n(b,N+Ka);m=k(b,N+wa);B=k(b,N+ea);z=k(b,N+va);N=k(b,N+Ca);THREE.BinaryLoader.prototype.f4n(G,M,ca,sa,Ea,ia,ma,m,B,z,N)}function F(N){var ca,sa;ca=k(b,N);sa=k(b,N+ka);N=k(b,N+aa);THREE.BinaryLoader.prototype.uv3(G.faceVertexUvs[0],O[ca*2],O[ca*2+1],O[sa*2],O[sa*2+1],O[N*2],O[N*2+1])}function I(N){var ca,sa,Ea;ca=k(b,N);sa=k(b,N+ra);Ea=k(b,N+Ga);N=k(b,N+la);THREE.BinaryLoader.prototype.uv4(G.faceVertexUvs[0],
|
|
|
-O[ca*2],O[ca*2+1],O[sa*2],O[sa*2+1],O[Ea*2],O[Ea*2+1],O[N*2],O[N*2+1])}var G=this,U=0,D,M=[],O=[],Q,Ia,ua,Aa,da,e,ga,Ba,Ja,Ka,wa,ea,va,Ca,ka,aa,ra,Ga,la,pa,Ha,Ta,ab,Xa,Ua;THREE.Geometry.call(this);THREE.Loader.prototype.init_materials(G,f,h);D={signature:b.substr(U,8),header_bytes:o(b,U+8),vertex_coordinate_bytes:o(b,U+9),normal_coordinate_bytes:o(b,U+10),uv_coordinate_bytes:o(b,U+11),vertex_index_bytes:o(b,U+12),normal_index_bytes:o(b,U+13),uv_index_bytes:o(b,U+14),material_index_bytes:o(b,U+15),
|
|
|
-nvertices:k(b,U+16),nnormals:k(b,U+16+4),nuvs:k(b,U+16+8),ntri_flat:k(b,U+16+12),ntri_smooth:k(b,U+16+16),ntri_flat_uv:k(b,U+16+20),ntri_smooth_uv:k(b,U+16+24),nquad_flat:k(b,U+16+28),nquad_smooth:k(b,U+16+32),nquad_flat_uv:k(b,U+16+36),nquad_smooth_uv:k(b,U+16+40)};U+=D.header_bytes;Q=D.vertex_index_bytes;Ia=D.vertex_index_bytes*2;ua=D.vertex_index_bytes*3;Aa=D.vertex_index_bytes*3+D.material_index_bytes;da=D.vertex_index_bytes*3+D.material_index_bytes+D.normal_index_bytes;e=D.vertex_index_bytes*
|
|
|
-3+D.material_index_bytes+D.normal_index_bytes*2;ga=D.vertex_index_bytes;Ba=D.vertex_index_bytes*2;Ja=D.vertex_index_bytes*3;Ka=D.vertex_index_bytes*4;wa=D.vertex_index_bytes*4+D.material_index_bytes;ea=D.vertex_index_bytes*4+D.material_index_bytes+D.normal_index_bytes;va=D.vertex_index_bytes*4+D.material_index_bytes+D.normal_index_bytes*2;Ca=D.vertex_index_bytes*4+D.material_index_bytes+D.normal_index_bytes*3;ka=D.uv_index_bytes;aa=D.uv_index_bytes*2;ra=D.uv_index_bytes;Ga=D.uv_index_bytes*2;la=D.uv_index_bytes*
|
|
|
-3;h=D.vertex_index_bytes*3+D.material_index_bytes;Ua=D.vertex_index_bytes*4+D.material_index_bytes;pa=D.ntri_flat*h;Ha=D.ntri_smooth*(h+D.normal_index_bytes*3);Ta=D.ntri_flat_uv*(h+D.uv_index_bytes*3);ab=D.ntri_smooth_uv*(h+D.normal_index_bytes*3+D.uv_index_bytes*3);Xa=D.nquad_flat*Ua;h=D.nquad_smooth*(Ua+D.normal_index_bytes*4);Ua=D.nquad_flat_uv*(Ua+D.uv_index_bytes*4);U+=function(N){for(var ca,sa,Ea,ia=D.vertex_coordinate_bytes*3,ma=N+D.nvertices*ia;N<ma;N+=ia){ca=j(b,N);sa=j(b,N+D.vertex_coordinate_bytes);
|
|
|
-Ea=j(b,N+D.vertex_coordinate_bytes*2);THREE.BinaryLoader.prototype.v(G,ca,sa,Ea)}return D.nvertices*ia}(U);U+=function(N){for(var ca,sa,Ea,ia=D.normal_coordinate_bytes*3,ma=N+D.nnormals*ia;N<ma;N+=ia){ca=p(b,N);sa=p(b,N+D.normal_coordinate_bytes);Ea=p(b,N+D.normal_coordinate_bytes*2);M.push(ca/127,sa/127,Ea/127)}return D.nnormals*ia}(U);U+=function(N){for(var ca,sa,Ea=D.uv_coordinate_bytes*2,ia=N+D.nuvs*Ea;N<ia;N+=Ea){ca=j(b,N);sa=j(b,N+D.uv_coordinate_bytes);O.push(ca,sa)}return D.nuvs*Ea}(U);pa=
|
|
|
-U+pa;Ha=pa+Ha;Ta=Ha+Ta;ab=Ta+ab;Xa=ab+Xa;h=Xa+h;Ua=h+Ua;(function(N){var ca,sa=D.vertex_index_bytes*3+D.material_index_bytes,Ea=sa+D.uv_index_bytes*3,ia=N+D.ntri_flat_uv*Ea;for(ca=N;ca<ia;ca+=Ea){x(ca);F(ca+sa)}return ia-N})(Ha);(function(N){var ca,sa=D.vertex_index_bytes*3+D.material_index_bytes+D.normal_index_bytes*3,Ea=sa+D.uv_index_bytes*3,ia=N+D.ntri_smooth_uv*Ea;for(ca=N;ca<ia;ca+=Ea){A(ca);F(ca+sa)}return ia-N})(Ta);(function(N){var ca,sa=D.vertex_index_bytes*4+D.material_index_bytes,Ea=sa+
|
|
|
-D.uv_index_bytes*4,ia=N+D.nquad_flat_uv*Ea;for(ca=N;ca<ia;ca+=Ea){t(ca);I(ca+sa)}return ia-N})(h);(function(N){var ca,sa=D.vertex_index_bytes*4+D.material_index_bytes+D.normal_index_bytes*4,Ea=sa+D.uv_index_bytes*4,ia=N+D.nquad_smooth_uv*Ea;for(ca=N;ca<ia;ca+=Ea){C(ca);I(ca+sa)}return ia-N})(Ua);(function(N){var ca,sa=D.vertex_index_bytes*3+D.material_index_bytes,Ea=N+D.ntri_flat*sa;for(ca=N;ca<Ea;ca+=sa)x(ca);return Ea-N})(U);(function(N){var ca,sa=D.vertex_index_bytes*3+D.material_index_bytes+D.normal_index_bytes*
|
|
|
-3,Ea=N+D.ntri_smooth*sa;for(ca=N;ca<Ea;ca+=sa)A(ca);return Ea-N})(pa);(function(N){var ca,sa=D.vertex_index_bytes*4+D.material_index_bytes,Ea=N+D.nquad_flat*sa;for(ca=N;ca<Ea;ca+=sa)t(ca);return Ea-N})(ab);(function(N){var ca,sa=D.vertex_index_bytes*4+D.material_index_bytes+D.normal_index_bytes*4,Ea=N+D.nquad_smooth*sa;for(ca=N;ca<Ea;ca+=sa)C(ca);return Ea-N})(Xa);this.computeCentroids();this.computeFaceNormals()};g.prototype=new THREE.Geometry;g.prototype.constructor=g;d(new g(c))},v:function(b,
|
|
|
-d,c,f){b.vertices.push(new THREE.Vertex(new THREE.Vector3(d,c,f)))},f3:function(b,d,c,f,g){b.faces.push(new THREE.Face3(d,c,f,null,null,b.materials[g]))},f4:function(b,d,c,f,g,h){b.faces.push(new THREE.Face4(d,c,f,g,null,null,b.materials[h]))},f3n:function(b,d,c,f,g,h,j,k,n){h=b.materials[h];var p=d[k*3],o=d[k*3+1];k=d[k*3+2];var x=d[n*3],A=d[n*3+1];n=d[n*3+2];b.faces.push(new THREE.Face3(c,f,g,[new THREE.Vector3(d[j*3],d[j*3+1],d[j*3+2]),new THREE.Vector3(p,o,k),new THREE.Vector3(x,A,n)],null,h))},
|
|
|
-f4n:function(b,d,c,f,g,h,j,k,n,p,o){j=b.materials[j];var x=d[n*3],A=d[n*3+1];n=d[n*3+2];var t=d[p*3],C=d[p*3+1];p=d[p*3+2];var F=d[o*3],I=d[o*3+1];o=d[o*3+2];b.faces.push(new THREE.Face4(c,f,g,h,[new THREE.Vector3(d[k*3],d[k*3+1],d[k*3+2]),new THREE.Vector3(x,A,n),new THREE.Vector3(t,C,p),new THREE.Vector3(F,I,o)],null,j))},uv3:function(b,d,c,f,g,h,j){var k=[];k.push(new THREE.UV(d,c));k.push(new THREE.UV(f,g));k.push(new THREE.UV(h,j));b.push(k)},uv4:function(b,d,c,f,g,h,j,k,n){var p=[];p.push(new THREE.UV(d,
|
|
|
-c));p.push(new THREE.UV(f,g));p.push(new THREE.UV(h,j));p.push(new THREE.UV(k,n));b.push(p)}};if(!window.Int32Array){window.Int32Array=Array;window.Float32Array=Array}
|
|
|
+j.setRequestHeader("Content-Type","text/plain");j.send(null)},createBinModel:function(b,d,c,f){var g=function(h){function j(N,$){var qa=o(N,$),Ca=o(N,$+1),ga=o(N,$+2),ka=o(N,$+3),m=(ka<<1&255|ga>>7)-127;qa|=(ga&127)<<16|Ca<<8;if(qa==0&&m==-127)return 0;return(1-2*(ka>>7))*(1+qa*Math.pow(2,-23))*Math.pow(2,m)}function k(N,$){var qa=o(N,$),Ca=o(N,$+1),ga=o(N,$+2);return(o(N,$+3)<<24)+(ga<<16)+(Ca<<8)+qa}function n(N,$){var qa=o(N,$);return(o(N,$+1)<<8)+qa}function p(N,$){var qa=o(N,$);return qa>127?
|
|
|
+qa-256:qa}function o(N,$){return N.charCodeAt($)&255}function t(N){var $,qa,Ca;$=k(b,N);qa=k(b,N+M);Ca=k(b,N+Ga);N=n(b,N+sa);THREE.BinaryLoader.prototype.f3(J,$,qa,Ca,N)}function y(N){var $,qa,Ca,ga,ka,m;$=k(b,N);qa=k(b,N+M);Ca=k(b,N+Ga);ga=n(b,N+sa);ka=k(b,N+ya);m=k(b,N+aa);N=k(b,N+e);THREE.BinaryLoader.prototype.f3n(J,K,$,qa,Ca,ga,ka,m,N)}function v(N){var $,qa,Ca,ga;$=k(b,N);qa=k(b,N+ea);Ca=k(b,N+za);ga=k(b,N+Ha);N=n(b,N+Ia);THREE.BinaryLoader.prototype.f4(J,$,qa,Ca,ga,N)}function B(N){var $,qa,
|
|
|
+Ca,ga,ka,m,A,x;$=k(b,N);qa=k(b,N+ea);Ca=k(b,N+za);ga=k(b,N+Ha);ka=n(b,N+Ia);m=k(b,N+ua);A=k(b,N+ca);x=k(b,N+ta);N=k(b,N+Aa);THREE.BinaryLoader.prototype.f4n(J,K,$,qa,Ca,ga,ka,m,A,x,N)}function C(N){var $,qa;$=k(b,N);qa=k(b,N+ia);N=k(b,N+Z);THREE.BinaryLoader.prototype.uv3(J.faceVertexUvs[0],L[$*2],L[$*2+1],L[qa*2],L[qa*2+1],L[N*2],L[N*2+1])}function E(N){var $,qa,Ca;$=k(b,N);qa=k(b,N+pa);Ca=k(b,N+Ea);N=k(b,N+ja);THREE.BinaryLoader.prototype.uv4(J.faceVertexUvs[0],L[$*2],L[$*2+1],L[qa*2],L[qa*2+1],
|
|
|
+L[Ca*2],L[Ca*2+1],L[N*2],L[N*2+1])}var J=this,T=0,z,K=[],L=[],M,Ga,sa,ya,aa,e,ea,za,Ha,Ia,ua,ca,ta,Aa,ia,Z,pa,Ea,ja,na,Fa,Ra,Za,Va,Sa;THREE.Geometry.call(this);THREE.Loader.prototype.init_materials(J,f,h);z={signature:b.substr(T,8),header_bytes:o(b,T+8),vertex_coordinate_bytes:o(b,T+9),normal_coordinate_bytes:o(b,T+10),uv_coordinate_bytes:o(b,T+11),vertex_index_bytes:o(b,T+12),normal_index_bytes:o(b,T+13),uv_index_bytes:o(b,T+14),material_index_bytes:o(b,T+15),nvertices:k(b,T+16),nnormals:k(b,T+16+
|
|
|
+4),nuvs:k(b,T+16+8),ntri_flat:k(b,T+16+12),ntri_smooth:k(b,T+16+16),ntri_flat_uv:k(b,T+16+20),ntri_smooth_uv:k(b,T+16+24),nquad_flat:k(b,T+16+28),nquad_smooth:k(b,T+16+32),nquad_flat_uv:k(b,T+16+36),nquad_smooth_uv:k(b,T+16+40)};T+=z.header_bytes;M=z.vertex_index_bytes;Ga=z.vertex_index_bytes*2;sa=z.vertex_index_bytes*3;ya=z.vertex_index_bytes*3+z.material_index_bytes;aa=z.vertex_index_bytes*3+z.material_index_bytes+z.normal_index_bytes;e=z.vertex_index_bytes*3+z.material_index_bytes+z.normal_index_bytes*
|
|
|
+2;ea=z.vertex_index_bytes;za=z.vertex_index_bytes*2;Ha=z.vertex_index_bytes*3;Ia=z.vertex_index_bytes*4;ua=z.vertex_index_bytes*4+z.material_index_bytes;ca=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes;ta=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*2;Aa=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*3;ia=z.uv_index_bytes;Z=z.uv_index_bytes*2;pa=z.uv_index_bytes;Ea=z.uv_index_bytes*2;ja=z.uv_index_bytes*3;h=z.vertex_index_bytes*3+z.material_index_bytes;
|
|
|
+Sa=z.vertex_index_bytes*4+z.material_index_bytes;na=z.ntri_flat*h;Fa=z.ntri_smooth*(h+z.normal_index_bytes*3);Ra=z.ntri_flat_uv*(h+z.uv_index_bytes*3);Za=z.ntri_smooth_uv*(h+z.normal_index_bytes*3+z.uv_index_bytes*3);Va=z.nquad_flat*Sa;h=z.nquad_smooth*(Sa+z.normal_index_bytes*4);Sa=z.nquad_flat_uv*(Sa+z.uv_index_bytes*4);T+=function(N){for(var $,qa,Ca,ga=z.vertex_coordinate_bytes*3,ka=N+z.nvertices*ga;N<ka;N+=ga){$=j(b,N);qa=j(b,N+z.vertex_coordinate_bytes);Ca=j(b,N+z.vertex_coordinate_bytes*2);
|
|
|
+THREE.BinaryLoader.prototype.v(J,$,qa,Ca)}return z.nvertices*ga}(T);T+=function(N){for(var $,qa,Ca,ga=z.normal_coordinate_bytes*3,ka=N+z.nnormals*ga;N<ka;N+=ga){$=p(b,N);qa=p(b,N+z.normal_coordinate_bytes);Ca=p(b,N+z.normal_coordinate_bytes*2);K.push($/127,qa/127,Ca/127)}return z.nnormals*ga}(T);T+=function(N){for(var $,qa,Ca=z.uv_coordinate_bytes*2,ga=N+z.nuvs*Ca;N<ga;N+=Ca){$=j(b,N);qa=j(b,N+z.uv_coordinate_bytes);L.push($,qa)}return z.nuvs*Ca}(T);na=T+na;Fa=na+Fa;Ra=Fa+Ra;Za=Ra+Za;Va=Za+Va;h=Va+
|
|
|
+h;Sa=h+Sa;(function(N){var $,qa=z.vertex_index_bytes*3+z.material_index_bytes,Ca=qa+z.uv_index_bytes*3,ga=N+z.ntri_flat_uv*Ca;for($=N;$<ga;$+=Ca){t($);C($+qa)}return ga-N})(Fa);(function(N){var $,qa=z.vertex_index_bytes*3+z.material_index_bytes+z.normal_index_bytes*3,Ca=qa+z.uv_index_bytes*3,ga=N+z.ntri_smooth_uv*Ca;for($=N;$<ga;$+=Ca){y($);C($+qa)}return ga-N})(Ra);(function(N){var $,qa=z.vertex_index_bytes*4+z.material_index_bytes,Ca=qa+z.uv_index_bytes*4,ga=N+z.nquad_flat_uv*Ca;for($=N;$<ga;$+=
|
|
|
+Ca){v($);E($+qa)}return ga-N})(h);(function(N){var $,qa=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*4,Ca=qa+z.uv_index_bytes*4,ga=N+z.nquad_smooth_uv*Ca;for($=N;$<ga;$+=Ca){B($);E($+qa)}return ga-N})(Sa);(function(N){var $,qa=z.vertex_index_bytes*3+z.material_index_bytes,Ca=N+z.ntri_flat*qa;for($=N;$<Ca;$+=qa)t($);return Ca-N})(T);(function(N){var $,qa=z.vertex_index_bytes*3+z.material_index_bytes+z.normal_index_bytes*3,Ca=N+z.ntri_smooth*qa;for($=N;$<Ca;$+=qa)y($);return Ca-
|
|
|
+N})(na);(function(N){var $,qa=z.vertex_index_bytes*4+z.material_index_bytes,Ca=N+z.nquad_flat*qa;for($=N;$<Ca;$+=qa)v($);return Ca-N})(Za);(function(N){var $,qa=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*4,Ca=N+z.nquad_smooth*qa;for($=N;$<Ca;$+=qa)B($);return Ca-N})(Va);this.computeCentroids();this.computeFaceNormals()};g.prototype=new THREE.Geometry;g.prototype.constructor=g;d(new g(c))},v:function(b,d,c,f){b.vertices.push(new THREE.Vertex(new THREE.Vector3(d,c,f)))},f3:function(b,
|
|
|
+d,c,f,g){b.faces.push(new THREE.Face3(d,c,f,null,null,b.materials[g]))},f4:function(b,d,c,f,g,h){b.faces.push(new THREE.Face4(d,c,f,g,null,null,b.materials[h]))},f3n:function(b,d,c,f,g,h,j,k,n){h=b.materials[h];var p=d[k*3],o=d[k*3+1];k=d[k*3+2];var t=d[n*3],y=d[n*3+1];n=d[n*3+2];b.faces.push(new THREE.Face3(c,f,g,[new THREE.Vector3(d[j*3],d[j*3+1],d[j*3+2]),new THREE.Vector3(p,o,k),new THREE.Vector3(t,y,n)],null,h))},f4n:function(b,d,c,f,g,h,j,k,n,p,o){j=b.materials[j];var t=d[n*3],y=d[n*3+1];n=
|
|
|
+d[n*3+2];var v=d[p*3],B=d[p*3+1];p=d[p*3+2];var C=d[o*3],E=d[o*3+1];o=d[o*3+2];b.faces.push(new THREE.Face4(c,f,g,h,[new THREE.Vector3(d[k*3],d[k*3+1],d[k*3+2]),new THREE.Vector3(t,y,n),new THREE.Vector3(v,B,p),new THREE.Vector3(C,E,o)],null,j))},uv3:function(b,d,c,f,g,h,j){var k=[];k.push(new THREE.UV(d,c));k.push(new THREE.UV(f,g));k.push(new THREE.UV(h,j));b.push(k)},uv4:function(b,d,c,f,g,h,j,k,n){var p=[];p.push(new THREE.UV(d,c));p.push(new THREE.UV(f,g));p.push(new THREE.UV(h,j));p.push(new THREE.UV(k,
|
|
|
+n));b.push(p)}};if(!window.Int32Array){window.Int32Array=Array;window.Float32Array=Array}
|
|
|
THREE.MarchingCubes=function(b,d){THREE.Object3D.call(this);this.materials=d instanceof Array?d:[d];this.init=function(c){this.isolation=80;this.size=c;this.size2=this.size*this.size;this.size3=this.size2*this.size;this.halfsize=this.size/2;this.delta=2/this.size;this.yd=this.size;this.zd=this.size2;this.field=new Float32Array(this.size3);this.normal_cache=new Float32Array(this.size3*3);this.vlist=new Float32Array(36);this.nlist=new Float32Array(36);this.firstDraw=!0;this.maxCount=4096;this.count=
|
|
|
-0;this.hasPos=!1;this.hasNormal=!1;this.positionArray=new Float32Array(this.maxCount*3);this.normalArray=new Float32Array(this.maxCount*3)};this.lerp=function(c,f,g){return c+(f-c)*g};this.VIntX=function(c,f,g,h,j,k,n,p,o,x){j=(j-o)/(x-o);o=this.normal_cache;f[h]=k+j*this.delta;f[h+1]=n;f[h+2]=p;g[h]=this.lerp(o[c],o[c+3],j);g[h+1]=this.lerp(o[c+1],o[c+4],j);g[h+2]=this.lerp(o[c+2],o[c+5],j)};this.VIntY=function(c,f,g,h,j,k,n,p,o,x){j=(j-o)/(x-o);o=this.normal_cache;f[h]=k;f[h+1]=n+j*this.delta;f[h+
|
|
|
-2]=p;f=c+this.yd*3;g[h]=this.lerp(o[c],o[f],j);g[h+1]=this.lerp(o[c+1],o[f+1],j);g[h+2]=this.lerp(o[c+2],o[f+2],j)};this.VIntZ=function(c,f,g,h,j,k,n,p,o,x){j=(j-o)/(x-o);o=this.normal_cache;f[h]=k;f[h+1]=n;f[h+2]=p+j*this.delta;f=c+this.zd*3;g[h]=this.lerp(o[c],o[f],j);g[h+1]=this.lerp(o[c+1],o[f+1],j);g[h+2]=this.lerp(o[c+2],o[f+2],j)};this.compNorm=function(c){var f=c*3;if(this.normal_cache[f]==0){this.normal_cache[f]=this.field[c-1]-this.field[c+1];this.normal_cache[f+1]=this.field[c-this.yd]-
|
|
|
-this.field[c+this.yd];this.normal_cache[f+2]=this.field[c-this.zd]-this.field[c+this.zd]}};this.polygonize=function(c,f,g,h,j,k){var n=h+1,p=h+this.yd,o=h+this.zd,x=n+this.yd,A=n+this.zd,t=h+this.yd+this.zd,C=n+this.yd+this.zd,F=0,I=this.field[h],G=this.field[n],U=this.field[p],D=this.field[x],M=this.field[o],O=this.field[A],Q=this.field[t],Ia=this.field[C];I<j&&(F|=1);G<j&&(F|=2);U<j&&(F|=8);D<j&&(F|=4);M<j&&(F|=16);O<j&&(F|=32);Q<j&&(F|=128);Ia<j&&(F|=64);var ua=THREE.edgeTable[F];if(ua==0)return 0;
|
|
|
-var Aa=this.delta,da=c+Aa,e=f+Aa;Aa=g+Aa;if(ua&1){this.compNorm(h);this.compNorm(n);this.VIntX(h*3,this.vlist,this.nlist,0,j,c,f,g,I,G)}if(ua&2){this.compNorm(n);this.compNorm(x);this.VIntY(n*3,this.vlist,this.nlist,3,j,da,f,g,G,D)}if(ua&4){this.compNorm(p);this.compNorm(x);this.VIntX(p*3,this.vlist,this.nlist,6,j,c,e,g,U,D)}if(ua&8){this.compNorm(h);this.compNorm(p);this.VIntY(h*3,this.vlist,this.nlist,9,j,c,f,g,I,U)}if(ua&16){this.compNorm(o);this.compNorm(A);this.VIntX(o*3,this.vlist,this.nlist,
|
|
|
-12,j,c,f,Aa,M,O)}if(ua&32){this.compNorm(A);this.compNorm(C);this.VIntY(A*3,this.vlist,this.nlist,15,j,da,f,Aa,O,Ia)}if(ua&64){this.compNorm(t);this.compNorm(C);this.VIntX(t*3,this.vlist,this.nlist,18,j,c,e,Aa,Q,Ia)}if(ua&128){this.compNorm(o);this.compNorm(t);this.VIntY(o*3,this.vlist,this.nlist,21,j,c,f,Aa,M,Q)}if(ua&256){this.compNorm(h);this.compNorm(o);this.VIntZ(h*3,this.vlist,this.nlist,24,j,c,f,g,I,M)}if(ua&512){this.compNorm(n);this.compNorm(A);this.VIntZ(n*3,this.vlist,this.nlist,27,j,da,
|
|
|
-f,g,G,O)}if(ua&1024){this.compNorm(x);this.compNorm(C);this.VIntZ(x*3,this.vlist,this.nlist,30,j,da,e,g,D,Ia)}if(ua&2048){this.compNorm(p);this.compNorm(t);this.VIntZ(p*3,this.vlist,this.nlist,33,j,c,e,g,U,Q)}F<<=4;for(j=h=0;THREE.triTable[F+j]!=-1;){c=F+j;f=c+1;g=c+2;this.posnormtriv(this.vlist,this.nlist,3*THREE.triTable[c],3*THREE.triTable[f],3*THREE.triTable[g],k);j+=3;h++}return h};this.posnormtriv=function(c,f,g,h,j,k){var n=this.count*3;this.positionArray[n]=c[g];this.positionArray[n+1]=c[g+
|
|
|
+0;this.hasPos=!1;this.hasNormal=!1;this.positionArray=new Float32Array(this.maxCount*3);this.normalArray=new Float32Array(this.maxCount*3)};this.lerp=function(c,f,g){return c+(f-c)*g};this.VIntX=function(c,f,g,h,j,k,n,p,o,t){j=(j-o)/(t-o);o=this.normal_cache;f[h]=k+j*this.delta;f[h+1]=n;f[h+2]=p;g[h]=this.lerp(o[c],o[c+3],j);g[h+1]=this.lerp(o[c+1],o[c+4],j);g[h+2]=this.lerp(o[c+2],o[c+5],j)};this.VIntY=function(c,f,g,h,j,k,n,p,o,t){j=(j-o)/(t-o);o=this.normal_cache;f[h]=k;f[h+1]=n+j*this.delta;f[h+
|
|
|
+2]=p;f=c+this.yd*3;g[h]=this.lerp(o[c],o[f],j);g[h+1]=this.lerp(o[c+1],o[f+1],j);g[h+2]=this.lerp(o[c+2],o[f+2],j)};this.VIntZ=function(c,f,g,h,j,k,n,p,o,t){j=(j-o)/(t-o);o=this.normal_cache;f[h]=k;f[h+1]=n;f[h+2]=p+j*this.delta;f=c+this.zd*3;g[h]=this.lerp(o[c],o[f],j);g[h+1]=this.lerp(o[c+1],o[f+1],j);g[h+2]=this.lerp(o[c+2],o[f+2],j)};this.compNorm=function(c){var f=c*3;if(this.normal_cache[f]==0){this.normal_cache[f]=this.field[c-1]-this.field[c+1];this.normal_cache[f+1]=this.field[c-this.yd]-
|
|
|
+this.field[c+this.yd];this.normal_cache[f+2]=this.field[c-this.zd]-this.field[c+this.zd]}};this.polygonize=function(c,f,g,h,j,k){var n=h+1,p=h+this.yd,o=h+this.zd,t=n+this.yd,y=n+this.zd,v=h+this.yd+this.zd,B=n+this.yd+this.zd,C=0,E=this.field[h],J=this.field[n],T=this.field[p],z=this.field[t],K=this.field[o],L=this.field[y],M=this.field[v],Ga=this.field[B];E<j&&(C|=1);J<j&&(C|=2);T<j&&(C|=8);z<j&&(C|=4);K<j&&(C|=16);L<j&&(C|=32);M<j&&(C|=128);Ga<j&&(C|=64);var sa=THREE.edgeTable[C];if(sa==0)return 0;
|
|
|
+var ya=this.delta,aa=c+ya,e=f+ya;ya=g+ya;if(sa&1){this.compNorm(h);this.compNorm(n);this.VIntX(h*3,this.vlist,this.nlist,0,j,c,f,g,E,J)}if(sa&2){this.compNorm(n);this.compNorm(t);this.VIntY(n*3,this.vlist,this.nlist,3,j,aa,f,g,J,z)}if(sa&4){this.compNorm(p);this.compNorm(t);this.VIntX(p*3,this.vlist,this.nlist,6,j,c,e,g,T,z)}if(sa&8){this.compNorm(h);this.compNorm(p);this.VIntY(h*3,this.vlist,this.nlist,9,j,c,f,g,E,T)}if(sa&16){this.compNorm(o);this.compNorm(y);this.VIntX(o*3,this.vlist,this.nlist,
|
|
|
+12,j,c,f,ya,K,L)}if(sa&32){this.compNorm(y);this.compNorm(B);this.VIntY(y*3,this.vlist,this.nlist,15,j,aa,f,ya,L,Ga)}if(sa&64){this.compNorm(v);this.compNorm(B);this.VIntX(v*3,this.vlist,this.nlist,18,j,c,e,ya,M,Ga)}if(sa&128){this.compNorm(o);this.compNorm(v);this.VIntY(o*3,this.vlist,this.nlist,21,j,c,f,ya,K,M)}if(sa&256){this.compNorm(h);this.compNorm(o);this.VIntZ(h*3,this.vlist,this.nlist,24,j,c,f,g,E,K)}if(sa&512){this.compNorm(n);this.compNorm(y);this.VIntZ(n*3,this.vlist,this.nlist,27,j,aa,
|
|
|
+f,g,J,L)}if(sa&1024){this.compNorm(t);this.compNorm(B);this.VIntZ(t*3,this.vlist,this.nlist,30,j,aa,e,g,z,Ga)}if(sa&2048){this.compNorm(p);this.compNorm(v);this.VIntZ(p*3,this.vlist,this.nlist,33,j,c,e,g,T,M)}C<<=4;for(j=h=0;THREE.triTable[C+j]!=-1;){c=C+j;f=c+1;g=c+2;this.posnormtriv(this.vlist,this.nlist,3*THREE.triTable[c],3*THREE.triTable[f],3*THREE.triTable[g],k);j+=3;h++}return h};this.posnormtriv=function(c,f,g,h,j,k){var n=this.count*3;this.positionArray[n]=c[g];this.positionArray[n+1]=c[g+
|
|
|
1];this.positionArray[n+2]=c[g+2];this.positionArray[n+3]=c[h];this.positionArray[n+4]=c[h+1];this.positionArray[n+5]=c[h+2];this.positionArray[n+6]=c[j];this.positionArray[n+7]=c[j+1];this.positionArray[n+8]=c[j+2];this.normalArray[n]=f[g];this.normalArray[n+1]=f[g+1];this.normalArray[n+2]=f[g+2];this.normalArray[n+3]=f[h];this.normalArray[n+4]=f[h+1];this.normalArray[n+5]=f[h+2];this.normalArray[n+6]=f[j];this.normalArray[n+7]=f[j+1];this.normalArray[n+8]=f[j+2];this.hasPos=!0;this.hasNormal=!0;
|
|
|
-this.count+=3;this.count>=this.maxCount-3&&k(this)};this.begin=function(){this.count=0;this.hasPos=!1;this.hasNormal=!1};this.end=function(c){if(this.count!=0){for(var f=this.count*3;f<this.positionArray.length;f++)this.positionArray[f]=0;c(this)}};this.addBall=function(c,f,g,h,j){var k=this.size*Math.sqrt(h/j),n=g*this.size,p=f*this.size,o=c*this.size,x=Math.floor(n-k);x<1&&(x=1);n=Math.floor(n+k);n>this.size-1&&(n=this.size-1);var A=Math.floor(p-k);A<1&&(A=1);p=Math.floor(p+k);p>this.size-1&&(p=
|
|
|
-this.size-1);var t=Math.floor(o-k);t<1&&(t=1);k=Math.floor(o+k);k>this.size-1&&(k=this.size-1);for(var C,F,I,G,U,D;x<n;x++){o=this.size2*x;F=x/this.size-g;U=F*F;for(F=A;F<p;F++){I=o+this.size*F;C=F/this.size-f;D=C*C;for(C=t;C<k;C++){G=C/this.size-c;G=h/(1.0E-6+G*G+D+U)-j;G>0&&(this.field[I+C]+=G)}}}};this.addPlaneX=function(c,f){var g,h,j,k,n,p=this.size,o=this.yd,x=this.zd,A=this.field,t=p*Math.sqrt(c/f);t>p&&(t=p);for(g=0;g<t;g++){h=g/p;h*=h;k=c/(1.0E-4+h)-f;if(k>0)for(h=0;h<p;h++){n=g+h*o;for(j=
|
|
|
-0;j<p;j++)A[x*j+n]+=k}}};this.addPlaneY=function(c,f){var g,h,j,k,n,p,o=this.size,x=this.yd,A=this.zd,t=this.field,C=o*Math.sqrt(c/f);C>o&&(C=o);for(h=0;h<C;h++){g=h/o;g*=g;k=c/(1.0E-4+g)-f;if(k>0){n=h*x;for(g=0;g<o;g++){p=n+g;for(j=0;j<o;j++)t[A*j+p]+=k}}}};this.addPlaneZ=function(c,f){var g,h,j,k,n,p;size=this.size;yd=this.yd;zd=this.zd;field=this.field;dist=size*Math.sqrt(c/f);dist>size&&(dist=size);for(j=0;j<dist;j++){g=j/size;g*=g;k=c/(1.0E-4+g)-f;if(k>0){n=zd*j;for(h=0;h<size;h++){p=n+h*yd;
|
|
|
-for(g=0;g<size;g++)field[p+g]+=k}}}};this.reset=function(){var c;for(c=0;c<this.size3;c++){this.normal_cache[c*3]=0;this.field[c]=0}};this.render=function(c){this.begin();var f,g,h,j,k,n,p,o,x,A=this.size-2;for(j=1;j<A;j++){x=this.size2*j;p=(j-this.halfsize)/this.halfsize;for(h=1;h<A;h++){o=x+this.size*h;n=(h-this.halfsize)/this.halfsize;for(g=1;g<A;g++){k=(g-this.halfsize)/this.halfsize;f=o+g;this.polygonize(k,n,p,f,this.isolation,c)}}}this.end(c)};this.generateGeometry=function(){var c=0,f=new THREE.Geometry;
|
|
|
-this.render(function(g){var h,j,k,n,p,o,x,A;for(h=0;h<g.count;h++){p=h*3;x=p+1;A=p+2;j=g.positionArray[p];k=g.positionArray[x];n=g.positionArray[A];o=new THREE.Vector3(j,k,n);j=g.normalArray[p];k=g.normalArray[x];n=g.normalArray[A];p=new THREE.Vector3(j,k,n);p.normalize();p=new THREE.Vertex(o,p);f.vertices.push(p)}nfaces=g.count/3;for(h=0;h<nfaces;h++){p=(c+h)*3;x=p+1;A=p+2;o=f.vertices[p].normal;j=f.vertices[x].normal;k=f.vertices[A].normal;p=new THREE.Face3(p,x,A,[o,j,k]);f.faces.push(p)}c+=nfaces;
|
|
|
+this.count+=3;this.count>=this.maxCount-3&&k(this)};this.begin=function(){this.count=0;this.hasPos=!1;this.hasNormal=!1};this.end=function(c){if(this.count!=0){for(var f=this.count*3;f<this.positionArray.length;f++)this.positionArray[f]=0;c(this)}};this.addBall=function(c,f,g,h,j){var k=this.size*Math.sqrt(h/j),n=g*this.size,p=f*this.size,o=c*this.size,t=Math.floor(n-k);t<1&&(t=1);n=Math.floor(n+k);n>this.size-1&&(n=this.size-1);var y=Math.floor(p-k);y<1&&(y=1);p=Math.floor(p+k);p>this.size-1&&(p=
|
|
|
+this.size-1);var v=Math.floor(o-k);v<1&&(v=1);k=Math.floor(o+k);k>this.size-1&&(k=this.size-1);for(var B,C,E,J,T,z;t<n;t++){o=this.size2*t;C=t/this.size-g;T=C*C;for(C=y;C<p;C++){E=o+this.size*C;B=C/this.size-f;z=B*B;for(B=v;B<k;B++){J=B/this.size-c;J=h/(1.0E-6+J*J+z+T)-j;J>0&&(this.field[E+B]+=J)}}}};this.addPlaneX=function(c,f){var g,h,j,k,n,p=this.size,o=this.yd,t=this.zd,y=this.field,v=p*Math.sqrt(c/f);v>p&&(v=p);for(g=0;g<v;g++){h=g/p;h*=h;k=c/(1.0E-4+h)-f;if(k>0)for(h=0;h<p;h++){n=g+h*o;for(j=
|
|
|
+0;j<p;j++)y[t*j+n]+=k}}};this.addPlaneY=function(c,f){var g,h,j,k,n,p,o=this.size,t=this.yd,y=this.zd,v=this.field,B=o*Math.sqrt(c/f);B>o&&(B=o);for(h=0;h<B;h++){g=h/o;g*=g;k=c/(1.0E-4+g)-f;if(k>0){n=h*t;for(g=0;g<o;g++){p=n+g;for(j=0;j<o;j++)v[y*j+p]+=k}}}};this.addPlaneZ=function(c,f){var g,h,j,k,n,p;size=this.size;yd=this.yd;zd=this.zd;field=this.field;dist=size*Math.sqrt(c/f);dist>size&&(dist=size);for(j=0;j<dist;j++){g=j/size;g*=g;k=c/(1.0E-4+g)-f;if(k>0){n=zd*j;for(h=0;h<size;h++){p=n+h*yd;
|
|
|
+for(g=0;g<size;g++)field[p+g]+=k}}}};this.reset=function(){var c;for(c=0;c<this.size3;c++){this.normal_cache[c*3]=0;this.field[c]=0}};this.render=function(c){this.begin();var f,g,h,j,k,n,p,o,t,y=this.size-2;for(j=1;j<y;j++){t=this.size2*j;p=(j-this.halfsize)/this.halfsize;for(h=1;h<y;h++){o=t+this.size*h;n=(h-this.halfsize)/this.halfsize;for(g=1;g<y;g++){k=(g-this.halfsize)/this.halfsize;f=o+g;this.polygonize(k,n,p,f,this.isolation,c)}}}this.end(c)};this.generateGeometry=function(){var c=0,f=new THREE.Geometry;
|
|
|
+this.render(function(g){var h,j,k,n,p,o,t,y;for(h=0;h<g.count;h++){p=h*3;t=p+1;y=p+2;j=g.positionArray[p];k=g.positionArray[t];n=g.positionArray[y];o=new THREE.Vector3(j,k,n);j=g.normalArray[p];k=g.normalArray[t];n=g.normalArray[y];p=new THREE.Vector3(j,k,n);p.normalize();p=new THREE.Vertex(o,p);f.vertices.push(p)}nfaces=g.count/3;for(h=0;h<nfaces;h++){p=(c+h)*3;t=p+1;y=p+2;o=f.vertices[p].normal;j=f.vertices[t].normal;k=f.vertices[y].normal;p=new THREE.Face3(p,t,y,[o,j,k]);f.faces.push(p)}c+=nfaces;
|
|
|
g.count=0});return f};this.init(b)};THREE.MarchingCubes.prototype=new THREE.Object3D;THREE.MarchingCubes.prototype.constructor=THREE.MarchingCubes;
|
|
|
THREE.edgeTable=new Int32Array([0,265,515,778,1030,1295,1541,1804,2060,2309,2575,2822,3082,3331,3593,3840,400,153,915,666,1430,1183,1941,1692,2460,2197,2975,2710,3482,3219,3993,3728,560,825,51,314,1590,1855,1077,1340,2620,2869,2111,2358,3642,3891,3129,3376,928,681,419,170,1958,1711,1445,1196,2988,2725,2479,2214,4010,3747,3497,3232,1120,1385,1635,1898,102,367,613,876,3180,3429,3695,3942,2154,2403,2665,2912,1520,1273,2035,1786,502,255,1013,764,3580,3317,4095,3830,2554,2291,3065,2800,1616,1881,1107,
|
|
|
1370,598,863,85,348,3676,3925,3167,3414,2650,2899,2137,2384,1984,1737,1475,1226,966,719,453,204,4044,3781,3535,3270,3018,2755,2505,2240,2240,2505,2755,3018,3270,3535,3781,4044,204,453,719,966,1226,1475,1737,1984,2384,2137,2899,2650,3414,3167,3925,3676,348,85,863,598,1370,1107,1881,1616,2800,3065,2291,2554,3830,4095,3317,3580,764,1013,255,502,1786,2035,1273,1520,2912,2665,2403,2154,3942,3695,3429,3180,876,613,367,102,1898,1635,1385,1120,3232,3497,3747,4010,2214,2479,2725,2988,1196,1445,1711,1958,170,
|