|
@@ -12,31 +12,31 @@ 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(F,H,U,z){z=z.clone().subSelf(H);U=U.clone().subSelf(H);var J=F.clone().subSelf(H);F=z.dot(z);H=z.dot(U);z=z.dot(J);var L=U.dot(U);U=U.dot(J);J=1/(F*L-H*H);L=(L*z-H*U)*J;F=(F*U-H*z)*J;return L>0&&F>0&&L+F<1}var c,f,g,h,j,k,n,p,o,u,
|
|
|
-y,v=b.geometry,B=v.vertices,C=[];c=0;for(f=v.faces.length;c<f;c++){g=v.faces[c];u=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,u))/o;u=u.addSelf(y.multiplyScalar(p));
|
|
|
-if(g instanceof THREE.Face3){if(d(u,h,j,k)){g={distance:this.origin.distanceTo(u),point:u,face:g,object:b};C.push(g)}}else if(g instanceof THREE.Face4&&(d(u,h,j,n)||d(u,j,k,n))){g={distance:this.origin.distanceTo(u),point:u,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,u){k=!1;d=n;c=p;f=o;g=u;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,u,y,v){if(k){k=!1;d=n<o?n<y?n:y:o<y?o:y;c=p<u?p<v?p:v:u<v?u:v;f=n>o?n>y?n:y:o>y?o:y;g=p>u?p>v?p:v:u>v?u: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<u?p<v?p<c?p:c:v<c?v:c:u<v?u<c?u: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>u?p>v?p>g?p:g:v>g?v:g:u>v?u>g?u: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()?
|
|
|
+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,U,y){y=y.clone().subSelf(J);U=U.clone().subSelf(J);var L=E.clone().subSelf(J);E=y.dot(y);J=y.dot(U);y=y.dot(L);var N=U.dot(U);U=U.dot(L);L=1/(E*N-J*J);N=(N*y-J*U)*L;E=(E*U-J*y)*L;return N>0&&E>0&&N+E<1}var c,f,g,h,j,k,n,p,o,t,
|
|
|
+x,v=b.geometry,z=v.vertices,C=[];c=0;for(f=v.faces.length;c<f;c++){g=v.faces[c];t=this.origin.clone();x=this.direction.clone();n=b.matrixWorld;h=n.multiplyVector3(z[g.a].position.clone());j=n.multiplyVector3(z[g.b].position.clone());k=n.multiplyVector3(z[g.c].position.clone());n=g instanceof THREE.Face4?n.multiplyVector3(z[g.d].position.clone()):null;p=b.matrixRotationWorld.multiplyVector3(g.normal.clone());o=x.dot(p);if(o<0){p=p.dot((new THREE.Vector3).sub(h,t))/o;t=t.addSelf(x.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,x,v){if(k){k=!1;d=n<o?n<x?n:x:o<x?o:x;c=p<t?p<v?p:v:t<v?t:v;f=n>o?n>x?n:x:o>x?o:x;g=p>t?p>v?p:v:t>v?t:v}else{d=n<o?n<x?n<d?n:d:x<d?x:d:o<x?o<d?o:d:x<d?x: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>x?n>f?n:f:x>f?x:f:o>x?o>f?o:f:x>f?x: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,u,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,u||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,u,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=u;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,
|
|
|
+THREE.Matrix4=function(b,d,c,f,g,h,j,k,n,p,o,t,x,v,z,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,x||0,v||0,z||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,x,v,z,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=x;this.n42=v;this.n43=z;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,u=b.n32,y=b.n33,v=b.n34,B=b.n41,C=b.n42,F=b.n43,H=b.n44,U=d.n11,z=d.n12,J=d.n13,L=d.n14,M=d.n21,Fa=d.n22,
|
|
|
-oa=d.n23,xa=d.n24,Z=d.n31,e=d.n32,da=d.n33,Ca=d.n34;this.n11=c*U+f*M+g*Z;this.n12=c*z+f*Fa+g*e;this.n13=c*J+f*oa+g*da;this.n14=c*L+f*xa+g*Ca+h;this.n21=j*U+k*M+n*Z;this.n22=j*z+k*Fa+n*e;this.n23=j*J+k*oa+n*da;this.n24=j*L+k*xa+n*Ca+p;this.n31=o*U+u*M+y*Z;this.n32=o*z+u*Fa+y*e;this.n33=o*J+u*oa+y*da;this.n34=o*L+u*xa+y*Ca+v;this.n41=B*U+C*M+F*Z;this.n42=B*z+C*Fa+F*e;this.n43=B*J+C*oa+F*da;this.n44=B*L+C*xa+F*Ca+H;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,u=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*u*y-d*j*u*y-f*j*n*v+c*k*n*v+f*g*o*v-b*k*o*v-c*g*u*v+b*j*u*v+f*h*n*B-d*k*n*B-f*g*p*B+b*k*p*B+d*g*u*B-b*h*u*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,0,1);return this},
|
|
|
-setScale:function(b,d,c){this.set(b,0,0,0,0,d,0,0,0,0,c,0,0,0,0,1);return this},setRotationX:function(b){var d=Math.cos(b);b=Math.sin(b);this.set(1,0,0,0,0,d,-b,0,0,b,d,0,0,0,0,1);return this},setRotationY:function(b){var d=Math.cos(b);b=Math.sin(b);this.set(d,0,b,0,0,1,0,0,-b,0,d,0,0,0,0,1);return this},setRotationZ:function(b){var d=Math.cos(b);b=Math.sin(b);this.set(d,-b,0,0,b,d,0,0,0,0,1,0,0,0,0,1);return this},setRotationAxis:function(b,d){var c=Math.cos(d),f=Math.sin(d),g=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=
|
|
|
+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,x=b.n33,v=b.n34,z=b.n41,C=b.n42,E=b.n43,J=b.n44,U=d.n11,y=d.n12,L=d.n13,N=d.n14,P=d.n21,za=d.n22,
|
|
|
+va=d.n23,ta=d.n24,e=d.n31,fa=d.n32,ea=d.n33,Aa=d.n34;this.n11=c*U+f*P+g*e;this.n12=c*y+f*za+g*fa;this.n13=c*L+f*va+g*ea;this.n14=c*N+f*ta+g*Aa+h;this.n21=j*U+k*P+n*e;this.n22=j*y+k*za+n*fa;this.n23=j*L+k*va+n*ea;this.n24=j*N+k*ta+n*Aa+p;this.n31=o*U+t*P+x*e;this.n32=o*y+t*za+x*fa;this.n33=o*L+t*va+x*ea;this.n34=o*N+t*ta+x*Aa+v;this.n41=z*U+C*P+E*e;this.n42=z*y+C*za+E*fa;this.n43=z*L+C*va+E*ea;this.n44=z*N+C*ta+E*Aa+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,t=this.n34,x=this.n41,v=this.n42,z=this.n43,C=this.n44;return f*j*p*x-c*k*p*x-f*h*o*x+d*k*o*x+c*h*t*x-d*j*t*x-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*z-d*k*n*z-f*g*p*z+b*k*p*z+d*g*t*z-b*h*t*z-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,
|
|
|
+0,1);return this},setScale:function(b,d,c){this.set(b,0,0,0,0,d,0,0,0,0,c,0,0,0,0,1);return this},setRotationX:function(b){var d=Math.cos(b);b=Math.sin(b);this.set(1,0,0,0,0,d,-b,0,0,b,d,0,0,0,0,1);return this},setRotationY:function(b){var d=Math.cos(b);b=Math.sin(b);this.set(d,0,b,0,0,1,0,0,-b,0,d,0,0,0,0,1);return this},setRotationZ:function(b){var d=Math.cos(b);b=Math.sin(b);this.set(d,-b,0,0,b,d,0,0,0,0,1,0,0,0,0,1);return this},setRotationAxis:function(b,d){var c=Math.cos(d),f=Math.sin(d),g=
|
|
|
+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,u=b.n32,y=b.n33,v=b.n34,B=b.n41,C=b.n42,F=b.n43,H=b.n44;d===undefined&&(d=new THREE.Matrix4);d.n11=n*v*C-p*y*C+p*u*F-k*v*F-n*u*H+k*y*H;d.n12=h*y*C-g*v*C-h*u*F+f*v*F+g*u*H-f*y*H;d.n13=g*p*C-h*n*C+h*k*F-f*p*F-g*k*H+f*n*H;d.n14=h*n*u-g*p*u-h*k*y+f*p*y+g*k*v-f*n*v;d.n21=p*y*B-n*v*B-p*o*F+j*v*F+n*o*H-j*y*H;d.n22=g*v*B-h*y*B+h*o*F-c*v*F-g*o*H+c*y*H;d.n23=h*n*B-g*p*B-h*j*F+c*p*F+g*j*H-c*n*H;
|
|
|
-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*u*B+p*o*C-j*v*C-k*o*H+j*u*H;d.n32=h*u*B-f*v*B-h*o*C+c*v*C+f*o*H-c*u*H;d.n33=g*p*B-h*k*B+h*j*C-c*p*C-f*j*H+c*k*H;d.n34=h*k*o-f*p*o-h*j*u+c*p*u+f*j*v-c*k*v;d.n41=n*u*B-k*y*B-n*o*C+j*y*C+k*o*F-j*u*F;d.n42=f*y*B-g*u*B+g*o*C-c*y*C-f*o*F+c*u*F;d.n43=g*k*B-f*n*B-g*j*C+c*n*C+f*j*F-c*k*F;d.n44=f*n*o-g*k*o+g*j*u-c*n*u-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,u=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*u;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,x=b.n33,v=b.n34,z=b.n41,C=b.n42,E=b.n43,J=b.n44;d===undefined&&(d=new THREE.Matrix4);d.n11=n*v*C-p*x*C+p*t*E-k*v*E-n*t*J+k*x*J;d.n12=h*x*C-g*v*C-h*t*E+f*v*E+g*t*J-f*x*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*x+f*p*x+g*k*v-f*n*v;d.n21=p*x*z-n*v*z-p*o*E+j*v*E+n*o*J-j*x*J;d.n22=g*v*z-h*x*z+h*o*E-c*v*E-g*o*J+c*x*J;d.n23=h*n*z-g*p*z-h*j*E+c*p*E+g*j*J-c*n*J;
|
|
|
+d.n24=g*p*o-h*n*o+h*j*x-c*p*x-g*j*v+c*n*v;d.n31=k*v*z-p*t*z+p*o*C-j*v*C-k*o*J+j*t*J;d.n32=h*t*z-f*v*z-h*o*C+c*v*C+f*o*J-c*t*J;d.n33=g*p*z-h*k*z+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*z-k*x*z-n*o*C+j*x*C+k*o*E-j*t*E;d.n42=f*x*z-g*t*z+g*o*C-c*x*C-f*o*E+c*t*E;d.n43=g*k*z-f*n*z-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*x+c*k*x;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,u=n*g+h*f-j*c;c=-h*c-j*f-k*g;d.x=p*n+c*-h+o*-k-u*-j;d.y=o*n+c*-j+u*-h-p*-k;d.z=u*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($,pa,Da,ga,Y,la,Ga){k=$.vertices[pa].position;n=$.vertices[Da].position;p=$.vertices[ga].position;o=j[Y];u=j[la];y=j[Ga];v=n.x-k.x;B=p.x-k.x;C=n.y-k.y;F=p.y-k.y;H=n.z-k.z;U=p.z-k.z;z=u.u-o.u;J=y.u-o.u;L=u.v-o.v;M=y.v-o.v;Fa=1/(z*M-J*L);
|
|
|
-e.set((M*v-L*B)*Fa,(M*C-L*F)*Fa,(M*H-L*U)*Fa);da.set((z*B-J*v)*Fa,(z*F-J*C)*Fa,(z*U-J*H)*Fa);xa[pa].addSelf(e);xa[Da].addSelf(e);xa[ga].addSelf(e);Z[pa].addSelf(da);Z[Da].addSelf(da);Z[ga].addSelf(da)}var d,c,f,g,h,j,k,n,p,o,u,y,v,B,C,F,H,U,z,J,L,M,Fa,oa,xa=[],Z=[],e=new THREE.Vector3,da=new THREE.Vector3,Ca=new THREE.Vector3,Aa=new THREE.Vector3,Ha=new THREE.Vector3;d=0;for(c=this.vertices.length;d<c;d++){xa[d]=new THREE.Vector3;Z[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 qa=["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++){Ha.copy(h.vertexNormals[f]);g=h[qa[f]];oa=xa[g];Ca.copy(oa);Ca.subSelf(Ha.multiplyScalar(Ha.dot(oa))).normalize();Aa.cross(h.vertexNormals[f],oa);g=Aa.dot(Z[g]);g=g<0?-1:1;h.vertexTangents[f]=new THREE.Vector4(Ca.x,Ca.y,
|
|
|
-Ca.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,sa,Ba,ja,$,pa,Fa){k=ca.vertices[sa].position;n=ca.vertices[Ba].position;p=ca.vertices[ja].position;o=j[$];t=j[pa];x=j[Fa];v=n.x-k.x;z=p.x-k.x;C=n.y-k.y;E=p.y-k.y;J=n.z-k.z;U=p.z-k.z;y=t.u-o.u;L=x.u-o.u;N=t.v-o.v;P=x.v-o.v;za=1/(y*P-
|
|
|
+L*N);fa.set((P*v-N*z)*za,(P*C-N*E)*za,(P*J-N*U)*za);ea.set((y*z-L*v)*za,(y*E-L*C)*za,(y*U-L*J)*za);ta[sa].addSelf(fa);ta[Ba].addSelf(fa);ta[ja].addSelf(fa);e[sa].addSelf(ea);e[Ba].addSelf(ea);e[ja].addSelf(ea)}var d,c,f,g,h,j,k,n,p,o,t,x,v,z,C,E,J,U,y,L,N,P,za,va,ta=[],e=[],fa=new THREE.Vector3,ea=new THREE.Vector3,Aa=new THREE.Vector3,Ha=new THREE.Vector3,Ia=new THREE.Vector3;d=0;for(c=this.vertices.length;d<c;d++){ta[d]=new THREE.Vector3;e[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]];va=ta[g];Aa.copy(va);Aa.subSelf(Ia.multiplyScalar(Ia.dot(va))).normalize();Ha.cross(h.vertexNormals[f],va);g=Ha.dot(e[g]);g=g<0?-1:1;h.vertexTangents[f]=new THREE.Vector4(Aa.x,
|
|
|
+Aa.y,Aa.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(v,B,C,F,H,U,z){v=(C-v)*0.5;F=(F-B)*0.5;return(2*(B-C)+v+F)*z+(-3*(B-C)-2*v-F)*U+v*H+B}this.points=b;var c=[],f={x:0,y:0,z:0},g,h,j,k,n,p,o,u,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]];
|
|
|
-u=this.points[c[2]];y=this.points[c[3]];k=j*j;n=j*k;f.x=d(p.x,o.x,u.x,y.x,j,k,n);f.y=d(p.y,o.y,u.y,y.y,j,k,n);f.z=d(p.z,o.z,u.z,y.z,j,k,n);return f};this.getControlPointsArray=function(){var v,B,C=this.points.length,F=[];for(v=0;v<C;v++){B=this.points[v];F[v]=[B.x,B.y,B.z]}return F};this.getLength=function(v){var B,C,F=B=B=0,H=new THREE.Vector3,U=new THREE.Vector3,z=[],J=0;z[0]=0;v||(v=100);C=this.points.length*v;H.copy(this.points[0]);for(v=1;v<C;v++){B=v/C;position=this.getPoint(B);U.copy(position);
|
|
|
-J+=U.distanceTo(H);H.copy(position);B*=this.points.length-1;B=Math.floor(B);if(B!=F){z[B]=J;F=B}}z[z.length]=J;return{chunks:z,total:J}};this.reparametrizeByArcLength=function(v){var B,C,F,H,U,z,J=[],L=new THREE.Vector3,M=this.getLength();J.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);H=(B-1)/(this.points.length-1);U=B/(this.points.length-1);for(C=1;C<z-1;C++){F=H+C*(1/z)*(U-H);position=this.getPoint(F);J.push(L.copy(position).clone())}J.push(L.copy(this.points[B]).clone())}this.points=
|
|
|
-J}};
|
|
|
+THREE.Spline=function(b){function d(v,z,C,E,J,U,y){v=(C-v)*0.5;E=(E-z)*0.5;return(2*(z-C)+v+E)*y+(-3*(z-C)-2*v-E)*U+v*J+z}this.points=b;var c=[],f={x:0,y:0,z:0},g,h,j,k,n,p,o,t,x;this.initFromArray=function(v){this.points=[];for(var z=0;z<v.length;z++)this.points[z]={x:v[z][0],y:v[z][1],z:v[z][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]];x=this.points[c[3]];k=j*j;n=j*k;f.x=d(p.x,o.x,t.x,x.x,j,k,n);f.y=d(p.y,o.y,t.y,x.y,j,k,n);f.z=d(p.z,o.z,t.z,x.z,j,k,n);return f};this.getControlPointsArray=function(){var v,z,C=this.points.length,E=[];for(v=0;v<C;v++){z=this.points[v];E[v]=[z.x,z.y,z.z]}return E};this.getLength=function(v){var z,C,E=z=z=0,J=new THREE.Vector3,U=new THREE.Vector3,y=[],L=0;y[0]=0;v||(v=100);C=this.points.length*v;J.copy(this.points[0]);for(v=1;v<C;v++){z=v/C;position=this.getPoint(z);U.copy(position);
|
|
|
+L+=U.distanceTo(J);J.copy(position);z*=this.points.length-1;z=Math.floor(z);if(z!=E){y[z]=L;E=z}}y[y.length]=L;return{chunks:y,total:L}};this.reparametrizeByArcLength=function(v){var z,C,E,J,U,y,L=[],N=new THREE.Vector3,P=this.getLength();L.push(N.copy(this.points[0]).clone());for(z=1;z<this.points.length;z++){C=P.chunks[z]-P.chunks[z-1];y=Math.ceil(v*C/P.total);J=(z-1)/(this.points.length-1);U=z/(this.points.length-1);for(C=1;C<y-1;C++){E=J+C*(1/y)*(U-J);position=this.getPoint(E);L.push(N.copy(position).clone())}L.push(N.copy(this.points[z]).clone())}this.points=
|
|
|
+L}};
|
|
|
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,9 +75,9 @@ 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,u,y;this.currentTime+=b*this.timeScale;y=this.currentTime;u=this.currentTime%=this.data.length;p=parseInt(Math.min(u*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(u<y)if(this.loop){j=this.data.hierarchy[v].keys[0];for(k=this.getNextKeyWith(c,v,1);k.time<u;){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<
|
|
|
-u)}n.prevKey[c]=j;n.nextKey[c]=k}b.matrixAutoUpdate=!0;b.matrixWorldNeedsUpdate=!0;f=(u-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]=
|
|
|
+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,x;this.currentTime+=b*this.timeScale;x=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,z=this.hierarchy.length;v<z;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<=x){if(t<x)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};
|
|
@@ -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,u=["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[u[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,u,y,v,B,C,F=0,H=["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[H[B]];k=b[h];for(C=0;C<g;C++){j=c[H[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){F++;if(F===1){p=k;o=n;u=h;y=j;v=H[B]}if(F===2){v+=H[B];return v==="ad"||v==="ac"?{faces:[d,c],vertices:[p,o,n,k],indices:[u,
|
|
|
-y,j,h],vertexTypes:[1,2,2,1],extrudable:!0}:{faces:[d,c],vertices:[p,k,n,o],indices:[u,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.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,x,v,z,C,E=0,J=["a","b","c","d"];f=d instanceof THREE.Face4?4:3;g=c instanceof THREE.Face4?4:3;for(z=0;z<f;z++){h=d[J[z]];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;x=j;v=J[z]}if(E===2){v+=J[z];return v==="ad"||v==="ac"?{faces:[d,c],vertices:[p,o,n,k],indices:[t,
|
|
|
+x,j,h],vertexTypes:[1,2,2,1],extrudable:!0}:{faces:[d,c],vertices:[p,k,n,o],indices:[t,h,j,x],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,da){return da.z-e.z}function c(e,da){var Ca=0,Aa=1,Ha=e.z+e.w,qa=da.z+da.w,$=-e.z+e.w,pa=-da.z+da.w;if(Ha>=0&&qa>=0&&$>=0&&pa>=0)return!0;else if(Ha<0&&qa<0||$<0&&pa<0)return!1;else{if(Ha<0)Ca=Math.max(Ca,Ha/(Ha-qa));else qa<0&&(Aa=Math.min(Aa,Ha/(Ha-qa)));if($<0)Ca=Math.max(Ca,$/($-pa));else pa<0&&(Aa=Math.min(Aa,$/($-pa)));if(Aa<Ca)return!1;else{e.lerpSelf(da,Ca);da.lerpSelf(e,1-Aa);return!0}}}
|
|
|
-var f,g,h=[],j,k,n=[],p,o,u=[],y,v=[],B,C,F=[],H,U,z=[],J=new THREE.Vector4,L=new THREE.Vector4,M=new THREE.Matrix4,Fa=new THREE.Matrix4,oa=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],xa=new THREE.Vector4,Z=new THREE.Vector4;this.projectVector=function(e,da){M.multiply(da.projectionMatrix,da.matrixWorldInverse);M.multiplyVector3(e);return e};this.unprojectVector=function(e,da){M.multiply(da.matrixWorld,THREE.Matrix4.makeInvert(da.projectionMatrix));
|
|
|
-M.multiplyVector3(e);return e};this.projectObjects=function(e,da,Ca){da=[];var Aa,Ha,qa;g=0;Ha=e.objects;e=0;for(Aa=Ha.length;e<Aa;e++){qa=Ha[e];var $;if(!($=!qa.visible))if($=qa instanceof THREE.Mesh){a:{$=void 0;for(var pa=qa.matrixWorld,Da=-qa.geometry.boundingSphere.radius*Math.max(qa.scale.x,Math.max(qa.scale.y,qa.scale.z)),ga=0;ga<6;ga++){$=oa[ga].x*pa.n14+oa[ga].y*pa.n24+oa[ga].z*pa.n34+oa[ga].w;if($<=Da){$=!1;break a}}$=!0}$=!$}if(!$){$=h[g]=h[g]||new THREE.RenderableObject;g++;f=$;J.copy(qa.position);
|
|
|
-M.multiplyVector3(J);f.object=qa;f.z=J.z;da.push(f)}}Ca&&da.sort(d);return da};this.projectScene=function(e,da,Ca){var Aa=[],Ha=da.near,qa=da.far,$,pa,Da,ga,Y,la,Ga,ka,na,wa,Ua,cb,ab,Pa,N,X,ma;U=C=y=o=0;da.matrixAutoUpdate&&da.updateMatrix();e.update(undefined,!1,da);M.multiply(da.projectionMatrix,da.matrixWorldInverse);oa[0].set(M.n41-M.n11,M.n42-M.n12,M.n43-M.n13,M.n44-M.n14);oa[1].set(M.n41+M.n11,M.n42+M.n12,M.n43+M.n13,M.n44+M.n14);oa[2].set(M.n41+M.n21,M.n42+M.n22,M.n43+M.n23,M.n44+M.n24);oa[3].set(M.n41-
|
|
|
-M.n21,M.n42-M.n22,M.n43-M.n23,M.n44-M.n24);oa[4].set(M.n41-M.n31,M.n42-M.n32,M.n43-M.n33,M.n44-M.n34);oa[5].set(M.n41+M.n31,M.n42+M.n32,M.n43+M.n33,M.n44+M.n34);for($=0;$<6;$++){na=oa[$];na.divideScalar(Math.sqrt(na.x*na.x+na.y*na.y+na.z*na.z))}na=this.projectObjects(e,da,!0);e=0;for($=na.length;e<$;e++){wa=na[e].object;if(wa.visible){Ua=wa.matrixWorld;cb=wa.matrixRotationWorld;ab=wa.materials;Pa=wa.overdraw;k=0;if(wa instanceof THREE.Mesh){N=wa.geometry;ga=N.vertices;X=N.faces;N=N.faceVertexUvs;
|
|
|
-pa=0;for(Da=ga.length;pa<Da;pa++){j=b();j.positionWorld.copy(ga[pa].position);Ua.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>Ha&&j.positionScreen.z<qa}ga=0;for(pa=X.length;ga<pa;ga++){Da=X[ga];if(Da instanceof THREE.Face3){Y=n[Da.a];la=n[Da.b];Ga=n[Da.c];if(Y.visible&&la.visible&&Ga.visible&&(wa.doubleSided||wa.flipSided!=(Ga.positionScreen.x-
|
|
|
-Y.positionScreen.x)*(la.positionScreen.y-Y.positionScreen.y)-(Ga.positionScreen.y-Y.positionScreen.y)*(la.positionScreen.x-Y.positionScreen.x)<0)){ka=u[o]=u[o]||new THREE.RenderableFace3;o++;p=ka;p.v1.copy(Y);p.v2.copy(la);p.v3.copy(Ga)}else continue}else if(Da instanceof THREE.Face4){Y=n[Da.a];la=n[Da.b];Ga=n[Da.c];ka=n[Da.d];if(Y.visible&&la.visible&&Ga.visible&&ka.visible&&(wa.doubleSided||wa.flipSided!=((ka.positionScreen.x-Y.positionScreen.x)*(la.positionScreen.y-Y.positionScreen.y)-(ka.positionScreen.y-
|
|
|
-Y.positionScreen.y)*(la.positionScreen.x-Y.positionScreen.x)<0||(la.positionScreen.x-Ga.positionScreen.x)*(ka.positionScreen.y-Ga.positionScreen.y)-(la.positionScreen.y-Ga.positionScreen.y)*(ka.positionScreen.x-Ga.positionScreen.x)<0))){ma=v[y]=v[y]||new THREE.RenderableFace4;y++;p=ma;p.v1.copy(Y);p.v2.copy(la);p.v3.copy(Ga);p.v4.copy(ka)}else continue}p.normalWorld.copy(Da.normal);cb.multiplyVector3(p.normalWorld);p.centroidWorld.copy(Da.centroid);Ua.multiplyVector3(p.centroidWorld);p.centroidScreen.copy(p.centroidWorld);
|
|
|
-M.multiplyVector3(p.centroidScreen);Ga=Da.vertexNormals;Y=0;for(la=Ga.length;Y<la;Y++){ka=p.vertexNormalsWorld[Y];ka.copy(Ga[Y]);cb.multiplyVector3(ka)}Y=0;for(la=N.length;Y<la;Y++)if(ma=N[Y][ga]){Ga=0;for(ka=ma.length;Ga<ka;Ga++)p.uvs[Y][Ga]=ma[Ga]}p.meshMaterials=ab;p.faceMaterials=Da.materials;p.overdraw=Pa;p.z=p.centroidScreen.z;Aa.push(p)}}else if(wa instanceof THREE.Line){Fa.multiply(M,Ua);ga=wa.geometry.vertices;Y=b();Y.positionScreen.copy(ga[0].position);Fa.multiplyVector4(Y.positionScreen);
|
|
|
-pa=1;for(Da=ga.length;pa<Da;pa++){Y=b();Y.positionScreen.copy(ga[pa].position);Fa.multiplyVector4(Y.positionScreen);la=n[k-2];xa.copy(Y.positionScreen);Z.copy(la.positionScreen);if(c(xa,Z)){xa.multiplyScalar(1/xa.w);Z.multiplyScalar(1/Z.w);Ua=F[C]=F[C]||new THREE.RenderableLine;C++;B=Ua;B.v1.positionScreen.copy(xa);B.v2.positionScreen.copy(Z);B.z=Math.max(xa.z,Z.z);B.materials=wa.materials;Aa.push(B)}}}else if(wa instanceof THREE.Particle){L.set(wa.position.x,wa.position.y,wa.position.z,1);M.multiplyVector4(L);
|
|
|
-L.z/=L.w;if(L.z>0&&L.z<1){Ua=z[U]=z[U]||new THREE.RenderableParticle;U++;H=Ua;H.x=L.x/L.w;H.y=L.y/L.w;H.z=L.z;H.rotation=wa.rotation.z;H.scale.x=wa.scale.x*Math.abs(H.x-(L.x+da.projectionMatrix.n11)/(L.w+da.projectionMatrix.n14));H.scale.y=wa.scale.y*Math.abs(H.y-(L.y+da.projectionMatrix.n22)/(L.w+da.projectionMatrix.n24));H.materials=wa.materials;Aa.push(H)}}}}Ca&&Aa.sort(d);return Aa}};
|
|
|
-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,u,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(u=y.material.length;o<u;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"),u=new THREE.Color(0),y=0,v=1,B=0,
|
|
|
-C=null,F=null,H=null,U=null,z=null,J,L,M,Fa,oa=new THREE.RenderableVertex,xa=new THREE.RenderableVertex,Z,e,da,Ca,Aa,Ha,qa,$,pa,Da,ga,Y,la=new THREE.Color,Ga=new THREE.Color,ka=new THREE.Color,na=new THREE.Color,wa=new THREE.Color,Ua,cb,ab,Pa,N,X,ma,Ea,Ka,ya,ia=new THREE.Rectangle,m=new THREE.Rectangle,A=new THREE.Rectangle,x=!1,t=new THREE.Color,w=new THREE.Color,S=new THREE.Color,E=new THREE.Color,G=new THREE.Vector3,O,D,I,Q,sa,W,Ba=16;O=document.createElement("canvas");O.width=O.height=2;D=O.getContext("2d");
|
|
|
-D.fillStyle="rgba(0,0,0,1)";D.fillRect(0,0,2,2);I=D.getImageData(0,0,2,2);Q=I.data;sa=document.createElement("canvas");sa.width=sa.height=Ba;W=sa.getContext("2d");W.translate(-Ba/2,-Ba/2);W.scale(Ba,Ba);Ba--;this.domElement=h;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setSize=function(ra,za){j=ra;k=za;n=j/2;p=k/2;h.width=j;h.height=k;ia.set(-n,-p,n,p);v=1;B=0;z=U=H=F=C=null};this.setClearColor=function(ra,za){u=ra;y=za};this.setClearColorHex=function(ra,za){u.setHex(ra);y=za};
|
|
|
-this.clear=function(){o.setTransform(1,0,0,-1,n,p);if(!m.isEmpty()){m.inflate(1);m.minSelf(ia);if(u.hex==0&&y==0)o.clearRect(m.getX(),m.getY(),m.getWidth(),m.getHeight());else{d(THREE.NormalBlending);b(1);o.fillStyle="rgba("+Math.floor(u.r*255)+","+Math.floor(u.g*255)+","+Math.floor(u.b*255)+","+y+")";o.fillRect(m.getX(),m.getY(),m.getWidth(),m.getHeight())}m.empty()}};this.render=function(ra,za){function Ia(T){var ta,fa,aa,va=T.lights;w.setRGB(0,0,0);S.setRGB(0,0,0);E.setRGB(0,0,0);T=0;for(ta=va.length;T<
|
|
|
-ta;T++){fa=va[T];aa=fa.color;if(fa instanceof THREE.AmbientLight){w.r+=aa.r;w.g+=aa.g;w.b+=aa.b}else if(fa instanceof THREE.DirectionalLight){S.r+=aa.r;S.g+=aa.g;S.b+=aa.b}else if(fa instanceof THREE.PointLight){E.r+=aa.r;E.g+=aa.g;E.b+=aa.b}}}function Sa(T,ta,fa,aa){var va,ua,ha,K,Qa=T.lights;T=0;for(va=Qa.length;T<va;T++){ua=Qa[T];ha=ua.color;if(ua instanceof THREE.DirectionalLight){K=fa.dot(ua.position);if(!(K<=0)){K*=ua.intensity;aa.r+=ha.r*K;aa.g+=ha.g*K;aa.b+=ha.b*K}}else if(ua instanceof THREE.PointLight){K=
|
|
|
-fa.dot(G.sub(ua.position,ta).normalize());if(!(K<=0)){K*=ua.distance==0?1:1-Math.min(ta.distanceTo(ua.position)/ua.distance,1);if(K!=0){K*=ua.intensity;aa.r+=ha.r*K;aa.g+=ha.g*K;aa.b+=ha.b*K}}}}}function ea(T,ta,fa){b(fa.opacity);d(fa.blending);var aa,va,ua,ha,K,Qa;if(fa instanceof THREE.ParticleBasicMaterial){if(fa.map){ha=fa.map.image;K=ha.width>>1;Qa=ha.height>>1;fa=ta.scale.x*n;ua=ta.scale.y*p;aa=fa*K;va=ua*Qa;A.set(T.x-aa,T.y-va,T.x+aa,T.y+va);if(ia.instersects(A)){o.save();o.translate(T.x,T.y);
|
|
|
-o.rotate(-ta.rotation);o.scale(fa,-ua);o.translate(-K,-Qa);o.drawImage(ha,0,0);o.restore()}}}else if(fa instanceof THREE.ParticleCanvasMaterial){aa=ta.scale.x*n;va=ta.scale.y*p;A.set(T.x-aa,T.y-va,T.x+aa,T.y+va);if(ia.instersects(A)){c(fa.color.__styleString);ua=fa.color.__styleString;if(F!=ua)o.fillStyle=F=ua;o.save();o.translate(T.x,T.y);o.rotate(-ta.rotation);o.scale(aa,va);fa.program(o);o.restore()}}}function ca(T,ta,fa,aa){b(aa.opacity);d(aa.blending);o.beginPath();o.moveTo(T.positionScreen.x,
|
|
|
-T.positionScreen.y);o.lineTo(ta.positionScreen.x,ta.positionScreen.y);o.closePath();if(aa instanceof THREE.LineBasicMaterial){la.__styleString=aa.color.__styleString;T=aa.linewidth;if(H!=T)o.lineWidth=H=T;T=aa.linecap;if(U!=T)o.lineCap=U=T;T=aa.linejoin;if(z!=T)o.lineJoin=z=T;c(la.__styleString);o.stroke();A.inflate(aa.linewidth*2)}}function ja(T,ta,fa,aa,va,ua,ha,K,Qa){b(K.opacity);d(K.blending);Z=T.positionScreen.x;e=T.positionScreen.y;da=ta.positionScreen.x;Ca=ta.positionScreen.y;Aa=fa.positionScreen.x;
|
|
|
-Ha=fa.positionScreen.y;V(Z,e,da,Ca,Aa,Ha);if(K instanceof THREE.MeshBasicMaterial)if(K.map){if(K.map.mapping instanceof THREE.UVMapping){Pa=ha.uvs[0];Na(Z,e,da,Ca,Aa,Ha,K.map.image,Pa[aa].u,Pa[aa].v,Pa[va].u,Pa[va].v,Pa[ua].u,Pa[ua].v)}}else if(K.envMap){if(K.envMap.mapping instanceof THREE.SphericalReflectionMapping){T=za.matrixWorldInverse;G.copy(ha.vertexNormalsWorld[0]);N=(G.x*T.n11+G.y*T.n12+G.z*T.n13)*0.5+0.5;X=-(G.x*T.n21+G.y*T.n22+G.z*T.n23)*0.5+0.5;G.copy(ha.vertexNormalsWorld[1]);ma=(G.x*
|
|
|
-T.n11+G.y*T.n12+G.z*T.n13)*0.5+0.5;Ea=-(G.x*T.n21+G.y*T.n22+G.z*T.n23)*0.5+0.5;G.copy(ha.vertexNormalsWorld[2]);Ka=(G.x*T.n11+G.y*T.n12+G.z*T.n13)*0.5+0.5;ya=-(G.x*T.n21+G.y*T.n22+G.z*T.n23)*0.5+0.5;Na(Z,e,da,Ca,Aa,Ha,K.envMap.image,N,X,ma,Ea,Ka,ya)}}else K.wireframe?Oa(K.color.__styleString,K.wireframeLinewidth,K.wireframeLinecap,K.wireframeLinejoin):fb(K.color.__styleString);else if(K instanceof THREE.MeshLambertMaterial){if(K.map&&!K.wireframe){if(K.map.mapping instanceof THREE.UVMapping){Pa=ha.uvs[0];
|
|
|
-Na(Z,e,da,Ca,Aa,Ha,K.map.image,Pa[aa].u,Pa[aa].v,Pa[va].u,Pa[va].v,Pa[ua].u,Pa[ua].v)}d(THREE.SubtractiveBlending)}if(x)if(!K.wireframe&&K.shading==THREE.SmoothShading&&ha.vertexNormalsWorld.length==3){Ga.r=ka.r=na.r=w.r;Ga.g=ka.g=na.g=w.g;Ga.b=ka.b=na.b=w.b;Sa(Qa,ha.v1.positionWorld,ha.vertexNormalsWorld[0],Ga);Sa(Qa,ha.v2.positionWorld,ha.vertexNormalsWorld[1],ka);Sa(Qa,ha.v3.positionWorld,ha.vertexNormalsWorld[2],na);wa.r=(ka.r+na.r)*0.5;wa.g=(ka.g+na.g)*0.5;wa.b=(ka.b+na.b)*0.5;ab=Xa(Ga,ka,na,
|
|
|
-wa);Na(Z,e,da,Ca,Aa,Ha,ab,0,0,1,0,0,1)}else{t.r=w.r;t.g=w.g;t.b=w.b;Sa(Qa,ha.centroidWorld,ha.normalWorld,t);la.r=K.color.r*t.r;la.g=K.color.g*t.g;la.b=K.color.b*t.b;la.updateStyleString();K.wireframe?Oa(la.__styleString,K.wireframeLinewidth,K.wireframeLinecap,K.wireframeLinejoin):fb(la.__styleString)}else K.wireframe?Oa(K.color.__styleString,K.wireframeLinewidth,K.wireframeLinecap,K.wireframeLinejoin):fb(K.color.__styleString)}else if(K instanceof THREE.MeshDepthMaterial){Ua=za.near;cb=za.far;Ga.r=
|
|
|
-Ga.g=Ga.b=1-gb(T.positionScreen.z,Ua,cb);ka.r=ka.g=ka.b=1-gb(ta.positionScreen.z,Ua,cb);na.r=na.g=na.b=1-gb(fa.positionScreen.z,Ua,cb);wa.r=(ka.r+na.r)*0.5;wa.g=(ka.g+na.g)*0.5;wa.b=(ka.b+na.b)*0.5;ab=Xa(Ga,ka,na,wa);Na(Z,e,da,Ca,Aa,Ha,ab,0,0,1,0,0,1)}else if(K instanceof THREE.MeshNormalMaterial){la.r=hb(ha.normalWorld.x);la.g=hb(ha.normalWorld.y);la.b=hb(ha.normalWorld.z);la.updateStyleString();K.wireframe?Oa(la.__styleString,K.wireframeLinewidth,K.wireframeLinecap,K.wireframeLinejoin):fb(la.__styleString)}}
|
|
|
-function La(T,ta,fa,aa,va,ua,ha,K,Qa){b(K.opacity);d(K.blending);if(K.map||K.envMap){ja(T,ta,aa,0,1,3,ha,K,Qa);ja(va,fa,ua,1,2,3,ha,K,Qa)}else{Z=T.positionScreen.x;e=T.positionScreen.y;da=ta.positionScreen.x;Ca=ta.positionScreen.y;Aa=fa.positionScreen.x;Ha=fa.positionScreen.y;qa=aa.positionScreen.x;$=aa.positionScreen.y;pa=va.positionScreen.x;Da=va.positionScreen.y;ga=ua.positionScreen.x;Y=ua.positionScreen.y;if(K instanceof THREE.MeshBasicMaterial){P(Z,e,da,Ca,Aa,Ha,qa,$);K.wireframe?Oa(K.color.__styleString,
|
|
|
-K.wireframeLinewidth,K.wireframeLinecap,K.wireframeLinejoin):fb(K.color.__styleString)}else if(K instanceof THREE.MeshLambertMaterial)if(x)if(!K.wireframe&&K.shading==THREE.SmoothShading&&ha.vertexNormalsWorld.length==4){Ga.r=ka.r=na.r=wa.r=w.r;Ga.g=ka.g=na.g=wa.g=w.g;Ga.b=ka.b=na.b=wa.b=w.b;Sa(Qa,ha.v1.positionWorld,ha.vertexNormalsWorld[0],Ga);Sa(Qa,ha.v2.positionWorld,ha.vertexNormalsWorld[1],ka);Sa(Qa,ha.v4.positionWorld,ha.vertexNormalsWorld[3],na);Sa(Qa,ha.v3.positionWorld,ha.vertexNormalsWorld[2],
|
|
|
-wa);ab=Xa(Ga,ka,na,wa);V(Z,e,da,Ca,qa,$);Na(Z,e,da,Ca,qa,$,ab,0,0,1,0,0,1);V(pa,Da,Aa,Ha,ga,Y);Na(pa,Da,Aa,Ha,ga,Y,ab,1,0,1,1,0,1)}else{t.r=w.r;t.g=w.g;t.b=w.b;Sa(Qa,ha.centroidWorld,ha.normalWorld,t);la.r=K.color.r*t.r;la.g=K.color.g*t.g;la.b=K.color.b*t.b;la.updateStyleString();P(Z,e,da,Ca,Aa,Ha,qa,$);K.wireframe?Oa(la.__styleString,K.wireframeLinewidth,K.wireframeLinecap,K.wireframeLinejoin):fb(la.__styleString)}else{P(Z,e,da,Ca,Aa,Ha,qa,$);K.wireframe?Oa(K.color.__styleString,K.wireframeLinewidth,
|
|
|
-K.wireframeLinecap,K.wireframeLinejoin):fb(K.color.__styleString)}else if(K instanceof THREE.MeshNormalMaterial){la.r=hb(ha.normalWorld.x);la.g=hb(ha.normalWorld.y);la.b=hb(ha.normalWorld.z);la.updateStyleString();P(Z,e,da,Ca,Aa,Ha,qa,$);K.wireframe?Oa(la.__styleString,K.wireframeLinewidth,K.wireframeLinecap,K.wireframeLinejoin):fb(la.__styleString)}else if(K instanceof THREE.MeshDepthMaterial){Ua=za.near;cb=za.far;Ga.r=Ga.g=Ga.b=1-gb(T.positionScreen.z,Ua,cb);ka.r=ka.g=ka.b=1-gb(ta.positionScreen.z,
|
|
|
-Ua,cb);na.r=na.g=na.b=1-gb(aa.positionScreen.z,Ua,cb);wa.r=wa.g=wa.b=1-gb(fa.positionScreen.z,Ua,cb);ab=Xa(Ga,ka,na,wa);V(Z,e,da,Ca,qa,$);Na(Z,e,da,Ca,qa,$,ab,0,0,1,0,0,1);V(pa,Da,Aa,Ha,ga,Y);Na(pa,Da,Aa,Ha,ga,Y,ab,1,0,1,1,0,1)}}}function V(T,ta,fa,aa,va,ua){o.beginPath();o.moveTo(T,ta);o.lineTo(fa,aa);o.lineTo(va,ua);o.lineTo(T,ta);o.closePath()}function P(T,ta,fa,aa,va,ua,ha,K){o.beginPath();o.moveTo(T,ta);o.lineTo(fa,aa);o.lineTo(va,ua);o.lineTo(ha,K);o.lineTo(T,ta);o.closePath()}function Oa(T,
|
|
|
-ta,fa,aa){if(H!=ta)o.lineWidth=H=ta;if(U!=fa)o.lineCap=U=fa;if(z!=aa)o.lineJoin=z=aa;c(T);o.stroke();A.inflate(ta*2)}function fb(T){if(F!=T)o.fillStyle=F=T;o.fill()}function Na(T,ta,fa,aa,va,ua,ha,K,Qa,db,Wa,bb,lb){var Ta,ib;Ta=ha.width-1;ib=ha.height-1;K*=Ta;Qa*=ib;db*=Ta;Wa*=ib;bb*=Ta;lb*=ib;fa-=T;aa-=ta;va-=T;ua-=ta;db-=K;Wa-=Qa;bb-=K;lb-=Qa;Ta=db*lb-bb*Wa;if(Ta!=0){ib=1/Ta;Ta=(lb*fa-Wa*va)*ib;Wa=(lb*aa-Wa*ua)*ib;fa=(db*va-bb*fa)*ib;aa=(db*ua-bb*aa)*ib;T=T-Ta*K-fa*Qa;ta=ta-Wa*K-aa*Qa;o.save();
|
|
|
-o.transform(Ta,Wa,fa,aa,T,ta);o.clip();o.drawImage(ha,0,0);o.restore()}}function Xa(T,ta,fa,aa){var va=~~(T.r*255),ua=~~(T.g*255);T=~~(T.b*255);var ha=~~(ta.r*255),K=~~(ta.g*255);ta=~~(ta.b*255);var Qa=~~(fa.r*255),db=~~(fa.g*255);fa=~~(fa.b*255);var Wa=~~(aa.r*255),bb=~~(aa.g*255);aa=~~(aa.b*255);Q[0]=va<0?0:va>255?255:va;Q[1]=ua<0?0:ua>255?255:ua;Q[2]=T<0?0:T>255?255:T;Q[4]=ha<0?0:ha>255?255:ha;Q[5]=K<0?0:K>255?255:K;Q[6]=ta<0?0:ta>255?255:ta;Q[8]=Qa<0?0:Qa>255?255:Qa;Q[9]=db<0?0:db>255?255:db;
|
|
|
-Q[10]=fa<0?0:fa>255?255:fa;Q[12]=Wa<0?0:Wa>255?255:Wa;Q[13]=bb<0?0:bb>255?255:bb;Q[14]=aa<0?0:aa>255?255:aa;D.putImageData(I,0,0);W.drawImage(O,0,0);return sa}function gb(T,ta,fa){T=(T-ta)/(fa-ta);return T*T*(3-2*T)}function hb(T){T=(T+1)*0.5;return T<0?0:T>1?1:T}function Ya(T,ta){var fa=ta.x-T.x,aa=ta.y-T.y,va=1/Math.sqrt(fa*fa+aa*aa);fa*=va;aa*=va;ta.x+=fa;ta.y+=aa;T.x-=fa;T.y-=aa}var eb,Ra,Ja,Ma,R,Va,Za,$a;this.autoClear?this.clear():o.setTransform(1,0,0,-1,n,p);f=g.projectScene(ra,za,this.sortElements);
|
|
|
-(x=ra.lights.length>0)&&Ia(ra);eb=0;for(Ra=f.length;eb<Ra;eb++){Ja=f[eb];A.empty();if(Ja instanceof THREE.RenderableParticle){J=Ja;J.x*=n;J.y*=p;Ma=0;for(R=Ja.materials.length;Ma<R;){$a=Ja.materials[Ma++];$a.opacity!=0&&ea(J,Ja,$a,ra)}}else if(Ja instanceof THREE.RenderableLine){J=Ja.v1;L=Ja.v2;J.positionScreen.x*=n;J.positionScreen.y*=p;L.positionScreen.x*=n;L.positionScreen.y*=p;A.addPoint(J.positionScreen.x,J.positionScreen.y);A.addPoint(L.positionScreen.x,L.positionScreen.y);if(ia.instersects(A)){Ma=
|
|
|
-0;for(R=Ja.materials.length;Ma<R;){$a=Ja.materials[Ma++];$a.opacity!=0&&ca(J,L,Ja,$a,ra)}}}else if(Ja instanceof THREE.RenderableFace3){J=Ja.v1;L=Ja.v2;M=Ja.v3;J.positionScreen.x*=n;J.positionScreen.y*=p;L.positionScreen.x*=n;L.positionScreen.y*=p;M.positionScreen.x*=n;M.positionScreen.y*=p;if(Ja.overdraw){Ya(J.positionScreen,L.positionScreen);Ya(L.positionScreen,M.positionScreen);Ya(M.positionScreen,J.positionScreen)}A.add3Points(J.positionScreen.x,J.positionScreen.y,L.positionScreen.x,L.positionScreen.y,
|
|
|
-M.positionScreen.x,M.positionScreen.y);if(ia.instersects(A)){Ma=0;for(R=Ja.meshMaterials.length;Ma<R;){$a=Ja.meshMaterials[Ma++];if($a instanceof THREE.MeshFaceMaterial){Va=0;for(Za=Ja.faceMaterials.length;Va<Za;)($a=Ja.faceMaterials[Va++])&&$a.opacity!=0&&ja(J,L,M,0,1,2,Ja,$a,ra)}else $a.opacity!=0&&ja(J,L,M,0,1,2,Ja,$a,ra)}}}else if(Ja instanceof THREE.RenderableFace4){J=Ja.v1;L=Ja.v2;M=Ja.v3;Fa=Ja.v4;J.positionScreen.x*=n;J.positionScreen.y*=p;L.positionScreen.x*=n;L.positionScreen.y*=p;M.positionScreen.x*=
|
|
|
-n;M.positionScreen.y*=p;Fa.positionScreen.x*=n;Fa.positionScreen.y*=p;oa.positionScreen.copy(L.positionScreen);xa.positionScreen.copy(Fa.positionScreen);if(Ja.overdraw){Ya(J.positionScreen,L.positionScreen);Ya(L.positionScreen,Fa.positionScreen);Ya(Fa.positionScreen,J.positionScreen);Ya(M.positionScreen,oa.positionScreen);Ya(M.positionScreen,xa.positionScreen)}A.addPoint(J.positionScreen.x,J.positionScreen.y);A.addPoint(L.positionScreen.x,L.positionScreen.y);A.addPoint(M.positionScreen.x,M.positionScreen.y);
|
|
|
-A.addPoint(Fa.positionScreen.x,Fa.positionScreen.y);if(ia.instersects(A)){Ma=0;for(R=Ja.meshMaterials.length;Ma<R;){$a=Ja.meshMaterials[Ma++];if($a instanceof THREE.MeshFaceMaterial){Va=0;for(Za=Ja.faceMaterials.length;Va<Za;)($a=Ja.faceMaterials[Va++])&&$a.opacity!=0&&La(J,L,M,Fa,oa,xa,Ja,$a,ra)}else $a.opacity!=0&&La(J,L,M,Fa,oa,xa,Ja,$a,ra)}}}m.addRectangle(A)}o.setTransform(1,0,0,1,0,0)}};
|
|
|
-THREE.SVGRenderer=function(){function b(qa,$,pa){var Da,ga,Y,la;Da=0;for(ga=qa.lights.length;Da<ga;Da++){Y=qa.lights[Da];if(Y instanceof THREE.DirectionalLight){la=$.normalWorld.dot(Y.position)*Y.intensity;if(la>0){pa.r+=Y.color.r*la;pa.g+=Y.color.g*la;pa.b+=Y.color.b*la}}else if(Y instanceof THREE.PointLight){xa.sub(Y.position,$.centroidWorld);xa.normalize();la=$.normalWorld.dot(xa)*Y.intensity;if(la>0){pa.r+=Y.color.r*la;pa.g+=Y.color.g*la;pa.b+=Y.color.b*la}}}}function d(qa,$,pa,Da,ga,Y){da=f(Ca++);
|
|
|
-da.setAttribute("d","M "+qa.positionScreen.x+" "+qa.positionScreen.y+" L "+$.positionScreen.x+" "+$.positionScreen.y+" L "+pa.positionScreen.x+","+pa.positionScreen.y+"z");if(ga instanceof THREE.MeshBasicMaterial)z.__styleString=ga.color.__styleString;else if(ga instanceof THREE.MeshLambertMaterial)if(U){J.r=L.r;J.g=L.g;J.b=L.b;b(Y,Da,J);z.r=ga.color.r*J.r;z.g=ga.color.g*J.g;z.b=ga.color.b*J.b;z.updateStyleString()}else z.__styleString=ga.color.__styleString;else if(ga instanceof THREE.MeshDepthMaterial){oa=
|
|
|
-1-ga.__2near/(ga.__farPlusNear-Da.z*ga.__farMinusNear);z.setRGB(oa,oa,oa)}else ga instanceof THREE.MeshNormalMaterial&&z.setRGB(g(Da.normalWorld.x),g(Da.normalWorld.y),g(Da.normalWorld.z));ga.wireframe?da.setAttribute("style","fill: none; stroke: "+z.__styleString+"; stroke-width: "+ga.wireframeLinewidth+"; stroke-opacity: "+ga.opacity+"; stroke-linecap: "+ga.wireframeLinecap+"; stroke-linejoin: "+ga.wireframeLinejoin):da.setAttribute("style","fill: "+z.__styleString+"; fill-opacity: "+ga.opacity);
|
|
|
-k.appendChild(da)}function c(qa,$,pa,Da,ga,Y,la){da=f(Ca++);da.setAttribute("d","M "+qa.positionScreen.x+" "+qa.positionScreen.y+" L "+$.positionScreen.x+" "+$.positionScreen.y+" L "+pa.positionScreen.x+","+pa.positionScreen.y+" L "+Da.positionScreen.x+","+Da.positionScreen.y+"z");if(Y instanceof THREE.MeshBasicMaterial)z.__styleString=Y.color.__styleString;else if(Y instanceof THREE.MeshLambertMaterial)if(U){J.r=L.r;J.g=L.g;J.b=L.b;b(la,ga,J);z.r=Y.color.r*J.r;z.g=Y.color.g*J.g;z.b=Y.color.b*J.b;
|
|
|
-z.updateStyleString()}else z.__styleString=Y.color.__styleString;else if(Y instanceof THREE.MeshDepthMaterial){oa=1-Y.__2near/(Y.__farPlusNear-ga.z*Y.__farMinusNear);z.setRGB(oa,oa,oa)}else Y instanceof THREE.MeshNormalMaterial&&z.setRGB(g(ga.normalWorld.x),g(ga.normalWorld.y),g(ga.normalWorld.z));Y.wireframe?da.setAttribute("style","fill: none; stroke: "+z.__styleString+"; stroke-width: "+Y.wireframeLinewidth+"; stroke-opacity: "+Y.opacity+"; stroke-linecap: "+Y.wireframeLinecap+"; stroke-linejoin: "+
|
|
|
-Y.wireframeLinejoin):da.setAttribute("style","fill: "+z.__styleString+"; fill-opacity: "+Y.opacity);k.appendChild(da)}function f(qa){if(Z[qa]==null){Z[qa]=document.createElementNS("http://www.w3.org/2000/svg","path");Ha==0&&Z[qa].setAttribute("shape-rendering","crispEdges")}return Z[qa]}function g(qa){return qa<0?Math.min((1+qa)*0.5,0.5):0.5+Math.min(qa*0.5,0.5)}var h=null,j=new THREE.Projector,k=document.createElementNS("http://www.w3.org/2000/svg","svg"),n,p,o,u,y,v,B,C,F=new THREE.Rectangle,H=
|
|
|
-new THREE.Rectangle,U=!1,z=new THREE.Color(16777215),J=new THREE.Color(16777215),L=new THREE.Color(0),M=new THREE.Color(0),Fa=new THREE.Color(0),oa,xa=new THREE.Vector3,Z=[],e=[],da,Ca,Aa,Ha=1;this.domElement=k;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setQuality=function(qa){switch(qa){case "high":Ha=1;break;case "low":Ha=0}};this.setSize=function(qa,$){n=qa;p=$;o=n/2;u=p/2;k.setAttribute("viewBox",-o+" "+-u+" "+n+" "+p);k.setAttribute("width",n);k.setAttribute("height",p);
|
|
|
-F.set(-o,-u,o,u)};this.clear=function(){for(;k.childNodes.length>0;)k.removeChild(k.childNodes[0])};this.render=function(qa,$){var pa,Da,ga,Y,la,Ga,ka,na;this.autoClear&&this.clear();h=j.projectScene(qa,$,this.sortElements);Aa=Ca=0;if(U=qa.lights.length>0){ka=qa.lights;L.setRGB(0,0,0);M.setRGB(0,0,0);Fa.setRGB(0,0,0);pa=0;for(Da=ka.length;pa<Da;pa++){ga=ka[pa];Y=ga.color;if(ga instanceof THREE.AmbientLight){L.r+=Y.r;L.g+=Y.g;L.b+=Y.b}else if(ga instanceof THREE.DirectionalLight){M.r+=Y.r;M.g+=Y.g;
|
|
|
-M.b+=Y.b}else if(ga instanceof THREE.PointLight){Fa.r+=Y.r;Fa.g+=Y.g;Fa.b+=Y.b}}}pa=0;for(Da=h.length;pa<Da;pa++){ka=h[pa];H.empty();if(ka instanceof THREE.RenderableParticle){y=ka;y.x*=o;y.y*=-u;ga=0;for(Y=ka.materials.length;ga<Y;)ga++}else if(ka instanceof THREE.RenderableLine){y=ka.v1;v=ka.v2;y.positionScreen.x*=o;y.positionScreen.y*=-u;v.positionScreen.x*=o;v.positionScreen.y*=-u;H.addPoint(y.positionScreen.x,y.positionScreen.y);H.addPoint(v.positionScreen.x,v.positionScreen.y);if(F.instersects(H)){ga=
|
|
|
-0;for(Y=ka.materials.length;ga<Y;)if((na=ka.materials[ga++])&&na.opacity!=0){la=y;Ga=v;var wa=Aa++;if(e[wa]==null){e[wa]=document.createElementNS("http://www.w3.org/2000/svg","line");Ha==0&&e[wa].setAttribute("shape-rendering","crispEdges")}da=e[wa];da.setAttribute("x1",la.positionScreen.x);da.setAttribute("y1",la.positionScreen.y);da.setAttribute("x2",Ga.positionScreen.x);da.setAttribute("y2",Ga.positionScreen.y);if(na instanceof THREE.LineBasicMaterial){z.__styleString=na.color.__styleString;da.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(da)}}}}else if(ka instanceof THREE.RenderableFace3){y=ka.v1;v=ka.v2;B=ka.v3;y.positionScreen.x*=o;y.positionScreen.y*=-u;v.positionScreen.x*=o;v.positionScreen.y*=-u;B.positionScreen.x*=o;B.positionScreen.y*=-u;H.addPoint(y.positionScreen.x,y.positionScreen.y);H.addPoint(v.positionScreen.x,v.positionScreen.y);H.addPoint(B.positionScreen.x,
|
|
|
-B.positionScreen.y);if(F.instersects(H)){ga=0;for(Y=ka.meshMaterials.length;ga<Y;){na=ka.meshMaterials[ga++];if(na instanceof THREE.MeshFaceMaterial){la=0;for(Ga=ka.faceMaterials.length;la<Ga;)(na=ka.faceMaterials[la++])&&na.opacity!=0&&d(y,v,B,ka,na,qa)}else na&&na.opacity!=0&&d(y,v,B,ka,na,qa)}}}else if(ka instanceof THREE.RenderableFace4){y=ka.v1;v=ka.v2;B=ka.v3;C=ka.v4;y.positionScreen.x*=o;y.positionScreen.y*=-u;v.positionScreen.x*=o;v.positionScreen.y*=-u;B.positionScreen.x*=o;B.positionScreen.y*=
|
|
|
--u;C.positionScreen.x*=o;C.positionScreen.y*=-u;H.addPoint(y.positionScreen.x,y.positionScreen.y);H.addPoint(v.positionScreen.x,v.positionScreen.y);H.addPoint(B.positionScreen.x,B.positionScreen.y);H.addPoint(C.positionScreen.x,C.positionScreen.y);if(F.instersects(H)){ga=0;for(Y=ka.meshMaterials.length;ga<Y;){na=ka.meshMaterials[ga++];if(na instanceof THREE.MeshFaceMaterial){la=0;for(Ga=ka.faceMaterials.length;la<Ga;)(na=ka.faceMaterials[la++])&&na.opacity!=0&&c(y,v,B,C,ka,na,qa)}else na&&na.opacity!=
|
|
|
-0&&c(y,v,B,C,ka,na,qa)}}}}}};
|
|
|
+THREE.Projector=function(){function b(){var fa=n[k]=n[k]||new THREE.RenderableVertex;k++;return fa}function d(fa,ea){return ea.z-fa.z}function c(fa,ea){var Aa=0,Ha=1,Ia=fa.z+fa.w,ua=ea.z+ea.w,ca=-fa.z+fa.w,sa=-ea.z+ea.w;if(Ia>=0&&ua>=0&&ca>=0&&sa>=0)return!0;else if(Ia<0&&ua<0||ca<0&&sa<0)return!1;else{if(Ia<0)Aa=Math.max(Aa,Ia/(Ia-ua));else ua<0&&(Ha=Math.min(Ha,Ia/(Ia-ua)));if(ca<0)Aa=Math.max(Aa,ca/(ca-sa));else sa<0&&(Ha=Math.min(Ha,ca/(ca-sa)));if(Ha<Aa)return!1;else{fa.lerpSelf(ea,Aa);ea.lerpSelf(fa,
|
|
|
+1-Ha);return!0}}}var f,g,h=[],j,k,n=[],p,o,t=[],x,v=[],z,C,E=[],J,U,y=[],L=new THREE.Vector4,N=new THREE.Vector4,P=new THREE.Matrix4,za=new THREE.Matrix4,va=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],ta=new THREE.Vector4,e=new THREE.Vector4;this.projectVector=function(fa,ea){P.multiply(ea.projectionMatrix,ea.matrixWorldInverse);P.multiplyVector3(fa);return fa};this.unprojectVector=function(fa,ea){P.multiply(ea.matrixWorld,THREE.Matrix4.makeInvert(ea.projectionMatrix));
|
|
|
+P.multiplyVector3(fa);return fa};this.projectObjects=function(fa,ea,Aa){ea=[];var Ha,Ia,ua;g=0;Ia=fa.objects;fa=0;for(Ha=Ia.length;fa<Ha;fa++){ua=Ia[fa];var ca;if(!(ca=!ua.visible))if(ca=ua instanceof THREE.Mesh){a:{ca=void 0;for(var sa=ua.matrixWorld,Ba=-ua.geometry.boundingSphere.radius*Math.max(ua.scale.x,Math.max(ua.scale.y,ua.scale.z)),ja=0;ja<6;ja++){ca=va[ja].x*sa.n14+va[ja].y*sa.n24+va[ja].z*sa.n34+va[ja].w;if(ca<=Ba){ca=!1;break a}}ca=!0}ca=!ca}if(!ca){ca=h[g]=h[g]||new THREE.RenderableObject;
|
|
|
+g++;f=ca;L.copy(ua.position);P.multiplyVector3(L);f.object=ua;f.z=L.z;ea.push(f)}}Aa&&ea.sort(d);return ea};this.projectScene=function(fa,ea,Aa){var Ha=[],Ia=ea.near,ua=ea.far,ca,sa,Ba,ja,$,pa,Fa,ka,oa,Ga,Ra,Za,Va,Sa,O,aa,qa;U=C=x=o=0;ea.matrixAutoUpdate&&ea.updateMatrix();fa.update(undefined,!1,ea);P.multiply(ea.projectionMatrix,ea.matrixWorldInverse);va[0].set(P.n41-P.n11,P.n42-P.n12,P.n43-P.n13,P.n44-P.n14);va[1].set(P.n41+P.n11,P.n42+P.n12,P.n43+P.n13,P.n44+P.n14);va[2].set(P.n41+P.n21,P.n42+
|
|
|
+P.n22,P.n43+P.n23,P.n44+P.n24);va[3].set(P.n41-P.n21,P.n42-P.n22,P.n43-P.n23,P.n44-P.n24);va[4].set(P.n41-P.n31,P.n42-P.n32,P.n43-P.n33,P.n44-P.n34);va[5].set(P.n41+P.n31,P.n42+P.n32,P.n43+P.n33,P.n44+P.n34);for(ca=0;ca<6;ca++){oa=va[ca];oa.divideScalar(Math.sqrt(oa.x*oa.x+oa.y*oa.y+oa.z*oa.z))}oa=this.projectObjects(fa,ea,!0);fa=0;for(ca=oa.length;fa<ca;fa++){Ga=oa[fa].object;if(Ga.visible){Ra=Ga.matrixWorld;Za=Ga.matrixRotationWorld;Va=Ga.materials;Sa=Ga.overdraw;k=0;if(Ga instanceof THREE.Mesh){O=
|
|
|
+Ga.geometry;ja=O.vertices;aa=O.faces;O=O.faceVertexUvs;sa=0;for(Ba=ja.length;sa<Ba;sa++){j=b();j.positionWorld.copy(ja[sa].position);Ra.multiplyVector3(j.positionWorld);j.positionScreen.copy(j.positionWorld);P.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}ja=0;for(sa=aa.length;ja<sa;ja++){Ba=aa[ja];if(Ba instanceof THREE.Face3){$=n[Ba.a];pa=n[Ba.b];Fa=n[Ba.c];if($.visible&&pa.visible&&
|
|
|
+Fa.visible&&(Ga.doubleSided||Ga.flipSided!=(Fa.positionScreen.x-$.positionScreen.x)*(pa.positionScreen.y-$.positionScreen.y)-(Fa.positionScreen.y-$.positionScreen.y)*(pa.positionScreen.x-$.positionScreen.x)<0)){ka=t[o]=t[o]||new THREE.RenderableFace3;o++;p=ka;p.v1.copy($);p.v2.copy(pa);p.v3.copy(Fa)}else continue}else if(Ba instanceof THREE.Face4){$=n[Ba.a];pa=n[Ba.b];Fa=n[Ba.c];ka=n[Ba.d];if($.visible&&pa.visible&&Fa.visible&&ka.visible&&(Ga.doubleSided||Ga.flipSided!=((ka.positionScreen.x-$.positionScreen.x)*
|
|
|
+(pa.positionScreen.y-$.positionScreen.y)-(ka.positionScreen.y-$.positionScreen.y)*(pa.positionScreen.x-$.positionScreen.x)<0||(pa.positionScreen.x-Fa.positionScreen.x)*(ka.positionScreen.y-Fa.positionScreen.y)-(pa.positionScreen.y-Fa.positionScreen.y)*(ka.positionScreen.x-Fa.positionScreen.x)<0))){qa=v[x]=v[x]||new THREE.RenderableFace4;x++;p=qa;p.v1.copy($);p.v2.copy(pa);p.v3.copy(Fa);p.v4.copy(ka)}else continue}p.normalWorld.copy(Ba.normal);Za.multiplyVector3(p.normalWorld);p.centroidWorld.copy(Ba.centroid);
|
|
|
+Ra.multiplyVector3(p.centroidWorld);p.centroidScreen.copy(p.centroidWorld);P.multiplyVector3(p.centroidScreen);Fa=Ba.vertexNormals;$=0;for(pa=Fa.length;$<pa;$++){ka=p.vertexNormalsWorld[$];ka.copy(Fa[$]);Za.multiplyVector3(ka)}$=0;for(pa=O.length;$<pa;$++)if(qa=O[$][ja]){Fa=0;for(ka=qa.length;Fa<ka;Fa++)p.uvs[$][Fa]=qa[Fa]}p.meshMaterials=Va;p.faceMaterials=Ba.materials;p.overdraw=Sa;p.z=p.centroidScreen.z;Ha.push(p)}}else if(Ga instanceof THREE.Line){za.multiply(P,Ra);ja=Ga.geometry.vertices;$=b();
|
|
|
+$.positionScreen.copy(ja[0].position);za.multiplyVector4($.positionScreen);sa=1;for(Ba=ja.length;sa<Ba;sa++){$=b();$.positionScreen.copy(ja[sa].position);za.multiplyVector4($.positionScreen);pa=n[k-2];ta.copy($.positionScreen);e.copy(pa.positionScreen);if(c(ta,e)){ta.multiplyScalar(1/ta.w);e.multiplyScalar(1/e.w);Ra=E[C]=E[C]||new THREE.RenderableLine;C++;z=Ra;z.v1.positionScreen.copy(ta);z.v2.positionScreen.copy(e);z.z=Math.max(ta.z,e.z);z.materials=Ga.materials;Ha.push(z)}}}else if(Ga instanceof
|
|
|
+THREE.Particle){N.set(Ga.position.x,Ga.position.y,Ga.position.z,1);P.multiplyVector4(N);N.z/=N.w;if(N.z>0&&N.z<1){Ra=y[U]=y[U]||new THREE.RenderableParticle;U++;J=Ra;J.x=N.x/N.w;J.y=N.y/N.w;J.z=N.z;J.rotation=Ga.rotation.z;J.scale.x=Ga.scale.x*Math.abs(J.x-(N.x+ea.projectionMatrix.n11)/(N.w+ea.projectionMatrix.n14));J.scale.y=Ga.scale.y*Math.abs(J.y-(N.y+ea.projectionMatrix.n22)/(N.w+ea.projectionMatrix.n24));J.materials=Ga.materials;Ha.push(J)}}}}Aa&&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,x,v,z,C;b=d.projectScene(j,k);n=0;for(p=b.length;n<p;n++){x=b[n];if(x instanceof THREE.RenderableParticle){z=x.x*g+g;C=x.y*h+h;o=0;for(t=x.material.length;o<t;o++){v=x.material[o];if(v instanceof THREE.ParticleDOMMaterial){v=v.domElement;v.style.left=z+"px";v.style.top=C+"px"}}}}}};
|
|
|
+THREE.CanvasRenderer=function(){function b(ra){if(v!=ra)o.globalAlpha=v=ra}function d(ra){if(z!=ra){switch(ra){case THREE.NormalBlending:o.globalCompositeOperation="source-over";break;case THREE.AdditiveBlending:o.globalCompositeOperation="lighter";break;case THREE.SubtractiveBlending:o.globalCompositeOperation="darker"}z=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),x=0,v=1,z=0,
|
|
|
+C=null,E=null,J=null,U=null,y=null,L,N,P,za,va=new THREE.RenderableVertex,ta=new THREE.RenderableVertex,e,fa,ea,Aa,Ha,Ia,ua,ca,sa,Ba,ja,$,pa=new THREE.Color,Fa=new THREE.Color,ka=new THREE.Color,oa=new THREE.Color,Ga=new THREE.Color,Ra,Za,Va,Sa,O,aa,qa,Da,ha,la,m=new THREE.Rectangle,B=new THREE.Rectangle,w=new THREE.Rectangle,u=!1,A=new THREE.Color,M=new THREE.Color,G=new THREE.Color,I=new THREE.Color,F=new THREE.Vector3,D,H,K,X,T,Ea,Ja=16;D=document.createElement("canvas");D.width=D.height=2;H=D.getContext("2d");
|
|
|
+H.fillStyle="rgba(0,0,0,1)";H.fillRect(0,0,2,2);K=H.getImageData(0,0,2,2);X=K.data;T=document.createElement("canvas");T.width=T.height=Ja;Ea=T.getContext("2d");Ea.translate(-Ja/2,-Ja/2);Ea.scale(Ja,Ja);Ja--;this.domElement=h;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setSize=function(ra,ya){j=ra;k=ya;n=j/2;p=k/2;h.width=j;h.height=k;m.set(-n,-p,n,p);v=1;z=0;y=U=J=E=C=null};this.setClearColor=function(ra,ya){t=ra;x=ya};this.setClearColorHex=function(ra,ya){t.setHex(ra);x=ya};this.clear=
|
|
|
+function(){o.setTransform(1,0,0,-1,n,p);if(!B.isEmpty()){B.inflate(1);B.minSelf(m);if(t.hex==0&&x==0)o.clearRect(B.getX(),B.getY(),B.getWidth(),B.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)+","+x+")";o.fillRect(B.getX(),B.getY(),B.getWidth(),B.getHeight())}B.empty()}};this.render=function(ra,ya){function bb(S){var ia,ma,W,xa=S.lights;M.setRGB(0,0,0);G.setRGB(0,0,0);I.setRGB(0,0,0);S=0;for(ia=xa.length;S<ia;S++){ma=
|
|
|
+xa[S];W=ma.color;if(ma instanceof THREE.AmbientLight){M.r+=W.r;M.g+=W.g;M.b+=W.b}else if(ma instanceof THREE.DirectionalLight){G.r+=W.r;G.g+=W.g;G.b+=W.b}else if(ma instanceof THREE.PointLight){I.r+=W.r;I.g+=W.g;I.b+=W.b}}}function Y(S,ia,ma,W){var xa,wa,ga,V,Ka=S.lights;S=0;for(xa=Ka.length;S<xa;S++){wa=Ka[S];ga=wa.color;if(wa instanceof THREE.DirectionalLight){V=ma.dot(wa.position);if(!(V<=0)){V*=wa.intensity;W.r+=ga.r*V;W.g+=ga.g*V;W.b+=ga.b*V}}else if(wa instanceof THREE.PointLight){V=ma.dot(F.sub(wa.position,
|
|
|
+ia).normalize());if(!(V<=0)){V*=wa.distance==0?1:1-Math.min(ia.distanceTo(wa.position)/wa.distance,1);if(V!=0){V*=wa.intensity;W.r+=ga.r*V;W.g+=ga.g*V;W.b+=ga.b*V}}}}}function da(S,ia,ma){b(ma.opacity);d(ma.blending);var W,xa,wa,ga,V,Ka;if(ma instanceof THREE.ParticleBasicMaterial){if(ma.map){ga=ma.map.image;V=ga.width>>1;Ka=ga.height>>1;ma=ia.scale.x*n;wa=ia.scale.y*p;W=ma*V;xa=wa*Ka;w.set(S.x-W,S.y-xa,S.x+W,S.y+xa);if(m.instersects(w)){o.save();o.translate(S.x,S.y);o.rotate(-ia.rotation);o.scale(ma,
|
|
|
+-wa);o.translate(-V,-Ka);o.drawImage(ga,0,0);o.restore()}}}else if(ma instanceof THREE.ParticleCanvasMaterial){W=ia.scale.x*n;xa=ia.scale.y*p;w.set(S.x-W,S.y-xa,S.x+W,S.y+xa);if(m.instersects(w)){c(ma.color.__styleString);wa=ma.color.__styleString;if(E!=wa)o.fillStyle=E=wa;o.save();o.translate(S.x,S.y);o.rotate(-ia.rotation);o.scale(W,xa);ma.program(o);o.restore()}}}function na(S,ia,ma,W){b(W.opacity);d(W.blending);o.beginPath();o.moveTo(S.positionScreen.x,S.positionScreen.y);o.lineTo(ia.positionScreen.x,
|
|
|
+ia.positionScreen.y);o.closePath();if(W instanceof THREE.LineBasicMaterial){pa.__styleString=W.color.__styleString;S=W.linewidth;if(J!=S)o.lineWidth=J=S;S=W.linecap;if(U!=S)o.lineCap=U=S;S=W.linejoin;if(y!=S)o.lineJoin=y=S;c(pa.__styleString);o.stroke();w.inflate(W.linewidth*2)}}function La(S,ia,ma,W,xa,wa,ga,V,Ka){b(V.opacity);d(V.blending);e=S.positionScreen.x;fa=S.positionScreen.y;ea=ia.positionScreen.x;Aa=ia.positionScreen.y;Ha=ma.positionScreen.x;Ia=ma.positionScreen.y;Q(e,fa,ea,Aa,Ha,Ia);if(V instanceof
|
|
|
+THREE.MeshBasicMaterial)if(V.map){if(V.map.mapping instanceof THREE.UVMapping){Sa=ga.uvs[0];Oa(e,fa,ea,Aa,Ha,Ia,V.map.image,Sa[W].u,Sa[W].v,Sa[xa].u,Sa[xa].v,Sa[wa].u,Sa[wa].v)}}else if(V.envMap){if(V.envMap.mapping instanceof THREE.SphericalReflectionMapping){S=ya.matrixWorldInverse;F.copy(ga.vertexNormalsWorld[0]);O=(F.x*S.n11+F.y*S.n12+F.z*S.n13)*0.5+0.5;aa=-(F.x*S.n21+F.y*S.n22+F.z*S.n23)*0.5+0.5;F.copy(ga.vertexNormalsWorld[1]);qa=(F.x*S.n11+F.y*S.n12+F.z*S.n13)*0.5+0.5;Da=-(F.x*S.n21+F.y*S.n22+
|
|
|
+F.z*S.n23)*0.5+0.5;F.copy(ga.vertexNormalsWorld[2]);ha=(F.x*S.n11+F.y*S.n12+F.z*S.n13)*0.5+0.5;la=-(F.x*S.n21+F.y*S.n22+F.z*S.n23)*0.5+0.5;Oa(e,fa,ea,Aa,Ha,Ia,V.envMap.image,O,aa,qa,Da,ha,la)}}else V.wireframe?db(V.color.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Na(V.color.__styleString);else if(V instanceof THREE.MeshLambertMaterial){if(V.map&&!V.wireframe){if(V.map.mapping instanceof THREE.UVMapping){Sa=ga.uvs[0];Oa(e,fa,ea,Aa,Ha,Ia,V.map.image,Sa[W].u,Sa[W].v,Sa[xa].u,
|
|
|
+Sa[xa].v,Sa[wa].u,Sa[wa].v)}d(THREE.SubtractiveBlending)}if(u)if(!V.wireframe&&V.shading==THREE.SmoothShading&&ga.vertexNormalsWorld.length==3){Fa.r=ka.r=oa.r=M.r;Fa.g=ka.g=oa.g=M.g;Fa.b=ka.b=oa.b=M.b;Y(Ka,ga.v1.positionWorld,ga.vertexNormalsWorld[0],Fa);Y(Ka,ga.v2.positionWorld,ga.vertexNormalsWorld[1],ka);Y(Ka,ga.v3.positionWorld,ga.vertexNormalsWorld[2],oa);Ga.r=(ka.r+oa.r)*0.5;Ga.g=(ka.g+oa.g)*0.5;Ga.b=(ka.b+oa.b)*0.5;Va=hb(Fa,ka,oa,Ga);Oa(e,fa,ea,Aa,Ha,Ia,Va,0,0,1,0,0,1)}else{A.r=M.r;A.g=M.g;
|
|
|
+A.b=M.b;Y(Ka,ga.centroidWorld,ga.normalWorld,A);pa.r=V.color.r*A.r;pa.g=V.color.g*A.g;pa.b=V.color.b*A.b;pa.updateStyleString();V.wireframe?db(pa.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Na(pa.__styleString)}else V.wireframe?db(V.color.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Na(V.color.__styleString)}else if(V instanceof THREE.MeshDepthMaterial){Ra=ya.near;Za=ya.far;Fa.r=Fa.g=Fa.b=1-eb(S.positionScreen.z,Ra,Za);ka.r=ka.g=ka.b=1-
|
|
|
+eb(ia.positionScreen.z,Ra,Za);oa.r=oa.g=oa.b=1-eb(ma.positionScreen.z,Ra,Za);Ga.r=(ka.r+oa.r)*0.5;Ga.g=(ka.g+oa.g)*0.5;Ga.b=(ka.b+oa.b)*0.5;Va=hb(Fa,ka,oa,Ga);Oa(e,fa,ea,Aa,Ha,Ia,Va,0,0,1,0,0,1)}else if(V instanceof THREE.MeshNormalMaterial){pa.r=$a(ga.normalWorld.x);pa.g=$a(ga.normalWorld.y);pa.b=$a(ga.normalWorld.z);pa.updateStyleString();V.wireframe?db(pa.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Na(pa.__styleString)}}function Z(S,ia,ma,W,xa,wa,ga,V,Ka){b(V.opacity);
|
|
|
+d(V.blending);if(V.map||V.envMap){La(S,ia,W,0,1,3,ga,V,Ka);La(xa,ma,wa,1,2,3,ga,V,Ka)}else{e=S.positionScreen.x;fa=S.positionScreen.y;ea=ia.positionScreen.x;Aa=ia.positionScreen.y;Ha=ma.positionScreen.x;Ia=ma.positionScreen.y;ua=W.positionScreen.x;ca=W.positionScreen.y;sa=xa.positionScreen.x;Ba=xa.positionScreen.y;ja=wa.positionScreen.x;$=wa.positionScreen.y;if(V instanceof THREE.MeshBasicMaterial){Qa(e,fa,ea,Aa,Ha,Ia,ua,ca);V.wireframe?db(V.color.__styleString,V.wireframeLinewidth,V.wireframeLinecap,
|
|
|
+V.wireframeLinejoin):Na(V.color.__styleString)}else if(V instanceof THREE.MeshLambertMaterial)if(u)if(!V.wireframe&&V.shading==THREE.SmoothShading&&ga.vertexNormalsWorld.length==4){Fa.r=ka.r=oa.r=Ga.r=M.r;Fa.g=ka.g=oa.g=Ga.g=M.g;Fa.b=ka.b=oa.b=Ga.b=M.b;Y(Ka,ga.v1.positionWorld,ga.vertexNormalsWorld[0],Fa);Y(Ka,ga.v2.positionWorld,ga.vertexNormalsWorld[1],ka);Y(Ka,ga.v4.positionWorld,ga.vertexNormalsWorld[3],oa);Y(Ka,ga.v3.positionWorld,ga.vertexNormalsWorld[2],Ga);Va=hb(Fa,ka,oa,Ga);Q(e,fa,ea,Aa,
|
|
|
+ua,ca);Oa(e,fa,ea,Aa,ua,ca,Va,0,0,1,0,0,1);Q(sa,Ba,Ha,Ia,ja,$);Oa(sa,Ba,Ha,Ia,ja,$,Va,1,0,1,1,0,1)}else{A.r=M.r;A.g=M.g;A.b=M.b;Y(Ka,ga.centroidWorld,ga.normalWorld,A);pa.r=V.color.r*A.r;pa.g=V.color.g*A.g;pa.b=V.color.b*A.b;pa.updateStyleString();Qa(e,fa,ea,Aa,Ha,Ia,ua,ca);V.wireframe?db(pa.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Na(pa.__styleString)}else{Qa(e,fa,ea,Aa,Ha,Ia,ua,ca);V.wireframe?db(V.color.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):
|
|
|
+Na(V.color.__styleString)}else if(V instanceof THREE.MeshNormalMaterial){pa.r=$a(ga.normalWorld.x);pa.g=$a(ga.normalWorld.y);pa.b=$a(ga.normalWorld.z);pa.updateStyleString();Qa(e,fa,ea,Aa,Ha,Ia,ua,ca);V.wireframe?db(pa.__styleString,V.wireframeLinewidth,V.wireframeLinecap,V.wireframeLinejoin):Na(pa.__styleString)}else if(V instanceof THREE.MeshDepthMaterial){Ra=ya.near;Za=ya.far;Fa.r=Fa.g=Fa.b=1-eb(S.positionScreen.z,Ra,Za);ka.r=ka.g=ka.b=1-eb(ia.positionScreen.z,Ra,Za);oa.r=oa.g=oa.b=1-eb(W.positionScreen.z,
|
|
|
+Ra,Za);Ga.r=Ga.g=Ga.b=1-eb(ma.positionScreen.z,Ra,Za);Va=hb(Fa,ka,oa,Ga);Q(e,fa,ea,Aa,ua,ca);Oa(e,fa,ea,Aa,ua,ca,Va,0,0,1,0,0,1);Q(sa,Ba,Ha,Ia,ja,$);Oa(sa,Ba,Ha,Ia,ja,$,Va,1,0,1,1,0,1)}}}function Q(S,ia,ma,W,xa,wa){o.beginPath();o.moveTo(S,ia);o.lineTo(ma,W);o.lineTo(xa,wa);o.lineTo(S,ia);o.closePath()}function Qa(S,ia,ma,W,xa,wa,ga,V){o.beginPath();o.moveTo(S,ia);o.lineTo(ma,W);o.lineTo(xa,wa);o.lineTo(ga,V);o.lineTo(S,ia);o.closePath()}function db(S,ia,ma,W){if(J!=ia)o.lineWidth=J=ia;if(U!=ma)o.lineCap=
|
|
|
+U=ma;if(y!=W)o.lineJoin=y=W;c(S);o.stroke();w.inflate(ia*2)}function Na(S){if(E!=S)o.fillStyle=E=S;o.fill()}function Oa(S,ia,ma,W,xa,wa,ga,V,Ka,Wa,Ua,ib,Xa){var fb,gb;fb=ga.width-1;gb=ga.height-1;V*=fb;Ka*=gb;Wa*=fb;Ua*=gb;ib*=fb;Xa*=gb;ma-=S;W-=ia;xa-=S;wa-=ia;Wa-=V;Ua-=Ka;ib-=V;Xa-=Ka;fb=Wa*Xa-ib*Ua;if(fb!=0){gb=1/fb;fb=(Xa*ma-Ua*xa)*gb;Ua=(Xa*W-Ua*wa)*gb;ma=(Wa*xa-ib*ma)*gb;W=(Wa*wa-ib*W)*gb;S=S-fb*V-ma*Ka;ia=ia-Ua*V-W*Ka;o.save();o.transform(fb,Ua,ma,W,S,ia);o.clip();o.drawImage(ga,0,0);o.restore()}}
|
|
|
+function hb(S,ia,ma,W){var xa=~~(S.r*255),wa=~~(S.g*255);S=~~(S.b*255);var ga=~~(ia.r*255),V=~~(ia.g*255);ia=~~(ia.b*255);var Ka=~~(ma.r*255),Wa=~~(ma.g*255);ma=~~(ma.b*255);var Ua=~~(W.r*255),ib=~~(W.g*255);W=~~(W.b*255);X[0]=xa<0?0:xa>255?255:xa;X[1]=wa<0?0:wa>255?255:wa;X[2]=S<0?0:S>255?255:S;X[4]=ga<0?0:ga>255?255:ga;X[5]=V<0?0:V>255?255:V;X[6]=ia<0?0:ia>255?255:ia;X[8]=Ka<0?0:Ka>255?255:Ka;X[9]=Wa<0?0:Wa>255?255:Wa;X[10]=ma<0?0:ma>255?255:ma;X[12]=Ua<0?0:Ua>255?255:Ua;X[13]=ib<0?0:ib>255?255:
|
|
|
+ib;X[14]=W<0?0:W>255?255:W;H.putImageData(K,0,0);Ea.drawImage(D,0,0);return T}function eb(S,ia,ma){S=(S-ia)/(ma-ia);return S*S*(3-2*S)}function $a(S){S=(S+1)*0.5;return S<0?0:S>1?1:S}function ab(S,ia){var ma=ia.x-S.x,W=ia.y-S.y,xa=1/Math.sqrt(ma*ma+W*W);ma*=xa;W*=xa;ia.x+=ma;ia.y+=W;S.x-=ma;S.y-=W}var Ma,cb,Ca,R,Pa,Ta,jb,Ya;this.autoClear?this.clear():o.setTransform(1,0,0,-1,n,p);f=g.projectScene(ra,ya,this.sortElements);(u=ra.lights.length>0)&&bb(ra);Ma=0;for(cb=f.length;Ma<cb;Ma++){Ca=f[Ma];w.empty();
|
|
|
+if(Ca instanceof THREE.RenderableParticle){L=Ca;L.x*=n;L.y*=p;R=0;for(Pa=Ca.materials.length;R<Pa;){Ya=Ca.materials[R++];Ya.opacity!=0&&da(L,Ca,Ya,ra)}}else if(Ca instanceof THREE.RenderableLine){L=Ca.v1;N=Ca.v2;L.positionScreen.x*=n;L.positionScreen.y*=p;N.positionScreen.x*=n;N.positionScreen.y*=p;w.addPoint(L.positionScreen.x,L.positionScreen.y);w.addPoint(N.positionScreen.x,N.positionScreen.y);if(m.instersects(w)){R=0;for(Pa=Ca.materials.length;R<Pa;){Ya=Ca.materials[R++];Ya.opacity!=0&&na(L,N,
|
|
|
+Ca,Ya,ra)}}}else if(Ca instanceof THREE.RenderableFace3){L=Ca.v1;N=Ca.v2;P=Ca.v3;L.positionScreen.x*=n;L.positionScreen.y*=p;N.positionScreen.x*=n;N.positionScreen.y*=p;P.positionScreen.x*=n;P.positionScreen.y*=p;if(Ca.overdraw){ab(L.positionScreen,N.positionScreen);ab(N.positionScreen,P.positionScreen);ab(P.positionScreen,L.positionScreen)}w.add3Points(L.positionScreen.x,L.positionScreen.y,N.positionScreen.x,N.positionScreen.y,P.positionScreen.x,P.positionScreen.y);if(m.instersects(w)){R=0;for(Pa=
|
|
|
+Ca.meshMaterials.length;R<Pa;){Ya=Ca.meshMaterials[R++];if(Ya instanceof THREE.MeshFaceMaterial){Ta=0;for(jb=Ca.faceMaterials.length;Ta<jb;)(Ya=Ca.faceMaterials[Ta++])&&Ya.opacity!=0&&La(L,N,P,0,1,2,Ca,Ya,ra)}else Ya.opacity!=0&&La(L,N,P,0,1,2,Ca,Ya,ra)}}}else if(Ca instanceof THREE.RenderableFace4){L=Ca.v1;N=Ca.v2;P=Ca.v3;za=Ca.v4;L.positionScreen.x*=n;L.positionScreen.y*=p;N.positionScreen.x*=n;N.positionScreen.y*=p;P.positionScreen.x*=n;P.positionScreen.y*=p;za.positionScreen.x*=n;za.positionScreen.y*=
|
|
|
+p;va.positionScreen.copy(N.positionScreen);ta.positionScreen.copy(za.positionScreen);if(Ca.overdraw){ab(L.positionScreen,N.positionScreen);ab(N.positionScreen,za.positionScreen);ab(za.positionScreen,L.positionScreen);ab(P.positionScreen,va.positionScreen);ab(P.positionScreen,ta.positionScreen)}w.addPoint(L.positionScreen.x,L.positionScreen.y);w.addPoint(N.positionScreen.x,N.positionScreen.y);w.addPoint(P.positionScreen.x,P.positionScreen.y);w.addPoint(za.positionScreen.x,za.positionScreen.y);if(m.instersects(w)){R=
|
|
|
+0;for(Pa=Ca.meshMaterials.length;R<Pa;){Ya=Ca.meshMaterials[R++];if(Ya instanceof THREE.MeshFaceMaterial){Ta=0;for(jb=Ca.faceMaterials.length;Ta<jb;)(Ya=Ca.faceMaterials[Ta++])&&Ya.opacity!=0&&Z(L,N,P,za,va,ta,Ca,Ya,ra)}else Ya.opacity!=0&&Z(L,N,P,za,va,ta,Ca,Ya,ra)}}}B.addRectangle(w)}o.setTransform(1,0,0,1,0,0)}};
|
|
|
+THREE.SVGRenderer=function(){function b(ua,ca,sa){var Ba,ja,$,pa;Ba=0;for(ja=ua.lights.length;Ba<ja;Ba++){$=ua.lights[Ba];if($ instanceof THREE.DirectionalLight){pa=ca.normalWorld.dot($.position)*$.intensity;if(pa>0){sa.r+=$.color.r*pa;sa.g+=$.color.g*pa;sa.b+=$.color.b*pa}}else if($ instanceof THREE.PointLight){ta.sub($.position,ca.centroidWorld);ta.normalize();pa=ca.normalWorld.dot(ta)*$.intensity;if(pa>0){sa.r+=$.color.r*pa;sa.g+=$.color.g*pa;sa.b+=$.color.b*pa}}}}function d(ua,ca,sa,Ba,ja,$){ea=
|
|
|
+f(Aa++);ea.setAttribute("d","M "+ua.positionScreen.x+" "+ua.positionScreen.y+" L "+ca.positionScreen.x+" "+ca.positionScreen.y+" L "+sa.positionScreen.x+","+sa.positionScreen.y+"z");if(ja instanceof THREE.MeshBasicMaterial)y.__styleString=ja.color.__styleString;else if(ja instanceof THREE.MeshLambertMaterial)if(U){L.r=N.r;L.g=N.g;L.b=N.b;b($,Ba,L);y.r=ja.color.r*L.r;y.g=ja.color.g*L.g;y.b=ja.color.b*L.b;y.updateStyleString()}else y.__styleString=ja.color.__styleString;else if(ja instanceof THREE.MeshDepthMaterial){va=
|
|
|
+1-ja.__2near/(ja.__farPlusNear-Ba.z*ja.__farMinusNear);y.setRGB(va,va,va)}else ja instanceof THREE.MeshNormalMaterial&&y.setRGB(g(Ba.normalWorld.x),g(Ba.normalWorld.y),g(Ba.normalWorld.z));ja.wireframe?ea.setAttribute("style","fill: none; stroke: "+y.__styleString+"; stroke-width: "+ja.wireframeLinewidth+"; stroke-opacity: "+ja.opacity+"; stroke-linecap: "+ja.wireframeLinecap+"; stroke-linejoin: "+ja.wireframeLinejoin):ea.setAttribute("style","fill: "+y.__styleString+"; fill-opacity: "+ja.opacity);
|
|
|
+k.appendChild(ea)}function c(ua,ca,sa,Ba,ja,$,pa){ea=f(Aa++);ea.setAttribute("d","M "+ua.positionScreen.x+" "+ua.positionScreen.y+" L "+ca.positionScreen.x+" "+ca.positionScreen.y+" L "+sa.positionScreen.x+","+sa.positionScreen.y+" L "+Ba.positionScreen.x+","+Ba.positionScreen.y+"z");if($ instanceof THREE.MeshBasicMaterial)y.__styleString=$.color.__styleString;else if($ instanceof THREE.MeshLambertMaterial)if(U){L.r=N.r;L.g=N.g;L.b=N.b;b(pa,ja,L);y.r=$.color.r*L.r;y.g=$.color.g*L.g;y.b=$.color.b*
|
|
|
+L.b;y.updateStyleString()}else y.__styleString=$.color.__styleString;else if($ instanceof THREE.MeshDepthMaterial){va=1-$.__2near/($.__farPlusNear-ja.z*$.__farMinusNear);y.setRGB(va,va,va)}else $ instanceof THREE.MeshNormalMaterial&&y.setRGB(g(ja.normalWorld.x),g(ja.normalWorld.y),g(ja.normalWorld.z));$.wireframe?ea.setAttribute("style","fill: none; stroke: "+y.__styleString+"; stroke-width: "+$.wireframeLinewidth+"; stroke-opacity: "+$.opacity+"; stroke-linecap: "+$.wireframeLinecap+"; stroke-linejoin: "+
|
|
|
+$.wireframeLinejoin):ea.setAttribute("style","fill: "+y.__styleString+"; fill-opacity: "+$.opacity);k.appendChild(ea)}function f(ua){if(e[ua]==null){e[ua]=document.createElementNS("http://www.w3.org/2000/svg","path");Ia==0&&e[ua].setAttribute("shape-rendering","crispEdges")}return e[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,x,v,z,C,E=new THREE.Rectangle,J=
|
|
|
+new THREE.Rectangle,U=!1,y=new THREE.Color(16777215),L=new THREE.Color(16777215),N=new THREE.Color(0),P=new THREE.Color(0),za=new THREE.Color(0),va,ta=new THREE.Vector3,e=[],fa=[],ea,Aa,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 sa,Ba,ja,$,pa,Fa,ka,oa;this.autoClear&&this.clear();h=j.projectScene(ua,ca,this.sortElements);Ha=Aa=0;if(U=ua.lights.length>0){ka=ua.lights;N.setRGB(0,0,0);P.setRGB(0,0,0);za.setRGB(0,0,0);sa=0;for(Ba=ka.length;sa<Ba;sa++){ja=ka[sa];$=ja.color;if(ja instanceof THREE.AmbientLight){N.r+=$.r;N.g+=$.g;N.b+=$.b}else if(ja instanceof THREE.DirectionalLight){P.r+=$.r;P.g+=
|
|
|
+$.g;P.b+=$.b}else if(ja instanceof THREE.PointLight){za.r+=$.r;za.g+=$.g;za.b+=$.b}}}sa=0;for(Ba=h.length;sa<Ba;sa++){ka=h[sa];J.empty();if(ka instanceof THREE.RenderableParticle){x=ka;x.x*=o;x.y*=-t;ja=0;for($=ka.materials.length;ja<$;)ja++}else if(ka instanceof THREE.RenderableLine){x=ka.v1;v=ka.v2;x.positionScreen.x*=o;x.positionScreen.y*=-t;v.positionScreen.x*=o;v.positionScreen.y*=-t;J.addPoint(x.positionScreen.x,x.positionScreen.y);J.addPoint(v.positionScreen.x,v.positionScreen.y);if(E.instersects(J)){ja=
|
|
|
+0;for($=ka.materials.length;ja<$;)if((oa=ka.materials[ja++])&&oa.opacity!=0){pa=x;Fa=v;var Ga=Ha++;if(fa[Ga]==null){fa[Ga]=document.createElementNS("http://www.w3.org/2000/svg","line");Ia==0&&fa[Ga].setAttribute("shape-rendering","crispEdges")}ea=fa[Ga];ea.setAttribute("x1",pa.positionScreen.x);ea.setAttribute("y1",pa.positionScreen.y);ea.setAttribute("x2",Fa.positionScreen.x);ea.setAttribute("y2",Fa.positionScreen.y);if(oa instanceof THREE.LineBasicMaterial){y.__styleString=oa.color.__styleString;
|
|
|
+ea.setAttribute("style","fill: none; stroke: "+y.__styleString+"; stroke-width: "+oa.linewidth+"; stroke-opacity: "+oa.opacity+"; stroke-linecap: "+oa.linecap+"; stroke-linejoin: "+oa.linejoin);k.appendChild(ea)}}}}else if(ka instanceof THREE.RenderableFace3){x=ka.v1;v=ka.v2;z=ka.v3;x.positionScreen.x*=o;x.positionScreen.y*=-t;v.positionScreen.x*=o;v.positionScreen.y*=-t;z.positionScreen.x*=o;z.positionScreen.y*=-t;J.addPoint(x.positionScreen.x,x.positionScreen.y);J.addPoint(v.positionScreen.x,v.positionScreen.y);
|
|
|
+J.addPoint(z.positionScreen.x,z.positionScreen.y);if(E.instersects(J)){ja=0;for($=ka.meshMaterials.length;ja<$;){oa=ka.meshMaterials[ja++];if(oa instanceof THREE.MeshFaceMaterial){pa=0;for(Fa=ka.faceMaterials.length;pa<Fa;)(oa=ka.faceMaterials[pa++])&&oa.opacity!=0&&d(x,v,z,ka,oa,ua)}else oa&&oa.opacity!=0&&d(x,v,z,ka,oa,ua)}}}else if(ka instanceof THREE.RenderableFace4){x=ka.v1;v=ka.v2;z=ka.v3;C=ka.v4;x.positionScreen.x*=o;x.positionScreen.y*=-t;v.positionScreen.x*=o;v.positionScreen.y*=-t;z.positionScreen.x*=
|
|
|
+o;z.positionScreen.y*=-t;C.positionScreen.x*=o;C.positionScreen.y*=-t;J.addPoint(x.positionScreen.x,x.positionScreen.y);J.addPoint(v.positionScreen.x,v.positionScreen.y);J.addPoint(z.positionScreen.x,z.positionScreen.y);J.addPoint(C.positionScreen.x,C.positionScreen.y);if(E.instersects(J)){ja=0;for($=ka.meshMaterials.length;ja<$;){oa=ka.meshMaterials[ja++];if(oa instanceof THREE.MeshFaceMaterial){pa=0;for(Fa=ka.faceMaterials.length;pa<Fa;)(oa=ka.faceMaterials[pa++])&&oa.opacity!=0&&c(x,v,z,C,ka,oa,
|
|
|
+ua)}else oa&&oa.opacity!=0&&c(x,v,z,C,ka,oa,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,105 +222,105 @@ 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,A,x){var t,w,S,E=m.vertices,G=E.length,O=m.colors,D=O.length,I=m.__vertexArray,Q=m.__colorArray,sa=m.__sortArray,W=m.__dirtyVertices,Ba=m.__dirtyColors;if(x.sortParticles){Ua.multiplySelf(x.matrixWorld);for(t=0;t<G;t++){w=E[t].position;Pa.copy(w);Ua.multiplyVector3(Pa);sa[t]=[Pa.z,t]}sa.sort(function(ra,za){return za[0]-ra[0]});for(t=0;t<G;t++){w=E[sa[t][1]].position;S=t*3;I[S]=w.x;I[S+1]=w.y;I[S+2]=w.z}for(t=0;t<D;t++){S=t*3;color=O[sa[t][1]];Q[S]=color.r;
|
|
|
-Q[S+1]=color.g;Q[S+2]=color.b}}else{if(W)for(t=0;t<G;t++){w=E[t].position;S=t*3;I[S]=w.x;I[S+1]=w.y;I[S+2]=w.z}if(Ba)for(t=0;t<D;t++){color=O[t];S=t*3;Q[S]=color.r;Q[S+1]=color.g;Q[S+2]=color.b}}if(W||x.sortParticles){e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,I,A)}if(Ba||x.sortParticles){e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,Q,A)}}function c(m,A){m.uniforms=Uniforms.clone(A.uniforms);m.vertexShader=A.vertexShader;m.fragmentShader=
|
|
|
-A.fragmentShader}function f(m,A,x,t,w){t.program||$.initMaterial(t,A,x,w);var S=t.program,E=S.uniforms,G=t.uniforms;if(S!=Aa){e.useProgram(S);Aa=S}e.uniformMatrix4fv(E.projectionMatrix,!1,cb);if(x&&(t instanceof THREE.MeshBasicMaterial||t instanceof THREE.MeshLambertMaterial||t instanceof THREE.MeshPhongMaterial||t instanceof THREE.LineBasicMaterial||t instanceof THREE.ParticleBasicMaterial||t.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(t instanceof THREE.MeshPhongMaterial||t instanceof THREE.MeshLambertMaterial||t.lights){var O,D,I=0,Q=0,sa=0,W,Ba,ra,za,Ia=N,Sa=Ia.directional.colors,ea=Ia.directional.positions,ca=Ia.point.colors,ja=Ia.point.positions,La=Ia.point.distances,V=0,P=0;x=D=za=0;for(O=A.length;x<O;x++){D=A[x];W=D.color;Ba=D.position;ra=D.intensity;za=D.distance;if(D instanceof THREE.AmbientLight){I+=W.r;Q+=W.g;sa+=W.b}else if(D instanceof THREE.DirectionalLight){za=
|
|
|
-V*3;Sa[za]=W.r*ra;Sa[za+1]=W.g*ra;Sa[za+2]=W.b*ra;ea[za]=Ba.x;ea[za+1]=Ba.y;ea[za+2]=Ba.z;V+=1}else if(D instanceof THREE.PointLight){D=P*3;ca[D]=W.r*ra;ca[D+1]=W.g*ra;ca[D+2]=W.b*ra;ja[D]=Ba.x;ja[D+1]=Ba.y;ja[D+2]=Ba.z;La[P]=za;P+=1}}for(x=V*3;x<Sa.length;x++)Sa[x]=0;for(x=P*3;x<ca.length;x++)ca[x]=0;Ia.point.length=P;Ia.directional.length=V;Ia.ambient[0]=I;Ia.ambient[1]=Q;Ia.ambient[2]=sa;x=N;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(t instanceof THREE.MeshBasicMaterial||t instanceof THREE.MeshLambertMaterial||t instanceof THREE.MeshPhongMaterial){G.diffuse.value.setRGB(t.color.r,t.color.g,t.color.b);G.opacity.value=t.opacity;G.map.texture=t.map;G.lightMap.texture=t.lightMap;G.envMap.texture=t.envMap;G.reflectivity.value=
|
|
|
-t.reflectivity;G.refractionRatio.value=t.refractionRatio;G.combine.value=t.combine;G.useRefract.value=t.envMap&&t.envMap.mapping instanceof THREE.CubeRefractionMapping}if(t instanceof THREE.LineBasicMaterial){G.diffuse.value.setRGB(t.color.r,t.color.g,t.color.b);G.opacity.value=t.opacity}else if(t instanceof THREE.ParticleBasicMaterial){G.psColor.value.setRGB(t.color.r,t.color.g,t.color.b);G.opacity.value=t.opacity;G.size.value=t.size;G.scale.value=da.height/2;G.map.texture=t.map}else if(t instanceof
|
|
|
-THREE.MeshPhongMaterial){G.ambient.value.setRGB(t.ambient.r,t.ambient.g,t.ambient.b);G.specular.value.setRGB(t.specular.r,t.specular.g,t.specular.b);G.shininess.value=t.shininess}else if(t instanceof THREE.MeshDepthMaterial){G.mNear.value=m.near;G.mFar.value=m.far;G.opacity.value=t.opacity}else if(t instanceof THREE.MeshNormalMaterial)G.opacity.value=t.opacity;for(var Oa in G)if(Q=S.uniforms[Oa]){O=G[Oa];I=O.type;x=O.value;if(I=="i")e.uniform1i(Q,x);else if(I=="f")e.uniform1f(Q,x);else if(I=="fv1")e.uniform1fv(Q,
|
|
|
-x);else if(I=="fv")e.uniform3fv(Q,x);else if(I=="v2")e.uniform2f(Q,x.x,x.y);else if(I=="v3")e.uniform3f(Q,x.x,x.y,x.z);else if(I=="v4")e.uniform4f(Q,x.x,x.y,x.z,x.w);else if(I=="c")e.uniform3f(Q,x.r,x.g,x.b);else if(I=="t"){e.uniform1i(Q,x);if(O=O.texture)if(O.image instanceof Array&&O.image.length==6){if(O.image.length==6){if(O.needsUpdate){if(O.__webglInit){e.bindTexture(e.TEXTURE_CUBE_MAP,O.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,
|
|
|
-O.image[I])}else{O.image.__webglTextureCube=e.createTexture();e.bindTexture(e.TEXTURE_CUBE_MAP,O.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,O.image[I]);O.__webglInit=!0}L(e.TEXTURE_CUBE_MAP,O,O.image[0]);e.bindTexture(e.TEXTURE_CUBE_MAP,null);O.needsUpdate=!1}e.activeTexture(e.TEXTURE0+x);e.bindTexture(e.TEXTURE_CUBE_MAP,O.image.__webglTextureCube)}}else M(O,x)}}e.uniformMatrix4fv(E.modelViewMatrix,!1,w._modelViewMatrixArray);
|
|
|
-e.uniformMatrix3fv(E.normalMatrix,!1,w._normalMatrixArray);(t instanceof THREE.MeshShaderMaterial||t instanceof THREE.MeshPhongMaterial||t.envMap)&&e.uniform3f(E.cameraPosition,m.position.x,m.position.y,m.position.z);(t instanceof THREE.MeshShaderMaterial||t.envMap||t.skinning)&&e.uniformMatrix4fv(E.objectMatrix,!1,w._objectMatrixArray);(t instanceof THREE.MeshPhongMaterial||t instanceof THREE.MeshLambertMaterial||t instanceof THREE.MeshShaderMaterial||t.skinning)&&e.uniformMatrix4fv(E.viewMatrix,
|
|
|
-!1,ab);if(t instanceof THREE.ShadowVolumeDynamicMaterial){m=G.directionalLightDirection.value;m[0]=-A.position.x;m[1]=-A.position.y;m[2]=-A.position.z;e.uniform3fv(E.directionalLightDirection,m);e.uniformMatrix4fv(E.objectMatrix,!1,w._objectMatrixArray);e.uniformMatrix4fv(E.viewMatrix,!1,ab)}if(t.skinning){e.uniformMatrix4fv(E.cameraInverseMatrix,!1,ab);e.uniformMatrix4fv(E.boneGlobalMatrices,!1,w.boneMatrices)}return S}function g(m,A,x,t,w,S){if(t.opacity!=0){var E;m=f(m,A,x,t,S).attributes;if(t.morphTargets){A=
|
|
|
-t.program.attributes;S.morphTargetBase!==-1?e.bindBuffer(e.ARRAY_BUFFER,w.__webglMorphTargetsBuffers[S.morphTargetBase]):e.bindBuffer(e.ARRAY_BUFFER,w.__webglVertexBuffer);e.vertexAttribPointer(A.position,3,e.FLOAT,!1,0,0);if(S.morphTargetForcedOrder.length){x=0;for(var G=S.morphTargetForcedOrder,O=S.morphTargetInfluences;x<t.numSupportedMorphTargets&&x<G.length;){e.bindBuffer(e.ARRAY_BUFFER,w.__webglMorphTargetsBuffers[G[x]]);e.vertexAttribPointer(A["morphTarget"+x],3,e.FLOAT,!1,0,0);S.__webglMorphTargetInfluences[x]=
|
|
|
-O[G[x]];x++}}else{G=[];var D=-1,I=0;O=S.morphTargetInfluences;var Q,sa=O.length;x=0;for(S.morphTargetBase!==-1&&(G[S.morphTargetBase]=!0);x<t.numSupportedMorphTargets;){for(Q=0;Q<sa;Q++)if(!G[Q]&&O[Q]>D){I=Q;D=O[I]}e.bindBuffer(e.ARRAY_BUFFER,w.__webglMorphTargetsBuffers[I]);e.vertexAttribPointer(A["morphTarget"+x],3,e.FLOAT,!1,0,0);S.__webglMorphTargetInfluences[x]=D;G[I]=1;D=-1;x++}}e.uniform1fv(t.program.uniforms.morphTargetInfluences,S.__webglMorphTargetInfluences)}else{e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
-w.__webglVertexBuffer);e.vertexAttribPointer(m.position,3,e.FLOAT,!1,0,0)}if(w.__webglCustomAttributes)for(E in w.__webglCustomAttributes)if(m[E]>=0){A=w.__webglCustomAttributes[E];e.bindBuffer(e.ARRAY_BUFFER,A.buffer);e.vertexAttribPointer(m[E],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(t.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(S instanceof THREE.Mesh)if(t.wireframe){e.lineWidth(t.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(S instanceof THREE.Line){S=S.type==THREE.LineStrip?e.LINE_STRIP:e.LINES;e.lineWidth(t.linewidth);e.drawArrays(S,0,w.__webglLineCount)}else if(S instanceof
|
|
|
-THREE.ParticleSystem)e.drawArrays(e.POINTS,0,w.__webglParticleCount);else S 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(pa!=m.doubleSided){m.doubleSided?e.disable(e.CULL_FACE):e.enable(e.CULL_FACE);pa=m.doubleSided}if(Da!=m.flipSided){m.flipSided?e.frontFace(e.CW):e.frontFace(e.CCW);Da=m.flipSided}}function k(m){if(Y!=
|
|
|
-m){m?e.enable(e.DEPTH_TEST):e.disable(e.DEPTH_TEST);Y=m}}function n(m){wa[0].set(m.n41-m.n11,m.n42-m.n12,m.n43-m.n13,m.n44-m.n14);wa[1].set(m.n41+m.n11,m.n42+m.n12,m.n43+m.n13,m.n44+m.n14);wa[2].set(m.n41+m.n21,m.n42+m.n22,m.n43+m.n23,m.n44+m.n24);wa[3].set(m.n41-m.n21,m.n42-m.n22,m.n43-m.n23,m.n44-m.n24);wa[4].set(m.n41-m.n31,m.n42-m.n32,m.n43-m.n33,m.n44-m.n34);wa[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=wa[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)),t=0;t<6;t++){m=wa[t].x*A.n14+wa[t].y*A.n24+wa[t].z*A.n34+wa[t].w;if(m<=x)return!1}return!0}function o(m,A){m.list[m.count]=A;m.count+=1}function u(m){var A,x,t=m.object,w=m.opaque,S=m.transparent;S.count=0;m=w.count=0;for(A=t.materials.length;m<A;m++){x=t.materials[m];x.transparent?o(S,x):o(w,x)}}function y(m){var A,x,t,w,S=m.object,E=m.buffer,G=m.opaque,O=m.transparent;
|
|
|
-O.count=0;m=G.count=0;for(t=S.materials.length;m<t;m++){A=S.materials[m];if(A instanceof THREE.MeshFaceMaterial){A=0;for(x=E.materials.length;A<x;A++)(w=E.materials[A])&&(w.transparent?o(O,w):o(G,w))}else(w=A)&&(w.transparent?o(O,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,t,w=m.lights,S=[],E,G,O,D,I,Q=m.__webglShadowVolumes.length;for(A=0;A<x;A++){t=m.lights[A];if(t instanceof THREE.DirectionalLight){S[0]=-t.position.x;S[1]=-t.position.y;S[2]=-t.position.z;for(I=0;I<Q;I++){t=m.__webglShadowVolumes[I].object;E=m.__webglShadowVolumes[I].buffer;G=t.materials[0];G.program||$.initMaterial(G,w,undefined,t);G=G.program;O=G.uniforms;D=G.attributes;if(Aa!==G){e.useProgram(G);Aa=G;e.uniformMatrix4fv(O.projectionMatrix,!1,cb);e.uniformMatrix4fv(O.viewMatrix,
|
|
|
-!1,ab);e.uniform3fv(O.directionalLightDirection,S)}t.matrixWorld.flattenToArray(t._objectMatrixArray);e.uniformMatrix4fv(O.objectMatrix,!1,t._objectMatrixArray);e.bindBuffer(e.ARRAY_BUFFER,E.__webglVertexBuffer);e.vertexAttribPointer(D.position,3,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,E.__webglNormalBuffer);e.vertexAttribPointer(D.normal,3,e.FLOAT,!1,0,0);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,E.__webglFaceBuffer);e.cullFace(e.FRONT);e.drawElements(e.TRIANGLES,E.__webglFaceCount,e.UNSIGNED_SHORT,
|
|
|
-0);e.cullFace(e.BACK);e.drawElements(e.TRIANGLES,E.__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);ga="";Aa=ya.program;e.useProgram(ya.program);e.uniformMatrix4fv(ya.projectionLocation,!1,cb);e.uniform1f(ya.darknessLocation,ya.darkness);e.bindBuffer(e.ARRAY_BUFFER,ya.vertexBuffer);e.vertexAttribPointer(ya.vertexLocation,3,e.FLOAT,!1,0,0);e.enableVertexAttribArray(ya.vertexLocation);
|
|
|
-e.blendFunc(e.ONE,e.ONE_MINUS_SRC_ALPHA);e.blendEquation(e.FUNC_ADD);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ya.elementBuffer);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0);e.disable(e.STENCIL_TEST);e.enable(e.DEPTH_TEST);e.depthMask(qa)}function C(m,A){var x,t,w,S=m.__webglLensFlares.length,E,G,O;E=new THREE.Vector3;var D=na/ka;G=ka*0.5;O=na*0.5;var I=16/na,Q=[I*D,I],sa=[1,1,0];I=[1,1];var W,Ba=ia.readBackPixels,ra,za,Ia=ia.uniforms;x=ia.attributes;e.useProgram(ia.program);Aa=ia.program;ga="";e.uniform1i(Ia.map,
|
|
|
-0);e.activeTexture(e.TEXTURE0);e.uniform1f(Ia.opacity,1);e.uniform1f(Ia.rotation,0);e.uniform2fv(Ia.scale,Q);e.bindBuffer(e.ARRAY_BUFFER,ia.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,ia.tempTexture);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ia.elementBuffer);e.disable(e.CULL_FACE);e.depthMask(!1);for(w=0;w<S;w++){x=m.__webglLensFlares[w].object;E.set(x.matrixWorld.n14,x.matrixWorld.n24,x.matrixWorld.n34);A.matrixWorldInverse.multiplyVector3(E);
|
|
|
-t=E.z;A.projectionMatrix.multiplyVector3(E);sa[0]=E.x;sa[1]=E.y;sa[2]=E.z;I[0]=sa[0]*G+G;I[1]=sa[1]*O+O;e.copyTexSubImage2D(e.TEXTURE_2D,0,0,0,I[0]-8,I[1]-8,16,16);e.uniform3fv(Ia.screenPosition,sa);e.uniform1i(Ia.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,ia.readBackPixels)}catch(Sa){console.log("WebGLRenderer.renderLensFlare: readPixels failed!")}e.getError()&&console.log("WebGLRenderer.renderLensFlare: readPixels failed!");
|
|
|
-sampleDistance=parseInt(5*(1-Math.max(0,Math.min(-t,A.far))/A.far),10)+2;t=sampleDistance*4;W=sampleDistance*64;za=0;ra=28-t+(448-W);ia.readBackPixels[ra+0]===255&&ia.readBackPixels[ra+1]===0&&ia.readBackPixels[ra+2]===255&&(za+=0.2);ra=28+t+(448-W);Ba[ra+0]===255&&Ba[ra+1]===0&&Ba[ra+2]===255&&(za+=0.2);ra=28+t+(448+W);Ba[ra+0]===255&&Ba[ra+1]===0&&Ba[ra+2]===255&&(za+=0.2);ra=28-t+(448+W);Ba[ra+0]===255&&Ba[ra+1]===0&&Ba[ra+2]===255&&(za+=0.2);ra=476;Ba[ra+0]===255&&Ba[ra+1]===0&&Ba[ra+2]===255&&
|
|
|
-(za+=0.2);x.positionScreen.x=sa[0];x.positionScreen.y=sa[1];x.positionScreen.z=sa[2];x.customUpdateCallback?x.customUpdateCallback(za,x):x.updateLensFlares(za);e.uniform1i(Ia.renderPink,0);e.disable(e.DEPTH_TEST);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)}for(w=0;w<S;w++){x=m.__webglLensFlares[w].object;E=0;for(G=x.lensFlares.length;E<G;E++){O=x.lensFlares[E];if(O.opacity>0.0010&&O.scale>0.0010){sa[0]=O.x;sa[1]=O.y;sa[2]=O.z;I=O.size*O.scale/na;Q[0]=I*D;Q[1]=I;e.uniform3fv(Ia.screenPosition,
|
|
|
-sa);e.uniform1f(Ia.rotation,O.rotation);e.uniform2fv(Ia.scale,Q);e.uniform1f(Ia.opacity,O.opacity);J(O.blending);M(O.texture,0);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)}}}e.enable(e.CULL_FACE);e.enable(e.DEPTH_TEST);e.depthMask(qa)}function F(m,A){m._modelViewMatrix.multiplyToArray(A.matrixWorldInverse,m.matrixWorld,m._modelViewMatrixArray);THREE.Matrix4.makeInvert3x3(m._modelViewMatrix).transposeIntoArray(m._normalMatrixArray)}function H(m){var A,x,t,w,S;if(m instanceof THREE.Mesh){x=m.geometry;
|
|
|
-for(A in x.geometryGroups){t=x.geometryGroups[A];S=!1;for(w in t.__webglCustomAttributes)if(t.__webglCustomAttributes[w].needsUpdate){S=!0;break}if(x.__dirtyVertices||x.__dirtyMorphTargets||x.__dirtyElements||x.__dirtyUvs||x.__dirtyNormals||x.__dirtyColors||x.__dirtyTangents||S){S=e.DYNAMIC_DRAW;var E=void 0,G=void 0,O=void 0,D=void 0;O=void 0;var I=void 0,Q=void 0,sa=void 0,W=void 0,Ba=void 0,ra=void 0,za=void 0,Ia=void 0,Sa=void 0,ea=void 0,ca=void 0,ja=void 0,La=void 0;Q=void 0;sa=void 0;D=void 0;
|
|
|
-W=void 0;D=void 0;ea=void 0;ca=void 0;Q=void 0;ea=void 0;ca=void 0;ja=void 0;La=void 0;ea=void 0;ca=void 0;ja=void 0;La=void 0;ea=void 0;ca=void 0;ja=void 0;La=void 0;ea=void 0;ca=void 0;ja=void 0;D=void 0;W=void 0;I=void 0;O=void 0;O=void 0;var V=void 0,P=void 0,Oa=void 0,fb=void 0,Na=0,Xa=0,gb=0,hb=0,Ya=0,eb=0,Ra=0,Ja=0,Ma=0,R=0,Va=0;V=0;var Za=t.__vertexArray,$a=t.__uvArray,T=t.__uv2Array,ta=t.__normalArray,fa=t.__tangentArray,aa=t.__colorArray,va=t.__skinVertexAArray,ua=t.__skinVertexBArray,ha=
|
|
|
-t.__skinIndexArray,K=t.__skinWeightArray,Qa=t.__morphTargetsArrays,db=t.__webglCustomAttributes;P=void 0;var Wa=t.__faceArray,bb=t.__lineArray,lb=t.__needsSmoothNormals;ra=t.__vertexColorType;Ba=t.__uvType;za=t.__normalType;var Ta=m.geometry,ib=Ta.__dirtyVertices,sb=Ta.__dirtyElements,rb=Ta.__dirtyUvs,tb=Ta.__dirtyNormals,ub=Ta.__dirtyTangents,vb=Ta.__dirtyColors,wb=Ta.__dirtyMorphTargets,nb=Ta.vertices,xb=t.faces,Ab=Ta.faces,yb=Ta.faceVertexUvs[0],zb=Ta.faceVertexUvs[1],ob=Ta.skinVerticesA,pb=Ta.skinVerticesB,
|
|
|
-qb=Ta.skinIndices,kb=Ta.skinWeights,mb=Ta.edgeFaces,jb=Ta.morphTargets;if(db)for(fb in db)db[fb].offset=0;E=0;for(G=xb.length;E<G;E++){O=xb[E];D=Ab[O];yb&&(Ia=yb[O]);zb&&(Sa=zb[O]);O=D.vertexNormals;I=D.normal;Q=D.vertexColors;sa=D.color;W=D.vertexTangents;if(D instanceof THREE.Face3){if(ib){ea=nb[D.a].position;ca=nb[D.b].position;ja=nb[D.c].position;Za[Xa]=ea.x;Za[Xa+1]=ea.y;Za[Xa+2]=ea.z;Za[Xa+3]=ca.x;Za[Xa+4]=ca.y;Za[Xa+5]=ca.z;Za[Xa+6]=ja.x;Za[Xa+7]=ja.y;Za[Xa+8]=ja.z;Xa+=9}if(db)for(fb in db){P=
|
|
|
-db[fb];if(P.needsUpdate){V=P.offset;if(P.size===1){P.array[V+0]=P.value[D.a];P.array[V+1]=P.value[D.b];P.array[V+2]=P.value[D.c];P.offset+=3}else{ea=P.value[D.a];ca=P.value[D.b];ja=P.value[D.c];if(P.size===2){P.array[V+0]=ea.x;P.array[V+1]=ea.y;P.array[V+2]=ca.x;P.array[V+3]=ca.y;P.array[V+4]=ja.x;P.array[V+5]=ja.y;P.offset+=6}else if(P.size===3){P.array[V+0]=ea.x;P.array[V+1]=ea.y;P.array[V+2]=ea.z;P.array[V+3]=ca.x;P.array[V+4]=ca.y;P.array[V+5]=ca.z;P.array[V+6]=ja.x;P.array[V+7]=ja.y;P.array[V+
|
|
|
-8]=ja.z;P.offset+=9}else{P.array[V+0]=ea.x;P.array[V+1]=ea.y;P.array[V+2]=ea.z;P.array[V+3]=ea.w;P.array[V+4]=ca.x;P.array[V+5]=ca.y;P.array[V+6]=ca.z;P.array[V+7]=ca.w;P.array[V+8]=ja.x;P.array[V+9]=ja.y;P.array[V+10]=ja.z;P.array[V+11]=ja.w;P.offset+=12}}}}if(wb){V=0;for(P=jb.length;V<P;V++){ea=jb[V].vertices[D.a].position;ca=jb[V].vertices[D.b].position;ja=jb[V].vertices[D.c].position;Oa=Qa[V];Oa[Va+0]=ea.x;Oa[Va+1]=ea.y;Oa[Va+2]=ea.z;Oa[Va+3]=ca.x;Oa[Va+4]=ca.y;Oa[Va+5]=ca.z;Oa[Va+6]=ja.x;Oa[Va+
|
|
|
-7]=ja.y;Oa[Va+8]=ja.z}Va+=9}if(kb.length){ea=kb[D.a];ca=kb[D.b];ja=kb[D.c];K[R]=ea.x;K[R+1]=ea.y;K[R+2]=ea.z;K[R+3]=ea.w;K[R+4]=ca.x;K[R+5]=ca.y;K[R+6]=ca.z;K[R+7]=ca.w;K[R+8]=ja.x;K[R+9]=ja.y;K[R+10]=ja.z;K[R+11]=ja.w;ea=qb[D.a];ca=qb[D.b];ja=qb[D.c];ha[R]=ea.x;ha[R+1]=ea.y;ha[R+2]=ea.z;ha[R+3]=ea.w;ha[R+4]=ca.x;ha[R+5]=ca.y;ha[R+6]=ca.z;ha[R+7]=ca.w;ha[R+8]=ja.x;ha[R+9]=ja.y;ha[R+10]=ja.z;ha[R+11]=ja.w;ea=ob[D.a];ca=ob[D.b];ja=ob[D.c];va[R]=ea.x;va[R+1]=ea.y;va[R+2]=ea.z;va[R+3]=1;va[R+4]=ca.x;
|
|
|
-va[R+5]=ca.y;va[R+6]=ca.z;va[R+7]=1;va[R+8]=ja.x;va[R+9]=ja.y;va[R+10]=ja.z;va[R+11]=1;ea=pb[D.a];ca=pb[D.b];ja=pb[D.c];ua[R]=ea.x;ua[R+1]=ea.y;ua[R+2]=ea.z;ua[R+3]=1;ua[R+4]=ca.x;ua[R+5]=ca.y;ua[R+6]=ca.z;ua[R+7]=1;ua[R+8]=ja.x;ua[R+9]=ja.y;ua[R+10]=ja.z;ua[R+11]=1;R+=12}if(vb&&ra){if(Q.length==3&&ra==THREE.VertexColors){D=Q[0];ea=Q[1];ca=Q[2]}else ca=ea=D=sa;aa[Ma]=D.r;aa[Ma+1]=D.g;aa[Ma+2]=D.b;aa[Ma+3]=ea.r;aa[Ma+4]=ea.g;aa[Ma+5]=ea.b;aa[Ma+6]=ca.r;aa[Ma+7]=ca.g;aa[Ma+8]=ca.b;Ma+=9}if(ub&&Ta.hasTangents){Q=
|
|
|
-W[0];sa=W[1];D=W[2];fa[Ra]=Q.x;fa[Ra+1]=Q.y;fa[Ra+2]=Q.z;fa[Ra+3]=Q.w;fa[Ra+4]=sa.x;fa[Ra+5]=sa.y;fa[Ra+6]=sa.z;fa[Ra+7]=sa.w;fa[Ra+8]=D.x;fa[Ra+9]=D.y;fa[Ra+10]=D.z;fa[Ra+11]=D.w;Ra+=12}if(tb&&za)if(O.length==3&&lb)for(W=0;W<3;W++){I=O[W];ta[eb]=I.x;ta[eb+1]=I.y;ta[eb+2]=I.z;eb+=3}else for(W=0;W<3;W++){ta[eb]=I.x;ta[eb+1]=I.y;ta[eb+2]=I.z;eb+=3}if(rb&&Ia!==undefined&&Ba)for(W=0;W<3;W++){O=Ia[W];$a[gb]=O.u;$a[gb+1]=O.v;gb+=2}if(rb&&Sa!==undefined&&Ba)for(W=0;W<3;W++){O=Sa[W];T[hb]=O.u;T[hb+1]=O.v;
|
|
|
-hb+=2}if(sb){Wa[Ya]=Na;Wa[Ya+1]=Na+1;Wa[Ya+2]=Na+2;Ya+=3;bb[Ja]=Na;bb[Ja+1]=Na+1;bb[Ja+2]=Na;bb[Ja+3]=Na+2;bb[Ja+4]=Na+1;bb[Ja+5]=Na+2;Ja+=6;Na+=3}}else if(D instanceof THREE.Face4){if(ib){ea=nb[D.a].position;ca=nb[D.b].position;ja=nb[D.c].position;La=nb[D.d].position;Za[Xa]=ea.x;Za[Xa+1]=ea.y;Za[Xa+2]=ea.z;Za[Xa+3]=ca.x;Za[Xa+4]=ca.y;Za[Xa+5]=ca.z;Za[Xa+6]=ja.x;Za[Xa+7]=ja.y;Za[Xa+8]=ja.z;Za[Xa+9]=La.x;Za[Xa+10]=La.y;Za[Xa+11]=La.z;Xa+=12}if(db)for(fb in db){P=db[fb];if(P.needsUpdate){V=P.offset;
|
|
|
-if(P.size===1){P.array[V+0]=P.value[D.a];P.array[V+1]=P.value[D.b];P.array[V+2]=P.value[D.c];P.array[V+2]=P.value[D.d];P.offset+=4}else{ea=P.value[D.a];ca=P.value[D.b];ja=P.value[D.c];La=P.value[D.d];if(P.size===2){P.array[V+0]=ea.x;P.array[V+1]=ea.y;P.array[V+2]=ca.x;P.array[V+3]=ca.y;P.array[V+4]=ja.x;P.array[V+5]=ja.y;P.array[V+6]=La.x;P.array[V+7]=La.y;P.offset+=8}else if(P.size===3){P.array[V+0]=ea.x;P.array[V+1]=ea.y;P.array[V+2]=ea.z;P.array[V+3]=ca.x;P.array[V+4]=ca.y;P.array[V+5]=ca.z;P.array[V+
|
|
|
-6]=ja.x;P.array[V+7]=ja.y;P.array[V+8]=ja.z;P.array[V+9]=La.x;P.array[V+10]=La.y;P.array[V+11]=La.z;P.offset+=12}else{P.array[V+0]=ea.x;P.array[V+1]=ea.y;P.array[V+2]=ea.z;P.array[V+3]=ea.w;P.array[V+4]=ca.x;P.array[V+5]=ca.y;P.array[V+6]=ca.z;P.array[V+7]=ca.w;P.array[V+8]=ja.x;P.array[V+9]=ja.y;P.array[V+10]=ja.z;P.array[V+11]=ja.w;P.array[V+12]=La.x;P.array[V+13]=La.y;P.array[V+14]=La.z;P.array[V+15]=La.w;P.offset+=16}}}}if(wb){V=0;for(P=jb.length;V<P;V++){ea=jb[V].vertices[D.a].position;ca=jb[V].vertices[D.b].position;
|
|
|
-ja=jb[V].vertices[D.c].position;La=jb[V].vertices[D.d].position;Oa=Qa[V];Oa[Va+0]=ea.x;Oa[Va+1]=ea.y;Oa[Va+2]=ea.z;Oa[Va+3]=ca.x;Oa[Va+4]=ca.y;Oa[Va+5]=ca.z;Oa[Va+6]=ja.x;Oa[Va+7]=ja.y;Oa[Va+8]=ja.z;Oa[Va+9]=La.x;Oa[Va+10]=La.y;Oa[Va+11]=La.z}Va+=12}if(kb.length){ea=kb[D.a];ca=kb[D.b];ja=kb[D.c];La=kb[D.d];K[R]=ea.x;K[R+1]=ea.y;K[R+2]=ea.z;K[R+3]=ea.w;K[R+4]=ca.x;K[R+5]=ca.y;K[R+6]=ca.z;K[R+7]=ca.w;K[R+8]=ja.x;K[R+9]=ja.y;K[R+10]=ja.z;K[R+11]=ja.w;K[R+12]=La.x;K[R+13]=La.y;K[R+14]=La.z;K[R+15]=La.w;
|
|
|
-ea=qb[D.a];ca=qb[D.b];ja=qb[D.c];La=qb[D.d];ha[R]=ea.x;ha[R+1]=ea.y;ha[R+2]=ea.z;ha[R+3]=ea.w;ha[R+4]=ca.x;ha[R+5]=ca.y;ha[R+6]=ca.z;ha[R+7]=ca.w;ha[R+8]=ja.x;ha[R+9]=ja.y;ha[R+10]=ja.z;ha[R+11]=ja.w;ha[R+12]=La.x;ha[R+13]=La.y;ha[R+14]=La.z;ha[R+15]=La.w;ea=ob[D.a];ca=ob[D.b];ja=ob[D.c];La=ob[D.d];va[R]=ea.x;va[R+1]=ea.y;va[R+2]=ea.z;va[R+3]=1;va[R+4]=ca.x;va[R+5]=ca.y;va[R+6]=ca.z;va[R+7]=1;va[R+8]=ja.x;va[R+9]=ja.y;va[R+10]=ja.z;va[R+11]=1;va[R+12]=La.x;va[R+13]=La.y;va[R+14]=La.z;va[R+15]=1;ea=
|
|
|
-pb[D.a];ca=pb[D.b];ja=pb[D.c];D=pb[D.d];ua[R]=ea.x;ua[R+1]=ea.y;ua[R+2]=ea.z;ua[R+3]=1;ua[R+4]=ca.x;ua[R+5]=ca.y;ua[R+6]=ca.z;ua[R+7]=1;ua[R+8]=ja.x;ua[R+9]=ja.y;ua[R+10]=ja.z;ua[R+11]=1;ua[R+12]=D.x;ua[R+13]=D.y;ua[R+14]=D.z;ua[R+15]=1;R+=16}if(vb&&ra){if(Q.length==4&&ra==THREE.VertexColors){D=Q[0];ea=Q[1];ca=Q[2];Q=Q[3]}else Q=ca=ea=D=sa;aa[Ma]=D.r;aa[Ma+1]=D.g;aa[Ma+2]=D.b;aa[Ma+3]=ea.r;aa[Ma+4]=ea.g;aa[Ma+5]=ea.b;aa[Ma+6]=ca.r;aa[Ma+7]=ca.g;aa[Ma+8]=ca.b;aa[Ma+9]=Q.r;aa[Ma+10]=Q.g;aa[Ma+11]=Q.b;
|
|
|
-Ma+=12}if(ub&&Ta.hasTangents){Q=W[0];sa=W[1];D=W[2];W=W[3];fa[Ra]=Q.x;fa[Ra+1]=Q.y;fa[Ra+2]=Q.z;fa[Ra+3]=Q.w;fa[Ra+4]=sa.x;fa[Ra+5]=sa.y;fa[Ra+6]=sa.z;fa[Ra+7]=sa.w;fa[Ra+8]=D.x;fa[Ra+9]=D.y;fa[Ra+10]=D.z;fa[Ra+11]=D.w;fa[Ra+12]=W.x;fa[Ra+13]=W.y;fa[Ra+14]=W.z;fa[Ra+15]=W.w;Ra+=16}if(tb&&za)if(O.length==4&&lb)for(W=0;W<4;W++){I=O[W];ta[eb]=I.x;ta[eb+1]=I.y;ta[eb+2]=I.z;eb+=3}else for(W=0;W<4;W++){ta[eb]=I.x;ta[eb+1]=I.y;ta[eb+2]=I.z;eb+=3}if(rb&&Ia!==undefined&&Ba)for(W=0;W<4;W++){O=Ia[W];$a[gb]=
|
|
|
-O.u;$a[gb+1]=O.v;gb+=2}if(rb&&Sa!==undefined&&Ba)for(W=0;W<4;W++){O=Sa[W];T[hb]=O.u;T[hb+1]=O.v;hb+=2}if(sb){Wa[Ya]=Na;Wa[Ya+1]=Na+1;Wa[Ya+2]=Na+3;Wa[Ya+3]=Na+1;Wa[Ya+4]=Na+2;Wa[Ya+5]=Na+3;Ya+=6;bb[Ja]=Na;bb[Ja+1]=Na+1;bb[Ja+2]=Na;bb[Ja+3]=Na+3;bb[Ja+4]=Na+1;bb[Ja+5]=Na+2;bb[Ja+6]=Na+2;bb[Ja+7]=Na+3;Ja+=8;Na+=4}}}if(mb){E=0;for(G=mb.length;E<G;E++){Wa[Ya]=mb[E].a;Wa[Ya+1]=mb[E].b;Wa[Ya+2]=mb[E].c;Wa[Ya+3]=mb[E].a;Wa[Ya+4]=mb[E].c;Wa[Ya+5]=mb[E].d;Ya+=6}}if(ib){e.bindBuffer(e.ARRAY_BUFFER,t.__webglVertexBuffer);
|
|
|
-e.bufferData(e.ARRAY_BUFFER,Za,S)}if(db)for(fb in db){P=db[fb];if(P.needsUpdate){e.bindBuffer(e.ARRAY_BUFFER,P.buffer);e.bufferData(e.ARRAY_BUFFER,P.array,S);P.needsUpdate=!1}}if(wb){V=0;for(P=jb.length;V<P;V++){e.bindBuffer(e.ARRAY_BUFFER,t.__webglMorphTargetsBuffers[V]);e.bufferData(e.ARRAY_BUFFER,Qa[V],S)}}if(vb&&Ma>0){e.bindBuffer(e.ARRAY_BUFFER,t.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,aa,S)}if(tb){e.bindBuffer(e.ARRAY_BUFFER,t.__webglNormalBuffer);e.bufferData(e.ARRAY_BUFFER,ta,S)}if(ub&&
|
|
|
-Ta.hasTangents){e.bindBuffer(e.ARRAY_BUFFER,t.__webglTangentBuffer);e.bufferData(e.ARRAY_BUFFER,fa,S)}if(rb&&gb>0){e.bindBuffer(e.ARRAY_BUFFER,t.__webglUVBuffer);e.bufferData(e.ARRAY_BUFFER,$a,S)}if(rb&&hb>0){e.bindBuffer(e.ARRAY_BUFFER,t.__webglUV2Buffer);e.bufferData(e.ARRAY_BUFFER,T,S)}if(sb){e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,t.__webglFaceBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,Wa,S);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,t.__webglLineBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,bb,S)}if(R>0){e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
-t.__webglSkinVertexABuffer);e.bufferData(e.ARRAY_BUFFER,va,S);e.bindBuffer(e.ARRAY_BUFFER,t.__webglSkinVertexBBuffer);e.bufferData(e.ARRAY_BUFFER,ua,S);e.bindBuffer(e.ARRAY_BUFFER,t.__webglSkinIndicesBuffer);e.bufferData(e.ARRAY_BUFFER,ha,S);e.bindBuffer(e.ARRAY_BUFFER,t.__webglSkinWeightsBuffer);e.bufferData(e.ARRAY_BUFFER,K,S)}}}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;ra=m.vertices;t=m.colors;za=ra.length;S=t.length;Ia=m.__vertexArray;E=m.__colorArray;Sa=m.__dirtyColors;if(m.__dirtyVertices){for(G=0;G<za;G++){Ba=ra[G].position;w=G*3;Ia[w]=Ba.x;Ia[w+1]=Ba.y;Ia[w+2]=Ba.z}e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,Ia,A)}if(Sa){for(G=0;G<S;G++){color=t[G];w=G*3;E[w]=color.r;E[w+1]=color.g;E[w+2]=color.b}e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,
|
|
|
-E,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;ra=m.vertices;t=m.colors;za=ra.length;S=t.length;Ia=m.__vertexArray;E=m.__colorArray;Sa=m.__dirtyColors;if(m.__dirtyVertices){for(G=0;G<za;G++){Ba=ra[G].position;w=G*3;Ia[w]=Ba.x;Ia[w+1]=Ba.y;Ia[w+2]=Ba.z}e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,Ia,A)}if(Sa){for(G=0;G<S;G++){color=t[G];w=G*3;E[w]=color.r;E[w+1]=
|
|
|
-color.g;E[w+2]=color.b}e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,E,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 U(m){function A(sa){var W=[];x=0;for(t=sa.length;x<t;x++)sa[x]==undefined?W.push("undefined"):W.push(sa[x].id);return W.join("_")}var x,t,w,S,E,G,O,D,I={},Q=m.morphTargets!==
|
|
|
-undefined?m.morphTargets.length:0;m.geometryGroups={};w=0;for(S=m.faces.length;w<S;w++){E=m.faces[w];G=E.materials;O=A(G);I[O]==undefined&&(I[O]={hash:O,counter:0});D=I[O].hash+"_"+I[O].counter;m.geometryGroups[D]==undefined&&(m.geometryGroups[D]={faces:[],materials:G,vertices:0,numMorphTargets:Q});E=E instanceof THREE.Face3?3:4;if(m.geometryGroups[D].vertices+E>65535){I[O].counter+=1;D=I[O].hash+"_"+I[O].counter;m.geometryGroups[D]==undefined&&(m.geometryGroups[D]={faces:[],materials:G,vertices:0,
|
|
|
-numMorphTargets:Q})}m.geometryGroups[D].faces.push(w);m.geometryGroups[D].vertices+=E}}function z(m,A,x){m.push({buffer:A,object:x,opaque:{list:[],count:0},transparent:{list:[],count:0}})}function J(m){if(m!=ga){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)}ga=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,Z(A.wrapS));e.texParameteri(m,e.TEXTURE_WRAP_T,Z(A.wrapT));e.texParameteri(m,e.TEXTURE_MAG_FILTER,Z(A.magFilter));e.texParameteri(m,e.TEXTURE_MIN_FILTER,Z(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,xa(A.magFilter));e.texParameteri(m,e.TEXTURE_MIN_FILTER,xa(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 Fa(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,Z(m.wrapS));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,Z(m.wrapT));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,Z(m.magFilter));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,Z(m.minFilter));e.texImage2D(e.TEXTURE_2D,0,Z(m.format),m.width,m.height,0,Z(m.format),Z(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=ka;m=na}if(A!=Ha){e.bindFramebuffer(e.FRAMEBUFFER,A);e.viewport(la,Ga,x,m);Ha=A}}function oa(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 xa(m){switch(m){case THREE.NearestFilter:case THREE.NearestMipMapNearestFilter:case THREE.NearestMipMapLinearFilter:return e.NEAREST;default:return e.LINEAR}}function Z(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,da=document.createElement("canvas"),Ca=[],Aa=null,Ha=null,qa=!0,$=this,pa=null,Da=null,ga=null,Y=null,la=0,Ga=0,ka=0,na=0,wa=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],Ua=new THREE.Matrix4,cb=new Float32Array(16),ab=new Float32Array(16),Pa=new THREE.Vector4,
|
|
|
-N={ambient:[0,0,0],directional:{length:0,colors:[],positions:[]},point:{length:0,colors:[],positions:[],distances:[]}},X=!0,ma=!0,Ea=new THREE.Color(0),Ka=0;if(b){if(b.stencil!=undefined)X=b.stencil;if(b.antialias!==undefined)ma=b.antialias;b.clearColor!==undefined&&Ea.setHex(b.clearColor);if(b.clearAlpha!==undefined)Ka=b.clearAlpha}this.maxMorphTargets=8;this.domElement=da;this.autoClear=!0;this.sortObjects=!0;(function(m,A,x,t){try{if(!(e=da.getContext("experimental-webgl",{antialias:m,stencil:t})))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)})(ma,Ea,Ka,X);this.context=e;if(X){var ya={};ya.vertices=new Float32Array(12);ya.faces=new Uint16Array(6);ya.darkness=0.5;ya.vertices[0]=-2;ya.vertices[1]=-1;ya.vertices[2]=-1;ya.vertices[3]=2;ya.vertices[4]=-1;
|
|
|
-ya.vertices[5]=-1;ya.vertices[6]=2;ya.vertices[7]=1;ya.vertices[8]=-1;ya.vertices[9]=-2;ya.vertices[10]=1;ya.vertices[11]=-1;ya.faces[0]=0;ya.faces[1]=1;ya.faces[2]=2;ya.faces[3]=0;ya.faces[4]=2;ya.faces[5]=3;ya.vertexBuffer=e.createBuffer();ya.elementBuffer=e.createBuffer();e.bindBuffer(e.ARRAY_BUFFER,ya.vertexBuffer);e.bufferData(e.ARRAY_BUFFER,ya.vertices,e.STATIC_DRAW);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ya.elementBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,ya.faces,e.STATIC_DRAW);ya.program=
|
|
|
-e.createProgram();e.attachShader(ya.program,oa("fragment",THREE.ShaderLib.shadowPost.fragmentShader));e.attachShader(ya.program,oa("vertex",THREE.ShaderLib.shadowPost.vertexShader));e.linkProgram(ya.program);ya.vertexLocation=e.getAttribLocation(ya.program,"position");ya.projectionLocation=e.getUniformLocation(ya.program,"projectionMatrix");ya.darknessLocation=e.getUniformLocation(ya.program,"darkness")}var ia={};ia.vertices=new Float32Array(16);ia.faces=new Uint16Array(6);ia.transparency=0.5;b=0;
|
|
|
-ia.vertices[b++]=-1;ia.vertices[b++]=-1;ia.vertices[b++]=0;ia.vertices[b++]=0;ia.vertices[b++]=1;ia.vertices[b++]=-1;ia.vertices[b++]=1;ia.vertices[b++]=0;ia.vertices[b++]=1;ia.vertices[b++]=1;ia.vertices[b++]=1;ia.vertices[b++]=1;ia.vertices[b++]=-1;ia.vertices[b++]=1;ia.vertices[b++]=0;ia.vertices[b++]=1;b=0;ia.faces[b++]=0;ia.faces[b++]=1;ia.faces[b++]=2;ia.faces[b++]=0;ia.faces[b++]=2;ia.faces[b++]=3;ia.vertexBuffer=e.createBuffer();ia.elementBuffer=e.createBuffer();ia.tempTexture=e.createTexture();
|
|
|
-ia.readBackPixels=new Uint8Array(1024);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);e.bindTexture(e.TEXTURE_2D,ia.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);ia.program=e.createProgram();e.attachShader(ia.program,oa("fragment",THREE.ShaderLib.lensFlare.fragmentShader));e.attachShader(ia.program,oa("vertex",THREE.ShaderLib.lensFlare.vertexShader));e.linkProgram(ia.program);ia.attributes={};ia.uniforms={};ia.attributes.vertex=e.getAttribLocation(ia.program,"position");ia.attributes.uv=e.getAttribLocation(ia.program,"UV");ia.uniforms.map=e.getUniformLocation(ia.program,
|
|
|
-"map");ia.uniforms.opacity=e.getUniformLocation(ia.program,"opacity");ia.uniforms.scale=e.getUniformLocation(ia.program,"scale");ia.uniforms.rotation=e.getUniformLocation(ia.program,"rotation");ia.uniforms.screenPosition=e.getUniformLocation(ia.program,"screenPosition");ia.uniforms.renderPink=e.getUniformLocation(ia.program,"renderPink");this.setSize=function(m,A){da.width=m;da.height=A;this.setViewport(0,0,da.width,da.height)};this.setViewport=function(m,A,x,t){la=m;Ga=A;ka=x;na=t;e.viewport(la,
|
|
|
-Ga,ka,na)};this.setScissor=function(m,A,x,t){e.scissor(m,A,x,t)};this.enableScissorTest=function(m){m?e.enable(e.SCISSOR_TEST):e.disable(e.SCISSOR_TEST)};this.enableDepthBufferWrite=function(m){qa=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){ya.darkness=
|
|
|
-m};this.initMaterial=function(m,A,x,t){var w,S,E,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);var O,D,I,Q;G=I=Q=0;for(O=A.length;G<O;G++){D=A[G];D instanceof THREE.DirectionalLight&&I++;D instanceof THREE.PointLight&&Q++}if(Q+I<=4)A=I;else{A=Math.ceil(4*I/(Q+I));Q=4-A}G={directional:A,point:Q};O=50;if(t!==undefined&&t instanceof THREE.SkinnedMesh)O=t.bones.length;a:{Q=m.fragmentShader;A=m.vertexShader;x={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:O};G=Q+"\n\n"+A+"\n\n";for(E in x)G+=E+": "+x[E]+",\n";E=0;for(O=Ca.length;E<O;E++)if(Ca[E].code==G){E=Ca[E].program;break a}E=e.createProgram();prefix_fragment=["#ifdef GL_ES\nprecision highp float;\n#endif","#define MAX_DIR_LIGHTS "+x.maxDirLights,"#define MAX_POINT_LIGHTS "+x.maxPointLights,x.fog?"#define USE_FOG":"",x.fog instanceof
|
|
|
-THREE.FogExp2?"#define FOG_EXP2":"",x.map?"#define USE_MAP":"",x.envMap?"#define USE_ENVMAP":"",x.lightMap?"#define USE_LIGHTMAP":"",x.vertexColors?"#define USE_COLOR":"","uniform mat4 viewMatrix;\nuniform vec3 cameraPosition;\n"].join("\n");prefix_vertex=[e.getParameter(e.MAX_VERTEX_TEXTURE_IMAGE_UNITS)>0?"#define VERTEX_TEXTURES":"","#define MAX_DIR_LIGHTS "+x.maxDirLights,"#define MAX_POINT_LIGHTS "+x.maxPointLights,"#define MAX_BONES "+x.maxBones,x.map?"#define USE_MAP":"",x.envMap?"#define USE_ENVMAP":
|
|
|
-"",x.lightMap?"#define USE_LIGHTMAP":"",x.vertexColors?"#define USE_COLOR":"",x.skinning?"#define USE_SKINNING":"",x.morphTargets?"#define USE_MORPHTARGETS":"",x.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(E,oa("fragment",prefix_fragment+Q));e.attachShader(E,oa("vertex",prefix_vertex+A));e.linkProgram(E);e.getProgramParameter(E,e.LINK_STATUS)||console.error("Could not initialise shader\nVALIDATE_STATUS: "+e.getProgramParameter(E,e.VALIDATE_STATUS)+", gl error ["+e.getError()+"]");E.uniforms={};E.attributes={};Ca.push({program:E,code:G})}m.program=E;E=["viewMatrix","modelViewMatrix","projectionMatrix","normalMatrix","objectMatrix","cameraPosition","cameraInverseMatrix","boneGlobalMatrices",
|
|
|
-"morphTargetInfluences"];for(w in m.uniforms)E.push(w);w=m.program;x=0;for(Q=E.length;x<Q;x++){A=E[x];w.uniforms[A]=e.getUniformLocation(w,A)}E=["position","normal","uv","uv2","tangent","color","skinVertexA","skinVertexB","skinIndex","skinWeight"];for(w=0;w<this.maxMorphTargets;w++)E.push("morphTarget"+w);for(S in m.attributes)E.push(S);w=m.program;x=0;for(Q=E.length;x<Q;x++){A=E[x];w.attributes[A]=e.getAttribLocation(w,A)}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(S in m.attributes)w[S]>=0&&e.enableVertexAttribArray(w[S]);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++}t.__webglMorphTargetInfluences=new Float32Array(this.maxMorphTargets);w=0;for(m=this.maxMorphTargets;w<m;w++)t.__webglMorphTargetInfluences[w]=0}};this.render=function(m,A,x,t){var w,S,E,G,O,D,I,Q,sa=m.lights,W=m.fog;A.matrixAutoUpdate&&A.updateMatrix();m.update(undefined,!1,A);A.matrixWorldInverse.flattenToArray(ab);A.projectionMatrix.flattenToArray(cb);
|
|
|
-Ua.multiply(A.projectionMatrix,A.matrixWorldInverse);n(Ua);this.initWebGLObjects(m);Fa(x);(this.autoClear||t)&&this.clear();O=m.__webglObjects.length;for(t=0;t<O;t++){w=m.__webglObjects[t];I=w.object;if(I.visible)if(!(I instanceof THREE.Mesh)||p(I)){I.matrixWorld.flattenToArray(I._objectMatrixArray);F(I,A);y(w);w.render=!0;if(this.sortObjects){Pa.copy(I.position);Ua.multiplyVector3(Pa);w.z=Pa.z}}else w.render=!1;else w.render=!1}this.sortObjects&&m.__webglObjects.sort(v);D=m.__webglObjectsImmediate.length;
|
|
|
-for(t=0;t<D;t++){w=m.__webglObjectsImmediate[t];I=w.object;if(I.visible){I.matrixAutoUpdate&&I.matrixWorld.flattenToArray(I._objectMatrixArray);F(I,A);u(w)}}J(THREE.NormalBlending);for(t=0;t<O;t++){w=m.__webglObjects[t];if(w.render){I=w.object;Q=w.buffer;E=w.opaque;j(I);for(w=0;w<E.count;w++){G=E.list[w];k(G.depthTest);g(A,sa,W,G,Q,I)}}}for(t=0;t<D;t++){w=m.__webglObjectsImmediate[t];I=w.object;if(I.visible){E=w.opaque;j(I);for(w=0;w<E.count;w++){G=E.list[w];k(G.depthTest);S=f(A,sa,W,G,I);I.render(function(Ba){h(Ba,
|
|
|
-S)})}}}for(t=0;t<O;t++){w=m.__webglObjects[t];if(w.render){I=w.object;Q=w.buffer;E=w.transparent;j(I);for(w=0;w<E.count;w++){G=E.list[w];J(G.blending);k(G.depthTest);g(A,sa,W,G,Q,I)}}}for(t=0;t<D;t++){w=m.__webglObjectsImmediate[t];I=w.object;if(I.visible){E=w.transparent;j(I);for(w=0;w<E.count;w++){G=E.list[w];J(G.blending);k(G.depthTest);S=f(A,sa,W,G,I);I.render(function(Ba){h(Ba,S)})}}}X&&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,t=void 0,w=void 0,S=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&&U(w);for(t in w.geometryGroups){S=w.geometryGroups[t];if(!S.__webglVertexBuffer){var E=S;E.__webglVertexBuffer=e.createBuffer();E.__webglNormalBuffer=e.createBuffer();E.__webglTangentBuffer=e.createBuffer();E.__webglColorBuffer=e.createBuffer();E.__webglUVBuffer=e.createBuffer();E.__webglUV2Buffer=
|
|
|
-e.createBuffer();E.__webglSkinVertexABuffer=e.createBuffer();E.__webglSkinVertexBBuffer=e.createBuffer();E.__webglSkinIndicesBuffer=e.createBuffer();E.__webglSkinWeightsBuffer=e.createBuffer();E.__webglFaceBuffer=e.createBuffer();E.__webglLineBuffer=e.createBuffer();if(E.numMorphTargets){var G=void 0,O=void 0;E.__webglMorphTargetsBuffers=[];G=0;for(O=E.numMorphTargets;G<O;G++)E.__webglMorphTargetsBuffers.push(e.createBuffer())}E=S;G=A;var D=void 0,I=void 0,Q=void 0;Q=void 0;var sa=void 0,W=void 0,
|
|
|
-Ba=void 0,ra=Ba=O=0;I=void 0;Q=void 0;var za=void 0;D=void 0;I=void 0;sa=G.geometry;za=sa.faces;W=E.faces;D=0;for(I=W.length;D<I;D++){Q=W[D];Q=za[Q];if(Q instanceof THREE.Face3){O+=3;Ba+=1;ra+=3}else if(Q instanceof THREE.Face4){O+=4;Ba+=2;ra+=4}}D=E;I=G;za=void 0;W=void 0;var Ia=void 0,Sa=void 0;Ia=void 0;Q=[];za=0;for(W=I.materials.length;za<W;za++){Ia=I.materials[za];if(Ia instanceof THREE.MeshFaceMaterial){Ia=0;for(l=D.materials.length;Ia<l;Ia++)(Sa=D.materials[Ia])&&Q.push(Sa)}else(Sa=Ia)&&Q.push(Sa)}D=
|
|
|
-Q;a:{I=void 0;za=void 0;W=D.length;for(I=0;I<W;I++){za=D[I];if(za.map||za.lightMap||za instanceof THREE.MeshShaderMaterial){I=!0;break a}}I=!1}a:{za=D;W=void 0;Q=void 0;Ia=za.length;for(W=0;W<Ia;W++){Q=za[W];if(!(Q instanceof THREE.MeshBasicMaterial&&!Q.envMap||Q instanceof THREE.MeshDepthMaterial)){za=Q&&Q.shading!=undefined&&Q.shading==THREE.SmoothShading?THREE.SmoothShading:THREE.FlatShading;break a}}za=!1}a:{W=void 0;Q=void 0;Ia=D.length;for(W=0;W<Ia;W++){Q=D[W];if(Q.vertexColors){Q=Q.vertexColors;
|
|
|
-break a}}Q=!1}E.__vertexArray=new Float32Array(O*3);if(za)E.__normalArray=new Float32Array(O*3);if(sa.hasTangents)E.__tangentArray=new Float32Array(O*4);if(Q)E.__colorArray=new Float32Array(O*3);if(I){if(sa.faceUvs.length>0||sa.faceVertexUvs.length>0)E.__uvArray=new Float32Array(O*2);if(sa.faceUvs.length>1||sa.faceVertexUvs.length>1)E.__uv2Array=new Float32Array(O*2)}if(G.geometry.skinWeights.length&&G.geometry.skinIndices.length){E.__skinVertexAArray=new Float32Array(O*4);E.__skinVertexBArray=new Float32Array(O*
|
|
|
-4);E.__skinIndexArray=new Float32Array(O*4);E.__skinWeightArray=new Float32Array(O*4)}E.__faceArray=new Uint16Array(Ba*3+(G.geometry.edgeFaces?G.geometry.edgeFaces.length*6:0));E.__lineArray=new Uint16Array(ra*2);if(E.numMorphTargets){E.__morphTargetsArrays=[];sa=0;for(W=E.numMorphTargets;sa<W;sa++)E.__morphTargetsArrays.push(new Float32Array(O*3))}E.__needsSmoothNormals=za==THREE.SmoothShading;E.__uvType=I;E.__vertexColorType=Q;E.__normalType=za;E.__webglFaceCount=Ba*3+(G.geometry.edgeFaces?G.geometry.edgeFaces.length*
|
|
|
-6:0);E.__webglLineCount=ra*2;sa=0;for(W=D.length;sa<W;sa++)if(D[sa].attributes){E.__webglCustomAttributes={};for(a in D[sa].attributes){I=D[sa].attributes[a];Ba=1;if(I.type==="v2")Ba=2;else if(I.type==="v3")Ba=3;else if(I.type==="v4")Ba=4;else I.type==="c"&&(Ba=3);I.size=Ba;I.needsUpdate=!0;I.array=new Float32Array(O*Ba);I.buffer=e.createBuffer();E.__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,S,A):z(x.__webglObjects,S,A)}}else if(A instanceof THREE.LensFlare)z(x.__webglLensFlares,undefined,A);else if(A instanceof THREE.Ribbon){w=A.geometry;if(!w.__webglVertexBuffer){t=w;t.__webglVertexBuffer=e.createBuffer();t.__webglColorBuffer=e.createBuffer();t=w;S=t.vertices.length;t.__vertexArray=new Float32Array(S*3);t.__colorArray=new Float32Array(S*3);t.__webglVertexCount=S;w.__dirtyVertices=!0;w.__dirtyColors=!0}z(x.__webglObjects,
|
|
|
-w,A)}else if(A instanceof THREE.Line){w=A.geometry;if(!w.__webglVertexBuffer){t=w;t.__webglVertexBuffer=e.createBuffer();t.__webglColorBuffer=e.createBuffer();t=w;S=t.vertices.length;t.__vertexArray=new Float32Array(S*3);t.__colorArray=new Float32Array(S*3);t.__webglLineCount=S;w.__dirtyVertices=!0;w.__dirtyColors=!0}z(x.__webglObjects,w,A)}else if(A instanceof THREE.ParticleSystem){w=A.geometry;if(!w.__webglVertexBuffer){t=w;t.__webglVertexBuffer=e.createBuffer();t.__webglColorBuffer=e.createBuffer();
|
|
|
-t=w;S=t.vertices.length;t.__vertexArray=new Float32Array(S*3);t.__colorArray=new Float32Array(S*3);t.__sortArray=[];t.__webglParticleCount=S;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;t=void 0;for(w=x.__webglObjects.length-
|
|
|
-1;w>=0;w--){t=x.__webglObjects[w].object;A==t&&x.__webglObjects.splice(w,1)}m.__objectsRemoved.splice(0,1)}A=0;for(x=m.__webglObjects.length;A<x;A++)H(m.__webglObjects[A].object,m);A=0;for(x=m.__webglShadowVolumes.length;A<x;A++)H(m.__webglShadowVolumes[A].object,m);A=0;for(x=m.__webglLensFlares.length;A<x;A++)H(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):
|
|
|
+THREE.WebGLRenderer=function(b){function d(m,B,w){var u,A,M,G=m.vertices,I=G.length,F=m.colors,D=F.length,H=m.__vertexArray,K=m.__colorArray,X=m.__sortArray,T=m.__dirtyVertices,Ea=m.__dirtyColors;if(w.sortParticles){Ga.multiplySelf(w.matrixWorld);for(u=0;u<I;u++){A=G[u].position;Va.copy(A);Ga.multiplyVector3(Va);X[u]=[Va.z,u]}X.sort(function(Ja,ra){return ra[0]-Ja[0]});for(u=0;u<I;u++){A=G[X[u][1]].position;M=u*3;H[M]=A.x;H[M+1]=A.y;H[M+2]=A.z}for(u=0;u<D;u++){M=u*3;color=F[X[u][1]];K[M]=color.r;
|
|
|
+K[M+1]=color.g;K[M+2]=color.b}}else{if(T)for(u=0;u<I;u++){A=G[u].position;M=u*3;H[M]=A.x;H[M+1]=A.y;H[M+2]=A.z}if(Ea)for(u=0;u<D;u++){color=F[u];M=u*3;K[M]=color.r;K[M+1]=color.g;K[M+2]=color.b}}if(T||w.sortParticles){e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,H,B)}if(Ea||w.sortParticles){e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,K,B)}}function c(m,B,w,u,A){u.program||ua.initMaterial(u,B,w,A);var M=u.program,G=M.uniforms,I=u.uniforms;
|
|
|
+if(M!=Aa){e.useProgram(M);Aa=M}e.uniformMatrix4fv(G.projectionMatrix,!1,Ra);if(w&&(u instanceof THREE.MeshBasicMaterial||u instanceof THREE.MeshLambertMaterial||u instanceof THREE.MeshPhongMaterial||u instanceof THREE.LineBasicMaterial||u instanceof THREE.ParticleBasicMaterial||u.fog)){I.fogColor.value.setHex(w.color.hex);if(w instanceof THREE.Fog){I.fogNear.value=w.near;I.fogFar.value=w.far}else if(w instanceof THREE.FogExp2)I.fogDensity.value=w.density}if(u instanceof THREE.MeshPhongMaterial||u instanceof
|
|
|
+THREE.MeshLambertMaterial||u.lights){var F,D,H=0,K=0,X=0,T,Ea,Ja,ra,ya=Sa,bb=ya.directional.colors,Y=ya.directional.positions,da=ya.point.colors,na=ya.point.positions,La=ya.point.distances,Z=0,Q=0;w=D=ra=0;for(F=B.length;w<F;w++){D=B[w];T=D.color;Ea=D.position;Ja=D.intensity;ra=D.distance;if(D instanceof THREE.AmbientLight){H+=T.r;K+=T.g;X+=T.b}else if(D instanceof THREE.DirectionalLight){ra=Z*3;bb[ra]=T.r*Ja;bb[ra+1]=T.g*Ja;bb[ra+2]=T.b*Ja;Y[ra]=Ea.x;Y[ra+1]=Ea.y;Y[ra+2]=Ea.z;Z+=1}else if(D instanceof
|
|
|
+THREE.PointLight){D=Q*3;da[D]=T.r*Ja;da[D+1]=T.g*Ja;da[D+2]=T.b*Ja;na[D]=Ea.x;na[D+1]=Ea.y;na[D+2]=Ea.z;La[Q]=ra;Q+=1}}for(w=Z*3;w<bb.length;w++)bb[w]=0;for(w=Q*3;w<da.length;w++)da[w]=0;ya.point.length=Q;ya.directional.length=Z;ya.ambient[0]=H;ya.ambient[1]=K;ya.ambient[2]=X;w=Sa;I.enableLighting.value=w.directional.length+w.point.length;I.ambientLightColor.value=w.ambient;I.directionalLightColor.value=w.directional.colors;I.directionalLightDirection.value=w.directional.positions;I.pointLightColor.value=
|
|
|
+w.point.colors;I.pointLightPosition.value=w.point.positions;I.pointLightDistance.value=w.point.distances}if(u instanceof THREE.MeshBasicMaterial||u instanceof THREE.MeshLambertMaterial||u instanceof THREE.MeshPhongMaterial){I.diffuse.value.setRGB(u.color.r,u.color.g,u.color.b);I.opacity.value=u.opacity;I.map.texture=u.map;I.lightMap.texture=u.lightMap;I.envMap.texture=u.envMap;I.reflectivity.value=u.reflectivity;I.refractionRatio.value=u.refractionRatio;I.combine.value=u.combine;I.useRefract.value=
|
|
|
+u.envMap&&u.envMap.mapping instanceof THREE.CubeRefractionMapping}if(u instanceof THREE.LineBasicMaterial){I.diffuse.value.setRGB(u.color.r,u.color.g,u.color.b);I.opacity.value=u.opacity}else if(u instanceof THREE.ParticleBasicMaterial){I.psColor.value.setRGB(u.color.r,u.color.g,u.color.b);I.opacity.value=u.opacity;I.size.value=u.size;I.scale.value=fa.height/2;I.map.texture=u.map}else if(u instanceof THREE.MeshPhongMaterial){I.ambient.value.setRGB(u.ambient.r,u.ambient.g,u.ambient.b);I.specular.value.setRGB(u.specular.r,
|
|
|
+u.specular.g,u.specular.b);I.shininess.value=u.shininess}else if(u instanceof THREE.MeshDepthMaterial){I.mNear.value=m.near;I.mFar.value=m.far;I.opacity.value=u.opacity}else if(u instanceof THREE.MeshNormalMaterial)I.opacity.value=u.opacity;for(var Qa in I)if(K=M.uniforms[Qa]){F=I[Qa];H=F.type;w=F.value;if(H=="i")e.uniform1i(K,w);else if(H=="f")e.uniform1f(K,w);else if(H=="fv1")e.uniform1fv(K,w);else if(H=="fv")e.uniform3fv(K,w);else if(H=="v2")e.uniform2f(K,w.x,w.y);else if(H=="v3")e.uniform3f(K,
|
|
|
+w.x,w.y,w.z);else if(H=="v4")e.uniform4f(K,w.x,w.y,w.z,w.w);else if(H=="c")e.uniform3f(K,w.r,w.g,w.b);else if(H=="t"){e.uniform1i(K,w);if(F=F.texture)if(F.image instanceof Array&&F.image.length==6){if(F.image.length==6){if(F.needsUpdate){if(F.__webglInit){e.bindTexture(e.TEXTURE_CUBE_MAP,F.image.__webglTextureCube);for(H=0;H<6;++H)e.texSubImage2D(e.TEXTURE_CUBE_MAP_POSITIVE_X+H,0,0,0,e.RGBA,e.UNSIGNED_BYTE,F.image[H])}else{F.image.__webglTextureCube=e.createTexture();e.bindTexture(e.TEXTURE_CUBE_MAP,
|
|
|
+F.image.__webglTextureCube);for(H=0;H<6;++H)e.texImage2D(e.TEXTURE_CUBE_MAP_POSITIVE_X+H,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,F.image[H]);F.__webglInit=!0}L(e.TEXTURE_CUBE_MAP,F,F.image[0]);e.bindTexture(e.TEXTURE_CUBE_MAP,null);F.needsUpdate=!1}e.activeTexture(e.TEXTURE0+w);e.bindTexture(e.TEXTURE_CUBE_MAP,F.image.__webglTextureCube)}}else N(F,w)}}e.uniformMatrix4fv(G.modelViewMatrix,!1,A._modelViewMatrixArray);e.uniformMatrix3fv(G.normalMatrix,!1,A._normalMatrixArray);(u instanceof THREE.MeshShaderMaterial||
|
|
|
+u instanceof THREE.MeshPhongMaterial||u.envMap)&&e.uniform3f(G.cameraPosition,m.position.x,m.position.y,m.position.z);(u instanceof THREE.MeshShaderMaterial||u.envMap||u.skinning)&&e.uniformMatrix4fv(G.objectMatrix,!1,A._objectMatrixArray);(u instanceof THREE.MeshPhongMaterial||u instanceof THREE.MeshLambertMaterial||u instanceof THREE.MeshShaderMaterial||u.skinning)&&e.uniformMatrix4fv(G.viewMatrix,!1,Za);if(u instanceof THREE.ShadowVolumeDynamicMaterial){m=I.directionalLightDirection.value;m[0]=
|
|
|
+-B.position.x;m[1]=-B.position.y;m[2]=-B.position.z;e.uniform3fv(G.directionalLightDirection,m);e.uniformMatrix4fv(G.objectMatrix,!1,A._objectMatrixArray);e.uniformMatrix4fv(G.viewMatrix,!1,Za)}if(u.skinning){e.uniformMatrix4fv(G.cameraInverseMatrix,!1,Za);e.uniformMatrix4fv(G.boneGlobalMatrices,!1,A.boneMatrices)}return M}function f(m,B,w,u,A,M){if(u.opacity!=0){var G;m=c(m,B,w,u,M).attributes;if(u.morphTargets){B=u.program.attributes;M.morphTargetBase!==-1?e.bindBuffer(e.ARRAY_BUFFER,A.__webglMorphTargetsBuffers[M.morphTargetBase]):
|
|
|
+e.bindBuffer(e.ARRAY_BUFFER,A.__webglVertexBuffer);e.vertexAttribPointer(B.position,3,e.FLOAT,!1,0,0);if(M.morphTargetForcedOrder.length){w=0;for(var I=M.morphTargetForcedOrder,F=M.morphTargetInfluences;w<u.numSupportedMorphTargets&&w<I.length;){e.bindBuffer(e.ARRAY_BUFFER,A.__webglMorphTargetsBuffers[I[w]]);e.vertexAttribPointer(B["morphTarget"+w],3,e.FLOAT,!1,0,0);M.__webglMorphTargetInfluences[w]=F[I[w]];w++}}else{I=[];var D=-1,H=0;F=M.morphTargetInfluences;var K,X=F.length;w=0;for(M.morphTargetBase!==
|
|
|
+-1&&(I[M.morphTargetBase]=!0);w<u.numSupportedMorphTargets;){for(K=0;K<X;K++)if(!I[K]&&F[K]>D){H=K;D=F[H]}e.bindBuffer(e.ARRAY_BUFFER,A.__webglMorphTargetsBuffers[H]);e.vertexAttribPointer(B["morphTarget"+w],3,e.FLOAT,!1,0,0);M.__webglMorphTargetInfluences[w]=D;I[H]=1;D=-1;w++}}e.uniform1fv(u.program.uniforms.morphTargetInfluences,M.__webglMorphTargetInfluences)}else{e.bindBuffer(e.ARRAY_BUFFER,A.__webglVertexBuffer);e.vertexAttribPointer(m.position,3,e.FLOAT,!1,0,0)}if(A.__webglCustomAttributes)for(G in A.__webglCustomAttributes)if(m[G]>=
|
|
|
+0){B=A.__webglCustomAttributes[G];e.bindBuffer(e.ARRAY_BUFFER,B.buffer);e.vertexAttribPointer(m[G],B.size,e.FLOAT,!1,0,0)}if(m.color>=0){e.bindBuffer(e.ARRAY_BUFFER,A.__webglColorBuffer);e.vertexAttribPointer(m.color,3,e.FLOAT,!1,0,0)}if(m.normal>=0){e.bindBuffer(e.ARRAY_BUFFER,A.__webglNormalBuffer);e.vertexAttribPointer(m.normal,3,e.FLOAT,!1,0,0)}if(m.tangent>=0){e.bindBuffer(e.ARRAY_BUFFER,A.__webglTangentBuffer);e.vertexAttribPointer(m.tangent,4,e.FLOAT,!1,0,0)}if(m.uv>=0)if(A.__webglUVBuffer){e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
+A.__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(A.__webglUV2Buffer){e.bindBuffer(e.ARRAY_BUFFER,A.__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,A.__webglSkinVertexABuffer);e.vertexAttribPointer(m.skinVertexA,
|
|
|
+4,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,A.__webglSkinVertexBBuffer);e.vertexAttribPointer(m.skinVertexB,4,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,A.__webglSkinIndicesBuffer);e.vertexAttribPointer(m.skinIndex,4,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,A.__webglSkinWeightsBuffer);e.vertexAttribPointer(m.skinWeight,4,e.FLOAT,!1,0,0)}if(M instanceof THREE.Mesh)if(u.wireframe){e.lineWidth(u.wireframeLinewidth);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,A.__webglLineBuffer);e.drawElements(e.LINES,
|
|
|
+A.__webglLineCount,e.UNSIGNED_SHORT,0)}else{e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,A.__webglFaceBuffer);e.drawElements(e.TRIANGLES,A.__webglFaceCount,e.UNSIGNED_SHORT,0)}else if(M instanceof THREE.Line){M=M.type==THREE.LineStrip?e.LINE_STRIP:e.LINES;e.lineWidth(u.linewidth);e.drawArrays(M,0,A.__webglLineCount)}else if(M instanceof THREE.ParticleSystem)e.drawArrays(e.POINTS,0,A.__webglParticleCount);else M instanceof THREE.Ribbon&&e.drawArrays(e.TRIANGLE_STRIP,0,A.__webglVertexCount)}}function g(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 h(m){if(ca!=m.doubleSided){m.doubleSided?e.disable(e.CULL_FACE):e.enable(e.CULL_FACE);ca=m.doubleSided}if(sa!=m.flipSided){m.flipSided?e.frontFace(e.CW):e.frontFace(e.CCW);sa=m.flipSided}}function j(m){if(ja!=m){m?e.enable(e.DEPTH_TEST):e.disable(e.DEPTH_TEST);ja=m}}function k(m){oa[0].set(m.n41-m.n11,m.n42-m.n12,m.n43-m.n13,m.n44-m.n14);oa[1].set(m.n41+m.n11,m.n42+m.n12,m.n43+m.n13,m.n44+m.n14);oa[2].set(m.n41+m.n21,m.n42+m.n22,
|
|
|
+m.n43+m.n23,m.n44+m.n24);oa[3].set(m.n41-m.n21,m.n42-m.n22,m.n43-m.n23,m.n44-m.n24);oa[4].set(m.n41-m.n31,m.n42-m.n32,m.n43-m.n33,m.n44-m.n34);oa[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=oa[m];B.divideScalar(Math.sqrt(B.x*B.x+B.y*B.y+B.z*B.z))}}function n(m){for(var B=m.matrixWorld,w=-m.geometry.boundingSphere.radius*Math.max(m.scale.x,Math.max(m.scale.y,m.scale.z)),u=0;u<6;u++){m=oa[u].x*B.n14+oa[u].y*B.n24+oa[u].z*B.n34+oa[u].w;if(m<=w)return!1}return!0}function p(m,
|
|
|
+B){m.list[m.count]=B;m.count+=1}function o(m){var B,w,u=m.object,A=m.opaque,M=m.transparent;M.count=0;m=A.count=0;for(B=u.materials.length;m<B;m++){w=u.materials[m];w.transparent?p(M,w):p(A,w)}}function t(m){var B,w,u,A,M=m.object,G=m.buffer,I=m.opaque,F=m.transparent;F.count=0;m=I.count=0;for(u=M.materials.length;m<u;m++){B=M.materials[m];if(B instanceof THREE.MeshFaceMaterial){B=0;for(w=G.materials.length;B<w;B++)(A=G.materials[B])&&(A.transparent?p(F,A):p(I,A))}else(A=B)&&(A.transparent?p(F,A):
|
|
|
+p(I,A))}}function x(m,B){return B.z-m.z}function v(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,w=m.lights.length,u,A=m.lights,M=[],G,I,F,D,H,K=m.__webglShadowVolumes.length;for(B=0;B<w;B++){u=m.lights[B];if(u instanceof THREE.DirectionalLight){M[0]=-u.position.x;M[1]=-u.position.y;M[2]=
|
|
|
+-u.position.z;for(H=0;H<K;H++){u=m.__webglShadowVolumes[H].object;G=m.__webglShadowVolumes[H].buffer;I=u.materials[0];I.program||ua.initMaterial(I,A,undefined,u);I=I.program;F=I.uniforms;D=I.attributes;if(Aa!==I){e.useProgram(I);Aa=I;e.uniformMatrix4fv(F.projectionMatrix,!1,Ra);e.uniformMatrix4fv(F.viewMatrix,!1,Za);e.uniform3fv(F.directionalLightDirection,M)}u.matrixWorld.flattenToArray(u._objectMatrixArray);e.uniformMatrix4fv(F.objectMatrix,!1,u._objectMatrixArray);e.bindBuffer(e.ARRAY_BUFFER,G.__webglVertexBuffer);
|
|
|
+e.vertexAttribPointer(D.position,3,e.FLOAT,!1,0,0);e.bindBuffer(e.ARRAY_BUFFER,G.__webglNormalBuffer);e.vertexAttribPointer(D.normal,3,e.FLOAT,!1,0,0);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,G.__webglFaceBuffer);e.cullFace(e.FRONT);e.drawElements(e.TRIANGLES,G.__webglFaceCount,e.UNSIGNED_SHORT,0);e.cullFace(e.BACK);e.drawElements(e.TRIANGLES,G.__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);Ba="";Aa=ha.program;e.useProgram(ha.program);e.uniformMatrix4fv(ha.projectionLocation,!1,Ra);e.uniform1f(ha.darknessLocation,ha.darkness);e.bindBuffer(e.ARRAY_BUFFER,ha.vertexBuffer);e.vertexAttribPointer(ha.vertexLocation,3,e.FLOAT,!1,0,0);e.enableVertexAttribArray(ha.vertexLocation);e.blendFunc(e.ONE,e.ONE_MINUS_SRC_ALPHA);e.blendEquation(e.FUNC_ADD);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ha.elementBuffer);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0);e.disable(e.STENCIL_TEST);
|
|
|
+e.enable(e.DEPTH_TEST);e.depthMask(Ia)}function z(m,B){var w,u,A,M=m.__webglLensFlares.length,G,I,F;G=new THREE.Vector3;var D=ka/Fa;I=Fa*0.5;F=ka*0.5;var H=16/ka,K=[H*D,H],X=[1,1,0];H=[1,1];var T,Ea=la.readBackPixels,Ja,ra,ya=la.uniforms;w=la.attributes;e.useProgram(la.program);Aa=la.program;Ba="";e.uniform1i(ya.map,0);e.activeTexture(e.TEXTURE0);e.uniform1f(ya.opacity,1);e.uniform1f(ya.rotation,0);e.uniform2fv(ya.scale,K);e.bindBuffer(e.ARRAY_BUFFER,la.vertexBuffer);e.vertexAttribPointer(w.vertex,
|
|
|
+2,e.FLOAT,!1,16,0);e.vertexAttribPointer(w.uv,2,e.FLOAT,!1,16,8);e.bindTexture(e.TEXTURE_2D,la.tempTexture);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,la.elementBuffer);e.disable(e.CULL_FACE);e.depthMask(!1);for(A=0;A<M;A++){w=m.__webglLensFlares[A].object;G.set(w.matrixWorld.n14,w.matrixWorld.n24,w.matrixWorld.n34);B.matrixWorldInverse.multiplyVector3(G);u=G.z;B.projectionMatrix.multiplyVector3(G);X[0]=G.x;X[1]=G.y;X[2]=G.z;H[0]=X[0]*I+I;H[1]=X[1]*F+F;e.copyTexSubImage2D(e.TEXTURE_2D,0,0,0,H[0]-8,H[1]-
|
|
|
+8,16,16);e.uniform3fv(ya.screenPosition,X);e.uniform1i(ya.renderPink,1);e.enable(e.DEPTH_TEST);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0);try{e.readPixels(H[0]-8,H[1]-8,16,16,e.RGBA,e.UNSIGNED_BYTE,la.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,B.far))/B.far),10)+2;u=sampleDistance*4;T=sampleDistance*64;ra=0;Ja=28-u+
|
|
|
+(448-T);la.readBackPixels[Ja+0]===255&&la.readBackPixels[Ja+1]===0&&la.readBackPixels[Ja+2]===255&&(ra+=0.2);Ja=28+u+(448-T);Ea[Ja+0]===255&&Ea[Ja+1]===0&&Ea[Ja+2]===255&&(ra+=0.2);Ja=28+u+(448+T);Ea[Ja+0]===255&&Ea[Ja+1]===0&&Ea[Ja+2]===255&&(ra+=0.2);Ja=28-u+(448+T);Ea[Ja+0]===255&&Ea[Ja+1]===0&&Ea[Ja+2]===255&&(ra+=0.2);Ja=476;Ea[Ja+0]===255&&Ea[Ja+1]===0&&Ea[Ja+2]===255&&(ra+=0.2);w.positionScreen.x=X[0];w.positionScreen.y=X[1];w.positionScreen.z=X[2];w.customUpdateCallback?w.customUpdateCallback(ra,
|
|
|
+w):w.updateLensFlares(ra);e.uniform1i(ya.renderPink,0);e.disable(e.DEPTH_TEST);e.drawElements(e.TRIANGLES,6,e.UNSIGNED_SHORT,0)}for(A=0;A<M;A++){w=m.__webglLensFlares[A].object;G=0;for(I=w.lensFlares.length;G<I;G++){F=w.lensFlares[G];if(F.opacity>0.0010&&F.scale>0.0010){X[0]=F.x;X[1]=F.y;X[2]=F.z;H=F.size*F.scale/ka;K[0]=H*D;K[1]=H;e.uniform3fv(ya.screenPosition,X);e.uniform1f(ya.rotation,F.rotation);e.uniform2fv(ya.scale,K);e.uniform1f(ya.opacity,F.opacity);y(F.blending);N(F.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 C(m,B){m._modelViewMatrix.multiplyToArray(B.matrixWorldInverse,m.matrixWorld,m._modelViewMatrixArray);THREE.Matrix4.makeInvert3x3(m._modelViewMatrix).transposeIntoArray(m._normalMatrixArray)}function E(m){var B,w,u,A,M;if(m instanceof THREE.Mesh){w=m.geometry;for(B in w.geometryGroups){u=w.geometryGroups[B];M=!1;for(A in u.__webglCustomAttributes)if(u.__webglCustomAttributes[A].needsUpdate){M=!0;break}if(w.__dirtyVertices||
|
|
|
+w.__dirtyMorphTargets||w.__dirtyElements||w.__dirtyUvs||w.__dirtyNormals||w.__dirtyColors||w.__dirtyTangents||M){M=e.DYNAMIC_DRAW;var G=void 0,I=void 0,F=void 0,D=void 0;F=void 0;var H=void 0,K=void 0,X=void 0,T=void 0,Ea=void 0,Ja=void 0,ra=void 0,ya=void 0,bb=void 0,Y=void 0,da=void 0,na=void 0,La=void 0;K=void 0;X=void 0;D=void 0;T=void 0;D=void 0;Y=void 0;da=void 0;K=void 0;Y=void 0;da=void 0;na=void 0;La=void 0;Y=void 0;da=void 0;na=void 0;La=void 0;Y=void 0;da=void 0;na=void 0;La=void 0;Y=void 0;
|
|
|
+da=void 0;na=void 0;D=void 0;T=void 0;H=void 0;F=void 0;F=void 0;var Z=void 0,Q=void 0,Qa=void 0,db=void 0,Na=0,Oa=0,hb=0,eb=0,$a=0,ab=0,Ma=0,cb=0,Ca=0,R=0,Pa=0;Z=0;var Ta=u.__vertexArray,jb=u.__uvArray,Ya=u.__uv2Array,S=u.__normalArray,ia=u.__tangentArray,ma=u.__colorArray,W=u.__skinVertexAArray,xa=u.__skinVertexBArray,wa=u.__skinIndexArray,ga=u.__skinWeightArray,V=u.__morphTargetsArrays,Ka=u.__webglCustomAttributes;Q=void 0;var Wa=u.__faceArray,Ua=u.__lineArray,ib=u.__needsSmoothNormals;Ja=u.__vertexColorType;
|
|
|
+Ea=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;G=0;for(I=wb.length;G<I;G++){F=wb[G];D=zb[F];xb&&(ya=xb[F]);yb&&(bb=yb[F]);
|
|
|
+F=D.vertexNormals;H=D.normal;K=D.vertexColors;X=D.color;T=D.vertexTangents;if(D instanceof THREE.Face3){if(fb){Y=nb[D.a].position;da=nb[D.b].position;na=nb[D.c].position;Ta[Oa]=Y.x;Ta[Oa+1]=Y.y;Ta[Oa+2]=Y.z;Ta[Oa+3]=da.x;Ta[Oa+4]=da.y;Ta[Oa+5]=da.z;Ta[Oa+6]=na.x;Ta[Oa+7]=na.y;Ta[Oa+8]=na.z;Oa+=9}if(Ka)for(db in Ka){Q=Ka[db];if(Q.needsUpdate){Z=Q.offset;if(Q.size===1){Q.array[Z+0]=Q.value[D.a];Q.array[Z+1]=Q.value[D.b];Q.array[Z+2]=Q.value[D.c];Q.offset+=3}else{Y=Q.value[D.a];da=Q.value[D.b];na=Q.value[D.c];
|
|
|
+if(Q.size===2){Q.array[Z+0]=Y.x;Q.array[Z+1]=Y.y;Q.array[Z+2]=da.x;Q.array[Z+3]=da.y;Q.array[Z+4]=na.x;Q.array[Z+5]=na.y;Q.offset+=6}else if(Q.size===3){Q.array[Z+0]=Y.x;Q.array[Z+1]=Y.y;Q.array[Z+2]=Y.z;Q.array[Z+3]=da.x;Q.array[Z+4]=da.y;Q.array[Z+5]=da.z;Q.array[Z+6]=na.x;Q.array[Z+7]=na.y;Q.array[Z+8]=na.z;Q.offset+=9}else{Q.array[Z+0]=Y.x;Q.array[Z+1]=Y.y;Q.array[Z+2]=Y.z;Q.array[Z+3]=Y.w;Q.array[Z+4]=da.x;Q.array[Z+5]=da.y;Q.array[Z+6]=da.z;Q.array[Z+7]=da.w;Q.array[Z+8]=na.x;Q.array[Z+9]=na.y;
|
|
|
+Q.array[Z+10]=na.z;Q.array[Z+11]=na.w;Q.offset+=12}}}}if(vb){Z=0;for(Q=kb.length;Z<Q;Z++){Y=kb[Z].vertices[D.a].position;da=kb[Z].vertices[D.b].position;na=kb[Z].vertices[D.c].position;Qa=V[Z];Qa[Pa+0]=Y.x;Qa[Pa+1]=Y.y;Qa[Pa+2]=Y.z;Qa[Pa+3]=da.x;Qa[Pa+4]=da.y;Qa[Pa+5]=da.z;Qa[Pa+6]=na.x;Qa[Pa+7]=na.y;Qa[Pa+8]=na.z}Pa+=9}if(lb.length){Y=lb[D.a];da=lb[D.b];na=lb[D.c];ga[R]=Y.x;ga[R+1]=Y.y;ga[R+2]=Y.z;ga[R+3]=Y.w;ga[R+4]=da.x;ga[R+5]=da.y;ga[R+6]=da.z;ga[R+7]=da.w;ga[R+8]=na.x;ga[R+9]=na.y;ga[R+10]=
|
|
|
+na.z;ga[R+11]=na.w;Y=qb[D.a];da=qb[D.b];na=qb[D.c];wa[R]=Y.x;wa[R+1]=Y.y;wa[R+2]=Y.z;wa[R+3]=Y.w;wa[R+4]=da.x;wa[R+5]=da.y;wa[R+6]=da.z;wa[R+7]=da.w;wa[R+8]=na.x;wa[R+9]=na.y;wa[R+10]=na.z;wa[R+11]=na.w;Y=ob[D.a];da=ob[D.b];na=ob[D.c];W[R]=Y.x;W[R+1]=Y.y;W[R+2]=Y.z;W[R+3]=1;W[R+4]=da.x;W[R+5]=da.y;W[R+6]=da.z;W[R+7]=1;W[R+8]=na.x;W[R+9]=na.y;W[R+10]=na.z;W[R+11]=1;Y=pb[D.a];da=pb[D.b];na=pb[D.c];xa[R]=Y.x;xa[R+1]=Y.y;xa[R+2]=Y.z;xa[R+3]=1;xa[R+4]=da.x;xa[R+5]=da.y;xa[R+6]=da.z;xa[R+7]=1;xa[R+8]=na.x;
|
|
|
+xa[R+9]=na.y;xa[R+10]=na.z;xa[R+11]=1;R+=12}if(ub&&Ja){if(K.length==3&&Ja==THREE.VertexColors){D=K[0];Y=K[1];da=K[2]}else da=Y=D=X;ma[Ca]=D.r;ma[Ca+1]=D.g;ma[Ca+2]=D.b;ma[Ca+3]=Y.r;ma[Ca+4]=Y.g;ma[Ca+5]=Y.b;ma[Ca+6]=da.r;ma[Ca+7]=da.g;ma[Ca+8]=da.b;Ca+=9}if(tb&&Xa.hasTangents){K=T[0];X=T[1];D=T[2];ia[Ma]=K.x;ia[Ma+1]=K.y;ia[Ma+2]=K.z;ia[Ma+3]=K.w;ia[Ma+4]=X.x;ia[Ma+5]=X.y;ia[Ma+6]=X.z;ia[Ma+7]=X.w;ia[Ma+8]=D.x;ia[Ma+9]=D.y;ia[Ma+10]=D.z;ia[Ma+11]=D.w;Ma+=12}if(sb&&ra)if(F.length==3&&ib)for(T=0;T<
|
|
|
+3;T++){H=F[T];S[ab]=H.x;S[ab+1]=H.y;S[ab+2]=H.z;ab+=3}else for(T=0;T<3;T++){S[ab]=H.x;S[ab+1]=H.y;S[ab+2]=H.z;ab+=3}if(rb&&ya!==undefined&&Ea)for(T=0;T<3;T++){F=ya[T];jb[hb]=F.u;jb[hb+1]=F.v;hb+=2}if(rb&&bb!==undefined&&Ea)for(T=0;T<3;T++){F=bb[T];Ya[eb]=F.u;Ya[eb+1]=F.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){Y=nb[D.a].position;da=nb[D.b].position;na=
|
|
|
+nb[D.c].position;La=nb[D.d].position;Ta[Oa]=Y.x;Ta[Oa+1]=Y.y;Ta[Oa+2]=Y.z;Ta[Oa+3]=da.x;Ta[Oa+4]=da.y;Ta[Oa+5]=da.z;Ta[Oa+6]=na.x;Ta[Oa+7]=na.y;Ta[Oa+8]=na.z;Ta[Oa+9]=La.x;Ta[Oa+10]=La.y;Ta[Oa+11]=La.z;Oa+=12}if(Ka)for(db in Ka){Q=Ka[db];if(Q.needsUpdate){Z=Q.offset;if(Q.size===1){Q.array[Z+0]=Q.value[D.a];Q.array[Z+1]=Q.value[D.b];Q.array[Z+2]=Q.value[D.c];Q.array[Z+2]=Q.value[D.d];Q.offset+=4}else{Y=Q.value[D.a];da=Q.value[D.b];na=Q.value[D.c];La=Q.value[D.d];if(Q.size===2){Q.array[Z+0]=Y.x;Q.array[Z+
|
|
|
+1]=Y.y;Q.array[Z+2]=da.x;Q.array[Z+3]=da.y;Q.array[Z+4]=na.x;Q.array[Z+5]=na.y;Q.array[Z+6]=La.x;Q.array[Z+7]=La.y;Q.offset+=8}else if(Q.size===3){Q.array[Z+0]=Y.x;Q.array[Z+1]=Y.y;Q.array[Z+2]=Y.z;Q.array[Z+3]=da.x;Q.array[Z+4]=da.y;Q.array[Z+5]=da.z;Q.array[Z+6]=na.x;Q.array[Z+7]=na.y;Q.array[Z+8]=na.z;Q.array[Z+9]=La.x;Q.array[Z+10]=La.y;Q.array[Z+11]=La.z;Q.offset+=12}else{Q.array[Z+0]=Y.x;Q.array[Z+1]=Y.y;Q.array[Z+2]=Y.z;Q.array[Z+3]=Y.w;Q.array[Z+4]=da.x;Q.array[Z+5]=da.y;Q.array[Z+6]=da.z;
|
|
|
+Q.array[Z+7]=da.w;Q.array[Z+8]=na.x;Q.array[Z+9]=na.y;Q.array[Z+10]=na.z;Q.array[Z+11]=na.w;Q.array[Z+12]=La.x;Q.array[Z+13]=La.y;Q.array[Z+14]=La.z;Q.array[Z+15]=La.w;Q.offset+=16}}}}if(vb){Z=0;for(Q=kb.length;Z<Q;Z++){Y=kb[Z].vertices[D.a].position;da=kb[Z].vertices[D.b].position;na=kb[Z].vertices[D.c].position;La=kb[Z].vertices[D.d].position;Qa=V[Z];Qa[Pa+0]=Y.x;Qa[Pa+1]=Y.y;Qa[Pa+2]=Y.z;Qa[Pa+3]=da.x;Qa[Pa+4]=da.y;Qa[Pa+5]=da.z;Qa[Pa+6]=na.x;Qa[Pa+7]=na.y;Qa[Pa+8]=na.z;Qa[Pa+9]=La.x;Qa[Pa+10]=
|
|
|
+La.y;Qa[Pa+11]=La.z}Pa+=12}if(lb.length){Y=lb[D.a];da=lb[D.b];na=lb[D.c];La=lb[D.d];ga[R]=Y.x;ga[R+1]=Y.y;ga[R+2]=Y.z;ga[R+3]=Y.w;ga[R+4]=da.x;ga[R+5]=da.y;ga[R+6]=da.z;ga[R+7]=da.w;ga[R+8]=na.x;ga[R+9]=na.y;ga[R+10]=na.z;ga[R+11]=na.w;ga[R+12]=La.x;ga[R+13]=La.y;ga[R+14]=La.z;ga[R+15]=La.w;Y=qb[D.a];da=qb[D.b];na=qb[D.c];La=qb[D.d];wa[R]=Y.x;wa[R+1]=Y.y;wa[R+2]=Y.z;wa[R+3]=Y.w;wa[R+4]=da.x;wa[R+5]=da.y;wa[R+6]=da.z;wa[R+7]=da.w;wa[R+8]=na.x;wa[R+9]=na.y;wa[R+10]=na.z;wa[R+11]=na.w;wa[R+12]=La.x;
|
|
|
+wa[R+13]=La.y;wa[R+14]=La.z;wa[R+15]=La.w;Y=ob[D.a];da=ob[D.b];na=ob[D.c];La=ob[D.d];W[R]=Y.x;W[R+1]=Y.y;W[R+2]=Y.z;W[R+3]=1;W[R+4]=da.x;W[R+5]=da.y;W[R+6]=da.z;W[R+7]=1;W[R+8]=na.x;W[R+9]=na.y;W[R+10]=na.z;W[R+11]=1;W[R+12]=La.x;W[R+13]=La.y;W[R+14]=La.z;W[R+15]=1;Y=pb[D.a];da=pb[D.b];na=pb[D.c];D=pb[D.d];xa[R]=Y.x;xa[R+1]=Y.y;xa[R+2]=Y.z;xa[R+3]=1;xa[R+4]=da.x;xa[R+5]=da.y;xa[R+6]=da.z;xa[R+7]=1;xa[R+8]=na.x;xa[R+9]=na.y;xa[R+10]=na.z;xa[R+11]=1;xa[R+12]=D.x;xa[R+13]=D.y;xa[R+14]=D.z;xa[R+15]=1;
|
|
|
+R+=16}if(ub&&Ja){if(K.length==4&&Ja==THREE.VertexColors){D=K[0];Y=K[1];da=K[2];K=K[3]}else K=da=Y=D=X;ma[Ca]=D.r;ma[Ca+1]=D.g;ma[Ca+2]=D.b;ma[Ca+3]=Y.r;ma[Ca+4]=Y.g;ma[Ca+5]=Y.b;ma[Ca+6]=da.r;ma[Ca+7]=da.g;ma[Ca+8]=da.b;ma[Ca+9]=K.r;ma[Ca+10]=K.g;ma[Ca+11]=K.b;Ca+=12}if(tb&&Xa.hasTangents){K=T[0];X=T[1];D=T[2];T=T[3];ia[Ma]=K.x;ia[Ma+1]=K.y;ia[Ma+2]=K.z;ia[Ma+3]=K.w;ia[Ma+4]=X.x;ia[Ma+5]=X.y;ia[Ma+6]=X.z;ia[Ma+7]=X.w;ia[Ma+8]=D.x;ia[Ma+9]=D.y;ia[Ma+10]=D.z;ia[Ma+11]=D.w;ia[Ma+12]=T.x;ia[Ma+13]=T.y;
|
|
|
+ia[Ma+14]=T.z;ia[Ma+15]=T.w;Ma+=16}if(sb&&ra)if(F.length==4&&ib)for(T=0;T<4;T++){H=F[T];S[ab]=H.x;S[ab+1]=H.y;S[ab+2]=H.z;ab+=3}else for(T=0;T<4;T++){S[ab]=H.x;S[ab+1]=H.y;S[ab+2]=H.z;ab+=3}if(rb&&ya!==undefined&&Ea)for(T=0;T<4;T++){F=ya[T];jb[hb]=F.u;jb[hb+1]=F.v;hb+=2}if(rb&&bb!==undefined&&Ea)for(T=0;T<4;T++){F=bb[T];Ya[eb]=F.u;Ya[eb+1]=F.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){G=0;for(I=mb.length;G<I;G++){Wa[$a]=mb[G].a;Wa[$a+1]=mb[G].b;Wa[$a+2]=mb[G].c;Wa[$a+3]=mb[G].a;Wa[$a+4]=mb[G].c;Wa[$a+5]=mb[G].d;$a+=6}}if(fb){e.bindBuffer(e.ARRAY_BUFFER,u.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,Ta,M)}if(Ka)for(db in Ka){Q=Ka[db];if(Q.needsUpdate){e.bindBuffer(e.ARRAY_BUFFER,Q.buffer);e.bufferData(e.ARRAY_BUFFER,Q.array,M);Q.needsUpdate=!1}}if(vb){Z=0;for(Q=kb.length;Z<Q;Z++){e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
+u.__webglMorphTargetsBuffers[Z]);e.bufferData(e.ARRAY_BUFFER,V[Z],M)}}if(ub&&Ca>0){e.bindBuffer(e.ARRAY_BUFFER,u.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,ma,M)}if(sb){e.bindBuffer(e.ARRAY_BUFFER,u.__webglNormalBuffer);e.bufferData(e.ARRAY_BUFFER,S,M)}if(tb&&Xa.hasTangents){e.bindBuffer(e.ARRAY_BUFFER,u.__webglTangentBuffer);e.bufferData(e.ARRAY_BUFFER,ia,M)}if(rb&&hb>0){e.bindBuffer(e.ARRAY_BUFFER,u.__webglUVBuffer);e.bufferData(e.ARRAY_BUFFER,jb,M)}if(rb&&eb>0){e.bindBuffer(e.ARRAY_BUFFER,
|
|
|
+u.__webglUV2Buffer);e.bufferData(e.ARRAY_BUFFER,Ya,M)}if(gb){e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,u.__webglFaceBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,Wa,M);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,u.__webglLineBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,Ua,M)}if(R>0){e.bindBuffer(e.ARRAY_BUFFER,u.__webglSkinVertexABuffer);e.bufferData(e.ARRAY_BUFFER,W,M);e.bindBuffer(e.ARRAY_BUFFER,u.__webglSkinVertexBBuffer);e.bufferData(e.ARRAY_BUFFER,xa,M);e.bindBuffer(e.ARRAY_BUFFER,u.__webglSkinIndicesBuffer);
|
|
|
+e.bufferData(e.ARRAY_BUFFER,wa,M);e.bindBuffer(e.ARRAY_BUFFER,u.__webglSkinWeightsBuffer);e.bufferData(e.ARRAY_BUFFER,ga,M)}}}w.__dirtyVertices=!1;w.__dirtyMorphTargets=!1;w.__dirtyElements=!1;w.__dirtyUvs=!1;w.__dirtyNormals=!1;w.__dirtyTangents=!1;w.__dirtyColors=!1}else if(m instanceof THREE.Ribbon){w=m.geometry;if(w.__dirtyVertices||w.__dirtyColors){m=w;B=e.DYNAMIC_DRAW;Ja=m.vertices;u=m.colors;ra=Ja.length;M=u.length;ya=m.__vertexArray;G=m.__colorArray;bb=m.__dirtyColors;if(m.__dirtyVertices){for(I=
|
|
|
+0;I<ra;I++){Ea=Ja[I].position;A=I*3;ya[A]=Ea.x;ya[A+1]=Ea.y;ya[A+2]=Ea.z}e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,ya,B)}if(bb){for(I=0;I<M;I++){color=u[I];A=I*3;G[A]=color.r;G[A+1]=color.g;G[A+2]=color.b}e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,G,B)}}w.__dirtyVertices=!1;w.__dirtyColors=!1}else if(m instanceof THREE.Line){w=m.geometry;if(w.__dirtyVertices||w.__dirtyColors){m=w;B=e.DYNAMIC_DRAW;Ja=m.vertices;u=m.colors;ra=Ja.length;
|
|
|
+M=u.length;ya=m.__vertexArray;G=m.__colorArray;bb=m.__dirtyColors;if(m.__dirtyVertices){for(I=0;I<ra;I++){Ea=Ja[I].position;A=I*3;ya[A]=Ea.x;ya[A+1]=Ea.y;ya[A+2]=Ea.z}e.bindBuffer(e.ARRAY_BUFFER,m.__webglVertexBuffer);e.bufferData(e.ARRAY_BUFFER,ya,B)}if(bb){for(I=0;I<M;I++){color=u[I];A=I*3;G[A]=color.r;G[A+1]=color.g;G[A+2]=color.b}e.bindBuffer(e.ARRAY_BUFFER,m.__webglColorBuffer);e.bufferData(e.ARRAY_BUFFER,G,B)}}w.__dirtyVertices=!1;w.__dirtyColors=!1}else if(m instanceof THREE.ParticleSystem){w=
|
|
|
+m.geometry;(w.__dirtyVertices||w.__dirtyColors||m.sortParticles)&&d(w,e.DYNAMIC_DRAW,m);w.__dirtyVertices=!1;w.__dirtyColors=!1}}function J(m){function B(X){var T=[];w=0;for(u=X.length;w<u;w++)X[w]==undefined?T.push("undefined"):T.push(X[w].id);return T.join("_")}var w,u,A,M,G,I,F,D,H={},K=m.morphTargets!==undefined?m.morphTargets.length:0;m.geometryGroups={};A=0;for(M=m.faces.length;A<M;A++){G=m.faces[A];I=G.materials;F=B(I);H[F]==undefined&&(H[F]={hash:F,counter:0});D=H[F].hash+"_"+H[F].counter;
|
|
|
+m.geometryGroups[D]==undefined&&(m.geometryGroups[D]={faces:[],materials:I,vertices:0,numMorphTargets:K});G=G instanceof THREE.Face3?3:4;if(m.geometryGroups[D].vertices+G>65535){H[F].counter+=1;D=H[F].hash+"_"+H[F].counter;m.geometryGroups[D]==undefined&&(m.geometryGroups[D]={faces:[],materials:I,vertices:0,numMorphTargets:K})}m.geometryGroups[D].faces.push(A);m.geometryGroups[D].vertices+=G}}function U(m,B,w){m.push({buffer:B,object:w,opaque:{list:[],count:0},transparent:{list:[],count:0}})}function y(m){if(m!=
|
|
|
+Ba){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)}Ba=m}}function L(m,B,w){if((w.width&w.width-1)==0&&(w.height&
|
|
|
+w.height-1)==0){e.texParameteri(m,e.TEXTURE_WRAP_S,ta(B.wrapS));e.texParameteri(m,e.TEXTURE_WRAP_T,ta(B.wrapT));e.texParameteri(m,e.TEXTURE_MAG_FILTER,ta(B.magFilter));e.texParameteri(m,e.TEXTURE_MIN_FILTER,ta(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,va(B.magFilter));e.texParameteri(m,e.TEXTURE_MIN_FILTER,va(B.minFilter))}}function N(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}L(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 P(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,ta(m.wrapS));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,ta(m.wrapT));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,ta(m.magFilter));e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,ta(m.minFilter));e.texImage2D(e.TEXTURE_2D,
|
|
|
+0,ta(m.format),m.width,m.height,0,ta(m.format),ta(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,w;if(m){B=m.__webglFramebuffer;w=m.width;m=m.height}else{B=null;w=Fa;m=ka}if(B!=
|
|
|
+Ha){e.bindFramebuffer(e.FRAMEBUFFER,B);e.viewport($,pa,w,m);Ha=B}}function za(m,B){var w;if(m=="fragment")w=e.createShader(e.FRAGMENT_SHADER);else m=="vertex"&&(w=e.createShader(e.VERTEX_SHADER));e.shaderSource(w,B);e.compileShader(w);if(!e.getShaderParameter(w,e.COMPILE_STATUS)){console.error(e.getShaderInfoLog(w));console.error(B);return null}return w}function va(m){switch(m){case THREE.NearestFilter:case THREE.NearestMipMapNearestFilter:case THREE.NearestMipMapLinearFilter:return e.NEAREST;default:return e.LINEAR}}
|
|
|
+function ta(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,fa=document.createElement("canvas"),ea=[],Aa=null,Ha=null,Ia=!0,ua=this,ca=null,sa=null,Ba=null,ja=null,$=0,pa=0,Fa=0,ka=0,oa=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],Ga=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:[]}},O=!0,aa=!0,qa=new THREE.Color(0),Da=0;if(b){if(b.stencil!=
|
|
|
+undefined)O=b.stencil;if(b.antialias!==undefined)aa=b.antialias;b.clearColor!==undefined&&qa.setHex(b.clearColor);if(b.clearAlpha!==undefined)Da=b.clearAlpha}this.maxMorphTargets=8;this.domElement=fa;this.autoClear=!0;this.sortObjects=!0;(function(m,B,w,u){try{if(!(e=fa.getContext("experimental-webgl",{antialias:m,stencil:u})))throw"Error creating WebGL context.";}catch(A){console.error(A)}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,w)})(aa,qa,Da,O);this.context=e;if(O){var ha={};ha.vertices=new Float32Array(12);ha.faces=new Uint16Array(6);ha.darkness=0.5;ha.vertices[0]=-2;ha.vertices[1]=-1;ha.vertices[2]=-1;ha.vertices[3]=2;ha.vertices[4]=-1;ha.vertices[5]=-1;ha.vertices[6]=2;ha.vertices[7]=1;ha.vertices[8]=-1;ha.vertices[9]=-2;ha.vertices[10]=1;ha.vertices[11]=-1;ha.faces[0]=0;ha.faces[1]=
|
|
|
+1;ha.faces[2]=2;ha.faces[3]=0;ha.faces[4]=2;ha.faces[5]=3;ha.vertexBuffer=e.createBuffer();ha.elementBuffer=e.createBuffer();e.bindBuffer(e.ARRAY_BUFFER,ha.vertexBuffer);e.bufferData(e.ARRAY_BUFFER,ha.vertices,e.STATIC_DRAW);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,ha.elementBuffer);e.bufferData(e.ELEMENT_ARRAY_BUFFER,ha.faces,e.STATIC_DRAW);ha.program=e.createProgram();e.attachShader(ha.program,za("fragment",THREE.ShaderLib.shadowPost.fragmentShader));e.attachShader(ha.program,za("vertex",THREE.ShaderLib.shadowPost.vertexShader));
|
|
|
+e.linkProgram(ha.program);ha.vertexLocation=e.getAttribLocation(ha.program,"position");ha.projectionLocation=e.getUniformLocation(ha.program,"projectionMatrix");ha.darknessLocation=e.getUniformLocation(ha.program,"darkness")}var la={};la.vertices=new Float32Array(16);la.faces=new Uint16Array(6);la.transparency=0.5;b=0;la.vertices[b++]=-1;la.vertices[b++]=-1;la.vertices[b++]=0;la.vertices[b++]=0;la.vertices[b++]=1;la.vertices[b++]=-1;la.vertices[b++]=1;la.vertices[b++]=0;la.vertices[b++]=1;la.vertices[b++]=
|
|
|
+1;la.vertices[b++]=1;la.vertices[b++]=1;la.vertices[b++]=-1;la.vertices[b++]=1;la.vertices[b++]=0;la.vertices[b++]=1;b=0;la.faces[b++]=0;la.faces[b++]=1;la.faces[b++]=2;la.faces[b++]=0;la.faces[b++]=2;la.faces[b++]=3;la.vertexBuffer=e.createBuffer();la.elementBuffer=e.createBuffer();la.tempTexture=e.createTexture();la.readBackPixels=new Uint8Array(1024);e.bindBuffer(e.ARRAY_BUFFER,la.vertexBuffer);e.bufferData(e.ARRAY_BUFFER,la.vertices,e.STATIC_DRAW);e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,la.elementBuffer);
|
|
|
+e.bufferData(e.ELEMENT_ARRAY_BUFFER,la.faces,e.STATIC_DRAW);e.bindTexture(e.TEXTURE_2D,la.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);la.program=e.createProgram();e.attachShader(la.program,za("fragment",THREE.ShaderLib.lensFlare.fragmentShader));
|
|
|
+e.attachShader(la.program,za("vertex",THREE.ShaderLib.lensFlare.vertexShader));e.linkProgram(la.program);la.attributes={};la.uniforms={};la.attributes.vertex=e.getAttribLocation(la.program,"position");la.attributes.uv=e.getAttribLocation(la.program,"UV");la.uniforms.map=e.getUniformLocation(la.program,"map");la.uniforms.opacity=e.getUniformLocation(la.program,"opacity");la.uniforms.scale=e.getUniformLocation(la.program,"scale");la.uniforms.rotation=e.getUniformLocation(la.program,"rotation");la.uniforms.screenPosition=
|
|
|
+e.getUniformLocation(la.program,"screenPosition");la.uniforms.renderPink=e.getUniformLocation(la.program,"renderPink");this.setSize=function(m,B){fa.width=m;fa.height=B;this.setViewport(0,0,fa.width,fa.height)};this.setViewport=function(m,B,w,u){$=m;pa=B;Fa=w;ka=u;e.viewport($,pa,Fa,ka)};this.setScissor=function(m,B,w,u){e.scissor(m,B,w,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,B){var w=new THREE.Color(m);e.clearColor(w.r,w.g,w.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){ha.darkness=m};this.initMaterial=function(m,B,w,u){var A,M,G;if(m instanceof THREE.MeshDepthMaterial)G="depth";else if(m instanceof THREE.ShadowVolumeDynamicMaterial)G="shadowVolumeDynamic";else if(m instanceof THREE.MeshNormalMaterial)G=
|
|
|
+"normal";else if(m instanceof THREE.MeshBasicMaterial)G="basic";else if(m instanceof THREE.MeshLambertMaterial)G="lambert";else if(m instanceof THREE.MeshPhongMaterial)G="phong";else if(m instanceof THREE.LineBasicMaterial)G="basic";else m instanceof THREE.ParticleBasicMaterial&&(G="particle_basic");if(G){var I=THREE.ShaderLib[G];m.uniforms=Uniforms.clone(I.uniforms);m.vertexShader=I.vertexShader;m.fragmentShader=I.fragmentShader}var F,D,H;F=H=I=0;for(D=B.length;F<D;F++){M=B[F];M instanceof THREE.DirectionalLight&&
|
|
|
+H++;M instanceof THREE.PointLight&&I++}if(I+H<=4)B=H;else{B=Math.ceil(4*H/(I+H));I=4-B}M={directional:B,point:I};H=50;if(u!==undefined&&u instanceof THREE.SkinnedMesh)H=u.bones.length;var K;a:{F=m.fragmentShader;D=m.vertexShader;I=m.uniforms;B=m.attributes;w={map:!!m.map,envMap:!!m.envMap,lightMap:!!m.lightMap,vertexColors:m.vertexColors,fog:w,sizeAttenuation:m.sizeAttenuation,skinning:m.skinning,morphTargets:m.morphTargets,maxMorphTargets:this.maxMorphTargets,maxDirLights:M.directional,maxPointLights:M.point,
|
|
|
+maxBones:H};var X;M=[];if(G)M.push(G);else{M.push(F);M.push(D)}for(X in w){M.push(X);M.push(w[X])}G=M.join();X=0;for(M=ea.length;X<M;X++)if(ea[X].code==G){K=ea[X].program;break a}X=e.createProgram();prefix_fragment=["#ifdef GL_ES\nprecision highp float;\n#endif","#define MAX_DIR_LIGHTS "+w.maxDirLights,"#define MAX_POINT_LIGHTS "+w.maxPointLights,w.fog?"#define USE_FOG":"",w.fog instanceof THREE.FogExp2?"#define FOG_EXP2":"",w.map?"#define USE_MAP":"",w.envMap?"#define USE_ENVMAP":"",w.lightMap?"#define USE_LIGHTMAP":
|
|
|
+"",w.vertexColors?"#define USE_COLOR":"","uniform mat4 viewMatrix;\nuniform vec3 cameraPosition;\n"].join("\n");prefix_vertex=[e.getParameter(e.MAX_VERTEX_TEXTURE_IMAGE_UNITS)>0?"#define VERTEX_TEXTURES":"","#define MAX_DIR_LIGHTS "+w.maxDirLights,"#define MAX_POINT_LIGHTS "+w.maxPointLights,"#define MAX_BONES "+w.maxBones,w.map?"#define USE_MAP":"",w.envMap?"#define USE_ENVMAP":"",w.lightMap?"#define USE_LIGHTMAP":"",w.vertexColors?"#define USE_COLOR":"",w.skinning?"#define USE_SKINNING":"",w.morphTargets?
|
|
|
+"#define USE_MORPHTARGETS":"",w.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(X,za("fragment",prefix_fragment+F));e.attachShader(X,za("vertex",prefix_vertex+D));e.linkProgram(X);e.getProgramParameter(X,e.LINK_STATUS)||console.error("Could not initialise shader\nVALIDATE_STATUS: "+e.getProgramParameter(X,e.VALIDATE_STATUS)+", gl error ["+e.getError()+"]");X.uniforms={};X.attributes={};var T;F=["viewMatrix","modelViewMatrix","projectionMatrix","normalMatrix","objectMatrix","cameraPosition","cameraInverseMatrix","boneGlobalMatrices","morphTargetInfluences"];for(T in I)F.push(T);
|
|
|
+T=F;I=0;for(F=T.length;I<F;I++){D=T[I];X.uniforms[D]=e.getUniformLocation(X,D)}F=["position","normal","uv","uv2","tangent","color","skinVertexA","skinVertexB","skinIndex","skinWeight"];for(T=0;T<w.maxMorphTargets;T++)F.push("morphTarget"+T);for(K in B)F.push(K);K=F;T=0;for(B=K.length;T<B;T++){w=K[T];X.attributes[w]=e.getAttribLocation(X,w)}ea.push({program:X,code:G});K=X}m.program=K;K=m.program.attributes;e.enableVertexAttribArray(K.position);K.color>=0&&e.enableVertexAttribArray(K.color);K.normal>=
|
|
|
+0&&e.enableVertexAttribArray(K.normal);K.tangent>=0&&e.enableVertexAttribArray(K.tangent);if(m.skinning&&K.skinVertexA>=0&&K.skinVertexB>=0&&K.skinIndex>=0&&K.skinWeight>=0){e.enableVertexAttribArray(K.skinVertexA);e.enableVertexAttribArray(K.skinVertexB);e.enableVertexAttribArray(K.skinIndex);e.enableVertexAttribArray(K.skinWeight)}for(A in m.attributes)K[A]>=0&&e.enableVertexAttribArray(K[A]);if(m.morphTargets){m.numSupportedMorphTargets=0;if(K.morphTarget0>=0){e.enableVertexAttribArray(K.morphTarget0);
|
|
|
+m.numSupportedMorphTargets++}if(K.morphTarget1>=0){e.enableVertexAttribArray(K.morphTarget1);m.numSupportedMorphTargets++}if(K.morphTarget2>=0){e.enableVertexAttribArray(K.morphTarget2);m.numSupportedMorphTargets++}if(K.morphTarget3>=0){e.enableVertexAttribArray(K.morphTarget3);m.numSupportedMorphTargets++}if(K.morphTarget4>=0){e.enableVertexAttribArray(K.morphTarget4);m.numSupportedMorphTargets++}if(K.morphTarget5>=0){e.enableVertexAttribArray(K.morphTarget5);m.numSupportedMorphTargets++}if(K.morphTarget6>=
|
|
|
+0){e.enableVertexAttribArray(K.morphTarget6);m.numSupportedMorphTargets++}if(K.morphTarget7>=0){e.enableVertexAttribArray(K.morphTarget7);m.numSupportedMorphTargets++}u.__webglMorphTargetInfluences=new Float32Array(this.maxMorphTargets);m=0;for(A=this.maxMorphTargets;m<A;m++)u.__webglMorphTargetInfluences[m]=0}};this.render=function(m,B,w,u){var A,M,G,I,F,D,H,K,X=m.lights,T=m.fog;B.matrixAutoUpdate&&B.updateMatrix();m.update(undefined,!1,B);B.matrixWorldInverse.flattenToArray(Za);B.projectionMatrix.flattenToArray(Ra);
|
|
|
+Ga.multiply(B.projectionMatrix,B.matrixWorldInverse);k(Ga);this.initWebGLObjects(m);P(w);(this.autoClear||u)&&this.clear();F=m.__webglObjects.length;for(u=0;u<F;u++){A=m.__webglObjects[u];H=A.object;if(H.visible)if(!(H instanceof THREE.Mesh)||n(H)){H.matrixWorld.flattenToArray(H._objectMatrixArray);C(H,B);t(A);A.render=!0;if(this.sortObjects){Va.copy(H.position);Ga.multiplyVector3(Va);A.z=Va.z}}else A.render=!1;else A.render=!1}this.sortObjects&&m.__webglObjects.sort(x);D=m.__webglObjectsImmediate.length;
|
|
|
+for(u=0;u<D;u++){A=m.__webglObjectsImmediate[u];H=A.object;if(H.visible){H.matrixAutoUpdate&&H.matrixWorld.flattenToArray(H._objectMatrixArray);C(H,B);o(A)}}y(THREE.NormalBlending);for(u=0;u<F;u++){A=m.__webglObjects[u];if(A.render){H=A.object;K=A.buffer;G=A.opaque;h(H);for(A=0;A<G.count;A++){I=G.list[A];j(I.depthTest);f(B,X,T,I,K,H)}}}for(u=0;u<D;u++){A=m.__webglObjectsImmediate[u];H=A.object;if(H.visible){G=A.opaque;h(H);for(A=0;A<G.count;A++){I=G.list[A];j(I.depthTest);M=c(B,X,T,I,H);H.render(function(Ea){g(Ea,
|
|
|
+M)})}}}for(u=0;u<F;u++){A=m.__webglObjects[u];if(A.render){H=A.object;K=A.buffer;G=A.transparent;h(H);for(A=0;A<G.count;A++){I=G.list[A];y(I.blending);j(I.depthTest);f(B,X,T,I,K,H)}}}for(u=0;u<D;u++){A=m.__webglObjectsImmediate[u];H=A.object;if(H.visible){G=A.transparent;h(H);for(A=0;A<G.count;A++){I=G.list[A];y(I.blending);j(I.depthTest);M=c(B,X,T,I,H);H.render(function(Ea){g(Ea,M)})}}}O&&m.__webglShadowVolumes.length&&m.lights.length&&v(m);m.__webglLensFlares.length&&z(m,B);if(w&&w.minFilter!==
|
|
|
+THREE.NearestFilter&&w.minFilter!==THREE.LinearFilter){e.bindTexture(e.TEXTURE_2D,w.__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],w=m,u=void 0,A=void 0,M=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){A=B.geometry;A.geometryGroups==undefined&&J(A);for(u in A.geometryGroups){M=A.geometryGroups[u];if(!M.__webglVertexBuffer){var G=M;G.__webglVertexBuffer=e.createBuffer();G.__webglNormalBuffer=e.createBuffer();G.__webglTangentBuffer=e.createBuffer();G.__webglColorBuffer=e.createBuffer();G.__webglUVBuffer=e.createBuffer();G.__webglUV2Buffer=
|
|
|
+e.createBuffer();G.__webglSkinVertexABuffer=e.createBuffer();G.__webglSkinVertexBBuffer=e.createBuffer();G.__webglSkinIndicesBuffer=e.createBuffer();G.__webglSkinWeightsBuffer=e.createBuffer();G.__webglFaceBuffer=e.createBuffer();G.__webglLineBuffer=e.createBuffer();if(G.numMorphTargets){var I=void 0,F=void 0;G.__webglMorphTargetsBuffers=[];I=0;for(F=G.numMorphTargets;I<F;I++)G.__webglMorphTargetsBuffers.push(e.createBuffer())}G=M;I=B;var D=void 0,H=void 0,K=void 0;K=void 0;var X=void 0,T=void 0,
|
|
|
+Ea=void 0,Ja=Ea=F=0;H=void 0;K=void 0;var ra=void 0;D=void 0;H=void 0;X=I.geometry;ra=X.faces;T=G.faces;D=0;for(H=T.length;D<H;D++){K=T[D];K=ra[K];if(K instanceof THREE.Face3){F+=3;Ea+=1;Ja+=3}else if(K instanceof THREE.Face4){F+=4;Ea+=2;Ja+=4}}D=G;H=I;ra=void 0;T=void 0;var ya=void 0,bb=void 0;ya=void 0;K=[];ra=0;for(T=H.materials.length;ra<T;ra++){ya=H.materials[ra];if(ya instanceof THREE.MeshFaceMaterial){ya=0;for(l=D.materials.length;ya<l;ya++)(bb=D.materials[ya])&&K.push(bb)}else(bb=ya)&&K.push(bb)}D=
|
|
|
+K;a:{H=void 0;ra=void 0;T=D.length;for(H=0;H<T;H++){ra=D[H];if(ra.map||ra.lightMap||ra instanceof THREE.MeshShaderMaterial){H=!0;break a}}H=!1}a:{ra=D;T=void 0;K=void 0;ya=ra.length;for(T=0;T<ya;T++){K=ra[T];if(!(K instanceof THREE.MeshBasicMaterial&&!K.envMap||K instanceof THREE.MeshDepthMaterial)){ra=K&&K.shading!=undefined&&K.shading==THREE.SmoothShading?THREE.SmoothShading:THREE.FlatShading;break a}}ra=!1}a:{T=void 0;K=void 0;ya=D.length;for(T=0;T<ya;T++){K=D[T];if(K.vertexColors){K=K.vertexColors;
|
|
|
+break a}}K=!1}G.__vertexArray=new Float32Array(F*3);if(ra)G.__normalArray=new Float32Array(F*3);if(X.hasTangents)G.__tangentArray=new Float32Array(F*4);if(K)G.__colorArray=new Float32Array(F*3);if(H){if(X.faceUvs.length>0||X.faceVertexUvs.length>0)G.__uvArray=new Float32Array(F*2);if(X.faceUvs.length>1||X.faceVertexUvs.length>1)G.__uv2Array=new Float32Array(F*2)}if(I.geometry.skinWeights.length&&I.geometry.skinIndices.length){G.__skinVertexAArray=new Float32Array(F*4);G.__skinVertexBArray=new Float32Array(F*
|
|
|
+4);G.__skinIndexArray=new Float32Array(F*4);G.__skinWeightArray=new Float32Array(F*4)}G.__faceArray=new Uint16Array(Ea*3+(I.geometry.edgeFaces?I.geometry.edgeFaces.length*6:0));G.__lineArray=new Uint16Array(Ja*2);if(G.numMorphTargets){G.__morphTargetsArrays=[];X=0;for(T=G.numMorphTargets;X<T;X++)G.__morphTargetsArrays.push(new Float32Array(F*3))}G.__needsSmoothNormals=ra==THREE.SmoothShading;G.__uvType=H;G.__vertexColorType=K;G.__normalType=ra;G.__webglFaceCount=Ea*3+(I.geometry.edgeFaces?I.geometry.edgeFaces.length*
|
|
|
+6:0);G.__webglLineCount=Ja*2;X=0;for(T=D.length;X<T;X++)if(D[X].attributes){G.__webglCustomAttributes={};for(a in D[X].attributes){H=D[X].attributes[a];Ea=1;if(H.type==="v2")Ea=2;else if(H.type==="v3")Ea=3;else if(H.type==="v4")Ea=4;else H.type==="c"&&(Ea=3);H.size=Ea;H.needsUpdate=!0;H.array=new Float32Array(F*Ea);H.buffer=e.createBuffer();G.__webglCustomAttributes[a]=H}}A.__dirtyVertices=!0;A.__dirtyMorphTargets=!0;A.__dirtyElements=!0;A.__dirtyUvs=!0;A.__dirtyNormals=!0;A.__dirtyTangents=!0;A.__dirtyColors=
|
|
|
+!0}B instanceof THREE.ShadowVolume?U(w.__webglShadowVolumes,M,B):U(w.__webglObjects,M,B)}}else if(B instanceof THREE.LensFlare)U(w.__webglLensFlares,undefined,B);else if(B instanceof THREE.Ribbon){A=B.geometry;if(!A.__webglVertexBuffer){u=A;u.__webglVertexBuffer=e.createBuffer();u.__webglColorBuffer=e.createBuffer();u=A;M=u.vertices.length;u.__vertexArray=new Float32Array(M*3);u.__colorArray=new Float32Array(M*3);u.__webglVertexCount=M;A.__dirtyVertices=!0;A.__dirtyColors=!0}U(w.__webglObjects,A,
|
|
|
+B)}else if(B instanceof THREE.Line){A=B.geometry;if(!A.__webglVertexBuffer){u=A;u.__webglVertexBuffer=e.createBuffer();u.__webglColorBuffer=e.createBuffer();u=A;M=u.vertices.length;u.__vertexArray=new Float32Array(M*3);u.__colorArray=new Float32Array(M*3);u.__webglLineCount=M;A.__dirtyVertices=!0;A.__dirtyColors=!0}U(w.__webglObjects,A,B)}else if(B instanceof THREE.ParticleSystem){A=B.geometry;if(!A.__webglVertexBuffer){u=A;u.__webglVertexBuffer=e.createBuffer();u.__webglColorBuffer=e.createBuffer();
|
|
|
+u=A;M=u.vertices.length;u.__vertexArray=new Float32Array(M*3);u.__colorArray=new Float32Array(M*3);u.__sortArray=[];u.__webglParticleCount=M;A.__dirtyVertices=!0;A.__dirtyColors=!0}U(w.__webglObjects,A,B)}else THREE.MarchingCubes!==undefined&&B instanceof THREE.MarchingCubes&&w.__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];w=m;A=void 0;u=void 0;for(A=w.__webglObjects.length-
|
|
|
+1;A>=0;A--){u=w.__webglObjects[A].object;B==u&&w.__webglObjects.splice(A,1)}m.__objectsRemoved.splice(0,1)}B=0;for(w=m.__webglObjects.length;B<w;B++)E(m.__webglObjects[B].object,m);B=0;for(w=m.__webglShadowVolumes.length;B<w;B++)E(m.__webglShadowVolumes[B].object,m);B=0;for(w=m.__webglLensFlares.length;B<w;B++)E(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);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)}}}};
|
|
@@ -328,18 +328,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,u=j.length;o<u;o++){var y=new THREE.Vertex(j[o].position.clone());c&&d.matrix.multiplyVector3(y.position);h.push(y)}o=0;for(u=n.length;o<u;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(u=g.length;o<u;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(Da,ga){return ga=="relativeToHTML"?
|
|
|
-Da:h+"/"+Da}function n(){for(v in Z.objects)if(!$.objects[v]){U=Z.objects[v];if(M=$.geometries[U.geometry]){xa=[];for(pa=0;pa<U.materials.length;pa++)xa[pa]=$.materials[U.materials[pa]];z=U.position;r=U.rotation;q=U.quaternion;s=U.scale;q=0;xa.length==0&&(xa[0]=new THREE.MeshFaceMaterial);object=new THREE.Mesh(M,xa);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=U.visible;$.scene.addObject(object);$.objects[v]=object}}}function p(Da){return function(ga){$.geometries[Da]=ga;n();Ca-=1;o()}}function o(){f({total_models:Ha,total_textures:qa,loaded_models:Ha-Ca,loaded_textures:qa-Aa},$);Ca==0&&Aa==0&&c($)}var u,y,v,B,C,F,H,U,z,J,L,M,Fa,oa,xa,Z,e,da,Ca,Aa,Ha,qa,$;Z=j.data;e=new THREE.BinaryLoader;da=new THREE.JSONLoader;Aa=Ca=0;$={scene:new THREE.Scene,geometries:{},materials:{},textures:{},objects:{},cameras:{},lights:{},fogs:{}};j=function(){Aa-=
|
|
|
-1;o()};for(C in Z.cameras){J=Z.cameras[C];if(J.type=="perspective")Fa=new THREE.Camera(J.fov,J.aspect,J.near,J.far);else if(J.type=="ortho"){Fa=new THREE.Camera;Fa.projectionMatrix=THREE.Matrix4.makeOrtho(J.left,J.right,J.top,J.bottom,J.near,J.far)}z=J.position;J=J.target;Fa.position.set(z[0],z[1],z[2]);Fa.target.position.set(J[0],J[1],J[2]);$.cameras[C]=Fa}for(B in Z.lights){C=Z.lights[B];Fa=C.color!==undefined?C.color:16777215;J=C.intensity!==undefined?C.intensity:1;if(C.type=="directional"){z=
|
|
|
-C.direction;light=new THREE.DirectionalLight(Fa,J);light.position.set(z[0],z[1],z[2]);light.position.normalize()}else if(C.type=="point"){z=C.position;light=new THREE.PointLight(Fa,J);light.position.set(z[0],z[1],z[2])}$.scene.addLight(light);$.lights[B]=light}for(F in Z.fogs){B=Z.fogs[F];if(B.type=="linear")oa=new THREE.Fog(0,B.near,B.far);else B.type=="exp2"&&(oa=new THREE.FogExp2(0,B.density));J=B.color;oa.color.setRGB(J[0],J[1],J[2]);$.fogs[F]=oa}if($.cameras&&Z.defaults.camera)$.currentCamera=
|
|
|
-$.cameras[Z.defaults.camera];if($.fogs&&Z.defaults.fog)$.scene.fog=$.fogs[Z.defaults.fog];J=Z.defaults.bgcolor;$.bgColor=new THREE.Color;$.bgColor.setRGB(J[0],J[1],J[2]);$.bgColorAlpha=Z.defaults.bgalpha;for(u in Z.geometries){F=Z.geometries[u];if(F.type=="bin_mesh"||F.type=="ascii_mesh")Ca+=1}Ha=Ca;for(u in Z.geometries){F=Z.geometries[u];if(F.type=="cube"){M=new Cube(F.width,F.height,F.depth,F.segmentsWidth,F.segmentsHeight,F.segmentsDepth,null,F.flipped,F.sides);$.geometries[u]=M}else if(F.type==
|
|
|
-"plane"){M=new Plane(F.width,F.height,F.segmentsWidth,F.segmentsHeight);$.geometries[u]=M}else if(F.type=="sphere"){M=new Sphere(F.radius,F.segmentsWidth,F.segmentsHeight);$.geometries[u]=M}else if(F.type=="cylinder"){M=new Cylinder(F.numSegs,F.topRad,F.botRad,F.height,F.topOffset,F.botOffset);$.geometries[u]=M}else if(F.type=="torus"){M=new Torus(F.radius,F.tube,F.segmentsR,F.segmentsT);$.geometries[u]=M}else if(F.type=="icosahedron"){M=new Icosahedron(F.subdivisions);$.geometries[u]=M}else if(F.type==
|
|
|
-"bin_mesh")e.load({model:k(F.url,Z.urlBaseType),callback:p(u)});else F.type=="ascii_mesh"&&da.load({model:k(F.url,Z.urlBaseType),callback:p(u)})}for(H in Z.textures){u=Z.textures[H];Aa+=u.url instanceof Array?u.url.length:1}qa=Aa;for(H in Z.textures){u=Z.textures[H];if(u.mapping!=undefined&&THREE[u.mapping]!=undefined)u.mapping=new THREE[u.mapping];if(u.url instanceof Array){F=[];for(var pa=0;pa<u.url.length;pa++)F[pa]=k(u.url[pa],Z.urlBaseType);F=ImageUtils.loadTextureCube(F,u.mapping,j)}else{F=
|
|
|
-ImageUtils.loadTexture(k(u.url,Z.urlBaseType),u.mapping,j);if(THREE[u.minFilter]!=undefined)F.minFilter=THREE[u.minFilter];if(THREE[u.magFilter]!=undefined)F.magFilter=THREE[u.magFilter]}$.textures[H]=F}for(y in Z.materials){H=Z.materials[y];for(L in H.parameters)if(L=="envMap"||L=="map"||L=="lightMap")H.parameters[L]=$.textures[H.parameters[L]];else if(L=="shading")H.parameters[L]=H.parameters[L]=="flat"?THREE.FlatShading:THREE.SmoothShading;else if(L=="blending")H.parameters[L]=THREE[H.parameters[L]]?
|
|
|
-THREE[H.parameters[L]]:THREE.NormalBlending;else L=="combine"&&(H.parameters[L]=H.parameters[L]=="MixOperation"?THREE.MixOperation:THREE.MultiplyOperation);H=new THREE[H.type](H.parameters);$.materials[y]=H}n();d($)}},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=
|
|
|
+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 x=new THREE.Vertex(j[o].position.clone());c&&d.matrix.multiplyVector3(x.position);h.push(x)}o=0;for(t=n.length;o<t;o++){j=n[o];var v,z,C=j.vertexNormals;x=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++){z=C[c];v.vertexNormals.push(z.clone())}v.color.copy(j.color);c=0;for(h=x.length;c<h;c++){z=x[c];v.vertexColors.push(z.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(Ba,ja){return ja=="relativeToHTML"?
|
|
|
+Ba:h+"/"+Ba}function n(){for(v in e.objects)if(!ca.objects[v]){U=e.objects[v];if(P=ca.geometries[U.geometry]){ta=[];for(sa=0;sa<U.materials.length;sa++)ta[sa]=ca.materials[U.materials[sa]];y=U.position;r=U.rotation;q=U.quaternion;s=U.scale;q=0;ta.length==0&&(ta[0]=new THREE.MeshFaceMaterial);object=new THREE.Mesh(P,ta);object.position.set(y[0],y[1],y[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;ca.scene.addObject(object);ca.objects[v]=object}}}function p(Ba){return function(ja){ca.geometries[Ba]=ja;n();Aa-=1;o()}}function o(){f({total_models:Ia,total_textures:ua,loaded_models:Ia-Aa,loaded_textures:ua-Ha},ca);Aa==0&&Ha==0&&c(ca)}var t,x,v,z,C,E,J,U,y,L,N,P,za,va,ta,e,fa,ea,Aa,Ha,Ia,ua,ca;e=j.data;fa=new THREE.BinaryLoader;ea=new THREE.JSONLoader;Ha=Aa=0;ca={scene:new THREE.Scene,geometries:{},materials:{},textures:{},objects:{},cameras:{},lights:{},fogs:{}};j=function(){Ha-=
|
|
|
+1;o()};for(C in e.cameras){L=e.cameras[C];if(L.type=="perspective")za=new THREE.Camera(L.fov,L.aspect,L.near,L.far);else if(L.type=="ortho"){za=new THREE.Camera;za.projectionMatrix=THREE.Matrix4.makeOrtho(L.left,L.right,L.top,L.bottom,L.near,L.far)}y=L.position;L=L.target;za.position.set(y[0],y[1],y[2]);za.target.position.set(L[0],L[1],L[2]);ca.cameras[C]=za}for(z in e.lights){C=e.lights[z];za=C.color!==undefined?C.color:16777215;L=C.intensity!==undefined?C.intensity:1;if(C.type=="directional"){y=
|
|
|
+C.direction;light=new THREE.DirectionalLight(za,L);light.position.set(y[0],y[1],y[2]);light.position.normalize()}else if(C.type=="point"){y=C.position;light=new THREE.PointLight(za,L);light.position.set(y[0],y[1],y[2])}ca.scene.addLight(light);ca.lights[z]=light}for(E in e.fogs){z=e.fogs[E];if(z.type=="linear")va=new THREE.Fog(0,z.near,z.far);else z.type=="exp2"&&(va=new THREE.FogExp2(0,z.density));L=z.color;va.color.setRGB(L[0],L[1],L[2]);ca.fogs[E]=va}if(ca.cameras&&e.defaults.camera)ca.currentCamera=
|
|
|
+ca.cameras[e.defaults.camera];if(ca.fogs&&e.defaults.fog)ca.scene.fog=ca.fogs[e.defaults.fog];L=e.defaults.bgcolor;ca.bgColor=new THREE.Color;ca.bgColor.setRGB(L[0],L[1],L[2]);ca.bgColorAlpha=e.defaults.bgalpha;for(t in e.geometries){E=e.geometries[t];if(E.type=="bin_mesh"||E.type=="ascii_mesh")Aa+=1}Ia=Aa;for(t in e.geometries){E=e.geometries[t];if(E.type=="cube"){P=new Cube(E.width,E.height,E.depth,E.segmentsWidth,E.segmentsHeight,E.segmentsDepth,null,E.flipped,E.sides);ca.geometries[t]=P}else if(E.type==
|
|
|
+"plane"){P=new Plane(E.width,E.height,E.segmentsWidth,E.segmentsHeight);ca.geometries[t]=P}else if(E.type=="sphere"){P=new Sphere(E.radius,E.segmentsWidth,E.segmentsHeight);ca.geometries[t]=P}else if(E.type=="cylinder"){P=new Cylinder(E.numSegs,E.topRad,E.botRad,E.height,E.topOffset,E.botOffset);ca.geometries[t]=P}else if(E.type=="torus"){P=new Torus(E.radius,E.tube,E.segmentsR,E.segmentsT);ca.geometries[t]=P}else if(E.type=="icosahedron"){P=new Icosahedron(E.subdivisions);ca.geometries[t]=P}else if(E.type==
|
|
|
+"bin_mesh")fa.load({model:k(E.url,e.urlBaseType),callback:p(t)});else E.type=="ascii_mesh"&&ea.load({model:k(E.url,e.urlBaseType),callback:p(t)})}for(J in e.textures){t=e.textures[J];Ha+=t.url instanceof Array?t.url.length:1}ua=Ha;for(J in e.textures){t=e.textures[J];if(t.mapping!=undefined&&THREE[t.mapping]!=undefined)t.mapping=new THREE[t.mapping];if(t.url instanceof Array){E=[];for(var sa=0;sa<t.url.length;sa++)E[sa]=k(t.url[sa],e.urlBaseType);E=ImageUtils.loadTextureCube(E,t.mapping,j)}else{E=
|
|
|
+ImageUtils.loadTexture(k(t.url,e.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(x in e.materials){J=e.materials[x];for(N in J.parameters)if(N=="envMap"||N=="map"||N=="lightMap")J.parameters[N]=ca.textures[J.parameters[N]];else if(N=="shading")J.parameters[N]=J.parameters[N]=="flat"?THREE.FlatShading:THREE.SmoothShading;else if(N=="blending")J.parameters[N]=THREE[J.parameters[N]]?
|
|
|
+THREE[J.parameters[N]]:THREE.NormalBlending;else N=="combine"&&(J.parameters[N]=J.parameters[N]=="MixOperation"?THREE.MixOperation:THREE.MultiplyOperation);J=new THREE[J.type](J.parameters);ca.materials[x]=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,d)}}},ShaderUtils={lib:{fresnel:{uniforms:{mRefractionRatio:{type:"f",value:1.02},mFresnelBias:{type:"f",
|
|
@@ -362,77 +362,77 @@ this.heightMin)*this.heightCoef:0;(this.moveForward||this.autoForward)&&this.tra
|
|
|
Math.PI/180;if(this.constrainVertical)this.phi=(this.phi-0)*(this.verticalMax-this.verticalMin)/3.14+this.verticalMin;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,u,y){var v={name:u,fps:0.6,length:y,hierarchy:[]},B,C=o.getControlPointsArray(),F=o.getLength(),H=C.length,U=0;B=H-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<H-1;B++){U=y*F.chunks[B]/F.total;o.keys[B]={time:U,pos:C[B]}}v.hierarchy[0]=o;THREE.AnimationHandler.add(v);return new THREE.Animation(p,u,THREE.AnimationHandler.CATMULLROM_FORWARD,!1)}function c(p,o){var u,
|
|
|
-y,v=new THREE.Geometry;for(u=0;u<p.points.length*o;u++){y=u/(p.points.length*o);y=p.getPoint(y);v.vertices[u]=new THREE.Vertex(new THREE.Vector3(y.x,y.y,y.z))}return v}function f(p,o){var u=c(o,10),y=c(o,10),v=new THREE.LineBasicMaterial({color:16711680,linewidth:3});lineObj=new THREE.Line(u,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++){u=new THREE.Mesh(y,v);u.position.copy(o.points[i]);u.updateMatrix();p.addChild(u)}}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,x){var v={name:t,fps:0.6,length:x,hierarchy:[]},z,C=o.getControlPointsArray(),E=o.getLength(),J=C.length,U=0;z=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[z]={time:x,pos:C[z],rot:[0,0,0,1],scl:[1,1,1]};for(z=1;z<J-1;z++){U=x*E.chunks[z]/E.total;o.keys[z]={time:U,pos:C[z]}}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,
|
|
|
+x,v=new THREE.Geometry;for(t=0;t<p.points.length*o;t++){x=t/(p.points.length*o);x=p.getPoint(x);v.vertices[t]=new THREE.Vertex(new THREE.Vector3(x.x,x.y,x.z))}return v}function f(p,o){var t=c(o,10),x=c(o,10),v=new THREE.LineBasicMaterial({color:16711680,linewidth:3});lineObj=new THREE.Line(t,v);particleObj=new THREE.ParticleSystem(x,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);x=new Sphere(1,
|
|
|
+16,8);v=new THREE.MeshBasicMaterial({color:65280});for(i=0;i<o.points.length;i++){t=new THREE.Mesh(x,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,u){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,u)};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 x,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;x=this.phi%g;this.phi=x>=0?x:x+g;x=this.verticalAngleMap.srcRange;v=this.verticalAngleMap.dstRange;
|
|
|
+this.phi=(this.phi-x[0])*(v[1]-v[0])/(x[1]-x[0])+v[0];x=this.horizontalAngleMap.srcRange;v=this.horizontalAngleMap.dstRange;this.theta=(this.theta-x[0])*(v[1]-v[0])/(x[1]-x[0])+v[0];x=this.target.position;x.x=100*Math.sin(this.phi)*Math.cos(this.theta);x.y=100*Math.cos(this.phi);x.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(F,H,U,z,J,L,M,Fa){var oa,xa,Z=f||1,e=g||1,da=J/2,Ca=L/2,Aa=o.vertices.length;if(F=="x"&&H=="y"||F=="y"&&H=="x")oa="z";else if(F=="x"&&H=="z"||F=="z"&&H=="x"){oa="y";e=h||1}else if(F=="z"&&H=="y"||F=="y"&&H=="z"){oa="x";Z=h||1}var Ha=Z+1,qa=e+1;J/=Z;var $=L/e;for(xa=0;xa<qa;xa++)for(L=0;L<Ha;L++){var pa=new THREE.Vector3;pa[F]=(L*J-da)*U;pa[H]=(xa*$-Ca)*z;pa[oa]=M;o.vertices.push(new THREE.Vertex(pa))}for(xa=0;xa<e;xa++)for(L=0;L<Z;L++){o.faces.push(new THREE.Face4(L+
|
|
|
-Ha*xa+Aa,L+Ha*(xa+1)+Aa,L+1+Ha*(xa+1)+Aa,L+1+Ha*xa+Aa,null,null,Fa));o.faceVertexUvs[0].push([new THREE.UV(L/Z,xa/e),new THREE.UV(L/Z,(xa+1)/e),new THREE.UV((L+1)/Z,(xa+1)/e),new THREE.UV((L+1)/Z,xa/e)])}}THREE.Geometry.call(this);var o=this,u=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,-u,this.materials[0]);this.sides.nx&&p("z","y",-1*k,-1,c,d,u,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 F=[],H=[],U=0,z=o.vertices.length;U<z;U++){for(var J=o.vertices[U],L=!1,M=0,Fa=F.length;M<Fa;M++){var oa=
|
|
|
-F[M];if(J.position.x==oa.position.x&&J.position.y==oa.position.y&&J.position.z==oa.position.z){H[U]=M;L=!0;break}}if(!L){H[U]=F.length;F.push(new THREE.Vertex(J.position.clone()))}}U=0;for(z=o.faces.length;U<z;U++){J=o.faces[U];J.a=H[J.a];J.b=H[J.b];J.c=H[J.c];J.d=H[J.d]}o.vertices=F})();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,u,y){k.vertices.push(new THREE.Vertex(new THREE.Vector3(o,u,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));
|
|
|
+var Cube=function(b,d,c,f,g,h,j,k,n){function p(E,J,U,y,L,N,P,za){var va,ta,e=f||1,fa=g||1,ea=L/2,Aa=N/2,Ha=o.vertices.length;if(E=="x"&&J=="y"||E=="y"&&J=="x")va="z";else if(E=="x"&&J=="z"||E=="z"&&J=="x"){va="y";fa=h||1}else if(E=="z"&&J=="y"||E=="y"&&J=="z"){va="x";e=h||1}var Ia=e+1,ua=fa+1;L/=e;var ca=N/fa;for(ta=0;ta<ua;ta++)for(N=0;N<Ia;N++){var sa=new THREE.Vector3;sa[E]=(N*L-ea)*U;sa[J]=(ta*ca-Aa)*y;sa[va]=P;o.vertices.push(new THREE.Vertex(sa))}for(ta=0;ta<fa;ta++)for(N=0;N<e;N++){o.faces.push(new THREE.Face4(N+
|
|
|
+Ia*ta+Ha,N+Ia*(ta+1)+Ha,N+1+Ia*(ta+1)+Ha,N+1+Ia*ta+Ha,null,null,za));o.faceVertexUvs[0].push([new THREE.UV(N/e,ta/fa),new THREE.UV(N/e,(ta+1)/fa),new THREE.UV((N+1)/e,(ta+1)/fa),new THREE.UV((N+1)/e,ta/fa)])}}THREE.Geometry.call(this);var o=this,t=b/2,x=d/2,v=c/2;k=k?-1:1;if(j!==undefined)if(j instanceof Array)this.materials=j;else{this.materials=[];for(var z=0;z<6;z++)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,x,this.materials[2]);this.sides.ny&&p("x","z",1*k,-1,b,c,-x,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=[],U=0,y=o.vertices.length;U<y;U++){for(var L=o.vertices[U],N=!1,P=0,za=E.length;P<za;P++){var va=
|
|
|
+E[P];if(L.position.x==va.position.x&&L.position.y==va.position.y&&L.position.z==va.position.z){J[U]=P;N=!0;break}}if(!N){J[U]=E.length;E.push(new THREE.Vertex(L.position.clone()))}}U=0;for(y=o.faces.length;U<y;U++){L=o.faces[U];L.a=J[L.a];L.b=J[L.b];L.c=J[L.c];L.d=J[L.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,x){k.vertices.push(new THREE.Vertex(new THREE.Vector3(o,t,x)))}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(u,y,v){var B=Math.sqrt(u*u+y*y+v*v);return g.vertices.push(new THREE.Vertex(new THREE.Vector3(u/B,y/B,v/B)))-1}function c(u,y,v,B){B.faces.push(new THREE.Face3(u,y,v))}function f(u,y){var v=g.vertices[u].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,
|
|
|
+var Icosahedron=function(b){function d(t,x,v){var z=Math.sqrt(t*t+x*x+v*v);return g.vertices.push(new THREE.Vertex(new THREE.Vector3(t/z,x/z,v/z)))-1}function c(t,x,v,z){z.faces.push(new THREE.Face3(t,x,v))}function f(t,x){var v=g.vertices[t].position,z=g.vertices[x].position;return d((v.x+z.x)/2,(v.y+z.y)/2,(v.z+z.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 u=2*f/h,y=n*Math.sin(u*g);u=n*Math.cos(u*g);(c==0||c==j)&&f>0||(o=this.vertices.push(new THREE.Vertex(new THREE.Vector3(u,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;u=f/h;o=new THREE.UV(1-B,y);y=new THREE.UV(1-u,y);u=new THREE.UV(1-u,v);var F=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,u])}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,u,F])}}}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,x=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,x)))-1);p.push(o)}d.push(p)}var v,z,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];x=c/(g-1);v=(c-1)/(g-1);z=(f+1)/h;t=f/h;o=new THREE.UV(1-z,x);x=new THREE.UV(1-t,x);t=new THREE.UV(1-t,v);var E=new THREE.UV(1-z,v);if(c<d.length-1){v=this.vertices[j].position.clone();z=this.vertices[k].position.clone();C=this.vertices[n].position.clone();v.normalize();z.normalize();C.normalize();this.faces.push(new THREE.Face3(j,k,n,[new THREE.Vector3(v.x,v.y,v.z),new THREE.Vector3(z.x,z.y,z.z),new THREE.Vector3(C.x,C.y,C.z)]));this.faceVertexUvs[0].push([o,x,t])}if(c>1){v=this.vertices[j].position.clone();
|
|
|
+z=this.vertices[n].position.clone();C=this.vertices[p].position.clone();v.normalize();z.normalize();C.normalize();this.faces.push(new THREE.Face3(j,n,p,[new THREE.Vector3(v.x,v.y,v.z),new THREE.Vector3(z.x,z.y,z.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(u,y,v,B,C,F){y=v/B*u;v=Math.cos(y);return new THREE.Vector3(C*(2+v)*0.5*Math.cos(u),C*(2+v)*Math.sin(u)*0.5,F*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=
|
|
|
+var TorusKnot=function(b,d,c,f,g,h,j){function k(t,x,v,z,C,E){x=v/z*t;v=Math.cos(x);return new THREE.Vector3(C*(2+v)*0.5*Math.cos(t),C*(2+v)*Math.sin(t)*0.5,E*C*Math.sin(x)*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)),u=Math.pow(2,Math.round(Math.log(this.height)/
|
|
|
-Math.LN2));k.image.width=o;k.image.height=u;k.image.getContext("2d").drawImage(this,0,0,o,u)}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.blending)if(b.blending=="Additive")h.blending=THREE.AdditiveBlending;else if(b.blending=="Subtractive")h.blending=
|
|
|
+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.blending)if(b.blending=="Additive")h.blending=THREE.AdditiveBlending;else if(b.blending=="Subtractive")h.blending=
|
|
|
THREE.SubtractiveBlending;else if(b.blending=="Multiply")h.blending=THREE.MultiplyBlending;if(b.transparent!==undefined)h.transparent=b.transparent;if(b.depthTest!==undefined)h.depthTest=b.depthTest;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,u,y,v,B,C,F,H,U,z=b.faces;p=b.vertices;var J=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;u=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++){F=b.uvs[g];y=z[k++];U=F[y*2];y=F[y*2+1];f.faceUvs[g][j]=new THREE.UV(U,y)}if(h)for(g=0;g<M;g++){F=b.uvs[g];H=[];for(h=0;h<p;h++){y=z[k++];U=F[y*2];y=F[y*2+1];H[h]=new THREE.UV(U,
|
|
|
-y)}f.faceVertexUvs[g][j]=H}if(u){u=z[k++]*3;h=new THREE.Vector3;h.x=J[u++];h.y=J[u++];h.z=J[u];C.normal=h}if(o)for(g=0;g<p;g++){u=z[k++]*3;h=new THREE.Vector3;h.x=J[u++];h.y=J[u++];h.z=J[u];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,
|
|
|
+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,x,v,z,C,E,J,U,y=b.faces;p=b.vertices;var L=b.normals,N=b.colors,P=0;for(g=0;g<b.uvs.length;g++)b.uvs[g].length&&P++;for(g=0;g<P;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=y.length;k<n;){v=y[k++];p=v&1;j=v&2;g=v&4;h=v&8;t=v&16;o=v&32;z=v&64;v&=128;if(p){C=new THREE.Face4;C.a=y[k++];C.b=y[k++];C.c=y[k++];C.d=y[k++];p=4}else{C=new THREE.Face3;C.a=y[k++];C.b=y[k++];C.c=y[k++];p=3}if(j){j=y[k++];C.materials=f.materials[j]}j=f.faces.length;if(g)for(g=0;g<P;g++){E=b.uvs[g];x=y[k++];U=E[x*2];x=E[x*2+1];f.faceUvs[g][j]=new THREE.UV(U,x)}if(h)for(g=0;g<P;g++){E=b.uvs[g];J=[];for(h=0;h<p;h++){x=y[k++];U=E[x*2];x=E[x*2+1];J[h]=new THREE.UV(U,
|
|
|
+x)}f.faceVertexUvs[g][j]=J}if(t){t=y[k++]*3;h=new THREE.Vector3;h.x=L[t++];h.y=L[t++];h.z=L[t];C.normal=h}if(o)for(g=0;g<p;g++){t=y[k++]*3;h=new THREE.Vector3;h.x=L[t++];h.y=L[t++];h.z=L[t];C.vertexNormals.push(h)}if(z){o=new THREE.Color(y[k++]);C.color=o}if(v)for(g=0;g<p;g++){o=y[k++];o=new THREE.Color(N[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,X){var ma=o(N,X),Ea=o(N,X+1),Ka=o(N,X+2),ya=o(N,X+3),ia=(ya<<1&255|Ka>>7)-127;ma|=(Ka&127)<<16|Ea<<8;if(ma==0&&ia==-127)return 0;return(1-2*(ya>>7))*(1+ma*Math.pow(2,-23))*Math.pow(2,ia)}function k(N,X){var ma=o(N,X),Ea=o(N,X+1),Ka=o(N,X+2);return(o(N,X+3)<<24)+(Ka<<16)+(Ea<<8)+ma}function n(N,X){var ma=o(N,X);return(o(N,X+1)<<8)+ma}function p(N,X){var ma=o(N,X);return ma>
|
|
|
-127?ma-256:ma}function o(N,X){return N.charCodeAt(X)&255}function u(N){var X,ma,Ea;X=k(b,N);ma=k(b,N+M);Ea=k(b,N+Fa);N=n(b,N+oa);THREE.BinaryLoader.prototype.f3(H,X,ma,Ea,N)}function y(N){var X,ma,Ea,Ka,ya,ia;X=k(b,N);ma=k(b,N+M);Ea=k(b,N+Fa);Ka=n(b,N+oa);ya=k(b,N+xa);ia=k(b,N+Z);N=k(b,N+e);THREE.BinaryLoader.prototype.f3n(H,J,X,ma,Ea,Ka,ya,ia,N)}function v(N){var X,ma,Ea,Ka;X=k(b,N);ma=k(b,N+da);Ea=k(b,N+Ca);Ka=k(b,N+Aa);N=n(b,N+Ha);THREE.BinaryLoader.prototype.f4(H,X,ma,Ea,Ka,N)}function B(N){var X,
|
|
|
-ma,Ea,Ka,ya,ia,m,A;X=k(b,N);ma=k(b,N+da);Ea=k(b,N+Ca);Ka=k(b,N+Aa);ya=n(b,N+Ha);ia=k(b,N+qa);m=k(b,N+$);A=k(b,N+pa);N=k(b,N+Da);THREE.BinaryLoader.prototype.f4n(H,J,X,ma,Ea,Ka,ya,ia,m,A,N)}function C(N){var X,ma;X=k(b,N);ma=k(b,N+ga);N=k(b,N+Y);THREE.BinaryLoader.prototype.uv3(H.faceVertexUvs[0],L[X*2],L[X*2+1],L[ma*2],L[ma*2+1],L[N*2],L[N*2+1])}function F(N){var X,ma,Ea;X=k(b,N);ma=k(b,N+la);Ea=k(b,N+Ga);N=k(b,N+ka);THREE.BinaryLoader.prototype.uv4(H.faceVertexUvs[0],L[X*2],L[X*2+1],L[ma*2],L[ma*
|
|
|
-2+1],L[Ea*2],L[Ea*2+1],L[N*2],L[N*2+1])}var H=this,U=0,z,J=[],L=[],M,Fa,oa,xa,Z,e,da,Ca,Aa,Ha,qa,$,pa,Da,ga,Y,la,Ga,ka,na,wa,Ua,cb,ab,Pa;THREE.Geometry.call(this);THREE.Loader.prototype.init_materials(H,f,h);z={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+=z.header_bytes;M=z.vertex_index_bytes;Fa=z.vertex_index_bytes*2;oa=z.vertex_index_bytes*3;xa=z.vertex_index_bytes*3+z.material_index_bytes;Z=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;da=z.vertex_index_bytes;Ca=z.vertex_index_bytes*2;Aa=z.vertex_index_bytes*3;Ha=z.vertex_index_bytes*4;qa=z.vertex_index_bytes*4+z.material_index_bytes;$=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes;pa=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*2;Da=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*3;ga=z.uv_index_bytes;Y=z.uv_index_bytes*2;la=z.uv_index_bytes;Ga=z.uv_index_bytes*2;ka=z.uv_index_bytes*3;h=z.vertex_index_bytes*3+z.material_index_bytes;
|
|
|
-Pa=z.vertex_index_bytes*4+z.material_index_bytes;na=z.ntri_flat*h;wa=z.ntri_smooth*(h+z.normal_index_bytes*3);Ua=z.ntri_flat_uv*(h+z.uv_index_bytes*3);cb=z.ntri_smooth_uv*(h+z.normal_index_bytes*3+z.uv_index_bytes*3);ab=z.nquad_flat*Pa;h=z.nquad_smooth*(Pa+z.normal_index_bytes*4);Pa=z.nquad_flat_uv*(Pa+z.uv_index_bytes*4);U+=function(N){for(var X,ma,Ea,Ka=z.vertex_coordinate_bytes*3,ya=N+z.nvertices*Ka;N<ya;N+=Ka){X=j(b,N);ma=j(b,N+z.vertex_coordinate_bytes);Ea=j(b,N+z.vertex_coordinate_bytes*2);
|
|
|
-THREE.BinaryLoader.prototype.v(H,X,ma,Ea)}return z.nvertices*Ka}(U);U+=function(N){for(var X,ma,Ea,Ka=z.normal_coordinate_bytes*3,ya=N+z.nnormals*Ka;N<ya;N+=Ka){X=p(b,N);ma=p(b,N+z.normal_coordinate_bytes);Ea=p(b,N+z.normal_coordinate_bytes*2);J.push(X/127,ma/127,Ea/127)}return z.nnormals*Ka}(U);U+=function(N){for(var X,ma,Ea=z.uv_coordinate_bytes*2,Ka=N+z.nuvs*Ea;N<Ka;N+=Ea){X=j(b,N);ma=j(b,N+z.uv_coordinate_bytes);L.push(X,ma)}return z.nuvs*Ea}(U);na=U+na;wa=na+wa;Ua=wa+Ua;cb=Ua+cb;ab=cb+ab;h=ab+
|
|
|
-h;Pa=h+Pa;(function(N){var X,ma=z.vertex_index_bytes*3+z.material_index_bytes,Ea=ma+z.uv_index_bytes*3,Ka=N+z.ntri_flat_uv*Ea;for(X=N;X<Ka;X+=Ea){u(X);C(X+ma)}return Ka-N})(wa);(function(N){var X,ma=z.vertex_index_bytes*3+z.material_index_bytes+z.normal_index_bytes*3,Ea=ma+z.uv_index_bytes*3,Ka=N+z.ntri_smooth_uv*Ea;for(X=N;X<Ka;X+=Ea){y(X);C(X+ma)}return Ka-N})(Ua);(function(N){var X,ma=z.vertex_index_bytes*4+z.material_index_bytes,Ea=ma+z.uv_index_bytes*4,Ka=N+z.nquad_flat_uv*Ea;for(X=N;X<Ka;X+=
|
|
|
-Ea){v(X);F(X+ma)}return Ka-N})(h);(function(N){var X,ma=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*4,Ea=ma+z.uv_index_bytes*4,Ka=N+z.nquad_smooth_uv*Ea;for(X=N;X<Ka;X+=Ea){B(X);F(X+ma)}return Ka-N})(Pa);(function(N){var X,ma=z.vertex_index_bytes*3+z.material_index_bytes,Ea=N+z.ntri_flat*ma;for(X=N;X<Ea;X+=ma)u(X);return Ea-N})(U);(function(N){var X,ma=z.vertex_index_bytes*3+z.material_index_bytes+z.normal_index_bytes*3,Ea=N+z.ntri_smooth*ma;for(X=N;X<Ea;X+=ma)y(X);return Ea-
|
|
|
-N})(na);(function(N){var X,ma=z.vertex_index_bytes*4+z.material_index_bytes,Ea=N+z.nquad_flat*ma;for(X=N;X<Ea;X+=ma)v(X);return Ea-N})(cb);(function(N){var X,ma=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*4,Ea=N+z.nquad_smooth*ma;for(X=N;X<Ea;X+=ma)B(X);return Ea-N})(ab);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 u=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(u,y,n)],null,h))},f4n:function(b,d,c,f,g,h,j,k,n,p,o){j=b.materials[j];var u=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],F=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(u,y,n),new THREE.Vector3(v,B,p),new THREE.Vector3(C,F,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(O,aa){var qa=o(O,aa),Da=o(O,aa+1),ha=o(O,aa+2),la=o(O,aa+3),m=(la<<1&255|ha>>7)-127;qa|=(ha&127)<<16|Da<<8;if(qa==0&&m==-127)return 0;return(1-2*(la>>7))*(1+qa*Math.pow(2,-23))*Math.pow(2,m)}function k(O,aa){var qa=o(O,aa),Da=o(O,aa+1),ha=o(O,aa+2);return(o(O,aa+3)<<24)+(ha<<16)+(Da<<8)+qa}function n(O,aa){var qa=o(O,aa);return(o(O,aa+1)<<8)+qa}function p(O,aa){var qa=o(O,aa);
|
|
|
+return qa>127?qa-256:qa}function o(O,aa){return O.charCodeAt(aa)&255}function t(O){var aa,qa,Da;aa=k(b,O);qa=k(b,O+P);Da=k(b,O+za);O=n(b,O+va);THREE.BinaryLoader.prototype.f3(J,aa,qa,Da,O)}function x(O){var aa,qa,Da,ha,la,m;aa=k(b,O);qa=k(b,O+P);Da=k(b,O+za);ha=n(b,O+va);la=k(b,O+ta);m=k(b,O+e);O=k(b,O+fa);THREE.BinaryLoader.prototype.f3n(J,L,aa,qa,Da,ha,la,m,O)}function v(O){var aa,qa,Da,ha;aa=k(b,O);qa=k(b,O+ea);Da=k(b,O+Aa);ha=k(b,O+Ha);O=n(b,O+Ia);THREE.BinaryLoader.prototype.f4(J,aa,qa,Da,ha,
|
|
|
+O)}function z(O){var aa,qa,Da,ha,la,m,B,w;aa=k(b,O);qa=k(b,O+ea);Da=k(b,O+Aa);ha=k(b,O+Ha);la=n(b,O+Ia);m=k(b,O+ua);B=k(b,O+ca);w=k(b,O+sa);O=k(b,O+Ba);THREE.BinaryLoader.prototype.f4n(J,L,aa,qa,Da,ha,la,m,B,w,O)}function C(O){var aa,qa;aa=k(b,O);qa=k(b,O+ja);O=k(b,O+$);THREE.BinaryLoader.prototype.uv3(J.faceVertexUvs[0],N[aa*2],N[aa*2+1],N[qa*2],N[qa*2+1],N[O*2],N[O*2+1])}function E(O){var aa,qa,Da;aa=k(b,O);qa=k(b,O+pa);Da=k(b,O+Fa);O=k(b,O+ka);THREE.BinaryLoader.prototype.uv4(J.faceVertexUvs[0],
|
|
|
+N[aa*2],N[aa*2+1],N[qa*2],N[qa*2+1],N[Da*2],N[Da*2+1],N[O*2],N[O*2+1])}var J=this,U=0,y,L=[],N=[],P,za,va,ta,e,fa,ea,Aa,Ha,Ia,ua,ca,sa,Ba,ja,$,pa,Fa,ka,oa,Ga,Ra,Za,Va,Sa;THREE.Geometry.call(this);THREE.Loader.prototype.init_materials(J,f,h);y={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+=y.header_bytes;P=y.vertex_index_bytes;za=y.vertex_index_bytes*2;va=y.vertex_index_bytes*3;ta=y.vertex_index_bytes*3+y.material_index_bytes;e=y.vertex_index_bytes*3+y.material_index_bytes+y.normal_index_bytes;fa=y.vertex_index_bytes*
|
|
|
+3+y.material_index_bytes+y.normal_index_bytes*2;ea=y.vertex_index_bytes;Aa=y.vertex_index_bytes*2;Ha=y.vertex_index_bytes*3;Ia=y.vertex_index_bytes*4;ua=y.vertex_index_bytes*4+y.material_index_bytes;ca=y.vertex_index_bytes*4+y.material_index_bytes+y.normal_index_bytes;sa=y.vertex_index_bytes*4+y.material_index_bytes+y.normal_index_bytes*2;Ba=y.vertex_index_bytes*4+y.material_index_bytes+y.normal_index_bytes*3;ja=y.uv_index_bytes;$=y.uv_index_bytes*2;pa=y.uv_index_bytes;Fa=y.uv_index_bytes*2;ka=y.uv_index_bytes*
|
|
|
+3;h=y.vertex_index_bytes*3+y.material_index_bytes;Sa=y.vertex_index_bytes*4+y.material_index_bytes;oa=y.ntri_flat*h;Ga=y.ntri_smooth*(h+y.normal_index_bytes*3);Ra=y.ntri_flat_uv*(h+y.uv_index_bytes*3);Za=y.ntri_smooth_uv*(h+y.normal_index_bytes*3+y.uv_index_bytes*3);Va=y.nquad_flat*Sa;h=y.nquad_smooth*(Sa+y.normal_index_bytes*4);Sa=y.nquad_flat_uv*(Sa+y.uv_index_bytes*4);U+=function(O){for(var aa,qa,Da,ha=y.vertex_coordinate_bytes*3,la=O+y.nvertices*ha;O<la;O+=ha){aa=j(b,O);qa=j(b,O+y.vertex_coordinate_bytes);
|
|
|
+Da=j(b,O+y.vertex_coordinate_bytes*2);THREE.BinaryLoader.prototype.v(J,aa,qa,Da)}return y.nvertices*ha}(U);U+=function(O){for(var aa,qa,Da,ha=y.normal_coordinate_bytes*3,la=O+y.nnormals*ha;O<la;O+=ha){aa=p(b,O);qa=p(b,O+y.normal_coordinate_bytes);Da=p(b,O+y.normal_coordinate_bytes*2);L.push(aa/127,qa/127,Da/127)}return y.nnormals*ha}(U);U+=function(O){for(var aa,qa,Da=y.uv_coordinate_bytes*2,ha=O+y.nuvs*Da;O<ha;O+=Da){aa=j(b,O);qa=j(b,O+y.uv_coordinate_bytes);N.push(aa,qa)}return y.nuvs*Da}(U);oa=
|
|
|
+U+oa;Ga=oa+Ga;Ra=Ga+Ra;Za=Ra+Za;Va=Za+Va;h=Va+h;Sa=h+Sa;(function(O){var aa,qa=y.vertex_index_bytes*3+y.material_index_bytes,Da=qa+y.uv_index_bytes*3,ha=O+y.ntri_flat_uv*Da;for(aa=O;aa<ha;aa+=Da){t(aa);C(aa+qa)}return ha-O})(Ga);(function(O){var aa,qa=y.vertex_index_bytes*3+y.material_index_bytes+y.normal_index_bytes*3,Da=qa+y.uv_index_bytes*3,ha=O+y.ntri_smooth_uv*Da;for(aa=O;aa<ha;aa+=Da){x(aa);C(aa+qa)}return ha-O})(Ra);(function(O){var aa,qa=y.vertex_index_bytes*4+y.material_index_bytes,Da=qa+
|
|
|
+y.uv_index_bytes*4,ha=O+y.nquad_flat_uv*Da;for(aa=O;aa<ha;aa+=Da){v(aa);E(aa+qa)}return ha-O})(h);(function(O){var aa,qa=y.vertex_index_bytes*4+y.material_index_bytes+y.normal_index_bytes*4,Da=qa+y.uv_index_bytes*4,ha=O+y.nquad_smooth_uv*Da;for(aa=O;aa<ha;aa+=Da){z(aa);E(aa+qa)}return ha-O})(Sa);(function(O){var aa,qa=y.vertex_index_bytes*3+y.material_index_bytes,Da=O+y.ntri_flat*qa;for(aa=O;aa<Da;aa+=qa)t(aa);return Da-O})(U);(function(O){var aa,qa=y.vertex_index_bytes*3+y.material_index_bytes+y.normal_index_bytes*
|
|
|
+3,Da=O+y.ntri_smooth*qa;for(aa=O;aa<Da;aa+=qa)x(aa);return Da-O})(oa);(function(O){var aa,qa=y.vertex_index_bytes*4+y.material_index_bytes,Da=O+y.nquad_flat*qa;for(aa=O;aa<Da;aa+=qa)v(aa);return Da-O})(Za);(function(O){var aa,qa=y.vertex_index_bytes*4+y.material_index_bytes+y.normal_index_bytes*4,Da=O+y.nquad_smooth*qa;for(aa=O;aa<Da;aa+=qa)z(aa);return Da-O})(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],x=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,x,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],x=d[n*3+1];n=d[n*3+2];var v=d[p*3],z=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,x,n),new THREE.Vector3(v,z,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,u){j=(j-o)/(u-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,u){j=(j-o)/(u-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,u){j=(j-o)/(u-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,u=n+this.yd,y=n+this.zd,v=h+this.yd+this.zd,B=n+this.yd+this.zd,C=0,F=this.field[h],H=this.field[n],U=this.field[p],z=this.field[u],J=this.field[o],L=this.field[y],M=this.field[v],Fa=this.field[B];F<j&&(C|=1);H<j&&(C|=2);U<j&&(C|=8);z<j&&(C|=4);J<j&&(C|=16);L<j&&(C|=32);M<j&&(C|=128);Fa<j&&(C|=64);var oa=THREE.edgeTable[C];if(oa==0)return 0;
|
|
|
-var xa=this.delta,Z=c+xa,e=f+xa;xa=g+xa;if(oa&1){this.compNorm(h);this.compNorm(n);this.VIntX(h*3,this.vlist,this.nlist,0,j,c,f,g,F,H)}if(oa&2){this.compNorm(n);this.compNorm(u);this.VIntY(n*3,this.vlist,this.nlist,3,j,Z,f,g,H,z)}if(oa&4){this.compNorm(p);this.compNorm(u);this.VIntX(p*3,this.vlist,this.nlist,6,j,c,e,g,U,z)}if(oa&8){this.compNorm(h);this.compNorm(p);this.VIntY(h*3,this.vlist,this.nlist,9,j,c,f,g,F,U)}if(oa&16){this.compNorm(o);this.compNorm(y);this.VIntX(o*3,this.vlist,this.nlist,
|
|
|
-12,j,c,f,xa,J,L)}if(oa&32){this.compNorm(y);this.compNorm(B);this.VIntY(y*3,this.vlist,this.nlist,15,j,Z,f,xa,L,Fa)}if(oa&64){this.compNorm(v);this.compNorm(B);this.VIntX(v*3,this.vlist,this.nlist,18,j,c,e,xa,M,Fa)}if(oa&128){this.compNorm(o);this.compNorm(v);this.VIntY(o*3,this.vlist,this.nlist,21,j,c,f,xa,J,M)}if(oa&256){this.compNorm(h);this.compNorm(o);this.VIntZ(h*3,this.vlist,this.nlist,24,j,c,f,g,F,J)}if(oa&512){this.compNorm(n);this.compNorm(y);this.VIntZ(n*3,this.vlist,this.nlist,27,j,Z,
|
|
|
-f,g,H,L)}if(oa&1024){this.compNorm(u);this.compNorm(B);this.VIntZ(u*3,this.vlist,this.nlist,30,j,Z,e,g,z,Fa)}if(oa&2048){this.compNorm(p);this.compNorm(v);this.VIntZ(p*3,this.vlist,this.nlist,33,j,c,e,g,U,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+
|
|
|
+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,x=n+this.zd,v=h+this.yd+this.zd,z=n+this.yd+this.zd,C=0,E=this.field[h],J=this.field[n],U=this.field[p],y=this.field[t],L=this.field[o],N=this.field[x],P=this.field[v],za=this.field[z];E<j&&(C|=1);J<j&&(C|=2);U<j&&(C|=8);y<j&&(C|=4);L<j&&(C|=16);N<j&&(C|=32);P<j&&(C|=128);za<j&&(C|=64);var va=THREE.edgeTable[C];if(va==0)return 0;
|
|
|
+var ta=this.delta,e=c+ta,fa=f+ta;ta=g+ta;if(va&1){this.compNorm(h);this.compNorm(n);this.VIntX(h*3,this.vlist,this.nlist,0,j,c,f,g,E,J)}if(va&2){this.compNorm(n);this.compNorm(t);this.VIntY(n*3,this.vlist,this.nlist,3,j,e,f,g,J,y)}if(va&4){this.compNorm(p);this.compNorm(t);this.VIntX(p*3,this.vlist,this.nlist,6,j,c,fa,g,U,y)}if(va&8){this.compNorm(h);this.compNorm(p);this.VIntY(h*3,this.vlist,this.nlist,9,j,c,f,g,E,U)}if(va&16){this.compNorm(o);this.compNorm(x);this.VIntX(o*3,this.vlist,this.nlist,
|
|
|
+12,j,c,f,ta,L,N)}if(va&32){this.compNorm(x);this.compNorm(z);this.VIntY(x*3,this.vlist,this.nlist,15,j,e,f,ta,N,za)}if(va&64){this.compNorm(v);this.compNorm(z);this.VIntX(v*3,this.vlist,this.nlist,18,j,c,fa,ta,P,za)}if(va&128){this.compNorm(o);this.compNorm(v);this.VIntY(o*3,this.vlist,this.nlist,21,j,c,f,ta,L,P)}if(va&256){this.compNorm(h);this.compNorm(o);this.VIntZ(h*3,this.vlist,this.nlist,24,j,c,f,g,E,L)}if(va&512){this.compNorm(n);this.compNorm(x);this.VIntZ(n*3,this.vlist,this.nlist,27,j,e,
|
|
|
+f,g,J,N)}if(va&1024){this.compNorm(t);this.compNorm(z);this.VIntZ(t*3,this.vlist,this.nlist,30,j,e,fa,g,y,za)}if(va&2048){this.compNorm(p);this.compNorm(v);this.VIntZ(p*3,this.vlist,this.nlist,33,j,c,fa,g,U,P)}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,u=Math.floor(n-k);u<1&&(u=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,F,H,U,z;u<n;u++){o=this.size2*u;C=u/this.size-g;U=C*C;for(C=y;C<p;C++){F=o+this.size*C;B=C/this.size-f;z=B*B;for(B=v;B<k;B++){H=B/this.size-c;H=h/(1.0E-6+H*H+z+U)-j;H>0&&(this.field[F+B]+=H)}}}};this.addPlaneX=function(c,f){var g,h,j,k,n,p=this.size,o=this.yd,u=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[u*j+n]+=k}}};this.addPlaneY=function(c,f){var g,h,j,k,n,p,o=this.size,u=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*u;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,u,y=this.size-2;for(j=1;j<y;j++){u=this.size2*j;p=(j-this.halfsize)/this.halfsize;for(h=1;h<y;h++){o=u+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,u,y;for(h=0;h<g.count;h++){p=h*3;u=p+1;y=p+2;j=g.positionArray[p];k=g.positionArray[u];n=g.positionArray[y];o=new THREE.Vector3(j,k,n);j=g.normalArray[p];k=g.normalArray[u];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;u=p+1;y=p+2;o=f.vertices[p].normal;j=f.vertices[u].normal;k=f.vertices[y].normal;p=new THREE.Face3(p,u,y,[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 x=Math.floor(p-k);x<1&&(x=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 z,C,E,J,U,y;t<n;t++){o=this.size2*t;C=t/this.size-g;U=C*C;for(C=x;C<p;C++){E=o+this.size*C;z=C/this.size-f;y=z*z;for(z=v;z<k;z++){J=z/this.size-c;J=h/(1.0E-6+J*J+y+U)-j;J>0&&(this.field[E+z]+=J)}}}};this.addPlaneX=function(c,f){var g,h,j,k,n,p=this.size,o=this.yd,t=this.zd,x=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++)x[t*j+n]+=k}}};this.addPlaneY=function(c,f){var g,h,j,k,n,p,o=this.size,t=this.yd,x=this.zd,v=this.field,z=o*Math.sqrt(c/f);z>o&&(z=o);for(h=0;h<z;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[x*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,x=this.size-2;for(j=1;j<x;j++){t=this.size2*j;p=(j-this.halfsize)/this.halfsize;for(h=1;h<x;h++){o=t+this.size*h;n=(h-this.halfsize)/this.halfsize;for(g=1;g<x;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,x;for(h=0;h<g.count;h++){p=h*3;t=p+1;x=p+2;j=g.positionArray[p];k=g.positionArray[t];n=g.positionArray[x];o=new THREE.Vector3(j,k,n);j=g.normalArray[p];k=g.normalArray[t];n=g.normalArray[x];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;x=p+2;o=f.vertices[p].normal;j=f.vertices[t].normal;k=f.vertices[x].normal;p=new THREE.Face3(p,t,x,[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,
|