diff --git a/build/Three.js b/build/Three.js index e8a81a57373fc628afb1d1a2976480ac159f001d..7168713ce9e70bed78eeebf9cb048292340c82fa 100755 --- a/build/Three.js +++ b/build/Three.js @@ -12,21 +12,21 @@ this.length();a>0?this.multiplyScalar(1/a):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(a,c,b,e){this.set(a||0,c||0,b||0,e||1)}; THREE.Vector4.prototype={set:function(a,c,b,e){this.x=a;this.y=c;this.z=b;this.w=e;return this},copy:function(a){this.set(a.x,a.y,a.z,a.w||1);return this},add:function(a,c){this.set(a.x+c.x,a.y+c.y,a.z+c.z,a.w+c.w);return this},addSelf:function(a){this.set(this.x+a.x,this.y+a.y,this.z+a.z,this.w+a.w);return this},sub:function(a,c){this.set(a.x-c.x,a.y-c.y,a.z-c.z,a.w-c.w);return this},subSelf:function(a){this.set(this.x-a.x,this.y-a.y,this.z-a.z,this.w-a.w);return this},multiplyScalar:function(a){this.set(this.x* a,this.y*a,this.z*a,this.w*a);return this},divideScalar:function(a){this.set(this.x/a,this.y/a,this.z/a,this.w/a);return this},lerpSelf:function(a,c){this.set(this.x+(a.x-this.x)*c,this.y+(a.y-this.y)*c,this.z+(a.z-this.z)*c,this.w+(a.w-this.w)*c)},clone:function(){return new THREE.Vector4(this.x,this.y,this.z,this.w)}};THREE.Ray=function(a,c){this.origin=a||new THREE.Vector3;this.direction=c||new THREE.Vector3}; -THREE.Ray.prototype={intersectScene:function(a){var c,b,e=a.objects,f=[];a=0;for(c=e.length;a0&&G>0&&Q+G<1}var b,e,f,g,h,j,m,o,n,t, -x,w=a.geometry,A=w.vertices,F=[];b=0;for(e=w.faces.length;b0&&G>0&&N+G<1}var b,e,f,g,h,j,m,o,n,t, +y,w=a.geometry,z=w.vertices,E=[];b=0;for(e=w.faces.length;bm?e:m;f=f>o?f:o}a()}; -this.add3Points=function(m,o,n,t,x,w){if(j){j=!1;c=mn?m>x?m:x:n>x?n:x;f=o>t?o>w?o:w:t>w?t:w}else{c=mn?m>x?m>e?m:e:x>e?x:e:n>x?n>e?n:e:x>e?x:e;f=o>t?o>w?o>f?o:f:w>f?w:f:t>w?t>f?t:f:w>f?w:f}a()};this.addRectangle=function(m){if(j){j=!1;c=m.getLeft();b=m.getTop();e=m.getRight();f=m.getBottom()}else{c=cm.getRight()? +this.add3Points=function(m,o,n,t,y,w){if(j){j=!1;c=mn?m>y?m:y:n>y?n:y;f=o>t?o>w?o:w:t>w?t:w}else{c=mn?m>y?m>e?m:e:y>e?y:e:n>y?n>e?n:e:y>e?y:e;f=o>t?o>w?o>f?o:f:w>f?w:f:t>w?t>f?t:f:w>f?w:f}a()};this.addRectangle=function(m){if(j){j=!1;c=m.getLeft();b=m.getTop();e=m.getRight();f=m.getBottom()}else{c=cm.getRight()? e:m.getRight();f=f>m.getBottom()?f:m.getBottom()}a()};this.inflate=function(m){c-=m;b-=m;e+=m;f+=m;a()};this.minSelf=function(m){c=c>m.getLeft()?c:m.getLeft();b=b>m.getTop()?b:m.getTop();e=e=0&&Math.min(f,m.getBottom())-Math.max(b,m.getTop())>=0};this.empty=function(){j=!0;f=e=b=c=0;a()};this.isEmpty=function(){return j}}; THREE.Matrix3=function(){this.m=[]};THREE.Matrix3.prototype={transpose:function(){var a,c=this.m;a=c[1];c[1]=c[3];c[3]=a;a=c[2];c[2]=c[6];c[6]=a;a=c[5];c[5]=c[7];c[7]=a;return this},transposeIntoArray:function(a){var c=this.m;a[0]=c[0];a[1]=c[3];a[2]=c[6];a[3]=c[1];a[4]=c[4];a[5]=c[7];a[6]=c[2];a[7]=c[5];a[8]=c[8];return this}}; -THREE.Matrix4=function(a,c,b,e,f,g,h,j,m,o,n,t,x,w,A,F){this.set(a||1,c||0,b||0,e||0,f||0,g||1,h||0,j||0,m||0,o||0,n||1,t||0,x||0,w||0,A||0,F||1);this.flat=Array(16);this.m33=new THREE.Matrix3}; -THREE.Matrix4.prototype={set:function(a,c,b,e,f,g,h,j,m,o,n,t,x,w,A,F){this.n11=a;this.n12=c;this.n13=b;this.n14=e;this.n21=f;this.n22=g;this.n23=h;this.n24=j;this.n31=m;this.n32=o;this.n33=n;this.n34=t;this.n41=x;this.n42=w;this.n43=A;this.n44=F;return this},identity:function(){this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);return this},copy:function(a){this.set(a.n11,a.n12,a.n13,a.n14,a.n21,a.n22,a.n23,a.n24,a.n31,a.n32,a.n33,a.n34,a.n41,a.n42,a.n43,a.n44);return this},lookAt:function(a,c,b){var e=THREE.Matrix4.__v1, +THREE.Matrix4=function(a,c,b,e,f,g,h,j,m,o,n,t,y,w,z,E){this.set(a||1,c||0,b||0,e||0,f||0,g||1,h||0,j||0,m||0,o||0,n||1,t||0,y||0,w||0,z||0,E||1);this.flat=Array(16);this.m33=new THREE.Matrix3}; +THREE.Matrix4.prototype={set:function(a,c,b,e,f,g,h,j,m,o,n,t,y,w,z,E){this.n11=a;this.n12=c;this.n13=b;this.n14=e;this.n21=f;this.n22=g;this.n23=h;this.n24=j;this.n31=m;this.n32=o;this.n33=n;this.n34=t;this.n41=y;this.n42=w;this.n43=z;this.n44=E;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(a){this.set(a.n11,a.n12,a.n13,a.n14,a.n21,a.n22,a.n23,a.n24,a.n31,a.n32,a.n33,a.n34,a.n41,a.n42,a.n43,a.n44);return this},lookAt:function(a,c,b){var e=THREE.Matrix4.__v1, f=THREE.Matrix4.__v2,g=THREE.Matrix4.__v3;g.sub(a,c).normalize();if(g.length()===0)g.z=1;e.cross(b,g).normalize();if(e.length()===0){g.x+=1.0E-4;e.cross(b,g).normalize()}f.cross(g,e).normalize();this.n11=e.x;this.n12=f.x;this.n13=g.x;this.n21=e.y;this.n22=f.y;this.n23=g.y;this.n31=e.z;this.n32=f.z;this.n33=g.z;return this},multiplyVector3:function(a){var c=a.x,b=a.y,e=a.z,f=1/(this.n41*c+this.n42*b+this.n43*e+this.n44);a.x=(this.n11*c+this.n12*b+this.n13*e+this.n14)*f;a.y=(this.n21*c+this.n22*b+this.n23* e+this.n24)*f;a.z=(this.n31*c+this.n32*b+this.n33*e+this.n34)*f;return a},multiplyVector4:function(a){var c=a.x,b=a.y,e=a.z,f=a.w;a.x=this.n11*c+this.n12*b+this.n13*e+this.n14*f;a.y=this.n21*c+this.n22*b+this.n23*e+this.n24*f;a.z=this.n31*c+this.n32*b+this.n33*e+this.n34*f;a.w=this.n41*c+this.n42*b+this.n43*e+this.n44*f;return a},rotateAxis:function(a){var c=a.x,b=a.y,e=a.z;a.x=c*this.n11+b*this.n12+e*this.n13;a.y=c*this.n21+b*this.n22+e*this.n23;a.z=c*this.n31+b*this.n32+e*this.n33;a.normalize(); -return a},crossVector:function(a){var c=new THREE.Vector4;c.x=this.n11*a.x+this.n12*a.y+this.n13*a.z+this.n14*a.w;c.y=this.n21*a.x+this.n22*a.y+this.n23*a.z+this.n24*a.w;c.z=this.n31*a.x+this.n32*a.y+this.n33*a.z+this.n34*a.w;c.w=a.w?this.n41*a.x+this.n42*a.y+this.n43*a.z+this.n44*a.w:1;return c},multiply:function(a,c){var b=a.n11,e=a.n12,f=a.n13,g=a.n14,h=a.n21,j=a.n22,m=a.n23,o=a.n24,n=a.n31,t=a.n32,x=a.n33,w=a.n34,A=a.n41,F=a.n42,G=a.n43,K=a.n44,O=c.n11,z=c.n12,P=c.n13,Q=c.n14,R=c.n21,Da=c.n22, -ha=c.n23,na=c.n24,Y=c.n31,d=c.n32,$=c.n33,ya=c.n34;this.n11=b*O+e*R+f*Y;this.n12=b*z+e*Da+f*d;this.n13=b*P+e*ha+f*$;this.n14=b*Q+e*na+f*ya+g;this.n21=h*O+j*R+m*Y;this.n22=h*z+j*Da+m*d;this.n23=h*P+j*ha+m*$;this.n24=h*Q+j*na+m*ya+o;this.n31=n*O+t*R+x*Y;this.n32=n*z+t*Da+x*d;this.n33=n*P+t*ha+x*$;this.n34=n*Q+t*na+x*ya+w;this.n41=A*O+F*R+G*Y;this.n42=A*z+F*Da+G*d;this.n43=A*P+F*ha+G*$;this.n44=A*Q+F*na+G*ya+K;return this},multiplyToArray:function(a,c,b){this.multiply(a,c);b[0]=this.n11;b[1]=this.n21; +return a},crossVector:function(a){var c=new THREE.Vector4;c.x=this.n11*a.x+this.n12*a.y+this.n13*a.z+this.n14*a.w;c.y=this.n21*a.x+this.n22*a.y+this.n23*a.z+this.n24*a.w;c.z=this.n31*a.x+this.n32*a.y+this.n33*a.z+this.n34*a.w;c.w=a.w?this.n41*a.x+this.n42*a.y+this.n43*a.z+this.n44*a.w:1;return c},multiply:function(a,c){var b=a.n11,e=a.n12,f=a.n13,g=a.n14,h=a.n21,j=a.n22,m=a.n23,o=a.n24,n=a.n31,t=a.n32,y=a.n33,w=a.n34,z=a.n41,E=a.n42,G=a.n43,J=a.n44,S=c.n11,D=c.n12,L=c.n13,N=c.n14,O=c.n21,Fa=c.n22, +oa=c.n23,xa=c.n24,W=c.n31,d=c.n32,Z=c.n33,ya=c.n34;this.n11=b*S+e*O+f*W;this.n12=b*D+e*Fa+f*d;this.n13=b*L+e*oa+f*Z;this.n14=b*N+e*xa+f*ya+g;this.n21=h*S+j*O+m*W;this.n22=h*D+j*Fa+m*d;this.n23=h*L+j*oa+m*Z;this.n24=h*N+j*xa+m*ya+o;this.n31=n*S+t*O+y*W;this.n32=n*D+t*Fa+y*d;this.n33=n*L+t*oa+y*Z;this.n34=n*N+t*xa+y*ya+w;this.n41=z*S+E*O+G*W;this.n42=z*D+E*Fa+G*d;this.n43=z*L+E*oa+G*Z;this.n44=z*N+E*xa+G*ya+J;return this},multiplyToArray:function(a,c,b){this.multiply(a,c);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 this},multiplySelf:function(a){this.multiply(this,a);return this},multiplyScalar:function(a){this.n11*=a;this.n12*=a;this.n13*=a;this.n14*=a;this.n21*=a;this.n22*=a;this.n23*=a;this.n24*=a;this.n31*=a;this.n32*=a;this.n33*=a;this.n34*=a;this.n41*=a;this.n42*=a;this.n43*=a;this.n44*=a;return this}, -determinant:function(){var a=this.n11,c=this.n12,b=this.n13,e=this.n14,f=this.n21,g=this.n22,h=this.n23,j=this.n24,m=this.n31,o=this.n32,n=this.n33,t=this.n34,x=this.n41,w=this.n42,A=this.n43,F=this.n44;return e*h*o*x-b*j*o*x-e*g*n*x+c*j*n*x+b*g*t*x-c*h*t*x-e*h*m*w+b*j*m*w+e*f*n*w-a*j*n*w-b*f*t*w+a*h*t*w+e*g*m*A-c*j*m*A-e*f*o*A+a*j*o*A+c*f*t*A-a*g*t*A-b*g*m*F+c*h*m*F+b*f*o*F-a*h*o*F-c*f*n*F+a*g*n*F},transpose:function(){var a;a=this.n21;this.n21=this.n12;this.n12=a;a=this.n31;this.n31=this.n13;this.n13= +determinant:function(){var a=this.n11,c=this.n12,b=this.n13,e=this.n14,f=this.n21,g=this.n22,h=this.n23,j=this.n24,m=this.n31,o=this.n32,n=this.n33,t=this.n34,y=this.n41,w=this.n42,z=this.n43,E=this.n44;return e*h*o*y-b*j*o*y-e*g*n*y+c*j*n*y+b*g*t*y-c*h*t*y-e*h*m*w+b*j*m*w+e*f*n*w-a*j*n*w-b*f*t*w+a*h*t*w+e*g*m*z-c*j*m*z-e*f*o*z+a*j*o*z+c*f*t*z-a*g*t*z-b*g*m*E+c*h*m*E+b*f*o*E-a*h*o*E-c*f*n*E+a*g*n*E},transpose:function(){var a;a=this.n21;this.n21=this.n12;this.n12=a;a=this.n31;this.n31=this.n13;this.n13= a;a=this.n32;this.n32=this.n23;this.n23=a;a=this.n41;this.n41=this.n14;this.n14=a;a=this.n42;this.n42=this.n24;this.n24=a;a=this.n43;this.n43=this.n34;this.n43=a;return this},clone:function(){var a=new THREE.Matrix4;a.n11=this.n11;a.n12=this.n12;a.n13=this.n13;a.n14=this.n14;a.n21=this.n21;a.n22=this.n22;a.n23=this.n23;a.n24=this.n24;a.n31=this.n31;a.n32=this.n32;a.n33=this.n33;a.n34=this.n34;a.n41=this.n41;a.n42=this.n42;a.n43=this.n43;a.n44=this.n44;return a},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(a){a[0]=this.n11;a[1]=this.n21;a[2]=this.n31;a[3]=this.n41;a[4]=this.n12;a[5]=this.n22;a[6]=this.n32;a[7]=this.n42;a[8]=this.n13; a[9]=this.n23;a[10]=this.n33;a[11]=this.n43;a[12]=this.n14;a[13]=this.n24;a[14]=this.n34;a[15]=this.n44;return a},flattenToArrayOffset:function(a,c){a[c]=this.n11;a[c+1]=this.n21;a[c+2]=this.n31;a[c+3]=this.n41;a[c+4]=this.n12;a[c+5]=this.n22;a[c+6]=this.n32;a[c+7]=this.n42;a[c+8]=this.n13;a[c+9]=this.n23;a[c+10]=this.n33;a[c+11]=this.n43;a[c+12]=this.n14;a[c+13]=this.n24;a[c+14]=this.n34;a[c+15]=this.n44;return a},setTranslation:function(a,c,b){this.set(1,0,0,a,0,1,0,c,0,0,1,b,0,0,0,1);return this}, @@ -34,8 +34,8 @@ setScale:function(a,c,b){this.set(a,0,0,0,0,c,0,0,0,0,b,0,0,0,0,1);return this}, a.z,m=f*g,o=f*h;this.set(m*g+b,m*h-e*j,m*j+e*h,0,m*h+e*j,o*h+b,o*j-e*g,0,m*j-e*h,o*j+e*g,f*j*j+b,0,0,0,0,1);return this},setPosition:function(a){this.n14=a.x;this.n24=a.y;this.n34=a.z;return this},setRotationFromEuler:function(a){var c=a.x,b=a.y,e=a.z;a=Math.cos(c);c=Math.sin(c);var f=Math.cos(b);b=Math.sin(b);var g=Math.cos(e);e=Math.sin(e);var h=a*b,j=c*b;this.n11=f*g;this.n12=-f*e;this.n13=b;this.n21=j*g+a*e;this.n22=-j*e+a*g;this.n23=-c*f;this.n31=-h*g+c*e;this.n32=h*e+c*g;this.n33=a*f;return this}, setRotationFromQuaternion:function(a){var c=a.x,b=a.y,e=a.z,f=a.w,g=c+c,h=b+b,j=e+e;a=c*g;var m=c*h;c*=j;var o=b*h;b*=j;e*=j;g*=f;h*=f;f*=j;this.n11=1-(o+e);this.n12=m-f;this.n13=c+h;this.n21=m+f;this.n22=1-(a+e);this.n23=b-g;this.n31=c-h;this.n32=b+g;this.n33=1-(a+o);return this},scale:function(a){var c=a.x,b=a.y;a=a.z;this.n11*=c;this.n12*=b;this.n13*=a;this.n21*=c;this.n22*=b;this.n23*=a;this.n31*=c;this.n32*=b;this.n33*=a;this.n41*=c;this.n42*=b;this.n43*=a;return this},extractPosition:function(a){this.n14= a.n14;this.n24=a.n24;this.n34=a.n34},extractRotation:function(a,c){var b=1/c.x,e=1/c.y,f=1/c.z;this.n11=a.n11*b;this.n21=a.n21*b;this.n31=a.n31*b;this.n12=a.n12*e;this.n22=a.n22*e;this.n32=a.n32*e;this.n13=a.n13*f;this.n23=a.n23*f;this.n33=a.n33*f}}; -THREE.Matrix4.makeInvert=function(a,c){var b=a.n11,e=a.n12,f=a.n13,g=a.n14,h=a.n21,j=a.n22,m=a.n23,o=a.n24,n=a.n31,t=a.n32,x=a.n33,w=a.n34,A=a.n41,F=a.n42,G=a.n43,K=a.n44;c===undefined&&(c=new THREE.Matrix4);c.n11=m*w*F-o*x*F+o*t*G-j*w*G-m*t*K+j*x*K;c.n12=g*x*F-f*w*F-g*t*G+e*w*G+f*t*K-e*x*K;c.n13=f*o*F-g*m*F+g*j*G-e*o*G-f*j*K+e*m*K;c.n14=g*m*t-f*o*t-g*j*x+e*o*x+f*j*w-e*m*w;c.n21=o*x*A-m*w*A-o*n*G+h*w*G+m*n*K-h*x*K;c.n22=f*w*A-g*x*A+g*n*G-b*w*G-f*n*K+b*x*K;c.n23=g*m*A-f*o*A-g*h*G+b*o*G+f*h*K-b*m*K; -c.n24=f*o*n-g*m*n+g*h*x-b*o*x-f*h*w+b*m*w;c.n31=j*w*A-o*t*A+o*n*F-h*w*F-j*n*K+h*t*K;c.n32=g*t*A-e*w*A-g*n*F+b*w*F+e*n*K-b*t*K;c.n33=f*o*A-g*j*A+g*h*F-b*o*F-e*h*K+b*j*K;c.n34=g*j*n-e*o*n-g*h*t+b*o*t+e*h*w-b*j*w;c.n41=m*t*A-j*x*A-m*n*F+h*x*F+j*n*G-h*t*G;c.n42=e*x*A-f*t*A+f*n*F-b*x*F-e*n*G+b*t*G;c.n43=f*j*A-e*m*A-f*h*F+b*m*F+e*h*G-b*j*G;c.n44=e*m*n-f*j*n+f*h*t-b*m*t-e*h*x+b*j*x;c.multiplyScalar(1/a.determinant());return c}; +THREE.Matrix4.makeInvert=function(a,c){var b=a.n11,e=a.n12,f=a.n13,g=a.n14,h=a.n21,j=a.n22,m=a.n23,o=a.n24,n=a.n31,t=a.n32,y=a.n33,w=a.n34,z=a.n41,E=a.n42,G=a.n43,J=a.n44;c===undefined&&(c=new THREE.Matrix4);c.n11=m*w*E-o*y*E+o*t*G-j*w*G-m*t*J+j*y*J;c.n12=g*y*E-f*w*E-g*t*G+e*w*G+f*t*J-e*y*J;c.n13=f*o*E-g*m*E+g*j*G-e*o*G-f*j*J+e*m*J;c.n14=g*m*t-f*o*t-g*j*y+e*o*y+f*j*w-e*m*w;c.n21=o*y*z-m*w*z-o*n*G+h*w*G+m*n*J-h*y*J;c.n22=f*w*z-g*y*z+g*n*G-b*w*G-f*n*J+b*y*J;c.n23=g*m*z-f*o*z-g*h*G+b*o*G+f*h*J-b*m*J; +c.n24=f*o*n-g*m*n+g*h*y-b*o*y-f*h*w+b*m*w;c.n31=j*w*z-o*t*z+o*n*E-h*w*E-j*n*J+h*t*J;c.n32=g*t*z-e*w*z-g*n*E+b*w*E+e*n*J-b*t*J;c.n33=f*o*z-g*j*z+g*h*E-b*o*E-e*h*J+b*j*J;c.n34=g*j*n-e*o*n-g*h*t+b*o*t+e*h*w-b*j*w;c.n41=m*t*z-j*y*z-m*n*E+h*y*E+j*n*G-h*t*G;c.n42=e*y*z-f*t*z+f*n*E-b*y*E-e*n*G+b*t*G;c.n43=f*j*z-e*m*z-f*h*E+b*m*E+e*h*G-b*j*G;c.n44=e*m*n-f*j*n+f*h*t-b*m*t-e*h*y+b*j*y;c.multiplyScalar(1/a.determinant());return c}; THREE.Matrix4.makeInvert3x3=function(a){var c=a.m33,b=c.m,e=a.n33*a.n22-a.n32*a.n23,f=-a.n33*a.n21+a.n31*a.n23,g=a.n32*a.n21-a.n31*a.n22,h=-a.n33*a.n12+a.n32*a.n13,j=a.n33*a.n11-a.n31*a.n13,m=-a.n32*a.n11+a.n31*a.n12,o=a.n23*a.n12-a.n22*a.n13,n=-a.n23*a.n11+a.n21*a.n13,t=a.n22*a.n11-a.n21*a.n12;a=a.n11*e+a.n21*h+a.n31*o;if(a==0)throw"matrix not invertible";a=1/a;b[0]=a*e;b[1]=a*f;b[2]=a*g;b[3]=a*h;b[4]=a*j;b[5]=a*m;b[6]=a*o;b[7]=a*n;b[8]=a*t;return c}; THREE.Matrix4.makeFrustum=function(a,c,b,e,f,g){var h;h=new THREE.Matrix4;h.n11=2*f/(c-a);h.n12=0;h.n13=(c+a)/(c-a);h.n14=0;h.n21=0;h.n22=2*f/(e-b);h.n23=(e+b)/(e-b);h.n24=0;h.n31=0;h.n32=0;h.n33=-(g+f)/(g-f);h.n34=-2*g*f/(g-f);h.n41=0;h.n42=0;h.n43=-1;h.n44=0;return h};THREE.Matrix4.makePerspective=function(a,c,b,e){var f;a=b*Math.tan(a*Math.PI/360);f=-a;return THREE.Matrix4.makeFrustum(f*c,a*c,f,a,b,e)}; THREE.Matrix4.makeOrtho=function(a,c,b,e,f,g){var h,j,m,o;h=new THREE.Matrix4;j=c-a;m=b-e;o=g-f;h.n11=2/j;h.n12=0;h.n13=0;h.n14=-((c+a)/j);h.n21=0;h.n22=2/m;h.n23=0;h.n24=-((b+e)/m);h.n31=0;h.n32=0;h.n33=-2/o;h.n34=-((g+f)/o);h.n41=0;h.n42=0;h.n43=0;h.n44=1;return h};THREE.Matrix4.__v1=new THREE.Vector3;THREE.Matrix4.__v2=new THREE.Vector3;THREE.Matrix4.__v3=new THREE.Vector3; @@ -56,16 +56,16 @@ THREE.Geometry.prototype={computeCentroids:function(){var a,c,b;a=0;for(c=this.f b.centroid.addSelf(this.vertices[b.d].position);b.centroid.divideScalar(4)}}},computeFaceNormals:function(a){var c,b,e,f,g,h,j=new THREE.Vector3,m=new THREE.Vector3;e=0;for(f=this.faces.length;e0){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 c=1,b=this.vertices.length;cthis.boundingBox.x[1])this.boundingBox.x[1]=a.position.x; if(a.position.ythis.boundingBox.y[1])this.boundingBox.y[1]=a.position.y;if(a.position.zthis.boundingBox.z[1])this.boundingBox.z[1]=a.position.z}}},computeBoundingSphere:function(){for(var a=this.boundingSphere===null?0:this.boundingSphere.radius,c=0,b=this.vertices.length;cthis.points.length-2?g:g+1;b[3]=g>this.points.length-3?g:g+2;o=this.points[b[0]];n=this.points[b[1]]; -t=this.points[b[2]];x=this.points[b[3]];j=h*h;m=h*j;e.x=c(o.x,n.x,t.x,x.x,h,j,m);e.y=c(o.y,n.y,t.y,x.y,h,j,m);e.z=c(o.z,n.z,t.z,x.z,h,j,m);return e};this.getControlPointsArray=function(){var w,A,F=this.points.length,G=[];for(w=0;wthis.points.length-2?g:g+1;b[3]=g>this.points.length-3?g:g+2;o=this.points[b[0]];n=this.points[b[1]]; +t=this.points[b[2]];y=this.points[b[3]];j=h*h;m=h*j;e.x=c(o.x,n.x,t.x,y.x,h,j,m);e.y=c(o.y,n.y,t.y,y.y,h,j,m);e.z=c(o.z,n.z,t.z,y.z,h,j,m);return e};this.getControlPointsArray=function(){var w,z,E=this.points.length,G=[];for(w=0;w1){console.log("THREE.Animation.update: Warning! Scale out of bounds:"+e+" on bone "+w);e=e<0?0:1}if(b==="pos"){b=a.position;if(this.interpolationType===THREE.AnimationHandler.LINEAR){b.x=f[0]+(g[0]-f[0])*e;b.y=f[1]+(g[1]-f[1])*e;b.z=f[2]+(g[2]-f[2])*e}else if(this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD){this.points[0]= this.getPrevKeyWith("pos",w,h.index-1).pos;this.points[1]=f;this.points[2]=g;this.points[3]=this.getNextKeyWith("pos",w,j.index+1).pos;e=e*0.33+0.33;f=this.interpolateCatmullRom(this.points,e);b.x=f[0];b.y=f[1];b.z=f[2];if(this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD){e=this.interpolateCatmullRom(this.points,e*1.01);this.target.set(e[0],e[1],e[2]);this.target.subSelf(b);this.target.y=0;this.target.normalize();e=Math.atan2(this.target.x,this.target.z);a.rotation.set(0,e,0)}}}else if(b=== "rot")THREE.Quaternion.slerp(f,g,a.quaternion,e);else if(b==="scl"){b=a.scale;b.x=f[0]+(g[0]-f[0])*e;b.y=f[1]+(g[1]-f[1])*e;b.z=f[2]+(g[2]-f[2])*e}}}}if(this.JITCompile&&n[0][o]===undefined){this.hierarchy[0].update(undefined,!0);for(w=0;w0?b:0:b>=0?b:b+e.length;b>=0;b--)if(e[b][a]!==undefined)return e[b];return this.data.hierarchy[c].keys[e.length-1]}; THREE.Camera=function(a,c,b,e,f){THREE.Object3D.call(this);this.fov=a||50;this.aspect=c||1;this.near=b||0.1;this.far=e||2E3;this.target=f||new THREE.Object3D;this.useTarget=!0;this.matrixWorldInverse=new THREE.Matrix4;this.projectionMatrix=null;this.updateProjectionMatrix()};THREE.Camera.prototype=new THREE.Object3D;THREE.Camera.prototype.constructor=THREE.Camera;THREE.Camera.prototype.supr=THREE.Object3D.prototype; THREE.Camera.prototype.translate=function(a,c){this.matrix.rotateAxis(c);this.position.addSelf(c.multiplyScalar(a));this.target.position.addSelf(c.multiplyScalar(a))};THREE.Camera.prototype.updateProjectionMatrix=function(){this.projectionMatrix=THREE.Matrix4.makePerspective(this.fov,this.aspect,this.near,this.far)};THREE.Camera.prototype.updateMatrix=function(){this.update(undefined,!0)}; -THREE.Camera.prototype.update=function(a,c,b){if(this.useTarget){this.matrix.lookAt(this.position,this.target.position,this.up);this.matrix.setPosition(this.position)}a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);THREE.Matrix4.makeInvert(this.matrixWorld,this.matrixWorldInverse);c=!0;for(a=0;a=0&&sa>=0&&aa>=0&&oa>=0)return!0;else if(Fa<0&&sa<0||aa<0&&oa<0)return!1;else{if(Fa<0)ya=Math.max(ya,Fa/(Fa-sa));else sa<0&&(Ea=Math.min(Ea,Fa/(Fa-sa)));if(aa<0)ya=Math.max(ya,aa/(aa-oa));else oa<0&&(Ea=Math.min(Ea,aa/(aa-oa)));if(EaFa&&h.positionScreen.z0&&Q.z<1){Qa=z[O]=z[O]||new THREE.RenderableParticle;O++;K=Qa;K.x=Q.x/Q.w;K.y=Q.y/Q.w;K.z=Q.z;K.rotation=Ga.rotation.z;K.scale.x=Ga.scale.x*Math.abs(K.x-(Q.x+$.projectionMatrix.n11)/(Q.w+$.projectionMatrix.n14));K.scale.y=Ga.scale.y*Math.abs(K.y-(Q.y+$.projectionMatrix.n22)/(Q.w+$.projectionMatrix.n24));K.materials=Ga.materials;Ea.push(K)}}}}ya&&Ea.sort(c);return Ea}}; -THREE.DOMRenderer=function(){THREE.Renderer.call(this);var a=null,c=new THREE.Projector,b,e,f,g;this.domElement=document.createElement("div");this.setSize=function(h,j){b=h;e=j;f=b/2;g=e/2};this.render=function(h,j){var m,o,n,t,x,w,A,F;a=c.projectScene(h,j);m=0;for(o=a.length;m>1;Ha=za.height>>1;fa=ja.scale.x*m;ra=ja.scale.y*o;Z=fa*U;ta=ra*Ha;y.set(N.x-Z,N.y-ta,N.x+Z,N.y+ta);if(T.instersects(y)){n.save();n.translate(N.x,N.y);n.rotate(-ja.rotation);n.scale(fa, --ra);n.translate(-U,-Ha);n.drawImage(za,0,0);n.restore()}}}else if(fa instanceof THREE.ParticleCanvasMaterial){Z=ja.scale.x*m;ta=ja.scale.y*o;y.set(N.x-Z,N.y-ta,N.x+Z,N.y+ta);if(T.instersects(y)){b(fa.color.__styleString);ra=fa.color.__styleString;if(G!=ra)n.fillStyle=G=ra;n.save();n.translate(N.x,N.y);n.rotate(-ja.rotation);n.scale(Z,ta);fa.program(n);n.restore()}}}function xa(N,ja,fa,Z){a(Z.opacity);c(Z.blending);n.beginPath();n.moveTo(N.positionScreen.x,N.positionScreen.y);n.lineTo(ja.positionScreen.x, -ja.positionScreen.y);n.closePath();if(Z instanceof THREE.LineBasicMaterial){V.__styleString=Z.color.__styleString;N=Z.linewidth;if(K!=N)n.lineWidth=K=N;b(V.__styleString);n.stroke();y.inflate(Z.linewidth*2)}}function La(N,ja,fa,Z,ta,ra,za,U,Ha){a(U.opacity);c(U.blending);ha=N.positionScreen.x;na=N.positionScreen.y;Y=ja.positionScreen.x;d=ja.positionScreen.y;$=fa.positionScreen.x;ya=fa.positionScreen.y;Za(ha,na,Y,d,$,ya);if(U instanceof THREE.MeshBasicMaterial)if(U.map){if(U.map.mapping instanceof -THREE.UVMapping){Ra=za.uvs[0];$a(ha,na,Y,d,$,ya,U.map.image,Ra[Z].u,Ra[Z].v,Ra[ta].u,Ra[ta].v,Ra[ra].u,Ra[ra].v)}}else if(U.envMap){if(U.envMap.mapping instanceof THREE.SphericalReflectionMapping){N=va.matrixWorldInverse;E.copy(za.vertexNormalsWorld[0]);bb=(E.x*N.n11+E.y*N.n12+E.z*N.n13)*0.5+0.5;Ya=-(E.x*N.n21+E.y*N.n22+E.z*N.n23)*0.5+0.5;E.copy(za.vertexNormalsWorld[1]);M=(E.x*N.n11+E.y*N.n12+E.z*N.n13)*0.5+0.5;X=-(E.x*N.n21+E.y*N.n22+E.z*N.n23)*0.5+0.5;E.copy(za.vertexNormalsWorld[2]);ma=(E.x*N.n11+ -E.y*N.n12+E.z*N.n13)*0.5+0.5;W=-(E.x*N.n21+E.y*N.n22+E.z*N.n23)*0.5+0.5;$a(ha,na,Y,d,$,ya,U.envMap.image,bb,Ya,M,X,ma,W)}}else U.wireframe?Ia(U.color.__styleString,U.wireframeLinewidth):Pa(U.color.__styleString);else if(U instanceof THREE.MeshLambertMaterial){if(U.map&&!U.wireframe){if(U.map.mapping instanceof THREE.UVMapping){Ra=za.uvs[0];$a(ha,na,Y,d,$,ya,U.map.image,Ra[Z].u,Ra[Z].v,Ra[ta].u,Ra[ta].v,Ra[ra].u,Ra[ra].v)}c(THREE.SubtractiveBlending)}if(B)if(!U.wireframe&&U.shading==THREE.SmoothShading&& -za.vertexNormalsWorld.length==3){S.r=ka.r=ua.r=C.r;S.g=ka.g=ua.g=C.g;S.b=ka.b=ua.b=C.b;da(Ha,za.v1.positionWorld,za.vertexNormalsWorld[0],S);da(Ha,za.v2.positionWorld,za.vertexNormalsWorld[1],ka);da(Ha,za.v3.positionWorld,za.vertexNormalsWorld[2],ua);ia.r=(ka.r+ua.r)*0.5;ia.g=(ka.g+ua.g)*0.5;ia.b=(ka.b+ua.b)*0.5;Qa=eb(S,ka,ua,ia);$a(ha,na,Y,d,$,ya,Qa,0,0,1,0,0,1)}else{p.r=C.r;p.g=C.g;p.b=C.b;da(Ha,za.centroidWorld,za.normalWorld,p);V.r=U.color.r*p.r;V.g=U.color.g*p.g;V.b=U.color.b*p.b;V.updateStyleString(); -U.wireframe?Ia(V.__styleString,U.wireframeLinewidth):Pa(V.__styleString)}else U.wireframe?Ia(U.color.__styleString,U.wireframeLinewidth):Pa(U.color.__styleString)}else if(U instanceof THREE.MeshDepthMaterial){Ba=va.near;Ga=va.far;S.r=S.g=S.b=1-Ua(N.positionScreen.z,Ba,Ga);ka.r=ka.g=ka.b=1-Ua(ja.positionScreen.z,Ba,Ga);ua.r=ua.g=ua.b=1-Ua(fa.positionScreen.z,Ba,Ga);ia.r=(ka.r+ua.r)*0.5;ia.g=(ka.g+ua.g)*0.5;ia.b=(ka.b+ua.b)*0.5;Qa=eb(S,ka,ua,ia);$a(ha,na,Y,d,$,ya,Qa,0,0,1,0,0,1)}else if(U instanceof -THREE.MeshNormalMaterial){V.r=Wa(za.normalWorld.x);V.g=Wa(za.normalWorld.y);V.b=Wa(za.normalWorld.z);V.updateStyleString();U.wireframe?Ia(V.__styleString,U.wireframeLinewidth):Pa(V.__styleString)}}function Va(N,ja,fa,Z,ta,ra,za,U,Ha){a(U.opacity);c(U.blending);if(U.map||U.envMap){La(N,ja,Z,0,1,3,za,U,Ha);La(ta,fa,ra,1,2,3,za,U,Ha)}else{ha=N.positionScreen.x;na=N.positionScreen.y;Y=ja.positionScreen.x;d=ja.positionScreen.y;$=fa.positionScreen.x;ya=fa.positionScreen.y;Ea=Z.positionScreen.x;Fa=Z.positionScreen.y; -sa=ta.positionScreen.x;aa=ta.positionScreen.y;oa=ra.positionScreen.x;Aa=ra.positionScreen.y;if(U instanceof THREE.MeshBasicMaterial){Ma(ha,na,Y,d,$,ya,Ea,Fa);U.wireframe?Ia(U.color.__styleString,U.wireframeLinewidth):Pa(U.color.__styleString)}else if(U instanceof THREE.MeshLambertMaterial)if(B)if(!U.wireframe&&U.shading==THREE.SmoothShading&&za.vertexNormalsWorld.length==4){S.r=ka.r=ua.r=ia.r=C.r;S.g=ka.g=ua.g=ia.g=C.g;S.b=ka.b=ua.b=ia.b=C.b;da(Ha,za.v1.positionWorld,za.vertexNormalsWorld[0],S);da(Ha, -za.v2.positionWorld,za.vertexNormalsWorld[1],ka);da(Ha,za.v4.positionWorld,za.vertexNormalsWorld[3],ua);da(Ha,za.v3.positionWorld,za.vertexNormalsWorld[2],ia);Qa=eb(S,ka,ua,ia);Za(ha,na,Y,d,Ea,Fa);$a(ha,na,Y,d,Ea,Fa,Qa,0,0,1,0,0,1);Za(sa,aa,$,ya,oa,Aa);$a(sa,aa,$,ya,oa,Aa,Qa,1,0,1,1,0,1)}else{p.r=C.r;p.g=C.g;p.b=C.b;da(Ha,za.centroidWorld,za.normalWorld,p);V.r=U.color.r*p.r;V.g=U.color.g*p.g;V.b=U.color.b*p.b;V.updateStyleString();Ma(ha,na,Y,d,$,ya,Ea,Fa);U.wireframe?Ia(V.__styleString,U.wireframeLinewidth): -Pa(V.__styleString)}else{Ma(ha,na,Y,d,$,ya,Ea,Fa);U.wireframe?Ia(U.color.__styleString,U.wireframeLinewidth):Pa(U.color.__styleString)}else if(U instanceof THREE.MeshNormalMaterial){V.r=Wa(za.normalWorld.x);V.g=Wa(za.normalWorld.y);V.b=Wa(za.normalWorld.z);V.updateStyleString();Ma(ha,na,Y,d,$,ya,Ea,Fa);U.wireframe?Ia(V.__styleString,U.wireframeLinewidth):Pa(V.__styleString)}else if(U instanceof THREE.MeshDepthMaterial){Ba=va.near;Ga=va.far;S.r=S.g=S.b=1-Ua(N.positionScreen.z,Ba,Ga);ka.r=ka.g=ka.b= -1-Ua(ja.positionScreen.z,Ba,Ga);ua.r=ua.g=ua.b=1-Ua(Z.positionScreen.z,Ba,Ga);ia.r=ia.g=ia.b=1-Ua(fa.positionScreen.z,Ba,Ga);Qa=eb(S,ka,ua,ia);Za(ha,na,Y,d,Ea,Fa);$a(ha,na,Y,d,Ea,Fa,Qa,0,0,1,0,0,1);Za(sa,aa,$,ya,oa,Aa);$a(sa,aa,$,ya,oa,Aa,Qa,1,0,1,1,0,1)}}}function Za(N,ja,fa,Z,ta,ra){n.beginPath();n.moveTo(N,ja);n.lineTo(fa,Z);n.lineTo(ta,ra);n.lineTo(N,ja);n.closePath()}function Ma(N,ja,fa,Z,ta,ra,za,U){n.beginPath();n.moveTo(N,ja);n.lineTo(fa,Z);n.lineTo(ta,ra);n.lineTo(za,U);n.lineTo(N,ja);n.closePath()} -function Ia(N,ja){b(N);if(K!=ja)n.lineWidth=K=ja;n.stroke();y.inflate(ja*2)}function Pa(N){if(G!=N)n.fillStyle=G=N;n.fill()}function $a(N,ja,fa,Z,ta,ra,za,U,Ha,fb,Oa,cb,jb){var ab,db;ab=za.width-1;db=za.height-1;U*=ab;Ha*=db;fb*=ab;Oa*=db;cb*=ab;jb*=db;fa-=N;Z-=ja;ta-=N;ra-=ja;fb-=U;Oa-=Ha;cb-=U;jb-=Ha;ab=fb*jb-cb*Oa;if(ab!=0){db=1/ab;ab=(jb*fa-Oa*ta)*db;Oa=(jb*Z-Oa*ra)*db;fa=(fb*ta-cb*fa)*db;Z=(fb*ra-cb*Z)*db;N=N-ab*U-fa*Ha;ja=ja-Oa*U-Z*Ha;n.save();n.transform(ab,Oa,fa,Z,N,ja);n.clip();n.drawImage(za, -0,0);n.restore()}}function eb(N,ja,fa,Z){var ta=~~(N.r*255),ra=~~(N.g*255);N=~~(N.b*255);var za=~~(ja.r*255),U=~~(ja.g*255);ja=~~(ja.b*255);var Ha=~~(fa.r*255),fb=~~(fa.g*255);fa=~~(fa.b*255);var Oa=~~(Z.r*255),cb=~~(Z.g*255);Z=~~(Z.b*255);ea[0]=ta<0?0:ta>255?255:ta;ea[1]=ra<0?0:ra>255?255:ra;ea[2]=N<0?0:N>255?255:N;ea[4]=za<0?0:za>255?255:za;ea[5]=U<0?0:U>255?255:U;ea[6]=ja<0?0:ja>255?255:ja;ea[8]=Ha<0?0:Ha>255?255:Ha;ea[9]=fb<0?0:fb>255?255:fb;ea[10]=fa<0?0:fa>255?255:fa;ea[12]=Oa<0?0:Oa>255?255: -Oa;ea[13]=cb<0?0:cb>255?255:cb;ea[14]=Z<0?0:Z>255?255:Z;ca.putImageData(I,0,0);wa.drawImage(D,0,0);return ga}function Ua(N,ja,fa){N=(N-ja)/(fa-ja);return N*N*(3-2*N)}function Wa(N){N=(N+1)*0.5;return N<0?0:N>1?1:N}function Ja(N,ja){var fa=ja.x-N.x,Z=ja.y-N.y,ta=1/Math.sqrt(fa*fa+Z*Z);fa*=ta;Z*=ta;ja.x+=fa;ja.y+=Z;N.x-=fa;N.y-=Z}var Xa,Ta,J,Ka,Sa,gb,hb,Na;this.autoClear?this.clear():n.setTransform(1,0,0,-1,m,o);e=f.projectScene(la,va,this.sortElements);(B=la.lights.length>0)&&Ca(la);Xa=0;for(Ta=e.length;Xa< -Ta;Xa++){J=e[Xa];y.empty();if(J instanceof THREE.RenderableParticle){O=J;O.x*=m;O.y*=o;Ka=0;for(Sa=J.materials.length;Ka0){oa.r+=S.color.r*ka;oa.g+=S.color.g*ka;oa.b+=S.color.b*ka}}else if(S instanceof THREE.PointLight){na.sub(S.position,aa.centroidWorld);na.normalize();ka=aa.normalWorld.dot(na)*S.intensity;if(ka>0){oa.r+=S.color.r*ka;oa.g+=S.color.g*ka;oa.b+=S.color.b*ka}}}}function c(sa,aa,oa,Aa,V,S){$=e(ya++); -$.setAttribute("d","M "+sa.positionScreen.x+" "+sa.positionScreen.y+" L "+aa.positionScreen.x+" "+aa.positionScreen.y+" L "+oa.positionScreen.x+","+oa.positionScreen.y+"z");if(V instanceof THREE.MeshBasicMaterial)z.__styleString=V.color.__styleString;else if(V instanceof THREE.MeshLambertMaterial)if(O){P.r=Q.r;P.g=Q.g;P.b=Q.b;a(S,Aa,P);z.r=V.color.r*P.r;z.g=V.color.g*P.g;z.b=V.color.b*P.b;z.updateStyleString()}else z.__styleString=V.color.__styleString;else if(V instanceof THREE.MeshDepthMaterial){ha= -1-V.__2near/(V.__farPlusNear-Aa.z*V.__farMinusNear);z.setRGB(ha,ha,ha)}else V instanceof THREE.MeshNormalMaterial&&z.setRGB(f(Aa.normalWorld.x),f(Aa.normalWorld.y),f(Aa.normalWorld.z));V.wireframe?$.setAttribute("style","fill: none; stroke: "+z.__styleString+"; stroke-width: "+V.wireframeLinewidth+"; stroke-opacity: "+V.opacity+"; stroke-linecap: "+V.wireframeLinecap+"; stroke-linejoin: "+V.wireframeLinejoin):$.setAttribute("style","fill: "+z.__styleString+"; fill-opacity: "+V.opacity);j.appendChild($)} -function b(sa,aa,oa,Aa,V,S,ka){$=e(ya++);$.setAttribute("d","M "+sa.positionScreen.x+" "+sa.positionScreen.y+" L "+aa.positionScreen.x+" "+aa.positionScreen.y+" L "+oa.positionScreen.x+","+oa.positionScreen.y+" L "+Aa.positionScreen.x+","+Aa.positionScreen.y+"z");if(S instanceof THREE.MeshBasicMaterial)z.__styleString=S.color.__styleString;else if(S instanceof THREE.MeshLambertMaterial)if(O){P.r=Q.r;P.g=Q.g;P.b=Q.b;a(ka,V,P);z.r=S.color.r*P.r;z.g=S.color.g*P.g;z.b=S.color.b*P.b;z.updateStyleString()}else z.__styleString= -S.color.__styleString;else if(S instanceof THREE.MeshDepthMaterial){ha=1-S.__2near/(S.__farPlusNear-V.z*S.__farMinusNear);z.setRGB(ha,ha,ha)}else S instanceof THREE.MeshNormalMaterial&&z.setRGB(f(V.normalWorld.x),f(V.normalWorld.y),f(V.normalWorld.z));S.wireframe?$.setAttribute("style","fill: none; stroke: "+z.__styleString+"; stroke-width: "+S.wireframeLinewidth+"; stroke-opacity: "+S.opacity+"; stroke-linecap: "+S.wireframeLinecap+"; stroke-linejoin: "+S.wireframeLinejoin):$.setAttribute("style", -"fill: "+z.__styleString+"; fill-opacity: "+S.opacity);j.appendChild($)}function e(sa){if(Y[sa]==null){Y[sa]=document.createElementNS("http://www.w3.org/2000/svg","path");Fa==0&&Y[sa].setAttribute("shape-rendering","crispEdges")}return Y[sa]}function f(sa){return sa<0?Math.min((1+sa)*0.5,0.5):0.5+Math.min(sa*0.5,0.5)}var g=null,h=new THREE.Projector,j=document.createElementNS("http://www.w3.org/2000/svg","svg"),m,o,n,t,x,w,A,F,G=new THREE.Rectangle,K=new THREE.Rectangle,O=!1,z=new THREE.Color(16777215), -P=new THREE.Color(16777215),Q=new THREE.Color(0),R=new THREE.Color(0),Da=new THREE.Color(0),ha,na=new THREE.Vector3,Y=[],d=[],$,ya,Ea,Fa=1;this.domElement=j;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setQuality=function(sa){switch(sa){case "high":Fa=1;break;case "low":Fa=0}};this.setSize=function(sa,aa){m=sa;o=aa;n=m/2;t=o/2;j.setAttribute("viewBox",-n+" "+-t+" "+m+" "+o);j.setAttribute("width",m);j.setAttribute("height",o);G.set(-n,-t,n,t)};this.clear=function(){for(;j.childNodes.length> -0;)j.removeChild(j.childNodes[0])};this.render=function(sa,aa){var oa,Aa,V,S,ka,ua,ia,Ba;this.autoClear&&this.clear();g=h.projectScene(sa,aa,this.sortElements);Ea=ya=0;if(O=sa.lights.length>0){ia=sa.lights;Q.setRGB(0,0,0);R.setRGB(0,0,0);Da.setRGB(0,0,0);oa=0;for(Aa=ia.length;oa=0&&ra>=0&&X>=0&&qa>=0)return!0;else if(Ha<0&&ra<0||X<0&&qa<0)return!1;else{if(Ha<0)ya=Math.max(ya,Ha/(Ha-ra));else ra<0&&(Ga=Math.min(Ga,Ha/(Ha-ra)));if(X<0)ya=Math.max(ya,X/(X-qa));else qa<0&&(Ga=Math.min(Ga,X/(X-qa)));if(GaHa&&h.positionScreen.z0&&N.z<1){Sa=D[S]=D[S]||new THREE.RenderableParticle;S++;J=Sa;J.x=N.x/N.w;J.y=N.y/N.w;J.z=N.z;J.rotation=Da.rotation.z;J.scale.x=Da.scale.x*Math.abs(J.x-(N.x+Z.projectionMatrix.n11)/(N.w+Z.projectionMatrix.n14));J.scale.y=Da.scale.y*Math.abs(J.y-(N.y+Z.projectionMatrix.n22)/(N.w+Z.projectionMatrix.n24));J.materials=Da.materials;Ga.push(J)}}}}ya&&Ga.sort(c);return Ga}}; +THREE.DOMRenderer=function(){THREE.Renderer.call(this);var a=null,c=new THREE.Projector,b,e,f,g;this.domElement=document.createElement("div");this.setSize=function(h,j){b=h;e=j;f=b/2;g=e/2};this.render=function(h,j){var m,o,n,t,y,w,z,E;a=c.projectScene(h,j);m=0;for(o=a.length;m>1;Oa=pa.height>>1;aa=da.scale.x*m;Ja=da.scale.y*o;T=aa*Q;ta=Ja*Oa;x.set(P.x-T,P.y-ta,P.x+T,P.y+ta);if(k.instersects(x)){n.save();n.translate(P.x,P.y);n.rotate(-da.rotation); +n.scale(aa,-Ja);n.translate(-Q,-Oa);n.drawImage(pa,0,0);n.restore()}}}else if(aa instanceof THREE.ParticleCanvasMaterial){T=da.scale.x*m;ta=da.scale.y*o;x.set(P.x-T,P.y-ta,P.x+T,P.y+ta);if(k.instersects(x)){b(aa.color.__styleString);Ja=aa.color.__styleString;if(G!=Ja)n.fillStyle=G=Ja;n.save();n.translate(P.x,P.y);n.rotate(-da.rotation);n.scale(T,ta);aa.program(n);n.restore()}}}function Qa(P,da,aa,T){a(T.opacity);c(T.blending);n.beginPath();n.moveTo(P.positionScreen.x,P.positionScreen.y);n.lineTo(da.positionScreen.x, +da.positionScreen.y);n.closePath();if(T instanceof THREE.LineBasicMaterial){ma.__styleString=T.color.__styleString;P=T.linewidth;if(J!=P)n.lineWidth=J=P;P=T.linecap;if(S!=P)n.lineCap=S=P;P=T.linejoin;if(D!=P)n.lineJoin=D=P;b(ma.__styleString);n.stroke();x.inflate(T.linewidth*2)}}function Va(P,da,aa,T,ta,Ja,pa,Q,Oa){a(Q.opacity);c(Q.blending);W=P.positionScreen.x;d=P.positionScreen.y;Z=da.positionScreen.x;ya=da.positionScreen.y;Ga=aa.positionScreen.x;Ha=aa.positionScreen.y;Ma(W,d,Z,ya,Ga,Ha);if(Q instanceof +THREE.MeshBasicMaterial)if(Q.map){if(Q.map.mapping instanceof THREE.UVMapping){Ta=pa.uvs[0];bb(W,d,Z,ya,Ga,Ha,Q.map.image,Ta[T].u,Ta[T].v,Ta[ta].u,Ta[ta].v,Ta[Ja].u,Ta[Ja].v)}}else if(Q.envMap){if(Q.envMap.mapping instanceof THREE.SphericalReflectionMapping){P=va.matrixWorldInverse;C.copy(pa.vertexNormalsWorld[0]);M=(C.x*P.n11+C.y*P.n12+C.z*P.n13)*0.5+0.5;V=-(C.x*P.n21+C.y*P.n22+C.z*P.n23)*0.5+0.5;C.copy(pa.vertexNormalsWorld[1]);na=(C.x*P.n11+C.y*P.n12+C.z*P.n13)*0.5+0.5;Aa=-(C.x*P.n21+C.y*P.n22+ +C.z*P.n23)*0.5+0.5;C.copy(pa.vertexNormalsWorld[2]);ca=(C.x*P.n11+C.y*P.n12+C.z*P.n13)*0.5+0.5;ga=-(C.x*P.n21+C.y*P.n22+C.z*P.n23)*0.5+0.5;bb(W,d,Z,ya,Ga,Ha,Q.envMap.image,M,V,na,Aa,ca,ga)}}else Q.wireframe?Pa(Q.color.__styleString,Q.wireframeLinewidth,Q.wireframeLinecap,Q.wireframeLinejoin):cb(Q.color.__styleString);else if(Q instanceof THREE.MeshLambertMaterial){if(Q.map&&!Q.wireframe){if(Q.map.mapping instanceof THREE.UVMapping){Ta=pa.uvs[0];bb(W,d,Z,ya,Ga,Ha,Q.map.image,Ta[T].u,Ta[T].v,Ta[ta].u, +Ta[ta].v,Ta[Ja].u,Ta[Ja].v)}c(THREE.SubtractiveBlending)}if(p)if(!Q.wireframe&&Q.shading==THREE.SmoothShading&&pa.vertexNormalsWorld.length==3){Ca.r=fa.r=ja.r=F.r;Ca.g=fa.g=ja.g=F.g;Ca.b=fa.b=ja.b=F.b;ia(Oa,pa.v1.positionWorld,pa.vertexNormalsWorld[0],Ca);ia(Oa,pa.v2.positionWorld,pa.vertexNormalsWorld[1],fa);ia(Oa,pa.v3.positionWorld,pa.vertexNormalsWorld[2],ja);Da.r=(fa.r+ja.r)*0.5;Da.g=(fa.g+ja.g)*0.5;Da.b=(fa.b+ja.b)*0.5;Wa=$a(Ca,fa,ja,Da);bb(W,d,Z,ya,Ga,Ha,Wa,0,0,1,0,0,1)}else{A.r=F.r;A.g=F.g; +A.b=F.b;ia(Oa,pa.centroidWorld,pa.normalWorld,A);ma.r=Q.color.r*A.r;ma.g=Q.color.g*A.g;ma.b=Q.color.b*A.b;ma.updateStyleString();Q.wireframe?Pa(ma.__styleString,Q.wireframeLinewidth,Q.wireframeLinecap,Q.wireframeLinejoin):cb(ma.__styleString)}else Q.wireframe?Pa(Q.color.__styleString,Q.wireframeLinewidth,Q.wireframeLinecap,Q.wireframeLinejoin):cb(Q.color.__styleString)}else if(Q instanceof THREE.MeshDepthMaterial){Sa=va.near;Xa=va.far;Ca.r=Ca.g=Ca.b=1-Za(P.positionScreen.z,Sa,Xa);fa.r=fa.g=fa.b=1- +Za(da.positionScreen.z,Sa,Xa);ja.r=ja.g=ja.b=1-Za(aa.positionScreen.z,Sa,Xa);Da.r=(fa.r+ja.r)*0.5;Da.g=(fa.g+ja.g)*0.5;Da.b=(fa.b+ja.b)*0.5;Wa=$a(Ca,fa,ja,Da);bb(W,d,Z,ya,Ga,Ha,Wa,0,0,1,0,0,1)}else if(Q instanceof THREE.MeshNormalMaterial){ma.r=Ka(pa.normalWorld.x);ma.g=Ka(pa.normalWorld.y);ma.b=Ka(pa.normalWorld.z);ma.updateStyleString();Q.wireframe?Pa(ma.__styleString,Q.wireframeLinewidth,Q.wireframeLinecap,Q.wireframeLinejoin):cb(ma.__styleString)}}function eb(P,da,aa,T,ta,Ja,pa,Q,Oa){a(Q.opacity); +c(Q.blending);if(Q.map||Q.envMap){Va(P,da,T,0,1,3,pa,Q,Oa);Va(ta,aa,Ja,1,2,3,pa,Q,Oa)}else{W=P.positionScreen.x;d=P.positionScreen.y;Z=da.positionScreen.x;ya=da.positionScreen.y;Ga=aa.positionScreen.x;Ha=aa.positionScreen.y;ra=T.positionScreen.x;X=T.positionScreen.y;qa=ta.positionScreen.x;za=ta.positionScreen.y;ea=Ja.positionScreen.x;U=Ja.positionScreen.y;if(Q instanceof THREE.MeshBasicMaterial){La(W,d,Z,ya,Ga,Ha,ra,X);Q.wireframe?Pa(Q.color.__styleString,Q.wireframeLinewidth,Q.wireframeLinecap,Q.wireframeLinejoin): +cb(Q.color.__styleString)}else if(Q instanceof THREE.MeshLambertMaterial)if(p)if(!Q.wireframe&&Q.shading==THREE.SmoothShading&&pa.vertexNormalsWorld.length==4){Ca.r=fa.r=ja.r=Da.r=F.r;Ca.g=fa.g=ja.g=Da.g=F.g;Ca.b=fa.b=ja.b=Da.b=F.b;ia(Oa,pa.v1.positionWorld,pa.vertexNormalsWorld[0],Ca);ia(Oa,pa.v2.positionWorld,pa.vertexNormalsWorld[1],fa);ia(Oa,pa.v4.positionWorld,pa.vertexNormalsWorld[3],ja);ia(Oa,pa.v3.positionWorld,pa.vertexNormalsWorld[2],Da);Wa=$a(Ca,fa,ja,Da);Ma(W,d,Z,ya,ra,X);bb(W,d,Z,ya, +ra,X,Wa,0,0,1,0,0,1);Ma(qa,za,Ga,Ha,ea,U);bb(qa,za,Ga,Ha,ea,U,Wa,1,0,1,1,0,1)}else{A.r=F.r;A.g=F.g;A.b=F.b;ia(Oa,pa.centroidWorld,pa.normalWorld,A);ma.r=Q.color.r*A.r;ma.g=Q.color.g*A.g;ma.b=Q.color.b*A.b;ma.updateStyleString();La(W,d,Z,ya,Ga,Ha,ra,X);Q.wireframe?Pa(ma.__styleString,Q.wireframeLinewidth,Q.wireframeLinecap,Q.wireframeLinejoin):cb(ma.__styleString)}else{La(W,d,Z,ya,Ga,Ha,ra,X);Q.wireframe?Pa(Q.color.__styleString,Q.wireframeLinewidth,Q.wireframeLinecap,Q.wireframeLinejoin):cb(Q.color.__styleString)}else if(Q instanceof +THREE.MeshNormalMaterial){ma.r=Ka(pa.normalWorld.x);ma.g=Ka(pa.normalWorld.y);ma.b=Ka(pa.normalWorld.z);ma.updateStyleString();La(W,d,Z,ya,Ga,Ha,ra,X);Q.wireframe?Pa(ma.__styleString,Q.wireframeLinewidth,Q.wireframeLinecap,Q.wireframeLinejoin):cb(ma.__styleString)}else if(Q instanceof THREE.MeshDepthMaterial){Sa=va.near;Xa=va.far;Ca.r=Ca.g=Ca.b=1-Za(P.positionScreen.z,Sa,Xa);fa.r=fa.g=fa.b=1-Za(da.positionScreen.z,Sa,Xa);ja.r=ja.g=ja.b=1-Za(T.positionScreen.z,Sa,Xa);Da.r=Da.g=Da.b=1-Za(aa.positionScreen.z, +Sa,Xa);Wa=$a(Ca,fa,ja,Da);Ma(W,d,Z,ya,ra,X);bb(W,d,Z,ya,ra,X,Wa,0,0,1,0,0,1);Ma(qa,za,Ga,Ha,ea,U);bb(qa,za,Ga,Ha,ea,U,Wa,1,0,1,1,0,1)}}}function Ma(P,da,aa,T,ta,Ja){n.beginPath();n.moveTo(P,da);n.lineTo(aa,T);n.lineTo(ta,Ja);n.lineTo(P,da);n.closePath()}function La(P,da,aa,T,ta,Ja,pa,Q){n.beginPath();n.moveTo(P,da);n.lineTo(aa,T);n.lineTo(ta,Ja);n.lineTo(pa,Q);n.lineTo(P,da);n.closePath()}function Pa(P,da,aa,T){if(J!=da)n.lineWidth=J=da;if(S!=aa)n.lineCap=S=aa;if(D!=T)n.lineJoin=D=T;b(P);n.stroke(); +x.inflate(da*2)}function cb(P){if(G!=P)n.fillStyle=G=P;n.fill()}function bb(P,da,aa,T,ta,Ja,pa,Q,Oa,Ra,db,hb,jb){var fb,ib;fb=pa.width-1;ib=pa.height-1;Q*=fb;Oa*=ib;Ra*=fb;db*=ib;hb*=fb;jb*=ib;aa-=P;T-=da;ta-=P;Ja-=da;Ra-=Q;db-=Oa;hb-=Q;jb-=Oa;fb=Ra*jb-hb*db;if(fb!=0){ib=1/fb;fb=(jb*aa-db*ta)*ib;db=(jb*T-db*Ja)*ib;aa=(Ra*ta-hb*aa)*ib;T=(Ra*Ja-hb*T)*ib;P=P-fb*Q-aa*Oa;da=da-db*Q-T*Oa;n.save();n.transform(fb,db,aa,T,P,da);n.clip();n.drawImage(pa,0,0);n.restore()}}function $a(P,da,aa,T){var ta=~~(P.r* +255),Ja=~~(P.g*255);P=~~(P.b*255);var pa=~~(da.r*255),Q=~~(da.g*255);da=~~(da.b*255);var Oa=~~(aa.r*255),Ra=~~(aa.g*255);aa=~~(aa.b*255);var db=~~(T.r*255),hb=~~(T.g*255);T=~~(T.b*255);Y[0]=ta<0?0:ta>255?255:ta;Y[1]=Ja<0?0:Ja>255?255:Ja;Y[2]=P<0?0:P>255?255:P;Y[4]=pa<0?0:pa>255?255:pa;Y[5]=Q<0?0:Q>255?255:Q;Y[6]=da<0?0:da>255?255:da;Y[8]=Oa<0?0:Oa>255?255:Oa;Y[9]=Ra<0?0:Ra>255?255:Ra;Y[10]=aa<0?0:aa>255?255:aa;Y[12]=db<0?0:db>255?255:db;Y[13]=hb<0?0:hb>255?255:hb;Y[14]=T<0?0:T>255?255:T;I.putImageData(la, +0,0);sa.drawImage($,0,0);return ua}function Za(P,da,aa){P=(P-da)/(aa-da);return P*P*(3-2*P)}function Ka(P){P=(P+1)*0.5;return P<0?0:P>1?1:P}function Ya(P,da){var aa=da.x-P.x,T=da.y-P.y,ta=1/Math.sqrt(aa*aa+T*T);aa*=ta;T*=ta;da.x+=aa;da.y+=T;P.x-=aa;P.y-=T}var Ua,R,Ba,Na,gb,kb,ab,Ia;this.autoClear?this.clear():n.setTransform(1,0,0,-1,m,o);e=f.projectScene(ka,va,this.sortElements);(p=ka.lights.length>0)&&ha(ka);Ua=0;for(R=e.length;Ua0){qa.r+=U.color.r*ma;qa.g+=U.color.g*ma;qa.b+=U.color.b*ma}}else if(U instanceof THREE.PointLight){xa.sub(U.position,X.centroidWorld);xa.normalize();ma=X.normalWorld.dot(xa)*U.intensity;if(ma>0){qa.r+=U.color.r*ma;qa.g+=U.color.g*ma;qa.b+=U.color.b*ma}}}}function c(ra,X,qa,za,ea,U){Z=e(ya++); +Z.setAttribute("d","M "+ra.positionScreen.x+" "+ra.positionScreen.y+" L "+X.positionScreen.x+" "+X.positionScreen.y+" L "+qa.positionScreen.x+","+qa.positionScreen.y+"z");if(ea instanceof THREE.MeshBasicMaterial)D.__styleString=ea.color.__styleString;else if(ea instanceof THREE.MeshLambertMaterial)if(S){L.r=N.r;L.g=N.g;L.b=N.b;a(U,za,L);D.r=ea.color.r*L.r;D.g=ea.color.g*L.g;D.b=ea.color.b*L.b;D.updateStyleString()}else D.__styleString=ea.color.__styleString;else if(ea instanceof THREE.MeshDepthMaterial){oa= +1-ea.__2near/(ea.__farPlusNear-za.z*ea.__farMinusNear);D.setRGB(oa,oa,oa)}else ea instanceof THREE.MeshNormalMaterial&&D.setRGB(f(za.normalWorld.x),f(za.normalWorld.y),f(za.normalWorld.z));ea.wireframe?Z.setAttribute("style","fill: none; stroke: "+D.__styleString+"; stroke-width: "+ea.wireframeLinewidth+"; stroke-opacity: "+ea.opacity+"; stroke-linecap: "+ea.wireframeLinecap+"; stroke-linejoin: "+ea.wireframeLinejoin):Z.setAttribute("style","fill: "+D.__styleString+"; fill-opacity: "+ea.opacity); +j.appendChild(Z)}function b(ra,X,qa,za,ea,U,ma){Z=e(ya++);Z.setAttribute("d","M "+ra.positionScreen.x+" "+ra.positionScreen.y+" L "+X.positionScreen.x+" "+X.positionScreen.y+" L "+qa.positionScreen.x+","+qa.positionScreen.y+" L "+za.positionScreen.x+","+za.positionScreen.y+"z");if(U instanceof THREE.MeshBasicMaterial)D.__styleString=U.color.__styleString;else if(U instanceof THREE.MeshLambertMaterial)if(S){L.r=N.r;L.g=N.g;L.b=N.b;a(ma,ea,L);D.r=U.color.r*L.r;D.g=U.color.g*L.g;D.b=U.color.b*L.b;D.updateStyleString()}else D.__styleString= +U.color.__styleString;else if(U instanceof THREE.MeshDepthMaterial){oa=1-U.__2near/(U.__farPlusNear-ea.z*U.__farMinusNear);D.setRGB(oa,oa,oa)}else U instanceof THREE.MeshNormalMaterial&&D.setRGB(f(ea.normalWorld.x),f(ea.normalWorld.y),f(ea.normalWorld.z));U.wireframe?Z.setAttribute("style","fill: none; stroke: "+D.__styleString+"; stroke-width: "+U.wireframeLinewidth+"; stroke-opacity: "+U.opacity+"; stroke-linecap: "+U.wireframeLinecap+"; stroke-linejoin: "+U.wireframeLinejoin):Z.setAttribute("style", +"fill: "+D.__styleString+"; fill-opacity: "+U.opacity);j.appendChild(Z)}function e(ra){if(W[ra]==null){W[ra]=document.createElementNS("http://www.w3.org/2000/svg","path");Ha==0&&W[ra].setAttribute("shape-rendering","crispEdges")}return W[ra]}function f(ra){return ra<0?Math.min((1+ra)*0.5,0.5):0.5+Math.min(ra*0.5,0.5)}var g=null,h=new THREE.Projector,j=document.createElementNS("http://www.w3.org/2000/svg","svg"),m,o,n,t,y,w,z,E,G=new THREE.Rectangle,J=new THREE.Rectangle,S=!1,D=new THREE.Color(16777215), +L=new THREE.Color(16777215),N=new THREE.Color(0),O=new THREE.Color(0),Fa=new THREE.Color(0),oa,xa=new THREE.Vector3,W=[],d=[],Z,ya,Ga,Ha=1;this.domElement=j;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setQuality=function(ra){switch(ra){case "high":Ha=1;break;case "low":Ha=0}};this.setSize=function(ra,X){m=ra;o=X;n=m/2;t=o/2;j.setAttribute("viewBox",-n+" "+-t+" "+m+" "+o);j.setAttribute("width",m);j.setAttribute("height",o);G.set(-n,-t,n,t)};this.clear=function(){for(;j.childNodes.length> +0;)j.removeChild(j.childNodes[0])};this.render=function(ra,X){var qa,za,ea,U,ma,Ca,fa,ja;this.autoClear&&this.clear();g=h.projectScene(ra,X,this.sortElements);Ga=ya=0;if(S=ra.lights.length>0){fa=ra.lights;N.setRGB(0,0,0);O.setRGB(0,0,0);Fa.setRGB(0,0,0);qa=0;for(za=fa.length;qaD){ca=I;D=E[ca]}d.bindBuffer(d.ARRAY_BUFFER,C.__webglMorphTargetsBuffers[ca]);d.vertexAttribPointer(y["morphTarget"+B],3,d.FLOAT,!1,0,0);L.__webglMorphTargetInfluences[B]=D;H[ca]=1;D=-1;B++}}d.uniform1fv(p.program.uniforms.morphTargetInfluences, -L.__webglMorphTargetInfluences)}else{d.bindBuffer(d.ARRAY_BUFFER,C.__webglVertexBuffer);d.vertexAttribPointer(k.position,3,d.FLOAT,!1,0,0)}if(k.color>=0){d.bindBuffer(d.ARRAY_BUFFER,C.__webglColorBuffer);d.vertexAttribPointer(k.color,3,d.FLOAT,!1,0,0)}if(k.normal>=0){d.bindBuffer(d.ARRAY_BUFFER,C.__webglNormalBuffer);d.vertexAttribPointer(k.normal,3,d.FLOAT,!1,0,0)}if(k.tangent>=0){d.bindBuffer(d.ARRAY_BUFFER,C.__webglTangentBuffer);d.vertexAttribPointer(k.tangent,4,d.FLOAT,!1,0,0)}if(k.uv>=0)if(C.__webglUVBuffer){d.bindBuffer(d.ARRAY_BUFFER, -C.__webglUVBuffer);d.vertexAttribPointer(k.uv,2,d.FLOAT,!1,0,0);d.enableVertexAttribArray(k.uv)}else d.disableVertexAttribArray(k.uv);if(k.uv2>=0)if(C.__webglUV2Buffer){d.bindBuffer(d.ARRAY_BUFFER,C.__webglUV2Buffer);d.vertexAttribPointer(k.uv2,2,d.FLOAT,!1,0,0);d.enableVertexAttribArray(k.uv2)}else d.disableVertexAttribArray(k.uv2);if(p.skinning&&k.skinVertexA>=0&&k.skinVertexB>=0&&k.skinIndex>=0&&k.skinWeight>=0){d.bindBuffer(d.ARRAY_BUFFER,C.__webglSkinVertexABuffer);d.vertexAttribPointer(k.skinVertexA, -4,d.FLOAT,!1,0,0);d.bindBuffer(d.ARRAY_BUFFER,C.__webglSkinVertexBBuffer);d.vertexAttribPointer(k.skinVertexB,4,d.FLOAT,!1,0,0);d.bindBuffer(d.ARRAY_BUFFER,C.__webglSkinIndicesBuffer);d.vertexAttribPointer(k.skinIndex,4,d.FLOAT,!1,0,0);d.bindBuffer(d.ARRAY_BUFFER,C.__webglSkinWeightsBuffer);d.vertexAttribPointer(k.skinWeight,4,d.FLOAT,!1,0,0)}if(L instanceof THREE.Mesh)if(p.wireframe){d.lineWidth(p.wireframeLinewidth);d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,C.__webglLineBuffer);d.drawElements(d.LINES, -C.__webglLineCount,d.UNSIGNED_SHORT,0)}else{d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,C.__webglFaceBuffer);d.drawElements(d.TRIANGLES,C.__webglFaceCount,d.UNSIGNED_SHORT,0)}else if(L instanceof THREE.Line){L=L.type==THREE.LineStrip?d.LINE_STRIP:d.LINES;d.lineWidth(p.linewidth);d.drawArrays(L,0,C.__webglLineCount)}else if(L instanceof THREE.ParticleSystem)d.drawArrays(d.POINTS,0,C.__webglParticleCount);else L instanceof THREE.Ribbon&&d.drawArrays(d.TRIANGLE_STRIP,0,C.__webglVertexCount)}}function g(k,y){if(!k.__webglVertexBuffer)k.__webglVertexBuffer= -d.createBuffer();if(!k.__webglNormalBuffer)k.__webglNormalBuffer=d.createBuffer();if(k.hasPos){d.bindBuffer(d.ARRAY_BUFFER,k.__webglVertexBuffer);d.bufferData(d.ARRAY_BUFFER,k.positionArray,d.DYNAMIC_DRAW);d.enableVertexAttribArray(y.attributes.position);d.vertexAttribPointer(y.attributes.position,3,d.FLOAT,!1,0,0)}if(k.hasNormal){d.bindBuffer(d.ARRAY_BUFFER,k.__webglNormalBuffer);d.bufferData(d.ARRAY_BUFFER,k.normalArray,d.DYNAMIC_DRAW);d.enableVertexAttribArray(y.attributes.normal);d.vertexAttribPointer(y.attributes.normal, -3,d.FLOAT,!1,0,0)}d.drawArrays(d.TRIANGLES,0,k.count);k.count=0}function h(k){if(sa!=k.doubleSided){k.doubleSided?d.disable(d.CULL_FACE):d.enable(d.CULL_FACE);sa=k.doubleSided}if(aa!=k.flipSided){k.flipSided?d.frontFace(d.CW):d.frontFace(d.CCW);aa=k.flipSided}}function j(k){if(Aa!=k){k?d.enable(d.DEPTH_TEST):d.disable(d.DEPTH_TEST);Aa=k}}function m(k){ia[0].set(k.n41-k.n11,k.n42-k.n12,k.n43-k.n13,k.n44-k.n14);ia[1].set(k.n41+k.n11,k.n42+k.n12,k.n43+k.n13,k.n44+k.n14);ia[2].set(k.n41+k.n21,k.n42+k.n22, -k.n43+k.n23,k.n44+k.n24);ia[3].set(k.n41-k.n21,k.n42-k.n22,k.n43-k.n23,k.n44-k.n24);ia[4].set(k.n41-k.n31,k.n42-k.n32,k.n43-k.n33,k.n44-k.n34);ia[5].set(k.n41+k.n31,k.n42+k.n32,k.n43+k.n33,k.n44+k.n34);var y;for(k=0;k<6;k++){y=ia[k];y.divideScalar(Math.sqrt(y.x*y.x+y.y*y.y+y.z*y.z))}}function o(k){for(var y=k.matrixWorld,B=-k.geometry.boundingSphere.radius*Math.max(k.scale.x,Math.max(k.scale.y,k.scale.z)),p=0;p<6;p++){k=ia[p].x*y.n14+ia[p].y*y.n24+ia[p].z*y.n34+ia[p].w;if(k<=B)return!1}return!0}function n(k, -y){k.list[k.count]=y;k.count+=1}function t(k){var y,B,p=k.object,C=k.opaque,L=k.transparent;L.count=0;k=C.count=0;for(y=p.materials.length;k0.0010&&D.scale>0.0010){ga[0]=D.x;ga[1]=D.y;ga[2]=D.z;I=D.size*D.scale/ua;ea[0]=I*ca;ea[1]=I;d.uniform3fv(Ca.screenPosition,ga);d.uniform1f(Ca.rotation, -D.rotation);d.uniform2fv(Ca.scale,ea);d.uniform1f(Ca.opacity,D.opacity);P(D.blending);R(D.texture,0);d.drawElements(d.TRIANGLES,6,d.UNSIGNED_SHORT,0)}}}d.enable(d.CULL_FACE);d.enable(d.DEPTH_TEST);d.depthMask(!0);d.disable(d.BLEND)}function G(k,y){k._modelViewMatrix.multiplyToArray(y.matrixWorldInverse,k.matrixWorld,k._modelViewMatrixArray);THREE.Matrix4.makeInvert3x3(k._modelViewMatrix).transposeIntoArray(k._normalMatrixArray)}function K(k){var y,B,p;if(k instanceof THREE.Mesh){B=k.geometry;for(y in B.geometryGroups){p= -B.geometryGroups[y];if(B.__dirtyVertices||B.__dirtyMorphTargets||B.__dirtyElements||B.__dirtyUvs||B.__dirtyNormals||B.__dirtyColors||B.__dirtyTangents){var C=d.DYNAMIC_DRAW,L=void 0,H=void 0,E=void 0,D=void 0;E=void 0;var ca=void 0,I=void 0,ea=void 0,ga=void 0,wa=void 0,qa=void 0,la=void 0,va=void 0,Ca=void 0,da=void 0,pa=void 0,xa=void 0,La=void 0;I=void 0;ea=void 0;D=void 0;ga=void 0;D=void 0;da=void 0;pa=void 0;I=void 0;da=void 0;pa=void 0;xa=void 0;La=void 0;da=void 0;pa=void 0;xa=void 0;La=void 0; -da=void 0;pa=void 0;xa=void 0;La=void 0;da=void 0;pa=void 0;xa=void 0;D=void 0;ga=void 0;ca=void 0;E=void 0;E=void 0;var Va=void 0,Za=void 0,Ma=void 0,Ia=0,Pa=0,$a=0,eb=0,Ua=0,Wa=0,Ja=0,Xa=0,Ta=0,J=0,Ka=0,Sa=p.__vertexArray,gb=p.__uvArray,hb=p.__uv2Array,Na=p.__normalArray,N=p.__tangentArray,ja=p.__colorArray,fa=p.__skinVertexAArray,Z=p.__skinVertexBArray,ta=p.__skinIndexArray,ra=p.__skinWeightArray,za=p.__morphTargetsArrays,U=p.__faceArray,Ha=p.__lineArray,fb=p.__needsSmoothNormals;qa=p.__vertexColorType; -wa=p.__uvType;la=p.__normalType;var Oa=k.geometry,cb=Oa.__dirtyVertices,jb=Oa.__dirtyElements,ab=Oa.__dirtyUvs,db=Oa.__dirtyNormals,qb=Oa.__dirtyTangents,rb=Oa.__dirtyColors,sb=Oa.__dirtyMorphTargets,mb=Oa.vertices,tb=p.faces,wb=Oa.faces,ub=Oa.faceVertexUvs[0],vb=Oa.faceVertexUvs[1],nb=Oa.skinVerticesA,ob=Oa.skinVerticesB,pb=Oa.skinIndices,kb=Oa.skinWeights,lb=Oa.edgeFaces,ib=Oa.morphTargets;L=0;for(H=tb.length;L0){d.bindBuffer(d.ARRAY_BUFFER,p.__webglColorBuffer);d.bufferData(d.ARRAY_BUFFER,ja,C)}if(db){d.bindBuffer(d.ARRAY_BUFFER,p.__webglNormalBuffer);d.bufferData(d.ARRAY_BUFFER,Na,C)}if(qb&&Oa.hasTangents){d.bindBuffer(d.ARRAY_BUFFER, -p.__webglTangentBuffer);d.bufferData(d.ARRAY_BUFFER,N,C)}if(ab&&$a>0){d.bindBuffer(d.ARRAY_BUFFER,p.__webglUVBuffer);d.bufferData(d.ARRAY_BUFFER,gb,C)}if(ab&&eb>0){d.bindBuffer(d.ARRAY_BUFFER,p.__webglUV2Buffer);d.bufferData(d.ARRAY_BUFFER,hb,C)}if(jb){d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,p.__webglFaceBuffer);d.bufferData(d.ELEMENT_ARRAY_BUFFER,U,C);d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,p.__webglLineBuffer);d.bufferData(d.ELEMENT_ARRAY_BUFFER,Ha,C)}if(J>0){d.bindBuffer(d.ARRAY_BUFFER,p.__webglSkinVertexABuffer); -d.bufferData(d.ARRAY_BUFFER,fa,C);d.bindBuffer(d.ARRAY_BUFFER,p.__webglSkinVertexBBuffer);d.bufferData(d.ARRAY_BUFFER,Z,C);d.bindBuffer(d.ARRAY_BUFFER,p.__webglSkinIndicesBuffer);d.bufferData(d.ARRAY_BUFFER,ta,C);d.bindBuffer(d.ARRAY_BUFFER,p.__webglSkinWeightsBuffer);d.bufferData(d.ARRAY_BUFFER,ra,C)}}}B.__dirtyVertices=!1;B.__dirtyMorphTargets=!1;B.__dirtyElements=!1;B.__dirtyUvs=!1;B.__dirtyNormals=!1;B.__dirtyTangents=!1;B.__dirtyColors=!1}else if(k instanceof THREE.Ribbon){B=k.geometry;if(B.__dirtyVertices|| -B.__dirtyColors){k=B;y=d.DYNAMIC_DRAW;la=k.vertices;C=k.colors;va=la.length;L=C.length;Ca=k.__vertexArray;H=k.__colorArray;Ia=k.__dirtyColors;if(k.__dirtyVertices){for(wa=0;wa65535){I[D].counter+=1;ca=I[D].hash+"_"+I[D].counter;k.geometryGroups[ca]==undefined&&(k.geometryGroups[ca]={faces:[],materials:E,vertices:0, -numMorphTargets:ea})}k.geometryGroups[ca].faces.push(C);k.geometryGroups[ca].vertices+=H}}function z(k,y,B){k.push({buffer:y,object:B,opaque:{list:[],count:0},transparent:{list:[],count:0}})}function P(k){if(k!=oa){switch(k){case THREE.AdditiveAlphaBlending:d.blendEquation(d.FUNC_ADD);d.blendFunc(d.SRC_ALPHA,d.ONE);break;case THREE.AdditiveBlending:d.blendEquation(d.FUNC_ADD);d.blendFunc(d.SRC_ALPHA,d.ONE);break;case THREE.SubtractiveBlending:d.blendEquation(d.FUNC_ADD);d.blendFunc(d.ZERO,d.ONE_MINUS_SRC_COLOR); -break;case THREE.MultiplyBlending:d.blendEquation(d.FUNC_ADD);d.blendFunc(d.ZERO,d.SRC_COLOR);break;default:d.blendEquationSeparate(d.FUNC_ADD,d.FUNC_ADD);d.blendFuncSeparate(d.SRC_ALPHA,d.ONE_MINUS_SRC_ALPHA,d.ONE,d.ONE_MINUS_SRC_ALPHA)}oa=k}}function Q(k,y,B){if((B.width&B.width-1)==0&&(B.height&B.height-1)==0){d.texParameteri(k,d.TEXTURE_WRAP_S,Y(y.wrapS));d.texParameteri(k,d.TEXTURE_WRAP_T,Y(y.wrapT));d.texParameteri(k,d.TEXTURE_MAG_FILTER,Y(y.magFilter));d.texParameteri(k,d.TEXTURE_MIN_FILTER, -Y(y.minFilter));d.generateMipmap(k)}else{d.texParameteri(k,d.TEXTURE_WRAP_S,d.CLAMP_TO_EDGE);d.texParameteri(k,d.TEXTURE_WRAP_T,d.CLAMP_TO_EDGE);d.texParameteri(k,d.TEXTURE_MAG_FILTER,na(y.magFilter));d.texParameteri(k,d.TEXTURE_MIN_FILTER,na(y.minFilter))}}function R(k,y){if(k.needsUpdate){if(k.__webglInit){d.bindTexture(d.TEXTURE_2D,k.__webglTexture);d.texSubImage2D(d.TEXTURE_2D,0,0,0,d.RGBA,d.UNSIGNED_BYTE,k.image)}else{k.__webglTexture=d.createTexture();d.bindTexture(d.TEXTURE_2D,k.__webglTexture); -d.texImage2D(d.TEXTURE_2D,0,d.RGBA,d.RGBA,d.UNSIGNED_BYTE,k.image);k.__webglInit=!0}Q(d.TEXTURE_2D,k,k.image);d.bindTexture(d.TEXTURE_2D,null);k.needsUpdate=!1}d.activeTexture(d.TEXTURE0+y);d.bindTexture(d.TEXTURE_2D,k.__webglTexture)}function Da(k){if(k&&!k.__webglFramebuffer){k.__webglFramebuffer=d.createFramebuffer();k.__webglRenderbuffer=d.createRenderbuffer();k.__webglTexture=d.createTexture();d.bindRenderbuffer(d.RENDERBUFFER,k.__webglRenderbuffer);d.renderbufferStorage(d.RENDERBUFFER,d.DEPTH_COMPONENT16, -k.width,k.height);d.bindTexture(d.TEXTURE_2D,k.__webglTexture);d.texParameteri(d.TEXTURE_2D,d.TEXTURE_WRAP_S,Y(k.wrapS));d.texParameteri(d.TEXTURE_2D,d.TEXTURE_WRAP_T,Y(k.wrapT));d.texParameteri(d.TEXTURE_2D,d.TEXTURE_MAG_FILTER,Y(k.magFilter));d.texParameteri(d.TEXTURE_2D,d.TEXTURE_MIN_FILTER,Y(k.minFilter));d.texImage2D(d.TEXTURE_2D,0,Y(k.format),k.width,k.height,0,Y(k.format),Y(k.type),null);d.bindFramebuffer(d.FRAMEBUFFER,k.__webglFramebuffer);d.framebufferTexture2D(d.FRAMEBUFFER,d.COLOR_ATTACHMENT0, -d.TEXTURE_2D,k.__webglTexture,0);d.framebufferRenderbuffer(d.FRAMEBUFFER,d.DEPTH_ATTACHMENT,d.RENDERBUFFER,k.__webglRenderbuffer);d.bindTexture(d.TEXTURE_2D,null);d.bindRenderbuffer(d.RENDERBUFFER,null);d.bindFramebuffer(d.FRAMEBUFFER,null)}var y,B;if(k){y=k.__webglFramebuffer;B=k.width;k=k.height}else{y=null;B=ka;k=ua}if(y!=Ea){d.bindFramebuffer(d.FRAMEBUFFER,y);d.viewport(V,S,B,k);Ea=y}}function ha(k,y){var B;if(k=="fragment")B=d.createShader(d.FRAGMENT_SHADER);else k=="vertex"&&(B=d.createShader(d.VERTEX_SHADER)); -d.shaderSource(B,y);d.compileShader(B);if(!d.getShaderParameter(B,d.COMPILE_STATUS)){console.error(d.getShaderInfoLog(B));console.error(y);return null}return B}function na(k){switch(k){case THREE.NearestFilter:case THREE.NearestMipMapNearestFilter:case THREE.NearestMipMapLinearFilter:return d.NEAREST;default:return d.LINEAR}}function Y(k){switch(k){case THREE.RepeatWrapping:return d.REPEAT;case THREE.ClampToEdgeWrapping:return d.CLAMP_TO_EDGE;case THREE.MirroredRepeatWrapping:return d.MIRRORED_REPEAT; -case THREE.NearestFilter:return d.NEAREST;case THREE.NearestMipMapNearestFilter:return d.NEAREST_MIPMAP_NEAREST;case THREE.NearestMipMapLinearFilter:return d.NEAREST_MIPMAP_LINEAR;case THREE.LinearFilter:return d.LINEAR;case THREE.LinearMipMapNearestFilter:return d.LINEAR_MIPMAP_NEAREST;case THREE.LinearMipMapLinearFilter:return d.LINEAR_MIPMAP_LINEAR;case THREE.ByteType:return d.BYTE;case THREE.UnsignedByteType:return d.UNSIGNED_BYTE;case THREE.ShortType:return d.SHORT;case THREE.UnsignedShortType:return d.UNSIGNED_SHORT; -case THREE.IntType:return d.INT;case THREE.UnsignedShortType:return d.UNSIGNED_INT;case THREE.FloatType:return d.FLOAT;case THREE.AlphaFormat:return d.ALPHA;case THREE.RGBFormat:return d.RGB;case THREE.RGBAFormat:return d.RGBA;case THREE.LuminanceFormat:return d.LUMINANCE;case THREE.LuminanceAlphaFormat:return d.LUMINANCE_ALPHA}return 0}var d,$=document.createElement("canvas"),ya=null,Ea=null,Fa=this,sa=null,aa=null,oa=null,Aa=null,V=0,S=0,ka=0,ua=0,ia=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4, -new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],Ba=new THREE.Matrix4,Ga=new Float32Array(16),Qa=new Float32Array(16),Ra=new THREE.Vector4,bb={ambient:[0,0,0],directional:{length:0,colors:[],positions:[]},point:{length:0,colors:[],positions:[],distances:[]}},Ya=!0,M=!0,X=new THREE.Color(0),ma=0;if(a){if(a.stencil!=undefined)Ya=a.stencil;if(a.antialias!==undefined)M=a.antialias;a.clearColor!==undefined&&X.setHex(a.clearColor);if(a.clearAlpha!==undefined)ma=a.clearAlpha}this.maxMorphTargets=8; -this.domElement=$;this.autoClear=!0;this.sortObjects=!0;(function(k,y,B,p){try{if(!(d=$.getContext("experimental-webgl",{antialias:k,stencil:p})))throw"Error creating WebGL context.";}catch(C){console.error(C)}d.clearColor(0,0,0,1);d.clearDepth(1);d.enable(d.DEPTH_TEST);d.depthFunc(d.LEQUAL);d.frontFace(d.CCW);d.cullFace(d.BACK);d.enable(d.CULL_FACE);d.enable(d.BLEND);d.blendEquation(d.FUNC_ADD);d.blendFunc(d.SRC_ALPHA,d.ONE_MINUS_SRC_ALPHA);d.clearColor(y.r,y.g,y.b,B)})(M,X,ma,Ya);this.context=d; -if(Ya){var W={};W.vertices=new Float32Array(12);W.faces=new Uint16Array(6);W.darkness=0.5;W.vertices[0]=-2;W.vertices[1]=-1;W.vertices[2]=-1;W.vertices[3]=2;W.vertices[4]=-1;W.vertices[5]=-1;W.vertices[6]=2;W.vertices[7]=1;W.vertices[8]=-1;W.vertices[9]=-2;W.vertices[10]=1;W.vertices[11]=-1;W.faces[0]=0;W.faces[1]=1;W.faces[2]=2;W.faces[3]=0;W.faces[4]=2;W.faces[5]=3;W.vertexBuffer=d.createBuffer();W.elementBuffer=d.createBuffer();d.bindBuffer(d.ARRAY_BUFFER,W.vertexBuffer);d.bufferData(d.ARRAY_BUFFER, -W.vertices,d.STATIC_DRAW);d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,W.elementBuffer);d.bufferData(d.ELEMENT_ARRAY_BUFFER,W.faces,d.STATIC_DRAW);W.program=d.createProgram();d.attachShader(W.program,ha("fragment",THREE.ShaderLib.shadowPost.fragmentShader));d.attachShader(W.program,ha("vertex",THREE.ShaderLib.shadowPost.vertexShader));d.linkProgram(W.program);W.vertexLocation=d.getAttribLocation(W.program,"position");W.projectionLocation=d.getUniformLocation(W.program,"projectionMatrix");W.darknessLocation= -d.getUniformLocation(W.program,"darkness")}var T={};T.vertices=new Float32Array(16);T.faces=new Uint16Array(6);T.transparency=0.5;a=0;T.vertices[a++]=-1;T.vertices[a++]=-1;T.vertices[a++]=0;T.vertices[a++]=0;T.vertices[a++]=1;T.vertices[a++]=-1;T.vertices[a++]=1;T.vertices[a++]=0;T.vertices[a++]=1;T.vertices[a++]=1;T.vertices[a++]=1;T.vertices[a++]=1;T.vertices[a++]=-1;T.vertices[a++]=1;T.vertices[a++]=0;T.vertices[a++]=1;a=0;T.faces[a++]=0;T.faces[a++]=1;T.faces[a++]=2;T.faces[a++]=0;T.faces[a++]= -2;T.faces[a++]=3;T.vertexBuffer=d.createBuffer();T.elementBuffer=d.createBuffer();T.tempTexture=d.createTexture();T.readBackPixels=new Uint8Array(1024);d.bindBuffer(d.ARRAY_BUFFER,T.vertexBuffer);d.bufferData(d.ARRAY_BUFFER,T.vertices,d.STATIC_DRAW);d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,T.elementBuffer);d.bufferData(d.ELEMENT_ARRAY_BUFFER,T.faces,d.STATIC_DRAW);d.bindTexture(d.TEXTURE_2D,T.tempTexture);d.texImage2D(d.TEXTURE_2D,0,d.RGB,16,16,0,d.RGB,d.UNSIGNED_BYTE,null);d.texParameteri(d.TEXTURE_2D, -d.TEXTURE_WRAP_S,d.CLAMP_TO_EDGE);d.texParameteri(d.TEXTURE_2D,d.TEXTURE_WRAP_T,d.CLAMP_TO_EDGE);d.texParameteri(d.TEXTURE_2D,d.TEXTURE_MAG_FILTER,d.NEAREST);d.texParameteri(d.TEXTURE_2D,d.TEXTURE_MIN_FILTER,d.NEAREST);T.program=d.createProgram();d.attachShader(T.program,ha("fragment",THREE.ShaderLib.lensFlare.fragmentShader));d.attachShader(T.program,ha("vertex",THREE.ShaderLib.lensFlare.vertexShader));d.linkProgram(T.program);T.attributes={};T.uniforms={};T.attributes.vertex=d.getAttribLocation(T.program, -"position");T.attributes.uv=d.getAttribLocation(T.program,"UV");T.uniforms.map=d.getUniformLocation(T.program,"map");T.uniforms.opacity=d.getUniformLocation(T.program,"opacity");T.uniforms.scale=d.getUniformLocation(T.program,"scale");T.uniforms.rotation=d.getUniformLocation(T.program,"rotation");T.uniforms.screenPosition=d.getUniformLocation(T.program,"screenPosition");T.uniforms.renderPink=d.getUniformLocation(T.program,"renderPink");this.setSize=function(k,y){$.width=k;$.height=y;this.setViewport(0, -0,$.width,$.height)};this.setViewport=function(k,y,B,p){V=k;S=y;ka=B;ua=p;d.viewport(V,S,ka,ua)};this.setScissor=function(k,y,B,p){d.scissor(k,y,B,p)};this.enableScissorTest=function(k){k?d.enable(d.SCISSOR_TEST):d.disable(d.SCISSOR_TEST)};this.enableDepthBufferWrite=function(k){d.depthMask(k)};this.setClearColorHex=function(k,y){var B=new THREE.Color(k);d.clearColor(B.r,B.g,B.b,y)};this.setClearColor=function(k,y){d.clearColor(k.r,k.g,k.b,y)};this.clear=function(){d.clear(d.COLOR_BUFFER_BIT|d.DEPTH_BUFFER_BIT| -d.STENCIL_BUFFER_BIT)};this.setStencilShadowDarkness=function(k){W.darkness=k};this.initMaterial=function(k,y,B,p){var C,L,H,E;if(k instanceof THREE.MeshDepthMaterial)b(k,THREE.ShaderLib.depth);else if(k instanceof THREE.ShadowVolumeDynamicMaterial)b(k,THREE.ShaderLib.shadowVolumeDynamic);else if(k instanceof THREE.MeshNormalMaterial)b(k,THREE.ShaderLib.normal);else if(k instanceof THREE.MeshBasicMaterial)b(k,THREE.ShaderLib.basic);else if(k instanceof THREE.MeshLambertMaterial)b(k,THREE.ShaderLib.lambert); -else if(k instanceof THREE.MeshPhongMaterial)b(k,THREE.ShaderLib.phong);else if(k instanceof THREE.LineBasicMaterial)b(k,THREE.ShaderLib.basic);else k instanceof THREE.ParticleBasicMaterial&&b(k,THREE.ShaderLib.particle_basic);if(!k.program){var D,ca,I;D=I=E=0;for(H=y.length;D0?"#define VERTEX_TEXTURES":"","#define MAX_DIR_LIGHTS "+H.maxDirLights,"#define MAX_POINT_LIGHTS "+H.maxPointLights,"#define MAX_BONES "+H.maxBones,H.map?"#define USE_MAP":"",H.envMap?"#define USE_ENVMAP":"",H.lightMap?"#define USE_LIGHTMAP": -"",H.vertexColors?"#define USE_COLOR":"",H.skinning?"#define USE_SKINNING":"",H.morphTargets?"#define USE_MORPHTARGETS":"",H.sizeAttenuation?"#define USE_SIZEATTENUATION":"","uniform mat4 objectMatrix;\nuniform mat4 modelViewMatrix;\nuniform mat4 projectionMatrix;\nuniform mat4 viewMatrix;\nuniform mat3 normalMatrix;\nuniform vec3 cameraPosition;\nuniform mat4 cameraInverseMatrix;\nattribute vec3 position;\nattribute vec3 normal;\nattribute vec2 uv;\nattribute vec2 uv2;\n#ifdef USE_COLOR\nattribute vec3 color;\n#endif\n#ifdef USE_MORPHTARGETS\nattribute vec3 morphTarget0;\nattribute vec3 morphTarget1;\nattribute vec3 morphTarget2;\nattribute vec3 morphTarget3;\nattribute vec3 morphTarget4;\nattribute vec3 morphTarget5;\nattribute vec3 morphTarget6;\nattribute vec3 morphTarget7;\n#endif\n#ifdef USE_SKINNING\nattribute vec4 skinVertexA;\nattribute vec4 skinVertexB;\nattribute vec4 skinIndex;\nattribute vec4 skinWeight;\n#endif\n"].join("\n"); -d.attachShader(y,ha("fragment",D+B));d.attachShader(y,ha("vertex",H+E));d.linkProgram(y);d.getProgramParameter(y,d.LINK_STATUS)||console.error("Could not initialise shader\nVALIDATE_STATUS: "+d.getProgramParameter(y,d.VALIDATE_STATUS)+", gl error ["+d.getError()+"]");y.uniforms={};y.attributes={};k.program=y;B=["viewMatrix","modelViewMatrix","projectionMatrix","normalMatrix","objectMatrix","cameraPosition","cameraInverseMatrix","boneGlobalMatrices","morphTargetInfluences"];for(C in k.uniforms)B.push(C); -C=k.program;E=0;for(y=B.length;E=0&&d.enableVertexAttribArray(L.color);L.normal>=0&&d.enableVertexAttribArray(L.normal); -L.tangent>=0&&d.enableVertexAttribArray(L.tangent);if(k.skinning&&L.skinVertexA>=0&&L.skinVertexB>=0&&L.skinIndex>=0&&L.skinWeight>=0){d.enableVertexAttribArray(L.skinVertexA);d.enableVertexAttribArray(L.skinVertexB);d.enableVertexAttribArray(L.skinIndex);d.enableVertexAttribArray(L.skinWeight)}if(k.morphTargets){k.numSupportedMorphTargets=0;if(L.morphTarget0>=0){d.enableVertexAttribArray(L.morphTarget0);k.numSupportedMorphTargets++}if(L.morphTarget1>=0){d.enableVertexAttribArray(L.morphTarget1); -k.numSupportedMorphTargets++}if(L.morphTarget2>=0){d.enableVertexAttribArray(L.morphTarget2);k.numSupportedMorphTargets++}if(L.morphTarget3>=0){d.enableVertexAttribArray(L.morphTarget3);k.numSupportedMorphTargets++}if(L.morphTarget4>=0){d.enableVertexAttribArray(L.morphTarget4);k.numSupportedMorphTargets++}if(L.morphTarget5>=0){d.enableVertexAttribArray(L.morphTarget5);k.numSupportedMorphTargets++}if(L.morphTarget6>=0){d.enableVertexAttribArray(L.morphTarget6);k.numSupportedMorphTargets++}if(L.morphTarget7>= -0){d.enableVertexAttribArray(L.morphTarget7);k.numSupportedMorphTargets++}p.__webglMorphTargetInfluences=new Float32Array(this.maxMorphTargets);C=0;for(L=this.maxMorphTargets;C0||la.faceVertexUvs.length>0)H.__uvArray=new Float32Array(D*2);if(la.faceUvs.length>1||la.faceVertexUvs.length>1)H.__uv2Array=new Float32Array(D*2)}if(E.geometry.skinWeights.length&&E.geometry.skinIndices.length){H.__skinVertexAArray=new Float32Array(D*4);H.__skinVertexBArray=new Float32Array(D* -4);H.__skinIndexArray=new Float32Array(D*4);H.__skinWeightArray=new Float32Array(D*4)}H.__faceArray=new Uint16Array(ga*3+(E.geometry.edgeFaces?E.geometry.edgeFaces.length*6:0));H.__lineArray=new Uint16Array(wa*2);if(H.numMorphTargets){la=void 0;va=void 0;H.__morphTargetsArrays=[];la=0;for(va=H.numMorphTargets;la=0;C--){p=B.__webglObjects[C].object;y==p&&B.__webglObjects.splice(C,1)}k.__objectsRemoved.splice(0,1)}y=0;for(B=k.__webglObjects.length;y0}}; +THREE.WebGLRenderer=function(a){function c(k,B,x){var p,A,F,H=k.vertices,K=H.length,C=k.colors,$=C.length,I=k.__vertexArray,la=k.__colorArray,Y=k.__sortArray,ua=k.__dirtyVertices,sa=k.__dirtyColors;if(x.sortParticles){Da.multiplySelf(x.matrixWorld);for(p=0;pC){$=I;C=K[$]}d.bindBuffer(d.ARRAY_BUFFER,A.__webglMorphTargetsBuffers[$]);d.vertexAttribPointer(B["morphTarget"+x],3,d.FLOAT,!1,0,0);F.__webglMorphTargetInfluences[x]=C;H[$]=1;C=-1;x++}}d.uniform1fv(p.program.uniforms.morphTargetInfluences,F.__webglMorphTargetInfluences)}else{d.bindBuffer(d.ARRAY_BUFFER, +A.__webglVertexBuffer);d.vertexAttribPointer(k.position,3,d.FLOAT,!1,0,0)}if(k.color>=0){d.bindBuffer(d.ARRAY_BUFFER,A.__webglColorBuffer);d.vertexAttribPointer(k.color,3,d.FLOAT,!1,0,0)}if(k.normal>=0){d.bindBuffer(d.ARRAY_BUFFER,A.__webglNormalBuffer);d.vertexAttribPointer(k.normal,3,d.FLOAT,!1,0,0)}if(k.tangent>=0){d.bindBuffer(d.ARRAY_BUFFER,A.__webglTangentBuffer);d.vertexAttribPointer(k.tangent,4,d.FLOAT,!1,0,0)}if(k.uv>=0)if(A.__webglUVBuffer){d.bindBuffer(d.ARRAY_BUFFER,A.__webglUVBuffer); +d.vertexAttribPointer(k.uv,2,d.FLOAT,!1,0,0);d.enableVertexAttribArray(k.uv)}else d.disableVertexAttribArray(k.uv);if(k.uv2>=0)if(A.__webglUV2Buffer){d.bindBuffer(d.ARRAY_BUFFER,A.__webglUV2Buffer);d.vertexAttribPointer(k.uv2,2,d.FLOAT,!1,0,0);d.enableVertexAttribArray(k.uv2)}else d.disableVertexAttribArray(k.uv2);if(p.skinning&&k.skinVertexA>=0&&k.skinVertexB>=0&&k.skinIndex>=0&&k.skinWeight>=0){d.bindBuffer(d.ARRAY_BUFFER,A.__webglSkinVertexABuffer);d.vertexAttribPointer(k.skinVertexA,4,d.FLOAT, +!1,0,0);d.bindBuffer(d.ARRAY_BUFFER,A.__webglSkinVertexBBuffer);d.vertexAttribPointer(k.skinVertexB,4,d.FLOAT,!1,0,0);d.bindBuffer(d.ARRAY_BUFFER,A.__webglSkinIndicesBuffer);d.vertexAttribPointer(k.skinIndex,4,d.FLOAT,!1,0,0);d.bindBuffer(d.ARRAY_BUFFER,A.__webglSkinWeightsBuffer);d.vertexAttribPointer(k.skinWeight,4,d.FLOAT,!1,0,0)}if(F instanceof THREE.Mesh)if(p.wireframe){d.lineWidth(p.wireframeLinewidth);d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,A.__webglLineBuffer);d.drawElements(d.LINES,A.__webglLineCount, +d.UNSIGNED_SHORT,0)}else{d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,A.__webglFaceBuffer);d.drawElements(d.TRIANGLES,A.__webglFaceCount,d.UNSIGNED_SHORT,0)}else if(F instanceof THREE.Line){F=F.type==THREE.LineStrip?d.LINE_STRIP:d.LINES;d.lineWidth(p.linewidth);d.drawArrays(F,0,A.__webglLineCount)}else if(F instanceof THREE.ParticleSystem)d.drawArrays(d.POINTS,0,A.__webglParticleCount);else F instanceof THREE.Ribbon&&d.drawArrays(d.TRIANGLE_STRIP,0,A.__webglVertexCount)}}function g(k,B){if(!k.__webglVertexBuffer)k.__webglVertexBuffer= +d.createBuffer();if(!k.__webglNormalBuffer)k.__webglNormalBuffer=d.createBuffer();if(k.hasPos){d.bindBuffer(d.ARRAY_BUFFER,k.__webglVertexBuffer);d.bufferData(d.ARRAY_BUFFER,k.positionArray,d.DYNAMIC_DRAW);d.enableVertexAttribArray(B.attributes.position);d.vertexAttribPointer(B.attributes.position,3,d.FLOAT,!1,0,0)}if(k.hasNormal){d.bindBuffer(d.ARRAY_BUFFER,k.__webglNormalBuffer);d.bufferData(d.ARRAY_BUFFER,k.normalArray,d.DYNAMIC_DRAW);d.enableVertexAttribArray(B.attributes.normal);d.vertexAttribPointer(B.attributes.normal, +3,d.FLOAT,!1,0,0)}d.drawArrays(d.TRIANGLES,0,k.count);k.count=0}function h(k){if(X!=k.doubleSided){k.doubleSided?d.disable(d.CULL_FACE):d.enable(d.CULL_FACE);X=k.doubleSided}if(qa!=k.flipSided){k.flipSided?d.frontFace(d.CW):d.frontFace(d.CCW);qa=k.flipSided}}function j(k){if(ea!=k){k?d.enable(d.DEPTH_TEST):d.disable(d.DEPTH_TEST);ea=k}}function m(k){ja[0].set(k.n41-k.n11,k.n42-k.n12,k.n43-k.n13,k.n44-k.n14);ja[1].set(k.n41+k.n11,k.n42+k.n12,k.n43+k.n13,k.n44+k.n14);ja[2].set(k.n41+k.n21,k.n42+k.n22, +k.n43+k.n23,k.n44+k.n24);ja[3].set(k.n41-k.n21,k.n42-k.n22,k.n43-k.n23,k.n44-k.n24);ja[4].set(k.n41-k.n31,k.n42-k.n32,k.n43-k.n33,k.n44-k.n34);ja[5].set(k.n41+k.n31,k.n42+k.n32,k.n43+k.n33,k.n44+k.n34);var B;for(k=0;k<6;k++){B=ja[k];B.divideScalar(Math.sqrt(B.x*B.x+B.y*B.y+B.z*B.z))}}function o(k){for(var B=k.matrixWorld,x=-k.geometry.boundingSphere.radius*Math.max(k.scale.x,Math.max(k.scale.y,k.scale.z)),p=0;p<6;p++){k=ja[p].x*B.n14+ja[p].y*B.n24+ja[p].z*B.n34+ja[p].w;if(k<=x)return!1}return!0}function n(k, +B){k.list[k.count]=B;k.count+=1}function t(k){var B,x,p=k.object,A=k.opaque,F=k.transparent;F.count=0;k=A.count=0;for(B=p.materials.length;k0.0010&&C.scale>0.0010){Y[0]=C.x;Y[1]=C.y;Y[2]=C.z;I=C.size*C.scale/fa;la[0]=I*$;la[1]=I;d.uniform3fv(va.screenPosition,Y);d.uniform1f(va.rotation,C.rotation);d.uniform2fv(va.scale, +la);d.uniform1f(va.opacity,C.opacity);L(C.blending);O(C.texture,0);d.drawElements(d.TRIANGLES,6,d.UNSIGNED_SHORT,0)}}}d.enable(d.CULL_FACE);d.enable(d.DEPTH_TEST);d.depthMask(Ha)}function G(k,B){k._modelViewMatrix.multiplyToArray(B.matrixWorldInverse,k.matrixWorld,k._modelViewMatrixArray);THREE.Matrix4.makeInvert3x3(k._modelViewMatrix).transposeIntoArray(k._normalMatrixArray)}function J(k){var B,x,p;if(k instanceof THREE.Mesh){x=k.geometry;for(B in x.geometryGroups){p=x.geometryGroups[B];if(x.__dirtyVertices|| +x.__dirtyMorphTargets||x.__dirtyElements||x.__dirtyUvs||x.__dirtyNormals||x.__dirtyColors||x.__dirtyTangents){var A=d.DYNAMIC_DRAW,F=void 0,H=void 0,K=void 0,C=void 0;K=void 0;var $=void 0,I=void 0,la=void 0,Y=void 0,ua=void 0,sa=void 0,Ea=void 0,ka=void 0,va=void 0,ha=void 0,ia=void 0,wa=void 0,Qa=void 0;I=void 0;la=void 0;C=void 0;Y=void 0;C=void 0;ha=void 0;ia=void 0;I=void 0;ha=void 0;ia=void 0;wa=void 0;Qa=void 0;ha=void 0;ia=void 0;wa=void 0;Qa=void 0;ha=void 0;ia=void 0;wa=void 0;Qa=void 0; +ha=void 0;ia=void 0;wa=void 0;C=void 0;Y=void 0;$=void 0;K=void 0;K=void 0;var Va=void 0,eb=void 0,Ma=void 0,La=0,Pa=0,cb=0,bb=0,$a=0,Za=0,Ka=0,Ya=0,Ua=0,R=0,Ba=0,Na=p.__vertexArray,gb=p.__uvArray,kb=p.__uv2Array,ab=p.__normalArray,Ia=p.__tangentArray,P=p.__colorArray,da=p.__skinVertexAArray,aa=p.__skinVertexBArray,T=p.__skinIndexArray,ta=p.__skinWeightArray,Ja=p.__morphTargetsArrays,pa=p.__faceArray,Q=p.__lineArray,Oa=p.__needsSmoothNormals;sa=p.__vertexColorType;ua=p.__uvType;Ea=p.__normalType; +var Ra=k.geometry,db=Ra.__dirtyVertices,hb=Ra.__dirtyElements,jb=Ra.__dirtyUvs,fb=Ra.__dirtyNormals,ib=Ra.__dirtyTangents,sb=Ra.__dirtyColors,tb=Ra.__dirtyMorphTargets,ob=Ra.vertices,ub=p.faces,xb=Ra.faces,vb=Ra.faceVertexUvs[0],wb=Ra.faceVertexUvs[1],pb=Ra.skinVerticesA,qb=Ra.skinVerticesB,rb=Ra.skinIndices,mb=Ra.skinWeights,nb=Ra.edgeFaces,lb=Ra.morphTargets;F=0;for(H=ub.length;F0){d.bindBuffer(d.ARRAY_BUFFER,p.__webglColorBuffer);d.bufferData(d.ARRAY_BUFFER,P,A)}if(fb){d.bindBuffer(d.ARRAY_BUFFER,p.__webglNormalBuffer);d.bufferData(d.ARRAY_BUFFER,ab,A)}if(ib&&Ra.hasTangents){d.bindBuffer(d.ARRAY_BUFFER,p.__webglTangentBuffer);d.bufferData(d.ARRAY_BUFFER,Ia,A)}if(jb&&cb>0){d.bindBuffer(d.ARRAY_BUFFER, +p.__webglUVBuffer);d.bufferData(d.ARRAY_BUFFER,gb,A)}if(jb&&bb>0){d.bindBuffer(d.ARRAY_BUFFER,p.__webglUV2Buffer);d.bufferData(d.ARRAY_BUFFER,kb,A)}if(hb){d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,p.__webglFaceBuffer);d.bufferData(d.ELEMENT_ARRAY_BUFFER,pa,A);d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,p.__webglLineBuffer);d.bufferData(d.ELEMENT_ARRAY_BUFFER,Q,A)}if(R>0){d.bindBuffer(d.ARRAY_BUFFER,p.__webglSkinVertexABuffer);d.bufferData(d.ARRAY_BUFFER,da,A);d.bindBuffer(d.ARRAY_BUFFER,p.__webglSkinVertexBBuffer); +d.bufferData(d.ARRAY_BUFFER,aa,A);d.bindBuffer(d.ARRAY_BUFFER,p.__webglSkinIndicesBuffer);d.bufferData(d.ARRAY_BUFFER,T,A);d.bindBuffer(d.ARRAY_BUFFER,p.__webglSkinWeightsBuffer);d.bufferData(d.ARRAY_BUFFER,ta,A)}}}x.__dirtyVertices=!1;x.__dirtyMorphTargets=!1;x.__dirtyElements=!1;x.__dirtyUvs=!1;x.__dirtyNormals=!1;x.__dirtyTangents=!1;x.__dirtyColors=!1}else if(k instanceof THREE.Ribbon){x=k.geometry;if(x.__dirtyVertices||x.__dirtyColors){k=x;B=d.DYNAMIC_DRAW;Ea=k.vertices;A=k.colors;ka=Ea.length; +F=A.length;va=k.__vertexArray;H=k.__colorArray;La=k.__dirtyColors;if(k.__dirtyVertices){for(ua=0;ua65535){I[C].counter+=1;$=I[C].hash+"_"+I[C].counter;k.geometryGroups[$]==undefined&&(k.geometryGroups[$]={faces:[],materials:K,vertices:0,numMorphTargets:la})}k.geometryGroups[$].faces.push(A);k.geometryGroups[$].vertices+= +H}}function D(k,B,x){k.push({buffer:B,object:x,opaque:{list:[],count:0},transparent:{list:[],count:0}})}function L(k){if(k!=za){switch(k){case THREE.AdditiveAlphaBlending:d.blendEquation(d.FUNC_ADD);d.blendFunc(d.SRC_ALPHA,d.ONE);break;case THREE.AdditiveBlending:d.blendEquation(d.FUNC_ADD);d.blendFunc(d.SRC_ALPHA,d.ONE);break;case THREE.SubtractiveBlending:d.blendEquation(d.FUNC_ADD);d.blendFunc(d.ZERO,d.ONE_MINUS_SRC_COLOR);break;case THREE.MultiplyBlending:d.blendEquation(d.FUNC_ADD);d.blendFunc(d.ZERO, +d.SRC_COLOR);break;default:d.blendEquationSeparate(d.FUNC_ADD,d.FUNC_ADD);d.blendFuncSeparate(d.SRC_ALPHA,d.ONE_MINUS_SRC_ALPHA,d.ONE,d.ONE_MINUS_SRC_ALPHA)}za=k}}function N(k,B,x){if((x.width&x.width-1)==0&&(x.height&x.height-1)==0){d.texParameteri(k,d.TEXTURE_WRAP_S,W(B.wrapS));d.texParameteri(k,d.TEXTURE_WRAP_T,W(B.wrapT));d.texParameteri(k,d.TEXTURE_MAG_FILTER,W(B.magFilter));d.texParameteri(k,d.TEXTURE_MIN_FILTER,W(B.minFilter));d.generateMipmap(k)}else{d.texParameteri(k,d.TEXTURE_WRAP_S,d.CLAMP_TO_EDGE); +d.texParameteri(k,d.TEXTURE_WRAP_T,d.CLAMP_TO_EDGE);d.texParameteri(k,d.TEXTURE_MAG_FILTER,xa(B.magFilter));d.texParameteri(k,d.TEXTURE_MIN_FILTER,xa(B.minFilter))}}function O(k,B){if(k.needsUpdate){if(k.__webglInit){d.bindTexture(d.TEXTURE_2D,k.__webglTexture);d.texSubImage2D(d.TEXTURE_2D,0,0,0,d.RGBA,d.UNSIGNED_BYTE,k.image)}else{k.__webglTexture=d.createTexture();d.bindTexture(d.TEXTURE_2D,k.__webglTexture);d.texImage2D(d.TEXTURE_2D,0,d.RGBA,d.RGBA,d.UNSIGNED_BYTE,k.image);k.__webglInit=!0}N(d.TEXTURE_2D, +k,k.image);d.bindTexture(d.TEXTURE_2D,null);k.needsUpdate=!1}d.activeTexture(d.TEXTURE0+B);d.bindTexture(d.TEXTURE_2D,k.__webglTexture)}function Fa(k){if(k&&!k.__webglFramebuffer){k.__webglFramebuffer=d.createFramebuffer();k.__webglRenderbuffer=d.createRenderbuffer();k.__webglTexture=d.createTexture();d.bindRenderbuffer(d.RENDERBUFFER,k.__webglRenderbuffer);d.renderbufferStorage(d.RENDERBUFFER,d.DEPTH_COMPONENT16,k.width,k.height);d.bindTexture(d.TEXTURE_2D,k.__webglTexture);d.texParameteri(d.TEXTURE_2D, +d.TEXTURE_WRAP_S,W(k.wrapS));d.texParameteri(d.TEXTURE_2D,d.TEXTURE_WRAP_T,W(k.wrapT));d.texParameteri(d.TEXTURE_2D,d.TEXTURE_MAG_FILTER,W(k.magFilter));d.texParameteri(d.TEXTURE_2D,d.TEXTURE_MIN_FILTER,W(k.minFilter));d.texImage2D(d.TEXTURE_2D,0,W(k.format),k.width,k.height,0,W(k.format),W(k.type),null);d.bindFramebuffer(d.FRAMEBUFFER,k.__webglFramebuffer);d.framebufferTexture2D(d.FRAMEBUFFER,d.COLOR_ATTACHMENT0,d.TEXTURE_2D,k.__webglTexture,0);d.framebufferRenderbuffer(d.FRAMEBUFFER,d.DEPTH_ATTACHMENT, +d.RENDERBUFFER,k.__webglRenderbuffer);d.bindTexture(d.TEXTURE_2D,null);d.bindRenderbuffer(d.RENDERBUFFER,null);d.bindFramebuffer(d.FRAMEBUFFER,null)}var B,x;if(k){B=k.__webglFramebuffer;x=k.width;k=k.height}else{B=null;x=Ca;k=fa}if(B!=Ga){d.bindFramebuffer(d.FRAMEBUFFER,B);d.viewport(U,ma,x,k);Ga=B}}function oa(k,B){var x;if(k=="fragment")x=d.createShader(d.FRAGMENT_SHADER);else k=="vertex"&&(x=d.createShader(d.VERTEX_SHADER));d.shaderSource(x,B);d.compileShader(x);if(!d.getShaderParameter(x,d.COMPILE_STATUS)){console.error(d.getShaderInfoLog(x)); +console.error(B);return null}return x}function xa(k){switch(k){case THREE.NearestFilter:case THREE.NearestMipMapNearestFilter:case THREE.NearestMipMapLinearFilter:return d.NEAREST;default:return d.LINEAR}}function W(k){switch(k){case THREE.RepeatWrapping:return d.REPEAT;case THREE.ClampToEdgeWrapping:return d.CLAMP_TO_EDGE;case THREE.MirroredRepeatWrapping:return d.MIRRORED_REPEAT;case THREE.NearestFilter:return d.NEAREST;case THREE.NearestMipMapNearestFilter:return d.NEAREST_MIPMAP_NEAREST;case THREE.NearestMipMapLinearFilter:return d.NEAREST_MIPMAP_LINEAR; +case THREE.LinearFilter:return d.LINEAR;case THREE.LinearMipMapNearestFilter:return d.LINEAR_MIPMAP_NEAREST;case THREE.LinearMipMapLinearFilter:return d.LINEAR_MIPMAP_LINEAR;case THREE.ByteType:return d.BYTE;case THREE.UnsignedByteType:return d.UNSIGNED_BYTE;case THREE.ShortType:return d.SHORT;case THREE.UnsignedShortType:return d.UNSIGNED_SHORT;case THREE.IntType:return d.INT;case THREE.UnsignedShortType:return d.UNSIGNED_INT;case THREE.FloatType:return d.FLOAT;case THREE.AlphaFormat:return d.ALPHA; +case THREE.RGBFormat:return d.RGB;case THREE.RGBAFormat:return d.RGBA;case THREE.LuminanceFormat:return d.LUMINANCE;case THREE.LuminanceAlphaFormat:return d.LUMINANCE_ALPHA}return 0}var d,Z=document.createElement("canvas"),ya=null,Ga=null,Ha=!0,ra=this,X=null,qa=null,za=null,ea=null,U=0,ma=0,Ca=0,fa=0,ja=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],Da=new THREE.Matrix4,Sa=new Float32Array(16),Xa=new Float32Array(16),Wa=new THREE.Vector4, +Ta={ambient:[0,0,0],directional:{length:0,colors:[],positions:[]},point:{length:0,colors:[],positions:[],distances:[]}},M=!0,V=!0,na=new THREE.Color(0),Aa=0;if(a){if(a.stencil!=undefined)M=a.stencil;if(a.antialias!==undefined)V=a.antialias;a.clearColor!==undefined&&na.setHex(a.clearColor);if(a.clearAlpha!==undefined)Aa=a.clearAlpha}this.maxMorphTargets=8;this.domElement=Z;this.autoClear=!0;this.sortObjects=!0;(function(k,B,x,p){try{if(!(d=Z.getContext("experimental-webgl",{antialias:k,stencil:p})))throw"Error creating WebGL context."; +}catch(A){console.error(A)}d.clearColor(0,0,0,1);d.clearDepth(1);d.enable(d.DEPTH_TEST);d.depthFunc(d.LEQUAL);d.frontFace(d.CCW);d.cullFace(d.BACK);d.enable(d.CULL_FACE);d.enable(d.BLEND);d.blendEquation(d.FUNC_ADD);d.blendFunc(d.SRC_ALPHA,d.ONE_MINUS_SRC_ALPHA);d.clearColor(B.r,B.g,B.b,x)})(V,na,Aa,M);this.context=d;if(M){var ca={};ca.vertices=new Float32Array(12);ca.faces=new Uint16Array(6);ca.darkness=0.5;ca.vertices[0]=-2;ca.vertices[1]=-1;ca.vertices[2]=-1;ca.vertices[3]=2;ca.vertices[4]=-1; +ca.vertices[5]=-1;ca.vertices[6]=2;ca.vertices[7]=1;ca.vertices[8]=-1;ca.vertices[9]=-2;ca.vertices[10]=1;ca.vertices[11]=-1;ca.faces[0]=0;ca.faces[1]=1;ca.faces[2]=2;ca.faces[3]=0;ca.faces[4]=2;ca.faces[5]=3;ca.vertexBuffer=d.createBuffer();ca.elementBuffer=d.createBuffer();d.bindBuffer(d.ARRAY_BUFFER,ca.vertexBuffer);d.bufferData(d.ARRAY_BUFFER,ca.vertices,d.STATIC_DRAW);d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,ca.elementBuffer);d.bufferData(d.ELEMENT_ARRAY_BUFFER,ca.faces,d.STATIC_DRAW);ca.program= +d.createProgram();d.attachShader(ca.program,oa("fragment",THREE.ShaderLib.shadowPost.fragmentShader));d.attachShader(ca.program,oa("vertex",THREE.ShaderLib.shadowPost.vertexShader));d.linkProgram(ca.program);ca.vertexLocation=d.getAttribLocation(ca.program,"position");ca.projectionLocation=d.getUniformLocation(ca.program,"projectionMatrix");ca.darknessLocation=d.getUniformLocation(ca.program,"darkness")}var ga={};ga.vertices=new Float32Array(16);ga.faces=new Uint16Array(6);ga.transparency=0.5;a=0; +ga.vertices[a++]=-1;ga.vertices[a++]=-1;ga.vertices[a++]=0;ga.vertices[a++]=0;ga.vertices[a++]=1;ga.vertices[a++]=-1;ga.vertices[a++]=1;ga.vertices[a++]=0;ga.vertices[a++]=1;ga.vertices[a++]=1;ga.vertices[a++]=1;ga.vertices[a++]=1;ga.vertices[a++]=-1;ga.vertices[a++]=1;ga.vertices[a++]=0;ga.vertices[a++]=1;a=0;ga.faces[a++]=0;ga.faces[a++]=1;ga.faces[a++]=2;ga.faces[a++]=0;ga.faces[a++]=2;ga.faces[a++]=3;ga.vertexBuffer=d.createBuffer();ga.elementBuffer=d.createBuffer();ga.tempTexture=d.createTexture(); +ga.readBackPixels=new Uint8Array(1024);d.bindBuffer(d.ARRAY_BUFFER,ga.vertexBuffer);d.bufferData(d.ARRAY_BUFFER,ga.vertices,d.STATIC_DRAW);d.bindBuffer(d.ELEMENT_ARRAY_BUFFER,ga.elementBuffer);d.bufferData(d.ELEMENT_ARRAY_BUFFER,ga.faces,d.STATIC_DRAW);d.bindTexture(d.TEXTURE_2D,ga.tempTexture);d.texImage2D(d.TEXTURE_2D,0,d.RGB,16,16,0,d.RGB,d.UNSIGNED_BYTE,null);d.texParameteri(d.TEXTURE_2D,d.TEXTURE_WRAP_S,d.CLAMP_TO_EDGE);d.texParameteri(d.TEXTURE_2D,d.TEXTURE_WRAP_T,d.CLAMP_TO_EDGE);d.texParameteri(d.TEXTURE_2D, +d.TEXTURE_MAG_FILTER,d.NEAREST);d.texParameteri(d.TEXTURE_2D,d.TEXTURE_MIN_FILTER,d.NEAREST);ga.program=d.createProgram();d.attachShader(ga.program,oa("fragment",THREE.ShaderLib.lensFlare.fragmentShader));d.attachShader(ga.program,oa("vertex",THREE.ShaderLib.lensFlare.vertexShader));d.linkProgram(ga.program);ga.attributes={};ga.uniforms={};ga.attributes.vertex=d.getAttribLocation(ga.program,"position");ga.attributes.uv=d.getAttribLocation(ga.program,"UV");ga.uniforms.map=d.getUniformLocation(ga.program, +"map");ga.uniforms.opacity=d.getUniformLocation(ga.program,"opacity");ga.uniforms.scale=d.getUniformLocation(ga.program,"scale");ga.uniforms.rotation=d.getUniformLocation(ga.program,"rotation");ga.uniforms.screenPosition=d.getUniformLocation(ga.program,"screenPosition");ga.uniforms.renderPink=d.getUniformLocation(ga.program,"renderPink");this.setSize=function(k,B){Z.width=k;Z.height=B;this.setViewport(0,0,Z.width,Z.height)};this.setViewport=function(k,B,x,p){U=k;ma=B;Ca=x;fa=p;d.viewport(U,ma,Ca, +fa)};this.setScissor=function(k,B,x,p){d.scissor(k,B,x,p)};this.enableScissorTest=function(k){k?d.enable(d.SCISSOR_TEST):d.disable(d.SCISSOR_TEST)};this.enableDepthBufferWrite=function(k){Ha=k;d.depthMask(k)};this.setClearColorHex=function(k,B){var x=new THREE.Color(k);d.clearColor(x.r,x.g,x.b,B)};this.setClearColor=function(k,B){d.clearColor(k.r,k.g,k.b,B)};this.clear=function(){d.clear(d.COLOR_BUFFER_BIT|d.DEPTH_BUFFER_BIT|d.STENCIL_BUFFER_BIT)};this.setStencilShadowDarkness=function(k){ca.darkness= +k};this.initMaterial=function(k,B,x,p){var A,F,H,K;if(k instanceof THREE.MeshDepthMaterial)b(k,THREE.ShaderLib.depth);else if(k instanceof THREE.ShadowVolumeDynamicMaterial)b(k,THREE.ShaderLib.shadowVolumeDynamic);else if(k instanceof THREE.MeshNormalMaterial)b(k,THREE.ShaderLib.normal);else if(k instanceof THREE.MeshBasicMaterial)b(k,THREE.ShaderLib.basic);else if(k instanceof THREE.MeshLambertMaterial)b(k,THREE.ShaderLib.lambert);else if(k instanceof THREE.MeshPhongMaterial)b(k,THREE.ShaderLib.phong); +else if(k instanceof THREE.LineBasicMaterial)b(k,THREE.ShaderLib.basic);else k instanceof THREE.ParticleBasicMaterial&&b(k,THREE.ShaderLib.particle_basic);if(!k.program){var C,$,I;C=I=K=0;for(H=B.length;C0?"#define VERTEX_TEXTURES":"","#define MAX_DIR_LIGHTS "+H.maxDirLights,"#define MAX_POINT_LIGHTS "+H.maxPointLights,"#define MAX_BONES "+H.maxBones,H.map?"#define USE_MAP":"",H.envMap?"#define USE_ENVMAP":"",H.lightMap?"#define USE_LIGHTMAP":"",H.vertexColors?"#define USE_COLOR":"",H.skinning?"#define USE_SKINNING":"",H.morphTargets?"#define USE_MORPHTARGETS": +"",H.sizeAttenuation?"#define USE_SIZEATTENUATION":"","uniform mat4 objectMatrix;\nuniform mat4 modelViewMatrix;\nuniform mat4 projectionMatrix;\nuniform mat4 viewMatrix;\nuniform mat3 normalMatrix;\nuniform vec3 cameraPosition;\nuniform mat4 cameraInverseMatrix;\nattribute vec3 position;\nattribute vec3 normal;\nattribute vec2 uv;\nattribute vec2 uv2;\n#ifdef USE_COLOR\nattribute vec3 color;\n#endif\n#ifdef USE_MORPHTARGETS\nattribute vec3 morphTarget0;\nattribute vec3 morphTarget1;\nattribute vec3 morphTarget2;\nattribute vec3 morphTarget3;\nattribute vec3 morphTarget4;\nattribute vec3 morphTarget5;\nattribute vec3 morphTarget6;\nattribute vec3 morphTarget7;\n#endif\n#ifdef USE_SKINNING\nattribute vec4 skinVertexA;\nattribute vec4 skinVertexB;\nattribute vec4 skinIndex;\nattribute vec4 skinWeight;\n#endif\n"].join("\n"); +d.attachShader(B,oa("fragment",C+x));d.attachShader(B,oa("vertex",H+K));d.linkProgram(B);d.getProgramParameter(B,d.LINK_STATUS)||console.error("Could not initialise shader\nVALIDATE_STATUS: "+d.getProgramParameter(B,d.VALIDATE_STATUS)+", gl error ["+d.getError()+"]");B.uniforms={};B.attributes={};k.program=B;x=["viewMatrix","modelViewMatrix","projectionMatrix","normalMatrix","objectMatrix","cameraPosition","cameraInverseMatrix","boneGlobalMatrices","morphTargetInfluences"];for(A in k.uniforms)x.push(A); +A=k.program;K=0;for(B=x.length;K=0&&d.enableVertexAttribArray(F.color);F.normal>=0&&d.enableVertexAttribArray(F.normal); +F.tangent>=0&&d.enableVertexAttribArray(F.tangent);if(k.skinning&&F.skinVertexA>=0&&F.skinVertexB>=0&&F.skinIndex>=0&&F.skinWeight>=0){d.enableVertexAttribArray(F.skinVertexA);d.enableVertexAttribArray(F.skinVertexB);d.enableVertexAttribArray(F.skinIndex);d.enableVertexAttribArray(F.skinWeight)}if(k.morphTargets){k.numSupportedMorphTargets=0;if(F.morphTarget0>=0){d.enableVertexAttribArray(F.morphTarget0);k.numSupportedMorphTargets++}if(F.morphTarget1>=0){d.enableVertexAttribArray(F.morphTarget1); +k.numSupportedMorphTargets++}if(F.morphTarget2>=0){d.enableVertexAttribArray(F.morphTarget2);k.numSupportedMorphTargets++}if(F.morphTarget3>=0){d.enableVertexAttribArray(F.morphTarget3);k.numSupportedMorphTargets++}if(F.morphTarget4>=0){d.enableVertexAttribArray(F.morphTarget4);k.numSupportedMorphTargets++}if(F.morphTarget5>=0){d.enableVertexAttribArray(F.morphTarget5);k.numSupportedMorphTargets++}if(F.morphTarget6>=0){d.enableVertexAttribArray(F.morphTarget6);k.numSupportedMorphTargets++}if(F.morphTarget7>= +0){d.enableVertexAttribArray(F.morphTarget7);k.numSupportedMorphTargets++}p.__webglMorphTargetInfluences=new Float32Array(this.maxMorphTargets);A=0;for(F=this.maxMorphTargets;A0||Ea.faceVertexUvs.length>0)H.__uvArray=new Float32Array(C*2);if(Ea.faceUvs.length>1||Ea.faceVertexUvs.length>1)H.__uv2Array=new Float32Array(C*2)}if(K.geometry.skinWeights.length&&K.geometry.skinIndices.length){H.__skinVertexAArray=new Float32Array(C*4);H.__skinVertexBArray=new Float32Array(C*4);H.__skinIndexArray= +new Float32Array(C*4);H.__skinWeightArray=new Float32Array(C*4)}H.__faceArray=new Uint16Array(Y*3+(K.geometry.edgeFaces?K.geometry.edgeFaces.length*6:0));H.__lineArray=new Uint16Array(ua*2);if(H.numMorphTargets){Ea=void 0;ka=void 0;H.__morphTargetsArrays=[];Ea=0;for(ka=H.numMorphTargets;Ea=0;A--){p=x.__webglObjects[A].object;B==p&&x.__webglObjects.splice(A,1)}k.__objectsRemoved.splice(0,1)}B=0;for(x=k.__webglObjects.length;B0}}; 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(a,c,b){b&&a.update(undefined,!1,c);b=a.sounds;var e,f=b.length;for(e=0;e25&&(g=25);f=(g-1)*0.5;b=Array(g);for(c=e=0;cthis.heightMax?this.heightMax:this.position.y)-this.heightMin)*this.heightCoef:0;(this.moveForward||this.autoForward)&&this.translateZ(-(this.movementSpeed+this.autoSpeedFactor));this.moveBackward&&this.translateZ(this.movementSpeed);this.moveLeft&&this.translateX(-this.movementSpeed);this.moveRight&&this.translateX(this.movementSpeed); -var b=this.lookSpeed;this.dragToLook&&!this.mouseDragOn&&(b=0);this.lon+=this.mouseX*b;this.lookVertical&&(this.lat-=this.mouseY*b);this.lat=Math.max(-85,Math.min(85,this.lat));this.phi=(90-this.lat)*Math.PI/180;this.theta=this.lon*Math.PI/180;b=this.target.position;var e=this.position;b.x=e.x+100*Math.sin(this.phi)*Math.cos(this.theta);b.y=e.y+100*Math.cos(this.phi);b.z=e.z+100*Math.sin(this.phi)*Math.sin(this.theta);this.supr.update.call(this)};this.domElement.addEventListener("contextmenu",function(b){b.preventDefault()}, +var b=this.lookSpeed;this.activeLook||(b=0);this.lon+=this.mouseX*b;this.lookVertical&&(this.lat-=this.mouseY*b);this.lat=Math.max(-85,Math.min(85,this.lat));this.phi=(90-this.lat)*Math.PI/180;this.theta=this.lon*Math.PI/180;b=this.target.position;var e=this.position;b.x=e.x+100*Math.sin(this.phi)*Math.cos(this.theta);b.y=e.y+100*Math.cos(this.phi);b.z=e.z+100*Math.sin(this.phi)*Math.sin(this.theta);this.supr.update.call(this)};this.domElement.addEventListener("contextmenu",function(b){b.preventDefault()}, !1);this.domElement.addEventListener("mousemove",c(this,this.onMouseMove),!1);this.domElement.addEventListener("mousedown",c(this,this.onMouseDown),!1);this.domElement.addEventListener("mouseup",c(this,this.onMouseUp),!1);this.domElement.addEventListener("keydown",c(this,this.onKeyDown),!1);this.domElement.addEventListener("keyup",c(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(a,c){this.matrix.rotateAxis(c);if(this.noFly)c.y=0;this.position.addSelf(c.multiplyScalar(a));this.target.position.addSelf(c.multiplyScalar(a))}; -THREE.PathCamera=function(a){function c(o,n,t,x){var w={name:t,fps:0.6,length:x,hierarchy:[]},A,F=n.getControlPointsArray(),G=n.getLength(),K=F.length,O=0;A=K-1;n={parent:-1,keys:[]};n.keys[0]={time:0,pos:F[0],rot:[0,0,0,1],scl:[1,1,1]};n.keys[A]={time:x,pos:F[A],rot:[0,0,0,1],scl:[1,1,1]};for(A=1;A=0?x:x+f;x=this.verticalAngleMap.srcRange;w=this.verticalAngleMap.dstRange; -this.phi=(this.phi-x[0])*(w[1]-w[0])/(x[1]-x[0])+w[0];x=this.horizontalAngleMap.srcRange;w=this.horizontalAngleMap.dstRange;this.theta=(this.theta-x[0])*(w[1]-w[0])/(x[1]-x[0])+w[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,o,n,t)};this.onMouseMove=function(o){this.mouseX=o.clientX-this.windowHalfX;this.mouseY=o.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 f=Math.PI*2,g=Math.PI/180;this.update=function(o,n,t){var y,w;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)*g;this.theta=this.lon*g;y=this.phi%f;this.phi=y>=0?y:y+f;y=this.verticalAngleMap.srcRange;w=this.verticalAngleMap.dstRange; +this.phi=(this.phi-y[0])*(w[1]-w[0])/(y[1]-y[0])+w[0];y=this.horizontalAngleMap.srcRange;w=this.horizontalAngleMap.dstRange;this.theta=(this.theta-y[0])*(w[1]-w[0])/(y[1]-y[0])+w[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,o,n,t)};this.onMouseMove=function(o){this.mouseX=o.clientX-this.windowHalfX;this.mouseY=o.clientY-this.windowHalfY};this.spline=new THREE.Spline;this.spline.initFromArray(this.waypoints); this.useConstantSpeed&&this.spline.reparametrizeByArcLength(this.resamplingCoef);if(this.createDebugDummy){a=new THREE.MeshLambertMaterial({color:30719});var h=new THREE.MeshLambertMaterial({color:65280}),j=new Cube(10,10,20),m=new Cube(2,2,10);this.animationParent=new THREE.Mesh(j,a);a=new THREE.Mesh(m,h);a.position.set(0,10,0);this.animation=c(this.animationParent,this.spline,this.id,this.duration);this.animationParent.addChild(this);this.animationParent.addChild(this.target);this.animationParent.addChild(a)}else{this.animation= c(this.animationParent,this.spline,this.id,this.duration);this.animationParent.addChild(this.target);this.animationParent.addChild(this)}this.createDebugPath&&e(this.debugPath,this.spline);this.domElement.addEventListener("mousemove",function(o,n){return function(){n.apply(o,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(a,c,b,e,f,g,h,j,m){function o(G,K,O,z,P,Q,R,Da){var ha,na,Y=e||1,d=f||1,$=P/2,ya=Q/2,Ea=n.vertices.length;if(G=="x"&&K=="y"||G=="y"&&K=="x")ha="z";else if(G=="x"&&K=="z"||G=="z"&&K=="x"){ha="y";d=g||1}else if(G=="z"&&K=="y"||G=="y"&&K=="z"){ha="x";Y=g||1}var Fa=Y+1,sa=d+1;P/=Y;var aa=Q/d;for(na=0;na0){h(0,0,-o-(g||0));for(e=a;e0){h(0,0,o+(f||0)); +var Cube=function(a,c,b,e,f,g,h,j,m){function o(G,J,S,D,L,N,O,Fa){var oa,xa,W=e||1,d=f||1,Z=L/2,ya=N/2,Ga=n.vertices.length;if(G=="x"&&J=="y"||G=="y"&&J=="x")oa="z";else if(G=="x"&&J=="z"||G=="z"&&J=="x"){oa="y";d=g||1}else if(G=="z"&&J=="y"||G=="y"&&J=="z"){oa="x";W=g||1}var Ha=W+1,ra=d+1;L/=W;var X=N/d;for(xa=0;xa0){h(0,0,-o-(g||0));for(e=a;e0){h(0,0,o+(f||0)); for(e=a+a/2;e<2*a;e++)j.faces.push(new THREE.Face4(2*a+1,(2*e-2*a+2)%a+a,(2*e-2*a+1)%a+a,(2*e-2*a)%a+a))}this.computeCentroids();this.computeFaceNormals()};Cylinder.prototype=new THREE.Geometry;Cylinder.prototype.constructor=Cylinder; -var Icosahedron=function(a){function c(t,x,w){var A=Math.sqrt(t*t+x*x+w*w);return f.vertices.push(new THREE.Vertex(new THREE.Vector3(t/A,x/A,w/A)))-1}function b(t,x,w,A){A.faces.push(new THREE.Face3(t,x,w))}function e(t,x){var w=f.vertices[t].position,A=f.vertices[x].position;return c((w.x+A.x)/2,(w.y+A.y)/2,(w.z+A.z)/2)}var f=this,g=new THREE.Geometry,h;this.subdivisions=a||0;THREE.Geometry.call(this);a=(1+Math.sqrt(5))/2;c(-1,a,0);c(1,a,0);c(-1,-a,0);c(1,-a,0);c(0,-1,a);c(0,1,a);c(0,-1,-a);c(0, +var Icosahedron=function(a){function c(t,y,w){var z=Math.sqrt(t*t+y*y+w*w);return f.vertices.push(new THREE.Vertex(new THREE.Vector3(t/z,y/z,w/z)))-1}function b(t,y,w,z){z.faces.push(new THREE.Face3(t,y,w))}function e(t,y){var w=f.vertices[t].position,z=f.vertices[y].position;return c((w.x+z.x)/2,(w.y+z.y)/2,(w.z+z.z)/2)}var f=this,g=new THREE.Geometry,h;this.subdivisions=a||0;THREE.Geometry.call(this);a=(1+Math.sqrt(5))/2;c(-1,a,0);c(1,a,0);c(-1,-a,0);c(1,-a,0);c(0,-1,a);c(0,1,a);c(0,-1,-a);c(0, 1,-a);c(a,0,-1);c(a,0,1);c(-a,0,-1);c(-a,0,1);b(0,11,5,g);b(0,5,1,g);b(0,1,7,g);b(0,7,10,g);b(0,10,11,g);b(1,5,9,g);b(5,11,4,g);b(11,10,2,g);b(10,7,6,g);b(7,1,8,g);b(3,9,4,g);b(3,4,2,g);b(3,2,6,g);b(3,6,8,g);b(3,8,9,g);b(4,9,5,g);b(2,4,11,g);b(6,2,10,g);b(8,6,7,g);b(9,8,1,g);for(a=0;a0||(n=this.vertices.push(new THREE.Vertex(new THREE.Vector3(t,j,x)))-1);o.push(n)}c.push(o)}var w,A,F;f=c.length;for(b=0;b0)for(e=0;e1){w=this.vertices[h].position.clone(); -A=this.vertices[m].position.clone();F=this.vertices[o].position.clone();w.normalize();A.normalize();F.normalize();this.faces.push(new THREE.Face3(h,m,o,[new THREE.Vector3(w.x,w.y,w.z),new THREE.Vector3(A.x,A.y,A.z),new THREE.Vector3(F.x,F.y,F.z)]));this.faceVertexUvs[0].push([n,t,G])}}}this.computeCentroids();this.computeFaceNormals();this.computeVertexNormals();this.boundingSphere={radius:a}};Sphere.prototype=new THREE.Geometry;Sphere.prototype.constructor=Sphere; +var Sphere=function(a,c,b){THREE.Geometry.call(this);var e,f=Math.PI,g=Math.max(3,c||8),h=Math.max(2,b||6);c=[];for(b=0;b0||(n=this.vertices.push(new THREE.Vertex(new THREE.Vector3(t,j,y)))-1);o.push(n)}c.push(o)}var w,z,E;f=c.length;for(b=0;b0)for(e=0;e1){w=this.vertices[h].position.clone(); +z=this.vertices[m].position.clone();E=this.vertices[o].position.clone();w.normalize();z.normalize();E.normalize();this.faces.push(new THREE.Face3(h,m,o,[new THREE.Vector3(w.x,w.y,w.z),new THREE.Vector3(z.x,z.y,z.z),new THREE.Vector3(E.x,E.y,E.z)]));this.faceVertexUvs[0].push([n,t,G])}}}this.computeCentroids();this.computeFaceNormals();this.computeVertexNormals();this.boundingSphere={radius:a}};Sphere.prototype=new THREE.Geometry;Sphere.prototype.constructor=Sphere; var Torus=function(a,c,b,e){this.radius=a||100;this.tube=c||40;this.segmentsR=b||8;this.segmentsT=e||6;a=[];THREE.Geometry.call(this);for(c=0;c<=this.segmentsR;++c)for(b=0;b<=this.segmentsT;++b){e=b/this.segmentsT*2*Math.PI;var f=c/this.segmentsR*2*Math.PI;this.vertices.push(new THREE.Vertex(new THREE.Vector3((this.radius+this.tube*Math.cos(f))*Math.cos(e),(this.radius+this.tube*Math.cos(f))*Math.sin(e),this.tube*Math.sin(f))));a.push([b/this.segmentsT,1-c/this.segmentsR])}for(c=1;c<=this.segmentsR;++c)for(b= 1;b<=this.segmentsT;++b){e=(this.segmentsT+1)*c+b;f=(this.segmentsT+1)*c+b-1;var g=(this.segmentsT+1)*(c-1)+b-1,h=(this.segmentsT+1)*(c-1)+b;this.faces.push(new THREE.Face4(e,f,g,h));this.faceVertexUvs[0].push([new THREE.UV(a[e][0],a[e][1]),new THREE.UV(a[f][0],a[f][1]),new THREE.UV(a[g][0],a[g][1]),new THREE.UV(a[h][0],a[h][1])])}delete a;this.computeCentroids();this.computeFaceNormals();this.computeVertexNormals()};Torus.prototype=new THREE.Geometry;Torus.prototype.constructor=Torus; -var TorusKnot=function(a,c,b,e,f,g,h){function j(t,x,w,A,F,G){x=w/A*t;w=Math.cos(x);return new THREE.Vector3(F*(2+w)*0.5*Math.cos(t),F*(2+w)*Math.sin(t)*0.5,G*F*Math.sin(x)*0.5)}THREE.Geometry.call(this);this.radius=a||200;this.tube=c||40;this.segmentsR=b||64;this.segmentsT=e||8;this.p=f||2;this.q=g||3;this.heightScale=h||1;this.grid=Array(this.segmentsR);b=new THREE.Vector3;e=new THREE.Vector3;g=new THREE.Vector3;for(a=0;a>7)-127;ma|=(T&127)<<16|W<<8;if(ma==0&&y==-127)return 0;return(1-2*(k>>7))*(1+ma*Math.pow(2,-23))*Math.pow(2,y)}function j(M,X){var ma=n(M,X),W=n(M,X+1),T=n(M,X+2);return(n(M,X+3)<<24)+(T<<16)+(W<<8)+ma}function m(M,X){var ma=n(M,X);return(n(M,X+1)<<8)+ma}function o(M,X){var ma=n(M,X);return ma>127?ma-256:ma}function n(M, -X){return M.charCodeAt(X)&255}function t(M){var X,ma,W;X=j(a,M);ma=j(a,M+R);W=j(a,M+Da);M=m(a,M+ha);THREE.BinaryLoader.prototype.f3(K,X,ma,W,M)}function x(M){var X,ma,W,T,k,y;X=j(a,M);ma=j(a,M+R);W=j(a,M+Da);T=m(a,M+ha);k=j(a,M+na);y=j(a,M+Y);M=j(a,M+d);THREE.BinaryLoader.prototype.f3n(K,P,X,ma,W,T,k,y,M)}function w(M){var X,ma,W,T;X=j(a,M);ma=j(a,M+$);W=j(a,M+ya);T=j(a,M+Ea);M=m(a,M+Fa);THREE.BinaryLoader.prototype.f4(K,X,ma,W,T,M)}function A(M){var X,ma,W,T,k,y,B,p;X=j(a,M);ma=j(a,M+$);W=j(a,M+ -ya);T=j(a,M+Ea);k=m(a,M+Fa);y=j(a,M+sa);B=j(a,M+aa);p=j(a,M+oa);M=j(a,M+Aa);THREE.BinaryLoader.prototype.f4n(K,P,X,ma,W,T,k,y,B,p,M)}function F(M){var X,ma;X=j(a,M);ma=j(a,M+V);M=j(a,M+S);THREE.BinaryLoader.prototype.uv3(K.faceVertexUvs[0],Q[X*2],Q[X*2+1],Q[ma*2],Q[ma*2+1],Q[M*2],Q[M*2+1])}function G(M){var X,ma,W;X=j(a,M);ma=j(a,M+ka);W=j(a,M+ua);M=j(a,M+ia);THREE.BinaryLoader.prototype.uv4(K.faceVertexUvs[0],Q[X*2],Q[X*2+1],Q[ma*2],Q[ma*2+1],Q[W*2],Q[W*2+1],Q[M*2],Q[M*2+1])}var K=this,O=0,z,P=[], -Q=[],R,Da,ha,na,Y,d,$,ya,Ea,Fa,sa,aa,oa,Aa,V,S,ka,ua,ia,Ba,Ga,Qa,Ra,bb,Ya;THREE.Geometry.call(this);THREE.Loader.prototype.init_materials(K,e,g);z={signature:a.substr(O,8),header_bytes:n(a,O+8),vertex_coordinate_bytes:n(a,O+9),normal_coordinate_bytes:n(a,O+10),uv_coordinate_bytes:n(a,O+11),vertex_index_bytes:n(a,O+12),normal_index_bytes:n(a,O+13),uv_index_bytes:n(a,O+14),material_index_bytes:n(a,O+15),nvertices:j(a,O+16),nnormals:j(a,O+16+4),nuvs:j(a,O+16+8),ntri_flat:j(a,O+16+12),ntri_smooth:j(a, -O+16+16),ntri_flat_uv:j(a,O+16+20),ntri_smooth_uv:j(a,O+16+24),nquad_flat:j(a,O+16+28),nquad_smooth:j(a,O+16+32),nquad_flat_uv:j(a,O+16+36),nquad_smooth_uv:j(a,O+16+40)};O+=z.header_bytes;R=z.vertex_index_bytes;Da=z.vertex_index_bytes*2;ha=z.vertex_index_bytes*3;na=z.vertex_index_bytes*3+z.material_index_bytes;Y=z.vertex_index_bytes*3+z.material_index_bytes+z.normal_index_bytes;d=z.vertex_index_bytes*3+z.material_index_bytes+z.normal_index_bytes*2;$=z.vertex_index_bytes;ya=z.vertex_index_bytes*2; -Ea=z.vertex_index_bytes*3;Fa=z.vertex_index_bytes*4;sa=z.vertex_index_bytes*4+z.material_index_bytes;aa=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes;oa=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*2;Aa=z.vertex_index_bytes*4+z.material_index_bytes+z.normal_index_bytes*3;V=z.uv_index_bytes;S=z.uv_index_bytes*2;ka=z.uv_index_bytes;ua=z.uv_index_bytes*2;ia=z.uv_index_bytes*3;g=z.vertex_index_bytes*3+z.material_index_bytes;Ya=z.vertex_index_bytes*4+z.material_index_bytes; -Ba=z.ntri_flat*g;Ga=z.ntri_smooth*(g+z.normal_index_bytes*3);Qa=z.ntri_flat_uv*(g+z.uv_index_bytes*3);Ra=z.ntri_smooth_uv*(g+z.normal_index_bytes*3+z.uv_index_bytes*3);bb=z.nquad_flat*Ya;g=z.nquad_smooth*(Ya+z.normal_index_bytes*4);Ya=z.nquad_flat_uv*(Ya+z.uv_index_bytes*4);O+=function(M){for(var X,ma,W,T=z.vertex_coordinate_bytes*3,k=M+z.nvertices*T;M>7)-127;na|=(ca&127)<<16|Aa<<8;if(na==0&&k==-127)return 0;return(1-2*(ga>>7))*(1+na*Math.pow(2,-23))*Math.pow(2,k)}function j(M,V){var na=n(M,V),Aa=n(M,V+1),ca=n(M,V+2);return(n(M,V+3)<<24)+(ca<<16)+(Aa<<8)+na}function m(M,V){var na=n(M,V);return(n(M,V+1)<<8)+na}function o(M,V){var na=n(M,V);return na>127? +na-256:na}function n(M,V){return M.charCodeAt(V)&255}function t(M){var V,na,Aa;V=j(a,M);na=j(a,M+O);Aa=j(a,M+Fa);M=m(a,M+oa);THREE.BinaryLoader.prototype.f3(J,V,na,Aa,M)}function y(M){var V,na,Aa,ca,ga,k;V=j(a,M);na=j(a,M+O);Aa=j(a,M+Fa);ca=m(a,M+oa);ga=j(a,M+xa);k=j(a,M+W);M=j(a,M+d);THREE.BinaryLoader.prototype.f3n(J,L,V,na,Aa,ca,ga,k,M)}function w(M){var V,na,Aa,ca;V=j(a,M);na=j(a,M+Z);Aa=j(a,M+ya);ca=j(a,M+Ga);M=m(a,M+Ha);THREE.BinaryLoader.prototype.f4(J,V,na,Aa,ca,M)}function z(M){var V,na, +Aa,ca,ga,k,B,x;V=j(a,M);na=j(a,M+Z);Aa=j(a,M+ya);ca=j(a,M+Ga);ga=m(a,M+Ha);k=j(a,M+ra);B=j(a,M+X);x=j(a,M+qa);M=j(a,M+za);THREE.BinaryLoader.prototype.f4n(J,L,V,na,Aa,ca,ga,k,B,x,M)}function E(M){var V,na;V=j(a,M);na=j(a,M+ea);M=j(a,M+U);THREE.BinaryLoader.prototype.uv3(J.faceVertexUvs[0],N[V*2],N[V*2+1],N[na*2],N[na*2+1],N[M*2],N[M*2+1])}function G(M){var V,na,Aa;V=j(a,M);na=j(a,M+ma);Aa=j(a,M+Ca);M=j(a,M+fa);THREE.BinaryLoader.prototype.uv4(J.faceVertexUvs[0],N[V*2],N[V*2+1],N[na*2],N[na*2+1],N[Aa* +2],N[Aa*2+1],N[M*2],N[M*2+1])}var J=this,S=0,D,L=[],N=[],O,Fa,oa,xa,W,d,Z,ya,Ga,Ha,ra,X,qa,za,ea,U,ma,Ca,fa,ja,Da,Sa,Xa,Wa,Ta;THREE.Geometry.call(this);THREE.Loader.prototype.init_materials(J,e,g);D={signature:a.substr(S,8),header_bytes:n(a,S+8),vertex_coordinate_bytes:n(a,S+9),normal_coordinate_bytes:n(a,S+10),uv_coordinate_bytes:n(a,S+11),vertex_index_bytes:n(a,S+12),normal_index_bytes:n(a,S+13),uv_index_bytes:n(a,S+14),material_index_bytes:n(a,S+15),nvertices:j(a,S+16),nnormals:j(a,S+16+4),nuvs:j(a, +S+16+8),ntri_flat:j(a,S+16+12),ntri_smooth:j(a,S+16+16),ntri_flat_uv:j(a,S+16+20),ntri_smooth_uv:j(a,S+16+24),nquad_flat:j(a,S+16+28),nquad_smooth:j(a,S+16+32),nquad_flat_uv:j(a,S+16+36),nquad_smooth_uv:j(a,S+16+40)};S+=D.header_bytes;O=D.vertex_index_bytes;Fa=D.vertex_index_bytes*2;oa=D.vertex_index_bytes*3;xa=D.vertex_index_bytes*3+D.material_index_bytes;W=D.vertex_index_bytes*3+D.material_index_bytes+D.normal_index_bytes;d=D.vertex_index_bytes*3+D.material_index_bytes+D.normal_index_bytes*2;Z= +D.vertex_index_bytes;ya=D.vertex_index_bytes*2;Ga=D.vertex_index_bytes*3;Ha=D.vertex_index_bytes*4;ra=D.vertex_index_bytes*4+D.material_index_bytes;X=D.vertex_index_bytes*4+D.material_index_bytes+D.normal_index_bytes;qa=D.vertex_index_bytes*4+D.material_index_bytes+D.normal_index_bytes*2;za=D.vertex_index_bytes*4+D.material_index_bytes+D.normal_index_bytes*3;ea=D.uv_index_bytes;U=D.uv_index_bytes*2;ma=D.uv_index_bytes;Ca=D.uv_index_bytes*2;fa=D.uv_index_bytes*3;g=D.vertex_index_bytes*3+D.material_index_bytes; +Ta=D.vertex_index_bytes*4+D.material_index_bytes;ja=D.ntri_flat*g;Da=D.ntri_smooth*(g+D.normal_index_bytes*3);Sa=D.ntri_flat_uv*(g+D.uv_index_bytes*3);Xa=D.ntri_smooth_uv*(g+D.normal_index_bytes*3+D.uv_index_bytes*3);Wa=D.nquad_flat*Ta;g=D.nquad_smooth*(Ta+D.normal_index_bytes*4);Ta=D.nquad_flat_uv*(Ta+D.uv_index_bytes*4);S+=function(M){for(var V,na,Aa,ca=D.vertex_coordinate_bytes*3,ga=M+D.nvertices*ca;M=this.maxCount-3&&j(this)};this.begin=function(){this.count=0;this.hasPos=!1;this.hasNormal=!1};this.end=function(b){if(this.count!=0){for(var e=this.count*3;ethis.size-1&&(m=this.size-1);var x=Math.floor(o-j);x<1&&(x=1);o=Math.floor(o+j);o>this.size-1&&(o= -this.size-1);var w=Math.floor(n-j);w<1&&(w=1);j=Math.floor(n+j);j>this.size-1&&(j=this.size-1);for(var A,F,G,K,O,z;t0&&(this.field[G+A]+=K)}}}};this.addPlaneX=function(b,e){var f,g,h,j,m,o=this.size,n=this.yd,t=this.zd,x=this.field,w=o*Math.sqrt(b/e);w>o&&(w=o);for(f=0;f0)for(g=0;gn&&(A=n);for(g=0;g0){m=g*t;for(f=0;fsize&&(dist=size);for(h=0;h0){m=zd*h;for(g=0;g=this.maxCount-3&&j(this)};this.begin=function(){this.count=0;this.hasPos=!1;this.hasNormal=!1};this.end=function(b){if(this.count!=0){for(var e=this.count*3;ethis.size-1&&(m=this.size-1);var y=Math.floor(o-j);y<1&&(y=1);o=Math.floor(o+j);o>this.size-1&&(o= +this.size-1);var w=Math.floor(n-j);w<1&&(w=1);j=Math.floor(n+j);j>this.size-1&&(j=this.size-1);for(var z,E,G,J,S,D;t0&&(this.field[G+z]+=J)}}}};this.addPlaneX=function(b,e){var f,g,h,j,m,o=this.size,n=this.yd,t=this.zd,y=this.field,w=o*Math.sqrt(b/e);w>o&&(w=o);for(f=0;f0)for(g=0;gn&&(z=n);for(g=0;g0){m=g*t;for(f=0;fsize&&(dist=size);for(h=0;h0){m=zd*h;for(g=0;g0?this.multiplyScalar(1/a):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(a,b,c,e){this.set(a||0,b||0,c||0,e||1)}; THREE.Vector4.prototype={set:function(a,b,c,e){this.x=a;this.y=b;this.z=c;this.w=e;return this},copy:function(a){this.set(a.x,a.y,a.z,a.w||1);return this},add:function(a,b){this.set(a.x+b.x,a.y+b.y,a.z+b.z,a.w+b.w);return this},addSelf:function(a){this.set(this.x+a.x,this.y+a.y,this.z+a.z,this.w+a.w);return this},sub:function(a,b){this.set(a.x-b.x,a.y-b.y,a.z-b.z,a.w-b.w);return this},subSelf:function(a){this.set(this.x-a.x,this.y-a.y,this.z-a.z,this.w-a.w);return this},multiplyScalar:function(a){this.set(this.x* a,this.y*a,this.z*a,this.w*a);return this},divideScalar:function(a){this.set(this.x/a,this.y/a,this.z/a,this.w/a);return this},lerpSelf:function(a,b){this.set(this.x+(a.x-this.x)*b,this.y+(a.y-this.y)*b,this.z+(a.z-this.z)*b,this.w+(a.w-this.w)*b)},clone:function(){return new THREE.Vector4(this.x,this.y,this.z,this.w)}};THREE.Ray=function(a,b){this.origin=a||new THREE.Vector3;this.direction=b||new THREE.Vector3}; -THREE.Ray.prototype={intersectScene:function(a){var b,c,e=a.objects,d=[];a=0;for(b=e.length;a0&&G>0&&H+G<1}var c,e,d,f,g,i,h,j,k,n, -p,o=a.geometry,v=o.vertices,y=[];c=0;for(e=o.faces.length;c0&&D>0&&u+D<1}var c,e,d,f,g,i,h,j,k,n, +q,o=a.geometry,w=o.vertices,z=[];c=0;for(e=o.faces.length;ch?e:h;d=d>j?d:j}a()}; -this.add3Points=function(h,j,k,n,p,o){if(i){i=!1;b=hk?h>p?h:p:k>p?k:p;d=j>n?j>o?j:o:n>o?n:o}else{b=hk?h>p?h>e?h:e:p>e?p:e:k>p?k>e?k:e:p>e?p:e;d=j>n?j>o?j>d?j:d:o>d?o:d:n>o?n>d?n:d:o>d?o:d}a()};this.addRectangle=function(h){if(i){i=!1;b=h.getLeft();c=h.getTop();e=h.getRight();d=h.getBottom()}else{b=bh.getRight()? +this.add3Points=function(h,j,k,n,q,o){if(i){i=!1;b=hk?h>q?h:q:k>q?k:q;d=j>n?j>o?j:o:n>o?n:o}else{b=hk?h>q?h>e?h:e:q>e?q:e:k>q?k>e?k:e:q>e?q:e;d=j>n?j>o?j>d?j:d:o>d?o:d:n>o?n>d?n:d:o>d?o:d}a()};this.addRectangle=function(h){if(i){i=!1;b=h.getLeft();c=h.getTop();e=h.getRight();d=h.getBottom()}else{b=bh.getRight()? e:h.getRight();d=d>h.getBottom()?d:h.getBottom()}a()};this.inflate=function(h){b-=h;c-=h;e+=h;d+=h;a()};this.minSelf=function(h){b=b>h.getLeft()?b:h.getLeft();c=c>h.getTop()?c:h.getTop();e=e=0&&Math.min(d,h.getBottom())-Math.max(c,h.getTop())>=0};this.empty=function(){i=!0;d=e=c=b=0;a()};this.isEmpty=function(){return i}}; THREE.Matrix3=function(){this.m=[]};THREE.Matrix3.prototype={transpose:function(){var a,b=this.m;a=b[1];b[1]=b[3];b[3]=a;a=b[2];b[2]=b[6];b[6]=a;a=b[5];b[5]=b[7];b[7]=a;return this},transposeIntoArray:function(a){var b=this.m;a[0]=b[0];a[1]=b[3];a[2]=b[6];a[3]=b[1];a[4]=b[4];a[5]=b[7];a[6]=b[2];a[7]=b[5];a[8]=b[8];return this}}; -THREE.Matrix4=function(a,b,c,e,d,f,g,i,h,j,k,n,p,o,v,y){this.set(a||1,b||0,c||0,e||0,d||0,f||1,g||0,i||0,h||0,j||0,k||1,n||0,p||0,o||0,v||0,y||1);this.flat=Array(16);this.m33=new THREE.Matrix3}; -THREE.Matrix4.prototype={set:function(a,b,c,e,d,f,g,i,h,j,k,n,p,o,v,y){this.n11=a;this.n12=b;this.n13=c;this.n14=e;this.n21=d;this.n22=f;this.n23=g;this.n24=i;this.n31=h;this.n32=j;this.n33=k;this.n34=n;this.n41=p;this.n42=o;this.n43=v;this.n44=y;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(a){this.set(a.n11,a.n12,a.n13,a.n14,a.n21,a.n22,a.n23,a.n24,a.n31,a.n32,a.n33,a.n34,a.n41,a.n42,a.n43,a.n44);return this},lookAt:function(a,b,c){var e=THREE.Matrix4.__v1, +THREE.Matrix4=function(a,b,c,e,d,f,g,i,h,j,k,n,q,o,w,z){this.set(a||1,b||0,c||0,e||0,d||0,f||1,g||0,i||0,h||0,j||0,k||1,n||0,q||0,o||0,w||0,z||1);this.flat=Array(16);this.m33=new THREE.Matrix3}; +THREE.Matrix4.prototype={set:function(a,b,c,e,d,f,g,i,h,j,k,n,q,o,w,z){this.n11=a;this.n12=b;this.n13=c;this.n14=e;this.n21=d;this.n22=f;this.n23=g;this.n24=i;this.n31=h;this.n32=j;this.n33=k;this.n34=n;this.n41=q;this.n42=o;this.n43=w;this.n44=z;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(a){this.set(a.n11,a.n12,a.n13,a.n14,a.n21,a.n22,a.n23,a.n24,a.n31,a.n32,a.n33,a.n34,a.n41,a.n42,a.n43,a.n44);return this},lookAt:function(a,b,c){var e=THREE.Matrix4.__v1, d=THREE.Matrix4.__v2,f=THREE.Matrix4.__v3;f.sub(a,b).normalize();if(f.length()===0)f.z=1;e.cross(c,f).normalize();if(e.length()===0){f.x+=1.0E-4;e.cross(c,f).normalize()}d.cross(f,e).normalize();this.n11=e.x;this.n12=d.x;this.n13=f.x;this.n21=e.y;this.n22=d.y;this.n23=f.y;this.n31=e.z;this.n32=d.z;this.n33=f.z;return this},multiplyVector3:function(a){var b=a.x,c=a.y,e=a.z,d=1/(this.n41*b+this.n42*c+this.n43*e+this.n44);a.x=(this.n11*b+this.n12*c+this.n13*e+this.n14)*d;a.y=(this.n21*b+this.n22*c+this.n23* e+this.n24)*d;a.z=(this.n31*b+this.n32*c+this.n33*e+this.n34)*d;return a},multiplyVector4:function(a){var b=a.x,c=a.y,e=a.z,d=a.w;a.x=this.n11*b+this.n12*c+this.n13*e+this.n14*d;a.y=this.n21*b+this.n22*c+this.n23*e+this.n24*d;a.z=this.n31*b+this.n32*c+this.n33*e+this.n34*d;a.w=this.n41*b+this.n42*c+this.n43*e+this.n44*d;return a},rotateAxis:function(a){var b=a.x,c=a.y,e=a.z;a.x=b*this.n11+c*this.n12+e*this.n13;a.y=b*this.n21+c*this.n22+e*this.n23;a.z=b*this.n31+c*this.n32+e*this.n33;a.normalize(); -return a},crossVector:function(a){var b=new THREE.Vector4;b.x=this.n11*a.x+this.n12*a.y+this.n13*a.z+this.n14*a.w;b.y=this.n21*a.x+this.n22*a.y+this.n23*a.z+this.n24*a.w;b.z=this.n31*a.x+this.n32*a.y+this.n33*a.z+this.n34*a.w;b.w=a.w?this.n41*a.x+this.n42*a.y+this.n43*a.z+this.n44*a.w:1;return b},multiply:function(a,b){var c=a.n11,e=a.n12,d=a.n13,f=a.n14,g=a.n21,i=a.n22,h=a.n23,j=a.n24,k=a.n31,n=a.n32,p=a.n33,o=a.n34,v=a.n41,y=a.n42,G=a.n43,B=a.n44,z=b.n11,D=b.n12,I=b.n13,H=b.n14,q=b.n21,aa=b.n22, -K=b.n23,P=b.n24,Q=b.n31,w=b.n32,s=b.n33,L=b.n34;this.n11=c*z+e*q+d*Q;this.n12=c*D+e*aa+d*w;this.n13=c*I+e*K+d*s;this.n14=c*H+e*P+d*L+f;this.n21=g*z+i*q+h*Q;this.n22=g*D+i*aa+h*w;this.n23=g*I+i*K+h*s;this.n24=g*H+i*P+h*L+j;this.n31=k*z+n*q+p*Q;this.n32=k*D+n*aa+p*w;this.n33=k*I+n*K+p*s;this.n34=k*H+n*P+p*L+o;this.n41=v*z+y*q+G*Q;this.n42=v*D+y*aa+G*w;this.n43=v*I+y*K+G*s;this.n44=v*H+y*P+G*L+B;return this},multiplyToArray:function(a,b,c){this.multiply(a,b);c[0]=this.n11;c[1]=this.n21;c[2]=this.n31; +return a},crossVector:function(a){var b=new THREE.Vector4;b.x=this.n11*a.x+this.n12*a.y+this.n13*a.z+this.n14*a.w;b.y=this.n21*a.x+this.n22*a.y+this.n23*a.z+this.n24*a.w;b.z=this.n31*a.x+this.n32*a.y+this.n33*a.z+this.n34*a.w;b.w=a.w?this.n41*a.x+this.n42*a.y+this.n43*a.z+this.n44*a.w:1;return b},multiply:function(a,b){var c=a.n11,e=a.n12,d=a.n13,f=a.n14,g=a.n21,i=a.n22,h=a.n23,j=a.n24,k=a.n31,n=a.n32,q=a.n33,o=a.n34,w=a.n41,z=a.n42,D=a.n43,A=a.n44,U=b.n11,V=b.n12,B=b.n13,u=b.n14,p=b.n21,Y=b.n22, +Z=b.n23,aa=b.n24,P=b.n31,x=b.n32,t=b.n33,K=b.n34;this.n11=c*U+e*p+d*P;this.n12=c*V+e*Y+d*x;this.n13=c*B+e*Z+d*t;this.n14=c*u+e*aa+d*K+f;this.n21=g*U+i*p+h*P;this.n22=g*V+i*Y+h*x;this.n23=g*B+i*Z+h*t;this.n24=g*u+i*aa+h*K+j;this.n31=k*U+n*p+q*P;this.n32=k*V+n*Y+q*x;this.n33=k*B+n*Z+q*t;this.n34=k*u+n*aa+q*K+o;this.n41=w*U+z*p+D*P;this.n42=w*V+z*Y+D*x;this.n43=w*B+z*Z+D*t;this.n44=w*u+z*aa+D*K+A;return this},multiplyToArray:function(a,b,c){this.multiply(a,b);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(a){this.multiply(this,a);return this},multiplyScalar:function(a){this.n11*=a;this.n12*=a;this.n13*=a;this.n14*=a;this.n21*=a;this.n22*=a;this.n23*=a;this.n24*=a;this.n31*=a;this.n32*=a;this.n33*=a;this.n34*=a;this.n41*=a;this.n42*=a;this.n43*=a;this.n44*=a;return this},determinant:function(){var a= -this.n11,b=this.n12,c=this.n13,e=this.n14,d=this.n21,f=this.n22,g=this.n23,i=this.n24,h=this.n31,j=this.n32,k=this.n33,n=this.n34,p=this.n41,o=this.n42,v=this.n43,y=this.n44;return e*g*j*p-c*i*j*p-e*f*k*p+b*i*k*p+c*f*n*p-b*g*n*p-e*g*h*o+c*i*h*o+e*d*k*o-a*i*k*o-c*d*n*o+a*g*n*o+e*f*h*v-b*i*h*v-e*d*j*v+a*i*j*v+b*d*n*v-a*f*n*v-c*f*h*y+b*g*h*y+c*d*j*y-a*g*j*y-b*d*k*y+a*f*k*y},transpose:function(){var a;a=this.n21;this.n21=this.n12;this.n12=a;a=this.n31;this.n31=this.n13;this.n13=a;a=this.n32;this.n32= +this.n11,b=this.n12,c=this.n13,e=this.n14,d=this.n21,f=this.n22,g=this.n23,i=this.n24,h=this.n31,j=this.n32,k=this.n33,n=this.n34,q=this.n41,o=this.n42,w=this.n43,z=this.n44;return e*g*j*q-c*i*j*q-e*f*k*q+b*i*k*q+c*f*n*q-b*g*n*q-e*g*h*o+c*i*h*o+e*d*k*o-a*i*k*o-c*d*n*o+a*g*n*o+e*f*h*w-b*i*h*w-e*d*j*w+a*i*j*w+b*d*n*w-a*f*n*w-c*f*h*z+b*g*h*z+c*d*j*z-a*g*j*z-b*d*k*z+a*f*k*z},transpose:function(){var a;a=this.n21;this.n21=this.n12;this.n12=a;a=this.n31;this.n31=this.n13;this.n13=a;a=this.n32;this.n32= this.n23;this.n23=a;a=this.n41;this.n41=this.n14;this.n14=a;a=this.n42;this.n42=this.n24;this.n24=a;a=this.n43;this.n43=this.n34;this.n43=a;return this},clone:function(){var a=new THREE.Matrix4;a.n11=this.n11;a.n12=this.n12;a.n13=this.n13;a.n14=this.n14;a.n21=this.n21;a.n22=this.n22;a.n23=this.n23;a.n24=this.n24;a.n31=this.n31;a.n32=this.n32;a.n33=this.n33;a.n34=this.n34;a.n41=this.n41;a.n42=this.n42;a.n43=this.n43;a.n44=this.n44;return a},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(a){a[0]=this.n11;a[1]=this.n21;a[2]=this.n31;a[3]=this.n41;a[4]=this.n12;a[5]=this.n22;a[6]=this.n32;a[7]=this.n42;a[8]=this.n13;a[9]=this.n23;a[10]= this.n33;a[11]=this.n43;a[12]=this.n14;a[13]=this.n24;a[14]=this.n34;a[15]=this.n44;return a},flattenToArrayOffset:function(a,b){a[b]=this.n11;a[b+1]=this.n21;a[b+2]=this.n31;a[b+3]=this.n41;a[b+4]=this.n12;a[b+5]=this.n22;a[b+6]=this.n32;a[b+7]=this.n42;a[b+8]=this.n13;a[b+9]=this.n23;a[b+10]=this.n33;a[b+11]=this.n43;a[b+12]=this.n14;a[b+13]=this.n24;a[b+14]=this.n34;a[b+15]=this.n44;return a},setTranslation:function(a,b,c){this.set(1,0,0,a,0,1,0,b,0,0,1,c,0,0,0,1);return this},setScale:function(a, @@ -34,8 +34,8 @@ b,c){this.set(a,0,0,0,0,b,0,0,0,0,c,0,0,0,0,1);return this},setRotationX:functio f+c,h*g-e*i,h*i+e*g,0,h*g+e*i,j*g+c,j*i-e*f,0,h*i-e*g,j*i+e*f,d*i*i+c,0,0,0,0,1);return this},setPosition:function(a){this.n14=a.x;this.n24=a.y;this.n34=a.z;return this},setRotationFromEuler:function(a){var b=a.x,c=a.y,e=a.z;a=Math.cos(b);b=Math.sin(b);var d=Math.cos(c);c=Math.sin(c);var f=Math.cos(e);e=Math.sin(e);var g=a*c,i=b*c;this.n11=d*f;this.n12=-d*e;this.n13=c;this.n21=i*f+a*e;this.n22=-i*e+a*f;this.n23=-b*d;this.n31=-g*f+b*e;this.n32=g*e+b*f;this.n33=a*d;return this},setRotationFromQuaternion:function(a){var b= a.x,c=a.y,e=a.z,d=a.w,f=b+b,g=c+c,i=e+e;a=b*f;var h=b*g;b*=i;var j=c*g;c*=i;e*=i;f*=d;g*=d;d*=i;this.n11=1-(j+e);this.n12=h-d;this.n13=b+g;this.n21=h+d;this.n22=1-(a+e);this.n23=c-f;this.n31=b-g;this.n32=c+f;this.n33=1-(a+j);return this},scale:function(a){var b=a.x,c=a.y;a=a.z;this.n11*=b;this.n12*=c;this.n13*=a;this.n21*=b;this.n22*=c;this.n23*=a;this.n31*=b;this.n32*=c;this.n33*=a;this.n41*=b;this.n42*=c;this.n43*=a;return this},extractPosition:function(a){this.n14=a.n14;this.n24=a.n24;this.n34= a.n34},extractRotation:function(a,b){var c=1/b.x,e=1/b.y,d=1/b.z;this.n11=a.n11*c;this.n21=a.n21*c;this.n31=a.n31*c;this.n12=a.n12*e;this.n22=a.n22*e;this.n32=a.n32*e;this.n13=a.n13*d;this.n23=a.n23*d;this.n33=a.n33*d}}; -THREE.Matrix4.makeInvert=function(a,b){var c=a.n11,e=a.n12,d=a.n13,f=a.n14,g=a.n21,i=a.n22,h=a.n23,j=a.n24,k=a.n31,n=a.n32,p=a.n33,o=a.n34,v=a.n41,y=a.n42,G=a.n43,B=a.n44;b===undefined&&(b=new THREE.Matrix4);b.n11=h*o*y-j*p*y+j*n*G-i*o*G-h*n*B+i*p*B;b.n12=f*p*y-d*o*y-f*n*G+e*o*G+d*n*B-e*p*B;b.n13=d*j*y-f*h*y+f*i*G-e*j*G-d*i*B+e*h*B;b.n14=f*h*n-d*j*n-f*i*p+e*j*p+d*i*o-e*h*o;b.n21=j*p*v-h*o*v-j*k*G+g*o*G+h*k*B-g*p*B;b.n22=d*o*v-f*p*v+f*k*G-c*o*G-d*k*B+c*p*B;b.n23=f*h*v-d*j*v-f*g*G+c*j*G+d*g*B-c*h*B; -b.n24=d*j*k-f*h*k+f*g*p-c*j*p-d*g*o+c*h*o;b.n31=i*o*v-j*n*v+j*k*y-g*o*y-i*k*B+g*n*B;b.n32=f*n*v-e*o*v-f*k*y+c*o*y+e*k*B-c*n*B;b.n33=d*j*v-f*i*v+f*g*y-c*j*y-e*g*B+c*i*B;b.n34=f*i*k-e*j*k-f*g*n+c*j*n+e*g*o-c*i*o;b.n41=h*n*v-i*p*v-h*k*y+g*p*y+i*k*G-g*n*G;b.n42=e*p*v-d*n*v+d*k*y-c*p*y-e*k*G+c*n*G;b.n43=d*i*v-e*h*v-d*g*y+c*h*y+e*g*G-c*i*G;b.n44=e*h*k-d*i*k+d*g*n-c*h*n-e*g*p+c*i*p;b.multiplyScalar(1/a.determinant());return b}; +THREE.Matrix4.makeInvert=function(a,b){var c=a.n11,e=a.n12,d=a.n13,f=a.n14,g=a.n21,i=a.n22,h=a.n23,j=a.n24,k=a.n31,n=a.n32,q=a.n33,o=a.n34,w=a.n41,z=a.n42,D=a.n43,A=a.n44;b===undefined&&(b=new THREE.Matrix4);b.n11=h*o*z-j*q*z+j*n*D-i*o*D-h*n*A+i*q*A;b.n12=f*q*z-d*o*z-f*n*D+e*o*D+d*n*A-e*q*A;b.n13=d*j*z-f*h*z+f*i*D-e*j*D-d*i*A+e*h*A;b.n14=f*h*n-d*j*n-f*i*q+e*j*q+d*i*o-e*h*o;b.n21=j*q*w-h*o*w-j*k*D+g*o*D+h*k*A-g*q*A;b.n22=d*o*w-f*q*w+f*k*D-c*o*D-d*k*A+c*q*A;b.n23=f*h*w-d*j*w-f*g*D+c*j*D+d*g*A-c*h*A; +b.n24=d*j*k-f*h*k+f*g*q-c*j*q-d*g*o+c*h*o;b.n31=i*o*w-j*n*w+j*k*z-g*o*z-i*k*A+g*n*A;b.n32=f*n*w-e*o*w-f*k*z+c*o*z+e*k*A-c*n*A;b.n33=d*j*w-f*i*w+f*g*z-c*j*z-e*g*A+c*i*A;b.n34=f*i*k-e*j*k-f*g*n+c*j*n+e*g*o-c*i*o;b.n41=h*n*w-i*q*w-h*k*z+g*q*z+i*k*D-g*n*D;b.n42=e*q*w-d*n*w+d*k*z-c*q*z-e*k*D+c*n*D;b.n43=d*i*w-e*h*w-d*g*z+c*h*z+e*g*D-c*i*D;b.n44=e*h*k-d*i*k+d*g*n-c*h*n-e*g*q+c*i*q;b.multiplyScalar(1/a.determinant());return b}; THREE.Matrix4.makeInvert3x3=function(a){var b=a.m33,c=b.m,e=a.n33*a.n22-a.n32*a.n23,d=-a.n33*a.n21+a.n31*a.n23,f=a.n32*a.n21-a.n31*a.n22,g=-a.n33*a.n12+a.n32*a.n13,i=a.n33*a.n11-a.n31*a.n13,h=-a.n32*a.n11+a.n31*a.n12,j=a.n23*a.n12-a.n22*a.n13,k=-a.n23*a.n11+a.n21*a.n13,n=a.n22*a.n11-a.n21*a.n12;a=a.n11*e+a.n21*g+a.n31*j;if(a==0)throw"matrix not invertible";a=1/a;c[0]=a*e;c[1]=a*d;c[2]=a*f;c[3]=a*g;c[4]=a*i;c[5]=a*h;c[6]=a*j;c[7]=a*k;c[8]=a*n;return b}; THREE.Matrix4.makeFrustum=function(a,b,c,e,d,f){var g;g=new THREE.Matrix4;g.n11=2*d/(b-a);g.n12=0;g.n13=(b+a)/(b-a);g.n14=0;g.n21=0;g.n22=2*d/(e-c);g.n23=(e+c)/(e-c);g.n24=0;g.n31=0;g.n32=0;g.n33=-(f+d)/(f-d);g.n34=-2*f*d/(f-d);g.n41=0;g.n42=0;g.n43=-1;g.n44=0;return g};THREE.Matrix4.makePerspective=function(a,b,c,e){var d;a=c*Math.tan(a*Math.PI/360);d=-a;return THREE.Matrix4.makeFrustum(d*b,a*b,d,a,c,e)}; THREE.Matrix4.makeOrtho=function(a,b,c,e,d,f){var g,i,h,j;g=new THREE.Matrix4;i=b-a;h=c-e;j=f-d;g.n11=2/i;g.n12=0;g.n13=0;g.n14=-((b+a)/i);g.n21=0;g.n22=2/h;g.n23=0;g.n24=-((c+e)/h);g.n31=0;g.n32=0;g.n33=-2/j;g.n34=-((f+d)/j);g.n41=0;g.n42=0;g.n43=0;g.n44=1;return g};THREE.Matrix4.__v1=new THREE.Vector3;THREE.Matrix4.__v2=new THREE.Vector3;THREE.Matrix4.__v3=new THREE.Vector3; @@ -48,7 +48,7 @@ b,c)}};THREE.Quaternion=function(a,b,c,e){this.set(a||0,b||0,c||0,e!==undefined? THREE.Quaternion.prototype={set:function(a,b,c,e){this.x=a;this.y=b;this.z=c;this.w=e;return this},setFromEuler:function(a){var b=0.5*Math.PI/360,c=a.x*b,e=a.y*b,d=a.z*b;a=Math.cos(e);e=Math.sin(e);b=Math.cos(-d);d=Math.sin(-d);var f=Math.cos(c);c=Math.sin(c);var g=a*b,i=e*d;this.w=g*f-i*c;this.x=g*c+i*f;this.y=e*b*f+a*d*c;this.z=a*d*f-e*b*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 a=Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w);if(a==0)this.w=this.z=this.y=this.x=0;else{a=1/a;this.x*=a;this.y*=a;this.z*=a;this.w*=a}return this},multiplySelf:function(a){var b=this.x,c=this.y,e=this.z,d=this.w,f=a.x,g=a.y,i=a.z;a=a.w;this.x=b*a+d*f+c*i-e*g;this.y=c*a+d*g+e*f-b*i;this.z=e*a+d*i+b*g-c*f;this.w=d*a-b*f-c*g-e*i;return this}, multiplyVector3:function(a,b){b||(b=a);var c=a.x,e=a.y,d=a.z,f=this.x,g=this.y,i=this.z,h=this.w,j=h*c+g*d-i*e,k=h*e+i*c-f*d,n=h*d+f*e-g*c;c=-f*c-g*e-i*d;b.x=j*h+c*-f+k*-i-n*-g;b.y=k*h+c*-g+n*-f-j*-i;b.z=n*h+c*-i+j*-g-k*-f;return b}}; -THREE.Quaternion.slerp=function(a,b,c,e){var d=a.w*b.w+a.x*b.x+a.y*b.y+a.z*b.z;if(Math.abs(d)>=1){c.w=a.w;c.x=a.x;c.y=a.y;c.z=a.z;return c}var f=Math.acos(d),g=Math.sqrt(1-d*d);if(Math.abs(g)<0.001){c.w=0.5*(a.w+b.w);c.x=0.5*(a.x+b.x);c.y=0.5*(a.y+b.y);c.z=0.5*(a.z+b.z);return c}d=Math.sin((1-e)*f)/g;e=Math.sin(e*f)/g;c.w=a.w*d+b.w*e;c.x=a.x*d+b.x*e;c.y=a.y*d+b.y*e;c.z=a.z*d+b.z*e;return c};THREE.Vertex=function(a){this.position=a||new THREE.Vector3}; +THREE.Quaternion.slerp=function(a,b,c,e){var d=a.w*b.w+a.x*b.x+a.y*b.y+a.z*b.z;if(Math.abs(d)>=1){c.w=a.w;c.x=a.x;c.y=a.y;c.z=a.z;return c}var f=Math.acos(d),g=Math.sqrt(1-d*d);if(Math.abs(g)<0.0010){c.w=0.5*(a.w+b.w);c.x=0.5*(a.x+b.x);c.y=0.5*(a.y+b.y);c.z=0.5*(a.z+b.z);return c}d=Math.sin((1-e)*f)/g;e=Math.sin(e*f)/g;c.w=a.w*d+b.w*e;c.x=a.x*d+b.x*e;c.y=a.y*d+b.y*e;c.z=a.z*d+b.z*e;return c};THREE.Vertex=function(a){this.position=a||new THREE.Vector3}; THREE.Face3=function(a,b,c,e,d,f){this.a=a;this.b=b;this.c=c;this.normal=e instanceof THREE.Vector3?e:new THREE.Vector3;this.vertexNormals=e instanceof Array?e:[];this.color=d instanceof THREE.Color?d:new THREE.Color;this.vertexColors=d instanceof Array?d:[];this.vertexTangents=[];this.materials=f instanceof Array?f:[f];this.centroid=new THREE.Vector3}; THREE.Face4=function(a,b,c,e,d,f,g){this.a=a;this.b=b;this.c=c;this.d=e;this.normal=d instanceof THREE.Vector3?d:new THREE.Vector3;this.vertexNormals=d instanceof Array?d:[];this.color=f instanceof THREE.Color?f:new THREE.Color;this.vertexColors=f instanceof Array?f:[];this.vertexTangents=[];this.materials=g instanceof Array?g:[g];this.centroid=new THREE.Vector3};THREE.UV=function(a,b){this.set(a||0,b||0)}; THREE.UV.prototype={set:function(a,b){this.u=a;this.v=b;return this},copy:function(a){this.set(a.u,a.v);return this}};THREE.Geometry=function(){this.id="Geometry"+THREE.GeometryIdCounter++;this.vertices=[];this.colors=[];this.faces=[];this.faceUvs=[[]];this.faceVertexUvs=[[]];this.morphTargets=[];this.skinWeights=[];this.skinIndices=[];this.boundingSphere=this.boundingBox=null;this.hasTangents=!1}; @@ -56,9 +56,9 @@ THREE.Geometry.prototype={computeCentroids:function(){var a,b,c;a=0;for(b=this.f c.centroid.addSelf(this.vertices[c.d].position);c.centroid.divideScalar(4)}}},computeFaceNormals:function(a){var b,c,e,d,f,g,i=new THREE.Vector3,h=new THREE.Vector3;e=0;for(d=this.faces.length;e0){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 b=1,c=this.vertices.length;bthis.boundingBox.x[1])this.boundingBox.x[1]=a.position.x;if(a.position.ythis.boundingBox.y[1])this.boundingBox.y[1]=a.position.y;if(a.position.zthis.boundingBox.z[1])this.boundingBox.z[1]=a.position.z}}},computeBoundingSphere:function(){for(var a=this.boundingSphere===null?0:this.boundingSphere.radius,b=0,c=this.vertices.length;b1){console.log("THREE.Animation.update: Warning! Scale out of bounds:"+e+" on bone "+o);e=e<0?0:1}if(c==="pos"){c=a.position;if(this.interpolationType===THREE.AnimationHandler.LINEAR){c.x=d[0]+(f[0]-d[0])*e;c.y=d[1]+(f[1]-d[1])*e;c.z=d[2]+(f[2]-d[2])*e}else if(this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD){this.points[0]= this.getPrevKeyWith("pos",o,g.index-1).pos;this.points[1]=d;this.points[2]=f;this.points[3]=this.getNextKeyWith("pos",o,i.index+1).pos;e=e*0.33+0.33;d=this.interpolateCatmullRom(this.points,e);c.x=d[0];c.y=d[1];c.z=d[2];if(this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD){e=this.interpolateCatmullRom(this.points,e*1.01);this.target.set(e[0],e[1],e[2]);this.target.subSelf(c);this.target.y=0;this.target.normalize();e=Math.atan2(this.target.x,this.target.z);a.rotation.set(0,e,0)}}}else if(c=== "rot")THREE.Quaternion.slerp(d,f,a.quaternion,e);else if(c==="scl"){c=a.scale;c.x=d[0]+(f[0]-d[0])*e;c.y=d[1]+(f[1]-d[1])*e;c.z=d[2]+(f[2]-d[2])*e}}}}if(this.JITCompile&&k[0][j]===undefined){this.hierarchy[0].update(undefined,!0);for(o=0;o0?c:0:c>=0?c:c+e.length;c>=0;c--)if(e[c][a]!==undefined)return e[c];return this.data.hierarchy[b].keys[e.length-1]}; THREE.Camera=function(a,b,c,e,d){THREE.Object3D.call(this);this.fov=a||50;this.aspect=b||1;this.near=c||0.1;this.far=e||2E3;this.target=d||new THREE.Object3D;this.useTarget=!0;this.matrixWorldInverse=new THREE.Matrix4;this.projectionMatrix=null;this.updateProjectionMatrix()};THREE.Camera.prototype=new THREE.Object3D;THREE.Camera.prototype.constructor=THREE.Camera;THREE.Camera.prototype.supr=THREE.Object3D.prototype; THREE.Camera.prototype.translate=function(a,b){this.matrix.rotateAxis(b);this.position.addSelf(b.multiplyScalar(a));this.target.position.addSelf(b.multiplyScalar(a))};THREE.Camera.prototype.updateProjectionMatrix=function(){this.projectionMatrix=THREE.Matrix4.makePerspective(this.fov,this.aspect,this.near,this.far)};THREE.Camera.prototype.updateMatrix=function(){this.update(undefined,!0)}; -THREE.Camera.prototype.update=function(a,b,c){if(this.useTarget){this.matrix.lookAt(this.position,this.target.position,this.up);this.matrix.setPosition(this.position)}a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);THREE.Matrix4.makeInvert(this.matrixWorld,this.matrixWorldInverse);b=!0;for(a=0;a=0&&Y>=0&&M>=0&&T>=0)return!0;else if(X<0&&Y<0||M<0&&T<0)return!1;else{if(X<0)L=Math.max(L,X/(X-Y));else Y<0&&(W=Math.min(W,X/(X-Y)));if(M<0)L=Math.max(L,M/(M-T));else T<0&&(W=Math.min(W,M/(M-T)));if(WX&&g.positionScreen.z0&&H.z<1){da=D[z]=D[z]||new THREE.RenderableParticle;z++;B=da;B.x=H.x/H.w;B.y=H.y/H.w;B.z=H.z;B.rotation=R.rotation.z;B.scale.x=R.scale.x*Math.abs(B.x-(H.x+s.projectionMatrix.n11)/ -(H.w+s.projectionMatrix.n14));B.scale.y=R.scale.y*Math.abs(B.y-(H.y+s.projectionMatrix.n22)/(H.w+s.projectionMatrix.n24));B.materials=R.materials;W.push(B)}}}}L&&W.sort(b);return W}}; -THREE.CanvasRenderer=function(){function a(Z){if(o!=Z)k.globalAlpha=o=Z}function b(Z){if(v!=Z){switch(Z){case THREE.NormalBlending:k.globalCompositeOperation="source-over";break;case THREE.AdditiveBlending:k.globalCompositeOperation="lighter";break;case THREE.SubtractiveBlending:k.globalCompositeOperation="darker"}v=Z}}function c(Z){if(y!=Z)k.strokeStyle=y=Z}var e=null,d=new THREE.Projector,f=document.createElement("canvas"),g,i,h,j,k=f.getContext("2d"),n=new THREE.Color(0),p=0,o=1,v=0,y=null,G=null, -B=1,z,D,I,H,q=new THREE.RenderableVertex,aa=new THREE.RenderableVertex,K,P,Q,w,s,L,W,X,Y,M,T,U,C=new THREE.Color,A=new THREE.Color,F=new THREE.Color,E=new THREE.Color,S=new THREE.Color,ba,R,da,ea,Fa,Ga,na,Ba,ua,Wa,za=new THREE.Rectangle,ia=new THREE.Rectangle,fa=new THREE.Rectangle,Ua=!1,ha=new THREE.Color,ga=new THREE.Color,Ma=new THREE.Color,Na=new THREE.Color,$=new THREE.Vector3,Ha,Ia,Va,ja,Ja,Oa,Ca=16;Ha=document.createElement("canvas");Ha.width=Ha.height=2;Ia=Ha.getContext("2d");Ia.fillStyle= -"rgba(0,0,0,1)";Ia.fillRect(0,0,2,2);Va=Ia.getImageData(0,0,2,2);ja=Va.data;Ja=document.createElement("canvas");Ja.width=Ja.height=Ca;Oa=Ja.getContext("2d");Oa.translate(-Ca/2,-Ca/2);Oa.scale(Ca,Ca);Ca--;this.domElement=f;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setSize=function(Z,ka){g=Z;i=ka;h=g/2;j=i/2;f.width=g;f.height=i;za.set(-h,-j,h,j);o=1;v=0;G=y=null;B=1};this.setClearColor=function(Z,ka){n=Z;p=ka};this.setClearColorHex=function(Z,ka){n.setHex(Z);p=ka};this.clear= -function(){k.setTransform(1,0,0,-1,h,j);if(!ia.isEmpty()){ia.inflate(1);ia.minSelf(za);if(n.hex==0&&p==0)k.clearRect(ia.getX(),ia.getY(),ia.getWidth(),ia.getHeight());else{b(THREE.NormalBlending);a(1);k.fillStyle="rgba("+Math.floor(n.r*255)+","+Math.floor(n.g*255)+","+Math.floor(n.b*255)+","+p+")";k.fillRect(ia.getX(),ia.getY(),ia.getWidth(),ia.getHeight())}ia.empty()}};this.render=function(Z,ka){function Za(l){var x,t,r,N=l.lights;ga.setRGB(0,0,0);Ma.setRGB(0,0,0);Na.setRGB(0,0,0);l=0;for(x=N.length;l< -x;l++){t=N[l];r=t.color;if(t instanceof THREE.AmbientLight){ga.r+=r.r;ga.g+=r.g;ga.b+=r.b}else if(t instanceof THREE.DirectionalLight){Ma.r+=r.r;Ma.g+=r.g;Ma.b+=r.b}else if(t instanceof THREE.PointLight){Na.r+=r.r;Na.g+=r.g;Na.b+=r.b}}}function pa(l,x,t,r){var N,J,u,m,V=l.lights;l=0;for(N=V.length;l>1;V=u.height>>1;t=x.scale.x*h;J=x.scale.y*j;r=t*m;N=J*V;fa.set(l.x-r,l.y-N,l.x+r,l.y+N);if(za.instersects(fa)){k.save();k.translate(l.x,l.y);k.rotate(-x.rotation);k.scale(t,-J);k.translate(-m,-V);k.drawImage(u, -0,0);k.restore()}}}else if(t instanceof THREE.ParticleCanvasMaterial){r=x.scale.x*h;N=x.scale.y*j;fa.set(l.x-r,l.y-N,l.x+r,l.y+N);if(za.instersects(fa)){c(t.color.__styleString);J=t.color.__styleString;if(G!=J)k.fillStyle=G=J;k.save();k.translate(l.x,l.y);k.rotate(-x.rotation);k.scale(r,N);t.program(k);k.restore()}}}function ab(l,x,t,r){a(r.opacity);b(r.blending);k.beginPath();k.moveTo(l.positionScreen.x,l.positionScreen.y);k.lineTo(x.positionScreen.x,x.positionScreen.y);k.closePath();if(r instanceof -THREE.LineBasicMaterial){C.__styleString=r.color.__styleString;l=r.linewidth;if(B!=l)k.lineWidth=B=l;c(C.__styleString);k.stroke();fa.inflate(r.linewidth*2)}}function Pa(l,x,t,r,N,J,u,m,V){a(m.opacity);b(m.blending);K=l.positionScreen.x;P=l.positionScreen.y;Q=x.positionScreen.x;w=x.positionScreen.y;s=t.positionScreen.x;L=t.positionScreen.y;Ka(K,P,Q,w,s,L);if(m instanceof THREE.MeshBasicMaterial)if(m.map){if(m.map.mapping instanceof THREE.UVMapping){ea=u.uvs[0];qa(K,P,Q,w,s,L,m.map.image,ea[r].u,ea[r].v, -ea[N].u,ea[N].v,ea[J].u,ea[J].v)}}else if(m.envMap){if(m.envMap.mapping instanceof THREE.SphericalReflectionMapping){l=ka.matrixWorldInverse;$.copy(u.vertexNormalsWorld[0]);Fa=($.x*l.n11+$.y*l.n12+$.z*l.n13)*0.5+0.5;Ga=-($.x*l.n21+$.y*l.n22+$.z*l.n23)*0.5+0.5;$.copy(u.vertexNormalsWorld[1]);na=($.x*l.n11+$.y*l.n12+$.z*l.n13)*0.5+0.5;Ba=-($.x*l.n21+$.y*l.n22+$.z*l.n23)*0.5+0.5;$.copy(u.vertexNormalsWorld[2]);ua=($.x*l.n11+$.y*l.n12+$.z*l.n13)*0.5+0.5;Wa=-($.x*l.n21+$.y*l.n22+$.z*l.n23)*0.5+0.5;qa(K, -P,Q,w,s,L,m.envMap.image,Fa,Ga,na,Ba,ua,Wa)}}else m.wireframe?va(m.color.__styleString,m.wireframeLinewidth):wa(m.color.__styleString);else if(m instanceof THREE.MeshLambertMaterial){if(m.map&&!m.wireframe){if(m.map.mapping instanceof THREE.UVMapping){ea=u.uvs[0];qa(K,P,Q,w,s,L,m.map.image,ea[r].u,ea[r].v,ea[N].u,ea[N].v,ea[J].u,ea[J].v)}b(THREE.SubtractiveBlending)}if(Ua)if(!m.wireframe&&m.shading==THREE.SmoothShading&&u.vertexNormalsWorld.length==3){A.r=F.r=E.r=ga.r;A.g=F.g=E.g=ga.g;A.b=F.b=E.b= -ga.b;pa(V,u.v1.positionWorld,u.vertexNormalsWorld[0],A);pa(V,u.v2.positionWorld,u.vertexNormalsWorld[1],F);pa(V,u.v3.positionWorld,u.vertexNormalsWorld[2],E);S.r=(F.r+E.r)*0.5;S.g=(F.g+E.g)*0.5;S.b=(F.b+E.b)*0.5;da=Qa(A,F,E,S);qa(K,P,Q,w,s,L,da,0,0,1,0,0,1)}else{ha.r=ga.r;ha.g=ga.g;ha.b=ga.b;pa(V,u.centroidWorld,u.normalWorld,ha);C.r=m.color.r*ha.r;C.g=m.color.g*ha.g;C.b=m.color.b*ha.b;C.updateStyleString();m.wireframe?va(C.__styleString,m.wireframeLinewidth):wa(C.__styleString)}else m.wireframe? -va(m.color.__styleString,m.wireframeLinewidth):wa(m.color.__styleString)}else if(m instanceof THREE.MeshDepthMaterial){ba=ka.near;R=ka.far;A.r=A.g=A.b=1-Aa(l.positionScreen.z,ba,R);F.r=F.g=F.b=1-Aa(x.positionScreen.z,ba,R);E.r=E.g=E.b=1-Aa(t.positionScreen.z,ba,R);S.r=(F.r+E.r)*0.5;S.g=(F.g+E.g)*0.5;S.b=(F.b+E.b)*0.5;da=Qa(A,F,E,S);qa(K,P,Q,w,s,L,da,0,0,1,0,0,1)}else if(m instanceof THREE.MeshNormalMaterial){C.r=Da(u.normalWorld.x);C.g=Da(u.normalWorld.y);C.b=Da(u.normalWorld.z);C.updateStyleString(); -m.wireframe?va(C.__styleString,m.wireframeLinewidth):wa(C.__styleString)}}function Xa(l,x,t,r,N,J,u,m,V){a(m.opacity);b(m.blending);if(m.map||m.envMap){Pa(l,x,r,0,1,3,u,m,V);Pa(N,t,J,1,2,3,u,m,V)}else{K=l.positionScreen.x;P=l.positionScreen.y;Q=x.positionScreen.x;w=x.positionScreen.y;s=t.positionScreen.x;L=t.positionScreen.y;W=r.positionScreen.x;X=r.positionScreen.y;Y=N.positionScreen.x;M=N.positionScreen.y;T=J.positionScreen.x;U=J.positionScreen.y;if(m instanceof THREE.MeshBasicMaterial){Ra(K,P, -Q,w,s,L,W,X);m.wireframe?va(m.color.__styleString,m.wireframeLinewidth):wa(m.color.__styleString)}else if(m instanceof THREE.MeshLambertMaterial)if(Ua)if(!m.wireframe&&m.shading==THREE.SmoothShading&&u.vertexNormalsWorld.length==4){A.r=F.r=E.r=S.r=ga.r;A.g=F.g=E.g=S.g=ga.g;A.b=F.b=E.b=S.b=ga.b;pa(V,u.v1.positionWorld,u.vertexNormalsWorld[0],A);pa(V,u.v2.positionWorld,u.vertexNormalsWorld[1],F);pa(V,u.v4.positionWorld,u.vertexNormalsWorld[3],E);pa(V,u.v3.positionWorld,u.vertexNormalsWorld[2],S);da= -Qa(A,F,E,S);Ka(K,P,Q,w,W,X);qa(K,P,Q,w,W,X,da,0,0,1,0,0,1);Ka(Y,M,s,L,T,U);qa(Y,M,s,L,T,U,da,1,0,1,1,0,1)}else{ha.r=ga.r;ha.g=ga.g;ha.b=ga.b;pa(V,u.centroidWorld,u.normalWorld,ha);C.r=m.color.r*ha.r;C.g=m.color.g*ha.g;C.b=m.color.b*ha.b;C.updateStyleString();Ra(K,P,Q,w,s,L,W,X);m.wireframe?va(C.__styleString,m.wireframeLinewidth):wa(C.__styleString)}else{Ra(K,P,Q,w,s,L,W,X);m.wireframe?va(m.color.__styleString,m.wireframeLinewidth):wa(m.color.__styleString)}else if(m instanceof THREE.MeshNormalMaterial){C.r= -Da(u.normalWorld.x);C.g=Da(u.normalWorld.y);C.b=Da(u.normalWorld.z);C.updateStyleString();Ra(K,P,Q,w,s,L,W,X);m.wireframe?va(C.__styleString,m.wireframeLinewidth):wa(C.__styleString)}else if(m instanceof THREE.MeshDepthMaterial){ba=ka.near;R=ka.far;A.r=A.g=A.b=1-Aa(l.positionScreen.z,ba,R);F.r=F.g=F.b=1-Aa(x.positionScreen.z,ba,R);E.r=E.g=E.b=1-Aa(r.positionScreen.z,ba,R);S.r=S.g=S.b=1-Aa(t.positionScreen.z,ba,R);da=Qa(A,F,E,S);Ka(K,P,Q,w,W,X);qa(K,P,Q,w,W,X,da,0,0,1,0,0,1);Ka(Y,M,s,L,T,U);qa(Y,M, -s,L,T,U,da,1,0,1,1,0,1)}}}function Ka(l,x,t,r,N,J){k.beginPath();k.moveTo(l,x);k.lineTo(t,r);k.lineTo(N,J);k.lineTo(l,x);k.closePath()}function Ra(l,x,t,r,N,J,u,m){k.beginPath();k.moveTo(l,x);k.lineTo(t,r);k.lineTo(N,J);k.lineTo(u,m);k.lineTo(l,x);k.closePath()}function va(l,x){c(l);if(B!=x)k.lineWidth=B=x;k.stroke();fa.inflate(x*2)}function wa(l){if(G!=l)k.fillStyle=G=l;k.fill()}function qa(l,x,t,r,N,J,u,m,V,ra,la,sa,La){var oa,ta;oa=u.width-1;ta=u.height-1;m*=oa;V*=ta;ra*=oa;la*=ta;sa*=oa;La*=ta; -t-=l;r-=x;N-=l;J-=x;ra-=m;la-=V;sa-=m;La-=V;oa=ra*La-sa*la;if(oa!=0){ta=1/oa;oa=(La*t-la*N)*ta;la=(La*r-la*J)*ta;t=(ra*N-sa*t)*ta;r=(ra*J-sa*r)*ta;l=l-oa*m-t*V;x=x-la*m-r*V;k.save();k.transform(oa,la,t,r,l,x);k.clip();k.drawImage(u,0,0);k.restore()}}function Qa(l,x,t,r){var N=~~(l.r*255),J=~~(l.g*255);l=~~(l.b*255);var u=~~(x.r*255),m=~~(x.g*255);x=~~(x.b*255);var V=~~(t.r*255),ra=~~(t.g*255);t=~~(t.b*255);var la=~~(r.r*255),sa=~~(r.g*255);r=~~(r.b*255);ja[0]=N<0?0:N>255?255:N;ja[1]=J<0?0:J>255?255: -J;ja[2]=l<0?0:l>255?255:l;ja[4]=u<0?0:u>255?255:u;ja[5]=m<0?0:m>255?255:m;ja[6]=x<0?0:x>255?255:x;ja[8]=V<0?0:V>255?255:V;ja[9]=ra<0?0:ra>255?255:ra;ja[10]=t<0?0:t>255?255:t;ja[12]=la<0?0:la>255?255:la;ja[13]=sa<0?0:sa>255?255:sa;ja[14]=r<0?0:r>255?255:r;Ia.putImageData(Va,0,0);Oa.drawImage(Ha,0,0);return Ja}function Aa(l,x,t){l=(l-x)/(t-x);return l*l*(3-2*l)}function Da(l){l=(l+1)*0.5;return l<0?0:l>1?1:l}function xa(l,x){var t=x.x-l.x,r=x.y-l.y,N=1/Math.sqrt(t*t+r*r);t*=N;r*=N;x.x+=t;x.y+=r;l.x-= -t;l.y-=r}var Sa,Ya,O,ma,ya,Ea,Ta,ca;this.autoClear?this.clear():k.setTransform(1,0,0,-1,h,j);e=d.projectScene(Z,ka,this.sortElements);(Ua=Z.lights.length>0)&&Za(Z);Sa=0;for(Ya=e.length;Sa=0&&T>=0&&E>=0&&R>=0)return!0;else if(Q<0&&T<0||E<0&&R<0)return!1;else{if(Q<0)K=Math.max(K,Q/(Q-T));else T<0&&(N=Math.min(N,Q/(Q-T)));if(E<0)K=Math.max(K,E/(E-R));else R<0&&(N=Math.min(N,E/(E-R)));if(NQ&&g.positionScreen.z0&&u.z<1){da=V[U]=V[U]||new THREE.RenderableParticle;U++;A=da;A.x=u.x/u.w;A.y=u.y/u.w;A.z=u.z;A.rotation=G.rotation.z;A.scale.x=G.scale.x*Math.abs(A.x-(u.x+ +t.projectionMatrix.n11)/(u.w+t.projectionMatrix.n14));A.scale.y=G.scale.y*Math.abs(A.y-(u.y+t.projectionMatrix.n22)/(u.w+t.projectionMatrix.n24));A.materials=G.materials;N.push(A)}}}}K&&N.sort(b);return N}}; +THREE.CanvasRenderer=function(){function a($){if(o!=$)k.globalAlpha=o=$}function b($){if(w!=$){switch($){case THREE.NormalBlending:k.globalCompositeOperation="source-over";break;case THREE.AdditiveBlending:k.globalCompositeOperation="lighter";break;case THREE.SubtractiveBlending:k.globalCompositeOperation="darker"}w=$}}function c($){if(z!=$)k.strokeStyle=z=$}var e=null,d=new THREE.Projector,f=document.createElement("canvas"),g,i,h,j,k=f.getContext("2d"),n=new THREE.Color(0),q=0,o=1,w=0,z=null,D=null, +A=null,U=null,V=null,B,u,p,Y,Z=new THREE.RenderableVertex,aa=new THREE.RenderableVertex,P,x,t,K,N,Q,T,E,R,S,W,H,C=new THREE.Color,F=new THREE.Color,I=new THREE.Color,M=new THREE.Color,G=new THREE.Color,da,ia,ja,fa,pa,Da,wa,Wa,Xa,Ya,Ba=new THREE.Rectangle,ka=new THREE.Rectangle,ea=new THREE.Rectangle,Ua=!1,ha=new THREE.Color,ga=new THREE.Color,Ma=new THREE.Color,Na=new THREE.Color,ba=new THREE.Vector3,Ha,Ia,Va,la,Ja,Oa,Ea=16;Ha=document.createElement("canvas");Ha.width=Ha.height=2;Ia=Ha.getContext("2d"); +Ia.fillStyle="rgba(0,0,0,1)";Ia.fillRect(0,0,2,2);Va=Ia.getImageData(0,0,2,2);la=Va.data;Ja=document.createElement("canvas");Ja.width=Ja.height=Ea;Oa=Ja.getContext("2d");Oa.translate(-Ea/2,-Ea/2);Oa.scale(Ea,Ea);Ea--;this.domElement=f;this.autoClear=!0;this.sortObjects=!0;this.sortElements=!0;this.setSize=function($,ma){g=$;i=ma;h=g/2;j=i/2;f.width=g;f.height=i;Ba.set(-h,-j,h,j);o=1;w=0;V=U=A=D=z=null};this.setClearColor=function($,ma){n=$;q=ma};this.setClearColorHex=function($,ma){n.setHex($);q= +ma};this.clear=function(){k.setTransform(1,0,0,-1,h,j);if(!ka.isEmpty()){ka.inflate(1);ka.minSelf(Ba);if(n.hex==0&&q==0)k.clearRect(ka.getX(),ka.getY(),ka.getWidth(),ka.getHeight());else{b(THREE.NormalBlending);a(1);k.fillStyle="rgba("+Math.floor(n.r*255)+","+Math.floor(n.g*255)+","+Math.floor(n.b*255)+","+q+")";k.fillRect(ka.getX(),ka.getY(),ka.getWidth(),ka.getHeight())}ka.empty()}};this.render=function($,ma){function ab(m){var y,s,r,L=m.lights;ga.setRGB(0,0,0);Ma.setRGB(0,0,0);Na.setRGB(0,0,0); +m=0;for(y=L.length;m>1;X=v.height>>1;s=y.scale.x*h;J=y.scale.y*j;r=s*l;L=J*X;ea.set(m.x-r,m.y-L,m.x+r,m.y+L);if(Ba.instersects(ea)){k.save();k.translate(m.x,m.y);k.rotate(-y.rotation);k.scale(s,-J); +k.translate(-l,-X);k.drawImage(v,0,0);k.restore()}}}else if(s instanceof THREE.ParticleCanvasMaterial){r=y.scale.x*h;L=y.scale.y*j;ea.set(m.x-r,m.y-L,m.x+r,m.y+L);if(Ba.instersects(ea)){c(s.color.__styleString);J=s.color.__styleString;if(D!=J)k.fillStyle=D=J;k.save();k.translate(m.x,m.y);k.rotate(-y.rotation);k.scale(r,L);s.program(k);k.restore()}}}function cb(m,y,s,r){a(r.opacity);b(r.blending);k.beginPath();k.moveTo(m.positionScreen.x,m.positionScreen.y);k.lineTo(y.positionScreen.x,y.positionScreen.y); +k.closePath();if(r instanceof THREE.LineBasicMaterial){C.__styleString=r.color.__styleString;m=r.linewidth;if(A!=m)k.lineWidth=A=m;m=r.linecap;if(U!=m)k.lineCap=U=m;m=r.linejoin;if(V!=m)k.lineJoin=V=m;c(C.__styleString);k.stroke();ea.inflate(r.linewidth*2)}}function Pa(m,y,s,r,L,J,v,l,X){a(l.opacity);b(l.blending);P=m.positionScreen.x;x=m.positionScreen.y;t=y.positionScreen.x;K=y.positionScreen.y;N=s.positionScreen.x;Q=s.positionScreen.y;Ka(P,x,t,K,N,Q);if(l instanceof THREE.MeshBasicMaterial)if(l.map){if(l.map.mapping instanceof +THREE.UVMapping){fa=v.uvs[0];sa(P,x,t,K,N,Q,l.map.image,fa[r].u,fa[r].v,fa[L].u,fa[L].v,fa[J].u,fa[J].v)}}else if(l.envMap){if(l.envMap.mapping instanceof THREE.SphericalReflectionMapping){m=ma.matrixWorldInverse;ba.copy(v.vertexNormalsWorld[0]);pa=(ba.x*m.n11+ba.y*m.n12+ba.z*m.n13)*0.5+0.5;Da=-(ba.x*m.n21+ba.y*m.n22+ba.z*m.n23)*0.5+0.5;ba.copy(v.vertexNormalsWorld[1]);wa=(ba.x*m.n11+ba.y*m.n12+ba.z*m.n13)*0.5+0.5;Wa=-(ba.x*m.n21+ba.y*m.n22+ba.z*m.n23)*0.5+0.5;ba.copy(v.vertexNormalsWorld[2]);Xa= +(ba.x*m.n11+ba.y*m.n12+ba.z*m.n13)*0.5+0.5;Ya=-(ba.x*m.n21+ba.y*m.n22+ba.z*m.n23)*0.5+0.5;sa(P,x,t,K,N,Q,l.envMap.image,pa,Da,wa,Wa,Xa,Ya)}}else l.wireframe?xa(l.color.__styleString,l.wireframeLinewidth,l.wireframeLinecap,l.wireframeLinejoin):ya(l.color.__styleString);else if(l instanceof THREE.MeshLambertMaterial){if(l.map&&!l.wireframe){if(l.map.mapping instanceof THREE.UVMapping){fa=v.uvs[0];sa(P,x,t,K,N,Q,l.map.image,fa[r].u,fa[r].v,fa[L].u,fa[L].v,fa[J].u,fa[J].v)}b(THREE.SubtractiveBlending)}if(Ua)if(!l.wireframe&& +l.shading==THREE.SmoothShading&&v.vertexNormalsWorld.length==3){F.r=I.r=M.r=ga.r;F.g=I.g=M.g=ga.g;F.b=I.b=M.b=ga.b;ra(X,v.v1.positionWorld,v.vertexNormalsWorld[0],F);ra(X,v.v2.positionWorld,v.vertexNormalsWorld[1],I);ra(X,v.v3.positionWorld,v.vertexNormalsWorld[2],M);G.r=(I.r+M.r)*0.5;G.g=(I.g+M.g)*0.5;G.b=(I.b+M.b)*0.5;ja=Qa(F,I,M,G);sa(P,x,t,K,N,Q,ja,0,0,1,0,0,1)}else{ha.r=ga.r;ha.g=ga.g;ha.b=ga.b;ra(X,v.centroidWorld,v.normalWorld,ha);C.r=l.color.r*ha.r;C.g=l.color.g*ha.g;C.b=l.color.b*ha.b;C.updateStyleString(); +l.wireframe?xa(C.__styleString,l.wireframeLinewidth,l.wireframeLinecap,l.wireframeLinejoin):ya(C.__styleString)}else l.wireframe?xa(l.color.__styleString,l.wireframeLinewidth,l.wireframeLinecap,l.wireframeLinejoin):ya(l.color.__styleString)}else if(l instanceof THREE.MeshDepthMaterial){da=ma.near;ia=ma.far;F.r=F.g=F.b=1-Ca(m.positionScreen.z,da,ia);I.r=I.g=I.b=1-Ca(y.positionScreen.z,da,ia);M.r=M.g=M.b=1-Ca(s.positionScreen.z,da,ia);G.r=(I.r+M.r)*0.5;G.g=(I.g+M.g)*0.5;G.b=(I.b+M.b)*0.5;ja=Qa(F,I, +M,G);sa(P,x,t,K,N,Q,ja,0,0,1,0,0,1)}else if(l instanceof THREE.MeshNormalMaterial){C.r=Fa(v.normalWorld.x);C.g=Fa(v.normalWorld.y);C.b=Fa(v.normalWorld.z);C.updateStyleString();l.wireframe?xa(C.__styleString,l.wireframeLinewidth,l.wireframeLinecap,l.wireframeLinejoin):ya(C.__styleString)}}function Za(m,y,s,r,L,J,v,l,X){a(l.opacity);b(l.blending);if(l.map||l.envMap){Pa(m,y,r,0,1,3,v,l,X);Pa(L,s,J,1,2,3,v,l,X)}else{P=m.positionScreen.x;x=m.positionScreen.y;t=y.positionScreen.x;K=y.positionScreen.y; +N=s.positionScreen.x;Q=s.positionScreen.y;T=r.positionScreen.x;E=r.positionScreen.y;R=L.positionScreen.x;S=L.positionScreen.y;W=J.positionScreen.x;H=J.positionScreen.y;if(l instanceof THREE.MeshBasicMaterial){Ra(P,x,t,K,N,Q,T,E);l.wireframe?xa(l.color.__styleString,l.wireframeLinewidth,l.wireframeLinecap,l.wireframeLinejoin):ya(l.color.__styleString)}else if(l instanceof THREE.MeshLambertMaterial)if(Ua)if(!l.wireframe&&l.shading==THREE.SmoothShading&&v.vertexNormalsWorld.length==4){F.r=I.r=M.r=G.r= +ga.r;F.g=I.g=M.g=G.g=ga.g;F.b=I.b=M.b=G.b=ga.b;ra(X,v.v1.positionWorld,v.vertexNormalsWorld[0],F);ra(X,v.v2.positionWorld,v.vertexNormalsWorld[1],I);ra(X,v.v4.positionWorld,v.vertexNormalsWorld[3],M);ra(X,v.v3.positionWorld,v.vertexNormalsWorld[2],G);ja=Qa(F,I,M,G);Ka(P,x,t,K,T,E);sa(P,x,t,K,T,E,ja,0,0,1,0,0,1);Ka(R,S,N,Q,W,H);sa(R,S,N,Q,W,H,ja,1,0,1,1,0,1)}else{ha.r=ga.r;ha.g=ga.g;ha.b=ga.b;ra(X,v.centroidWorld,v.normalWorld,ha);C.r=l.color.r*ha.r;C.g=l.color.g*ha.g;C.b=l.color.b*ha.b;C.updateStyleString(); +Ra(P,x,t,K,N,Q,T,E);l.wireframe?xa(C.__styleString,l.wireframeLinewidth,l.wireframeLinecap,l.wireframeLinejoin):ya(C.__styleString)}else{Ra(P,x,t,K,N,Q,T,E);l.wireframe?xa(l.color.__styleString,l.wireframeLinewidth,l.wireframeLinecap,l.wireframeLinejoin):ya(l.color.__styleString)}else if(l instanceof THREE.MeshNormalMaterial){C.r=Fa(v.normalWorld.x);C.g=Fa(v.normalWorld.y);C.b=Fa(v.normalWorld.z);C.updateStyleString();Ra(P,x,t,K,N,Q,T,E);l.wireframe?xa(C.__styleString,l.wireframeLinewidth,l.wireframeLinecap, +l.wireframeLinejoin):ya(C.__styleString)}else if(l instanceof THREE.MeshDepthMaterial){da=ma.near;ia=ma.far;F.r=F.g=F.b=1-Ca(m.positionScreen.z,da,ia);I.r=I.g=I.b=1-Ca(y.positionScreen.z,da,ia);M.r=M.g=M.b=1-Ca(r.positionScreen.z,da,ia);G.r=G.g=G.b=1-Ca(s.positionScreen.z,da,ia);ja=Qa(F,I,M,G);Ka(P,x,t,K,T,E);sa(P,x,t,K,T,E,ja,0,0,1,0,0,1);Ka(R,S,N,Q,W,H);sa(R,S,N,Q,W,H,ja,1,0,1,1,0,1)}}}function Ka(m,y,s,r,L,J){k.beginPath();k.moveTo(m,y);k.lineTo(s,r);k.lineTo(L,J);k.lineTo(m,y);k.closePath()}function Ra(m, +y,s,r,L,J,v,l){k.beginPath();k.moveTo(m,y);k.lineTo(s,r);k.lineTo(L,J);k.lineTo(v,l);k.lineTo(m,y);k.closePath()}function xa(m,y,s,r){if(A!=y)k.lineWidth=A=y;if(U!=s)k.lineCap=U=s;if(V!=r)k.lineJoin=V=r;c(m);k.stroke();ea.inflate(y*2)}function ya(m){if(D!=m)k.fillStyle=D=m;k.fill()}function sa(m,y,s,r,L,J,v,l,X,ta,na,ua,La){var qa,va;qa=v.width-1;va=v.height-1;l*=qa;X*=va;ta*=qa;na*=va;ua*=qa;La*=va;s-=m;r-=y;L-=m;J-=y;ta-=l;na-=X;ua-=l;La-=X;qa=ta*La-ua*na;if(qa!=0){va=1/qa;qa=(La*s-na*L)*va;na= +(La*r-na*J)*va;s=(ta*L-ua*s)*va;r=(ta*J-ua*r)*va;m=m-qa*l-s*X;y=y-na*l-r*X;k.save();k.transform(qa,na,s,r,m,y);k.clip();k.drawImage(v,0,0);k.restore()}}function Qa(m,y,s,r){var L=~~(m.r*255),J=~~(m.g*255);m=~~(m.b*255);var v=~~(y.r*255),l=~~(y.g*255);y=~~(y.b*255);var X=~~(s.r*255),ta=~~(s.g*255);s=~~(s.b*255);var na=~~(r.r*255),ua=~~(r.g*255);r=~~(r.b*255);la[0]=L<0?0:L>255?255:L;la[1]=J<0?0:J>255?255:J;la[2]=m<0?0:m>255?255:m;la[4]=v<0?0:v>255?255:v;la[5]=l<0?0:l>255?255:l;la[6]=y<0?0:y>255?255: +y;la[8]=X<0?0:X>255?255:X;la[9]=ta<0?0:ta>255?255:ta;la[10]=s<0?0:s>255?255:s;la[12]=na<0?0:na>255?255:na;la[13]=ua<0?0:ua>255?255:ua;la[14]=r<0?0:r>255?255:r;Ia.putImageData(Va,0,0);Oa.drawImage(Ha,0,0);return Ja}function Ca(m,y,s){m=(m-y)/(s-y);return m*m*(3-2*m)}function Fa(m){m=(m+1)*0.5;return m<0?0:m>1?1:m}function za(m,y){var s=y.x-m.x,r=y.y-m.y,L=1/Math.sqrt(s*s+r*r);s*=L;r*=L;y.x+=s;y.y+=r;m.x-=s;m.y-=r}var Sa,$a,O,oa,Aa,Ga,Ta,ca;this.autoClear?this.clear():k.setTransform(1,0,0,-1,h,j);e= +d.projectScene($,ma,this.sortElements);(Ua=$.lights.length>0)&&ab($);Sa=0;for($a=e.length;Sa<$a;Sa++){O=e[Sa];ea.empty();if(O instanceof THREE.RenderableParticle){B=O;B.x*=h;B.y*=j;oa=0;for(Aa=O.materials.length;oa=1){c.w=a.w;c.x=a.x;c.y=a.y;c.z=a.z;return c}var g=Math.acos(d),f=Math.sqrt(1-d*d);if(Math.abs(f)<0.001){c.w=0.5*(a.w+b.w);c.x=0.5*(a.x+b.x);c.y=0.5*(a.y+b.y);c.z=0.5*(a.z+b.z);return c}d=Math.sin((1-e)*g)/f;e=Math.sin(e*g)/f;c.w=a.w*d+b.w*e;c.x=a.x*d+b.x*e;c.y=a.y*d+b.y*e;c.z=a.z*d+b.z*e;return c};THREE.Vertex=function(a){this.position=a||new THREE.Vector3}; +THREE.Quaternion.slerp=function(a,b,c,e){var d=a.w*b.w+a.x*b.x+a.y*b.y+a.z*b.z;if(Math.abs(d)>=1){c.w=a.w;c.x=a.x;c.y=a.y;c.z=a.z;return c}var g=Math.acos(d),f=Math.sqrt(1-d*d);if(Math.abs(f)<0.0010){c.w=0.5*(a.w+b.w);c.x=0.5*(a.x+b.x);c.y=0.5*(a.y+b.y);c.z=0.5*(a.z+b.z);return c}d=Math.sin((1-e)*g)/f;e=Math.sin(e*g)/f;c.w=a.w*d+b.w*e;c.x=a.x*d+b.x*e;c.y=a.y*d+b.y*e;c.z=a.z*d+b.z*e;return c};THREE.Vertex=function(a){this.position=a||new THREE.Vector3}; THREE.Face3=function(a,b,c,e,d,g){this.a=a;this.b=b;this.c=c;this.normal=e instanceof THREE.Vector3?e:new THREE.Vector3;this.vertexNormals=e instanceof Array?e:[];this.color=d instanceof THREE.Color?d:new THREE.Color;this.vertexColors=d instanceof Array?d:[];this.vertexTangents=[];this.materials=g instanceof Array?g:[g];this.centroid=new THREE.Vector3}; THREE.Face4=function(a,b,c,e,d,g,f){this.a=a;this.b=b;this.c=c;this.d=e;this.normal=d instanceof THREE.Vector3?d:new THREE.Vector3;this.vertexNormals=d instanceof Array?d:[];this.color=g instanceof THREE.Color?g:new THREE.Color;this.vertexColors=g instanceof Array?g:[];this.vertexTangents=[];this.materials=f instanceof Array?f:[f];this.centroid=new THREE.Vector3};THREE.UV=function(a,b){this.set(a||0,b||0)}; THREE.UV.prototype={set:function(a,b){this.u=a;this.v=b;return this},copy:function(a){this.set(a.u,a.v);return this}}; @@ -71,8 +71,9 @@ THREE.Animation.prototype.interpolate=function(a,b,c,e,d,g,f){a=(c-a)*0.5;e=(e-b THREE.Animation.prototype.getPrevKeyWith=function(a,b,c){var e=this.data.hierarchy[b].keys;for(c=this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD?c>0?c:0:c>=0?c:c+e.length;c>=0;c--)if(e[c][a]!==undefined)return e[c];return this.data.hierarchy[b].keys[e.length-1]}; THREE.Camera=function(a,b,c,e,d){THREE.Object3D.call(this);this.fov=a||50;this.aspect=b||1;this.near=c||0.1;this.far=e||2E3;this.target=d||new THREE.Object3D;this.useTarget=!0;this.matrixWorldInverse=new THREE.Matrix4;this.projectionMatrix=null;this.updateProjectionMatrix()};THREE.Camera.prototype=new THREE.Object3D;THREE.Camera.prototype.constructor=THREE.Camera;THREE.Camera.prototype.supr=THREE.Object3D.prototype; THREE.Camera.prototype.translate=function(a,b){this.matrix.rotateAxis(b);this.position.addSelf(b.multiplyScalar(a));this.target.position.addSelf(b.multiplyScalar(a))};THREE.Camera.prototype.updateProjectionMatrix=function(){this.projectionMatrix=THREE.Matrix4.makePerspective(this.fov,this.aspect,this.near,this.far)};THREE.Camera.prototype.updateMatrix=function(){this.update(undefined,!0)}; -THREE.Camera.prototype.update=function(a,b,c){if(this.useTarget){this.matrix.lookAt(this.position,this.target.position,this.up);this.matrix.setPosition(this.position)}a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);THREE.Matrix4.makeInvert(this.matrixWorld,this.matrixWorldInverse);b=!0;for(a=0;a25&&(f=25);d=(f-1)*0.5;b=Array(f);for(e=c=0;ethis.heightMax?this.heightMax:this.position.y)-this.heightMin)*this.heightCoef:0;(this.moveForward||this.autoForward)&&this.translateZ(-(this.movementSpeed+this.autoSpeedFactor));this.moveBackward&&this.translateZ(this.movementSpeed);this.moveLeft&&this.translateX(-this.movementSpeed);this.moveRight&&this.translateX(this.movementSpeed); -var b=this.lookSpeed;this.dragToLook&&!this.mouseDragOn&&(b=0);this.lon+=this.mouseX*b;this.lookVertical&&(this.lat-=this.mouseY*b);this.lat=Math.max(-85,Math.min(85,this.lat));this.phi=(90-this.lat)*Math.PI/180;this.theta=this.lon*Math.PI/180;b=this.target.position;var c=this.position;b.x=c.x+100*Math.sin(this.phi)*Math.cos(this.theta);b.y=c.y+100*Math.cos(this.phi);b.z=c.z+100*Math.sin(this.phi)*Math.sin(this.theta);this.supr.update.call(this)};this.domElement.addEventListener("contextmenu",function(b){b.preventDefault()}, +var b=this.lookSpeed;this.activeLook||(b=0);this.lon+=this.mouseX*b;this.lookVertical&&(this.lat-=this.mouseY*b);this.lat=Math.max(-85,Math.min(85,this.lat));this.phi=(90-this.lat)*Math.PI/180;this.theta=this.lon*Math.PI/180;b=this.target.position;var c=this.position;b.x=c.x+100*Math.sin(this.phi)*Math.cos(this.theta);b.y=c.y+100*Math.cos(this.phi);b.z=c.z+100*Math.sin(this.phi)*Math.sin(this.theta);this.supr.update.call(this)};this.domElement.addEventListener("contextmenu",function(b){b.preventDefault()}, !1);this.domElement.addEventListener("mousemove",e(this,this.onMouseMove),!1);this.domElement.addEventListener("mousedown",e(this,this.onMouseDown),!1);this.domElement.addEventListener("mouseup",e(this,this.onMouseUp),!1);this.domElement.addEventListener("keydown",e(this,this.onKeyDown),!1);this.domElement.addEventListener("keyup",e(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(a,e){this.matrix.rotateAxis(e);if(this.noFly)e.y=0;this.position.addSelf(e.multiplyScalar(a));this.target.position.addSelf(e.multiplyScalar(a))}; THREE.PathCamera=function(a){function e(k,j,m,p){var w={name:m,fps:0.6,length:p,hierarchy:[]},t,z=j.getControlPointsArray(),y=j.getLength(),A=z.length,C=0;t=A-1;j={parent:-1,keys:[]};j.keys[0]={time:0,pos:z[0],rot:[0,0,0,1],scl:[1,1,1]};j.keys[t]={time:p,pos:z[t],rot:[0,0,0,1],scl:[1,1,1]};for(t=1;t=0?p:p+d;p=this.verticalAngleMap.srcRange;w=this.verticalAngleMap.dstRange; @@ -50,7 +50,7 @@ for(c=a+a/2;c<2*a;c++)h.faces.push(new THREE.Face4(2*a+1,(2*c-2*a+2)%a+a,(2*c-2* var Icosahedron=function(a){function e(m,p,w){var t=Math.sqrt(m*m+p*p+w*w);return d.vertices.push(new THREE.Vertex(new THREE.Vector3(m/t,p/t,w/t)))-1}function b(m,p,w,t){t.faces.push(new THREE.Face3(m,p,w))}function c(m,p){var w=d.vertices[m].position,t=d.vertices[p].position;return e((w.x+t.x)/2,(w.y+t.y)/2,(w.z+t.z)/2)}var d=this,f=new THREE.Geometry,g;this.subdivisions=a||0;THREE.Geometry.call(this);a=(1+Math.sqrt(5))/2;e(-1,a,0);e(1,a,0);e(-1,-a,0);e(1,-a,0);e(0,-1,a);e(0,1,a);e(0,-1,-a);e(0, 1,-a);e(a,0,-1);e(a,0,1);e(-a,0,-1);e(-a,0,1);b(0,11,5,f);b(0,5,1,f);b(0,1,7,f);b(0,7,10,f);b(0,10,11,f);b(1,5,9,f);b(5,11,4,f);b(11,10,2,f);b(10,7,6,f);b(7,1,8,f);b(3,9,4,f);b(3,4,2,f);b(3,2,6,f);b(3,6,8,f);b(3,8,9,f);b(4,9,5,f);b(2,4,11,f);b(6,2,10,f);b(8,6,7,f);b(9,8,1,f);for(a=0;a=1){c.w=a.w;c.x=a.x;c.y=a.y;c.z=a.z;return c}var f=Math.acos(d),g=Math.sqrt(1-d*d);if(Math.abs(g)<0.001){c.w=0.5*(a.w+b.w);c.x=0.5*(a.x+b.x);c.y=0.5*(a.y+b.y);c.z=0.5*(a.z+b.z);return c}d=Math.sin((1-e)*f)/g;e=Math.sin(e*f)/g;c.w=a.w*d+b.w*e;c.x=a.x*d+b.x*e;c.y=a.y*d+b.y*e;c.z=a.z*d+b.z*e;return c};THREE.Vertex=function(a){this.position=a||new THREE.Vector3}; +THREE.Quaternion.slerp=function(a,b,c,e){var d=a.w*b.w+a.x*b.x+a.y*b.y+a.z*b.z;if(Math.abs(d)>=1){c.w=a.w;c.x=a.x;c.y=a.y;c.z=a.z;return c}var f=Math.acos(d),g=Math.sqrt(1-d*d);if(Math.abs(g)<0.0010){c.w=0.5*(a.w+b.w);c.x=0.5*(a.x+b.x);c.y=0.5*(a.y+b.y);c.z=0.5*(a.z+b.z);return c}d=Math.sin((1-e)*f)/g;e=Math.sin(e*f)/g;c.w=a.w*d+b.w*e;c.x=a.x*d+b.x*e;c.y=a.y*d+b.y*e;c.z=a.z*d+b.z*e;return c};THREE.Vertex=function(a){this.position=a||new THREE.Vector3}; THREE.Face3=function(a,b,c,e,d,f){this.a=a;this.b=b;this.c=c;this.normal=e instanceof THREE.Vector3?e:new THREE.Vector3;this.vertexNormals=e instanceof Array?e:[];this.color=d instanceof THREE.Color?d:new THREE.Color;this.vertexColors=d instanceof Array?d:[];this.vertexTangents=[];this.materials=f instanceof Array?f:[f];this.centroid=new THREE.Vector3}; THREE.Face4=function(a,b,c,e,d,f,g){this.a=a;this.b=b;this.c=c;this.d=e;this.normal=d instanceof THREE.Vector3?d:new THREE.Vector3;this.vertexNormals=d instanceof Array?d:[];this.color=f instanceof THREE.Color?f:new THREE.Color;this.vertexColors=f instanceof Array?f:[];this.vertexTangents=[];this.materials=g instanceof Array?g:[g];this.centroid=new THREE.Vector3};THREE.UV=function(a,b){this.set(a||0,b||0)}; THREE.UV.prototype={set:function(a,b){this.u=a;this.v=b;return this},copy:function(a){this.set(a.u,a.v);return this}};THREE.Geometry=function(){this.id="Geometry"+THREE.GeometryIdCounter++;this.vertices=[];this.colors=[];this.faces=[];this.faceUvs=[[]];this.faceVertexUvs=[[]];this.morphTargets=[];this.skinWeights=[];this.skinIndices=[];this.boundingSphere=this.boundingBox=null;this.hasTangents=!1}; @@ -80,10 +80,10 @@ THREE.Animation.prototype.interpolate=function(a,b,c,e,d,f,g){a=(c-a)*0.5;e=(e-b THREE.Animation.prototype.getPrevKeyWith=function(a,b,c){var e=this.data.hierarchy[b].keys;for(c=this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD?c>0?c:0:c>=0?c:c+e.length;c>=0;c--)if(e[c][a]!==undefined)return e[c];return this.data.hierarchy[b].keys[e.length-1]}; THREE.Camera=function(a,b,c,e,d){THREE.Object3D.call(this);this.fov=a||50;this.aspect=b||1;this.near=c||0.1;this.far=e||2E3;this.target=d||new THREE.Object3D;this.useTarget=!0;this.matrixWorldInverse=new THREE.Matrix4;this.projectionMatrix=null;this.updateProjectionMatrix()};THREE.Camera.prototype=new THREE.Object3D;THREE.Camera.prototype.constructor=THREE.Camera;THREE.Camera.prototype.supr=THREE.Object3D.prototype; THREE.Camera.prototype.translate=function(a,b){this.matrix.rotateAxis(b);this.position.addSelf(b.multiplyScalar(a));this.target.position.addSelf(b.multiplyScalar(a))};THREE.Camera.prototype.updateProjectionMatrix=function(){this.projectionMatrix=THREE.Matrix4.makePerspective(this.fov,this.aspect,this.near,this.far)};THREE.Camera.prototype.updateMatrix=function(){this.update(undefined,!0)}; -THREE.Camera.prototype.update=function(a,b,c){if(this.useTarget){this.matrix.lookAt(this.position,this.target.position,this.up);this.matrix.setPosition(this.position)}a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);THREE.Matrix4.makeInvert(this.matrixWorld,this.matrixWorldInverse);b=!0;for(a=0;a=1){d.w=a.w;d.x=a.x;d.y=a.y;d.z=a.z;return d}var h=Math.acos(f),i=Math.sqrt(1-f*f);if(Math.abs(i)<0.001){d.w=0.5*(a.w+c.w);d.x=0.5*(a.x+c.x);d.y=0.5*(a.y+c.y);d.z=0.5*(a.z+c.z);return d}f=Math.sin((1-g)*h)/i;g=Math.sin(g*h)/i;d.w=a.w*f+c.w*g;d.x=a.x*f+c.x*g;d.y=a.y*f+c.y*g;d.z=a.z*f+c.z*g;return d};THREE.Vertex=function(a){this.position=a||new THREE.Vector3}; +THREE.Quaternion.slerp=function(a,c,d,g){var f=a.w*c.w+a.x*c.x+a.y*c.y+a.z*c.z;if(Math.abs(f)>=1){d.w=a.w;d.x=a.x;d.y=a.y;d.z=a.z;return d}var h=Math.acos(f),i=Math.sqrt(1-f*f);if(Math.abs(i)<0.0010){d.w=0.5*(a.w+c.w);d.x=0.5*(a.x+c.x);d.y=0.5*(a.y+c.y);d.z=0.5*(a.z+c.z);return d}f=Math.sin((1-g)*h)/i;g=Math.sin(g*h)/i;d.w=a.w*f+c.w*g;d.x=a.x*f+c.x*g;d.y=a.y*f+c.y*g;d.z=a.z*f+c.z*g;return d};THREE.Vertex=function(a){this.position=a||new THREE.Vector3}; THREE.Face3=function(a,c,d,g,f,h){this.a=a;this.b=c;this.c=d;this.normal=g instanceof THREE.Vector3?g:new THREE.Vector3;this.vertexNormals=g instanceof Array?g:[];this.color=f instanceof THREE.Color?f:new THREE.Color;this.vertexColors=f instanceof Array?f:[];this.vertexTangents=[];this.materials=h instanceof Array?h:[h];this.centroid=new THREE.Vector3}; THREE.Face4=function(a,c,d,g,f,h,i){this.a=a;this.b=c;this.c=d;this.d=g;this.normal=f instanceof THREE.Vector3?f:new THREE.Vector3;this.vertexNormals=f instanceof Array?f:[];this.color=h instanceof THREE.Color?h:new THREE.Color;this.vertexColors=h instanceof Array?h:[];this.vertexTangents=[];this.materials=i instanceof Array?i:[i];this.centroid=new THREE.Vector3};THREE.UV=function(a,c){this.set(a||0,c||0)}; THREE.UV.prototype={set:function(a,c){this.u=a;this.v=c;return this},copy:function(a){this.set(a.u,a.v);return this}};THREE.Geometry=function(){this.id="Geometry"+THREE.GeometryIdCounter++;this.vertices=[];this.colors=[];this.faces=[];this.faceUvs=[[]];this.faceVertexUvs=[[]];this.morphTargets=[];this.skinWeights=[];this.skinIndices=[];this.boundingSphere=this.boundingBox=null;this.hasTangents=!1}; @@ -81,10 +81,11 @@ THREE.Animation.prototype.interpolate=function(a,c,d,g,f,h,i){a=(d-a)*0.5;g=(g-c THREE.Animation.prototype.getPrevKeyWith=function(a,c,d){var g=this.data.hierarchy[c].keys;for(d=this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD?d>0?d:0:d>=0?d:d+g.length;d>=0;d--)if(g[d][a]!==undefined)return g[d];return this.data.hierarchy[c].keys[g.length-1]}; THREE.Camera=function(a,c,d,g,f){THREE.Object3D.call(this);this.fov=a||50;this.aspect=c||1;this.near=d||0.1;this.far=g||2E3;this.target=f||new THREE.Object3D;this.useTarget=!0;this.matrixWorldInverse=new THREE.Matrix4;this.projectionMatrix=null;this.updateProjectionMatrix()};THREE.Camera.prototype=new THREE.Object3D;THREE.Camera.prototype.constructor=THREE.Camera;THREE.Camera.prototype.supr=THREE.Object3D.prototype; THREE.Camera.prototype.translate=function(a,c){this.matrix.rotateAxis(c);this.position.addSelf(c.multiplyScalar(a));this.target.position.addSelf(c.multiplyScalar(a))};THREE.Camera.prototype.updateProjectionMatrix=function(){this.projectionMatrix=THREE.Matrix4.makePerspective(this.fov,this.aspect,this.near,this.far)};THREE.Camera.prototype.updateMatrix=function(){this.update(undefined,!0)}; -THREE.Camera.prototype.update=function(a,c,d){if(this.useTarget){this.matrix.lookAt(this.position,this.target.position,this.up);this.matrix.setPosition(this.position)}a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);THREE.Matrix4.makeInvert(this.matrixWorld,this.matrixWorldInverse);c=!0;for(a=0;a 0.0 and (m.specular_color[0] > 0 or m.specular_color[1] > 0 or m.specular_color[2] > 0): - material['shading'] = "Phong" - else: - material['shading'] = "Lambert" + material["useVertexColors"] = m.THREE_useVertexColors + + # can't really use this reliably to tell apart Phong from Lambert + # as Blender defaults to non-zero specular color + #if m.specular_intensity > 0.0 and (m.specular_color[0] > 0 or m.specular_color[1] > 0 or m.specular_color[2] > 0): + # material['shading'] = "Phong" + #else: + # material['shading'] = "Lambert" return materials diff --git a/utils/exporters/blender/2.56/scripts/op/io_mesh_threejs/import_threejs.py b/utils/exporters/blender/2.56/scripts/op/io_mesh_threejs/import_threejs.py index c9fc124e9cc7ad6cab11e1c1271d9c53f2e4717e..42824c08cbce50241ea6a9dc98077484279a3b72 100644 --- a/utils/exporters/blender/2.56/scripts/op/io_mesh_threejs/import_threejs.py +++ b/utils/exporters/blender/2.56/scripts/op/io_mesh_threejs/import_threejs.py @@ -36,13 +36,83 @@ from io_utils import load_image, unpack_list, unpack_face_list # ##################################################### # Generators # ##################################################### +def setColor(c, t): + c.r = t[0] + c.g = t[1] + c.b = t[2] + +def create_texture(filename, modelpath): + name = filename + texture = bpy.data.textures.new(name, type='IMAGE') + + image = load_image(filename, modelpath) + has_data = False + + if image: + texture.image = image + has_data = image.has_data + + return texture + +def create_materials(data, modelpath): + materials = [] + materials_data = data.get("materials", []) + + for i, m in enumerate(materials_data): -def create_mesh_object(name, vertices, face_data, flipYZ, recalculate_normals): + name = m.get("DbgName", "material_%d" % i) + + colorAmbient = m.get("colorAmbient", None) + colorDiffuse = m.get("colorDiffuse", None) + colorSpecular = m.get("colorSpecular", None) + alpha = m.get("transparency", 1.0) + specular_hardness = m.get("specularCoef", 0) + + mapDiffuse = m.get("mapDiffuse", None) + mapLightmap = m.get("mapLightmap", None) + + useVertexColors = m.get("vertexColors", False) + + material = bpy.data.materials.new(name) + + material.THREE_useVertexColors = useVertexColors + + if colorDiffuse: + setColor(material.diffuse_color, colorDiffuse) + material.diffuse_intensity = 1.0 + + if colorSpecular: + setColor(material.specular_color, colorSpecular) + material.specular_intensity = 1.0 + + if alpha < 1.0: + material.alpha = alpha + material.use_transparency = True + + if specular_hardness: + material.specular_hardness = specular_hardness + + if mapDiffuse: + texture = create_texture(mapDiffuse, modelpath) + mtex = material.texture_slots.add() + mtex.texture = texture + mtex.texture_coords = 'UV' + mtex.use = True + mtex.use_map_color_diffuse = True + + material.active_texture = texture + + materials.append(material) + + return materials + +def create_mesh_object(name, vertices, materials, face_data, flipYZ, recalculate_normals): faces = face_data["faces"] vertexNormals = face_data["vertexNormals"] vertexColors = face_data["vertexColors"] vertexUVs = face_data["vertexUVs"] + faceMaterials = face_data["materials"] edges = [] @@ -88,14 +158,14 @@ def create_mesh_object(name, vertices, face_data, flipYZ, recalculate_normals): if flipYZ: tmp = y - y = z + y = -z z = tmp # flip normals (this make them look consistent with the original before export) - x = -x - y = -y - z = -z + #x = -x + #y = -y + #z = -z vi = me.faces[fi].vertices[j] @@ -146,8 +216,8 @@ def create_mesh_object(name, vertices, face_data, flipYZ, recalculate_normals): if layer[fi]: - face_uvs = me.uv_textures[li].data[fi] - face_uvs = face_uvs.uv1, face_uvs.uv2, face_uvs.uv3, face_uvs.uv4 + uv_face = me.uv_textures[li].data[fi] + face_uvs = uv_face.uv1, uv_face.uv2, uv_face.uv3, uv_face.uv4 for vi in range(len(layer[fi])): @@ -156,13 +226,39 @@ def create_mesh_object(name, vertices, face_data, flipYZ, recalculate_normals): face_uvs[vi].x = u face_uvs[vi].y = 1.0 - v + + active_texture = materials[faceMaterials[fi]].active_texture + + if active_texture: + uv_face.use_image = True + uv_face.image = active_texture.image + + + # Handle materials # 1 + + if face_data["hasMaterials"]: + + print("setting materials (mesh)") + + for m in materials: + + me.materials.append(m) + + print("setting materials (faces)") + + for fi in range(len(faces)): + + if faceMaterials[fi] >= 0: + + me.faces[fi].material_index = faceMaterials[fi] # Create a new object ob = bpy.data.objects.new(name, me) ob.data = me # link the mesh data to the object + scene = bpy.context.scene # get the current scene scene.objects.link(ob) # link the object into the scene @@ -187,7 +283,8 @@ def extract_faces(data): "hasVertexNormals" : False, "hasVertexUVs" : False, - "hasVertexColors" : False + "hasVertexColors" : False, + "hasMaterials" : False } faces = data.get("faces", []) @@ -228,6 +325,7 @@ def extract_faces(data): result["hasVertexUVs"] = result["hasVertexUVs"] or hasFaceVertexUv result["hasVertexNormals"] = result["hasVertexNormals"] or hasFaceVertexNormal result["hasVertexColors"] = result["hasVertexColors"] or hasFaceVertexColor + result["hasMaterials"] = result["hasMaterials"] or hasMaterial # vertices @@ -431,7 +529,10 @@ def extract_json_string(text): def get_name(filepath): return os.path.splitext(os.path.basename(filepath))[0] - + +def get_path(filepath): + return os.path.dirname(filepath) + # ##################################################### # Parser # ##################################################### @@ -464,7 +565,7 @@ def load(operator, context, filepath, option_flip_yz = True, recalculate_normals vertices = splitArray(data["vertices"], 3) if option_flip_yz: - vertices[:] = [(v[0], v[2], v[1]) for v in vertices] + vertices[:] = [(v[0], -v[2], v[1]) for v in vertices] # extract faces @@ -484,9 +585,13 @@ def load(operator, context, filepath, option_flip_yz = True, recalculate_normals print('\tbuilding geometry...\n\tfaces:%i, vertices:%i, vertex normals: %i, vertex uvs: %i, vertex colors: %i, materials: %i ...' % ( nfaces, nvertices, nnormals, nuvs, ncolors, nmaterials )) + # Create materials + + materials = create_materials(data, get_path(filepath)) + # Create new obj - create_mesh_object(get_name(filepath), vertices, face_data, option_flip_yz, recalculate_normals) + create_mesh_object(get_name(filepath), vertices, materials, face_data, option_flip_yz, recalculate_normals) scene = bpy.context.scene scene.update()