|
@@ -1,6 +1,6 @@
|
|
|
// ThreeWebGL.js r36 - http://github.com/mrdoob/three.js
|
|
|
var THREE=THREE||{};THREE.Color=function(a){this.setHex(a)};
|
|
|
-THREE.Color.prototype={autoUpdate:!0,setRGB:function(a,b,d){this.r=a;this.g=b;this.b=d;if(this.autoUpdate){this.updateHex();this.updateStyleString()}},setHSV:function(a,b,d){var e,g,l,m,s,o;if(d==0)e=g=l=0;else{m=Math.floor(a*6);s=a*6-m;a=d*(1-b);o=d*(1-b*s);b=d*(1-b*(1-s));switch(m){case 1:e=o;g=d;l=a;break;case 2:e=a;g=d;l=b;break;case 3:e=a;g=o;l=d;break;case 4:e=b;g=a;l=d;break;case 5:e=d;g=a;l=o;break;case 6:case 0:e=d;g=b;l=a}}this.r=e;this.g=g;this.b=l;if(this.autoUpdate){this.updateHex();
|
|
|
+THREE.Color.prototype={autoUpdate:!0,setRGB:function(a,b,d){this.r=a;this.g=b;this.b=d;if(this.autoUpdate){this.updateHex();this.updateStyleString()}},setHSV:function(a,b,d){var e,f,h,j,o,m;if(d==0)e=f=h=0;else{j=Math.floor(a*6);o=a*6-j;a=d*(1-b);m=d*(1-b*o);b=d*(1-b*(1-o));switch(j){case 1:e=m;f=d;h=a;break;case 2:e=a;f=d;h=b;break;case 3:e=a;f=m;h=d;break;case 4:e=b;f=a;h=d;break;case 5:e=d;f=a;h=m;break;case 6:case 0:e=d;f=b;h=a}}this.r=e;this.g=f;this.b=h;if(this.autoUpdate){this.updateHex();
|
|
|
this.updateStyleString()}},setHex:function(a){this.hex=~~a&16777215;if(this.autoUpdate){this.updateRGB();this.updateStyleString()}},updateHex:function(){this.hex=~~(this.r*255)<<16^~~(this.g*255)<<8^~~(this.b*255)},updateRGB:function(){this.r=(this.hex>>16&255)/255;this.g=(this.hex>>8&255)/255;this.b=(this.hex&255)/255},updateStyleString:function(){this.__styleString="rgb("+~~(this.r*255)+","+~~(this.g*255)+","+~~(this.b*255)+")"},clone:function(){return new THREE.Color(this.hex)}};
|
|
|
THREE.Vector2=function(a,b){this.set(a||0,b||0)};
|
|
|
THREE.Vector2.prototype={set:function(a,b){this.x=a;this.y=b;return this},copy:function(a){this.set(a.x,a.y);return this},addSelf:function(a){this.set(this.x+a.x,this.y+a.y);return this},add:function(a,b){this.set(a.x+b.x,a.y+b.y);return this},subSelf:function(a){this.set(this.x-a.x,this.y-a.y);return this},sub:function(a,b){this.set(a.x-b.x,a.y-b.y);return this},multiplyScalar:function(a){this.set(this.x*a,this.y*a);return this},negate:function(){this.set(-this.x,-this.y);return this},unit:function(){this.multiplyScalar(1/
|
|
@@ -12,57 +12,74 @@ 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,b,d,e){this.set(a||0,b||0,d||0,e||1)};
|
|
|
THREE.Vector4.prototype={set:function(a,b,d,e){this.x=a;this.y=b;this.z=d;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,d,e=a.objects,g=[];a=0;for(b=e.length;a<b;a++){d=e[a];d instanceof THREE.Mesh&&(g=g.concat(this.intersectObject(d)))}g.sort(function(l,m){return l.distance-m.distance});return g},intersectObject:function(a){function b(L,M,W,$){$=$.clone().subSelf(M);W=W.clone().subSelf(M);var ia=L.clone().subSelf(M);L=$.dot($);M=$.dot(W);$=$.dot(ia);var ea=W.dot(W);W=W.dot(ia);ia=1/(L*ea-M*M);ea=(ea*$-M*W)*ia;L=(L*W-M*$)*ia;return ea>0&&L>0&&ea+L<1}var d,e,g,l,
|
|
|
-m,s,o,v,B,z,D,E=a.geometry,H=E.vertices,I=[];d=0;for(e=E.faces.length;d<e;d++){g=E.faces[d];z=this.origin.clone();D=this.direction.clone();o=a.matrixWorld;l=o.multiplyVector3(H[g.a].position.clone());m=o.multiplyVector3(H[g.b].position.clone());s=o.multiplyVector3(H[g.c].position.clone());o=g instanceof THREE.Face4?o.multiplyVector3(H[g.d].position.clone()):null;v=a.matrixRotationWorld.multiplyVector3(g.normal.clone());B=D.dot(v);if(B<0){v=v.dot((new THREE.Vector3).sub(l,z))/B;z=z.addSelf(D.multiplyScalar(v));
|
|
|
-if(g instanceof THREE.Face3){if(b(z,l,m,s)){g={distance:this.origin.distanceTo(z),point:z,face:g,object:a};I.push(g)}}else if(g instanceof THREE.Face4&&(b(z,l,m,o)||b(z,m,s,o))){g={distance:this.origin.distanceTo(z),point:z,face:g,object:a};I.push(g)}}}return I}};
|
|
|
-THREE.Rectangle=function(){function a(){l=e-b;m=g-d}var b,d,e,g,l,m,s=!0;this.getX=function(){return b};this.getY=function(){return d};this.getWidth=function(){return l};this.getHeight=function(){return m};this.getLeft=function(){return b};this.getTop=function(){return d};this.getRight=function(){return e};this.getBottom=function(){return g};this.set=function(o,v,B,z){s=!1;b=o;d=v;e=B;g=z;a()};this.addPoint=function(o,v){if(s){s=!1;b=o;d=v;e=o;g=v}else{b=b<o?b:o;d=d<v?d:v;e=e>o?e:o;g=g>v?g:v}a()};
|
|
|
-this.add3Points=function(o,v,B,z,D,E){if(s){s=!1;b=o<B?o<D?o:D:B<D?B:D;d=v<z?v<E?v:E:z<E?z:E;e=o>B?o>D?o:D:B>D?B:D;g=v>z?v>E?v:E:z>E?z:E}else{b=o<B?o<D?o<b?o:b:D<b?D:b:B<D?B<b?B:b:D<b?D:b;d=v<z?v<E?v<d?v:d:E<d?E:d:z<E?z<d?z:d:E<d?E:d;e=o>B?o>D?o>e?o:e:D>e?D:e:B>D?B>e?B:e:D>e?D:e;g=v>z?v>E?v>g?v:g:E>g?E:g:z>E?z>g?z:g:E>g?E:g}a()};this.addRectangle=function(o){if(s){s=!1;b=o.getLeft();d=o.getTop();e=o.getRight();g=o.getBottom()}else{b=b<o.getLeft()?b:o.getLeft();d=d<o.getTop()?d:o.getTop();e=e>o.getRight()?
|
|
|
-e:o.getRight();g=g>o.getBottom()?g:o.getBottom()}a()};this.inflate=function(o){b-=o;d-=o;e+=o;g+=o;a()};this.minSelf=function(o){b=b>o.getLeft()?b:o.getLeft();d=d>o.getTop()?d:o.getTop();e=e<o.getRight()?e:o.getRight();g=g<o.getBottom()?g:o.getBottom();a()};this.instersects=function(o){return Math.min(e,o.getRight())-Math.max(b,o.getLeft())>=0&&Math.min(g,o.getBottom())-Math.max(d,o.getTop())>=0};this.empty=function(){s=!0;g=e=d=b=0;a()};this.isEmpty=function(){return s}};
|
|
|
+THREE.Ray.prototype={intersectScene:function(a){var b,d,e=a.objects,f=[];a=0;for(b=e.length;a<b;a++){d=e[a];d instanceof THREE.Mesh&&(f=f.concat(this.intersectObject(d)))}f.sort(function(h,j){return h.distance-j.distance});return f},intersectObject:function(a){function b(H,w,ga,U){U=U.clone().subSelf(w);ga=ga.clone().subSelf(w);var ha=H.clone().subSelf(w);H=U.dot(U);w=U.dot(ga);U=U.dot(ha);var fa=ga.dot(ga);ga=ga.dot(ha);ha=1/(H*fa-w*w);fa=(fa*U-w*ga)*ha;H=(H*ga-w*U)*ha;return fa>0&&H>0&&fa+H<1}var d,
|
|
|
+e,f,h,j,o,m,u,y,z,A,x=a.geometry,K=x.vertices,J=[];d=0;for(e=x.faces.length;d<e;d++){f=x.faces[d];z=this.origin.clone();A=this.direction.clone();m=a.matrixWorld;h=m.multiplyVector3(K[f.a].position.clone());j=m.multiplyVector3(K[f.b].position.clone());o=m.multiplyVector3(K[f.c].position.clone());m=f instanceof THREE.Face4?m.multiplyVector3(K[f.d].position.clone()):null;u=a.matrixRotationWorld.multiplyVector3(f.normal.clone());y=A.dot(u);if(y<0){u=u.dot((new THREE.Vector3).sub(h,z))/y;z=z.addSelf(A.multiplyScalar(u));
|
|
|
+if(f instanceof THREE.Face3){if(b(z,h,j,o)){f={distance:this.origin.distanceTo(z),point:z,face:f,object:a};J.push(f)}}else if(f instanceof THREE.Face4&&(b(z,h,j,m)||b(z,j,o,m))){f={distance:this.origin.distanceTo(z),point:z,face:f,object:a};J.push(f)}}}return J}};
|
|
|
+THREE.Rectangle=function(){function a(){h=e-b;j=f-d}var b,d,e,f,h,j,o=!0;this.getX=function(){return b};this.getY=function(){return d};this.getWidth=function(){return h};this.getHeight=function(){return j};this.getLeft=function(){return b};this.getTop=function(){return d};this.getRight=function(){return e};this.getBottom=function(){return f};this.set=function(m,u,y,z){o=!1;b=m;d=u;e=y;f=z;a()};this.addPoint=function(m,u){if(o){o=!1;b=m;d=u;e=m;f=u}else{b=b<m?b:m;d=d<u?d:u;e=e>m?e:m;f=f>u?f:u}a()};
|
|
|
+this.add3Points=function(m,u,y,z,A,x){if(o){o=!1;b=m<y?m<A?m:A:y<A?y:A;d=u<z?u<x?u:x:z<x?z:x;e=m>y?m>A?m:A:y>A?y:A;f=u>z?u>x?u:x:z>x?z:x}else{b=m<y?m<A?m<b?m:b:A<b?A:b:y<A?y<b?y:b:A<b?A:b;d=u<z?u<x?u<d?u:d:x<d?x:d:z<x?z<d?z:d:x<d?x:d;e=m>y?m>A?m>e?m:e:A>e?A:e:y>A?y>e?y:e:A>e?A:e;f=u>z?u>x?u>f?u:f:x>f?x:f:z>x?z>f?z:f:x>f?x:f}a()};this.addRectangle=function(m){if(o){o=!1;b=m.getLeft();d=m.getTop();e=m.getRight();f=m.getBottom()}else{b=b<m.getLeft()?b:m.getLeft();d=d<m.getTop()?d:m.getTop();e=e>m.getRight()?
|
|
|
+e:m.getRight();f=f>m.getBottom()?f:m.getBottom()}a()};this.inflate=function(m){b-=m;d-=m;e+=m;f+=m;a()};this.minSelf=function(m){b=b>m.getLeft()?b:m.getLeft();d=d>m.getTop()?d:m.getTop();e=e<m.getRight()?e:m.getRight();f=f<m.getBottom()?f:m.getBottom();a()};this.instersects=function(m){return Math.min(e,m.getRight())-Math.max(b,m.getLeft())>=0&&Math.min(f,m.getBottom())-Math.max(d,m.getTop())>=0};this.empty=function(){o=!0;f=e=d=b=0;a()};this.isEmpty=function(){return o}};
|
|
|
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,d,e,g,l,m,s,o,v,B,z,D,E,H,I){this.set(a||1,b||0,d||0,e||0,g||0,l||1,m||0,s||0,o||0,v||0,B||1,z||0,D||0,E||0,H||0,I||1);this.flat=Array(16);this.m33=new THREE.Matrix3};
|
|
|
-THREE.Matrix4.prototype={set:function(a,b,d,e,g,l,m,s,o,v,B,z,D,E,H,I){this.n11=a;this.n12=b;this.n13=d;this.n14=e;this.n21=g;this.n22=l;this.n23=m;this.n24=s;this.n31=o;this.n32=v;this.n33=B;this.n34=z;this.n41=D;this.n42=E;this.n43=H;this.n44=I;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,d){var e=THREE.Matrix4.__v1,
|
|
|
-g=THREE.Matrix4.__v2,l=THREE.Matrix4.__v3;l.sub(a,b).normalize();if(l.length()===0)l.z=1;e.cross(d,l).normalize();if(e.length()===0){l.x+=1.0E-4;e.cross(d,l).normalize()}g.cross(l,e).normalize();this.n11=e.x;this.n12=g.x;this.n13=l.x;this.n21=e.y;this.n22=g.y;this.n23=l.y;this.n31=e.z;this.n32=g.z;this.n33=l.z;return this},multiplyVector3:function(a){var b=a.x,d=a.y,e=a.z,g=1/(this.n41*b+this.n42*d+this.n43*e+this.n44);a.x=(this.n11*b+this.n12*d+this.n13*e+this.n14)*g;a.y=(this.n21*b+this.n22*d+this.n23*
|
|
|
-e+this.n24)*g;a.z=(this.n31*b+this.n32*d+this.n33*e+this.n34)*g;return a},multiplyVector4:function(a){var b=a.x,d=a.y,e=a.z,g=a.w;a.x=this.n11*b+this.n12*d+this.n13*e+this.n14*g;a.y=this.n21*b+this.n22*d+this.n23*e+this.n24*g;a.z=this.n31*b+this.n32*d+this.n33*e+this.n34*g;a.w=this.n41*b+this.n42*d+this.n43*e+this.n44*g;return a},rotateAxis:function(a){var b=a.x,d=a.y,e=a.z;a.x=b*this.n11+d*this.n12+e*this.n13;a.y=b*this.n21+d*this.n22+e*this.n23;a.z=b*this.n31+d*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 d=a.n11,e=a.n12,g=a.n13,l=a.n14,m=a.n21,s=a.n22,o=a.n23,v=a.n24,B=a.n31,z=a.n32,D=a.n33,E=a.n34,H=a.n41,I=a.n42,L=a.n43,M=a.n44,W=b.n11,$=b.n12,ia=b.n13,ea=b.n14,aa=b.n21,ja=b.n22,
|
|
|
-c=b.n23,ra=b.n24,pa=b.n31,ya=b.n32,sa=b.n33,ta=b.n34;this.n11=d*W+e*aa+g*pa;this.n12=d*$+e*ja+g*ya;this.n13=d*ia+e*c+g*sa;this.n14=d*ea+e*ra+g*ta+l;this.n21=m*W+s*aa+o*pa;this.n22=m*$+s*ja+o*ya;this.n23=m*ia+s*c+o*sa;this.n24=m*ea+s*ra+o*ta+v;this.n31=B*W+z*aa+D*pa;this.n32=B*$+z*ja+D*ya;this.n33=B*ia+z*c+D*sa;this.n34=B*ea+z*ra+D*ta+E;this.n41=H*W+I*aa+L*pa;this.n42=H*$+I*ja+L*ya;this.n43=H*ia+I*c+L*sa;this.n44=H*ea+I*ra+L*ta+M;return this},multiplyToArray:function(a,b,d){this.multiply(a,b);d[0]=
|
|
|
-this.n11;d[1]=this.n21;d[2]=this.n31;d[3]=this.n41;d[4]=this.n12;d[5]=this.n22;d[6]=this.n32;d[7]=this.n42;d[8]=this.n13;d[9]=this.n23;d[10]=this.n33;d[11]=this.n43;d[12]=this.n14;d[13]=this.n24;d[14]=this.n34;d[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,d=this.n13,e=this.n14,g=this.n21,l=this.n22,m=this.n23,s=this.n24,o=this.n31,v=this.n32,B=this.n33,z=this.n34,D=this.n41,E=this.n42,H=this.n43,I=this.n44;return e*m*v*D-d*s*v*D-e*l*B*D+b*s*B*D+d*l*z*D-b*m*z*D-e*m*o*E+d*s*o*E+e*g*B*E-a*s*B*E-d*g*z*E+a*m*z*E+e*l*o*H-b*s*o*H-e*g*v*H+a*s*v*H+b*g*z*H-a*l*z*H-d*l*o*I+b*m*o*I+d*g*v*I-a*m*v*I-b*g*B*I+a*l*B*I},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]=
|
|
|
+THREE.Matrix4=function(a,b,d,e,f,h,j,o,m,u,y,z,A,x,K,J){this.set(a||1,b||0,d||0,e||0,f||0,h||1,j||0,o||0,m||0,u||0,y||1,z||0,A||0,x||0,K||0,J||1);this.flat=Array(16);this.m33=new THREE.Matrix3};
|
|
|
+THREE.Matrix4.prototype={set:function(a,b,d,e,f,h,j,o,m,u,y,z,A,x,K,J){this.n11=a;this.n12=b;this.n13=d;this.n14=e;this.n21=f;this.n22=h;this.n23=j;this.n24=o;this.n31=m;this.n32=u;this.n33=y;this.n34=z;this.n41=A;this.n42=x;this.n43=K;this.n44=J;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,d){var e=THREE.Matrix4.__v1,
|
|
|
+f=THREE.Matrix4.__v2,h=THREE.Matrix4.__v3;h.sub(a,b).normalize();if(h.length()===0)h.z=1;e.cross(d,h).normalize();if(e.length()===0){h.x+=1.0E-4;e.cross(d,h).normalize()}f.cross(h,e).normalize();this.n11=e.x;this.n12=f.x;this.n13=h.x;this.n21=e.y;this.n22=f.y;this.n23=h.y;this.n31=e.z;this.n32=f.z;this.n33=h.z;return this},multiplyVector3:function(a){var b=a.x,d=a.y,e=a.z,f=1/(this.n41*b+this.n42*d+this.n43*e+this.n44);a.x=(this.n11*b+this.n12*d+this.n13*e+this.n14)*f;a.y=(this.n21*b+this.n22*d+this.n23*
|
|
|
+e+this.n24)*f;a.z=(this.n31*b+this.n32*d+this.n33*e+this.n34)*f;return a},multiplyVector4:function(a){var b=a.x,d=a.y,e=a.z,f=a.w;a.x=this.n11*b+this.n12*d+this.n13*e+this.n14*f;a.y=this.n21*b+this.n22*d+this.n23*e+this.n24*f;a.z=this.n31*b+this.n32*d+this.n33*e+this.n34*f;a.w=this.n41*b+this.n42*d+this.n43*e+this.n44*f;return a},rotateAxis:function(a){var b=a.x,d=a.y,e=a.z;a.x=b*this.n11+d*this.n12+e*this.n13;a.y=b*this.n21+d*this.n22+e*this.n23;a.z=b*this.n31+d*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 d=a.n11,e=a.n12,f=a.n13,h=a.n14,j=a.n21,o=a.n22,m=a.n23,u=a.n24,y=a.n31,z=a.n32,A=a.n33,x=a.n34,K=a.n41,J=a.n42,H=a.n43,w=a.n44,ga=b.n11,U=b.n12,ha=b.n13,fa=b.n14,ia=b.n21,M=b.n22,
|
|
|
+c=b.n23,ja=b.n24,W=b.n31,la=b.n32,Z=b.n33,R=b.n34;this.n11=d*ga+e*ia+f*W;this.n12=d*U+e*M+f*la;this.n13=d*ha+e*c+f*Z;this.n14=d*fa+e*ja+f*R+h;this.n21=j*ga+o*ia+m*W;this.n22=j*U+o*M+m*la;this.n23=j*ha+o*c+m*Z;this.n24=j*fa+o*ja+m*R+u;this.n31=y*ga+z*ia+A*W;this.n32=y*U+z*M+A*la;this.n33=y*ha+z*c+A*Z;this.n34=y*fa+z*ja+A*R+x;this.n41=K*ga+J*ia+H*W;this.n42=K*U+J*M+H*la;this.n43=K*ha+J*c+H*Z;this.n44=K*fa+J*ja+H*R+w;return this},multiplyToArray:function(a,b,d){this.multiply(a,b);d[0]=this.n11;d[1]=
|
|
|
+this.n21;d[2]=this.n31;d[3]=this.n41;d[4]=this.n12;d[5]=this.n22;d[6]=this.n32;d[7]=this.n42;d[8]=this.n13;d[9]=this.n23;d[10]=this.n33;d[11]=this.n43;d[12]=this.n14;d[13]=this.n24;d[14]=this.n34;d[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,d=this.n13,e=this.n14,f=this.n21,h=this.n22,j=this.n23,o=this.n24,m=this.n31,u=this.n32,y=this.n33,z=this.n34,A=this.n41,x=this.n42,K=this.n43,J=this.n44;return e*j*u*A-d*o*u*A-e*h*y*A+b*o*y*A+d*h*z*A-b*j*z*A-e*j*m*x+d*o*m*x+e*f*y*x-a*o*y*x-d*f*z*x+a*j*z*x+e*h*m*K-b*o*m*K-e*f*u*K+a*o*u*K+b*f*z*K-a*h*z*K-d*h*m*J+b*j*m*J+d*f*u*J-a*j*u*J-b*f*y*J+a*h*y*J},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,d){this.set(1,0,0,a,0,1,0,b,0,0,1,d,0,0,
|
|
|
-0,1);return this},setScale:function(a,b,d){this.set(a,0,0,0,0,b,0,0,0,0,d,0,0,0,0,1);return this},setRotationX:function(a){var b=Math.cos(a);a=Math.sin(a);this.set(1,0,0,0,0,b,-a,0,0,a,b,0,0,0,0,1);return this},setRotationY:function(a){var b=Math.cos(a);a=Math.sin(a);this.set(b,0,a,0,0,1,0,0,-a,0,b,0,0,0,0,1);return this},setRotationZ:function(a){var b=Math.cos(a);a=Math.sin(a);this.set(b,-a,0,0,a,b,0,0,0,0,1,0,0,0,0,1);return this},setRotationAxis:function(a,b){var d=Math.cos(b),e=Math.sin(b),g=
|
|
|
-1-d,l=a.x,m=a.y,s=a.z,o=g*l,v=g*m;this.set(o*l+d,o*m-e*s,o*s+e*m,0,o*m+e*s,v*m+d,v*s-e*l,0,o*s-e*m,v*s+e*l,g*s*s+d,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,d=a.y,e=a.z;a=Math.cos(b);b=Math.sin(b);var g=Math.cos(d);d=Math.sin(d);var l=Math.cos(e);e=Math.sin(e);var m=a*d,s=b*d;this.n11=g*l;this.n12=-g*e;this.n13=d;this.n21=s*l+a*e;this.n22=-s*e+a*l;this.n23=-b*g;this.n31=-m*l+b*e;this.n32=m*e+b*l;this.n33=
|
|
|
-a*g;return this},setRotationFromQuaternion:function(a){var b=a.x,d=a.y,e=a.z,g=a.w,l=b+b,m=d+d,s=e+e;a=b*l;var o=b*m;b*=s;var v=d*m;d*=s;e*=s;l*=g;m*=g;g*=s;this.n11=1-(v+e);this.n12=o-g;this.n13=b+m;this.n21=o+g;this.n22=1-(a+e);this.n23=d-l;this.n31=b-m;this.n32=d+l;this.n33=1-(a+v);return this},scale:function(a){var b=a.x,d=a.y;a=a.z;this.n11*=b;this.n12*=d;this.n13*=a;this.n21*=b;this.n22*=d;this.n23*=a;this.n31*=b;this.n32*=d;this.n33*=a;this.n41*=b;this.n42*=d;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 d=1/b.x,e=1/b.y,g=1/b.z;this.n11=a.n11*d;this.n21=a.n21*d;this.n31=a.n31*d;this.n12=a.n12*e;this.n22=a.n22*e;this.n32=a.n32*e;this.n13=a.n13*g;this.n23=a.n23*g;this.n33=a.n33*g}};
|
|
|
-THREE.Matrix4.makeInvert=function(a,b){var d=a.n11,e=a.n12,g=a.n13,l=a.n14,m=a.n21,s=a.n22,o=a.n23,v=a.n24,B=a.n31,z=a.n32,D=a.n33,E=a.n34,H=a.n41,I=a.n42,L=a.n43,M=a.n44;b===undefined&&(b=new THREE.Matrix4);b.n11=o*E*I-v*D*I+v*z*L-s*E*L-o*z*M+s*D*M;b.n12=l*D*I-g*E*I-l*z*L+e*E*L+g*z*M-e*D*M;b.n13=g*v*I-l*o*I+l*s*L-e*v*L-g*s*M+e*o*M;b.n14=l*o*z-g*v*z-l*s*D+e*v*D+g*s*E-e*o*E;b.n21=v*D*H-o*E*H-v*B*L+m*E*L+o*B*M-m*D*M;b.n22=g*E*H-l*D*H+l*B*L-d*E*L-g*B*M+d*D*M;b.n23=l*o*H-g*v*H-l*m*L+d*v*L+g*m*M-d*o*M;
|
|
|
-b.n24=g*v*B-l*o*B+l*m*D-d*v*D-g*m*E+d*o*E;b.n31=s*E*H-v*z*H+v*B*I-m*E*I-s*B*M+m*z*M;b.n32=l*z*H-e*E*H-l*B*I+d*E*I+e*B*M-d*z*M;b.n33=g*v*H-l*s*H+l*m*I-d*v*I-e*m*M+d*s*M;b.n34=l*s*B-e*v*B-l*m*z+d*v*z+e*m*E-d*s*E;b.n41=o*z*H-s*D*H-o*B*I+m*D*I+s*B*L-m*z*L;b.n42=e*D*H-g*z*H+g*B*I-d*D*I-e*B*L+d*z*L;b.n43=g*s*H-e*o*H-g*m*I+d*o*I+e*m*L-d*s*L;b.n44=e*o*B-g*s*B+g*m*z-d*o*z-e*m*D+d*s*D;b.multiplyScalar(1/a.determinant());return b};
|
|
|
-THREE.Matrix4.makeInvert3x3=function(a){var b=a.m33,d=b.m,e=a.n33*a.n22-a.n32*a.n23,g=-a.n33*a.n21+a.n31*a.n23,l=a.n32*a.n21-a.n31*a.n22,m=-a.n33*a.n12+a.n32*a.n13,s=a.n33*a.n11-a.n31*a.n13,o=-a.n32*a.n11+a.n31*a.n12,v=a.n23*a.n12-a.n22*a.n13,B=-a.n23*a.n11+a.n21*a.n13,z=a.n22*a.n11-a.n21*a.n12;a=a.n11*e+a.n21*m+a.n31*v;if(a==0)throw"matrix not invertible";a=1/a;d[0]=a*e;d[1]=a*g;d[2]=a*l;d[3]=a*m;d[4]=a*s;d[5]=a*o;d[6]=a*v;d[7]=a*B;d[8]=a*z;return b};
|
|
|
-THREE.Matrix4.makeFrustum=function(a,b,d,e,g,l){var m;m=new THREE.Matrix4;m.n11=2*g/(b-a);m.n12=0;m.n13=(b+a)/(b-a);m.n14=0;m.n21=0;m.n22=2*g/(e-d);m.n23=(e+d)/(e-d);m.n24=0;m.n31=0;m.n32=0;m.n33=-(l+g)/(l-g);m.n34=-2*l*g/(l-g);m.n41=0;m.n42=0;m.n43=-1;m.n44=0;return m};THREE.Matrix4.makePerspective=function(a,b,d,e){var g;a=d*Math.tan(a*Math.PI/360);g=-a;return THREE.Matrix4.makeFrustum(g*b,a*b,g,a,d,e)};
|
|
|
-THREE.Matrix4.makeOrtho=function(a,b,d,e,g,l){var m,s,o,v;m=new THREE.Matrix4;s=b-a;o=d-e;v=l-g;m.n11=2/s;m.n12=0;m.n13=0;m.n14=-((b+a)/s);m.n21=0;m.n22=2/o;m.n23=0;m.n24=-((d+e)/o);m.n31=0;m.n32=0;m.n33=-2/v;m.n34=-((l+g)/v);m.n41=0;m.n42=0;m.n43=0;m.n44=1;return m};THREE.Matrix4.__v1=new THREE.Vector3;THREE.Matrix4.__v2=new THREE.Vector3;THREE.Matrix4.__v3=new THREE.Vector3;
|
|
|
+0,1);return this},setScale:function(a,b,d){this.set(a,0,0,0,0,b,0,0,0,0,d,0,0,0,0,1);return this},setRotationX:function(a){var b=Math.cos(a);a=Math.sin(a);this.set(1,0,0,0,0,b,-a,0,0,a,b,0,0,0,0,1);return this},setRotationY:function(a){var b=Math.cos(a);a=Math.sin(a);this.set(b,0,a,0,0,1,0,0,-a,0,b,0,0,0,0,1);return this},setRotationZ:function(a){var b=Math.cos(a);a=Math.sin(a);this.set(b,-a,0,0,a,b,0,0,0,0,1,0,0,0,0,1);return this},setRotationAxis:function(a,b){var d=Math.cos(b),e=Math.sin(b),f=
|
|
|
+1-d,h=a.x,j=a.y,o=a.z,m=f*h,u=f*j;this.set(m*h+d,m*j-e*o,m*o+e*j,0,m*j+e*o,u*j+d,u*o-e*h,0,m*o-e*j,u*o+e*h,f*o*o+d,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,d=a.y,e=a.z;a=Math.cos(b);b=Math.sin(b);var f=Math.cos(d);d=Math.sin(d);var h=Math.cos(e);e=Math.sin(e);var j=a*d,o=b*d;this.n11=f*h;this.n12=-f*e;this.n13=d;this.n21=o*h+a*e;this.n22=-o*e+a*h;this.n23=-b*f;this.n31=-j*h+b*e;this.n32=j*e+b*h;this.n33=
|
|
|
+a*f;return this},setRotationFromQuaternion:function(a){var b=a.x,d=a.y,e=a.z,f=a.w,h=b+b,j=d+d,o=e+e;a=b*h;var m=b*j;b*=o;var u=d*j;d*=o;e*=o;h*=f;j*=f;f*=o;this.n11=1-(u+e);this.n12=m-f;this.n13=b+j;this.n21=m+f;this.n22=1-(a+e);this.n23=d-h;this.n31=b-j;this.n32=d+h;this.n33=1-(a+u);return this},scale:function(a){var b=a.x,d=a.y;a=a.z;this.n11*=b;this.n12*=d;this.n13*=a;this.n21*=b;this.n22*=d;this.n23*=a;this.n31*=b;this.n32*=d;this.n33*=a;this.n41*=b;this.n42*=d;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 d=1/b.x,e=1/b.y,f=1/b.z;this.n11=a.n11*d;this.n21=a.n21*d;this.n31=a.n31*d;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,b){var d=a.n11,e=a.n12,f=a.n13,h=a.n14,j=a.n21,o=a.n22,m=a.n23,u=a.n24,y=a.n31,z=a.n32,A=a.n33,x=a.n34,K=a.n41,J=a.n42,H=a.n43,w=a.n44;b===undefined&&(b=new THREE.Matrix4);b.n11=m*x*J-u*A*J+u*z*H-o*x*H-m*z*w+o*A*w;b.n12=h*A*J-f*x*J-h*z*H+e*x*H+f*z*w-e*A*w;b.n13=f*u*J-h*m*J+h*o*H-e*u*H-f*o*w+e*m*w;b.n14=h*m*z-f*u*z-h*o*A+e*u*A+f*o*x-e*m*x;b.n21=u*A*K-m*x*K-u*y*H+j*x*H+m*y*w-j*A*w;b.n22=f*x*K-h*A*K+h*y*H-d*x*H-f*y*w+d*A*w;b.n23=h*m*K-f*u*K-h*j*H+d*u*H+f*j*w-d*m*w;
|
|
|
+b.n24=f*u*y-h*m*y+h*j*A-d*u*A-f*j*x+d*m*x;b.n31=o*x*K-u*z*K+u*y*J-j*x*J-o*y*w+j*z*w;b.n32=h*z*K-e*x*K-h*y*J+d*x*J+e*y*w-d*z*w;b.n33=f*u*K-h*o*K+h*j*J-d*u*J-e*j*w+d*o*w;b.n34=h*o*y-e*u*y-h*j*z+d*u*z+e*j*x-d*o*x;b.n41=m*z*K-o*A*K-m*y*J+j*A*J+o*y*H-j*z*H;b.n42=e*A*K-f*z*K+f*y*J-d*A*J-e*y*H+d*z*H;b.n43=f*o*K-e*m*K-f*j*J+d*m*J+e*j*H-d*o*H;b.n44=e*m*y-f*o*y+f*j*z-d*m*z-e*j*A+d*o*A;b.multiplyScalar(1/a.determinant());return b};
|
|
|
+THREE.Matrix4.makeInvert3x3=function(a){var b=a.m33,d=b.m,e=a.n33*a.n22-a.n32*a.n23,f=-a.n33*a.n21+a.n31*a.n23,h=a.n32*a.n21-a.n31*a.n22,j=-a.n33*a.n12+a.n32*a.n13,o=a.n33*a.n11-a.n31*a.n13,m=-a.n32*a.n11+a.n31*a.n12,u=a.n23*a.n12-a.n22*a.n13,y=-a.n23*a.n11+a.n21*a.n13,z=a.n22*a.n11-a.n21*a.n12;a=a.n11*e+a.n21*j+a.n31*u;if(a==0)throw"matrix not invertible";a=1/a;d[0]=a*e;d[1]=a*f;d[2]=a*h;d[3]=a*j;d[4]=a*o;d[5]=a*m;d[6]=a*u;d[7]=a*y;d[8]=a*z;return b};
|
|
|
+THREE.Matrix4.makeFrustum=function(a,b,d,e,f,h){var j;j=new THREE.Matrix4;j.n11=2*f/(b-a);j.n12=0;j.n13=(b+a)/(b-a);j.n14=0;j.n21=0;j.n22=2*f/(e-d);j.n23=(e+d)/(e-d);j.n24=0;j.n31=0;j.n32=0;j.n33=-(h+f)/(h-f);j.n34=-2*h*f/(h-f);j.n41=0;j.n42=0;j.n43=-1;j.n44=0;return j};THREE.Matrix4.makePerspective=function(a,b,d,e){var f;a=d*Math.tan(a*Math.PI/360);f=-a;return THREE.Matrix4.makeFrustum(f*b,a*b,f,a,d,e)};
|
|
|
+THREE.Matrix4.makeOrtho=function(a,b,d,e,f,h){var j,o,m,u;j=new THREE.Matrix4;o=b-a;m=d-e;u=h-f;j.n11=2/o;j.n12=0;j.n13=0;j.n14=-((b+a)/o);j.n21=0;j.n22=2/m;j.n23=0;j.n24=-((d+e)/m);j.n31=0;j.n32=0;j.n33=-2/u;j.n34=-((h+f)/u);j.n41=0;j.n42=0;j.n43=0;j.n44=1;return j};THREE.Matrix4.__v1=new THREE.Vector3;THREE.Matrix4.__v2=new THREE.Vector3;THREE.Matrix4.__v3=new THREE.Vector3;
|
|
|
THREE.Object3D=function(){this.parent=undefined;this.children=[];this.up=new THREE.Vector3(0,1,0);this.position=new THREE.Vector3;this.rotation=new THREE.Vector3;this.scale=new THREE.Vector3(1,1,1);this.rotationAutoUpdate=!0;this.matrix=new THREE.Matrix4;this.matrixWorld=new THREE.Matrix4;this.matrixRotationWorld=new THREE.Matrix4;this.matrixAutoUpdate=!0;this.matrixWorldNeedsUpdate=!0;this.quaternion=new THREE.Quaternion;this.useQuaternion=!1;this.boundRadius=0;this.boundRadiusScale=1;this.visible=
|
|
|
!0;this._vector=new THREE.Vector3};
|
|
|
THREE.Object3D.prototype={translate:function(a,b){this.matrix.rotateAxis(b);this.position.addSelf(b.multiplyScalar(a))},translateX:function(a){this.translate(a,this._vector.set(1,0,0))},translateY:function(a){this.translate(a,this._vector.set(0,1,0))},translateZ:function(a){this.translate(a,this._vector.set(0,0,1))},lookAt:function(a){this.matrix.lookAt(this.position,a,this.up);this.rotationAutoUpdate&&this.rotation.setRotationFromMatrix(this.matrix)},addChild:function(a){if(this.children.indexOf(a)===-1){a.parent!==
|
|
|
undefined&&a.parent.removeChild(a);a.parent=this;this.children.push(a);for(var b=this;b instanceof THREE.Scene===!1&&b!==undefined;)b=b.parent;b!==undefined&&b.addChildRecurse(a)}},removeChild:function(a){var b=this.children.indexOf(a);if(b!==-1){a.parent=undefined;this.children.splice(b,1)}},updateMatrix:function(){this.matrix.setPosition(this.position);this.useQuaternion?this.matrix.setRotationFromQuaternion(this.quaternion):this.matrix.setRotationFromEuler(this.rotation);if(this.scale.x!==1||this.scale.y!==
|
|
|
1||this.scale.z!==1){this.matrix.scale(this.scale);this.boundRadiusScale=Math.max(this.scale.x,Math.max(this.scale.y,this.scale.z))}this.matrixWorldNeedsUpdate=!0},update:function(a,b,d){if(this.visible){this.matrixAutoUpdate&&this.updateMatrix();if(this.matrixWorldNeedsUpdate||b){a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);this.matrixRotationWorld.extractRotation(this.matrixWorld,this.scale);this.matrixWorldNeedsUpdate=!1;b=!0}a=0;for(var e=this.children.length;a<
|
|
|
e;a++)this.children[a].update(this.matrixWorld,b,d)}}};THREE.Quaternion=function(a,b,d,e){this.set(a||0,b||0,d||0,e!==undefined?e:1)};
|
|
|
-THREE.Quaternion.prototype={set:function(a,b,d,e){this.x=a;this.y=b;this.z=d;this.w=e;return this},setFromEuler:function(a){var b=0.5*Math.PI/360,d=a.x*b,e=a.y*b,g=a.z*b;a=Math.cos(e);e=Math.sin(e);b=Math.cos(-g);g=Math.sin(-g);var l=Math.cos(d);d=Math.sin(d);var m=a*b,s=e*g;this.w=m*l-s*d;this.x=m*d+s*l;this.y=e*b*l+a*g*d;this.z=a*g*l-e*b*d;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,d=this.y,e=this.z,g=this.w,l=a.x,m=a.y,s=a.z;a=a.w;this.x=b*a+g*l+d*s-e*m;this.y=d*a+g*m+e*l-b*s;this.z=e*a+g*s+b*m-d*l;this.w=g*a-b*l-d*m-e*s;return this},
|
|
|
-multiplyVector3:function(a,b){b||(b=a);var d=a.x,e=a.y,g=a.z,l=this.x,m=this.y,s=this.z,o=this.w,v=o*d+m*g-s*e,B=o*e+s*d-l*g,z=o*g+l*e-m*d;d=-l*d-m*e-s*g;b.x=v*o+d*-l+B*-s-z*-m;b.y=B*o+d*-m+z*-l-v*-s;b.z=z*o+d*-s+v*-m-B*-l;return b}};
|
|
|
-THREE.Quaternion.slerp=function(a,b,d,e){var g=a.w*b.w+a.x*b.x+a.y*b.y+a.z*b.z;if(Math.abs(g)>=1){d.w=a.w;d.x=a.x;d.y=a.y;d.z=a.z;return d}var l=Math.acos(g),m=Math.sqrt(1-g*g);if(Math.abs(m)<0.0010){d.w=0.5*(a.w+b.w);d.x=0.5*(a.x+b.x);d.y=0.5*(a.y+b.y);d.z=0.5*(a.z+b.z);return d}g=Math.sin((1-e)*l)/m;e=Math.sin(e*l)/m;d.w=a.w*g+b.w*e;d.x=a.x*g+b.x*e;d.y=a.y*g+b.y*e;d.z=a.z*g+b.z*e;return d};
|
|
|
+THREE.Quaternion.prototype={set:function(a,b,d,e){this.x=a;this.y=b;this.z=d;this.w=e;return this},setFromEuler:function(a){var b=0.5*Math.PI/360,d=a.x*b,e=a.y*b,f=a.z*b;a=Math.cos(e);e=Math.sin(e);b=Math.cos(-f);f=Math.sin(-f);var h=Math.cos(d);d=Math.sin(d);var j=a*b,o=e*f;this.w=j*h-o*d;this.x=j*d+o*h;this.y=e*b*h+a*f*d;this.z=a*f*h-e*b*d;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,d=this.y,e=this.z,f=this.w,h=a.x,j=a.y,o=a.z;a=a.w;this.x=b*a+f*h+d*o-e*j;this.y=d*a+f*j+e*h-b*o;this.z=e*a+f*o+b*j-d*h;this.w=f*a-b*h-d*j-e*o;return this},
|
|
|
+multiplyVector3:function(a,b){b||(b=a);var d=a.x,e=a.y,f=a.z,h=this.x,j=this.y,o=this.z,m=this.w,u=m*d+j*f-o*e,y=m*e+o*d-h*f,z=m*f+h*e-j*d;d=-h*d-j*e-o*f;b.x=u*m+d*-h+y*-o-z*-j;b.y=y*m+d*-j+z*-h-u*-o;b.z=z*m+d*-o+u*-j-y*-h;return b}};
|
|
|
+THREE.Quaternion.slerp=function(a,b,d,e){var f=a.w*b.w+a.x*b.x+a.y*b.y+a.z*b.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),j=Math.sqrt(1-f*f);if(Math.abs(j)<0.001){d.w=0.5*(a.w+b.w);d.x=0.5*(a.x+b.x);d.y=0.5*(a.y+b.y);d.z=0.5*(a.z+b.z);return d}f=Math.sin((1-e)*h)/j;e=Math.sin(e*h)/j;d.w=a.w*f+b.w*e;d.x=a.x*f+b.x*e;d.y=a.y*f+b.y*e;d.z=a.z*f+b.z*e;return d};
|
|
|
THREE.Vertex=function(a,b){this.position=a||new THREE.Vector3;this.positionWorld=new THREE.Vector3;this.positionScreen=new THREE.Vector4;this.normal=b||new THREE.Vector3;this.normalWorld=new THREE.Vector3;this.normalScreen=new THREE.Vector3;this.tangent=new THREE.Vector4;this.__visible=!0};
|
|
|
-THREE.Face3=function(a,b,d,e,g){this.a=a;this.b=b;this.c=d;this.centroid=new THREE.Vector3;this.normal=e instanceof THREE.Vector3?e:new THREE.Vector3;this.vertexNormals=e instanceof Array?e:[];this.materials=g instanceof Array?g:[g]};THREE.Face4=function(a,b,d,e,g,l){this.a=a;this.b=b;this.c=d;this.d=e;this.centroid=new THREE.Vector3;this.normal=g instanceof THREE.Vector3?g:new THREE.Vector3;this.vertexNormals=g instanceof Array?g:[];this.materials=l instanceof Array?l:[l]};
|
|
|
+THREE.Face3=function(a,b,d,e,f){this.a=a;this.b=b;this.c=d;this.centroid=new THREE.Vector3;this.normal=e instanceof THREE.Vector3?e:new THREE.Vector3;this.vertexNormals=e instanceof Array?e:[];this.materials=f instanceof Array?f:[f]};THREE.Face4=function(a,b,d,e,f,h){this.a=a;this.b=b;this.c=d;this.d=e;this.centroid=new THREE.Vector3;this.normal=f instanceof THREE.Vector3?f:new THREE.Vector3;this.vertexNormals=f instanceof Array?f:[];this.materials=h instanceof Array?h:[h]};
|
|
|
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.faces=[];this.uvs=[];this.uvs2=[];this.colors=[];this.morphTargets=[];this.skinWeights=[];this.skinIndices=[];this.boundingSphere=this.boundingBox=null;this.hasTangents=!1};
|
|
|
THREE.Geometry.prototype={computeCentroids:function(){var a,b,d;a=0;for(b=this.faces.length;a<b;a++){d=this.faces[a];d.centroid.set(0,0,0);if(d instanceof THREE.Face3){d.centroid.addSelf(this.vertices[d.a].position);d.centroid.addSelf(this.vertices[d.b].position);d.centroid.addSelf(this.vertices[d.c].position);d.centroid.divideScalar(3)}else if(d instanceof THREE.Face4){d.centroid.addSelf(this.vertices[d.a].position);d.centroid.addSelf(this.vertices[d.b].position);d.centroid.addSelf(this.vertices[d.c].position);
|
|
|
-d.centroid.addSelf(this.vertices[d.d].position);d.centroid.divideScalar(4)}}},computeFaceNormals:function(a){var b,d,e,g,l,m,s=new THREE.Vector3,o=new THREE.Vector3;e=0;for(g=this.vertices.length;e<g;e++){l=this.vertices[e];l.normal.set(0,0,0)}e=0;for(g=this.faces.length;e<g;e++){l=this.faces[e];if(a&&l.vertexNormals.length){s.set(0,0,0);b=0;for(d=l.vertexNormals.length;b<d;b++)s.addSelf(l.vertexNormals[b]);s.divideScalar(3)}else{b=this.vertices[l.a];d=this.vertices[l.b];m=this.vertices[l.c];s.sub(m.position,
|
|
|
-d.position);o.sub(b.position,d.position);s.crossSelf(o)}s.isZero()||s.normalize();l.normal.copy(s)}},computeVertexNormals:function(){var a,b,d,e;if(this.__tmpVertices==undefined){e=this.__tmpVertices=Array(this.vertices.length);a=0;for(b=this.vertices.length;a<b;a++)e[a]=new THREE.Vector3;a=0;for(b=this.faces.length;a<b;a++){d=this.faces[a];if(d instanceof THREE.Face3)d.vertexNormals=[new THREE.Vector3,new THREE.Vector3,new THREE.Vector3];else if(d instanceof THREE.Face4)d.vertexNormals=[new THREE.Vector3,
|
|
|
+d.centroid.addSelf(this.vertices[d.d].position);d.centroid.divideScalar(4)}}},computeFaceNormals:function(a){var b,d,e,f,h,j,o=new THREE.Vector3,m=new THREE.Vector3;e=0;for(f=this.vertices.length;e<f;e++){h=this.vertices[e];h.normal.set(0,0,0)}e=0;for(f=this.faces.length;e<f;e++){h=this.faces[e];if(a&&h.vertexNormals.length){o.set(0,0,0);b=0;for(d=h.vertexNormals.length;b<d;b++)o.addSelf(h.vertexNormals[b]);o.divideScalar(3)}else{b=this.vertices[h.a];d=this.vertices[h.b];j=this.vertices[h.c];o.sub(j.position,
|
|
|
+d.position);m.sub(b.position,d.position);o.crossSelf(m)}o.isZero()||o.normalize();h.normal.copy(o)}},computeVertexNormals:function(){var a,b,d,e;if(this.__tmpVertices==undefined){e=this.__tmpVertices=Array(this.vertices.length);a=0;for(b=this.vertices.length;a<b;a++)e[a]=new THREE.Vector3;a=0;for(b=this.faces.length;a<b;a++){d=this.faces[a];if(d instanceof THREE.Face3)d.vertexNormals=[new THREE.Vector3,new THREE.Vector3,new THREE.Vector3];else if(d instanceof THREE.Face4)d.vertexNormals=[new THREE.Vector3,
|
|
|
new THREE.Vector3,new THREE.Vector3,new THREE.Vector3]}}else{e=this.__tmpVertices;a=0;for(b=this.vertices.length;a<b;a++)e[a].set(0,0,0)}a=0;for(b=this.faces.length;a<b;a++){d=this.faces[a];if(d instanceof THREE.Face3){e[d.a].addSelf(d.normal);e[d.b].addSelf(d.normal);e[d.c].addSelf(d.normal)}else if(d instanceof THREE.Face4){e[d.a].addSelf(d.normal);e[d.b].addSelf(d.normal);e[d.c].addSelf(d.normal);e[d.d].addSelf(d.normal)}}a=0;for(b=this.vertices.length;a<b;a++)e[a].normalize();a=0;for(b=this.faces.length;a<
|
|
|
-b;a++){d=this.faces[a];if(d instanceof THREE.Face3){d.vertexNormals[0].copy(e[d.a]);d.vertexNormals[1].copy(e[d.b]);d.vertexNormals[2].copy(e[d.c])}else if(d instanceof THREE.Face4){d.vertexNormals[0].copy(e[d.a]);d.vertexNormals[1].copy(e[d.b]);d.vertexNormals[2].copy(e[d.c]);d.vertexNormals[3].copy(e[d.d])}}},computeTangents:function(){function a(ta,Ea,Fa,Aa,Ja,Ka,La){l=ta.vertices[Ea].position;m=ta.vertices[Fa].position;s=ta.vertices[Aa].position;o=g[Ja];v=g[Ka];B=g[La];z=m.x-l.x;D=s.x-l.x;E=m.y-
|
|
|
-l.y;H=s.y-l.y;I=m.z-l.z;L=s.z-l.z;M=v.u-o.u;W=B.u-o.u;$=v.v-o.v;ia=B.v-o.v;ea=1/(M*ia-W*$);c.set((ia*z-$*D)*ea,(ia*E-$*H)*ea,(ia*I-$*L)*ea);ra.set((M*D-W*z)*ea,(M*H-W*E)*ea,(M*L-W*I)*ea);aa[Ea].addSelf(c);aa[Fa].addSelf(c);aa[Aa].addSelf(c);ja[Ea].addSelf(ra);ja[Fa].addSelf(ra);ja[Aa].addSelf(ra)}var b,d,e,g,l,m,s,o,v,B,z,D,E,H,I,L,M,W,$,ia,ea,aa=[],ja=[],c=new THREE.Vector3,ra=new THREE.Vector3,pa=new THREE.Vector3,ya=new THREE.Vector3,sa=new THREE.Vector3;b=0;for(d=this.vertices.length;b<d;b++){aa[b]=
|
|
|
-new THREE.Vector3;ja[b]=new THREE.Vector3}b=0;for(d=this.faces.length;b<d;b++){e=this.faces[b];g=this.uvs[b];if(e instanceof THREE.Face3){a(this,e.a,e.b,e.c,0,1,2);this.vertices[e.a].normal.copy(e.vertexNormals[0]);this.vertices[e.b].normal.copy(e.vertexNormals[1]);this.vertices[e.c].normal.copy(e.vertexNormals[2])}else if(e instanceof THREE.Face4){a(this,e.a,e.b,e.c,0,1,2);a(this,e.a,e.b,e.d,0,1,3);this.vertices[e.a].normal.copy(e.vertexNormals[0]);this.vertices[e.b].normal.copy(e.vertexNormals[1]);
|
|
|
-this.vertices[e.c].normal.copy(e.vertexNormals[2]);this.vertices[e.d].normal.copy(e.vertexNormals[3])}}b=0;for(d=this.vertices.length;b<d;b++){sa.copy(this.vertices[b].normal);e=aa[b];pa.copy(e);pa.subSelf(sa.multiplyScalar(sa.dot(e))).normalize();ya.cross(this.vertices[b].normal,e);e=ya.dot(ja[b]);e=e<0?-1:1;this.vertices[b].tangent.set(pa.x,pa.y,pa.z,e)}this.hasTangents=!0},computeBoundingBox:function(){var a;if(this.vertices.length>0){this.boundingBox={x:[this.vertices[0].position.x,this.vertices[0].position.x],
|
|
|
-y:[this.vertices[0].position.y,this.vertices[0].position.y],z:[this.vertices[0].position.z,this.vertices[0].position.z]};for(var b=1,d=this.vertices.length;b<d;b++){a=this.vertices[b];if(a.position.x<this.boundingBox.x[0])this.boundingBox.x[0]=a.position.x;else if(a.position.x>this.boundingBox.x[1])this.boundingBox.x[1]=a.position.x;if(a.position.y<this.boundingBox.y[0])this.boundingBox.y[0]=a.position.y;else if(a.position.y>this.boundingBox.y[1])this.boundingBox.y[1]=a.position.y;if(a.position.z<
|
|
|
-this.boundingBox.z[0])this.boundingBox.z[0]=a.position.z;else if(a.position.z>this.boundingBox.z[1])this.boundingBox.z[1]=a.position.z}}},computeBoundingSphere:function(){for(var a=this.boundingSphere===null?0:this.boundingSphere.radius,b=0,d=this.vertices.length;b<d;b++)a=Math.max(a,this.vertices[b].position.length());this.boundingSphere={radius:a}}};THREE.GeometryIdCounter=0;
|
|
|
-THREE.Camera=function(a,b,d,e,g){THREE.Object3D.call(this);this.fov=a||50;this.aspect=b||1;this.near=d||0.1;this.far=e||2E3;this.target=g||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;
|
|
|
+b;a++){d=this.faces[a];if(d instanceof THREE.Face3){d.vertexNormals[0].copy(e[d.a]);d.vertexNormals[1].copy(e[d.b]);d.vertexNormals[2].copy(e[d.c])}else if(d instanceof THREE.Face4){d.vertexNormals[0].copy(e[d.a]);d.vertexNormals[1].copy(e[d.b]);d.vertexNormals[2].copy(e[d.c]);d.vertexNormals[3].copy(e[d.d])}}},computeTangents:function(){function a(R,N,Ba,L,ka,wa,P){h=R.vertices[N].position;j=R.vertices[Ba].position;o=R.vertices[L].position;m=f[ka];u=f[wa];y=f[P];z=j.x-h.x;A=o.x-h.x;x=j.y-h.y;K=o.y-
|
|
|
+h.y;J=j.z-h.z;H=o.z-h.z;w=u.u-m.u;ga=y.u-m.u;U=u.v-m.v;ha=y.v-m.v;fa=1/(w*ha-ga*U);c.set((ha*z-U*A)*fa,(ha*x-U*K)*fa,(ha*J-U*H)*fa);ja.set((w*A-ga*z)*fa,(w*K-ga*x)*fa,(w*H-ga*J)*fa);ia[N].addSelf(c);ia[Ba].addSelf(c);ia[L].addSelf(c);M[N].addSelf(ja);M[Ba].addSelf(ja);M[L].addSelf(ja)}var b,d,e,f,h,j,o,m,u,y,z,A,x,K,J,H,w,ga,U,ha,fa,ia=[],M=[],c=new THREE.Vector3,ja=new THREE.Vector3,W=new THREE.Vector3,la=new THREE.Vector3,Z=new THREE.Vector3;b=0;for(d=this.vertices.length;b<d;b++){ia[b]=new THREE.Vector3;
|
|
|
+M[b]=new THREE.Vector3}b=0;for(d=this.faces.length;b<d;b++){e=this.faces[b];f=this.uvs[b];if(e instanceof THREE.Face3){a(this,e.a,e.b,e.c,0,1,2);this.vertices[e.a].normal.copy(e.vertexNormals[0]);this.vertices[e.b].normal.copy(e.vertexNormals[1]);this.vertices[e.c].normal.copy(e.vertexNormals[2])}else if(e instanceof THREE.Face4){a(this,e.a,e.b,e.c,0,1,2);a(this,e.a,e.b,e.d,0,1,3);this.vertices[e.a].normal.copy(e.vertexNormals[0]);this.vertices[e.b].normal.copy(e.vertexNormals[1]);this.vertices[e.c].normal.copy(e.vertexNormals[2]);
|
|
|
+this.vertices[e.d].normal.copy(e.vertexNormals[3])}}b=0;for(d=this.vertices.length;b<d;b++){Z.copy(this.vertices[b].normal);e=ia[b];W.copy(e);W.subSelf(Z.multiplyScalar(Z.dot(e))).normalize();la.cross(this.vertices[b].normal,e);e=la.dot(M[b]);e=e<0?-1:1;this.vertices[b].tangent.set(W.x,W.y,W.z,e)}this.hasTangents=!0},computeBoundingBox:function(){var a;if(this.vertices.length>0){this.boundingBox={x:[this.vertices[0].position.x,this.vertices[0].position.x],y:[this.vertices[0].position.y,this.vertices[0].position.y],
|
|
|
+z:[this.vertices[0].position.z,this.vertices[0].position.z]};for(var b=1,d=this.vertices.length;b<d;b++){a=this.vertices[b];if(a.position.x<this.boundingBox.x[0])this.boundingBox.x[0]=a.position.x;else if(a.position.x>this.boundingBox.x[1])this.boundingBox.x[1]=a.position.x;if(a.position.y<this.boundingBox.y[0])this.boundingBox.y[0]=a.position.y;else if(a.position.y>this.boundingBox.y[1])this.boundingBox.y[1]=a.position.y;if(a.position.z<this.boundingBox.z[0])this.boundingBox.z[0]=a.position.z;else if(a.position.z>
|
|
|
+this.boundingBox.z[1])this.boundingBox.z[1]=a.position.z}}},computeBoundingSphere:function(){for(var a=this.boundingSphere===null?0:this.boundingSphere.radius,b=0,d=this.vertices.length;b<d;b++)a=Math.max(a,this.vertices[b].position.length());this.boundingSphere={radius:a}}};THREE.GeometryIdCounter=0;
|
|
|
+THREE.AnimationHandler=function(){var a=[],b={},d={};d.update=function(f){for(var h=0;h<a.length;h++)a[h].update(f)};d.addToUpdate=function(f){a.indexOf(f)===-1&&a.push(f)};d.removeFromUpdate=function(f){f=a.indexOf(f);f!==-1&&a.splice(f,1)};d.add=function(f){b[f.name]!==undefined&&console.log("THREE.AnimationHandler.add: Warning! "+f.name+" already exists in library. Overwriting.");b[f.name]=f;if(f.initialized!==!0){for(var h=0;h<f.hierarchy.length;h++){for(var j=0;j<f.hierarchy[h].keys.length;j++){if(f.hierarchy[h].keys[j].time<
|
|
|
+0)f.hierarchy[h].keys[j].time=0;if(f.hierarchy[h].keys[j].rot!==undefined&&!(f.hierarchy[h].keys[j].rot instanceof THREE.Quaternion)){var o=f.hierarchy[h].keys[j].rot;f.hierarchy[h].keys[j].rot=new THREE.Quaternion(o[0],o[1],o[2],o[3])}}if(f.hierarchy[h].keys[0].morphTargets!==undefined){o={};for(j=0;j<f.hierarchy[h].keys.length;j++)for(var m=0;m<f.hierarchy[h].keys[j].morphTargets.length;m++){var u=f.hierarchy[h].keys[j].morphTargets[m];o[u]=-1}f.hierarchy[h].usedMorphTargets=o;for(j=0;j<f.hierarchy[h].keys.length;j++){var y=
|
|
|
+{};for(u in o){for(m=0;m<f.hierarchy[h].keys[j].morphTargets.length;m++)if(f.hierarchy[h].keys[j].morphTargets[m]===u){y[u]=f.hierarchy[h].keys[j].morphTargetsInfluences[m];break}m===f.hierarchy[h].keys[j].morphTargets.length&&(y[u]=0)}f.hierarchy[h].keys[j].morphTargetsInfluences=y}}for(j=1;j<f.hierarchy[h].keys.length;j++)if(f.hierarchy[h].keys[j].time===f.hierarchy[h].keys[j-1].time){f.hierarchy[h].keys.splice(j,1);j--}for(j=1;j<f.hierarchy[h].keys.length;j++)f.hierarchy[h].keys[j].index=j}j=parseInt(f.length*
|
|
|
+f.fps,10);f.JIT={};f.JIT.hierarchy=[];for(h=0;h<f.hierarchy.length;h++)f.JIT.hierarchy.push(Array(j));f.initialized=!0}};d.get=function(f){if(typeof f==="string")if(b[f])return b[f];else{console.log("THREE.AnimationHandler.get: Couldn't find animation "+f);return null}};d.parse=function(f){var h=[];if(f instanceof THREE.SkinnedMesh)for(var j=0;j<f.bones.length;j++)h.push(f.bones[j]);else e(f,h);return h};var e=function(f,h){h.push(f);for(var j=0;j<f.children.length;j++)e(f.children[j],h)};d.LINEAR=
|
|
|
+0;d.CATMULLROM=1;d.CATMULLROM_FORWARD=2;return d}();THREE.Animation=function(a,b,d,e){this.root=a;this.data=THREE.AnimationHandler.get(b);this.hierarchy=THREE.AnimationHandler.parse(a);this.currentTime=0;this.timeScale=1;this.isPlaying=!1;this.isPaused=!0;this.loop=!0;this.interpolationType=d!==undefined?d:THREE.AnimationHandler.LINEAR;this.JITCompile=e!==undefined?e:!0;this.points=[];this.target=new THREE.Vector3};
|
|
|
+THREE.Animation.prototype.play=function(a,b){if(!this.isPlaying){this.isPlaying=!0;this.loop=a!==undefined?a:!0;this.currentTime=b!==undefined?b:0;var d,e=this.hierarchy.length,f;for(d=0;d<e;d++){f=this.hierarchy[d];if(this.interpolationType!==THREE.AnimationHandler.CATMULLROM_FORWARD)f.useQuaternion=!0;f.matrixAutoUpdate=!0;if(f.animationCache===undefined){f.animationCache={};f.animationCache.prevKey={pos:0,rot:0,scl:0};f.animationCache.nextKey={pos:0,rot:0,scl:0};f.animationCache.originalMatrix=
|
|
|
+f instanceof THREE.Bone?f.skinMatrix:f.matrix}var h=f.animationCache.prevKey;f=f.animationCache.nextKey;h.pos=this.data.hierarchy[d].keys[0];h.rot=this.data.hierarchy[d].keys[0];h.scl=this.data.hierarchy[d].keys[0];f.pos=this.getNextKeyWith("pos",d,1);f.rot=this.getNextKeyWith("rot",d,1);f.scl=this.getNextKeyWith("scl",d,1)}this.update(0)}this.isPaused=!1;THREE.AnimationHandler.addToUpdate(this)};
|
|
|
+THREE.Animation.prototype.pause=function(){this.isPaused?THREE.AnimationHandler.addToUpdate(this):THREE.AnimationHandler.removeFromUpdate(this);this.isPaused=!this.isPaused};
|
|
|
+THREE.Animation.prototype.stop=function(){this.isPlaying=!1;this.isPaused=!1;THREE.AnimationHandler.removeFromUpdate(this);for(var a=0;a<this.hierarchy.length;a++)if(this.hierarchy[a].animationCache!==undefined){if(this.hierarchy[a]instanceof THREE.Bone)this.hierarchy[a].skinMatrix=this.hierarchy[a].animationCache.originalMatrix;else this.hierarchy[a].matrix=this.hierarchy[a].animationCache.originalMatrix;delete this.hierarchy[a].animationCache}};
|
|
|
+THREE.Animation.prototype.update=function(a){if(this.isPlaying){var b=["pos","rot","scl"],d,e,f,h,j,o,m,u,y=this.data.JIT.hierarchy,z,A;this.currentTime+=a*this.timeScale;A=this.currentTime;z=this.currentTime%=this.data.length;u=parseInt(Math.min(z*this.data.fps,this.data.length*this.data.fps),10);for(var x=0,K=this.hierarchy.length;x<K;x++){a=this.hierarchy[x];m=a.animationCache;if(this.JITCompile&&y[x][u]!==undefined)if(a instanceof THREE.Bone){a.skinMatrix=y[x][u];a.matrixAutoUpdate=!1;a.matrixWorldNeedsUpdate=
|
|
|
+!1}else{a.matrix=y[x][u];a.matrixAutoUpdate=!1;a.matrixWorldNeedsUpdate=!0}else{if(this.JITCompile)if(a instanceof THREE.Bone)a.skinMatrix=a.animationCache.originalMatrix;else a.matrix=a.animationCache.originalMatrix;for(var J=0;J<3;J++){d=b[J];j=m.prevKey[d];o=m.nextKey[d];if(o.time<=A){if(z<A)if(this.loop){j=this.data.hierarchy[x].keys[0];for(o=this.getNextKeyWith(d,x,1);o.time<z;){j=o;o=this.getNextKeyWith(d,x,o.index+1)}}else{this.stop();return}else{do{j=o;o=this.getNextKeyWith(d,x,o.index+1)}while(o.time<
|
|
|
+z)}m.prevKey[d]=j;m.nextKey[d]=o}a.matrixAutoUpdate=!0;a.matrixWorldNeedsUpdate=!0;e=(z-j.time)/(o.time-j.time);f=j[d];h=o[d];if(e<0||e>1){console.log("THREE.Animation.update: Warning! Scale out of bounds:"+e+" on bone "+x);e=e<0?0:1}if(d==="pos"){d=a.position;if(this.interpolationType===THREE.AnimationHandler.LINEAR){d.x=f[0]+(h[0]-f[0])*e;d.y=f[1]+(h[1]-f[1])*e;d.z=f[2]+(h[2]-f[2])*e}else if(this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD){this.points[0]=
|
|
|
+this.getPrevKeyWith("pos",x,j.index-1).pos;this.points[1]=f;this.points[2]=h;this.points[3]=this.getNextKeyWith("pos",x,o.index+1).pos;e=e*0.33+0.33;f=this.interpolateCatmullRom(this.points,e);d.x=f[0];d.y=f[1];d.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(d);this.target.y=0;this.target.normalize();e=Math.atan2(this.target.x,this.target.z);a.rotation.set(0,e,0)}}}else if(d===
|
|
|
+"rot")THREE.Quaternion.slerp(f,h,a.quaternion,e);else if(d==="scl"){d=a.scale;d.x=f[0]+(h[0]-f[0])*e;d.y=f[1]+(h[1]-f[1])*e;d.z=f[2]+(h[2]-f[2])*e}}}}if(this.JITCompile&&y[0][u]===undefined){this.hierarchy[0].update(undefined,!0);for(x=0;x<this.hierarchy.length;x++)y[x][u]=this.hierarchy[x]instanceof THREE.Bone?this.hierarchy[x].skinMatrix.clone():this.hierarchy[x].matrix.clone()}}};
|
|
|
+THREE.Animation.prototype.interpolateCatmullRom=function(a,b){var d=[],e=[],f,h,j,o,m,u;f=(a.length-1)*b;h=Math.floor(f);f-=h;d[0]=h==0?h:h-1;d[1]=h;d[2]=h>a.length-2?h:h+1;d[3]=h>a.length-3?h:h+2;h=a[d[0]];o=a[d[1]];m=a[d[2]];u=a[d[3]];d=f*f;j=f*d;e[0]=this.interpolate(h[0],o[0],m[0],u[0],f,d,j);e[1]=this.interpolate(h[1],o[1],m[1],u[1],f,d,j);e[2]=this.interpolate(h[2],o[2],m[2],u[2],f,d,j);return e};
|
|
|
+THREE.Animation.prototype.interpolate=function(a,b,d,e,f,h,j){a=(d-a)*0.5;e=(e-b)*0.5;return(2*(b-d)+a+e)*j+(-3*(b-d)-2*a-e)*h+a*f+b};THREE.Animation.prototype.getNextKeyWith=function(a,b,d){var e=this.data.hierarchy[b].keys;if(this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD)d=d<e.length-1?d:e.length-1;else d%=e.length;for(;d<e.length;d++)if(e[d][a]!==undefined)return e[d];return this.data.hierarchy[b].keys[0]};
|
|
|
+THREE.Animation.prototype.getPrevKeyWith=function(a,b,d){var e=this.data.hierarchy[b].keys;for(d=this.interpolationType===THREE.AnimationHandler.CATMULLROM||this.interpolationType===THREE.AnimationHandler.CATMULLROM_FORWARD?d>0?d:0:d>=0?d:d+e.length;d>=0;d--)if(e[d][a]!==undefined)return e[d];return this.data.hierarchy[b].keys[e.length-1]};
|
|
|
+THREE.Camera=function(a,b,d,e,f){THREE.Object3D.call(this);this.fov=a||50;this.aspect=b||1;this.near=d||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,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,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);b=!0}else{this.matrixAutoUpdate&&(b|=this.updateMatrix());if(b||this.matrixWorldNeedsUpdate){a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);this.matrixWorldNeedsUpdate=
|
|
|
!1;b=!0;THREE.Matrix4.makeInvert(this.matrixWorld,this.matrixWorldInverse)}}for(a=0;a<this.children.length;a++)this.children[a].update(this.matrixWorld,b,d)};THREE.Light=function(a){THREE.Object3D.call(this);this.color=new THREE.Color(a)};THREE.Light.prototype=new THREE.Object3D;THREE.Light.prototype.constructor=THREE.Light;THREE.Light.prototype.supr=THREE.Object3D.prototype;THREE.AmbientLight=function(a){THREE.Light.call(this,a)};THREE.AmbientLight.prototype=new THREE.Light;
|
|
@@ -91,27 +108,27 @@ undefined)this.vertexShader=a.vertexShader;if(a.uniforms!==undefined)this.unifor
|
|
|
if(a.wireframeLinejoin!==undefined)this.wireframeLinejoin=a.wireframeLinejoin;if(a.lights!==undefined)this.lights=a.lights;if(a.vertexColors!==undefined)this.vertexColors=a.vertexColors;if(a.skinning!==undefined)this.skinning=a.skinning;if(a.morphTargets!==undefined)this.morphTargets=a.morphTargets}};
|
|
|
THREE.ParticleBasicMaterial=function(a){this.id=THREE.MaterialCounter.value++;this.color=new THREE.Color(16777215);this.opacity=1;this.map=null;this.size=1;this.sizeAttenuation=!0;this.blending=THREE.NormalBlending;this.depthTest=!0;this.offset=new THREE.Vector2;this.vertexColors=!1;if(a){a.color!==undefined&&this.color.setHex(a.color);if(a.opacity!==undefined)this.opacity=a.opacity;if(a.map!==undefined)this.map=a.map;if(a.size!==undefined)this.size=a.size;if(a.sizeAttenuation!==undefined)this.sizeAttenuation=
|
|
|
a.sizeAttenuation;if(a.blending!==undefined)this.blending=a.blending;if(a.depthTest!==undefined)this.depthTest=a.depthTest;if(a.vertexColors!==undefined)this.vertexColors=a.vertexColors}};THREE.ParticleCircleMaterial=function(a){this.id=THREE.MaterialCounter.value++;this.color=new THREE.Color(16777215);this.opacity=1;this.blending=THREE.NormalBlending;if(a){a.color!==undefined&&this.color.setHex(a.color);if(a.opacity!==undefined)this.opacity=a.opacity;if(a.blending!==undefined)this.blending=a.blending}};
|
|
|
-THREE.Texture=function(a,b,d,e,g,l){this.image=a;this.mapping=b!==undefined?b:new THREE.UVMapping;this.wrapS=d!==undefined?d:THREE.ClampToEdgeWrapping;this.wrapT=e!==undefined?e:THREE.ClampToEdgeWrapping;this.magFilter=g!==undefined?g:THREE.LinearFilter;this.minFilter=l!==undefined?l:THREE.LinearMipMapLinearFilter;this.needsUpdate=!1};THREE.Texture.prototype={clone:function(){return new THREE.Texture(this.image,this.mapping,this.wrapS,this.wrapT,this.magFilter,this.minFilter)}};
|
|
|
+THREE.Texture=function(a,b,d,e,f,h){this.image=a;this.mapping=b!==undefined?b:new THREE.UVMapping;this.wrapS=d!==undefined?d:THREE.ClampToEdgeWrapping;this.wrapT=e!==undefined?e:THREE.ClampToEdgeWrapping;this.magFilter=f!==undefined?f:THREE.LinearFilter;this.minFilter=h!==undefined?h:THREE.LinearMipMapLinearFilter;this.needsUpdate=!1};THREE.Texture.prototype={clone:function(){return new THREE.Texture(this.image,this.mapping,this.wrapS,this.wrapT,this.magFilter,this.minFilter)}};
|
|
|
THREE.MultiplyOperation=0;THREE.MixOperation=1;THREE.RepeatWrapping=0;THREE.ClampToEdgeWrapping=1;THREE.MirroredRepeatWrapping=2;THREE.NearestFilter=3;THREE.NearestMipMapNearestFilter=4;THREE.NearestMipMapLinearFilter=5;THREE.LinearFilter=6;THREE.LinearMipMapNearestFilter=7;THREE.LinearMipMapLinearFilter=8;THREE.ByteType=9;THREE.UnsignedByteType=10;THREE.ShortType=11;THREE.UnsignedShortType=12;THREE.IntType=13;THREE.UnsignedIntType=14;THREE.FloatType=15;THREE.AlphaFormat=16;THREE.RGBFormat=17;
|
|
|
THREE.RGBAFormat=18;THREE.LuminanceFormat=19;THREE.LuminanceAlphaFormat=20;
|
|
|
THREE.RenderTarget=function(a,b,d){this.width=a;this.height=b;d=d||{};this.wrapS=d.wrapS!==undefined?d.wrapS:THREE.ClampToEdgeWrapping;this.wrapT=d.wrapT!==undefined?d.wrapT:THREE.ClampToEdgeWrapping;this.magFilter=d.magFilter!==undefined?d.magFilter:THREE.LinearFilter;this.minFilter=d.minFilter!==undefined?d.minFilter:THREE.LinearMipMapLinearFilter;this.format=d.format!==undefined?d.format:THREE.RGBFormat;this.type=d.type!==undefined?d.type:THREE.UnsignedByteType};
|
|
|
-var Uniforms={clone:function(a){var b,d,e,g={};for(b in a){g[b]={};for(d in a[b]){e=a[b][d];g[b][d]=e instanceof THREE.Color||e instanceof THREE.Vector3||e instanceof THREE.Texture?e.clone():e}}return g},merge:function(a){var b,d,e,g={};for(b=0;b<a.length;b++){e=this.clone(a[b]);for(d in e)g[d]=e[d]}return g}};THREE.Particle=function(a){THREE.Object3D.call(this);this.materials=a instanceof Array?a:[a];this.matrixAutoUpdate=!1};THREE.Particle.prototype=new THREE.Object3D;
|
|
|
+var Uniforms={clone:function(a){var b,d,e,f={};for(b in a){f[b]={};for(d in a[b]){e=a[b][d];f[b][d]=e instanceof THREE.Color||e instanceof THREE.Vector3||e instanceof THREE.Texture?e.clone():e}}return f},merge:function(a){var b,d,e,f={};for(b=0;b<a.length;b++){e=this.clone(a[b]);for(d in e)f[d]=e[d]}return f}};THREE.Particle=function(a){THREE.Object3D.call(this);this.materials=a instanceof Array?a:[a];this.matrixAutoUpdate=!1};THREE.Particle.prototype=new THREE.Object3D;
|
|
|
THREE.Particle.prototype.constructor=THREE.Particle;THREE.ParticleSystem=function(a,b){THREE.Object3D.call(this);this.geometry=a;this.materials=b instanceof Array?b:[b];this.sortParticles=!1};THREE.ParticleSystem.prototype=new THREE.Object3D;THREE.ParticleSystem.prototype.constructor=THREE.ParticleSystem;THREE.Line=function(a,b,d){THREE.Object3D.call(this);this.geometry=a;this.materials=b instanceof Array?b:[b];this.type=d!=undefined?d:THREE.LineStrip};THREE.LineStrip=0;THREE.LinePieces=1;
|
|
|
THREE.Line.prototype=new THREE.Object3D;THREE.Line.prototype.constructor=THREE.Line;
|
|
|
THREE.Mesh=function(a,b){THREE.Object3D.call(this);this.geometry=a;this.materials=b&&b.length?b:[b];this.flipSided=!1;this.doubleSided=!1;this.overdraw=!1;if(this.geometry){this.geometry.boundingSphere||this.geometry.computeBoundingSphere();this.boundRadius=a.boundingSphere.radius;if(this.geometry.morphTargets.length){this.morphTargetBase=-1;this.morphTargetForcedOrder=[];this.morphTargetInfluences=[];this.morphTargetDictionary={};for(var d=0;d<this.geometry.morphTargets.length;d++){this.morphTargetInfluences.push(0);
|
|
|
this.morphTargetDictionary[this.geometry.morphTargets[d].name]=d}}}};THREE.Mesh.prototype=new THREE.Object3D;THREE.Mesh.prototype.constructor=THREE.Mesh;THREE.Mesh.prototype.supr=THREE.Object3D.prototype;THREE.Mesh.prototype.getMorphTargetIndexByName=function(a){if(this.morphTargetDictionary[a]!==undefined)return this.morphTargetDictionary[a];console.log("THREE.Mesh.getMorphTargetIndexByName: morph target "+a+" does not exist. Returning 0.");return 0};
|
|
|
THREE.Bone=function(a){THREE.Object3D.call(this);this.skin=a;this.skinMatrix=new THREE.Matrix4;this.hasNoneBoneChildren=!1};THREE.Bone.prototype=new THREE.Object3D;THREE.Bone.prototype.constructor=THREE.Bone;THREE.Bone.prototype.supr=THREE.Object3D.prototype;
|
|
|
-THREE.Bone.prototype.update=function(a,b,d){this.matrixAutoUpdate&&(b|=this.updateMatrix());if(b||this.matrixWorldNeedsUpdate){a?this.skinMatrix.multiply(a,this.matrix):this.skinMatrix.copy(this.matrix);this.matrixWorldNeedsUpdate=!1;b=!0}var e,g=this.children.length;if(this.hasNoneBoneChildren){this.matrixWorld.multiply(this.skin.matrixWorld,this.skinMatrix);for(e=0;e<g;e++){a=this.children[e];a instanceof THREE.Bone?a.update(this.skinMatrix,b,d):a.update(this.matrixWorld,!0,d)}}else for(e=0;e<g;e++)this.children[e].update(this.skinMatrix,
|
|
|
+THREE.Bone.prototype.update=function(a,b,d){this.matrixAutoUpdate&&(b|=this.updateMatrix());if(b||this.matrixWorldNeedsUpdate){a?this.skinMatrix.multiply(a,this.matrix):this.skinMatrix.copy(this.matrix);this.matrixWorldNeedsUpdate=!1;b=!0}var e,f=this.children.length;if(this.hasNoneBoneChildren){this.matrixWorld.multiply(this.skin.matrixWorld,this.skinMatrix);for(e=0;e<f;e++){a=this.children[e];a instanceof THREE.Bone?a.update(this.skinMatrix,b,d):a.update(this.matrixWorld,!0,d)}}else for(e=0;e<f;e++)this.children[e].update(this.skinMatrix,
|
|
|
b,d)};THREE.Bone.prototype.addChild=function(a){if(this.children.indexOf(a)===-1){a.parent!==undefined&&a.parent.removeChild(a);a.parent=this;this.children.push(a);if(!(a instanceof THREE.Bone))this.hasNoneBoneChildren=!0}};if(!window.Float32Array)window.Float32Array=Array;
|
|
|
-THREE.SkinnedMesh=function(a,b){THREE.Mesh.call(this,a,b);this.identityMatrix=new THREE.Matrix4;this.bones=[];this.boneMatrices=[];var d,e,g,l,m,s;if(this.geometry.bones!==undefined){for(d=0;d<this.geometry.bones.length;d++){g=this.geometry.bones[d];l=g.pos;m=g.rotq;s=g.scl;e=this.addBone();e.name=g.name;e.position.set(l[0],l[1],l[2]);e.quaternion.set(m[0],m[1],m[2],m[3]);e.useQuaternion=!0;s!==undefined?e.scale.set(s[0],s[1],s[2]):e.scale.set(1,1,1)}for(d=0;d<this.bones.length;d++){g=this.geometry.bones[d];
|
|
|
-e=this.bones[d];g.parent===-1?this.addChild(e):this.bones[g.parent].addChild(e)}this.boneMatrices=new Float32Array(16*this.bones.length);this.pose()}};THREE.SkinnedMesh.prototype=new THREE.Mesh;THREE.SkinnedMesh.prototype.constructor=THREE.SkinnedMesh;
|
|
|
-THREE.SkinnedMesh.prototype.update=function(a,b,d){if(this.visible){this.matrixAutoUpdate&&(b|=this.updateMatrix());if(b||this.matrixWorldNeedsUpdate){a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);this.matrixWorldNeedsUpdate=!1;b=!0}var e,g=this.children.length;for(e=0;e<g;e++){a=this.children[e];a instanceof THREE.Bone?a.update(this.identityMatrix,!1,d):a.update(this.matrixWorld,b,d)}d=this.bones.length;ba=this.bones;bm=this.boneMatrices;for(b=0;b<d;b++)ba[b].skinMatrix.flattenToArrayOffset(bm,
|
|
|
+THREE.SkinnedMesh=function(a,b){THREE.Mesh.call(this,a,b);this.identityMatrix=new THREE.Matrix4;this.bones=[];this.boneMatrices=[];var d,e,f,h,j,o;if(this.geometry.bones!==undefined){for(d=0;d<this.geometry.bones.length;d++){f=this.geometry.bones[d];h=f.pos;j=f.rotq;o=f.scl;e=this.addBone();e.name=f.name;e.position.set(h[0],h[1],h[2]);e.quaternion.set(j[0],j[1],j[2],j[3]);e.useQuaternion=!0;o!==undefined?e.scale.set(o[0],o[1],o[2]):e.scale.set(1,1,1)}for(d=0;d<this.bones.length;d++){f=this.geometry.bones[d];
|
|
|
+e=this.bones[d];f.parent===-1?this.addChild(e):this.bones[f.parent].addChild(e)}this.boneMatrices=new Float32Array(16*this.bones.length);this.pose()}};THREE.SkinnedMesh.prototype=new THREE.Mesh;THREE.SkinnedMesh.prototype.constructor=THREE.SkinnedMesh;
|
|
|
+THREE.SkinnedMesh.prototype.update=function(a,b,d){if(this.visible){this.matrixAutoUpdate&&(b|=this.updateMatrix());if(b||this.matrixWorldNeedsUpdate){a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);this.matrixWorldNeedsUpdate=!1;b=!0}var e,f=this.children.length;for(e=0;e<f;e++){a=this.children[e];a instanceof THREE.Bone?a.update(this.identityMatrix,!1,d):a.update(this.matrixWorld,b,d)}d=this.bones.length;ba=this.bones;bm=this.boneMatrices;for(b=0;b<d;b++)ba[b].skinMatrix.flattenToArrayOffset(bm,
|
|
|
b*16)}};THREE.SkinnedMesh.prototype.addBone=function(a){a===undefined&&(a=new THREE.Bone(this));this.bones.push(a);return a};
|
|
|
-THREE.SkinnedMesh.prototype.pose=function(){this.update(undefined,!0);for(var a,b=[],d=0;d<this.bones.length;d++){a=this.bones[d];b.push(THREE.Matrix4.makeInvert(a.skinMatrix));a.skinMatrix.flattenToArrayOffset(this.boneMatrices,d*16)}if(this.geometry.skinVerticesA===undefined){this.geometry.skinVerticesA=[];this.geometry.skinVerticesB=[];var e;for(a=0;a<this.geometry.skinIndices.length;a++){d=this.geometry.vertices[a].position;var g=this.geometry.skinIndices[a].x,l=this.geometry.skinIndices[a].y;
|
|
|
-e=new THREE.Vector3(d.x,d.y,d.z);this.geometry.skinVerticesA.push(b[g].multiplyVector3(e));e=new THREE.Vector3(d.x,d.y,d.z);this.geometry.skinVerticesB.push(b[l].multiplyVector3(e));if(this.geometry.skinWeights[a].x+this.geometry.skinWeights[a].y!==1){d=(1-(this.geometry.skinWeights[a].x+this.geometry.skinWeights[a].y))*0.5;this.geometry.skinWeights[a].x+=d;this.geometry.skinWeights[a].y+=d}}}};
|
|
|
+THREE.SkinnedMesh.prototype.pose=function(){this.update(undefined,!0);for(var a,b=[],d=0;d<this.bones.length;d++){a=this.bones[d];b.push(THREE.Matrix4.makeInvert(a.skinMatrix));a.skinMatrix.flattenToArrayOffset(this.boneMatrices,d*16)}if(this.geometry.skinVerticesA===undefined){this.geometry.skinVerticesA=[];this.geometry.skinVerticesB=[];var e;for(a=0;a<this.geometry.skinIndices.length;a++){d=this.geometry.vertices[a].position;var f=this.geometry.skinIndices[a].x,h=this.geometry.skinIndices[a].y;
|
|
|
+e=new THREE.Vector3(d.x,d.y,d.z);this.geometry.skinVerticesA.push(b[f].multiplyVector3(e));e=new THREE.Vector3(d.x,d.y,d.z);this.geometry.skinVerticesB.push(b[h].multiplyVector3(e));if(this.geometry.skinWeights[a].x+this.geometry.skinWeights[a].y!==1){d=(1-(this.geometry.skinWeights[a].x+this.geometry.skinWeights[a].y))*0.5;this.geometry.skinWeights[a].x+=d;this.geometry.skinWeights[a].y+=d}}}};
|
|
|
THREE.Ribbon=function(a,b){THREE.Object3D.call(this);this.geometry=a;this.materials=b instanceof Array?b:[b];this.flipSided=!1;this.doubleSided=!1};THREE.Ribbon.prototype=new THREE.Object3D;THREE.Ribbon.prototype.constructor=THREE.Ribbon;
|
|
|
-THREE.Sound=function(a,b,d,e){THREE.Object3D.call(this);this.isLoaded=!1;this.isAddedToDOM=!1;this.isPlaying=!1;this.duration=-1;this.radius=b!==undefined?Math.abs(b):100;this.volume=Math.min(1,Math.max(0,d!==undefined?d:1));this.domElement=document.createElement("audio");this.domElement.volume=0;this.domElement.pan=0;this.domElement.loop=e!==undefined?e:!0;this.sources=a instanceof Array?a:[a];var g;d=this.sources.length;for(a=0;a<d;a++){b=this.sources[a];b.toLowerCase();if(b.indexOf(".mp3")!==-1)g=
|
|
|
-"audio/mpeg";else if(b.indexOf(".ogg")!==-1)g="audio/ogg";else b.indexOf(".wav")!==-1&&(g="audio/wav");if(this.domElement.canPlayType(g)){g=document.createElement("source");g.src=this.sources[a];this.domElement.THREESound=this;this.domElement.appendChild(g);this.domElement.addEventListener("canplay",this.onLoad,!0);this.domElement.load();break}}};THREE.Sound.prototype=new THREE.Object3D;THREE.Sound.prototype.constructor=THREE.Sound;THREE.Sound.prototype.supr=THREE.Object3D.prototype;
|
|
|
+THREE.Sound=function(a,b,d,e){THREE.Object3D.call(this);this.isLoaded=!1;this.isAddedToDOM=!1;this.isPlaying=!1;this.duration=-1;this.radius=b!==undefined?Math.abs(b):100;this.volume=Math.min(1,Math.max(0,d!==undefined?d:1));this.domElement=document.createElement("audio");this.domElement.volume=0;this.domElement.pan=0;this.domElement.loop=e!==undefined?e:!0;this.sources=a instanceof Array?a:[a];var f;d=this.sources.length;for(a=0;a<d;a++){b=this.sources[a];b.toLowerCase();if(b.indexOf(".mp3")!==-1)f=
|
|
|
+"audio/mpeg";else if(b.indexOf(".ogg")!==-1)f="audio/ogg";else b.indexOf(".wav")!==-1&&(f="audio/wav");if(this.domElement.canPlayType(f)){f=document.createElement("source");f.src=this.sources[a];this.domElement.THREESound=this;this.domElement.appendChild(f);this.domElement.addEventListener("canplay",this.onLoad,!0);this.domElement.load();break}}};THREE.Sound.prototype=new THREE.Object3D;THREE.Sound.prototype.constructor=THREE.Sound;THREE.Sound.prototype.supr=THREE.Object3D.prototype;
|
|
|
THREE.Sound.prototype.onLoad=function(){var a=this.THREESound;if(!a.isLoaded){this.removeEventListener("canplay",this.onLoad,!0);a.isLoaded=!0;a.duration=this.duration;a.isPlaying&&a.play()}};THREE.Sound.prototype.addToDOM=function(a){this.isAddedToDOM=!0;a.appendChild(this.domElement)};THREE.Sound.prototype.play=function(a){this.isPlaying=!0;if(this.isLoaded){this.domElement.play();if(a)this.domElement.currentTime=a%this.duration}};THREE.Sound.prototype.pause=function(){this.isPlaying=!1;this.domElement.pause()};
|
|
|
THREE.Sound.prototype.stop=function(){this.isPlaying=!1;this.domElement.pause();this.domElement.currentTime=0};THREE.Sound.prototype.calculateVolumeAndPan=function(a){a=a.length();this.domElement.volume=a<=this.radius?this.volume*(1-a/this.radius):0};
|
|
|
THREE.Sound.prototype.update=function(a,b,d){if(this.matrixAutoUpdate){this.matrix.setPosition(this.position);b=!0}if(b||this.matrixWorldNeedsUpdate){a?this.matrixWorld.multiply(a,this.matrix):this.matrixWorld.copy(this.matrix);this.matrixWorldNeedsUpdate=!1;b=!0}var e=this.children.length;for(a=0;a<e;a++)this.children[a].update(this.matrixWorld,b,d)};THREE.LOD=function(){THREE.Object3D.call(this);this.LODs=[]};THREE.LOD.prototype=new THREE.Object3D;THREE.LOD.prototype.constructor=THREE.LOD;
|
|
@@ -121,7 +138,20 @@ THREE.LOD.prototype.update=function(a,b,d){this.matrixAutoUpdate&&(b|=this.updat
|
|
|
THREE.Scene.prototype.addChild=function(a){this.supr.addChild.call(this,a);this.addChildRecurse(a)};THREE.Scene.prototype.addChildRecurse=function(a){if(a instanceof THREE.Light)this.lights.indexOf(a)===-1&&this.lights.push(a);else if(a instanceof THREE.Sound)this.sounds.indexOf(a)===-1&&this.sounds.push(a);else if(!(a instanceof THREE.Camera||a instanceof THREE.Bone)&&this.objects.indexOf(a)===-1){this.objects.push(a);this.__objectsAdded.push(a)}for(var b=0;b<a.children.length;b++)this.addChildRecurse(a.children[b])};
|
|
|
THREE.Scene.prototype.removeChild=function(a){this.supr.removeChild.call(this,a);this.removeChildRecurse(a)};THREE.Scene.prototype.removeChildRecurse=function(a){if(a instanceof THREE.Light){var b=this.lights.indexOf(a);b!==-1&&this.lights.splice(b,1)}else if(a instanceof THREE.Sound){b=this.sounds.indexOf(a);b!==-1&&this.sounds.splice(b,1)}else if(!(a instanceof THREE.Camera)){b=this.objects.indexOf(a);if(b!==-1){this.objects.splice(b,1);this.__objectsRemoved.push(a)}}for(b=0;b<a.children.length;b++)this.removeChildRecurse(a.children[b])};
|
|
|
THREE.Scene.prototype.addObject=THREE.Scene.prototype.addChild;THREE.Scene.prototype.removeObject=THREE.Scene.prototype.removeChild;THREE.Scene.prototype.addLight=THREE.Scene.prototype.addChild;THREE.Scene.prototype.removeLight=THREE.Scene.prototype.removeChild;THREE.Fog=function(a,b,d){this.color=new THREE.Color(a);this.near=b||1;this.far=d||1E3};THREE.FogExp2=function(a,b){this.color=new THREE.Color(a);this.density=b!==undefined?b:2.5E-4};
|
|
|
-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,b,d){d&&a.update(undefined,!1,b);d=a.sounds;var e,g=d.length;for(e=0;e<g;e++){a=d[e];this.soundPosition.set(a.matrixWorld.n14,a.matrixWorld.n24,a.matrixWorld.n34);this.soundPosition.subSelf(b.position);if(a.isPlaying&&a.isLoaded){a.isAddedToDOM||a.addToDOM(this.domElement);a.calculateVolumeAndPan(this.soundPosition)}}}};
|
|
|
+THREE.Projector=function(){function a(M,c){return c.z-M.z}function b(M,c){var ja=0,W=1,la=M.z+M.w,Z=c.z+c.w,R=-M.z+M.w,N=-c.z+c.w;if(la>=0&&Z>=0&&R>=0&&N>=0)return!0;else if(la<0&&Z<0||R<0&&N<0)return!1;else{if(la<0)ja=Math.max(ja,la/(la-Z));else Z<0&&(W=Math.min(W,la/(la-Z)));if(R<0)ja=Math.max(ja,R/(R-N));else N<0&&(W=Math.min(W,R/(R-N)));if(W<ja)return!1;else{M.lerpSelf(c,ja);c.lerpSelf(M,1-W);return!0}}}var d,e,f=[],h,j,o,m=[],u,y,z=[],A,x,K=[],J=new THREE.Vector4,H=new THREE.Vector4,w=new THREE.Matrix4,
|
|
|
+ga=new THREE.Matrix4,U=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],ha=new THREE.Vector4,fa=new THREE.Vector4,ia;this.projectObjects=function(M,c,ja){c=[];var W,la,Z;e=0;la=M.objects;M=0;for(W=la.length;M<W;M++){Z=la[M];var R;if(!(R=!Z.visible))if(R=Z instanceof THREE.Mesh){a:{R=void 0;for(var N=Z.matrixWorld,Ba=-Z.geometry.boundingSphere.radius*Math.max(Z.scale.x,Math.max(Z.scale.y,Z.scale.z)),L=0;L<6;L++){R=U[L].x*N.n14+U[L].y*N.n24+
|
|
|
+U[L].z*N.n34+U[L].w;if(R<=Ba){R=!1;break a}}R=!0}R=!R}if(!R){d=f[e]=f[e]||new THREE.RenderableObject;J.copy(Z.position);w.multiplyVector3(J);d.object=Z;d.z=J.z;c.push(d);e++}}ja&&c.sort(a);return c};this.projectScene=function(M,c,ja){var W=[],la=c.near,Z=c.far,R,N,Ba,L,ka,wa,P,xa,Ha,Na,Ma,Fa,va,V,sa,za;o=y=x=0;c.matrixAutoUpdate&&c.updateMatrix();M.update(undefined,!1,c);w.multiply(c.projectionMatrix,c.matrixWorldInverse);U[0].set(w.n41-w.n11,w.n42-w.n12,w.n43-w.n13,w.n44-w.n14);U[1].set(w.n41+w.n11,
|
|
|
+w.n42+w.n12,w.n43+w.n13,w.n44+w.n14);U[2].set(w.n41+w.n21,w.n42+w.n22,w.n43+w.n23,w.n44+w.n24);U[3].set(w.n41-w.n21,w.n42-w.n22,w.n43-w.n23,w.n44-w.n24);U[4].set(w.n41-w.n31,w.n42-w.n32,w.n43-w.n33,w.n44-w.n34);U[5].set(w.n41+w.n31,w.n42+w.n32,w.n43+w.n33,w.n44+w.n34);for(R=0;R<6;R++){wa=U[R];wa.divideScalar(Math.sqrt(wa.x*wa.x+wa.y*wa.y+wa.z*wa.z))}wa=this.projectObjects(M,c,!0);M=0;for(R=wa.length;M<R;M++){P=wa[M].object;if(P.visible){xa=P.matrixWorld;Ma=P.matrixRotationWorld;Ha=P.materials;Na=
|
|
|
+P.overdraw;if(P instanceof THREE.Mesh){Fa=P.geometry;va=Fa.vertices;N=0;for(Ba=va.length;N<Ba;N++){V=va[N];V.positionWorld.copy(V.position);xa.multiplyVector3(V.positionWorld);L=V.positionScreen;L.copy(V.positionWorld);w.multiplyVector4(L);L.x/=L.w;L.y/=L.w;V.__visible=L.z>la&&L.z<Z}Fa=Fa.faces;N=0;for(Ba=Fa.length;N<Ba;N++){V=Fa[N];if(V instanceof THREE.Face3){L=va[V.a];ka=va[V.b];sa=va[V.c];if(L.__visible&&ka.__visible&&sa.__visible&&(P.doubleSided||P.flipSided!=(sa.positionScreen.x-L.positionScreen.x)*
|
|
|
+(ka.positionScreen.y-L.positionScreen.y)-(sa.positionScreen.y-L.positionScreen.y)*(ka.positionScreen.x-L.positionScreen.x)<0)){h=m[o]=m[o]||new THREE.RenderableFace3;h.v1.positionWorld.copy(L.positionWorld);h.v2.positionWorld.copy(ka.positionWorld);h.v3.positionWorld.copy(sa.positionWorld);h.v1.positionScreen.copy(L.positionScreen);h.v2.positionScreen.copy(ka.positionScreen);h.v3.positionScreen.copy(sa.positionScreen);h.normalWorld.copy(V.normal);Ma.multiplyVector3(h.normalWorld);h.centroidWorld.copy(V.centroid);
|
|
|
+xa.multiplyVector3(h.centroidWorld);h.centroidScreen.copy(h.centroidWorld);w.multiplyVector3(h.centroidScreen);sa=V.vertexNormals;ia=h.vertexNormalsWorld;L=0;for(ka=sa.length;L<ka;L++){za=ia[L]=ia[L]||new THREE.Vector3;za.copy(sa[L]);Ma.multiplyVector3(za)}h.z=h.centroidScreen.z;h.meshMaterials=Ha;h.faceMaterials=V.materials;h.overdraw=Na;if(P.geometry.uvs[N]){h.uvs[0]=P.geometry.uvs[N][0];h.uvs[1]=P.geometry.uvs[N][1];h.uvs[2]=P.geometry.uvs[N][2]}W.push(h);o++}}else if(V instanceof THREE.Face4){L=
|
|
|
+va[V.a];ka=va[V.b];sa=va[V.c];za=va[V.d];if(L.__visible&&ka.__visible&&sa.__visible&&za.__visible&&(P.doubleSided||P.flipSided!=((za.positionScreen.x-L.positionScreen.x)*(ka.positionScreen.y-L.positionScreen.y)-(za.positionScreen.y-L.positionScreen.y)*(ka.positionScreen.x-L.positionScreen.x)<0||(ka.positionScreen.x-sa.positionScreen.x)*(za.positionScreen.y-sa.positionScreen.y)-(ka.positionScreen.y-sa.positionScreen.y)*(za.positionScreen.x-sa.positionScreen.x)<0))){h=m[o]=m[o]||new THREE.RenderableFace3;
|
|
|
+h.v1.positionWorld.copy(L.positionWorld);h.v2.positionWorld.copy(ka.positionWorld);h.v3.positionWorld.copy(za.positionWorld);h.v1.positionScreen.copy(L.positionScreen);h.v2.positionScreen.copy(ka.positionScreen);h.v3.positionScreen.copy(za.positionScreen);h.normalWorld.copy(V.normal);Ma.multiplyVector3(h.normalWorld);h.centroidWorld.copy(V.centroid);xa.multiplyVector3(h.centroidWorld);h.centroidScreen.copy(h.centroidWorld);w.multiplyVector3(h.centroidScreen);h.z=h.centroidScreen.z;h.meshMaterials=
|
|
|
+Ha;h.faceMaterials=V.materials;h.overdraw=Na;if(P.geometry.uvs[N]){h.uvs[0]=P.geometry.uvs[N][0];h.uvs[1]=P.geometry.uvs[N][1];h.uvs[2]=P.geometry.uvs[N][3]}W.push(h);o++;j=m[o]=m[o]||new THREE.RenderableFace3;j.v1.positionWorld.copy(ka.positionWorld);j.v2.positionWorld.copy(sa.positionWorld);j.v3.positionWorld.copy(za.positionWorld);j.v1.positionScreen.copy(ka.positionScreen);j.v2.positionScreen.copy(sa.positionScreen);j.v3.positionScreen.copy(za.positionScreen);j.normalWorld.copy(h.normalWorld);
|
|
|
+j.centroidWorld.copy(h.centroidWorld);j.centroidScreen.copy(h.centroidScreen);j.z=j.centroidScreen.z;j.meshMaterials=Ha;j.faceMaterials=V.materials;j.overdraw=Na;if(P.geometry.uvs[N]){j.uvs[0]=P.geometry.uvs[N][1];j.uvs[1]=P.geometry.uvs[N][2];j.uvs[2]=P.geometry.uvs[N][3]}W.push(j);o++}}}}else if(P instanceof THREE.Line){ga.multiply(w,xa);va=P.geometry.vertices;V=va[0];V.positionScreen.copy(V.position);ga.multiplyVector4(V.positionScreen);N=1;for(Ba=va.length;N<Ba;N++){L=va[N];L.positionScreen.copy(L.position);
|
|
|
+ga.multiplyVector4(L.positionScreen);ka=va[N-1];ha.copy(L.positionScreen);fa.copy(ka.positionScreen);if(b(ha,fa)){ha.multiplyScalar(1/ha.w);fa.multiplyScalar(1/fa.w);u=z[y]=z[y]||new THREE.RenderableLine;u.v1.positionScreen.copy(ha);u.v2.positionScreen.copy(fa);u.z=Math.max(ha.z,fa.z);u.materials=P.materials;W.push(u);y++}}}else if(P instanceof THREE.Particle){H.set(P.position.x,P.position.y,P.position.z,1);w.multiplyVector4(H);H.z/=H.w;if(H.z>0&&H.z<1){A=K[x]=K[x]||new THREE.RenderableParticle;A.x=
|
|
|
+H.x/H.w;A.y=H.y/H.w;A.z=H.z;A.rotation=P.rotation.z;A.scale.x=P.scale.x*Math.abs(A.x-(H.x+c.projectionMatrix.n11)/(H.w+c.projectionMatrix.n14));A.scale.y=P.scale.y*Math.abs(A.y-(H.y+c.projectionMatrix.n22)/(H.w+c.projectionMatrix.n24));A.materials=P.materials;W.push(A);x++}}}}ja&&W.sort(a);return W};this.unprojectVector=function(M,c){var ja=c.matrixWorld.clone();ja.multiplySelf(THREE.Matrix4.makeInvert(c.projectionMatrix));ja.multiplyVector3(M);return M}};
|
|
|
+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,b,d){d&&a.update(undefined,!1,b);d=a.sounds;var e,f=d.length;for(e=0;e<f;e++){a=d[e];this.soundPosition.set(a.matrixWorld.n14,a.matrixWorld.n24,a.matrixWorld.n34);this.soundPosition.subSelf(b.position);if(a.isPlaying&&a.isLoaded){a.isAddedToDOM||a.addToDOM(this.domElement);a.calculateVolumeAndPan(this.soundPosition)}}}};
|
|
|
THREE.ShaderChunk={fog_pars_fragment:"#ifdef USE_FOG\nuniform vec3 fogColor;\n#ifdef FOG_EXP2\nuniform float fogDensity;\n#else\nuniform float fogNear;\nuniform float fogFar;\n#endif\n#endif",fog_fragment:"#ifdef USE_FOG\nfloat depth = gl_FragCoord.z / gl_FragCoord.w;\n#ifdef FOG_EXP2\nconst float LOG2 = 1.442695;\nfloat fogFactor = exp2( - fogDensity * fogDensity * depth * depth * LOG2 );\nfogFactor = 1.0 - clamp( fogFactor, 0.0, 1.0 );\n#else\nfloat fogFactor = smoothstep( fogNear, fogFar, depth );\n#endif\ngl_FragColor = mix( gl_FragColor, vec4( fogColor, gl_FragColor.w ), fogFactor );\n#endif",
|
|
|
envmap_pars_fragment:"#ifdef USE_ENVMAP\nvarying vec3 vReflect;\nuniform float reflectivity;\nuniform samplerCube envMap;\nuniform int combine;\n#endif",envmap_fragment:"#ifdef USE_ENVMAP\nvec4 cubeColor = textureCube( envMap, vec3( -vReflect.x, vReflect.yz ) );\nif ( combine == 1 ) {\ngl_FragColor = vec4( mix( gl_FragColor.xyz, cubeColor.xyz, reflectivity ), opacity );\n} else {\ngl_FragColor = gl_FragColor * cubeColor;\n}\n#endif",envmap_pars_vertex:"#ifdef USE_ENVMAP\nvarying vec3 vReflect;\nuniform float refractionRatio;\nuniform bool useRefract;\n#endif",
|
|
|
envmap_vertex:"#ifdef USE_ENVMAP\nvec4 mPosition = objectMatrix * vec4( position, 1.0 );\nvec3 nWorld = mat3( objectMatrix[0].xyz, objectMatrix[1].xyz, objectMatrix[2].xyz ) * normal;\nif ( useRefract ) {\nvReflect = refract( normalize( mPosition.xyz - cameraPosition ), normalize( nWorld.xyz ), refractionRatio );\n} else {\nvReflect = reflect( normalize( mPosition.xyz - cameraPosition ), normalize( nWorld.xyz ) );\n}\n#endif",map_particle_pars_fragment:"#ifdef USE_MAP\nuniform sampler2D map;\n#endif",
|
|
@@ -146,76 +176,77 @@ THREE.ShaderChunk.color_pars_fragment,THREE.ShaderChunk.map_pars_fragment,THREE.
|
|
|
vertexShader:["#define PHONG\nvarying vec3 vLightWeighting;\nvarying vec3 vViewPosition;\nvarying vec3 vNormal;",THREE.ShaderChunk.map_pars_vertex,THREE.ShaderChunk.lightmap_pars_vertex,THREE.ShaderChunk.envmap_pars_vertex,THREE.ShaderChunk.lights_pars_vertex,THREE.ShaderChunk.color_pars_vertex,THREE.ShaderChunk.skinning_pars_vertex,THREE.ShaderChunk.morphtarget_pars_vertex,"void main() {\nvec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );",THREE.ShaderChunk.map_vertex,THREE.ShaderChunk.lightmap_vertex,
|
|
|
THREE.ShaderChunk.envmap_vertex,THREE.ShaderChunk.color_vertex,"#ifndef USE_ENVMAP\nvec4 mPosition = objectMatrix * vec4( position, 1.0 );\n#endif\nvViewPosition = cameraPosition - mPosition.xyz;\nvec3 transformedNormal = normalize( normalMatrix * normal );\nvNormal = transformedNormal;",THREE.ShaderChunk.lights_vertex,THREE.ShaderChunk.skinning_vertex,THREE.ShaderChunk.morphtarget_vertex,THREE.ShaderChunk.default_vertex,"}"].join("\n")},particle_basic:{uniforms:THREE.UniformsLib.particle,fragmentShader:["uniform vec3 psColor;\nuniform float opacity;",
|
|
|
THREE.ShaderChunk.color_pars_fragment,THREE.ShaderChunk.map_particle_pars_fragment,THREE.ShaderChunk.fog_pars_fragment,"void main() {\ngl_FragColor = vec4( psColor, opacity );",THREE.ShaderChunk.map_particle_fragment,THREE.ShaderChunk.color_fragment,THREE.ShaderChunk.fog_fragment,"}"].join("\n"),vertexShader:["uniform float size;\nuniform float scale;",THREE.ShaderChunk.color_pars_vertex,"void main() {",THREE.ShaderChunk.color_vertex,"vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );\n#ifdef USE_SIZEATTENUATION\ngl_PointSize = size * ( scale / length( mvPosition.xyz ) );\n#else\ngl_PointSize = size;\n#endif\ngl_Position = projectionMatrix * mvPosition;\n}"].join("\n")}};
|
|
|
-THREE.WebGLRenderer=function(a){function b(f,j,k){var h,i,r,n=f.vertices,q=n.length,A=f.colors,C=A.length,p=f.__vertexArray,F=f.__colorArray,N=f.__sortArray,K=f.__dirtyVertices,J=f.__dirtyColors;if(k.sortParticles){Ma.multiplySelf(k.matrixWorld);for(h=0;h<q;h++){i=n[h].position;Ga.copy(i);Ma.multiplyVector3(Ga);N[h]=[Ga.z,h]}N.sort(function(G,P){return P[0]-G[0]});for(h=0;h<q;h++){i=n[N[h][1]].position;r=h*3;p[r]=i.x;p[r+1]=i.y;p[r+2]=i.z}for(h=0;h<C;h++){r=h*3;color=A[N[h][1]];F[r]=color.r;F[r+1]=
|
|
|
-color.g;F[r+2]=color.b}}else{if(K)for(h=0;h<q;h++){i=n[h].position;r=h*3;p[r]=i.x;p[r+1]=i.y;p[r+2]=i.z}if(J)for(h=0;h<C;h++){color=A[h];r=h*3;F[r]=color.r;F[r+1]=color.g;F[r+2]=color.b}}if(K||k.sortParticles){c.bindBuffer(c.ARRAY_BUFFER,f.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,p,j)}if(J||k.sortParticles){c.bindBuffer(c.ARRAY_BUFFER,f.__webGLColorBuffer);c.bufferData(c.ARRAY_BUFFER,F,j)}}function d(f,j){f.fragmentShader=j.fragmentShader;f.vertexShader=j.vertexShader;f.uniforms=Uniforms.clone(j.uniforms)}
|
|
|
-function e(f,j,k,h,i){h.program||ya.initMaterial(h,j,k,i);var r=h.program,n=r.uniforms,q=h.uniforms;if(r!=ra){c.useProgram(r);ra=r}c.uniformMatrix4fv(n.projectionMatrix,!1,Xa);if(k&&(h instanceof THREE.MeshBasicMaterial||h instanceof THREE.MeshLambertMaterial||h instanceof THREE.MeshPhongMaterial||h instanceof THREE.LineBasicMaterial||h instanceof THREE.ParticleBasicMaterial)){q.fogColor.value.setHex(k.color.hex);if(k instanceof THREE.Fog){q.fogNear.value=k.near;q.fogFar.value=k.far}else if(k instanceof
|
|
|
-THREE.FogExp2)q.fogDensity.value=k.density}if(h instanceof THREE.MeshPhongMaterial||h instanceof THREE.MeshLambertMaterial||h.lights){var A,C,p=0,F=0,N=0,K,J,G,P=Ya,Q=P.directional.colors,na=P.directional.positions,u=P.point.colors,la=P.point.positions,fa=0,ka=0;k=C=C=0;for(A=j.length;k<A;k++){C=j[k];K=C.color;J=C.position;G=C.intensity;if(C instanceof THREE.AmbientLight){p+=K.r;F+=K.g;N+=K.b}else if(C instanceof THREE.DirectionalLight){C=fa*3;Q[C]=K.r*G;Q[C+1]=K.g*G;Q[C+2]=K.b*G;na[C]=J.x;na[C+1]=
|
|
|
-J.y;na[C+2]=J.z;fa+=1}else if(C instanceof THREE.PointLight){C=ka*3;u[C]=K.r*G;u[C+1]=K.g*G;u[C+2]=K.b*G;la[C]=J.x;la[C+1]=J.y;la[C+2]=J.z;ka+=1}}for(k=fa*3;k<Q.length;k++)Q[k]=0;for(k=ka*3;k<u.length;k++)u[k]=0;P.point.length=ka;P.directional.length=fa;P.ambient[0]=p;P.ambient[1]=F;P.ambient[2]=N;j=Ya;q.enableLighting.value=j.directional.length+j.point.length;q.ambientLightColor.value=j.ambient;q.directionalLightColor.value=j.directional.colors;q.directionalLightDirection.value=j.directional.positions;
|
|
|
-q.pointLightColor.value=j.point.colors;q.pointLightPosition.value=j.point.positions}if(h instanceof THREE.MeshBasicMaterial||h instanceof THREE.MeshLambertMaterial||h instanceof THREE.MeshPhongMaterial){q.diffuse.value.setRGB(h.color.r*h.opacity,h.color.g*h.opacity,h.color.b*h.opacity);q.opacity.value=h.opacity;q.map.texture=h.map;q.lightMap.texture=h.lightMap;q.envMap.texture=h.envMap;q.reflectivity.value=h.reflectivity;q.refractionRatio.value=h.refractionRatio;q.combine.value=h.combine;q.useRefract.value=
|
|
|
-h.envMap&&h.envMap.mapping instanceof THREE.CubeRefractionMapping}if(h instanceof THREE.LineBasicMaterial){q.diffuse.value.setRGB(h.color.r*h.opacity,h.color.g*h.opacity,h.color.b*h.opacity);q.opacity.value=h.opacity}else if(h instanceof THREE.ParticleBasicMaterial){q.psColor.value.setRGB(h.color.r*h.opacity,h.color.g*h.opacity,h.color.b*h.opacity);q.opacity.value=h.opacity;q.size.value=h.size;q.scale.value=ja.height/2;q.map.texture=h.map}else if(h instanceof THREE.MeshPhongMaterial){q.ambient.value.setRGB(h.ambient.r,
|
|
|
-h.ambient.g,h.ambient.b);q.specular.value.setRGB(h.specular.r,h.specular.g,h.specular.b);q.shininess.value=h.shininess}else if(h instanceof THREE.MeshDepthMaterial){q.mNear.value=f.near;q.mFar.value=f.far;q.opacity.value=h.opacity}else if(h instanceof THREE.MeshNormalMaterial)q.opacity.value=h.opacity;for(var w in q)if(p=r.uniforms[w]){k=q[w];A=k.type;j=k.value;if(A=="i")c.uniform1i(p,j);else if(A=="f")c.uniform1f(p,j);else if(A=="fv1")c.uniform1fv(p,j);else if(A=="fv")c.uniform3fv(p,j);else if(A==
|
|
|
-"v2")c.uniform2f(p,j.x,j.y);else if(A=="v3")c.uniform3f(p,j.x,j.y,j.z);else if(A=="c")c.uniform3f(p,j.r,j.g,j.b);else if(A=="t"){c.uniform1i(p,j);if(k=k.texture)if(k.image instanceof Array&&k.image.length==6){if(k.image.length==6){if(k.needsUpdate){if(k.__wasSetOnce){c.bindTexture(c.TEXTURE_CUBE_MAP,k.image.__webGLTextureCube);for(A=0;A<6;++A)c.texSubImage2D(c.TEXTURE_CUBE_MAP_POSITIVE_X+A,0,0,0,c.RGBA,c.UNSIGNED_BYTE,k.image[A])}else{k.image.__webGLTextureCube=c.createTexture();c.bindTexture(c.TEXTURE_CUBE_MAP,
|
|
|
-k.image.__webGLTextureCube);for(A=0;A<6;++A)c.texImage2D(c.TEXTURE_CUBE_MAP_POSITIVE_X+A,0,c.RGBA,c.RGBA,c.UNSIGNED_BYTE,k.image[A]);k.__wasSetOnce=!0}W(c.TEXTURE_CUBE_MAP,k,k.image[0]);c.bindTexture(c.TEXTURE_CUBE_MAP,null);k.needsUpdate=!1}c.activeTexture(c.TEXTURE0+j);c.bindTexture(c.TEXTURE_CUBE_MAP,k.image.__webGLTextureCube)}}else{if(k.needsUpdate){if(k.__wasSetOnce){c.bindTexture(c.TEXTURE_2D,k.__webGLTexture);c.texSubImage2D(c.TEXTURE_2D,0,0,0,c.RGBA,c.UNSIGNED_BYTE,k.image)}else{k.__webGLTexture=
|
|
|
-c.createTexture();c.bindTexture(c.TEXTURE_2D,k.__webGLTexture);c.texImage2D(c.TEXTURE_2D,0,c.RGBA,c.RGBA,c.UNSIGNED_BYTE,k.image);k.__wasSetOnce=!0}W(c.TEXTURE_2D,k,k.image);c.bindTexture(c.TEXTURE_2D,null);k.needsUpdate=!1}c.activeTexture(c.TEXTURE0+j);c.bindTexture(c.TEXTURE_2D,k.__webGLTexture)}}}c.uniformMatrix4fv(n.modelViewMatrix,!1,i._modelViewMatrixArray);c.uniformMatrix3fv(n.normalMatrix,!1,i._normalMatrixArray);(h instanceof THREE.MeshShaderMaterial||h instanceof THREE.MeshPhongMaterial||
|
|
|
-h.envMap)&&c.uniform3f(n.cameraPosition,f.position.x,f.position.y,f.position.z);(h instanceof THREE.MeshShaderMaterial||h.envMap||h.skinning)&&c.uniformMatrix4fv(n.objectMatrix,!1,i._objectMatrixArray);(h instanceof THREE.MeshPhongMaterial||h instanceof THREE.MeshLambertMaterial||h instanceof THREE.MeshShaderMaterial||h.skinning)&&c.uniformMatrix4fv(n.viewMatrix,!1,Pa);if(h.skinning){c.uniformMatrix4fv(n.cameraInverseMatrix,!1,Pa);c.uniformMatrix4fv(n.boneGlobalMatrices,!1,i.boneMatrices)}return r}
|
|
|
-function g(f,j,k,h,i,r){if(h.opacity!=0){f=e(f,j,k,h,r).attributes;if(h.morphTargets){j=h.program.attributes;r.morphTargetBase!==-1?c.bindBuffer(c.ARRAY_BUFFER,i.__webGLMorphTargetsBuffers[r.morphTargetBase]):c.bindBuffer(c.ARRAY_BUFFER,i.__webGLVertexBuffer);c.vertexAttribPointer(j.position,3,c.FLOAT,!1,0,0);if(r.morphTargetForcedOrder.length){k=0;for(var n=r.morphTargetForcedOrder,q=r.morphTargetInfluences;k<h.numSupportedMorphTargets&&k<n.length;){c.bindBuffer(c.ARRAY_BUFFER,i.__webGLMorphTargetsBuffers[n[k]]);
|
|
|
-c.vertexAttribPointer(j["morphTarget"+k],3,c.FLOAT,!1,0,0);r.__webGLMorphTargetInfluences[k]=q[n[k]];k++}}else{n=[];var A=-1,C=0;q=r.morphTargetInfluences;var p,F=q.length;k=0;for(r.morphTargetBase!==-1&&(n[r.morphTargetBase]=!0);k<h.numSupportedMorphTargets;){for(p=0;p<F;p++)if(!n[p]&&q[p]>A){C=p;A=q[C]}c.bindBuffer(c.ARRAY_BUFFER,i.__webGLMorphTargetsBuffers[C]);c.vertexAttribPointer(j["morphTarget"+k],3,c.FLOAT,!1,0,0);r.__webGLMorphTargetInfluences[k]=A;n[C]=1;A=-1;k++}}c.uniform1fv(h.program.uniforms.morphTargetInfluences,
|
|
|
-r.__webGLMorphTargetInfluences)}else{c.bindBuffer(c.ARRAY_BUFFER,i.__webGLVertexBuffer);c.vertexAttribPointer(f.position,3,c.FLOAT,!1,0,0)}if(f.color>=0){c.bindBuffer(c.ARRAY_BUFFER,i.__webGLColorBuffer);c.vertexAttribPointer(f.color,3,c.FLOAT,!1,0,0)}if(f.normal>=0){c.bindBuffer(c.ARRAY_BUFFER,i.__webGLNormalBuffer);c.vertexAttribPointer(f.normal,3,c.FLOAT,!1,0,0)}if(f.tangent>=0){c.bindBuffer(c.ARRAY_BUFFER,i.__webGLTangentBuffer);c.vertexAttribPointer(f.tangent,4,c.FLOAT,!1,0,0)}if(f.uv>=0)if(i.__webGLUVBuffer){c.bindBuffer(c.ARRAY_BUFFER,
|
|
|
-i.__webGLUVBuffer);c.vertexAttribPointer(f.uv,2,c.FLOAT,!1,0,0);c.enableVertexAttribArray(f.uv)}else c.disableVertexAttribArray(f.uv);if(f.uv2>=0)if(i.__webGLUV2Buffer){c.bindBuffer(c.ARRAY_BUFFER,i.__webGLUV2Buffer);c.vertexAttribPointer(f.uv2,2,c.FLOAT,!1,0,0);c.enableVertexAttribArray(f.uv2)}else c.disableVertexAttribArray(f.uv2);if(h.skinning&&f.skinVertexA>=0&&f.skinVertexB>=0&&f.skinIndex>=0&&f.skinWeight>=0){c.bindBuffer(c.ARRAY_BUFFER,i.__webGLSkinVertexABuffer);c.vertexAttribPointer(f.skinVertexA,
|
|
|
-4,c.FLOAT,!1,0,0);c.bindBuffer(c.ARRAY_BUFFER,i.__webGLSkinVertexBBuffer);c.vertexAttribPointer(f.skinVertexB,4,c.FLOAT,!1,0,0);c.bindBuffer(c.ARRAY_BUFFER,i.__webGLSkinIndicesBuffer);c.vertexAttribPointer(f.skinIndex,4,c.FLOAT,!1,0,0);c.bindBuffer(c.ARRAY_BUFFER,i.__webGLSkinWeightsBuffer);c.vertexAttribPointer(f.skinWeight,4,c.FLOAT,!1,0,0)}if(r instanceof THREE.Mesh)if(h.wireframe){c.lineWidth(h.wireframeLinewidth);c.bindBuffer(c.ELEMENT_ARRAY_BUFFER,i.__webGLLineBuffer);c.drawElements(c.LINES,
|
|
|
-i.__webGLLineCount,c.UNSIGNED_SHORT,0)}else{c.bindBuffer(c.ELEMENT_ARRAY_BUFFER,i.__webGLFaceBuffer);c.drawElements(c.TRIANGLES,i.__webGLFaceCount,c.UNSIGNED_SHORT,0)}else if(r instanceof THREE.Line){r=r.type==THREE.LineStrip?c.LINE_STRIP:c.LINES;c.lineWidth(h.linewidth);c.drawArrays(r,0,i.__webGLLineCount)}else if(r instanceof THREE.ParticleSystem)c.drawArrays(c.POINTS,0,i.__webGLParticleCount);else r instanceof THREE.Ribbon&&c.drawArrays(c.TRIANGLE_STRIP,0,i.__webGLVertexCount)}}function l(f,j){if(!f.__webGLVertexBuffer)f.__webGLVertexBuffer=
|
|
|
-c.createBuffer();if(!f.__webGLNormalBuffer)f.__webGLNormalBuffer=c.createBuffer();if(f.hasPos){c.bindBuffer(c.ARRAY_BUFFER,f.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,f.positionArray,c.DYNAMIC_DRAW);c.enableVertexAttribArray(j.attributes.position);c.vertexAttribPointer(j.attributes.position,3,c.FLOAT,!1,0,0)}if(f.hasNormal){c.bindBuffer(c.ARRAY_BUFFER,f.__webGLNormalBuffer);c.bufferData(c.ARRAY_BUFFER,f.normalArray,c.DYNAMIC_DRAW);c.enableVertexAttribArray(j.attributes.normal);c.vertexAttribPointer(j.attributes.normal,
|
|
|
-3,c.FLOAT,!1,0,0)}c.drawArrays(c.TRIANGLES,0,f.count);f.count=0}function m(f){if(sa!=f.doubleSided){f.doubleSided?c.disable(c.CULL_FACE):c.enable(c.CULL_FACE);sa=f.doubleSided}if(ta!=f.flipSided){f.flipSided?c.frontFace(c.CW):c.frontFace(c.CCW);ta=f.flipSided}}function s(f){if(Fa!=f){f?c.enable(c.DEPTH_TEST):c.disable(c.DEPTH_TEST);Fa=f}}function o(f){ua[0].set(f.n41-f.n11,f.n42-f.n12,f.n43-f.n13,f.n44-f.n14);ua[1].set(f.n41+f.n11,f.n42+f.n12,f.n43+f.n13,f.n44+f.n14);ua[2].set(f.n41+f.n21,f.n42+f.n22,
|
|
|
-f.n43+f.n23,f.n44+f.n24);ua[3].set(f.n41-f.n21,f.n42-f.n22,f.n43-f.n23,f.n44-f.n24);ua[4].set(f.n41-f.n31,f.n42-f.n32,f.n43-f.n33,f.n44-f.n34);ua[5].set(f.n41+f.n31,f.n42+f.n32,f.n43+f.n33,f.n44+f.n34);var j;for(f=0;f<6;f++){j=ua[f];j.divideScalar(Math.sqrt(j.x*j.x+j.y*j.y+j.z*j.z))}}function v(f){for(var j=f.matrixWorld,k=-f.geometry.boundingSphere.radius*Math.max(f.scale.x,Math.max(f.scale.y,f.scale.z)),h=0;h<6;h++){f=ua[h].x*j.n14+ua[h].y*j.n24+ua[h].z*j.n34+ua[h].w;if(f<=k)return!1}return!0}function B(f,
|
|
|
-j){f.list[f.count]=j;f.count+=1}function z(f){var j,k,h=f.object,i=f.opaque,r=f.transparent;r.count=0;f=i.count=0;for(j=h.materials.length;f<j;f++){k=h.materials[f];k.opacity&&k.opacity<1||k.blending!=THREE.NormalBlending?B(r,k):B(i,k)}}function D(f){var j,k,h,i,r=f.object,n=f.buffer,q=f.opaque,A=f.transparent;A.count=0;f=q.count=0;for(h=r.materials.length;f<h;f++){j=r.materials[f];if(j instanceof THREE.MeshFaceMaterial){j=0;for(k=n.materials.length;j<k;j++)(i=n.materials[j])&&(i.opacity&&i.opacity<
|
|
|
-1||i.blending!=THREE.NormalBlending?B(A,i):B(q,i))}else{i=j;i.opacity&&i.opacity<1||i.blending!=THREE.NormalBlending?B(A,i):B(q,i)}}}function E(f,j){return j.z-f.z}function H(f,j){f._modelViewMatrix.multiplyToArray(j.matrixWorldInverse,f.matrixWorld,f._modelViewMatrixArray);THREE.Matrix4.makeInvert3x3(f._modelViewMatrix).transposeIntoArray(f._normalMatrixArray)}function I(f){function j(N){var K=[];k=0;for(h=N.length;k<h;k++)N[k]==undefined?K.push("undefined"):K.push(N[k].id);return K.join("_")}var k,
|
|
|
-h,i,r,n,q,A,C,p={},F=f.morphTargets!==undefined?f.morphTargets.length:0;f.geometryGroups={};i=0;for(r=f.faces.length;i<r;i++){n=f.faces[i];q=n.materials;A=j(q);p[A]==undefined&&(p[A]={hash:A,counter:0});C=p[A].hash+"_"+p[A].counter;f.geometryGroups[C]==undefined&&(f.geometryGroups[C]={faces:[],materials:q,vertices:0,numMorphTargets:F});n=n instanceof THREE.Face3?3:4;if(f.geometryGroups[C].vertices+n>65535){p[A].counter+=1;C=p[A].hash+"_"+p[A].counter;f.geometryGroups[C]==undefined&&(f.geometryGroups[C]=
|
|
|
-{faces:[],materials:q,vertices:0,numMorphTargets:F})}f.geometryGroups[C].faces.push(i);f.geometryGroups[C].vertices+=n}}function L(f,j,k){f.push({buffer:j,object:k,opaque:{list:[],count:0},transparent:{list:[],count:0}})}function M(f){if(f!=Ea){switch(f){case THREE.AdditiveBlending:c.blendEquation(c.FUNC_ADD);c.blendFunc(c.ONE,c.ONE);break;case THREE.SubtractiveBlending:c.blendFunc(c.DST_COLOR,c.ZERO);break;case THREE.BillboardBlending:c.blendEquation(c.FUNC_ADD);c.blendFunc(c.SRC_ALPHA,c.ONE_MINUS_SRC_ALPHA);
|
|
|
-break;case THREE.ReverseSubtractiveBlending:c.blendEquation(c.FUNC_REVERSE_SUBTRACT);c.blendFunc(c.ONE,c.ONE);break;default:c.blendEquation(c.FUNC_ADD);c.blendFunc(c.ONE,c.ONE_MINUS_SRC_ALPHA)}Ea=f}}function W(f,j,k){if((k.width&k.width-1)==0&&(k.height&k.height-1)==0){c.texParameteri(f,c.TEXTURE_WRAP_S,aa(j.wrapS));c.texParameteri(f,c.TEXTURE_WRAP_T,aa(j.wrapT));c.texParameteri(f,c.TEXTURE_MAG_FILTER,aa(j.magFilter));c.texParameteri(f,c.TEXTURE_MIN_FILTER,aa(j.minFilter));c.generateMipmap(f)}else{c.texParameteri(f,
|
|
|
-c.TEXTURE_WRAP_S,c.CLAMP_TO_EDGE);c.texParameteri(f,c.TEXTURE_WRAP_T,c.CLAMP_TO_EDGE);c.texParameteri(f,c.TEXTURE_MAG_FILTER,ea(j.magFilter));c.texParameteri(f,c.TEXTURE_MIN_FILTER,ea(j.minFilter))}}function $(f){if(f&&!f.__webGLFramebuffer){f.__webGLFramebuffer=c.createFramebuffer();f.__webGLRenderbuffer=c.createRenderbuffer();f.__webGLTexture=c.createTexture();c.bindRenderbuffer(c.RENDERBUFFER,f.__webGLRenderbuffer);c.renderbufferStorage(c.RENDERBUFFER,c.DEPTH_COMPONENT16,f.width,f.height);c.bindTexture(c.TEXTURE_2D,
|
|
|
-f.__webGLTexture);c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_S,aa(f.wrapS));c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_T,aa(f.wrapT));c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MAG_FILTER,aa(f.magFilter));c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MIN_FILTER,aa(f.minFilter));c.texImage2D(c.TEXTURE_2D,0,aa(f.format),f.width,f.height,0,aa(f.format),aa(f.type),null);c.bindFramebuffer(c.FRAMEBUFFER,f.__webGLFramebuffer);c.framebufferTexture2D(c.FRAMEBUFFER,c.COLOR_ATTACHMENT0,c.TEXTURE_2D,f.__webGLTexture,
|
|
|
-0);c.framebufferRenderbuffer(c.FRAMEBUFFER,c.DEPTH_ATTACHMENT,c.RENDERBUFFER,f.__webGLRenderbuffer);c.bindTexture(c.TEXTURE_2D,null);c.bindRenderbuffer(c.RENDERBUFFER,null);c.bindFramebuffer(c.FRAMEBUFFER,null)}var j,k;if(f){j=f.__webGLFramebuffer;k=f.width;f=f.height}else{j=null;k=Ka;f=La}if(j!=pa){c.bindFramebuffer(c.FRAMEBUFFER,j);c.viewport(Aa,Ja,k,f);pa=j}}function ia(f,j){var k;if(f=="fragment")k=c.createShader(c.FRAGMENT_SHADER);else f=="vertex"&&(k=c.createShader(c.VERTEX_SHADER));c.shaderSource(k,
|
|
|
-j);c.compileShader(k);if(!c.getShaderParameter(k,c.COMPILE_STATUS)){alert(c.getShaderInfoLog(k));return null}return k}function ea(f){switch(f){case THREE.NearestFilter:case THREE.NearestMipMapNearestFilter:case THREE.NearestMipMapLinearFilter:return c.NEAREST;case THREE.LinearFilter:case THREE.LinearMipMapNearestFilter:case THREE.LinearMipMapLinearFilter:return c.LINEAR}}function aa(f){switch(f){case THREE.RepeatWrapping:return c.REPEAT;case THREE.ClampToEdgeWrapping:return c.CLAMP_TO_EDGE;case THREE.MirroredRepeatWrapping:return c.MIRRORED_REPEAT;
|
|
|
+THREE.WebGLRenderer=function(a){function b(g,l,n){var i,k,s,p=g.vertices,r=p.length,E=g.colors,F=E.length,q=g.__vertexArray,G=g.__colorArray,S=g.__sortArray,Q=g.__dirtyVertices,O=g.__dirtyColors;if(n.sortParticles){Ha.multiplySelf(n.matrixWorld);for(i=0;i<r;i++){k=p[i].position;Fa.copy(k);Ha.multiplyVector3(Fa);S[i]=[Fa.z,i]}S.sort(function(I,X){return X[0]-I[0]});for(i=0;i<r;i++){k=p[S[i][1]].position;s=i*3;q[s]=k.x;q[s+1]=k.y;q[s+2]=k.z}for(i=0;i<F;i++){s=i*3;color=E[S[i][1]];G[s]=color.r;G[s+1]=
|
|
|
+color.g;G[s+2]=color.b}}else{if(Q)for(i=0;i<r;i++){k=p[i].position;s=i*3;q[s]=k.x;q[s+1]=k.y;q[s+2]=k.z}if(O)for(i=0;i<F;i++){color=E[i];s=i*3;G[s]=color.r;G[s+1]=color.g;G[s+2]=color.b}}if(Q||n.sortParticles){c.bindBuffer(c.ARRAY_BUFFER,g.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,q,l)}if(O||n.sortParticles){c.bindBuffer(c.ARRAY_BUFFER,g.__webGLColorBuffer);c.bufferData(c.ARRAY_BUFFER,G,l)}}function d(g,l){g.fragmentShader=l.fragmentShader;g.vertexShader=l.vertexShader;g.uniforms=Uniforms.clone(l.uniforms)}
|
|
|
+function e(g,l,n,i,k){i.program||la.initMaterial(i,l,n,k);var s=i.program,p=s.uniforms,r=i.uniforms;if(s!=ja){c.useProgram(s);ja=s}c.uniformMatrix4fv(p.projectionMatrix,!1,Na);if(n&&(i instanceof THREE.MeshBasicMaterial||i instanceof THREE.MeshLambertMaterial||i instanceof THREE.MeshPhongMaterial||i instanceof THREE.LineBasicMaterial||i instanceof THREE.ParticleBasicMaterial)){r.fogColor.value.setHex(n.color.hex);if(n instanceof THREE.Fog){r.fogNear.value=n.near;r.fogFar.value=n.far}else if(n instanceof
|
|
|
+THREE.FogExp2)r.fogDensity.value=n.density}if(i instanceof THREE.MeshPhongMaterial||i instanceof THREE.MeshLambertMaterial||i.lights){var E,F,q=0,G=0,S=0,Q,O,I,X=va,Y=X.directional.colors,Da=X.directional.positions,v=X.point.colors,Aa=X.point.positions,ra=0,ya=0;n=F=F=0;for(E=l.length;n<E;n++){F=l[n];Q=F.color;O=F.position;I=F.intensity;if(F instanceof THREE.AmbientLight){q+=Q.r;G+=Q.g;S+=Q.b}else if(F instanceof THREE.DirectionalLight){F=ra*3;Y[F]=Q.r*I;Y[F+1]=Q.g*I;Y[F+2]=Q.b*I;Da[F]=O.x;Da[F+1]=
|
|
|
+O.y;Da[F+2]=O.z;ra+=1}else if(F instanceof THREE.PointLight){F=ya*3;v[F]=Q.r*I;v[F+1]=Q.g*I;v[F+2]=Q.b*I;Aa[F]=O.x;Aa[F+1]=O.y;Aa[F+2]=O.z;ya+=1}}for(n=ra*3;n<Y.length;n++)Y[n]=0;for(n=ya*3;n<v.length;n++)v[n]=0;X.point.length=ya;X.directional.length=ra;X.ambient[0]=q;X.ambient[1]=G;X.ambient[2]=S;l=va;r.enableLighting.value=l.directional.length+l.point.length;r.ambientLightColor.value=l.ambient;r.directionalLightColor.value=l.directional.colors;r.directionalLightDirection.value=l.directional.positions;
|
|
|
+r.pointLightColor.value=l.point.colors;r.pointLightPosition.value=l.point.positions}if(i instanceof THREE.MeshBasicMaterial||i instanceof THREE.MeshLambertMaterial||i instanceof THREE.MeshPhongMaterial){r.diffuse.value.setRGB(i.color.r*i.opacity,i.color.g*i.opacity,i.color.b*i.opacity);r.opacity.value=i.opacity;r.map.texture=i.map;r.lightMap.texture=i.lightMap;r.envMap.texture=i.envMap;r.reflectivity.value=i.reflectivity;r.refractionRatio.value=i.refractionRatio;r.combine.value=i.combine;r.useRefract.value=
|
|
|
+i.envMap&&i.envMap.mapping instanceof THREE.CubeRefractionMapping}if(i instanceof THREE.LineBasicMaterial){r.diffuse.value.setRGB(i.color.r*i.opacity,i.color.g*i.opacity,i.color.b*i.opacity);r.opacity.value=i.opacity}else if(i instanceof THREE.ParticleBasicMaterial){r.psColor.value.setRGB(i.color.r*i.opacity,i.color.g*i.opacity,i.color.b*i.opacity);r.opacity.value=i.opacity;r.size.value=i.size;r.scale.value=M.height/2;r.map.texture=i.map}else if(i instanceof THREE.MeshPhongMaterial){r.ambient.value.setRGB(i.ambient.r,
|
|
|
+i.ambient.g,i.ambient.b);r.specular.value.setRGB(i.specular.r,i.specular.g,i.specular.b);r.shininess.value=i.shininess}else if(i instanceof THREE.MeshDepthMaterial){r.mNear.value=g.near;r.mFar.value=g.far;r.opacity.value=i.opacity}else if(i instanceof THREE.MeshNormalMaterial)r.opacity.value=i.opacity;for(var B in r)if(q=s.uniforms[B]){n=r[B];E=n.type;l=n.value;if(E=="i")c.uniform1i(q,l);else if(E=="f")c.uniform1f(q,l);else if(E=="fv1")c.uniform1fv(q,l);else if(E=="fv")c.uniform3fv(q,l);else if(E==
|
|
|
+"v2")c.uniform2f(q,l.x,l.y);else if(E=="v3")c.uniform3f(q,l.x,l.y,l.z);else if(E=="c")c.uniform3f(q,l.r,l.g,l.b);else if(E=="t"){c.uniform1i(q,l);if(n=n.texture)if(n.image instanceof Array&&n.image.length==6){if(n.image.length==6){if(n.needsUpdate){if(n.__wasSetOnce){c.bindTexture(c.TEXTURE_CUBE_MAP,n.image.__webGLTextureCube);for(E=0;E<6;++E)c.texSubImage2D(c.TEXTURE_CUBE_MAP_POSITIVE_X+E,0,0,0,c.RGBA,c.UNSIGNED_BYTE,n.image[E])}else{n.image.__webGLTextureCube=c.createTexture();c.bindTexture(c.TEXTURE_CUBE_MAP,
|
|
|
+n.image.__webGLTextureCube);for(E=0;E<6;++E)c.texImage2D(c.TEXTURE_CUBE_MAP_POSITIVE_X+E,0,c.RGBA,c.RGBA,c.UNSIGNED_BYTE,n.image[E]);n.__wasSetOnce=!0}ga(c.TEXTURE_CUBE_MAP,n,n.image[0]);c.bindTexture(c.TEXTURE_CUBE_MAP,null);n.needsUpdate=!1}c.activeTexture(c.TEXTURE0+l);c.bindTexture(c.TEXTURE_CUBE_MAP,n.image.__webGLTextureCube)}}else{if(n.needsUpdate){if(n.__wasSetOnce){c.bindTexture(c.TEXTURE_2D,n.__webGLTexture);c.texSubImage2D(c.TEXTURE_2D,0,0,0,c.RGBA,c.UNSIGNED_BYTE,n.image)}else{n.__webGLTexture=
|
|
|
+c.createTexture();c.bindTexture(c.TEXTURE_2D,n.__webGLTexture);c.texImage2D(c.TEXTURE_2D,0,c.RGBA,c.RGBA,c.UNSIGNED_BYTE,n.image);n.__wasSetOnce=!0}ga(c.TEXTURE_2D,n,n.image);c.bindTexture(c.TEXTURE_2D,null);n.needsUpdate=!1}c.activeTexture(c.TEXTURE0+l);c.bindTexture(c.TEXTURE_2D,n.__webGLTexture)}}}c.uniformMatrix4fv(p.modelViewMatrix,!1,k._modelViewMatrixArray);c.uniformMatrix3fv(p.normalMatrix,!1,k._normalMatrixArray);(i instanceof THREE.MeshShaderMaterial||i instanceof THREE.MeshPhongMaterial||
|
|
|
+i.envMap)&&c.uniform3f(p.cameraPosition,g.position.x,g.position.y,g.position.z);(i instanceof THREE.MeshShaderMaterial||i.envMap||i.skinning)&&c.uniformMatrix4fv(p.objectMatrix,!1,k._objectMatrixArray);(i instanceof THREE.MeshPhongMaterial||i instanceof THREE.MeshLambertMaterial||i instanceof THREE.MeshShaderMaterial||i.skinning)&&c.uniformMatrix4fv(p.viewMatrix,!1,Ma);if(i.skinning){c.uniformMatrix4fv(p.cameraInverseMatrix,!1,Ma);c.uniformMatrix4fv(p.boneGlobalMatrices,!1,k.boneMatrices)}return s}
|
|
|
+function f(g,l,n,i,k,s){if(i.opacity!=0){g=e(g,l,n,i,s).attributes;if(i.morphTargets){l=i.program.attributes;s.morphTargetBase!==-1?c.bindBuffer(c.ARRAY_BUFFER,k.__webGLMorphTargetsBuffers[s.morphTargetBase]):c.bindBuffer(c.ARRAY_BUFFER,k.__webGLVertexBuffer);c.vertexAttribPointer(l.position,3,c.FLOAT,!1,0,0);if(s.morphTargetForcedOrder.length){n=0;for(var p=s.morphTargetForcedOrder,r=s.morphTargetInfluences;n<i.numSupportedMorphTargets&&n<p.length;){c.bindBuffer(c.ARRAY_BUFFER,k.__webGLMorphTargetsBuffers[p[n]]);
|
|
|
+c.vertexAttribPointer(l["morphTarget"+n],3,c.FLOAT,!1,0,0);s.__webGLMorphTargetInfluences[n]=r[p[n]];n++}}else{p=[];var E=-1,F=0;r=s.morphTargetInfluences;var q,G=r.length;n=0;for(s.morphTargetBase!==-1&&(p[s.morphTargetBase]=!0);n<i.numSupportedMorphTargets;){for(q=0;q<G;q++)if(!p[q]&&r[q]>E){F=q;E=r[F]}c.bindBuffer(c.ARRAY_BUFFER,k.__webGLMorphTargetsBuffers[F]);c.vertexAttribPointer(l["morphTarget"+n],3,c.FLOAT,!1,0,0);s.__webGLMorphTargetInfluences[n]=E;p[F]=1;E=-1;n++}}c.uniform1fv(i.program.uniforms.morphTargetInfluences,
|
|
|
+s.__webGLMorphTargetInfluences)}else{c.bindBuffer(c.ARRAY_BUFFER,k.__webGLVertexBuffer);c.vertexAttribPointer(g.position,3,c.FLOAT,!1,0,0)}if(g.color>=0){c.bindBuffer(c.ARRAY_BUFFER,k.__webGLColorBuffer);c.vertexAttribPointer(g.color,3,c.FLOAT,!1,0,0)}if(g.normal>=0){c.bindBuffer(c.ARRAY_BUFFER,k.__webGLNormalBuffer);c.vertexAttribPointer(g.normal,3,c.FLOAT,!1,0,0)}if(g.tangent>=0){c.bindBuffer(c.ARRAY_BUFFER,k.__webGLTangentBuffer);c.vertexAttribPointer(g.tangent,4,c.FLOAT,!1,0,0)}if(g.uv>=0)if(k.__webGLUVBuffer){c.bindBuffer(c.ARRAY_BUFFER,
|
|
|
+k.__webGLUVBuffer);c.vertexAttribPointer(g.uv,2,c.FLOAT,!1,0,0);c.enableVertexAttribArray(g.uv)}else c.disableVertexAttribArray(g.uv);if(g.uv2>=0)if(k.__webGLUV2Buffer){c.bindBuffer(c.ARRAY_BUFFER,k.__webGLUV2Buffer);c.vertexAttribPointer(g.uv2,2,c.FLOAT,!1,0,0);c.enableVertexAttribArray(g.uv2)}else c.disableVertexAttribArray(g.uv2);if(i.skinning&&g.skinVertexA>=0&&g.skinVertexB>=0&&g.skinIndex>=0&&g.skinWeight>=0){c.bindBuffer(c.ARRAY_BUFFER,k.__webGLSkinVertexABuffer);c.vertexAttribPointer(g.skinVertexA,
|
|
|
+4,c.FLOAT,!1,0,0);c.bindBuffer(c.ARRAY_BUFFER,k.__webGLSkinVertexBBuffer);c.vertexAttribPointer(g.skinVertexB,4,c.FLOAT,!1,0,0);c.bindBuffer(c.ARRAY_BUFFER,k.__webGLSkinIndicesBuffer);c.vertexAttribPointer(g.skinIndex,4,c.FLOAT,!1,0,0);c.bindBuffer(c.ARRAY_BUFFER,k.__webGLSkinWeightsBuffer);c.vertexAttribPointer(g.skinWeight,4,c.FLOAT,!1,0,0)}if(s instanceof THREE.Mesh)if(i.wireframe){c.lineWidth(i.wireframeLinewidth);c.bindBuffer(c.ELEMENT_ARRAY_BUFFER,k.__webGLLineBuffer);c.drawElements(c.LINES,
|
|
|
+k.__webGLLineCount,c.UNSIGNED_SHORT,0)}else{c.bindBuffer(c.ELEMENT_ARRAY_BUFFER,k.__webGLFaceBuffer);c.drawElements(c.TRIANGLES,k.__webGLFaceCount,c.UNSIGNED_SHORT,0)}else if(s instanceof THREE.Line){s=s.type==THREE.LineStrip?c.LINE_STRIP:c.LINES;c.lineWidth(i.linewidth);c.drawArrays(s,0,k.__webGLLineCount)}else if(s instanceof THREE.ParticleSystem)c.drawArrays(c.POINTS,0,k.__webGLParticleCount);else s instanceof THREE.Ribbon&&c.drawArrays(c.TRIANGLE_STRIP,0,k.__webGLVertexCount)}}function h(g,l){if(!g.__webGLVertexBuffer)g.__webGLVertexBuffer=
|
|
|
+c.createBuffer();if(!g.__webGLNormalBuffer)g.__webGLNormalBuffer=c.createBuffer();if(g.hasPos){c.bindBuffer(c.ARRAY_BUFFER,g.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,g.positionArray,c.DYNAMIC_DRAW);c.enableVertexAttribArray(l.attributes.position);c.vertexAttribPointer(l.attributes.position,3,c.FLOAT,!1,0,0)}if(g.hasNormal){c.bindBuffer(c.ARRAY_BUFFER,g.__webGLNormalBuffer);c.bufferData(c.ARRAY_BUFFER,g.normalArray,c.DYNAMIC_DRAW);c.enableVertexAttribArray(l.attributes.normal);c.vertexAttribPointer(l.attributes.normal,
|
|
|
+3,c.FLOAT,!1,0,0)}c.drawArrays(c.TRIANGLES,0,g.count);g.count=0}function j(g){if(Z!=g.doubleSided){g.doubleSided?c.disable(c.CULL_FACE):c.enable(c.CULL_FACE);Z=g.doubleSided}if(R!=g.flipSided){g.flipSided?c.frontFace(c.CW):c.frontFace(c.CCW);R=g.flipSided}}function o(g){if(Ba!=g){g?c.enable(c.DEPTH_TEST):c.disable(c.DEPTH_TEST);Ba=g}}function m(g){xa[0].set(g.n41-g.n11,g.n42-g.n12,g.n43-g.n13,g.n44-g.n14);xa[1].set(g.n41+g.n11,g.n42+g.n12,g.n43+g.n13,g.n44+g.n14);xa[2].set(g.n41+g.n21,g.n42+g.n22,
|
|
|
+g.n43+g.n23,g.n44+g.n24);xa[3].set(g.n41-g.n21,g.n42-g.n22,g.n43-g.n23,g.n44-g.n24);xa[4].set(g.n41-g.n31,g.n42-g.n32,g.n43-g.n33,g.n44-g.n34);xa[5].set(g.n41+g.n31,g.n42+g.n32,g.n43+g.n33,g.n44+g.n34);var l;for(g=0;g<6;g++){l=xa[g];l.divideScalar(Math.sqrt(l.x*l.x+l.y*l.y+l.z*l.z))}}function u(g){for(var l=g.matrixWorld,n=-g.geometry.boundingSphere.radius*Math.max(g.scale.x,Math.max(g.scale.y,g.scale.z)),i=0;i<6;i++){g=xa[i].x*l.n14+xa[i].y*l.n24+xa[i].z*l.n34+xa[i].w;if(g<=n)return!1}return!0}function y(g,
|
|
|
+l){g.list[g.count]=l;g.count+=1}function z(g){var l,n,i=g.object,k=g.opaque,s=g.transparent;s.count=0;g=k.count=0;for(l=i.materials.length;g<l;g++){n=i.materials[g];n.opacity&&n.opacity<1||n.blending!=THREE.NormalBlending?y(s,n):y(k,n)}}function A(g){var l,n,i,k,s=g.object,p=g.buffer,r=g.opaque,E=g.transparent;E.count=0;g=r.count=0;for(i=s.materials.length;g<i;g++){l=s.materials[g];if(l instanceof THREE.MeshFaceMaterial){l=0;for(n=p.materials.length;l<n;l++)(k=p.materials[l])&&(k.opacity&&k.opacity<
|
|
|
+1||k.blending!=THREE.NormalBlending?y(E,k):y(r,k))}else{k=l;k.opacity&&k.opacity<1||k.blending!=THREE.NormalBlending?y(E,k):y(r,k)}}}function x(g,l){return l.z-g.z}function K(g,l){g._modelViewMatrix.multiplyToArray(l.matrixWorldInverse,g.matrixWorld,g._modelViewMatrixArray);THREE.Matrix4.makeInvert3x3(g._modelViewMatrix).transposeIntoArray(g._normalMatrixArray)}function J(g){function l(S){var Q=[];n=0;for(i=S.length;n<i;n++)S[n]==undefined?Q.push("undefined"):Q.push(S[n].id);return Q.join("_")}var n,
|
|
|
+i,k,s,p,r,E,F,q={},G=g.morphTargets!==undefined?g.morphTargets.length:0;g.geometryGroups={};k=0;for(s=g.faces.length;k<s;k++){p=g.faces[k];r=p.materials;E=l(r);q[E]==undefined&&(q[E]={hash:E,counter:0});F=q[E].hash+"_"+q[E].counter;g.geometryGroups[F]==undefined&&(g.geometryGroups[F]={faces:[],materials:r,vertices:0,numMorphTargets:G});p=p instanceof THREE.Face3?3:4;if(g.geometryGroups[F].vertices+p>65535){q[E].counter+=1;F=q[E].hash+"_"+q[E].counter;g.geometryGroups[F]==undefined&&(g.geometryGroups[F]=
|
|
|
+{faces:[],materials:r,vertices:0,numMorphTargets:G})}g.geometryGroups[F].faces.push(k);g.geometryGroups[F].vertices+=p}}function H(g,l,n){g.push({buffer:l,object:n,opaque:{list:[],count:0},transparent:{list:[],count:0}})}function w(g){if(g!=N){switch(g){case THREE.AdditiveBlending:c.blendEquation(c.FUNC_ADD);c.blendFunc(c.ONE,c.ONE);break;case THREE.SubtractiveBlending:c.blendFunc(c.DST_COLOR,c.ZERO);break;case THREE.BillboardBlending:c.blendEquation(c.FUNC_ADD);c.blendFunc(c.SRC_ALPHA,c.ONE_MINUS_SRC_ALPHA);
|
|
|
+break;case THREE.ReverseSubtractiveBlending:c.blendEquation(c.FUNC_REVERSE_SUBTRACT);c.blendFunc(c.ONE,c.ONE);break;default:c.blendEquation(c.FUNC_ADD);c.blendFunc(c.ONE,c.ONE_MINUS_SRC_ALPHA)}N=g}}function ga(g,l,n){if((n.width&n.width-1)==0&&(n.height&n.height-1)==0){c.texParameteri(g,c.TEXTURE_WRAP_S,ia(l.wrapS));c.texParameteri(g,c.TEXTURE_WRAP_T,ia(l.wrapT));c.texParameteri(g,c.TEXTURE_MAG_FILTER,ia(l.magFilter));c.texParameteri(g,c.TEXTURE_MIN_FILTER,ia(l.minFilter));c.generateMipmap(g)}else{c.texParameteri(g,
|
|
|
+c.TEXTURE_WRAP_S,c.CLAMP_TO_EDGE);c.texParameteri(g,c.TEXTURE_WRAP_T,c.CLAMP_TO_EDGE);c.texParameteri(g,c.TEXTURE_MAG_FILTER,fa(l.magFilter));c.texParameteri(g,c.TEXTURE_MIN_FILTER,fa(l.minFilter))}}function U(g){if(g&&!g.__webGLFramebuffer){g.__webGLFramebuffer=c.createFramebuffer();g.__webGLRenderbuffer=c.createRenderbuffer();g.__webGLTexture=c.createTexture();c.bindRenderbuffer(c.RENDERBUFFER,g.__webGLRenderbuffer);c.renderbufferStorage(c.RENDERBUFFER,c.DEPTH_COMPONENT16,g.width,g.height);c.bindTexture(c.TEXTURE_2D,
|
|
|
+g.__webGLTexture);c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_S,ia(g.wrapS));c.texParameteri(c.TEXTURE_2D,c.TEXTURE_WRAP_T,ia(g.wrapT));c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MAG_FILTER,ia(g.magFilter));c.texParameteri(c.TEXTURE_2D,c.TEXTURE_MIN_FILTER,ia(g.minFilter));c.texImage2D(c.TEXTURE_2D,0,ia(g.format),g.width,g.height,0,ia(g.format),ia(g.type),null);c.bindFramebuffer(c.FRAMEBUFFER,g.__webGLFramebuffer);c.framebufferTexture2D(c.FRAMEBUFFER,c.COLOR_ATTACHMENT0,c.TEXTURE_2D,g.__webGLTexture,
|
|
|
+0);c.framebufferRenderbuffer(c.FRAMEBUFFER,c.DEPTH_ATTACHMENT,c.RENDERBUFFER,g.__webGLRenderbuffer);c.bindTexture(c.TEXTURE_2D,null);c.bindRenderbuffer(c.RENDERBUFFER,null);c.bindFramebuffer(c.FRAMEBUFFER,null)}var l,n;if(g){l=g.__webGLFramebuffer;n=g.width;g=g.height}else{l=null;n=wa;g=P}if(l!=W){c.bindFramebuffer(c.FRAMEBUFFER,l);c.viewport(L,ka,n,g);W=l}}function ha(g,l){var n;if(g=="fragment")n=c.createShader(c.FRAGMENT_SHADER);else g=="vertex"&&(n=c.createShader(c.VERTEX_SHADER));c.shaderSource(n,
|
|
|
+l);c.compileShader(n);if(!c.getShaderParameter(n,c.COMPILE_STATUS)){alert(c.getShaderInfoLog(n));return null}return n}function fa(g){switch(g){case THREE.NearestFilter:case THREE.NearestMipMapNearestFilter:case THREE.NearestMipMapLinearFilter:return c.NEAREST;case THREE.LinearFilter:case THREE.LinearMipMapNearestFilter:case THREE.LinearMipMapLinearFilter:return c.LINEAR}}function ia(g){switch(g){case THREE.RepeatWrapping:return c.REPEAT;case THREE.ClampToEdgeWrapping:return c.CLAMP_TO_EDGE;case THREE.MirroredRepeatWrapping:return c.MIRRORED_REPEAT;
|
|
|
case THREE.NearestFilter:return c.NEAREST;case THREE.NearestMipMapNearestFilter:return c.NEAREST_MIPMAP_NEAREST;case THREE.NearestMipMapLinearFilter:return c.NEAREST_MIPMAP_LINEAR;case THREE.LinearFilter:return c.LINEAR;case THREE.LinearMipMapNearestFilter:return c.LINEAR_MIPMAP_NEAREST;case THREE.LinearMipMapLinearFilter:return c.LINEAR_MIPMAP_LINEAR;case THREE.ByteType:return c.BYTE;case THREE.UnsignedByteType:return c.UNSIGNED_BYTE;case THREE.ShortType:return c.SHORT;case THREE.UnsignedShortType:return c.UNSIGNED_SHORT;
|
|
|
-case THREE.IntType:return c.INT;case THREE.UnsignedShortType:return c.UNSIGNED_INT;case THREE.FloatType:return c.FLOAT;case THREE.AlphaFormat:return c.ALPHA;case THREE.RGBFormat:return c.RGB;case THREE.RGBAFormat:return c.RGBA;case THREE.LuminanceFormat:return c.LUMINANCE;case THREE.LuminanceAlphaFormat:return c.LUMINANCE_ALPHA}return 0}var ja=document.createElement("canvas"),c,ra=null,pa=null,ya=this,sa=null,ta=null,Ea=null,Fa=null,Aa=0,Ja=0,Ka=0,La=0,ua=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,
|
|
|
-new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],Ma=new THREE.Matrix4,Xa=new Float32Array(16),Pa=new Float32Array(16),Ga=new THREE.Vector4,Ya={ambient:[0,0,0],directional:{length:0,colors:[],positions:[]},point:{length:0,colors:[],positions:[]}},Za=!0,$a=new THREE.Color(0),ab=0;if(a){if(a.antialias!==undefined)Za=a.antialias;a.clearColor!==undefined&&$a.setHex(a.clearColor);if(a.clearAlpha!==undefined)ab=a.clearAlpha}this.maxMorphTargets=8;this.domElement=ja;this.autoClear=!0;this.sortObjects=
|
|
|
-!0;(function(f,j,k){try{if(!(c=ja.getContext("experimental-webgl",{antialias:f})))throw"Error creating WebGL context.";}catch(h){console.error(h)}c.clearColor(0,0,0,1);c.clearDepth(1);c.enable(c.DEPTH_TEST);c.depthFunc(c.LEQUAL);c.frontFace(c.CCW);c.cullFace(c.BACK);c.enable(c.CULL_FACE);c.enable(c.BLEND);c.blendFunc(c.ONE,c.ONE_MINUS_SRC_ALPHA);c.clearColor(j.r,j.g,j.b,k);_cullEnabled=!0})(Za,$a,ab);this.context=c;this.setSize=function(f,j){ja.width=f;ja.height=j;this.setViewport(0,0,ja.width,ja.height)};
|
|
|
-this.setViewport=function(f,j,k,h){Aa=f;Ja=j;Ka=k;La=h;c.viewport(Aa,Ja,Ka,La)};this.setScissor=function(f,j,k,h){c.scissor(f,j,k,h)};this.enableScissorTest=function(f){f?c.enable(c.SCISSOR_TEST):c.disable(c.SCISSOR_TEST)};this.enableDepthBufferWrite=function(f){c.depthMask(f)};this.setClearColorHex=function(f,j){var k=new THREE.Color(f);c.clearColor(k.r,k.g,k.b,j)};this.setClearColor=function(f,j){c.clearColor(f.r,f.g,f.b,j)};this.clear=function(){c.clear(c.COLOR_BUFFER_BIT|c.DEPTH_BUFFER_BIT)};
|
|
|
-this.initMaterial=function(f,j,k,h){var i,r,n;if(f instanceof THREE.MeshDepthMaterial)d(f,THREE.ShaderLib.depth);else if(f instanceof THREE.MeshNormalMaterial)d(f,THREE.ShaderLib.normal);else if(f instanceof THREE.MeshBasicMaterial)d(f,THREE.ShaderLib.basic);else if(f instanceof THREE.MeshLambertMaterial)d(f,THREE.ShaderLib.lambert);else if(f instanceof THREE.MeshPhongMaterial)d(f,THREE.ShaderLib.phong);else if(f instanceof THREE.LineBasicMaterial)d(f,THREE.ShaderLib.basic);else f instanceof THREE.ParticleBasicMaterial&&
|
|
|
-d(f,THREE.ShaderLib.particle_basic);var q,A,C,p;n=C=p=0;for(q=j.length;n<q;n++){A=j[n];A instanceof THREE.DirectionalLight&&C++;A instanceof THREE.PointLight&&p++}if(p+C<=4)j=C;else{j=Math.ceil(4*C/(p+C));p=4-j}n={directional:j,point:p};q=50;if(h!==undefined&&h instanceof THREE.SkinnedMesh)q=h.bones.length;p=f.fragmentShader;j=f.vertexShader;q={fog:k,map:f.map,envMap:f.envMap,lightMap:f.lightMap,vertexColors:f.vertexColors,sizeAttenuation:f.sizeAttenuation,skinning:f.skinning,morphTargets:f.morphTargets,
|
|
|
-maxDirLights:n.directional,maxPointLights:n.point,maxBones:q};k=c.createProgram();n=["#ifdef GL_ES\nprecision highp float;\n#endif","#define MAX_DIR_LIGHTS "+q.maxDirLights,"#define MAX_POINT_LIGHTS "+q.maxPointLights,q.fog?"#define USE_FOG":"",q.fog instanceof THREE.FogExp2?"#define FOG_EXP2":"",q.map?"#define USE_MAP":"",q.envMap?"#define USE_ENVMAP":"",q.lightMap?"#define USE_LIGHTMAP":"",q.vertexColors?"#define USE_COLOR":"","uniform mat4 viewMatrix;\nuniform vec3 cameraPosition;\n"].join("\n");
|
|
|
-q=[c.getParameter(c.MAX_VERTEX_TEXTURE_IMAGE_UNITS)>0?"#define VERTEX_TEXTURES":"","#define MAX_DIR_LIGHTS "+q.maxDirLights,"#define MAX_POINT_LIGHTS "+q.maxPointLights,"#define MAX_BONES "+q.maxBones,q.map?"#define USE_MAP":"",q.envMap?"#define USE_ENVMAP":"",q.lightMap?"#define USE_LIGHTMAP":"",q.vertexColors?"#define USE_COLOR":"",q.skinning?"#define USE_SKINNING":"",q.morphTargets?"#define USE_MORPHTARGETS":"",q.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 morphTarget0;\nattribute vec3 morphTarget1;\nattribute vec3 morphTarget2;\nattribute vec3 morphTarget3;\nattribute vec3 morphTarget4;\nattribute vec3 morphTarget5;\nattribute vec3 morphTarget6;\nattribute vec3 morphTarget7;\nattribute vec3 normal;\nattribute vec3 color;\nattribute vec2 uv;\nattribute vec2 uv2;\nattribute vec4 skinVertexA;\nattribute vec4 skinVertexB;\nattribute vec4 skinIndex;\nattribute vec4 skinWeight;\n"].join("\n");
|
|
|
-c.attachShader(k,ia("fragment",n+p));c.attachShader(k,ia("vertex",q+j));c.linkProgram(k);c.getProgramParameter(k,c.LINK_STATUS)||alert("Could not initialise shaders\nVALIDATE_STATUS: "+c.getProgramParameter(k,c.VALIDATE_STATUS)+", gl error ["+c.getError()+"]");k.uniforms={};k.attributes={};f.program=k;k=["viewMatrix","modelViewMatrix","projectionMatrix","normalMatrix","objectMatrix","cameraPosition","cameraInverseMatrix","boneGlobalMatrices","morphTargetInfluences"];for(i in f.uniforms)k.push(i);
|
|
|
-i=f.program;p=0;for(j=k.length;p<j;p++){n=k[p];i.uniforms[n]=c.getUniformLocation(i,n)}k=["position","normal","uv","uv2","tangent","color","skinVertexA","skinVertexB","skinIndex","skinWeight"];for(i=0;i<this.maxMorphTargets;i++)k.push("morphTarget"+i);for(r in f.attributes)k.push(r);r=f.program;i=k;k=0;for(p=i.length;k<p;k++){j=i[k];r.attributes[j]=c.getAttribLocation(r,j)}r=f.program.attributes;c.enableVertexAttribArray(r.position);r.color>=0&&c.enableVertexAttribArray(r.color);r.normal>=0&&c.enableVertexAttribArray(r.normal);
|
|
|
-r.tangent>=0&&c.enableVertexAttribArray(r.tangent);if(f.skinning&&r.skinVertexA>=0&&r.skinVertexB>=0&&r.skinIndex>=0&&r.skinWeight>=0){c.enableVertexAttribArray(r.skinVertexA);c.enableVertexAttribArray(r.skinVertexB);c.enableVertexAttribArray(r.skinIndex);c.enableVertexAttribArray(r.skinWeight)}if(f.morphTargets){f.numSupportedMorphTargets=0;if(r.morphTarget0>=0){c.enableVertexAttribArray(r.morphTarget0);f.numSupportedMorphTargets++}if(r.morphTarget1>=0){c.enableVertexAttribArray(r.morphTarget1);
|
|
|
-f.numSupportedMorphTargets++}if(r.morphTarget2>=0){c.enableVertexAttribArray(r.morphTarget2);f.numSupportedMorphTargets++}if(r.morphTarget3>=0){c.enableVertexAttribArray(r.morphTarget3);f.numSupportedMorphTargets++}if(r.morphTarget4>=0){c.enableVertexAttribArray(r.morphTarget4);f.numSupportedMorphTargets++}if(r.morphTarget5>=0){c.enableVertexAttribArray(r.morphTarget5);f.numSupportedMorphTargets++}if(r.morphTarget6>=0){c.enableVertexAttribArray(r.morphTarget6);f.numSupportedMorphTargets++}if(r.morphTarget7>=
|
|
|
-0){c.enableVertexAttribArray(r.morphTarget7);f.numSupportedMorphTargets++}h.__webGLMorphTargetInfluences=new Float32Array(this.maxMorphTargets);for(i=0;i<this.maxMorphTargets;i++)h.__webGLMorphTargetInfluences[i]=0}};this.render=function(f,j,k,h){var i,r,n,q,A,C,p,F,N=f.lights,K=f.fog;j.matrixAutoUpdate&&j.updateMatrix();f.update(undefined,!1,j);j.matrixWorldInverse.flattenToArray(Pa);j.projectionMatrix.flattenToArray(Xa);Ma.multiply(j.projectionMatrix,j.matrixWorldInverse);o(Ma);this.initWebGLObjects(f);
|
|
|
-$(k);(this.autoClear||h)&&this.clear();A=f.__webglObjects.length;for(h=0;h<A;h++){i=f.__webglObjects[h];p=i.object;if(p.visible)if(!(p instanceof THREE.Mesh)||v(p)){p.matrixWorld.flattenToArray(p._objectMatrixArray);H(p,j);D(i);i.render=!0;if(this.sortObjects){Ga.copy(p.position);Ma.multiplyVector3(Ga);i.z=Ga.z}}else i.render=!1;else i.render=!1}this.sortObjects&&f.__webglObjects.sort(E);C=f.__webglObjectsImmediate.length;for(h=0;h<C;h++){i=f.__webglObjectsImmediate[h];p=i.object;if(p.visible){p.matrixAutoUpdate&&
|
|
|
-p.matrixWorld.flattenToArray(p._objectMatrixArray);H(p,j);z(i)}}M(THREE.NormalBlending);for(h=0;h<A;h++){i=f.__webglObjects[h];if(i.render){p=i.object;F=i.buffer;n=i.opaque;m(p);for(i=0;i<n.count;i++){q=n.list[i];s(q.depthTest);g(j,N,K,q,F,p)}}}for(h=0;h<C;h++){i=f.__webglObjectsImmediate[h];p=i.object;if(p.visible){n=i.opaque;m(p);for(i=0;i<n.count;i++){q=n.list[i];s(q.depthTest);r=e(j,N,K,q,p);p.render(function(J){l(J,r)})}}}for(h=0;h<A;h++){i=f.__webglObjects[h];if(i.render){p=i.object;F=i.buffer;
|
|
|
-n=i.transparent;m(p);for(i=0;i<n.count;i++){q=n.list[i];M(q.blending);s(q.depthTest);g(j,N,K,q,F,p)}}}for(h=0;h<C;h++){i=f.__webglObjectsImmediate[h];p=i.object;if(p.visible){n=i.transparent;m(p);for(i=0;i<n.count;i++){q=n.list[i];M(q.blending);s(q.depthTest);r=e(j,N,K,q,p);p.render(function(J){l(J,r)})}}}if(k&&k.minFilter!==THREE.NearestFilter&&k.minFilter!==THREE.LinearFilter){c.bindTexture(c.TEXTURE_2D,k.__webGLTexture);c.generateMipmap(c.TEXTURE_2D);c.bindTexture(c.TEXTURE_2D,null)}};this.initWebGLObjects=
|
|
|
-function(f){if(!f.__webglObjects){f.__webglObjects=[];f.__webglObjectsImmediate=[]}for(;f.__objectsAdded.length;){var j=f.__objectsAdded[0],k=f,h=void 0,i=void 0,r=void 0;if(j._modelViewMatrix==undefined){j._modelViewMatrix=new THREE.Matrix4;j._normalMatrixArray=new Float32Array(9);j._modelViewMatrixArray=new Float32Array(16);j._objectMatrixArray=new Float32Array(16);j.matrixWorld.flattenToArray(j._objectMatrixArray)}if(j instanceof THREE.Mesh){i=j.geometry;i.geometryGroups==undefined&&I(i);for(h in i.geometryGroups){r=
|
|
|
-i.geometryGroups[h];if(!r.__webGLVertexBuffer){var n=r;n.__webGLVertexBuffer=c.createBuffer();n.__webGLNormalBuffer=c.createBuffer();n.__webGLTangentBuffer=c.createBuffer();n.__webGLColorBuffer=c.createBuffer();n.__webGLUVBuffer=c.createBuffer();n.__webGLUV2Buffer=c.createBuffer();n.__webGLSkinVertexABuffer=c.createBuffer();n.__webGLSkinVertexBBuffer=c.createBuffer();n.__webGLSkinIndicesBuffer=c.createBuffer();n.__webGLSkinWeightsBuffer=c.createBuffer();n.__webGLFaceBuffer=c.createBuffer();n.__webGLLineBuffer=
|
|
|
-c.createBuffer();if(n.numMorphTargets){var q=void 0,A=void 0;n.__webGLMorphTargetsBuffers=[];q=0;for(A=n.numMorphTargets;q<A;q++)n.__webGLMorphTargetsBuffers.push(c.createBuffer())}n=r;var C=j,p=void 0,F=void 0,N=A=q=0,K=C.geometry.faces,J=n.faces;p=0;for(F=J.length;p<F;p++){fi=J[p];face=K[fi];if(face instanceof THREE.Face3){q+=3;A+=1;N+=3}else if(face instanceof THREE.Face4){q+=4;A+=2;N+=4}}n.__vertexArray=new Float32Array(q*3);n.__normalArray=new Float32Array(q*3);n.__tangentArray=new Float32Array(q*
|
|
|
-4);n.__colorArray=new Float32Array(q*3);n.__uvArray=new Float32Array(q*2);n.__uv2Array=new Float32Array(q*2);n.__skinVertexAArray=new Float32Array(q*4);n.__skinVertexBArray=new Float32Array(q*4);n.__skinIndexArray=new Float32Array(q*4);n.__skinWeightArray=new Float32Array(q*4);n.__faceArray=new Uint16Array(A*3);n.__lineArray=new Uint16Array(N*2);F=p=n;K=void 0;J=void 0;var G=void 0,P=void 0;G=void 0;var Q=!1;K=0;for(J=C.materials.length;K<J;K++){G=C.materials[K];if(G instanceof THREE.MeshFaceMaterial){G=
|
|
|
-0;for(P=F.materials.length;G<P;G++)if(F.materials[G]&&F.materials[G].shading!=undefined&&F.materials[G].shading==THREE.SmoothShading){Q=!0;break}}else if(G&&G.shading!=undefined&&G.shading==THREE.SmoothShading){Q=!0;break}if(Q)break}p.__needsSmoothNormals=Q;n.__webGLFaceCount=A*3;n.__webGLLineCount=N*2;if(n.numMorphTargets){A=void 0;N=void 0;n.__morphTargetsArrays=[];A=0;for(N=n.numMorphTargets;A<N;A++)n.__morphTargetsArrays.push(new Float32Array(q*3))}i.__dirtyVertices=!0;i.__dirtyMorphTargets=!0;
|
|
|
-i.__dirtyElements=!0;i.__dirtyUvs=!0;i.__dirtyNormals=!0;i.__dirtyTangents=!0;i.__dirtyColors=!0}L(k.__webglObjects,r,j)}}else if(j instanceof THREE.Ribbon){i=j.geometry;if(!i.__webGLVertexBuffer){h=i;h.__webGLVertexBuffer=c.createBuffer();h.__webGLColorBuffer=c.createBuffer();h=i;r=h.vertices.length;h.__vertexArray=new Float32Array(r*3);h.__colorArray=new Float32Array(r*3);h.__webGLVertexCount=r;i.__dirtyVertices=!0;i.__dirtyColors=!0}L(k.__webglObjects,i,j)}else if(j instanceof THREE.Line){i=j.geometry;
|
|
|
-if(!i.__webGLVertexBuffer){h=i;h.__webGLVertexBuffer=c.createBuffer();h.__webGLColorBuffer=c.createBuffer();h=i;r=h.vertices.length;h.__vertexArray=new Float32Array(r*3);h.__colorArray=new Float32Array(r*3);h.__webGLLineCount=r;i.__dirtyVertices=!0;i.__dirtyColors=!0}L(k.__webglObjects,i,j)}else if(j instanceof THREE.ParticleSystem){i=j.geometry;if(!i.__webGLVertexBuffer){h=i;h.__webGLVertexBuffer=c.createBuffer();h.__webGLColorBuffer=c.createBuffer();h=i;r=h.vertices.length;h.__vertexArray=new Float32Array(r*
|
|
|
-3);h.__colorArray=new Float32Array(r*3);h.__sortArray=[];h.__webGLParticleCount=r;i.__dirtyVertices=!0;i.__dirtyColors=!0}L(k.__webglObjects,i,j)}else THREE.MarchingCubes!==undefined&&j instanceof THREE.MarchingCubes&&k.__webglObjectsImmediate.push({object:j,opaque:{list:[],count:0},transparent:{list:[],count:0}});f.__objectsAdded.splice(0,1)}for(;f.__objectsRemoved.length;){j=f.__objectsRemoved[0];k=f;i=void 0;h=void 0;for(i=k.__webglObjects.length-1;i>=0;i--){h=k.__webglObjects[i].object;j==h&&
|
|
|
-k.__webglObjects.splice(i,1)}f.__objectsRemoved.splice(0,1)}j=0;for(k=f.__webglObjects.length;j<k;j++){h=f.__webglObjects[j].object;r=void 0;i=void 0;n=void 0;if(h instanceof THREE.Mesh){i=h.geometry;for(r in i.geometryGroups){n=i.geometryGroups[r];if(i.__dirtyVertices||i.__dirtyMorphTargets||i.__dirtyElements||i.__dirtyUvs||i.__dirtyNormals||i.__dirtyColors||i.__dirtyTangents){q=c.DYNAMIC_DRAW;A=void 0;N=void 0;var na=void 0,u=void 0,la=void 0,fa=void 0,ka=void 0;na=void 0;var w=void 0,x=void 0,
|
|
|
-y=void 0,O=void 0;w=void 0;x=void 0;y=void 0;u=void 0;w=void 0;x=void 0;y=void 0;O=void 0;w=void 0;x=void 0;y=void 0;O=void 0;w=void 0;x=void 0;y=void 0;O=void 0;w=void 0;x=void 0;y=void 0;O=void 0;w=void 0;x=void 0;y=void 0;O=void 0;u=void 0;fa=void 0;la=void 0;ka=void 0;var ga=void 0,Ha=void 0,X=void 0,Y=P=G=Q=J=K=C=F=p=0,t=0,Z=0,ca=n.__vertexArray,Na=n.__uvArray,Oa=n.__uv2Array,qa=n.__normalArray,R=n.__tangentArray,da=n.__colorArray,S=n.__skinVertexAArray,T=n.__skinVertexBArray,U=n.__skinIndexArray,
|
|
|
-V=n.__skinWeightArray,Qa=n.__morphTargetsArrays,va=n.__faceArray,ma=n.__lineArray,bb=n.__needsSmoothNormals,ha=h.geometry,Ra=ha.__dirtyVertices,Sa=ha.__dirtyElements,Ia=ha.__dirtyUvs,Ta=ha.__dirtyNormals,Ua=ha.__dirtyTangents,Va=ha.__dirtyColors,Wa=ha.__dirtyMorphTargets,oa=ha.vertices,cb=n.faces,db=ha.faces,eb=ha.uvs,fb=ha.uvs2,wa=ha.colors,Ba=ha.skinVerticesA,Ca=ha.skinVerticesB,Da=ha.skinIndices,za=ha.skinWeights,xa=ha.morphTargets;A=0;for(N=cb.length;A<N;A++){na=cb[A];u=db[na];ka=eb[na];na=fb[na];
|
|
|
-la=u.vertexNormals;fa=u.normal;if(u instanceof THREE.Face3){if(Ra){w=oa[u.a].position;x=oa[u.b].position;y=oa[u.c].position;ca[F]=w.x;ca[F+1]=w.y;ca[F+2]=w.z;ca[F+3]=x.x;ca[F+4]=x.y;ca[F+5]=x.z;ca[F+6]=y.x;ca[F+7]=y.y;ca[F+8]=y.z;F+=9}if(Wa){ga=0;for(Ha=xa.length;ga<Ha;ga++){w=xa[ga].vertices[u.a].position;x=xa[ga].vertices[u.b].position;y=xa[ga].vertices[u.c].position;X=Qa[ga];X[Z+0]=w.x;X[Z+1]=w.y;X[Z+2]=w.z;X[Z+3]=x.x;X[Z+4]=x.y;X[Z+5]=x.z;X[Z+6]=y.x;X[Z+7]=y.y;X[Z+8]=y.z}Z+=9}if(za.length){w=
|
|
|
-za[u.a];x=za[u.b];y=za[u.c];V[t]=w.x;V[t+1]=w.y;V[t+2]=w.z;V[t+3]=w.w;V[t+4]=x.x;V[t+5]=x.y;V[t+6]=x.z;V[t+7]=x.w;V[t+8]=y.x;V[t+9]=y.y;V[t+10]=y.z;V[t+11]=y.w;w=Da[u.a];x=Da[u.b];y=Da[u.c];U[t]=w.x;U[t+1]=w.y;U[t+2]=w.z;U[t+3]=w.w;U[t+4]=x.x;U[t+5]=x.y;U[t+6]=x.z;U[t+7]=x.w;U[t+8]=y.x;U[t+9]=y.y;U[t+10]=y.z;U[t+11]=y.w;w=Ba[u.a];x=Ba[u.b];y=Ba[u.c];S[t]=w.x;S[t+1]=w.y;S[t+2]=w.z;S[t+3]=1;S[t+4]=x.x;S[t+5]=x.y;S[t+6]=x.z;S[t+7]=1;S[t+8]=y.x;S[t+9]=y.y;S[t+10]=y.z;S[t+11]=1;w=Ca[u.a];x=Ca[u.b];y=Ca[u.c];
|
|
|
-T[t]=w.x;T[t+1]=w.y;T[t+2]=w.z;T[t+3]=1;T[t+4]=x.x;T[t+5]=x.y;T[t+6]=x.z;T[t+7]=1;T[t+8]=y.x;T[t+9]=y.y;T[t+10]=y.z;T[t+11]=1;t+=12}if(Va&&wa.length){w=wa[u.a];x=wa[u.b];y=wa[u.c];da[Y]=w.r;da[Y+1]=w.g;da[Y+2]=w.b;da[Y+3]=x.r;da[Y+4]=x.g;da[Y+5]=x.b;da[Y+6]=y.r;da[Y+7]=y.g;da[Y+8]=y.b;Y+=9}if(Ua&&ha.hasTangents){w=oa[u.a].tangent;x=oa[u.b].tangent;y=oa[u.c].tangent;R[G]=w.x;R[G+1]=w.y;R[G+2]=w.z;R[G+3]=w.w;R[G+4]=x.x;R[G+5]=x.y;R[G+6]=x.z;R[G+7]=x.w;R[G+8]=y.x;R[G+9]=y.y;R[G+10]=y.z;R[G+11]=y.w;G+=
|
|
|
-12}if(Ta)if(la.length==3&&bb)for(u=0;u<3;u++){fa=la[u];qa[Q]=fa.x;qa[Q+1]=fa.y;qa[Q+2]=fa.z;Q+=3}else for(u=0;u<3;u++){qa[Q]=fa.x;qa[Q+1]=fa.y;qa[Q+2]=fa.z;Q+=3}if(Ia&&ka)for(u=0;u<3;u++){la=ka[u];Na[C]=la.u;Na[C+1]=la.v;C+=2}if(Ia&&na)for(u=0;u<3;u++){ka=na[u];Oa[K]=ka.u;Oa[K+1]=ka.v;K+=2}if(Sa){va[J]=p;va[J+1]=p+1;va[J+2]=p+2;J+=3;ma[P]=p;ma[P+1]=p+1;ma[P+2]=p;ma[P+3]=p+2;ma[P+4]=p+1;ma[P+5]=p+2;P+=6;p+=3}}else if(u instanceof THREE.Face4){if(Ra){w=oa[u.a].position;x=oa[u.b].position;y=oa[u.c].position;
|
|
|
-O=oa[u.d].position;ca[F]=w.x;ca[F+1]=w.y;ca[F+2]=w.z;ca[F+3]=x.x;ca[F+4]=x.y;ca[F+5]=x.z;ca[F+6]=y.x;ca[F+7]=y.y;ca[F+8]=y.z;ca[F+9]=O.x;ca[F+10]=O.y;ca[F+11]=O.z;F+=12}if(Wa){ga=0;for(Ha=xa.length;ga<Ha;ga++){w=xa[ga].vertices[u.a].position;x=xa[ga].vertices[u.b].position;y=xa[ga].vertices[u.c].position;O=xa[ga].vertices[u.d].position;X=Qa[ga];X[Z+0]=w.x;X[Z+1]=w.y;X[Z+2]=w.z;X[Z+3]=x.x;X[Z+4]=x.y;X[Z+5]=x.z;X[Z+6]=y.x;X[Z+7]=y.y;X[Z+8]=y.z;X[Z+9]=O.x;X[Z+10]=O.y;X[Z+11]=O.z}Z+=12}if(za.length){w=
|
|
|
-za[u.a];x=za[u.b];y=za[u.c];O=za[u.d];V[t]=w.x;V[t+1]=w.y;V[t+2]=w.z;V[t+3]=w.w;V[t+4]=x.x;V[t+5]=x.y;V[t+6]=x.z;V[t+7]=x.w;V[t+8]=y.x;V[t+9]=y.y;V[t+10]=y.z;V[t+11]=y.w;V[t+12]=O.x;V[t+13]=O.y;V[t+14]=O.z;V[t+15]=O.w;w=Da[u.a];x=Da[u.b];y=Da[u.c];O=Da[u.d];U[t]=w.x;U[t+1]=w.y;U[t+2]=w.z;U[t+3]=w.w;U[t+4]=x.x;U[t+5]=x.y;U[t+6]=x.z;U[t+7]=x.w;U[t+8]=y.x;U[t+9]=y.y;U[t+10]=y.z;U[t+11]=y.w;U[t+12]=O.x;U[t+13]=O.y;U[t+14]=O.z;U[t+15]=O.w;w=Ba[u.a];x=Ba[u.b];y=Ba[u.c];O=Ba[u.d];S[t]=w.x;S[t+1]=w.y;S[t+
|
|
|
-2]=w.z;S[t+3]=1;S[t+4]=x.x;S[t+5]=x.y;S[t+6]=x.z;S[t+7]=1;S[t+8]=y.x;S[t+9]=y.y;S[t+10]=y.z;S[t+11]=1;S[t+12]=O.x;S[t+13]=O.y;S[t+14]=O.z;S[t+15]=1;w=Ca[u.a];x=Ca[u.b];y=Ca[u.c];O=Ca[u.d];T[t]=w.x;T[t+1]=w.y;T[t+2]=w.z;T[t+3]=1;T[t+4]=x.x;T[t+5]=x.y;T[t+6]=x.z;T[t+7]=1;T[t+8]=y.x;T[t+9]=y.y;T[t+10]=y.z;T[t+11]=1;T[t+12]=O.x;T[t+13]=O.y;T[t+14]=O.z;T[t+15]=1;t+=16}if(Va&&wa.length){w=wa[u.a];x=wa[u.b];y=wa[u.c];O=wa[u.d];da[Y]=w.r;da[Y+1]=w.g;da[Y+2]=w.b;da[Y+3]=x.r;da[Y+4]=x.g;da[Y+5]=x.b;da[Y+6]=
|
|
|
-y.r;da[Y+7]=y.g;da[Y+8]=y.b;da[Y+9]=O.r;da[Y+10]=O.g;da[Y+11]=O.b;Y+=12}if(Ua&&ha.hasTangents){w=oa[u.a].tangent;x=oa[u.b].tangent;y=oa[u.c].tangent;u=oa[u.d].tangent;R[G]=w.x;R[G+1]=w.y;R[G+2]=w.z;R[G+3]=w.w;R[G+4]=x.x;R[G+5]=x.y;R[G+6]=x.z;R[G+7]=x.w;R[G+8]=y.x;R[G+9]=y.y;R[G+10]=y.z;R[G+11]=y.w;R[G+12]=u.x;R[G+13]=u.y;R[G+14]=u.z;R[G+15]=u.w;G+=16}if(Ta)if(la.length==4&&bb)for(u=0;u<4;u++){fa=la[u];qa[Q]=fa.x;qa[Q+1]=fa.y;qa[Q+2]=fa.z;Q+=3}else for(u=0;u<4;u++){qa[Q]=fa.x;qa[Q+1]=fa.y;qa[Q+2]=
|
|
|
-fa.z;Q+=3}if(Ia&&ka)for(u=0;u<4;u++){la=ka[u];Na[C]=la.u;Na[C+1]=la.v;C+=2}if(Ia&&na)for(u=0;u<4;u++){ka=na[u];Oa[K]=ka.u;Oa[K+1]=ka.v;K+=2}if(Sa){va[J]=p;va[J+1]=p+1;va[J+2]=p+2;va[J+3]=p;va[J+4]=p+2;va[J+5]=p+3;J+=6;ma[P]=p;ma[P+1]=p+1;ma[P+2]=p;ma[P+3]=p+3;ma[P+4]=p+1;ma[P+5]=p+2;ma[P+6]=p+2;ma[P+7]=p+3;P+=8;p+=4}}}if(Ra){c.bindBuffer(c.ARRAY_BUFFER,n.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,ca,q)}if(Wa){ga=0;for(Ha=xa.length;ga<Ha;ga++){c.bindBuffer(c.ARRAY_BUFFER,n.__webGLMorphTargetsBuffers[ga]);
|
|
|
-c.bufferData(c.ARRAY_BUFFER,Qa[ga],q)}}if(Va&&wa.length){c.bindBuffer(c.ARRAY_BUFFER,n.__webGLColorBuffer);c.bufferData(c.ARRAY_BUFFER,da,q)}if(Ta){c.bindBuffer(c.ARRAY_BUFFER,n.__webGLNormalBuffer);c.bufferData(c.ARRAY_BUFFER,qa,q)}if(Ua&&ha.hasTangents){c.bindBuffer(c.ARRAY_BUFFER,n.__webGLTangentBuffer);c.bufferData(c.ARRAY_BUFFER,R,q)}if(Ia&&C>0){c.bindBuffer(c.ARRAY_BUFFER,n.__webGLUVBuffer);c.bufferData(c.ARRAY_BUFFER,Na,q)}if(Ia&&K>0){c.bindBuffer(c.ARRAY_BUFFER,n.__webGLUV2Buffer);c.bufferData(c.ARRAY_BUFFER,
|
|
|
-Oa,q)}if(Sa){c.bindBuffer(c.ELEMENT_ARRAY_BUFFER,n.__webGLFaceBuffer);c.bufferData(c.ELEMENT_ARRAY_BUFFER,va,q);c.bindBuffer(c.ELEMENT_ARRAY_BUFFER,n.__webGLLineBuffer);c.bufferData(c.ELEMENT_ARRAY_BUFFER,ma,q)}if(t>0){c.bindBuffer(c.ARRAY_BUFFER,n.__webGLSkinVertexABuffer);c.bufferData(c.ARRAY_BUFFER,S,q);c.bindBuffer(c.ARRAY_BUFFER,n.__webGLSkinVertexBBuffer);c.bufferData(c.ARRAY_BUFFER,T,q);c.bindBuffer(c.ARRAY_BUFFER,n.__webGLSkinIndicesBuffer);c.bufferData(c.ARRAY_BUFFER,U,q);c.bindBuffer(c.ARRAY_BUFFER,
|
|
|
-n.__webGLSkinWeightsBuffer);c.bufferData(c.ARRAY_BUFFER,V,q)}}}i.__dirtyVertices=!1;i.__dirtyMorphTargets=!1;i.__dirtyElements=!1;i.__dirtyUvs=!1;i.__dirtyNormals=!1;i.__dirtyTangents=!1;i.__dirtyColors=!1}else if(h instanceof THREE.Ribbon){i=h.geometry;if(i.__dirtyVertices||i.__dirtyColors){h=i;r=c.DYNAMIC_DRAW;p=void 0;p=void 0;F=void 0;n=void 0;C=h.vertices;q=h.colors;K=C.length;A=q.length;J=h.__vertexArray;N=h.__colorArray;Q=h.__dirtyColors;if(h.__dirtyVertices){for(p=0;p<K;p++){F=C[p].position;
|
|
|
-n=p*3;J[n]=F.x;J[n+1]=F.y;J[n+2]=F.z}c.bindBuffer(c.ARRAY_BUFFER,h.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,J,r)}if(Q){for(p=0;p<A;p++){color=q[p];n=p*3;N[n]=color.r;N[n+1]=color.g;N[n+2]=color.b}c.bindBuffer(c.ARRAY_BUFFER,h.__webGLColorBuffer);c.bufferData(c.ARRAY_BUFFER,N,r)}}i.__dirtyVertices=!1;i.__dirtyColors=!1}else if(h instanceof THREE.Line){i=h.geometry;if(i.__dirtyVertices||i.__dirtyColors){h=i;r=c.DYNAMIC_DRAW;p=void 0;p=void 0;F=void 0;n=void 0;C=h.vertices;q=h.colors;K=C.length;
|
|
|
-A=q.length;J=h.__vertexArray;N=h.__colorArray;Q=h.__dirtyColors;if(h.__dirtyVertices){for(p=0;p<K;p++){F=C[p].position;n=p*3;J[n]=F.x;J[n+1]=F.y;J[n+2]=F.z}c.bindBuffer(c.ARRAY_BUFFER,h.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,J,r)}if(Q){for(p=0;p<A;p++){color=q[p];n=p*3;N[n]=color.r;N[n+1]=color.g;N[n+2]=color.b}c.bindBuffer(c.ARRAY_BUFFER,h.__webGLColorBuffer);c.bufferData(c.ARRAY_BUFFER,N,r)}}i.__dirtyVertices=!1;i.__dirtyColors=!1}else if(h instanceof THREE.ParticleSystem){i=h.geometry;
|
|
|
-(i.__dirtyVertices||i.__dirtyColors||h.sortParticles)&&b(i,c.DYNAMIC_DRAW,h);i.__dirtyVertices=!1;i.__dirtyColors=!1}}};this.setFaceCulling=function(f,j){if(f){!j||j=="ccw"?c.frontFace(c.CCW):c.frontFace(c.CW);if(f=="back")c.cullFace(c.BACK);else f=="front"?c.cullFace(c.FRONT):c.cullFace(c.FRONT_AND_BACK);c.enable(c.CULL_FACE)}else c.disable(c.CULL_FACE)};this.supportsVertexTextures=function(){return c.getParameter(c.MAX_VERTEX_TEXTURE_IMAGE_UNITS)>0}};
|
|
|
+case THREE.IntType:return c.INT;case THREE.UnsignedShortType:return c.UNSIGNED_INT;case THREE.FloatType:return c.FLOAT;case THREE.AlphaFormat:return c.ALPHA;case THREE.RGBFormat:return c.RGB;case THREE.RGBAFormat:return c.RGBA;case THREE.LuminanceFormat:return c.LUMINANCE;case THREE.LuminanceAlphaFormat:return c.LUMINANCE_ALPHA}return 0}var M=document.createElement("canvas"),c,ja=null,W=null,la=this,Z=null,R=null,N=null,Ba=null,L=0,ka=0,wa=0,P=0,xa=[new THREE.Vector4,new THREE.Vector4,new THREE.Vector4,
|
|
|
+new THREE.Vector4,new THREE.Vector4,new THREE.Vector4],Ha=new THREE.Matrix4,Na=new Float32Array(16),Ma=new Float32Array(16),Fa=new THREE.Vector4,va={ambient:[0,0,0],directional:{length:0,colors:[],positions:[]},point:{length:0,colors:[],positions:[]}},V=!0,sa=new THREE.Color(0),za=0;if(a){if(a.antialias!==undefined)V=a.antialias;a.clearColor!==undefined&&sa.setHex(a.clearColor);if(a.clearAlpha!==undefined)za=a.clearAlpha}this.maxMorphTargets=8;this.domElement=M;this.autoClear=!0;this.sortObjects=
|
|
|
+!0;(function(g,l,n){try{if(!(c=M.getContext("experimental-webgl",{antialias:g})))throw"Error creating WebGL context.";}catch(i){console.error(i)}c.clearColor(0,0,0,1);c.clearDepth(1);c.enable(c.DEPTH_TEST);c.depthFunc(c.LEQUAL);c.frontFace(c.CCW);c.cullFace(c.BACK);c.enable(c.CULL_FACE);c.enable(c.BLEND);c.blendFunc(c.ONE,c.ONE_MINUS_SRC_ALPHA);c.clearColor(l.r,l.g,l.b,n);_cullEnabled=!0})(V,sa,za);this.context=c;this.setSize=function(g,l){M.width=g;M.height=l;this.setViewport(0,0,M.width,M.height)};
|
|
|
+this.setViewport=function(g,l,n,i){L=g;ka=l;wa=n;P=i;c.viewport(L,ka,wa,P)};this.setScissor=function(g,l,n,i){c.scissor(g,l,n,i)};this.enableScissorTest=function(g){g?c.enable(c.SCISSOR_TEST):c.disable(c.SCISSOR_TEST)};this.enableDepthBufferWrite=function(g){c.depthMask(g)};this.setClearColorHex=function(g,l){var n=new THREE.Color(g);c.clearColor(n.r,n.g,n.b,l)};this.setClearColor=function(g,l){c.clearColor(g.r,g.g,g.b,l)};this.clear=function(){c.clear(c.COLOR_BUFFER_BIT|c.DEPTH_BUFFER_BIT)};this.initMaterial=
|
|
|
+function(g,l,n,i){var k,s,p;if(g instanceof THREE.MeshDepthMaterial)d(g,THREE.ShaderLib.depth);else if(g instanceof THREE.MeshNormalMaterial)d(g,THREE.ShaderLib.normal);else if(g instanceof THREE.MeshBasicMaterial)d(g,THREE.ShaderLib.basic);else if(g instanceof THREE.MeshLambertMaterial)d(g,THREE.ShaderLib.lambert);else if(g instanceof THREE.MeshPhongMaterial)d(g,THREE.ShaderLib.phong);else if(g instanceof THREE.LineBasicMaterial)d(g,THREE.ShaderLib.basic);else g instanceof THREE.ParticleBasicMaterial&&
|
|
|
+d(g,THREE.ShaderLib.particle_basic);var r,E,F,q;p=F=q=0;for(r=l.length;p<r;p++){E=l[p];E instanceof THREE.DirectionalLight&&F++;E instanceof THREE.PointLight&&q++}if(q+F<=4)l=F;else{l=Math.ceil(4*F/(q+F));q=4-l}p={directional:l,point:q};r=50;if(i!==undefined&&i instanceof THREE.SkinnedMesh)r=i.bones.length;q=g.fragmentShader;l=g.vertexShader;r={fog:n,map:g.map,envMap:g.envMap,lightMap:g.lightMap,vertexColors:g.vertexColors,sizeAttenuation:g.sizeAttenuation,skinning:g.skinning,morphTargets:g.morphTargets,
|
|
|
+maxDirLights:p.directional,maxPointLights:p.point,maxBones:r};n=c.createProgram();p=["#ifdef GL_ES\nprecision highp float;\n#endif","#define MAX_DIR_LIGHTS "+r.maxDirLights,"#define MAX_POINT_LIGHTS "+r.maxPointLights,r.fog?"#define USE_FOG":"",r.fog instanceof THREE.FogExp2?"#define FOG_EXP2":"",r.map?"#define USE_MAP":"",r.envMap?"#define USE_ENVMAP":"",r.lightMap?"#define USE_LIGHTMAP":"",r.vertexColors?"#define USE_COLOR":"","uniform mat4 viewMatrix;\nuniform vec3 cameraPosition;\n"].join("\n");
|
|
|
+r=[c.getParameter(c.MAX_VERTEX_TEXTURE_IMAGE_UNITS)>0?"#define VERTEX_TEXTURES":"","#define MAX_DIR_LIGHTS "+r.maxDirLights,"#define MAX_POINT_LIGHTS "+r.maxPointLights,"#define MAX_BONES "+r.maxBones,r.map?"#define USE_MAP":"",r.envMap?"#define USE_ENVMAP":"",r.lightMap?"#define USE_LIGHTMAP":"",r.vertexColors?"#define USE_COLOR":"",r.skinning?"#define USE_SKINNING":"",r.morphTargets?"#define USE_MORPHTARGETS":"",r.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 morphTarget0;\nattribute vec3 morphTarget1;\nattribute vec3 morphTarget2;\nattribute vec3 morphTarget3;\nattribute vec3 morphTarget4;\nattribute vec3 morphTarget5;\nattribute vec3 morphTarget6;\nattribute vec3 morphTarget7;\nattribute vec3 normal;\nattribute vec3 color;\nattribute vec2 uv;\nattribute vec2 uv2;\nattribute vec4 skinVertexA;\nattribute vec4 skinVertexB;\nattribute vec4 skinIndex;\nattribute vec4 skinWeight;\n"].join("\n");
|
|
|
+c.attachShader(n,ha("fragment",p+q));c.attachShader(n,ha("vertex",r+l));c.linkProgram(n);c.getProgramParameter(n,c.LINK_STATUS)||alert("Could not initialise shaders\nVALIDATE_STATUS: "+c.getProgramParameter(n,c.VALIDATE_STATUS)+", gl error ["+c.getError()+"]");n.uniforms={};n.attributes={};g.program=n;n=["viewMatrix","modelViewMatrix","projectionMatrix","normalMatrix","objectMatrix","cameraPosition","cameraInverseMatrix","boneGlobalMatrices","morphTargetInfluences"];for(k in g.uniforms)n.push(k);
|
|
|
+k=g.program;q=0;for(l=n.length;q<l;q++){p=n[q];k.uniforms[p]=c.getUniformLocation(k,p)}n=["position","normal","uv","uv2","tangent","color","skinVertexA","skinVertexB","skinIndex","skinWeight"];for(k=0;k<this.maxMorphTargets;k++)n.push("morphTarget"+k);for(s in g.attributes)n.push(s);s=g.program;k=n;n=0;for(q=k.length;n<q;n++){l=k[n];s.attributes[l]=c.getAttribLocation(s,l)}s=g.program.attributes;c.enableVertexAttribArray(s.position);s.color>=0&&c.enableVertexAttribArray(s.color);s.normal>=0&&c.enableVertexAttribArray(s.normal);
|
|
|
+s.tangent>=0&&c.enableVertexAttribArray(s.tangent);if(g.skinning&&s.skinVertexA>=0&&s.skinVertexB>=0&&s.skinIndex>=0&&s.skinWeight>=0){c.enableVertexAttribArray(s.skinVertexA);c.enableVertexAttribArray(s.skinVertexB);c.enableVertexAttribArray(s.skinIndex);c.enableVertexAttribArray(s.skinWeight)}if(g.morphTargets){g.numSupportedMorphTargets=0;if(s.morphTarget0>=0){c.enableVertexAttribArray(s.morphTarget0);g.numSupportedMorphTargets++}if(s.morphTarget1>=0){c.enableVertexAttribArray(s.morphTarget1);
|
|
|
+g.numSupportedMorphTargets++}if(s.morphTarget2>=0){c.enableVertexAttribArray(s.morphTarget2);g.numSupportedMorphTargets++}if(s.morphTarget3>=0){c.enableVertexAttribArray(s.morphTarget3);g.numSupportedMorphTargets++}if(s.morphTarget4>=0){c.enableVertexAttribArray(s.morphTarget4);g.numSupportedMorphTargets++}if(s.morphTarget5>=0){c.enableVertexAttribArray(s.morphTarget5);g.numSupportedMorphTargets++}if(s.morphTarget6>=0){c.enableVertexAttribArray(s.morphTarget6);g.numSupportedMorphTargets++}if(s.morphTarget7>=
|
|
|
+0){c.enableVertexAttribArray(s.morphTarget7);g.numSupportedMorphTargets++}i.__webGLMorphTargetInfluences=new Float32Array(this.maxMorphTargets);for(k=0;k<this.maxMorphTargets;k++)i.__webGLMorphTargetInfluences[k]=0}};this.render=function(g,l,n,i){var k,s,p,r,E,F,q,G,S=g.lights,Q=g.fog;l.matrixAutoUpdate&&l.updateMatrix();g.update(undefined,!1,l);l.matrixWorldInverse.flattenToArray(Ma);l.projectionMatrix.flattenToArray(Na);Ha.multiply(l.projectionMatrix,l.matrixWorldInverse);m(Ha);this.initWebGLObjects(g);
|
|
|
+U(n);(this.autoClear||i)&&this.clear();E=g.__webglObjects.length;for(i=0;i<E;i++){k=g.__webglObjects[i];q=k.object;if(q.visible)if(!(q instanceof THREE.Mesh)||u(q)){q.matrixWorld.flattenToArray(q._objectMatrixArray);K(q,l);A(k);k.render=!0;if(this.sortObjects){Fa.copy(q.position);Ha.multiplyVector3(Fa);k.z=Fa.z}}else k.render=!1;else k.render=!1}this.sortObjects&&g.__webglObjects.sort(x);F=g.__webglObjectsImmediate.length;for(i=0;i<F;i++){k=g.__webglObjectsImmediate[i];q=k.object;if(q.visible){q.matrixAutoUpdate&&
|
|
|
+q.matrixWorld.flattenToArray(q._objectMatrixArray);K(q,l);z(k)}}w(THREE.NormalBlending);for(i=0;i<E;i++){k=g.__webglObjects[i];if(k.render){q=k.object;G=k.buffer;p=k.opaque;j(q);for(k=0;k<p.count;k++){r=p.list[k];o(r.depthTest);f(l,S,Q,r,G,q)}}}for(i=0;i<F;i++){k=g.__webglObjectsImmediate[i];q=k.object;if(q.visible){p=k.opaque;j(q);for(k=0;k<p.count;k++){r=p.list[k];o(r.depthTest);s=e(l,S,Q,r,q);q.render(function(O){h(O,s)})}}}for(i=0;i<E;i++){k=g.__webglObjects[i];if(k.render){q=k.object;G=k.buffer;
|
|
|
+p=k.transparent;j(q);for(k=0;k<p.count;k++){r=p.list[k];w(r.blending);o(r.depthTest);f(l,S,Q,r,G,q)}}}for(i=0;i<F;i++){k=g.__webglObjectsImmediate[i];q=k.object;if(q.visible){p=k.transparent;j(q);for(k=0;k<p.count;k++){r=p.list[k];w(r.blending);o(r.depthTest);s=e(l,S,Q,r,q);q.render(function(O){h(O,s)})}}}if(n&&n.minFilter!==THREE.NearestFilter&&n.minFilter!==THREE.LinearFilter){c.bindTexture(c.TEXTURE_2D,n.__webGLTexture);c.generateMipmap(c.TEXTURE_2D);c.bindTexture(c.TEXTURE_2D,null)}};this.initWebGLObjects=
|
|
|
+function(g){if(!g.__webglObjects){g.__webglObjects=[];g.__webglObjectsImmediate=[]}for(;g.__objectsAdded.length;){var l=g.__objectsAdded[0],n=g,i=void 0,k=void 0,s=void 0;if(l._modelViewMatrix==undefined){l._modelViewMatrix=new THREE.Matrix4;l._normalMatrixArray=new Float32Array(9);l._modelViewMatrixArray=new Float32Array(16);l._objectMatrixArray=new Float32Array(16);l.matrixWorld.flattenToArray(l._objectMatrixArray)}if(l instanceof THREE.Mesh){k=l.geometry;k.geometryGroups==undefined&&J(k);for(i in k.geometryGroups){s=
|
|
|
+k.geometryGroups[i];if(!s.__webGLVertexBuffer){var p=s;p.__webGLVertexBuffer=c.createBuffer();p.__webGLNormalBuffer=c.createBuffer();p.__webGLTangentBuffer=c.createBuffer();p.__webGLColorBuffer=c.createBuffer();p.__webGLUVBuffer=c.createBuffer();p.__webGLUV2Buffer=c.createBuffer();p.__webGLSkinVertexABuffer=c.createBuffer();p.__webGLSkinVertexBBuffer=c.createBuffer();p.__webGLSkinIndicesBuffer=c.createBuffer();p.__webGLSkinWeightsBuffer=c.createBuffer();p.__webGLFaceBuffer=c.createBuffer();p.__webGLLineBuffer=
|
|
|
+c.createBuffer();if(p.numMorphTargets){var r=void 0,E=void 0;p.__webGLMorphTargetsBuffers=[];r=0;for(E=p.numMorphTargets;r<E;r++)p.__webGLMorphTargetsBuffers.push(c.createBuffer())}p=s;var F=l,q=void 0,G=void 0,S=E=r=0,Q=F.geometry.faces,O=p.faces;q=0;for(G=O.length;q<G;q++){fi=O[q];face=Q[fi];if(face instanceof THREE.Face3){r+=3;E+=1;S+=3}else if(face instanceof THREE.Face4){r+=4;E+=2;S+=4}}p.__vertexArray=new Float32Array(r*3);p.__normalArray=new Float32Array(r*3);p.__tangentArray=new Float32Array(r*
|
|
|
+4);p.__colorArray=new Float32Array(r*3);p.__uvArray=new Float32Array(r*2);p.__uv2Array=new Float32Array(r*2);p.__skinVertexAArray=new Float32Array(r*4);p.__skinVertexBArray=new Float32Array(r*4);p.__skinIndexArray=new Float32Array(r*4);p.__skinWeightArray=new Float32Array(r*4);p.__faceArray=new Uint16Array(E*3);p.__lineArray=new Uint16Array(S*2);G=q=p;Q=void 0;O=void 0;var I=void 0,X=void 0;I=void 0;var Y=!1;Q=0;for(O=F.materials.length;Q<O;Q++){I=F.materials[Q];if(I instanceof THREE.MeshFaceMaterial){I=
|
|
|
+0;for(X=G.materials.length;I<X;I++)if(G.materials[I]&&G.materials[I].shading!=undefined&&G.materials[I].shading==THREE.SmoothShading){Y=!0;break}}else if(I&&I.shading!=undefined&&I.shading==THREE.SmoothShading){Y=!0;break}if(Y)break}q.__needsSmoothNormals=Y;p.__webGLFaceCount=E*3;p.__webGLLineCount=S*2;if(p.numMorphTargets){E=void 0;S=void 0;p.__morphTargetsArrays=[];E=0;for(S=p.numMorphTargets;E<S;E++)p.__morphTargetsArrays.push(new Float32Array(r*3))}k.__dirtyVertices=!0;k.__dirtyMorphTargets=!0;
|
|
|
+k.__dirtyElements=!0;k.__dirtyUvs=!0;k.__dirtyNormals=!0;k.__dirtyTangents=!0;k.__dirtyColors=!0}H(n.__webglObjects,s,l)}}else if(l instanceof THREE.Ribbon){k=l.geometry;if(!k.__webGLVertexBuffer){i=k;i.__webGLVertexBuffer=c.createBuffer();i.__webGLColorBuffer=c.createBuffer();i=k;s=i.vertices.length;i.__vertexArray=new Float32Array(s*3);i.__colorArray=new Float32Array(s*3);i.__webGLVertexCount=s;k.__dirtyVertices=!0;k.__dirtyColors=!0}H(n.__webglObjects,k,l)}else if(l instanceof THREE.Line){k=l.geometry;
|
|
|
+if(!k.__webGLVertexBuffer){i=k;i.__webGLVertexBuffer=c.createBuffer();i.__webGLColorBuffer=c.createBuffer();i=k;s=i.vertices.length;i.__vertexArray=new Float32Array(s*3);i.__colorArray=new Float32Array(s*3);i.__webGLLineCount=s;k.__dirtyVertices=!0;k.__dirtyColors=!0}H(n.__webglObjects,k,l)}else if(l instanceof THREE.ParticleSystem){k=l.geometry;if(!k.__webGLVertexBuffer){i=k;i.__webGLVertexBuffer=c.createBuffer();i.__webGLColorBuffer=c.createBuffer();i=k;s=i.vertices.length;i.__vertexArray=new Float32Array(s*
|
|
|
+3);i.__colorArray=new Float32Array(s*3);i.__sortArray=[];i.__webGLParticleCount=s;k.__dirtyVertices=!0;k.__dirtyColors=!0}H(n.__webglObjects,k,l)}else THREE.MarchingCubes!==undefined&&l instanceof THREE.MarchingCubes&&n.__webglObjectsImmediate.push({object:l,opaque:{list:[],count:0},transparent:{list:[],count:0}});g.__objectsAdded.splice(0,1)}for(;g.__objectsRemoved.length;){l=g.__objectsRemoved[0];n=g;k=void 0;i=void 0;for(k=n.__webglObjects.length-1;k>=0;k--){i=n.__webglObjects[k].object;l==i&&
|
|
|
+n.__webglObjects.splice(k,1)}g.__objectsRemoved.splice(0,1)}l=0;for(n=g.__webglObjects.length;l<n;l++){i=g.__webglObjects[l].object;s=void 0;k=void 0;p=void 0;if(i instanceof THREE.Mesh){k=i.geometry;for(s in k.geometryGroups){p=k.geometryGroups[s];if(k.__dirtyVertices||k.__dirtyMorphTargets||k.__dirtyElements||k.__dirtyUvs||k.__dirtyNormals||k.__dirtyColors||k.__dirtyTangents){r=c.DYNAMIC_DRAW;E=void 0;S=void 0;var Da=void 0,v=void 0,Aa=void 0,ra=void 0,ya=void 0;Da=void 0;var B=void 0,C=void 0,
|
|
|
+D=void 0,T=void 0;B=void 0;C=void 0;D=void 0;v=void 0;B=void 0;C=void 0;D=void 0;T=void 0;B=void 0;C=void 0;D=void 0;T=void 0;B=void 0;C=void 0;D=void 0;T=void 0;B=void 0;C=void 0;D=void 0;T=void 0;B=void 0;C=void 0;D=void 0;T=void 0;v=void 0;ra=void 0;Aa=void 0;ya=void 0;var ta=void 0,Ra=void 0,ma=void 0,na=X=I=Y=O=Q=F=G=q=0,t=0,oa=0,pa=p.__vertexArray,Ta=p.__uvArray,Ua=p.__uv2Array,Ga=p.__normalArray,$=p.__tangentArray,qa=p.__colorArray,aa=p.__skinVertexAArray,ca=p.__skinVertexBArray,da=p.__skinIndexArray,
|
|
|
+ea=p.__skinWeightArray,Va=p.__morphTargetsArrays,Ia=p.__faceArray,Ca=p.__lineArray,bb=p.__needsSmoothNormals,ua=i.geometry,Wa=ua.__dirtyVertices,Xa=ua.__dirtyElements,Sa=ua.__dirtyUvs,Ya=ua.__dirtyNormals,Za=ua.__dirtyTangents,$a=ua.__dirtyColors,ab=ua.__dirtyMorphTargets,Ea=ua.vertices,cb=p.faces,db=ua.faces,eb=ua.uvs,fb=ua.uvs2,Ja=ua.colors,Oa=ua.skinVerticesA,Pa=ua.skinVerticesB,Qa=ua.skinIndices,La=ua.skinWeights,Ka=ua.morphTargets;E=0;for(S=cb.length;E<S;E++){Da=cb[E];v=db[Da];ya=eb[Da];Da=fb[Da];
|
|
|
+Aa=v.vertexNormals;ra=v.normal;if(v instanceof THREE.Face3){if(Wa){B=Ea[v.a].position;C=Ea[v.b].position;D=Ea[v.c].position;pa[G]=B.x;pa[G+1]=B.y;pa[G+2]=B.z;pa[G+3]=C.x;pa[G+4]=C.y;pa[G+5]=C.z;pa[G+6]=D.x;pa[G+7]=D.y;pa[G+8]=D.z;G+=9}if(ab){ta=0;for(Ra=Ka.length;ta<Ra;ta++){B=Ka[ta].vertices[v.a].position;C=Ka[ta].vertices[v.b].position;D=Ka[ta].vertices[v.c].position;ma=Va[ta];ma[oa+0]=B.x;ma[oa+1]=B.y;ma[oa+2]=B.z;ma[oa+3]=C.x;ma[oa+4]=C.y;ma[oa+5]=C.z;ma[oa+6]=D.x;ma[oa+7]=D.y;ma[oa+8]=D.z}oa+=
|
|
|
+9}if(La.length){B=La[v.a];C=La[v.b];D=La[v.c];ea[t]=B.x;ea[t+1]=B.y;ea[t+2]=B.z;ea[t+3]=B.w;ea[t+4]=C.x;ea[t+5]=C.y;ea[t+6]=C.z;ea[t+7]=C.w;ea[t+8]=D.x;ea[t+9]=D.y;ea[t+10]=D.z;ea[t+11]=D.w;B=Qa[v.a];C=Qa[v.b];D=Qa[v.c];da[t]=B.x;da[t+1]=B.y;da[t+2]=B.z;da[t+3]=B.w;da[t+4]=C.x;da[t+5]=C.y;da[t+6]=C.z;da[t+7]=C.w;da[t+8]=D.x;da[t+9]=D.y;da[t+10]=D.z;da[t+11]=D.w;B=Oa[v.a];C=Oa[v.b];D=Oa[v.c];aa[t]=B.x;aa[t+1]=B.y;aa[t+2]=B.z;aa[t+3]=1;aa[t+4]=C.x;aa[t+5]=C.y;aa[t+6]=C.z;aa[t+7]=1;aa[t+8]=D.x;aa[t+
|
|
|
+9]=D.y;aa[t+10]=D.z;aa[t+11]=1;B=Pa[v.a];C=Pa[v.b];D=Pa[v.c];ca[t]=B.x;ca[t+1]=B.y;ca[t+2]=B.z;ca[t+3]=1;ca[t+4]=C.x;ca[t+5]=C.y;ca[t+6]=C.z;ca[t+7]=1;ca[t+8]=D.x;ca[t+9]=D.y;ca[t+10]=D.z;ca[t+11]=1;t+=12}if($a&&Ja.length){B=Ja[v.a];C=Ja[v.b];D=Ja[v.c];qa[na]=B.r;qa[na+1]=B.g;qa[na+2]=B.b;qa[na+3]=C.r;qa[na+4]=C.g;qa[na+5]=C.b;qa[na+6]=D.r;qa[na+7]=D.g;qa[na+8]=D.b;na+=9}if(Za&&ua.hasTangents){B=Ea[v.a].tangent;C=Ea[v.b].tangent;D=Ea[v.c].tangent;$[I]=B.x;$[I+1]=B.y;$[I+2]=B.z;$[I+3]=B.w;$[I+4]=C.x;
|
|
|
+$[I+5]=C.y;$[I+6]=C.z;$[I+7]=C.w;$[I+8]=D.x;$[I+9]=D.y;$[I+10]=D.z;$[I+11]=D.w;I+=12}if(Ya)if(Aa.length==3&&bb)for(v=0;v<3;v++){ra=Aa[v];Ga[Y]=ra.x;Ga[Y+1]=ra.y;Ga[Y+2]=ra.z;Y+=3}else for(v=0;v<3;v++){Ga[Y]=ra.x;Ga[Y+1]=ra.y;Ga[Y+2]=ra.z;Y+=3}if(Sa&&ya)for(v=0;v<3;v++){Aa=ya[v];Ta[F]=Aa.u;Ta[F+1]=Aa.v;F+=2}if(Sa&&Da)for(v=0;v<3;v++){ya=Da[v];Ua[Q]=ya.u;Ua[Q+1]=ya.v;Q+=2}if(Xa){Ia[O]=q;Ia[O+1]=q+1;Ia[O+2]=q+2;O+=3;Ca[X]=q;Ca[X+1]=q+1;Ca[X+2]=q;Ca[X+3]=q+2;Ca[X+4]=q+1;Ca[X+5]=q+2;X+=6;q+=3}}else if(v instanceof
|
|
|
+THREE.Face4){if(Wa){B=Ea[v.a].position;C=Ea[v.b].position;D=Ea[v.c].position;T=Ea[v.d].position;pa[G]=B.x;pa[G+1]=B.y;pa[G+2]=B.z;pa[G+3]=C.x;pa[G+4]=C.y;pa[G+5]=C.z;pa[G+6]=D.x;pa[G+7]=D.y;pa[G+8]=D.z;pa[G+9]=T.x;pa[G+10]=T.y;pa[G+11]=T.z;G+=12}if(ab){ta=0;for(Ra=Ka.length;ta<Ra;ta++){B=Ka[ta].vertices[v.a].position;C=Ka[ta].vertices[v.b].position;D=Ka[ta].vertices[v.c].position;T=Ka[ta].vertices[v.d].position;ma=Va[ta];ma[oa+0]=B.x;ma[oa+1]=B.y;ma[oa+2]=B.z;ma[oa+3]=C.x;ma[oa+4]=C.y;ma[oa+5]=C.z;
|
|
|
+ma[oa+6]=D.x;ma[oa+7]=D.y;ma[oa+8]=D.z;ma[oa+9]=T.x;ma[oa+10]=T.y;ma[oa+11]=T.z}oa+=12}if(La.length){B=La[v.a];C=La[v.b];D=La[v.c];T=La[v.d];ea[t]=B.x;ea[t+1]=B.y;ea[t+2]=B.z;ea[t+3]=B.w;ea[t+4]=C.x;ea[t+5]=C.y;ea[t+6]=C.z;ea[t+7]=C.w;ea[t+8]=D.x;ea[t+9]=D.y;ea[t+10]=D.z;ea[t+11]=D.w;ea[t+12]=T.x;ea[t+13]=T.y;ea[t+14]=T.z;ea[t+15]=T.w;B=Qa[v.a];C=Qa[v.b];D=Qa[v.c];T=Qa[v.d];da[t]=B.x;da[t+1]=B.y;da[t+2]=B.z;da[t+3]=B.w;da[t+4]=C.x;da[t+5]=C.y;da[t+6]=C.z;da[t+7]=C.w;da[t+8]=D.x;da[t+9]=D.y;da[t+10]=
|
|
|
+D.z;da[t+11]=D.w;da[t+12]=T.x;da[t+13]=T.y;da[t+14]=T.z;da[t+15]=T.w;B=Oa[v.a];C=Oa[v.b];D=Oa[v.c];T=Oa[v.d];aa[t]=B.x;aa[t+1]=B.y;aa[t+2]=B.z;aa[t+3]=1;aa[t+4]=C.x;aa[t+5]=C.y;aa[t+6]=C.z;aa[t+7]=1;aa[t+8]=D.x;aa[t+9]=D.y;aa[t+10]=D.z;aa[t+11]=1;aa[t+12]=T.x;aa[t+13]=T.y;aa[t+14]=T.z;aa[t+15]=1;B=Pa[v.a];C=Pa[v.b];D=Pa[v.c];T=Pa[v.d];ca[t]=B.x;ca[t+1]=B.y;ca[t+2]=B.z;ca[t+3]=1;ca[t+4]=C.x;ca[t+5]=C.y;ca[t+6]=C.z;ca[t+7]=1;ca[t+8]=D.x;ca[t+9]=D.y;ca[t+10]=D.z;ca[t+11]=1;ca[t+12]=T.x;ca[t+13]=T.y;
|
|
|
+ca[t+14]=T.z;ca[t+15]=1;t+=16}if($a&&Ja.length){B=Ja[v.a];C=Ja[v.b];D=Ja[v.c];T=Ja[v.d];qa[na]=B.r;qa[na+1]=B.g;qa[na+2]=B.b;qa[na+3]=C.r;qa[na+4]=C.g;qa[na+5]=C.b;qa[na+6]=D.r;qa[na+7]=D.g;qa[na+8]=D.b;qa[na+9]=T.r;qa[na+10]=T.g;qa[na+11]=T.b;na+=12}if(Za&&ua.hasTangents){B=Ea[v.a].tangent;C=Ea[v.b].tangent;D=Ea[v.c].tangent;v=Ea[v.d].tangent;$[I]=B.x;$[I+1]=B.y;$[I+2]=B.z;$[I+3]=B.w;$[I+4]=C.x;$[I+5]=C.y;$[I+6]=C.z;$[I+7]=C.w;$[I+8]=D.x;$[I+9]=D.y;$[I+10]=D.z;$[I+11]=D.w;$[I+12]=v.x;$[I+13]=v.y;
|
|
|
+$[I+14]=v.z;$[I+15]=v.w;I+=16}if(Ya)if(Aa.length==4&&bb)for(v=0;v<4;v++){ra=Aa[v];Ga[Y]=ra.x;Ga[Y+1]=ra.y;Ga[Y+2]=ra.z;Y+=3}else for(v=0;v<4;v++){Ga[Y]=ra.x;Ga[Y+1]=ra.y;Ga[Y+2]=ra.z;Y+=3}if(Sa&&ya)for(v=0;v<4;v++){Aa=ya[v];Ta[F]=Aa.u;Ta[F+1]=Aa.v;F+=2}if(Sa&&Da)for(v=0;v<4;v++){ya=Da[v];Ua[Q]=ya.u;Ua[Q+1]=ya.v;Q+=2}if(Xa){Ia[O]=q;Ia[O+1]=q+1;Ia[O+2]=q+2;Ia[O+3]=q;Ia[O+4]=q+2;Ia[O+5]=q+3;O+=6;Ca[X]=q;Ca[X+1]=q+1;Ca[X+2]=q;Ca[X+3]=q+3;Ca[X+4]=q+1;Ca[X+5]=q+2;Ca[X+6]=q+2;Ca[X+7]=q+3;X+=8;q+=4}}}if(Wa){c.bindBuffer(c.ARRAY_BUFFER,
|
|
|
+p.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,pa,r)}if(ab){ta=0;for(Ra=Ka.length;ta<Ra;ta++){c.bindBuffer(c.ARRAY_BUFFER,p.__webGLMorphTargetsBuffers[ta]);c.bufferData(c.ARRAY_BUFFER,Va[ta],r)}}if($a&&Ja.length){c.bindBuffer(c.ARRAY_BUFFER,p.__webGLColorBuffer);c.bufferData(c.ARRAY_BUFFER,qa,r)}if(Ya){c.bindBuffer(c.ARRAY_BUFFER,p.__webGLNormalBuffer);c.bufferData(c.ARRAY_BUFFER,Ga,r)}if(Za&&ua.hasTangents){c.bindBuffer(c.ARRAY_BUFFER,p.__webGLTangentBuffer);c.bufferData(c.ARRAY_BUFFER,$,r)}if(Sa&&
|
|
|
+F>0){c.bindBuffer(c.ARRAY_BUFFER,p.__webGLUVBuffer);c.bufferData(c.ARRAY_BUFFER,Ta,r)}if(Sa&&Q>0){c.bindBuffer(c.ARRAY_BUFFER,p.__webGLUV2Buffer);c.bufferData(c.ARRAY_BUFFER,Ua,r)}if(Xa){c.bindBuffer(c.ELEMENT_ARRAY_BUFFER,p.__webGLFaceBuffer);c.bufferData(c.ELEMENT_ARRAY_BUFFER,Ia,r);c.bindBuffer(c.ELEMENT_ARRAY_BUFFER,p.__webGLLineBuffer);c.bufferData(c.ELEMENT_ARRAY_BUFFER,Ca,r)}if(t>0){c.bindBuffer(c.ARRAY_BUFFER,p.__webGLSkinVertexABuffer);c.bufferData(c.ARRAY_BUFFER,aa,r);c.bindBuffer(c.ARRAY_BUFFER,
|
|
|
+p.__webGLSkinVertexBBuffer);c.bufferData(c.ARRAY_BUFFER,ca,r);c.bindBuffer(c.ARRAY_BUFFER,p.__webGLSkinIndicesBuffer);c.bufferData(c.ARRAY_BUFFER,da,r);c.bindBuffer(c.ARRAY_BUFFER,p.__webGLSkinWeightsBuffer);c.bufferData(c.ARRAY_BUFFER,ea,r)}}}k.__dirtyVertices=!1;k.__dirtyMorphTargets=!1;k.__dirtyElements=!1;k.__dirtyUvs=!1;k.__dirtyNormals=!1;k.__dirtyTangents=!1;k.__dirtyColors=!1}else if(i instanceof THREE.Ribbon){k=i.geometry;if(k.__dirtyVertices||k.__dirtyColors){i=k;s=c.DYNAMIC_DRAW;q=void 0;
|
|
|
+q=void 0;G=void 0;p=void 0;F=i.vertices;r=i.colors;Q=F.length;E=r.length;O=i.__vertexArray;S=i.__colorArray;Y=i.__dirtyColors;if(i.__dirtyVertices){for(q=0;q<Q;q++){G=F[q].position;p=q*3;O[p]=G.x;O[p+1]=G.y;O[p+2]=G.z}c.bindBuffer(c.ARRAY_BUFFER,i.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,O,s)}if(Y){for(q=0;q<E;q++){color=r[q];p=q*3;S[p]=color.r;S[p+1]=color.g;S[p+2]=color.b}c.bindBuffer(c.ARRAY_BUFFER,i.__webGLColorBuffer);c.bufferData(c.ARRAY_BUFFER,S,s)}}k.__dirtyVertices=!1;k.__dirtyColors=
|
|
|
+!1}else if(i instanceof THREE.Line){k=i.geometry;if(k.__dirtyVertices||k.__dirtyColors){i=k;s=c.DYNAMIC_DRAW;q=void 0;q=void 0;G=void 0;p=void 0;F=i.vertices;r=i.colors;Q=F.length;E=r.length;O=i.__vertexArray;S=i.__colorArray;Y=i.__dirtyColors;if(i.__dirtyVertices){for(q=0;q<Q;q++){G=F[q].position;p=q*3;O[p]=G.x;O[p+1]=G.y;O[p+2]=G.z}c.bindBuffer(c.ARRAY_BUFFER,i.__webGLVertexBuffer);c.bufferData(c.ARRAY_BUFFER,O,s)}if(Y){for(q=0;q<E;q++){color=r[q];p=q*3;S[p]=color.r;S[p+1]=color.g;S[p+2]=color.b}c.bindBuffer(c.ARRAY_BUFFER,
|
|
|
+i.__webGLColorBuffer);c.bufferData(c.ARRAY_BUFFER,S,s)}}k.__dirtyVertices=!1;k.__dirtyColors=!1}else if(i instanceof THREE.ParticleSystem){k=i.geometry;(k.__dirtyVertices||k.__dirtyColors||i.sortParticles)&&b(k,c.DYNAMIC_DRAW,i);k.__dirtyVertices=!1;k.__dirtyColors=!1}}};this.setFaceCulling=function(g,l){if(g){!l||l=="ccw"?c.frontFace(c.CCW):c.frontFace(c.CW);if(g=="back")c.cullFace(c.BACK);else g=="front"?c.cullFace(c.FRONT):c.cullFace(c.FRONT_AND_BACK);c.enable(c.CULL_FACE)}else c.disable(c.CULL_FACE)};
|
|
|
+this.supportsVertexTextures=function(){return c.getParameter(c.MAX_VERTEX_TEXTURE_IMAGE_UNITS)>0}};
|