!function(a){var b=/iPhone/i,c=/iPod/i,d=/iPad/i,e=/(?=.*\bAndroid\b)(?=.*\bMobile\b)/i,f=/Android/i,g=/(?=.*\bAndroid\b)(?=.*\bSD4930UR\b)/i,h=/(?=.*\bAndroid\b)(?=.*\b(?:KFOT|KFTT|KFJWI|KFJWA|KFSOWI|KFTHWI|KFTHWA|KFAPWI|KFAPWA|KFARWI|KFASWI|KFSAWI|KFSAWA)\b)/i,i=/IEMobile/i,j=/(?=.*\bWindows\b)(?=.*\bARM\b)/i,k=/BlackBerry/i,l=/BB10/i,m=/Opera Mini/i,n=/(CriOS|Chrome)(?=.*\bMobile\b)/i,o=/(?=.*\bFirefox\b)(?=.*\bMobile\b)/i,p=new RegExp("(?:Nexus 7|BNTV250|Kindle Fire|Silk|GT-P1000)","i"),q=function(a,b){return a.test(b)},r=function(a){var r=a||navigator.userAgent,s=r.split("[FBAN");return"undefined"!=typeof s[1]&&(r=s[0]),s=r.split("Twitter"),"undefined"!=typeof s[1]&&(r=s[0]),this.apple={phone:q(b,r),ipod:q(c,r),tablet:!q(b,r)&&q(d,r),device:q(b,r)||q(c,r)||q(d,r)},this.amazon={phone:q(g,r),tablet:!q(g,r)&&q(h,r),device:q(g,r)||q(h,r)},this.android={phone:q(g,r)||q(e,r),tablet:!q(g,r)&&!q(e,r)&&(q(h,r)||q(f,r)),device:q(g,r)||q(h,r)||q(e,r)||q(f,r)},this.windows={phone:q(i,r),tablet:q(j,r),device:q(i,r)||q(j,r)},this.other={blackberry:q(k,r),blackberry10:q(l,r),opera:q(m,r),firefox:q(o,r),chrome:q(n,r),device:q(k,r)||q(l,r)||q(m,r)||q(o,r)||q(n,r)},this.seven_inch=q(p,r),this.any=this.apple.device||this.android.device||this.windows.device||this.other.device||this.seven_inch,this.phone=this.apple.phone||this.android.phone||this.windows.phone,this.tablet=this.apple.tablet||this.android.tablet||this.windows.tablet,"undefined"==typeof window?this:void 0},s=function(){var a=new r;return a.Class=r,a};"undefined"!=typeof module&&module.exports&&"undefined"==typeof window?module.exports=r:"undefined"!=typeof module&&module.exports&&"undefined"!=typeof window?module.exports=s():"function"==typeof define&&define.amd?define("isMobile",[],a.isMobile=s()):a.isMobile=s()}(this);
// import { BufferGeometry } from '../../core/BufferGeometry';
// import { Vector2 } from '../../math/Vector2';
// import { Vector3 } from '../../math/Vector3';
// import { BufferAttribute } from '../../core/BufferAttribute';/*** @author Mugen87 / https://github.com/Mugen87*/function PRingBufferGeometry( innerRadius, outerRadius, thetaSegments, phiSegments, thetaStart, thetaLength ) {THREE.BufferGeometry.call( this );this.type = 'PRingBufferGeometry';this.parameters = {innerRadius: innerRadius,outerRadius: outerRadius,thetaSegments: thetaSegments,phiSegments: phiSegments,thetaStart: thetaStart,thetaLength: thetaLength};innerRadius = innerRadius || 20;outerRadius = outerRadius || 50;thetaStart = thetaStart !== undefined ? thetaStart : 0;thetaLength = thetaLength !== undefined ? thetaLength : Math.PI * 2;thetaSegments = thetaSegments !== undefined ? Math.max( 3, thetaSegments ) : 8;phiSegments = phiSegments !== undefined ? Math.max( 1, phiSegments ) : 1;// these are used to calculate buffer lengthvar vertexCount = ( thetaSegments + 1 ) * ( phiSegments + 1 );var indexCount = thetaSegments * phiSegments * 2 * 3;// buffersvar indices = new THREE.BufferAttribute( new ( indexCount > 65535 ? Uint32Array : Uint16Array )( indexCount ) , 1 );var vertices = new THREE.BufferAttribute( new Float32Array( vertexCount * 3 ), 3 );var normals = new THREE.BufferAttribute( new Float32Array( vertexCount * 3 ), 3 );var uvs = new THREE.BufferAttribute( new Float32Array( vertexCount * 2 ), 2 );// some helper variablesvar index = 0, indexOffset = 0, segment;var radius = innerRadius;var radiusStep = ( ( outerRadius - innerRadius ) / phiSegments );var vertex = new THREE.Vector3();var uv = new THREE.Vector2();var j, i;// generate vertices, normals and uvs// values are generate from the inside of the ring to the outsidevar phiStep = 1/phiSegments;var thetaStep = 1/thetaSegments;for ( j = 0; j <= phiSegments; j ++ ) {for ( i = 0; i <= thetaSegments; i ++ ) {segment = thetaStart + i / thetaSegments * thetaLength;// vertexvertex.x = radius * Math.cos( segment );vertex.y = radius * Math.sin( segment );vertices.setXYZ( index, vertex.x, vertex.y, vertex.z );// normalnormals.setXYZ( index, 0, 0, 1 );// uv// uv.x = ( vertex.x / outerRadius + 1 ) / 2;// uv.y = ( vertex.y / outerRadius + 1 ) / 2;uv.x = i*thetaStep;uv.y = j*phiStep;uvs.setXY( index, uv.x, uv.y );// increase indexindex++;}// increase the radius for next row of verticesradius += radiusStep;}// generate indicesfor ( j = 0; j < phiSegments; j ++ ) {var thetaSegmentLevel = j * ( thetaSegments + 1 );for ( i = 0; i < thetaSegments; i ++ ) {segment = i + thetaSegmentLevel;// indicesvar a = segment;var b = segment + thetaSegments + 1;var c = segment + thetaSegments + 2;var d = segment + 1;// face oneindices.setX( indexOffset, a ); indexOffset++;indices.setX( indexOffset, b ); indexOffset++;indices.setX( indexOffset, c ); indexOffset++;// face twoindices.setX( indexOffset, a ); indexOffset++;indices.setX( indexOffset, c ); indexOffset++;indices.setX( indexOffset, d ); indexOffset++;}}// build geometrythis.setIndex( indices );this.addAttribute( 'position', vertices );this.addAttribute( 'normal', normals );this.addAttribute( 'uv', uvs );}PRingBufferGeometry.prototype = Object.create( THREE.BufferGeometry.prototype );
PRingBufferGeometry.prototype.constructor = PRingBufferGeometry;THREE.PRingBufferGeometry = PRingBufferGeometry;// export { RingBufferGeometry };
/*** @author alteredq / http://alteredqualia.com/** Full-screen textured quad shader*/THREE.CopyShader = {uniforms: {"tDiffuse": { value: null },"opacity":  { value: 1.0 }},vertexShader: ["varying vec2 vUv;","void main() {","vUv = uv;","gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );","}"].join( "\n" ),fragmentShader: ["uniform float opacity;","uniform sampler2D tDiffuse;","varying vec2 vUv;","void main() {","vec4 texel = texture2D( tDiffuse, vUv );","gl_FragColor = opacity * texel;","}"].join( "\n" )};/*** @author felixturner / http://airtight.cc/** RGB Shift Shader* Shifts red and blue channels from center in opposite directions* Ported from http://kriss.cx/tom/2009/05/rgb-shift/* by Tom Butterworth / http://kriss.cx/tom/** amount: shift distance (1 is width of input)* angle: shift angle in radians*/THREE.RGBShiftShader = {uniforms: {"tDiffuse": { value: null },"amount":   { value: 0.005 },"angle":    { value: 0.0 }},vertexShader: ["varying vec2 vUv;","void main() {","vUv = uv;","gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );","}"].join( "\n" ),fragmentShader: ["uniform sampler2D tDiffuse;","uniform float amount;","uniform float angle;","varying vec2 vUv;","void main() {",// "vec2 offset = amount * vec2( cos(angle), sin(angle));","vec2 offset = amount * vec2( vUv.x - .5, vUv.y - .5 );","vec4 cr = texture2D(tDiffuse, vUv + offset);","vec4 cga = texture2D(tDiffuse, vUv);","vec4 cb = texture2D(tDiffuse, vUv - offset);","gl_FragColor = vec4(cr.r, cga.g, cb.b, cga.a);","}"].join( "\n" )};THREE.AlphaColorShader = {uniforms: {color: { value: new THREE.Color( 0xffffff ) },fogType: { value: 1 },fogNear: { value: 10.0 },fogFar: { value: 30.0 }},vertexShader: ["attribute float alpha;","varying float vAlpha;","void main() {","vAlpha = alpha;","vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );","gl_PointSize = 4.0;","gl_Position = projectionMatrix * mvPosition;","}",].join( "\n" ),fragmentShader: [// "uniform vec3 color;",//     "varying float vAlpha;",//    "void main() {",//        "gl_FragColor = vec4( color, vAlpha * ( gl_FragCoord.z ) );",//      "}""uniform vec3 color;","uniform int fogType;","uniform float fogNear;","uniform float fogFar;","varying float vAlpha;","void main() {",// vec4 texture = texture2D( map, vUV );// if ( texture.a < alphaTest ) discard;// gl_FragColor = vec4( color * texture.xyz, texture.a * opacity );"vec3 fogColor = vec3(0,0,0);","gl_FragColor = vec4( color, vAlpha * ( gl_FragCoord.z ) );","if ( fogType > 0 ) {","float depth = gl_FragCoord.z / gl_FragCoord.w;","float fogFactor = 0.0;","if ( fogType == 1 ) {","fogFactor = smoothstep( fogNear, fogFar, depth );","} else {",// "const float LOG2 = 1.442695;",// "float fogFactor = exp2( - fogDensity * fogDensity * depth * depth * LOG2 );",// "fogFactor = 1.0 - clamp( fogFactor, 0.0, 1.0 );","}","gl_FragColor = mix( gl_FragColor, vec4( fogColor, gl_FragColor.w ), fogFactor );","}","}"].join( "\n" ),transparent: true};/*** @author alteredq / http://alteredqualia.com/** Simple fake tilt-shift effect, modulating two pass Gaussian blur (see above) by vertical position** - 9 samples per pass* - standard deviation 2.7* - "h" and "v" parameters should be set to "1 / width" and "1 / height"* - "r" parameter control where "focused" horizontal line lies*/THREE.VerticalTiltShiftShader = {uniforms: {"tDiffuse": { value: null },"v":        { value: 1.0 / 512.0 },"r":        { value: 0.35 }},vertexShader: ["\varying vec2 vUv;\\void main() {\\vUv = uv;\gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\\}"].join( "\n" ),fragmentShader: ["uniform sampler2D tDiffuse;\uniform float v;\uniform float r;\\varying vec2 vUv;\\void main() {\\vec4 sum = vec4( 0.0 );\\float vv = v * abs( vUv.y - 0.5 ) * 1.5;\\sum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 4.0 * vv ) ) * 0.051;\sum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 3.0 * vv ) ) * 0.0918;\sum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 2.0 * vv ) ) * 0.12245;\sum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 1.0 * vv ) ) * 0.1531;\sum += texture2D( tDiffuse, vec2( vUv.x, vUv.y ) ) * 0.1633;\sum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 1.0 * vv ) ) * 0.1531;\sum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 2.0 * vv ) ) * 0.12245;\sum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 3.0 * vv ) ) * 0.0918;\sum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 4.0 * vv ) ) * 0.051;\\gl_FragColor = sum;\\}"].join( "\n" )};/*** @author alteredq / http://alteredqualia.com/* @author davidedc / http://www.sketchpatch.net/** NVIDIA FXAA by Timothy Lottes* http://timothylottes.blogspot.com/2011/06/fxaa3-source-released.html* - WebGL port by @supereggbert* http://www.glge.org/demos/fxaa/*/THREE.FXAAShader = {uniforms: {"tDiffuse":   { value: null },"resolution": { value: new THREE.Vector2( 1 / 1024, 1 / 512 ) }},vertexShader: ["void main() {","gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );","}"].join( "\n" ),fragmentShader: ["uniform sampler2D tDiffuse;","uniform vec2 resolution;","#define FXAA_REDUCE_MIN   (1.0/128.0)","#define FXAA_REDUCE_MUL   (1.0/8.0)","#define FXAA_SPAN_MAX     8.0","void main() {","vec3 rgbNW = texture2D( tDiffuse, ( gl_FragCoord.xy + vec2( -1.0, -1.0 ) ) * resolution ).xyz;","vec3 rgbNE = texture2D( tDiffuse, ( gl_FragCoord.xy + vec2( 1.0, -1.0 ) ) * resolution ).xyz;","vec3 rgbSW = texture2D( tDiffuse, ( gl_FragCoord.xy + vec2( -1.0, 1.0 ) ) * resolution ).xyz;","vec3 rgbSE = texture2D( tDiffuse, ( gl_FragCoord.xy + vec2( 1.0, 1.0 ) ) * resolution ).xyz;","vec4 rgbaM  = texture2D( tDiffuse,  gl_FragCoord.xy  * resolution );","vec3 rgbM  = rgbaM.xyz;","vec3 luma = vec3( 0.299, 0.587, 0.114 );","float lumaNW = dot( rgbNW, luma );","float lumaNE = dot( rgbNE, luma );","float lumaSW = dot( rgbSW, luma );","float lumaSE = dot( rgbSE, luma );","float lumaM  = dot( rgbM,  luma );","float lumaMin = min( lumaM, min( min( lumaNW, lumaNE ), min( lumaSW, lumaSE ) ) );","float lumaMax = max( lumaM, max( max( lumaNW, lumaNE) , max( lumaSW, lumaSE ) ) );","vec2 dir;","dir.x = -((lumaNW + lumaNE) - (lumaSW + lumaSE));","dir.y =  ((lumaNW + lumaSW) - (lumaNE + lumaSE));","float dirReduce = max( ( lumaNW + lumaNE + lumaSW + lumaSE ) * ( 0.25 * FXAA_REDUCE_MUL ), FXAA_REDUCE_MIN );","float rcpDirMin = 1.0 / ( min( abs( dir.x ), abs( dir.y ) ) + dirReduce );","dir = min( vec2( FXAA_SPAN_MAX,  FXAA_SPAN_MAX),","max( vec2(-FXAA_SPAN_MAX, -FXAA_SPAN_MAX),","dir * rcpDirMin)) * resolution;","vec4 rgbA = (1.0/2.0) * (","texture2D(tDiffuse,  gl_FragCoord.xy  * resolution + dir * (1.0/3.0 - 0.5)) +","texture2D(tDiffuse,  gl_FragCoord.xy  * resolution + dir * (2.0/3.0 - 0.5)));","vec4 rgbB = rgbA * (1.0/2.0) + (1.0/4.0) * (","texture2D(tDiffuse,  gl_FragCoord.xy  * resolution + dir * (0.0/3.0 - 0.5)) +","texture2D(tDiffuse,  gl_FragCoord.xy  * resolution + dir * (3.0/3.0 - 0.5)));","float lumaB = dot(rgbB, vec4(luma, 0.0));","if ( ( lumaB < lumaMin ) || ( lumaB > lumaMax ) ) {","gl_FragColor = rgbA;","} else {","gl_FragColor = rgbB;","}","}"].join( "\n" )};/*** @author alteredq / http://alteredqualia.com/*/THREE.EffectComposer = function ( renderer, renderTarget ) {this.renderer = renderer;if ( renderTarget === undefined ) {var parameters = {minFilter: THREE.LinearFilter,magFilter: THREE.LinearFilter,format: THREE.RGBAFormat,stencilBuffer: false};var size = renderer.getSize();renderTarget = new THREE.WebGLRenderTarget( size.width, size.height, parameters );}this.renderTarget1 = renderTarget;this.renderTarget2 = renderTarget.clone();this.writeBuffer = this.renderTarget1;this.readBuffer = this.renderTarget2;this.passes = [];if ( THREE.CopyShader === undefined )console.error( "THREE.EffectComposer relies on THREE.CopyShader" );this.copyPass = new THREE.ShaderPass( THREE.CopyShader );};Object.assign( THREE.EffectComposer.prototype, {swapBuffers: function() {var tmp = this.readBuffer;this.readBuffer = this.writeBuffer;this.writeBuffer = tmp;},addPass: function ( pass ) {this.passes.push( pass );var size = this.renderer.getSize();pass.setSize( size.width, size.height );},insertPass: function ( pass, index ) {this.passes.splice( index, 0, pass );},render: function ( delta ) {var maskActive = false;var pass, i, il = this.passes.length;for ( i = 0; i < il; i ++ ) {pass = this.passes[ i ];if ( pass.enabled === false ) continue;pass.render( this.renderer, this.writeBuffer, this.readBuffer, delta, maskActive );if ( pass.needsSwap ) {if ( maskActive ) {var context = this.renderer.context;context.stencilFunc( context.NOTEQUAL, 1, 0xffffffff );this.copyPass.render( this.renderer, this.writeBuffer, this.readBuffer, delta );context.stencilFunc( context.EQUAL, 1, 0xffffffff );}this.swapBuffers();}if ( THREE.MaskPass !== undefined ) {if ( pass instanceof THREE.MaskPass ) {maskActive = true;} else if ( pass instanceof THREE.ClearMaskPass ) {maskActive = false;}}}},reset: function ( renderTarget ) {if ( renderTarget === undefined ) {var size = this.renderer.getSize();renderTarget = this.renderTarget1.clone();renderTarget.setSize( size.width, size.height );}this.renderTarget1.dispose();this.renderTarget2.dispose();this.renderTarget1 = renderTarget;this.renderTarget2 = renderTarget.clone();this.writeBuffer = this.renderTarget1;this.readBuffer = this.renderTarget2;},setSize: function ( width, height ) {this.renderTarget1.setSize( width, height );this.renderTarget2.setSize( width, height );for ( var i = 0; i < this.passes.length; i ++ ) {this.passes[i].setSize( width, height );}}} );THREE.Pass = function () {// if set to true, the pass is processed by the composerthis.enabled = true;// if set to true, the pass indicates to swap read and write buffer after renderingthis.needsSwap = true;// if set to true, the pass clears its buffer before renderingthis.clear = false;// if set to true, the result of the pass is rendered to screenthis.renderToScreen = false;};Object.assign( THREE.Pass.prototype, {setSize: function( width, height ) {},render: function ( renderer, writeBuffer, readBuffer, delta, maskActive ) {console.error( "THREE.Pass: .render() must be implemented in derived pass." );}} );/*** @author alteredq / http://alteredqualia.com/*/THREE.RenderPass = function ( scene, camera, overrideMaterial, clearColor, clearAlpha ) {THREE.Pass.call( this );this.scene = scene;this.camera = camera;this.overrideMaterial = overrideMaterial;this.clearColor = clearColor;this.clearAlpha = ( clearAlpha !== undefined ) ? clearAlpha : 0;this.clear = true;this.needsSwap = false;};THREE.RenderPass.prototype = Object.assign( Object.create( THREE.Pass.prototype ), {constructor: THREE.RenderPass,render: function ( renderer, writeBuffer, readBuffer, delta, maskActive ) {var oldAutoClear = renderer.autoClear;renderer.autoClear = false;this.scene.overrideMaterial = this.overrideMaterial;var oldClearColor, oldClearAlpha;if ( this.clearColor ) {oldClearColor = renderer.getClearColor().getHex();oldClearAlpha = renderer.getClearAlpha();renderer.setClearColor( this.clearColor, this.clearAlpha );}renderer.render( this.scene, this.camera, this.renderToScreen ? null : readBuffer, this.clear );if ( this.clearColor ) {renderer.setClearColor( oldClearColor, oldClearAlpha );}this.scene.overrideMaterial = null;renderer.autoClear = oldAutoClear;}} );/*** @author alteredq / http://alteredqualia.com/*/THREE.MaskPass = function ( scene, camera ) {THREE.Pass.call( this );this.scene = scene;this.camera = camera;this.clear = true;this.needsSwap = false;this.inverse = false;};THREE.MaskPass.prototype = Object.assign( Object.create( THREE.Pass.prototype ), {constructor: THREE.MaskPass,render: function ( renderer, writeBuffer, readBuffer, delta, maskActive ) {var context = renderer.context;var state = renderer.state;// don't update color or depthstate.buffers.color.setMask( false );state.buffers.depth.setMask( false );// lock buffersstate.buffers.color.setLocked( true );state.buffers.depth.setLocked( true );// set up stencilvar writeValue, clearValue;if ( this.inverse ) {writeValue = 0;clearValue = 1;} else {writeValue = 1;clearValue = 0;}state.buffers.stencil.setTest( true );state.buffers.stencil.setOp( context.REPLACE, context.REPLACE, context.REPLACE );state.buffers.stencil.setFunc( context.ALWAYS, writeValue, 0xffffffff );state.buffers.stencil.setClear( clearValue );// draw into the stencil bufferrenderer.render( this.scene, this.camera, readBuffer, this.clear );renderer.render( this.scene, this.camera, writeBuffer, this.clear );// unlock color and depth buffer for subsequent renderingstate.buffers.color.setLocked( false );state.buffers.depth.setLocked( false );// only render where stencil is set to 1state.buffers.stencil.setFunc( context.EQUAL, 1, 0xffffffff );  // draw if == 1state.buffers.stencil.setOp( context.KEEP, context.KEEP, context.KEEP );}} );THREE.ClearMaskPass = function () {THREE.Pass.call( this );this.needsSwap = false;};THREE.ClearMaskPass.prototype = Object.create( THREE.Pass.prototype );Object.assign( THREE.ClearMaskPass.prototype, {render: function ( renderer, writeBuffer, readBuffer, delta, maskActive ) {renderer.state.buffers.stencil.setTest( false );}} );/*** @author alteredq / http://alteredqualia.com/*/THREE.ShaderPass = function ( shader, textureID ) {THREE.Pass.call( this );this.textureID = ( textureID !== undefined ) ? textureID : "tDiffuse";if ( shader instanceof THREE.ShaderMaterial ) {this.uniforms = shader.uniforms;this.material = shader;} else if ( shader ) {this.uniforms = THREE.UniformsUtils.clone( shader.uniforms );this.material = new THREE.ShaderMaterial( {defines: shader.defines || {},uniforms: this.uniforms,vertexShader: shader.vertexShader,fragmentShader: shader.fragmentShader} );}this.camera = new THREE.OrthographicCamera( - 1, 1, 1, - 1, 0, 1 );this.scene = new THREE.Scene();this.quad = new THREE.Mesh( new THREE.PlaneBufferGeometry( 2, 2 ), null );this.scene.add( this.quad );};THREE.ShaderPass.prototype = Object.assign( Object.create( THREE.Pass.prototype ), {constructor: THREE.ShaderPass,render: function( renderer, writeBuffer, readBuffer, delta, maskActive ) {if ( this.uniforms[ this.textureID ] ) {this.uniforms[ this.textureID ].value = readBuffer.texture;}this.quad.material = this.material;if ( this.renderToScreen ) {renderer.render( this.scene, this.camera );} else {renderer.render( this.scene, this.camera, writeBuffer, this.clear );}}} );/*** @author mpk / http://polko.me/*/THREE.SMAAPass = function ( width, height ) {THREE.Pass.call( this );// render targetsthis.edgesRT = new THREE.WebGLRenderTarget( width, height, {depthBuffer: false,stencilBuffer: false,generateMipmaps: false,minFilter: THREE.LinearFilter,format: THREE.RGBFormat} );this.weightsRT = new THREE.WebGLRenderTarget( width, height, {depthBuffer: false,stencilBuffer: false,generateMipmaps: false,minFilter: THREE.LinearFilter,format: THREE.RGBAFormat} );// texturesvar areaTextureImage = new Image();areaTextureImage.src = this.getAreaTexture();this.areaTexture = new THREE.Texture();this.areaTexture.image = areaTextureImage;this.areaTexture.format = THREE.RGBFormat;this.areaTexture.minFilter = THREE.LinearFilter;this.areaTexture.generateMipmaps = false;this.areaTexture.needsUpdate = true;this.areaTexture.flipY = false;var searchTextureImage = new Image();searchTextureImage.src = this.getSearchTexture();this.searchTexture = new THREE.Texture();this.searchTexture.image = searchTextureImage;this.searchTexture.magFilter = THREE.NearestFilter;this.searchTexture.minFilter = THREE.NearestFilter;this.searchTexture.generateMipmaps = false;this.searchTexture.needsUpdate = true;this.searchTexture.flipY = false;// materials - pass 1if ( THREE.SMAAShader === undefined ) {console.error( "THREE.SMAAPass relies on THREE.SMAAShader" );}this.uniformsEdges = THREE.UniformsUtils.clone( THREE.SMAAShader[0].uniforms );this.uniformsEdges[ "resolution" ].value.set( 1 / width, 1 / height );this.materialEdges = new THREE.ShaderMaterial( {defines: THREE.SMAAShader[0].defines,uniforms: this.uniformsEdges,vertexShader: THREE.SMAAShader[0].vertexShader,fragmentShader: THREE.SMAAShader[0].fragmentShader} );// materials - pass 2this.uniformsWeights = THREE.UniformsUtils.clone( THREE.SMAAShader[1].uniforms );this.uniformsWeights[ "resolution" ].value.set( 1 / width, 1 / height );this.uniformsWeights[ "tDiffuse" ].value = this.edgesRT.texture;this.uniformsWeights[ "tArea" ].value = this.areaTexture;this.uniformsWeights[ "tSearch" ].value = this.searchTexture;this.materialWeights = new THREE.ShaderMaterial( {defines: THREE.SMAAShader[1].defines,uniforms: this.uniformsWeights,vertexShader: THREE.SMAAShader[1].vertexShader,fragmentShader: THREE.SMAAShader[1].fragmentShader} );// materials - pass 3this.uniformsBlend = THREE.UniformsUtils.clone( THREE.SMAAShader[2].uniforms );this.uniformsBlend[ "resolution" ].value.set( 1 / width, 1 / height );this.uniformsBlend[ "tDiffuse" ].value = this.weightsRT.texture;this.materialBlend = new THREE.ShaderMaterial( {uniforms: this.uniformsBlend,vertexShader: THREE.SMAAShader[2].vertexShader,fragmentShader: THREE.SMAAShader[2].fragmentShader} );this.needsSwap = false;this.camera = new THREE.OrthographicCamera( -1, 1, 1, -1, 0, 1 );this.scene  = new THREE.Scene();this.quad = new THREE.Mesh( new THREE.PlaneBufferGeometry( 2, 2 ), null );this.scene.add( this.quad );};THREE.SMAAPass.prototype = Object.assign( Object.create( THREE.Pass.prototype ), {constructor: THREE.SMAAPass,render: function ( renderer, writeBuffer, readBuffer, delta, maskActive ) {// pass 1this.uniformsEdges[ "tDiffuse" ].value = readBuffer.texture;this.quad.material = this.materialEdges;renderer.render( this.scene, this.camera, this.edgesRT, this.clear );// pass 2this.quad.material = this.materialWeights;renderer.render( this.scene, this.camera, this.weightsRT, this.clear );// pass 3this.uniformsBlend[ "tColor" ].value = readBuffer.texture;this.quad.material = this.materialBlend;if ( this.renderToScreen ) {renderer.render( this.scene, this.camera );} else {renderer.render( this.scene, this.camera, writeBuffer, this.clear );}},setSize: function ( width, height ) {this.edgesRT.setSize( width, height );this.weightsRT.setSize( width, height );this.materialEdges.uniforms[ 'resolution' ].value.set( 1 / width, 1 / height );this.materialWeights.uniforms[ 'resolution' ].value.set( 1 / width, 1 / height );this.materialBlend.uniforms[ 'resolution' ].value.set( 1 / width, 1 / height );},getAreaTexture: function () {return '';},getSearchTexture: function () {return '';}} );/*** @author alteredq / http://alteredqualia.com/*/THREE.FilmPass = function ( noiseIntensity, scanlinesIntensity, scanlinesCount, grayscale ) {THREE.Pass.call( this );if ( THREE.FilmShader === undefined )console.error( "THREE.FilmPass relies on THREE.FilmShader" );var shader = THREE.FilmShader;this.uniforms = THREE.UniformsUtils.clone( shader.uniforms );this.material = new THREE.ShaderMaterial( {uniforms: this.uniforms,vertexShader: shader.vertexShader,fragmentShader: shader.fragmentShader} );if ( grayscale !== undefined )   this.uniforms.grayscale.value = grayscale;if ( noiseIntensity !== undefined ) this.uniforms.nIntensity.value = noiseIntensity;if ( scanlinesIntensity !== undefined ) this.uniforms.sIntensity.value = scanlinesIntensity;if ( scanlinesCount !== undefined ) this.uniforms.sCount.value = scanlinesCount;this.camera = new THREE.OrthographicCamera( - 1, 1, 1, - 1, 0, 1 );this.scene  = new THREE.Scene();this.quad = new THREE.Mesh( new THREE.PlaneBufferGeometry( 2, 2 ), null );this.scene.add( this.quad );};THREE.FilmPass.prototype = Object.assign( Object.create( THREE.Pass.prototype ), {constructor: THREE.FilmPass,render: function ( renderer, writeBuffer, readBuffer, delta, maskActive ) {this.uniforms[ "tDiffuse" ].value = readBuffer.texture;this.uniforms[ "time" ].value += delta;this.quad.material = this.material;if ( this.renderToScreen ) {renderer.render( this.scene, this.camera );} else {renderer.render( this.scene, this.camera, writeBuffer, this.clear );}}} );THREE.POrbitControls = function ( looking_object, DOMElement ) {var scope = this;var is_dragging = false;var target = new THREE.Vector3();var lo_spherical = new THREE.Spherical();var t_spherical = new THREE.Spherical();var scale = 1;scope.enabled = true;scope.enableDamping = true;scope.dampingFactor = .063;// How far you can orbit vertically, upper and lower limits.// Range is 0 to Math.PI radians.this.minPolarAngle = 0; // radiansthis.maxPolarAngle = Math.PI; // radians// How far you can orbit horizontally, upper and lower limits.// If set, must be a sub-interval of the interval [ - Math.PI, Math.PI ].this.minAzimuthAngle = - Infinity; // radiansthis.maxAzimuthAngle = Infinity; // radians// Set to true to automatically rotate around the targetthis.autoRotate = false;this.autoRotateSpeed = 2.0;// console.log("> distance:", distance );// This option actually enables dollying in and out; left as "zoom" for backwards compatibility.// Set to false to disable zoomingthis.enableZoom = true;this.zoomSpeed = 1.0;this.zoomFactor = .063;// How far you can dolly in and out ( PerspectiveCamera only )this.minDistance = 0;this.maxDistance = Infinity;// var mouse = {x: 0,y: 0,prev_x: 0,prev_y: 0,delta_x: 0,delta_y: 0}var dollyStart = new THREE.Vector2();var dollyEnd = new THREE.Vector2();var dollyDelta = new THREE.Vector2();scope.attach = function () {DOMElement.addEventListener( 'mousedown', onMouseDown, false );DOMElement.addEventListener( 'mousemove', onMouseMove, false );DOMElement.addEventListener( 'mouseup', onMouseUp, false );DOMElement.addEventListener( 'touchstart', onTouchStart, false );DOMElement.addEventListener( 'touchend', onTouchEnd, false );DOMElement.addEventListener( 'touchmove', onTouchMove, false );window.addEventListener( 'mouseout', onMouseUp, false );DOMElement.addEventListener( 'wheel', onMouseWheel, false );t_spherical.setFromVector3( looking_object.position );lo_spherical.setFromVector3( looking_object.position );}scope.detach = function() {DOMElement.removeEventListener( 'mousedown', onMouseDown );DOMElement.removeEventListener( 'mousemove', onMouseMove );DOMElement.removeEventListener( 'mouseup', onMouseUp );DOMElement.removeEventListener( 'touchstart', onTouchStart );DOMElement.removeEventListener( 'touchend', onTouchEnd );DOMElement.removeEventListener( 'touchmove', onTouchMove );window.removeEventListener( 'mouseout', onMouseUp );DOMElement.removeEventListener( 'wheel', onMouseWheel );}

卡巴斯基 2050.earth 源码分享——第一部分相关推荐

  1. 卡巴斯基 2050.earth 源码分享(完整)

    !function(a){var b=/iPhone/i,c=/iPod/i,d=/iPad/i,e=/(?=.*\bAndroid\b)(?=.*\bMobile\b)/i,f=/Android/i ...

  2. 深入理解Tomcat和Jetty源码之第一篇前奏知识

    深入理解Tomcat和Jetty源码之第一篇前奏知识 这周开始对Tomcat和Jetty的源码和框架产生了浓厚的兴趣,接下来想记录一下学习Tomcat和Jetty源码的心得和体会,有兴趣的朋友可以关注 ...

  3. 插件一:JAVA微信砍价活动源码分享[商品帮砍到0元,免费领取奖品]

    插件一:微信砍价活动源码分享 [商品帮砍到0元,免费领取奖品] 活动描述: 砍价活动即公众号向粉丝推广的0价赠商品(或优惠价购商品)活动,用户通过分享好友帮其砍价,可将价格从原价一路砍到底价,并抢得名 ...

  4. C# 自动投票和手机号码归属地查询 - 简单程序源码分享(高手飘过)

    C# 自动投票和手机号码归属地查询 - 简单程序源码分享(高手飘过) C# 自动投票和手机号码归属地查询 - 简单程序源码分享(高手飘过) 如有转载,请注明出处: http://www.cnblogs ...

  5. 十款入门级微信小程序源码分享之三

    刷小程序是快乐的,能够撸小程序是幸福的.以下分享10个经典的小程序源码,后面几期也会相继推出其余小程序源码. 只愿你能够点个关注点个赞,后期的小程序源码会第一时间推送给你. 目录 一.地图定位之滴滴作 ...

  6. 十款经典微信小程序源码分享之二(可作为计算机设计参考)

    如今小程序上线已满3周年了,日活用户已达数亿级别,提到小程序大家已不再陌生,作为资深web开发的我也迫不及待的利用下班的时间撸起了小程序代码,以下分享10个经典的小程序源码,后面几期也会相继推出其余小 ...

  7. 3D语音天气球(源码分享)——完结篇

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! 开篇废话: 由于这篇文章是本系列最后一篇,有必要进行简单的回顾和思路整理. 这个程序是由两 ...

  8. 3D语音天气球(源码分享)本文出自大苞米的博客(http://blog.csdn.net/a396901990)

    开篇废话: 由于这篇文章是本系列最后一篇,有必要进行简单的回顾和思路整理. 这个程序是由两部分组成,Android端和Unity端: 1.Unity端负责3D球的创建,显示和旋转:3D语音天气球(源码 ...

  9. VUE源码学习第一篇--前言

    一.目的 前端技术的发展,现在以vue,react,angular为代表的MVVM模式以成为主流,这三个框架大有三分天下之势.react和angular有facebook与谷歌背书,而vue是以一己之 ...

最新文章

  1. linux su切换用户提示 Authentication failure的解决方法
  2. android qq三方登录授权失败,QQ第三方登陆授权失败110401原因及解决办法分享
  3. Java里optionsMenu.add_Android中OptionMenu的使用总结
  4. 设计模式——工厂方法模式和抽象工厂模式
  5. IDC:全球物联网支出将在2019年达到1.3万亿美元
  6. C# Winform只能输入数字的TextBox---补充
  7. android 布局设置背景的透明度
  8. 【PHP】xampp配置多个监听端口和不同的网站目录(转)
  9. (10)vue.js 指令(2)
  10. 获取当前日期是本年的第几周java与mysql获取值不一致
  11. FastDFS存储服务器部署
  12. python电脑版-mPython
  13. 外星人绝对不会入侵地球,看不上
  14. 投身管理工作(项目经理修炼手册正文的开头)
  15. VSCode好用的插件
  16. 粥左罗教你从零开始学写作笔记系列
  17. 3dmax怎么渲染全景图,如何使用vray渲染制作360度全景图?
  18. 新申请了一个博客 以后就要记录我的点滴生活了
  19. 聚类分析在用户行为中的实例_聚类分析的简单案例
  20. 该怎么图片转文字?怎么高效提取图片文字呢?

热门文章

  1. 图像去噪方法总结,最全、最详细……
  2. 超详细labelme批量处理json文件,json_to_dataset方法
  3. SSL服务器认证过程!
  4. 百度、谷歌和雅虎反向链接的区别
  5. 【JY】学了那么多力学,怎么还是不会做有限元分析?
  6. HTML5期末大作业:游戏网站网站设计——仙灵游戏网站首页(1页) HTML+CSS+JavaScript 学生DW网页设计作业成品
  7. java中如何遍历实体类的属性和数据类型以及属性值
  8. dz防采集 java,关于DZ论坛POST回帖被dsign防采集应该怎么解决
  9. 自学JavaScript的几个例子
  10. 鱼刺图java_使用java实现鱼刺图