whs.js/modules/StatsModule.module.js
2018-06-02 14:22:49 +03:00

8138 lines
5.2 MiB

/* Built for whs v2.2.0-beta.0 */
function _classCallCheck(instance, Constructor) {
if (!(instance instanceof Constructor)) {
throw new TypeError("Cannot call a class as a function");
}
}
function _defineProperties(target, props) {
for (var i = 0; i < props.length; i++) {
var descriptor = props[i];
descriptor.enumerable = descriptor.enumerable || false;
descriptor.configurable = true;
if ("value" in descriptor) descriptor.writable = true;
Object.defineProperty(target, descriptor.key, descriptor);
}
}
function _createClass(Constructor, protoProps, staticProps) {
if (protoProps) _defineProperties(Constructor.prototype, protoProps);
if (staticProps) _defineProperties(Constructor, staticProps);
return Constructor;
}
function _defineProperty(obj, key, value) {
if (key in obj) {
Object.defineProperty(obj, key, {
value: value,
enumerable: true,
configurable: true,
writable: true
});
} else {
obj[key] = value;
}
return obj;
}
/* WhitestormJS Framework v2.2.0-alpha.0 */function createCommonjsModule(fn,module){return module={exports:{}},fn(module,module.exports),module.exports;}var runtime=createCommonjsModule(function(module){/**
* Copyright (c) 2014-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/!function(global){var Op=Object.prototype;var hasOwn=Op.hasOwnProperty;var undefined;// More compressible than void 0.
var $Symbol=typeof Symbol==="function"?Symbol:{};var iteratorSymbol=$Symbol.iterator||"@@iterator";var asyncIteratorSymbol=$Symbol.asyncIterator||"@@asyncIterator";var toStringTagSymbol=$Symbol.toStringTag||"@@toStringTag";var runtime=global.regeneratorRuntime;if(runtime){{// If regeneratorRuntime is defined globally and we're in a module,
// make the exports object identical to regeneratorRuntime.
module.exports=runtime;}// Don't bother evaluating the rest of this file if the runtime was
// already defined globally.
return;}// Define the runtime globally (as expected by generated code) as either
// module.exports (if we're in a module) or a new, empty object.
runtime=global.regeneratorRuntime=module.exports;function wrap(innerFn,outerFn,self,tryLocsList){// If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.
var protoGenerator=outerFn&&outerFn.prototype instanceof Generator?outerFn:Generator;var generator=Object.create(protoGenerator.prototype);var context=new Context(tryLocsList||[]);// The ._invoke method unifies the implementations of the .next,
// .throw, and .return methods.
generator._invoke=makeInvokeMethod(innerFn,self,context);return generator;}runtime.wrap=wrap;// Try/catch helper to minimize deoptimizations. Returns a completion
// record like context.tryEntries[i].completion. This interface could
// have been (and was previously) designed to take a closure to be
// invoked without arguments, but in all the cases we care about we
// already have an existing method we want to call, so there's no need
// to create a new function object. We can even get away with assuming
// the method takes exactly one argument, since that happens to be true
// in every case, so we don't have to touch the arguments object. The
// only additional allocation required is the completion record, which
// has a stable shape and so hopefully should be cheap to allocate.
function tryCatch(fn,obj,arg){try{return {type:"normal",arg:fn.call(obj,arg)};}catch(err){return {type:"throw",arg:err};}}var GenStateSuspendedStart="suspendedStart";var GenStateSuspendedYield="suspendedYield";var GenStateExecuting="executing";var GenStateCompleted="completed";// Returning this object from the innerFn has the same effect as
// breaking out of the dispatch switch statement.
var ContinueSentinel={};// Dummy constructor functions that we use as the .constructor and
// .constructor.prototype properties for functions that return Generator
// objects. For full spec compliance, you may wish to configure your
// minifier not to mangle the names of these two functions.
function Generator(){}function GeneratorFunction(){}function GeneratorFunctionPrototype(){}// This is a polyfill for %IteratorPrototype% for environments that
// don't natively support it.
var IteratorPrototype={};IteratorPrototype[iteratorSymbol]=function(){return this;};var getProto=Object.getPrototypeOf;var NativeIteratorPrototype=getProto&&getProto(getProto(values([])));if(NativeIteratorPrototype&&NativeIteratorPrototype!==Op&&hasOwn.call(NativeIteratorPrototype,iteratorSymbol)){// This environment has a native %IteratorPrototype%; use it instead
// of the polyfill.
IteratorPrototype=NativeIteratorPrototype;}var Gp=GeneratorFunctionPrototype.prototype=Generator.prototype=Object.create(IteratorPrototype);GeneratorFunction.prototype=Gp.constructor=GeneratorFunctionPrototype;GeneratorFunctionPrototype.constructor=GeneratorFunction;GeneratorFunctionPrototype[toStringTagSymbol]=GeneratorFunction.displayName="GeneratorFunction";// Helper for defining the .next, .throw, and .return methods of the
// Iterator interface in terms of a single ._invoke method.
function defineIteratorMethods(prototype){["next","throw","return"].forEach(function(method){prototype[method]=function(arg){return this._invoke(method,arg);};});}runtime.isGeneratorFunction=function(genFun){var ctor=typeof genFun==="function"&&genFun.constructor;return ctor?ctor===GeneratorFunction||// For the native GeneratorFunction constructor, the best we can
// do is to check its .name property.
(ctor.displayName||ctor.name)==="GeneratorFunction":false;};runtime.mark=function(genFun){if(Object.setPrototypeOf){Object.setPrototypeOf(genFun,GeneratorFunctionPrototype);}else{genFun.__proto__=GeneratorFunctionPrototype;if(!(toStringTagSymbol in genFun)){genFun[toStringTagSymbol]="GeneratorFunction";}}genFun.prototype=Object.create(Gp);return genFun;};// Within the body of any async function, `await x` is transformed to
// `yield regeneratorRuntime.awrap(x)`, so that the runtime can test
// `hasOwn.call(value, "__await")` to determine if the yielded value is
// meant to be awaited.
runtime.awrap=function(arg){return {__await:arg};};function AsyncIterator(generator){function invoke(method,arg,resolve,reject){var record=tryCatch(generator[method],generator,arg);if(record.type==="throw"){reject(record.arg);}else{var result=record.arg;var value=result.value;if(value&&typeof value==="object"&&hasOwn.call(value,"__await")){return Promise.resolve(value.__await).then(function(value){invoke("next",value,resolve,reject);},function(err){invoke("throw",err,resolve,reject);});}return Promise.resolve(value).then(function(unwrapped){// When a yielded Promise is resolved, its final value becomes
// the .value of the Promise<{value,done}> result for the
// current iteration. If the Promise is rejected, however, the
// result for this iteration will be rejected with the same
// reason. Note that rejections of yielded Promises are not
// thrown back into the generator function, as is the case
// when an awaited Promise is rejected. This difference in
// behavior between yield and await is important, because it
// allows the consumer to decide what to do with the yielded
// rejection (swallow it and continue, manually .throw it back
// into the generator, abandon iteration, whatever). With
// await, by contrast, there is no opportunity to examine the
// rejection reason outside the generator function, so the
// only option is to throw it from the await expression, and
// let the generator function handle the exception.
result.value=unwrapped;resolve(result);},reject);}}var previousPromise;function enqueue(method,arg){function callInvokeWithMethodAndArg(){return new Promise(function(resolve,reject){invoke(method,arg,resolve,reject);});}return previousPromise=// If enqueue has been called before, then we want to wait until
// all previous Promises have been resolved before calling invoke,
// so that results are always delivered in the correct order. If
// enqueue has not been called before, then it is important to
// call invoke immediately, without waiting on a callback to fire,
// so that the async generator function has the opportunity to do
// any necessary setup in a predictable way. This predictability
// is why the Promise constructor synchronously invokes its
// executor callback, and why async functions synchronously
// execute code before the first await. Since we implement simple
// async functions in terms of async generators, it is especially
// important to get this right, even though it requires care.
previousPromise?previousPromise.then(callInvokeWithMethodAndArg,// Avoid propagating failures to Promises returned by later
// invocations of the iterator.
callInvokeWithMethodAndArg):callInvokeWithMethodAndArg();}// Define the unified helper method that is used to implement .next,
// .throw, and .return (see defineIteratorMethods).
this._invoke=enqueue;}defineIteratorMethods(AsyncIterator.prototype);AsyncIterator.prototype[asyncIteratorSymbol]=function(){return this;};runtime.AsyncIterator=AsyncIterator;// Note that simple async functions are implemented on top of
// AsyncIterator objects; they just return a Promise for the value of
// the final result produced by the iterator.
runtime.async=function(innerFn,outerFn,self,tryLocsList){var iter=new AsyncIterator(wrap(innerFn,outerFn,self,tryLocsList));return runtime.isGeneratorFunction(outerFn)?iter// If outerFn is a generator, return the full iterator.
:iter.next().then(function(result){return result.done?result.value:iter.next();});};function makeInvokeMethod(innerFn,self,context){var state=GenStateSuspendedStart;return function invoke(method,arg){if(state===GenStateExecuting){throw new Error("Generator is already running");}if(state===GenStateCompleted){if(method==="throw"){throw arg;}// Be forgiving, per 25.3.3.3.3 of the spec:
// https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume
return doneResult();}context.method=method;context.arg=arg;while(true){var delegate=context.delegate;if(delegate){var delegateResult=maybeInvokeDelegate(delegate,context);if(delegateResult){if(delegateResult===ContinueSentinel)continue;return delegateResult;}}if(context.method==="next"){// Setting context._sent for legacy support of Babel's
// function.sent implementation.
context.sent=context._sent=context.arg;}else if(context.method==="throw"){if(state===GenStateSuspendedStart){state=GenStateCompleted;throw context.arg;}context.dispatchException(context.arg);}else if(context.method==="return"){context.abrupt("return",context.arg);}state=GenStateExecuting;var record=tryCatch(innerFn,self,context);if(record.type==="normal"){// If an exception is thrown from innerFn, we leave state ===
// GenStateExecuting and loop back for another invocation.
state=context.done?GenStateCompleted:GenStateSuspendedYield;if(record.arg===ContinueSentinel){continue;}return {value:record.arg,done:context.done};}else if(record.type==="throw"){state=GenStateCompleted;// Dispatch the exception by looping back around to the
// context.dispatchException(context.arg) call above.
context.method="throw";context.arg=record.arg;}}};}// Call delegate.iterator[context.method](context.arg) and handle the
// result, either by returning a { value, done } result from the
// delegate iterator, or by modifying context.method and context.arg,
// setting context.delegate to null, and returning the ContinueSentinel.
function maybeInvokeDelegate(delegate,context){var method=delegate.iterator[context.method];if(method===undefined){// A .throw or .return when the delegate iterator has no .throw
// method always terminates the yield* loop.
context.delegate=null;if(context.method==="throw"){if(delegate.iterator.return){// If the delegate iterator has a return method, give it a
// chance to clean up.
context.method="return";context.arg=undefined;maybeInvokeDelegate(delegate,context);if(context.method==="throw"){// If maybeInvokeDelegate(context) changed context.method from
// "return" to "throw", let that override the TypeError below.
return ContinueSentinel;}}context.method="throw";context.arg=new TypeError("The iterator does not provide a 'throw' method");}return ContinueSentinel;}var record=tryCatch(method,delegate.iterator,context.arg);if(record.type==="throw"){context.method="throw";context.arg=record.arg;context.delegate=null;return ContinueSentinel;}var info=record.arg;if(!info){context.method="throw";context.arg=new TypeError("iterator result is not an object");context.delegate=null;return ContinueSentinel;}if(info.done){// Assign the result of the finished delegate to the temporary
// variable specified by delegate.resultName (see delegateYield).
context[delegate.resultName]=info.value;// Resume execution at the desired location (see delegateYield).
context.next=delegate.nextLoc;// If context.method was "throw" but the delegate handled the
// exception, let the outer generator proceed normally. If
// context.method was "next", forget context.arg since it has been
// "consumed" by the delegate iterator. If context.method was
// "return", allow the original .return call to continue in the
// outer generator.
if(context.method!=="return"){context.method="next";context.arg=undefined;}}else{// Re-yield the result returned by the delegate method.
return info;}// The delegate iterator is finished, so forget it and continue with
// the outer generator.
context.delegate=null;return ContinueSentinel;}// Define Generator.prototype.{next,throw,return} in terms of the
// unified ._invoke helper method.
defineIteratorMethods(Gp);Gp[toStringTagSymbol]="Generator";// A Generator should always return itself as the iterator object when the
// @@iterator function is called on it. Some browsers' implementations of the
// iterator prototype chain incorrectly implement this, causing the Generator
// object to not be returned from this call. This ensures that doesn't happen.
// See https://github.com/facebook/regenerator/issues/274 for more details.
Gp[iteratorSymbol]=function(){return this;};Gp.toString=function(){return "[object Generator]";};function pushTryEntry(locs){var entry={tryLoc:locs[0]};if(1 in locs){entry.catchLoc=locs[1];}if(2 in locs){entry.finallyLoc=locs[2];entry.afterLoc=locs[3];}this.tryEntries.push(entry);}function resetTryEntry(entry){var record=entry.completion||{};record.type="normal";delete record.arg;entry.completion=record;}function Context(tryLocsList){// The root entry object (effectively a try statement without a catch
// or a finally block) gives us a place to store values thrown from
// locations where there is no enclosing try statement.
this.tryEntries=[{tryLoc:"root"}];tryLocsList.forEach(pushTryEntry,this);this.reset(true);}runtime.keys=function(object){var keys=[];for(var key in object){keys.push(key);}keys.reverse();// Rather than returning an object with a next method, we keep
// things simple and return the next function itself.
return function next(){while(keys.length){var key=keys.pop();if(key in object){next.value=key;next.done=false;return next;}}// To avoid creating an additional object, we just hang the .value
// and .done properties off the next function object itself. This
// also ensures that the minifier will not anonymize the function.
next.done=true;return next;};};function values(iterable){if(iterable){var iteratorMethod=iterable[iteratorSymbol];if(iteratorMethod){return iteratorMethod.call(iterable);}if(typeof iterable.next==="function"){return iterable;}if(!isNaN(iterable.length)){var i=-1,next=function next(){while(++i<iterable.length){if(hasOwn.call(iterable,i)){next.value=iterable[i];next.done=false;return next;}}next.value=undefined;next.done=true;return next;};return next.next=next;}}// Return an iterator with no values.
return {next:doneResult};}runtime.values=values;function doneResult(){return {value:undefined,done:true};}Context.prototype={constructor:Context,reset:function(skipTempReset){this.prev=0;this.next=0;// Resetting context._sent for legacy support of Babel's
// function.sent implementation.
this.sent=this._sent=undefined;this.done=false;this.delegate=null;this.method="next";this.arg=undefined;this.tryEntries.forEach(resetTryEntry);if(!skipTempReset){for(var name in this){// Not sure about the optimal order of these conditions:
if(name.charAt(0)==="t"&&hasOwn.call(this,name)&&!isNaN(+name.slice(1))){this[name]=undefined;}}}},stop:function(){this.done=true;var rootEntry=this.tryEntries[0];var rootRecord=rootEntry.completion;if(rootRecord.type==="throw"){throw rootRecord.arg;}return this.rval;},dispatchException:function(exception){if(this.done){throw exception;}var context=this;function handle(loc,caught){record.type="throw";record.arg=exception;context.next=loc;if(caught){// If the dispatched exception was caught by a catch block,
// then let that catch block handle the exception normally.
context.method="next";context.arg=undefined;}return !!caught;}for(var i=this.tryEntries.length-1;i>=0;--i){var entry=this.tryEntries[i];var record=entry.completion;if(entry.tryLoc==="root"){// Exception thrown outside of any try block that could handle
// it, so set the completion value of the entire function to
// throw the exception.
return handle("end");}if(entry.tryLoc<=this.prev){var hasCatch=hasOwn.call(entry,"catchLoc");var hasFinally=hasOwn.call(entry,"finallyLoc");if(hasCatch&&hasFinally){if(this.prev<entry.catchLoc){return handle(entry.catchLoc,true);}else if(this.prev<entry.finallyLoc){return handle(entry.finallyLoc);}}else if(hasCatch){if(this.prev<entry.catchLoc){return handle(entry.catchLoc,true);}}else if(hasFinally){if(this.prev<entry.finallyLoc){return handle(entry.finallyLoc);}}else{throw new Error("try statement without catch or finally");}}}},abrupt:function(type,arg){for(var i=this.tryEntries.length-1;i>=0;--i){var entry=this.tryEntries[i];if(entry.tryLoc<=this.prev&&hasOwn.call(entry,"finallyLoc")&&this.prev<entry.finallyLoc){var finallyEntry=entry;break;}}if(finallyEntry&&(type==="break"||type==="continue")&&finallyEntry.tryLoc<=arg&&arg<=finallyEntry.finallyLoc){// Ignore the finally entry if control is not jumping to a
// location outside the try/catch block.
finallyEntry=null;}var record=finallyEntry?finallyEntry.completion:{};record.type=type;record.arg=arg;if(finallyEntry){this.method="next";this.next=finallyEntry.finallyLoc;return ContinueSentinel;}return this.complete(record);},complete:function(record,afterLoc){if(record.type==="throw"){throw record.arg;}if(record.type==="break"||record.type==="continue"){this.next=record.arg;}else if(record.type==="return"){this.rval=this.arg=record.arg;this.method="return";this.next="end";}else if(record.type==="normal"&&afterLoc){this.next=afterLoc;}return ContinueSentinel;},finish:function(finallyLoc){for(var i=this.tryEntries.length-1;i>=0;--i){var entry=this.tryEntries[i];if(entry.finallyLoc===finallyLoc){this.complete(entry.completion,entry.afterLoc);resetTryEntry(entry);return ContinueSentinel;}}},"catch":function(tryLoc){for(var i=this.tryEntries.length-1;i>=0;--i){var entry=this.tryEntries[i];if(entry.tryLoc===tryLoc){var record=entry.completion;if(record.type==="throw"){var thrown=record.arg;resetTryEntry(entry);}return thrown;}}// The context.catch method must only be called with a location
// argument that corresponds to a known catch block.
throw new Error("illegal catch attempt");},delegateYield:function(iterable,resultName,nextLoc){this.delegate={iterator:values(iterable),resultName:resultName,nextLoc:nextLoc};if(this.method==="next"){// Deliberately forget the last sent value so that we don't
// accidentally pass it on to the delegate.
this.arg=undefined;}return ContinueSentinel;}};}(// In sloppy mode, unbound `this` refers to the global object, fallback to
// Function constructor if we're in global strict mode. That is sadly a form
// of indirect eval which violates Content Security Policy.
function(){return this;}()||Function("return this")());});/**
* Copyright (c) 2014-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/ // This method of obtaining a reference to the global object needs to be
// kept identical to the way it is obtained in runtime.js
var g=function(){return this;}()||Function("return this")();// Use `getOwnPropertyNames` because not all browsers support calling
// `hasOwnProperty` on the global `self` object in a worker. See #183.
var hadRuntime=g.regeneratorRuntime&&Object.getOwnPropertyNames(g).indexOf("regeneratorRuntime")>=0;// Save the old regeneratorRuntime in case it needs to be restored later.
var oldRuntime=hadRuntime&&g.regeneratorRuntime;// Force reevalutation of runtime.js.
g.regeneratorRuntime=undefined;var runtimeModule=runtime;if(hadRuntime){// Restore the original runtime.
g.regeneratorRuntime=oldRuntime;}else{// Remove the global property added by runtime.js.
try{delete g.regeneratorRuntime;}catch(e){g.regeneratorRuntime=undefined;}}var regenerator=runtimeModule;// 7.1.4 ToInteger
var ceil=Math.ceil;var floor=Math.floor;var _toInteger=function(it){return isNaN(it=+it)?0:(it>0?floor:ceil)(it);};// 7.2.1 RequireObjectCoercible(argument)
var _defined=function(it){if(it==undefined)throw TypeError("Can't call method on "+it);return it;};// true -> String#at
// false -> String#codePointAt
var _stringAt=function(TO_STRING){return function(that,pos){var s=String(_defined(that));var i=_toInteger(pos);var l=s.length;var a,b;if(i<0||i>=l)return TO_STRING?'':undefined;a=s.charCodeAt(i);return a<0xd800||a>0xdbff||i+1===l||(b=s.charCodeAt(i+1))<0xdc00||b>0xdfff?TO_STRING?s.charAt(i):a:TO_STRING?s.slice(i,i+2):(a-0xd800<<10)+(b-0xdc00)+0x10000;};};var _library=true;var _global=createCommonjsModule(function(module){// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028
var global=module.exports=typeof window!='undefined'&&window.Math==Math?window:typeof self!='undefined'&&self.Math==Math?self// eslint-disable-next-line no-new-func
:Function('return this')();if(typeof __g=='number')__g=global;// eslint-disable-line no-undef
});var _core=createCommonjsModule(function(module){var core=module.exports={version:'2.5.6'};if(typeof __e=='number')__e=core;// eslint-disable-line no-undef
});var _core_1=_core.version;var _aFunction=function(it){if(typeof it!='function')throw TypeError(it+' is not a function!');return it;};// optional / simple context binding
var _ctx=function(fn,that,length){_aFunction(fn);if(that===undefined)return fn;switch(length){case 1:return function(a){return fn.call(that,a);};case 2:return function(a,b){return fn.call(that,a,b);};case 3:return function(a,b,c){return fn.call(that,a,b,c);};}return function()/* ...args */{return fn.apply(that,arguments);};};var _isObject=function(it){return typeof it==='object'?it!==null:typeof it==='function';};var _anObject=function(it){if(!_isObject(it))throw TypeError(it+' is not an object!');return it;};var _fails=function(exec){try{return !!exec();}catch(e){return true;}};// Thank's IE8 for his funny defineProperty
var _descriptors=!_fails(function(){return Object.defineProperty({},'a',{get:function(){return 7;}}).a!=7;});var document$1=_global.document;// typeof document.createElement is 'object' in old IE
var is=_isObject(document$1)&&_isObject(document$1.createElement);var _domCreate=function(it){return is?document$1.createElement(it):{};};var _ie8DomDefine=!_descriptors&&!_fails(function(){return Object.defineProperty(_domCreate('div'),'a',{get:function(){return 7;}}).a!=7;});// 7.1.1 ToPrimitive(input [, PreferredType])
// instead of the ES6 spec version, we didn't implement @@toPrimitive case
// and the second argument - flag - preferred type is a string
var _toPrimitive=function(it,S){if(!_isObject(it))return it;var fn,val;if(S&&typeof(fn=it.toString)=='function'&&!_isObject(val=fn.call(it)))return val;if(typeof(fn=it.valueOf)=='function'&&!_isObject(val=fn.call(it)))return val;if(!S&&typeof(fn=it.toString)=='function'&&!_isObject(val=fn.call(it)))return val;throw TypeError("Can't convert object to primitive value");};var dP=Object.defineProperty;var f=_descriptors?Object.defineProperty:function defineProperty(O,P,Attributes){_anObject(O);P=_toPrimitive(P,true);_anObject(Attributes);if(_ie8DomDefine)try{return dP(O,P,Attributes);}catch(e){/* empty */}if('get'in Attributes||'set'in Attributes)throw TypeError('Accessors not supported!');if('value'in Attributes)O[P]=Attributes.value;return O;};var _objectDp={f:f};var _propertyDesc=function(bitmap,value){return {enumerable:!(bitmap&1),configurable:!(bitmap&2),writable:!(bitmap&4),value:value};};var _hide=_descriptors?function(object,key,value){return _objectDp.f(object,key,_propertyDesc(1,value));}:function(object,key,value){object[key]=value;return object;};var hasOwnProperty={}.hasOwnProperty;var _has=function(it,key){return hasOwnProperty.call(it,key);};var PROTOTYPE='prototype';var $export=function(type,name,source){var IS_FORCED=type&$export.F;var IS_GLOBAL=type&$export.G;var IS_STATIC=type&$export.S;var IS_PROTO=type&$export.P;var IS_BIND=type&$export.B;var IS_WRAP=type&$export.W;var exports=IS_GLOBAL?_core:_core[name]||(_core[name]={});var expProto=exports[PROTOTYPE];var target=IS_GLOBAL?_global:IS_STATIC?_global[name]:(_global[name]||{})[PROTOTYPE];var key,own,out;if(IS_GLOBAL)source=name;for(key in source){// contains in native
own=!IS_FORCED&&target&&target[key]!==undefined;if(own&&_has(exports,key))continue;// export native or passed
out=own?target[key]:source[key];// prevent global pollution for namespaces
exports[key]=IS_GLOBAL&&typeof target[key]!='function'?source[key]// bind timers to global for call from export context
:IS_BIND&&own?_ctx(out,_global)// wrap global constructors for prevent change them in library
:IS_WRAP&&target[key]==out?function(C){var F=function(a,b,c){if(this instanceof C){switch(arguments.length){case 0:return new C();case 1:return new C(a);case 2:return new C(a,b);}return new C(a,b,c);}return C.apply(this,arguments);};F[PROTOTYPE]=C[PROTOTYPE];return F;// make static versions for prototype methods
}(out):IS_PROTO&&typeof out=='function'?_ctx(Function.call,out):out;// export proto methods to core.%CONSTRUCTOR%.methods.%NAME%
if(IS_PROTO){(exports.virtual||(exports.virtual={}))[key]=out;// export proto methods to core.%CONSTRUCTOR%.prototype.%NAME%
if(type&$export.R&&expProto&&!expProto[key])_hide(expProto,key,out);}}};// type bitmap
$export.F=1;// forced
$export.G=2;// global
$export.S=4;// static
$export.P=8;// proto
$export.B=16;// bind
$export.W=32;// wrap
$export.U=64;// safe
$export.R=128;// real proto method for `library`
var _export=$export;var _redefine=_hide;var _iterators={};var toString={}.toString;var _cof=function(it){return toString.call(it).slice(8,-1);};// fallback for non-array-like ES3 and non-enumerable old V8 strings
// eslint-disable-next-line no-prototype-builtins
var _iobject=Object('z').propertyIsEnumerable(0)?Object:function(it){return _cof(it)=='String'?it.split(''):Object(it);};// to indexed object, toObject with fallback for non-array-like ES3 strings
var _toIobject=function(it){return _iobject(_defined(it));};// 7.1.15 ToLength
var min=Math.min;var _toLength=function(it){return it>0?min(_toInteger(it),0x1fffffffffffff):0;// pow(2, 53) - 1 == 9007199254740991
};var max=Math.max;var min$1=Math.min;var _toAbsoluteIndex=function(index,length){index=_toInteger(index);return index<0?max(index+length,0):min$1(index,length);};// false -> Array#indexOf
// true -> Array#includes
var _arrayIncludes=function(IS_INCLUDES){return function($this,el,fromIndex){var O=_toIobject($this);var length=_toLength(O.length);var index=_toAbsoluteIndex(fromIndex,length);var value;// Array#includes uses SameValueZero equality algorithm
// eslint-disable-next-line no-self-compare
if(IS_INCLUDES&&el!=el)while(length>index){value=O[index++];// eslint-disable-next-line no-self-compare
if(value!=value)return true;// Array#indexOf ignores holes, Array#includes - not
}else for(;length>index;index++)if(IS_INCLUDES||index in O){if(O[index]===el)return IS_INCLUDES||index||0;}return !IS_INCLUDES&&-1;};};var _shared=createCommonjsModule(function(module){var SHARED='__core-js_shared__';var store=_global[SHARED]||(_global[SHARED]={});(module.exports=function(key,value){return store[key]||(store[key]=value!==undefined?value:{});})('versions',[]).push({version:_core.version,mode:'pure',copyright:'© 2018 Denis Pushkarev (zloirock.ru)'});});var id$1=0;var px=Math.random();var _uid=function(key){return 'Symbol('.concat(key===undefined?'':key,')_',(++id$1+px).toString(36));};var shared=_shared('keys');var _sharedKey=function(key){return shared[key]||(shared[key]=_uid(key));};var arrayIndexOf=_arrayIncludes(false);var IE_PROTO=_sharedKey('IE_PROTO');var _objectKeysInternal=function(object,names){var O=_toIobject(object);var i=0;var result=[];var key;for(key in O)if(key!=IE_PROTO)_has(O,key)&&result.push(key);// Don't enum bug & hidden keys
while(names.length>i)if(_has(O,key=names[i++])){~arrayIndexOf(result,key)||result.push(key);}return result;};// IE 8- don't enum bug keys
var _enumBugKeys='constructor,hasOwnProperty,isPrototypeOf,propertyIsEnumerable,toLocaleString,toString,valueOf'.split(',');// 19.1.2.14 / 15.2.3.14 Object.keys(O)
var _objectKeys=Object.keys||function keys(O){return _objectKeysInternal(O,_enumBugKeys);};var _objectDps=_descriptors?Object.defineProperties:function defineProperties(O,Properties){_anObject(O);var keys=_objectKeys(Properties);var length=keys.length;var i=0;var P;while(length>i)_objectDp.f(O,P=keys[i++],Properties[P]);return O;};var document$2=_global.document;var _html=document$2&&document$2.documentElement;// 19.1.2.2 / 15.2.3.5 Object.create(O [, Properties])
var IE_PROTO$1=_sharedKey('IE_PROTO');var Empty=function(){/* empty */};var PROTOTYPE$1='prototype';// Create object with fake `null` prototype: use iframe Object with cleared prototype
var createDict=function(){// Thrash, waste and sodomy: IE GC bug
var iframe=_domCreate('iframe');var i=_enumBugKeys.length;var lt='<';var gt='>';var iframeDocument;iframe.style.display='none';_html.appendChild(iframe);iframe.src='javascript:';// eslint-disable-line no-script-url
// createDict = iframe.contentWindow.Object;
// html.removeChild(iframe);
iframeDocument=iframe.contentWindow.document;iframeDocument.open();iframeDocument.write(lt+'script'+gt+'document.F=Object'+lt+'/script'+gt);iframeDocument.close();createDict=iframeDocument.F;while(i--)delete createDict[PROTOTYPE$1][_enumBugKeys[i]];return createDict();};var _objectCreate=Object.create||function create(O,Properties){var result;if(O!==null){Empty[PROTOTYPE$1]=_anObject(O);result=new Empty();Empty[PROTOTYPE$1]=null;// add "__proto__" for Object.getPrototypeOf polyfill
result[IE_PROTO$1]=O;}else result=createDict();return Properties===undefined?result:_objectDps(result,Properties);};var _wks=createCommonjsModule(function(module){var store=_shared('wks');var Symbol=_global.Symbol;var USE_SYMBOL=typeof Symbol=='function';var $exports=module.exports=function(name){return store[name]||(store[name]=USE_SYMBOL&&Symbol[name]||(USE_SYMBOL?Symbol:_uid)('Symbol.'+name));};$exports.store=store;});var def=_objectDp.f;var TAG=_wks('toStringTag');var _setToStringTag=function(it,tag,stat){if(it&&!_has(it=stat?it:it.prototype,TAG))def(it,TAG,{configurable:true,value:tag});};var IteratorPrototype={};// 25.1.2.1.1 %IteratorPrototype%[@@iterator]()
_hide(IteratorPrototype,_wks('iterator'),function(){return this;});var _iterCreate=function(Constructor,NAME,next){Constructor.prototype=_objectCreate(IteratorPrototype,{next:_propertyDesc(1,next)});_setToStringTag(Constructor,NAME+' Iterator');};// 7.1.13 ToObject(argument)
var _toObject=function(it){return Object(_defined(it));};// 19.1.2.9 / 15.2.3.2 Object.getPrototypeOf(O)
var IE_PROTO$2=_sharedKey('IE_PROTO');var ObjectProto=Object.prototype;var _objectGpo=Object.getPrototypeOf||function(O){O=_toObject(O);if(_has(O,IE_PROTO$2))return O[IE_PROTO$2];if(typeof O.constructor=='function'&&O instanceof O.constructor){return O.constructor.prototype;}return O instanceof Object?ObjectProto:null;};var ITERATOR=_wks('iterator');var BUGGY=!([].keys&&'next'in[].keys());// Safari has buggy iterators w/o `next`
var FF_ITERATOR='@@iterator';var KEYS='keys';var VALUES='values';var returnThis=function(){return this;};var _iterDefine=function(Base,NAME,Constructor,next,DEFAULT,IS_SET,FORCED){_iterCreate(Constructor,NAME,next);var getMethod=function(kind){if(!BUGGY&&kind in proto)return proto[kind];switch(kind){case KEYS:return function keys(){return new Constructor(this,kind);};case VALUES:return function values(){return new Constructor(this,kind);};}return function entries(){return new Constructor(this,kind);};};var TAG=NAME+' Iterator';var DEF_VALUES=DEFAULT==VALUES;var VALUES_BUG=false;var proto=Base.prototype;var $native=proto[ITERATOR]||proto[FF_ITERATOR]||DEFAULT&&proto[DEFAULT];var $default=$native||getMethod(DEFAULT);var $entries=DEFAULT?!DEF_VALUES?$default:getMethod('entries'):undefined;var $anyNative=NAME=='Array'?proto.entries||$native:$native;var methods,key,IteratorPrototype;// Fix native
if($anyNative){IteratorPrototype=_objectGpo($anyNative.call(new Base()));if(IteratorPrototype!==Object.prototype&&IteratorPrototype.next){// Set @@toStringTag to native iterators
_setToStringTag(IteratorPrototype,TAG,true);// fix for some old engines
}}// fix Array#{values, @@iterator}.name in V8 / FF
if(DEF_VALUES&&$native&&$native.name!==VALUES){VALUES_BUG=true;$default=function values(){return $native.call(this);};}// Define iterator
if((FORCED)&&(BUGGY||VALUES_BUG||!proto[ITERATOR])){_hide(proto,ITERATOR,$default);}// Plug for library
_iterators[NAME]=$default;_iterators[TAG]=returnThis;if(DEFAULT){methods={values:DEF_VALUES?$default:getMethod(VALUES),keys:IS_SET?$default:getMethod(KEYS),entries:$entries};if(FORCED)for(key in methods){if(!(key in proto))_redefine(proto,key,methods[key]);}else _export(_export.P+_export.F*(BUGGY||VALUES_BUG),NAME,methods);}return methods;};var $at=_stringAt(true);// 21.1.3.27 String.prototype[@@iterator]()
_iterDefine(String,'String',function(iterated){this._t=String(iterated);// target
this._i=0;// next index
// 21.1.5.2.1 %StringIteratorPrototype%.next()
},function(){var O=this._t;var index=this._i;var point;if(index>=O.length)return {value:undefined,done:true};point=$at(O,index);this._i+=point.length;return {value:point,done:false};});var _iterStep=function(done,value){return {value:value,done:!!done};};// 22.1.3.4 Array.prototype.entries()
// 22.1.3.13 Array.prototype.keys()
// 22.1.3.29 Array.prototype.values()
// 22.1.3.30 Array.prototype[@@iterator]()
var es6_array_iterator=_iterDefine(Array,'Array',function(iterated,kind){this._t=_toIobject(iterated);// target
this._i=0;// next index
this._k=kind;// kind
// 22.1.5.2.1 %ArrayIteratorPrototype%.next()
},function(){var O=this._t;var kind=this._k;var index=this._i++;if(!O||index>=O.length){this._t=undefined;return _iterStep(1);}if(kind=='keys')return _iterStep(0,index);if(kind=='values')return _iterStep(0,O[index]);return _iterStep(0,[index,O[index]]);},'values');// argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)
_iterators.Arguments=_iterators.Array;var TO_STRING_TAG=_wks('toStringTag');var DOMIterables=('CSSRuleList,CSSStyleDeclaration,CSSValueList,ClientRectList,DOMRectList,DOMStringList,'+'DOMTokenList,DataTransferItemList,FileList,HTMLAllCollection,HTMLCollection,HTMLFormElement,HTMLSelectElement,'+'MediaList,MimeTypeArray,NamedNodeMap,NodeList,PaintRequestList,Plugin,PluginArray,SVGLengthList,SVGNumberList,'+'SVGPathSegList,SVGPointList,SVGStringList,SVGTransformList,SourceBufferList,StyleSheetList,TextTrackCueList,'+'TextTrackList,TouchList').split(',');for(var i=0;i<DOMIterables.length;i++){var NAME=DOMIterables[i];var Collection=_global[NAME];var proto=Collection&&Collection.prototype;if(proto&&!proto[TO_STRING_TAG])_hide(proto,TO_STRING_TAG,NAME);_iterators[NAME]=_iterators.Array;}// getting tag from 19.1.3.6 Object.prototype.toString()
var TAG$1=_wks('toStringTag');// ES3 wrong here
var ARG=_cof(function(){return arguments;}())=='Arguments';// fallback for IE11 Script Access Denied error
var tryGet=function(it,key){try{return it[key];}catch(e){/* empty */}};var _classof=function(it){var O,T,B;return it===undefined?'Undefined':it===null?'Null'// @@toStringTag case
:typeof(T=tryGet(O=Object(it),TAG$1))=='string'?T// builtinTag case
:ARG?_cof(O)// ES3 arguments fallback
:(B=_cof(O))=='Object'&&typeof O.callee=='function'?'Arguments':B;};var _anInstance=function(it,Constructor,name,forbiddenField){if(!(it instanceof Constructor)||forbiddenField!==undefined&&forbiddenField in it){throw TypeError(name+': incorrect invocation!');}return it;};// call something on iterator step with safe closing on error
var _iterCall=function(iterator,fn,value,entries){try{return entries?fn(_anObject(value)[0],value[1]):fn(value);// 7.4.6 IteratorClose(iterator, completion)
}catch(e){var ret=iterator['return'];if(ret!==undefined)_anObject(ret.call(iterator));throw e;}};// check on default Array iterator
var ITERATOR$1=_wks('iterator');var ArrayProto=Array.prototype;var _isArrayIter=function(it){return it!==undefined&&(_iterators.Array===it||ArrayProto[ITERATOR$1]===it);};var ITERATOR$2=_wks('iterator');var core_getIteratorMethod=_core.getIteratorMethod=function(it){if(it!=undefined)return it[ITERATOR$2]||it['@@iterator']||_iterators[_classof(it)];};var _forOf=createCommonjsModule(function(module){var BREAK={};var RETURN={};var exports=module.exports=function(iterable,entries,fn,that,ITERATOR){var iterFn=ITERATOR?function(){return iterable;}:core_getIteratorMethod(iterable);var f=_ctx(fn,that,entries?2:1);var index=0;var length,step,iterator,result;if(typeof iterFn!='function')throw TypeError(iterable+' is not iterable!');// fast case for arrays with default iterator
if(_isArrayIter(iterFn))for(length=_toLength(iterable.length);length>index;index++){result=entries?f(_anObject(step=iterable[index])[0],step[1]):f(iterable[index]);if(result===BREAK||result===RETURN)return result;}else for(iterator=iterFn.call(iterable);!(step=iterator.next()).done;){result=_iterCall(iterator,f,step.value,entries);if(result===BREAK||result===RETURN)return result;}};exports.BREAK=BREAK;exports.RETURN=RETURN;});// 7.3.20 SpeciesConstructor(O, defaultConstructor)
var SPECIES=_wks('species');var _speciesConstructor=function(O,D){var C=_anObject(O).constructor;var S;return C===undefined||(S=_anObject(C)[SPECIES])==undefined?D:_aFunction(S);};// fast apply, http://jsperf.lnkit.com/fast-apply/5
var _invoke=function(fn,args,that){var un=that===undefined;switch(args.length){case 0:return un?fn():fn.call(that);case 1:return un?fn(args[0]):fn.call(that,args[0]);case 2:return un?fn(args[0],args[1]):fn.call(that,args[0],args[1]);case 3:return un?fn(args[0],args[1],args[2]):fn.call(that,args[0],args[1],args[2]);case 4:return un?fn(args[0],args[1],args[2],args[3]):fn.call(that,args[0],args[1],args[2],args[3]);}return fn.apply(that,args);};var process=_global.process;var setTask=_global.setImmediate;var clearTask=_global.clearImmediate;var MessageChannel=_global.MessageChannel;var Dispatch=_global.Dispatch;var counter=0;var queue={};var ONREADYSTATECHANGE='onreadystatechange';var defer,channel,port;var run=function(){var id=+this;// eslint-disable-next-line no-prototype-builtins
if(queue.hasOwnProperty(id)){var fn=queue[id];delete queue[id];fn();}};var listener=function(event){run.call(event.data);};// Node.js 0.9+ & IE10+ has setImmediate, otherwise:
if(!setTask||!clearTask){setTask=function setImmediate(fn){var args=[];var i=1;while(arguments.length>i)args.push(arguments[i++]);queue[++counter]=function(){// eslint-disable-next-line no-new-func
_invoke(typeof fn=='function'?fn:Function(fn),args);};defer(counter);return counter;};clearTask=function clearImmediate(id){delete queue[id];};// Node.js 0.8-
if(_cof(process)=='process'){defer=function(id){process.nextTick(_ctx(run,id,1));};// Sphere (JS game engine) Dispatch API
}else if(Dispatch&&Dispatch.now){defer=function(id){Dispatch.now(_ctx(run,id,1));};// Browsers with MessageChannel, includes WebWorkers
}else if(MessageChannel){channel=new MessageChannel();port=channel.port2;channel.port1.onmessage=listener;defer=_ctx(port.postMessage,port,1);// Browsers with postMessage, skip WebWorkers
// IE8 has postMessage, but it's sync & typeof its postMessage is 'object'
}else if(_global.addEventListener&&typeof postMessage=='function'&&!_global.importScripts){defer=function(id){_global.postMessage(id+'','*');};_global.addEventListener('message',listener,false);// IE8-
}else if(ONREADYSTATECHANGE in _domCreate('script')){defer=function(id){_html.appendChild(_domCreate('script'))[ONREADYSTATECHANGE]=function(){_html.removeChild(this);run.call(id);};};// Rest old browsers
}else{defer=function(id){setTimeout(_ctx(run,id,1),0);};}}var _task={set:setTask,clear:clearTask};var macrotask=_task.set;var Observer=_global.MutationObserver||_global.WebKitMutationObserver;var process$1=_global.process;var Promise$1=_global.Promise;var isNode=_cof(process$1)=='process';var _microtask=function(){var head,last,notify;var flush=function(){var parent,fn;if(isNode&&(parent=process$1.domain))parent.exit();while(head){fn=head.fn;head=head.next;try{fn();}catch(e){if(head)notify();else last=undefined;throw e;}}last=undefined;if(parent)parent.enter();};// Node.js
if(isNode){notify=function(){process$1.nextTick(flush);};// browsers with MutationObserver, except iOS Safari - https://github.com/zloirock/core-js/issues/339
}else if(Observer&&!(_global.navigator&&_global.navigator.standalone)){var toggle=true;var node=document.createTextNode('');new Observer(flush).observe(node,{characterData:true});// eslint-disable-line no-new
notify=function(){node.data=toggle=!toggle;};// environments with maybe non-completely correct, but existent Promise
}else if(Promise$1&&Promise$1.resolve){// Promise.resolve without an argument throws an error in LG WebOS 2
var promise=Promise$1.resolve(undefined);notify=function(){promise.then(flush);};// for other environments - macrotask based on:
// - setImmediate
// - MessageChannel
// - window.postMessag
// - onreadystatechange
// - setTimeout
}else{notify=function(){// strange IE + webpack dev server bug - use .call(global)
macrotask.call(_global,flush);};}return function(fn){var task={fn:fn,next:undefined};if(last)last.next=task;if(!head){head=task;notify();}last=task;};};// 25.4.1.5 NewPromiseCapability(C)
function PromiseCapability(C){var resolve,reject;this.promise=new C(function($$resolve,$$reject){if(resolve!==undefined||reject!==undefined)throw TypeError('Bad Promise constructor');resolve=$$resolve;reject=$$reject;});this.resolve=_aFunction(resolve);this.reject=_aFunction(reject);}var f$1=function(C){return new PromiseCapability(C);};var _newPromiseCapability={f:f$1};var _perform=function(exec){try{return {e:false,v:exec()};}catch(e){return {e:true,v:e};}};var navigator=_global.navigator;var _userAgent=navigator&&navigator.userAgent||'';var _promiseResolve=function(C,x){_anObject(C);if(_isObject(x)&&x.constructor===C)return x;var promiseCapability=_newPromiseCapability.f(C);var resolve=promiseCapability.resolve;resolve(x);return promiseCapability.promise;};var _redefineAll=function(target,src,safe){for(var key in src){if(safe&&target[key])target[key]=src[key];else _hide(target,key,src[key]);}return target;};var SPECIES$1=_wks('species');var _setSpecies=function(KEY){var C=typeof _core[KEY]=='function'?_core[KEY]:_global[KEY];if(_descriptors&&C&&!C[SPECIES$1])_objectDp.f(C,SPECIES$1,{configurable:true,get:function(){return this;}});};var ITERATOR$3=_wks('iterator');var SAFE_CLOSING=false;try{var riter=[7][ITERATOR$3]();riter['return']=function(){SAFE_CLOSING=true;};}catch(e){/* empty */}var _iterDetect=function(exec,skipClosing){if(!skipClosing&&!SAFE_CLOSING)return false;var safe=false;try{var arr=[7];var iter=arr[ITERATOR$3]();iter.next=function(){return {done:safe=true};};arr[ITERATOR$3]=function(){return iter;};exec(arr);}catch(e){/* empty */}return safe;};var task=_task.set;var microtask=_microtask();var PROMISE='Promise';var TypeError$1=_global.TypeError;var process$2=_global.process;var versions=process$2&&process$2.versions;var v8=versions&&versions.v8||'';var $Promise=_global[PROMISE];var isNode$1=_classof(process$2)=='process';var empty=function(){/* empty */};var Internal,newGenericPromiseCapability,OwnPromiseCapability,Wrapper;var newPromiseCapability=newGenericPromiseCapability=_newPromiseCapability.f;var USE_NATIVE=!!function(){try{// correct subclassing with @@species support
var promise=$Promise.resolve(1);var FakePromise=(promise.constructor={})[_wks('species')]=function(exec){exec(empty,empty);};// unhandled rejections tracking support, NodeJS Promise without it fails @@species test
return (isNode$1||typeof PromiseRejectionEvent=='function')&&promise.then(empty)instanceof FakePromise// v8 6.6 (Node 10 and Chrome 66) have a bug with resolving custom thenables
// https://bugs.chromium.org/p/chromium/issues/detail?id=830565
// we can't detect it synchronously, so just check versions
&&v8.indexOf('6.6')!==0&&_userAgent.indexOf('Chrome/66')===-1;}catch(e){/* empty */}}();// helpers
var isThenable=function(it){var then;return _isObject(it)&&typeof(then=it.then)=='function'?then:false;};var notify=function(promise,isReject){if(promise._n)return;promise._n=true;var chain=promise._c;microtask(function(){var value=promise._v;var ok=promise._s==1;var i=0;var run=function(reaction){var handler=ok?reaction.ok:reaction.fail;var resolve=reaction.resolve;var reject=reaction.reject;var domain=reaction.domain;var result,then,exited;try{if(handler){if(!ok){if(promise._h==2)onHandleUnhandled(promise);promise._h=1;}if(handler===true)result=value;else{if(domain)domain.enter();result=handler(value);// may throw
if(domain){domain.exit();exited=true;}}if(result===reaction.promise){reject(TypeError$1('Promise-chain cycle'));}else if(then=isThenable(result)){then.call(result,resolve,reject);}else resolve(result);}else reject(value);}catch(e){if(domain&&!exited)domain.exit();reject(e);}};while(chain.length>i)run(chain[i++]);// variable length - can't use forEach
promise._c=[];promise._n=false;if(isReject&&!promise._h)onUnhandled(promise);});};var onUnhandled=function(promise){task.call(_global,function(){var value=promise._v;var unhandled=isUnhandled(promise);var result,handler,console;if(unhandled){result=_perform(function(){if(isNode$1){process$2.emit('unhandledRejection',value,promise);}else if(handler=_global.onunhandledrejection){handler({promise:promise,reason:value});}else if((console=_global.console)&&console.error){console.error('Unhandled promise rejection',value);}});// Browsers should not trigger `rejectionHandled` event if it was handled here, NodeJS - should
promise._h=isNode$1||isUnhandled(promise)?2:1;}promise._a=undefined;if(unhandled&&result.e)throw result.v;});};var isUnhandled=function(promise){return promise._h!==1&&(promise._a||promise._c).length===0;};var onHandleUnhandled=function(promise){task.call(_global,function(){var handler;if(isNode$1){process$2.emit('rejectionHandled',promise);}else if(handler=_global.onrejectionhandled){handler({promise:promise,reason:promise._v});}});};var $reject=function(value){var promise=this;if(promise._d)return;promise._d=true;promise=promise._w||promise;// unwrap
promise._v=value;promise._s=2;if(!promise._a)promise._a=promise._c.slice();notify(promise,true);};var $resolve=function(value){var promise=this;var then;if(promise._d)return;promise._d=true;promise=promise._w||promise;// unwrap
try{if(promise===value)throw TypeError$1("Promise can't be resolved itself");if(then=isThenable(value)){microtask(function(){var wrapper={_w:promise,_d:false};// wrap
try{then.call(value,_ctx($resolve,wrapper,1),_ctx($reject,wrapper,1));}catch(e){$reject.call(wrapper,e);}});}else{promise._v=value;promise._s=1;notify(promise,false);}}catch(e){$reject.call({_w:promise,_d:false},e);// wrap
}};// constructor polyfill
if(!USE_NATIVE){// 25.4.3.1 Promise(executor)
$Promise=function Promise(executor){_anInstance(this,$Promise,PROMISE,'_h');_aFunction(executor);Internal.call(this);try{executor(_ctx($resolve,this,1),_ctx($reject,this,1));}catch(err){$reject.call(this,err);}};// eslint-disable-next-line no-unused-vars
Internal=function Promise(executor){this._c=[];// <- awaiting reactions
this._a=undefined;// <- checked in isUnhandled reactions
this._s=0;// <- state
this._d=false;// <- done
this._v=undefined;// <- value
this._h=0;// <- rejection state, 0 - default, 1 - handled, 2 - unhandled
this._n=false;// <- notify
};Internal.prototype=_redefineAll($Promise.prototype,{// 25.4.5.3 Promise.prototype.then(onFulfilled, onRejected)
then:function then(onFulfilled,onRejected){var reaction=newPromiseCapability(_speciesConstructor(this,$Promise));reaction.ok=typeof onFulfilled=='function'?onFulfilled:true;reaction.fail=typeof onRejected=='function'&&onRejected;reaction.domain=isNode$1?process$2.domain:undefined;this._c.push(reaction);if(this._a)this._a.push(reaction);if(this._s)notify(this,false);return reaction.promise;},// 25.4.5.1 Promise.prototype.catch(onRejected)
'catch':function(onRejected){return this.then(undefined,onRejected);}});OwnPromiseCapability=function(){var promise=new Internal();this.promise=promise;this.resolve=_ctx($resolve,promise,1);this.reject=_ctx($reject,promise,1);};_newPromiseCapability.f=newPromiseCapability=function(C){return C===$Promise||C===Wrapper?new OwnPromiseCapability(C):newGenericPromiseCapability(C);};}_export(_export.G+_export.W+_export.F*!USE_NATIVE,{Promise:$Promise});_setToStringTag($Promise,PROMISE);_setSpecies(PROMISE);Wrapper=_core[PROMISE];// statics
_export(_export.S+_export.F*!USE_NATIVE,PROMISE,{// 25.4.4.5 Promise.reject(r)
reject:function reject(r){var capability=newPromiseCapability(this);var $$reject=capability.reject;$$reject(r);return capability.promise;}});_export(_export.S+_export.F*(_library),PROMISE,{// 25.4.4.6 Promise.resolve(x)
resolve:function resolve(x){return _promiseResolve(this===Wrapper?$Promise:this,x);}});_export(_export.S+_export.F*!(USE_NATIVE&&_iterDetect(function(iter){$Promise.all(iter)['catch'](empty);})),PROMISE,{// 25.4.4.1 Promise.all(iterable)
all:function all(iterable){var C=this;var capability=newPromiseCapability(C);var resolve=capability.resolve;var reject=capability.reject;var result=_perform(function(){var values=[];var index=0;var remaining=1;_forOf(iterable,false,function(promise){var $index=index++;var alreadyCalled=false;values.push(undefined);remaining++;C.resolve(promise).then(function(value){if(alreadyCalled)return;alreadyCalled=true;values[$index]=value;--remaining||resolve(values);},reject);});--remaining||resolve(values);});if(result.e)reject(result.v);return capability.promise;},// 25.4.4.4 Promise.race(iterable)
race:function race(iterable){var C=this;var capability=newPromiseCapability(C);var reject=capability.reject;var result=_perform(function(){_forOf(iterable,false,function(promise){C.resolve(promise).then(capability.resolve,reject);});});if(result.e)reject(result.v);return capability.promise;}});_export(_export.P+_export.R,'Promise',{'finally':function(onFinally){var C=_speciesConstructor(this,_core.Promise||_global.Promise);var isFunction=typeof onFinally=='function';return this.then(isFunction?function(x){return _promiseResolve(C,onFinally()).then(function(){return x;});}:onFinally,isFunction?function(e){return _promiseResolve(C,onFinally()).then(function(){throw e;});}:onFinally);}});// https://github.com/tc39/proposal-promise-try
_export(_export.S,'Promise',{'try':function(callbackfn){var promiseCapability=_newPromiseCapability.f(this);var result=_perform(callbackfn);(result.e?promiseCapability.reject:promiseCapability.resolve)(result.v);return promiseCapability.promise;}});var promise=_core.Promise;var promise$1=promise;function _asyncToGenerator$1(fn){return function(){var self=this,args=arguments;return new promise$1(function(resolve,reject){var gen=fn.apply(self,args);function step(key,arg){try{var info=gen[key](arg);var value=info.value;}catch(error){reject(error);return;}if(info.done){resolve(value);}else{promise$1.resolve(value).then(_next,_throw);}}function _next(value){step("next",value);}function _throw(err){step("throw",err);}_next();});};}var asyncToGenerator=_asyncToGenerator$1;var f$2={}.propertyIsEnumerable;var _objectPie={f:f$2};var gOPD=Object.getOwnPropertyDescriptor;var f$3=_descriptors?gOPD:function getOwnPropertyDescriptor(O,P){O=_toIobject(O);P=_toPrimitive(P,true);if(_ie8DomDefine)try{return gOPD(O,P);}catch(e){/* empty */}if(_has(O,P))return _propertyDesc(!_objectPie.f.call(O,P),O[P]);};var _objectGopd={f:f$3};// most Object methods by ES6 should accept primitives
var _objectSap=function(KEY,exec){var fn=(_core.Object||{})[KEY]||Object[KEY];var exp={};exp[KEY]=exec(fn);_export(_export.S+_export.F*_fails(function(){fn(1);}),'Object',exp);};// 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)
var $getOwnPropertyDescriptor=_objectGopd.f;_objectSap('getOwnPropertyDescriptor',function(){return function getOwnPropertyDescriptor(it,key){return $getOwnPropertyDescriptor(_toIobject(it),key);};});var $Object=_core.Object;var getOwnPropertyDescriptor=function getOwnPropertyDescriptor(it,key){return $Object.getOwnPropertyDescriptor(it,key);};var getOwnPropertyDescriptor$1=getOwnPropertyDescriptor;var _meta=createCommonjsModule(function(module){var META=_uid('meta');var setDesc=_objectDp.f;var id=0;var isExtensible=Object.isExtensible||function(){return true;};var FREEZE=!_fails(function(){return isExtensible(Object.preventExtensions({}));});var setMeta=function(it){setDesc(it,META,{value:{i:'O'+ ++id,// object ID
w:{}// weak collections IDs
}});};var fastKey=function(it,create){// return primitive with prefix
if(!_isObject(it))return typeof it=='symbol'?it:(typeof it=='string'?'S':'P')+it;if(!_has(it,META)){// can't set metadata to uncaught frozen object
if(!isExtensible(it))return 'F';// not necessary to add metadata
if(!create)return 'E';// add missing metadata
setMeta(it);// return object ID
}return it[META].i;};var getWeak=function(it,create){if(!_has(it,META)){// can't set metadata to uncaught frozen object
if(!isExtensible(it))return true;// not necessary to add metadata
if(!create)return false;// add missing metadata
setMeta(it);// return hash weak collections IDs
}return it[META].w;};// add metadata on freeze-family methods calling
var onFreeze=function(it){if(FREEZE&&meta.NEED&&isExtensible(it)&&!_has(it,META))setMeta(it);return it;};var meta=module.exports={KEY:META,NEED:false,fastKey:fastKey,getWeak:getWeak,onFreeze:onFreeze};});var _meta_1=_meta.KEY;var _meta_2=_meta.NEED;var _meta_3=_meta.fastKey;var _meta_4=_meta.getWeak;var _meta_5=_meta.onFreeze;var f$4=_wks;var _wksExt={f:f$4};var defineProperty=_objectDp.f;var _wksDefine=function(name){var $Symbol=_core.Symbol||(_core.Symbol={});if(name.charAt(0)!='_'&&!(name in $Symbol))defineProperty($Symbol,name,{value:_wksExt.f(name)});};var f$5=Object.getOwnPropertySymbols;var _objectGops={f:f$5};// all enumerable object keys, includes symbols
var _enumKeys=function(it){var result=_objectKeys(it);var getSymbols=_objectGops.f;if(getSymbols){var symbols=getSymbols(it);var isEnum=_objectPie.f;var i=0;var key;while(symbols.length>i)if(isEnum.call(it,key=symbols[i++]))result.push(key);}return result;};// 7.2.2 IsArray(argument)
var _isArray=Array.isArray||function isArray(arg){return _cof(arg)=='Array';};// 19.1.2.7 / 15.2.3.4 Object.getOwnPropertyNames(O)
var hiddenKeys=_enumBugKeys.concat('length','prototype');var f$6=Object.getOwnPropertyNames||function getOwnPropertyNames(O){return _objectKeysInternal(O,hiddenKeys);};var _objectGopn={f:f$6};// fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window
var gOPN=_objectGopn.f;var toString$1={}.toString;var windowNames=typeof window=='object'&&window&&Object.getOwnPropertyNames?Object.getOwnPropertyNames(window):[];var getWindowNames=function(it){try{return gOPN(it);}catch(e){return windowNames.slice();}};var f$7=function getOwnPropertyNames(it){return windowNames&&toString$1.call(it)=='[object Window]'?getWindowNames(it):gOPN(_toIobject(it));};var _objectGopnExt={f:f$7};// ECMAScript 6 symbols shim
var META=_meta.KEY;var gOPD$1=_objectGopd.f;var dP$1=_objectDp.f;var gOPN$1=_objectGopnExt.f;var $Symbol=_global.Symbol;var $JSON=_global.JSON;var _stringify=$JSON&&$JSON.stringify;var PROTOTYPE$2='prototype';var HIDDEN=_wks('_hidden');var TO_PRIMITIVE=_wks('toPrimitive');var isEnum={}.propertyIsEnumerable;var SymbolRegistry=_shared('symbol-registry');var AllSymbols=_shared('symbols');var OPSymbols=_shared('op-symbols');var ObjectProto$1=Object[PROTOTYPE$2];var USE_NATIVE$1=typeof $Symbol=='function';var QObject=_global.QObject;// Don't use setters in Qt Script, https://github.com/zloirock/core-js/issues/173
var setter=!QObject||!QObject[PROTOTYPE$2]||!QObject[PROTOTYPE$2].findChild;// fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687
var setSymbolDesc=_descriptors&&_fails(function(){return _objectCreate(dP$1({},'a',{get:function(){return dP$1(this,'a',{value:7}).a;}})).a!=7;})?function(it,key,D){var protoDesc=gOPD$1(ObjectProto$1,key);if(protoDesc)delete ObjectProto$1[key];dP$1(it,key,D);if(protoDesc&&it!==ObjectProto$1)dP$1(ObjectProto$1,key,protoDesc);}:dP$1;var wrap=function(tag){var sym=AllSymbols[tag]=_objectCreate($Symbol[PROTOTYPE$2]);sym._k=tag;return sym;};var isSymbol=USE_NATIVE$1&&typeof $Symbol.iterator=='symbol'?function(it){return typeof it=='symbol';}:function(it){return it instanceof $Symbol;};var $defineProperty=function defineProperty(it,key,D){if(it===ObjectProto$1)$defineProperty(OPSymbols,key,D);_anObject(it);key=_toPrimitive(key,true);_anObject(D);if(_has(AllSymbols,key)){if(!D.enumerable){if(!_has(it,HIDDEN))dP$1(it,HIDDEN,_propertyDesc(1,{}));it[HIDDEN][key]=true;}else{if(_has(it,HIDDEN)&&it[HIDDEN][key])it[HIDDEN][key]=false;D=_objectCreate(D,{enumerable:_propertyDesc(0,false)});}return setSymbolDesc(it,key,D);}return dP$1(it,key,D);};var $defineProperties=function defineProperties(it,P){_anObject(it);var keys=_enumKeys(P=_toIobject(P));var i=0;var l=keys.length;var key;while(l>i)$defineProperty(it,key=keys[i++],P[key]);return it;};var $create=function create(it,P){return P===undefined?_objectCreate(it):$defineProperties(_objectCreate(it),P);};var $propertyIsEnumerable=function propertyIsEnumerable(key){var E=isEnum.call(this,key=_toPrimitive(key,true));if(this===ObjectProto$1&&_has(AllSymbols,key)&&!_has(OPSymbols,key))return false;return E||!_has(this,key)||!_has(AllSymbols,key)||_has(this,HIDDEN)&&this[HIDDEN][key]?E:true;};var $getOwnPropertyDescriptor$1=function getOwnPropertyDescriptor(it,key){it=_toIobject(it);key=_toPrimitive(key,true);if(it===ObjectProto$1&&_has(AllSymbols,key)&&!_has(OPSymbols,key))return;var D=gOPD$1(it,key);if(D&&_has(AllSymbols,key)&&!(_has(it,HIDDEN)&&it[HIDDEN][key]))D.enumerable=true;return D;};var $getOwnPropertyNames=function getOwnPropertyNames(it){var names=gOPN$1(_toIobject(it));var result=[];var i=0;var key;while(names.length>i){if(!_has(AllSymbols,key=names[i++])&&key!=HIDDEN&&key!=META)result.push(key);}return result;};var $getOwnPropertySymbols=function getOwnPropertySymbols(it){var IS_OP=it===ObjectProto$1;var names=gOPN$1(IS_OP?OPSymbols:_toIobject(it));var result=[];var i=0;var key;while(names.length>i){if(_has(AllSymbols,key=names[i++])&&(IS_OP?_has(ObjectProto$1,key):true))result.push(AllSymbols[key]);}return result;};// 19.4.1.1 Symbol([description])
if(!USE_NATIVE$1){$Symbol=function Symbol(){if(this instanceof $Symbol)throw TypeError('Symbol is not a constructor!');var tag=_uid(arguments.length>0?arguments[0]:undefined);var $set=function(value){if(this===ObjectProto$1)$set.call(OPSymbols,value);if(_has(this,HIDDEN)&&_has(this[HIDDEN],tag))this[HIDDEN][tag]=false;setSymbolDesc(this,tag,_propertyDesc(1,value));};if(_descriptors&&setter)setSymbolDesc(ObjectProto$1,tag,{configurable:true,set:$set});return wrap(tag);};_redefine($Symbol[PROTOTYPE$2],'toString',function toString(){return this._k;});_objectGopd.f=$getOwnPropertyDescriptor$1;_objectDp.f=$defineProperty;_objectGopn.f=_objectGopnExt.f=$getOwnPropertyNames;_objectPie.f=$propertyIsEnumerable;_objectGops.f=$getOwnPropertySymbols;if(_descriptors&&!_library){_redefine(ObjectProto$1,'propertyIsEnumerable',$propertyIsEnumerable,true);}_wksExt.f=function(name){return wrap(_wks(name));};}_export(_export.G+_export.W+_export.F*!USE_NATIVE$1,{Symbol:$Symbol});for(var es6Symbols=// 19.4.2.2, 19.4.2.3, 19.4.2.4, 19.4.2.6, 19.4.2.8, 19.4.2.9, 19.4.2.10, 19.4.2.11, 19.4.2.12, 19.4.2.13, 19.4.2.14
'hasInstance,isConcatSpreadable,iterator,match,replace,search,species,split,toPrimitive,toStringTag,unscopables'.split(','),j=0;es6Symbols.length>j;)_wks(es6Symbols[j++]);for(var wellKnownSymbols=_objectKeys(_wks.store),k=0;wellKnownSymbols.length>k;)_wksDefine(wellKnownSymbols[k++]);_export(_export.S+_export.F*!USE_NATIVE$1,'Symbol',{// 19.4.2.1 Symbol.for(key)
'for':function(key){return _has(SymbolRegistry,key+='')?SymbolRegistry[key]:SymbolRegistry[key]=$Symbol(key);},// 19.4.2.5 Symbol.keyFor(sym)
keyFor:function keyFor(sym){if(!isSymbol(sym))throw TypeError(sym+' is not a symbol!');for(var key in SymbolRegistry)if(SymbolRegistry[key]===sym)return key;},useSetter:function(){setter=true;},useSimple:function(){setter=false;}});_export(_export.S+_export.F*!USE_NATIVE$1,'Object',{// 19.1.2.2 Object.create(O [, Properties])
create:$create,// 19.1.2.4 Object.defineProperty(O, P, Attributes)
defineProperty:$defineProperty,// 19.1.2.3 Object.defineProperties(O, Properties)
defineProperties:$defineProperties,// 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)
getOwnPropertyDescriptor:$getOwnPropertyDescriptor$1,// 19.1.2.7 Object.getOwnPropertyNames(O)
getOwnPropertyNames:$getOwnPropertyNames,// 19.1.2.8 Object.getOwnPropertySymbols(O)
getOwnPropertySymbols:$getOwnPropertySymbols});// 24.3.2 JSON.stringify(value [, replacer [, space]])
$JSON&&_export(_export.S+_export.F*(!USE_NATIVE$1||_fails(function(){var S=$Symbol();// MS Edge converts symbol values to JSON as {}
// WebKit converts symbol values to JSON as null
// V8 throws on boxed symbols
return _stringify([S])!='[null]'||_stringify({a:S})!='{}'||_stringify(Object(S))!='{}';})),'JSON',{stringify:function stringify(it){var args=[it];var i=1;var replacer,$replacer;while(arguments.length>i)args.push(arguments[i++]);$replacer=replacer=args[1];if(!_isObject(replacer)&&it===undefined||isSymbol(it))return;// IE8 returns string on undefined
if(!_isArray(replacer))replacer=function(key,value){if(typeof $replacer=='function')value=$replacer.call(this,key,value);if(!isSymbol(value))return value;};args[1]=replacer;return _stringify.apply($JSON,args);}});// 19.4.3.4 Symbol.prototype[@@toPrimitive](hint)
$Symbol[PROTOTYPE$2][TO_PRIMITIVE]||_hide($Symbol[PROTOTYPE$2],TO_PRIMITIVE,$Symbol[PROTOTYPE$2].valueOf);// 19.4.3.5 Symbol.prototype[@@toStringTag]
_setToStringTag($Symbol,'Symbol');// 20.2.1.9 Math[@@toStringTag]
_setToStringTag(Math,'Math',true);// 24.3.3 JSON[@@toStringTag]
_setToStringTag(_global.JSON,'JSON',true);var getOwnPropertySymbols=_core.Object.getOwnPropertySymbols;var getOwnPropertySymbols$1=getOwnPropertySymbols;// 19.1.2.14 Object.keys(O)
_objectSap('keys',function(){return function keys(it){return _objectKeys(_toObject(it));};});var keys=_core.Object.keys;var keys$1=keys;// 19.1.2.4 / 15.2.3.6 Object.defineProperty(O, P, Attributes)
_export(_export.S+_export.F*!_descriptors,'Object',{defineProperty:_objectDp.f});var $Object$1=_core.Object;var defineProperty$1=function defineProperty(it,key,desc){return $Object$1.defineProperty(it,key,desc);};var defineProperty$2=defineProperty$1;function _defineProperty$1(obj,key,value){if(key in obj){defineProperty$2(obj,key,{value:value,enumerable:true,configurable:true,writable:true});}else{obj[key]=value;}return obj;}var defineProperty$3=_defineProperty$1;function _objectSpread$1(target){for(var i=1;i<arguments.length;i++){var source=arguments[i]!=null?arguments[i]:{};var ownKeys=keys$1(source);if(typeof getOwnPropertySymbols$1==='function'){ownKeys=ownKeys.concat(getOwnPropertySymbols$1(source).filter(function(sym){return getOwnPropertyDescriptor$1(source,sym).enumerable;}));}ownKeys.forEach(function(key){defineProperty$3(target,key,source[key]);});}return target;}var objectSpread=_objectSpread$1;function _classCallCheck$1(instance,Constructor){if(!(instance instanceof Constructor)){throw new TypeError("Cannot call a class as a function");}}var classCallCheck=_classCallCheck$1;// Works with __proto__ only. Old v8 can't work with null proto objects.
/* eslint-disable no-proto */var check=function(O,proto){_anObject(O);if(!_isObject(proto)&&proto!==null)throw TypeError(proto+": can't set as prototype!");};var _setProto={set:Object.setPrototypeOf||('__proto__'in{}?// eslint-disable-line
function(test,buggy,set){try{set=_ctx(Function.call,_objectGopd.f(Object.prototype,'__proto__').set,2);set(test,[]);buggy=!(test instanceof Array);}catch(e){buggy=true;}return function setPrototypeOf(O,proto){check(O,proto);if(buggy)O.__proto__=proto;else set(O,proto);return O;};}({},false):undefined),check:check};// 19.1.3.19 Object.setPrototypeOf(O, proto)
_export(_export.S,'Object',{setPrototypeOf:_setProto.set});var setPrototypeOf=_core.Object.setPrototypeOf;var setPrototypeOf$1=setPrototypeOf;var setPrototypeOf$2=createCommonjsModule(function(module){function _setPrototypeOf$$1(o,p){module.exports=_setPrototypeOf$$1=setPrototypeOf$1||function _setPrototypeOf$$1(o,p){o.__proto__=p;return o;};return _setPrototypeOf$$1(o,p);}module.exports=_setPrototypeOf$$1;});function _inherits$1(subClass,superClass){if(typeof superClass!=="function"&&superClass!==null){throw new TypeError("Super expression must either be null or a function");}setPrototypeOf$2(subClass.prototype,superClass&&superClass.prototype);if(superClass)setPrototypeOf$2(subClass,superClass);}var inherits=_inherits$1;function _defineProperties$1(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||false;descriptor.configurable=true;if("value"in descriptor)descriptor.writable=true;defineProperty$2(target,descriptor.key,descriptor);}}function _createClass$1(Constructor,protoProps,staticProps){if(protoProps)_defineProperties$1(Constructor.prototype,protoProps);if(staticProps)_defineProperties$1(Constructor,staticProps);return Constructor;}var createClass=_createClass$1;var iterator=_wksExt.f('iterator');var iterator$1=iterator;_wksDefine('asyncIterator');_wksDefine('observable');var symbol=_core.Symbol;var symbol$1=symbol;var _typeof_1=createCommonjsModule(function(module){function _typeof2(obj){if(typeof symbol$1==="function"&&typeof iterator$1==="symbol"){_typeof2=function _typeof2(obj){return typeof obj;};}else{_typeof2=function _typeof2(obj){return obj&&typeof symbol$1==="function"&&obj.constructor===symbol$1&&obj!==symbol$1.prototype?"symbol":typeof obj;};}return _typeof2(obj);}function _typeof$$1(obj){if(typeof symbol$1==="function"&&_typeof2(iterator$1)==="symbol"){module.exports=_typeof$$1=function _typeof$$1(obj){return _typeof2(obj);};}else{module.exports=_typeof$$1=function _typeof$$1(obj){return obj&&typeof symbol$1==="function"&&obj.constructor===symbol$1&&obj!==symbol$1.prototype?"symbol":_typeof2(obj);};}return _typeof$$1(obj);}module.exports=_typeof$$1;});function _assertThisInitialized$1(self){if(self===void 0){throw new ReferenceError("this hasn't been initialised - super() hasn't been called");}return self;}var assertThisInitialized=_assertThisInitialized$1;function _possibleConstructorReturn$1(self,call){if(call&&(_typeof_1(call)==="object"||typeof call==="function")){return call;}return assertThisInitialized(self);}var possibleConstructorReturn=_possibleConstructorReturn$1;// 19.1.2.9 Object.getPrototypeOf(O)
_objectSap('getPrototypeOf',function(){return function getPrototypeOf(it){return _objectGpo(_toObject(it));};});var getPrototypeOf=_core.Object.getPrototypeOf;var getPrototypeOf$1=getPrototypeOf;var getPrototypeOf$2=createCommonjsModule(function(module){function _getPrototypeOf$$1(o){module.exports=_getPrototypeOf$$1=getPrototypeOf$1||function _getPrototypeOf$$1(o){return o.__proto__;};return _getPrototypeOf$$1(o);}module.exports=_getPrototypeOf$$1;});var extend=function extend(object){for(var _len=arguments.length,extensions=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){extensions[_key-1]=arguments[_key];}// $.extend alternative, ... is the spread operator.
for(var _i=0;_i<extensions.length;_i++){var extension=extensions[_i];// console.log(extension);
// console.log(typeof extension);
if(!extension)continue;// Ignore null and undefined objects and parameters.
var _iteratorNormalCompletion=true;var _didIteratorError=false;var _iteratorError=undefined;try{for(var _iterator=Object.getOwnPropertyNames(extension)[Symbol.iterator](),_step;!(_iteratorNormalCompletion=(_step=_iterator.next()).done);_iteratorNormalCompletion=true){var prop=_step.value;// Do not traverse the prototype chain.
if(object[prop]!==undefined&&extension[prop]&&object[prop].toString()==='[object Object]'&&extension[prop].toString()==='[object Object]'){// Goes deep only if object[prop] and extension[prop] are both objects !
if(object[prop].constructor===Object)extend(object[prop],extension[prop]);}else object[prop]=typeof object[prop]==='undefined'?extension[prop]:object[prop];if(typeof object[prop]==='undefined'&&Array.isArray(extension[prop]))object[prop]=extension[prop].slice();// Add values that do not already exist.
else if(typeof object[prop]==='undefined'&&Array.isArray(extension[prop]))object[prop]=extension[prop];}}catch(err){_didIteratorError=true;_iteratorError=err;}finally{try{if(!_iteratorNormalCompletion&&_iterator.return!=null){_iterator.return();}}finally{if(_didIteratorError){throw _iteratorError;}}}}return object;};var instruct=function instruct(array,instArray){var tempObject={};for(var i=0,max=instArray.length;i<max;i++){var guide=instArray[i];tempObject[guide]=array[i];}return tempObject;};var transformData=function transformData(object,instructions){for(var key in instructions){if(Array.isArray(object[key]))object[key]=instruct(object[key],instructions[key]);else if(object[key]instanceof Object&&!Array.isArray(instructions[key]))object[key]=transformData(object[key],instructions[key]);}return object;};if(Number.EPSILON===undefined){Number.EPSILON=Math.pow(2,-52);}if(Number.isInteger===undefined){// Missing in IE
// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/isInteger
Number.isInteger=function(value){return typeof value==='number'&&isFinite(value)&&Math.floor(value)===value;};}//
if(Math.sign===undefined){// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/sign
Math.sign=function(x){return x<0?-1:x>0?1:+x;};}if('name'in Function.prototype===false){// Missing in IE
// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/name
Object.defineProperty(Function.prototype,'name',{get:function(){return this.toString().match(/^\s*function\s*([^\(\s]*)/)[1];}});}if(Object.assign===undefined){// Missing in IE
// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/assign
(function(){Object.assign=function(target){if(target===undefined||target===null){throw new TypeError('Cannot convert undefined or null to object');}var output=Object(target);for(var index=1;index<arguments.length;index++){var source=arguments[index];if(source!==undefined&&source!==null){for(var nextKey in source){if(Object.prototype.hasOwnProperty.call(source,nextKey)){output[nextKey]=source[nextKey];}}}}return output;};})();}/**
* https://github.com/mrdoob/eventdispatcher.js/
*/function EventDispatcher(){}Object.assign(EventDispatcher.prototype,{addEventListener:function(type,listener){if(this._listeners===undefined)this._listeners={};var listeners=this._listeners;if(listeners[type]===undefined){listeners[type]=[];}if(listeners[type].indexOf(listener)===-1){listeners[type].push(listener);}},hasEventListener:function(type,listener){if(this._listeners===undefined)return false;var listeners=this._listeners;return listeners[type]!==undefined&&listeners[type].indexOf(listener)!==-1;},removeEventListener:function(type,listener){if(this._listeners===undefined)return;var listeners=this._listeners;var listenerArray=listeners[type];if(listenerArray!==undefined){var index=listenerArray.indexOf(listener);if(index!==-1){listenerArray.splice(index,1);}}},dispatchEvent:function(event){if(this._listeners===undefined)return;var listeners=this._listeners;var listenerArray=listeners[event.type];if(listenerArray!==undefined){event.target=this;var array=listenerArray.slice(0);for(var i=0,l=array.length;i<l;i++){array[i].call(this,event);}}}});var REVISION='92';var MOUSE={LEFT:0,MIDDLE:1,RIGHT:2};var CullFaceNone=0;var CullFaceBack=1;var CullFaceFront=2;var PCFShadowMap=1;var PCFSoftShadowMap=2;var FrontSide=0;var BackSide=1;var DoubleSide=2;var FlatShading=1;var NoColors=0;var FaceColors=1;var VertexColors=2;var NoBlending=0;var NormalBlending=1;var AdditiveBlending=2;var SubtractiveBlending=3;var MultiplyBlending=4;var CustomBlending=5;var AddEquation=100;var SubtractEquation=101;var ReverseSubtractEquation=102;var MinEquation=103;var MaxEquation=104;var ZeroFactor=200;var OneFactor=201;var SrcColorFactor=202;var OneMinusSrcColorFactor=203;var SrcAlphaFactor=204;var OneMinusSrcAlphaFactor=205;var DstAlphaFactor=206;var OneMinusDstAlphaFactor=207;var DstColorFactor=208;var OneMinusDstColorFactor=209;var SrcAlphaSaturateFactor=210;var NeverDepth=0;var AlwaysDepth=1;var LessDepth=2;var LessEqualDepth=3;var EqualDepth=4;var GreaterEqualDepth=5;var GreaterDepth=6;var NotEqualDepth=7;var MultiplyOperation=0;var MixOperation=1;var AddOperation=2;var NoToneMapping=0;var LinearToneMapping=1;var ReinhardToneMapping=2;var Uncharted2ToneMapping=3;var CineonToneMapping=4;var UVMapping=300;var CubeReflectionMapping=301;var CubeRefractionMapping=302;var EquirectangularReflectionMapping=303;var EquirectangularRefractionMapping=304;var SphericalReflectionMapping=305;var CubeUVReflectionMapping=306;var CubeUVRefractionMapping=307;var RepeatWrapping=1000;var ClampToEdgeWrapping=1001;var MirroredRepeatWrapping=1002;var NearestFilter=1003;var NearestMipMapNearestFilter=1004;var NearestMipMapLinearFilter=1005;var LinearFilter=1006;var LinearMipMapNearestFilter=1007;var LinearMipMapLinearFilter=1008;var UnsignedByteType=1009;var ByteType=1010;var ShortType=1011;var UnsignedShortType=1012;var IntType=1013;var UnsignedIntType=1014;var FloatType=1015;var HalfFloatType=1016;var UnsignedShort4444Type=1017;var UnsignedShort5551Type=1018;var UnsignedShort565Type=1019;var UnsignedInt248Type=1020;var AlphaFormat=1021;var RGBFormat=1022;var RGBAFormat=1023;var LuminanceFormat=1024;var LuminanceAlphaFormat=1025;var DepthFormat=1026;var DepthStencilFormat=1027;var RGB_S3TC_DXT1_Format=33776;var RGBA_S3TC_DXT1_Format=33777;var RGBA_S3TC_DXT3_Format=33778;var RGBA_S3TC_DXT5_Format=33779;var RGB_PVRTC_4BPPV1_Format=35840;var RGB_PVRTC_2BPPV1_Format=35841;var RGBA_PVRTC_4BPPV1_Format=35842;var RGBA_PVRTC_2BPPV1_Format=35843;var RGB_ETC1_Format=36196;var RGBA_ASTC_4x4_Format=37808;var RGBA_ASTC_5x4_Format=37809;var RGBA_ASTC_5x5_Format=37810;var RGBA_ASTC_6x5_Format=37811;var RGBA_ASTC_6x6_Format=37812;var RGBA_ASTC_8x5_Format=37813;var RGBA_ASTC_8x6_Format=37814;var RGBA_ASTC_8x8_Format=37815;var RGBA_ASTC_10x5_Format=37816;var RGBA_ASTC_10x6_Format=37817;var RGBA_ASTC_10x8_Format=37818;var RGBA_ASTC_10x10_Format=37819;var RGBA_ASTC_12x10_Format=37820;var RGBA_ASTC_12x12_Format=37821;var LoopOnce=2200;var LoopRepeat=2201;var LoopPingPong=2202;var InterpolateDiscrete=2300;var InterpolateLinear=2301;var InterpolateSmooth=2302;var ZeroCurvatureEnding=2400;var ZeroSlopeEnding=2401;var WrapAroundEnding=2402;var TrianglesDrawMode=0;var TriangleStripDrawMode=1;var TriangleFanDrawMode=2;var LinearEncoding=3000;var sRGBEncoding=3001;var GammaEncoding=3007;var RGBEEncoding=3002;var RGBM7Encoding=3004;var RGBM16Encoding=3005;var RGBDEncoding=3006;var BasicDepthPacking=3200;var RGBADepthPacking=3201;/**
* @author alteredq / http://alteredqualia.com/
* @author mrdoob / http://mrdoob.com/
*/var _Math={DEG2RAD:Math.PI/180,RAD2DEG:180/Math.PI,generateUUID:function(){// http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/21963136#21963136
var lut=[];for(var i=0;i<256;i++){lut[i]=(i<16?'0':'')+i.toString(16);}return function generateUUID(){var d0=Math.random()*0xffffffff|0;var d1=Math.random()*0xffffffff|0;var d2=Math.random()*0xffffffff|0;var d3=Math.random()*0xffffffff|0;var uuid=lut[d0&0xff]+lut[d0>>8&0xff]+lut[d0>>16&0xff]+lut[d0>>24&0xff]+'-'+lut[d1&0xff]+lut[d1>>8&0xff]+'-'+lut[d1>>16&0x0f|0x40]+lut[d1>>24&0xff]+'-'+lut[d2&0x3f|0x80]+lut[d2>>8&0xff]+'-'+lut[d2>>16&0xff]+lut[d2>>24&0xff]+lut[d3&0xff]+lut[d3>>8&0xff]+lut[d3>>16&0xff]+lut[d3>>24&0xff];// .toUpperCase() here flattens concatenated strings to save heap memory space.
return uuid.toUpperCase();};}(),clamp:function(value,min,max){return Math.max(min,Math.min(max,value));},// compute euclidian modulo of m % n
// https://en.wikipedia.org/wiki/Modulo_operation
euclideanModulo:function(n,m){return (n%m+m)%m;},// Linear mapping from range <a1, a2> to range <b1, b2>
mapLinear:function(x,a1,a2,b1,b2){return b1+(x-a1)*(b2-b1)/(a2-a1);},// https://en.wikipedia.org/wiki/Linear_interpolation
lerp:function(x,y,t){return (1-t)*x+t*y;},// http://en.wikipedia.org/wiki/Smoothstep
smoothstep:function(x,min,max){if(x<=min)return 0;if(x>=max)return 1;x=(x-min)/(max-min);return x*x*(3-2*x);},smootherstep:function(x,min,max){if(x<=min)return 0;if(x>=max)return 1;x=(x-min)/(max-min);return x*x*x*(x*(x*6-15)+10);},// Random integer from <low, high> interval
randInt:function(low,high){return low+Math.floor(Math.random()*(high-low+1));},// Random float from <low, high> interval
randFloat:function(low,high){return low+Math.random()*(high-low);},// Random float from <-range/2, range/2> interval
randFloatSpread:function(range){return range*(0.5-Math.random());},degToRad:function(degrees){return degrees*_Math.DEG2RAD;},radToDeg:function(radians){return radians*_Math.RAD2DEG;},isPowerOfTwo:function(value){return (value&value-1)===0&&value!==0;},ceilPowerOfTwo:function(value){return Math.pow(2,Math.ceil(Math.log(value)/Math.LN2));},floorPowerOfTwo:function(value){return Math.pow(2,Math.floor(Math.log(value)/Math.LN2));}};/**
* @author mrdoob / http://mrdoob.com/
* @author philogb / http://blog.thejit.org/
* @author egraether / http://egraether.com/
* @author zz85 / http://www.lab4games.net/zz85/blog
*/function Vector2(x,y){this.x=x||0;this.y=y||0;}Object.defineProperties(Vector2.prototype,{"width":{get:function(){return this.x;},set:function(value){this.x=value;}},"height":{get:function(){return this.y;},set:function(value){this.y=value;}}});Object.assign(Vector2.prototype,{isVector2:true,set:function(x,y){this.x=x;this.y=y;return this;},setScalar:function(scalar){this.x=scalar;this.y=scalar;return this;},setX:function(x){this.x=x;return this;},setY:function(y){this.y=y;return this;},setComponent:function(index,value){switch(index){case 0:this.x=value;break;case 1:this.y=value;break;default:throw new Error('index is out of range: '+index);}return this;},getComponent:function(index){switch(index){case 0:return this.x;case 1:return this.y;default:throw new Error('index is out of range: '+index);}},clone:function(){return new this.constructor(this.x,this.y);},copy:function(v){this.x=v.x;this.y=v.y;return this;},add:function(v,w){if(w!==undefined){console.warn('THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead.');return this.addVectors(v,w);}this.x+=v.x;this.y+=v.y;return this;},addScalar:function(s){this.x+=s;this.y+=s;return this;},addVectors:function(a,b){this.x=a.x+b.x;this.y=a.y+b.y;return this;},addScaledVector:function(v,s){this.x+=v.x*s;this.y+=v.y*s;return this;},sub:function(v,w){if(w!==undefined){console.warn('THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.');return this.subVectors(v,w);}this.x-=v.x;this.y-=v.y;return this;},subScalar:function(s){this.x-=s;this.y-=s;return this;},subVectors:function(a,b){this.x=a.x-b.x;this.y=a.y-b.y;return this;},multiply:function(v){this.x*=v.x;this.y*=v.y;return this;},multiplyScalar:function(scalar){this.x*=scalar;this.y*=scalar;return this;},divide:function(v){this.x/=v.x;this.y/=v.y;return this;},divideScalar:function(scalar){return this.multiplyScalar(1/scalar);},applyMatrix3:function(m){var x=this.x,y=this.y;var e=m.elements;this.x=e[0]*x+e[3]*y+e[6];this.y=e[1]*x+e[4]*y+e[7];return this;},min:function(v){this.x=Math.min(this.x,v.x);this.y=Math.min(this.y,v.y);return this;},max:function(v){this.x=Math.max(this.x,v.x);this.y=Math.max(this.y,v.y);return this;},clamp:function(min,max){// assumes min < max, componentwise
this.x=Math.max(min.x,Math.min(max.x,this.x));this.y=Math.max(min.y,Math.min(max.y,this.y));return this;},clampScalar:function(){var min=new Vector2();var max=new Vector2();return function clampScalar(minVal,maxVal){min.set(minVal,minVal);max.set(maxVal,maxVal);return this.clamp(min,max);};}(),clampLength:function(min,max){var length=this.length();return this.divideScalar(length||1).multiplyScalar(Math.max(min,Math.min(max,length)));},floor:function(){this.x=Math.floor(this.x);this.y=Math.floor(this.y);return this;},ceil:function(){this.x=Math.ceil(this.x);this.y=Math.ceil(this.y);return this;},round:function(){this.x=Math.round(this.x);this.y=Math.round(this.y);return this;},roundToZero:function(){this.x=this.x<0?Math.ceil(this.x):Math.floor(this.x);this.y=this.y<0?Math.ceil(this.y):Math.floor(this.y);return this;},negate:function(){this.x=-this.x;this.y=-this.y;return this;},dot:function(v){return this.x*v.x+this.y*v.y;},lengthSq:function(){return this.x*this.x+this.y*this.y;},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y);},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y);},normalize:function(){return this.divideScalar(this.length()||1);},angle:function(){// computes the angle in radians with respect to the positive x-axis
var angle=Math.atan2(this.y,this.x);if(angle<0)angle+=2*Math.PI;return angle;},distanceTo:function(v){return Math.sqrt(this.distanceToSquared(v));},distanceToSquared:function(v){var dx=this.x-v.x,dy=this.y-v.y;return dx*dx+dy*dy;},manhattanDistanceTo:function(v){return Math.abs(this.x-v.x)+Math.abs(this.y-v.y);},setLength:function(length){return this.normalize().multiplyScalar(length);},lerp:function(v,alpha){this.x+=(v.x-this.x)*alpha;this.y+=(v.y-this.y)*alpha;return this;},lerpVectors:function(v1,v2,alpha){return this.subVectors(v2,v1).multiplyScalar(alpha).add(v1);},equals:function(v){return v.x===this.x&&v.y===this.y;},fromArray:function(array,offset){if(offset===undefined)offset=0;this.x=array[offset];this.y=array[offset+1];return this;},toArray:function(array,offset){if(array===undefined)array=[];if(offset===undefined)offset=0;array[offset]=this.x;array[offset+1]=this.y;return array;},fromBufferAttribute:function(attribute,index,offset){if(offset!==undefined){console.warn('THREE.Vector2: offset has been removed from .fromBufferAttribute().');}this.x=attribute.getX(index);this.y=attribute.getY(index);return this;},rotateAround:function(center,angle){var c=Math.cos(angle),s=Math.sin(angle);var x=this.x-center.x;var y=this.y-center.y;this.x=x*c-y*s+center.x;this.y=x*s+y*c+center.y;return this;}});/**
* @author mrdoob / http://mrdoob.com/
* @author supereggbert / http://www.paulbrunt.co.uk/
* @author philogb / http://blog.thejit.org/
* @author jordi_ros / http://plattsoft.com
* @author D1plo1d / http://github.com/D1plo1d
* @author alteredq / http://alteredqualia.com/
* @author mikael emtinger / http://gomo.se/
* @author timknip / http://www.floorplanner.com/
* @author bhouston / http://clara.io
* @author WestLangley / http://github.com/WestLangley
*/function Matrix4(){this.elements=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];if(arguments.length>0){console.error('THREE.Matrix4: the constructor no longer reads arguments. use .set() instead.');}}Object.assign(Matrix4.prototype,{isMatrix4:true,set:function(n11,n12,n13,n14,n21,n22,n23,n24,n31,n32,n33,n34,n41,n42,n43,n44){var te=this.elements;te[0]=n11;te[4]=n12;te[8]=n13;te[12]=n14;te[1]=n21;te[5]=n22;te[9]=n23;te[13]=n24;te[2]=n31;te[6]=n32;te[10]=n33;te[14]=n34;te[3]=n41;te[7]=n42;te[11]=n43;te[15]=n44;return this;},identity:function(){this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);return this;},clone:function(){return new Matrix4().fromArray(this.elements);},copy:function(m){var te=this.elements;var me=m.elements;te[0]=me[0];te[1]=me[1];te[2]=me[2];te[3]=me[3];te[4]=me[4];te[5]=me[5];te[6]=me[6];te[7]=me[7];te[8]=me[8];te[9]=me[9];te[10]=me[10];te[11]=me[11];te[12]=me[12];te[13]=me[13];te[14]=me[14];te[15]=me[15];return this;},copyPosition:function(m){var te=this.elements,me=m.elements;te[12]=me[12];te[13]=me[13];te[14]=me[14];return this;},extractBasis:function(xAxis,yAxis,zAxis){xAxis.setFromMatrixColumn(this,0);yAxis.setFromMatrixColumn(this,1);zAxis.setFromMatrixColumn(this,2);return this;},makeBasis:function(xAxis,yAxis,zAxis){this.set(xAxis.x,yAxis.x,zAxis.x,0,xAxis.y,yAxis.y,zAxis.y,0,xAxis.z,yAxis.z,zAxis.z,0,0,0,0,1);return this;},extractRotation:function(){var v1=new Vector3();return function extractRotation(m){var te=this.elements;var me=m.elements;var scaleX=1/v1.setFromMatrixColumn(m,0).length();var scaleY=1/v1.setFromMatrixColumn(m,1).length();var scaleZ=1/v1.setFromMatrixColumn(m,2).length();te[0]=me[0]*scaleX;te[1]=me[1]*scaleX;te[2]=me[2]*scaleX;te[4]=me[4]*scaleY;te[5]=me[5]*scaleY;te[6]=me[6]*scaleY;te[8]=me[8]*scaleZ;te[9]=me[9]*scaleZ;te[10]=me[10]*scaleZ;return this;};}(),makeRotationFromEuler:function(euler){if(!(euler&&euler.isEuler)){console.error('THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.');}var te=this.elements;var x=euler.x,y=euler.y,z=euler.z;var a=Math.cos(x),b=Math.sin(x);var c=Math.cos(y),d=Math.sin(y);var e=Math.cos(z),f=Math.sin(z);if(euler.order==='XYZ'){var ae=a*e,af=a*f,be=b*e,bf=b*f;te[0]=c*e;te[4]=-c*f;te[8]=d;te[1]=af+be*d;te[5]=ae-bf*d;te[9]=-b*c;te[2]=bf-ae*d;te[6]=be+af*d;te[10]=a*c;}else if(euler.order==='YXZ'){var ce=c*e,cf=c*f,de=d*e,df=d*f;te[0]=ce+df*b;te[4]=de*b-cf;te[8]=a*d;te[1]=a*f;te[5]=a*e;te[9]=-b;te[2]=cf*b-de;te[6]=df+ce*b;te[10]=a*c;}else if(euler.order==='ZXY'){var ce=c*e,cf=c*f,de=d*e,df=d*f;te[0]=ce-df*b;te[4]=-a*f;te[8]=de+cf*b;te[1]=cf+de*b;te[5]=a*e;te[9]=df-ce*b;te[2]=-a*d;te[6]=b;te[10]=a*c;}else if(euler.order==='ZYX'){var ae=a*e,af=a*f,be=b*e,bf=b*f;te[0]=c*e;te[4]=be*d-af;te[8]=ae*d+bf;te[1]=c*f;te[5]=bf*d+ae;te[9]=af*d-be;te[2]=-d;te[6]=b*c;te[10]=a*c;}else if(euler.order==='YZX'){var ac=a*c,ad=a*d,bc=b*c,bd=b*d;te[0]=c*e;te[4]=bd-ac*f;te[8]=bc*f+ad;te[1]=f;te[5]=a*e;te[9]=-b*e;te[2]=-d*e;te[6]=ad*f+bc;te[10]=ac-bd*f;}else if(euler.order==='XZY'){var ac=a*c,ad=a*d,bc=b*c,bd=b*d;te[0]=c*e;te[4]=-f;te[8]=d*e;te[1]=ac*f+bd;te[5]=a*e;te[9]=ad*f-bc;te[2]=bc*f-ad;te[6]=b*e;te[10]=bd*f+ac;}// last column
te[3]=0;te[7]=0;te[11]=0;// bottom row
te[12]=0;te[13]=0;te[14]=0;te[15]=1;return this;},makeRotationFromQuaternion:function(q){var te=this.elements;var x=q._x,y=q._y,z=q._z,w=q._w;var x2=x+x,y2=y+y,z2=z+z;var xx=x*x2,xy=x*y2,xz=x*z2;var yy=y*y2,yz=y*z2,zz=z*z2;var wx=w*x2,wy=w*y2,wz=w*z2;te[0]=1-(yy+zz);te[4]=xy-wz;te[8]=xz+wy;te[1]=xy+wz;te[5]=1-(xx+zz);te[9]=yz-wx;te[2]=xz-wy;te[6]=yz+wx;te[10]=1-(xx+yy);// last column
te[3]=0;te[7]=0;te[11]=0;// bottom row
te[12]=0;te[13]=0;te[14]=0;te[15]=1;return this;},lookAt:function(){var x=new Vector3();var y=new Vector3();var z=new Vector3();return function lookAt(eye,target,up){var te=this.elements;z.subVectors(eye,target);if(z.lengthSq()===0){// eye and target are in the same position
z.z=1;}z.normalize();x.crossVectors(up,z);if(x.lengthSq()===0){// up and z are parallel
if(Math.abs(up.z)===1){z.x+=0.0001;}else{z.z+=0.0001;}z.normalize();x.crossVectors(up,z);}x.normalize();y.crossVectors(z,x);te[0]=x.x;te[4]=y.x;te[8]=z.x;te[1]=x.y;te[5]=y.y;te[9]=z.y;te[2]=x.z;te[6]=y.z;te[10]=z.z;return this;};}(),multiply:function(m,n){if(n!==undefined){console.warn('THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead.');return this.multiplyMatrices(m,n);}return this.multiplyMatrices(this,m);},premultiply:function(m){return this.multiplyMatrices(m,this);},multiplyMatrices:function(a,b){var ae=a.elements;var be=b.elements;var te=this.elements;var a11=ae[0],a12=ae[4],a13=ae[8],a14=ae[12];var a21=ae[1],a22=ae[5],a23=ae[9],a24=ae[13];var a31=ae[2],a32=ae[6],a33=ae[10],a34=ae[14];var a41=ae[3],a42=ae[7],a43=ae[11],a44=ae[15];var b11=be[0],b12=be[4],b13=be[8],b14=be[12];var b21=be[1],b22=be[5],b23=be[9],b24=be[13];var b31=be[2],b32=be[6],b33=be[10],b34=be[14];var b41=be[3],b42=be[7],b43=be[11],b44=be[15];te[0]=a11*b11+a12*b21+a13*b31+a14*b41;te[4]=a11*b12+a12*b22+a13*b32+a14*b42;te[8]=a11*b13+a12*b23+a13*b33+a14*b43;te[12]=a11*b14+a12*b24+a13*b34+a14*b44;te[1]=a21*b11+a22*b21+a23*b31+a24*b41;te[5]=a21*b12+a22*b22+a23*b32+a24*b42;te[9]=a21*b13+a22*b23+a23*b33+a24*b43;te[13]=a21*b14+a22*b24+a23*b34+a24*b44;te[2]=a31*b11+a32*b21+a33*b31+a34*b41;te[6]=a31*b12+a32*b22+a33*b32+a34*b42;te[10]=a31*b13+a32*b23+a33*b33+a34*b43;te[14]=a31*b14+a32*b24+a33*b34+a34*b44;te[3]=a41*b11+a42*b21+a43*b31+a44*b41;te[7]=a41*b12+a42*b22+a43*b32+a44*b42;te[11]=a41*b13+a42*b23+a43*b33+a44*b43;te[15]=a41*b14+a42*b24+a43*b34+a44*b44;return this;},multiplyScalar:function(s){var te=this.elements;te[0]*=s;te[4]*=s;te[8]*=s;te[12]*=s;te[1]*=s;te[5]*=s;te[9]*=s;te[13]*=s;te[2]*=s;te[6]*=s;te[10]*=s;te[14]*=s;te[3]*=s;te[7]*=s;te[11]*=s;te[15]*=s;return this;},applyToBufferAttribute:function(){var v1=new Vector3();return function applyToBufferAttribute(attribute){for(var i=0,l=attribute.count;i<l;i++){v1.x=attribute.getX(i);v1.y=attribute.getY(i);v1.z=attribute.getZ(i);v1.applyMatrix4(this);attribute.setXYZ(i,v1.x,v1.y,v1.z);}return attribute;};}(),determinant:function(){var te=this.elements;var n11=te[0],n12=te[4],n13=te[8],n14=te[12];var n21=te[1],n22=te[5],n23=te[9],n24=te[13];var n31=te[2],n32=te[6],n33=te[10],n34=te[14];var n41=te[3],n42=te[7],n43=te[11],n44=te[15];//TODO: make this more efficient
//( based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm )
return n41*(+n14*n23*n32-n13*n24*n32-n14*n22*n33+n12*n24*n33+n13*n22*n34-n12*n23*n34)+n42*(+n11*n23*n34-n11*n24*n33+n14*n21*n33-n13*n21*n34+n13*n24*n31-n14*n23*n31)+n43*(+n11*n24*n32-n11*n22*n34-n14*n21*n32+n12*n21*n34+n14*n22*n31-n12*n24*n31)+n44*(-n13*n22*n31-n11*n23*n32+n11*n22*n33+n13*n21*n32-n12*n21*n33+n12*n23*n31);},transpose:function(){var te=this.elements;var tmp;tmp=te[1];te[1]=te[4];te[4]=tmp;tmp=te[2];te[2]=te[8];te[8]=tmp;tmp=te[6];te[6]=te[9];te[9]=tmp;tmp=te[3];te[3]=te[12];te[12]=tmp;tmp=te[7];te[7]=te[13];te[13]=tmp;tmp=te[11];te[11]=te[14];te[14]=tmp;return this;},setPosition:function(v){var te=this.elements;te[12]=v.x;te[13]=v.y;te[14]=v.z;return this;},getInverse:function(m,throwOnDegenerate){// based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm
var te=this.elements,me=m.elements,n11=me[0],n21=me[1],n31=me[2],n41=me[3],n12=me[4],n22=me[5],n32=me[6],n42=me[7],n13=me[8],n23=me[9],n33=me[10],n43=me[11],n14=me[12],n24=me[13],n34=me[14],n44=me[15],t11=n23*n34*n42-n24*n33*n42+n24*n32*n43-n22*n34*n43-n23*n32*n44+n22*n33*n44,t12=n14*n33*n42-n13*n34*n42-n14*n32*n43+n12*n34*n43+n13*n32*n44-n12*n33*n44,t13=n13*n24*n42-n14*n23*n42+n14*n22*n43-n12*n24*n43-n13*n22*n44+n12*n23*n44,t14=n14*n23*n32-n13*n24*n32-n14*n22*n33+n12*n24*n33+n13*n22*n34-n12*n23*n34;var det=n11*t11+n21*t12+n31*t13+n41*t14;if(det===0){var msg="THREE.Matrix4: .getInverse() can't invert matrix, determinant is 0";if(throwOnDegenerate===true){throw new Error(msg);}else{console.warn(msg);}return this.identity();}var detInv=1/det;te[0]=t11*detInv;te[1]=(n24*n33*n41-n23*n34*n41-n24*n31*n43+n21*n34*n43+n23*n31*n44-n21*n33*n44)*detInv;te[2]=(n22*n34*n41-n24*n32*n41+n24*n31*n42-n21*n34*n42-n22*n31*n44+n21*n32*n44)*detInv;te[3]=(n23*n32*n41-n22*n33*n41-n23*n31*n42+n21*n33*n42+n22*n31*n43-n21*n32*n43)*detInv;te[4]=t12*detInv;te[5]=(n13*n34*n41-n14*n33*n41+n14*n31*n43-n11*n34*n43-n13*n31*n44+n11*n33*n44)*detInv;te[6]=(n14*n32*n41-n12*n34*n41-n14*n31*n42+n11*n34*n42+n12*n31*n44-n11*n32*n44)*detInv;te[7]=(n12*n33*n41-n13*n32*n41+n13*n31*n42-n11*n33*n42-n12*n31*n43+n11*n32*n43)*detInv;te[8]=t13*detInv;te[9]=(n14*n23*n41-n13*n24*n41-n14*n21*n43+n11*n24*n43+n13*n21*n44-n11*n23*n44)*detInv;te[10]=(n12*n24*n41-n14*n22*n41+n14*n21*n42-n11*n24*n42-n12*n21*n44+n11*n22*n44)*detInv;te[11]=(n13*n22*n41-n12*n23*n41-n13*n21*n42+n11*n23*n42+n12*n21*n43-n11*n22*n43)*detInv;te[12]=t14*detInv;te[13]=(n13*n24*n31-n14*n23*n31+n14*n21*n33-n11*n24*n33-n13*n21*n34+n11*n23*n34)*detInv;te[14]=(n14*n22*n31-n12*n24*n31-n14*n21*n32+n11*n24*n32+n12*n21*n34-n11*n22*n34)*detInv;te[15]=(n12*n23*n31-n13*n22*n31+n13*n21*n32-n11*n23*n32-n12*n21*n33+n11*n22*n33)*detInv;return this;},scale:function(v){var te=this.elements;var x=v.x,y=v.y,z=v.z;te[0]*=x;te[4]*=y;te[8]*=z;te[1]*=x;te[5]*=y;te[9]*=z;te[2]*=x;te[6]*=y;te[10]*=z;te[3]*=x;te[7]*=y;te[11]*=z;return this;},getMaxScaleOnAxis:function(){var te=this.elements;var scaleXSq=te[0]*te[0]+te[1]*te[1]+te[2]*te[2];var scaleYSq=te[4]*te[4]+te[5]*te[5]+te[6]*te[6];var scaleZSq=te[8]*te[8]+te[9]*te[9]+te[10]*te[10];return Math.sqrt(Math.max(scaleXSq,scaleYSq,scaleZSq));},makeTranslation:function(x,y,z){this.set(1,0,0,x,0,1,0,y,0,0,1,z,0,0,0,1);return this;},makeRotationX:function(theta){var c=Math.cos(theta),s=Math.sin(theta);this.set(1,0,0,0,0,c,-s,0,0,s,c,0,0,0,0,1);return this;},makeRotationY:function(theta){var c=Math.cos(theta),s=Math.sin(theta);this.set(c,0,s,0,0,1,0,0,-s,0,c,0,0,0,0,1);return this;},makeRotationZ:function(theta){var c=Math.cos(theta),s=Math.sin(theta);this.set(c,-s,0,0,s,c,0,0,0,0,1,0,0,0,0,1);return this;},makeRotationAxis:function(axis,angle){// Based on http://www.gamedev.net/reference/articles/article1199.asp
var c=Math.cos(angle);var s=Math.sin(angle);var t=1-c;var x=axis.x,y=axis.y,z=axis.z;var tx=t*x,ty=t*y;this.set(tx*x+c,tx*y-s*z,tx*z+s*y,0,tx*y+s*z,ty*y+c,ty*z-s*x,0,tx*z-s*y,ty*z+s*x,t*z*z+c,0,0,0,0,1);return this;},makeScale:function(x,y,z){this.set(x,0,0,0,0,y,0,0,0,0,z,0,0,0,0,1);return this;},makeShear:function(x,y,z){this.set(1,y,z,0,x,1,z,0,x,y,1,0,0,0,0,1);return this;},compose:function(position,quaternion,scale){this.makeRotationFromQuaternion(quaternion);this.scale(scale);this.setPosition(position);return this;},decompose:function(){var vector=new Vector3();var matrix=new Matrix4();return function decompose(position,quaternion,scale){var te=this.elements;var sx=vector.set(te[0],te[1],te[2]).length();var sy=vector.set(te[4],te[5],te[6]).length();var sz=vector.set(te[8],te[9],te[10]).length();// if determine is negative, we need to invert one scale
var det=this.determinant();if(det<0)sx=-sx;position.x=te[12];position.y=te[13];position.z=te[14];// scale the rotation part
matrix.copy(this);var invSX=1/sx;var invSY=1/sy;var invSZ=1/sz;matrix.elements[0]*=invSX;matrix.elements[1]*=invSX;matrix.elements[2]*=invSX;matrix.elements[4]*=invSY;matrix.elements[5]*=invSY;matrix.elements[6]*=invSY;matrix.elements[8]*=invSZ;matrix.elements[9]*=invSZ;matrix.elements[10]*=invSZ;quaternion.setFromRotationMatrix(matrix);scale.x=sx;scale.y=sy;scale.z=sz;return this;};}(),makePerspective:function(left,right,top,bottom,near,far){if(far===undefined){console.warn('THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.');}var te=this.elements;var x=2*near/(right-left);var y=2*near/(top-bottom);var a=(right+left)/(right-left);var b=(top+bottom)/(top-bottom);var c=-(far+near)/(far-near);var d=-2*far*near/(far-near);te[0]=x;te[4]=0;te[8]=a;te[12]=0;te[1]=0;te[5]=y;te[9]=b;te[13]=0;te[2]=0;te[6]=0;te[10]=c;te[14]=d;te[3]=0;te[7]=0;te[11]=-1;te[15]=0;return this;},makeOrthographic:function(left,right,top,bottom,near,far){var te=this.elements;var w=1.0/(right-left);var h=1.0/(top-bottom);var p=1.0/(far-near);var x=(right+left)*w;var y=(top+bottom)*h;var z=(far+near)*p;te[0]=2*w;te[4]=0;te[8]=0;te[12]=-x;te[1]=0;te[5]=2*h;te[9]=0;te[13]=-y;te[2]=0;te[6]=0;te[10]=-2*p;te[14]=-z;te[3]=0;te[7]=0;te[11]=0;te[15]=1;return this;},equals:function(matrix){var te=this.elements;var me=matrix.elements;for(var i=0;i<16;i++){if(te[i]!==me[i])return false;}return true;},fromArray:function(array,offset){if(offset===undefined)offset=0;for(var i=0;i<16;i++){this.elements[i]=array[i+offset];}return this;},toArray:function(array,offset){if(array===undefined)array=[];if(offset===undefined)offset=0;var te=this.elements;array[offset]=te[0];array[offset+1]=te[1];array[offset+2]=te[2];array[offset+3]=te[3];array[offset+4]=te[4];array[offset+5]=te[5];array[offset+6]=te[6];array[offset+7]=te[7];array[offset+8]=te[8];array[offset+9]=te[9];array[offset+10]=te[10];array[offset+11]=te[11];array[offset+12]=te[12];array[offset+13]=te[13];array[offset+14]=te[14];array[offset+15]=te[15];return array;}});/**
* @author mikael emtinger / http://gomo.se/
* @author alteredq / http://alteredqualia.com/
* @author WestLangley / http://github.com/WestLangley
* @author bhouston / http://clara.io
*/function Quaternion(x,y,z,w){this._x=x||0;this._y=y||0;this._z=z||0;this._w=w!==undefined?w:1;}Object.assign(Quaternion,{slerp:function(qa,qb,qm,t){return qm.copy(qa).slerp(qb,t);},slerpFlat:function(dst,dstOffset,src0,srcOffset0,src1,srcOffset1,t){// fuzz-free, array-based Quaternion SLERP operation
var x0=src0[srcOffset0+0],y0=src0[srcOffset0+1],z0=src0[srcOffset0+2],w0=src0[srcOffset0+3],x1=src1[srcOffset1+0],y1=src1[srcOffset1+1],z1=src1[srcOffset1+2],w1=src1[srcOffset1+3];if(w0!==w1||x0!==x1||y0!==y1||z0!==z1){var s=1-t,cos=x0*x1+y0*y1+z0*z1+w0*w1,dir=cos>=0?1:-1,sqrSin=1-cos*cos;// Skip the Slerp for tiny steps to avoid numeric problems:
if(sqrSin>Number.EPSILON){var sin=Math.sqrt(sqrSin),len=Math.atan2(sin,cos*dir);s=Math.sin(s*len)/sin;t=Math.sin(t*len)/sin;}var tDir=t*dir;x0=x0*s+x1*tDir;y0=y0*s+y1*tDir;z0=z0*s+z1*tDir;w0=w0*s+w1*tDir;// Normalize in case we just did a lerp:
if(s===1-t){var f=1/Math.sqrt(x0*x0+y0*y0+z0*z0+w0*w0);x0*=f;y0*=f;z0*=f;w0*=f;}}dst[dstOffset]=x0;dst[dstOffset+1]=y0;dst[dstOffset+2]=z0;dst[dstOffset+3]=w0;}});Object.defineProperties(Quaternion.prototype,{x:{get:function(){return this._x;},set:function(value){this._x=value;this.onChangeCallback();}},y:{get:function(){return this._y;},set:function(value){this._y=value;this.onChangeCallback();}},z:{get:function(){return this._z;},set:function(value){this._z=value;this.onChangeCallback();}},w:{get:function(){return this._w;},set:function(value){this._w=value;this.onChangeCallback();}}});Object.assign(Quaternion.prototype,{set:function(x,y,z,w){this._x=x;this._y=y;this._z=z;this._w=w;this.onChangeCallback();return this;},clone:function(){return new this.constructor(this._x,this._y,this._z,this._w);},copy:function(quaternion){this._x=quaternion.x;this._y=quaternion.y;this._z=quaternion.z;this._w=quaternion.w;this.onChangeCallback();return this;},setFromEuler:function(euler,update){if(!(euler&&euler.isEuler)){throw new Error('THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.');}var x=euler._x,y=euler._y,z=euler._z,order=euler.order;// http://www.mathworks.com/matlabcentral/fileexchange/
// 20696-function-to-convert-between-dcm-euler-angles-quaternions-and-euler-vectors/
// content/SpinCalc.m
var cos=Math.cos;var sin=Math.sin;var c1=cos(x/2);var c2=cos(y/2);var c3=cos(z/2);var s1=sin(x/2);var s2=sin(y/2);var s3=sin(z/2);if(order==='XYZ'){this._x=s1*c2*c3+c1*s2*s3;this._y=c1*s2*c3-s1*c2*s3;this._z=c1*c2*s3+s1*s2*c3;this._w=c1*c2*c3-s1*s2*s3;}else if(order==='YXZ'){this._x=s1*c2*c3+c1*s2*s3;this._y=c1*s2*c3-s1*c2*s3;this._z=c1*c2*s3-s1*s2*c3;this._w=c1*c2*c3+s1*s2*s3;}else if(order==='ZXY'){this._x=s1*c2*c3-c1*s2*s3;this._y=c1*s2*c3+s1*c2*s3;this._z=c1*c2*s3+s1*s2*c3;this._w=c1*c2*c3-s1*s2*s3;}else if(order==='ZYX'){this._x=s1*c2*c3-c1*s2*s3;this._y=c1*s2*c3+s1*c2*s3;this._z=c1*c2*s3-s1*s2*c3;this._w=c1*c2*c3+s1*s2*s3;}else if(order==='YZX'){this._x=s1*c2*c3+c1*s2*s3;this._y=c1*s2*c3+s1*c2*s3;this._z=c1*c2*s3-s1*s2*c3;this._w=c1*c2*c3-s1*s2*s3;}else if(order==='XZY'){this._x=s1*c2*c3-c1*s2*s3;this._y=c1*s2*c3-s1*c2*s3;this._z=c1*c2*s3+s1*s2*c3;this._w=c1*c2*c3+s1*s2*s3;}if(update!==false)this.onChangeCallback();return this;},setFromAxisAngle:function(axis,angle){// http://www.euclideanspace.com/maths/geometry/rotations/conversions/angleToQuaternion/index.htm
// assumes axis is normalized
var halfAngle=angle/2,s=Math.sin(halfAngle);this._x=axis.x*s;this._y=axis.y*s;this._z=axis.z*s;this._w=Math.cos(halfAngle);this.onChangeCallback();return this;},setFromRotationMatrix:function(m){// http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToQuaternion/index.htm
// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)
var te=m.elements,m11=te[0],m12=te[4],m13=te[8],m21=te[1],m22=te[5],m23=te[9],m31=te[2],m32=te[6],m33=te[10],trace=m11+m22+m33,s;if(trace>0){s=0.5/Math.sqrt(trace+1.0);this._w=0.25/s;this._x=(m32-m23)*s;this._y=(m13-m31)*s;this._z=(m21-m12)*s;}else if(m11>m22&&m11>m33){s=2.0*Math.sqrt(1.0+m11-m22-m33);this._w=(m32-m23)/s;this._x=0.25*s;this._y=(m12+m21)/s;this._z=(m13+m31)/s;}else if(m22>m33){s=2.0*Math.sqrt(1.0+m22-m11-m33);this._w=(m13-m31)/s;this._x=(m12+m21)/s;this._y=0.25*s;this._z=(m23+m32)/s;}else{s=2.0*Math.sqrt(1.0+m33-m11-m22);this._w=(m21-m12)/s;this._x=(m13+m31)/s;this._y=(m23+m32)/s;this._z=0.25*s;}this.onChangeCallback();return this;},setFromUnitVectors:function(){// assumes direction vectors vFrom and vTo are normalized
var v1=new Vector3();var r;var EPS=0.000001;return function setFromUnitVectors(vFrom,vTo){if(v1===undefined)v1=new Vector3();r=vFrom.dot(vTo)+1;if(r<EPS){r=0;if(Math.abs(vFrom.x)>Math.abs(vFrom.z)){v1.set(-vFrom.y,vFrom.x,0);}else{v1.set(0,-vFrom.z,vFrom.y);}}else{v1.crossVectors(vFrom,vTo);}this._x=v1.x;this._y=v1.y;this._z=v1.z;this._w=r;return this.normalize();};}(),inverse:function(){// quaternion is assumed to have unit length
return this.conjugate();},conjugate:function(){this._x*=-1;this._y*=-1;this._z*=-1;this.onChangeCallback();return this;},dot:function(v){return this._x*v._x+this._y*v._y+this._z*v._z+this._w*v._w;},lengthSq:function(){return this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w;},length:function(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w);},normalize:function(){var l=this.length();if(l===0){this._x=0;this._y=0;this._z=0;this._w=1;}else{l=1/l;this._x=this._x*l;this._y=this._y*l;this._z=this._z*l;this._w=this._w*l;}this.onChangeCallback();return this;},multiply:function(q,p){if(p!==undefined){console.warn('THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead.');return this.multiplyQuaternions(q,p);}return this.multiplyQuaternions(this,q);},premultiply:function(q){return this.multiplyQuaternions(q,this);},multiplyQuaternions:function(a,b){// from http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/code/index.htm
var qax=a._x,qay=a._y,qaz=a._z,qaw=a._w;var qbx=b._x,qby=b._y,qbz=b._z,qbw=b._w;this._x=qax*qbw+qaw*qbx+qay*qbz-qaz*qby;this._y=qay*qbw+qaw*qby+qaz*qbx-qax*qbz;this._z=qaz*qbw+qaw*qbz+qax*qby-qay*qbx;this._w=qaw*qbw-qax*qbx-qay*qby-qaz*qbz;this.onChangeCallback();return this;},slerp:function(qb,t){if(t===0)return this;if(t===1)return this.copy(qb);var x=this._x,y=this._y,z=this._z,w=this._w;// http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/slerp/
var cosHalfTheta=w*qb._w+x*qb._x+y*qb._y+z*qb._z;if(cosHalfTheta<0){this._w=-qb._w;this._x=-qb._x;this._y=-qb._y;this._z=-qb._z;cosHalfTheta=-cosHalfTheta;}else{this.copy(qb);}if(cosHalfTheta>=1.0){this._w=w;this._x=x;this._y=y;this._z=z;return this;}var sinHalfTheta=Math.sqrt(1.0-cosHalfTheta*cosHalfTheta);if(Math.abs(sinHalfTheta)<0.001){this._w=0.5*(w+this._w);this._x=0.5*(x+this._x);this._y=0.5*(y+this._y);this._z=0.5*(z+this._z);return this;}var halfTheta=Math.atan2(sinHalfTheta,cosHalfTheta);var ratioA=Math.sin((1-t)*halfTheta)/sinHalfTheta,ratioB=Math.sin(t*halfTheta)/sinHalfTheta;this._w=w*ratioA+this._w*ratioB;this._x=x*ratioA+this._x*ratioB;this._y=y*ratioA+this._y*ratioB;this._z=z*ratioA+this._z*ratioB;this.onChangeCallback();return this;},equals:function(quaternion){return quaternion._x===this._x&&quaternion._y===this._y&&quaternion._z===this._z&&quaternion._w===this._w;},fromArray:function(array,offset){if(offset===undefined)offset=0;this._x=array[offset];this._y=array[offset+1];this._z=array[offset+2];this._w=array[offset+3];this.onChangeCallback();return this;},toArray:function(array,offset){if(array===undefined)array=[];if(offset===undefined)offset=0;array[offset]=this._x;array[offset+1]=this._y;array[offset+2]=this._z;array[offset+3]=this._w;return array;},onChange:function(callback){this.onChangeCallback=callback;return this;},onChangeCallback:function(){}});/**
* @author mrdoob / http://mrdoob.com/
* @author kile / http://kile.stravaganza.org/
* @author philogb / http://blog.thejit.org/
* @author mikael emtinger / http://gomo.se/
* @author egraether / http://egraether.com/
* @author WestLangley / http://github.com/WestLangley
*/function Vector3(x,y,z){this.x=x||0;this.y=y||0;this.z=z||0;}Object.assign(Vector3.prototype,{isVector3:true,set:function(x,y,z){this.x=x;this.y=y;this.z=z;return this;},setScalar:function(scalar){this.x=scalar;this.y=scalar;this.z=scalar;return this;},setX:function(x){this.x=x;return this;},setY:function(y){this.y=y;return this;},setZ:function(z){this.z=z;return this;},setComponent:function(index,value){switch(index){case 0:this.x=value;break;case 1:this.y=value;break;case 2:this.z=value;break;default:throw new Error('index is out of range: '+index);}return this;},getComponent:function(index){switch(index){case 0:return this.x;case 1:return this.y;case 2:return this.z;default:throw new Error('index is out of range: '+index);}},clone:function(){return new this.constructor(this.x,this.y,this.z);},copy:function(v){this.x=v.x;this.y=v.y;this.z=v.z;return this;},add:function(v,w){if(w!==undefined){console.warn('THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead.');return this.addVectors(v,w);}this.x+=v.x;this.y+=v.y;this.z+=v.z;return this;},addScalar:function(s){this.x+=s;this.y+=s;this.z+=s;return this;},addVectors:function(a,b){this.x=a.x+b.x;this.y=a.y+b.y;this.z=a.z+b.z;return this;},addScaledVector:function(v,s){this.x+=v.x*s;this.y+=v.y*s;this.z+=v.z*s;return this;},sub:function(v,w){if(w!==undefined){console.warn('THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.');return this.subVectors(v,w);}this.x-=v.x;this.y-=v.y;this.z-=v.z;return this;},subScalar:function(s){this.x-=s;this.y-=s;this.z-=s;return this;},subVectors:function(a,b){this.x=a.x-b.x;this.y=a.y-b.y;this.z=a.z-b.z;return this;},multiply:function(v,w){if(w!==undefined){console.warn('THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead.');return this.multiplyVectors(v,w);}this.x*=v.x;this.y*=v.y;this.z*=v.z;return this;},multiplyScalar:function(scalar){this.x*=scalar;this.y*=scalar;this.z*=scalar;return this;},multiplyVectors:function(a,b){this.x=a.x*b.x;this.y=a.y*b.y;this.z=a.z*b.z;return this;},applyEuler:function(){var quaternion=new Quaternion();return function applyEuler(euler){if(!(euler&&euler.isEuler)){console.error('THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order.');}return this.applyQuaternion(quaternion.setFromEuler(euler));};}(),applyAxisAngle:function(){var quaternion=new Quaternion();return function applyAxisAngle(axis,angle){return this.applyQuaternion(quaternion.setFromAxisAngle(axis,angle));};}(),applyMatrix3:function(m){var x=this.x,y=this.y,z=this.z;var e=m.elements;this.x=e[0]*x+e[3]*y+e[6]*z;this.y=e[1]*x+e[4]*y+e[7]*z;this.z=e[2]*x+e[5]*y+e[8]*z;return this;},applyMatrix4:function(m){var x=this.x,y=this.y,z=this.z;var e=m.elements;var w=1/(e[3]*x+e[7]*y+e[11]*z+e[15]);this.x=(e[0]*x+e[4]*y+e[8]*z+e[12])*w;this.y=(e[1]*x+e[5]*y+e[9]*z+e[13])*w;this.z=(e[2]*x+e[6]*y+e[10]*z+e[14])*w;return this;},applyQuaternion:function(q){var x=this.x,y=this.y,z=this.z;var qx=q.x,qy=q.y,qz=q.z,qw=q.w;// calculate quat * vector
var ix=qw*x+qy*z-qz*y;var iy=qw*y+qz*x-qx*z;var iz=qw*z+qx*y-qy*x;var iw=-qx*x-qy*y-qz*z;// calculate result * inverse quat
this.x=ix*qw+iw*-qx+iy*-qz-iz*-qy;this.y=iy*qw+iw*-qy+iz*-qx-ix*-qz;this.z=iz*qw+iw*-qz+ix*-qy-iy*-qx;return this;},project:function(){var matrix=new Matrix4();return function project(camera){matrix.multiplyMatrices(camera.projectionMatrix,matrix.getInverse(camera.matrixWorld));return this.applyMatrix4(matrix);};}(),unproject:function(){var matrix=new Matrix4();return function unproject(camera){matrix.multiplyMatrices(camera.matrixWorld,matrix.getInverse(camera.projectionMatrix));return this.applyMatrix4(matrix);};}(),transformDirection:function(m){// input: THREE.Matrix4 affine matrix
// vector interpreted as a direction
var x=this.x,y=this.y,z=this.z;var e=m.elements;this.x=e[0]*x+e[4]*y+e[8]*z;this.y=e[1]*x+e[5]*y+e[9]*z;this.z=e[2]*x+e[6]*y+e[10]*z;return this.normalize();},divide:function(v){this.x/=v.x;this.y/=v.y;this.z/=v.z;return this;},divideScalar:function(scalar){return this.multiplyScalar(1/scalar);},min:function(v){this.x=Math.min(this.x,v.x);this.y=Math.min(this.y,v.y);this.z=Math.min(this.z,v.z);return this;},max:function(v){this.x=Math.max(this.x,v.x);this.y=Math.max(this.y,v.y);this.z=Math.max(this.z,v.z);return this;},clamp:function(min,max){// assumes min < max, componentwise
this.x=Math.max(min.x,Math.min(max.x,this.x));this.y=Math.max(min.y,Math.min(max.y,this.y));this.z=Math.max(min.z,Math.min(max.z,this.z));return this;},clampScalar:function(){var min=new Vector3();var max=new Vector3();return function clampScalar(minVal,maxVal){min.set(minVal,minVal,minVal);max.set(maxVal,maxVal,maxVal);return this.clamp(min,max);};}(),clampLength:function(min,max){var length=this.length();return this.divideScalar(length||1).multiplyScalar(Math.max(min,Math.min(max,length)));},floor:function(){this.x=Math.floor(this.x);this.y=Math.floor(this.y);this.z=Math.floor(this.z);return this;},ceil:function(){this.x=Math.ceil(this.x);this.y=Math.ceil(this.y);this.z=Math.ceil(this.z);return this;},round:function(){this.x=Math.round(this.x);this.y=Math.round(this.y);this.z=Math.round(this.z);return this;},roundToZero:function(){this.x=this.x<0?Math.ceil(this.x):Math.floor(this.x);this.y=this.y<0?Math.ceil(this.y):Math.floor(this.y);this.z=this.z<0?Math.ceil(this.z):Math.floor(this.z);return this;},negate:function(){this.x=-this.x;this.y=-this.y;this.z=-this.z;return this;},dot:function(v){return this.x*v.x+this.y*v.y+this.z*v.z;},// TODO lengthSquared?
lengthSq:function(){return this.x*this.x+this.y*this.y+this.z*this.z;},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z);},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z);},normalize:function(){return this.divideScalar(this.length()||1);},setLength:function(length){return this.normalize().multiplyScalar(length);},lerp:function(v,alpha){this.x+=(v.x-this.x)*alpha;this.y+=(v.y-this.y)*alpha;this.z+=(v.z-this.z)*alpha;return this;},lerpVectors:function(v1,v2,alpha){return this.subVectors(v2,v1).multiplyScalar(alpha).add(v1);},cross:function(v,w){if(w!==undefined){console.warn('THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead.');return this.crossVectors(v,w);}return this.crossVectors(this,v);},crossVectors:function(a,b){var ax=a.x,ay=a.y,az=a.z;var bx=b.x,by=b.y,bz=b.z;this.x=ay*bz-az*by;this.y=az*bx-ax*bz;this.z=ax*by-ay*bx;return this;},projectOnVector:function(vector){var scalar=vector.dot(this)/vector.lengthSq();return this.copy(vector).multiplyScalar(scalar);},projectOnPlane:function(){var v1=new Vector3();return function projectOnPlane(planeNormal){v1.copy(this).projectOnVector(planeNormal);return this.sub(v1);};}(),reflect:function(){// reflect incident vector off plane orthogonal to normal
// normal is assumed to have unit length
var v1=new Vector3();return function reflect(normal){return this.sub(v1.copy(normal).multiplyScalar(2*this.dot(normal)));};}(),angleTo:function(v){var theta=this.dot(v)/Math.sqrt(this.lengthSq()*v.lengthSq());// clamp, to handle numerical problems
return Math.acos(_Math.clamp(theta,-1,1));},distanceTo:function(v){return Math.sqrt(this.distanceToSquared(v));},distanceToSquared:function(v){var dx=this.x-v.x,dy=this.y-v.y,dz=this.z-v.z;return dx*dx+dy*dy+dz*dz;},manhattanDistanceTo:function(v){return Math.abs(this.x-v.x)+Math.abs(this.y-v.y)+Math.abs(this.z-v.z);},setFromSpherical:function(s){var sinPhiRadius=Math.sin(s.phi)*s.radius;this.x=sinPhiRadius*Math.sin(s.theta);this.y=Math.cos(s.phi)*s.radius;this.z=sinPhiRadius*Math.cos(s.theta);return this;},setFromCylindrical:function(c){this.x=c.radius*Math.sin(c.theta);this.y=c.y;this.z=c.radius*Math.cos(c.theta);return this;},setFromMatrixPosition:function(m){var e=m.elements;this.x=e[12];this.y=e[13];this.z=e[14];return this;},setFromMatrixScale:function(m){var sx=this.setFromMatrixColumn(m,0).length();var sy=this.setFromMatrixColumn(m,1).length();var sz=this.setFromMatrixColumn(m,2).length();this.x=sx;this.y=sy;this.z=sz;return this;},setFromMatrixColumn:function(m,index){return this.fromArray(m.elements,index*4);},equals:function(v){return v.x===this.x&&v.y===this.y&&v.z===this.z;},fromArray:function(array,offset){if(offset===undefined)offset=0;this.x=array[offset];this.y=array[offset+1];this.z=array[offset+2];return this;},toArray:function(array,offset){if(array===undefined)array=[];if(offset===undefined)offset=0;array[offset]=this.x;array[offset+1]=this.y;array[offset+2]=this.z;return array;},fromBufferAttribute:function(attribute,index,offset){if(offset!==undefined){console.warn('THREE.Vector3: offset has been removed from .fromBufferAttribute().');}this.x=attribute.getX(index);this.y=attribute.getY(index);this.z=attribute.getZ(index);return this;}});/**
* @author alteredq / http://alteredqualia.com/
* @author WestLangley / http://github.com/WestLangley
* @author bhouston / http://clara.io
* @author tschw
*/function Matrix3(){this.elements=[1,0,0,0,1,0,0,0,1];if(arguments.length>0){console.error('THREE.Matrix3: the constructor no longer reads arguments. use .set() instead.');}}Object.assign(Matrix3.prototype,{isMatrix3:true,set:function(n11,n12,n13,n21,n22,n23,n31,n32,n33){var te=this.elements;te[0]=n11;te[1]=n21;te[2]=n31;te[3]=n12;te[4]=n22;te[5]=n32;te[6]=n13;te[7]=n23;te[8]=n33;return this;},identity:function(){this.set(1,0,0,0,1,0,0,0,1);return this;},clone:function(){return new this.constructor().fromArray(this.elements);},copy:function(m){var te=this.elements;var me=m.elements;te[0]=me[0];te[1]=me[1];te[2]=me[2];te[3]=me[3];te[4]=me[4];te[5]=me[5];te[6]=me[6];te[7]=me[7];te[8]=me[8];return this;},setFromMatrix4:function(m){var me=m.elements;this.set(me[0],me[4],me[8],me[1],me[5],me[9],me[2],me[6],me[10]);return this;},applyToBufferAttribute:function(){var v1=new Vector3();return function applyToBufferAttribute(attribute){for(var i=0,l=attribute.count;i<l;i++){v1.x=attribute.getX(i);v1.y=attribute.getY(i);v1.z=attribute.getZ(i);v1.applyMatrix3(this);attribute.setXYZ(i,v1.x,v1.y,v1.z);}return attribute;};}(),multiply:function(m){return this.multiplyMatrices(this,m);},premultiply:function(m){return this.multiplyMatrices(m,this);},multiplyMatrices:function(a,b){var ae=a.elements;var be=b.elements;var te=this.elements;var a11=ae[0],a12=ae[3],a13=ae[6];var a21=ae[1],a22=ae[4],a23=ae[7];var a31=ae[2],a32=ae[5],a33=ae[8];var b11=be[0],b12=be[3],b13=be[6];var b21=be[1],b22=be[4],b23=be[7];var b31=be[2],b32=be[5],b33=be[8];te[0]=a11*b11+a12*b21+a13*b31;te[3]=a11*b12+a12*b22+a13*b32;te[6]=a11*b13+a12*b23+a13*b33;te[1]=a21*b11+a22*b21+a23*b31;te[4]=a21*b12+a22*b22+a23*b32;te[7]=a21*b13+a22*b23+a23*b33;te[2]=a31*b11+a32*b21+a33*b31;te[5]=a31*b12+a32*b22+a33*b32;te[8]=a31*b13+a32*b23+a33*b33;return this;},multiplyScalar:function(s){var te=this.elements;te[0]*=s;te[3]*=s;te[6]*=s;te[1]*=s;te[4]*=s;te[7]*=s;te[2]*=s;te[5]*=s;te[8]*=s;return this;},determinant:function(){var te=this.elements;var a=te[0],b=te[1],c=te[2],d=te[3],e=te[4],f=te[5],g=te[6],h=te[7],i=te[8];return a*e*i-a*f*h-b*d*i+b*f*g+c*d*h-c*e*g;},getInverse:function(matrix,throwOnDegenerate){if(matrix&&matrix.isMatrix4){console.error("THREE.Matrix3: .getInverse() no longer takes a Matrix4 argument.");}var me=matrix.elements,te=this.elements,n11=me[0],n21=me[1],n31=me[2],n12=me[3],n22=me[4],n32=me[5],n13=me[6],n23=me[7],n33=me[8],t11=n33*n22-n32*n23,t12=n32*n13-n33*n12,t13=n23*n12-n22*n13,det=n11*t11+n21*t12+n31*t13;if(det===0){var msg="THREE.Matrix3: .getInverse() can't invert matrix, determinant is 0";if(throwOnDegenerate===true){throw new Error(msg);}else{console.warn(msg);}return this.identity();}var detInv=1/det;te[0]=t11*detInv;te[1]=(n31*n23-n33*n21)*detInv;te[2]=(n32*n21-n31*n22)*detInv;te[3]=t12*detInv;te[4]=(n33*n11-n31*n13)*detInv;te[5]=(n31*n12-n32*n11)*detInv;te[6]=t13*detInv;te[7]=(n21*n13-n23*n11)*detInv;te[8]=(n22*n11-n21*n12)*detInv;return this;},transpose:function(){var tmp,m=this.elements;tmp=m[1];m[1]=m[3];m[3]=tmp;tmp=m[2];m[2]=m[6];m[6]=tmp;tmp=m[5];m[5]=m[7];m[7]=tmp;return this;},getNormalMatrix:function(matrix4){return this.setFromMatrix4(matrix4).getInverse(this).transpose();},transposeIntoArray:function(r){var m=this.elements;r[0]=m[0];r[1]=m[3];r[2]=m[6];r[3]=m[1];r[4]=m[4];r[5]=m[7];r[6]=m[2];r[7]=m[5];r[8]=m[8];return this;},setUvTransform:function(tx,ty,sx,sy,rotation,cx,cy){var c=Math.cos(rotation);var s=Math.sin(rotation);this.set(sx*c,sx*s,-sx*(c*cx+s*cy)+cx+tx,-sy*s,sy*c,-sy*(-s*cx+c*cy)+cy+ty,0,0,1);},scale:function(sx,sy){var te=this.elements;te[0]*=sx;te[3]*=sx;te[6]*=sx;te[1]*=sy;te[4]*=sy;te[7]*=sy;return this;},rotate:function(theta){var c=Math.cos(theta);var s=Math.sin(theta);var te=this.elements;var a11=te[0],a12=te[3],a13=te[6];var a21=te[1],a22=te[4],a23=te[7];te[0]=c*a11+s*a21;te[3]=c*a12+s*a22;te[6]=c*a13+s*a23;te[1]=-s*a11+c*a21;te[4]=-s*a12+c*a22;te[7]=-s*a13+c*a23;return this;},translate:function(tx,ty){var te=this.elements;te[0]+=tx*te[2];te[3]+=tx*te[5];te[6]+=tx*te[8];te[1]+=ty*te[2];te[4]+=ty*te[5];te[7]+=ty*te[8];return this;},equals:function(matrix){var te=this.elements;var me=matrix.elements;for(var i=0;i<9;i++){if(te[i]!==me[i])return false;}return true;},fromArray:function(array,offset){if(offset===undefined)offset=0;for(var i=0;i<9;i++){this.elements[i]=array[i+offset];}return this;},toArray:function(array,offset){if(array===undefined)array=[];if(offset===undefined)offset=0;var te=this.elements;array[offset]=te[0];array[offset+1]=te[1];array[offset+2]=te[2];array[offset+3]=te[3];array[offset+4]=te[4];array[offset+5]=te[5];array[offset+6]=te[6];array[offset+7]=te[7];array[offset+8]=te[8];return array;}});/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
* @author szimek / https://github.com/szimek/
*/var textureId=0;function Texture(image,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy,encoding){Object.defineProperty(this,'id',{value:textureId++});this.uuid=_Math.generateUUID();this.name='';this.image=image!==undefined?image:Texture.DEFAULT_IMAGE;this.mipmaps=[];this.mapping=mapping!==undefined?mapping:Texture.DEFAULT_MAPPING;this.wrapS=wrapS!==undefined?wrapS:ClampToEdgeWrapping;this.wrapT=wrapT!==undefined?wrapT:ClampToEdgeWrapping;this.magFilter=magFilter!==undefined?magFilter:LinearFilter;this.minFilter=minFilter!==undefined?minFilter:LinearMipMapLinearFilter;this.anisotropy=anisotropy!==undefined?anisotropy:1;this.format=format!==undefined?format:RGBAFormat;this.type=type!==undefined?type:UnsignedByteType;this.offset=new Vector2(0,0);this.repeat=new Vector2(1,1);this.center=new Vector2(0,0);this.rotation=0;this.matrixAutoUpdate=true;this.matrix=new Matrix3();this.generateMipmaps=true;this.premultiplyAlpha=false;this.flipY=true;this.unpackAlignment=4;// valid values: 1, 2, 4, 8 (see http://www.khronos.org/opengles/sdk/docs/man/xhtml/glPixelStorei.xml)
// Values of encoding !== THREE.LinearEncoding only supported on map, envMap and emissiveMap.
//
// Also changing the encoding after already used by a Material will not automatically make the Material
// update. You need to explicitly call Material.needsUpdate to trigger it to recompile.
this.encoding=encoding!==undefined?encoding:LinearEncoding;this.version=0;this.onUpdate=null;}Texture.DEFAULT_IMAGE=undefined;Texture.DEFAULT_MAPPING=UVMapping;Texture.prototype=Object.assign(Object.create(EventDispatcher.prototype),{constructor:Texture,isTexture:true,updateMatrix:function(){this.matrix.setUvTransform(this.offset.x,this.offset.y,this.repeat.x,this.repeat.y,this.rotation,this.center.x,this.center.y);},clone:function(){return new this.constructor().copy(this);},copy:function(source){this.name=source.name;this.image=source.image;this.mipmaps=source.mipmaps.slice(0);this.mapping=source.mapping;this.wrapS=source.wrapS;this.wrapT=source.wrapT;this.magFilter=source.magFilter;this.minFilter=source.minFilter;this.anisotropy=source.anisotropy;this.format=source.format;this.type=source.type;this.offset.copy(source.offset);this.repeat.copy(source.repeat);this.center.copy(source.center);this.rotation=source.rotation;this.matrixAutoUpdate=source.matrixAutoUpdate;this.matrix.copy(source.matrix);this.generateMipmaps=source.generateMipmaps;this.premultiplyAlpha=source.premultiplyAlpha;this.flipY=source.flipY;this.unpackAlignment=source.unpackAlignment;this.encoding=source.encoding;return this;},toJSON:function(meta){var isRootObject=meta===undefined||typeof meta==='string';if(!isRootObject&&meta.textures[this.uuid]!==undefined){return meta.textures[this.uuid];}function getDataURL(image){var canvas;if(image instanceof HTMLCanvasElement){canvas=image;}else{canvas=document.createElementNS('http://www.w3.org/1999/xhtml','canvas');canvas.width=image.width;canvas.height=image.height;var context=canvas.getContext('2d');if(image instanceof ImageData){context.putImageData(image,0,0);}else{context.drawImage(image,0,0,image.width,image.height);}}if(canvas.width>2048||canvas.height>2048){return canvas.toDataURL('image/jpeg',0.6);}else{return canvas.toDataURL('image/png');}}var output={metadata:{version:4.5,type:'Texture',generator:'Texture.toJSON'},uuid:this.uuid,name:this.name,mapping:this.mapping,repeat:[this.repeat.x,this.repeat.y],offset:[this.offset.x,this.offset.y],center:[this.center.x,this.center.y],rotation:this.rotation,wrap:[this.wrapS,this.wrapT],format:this.format,minFilter:this.minFilter,magFilter:this.magFilter,anisotropy:this.anisotropy,flipY:this.flipY};if(this.image!==undefined){// TODO: Move to THREE.Image
var image=this.image;if(image.uuid===undefined){image.uuid=_Math.generateUUID();// UGH
}if(!isRootObject&&meta.images[image.uuid]===undefined){meta.images[image.uuid]={uuid:image.uuid,url:getDataURL(image)};}output.image=image.uuid;}if(!isRootObject){meta.textures[this.uuid]=output;}return output;},dispose:function(){this.dispatchEvent({type:'dispose'});},transformUv:function(uv){if(this.mapping!==UVMapping)return;uv.applyMatrix3(this.matrix);if(uv.x<0||uv.x>1){switch(this.wrapS){case RepeatWrapping:uv.x=uv.x-Math.floor(uv.x);break;case ClampToEdgeWrapping:uv.x=uv.x<0?0:1;break;case MirroredRepeatWrapping:if(Math.abs(Math.floor(uv.x)%2)===1){uv.x=Math.ceil(uv.x)-uv.x;}else{uv.x=uv.x-Math.floor(uv.x);}break;}}if(uv.y<0||uv.y>1){switch(this.wrapT){case RepeatWrapping:uv.y=uv.y-Math.floor(uv.y);break;case ClampToEdgeWrapping:uv.y=uv.y<0?0:1;break;case MirroredRepeatWrapping:if(Math.abs(Math.floor(uv.y)%2)===1){uv.y=Math.ceil(uv.y)-uv.y;}else{uv.y=uv.y-Math.floor(uv.y);}break;}}if(this.flipY){uv.y=1-uv.y;}}});Object.defineProperty(Texture.prototype,"needsUpdate",{set:function(value){if(value===true)this.version++;}});/**
* @author supereggbert / http://www.paulbrunt.co.uk/
* @author philogb / http://blog.thejit.org/
* @author mikael emtinger / http://gomo.se/
* @author egraether / http://egraether.com/
* @author WestLangley / http://github.com/WestLangley
*/function Vector4(x,y,z,w){this.x=x||0;this.y=y||0;this.z=z||0;this.w=w!==undefined?w:1;}Object.assign(Vector4.prototype,{isVector4:true,set:function(x,y,z,w){this.x=x;this.y=y;this.z=z;this.w=w;return this;},setScalar:function(scalar){this.x=scalar;this.y=scalar;this.z=scalar;this.w=scalar;return this;},setX:function(x){this.x=x;return this;},setY:function(y){this.y=y;return this;},setZ:function(z){this.z=z;return this;},setW:function(w){this.w=w;return this;},setComponent:function(index,value){switch(index){case 0:this.x=value;break;case 1:this.y=value;break;case 2:this.z=value;break;case 3:this.w=value;break;default:throw new Error('index is out of range: '+index);}return this;},getComponent:function(index){switch(index){case 0:return this.x;case 1:return this.y;case 2:return this.z;case 3:return this.w;default:throw new Error('index is out of range: '+index);}},clone:function(){return new this.constructor(this.x,this.y,this.z,this.w);},copy:function(v){this.x=v.x;this.y=v.y;this.z=v.z;this.w=v.w!==undefined?v.w:1;return this;},add:function(v,w){if(w!==undefined){console.warn('THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead.');return this.addVectors(v,w);}this.x+=v.x;this.y+=v.y;this.z+=v.z;this.w+=v.w;return this;},addScalar:function(s){this.x+=s;this.y+=s;this.z+=s;this.w+=s;return this;},addVectors:function(a,b){this.x=a.x+b.x;this.y=a.y+b.y;this.z=a.z+b.z;this.w=a.w+b.w;return this;},addScaledVector:function(v,s){this.x+=v.x*s;this.y+=v.y*s;this.z+=v.z*s;this.w+=v.w*s;return this;},sub:function(v,w){if(w!==undefined){console.warn('THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.');return this.subVectors(v,w);}this.x-=v.x;this.y-=v.y;this.z-=v.z;this.w-=v.w;return this;},subScalar:function(s){this.x-=s;this.y-=s;this.z-=s;this.w-=s;return this;},subVectors:function(a,b){this.x=a.x-b.x;this.y=a.y-b.y;this.z=a.z-b.z;this.w=a.w-b.w;return this;},multiplyScalar:function(scalar){this.x*=scalar;this.y*=scalar;this.z*=scalar;this.w*=scalar;return this;},applyMatrix4:function(m){var x=this.x,y=this.y,z=this.z,w=this.w;var e=m.elements;this.x=e[0]*x+e[4]*y+e[8]*z+e[12]*w;this.y=e[1]*x+e[5]*y+e[9]*z+e[13]*w;this.z=e[2]*x+e[6]*y+e[10]*z+e[14]*w;this.w=e[3]*x+e[7]*y+e[11]*z+e[15]*w;return this;},divideScalar:function(scalar){return this.multiplyScalar(1/scalar);},setAxisAngleFromQuaternion:function(q){// http://www.euclideanspace.com/maths/geometry/rotations/conversions/quaternionToAngle/index.htm
// q is assumed to be normalized
this.w=2*Math.acos(q.w);var s=Math.sqrt(1-q.w*q.w);if(s<0.0001){this.x=1;this.y=0;this.z=0;}else{this.x=q.x/s;this.y=q.y/s;this.z=q.z/s;}return this;},setAxisAngleFromRotationMatrix:function(m){// http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToAngle/index.htm
// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)
var angle,x,y,z,// variables for result
epsilon=0.01,// margin to allow for rounding errors
epsilon2=0.1,// margin to distinguish between 0 and 180 degrees
te=m.elements,m11=te[0],m12=te[4],m13=te[8],m21=te[1],m22=te[5],m23=te[9],m31=te[2],m32=te[6],m33=te[10];if(Math.abs(m12-m21)<epsilon&&Math.abs(m13-m31)<epsilon&&Math.abs(m23-m32)<epsilon){// singularity found
// first check for identity matrix which must have +1 for all terms
// in leading diagonal and zero in other terms
if(Math.abs(m12+m21)<epsilon2&&Math.abs(m13+m31)<epsilon2&&Math.abs(m23+m32)<epsilon2&&Math.abs(m11+m22+m33-3)<epsilon2){// this singularity is identity matrix so angle = 0
this.set(1,0,0,0);return this;// zero angle, arbitrary axis
}// otherwise this singularity is angle = 180
angle=Math.PI;var xx=(m11+1)/2;var yy=(m22+1)/2;var zz=(m33+1)/2;var xy=(m12+m21)/4;var xz=(m13+m31)/4;var yz=(m23+m32)/4;if(xx>yy&&xx>zz){// m11 is the largest diagonal term
if(xx<epsilon){x=0;y=0.707106781;z=0.707106781;}else{x=Math.sqrt(xx);y=xy/x;z=xz/x;}}else if(yy>zz){// m22 is the largest diagonal term
if(yy<epsilon){x=0.707106781;y=0;z=0.707106781;}else{y=Math.sqrt(yy);x=xy/y;z=yz/y;}}else{// m33 is the largest diagonal term so base result on this
if(zz<epsilon){x=0.707106781;y=0.707106781;z=0;}else{z=Math.sqrt(zz);x=xz/z;y=yz/z;}}this.set(x,y,z,angle);return this;// return 180 deg rotation
}// as we have reached here there are no singularities so we can handle normally
var s=Math.sqrt((m32-m23)*(m32-m23)+(m13-m31)*(m13-m31)+(m21-m12)*(m21-m12));// used to normalize
if(Math.abs(s)<0.001)s=1;// prevent divide by zero, should not happen if matrix is orthogonal and should be
// caught by singularity test above, but I've left it in just in case
this.x=(m32-m23)/s;this.y=(m13-m31)/s;this.z=(m21-m12)/s;this.w=Math.acos((m11+m22+m33-1)/2);return this;},min:function(v){this.x=Math.min(this.x,v.x);this.y=Math.min(this.y,v.y);this.z=Math.min(this.z,v.z);this.w=Math.min(this.w,v.w);return this;},max:function(v){this.x=Math.max(this.x,v.x);this.y=Math.max(this.y,v.y);this.z=Math.max(this.z,v.z);this.w=Math.max(this.w,v.w);return this;},clamp:function(min,max){// assumes min < max, componentwise
this.x=Math.max(min.x,Math.min(max.x,this.x));this.y=Math.max(min.y,Math.min(max.y,this.y));this.z=Math.max(min.z,Math.min(max.z,this.z));this.w=Math.max(min.w,Math.min(max.w,this.w));return this;},clampScalar:function(){var min,max;return function clampScalar(minVal,maxVal){if(min===undefined){min=new Vector4();max=new Vector4();}min.set(minVal,minVal,minVal,minVal);max.set(maxVal,maxVal,maxVal,maxVal);return this.clamp(min,max);};}(),clampLength:function(min,max){var length=this.length();return this.divideScalar(length||1).multiplyScalar(Math.max(min,Math.min(max,length)));},floor:function(){this.x=Math.floor(this.x);this.y=Math.floor(this.y);this.z=Math.floor(this.z);this.w=Math.floor(this.w);return this;},ceil:function(){this.x=Math.ceil(this.x);this.y=Math.ceil(this.y);this.z=Math.ceil(this.z);this.w=Math.ceil(this.w);return this;},round:function(){this.x=Math.round(this.x);this.y=Math.round(this.y);this.z=Math.round(this.z);this.w=Math.round(this.w);return this;},roundToZero:function(){this.x=this.x<0?Math.ceil(this.x):Math.floor(this.x);this.y=this.y<0?Math.ceil(this.y):Math.floor(this.y);this.z=this.z<0?Math.ceil(this.z):Math.floor(this.z);this.w=this.w<0?Math.ceil(this.w):Math.floor(this.w);return this;},negate:function(){this.x=-this.x;this.y=-this.y;this.z=-this.z;this.w=-this.w;return this;},dot:function(v){return this.x*v.x+this.y*v.y+this.z*v.z+this.w*v.w;},lengthSq:function(){return this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w;},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w);},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)+Math.abs(this.w);},normalize:function(){return this.divideScalar(this.length()||1);},setLength:function(length){return this.normalize().multiplyScalar(length);},lerp:function(v,alpha){this.x+=(v.x-this.x)*alpha;this.y+=(v.y-this.y)*alpha;this.z+=(v.z-this.z)*alpha;this.w+=(v.w-this.w)*alpha;return this;},lerpVectors:function(v1,v2,alpha){return this.subVectors(v2,v1).multiplyScalar(alpha).add(v1);},equals:function(v){return v.x===this.x&&v.y===this.y&&v.z===this.z&&v.w===this.w;},fromArray:function(array,offset){if(offset===undefined)offset=0;this.x=array[offset];this.y=array[offset+1];this.z=array[offset+2];this.w=array[offset+3];return this;},toArray:function(array,offset){if(array===undefined)array=[];if(offset===undefined)offset=0;array[offset]=this.x;array[offset+1]=this.y;array[offset+2]=this.z;array[offset+3]=this.w;return array;},fromBufferAttribute:function(attribute,index,offset){if(offset!==undefined){console.warn('THREE.Vector4: offset has been removed from .fromBufferAttribute().');}this.x=attribute.getX(index);this.y=attribute.getY(index);this.z=attribute.getZ(index);this.w=attribute.getW(index);return this;}});/**
* @author szimek / https://github.com/szimek/
* @author alteredq / http://alteredqualia.com/
* @author Marius Kintel / https://github.com/kintel
*/ /*
In options, we can specify:
* Texture parameters for an auto-generated target texture
* depthBuffer/stencilBuffer: Booleans to indicate if we should generate these buffers
*/function WebGLRenderTarget(width,height,options){this.width=width;this.height=height;this.scissor=new Vector4(0,0,width,height);this.scissorTest=false;this.viewport=new Vector4(0,0,width,height);options=options||{};if(options.minFilter===undefined)options.minFilter=LinearFilter;this.texture=new Texture(undefined,undefined,options.wrapS,options.wrapT,options.magFilter,options.minFilter,options.format,options.type,options.anisotropy,options.encoding);this.depthBuffer=options.depthBuffer!==undefined?options.depthBuffer:true;this.stencilBuffer=options.stencilBuffer!==undefined?options.stencilBuffer:true;this.depthTexture=options.depthTexture!==undefined?options.depthTexture:null;}WebGLRenderTarget.prototype=Object.assign(Object.create(EventDispatcher.prototype),{constructor:WebGLRenderTarget,isWebGLRenderTarget:true,setSize:function(width,height){if(this.width!==width||this.height!==height){this.width=width;this.height=height;this.dispose();}this.viewport.set(0,0,width,height);this.scissor.set(0,0,width,height);},clone:function(){return new this.constructor().copy(this);},copy:function(source){this.width=source.width;this.height=source.height;this.viewport.copy(source.viewport);this.texture=source.texture.clone();this.depthBuffer=source.depthBuffer;this.stencilBuffer=source.stencilBuffer;this.depthTexture=source.depthTexture;return this;},dispose:function(){this.dispatchEvent({type:'dispose'});}});/**
* @author alteredq / http://alteredqualia.com
*/function WebGLRenderTargetCube(width,height,options){WebGLRenderTarget.call(this,width,height,options);this.activeCubeFace=0;// PX 0, NX 1, PY 2, NY 3, PZ 4, NZ 5
this.activeMipMapLevel=0;}WebGLRenderTargetCube.prototype=Object.create(WebGLRenderTarget.prototype);WebGLRenderTargetCube.prototype.constructor=WebGLRenderTargetCube;WebGLRenderTargetCube.prototype.isWebGLRenderTargetCube=true;/**
* @author alteredq / http://alteredqualia.com/
*/function DataTexture(data,width,height,format,type,mapping,wrapS,wrapT,magFilter,minFilter,anisotropy,encoding){Texture.call(this,null,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy,encoding);this.image={data:data,width:width,height:height};this.magFilter=magFilter!==undefined?magFilter:NearestFilter;this.minFilter=minFilter!==undefined?minFilter:NearestFilter;this.generateMipmaps=false;this.flipY=false;this.unpackAlignment=1;}DataTexture.prototype=Object.create(Texture.prototype);DataTexture.prototype.constructor=DataTexture;DataTexture.prototype.isDataTexture=true;/**
* @author bhouston / http://clara.io
* @author WestLangley / http://github.com/WestLangley
*/function Box3(min,max){this.min=min!==undefined?min:new Vector3(+Infinity,+Infinity,+Infinity);this.max=max!==undefined?max:new Vector3(-Infinity,-Infinity,-Infinity);}Object.assign(Box3.prototype,{isBox3:true,set:function(min,max){this.min.copy(min);this.max.copy(max);return this;},setFromArray:function(array){var minX=+Infinity;var minY=+Infinity;var minZ=+Infinity;var maxX=-Infinity;var maxY=-Infinity;var maxZ=-Infinity;for(var i=0,l=array.length;i<l;i+=3){var x=array[i];var y=array[i+1];var z=array[i+2];if(x<minX)minX=x;if(y<minY)minY=y;if(z<minZ)minZ=z;if(x>maxX)maxX=x;if(y>maxY)maxY=y;if(z>maxZ)maxZ=z;}this.min.set(minX,minY,minZ);this.max.set(maxX,maxY,maxZ);return this;},setFromBufferAttribute:function(attribute){var minX=+Infinity;var minY=+Infinity;var minZ=+Infinity;var maxX=-Infinity;var maxY=-Infinity;var maxZ=-Infinity;for(var i=0,l=attribute.count;i<l;i++){var x=attribute.getX(i);var y=attribute.getY(i);var z=attribute.getZ(i);if(x<minX)minX=x;if(y<minY)minY=y;if(z<minZ)minZ=z;if(x>maxX)maxX=x;if(y>maxY)maxY=y;if(z>maxZ)maxZ=z;}this.min.set(minX,minY,minZ);this.max.set(maxX,maxY,maxZ);return this;},setFromPoints:function(points){this.makeEmpty();for(var i=0,il=points.length;i<il;i++){this.expandByPoint(points[i]);}return this;},setFromCenterAndSize:function(){var v1=new Vector3();return function setFromCenterAndSize(center,size){var halfSize=v1.copy(size).multiplyScalar(0.5);this.min.copy(center).sub(halfSize);this.max.copy(center).add(halfSize);return this;};}(),setFromObject:function(object){this.makeEmpty();return this.expandByObject(object);},clone:function(){return new this.constructor().copy(this);},copy:function(box){this.min.copy(box.min);this.max.copy(box.max);return this;},makeEmpty:function(){this.min.x=this.min.y=this.min.z=+Infinity;this.max.x=this.max.y=this.max.z=-Infinity;return this;},isEmpty:function(){// this is a more robust check for empty than ( volume <= 0 ) because volume can get positive with two negative axes
return this.max.x<this.min.x||this.max.y<this.min.y||this.max.z<this.min.z;},getCenter:function(target){if(target===undefined){console.warn('THREE.Box3: .getCenter() target is now required');target=new Vector3();}return this.isEmpty()?target.set(0,0,0):target.addVectors(this.min,this.max).multiplyScalar(0.5);},getSize:function(target){if(target===undefined){console.warn('THREE.Box3: .getSize() target is now required');target=new Vector3();}return this.isEmpty()?target.set(0,0,0):target.subVectors(this.max,this.min);},expandByPoint:function(point){this.min.min(point);this.max.max(point);return this;},expandByVector:function(vector){this.min.sub(vector);this.max.add(vector);return this;},expandByScalar:function(scalar){this.min.addScalar(-scalar);this.max.addScalar(scalar);return this;},expandByObject:function(){// Computes the world-axis-aligned bounding box of an object (including its children),
// accounting for both the object's, and children's, world transforms
var scope,i,l;var v1=new Vector3();function traverse(node){var geometry=node.geometry;if(geometry!==undefined){if(geometry.isGeometry){var vertices=geometry.vertices;for(i=0,l=vertices.length;i<l;i++){v1.copy(vertices[i]);v1.applyMatrix4(node.matrixWorld);scope.expandByPoint(v1);}}else if(geometry.isBufferGeometry){var attribute=geometry.attributes.position;if(attribute!==undefined){for(i=0,l=attribute.count;i<l;i++){v1.fromBufferAttribute(attribute,i).applyMatrix4(node.matrixWorld);scope.expandByPoint(v1);}}}}}return function expandByObject(object){scope=this;object.updateMatrixWorld(true);object.traverse(traverse);return this;};}(),containsPoint:function(point){return point.x<this.min.x||point.x>this.max.x||point.y<this.min.y||point.y>this.max.y||point.z<this.min.z||point.z>this.max.z?false:true;},containsBox:function(box){return this.min.x<=box.min.x&&box.max.x<=this.max.x&&this.min.y<=box.min.y&&box.max.y<=this.max.y&&this.min.z<=box.min.z&&box.max.z<=this.max.z;},getParameter:function(point,target){// This can potentially have a divide by zero if the box
// has a size dimension of 0.
if(target===undefined){console.warn('THREE.Box3: .getParameter() target is now required');target=new Vector3();}return target.set((point.x-this.min.x)/(this.max.x-this.min.x),(point.y-this.min.y)/(this.max.y-this.min.y),(point.z-this.min.z)/(this.max.z-this.min.z));},intersectsBox:function(box){// using 6 splitting planes to rule out intersections.
return box.max.x<this.min.x||box.min.x>this.max.x||box.max.y<this.min.y||box.min.y>this.max.y||box.max.z<this.min.z||box.min.z>this.max.z?false:true;},intersectsSphere:function(){var closestPoint=new Vector3();return function intersectsSphere(sphere){// Find the point on the AABB closest to the sphere center.
this.clampPoint(sphere.center,closestPoint);// If that point is inside the sphere, the AABB and sphere intersect.
return closestPoint.distanceToSquared(sphere.center)<=sphere.radius*sphere.radius;};}(),intersectsPlane:function(plane){// We compute the minimum and maximum dot product values. If those values
// are on the same side (back or front) of the plane, then there is no intersection.
var min,max;if(plane.normal.x>0){min=plane.normal.x*this.min.x;max=plane.normal.x*this.max.x;}else{min=plane.normal.x*this.max.x;max=plane.normal.x*this.min.x;}if(plane.normal.y>0){min+=plane.normal.y*this.min.y;max+=plane.normal.y*this.max.y;}else{min+=plane.normal.y*this.max.y;max+=plane.normal.y*this.min.y;}if(plane.normal.z>0){min+=plane.normal.z*this.min.z;max+=plane.normal.z*this.max.z;}else{min+=plane.normal.z*this.max.z;max+=plane.normal.z*this.min.z;}return min<=plane.constant&&max>=plane.constant;},intersectsTriangle:function(){// triangle centered vertices
var v0=new Vector3();var v1=new Vector3();var v2=new Vector3();// triangle edge vectors
var f0=new Vector3();var f1=new Vector3();var f2=new Vector3();var testAxis=new Vector3();var center=new Vector3();var extents=new Vector3();var triangleNormal=new Vector3();function satForAxes(axes){var i,j;for(i=0,j=axes.length-3;i<=j;i+=3){testAxis.fromArray(axes,i);// project the aabb onto the seperating axis
var r=extents.x*Math.abs(testAxis.x)+extents.y*Math.abs(testAxis.y)+extents.z*Math.abs(testAxis.z);// project all 3 vertices of the triangle onto the seperating axis
var p0=v0.dot(testAxis);var p1=v1.dot(testAxis);var p2=v2.dot(testAxis);// actual test, basically see if either of the most extreme of the triangle points intersects r
if(Math.max(-Math.max(p0,p1,p2),Math.min(p0,p1,p2))>r){// points of the projected triangle are outside the projected half-length of the aabb
// the axis is seperating and we can exit
return false;}}return true;}return function intersectsTriangle(triangle){if(this.isEmpty()){return false;}// compute box center and extents
this.getCenter(center);extents.subVectors(this.max,center);// translate triangle to aabb origin
v0.subVectors(triangle.a,center);v1.subVectors(triangle.b,center);v2.subVectors(triangle.c,center);// compute edge vectors for triangle
f0.subVectors(v1,v0);f1.subVectors(v2,v1);f2.subVectors(v0,v2);// test against axes that are given by cross product combinations of the edges of the triangle and the edges of the aabb
// make an axis testing of each of the 3 sides of the aabb against each of the 3 sides of the triangle = 9 axis of separation
// axis_ij = u_i x f_j (u0, u1, u2 = face normals of aabb = x,y,z axes vectors since aabb is axis aligned)
var axes=[0,-f0.z,f0.y,0,-f1.z,f1.y,0,-f2.z,f2.y,f0.z,0,-f0.x,f1.z,0,-f1.x,f2.z,0,-f2.x,-f0.y,f0.x,0,-f1.y,f1.x,0,-f2.y,f2.x,0];if(!satForAxes(axes)){return false;}// test 3 face normals from the aabb
axes=[1,0,0,0,1,0,0,0,1];if(!satForAxes(axes)){return false;}// finally testing the face normal of the triangle
// use already existing triangle edge vectors here
triangleNormal.crossVectors(f0,f1);axes=[triangleNormal.x,triangleNormal.y,triangleNormal.z];return satForAxes(axes);};}(),clampPoint:function(point,target){if(target===undefined){console.warn('THREE.Box3: .clampPoint() target is now required');target=new Vector3();}return target.copy(point).clamp(this.min,this.max);},distanceToPoint:function(){var v1=new Vector3();return function distanceToPoint(point){var clampedPoint=v1.copy(point).clamp(this.min,this.max);return clampedPoint.sub(point).length();};}(),getBoundingSphere:function(){var v1=new Vector3();return function getBoundingSphere(target){if(target===undefined){console.warn('THREE.Box3: .getBoundingSphere() target is now required');target=new Sphere();}this.getCenter(target.center);target.radius=this.getSize(v1).length()*0.5;return target;};}(),intersect:function(box){this.min.max(box.min);this.max.min(box.max);// ensure that if there is no overlap, the result is fully empty, not slightly empty with non-inf/+inf values that will cause subsequence intersects to erroneously return valid values.
if(this.isEmpty())this.makeEmpty();return this;},union:function(box){this.min.min(box.min);this.max.max(box.max);return this;},applyMatrix4:function(){var points=[new Vector3(),new Vector3(),new Vector3(),new Vector3(),new Vector3(),new Vector3(),new Vector3(),new Vector3()];return function applyMatrix4(matrix){// transform of empty box is an empty box.
if(this.isEmpty())return this;// NOTE: I am using a binary pattern to specify all 2^3 combinations below
points[0].set(this.min.x,this.min.y,this.min.z).applyMatrix4(matrix);// 000
points[1].set(this.min.x,this.min.y,this.max.z).applyMatrix4(matrix);// 001
points[2].set(this.min.x,this.max.y,this.min.z).applyMatrix4(matrix);// 010
points[3].set(this.min.x,this.max.y,this.max.z).applyMatrix4(matrix);// 011
points[4].set(this.max.x,this.min.y,this.min.z).applyMatrix4(matrix);// 100
points[5].set(this.max.x,this.min.y,this.max.z).applyMatrix4(matrix);// 101
points[6].set(this.max.x,this.max.y,this.min.z).applyMatrix4(matrix);// 110
points[7].set(this.max.x,this.max.y,this.max.z).applyMatrix4(matrix);// 111
this.setFromPoints(points);return this;};}(),translate:function(offset){this.min.add(offset);this.max.add(offset);return this;},equals:function(box){return box.min.equals(this.min)&&box.max.equals(this.max);}});/**
* @author bhouston / http://clara.io
* @author mrdoob / http://mrdoob.com/
*/function Sphere(center,radius){this.center=center!==undefined?center:new Vector3();this.radius=radius!==undefined?radius:0;}Object.assign(Sphere.prototype,{set:function(center,radius){this.center.copy(center);this.radius=radius;return this;},setFromPoints:function(){var box=new Box3();return function setFromPoints(points,optionalCenter){var center=this.center;if(optionalCenter!==undefined){center.copy(optionalCenter);}else{box.setFromPoints(points).getCenter(center);}var maxRadiusSq=0;for(var i=0,il=points.length;i<il;i++){maxRadiusSq=Math.max(maxRadiusSq,center.distanceToSquared(points[i]));}this.radius=Math.sqrt(maxRadiusSq);return this;};}(),clone:function(){return new this.constructor().copy(this);},copy:function(sphere){this.center.copy(sphere.center);this.radius=sphere.radius;return this;},empty:function(){return this.radius<=0;},containsPoint:function(point){return point.distanceToSquared(this.center)<=this.radius*this.radius;},distanceToPoint:function(point){return point.distanceTo(this.center)-this.radius;},intersectsSphere:function(sphere){var radiusSum=this.radius+sphere.radius;return sphere.center.distanceToSquared(this.center)<=radiusSum*radiusSum;},intersectsBox:function(box){return box.intersectsSphere(this);},intersectsPlane:function(plane){return Math.abs(plane.distanceToPoint(this.center))<=this.radius;},clampPoint:function(point,target){var deltaLengthSq=this.center.distanceToSquared(point);if(target===undefined){console.warn('THREE.Sphere: .clampPoint() target is now required');target=new Vector3();}target.copy(point);if(deltaLengthSq>this.radius*this.radius){target.sub(this.center).normalize();target.multiplyScalar(this.radius).add(this.center);}return target;},getBoundingBox:function(target){if(target===undefined){console.warn('THREE.Sphere: .getBoundingBox() target is now required');target=new Box3();}target.set(this.center,this.center);target.expandByScalar(this.radius);return target;},applyMatrix4:function(matrix){this.center.applyMatrix4(matrix);this.radius=this.radius*matrix.getMaxScaleOnAxis();return this;},translate:function(offset){this.center.add(offset);return this;},equals:function(sphere){return sphere.center.equals(this.center)&&sphere.radius===this.radius;}});/**
* @author bhouston / http://clara.io
*/function Plane(normal,constant){// normal is assumed to be normalized
this.normal=normal!==undefined?normal:new Vector3(1,0,0);this.constant=constant!==undefined?constant:0;}Object.assign(Plane.prototype,{set:function(normal,constant){this.normal.copy(normal);this.constant=constant;return this;},setComponents:function(x,y,z,w){this.normal.set(x,y,z);this.constant=w;return this;},setFromNormalAndCoplanarPoint:function(normal,point){this.normal.copy(normal);this.constant=-point.dot(this.normal);return this;},setFromCoplanarPoints:function(){var v1=new Vector3();var v2=new Vector3();return function setFromCoplanarPoints(a,b,c){var normal=v1.subVectors(c,b).cross(v2.subVectors(a,b)).normalize();// Q: should an error be thrown if normal is zero (e.g. degenerate plane)?
this.setFromNormalAndCoplanarPoint(normal,a);return this;};}(),clone:function(){return new this.constructor().copy(this);},copy:function(plane){this.normal.copy(plane.normal);this.constant=plane.constant;return this;},normalize:function(){// Note: will lead to a divide by zero if the plane is invalid.
var inverseNormalLength=1.0/this.normal.length();this.normal.multiplyScalar(inverseNormalLength);this.constant*=inverseNormalLength;return this;},negate:function(){this.constant*=-1;this.normal.negate();return this;},distanceToPoint:function(point){return this.normal.dot(point)+this.constant;},distanceToSphere:function(sphere){return this.distanceToPoint(sphere.center)-sphere.radius;},projectPoint:function(point,target){if(target===undefined){console.warn('THREE.Plane: .projectPoint() target is now required');target=new Vector3();}return target.copy(this.normal).multiplyScalar(-this.distanceToPoint(point)).add(point);},intersectLine:function(){var v1=new Vector3();return function intersectLine(line,target){if(target===undefined){console.warn('THREE.Plane: .intersectLine() target is now required');target=new Vector3();}var direction=line.delta(v1);var denominator=this.normal.dot(direction);if(denominator===0){// line is coplanar, return origin
if(this.distanceToPoint(line.start)===0){return target.copy(line.start);}// Unsure if this is the correct method to handle this case.
return undefined;}var t=-(line.start.dot(this.normal)+this.constant)/denominator;if(t<0||t>1){return undefined;}return target.copy(direction).multiplyScalar(t).add(line.start);};}(),intersectsLine:function(line){// Note: this tests if a line intersects the plane, not whether it (or its end-points) are coplanar with it.
var startSign=this.distanceToPoint(line.start);var endSign=this.distanceToPoint(line.end);return startSign<0&&endSign>0||endSign<0&&startSign>0;},intersectsBox:function(box){return box.intersectsPlane(this);},intersectsSphere:function(sphere){return sphere.intersectsPlane(this);},coplanarPoint:function(target){if(target===undefined){console.warn('THREE.Plane: .coplanarPoint() target is now required');target=new Vector3();}return target.copy(this.normal).multiplyScalar(-this.constant);},applyMatrix4:function(){var v1=new Vector3();var m1=new Matrix3();return function applyMatrix4(matrix,optionalNormalMatrix){var normalMatrix=optionalNormalMatrix||m1.getNormalMatrix(matrix);var referencePoint=this.coplanarPoint(v1).applyMatrix4(matrix);var normal=this.normal.applyMatrix3(normalMatrix).normalize();this.constant=-referencePoint.dot(normal);return this;};}(),translate:function(offset){this.constant-=offset.dot(this.normal);return this;},equals:function(plane){return plane.normal.equals(this.normal)&&plane.constant===this.constant;}});/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
* @author bhouston / http://clara.io
*/function Frustum(p0,p1,p2,p3,p4,p5){this.planes=[p0!==undefined?p0:new Plane(),p1!==undefined?p1:new Plane(),p2!==undefined?p2:new Plane(),p3!==undefined?p3:new Plane(),p4!==undefined?p4:new Plane(),p5!==undefined?p5:new Plane()];}Object.assign(Frustum.prototype,{set:function(p0,p1,p2,p3,p4,p5){var planes=this.planes;planes[0].copy(p0);planes[1].copy(p1);planes[2].copy(p2);planes[3].copy(p3);planes[4].copy(p4);planes[5].copy(p5);return this;},clone:function(){return new this.constructor().copy(this);},copy:function(frustum){var planes=this.planes;for(var i=0;i<6;i++){planes[i].copy(frustum.planes[i]);}return this;},setFromMatrix:function(m){var planes=this.planes;var me=m.elements;var me0=me[0],me1=me[1],me2=me[2],me3=me[3];var me4=me[4],me5=me[5],me6=me[6],me7=me[7];var me8=me[8],me9=me[9],me10=me[10],me11=me[11];var me12=me[12],me13=me[13],me14=me[14],me15=me[15];planes[0].setComponents(me3-me0,me7-me4,me11-me8,me15-me12).normalize();planes[1].setComponents(me3+me0,me7+me4,me11+me8,me15+me12).normalize();planes[2].setComponents(me3+me1,me7+me5,me11+me9,me15+me13).normalize();planes[3].setComponents(me3-me1,me7-me5,me11-me9,me15-me13).normalize();planes[4].setComponents(me3-me2,me7-me6,me11-me10,me15-me14).normalize();planes[5].setComponents(me3+me2,me7+me6,me11+me10,me15+me14).normalize();return this;},intersectsObject:function(){var sphere=new Sphere();return function intersectsObject(object){var geometry=object.geometry;if(geometry.boundingSphere===null)geometry.computeBoundingSphere();sphere.copy(geometry.boundingSphere).applyMatrix4(object.matrixWorld);return this.intersectsSphere(sphere);};}(),intersectsSprite:function(){var sphere=new Sphere();return function intersectsSprite(sprite){sphere.center.set(0,0,0);sphere.radius=0.7071067811865476;sphere.applyMatrix4(sprite.matrixWorld);return this.intersectsSphere(sphere);};}(),intersectsSphere:function(sphere){var planes=this.planes;var center=sphere.center;var negRadius=-sphere.radius;for(var i=0;i<6;i++){var distance=planes[i].distanceToPoint(center);if(distance<negRadius){return false;}}return true;},intersectsBox:function(){var p1=new Vector3(),p2=new Vector3();return function intersectsBox(box){var planes=this.planes;for(var i=0;i<6;i++){var plane=planes[i];p1.x=plane.normal.x>0?box.min.x:box.max.x;p2.x=plane.normal.x>0?box.max.x:box.min.x;p1.y=plane.normal.y>0?box.min.y:box.max.y;p2.y=plane.normal.y>0?box.max.y:box.min.y;p1.z=plane.normal.z>0?box.min.z:box.max.z;p2.z=plane.normal.z>0?box.max.z:box.min.z;var d1=plane.distanceToPoint(p1);var d2=plane.distanceToPoint(p2);// if both outside plane, no intersection
if(d1<0&&d2<0){return false;}}return true;};}(),containsPoint:function(point){var planes=this.planes;for(var i=0;i<6;i++){if(planes[i].distanceToPoint(point)<0){return false;}}return true;}});var alphamap_fragment="#ifdef USE_ALPHAMAP\n\tdiffuseColor.a *= texture2D( alphaMap, vUv ).g;\n#endif\n";var alphamap_pars_fragment="#ifdef USE_ALPHAMAP\n\tuniform sampler2D alphaMap;\n#endif\n";var alphatest_fragment="#ifdef ALPHATEST\n\tif ( diffuseColor.a < ALPHATEST ) discard;\n#endif\n";var aomap_fragment="#ifdef USE_AOMAP\n\tfloat ambientOcclusion = ( texture2D( aoMap, vUv2 ).r - 1.0 ) * aoMapIntensity + 1.0;\n\treflectedLight.indirectDiffuse *= ambientOcclusion;\n\t#if defined( USE_ENVMAP ) && defined( PHYSICAL )\n\t\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\n\t\treflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.specularRoughness );\n\t#endif\n#endif\n";var aomap_pars_fragment="#ifdef USE_AOMAP\n\tuniform sampler2D aoMap;\n\tuniform float aoMapIntensity;\n#endif";var begin_vertex="\nvec3 transformed = vec3( position );\n";var beginnormal_vertex="\nvec3 objectNormal = vec3( normal );\n";var bsdfs="float punctualLightIntensityToIrradianceFactor( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) {\n\tif( decayExponent > 0.0 ) {\n#if defined ( PHYSICALLY_CORRECT_LIGHTS )\n\t\tfloat distanceFalloff = 1.0 / max( pow( lightDistance, decayExponent ), 0.01 );\n\t\tfloat maxDistanceCutoffFactor = pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) );\n\t\treturn distanceFalloff * maxDistanceCutoffFactor;\n#else\n\t\treturn pow( saturate( -lightDistance / cutoffDistance + 1.0 ), decayExponent );\n#endif\n\t}\n\treturn 1.0;\n}\nvec3 BRDF_Diffuse_Lambert( const in vec3 diffuseColor ) {\n\treturn RECIPROCAL_PI * diffuseColor;\n}\nvec3 F_Schlick( const in vec3 specularColor, const in float dotLH ) {\n\tfloat fresnel = exp2( ( -5.55473 * dotLH - 6.98316 ) * dotLH );\n\treturn ( 1.0 - specularColor ) * fresnel + specularColor;\n}\nfloat G_GGX_Smith( const in float alpha, const in float dotNL, const in float dotNV ) {\n\tfloat a2 = pow2( alpha );\n\tfloat gl = dotNL + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\n\tfloat gv = dotNV + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\n\treturn 1.0 / ( gl * gv );\n}\nfloat G_GGX_SmithCorrelated( const in float alpha, const in float dotNL, const in float dotNV ) {\n\tfloat a2 = pow2( alpha );\n\tfloat gv = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\n\tfloat gl = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\n\treturn 0.5 / max( gv + gl, EPSILON );\n}\nfloat D_GGX( const in float alpha, const in float dotNH ) {\n\tfloat a2 = pow2( alpha );\n\tfloat denom = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0;\n\treturn RECIPROCAL_PI * a2 / pow2( denom );\n}\nvec3 BRDF_Specular_GGX( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float roughness ) {\n\tfloat alpha = pow2( roughness );\n\tvec3 halfDir = normalize( incidentLight.direction + geometry.viewDir );\n\tfloat dotNL = saturate( dot( geometry.normal, incidentLight.direction ) );\n\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\n\tfloat dotNH = saturate( dot( geometry.normal, halfDir ) );\n\tfloat dotLH = saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F = F_Schlick( specularColor, dotLH );\n\tfloat G = G_GGX_SmithCorrelated( alpha, dotNL, dotNV );\n\tfloat D = D_GGX( alpha, dotNH );\n\treturn F * ( G * D );\n}\nvec2 LTC_Uv( const in vec3 N, const in vec3 V, const in float roughness ) {\n\tconst float LUT_SIZE = 64.0;\n\tconst float LUT_SCALE = ( LUT_SIZE - 1.0 ) / LUT_SIZE;\n\tconst float LUT_BIAS = 0.5 / LUT_SIZE;\n\tfloat dotNV = saturate( dot( N, V ) );\n\tvec2 uv = vec2( roughness, sqrt( 1.0 - dotNV ) );\n\tuv = uv * LUT_SCALE + LUT_BIAS;\n\treturn uv;\n}\nfloat LTC_ClippedSphereFormFactor( const in vec3 f ) {\n\tfloat l = length( f );\n\treturn max( ( l * l + f.z ) / ( l + 1.0 ), 0.0 );\n}\nvec3 LTC_EdgeVectorFormFactor( const in vec3 v1, const in vec3 v2 ) {\n\tfloat x = dot( v1, v2 );\n\tfloat y = abs( x );\n\tfloat a = 0.8543985 + ( 0.4965155 + 0.0145206 * y ) * y;\n\tfloat b = 3.4175940 + ( 4.1616724 + y ) * y;\n\tfloat v = a / b;\n\tfloat theta_sintheta = ( x > 0.0 ) ? v : 0.5 * inversesqrt( max( 1.0 - x * x, 1e-7 ) ) - v;\n\treturn cross( v1, v2 ) * theta_sintheta;\n}\nvec3 LTC_Evaluate( const in vec3 N, const in vec3 V, const in vec3 P, const in mat3 mInv, const in vec3 rectCoords[ 4 ] ) {\n\tvec3 v1 = rectCoords[ 1 ] - rectCoords[ 0 ];\n\tvec3 v2 = rectCoords[ 3 ] - rectCoords[ 0 ];\n\tvec3 lightNormal = cross( v1, v2 );\n\tif( dot( lightNormal, P - rectCoords[ 0 ] ) < 0.0 ) return vec3( 0.0 );\n\tvec3 T1, T2;\n\tT1 = normalize( V - N * dot( V, N ) );\n\tT2 = - cross( N, T1 );\n\tmat3 mat = mInv * transposeMat3( mat3( T1, T2, N ) );\n\tvec3 coords[ 4 ];\n\tcoords[ 0 ] = mat * ( rectCoords[ 0 ] - P );\n\tcoords[ 1 ] = mat * ( rectCoords[ 1 ] - P );\n\tcoords[ 2 ] = mat * ( rectCoords[ 2 ] - P );\n\tcoords[ 3 ] = mat * ( rectCoords[ 3 ] - P );\n\tcoords[ 0 ] = normalize( coords[ 0 ] );\n\tcoords[ 1 ] = normalize( coords[ 1 ] );\n\tcoords[ 2 ] = normalize( coords[ 2 ] );\n\tcoords[ 3 ] = normalize( coords[ 3 ] );\n\tvec3 vectorFormFactor = vec3( 0.0 );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 0 ], coords[ 1 ] );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 1 ], coords[ 2 ] );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 2 ], coords[ 3 ] );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 3 ], coords[ 0 ] );\n\tfloat result = LTC_ClippedSphereFormFactor( vectorFormFactor );\n\treturn vec3( result );\n}\nvec3 BRDF_Specular_GGX_Environment( const in GeometricContext geometry, const in vec3 specularColor, const in float roughness ) {\n\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\n\tconst vec4 c0 = vec4( - 1, - 0.0275, - 0.572, 0.022 );\n\tconst vec4 c1 = vec4( 1, 0.0425, 1.04, - 0.04 );\n\tvec4 r = roughness * c0 + c1;\n\tfloat a004 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\n\tvec2 AB = vec2( -1.04, 1.04 ) * a004 + r.zw;\n\treturn specularColor * AB.x + AB.y;\n}\nfloat G_BlinnPhong_Implicit( ) {\n\treturn 0.25;\n}\nfloat D_BlinnPhong( const in float shininess, const in float dotNH ) {\n\treturn RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow( dotNH, shininess );\n}\nvec3 BRDF_Specular_BlinnPhong( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float shininess ) {\n\tvec3 halfDir = normalize( incidentLight.direction + geometry.viewDir );\n\tfloat dotNH = saturate( dot( geometry.normal, halfDir ) );\n\tfloat dotLH = saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F = F_Schlick( specularColor, dotLH );\n\tfloat G = G_BlinnPhong_Implicit( );\n\tfloat D = D_BlinnPhong( shininess, dotNH );\n\treturn F * ( G * D );\n}\nfloat GGXRoughnessToBlinnExponent( const in float ggxRoughness ) {\n\treturn ( 2.0 / pow2( ggxRoughness + 0.0001 ) - 2.0 );\n}\nfloat BlinnExponentToGGXRoughness( const in float blinnExponent ) {\n\treturn sqrt( 2.0 / ( blinnExponent + 2.0 ) );\n}\n";var bumpmap_pars_fragment="#ifdef USE_BUMPMAP\n\tuniform sampler2D bumpMap;\n\tuniform float bumpScale;\n\tvec2 dHdxy_fwd() {\n\t\tvec2 dSTdx = dFdx( vUv );\n\t\tvec2 dSTdy = dFdy( vUv );\n\t\tfloat Hll = bumpScale * texture2D( bumpMap, vUv ).x;\n\t\tfloat dBx = bumpScale * texture2D( bumpMap, vUv + dSTdx ).x - Hll;\n\t\tfloat dBy = bumpScale * texture2D( bumpMap, vUv + dSTdy ).x - Hll;\n\t\treturn vec2( dBx, dBy );\n\t}\n\tvec3 perturbNormalArb( vec3 surf_pos, vec3 surf_norm, vec2 dHdxy ) {\n\t\tvec3 vSigmaX = vec3( dFdx( surf_pos.x ), dFdx( surf_pos.y ), dFdx( surf_pos.z ) );\n\t\tvec3 vSigmaY = vec3( dFdy( surf_pos.x ), dFdy( surf_pos.y ), dFdy( surf_pos.z ) );\n\t\tvec3 vN = surf_norm;\n\t\tvec3 R1 = cross( vSigmaY, vN );\n\t\tvec3 R2 = cross( vN, vSigmaX );\n\t\tfloat fDet = dot( vSigmaX, R1 );\n\t\tvec3 vGrad = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\n\t\treturn normalize( abs( fDet ) * surf_norm - vGrad );\n\t}\n#endif\n";var clipping_planes_fragment="#if NUM_CLIPPING_PLANES > 0\n\tvec4 plane;\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < UNION_CLIPPING_PLANES; i ++ ) {\n\t\tplane = clippingPlanes[ i ];\n\t\tif ( dot( vViewPosition, plane.xyz ) > plane.w ) discard;\n\t}\n\t#if UNION_CLIPPING_PLANES < NUM_CLIPPING_PLANES\n\t\tbool clipped = true;\n\t\t#pragma unroll_loop\n\t\tfor ( int i = UNION_CLIPPING_PLANES; i < NUM_CLIPPING_PLANES; i ++ ) {\n\t\t\tplane = clippingPlanes[ i ];\n\t\t\tclipped = ( dot( vViewPosition, plane.xyz ) > plane.w ) && clipped;\n\t\t}\n\t\tif ( clipped ) discard;\n\t#endif\n#endif\n";var clipping_planes_pars_fragment="#if NUM_CLIPPING_PLANES > 0\n\t#if ! defined( PHYSICAL ) && ! defined( PHONG )\n\t\tvarying vec3 vViewPosition;\n\t#endif\n\tuniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ];\n#endif\n";var clipping_planes_pars_vertex="#if NUM_CLIPPING_PLANES > 0 && ! defined( PHYSICAL ) && ! defined( PHONG )\n\tvarying vec3 vViewPosition;\n#endif\n";var clipping_planes_vertex="#if NUM_CLIPPING_PLANES > 0 && ! defined( PHYSICAL ) && ! defined( PHONG )\n\tvViewPosition = - mvPosition.xyz;\n#endif\n";var color_fragment="#ifdef USE_COLOR\n\tdiffuseColor.rgb *= vColor;\n#endif";var color_pars_fragment="#ifdef USE_COLOR\n\tvarying vec3 vColor;\n#endif\n";var color_pars_vertex="#ifdef USE_COLOR\n\tvarying vec3 vColor;\n#endif";var color_vertex="#ifdef USE_COLOR\n\tvColor.xyz = color.xyz;\n#endif";var common="#define PI 3.14159265359\n#define PI2 6.28318530718\n#define PI_HALF 1.5707963267949\n#define RECIPROCAL_PI 0.31830988618\n#define RECIPROCAL_PI2 0.15915494\n#define LOG2 1.442695\n#define EPSILON 1e-6\n#define saturate(a) clamp( a, 0.0, 1.0 )\n#define whiteCompliment(a) ( 1.0 - saturate( a ) )\nfloat pow2( const in float x ) { return x*x; }\nfloat pow3( const in float x ) { return x*x*x; }\nfloat pow4( const in float x ) { float x2 = x*x; return x2*x2; }\nfloat average( const in vec3 color ) { return dot( color, vec3( 0.3333 ) ); }\nhighp float rand( const in vec2 uv ) {\n\tconst highp float a = 12.9898, b = 78.233, c = 43758.5453;\n\thighp float dt = dot( uv.xy, vec2( a,b ) ), sn = mod( dt, PI );\n\treturn fract(sin(sn) * c);\n}\nstruct IncidentLight {\n\tvec3 color;\n\tvec3 direction;\n\tbool visible;\n};\nstruct ReflectedLight {\n\tvec3 directDiffuse;\n\tvec3 directSpecular;\n\tvec3 indirectDiffuse;\n\tvec3 indirectSpecular;\n};\nstruct GeometricContext {\n\tvec3 position;\n\tvec3 normal;\n\tvec3 viewDir;\n};\nvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\n}\nvec3 inverseTransformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( vec4( dir, 0.0 ) * matrix ).xyz );\n}\nvec3 projectOnPlane(in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\tfloat distance = dot( planeNormal, point - pointOnPlane );\n\treturn - distance * planeNormal + point;\n}\nfloat sideOfPlane( in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn sign( dot( point - pointOnPlane, planeNormal ) );\n}\nvec3 linePlaneIntersect( in vec3 pointOnLine, in vec3 lineDirection, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn lineDirection * ( dot( planeNormal, pointOnPlane - pointOnLine ) / dot( planeNormal, lineDirection ) ) + pointOnLine;\n}\nmat3 transposeMat3( const in mat3 m ) {\n\tmat3 tmp;\n\ttmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\n\ttmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\n\ttmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\n\treturn tmp;\n}\nfloat linearToRelativeLuminance( const in vec3 color ) {\n\tvec3 weights = vec3( 0.2126, 0.7152, 0.0722 );\n\treturn dot( weights, color.rgb );\n}\n";var cube_uv_reflection_fragment="#ifdef ENVMAP_TYPE_CUBE_UV\n#define cubeUV_textureSize (1024.0)\nint getFaceFromDirection(vec3 direction) {\n\tvec3 absDirection = abs(direction);\n\tint face = -1;\n\tif( absDirection.x > absDirection.z ) {\n\t\tif(absDirection.x > absDirection.y )\n\t\t\tface = direction.x > 0.0 ? 0 : 3;\n\t\telse\n\t\t\tface = direction.y > 0.0 ? 1 : 4;\n\t}\n\telse {\n\t\tif(absDirection.z > absDirection.y )\n\t\t\tface = direction.z > 0.0 ? 2 : 5;\n\t\telse\n\t\t\tface = direction.y > 0.0 ? 1 : 4;\n\t}\n\treturn face;\n}\n#define cubeUV_maxLods1 (log2(cubeUV_textureSize*0.25) - 1.0)\n#define cubeUV_rangeClamp (exp2((6.0 - 1.0) * 2.0))\nvec2 MipLevelInfo( vec3 vec, float roughnessLevel, float roughness ) {\n\tfloat scale = exp2(cubeUV_maxLods1 - roughnessLevel);\n\tfloat dxRoughness = dFdx(roughness);\n\tfloat dyRoughness = dFdy(roughness);\n\tvec3 dx = dFdx( vec * scale * dxRoughness );\n\tvec3 dy = dFdy( vec * scale * dyRoughness );\n\tfloat d = max( dot( dx, dx ), dot( dy, dy ) );\n\td = clamp(d, 1.0, cubeUV_rangeClamp);\n\tfloat mipLevel = 0.5 * log2(d);\n\treturn vec2(floor(mipLevel), fract(mipLevel));\n}\n#define cubeUV_maxLods2 (log2(cubeUV_textureSize*0.25) - 2.0)\n#define cubeUV_rcpTextureSize (1.0 / cubeUV_textureSize)\nvec2 getCubeUV(vec3 direction, float roughnessLevel, float mipLevel) {\n\tmipLevel = roughnessLevel > cubeUV_maxLods2 - 3.0 ? 0.0 : mipLevel;\n\tfloat a = 16.0 * cubeUV_rcpTextureSize;\n\tvec2 exp2_packed = exp2( vec2( roughnessLevel, mipLevel ) );\n\tvec2 rcp_exp2_packed = vec2( 1.0 ) / exp2_packed;\n\tfloat powScale = exp2_packed.x * exp2_packed.y;\n\tfloat scale = rcp_exp2_packed.x * rcp_exp2_packed.y * 0.25;\n\tfloat mipOffset = 0.75*(1.0 - rcp_exp2_packed.y) * rcp_exp2_packed.x;\n\tbool bRes = mipLevel == 0.0;\n\tscale = bRes && (scale < a) ? a : scale;\n\tvec3 r;\n\tvec2 offset;\n\tint face = getFaceFromDirection(direction);\n\tfloat rcpPowScale = 1.0 / powScale;\n\tif( face == 0) {\n\t\tr = vec3(direction.x, -direction.z, direction.y);\n\t\toffset = vec2(0.0+mipOffset,0.75 * rcpPowScale);\n\t\toffset.y = bRes && (offset.y < 2.0*a) ? a : offset.y;\n\t}\n\telse if( face == 1) {\n\t\tr = vec3(direction.y, direction.x, direction.z);\n\t\toffset = vec2(scale+mipOffset, 0.75 * rcpPowScale);\n\t\toffset.y = bRes && (offset.y < 2.0*a) ? a : offset.y;\n\t}\n\telse if( face == 2) {\n\t\tr = vec3(direction.z, direction.x, direction.y);\n\t\toffset = vec2(2.0*scale+mipOffset, 0.75 * rcpPowScale);\n\t\toffset.y = bRes && (offset.y < 2.0*a) ? a : offset.y;\n\t}\n\telse if( face == 3) {\n\t\tr = vec3(direction.x, direction.z, direction.y);\n\t\toffset = vec2(0.0+mipOffset,0.5 * rcpPowScale);\n\t\toffset.y = bRes && (offset.y < 2.0*a) ? 0.0 : offset.y;\n\t}\n\telse if( face == 4) {\n\t\tr = vec3(direction.y, direction.x, -direction.z);\n\t\toffset = vec2(scale+mipOffset, 0.5 * rcpPowScale);\n\t\toffset.y = bRes && (offset.y < 2.0*a) ? 0.0 : offset.y;\n\t}\n\telse {\n\t\tr = vec3(direction.z, -direction.x, direction.y);\n\t\toffset = vec2(2.0*scale+mipOffset, 0.5 * rcpPowScale);\n\t\toffset.y = bRes && (offset.y < 2.0*a) ? 0.0 : offset.y;\n\t}\n\tr = normalize(r);\n\tfloat texelOffset = 0.5 * cubeUV_rcpTextureSize;\n\tvec2 s = ( r.yz / abs( r.x ) + vec2( 1.0 ) ) * 0.5;\n\tvec2 base = offset + vec2( texelOffset );\n\treturn base + s * ( scale - 2.0 * texelOffset );\n}\n#define cubeUV_maxLods3 (log2(cubeUV_textureSize*0.25) - 3.0)\nvec4 textureCubeUV(vec3 reflectedDirection, float roughness ) {\n\tfloat roughnessVal = roughness* cubeUV_maxLods3;\n\tfloat r1 = floor(roughnessVal);\n\tfloat r2 = r1 + 1.0;\n\tfloat t = fract(roughnessVal);\n\tvec2 mipInfo = MipLevelInfo(reflectedDirection, r1, roughness);\n\tfloat s = mipInfo.y;\n\tfloat level0 = mipInfo.x;\n\tfloat level1 = level0 + 1.0;\n\tlevel1 = level1 > 5.0 ? 5.0 : level1;\n\tlevel0 += min( floor( s + 0.5 ), 5.0 );\n\tvec2 uv_10 = getCubeUV(reflectedDirection, r1, level0);\n\tvec4 color10 = envMapTexelToLinear(texture2D(envMap, uv_10));\n\tvec2 uv_20 = getCubeUV(reflectedDirection, r2, level0);\n\tvec4 color20 = envMapTexelToLinear(texture2D(envMap, uv_20));\n\tvec4 result = mix(color10, color20, t);\n\treturn vec4(result.rgb, 1.0);\n}\n#endif\n";var defaultnormal_vertex="vec3 transformedNormal = normalMatrix * objectNormal;\n#ifdef FLIP_SIDED\n\ttransformedNormal = - transformedNormal;\n#endif\n";var displacementmap_pars_vertex="#ifdef USE_DISPLACEMENTMAP\n\tuniform sampler2D displacementMap;\n\tuniform float displacementScale;\n\tuniform float displacementBias;\n#endif\n";var displacementmap_vertex="#ifdef USE_DISPLACEMENTMAP\n\ttransformed += normalize( objectNormal ) * ( texture2D( displacementMap, uv ).x * displacementScale + displacementBias );\n#endif\n";var emissivemap_fragment="#ifdef USE_EMISSIVEMAP\n\tvec4 emissiveColor = texture2D( emissiveMap, vUv );\n\temissiveColor.rgb = emissiveMapTexelToLinear( emissiveColor ).rgb;\n\ttotalEmissiveRadiance *= emissiveColor.rgb;\n#endif\n";var emissivemap_pars_fragment="#ifdef USE_EMISSIVEMAP\n\tuniform sampler2D emissiveMap;\n#endif\n";var encodings_fragment=" gl_FragColor = linearToOutputTexel( gl_FragColor );\n";var encodings_pars_fragment="\nvec4 LinearToLinear( in vec4 value ) {\n\treturn value;\n}\nvec4 GammaToLinear( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.xyz, vec3( gammaFactor ) ), value.w );\n}\nvec4 LinearToGamma( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.xyz, vec3( 1.0 / gammaFactor ) ), value.w );\n}\nvec4 sRGBToLinear( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), value.rgb * 0.0773993808, vec3( lessThanEqual( value.rgb, vec3( 0.04045 ) ) ) ), value.w );\n}\nvec4 LinearTosRGB( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.w );\n}\nvec4 RGBEToLinear( in vec4 value ) {\n\treturn vec4( value.rgb * exp2( value.a * 255.0 - 128.0 ), 1.0 );\n}\nvec4 LinearToRGBE( in vec4 value ) {\n\tfloat maxComponent = max( max( value.r, value.g ), value.b );\n\tfloat fExp = clamp( ceil( log2( maxComponent ) ), -128.0, 127.0 );\n\treturn vec4( value.rgb / exp2( fExp ), ( fExp + 128.0 ) / 255.0 );\n}\nvec4 RGBMToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.xyz * value.w * maxRange, 1.0 );\n}\nvec4 LinearToRGBM( in vec4 value, in float maxRange ) {\n\tfloat maxRGB = max( value.x, max( value.g, value.b ) );\n\tfloat M = clamp( maxRGB / maxRange, 0.0, 1.0 );\n\tM = ceil( M * 255.0 ) / 255.0;\n\treturn vec4( value.rgb / ( M * maxRange ), M );\n}\nvec4 RGBDToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * ( ( maxRange / 255.0 ) / value.a ), 1.0 );\n}\nvec4 LinearToRGBD( in vec4 value, in float maxRange ) {\n\tfloat maxRGB = max( value.x, max( value.g, value.b ) );\n\tfloat D = max( maxRange / maxRGB, 1.0 );\n\tD = min( floor( D ) / 255.0, 1.0 );\n\treturn vec4( value.rgb * ( D * ( 255.0 / maxRange ) ), D );\n}\nconst mat3 cLogLuvM = mat3( 0.2209, 0.3390, 0.4184, 0.1138, 0.6780, 0.7319, 0.0102, 0.1130, 0.2969 );\nvec4 LinearToLogLuv( in vec4 value ) {\n\tvec3 Xp_Y_XYZp = value.rgb * cLogLuvM;\n\tXp_Y_XYZp = max(Xp_Y_XYZp, vec3(1e-6, 1e-6, 1e-6));\n\tvec4 vResult;\n\tvResult.xy = Xp_Y_XYZp.xy / Xp_Y_XYZp.z;\n\tfloat Le = 2.0 * log2(Xp_Y_XYZp.y) + 127.0;\n\tvResult.w = fract(Le);\n\tvResult.z = (Le - (floor(vResult.w*255.0))/255.0)/255.0;\n\treturn vResult;\n}\nconst mat3 cLogLuvInverseM = mat3( 6.0014, -2.7008, -1.7996, -1.3320, 3.1029, -5.7721, 0.3008, -1.0882, 5.6268 );\nvec4 LogLuvToLinear( in vec4 value ) {\n\tfloat Le = value.z * 255.0 + value.w;\n\tvec3 Xp_Y_XYZp;\n\tXp_Y_XYZp.y = exp2((Le - 127.0) / 2.0);\n\tXp_Y_XYZp.z = Xp_Y_XYZp.y / value.y;\n\tXp_Y_XYZp.x = value.x * Xp_Y_XYZp.z;\n\tvec3 vRGB = Xp_Y_XYZp.rgb * cLogLuvInverseM;\n\treturn vec4( max(vRGB, 0.0), 1.0 );\n}\n";var envmap_fragment="#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\tvec3 cameraToVertex = normalize( vWorldPosition - cameraPosition );\n\t\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvec3 reflectVec = reflect( cameraToVertex, worldNormal );\n\t\t#else\n\t\t\tvec3 reflectVec = refract( cameraToVertex, worldNormal, refractionRatio );\n\t\t#endif\n\t#else\n\t\tvec3 reflectVec = vReflect;\n\t#endif\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tvec4 envColor = textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) );\n\t#elif defined( ENVMAP_TYPE_EQUIREC )\n\t\tvec2 sampleUV;\n\t\treflectVec = normalize( reflectVec );\n\t\tsampleUV.y = asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\t\tsampleUV.x = atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\n\t\tvec4 envColor = texture2D( envMap, sampleUV );\n\t#elif defined( ENVMAP_TYPE_SPHERE )\n\t\treflectVec = normalize( reflectVec );\n\t\tvec3 reflectView = normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0, 0.0, 1.0 ) );\n\t\tvec4 envColor = texture2D( envMap, reflectView.xy * 0.5 + 0.5 );\n\t#else\n\t\tvec4 envColor = vec4( 0.0 );\n\t#endif\n\tenvColor = envMapTexelToLinear( envColor );\n\t#ifdef ENVMAP_BLENDING_MULTIPLY\n\t\toutgoingLight = mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_MIX )\n\t\toutgoingLight = mix( outgoingLight, envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_ADD )\n\t\toutgoingLight += envColor.xyz * specularStrength * reflectivity;\n\t#endif\n#endif\n";var envmap_pars_fragment="#if defined( USE_ENVMAP ) || defined( PHYSICAL )\n\tuniform float reflectivity;\n\tuniform float envMapIntensity;\n#endif\n#ifdef USE_ENVMAP\n\t#if ! defined( PHYSICAL ) && ( defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG ) )\n\t\tvarying vec3 vWorldPosition;\n\t#endif\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tuniform samplerCube envMap;\n\t#else\n\t\tuniform sampler2D envMap;\n\t#endif\n\tuniform float flipEnvMap;\n\tuniform int maxMipLevel;\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG ) || defined( PHYSICAL )\n\t\tuniform float refractionRatio;\n\t#else\n\t\tvarying vec3 vReflect;\n\t#endif\n#endif\n";var envmap_pars_vertex="#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\tvarying vec3 vWorldPosition;\n\t#else\n\t\tvarying vec3 vReflect;\n\t\tuniform float refractionRatio;\n\t#endif\n#endif\n";var envmap_vertex="#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\tvWorldPosition = worldPosition.xyz;\n\t#else\n\t\tvec3 cameraToVertex = normalize( worldPosition.xyz - cameraPosition );\n\t\tvec3 worldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvReflect = reflect( cameraToVertex, worldNormal );\n\t\t#else\n\t\t\tvReflect = refract( cameraToVertex, worldNormal, refractionRatio );\n\t\t#endif\n\t#endif\n#endif\n";var fog_vertex="\n#ifdef USE_FOG\nfogDepth = -mvPosition.z;\n#endif";var fog_pars_vertex="#ifdef USE_FOG\n varying float fogDepth;\n#endif\n";var fog_fragment="#ifdef USE_FOG\n\t#ifdef FOG_EXP2\n\t\tfloat fogFactor = whiteCompliment( exp2( - fogDensity * fogDensity * fogDepth * fogDepth * LOG2 ) );\n\t#else\n\t\tfloat fogFactor = smoothstep( fogNear, fogFar, fogDepth );\n\t#endif\n\tgl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor );\n#endif\n";var fog_pars_fragment="#ifdef USE_FOG\n\tuniform vec3 fogColor;\n\tvarying float fogDepth;\n\t#ifdef FOG_EXP2\n\t\tuniform float fogDensity;\n\t#else\n\t\tuniform float fogNear;\n\t\tuniform float fogFar;\n\t#endif\n#endif\n";var gradientmap_pars_fragment="#ifdef TOON\n\tuniform sampler2D gradientMap;\n\tvec3 getGradientIrradiance( vec3 normal, vec3 lightDirection ) {\n\t\tfloat dotNL = dot( normal, lightDirection );\n\t\tvec2 coord = vec2( dotNL * 0.5 + 0.5, 0.0 );\n\t\t#ifdef USE_GRADIENTMAP\n\t\t\treturn texture2D( gradientMap, coord ).rgb;\n\t\t#else\n\t\t\treturn ( coord.x < 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 );\n\t\t#endif\n\t}\n#endif\n";var lightmap_fragment="#ifdef USE_LIGHTMAP\n\treflectedLight.indirectDiffuse += PI * texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n#endif\n";var lightmap_pars_fragment="#ifdef USE_LIGHTMAP\n\tuniform sampler2D lightMap;\n\tuniform float lightMapIntensity;\n#endif";var lights_lambert_vertex="vec3 diffuse = vec3( 1.0 );\nGeometricContext geometry;\ngeometry.position = mvPosition.xyz;\ngeometry.normal = normalize( transformedNormal );\ngeometry.viewDir = normalize( -mvPosition.xyz );\nGeometricContext backGeometry;\nbackGeometry.position = geometry.position;\nbackGeometry.normal = -geometry.normal;\nbackGeometry.viewDir = geometry.viewDir;\nvLightFront = vec3( 0.0 );\n#ifdef DOUBLE_SIDED\n\tvLightBack = vec3( 0.0 );\n#endif\nIncidentLight directLight;\nfloat dotNL;\nvec3 directLightColor_Diffuse;\n#if NUM_POINT_LIGHTS > 0\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\t\tgetPointDirectLightIrradiance( pointLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = PI * directLight.color;\n\t\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n#endif\n#if NUM_SPOT_LIGHTS > 0\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\t\tgetSpotDirectLightIrradiance( spotLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = PI * directLight.color;\n\t\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n#endif\n#if NUM_DIR_LIGHTS > 0\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\t\tgetDirectionalDirectLightIrradiance( directionalLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = PI * directLight.color;\n\t\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n#endif\n#if NUM_HEMI_LIGHTS > 0\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n\t\tvLightFront += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry );\n\t\t#endif\n\t}\n#endif\n";var lights_pars_begin="uniform vec3 ambientLightColor;\nvec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {\n\tvec3 irradiance = ambientLightColor;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\treturn irradiance;\n}\n#if NUM_DIR_LIGHTS > 0\n\tstruct DirectionalLight {\n\t\tvec3 direction;\n\t\tvec3 color;\n\t\tint shadow;\n\t\tfloat shadowBias;\n\t\tfloat shadowRadius;\n\t\tvec2 shadowMapSize;\n\t};\n\tuniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];\n\tvoid getDirectionalDirectLightIrradiance( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tdirectLight.color = directionalLight.color;\n\t\tdirectLight.direction = directionalLight.direction;\n\t\tdirectLight.visible = true;\n\t}\n#endif\n#if NUM_POINT_LIGHTS > 0\n\tstruct PointLight {\n\t\tvec3 position;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t\tint shadow;\n\t\tfloat shadowBias;\n\t\tfloat shadowRadius;\n\t\tvec2 shadowMapSize;\n\t\tfloat shadowCameraNear;\n\t\tfloat shadowCameraFar;\n\t};\n\tuniform PointLight pointLights[ NUM_POINT_LIGHTS ];\n\tvoid getPointDirectLightIrradiance( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tvec3 lVector = pointLight.position - geometry.position;\n\t\tdirectLight.direction = normalize( lVector );\n\t\tfloat lightDistance = length( lVector );\n\t\tdirectLight.color = pointLight.color;\n\t\tdirectLight.color *= punctualLightIntensityToIrradianceFactor( lightDistance, pointLight.distance, pointLight.decay );\n\t\tdirectLight.visible = ( directLight.color != vec3( 0.0 ) );\n\t}\n#endif\n#if NUM_SPOT_LIGHTS > 0\n\tstruct SpotLight {\n\t\tvec3 position;\n\t\tvec3 direction;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t\tfloat coneCos;\n\t\tfloat penumbraCos;\n\t\tint shadow;\n\t\tfloat shadowBias;\n\t\tfloat shadowRadius;\n\t\tvec2 shadowMapSize;\n\t};\n\tuniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];\n\tvoid getSpotDirectLightIrradiance( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tvec3 lVector = spotLight.position - geometry.position;\n\t\tdirectLight.direction = normalize( lVector );\n\t\tfloat lightDistance = length( lVector );\n\t\tfloat angleCos = dot( directLight.direction, spotLight.direction );\n\t\tif ( angleCos > spotLight.coneCos ) {\n\t\t\tfloat spotEffect = smoothstep( spotLight.coneCos, spotLight.penumbraCos, angleCos );\n\t\t\tdirectLight.color = spotLight.color;\n\t\t\tdirectLight.color *= spotEffect * punctualLightIntensityToIrradianceFactor( lightDistance, spotLight.distance, spotLight.decay );\n\t\t\tdirectLight.visible = true;\n\t\t} else {\n\t\t\tdirectLight.color = vec3( 0.0 );\n\t\t\tdirectLight.visible = false;\n\t\t}\n\t}\n#endif\n#if NUM_RECT_AREA_LIGHTS > 0\n\tstruct RectAreaLight {\n\t\tvec3 color;\n\t\tvec3 position;\n\t\tvec3 halfWidth;\n\t\tvec3 halfHeight;\n\t};\n\tuniform sampler2D ltc_1;\tuniform sampler2D ltc_2;\n\tuniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];\n#endif\n#if NUM_HEMI_LIGHTS > 0\n\tstruct HemisphereLight {\n\t\tvec3 direction;\n\t\tvec3 skyColor;\n\t\tvec3 groundColor;\n\t};\n\tuniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];\n\tvec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in GeometricContext geometry ) {\n\t\tfloat dotNL = dot( geometry.normal, hemiLight.direction );\n\t\tfloat hemiDiffuseWeight = 0.5 * dotNL + 0.5;\n\t\tvec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tirradiance *= PI;\n\t\t#endif\n\t\treturn irradiance;\n\t}\n#endif\n";var lights_pars_maps="#if defined( USE_ENVMAP ) && defined( PHYSICAL )\n\tvec3 getLightProbeIndirectIrradiance( const in GeometricContext geometry, const in int maxMIPLevel ) {\n\t\tvec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = textureCubeLodEXT( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = textureCube( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\n\t\t\tvec4 envMapColor = textureCubeUV( queryVec, 1.0 );\n\t\t#else\n\t\t\tvec4 envMapColor = vec4( 0.0 );\n\t\t#endif\n\t\treturn PI * envMapColor.rgb * envMapIntensity;\n\t}\n\tfloat getSpecularMIPLevel( const in float blinnShininessExponent, const in int maxMIPLevel ) {\n\t\tfloat maxMIPLevelScalar = float( maxMIPLevel );\n\t\tfloat desiredMIPLevel = maxMIPLevelScalar + 0.79248 - 0.5 * log2( pow2( blinnShininessExponent ) + 1.0 );\n\t\treturn clamp( desiredMIPLevel, 0.0, maxMIPLevelScalar );\n\t}\n\tvec3 getLightProbeIndirectRadiance( const in GeometricContext geometry, const in float blinnShininessExponent, const in int maxMIPLevel ) {\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvec3 reflectVec = reflect( -geometry.viewDir, geometry.normal );\n\t\t#else\n\t\t\tvec3 reflectVec = refract( -geometry.viewDir, geometry.normal, refractionRatio );\n\t\t#endif\n\t\treflectVec = inverseTransformDirection( reflectVec, viewMatrix );\n\t\tfloat specularMIPLevel = getSpecularMIPLevel( blinnShininessExponent, maxMIPLevel );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = textureCubeLodEXT( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = textureCube( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\n\t\t\tvec4 envMapColor = textureCubeUV(queryReflectVec, BlinnExponentToGGXRoughness(blinnShininessExponent));\n\t\t#elif defined( ENVMAP_TYPE_EQUIREC )\n\t\t\tvec2 sampleUV;\n\t\t\tsampleUV.y = asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\t\t\tsampleUV.x = atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = texture2DLodEXT( envMap, sampleUV, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = texture2D( envMap, sampleUV, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_SPHERE )\n\t\t\tvec3 reflectView = normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0,0.0,1.0 ) );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = texture2DLodEXT( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = texture2D( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#endif\n\t\treturn envMapColor.rgb * envMapIntensity;\n\t}\n#endif\n";var lights_phong_fragment="BlinnPhongMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb;\nmaterial.specularColor = specular;\nmaterial.specularShininess = shininess;\nmaterial.specularStrength = specularStrength;\n";var lights_phong_pars_fragment="varying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\nstruct BlinnPhongMaterial {\n\tvec3\tdiffuseColor;\n\tvec3\tspecularColor;\n\tfloat\tspecularShininess;\n\tfloat\tspecularStrength;\n};\nvoid RE_Direct_BlinnPhong( const in IncidentLight directLight, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\t#ifdef TOON\n\t\tvec3 irradiance = getGradientIrradiance( geometry.normal, directLight.direction ) * directLight.color;\n\t#else\n\t\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\n\t\tvec3 irradiance = dotNL * directLight.color;\n\t#endif\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\treflectedLight.directDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\treflectedLight.directSpecular += irradiance * BRDF_Specular_BlinnPhong( directLight, geometry, material.specularColor, material.specularShininess ) * material.specularStrength;\n}\nvoid RE_IndirectDiffuse_BlinnPhong( const in vec3 irradiance, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\n#define RE_Direct\t\t\t\tRE_Direct_BlinnPhong\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_BlinnPhong\n#define Material_LightProbeLOD( material )\t(0)\n";var lights_physical_fragment="PhysicalMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor );\nmaterial.specularRoughness = clamp( roughnessFactor, 0.04, 1.0 );\n#ifdef STANDARD\n\tmaterial.specularColor = mix( vec3( DEFAULT_SPECULAR_COEFFICIENT ), diffuseColor.rgb, metalnessFactor );\n#else\n\tmaterial.specularColor = mix( vec3( MAXIMUM_SPECULAR_COEFFICIENT * pow2( reflectivity ) ), diffuseColor.rgb, metalnessFactor );\n\tmaterial.clearCoat = saturate( clearCoat );\tmaterial.clearCoatRoughness = clamp( clearCoatRoughness, 0.04, 1.0 );\n#endif\n";var lights_physical_pars_fragment="struct PhysicalMaterial {\n\tvec3\tdiffuseColor;\n\tfloat\tspecularRoughness;\n\tvec3\tspecularColor;\n\t#ifndef STANDARD\n\t\tfloat clearCoat;\n\t\tfloat clearCoatRoughness;\n\t#endif\n};\n#define MAXIMUM_SPECULAR_COEFFICIENT 0.16\n#define DEFAULT_SPECULAR_COEFFICIENT 0.04\nfloat clearCoatDHRApprox( const in float roughness, const in float dotNL ) {\n\treturn DEFAULT_SPECULAR_COEFFICIENT + ( 1.0 - DEFAULT_SPECULAR_COEFFICIENT ) * ( pow( 1.0 - dotNL, 5.0 ) * pow( 1.0 - roughness, 2.0 ) );\n}\n#if NUM_RECT_AREA_LIGHTS > 0\n\tvoid RE_Direct_RectArea_Physical( const in RectAreaLight rectAreaLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\t\tvec3 normal = geometry.normal;\n\t\tvec3 viewDir = geometry.viewDir;\n\t\tvec3 position = geometry.position;\n\t\tvec3 lightPos = rectAreaLight.position;\n\t\tvec3 halfWidth = rectAreaLight.halfWidth;\n\t\tvec3 halfHeight = rectAreaLight.halfHeight;\n\t\tvec3 lightColor = rectAreaLight.color;\n\t\tfloat roughness = material.specularRoughness;\n\t\tvec3 rectCoords[ 4 ];\n\t\trectCoords[ 0 ] = lightPos - halfWidth - halfHeight;\t\trectCoords[ 1 ] = lightPos + halfWidth - halfHeight;\n\t\trectCoords[ 2 ] = lightPos + halfWidth + halfHeight;\n\t\trectCoords[ 3 ] = lightPos - halfWidth + halfHeight;\n\t\tvec2 uv = LTC_Uv( normal, viewDir, roughness );\n\t\tvec4 t1 = texture2D( ltc_1, uv );\n\t\tvec4 t2 = texture2D( ltc_2, uv );\n\t\tmat3 mInv = mat3(\n\t\t\tvec3( t1.x, 0, t1.y ),\n\t\t\tvec3( 0, 1, 0 ),\n\t\t\tvec3( t1.z, 0, t1.w )\n\t\t);\n\t\tvec3 fresnel = ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y );\n\t\treflectedLight.directSpecular += lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords );\n\t\treflectedLight.directDiffuse += lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords );\n\t}\n#endif\nvoid RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\n\tvec3 irradiance = dotNL * directLight.color;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\t#ifndef STANDARD\n\t\tfloat clearCoatDHR = material.clearCoat * clearCoatDHRApprox( material.clearCoatRoughness, dotNL );\n\t#else\n\t\tfloat clearCoatDHR = 0.0;\n\t#endif\n\treflectedLight.directSpecular += ( 1.0 - clearCoatDHR ) * irradiance * BRDF_Specular_GGX( directLight, geometry, material.specularColor, material.specularRoughness );\n\treflectedLight.directDiffuse += ( 1.0 - clearCoatDHR ) * irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\t#ifndef STANDARD\n\t\treflectedLight.directSpecular += irradiance * material.clearCoat * BRDF_Specular_GGX( directLight, geometry, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearCoatRoughness );\n\t#endif\n}\nvoid RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\nvoid RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 clearCoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\t#ifndef STANDARD\n\t\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\n\t\tfloat dotNL = dotNV;\n\t\tfloat clearCoatDHR = material.clearCoat * clearCoatDHRApprox( material.clearCoatRoughness, dotNL );\n\t#else\n\t\tfloat clearCoatDHR = 0.0;\n\t#endif\n\treflectedLight.indirectSpecular += ( 1.0 - clearCoatDHR ) * radiance * BRDF_Specular_GGX_Environment( geometry, material.specularColor, material.specularRoughness );\n\t#ifndef STANDARD\n\t\treflectedLight.indirectSpecular += clearCoatRadiance * material.clearCoat * BRDF_Specular_GGX_Environment( geometry, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearCoatRoughness );\n\t#endif\n}\n#define RE_Direct\t\t\t\tRE_Direct_Physical\n#define RE_Direct_RectArea\t\tRE_Direct_RectArea_Physical\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_Physical\n#define RE_IndirectSpecular\t\tRE_IndirectSpecular_Physical\n#define Material_BlinnShininessExponent( material ) GGXRoughnessToBlinnExponent( material.specularRoughness )\n#define Material_ClearCoat_BlinnShininessExponent( material ) GGXRoughnessToBlinnExponent( material.clearCoatRoughness )\nfloat computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) {\n\treturn saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\n}\n";var lights_fragment_begin="\nGeometricContext geometry;\ngeometry.position = - vViewPosition;\ngeometry.normal = normal;\ngeometry.viewDir = normalize( vViewPosition );\nIncidentLight directLight;\n#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\n\tPointLight pointLight;\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\t\tpointLight = pointLights[ i ];\n\t\tgetPointDirectLightIrradiance( pointLight, geometry, directLight );\n\t\t#ifdef USE_SHADOWMAP\n\t\tdirectLight.color *= all( bvec2( pointLight.shadow, directLight.visible ) ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\n\tSpotLight spotLight;\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\t\tspotLight = spotLights[ i ];\n\t\tgetSpotDirectLightIrradiance( spotLight, geometry, directLight );\n\t\t#ifdef USE_SHADOWMAP\n\t\tdirectLight.color *= all( bvec2( spotLight.shadow, directLight.visible ) ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )\n\tDirectionalLight directionalLight;\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\t\tdirectionalLight = directionalLights[ i ];\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\t\t#ifdef USE_SHADOWMAP\n\t\tdirectLight.color *= all( bvec2( directionalLight.shadow, directLight.visible ) ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\n\tRectAreaLight rectAreaLight;\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\n\t\trectAreaLight = rectAreaLights[ i ];\n\t\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if defined( RE_IndirectDiffuse )\n\tvec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\n\t#if ( NUM_HEMI_LIGHTS > 0 )\n\t\t#pragma unroll_loop\n\t\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n\t\t\tirradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\t\t}\n\t#endif\n#endif\n#if defined( RE_IndirectSpecular )\n\tvec3 radiance = vec3( 0.0 );\n\tvec3 clearCoatRadiance = vec3( 0.0 );\n#endif\n";var lights_fragment_maps="#if defined( RE_IndirectDiffuse )\n\t#ifdef USE_LIGHTMAP\n\t\tvec3 lightMapIrradiance = texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tlightMapIrradiance *= PI;\n\t\t#endif\n\t\tirradiance += lightMapIrradiance;\n\t#endif\n\t#if defined( USE_ENVMAP ) && defined( PHYSICAL ) && defined( ENVMAP_TYPE_CUBE_UV )\n\t\tirradiance += getLightProbeIndirectIrradiance( geometry, maxMipLevel );\n\t#endif\n#endif\n#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )\n\tradiance += getLightProbeIndirectRadiance( geometry, Material_BlinnShininessExponent( material ), maxMipLevel );\n\t#ifndef STANDARD\n\t\tclearCoatRadiance += getLightProbeIndirectRadiance( geometry, Material_ClearCoat_BlinnShininessExponent( material ), maxMipLevel );\n\t#endif\n#endif\n";var lights_fragment_end="#if defined( RE_IndirectDiffuse )\n\tRE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\n#endif\n#if defined( RE_IndirectSpecular )\n\tRE_IndirectSpecular( radiance, clearCoatRadiance, geometry, material, reflectedLight );\n#endif\n";var logdepthbuf_fragment="#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\n\tgl_FragDepthEXT = log2( vFragDepth ) * logDepthBufFC * 0.5;\n#endif";var logdepthbuf_pars_fragment="#ifdef USE_LOGDEPTHBUF\n\tuniform float logDepthBufFC;\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvarying float vFragDepth;\n\t#endif\n#endif\n";var logdepthbuf_pars_vertex="#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvarying float vFragDepth;\n\t#endif\n\tuniform float logDepthBufFC;\n#endif";var logdepthbuf_vertex="#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvFragDepth = 1.0 + gl_Position.w;\n\t#else\n\t\tgl_Position.z = log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0;\n\t\tgl_Position.z *= gl_Position.w;\n\t#endif\n#endif\n";var map_fragment="#ifdef USE_MAP\n\tvec4 texelColor = texture2D( map, vUv );\n\ttexelColor = mapTexelToLinear( texelColor );\n\tdiffuseColor *= texelColor;\n#endif\n";var map_pars_fragment="#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif\n";var map_particle_fragment="#ifdef USE_MAP\n\tvec2 uv = ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy;\n\tvec4 mapTexel = texture2D( map, uv );\n\tdiffuseColor *= mapTexelToLinear( mapTexel );\n#endif\n";var map_particle_pars_fragment="#ifdef USE_MAP\n\tuniform mat3 uvTransform;\n\tuniform sampler2D map;\n#endif\n";var metalnessmap_fragment="float metalnessFactor = metalness;\n#ifdef USE_METALNESSMAP\n\tvec4 texelMetalness = texture2D( metalnessMap, vUv );\n\tmetalnessFactor *= texelMetalness.b;\n#endif\n";var metalnessmap_pars_fragment="#ifdef USE_METALNESSMAP\n\tuniform sampler2D metalnessMap;\n#endif";var morphnormal_vertex="#ifdef USE_MORPHNORMALS\n\tobjectNormal += ( morphNormal0 - normal ) * morphTargetInfluences[ 0 ];\n\tobjectNormal += ( morphNormal1 - normal ) * morphTargetInfluences[ 1 ];\n\tobjectNormal += ( morphNormal2 - normal ) * morphTargetInfluences[ 2 ];\n\tobjectNormal += ( morphNormal3 - normal ) * morphTargetInfluences[ 3 ];\n#endif\n";var morphtarget_pars_vertex="#ifdef USE_MORPHTARGETS\n\t#ifndef USE_MORPHNORMALS\n\tuniform float morphTargetInfluences[ 8 ];\n\t#else\n\tuniform float morphTargetInfluences[ 4 ];\n\t#endif\n#endif";var morphtarget_vertex="#ifdef USE_MORPHTARGETS\n\ttransformed += ( morphTarget0 - position ) * morphTargetInfluences[ 0 ];\n\ttransformed += ( morphTarget1 - position ) * morphTargetInfluences[ 1 ];\n\ttransformed += ( morphTarget2 - position ) * morphTargetInfluences[ 2 ];\n\ttransformed += ( morphTarget3 - position ) * morphTargetInfluences[ 3 ];\n\t#ifndef USE_MORPHNORMALS\n\ttransformed += ( morphTarget4 - position ) * morphTargetInfluences[ 4 ];\n\ttransformed += ( morphTarget5 - position ) * morphTargetInfluences[ 5 ];\n\ttransformed += ( morphTarget6 - position ) * morphTargetInfluences[ 6 ];\n\ttransformed += ( morphTarget7 - position ) * morphTargetInfluences[ 7 ];\n\t#endif\n#endif\n";var normal_fragment_begin="#ifdef FLAT_SHADED\n\tvec3 fdx = vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );\n\tvec3 fdy = vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );\n\tvec3 normal = normalize( cross( fdx, fdy ) );\n#else\n\tvec3 normal = normalize( vNormal );\n\t#ifdef DOUBLE_SIDED\n\t\tnormal = normal * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t#endif\n#endif\n";var normal_fragment_maps="#ifdef USE_NORMALMAP\n\tnormal = perturbNormal2Arb( -vViewPosition, normal );\n#elif defined( USE_BUMPMAP )\n\tnormal = perturbNormalArb( -vViewPosition, normal, dHdxy_fwd() );\n#endif\n";var normalmap_pars_fragment="#ifdef USE_NORMALMAP\n\tuniform sampler2D normalMap;\n\tuniform vec2 normalScale;\n\tvec3 perturbNormal2Arb( vec3 eye_pos, vec3 surf_norm ) {\n\t\tvec3 q0 = vec3( dFdx( eye_pos.x ), dFdx( eye_pos.y ), dFdx( eye_pos.z ) );\n\t\tvec3 q1 = vec3( dFdy( eye_pos.x ), dFdy( eye_pos.y ), dFdy( eye_pos.z ) );\n\t\tvec2 st0 = dFdx( vUv.st );\n\t\tvec2 st1 = dFdy( vUv.st );\n\t\tfloat scale = sign( st1.t * st0.s - st0.t * st1.s );\t\tscale *= float( gl_FrontFacing ) * 2.0 - 1.0;\n\t\tvec3 S = normalize( ( q0 * st1.t - q1 * st0.t ) * scale );\n\t\tvec3 T = normalize( ( - q0 * st1.s + q1 * st0.s ) * scale );\n\t\tvec3 N = normalize( surf_norm );\n\t\tvec3 mapN = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\t\tmapN.xy = normalScale * mapN.xy;\n\t\tmat3 tsn = mat3( S, T, N );\n\t\treturn normalize( tsn * mapN );\n\t}\n#endif\n";var packing="vec3 packNormalToRGB( const in vec3 normal ) {\n\treturn normalize( normal ) * 0.5 + 0.5;\n}\nvec3 unpackRGBToNormal( const in vec3 rgb ) {\n\treturn 2.0 * rgb.xyz - 1.0;\n}\nconst float PackUpscale = 256. / 255.;const float UnpackDownscale = 255. / 256.;\nconst vec3 PackFactors = vec3( 256. * 256. * 256., 256. * 256., 256. );\nconst vec4 UnpackFactors = UnpackDownscale / vec4( PackFactors, 1. );\nconst float ShiftRight8 = 1. / 256.;\nvec4 packDepthToRGBA( const in float v ) {\n\tvec4 r = vec4( fract( v * PackFactors ), v );\n\tr.yzw -= r.xyz * ShiftRight8;\treturn r * PackUpscale;\n}\nfloat unpackRGBAToDepth( const in vec4 v ) {\n\treturn dot( v, UnpackFactors );\n}\nfloat viewZToOrthographicDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn ( viewZ + near ) / ( near - far );\n}\nfloat orthographicDepthToViewZ( const in float linearClipZ, const in float near, const in float far ) {\n\treturn linearClipZ * ( near - far ) - near;\n}\nfloat viewZToPerspectiveDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn (( near + viewZ ) * far ) / (( far - near ) * viewZ );\n}\nfloat perspectiveDepthToViewZ( const in float invClipZ, const in float near, const in float far ) {\n\treturn ( near * far ) / ( ( far - near ) * invClipZ - far );\n}\n";var premultiplied_alpha_fragment="#ifdef PREMULTIPLIED_ALPHA\n\tgl_FragColor.rgb *= gl_FragColor.a;\n#endif\n";var project_vertex="vec4 mvPosition = modelViewMatrix * vec4( transformed, 1.0 );\ngl_Position = projectionMatrix * mvPosition;\n";var dithering_fragment="#if defined( DITHERING )\n gl_FragColor.rgb = dithering( gl_FragColor.rgb );\n#endif\n";var dithering_pars_fragment="#if defined( DITHERING )\n\tvec3 dithering( vec3 color ) {\n\t\tfloat grid_position = rand( gl_FragCoord.xy );\n\t\tvec3 dither_shift_RGB = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\n\t\tdither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\n\t\treturn color + dither_shift_RGB;\n\t}\n#endif\n";var roughnessmap_fragment="float roughnessFactor = roughness;\n#ifdef USE_ROUGHNESSMAP\n\tvec4 texelRoughness = texture2D( roughnessMap, vUv );\n\troughnessFactor *= texelRoughness.g;\n#endif\n";var roughnessmap_pars_fragment="#ifdef USE_ROUGHNESSMAP\n\tuniform sampler2D roughnessMap;\n#endif";var shadowmap_pars_fragment="#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS > 0\n\t\tuniform sampler2D directionalShadowMap[ NUM_DIR_LIGHTS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHTS ];\n\t#endif\n\t#if NUM_SPOT_LIGHTS > 0\n\t\tuniform sampler2D spotShadowMap[ NUM_SPOT_LIGHTS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHTS ];\n\t#endif\n\t#if NUM_POINT_LIGHTS > 0\n\t\tuniform sampler2D pointShadowMap[ NUM_POINT_LIGHTS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHTS ];\n\t#endif\n\tfloat texture2DCompare( sampler2D depths, vec2 uv, float compare ) {\n\t\treturn step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\n\t}\n\tfloat texture2DShadowLerp( sampler2D depths, vec2 size, vec2 uv, float compare ) {\n\t\tconst vec2 offset = vec2( 0.0, 1.0 );\n\t\tvec2 texelSize = vec2( 1.0 ) / size;\n\t\tvec2 centroidUV = floor( uv * size + 0.5 ) / size;\n\t\tfloat lb = texture2DCompare( depths, centroidUV + texelSize * offset.xx, compare );\n\t\tfloat lt = texture2DCompare( depths, centroidUV + texelSize * offset.xy, compare );\n\t\tfloat rb = texture2DCompare( depths, centroidUV + texelSize * offset.yx, compare );\n\t\tfloat rt = texture2DCompare( depths, centroidUV + texelSize * offset.yy, compare );\n\t\tvec2 f = fract( uv * size + 0.5 );\n\t\tfloat a = mix( lb, lt, f.y );\n\t\tfloat b = mix( rb, rt, f.y );\n\t\tfloat c = mix( a, b, f.x );\n\t\treturn c;\n\t}\n\tfloat getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) {\n\t\tfloat shadow = 1.0;\n\t\tshadowCoord.xyz /= shadowCoord.w;\n\t\tshadowCoord.z += shadowBias;\n\t\tbvec4 inFrustumVec = bvec4 ( shadowCoord.x >= 0.0, shadowCoord.x <= 1.0, shadowCoord.y >= 0.0, shadowCoord.y <= 1.0 );\n\t\tbool inFrustum = all( inFrustumVec );\n\t\tbvec2 frustumTestVec = bvec2( inFrustum, shadowCoord.z <= 1.0 );\n\t\tbool frustumTest = all( frustumTestVec );\n\t\tif ( frustumTest ) {\n\t\t#if defined( SHADOWMAP_TYPE_PCF )\n\t\t\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx0 = - texelSize.x * shadowRadius;\n\t\t\tfloat dy0 = - texelSize.y * shadowRadius;\n\t\t\tfloat dx1 = + texelSize.x * shadowRadius;\n\t\t\tfloat dy1 = + texelSize.y * shadowRadius;\n\t\t\tshadow = (\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#elif defined( SHADOWMAP_TYPE_PCF_SOFT )\n\t\t\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx0 = - texelSize.x * shadowRadius;\n\t\t\tfloat dy0 = - texelSize.y * shadowRadius;\n\t\t\tfloat dx1 = + texelSize.x * shadowRadius;\n\t\t\tfloat dy1 = + texelSize.y * shadowRadius;\n\t\t\tshadow = (\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy, shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#else\n\t\t\tshadow = texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\n\t\t#endif\n\t\t}\n\t\treturn shadow;\n\t}\n\tvec2 cubeToUV( vec3 v, float texelSizeY ) {\n\t\tvec3 absV = abs( v );\n\t\tfloat scaleToCube = 1.0 / max( absV.x, max( absV.y, absV.z ) );\n\t\tabsV *= scaleToCube;\n\t\tv *= scaleToCube * ( 1.0 - 2.0 * texelSizeY );\n\t\tvec2 planar = v.xy;\n\t\tfloat almostATexel = 1.5 * texelSizeY;\n\t\tfloat almostOne = 1.0 - almostATexel;\n\t\tif ( absV.z >= almostOne ) {\n\t\t\tif ( v.z > 0.0 )\n\t\t\t\tplanar.x = 4.0 - v.x;\n\t\t} else if ( absV.x >= almostOne ) {\n\t\t\tfloat signX = sign( v.x );\n\t\t\tplanar.x = v.z * signX + 2.0 * signX;\n\t\t} else if ( absV.y >= almostOne ) {\n\t\t\tfloat signY = sign( v.y );\n\t\t\tplanar.x = v.x + 2.0 * signY + 2.0;\n\t\t\tplanar.y = v.z * signY - 2.0;\n\t\t}\n\t\treturn vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\n\t}\n\tfloat getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\n\t\tvec2 texelSize = vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\n\t\tvec3 lightToPosition = shadowCoord.xyz;\n\t\tfloat dp = ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear );\t\tdp += shadowBias;\n\t\tvec3 bd3D = normalize( lightToPosition );\n\t\t#if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT )\n\t\t\tvec2 offset = vec2( - 1, 1 ) * shadowRadius * texelSize.y;\n\t\t\treturn (\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#else\n\t\t\treturn texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\n\t\t#endif\n\t}\n#endif\n";var shadowmap_pars_vertex="#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS > 0\n\t\tuniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHTS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHTS ];\n\t#endif\n\t#if NUM_SPOT_LIGHTS > 0\n\t\tuniform mat4 spotShadowMatrix[ NUM_SPOT_LIGHTS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHTS ];\n\t#endif\n\t#if NUM_POINT_LIGHTS > 0\n\t\tuniform mat4 pointShadowMatrix[ NUM_POINT_LIGHTS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHTS ];\n\t#endif\n#endif\n";var shadowmap_vertex="#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS > 0\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\t\tvDirectionalShadowCoord[ i ] = directionalShadowMatrix[ i ] * worldPosition;\n\t}\n\t#endif\n\t#if NUM_SPOT_LIGHTS > 0\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\t\tvSpotShadowCoord[ i ] = spotShadowMatrix[ i ] * worldPosition;\n\t}\n\t#endif\n\t#if NUM_POINT_LIGHTS > 0\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\t\tvPointShadowCoord[ i ] = pointShadowMatrix[ i ] * worldPosition;\n\t}\n\t#endif\n#endif\n";var shadowmask_pars_fragment="float getShadowMask() {\n\tfloat shadow = 1.0;\n\t#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS > 0\n\tDirectionalLight directionalLight;\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\t\tdirectionalLight = directionalLights[ i ];\n\t\tshadow *= bool( directionalLight.shadow ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t}\n\t#endif\n\t#if NUM_SPOT_LIGHTS > 0\n\tSpotLight spotLight;\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\t\tspotLight = spotLights[ i ];\n\t\tshadow *= bool( spotLight.shadow ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t}\n\t#endif\n\t#if NUM_POINT_LIGHTS > 0\n\tPointLight pointLight;\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\t\tpointLight = pointLights[ i ];\n\t\tshadow *= bool( pointLight.shadow ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\n\t}\n\t#endif\n\t#endif\n\treturn shadow;\n}\n";var skinbase_vertex="#ifdef USE_SKINNING\n\tmat4 boneMatX = getBoneMatrix( skinIndex.x );\n\tmat4 boneMatY = getBoneMatrix( skinIndex.y );\n\tmat4 boneMatZ = getBoneMatrix( skinIndex.z );\n\tmat4 boneMatW = getBoneMatrix( skinIndex.w );\n#endif";var skinning_pars_vertex="#ifdef USE_SKINNING\n\tuniform mat4 bindMatrix;\n\tuniform mat4 bindMatrixInverse;\n\t#ifdef BONE_TEXTURE\n\t\tuniform sampler2D boneTexture;\n\t\tuniform int boneTextureSize;\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tfloat j = i * 4.0;\n\t\t\tfloat x = mod( j, float( boneTextureSize ) );\n\t\t\tfloat y = floor( j / float( boneTextureSize ) );\n\t\t\tfloat dx = 1.0 / float( boneTextureSize );\n\t\t\tfloat dy = 1.0 / float( boneTextureSize );\n\t\t\ty = dy * ( y + 0.5 );\n\t\t\tvec4 v1 = texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) );\n\t\t\tvec4 v2 = texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) );\n\t\t\tvec4 v3 = texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) );\n\t\t\tvec4 v4 = texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) );\n\t\t\tmat4 bone = mat4( v1, v2, v3, v4 );\n\t\t\treturn bone;\n\t\t}\n\t#else\n\t\tuniform mat4 boneMatrices[ MAX_BONES ];\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tmat4 bone = boneMatrices[ int(i) ];\n\t\t\treturn bone;\n\t\t}\n\t#endif\n#endif\n";var skinning_vertex="#ifdef USE_SKINNING\n\tvec4 skinVertex = bindMatrix * vec4( transformed, 1.0 );\n\tvec4 skinned = vec4( 0.0 );\n\tskinned += boneMatX * skinVertex * skinWeight.x;\n\tskinned += boneMatY * skinVertex * skinWeight.y;\n\tskinned += boneMatZ * skinVertex * skinWeight.z;\n\tskinned += boneMatW * skinVertex * skinWeight.w;\n\ttransformed = ( bindMatrixInverse * skinned ).xyz;\n#endif\n";var skinnormal_vertex="#ifdef USE_SKINNING\n\tmat4 skinMatrix = mat4( 0.0 );\n\tskinMatrix += skinWeight.x * boneMatX;\n\tskinMatrix += skinWeight.y * boneMatY;\n\tskinMatrix += skinWeight.z * boneMatZ;\n\tskinMatrix += skinWeight.w * boneMatW;\n\tskinMatrix = bindMatrixInverse * skinMatrix * bindMatrix;\n\tobjectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz;\n#endif\n";var specularmap_fragment="float specularStrength;\n#ifdef USE_SPECULARMAP\n\tvec4 texelSpecular = texture2D( specularMap, vUv );\n\tspecularStrength = texelSpecular.r;\n#else\n\tspecularStrength = 1.0;\n#endif";var specularmap_pars_fragment="#ifdef USE_SPECULARMAP\n\tuniform sampler2D specularMap;\n#endif";var tonemapping_fragment="#if defined( TONE_MAPPING )\n gl_FragColor.rgb = toneMapping( gl_FragColor.rgb );\n#endif\n";var tonemapping_pars_fragment="#ifndef saturate\n\t#define saturate(a) clamp( a, 0.0, 1.0 )\n#endif\nuniform float toneMappingExposure;\nuniform float toneMappingWhitePoint;\nvec3 LinearToneMapping( vec3 color ) {\n\treturn toneMappingExposure * color;\n}\nvec3 ReinhardToneMapping( vec3 color ) {\n\tcolor *= toneMappingExposure;\n\treturn saturate( color / ( vec3( 1.0 ) + color ) );\n}\n#define Uncharted2Helper( x ) max( ( ( x * ( 0.15 * x + 0.10 * 0.50 ) + 0.20 * 0.02 ) / ( x * ( 0.15 * x + 0.50 ) + 0.20 * 0.30 ) ) - 0.02 / 0.30, vec3( 0.0 ) )\nvec3 Uncharted2ToneMapping( vec3 color ) {\n\tcolor *= toneMappingExposure;\n\treturn saturate( Uncharted2Helper( color ) / Uncharted2Helper( vec3( toneMappingWhitePoint ) ) );\n}\nvec3 OptimizedCineonToneMapping( vec3 color ) {\n\tcolor *= toneMappingExposure;\n\tcolor = max( vec3( 0.0 ), color - 0.004 );\n\treturn pow( ( color * ( 6.2 * color + 0.5 ) ) / ( color * ( 6.2 * color + 1.7 ) + 0.06 ), vec3( 2.2 ) );\n}\n";var uv_pars_fragment="#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\n\tvarying vec2 vUv;\n#endif";var uv_pars_vertex="#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\n\tvarying vec2 vUv;\n\tuniform mat3 uvTransform;\n#endif\n";var uv_vertex="#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\n\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\n#endif";var uv2_pars_fragment="#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvarying vec2 vUv2;\n#endif";var uv2_pars_vertex="#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tattribute vec2 uv2;\n\tvarying vec2 vUv2;\n#endif";var uv2_vertex="#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvUv2 = uv2;\n#endif";var worldpos_vertex="#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP )\n\tvec4 worldPosition = modelMatrix * vec4( transformed, 1.0 );\n#endif\n";var cube_frag="uniform samplerCube tCube;\nuniform float tFlip;\nuniform float opacity;\nvarying vec3 vWorldPosition;\nvoid main() {\n\tgl_FragColor = textureCube( tCube, vec3( tFlip * vWorldPosition.x, vWorldPosition.yz ) );\n\tgl_FragColor.a *= opacity;\n}\n";var cube_vert="varying vec3 vWorldPosition;\n#include <common>\nvoid main() {\n\tvWorldPosition = transformDirection( position, modelMatrix );\n\t#include <begin_vertex>\n\t#include <project_vertex>\n\tgl_Position.z = gl_Position.w;\n}\n";var depth_frag="#if DEPTH_PACKING == 3200\n\tuniform float opacity;\n#endif\n#include <common>\n#include <packing>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( 1.0 );\n\t#if DEPTH_PACKING == 3200\n\t\tdiffuseColor.a = opacity;\n\t#endif\n\t#include <map_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <logdepthbuf_fragment>\n\t#if DEPTH_PACKING == 3200\n\t\tgl_FragColor = vec4( vec3( 1.0 - gl_FragCoord.z ), opacity );\n\t#elif DEPTH_PACKING == 3201\n\t\tgl_FragColor = packDepthToRGBA( gl_FragCoord.z );\n\t#endif\n}\n";var depth_vert="#include <common>\n#include <uv_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <skinbase_vertex>\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include <beginnormal_vertex>\n\t\t#include <morphnormal_vertex>\n\t\t#include <skinnormal_vertex>\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n}\n";var distanceRGBA_frag="#define DISTANCE\nuniform vec3 referencePosition;\nuniform float nearDistance;\nuniform float farDistance;\nvarying vec3 vWorldPosition;\n#include <common>\n#include <packing>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main () {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( 1.0 );\n\t#include <map_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\tfloat dist = length( vWorldPosition - referencePosition );\n\tdist = ( dist - nearDistance ) / ( farDistance - nearDistance );\n\tdist = saturate( dist );\n\tgl_FragColor = packDepthToRGBA( dist );\n}\n";var distanceRGBA_vert="#define DISTANCE\nvarying vec3 vWorldPosition;\n#include <common>\n#include <uv_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <skinbase_vertex>\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include <beginnormal_vertex>\n\t\t#include <morphnormal_vertex>\n\t\t#include <skinnormal_vertex>\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <worldpos_vertex>\n\t#include <clipping_planes_vertex>\n\tvWorldPosition = worldPosition.xyz;\n}\n";var equirect_frag="uniform sampler2D tEquirect;\nvarying vec3 vWorldPosition;\n#include <common>\nvoid main() {\n\tvec3 direction = normalize( vWorldPosition );\n\tvec2 sampleUV;\n\tsampleUV.y = asin( clamp( direction.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\tsampleUV.x = atan( direction.z, direction.x ) * RECIPROCAL_PI2 + 0.5;\n\tgl_FragColor = texture2D( tEquirect, sampleUV );\n}\n";var equirect_vert="varying vec3 vWorldPosition;\n#include <common>\nvoid main() {\n\tvWorldPosition = transformDirection( position, modelMatrix );\n\t#include <begin_vertex>\n\t#include <project_vertex>\n}\n";var linedashed_frag="uniform vec3 diffuse;\nuniform float opacity;\nuniform float dashSize;\nuniform float totalSize;\nvarying float vLineDistance;\n#include <common>\n#include <color_pars_fragment>\n#include <fog_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tif ( mod( vLineDistance, totalSize ) > dashSize ) {\n\t\tdiscard;\n\t}\n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <color_fragment>\n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <premultiplied_alpha_fragment>\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n}\n";var linedashed_vert="uniform float scale;\nattribute float lineDistance;\nvarying float vLineDistance;\n#include <common>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <color_vertex>\n\tvLineDistance = scale * lineDistance;\n\tvec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );\n\tgl_Position = projectionMatrix * mvPosition;\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <fog_vertex>\n}\n";var meshbasic_frag="uniform vec3 diffuse;\nuniform float opacity;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <envmap_pars_fragment>\n#include <fog_pars_fragment>\n#include <specularmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <specularmap_fragment>\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\t#ifdef USE_LIGHTMAP\n\t\treflectedLight.indirectDiffuse += texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n\t#else\n\t\treflectedLight.indirectDiffuse += vec3( 1.0 );\n\t#endif\n\t#include <aomap_fragment>\n\treflectedLight.indirectDiffuse *= diffuseColor.rgb;\n\tvec3 outgoingLight = reflectedLight.indirectDiffuse;\n\t#include <envmap_fragment>\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <premultiplied_alpha_fragment>\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n}\n";var meshbasic_vert="#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <envmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <skinbase_vertex>\n\t#ifdef USE_ENVMAP\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <worldpos_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <envmap_vertex>\n\t#include <fog_vertex>\n}\n";var meshlambert_frag="uniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float opacity;\nvarying vec3 vLightFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n#endif\n#include <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <envmap_pars_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <lights_pars_maps>\n#include <fog_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <shadowmask_pars_fragment>\n#include <specularmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <specularmap_fragment>\n\t#include <emissivemap_fragment>\n\treflectedLight.indirectDiffuse = getAmbientLightIrradiance( ambientLightColor );\n\t#include <lightmap_fragment>\n\treflectedLight.indirectDiffuse *= BRDF_Diffuse_Lambert( diffuseColor.rgb );\n\t#ifdef DOUBLE_SIDED\n\t\treflectedLight.directDiffuse = ( gl_FrontFacing ) ? vLightFront : vLightBack;\n\t#else\n\t\treflectedLight.directDiffuse = vLightFront;\n\t#endif\n\treflectedLight.directDiffuse *= BRDF_Diffuse_Lambert( diffuseColor.rgb ) * getShadowMask();\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\t#include <envmap_fragment>\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}\n";var meshlambert_vert="#define LAMBERT\nvarying vec3 vLightFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <envmap_pars_vertex>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <lights_pars_maps>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <worldpos_vertex>\n\t#include <envmap_vertex>\n\t#include <lights_lambert_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}\n";var meshphong_frag="#define PHONG\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform vec3 specular;\nuniform float shininess;\nuniform float opacity;\n#include <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <envmap_pars_fragment>\n#include <gradientmap_pars_fragment>\n#include <fog_pars_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <lights_pars_maps>\n#include <lights_phong_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <specularmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <specularmap_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\t#include <emissivemap_fragment>\n\t#include <lights_phong_fragment>\n\t#include <lights_fragment_begin>\n\t#include <lights_fragment_maps>\n\t#include <lights_fragment_end>\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\t#include <envmap_fragment>\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}\n";var meshphong_vert="#define PHONG\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <envmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvViewPosition = - mvPosition.xyz;\n\t#include <worldpos_vertex>\n\t#include <envmap_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}\n";var meshphysical_frag="#define PHYSICAL\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float roughness;\nuniform float metalness;\nuniform float opacity;\n#ifndef STANDARD\n\tuniform float clearCoat;\n\tuniform float clearCoatRoughness;\n#endif\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <envmap_pars_fragment>\n#include <fog_pars_fragment>\n#include <bsdfs>\n#include <cube_uv_reflection_fragment>\n#include <lights_pars_begin>\n#include <lights_pars_maps>\n#include <lights_physical_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <roughnessmap_pars_fragment>\n#include <metalnessmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <roughnessmap_fragment>\n\t#include <metalnessmap_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\t#include <emissivemap_fragment>\n\t#include <lights_physical_fragment>\n\t#include <lights_fragment_begin>\n\t#include <lights_fragment_maps>\n\t#include <lights_fragment_end>\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}\n";var meshphysical_vert="#define PHYSICAL\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvViewPosition = - mvPosition.xyz;\n\t#include <worldpos_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}\n";var normal_frag="#define NORMAL\nuniform float opacity;\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP )\n\tvarying vec3 vViewPosition;\n#endif\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <packing>\n#include <uv_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\nvoid main() {\n\t#include <logdepthbuf_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\tgl_FragColor = vec4( packNormalToRGB( normal ), opacity );\n}\n";var normal_vert="#define NORMAL\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP )\n\tvarying vec3 vViewPosition;\n#endif\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <uv_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP )\n\tvViewPosition = - mvPosition.xyz;\n#endif\n}\n";var points_frag="uniform vec3 diffuse;\nuniform float opacity;\n#include <common>\n#include <packing>\n#include <color_pars_fragment>\n#include <map_particle_pars_fragment>\n#include <fog_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_particle_fragment>\n\t#include <color_fragment>\n\t#include <alphatest_fragment>\n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <premultiplied_alpha_fragment>\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n}\n";var points_vert="uniform float size;\nuniform float scale;\n#include <common>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <color_vertex>\n\t#include <begin_vertex>\n\t#include <project_vertex>\n\t#ifdef USE_SIZEATTENUATION\n\t\tgl_PointSize = size * ( scale / - mvPosition.z );\n\t#else\n\t\tgl_PointSize = size;\n\t#endif\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <worldpos_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}\n";var shadow_frag="uniform vec3 color;\nuniform float opacity;\n#include <common>\n#include <packing>\n#include <fog_pars_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <shadowmap_pars_fragment>\n#include <shadowmask_pars_fragment>\nvoid main() {\n\tgl_FragColor = vec4( color, opacity * ( 1.0 - getShadowMask() ) );\n\t#include <fog_fragment>\n}\n";var shadow_vert="#include <fog_pars_vertex>\n#include <shadowmap_pars_vertex>\nvoid main() {\n\t#include <begin_vertex>\n\t#include <project_vertex>\n\t#include <worldpos_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}\n";var ShaderChunk={alphamap_fragment:alphamap_fragment,alphamap_pars_fragment:alphamap_pars_fragment,alphatest_fragment:alphatest_fragment,aomap_fragment:aomap_fragment,aomap_pars_fragment:aomap_pars_fragment,begin_vertex:begin_vertex,beginnormal_vertex:beginnormal_vertex,bsdfs:bsdfs,bumpmap_pars_fragment:bumpmap_pars_fragment,clipping_planes_fragment:clipping_planes_fragment,clipping_planes_pars_fragment:clipping_planes_pars_fragment,clipping_planes_pars_vertex:clipping_planes_pars_vertex,clipping_planes_vertex:clipping_planes_vertex,color_fragment:color_fragment,color_pars_fragment:color_pars_fragment,color_pars_vertex:color_pars_vertex,color_vertex:color_vertex,common:common,cube_uv_reflection_fragment:cube_uv_reflection_fragment,defaultnormal_vertex:defaultnormal_vertex,displacementmap_pars_vertex:displacementmap_pars_vertex,displacementmap_vertex:displacementmap_vertex,emissivemap_fragment:emissivemap_fragment,emissivemap_pars_fragment:emissivemap_pars_fragment,encodings_fragment:encodings_fragment,encodings_pars_fragment:encodings_pars_fragment,envmap_fragment:envmap_fragment,envmap_pars_fragment:envmap_pars_fragment,envmap_pars_vertex:envmap_pars_vertex,envmap_vertex:envmap_vertex,fog_vertex:fog_vertex,fog_pars_vertex:fog_pars_vertex,fog_fragment:fog_fragment,fog_pars_fragment:fog_pars_fragment,gradientmap_pars_fragment:gradientmap_pars_fragment,lightmap_fragment:lightmap_fragment,lightmap_pars_fragment:lightmap_pars_fragment,lights_lambert_vertex:lights_lambert_vertex,lights_pars_begin:lights_pars_begin,lights_pars_maps:lights_pars_maps,lights_phong_fragment:lights_phong_fragment,lights_phong_pars_fragment:lights_phong_pars_fragment,lights_physical_fragment:lights_physical_fragment,lights_physical_pars_fragment:lights_physical_pars_fragment,lights_fragment_begin:lights_fragment_begin,lights_fragment_maps:lights_fragment_maps,lights_fragment_end:lights_fragment_end,logdepthbuf_fragment:logdepthbuf_fragment,logdepthbuf_pars_fragment:logdepthbuf_pars_fragment,logdepthbuf_pars_vertex:logdepthbuf_pars_vertex,logdepthbuf_vertex:logdepthbuf_vertex,map_fragment:map_fragment,map_pars_fragment:map_pars_fragment,map_particle_fragment:map_particle_fragment,map_particle_pars_fragment:map_particle_pars_fragment,metalnessmap_fragment:metalnessmap_fragment,metalnessmap_pars_fragment:metalnessmap_pars_fragment,morphnormal_vertex:morphnormal_vertex,morphtarget_pars_vertex:morphtarget_pars_vertex,morphtarget_vertex:morphtarget_vertex,normal_fragment_begin:normal_fragment_begin,normal_fragment_maps:normal_fragment_maps,normalmap_pars_fragment:normalmap_pars_fragment,packing:packing,premultiplied_alpha_fragment:premultiplied_alpha_fragment,project_vertex:project_vertex,dithering_fragment:dithering_fragment,dithering_pars_fragment:dithering_pars_fragment,roughnessmap_fragment:roughnessmap_fragment,roughnessmap_pars_fragment:roughnessmap_pars_fragment,shadowmap_pars_fragment:shadowmap_pars_fragment,shadowmap_pars_vertex:shadowmap_pars_vertex,shadowmap_vertex:shadowmap_vertex,shadowmask_pars_fragment:shadowmask_pars_fragment,skinbase_vertex:skinbase_vertex,skinning_pars_vertex:skinning_pars_vertex,skinning_vertex:skinning_vertex,skinnormal_vertex:skinnormal_vertex,specularmap_fragment:specularmap_fragment,specularmap_pars_fragment:specularmap_pars_fragment,tonemapping_fragment:tonemapping_fragment,tonemapping_pars_fragment:tonemapping_pars_fragment,uv_pars_fragment:uv_pars_fragment,uv_pars_vertex:uv_pars_vertex,uv_vertex:uv_vertex,uv2_pars_fragment:uv2_pars_fragment,uv2_pars_vertex:uv2_pars_vertex,uv2_vertex:uv2_vertex,worldpos_vertex:worldpos_vertex,cube_frag:cube_frag,cube_vert:cube_vert,depth_frag:depth_frag,depth_vert:depth_vert,distanceRGBA_frag:distanceRGBA_frag,distanceRGBA_vert:distanceRGBA_vert,equirect_frag:equirect_frag,equirect_vert:equirect_vert,linedashed_frag:linedashed_frag,linedashed_vert:linedashed_vert,meshbasic_frag:meshbasic_frag,meshbasic_vert:meshbasic_vert,meshlambert_frag:meshlambert_frag,meshlambert_vert:meshlambert_vert,meshphong_frag:meshphong_frag,meshphong_vert:meshphong_vert,meshphysical_frag:meshphysical_frag,meshphysical_vert:meshphysical_vert,normal_frag:normal_frag,normal_vert:normal_vert,points_frag:points_frag,points_vert:points_vert,shadow_frag:shadow_frag,shadow_vert:shadow_vert};/**
* Uniform Utilities
*/var UniformsUtils={merge:function(uniforms){var merged={};for(var u=0;u<uniforms.length;u++){var tmp=this.clone(uniforms[u]);for(var p in tmp){merged[p]=tmp[p];}}return merged;},clone:function(uniforms_src){var uniforms_dst={};for(var u in uniforms_src){uniforms_dst[u]={};for(var p in uniforms_src[u]){var parameter_src=uniforms_src[u][p];if(parameter_src&&(parameter_src.isColor||parameter_src.isMatrix3||parameter_src.isMatrix4||parameter_src.isVector2||parameter_src.isVector3||parameter_src.isVector4||parameter_src.isTexture)){uniforms_dst[u][p]=parameter_src.clone();}else if(Array.isArray(parameter_src)){uniforms_dst[u][p]=parameter_src.slice();}else{uniforms_dst[u][p]=parameter_src;}}}return uniforms_dst;}};/**
* @author mrdoob / http://mrdoob.com/
*/var ColorKeywords={'aliceblue':0xF0F8FF,'antiquewhite':0xFAEBD7,'aqua':0x00FFFF,'aquamarine':0x7FFFD4,'azure':0xF0FFFF,'beige':0xF5F5DC,'bisque':0xFFE4C4,'black':0x000000,'blanchedalmond':0xFFEBCD,'blue':0x0000FF,'blueviolet':0x8A2BE2,'brown':0xA52A2A,'burlywood':0xDEB887,'cadetblue':0x5F9EA0,'chartreuse':0x7FFF00,'chocolate':0xD2691E,'coral':0xFF7F50,'cornflowerblue':0x6495ED,'cornsilk':0xFFF8DC,'crimson':0xDC143C,'cyan':0x00FFFF,'darkblue':0x00008B,'darkcyan':0x008B8B,'darkgoldenrod':0xB8860B,'darkgray':0xA9A9A9,'darkgreen':0x006400,'darkgrey':0xA9A9A9,'darkkhaki':0xBDB76B,'darkmagenta':0x8B008B,'darkolivegreen':0x556B2F,'darkorange':0xFF8C00,'darkorchid':0x9932CC,'darkred':0x8B0000,'darksalmon':0xE9967A,'darkseagreen':0x8FBC8F,'darkslateblue':0x483D8B,'darkslategray':0x2F4F4F,'darkslategrey':0x2F4F4F,'darkturquoise':0x00CED1,'darkviolet':0x9400D3,'deeppink':0xFF1493,'deepskyblue':0x00BFFF,'dimgray':0x696969,'dimgrey':0x696969,'dodgerblue':0x1E90FF,'firebrick':0xB22222,'floralwhite':0xFFFAF0,'forestgreen':0x228B22,'fuchsia':0xFF00FF,'gainsboro':0xDCDCDC,'ghostwhite':0xF8F8FF,'gold':0xFFD700,'goldenrod':0xDAA520,'gray':0x808080,'green':0x008000,'greenyellow':0xADFF2F,'grey':0x808080,'honeydew':0xF0FFF0,'hotpink':0xFF69B4,'indianred':0xCD5C5C,'indigo':0x4B0082,'ivory':0xFFFFF0,'khaki':0xF0E68C,'lavender':0xE6E6FA,'lavenderblush':0xFFF0F5,'lawngreen':0x7CFC00,'lemonchiffon':0xFFFACD,'lightblue':0xADD8E6,'lightcoral':0xF08080,'lightcyan':0xE0FFFF,'lightgoldenrodyellow':0xFAFAD2,'lightgray':0xD3D3D3,'lightgreen':0x90EE90,'lightgrey':0xD3D3D3,'lightpink':0xFFB6C1,'lightsalmon':0xFFA07A,'lightseagreen':0x20B2AA,'lightskyblue':0x87CEFA,'lightslategray':0x778899,'lightslategrey':0x778899,'lightsteelblue':0xB0C4DE,'lightyellow':0xFFFFE0,'lime':0x00FF00,'limegreen':0x32CD32,'linen':0xFAF0E6,'magenta':0xFF00FF,'maroon':0x800000,'mediumaquamarine':0x66CDAA,'mediumblue':0x0000CD,'mediumorchid':0xBA55D3,'mediumpurple':0x9370DB,'mediumseagreen':0x3CB371,'mediumslateblue':0x7B68EE,'mediumspringgreen':0x00FA9A,'mediumturquoise':0x48D1CC,'mediumvioletred':0xC71585,'midnightblue':0x191970,'mintcream':0xF5FFFA,'mistyrose':0xFFE4E1,'moccasin':0xFFE4B5,'navajowhite':0xFFDEAD,'navy':0x000080,'oldlace':0xFDF5E6,'olive':0x808000,'olivedrab':0x6B8E23,'orange':0xFFA500,'orangered':0xFF4500,'orchid':0xDA70D6,'palegoldenrod':0xEEE8AA,'palegreen':0x98FB98,'paleturquoise':0xAFEEEE,'palevioletred':0xDB7093,'papayawhip':0xFFEFD5,'peachpuff':0xFFDAB9,'peru':0xCD853F,'pink':0xFFC0CB,'plum':0xDDA0DD,'powderblue':0xB0E0E6,'purple':0x800080,'rebeccapurple':0x663399,'red':0xFF0000,'rosybrown':0xBC8F8F,'royalblue':0x4169E1,'saddlebrown':0x8B4513,'salmon':0xFA8072,'sandybrown':0xF4A460,'seagreen':0x2E8B57,'seashell':0xFFF5EE,'sienna':0xA0522D,'silver':0xC0C0C0,'skyblue':0x87CEEB,'slateblue':0x6A5ACD,'slategray':0x708090,'slategrey':0x708090,'snow':0xFFFAFA,'springgreen':0x00FF7F,'steelblue':0x4682B4,'tan':0xD2B48C,'teal':0x008080,'thistle':0xD8BFD8,'tomato':0xFF6347,'turquoise':0x40E0D0,'violet':0xEE82EE,'wheat':0xF5DEB3,'white':0xFFFFFF,'whitesmoke':0xF5F5F5,'yellow':0xFFFF00,'yellowgreen':0x9ACD32};function Color(r,g,b){if(g===undefined&&b===undefined){// r is THREE.Color, hex or string
return this.set(r);}return this.setRGB(r,g,b);}Object.assign(Color.prototype,{isColor:true,r:1,g:1,b:1,set:function(value){if(value&&value.isColor){this.copy(value);}else if(typeof value==='number'){this.setHex(value);}else if(typeof value==='string'){this.setStyle(value);}return this;},setScalar:function(scalar){this.r=scalar;this.g=scalar;this.b=scalar;return this;},setHex:function(hex){hex=Math.floor(hex);this.r=(hex>>16&255)/255;this.g=(hex>>8&255)/255;this.b=(hex&255)/255;return this;},setRGB:function(r,g,b){this.r=r;this.g=g;this.b=b;return this;},setHSL:function(){function hue2rgb(p,q,t){if(t<0)t+=1;if(t>1)t-=1;if(t<1/6)return p+(q-p)*6*t;if(t<1/2)return q;if(t<2/3)return p+(q-p)*6*(2/3-t);return p;}return function setHSL(h,s,l){// h,s,l ranges are in 0.0 - 1.0
h=_Math.euclideanModulo(h,1);s=_Math.clamp(s,0,1);l=_Math.clamp(l,0,1);if(s===0){this.r=this.g=this.b=l;}else{var p=l<=0.5?l*(1+s):l+s-l*s;var q=2*l-p;this.r=hue2rgb(q,p,h+1/3);this.g=hue2rgb(q,p,h);this.b=hue2rgb(q,p,h-1/3);}return this;};}(),setStyle:function(style){function handleAlpha(string){if(string===undefined)return;if(parseFloat(string)<1){console.warn('THREE.Color: Alpha component of '+style+' will be ignored.');}}var m;if(m=/^((?:rgb|hsl)a?)\(\s*([^\)]*)\)/.exec(style)){// rgb / hsl
var color;var name=m[1];var components=m[2];switch(name){case'rgb':case'rgba':if(color=/^(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(components)){// rgb(255,0,0) rgba(255,0,0,0.5)
this.r=Math.min(255,parseInt(color[1],10))/255;this.g=Math.min(255,parseInt(color[2],10))/255;this.b=Math.min(255,parseInt(color[3],10))/255;handleAlpha(color[5]);return this;}if(color=/^(\d+)\%\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(components)){// rgb(100%,0%,0%) rgba(100%,0%,0%,0.5)
this.r=Math.min(100,parseInt(color[1],10))/100;this.g=Math.min(100,parseInt(color[2],10))/100;this.b=Math.min(100,parseInt(color[3],10))/100;handleAlpha(color[5]);return this;}break;case'hsl':case'hsla':if(color=/^([0-9]*\.?[0-9]+)\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(components)){// hsl(120,50%,50%) hsla(120,50%,50%,0.5)
var h=parseFloat(color[1])/360;var s=parseInt(color[2],10)/100;var l=parseInt(color[3],10)/100;handleAlpha(color[5]);return this.setHSL(h,s,l);}break;}}else if(m=/^\#([A-Fa-f0-9]+)$/.exec(style)){// hex color
var hex=m[1];var size=hex.length;if(size===3){// #ff0
this.r=parseInt(hex.charAt(0)+hex.charAt(0),16)/255;this.g=parseInt(hex.charAt(1)+hex.charAt(1),16)/255;this.b=parseInt(hex.charAt(2)+hex.charAt(2),16)/255;return this;}else if(size===6){// #ff0000
this.r=parseInt(hex.charAt(0)+hex.charAt(1),16)/255;this.g=parseInt(hex.charAt(2)+hex.charAt(3),16)/255;this.b=parseInt(hex.charAt(4)+hex.charAt(5),16)/255;return this;}}if(style&&style.length>0){// color keywords
var hex=ColorKeywords[style];if(hex!==undefined){// red
this.setHex(hex);}else{// unknown color
console.warn('THREE.Color: Unknown color '+style);}}return this;},clone:function(){return new this.constructor(this.r,this.g,this.b);},copy:function(color){this.r=color.r;this.g=color.g;this.b=color.b;return this;},copyGammaToLinear:function(color,gammaFactor){if(gammaFactor===undefined)gammaFactor=2.0;this.r=Math.pow(color.r,gammaFactor);this.g=Math.pow(color.g,gammaFactor);this.b=Math.pow(color.b,gammaFactor);return this;},copyLinearToGamma:function(color,gammaFactor){if(gammaFactor===undefined)gammaFactor=2.0;var safeInverse=gammaFactor>0?1.0/gammaFactor:1.0;this.r=Math.pow(color.r,safeInverse);this.g=Math.pow(color.g,safeInverse);this.b=Math.pow(color.b,safeInverse);return this;},convertGammaToLinear:function(){var r=this.r,g=this.g,b=this.b;this.r=r*r;this.g=g*g;this.b=b*b;return this;},convertLinearToGamma:function(){this.r=Math.sqrt(this.r);this.g=Math.sqrt(this.g);this.b=Math.sqrt(this.b);return this;},getHex:function(){return this.r*255<<16^this.g*255<<8^this.b*255<<0;},getHexString:function(){return ('000000'+this.getHex().toString(16)).slice(-6);},getHSL:function(target){// h,s,l ranges are in 0.0 - 1.0
if(target===undefined){console.warn('THREE.Color: .getHSL() target is now required');target={h:0,s:0,l:0};}var r=this.r,g=this.g,b=this.b;var max=Math.max(r,g,b);var min=Math.min(r,g,b);var hue,saturation;var lightness=(min+max)/2.0;if(min===max){hue=0;saturation=0;}else{var delta=max-min;saturation=lightness<=0.5?delta/(max+min):delta/(2-max-min);switch(max){case r:hue=(g-b)/delta+(g<b?6:0);break;case g:hue=(b-r)/delta+2;break;case b:hue=(r-g)/delta+4;break;}hue/=6;}target.h=hue;target.s=saturation;target.l=lightness;return target;},getStyle:function(){return 'rgb('+(this.r*255|0)+','+(this.g*255|0)+','+(this.b*255|0)+')';},offsetHSL:function(){var hsl={};return function(h,s,l){this.getHSL(hsl);hsl.h+=h;hsl.s+=s;hsl.l+=l;this.setHSL(hsl.h,hsl.s,hsl.l);return this;};}(),add:function(color){this.r+=color.r;this.g+=color.g;this.b+=color.b;return this;},addColors:function(color1,color2){this.r=color1.r+color2.r;this.g=color1.g+color2.g;this.b=color1.b+color2.b;return this;},addScalar:function(s){this.r+=s;this.g+=s;this.b+=s;return this;},sub:function(color){this.r=Math.max(0,this.r-color.r);this.g=Math.max(0,this.g-color.g);this.b=Math.max(0,this.b-color.b);return this;},multiply:function(color){this.r*=color.r;this.g*=color.g;this.b*=color.b;return this;},multiplyScalar:function(s){this.r*=s;this.g*=s;this.b*=s;return this;},lerp:function(color,alpha){this.r+=(color.r-this.r)*alpha;this.g+=(color.g-this.g)*alpha;this.b+=(color.b-this.b)*alpha;return this;},equals:function(c){return c.r===this.r&&c.g===this.g&&c.b===this.b;},fromArray:function(array,offset){if(offset===undefined)offset=0;this.r=array[offset];this.g=array[offset+1];this.b=array[offset+2];return this;},toArray:function(array,offset){if(array===undefined)array=[];if(offset===undefined)offset=0;array[offset]=this.r;array[offset+1]=this.g;array[offset+2]=this.b;return array;},toJSON:function(){return this.getHex();}});/**
* Uniforms library for shared webgl shaders
*/var UniformsLib={common:{diffuse:{value:new Color(0xeeeeee)},opacity:{value:1.0},map:{value:null},uvTransform:{value:new Matrix3()},alphaMap:{value:null}},specularmap:{specularMap:{value:null}},envmap:{envMap:{value:null},flipEnvMap:{value:-1},reflectivity:{value:1.0},refractionRatio:{value:0.98},maxMipLevel:{value:0}},aomap:{aoMap:{value:null},aoMapIntensity:{value:1}},lightmap:{lightMap:{value:null},lightMapIntensity:{value:1}},emissivemap:{emissiveMap:{value:null}},bumpmap:{bumpMap:{value:null},bumpScale:{value:1}},normalmap:{normalMap:{value:null},normalScale:{value:new Vector2(1,1)}},displacementmap:{displacementMap:{value:null},displacementScale:{value:1},displacementBias:{value:0}},roughnessmap:{roughnessMap:{value:null}},metalnessmap:{metalnessMap:{value:null}},gradientmap:{gradientMap:{value:null}},fog:{fogDensity:{value:0.00025},fogNear:{value:1},fogFar:{value:2000},fogColor:{value:new Color(0xffffff)}},lights:{ambientLightColor:{value:[]},directionalLights:{value:[],properties:{direction:{},color:{},shadow:{},shadowBias:{},shadowRadius:{},shadowMapSize:{}}},directionalShadowMap:{value:[]},directionalShadowMatrix:{value:[]},spotLights:{value:[],properties:{color:{},position:{},direction:{},distance:{},coneCos:{},penumbraCos:{},decay:{},shadow:{},shadowBias:{},shadowRadius:{},shadowMapSize:{}}},spotShadowMap:{value:[]},spotShadowMatrix:{value:[]},pointLights:{value:[],properties:{color:{},position:{},decay:{},distance:{},shadow:{},shadowBias:{},shadowRadius:{},shadowMapSize:{},shadowCameraNear:{},shadowCameraFar:{}}},pointShadowMap:{value:[]},pointShadowMatrix:{value:[]},hemisphereLights:{value:[],properties:{direction:{},skyColor:{},groundColor:{}}},// TODO (abelnation): RectAreaLight BRDF data needs to be moved from example to main src
rectAreaLights:{value:[],properties:{color:{},position:{},width:{},height:{}}}},points:{diffuse:{value:new Color(0xeeeeee)},opacity:{value:1.0},size:{value:1.0},scale:{value:1.0},map:{value:null},uvTransform:{value:new Matrix3()}}};/**
* @author alteredq / http://alteredqualia.com/
* @author mrdoob / http://mrdoob.com/
* @author mikael emtinger / http://gomo.se/
*/var ShaderLib={basic:{uniforms:UniformsUtils.merge([UniformsLib.common,UniformsLib.specularmap,UniformsLib.envmap,UniformsLib.aomap,UniformsLib.lightmap,UniformsLib.fog]),vertexShader:ShaderChunk.meshbasic_vert,fragmentShader:ShaderChunk.meshbasic_frag},lambert:{uniforms:UniformsUtils.merge([UniformsLib.common,UniformsLib.specularmap,UniformsLib.envmap,UniformsLib.aomap,UniformsLib.lightmap,UniformsLib.emissivemap,UniformsLib.fog,UniformsLib.lights,{emissive:{value:new Color(0x000000)}}]),vertexShader:ShaderChunk.meshlambert_vert,fragmentShader:ShaderChunk.meshlambert_frag},phong:{uniforms:UniformsUtils.merge([UniformsLib.common,UniformsLib.specularmap,UniformsLib.envmap,UniformsLib.aomap,UniformsLib.lightmap,UniformsLib.emissivemap,UniformsLib.bumpmap,UniformsLib.normalmap,UniformsLib.displacementmap,UniformsLib.gradientmap,UniformsLib.fog,UniformsLib.lights,{emissive:{value:new Color(0x000000)},specular:{value:new Color(0x111111)},shininess:{value:30}}]),vertexShader:ShaderChunk.meshphong_vert,fragmentShader:ShaderChunk.meshphong_frag},standard:{uniforms:UniformsUtils.merge([UniformsLib.common,UniformsLib.envmap,UniformsLib.aomap,UniformsLib.lightmap,UniformsLib.emissivemap,UniformsLib.bumpmap,UniformsLib.normalmap,UniformsLib.displacementmap,UniformsLib.roughnessmap,UniformsLib.metalnessmap,UniformsLib.fog,UniformsLib.lights,{emissive:{value:new Color(0x000000)},roughness:{value:0.5},metalness:{value:0.5},envMapIntensity:{value:1// temporary
}}]),vertexShader:ShaderChunk.meshphysical_vert,fragmentShader:ShaderChunk.meshphysical_frag},points:{uniforms:UniformsUtils.merge([UniformsLib.points,UniformsLib.fog]),vertexShader:ShaderChunk.points_vert,fragmentShader:ShaderChunk.points_frag},dashed:{uniforms:UniformsUtils.merge([UniformsLib.common,UniformsLib.fog,{scale:{value:1},dashSize:{value:1},totalSize:{value:2}}]),vertexShader:ShaderChunk.linedashed_vert,fragmentShader:ShaderChunk.linedashed_frag},depth:{uniforms:UniformsUtils.merge([UniformsLib.common,UniformsLib.displacementmap]),vertexShader:ShaderChunk.depth_vert,fragmentShader:ShaderChunk.depth_frag},normal:{uniforms:UniformsUtils.merge([UniformsLib.common,UniformsLib.bumpmap,UniformsLib.normalmap,UniformsLib.displacementmap,{opacity:{value:1.0}}]),vertexShader:ShaderChunk.normal_vert,fragmentShader:ShaderChunk.normal_frag},/* -------------------------------------------------------------------------
// Cube map shader
------------------------------------------------------------------------- */cube:{uniforms:{tCube:{value:null},tFlip:{value:-1},opacity:{value:1.0}},vertexShader:ShaderChunk.cube_vert,fragmentShader:ShaderChunk.cube_frag},equirect:{uniforms:{tEquirect:{value:null}},vertexShader:ShaderChunk.equirect_vert,fragmentShader:ShaderChunk.equirect_frag},distanceRGBA:{uniforms:UniformsUtils.merge([UniformsLib.common,UniformsLib.displacementmap,{referencePosition:{value:new Vector3()},nearDistance:{value:1},farDistance:{value:1000}}]),vertexShader:ShaderChunk.distanceRGBA_vert,fragmentShader:ShaderChunk.distanceRGBA_frag},shadow:{uniforms:UniformsUtils.merge([UniformsLib.lights,UniformsLib.fog,{color:{value:new Color(0x00000)},opacity:{value:1.0}}]),vertexShader:ShaderChunk.shadow_vert,fragmentShader:ShaderChunk.shadow_frag}};ShaderLib.physical={uniforms:UniformsUtils.merge([ShaderLib.standard.uniforms,{clearCoat:{value:0},clearCoatRoughness:{value:0}}]),vertexShader:ShaderChunk.meshphysical_vert,fragmentShader:ShaderChunk.meshphysical_frag};/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLAttributes(gl){var buffers=new WeakMap();function createBuffer(attribute,bufferType){var array=attribute.array;var usage=attribute.dynamic?gl.DYNAMIC_DRAW:gl.STATIC_DRAW;var buffer=gl.createBuffer();gl.bindBuffer(bufferType,buffer);gl.bufferData(bufferType,array,usage);attribute.onUploadCallback();var type=gl.FLOAT;if(array instanceof Float32Array){type=gl.FLOAT;}else if(array instanceof Float64Array){console.warn('THREE.WebGLAttributes: Unsupported data buffer format: Float64Array.');}else if(array instanceof Uint16Array){type=gl.UNSIGNED_SHORT;}else if(array instanceof Int16Array){type=gl.SHORT;}else if(array instanceof Uint32Array){type=gl.UNSIGNED_INT;}else if(array instanceof Int32Array){type=gl.INT;}else if(array instanceof Int8Array){type=gl.BYTE;}else if(array instanceof Uint8Array){type=gl.UNSIGNED_BYTE;}return {buffer:buffer,type:type,bytesPerElement:array.BYTES_PER_ELEMENT,version:attribute.version};}function updateBuffer(buffer,attribute,bufferType){var array=attribute.array;var updateRange=attribute.updateRange;gl.bindBuffer(bufferType,buffer);if(attribute.dynamic===false){gl.bufferData(bufferType,array,gl.STATIC_DRAW);}else if(updateRange.count===-1){// Not using update ranges
gl.bufferSubData(bufferType,0,array);}else if(updateRange.count===0){console.error('THREE.WebGLObjects.updateBuffer: dynamic THREE.BufferAttribute marked as needsUpdate but updateRange.count is 0, ensure you are using set methods or updating manually.');}else{gl.bufferSubData(bufferType,updateRange.offset*array.BYTES_PER_ELEMENT,array.subarray(updateRange.offset,updateRange.offset+updateRange.count));updateRange.count=-1;// reset range
}}//
function get(attribute){if(attribute.isInterleavedBufferAttribute)attribute=attribute.data;return buffers.get(attribute);}function remove(attribute){if(attribute.isInterleavedBufferAttribute)attribute=attribute.data;var data=buffers.get(attribute);if(data){gl.deleteBuffer(data.buffer);buffers.delete(attribute);}}function update(attribute,bufferType){if(attribute.isInterleavedBufferAttribute)attribute=attribute.data;var data=buffers.get(attribute);if(data===undefined){buffers.set(attribute,createBuffer(attribute,bufferType));}else if(data.version<attribute.version){updateBuffer(data.buffer,attribute,bufferType);data.version=attribute.version;}}return {get:get,remove:remove,update:update};}/**
* @author mrdoob / http://mrdoob.com/
* @author WestLangley / http://github.com/WestLangley
* @author bhouston / http://clara.io
*/function Euler(x,y,z,order){this._x=x||0;this._y=y||0;this._z=z||0;this._order=order||Euler.DefaultOrder;}Euler.RotationOrders=['XYZ','YZX','ZXY','XZY','YXZ','ZYX'];Euler.DefaultOrder='XYZ';Object.defineProperties(Euler.prototype,{x:{get:function(){return this._x;},set:function(value){this._x=value;this.onChangeCallback();}},y:{get:function(){return this._y;},set:function(value){this._y=value;this.onChangeCallback();}},z:{get:function(){return this._z;},set:function(value){this._z=value;this.onChangeCallback();}},order:{get:function(){return this._order;},set:function(value){this._order=value;this.onChangeCallback();}}});Object.assign(Euler.prototype,{isEuler:true,set:function(x,y,z,order){this._x=x;this._y=y;this._z=z;this._order=order||this._order;this.onChangeCallback();return this;},clone:function(){return new this.constructor(this._x,this._y,this._z,this._order);},copy:function(euler){this._x=euler._x;this._y=euler._y;this._z=euler._z;this._order=euler._order;this.onChangeCallback();return this;},setFromRotationMatrix:function(m,order,update){var clamp=_Math.clamp;// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)
var te=m.elements;var m11=te[0],m12=te[4],m13=te[8];var m21=te[1],m22=te[5],m23=te[9];var m31=te[2],m32=te[6],m33=te[10];order=order||this._order;if(order==='XYZ'){this._y=Math.asin(clamp(m13,-1,1));if(Math.abs(m13)<0.99999){this._x=Math.atan2(-m23,m33);this._z=Math.atan2(-m12,m11);}else{this._x=Math.atan2(m32,m22);this._z=0;}}else if(order==='YXZ'){this._x=Math.asin(-clamp(m23,-1,1));if(Math.abs(m23)<0.99999){this._y=Math.atan2(m13,m33);this._z=Math.atan2(m21,m22);}else{this._y=Math.atan2(-m31,m11);this._z=0;}}else if(order==='ZXY'){this._x=Math.asin(clamp(m32,-1,1));if(Math.abs(m32)<0.99999){this._y=Math.atan2(-m31,m33);this._z=Math.atan2(-m12,m22);}else{this._y=0;this._z=Math.atan2(m21,m11);}}else if(order==='ZYX'){this._y=Math.asin(-clamp(m31,-1,1));if(Math.abs(m31)<0.99999){this._x=Math.atan2(m32,m33);this._z=Math.atan2(m21,m11);}else{this._x=0;this._z=Math.atan2(-m12,m22);}}else if(order==='YZX'){this._z=Math.asin(clamp(m21,-1,1));if(Math.abs(m21)<0.99999){this._x=Math.atan2(-m23,m22);this._y=Math.atan2(-m31,m11);}else{this._x=0;this._y=Math.atan2(m13,m33);}}else if(order==='XZY'){this._z=Math.asin(-clamp(m12,-1,1));if(Math.abs(m12)<0.99999){this._x=Math.atan2(m32,m22);this._y=Math.atan2(m13,m11);}else{this._x=Math.atan2(-m23,m33);this._y=0;}}else{console.warn('THREE.Euler: .setFromRotationMatrix() given unsupported order: '+order);}this._order=order;if(update!==false)this.onChangeCallback();return this;},setFromQuaternion:function(){var matrix=new Matrix4();return function setFromQuaternion(q,order,update){matrix.makeRotationFromQuaternion(q);return this.setFromRotationMatrix(matrix,order,update);};}(),setFromVector3:function(v,order){return this.set(v.x,v.y,v.z,order||this._order);},reorder:function(){// WARNING: this discards revolution information -bhouston
var q=new Quaternion();return function reorder(newOrder){q.setFromEuler(this);return this.setFromQuaternion(q,newOrder);};}(),equals:function(euler){return euler._x===this._x&&euler._y===this._y&&euler._z===this._z&&euler._order===this._order;},fromArray:function(array){this._x=array[0];this._y=array[1];this._z=array[2];if(array[3]!==undefined)this._order=array[3];this.onChangeCallback();return this;},toArray:function(array,offset){if(array===undefined)array=[];if(offset===undefined)offset=0;array[offset]=this._x;array[offset+1]=this._y;array[offset+2]=this._z;array[offset+3]=this._order;return array;},toVector3:function(optionalResult){if(optionalResult){return optionalResult.set(this._x,this._y,this._z);}else{return new Vector3(this._x,this._y,this._z);}},onChange:function(callback){this.onChangeCallback=callback;return this;},onChangeCallback:function(){}});/**
* @author mrdoob / http://mrdoob.com/
*/function Layers(){this.mask=1|0;}Object.assign(Layers.prototype,{set:function(channel){this.mask=1<<channel|0;},enable:function(channel){this.mask|=1<<channel|0;},toggle:function(channel){this.mask^=1<<channel|0;},disable:function(channel){this.mask&=~(1<<channel|0);},test:function(layers){return (this.mask&layers.mask)!==0;}});/**
* @author mrdoob / http://mrdoob.com/
* @author mikael emtinger / http://gomo.se/
* @author alteredq / http://alteredqualia.com/
* @author WestLangley / http://github.com/WestLangley
* @author elephantatwork / www.elephantatwork.ch
*/var object3DId=0;function Object3D(){Object.defineProperty(this,'id',{value:object3DId++});this.uuid=_Math.generateUUID();this.name='';this.type='Object3D';this.parent=null;this.children=[];this.up=Object3D.DefaultUp.clone();var position=new Vector3();var rotation=new Euler();var quaternion=new Quaternion();var scale=new Vector3(1,1,1);function onRotationChange(){quaternion.setFromEuler(rotation,false);}function onQuaternionChange(){rotation.setFromQuaternion(quaternion,undefined,false);}rotation.onChange(onRotationChange);quaternion.onChange(onQuaternionChange);Object.defineProperties(this,{position:{enumerable:true,value:position},rotation:{enumerable:true,value:rotation},quaternion:{enumerable:true,value:quaternion},scale:{enumerable:true,value:scale},modelViewMatrix:{value:new Matrix4()},normalMatrix:{value:new Matrix3()}});this.matrix=new Matrix4();this.matrixWorld=new Matrix4();this.matrixAutoUpdate=Object3D.DefaultMatrixAutoUpdate;this.matrixWorldNeedsUpdate=false;this.layers=new Layers();this.visible=true;this.castShadow=false;this.receiveShadow=false;this.frustumCulled=true;this.renderOrder=0;this.userData={};}Object3D.DefaultUp=new Vector3(0,1,0);Object3D.DefaultMatrixAutoUpdate=true;Object3D.prototype=Object.assign(Object.create(EventDispatcher.prototype),{constructor:Object3D,isObject3D:true,onBeforeRender:function(){},onAfterRender:function(){},applyMatrix:function(matrix){this.matrix.multiplyMatrices(matrix,this.matrix);this.matrix.decompose(this.position,this.quaternion,this.scale);},applyQuaternion:function(q){this.quaternion.premultiply(q);return this;},setRotationFromAxisAngle:function(axis,angle){// assumes axis is normalized
this.quaternion.setFromAxisAngle(axis,angle);},setRotationFromEuler:function(euler){this.quaternion.setFromEuler(euler,true);},setRotationFromMatrix:function(m){// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)
this.quaternion.setFromRotationMatrix(m);},setRotationFromQuaternion:function(q){// assumes q is normalized
this.quaternion.copy(q);},rotateOnAxis:function(){// rotate object on axis in object space
// axis is assumed to be normalized
var q1=new Quaternion();return function rotateOnAxis(axis,angle){q1.setFromAxisAngle(axis,angle);this.quaternion.multiply(q1);return this;};}(),rotateOnWorldAxis:function(){// rotate object on axis in world space
// axis is assumed to be normalized
// method assumes no rotated parent
var q1=new Quaternion();return function rotateOnWorldAxis(axis,angle){q1.setFromAxisAngle(axis,angle);this.quaternion.premultiply(q1);return this;};}(),rotateX:function(){var v1=new Vector3(1,0,0);return function rotateX(angle){return this.rotateOnAxis(v1,angle);};}(),rotateY:function(){var v1=new Vector3(0,1,0);return function rotateY(angle){return this.rotateOnAxis(v1,angle);};}(),rotateZ:function(){var v1=new Vector3(0,0,1);return function rotateZ(angle){return this.rotateOnAxis(v1,angle);};}(),translateOnAxis:function(){// translate object by distance along axis in object space
// axis is assumed to be normalized
var v1=new Vector3();return function translateOnAxis(axis,distance){v1.copy(axis).applyQuaternion(this.quaternion);this.position.add(v1.multiplyScalar(distance));return this;};}(),translateX:function(){var v1=new Vector3(1,0,0);return function translateX(distance){return this.translateOnAxis(v1,distance);};}(),translateY:function(){var v1=new Vector3(0,1,0);return function translateY(distance){return this.translateOnAxis(v1,distance);};}(),translateZ:function(){var v1=new Vector3(0,0,1);return function translateZ(distance){return this.translateOnAxis(v1,distance);};}(),localToWorld:function(vector){return vector.applyMatrix4(this.matrixWorld);},worldToLocal:function(){var m1=new Matrix4();return function worldToLocal(vector){return vector.applyMatrix4(m1.getInverse(this.matrixWorld));};}(),lookAt:function(){// This method does not support objects with rotated and/or translated parent(s)
var m1=new Matrix4();var vector=new Vector3();return function lookAt(x,y,z){if(x.isVector3){vector.copy(x);}else{vector.set(x,y,z);}if(this.isCamera){m1.lookAt(this.position,vector,this.up);}else{m1.lookAt(vector,this.position,this.up);}this.quaternion.setFromRotationMatrix(m1);};}(),add:function(object){if(arguments.length>1){for(var i=0;i<arguments.length;i++){this.add(arguments[i]);}return this;}if(object===this){console.error("THREE.Object3D.add: object can't be added as a child of itself.",object);return this;}if(object&&object.isObject3D){if(object.parent!==null){object.parent.remove(object);}object.parent=this;object.dispatchEvent({type:'added'});this.children.push(object);}else{console.error("THREE.Object3D.add: object not an instance of THREE.Object3D.",object);}return this;},remove:function(object){if(arguments.length>1){for(var i=0;i<arguments.length;i++){this.remove(arguments[i]);}return this;}var index=this.children.indexOf(object);if(index!==-1){object.parent=null;object.dispatchEvent({type:'removed'});this.children.splice(index,1);}return this;},getObjectById:function(id){return this.getObjectByProperty('id',id);},getObjectByName:function(name){return this.getObjectByProperty('name',name);},getObjectByProperty:function(name,value){if(this[name]===value)return this;for(var i=0,l=this.children.length;i<l;i++){var child=this.children[i];var object=child.getObjectByProperty(name,value);if(object!==undefined){return object;}}return undefined;},getWorldPosition:function(target){if(target===undefined){console.warn('THREE.Object3D: .getWorldPosition() target is now required');target=new Vector3();}this.updateMatrixWorld(true);return target.setFromMatrixPosition(this.matrixWorld);},getWorldQuaternion:function(){var position=new Vector3();var scale=new Vector3();return function getWorldQuaternion(target){if(target===undefined){console.warn('THREE.Object3D: .getWorldQuaternion() target is now required');target=new Quaternion();}this.updateMatrixWorld(true);this.matrixWorld.decompose(position,target,scale);return target;};}(),getWorldScale:function(){var position=new Vector3();var quaternion=new Quaternion();return function getWorldScale(target){if(target===undefined){console.warn('THREE.Object3D: .getWorldScale() target is now required');target=new Vector3();}this.updateMatrixWorld(true);this.matrixWorld.decompose(position,quaternion,target);return target;};}(),getWorldDirection:function(){var quaternion=new Quaternion();return function getWorldDirection(target){if(target===undefined){console.warn('THREE.Object3D: .getWorldDirection() target is now required');target=new Vector3();}this.getWorldQuaternion(quaternion);return target.set(0,0,1).applyQuaternion(quaternion);};}(),raycast:function(){},traverse:function(callback){callback(this);var children=this.children;for(var i=0,l=children.length;i<l;i++){children[i].traverse(callback);}},traverseVisible:function(callback){if(this.visible===false)return;callback(this);var children=this.children;for(var i=0,l=children.length;i<l;i++){children[i].traverseVisible(callback);}},traverseAncestors:function(callback){var parent=this.parent;if(parent!==null){callback(parent);parent.traverseAncestors(callback);}},updateMatrix:function(){this.matrix.compose(this.position,this.quaternion,this.scale);this.matrixWorldNeedsUpdate=true;},updateMatrixWorld:function(force){if(this.matrixAutoUpdate)this.updateMatrix();if(this.matrixWorldNeedsUpdate||force){if(this.parent===null){this.matrixWorld.copy(this.matrix);}else{this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.matrix);}this.matrixWorldNeedsUpdate=false;force=true;}// update children
var children=this.children;for(var i=0,l=children.length;i<l;i++){children[i].updateMatrixWorld(force);}},toJSON:function(meta){// meta is a string when called from JSON.stringify
var isRootObject=meta===undefined||typeof meta==='string';var output={};// meta is a hash used to collect geometries, materials.
// not providing it implies that this is the root object
// being serialized.
if(isRootObject){// initialize meta obj
meta={geometries:{},materials:{},textures:{},images:{},shapes:{}};output.metadata={version:4.5,type:'Object',generator:'Object3D.toJSON'};}// standard Object3D serialization
var object={};object.uuid=this.uuid;object.type=this.type;if(this.name!=='')object.name=this.name;if(this.castShadow===true)object.castShadow=true;if(this.receiveShadow===true)object.receiveShadow=true;if(this.visible===false)object.visible=false;if(this.frustumCulled===false)object.frustumCulled=false;if(this.renderOrder!==0)object.renderOrder=this.renderOrder;if(JSON.stringify(this.userData)!=='{}')object.userData=this.userData;object.matrix=this.matrix.toArray();if(this.matrixAutoUpdate===false)object.matrixAutoUpdate=false;//
function serialize(library,element){if(library[element.uuid]===undefined){library[element.uuid]=element.toJSON(meta);}return element.uuid;}if(this.geometry!==undefined){object.geometry=serialize(meta.geometries,this.geometry);var parameters=this.geometry.parameters;if(parameters!==undefined&&parameters.shapes!==undefined){var shapes=parameters.shapes;if(Array.isArray(shapes)){for(var i=0,l=shapes.length;i<l;i++){var shape=shapes[i];serialize(meta.shapes,shape);}}else{serialize(meta.shapes,shapes);}}}if(this.material!==undefined){if(Array.isArray(this.material)){var uuids=[];for(var i=0,l=this.material.length;i<l;i++){uuids.push(serialize(meta.materials,this.material[i]));}object.material=uuids;}else{object.material=serialize(meta.materials,this.material);}}//
if(this.children.length>0){object.children=[];for(var i=0;i<this.children.length;i++){object.children.push(this.children[i].toJSON(meta).object);}}if(isRootObject){var geometries=extractFromCache(meta.geometries);var materials=extractFromCache(meta.materials);var textures=extractFromCache(meta.textures);var images=extractFromCache(meta.images);var shapes=extractFromCache(meta.shapes);if(geometries.length>0)output.geometries=geometries;if(materials.length>0)output.materials=materials;if(textures.length>0)output.textures=textures;if(images.length>0)output.images=images;if(shapes.length>0)output.shapes=shapes;}output.object=object;return output;// extract data from the cache hash
// remove metadata on each item
// and return as array
function extractFromCache(cache){var values=[];for(var key in cache){var data=cache[key];delete data.metadata;values.push(data);}return values;}},clone:function(recursive){return new this.constructor().copy(this,recursive);},copy:function(source,recursive){if(recursive===undefined)recursive=true;this.name=source.name;this.up.copy(source.up);this.position.copy(source.position);this.quaternion.copy(source.quaternion);this.scale.copy(source.scale);this.matrix.copy(source.matrix);this.matrixWorld.copy(source.matrixWorld);this.matrixAutoUpdate=source.matrixAutoUpdate;this.matrixWorldNeedsUpdate=source.matrixWorldNeedsUpdate;this.layers.mask=source.layers.mask;this.visible=source.visible;this.castShadow=source.castShadow;this.receiveShadow=source.receiveShadow;this.frustumCulled=source.frustumCulled;this.renderOrder=source.renderOrder;this.userData=JSON.parse(JSON.stringify(source.userData));if(recursive===true){for(var i=0;i<source.children.length;i++){var child=source.children[i];this.add(child.clone());}}return this;}});/**
* @author mrdoob / http://mrdoob.com/
* @author mikael emtinger / http://gomo.se/
* @author WestLangley / http://github.com/WestLangley
*/function Camera(){Object3D.call(this);this.type='Camera';this.matrixWorldInverse=new Matrix4();this.projectionMatrix=new Matrix4();}Camera.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Camera,isCamera:true,copy:function(source,recursive){Object3D.prototype.copy.call(this,source,recursive);this.matrixWorldInverse.copy(source.matrixWorldInverse);this.projectionMatrix.copy(source.projectionMatrix);return this;},getWorldDirection:function(){var quaternion=new Quaternion();return function getWorldDirection(target){if(target===undefined){console.warn('THREE.Camera: .getWorldDirection() target is now required');target=new Vector3();}this.getWorldQuaternion(quaternion);return target.set(0,0,-1).applyQuaternion(quaternion);};}(),updateMatrixWorld:function(force){Object3D.prototype.updateMatrixWorld.call(this,force);this.matrixWorldInverse.getInverse(this.matrixWorld);},clone:function(){return new this.constructor().copy(this);}});/**
* @author alteredq / http://alteredqualia.com/
* @author arose / http://github.com/arose
*/function OrthographicCamera(left,right,top,bottom,near,far){Camera.call(this);this.type='OrthographicCamera';this.zoom=1;this.view=null;this.left=left;this.right=right;this.top=top;this.bottom=bottom;this.near=near!==undefined?near:0.1;this.far=far!==undefined?far:2000;this.updateProjectionMatrix();}OrthographicCamera.prototype=Object.assign(Object.create(Camera.prototype),{constructor:OrthographicCamera,isOrthographicCamera:true,copy:function(source,recursive){Camera.prototype.copy.call(this,source,recursive);this.left=source.left;this.right=source.right;this.top=source.top;this.bottom=source.bottom;this.near=source.near;this.far=source.far;this.zoom=source.zoom;this.view=source.view===null?null:Object.assign({},source.view);return this;},setViewOffset:function(fullWidth,fullHeight,x,y,width,height){if(this.view===null){this.view={enabled:true,fullWidth:1,fullHeight:1,offsetX:0,offsetY:0,width:1,height:1};}this.view.enabled=true;this.view.fullWidth=fullWidth;this.view.fullHeight=fullHeight;this.view.offsetX=x;this.view.offsetY=y;this.view.width=width;this.view.height=height;this.updateProjectionMatrix();},clearViewOffset:function(){if(this.view!==null){this.view.enabled=false;}this.updateProjectionMatrix();},updateProjectionMatrix:function(){var dx=(this.right-this.left)/(2*this.zoom);var dy=(this.top-this.bottom)/(2*this.zoom);var cx=(this.right+this.left)/2;var cy=(this.top+this.bottom)/2;var left=cx-dx;var right=cx+dx;var top=cy+dy;var bottom=cy-dy;if(this.view!==null&&this.view.enabled){var zoomW=this.zoom/(this.view.width/this.view.fullWidth);var zoomH=this.zoom/(this.view.height/this.view.fullHeight);var scaleW=(this.right-this.left)/this.view.width;var scaleH=(this.top-this.bottom)/this.view.height;left+=scaleW*(this.view.offsetX/zoomW);right=left+scaleW*(this.view.width/zoomW);top-=scaleH*(this.view.offsetY/zoomH);bottom=top-scaleH*(this.view.height/zoomH);}this.projectionMatrix.makeOrthographic(left,right,top,bottom,this.near,this.far);},toJSON:function(meta){var data=Object3D.prototype.toJSON.call(this,meta);data.object.zoom=this.zoom;data.object.left=this.left;data.object.right=this.right;data.object.top=this.top;data.object.bottom=this.bottom;data.object.near=this.near;data.object.far=this.far;if(this.view!==null)data.object.view=Object.assign({},this.view);return data;}});/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*/function Face3(a,b,c,normal,color,materialIndex){this.a=a;this.b=b;this.c=c;this.normal=normal&&normal.isVector3?normal:new Vector3();this.vertexNormals=Array.isArray(normal)?normal:[];this.color=color&&color.isColor?color:new Color();this.vertexColors=Array.isArray(color)?color:[];this.materialIndex=materialIndex!==undefined?materialIndex:0;}Object.assign(Face3.prototype,{clone:function(){return new this.constructor().copy(this);},copy:function(source){this.a=source.a;this.b=source.b;this.c=source.c;this.normal.copy(source.normal);this.color.copy(source.color);this.materialIndex=source.materialIndex;for(var i=0,il=source.vertexNormals.length;i<il;i++){this.vertexNormals[i]=source.vertexNormals[i].clone();}for(var i=0,il=source.vertexColors.length;i<il;i++){this.vertexColors[i]=source.vertexColors[i].clone();}return this;}});/**
* @author mrdoob / http://mrdoob.com/
* @author kile / http://kile.stravaganza.org/
* @author alteredq / http://alteredqualia.com/
* @author mikael emtinger / http://gomo.se/
* @author zz85 / http://www.lab4games.net/zz85/blog
* @author bhouston / http://clara.io
*/var geometryId=0;// Geometry uses even numbers as Id
function Geometry(){Object.defineProperty(this,'id',{value:geometryId+=2});this.uuid=_Math.generateUUID();this.name='';this.type='Geometry';this.vertices=[];this.colors=[];this.faces=[];this.faceVertexUvs=[[]];this.morphTargets=[];this.morphNormals=[];this.skinWeights=[];this.skinIndices=[];this.lineDistances=[];this.boundingBox=null;this.boundingSphere=null;// update flags
this.elementsNeedUpdate=false;this.verticesNeedUpdate=false;this.uvsNeedUpdate=false;this.normalsNeedUpdate=false;this.colorsNeedUpdate=false;this.lineDistancesNeedUpdate=false;this.groupsNeedUpdate=false;}Geometry.prototype=Object.assign(Object.create(EventDispatcher.prototype),{constructor:Geometry,isGeometry:true,applyMatrix:function(matrix){var normalMatrix=new Matrix3().getNormalMatrix(matrix);for(var i=0,il=this.vertices.length;i<il;i++){var vertex=this.vertices[i];vertex.applyMatrix4(matrix);}for(var i=0,il=this.faces.length;i<il;i++){var face=this.faces[i];face.normal.applyMatrix3(normalMatrix).normalize();for(var j=0,jl=face.vertexNormals.length;j<jl;j++){face.vertexNormals[j].applyMatrix3(normalMatrix).normalize();}}if(this.boundingBox!==null){this.computeBoundingBox();}if(this.boundingSphere!==null){this.computeBoundingSphere();}this.verticesNeedUpdate=true;this.normalsNeedUpdate=true;return this;},rotateX:function(){// rotate geometry around world x-axis
var m1=new Matrix4();return function rotateX(angle){m1.makeRotationX(angle);this.applyMatrix(m1);return this;};}(),rotateY:function(){// rotate geometry around world y-axis
var m1=new Matrix4();return function rotateY(angle){m1.makeRotationY(angle);this.applyMatrix(m1);return this;};}(),rotateZ:function(){// rotate geometry around world z-axis
var m1=new Matrix4();return function rotateZ(angle){m1.makeRotationZ(angle);this.applyMatrix(m1);return this;};}(),translate:function(){// translate geometry
var m1=new Matrix4();return function translate(x,y,z){m1.makeTranslation(x,y,z);this.applyMatrix(m1);return this;};}(),scale:function(){// scale geometry
var m1=new Matrix4();return function scale(x,y,z){m1.makeScale(x,y,z);this.applyMatrix(m1);return this;};}(),lookAt:function(){var obj=new Object3D();return function lookAt(vector){obj.lookAt(vector);obj.updateMatrix();this.applyMatrix(obj.matrix);};}(),fromBufferGeometry:function(geometry){var scope=this;var indices=geometry.index!==null?geometry.index.array:undefined;var attributes=geometry.attributes;var positions=attributes.position.array;var normals=attributes.normal!==undefined?attributes.normal.array:undefined;var colors=attributes.color!==undefined?attributes.color.array:undefined;var uvs=attributes.uv!==undefined?attributes.uv.array:undefined;var uvs2=attributes.uv2!==undefined?attributes.uv2.array:undefined;if(uvs2!==undefined)this.faceVertexUvs[1]=[];var tempNormals=[];var tempUVs=[];var tempUVs2=[];for(var i=0,j=0;i<positions.length;i+=3,j+=2){scope.vertices.push(new Vector3(positions[i],positions[i+1],positions[i+2]));if(normals!==undefined){tempNormals.push(new Vector3(normals[i],normals[i+1],normals[i+2]));}if(colors!==undefined){scope.colors.push(new Color(colors[i],colors[i+1],colors[i+2]));}if(uvs!==undefined){tempUVs.push(new Vector2(uvs[j],uvs[j+1]));}if(uvs2!==undefined){tempUVs2.push(new Vector2(uvs2[j],uvs2[j+1]));}}function addFace(a,b,c,materialIndex){var vertexNormals=normals!==undefined?[tempNormals[a].clone(),tempNormals[b].clone(),tempNormals[c].clone()]:[];var vertexColors=colors!==undefined?[scope.colors[a].clone(),scope.colors[b].clone(),scope.colors[c].clone()]:[];var face=new Face3(a,b,c,vertexNormals,vertexColors,materialIndex);scope.faces.push(face);if(uvs!==undefined){scope.faceVertexUvs[0].push([tempUVs[a].clone(),tempUVs[b].clone(),tempUVs[c].clone()]);}if(uvs2!==undefined){scope.faceVertexUvs[1].push([tempUVs2[a].clone(),tempUVs2[b].clone(),tempUVs2[c].clone()]);}}var groups=geometry.groups;if(groups.length>0){for(var i=0;i<groups.length;i++){var group=groups[i];var start=group.start;var count=group.count;for(var j=start,jl=start+count;j<jl;j+=3){if(indices!==undefined){addFace(indices[j],indices[j+1],indices[j+2],group.materialIndex);}else{addFace(j,j+1,j+2,group.materialIndex);}}}}else{if(indices!==undefined){for(var i=0;i<indices.length;i+=3){addFace(indices[i],indices[i+1],indices[i+2]);}}else{for(var i=0;i<positions.length/3;i+=3){addFace(i,i+1,i+2);}}}this.computeFaceNormals();if(geometry.boundingBox!==null){this.boundingBox=geometry.boundingBox.clone();}if(geometry.boundingSphere!==null){this.boundingSphere=geometry.boundingSphere.clone();}return this;},center:function(){var offset=new Vector3();return function center(){this.computeBoundingBox();this.boundingBox.getCenter(offset).negate();this.translate(offset.x,offset.y,offset.z);return this;};}(),normalize:function(){this.computeBoundingSphere();var center=this.boundingSphere.center;var radius=this.boundingSphere.radius;var s=radius===0?1:1.0/radius;var matrix=new Matrix4();matrix.set(s,0,0,-s*center.x,0,s,0,-s*center.y,0,0,s,-s*center.z,0,0,0,1);this.applyMatrix(matrix);return this;},computeFaceNormals:function(){var cb=new Vector3(),ab=new Vector3();for(var f=0,fl=this.faces.length;f<fl;f++){var face=this.faces[f];var vA=this.vertices[face.a];var vB=this.vertices[face.b];var vC=this.vertices[face.c];cb.subVectors(vC,vB);ab.subVectors(vA,vB);cb.cross(ab);cb.normalize();face.normal.copy(cb);}},computeVertexNormals:function(areaWeighted){if(areaWeighted===undefined)areaWeighted=true;var v,vl,f,fl,face,vertices;vertices=new Array(this.vertices.length);for(v=0,vl=this.vertices.length;v<vl;v++){vertices[v]=new Vector3();}if(areaWeighted){// vertex normals weighted by triangle areas
// http://www.iquilezles.org/www/articles/normals/normals.htm
var vA,vB,vC;var cb=new Vector3(),ab=new Vector3();for(f=0,fl=this.faces.length;f<fl;f++){face=this.faces[f];vA=this.vertices[face.a];vB=this.vertices[face.b];vC=this.vertices[face.c];cb.subVectors(vC,vB);ab.subVectors(vA,vB);cb.cross(ab);vertices[face.a].add(cb);vertices[face.b].add(cb);vertices[face.c].add(cb);}}else{this.computeFaceNormals();for(f=0,fl=this.faces.length;f<fl;f++){face=this.faces[f];vertices[face.a].add(face.normal);vertices[face.b].add(face.normal);vertices[face.c].add(face.normal);}}for(v=0,vl=this.vertices.length;v<vl;v++){vertices[v].normalize();}for(f=0,fl=this.faces.length;f<fl;f++){face=this.faces[f];var vertexNormals=face.vertexNormals;if(vertexNormals.length===3){vertexNormals[0].copy(vertices[face.a]);vertexNormals[1].copy(vertices[face.b]);vertexNormals[2].copy(vertices[face.c]);}else{vertexNormals[0]=vertices[face.a].clone();vertexNormals[1]=vertices[face.b].clone();vertexNormals[2]=vertices[face.c].clone();}}if(this.faces.length>0){this.normalsNeedUpdate=true;}},computeFlatVertexNormals:function(){var f,fl,face;this.computeFaceNormals();for(f=0,fl=this.faces.length;f<fl;f++){face=this.faces[f];var vertexNormals=face.vertexNormals;if(vertexNormals.length===3){vertexNormals[0].copy(face.normal);vertexNormals[1].copy(face.normal);vertexNormals[2].copy(face.normal);}else{vertexNormals[0]=face.normal.clone();vertexNormals[1]=face.normal.clone();vertexNormals[2]=face.normal.clone();}}if(this.faces.length>0){this.normalsNeedUpdate=true;}},computeMorphNormals:function(){var i,il,f,fl,face;// save original normals
// - create temp variables on first access
// otherwise just copy (for faster repeated calls)
for(f=0,fl=this.faces.length;f<fl;f++){face=this.faces[f];if(!face.__originalFaceNormal){face.__originalFaceNormal=face.normal.clone();}else{face.__originalFaceNormal.copy(face.normal);}if(!face.__originalVertexNormals)face.__originalVertexNormals=[];for(i=0,il=face.vertexNormals.length;i<il;i++){if(!face.__originalVertexNormals[i]){face.__originalVertexNormals[i]=face.vertexNormals[i].clone();}else{face.__originalVertexNormals[i].copy(face.vertexNormals[i]);}}}// use temp geometry to compute face and vertex normals for each morph
var tmpGeo=new Geometry();tmpGeo.faces=this.faces;for(i=0,il=this.morphTargets.length;i<il;i++){// create on first access
if(!this.morphNormals[i]){this.morphNormals[i]={};this.morphNormals[i].faceNormals=[];this.morphNormals[i].vertexNormals=[];var dstNormalsFace=this.morphNormals[i].faceNormals;var dstNormalsVertex=this.morphNormals[i].vertexNormals;var faceNormal,vertexNormals;for(f=0,fl=this.faces.length;f<fl;f++){faceNormal=new Vector3();vertexNormals={a:new Vector3(),b:new Vector3(),c:new Vector3()};dstNormalsFace.push(faceNormal);dstNormalsVertex.push(vertexNormals);}}var morphNormals=this.morphNormals[i];// set vertices to morph target
tmpGeo.vertices=this.morphTargets[i].vertices;// compute morph normals
tmpGeo.computeFaceNormals();tmpGeo.computeVertexNormals();// store morph normals
var faceNormal,vertexNormals;for(f=0,fl=this.faces.length;f<fl;f++){face=this.faces[f];faceNormal=morphNormals.faceNormals[f];vertexNormals=morphNormals.vertexNormals[f];faceNormal.copy(face.normal);vertexNormals.a.copy(face.vertexNormals[0]);vertexNormals.b.copy(face.vertexNormals[1]);vertexNormals.c.copy(face.vertexNormals[2]);}}// restore original normals
for(f=0,fl=this.faces.length;f<fl;f++){face=this.faces[f];face.normal=face.__originalFaceNormal;face.vertexNormals=face.__originalVertexNormals;}},computeBoundingBox:function(){if(this.boundingBox===null){this.boundingBox=new Box3();}this.boundingBox.setFromPoints(this.vertices);},computeBoundingSphere:function(){if(this.boundingSphere===null){this.boundingSphere=new Sphere();}this.boundingSphere.setFromPoints(this.vertices);},merge:function(geometry,matrix,materialIndexOffset){if(!(geometry&&geometry.isGeometry)){console.error('THREE.Geometry.merge(): geometry not an instance of THREE.Geometry.',geometry);return;}var normalMatrix,vertexOffset=this.vertices.length,vertices1=this.vertices,vertices2=geometry.vertices,faces1=this.faces,faces2=geometry.faces,uvs1=this.faceVertexUvs[0],uvs2=geometry.faceVertexUvs[0],colors1=this.colors,colors2=geometry.colors;if(materialIndexOffset===undefined)materialIndexOffset=0;if(matrix!==undefined){normalMatrix=new Matrix3().getNormalMatrix(matrix);}// vertices
for(var i=0,il=vertices2.length;i<il;i++){var vertex=vertices2[i];var vertexCopy=vertex.clone();if(matrix!==undefined)vertexCopy.applyMatrix4(matrix);vertices1.push(vertexCopy);}// colors
for(var i=0,il=colors2.length;i<il;i++){colors1.push(colors2[i].clone());}// faces
for(i=0,il=faces2.length;i<il;i++){var face=faces2[i],faceCopy,normal,color,faceVertexNormals=face.vertexNormals,faceVertexColors=face.vertexColors;faceCopy=new Face3(face.a+vertexOffset,face.b+vertexOffset,face.c+vertexOffset);faceCopy.normal.copy(face.normal);if(normalMatrix!==undefined){faceCopy.normal.applyMatrix3(normalMatrix).normalize();}for(var j=0,jl=faceVertexNormals.length;j<jl;j++){normal=faceVertexNormals[j].clone();if(normalMatrix!==undefined){normal.applyMatrix3(normalMatrix).normalize();}faceCopy.vertexNormals.push(normal);}faceCopy.color.copy(face.color);for(var j=0,jl=faceVertexColors.length;j<jl;j++){color=faceVertexColors[j];faceCopy.vertexColors.push(color.clone());}faceCopy.materialIndex=face.materialIndex+materialIndexOffset;faces1.push(faceCopy);}// uvs
for(i=0,il=uvs2.length;i<il;i++){var uv=uvs2[i],uvCopy=[];if(uv===undefined){continue;}for(var j=0,jl=uv.length;j<jl;j++){uvCopy.push(uv[j].clone());}uvs1.push(uvCopy);}},mergeMesh:function(mesh){if(!(mesh&&mesh.isMesh)){console.error('THREE.Geometry.mergeMesh(): mesh not an instance of THREE.Mesh.',mesh);return;}if(mesh.matrixAutoUpdate)mesh.updateMatrix();this.merge(mesh.geometry,mesh.matrix);},/*
* Checks for duplicate vertices with hashmap.
* Duplicated vertices are removed
* and faces' vertices are updated.
*/mergeVertices:function(){var verticesMap={};// Hashmap for looking up vertices by position coordinates (and making sure they are unique)
var unique=[],changes=[];var v,key;var precisionPoints=4;// number of decimal points, e.g. 4 for epsilon of 0.0001
var precision=Math.pow(10,precisionPoints);var i,il,face;var indices,j,jl;for(i=0,il=this.vertices.length;i<il;i++){v=this.vertices[i];key=Math.round(v.x*precision)+'_'+Math.round(v.y*precision)+'_'+Math.round(v.z*precision);if(verticesMap[key]===undefined){verticesMap[key]=i;unique.push(this.vertices[i]);changes[i]=unique.length-1;}else{//console.log('Duplicate vertex found. ', i, ' could be using ', verticesMap[key]);
changes[i]=changes[verticesMap[key]];}}// if faces are completely degenerate after merging vertices, we
// have to remove them from the geometry.
var faceIndicesToRemove=[];for(i=0,il=this.faces.length;i<il;i++){face=this.faces[i];face.a=changes[face.a];face.b=changes[face.b];face.c=changes[face.c];indices=[face.a,face.b,face.c];// if any duplicate vertices are found in a Face3
// we have to remove the face as nothing can be saved
for(var n=0;n<3;n++){if(indices[n]===indices[(n+1)%3]){faceIndicesToRemove.push(i);break;}}}for(i=faceIndicesToRemove.length-1;i>=0;i--){var idx=faceIndicesToRemove[i];this.faces.splice(idx,1);for(j=0,jl=this.faceVertexUvs.length;j<jl;j++){this.faceVertexUvs[j].splice(idx,1);}}// Use unique set of vertices
var diff=this.vertices.length-unique.length;this.vertices=unique;return diff;},setFromPoints:function(points){this.vertices=[];for(var i=0,l=points.length;i<l;i++){var point=points[i];this.vertices.push(new Vector3(point.x,point.y,point.z||0));}return this;},sortFacesByMaterialIndex:function(){var faces=this.faces;var length=faces.length;// tag faces
for(var i=0;i<length;i++){faces[i]._id=i;}// sort faces
function materialIndexSort(a,b){return a.materialIndex-b.materialIndex;}faces.sort(materialIndexSort);// sort uvs
var uvs1=this.faceVertexUvs[0];var uvs2=this.faceVertexUvs[1];var newUvs1,newUvs2;if(uvs1&&uvs1.length===length)newUvs1=[];if(uvs2&&uvs2.length===length)newUvs2=[];for(var i=0;i<length;i++){var id=faces[i]._id;if(newUvs1)newUvs1.push(uvs1[id]);if(newUvs2)newUvs2.push(uvs2[id]);}if(newUvs1)this.faceVertexUvs[0]=newUvs1;if(newUvs2)this.faceVertexUvs[1]=newUvs2;},toJSON:function(){var data={metadata:{version:4.5,type:'Geometry',generator:'Geometry.toJSON'}};// standard Geometry serialization
data.uuid=this.uuid;data.type=this.type;if(this.name!=='')data.name=this.name;if(this.parameters!==undefined){var parameters=this.parameters;for(var key in parameters){if(parameters[key]!==undefined)data[key]=parameters[key];}return data;}var vertices=[];for(var i=0;i<this.vertices.length;i++){var vertex=this.vertices[i];vertices.push(vertex.x,vertex.y,vertex.z);}var faces=[];var normals=[];var normalsHash={};var colors=[];var colorsHash={};var uvs=[];var uvsHash={};for(var i=0;i<this.faces.length;i++){var face=this.faces[i];var hasMaterial=true;var hasFaceUv=false;// deprecated
var hasFaceVertexUv=this.faceVertexUvs[0][i]!==undefined;var hasFaceNormal=face.normal.length()>0;var hasFaceVertexNormal=face.vertexNormals.length>0;var hasFaceColor=face.color.r!==1||face.color.g!==1||face.color.b!==1;var hasFaceVertexColor=face.vertexColors.length>0;var faceType=0;faceType=setBit(faceType,0,0);// isQuad
faceType=setBit(faceType,1,hasMaterial);faceType=setBit(faceType,2,hasFaceUv);faceType=setBit(faceType,3,hasFaceVertexUv);faceType=setBit(faceType,4,hasFaceNormal);faceType=setBit(faceType,5,hasFaceVertexNormal);faceType=setBit(faceType,6,hasFaceColor);faceType=setBit(faceType,7,hasFaceVertexColor);faces.push(faceType);faces.push(face.a,face.b,face.c);faces.push(face.materialIndex);if(hasFaceVertexUv){var faceVertexUvs=this.faceVertexUvs[0][i];faces.push(getUvIndex(faceVertexUvs[0]),getUvIndex(faceVertexUvs[1]),getUvIndex(faceVertexUvs[2]));}if(hasFaceNormal){faces.push(getNormalIndex(face.normal));}if(hasFaceVertexNormal){var vertexNormals=face.vertexNormals;faces.push(getNormalIndex(vertexNormals[0]),getNormalIndex(vertexNormals[1]),getNormalIndex(vertexNormals[2]));}if(hasFaceColor){faces.push(getColorIndex(face.color));}if(hasFaceVertexColor){var vertexColors=face.vertexColors;faces.push(getColorIndex(vertexColors[0]),getColorIndex(vertexColors[1]),getColorIndex(vertexColors[2]));}}function setBit(value,position,enabled){return enabled?value|1<<position:value&~(1<<position);}function getNormalIndex(normal){var hash=normal.x.toString()+normal.y.toString()+normal.z.toString();if(normalsHash[hash]!==undefined){return normalsHash[hash];}normalsHash[hash]=normals.length/3;normals.push(normal.x,normal.y,normal.z);return normalsHash[hash];}function getColorIndex(color){var hash=color.r.toString()+color.g.toString()+color.b.toString();if(colorsHash[hash]!==undefined){return colorsHash[hash];}colorsHash[hash]=colors.length;colors.push(color.getHex());return colorsHash[hash];}function getUvIndex(uv){var hash=uv.x.toString()+uv.y.toString();if(uvsHash[hash]!==undefined){return uvsHash[hash];}uvsHash[hash]=uvs.length/2;uvs.push(uv.x,uv.y);return uvsHash[hash];}data.data={};data.data.vertices=vertices;data.data.normals=normals;if(colors.length>0)data.data.colors=colors;if(uvs.length>0)data.data.uvs=[uvs];// temporal backward compatibility
data.data.faces=faces;return data;},clone:function(){/*
// Handle primitives
var parameters = this.parameters;
if ( parameters !== undefined ) {
var values = [];
for ( var key in parameters ) {
values.push( parameters[ key ] );
}
var geometry = Object.create( this.constructor.prototype );
this.constructor.apply( geometry, values );
return geometry;
}
return new this.constructor().copy( this );
*/return new Geometry().copy(this);},copy:function(source){var i,il,j,jl,k,kl;// reset
this.vertices=[];this.colors=[];this.faces=[];this.faceVertexUvs=[[]];this.morphTargets=[];this.morphNormals=[];this.skinWeights=[];this.skinIndices=[];this.lineDistances=[];this.boundingBox=null;this.boundingSphere=null;// name
this.name=source.name;// vertices
var vertices=source.vertices;for(i=0,il=vertices.length;i<il;i++){this.vertices.push(vertices[i].clone());}// colors
var colors=source.colors;for(i=0,il=colors.length;i<il;i++){this.colors.push(colors[i].clone());}// faces
var faces=source.faces;for(i=0,il=faces.length;i<il;i++){this.faces.push(faces[i].clone());}// face vertex uvs
for(i=0,il=source.faceVertexUvs.length;i<il;i++){var faceVertexUvs=source.faceVertexUvs[i];if(this.faceVertexUvs[i]===undefined){this.faceVertexUvs[i]=[];}for(j=0,jl=faceVertexUvs.length;j<jl;j++){var uvs=faceVertexUvs[j],uvsCopy=[];for(k=0,kl=uvs.length;k<kl;k++){var uv=uvs[k];uvsCopy.push(uv.clone());}this.faceVertexUvs[i].push(uvsCopy);}}// morph targets
var morphTargets=source.morphTargets;for(i=0,il=morphTargets.length;i<il;i++){var morphTarget={};morphTarget.name=morphTargets[i].name;// vertices
if(morphTargets[i].vertices!==undefined){morphTarget.vertices=[];for(j=0,jl=morphTargets[i].vertices.length;j<jl;j++){morphTarget.vertices.push(morphTargets[i].vertices[j].clone());}}// normals
if(morphTargets[i].normals!==undefined){morphTarget.normals=[];for(j=0,jl=morphTargets[i].normals.length;j<jl;j++){morphTarget.normals.push(morphTargets[i].normals[j].clone());}}this.morphTargets.push(morphTarget);}// morph normals
var morphNormals=source.morphNormals;for(i=0,il=morphNormals.length;i<il;i++){var morphNormal={};// vertex normals
if(morphNormals[i].vertexNormals!==undefined){morphNormal.vertexNormals=[];for(j=0,jl=morphNormals[i].vertexNormals.length;j<jl;j++){var srcVertexNormal=morphNormals[i].vertexNormals[j];var destVertexNormal={};destVertexNormal.a=srcVertexNormal.a.clone();destVertexNormal.b=srcVertexNormal.b.clone();destVertexNormal.c=srcVertexNormal.c.clone();morphNormal.vertexNormals.push(destVertexNormal);}}// face normals
if(morphNormals[i].faceNormals!==undefined){morphNormal.faceNormals=[];for(j=0,jl=morphNormals[i].faceNormals.length;j<jl;j++){morphNormal.faceNormals.push(morphNormals[i].faceNormals[j].clone());}}this.morphNormals.push(morphNormal);}// skin weights
var skinWeights=source.skinWeights;for(i=0,il=skinWeights.length;i<il;i++){this.skinWeights.push(skinWeights[i].clone());}// skin indices
var skinIndices=source.skinIndices;for(i=0,il=skinIndices.length;i<il;i++){this.skinIndices.push(skinIndices[i].clone());}// line distances
var lineDistances=source.lineDistances;for(i=0,il=lineDistances.length;i<il;i++){this.lineDistances.push(lineDistances[i]);}// bounding box
var boundingBox=source.boundingBox;if(boundingBox!==null){this.boundingBox=boundingBox.clone();}// bounding sphere
var boundingSphere=source.boundingSphere;if(boundingSphere!==null){this.boundingSphere=boundingSphere.clone();}// update flags
this.elementsNeedUpdate=source.elementsNeedUpdate;this.verticesNeedUpdate=source.verticesNeedUpdate;this.uvsNeedUpdate=source.uvsNeedUpdate;this.normalsNeedUpdate=source.normalsNeedUpdate;this.colorsNeedUpdate=source.colorsNeedUpdate;this.lineDistancesNeedUpdate=source.lineDistancesNeedUpdate;this.groupsNeedUpdate=source.groupsNeedUpdate;return this;},dispose:function(){this.dispatchEvent({type:'dispose'});}});/**
* @author mrdoob / http://mrdoob.com/
*/function BufferAttribute(array,itemSize,normalized){if(Array.isArray(array)){throw new TypeError('THREE.BufferAttribute: array should be a Typed Array.');}this.name='';this.array=array;this.itemSize=itemSize;this.count=array!==undefined?array.length/itemSize:0;this.normalized=normalized===true;this.dynamic=false;this.updateRange={offset:0,count:-1};this.version=0;}Object.defineProperty(BufferAttribute.prototype,'needsUpdate',{set:function(value){if(value===true)this.version++;}});Object.assign(BufferAttribute.prototype,{isBufferAttribute:true,onUploadCallback:function(){},setArray:function(array){if(Array.isArray(array)){throw new TypeError('THREE.BufferAttribute: array should be a Typed Array.');}this.count=array!==undefined?array.length/this.itemSize:0;this.array=array;return this;},setDynamic:function(value){this.dynamic=value;return this;},copy:function(source){this.name=source.name;this.array=new source.array.constructor(source.array);this.itemSize=source.itemSize;this.count=source.count;this.normalized=source.normalized;this.dynamic=source.dynamic;return this;},copyAt:function(index1,attribute,index2){index1*=this.itemSize;index2*=attribute.itemSize;for(var i=0,l=this.itemSize;i<l;i++){this.array[index1+i]=attribute.array[index2+i];}return this;},copyArray:function(array){this.array.set(array);return this;},copyColorsArray:function(colors){var array=this.array,offset=0;for(var i=0,l=colors.length;i<l;i++){var color=colors[i];if(color===undefined){console.warn('THREE.BufferAttribute.copyColorsArray(): color is undefined',i);color=new Color();}array[offset++]=color.r;array[offset++]=color.g;array[offset++]=color.b;}return this;},copyVector2sArray:function(vectors){var array=this.array,offset=0;for(var i=0,l=vectors.length;i<l;i++){var vector=vectors[i];if(vector===undefined){console.warn('THREE.BufferAttribute.copyVector2sArray(): vector is undefined',i);vector=new Vector2();}array[offset++]=vector.x;array[offset++]=vector.y;}return this;},copyVector3sArray:function(vectors){var array=this.array,offset=0;for(var i=0,l=vectors.length;i<l;i++){var vector=vectors[i];if(vector===undefined){console.warn('THREE.BufferAttribute.copyVector3sArray(): vector is undefined',i);vector=new Vector3();}array[offset++]=vector.x;array[offset++]=vector.y;array[offset++]=vector.z;}return this;},copyVector4sArray:function(vectors){var array=this.array,offset=0;for(var i=0,l=vectors.length;i<l;i++){var vector=vectors[i];if(vector===undefined){console.warn('THREE.BufferAttribute.copyVector4sArray(): vector is undefined',i);vector=new Vector4();}array[offset++]=vector.x;array[offset++]=vector.y;array[offset++]=vector.z;array[offset++]=vector.w;}return this;},set:function(value,offset){if(offset===undefined)offset=0;this.array.set(value,offset);return this;},getX:function(index){return this.array[index*this.itemSize];},setX:function(index,x){this.array[index*this.itemSize]=x;return this;},getY:function(index){return this.array[index*this.itemSize+1];},setY:function(index,y){this.array[index*this.itemSize+1]=y;return this;},getZ:function(index){return this.array[index*this.itemSize+2];},setZ:function(index,z){this.array[index*this.itemSize+2]=z;return this;},getW:function(index){return this.array[index*this.itemSize+3];},setW:function(index,w){this.array[index*this.itemSize+3]=w;return this;},setXY:function(index,x,y){index*=this.itemSize;this.array[index+0]=x;this.array[index+1]=y;return this;},setXYZ:function(index,x,y,z){index*=this.itemSize;this.array[index+0]=x;this.array[index+1]=y;this.array[index+2]=z;return this;},setXYZW:function(index,x,y,z,w){index*=this.itemSize;this.array[index+0]=x;this.array[index+1]=y;this.array[index+2]=z;this.array[index+3]=w;return this;},onUpload:function(callback){this.onUploadCallback=callback;return this;},clone:function(){return new this.constructor(this.array,this.itemSize).copy(this);}});//
function Int8BufferAttribute(array,itemSize,normalized){BufferAttribute.call(this,new Int8Array(array),itemSize,normalized);}Int8BufferAttribute.prototype=Object.create(BufferAttribute.prototype);Int8BufferAttribute.prototype.constructor=Int8BufferAttribute;function Uint8BufferAttribute(array,itemSize,normalized){BufferAttribute.call(this,new Uint8Array(array),itemSize,normalized);}Uint8BufferAttribute.prototype=Object.create(BufferAttribute.prototype);Uint8BufferAttribute.prototype.constructor=Uint8BufferAttribute;function Uint8ClampedBufferAttribute(array,itemSize,normalized){BufferAttribute.call(this,new Uint8ClampedArray(array),itemSize,normalized);}Uint8ClampedBufferAttribute.prototype=Object.create(BufferAttribute.prototype);Uint8ClampedBufferAttribute.prototype.constructor=Uint8ClampedBufferAttribute;function Int16BufferAttribute(array,itemSize,normalized){BufferAttribute.call(this,new Int16Array(array),itemSize,normalized);}Int16BufferAttribute.prototype=Object.create(BufferAttribute.prototype);Int16BufferAttribute.prototype.constructor=Int16BufferAttribute;function Uint16BufferAttribute(array,itemSize,normalized){BufferAttribute.call(this,new Uint16Array(array),itemSize,normalized);}Uint16BufferAttribute.prototype=Object.create(BufferAttribute.prototype);Uint16BufferAttribute.prototype.constructor=Uint16BufferAttribute;function Int32BufferAttribute(array,itemSize,normalized){BufferAttribute.call(this,new Int32Array(array),itemSize,normalized);}Int32BufferAttribute.prototype=Object.create(BufferAttribute.prototype);Int32BufferAttribute.prototype.constructor=Int32BufferAttribute;function Uint32BufferAttribute(array,itemSize,normalized){BufferAttribute.call(this,new Uint32Array(array),itemSize,normalized);}Uint32BufferAttribute.prototype=Object.create(BufferAttribute.prototype);Uint32BufferAttribute.prototype.constructor=Uint32BufferAttribute;function Float32BufferAttribute(array,itemSize,normalized){BufferAttribute.call(this,new Float32Array(array),itemSize,normalized);}Float32BufferAttribute.prototype=Object.create(BufferAttribute.prototype);Float32BufferAttribute.prototype.constructor=Float32BufferAttribute;function Float64BufferAttribute(array,itemSize,normalized){BufferAttribute.call(this,new Float64Array(array),itemSize,normalized);}Float64BufferAttribute.prototype=Object.create(BufferAttribute.prototype);Float64BufferAttribute.prototype.constructor=Float64BufferAttribute;/**
* @author mrdoob / http://mrdoob.com/
*/function DirectGeometry(){this.vertices=[];this.normals=[];this.colors=[];this.uvs=[];this.uvs2=[];this.groups=[];this.morphTargets={};this.skinWeights=[];this.skinIndices=[];// this.lineDistances = [];
this.boundingBox=null;this.boundingSphere=null;// update flags
this.verticesNeedUpdate=false;this.normalsNeedUpdate=false;this.colorsNeedUpdate=false;this.uvsNeedUpdate=false;this.groupsNeedUpdate=false;}Object.assign(DirectGeometry.prototype,{computeGroups:function(geometry){var group;var groups=[];var materialIndex=undefined;var faces=geometry.faces;for(var i=0;i<faces.length;i++){var face=faces[i];// materials
if(face.materialIndex!==materialIndex){materialIndex=face.materialIndex;if(group!==undefined){group.count=i*3-group.start;groups.push(group);}group={start:i*3,materialIndex:materialIndex};}}if(group!==undefined){group.count=i*3-group.start;groups.push(group);}this.groups=groups;},fromGeometry:function(geometry){var faces=geometry.faces;var vertices=geometry.vertices;var faceVertexUvs=geometry.faceVertexUvs;var hasFaceVertexUv=faceVertexUvs[0]&&faceVertexUvs[0].length>0;var hasFaceVertexUv2=faceVertexUvs[1]&&faceVertexUvs[1].length>0;// morphs
var morphTargets=geometry.morphTargets;var morphTargetsLength=morphTargets.length;var morphTargetsPosition;if(morphTargetsLength>0){morphTargetsPosition=[];for(var i=0;i<morphTargetsLength;i++){morphTargetsPosition[i]=[];}this.morphTargets.position=morphTargetsPosition;}var morphNormals=geometry.morphNormals;var morphNormalsLength=morphNormals.length;var morphTargetsNormal;if(morphNormalsLength>0){morphTargetsNormal=[];for(var i=0;i<morphNormalsLength;i++){morphTargetsNormal[i]=[];}this.morphTargets.normal=morphTargetsNormal;}// skins
var skinIndices=geometry.skinIndices;var skinWeights=geometry.skinWeights;var hasSkinIndices=skinIndices.length===vertices.length;var hasSkinWeights=skinWeights.length===vertices.length;//
for(var i=0;i<faces.length;i++){var face=faces[i];this.vertices.push(vertices[face.a],vertices[face.b],vertices[face.c]);var vertexNormals=face.vertexNormals;if(vertexNormals.length===3){this.normals.push(vertexNormals[0],vertexNormals[1],vertexNormals[2]);}else{var normal=face.normal;this.normals.push(normal,normal,normal);}var vertexColors=face.vertexColors;if(vertexColors.length===3){this.colors.push(vertexColors[0],vertexColors[1],vertexColors[2]);}else{var color=face.color;this.colors.push(color,color,color);}if(hasFaceVertexUv===true){var vertexUvs=faceVertexUvs[0][i];if(vertexUvs!==undefined){this.uvs.push(vertexUvs[0],vertexUvs[1],vertexUvs[2]);}else{console.warn('THREE.DirectGeometry.fromGeometry(): Undefined vertexUv ',i);this.uvs.push(new Vector2(),new Vector2(),new Vector2());}}if(hasFaceVertexUv2===true){var vertexUvs=faceVertexUvs[1][i];if(vertexUvs!==undefined){this.uvs2.push(vertexUvs[0],vertexUvs[1],vertexUvs[2]);}else{console.warn('THREE.DirectGeometry.fromGeometry(): Undefined vertexUv2 ',i);this.uvs2.push(new Vector2(),new Vector2(),new Vector2());}}// morphs
for(var j=0;j<morphTargetsLength;j++){var morphTarget=morphTargets[j].vertices;morphTargetsPosition[j].push(morphTarget[face.a],morphTarget[face.b],morphTarget[face.c]);}for(var j=0;j<morphNormalsLength;j++){var morphNormal=morphNormals[j].vertexNormals[i];morphTargetsNormal[j].push(morphNormal.a,morphNormal.b,morphNormal.c);}// skins
if(hasSkinIndices){this.skinIndices.push(skinIndices[face.a],skinIndices[face.b],skinIndices[face.c]);}if(hasSkinWeights){this.skinWeights.push(skinWeights[face.a],skinWeights[face.b],skinWeights[face.c]);}}this.computeGroups(geometry);this.verticesNeedUpdate=geometry.verticesNeedUpdate;this.normalsNeedUpdate=geometry.normalsNeedUpdate;this.colorsNeedUpdate=geometry.colorsNeedUpdate;this.uvsNeedUpdate=geometry.uvsNeedUpdate;this.groupsNeedUpdate=geometry.groupsNeedUpdate;return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/function arrayMax(array){if(array.length===0)return -Infinity;var max=array[0];for(var i=1,l=array.length;i<l;++i){if(array[i]>max)max=array[i];}return max;}/**
* @author alteredq / http://alteredqualia.com/
* @author mrdoob / http://mrdoob.com/
*/var bufferGeometryId=1;// BufferGeometry uses odd numbers as Id
function BufferGeometry(){Object.defineProperty(this,'id',{value:bufferGeometryId+=2});this.uuid=_Math.generateUUID();this.name='';this.type='BufferGeometry';this.index=null;this.attributes={};this.morphAttributes={};this.groups=[];this.boundingBox=null;this.boundingSphere=null;this.drawRange={start:0,count:Infinity};}BufferGeometry.prototype=Object.assign(Object.create(EventDispatcher.prototype),{constructor:BufferGeometry,isBufferGeometry:true,getIndex:function(){return this.index;},setIndex:function(index){if(Array.isArray(index)){this.index=new(arrayMax(index)>65535?Uint32BufferAttribute:Uint16BufferAttribute)(index,1);}else{this.index=index;}},addAttribute:function(name,attribute){if(!(attribute&&attribute.isBufferAttribute)&&!(attribute&&attribute.isInterleavedBufferAttribute)){console.warn('THREE.BufferGeometry: .addAttribute() now expects ( name, attribute ).');this.addAttribute(name,new BufferAttribute(arguments[1],arguments[2]));return;}if(name==='index'){console.warn('THREE.BufferGeometry.addAttribute: Use .setIndex() for index attribute.');this.setIndex(attribute);return;}this.attributes[name]=attribute;return this;},getAttribute:function(name){return this.attributes[name];},removeAttribute:function(name){delete this.attributes[name];return this;},addGroup:function(start,count,materialIndex){this.groups.push({start:start,count:count,materialIndex:materialIndex!==undefined?materialIndex:0});},clearGroups:function(){this.groups=[];},setDrawRange:function(start,count){this.drawRange.start=start;this.drawRange.count=count;},applyMatrix:function(matrix){var position=this.attributes.position;if(position!==undefined){matrix.applyToBufferAttribute(position);position.needsUpdate=true;}var normal=this.attributes.normal;if(normal!==undefined){var normalMatrix=new Matrix3().getNormalMatrix(matrix);normalMatrix.applyToBufferAttribute(normal);normal.needsUpdate=true;}if(this.boundingBox!==null){this.computeBoundingBox();}if(this.boundingSphere!==null){this.computeBoundingSphere();}return this;},rotateX:function(){// rotate geometry around world x-axis
var m1=new Matrix4();return function rotateX(angle){m1.makeRotationX(angle);this.applyMatrix(m1);return this;};}(),rotateY:function(){// rotate geometry around world y-axis
var m1=new Matrix4();return function rotateY(angle){m1.makeRotationY(angle);this.applyMatrix(m1);return this;};}(),rotateZ:function(){// rotate geometry around world z-axis
var m1=new Matrix4();return function rotateZ(angle){m1.makeRotationZ(angle);this.applyMatrix(m1);return this;};}(),translate:function(){// translate geometry
var m1=new Matrix4();return function translate(x,y,z){m1.makeTranslation(x,y,z);this.applyMatrix(m1);return this;};}(),scale:function(){// scale geometry
var m1=new Matrix4();return function scale(x,y,z){m1.makeScale(x,y,z);this.applyMatrix(m1);return this;};}(),lookAt:function(){var obj=new Object3D();return function lookAt(vector){obj.lookAt(vector);obj.updateMatrix();this.applyMatrix(obj.matrix);};}(),center:function(){var offset=new Vector3();return function center(){this.computeBoundingBox();this.boundingBox.getCenter(offset).negate();this.translate(offset.x,offset.y,offset.z);return this;};}(),setFromObject:function(object){// console.log( 'THREE.BufferGeometry.setFromObject(). Converting', object, this );
var geometry=object.geometry;if(object.isPoints||object.isLine){var positions=new Float32BufferAttribute(geometry.vertices.length*3,3);var colors=new Float32BufferAttribute(geometry.colors.length*3,3);this.addAttribute('position',positions.copyVector3sArray(geometry.vertices));this.addAttribute('color',colors.copyColorsArray(geometry.colors));if(geometry.lineDistances&&geometry.lineDistances.length===geometry.vertices.length){var lineDistances=new Float32BufferAttribute(geometry.lineDistances.length,1);this.addAttribute('lineDistance',lineDistances.copyArray(geometry.lineDistances));}if(geometry.boundingSphere!==null){this.boundingSphere=geometry.boundingSphere.clone();}if(geometry.boundingBox!==null){this.boundingBox=geometry.boundingBox.clone();}}else if(object.isMesh){if(geometry&&geometry.isGeometry){this.fromGeometry(geometry);}}return this;},setFromPoints:function(points){var position=[];for(var i=0,l=points.length;i<l;i++){var point=points[i];position.push(point.x,point.y,point.z||0);}this.addAttribute('position',new Float32BufferAttribute(position,3));return this;},updateFromObject:function(object){var geometry=object.geometry;if(object.isMesh){var direct=geometry.__directGeometry;if(geometry.elementsNeedUpdate===true){direct=undefined;geometry.elementsNeedUpdate=false;}if(direct===undefined){return this.fromGeometry(geometry);}direct.verticesNeedUpdate=geometry.verticesNeedUpdate;direct.normalsNeedUpdate=geometry.normalsNeedUpdate;direct.colorsNeedUpdate=geometry.colorsNeedUpdate;direct.uvsNeedUpdate=geometry.uvsNeedUpdate;direct.groupsNeedUpdate=geometry.groupsNeedUpdate;geometry.verticesNeedUpdate=false;geometry.normalsNeedUpdate=false;geometry.colorsNeedUpdate=false;geometry.uvsNeedUpdate=false;geometry.groupsNeedUpdate=false;geometry=direct;}var attribute;if(geometry.verticesNeedUpdate===true){attribute=this.attributes.position;if(attribute!==undefined){attribute.copyVector3sArray(geometry.vertices);attribute.needsUpdate=true;}geometry.verticesNeedUpdate=false;}if(geometry.normalsNeedUpdate===true){attribute=this.attributes.normal;if(attribute!==undefined){attribute.copyVector3sArray(geometry.normals);attribute.needsUpdate=true;}geometry.normalsNeedUpdate=false;}if(geometry.colorsNeedUpdate===true){attribute=this.attributes.color;if(attribute!==undefined){attribute.copyColorsArray(geometry.colors);attribute.needsUpdate=true;}geometry.colorsNeedUpdate=false;}if(geometry.uvsNeedUpdate){attribute=this.attributes.uv;if(attribute!==undefined){attribute.copyVector2sArray(geometry.uvs);attribute.needsUpdate=true;}geometry.uvsNeedUpdate=false;}if(geometry.lineDistancesNeedUpdate){attribute=this.attributes.lineDistance;if(attribute!==undefined){attribute.copyArray(geometry.lineDistances);attribute.needsUpdate=true;}geometry.lineDistancesNeedUpdate=false;}if(geometry.groupsNeedUpdate){geometry.computeGroups(object.geometry);this.groups=geometry.groups;geometry.groupsNeedUpdate=false;}return this;},fromGeometry:function(geometry){geometry.__directGeometry=new DirectGeometry().fromGeometry(geometry);return this.fromDirectGeometry(geometry.__directGeometry);},fromDirectGeometry:function(geometry){var positions=new Float32Array(geometry.vertices.length*3);this.addAttribute('position',new BufferAttribute(positions,3).copyVector3sArray(geometry.vertices));if(geometry.normals.length>0){var normals=new Float32Array(geometry.normals.length*3);this.addAttribute('normal',new BufferAttribute(normals,3).copyVector3sArray(geometry.normals));}if(geometry.colors.length>0){var colors=new Float32Array(geometry.colors.length*3);this.addAttribute('color',new BufferAttribute(colors,3).copyColorsArray(geometry.colors));}if(geometry.uvs.length>0){var uvs=new Float32Array(geometry.uvs.length*2);this.addAttribute('uv',new BufferAttribute(uvs,2).copyVector2sArray(geometry.uvs));}if(geometry.uvs2.length>0){var uvs2=new Float32Array(geometry.uvs2.length*2);this.addAttribute('uv2',new BufferAttribute(uvs2,2).copyVector2sArray(geometry.uvs2));}// groups
this.groups=geometry.groups;// morphs
for(var name in geometry.morphTargets){var array=[];var morphTargets=geometry.morphTargets[name];for(var i=0,l=morphTargets.length;i<l;i++){var morphTarget=morphTargets[i];var attribute=new Float32BufferAttribute(morphTarget.length*3,3);array.push(attribute.copyVector3sArray(morphTarget));}this.morphAttributes[name]=array;}// skinning
if(geometry.skinIndices.length>0){var skinIndices=new Float32BufferAttribute(geometry.skinIndices.length*4,4);this.addAttribute('skinIndex',skinIndices.copyVector4sArray(geometry.skinIndices));}if(geometry.skinWeights.length>0){var skinWeights=new Float32BufferAttribute(geometry.skinWeights.length*4,4);this.addAttribute('skinWeight',skinWeights.copyVector4sArray(geometry.skinWeights));}//
if(geometry.boundingSphere!==null){this.boundingSphere=geometry.boundingSphere.clone();}if(geometry.boundingBox!==null){this.boundingBox=geometry.boundingBox.clone();}return this;},computeBoundingBox:function(){if(this.boundingBox===null){this.boundingBox=new Box3();}var position=this.attributes.position;if(position!==undefined){this.boundingBox.setFromBufferAttribute(position);}else{this.boundingBox.makeEmpty();}if(isNaN(this.boundingBox.min.x)||isNaN(this.boundingBox.min.y)||isNaN(this.boundingBox.min.z)){console.error('THREE.BufferGeometry.computeBoundingBox: Computed min/max have NaN values. The "position" attribute is likely to have NaN values.',this);}},computeBoundingSphere:function(){var box=new Box3();var vector=new Vector3();return function computeBoundingSphere(){if(this.boundingSphere===null){this.boundingSphere=new Sphere();}var position=this.attributes.position;if(position){var center=this.boundingSphere.center;box.setFromBufferAttribute(position);box.getCenter(center);// hoping to find a boundingSphere with a radius smaller than the
// boundingSphere of the boundingBox: sqrt(3) smaller in the best case
var maxRadiusSq=0;for(var i=0,il=position.count;i<il;i++){vector.x=position.getX(i);vector.y=position.getY(i);vector.z=position.getZ(i);maxRadiusSq=Math.max(maxRadiusSq,center.distanceToSquared(vector));}this.boundingSphere.radius=Math.sqrt(maxRadiusSq);if(isNaN(this.boundingSphere.radius)){console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.',this);}}};}(),computeFaceNormals:function(){// backwards compatibility
},computeVertexNormals:function(){var index=this.index;var attributes=this.attributes;var groups=this.groups;if(attributes.position){var positions=attributes.position.array;if(attributes.normal===undefined){this.addAttribute('normal',new BufferAttribute(new Float32Array(positions.length),3));}else{// reset existing normals to zero
var array=attributes.normal.array;for(var i=0,il=array.length;i<il;i++){array[i]=0;}}var normals=attributes.normal.array;var vA,vB,vC;var pA=new Vector3(),pB=new Vector3(),pC=new Vector3();var cb=new Vector3(),ab=new Vector3();// indexed elements
if(index){var indices=index.array;if(groups.length===0){this.addGroup(0,indices.length);}for(var j=0,jl=groups.length;j<jl;++j){var group=groups[j];var start=group.start;var count=group.count;for(var i=start,il=start+count;i<il;i+=3){vA=indices[i+0]*3;vB=indices[i+1]*3;vC=indices[i+2]*3;pA.fromArray(positions,vA);pB.fromArray(positions,vB);pC.fromArray(positions,vC);cb.subVectors(pC,pB);ab.subVectors(pA,pB);cb.cross(ab);normals[vA]+=cb.x;normals[vA+1]+=cb.y;normals[vA+2]+=cb.z;normals[vB]+=cb.x;normals[vB+1]+=cb.y;normals[vB+2]+=cb.z;normals[vC]+=cb.x;normals[vC+1]+=cb.y;normals[vC+2]+=cb.z;}}}else{// non-indexed elements (unconnected triangle soup)
for(var i=0,il=positions.length;i<il;i+=9){pA.fromArray(positions,i);pB.fromArray(positions,i+3);pC.fromArray(positions,i+6);cb.subVectors(pC,pB);ab.subVectors(pA,pB);cb.cross(ab);normals[i]=cb.x;normals[i+1]=cb.y;normals[i+2]=cb.z;normals[i+3]=cb.x;normals[i+4]=cb.y;normals[i+5]=cb.z;normals[i+6]=cb.x;normals[i+7]=cb.y;normals[i+8]=cb.z;}}this.normalizeNormals();attributes.normal.needsUpdate=true;}},merge:function(geometry,offset){if(!(geometry&&geometry.isBufferGeometry)){console.error('THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.',geometry);return;}if(offset===undefined){offset=0;console.warn('THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset=0. '+'Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge.');}var attributes=this.attributes;for(var key in attributes){if(geometry.attributes[key]===undefined)continue;var attribute1=attributes[key];var attributeArray1=attribute1.array;var attribute2=geometry.attributes[key];var attributeArray2=attribute2.array;var attributeSize=attribute2.itemSize;for(var i=0,j=attributeSize*offset;i<attributeArray2.length;i++,j++){attributeArray1[j]=attributeArray2[i];}}return this;},normalizeNormals:function(){var vector=new Vector3();return function normalizeNormals(){var normals=this.attributes.normal;for(var i=0,il=normals.count;i<il;i++){vector.x=normals.getX(i);vector.y=normals.getY(i);vector.z=normals.getZ(i);vector.normalize();normals.setXYZ(i,vector.x,vector.y,vector.z);}};}(),toNonIndexed:function(){if(this.index===null){console.warn('THREE.BufferGeometry.toNonIndexed(): Geometry is already non-indexed.');return this;}var geometry2=new BufferGeometry();var indices=this.index.array;var attributes=this.attributes;for(var name in attributes){var attribute=attributes[name];var array=attribute.array;var itemSize=attribute.itemSize;var array2=new array.constructor(indices.length*itemSize);var index=0,index2=0;for(var i=0,l=indices.length;i<l;i++){index=indices[i]*itemSize;for(var j=0;j<itemSize;j++){array2[index2++]=array[index++];}}geometry2.addAttribute(name,new BufferAttribute(array2,itemSize));}var groups=this.groups;for(var i=0,l=groups.length;i<l;i++){var group=groups[i];geometry2.addGroup(group.start,group.count,group.materialIndex);}return geometry2;},toJSON:function(){var data={metadata:{version:4.5,type:'BufferGeometry',generator:'BufferGeometry.toJSON'}};// standard BufferGeometry serialization
data.uuid=this.uuid;data.type=this.type;if(this.name!=='')data.name=this.name;if(this.parameters!==undefined){var parameters=this.parameters;for(var key in parameters){if(parameters[key]!==undefined)data[key]=parameters[key];}return data;}data.data={attributes:{}};var index=this.index;if(index!==null){var array=Array.prototype.slice.call(index.array);data.data.index={type:index.array.constructor.name,array:array};}var attributes=this.attributes;for(var key in attributes){var attribute=attributes[key];var array=Array.prototype.slice.call(attribute.array);data.data.attributes[key]={itemSize:attribute.itemSize,type:attribute.array.constructor.name,array:array,normalized:attribute.normalized};}var groups=this.groups;if(groups.length>0){data.data.groups=JSON.parse(JSON.stringify(groups));}var boundingSphere=this.boundingSphere;if(boundingSphere!==null){data.data.boundingSphere={center:boundingSphere.center.toArray(),radius:boundingSphere.radius};}return data;},clone:function(){/*
// Handle primitives
var parameters = this.parameters;
if ( parameters !== undefined ) {
var values = [];
for ( var key in parameters ) {
values.push( parameters[ key ] );
}
var geometry = Object.create( this.constructor.prototype );
this.constructor.apply( geometry, values );
return geometry;
}
return new this.constructor().copy( this );
*/return new BufferGeometry().copy(this);},copy:function(source){var name,i,l;// reset
this.index=null;this.attributes={};this.morphAttributes={};this.groups=[];this.boundingBox=null;this.boundingSphere=null;// name
this.name=source.name;// index
var index=source.index;if(index!==null){this.setIndex(index.clone());}// attributes
var attributes=source.attributes;for(name in attributes){var attribute=attributes[name];this.addAttribute(name,attribute.clone());}// morph attributes
var morphAttributes=source.morphAttributes;for(name in morphAttributes){var array=[];var morphAttribute=morphAttributes[name];// morphAttribute: array of Float32BufferAttributes
for(i=0,l=morphAttribute.length;i<l;i++){array.push(morphAttribute[i].clone());}this.morphAttributes[name]=array;}// groups
var groups=source.groups;for(i=0,l=groups.length;i<l;i++){var group=groups[i];this.addGroup(group.start,group.count,group.materialIndex);}// bounding box
var boundingBox=source.boundingBox;if(boundingBox!==null){this.boundingBox=boundingBox.clone();}// bounding sphere
var boundingSphere=source.boundingSphere;if(boundingSphere!==null){this.boundingSphere=boundingSphere.clone();}// draw range
this.drawRange.start=source.drawRange.start;this.drawRange.count=source.drawRange.count;return this;},dispose:function(){this.dispatchEvent({type:'dispose'});}});/**
* @author mrdoob / http://mrdoob.com/
* @author Mugen87 / https://github.com/Mugen87
*/ // BoxGeometry
function BoxGeometry(width,height,depth,widthSegments,heightSegments,depthSegments){Geometry.call(this);this.type='BoxGeometry';this.parameters={width:width,height:height,depth:depth,widthSegments:widthSegments,heightSegments:heightSegments,depthSegments:depthSegments};this.fromBufferGeometry(new BoxBufferGeometry(width,height,depth,widthSegments,heightSegments,depthSegments));this.mergeVertices();}BoxGeometry.prototype=Object.create(Geometry.prototype);BoxGeometry.prototype.constructor=BoxGeometry;// BoxBufferGeometry
function BoxBufferGeometry(width,height,depth,widthSegments,heightSegments,depthSegments){BufferGeometry.call(this);this.type='BoxBufferGeometry';this.parameters={width:width,height:height,depth:depth,widthSegments:widthSegments,heightSegments:heightSegments,depthSegments:depthSegments};var scope=this;width=width||1;height=height||1;depth=depth||1;// segments
widthSegments=Math.floor(widthSegments)||1;heightSegments=Math.floor(heightSegments)||1;depthSegments=Math.floor(depthSegments)||1;// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];// helper variables
var numberOfVertices=0;var groupStart=0;// build each side of the box geometry
buildPlane('z','y','x',-1,-1,depth,height,width,depthSegments,heightSegments,0);// px
buildPlane('z','y','x',1,-1,depth,height,-width,depthSegments,heightSegments,1);// nx
buildPlane('x','z','y',1,1,width,depth,height,widthSegments,depthSegments,2);// py
buildPlane('x','z','y',1,-1,width,depth,-height,widthSegments,depthSegments,3);// ny
buildPlane('x','y','z',1,-1,width,height,depth,widthSegments,heightSegments,4);// pz
buildPlane('x','y','z',-1,-1,width,height,-depth,widthSegments,heightSegments,5);// nz
// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));function buildPlane(u,v,w,udir,vdir,width,height,depth,gridX,gridY,materialIndex){var segmentWidth=width/gridX;var segmentHeight=height/gridY;var widthHalf=width/2;var heightHalf=height/2;var depthHalf=depth/2;var gridX1=gridX+1;var gridY1=gridY+1;var vertexCounter=0;var groupCount=0;var ix,iy;var vector=new Vector3();// generate vertices, normals and uvs
for(iy=0;iy<gridY1;iy++){var y=iy*segmentHeight-heightHalf;for(ix=0;ix<gridX1;ix++){var x=ix*segmentWidth-widthHalf;// set values to correct vector component
vector[u]=x*udir;vector[v]=y*vdir;vector[w]=depthHalf;// now apply vector to vertex buffer
vertices.push(vector.x,vector.y,vector.z);// set values to correct vector component
vector[u]=0;vector[v]=0;vector[w]=depth>0?1:-1;// now apply vector to normal buffer
normals.push(vector.x,vector.y,vector.z);// uvs
uvs.push(ix/gridX);uvs.push(1-iy/gridY);// counters
vertexCounter+=1;}}// indices
// 1. you need three indices to draw a single face
// 2. a single segment consists of two faces
// 3. so we need to generate six (2*3) indices per segment
for(iy=0;iy<gridY;iy++){for(ix=0;ix<gridX;ix++){var a=numberOfVertices+ix+gridX1*iy;var b=numberOfVertices+ix+gridX1*(iy+1);var c=numberOfVertices+(ix+1)+gridX1*(iy+1);var d=numberOfVertices+(ix+1)+gridX1*iy;// faces
indices.push(a,b,d);indices.push(b,c,d);// increase counter
groupCount+=6;}}// add a group to the geometry. this will ensure multi material support
scope.addGroup(groupStart,groupCount,materialIndex);// calculate new start value for groups
groupStart+=groupCount;// update total number of vertices
numberOfVertices+=vertexCounter;}}BoxBufferGeometry.prototype=Object.create(BufferGeometry.prototype);BoxBufferGeometry.prototype.constructor=BoxBufferGeometry;/**
* @author mrdoob / http://mrdoob.com/
* @author Mugen87 / https://github.com/Mugen87
*/ // PlaneGeometry
function PlaneGeometry(width,height,widthSegments,heightSegments){Geometry.call(this);this.type='PlaneGeometry';this.parameters={width:width,height:height,widthSegments:widthSegments,heightSegments:heightSegments};this.fromBufferGeometry(new PlaneBufferGeometry(width,height,widthSegments,heightSegments));this.mergeVertices();}PlaneGeometry.prototype=Object.create(Geometry.prototype);PlaneGeometry.prototype.constructor=PlaneGeometry;// PlaneBufferGeometry
function PlaneBufferGeometry(width,height,widthSegments,heightSegments){BufferGeometry.call(this);this.type='PlaneBufferGeometry';this.parameters={width:width,height:height,widthSegments:widthSegments,heightSegments:heightSegments};width=width||1;height=height||1;var width_half=width/2;var height_half=height/2;var gridX=Math.floor(widthSegments)||1;var gridY=Math.floor(heightSegments)||1;var gridX1=gridX+1;var gridY1=gridY+1;var segment_width=width/gridX;var segment_height=height/gridY;var ix,iy;// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];// generate vertices, normals and uvs
for(iy=0;iy<gridY1;iy++){var y=iy*segment_height-height_half;for(ix=0;ix<gridX1;ix++){var x=ix*segment_width-width_half;vertices.push(x,-y,0);normals.push(0,0,1);uvs.push(ix/gridX);uvs.push(1-iy/gridY);}}// indices
for(iy=0;iy<gridY;iy++){for(ix=0;ix<gridX;ix++){var a=ix+gridX1*iy;var b=ix+gridX1*(iy+1);var c=ix+1+gridX1*(iy+1);var d=ix+1+gridX1*iy;// faces
indices.push(a,b,d);indices.push(b,c,d);}}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));}PlaneBufferGeometry.prototype=Object.create(BufferGeometry.prototype);PlaneBufferGeometry.prototype.constructor=PlaneBufferGeometry;/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*/var materialId=0;function Material(){Object.defineProperty(this,'id',{value:materialId++});this.uuid=_Math.generateUUID();this.name='';this.type='Material';this.fog=true;this.lights=true;this.blending=NormalBlending;this.side=FrontSide;this.flatShading=false;this.vertexColors=NoColors;// THREE.NoColors, THREE.VertexColors, THREE.FaceColors
this.opacity=1;this.transparent=false;this.blendSrc=SrcAlphaFactor;this.blendDst=OneMinusSrcAlphaFactor;this.blendEquation=AddEquation;this.blendSrcAlpha=null;this.blendDstAlpha=null;this.blendEquationAlpha=null;this.depthFunc=LessEqualDepth;this.depthTest=true;this.depthWrite=true;this.clippingPlanes=null;this.clipIntersection=false;this.clipShadows=false;this.shadowSide=null;this.colorWrite=true;this.precision=null;// override the renderer's default precision for this material
this.polygonOffset=false;this.polygonOffsetFactor=0;this.polygonOffsetUnits=0;this.dithering=false;this.alphaTest=0;this.premultipliedAlpha=false;this.overdraw=0;// Overdrawn pixels (typically between 0 and 1) for fixing antialiasing gaps in CanvasRenderer
this.visible=true;this.userData={};this.needsUpdate=true;}Material.prototype=Object.assign(Object.create(EventDispatcher.prototype),{constructor:Material,isMaterial:true,onBeforeCompile:function(){},setValues:function(values){if(values===undefined)return;for(var key in values){var newValue=values[key];if(newValue===undefined){console.warn("THREE.Material: '"+key+"' parameter is undefined.");continue;}// for backward compatability if shading is set in the constructor
if(key==='shading'){console.warn('THREE.'+this.type+': .shading has been removed. Use the boolean .flatShading instead.');this.flatShading=newValue===FlatShading?true:false;continue;}var currentValue=this[key];if(currentValue===undefined){console.warn("THREE."+this.type+": '"+key+"' is not a property of this material.");continue;}if(currentValue&&currentValue.isColor){currentValue.set(newValue);}else if(currentValue&&currentValue.isVector3&&newValue&&newValue.isVector3){currentValue.copy(newValue);}else if(key==='overdraw'){// ensure overdraw is backwards-compatible with legacy boolean type
this[key]=Number(newValue);}else{this[key]=newValue;}}},toJSON:function(meta){var isRoot=meta===undefined||typeof meta==='string';if(isRoot){meta={textures:{},images:{}};}var data={metadata:{version:4.5,type:'Material',generator:'Material.toJSON'}};// standard Material serialization
data.uuid=this.uuid;data.type=this.type;if(this.name!=='')data.name=this.name;if(this.color&&this.color.isColor)data.color=this.color.getHex();if(this.roughness!==undefined)data.roughness=this.roughness;if(this.metalness!==undefined)data.metalness=this.metalness;if(this.emissive&&this.emissive.isColor)data.emissive=this.emissive.getHex();if(this.emissiveIntensity!==1)data.emissiveIntensity=this.emissiveIntensity;if(this.specular&&this.specular.isColor)data.specular=this.specular.getHex();if(this.shininess!==undefined)data.shininess=this.shininess;if(this.clearCoat!==undefined)data.clearCoat=this.clearCoat;if(this.clearCoatRoughness!==undefined)data.clearCoatRoughness=this.clearCoatRoughness;if(this.map&&this.map.isTexture)data.map=this.map.toJSON(meta).uuid;if(this.alphaMap&&this.alphaMap.isTexture)data.alphaMap=this.alphaMap.toJSON(meta).uuid;if(this.lightMap&&this.lightMap.isTexture)data.lightMap=this.lightMap.toJSON(meta).uuid;if(this.bumpMap&&this.bumpMap.isTexture){data.bumpMap=this.bumpMap.toJSON(meta).uuid;data.bumpScale=this.bumpScale;}if(this.normalMap&&this.normalMap.isTexture){data.normalMap=this.normalMap.toJSON(meta).uuid;data.normalScale=this.normalScale.toArray();}if(this.displacementMap&&this.displacementMap.isTexture){data.displacementMap=this.displacementMap.toJSON(meta).uuid;data.displacementScale=this.displacementScale;data.displacementBias=this.displacementBias;}if(this.roughnessMap&&this.roughnessMap.isTexture)data.roughnessMap=this.roughnessMap.toJSON(meta).uuid;if(this.metalnessMap&&this.metalnessMap.isTexture)data.metalnessMap=this.metalnessMap.toJSON(meta).uuid;if(this.emissiveMap&&this.emissiveMap.isTexture)data.emissiveMap=this.emissiveMap.toJSON(meta).uuid;if(this.specularMap&&this.specularMap.isTexture)data.specularMap=this.specularMap.toJSON(meta).uuid;if(this.envMap&&this.envMap.isTexture){data.envMap=this.envMap.toJSON(meta).uuid;data.reflectivity=this.reflectivity;// Scale behind envMap
}if(this.gradientMap&&this.gradientMap.isTexture){data.gradientMap=this.gradientMap.toJSON(meta).uuid;}if(this.size!==undefined)data.size=this.size;if(this.sizeAttenuation!==undefined)data.sizeAttenuation=this.sizeAttenuation;if(this.blending!==NormalBlending)data.blending=this.blending;if(this.flatShading===true)data.flatShading=this.flatShading;if(this.side!==FrontSide)data.side=this.side;if(this.vertexColors!==NoColors)data.vertexColors=this.vertexColors;if(this.opacity<1)data.opacity=this.opacity;if(this.transparent===true)data.transparent=this.transparent;data.depthFunc=this.depthFunc;data.depthTest=this.depthTest;data.depthWrite=this.depthWrite;// rotation (SpriteMaterial)
if(this.rotation!==0)data.rotation=this.rotation;if(this.linewidth!==1)data.linewidth=this.linewidth;if(this.dashSize!==undefined)data.dashSize=this.dashSize;if(this.gapSize!==undefined)data.gapSize=this.gapSize;if(this.scale!==undefined)data.scale=this.scale;if(this.dithering===true)data.dithering=true;if(this.alphaTest>0)data.alphaTest=this.alphaTest;if(this.premultipliedAlpha===true)data.premultipliedAlpha=this.premultipliedAlpha;if(this.wireframe===true)data.wireframe=this.wireframe;if(this.wireframeLinewidth>1)data.wireframeLinewidth=this.wireframeLinewidth;if(this.wireframeLinecap!=='round')data.wireframeLinecap=this.wireframeLinecap;if(this.wireframeLinejoin!=='round')data.wireframeLinejoin=this.wireframeLinejoin;if(this.morphTargets===true)data.morphTargets=true;if(this.skinning===true)data.skinning=true;if(this.visible===false)data.visible=false;if(JSON.stringify(this.userData)!=='{}')data.userData=this.userData;// TODO: Copied from Object3D.toJSON
function extractFromCache(cache){var values=[];for(var key in cache){var data=cache[key];delete data.metadata;values.push(data);}return values;}if(isRoot){var textures=extractFromCache(meta.textures);var images=extractFromCache(meta.images);if(textures.length>0)data.textures=textures;if(images.length>0)data.images=images;}return data;},clone:function(){return new this.constructor().copy(this);},copy:function(source){this.name=source.name;this.fog=source.fog;this.lights=source.lights;this.blending=source.blending;this.side=source.side;this.flatShading=source.flatShading;this.vertexColors=source.vertexColors;this.opacity=source.opacity;this.transparent=source.transparent;this.blendSrc=source.blendSrc;this.blendDst=source.blendDst;this.blendEquation=source.blendEquation;this.blendSrcAlpha=source.blendSrcAlpha;this.blendDstAlpha=source.blendDstAlpha;this.blendEquationAlpha=source.blendEquationAlpha;this.depthFunc=source.depthFunc;this.depthTest=source.depthTest;this.depthWrite=source.depthWrite;this.colorWrite=source.colorWrite;this.precision=source.precision;this.polygonOffset=source.polygonOffset;this.polygonOffsetFactor=source.polygonOffsetFactor;this.polygonOffsetUnits=source.polygonOffsetUnits;this.dithering=source.dithering;this.alphaTest=source.alphaTest;this.premultipliedAlpha=source.premultipliedAlpha;this.overdraw=source.overdraw;this.visible=source.visible;this.userData=JSON.parse(JSON.stringify(source.userData));this.clipShadows=source.clipShadows;this.clipIntersection=source.clipIntersection;var srcPlanes=source.clippingPlanes,dstPlanes=null;if(srcPlanes!==null){var n=srcPlanes.length;dstPlanes=new Array(n);for(var i=0;i!==n;++i)dstPlanes[i]=srcPlanes[i].clone();}this.clippingPlanes=dstPlanes;this.shadowSide=source.shadowSide;return this;},dispose:function(){this.dispatchEvent({type:'dispose'});}});/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*
* parameters = {
* color: <hex>,
* opacity: <float>,
* map: new THREE.Texture( <Image> ),
*
* lightMap: new THREE.Texture( <Image> ),
* lightMapIntensity: <float>
*
* aoMap: new THREE.Texture( <Image> ),
* aoMapIntensity: <float>
*
* specularMap: new THREE.Texture( <Image> ),
*
* alphaMap: new THREE.Texture( <Image> ),
*
* envMap: new THREE.CubeTexture( [posx, negx, posy, negy, posz, negz] ),
* combine: THREE.Multiply,
* reflectivity: <float>,
* refractionRatio: <float>,
*
* depthTest: <bool>,
* depthWrite: <bool>,
*
* wireframe: <boolean>,
* wireframeLinewidth: <float>,
*
* skinning: <bool>,
* morphTargets: <bool>
* }
*/function MeshBasicMaterial(parameters){Material.call(this);this.type='MeshBasicMaterial';this.color=new Color(0xffffff);// emissive
this.map=null;this.lightMap=null;this.lightMapIntensity=1.0;this.aoMap=null;this.aoMapIntensity=1.0;this.specularMap=null;this.alphaMap=null;this.envMap=null;this.combine=MultiplyOperation;this.reflectivity=1;this.refractionRatio=0.98;this.wireframe=false;this.wireframeLinewidth=1;this.wireframeLinecap='round';this.wireframeLinejoin='round';this.skinning=false;this.morphTargets=false;this.lights=false;this.setValues(parameters);}MeshBasicMaterial.prototype=Object.create(Material.prototype);MeshBasicMaterial.prototype.constructor=MeshBasicMaterial;MeshBasicMaterial.prototype.isMeshBasicMaterial=true;MeshBasicMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.color.copy(source.color);this.map=source.map;this.lightMap=source.lightMap;this.lightMapIntensity=source.lightMapIntensity;this.aoMap=source.aoMap;this.aoMapIntensity=source.aoMapIntensity;this.specularMap=source.specularMap;this.alphaMap=source.alphaMap;this.envMap=source.envMap;this.combine=source.combine;this.reflectivity=source.reflectivity;this.refractionRatio=source.refractionRatio;this.wireframe=source.wireframe;this.wireframeLinewidth=source.wireframeLinewidth;this.wireframeLinecap=source.wireframeLinecap;this.wireframeLinejoin=source.wireframeLinejoin;this.skinning=source.skinning;this.morphTargets=source.morphTargets;return this;};/**
* @author alteredq / http://alteredqualia.com/
*
* parameters = {
* defines: { "label" : "value" },
* uniforms: { "parameter1": { value: 1.0 }, "parameter2": { value2: 2 } },
*
* fragmentShader: <string>,
* vertexShader: <string>,
*
* wireframe: <boolean>,
* wireframeLinewidth: <float>,
*
* lights: <bool>,
*
* skinning: <bool>,
* morphTargets: <bool>,
* morphNormals: <bool>
* }
*/function ShaderMaterial(parameters){Material.call(this);this.type='ShaderMaterial';this.defines={};this.uniforms={};this.vertexShader='void main() {\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n}';this.fragmentShader='void main() {\n\tgl_FragColor = vec4( 1.0, 0.0, 0.0, 1.0 );\n}';this.linewidth=1;this.wireframe=false;this.wireframeLinewidth=1;this.fog=false;// set to use scene fog
this.lights=false;// set to use scene lights
this.clipping=false;// set to use user-defined clipping planes
this.skinning=false;// set to use skinning attribute streams
this.morphTargets=false;// set to use morph targets
this.morphNormals=false;// set to use morph normals
this.extensions={derivatives:false,// set to use derivatives
fragDepth:false,// set to use fragment depth values
drawBuffers:false,// set to use draw buffers
shaderTextureLOD:false// set to use shader texture LOD
};// When rendered geometry doesn't include these attributes but the material does,
// use these default values in WebGL. This avoids errors when buffer data is missing.
this.defaultAttributeValues={'color':[1,1,1],'uv':[0,0],'uv2':[0,0]};this.index0AttributeName=undefined;this.uniformsNeedUpdate=false;if(parameters!==undefined){if(parameters.attributes!==undefined){console.error('THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead.');}this.setValues(parameters);}}ShaderMaterial.prototype=Object.create(Material.prototype);ShaderMaterial.prototype.constructor=ShaderMaterial;ShaderMaterial.prototype.isShaderMaterial=true;ShaderMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.fragmentShader=source.fragmentShader;this.vertexShader=source.vertexShader;this.uniforms=UniformsUtils.clone(source.uniforms);this.defines=Object.assign({},source.defines);this.wireframe=source.wireframe;this.wireframeLinewidth=source.wireframeLinewidth;this.lights=source.lights;this.clipping=source.clipping;this.skinning=source.skinning;this.morphTargets=source.morphTargets;this.morphNormals=source.morphNormals;this.extensions=source.extensions;return this;};ShaderMaterial.prototype.toJSON=function(meta){var data=Material.prototype.toJSON.call(this,meta);data.uniforms=this.uniforms;data.vertexShader=this.vertexShader;data.fragmentShader=this.fragmentShader;return data;};/**
* @author bhouston / http://clara.io
*/function Ray(origin,direction){this.origin=origin!==undefined?origin:new Vector3();this.direction=direction!==undefined?direction:new Vector3();}Object.assign(Ray.prototype,{set:function(origin,direction){this.origin.copy(origin);this.direction.copy(direction);return this;},clone:function(){return new this.constructor().copy(this);},copy:function(ray){this.origin.copy(ray.origin);this.direction.copy(ray.direction);return this;},at:function(t,target){if(target===undefined){console.warn('THREE.Ray: .at() target is now required');target=new Vector3();}return target.copy(this.direction).multiplyScalar(t).add(this.origin);},lookAt:function(v){this.direction.copy(v).sub(this.origin).normalize();return this;},recast:function(){var v1=new Vector3();return function recast(t){this.origin.copy(this.at(t,v1));return this;};}(),closestPointToPoint:function(point,target){if(target===undefined){console.warn('THREE.Ray: .closestPointToPoint() target is now required');target=new Vector3();}target.subVectors(point,this.origin);var directionDistance=target.dot(this.direction);if(directionDistance<0){return target.copy(this.origin);}return target.copy(this.direction).multiplyScalar(directionDistance).add(this.origin);},distanceToPoint:function(point){return Math.sqrt(this.distanceSqToPoint(point));},distanceSqToPoint:function(){var v1=new Vector3();return function distanceSqToPoint(point){var directionDistance=v1.subVectors(point,this.origin).dot(this.direction);// point behind the ray
if(directionDistance<0){return this.origin.distanceToSquared(point);}v1.copy(this.direction).multiplyScalar(directionDistance).add(this.origin);return v1.distanceToSquared(point);};}(),distanceSqToSegment:function(){var segCenter=new Vector3();var segDir=new Vector3();var diff=new Vector3();return function distanceSqToSegment(v0,v1,optionalPointOnRay,optionalPointOnSegment){// from http://www.geometrictools.com/GTEngine/Include/Mathematics/GteDistRaySegment.h
// It returns the min distance between the ray and the segment
// defined by v0 and v1
// It can also set two optional targets :
// - The closest point on the ray
// - The closest point on the segment
segCenter.copy(v0).add(v1).multiplyScalar(0.5);segDir.copy(v1).sub(v0).normalize();diff.copy(this.origin).sub(segCenter);var segExtent=v0.distanceTo(v1)*0.5;var a01=-this.direction.dot(segDir);var b0=diff.dot(this.direction);var b1=-diff.dot(segDir);var c=diff.lengthSq();var det=Math.abs(1-a01*a01);var s0,s1,sqrDist,extDet;if(det>0){// The ray and segment are not parallel.
s0=a01*b1-b0;s1=a01*b0-b1;extDet=segExtent*det;if(s0>=0){if(s1>=-extDet){if(s1<=extDet){// region 0
// Minimum at interior points of ray and segment.
var invDet=1/det;s0*=invDet;s1*=invDet;sqrDist=s0*(s0+a01*s1+2*b0)+s1*(a01*s0+s1+2*b1)+c;}else{// region 1
s1=segExtent;s0=Math.max(0,-(a01*s1+b0));sqrDist=-s0*s0+s1*(s1+2*b1)+c;}}else{// region 5
s1=-segExtent;s0=Math.max(0,-(a01*s1+b0));sqrDist=-s0*s0+s1*(s1+2*b1)+c;}}else{if(s1<=-extDet){// region 4
s0=Math.max(0,-(-a01*segExtent+b0));s1=s0>0?-segExtent:Math.min(Math.max(-segExtent,-b1),segExtent);sqrDist=-s0*s0+s1*(s1+2*b1)+c;}else if(s1<=extDet){// region 3
s0=0;s1=Math.min(Math.max(-segExtent,-b1),segExtent);sqrDist=s1*(s1+2*b1)+c;}else{// region 2
s0=Math.max(0,-(a01*segExtent+b0));s1=s0>0?segExtent:Math.min(Math.max(-segExtent,-b1),segExtent);sqrDist=-s0*s0+s1*(s1+2*b1)+c;}}}else{// Ray and segment are parallel.
s1=a01>0?-segExtent:segExtent;s0=Math.max(0,-(a01*s1+b0));sqrDist=-s0*s0+s1*(s1+2*b1)+c;}if(optionalPointOnRay){optionalPointOnRay.copy(this.direction).multiplyScalar(s0).add(this.origin);}if(optionalPointOnSegment){optionalPointOnSegment.copy(segDir).multiplyScalar(s1).add(segCenter);}return sqrDist;};}(),intersectSphere:function(){var v1=new Vector3();return function intersectSphere(sphere,target){v1.subVectors(sphere.center,this.origin);var tca=v1.dot(this.direction);var d2=v1.dot(v1)-tca*tca;var radius2=sphere.radius*sphere.radius;if(d2>radius2)return null;var thc=Math.sqrt(radius2-d2);// t0 = first intersect point - entrance on front of sphere
var t0=tca-thc;// t1 = second intersect point - exit point on back of sphere
var t1=tca+thc;// test to see if both t0 and t1 are behind the ray - if so, return null
if(t0<0&&t1<0)return null;// test to see if t0 is behind the ray:
// if it is, the ray is inside the sphere, so return the second exit point scaled by t1,
// in order to always return an intersect point that is in front of the ray.
if(t0<0)return this.at(t1,target);// else t0 is in front of the ray, so return the first collision point scaled by t0
return this.at(t0,target);};}(),intersectsSphere:function(sphere){return this.distanceToPoint(sphere.center)<=sphere.radius;},distanceToPlane:function(plane){var denominator=plane.normal.dot(this.direction);if(denominator===0){// line is coplanar, return origin
if(plane.distanceToPoint(this.origin)===0){return 0;}// Null is preferable to undefined since undefined means.... it is undefined
return null;}var t=-(this.origin.dot(plane.normal)+plane.constant)/denominator;// Return if the ray never intersects the plane
return t>=0?t:null;},intersectPlane:function(plane,target){var t=this.distanceToPlane(plane);if(t===null){return null;}return this.at(t,target);},intersectsPlane:function(plane){// check if the ray lies on the plane first
var distToPoint=plane.distanceToPoint(this.origin);if(distToPoint===0){return true;}var denominator=plane.normal.dot(this.direction);if(denominator*distToPoint<0){return true;}// ray origin is behind the plane (and is pointing behind it)
return false;},intersectBox:function(box,target){var tmin,tmax,tymin,tymax,tzmin,tzmax;var invdirx=1/this.direction.x,invdiry=1/this.direction.y,invdirz=1/this.direction.z;var origin=this.origin;if(invdirx>=0){tmin=(box.min.x-origin.x)*invdirx;tmax=(box.max.x-origin.x)*invdirx;}else{tmin=(box.max.x-origin.x)*invdirx;tmax=(box.min.x-origin.x)*invdirx;}if(invdiry>=0){tymin=(box.min.y-origin.y)*invdiry;tymax=(box.max.y-origin.y)*invdiry;}else{tymin=(box.max.y-origin.y)*invdiry;tymax=(box.min.y-origin.y)*invdiry;}if(tmin>tymax||tymin>tmax)return null;// These lines also handle the case where tmin or tmax is NaN
// (result of 0 * Infinity). x !== x returns true if x is NaN
if(tymin>tmin||tmin!==tmin)tmin=tymin;if(tymax<tmax||tmax!==tmax)tmax=tymax;if(invdirz>=0){tzmin=(box.min.z-origin.z)*invdirz;tzmax=(box.max.z-origin.z)*invdirz;}else{tzmin=(box.max.z-origin.z)*invdirz;tzmax=(box.min.z-origin.z)*invdirz;}if(tmin>tzmax||tzmin>tmax)return null;if(tzmin>tmin||tmin!==tmin)tmin=tzmin;if(tzmax<tmax||tmax!==tmax)tmax=tzmax;//return point closest to the ray (positive side)
if(tmax<0)return null;return this.at(tmin>=0?tmin:tmax,target);},intersectsBox:function(){var v=new Vector3();return function intersectsBox(box){return this.intersectBox(box,v)!==null;};}(),intersectTriangle:function(){// Compute the offset origin, edges, and normal.
var diff=new Vector3();var edge1=new Vector3();var edge2=new Vector3();var normal=new Vector3();return function intersectTriangle(a,b,c,backfaceCulling,target){// from http://www.geometrictools.com/GTEngine/Include/Mathematics/GteIntrRay3Triangle3.h
edge1.subVectors(b,a);edge2.subVectors(c,a);normal.crossVectors(edge1,edge2);// Solve Q + t*D = b1*E1 + b2*E2 (Q = kDiff, D = ray direction,
// E1 = kEdge1, E2 = kEdge2, N = Cross(E1,E2)) by
// |Dot(D,N)|*b1 = sign(Dot(D,N))*Dot(D,Cross(Q,E2))
// |Dot(D,N)|*b2 = sign(Dot(D,N))*Dot(D,Cross(E1,Q))
// |Dot(D,N)|*t = -sign(Dot(D,N))*Dot(Q,N)
var DdN=this.direction.dot(normal);var sign;if(DdN>0){if(backfaceCulling)return null;sign=1;}else if(DdN<0){sign=-1;DdN=-DdN;}else{return null;}diff.subVectors(this.origin,a);var DdQxE2=sign*this.direction.dot(edge2.crossVectors(diff,edge2));// b1 < 0, no intersection
if(DdQxE2<0){return null;}var DdE1xQ=sign*this.direction.dot(edge1.cross(diff));// b2 < 0, no intersection
if(DdE1xQ<0){return null;}// b1+b2 > 1, no intersection
if(DdQxE2+DdE1xQ>DdN){return null;}// Line intersects triangle, check if ray does.
var QdN=-sign*diff.dot(normal);// t < 0, no intersection
if(QdN<0){return null;}// Ray intersects triangle.
return this.at(QdN/DdN,target);};}(),applyMatrix4:function(matrix4){this.origin.applyMatrix4(matrix4);this.direction.transformDirection(matrix4);return this;},equals:function(ray){return ray.origin.equals(this.origin)&&ray.direction.equals(this.direction);}});/**
* @author bhouston / http://clara.io
*/function Line3(start,end){this.start=start!==undefined?start:new Vector3();this.end=end!==undefined?end:new Vector3();}Object.assign(Line3.prototype,{set:function(start,end){this.start.copy(start);this.end.copy(end);return this;},clone:function(){return new this.constructor().copy(this);},copy:function(line){this.start.copy(line.start);this.end.copy(line.end);return this;},getCenter:function(target){if(target===undefined){console.warn('THREE.Line3: .getCenter() target is now required');target=new Vector3();}return target.addVectors(this.start,this.end).multiplyScalar(0.5);},delta:function(target){if(target===undefined){console.warn('THREE.Line3: .delta() target is now required');target=new Vector3();}return target.subVectors(this.end,this.start);},distanceSq:function(){return this.start.distanceToSquared(this.end);},distance:function(){return this.start.distanceTo(this.end);},at:function(t,target){if(target===undefined){console.warn('THREE.Line3: .at() target is now required');target=new Vector3();}return this.delta(target).multiplyScalar(t).add(this.start);},closestPointToPointParameter:function(){var startP=new Vector3();var startEnd=new Vector3();return function closestPointToPointParameter(point,clampToLine){startP.subVectors(point,this.start);startEnd.subVectors(this.end,this.start);var startEnd2=startEnd.dot(startEnd);var startEnd_startP=startEnd.dot(startP);var t=startEnd_startP/startEnd2;if(clampToLine){t=_Math.clamp(t,0,1);}return t;};}(),closestPointToPoint:function(point,clampToLine,target){var t=this.closestPointToPointParameter(point,clampToLine);if(target===undefined){console.warn('THREE.Line3: .closestPointToPoint() target is now required');target=new Vector3();}return this.delta(target).multiplyScalar(t).add(this.start);},applyMatrix4:function(matrix){this.start.applyMatrix4(matrix);this.end.applyMatrix4(matrix);return this;},equals:function(line){return line.start.equals(this.start)&&line.end.equals(this.end);}});/**
* @author bhouston / http://clara.io
* @author mrdoob / http://mrdoob.com/
*/function Triangle(a,b,c){this.a=a!==undefined?a:new Vector3();this.b=b!==undefined?b:new Vector3();this.c=c!==undefined?c:new Vector3();}Object.assign(Triangle,{getNormal:function(){var v0=new Vector3();return function getNormal(a,b,c,target){if(target===undefined){console.warn('THREE.Triangle: .getNormal() target is now required');target=new Vector3();}target.subVectors(c,b);v0.subVectors(a,b);target.cross(v0);var targetLengthSq=target.lengthSq();if(targetLengthSq>0){return target.multiplyScalar(1/Math.sqrt(targetLengthSq));}return target.set(0,0,0);};}(),// static/instance method to calculate barycentric coordinates
// based on: http://www.blackpawn.com/texts/pointinpoly/default.html
getBarycoord:function(){var v0=new Vector3();var v1=new Vector3();var v2=new Vector3();return function getBarycoord(point,a,b,c,target){v0.subVectors(c,a);v1.subVectors(b,a);v2.subVectors(point,a);var dot00=v0.dot(v0);var dot01=v0.dot(v1);var dot02=v0.dot(v2);var dot11=v1.dot(v1);var dot12=v1.dot(v2);var denom=dot00*dot11-dot01*dot01;if(target===undefined){console.warn('THREE.Triangle: .getBarycoord() target is now required');target=new Vector3();}// collinear or singular triangle
if(denom===0){// arbitrary location outside of triangle?
// not sure if this is the best idea, maybe should be returning undefined
return target.set(-2,-1,-1);}var invDenom=1/denom;var u=(dot11*dot02-dot01*dot12)*invDenom;var v=(dot00*dot12-dot01*dot02)*invDenom;// barycentric coordinates must always sum to 1
return target.set(1-u-v,v,u);};}(),containsPoint:function(){var v1=new Vector3();return function containsPoint(point,a,b,c){Triangle.getBarycoord(point,a,b,c,v1);return v1.x>=0&&v1.y>=0&&v1.x+v1.y<=1;};}()});Object.assign(Triangle.prototype,{set:function(a,b,c){this.a.copy(a);this.b.copy(b);this.c.copy(c);return this;},setFromPointsAndIndices:function(points,i0,i1,i2){this.a.copy(points[i0]);this.b.copy(points[i1]);this.c.copy(points[i2]);return this;},clone:function(){return new this.constructor().copy(this);},copy:function(triangle){this.a.copy(triangle.a);this.b.copy(triangle.b);this.c.copy(triangle.c);return this;},getArea:function(){var v0=new Vector3();var v1=new Vector3();return function getArea(){v0.subVectors(this.c,this.b);v1.subVectors(this.a,this.b);return v0.cross(v1).length()*0.5;};}(),getMidpoint:function(target){if(target===undefined){console.warn('THREE.Triangle: .getMidpoint() target is now required');target=new Vector3();}return target.addVectors(this.a,this.b).add(this.c).multiplyScalar(1/3);},getNormal:function(target){return Triangle.getNormal(this.a,this.b,this.c,target);},getPlane:function(target){if(target===undefined){console.warn('THREE.Triangle: .getPlane() target is now required');target=new Vector3();}return target.setFromCoplanarPoints(this.a,this.b,this.c);},getBarycoord:function(point,target){return Triangle.getBarycoord(point,this.a,this.b,this.c,target);},containsPoint:function(point){return Triangle.containsPoint(point,this.a,this.b,this.c);},intersectsBox:function(box){return box.intersectsTriangle(this);},closestPointToPoint:function(){var plane=new Plane();var edgeList=[new Line3(),new Line3(),new Line3()];var projectedPoint=new Vector3();var closestPoint=new Vector3();return function closestPointToPoint(point,target){if(target===undefined){console.warn('THREE.Triangle: .closestPointToPoint() target is now required');target=new Vector3();}var minDistance=Infinity;// project the point onto the plane of the triangle
plane.setFromCoplanarPoints(this.a,this.b,this.c);plane.projectPoint(point,projectedPoint);// check if the projection lies within the triangle
if(this.containsPoint(projectedPoint)===true){// if so, this is the closest point
target.copy(projectedPoint);}else{// if not, the point falls outside the triangle. the target is the closest point to the triangle's edges or vertices
edgeList[0].set(this.a,this.b);edgeList[1].set(this.b,this.c);edgeList[2].set(this.c,this.a);for(var i=0;i<edgeList.length;i++){edgeList[i].closestPointToPoint(projectedPoint,true,closestPoint);var distance=projectedPoint.distanceToSquared(closestPoint);if(distance<minDistance){minDistance=distance;target.copy(closestPoint);}}}return target;};}(),equals:function(triangle){return triangle.a.equals(this.a)&&triangle.b.equals(this.b)&&triangle.c.equals(this.c);}});/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
* @author mikael emtinger / http://gomo.se/
* @author jonobr1 / http://jonobr1.com/
*/function Mesh(geometry,material){Object3D.call(this);this.type='Mesh';this.geometry=geometry!==undefined?geometry:new BufferGeometry();this.material=material!==undefined?material:new MeshBasicMaterial({color:Math.random()*0xffffff});this.drawMode=TrianglesDrawMode;this.updateMorphTargets();}Mesh.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Mesh,isMesh:true,setDrawMode:function(value){this.drawMode=value;},copy:function(source){Object3D.prototype.copy.call(this,source);this.drawMode=source.drawMode;if(source.morphTargetInfluences!==undefined){this.morphTargetInfluences=source.morphTargetInfluences.slice();}if(source.morphTargetDictionary!==undefined){this.morphTargetDictionary=Object.assign({},source.morphTargetDictionary);}return this;},updateMorphTargets:function(){var geometry=this.geometry;var m,ml,name;if(geometry.isBufferGeometry){var morphAttributes=geometry.morphAttributes;var keys=Object.keys(morphAttributes);if(keys.length>0){var morphAttribute=morphAttributes[keys[0]];if(morphAttribute!==undefined){this.morphTargetInfluences=[];this.morphTargetDictionary={};for(m=0,ml=morphAttribute.length;m<ml;m++){name=morphAttribute[m].name||String(m);this.morphTargetInfluences.push(0);this.morphTargetDictionary[name]=m;}}}}else{var morphTargets=geometry.morphTargets;if(morphTargets!==undefined&&morphTargets.length>0){this.morphTargetInfluences=[];this.morphTargetDictionary={};for(m=0,ml=morphTargets.length;m<ml;m++){name=morphTargets[m].name||String(m);this.morphTargetInfluences.push(0);this.morphTargetDictionary[name]=m;}}}},raycast:function(){var inverseMatrix=new Matrix4();var ray=new Ray();var sphere=new Sphere();var vA=new Vector3();var vB=new Vector3();var vC=new Vector3();var tempA=new Vector3();var tempB=new Vector3();var tempC=new Vector3();var uvA=new Vector2();var uvB=new Vector2();var uvC=new Vector2();var barycoord=new Vector3();var intersectionPoint=new Vector3();var intersectionPointWorld=new Vector3();function uvIntersection(point,p1,p2,p3,uv1,uv2,uv3){Triangle.getBarycoord(point,p1,p2,p3,barycoord);uv1.multiplyScalar(barycoord.x);uv2.multiplyScalar(barycoord.y);uv3.multiplyScalar(barycoord.z);uv1.add(uv2).add(uv3);return uv1.clone();}function checkIntersection(object,material,raycaster,ray,pA,pB,pC,point){var intersect;if(material.side===BackSide){intersect=ray.intersectTriangle(pC,pB,pA,true,point);}else{intersect=ray.intersectTriangle(pA,pB,pC,material.side!==DoubleSide,point);}if(intersect===null)return null;intersectionPointWorld.copy(point);intersectionPointWorld.applyMatrix4(object.matrixWorld);var distance=raycaster.ray.origin.distanceTo(intersectionPointWorld);if(distance<raycaster.near||distance>raycaster.far)return null;return {distance:distance,point:intersectionPointWorld.clone(),object:object};}function checkBufferGeometryIntersection(object,raycaster,ray,position,uv,a,b,c){vA.fromBufferAttribute(position,a);vB.fromBufferAttribute(position,b);vC.fromBufferAttribute(position,c);var intersection=checkIntersection(object,object.material,raycaster,ray,vA,vB,vC,intersectionPoint);if(intersection){if(uv){uvA.fromBufferAttribute(uv,a);uvB.fromBufferAttribute(uv,b);uvC.fromBufferAttribute(uv,c);intersection.uv=uvIntersection(intersectionPoint,vA,vB,vC,uvA,uvB,uvC);}var face=new Face3(a,b,c);Triangle.getNormal(vA,vB,vC,face.normal);intersection.face=face;intersection.faceIndex=a;}return intersection;}return function raycast(raycaster,intersects){var geometry=this.geometry;var material=this.material;var matrixWorld=this.matrixWorld;if(material===undefined)return;// Checking boundingSphere distance to ray
if(geometry.boundingSphere===null)geometry.computeBoundingSphere();sphere.copy(geometry.boundingSphere);sphere.applyMatrix4(matrixWorld);if(raycaster.ray.intersectsSphere(sphere)===false)return;//
inverseMatrix.getInverse(matrixWorld);ray.copy(raycaster.ray).applyMatrix4(inverseMatrix);// Check boundingBox before continuing
if(geometry.boundingBox!==null){if(ray.intersectsBox(geometry.boundingBox)===false)return;}var intersection;if(geometry.isBufferGeometry){var a,b,c;var index=geometry.index;var position=geometry.attributes.position;var uv=geometry.attributes.uv;var i,l;if(index!==null){// indexed buffer geometry
for(i=0,l=index.count;i<l;i+=3){a=index.getX(i);b=index.getX(i+1);c=index.getX(i+2);intersection=checkBufferGeometryIntersection(this,raycaster,ray,position,uv,a,b,c);if(intersection){intersection.faceIndex=Math.floor(i/3);// triangle number in indices buffer semantics
intersects.push(intersection);}}}else if(position!==undefined){// non-indexed buffer geometry
for(i=0,l=position.count;i<l;i+=3){a=i;b=i+1;c=i+2;intersection=checkBufferGeometryIntersection(this,raycaster,ray,position,uv,a,b,c);if(intersection)intersects.push(intersection);}}}else if(geometry.isGeometry){var fvA,fvB,fvC;var isMultiMaterial=Array.isArray(material);var vertices=geometry.vertices;var faces=geometry.faces;var uvs;var faceVertexUvs=geometry.faceVertexUvs[0];if(faceVertexUvs.length>0)uvs=faceVertexUvs;for(var f=0,fl=faces.length;f<fl;f++){var face=faces[f];var faceMaterial=isMultiMaterial?material[face.materialIndex]:material;if(faceMaterial===undefined)continue;fvA=vertices[face.a];fvB=vertices[face.b];fvC=vertices[face.c];if(faceMaterial.morphTargets===true){var morphTargets=geometry.morphTargets;var morphInfluences=this.morphTargetInfluences;vA.set(0,0,0);vB.set(0,0,0);vC.set(0,0,0);for(var t=0,tl=morphTargets.length;t<tl;t++){var influence=morphInfluences[t];if(influence===0)continue;var targets=morphTargets[t].vertices;vA.addScaledVector(tempA.subVectors(targets[face.a],fvA),influence);vB.addScaledVector(tempB.subVectors(targets[face.b],fvB),influence);vC.addScaledVector(tempC.subVectors(targets[face.c],fvC),influence);}vA.add(fvA);vB.add(fvB);vC.add(fvC);fvA=vA;fvB=vB;fvC=vC;}intersection=checkIntersection(this,faceMaterial,raycaster,ray,fvA,fvB,fvC,intersectionPoint);if(intersection){if(uvs&&uvs[f]){var uvs_f=uvs[f];uvA.copy(uvs_f[0]);uvB.copy(uvs_f[1]);uvC.copy(uvs_f[2]);intersection.uv=uvIntersection(intersectionPoint,fvA,fvB,fvC,uvA,uvB,uvC);}intersection.face=face;intersection.faceIndex=f;intersects.push(intersection);}}}};}(),clone:function(){return new this.constructor(this.geometry,this.material).copy(this);}});/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLBackground(renderer,state,geometries,premultipliedAlpha){var clearColor=new Color(0x000000);var clearAlpha=0;var planeCamera,planeMesh;var boxMesh;function render(renderList,scene,camera,forceClear){var background=scene.background;if(background===null){setClear(clearColor,clearAlpha);}else if(background&&background.isColor){setClear(background,1);forceClear=true;}if(renderer.autoClear||forceClear){renderer.clear(renderer.autoClearColor,renderer.autoClearDepth,renderer.autoClearStencil);}if(background&&background.isCubeTexture){if(boxMesh===undefined){boxMesh=new Mesh(new BoxBufferGeometry(1,1,1),new ShaderMaterial({uniforms:ShaderLib.cube.uniforms,vertexShader:ShaderLib.cube.vertexShader,fragmentShader:ShaderLib.cube.fragmentShader,side:BackSide,depthTest:true,depthWrite:false,fog:false}));boxMesh.geometry.removeAttribute('normal');boxMesh.geometry.removeAttribute('uv');boxMesh.onBeforeRender=function(renderer,scene,camera){this.matrixWorld.copyPosition(camera.matrixWorld);};geometries.update(boxMesh.geometry);}boxMesh.material.uniforms.tCube.value=background;renderList.push(boxMesh,boxMesh.geometry,boxMesh.material,0,null);}else if(background&&background.isTexture){if(planeCamera===undefined){planeCamera=new OrthographicCamera(-1,1,1,-1,0,1);planeMesh=new Mesh(new PlaneBufferGeometry(2,2),new MeshBasicMaterial({depthTest:false,depthWrite:false,fog:false}));geometries.update(planeMesh.geometry);}planeMesh.material.map=background;// TODO Push this to renderList
renderer.renderBufferDirect(planeCamera,null,planeMesh.geometry,planeMesh.material,planeMesh,null);}}function setClear(color,alpha){state.buffers.color.setClear(color.r,color.g,color.b,alpha,premultipliedAlpha);}return {getClearColor:function(){return clearColor;},setClearColor:function(color,alpha){clearColor.set(color);clearAlpha=alpha!==undefined?alpha:1;setClear(clearColor,clearAlpha);},getClearAlpha:function(){return clearAlpha;},setClearAlpha:function(alpha){clearAlpha=alpha;setClear(clearColor,clearAlpha);},render:render};}/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLBufferRenderer(gl,extensions,info){var mode;function setMode(value){mode=value;}function render(start,count){gl.drawArrays(mode,start,count);info.update(count,mode);}function renderInstances(geometry,start,count){var extension=extensions.get('ANGLE_instanced_arrays');if(extension===null){console.error('THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.');return;}var position=geometry.attributes.position;if(position.isInterleavedBufferAttribute){count=position.data.count;extension.drawArraysInstancedANGLE(mode,0,count,geometry.maxInstancedCount);}else{extension.drawArraysInstancedANGLE(mode,start,count,geometry.maxInstancedCount);}info.update(count,mode,geometry.maxInstancedCount);}//
this.setMode=setMode;this.render=render;this.renderInstances=renderInstances;}/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLCapabilities(gl,extensions,parameters){var maxAnisotropy;function getMaxAnisotropy(){if(maxAnisotropy!==undefined)return maxAnisotropy;var extension=extensions.get('EXT_texture_filter_anisotropic');if(extension!==null){maxAnisotropy=gl.getParameter(extension.MAX_TEXTURE_MAX_ANISOTROPY_EXT);}else{maxAnisotropy=0;}return maxAnisotropy;}function getMaxPrecision(precision){if(precision==='highp'){if(gl.getShaderPrecisionFormat(gl.VERTEX_SHADER,gl.HIGH_FLOAT).precision>0&&gl.getShaderPrecisionFormat(gl.FRAGMENT_SHADER,gl.HIGH_FLOAT).precision>0){return 'highp';}precision='mediump';}if(precision==='mediump'){if(gl.getShaderPrecisionFormat(gl.VERTEX_SHADER,gl.MEDIUM_FLOAT).precision>0&&gl.getShaderPrecisionFormat(gl.FRAGMENT_SHADER,gl.MEDIUM_FLOAT).precision>0){return 'mediump';}}return 'lowp';}var precision=parameters.precision!==undefined?parameters.precision:'highp';var maxPrecision=getMaxPrecision(precision);if(maxPrecision!==precision){console.warn('THREE.WebGLRenderer:',precision,'not supported, using',maxPrecision,'instead.');precision=maxPrecision;}var logarithmicDepthBuffer=parameters.logarithmicDepthBuffer===true;var maxTextures=gl.getParameter(gl.MAX_TEXTURE_IMAGE_UNITS);var maxVertexTextures=gl.getParameter(gl.MAX_VERTEX_TEXTURE_IMAGE_UNITS);var maxTextureSize=gl.getParameter(gl.MAX_TEXTURE_SIZE);var maxCubemapSize=gl.getParameter(gl.MAX_CUBE_MAP_TEXTURE_SIZE);var maxAttributes=gl.getParameter(gl.MAX_VERTEX_ATTRIBS);var maxVertexUniforms=gl.getParameter(gl.MAX_VERTEX_UNIFORM_VECTORS);var maxVaryings=gl.getParameter(gl.MAX_VARYING_VECTORS);var maxFragmentUniforms=gl.getParameter(gl.MAX_FRAGMENT_UNIFORM_VECTORS);var vertexTextures=maxVertexTextures>0;var floatFragmentTextures=!!extensions.get('OES_texture_float');var floatVertexTextures=vertexTextures&&floatFragmentTextures;return {getMaxAnisotropy:getMaxAnisotropy,getMaxPrecision:getMaxPrecision,precision:precision,logarithmicDepthBuffer:logarithmicDepthBuffer,maxTextures:maxTextures,maxVertexTextures:maxVertexTextures,maxTextureSize:maxTextureSize,maxCubemapSize:maxCubemapSize,maxAttributes:maxAttributes,maxVertexUniforms:maxVertexUniforms,maxVaryings:maxVaryings,maxFragmentUniforms:maxFragmentUniforms,vertexTextures:vertexTextures,floatFragmentTextures:floatFragmentTextures,floatVertexTextures:floatVertexTextures};}/**
* @author tschw
*/function WebGLClipping(){var scope=this,globalState=null,numGlobalPlanes=0,localClippingEnabled=false,renderingShadows=false,plane=new Plane(),viewNormalMatrix=new Matrix3(),uniform={value:null,needsUpdate:false};this.uniform=uniform;this.numPlanes=0;this.numIntersection=0;this.init=function(planes,enableLocalClipping,camera){var enabled=planes.length!==0||enableLocalClipping||// enable state of previous frame - the clipping code has to
// run another frame in order to reset the state:
numGlobalPlanes!==0||localClippingEnabled;localClippingEnabled=enableLocalClipping;globalState=projectPlanes(planes,camera,0);numGlobalPlanes=planes.length;return enabled;};this.beginShadows=function(){renderingShadows=true;projectPlanes(null);};this.endShadows=function(){renderingShadows=false;resetGlobalState();};this.setState=function(planes,clipIntersection,clipShadows,camera,cache,fromCache){if(!localClippingEnabled||planes===null||planes.length===0||renderingShadows&&!clipShadows){// there's no local clipping
if(renderingShadows){// there's no global clipping
projectPlanes(null);}else{resetGlobalState();}}else{var nGlobal=renderingShadows?0:numGlobalPlanes,lGlobal=nGlobal*4,dstArray=cache.clippingState||null;uniform.value=dstArray;// ensure unique state
dstArray=projectPlanes(planes,camera,lGlobal,fromCache);for(var i=0;i!==lGlobal;++i){dstArray[i]=globalState[i];}cache.clippingState=dstArray;this.numIntersection=clipIntersection?this.numPlanes:0;this.numPlanes+=nGlobal;}};function resetGlobalState(){if(uniform.value!==globalState){uniform.value=globalState;uniform.needsUpdate=numGlobalPlanes>0;}scope.numPlanes=numGlobalPlanes;scope.numIntersection=0;}function projectPlanes(planes,camera,dstOffset,skipTransform){var nPlanes=planes!==null?planes.length:0,dstArray=null;if(nPlanes!==0){dstArray=uniform.value;if(skipTransform!==true||dstArray===null){var flatSize=dstOffset+nPlanes*4,viewMatrix=camera.matrixWorldInverse;viewNormalMatrix.getNormalMatrix(viewMatrix);if(dstArray===null||dstArray.length<flatSize){dstArray=new Float32Array(flatSize);}for(var i=0,i4=dstOffset;i!==nPlanes;++i,i4+=4){plane.copy(planes[i]).applyMatrix4(viewMatrix,viewNormalMatrix);plane.normal.toArray(dstArray,i4);dstArray[i4+3]=plane.constant;}}uniform.value=dstArray;uniform.needsUpdate=true;}scope.numPlanes=nPlanes;return dstArray;}}/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLExtensions(gl){var extensions={};return {get:function(name){if(extensions[name]!==undefined){return extensions[name];}var extension;switch(name){case'WEBGL_depth_texture':extension=gl.getExtension('WEBGL_depth_texture')||gl.getExtension('MOZ_WEBGL_depth_texture')||gl.getExtension('WEBKIT_WEBGL_depth_texture');break;case'EXT_texture_filter_anisotropic':extension=gl.getExtension('EXT_texture_filter_anisotropic')||gl.getExtension('MOZ_EXT_texture_filter_anisotropic')||gl.getExtension('WEBKIT_EXT_texture_filter_anisotropic');break;case'WEBGL_compressed_texture_s3tc':extension=gl.getExtension('WEBGL_compressed_texture_s3tc')||gl.getExtension('MOZ_WEBGL_compressed_texture_s3tc')||gl.getExtension('WEBKIT_WEBGL_compressed_texture_s3tc');break;case'WEBGL_compressed_texture_pvrtc':extension=gl.getExtension('WEBGL_compressed_texture_pvrtc')||gl.getExtension('WEBKIT_WEBGL_compressed_texture_pvrtc');break;default:extension=gl.getExtension(name);}if(extension===null){console.warn('THREE.WebGLRenderer: '+name+' extension not supported.');}extensions[name]=extension;return extension;}};}/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLGeometries(gl,attributes,info){var geometries={};var wireframeAttributes={};function onGeometryDispose(event){var geometry=event.target;var buffergeometry=geometries[geometry.id];if(buffergeometry.index!==null){attributes.remove(buffergeometry.index);}for(var name in buffergeometry.attributes){attributes.remove(buffergeometry.attributes[name]);}geometry.removeEventListener('dispose',onGeometryDispose);delete geometries[geometry.id];// TODO Remove duplicate code
var attribute=wireframeAttributes[geometry.id];if(attribute){attributes.remove(attribute);delete wireframeAttributes[geometry.id];}attribute=wireframeAttributes[buffergeometry.id];if(attribute){attributes.remove(attribute);delete wireframeAttributes[buffergeometry.id];}//
info.memory.geometries--;}function get(object,geometry){var buffergeometry=geometries[geometry.id];if(buffergeometry)return buffergeometry;geometry.addEventListener('dispose',onGeometryDispose);if(geometry.isBufferGeometry){buffergeometry=geometry;}else if(geometry.isGeometry){if(geometry._bufferGeometry===undefined){geometry._bufferGeometry=new BufferGeometry().setFromObject(object);}buffergeometry=geometry._bufferGeometry;}geometries[geometry.id]=buffergeometry;info.memory.geometries++;return buffergeometry;}function update(geometry){var index=geometry.index;var geometryAttributes=geometry.attributes;if(index!==null){attributes.update(index,gl.ELEMENT_ARRAY_BUFFER);}for(var name in geometryAttributes){attributes.update(geometryAttributes[name],gl.ARRAY_BUFFER);}// morph targets
var morphAttributes=geometry.morphAttributes;for(var name in morphAttributes){var array=morphAttributes[name];for(var i=0,l=array.length;i<l;i++){attributes.update(array[i],gl.ARRAY_BUFFER);}}}function getWireframeAttribute(geometry){var attribute=wireframeAttributes[geometry.id];if(attribute)return attribute;var indices=[];var geometryIndex=geometry.index;var geometryAttributes=geometry.attributes;// console.time( 'wireframe' );
if(geometryIndex!==null){var array=geometryIndex.array;for(var i=0,l=array.length;i<l;i+=3){var a=array[i+0];var b=array[i+1];var c=array[i+2];indices.push(a,b,b,c,c,a);}}else{var array=geometryAttributes.position.array;for(var i=0,l=array.length/3-1;i<l;i+=3){var a=i+0;var b=i+1;var c=i+2;indices.push(a,b,b,c,c,a);}}// console.timeEnd( 'wireframe' );
attribute=new(arrayMax(indices)>65535?Uint32BufferAttribute:Uint16BufferAttribute)(indices,1);attributes.update(attribute,gl.ELEMENT_ARRAY_BUFFER);wireframeAttributes[geometry.id]=attribute;return attribute;}return {get:get,update:update,getWireframeAttribute:getWireframeAttribute};}/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLIndexedBufferRenderer(gl,extensions,info){var mode;function setMode(value){mode=value;}var type,bytesPerElement;function setIndex(value){type=value.type;bytesPerElement=value.bytesPerElement;}function render(start,count){gl.drawElements(mode,count,type,start*bytesPerElement);info.update(count,mode);}function renderInstances(geometry,start,count){var extension=extensions.get('ANGLE_instanced_arrays');if(extension===null){console.error('THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.');return;}extension.drawElementsInstancedANGLE(mode,count,type,start*bytesPerElement,geometry.maxInstancedCount);info.update(count,mode,geometry.maxInstancedCount);}//
this.setMode=setMode;this.setIndex=setIndex;this.render=render;this.renderInstances=renderInstances;}/**
* @author Mugen87 / https://github.com/Mugen87
*/function WebGLInfo(gl){var memory={geometries:0,textures:0};var render={frame:0,calls:0,triangles:0,points:0,lines:0};function update(count,mode,instanceCount){instanceCount=instanceCount||1;render.calls++;switch(mode){case gl.TRIANGLES:render.triangles+=instanceCount*(count/3);break;case gl.TRIANGLE_STRIP:case gl.TRIANGLE_FAN:render.triangles+=instanceCount*(count-2);break;case gl.LINES:render.lines+=instanceCount*(count/2);break;case gl.LINE_STRIP:render.lines+=instanceCount*(count-1);break;case gl.LINE_LOOP:render.lines+=instanceCount*count;break;case gl.POINTS:render.points+=instanceCount*count;break;default:console.error('THREE.WebGLInfo: Unknown draw mode:',mode);break;}}function reset(){render.frame++;render.calls=0;render.triangles=0;render.points=0;render.lines=0;}return {memory:memory,render:render,programs:null,autoReset:true,reset:reset,update:update};}/**
* @author mrdoob / http://mrdoob.com/
*/function absNumericalSort(a,b){return Math.abs(b[1])-Math.abs(a[1]);}function WebGLMorphtargets(gl){var influencesList={};var morphInfluences=new Float32Array(8);function update(object,geometry,material,program){var objectInfluences=object.morphTargetInfluences;var length=objectInfluences.length;var influences=influencesList[geometry.id];if(influences===undefined){// initialise list
influences=[];for(var i=0;i<length;i++){influences[i]=[i,0];}influencesList[geometry.id]=influences;}var morphTargets=material.morphTargets&&geometry.morphAttributes.position;var morphNormals=material.morphNormals&&geometry.morphAttributes.normal;// Remove current morphAttributes
for(var i=0;i<length;i++){var influence=influences[i];if(influence[1]!==0){if(morphTargets)geometry.removeAttribute('morphTarget'+i);if(morphNormals)geometry.removeAttribute('morphNormal'+i);}}// Collect influences
for(var i=0;i<length;i++){var influence=influences[i];influence[0]=i;influence[1]=objectInfluences[i];}influences.sort(absNumericalSort);// Add morphAttributes
for(var i=0;i<8;i++){var influence=influences[i];if(influence){var index=influence[0];var value=influence[1];if(value){if(morphTargets)geometry.addAttribute('morphTarget'+i,morphTargets[index]);if(morphNormals)geometry.addAttribute('morphNormal'+i,morphNormals[index]);morphInfluences[i]=value;continue;}}morphInfluences[i]=0;}program.getUniforms().setValue(gl,'morphTargetInfluences',morphInfluences);}return {update:update};}/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLObjects(geometries,info){var updateList={};function update(object){var frame=info.render.frame;var geometry=object.geometry;var buffergeometry=geometries.get(object,geometry);// Update once per frame
if(updateList[buffergeometry.id]!==frame){if(geometry.isGeometry){buffergeometry.updateFromObject(object);}geometries.update(buffergeometry);updateList[buffergeometry.id]=frame;}return buffergeometry;}function dispose(){updateList={};}return {update:update,dispose:dispose};}/**
* @author mrdoob / http://mrdoob.com/
*/function CubeTexture(images,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy,encoding){images=images!==undefined?images:[];mapping=mapping!==undefined?mapping:CubeReflectionMapping;Texture.call(this,images,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy,encoding);this.flipY=false;}CubeTexture.prototype=Object.create(Texture.prototype);CubeTexture.prototype.constructor=CubeTexture;CubeTexture.prototype.isCubeTexture=true;Object.defineProperty(CubeTexture.prototype,'images',{get:function(){return this.image;},set:function(value){this.image=value;}});/**
* @author tschw
*
* Uniforms of a program.
* Those form a tree structure with a special top-level container for the root,
* which you get by calling 'new WebGLUniforms( gl, program, renderer )'.
*
*
* Properties of inner nodes including the top-level container:
*
* .seq - array of nested uniforms
* .map - nested uniforms by name
*
*
* Methods of all nodes except the top-level container:
*
* .setValue( gl, value, [renderer] )
*
* uploads a uniform value(s)
* the 'renderer' parameter is needed for sampler uniforms
*
*
* Static methods of the top-level container (renderer factorizations):
*
* .upload( gl, seq, values, renderer )
*
* sets uniforms in 'seq' to 'values[id].value'
*
* .seqWithValue( seq, values ) : filteredSeq
*
* filters 'seq' entries with corresponding entry in values
*
*
* Methods of the top-level container (renderer factorizations):
*
* .setValue( gl, name, value )
*
* sets uniform with name 'name' to 'value'
*
* .set( gl, obj, prop )
*
* sets uniform from object and property with same name than uniform
*
* .setOptional( gl, obj, prop )
*
* like .set for an optional property of the object
*
*/var emptyTexture=new Texture();var emptyCubeTexture=new CubeTexture();// --- Base for inner nodes (including the root) ---
function UniformContainer(){this.seq=[];this.map={};}// --- Utilities ---
// Array Caches (provide typed arrays for temporary by size)
var arrayCacheF32=[];var arrayCacheI32=[];// Float32Array caches used for uploading Matrix uniforms
var mat4array=new Float32Array(16);var mat3array=new Float32Array(9);// Flattening for arrays of vectors and matrices
function flatten(array,nBlocks,blockSize){var firstElem=array[0];if(firstElem<=0||firstElem>0)return array;// unoptimized: ! isNaN( firstElem )
// see http://jacksondunstan.com/articles/983
var n=nBlocks*blockSize,r=arrayCacheF32[n];if(r===undefined){r=new Float32Array(n);arrayCacheF32[n]=r;}if(nBlocks!==0){firstElem.toArray(r,0);for(var i=1,offset=0;i!==nBlocks;++i){offset+=blockSize;array[i].toArray(r,offset);}}return r;}// Texture unit allocation
function allocTexUnits(renderer,n){var r=arrayCacheI32[n];if(r===undefined){r=new Int32Array(n);arrayCacheI32[n]=r;}for(var i=0;i!==n;++i)r[i]=renderer.allocTextureUnit();return r;}// --- Setters ---
// Note: Defining these methods externally, because they come in a bunch
// and this way their names minify.
// Single scalar
function setValue1f(gl,v){gl.uniform1f(this.addr,v);}function setValue1i(gl,v){gl.uniform1i(this.addr,v);}// Single float vector (from flat array or THREE.VectorN)
function setValue2fv(gl,v){if(v.x===undefined){gl.uniform2fv(this.addr,v);}else{gl.uniform2f(this.addr,v.x,v.y);}}function setValue3fv(gl,v){if(v.x!==undefined){gl.uniform3f(this.addr,v.x,v.y,v.z);}else if(v.r!==undefined){gl.uniform3f(this.addr,v.r,v.g,v.b);}else{gl.uniform3fv(this.addr,v);}}function setValue4fv(gl,v){if(v.x===undefined){gl.uniform4fv(this.addr,v);}else{gl.uniform4f(this.addr,v.x,v.y,v.z,v.w);}}// Single matrix (from flat array or MatrixN)
function setValue2fm(gl,v){gl.uniformMatrix2fv(this.addr,false,v.elements||v);}function setValue3fm(gl,v){if(v.elements===undefined){gl.uniformMatrix3fv(this.addr,false,v);}else{mat3array.set(v.elements);gl.uniformMatrix3fv(this.addr,false,mat3array);}}function setValue4fm(gl,v){if(v.elements===undefined){gl.uniformMatrix4fv(this.addr,false,v);}else{mat4array.set(v.elements);gl.uniformMatrix4fv(this.addr,false,mat4array);}}// Single texture (2D / Cube)
function setValueT1(gl,v,renderer){var unit=renderer.allocTextureUnit();gl.uniform1i(this.addr,unit);renderer.setTexture2D(v||emptyTexture,unit);}function setValueT6(gl,v,renderer){var unit=renderer.allocTextureUnit();gl.uniform1i(this.addr,unit);renderer.setTextureCube(v||emptyCubeTexture,unit);}// Integer / Boolean vectors or arrays thereof (always flat arrays)
function setValue2iv(gl,v){gl.uniform2iv(this.addr,v);}function setValue3iv(gl,v){gl.uniform3iv(this.addr,v);}function setValue4iv(gl,v){gl.uniform4iv(this.addr,v);}// Helper to pick the right setter for the singular case
function getSingularSetter(type){switch(type){case 0x1406:return setValue1f;// FLOAT
case 0x8b50:return setValue2fv;// _VEC2
case 0x8b51:return setValue3fv;// _VEC3
case 0x8b52:return setValue4fv;// _VEC4
case 0x8b5a:return setValue2fm;// _MAT2
case 0x8b5b:return setValue3fm;// _MAT3
case 0x8b5c:return setValue4fm;// _MAT4
case 0x8b5e:case 0x8d66:return setValueT1;// SAMPLER_2D, SAMPLER_EXTERNAL_OES
case 0x8b60:return setValueT6;// SAMPLER_CUBE
case 0x1404:case 0x8b56:return setValue1i;// INT, BOOL
case 0x8b53:case 0x8b57:return setValue2iv;// _VEC2
case 0x8b54:case 0x8b58:return setValue3iv;// _VEC3
case 0x8b55:case 0x8b59:return setValue4iv;// _VEC4
}}// Array of scalars
function setValue1fv(gl,v){gl.uniform1fv(this.addr,v);}function setValue1iv(gl,v){gl.uniform1iv(this.addr,v);}// Array of vectors (flat or from THREE classes)
function setValueV2a(gl,v){gl.uniform2fv(this.addr,flatten(v,this.size,2));}function setValueV3a(gl,v){gl.uniform3fv(this.addr,flatten(v,this.size,3));}function setValueV4a(gl,v){gl.uniform4fv(this.addr,flatten(v,this.size,4));}// Array of matrices (flat or from THREE clases)
function setValueM2a(gl,v){gl.uniformMatrix2fv(this.addr,false,flatten(v,this.size,4));}function setValueM3a(gl,v){gl.uniformMatrix3fv(this.addr,false,flatten(v,this.size,9));}function setValueM4a(gl,v){gl.uniformMatrix4fv(this.addr,false,flatten(v,this.size,16));}// Array of textures (2D / Cube)
function setValueT1a(gl,v,renderer){var n=v.length,units=allocTexUnits(renderer,n);gl.uniform1iv(this.addr,units);for(var i=0;i!==n;++i){renderer.setTexture2D(v[i]||emptyTexture,units[i]);}}function setValueT6a(gl,v,renderer){var n=v.length,units=allocTexUnits(renderer,n);gl.uniform1iv(this.addr,units);for(var i=0;i!==n;++i){renderer.setTextureCube(v[i]||emptyCubeTexture,units[i]);}}// Helper to pick the right setter for a pure (bottom-level) array
function getPureArraySetter(type){switch(type){case 0x1406:return setValue1fv;// FLOAT
case 0x8b50:return setValueV2a;// _VEC2
case 0x8b51:return setValueV3a;// _VEC3
case 0x8b52:return setValueV4a;// _VEC4
case 0x8b5a:return setValueM2a;// _MAT2
case 0x8b5b:return setValueM3a;// _MAT3
case 0x8b5c:return setValueM4a;// _MAT4
case 0x8b5e:return setValueT1a;// SAMPLER_2D
case 0x8b60:return setValueT6a;// SAMPLER_CUBE
case 0x1404:case 0x8b56:return setValue1iv;// INT, BOOL
case 0x8b53:case 0x8b57:return setValue2iv;// _VEC2
case 0x8b54:case 0x8b58:return setValue3iv;// _VEC3
case 0x8b55:case 0x8b59:return setValue4iv;// _VEC4
}}// --- Uniform Classes ---
function SingleUniform(id,activeInfo,addr){this.id=id;this.addr=addr;this.setValue=getSingularSetter(activeInfo.type);// this.path = activeInfo.name; // DEBUG
}function PureArrayUniform(id,activeInfo,addr){this.id=id;this.addr=addr;this.size=activeInfo.size;this.setValue=getPureArraySetter(activeInfo.type);// this.path = activeInfo.name; // DEBUG
}function StructuredUniform(id){this.id=id;UniformContainer.call(this);// mix-in
}StructuredUniform.prototype.setValue=function(gl,value){// Note: Don't need an extra 'renderer' parameter, since samplers
// are not allowed in structured uniforms.
var seq=this.seq;for(var i=0,n=seq.length;i!==n;++i){var u=seq[i];u.setValue(gl,value[u.id]);}};// --- Top-level ---
// Parser - builds up the property tree from the path strings
var RePathPart=/([\w\d_]+)(\])?(\[|\.)?/g;// extracts
// - the identifier (member name or array index)
// - followed by an optional right bracket (found when array index)
// - followed by an optional left bracket or dot (type of subscript)
//
// Note: These portions can be read in a non-overlapping fashion and
// allow straightforward parsing of the hierarchy that WebGL encodes
// in the uniform names.
function addUniform(container,uniformObject){container.seq.push(uniformObject);container.map[uniformObject.id]=uniformObject;}function parseUniform(activeInfo,addr,container){var path=activeInfo.name,pathLength=path.length;// reset RegExp object, because of the early exit of a previous run
RePathPart.lastIndex=0;for(;;){var match=RePathPart.exec(path),matchEnd=RePathPart.lastIndex,id=match[1],idIsIndex=match[2]===']',subscript=match[3];if(idIsIndex)id=id|0;// convert to integer
if(subscript===undefined||subscript==='['&&matchEnd+2===pathLength){// bare name or "pure" bottom-level array "[0]" suffix
addUniform(container,subscript===undefined?new SingleUniform(id,activeInfo,addr):new PureArrayUniform(id,activeInfo,addr));break;}else{// step into inner node / create it in case it doesn't exist
var map=container.map,next=map[id];if(next===undefined){next=new StructuredUniform(id);addUniform(container,next);}container=next;}}}// Root Container
function WebGLUniforms(gl,program,renderer){UniformContainer.call(this);this.renderer=renderer;var n=gl.getProgramParameter(program,gl.ACTIVE_UNIFORMS);for(var i=0;i<n;++i){var info=gl.getActiveUniform(program,i),addr=gl.getUniformLocation(program,info.name);parseUniform(info,addr,this);}}WebGLUniforms.prototype.setValue=function(gl,name,value){var u=this.map[name];if(u!==undefined)u.setValue(gl,value,this.renderer);};WebGLUniforms.prototype.setOptional=function(gl,object,name){var v=object[name];if(v!==undefined)this.setValue(gl,name,v);};// Static interface
WebGLUniforms.upload=function(gl,seq,values,renderer){for(var i=0,n=seq.length;i!==n;++i){var u=seq[i],v=values[u.id];if(v.needsUpdate!==false){// note: always updating when .needsUpdate is undefined
u.setValue(gl,v.value,renderer);}}};WebGLUniforms.seqWithValue=function(seq,values){var r=[];for(var i=0,n=seq.length;i!==n;++i){var u=seq[i];if(u.id in values)r.push(u);}return r;};/**
* @author mrdoob / http://mrdoob.com/
*/function addLineNumbers(string){var lines=string.split('\n');for(var i=0;i<lines.length;i++){lines[i]=i+1+': '+lines[i];}return lines.join('\n');}function WebGLShader(gl,type,string){var shader=gl.createShader(type);gl.shaderSource(shader,string);gl.compileShader(shader);if(gl.getShaderParameter(shader,gl.COMPILE_STATUS)===false){console.error('THREE.WebGLShader: Shader couldn\'t compile.');}if(gl.getShaderInfoLog(shader)!==''){console.warn('THREE.WebGLShader: gl.getShaderInfoLog()',type===gl.VERTEX_SHADER?'vertex':'fragment',gl.getShaderInfoLog(shader),addLineNumbers(string));}// --enable-privileged-webgl-extension
// console.log( type, gl.getExtension( 'WEBGL_debug_shaders' ).getTranslatedShaderSource( shader ) );
return shader;}/**
* @author mrdoob / http://mrdoob.com/
*/var programIdCount=0;function getEncodingComponents(encoding){switch(encoding){case LinearEncoding:return ['Linear','( value )'];case sRGBEncoding:return ['sRGB','( value )'];case RGBEEncoding:return ['RGBE','( value )'];case RGBM7Encoding:return ['RGBM','( value, 7.0 )'];case RGBM16Encoding:return ['RGBM','( value, 16.0 )'];case RGBDEncoding:return ['RGBD','( value, 256.0 )'];case GammaEncoding:return ['Gamma','( value, float( GAMMA_FACTOR ) )'];default:throw new Error('unsupported encoding: '+encoding);}}function getTexelDecodingFunction(functionName,encoding){var components=getEncodingComponents(encoding);return 'vec4 '+functionName+'( vec4 value ) { return '+components[0]+'ToLinear'+components[1]+'; }';}function getTexelEncodingFunction(functionName,encoding){var components=getEncodingComponents(encoding);return 'vec4 '+functionName+'( vec4 value ) { return LinearTo'+components[0]+components[1]+'; }';}function getToneMappingFunction(functionName,toneMapping){var toneMappingName;switch(toneMapping){case LinearToneMapping:toneMappingName='Linear';break;case ReinhardToneMapping:toneMappingName='Reinhard';break;case Uncharted2ToneMapping:toneMappingName='Uncharted2';break;case CineonToneMapping:toneMappingName='OptimizedCineon';break;default:throw new Error('unsupported toneMapping: '+toneMapping);}return 'vec3 '+functionName+'( vec3 color ) { return '+toneMappingName+'ToneMapping( color ); }';}function generateExtensions(extensions,parameters,rendererExtensions){extensions=extensions||{};var chunks=[extensions.derivatives||parameters.envMapCubeUV||parameters.bumpMap||parameters.normalMap||parameters.flatShading?'#extension GL_OES_standard_derivatives : enable':'',(extensions.fragDepth||parameters.logarithmicDepthBuffer)&&rendererExtensions.get('EXT_frag_depth')?'#extension GL_EXT_frag_depth : enable':'',extensions.drawBuffers&&rendererExtensions.get('WEBGL_draw_buffers')?'#extension GL_EXT_draw_buffers : require':'',(extensions.shaderTextureLOD||parameters.envMap)&&rendererExtensions.get('EXT_shader_texture_lod')?'#extension GL_EXT_shader_texture_lod : enable':''];return chunks.filter(filterEmptyLine).join('\n');}function generateDefines(defines){var chunks=[];for(var name in defines){var value=defines[name];if(value===false)continue;chunks.push('#define '+name+' '+value);}return chunks.join('\n');}function fetchAttributeLocations(gl,program){var attributes={};var n=gl.getProgramParameter(program,gl.ACTIVE_ATTRIBUTES);for(var i=0;i<n;i++){var info=gl.getActiveAttrib(program,i);var name=info.name;// console.log( 'THREE.WebGLProgram: ACTIVE VERTEX ATTRIBUTE:', name, i );
attributes[name]=gl.getAttribLocation(program,name);}return attributes;}function filterEmptyLine(string){return string!=='';}function replaceLightNums(string,parameters){return string.replace(/NUM_DIR_LIGHTS/g,parameters.numDirLights).replace(/NUM_SPOT_LIGHTS/g,parameters.numSpotLights).replace(/NUM_RECT_AREA_LIGHTS/g,parameters.numRectAreaLights).replace(/NUM_POINT_LIGHTS/g,parameters.numPointLights).replace(/NUM_HEMI_LIGHTS/g,parameters.numHemiLights);}function replaceClippingPlaneNums(string,parameters){return string.replace(/NUM_CLIPPING_PLANES/g,parameters.numClippingPlanes).replace(/UNION_CLIPPING_PLANES/g,parameters.numClippingPlanes-parameters.numClipIntersection);}function parseIncludes(string){var pattern=/^[ \t]*#include +<([\w\d.]+)>/gm;function replace(match,include){var replace=ShaderChunk[include];if(replace===undefined){throw new Error('Can not resolve #include <'+include+'>');}return parseIncludes(replace);}return string.replace(pattern,replace);}function unrollLoops(string){var pattern=/#pragma unroll_loop[\s]+?for \( int i \= (\d+)\; i < (\d+)\; i \+\+ \) \{([\s\S]+?)(?=\})\}/g;function replace(match,start,end,snippet){var unroll='';for(var i=parseInt(start);i<parseInt(end);i++){unroll+=snippet.replace(/\[ i \]/g,'[ '+i+' ]');}return unroll;}return string.replace(pattern,replace);}function WebGLProgram(renderer,extensions,code,material,shader,parameters){var gl=renderer.context;var defines=material.defines;var vertexShader=shader.vertexShader;var fragmentShader=shader.fragmentShader;var shadowMapTypeDefine='SHADOWMAP_TYPE_BASIC';if(parameters.shadowMapType===PCFShadowMap){shadowMapTypeDefine='SHADOWMAP_TYPE_PCF';}else if(parameters.shadowMapType===PCFSoftShadowMap){shadowMapTypeDefine='SHADOWMAP_TYPE_PCF_SOFT';}var envMapTypeDefine='ENVMAP_TYPE_CUBE';var envMapModeDefine='ENVMAP_MODE_REFLECTION';var envMapBlendingDefine='ENVMAP_BLENDING_MULTIPLY';if(parameters.envMap){switch(material.envMap.mapping){case CubeReflectionMapping:case CubeRefractionMapping:envMapTypeDefine='ENVMAP_TYPE_CUBE';break;case CubeUVReflectionMapping:case CubeUVRefractionMapping:envMapTypeDefine='ENVMAP_TYPE_CUBE_UV';break;case EquirectangularReflectionMapping:case EquirectangularRefractionMapping:envMapTypeDefine='ENVMAP_TYPE_EQUIREC';break;case SphericalReflectionMapping:envMapTypeDefine='ENVMAP_TYPE_SPHERE';break;}switch(material.envMap.mapping){case CubeRefractionMapping:case EquirectangularRefractionMapping:envMapModeDefine='ENVMAP_MODE_REFRACTION';break;}switch(material.combine){case MultiplyOperation:envMapBlendingDefine='ENVMAP_BLENDING_MULTIPLY';break;case MixOperation:envMapBlendingDefine='ENVMAP_BLENDING_MIX';break;case AddOperation:envMapBlendingDefine='ENVMAP_BLENDING_ADD';break;}}var gammaFactorDefine=renderer.gammaFactor>0?renderer.gammaFactor:1.0;// console.log( 'building new program ' );
//
var customExtensions=generateExtensions(material.extensions,parameters,extensions);var customDefines=generateDefines(defines);//
var program=gl.createProgram();var prefixVertex,prefixFragment;if(material.isRawShaderMaterial){prefixVertex=[customDefines].filter(filterEmptyLine).join('\n');if(prefixVertex.length>0){prefixVertex+='\n';}prefixFragment=[customExtensions,customDefines].filter(filterEmptyLine).join('\n');if(prefixFragment.length>0){prefixFragment+='\n';}}else{prefixVertex=['precision '+parameters.precision+' float;','precision '+parameters.precision+' int;','#define SHADER_NAME '+shader.name,customDefines,parameters.supportsVertexTextures?'#define VERTEX_TEXTURES':'','#define GAMMA_FACTOR '+gammaFactorDefine,'#define MAX_BONES '+parameters.maxBones,parameters.useFog&&parameters.fog?'#define USE_FOG':'',parameters.useFog&&parameters.fogExp?'#define FOG_EXP2':'',parameters.map?'#define USE_MAP':'',parameters.envMap?'#define USE_ENVMAP':'',parameters.envMap?'#define '+envMapModeDefine:'',parameters.lightMap?'#define USE_LIGHTMAP':'',parameters.aoMap?'#define USE_AOMAP':'',parameters.emissiveMap?'#define USE_EMISSIVEMAP':'',parameters.bumpMap?'#define USE_BUMPMAP':'',parameters.normalMap?'#define USE_NORMALMAP':'',parameters.displacementMap&&parameters.supportsVertexTextures?'#define USE_DISPLACEMENTMAP':'',parameters.specularMap?'#define USE_SPECULARMAP':'',parameters.roughnessMap?'#define USE_ROUGHNESSMAP':'',parameters.metalnessMap?'#define USE_METALNESSMAP':'',parameters.alphaMap?'#define USE_ALPHAMAP':'',parameters.vertexColors?'#define USE_COLOR':'',parameters.flatShading?'#define FLAT_SHADED':'',parameters.skinning?'#define USE_SKINNING':'',parameters.useVertexTexture?'#define BONE_TEXTURE':'',parameters.morphTargets?'#define USE_MORPHTARGETS':'',parameters.morphNormals&&parameters.flatShading===false?'#define USE_MORPHNORMALS':'',parameters.doubleSided?'#define DOUBLE_SIDED':'',parameters.flipSided?'#define FLIP_SIDED':'',parameters.shadowMapEnabled?'#define USE_SHADOWMAP':'',parameters.shadowMapEnabled?'#define '+shadowMapTypeDefine:'',parameters.sizeAttenuation?'#define USE_SIZEATTENUATION':'',parameters.logarithmicDepthBuffer?'#define USE_LOGDEPTHBUF':'',parameters.logarithmicDepthBuffer&&extensions.get('EXT_frag_depth')?'#define USE_LOGDEPTHBUF_EXT':'','uniform mat4 modelMatrix;','uniform mat4 modelViewMatrix;','uniform mat4 projectionMatrix;','uniform mat4 viewMatrix;','uniform mat3 normalMatrix;','uniform vec3 cameraPosition;','attribute vec3 position;','attribute vec3 normal;','attribute vec2 uv;','#ifdef USE_COLOR',' attribute vec3 color;','#endif','#ifdef USE_MORPHTARGETS',' attribute vec3 morphTarget0;',' attribute vec3 morphTarget1;',' attribute vec3 morphTarget2;',' attribute vec3 morphTarget3;',' #ifdef USE_MORPHNORMALS',' attribute vec3 morphNormal0;',' attribute vec3 morphNormal1;',' attribute vec3 morphNormal2;',' attribute vec3 morphNormal3;',' #else',' attribute vec3 morphTarget4;',' attribute vec3 morphTarget5;',' attribute vec3 morphTarget6;',' attribute vec3 morphTarget7;',' #endif','#endif','#ifdef USE_SKINNING',' attribute vec4 skinIndex;',' attribute vec4 skinWeight;','#endif','\n'].filter(filterEmptyLine).join('\n');prefixFragment=[customExtensions,'precision '+parameters.precision+' float;','precision '+parameters.precision+' int;','#define SHADER_NAME '+shader.name,customDefines,parameters.alphaTest?'#define ALPHATEST '+parameters.alphaTest:'','#define GAMMA_FACTOR '+gammaFactorDefine,parameters.useFog&&parameters.fog?'#define USE_FOG':'',parameters.useFog&&parameters.fogExp?'#define FOG_EXP2':'',parameters.map?'#define USE_MAP':'',parameters.envMap?'#define USE_ENVMAP':'',parameters.envMap?'#define '+envMapTypeDefine:'',parameters.envMap?'#define '+envMapModeDefine:'',parameters.envMap?'#define '+envMapBlendingDefine:'',parameters.lightMap?'#define USE_LIGHTMAP':'',parameters.aoMap?'#define USE_AOMAP':'',parameters.emissiveMap?'#define USE_EMISSIVEMAP':'',parameters.bumpMap?'#define USE_BUMPMAP':'',parameters.normalMap?'#define USE_NORMALMAP':'',parameters.specularMap?'#define USE_SPECULARMAP':'',parameters.roughnessMap?'#define USE_ROUGHNESSMAP':'',parameters.metalnessMap?'#define USE_METALNESSMAP':'',parameters.alphaMap?'#define USE_ALPHAMAP':'',parameters.vertexColors?'#define USE_COLOR':'',parameters.gradientMap?'#define USE_GRADIENTMAP':'',parameters.flatShading?'#define FLAT_SHADED':'',parameters.doubleSided?'#define DOUBLE_SIDED':'',parameters.flipSided?'#define FLIP_SIDED':'',parameters.shadowMapEnabled?'#define USE_SHADOWMAP':'',parameters.shadowMapEnabled?'#define '+shadowMapTypeDefine:'',parameters.premultipliedAlpha?'#define PREMULTIPLIED_ALPHA':'',parameters.physicallyCorrectLights?'#define PHYSICALLY_CORRECT_LIGHTS':'',parameters.logarithmicDepthBuffer?'#define USE_LOGDEPTHBUF':'',parameters.logarithmicDepthBuffer&&extensions.get('EXT_frag_depth')?'#define USE_LOGDEPTHBUF_EXT':'',parameters.envMap&&extensions.get('EXT_shader_texture_lod')?'#define TEXTURE_LOD_EXT':'','uniform mat4 viewMatrix;','uniform vec3 cameraPosition;',parameters.toneMapping!==NoToneMapping?'#define TONE_MAPPING':'',parameters.toneMapping!==NoToneMapping?ShaderChunk['tonemapping_pars_fragment']:'',// this code is required here because it is used by the toneMapping() function defined below
parameters.toneMapping!==NoToneMapping?getToneMappingFunction('toneMapping',parameters.toneMapping):'',parameters.dithering?'#define DITHERING':'',parameters.outputEncoding||parameters.mapEncoding||parameters.envMapEncoding||parameters.emissiveMapEncoding?ShaderChunk['encodings_pars_fragment']:'',// this code is required here because it is used by the various encoding/decoding function defined below
parameters.mapEncoding?getTexelDecodingFunction('mapTexelToLinear',parameters.mapEncoding):'',parameters.envMapEncoding?getTexelDecodingFunction('envMapTexelToLinear',parameters.envMapEncoding):'',parameters.emissiveMapEncoding?getTexelDecodingFunction('emissiveMapTexelToLinear',parameters.emissiveMapEncoding):'',parameters.outputEncoding?getTexelEncodingFunction('linearToOutputTexel',parameters.outputEncoding):'',parameters.depthPacking?'#define DEPTH_PACKING '+material.depthPacking:'','\n'].filter(filterEmptyLine).join('\n');}vertexShader=parseIncludes(vertexShader);vertexShader=replaceLightNums(vertexShader,parameters);vertexShader=replaceClippingPlaneNums(vertexShader,parameters);fragmentShader=parseIncludes(fragmentShader);fragmentShader=replaceLightNums(fragmentShader,parameters);fragmentShader=replaceClippingPlaneNums(fragmentShader,parameters);vertexShader=unrollLoops(vertexShader);fragmentShader=unrollLoops(fragmentShader);var vertexGlsl=prefixVertex+vertexShader;var fragmentGlsl=prefixFragment+fragmentShader;// console.log( '*VERTEX*', vertexGlsl );
// console.log( '*FRAGMENT*', fragmentGlsl );
var glVertexShader=WebGLShader(gl,gl.VERTEX_SHADER,vertexGlsl);var glFragmentShader=WebGLShader(gl,gl.FRAGMENT_SHADER,fragmentGlsl);gl.attachShader(program,glVertexShader);gl.attachShader(program,glFragmentShader);// Force a particular attribute to index 0.
if(material.index0AttributeName!==undefined){gl.bindAttribLocation(program,0,material.index0AttributeName);}else if(parameters.morphTargets===true){// programs with morphTargets displace position out of attribute 0
gl.bindAttribLocation(program,0,'position');}gl.linkProgram(program);var programLog=gl.getProgramInfoLog(program).trim();var vertexLog=gl.getShaderInfoLog(glVertexShader).trim();var fragmentLog=gl.getShaderInfoLog(glFragmentShader).trim();var runnable=true;var haveDiagnostics=true;// console.log( '**VERTEX**', gl.getExtension( 'WEBGL_debug_shaders' ).getTranslatedShaderSource( glVertexShader ) );
// console.log( '**FRAGMENT**', gl.getExtension( 'WEBGL_debug_shaders' ).getTranslatedShaderSource( glFragmentShader ) );
if(gl.getProgramParameter(program,gl.LINK_STATUS)===false){runnable=false;console.error('THREE.WebGLProgram: shader error: ',gl.getError(),'gl.VALIDATE_STATUS',gl.getProgramParameter(program,gl.VALIDATE_STATUS),'gl.getProgramInfoLog',programLog,vertexLog,fragmentLog);}else if(programLog!==''){console.warn('THREE.WebGLProgram: gl.getProgramInfoLog()',programLog);}else if(vertexLog===''||fragmentLog===''){haveDiagnostics=false;}if(haveDiagnostics){this.diagnostics={runnable:runnable,material:material,programLog:programLog,vertexShader:{log:vertexLog,prefix:prefixVertex},fragmentShader:{log:fragmentLog,prefix:prefixFragment}};}// clean up
gl.deleteShader(glVertexShader);gl.deleteShader(glFragmentShader);// set up caching for uniform locations
var cachedUniforms;this.getUniforms=function(){if(cachedUniforms===undefined){cachedUniforms=new WebGLUniforms(gl,program,renderer);}return cachedUniforms;};// set up caching for attribute locations
var cachedAttributes;this.getAttributes=function(){if(cachedAttributes===undefined){cachedAttributes=fetchAttributeLocations(gl,program);}return cachedAttributes;};// free resource
this.destroy=function(){gl.deleteProgram(program);this.program=undefined;};// DEPRECATED
Object.defineProperties(this,{uniforms:{get:function(){console.warn('THREE.WebGLProgram: .uniforms is now .getUniforms().');return this.getUniforms();}},attributes:{get:function(){console.warn('THREE.WebGLProgram: .attributes is now .getAttributes().');return this.getAttributes();}}});//
this.name=shader.name;this.id=programIdCount++;this.code=code;this.usedTimes=1;this.program=program;this.vertexShader=glVertexShader;this.fragmentShader=glFragmentShader;return this;}/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLPrograms(renderer,extensions,capabilities){var programs=[];var shaderIDs={MeshDepthMaterial:'depth',MeshDistanceMaterial:'distanceRGBA',MeshNormalMaterial:'normal',MeshBasicMaterial:'basic',MeshLambertMaterial:'lambert',MeshPhongMaterial:'phong',MeshToonMaterial:'phong',MeshStandardMaterial:'physical',MeshPhysicalMaterial:'physical',LineBasicMaterial:'basic',LineDashedMaterial:'dashed',PointsMaterial:'points',ShadowMaterial:'shadow'};var parameterNames=["precision","supportsVertexTextures","map","mapEncoding","envMap","envMapMode","envMapEncoding","lightMap","aoMap","emissiveMap","emissiveMapEncoding","bumpMap","normalMap","displacementMap","specularMap","roughnessMap","metalnessMap","gradientMap","alphaMap","combine","vertexColors","fog","useFog","fogExp","flatShading","sizeAttenuation","logarithmicDepthBuffer","skinning","maxBones","useVertexTexture","morphTargets","morphNormals","maxMorphTargets","maxMorphNormals","premultipliedAlpha","numDirLights","numPointLights","numSpotLights","numHemiLights","numRectAreaLights","shadowMapEnabled","shadowMapType","toneMapping",'physicallyCorrectLights',"alphaTest","doubleSided","flipSided","numClippingPlanes","numClipIntersection","depthPacking","dithering"];function allocateBones(object){var skeleton=object.skeleton;var bones=skeleton.bones;if(capabilities.floatVertexTextures){return 1024;}else{// default for when object is not specified
// ( for example when prebuilding shader to be used with multiple objects )
//
// - leave some extra space for other uniforms
// - limit here is ANGLE's 254 max uniform vectors
// (up to 54 should be safe)
var nVertexUniforms=capabilities.maxVertexUniforms;var nVertexMatrices=Math.floor((nVertexUniforms-20)/4);var maxBones=Math.min(nVertexMatrices,bones.length);if(maxBones<bones.length){console.warn('THREE.WebGLRenderer: Skeleton has '+bones.length+' bones. This GPU supports '+maxBones+'.');return 0;}return maxBones;}}function getTextureEncodingFromMap(map,gammaOverrideLinear){var encoding;if(!map){encoding=LinearEncoding;}else if(map.isTexture){encoding=map.encoding;}else if(map.isWebGLRenderTarget){console.warn("THREE.WebGLPrograms.getTextureEncodingFromMap: don't use render targets as textures. Use their .texture property instead.");encoding=map.texture.encoding;}// add backwards compatibility for WebGLRenderer.gammaInput/gammaOutput parameter, should probably be removed at some point.
if(encoding===LinearEncoding&&gammaOverrideLinear){encoding=GammaEncoding;}return encoding;}this.getParameters=function(material,lights,shadows,fog,nClipPlanes,nClipIntersection,object){var shaderID=shaderIDs[material.type];// heuristics to create shader parameters according to lights in the scene
// (not to blow over maxLights budget)
var maxBones=object.isSkinnedMesh?allocateBones(object):0;var precision=capabilities.precision;if(material.precision!==null){precision=capabilities.getMaxPrecision(material.precision);if(precision!==material.precision){console.warn('THREE.WebGLProgram.getParameters:',material.precision,'not supported, using',precision,'instead.');}}var currentRenderTarget=renderer.getRenderTarget();var parameters={shaderID:shaderID,precision:precision,supportsVertexTextures:capabilities.vertexTextures,outputEncoding:getTextureEncodingFromMap(!currentRenderTarget?null:currentRenderTarget.texture,renderer.gammaOutput),map:!!material.map,mapEncoding:getTextureEncodingFromMap(material.map,renderer.gammaInput),envMap:!!material.envMap,envMapMode:material.envMap&&material.envMap.mapping,envMapEncoding:getTextureEncodingFromMap(material.envMap,renderer.gammaInput),envMapCubeUV:!!material.envMap&&(material.envMap.mapping===CubeUVReflectionMapping||material.envMap.mapping===CubeUVRefractionMapping),lightMap:!!material.lightMap,aoMap:!!material.aoMap,emissiveMap:!!material.emissiveMap,emissiveMapEncoding:getTextureEncodingFromMap(material.emissiveMap,renderer.gammaInput),bumpMap:!!material.bumpMap,normalMap:!!material.normalMap,displacementMap:!!material.displacementMap,roughnessMap:!!material.roughnessMap,metalnessMap:!!material.metalnessMap,specularMap:!!material.specularMap,alphaMap:!!material.alphaMap,gradientMap:!!material.gradientMap,combine:material.combine,vertexColors:material.vertexColors,fog:!!fog,useFog:material.fog,fogExp:fog&&fog.isFogExp2,flatShading:material.flatShading,sizeAttenuation:material.sizeAttenuation,logarithmicDepthBuffer:capabilities.logarithmicDepthBuffer,skinning:material.skinning&&maxBones>0,maxBones:maxBones,useVertexTexture:capabilities.floatVertexTextures,morphTargets:material.morphTargets,morphNormals:material.morphNormals,maxMorphTargets:renderer.maxMorphTargets,maxMorphNormals:renderer.maxMorphNormals,numDirLights:lights.directional.length,numPointLights:lights.point.length,numSpotLights:lights.spot.length,numRectAreaLights:lights.rectArea.length,numHemiLights:lights.hemi.length,numClippingPlanes:nClipPlanes,numClipIntersection:nClipIntersection,dithering:material.dithering,shadowMapEnabled:renderer.shadowMap.enabled&&object.receiveShadow&&shadows.length>0,shadowMapType:renderer.shadowMap.type,toneMapping:renderer.toneMapping,physicallyCorrectLights:renderer.physicallyCorrectLights,premultipliedAlpha:material.premultipliedAlpha,alphaTest:material.alphaTest,doubleSided:material.side===DoubleSide,flipSided:material.side===BackSide,depthPacking:material.depthPacking!==undefined?material.depthPacking:false};return parameters;};this.getProgramCode=function(material,parameters){var array=[];if(parameters.shaderID){array.push(parameters.shaderID);}else{array.push(material.fragmentShader);array.push(material.vertexShader);}if(material.defines!==undefined){for(var name in material.defines){array.push(name);array.push(material.defines[name]);}}for(var i=0;i<parameterNames.length;i++){array.push(parameters[parameterNames[i]]);}array.push(material.onBeforeCompile.toString());array.push(renderer.gammaOutput);return array.join();};this.acquireProgram=function(material,shader,parameters,code){var program;// Check if code has been already compiled
for(var p=0,pl=programs.length;p<pl;p++){var programInfo=programs[p];if(programInfo.code===code){program=programInfo;++program.usedTimes;break;}}if(program===undefined){program=new WebGLProgram(renderer,extensions,code,material,shader,parameters);programs.push(program);}return program;};this.releaseProgram=function(program){if(--program.usedTimes===0){// Remove from unordered set
var i=programs.indexOf(program);programs[i]=programs[programs.length-1];programs.pop();// Free WebGL resources
program.destroy();}};// Exposed for resource monitoring & error feedback via renderer.info:
this.programs=programs;}/**
* @author fordacious / fordacious.github.io
*/function WebGLProperties(){var properties=new WeakMap();function get(object){var map=properties.get(object);if(map===undefined){map={};properties.set(object,map);}return map;}function remove(object){properties.delete(object);}function update(object,key,value){properties.get(object)[key]=value;}function dispose(){properties=new WeakMap();}return {get:get,remove:remove,update:update,dispose:dispose};}/**
* @author mrdoob / http://mrdoob.com/
*/function painterSortStable(a,b){if(a.renderOrder!==b.renderOrder){return a.renderOrder-b.renderOrder;}else if(a.program&&b.program&&a.program!==b.program){return a.program.id-b.program.id;}else if(a.material.id!==b.material.id){return a.material.id-b.material.id;}else if(a.z!==b.z){return a.z-b.z;}else{return a.id-b.id;}}function reversePainterSortStable(a,b){if(a.renderOrder!==b.renderOrder){return a.renderOrder-b.renderOrder;}if(a.z!==b.z){return b.z-a.z;}else{return a.id-b.id;}}function WebGLRenderList(){var renderItems=[];var renderItemsIndex=0;var opaque=[];var transparent=[];function init(){renderItemsIndex=0;opaque.length=0;transparent.length=0;}function push(object,geometry,material,z,group){var renderItem=renderItems[renderItemsIndex];if(renderItem===undefined){renderItem={id:object.id,object:object,geometry:geometry,material:material,program:material.program,renderOrder:object.renderOrder,z:z,group:group};renderItems[renderItemsIndex]=renderItem;}else{renderItem.id=object.id;renderItem.object=object;renderItem.geometry=geometry;renderItem.material=material;renderItem.program=material.program;renderItem.renderOrder=object.renderOrder;renderItem.z=z;renderItem.group=group;}(material.transparent===true?transparent:opaque).push(renderItem);renderItemsIndex++;}function sort(){if(opaque.length>1)opaque.sort(painterSortStable);if(transparent.length>1)transparent.sort(reversePainterSortStable);}return {opaque:opaque,transparent:transparent,init:init,push:push,sort:sort};}function WebGLRenderLists(){var lists={};function get(scene,camera){var hash=scene.id+','+camera.id;var list=lists[hash];if(list===undefined){// console.log( 'THREE.WebGLRenderLists:', hash );
list=new WebGLRenderList();lists[hash]=list;}return list;}function dispose(){lists={};}return {get:get,dispose:dispose};}/**
* @author mrdoob / http://mrdoob.com/
*/function UniformsCache(){var lights={};return {get:function(light){if(lights[light.id]!==undefined){return lights[light.id];}var uniforms;switch(light.type){case'DirectionalLight':uniforms={direction:new Vector3(),color:new Color(),shadow:false,shadowBias:0,shadowRadius:1,shadowMapSize:new Vector2()};break;case'SpotLight':uniforms={position:new Vector3(),direction:new Vector3(),color:new Color(),distance:0,coneCos:0,penumbraCos:0,decay:0,shadow:false,shadowBias:0,shadowRadius:1,shadowMapSize:new Vector2()};break;case'PointLight':uniforms={position:new Vector3(),color:new Color(),distance:0,decay:0,shadow:false,shadowBias:0,shadowRadius:1,shadowMapSize:new Vector2(),shadowCameraNear:1,shadowCameraFar:1000};break;case'HemisphereLight':uniforms={direction:new Vector3(),skyColor:new Color(),groundColor:new Color()};break;case'RectAreaLight':uniforms={color:new Color(),position:new Vector3(),halfWidth:new Vector3(),halfHeight:new Vector3()// TODO (abelnation): set RectAreaLight shadow uniforms
};break;}lights[light.id]=uniforms;return uniforms;}};}var count=0;function WebGLLights(){var cache=new UniformsCache();var state={id:count++,hash:'',ambient:[0,0,0],directional:[],directionalShadowMap:[],directionalShadowMatrix:[],spot:[],spotShadowMap:[],spotShadowMatrix:[],rectArea:[],point:[],pointShadowMap:[],pointShadowMatrix:[],hemi:[]};var vector3=new Vector3();var matrix4=new Matrix4();var matrix42=new Matrix4();function setup(lights,shadows,camera){var r=0,g=0,b=0;var directionalLength=0;var pointLength=0;var spotLength=0;var rectAreaLength=0;var hemiLength=0;var viewMatrix=camera.matrixWorldInverse;for(var i=0,l=lights.length;i<l;i++){var light=lights[i];var color=light.color;var intensity=light.intensity;var distance=light.distance;var shadowMap=light.shadow&&light.shadow.map?light.shadow.map.texture:null;if(light.isAmbientLight){r+=color.r*intensity;g+=color.g*intensity;b+=color.b*intensity;}else if(light.isDirectionalLight){var uniforms=cache.get(light);uniforms.color.copy(light.color).multiplyScalar(light.intensity);uniforms.direction.setFromMatrixPosition(light.matrixWorld);vector3.setFromMatrixPosition(light.target.matrixWorld);uniforms.direction.sub(vector3);uniforms.direction.transformDirection(viewMatrix);uniforms.shadow=light.castShadow;if(light.castShadow){var shadow=light.shadow;uniforms.shadowBias=shadow.bias;uniforms.shadowRadius=shadow.radius;uniforms.shadowMapSize=shadow.mapSize;}state.directionalShadowMap[directionalLength]=shadowMap;state.directionalShadowMatrix[directionalLength]=light.shadow.matrix;state.directional[directionalLength]=uniforms;directionalLength++;}else if(light.isSpotLight){var uniforms=cache.get(light);uniforms.position.setFromMatrixPosition(light.matrixWorld);uniforms.position.applyMatrix4(viewMatrix);uniforms.color.copy(color).multiplyScalar(intensity);uniforms.distance=distance;uniforms.direction.setFromMatrixPosition(light.matrixWorld);vector3.setFromMatrixPosition(light.target.matrixWorld);uniforms.direction.sub(vector3);uniforms.direction.transformDirection(viewMatrix);uniforms.coneCos=Math.cos(light.angle);uniforms.penumbraCos=Math.cos(light.angle*(1-light.penumbra));uniforms.decay=light.distance===0?0.0:light.decay;uniforms.shadow=light.castShadow;if(light.castShadow){var shadow=light.shadow;uniforms.shadowBias=shadow.bias;uniforms.shadowRadius=shadow.radius;uniforms.shadowMapSize=shadow.mapSize;}state.spotShadowMap[spotLength]=shadowMap;state.spotShadowMatrix[spotLength]=light.shadow.matrix;state.spot[spotLength]=uniforms;spotLength++;}else if(light.isRectAreaLight){var uniforms=cache.get(light);// (a) intensity is the total visible light emitted
//uniforms.color.copy( color ).multiplyScalar( intensity / ( light.width * light.height * Math.PI ) );
// (b) intensity is the brightness of the light
uniforms.color.copy(color).multiplyScalar(intensity);uniforms.position.setFromMatrixPosition(light.matrixWorld);uniforms.position.applyMatrix4(viewMatrix);// extract local rotation of light to derive width/height half vectors
matrix42.identity();matrix4.copy(light.matrixWorld);matrix4.premultiply(viewMatrix);matrix42.extractRotation(matrix4);uniforms.halfWidth.set(light.width*0.5,0.0,0.0);uniforms.halfHeight.set(0.0,light.height*0.5,0.0);uniforms.halfWidth.applyMatrix4(matrix42);uniforms.halfHeight.applyMatrix4(matrix42);// TODO (abelnation): RectAreaLight distance?
// uniforms.distance = distance;
state.rectArea[rectAreaLength]=uniforms;rectAreaLength++;}else if(light.isPointLight){var uniforms=cache.get(light);uniforms.position.setFromMatrixPosition(light.matrixWorld);uniforms.position.applyMatrix4(viewMatrix);uniforms.color.copy(light.color).multiplyScalar(light.intensity);uniforms.distance=light.distance;uniforms.decay=light.distance===0?0.0:light.decay;uniforms.shadow=light.castShadow;if(light.castShadow){var shadow=light.shadow;uniforms.shadowBias=shadow.bias;uniforms.shadowRadius=shadow.radius;uniforms.shadowMapSize=shadow.mapSize;uniforms.shadowCameraNear=shadow.camera.near;uniforms.shadowCameraFar=shadow.camera.far;}state.pointShadowMap[pointLength]=shadowMap;state.pointShadowMatrix[pointLength]=light.shadow.matrix;state.point[pointLength]=uniforms;pointLength++;}else if(light.isHemisphereLight){var uniforms=cache.get(light);uniforms.direction.setFromMatrixPosition(light.matrixWorld);uniforms.direction.transformDirection(viewMatrix);uniforms.direction.normalize();uniforms.skyColor.copy(light.color).multiplyScalar(intensity);uniforms.groundColor.copy(light.groundColor).multiplyScalar(intensity);state.hemi[hemiLength]=uniforms;hemiLength++;}}state.ambient[0]=r;state.ambient[1]=g;state.ambient[2]=b;state.directional.length=directionalLength;state.spot.length=spotLength;state.rectArea.length=rectAreaLength;state.point.length=pointLength;state.hemi.length=hemiLength;state.hash=state.id+','+directionalLength+','+pointLength+','+spotLength+','+rectAreaLength+','+hemiLength+','+shadows.length;}return {setup:setup,state:state};}/**
* @author Mugen87 / https://github.com/Mugen87
*/function WebGLRenderState(){var lights=new WebGLLights();var lightsArray=[];var shadowsArray=[];var spritesArray=[];function init(){lightsArray.length=0;shadowsArray.length=0;spritesArray.length=0;}function pushLight(light){lightsArray.push(light);}function pushShadow(shadowLight){shadowsArray.push(shadowLight);}function pushSprite(shadowLight){spritesArray.push(shadowLight);}function setupLights(camera){lights.setup(lightsArray,shadowsArray,camera);}var state={lightsArray:lightsArray,shadowsArray:shadowsArray,spritesArray:spritesArray,lights:lights};return {init:init,state:state,setupLights:setupLights,pushLight:pushLight,pushShadow:pushShadow,pushSprite:pushSprite};}function WebGLRenderStates(){var renderStates={};function get(scene,camera){var hash=scene.id+','+camera.id;var renderState=renderStates[hash];if(renderState===undefined){renderState=new WebGLRenderState();renderStates[hash]=renderState;}return renderState;}function dispose(){renderStates={};}return {get:get,dispose:dispose};}/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
* @author bhouston / https://clara.io
* @author WestLangley / http://github.com/WestLangley
*
* parameters = {
*
* opacity: <float>,
*
* map: new THREE.Texture( <Image> ),
*
* alphaMap: new THREE.Texture( <Image> ),
*
* displacementMap: new THREE.Texture( <Image> ),
* displacementScale: <float>,
* displacementBias: <float>,
*
* wireframe: <boolean>,
* wireframeLinewidth: <float>
* }
*/function MeshDepthMaterial(parameters){Material.call(this);this.type='MeshDepthMaterial';this.depthPacking=BasicDepthPacking;this.skinning=false;this.morphTargets=false;this.map=null;this.alphaMap=null;this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.wireframe=false;this.wireframeLinewidth=1;this.fog=false;this.lights=false;this.setValues(parameters);}MeshDepthMaterial.prototype=Object.create(Material.prototype);MeshDepthMaterial.prototype.constructor=MeshDepthMaterial;MeshDepthMaterial.prototype.isMeshDepthMaterial=true;MeshDepthMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.depthPacking=source.depthPacking;this.skinning=source.skinning;this.morphTargets=source.morphTargets;this.map=source.map;this.alphaMap=source.alphaMap;this.displacementMap=source.displacementMap;this.displacementScale=source.displacementScale;this.displacementBias=source.displacementBias;this.wireframe=source.wireframe;this.wireframeLinewidth=source.wireframeLinewidth;return this;};/**
* @author WestLangley / http://github.com/WestLangley
*
* parameters = {
*
* referencePosition: <float>,
* nearDistance: <float>,
* farDistance: <float>,
*
* skinning: <bool>,
* morphTargets: <bool>,
*
* map: new THREE.Texture( <Image> ),
*
* alphaMap: new THREE.Texture( <Image> ),
*
* displacementMap: new THREE.Texture( <Image> ),
* displacementScale: <float>,
* displacementBias: <float>
*
* }
*/function MeshDistanceMaterial(parameters){Material.call(this);this.type='MeshDistanceMaterial';this.referencePosition=new Vector3();this.nearDistance=1;this.farDistance=1000;this.skinning=false;this.morphTargets=false;this.map=null;this.alphaMap=null;this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.fog=false;this.lights=false;this.setValues(parameters);}MeshDistanceMaterial.prototype=Object.create(Material.prototype);MeshDistanceMaterial.prototype.constructor=MeshDistanceMaterial;MeshDistanceMaterial.prototype.isMeshDistanceMaterial=true;MeshDistanceMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.referencePosition.copy(source.referencePosition);this.nearDistance=source.nearDistance;this.farDistance=source.farDistance;this.skinning=source.skinning;this.morphTargets=source.morphTargets;this.map=source.map;this.alphaMap=source.alphaMap;this.displacementMap=source.displacementMap;this.displacementScale=source.displacementScale;this.displacementBias=source.displacementBias;return this;};/**
* @author alteredq / http://alteredqualia.com/
* @author mrdoob / http://mrdoob.com/
*/function WebGLShadowMap(_renderer,_objects,maxTextureSize){var _frustum=new Frustum(),_projScreenMatrix=new Matrix4(),_shadowMapSize=new Vector2(),_maxShadowMapSize=new Vector2(maxTextureSize,maxTextureSize),_lookTarget=new Vector3(),_lightPositionWorld=new Vector3(),_MorphingFlag=1,_SkinningFlag=2,_NumberOfMaterialVariants=(_MorphingFlag|_SkinningFlag)+1,_depthMaterials=new Array(_NumberOfMaterialVariants),_distanceMaterials=new Array(_NumberOfMaterialVariants),_materialCache={};var shadowSide={0:BackSide,1:FrontSide,2:DoubleSide};var cubeDirections=[new Vector3(1,0,0),new Vector3(-1,0,0),new Vector3(0,0,1),new Vector3(0,0,-1),new Vector3(0,1,0),new Vector3(0,-1,0)];var cubeUps=[new Vector3(0,1,0),new Vector3(0,1,0),new Vector3(0,1,0),new Vector3(0,1,0),new Vector3(0,0,1),new Vector3(0,0,-1)];var cube2DViewPorts=[new Vector4(),new Vector4(),new Vector4(),new Vector4(),new Vector4(),new Vector4()];// init
for(var i=0;i!==_NumberOfMaterialVariants;++i){var useMorphing=(i&_MorphingFlag)!==0;var useSkinning=(i&_SkinningFlag)!==0;var depthMaterial=new MeshDepthMaterial({depthPacking:RGBADepthPacking,morphTargets:useMorphing,skinning:useSkinning});_depthMaterials[i]=depthMaterial;//
var distanceMaterial=new MeshDistanceMaterial({morphTargets:useMorphing,skinning:useSkinning});_distanceMaterials[i]=distanceMaterial;}//
var scope=this;this.enabled=false;this.autoUpdate=true;this.needsUpdate=false;this.type=PCFShadowMap;this.render=function(lights,scene,camera){if(scope.enabled===false)return;if(scope.autoUpdate===false&&scope.needsUpdate===false)return;if(lights.length===0)return;// TODO Clean up (needed in case of contextlost)
var _gl=_renderer.context;var _state=_renderer.state;// Set GL state for depth map.
_state.disable(_gl.BLEND);_state.buffers.color.setClear(1,1,1,1);_state.buffers.depth.setTest(true);_state.setScissorTest(false);// render depth map
var faceCount;for(var i=0,il=lights.length;i<il;i++){var light=lights[i];var shadow=light.shadow;var isPointLight=light&&light.isPointLight;if(shadow===undefined){console.warn('THREE.WebGLShadowMap:',light,'has no shadow.');continue;}var shadowCamera=shadow.camera;_shadowMapSize.copy(shadow.mapSize);_shadowMapSize.min(_maxShadowMapSize);if(isPointLight){var vpWidth=_shadowMapSize.x;var vpHeight=_shadowMapSize.y;// These viewports map a cube-map onto a 2D texture with the
// following orientation:
//
// xzXZ
// y Y
//
// X - Positive x direction
// x - Negative x direction
// Y - Positive y direction
// y - Negative y direction
// Z - Positive z direction
// z - Negative z direction
// positive X
cube2DViewPorts[0].set(vpWidth*2,vpHeight,vpWidth,vpHeight);// negative X
cube2DViewPorts[1].set(0,vpHeight,vpWidth,vpHeight);// positive Z
cube2DViewPorts[2].set(vpWidth*3,vpHeight,vpWidth,vpHeight);// negative Z
cube2DViewPorts[3].set(vpWidth,vpHeight,vpWidth,vpHeight);// positive Y
cube2DViewPorts[4].set(vpWidth*3,0,vpWidth,vpHeight);// negative Y
cube2DViewPorts[5].set(vpWidth,0,vpWidth,vpHeight);_shadowMapSize.x*=4.0;_shadowMapSize.y*=2.0;}if(shadow.map===null){var pars={minFilter:NearestFilter,magFilter:NearestFilter,format:RGBAFormat};shadow.map=new WebGLRenderTarget(_shadowMapSize.x,_shadowMapSize.y,pars);shadow.map.texture.name=light.name+".shadowMap";shadowCamera.updateProjectionMatrix();}if(shadow.isSpotLightShadow){shadow.update(light);}var shadowMap=shadow.map;var shadowMatrix=shadow.matrix;_lightPositionWorld.setFromMatrixPosition(light.matrixWorld);shadowCamera.position.copy(_lightPositionWorld);if(isPointLight){faceCount=6;// for point lights we set the shadow matrix to be a translation-only matrix
// equal to inverse of the light's position
shadowMatrix.makeTranslation(-_lightPositionWorld.x,-_lightPositionWorld.y,-_lightPositionWorld.z);}else{faceCount=1;_lookTarget.setFromMatrixPosition(light.target.matrixWorld);shadowCamera.lookAt(_lookTarget);shadowCamera.updateMatrixWorld();// compute shadow matrix
shadowMatrix.set(0.5,0.0,0.0,0.5,0.0,0.5,0.0,0.5,0.0,0.0,0.5,0.5,0.0,0.0,0.0,1.0);shadowMatrix.multiply(shadowCamera.projectionMatrix);shadowMatrix.multiply(shadowCamera.matrixWorldInverse);}_renderer.setRenderTarget(shadowMap);_renderer.clear();// render shadow map for each cube face (if omni-directional) or
// run a single pass if not
for(var face=0;face<faceCount;face++){if(isPointLight){_lookTarget.copy(shadowCamera.position);_lookTarget.add(cubeDirections[face]);shadowCamera.up.copy(cubeUps[face]);shadowCamera.lookAt(_lookTarget);shadowCamera.updateMatrixWorld();var vpDimensions=cube2DViewPorts[face];_state.viewport(vpDimensions);}// update camera matrices and frustum
_projScreenMatrix.multiplyMatrices(shadowCamera.projectionMatrix,shadowCamera.matrixWorldInverse);_frustum.setFromMatrix(_projScreenMatrix);// set object matrices & frustum culling
renderObject(scene,camera,shadowCamera,isPointLight);}}scope.needsUpdate=false;};function getDepthMaterial(object,material,isPointLight,lightPositionWorld,shadowCameraNear,shadowCameraFar){var geometry=object.geometry;var result=null;var materialVariants=_depthMaterials;var customMaterial=object.customDepthMaterial;if(isPointLight){materialVariants=_distanceMaterials;customMaterial=object.customDistanceMaterial;}if(!customMaterial){var useMorphing=false;if(material.morphTargets){if(geometry&&geometry.isBufferGeometry){useMorphing=geometry.morphAttributes&&geometry.morphAttributes.position&&geometry.morphAttributes.position.length>0;}else if(geometry&&geometry.isGeometry){useMorphing=geometry.morphTargets&&geometry.morphTargets.length>0;}}if(object.isSkinnedMesh&&material.skinning===false){console.warn('THREE.WebGLShadowMap: THREE.SkinnedMesh with material.skinning set to false:',object);}var useSkinning=object.isSkinnedMesh&&material.skinning;var variantIndex=0;if(useMorphing)variantIndex|=_MorphingFlag;if(useSkinning)variantIndex|=_SkinningFlag;result=materialVariants[variantIndex];}else{result=customMaterial;}if(_renderer.localClippingEnabled&&material.clipShadows===true&&material.clippingPlanes.length!==0){// in this case we need a unique material instance reflecting the
// appropriate state
var keyA=result.uuid,keyB=material.uuid;var materialsForVariant=_materialCache[keyA];if(materialsForVariant===undefined){materialsForVariant={};_materialCache[keyA]=materialsForVariant;}var cachedMaterial=materialsForVariant[keyB];if(cachedMaterial===undefined){cachedMaterial=result.clone();materialsForVariant[keyB]=cachedMaterial;}result=cachedMaterial;}result.visible=material.visible;result.wireframe=material.wireframe;result.side=material.shadowSide!=null?material.shadowSide:shadowSide[material.side];result.clipShadows=material.clipShadows;result.clippingPlanes=material.clippingPlanes;result.clipIntersection=material.clipIntersection;result.wireframeLinewidth=material.wireframeLinewidth;result.linewidth=material.linewidth;if(isPointLight&&result.isMeshDistanceMaterial){result.referencePosition.copy(lightPositionWorld);result.nearDistance=shadowCameraNear;result.farDistance=shadowCameraFar;}return result;}function renderObject(object,camera,shadowCamera,isPointLight){if(object.visible===false)return;var visible=object.layers.test(camera.layers);if(visible&&(object.isMesh||object.isLine||object.isPoints)){if(object.castShadow&&(!object.frustumCulled||_frustum.intersectsObject(object))){object.modelViewMatrix.multiplyMatrices(shadowCamera.matrixWorldInverse,object.matrixWorld);var geometry=_objects.update(object);var material=object.material;if(Array.isArray(material)){var groups=geometry.groups;for(var k=0,kl=groups.length;k<kl;k++){var group=groups[k];var groupMaterial=material[group.materialIndex];if(groupMaterial&&groupMaterial.visible){var depthMaterial=getDepthMaterial(object,groupMaterial,isPointLight,_lightPositionWorld,shadowCamera.near,shadowCamera.far);_renderer.renderBufferDirect(shadowCamera,null,geometry,depthMaterial,object,group);}}}else if(material.visible){var depthMaterial=getDepthMaterial(object,material,isPointLight,_lightPositionWorld,shadowCamera.near,shadowCamera.far);_renderer.renderBufferDirect(shadowCamera,null,geometry,depthMaterial,object,null);}}}var children=object.children;for(var i=0,l=children.length;i<l;i++){renderObject(children[i],camera,shadowCamera,isPointLight);}}}/**
* @author mrdoob / http://mrdoob.com/
*/function CanvasTexture(canvas,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy){Texture.call(this,canvas,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy);this.needsUpdate=true;}CanvasTexture.prototype=Object.create(Texture.prototype);CanvasTexture.prototype.constructor=CanvasTexture;/**
* @author mikael emtinger / http://gomo.se/
* @author alteredq / http://alteredqualia.com/
*/function WebGLSpriteRenderer(renderer,gl,state,textures,capabilities){var vertexBuffer,elementBuffer;var program,attributes,uniforms;var texture;// decompose matrixWorld
var spritePosition=new Vector3();var spriteRotation=new Quaternion();var spriteScale=new Vector3();function init(){var vertices=new Float32Array([-0.5,-0.5,0,0,0.5,-0.5,1,0,0.5,0.5,1,1,-0.5,0.5,0,1]);var faces=new Uint16Array([0,1,2,0,2,3]);vertexBuffer=gl.createBuffer();elementBuffer=gl.createBuffer();gl.bindBuffer(gl.ARRAY_BUFFER,vertexBuffer);gl.bufferData(gl.ARRAY_BUFFER,vertices,gl.STATIC_DRAW);gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER,elementBuffer);gl.bufferData(gl.ELEMENT_ARRAY_BUFFER,faces,gl.STATIC_DRAW);program=createProgram();attributes={position:gl.getAttribLocation(program,'position'),uv:gl.getAttribLocation(program,'uv')};uniforms={uvOffset:gl.getUniformLocation(program,'uvOffset'),uvScale:gl.getUniformLocation(program,'uvScale'),rotation:gl.getUniformLocation(program,'rotation'),center:gl.getUniformLocation(program,'center'),scale:gl.getUniformLocation(program,'scale'),color:gl.getUniformLocation(program,'color'),map:gl.getUniformLocation(program,'map'),opacity:gl.getUniformLocation(program,'opacity'),modelViewMatrix:gl.getUniformLocation(program,'modelViewMatrix'),projectionMatrix:gl.getUniformLocation(program,'projectionMatrix'),fogType:gl.getUniformLocation(program,'fogType'),fogDensity:gl.getUniformLocation(program,'fogDensity'),fogNear:gl.getUniformLocation(program,'fogNear'),fogFar:gl.getUniformLocation(program,'fogFar'),fogColor:gl.getUniformLocation(program,'fogColor'),fogDepth:gl.getUniformLocation(program,'fogDepth'),alphaTest:gl.getUniformLocation(program,'alphaTest')};var canvas=document.createElementNS('http://www.w3.org/1999/xhtml','canvas');canvas.width=8;canvas.height=8;var context=canvas.getContext('2d');context.fillStyle='white';context.fillRect(0,0,8,8);texture=new CanvasTexture(canvas);}this.render=function(sprites,scene,camera){if(sprites.length===0)return;// setup gl
if(program===undefined){init();}state.useProgram(program);state.initAttributes();state.enableAttribute(attributes.position);state.enableAttribute(attributes.uv);state.disableUnusedAttributes();state.disable(gl.CULL_FACE);state.enable(gl.BLEND);gl.bindBuffer(gl.ARRAY_BUFFER,vertexBuffer);gl.vertexAttribPointer(attributes.position,2,gl.FLOAT,false,2*8,0);gl.vertexAttribPointer(attributes.uv,2,gl.FLOAT,false,2*8,8);gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER,elementBuffer);gl.uniformMatrix4fv(uniforms.projectionMatrix,false,camera.projectionMatrix.elements);state.activeTexture(gl.TEXTURE0);gl.uniform1i(uniforms.map,0);var oldFogType=0;var sceneFogType=0;var fog=scene.fog;if(fog){gl.uniform3f(uniforms.fogColor,fog.color.r,fog.color.g,fog.color.b);if(fog.isFog){gl.uniform1f(uniforms.fogNear,fog.near);gl.uniform1f(uniforms.fogFar,fog.far);gl.uniform1i(uniforms.fogType,1);oldFogType=1;sceneFogType=1;}else if(fog.isFogExp2){gl.uniform1f(uniforms.fogDensity,fog.density);gl.uniform1i(uniforms.fogType,2);oldFogType=2;sceneFogType=2;}}else{gl.uniform1i(uniforms.fogType,0);oldFogType=0;sceneFogType=0;}// update positions and sort
for(var i=0,l=sprites.length;i<l;i++){var sprite=sprites[i];sprite.modelViewMatrix.multiplyMatrices(camera.matrixWorldInverse,sprite.matrixWorld);sprite.z=-sprite.modelViewMatrix.elements[14];}sprites.sort(painterSortStable);// render all sprites
var scale=[];var center=[];for(var i=0,l=sprites.length;i<l;i++){var sprite=sprites[i];var material=sprite.material;if(material.visible===false)continue;sprite.onBeforeRender(renderer,scene,camera,undefined,material,undefined);gl.uniform1f(uniforms.alphaTest,material.alphaTest);gl.uniformMatrix4fv(uniforms.modelViewMatrix,false,sprite.modelViewMatrix.elements);sprite.matrixWorld.decompose(spritePosition,spriteRotation,spriteScale);scale[0]=spriteScale.x;scale[1]=spriteScale.y;center[0]=sprite.center.x-0.5;center[1]=sprite.center.y-0.5;var fogType=0;if(scene.fog&&material.fog){fogType=sceneFogType;}if(oldFogType!==fogType){gl.uniform1i(uniforms.fogType,fogType);oldFogType=fogType;}if(material.map!==null){gl.uniform2f(uniforms.uvOffset,material.map.offset.x,material.map.offset.y);gl.uniform2f(uniforms.uvScale,material.map.repeat.x,material.map.repeat.y);}else{gl.uniform2f(uniforms.uvOffset,0,0);gl.uniform2f(uniforms.uvScale,1,1);}gl.uniform1f(uniforms.opacity,material.opacity);gl.uniform3f(uniforms.color,material.color.r,material.color.g,material.color.b);gl.uniform1f(uniforms.rotation,material.rotation);gl.uniform2fv(uniforms.center,center);gl.uniform2fv(uniforms.scale,scale);state.setBlending(material.blending,material.blendEquation,material.blendSrc,material.blendDst,material.blendEquationAlpha,material.blendSrcAlpha,material.blendDstAlpha,material.premultipliedAlpha);state.buffers.depth.setTest(material.depthTest);state.buffers.depth.setMask(material.depthWrite);state.buffers.color.setMask(material.colorWrite);textures.setTexture2D(material.map||texture,0);gl.drawElements(gl.TRIANGLES,6,gl.UNSIGNED_SHORT,0);sprite.onAfterRender(renderer,scene,camera,undefined,material,undefined);}// restore gl
state.enable(gl.CULL_FACE);state.reset();};function createProgram(){var program=gl.createProgram();var vertexShader=gl.createShader(gl.VERTEX_SHADER);var fragmentShader=gl.createShader(gl.FRAGMENT_SHADER);gl.shaderSource(vertexShader,['precision '+capabilities.precision+' float;','#define SHADER_NAME '+'SpriteMaterial','uniform mat4 modelViewMatrix;','uniform mat4 projectionMatrix;','uniform float rotation;','uniform vec2 center;','uniform vec2 scale;','uniform vec2 uvOffset;','uniform vec2 uvScale;','attribute vec2 position;','attribute vec2 uv;','varying vec2 vUV;','varying float fogDepth;','void main() {',' vUV = uvOffset + uv * uvScale;',' vec2 alignedPosition = ( position - center ) * scale;',' vec2 rotatedPosition;',' rotatedPosition.x = cos( rotation ) * alignedPosition.x - sin( rotation ) * alignedPosition.y;',' rotatedPosition.y = sin( rotation ) * alignedPosition.x + cos( rotation ) * alignedPosition.y;',' vec4 mvPosition;',' mvPosition = modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 );',' mvPosition.xy += rotatedPosition;',' gl_Position = projectionMatrix * mvPosition;',' fogDepth = - mvPosition.z;','}'].join('\n'));gl.shaderSource(fragmentShader,['precision '+capabilities.precision+' float;','#define SHADER_NAME '+'SpriteMaterial','uniform vec3 color;','uniform sampler2D map;','uniform float opacity;','uniform int fogType;','uniform vec3 fogColor;','uniform float fogDensity;','uniform float fogNear;','uniform float fogFar;','uniform float alphaTest;','varying vec2 vUV;','varying float fogDepth;','void main() {',' vec4 texture = texture2D( map, vUV );',' gl_FragColor = vec4( color * texture.xyz, texture.a * opacity );',' if ( gl_FragColor.a < alphaTest ) discard;',' if ( fogType > 0 ) {',' float fogFactor = 0.0;',' if ( fogType == 1 ) {',' fogFactor = smoothstep( fogNear, fogFar, fogDepth );',' } else {',' const float LOG2 = 1.442695;',' fogFactor = exp2( - fogDensity * fogDensity * fogDepth * fogDepth * LOG2 );',' fogFactor = 1.0 - clamp( fogFactor, 0.0, 1.0 );',' }',' gl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor );',' }','}'].join('\n'));gl.compileShader(vertexShader);gl.compileShader(fragmentShader);gl.attachShader(program,vertexShader);gl.attachShader(program,fragmentShader);gl.linkProgram(program);return program;}function painterSortStable(a,b){if(a.renderOrder!==b.renderOrder){return a.renderOrder-b.renderOrder;}else if(a.z!==b.z){return b.z-a.z;}else{return b.id-a.id;}}}/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLState(gl,extensions,utils){function ColorBuffer(){var locked=false;var color=new Vector4();var currentColorMask=null;var currentColorClear=new Vector4(0,0,0,0);return {setMask:function(colorMask){if(currentColorMask!==colorMask&&!locked){gl.colorMask(colorMask,colorMask,colorMask,colorMask);currentColorMask=colorMask;}},setLocked:function(lock){locked=lock;},setClear:function(r,g,b,a,premultipliedAlpha){if(premultipliedAlpha===true){r*=a;g*=a;b*=a;}color.set(r,g,b,a);if(currentColorClear.equals(color)===false){gl.clearColor(r,g,b,a);currentColorClear.copy(color);}},reset:function(){locked=false;currentColorMask=null;currentColorClear.set(-1,0,0,0);// set to invalid state
}};}function DepthBuffer(){var locked=false;var currentDepthMask=null;var currentDepthFunc=null;var currentDepthClear=null;return {setTest:function(depthTest){if(depthTest){enable(gl.DEPTH_TEST);}else{disable(gl.DEPTH_TEST);}},setMask:function(depthMask){if(currentDepthMask!==depthMask&&!locked){gl.depthMask(depthMask);currentDepthMask=depthMask;}},setFunc:function(depthFunc){if(currentDepthFunc!==depthFunc){if(depthFunc){switch(depthFunc){case NeverDepth:gl.depthFunc(gl.NEVER);break;case AlwaysDepth:gl.depthFunc(gl.ALWAYS);break;case LessDepth:gl.depthFunc(gl.LESS);break;case LessEqualDepth:gl.depthFunc(gl.LEQUAL);break;case EqualDepth:gl.depthFunc(gl.EQUAL);break;case GreaterEqualDepth:gl.depthFunc(gl.GEQUAL);break;case GreaterDepth:gl.depthFunc(gl.GREATER);break;case NotEqualDepth:gl.depthFunc(gl.NOTEQUAL);break;default:gl.depthFunc(gl.LEQUAL);}}else{gl.depthFunc(gl.LEQUAL);}currentDepthFunc=depthFunc;}},setLocked:function(lock){locked=lock;},setClear:function(depth){if(currentDepthClear!==depth){gl.clearDepth(depth);currentDepthClear=depth;}},reset:function(){locked=false;currentDepthMask=null;currentDepthFunc=null;currentDepthClear=null;}};}function StencilBuffer(){var locked=false;var currentStencilMask=null;var currentStencilFunc=null;var currentStencilRef=null;var currentStencilFuncMask=null;var currentStencilFail=null;var currentStencilZFail=null;var currentStencilZPass=null;var currentStencilClear=null;return {setTest:function(stencilTest){if(stencilTest){enable(gl.STENCIL_TEST);}else{disable(gl.STENCIL_TEST);}},setMask:function(stencilMask){if(currentStencilMask!==stencilMask&&!locked){gl.stencilMask(stencilMask);currentStencilMask=stencilMask;}},setFunc:function(stencilFunc,stencilRef,stencilMask){if(currentStencilFunc!==stencilFunc||currentStencilRef!==stencilRef||currentStencilFuncMask!==stencilMask){gl.stencilFunc(stencilFunc,stencilRef,stencilMask);currentStencilFunc=stencilFunc;currentStencilRef=stencilRef;currentStencilFuncMask=stencilMask;}},setOp:function(stencilFail,stencilZFail,stencilZPass){if(currentStencilFail!==stencilFail||currentStencilZFail!==stencilZFail||currentStencilZPass!==stencilZPass){gl.stencilOp(stencilFail,stencilZFail,stencilZPass);currentStencilFail=stencilFail;currentStencilZFail=stencilZFail;currentStencilZPass=stencilZPass;}},setLocked:function(lock){locked=lock;},setClear:function(stencil){if(currentStencilClear!==stencil){gl.clearStencil(stencil);currentStencilClear=stencil;}},reset:function(){locked=false;currentStencilMask=null;currentStencilFunc=null;currentStencilRef=null;currentStencilFuncMask=null;currentStencilFail=null;currentStencilZFail=null;currentStencilZPass=null;currentStencilClear=null;}};}//
var colorBuffer=new ColorBuffer();var depthBuffer=new DepthBuffer();var stencilBuffer=new StencilBuffer();var maxVertexAttributes=gl.getParameter(gl.MAX_VERTEX_ATTRIBS);var newAttributes=new Uint8Array(maxVertexAttributes);var enabledAttributes=new Uint8Array(maxVertexAttributes);var attributeDivisors=new Uint8Array(maxVertexAttributes);var capabilities={};var compressedTextureFormats=null;var currentProgram=null;var currentBlending=null;var currentBlendEquation=null;var currentBlendSrc=null;var currentBlendDst=null;var currentBlendEquationAlpha=null;var currentBlendSrcAlpha=null;var currentBlendDstAlpha=null;var currentPremultipledAlpha=false;var currentFlipSided=null;var currentCullFace=null;var currentLineWidth=null;var currentPolygonOffsetFactor=null;var currentPolygonOffsetUnits=null;var maxTextures=gl.getParameter(gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS);var lineWidthAvailable=false;var version=0;var glVersion=gl.getParameter(gl.VERSION);if(glVersion.indexOf('WebGL')!==-1){version=parseFloat(/^WebGL\ ([0-9])/.exec(glVersion)[1]);lineWidthAvailable=version>=1.0;}else if(glVersion.indexOf('OpenGL ES')!==-1){version=parseFloat(/^OpenGL\ ES\ ([0-9])/.exec(glVersion)[1]);lineWidthAvailable=version>=2.0;}var currentTextureSlot=null;var currentBoundTextures={};var currentScissor=new Vector4();var currentViewport=new Vector4();function createTexture(type,target,count){var data=new Uint8Array(4);// 4 is required to match default unpack alignment of 4.
var texture=gl.createTexture();gl.bindTexture(type,texture);gl.texParameteri(type,gl.TEXTURE_MIN_FILTER,gl.NEAREST);gl.texParameteri(type,gl.TEXTURE_MAG_FILTER,gl.NEAREST);for(var i=0;i<count;i++){gl.texImage2D(target+i,0,gl.RGBA,1,1,0,gl.RGBA,gl.UNSIGNED_BYTE,data);}return texture;}var emptyTextures={};emptyTextures[gl.TEXTURE_2D]=createTexture(gl.TEXTURE_2D,gl.TEXTURE_2D,1);emptyTextures[gl.TEXTURE_CUBE_MAP]=createTexture(gl.TEXTURE_CUBE_MAP,gl.TEXTURE_CUBE_MAP_POSITIVE_X,6);// init
colorBuffer.setClear(0,0,0,1);depthBuffer.setClear(1);stencilBuffer.setClear(0);enable(gl.DEPTH_TEST);depthBuffer.setFunc(LessEqualDepth);setFlipSided(false);setCullFace(CullFaceBack);enable(gl.CULL_FACE);enable(gl.BLEND);setBlending(NormalBlending);//
function initAttributes(){for(var i=0,l=newAttributes.length;i<l;i++){newAttributes[i]=0;}}function enableAttribute(attribute){newAttributes[attribute]=1;if(enabledAttributes[attribute]===0){gl.enableVertexAttribArray(attribute);enabledAttributes[attribute]=1;}if(attributeDivisors[attribute]!==0){var extension=extensions.get('ANGLE_instanced_arrays');extension.vertexAttribDivisorANGLE(attribute,0);attributeDivisors[attribute]=0;}}function enableAttributeAndDivisor(attribute,meshPerAttribute){newAttributes[attribute]=1;if(enabledAttributes[attribute]===0){gl.enableVertexAttribArray(attribute);enabledAttributes[attribute]=1;}if(attributeDivisors[attribute]!==meshPerAttribute){var extension=extensions.get('ANGLE_instanced_arrays');extension.vertexAttribDivisorANGLE(attribute,meshPerAttribute);attributeDivisors[attribute]=meshPerAttribute;}}function disableUnusedAttributes(){for(var i=0,l=enabledAttributes.length;i!==l;++i){if(enabledAttributes[i]!==newAttributes[i]){gl.disableVertexAttribArray(i);enabledAttributes[i]=0;}}}function enable(id){if(capabilities[id]!==true){gl.enable(id);capabilities[id]=true;}}function disable(id){if(capabilities[id]!==false){gl.disable(id);capabilities[id]=false;}}function getCompressedTextureFormats(){if(compressedTextureFormats===null){compressedTextureFormats=[];if(extensions.get('WEBGL_compressed_texture_pvrtc')||extensions.get('WEBGL_compressed_texture_s3tc')||extensions.get('WEBGL_compressed_texture_etc1')||extensions.get('WEBGL_compressed_texture_astc')){var formats=gl.getParameter(gl.COMPRESSED_TEXTURE_FORMATS);for(var i=0;i<formats.length;i++){compressedTextureFormats.push(formats[i]);}}}return compressedTextureFormats;}function useProgram(program){if(currentProgram!==program){gl.useProgram(program);currentProgram=program;return true;}return false;}function setBlending(blending,blendEquation,blendSrc,blendDst,blendEquationAlpha,blendSrcAlpha,blendDstAlpha,premultipliedAlpha){if(blending!==NoBlending){enable(gl.BLEND);}else{disable(gl.BLEND);}if(blending!==CustomBlending){if(blending!==currentBlending||premultipliedAlpha!==currentPremultipledAlpha){switch(blending){case AdditiveBlending:if(premultipliedAlpha){gl.blendEquationSeparate(gl.FUNC_ADD,gl.FUNC_ADD);gl.blendFuncSeparate(gl.ONE,gl.ONE,gl.ONE,gl.ONE);}else{gl.blendEquation(gl.FUNC_ADD);gl.blendFunc(gl.SRC_ALPHA,gl.ONE);}break;case SubtractiveBlending:if(premultipliedAlpha){gl.blendEquationSeparate(gl.FUNC_ADD,gl.FUNC_ADD);gl.blendFuncSeparate(gl.ZERO,gl.ZERO,gl.ONE_MINUS_SRC_COLOR,gl.ONE_MINUS_SRC_ALPHA);}else{gl.blendEquation(gl.FUNC_ADD);gl.blendFunc(gl.ZERO,gl.ONE_MINUS_SRC_COLOR);}break;case MultiplyBlending:if(premultipliedAlpha){gl.blendEquationSeparate(gl.FUNC_ADD,gl.FUNC_ADD);gl.blendFuncSeparate(gl.ZERO,gl.SRC_COLOR,gl.ZERO,gl.SRC_ALPHA);}else{gl.blendEquation(gl.FUNC_ADD);gl.blendFunc(gl.ZERO,gl.SRC_COLOR);}break;default:if(premultipliedAlpha){gl.blendEquationSeparate(gl.FUNC_ADD,gl.FUNC_ADD);gl.blendFuncSeparate(gl.ONE,gl.ONE_MINUS_SRC_ALPHA,gl.ONE,gl.ONE_MINUS_SRC_ALPHA);}else{gl.blendEquationSeparate(gl.FUNC_ADD,gl.FUNC_ADD);gl.blendFuncSeparate(gl.SRC_ALPHA,gl.ONE_MINUS_SRC_ALPHA,gl.ONE,gl.ONE_MINUS_SRC_ALPHA);}}}currentBlendEquation=null;currentBlendSrc=null;currentBlendDst=null;currentBlendEquationAlpha=null;currentBlendSrcAlpha=null;currentBlendDstAlpha=null;}else{blendEquationAlpha=blendEquationAlpha||blendEquation;blendSrcAlpha=blendSrcAlpha||blendSrc;blendDstAlpha=blendDstAlpha||blendDst;if(blendEquation!==currentBlendEquation||blendEquationAlpha!==currentBlendEquationAlpha){gl.blendEquationSeparate(utils.convert(blendEquation),utils.convert(blendEquationAlpha));currentBlendEquation=blendEquation;currentBlendEquationAlpha=blendEquationAlpha;}if(blendSrc!==currentBlendSrc||blendDst!==currentBlendDst||blendSrcAlpha!==currentBlendSrcAlpha||blendDstAlpha!==currentBlendDstAlpha){gl.blendFuncSeparate(utils.convert(blendSrc),utils.convert(blendDst),utils.convert(blendSrcAlpha),utils.convert(blendDstAlpha));currentBlendSrc=blendSrc;currentBlendDst=blendDst;currentBlendSrcAlpha=blendSrcAlpha;currentBlendDstAlpha=blendDstAlpha;}}currentBlending=blending;currentPremultipledAlpha=premultipliedAlpha;}function setMaterial(material,frontFaceCW){material.side===DoubleSide?disable(gl.CULL_FACE):enable(gl.CULL_FACE);var flipSided=material.side===BackSide;if(frontFaceCW)flipSided=!flipSided;setFlipSided(flipSided);material.transparent===true?setBlending(material.blending,material.blendEquation,material.blendSrc,material.blendDst,material.blendEquationAlpha,material.blendSrcAlpha,material.blendDstAlpha,material.premultipliedAlpha):setBlending(NoBlending);depthBuffer.setFunc(material.depthFunc);depthBuffer.setTest(material.depthTest);depthBuffer.setMask(material.depthWrite);colorBuffer.setMask(material.colorWrite);setPolygonOffset(material.polygonOffset,material.polygonOffsetFactor,material.polygonOffsetUnits);}//
function setFlipSided(flipSided){if(currentFlipSided!==flipSided){if(flipSided){gl.frontFace(gl.CW);}else{gl.frontFace(gl.CCW);}currentFlipSided=flipSided;}}function setCullFace(cullFace){if(cullFace!==CullFaceNone){enable(gl.CULL_FACE);if(cullFace!==currentCullFace){if(cullFace===CullFaceBack){gl.cullFace(gl.BACK);}else if(cullFace===CullFaceFront){gl.cullFace(gl.FRONT);}else{gl.cullFace(gl.FRONT_AND_BACK);}}}else{disable(gl.CULL_FACE);}currentCullFace=cullFace;}function setLineWidth(width){if(width!==currentLineWidth){if(lineWidthAvailable)gl.lineWidth(width);currentLineWidth=width;}}function setPolygonOffset(polygonOffset,factor,units){if(polygonOffset){enable(gl.POLYGON_OFFSET_FILL);if(currentPolygonOffsetFactor!==factor||currentPolygonOffsetUnits!==units){gl.polygonOffset(factor,units);currentPolygonOffsetFactor=factor;currentPolygonOffsetUnits=units;}}else{disable(gl.POLYGON_OFFSET_FILL);}}function setScissorTest(scissorTest){if(scissorTest){enable(gl.SCISSOR_TEST);}else{disable(gl.SCISSOR_TEST);}}// texture
function activeTexture(webglSlot){if(webglSlot===undefined)webglSlot=gl.TEXTURE0+maxTextures-1;if(currentTextureSlot!==webglSlot){gl.activeTexture(webglSlot);currentTextureSlot=webglSlot;}}function bindTexture(webglType,webglTexture){if(currentTextureSlot===null){activeTexture();}var boundTexture=currentBoundTextures[currentTextureSlot];if(boundTexture===undefined){boundTexture={type:undefined,texture:undefined};currentBoundTextures[currentTextureSlot]=boundTexture;}if(boundTexture.type!==webglType||boundTexture.texture!==webglTexture){gl.bindTexture(webglType,webglTexture||emptyTextures[webglType]);boundTexture.type=webglType;boundTexture.texture=webglTexture;}}function compressedTexImage2D(){try{gl.compressedTexImage2D.apply(gl,arguments);}catch(error){console.error('THREE.WebGLState:',error);}}function texImage2D(){try{gl.texImage2D.apply(gl,arguments);}catch(error){console.error('THREE.WebGLState:',error);}}//
function scissor(scissor){if(currentScissor.equals(scissor)===false){gl.scissor(scissor.x,scissor.y,scissor.z,scissor.w);currentScissor.copy(scissor);}}function viewport(viewport){if(currentViewport.equals(viewport)===false){gl.viewport(viewport.x,viewport.y,viewport.z,viewport.w);currentViewport.copy(viewport);}}//
function reset(){for(var i=0;i<enabledAttributes.length;i++){if(enabledAttributes[i]===1){gl.disableVertexAttribArray(i);enabledAttributes[i]=0;}}capabilities={};compressedTextureFormats=null;currentTextureSlot=null;currentBoundTextures={};currentProgram=null;currentBlending=null;currentFlipSided=null;currentCullFace=null;colorBuffer.reset();depthBuffer.reset();stencilBuffer.reset();}return {buffers:{color:colorBuffer,depth:depthBuffer,stencil:stencilBuffer},initAttributes:initAttributes,enableAttribute:enableAttribute,enableAttributeAndDivisor:enableAttributeAndDivisor,disableUnusedAttributes:disableUnusedAttributes,enable:enable,disable:disable,getCompressedTextureFormats:getCompressedTextureFormats,useProgram:useProgram,setBlending:setBlending,setMaterial:setMaterial,setFlipSided:setFlipSided,setCullFace:setCullFace,setLineWidth:setLineWidth,setPolygonOffset:setPolygonOffset,setScissorTest:setScissorTest,activeTexture:activeTexture,bindTexture:bindTexture,compressedTexImage2D:compressedTexImage2D,texImage2D:texImage2D,scissor:scissor,viewport:viewport,reset:reset};}/**
* @author mrdoob / http://mrdoob.com/
*/function WebGLTextures(_gl,extensions,state,properties,capabilities,utils,info){var _isWebGL2=typeof WebGL2RenderingContext!=='undefined'&&_gl instanceof WebGL2RenderingContext;/* global WebGL2RenderingContext */var _videoTextures={};var _canvas;//
function clampToMaxSize(image,maxSize){if(image.width>maxSize||image.height>maxSize){if('data'in image){console.warn('THREE.WebGLRenderer: image in DataTexture is too big ('+image.width+'x'+image.height+').');return;}// Warning: Scaling through the canvas will only work with images that use
// premultiplied alpha.
var scale=maxSize/Math.max(image.width,image.height);var canvas=document.createElementNS('http://www.w3.org/1999/xhtml','canvas');canvas.width=Math.floor(image.width*scale);canvas.height=Math.floor(image.height*scale);var context=canvas.getContext('2d');context.drawImage(image,0,0,image.width,image.height,0,0,canvas.width,canvas.height);console.warn('THREE.WebGLRenderer: image is too big ('+image.width+'x'+image.height+'). Resized to '+canvas.width+'x'+canvas.height,image);return canvas;}return image;}function isPowerOfTwo(image){return _Math.isPowerOfTwo(image.width)&&_Math.isPowerOfTwo(image.height);}function makePowerOfTwo(image){if(image instanceof HTMLImageElement||image instanceof HTMLCanvasElement||image instanceof ImageBitmap){if(_canvas===undefined)_canvas=document.createElementNS('http://www.w3.org/1999/xhtml','canvas');_canvas.width=_Math.floorPowerOfTwo(image.width);_canvas.height=_Math.floorPowerOfTwo(image.height);var context=_canvas.getContext('2d');context.drawImage(image,0,0,_canvas.width,_canvas.height);console.warn('THREE.WebGLRenderer: image is not power of two ('+image.width+'x'+image.height+'). Resized to '+_canvas.width+'x'+_canvas.height,image);return _canvas;}return image;}function textureNeedsPowerOfTwo(texture){return texture.wrapS!==ClampToEdgeWrapping||texture.wrapT!==ClampToEdgeWrapping||texture.minFilter!==NearestFilter&&texture.minFilter!==LinearFilter;}function textureNeedsGenerateMipmaps(texture,isPowerOfTwo){return texture.generateMipmaps&&isPowerOfTwo&&texture.minFilter!==NearestFilter&&texture.minFilter!==LinearFilter;}function generateMipmap(target,texture,width,height){_gl.generateMipmap(target);var textureProperties=properties.get(texture);// Note: Math.log( x ) * Math.LOG2E used instead of Math.log2( x ) which is not supported by IE11
textureProperties.__maxMipLevel=Math.log(Math.max(width,height))*Math.LOG2E;}// Fallback filters for non-power-of-2 textures
function filterFallback(f){if(f===NearestFilter||f===NearestMipMapNearestFilter||f===NearestMipMapLinearFilter){return _gl.NEAREST;}return _gl.LINEAR;}//
function onTextureDispose(event){var texture=event.target;texture.removeEventListener('dispose',onTextureDispose);deallocateTexture(texture);if(texture.isVideoTexture){delete _videoTextures[texture.id];}info.memory.textures--;}function onRenderTargetDispose(event){var renderTarget=event.target;renderTarget.removeEventListener('dispose',onRenderTargetDispose);deallocateRenderTarget(renderTarget);info.memory.textures--;}//
function deallocateTexture(texture){var textureProperties=properties.get(texture);if(texture.image&&textureProperties.__image__webglTextureCube){// cube texture
_gl.deleteTexture(textureProperties.__image__webglTextureCube);}else{// 2D texture
if(textureProperties.__webglInit===undefined)return;_gl.deleteTexture(textureProperties.__webglTexture);}// remove all webgl properties
properties.remove(texture);}function deallocateRenderTarget(renderTarget){var renderTargetProperties=properties.get(renderTarget);var textureProperties=properties.get(renderTarget.texture);if(!renderTarget)return;if(textureProperties.__webglTexture!==undefined){_gl.deleteTexture(textureProperties.__webglTexture);}if(renderTarget.depthTexture){renderTarget.depthTexture.dispose();}if(renderTarget.isWebGLRenderTargetCube){for(var i=0;i<6;i++){_gl.deleteFramebuffer(renderTargetProperties.__webglFramebuffer[i]);if(renderTargetProperties.__webglDepthbuffer)_gl.deleteRenderbuffer(renderTargetProperties.__webglDepthbuffer[i]);}}else{_gl.deleteFramebuffer(renderTargetProperties.__webglFramebuffer);if(renderTargetProperties.__webglDepthbuffer)_gl.deleteRenderbuffer(renderTargetProperties.__webglDepthbuffer);}properties.remove(renderTarget.texture);properties.remove(renderTarget);}//
function setTexture2D(texture,slot){var textureProperties=properties.get(texture);if(texture.isVideoTexture)updateVideoTexture(texture);if(texture.version>0&&textureProperties.__version!==texture.version){var image=texture.image;if(image===undefined){console.warn('THREE.WebGLRenderer: Texture marked for update but image is undefined',texture);}else if(image.complete===false){console.warn('THREE.WebGLRenderer: Texture marked for update but image is incomplete',texture);}else{uploadTexture(textureProperties,texture,slot);return;}}state.activeTexture(_gl.TEXTURE0+slot);state.bindTexture(_gl.TEXTURE_2D,textureProperties.__webglTexture);}function setTextureCube(texture,slot){var textureProperties=properties.get(texture);if(texture.image.length===6){if(texture.version>0&&textureProperties.__version!==texture.version){if(!textureProperties.__image__webglTextureCube){texture.addEventListener('dispose',onTextureDispose);textureProperties.__image__webglTextureCube=_gl.createTexture();info.memory.textures++;}state.activeTexture(_gl.TEXTURE0+slot);state.bindTexture(_gl.TEXTURE_CUBE_MAP,textureProperties.__image__webglTextureCube);_gl.pixelStorei(_gl.UNPACK_FLIP_Y_WEBGL,texture.flipY);var isCompressed=texture&&texture.isCompressedTexture;var isDataTexture=texture.image[0]&&texture.image[0].isDataTexture;var cubeImage=[];for(var i=0;i<6;i++){if(!isCompressed&&!isDataTexture){cubeImage[i]=clampToMaxSize(texture.image[i],capabilities.maxCubemapSize);}else{cubeImage[i]=isDataTexture?texture.image[i].image:texture.image[i];}}var image=cubeImage[0],isPowerOfTwoImage=isPowerOfTwo(image),glFormat=utils.convert(texture.format),glType=utils.convert(texture.type);setTextureParameters(_gl.TEXTURE_CUBE_MAP,texture,isPowerOfTwoImage);for(var i=0;i<6;i++){if(!isCompressed){if(isDataTexture){state.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X+i,0,glFormat,cubeImage[i].width,cubeImage[i].height,0,glFormat,glType,cubeImage[i].data);}else{state.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X+i,0,glFormat,glFormat,glType,cubeImage[i]);}}else{var mipmap,mipmaps=cubeImage[i].mipmaps;for(var j=0,jl=mipmaps.length;j<jl;j++){mipmap=mipmaps[j];if(texture.format!==RGBAFormat&&texture.format!==RGBFormat){if(state.getCompressedTextureFormats().indexOf(glFormat)>-1){state.compressedTexImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X+i,j,glFormat,mipmap.width,mipmap.height,0,mipmap.data);}else{console.warn('THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()');}}else{state.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X+i,j,glFormat,mipmap.width,mipmap.height,0,glFormat,glType,mipmap.data);}}}}if(!isCompressed){textureProperties.__maxMipLevel=0;}else{textureProperties.__maxMipLevel=mipmaps.length-1;}if(textureNeedsGenerateMipmaps(texture,isPowerOfTwoImage)){// We assume images for cube map have the same size.
generateMipmap(_gl.TEXTURE_CUBE_MAP,texture,image.width,image.height);}textureProperties.__version=texture.version;if(texture.onUpdate)texture.onUpdate(texture);}else{state.activeTexture(_gl.TEXTURE0+slot);state.bindTexture(_gl.TEXTURE_CUBE_MAP,textureProperties.__image__webglTextureCube);}}}function setTextureCubeDynamic(texture,slot){state.activeTexture(_gl.TEXTURE0+slot);state.bindTexture(_gl.TEXTURE_CUBE_MAP,properties.get(texture).__webglTexture);}function setTextureParameters(textureType,texture,isPowerOfTwoImage){var extension;if(isPowerOfTwoImage){_gl.texParameteri(textureType,_gl.TEXTURE_WRAP_S,utils.convert(texture.wrapS));_gl.texParameteri(textureType,_gl.TEXTURE_WRAP_T,utils.convert(texture.wrapT));_gl.texParameteri(textureType,_gl.TEXTURE_MAG_FILTER,utils.convert(texture.magFilter));_gl.texParameteri(textureType,_gl.TEXTURE_MIN_FILTER,utils.convert(texture.minFilter));}else{_gl.texParameteri(textureType,_gl.TEXTURE_WRAP_S,_gl.CLAMP_TO_EDGE);_gl.texParameteri(textureType,_gl.TEXTURE_WRAP_T,_gl.CLAMP_TO_EDGE);if(texture.wrapS!==ClampToEdgeWrapping||texture.wrapT!==ClampToEdgeWrapping){console.warn('THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping.',texture);}_gl.texParameteri(textureType,_gl.TEXTURE_MAG_FILTER,filterFallback(texture.magFilter));_gl.texParameteri(textureType,_gl.TEXTURE_MIN_FILTER,filterFallback(texture.minFilter));if(texture.minFilter!==NearestFilter&&texture.minFilter!==LinearFilter){console.warn('THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter.',texture);}}extension=extensions.get('EXT_texture_filter_anisotropic');if(extension){if(texture.type===FloatType&&extensions.get('OES_texture_float_linear')===null)return;if(texture.type===HalfFloatType&&extensions.get('OES_texture_half_float_linear')===null)return;if(texture.anisotropy>1||properties.get(texture).__currentAnisotropy){_gl.texParameterf(textureType,extension.TEXTURE_MAX_ANISOTROPY_EXT,Math.min(texture.anisotropy,capabilities.getMaxAnisotropy()));properties.get(texture).__currentAnisotropy=texture.anisotropy;}}}function uploadTexture(textureProperties,texture,slot){if(textureProperties.__webglInit===undefined){textureProperties.__webglInit=true;texture.addEventListener('dispose',onTextureDispose);textureProperties.__webglTexture=_gl.createTexture();info.memory.textures++;}state.activeTexture(_gl.TEXTURE0+slot);state.bindTexture(_gl.TEXTURE_2D,textureProperties.__webglTexture);_gl.pixelStorei(_gl.UNPACK_FLIP_Y_WEBGL,texture.flipY);_gl.pixelStorei(_gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL,texture.premultiplyAlpha);_gl.pixelStorei(_gl.UNPACK_ALIGNMENT,texture.unpackAlignment);var image=clampToMaxSize(texture.image,capabilities.maxTextureSize);if(textureNeedsPowerOfTwo(texture)&&isPowerOfTwo(image)===false){image=makePowerOfTwo(image);}var isPowerOfTwoImage=isPowerOfTwo(image),glFormat=utils.convert(texture.format),glType=utils.convert(texture.type);setTextureParameters(_gl.TEXTURE_2D,texture,isPowerOfTwoImage);var mipmap,mipmaps=texture.mipmaps;if(texture.isDepthTexture){// populate depth texture with dummy data
var internalFormat=_gl.DEPTH_COMPONENT;if(texture.type===FloatType){if(!_isWebGL2)throw new Error('Float Depth Texture only supported in WebGL2.0');internalFormat=_gl.DEPTH_COMPONENT32F;}else if(_isWebGL2){// WebGL 2.0 requires signed internalformat for glTexImage2D
internalFormat=_gl.DEPTH_COMPONENT16;}if(texture.format===DepthFormat&&internalFormat===_gl.DEPTH_COMPONENT){// The error INVALID_OPERATION is generated by texImage2D if format and internalformat are
// DEPTH_COMPONENT and type is not UNSIGNED_SHORT or UNSIGNED_INT
// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)
if(texture.type!==UnsignedShortType&&texture.type!==UnsignedIntType){console.warn('THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture.');texture.type=UnsignedShortType;glType=utils.convert(texture.type);}}// Depth stencil textures need the DEPTH_STENCIL internal format
// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)
if(texture.format===DepthStencilFormat){internalFormat=_gl.DEPTH_STENCIL;// The error INVALID_OPERATION is generated by texImage2D if format and internalformat are
// DEPTH_STENCIL and type is not UNSIGNED_INT_24_8_WEBGL.
// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)
if(texture.type!==UnsignedInt248Type){console.warn('THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture.');texture.type=UnsignedInt248Type;glType=utils.convert(texture.type);}}state.texImage2D(_gl.TEXTURE_2D,0,internalFormat,image.width,image.height,0,glFormat,glType,null);}else if(texture.isDataTexture){// use manually created mipmaps if available
// if there are no manual mipmaps
// set 0 level mipmap and then use GL to generate other mipmap levels
if(mipmaps.length>0&&isPowerOfTwoImage){for(var i=0,il=mipmaps.length;i<il;i++){mipmap=mipmaps[i];state.texImage2D(_gl.TEXTURE_2D,i,glFormat,mipmap.width,mipmap.height,0,glFormat,glType,mipmap.data);}texture.generateMipmaps=false;textureProperties.__maxMipLevel=mipmaps.length-1;}else{state.texImage2D(_gl.TEXTURE_2D,0,glFormat,image.width,image.height,0,glFormat,glType,image.data);textureProperties.__maxMipLevel=0;}}else if(texture.isCompressedTexture){for(var i=0,il=mipmaps.length;i<il;i++){mipmap=mipmaps[i];if(texture.format!==RGBAFormat&&texture.format!==RGBFormat){if(state.getCompressedTextureFormats().indexOf(glFormat)>-1){state.compressedTexImage2D(_gl.TEXTURE_2D,i,glFormat,mipmap.width,mipmap.height,0,mipmap.data);}else{console.warn('THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()');}}else{state.texImage2D(_gl.TEXTURE_2D,i,glFormat,mipmap.width,mipmap.height,0,glFormat,glType,mipmap.data);}}textureProperties.__maxMipLevel=mipmaps.length-1;}else{// regular Texture (image, video, canvas)
// use manually created mipmaps if available
// if there are no manual mipmaps
// set 0 level mipmap and then use GL to generate other mipmap levels
if(mipmaps.length>0&&isPowerOfTwoImage){for(var i=0,il=mipmaps.length;i<il;i++){mipmap=mipmaps[i];state.texImage2D(_gl.TEXTURE_2D,i,glFormat,glFormat,glType,mipmap);}texture.generateMipmaps=false;textureProperties.__maxMipLevel=mipmaps.length-1;}else{state.texImage2D(_gl.TEXTURE_2D,0,glFormat,glFormat,glType,image);textureProperties.__maxMipLevel=0;}}if(textureNeedsGenerateMipmaps(texture,isPowerOfTwoImage)){generateMipmap(_gl.TEXTURE_2D,texture,image.width,image.height);}textureProperties.__version=texture.version;if(texture.onUpdate)texture.onUpdate(texture);}// Render targets
// Setup storage for target texture and bind it to correct framebuffer
function setupFrameBufferTexture(framebuffer,renderTarget,attachment,textureTarget){var glFormat=utils.convert(renderTarget.texture.format);var glType=utils.convert(renderTarget.texture.type);state.texImage2D(textureTarget,0,glFormat,renderTarget.width,renderTarget.height,0,glFormat,glType,null);_gl.bindFramebuffer(_gl.FRAMEBUFFER,framebuffer);_gl.framebufferTexture2D(_gl.FRAMEBUFFER,attachment,textureTarget,properties.get(renderTarget.texture).__webglTexture,0);_gl.bindFramebuffer(_gl.FRAMEBUFFER,null);}// Setup storage for internal depth/stencil buffers and bind to correct framebuffer
function setupRenderBufferStorage(renderbuffer,renderTarget){_gl.bindRenderbuffer(_gl.RENDERBUFFER,renderbuffer);if(renderTarget.depthBuffer&&!renderTarget.stencilBuffer){_gl.renderbufferStorage(_gl.RENDERBUFFER,_gl.DEPTH_COMPONENT16,renderTarget.width,renderTarget.height);_gl.framebufferRenderbuffer(_gl.FRAMEBUFFER,_gl.DEPTH_ATTACHMENT,_gl.RENDERBUFFER,renderbuffer);}else if(renderTarget.depthBuffer&&renderTarget.stencilBuffer){_gl.renderbufferStorage(_gl.RENDERBUFFER,_gl.DEPTH_STENCIL,renderTarget.width,renderTarget.height);_gl.framebufferRenderbuffer(_gl.FRAMEBUFFER,_gl.DEPTH_STENCIL_ATTACHMENT,_gl.RENDERBUFFER,renderbuffer);}else{// FIXME: We don't support !depth !stencil
_gl.renderbufferStorage(_gl.RENDERBUFFER,_gl.RGBA4,renderTarget.width,renderTarget.height);}_gl.bindRenderbuffer(_gl.RENDERBUFFER,null);}// Setup resources for a Depth Texture for a FBO (needs an extension)
function setupDepthTexture(framebuffer,renderTarget){var isCube=renderTarget&&renderTarget.isWebGLRenderTargetCube;if(isCube)throw new Error('Depth Texture with cube render targets is not supported');_gl.bindFramebuffer(_gl.FRAMEBUFFER,framebuffer);if(!(renderTarget.depthTexture&&renderTarget.depthTexture.isDepthTexture)){throw new Error('renderTarget.depthTexture must be an instance of THREE.DepthTexture');}// upload an empty depth texture with framebuffer size
if(!properties.get(renderTarget.depthTexture).__webglTexture||renderTarget.depthTexture.image.width!==renderTarget.width||renderTarget.depthTexture.image.height!==renderTarget.height){renderTarget.depthTexture.image.width=renderTarget.width;renderTarget.depthTexture.image.height=renderTarget.height;renderTarget.depthTexture.needsUpdate=true;}setTexture2D(renderTarget.depthTexture,0);var webglDepthTexture=properties.get(renderTarget.depthTexture).__webglTexture;if(renderTarget.depthTexture.format===DepthFormat){_gl.framebufferTexture2D(_gl.FRAMEBUFFER,_gl.DEPTH_ATTACHMENT,_gl.TEXTURE_2D,webglDepthTexture,0);}else if(renderTarget.depthTexture.format===DepthStencilFormat){_gl.framebufferTexture2D(_gl.FRAMEBUFFER,_gl.DEPTH_STENCIL_ATTACHMENT,_gl.TEXTURE_2D,webglDepthTexture,0);}else{throw new Error('Unknown depthTexture format');}}// Setup GL resources for a non-texture depth buffer
function setupDepthRenderbuffer(renderTarget){var renderTargetProperties=properties.get(renderTarget);var isCube=renderTarget.isWebGLRenderTargetCube===true;if(renderTarget.depthTexture){if(isCube)throw new Error('target.depthTexture not supported in Cube render targets');setupDepthTexture(renderTargetProperties.__webglFramebuffer,renderTarget);}else{if(isCube){renderTargetProperties.__webglDepthbuffer=[];for(var i=0;i<6;i++){_gl.bindFramebuffer(_gl.FRAMEBUFFER,renderTargetProperties.__webglFramebuffer[i]);renderTargetProperties.__webglDepthbuffer[i]=_gl.createRenderbuffer();setupRenderBufferStorage(renderTargetProperties.__webglDepthbuffer[i],renderTarget);}}else{_gl.bindFramebuffer(_gl.FRAMEBUFFER,renderTargetProperties.__webglFramebuffer);renderTargetProperties.__webglDepthbuffer=_gl.createRenderbuffer();setupRenderBufferStorage(renderTargetProperties.__webglDepthbuffer,renderTarget);}}_gl.bindFramebuffer(_gl.FRAMEBUFFER,null);}// Set up GL resources for the render target
function setupRenderTarget(renderTarget){var renderTargetProperties=properties.get(renderTarget);var textureProperties=properties.get(renderTarget.texture);renderTarget.addEventListener('dispose',onRenderTargetDispose);textureProperties.__webglTexture=_gl.createTexture();info.memory.textures++;var isCube=renderTarget.isWebGLRenderTargetCube===true;var isTargetPowerOfTwo=isPowerOfTwo(renderTarget);// Setup framebuffer
if(isCube){renderTargetProperties.__webglFramebuffer=[];for(var i=0;i<6;i++){renderTargetProperties.__webglFramebuffer[i]=_gl.createFramebuffer();}}else{renderTargetProperties.__webglFramebuffer=_gl.createFramebuffer();}// Setup color buffer
if(isCube){state.bindTexture(_gl.TEXTURE_CUBE_MAP,textureProperties.__webglTexture);setTextureParameters(_gl.TEXTURE_CUBE_MAP,renderTarget.texture,isTargetPowerOfTwo);for(var i=0;i<6;i++){setupFrameBufferTexture(renderTargetProperties.__webglFramebuffer[i],renderTarget,_gl.COLOR_ATTACHMENT0,_gl.TEXTURE_CUBE_MAP_POSITIVE_X+i);}if(textureNeedsGenerateMipmaps(renderTarget.texture,isTargetPowerOfTwo)){generateMipmap(_gl.TEXTURE_CUBE_MAP,renderTarget.texture,renderTarget.width,renderTarget.height);}state.bindTexture(_gl.TEXTURE_CUBE_MAP,null);}else{state.bindTexture(_gl.TEXTURE_2D,textureProperties.__webglTexture);setTextureParameters(_gl.TEXTURE_2D,renderTarget.texture,isTargetPowerOfTwo);setupFrameBufferTexture(renderTargetProperties.__webglFramebuffer,renderTarget,_gl.COLOR_ATTACHMENT0,_gl.TEXTURE_2D);if(textureNeedsGenerateMipmaps(renderTarget.texture,isTargetPowerOfTwo)){generateMipmap(_gl.TEXTURE_2D,renderTarget.texture,renderTarget.width,renderTarget.height);}state.bindTexture(_gl.TEXTURE_2D,null);}// Setup depth and stencil buffers
if(renderTarget.depthBuffer){setupDepthRenderbuffer(renderTarget);}}function updateRenderTargetMipmap(renderTarget){var texture=renderTarget.texture;var isTargetPowerOfTwo=isPowerOfTwo(renderTarget);if(textureNeedsGenerateMipmaps(texture,isTargetPowerOfTwo)){var target=renderTarget.isWebGLRenderTargetCube?_gl.TEXTURE_CUBE_MAP:_gl.TEXTURE_2D;var webglTexture=properties.get(texture).__webglTexture;state.bindTexture(target,webglTexture);generateMipmap(target,texture,renderTarget.width,renderTarget.height);state.bindTexture(target,null);}}function updateVideoTexture(texture){var id=texture.id;var frame=info.render.frame;// Check the last frame we updated the VideoTexture
if(_videoTextures[id]!==frame){_videoTextures[id]=frame;texture.update();}}this.setTexture2D=setTexture2D;this.setTextureCube=setTextureCube;this.setTextureCubeDynamic=setTextureCubeDynamic;this.setupRenderTarget=setupRenderTarget;this.updateRenderTargetMipmap=updateRenderTargetMipmap;}/**
* @author thespite / http://www.twitter.com/thespite
*/function WebGLUtils(gl,extensions){function convert(p){var extension;if(p===RepeatWrapping)return gl.REPEAT;if(p===ClampToEdgeWrapping)return gl.CLAMP_TO_EDGE;if(p===MirroredRepeatWrapping)return gl.MIRRORED_REPEAT;if(p===NearestFilter)return gl.NEAREST;if(p===NearestMipMapNearestFilter)return gl.NEAREST_MIPMAP_NEAREST;if(p===NearestMipMapLinearFilter)return gl.NEAREST_MIPMAP_LINEAR;if(p===LinearFilter)return gl.LINEAR;if(p===LinearMipMapNearestFilter)return gl.LINEAR_MIPMAP_NEAREST;if(p===LinearMipMapLinearFilter)return gl.LINEAR_MIPMAP_LINEAR;if(p===UnsignedByteType)return gl.UNSIGNED_BYTE;if(p===UnsignedShort4444Type)return gl.UNSIGNED_SHORT_4_4_4_4;if(p===UnsignedShort5551Type)return gl.UNSIGNED_SHORT_5_5_5_1;if(p===UnsignedShort565Type)return gl.UNSIGNED_SHORT_5_6_5;if(p===ByteType)return gl.BYTE;if(p===ShortType)return gl.SHORT;if(p===UnsignedShortType)return gl.UNSIGNED_SHORT;if(p===IntType)return gl.INT;if(p===UnsignedIntType)return gl.UNSIGNED_INT;if(p===FloatType)return gl.FLOAT;if(p===HalfFloatType){extension=extensions.get('OES_texture_half_float');if(extension!==null)return extension.HALF_FLOAT_OES;}if(p===AlphaFormat)return gl.ALPHA;if(p===RGBFormat)return gl.RGB;if(p===RGBAFormat)return gl.RGBA;if(p===LuminanceFormat)return gl.LUMINANCE;if(p===LuminanceAlphaFormat)return gl.LUMINANCE_ALPHA;if(p===DepthFormat)return gl.DEPTH_COMPONENT;if(p===DepthStencilFormat)return gl.DEPTH_STENCIL;if(p===AddEquation)return gl.FUNC_ADD;if(p===SubtractEquation)return gl.FUNC_SUBTRACT;if(p===ReverseSubtractEquation)return gl.FUNC_REVERSE_SUBTRACT;if(p===ZeroFactor)return gl.ZERO;if(p===OneFactor)return gl.ONE;if(p===SrcColorFactor)return gl.SRC_COLOR;if(p===OneMinusSrcColorFactor)return gl.ONE_MINUS_SRC_COLOR;if(p===SrcAlphaFactor)return gl.SRC_ALPHA;if(p===OneMinusSrcAlphaFactor)return gl.ONE_MINUS_SRC_ALPHA;if(p===DstAlphaFactor)return gl.DST_ALPHA;if(p===OneMinusDstAlphaFactor)return gl.ONE_MINUS_DST_ALPHA;if(p===DstColorFactor)return gl.DST_COLOR;if(p===OneMinusDstColorFactor)return gl.ONE_MINUS_DST_COLOR;if(p===SrcAlphaSaturateFactor)return gl.SRC_ALPHA_SATURATE;if(p===RGB_S3TC_DXT1_Format||p===RGBA_S3TC_DXT1_Format||p===RGBA_S3TC_DXT3_Format||p===RGBA_S3TC_DXT5_Format){extension=extensions.get('WEBGL_compressed_texture_s3tc');if(extension!==null){if(p===RGB_S3TC_DXT1_Format)return extension.COMPRESSED_RGB_S3TC_DXT1_EXT;if(p===RGBA_S3TC_DXT1_Format)return extension.COMPRESSED_RGBA_S3TC_DXT1_EXT;if(p===RGBA_S3TC_DXT3_Format)return extension.COMPRESSED_RGBA_S3TC_DXT3_EXT;if(p===RGBA_S3TC_DXT5_Format)return extension.COMPRESSED_RGBA_S3TC_DXT5_EXT;}}if(p===RGB_PVRTC_4BPPV1_Format||p===RGB_PVRTC_2BPPV1_Format||p===RGBA_PVRTC_4BPPV1_Format||p===RGBA_PVRTC_2BPPV1_Format){extension=extensions.get('WEBGL_compressed_texture_pvrtc');if(extension!==null){if(p===RGB_PVRTC_4BPPV1_Format)return extension.COMPRESSED_RGB_PVRTC_4BPPV1_IMG;if(p===RGB_PVRTC_2BPPV1_Format)return extension.COMPRESSED_RGB_PVRTC_2BPPV1_IMG;if(p===RGBA_PVRTC_4BPPV1_Format)return extension.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG;if(p===RGBA_PVRTC_2BPPV1_Format)return extension.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG;}}if(p===RGB_ETC1_Format){extension=extensions.get('WEBGL_compressed_texture_etc1');if(extension!==null)return extension.COMPRESSED_RGB_ETC1_WEBGL;}if(p===RGBA_ASTC_4x4_Format||p===RGBA_ASTC_5x4_Format||p===RGBA_ASTC_5x5_Format||p===RGBA_ASTC_6x5_Format||p===RGBA_ASTC_6x6_Format||p===RGBA_ASTC_8x5_Format||p===RGBA_ASTC_8x6_Format||p===RGBA_ASTC_8x8_Format||p===RGBA_ASTC_10x5_Format||p===RGBA_ASTC_10x6_Format||p===RGBA_ASTC_10x8_Format||p===RGBA_ASTC_10x10_Format||p===RGBA_ASTC_12x10_Format||p===RGBA_ASTC_12x12_Format){extension=extensions.get('WEBGL_compressed_texture_astc');if(extension!==null){return p;}}if(p===MinEquation||p===MaxEquation){extension=extensions.get('EXT_blend_minmax');if(extension!==null){if(p===MinEquation)return extension.MIN_EXT;if(p===MaxEquation)return extension.MAX_EXT;}}if(p===UnsignedInt248Type){extension=extensions.get('WEBGL_depth_texture');if(extension!==null)return extension.UNSIGNED_INT_24_8_WEBGL;}return 0;}return {convert:convert};}/**
* @author mrdoob / http://mrdoob.com/
* @author greggman / http://games.greggman.com/
* @author zz85 / http://www.lab4games.net/zz85/blog
* @author tschw
*/function PerspectiveCamera(fov,aspect,near,far){Camera.call(this);this.type='PerspectiveCamera';this.fov=fov!==undefined?fov:50;this.zoom=1;this.near=near!==undefined?near:0.1;this.far=far!==undefined?far:2000;this.focus=10;this.aspect=aspect!==undefined?aspect:1;this.view=null;this.filmGauge=35;// width of the film (default in millimeters)
this.filmOffset=0;// horizontal film offset (same unit as gauge)
this.updateProjectionMatrix();}PerspectiveCamera.prototype=Object.assign(Object.create(Camera.prototype),{constructor:PerspectiveCamera,isPerspectiveCamera:true,copy:function(source,recursive){Camera.prototype.copy.call(this,source,recursive);this.fov=source.fov;this.zoom=source.zoom;this.near=source.near;this.far=source.far;this.focus=source.focus;this.aspect=source.aspect;this.view=source.view===null?null:Object.assign({},source.view);this.filmGauge=source.filmGauge;this.filmOffset=source.filmOffset;return this;},/**
* Sets the FOV by focal length in respect to the current .filmGauge.
*
* The default film gauge is 35, so that the focal length can be specified for
* a 35mm (full frame) camera.
*
* Values for focal length and film gauge must have the same unit.
*/setFocalLength:function(focalLength){// see http://www.bobatkins.com/photography/technical/field_of_view.html
var vExtentSlope=0.5*this.getFilmHeight()/focalLength;this.fov=_Math.RAD2DEG*2*Math.atan(vExtentSlope);this.updateProjectionMatrix();},/**
* Calculates the focal length from the current .fov and .filmGauge.
*/getFocalLength:function(){var vExtentSlope=Math.tan(_Math.DEG2RAD*0.5*this.fov);return 0.5*this.getFilmHeight()/vExtentSlope;},getEffectiveFOV:function(){return _Math.RAD2DEG*2*Math.atan(Math.tan(_Math.DEG2RAD*0.5*this.fov)/this.zoom);},getFilmWidth:function(){// film not completely covered in portrait format (aspect < 1)
return this.filmGauge*Math.min(this.aspect,1);},getFilmHeight:function(){// film not completely covered in landscape format (aspect > 1)
return this.filmGauge/Math.max(this.aspect,1);},/**
* Sets an offset in a larger frustum. This is useful for multi-window or
* multi-monitor/multi-machine setups.
*
* For example, if you have 3x2 monitors and each monitor is 1920x1080 and
* the monitors are in grid like this
*
* +---+---+---+
* | A | B | C |
* +---+---+---+
* | D | E | F |
* +---+---+---+
*
* then for each monitor you would call it like this
*
* var w = 1920;
* var h = 1080;
* var fullWidth = w * 3;
* var fullHeight = h * 2;
*
* --A--
* camera.setOffset( fullWidth, fullHeight, w * 0, h * 0, w, h );
* --B--
* camera.setOffset( fullWidth, fullHeight, w * 1, h * 0, w, h );
* --C--
* camera.setOffset( fullWidth, fullHeight, w * 2, h * 0, w, h );
* --D--
* camera.setOffset( fullWidth, fullHeight, w * 0, h * 1, w, h );
* --E--
* camera.setOffset( fullWidth, fullHeight, w * 1, h * 1, w, h );
* --F--
* camera.setOffset( fullWidth, fullHeight, w * 2, h * 1, w, h );
*
* Note there is no reason monitors have to be the same size or in a grid.
*/setViewOffset:function(fullWidth,fullHeight,x,y,width,height){this.aspect=fullWidth/fullHeight;if(this.view===null){this.view={enabled:true,fullWidth:1,fullHeight:1,offsetX:0,offsetY:0,width:1,height:1};}this.view.enabled=true;this.view.fullWidth=fullWidth;this.view.fullHeight=fullHeight;this.view.offsetX=x;this.view.offsetY=y;this.view.width=width;this.view.height=height;this.updateProjectionMatrix();},clearViewOffset:function(){if(this.view!==null){this.view.enabled=false;}this.updateProjectionMatrix();},updateProjectionMatrix:function(){var near=this.near,top=near*Math.tan(_Math.DEG2RAD*0.5*this.fov)/this.zoom,height=2*top,width=this.aspect*height,left=-0.5*width,view=this.view;if(this.view!==null&&this.view.enabled){var fullWidth=view.fullWidth,fullHeight=view.fullHeight;left+=view.offsetX*width/fullWidth;top-=view.offsetY*height/fullHeight;width*=view.width/fullWidth;height*=view.height/fullHeight;}var skew=this.filmOffset;if(skew!==0)left+=near*skew/this.getFilmWidth();this.projectionMatrix.makePerspective(left,left+width,top,top-height,near,this.far);},toJSON:function(meta){var data=Object3D.prototype.toJSON.call(this,meta);data.object.fov=this.fov;data.object.zoom=this.zoom;data.object.near=this.near;data.object.far=this.far;data.object.focus=this.focus;data.object.aspect=this.aspect;if(this.view!==null)data.object.view=Object.assign({},this.view);data.object.filmGauge=this.filmGauge;data.object.filmOffset=this.filmOffset;return data;}});/**
* @author mrdoob / http://mrdoob.com/
*/function ArrayCamera(array){PerspectiveCamera.call(this);this.cameras=array||[];}ArrayCamera.prototype=Object.assign(Object.create(PerspectiveCamera.prototype),{constructor:ArrayCamera,isArrayCamera:true});/**
* @author mrdoob / http://mrdoob.com/
*/function WebVRManager(renderer){var scope=this;var device=null;var frameData=null;var poseTarget=null;var standingMatrix=new Matrix4();var standingMatrixInverse=new Matrix4();if(typeof window!=='undefined'&&'VRFrameData'in window){frameData=new window.VRFrameData();window.addEventListener('vrdisplaypresentchange',onVRDisplayPresentChange,false);}var matrixWorldInverse=new Matrix4();var tempQuaternion=new Quaternion();var tempPosition=new Vector3();var cameraL=new PerspectiveCamera();cameraL.bounds=new Vector4(0.0,0.0,0.5,1.0);cameraL.layers.enable(1);var cameraR=new PerspectiveCamera();cameraR.bounds=new Vector4(0.5,0.0,0.5,1.0);cameraR.layers.enable(2);var cameraVR=new ArrayCamera([cameraL,cameraR]);cameraVR.layers.enable(1);cameraVR.layers.enable(2);//
function isPresenting(){return device!==null&&device.isPresenting===true;}var currentSize,currentPixelRatio;function onVRDisplayPresentChange(){if(isPresenting()){var eyeParameters=device.getEyeParameters('left');var renderWidth=eyeParameters.renderWidth;var renderHeight=eyeParameters.renderHeight;currentPixelRatio=renderer.getPixelRatio();currentSize=renderer.getSize();renderer.setDrawingBufferSize(renderWidth*2,renderHeight,1);}else if(scope.enabled){renderer.setDrawingBufferSize(currentSize.width,currentSize.height,currentPixelRatio);}}//
this.enabled=false;this.userHeight=1.6;this.getDevice=function(){return device;};this.setDevice=function(value){if(value!==undefined)device=value;};this.setPoseTarget=function(object){if(object!==undefined)poseTarget=object;};this.getCamera=function(camera){if(device===null)return camera;device.depthNear=camera.near;device.depthFar=camera.far;device.getFrameData(frameData);//
var stageParameters=device.stageParameters;if(stageParameters){standingMatrix.fromArray(stageParameters.sittingToStandingTransform);}else{standingMatrix.makeTranslation(0,scope.userHeight,0);}var pose=frameData.pose;var poseObject=poseTarget!==null?poseTarget:camera;// We want to manipulate poseObject by its position and quaternion components since users may rely on them.
poseObject.matrix.copy(standingMatrix);poseObject.matrix.decompose(poseObject.position,poseObject.quaternion,poseObject.scale);if(pose.orientation!==null){tempQuaternion.fromArray(pose.orientation);poseObject.quaternion.multiply(tempQuaternion);}if(pose.position!==null){tempQuaternion.setFromRotationMatrix(standingMatrix);tempPosition.fromArray(pose.position);tempPosition.applyQuaternion(tempQuaternion);poseObject.position.add(tempPosition);}poseObject.updateMatrixWorld();if(device.isPresenting===false)return camera;//
cameraL.near=camera.near;cameraR.near=camera.near;cameraL.far=camera.far;cameraR.far=camera.far;cameraVR.matrixWorld.copy(camera.matrixWorld);cameraVR.matrixWorldInverse.copy(camera.matrixWorldInverse);cameraL.matrixWorldInverse.fromArray(frameData.leftViewMatrix);cameraR.matrixWorldInverse.fromArray(frameData.rightViewMatrix);// TODO (mrdoob) Double check this code
standingMatrixInverse.getInverse(standingMatrix);cameraL.matrixWorldInverse.multiply(standingMatrixInverse);cameraR.matrixWorldInverse.multiply(standingMatrixInverse);var parent=poseObject.parent;if(parent!==null){matrixWorldInverse.getInverse(parent.matrixWorld);cameraL.matrixWorldInverse.multiply(matrixWorldInverse);cameraR.matrixWorldInverse.multiply(matrixWorldInverse);}// envMap and Mirror needs camera.matrixWorld
cameraL.matrixWorld.getInverse(cameraL.matrixWorldInverse);cameraR.matrixWorld.getInverse(cameraR.matrixWorldInverse);cameraL.projectionMatrix.fromArray(frameData.leftProjectionMatrix);cameraR.projectionMatrix.fromArray(frameData.rightProjectionMatrix);// HACK (mrdoob)
// https://github.com/w3c/webvr/issues/203
cameraVR.projectionMatrix.copy(cameraL.projectionMatrix);//
var layers=device.getLayers();if(layers.length){var layer=layers[0];if(layer.leftBounds!==null&&layer.leftBounds.length===4){cameraL.bounds.fromArray(layer.leftBounds);}if(layer.rightBounds!==null&&layer.rightBounds.length===4){cameraR.bounds.fromArray(layer.rightBounds);}}return cameraVR;};this.getStandingMatrix=function(){return standingMatrix;};this.submitFrame=function(){if(isPresenting())device.submitFrame();};this.dispose=function(){if(typeof window!=='undefined'){window.removeEventListener('vrdisplaypresentchange',onVRDisplayPresentChange);}};}/**
* @author supereggbert / http://www.paulbrunt.co.uk/
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
* @author szimek / https://github.com/szimek/
* @author tschw
*/function WebGLRenderer(parameters){console.log('THREE.WebGLRenderer',REVISION);parameters=parameters||{};var _canvas=parameters.canvas!==undefined?parameters.canvas:document.createElementNS('http://www.w3.org/1999/xhtml','canvas'),_context=parameters.context!==undefined?parameters.context:null,_alpha=parameters.alpha!==undefined?parameters.alpha:false,_depth=parameters.depth!==undefined?parameters.depth:true,_stencil=parameters.stencil!==undefined?parameters.stencil:true,_antialias=parameters.antialias!==undefined?parameters.antialias:false,_premultipliedAlpha=parameters.premultipliedAlpha!==undefined?parameters.premultipliedAlpha:true,_preserveDrawingBuffer=parameters.preserveDrawingBuffer!==undefined?parameters.preserveDrawingBuffer:false,_powerPreference=parameters.powerPreference!==undefined?parameters.powerPreference:'default';var currentRenderList=null;var currentRenderState=null;// public properties
this.domElement=_canvas;this.context=null;// clearing
this.autoClear=true;this.autoClearColor=true;this.autoClearDepth=true;this.autoClearStencil=true;// scene graph
this.sortObjects=true;// user-defined clipping
this.clippingPlanes=[];this.localClippingEnabled=false;// physically based shading
this.gammaFactor=2.0;// for backwards compatibility
this.gammaInput=false;this.gammaOutput=false;// physical lights
this.physicallyCorrectLights=false;// tone mapping
this.toneMapping=LinearToneMapping;this.toneMappingExposure=1.0;this.toneMappingWhitePoint=1.0;// morphs
this.maxMorphTargets=8;this.maxMorphNormals=4;// internal properties
var _this=this,_isContextLost=false,// internal state cache
_currentRenderTarget=null,_currentFramebuffer=null,_currentMaterialId=-1,_currentGeometryProgram='',_currentCamera=null,_currentArrayCamera=null,_currentViewport=new Vector4(),_currentScissor=new Vector4(),_currentScissorTest=null,//
_usedTextureUnits=0,//
_width=_canvas.width,_height=_canvas.height,_pixelRatio=1,_viewport=new Vector4(0,0,_width,_height),_scissor=new Vector4(0,0,_width,_height),_scissorTest=false,// frustum
_frustum=new Frustum(),// clipping
_clipping=new WebGLClipping(),_clippingEnabled=false,_localClippingEnabled=false,// camera matrices cache
_projScreenMatrix=new Matrix4(),_vector3=new Vector3();function getTargetPixelRatio(){return _currentRenderTarget===null?_pixelRatio:1;}// initialize
var _gl;try{var contextAttributes={alpha:_alpha,depth:_depth,stencil:_stencil,antialias:_antialias,premultipliedAlpha:_premultipliedAlpha,preserveDrawingBuffer:_preserveDrawingBuffer,powerPreference:_powerPreference};// event listeners must be registered before WebGL context is created, see #12753
_canvas.addEventListener('webglcontextlost',onContextLost,false);_canvas.addEventListener('webglcontextrestored',onContextRestore,false);_gl=_context||_canvas.getContext('webgl',contextAttributes)||_canvas.getContext('experimental-webgl',contextAttributes);if(_gl===null){if(_canvas.getContext('webgl')!==null){throw new Error('Error creating WebGL context with your selected attributes.');}else{throw new Error('Error creating WebGL context.');}}// Some experimental-webgl implementations do not have getShaderPrecisionFormat
if(_gl.getShaderPrecisionFormat===undefined){_gl.getShaderPrecisionFormat=function(){return {'rangeMin':1,'rangeMax':1,'precision':1};};}}catch(error){console.error('THREE.WebGLRenderer: '+error.message);}var extensions,capabilities,state,info;var properties,textures,attributes,geometries,objects;var programCache,renderLists,renderStates;var background,morphtargets,bufferRenderer,indexedBufferRenderer;var spriteRenderer;var utils;function initGLContext(){extensions=new WebGLExtensions(_gl);extensions.get('WEBGL_depth_texture');extensions.get('OES_texture_float');extensions.get('OES_texture_float_linear');extensions.get('OES_texture_half_float');extensions.get('OES_texture_half_float_linear');extensions.get('OES_standard_derivatives');extensions.get('OES_element_index_uint');extensions.get('ANGLE_instanced_arrays');utils=new WebGLUtils(_gl,extensions);capabilities=new WebGLCapabilities(_gl,extensions,parameters);state=new WebGLState(_gl,extensions,utils);state.scissor(_currentScissor.copy(_scissor).multiplyScalar(_pixelRatio));state.viewport(_currentViewport.copy(_viewport).multiplyScalar(_pixelRatio));info=new WebGLInfo(_gl);properties=new WebGLProperties();textures=new WebGLTextures(_gl,extensions,state,properties,capabilities,utils,info);attributes=new WebGLAttributes(_gl);geometries=new WebGLGeometries(_gl,attributes,info);objects=new WebGLObjects(geometries,info);morphtargets=new WebGLMorphtargets(_gl);programCache=new WebGLPrograms(_this,extensions,capabilities);renderLists=new WebGLRenderLists();renderStates=new WebGLRenderStates();background=new WebGLBackground(_this,state,geometries,_premultipliedAlpha);bufferRenderer=new WebGLBufferRenderer(_gl,extensions,info);indexedBufferRenderer=new WebGLIndexedBufferRenderer(_gl,extensions,info);spriteRenderer=new WebGLSpriteRenderer(_this,_gl,state,textures,capabilities);info.programs=programCache.programs;_this.context=_gl;_this.capabilities=capabilities;_this.extensions=extensions;_this.properties=properties;_this.renderLists=renderLists;_this.state=state;_this.info=info;}initGLContext();// vr
var vr=new WebVRManager(_this);this.vr=vr;// shadow map
var shadowMap=new WebGLShadowMap(_this,objects,capabilities.maxTextureSize);this.shadowMap=shadowMap;// API
this.getContext=function(){return _gl;};this.getContextAttributes=function(){return _gl.getContextAttributes();};this.forceContextLoss=function(){var extension=extensions.get('WEBGL_lose_context');if(extension)extension.loseContext();};this.forceContextRestore=function(){var extension=extensions.get('WEBGL_lose_context');if(extension)extension.restoreContext();};this.getPixelRatio=function(){return _pixelRatio;};this.setPixelRatio=function(value){if(value===undefined)return;_pixelRatio=value;this.setSize(_width,_height,false);};this.getSize=function(){return {width:_width,height:_height};};this.setSize=function(width,height,updateStyle){var device=vr.getDevice();if(device&&device.isPresenting){console.warn('THREE.WebGLRenderer: Can\'t change size while VR device is presenting.');return;}_width=width;_height=height;_canvas.width=width*_pixelRatio;_canvas.height=height*_pixelRatio;if(updateStyle!==false){_canvas.style.width=width+'px';_canvas.style.height=height+'px';}this.setViewport(0,0,width,height);};this.getDrawingBufferSize=function(){return {width:_width*_pixelRatio,height:_height*_pixelRatio};};this.setDrawingBufferSize=function(width,height,pixelRatio){_width=width;_height=height;_pixelRatio=pixelRatio;_canvas.width=width*pixelRatio;_canvas.height=height*pixelRatio;this.setViewport(0,0,width,height);};this.getCurrentViewport=function(){return _currentViewport;};this.setViewport=function(x,y,width,height){_viewport.set(x,_height-y-height,width,height);state.viewport(_currentViewport.copy(_viewport).multiplyScalar(_pixelRatio));};this.setScissor=function(x,y,width,height){_scissor.set(x,_height-y-height,width,height);state.scissor(_currentScissor.copy(_scissor).multiplyScalar(_pixelRatio));};this.setScissorTest=function(boolean){state.setScissorTest(_scissorTest=boolean);};// Clearing
this.getClearColor=function(){return background.getClearColor();};this.setClearColor=function(){background.setClearColor.apply(background,arguments);};this.getClearAlpha=function(){return background.getClearAlpha();};this.setClearAlpha=function(){background.setClearAlpha.apply(background,arguments);};this.clear=function(color,depth,stencil){var bits=0;if(color===undefined||color)bits|=_gl.COLOR_BUFFER_BIT;if(depth===undefined||depth)bits|=_gl.DEPTH_BUFFER_BIT;if(stencil===undefined||stencil)bits|=_gl.STENCIL_BUFFER_BIT;_gl.clear(bits);};this.clearColor=function(){this.clear(true,false,false);};this.clearDepth=function(){this.clear(false,true,false);};this.clearStencil=function(){this.clear(false,false,true);};this.clearTarget=function(renderTarget,color,depth,stencil){this.setRenderTarget(renderTarget);this.clear(color,depth,stencil);};//
this.dispose=function(){_canvas.removeEventListener('webglcontextlost',onContextLost,false);_canvas.removeEventListener('webglcontextrestored',onContextRestore,false);renderLists.dispose();renderStates.dispose();properties.dispose();objects.dispose();vr.dispose();stopAnimation();};// Events
function onContextLost(event){event.preventDefault();console.log('THREE.WebGLRenderer: Context Lost.');_isContextLost=true;}function onContextRestore()/* event */{console.log('THREE.WebGLRenderer: Context Restored.');_isContextLost=false;initGLContext();}function onMaterialDispose(event){var material=event.target;material.removeEventListener('dispose',onMaterialDispose);deallocateMaterial(material);}// Buffer deallocation
function deallocateMaterial(material){releaseMaterialProgramReference(material);properties.remove(material);}function releaseMaterialProgramReference(material){var programInfo=properties.get(material).program;material.program=undefined;if(programInfo!==undefined){programCache.releaseProgram(programInfo);}}// Buffer rendering
function renderObjectImmediate(object,program,material){object.render(function(object){_this.renderBufferImmediate(object,program,material);});}this.renderBufferImmediate=function(object,program,material){state.initAttributes();var buffers=properties.get(object);if(object.hasPositions&&!buffers.position)buffers.position=_gl.createBuffer();if(object.hasNormals&&!buffers.normal)buffers.normal=_gl.createBuffer();if(object.hasUvs&&!buffers.uv)buffers.uv=_gl.createBuffer();if(object.hasColors&&!buffers.color)buffers.color=_gl.createBuffer();var programAttributes=program.getAttributes();if(object.hasPositions){_gl.bindBuffer(_gl.ARRAY_BUFFER,buffers.position);_gl.bufferData(_gl.ARRAY_BUFFER,object.positionArray,_gl.DYNAMIC_DRAW);state.enableAttribute(programAttributes.position);_gl.vertexAttribPointer(programAttributes.position,3,_gl.FLOAT,false,0,0);}if(object.hasNormals){_gl.bindBuffer(_gl.ARRAY_BUFFER,buffers.normal);if(!material.isMeshPhongMaterial&&!material.isMeshStandardMaterial&&!material.isMeshNormalMaterial&&material.flatShading===true){for(var i=0,l=object.count*3;i<l;i+=9){var array=object.normalArray;var nx=(array[i+0]+array[i+3]+array[i+6])/3;var ny=(array[i+1]+array[i+4]+array[i+7])/3;var nz=(array[i+2]+array[i+5]+array[i+8])/3;array[i+0]=nx;array[i+1]=ny;array[i+2]=nz;array[i+3]=nx;array[i+4]=ny;array[i+5]=nz;array[i+6]=nx;array[i+7]=ny;array[i+8]=nz;}}_gl.bufferData(_gl.ARRAY_BUFFER,object.normalArray,_gl.DYNAMIC_DRAW);state.enableAttribute(programAttributes.normal);_gl.vertexAttribPointer(programAttributes.normal,3,_gl.FLOAT,false,0,0);}if(object.hasUvs&&material.map){_gl.bindBuffer(_gl.ARRAY_BUFFER,buffers.uv);_gl.bufferData(_gl.ARRAY_BUFFER,object.uvArray,_gl.DYNAMIC_DRAW);state.enableAttribute(programAttributes.uv);_gl.vertexAttribPointer(programAttributes.uv,2,_gl.FLOAT,false,0,0);}if(object.hasColors&&material.vertexColors!==NoColors){_gl.bindBuffer(_gl.ARRAY_BUFFER,buffers.color);_gl.bufferData(_gl.ARRAY_BUFFER,object.colorArray,_gl.DYNAMIC_DRAW);state.enableAttribute(programAttributes.color);_gl.vertexAttribPointer(programAttributes.color,3,_gl.FLOAT,false,0,0);}state.disableUnusedAttributes();_gl.drawArrays(_gl.TRIANGLES,0,object.count);object.count=0;};this.renderBufferDirect=function(camera,fog,geometry,material,object,group){var frontFaceCW=object.isMesh&&object.matrixWorld.determinant()<0;state.setMaterial(material,frontFaceCW);var program=setProgram(camera,fog,material,object);var geometryProgram=geometry.id+'_'+program.id+'_'+(material.wireframe===true);var updateBuffers=false;if(geometryProgram!==_currentGeometryProgram){_currentGeometryProgram=geometryProgram;updateBuffers=true;}if(object.morphTargetInfluences){morphtargets.update(object,geometry,material,program);updateBuffers=true;}//
var index=geometry.index;var position=geometry.attributes.position;var rangeFactor=1;if(material.wireframe===true){index=geometries.getWireframeAttribute(geometry);rangeFactor=2;}var attribute;var renderer=bufferRenderer;if(index!==null){attribute=attributes.get(index);renderer=indexedBufferRenderer;renderer.setIndex(attribute);}if(updateBuffers){setupVertexAttributes(material,program,geometry);if(index!==null){_gl.bindBuffer(_gl.ELEMENT_ARRAY_BUFFER,attribute.buffer);}}//
var dataCount=Infinity;if(index!==null){dataCount=index.count;}else if(position!==undefined){dataCount=position.count;}var rangeStart=geometry.drawRange.start*rangeFactor;var rangeCount=geometry.drawRange.count*rangeFactor;var groupStart=group!==null?group.start*rangeFactor:0;var groupCount=group!==null?group.count*rangeFactor:Infinity;var drawStart=Math.max(rangeStart,groupStart);var drawEnd=Math.min(dataCount,rangeStart+rangeCount,groupStart+groupCount)-1;var drawCount=Math.max(0,drawEnd-drawStart+1);if(drawCount===0)return;//
if(object.isMesh){if(material.wireframe===true){state.setLineWidth(material.wireframeLinewidth*getTargetPixelRatio());renderer.setMode(_gl.LINES);}else{switch(object.drawMode){case TrianglesDrawMode:renderer.setMode(_gl.TRIANGLES);break;case TriangleStripDrawMode:renderer.setMode(_gl.TRIANGLE_STRIP);break;case TriangleFanDrawMode:renderer.setMode(_gl.TRIANGLE_FAN);break;}}}else if(object.isLine){var lineWidth=material.linewidth;if(lineWidth===undefined)lineWidth=1;// Not using Line*Material
state.setLineWidth(lineWidth*getTargetPixelRatio());if(object.isLineSegments){renderer.setMode(_gl.LINES);}else if(object.isLineLoop){renderer.setMode(_gl.LINE_LOOP);}else{renderer.setMode(_gl.LINE_STRIP);}}else if(object.isPoints){renderer.setMode(_gl.POINTS);}if(geometry&&geometry.isInstancedBufferGeometry){if(geometry.maxInstancedCount>0){renderer.renderInstances(geometry,drawStart,drawCount);}}else{renderer.render(drawStart,drawCount);}};function setupVertexAttributes(material,program,geometry){if(geometry&&geometry.isInstancedBufferGeometry){if(extensions.get('ANGLE_instanced_arrays')===null){console.error('THREE.WebGLRenderer.setupVertexAttributes: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.');return;}}state.initAttributes();var geometryAttributes=geometry.attributes;var programAttributes=program.getAttributes();var materialDefaultAttributeValues=material.defaultAttributeValues;for(var name in programAttributes){var programAttribute=programAttributes[name];if(programAttribute>=0){var geometryAttribute=geometryAttributes[name];if(geometryAttribute!==undefined){var normalized=geometryAttribute.normalized;var size=geometryAttribute.itemSize;var attribute=attributes.get(geometryAttribute);// TODO Attribute may not be available on context restore
if(attribute===undefined)continue;var buffer=attribute.buffer;var type=attribute.type;var bytesPerElement=attribute.bytesPerElement;if(geometryAttribute.isInterleavedBufferAttribute){var data=geometryAttribute.data;var stride=data.stride;var offset=geometryAttribute.offset;if(data&&data.isInstancedInterleavedBuffer){state.enableAttributeAndDivisor(programAttribute,data.meshPerAttribute);if(geometry.maxInstancedCount===undefined){geometry.maxInstancedCount=data.meshPerAttribute*data.count;}}else{state.enableAttribute(programAttribute);}_gl.bindBuffer(_gl.ARRAY_BUFFER,buffer);_gl.vertexAttribPointer(programAttribute,size,type,normalized,stride*bytesPerElement,offset*bytesPerElement);}else{if(geometryAttribute.isInstancedBufferAttribute){state.enableAttributeAndDivisor(programAttribute,geometryAttribute.meshPerAttribute);if(geometry.maxInstancedCount===undefined){geometry.maxInstancedCount=geometryAttribute.meshPerAttribute*geometryAttribute.count;}}else{state.enableAttribute(programAttribute);}_gl.bindBuffer(_gl.ARRAY_BUFFER,buffer);_gl.vertexAttribPointer(programAttribute,size,type,normalized,0,0);}}else if(materialDefaultAttributeValues!==undefined){var value=materialDefaultAttributeValues[name];if(value!==undefined){switch(value.length){case 2:_gl.vertexAttrib2fv(programAttribute,value);break;case 3:_gl.vertexAttrib3fv(programAttribute,value);break;case 4:_gl.vertexAttrib4fv(programAttribute,value);break;default:_gl.vertexAttrib1fv(programAttribute,value);}}}}}state.disableUnusedAttributes();}// Compile
this.compile=function(scene,camera){currentRenderState=renderStates.get(scene,camera);currentRenderState.init();scene.traverse(function(object){if(object.isLight){currentRenderState.pushLight(object);if(object.castShadow){currentRenderState.pushShadow(object);}}});currentRenderState.setupLights(camera);scene.traverse(function(object){if(object.material){if(Array.isArray(object.material)){for(var i=0;i<object.material.length;i++){initMaterial(object.material[i],scene.fog,object);}}else{initMaterial(object.material,scene.fog,object);}}});};// Animation Loop
var isAnimating=false;var onAnimationFrame=null;function startAnimation(){if(isAnimating)return;requestAnimationLoopFrame();isAnimating=true;}function stopAnimation(){isAnimating=false;}function requestAnimationLoopFrame(){var device=vr.getDevice();if(device&&device.isPresenting){device.requestAnimationFrame(animationLoop);}else{window.requestAnimationFrame(animationLoop);}}function animationLoop(time){if(isAnimating===false)return;onAnimationFrame(time);requestAnimationLoopFrame();}this.animate=function(callback){onAnimationFrame=callback;onAnimationFrame!==null?startAnimation():stopAnimation();};// Rendering
this.render=function(scene,camera,renderTarget,forceClear){if(!(camera&&camera.isCamera)){console.error('THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.');return;}if(_isContextLost)return;// reset caching for this frame
_currentGeometryProgram='';_currentMaterialId=-1;_currentCamera=null;// update scene graph
if(scene.autoUpdate===true)scene.updateMatrixWorld();// update camera matrices and frustum
if(camera.parent===null)camera.updateMatrixWorld();if(vr.enabled){camera=vr.getCamera(camera);}//
currentRenderState=renderStates.get(scene,camera);currentRenderState.init();scene.onBeforeRender(_this,scene,camera,renderTarget);_projScreenMatrix.multiplyMatrices(camera.projectionMatrix,camera.matrixWorldInverse);_frustum.setFromMatrix(_projScreenMatrix);_localClippingEnabled=this.localClippingEnabled;_clippingEnabled=_clipping.init(this.clippingPlanes,_localClippingEnabled,camera);currentRenderList=renderLists.get(scene,camera);currentRenderList.init();projectObject(scene,camera,_this.sortObjects);if(_this.sortObjects===true){currentRenderList.sort();}//
if(_clippingEnabled)_clipping.beginShadows();var shadowsArray=currentRenderState.state.shadowsArray;shadowMap.render(shadowsArray,scene,camera);currentRenderState.setupLights(camera);if(_clippingEnabled)_clipping.endShadows();//
if(this.info.autoReset)this.info.reset();if(renderTarget===undefined){renderTarget=null;}this.setRenderTarget(renderTarget);//
background.render(currentRenderList,scene,camera,forceClear);// render scene
var opaqueObjects=currentRenderList.opaque;var transparentObjects=currentRenderList.transparent;if(scene.overrideMaterial){var overrideMaterial=scene.overrideMaterial;if(opaqueObjects.length)renderObjects(opaqueObjects,scene,camera,overrideMaterial);if(transparentObjects.length)renderObjects(transparentObjects,scene,camera,overrideMaterial);}else{// opaque pass (front-to-back order)
if(opaqueObjects.length)renderObjects(opaqueObjects,scene,camera);// transparent pass (back-to-front order)
if(transparentObjects.length)renderObjects(transparentObjects,scene,camera);}// custom renderers
var spritesArray=currentRenderState.state.spritesArray;spriteRenderer.render(spritesArray,scene,camera);// Generate mipmap if we're using any kind of mipmap filtering
if(renderTarget){textures.updateRenderTargetMipmap(renderTarget);}// Ensure depth buffer writing is enabled so it can be cleared on next render
state.buffers.depth.setTest(true);state.buffers.depth.setMask(true);state.buffers.color.setMask(true);state.setPolygonOffset(false);scene.onAfterRender(_this,scene,camera);if(vr.enabled){vr.submitFrame();}// _gl.finish();
currentRenderList=null;currentRenderState=null;};/*
// TODO Duplicated code (Frustum)
var _sphere = new Sphere();
function isObjectViewable( object ) {
var geometry = object.geometry;
if ( geometry.boundingSphere === null )
geometry.computeBoundingSphere();
_sphere.copy( geometry.boundingSphere ).
applyMatrix4( object.matrixWorld );
return isSphereViewable( _sphere );
}
function isSpriteViewable( sprite ) {
_sphere.center.set( 0, 0, 0 );
_sphere.radius = 0.7071067811865476;
_sphere.applyMatrix4( sprite.matrixWorld );
return isSphereViewable( _sphere );
}
function isSphereViewable( sphere ) {
if ( ! _frustum.intersectsSphere( sphere ) ) return false;
var numPlanes = _clipping.numPlanes;
if ( numPlanes === 0 ) return true;
var planes = _this.clippingPlanes,
center = sphere.center,
negRad = - sphere.radius,
i = 0;
do {
// out when deeper than radius in the negative halfspace
if ( planes[ i ].distanceToPoint( center ) < negRad ) return false;
} while ( ++ i !== numPlanes );
return true;
}
*/function projectObject(object,camera,sortObjects){if(object.visible===false)return;var visible=object.layers.test(camera.layers);if(visible){if(object.isLight){currentRenderState.pushLight(object);if(object.castShadow){currentRenderState.pushShadow(object);}}else if(object.isSprite){if(!object.frustumCulled||_frustum.intersectsSprite(object)){currentRenderState.pushSprite(object);}}else if(object.isImmediateRenderObject){if(sortObjects){_vector3.setFromMatrixPosition(object.matrixWorld).applyMatrix4(_projScreenMatrix);}currentRenderList.push(object,null,object.material,_vector3.z,null);}else if(object.isMesh||object.isLine||object.isPoints){if(object.isSkinnedMesh){object.skeleton.update();}if(!object.frustumCulled||_frustum.intersectsObject(object)){if(sortObjects){_vector3.setFromMatrixPosition(object.matrixWorld).applyMatrix4(_projScreenMatrix);}var geometry=objects.update(object);var material=object.material;if(Array.isArray(material)){var groups=geometry.groups;for(var i=0,l=groups.length;i<l;i++){var group=groups[i];var groupMaterial=material[group.materialIndex];if(groupMaterial&&groupMaterial.visible){currentRenderList.push(object,geometry,groupMaterial,_vector3.z,group);}}}else if(material.visible){currentRenderList.push(object,geometry,material,_vector3.z,null);}}}}var children=object.children;for(var i=0,l=children.length;i<l;i++){projectObject(children[i],camera,sortObjects);}}function renderObjects(renderList,scene,camera,overrideMaterial){for(var i=0,l=renderList.length;i<l;i++){var renderItem=renderList[i];var object=renderItem.object;var geometry=renderItem.geometry;var material=overrideMaterial===undefined?renderItem.material:overrideMaterial;var group=renderItem.group;if(camera.isArrayCamera){_currentArrayCamera=camera;var cameras=camera.cameras;for(var j=0,jl=cameras.length;j<jl;j++){var camera2=cameras[j];if(object.layers.test(camera2.layers)){var bounds=camera2.bounds;var x=bounds.x*_width;var y=bounds.y*_height;var width=bounds.z*_width;var height=bounds.w*_height;state.viewport(_currentViewport.set(x,y,width,height).multiplyScalar(_pixelRatio));renderObject(object,scene,camera2,geometry,material,group);}}}else{_currentArrayCamera=null;renderObject(object,scene,camera,geometry,material,group);}}}function renderObject(object,scene,camera,geometry,material,group){object.onBeforeRender(_this,scene,camera,geometry,material,group);currentRenderState=renderStates.get(scene,_currentArrayCamera||camera);object.modelViewMatrix.multiplyMatrices(camera.matrixWorldInverse,object.matrixWorld);object.normalMatrix.getNormalMatrix(object.modelViewMatrix);if(object.isImmediateRenderObject){var frontFaceCW=object.isMesh&&object.matrixWorld.determinant()<0;state.setMaterial(material,frontFaceCW);var program=setProgram(camera,scene.fog,material,object);_currentGeometryProgram='';renderObjectImmediate(object,program,material);}else{_this.renderBufferDirect(camera,scene.fog,geometry,material,object,group);}object.onAfterRender(_this,scene,camera,geometry,material,group);currentRenderState=renderStates.get(scene,_currentArrayCamera||camera);}function initMaterial(material,fog,object){var materialProperties=properties.get(material);var lights=currentRenderState.state.lights;var shadowsArray=currentRenderState.state.shadowsArray;var parameters=programCache.getParameters(material,lights.state,shadowsArray,fog,_clipping.numPlanes,_clipping.numIntersection,object);var code=programCache.getProgramCode(material,parameters);var program=materialProperties.program;var programChange=true;if(program===undefined){// new material
material.addEventListener('dispose',onMaterialDispose);}else if(program.code!==code){// changed glsl or parameters
releaseMaterialProgramReference(material);}else if(materialProperties.lightsHash!==lights.state.hash){properties.update(material,'lightsHash',lights.state.hash);programChange=false;}else if(parameters.shaderID!==undefined){// same glsl and uniform list
return;}else{// only rebuild uniform list
programChange=false;}if(programChange){if(parameters.shaderID){var shader=ShaderLib[parameters.shaderID];materialProperties.shader={name:material.type,uniforms:UniformsUtils.clone(shader.uniforms),vertexShader:shader.vertexShader,fragmentShader:shader.fragmentShader};}else{materialProperties.shader={name:material.type,uniforms:material.uniforms,vertexShader:material.vertexShader,fragmentShader:material.fragmentShader};}material.onBeforeCompile(materialProperties.shader,_this);program=programCache.acquireProgram(material,materialProperties.shader,parameters,code);materialProperties.program=program;material.program=program;}var programAttributes=program.getAttributes();if(material.morphTargets){material.numSupportedMorphTargets=0;for(var i=0;i<_this.maxMorphTargets;i++){if(programAttributes['morphTarget'+i]>=0){material.numSupportedMorphTargets++;}}}if(material.morphNormals){material.numSupportedMorphNormals=0;for(var i=0;i<_this.maxMorphNormals;i++){if(programAttributes['morphNormal'+i]>=0){material.numSupportedMorphNormals++;}}}var uniforms=materialProperties.shader.uniforms;if(!material.isShaderMaterial&&!material.isRawShaderMaterial||material.clipping===true){materialProperties.numClippingPlanes=_clipping.numPlanes;materialProperties.numIntersection=_clipping.numIntersection;uniforms.clippingPlanes=_clipping.uniform;}materialProperties.fog=fog;// store the light setup it was created for
materialProperties.lightsHash=lights.state.hash;if(material.lights){// wire up the material to this renderer's lighting state
uniforms.ambientLightColor.value=lights.state.ambient;uniforms.directionalLights.value=lights.state.directional;uniforms.spotLights.value=lights.state.spot;uniforms.rectAreaLights.value=lights.state.rectArea;uniforms.pointLights.value=lights.state.point;uniforms.hemisphereLights.value=lights.state.hemi;uniforms.directionalShadowMap.value=lights.state.directionalShadowMap;uniforms.directionalShadowMatrix.value=lights.state.directionalShadowMatrix;uniforms.spotShadowMap.value=lights.state.spotShadowMap;uniforms.spotShadowMatrix.value=lights.state.spotShadowMatrix;uniforms.pointShadowMap.value=lights.state.pointShadowMap;uniforms.pointShadowMatrix.value=lights.state.pointShadowMatrix;// TODO (abelnation): add area lights shadow info to uniforms
}var progUniforms=materialProperties.program.getUniforms(),uniformsList=WebGLUniforms.seqWithValue(progUniforms.seq,uniforms);materialProperties.uniformsList=uniformsList;}function setProgram(camera,fog,material,object){_usedTextureUnits=0;var materialProperties=properties.get(material);var lights=currentRenderState.state.lights;if(_clippingEnabled){if(_localClippingEnabled||camera!==_currentCamera){var useCache=camera===_currentCamera&&material.id===_currentMaterialId;// we might want to call this function with some ClippingGroup
// object instead of the material, once it becomes feasible
// (#8465, #8379)
_clipping.setState(material.clippingPlanes,material.clipIntersection,material.clipShadows,camera,materialProperties,useCache);}}if(material.needsUpdate===false){if(materialProperties.program===undefined){material.needsUpdate=true;}else if(material.fog&&materialProperties.fog!==fog){material.needsUpdate=true;}else if(material.lights&&materialProperties.lightsHash!==lights.state.hash){material.needsUpdate=true;}else if(materialProperties.numClippingPlanes!==undefined&&(materialProperties.numClippingPlanes!==_clipping.numPlanes||materialProperties.numIntersection!==_clipping.numIntersection)){material.needsUpdate=true;}}if(material.needsUpdate){initMaterial(material,fog,object);material.needsUpdate=false;}var refreshProgram=false;var refreshMaterial=false;var refreshLights=false;var program=materialProperties.program,p_uniforms=program.getUniforms(),m_uniforms=materialProperties.shader.uniforms;if(state.useProgram(program.program)){refreshProgram=true;refreshMaterial=true;refreshLights=true;}if(material.id!==_currentMaterialId){_currentMaterialId=material.id;refreshMaterial=true;}if(refreshProgram||camera!==_currentCamera){p_uniforms.setValue(_gl,'projectionMatrix',camera.projectionMatrix);if(capabilities.logarithmicDepthBuffer){p_uniforms.setValue(_gl,'logDepthBufFC',2.0/(Math.log(camera.far+1.0)/Math.LN2));}// Avoid unneeded uniform updates per ArrayCamera's sub-camera
if(_currentCamera!==(_currentArrayCamera||camera)){_currentCamera=_currentArrayCamera||camera;// lighting uniforms depend on the camera so enforce an update
// now, in case this material supports lights - or later, when
// the next material that does gets activated:
refreshMaterial=true;// set to true on material change
refreshLights=true;// remains set until update done
}// load material specific uniforms
// (shader material also gets them for the sake of genericity)
if(material.isShaderMaterial||material.isMeshPhongMaterial||material.isMeshStandardMaterial||material.envMap){var uCamPos=p_uniforms.map.cameraPosition;if(uCamPos!==undefined){uCamPos.setValue(_gl,_vector3.setFromMatrixPosition(camera.matrixWorld));}}if(material.isMeshPhongMaterial||material.isMeshLambertMaterial||material.isMeshBasicMaterial||material.isMeshStandardMaterial||material.isShaderMaterial||material.skinning){p_uniforms.setValue(_gl,'viewMatrix',camera.matrixWorldInverse);}}// skinning uniforms must be set even if material didn't change
// auto-setting of texture unit for bone texture must go before other textures
// not sure why, but otherwise weird things happen
if(material.skinning){p_uniforms.setOptional(_gl,object,'bindMatrix');p_uniforms.setOptional(_gl,object,'bindMatrixInverse');var skeleton=object.skeleton;if(skeleton){var bones=skeleton.bones;if(capabilities.floatVertexTextures){if(skeleton.boneTexture===undefined){// layout (1 matrix = 4 pixels)
// RGBA RGBA RGBA RGBA (=> column1, column2, column3, column4)
// with 8x8 pixel texture max 16 bones * 4 pixels = (8 * 8)
// 16x16 pixel texture max 64 bones * 4 pixels = (16 * 16)
// 32x32 pixel texture max 256 bones * 4 pixels = (32 * 32)
// 64x64 pixel texture max 1024 bones * 4 pixels = (64 * 64)
var size=Math.sqrt(bones.length*4);// 4 pixels needed for 1 matrix
size=_Math.ceilPowerOfTwo(size);size=Math.max(size,4);var boneMatrices=new Float32Array(size*size*4);// 4 floats per RGBA pixel
boneMatrices.set(skeleton.boneMatrices);// copy current values
var boneTexture=new DataTexture(boneMatrices,size,size,RGBAFormat,FloatType);boneTexture.needsUpdate=true;skeleton.boneMatrices=boneMatrices;skeleton.boneTexture=boneTexture;skeleton.boneTextureSize=size;}p_uniforms.setValue(_gl,'boneTexture',skeleton.boneTexture);p_uniforms.setValue(_gl,'boneTextureSize',skeleton.boneTextureSize);}else{p_uniforms.setOptional(_gl,skeleton,'boneMatrices');}}}if(refreshMaterial){p_uniforms.setValue(_gl,'toneMappingExposure',_this.toneMappingExposure);p_uniforms.setValue(_gl,'toneMappingWhitePoint',_this.toneMappingWhitePoint);if(material.lights){// the current material requires lighting info
// note: all lighting uniforms are always set correctly
// they simply reference the renderer's state for their
// values
//
// use the current material's .needsUpdate flags to set
// the GL state when required
markUniformsLightsNeedsUpdate(m_uniforms,refreshLights);}// refresh uniforms common to several materials
if(fog&&material.fog){refreshUniformsFog(m_uniforms,fog);}if(material.isMeshBasicMaterial){refreshUniformsCommon(m_uniforms,material);}else if(material.isMeshLambertMaterial){refreshUniformsCommon(m_uniforms,material);refreshUniformsLambert(m_uniforms,material);}else if(material.isMeshPhongMaterial){refreshUniformsCommon(m_uniforms,material);if(material.isMeshToonMaterial){refreshUniformsToon(m_uniforms,material);}else{refreshUniformsPhong(m_uniforms,material);}}else if(material.isMeshStandardMaterial){refreshUniformsCommon(m_uniforms,material);if(material.isMeshPhysicalMaterial){refreshUniformsPhysical(m_uniforms,material);}else{refreshUniformsStandard(m_uniforms,material);}}else if(material.isMeshDepthMaterial){refreshUniformsCommon(m_uniforms,material);refreshUniformsDepth(m_uniforms,material);}else if(material.isMeshDistanceMaterial){refreshUniformsCommon(m_uniforms,material);refreshUniformsDistance(m_uniforms,material);}else if(material.isMeshNormalMaterial){refreshUniformsCommon(m_uniforms,material);refreshUniformsNormal(m_uniforms,material);}else if(material.isLineBasicMaterial){refreshUniformsLine(m_uniforms,material);if(material.isLineDashedMaterial){refreshUniformsDash(m_uniforms,material);}}else if(material.isPointsMaterial){refreshUniformsPoints(m_uniforms,material);}else if(material.isShadowMaterial){m_uniforms.color.value=material.color;m_uniforms.opacity.value=material.opacity;}// RectAreaLight Texture
// TODO (mrdoob): Find a nicer implementation
if(m_uniforms.ltc_1!==undefined)m_uniforms.ltc_1.value=UniformsLib.LTC_1;if(m_uniforms.ltc_2!==undefined)m_uniforms.ltc_2.value=UniformsLib.LTC_2;WebGLUniforms.upload(_gl,materialProperties.uniformsList,m_uniforms,_this);}if(material.isShaderMaterial&&material.uniformsNeedUpdate===true){WebGLUniforms.upload(_gl,materialProperties.uniformsList,m_uniforms,_this);material.uniformsNeedUpdate=false;}// common matrices
p_uniforms.setValue(_gl,'modelViewMatrix',object.modelViewMatrix);p_uniforms.setValue(_gl,'normalMatrix',object.normalMatrix);p_uniforms.setValue(_gl,'modelMatrix',object.matrixWorld);return program;}// Uniforms (refresh uniforms objects)
function refreshUniformsCommon(uniforms,material){uniforms.opacity.value=material.opacity;if(material.color){uniforms.diffuse.value=material.color;}if(material.emissive){uniforms.emissive.value.copy(material.emissive).multiplyScalar(material.emissiveIntensity);}if(material.map){uniforms.map.value=material.map;}if(material.alphaMap){uniforms.alphaMap.value=material.alphaMap;}if(material.specularMap){uniforms.specularMap.value=material.specularMap;}if(material.envMap){uniforms.envMap.value=material.envMap;// don't flip CubeTexture envMaps, flip everything else:
// WebGLRenderTargetCube will be flipped for backwards compatibility
// WebGLRenderTargetCube.texture will be flipped because it's a Texture and NOT a CubeTexture
// this check must be handled differently, or removed entirely, if WebGLRenderTargetCube uses a CubeTexture in the future
uniforms.flipEnvMap.value=!(material.envMap&&material.envMap.isCubeTexture)?1:-1;uniforms.reflectivity.value=material.reflectivity;uniforms.refractionRatio.value=material.refractionRatio;uniforms.maxMipLevel.value=properties.get(material.envMap).__maxMipLevel;}if(material.lightMap){uniforms.lightMap.value=material.lightMap;uniforms.lightMapIntensity.value=material.lightMapIntensity;}if(material.aoMap){uniforms.aoMap.value=material.aoMap;uniforms.aoMapIntensity.value=material.aoMapIntensity;}// uv repeat and offset setting priorities
// 1. color map
// 2. specular map
// 3. normal map
// 4. bump map
// 5. alpha map
// 6. emissive map
var uvScaleMap;if(material.map){uvScaleMap=material.map;}else if(material.specularMap){uvScaleMap=material.specularMap;}else if(material.displacementMap){uvScaleMap=material.displacementMap;}else if(material.normalMap){uvScaleMap=material.normalMap;}else if(material.bumpMap){uvScaleMap=material.bumpMap;}else if(material.roughnessMap){uvScaleMap=material.roughnessMap;}else if(material.metalnessMap){uvScaleMap=material.metalnessMap;}else if(material.alphaMap){uvScaleMap=material.alphaMap;}else if(material.emissiveMap){uvScaleMap=material.emissiveMap;}if(uvScaleMap!==undefined){// backwards compatibility
if(uvScaleMap.isWebGLRenderTarget){uvScaleMap=uvScaleMap.texture;}if(uvScaleMap.matrixAutoUpdate===true){uvScaleMap.updateMatrix();}uniforms.uvTransform.value.copy(uvScaleMap.matrix);}}function refreshUniformsLine(uniforms,material){uniforms.diffuse.value=material.color;uniforms.opacity.value=material.opacity;}function refreshUniformsDash(uniforms,material){uniforms.dashSize.value=material.dashSize;uniforms.totalSize.value=material.dashSize+material.gapSize;uniforms.scale.value=material.scale;}function refreshUniformsPoints(uniforms,material){uniforms.diffuse.value=material.color;uniforms.opacity.value=material.opacity;uniforms.size.value=material.size*_pixelRatio;uniforms.scale.value=_height*0.5;uniforms.map.value=material.map;if(material.map!==null){if(material.map.matrixAutoUpdate===true){material.map.updateMatrix();}uniforms.uvTransform.value.copy(material.map.matrix);}}function refreshUniformsFog(uniforms,fog){uniforms.fogColor.value=fog.color;if(fog.isFog){uniforms.fogNear.value=fog.near;uniforms.fogFar.value=fog.far;}else if(fog.isFogExp2){uniforms.fogDensity.value=fog.density;}}function refreshUniformsLambert(uniforms,material){if(material.emissiveMap){uniforms.emissiveMap.value=material.emissiveMap;}}function refreshUniformsPhong(uniforms,material){uniforms.specular.value=material.specular;uniforms.shininess.value=Math.max(material.shininess,1e-4);// to prevent pow( 0.0, 0.0 )
if(material.emissiveMap){uniforms.emissiveMap.value=material.emissiveMap;}if(material.bumpMap){uniforms.bumpMap.value=material.bumpMap;uniforms.bumpScale.value=material.bumpScale;}if(material.normalMap){uniforms.normalMap.value=material.normalMap;uniforms.normalScale.value.copy(material.normalScale);}if(material.displacementMap){uniforms.displacementMap.value=material.displacementMap;uniforms.displacementScale.value=material.displacementScale;uniforms.displacementBias.value=material.displacementBias;}}function refreshUniformsToon(uniforms,material){refreshUniformsPhong(uniforms,material);if(material.gradientMap){uniforms.gradientMap.value=material.gradientMap;}}function refreshUniformsStandard(uniforms,material){uniforms.roughness.value=material.roughness;uniforms.metalness.value=material.metalness;if(material.roughnessMap){uniforms.roughnessMap.value=material.roughnessMap;}if(material.metalnessMap){uniforms.metalnessMap.value=material.metalnessMap;}if(material.emissiveMap){uniforms.emissiveMap.value=material.emissiveMap;}if(material.bumpMap){uniforms.bumpMap.value=material.bumpMap;uniforms.bumpScale.value=material.bumpScale;}if(material.normalMap){uniforms.normalMap.value=material.normalMap;uniforms.normalScale.value.copy(material.normalScale);}if(material.displacementMap){uniforms.displacementMap.value=material.displacementMap;uniforms.displacementScale.value=material.displacementScale;uniforms.displacementBias.value=material.displacementBias;}if(material.envMap){//uniforms.envMap.value = material.envMap; // part of uniforms common
uniforms.envMapIntensity.value=material.envMapIntensity;}}function refreshUniformsPhysical(uniforms,material){uniforms.clearCoat.value=material.clearCoat;uniforms.clearCoatRoughness.value=material.clearCoatRoughness;refreshUniformsStandard(uniforms,material);}function refreshUniformsDepth(uniforms,material){if(material.displacementMap){uniforms.displacementMap.value=material.displacementMap;uniforms.displacementScale.value=material.displacementScale;uniforms.displacementBias.value=material.displacementBias;}}function refreshUniformsDistance(uniforms,material){if(material.displacementMap){uniforms.displacementMap.value=material.displacementMap;uniforms.displacementScale.value=material.displacementScale;uniforms.displacementBias.value=material.displacementBias;}uniforms.referencePosition.value.copy(material.referencePosition);uniforms.nearDistance.value=material.nearDistance;uniforms.farDistance.value=material.farDistance;}function refreshUniformsNormal(uniforms,material){if(material.bumpMap){uniforms.bumpMap.value=material.bumpMap;uniforms.bumpScale.value=material.bumpScale;}if(material.normalMap){uniforms.normalMap.value=material.normalMap;uniforms.normalScale.value.copy(material.normalScale);}if(material.displacementMap){uniforms.displacementMap.value=material.displacementMap;uniforms.displacementScale.value=material.displacementScale;uniforms.displacementBias.value=material.displacementBias;}}// If uniforms are marked as clean, they don't need to be loaded to the GPU.
function markUniformsLightsNeedsUpdate(uniforms,value){uniforms.ambientLightColor.needsUpdate=value;uniforms.directionalLights.needsUpdate=value;uniforms.pointLights.needsUpdate=value;uniforms.spotLights.needsUpdate=value;uniforms.rectAreaLights.needsUpdate=value;uniforms.hemisphereLights.needsUpdate=value;}// Textures
function allocTextureUnit(){var textureUnit=_usedTextureUnits;if(textureUnit>=capabilities.maxTextures){console.warn('THREE.WebGLRenderer: Trying to use '+textureUnit+' texture units while this GPU supports only '+capabilities.maxTextures);}_usedTextureUnits+=1;return textureUnit;}this.allocTextureUnit=allocTextureUnit;// this.setTexture2D = setTexture2D;
this.setTexture2D=function(){var warned=false;// backwards compatibility: peel texture.texture
return function setTexture2D(texture,slot){if(texture&&texture.isWebGLRenderTarget){if(!warned){console.warn("THREE.WebGLRenderer.setTexture2D: don't use render targets as textures. Use their .texture property instead.");warned=true;}texture=texture.texture;}textures.setTexture2D(texture,slot);};}();this.setTexture=function(){var warned=false;return function setTexture(texture,slot){if(!warned){console.warn("THREE.WebGLRenderer: .setTexture is deprecated, use setTexture2D instead.");warned=true;}textures.setTexture2D(texture,slot);};}();this.setTextureCube=function(){var warned=false;return function setTextureCube(texture,slot){// backwards compatibility: peel texture.texture
if(texture&&texture.isWebGLRenderTargetCube){if(!warned){console.warn("THREE.WebGLRenderer.setTextureCube: don't use cube render targets as textures. Use their .texture property instead.");warned=true;}texture=texture.texture;}// currently relying on the fact that WebGLRenderTargetCube.texture is a Texture and NOT a CubeTexture
// TODO: unify these code paths
if(texture&&texture.isCubeTexture||Array.isArray(texture.image)&&texture.image.length===6){// CompressedTexture can have Array in image :/
// this function alone should take care of cube textures
textures.setTextureCube(texture,slot);}else{// assumed: texture property of THREE.WebGLRenderTargetCube
textures.setTextureCubeDynamic(texture,slot);}};}();this.getRenderTarget=function(){return _currentRenderTarget;};this.setRenderTarget=function(renderTarget){_currentRenderTarget=renderTarget;if(renderTarget&&properties.get(renderTarget).__webglFramebuffer===undefined){textures.setupRenderTarget(renderTarget);}var framebuffer=null;var isCube=false;if(renderTarget){var __webglFramebuffer=properties.get(renderTarget).__webglFramebuffer;if(renderTarget.isWebGLRenderTargetCube){framebuffer=__webglFramebuffer[renderTarget.activeCubeFace];isCube=true;}else{framebuffer=__webglFramebuffer;}_currentViewport.copy(renderTarget.viewport);_currentScissor.copy(renderTarget.scissor);_currentScissorTest=renderTarget.scissorTest;}else{_currentViewport.copy(_viewport).multiplyScalar(_pixelRatio);_currentScissor.copy(_scissor).multiplyScalar(_pixelRatio);_currentScissorTest=_scissorTest;}if(_currentFramebuffer!==framebuffer){_gl.bindFramebuffer(_gl.FRAMEBUFFER,framebuffer);_currentFramebuffer=framebuffer;}state.viewport(_currentViewport);state.scissor(_currentScissor);state.setScissorTest(_currentScissorTest);if(isCube){var textureProperties=properties.get(renderTarget.texture);_gl.framebufferTexture2D(_gl.FRAMEBUFFER,_gl.COLOR_ATTACHMENT0,_gl.TEXTURE_CUBE_MAP_POSITIVE_X+renderTarget.activeCubeFace,textureProperties.__webglTexture,renderTarget.activeMipMapLevel);}};this.readRenderTargetPixels=function(renderTarget,x,y,width,height,buffer){if(!(renderTarget&&renderTarget.isWebGLRenderTarget)){console.error('THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.');return;}var framebuffer=properties.get(renderTarget).__webglFramebuffer;if(framebuffer){var restore=false;if(framebuffer!==_currentFramebuffer){_gl.bindFramebuffer(_gl.FRAMEBUFFER,framebuffer);restore=true;}try{var texture=renderTarget.texture;var textureFormat=texture.format;var textureType=texture.type;if(textureFormat!==RGBAFormat&&utils.convert(textureFormat)!==_gl.getParameter(_gl.IMPLEMENTATION_COLOR_READ_FORMAT)){console.error('THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format.');return;}if(textureType!==UnsignedByteType&&utils.convert(textureType)!==_gl.getParameter(_gl.IMPLEMENTATION_COLOR_READ_TYPE)&&// IE11, Edge and Chrome Mac < 52 (#9513)
!(textureType===FloatType&&(extensions.get('OES_texture_float')||extensions.get('WEBGL_color_buffer_float')))&&// Chrome Mac >= 52 and Firefox
!(textureType===HalfFloatType&&extensions.get('EXT_color_buffer_half_float'))){console.error('THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.');return;}if(_gl.checkFramebufferStatus(_gl.FRAMEBUFFER)===_gl.FRAMEBUFFER_COMPLETE){// the following if statement ensures valid read requests (no out-of-bounds pixels, see #8604)
if(x>=0&&x<=renderTarget.width-width&&y>=0&&y<=renderTarget.height-height){_gl.readPixels(x,y,width,height,utils.convert(textureFormat),utils.convert(textureType),buffer);}}else{console.error('THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete.');}}finally{if(restore){_gl.bindFramebuffer(_gl.FRAMEBUFFER,_currentFramebuffer);}}}};this.copyFramebufferToTexture=function(position,texture,level){var width=texture.image.width;var height=texture.image.height;var glFormat=utils.convert(texture.format);this.setTexture2D(texture,0);_gl.copyTexImage2D(_gl.TEXTURE_2D,level||0,glFormat,position.x,position.y,width,height,0);};this.copyTextureToTexture=function(position,srcTexture,dstTexture,level){var width=srcTexture.image.width;var height=srcTexture.image.height;var glFormat=utils.convert(dstTexture.format);var glType=utils.convert(dstTexture.type);var pixels=srcTexture.isDataTexture?srcTexture.image.data:srcTexture.image;this.setTexture2D(dstTexture,0);_gl.texSubImage2D(_gl.TEXTURE_2D,level||0,position.x,position.y,width,height,glFormat,glType,pixels);};}/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*/function FogExp2(color,density){this.name='';this.color=new Color(color);this.density=density!==undefined?density:0.00025;}FogExp2.prototype.isFogExp2=true;FogExp2.prototype.clone=function(){return new FogExp2(this.color.getHex(),this.density);};FogExp2.prototype.toJSON=function()/* meta */{return {type:'FogExp2',color:this.color.getHex(),density:this.density};};/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*/function Fog(color,near,far){this.name='';this.color=new Color(color);this.near=near!==undefined?near:1;this.far=far!==undefined?far:1000;}Fog.prototype.isFog=true;Fog.prototype.clone=function(){return new Fog(this.color.getHex(),this.near,this.far);};Fog.prototype.toJSON=function()/* meta */{return {type:'Fog',color:this.color.getHex(),near:this.near,far:this.far};};/**
* @author mrdoob / http://mrdoob.com/
*/function Scene(){Object3D.call(this);this.type='Scene';this.background=null;this.fog=null;this.overrideMaterial=null;this.autoUpdate=true;// checked by the renderer
}Scene.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Scene,copy:function(source,recursive){Object3D.prototype.copy.call(this,source,recursive);if(source.background!==null)this.background=source.background.clone();if(source.fog!==null)this.fog=source.fog.clone();if(source.overrideMaterial!==null)this.overrideMaterial=source.overrideMaterial.clone();this.autoUpdate=source.autoUpdate;this.matrixAutoUpdate=source.matrixAutoUpdate;return this;},toJSON:function(meta){var data=Object3D.prototype.toJSON.call(this,meta);if(this.background!==null)data.object.background=this.background.toJSON(meta);if(this.fog!==null)data.object.fog=this.fog.toJSON();return data;}});/**
* @author alteredq / http://alteredqualia.com/
*
* parameters = {
* color: <hex>,
* opacity: <float>,
* map: new THREE.Texture( <Image> ),
*
* uvOffset: new THREE.Vector2(),
* uvScale: new THREE.Vector2()
* }
*/function SpriteMaterial(parameters){Material.call(this);this.type='SpriteMaterial';this.color=new Color(0xffffff);this.map=null;this.rotation=0;this.fog=false;this.lights=false;this.setValues(parameters);}SpriteMaterial.prototype=Object.create(Material.prototype);SpriteMaterial.prototype.constructor=SpriteMaterial;SpriteMaterial.prototype.isSpriteMaterial=true;SpriteMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.color.copy(source.color);this.map=source.map;this.rotation=source.rotation;return this;};/**
* @author mikael emtinger / http://gomo.se/
* @author alteredq / http://alteredqualia.com/
*/function Sprite(material){Object3D.call(this);this.type='Sprite';this.material=material!==undefined?material:new SpriteMaterial();this.center=new Vector2(0.5,0.5);}Sprite.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Sprite,isSprite:true,raycast:function(){var intersectPoint=new Vector3();var worldPosition=new Vector3();var worldScale=new Vector3();return function raycast(raycaster,intersects){worldPosition.setFromMatrixPosition(this.matrixWorld);raycaster.ray.closestPointToPoint(worldPosition,intersectPoint);worldScale.setFromMatrixScale(this.matrixWorld);var guessSizeSq=worldScale.x*worldScale.y/4;if(worldPosition.distanceToSquared(intersectPoint)>guessSizeSq)return;var distance=raycaster.ray.origin.distanceTo(intersectPoint);if(distance<raycaster.near||distance>raycaster.far)return;intersects.push({distance:distance,point:intersectPoint.clone(),face:null,object:this});};}(),clone:function(){return new this.constructor(this.material).copy(this);},copy:function(source){Object3D.prototype.copy.call(this,source);if(source.center!==undefined)this.center.copy(source.center);return this;}});/**
* @author mikael emtinger / http://gomo.se/
* @author alteredq / http://alteredqualia.com/
* @author mrdoob / http://mrdoob.com/
*/function LOD(){Object3D.call(this);this.type='LOD';Object.defineProperties(this,{levels:{enumerable:true,value:[]}});}LOD.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:LOD,copy:function(source){Object3D.prototype.copy.call(this,source,false);var levels=source.levels;for(var i=0,l=levels.length;i<l;i++){var level=levels[i];this.addLevel(level.object.clone(),level.distance);}return this;},addLevel:function(object,distance){if(distance===undefined)distance=0;distance=Math.abs(distance);var levels=this.levels;for(var l=0;l<levels.length;l++){if(distance<levels[l].distance){break;}}levels.splice(l,0,{distance:distance,object:object});this.add(object);},getObjectForDistance:function(distance){var levels=this.levels;for(var i=1,l=levels.length;i<l;i++){if(distance<levels[i].distance){break;}}return levels[i-1].object;},raycast:function(){var matrixPosition=new Vector3();return function raycast(raycaster,intersects){matrixPosition.setFromMatrixPosition(this.matrixWorld);var distance=raycaster.ray.origin.distanceTo(matrixPosition);this.getObjectForDistance(distance).raycast(raycaster,intersects);};}(),update:function(){var v1=new Vector3();var v2=new Vector3();return function update(camera){var levels=this.levels;if(levels.length>1){v1.setFromMatrixPosition(camera.matrixWorld);v2.setFromMatrixPosition(this.matrixWorld);var distance=v1.distanceTo(v2);levels[0].object.visible=true;for(var i=1,l=levels.length;i<l;i++){if(distance>=levels[i].distance){levels[i-1].object.visible=false;levels[i].object.visible=true;}else{break;}}for(;i<l;i++){levels[i].object.visible=false;}}};}(),toJSON:function(meta){var data=Object3D.prototype.toJSON.call(this,meta);data.object.levels=[];var levels=this.levels;for(var i=0,l=levels.length;i<l;i++){var level=levels[i];data.object.levels.push({object:level.object.uuid,distance:level.distance});}return data;}});/**
* @author mikael emtinger / http://gomo.se/
* @author alteredq / http://alteredqualia.com/
* @author michael guerrero / http://realitymeltdown.com
* @author ikerr / http://verold.com
*/function Skeleton(bones,boneInverses){// copy the bone array
bones=bones||[];this.bones=bones.slice(0);this.boneMatrices=new Float32Array(this.bones.length*16);// use the supplied bone inverses or calculate the inverses
if(boneInverses===undefined){this.calculateInverses();}else{if(this.bones.length===boneInverses.length){this.boneInverses=boneInverses.slice(0);}else{console.warn('THREE.Skeleton boneInverses is the wrong length.');this.boneInverses=[];for(var i=0,il=this.bones.length;i<il;i++){this.boneInverses.push(new Matrix4());}}}}Object.assign(Skeleton.prototype,{calculateInverses:function(){this.boneInverses=[];for(var i=0,il=this.bones.length;i<il;i++){var inverse=new Matrix4();if(this.bones[i]){inverse.getInverse(this.bones[i].matrixWorld);}this.boneInverses.push(inverse);}},pose:function(){var bone,i,il;// recover the bind-time world matrices
for(i=0,il=this.bones.length;i<il;i++){bone=this.bones[i];if(bone){bone.matrixWorld.getInverse(this.boneInverses[i]);}}// compute the local matrices, positions, rotations and scales
for(i=0,il=this.bones.length;i<il;i++){bone=this.bones[i];if(bone){if(bone.parent&&bone.parent.isBone){bone.matrix.getInverse(bone.parent.matrixWorld);bone.matrix.multiply(bone.matrixWorld);}else{bone.matrix.copy(bone.matrixWorld);}bone.matrix.decompose(bone.position,bone.quaternion,bone.scale);}}},update:function(){var offsetMatrix=new Matrix4();var identityMatrix=new Matrix4();return function update(){var bones=this.bones;var boneInverses=this.boneInverses;var boneMatrices=this.boneMatrices;var boneTexture=this.boneTexture;// flatten bone matrices to array
for(var i=0,il=bones.length;i<il;i++){// compute the offset between the current and the original transform
var matrix=bones[i]?bones[i].matrixWorld:identityMatrix;offsetMatrix.multiplyMatrices(matrix,boneInverses[i]);offsetMatrix.toArray(boneMatrices,i*16);}if(boneTexture!==undefined){boneTexture.needsUpdate=true;}};}(),clone:function(){return new Skeleton(this.bones,this.boneInverses);},getBoneByName:function(name){for(var i=0,il=this.bones.length;i<il;i++){var bone=this.bones[i];if(bone.name===name){return bone;}}return undefined;}});/**
* @author mikael emtinger / http://gomo.se/
* @author alteredq / http://alteredqualia.com/
* @author ikerr / http://verold.com
*/function Bone(){Object3D.call(this);this.type='Bone';}Bone.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Bone,isBone:true});/**
* @author mikael emtinger / http://gomo.se/
* @author alteredq / http://alteredqualia.com/
* @author ikerr / http://verold.com
*/function SkinnedMesh(geometry,material){Mesh.call(this,geometry,material);this.type='SkinnedMesh';this.bindMode='attached';this.bindMatrix=new Matrix4();this.bindMatrixInverse=new Matrix4();var bones=this.initBones();var skeleton=new Skeleton(bones);this.bind(skeleton,this.matrixWorld);this.normalizeSkinWeights();}SkinnedMesh.prototype=Object.assign(Object.create(Mesh.prototype),{constructor:SkinnedMesh,isSkinnedMesh:true,initBones:function(){var bones=[],bone,gbone;var i,il;if(this.geometry&&this.geometry.bones!==undefined){// first, create array of 'Bone' objects from geometry data
for(i=0,il=this.geometry.bones.length;i<il;i++){gbone=this.geometry.bones[i];// create new 'Bone' object
bone=new Bone();bones.push(bone);// apply values
bone.name=gbone.name;bone.position.fromArray(gbone.pos);bone.quaternion.fromArray(gbone.rotq);if(gbone.scl!==undefined)bone.scale.fromArray(gbone.scl);}// second, create bone hierarchy
for(i=0,il=this.geometry.bones.length;i<il;i++){gbone=this.geometry.bones[i];if(gbone.parent!==-1&&gbone.parent!==null&&bones[gbone.parent]!==undefined){// subsequent bones in the hierarchy
bones[gbone.parent].add(bones[i]);}else{// topmost bone, immediate child of the skinned mesh
this.add(bones[i]);}}}// now the bones are part of the scene graph and children of the skinned mesh.
// let's update the corresponding matrices
this.updateMatrixWorld(true);return bones;},bind:function(skeleton,bindMatrix){this.skeleton=skeleton;if(bindMatrix===undefined){this.updateMatrixWorld(true);this.skeleton.calculateInverses();bindMatrix=this.matrixWorld;}this.bindMatrix.copy(bindMatrix);this.bindMatrixInverse.getInverse(bindMatrix);},pose:function(){this.skeleton.pose();},normalizeSkinWeights:function(){var scale,i;if(this.geometry&&this.geometry.isGeometry){for(i=0;i<this.geometry.skinWeights.length;i++){var sw=this.geometry.skinWeights[i];scale=1.0/sw.manhattanLength();if(scale!==Infinity){sw.multiplyScalar(scale);}else{sw.set(1,0,0,0);// do something reasonable
}}}else if(this.geometry&&this.geometry.isBufferGeometry){var vec=new Vector4();var skinWeight=this.geometry.attributes.skinWeight;for(i=0;i<skinWeight.count;i++){vec.x=skinWeight.getX(i);vec.y=skinWeight.getY(i);vec.z=skinWeight.getZ(i);vec.w=skinWeight.getW(i);scale=1.0/vec.manhattanLength();if(scale!==Infinity){vec.multiplyScalar(scale);}else{vec.set(1,0,0,0);// do something reasonable
}skinWeight.setXYZW(i,vec.x,vec.y,vec.z,vec.w);}}},updateMatrixWorld:function(force){Mesh.prototype.updateMatrixWorld.call(this,force);if(this.bindMode==='attached'){this.bindMatrixInverse.getInverse(this.matrixWorld);}else if(this.bindMode==='detached'){this.bindMatrixInverse.getInverse(this.bindMatrix);}else{console.warn('THREE.SkinnedMesh: Unrecognized bindMode: '+this.bindMode);}},clone:function(){return new this.constructor(this.geometry,this.material).copy(this);}});/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*
* parameters = {
* color: <hex>,
* opacity: <float>,
*
* linewidth: <float>,
* linecap: "round",
* linejoin: "round"
* }
*/function LineBasicMaterial(parameters){Material.call(this);this.type='LineBasicMaterial';this.color=new Color(0xffffff);this.linewidth=1;this.linecap='round';this.linejoin='round';this.lights=false;this.setValues(parameters);}LineBasicMaterial.prototype=Object.create(Material.prototype);LineBasicMaterial.prototype.constructor=LineBasicMaterial;LineBasicMaterial.prototype.isLineBasicMaterial=true;LineBasicMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.color.copy(source.color);this.linewidth=source.linewidth;this.linecap=source.linecap;this.linejoin=source.linejoin;return this;};/**
* @author mrdoob / http://mrdoob.com/
*/function Line(geometry,material,mode){if(mode===1){console.warn('THREE.Line: parameter THREE.LinePieces no longer supported. Created THREE.LineSegments instead.');return new LineSegments(geometry,material);}Object3D.call(this);this.type='Line';this.geometry=geometry!==undefined?geometry:new BufferGeometry();this.material=material!==undefined?material:new LineBasicMaterial({color:Math.random()*0xffffff});}Line.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Line,isLine:true,computeLineDistances:function(){var start=new Vector3();var end=new Vector3();return function computeLineDistances(){var geometry=this.geometry;if(geometry.isBufferGeometry){// we assume non-indexed geometry
if(geometry.index===null){var positionAttribute=geometry.attributes.position;var lineDistances=[0];for(var i=1,l=positionAttribute.count;i<l;i++){start.fromBufferAttribute(positionAttribute,i-1);end.fromBufferAttribute(positionAttribute,i);lineDistances[i]=lineDistances[i-1];lineDistances[i]+=start.distanceTo(end);}geometry.addAttribute('lineDistance',new Float32BufferAttribute(lineDistances,1));}else{console.warn('THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.');}}else if(geometry.isGeometry){var vertices=geometry.vertices;var lineDistances=geometry.lineDistances;lineDistances[0]=0;for(var i=1,l=vertices.length;i<l;i++){lineDistances[i]=lineDistances[i-1];lineDistances[i]+=vertices[i-1].distanceTo(vertices[i]);}}return this;};}(),raycast:function(){var inverseMatrix=new Matrix4();var ray=new Ray();var sphere=new Sphere();return function raycast(raycaster,intersects){var precision=raycaster.linePrecision;var precisionSq=precision*precision;var geometry=this.geometry;var matrixWorld=this.matrixWorld;// Checking boundingSphere distance to ray
if(geometry.boundingSphere===null)geometry.computeBoundingSphere();sphere.copy(geometry.boundingSphere);sphere.applyMatrix4(matrixWorld);if(raycaster.ray.intersectsSphere(sphere)===false)return;//
inverseMatrix.getInverse(matrixWorld);ray.copy(raycaster.ray).applyMatrix4(inverseMatrix);var vStart=new Vector3();var vEnd=new Vector3();var interSegment=new Vector3();var interRay=new Vector3();var step=this&&this.isLineSegments?2:1;if(geometry.isBufferGeometry){var index=geometry.index;var attributes=geometry.attributes;var positions=attributes.position.array;if(index!==null){var indices=index.array;for(var i=0,l=indices.length-1;i<l;i+=step){var a=indices[i];var b=indices[i+1];vStart.fromArray(positions,a*3);vEnd.fromArray(positions,b*3);var distSq=ray.distanceSqToSegment(vStart,vEnd,interRay,interSegment);if(distSq>precisionSq)continue;interRay.applyMatrix4(this.matrixWorld);//Move back to world space for distance calculation
var distance=raycaster.ray.origin.distanceTo(interRay);if(distance<raycaster.near||distance>raycaster.far)continue;intersects.push({distance:distance,// What do we want? intersection point on the ray or on the segment??
// point: raycaster.ray.at( distance ),
point:interSegment.clone().applyMatrix4(this.matrixWorld),index:i,face:null,faceIndex:null,object:this});}}else{for(var i=0,l=positions.length/3-1;i<l;i+=step){vStart.fromArray(positions,3*i);vEnd.fromArray(positions,3*i+3);var distSq=ray.distanceSqToSegment(vStart,vEnd,interRay,interSegment);if(distSq>precisionSq)continue;interRay.applyMatrix4(this.matrixWorld);//Move back to world space for distance calculation
var distance=raycaster.ray.origin.distanceTo(interRay);if(distance<raycaster.near||distance>raycaster.far)continue;intersects.push({distance:distance,// What do we want? intersection point on the ray or on the segment??
// point: raycaster.ray.at( distance ),
point:interSegment.clone().applyMatrix4(this.matrixWorld),index:i,face:null,faceIndex:null,object:this});}}}else if(geometry.isGeometry){var vertices=geometry.vertices;var nbVertices=vertices.length;for(var i=0;i<nbVertices-1;i+=step){var distSq=ray.distanceSqToSegment(vertices[i],vertices[i+1],interRay,interSegment);if(distSq>precisionSq)continue;interRay.applyMatrix4(this.matrixWorld);//Move back to world space for distance calculation
var distance=raycaster.ray.origin.distanceTo(interRay);if(distance<raycaster.near||distance>raycaster.far)continue;intersects.push({distance:distance,// What do we want? intersection point on the ray or on the segment??
// point: raycaster.ray.at( distance ),
point:interSegment.clone().applyMatrix4(this.matrixWorld),index:i,face:null,faceIndex:null,object:this});}}};}(),clone:function(){return new this.constructor(this.geometry,this.material).copy(this);}});/**
* @author mrdoob / http://mrdoob.com/
*/function LineSegments(geometry,material){Line.call(this,geometry,material);this.type='LineSegments';}LineSegments.prototype=Object.assign(Object.create(Line.prototype),{constructor:LineSegments,isLineSegments:true,computeLineDistances:function(){var start=new Vector3();var end=new Vector3();return function computeLineDistances(){var geometry=this.geometry;if(geometry.isBufferGeometry){// we assume non-indexed geometry
if(geometry.index===null){var positionAttribute=geometry.attributes.position;var lineDistances=[];for(var i=0,l=positionAttribute.count;i<l;i+=2){start.fromBufferAttribute(positionAttribute,i);end.fromBufferAttribute(positionAttribute,i+1);lineDistances[i]=i===0?0:lineDistances[i-1];lineDistances[i+1]=lineDistances[i]+start.distanceTo(end);}geometry.addAttribute('lineDistance',new Float32BufferAttribute(lineDistances,1));}else{console.warn('THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.');}}else if(geometry.isGeometry){var vertices=geometry.vertices;var lineDistances=geometry.lineDistances;for(var i=0,l=vertices.length;i<l;i+=2){start.copy(vertices[i]);end.copy(vertices[i+1]);lineDistances[i]=i===0?0:lineDistances[i-1];lineDistances[i+1]=lineDistances[i]+start.distanceTo(end);}}return this;};}()});/**
* @author mgreter / http://github.com/mgreter
*/function LineLoop(geometry,material){Line.call(this,geometry,material);this.type='LineLoop';}LineLoop.prototype=Object.assign(Object.create(Line.prototype),{constructor:LineLoop,isLineLoop:true});/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*
* parameters = {
* color: <hex>,
* opacity: <float>,
* map: new THREE.Texture( <Image> ),
*
* size: <float>,
* sizeAttenuation: <bool>
* }
*/function PointsMaterial(parameters){Material.call(this);this.type='PointsMaterial';this.color=new Color(0xffffff);this.map=null;this.size=1;this.sizeAttenuation=true;this.lights=false;this.setValues(parameters);}PointsMaterial.prototype=Object.create(Material.prototype);PointsMaterial.prototype.constructor=PointsMaterial;PointsMaterial.prototype.isPointsMaterial=true;PointsMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.color.copy(source.color);this.map=source.map;this.size=source.size;this.sizeAttenuation=source.sizeAttenuation;return this;};/**
* @author alteredq / http://alteredqualia.com/
*/function Points(geometry,material){Object3D.call(this);this.type='Points';this.geometry=geometry!==undefined?geometry:new BufferGeometry();this.material=material!==undefined?material:new PointsMaterial({color:Math.random()*0xffffff});}Points.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Points,isPoints:true,raycast:function(){var inverseMatrix=new Matrix4();var ray=new Ray();var sphere=new Sphere();return function raycast(raycaster,intersects){var object=this;var geometry=this.geometry;var matrixWorld=this.matrixWorld;var threshold=raycaster.params.Points.threshold;// Checking boundingSphere distance to ray
if(geometry.boundingSphere===null)geometry.computeBoundingSphere();sphere.copy(geometry.boundingSphere);sphere.applyMatrix4(matrixWorld);sphere.radius+=threshold;if(raycaster.ray.intersectsSphere(sphere)===false)return;//
inverseMatrix.getInverse(matrixWorld);ray.copy(raycaster.ray).applyMatrix4(inverseMatrix);var localThreshold=threshold/((this.scale.x+this.scale.y+this.scale.z)/3);var localThresholdSq=localThreshold*localThreshold;var position=new Vector3();var intersectPoint=new Vector3();function testPoint(point,index){var rayPointDistanceSq=ray.distanceSqToPoint(point);if(rayPointDistanceSq<localThresholdSq){ray.closestPointToPoint(point,intersectPoint);intersectPoint.applyMatrix4(matrixWorld);var distance=raycaster.ray.origin.distanceTo(intersectPoint);if(distance<raycaster.near||distance>raycaster.far)return;intersects.push({distance:distance,distanceToRay:Math.sqrt(rayPointDistanceSq),point:intersectPoint.clone(),index:index,face:null,object:object});}}if(geometry.isBufferGeometry){var index=geometry.index;var attributes=geometry.attributes;var positions=attributes.position.array;if(index!==null){var indices=index.array;for(var i=0,il=indices.length;i<il;i++){var a=indices[i];position.fromArray(positions,a*3);testPoint(position,a);}}else{for(var i=0,l=positions.length/3;i<l;i++){position.fromArray(positions,i*3);testPoint(position,i);}}}else{var vertices=geometry.vertices;for(var i=0,l=vertices.length;i<l;i++){testPoint(vertices[i],i);}}};}(),clone:function(){return new this.constructor(this.geometry,this.material).copy(this);}});/**
* @author mrdoob / http://mrdoob.com/
*/function Group(){Object3D.call(this);this.type='Group';}Group.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Group,isGroup:true});/**
* @author mrdoob / http://mrdoob.com/
*/function VideoTexture(video,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy){Texture.call(this,video,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy);this.generateMipmaps=false;}VideoTexture.prototype=Object.assign(Object.create(Texture.prototype),{constructor:VideoTexture,isVideoTexture:true,update:function(){var video=this.image;if(video.readyState>=video.HAVE_CURRENT_DATA){this.needsUpdate=true;}}});/**
* @author alteredq / http://alteredqualia.com/
*/function CompressedTexture(mipmaps,width,height,format,type,mapping,wrapS,wrapT,magFilter,minFilter,anisotropy,encoding){Texture.call(this,null,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy,encoding);this.image={width:width,height:height};this.mipmaps=mipmaps;// no flipping for cube textures
// (also flipping doesn't work for compressed textures )
this.flipY=false;// can't generate mipmaps for compressed textures
// mips must be embedded in DDS files
this.generateMipmaps=false;}CompressedTexture.prototype=Object.create(Texture.prototype);CompressedTexture.prototype.constructor=CompressedTexture;CompressedTexture.prototype.isCompressedTexture=true;/**
* @author Matt DesLauriers / @mattdesl
* @author atix / arthursilber.de
*/function DepthTexture(width,height,type,mapping,wrapS,wrapT,magFilter,minFilter,anisotropy,format){format=format!==undefined?format:DepthFormat;if(format!==DepthFormat&&format!==DepthStencilFormat){throw new Error('DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat');}if(type===undefined&&format===DepthFormat)type=UnsignedShortType;if(type===undefined&&format===DepthStencilFormat)type=UnsignedInt248Type;Texture.call(this,null,mapping,wrapS,wrapT,magFilter,minFilter,format,type,anisotropy);this.image={width:width,height:height};this.magFilter=magFilter!==undefined?magFilter:NearestFilter;this.minFilter=minFilter!==undefined?minFilter:NearestFilter;this.flipY=false;this.generateMipmaps=false;}DepthTexture.prototype=Object.create(Texture.prototype);DepthTexture.prototype.constructor=DepthTexture;DepthTexture.prototype.isDepthTexture=true;/**
* @author mrdoob / http://mrdoob.com/
* @author Mugen87 / https://github.com/Mugen87
*/function WireframeGeometry(geometry){BufferGeometry.call(this);this.type='WireframeGeometry';// buffer
var vertices=[];// helper variables
var i,j,l,o,ol;var edge=[0,0],edges={},e,edge1,edge2;var key,keys=['a','b','c'];var vertex;// different logic for Geometry and BufferGeometry
if(geometry&&geometry.isGeometry){// create a data structure that contains all edges without duplicates
var faces=geometry.faces;for(i=0,l=faces.length;i<l;i++){var face=faces[i];for(j=0;j<3;j++){edge1=face[keys[j]];edge2=face[keys[(j+1)%3]];edge[0]=Math.min(edge1,edge2);// sorting prevents duplicates
edge[1]=Math.max(edge1,edge2);key=edge[0]+','+edge[1];if(edges[key]===undefined){edges[key]={index1:edge[0],index2:edge[1]};}}}// generate vertices
for(key in edges){e=edges[key];vertex=geometry.vertices[e.index1];vertices.push(vertex.x,vertex.y,vertex.z);vertex=geometry.vertices[e.index2];vertices.push(vertex.x,vertex.y,vertex.z);}}else if(geometry&&geometry.isBufferGeometry){var position,indices,groups;var group,start,count;var index1,index2;vertex=new Vector3();if(geometry.index!==null){// indexed BufferGeometry
position=geometry.attributes.position;indices=geometry.index;groups=geometry.groups;if(groups.length===0){groups=[{start:0,count:indices.count,materialIndex:0}];}// create a data structure that contains all eges without duplicates
for(o=0,ol=groups.length;o<ol;++o){group=groups[o];start=group.start;count=group.count;for(i=start,l=start+count;i<l;i+=3){for(j=0;j<3;j++){edge1=indices.getX(i+j);edge2=indices.getX(i+(j+1)%3);edge[0]=Math.min(edge1,edge2);// sorting prevents duplicates
edge[1]=Math.max(edge1,edge2);key=edge[0]+','+edge[1];if(edges[key]===undefined){edges[key]={index1:edge[0],index2:edge[1]};}}}}// generate vertices
for(key in edges){e=edges[key];vertex.fromBufferAttribute(position,e.index1);vertices.push(vertex.x,vertex.y,vertex.z);vertex.fromBufferAttribute(position,e.index2);vertices.push(vertex.x,vertex.y,vertex.z);}}else{// non-indexed BufferGeometry
position=geometry.attributes.position;for(i=0,l=position.count/3;i<l;i++){for(j=0;j<3;j++){// three edges per triangle, an edge is represented as (index1, index2)
// e.g. the first triangle has the following edges: (0,1),(1,2),(2,0)
index1=3*i+j;vertex.fromBufferAttribute(position,index1);vertices.push(vertex.x,vertex.y,vertex.z);index2=3*i+(j+1)%3;vertex.fromBufferAttribute(position,index2);vertices.push(vertex.x,vertex.y,vertex.z);}}}}// build geometry
this.addAttribute('position',new Float32BufferAttribute(vertices,3));}WireframeGeometry.prototype=Object.create(BufferGeometry.prototype);WireframeGeometry.prototype.constructor=WireframeGeometry;/**
* @author zz85 / https://github.com/zz85
* @author Mugen87 / https://github.com/Mugen87
*
* Parametric Surfaces Geometry
* based on the brilliant article by @prideout http://prideout.net/blog/?p=44
*/ // ParametricGeometry
function ParametricGeometry(func,slices,stacks){Geometry.call(this);this.type='ParametricGeometry';this.parameters={func:func,slices:slices,stacks:stacks};this.fromBufferGeometry(new ParametricBufferGeometry(func,slices,stacks));this.mergeVertices();}ParametricGeometry.prototype=Object.create(Geometry.prototype);ParametricGeometry.prototype.constructor=ParametricGeometry;// ParametricBufferGeometry
function ParametricBufferGeometry(func,slices,stacks){BufferGeometry.call(this);this.type='ParametricBufferGeometry';this.parameters={func:func,slices:slices,stacks:stacks};// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];var EPS=0.00001;var normal=new Vector3();var p0=new Vector3(),p1=new Vector3();var pu=new Vector3(),pv=new Vector3();var i,j;// generate vertices, normals and uvs
var sliceCount=slices+1;for(i=0;i<=stacks;i++){var v=i/stacks;for(j=0;j<=slices;j++){var u=j/slices;// vertex
func(u,v,p0);vertices.push(p0.x,p0.y,p0.z);// normal
// approximate tangent vectors via finite differences
if(u-EPS>=0){func(u-EPS,v,p1);pu.subVectors(p0,p1);}else{func(u+EPS,v,p1);pu.subVectors(p1,p0);}if(v-EPS>=0){func(u,v-EPS,p1);pv.subVectors(p0,p1);}else{func(u,v+EPS,p1);pv.subVectors(p1,p0);}// cross product of tangent vectors returns surface normal
normal.crossVectors(pu,pv).normalize();normals.push(normal.x,normal.y,normal.z);// uv
uvs.push(u,v);}}// generate indices
for(i=0;i<stacks;i++){for(j=0;j<slices;j++){var a=i*sliceCount+j;var b=i*sliceCount+j+1;var c=(i+1)*sliceCount+j+1;var d=(i+1)*sliceCount+j;// faces one and two
indices.push(a,b,d);indices.push(b,c,d);}}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));}ParametricBufferGeometry.prototype=Object.create(BufferGeometry.prototype);ParametricBufferGeometry.prototype.constructor=ParametricBufferGeometry;/**
* @author clockworkgeek / https://github.com/clockworkgeek
* @author timothypratley / https://github.com/timothypratley
* @author WestLangley / http://github.com/WestLangley
* @author Mugen87 / https://github.com/Mugen87
*/ // PolyhedronGeometry
function PolyhedronGeometry(vertices,indices,radius,detail){Geometry.call(this);this.type='PolyhedronGeometry';this.parameters={vertices:vertices,indices:indices,radius:radius,detail:detail};this.fromBufferGeometry(new PolyhedronBufferGeometry(vertices,indices,radius,detail));this.mergeVertices();}PolyhedronGeometry.prototype=Object.create(Geometry.prototype);PolyhedronGeometry.prototype.constructor=PolyhedronGeometry;// PolyhedronBufferGeometry
function PolyhedronBufferGeometry(vertices,indices,radius,detail){BufferGeometry.call(this);this.type='PolyhedronBufferGeometry';this.parameters={vertices:vertices,indices:indices,radius:radius,detail:detail};radius=radius||1;detail=detail||0;// default buffer data
var vertexBuffer=[];var uvBuffer=[];// the subdivision creates the vertex buffer data
subdivide(detail);// all vertices should lie on a conceptual sphere with a given radius
appplyRadius(radius);// finally, create the uv data
generateUVs();// build non-indexed geometry
this.addAttribute('position',new Float32BufferAttribute(vertexBuffer,3));this.addAttribute('normal',new Float32BufferAttribute(vertexBuffer.slice(),3));this.addAttribute('uv',new Float32BufferAttribute(uvBuffer,2));if(detail===0){this.computeVertexNormals();// flat normals
}else{this.normalizeNormals();// smooth normals
}// helper functions
function subdivide(detail){var a=new Vector3();var b=new Vector3();var c=new Vector3();// iterate over all faces and apply a subdivison with the given detail value
for(var i=0;i<indices.length;i+=3){// get the vertices of the face
getVertexByIndex(indices[i+0],a);getVertexByIndex(indices[i+1],b);getVertexByIndex(indices[i+2],c);// perform subdivision
subdivideFace(a,b,c,detail);}}function subdivideFace(a,b,c,detail){var cols=Math.pow(2,detail);// we use this multidimensional array as a data structure for creating the subdivision
var v=[];var i,j;// construct all of the vertices for this subdivision
for(i=0;i<=cols;i++){v[i]=[];var aj=a.clone().lerp(c,i/cols);var bj=b.clone().lerp(c,i/cols);var rows=cols-i;for(j=0;j<=rows;j++){if(j===0&&i===cols){v[i][j]=aj;}else{v[i][j]=aj.clone().lerp(bj,j/rows);}}}// construct all of the faces
for(i=0;i<cols;i++){for(j=0;j<2*(cols-i)-1;j++){var k=Math.floor(j/2);if(j%2===0){pushVertex(v[i][k+1]);pushVertex(v[i+1][k]);pushVertex(v[i][k]);}else{pushVertex(v[i][k+1]);pushVertex(v[i+1][k+1]);pushVertex(v[i+1][k]);}}}}function appplyRadius(radius){var vertex=new Vector3();// iterate over the entire buffer and apply the radius to each vertex
for(var i=0;i<vertexBuffer.length;i+=3){vertex.x=vertexBuffer[i+0];vertex.y=vertexBuffer[i+1];vertex.z=vertexBuffer[i+2];vertex.normalize().multiplyScalar(radius);vertexBuffer[i+0]=vertex.x;vertexBuffer[i+1]=vertex.y;vertexBuffer[i+2]=vertex.z;}}function generateUVs(){var vertex=new Vector3();for(var i=0;i<vertexBuffer.length;i+=3){vertex.x=vertexBuffer[i+0];vertex.y=vertexBuffer[i+1];vertex.z=vertexBuffer[i+2];var u=azimuth(vertex)/2/Math.PI+0.5;var v=inclination(vertex)/Math.PI+0.5;uvBuffer.push(u,1-v);}correctUVs();correctSeam();}function correctSeam(){// handle case when face straddles the seam, see #3269
for(var i=0;i<uvBuffer.length;i+=6){// uv data of a single face
var x0=uvBuffer[i+0];var x1=uvBuffer[i+2];var x2=uvBuffer[i+4];var max=Math.max(x0,x1,x2);var min=Math.min(x0,x1,x2);// 0.9 is somewhat arbitrary
if(max>0.9&&min<0.1){if(x0<0.2)uvBuffer[i+0]+=1;if(x1<0.2)uvBuffer[i+2]+=1;if(x2<0.2)uvBuffer[i+4]+=1;}}}function pushVertex(vertex){vertexBuffer.push(vertex.x,vertex.y,vertex.z);}function getVertexByIndex(index,vertex){var stride=index*3;vertex.x=vertices[stride+0];vertex.y=vertices[stride+1];vertex.z=vertices[stride+2];}function correctUVs(){var a=new Vector3();var b=new Vector3();var c=new Vector3();var centroid=new Vector3();var uvA=new Vector2();var uvB=new Vector2();var uvC=new Vector2();for(var i=0,j=0;i<vertexBuffer.length;i+=9,j+=6){a.set(vertexBuffer[i+0],vertexBuffer[i+1],vertexBuffer[i+2]);b.set(vertexBuffer[i+3],vertexBuffer[i+4],vertexBuffer[i+5]);c.set(vertexBuffer[i+6],vertexBuffer[i+7],vertexBuffer[i+8]);uvA.set(uvBuffer[j+0],uvBuffer[j+1]);uvB.set(uvBuffer[j+2],uvBuffer[j+3]);uvC.set(uvBuffer[j+4],uvBuffer[j+5]);centroid.copy(a).add(b).add(c).divideScalar(3);var azi=azimuth(centroid);correctUV(uvA,j+0,a,azi);correctUV(uvB,j+2,b,azi);correctUV(uvC,j+4,c,azi);}}function correctUV(uv,stride,vector,azimuth){if(azimuth<0&&uv.x===1){uvBuffer[stride]=uv.x-1;}if(vector.x===0&&vector.z===0){uvBuffer[stride]=azimuth/2/Math.PI+0.5;}}// Angle around the Y axis, counter-clockwise when looking from above.
function azimuth(vector){return Math.atan2(vector.z,-vector.x);}// Angle above the XZ plane.
function inclination(vector){return Math.atan2(-vector.y,Math.sqrt(vector.x*vector.x+vector.z*vector.z));}}PolyhedronBufferGeometry.prototype=Object.create(BufferGeometry.prototype);PolyhedronBufferGeometry.prototype.constructor=PolyhedronBufferGeometry;/**
* @author timothypratley / https://github.com/timothypratley
* @author Mugen87 / https://github.com/Mugen87
*/ // TetrahedronGeometry
function TetrahedronGeometry(radius,detail){Geometry.call(this);this.type='TetrahedronGeometry';this.parameters={radius:radius,detail:detail};this.fromBufferGeometry(new TetrahedronBufferGeometry(radius,detail));this.mergeVertices();}TetrahedronGeometry.prototype=Object.create(Geometry.prototype);TetrahedronGeometry.prototype.constructor=TetrahedronGeometry;// TetrahedronBufferGeometry
function TetrahedronBufferGeometry(radius,detail){var vertices=[1,1,1,-1,-1,1,-1,1,-1,1,-1,-1];var indices=[2,1,0,0,3,2,1,3,0,2,3,1];PolyhedronBufferGeometry.call(this,vertices,indices,radius,detail);this.type='TetrahedronBufferGeometry';this.parameters={radius:radius,detail:detail};}TetrahedronBufferGeometry.prototype=Object.create(PolyhedronBufferGeometry.prototype);TetrahedronBufferGeometry.prototype.constructor=TetrahedronBufferGeometry;/**
* @author timothypratley / https://github.com/timothypratley
* @author Mugen87 / https://github.com/Mugen87
*/ // OctahedronGeometry
function OctahedronGeometry(radius,detail){Geometry.call(this);this.type='OctahedronGeometry';this.parameters={radius:radius,detail:detail};this.fromBufferGeometry(new OctahedronBufferGeometry(radius,detail));this.mergeVertices();}OctahedronGeometry.prototype=Object.create(Geometry.prototype);OctahedronGeometry.prototype.constructor=OctahedronGeometry;// OctahedronBufferGeometry
function OctahedronBufferGeometry(radius,detail){var vertices=[1,0,0,-1,0,0,0,1,0,0,-1,0,0,0,1,0,0,-1];var indices=[0,2,4,0,4,3,0,3,5,0,5,2,1,2,5,1,5,3,1,3,4,1,4,2];PolyhedronBufferGeometry.call(this,vertices,indices,radius,detail);this.type='OctahedronBufferGeometry';this.parameters={radius:radius,detail:detail};}OctahedronBufferGeometry.prototype=Object.create(PolyhedronBufferGeometry.prototype);OctahedronBufferGeometry.prototype.constructor=OctahedronBufferGeometry;/**
* @author timothypratley / https://github.com/timothypratley
* @author Mugen87 / https://github.com/Mugen87
*/ // IcosahedronGeometry
function IcosahedronGeometry(radius,detail){Geometry.call(this);this.type='IcosahedronGeometry';this.parameters={radius:radius,detail:detail};this.fromBufferGeometry(new IcosahedronBufferGeometry(radius,detail));this.mergeVertices();}IcosahedronGeometry.prototype=Object.create(Geometry.prototype);IcosahedronGeometry.prototype.constructor=IcosahedronGeometry;// IcosahedronBufferGeometry
function IcosahedronBufferGeometry(radius,detail){var t=(1+Math.sqrt(5))/2;var vertices=[-1,t,0,1,t,0,-1,-t,0,1,-t,0,0,-1,t,0,1,t,0,-1,-t,0,1,-t,t,0,-1,t,0,1,-t,0,-1,-t,0,1];var indices=[0,11,5,0,5,1,0,1,7,0,7,10,0,10,11,1,5,9,5,11,4,11,10,2,10,7,6,7,1,8,3,9,4,3,4,2,3,2,6,3,6,8,3,8,9,4,9,5,2,4,11,6,2,10,8,6,7,9,8,1];PolyhedronBufferGeometry.call(this,vertices,indices,radius,detail);this.type='IcosahedronBufferGeometry';this.parameters={radius:radius,detail:detail};}IcosahedronBufferGeometry.prototype=Object.create(PolyhedronBufferGeometry.prototype);IcosahedronBufferGeometry.prototype.constructor=IcosahedronBufferGeometry;/**
* @author Abe Pazos / https://hamoid.com
* @author Mugen87 / https://github.com/Mugen87
*/ // DodecahedronGeometry
function DodecahedronGeometry(radius,detail){Geometry.call(this);this.type='DodecahedronGeometry';this.parameters={radius:radius,detail:detail};this.fromBufferGeometry(new DodecahedronBufferGeometry(radius,detail));this.mergeVertices();}DodecahedronGeometry.prototype=Object.create(Geometry.prototype);DodecahedronGeometry.prototype.constructor=DodecahedronGeometry;// DodecahedronBufferGeometry
function DodecahedronBufferGeometry(radius,detail){var t=(1+Math.sqrt(5))/2;var r=1/t;var vertices=[// (±1, ±1, ±1)
-1,-1,-1,-1,-1,1,-1,1,-1,-1,1,1,1,-1,-1,1,-1,1,1,1,-1,1,1,1,// (0, ±1/φ, ±φ)
0,-r,-t,0,-r,t,0,r,-t,0,r,t,// (±1/φ, ±φ, 0)
-r,-t,0,-r,t,0,r,-t,0,r,t,0,// (±φ, 0, ±1/φ)
-t,0,-r,t,0,-r,-t,0,r,t,0,r];var indices=[3,11,7,3,7,15,3,15,13,7,19,17,7,17,6,7,6,15,17,4,8,17,8,10,17,10,6,8,0,16,8,16,2,8,2,10,0,12,1,0,1,18,0,18,16,6,10,2,6,2,13,6,13,15,2,16,18,2,18,3,2,3,13,18,1,9,18,9,11,18,11,3,4,14,12,4,12,0,4,0,8,11,9,5,11,5,19,11,19,7,19,5,14,19,14,4,19,4,17,1,12,14,1,14,5,1,5,9];PolyhedronBufferGeometry.call(this,vertices,indices,radius,detail);this.type='DodecahedronBufferGeometry';this.parameters={radius:radius,detail:detail};}DodecahedronBufferGeometry.prototype=Object.create(PolyhedronBufferGeometry.prototype);DodecahedronBufferGeometry.prototype.constructor=DodecahedronBufferGeometry;/**
* @author oosmoxiecode / https://github.com/oosmoxiecode
* @author WestLangley / https://github.com/WestLangley
* @author zz85 / https://github.com/zz85
* @author miningold / https://github.com/miningold
* @author jonobr1 / https://github.com/jonobr1
* @author Mugen87 / https://github.com/Mugen87
*
*/ // TubeGeometry
function TubeGeometry(path,tubularSegments,radius,radialSegments,closed,taper){Geometry.call(this);this.type='TubeGeometry';this.parameters={path:path,tubularSegments:tubularSegments,radius:radius,radialSegments:radialSegments,closed:closed};if(taper!==undefined)console.warn('THREE.TubeGeometry: taper has been removed.');var bufferGeometry=new TubeBufferGeometry(path,tubularSegments,radius,radialSegments,closed);// expose internals
this.tangents=bufferGeometry.tangents;this.normals=bufferGeometry.normals;this.binormals=bufferGeometry.binormals;// create geometry
this.fromBufferGeometry(bufferGeometry);this.mergeVertices();}TubeGeometry.prototype=Object.create(Geometry.prototype);TubeGeometry.prototype.constructor=TubeGeometry;// TubeBufferGeometry
function TubeBufferGeometry(path,tubularSegments,radius,radialSegments,closed){BufferGeometry.call(this);this.type='TubeBufferGeometry';this.parameters={path:path,tubularSegments:tubularSegments,radius:radius,radialSegments:radialSegments,closed:closed};tubularSegments=tubularSegments||64;radius=radius||1;radialSegments=radialSegments||8;closed=closed||false;var frames=path.computeFrenetFrames(tubularSegments,closed);// expose internals
this.tangents=frames.tangents;this.normals=frames.normals;this.binormals=frames.binormals;// helper variables
var vertex=new Vector3();var normal=new Vector3();var uv=new Vector2();var P=new Vector3();var i,j;// buffer
var vertices=[];var normals=[];var uvs=[];var indices=[];// create buffer data
generateBufferData();// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));// functions
function generateBufferData(){for(i=0;i<tubularSegments;i++){generateSegment(i);}// if the geometry is not closed, generate the last row of vertices and normals
// at the regular position on the given path
//
// if the geometry is closed, duplicate the first row of vertices and normals (uvs will differ)
generateSegment(closed===false?tubularSegments:0);// uvs are generated in a separate function.
// this makes it easy compute correct values for closed geometries
generateUVs();// finally create faces
generateIndices();}function generateSegment(i){// we use getPointAt to sample evenly distributed points from the given path
P=path.getPointAt(i/tubularSegments,P);// retrieve corresponding normal and binormal
var N=frames.normals[i];var B=frames.binormals[i];// generate normals and vertices for the current segment
for(j=0;j<=radialSegments;j++){var v=j/radialSegments*Math.PI*2;var sin=Math.sin(v);var cos=-Math.cos(v);// normal
normal.x=cos*N.x+sin*B.x;normal.y=cos*N.y+sin*B.y;normal.z=cos*N.z+sin*B.z;normal.normalize();normals.push(normal.x,normal.y,normal.z);// vertex
vertex.x=P.x+radius*normal.x;vertex.y=P.y+radius*normal.y;vertex.z=P.z+radius*normal.z;vertices.push(vertex.x,vertex.y,vertex.z);}}function generateIndices(){for(j=1;j<=tubularSegments;j++){for(i=1;i<=radialSegments;i++){var a=(radialSegments+1)*(j-1)+(i-1);var b=(radialSegments+1)*j+(i-1);var c=(radialSegments+1)*j+i;var d=(radialSegments+1)*(j-1)+i;// faces
indices.push(a,b,d);indices.push(b,c,d);}}}function generateUVs(){for(i=0;i<=tubularSegments;i++){for(j=0;j<=radialSegments;j++){uv.x=i/tubularSegments;uv.y=j/radialSegments;uvs.push(uv.x,uv.y);}}}}TubeBufferGeometry.prototype=Object.create(BufferGeometry.prototype);TubeBufferGeometry.prototype.constructor=TubeBufferGeometry;/**
* @author oosmoxiecode
* @author Mugen87 / https://github.com/Mugen87
*
* based on http://www.blackpawn.com/texts/pqtorus/
*/ // TorusKnotGeometry
function TorusKnotGeometry(radius,tube,tubularSegments,radialSegments,p,q,heightScale){Geometry.call(this);this.type='TorusKnotGeometry';this.parameters={radius:radius,tube:tube,tubularSegments:tubularSegments,radialSegments:radialSegments,p:p,q:q};if(heightScale!==undefined)console.warn('THREE.TorusKnotGeometry: heightScale has been deprecated. Use .scale( x, y, z ) instead.');this.fromBufferGeometry(new TorusKnotBufferGeometry(radius,tube,tubularSegments,radialSegments,p,q));this.mergeVertices();}TorusKnotGeometry.prototype=Object.create(Geometry.prototype);TorusKnotGeometry.prototype.constructor=TorusKnotGeometry;// TorusKnotBufferGeometry
function TorusKnotBufferGeometry(radius,tube,tubularSegments,radialSegments,p,q){BufferGeometry.call(this);this.type='TorusKnotBufferGeometry';this.parameters={radius:radius,tube:tube,tubularSegments:tubularSegments,radialSegments:radialSegments,p:p,q:q};radius=radius||1;tube=tube||0.4;tubularSegments=Math.floor(tubularSegments)||64;radialSegments=Math.floor(radialSegments)||8;p=p||2;q=q||3;// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];// helper variables
var i,j;var vertex=new Vector3();var normal=new Vector3();var P1=new Vector3();var P2=new Vector3();var B=new Vector3();var T=new Vector3();var N=new Vector3();// generate vertices, normals and uvs
for(i=0;i<=tubularSegments;++i){// the radian "u" is used to calculate the position on the torus curve of the current tubular segement
var u=i/tubularSegments*p*Math.PI*2;// now we calculate two points. P1 is our current position on the curve, P2 is a little farther ahead.
// these points are used to create a special "coordinate space", which is necessary to calculate the correct vertex positions
calculatePositionOnCurve(u,p,q,radius,P1);calculatePositionOnCurve(u+0.01,p,q,radius,P2);// calculate orthonormal basis
T.subVectors(P2,P1);N.addVectors(P2,P1);B.crossVectors(T,N);N.crossVectors(B,T);// normalize B, N. T can be ignored, we don't use it
B.normalize();N.normalize();for(j=0;j<=radialSegments;++j){// now calculate the vertices. they are nothing more than an extrusion of the torus curve.
// because we extrude a shape in the xy-plane, there is no need to calculate a z-value.
var v=j/radialSegments*Math.PI*2;var cx=-tube*Math.cos(v);var cy=tube*Math.sin(v);// now calculate the final vertex position.
// first we orient the extrusion with our basis vectos, then we add it to the current position on the curve
vertex.x=P1.x+(cx*N.x+cy*B.x);vertex.y=P1.y+(cx*N.y+cy*B.y);vertex.z=P1.z+(cx*N.z+cy*B.z);vertices.push(vertex.x,vertex.y,vertex.z);// normal (P1 is always the center/origin of the extrusion, thus we can use it to calculate the normal)
normal.subVectors(vertex,P1).normalize();normals.push(normal.x,normal.y,normal.z);// uv
uvs.push(i/tubularSegments);uvs.push(j/radialSegments);}}// generate indices
for(j=1;j<=tubularSegments;j++){for(i=1;i<=radialSegments;i++){// indices
var a=(radialSegments+1)*(j-1)+(i-1);var b=(radialSegments+1)*j+(i-1);var c=(radialSegments+1)*j+i;var d=(radialSegments+1)*(j-1)+i;// faces
indices.push(a,b,d);indices.push(b,c,d);}}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));// this function calculates the current position on the torus curve
function calculatePositionOnCurve(u,p,q,radius,position){var cu=Math.cos(u);var su=Math.sin(u);var quOverP=q/p*u;var cs=Math.cos(quOverP);position.x=radius*(2+cs)*0.5*cu;position.y=radius*(2+cs)*su*0.5;position.z=radius*Math.sin(quOverP)*0.5;}}TorusKnotBufferGeometry.prototype=Object.create(BufferGeometry.prototype);TorusKnotBufferGeometry.prototype.constructor=TorusKnotBufferGeometry;/**
* @author oosmoxiecode
* @author mrdoob / http://mrdoob.com/
* @author Mugen87 / https://github.com/Mugen87
*/ // TorusGeometry
function TorusGeometry(radius,tube,radialSegments,tubularSegments,arc){Geometry.call(this);this.type='TorusGeometry';this.parameters={radius:radius,tube:tube,radialSegments:radialSegments,tubularSegments:tubularSegments,arc:arc};this.fromBufferGeometry(new TorusBufferGeometry(radius,tube,radialSegments,tubularSegments,arc));this.mergeVertices();}TorusGeometry.prototype=Object.create(Geometry.prototype);TorusGeometry.prototype.constructor=TorusGeometry;// TorusBufferGeometry
function TorusBufferGeometry(radius,tube,radialSegments,tubularSegments,arc){BufferGeometry.call(this);this.type='TorusBufferGeometry';this.parameters={radius:radius,tube:tube,radialSegments:radialSegments,tubularSegments:tubularSegments,arc:arc};radius=radius||1;tube=tube||0.4;radialSegments=Math.floor(radialSegments)||8;tubularSegments=Math.floor(tubularSegments)||6;arc=arc||Math.PI*2;// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];// helper variables
var center=new Vector3();var vertex=new Vector3();var normal=new Vector3();var j,i;// generate vertices, normals and uvs
for(j=0;j<=radialSegments;j++){for(i=0;i<=tubularSegments;i++){var u=i/tubularSegments*arc;var v=j/radialSegments*Math.PI*2;// vertex
vertex.x=(radius+tube*Math.cos(v))*Math.cos(u);vertex.y=(radius+tube*Math.cos(v))*Math.sin(u);vertex.z=tube*Math.sin(v);vertices.push(vertex.x,vertex.y,vertex.z);// normal
center.x=radius*Math.cos(u);center.y=radius*Math.sin(u);normal.subVectors(vertex,center).normalize();normals.push(normal.x,normal.y,normal.z);// uv
uvs.push(i/tubularSegments);uvs.push(j/radialSegments);}}// generate indices
for(j=1;j<=radialSegments;j++){for(i=1;i<=tubularSegments;i++){// indices
var a=(tubularSegments+1)*j+i-1;var b=(tubularSegments+1)*(j-1)+i-1;var c=(tubularSegments+1)*(j-1)+i;var d=(tubularSegments+1)*j+i;// faces
indices.push(a,b,d);indices.push(b,c,d);}}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));}TorusBufferGeometry.prototype=Object.create(BufferGeometry.prototype);TorusBufferGeometry.prototype.constructor=TorusBufferGeometry;/**
* @author Mugen87 / https://github.com/Mugen87
* Port from https://github.com/mapbox/earcut (v2.1.2)
*/var Earcut={triangulate:function(data,holeIndices,dim){dim=dim||2;var hasHoles=holeIndices&&holeIndices.length,outerLen=hasHoles?holeIndices[0]*dim:data.length,outerNode=linkedList(data,0,outerLen,dim,true),triangles=[];if(!outerNode)return triangles;var minX,minY,maxX,maxY,x,y,invSize;if(hasHoles)outerNode=eliminateHoles(data,holeIndices,outerNode,dim);// if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox
if(data.length>80*dim){minX=maxX=data[0];minY=maxY=data[1];for(var i=dim;i<outerLen;i+=dim){x=data[i];y=data[i+1];if(x<minX)minX=x;if(y<minY)minY=y;if(x>maxX)maxX=x;if(y>maxY)maxY=y;}// minX, minY and invSize are later used to transform coords into integers for z-order calculation
invSize=Math.max(maxX-minX,maxY-minY);invSize=invSize!==0?1/invSize:0;}earcutLinked(outerNode,triangles,dim,minX,minY,invSize);return triangles;}};// create a circular doubly linked list from polygon points in the specified winding order
function linkedList(data,start,end,dim,clockwise){var i,last;if(clockwise===signedArea(data,start,end,dim)>0){for(i=start;i<end;i+=dim)last=insertNode(i,data[i],data[i+1],last);}else{for(i=end-dim;i>=start;i-=dim)last=insertNode(i,data[i],data[i+1],last);}if(last&&equals(last,last.next)){removeNode(last);last=last.next;}return last;}// eliminate colinear or duplicate points
function filterPoints(start,end){if(!start)return start;if(!end)end=start;var p=start,again;do{again=false;if(!p.steiner&&(equals(p,p.next)||area(p.prev,p,p.next)===0)){removeNode(p);p=end=p.prev;if(p===p.next)break;again=true;}else{p=p.next;}}while(again||p!==end);return end;}// main ear slicing loop which triangulates a polygon (given as a linked list)
function earcutLinked(ear,triangles,dim,minX,minY,invSize,pass){if(!ear)return;// interlink polygon nodes in z-order
if(!pass&&invSize)indexCurve(ear,minX,minY,invSize);var stop=ear,prev,next;// iterate through ears, slicing them one by one
while(ear.prev!==ear.next){prev=ear.prev;next=ear.next;if(invSize?isEarHashed(ear,minX,minY,invSize):isEar(ear)){// cut off the triangle
triangles.push(prev.i/dim);triangles.push(ear.i/dim);triangles.push(next.i/dim);removeNode(ear);// skipping the next vertice leads to less sliver triangles
ear=next.next;stop=next.next;continue;}ear=next;// if we looped through the whole remaining polygon and can't find any more ears
if(ear===stop){// try filtering points and slicing again
if(!pass){earcutLinked(filterPoints(ear),triangles,dim,minX,minY,invSize,1);// if this didn't work, try curing all small self-intersections locally
}else if(pass===1){ear=cureLocalIntersections(ear,triangles,dim);earcutLinked(ear,triangles,dim,minX,minY,invSize,2);// as a last resort, try splitting the remaining polygon into two
}else if(pass===2){splitEarcut(ear,triangles,dim,minX,minY,invSize);}break;}}}// check whether a polygon node forms a valid ear with adjacent nodes
function isEar(ear){var a=ear.prev,b=ear,c=ear.next;if(area(a,b,c)>=0)return false;// reflex, can't be an ear
// now make sure we don't have other points inside the potential ear
var p=ear.next.next;while(p!==ear.prev){if(pointInTriangle(a.x,a.y,b.x,b.y,c.x,c.y,p.x,p.y)&&area(p.prev,p,p.next)>=0){return false;}p=p.next;}return true;}function isEarHashed(ear,minX,minY,invSize){var a=ear.prev,b=ear,c=ear.next;if(area(a,b,c)>=0)return false;// reflex, can't be an ear
// triangle bbox; min & max are calculated like this for speed
var minTX=a.x<b.x?a.x<c.x?a.x:c.x:b.x<c.x?b.x:c.x,minTY=a.y<b.y?a.y<c.y?a.y:c.y:b.y<c.y?b.y:c.y,maxTX=a.x>b.x?a.x>c.x?a.x:c.x:b.x>c.x?b.x:c.x,maxTY=a.y>b.y?a.y>c.y?a.y:c.y:b.y>c.y?b.y:c.y;// z-order range for the current triangle bbox;
var minZ=zOrder(minTX,minTY,minX,minY,invSize),maxZ=zOrder(maxTX,maxTY,minX,minY,invSize);// first look for points inside the triangle in increasing z-order
var p=ear.nextZ;while(p&&p.z<=maxZ){if(p!==ear.prev&&p!==ear.next&&pointInTriangle(a.x,a.y,b.x,b.y,c.x,c.y,p.x,p.y)&&area(p.prev,p,p.next)>=0)return false;p=p.nextZ;}// then look for points in decreasing z-order
p=ear.prevZ;while(p&&p.z>=minZ){if(p!==ear.prev&&p!==ear.next&&pointInTriangle(a.x,a.y,b.x,b.y,c.x,c.y,p.x,p.y)&&area(p.prev,p,p.next)>=0)return false;p=p.prevZ;}return true;}// go through all polygon nodes and cure small local self-intersections
function cureLocalIntersections(start,triangles,dim){var p=start;do{var a=p.prev,b=p.next.next;if(!equals(a,b)&&intersects(a,p,p.next,b)&&locallyInside(a,b)&&locallyInside(b,a)){triangles.push(a.i/dim);triangles.push(p.i/dim);triangles.push(b.i/dim);// remove two nodes involved
removeNode(p);removeNode(p.next);p=start=b;}p=p.next;}while(p!==start);return p;}// try splitting polygon into two and triangulate them independently
function splitEarcut(start,triangles,dim,minX,minY,invSize){// look for a valid diagonal that divides the polygon into two
var a=start;do{var b=a.next.next;while(b!==a.prev){if(a.i!==b.i&&isValidDiagonal(a,b)){// split the polygon in two by the diagonal
var c=splitPolygon(a,b);// filter colinear points around the cuts
a=filterPoints(a,a.next);c=filterPoints(c,c.next);// run earcut on each half
earcutLinked(a,triangles,dim,minX,minY,invSize);earcutLinked(c,triangles,dim,minX,minY,invSize);return;}b=b.next;}a=a.next;}while(a!==start);}// link every hole into the outer loop, producing a single-ring polygon without holes
function eliminateHoles(data,holeIndices,outerNode,dim){var queue=[],i,len,start,end,list;for(i=0,len=holeIndices.length;i<len;i++){start=holeIndices[i]*dim;end=i<len-1?holeIndices[i+1]*dim:data.length;list=linkedList(data,start,end,dim,false);if(list===list.next)list.steiner=true;queue.push(getLeftmost(list));}queue.sort(compareX);// process holes from left to right
for(i=0;i<queue.length;i++){eliminateHole(queue[i],outerNode);outerNode=filterPoints(outerNode,outerNode.next);}return outerNode;}function compareX(a,b){return a.x-b.x;}// find a bridge between vertices that connects hole with an outer ring and and link it
function eliminateHole(hole,outerNode){outerNode=findHoleBridge(hole,outerNode);if(outerNode){var b=splitPolygon(outerNode,hole);filterPoints(b,b.next);}}// David Eberly's algorithm for finding a bridge between hole and outer polygon
function findHoleBridge(hole,outerNode){var p=outerNode,hx=hole.x,hy=hole.y,qx=-Infinity,m;// find a segment intersected by a ray from the hole's leftmost point to the left;
// segment's endpoint with lesser x will be potential connection point
do{if(hy<=p.y&&hy>=p.next.y&&p.next.y!==p.y){var x=p.x+(hy-p.y)*(p.next.x-p.x)/(p.next.y-p.y);if(x<=hx&&x>qx){qx=x;if(x===hx){if(hy===p.y)return p;if(hy===p.next.y)return p.next;}m=p.x<p.next.x?p:p.next;}}p=p.next;}while(p!==outerNode);if(!m)return null;if(hx===qx)return m.prev;// hole touches outer segment; pick lower endpoint
// look for points inside the triangle of hole point, segment intersection and endpoint;
// if there are no points found, we have a valid connection;
// otherwise choose the point of the minimum angle with the ray as connection point
var stop=m,mx=m.x,my=m.y,tanMin=Infinity,tan;p=m.next;while(p!==stop){if(hx>=p.x&&p.x>=mx&&hx!==p.x&&pointInTriangle(hy<my?hx:qx,hy,mx,my,hy<my?qx:hx,hy,p.x,p.y)){tan=Math.abs(hy-p.y)/(hx-p.x);// tangential
if((tan<tanMin||tan===tanMin&&p.x>m.x)&&locallyInside(p,hole)){m=p;tanMin=tan;}}p=p.next;}return m;}// interlink polygon nodes in z-order
function indexCurve(start,minX,minY,invSize){var p=start;do{if(p.z===null)p.z=zOrder(p.x,p.y,minX,minY,invSize);p.prevZ=p.prev;p.nextZ=p.next;p=p.next;}while(p!==start);p.prevZ.nextZ=null;p.prevZ=null;sortLinked(p);}// Simon Tatham's linked list merge sort algorithm
// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html
function sortLinked(list){var i,p,q,e,tail,numMerges,pSize,qSize,inSize=1;do{p=list;list=null;tail=null;numMerges=0;while(p){numMerges++;q=p;pSize=0;for(i=0;i<inSize;i++){pSize++;q=q.nextZ;if(!q)break;}qSize=inSize;while(pSize>0||qSize>0&&q){if(pSize!==0&&(qSize===0||!q||p.z<=q.z)){e=p;p=p.nextZ;pSize--;}else{e=q;q=q.nextZ;qSize--;}if(tail)tail.nextZ=e;else list=e;e.prevZ=tail;tail=e;}p=q;}tail.nextZ=null;inSize*=2;}while(numMerges>1);return list;}// z-order of a point given coords and inverse of the longer side of data bbox
function zOrder(x,y,minX,minY,invSize){// coords are transformed into non-negative 15-bit integer range
x=32767*(x-minX)*invSize;y=32767*(y-minY)*invSize;x=(x|x<<8)&0x00FF00FF;x=(x|x<<4)&0x0F0F0F0F;x=(x|x<<2)&0x33333333;x=(x|x<<1)&0x55555555;y=(y|y<<8)&0x00FF00FF;y=(y|y<<4)&0x0F0F0F0F;y=(y|y<<2)&0x33333333;y=(y|y<<1)&0x55555555;return x|y<<1;}// find the leftmost node of a polygon ring
function getLeftmost(start){var p=start,leftmost=start;do{if(p.x<leftmost.x)leftmost=p;p=p.next;}while(p!==start);return leftmost;}// check if a point lies within a convex triangle
function pointInTriangle(ax,ay,bx,by,cx,cy,px,py){return (cx-px)*(ay-py)-(ax-px)*(cy-py)>=0&&(ax-px)*(by-py)-(bx-px)*(ay-py)>=0&&(bx-px)*(cy-py)-(cx-px)*(by-py)>=0;}// check if a diagonal between two polygon nodes is valid (lies in polygon interior)
function isValidDiagonal(a,b){return a.next.i!==b.i&&a.prev.i!==b.i&&!intersectsPolygon(a,b)&&locallyInside(a,b)&&locallyInside(b,a)&&middleInside(a,b);}// signed area of a triangle
function area(p,q,r){return (q.y-p.y)*(r.x-q.x)-(q.x-p.x)*(r.y-q.y);}// check if two points are equal
function equals(p1,p2){return p1.x===p2.x&&p1.y===p2.y;}// check if two segments intersect
function intersects(p1,q1,p2,q2){if(equals(p1,q1)&&equals(p2,q2)||equals(p1,q2)&&equals(p2,q1))return true;return area(p1,q1,p2)>0!==area(p1,q1,q2)>0&&area(p2,q2,p1)>0!==area(p2,q2,q1)>0;}// check if a polygon diagonal intersects any polygon segments
function intersectsPolygon(a,b){var p=a;do{if(p.i!==a.i&&p.next.i!==a.i&&p.i!==b.i&&p.next.i!==b.i&&intersects(p,p.next,a,b)){return true;}p=p.next;}while(p!==a);return false;}// check if a polygon diagonal is locally inside the polygon
function locallyInside(a,b){return area(a.prev,a,a.next)<0?area(a,b,a.next)>=0&&area(a,a.prev,b)>=0:area(a,b,a.prev)<0||area(a,a.next,b)<0;}// check if the middle point of a polygon diagonal is inside the polygon
function middleInside(a,b){var p=a,inside=false,px=(a.x+b.x)/2,py=(a.y+b.y)/2;do{if(p.y>py!==p.next.y>py&&p.next.y!==p.y&&px<(p.next.x-p.x)*(py-p.y)/(p.next.y-p.y)+p.x){inside=!inside;}p=p.next;}while(p!==a);return inside;}// link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;
// if one belongs to the outer ring and another to a hole, it merges it into a single ring
function splitPolygon(a,b){var a2=new Node(a.i,a.x,a.y),b2=new Node(b.i,b.x,b.y),an=a.next,bp=b.prev;a.next=b;b.prev=a;a2.next=an;an.prev=a2;b2.next=a2;a2.prev=b2;bp.next=b2;b2.prev=bp;return b2;}// create a node and optionally link it with previous one (in a circular doubly linked list)
function insertNode(i,x,y,last){var p=new Node(i,x,y);if(!last){p.prev=p;p.next=p;}else{p.next=last.next;p.prev=last;last.next.prev=p;last.next=p;}return p;}function removeNode(p){p.next.prev=p.prev;p.prev.next=p.next;if(p.prevZ)p.prevZ.nextZ=p.nextZ;if(p.nextZ)p.nextZ.prevZ=p.prevZ;}function Node(i,x,y){// vertice index in coordinates array
this.i=i;// vertex coordinates
this.x=x;this.y=y;// previous and next vertice nodes in a polygon ring
this.prev=null;this.next=null;// z-order curve value
this.z=null;// previous and next nodes in z-order
this.prevZ=null;this.nextZ=null;// indicates whether this is a steiner point
this.steiner=false;}function signedArea(data,start,end,dim){var sum=0;for(var i=start,j=end-dim;i<end;i+=dim){sum+=(data[j]-data[i])*(data[i+1]+data[j+1]);j=i;}return sum;}/**
* @author zz85 / http://www.lab4games.net/zz85/blog
*/var ShapeUtils={// calculate area of the contour polygon
area:function(contour){var n=contour.length;var a=0.0;for(var p=n-1,q=0;q<n;p=q++){a+=contour[p].x*contour[q].y-contour[q].x*contour[p].y;}return a*0.5;},isClockWise:function(pts){return ShapeUtils.area(pts)<0;},triangulateShape:function(contour,holes){var vertices=[];// flat array of vertices like [ x0,y0, x1,y1, x2,y2, ... ]
var holeIndices=[];// array of hole indices
var faces=[];// final array of vertex indices like [ [ a,b,d ], [ b,c,d ] ]
removeDupEndPts(contour);addContour(vertices,contour);//
var holeIndex=contour.length;holes.forEach(removeDupEndPts);for(var i=0;i<holes.length;i++){holeIndices.push(holeIndex);holeIndex+=holes[i].length;addContour(vertices,holes[i]);}//
var triangles=Earcut.triangulate(vertices,holeIndices);//
for(var i=0;i<triangles.length;i+=3){faces.push(triangles.slice(i,i+3));}return faces;}};function removeDupEndPts(points){var l=points.length;if(l>2&&points[l-1].equals(points[0])){points.pop();}}function addContour(vertices,contour){for(var i=0;i<contour.length;i++){vertices.push(contour[i].x);vertices.push(contour[i].y);}}/**
* @author zz85 / http://www.lab4games.net/zz85/blog
*
* Creates extruded geometry from a path shape.
*
* parameters = {
*
* curveSegments: <int>, // number of points on the curves
* steps: <int>, // number of points for z-side extrusions / used for subdividing segments of extrude spline too
* amount: <int>, // Depth to extrude the shape
*
* bevelEnabled: <bool>, // turn on bevel
* bevelThickness: <float>, // how deep into the original shape bevel goes
* bevelSize: <float>, // how far from shape outline is bevel
* bevelSegments: <int>, // number of bevel layers
*
* extrudePath: <THREE.Curve> // curve to extrude shape along
*
* UVGenerator: <Object> // object that provides UV generator functions
*
* }
*/ // ExtrudeGeometry
function ExtrudeGeometry(shapes,options){Geometry.call(this);this.type='ExtrudeGeometry';this.parameters={shapes:shapes,options:options};this.fromBufferGeometry(new ExtrudeBufferGeometry(shapes,options));this.mergeVertices();}ExtrudeGeometry.prototype=Object.create(Geometry.prototype);ExtrudeGeometry.prototype.constructor=ExtrudeGeometry;// ExtrudeBufferGeometry
function ExtrudeBufferGeometry(shapes,options){BufferGeometry.call(this);this.type='ExtrudeBufferGeometry';this.parameters={shapes:shapes,options:options};shapes=Array.isArray(shapes)?shapes:[shapes];var scope=this;var verticesArray=[];var uvArray=[];for(var i=0,l=shapes.length;i<l;i++){var shape=shapes[i];addShape(shape,options);}// build geometry
this.addAttribute('position',new Float32BufferAttribute(verticesArray,3));this.addAttribute('uv',new Float32BufferAttribute(uvArray,2));this.computeVertexNormals();// functions
function addShape(shape){var placeholder=[];// options
var curveSegments=options.curveSegments!==undefined?options.curveSegments:12;var steps=options.steps!==undefined?options.steps:1;var amount=options.amount!==undefined?options.amount:100;var bevelEnabled=options.bevelEnabled!==undefined?options.bevelEnabled:true;var bevelThickness=options.bevelThickness!==undefined?options.bevelThickness:6;var bevelSize=options.bevelSize!==undefined?options.bevelSize:bevelThickness-2;var bevelSegments=options.bevelSegments!==undefined?options.bevelSegments:3;var extrudePath=options.extrudePath;var uvgen=options.UVGenerator!==undefined?options.UVGenerator:WorldUVGenerator;//
var extrudePts,extrudeByPath=false;var splineTube,binormal,normal,position2;if(extrudePath){extrudePts=extrudePath.getSpacedPoints(steps);extrudeByPath=true;bevelEnabled=false;// bevels not supported for path extrusion
// SETUP TNB variables
// TODO1 - have a .isClosed in spline?
splineTube=extrudePath.computeFrenetFrames(steps,false);// console.log(splineTube, 'splineTube', splineTube.normals.length, 'steps', steps, 'extrudePts', extrudePts.length);
binormal=new Vector3();normal=new Vector3();position2=new Vector3();}// Safeguards if bevels are not enabled
if(!bevelEnabled){bevelSegments=0;bevelThickness=0;bevelSize=0;}// Variables initialization
var ahole,h,hl;// looping of holes
var shapePoints=shape.extractPoints(curveSegments);var vertices=shapePoints.shape;var holes=shapePoints.holes;var reverse=!ShapeUtils.isClockWise(vertices);if(reverse){vertices=vertices.reverse();// Maybe we should also check if holes are in the opposite direction, just to be safe ...
for(h=0,hl=holes.length;h<hl;h++){ahole=holes[h];if(ShapeUtils.isClockWise(ahole)){holes[h]=ahole.reverse();}}}var faces=ShapeUtils.triangulateShape(vertices,holes);/* Vertices */var contour=vertices;// vertices has all points but contour has only points of circumference
for(h=0,hl=holes.length;h<hl;h++){ahole=holes[h];vertices=vertices.concat(ahole);}function scalePt2(pt,vec,size){if(!vec)console.error("THREE.ExtrudeGeometry: vec does not exist");return vec.clone().multiplyScalar(size).add(pt);}var b,bs,t,z,vert,vlen=vertices.length,face,flen=faces.length;// Find directions for point movement
function getBevelVec(inPt,inPrev,inNext){// computes for inPt the corresponding point inPt' on a new contour
// shifted by 1 unit (length of normalized vector) to the left
// if we walk along contour clockwise, this new contour is outside the old one
//
// inPt' is the intersection of the two lines parallel to the two
// adjacent edges of inPt at a distance of 1 unit on the left side.
var v_trans_x,v_trans_y,shrink_by;// resulting translation vector for inPt
// good reading for geometry algorithms (here: line-line intersection)
// http://geomalgorithms.com/a05-_intersect-1.html
var v_prev_x=inPt.x-inPrev.x,v_prev_y=inPt.y-inPrev.y;var v_next_x=inNext.x-inPt.x,v_next_y=inNext.y-inPt.y;var v_prev_lensq=v_prev_x*v_prev_x+v_prev_y*v_prev_y;// check for collinear edges
var collinear0=v_prev_x*v_next_y-v_prev_y*v_next_x;if(Math.abs(collinear0)>Number.EPSILON){// not collinear
// length of vectors for normalizing
var v_prev_len=Math.sqrt(v_prev_lensq);var v_next_len=Math.sqrt(v_next_x*v_next_x+v_next_y*v_next_y);// shift adjacent points by unit vectors to the left
var ptPrevShift_x=inPrev.x-v_prev_y/v_prev_len;var ptPrevShift_y=inPrev.y+v_prev_x/v_prev_len;var ptNextShift_x=inNext.x-v_next_y/v_next_len;var ptNextShift_y=inNext.y+v_next_x/v_next_len;// scaling factor for v_prev to intersection point
var sf=((ptNextShift_x-ptPrevShift_x)*v_next_y-(ptNextShift_y-ptPrevShift_y)*v_next_x)/(v_prev_x*v_next_y-v_prev_y*v_next_x);// vector from inPt to intersection point
v_trans_x=ptPrevShift_x+v_prev_x*sf-inPt.x;v_trans_y=ptPrevShift_y+v_prev_y*sf-inPt.y;// Don't normalize!, otherwise sharp corners become ugly
// but prevent crazy spikes
var v_trans_lensq=v_trans_x*v_trans_x+v_trans_y*v_trans_y;if(v_trans_lensq<=2){return new Vector2(v_trans_x,v_trans_y);}else{shrink_by=Math.sqrt(v_trans_lensq/2);}}else{// handle special case of collinear edges
var direction_eq=false;// assumes: opposite
if(v_prev_x>Number.EPSILON){if(v_next_x>Number.EPSILON){direction_eq=true;}}else{if(v_prev_x<-Number.EPSILON){if(v_next_x<-Number.EPSILON){direction_eq=true;}}else{if(Math.sign(v_prev_y)===Math.sign(v_next_y)){direction_eq=true;}}}if(direction_eq){// console.log("Warning: lines are a straight sequence");
v_trans_x=-v_prev_y;v_trans_y=v_prev_x;shrink_by=Math.sqrt(v_prev_lensq);}else{// console.log("Warning: lines are a straight spike");
v_trans_x=v_prev_x;v_trans_y=v_prev_y;shrink_by=Math.sqrt(v_prev_lensq/2);}}return new Vector2(v_trans_x/shrink_by,v_trans_y/shrink_by);}var contourMovements=[];for(var i=0,il=contour.length,j=il-1,k=i+1;i<il;i++,j++,k++){if(j===il)j=0;if(k===il)k=0;// (j)---(i)---(k)
// console.log('i,j,k', i, j , k)
contourMovements[i]=getBevelVec(contour[i],contour[j],contour[k]);}var holesMovements=[],oneHoleMovements,verticesMovements=contourMovements.concat();for(h=0,hl=holes.length;h<hl;h++){ahole=holes[h];oneHoleMovements=[];for(i=0,il=ahole.length,j=il-1,k=i+1;i<il;i++,j++,k++){if(j===il)j=0;if(k===il)k=0;// (j)---(i)---(k)
oneHoleMovements[i]=getBevelVec(ahole[i],ahole[j],ahole[k]);}holesMovements.push(oneHoleMovements);verticesMovements=verticesMovements.concat(oneHoleMovements);}// Loop bevelSegments, 1 for the front, 1 for the back
for(b=0;b<bevelSegments;b++){//for ( b = bevelSegments; b > 0; b -- ) {
t=b/bevelSegments;z=bevelThickness*Math.cos(t*Math.PI/2);bs=bevelSize*Math.sin(t*Math.PI/2);// contract shape
for(i=0,il=contour.length;i<il;i++){vert=scalePt2(contour[i],contourMovements[i],bs);v(vert.x,vert.y,-z);}// expand holes
for(h=0,hl=holes.length;h<hl;h++){ahole=holes[h];oneHoleMovements=holesMovements[h];for(i=0,il=ahole.length;i<il;i++){vert=scalePt2(ahole[i],oneHoleMovements[i],bs);v(vert.x,vert.y,-z);}}}bs=bevelSize;// Back facing vertices
for(i=0;i<vlen;i++){vert=bevelEnabled?scalePt2(vertices[i],verticesMovements[i],bs):vertices[i];if(!extrudeByPath){v(vert.x,vert.y,0);}else{// v( vert.x, vert.y + extrudePts[ 0 ].y, extrudePts[ 0 ].x );
normal.copy(splineTube.normals[0]).multiplyScalar(vert.x);binormal.copy(splineTube.binormals[0]).multiplyScalar(vert.y);position2.copy(extrudePts[0]).add(normal).add(binormal);v(position2.x,position2.y,position2.z);}}// Add stepped vertices...
// Including front facing vertices
var s;for(s=1;s<=steps;s++){for(i=0;i<vlen;i++){vert=bevelEnabled?scalePt2(vertices[i],verticesMovements[i],bs):vertices[i];if(!extrudeByPath){v(vert.x,vert.y,amount/steps*s);}else{// v( vert.x, vert.y + extrudePts[ s - 1 ].y, extrudePts[ s - 1 ].x );
normal.copy(splineTube.normals[s]).multiplyScalar(vert.x);binormal.copy(splineTube.binormals[s]).multiplyScalar(vert.y);position2.copy(extrudePts[s]).add(normal).add(binormal);v(position2.x,position2.y,position2.z);}}}// Add bevel segments planes
//for ( b = 1; b <= bevelSegments; b ++ ) {
for(b=bevelSegments-1;b>=0;b--){t=b/bevelSegments;z=bevelThickness*Math.cos(t*Math.PI/2);bs=bevelSize*Math.sin(t*Math.PI/2);// contract shape
for(i=0,il=contour.length;i<il;i++){vert=scalePt2(contour[i],contourMovements[i],bs);v(vert.x,vert.y,amount+z);}// expand holes
for(h=0,hl=holes.length;h<hl;h++){ahole=holes[h];oneHoleMovements=holesMovements[h];for(i=0,il=ahole.length;i<il;i++){vert=scalePt2(ahole[i],oneHoleMovements[i],bs);if(!extrudeByPath){v(vert.x,vert.y,amount+z);}else{v(vert.x,vert.y+extrudePts[steps-1].y,extrudePts[steps-1].x+z);}}}}/* Faces */ // Top and bottom faces
buildLidFaces();// Sides faces
buildSideFaces();///// Internal functions
function buildLidFaces(){var start=verticesArray.length/3;if(bevelEnabled){var layer=0;// steps + 1
var offset=vlen*layer;// Bottom faces
for(i=0;i<flen;i++){face=faces[i];f3(face[2]+offset,face[1]+offset,face[0]+offset);}layer=steps+bevelSegments*2;offset=vlen*layer;// Top faces
for(i=0;i<flen;i++){face=faces[i];f3(face[0]+offset,face[1]+offset,face[2]+offset);}}else{// Bottom faces
for(i=0;i<flen;i++){face=faces[i];f3(face[2],face[1],face[0]);}// Top faces
for(i=0;i<flen;i++){face=faces[i];f3(face[0]+vlen*steps,face[1]+vlen*steps,face[2]+vlen*steps);}}scope.addGroup(start,verticesArray.length/3-start,0);}// Create faces for the z-sides of the shape
function buildSideFaces(){var start=verticesArray.length/3;var layeroffset=0;sidewalls(contour,layeroffset);layeroffset+=contour.length;for(h=0,hl=holes.length;h<hl;h++){ahole=holes[h];sidewalls(ahole,layeroffset);//, true
layeroffset+=ahole.length;}scope.addGroup(start,verticesArray.length/3-start,1);}function sidewalls(contour,layeroffset){var j,k;i=contour.length;while(--i>=0){j=i;k=i-1;if(k<0)k=contour.length-1;//console.log('b', i,j, i-1, k,vertices.length);
var s=0,sl=steps+bevelSegments*2;for(s=0;s<sl;s++){var slen1=vlen*s;var slen2=vlen*(s+1);var a=layeroffset+j+slen1,b=layeroffset+k+slen1,c=layeroffset+k+slen2,d=layeroffset+j+slen2;f4(a,b,c,d);}}}function v(x,y,z){placeholder.push(x);placeholder.push(y);placeholder.push(z);}function f3(a,b,c){addVertex(a);addVertex(b);addVertex(c);var nextIndex=verticesArray.length/3;var uvs=uvgen.generateTopUV(scope,verticesArray,nextIndex-3,nextIndex-2,nextIndex-1);addUV(uvs[0]);addUV(uvs[1]);addUV(uvs[2]);}function f4(a,b,c,d){addVertex(a);addVertex(b);addVertex(d);addVertex(b);addVertex(c);addVertex(d);var nextIndex=verticesArray.length/3;var uvs=uvgen.generateSideWallUV(scope,verticesArray,nextIndex-6,nextIndex-3,nextIndex-2,nextIndex-1);addUV(uvs[0]);addUV(uvs[1]);addUV(uvs[3]);addUV(uvs[1]);addUV(uvs[2]);addUV(uvs[3]);}function addVertex(index){verticesArray.push(placeholder[index*3+0]);verticesArray.push(placeholder[index*3+1]);verticesArray.push(placeholder[index*3+2]);}function addUV(vector2){uvArray.push(vector2.x);uvArray.push(vector2.y);}}}ExtrudeBufferGeometry.prototype=Object.create(BufferGeometry.prototype);ExtrudeBufferGeometry.prototype.constructor=ExtrudeBufferGeometry;var WorldUVGenerator={generateTopUV:function(geometry,vertices,indexA,indexB,indexC){var a_x=vertices[indexA*3];var a_y=vertices[indexA*3+1];var b_x=vertices[indexB*3];var b_y=vertices[indexB*3+1];var c_x=vertices[indexC*3];var c_y=vertices[indexC*3+1];return [new Vector2(a_x,a_y),new Vector2(b_x,b_y),new Vector2(c_x,c_y)];},generateSideWallUV:function(geometry,vertices,indexA,indexB,indexC,indexD){var a_x=vertices[indexA*3];var a_y=vertices[indexA*3+1];var a_z=vertices[indexA*3+2];var b_x=vertices[indexB*3];var b_y=vertices[indexB*3+1];var b_z=vertices[indexB*3+2];var c_x=vertices[indexC*3];var c_y=vertices[indexC*3+1];var c_z=vertices[indexC*3+2];var d_x=vertices[indexD*3];var d_y=vertices[indexD*3+1];var d_z=vertices[indexD*3+2];if(Math.abs(a_y-b_y)<0.01){return [new Vector2(a_x,1-a_z),new Vector2(b_x,1-b_z),new Vector2(c_x,1-c_z),new Vector2(d_x,1-d_z)];}else{return [new Vector2(a_y,1-a_z),new Vector2(b_y,1-b_z),new Vector2(c_y,1-c_z),new Vector2(d_y,1-d_z)];}}};/**
* @author zz85 / http://www.lab4games.net/zz85/blog
* @author alteredq / http://alteredqualia.com/
*
* Text = 3D Text
*
* parameters = {
* font: <THREE.Font>, // font
*
* size: <float>, // size of the text
* height: <float>, // thickness to extrude text
* curveSegments: <int>, // number of points on the curves
*
* bevelEnabled: <bool>, // turn on bevel
* bevelThickness: <float>, // how deep into text bevel goes
* bevelSize: <float> // how far from text outline is bevel
* }
*/ // TextGeometry
function TextGeometry(text,parameters){Geometry.call(this);this.type='TextGeometry';this.parameters={text:text,parameters:parameters};this.fromBufferGeometry(new TextBufferGeometry(text,parameters));this.mergeVertices();}TextGeometry.prototype=Object.create(Geometry.prototype);TextGeometry.prototype.constructor=TextGeometry;// TextBufferGeometry
function TextBufferGeometry(text,parameters){parameters=parameters||{};var font=parameters.font;if(!(font&&font.isFont)){console.error('THREE.TextGeometry: font parameter is not an instance of THREE.Font.');return new Geometry();}var shapes=font.generateShapes(text,parameters.size,parameters.curveSegments);// translate parameters to ExtrudeGeometry API
parameters.amount=parameters.height!==undefined?parameters.height:50;// defaults
if(parameters.bevelThickness===undefined)parameters.bevelThickness=10;if(parameters.bevelSize===undefined)parameters.bevelSize=8;if(parameters.bevelEnabled===undefined)parameters.bevelEnabled=false;ExtrudeBufferGeometry.call(this,shapes,parameters);this.type='TextBufferGeometry';}TextBufferGeometry.prototype=Object.create(ExtrudeBufferGeometry.prototype);TextBufferGeometry.prototype.constructor=TextBufferGeometry;/**
* @author mrdoob / http://mrdoob.com/
* @author benaadams / https://twitter.com/ben_a_adams
* @author Mugen87 / https://github.com/Mugen87
*/ // SphereGeometry
function SphereGeometry(radius,widthSegments,heightSegments,phiStart,phiLength,thetaStart,thetaLength){Geometry.call(this);this.type='SphereGeometry';this.parameters={radius:radius,widthSegments:widthSegments,heightSegments:heightSegments,phiStart:phiStart,phiLength:phiLength,thetaStart:thetaStart,thetaLength:thetaLength};this.fromBufferGeometry(new SphereBufferGeometry(radius,widthSegments,heightSegments,phiStart,phiLength,thetaStart,thetaLength));this.mergeVertices();}SphereGeometry.prototype=Object.create(Geometry.prototype);SphereGeometry.prototype.constructor=SphereGeometry;// SphereBufferGeometry
function SphereBufferGeometry(radius,widthSegments,heightSegments,phiStart,phiLength,thetaStart,thetaLength){BufferGeometry.call(this);this.type='SphereBufferGeometry';this.parameters={radius:radius,widthSegments:widthSegments,heightSegments:heightSegments,phiStart:phiStart,phiLength:phiLength,thetaStart:thetaStart,thetaLength:thetaLength};radius=radius||1;widthSegments=Math.max(3,Math.floor(widthSegments)||8);heightSegments=Math.max(2,Math.floor(heightSegments)||6);phiStart=phiStart!==undefined?phiStart:0;phiLength=phiLength!==undefined?phiLength:Math.PI*2;thetaStart=thetaStart!==undefined?thetaStart:0;thetaLength=thetaLength!==undefined?thetaLength:Math.PI;var thetaEnd=thetaStart+thetaLength;var ix,iy;var index=0;var grid=[];var vertex=new Vector3();var normal=new Vector3();// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];// generate vertices, normals and uvs
for(iy=0;iy<=heightSegments;iy++){var verticesRow=[];var v=iy/heightSegments;for(ix=0;ix<=widthSegments;ix++){var u=ix/widthSegments;// vertex
vertex.x=-radius*Math.cos(phiStart+u*phiLength)*Math.sin(thetaStart+v*thetaLength);vertex.y=radius*Math.cos(thetaStart+v*thetaLength);vertex.z=radius*Math.sin(phiStart+u*phiLength)*Math.sin(thetaStart+v*thetaLength);vertices.push(vertex.x,vertex.y,vertex.z);// normal
normal.set(vertex.x,vertex.y,vertex.z).normalize();normals.push(normal.x,normal.y,normal.z);// uv
uvs.push(u,1-v);verticesRow.push(index++);}grid.push(verticesRow);}// indices
for(iy=0;iy<heightSegments;iy++){for(ix=0;ix<widthSegments;ix++){var a=grid[iy][ix+1];var b=grid[iy][ix];var c=grid[iy+1][ix];var d=grid[iy+1][ix+1];if(iy!==0||thetaStart>0)indices.push(a,b,d);if(iy!==heightSegments-1||thetaEnd<Math.PI)indices.push(b,c,d);}}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));}SphereBufferGeometry.prototype=Object.create(BufferGeometry.prototype);SphereBufferGeometry.prototype.constructor=SphereBufferGeometry;/**
* @author Kaleb Murphy
* @author Mugen87 / https://github.com/Mugen87
*/ // RingGeometry
function RingGeometry(innerRadius,outerRadius,thetaSegments,phiSegments,thetaStart,thetaLength){Geometry.call(this);this.type='RingGeometry';this.parameters={innerRadius:innerRadius,outerRadius:outerRadius,thetaSegments:thetaSegments,phiSegments:phiSegments,thetaStart:thetaStart,thetaLength:thetaLength};this.fromBufferGeometry(new RingBufferGeometry(innerRadius,outerRadius,thetaSegments,phiSegments,thetaStart,thetaLength));this.mergeVertices();}RingGeometry.prototype=Object.create(Geometry.prototype);RingGeometry.prototype.constructor=RingGeometry;// RingBufferGeometry
function RingBufferGeometry(innerRadius,outerRadius,thetaSegments,phiSegments,thetaStart,thetaLength){BufferGeometry.call(this);this.type='RingBufferGeometry';this.parameters={innerRadius:innerRadius,outerRadius:outerRadius,thetaSegments:thetaSegments,phiSegments:phiSegments,thetaStart:thetaStart,thetaLength:thetaLength};innerRadius=innerRadius||0.5;outerRadius=outerRadius||1;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;// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];// some helper variables
var segment;var radius=innerRadius;var radiusStep=(outerRadius-innerRadius)/phiSegments;var vertex=new Vector3();var uv=new Vector2();var j,i;// generate vertices, normals and uvs
for(j=0;j<=phiSegments;j++){for(i=0;i<=thetaSegments;i++){// values are generate from the inside of the ring to the outside
segment=thetaStart+i/thetaSegments*thetaLength;// vertex
vertex.x=radius*Math.cos(segment);vertex.y=radius*Math.sin(segment);vertices.push(vertex.x,vertex.y,vertex.z);// normal
normals.push(0,0,1);// uv
uv.x=(vertex.x/outerRadius+1)/2;uv.y=(vertex.y/outerRadius+1)/2;uvs.push(uv.x,uv.y);}// increase the radius for next row of vertices
radius+=radiusStep;}// indices
for(j=0;j<phiSegments;j++){var thetaSegmentLevel=j*(thetaSegments+1);for(i=0;i<thetaSegments;i++){segment=i+thetaSegmentLevel;var a=segment;var b=segment+thetaSegments+1;var c=segment+thetaSegments+2;var d=segment+1;// faces
indices.push(a,b,d);indices.push(b,c,d);}}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));}RingBufferGeometry.prototype=Object.create(BufferGeometry.prototype);RingBufferGeometry.prototype.constructor=RingBufferGeometry;/**
* @author astrodud / http://astrodud.isgreat.org/
* @author zz85 / https://github.com/zz85
* @author bhouston / http://clara.io
* @author Mugen87 / https://github.com/Mugen87
*/ // LatheGeometry
function LatheGeometry(points,segments,phiStart,phiLength){Geometry.call(this);this.type='LatheGeometry';this.parameters={points:points,segments:segments,phiStart:phiStart,phiLength:phiLength};this.fromBufferGeometry(new LatheBufferGeometry(points,segments,phiStart,phiLength));this.mergeVertices();}LatheGeometry.prototype=Object.create(Geometry.prototype);LatheGeometry.prototype.constructor=LatheGeometry;// LatheBufferGeometry
function LatheBufferGeometry(points,segments,phiStart,phiLength){BufferGeometry.call(this);this.type='LatheBufferGeometry';this.parameters={points:points,segments:segments,phiStart:phiStart,phiLength:phiLength};segments=Math.floor(segments)||12;phiStart=phiStart||0;phiLength=phiLength||Math.PI*2;// clamp phiLength so it's in range of [ 0, 2PI ]
phiLength=_Math.clamp(phiLength,0,Math.PI*2);// buffers
var indices=[];var vertices=[];var uvs=[];// helper variables
var base;var inverseSegments=1.0/segments;var vertex=new Vector3();var uv=new Vector2();var i,j;// generate vertices and uvs
for(i=0;i<=segments;i++){var phi=phiStart+i*inverseSegments*phiLength;var sin=Math.sin(phi);var cos=Math.cos(phi);for(j=0;j<=points.length-1;j++){// vertex
vertex.x=points[j].x*sin;vertex.y=points[j].y;vertex.z=points[j].x*cos;vertices.push(vertex.x,vertex.y,vertex.z);// uv
uv.x=i/segments;uv.y=j/(points.length-1);uvs.push(uv.x,uv.y);}}// indices
for(i=0;i<segments;i++){for(j=0;j<points.length-1;j++){base=j+i*points.length;var a=base;var b=base+points.length;var c=base+points.length+1;var d=base+1;// faces
indices.push(a,b,d);indices.push(b,c,d);}}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));// generate normals
this.computeVertexNormals();// if the geometry is closed, we need to average the normals along the seam.
// because the corresponding vertices are identical (but still have different UVs).
if(phiLength===Math.PI*2){var normals=this.attributes.normal.array;var n1=new Vector3();var n2=new Vector3();var n=new Vector3();// this is the buffer offset for the last line of vertices
base=segments*points.length*3;for(i=0,j=0;i<points.length;i++,j+=3){// select the normal of the vertex in the first line
n1.x=normals[j+0];n1.y=normals[j+1];n1.z=normals[j+2];// select the normal of the vertex in the last line
n2.x=normals[base+j+0];n2.y=normals[base+j+1];n2.z=normals[base+j+2];// average normals
n.addVectors(n1,n2).normalize();// assign the new values to both normals
normals[j+0]=normals[base+j+0]=n.x;normals[j+1]=normals[base+j+1]=n.y;normals[j+2]=normals[base+j+2]=n.z;}}}LatheBufferGeometry.prototype=Object.create(BufferGeometry.prototype);LatheBufferGeometry.prototype.constructor=LatheBufferGeometry;/**
* @author jonobr1 / http://jonobr1.com
* @author Mugen87 / https://github.com/Mugen87
*/ // ShapeGeometry
function ShapeGeometry(shapes,curveSegments){Geometry.call(this);this.type='ShapeGeometry';if(typeof curveSegments==='object'){console.warn('THREE.ShapeGeometry: Options parameter has been removed.');curveSegments=curveSegments.curveSegments;}this.parameters={shapes:shapes,curveSegments:curveSegments};this.fromBufferGeometry(new ShapeBufferGeometry(shapes,curveSegments));this.mergeVertices();}ShapeGeometry.prototype=Object.create(Geometry.prototype);ShapeGeometry.prototype.constructor=ShapeGeometry;ShapeGeometry.prototype.toJSON=function(){var data=Geometry.prototype.toJSON.call(this);var shapes=this.parameters.shapes;return toJSON(shapes,data);};// ShapeBufferGeometry
function ShapeBufferGeometry(shapes,curveSegments){BufferGeometry.call(this);this.type='ShapeBufferGeometry';this.parameters={shapes:shapes,curveSegments:curveSegments};curveSegments=curveSegments||12;// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];// helper variables
var groupStart=0;var groupCount=0;// allow single and array values for "shapes" parameter
if(Array.isArray(shapes)===false){addShape(shapes);}else{for(var i=0;i<shapes.length;i++){addShape(shapes[i]);this.addGroup(groupStart,groupCount,i);// enables MultiMaterial support
groupStart+=groupCount;groupCount=0;}}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));// helper functions
function addShape(shape){var i,l,shapeHole;var indexOffset=vertices.length/3;var points=shape.extractPoints(curveSegments);var shapeVertices=points.shape;var shapeHoles=points.holes;// check direction of vertices
if(ShapeUtils.isClockWise(shapeVertices)===false){shapeVertices=shapeVertices.reverse();// also check if holes are in the opposite direction
for(i=0,l=shapeHoles.length;i<l;i++){shapeHole=shapeHoles[i];if(ShapeUtils.isClockWise(shapeHole)===true){shapeHoles[i]=shapeHole.reverse();}}}var faces=ShapeUtils.triangulateShape(shapeVertices,shapeHoles);// join vertices of inner and outer paths to a single array
for(i=0,l=shapeHoles.length;i<l;i++){shapeHole=shapeHoles[i];shapeVertices=shapeVertices.concat(shapeHole);}// vertices, normals, uvs
for(i=0,l=shapeVertices.length;i<l;i++){var vertex=shapeVertices[i];vertices.push(vertex.x,vertex.y,0);normals.push(0,0,1);uvs.push(vertex.x,vertex.y);// world uvs
}// incides
for(i=0,l=faces.length;i<l;i++){var face=faces[i];var a=face[0]+indexOffset;var b=face[1]+indexOffset;var c=face[2]+indexOffset;indices.push(a,b,c);groupCount+=3;}}}ShapeBufferGeometry.prototype=Object.create(BufferGeometry.prototype);ShapeBufferGeometry.prototype.constructor=ShapeBufferGeometry;ShapeBufferGeometry.prototype.toJSON=function(){var data=BufferGeometry.prototype.toJSON.call(this);var shapes=this.parameters.shapes;return toJSON(shapes,data);};//
function toJSON(shapes,data){data.shapes=[];if(Array.isArray(shapes)){for(var i=0,l=shapes.length;i<l;i++){var shape=shapes[i];data.shapes.push(shape.uuid);}}else{data.shapes.push(shapes.uuid);}return data;}/**
* @author WestLangley / http://github.com/WestLangley
* @author Mugen87 / https://github.com/Mugen87
*/function EdgesGeometry(geometry,thresholdAngle){BufferGeometry.call(this);this.type='EdgesGeometry';this.parameters={thresholdAngle:thresholdAngle};thresholdAngle=thresholdAngle!==undefined?thresholdAngle:1;// buffer
var vertices=[];// helper variables
var thresholdDot=Math.cos(_Math.DEG2RAD*thresholdAngle);var edge=[0,0],edges={},edge1,edge2;var key,keys=['a','b','c'];// prepare source geometry
var geometry2;if(geometry.isBufferGeometry){geometry2=new Geometry();geometry2.fromBufferGeometry(geometry);}else{geometry2=geometry.clone();}geometry2.mergeVertices();geometry2.computeFaceNormals();var sourceVertices=geometry2.vertices;var faces=geometry2.faces;// now create a data structure where each entry represents an edge with its adjoining faces
for(var i=0,l=faces.length;i<l;i++){var face=faces[i];for(var j=0;j<3;j++){edge1=face[keys[j]];edge2=face[keys[(j+1)%3]];edge[0]=Math.min(edge1,edge2);edge[1]=Math.max(edge1,edge2);key=edge[0]+','+edge[1];if(edges[key]===undefined){edges[key]={index1:edge[0],index2:edge[1],face1:i,face2:undefined};}else{edges[key].face2=i;}}}// generate vertices
for(key in edges){var e=edges[key];// an edge is only rendered if the angle (in degrees) between the face normals of the adjoining faces exceeds this value. default = 1 degree.
if(e.face2===undefined||faces[e.face1].normal.dot(faces[e.face2].normal)<=thresholdDot){var vertex=sourceVertices[e.index1];vertices.push(vertex.x,vertex.y,vertex.z);vertex=sourceVertices[e.index2];vertices.push(vertex.x,vertex.y,vertex.z);}}// build geometry
this.addAttribute('position',new Float32BufferAttribute(vertices,3));}EdgesGeometry.prototype=Object.create(BufferGeometry.prototype);EdgesGeometry.prototype.constructor=EdgesGeometry;/**
* @author mrdoob / http://mrdoob.com/
* @author Mugen87 / https://github.com/Mugen87
*/ // CylinderGeometry
function CylinderGeometry(radiusTop,radiusBottom,height,radialSegments,heightSegments,openEnded,thetaStart,thetaLength){Geometry.call(this);this.type='CylinderGeometry';this.parameters={radiusTop:radiusTop,radiusBottom:radiusBottom,height:height,radialSegments:radialSegments,heightSegments:heightSegments,openEnded:openEnded,thetaStart:thetaStart,thetaLength:thetaLength};this.fromBufferGeometry(new CylinderBufferGeometry(radiusTop,radiusBottom,height,radialSegments,heightSegments,openEnded,thetaStart,thetaLength));this.mergeVertices();}CylinderGeometry.prototype=Object.create(Geometry.prototype);CylinderGeometry.prototype.constructor=CylinderGeometry;// CylinderBufferGeometry
function CylinderBufferGeometry(radiusTop,radiusBottom,height,radialSegments,heightSegments,openEnded,thetaStart,thetaLength){BufferGeometry.call(this);this.type='CylinderBufferGeometry';this.parameters={radiusTop:radiusTop,radiusBottom:radiusBottom,height:height,radialSegments:radialSegments,heightSegments:heightSegments,openEnded:openEnded,thetaStart:thetaStart,thetaLength:thetaLength};var scope=this;radiusTop=radiusTop!==undefined?radiusTop:1;radiusBottom=radiusBottom!==undefined?radiusBottom:1;height=height||1;radialSegments=Math.floor(radialSegments)||8;heightSegments=Math.floor(heightSegments)||1;openEnded=openEnded!==undefined?openEnded:false;thetaStart=thetaStart!==undefined?thetaStart:0.0;thetaLength=thetaLength!==undefined?thetaLength:Math.PI*2;// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];// helper variables
var index=0;var indexArray=[];var halfHeight=height/2;var groupStart=0;// generate geometry
generateTorso();if(openEnded===false){if(radiusTop>0)generateCap(true);if(radiusBottom>0)generateCap(false);}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));function generateTorso(){var x,y;var normal=new Vector3();var vertex=new Vector3();var groupCount=0;// this will be used to calculate the normal
var slope=(radiusBottom-radiusTop)/height;// generate vertices, normals and uvs
for(y=0;y<=heightSegments;y++){var indexRow=[];var v=y/heightSegments;// calculate the radius of the current row
var radius=v*(radiusBottom-radiusTop)+radiusTop;for(x=0;x<=radialSegments;x++){var u=x/radialSegments;var theta=u*thetaLength+thetaStart;var sinTheta=Math.sin(theta);var cosTheta=Math.cos(theta);// vertex
vertex.x=radius*sinTheta;vertex.y=-v*height+halfHeight;vertex.z=radius*cosTheta;vertices.push(vertex.x,vertex.y,vertex.z);// normal
normal.set(sinTheta,slope,cosTheta).normalize();normals.push(normal.x,normal.y,normal.z);// uv
uvs.push(u,1-v);// save index of vertex in respective row
indexRow.push(index++);}// now save vertices of the row in our index array
indexArray.push(indexRow);}// generate indices
for(x=0;x<radialSegments;x++){for(y=0;y<heightSegments;y++){// we use the index array to access the correct indices
var a=indexArray[y][x];var b=indexArray[y+1][x];var c=indexArray[y+1][x+1];var d=indexArray[y][x+1];// faces
indices.push(a,b,d);indices.push(b,c,d);// update group counter
groupCount+=6;}}// add a group to the geometry. this will ensure multi material support
scope.addGroup(groupStart,groupCount,0);// calculate new start value for groups
groupStart+=groupCount;}function generateCap(top){var x,centerIndexStart,centerIndexEnd;var uv=new Vector2();var vertex=new Vector3();var groupCount=0;var radius=top===true?radiusTop:radiusBottom;var sign=top===true?1:-1;// save the index of the first center vertex
centerIndexStart=index;// first we generate the center vertex data of the cap.
// because the geometry needs one set of uvs per face,
// we must generate a center vertex per face/segment
for(x=1;x<=radialSegments;x++){// vertex
vertices.push(0,halfHeight*sign,0);// normal
normals.push(0,sign,0);// uv
uvs.push(0.5,0.5);// increase index
index++;}// save the index of the last center vertex
centerIndexEnd=index;// now we generate the surrounding vertices, normals and uvs
for(x=0;x<=radialSegments;x++){var u=x/radialSegments;var theta=u*thetaLength+thetaStart;var cosTheta=Math.cos(theta);var sinTheta=Math.sin(theta);// vertex
vertex.x=radius*sinTheta;vertex.y=halfHeight*sign;vertex.z=radius*cosTheta;vertices.push(vertex.x,vertex.y,vertex.z);// normal
normals.push(0,sign,0);// uv
uv.x=cosTheta*0.5+0.5;uv.y=sinTheta*0.5*sign+0.5;uvs.push(uv.x,uv.y);// increase index
index++;}// generate indices
for(x=0;x<radialSegments;x++){var c=centerIndexStart+x;var i=centerIndexEnd+x;if(top===true){// face top
indices.push(i,i+1,c);}else{// face bottom
indices.push(i+1,i,c);}groupCount+=3;}// add a group to the geometry. this will ensure multi material support
scope.addGroup(groupStart,groupCount,top===true?1:2);// calculate new start value for groups
groupStart+=groupCount;}}CylinderBufferGeometry.prototype=Object.create(BufferGeometry.prototype);CylinderBufferGeometry.prototype.constructor=CylinderBufferGeometry;/**
* @author abelnation / http://github.com/abelnation
*/ // ConeGeometry
function ConeGeometry(radius,height,radialSegments,heightSegments,openEnded,thetaStart,thetaLength){CylinderGeometry.call(this,0,radius,height,radialSegments,heightSegments,openEnded,thetaStart,thetaLength);this.type='ConeGeometry';this.parameters={radius:radius,height:height,radialSegments:radialSegments,heightSegments:heightSegments,openEnded:openEnded,thetaStart:thetaStart,thetaLength:thetaLength};}ConeGeometry.prototype=Object.create(CylinderGeometry.prototype);ConeGeometry.prototype.constructor=ConeGeometry;// ConeBufferGeometry
function ConeBufferGeometry(radius,height,radialSegments,heightSegments,openEnded,thetaStart,thetaLength){CylinderBufferGeometry.call(this,0,radius,height,radialSegments,heightSegments,openEnded,thetaStart,thetaLength);this.type='ConeBufferGeometry';this.parameters={radius:radius,height:height,radialSegments:radialSegments,heightSegments:heightSegments,openEnded:openEnded,thetaStart:thetaStart,thetaLength:thetaLength};}ConeBufferGeometry.prototype=Object.create(CylinderBufferGeometry.prototype);ConeBufferGeometry.prototype.constructor=ConeBufferGeometry;/**
* @author benaadams / https://twitter.com/ben_a_adams
* @author Mugen87 / https://github.com/Mugen87
* @author hughes
*/ // CircleGeometry
function CircleGeometry(radius,segments,thetaStart,thetaLength){Geometry.call(this);this.type='CircleGeometry';this.parameters={radius:radius,segments:segments,thetaStart:thetaStart,thetaLength:thetaLength};this.fromBufferGeometry(new CircleBufferGeometry(radius,segments,thetaStart,thetaLength));this.mergeVertices();}CircleGeometry.prototype=Object.create(Geometry.prototype);CircleGeometry.prototype.constructor=CircleGeometry;// CircleBufferGeometry
function CircleBufferGeometry(radius,segments,thetaStart,thetaLength){BufferGeometry.call(this);this.type='CircleBufferGeometry';this.parameters={radius:radius,segments:segments,thetaStart:thetaStart,thetaLength:thetaLength};radius=radius||1;segments=segments!==undefined?Math.max(3,segments):8;thetaStart=thetaStart!==undefined?thetaStart:0;thetaLength=thetaLength!==undefined?thetaLength:Math.PI*2;// buffers
var indices=[];var vertices=[];var normals=[];var uvs=[];// helper variables
var i,s;var vertex=new Vector3();var uv=new Vector2();// center point
vertices.push(0,0,0);normals.push(0,0,1);uvs.push(0.5,0.5);for(s=0,i=3;s<=segments;s++,i+=3){var segment=thetaStart+s/segments*thetaLength;// vertex
vertex.x=radius*Math.cos(segment);vertex.y=radius*Math.sin(segment);vertices.push(vertex.x,vertex.y,vertex.z);// normal
normals.push(0,0,1);// uvs
uv.x=(vertices[i]/radius+1)/2;uv.y=(vertices[i+1]/radius+1)/2;uvs.push(uv.x,uv.y);}// indices
for(i=1;i<=segments;i++){indices.push(i,i+1,0);}// build geometry
this.setIndex(indices);this.addAttribute('position',new Float32BufferAttribute(vertices,3));this.addAttribute('normal',new Float32BufferAttribute(normals,3));this.addAttribute('uv',new Float32BufferAttribute(uvs,2));}CircleBufferGeometry.prototype=Object.create(BufferGeometry.prototype);CircleBufferGeometry.prototype.constructor=CircleBufferGeometry;var Geometries=Object.freeze({WireframeGeometry:WireframeGeometry,ParametricGeometry:ParametricGeometry,ParametricBufferGeometry:ParametricBufferGeometry,TetrahedronGeometry:TetrahedronGeometry,TetrahedronBufferGeometry:TetrahedronBufferGeometry,OctahedronGeometry:OctahedronGeometry,OctahedronBufferGeometry:OctahedronBufferGeometry,IcosahedronGeometry:IcosahedronGeometry,IcosahedronBufferGeometry:IcosahedronBufferGeometry,DodecahedronGeometry:DodecahedronGeometry,DodecahedronBufferGeometry:DodecahedronBufferGeometry,PolyhedronGeometry:PolyhedronGeometry,PolyhedronBufferGeometry:PolyhedronBufferGeometry,TubeGeometry:TubeGeometry,TubeBufferGeometry:TubeBufferGeometry,TorusKnotGeometry:TorusKnotGeometry,TorusKnotBufferGeometry:TorusKnotBufferGeometry,TorusGeometry:TorusGeometry,TorusBufferGeometry:TorusBufferGeometry,TextGeometry:TextGeometry,TextBufferGeometry:TextBufferGeometry,SphereGeometry:SphereGeometry,SphereBufferGeometry:SphereBufferGeometry,RingGeometry:RingGeometry,RingBufferGeometry:RingBufferGeometry,PlaneGeometry:PlaneGeometry,PlaneBufferGeometry:PlaneBufferGeometry,LatheGeometry:LatheGeometry,LatheBufferGeometry:LatheBufferGeometry,ShapeGeometry:ShapeGeometry,ShapeBufferGeometry:ShapeBufferGeometry,ExtrudeGeometry:ExtrudeGeometry,ExtrudeBufferGeometry:ExtrudeBufferGeometry,EdgesGeometry:EdgesGeometry,ConeGeometry:ConeGeometry,ConeBufferGeometry:ConeBufferGeometry,CylinderGeometry:CylinderGeometry,CylinderBufferGeometry:CylinderBufferGeometry,CircleGeometry:CircleGeometry,CircleBufferGeometry:CircleBufferGeometry,BoxGeometry:BoxGeometry,BoxBufferGeometry:BoxBufferGeometry});/**
* @author mrdoob / http://mrdoob.com/
*
* parameters = {
* color: <THREE.Color>
* }
*/function ShadowMaterial(parameters){Material.call(this);this.type='ShadowMaterial';this.color=new Color(0x000000);this.transparent=true;this.setValues(parameters);}ShadowMaterial.prototype=Object.create(Material.prototype);ShadowMaterial.prototype.constructor=ShadowMaterial;ShadowMaterial.prototype.isShadowMaterial=true;ShadowMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.color.copy(source.color);return this;};/**
* @author mrdoob / http://mrdoob.com/
*/function RawShaderMaterial(parameters){ShaderMaterial.call(this,parameters);this.type='RawShaderMaterial';}RawShaderMaterial.prototype=Object.create(ShaderMaterial.prototype);RawShaderMaterial.prototype.constructor=RawShaderMaterial;RawShaderMaterial.prototype.isRawShaderMaterial=true;/**
* @author WestLangley / http://github.com/WestLangley
*
* parameters = {
* color: <hex>,
* roughness: <float>,
* metalness: <float>,
* opacity: <float>,
*
* map: new THREE.Texture( <Image> ),
*
* lightMap: new THREE.Texture( <Image> ),
* lightMapIntensity: <float>
*
* aoMap: new THREE.Texture( <Image> ),
* aoMapIntensity: <float>
*
* emissive: <hex>,
* emissiveIntensity: <float>
* emissiveMap: new THREE.Texture( <Image> ),
*
* bumpMap: new THREE.Texture( <Image> ),
* bumpScale: <float>,
*
* normalMap: new THREE.Texture( <Image> ),
* normalScale: <Vector2>,
*
* displacementMap: new THREE.Texture( <Image> ),
* displacementScale: <float>,
* displacementBias: <float>,
*
* roughnessMap: new THREE.Texture( <Image> ),
*
* metalnessMap: new THREE.Texture( <Image> ),
*
* alphaMap: new THREE.Texture( <Image> ),
*
* envMap: new THREE.CubeTexture( [posx, negx, posy, negy, posz, negz] ),
* envMapIntensity: <float>
*
* refractionRatio: <float>,
*
* wireframe: <boolean>,
* wireframeLinewidth: <float>,
*
* skinning: <bool>,
* morphTargets: <bool>,
* morphNormals: <bool>
* }
*/function MeshStandardMaterial(parameters){Material.call(this);this.defines={'STANDARD':''};this.type='MeshStandardMaterial';this.color=new Color(0xffffff);// diffuse
this.roughness=0.5;this.metalness=0.5;this.map=null;this.lightMap=null;this.lightMapIntensity=1.0;this.aoMap=null;this.aoMapIntensity=1.0;this.emissive=new Color(0x000000);this.emissiveIntensity=1.0;this.emissiveMap=null;this.bumpMap=null;this.bumpScale=1;this.normalMap=null;this.normalScale=new Vector2(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.roughnessMap=null;this.metalnessMap=null;this.alphaMap=null;this.envMap=null;this.envMapIntensity=1.0;this.refractionRatio=0.98;this.wireframe=false;this.wireframeLinewidth=1;this.wireframeLinecap='round';this.wireframeLinejoin='round';this.skinning=false;this.morphTargets=false;this.morphNormals=false;this.setValues(parameters);}MeshStandardMaterial.prototype=Object.create(Material.prototype);MeshStandardMaterial.prototype.constructor=MeshStandardMaterial;MeshStandardMaterial.prototype.isMeshStandardMaterial=true;MeshStandardMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.defines={'STANDARD':''};this.color.copy(source.color);this.roughness=source.roughness;this.metalness=source.metalness;this.map=source.map;this.lightMap=source.lightMap;this.lightMapIntensity=source.lightMapIntensity;this.aoMap=source.aoMap;this.aoMapIntensity=source.aoMapIntensity;this.emissive.copy(source.emissive);this.emissiveMap=source.emissiveMap;this.emissiveIntensity=source.emissiveIntensity;this.bumpMap=source.bumpMap;this.bumpScale=source.bumpScale;this.normalMap=source.normalMap;this.normalScale.copy(source.normalScale);this.displacementMap=source.displacementMap;this.displacementScale=source.displacementScale;this.displacementBias=source.displacementBias;this.roughnessMap=source.roughnessMap;this.metalnessMap=source.metalnessMap;this.alphaMap=source.alphaMap;this.envMap=source.envMap;this.envMapIntensity=source.envMapIntensity;this.refractionRatio=source.refractionRatio;this.wireframe=source.wireframe;this.wireframeLinewidth=source.wireframeLinewidth;this.wireframeLinecap=source.wireframeLinecap;this.wireframeLinejoin=source.wireframeLinejoin;this.skinning=source.skinning;this.morphTargets=source.morphTargets;this.morphNormals=source.morphNormals;return this;};/**
* @author WestLangley / http://github.com/WestLangley
*
* parameters = {
* reflectivity: <float>
* }
*/function MeshPhysicalMaterial(parameters){MeshStandardMaterial.call(this);this.defines={'PHYSICAL':''};this.type='MeshPhysicalMaterial';this.reflectivity=0.5;// maps to F0 = 0.04
this.clearCoat=0.0;this.clearCoatRoughness=0.0;this.setValues(parameters);}MeshPhysicalMaterial.prototype=Object.create(MeshStandardMaterial.prototype);MeshPhysicalMaterial.prototype.constructor=MeshPhysicalMaterial;MeshPhysicalMaterial.prototype.isMeshPhysicalMaterial=true;MeshPhysicalMaterial.prototype.copy=function(source){MeshStandardMaterial.prototype.copy.call(this,source);this.defines={'PHYSICAL':''};this.reflectivity=source.reflectivity;this.clearCoat=source.clearCoat;this.clearCoatRoughness=source.clearCoatRoughness;return this;};/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*
* parameters = {
* color: <hex>,
* specular: <hex>,
* shininess: <float>,
* opacity: <float>,
*
* map: new THREE.Texture( <Image> ),
*
* lightMap: new THREE.Texture( <Image> ),
* lightMapIntensity: <float>
*
* aoMap: new THREE.Texture( <Image> ),
* aoMapIntensity: <float>
*
* emissive: <hex>,
* emissiveIntensity: <float>
* emissiveMap: new THREE.Texture( <Image> ),
*
* bumpMap: new THREE.Texture( <Image> ),
* bumpScale: <float>,
*
* normalMap: new THREE.Texture( <Image> ),
* normalScale: <Vector2>,
*
* displacementMap: new THREE.Texture( <Image> ),
* displacementScale: <float>,
* displacementBias: <float>,
*
* specularMap: new THREE.Texture( <Image> ),
*
* alphaMap: new THREE.Texture( <Image> ),
*
* envMap: new THREE.CubeTexture( [posx, negx, posy, negy, posz, negz] ),
* combine: THREE.Multiply,
* reflectivity: <float>,
* refractionRatio: <float>,
*
* wireframe: <boolean>,
* wireframeLinewidth: <float>,
*
* skinning: <bool>,
* morphTargets: <bool>,
* morphNormals: <bool>
* }
*/function MeshPhongMaterial(parameters){Material.call(this);this.type='MeshPhongMaterial';this.color=new Color(0xffffff);// diffuse
this.specular=new Color(0x111111);this.shininess=30;this.map=null;this.lightMap=null;this.lightMapIntensity=1.0;this.aoMap=null;this.aoMapIntensity=1.0;this.emissive=new Color(0x000000);this.emissiveIntensity=1.0;this.emissiveMap=null;this.bumpMap=null;this.bumpScale=1;this.normalMap=null;this.normalScale=new Vector2(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.specularMap=null;this.alphaMap=null;this.envMap=null;this.combine=MultiplyOperation;this.reflectivity=1;this.refractionRatio=0.98;this.wireframe=false;this.wireframeLinewidth=1;this.wireframeLinecap='round';this.wireframeLinejoin='round';this.skinning=false;this.morphTargets=false;this.morphNormals=false;this.setValues(parameters);}MeshPhongMaterial.prototype=Object.create(Material.prototype);MeshPhongMaterial.prototype.constructor=MeshPhongMaterial;MeshPhongMaterial.prototype.isMeshPhongMaterial=true;MeshPhongMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.color.copy(source.color);this.specular.copy(source.specular);this.shininess=source.shininess;this.map=source.map;this.lightMap=source.lightMap;this.lightMapIntensity=source.lightMapIntensity;this.aoMap=source.aoMap;this.aoMapIntensity=source.aoMapIntensity;this.emissive.copy(source.emissive);this.emissiveMap=source.emissiveMap;this.emissiveIntensity=source.emissiveIntensity;this.bumpMap=source.bumpMap;this.bumpScale=source.bumpScale;this.normalMap=source.normalMap;this.normalScale.copy(source.normalScale);this.displacementMap=source.displacementMap;this.displacementScale=source.displacementScale;this.displacementBias=source.displacementBias;this.specularMap=source.specularMap;this.alphaMap=source.alphaMap;this.envMap=source.envMap;this.combine=source.combine;this.reflectivity=source.reflectivity;this.refractionRatio=source.refractionRatio;this.wireframe=source.wireframe;this.wireframeLinewidth=source.wireframeLinewidth;this.wireframeLinecap=source.wireframeLinecap;this.wireframeLinejoin=source.wireframeLinejoin;this.skinning=source.skinning;this.morphTargets=source.morphTargets;this.morphNormals=source.morphNormals;return this;};/**
* @author takahirox / http://github.com/takahirox
*
* parameters = {
* gradientMap: new THREE.Texture( <Image> )
* }
*/function MeshToonMaterial(parameters){MeshPhongMaterial.call(this);this.defines={'TOON':''};this.type='MeshToonMaterial';this.gradientMap=null;this.setValues(parameters);}MeshToonMaterial.prototype=Object.create(MeshPhongMaterial.prototype);MeshToonMaterial.prototype.constructor=MeshToonMaterial;MeshToonMaterial.prototype.isMeshToonMaterial=true;MeshToonMaterial.prototype.copy=function(source){MeshPhongMaterial.prototype.copy.call(this,source);this.gradientMap=source.gradientMap;return this;};/**
* @author mrdoob / http://mrdoob.com/
* @author WestLangley / http://github.com/WestLangley
*
* parameters = {
* opacity: <float>,
*
* bumpMap: new THREE.Texture( <Image> ),
* bumpScale: <float>,
*
* normalMap: new THREE.Texture( <Image> ),
* normalScale: <Vector2>,
*
* displacementMap: new THREE.Texture( <Image> ),
* displacementScale: <float>,
* displacementBias: <float>,
*
* wireframe: <boolean>,
* wireframeLinewidth: <float>
*
* skinning: <bool>,
* morphTargets: <bool>,
* morphNormals: <bool>
* }
*/function MeshNormalMaterial(parameters){Material.call(this);this.type='MeshNormalMaterial';this.bumpMap=null;this.bumpScale=1;this.normalMap=null;this.normalScale=new Vector2(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.wireframe=false;this.wireframeLinewidth=1;this.fog=false;this.lights=false;this.skinning=false;this.morphTargets=false;this.morphNormals=false;this.setValues(parameters);}MeshNormalMaterial.prototype=Object.create(Material.prototype);MeshNormalMaterial.prototype.constructor=MeshNormalMaterial;MeshNormalMaterial.prototype.isMeshNormalMaterial=true;MeshNormalMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.bumpMap=source.bumpMap;this.bumpScale=source.bumpScale;this.normalMap=source.normalMap;this.normalScale.copy(source.normalScale);this.displacementMap=source.displacementMap;this.displacementScale=source.displacementScale;this.displacementBias=source.displacementBias;this.wireframe=source.wireframe;this.wireframeLinewidth=source.wireframeLinewidth;this.skinning=source.skinning;this.morphTargets=source.morphTargets;this.morphNormals=source.morphNormals;return this;};/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*
* parameters = {
* color: <hex>,
* opacity: <float>,
*
* map: new THREE.Texture( <Image> ),
*
* lightMap: new THREE.Texture( <Image> ),
* lightMapIntensity: <float>
*
* aoMap: new THREE.Texture( <Image> ),
* aoMapIntensity: <float>
*
* emissive: <hex>,
* emissiveIntensity: <float>
* emissiveMap: new THREE.Texture( <Image> ),
*
* specularMap: new THREE.Texture( <Image> ),
*
* alphaMap: new THREE.Texture( <Image> ),
*
* envMap: new THREE.CubeTexture( [posx, negx, posy, negy, posz, negz] ),
* combine: THREE.Multiply,
* reflectivity: <float>,
* refractionRatio: <float>,
*
* wireframe: <boolean>,
* wireframeLinewidth: <float>,
*
* skinning: <bool>,
* morphTargets: <bool>,
* morphNormals: <bool>
* }
*/function MeshLambertMaterial(parameters){Material.call(this);this.type='MeshLambertMaterial';this.color=new Color(0xffffff);// diffuse
this.map=null;this.lightMap=null;this.lightMapIntensity=1.0;this.aoMap=null;this.aoMapIntensity=1.0;this.emissive=new Color(0x000000);this.emissiveIntensity=1.0;this.emissiveMap=null;this.specularMap=null;this.alphaMap=null;this.envMap=null;this.combine=MultiplyOperation;this.reflectivity=1;this.refractionRatio=0.98;this.wireframe=false;this.wireframeLinewidth=1;this.wireframeLinecap='round';this.wireframeLinejoin='round';this.skinning=false;this.morphTargets=false;this.morphNormals=false;this.setValues(parameters);}MeshLambertMaterial.prototype=Object.create(Material.prototype);MeshLambertMaterial.prototype.constructor=MeshLambertMaterial;MeshLambertMaterial.prototype.isMeshLambertMaterial=true;MeshLambertMaterial.prototype.copy=function(source){Material.prototype.copy.call(this,source);this.color.copy(source.color);this.map=source.map;this.lightMap=source.lightMap;this.lightMapIntensity=source.lightMapIntensity;this.aoMap=source.aoMap;this.aoMapIntensity=source.aoMapIntensity;this.emissive.copy(source.emissive);this.emissiveMap=source.emissiveMap;this.emissiveIntensity=source.emissiveIntensity;this.specularMap=source.specularMap;this.alphaMap=source.alphaMap;this.envMap=source.envMap;this.combine=source.combine;this.reflectivity=source.reflectivity;this.refractionRatio=source.refractionRatio;this.wireframe=source.wireframe;this.wireframeLinewidth=source.wireframeLinewidth;this.wireframeLinecap=source.wireframeLinecap;this.wireframeLinejoin=source.wireframeLinejoin;this.skinning=source.skinning;this.morphTargets=source.morphTargets;this.morphNormals=source.morphNormals;return this;};/**
* @author alteredq / http://alteredqualia.com/
*
* parameters = {
* color: <hex>,
* opacity: <float>,
*
* linewidth: <float>,
*
* scale: <float>,
* dashSize: <float>,
* gapSize: <float>
* }
*/function LineDashedMaterial(parameters){LineBasicMaterial.call(this);this.type='LineDashedMaterial';this.scale=1;this.dashSize=3;this.gapSize=1;this.setValues(parameters);}LineDashedMaterial.prototype=Object.create(LineBasicMaterial.prototype);LineDashedMaterial.prototype.constructor=LineDashedMaterial;LineDashedMaterial.prototype.isLineDashedMaterial=true;LineDashedMaterial.prototype.copy=function(source){LineBasicMaterial.prototype.copy.call(this,source);this.scale=source.scale;this.dashSize=source.dashSize;this.gapSize=source.gapSize;return this;};var Materials=Object.freeze({ShadowMaterial:ShadowMaterial,SpriteMaterial:SpriteMaterial,RawShaderMaterial:RawShaderMaterial,ShaderMaterial:ShaderMaterial,PointsMaterial:PointsMaterial,MeshPhysicalMaterial:MeshPhysicalMaterial,MeshStandardMaterial:MeshStandardMaterial,MeshPhongMaterial:MeshPhongMaterial,MeshToonMaterial:MeshToonMaterial,MeshNormalMaterial:MeshNormalMaterial,MeshLambertMaterial:MeshLambertMaterial,MeshDepthMaterial:MeshDepthMaterial,MeshDistanceMaterial:MeshDistanceMaterial,MeshBasicMaterial:MeshBasicMaterial,LineDashedMaterial:LineDashedMaterial,LineBasicMaterial:LineBasicMaterial,Material:Material});/**
* @author mrdoob / http://mrdoob.com/
*/var Cache={enabled:false,files:{},add:function(key,file){if(this.enabled===false)return;// console.log( 'THREE.Cache', 'Adding key:', key );
this.files[key]=file;},get:function(key){if(this.enabled===false)return;// console.log( 'THREE.Cache', 'Checking key:', key );
return this.files[key];},remove:function(key){delete this.files[key];},clear:function(){this.files={};}};/**
* @author mrdoob / http://mrdoob.com/
*/function LoadingManager(onLoad,onProgress,onError){var scope=this;var isLoading=false;var itemsLoaded=0;var itemsTotal=0;var urlModifier=undefined;this.onStart=undefined;this.onLoad=onLoad;this.onProgress=onProgress;this.onError=onError;this.itemStart=function(url){itemsTotal++;if(isLoading===false){if(scope.onStart!==undefined){scope.onStart(url,itemsLoaded,itemsTotal);}}isLoading=true;};this.itemEnd=function(url){itemsLoaded++;if(scope.onProgress!==undefined){scope.onProgress(url,itemsLoaded,itemsTotal);}if(itemsLoaded===itemsTotal){isLoading=false;if(scope.onLoad!==undefined){scope.onLoad();}}};this.itemError=function(url){if(scope.onError!==undefined){scope.onError(url);}};this.resolveURL=function(url){if(urlModifier){return urlModifier(url);}return url;};this.setURLModifier=function(transform){urlModifier=transform;return this;};}var DefaultLoadingManager=new LoadingManager();/**
* @author mrdoob / http://mrdoob.com/
*/var loading={};function FileLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;}Object.assign(FileLoader.prototype,{load:function(url,onLoad,onProgress,onError){if(url===undefined)url='';if(this.path!==undefined)url=this.path+url;url=this.manager.resolveURL(url);var scope=this;var cached=Cache.get(url);if(cached!==undefined){scope.manager.itemStart(url);setTimeout(function(){if(onLoad)onLoad(cached);scope.manager.itemEnd(url);},0);return cached;}// Check if request is duplicate
if(loading[url]!==undefined){loading[url].push({onLoad:onLoad,onProgress:onProgress,onError:onError});return;}// Check for data: URI
var dataUriRegex=/^data:(.*?)(;base64)?,(.*)$/;var dataUriRegexResult=url.match(dataUriRegex);// Safari can not handle Data URIs through XMLHttpRequest so process manually
if(dataUriRegexResult){var mimeType=dataUriRegexResult[1];var isBase64=!!dataUriRegexResult[2];var data=dataUriRegexResult[3];data=window.decodeURIComponent(data);if(isBase64)data=window.atob(data);try{var response;var responseType=(this.responseType||'').toLowerCase();switch(responseType){case'arraybuffer':case'blob':var view=new Uint8Array(data.length);for(var i=0;i<data.length;i++){view[i]=data.charCodeAt(i);}if(responseType==='blob'){response=new Blob([view.buffer],{type:mimeType});}else{response=view.buffer;}break;case'document':var parser=new DOMParser();response=parser.parseFromString(data,mimeType);break;case'json':response=JSON.parse(data);break;default:// 'text' or other
response=data;break;}// Wait for next browser tick like standard XMLHttpRequest event dispatching does
window.setTimeout(function(){if(onLoad)onLoad(response);scope.manager.itemEnd(url);},0);}catch(error){// Wait for next browser tick like standard XMLHttpRequest event dispatching does
window.setTimeout(function(){if(onError)onError(error);scope.manager.itemEnd(url);scope.manager.itemError(url);},0);}}else{// Initialise array for duplicate requests
loading[url]=[];loading[url].push({onLoad:onLoad,onProgress:onProgress,onError:onError});var request=new XMLHttpRequest();request.open('GET',url,true);request.addEventListener('load',function(event){var response=this.response;Cache.add(url,response);var callbacks=loading[url];delete loading[url];if(this.status===200){for(var i=0,il=callbacks.length;i<il;i++){var callback=callbacks[i];if(callback.onLoad)callback.onLoad(response);}scope.manager.itemEnd(url);}else if(this.status===0){// Some browsers return HTTP Status 0 when using non-http protocol
// e.g. 'file://' or 'data://'. Handle as success.
console.warn('THREE.FileLoader: HTTP Status 0 received.');for(var i=0,il=callbacks.length;i<il;i++){var callback=callbacks[i];if(callback.onLoad)callback.onLoad(response);}scope.manager.itemEnd(url);}else{for(var i=0,il=callbacks.length;i<il;i++){var callback=callbacks[i];if(callback.onError)callback.onError(event);}scope.manager.itemEnd(url);scope.manager.itemError(url);}},false);request.addEventListener('progress',function(event){var callbacks=loading[url];for(var i=0,il=callbacks.length;i<il;i++){var callback=callbacks[i];if(callback.onProgress)callback.onProgress(event);}},false);request.addEventListener('error',function(event){var callbacks=loading[url];delete loading[url];for(var i=0,il=callbacks.length;i<il;i++){var callback=callbacks[i];if(callback.onError)callback.onError(event);}scope.manager.itemEnd(url);scope.manager.itemError(url);},false);if(this.responseType!==undefined)request.responseType=this.responseType;if(this.withCredentials!==undefined)request.withCredentials=this.withCredentials;if(request.overrideMimeType)request.overrideMimeType(this.mimeType!==undefined?this.mimeType:'text/plain');for(var header in this.requestHeader){request.setRequestHeader(header,this.requestHeader[header]);}request.send(null);}scope.manager.itemStart(url);return request;},setPath:function(value){this.path=value;return this;},setResponseType:function(value){this.responseType=value;return this;},setWithCredentials:function(value){this.withCredentials=value;return this;},setMimeType:function(value){this.mimeType=value;return this;},setRequestHeader:function(value){this.requestHeader=value;return this;}});/**
* @author mrdoob / http://mrdoob.com/
*
* Abstract Base class to block based textures loader (dds, pvr, ...)
*/function CompressedTextureLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;// override in sub classes
this._parser=null;}Object.assign(CompressedTextureLoader.prototype,{load:function(url,onLoad,onProgress,onError){var scope=this;var images=[];var texture=new CompressedTexture();texture.image=images;var loader=new FileLoader(this.manager);loader.setPath(this.path);loader.setResponseType('arraybuffer');function loadTexture(i){loader.load(url[i],function(buffer){var texDatas=scope._parser(buffer,true);images[i]={width:texDatas.width,height:texDatas.height,format:texDatas.format,mipmaps:texDatas.mipmaps};loaded+=1;if(loaded===6){if(texDatas.mipmapCount===1)texture.minFilter=LinearFilter;texture.format=texDatas.format;texture.needsUpdate=true;if(onLoad)onLoad(texture);}},onProgress,onError);}if(Array.isArray(url)){var loaded=0;for(var i=0,il=url.length;i<il;++i){loadTexture(i);}}else{// compressed cubemap texture stored in a single DDS file
loader.load(url,function(buffer){var texDatas=scope._parser(buffer,true);if(texDatas.isCubemap){var faces=texDatas.mipmaps.length/texDatas.mipmapCount;for(var f=0;f<faces;f++){images[f]={mipmaps:[]};for(var i=0;i<texDatas.mipmapCount;i++){images[f].mipmaps.push(texDatas.mipmaps[f*texDatas.mipmapCount+i]);images[f].format=texDatas.format;images[f].width=texDatas.width;images[f].height=texDatas.height;}}}else{texture.image.width=texDatas.width;texture.image.height=texDatas.height;texture.mipmaps=texDatas.mipmaps;}if(texDatas.mipmapCount===1){texture.minFilter=LinearFilter;}texture.format=texDatas.format;texture.needsUpdate=true;if(onLoad)onLoad(texture);},onProgress,onError);}return texture;},setPath:function(value){this.path=value;return this;}});/**
* @author Nikos M. / https://github.com/foo123/
*
* Abstract Base class to load generic binary textures formats (rgbe, hdr, ...)
*/function DataTextureLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;// override in sub classes
this._parser=null;}Object.assign(DataTextureLoader.prototype,{load:function(url,onLoad,onProgress,onError){var scope=this;var texture=new DataTexture();var loader=new FileLoader(this.manager);loader.setResponseType('arraybuffer');loader.load(url,function(buffer){var texData=scope._parser(buffer);if(!texData)return;if(undefined!==texData.image){texture.image=texData.image;}else if(undefined!==texData.data){texture.image.width=texData.width;texture.image.height=texData.height;texture.image.data=texData.data;}texture.wrapS=undefined!==texData.wrapS?texData.wrapS:ClampToEdgeWrapping;texture.wrapT=undefined!==texData.wrapT?texData.wrapT:ClampToEdgeWrapping;texture.magFilter=undefined!==texData.magFilter?texData.magFilter:LinearFilter;texture.minFilter=undefined!==texData.minFilter?texData.minFilter:LinearMipMapLinearFilter;texture.anisotropy=undefined!==texData.anisotropy?texData.anisotropy:1;if(undefined!==texData.format){texture.format=texData.format;}if(undefined!==texData.type){texture.type=texData.type;}if(undefined!==texData.mipmaps){texture.mipmaps=texData.mipmaps;}if(1===texData.mipmapCount){texture.minFilter=LinearFilter;}texture.needsUpdate=true;if(onLoad)onLoad(texture,texData);},onProgress,onError);return texture;}});/**
* @author mrdoob / http://mrdoob.com/
*/function ImageLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;}Object.assign(ImageLoader.prototype,{crossOrigin:'Anonymous',load:function(url,onLoad,onProgress,onError){if(url===undefined)url='';if(this.path!==undefined)url=this.path+url;url=this.manager.resolveURL(url);var scope=this;var cached=Cache.get(url);if(cached!==undefined){scope.manager.itemStart(url);setTimeout(function(){if(onLoad)onLoad(cached);scope.manager.itemEnd(url);},0);return cached;}var image=document.createElementNS('http://www.w3.org/1999/xhtml','img');image.addEventListener('load',function(){Cache.add(url,this);if(onLoad)onLoad(this);scope.manager.itemEnd(url);},false);/*
image.addEventListener( 'progress', function ( event ) {
if ( onProgress ) onProgress( event );
}, false );
*/image.addEventListener('error',function(event){if(onError)onError(event);scope.manager.itemEnd(url);scope.manager.itemError(url);},false);if(url.substr(0,5)!=='data:'){if(this.crossOrigin!==undefined)image.crossOrigin=this.crossOrigin;}scope.manager.itemStart(url);image.src=url;return image;},setCrossOrigin:function(value){this.crossOrigin=value;return this;},setPath:function(value){this.path=value;return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/function CubeTextureLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;}Object.assign(CubeTextureLoader.prototype,{crossOrigin:'Anonymous',load:function(urls,onLoad,onProgress,onError){var texture=new CubeTexture();var loader=new ImageLoader(this.manager);loader.setCrossOrigin(this.crossOrigin);loader.setPath(this.path);var loaded=0;function loadTexture(i){loader.load(urls[i],function(image){texture.images[i]=image;loaded++;if(loaded===6){texture.needsUpdate=true;if(onLoad)onLoad(texture);}},undefined,onError);}for(var i=0;i<urls.length;++i){loadTexture(i);}return texture;},setCrossOrigin:function(value){this.crossOrigin=value;return this;},setPath:function(value){this.path=value;return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/function TextureLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;}Object.assign(TextureLoader.prototype,{crossOrigin:'Anonymous',load:function(url,onLoad,onProgress,onError){var texture=new Texture();var loader=new ImageLoader(this.manager);loader.setCrossOrigin(this.crossOrigin);loader.setPath(this.path);loader.load(url,function(image){texture.image=image;// JPEGs can't have an alpha channel, so memory can be saved by storing them as RGB.
var isJPEG=url.search(/\.(jpg|jpeg)$/)>0||url.search(/^data\:image\/jpeg/)===0;texture.format=isJPEG?RGBFormat:RGBAFormat;texture.needsUpdate=true;if(onLoad!==undefined){onLoad(texture);}},onProgress,onError);return texture;},setCrossOrigin:function(value){this.crossOrigin=value;return this;},setPath:function(value){this.path=value;return this;}});/**
* @author zz85 / http://www.lab4games.net/zz85/blog
* Extensible curve object
*
* Some common of curve methods:
* .getPoint( t, optionalTarget ), .getTangent( t )
* .getPointAt( u, optionalTarget ), .getTangentAt( u )
* .getPoints(), .getSpacedPoints()
* .getLength()
* .updateArcLengths()
*
* This following curves inherit from THREE.Curve:
*
* -- 2D curves --
* THREE.ArcCurve
* THREE.CubicBezierCurve
* THREE.EllipseCurve
* THREE.LineCurve
* THREE.QuadraticBezierCurve
* THREE.SplineCurve
*
* -- 3D curves --
* THREE.CatmullRomCurve3
* THREE.CubicBezierCurve3
* THREE.LineCurve3
* THREE.QuadraticBezierCurve3
*
* A series of curves can be represented as a THREE.CurvePath.
*
**/ /**************************************************************
* Abstract Curve base class
**************************************************************/function Curve(){this.type='Curve';this.arcLengthDivisions=200;}Object.assign(Curve.prototype,{// Virtual base class method to overwrite and implement in subclasses
// - t [0 .. 1]
getPoint:function()/* t, optionalTarget */{console.warn('THREE.Curve: .getPoint() not implemented.');return null;},// Get point at relative position in curve according to arc length
// - u [0 .. 1]
getPointAt:function(u,optionalTarget){var t=this.getUtoTmapping(u);return this.getPoint(t,optionalTarget);},// Get sequence of points using getPoint( t )
getPoints:function(divisions){if(divisions===undefined)divisions=5;var points=[];for(var d=0;d<=divisions;d++){points.push(this.getPoint(d/divisions));}return points;},// Get sequence of points using getPointAt( u )
getSpacedPoints:function(divisions){if(divisions===undefined)divisions=5;var points=[];for(var d=0;d<=divisions;d++){points.push(this.getPointAt(d/divisions));}return points;},// Get total curve arc length
getLength:function(){var lengths=this.getLengths();return lengths[lengths.length-1];},// Get list of cumulative segment lengths
getLengths:function(divisions){if(divisions===undefined)divisions=this.arcLengthDivisions;if(this.cacheArcLengths&&this.cacheArcLengths.length===divisions+1&&!this.needsUpdate){return this.cacheArcLengths;}this.needsUpdate=false;var cache=[];var current,last=this.getPoint(0);var p,sum=0;cache.push(0);for(p=1;p<=divisions;p++){current=this.getPoint(p/divisions);sum+=current.distanceTo(last);cache.push(sum);last=current;}this.cacheArcLengths=cache;return cache;// { sums: cache, sum: sum }; Sum is in the last element.
},updateArcLengths:function(){this.needsUpdate=true;this.getLengths();},// Given u ( 0 .. 1 ), get a t to find p. This gives you points which are equidistant
getUtoTmapping:function(u,distance){var arcLengths=this.getLengths();var i=0,il=arcLengths.length;var targetArcLength;// The targeted u distance value to get
if(distance){targetArcLength=distance;}else{targetArcLength=u*arcLengths[il-1];}// binary search for the index with largest value smaller than target u distance
var low=0,high=il-1,comparison;while(low<=high){i=Math.floor(low+(high-low)/2);// less likely to overflow, though probably not issue here, JS doesn't really have integers, all numbers are floats
comparison=arcLengths[i]-targetArcLength;if(comparison<0){low=i+1;}else if(comparison>0){high=i-1;}else{high=i;break;// DONE
}}i=high;if(arcLengths[i]===targetArcLength){return i/(il-1);}// we could get finer grain at lengths, or use simple interpolation between two points
var lengthBefore=arcLengths[i];var lengthAfter=arcLengths[i+1];var segmentLength=lengthAfter-lengthBefore;// determine where we are between the 'before' and 'after' points
var segmentFraction=(targetArcLength-lengthBefore)/segmentLength;// add that fractional amount to t
var t=(i+segmentFraction)/(il-1);return t;},// Returns a unit vector tangent at t
// In case any sub curve does not implement its tangent derivation,
// 2 points a small delta apart will be used to find its gradient
// which seems to give a reasonable approximation
getTangent:function(t){var delta=0.0001;var t1=t-delta;var t2=t+delta;// Capping in case of danger
if(t1<0)t1=0;if(t2>1)t2=1;var pt1=this.getPoint(t1);var pt2=this.getPoint(t2);var vec=pt2.clone().sub(pt1);return vec.normalize();},getTangentAt:function(u){var t=this.getUtoTmapping(u);return this.getTangent(t);},computeFrenetFrames:function(segments,closed){// see http://www.cs.indiana.edu/pub/techreports/TR425.pdf
var normal=new Vector3();var tangents=[];var normals=[];var binormals=[];var vec=new Vector3();var mat=new Matrix4();var i,u,theta;// compute the tangent vectors for each segment on the curve
for(i=0;i<=segments;i++){u=i/segments;tangents[i]=this.getTangentAt(u);tangents[i].normalize();}// select an initial normal vector perpendicular to the first tangent vector,
// and in the direction of the minimum tangent xyz component
normals[0]=new Vector3();binormals[0]=new Vector3();var min=Number.MAX_VALUE;var tx=Math.abs(tangents[0].x);var ty=Math.abs(tangents[0].y);var tz=Math.abs(tangents[0].z);if(tx<=min){min=tx;normal.set(1,0,0);}if(ty<=min){min=ty;normal.set(0,1,0);}if(tz<=min){normal.set(0,0,1);}vec.crossVectors(tangents[0],normal).normalize();normals[0].crossVectors(tangents[0],vec);binormals[0].crossVectors(tangents[0],normals[0]);// compute the slowly-varying normal and binormal vectors for each segment on the curve
for(i=1;i<=segments;i++){normals[i]=normals[i-1].clone();binormals[i]=binormals[i-1].clone();vec.crossVectors(tangents[i-1],tangents[i]);if(vec.length()>Number.EPSILON){vec.normalize();theta=Math.acos(_Math.clamp(tangents[i-1].dot(tangents[i]),-1,1));// clamp for floating pt errors
normals[i].applyMatrix4(mat.makeRotationAxis(vec,theta));}binormals[i].crossVectors(tangents[i],normals[i]);}// if the curve is closed, postprocess the vectors so the first and last normal vectors are the same
if(closed===true){theta=Math.acos(_Math.clamp(normals[0].dot(normals[segments]),-1,1));theta/=segments;if(tangents[0].dot(vec.crossVectors(normals[0],normals[segments]))>0){theta=-theta;}for(i=1;i<=segments;i++){// twist a little...
normals[i].applyMatrix4(mat.makeRotationAxis(tangents[i],theta*i));binormals[i].crossVectors(tangents[i],normals[i]);}}return {tangents:tangents,normals:normals,binormals:binormals};},clone:function(){return new this.constructor().copy(this);},copy:function(source){this.arcLengthDivisions=source.arcLengthDivisions;return this;},toJSON:function(){var data={metadata:{version:4.5,type:'Curve',generator:'Curve.toJSON'}};data.arcLengthDivisions=this.arcLengthDivisions;data.type=this.type;return data;},fromJSON:function(json){this.arcLengthDivisions=json.arcLengthDivisions;return this;}});function EllipseCurve(aX,aY,xRadius,yRadius,aStartAngle,aEndAngle,aClockwise,aRotation){Curve.call(this);this.type='EllipseCurve';this.aX=aX||0;this.aY=aY||0;this.xRadius=xRadius||1;this.yRadius=yRadius||1;this.aStartAngle=aStartAngle||0;this.aEndAngle=aEndAngle||2*Math.PI;this.aClockwise=aClockwise||false;this.aRotation=aRotation||0;}EllipseCurve.prototype=Object.create(Curve.prototype);EllipseCurve.prototype.constructor=EllipseCurve;EllipseCurve.prototype.isEllipseCurve=true;EllipseCurve.prototype.getPoint=function(t,optionalTarget){var point=optionalTarget||new Vector2();var twoPi=Math.PI*2;var deltaAngle=this.aEndAngle-this.aStartAngle;var samePoints=Math.abs(deltaAngle)<Number.EPSILON;// ensures that deltaAngle is 0 .. 2 PI
while(deltaAngle<0)deltaAngle+=twoPi;while(deltaAngle>twoPi)deltaAngle-=twoPi;if(deltaAngle<Number.EPSILON){if(samePoints){deltaAngle=0;}else{deltaAngle=twoPi;}}if(this.aClockwise===true&&!samePoints){if(deltaAngle===twoPi){deltaAngle=-twoPi;}else{deltaAngle=deltaAngle-twoPi;}}var angle=this.aStartAngle+t*deltaAngle;var x=this.aX+this.xRadius*Math.cos(angle);var y=this.aY+this.yRadius*Math.sin(angle);if(this.aRotation!==0){var cos=Math.cos(this.aRotation);var sin=Math.sin(this.aRotation);var tx=x-this.aX;var ty=y-this.aY;// Rotate the point about the center of the ellipse.
x=tx*cos-ty*sin+this.aX;y=tx*sin+ty*cos+this.aY;}return point.set(x,y);};EllipseCurve.prototype.copy=function(source){Curve.prototype.copy.call(this,source);this.aX=source.aX;this.aY=source.aY;this.xRadius=source.xRadius;this.yRadius=source.yRadius;this.aStartAngle=source.aStartAngle;this.aEndAngle=source.aEndAngle;this.aClockwise=source.aClockwise;this.aRotation=source.aRotation;return this;};EllipseCurve.prototype.toJSON=function(){var data=Curve.prototype.toJSON.call(this);data.aX=this.aX;data.aY=this.aY;data.xRadius=this.xRadius;data.yRadius=this.yRadius;data.aStartAngle=this.aStartAngle;data.aEndAngle=this.aEndAngle;data.aClockwise=this.aClockwise;data.aRotation=this.aRotation;return data;};EllipseCurve.prototype.fromJSON=function(json){Curve.prototype.fromJSON.call(this,json);this.aX=json.aX;this.aY=json.aY;this.xRadius=json.xRadius;this.yRadius=json.yRadius;this.aStartAngle=json.aStartAngle;this.aEndAngle=json.aEndAngle;this.aClockwise=json.aClockwise;this.aRotation=json.aRotation;return this;};function ArcCurve(aX,aY,aRadius,aStartAngle,aEndAngle,aClockwise){EllipseCurve.call(this,aX,aY,aRadius,aRadius,aStartAngle,aEndAngle,aClockwise);this.type='ArcCurve';}ArcCurve.prototype=Object.create(EllipseCurve.prototype);ArcCurve.prototype.constructor=ArcCurve;ArcCurve.prototype.isArcCurve=true;/**
* @author zz85 https://github.com/zz85
*
* Centripetal CatmullRom Curve - which is useful for avoiding
* cusps and self-intersections in non-uniform catmull rom curves.
* http://www.cemyuksel.com/research/catmullrom_param/catmullrom.pdf
*
* curve.type accepts centripetal(default), chordal and catmullrom
* curve.tension is used for catmullrom which defaults to 0.5
*/ /*
Based on an optimized c++ solution in
- http://stackoverflow.com/questions/9489736/catmull-rom-curve-with-no-cusps-and-no-self-intersections/
- http://ideone.com/NoEbVM
This CubicPoly class could be used for reusing some variables and calculations,
but for three.js curve use, it could be possible inlined and flatten into a single function call
which can be placed in CurveUtils.
*/function CubicPoly(){var c0=0,c1=0,c2=0,c3=0;/*
* Compute coefficients for a cubic polynomial
* p(s) = c0 + c1*s + c2*s^2 + c3*s^3
* such that
* p(0) = x0, p(1) = x1
* and
* p'(0) = t0, p'(1) = t1.
*/function init(x0,x1,t0,t1){c0=x0;c1=t0;c2=-3*x0+3*x1-2*t0-t1;c3=2*x0-2*x1+t0+t1;}return {initCatmullRom:function(x0,x1,x2,x3,tension){init(x1,x2,tension*(x2-x0),tension*(x3-x1));},initNonuniformCatmullRom:function(x0,x1,x2,x3,dt0,dt1,dt2){// compute tangents when parameterized in [t1,t2]
var t1=(x1-x0)/dt0-(x2-x0)/(dt0+dt1)+(x2-x1)/dt1;var t2=(x2-x1)/dt1-(x3-x1)/(dt1+dt2)+(x3-x2)/dt2;// rescale tangents for parametrization in [0,1]
t1*=dt1;t2*=dt1;init(x1,x2,t1,t2);},calc:function(t){var t2=t*t;var t3=t2*t;return c0+c1*t+c2*t2+c3*t3;}};}//
var tmp=new Vector3();var px$1=new CubicPoly();var py=new CubicPoly();var pz=new CubicPoly();function CatmullRomCurve3(points,closed,curveType,tension){Curve.call(this);this.type='CatmullRomCurve3';this.points=points||[];this.closed=closed||false;this.curveType=curveType||'centripetal';this.tension=tension||0.5;}CatmullRomCurve3.prototype=Object.create(Curve.prototype);CatmullRomCurve3.prototype.constructor=CatmullRomCurve3;CatmullRomCurve3.prototype.isCatmullRomCurve3=true;CatmullRomCurve3.prototype.getPoint=function(t,optionalTarget){var point=optionalTarget||new Vector3();var points=this.points;var l=points.length;var p=(l-(this.closed?0:1))*t;var intPoint=Math.floor(p);var weight=p-intPoint;if(this.closed){intPoint+=intPoint>0?0:(Math.floor(Math.abs(intPoint)/l)+1)*l;}else if(weight===0&&intPoint===l-1){intPoint=l-2;weight=1;}var p0,p1,p2,p3;// 4 points
if(this.closed||intPoint>0){p0=points[(intPoint-1)%l];}else{// extrapolate first point
tmp.subVectors(points[0],points[1]).add(points[0]);p0=tmp;}p1=points[intPoint%l];p2=points[(intPoint+1)%l];if(this.closed||intPoint+2<l){p3=points[(intPoint+2)%l];}else{// extrapolate last point
tmp.subVectors(points[l-1],points[l-2]).add(points[l-1]);p3=tmp;}if(this.curveType==='centripetal'||this.curveType==='chordal'){// init Centripetal / Chordal Catmull-Rom
var pow=this.curveType==='chordal'?0.5:0.25;var dt0=Math.pow(p0.distanceToSquared(p1),pow);var dt1=Math.pow(p1.distanceToSquared(p2),pow);var dt2=Math.pow(p2.distanceToSquared(p3),pow);// safety check for repeated points
if(dt1<1e-4)dt1=1.0;if(dt0<1e-4)dt0=dt1;if(dt2<1e-4)dt2=dt1;px$1.initNonuniformCatmullRom(p0.x,p1.x,p2.x,p3.x,dt0,dt1,dt2);py.initNonuniformCatmullRom(p0.y,p1.y,p2.y,p3.y,dt0,dt1,dt2);pz.initNonuniformCatmullRom(p0.z,p1.z,p2.z,p3.z,dt0,dt1,dt2);}else if(this.curveType==='catmullrom'){px$1.initCatmullRom(p0.x,p1.x,p2.x,p3.x,this.tension);py.initCatmullRom(p0.y,p1.y,p2.y,p3.y,this.tension);pz.initCatmullRom(p0.z,p1.z,p2.z,p3.z,this.tension);}point.set(px$1.calc(weight),py.calc(weight),pz.calc(weight));return point;};CatmullRomCurve3.prototype.copy=function(source){Curve.prototype.copy.call(this,source);this.points=[];for(var i=0,l=source.points.length;i<l;i++){var point=source.points[i];this.points.push(point.clone());}this.closed=source.closed;this.curveType=source.curveType;this.tension=source.tension;return this;};CatmullRomCurve3.prototype.toJSON=function(){var data=Curve.prototype.toJSON.call(this);data.points=[];for(var i=0,l=this.points.length;i<l;i++){var point=this.points[i];data.points.push(point.toArray());}data.closed=this.closed;data.curveType=this.curveType;data.tension=this.tension;return data;};CatmullRomCurve3.prototype.fromJSON=function(json){Curve.prototype.fromJSON.call(this,json);this.points=[];for(var i=0,l=json.points.length;i<l;i++){var point=json.points[i];this.points.push(new Vector3().fromArray(point));}this.closed=json.closed;this.curveType=json.curveType;this.tension=json.tension;return this;};/**
* @author zz85 / http://www.lab4games.net/zz85/blog
*
* Bezier Curves formulas obtained from
* http://en.wikipedia.org/wiki/Bézier_curve
*/function CatmullRom(t,p0,p1,p2,p3){var v0=(p2-p0)*0.5;var v1=(p3-p1)*0.5;var t2=t*t;var t3=t*t2;return (2*p1-2*p2+v0+v1)*t3+(-3*p1+3*p2-2*v0-v1)*t2+v0*t+p1;}//
function QuadraticBezierP0(t,p){var k=1-t;return k*k*p;}function QuadraticBezierP1(t,p){return 2*(1-t)*t*p;}function QuadraticBezierP2(t,p){return t*t*p;}function QuadraticBezier(t,p0,p1,p2){return QuadraticBezierP0(t,p0)+QuadraticBezierP1(t,p1)+QuadraticBezierP2(t,p2);}//
function CubicBezierP0(t,p){var k=1-t;return k*k*k*p;}function CubicBezierP1(t,p){var k=1-t;return 3*k*k*t*p;}function CubicBezierP2(t,p){return 3*(1-t)*t*t*p;}function CubicBezierP3(t,p){return t*t*t*p;}function CubicBezier(t,p0,p1,p2,p3){return CubicBezierP0(t,p0)+CubicBezierP1(t,p1)+CubicBezierP2(t,p2)+CubicBezierP3(t,p3);}function CubicBezierCurve(v0,v1,v2,v3){Curve.call(this);this.type='CubicBezierCurve';this.v0=v0||new Vector2();this.v1=v1||new Vector2();this.v2=v2||new Vector2();this.v3=v3||new Vector2();}CubicBezierCurve.prototype=Object.create(Curve.prototype);CubicBezierCurve.prototype.constructor=CubicBezierCurve;CubicBezierCurve.prototype.isCubicBezierCurve=true;CubicBezierCurve.prototype.getPoint=function(t,optionalTarget){var point=optionalTarget||new Vector2();var v0=this.v0,v1=this.v1,v2=this.v2,v3=this.v3;point.set(CubicBezier(t,v0.x,v1.x,v2.x,v3.x),CubicBezier(t,v0.y,v1.y,v2.y,v3.y));return point;};CubicBezierCurve.prototype.copy=function(source){Curve.prototype.copy.call(this,source);this.v0.copy(source.v0);this.v1.copy(source.v1);this.v2.copy(source.v2);this.v3.copy(source.v3);return this;};CubicBezierCurve.prototype.toJSON=function(){var data=Curve.prototype.toJSON.call(this);data.v0=this.v0.toArray();data.v1=this.v1.toArray();data.v2=this.v2.toArray();data.v3=this.v3.toArray();return data;};CubicBezierCurve.prototype.fromJSON=function(json){Curve.prototype.fromJSON.call(this,json);this.v0.fromArray(json.v0);this.v1.fromArray(json.v1);this.v2.fromArray(json.v2);this.v3.fromArray(json.v3);return this;};function CubicBezierCurve3(v0,v1,v2,v3){Curve.call(this);this.type='CubicBezierCurve3';this.v0=v0||new Vector3();this.v1=v1||new Vector3();this.v2=v2||new Vector3();this.v3=v3||new Vector3();}CubicBezierCurve3.prototype=Object.create(Curve.prototype);CubicBezierCurve3.prototype.constructor=CubicBezierCurve3;CubicBezierCurve3.prototype.isCubicBezierCurve3=true;CubicBezierCurve3.prototype.getPoint=function(t,optionalTarget){var point=optionalTarget||new Vector3();var v0=this.v0,v1=this.v1,v2=this.v2,v3=this.v3;point.set(CubicBezier(t,v0.x,v1.x,v2.x,v3.x),CubicBezier(t,v0.y,v1.y,v2.y,v3.y),CubicBezier(t,v0.z,v1.z,v2.z,v3.z));return point;};CubicBezierCurve3.prototype.copy=function(source){Curve.prototype.copy.call(this,source);this.v0.copy(source.v0);this.v1.copy(source.v1);this.v2.copy(source.v2);this.v3.copy(source.v3);return this;};CubicBezierCurve3.prototype.toJSON=function(){var data=Curve.prototype.toJSON.call(this);data.v0=this.v0.toArray();data.v1=this.v1.toArray();data.v2=this.v2.toArray();data.v3=this.v3.toArray();return data;};CubicBezierCurve3.prototype.fromJSON=function(json){Curve.prototype.fromJSON.call(this,json);this.v0.fromArray(json.v0);this.v1.fromArray(json.v1);this.v2.fromArray(json.v2);this.v3.fromArray(json.v3);return this;};function LineCurve(v1,v2){Curve.call(this);this.type='LineCurve';this.v1=v1||new Vector2();this.v2=v2||new Vector2();}LineCurve.prototype=Object.create(Curve.prototype);LineCurve.prototype.constructor=LineCurve;LineCurve.prototype.isLineCurve=true;LineCurve.prototype.getPoint=function(t,optionalTarget){var point=optionalTarget||new Vector2();if(t===1){point.copy(this.v2);}else{point.copy(this.v2).sub(this.v1);point.multiplyScalar(t).add(this.v1);}return point;};// Line curve is linear, so we can overwrite default getPointAt
LineCurve.prototype.getPointAt=function(u,optionalTarget){return this.getPoint(u,optionalTarget);};LineCurve.prototype.getTangent=function()/* t */{var tangent=this.v2.clone().sub(this.v1);return tangent.normalize();};LineCurve.prototype.copy=function(source){Curve.prototype.copy.call(this,source);this.v1.copy(source.v1);this.v2.copy(source.v2);return this;};LineCurve.prototype.toJSON=function(){var data=Curve.prototype.toJSON.call(this);data.v1=this.v1.toArray();data.v2=this.v2.toArray();return data;};LineCurve.prototype.fromJSON=function(json){Curve.prototype.fromJSON.call(this,json);this.v1.fromArray(json.v1);this.v2.fromArray(json.v2);return this;};function LineCurve3(v1,v2){Curve.call(this);this.type='LineCurve3';this.v1=v1||new Vector3();this.v2=v2||new Vector3();}LineCurve3.prototype=Object.create(Curve.prototype);LineCurve3.prototype.constructor=LineCurve3;LineCurve3.prototype.isLineCurve3=true;LineCurve3.prototype.getPoint=function(t,optionalTarget){var point=optionalTarget||new Vector3();if(t===1){point.copy(this.v2);}else{point.copy(this.v2).sub(this.v1);point.multiplyScalar(t).add(this.v1);}return point;};// Line curve is linear, so we can overwrite default getPointAt
LineCurve3.prototype.getPointAt=function(u,optionalTarget){return this.getPoint(u,optionalTarget);};LineCurve3.prototype.copy=function(source){Curve.prototype.copy.call(this,source);this.v1.copy(source.v1);this.v2.copy(source.v2);return this;};LineCurve3.prototype.toJSON=function(){var data=Curve.prototype.toJSON.call(this);data.v1=this.v1.toArray();data.v2=this.v2.toArray();return data;};LineCurve3.prototype.fromJSON=function(json){Curve.prototype.fromJSON.call(this,json);this.v1.fromArray(json.v1);this.v2.fromArray(json.v2);return this;};function QuadraticBezierCurve(v0,v1,v2){Curve.call(this);this.type='QuadraticBezierCurve';this.v0=v0||new Vector2();this.v1=v1||new Vector2();this.v2=v2||new Vector2();}QuadraticBezierCurve.prototype=Object.create(Curve.prototype);QuadraticBezierCurve.prototype.constructor=QuadraticBezierCurve;QuadraticBezierCurve.prototype.isQuadraticBezierCurve=true;QuadraticBezierCurve.prototype.getPoint=function(t,optionalTarget){var point=optionalTarget||new Vector2();var v0=this.v0,v1=this.v1,v2=this.v2;point.set(QuadraticBezier(t,v0.x,v1.x,v2.x),QuadraticBezier(t,v0.y,v1.y,v2.y));return point;};QuadraticBezierCurve.prototype.copy=function(source){Curve.prototype.copy.call(this,source);this.v0.copy(source.v0);this.v1.copy(source.v1);this.v2.copy(source.v2);return this;};QuadraticBezierCurve.prototype.toJSON=function(){var data=Curve.prototype.toJSON.call(this);data.v0=this.v0.toArray();data.v1=this.v1.toArray();data.v2=this.v2.toArray();return data;};QuadraticBezierCurve.prototype.fromJSON=function(json){Curve.prototype.fromJSON.call(this,json);this.v0.fromArray(json.v0);this.v1.fromArray(json.v1);this.v2.fromArray(json.v2);return this;};function QuadraticBezierCurve3(v0,v1,v2){Curve.call(this);this.type='QuadraticBezierCurve3';this.v0=v0||new Vector3();this.v1=v1||new Vector3();this.v2=v2||new Vector3();}QuadraticBezierCurve3.prototype=Object.create(Curve.prototype);QuadraticBezierCurve3.prototype.constructor=QuadraticBezierCurve3;QuadraticBezierCurve3.prototype.isQuadraticBezierCurve3=true;QuadraticBezierCurve3.prototype.getPoint=function(t,optionalTarget){var point=optionalTarget||new Vector3();var v0=this.v0,v1=this.v1,v2=this.v2;point.set(QuadraticBezier(t,v0.x,v1.x,v2.x),QuadraticBezier(t,v0.y,v1.y,v2.y),QuadraticBezier(t,v0.z,v1.z,v2.z));return point;};QuadraticBezierCurve3.prototype.copy=function(source){Curve.prototype.copy.call(this,source);this.v0.copy(source.v0);this.v1.copy(source.v1);this.v2.copy(source.v2);return this;};QuadraticBezierCurve3.prototype.toJSON=function(){var data=Curve.prototype.toJSON.call(this);data.v0=this.v0.toArray();data.v1=this.v1.toArray();data.v2=this.v2.toArray();return data;};QuadraticBezierCurve3.prototype.fromJSON=function(json){Curve.prototype.fromJSON.call(this,json);this.v0.fromArray(json.v0);this.v1.fromArray(json.v1);this.v2.fromArray(json.v2);return this;};function SplineCurve(points/* array of Vector2 */){Curve.call(this);this.type='SplineCurve';this.points=points||[];}SplineCurve.prototype=Object.create(Curve.prototype);SplineCurve.prototype.constructor=SplineCurve;SplineCurve.prototype.isSplineCurve=true;SplineCurve.prototype.getPoint=function(t,optionalTarget){var point=optionalTarget||new Vector2();var points=this.points;var p=(points.length-1)*t;var intPoint=Math.floor(p);var weight=p-intPoint;var p0=points[intPoint===0?intPoint:intPoint-1];var p1=points[intPoint];var p2=points[intPoint>points.length-2?points.length-1:intPoint+1];var p3=points[intPoint>points.length-3?points.length-1:intPoint+2];point.set(CatmullRom(weight,p0.x,p1.x,p2.x,p3.x),CatmullRom(weight,p0.y,p1.y,p2.y,p3.y));return point;};SplineCurve.prototype.copy=function(source){Curve.prototype.copy.call(this,source);this.points=[];for(var i=0,l=source.points.length;i<l;i++){var point=source.points[i];this.points.push(point.clone());}return this;};SplineCurve.prototype.toJSON=function(){var data=Curve.prototype.toJSON.call(this);data.points=[];for(var i=0,l=this.points.length;i<l;i++){var point=this.points[i];data.points.push(point.toArray());}return data;};SplineCurve.prototype.fromJSON=function(json){Curve.prototype.fromJSON.call(this,json);this.points=[];for(var i=0,l=json.points.length;i<l;i++){var point=json.points[i];this.points.push(new Vector2().fromArray(point));}return this;};var Curves=Object.freeze({ArcCurve:ArcCurve,CatmullRomCurve3:CatmullRomCurve3,CubicBezierCurve:CubicBezierCurve,CubicBezierCurve3:CubicBezierCurve3,EllipseCurve:EllipseCurve,LineCurve:LineCurve,LineCurve3:LineCurve3,QuadraticBezierCurve:QuadraticBezierCurve,QuadraticBezierCurve3:QuadraticBezierCurve3,SplineCurve:SplineCurve});/**
* @author zz85 / http://www.lab4games.net/zz85/blog
*
**/ /**************************************************************
* Curved Path - a curve path is simply a array of connected
* curves, but retains the api of a curve
**************************************************************/function CurvePath(){Curve.call(this);this.type='CurvePath';this.curves=[];this.autoClose=false;// Automatically closes the path
}CurvePath.prototype=Object.assign(Object.create(Curve.prototype),{constructor:CurvePath,add:function(curve){this.curves.push(curve);},closePath:function(){// Add a line curve if start and end of lines are not connected
var startPoint=this.curves[0].getPoint(0);var endPoint=this.curves[this.curves.length-1].getPoint(1);if(!startPoint.equals(endPoint)){this.curves.push(new LineCurve(endPoint,startPoint));}},// To get accurate point with reference to
// entire path distance at time t,
// following has to be done:
// 1. Length of each sub path have to be known
// 2. Locate and identify type of curve
// 3. Get t for the curve
// 4. Return curve.getPointAt(t')
getPoint:function(t){var d=t*this.getLength();var curveLengths=this.getCurveLengths();var i=0;// To think about boundaries points.
while(i<curveLengths.length){if(curveLengths[i]>=d){var diff=curveLengths[i]-d;var curve=this.curves[i];var segmentLength=curve.getLength();var u=segmentLength===0?0:1-diff/segmentLength;return curve.getPointAt(u);}i++;}return null;// loop where sum != 0, sum > d , sum+1 <d
},// We cannot use the default THREE.Curve getPoint() with getLength() because in
// THREE.Curve, getLength() depends on getPoint() but in THREE.CurvePath
// getPoint() depends on getLength
getLength:function(){var lens=this.getCurveLengths();return lens[lens.length-1];},// cacheLengths must be recalculated.
updateArcLengths:function(){this.needsUpdate=true;this.cacheLengths=null;this.getCurveLengths();},// Compute lengths and cache them
// We cannot overwrite getLengths() because UtoT mapping uses it.
getCurveLengths:function(){// We use cache values if curves and cache array are same length
if(this.cacheLengths&&this.cacheLengths.length===this.curves.length){return this.cacheLengths;}// Get length of sub-curve
// Push sums into cached array
var lengths=[],sums=0;for(var i=0,l=this.curves.length;i<l;i++){sums+=this.curves[i].getLength();lengths.push(sums);}this.cacheLengths=lengths;return lengths;},getSpacedPoints:function(divisions){if(divisions===undefined)divisions=40;var points=[];for(var i=0;i<=divisions;i++){points.push(this.getPoint(i/divisions));}if(this.autoClose){points.push(points[0]);}return points;},getPoints:function(divisions){divisions=divisions||12;var points=[],last;for(var i=0,curves=this.curves;i<curves.length;i++){var curve=curves[i];var resolution=curve&&curve.isEllipseCurve?divisions*2:curve&&curve.isLineCurve?1:curve&&curve.isSplineCurve?divisions*curve.points.length:divisions;var pts=curve.getPoints(resolution);for(var j=0;j<pts.length;j++){var point=pts[j];if(last&&last.equals(point))continue;// ensures no consecutive points are duplicates
points.push(point);last=point;}}if(this.autoClose&&points.length>1&&!points[points.length-1].equals(points[0])){points.push(points[0]);}return points;},copy:function(source){Curve.prototype.copy.call(this,source);this.curves=[];for(var i=0,l=source.curves.length;i<l;i++){var curve=source.curves[i];this.curves.push(curve.clone());}this.autoClose=source.autoClose;return this;},toJSON:function(){var data=Curve.prototype.toJSON.call(this);data.autoClose=this.autoClose;data.curves=[];for(var i=0,l=this.curves.length;i<l;i++){var curve=this.curves[i];data.curves.push(curve.toJSON());}return data;},fromJSON:function(json){Curve.prototype.fromJSON.call(this,json);this.autoClose=json.autoClose;this.curves=[];for(var i=0,l=json.curves.length;i<l;i++){var curve=json.curves[i];this.curves.push(new Curves[curve.type]().fromJSON(curve));}return this;}});/**
* @author zz85 / http://www.lab4games.net/zz85/blog
* Creates free form 2d path using series of points, lines or curves.
**/function Path(points){CurvePath.call(this);this.type='Path';this.currentPoint=new Vector2();if(points){this.setFromPoints(points);}}Path.prototype=Object.assign(Object.create(CurvePath.prototype),{constructor:Path,setFromPoints:function(points){this.moveTo(points[0].x,points[0].y);for(var i=1,l=points.length;i<l;i++){this.lineTo(points[i].x,points[i].y);}},moveTo:function(x,y){this.currentPoint.set(x,y);// TODO consider referencing vectors instead of copying?
},lineTo:function(x,y){var curve=new LineCurve(this.currentPoint.clone(),new Vector2(x,y));this.curves.push(curve);this.currentPoint.set(x,y);},quadraticCurveTo:function(aCPx,aCPy,aX,aY){var curve=new QuadraticBezierCurve(this.currentPoint.clone(),new Vector2(aCPx,aCPy),new Vector2(aX,aY));this.curves.push(curve);this.currentPoint.set(aX,aY);},bezierCurveTo:function(aCP1x,aCP1y,aCP2x,aCP2y,aX,aY){var curve=new CubicBezierCurve(this.currentPoint.clone(),new Vector2(aCP1x,aCP1y),new Vector2(aCP2x,aCP2y),new Vector2(aX,aY));this.curves.push(curve);this.currentPoint.set(aX,aY);},splineThru:function(pts/*Array of Vector*/){var npts=[this.currentPoint.clone()].concat(pts);var curve=new SplineCurve(npts);this.curves.push(curve);this.currentPoint.copy(pts[pts.length-1]);},arc:function(aX,aY,aRadius,aStartAngle,aEndAngle,aClockwise){var x0=this.currentPoint.x;var y0=this.currentPoint.y;this.absarc(aX+x0,aY+y0,aRadius,aStartAngle,aEndAngle,aClockwise);},absarc:function(aX,aY,aRadius,aStartAngle,aEndAngle,aClockwise){this.absellipse(aX,aY,aRadius,aRadius,aStartAngle,aEndAngle,aClockwise);},ellipse:function(aX,aY,xRadius,yRadius,aStartAngle,aEndAngle,aClockwise,aRotation){var x0=this.currentPoint.x;var y0=this.currentPoint.y;this.absellipse(aX+x0,aY+y0,xRadius,yRadius,aStartAngle,aEndAngle,aClockwise,aRotation);},absellipse:function(aX,aY,xRadius,yRadius,aStartAngle,aEndAngle,aClockwise,aRotation){var curve=new EllipseCurve(aX,aY,xRadius,yRadius,aStartAngle,aEndAngle,aClockwise,aRotation);if(this.curves.length>0){// if a previous curve is present, attempt to join
var firstPoint=curve.getPoint(0);if(!firstPoint.equals(this.currentPoint)){this.lineTo(firstPoint.x,firstPoint.y);}}this.curves.push(curve);var lastPoint=curve.getPoint(1);this.currentPoint.copy(lastPoint);},copy:function(source){CurvePath.prototype.copy.call(this,source);this.currentPoint.copy(source.currentPoint);return this;},toJSON:function(){var data=CurvePath.prototype.toJSON.call(this);data.currentPoint=this.currentPoint.toArray();return data;},fromJSON:function(json){CurvePath.prototype.fromJSON.call(this,json);this.currentPoint.fromArray(json.currentPoint);return this;}});/**
* @author zz85 / http://www.lab4games.net/zz85/blog
* Defines a 2d shape plane using paths.
**/ // STEP 1 Create a path.
// STEP 2 Turn path into shape.
// STEP 3 ExtrudeGeometry takes in Shape/Shapes
// STEP 3a - Extract points from each shape, turn to vertices
// STEP 3b - Triangulate each shape, add faces.
function Shape(points){Path.call(this,points);this.uuid=_Math.generateUUID();this.type='Shape';this.holes=[];}Shape.prototype=Object.assign(Object.create(Path.prototype),{constructor:Shape,getPointsHoles:function(divisions){var holesPts=[];for(var i=0,l=this.holes.length;i<l;i++){holesPts[i]=this.holes[i].getPoints(divisions);}return holesPts;},// get points of shape and holes (keypoints based on segments parameter)
extractPoints:function(divisions){return {shape:this.getPoints(divisions),holes:this.getPointsHoles(divisions)};},copy:function(source){Path.prototype.copy.call(this,source);this.holes=[];for(var i=0,l=source.holes.length;i<l;i++){var hole=source.holes[i];this.holes.push(hole.clone());}return this;},toJSON:function(){var data=Path.prototype.toJSON.call(this);data.uuid=this.uuid;data.holes=[];for(var i=0,l=this.holes.length;i<l;i++){var hole=this.holes[i];data.holes.push(hole.toJSON());}return data;},fromJSON:function(json){Path.prototype.fromJSON.call(this,json);this.uuid=json.uuid;this.holes=[];for(var i=0,l=json.holes.length;i<l;i++){var hole=json.holes[i];this.holes.push(new Path().fromJSON(hole));}return this;}});/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*/function Light(color,intensity){Object3D.call(this);this.type='Light';this.color=new Color(color);this.intensity=intensity!==undefined?intensity:1;this.receiveShadow=undefined;}Light.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Light,isLight:true,copy:function(source){Object3D.prototype.copy.call(this,source);this.color.copy(source.color);this.intensity=source.intensity;return this;},toJSON:function(meta){var data=Object3D.prototype.toJSON.call(this,meta);data.object.color=this.color.getHex();data.object.intensity=this.intensity;if(this.groundColor!==undefined)data.object.groundColor=this.groundColor.getHex();if(this.distance!==undefined)data.object.distance=this.distance;if(this.angle!==undefined)data.object.angle=this.angle;if(this.decay!==undefined)data.object.decay=this.decay;if(this.penumbra!==undefined)data.object.penumbra=this.penumbra;if(this.shadow!==undefined)data.object.shadow=this.shadow.toJSON();return data;}});/**
* @author alteredq / http://alteredqualia.com/
*/function HemisphereLight(skyColor,groundColor,intensity){Light.call(this,skyColor,intensity);this.type='HemisphereLight';this.castShadow=undefined;this.position.copy(Object3D.DefaultUp);this.updateMatrix();this.groundColor=new Color(groundColor);}HemisphereLight.prototype=Object.assign(Object.create(Light.prototype),{constructor:HemisphereLight,isHemisphereLight:true,copy:function(source){Light.prototype.copy.call(this,source);this.groundColor.copy(source.groundColor);return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/function LightShadow(camera){this.camera=camera;this.bias=0;this.radius=1;this.mapSize=new Vector2(512,512);this.map=null;this.matrix=new Matrix4();}Object.assign(LightShadow.prototype,{copy:function(source){this.camera=source.camera.clone();this.bias=source.bias;this.radius=source.radius;this.mapSize.copy(source.mapSize);return this;},clone:function(){return new this.constructor().copy(this);},toJSON:function(){var object={};if(this.bias!==0)object.bias=this.bias;if(this.radius!==1)object.radius=this.radius;if(this.mapSize.x!==512||this.mapSize.y!==512)object.mapSize=this.mapSize.toArray();object.camera=this.camera.toJSON(false).object;delete object.camera.matrix;return object;}});/**
* @author mrdoob / http://mrdoob.com/
*/function SpotLightShadow(){LightShadow.call(this,new PerspectiveCamera(50,1,0.5,500));}SpotLightShadow.prototype=Object.assign(Object.create(LightShadow.prototype),{constructor:SpotLightShadow,isSpotLightShadow:true,update:function(light){var camera=this.camera;var fov=_Math.RAD2DEG*2*light.angle;var aspect=this.mapSize.width/this.mapSize.height;var far=light.distance||camera.far;if(fov!==camera.fov||aspect!==camera.aspect||far!==camera.far){camera.fov=fov;camera.aspect=aspect;camera.far=far;camera.updateProjectionMatrix();}}});/**
* @author alteredq / http://alteredqualia.com/
*/function SpotLight(color,intensity,distance,angle,penumbra,decay){Light.call(this,color,intensity);this.type='SpotLight';this.position.copy(Object3D.DefaultUp);this.updateMatrix();this.target=new Object3D();Object.defineProperty(this,'power',{get:function(){// intensity = power per solid angle.
// ref: equation (17) from https://seblagarde.files.wordpress.com/2015/07/course_notes_moving_frostbite_to_pbr_v32.pdf
return this.intensity*Math.PI;},set:function(power){// intensity = power per solid angle.
// ref: equation (17) from https://seblagarde.files.wordpress.com/2015/07/course_notes_moving_frostbite_to_pbr_v32.pdf
this.intensity=power/Math.PI;}});this.distance=distance!==undefined?distance:0;this.angle=angle!==undefined?angle:Math.PI/3;this.penumbra=penumbra!==undefined?penumbra:0;this.decay=decay!==undefined?decay:1;// for physically correct lights, should be 2.
this.shadow=new SpotLightShadow();}SpotLight.prototype=Object.assign(Object.create(Light.prototype),{constructor:SpotLight,isSpotLight:true,copy:function(source){Light.prototype.copy.call(this,source);this.distance=source.distance;this.angle=source.angle;this.penumbra=source.penumbra;this.decay=source.decay;this.target=source.target.clone();this.shadow=source.shadow.clone();return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/function PointLight(color,intensity,distance,decay){Light.call(this,color,intensity);this.type='PointLight';Object.defineProperty(this,'power',{get:function(){// intensity = power per solid angle.
// ref: equation (15) from https://seblagarde.files.wordpress.com/2015/07/course_notes_moving_frostbite_to_pbr_v32.pdf
return this.intensity*4*Math.PI;},set:function(power){// intensity = power per solid angle.
// ref: equation (15) from https://seblagarde.files.wordpress.com/2015/07/course_notes_moving_frostbite_to_pbr_v32.pdf
this.intensity=power/(4*Math.PI);}});this.distance=distance!==undefined?distance:0;this.decay=decay!==undefined?decay:1;// for physically correct lights, should be 2.
this.shadow=new LightShadow(new PerspectiveCamera(90,1,0.5,500));}PointLight.prototype=Object.assign(Object.create(Light.prototype),{constructor:PointLight,isPointLight:true,copy:function(source){Light.prototype.copy.call(this,source);this.distance=source.distance;this.decay=source.decay;this.shadow=source.shadow.clone();return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/function DirectionalLightShadow(){LightShadow.call(this,new OrthographicCamera(-5,5,5,-5,0.5,500));}DirectionalLightShadow.prototype=Object.assign(Object.create(LightShadow.prototype),{constructor:DirectionalLightShadow});/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*/function DirectionalLight(color,intensity){Light.call(this,color,intensity);this.type='DirectionalLight';this.position.copy(Object3D.DefaultUp);this.updateMatrix();this.target=new Object3D();this.shadow=new DirectionalLightShadow();}DirectionalLight.prototype=Object.assign(Object.create(Light.prototype),{constructor:DirectionalLight,isDirectionalLight:true,copy:function(source){Light.prototype.copy.call(this,source);this.target=source.target.clone();this.shadow=source.shadow.clone();return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/function AmbientLight(color,intensity){Light.call(this,color,intensity);this.type='AmbientLight';this.castShadow=undefined;}AmbientLight.prototype=Object.assign(Object.create(Light.prototype),{constructor:AmbientLight,isAmbientLight:true});/**
* @author abelnation / http://github.com/abelnation
*/function RectAreaLight(color,intensity,width,height){Light.call(this,color,intensity);this.type='RectAreaLight';this.width=width!==undefined?width:10;this.height=height!==undefined?height:10;}RectAreaLight.prototype=Object.assign(Object.create(Light.prototype),{constructor:RectAreaLight,isRectAreaLight:true,copy:function(source){Light.prototype.copy.call(this,source);this.width=source.width;this.height=source.height;return this;},toJSON:function(meta){var data=Light.prototype.toJSON.call(this,meta);data.object.width=this.width;data.object.height=this.height;return data;}});/**
*
* A Track that interpolates Strings
*
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/function StringKeyframeTrack(name,times,values,interpolation){KeyframeTrack.call(this,name,times,values,interpolation);}StringKeyframeTrack.prototype=Object.assign(Object.create(KeyframeTrack.prototype),{constructor:StringKeyframeTrack,ValueTypeName:'string',ValueBufferType:Array,DefaultInterpolation:InterpolateDiscrete,InterpolantFactoryMethodLinear:undefined,InterpolantFactoryMethodSmooth:undefined});/**
*
* A Track of Boolean keyframe values.
*
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/function BooleanKeyframeTrack(name,times,values){KeyframeTrack.call(this,name,times,values);}BooleanKeyframeTrack.prototype=Object.assign(Object.create(KeyframeTrack.prototype),{constructor:BooleanKeyframeTrack,ValueTypeName:'bool',ValueBufferType:Array,DefaultInterpolation:InterpolateDiscrete,InterpolantFactoryMethodLinear:undefined,InterpolantFactoryMethodSmooth:undefined// Note: Actually this track could have a optimized / compressed
// representation of a single value and a custom interpolant that
// computes "firstValue ^ isOdd( index )".
});/**
* Abstract base class of interpolants over parametric samples.
*
* The parameter domain is one dimensional, typically the time or a path
* along a curve defined by the data.
*
* The sample values can have any dimensionality and derived classes may
* apply special interpretations to the data.
*
* This class provides the interval seek in a Template Method, deferring
* the actual interpolation to derived classes.
*
* Time complexity is O(1) for linear access crossing at most two points
* and O(log N) for random access, where N is the number of positions.
*
* References:
*
* http://www.oodesign.com/template-method-pattern.html
*
* @author tschw
*/function Interpolant(parameterPositions,sampleValues,sampleSize,resultBuffer){this.parameterPositions=parameterPositions;this._cachedIndex=0;this.resultBuffer=resultBuffer!==undefined?resultBuffer:new sampleValues.constructor(sampleSize);this.sampleValues=sampleValues;this.valueSize=sampleSize;}Object.assign(Interpolant.prototype,{evaluate:function(t){var pp=this.parameterPositions,i1=this._cachedIndex,t1=pp[i1],t0=pp[i1-1];validate_interval:{seek:{var right;linear_scan:{//- See http://jsperf.com/comparison-to-undefined/3
//- slower code:
//-
//- if ( t >= t1 || t1 === undefined ) {
forward_scan:if(!(t<t1)){for(var giveUpAt=i1+2;;){if(t1===undefined){if(t<t0)break forward_scan;// after end
i1=pp.length;this._cachedIndex=i1;return this.afterEnd_(i1-1,t,t0);}if(i1===giveUpAt)break;// this loop
t0=t1;t1=pp[++i1];if(t<t1){// we have arrived at the sought interval
break seek;}}// prepare binary search on the right side of the index
right=pp.length;break linear_scan;}//- slower code:
//- if ( t < t0 || t0 === undefined ) {
if(!(t>=t0)){// looping?
var t1global=pp[1];if(t<t1global){i1=2;// + 1, using the scan for the details
t0=t1global;}// linear reverse scan
for(var giveUpAt=i1-2;;){if(t0===undefined){// before start
this._cachedIndex=0;return this.beforeStart_(0,t,t1);}if(i1===giveUpAt)break;// this loop
t1=t0;t0=pp[--i1-1];if(t>=t0){// we have arrived at the sought interval
break seek;}}// prepare binary search on the left side of the index
right=i1;i1=0;break linear_scan;}// the interval is valid
break validate_interval;}// linear scan
// binary search
while(i1<right){var mid=i1+right>>>1;if(t<pp[mid]){right=mid;}else{i1=mid+1;}}t1=pp[i1];t0=pp[i1-1];// check boundary cases, again
if(t0===undefined){this._cachedIndex=0;return this.beforeStart_(0,t,t1);}if(t1===undefined){i1=pp.length;this._cachedIndex=i1;return this.afterEnd_(i1-1,t0,t);}}// seek
this._cachedIndex=i1;this.intervalChanged_(i1,t0,t1);}// validate_interval
return this.interpolate_(i1,t0,t,t1);},settings:null,// optional, subclass-specific settings structure
// Note: The indirection allows central control of many interpolants.
// --- Protected interface
DefaultSettings_:{},getSettings_:function(){return this.settings||this.DefaultSettings_;},copySampleValue_:function(index){// copies a sample value to the result buffer
var result=this.resultBuffer,values=this.sampleValues,stride=this.valueSize,offset=index*stride;for(var i=0;i!==stride;++i){result[i]=values[offset+i];}return result;},// Template methods for derived classes:
interpolate_:function()/* i1, t0, t, t1 */{throw new Error('call to abstract method');// implementations shall return this.resultBuffer
},intervalChanged_:function()/* i1, t0, t1 */{// empty
}});//!\ DECLARE ALIAS AFTER assign prototype !
Object.assign(Interpolant.prototype,{//( 0, t, t0 ), returns this.resultBuffer
beforeStart_:Interpolant.prototype.copySampleValue_,//( N-1, tN-1, t ), returns this.resultBuffer
afterEnd_:Interpolant.prototype.copySampleValue_});/**
* Spherical linear unit quaternion interpolant.
*
* @author tschw
*/function QuaternionLinearInterpolant(parameterPositions,sampleValues,sampleSize,resultBuffer){Interpolant.call(this,parameterPositions,sampleValues,sampleSize,resultBuffer);}QuaternionLinearInterpolant.prototype=Object.assign(Object.create(Interpolant.prototype),{constructor:QuaternionLinearInterpolant,interpolate_:function(i1,t0,t,t1){var result=this.resultBuffer,values=this.sampleValues,stride=this.valueSize,offset=i1*stride,alpha=(t-t0)/(t1-t0);for(var end=offset+stride;offset!==end;offset+=4){Quaternion.slerpFlat(result,0,values,offset-stride,values,offset,alpha);}return result;}});/**
*
* A Track of quaternion keyframe values.
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/function QuaternionKeyframeTrack(name,times,values,interpolation){KeyframeTrack.call(this,name,times,values,interpolation);}QuaternionKeyframeTrack.prototype=Object.assign(Object.create(KeyframeTrack.prototype),{constructor:QuaternionKeyframeTrack,ValueTypeName:'quaternion',// ValueBufferType is inherited
DefaultInterpolation:InterpolateLinear,InterpolantFactoryMethodLinear:function(result){return new QuaternionLinearInterpolant(this.times,this.values,this.getValueSize(),result);},InterpolantFactoryMethodSmooth:undefined// not yet implemented
});/**
*
* A Track of keyframe values that represent color.
*
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/function ColorKeyframeTrack(name,times,values,interpolation){KeyframeTrack.call(this,name,times,values,interpolation);}ColorKeyframeTrack.prototype=Object.assign(Object.create(KeyframeTrack.prototype),{constructor:ColorKeyframeTrack,ValueTypeName:'color'// ValueBufferType is inherited
// DefaultInterpolation is inherited
// Note: Very basic implementation and nothing special yet.
// However, this is the place for color space parameterization.
});/**
*
* A Track of numeric keyframe values.
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/function NumberKeyframeTrack(name,times,values,interpolation){KeyframeTrack.call(this,name,times,values,interpolation);}NumberKeyframeTrack.prototype=Object.assign(Object.create(KeyframeTrack.prototype),{constructor:NumberKeyframeTrack,ValueTypeName:'number'// ValueBufferType is inherited
// DefaultInterpolation is inherited
});/**
* Fast and simple cubic spline interpolant.
*
* It was derived from a Hermitian construction setting the first derivative
* at each sample position to the linear slope between neighboring positions
* over their parameter interval.
*
* @author tschw
*/function CubicInterpolant(parameterPositions,sampleValues,sampleSize,resultBuffer){Interpolant.call(this,parameterPositions,sampleValues,sampleSize,resultBuffer);this._weightPrev=-0;this._offsetPrev=-0;this._weightNext=-0;this._offsetNext=-0;}CubicInterpolant.prototype=Object.assign(Object.create(Interpolant.prototype),{constructor:CubicInterpolant,DefaultSettings_:{endingStart:ZeroCurvatureEnding,endingEnd:ZeroCurvatureEnding},intervalChanged_:function(i1,t0,t1){var pp=this.parameterPositions,iPrev=i1-2,iNext=i1+1,tPrev=pp[iPrev],tNext=pp[iNext];if(tPrev===undefined){switch(this.getSettings_().endingStart){case ZeroSlopeEnding:// f'(t0) = 0
iPrev=i1;tPrev=2*t0-t1;break;case WrapAroundEnding:// use the other end of the curve
iPrev=pp.length-2;tPrev=t0+pp[iPrev]-pp[iPrev+1];break;default:// ZeroCurvatureEnding
// f''(t0) = 0 a.k.a. Natural Spline
iPrev=i1;tPrev=t1;}}if(tNext===undefined){switch(this.getSettings_().endingEnd){case ZeroSlopeEnding:// f'(tN) = 0
iNext=i1;tNext=2*t1-t0;break;case WrapAroundEnding:// use the other end of the curve
iNext=1;tNext=t1+pp[1]-pp[0];break;default:// ZeroCurvatureEnding
// f''(tN) = 0, a.k.a. Natural Spline
iNext=i1-1;tNext=t0;}}var halfDt=(t1-t0)*0.5,stride=this.valueSize;this._weightPrev=halfDt/(t0-tPrev);this._weightNext=halfDt/(tNext-t1);this._offsetPrev=iPrev*stride;this._offsetNext=iNext*stride;},interpolate_:function(i1,t0,t,t1){var result=this.resultBuffer,values=this.sampleValues,stride=this.valueSize,o1=i1*stride,o0=o1-stride,oP=this._offsetPrev,oN=this._offsetNext,wP=this._weightPrev,wN=this._weightNext,p=(t-t0)/(t1-t0),pp=p*p,ppp=pp*p;// evaluate polynomials
var sP=-wP*ppp+2*wP*pp-wP*p;var s0=(1+wP)*ppp+(-1.5-2*wP)*pp+(-0.5+wP)*p+1;var s1=(-1-wN)*ppp+(1.5+wN)*pp+0.5*p;var sN=wN*ppp-wN*pp;// combine data linearly
for(var i=0;i!==stride;++i){result[i]=sP*values[oP+i]+s0*values[o0+i]+s1*values[o1+i]+sN*values[oN+i];}return result;}});/**
* @author tschw
*/function LinearInterpolant(parameterPositions,sampleValues,sampleSize,resultBuffer){Interpolant.call(this,parameterPositions,sampleValues,sampleSize,resultBuffer);}LinearInterpolant.prototype=Object.assign(Object.create(Interpolant.prototype),{constructor:LinearInterpolant,interpolate_:function(i1,t0,t,t1){var result=this.resultBuffer,values=this.sampleValues,stride=this.valueSize,offset1=i1*stride,offset0=offset1-stride,weight1=(t-t0)/(t1-t0),weight0=1-weight1;for(var i=0;i!==stride;++i){result[i]=values[offset0+i]*weight0+values[offset1+i]*weight1;}return result;}});/**
*
* Interpolant that evaluates to the sample value at the position preceeding
* the parameter.
*
* @author tschw
*/function DiscreteInterpolant(parameterPositions,sampleValues,sampleSize,resultBuffer){Interpolant.call(this,parameterPositions,sampleValues,sampleSize,resultBuffer);}DiscreteInterpolant.prototype=Object.assign(Object.create(Interpolant.prototype),{constructor:DiscreteInterpolant,interpolate_:function(i1/*, t0, t, t1 */){return this.copySampleValue_(i1-1);}});/**
* @author tschw
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
*/var AnimationUtils={// same as Array.prototype.slice, but also works on typed arrays
arraySlice:function(array,from,to){if(AnimationUtils.isTypedArray(array)){// in ios9 array.subarray(from, undefined) will return empty array
// but array.subarray(from) or array.subarray(from, len) is correct
return new array.constructor(array.subarray(from,to!==undefined?to:array.length));}return array.slice(from,to);},// converts an array to a specific type
convertArray:function(array,type,forceClone){if(!array||// let 'undefined' and 'null' pass
!forceClone&&array.constructor===type)return array;if(typeof type.BYTES_PER_ELEMENT==='number'){return new type(array);// create typed array
}return Array.prototype.slice.call(array);// create Array
},isTypedArray:function(object){return ArrayBuffer.isView(object)&&!(object instanceof DataView);},// returns an array by which times and values can be sorted
getKeyframeOrder:function(times){function compareTime(i,j){return times[i]-times[j];}var n=times.length;var result=new Array(n);for(var i=0;i!==n;++i)result[i]=i;result.sort(compareTime);return result;},// uses the array previously returned by 'getKeyframeOrder' to sort data
sortedArray:function(values,stride,order){var nValues=values.length;var result=new values.constructor(nValues);for(var i=0,dstOffset=0;dstOffset!==nValues;++i){var srcOffset=order[i]*stride;for(var j=0;j!==stride;++j){result[dstOffset++]=values[srcOffset+j];}}return result;},// function for parsing AOS keyframe formats
flattenJSON:function(jsonKeys,times,values,valuePropertyName){var i=1,key=jsonKeys[0];while(key!==undefined&&key[valuePropertyName]===undefined){key=jsonKeys[i++];}if(key===undefined)return;// no data
var value=key[valuePropertyName];if(value===undefined)return;// no data
if(Array.isArray(value)){do{value=key[valuePropertyName];if(value!==undefined){times.push(key.time);values.push.apply(values,value);// push all elements
}key=jsonKeys[i++];}while(key!==undefined);}else if(value.toArray!==undefined){// ...assume THREE.Math-ish
do{value=key[valuePropertyName];if(value!==undefined){times.push(key.time);value.toArray(values,values.length);}key=jsonKeys[i++];}while(key!==undefined);}else{// otherwise push as-is
do{value=key[valuePropertyName];if(value!==undefined){times.push(key.time);values.push(value);}key=jsonKeys[i++];}while(key!==undefined);}}};/**
*
* A timed sequence of keyframes for a specific property.
*
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/function KeyframeTrack(name,times,values,interpolation){if(name===undefined)throw new Error('THREE.KeyframeTrack: track name is undefined');if(times===undefined||times.length===0)throw new Error('THREE.KeyframeTrack: no keyframes in track named '+name);this.name=name;this.times=AnimationUtils.convertArray(times,this.TimeBufferType);this.values=AnimationUtils.convertArray(values,this.ValueBufferType);this.setInterpolation(interpolation||this.DefaultInterpolation);this.validate();this.optimize();}// Static methods:
Object.assign(KeyframeTrack,{// Serialization (in static context, because of constructor invocation
// and automatic invocation of .toJSON):
parse:function(json){if(json.type===undefined){throw new Error('THREE.KeyframeTrack: track type undefined, can not parse');}var trackType=KeyframeTrack._getTrackTypeForValueTypeName(json.type);if(json.times===undefined){var times=[],values=[];AnimationUtils.flattenJSON(json.keys,times,values,'value');json.times=times;json.values=values;}// derived classes can define a static parse method
if(trackType.parse!==undefined){return trackType.parse(json);}else{// by default, we assume a constructor compatible with the base
return new trackType(json.name,json.times,json.values,json.interpolation);}},toJSON:function(track){var trackType=track.constructor;var json;// derived classes can define a static toJSON method
if(trackType.toJSON!==undefined){json=trackType.toJSON(track);}else{// by default, we assume the data can be serialized as-is
json={'name':track.name,'times':AnimationUtils.convertArray(track.times,Array),'values':AnimationUtils.convertArray(track.values,Array)};var interpolation=track.getInterpolation();if(interpolation!==track.DefaultInterpolation){json.interpolation=interpolation;}}json.type=track.ValueTypeName;// mandatory
return json;},_getTrackTypeForValueTypeName:function(typeName){switch(typeName.toLowerCase()){case'scalar':case'double':case'float':case'number':case'integer':return NumberKeyframeTrack;case'vector':case'vector2':case'vector3':case'vector4':return VectorKeyframeTrack;case'color':return ColorKeyframeTrack;case'quaternion':return QuaternionKeyframeTrack;case'bool':case'boolean':return BooleanKeyframeTrack;case'string':return StringKeyframeTrack;}throw new Error('THREE.KeyframeTrack: Unsupported typeName: '+typeName);}});Object.assign(KeyframeTrack.prototype,{constructor:KeyframeTrack,TimeBufferType:Float32Array,ValueBufferType:Float32Array,DefaultInterpolation:InterpolateLinear,InterpolantFactoryMethodDiscrete:function(result){return new DiscreteInterpolant(this.times,this.values,this.getValueSize(),result);},InterpolantFactoryMethodLinear:function(result){return new LinearInterpolant(this.times,this.values,this.getValueSize(),result);},InterpolantFactoryMethodSmooth:function(result){return new CubicInterpolant(this.times,this.values,this.getValueSize(),result);},setInterpolation:function(interpolation){var factoryMethod;switch(interpolation){case InterpolateDiscrete:factoryMethod=this.InterpolantFactoryMethodDiscrete;break;case InterpolateLinear:factoryMethod=this.InterpolantFactoryMethodLinear;break;case InterpolateSmooth:factoryMethod=this.InterpolantFactoryMethodSmooth;break;}if(factoryMethod===undefined){var message="unsupported interpolation for "+this.ValueTypeName+" keyframe track named "+this.name;if(this.createInterpolant===undefined){// fall back to default, unless the default itself is messed up
if(interpolation!==this.DefaultInterpolation){this.setInterpolation(this.DefaultInterpolation);}else{throw new Error(message);// fatal, in this case
}}console.warn('THREE.KeyframeTrack:',message);return;}this.createInterpolant=factoryMethod;},getInterpolation:function(){switch(this.createInterpolant){case this.InterpolantFactoryMethodDiscrete:return InterpolateDiscrete;case this.InterpolantFactoryMethodLinear:return InterpolateLinear;case this.InterpolantFactoryMethodSmooth:return InterpolateSmooth;}},getValueSize:function(){return this.values.length/this.times.length;},// move all keyframes either forwards or backwards in time
shift:function(timeOffset){if(timeOffset!==0.0){var times=this.times;for(var i=0,n=times.length;i!==n;++i){times[i]+=timeOffset;}}return this;},// scale all keyframe times by a factor (useful for frame <-> seconds conversions)
scale:function(timeScale){if(timeScale!==1.0){var times=this.times;for(var i=0,n=times.length;i!==n;++i){times[i]*=timeScale;}}return this;},// removes keyframes before and after animation without changing any values within the range [startTime, endTime].
// IMPORTANT: We do not shift around keys to the start of the track time, because for interpolated keys this will change their values
trim:function(startTime,endTime){var times=this.times,nKeys=times.length,from=0,to=nKeys-1;while(from!==nKeys&&times[from]<startTime){++from;}while(to!==-1&&times[to]>endTime){--to;}++to;// inclusive -> exclusive bound
if(from!==0||to!==nKeys){// empty tracks are forbidden, so keep at least one keyframe
if(from>=to)to=Math.max(to,1),from=to-1;var stride=this.getValueSize();this.times=AnimationUtils.arraySlice(times,from,to);this.values=AnimationUtils.arraySlice(this.values,from*stride,to*stride);}return this;},// ensure we do not get a GarbageInGarbageOut situation, make sure tracks are at least minimally viable
validate:function(){var valid=true;var valueSize=this.getValueSize();if(valueSize-Math.floor(valueSize)!==0){console.error('THREE.KeyframeTrack: Invalid value size in track.',this);valid=false;}var times=this.times,values=this.values,nKeys=times.length;if(nKeys===0){console.error('THREE.KeyframeTrack: Track is empty.',this);valid=false;}var prevTime=null;for(var i=0;i!==nKeys;i++){var currTime=times[i];if(typeof currTime==='number'&&isNaN(currTime)){console.error('THREE.KeyframeTrack: Time is not a valid number.',this,i,currTime);valid=false;break;}if(prevTime!==null&&prevTime>currTime){console.error('THREE.KeyframeTrack: Out of order keys.',this,i,currTime,prevTime);valid=false;break;}prevTime=currTime;}if(values!==undefined){if(AnimationUtils.isTypedArray(values)){for(var i=0,n=values.length;i!==n;++i){var value=values[i];if(isNaN(value)){console.error('THREE.KeyframeTrack: Value is not a valid number.',this,i,value);valid=false;break;}}}}return valid;},// removes equivalent sequential keys as common in morph target sequences
// (0,0,0,0,1,1,1,0,0,0,0,0,0,0) --> (0,0,1,1,0,0)
optimize:function(){var times=this.times,values=this.values,stride=this.getValueSize(),smoothInterpolation=this.getInterpolation()===InterpolateSmooth,writeIndex=1,lastIndex=times.length-1;for(var i=1;i<lastIndex;++i){var keep=false;var time=times[i];var timeNext=times[i+1];// remove adjacent keyframes scheduled at the same time
if(time!==timeNext&&(i!==1||time!==time[0])){if(!smoothInterpolation){// remove unnecessary keyframes same as their neighbors
var offset=i*stride,offsetP=offset-stride,offsetN=offset+stride;for(var j=0;j!==stride;++j){var value=values[offset+j];if(value!==values[offsetP+j]||value!==values[offsetN+j]){keep=true;break;}}}else{keep=true;}}// in-place compaction
if(keep){if(i!==writeIndex){times[writeIndex]=times[i];var readOffset=i*stride,writeOffset=writeIndex*stride;for(var j=0;j!==stride;++j){values[writeOffset+j]=values[readOffset+j];}}++writeIndex;}}// flush last keyframe (compaction looks ahead)
if(lastIndex>0){times[writeIndex]=times[lastIndex];for(var readOffset=lastIndex*stride,writeOffset=writeIndex*stride,j=0;j!==stride;++j){values[writeOffset+j]=values[readOffset+j];}++writeIndex;}if(writeIndex!==times.length){this.times=AnimationUtils.arraySlice(times,0,writeIndex);this.values=AnimationUtils.arraySlice(values,0,writeIndex*stride);}return this;}});/**
*
* A Track of vectored keyframe values.
*
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/function VectorKeyframeTrack(name,times,values,interpolation){KeyframeTrack.call(this,name,times,values,interpolation);}VectorKeyframeTrack.prototype=Object.assign(Object.create(KeyframeTrack.prototype),{constructor:VectorKeyframeTrack,ValueTypeName:'vector'// ValueBufferType is inherited
// DefaultInterpolation is inherited
});/**
*
* Reusable set of Tracks that represent an animation.
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
*/function AnimationClip(name,duration,tracks){this.name=name;this.tracks=tracks;this.duration=duration!==undefined?duration:-1;this.uuid=_Math.generateUUID();// this means it should figure out its duration by scanning the tracks
if(this.duration<0){this.resetDuration();}this.optimize();}Object.assign(AnimationClip,{parse:function(json){var tracks=[],jsonTracks=json.tracks,frameTime=1.0/(json.fps||1.0);for(var i=0,n=jsonTracks.length;i!==n;++i){tracks.push(KeyframeTrack.parse(jsonTracks[i]).scale(frameTime));}return new AnimationClip(json.name,json.duration,tracks);},toJSON:function(clip){var tracks=[],clipTracks=clip.tracks;var json={'name':clip.name,'duration':clip.duration,'tracks':tracks};for(var i=0,n=clipTracks.length;i!==n;++i){tracks.push(KeyframeTrack.toJSON(clipTracks[i]));}return json;},CreateFromMorphTargetSequence:function(name,morphTargetSequence,fps,noLoop){var numMorphTargets=morphTargetSequence.length;var tracks=[];for(var i=0;i<numMorphTargets;i++){var times=[];var values=[];times.push((i+numMorphTargets-1)%numMorphTargets,i,(i+1)%numMorphTargets);values.push(0,1,0);var order=AnimationUtils.getKeyframeOrder(times);times=AnimationUtils.sortedArray(times,1,order);values=AnimationUtils.sortedArray(values,1,order);// if there is a key at the first frame, duplicate it as the
// last frame as well for perfect loop.
if(!noLoop&&times[0]===0){times.push(numMorphTargets);values.push(values[0]);}tracks.push(new NumberKeyframeTrack('.morphTargetInfluences['+morphTargetSequence[i].name+']',times,values).scale(1.0/fps));}return new AnimationClip(name,-1,tracks);},findByName:function(objectOrClipArray,name){var clipArray=objectOrClipArray;if(!Array.isArray(objectOrClipArray)){var o=objectOrClipArray;clipArray=o.geometry&&o.geometry.animations||o.animations;}for(var i=0;i<clipArray.length;i++){if(clipArray[i].name===name){return clipArray[i];}}return null;},CreateClipsFromMorphTargetSequences:function(morphTargets,fps,noLoop){var animationToMorphTargets={};// tested with https://regex101.com/ on trick sequences
// such flamingo_flyA_003, flamingo_run1_003, crdeath0059
var pattern=/^([\w-]*?)([\d]+)$/;// sort morph target names into animation groups based
// patterns like Walk_001, Walk_002, Run_001, Run_002
for(var i=0,il=morphTargets.length;i<il;i++){var morphTarget=morphTargets[i];var parts=morphTarget.name.match(pattern);if(parts&&parts.length>1){var name=parts[1];var animationMorphTargets=animationToMorphTargets[name];if(!animationMorphTargets){animationToMorphTargets[name]=animationMorphTargets=[];}animationMorphTargets.push(morphTarget);}}var clips=[];for(var name in animationToMorphTargets){clips.push(AnimationClip.CreateFromMorphTargetSequence(name,animationToMorphTargets[name],fps,noLoop));}return clips;},// parse the animation.hierarchy format
parseAnimation:function(animation,bones){if(!animation){console.error('THREE.AnimationClip: No animation in JSONLoader data.');return null;}var addNonemptyTrack=function(trackType,trackName,animationKeys,propertyName,destTracks){// only return track if there are actually keys.
if(animationKeys.length!==0){var times=[];var values=[];AnimationUtils.flattenJSON(animationKeys,times,values,propertyName);// empty keys are filtered out, so check again
if(times.length!==0){destTracks.push(new trackType(trackName,times,values));}}};var tracks=[];var clipName=animation.name||'default';// automatic length determination in AnimationClip.
var duration=animation.length||-1;var fps=animation.fps||30;var hierarchyTracks=animation.hierarchy||[];for(var h=0;h<hierarchyTracks.length;h++){var animationKeys=hierarchyTracks[h].keys;// skip empty tracks
if(!animationKeys||animationKeys.length===0)continue;// process morph targets
if(animationKeys[0].morphTargets){// figure out all morph targets used in this track
var morphTargetNames={};for(var k=0;k<animationKeys.length;k++){if(animationKeys[k].morphTargets){for(var m=0;m<animationKeys[k].morphTargets.length;m++){morphTargetNames[animationKeys[k].morphTargets[m]]=-1;}}}// create a track for each morph target with all zero
// morphTargetInfluences except for the keys in which
// the morphTarget is named.
for(var morphTargetName in morphTargetNames){var times=[];var values=[];for(var m=0;m!==animationKeys[k].morphTargets.length;++m){var animationKey=animationKeys[k];times.push(animationKey.time);values.push(animationKey.morphTarget===morphTargetName?1:0);}tracks.push(new NumberKeyframeTrack('.morphTargetInfluence['+morphTargetName+']',times,values));}duration=morphTargetNames.length*(fps||1.0);}else{// ...assume skeletal animation
var boneName='.bones['+bones[h].name+']';addNonemptyTrack(VectorKeyframeTrack,boneName+'.position',animationKeys,'pos',tracks);addNonemptyTrack(QuaternionKeyframeTrack,boneName+'.quaternion',animationKeys,'rot',tracks);addNonemptyTrack(VectorKeyframeTrack,boneName+'.scale',animationKeys,'scl',tracks);}}if(tracks.length===0){return null;}var clip=new AnimationClip(clipName,duration,tracks);return clip;}});Object.assign(AnimationClip.prototype,{resetDuration:function(){var tracks=this.tracks,duration=0;for(var i=0,n=tracks.length;i!==n;++i){var track=this.tracks[i];duration=Math.max(duration,track.times[track.times.length-1]);}this.duration=duration;},trim:function(){for(var i=0;i<this.tracks.length;i++){this.tracks[i].trim(0,this.duration);}return this;},optimize:function(){for(var i=0;i<this.tracks.length;i++){this.tracks[i].optimize();}return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/function MaterialLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;this.textures={};}Object.assign(MaterialLoader.prototype,{load:function(url,onLoad,onProgress,onError){var scope=this;var loader=new FileLoader(scope.manager);loader.load(url,function(text){onLoad(scope.parse(JSON.parse(text)));},onProgress,onError);},setTextures:function(value){this.textures=value;},parse:function(json){var textures=this.textures;function getTexture(name){if(textures[name]===undefined){console.warn('THREE.MaterialLoader: Undefined texture',name);}return textures[name];}var material=new Materials[json.type]();if(json.uuid!==undefined)material.uuid=json.uuid;if(json.name!==undefined)material.name=json.name;if(json.color!==undefined)material.color.setHex(json.color);if(json.roughness!==undefined)material.roughness=json.roughness;if(json.metalness!==undefined)material.metalness=json.metalness;if(json.emissive!==undefined)material.emissive.setHex(json.emissive);if(json.specular!==undefined)material.specular.setHex(json.specular);if(json.shininess!==undefined)material.shininess=json.shininess;if(json.clearCoat!==undefined)material.clearCoat=json.clearCoat;if(json.clearCoatRoughness!==undefined)material.clearCoatRoughness=json.clearCoatRoughness;if(json.uniforms!==undefined)material.uniforms=json.uniforms;if(json.vertexShader!==undefined)material.vertexShader=json.vertexShader;if(json.fragmentShader!==undefined)material.fragmentShader=json.fragmentShader;if(json.vertexColors!==undefined)material.vertexColors=json.vertexColors;if(json.fog!==undefined)material.fog=json.fog;if(json.flatShading!==undefined)material.flatShading=json.flatShading;if(json.blending!==undefined)material.blending=json.blending;if(json.side!==undefined)material.side=json.side;if(json.opacity!==undefined)material.opacity=json.opacity;if(json.transparent!==undefined)material.transparent=json.transparent;if(json.alphaTest!==undefined)material.alphaTest=json.alphaTest;if(json.depthTest!==undefined)material.depthTest=json.depthTest;if(json.depthWrite!==undefined)material.depthWrite=json.depthWrite;if(json.colorWrite!==undefined)material.colorWrite=json.colorWrite;if(json.wireframe!==undefined)material.wireframe=json.wireframe;if(json.wireframeLinewidth!==undefined)material.wireframeLinewidth=json.wireframeLinewidth;if(json.wireframeLinecap!==undefined)material.wireframeLinecap=json.wireframeLinecap;if(json.wireframeLinejoin!==undefined)material.wireframeLinejoin=json.wireframeLinejoin;if(json.rotation!==undefined)material.rotation=json.rotation;if(json.linewidth!==1)material.linewidth=json.linewidth;if(json.dashSize!==undefined)material.dashSize=json.dashSize;if(json.gapSize!==undefined)material.gapSize=json.gapSize;if(json.scale!==undefined)material.scale=json.scale;if(json.polygonOffset!==undefined)material.polygonOffset=json.polygonOffset;if(json.polygonOffsetFactor!==undefined)material.polygonOffsetFactor=json.polygonOffsetFactor;if(json.polygonOffsetUnits!==undefined)material.polygonOffsetUnits=json.polygonOffsetUnits;if(json.skinning!==undefined)material.skinning=json.skinning;if(json.morphTargets!==undefined)material.morphTargets=json.morphTargets;if(json.dithering!==undefined)material.dithering=json.dithering;if(json.visible!==undefined)material.visible=json.visible;if(json.userData!==undefined)material.userData=json.userData;// Deprecated
if(json.shading!==undefined)material.flatShading=json.shading===1;// THREE.FlatShading
// for PointsMaterial
if(json.size!==undefined)material.size=json.size;if(json.sizeAttenuation!==undefined)material.sizeAttenuation=json.sizeAttenuation;// maps
if(json.map!==undefined)material.map=getTexture(json.map);if(json.alphaMap!==undefined){material.alphaMap=getTexture(json.alphaMap);material.transparent=true;}if(json.bumpMap!==undefined)material.bumpMap=getTexture(json.bumpMap);if(json.bumpScale!==undefined)material.bumpScale=json.bumpScale;if(json.normalMap!==undefined)material.normalMap=getTexture(json.normalMap);if(json.normalScale!==undefined){var normalScale=json.normalScale;if(Array.isArray(normalScale)===false){// Blender exporter used to export a scalar. See #7459
normalScale=[normalScale,normalScale];}material.normalScale=new Vector2().fromArray(normalScale);}if(json.displacementMap!==undefined)material.displacementMap=getTexture(json.displacementMap);if(json.displacementScale!==undefined)material.displacementScale=json.displacementScale;if(json.displacementBias!==undefined)material.displacementBias=json.displacementBias;if(json.roughnessMap!==undefined)material.roughnessMap=getTexture(json.roughnessMap);if(json.metalnessMap!==undefined)material.metalnessMap=getTexture(json.metalnessMap);if(json.emissiveMap!==undefined)material.emissiveMap=getTexture(json.emissiveMap);if(json.emissiveIntensity!==undefined)material.emissiveIntensity=json.emissiveIntensity;if(json.specularMap!==undefined)material.specularMap=getTexture(json.specularMap);if(json.envMap!==undefined)material.envMap=getTexture(json.envMap);if(json.reflectivity!==undefined)material.reflectivity=json.reflectivity;if(json.lightMap!==undefined)material.lightMap=getTexture(json.lightMap);if(json.lightMapIntensity!==undefined)material.lightMapIntensity=json.lightMapIntensity;if(json.aoMap!==undefined)material.aoMap=getTexture(json.aoMap);if(json.aoMapIntensity!==undefined)material.aoMapIntensity=json.aoMapIntensity;if(json.gradientMap!==undefined)material.gradientMap=getTexture(json.gradientMap);return material;}});/**
* @author mrdoob / http://mrdoob.com/
*/function BufferGeometryLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;}Object.assign(BufferGeometryLoader.prototype,{load:function(url,onLoad,onProgress,onError){var scope=this;var loader=new FileLoader(scope.manager);loader.load(url,function(text){onLoad(scope.parse(JSON.parse(text)));},onProgress,onError);},parse:function(json){var geometry=new BufferGeometry();var index=json.data.index;if(index!==undefined){var typedArray=new TYPED_ARRAYS[index.type](index.array);geometry.setIndex(new BufferAttribute(typedArray,1));}var attributes=json.data.attributes;for(var key in attributes){var attribute=attributes[key];var typedArray=new TYPED_ARRAYS[attribute.type](attribute.array);geometry.addAttribute(key,new BufferAttribute(typedArray,attribute.itemSize,attribute.normalized));}var groups=json.data.groups||json.data.drawcalls||json.data.offsets;if(groups!==undefined){for(var i=0,n=groups.length;i!==n;++i){var group=groups[i];geometry.addGroup(group.start,group.count,group.materialIndex);}}var boundingSphere=json.data.boundingSphere;if(boundingSphere!==undefined){var center=new Vector3();if(boundingSphere.center!==undefined){center.fromArray(boundingSphere.center);}geometry.boundingSphere=new Sphere(center,boundingSphere.radius);}return geometry;}});var TYPED_ARRAYS={Int8Array:Int8Array,Uint8Array:Uint8Array,// Workaround for IE11 pre KB2929437. See #11440
Uint8ClampedArray:typeof Uint8ClampedArray!=='undefined'?Uint8ClampedArray:Uint8Array,Int16Array:Int16Array,Uint16Array:Uint16Array,Int32Array:Int32Array,Uint32Array:Uint32Array,Float32Array:Float32Array,Float64Array:Float64Array};/**
* @author alteredq / http://alteredqualia.com/
*/function Loader(){}Loader.Handlers={handlers:[],add:function(regex,loader){this.handlers.push(regex,loader);},get:function(file){var handlers=this.handlers;for(var i=0,l=handlers.length;i<l;i+=2){var regex=handlers[i];var loader=handlers[i+1];if(regex.test(file)){return loader;}}return null;}};Object.assign(Loader.prototype,{crossOrigin:undefined,onLoadStart:function(){},onLoadProgress:function(){},onLoadComplete:function(){},initMaterials:function(materials,texturePath,crossOrigin){var array=[];for(var i=0;i<materials.length;++i){array[i]=this.createMaterial(materials[i],texturePath,crossOrigin);}return array;},createMaterial:function(){var BlendingMode={NoBlending:NoBlending,NormalBlending:NormalBlending,AdditiveBlending:AdditiveBlending,SubtractiveBlending:SubtractiveBlending,MultiplyBlending:MultiplyBlending,CustomBlending:CustomBlending};var color=new Color();var textureLoader=new TextureLoader();var materialLoader=new MaterialLoader();return function createMaterial(m,texturePath,crossOrigin){// convert from old material format
var textures={};function loadTexture(path,repeat,offset,wrap,anisotropy){var fullPath=texturePath+path;var loader=Loader.Handlers.get(fullPath);var texture;if(loader!==null){texture=loader.load(fullPath);}else{textureLoader.setCrossOrigin(crossOrigin);texture=textureLoader.load(fullPath);}if(repeat!==undefined){texture.repeat.fromArray(repeat);if(repeat[0]!==1)texture.wrapS=RepeatWrapping;if(repeat[1]!==1)texture.wrapT=RepeatWrapping;}if(offset!==undefined){texture.offset.fromArray(offset);}if(wrap!==undefined){if(wrap[0]==='repeat')texture.wrapS=RepeatWrapping;if(wrap[0]==='mirror')texture.wrapS=MirroredRepeatWrapping;if(wrap[1]==='repeat')texture.wrapT=RepeatWrapping;if(wrap[1]==='mirror')texture.wrapT=MirroredRepeatWrapping;}if(anisotropy!==undefined){texture.anisotropy=anisotropy;}var uuid=_Math.generateUUID();textures[uuid]=texture;return uuid;}//
var json={uuid:_Math.generateUUID(),type:'MeshLambertMaterial'};for(var name in m){var value=m[name];switch(name){case'DbgColor':case'DbgIndex':case'opticalDensity':case'illumination':break;case'DbgName':json.name=value;break;case'blending':json.blending=BlendingMode[value];break;case'colorAmbient':case'mapAmbient':console.warn('THREE.Loader.createMaterial:',name,'is no longer supported.');break;case'colorDiffuse':json.color=color.fromArray(value).getHex();break;case'colorSpecular':json.specular=color.fromArray(value).getHex();break;case'colorEmissive':json.emissive=color.fromArray(value).getHex();break;case'specularCoef':json.shininess=value;break;case'shading':if(value.toLowerCase()==='basic')json.type='MeshBasicMaterial';if(value.toLowerCase()==='phong')json.type='MeshPhongMaterial';if(value.toLowerCase()==='standard')json.type='MeshStandardMaterial';break;case'mapDiffuse':json.map=loadTexture(value,m.mapDiffuseRepeat,m.mapDiffuseOffset,m.mapDiffuseWrap,m.mapDiffuseAnisotropy);break;case'mapDiffuseRepeat':case'mapDiffuseOffset':case'mapDiffuseWrap':case'mapDiffuseAnisotropy':break;case'mapEmissive':json.emissiveMap=loadTexture(value,m.mapEmissiveRepeat,m.mapEmissiveOffset,m.mapEmissiveWrap,m.mapEmissiveAnisotropy);break;case'mapEmissiveRepeat':case'mapEmissiveOffset':case'mapEmissiveWrap':case'mapEmissiveAnisotropy':break;case'mapLight':json.lightMap=loadTexture(value,m.mapLightRepeat,m.mapLightOffset,m.mapLightWrap,m.mapLightAnisotropy);break;case'mapLightRepeat':case'mapLightOffset':case'mapLightWrap':case'mapLightAnisotropy':break;case'mapAO':json.aoMap=loadTexture(value,m.mapAORepeat,m.mapAOOffset,m.mapAOWrap,m.mapAOAnisotropy);break;case'mapAORepeat':case'mapAOOffset':case'mapAOWrap':case'mapAOAnisotropy':break;case'mapBump':json.bumpMap=loadTexture(value,m.mapBumpRepeat,m.mapBumpOffset,m.mapBumpWrap,m.mapBumpAnisotropy);break;case'mapBumpScale':json.bumpScale=value;break;case'mapBumpRepeat':case'mapBumpOffset':case'mapBumpWrap':case'mapBumpAnisotropy':break;case'mapNormal':json.normalMap=loadTexture(value,m.mapNormalRepeat,m.mapNormalOffset,m.mapNormalWrap,m.mapNormalAnisotropy);break;case'mapNormalFactor':json.normalScale=value;break;case'mapNormalRepeat':case'mapNormalOffset':case'mapNormalWrap':case'mapNormalAnisotropy':break;case'mapSpecular':json.specularMap=loadTexture(value,m.mapSpecularRepeat,m.mapSpecularOffset,m.mapSpecularWrap,m.mapSpecularAnisotropy);break;case'mapSpecularRepeat':case'mapSpecularOffset':case'mapSpecularWrap':case'mapSpecularAnisotropy':break;case'mapMetalness':json.metalnessMap=loadTexture(value,m.mapMetalnessRepeat,m.mapMetalnessOffset,m.mapMetalnessWrap,m.mapMetalnessAnisotropy);break;case'mapMetalnessRepeat':case'mapMetalnessOffset':case'mapMetalnessWrap':case'mapMetalnessAnisotropy':break;case'mapRoughness':json.roughnessMap=loadTexture(value,m.mapRoughnessRepeat,m.mapRoughnessOffset,m.mapRoughnessWrap,m.mapRoughnessAnisotropy);break;case'mapRoughnessRepeat':case'mapRoughnessOffset':case'mapRoughnessWrap':case'mapRoughnessAnisotropy':break;case'mapAlpha':json.alphaMap=loadTexture(value,m.mapAlphaRepeat,m.mapAlphaOffset,m.mapAlphaWrap,m.mapAlphaAnisotropy);break;case'mapAlphaRepeat':case'mapAlphaOffset':case'mapAlphaWrap':case'mapAlphaAnisotropy':break;case'flipSided':json.side=BackSide;break;case'doubleSided':json.side=DoubleSide;break;case'transparency':console.warn('THREE.Loader.createMaterial: transparency has been renamed to opacity');json.opacity=value;break;case'depthTest':case'depthWrite':case'colorWrite':case'opacity':case'reflectivity':case'transparent':case'visible':case'wireframe':json[name]=value;break;case'vertexColors':if(value===true)json.vertexColors=VertexColors;if(value==='face')json.vertexColors=FaceColors;break;default:console.error('THREE.Loader.createMaterial: Unsupported',name,value);break;}}if(json.type==='MeshBasicMaterial')delete json.emissive;if(json.type!=='MeshPhongMaterial')delete json.specular;if(json.opacity<1)json.transparent=true;materialLoader.setTextures(textures);return materialLoader.parse(json);};}()});/**
* @author Don McCurdy / https://www.donmccurdy.com
*/var LoaderUtils={decodeText:function(array){if(typeof TextDecoder!=='undefined'){return new TextDecoder().decode(array);}// Avoid the String.fromCharCode.apply(null, array) shortcut, which
// throws a "maximum call stack size exceeded" error for large arrays.
var s='';for(var i=0,il=array.length;i<il;i++){// Implicitly assumes little-endian.
s+=String.fromCharCode(array[i]);}// Merges multi-byte utf-8 characters.
return decodeURIComponent(escape(s));},extractUrlBase:function(url){var index=url.lastIndexOf('/');if(index===-1)return './';return url.substr(0,index+1);}};/**
* @author mrdoob / http://mrdoob.com/
* @author alteredq / http://alteredqualia.com/
*/function JSONLoader(manager){if(typeof manager==='boolean'){console.warn('THREE.JSONLoader: showStatus parameter has been removed from constructor.');manager=undefined;}this.manager=manager!==undefined?manager:DefaultLoadingManager;this.withCredentials=false;}Object.assign(JSONLoader.prototype,{load:function(url,onLoad,onProgress,onError){var scope=this;var texturePath=this.texturePath&&typeof this.texturePath==='string'?this.texturePath:LoaderUtils.extractUrlBase(url);var loader=new FileLoader(this.manager);loader.setWithCredentials(this.withCredentials);loader.load(url,function(text){var json=JSON.parse(text);var metadata=json.metadata;if(metadata!==undefined){var type=metadata.type;if(type!==undefined){if(type.toLowerCase()==='object'){console.error('THREE.JSONLoader: '+url+' should be loaded with THREE.ObjectLoader instead.');return;}}}var object=scope.parse(json,texturePath);onLoad(object.geometry,object.materials);},onProgress,onError);},setTexturePath:function(value){this.texturePath=value;},parse:function(){function parseModel(json,geometry){function isBitSet(value,position){return value&1<<position;}var i,j,fi,offset,zLength,colorIndex,normalIndex,uvIndex,materialIndex,type,isQuad,hasMaterial,hasFaceVertexUv,hasFaceNormal,hasFaceVertexNormal,hasFaceColor,hasFaceVertexColor,vertex,face,faceA,faceB,hex,normal,uvLayer,uv,u,v,faces=json.faces,vertices=json.vertices,normals=json.normals,colors=json.colors,scale=json.scale,nUvLayers=0;if(json.uvs!==undefined){// disregard empty arrays
for(i=0;i<json.uvs.length;i++){if(json.uvs[i].length)nUvLayers++;}for(i=0;i<nUvLayers;i++){geometry.faceVertexUvs[i]=[];}}offset=0;zLength=vertices.length;while(offset<zLength){vertex=new Vector3();vertex.x=vertices[offset++]*scale;vertex.y=vertices[offset++]*scale;vertex.z=vertices[offset++]*scale;geometry.vertices.push(vertex);}offset=0;zLength=faces.length;while(offset<zLength){type=faces[offset++];isQuad=isBitSet(type,0);hasMaterial=isBitSet(type,1);hasFaceVertexUv=isBitSet(type,3);hasFaceNormal=isBitSet(type,4);hasFaceVertexNormal=isBitSet(type,5);hasFaceColor=isBitSet(type,6);hasFaceVertexColor=isBitSet(type,7);// console.log("type", type, "bits", isQuad, hasMaterial, hasFaceVertexUv, hasFaceNormal, hasFaceVertexNormal, hasFaceColor, hasFaceVertexColor);
if(isQuad){faceA=new Face3();faceA.a=faces[offset];faceA.b=faces[offset+1];faceA.c=faces[offset+3];faceB=new Face3();faceB.a=faces[offset+1];faceB.b=faces[offset+2];faceB.c=faces[offset+3];offset+=4;if(hasMaterial){materialIndex=faces[offset++];faceA.materialIndex=materialIndex;faceB.materialIndex=materialIndex;}// to get face <=> uv index correspondence
fi=geometry.faces.length;if(hasFaceVertexUv){for(i=0;i<nUvLayers;i++){uvLayer=json.uvs[i];geometry.faceVertexUvs[i][fi]=[];geometry.faceVertexUvs[i][fi+1]=[];for(j=0;j<4;j++){uvIndex=faces[offset++];u=uvLayer[uvIndex*2];v=uvLayer[uvIndex*2+1];uv=new Vector2(u,v);if(j!==2)geometry.faceVertexUvs[i][fi].push(uv);if(j!==0)geometry.faceVertexUvs[i][fi+1].push(uv);}}}if(hasFaceNormal){normalIndex=faces[offset++]*3;faceA.normal.set(normals[normalIndex++],normals[normalIndex++],normals[normalIndex]);faceB.normal.copy(faceA.normal);}if(hasFaceVertexNormal){for(i=0;i<4;i++){normalIndex=faces[offset++]*3;normal=new Vector3(normals[normalIndex++],normals[normalIndex++],normals[normalIndex]);if(i!==2)faceA.vertexNormals.push(normal);if(i!==0)faceB.vertexNormals.push(normal);}}if(hasFaceColor){colorIndex=faces[offset++];hex=colors[colorIndex];faceA.color.setHex(hex);faceB.color.setHex(hex);}if(hasFaceVertexColor){for(i=0;i<4;i++){colorIndex=faces[offset++];hex=colors[colorIndex];if(i!==2)faceA.vertexColors.push(new Color(hex));if(i!==0)faceB.vertexColors.push(new Color(hex));}}geometry.faces.push(faceA);geometry.faces.push(faceB);}else{face=new Face3();face.a=faces[offset++];face.b=faces[offset++];face.c=faces[offset++];if(hasMaterial){materialIndex=faces[offset++];face.materialIndex=materialIndex;}// to get face <=> uv index correspondence
fi=geometry.faces.length;if(hasFaceVertexUv){for(i=0;i<nUvLayers;i++){uvLayer=json.uvs[i];geometry.faceVertexUvs[i][fi]=[];for(j=0;j<3;j++){uvIndex=faces[offset++];u=uvLayer[uvIndex*2];v=uvLayer[uvIndex*2+1];uv=new Vector2(u,v);geometry.faceVertexUvs[i][fi].push(uv);}}}if(hasFaceNormal){normalIndex=faces[offset++]*3;face.normal.set(normals[normalIndex++],normals[normalIndex++],normals[normalIndex]);}if(hasFaceVertexNormal){for(i=0;i<3;i++){normalIndex=faces[offset++]*3;normal=new Vector3(normals[normalIndex++],normals[normalIndex++],normals[normalIndex]);face.vertexNormals.push(normal);}}if(hasFaceColor){colorIndex=faces[offset++];face.color.setHex(colors[colorIndex]);}if(hasFaceVertexColor){for(i=0;i<3;i++){colorIndex=faces[offset++];face.vertexColors.push(new Color(colors[colorIndex]));}}geometry.faces.push(face);}}}function parseSkin(json,geometry){var influencesPerVertex=json.influencesPerVertex!==undefined?json.influencesPerVertex:2;if(json.skinWeights){for(var i=0,l=json.skinWeights.length;i<l;i+=influencesPerVertex){var x=json.skinWeights[i];var y=influencesPerVertex>1?json.skinWeights[i+1]:0;var z=influencesPerVertex>2?json.skinWeights[i+2]:0;var w=influencesPerVertex>3?json.skinWeights[i+3]:0;geometry.skinWeights.push(new Vector4(x,y,z,w));}}if(json.skinIndices){for(var i=0,l=json.skinIndices.length;i<l;i+=influencesPerVertex){var a=json.skinIndices[i];var b=influencesPerVertex>1?json.skinIndices[i+1]:0;var c=influencesPerVertex>2?json.skinIndices[i+2]:0;var d=influencesPerVertex>3?json.skinIndices[i+3]:0;geometry.skinIndices.push(new Vector4(a,b,c,d));}}geometry.bones=json.bones;if(geometry.bones&&geometry.bones.length>0&&(geometry.skinWeights.length!==geometry.skinIndices.length||geometry.skinIndices.length!==geometry.vertices.length)){console.warn('When skinning, number of vertices ('+geometry.vertices.length+'), skinIndices ('+geometry.skinIndices.length+'), and skinWeights ('+geometry.skinWeights.length+') should match.');}}function parseMorphing(json,geometry){var scale=json.scale;if(json.morphTargets!==undefined){for(var i=0,l=json.morphTargets.length;i<l;i++){geometry.morphTargets[i]={};geometry.morphTargets[i].name=json.morphTargets[i].name;geometry.morphTargets[i].vertices=[];var dstVertices=geometry.morphTargets[i].vertices;var srcVertices=json.morphTargets[i].vertices;for(var v=0,vl=srcVertices.length;v<vl;v+=3){var vertex=new Vector3();vertex.x=srcVertices[v]*scale;vertex.y=srcVertices[v+1]*scale;vertex.z=srcVertices[v+2]*scale;dstVertices.push(vertex);}}}if(json.morphColors!==undefined&&json.morphColors.length>0){console.warn('THREE.JSONLoader: "morphColors" no longer supported. Using them as face colors.');var faces=geometry.faces;var morphColors=json.morphColors[0].colors;for(var i=0,l=faces.length;i<l;i++){faces[i].color.fromArray(morphColors,i*3);}}}function parseAnimations(json,geometry){var outputAnimations=[];// parse old style Bone/Hierarchy animations
var animations=[];if(json.animation!==undefined){animations.push(json.animation);}if(json.animations!==undefined){if(json.animations.length){animations=animations.concat(json.animations);}else{animations.push(json.animations);}}for(var i=0;i<animations.length;i++){var clip=AnimationClip.parseAnimation(animations[i],geometry.bones);if(clip)outputAnimations.push(clip);}// parse implicit morph animations
if(geometry.morphTargets){// TODO: Figure out what an appropraite FPS is for morph target animations -- defaulting to 10, but really it is completely arbitrary.
var morphAnimationClips=AnimationClip.CreateClipsFromMorphTargetSequences(geometry.morphTargets,10);outputAnimations=outputAnimations.concat(morphAnimationClips);}if(outputAnimations.length>0)geometry.animations=outputAnimations;}return function parse(json,texturePath){if(json.data!==undefined){// Geometry 4.0 spec
json=json.data;}if(json.scale!==undefined){json.scale=1.0/json.scale;}else{json.scale=1.0;}var geometry=new Geometry();parseModel(json,geometry);parseSkin(json,geometry);parseMorphing(json,geometry);parseAnimations(json,geometry);geometry.computeFaceNormals();geometry.computeBoundingSphere();if(json.materials===undefined||json.materials.length===0){return {geometry:geometry};}else{var materials=Loader.prototype.initMaterials(json.materials,texturePath,this.crossOrigin);return {geometry:geometry,materials:materials};}};}()});/**
* @author mrdoob / http://mrdoob.com/
*/function ObjectLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;this.texturePath='';}Object.assign(ObjectLoader.prototype,{load:function(url,onLoad,onProgress,onError){if(this.texturePath===''){this.texturePath=url.substring(0,url.lastIndexOf('/')+1);}var scope=this;var loader=new FileLoader(scope.manager);loader.load(url,function(text){var json=null;try{json=JSON.parse(text);}catch(error){if(onError!==undefined)onError(error);console.error('THREE:ObjectLoader: Can\'t parse '+url+'.',error.message);return;}var metadata=json.metadata;if(metadata===undefined||metadata.type===undefined||metadata.type.toLowerCase()==='geometry'){console.error('THREE.ObjectLoader: Can\'t load '+url+'. Use THREE.JSONLoader instead.');return;}scope.parse(json,onLoad);},onProgress,onError);},setTexturePath:function(value){this.texturePath=value;},setCrossOrigin:function(value){this.crossOrigin=value;},parse:function(json,onLoad){var shapes=this.parseShape(json.shapes);var geometries=this.parseGeometries(json.geometries,shapes);var images=this.parseImages(json.images,function(){if(onLoad!==undefined)onLoad(object);});var textures=this.parseTextures(json.textures,images);var materials=this.parseMaterials(json.materials,textures);var object=this.parseObject(json.object,geometries,materials);if(json.animations){object.animations=this.parseAnimations(json.animations);}if(json.images===undefined||json.images.length===0){if(onLoad!==undefined)onLoad(object);}return object;},parseShape:function(json){var shapes={};if(json!==undefined){for(var i=0,l=json.length;i<l;i++){var shape=new Shape().fromJSON(json[i]);shapes[shape.uuid]=shape;}}return shapes;},parseGeometries:function(json,shapes){var geometries={};if(json!==undefined){var geometryLoader=new JSONLoader();var bufferGeometryLoader=new BufferGeometryLoader();for(var i=0,l=json.length;i<l;i++){var geometry;var data=json[i];switch(data.type){case'PlaneGeometry':case'PlaneBufferGeometry':geometry=new Geometries[data.type](data.width,data.height,data.widthSegments,data.heightSegments);break;case'BoxGeometry':case'BoxBufferGeometry':case'CubeGeometry':// backwards compatible
geometry=new Geometries[data.type](data.width,data.height,data.depth,data.widthSegments,data.heightSegments,data.depthSegments);break;case'CircleGeometry':case'CircleBufferGeometry':geometry=new Geometries[data.type](data.radius,data.segments,data.thetaStart,data.thetaLength);break;case'CylinderGeometry':case'CylinderBufferGeometry':geometry=new Geometries[data.type](data.radiusTop,data.radiusBottom,data.height,data.radialSegments,data.heightSegments,data.openEnded,data.thetaStart,data.thetaLength);break;case'ConeGeometry':case'ConeBufferGeometry':geometry=new Geometries[data.type](data.radius,data.height,data.radialSegments,data.heightSegments,data.openEnded,data.thetaStart,data.thetaLength);break;case'SphereGeometry':case'SphereBufferGeometry':geometry=new Geometries[data.type](data.radius,data.widthSegments,data.heightSegments,data.phiStart,data.phiLength,data.thetaStart,data.thetaLength);break;case'DodecahedronGeometry':case'DodecahedronBufferGeometry':case'IcosahedronGeometry':case'IcosahedronBufferGeometry':case'OctahedronGeometry':case'OctahedronBufferGeometry':case'TetrahedronGeometry':case'TetrahedronBufferGeometry':geometry=new Geometries[data.type](data.radius,data.detail);break;case'RingGeometry':case'RingBufferGeometry':geometry=new Geometries[data.type](data.innerRadius,data.outerRadius,data.thetaSegments,data.phiSegments,data.thetaStart,data.thetaLength);break;case'TorusGeometry':case'TorusBufferGeometry':geometry=new Geometries[data.type](data.radius,data.tube,data.radialSegments,data.tubularSegments,data.arc);break;case'TorusKnotGeometry':case'TorusKnotBufferGeometry':geometry=new Geometries[data.type](data.radius,data.tube,data.tubularSegments,data.radialSegments,data.p,data.q);break;case'LatheGeometry':case'LatheBufferGeometry':geometry=new Geometries[data.type](data.points,data.segments,data.phiStart,data.phiLength);break;case'PolyhedronGeometry':case'PolyhedronBufferGeometry':geometry=new Geometries[data.type](data.vertices,data.indices,data.radius,data.details);break;case'ShapeGeometry':case'ShapeBufferGeometry':var geometryShapes=[];for(var j=0,jl=data.shapes.length;j<jl;j++){var shape=shapes[data.shapes[j]];geometryShapes.push(shape);}geometry=new Geometries[data.type](geometryShapes,data.curveSegments);break;case'BufferGeometry':geometry=bufferGeometryLoader.parse(data);break;case'Geometry':geometry=geometryLoader.parse(data,this.texturePath).geometry;break;default:console.warn('THREE.ObjectLoader: Unsupported geometry type "'+data.type+'"');continue;}geometry.uuid=data.uuid;if(data.name!==undefined)geometry.name=data.name;geometries[data.uuid]=geometry;}}return geometries;},parseMaterials:function(json,textures){var materials={};if(json!==undefined){var loader=new MaterialLoader();loader.setTextures(textures);for(var i=0,l=json.length;i<l;i++){var data=json[i];if(data.type==='MultiMaterial'){// Deprecated
var array=[];for(var j=0;j<data.materials.length;j++){array.push(loader.parse(data.materials[j]));}materials[data.uuid]=array;}else{materials[data.uuid]=loader.parse(data);}}}return materials;},parseAnimations:function(json){var animations=[];for(var i=0;i<json.length;i++){var clip=AnimationClip.parse(json[i]);animations.push(clip);}return animations;},parseImages:function(json,onLoad){var scope=this;var images={};function loadImage(url){scope.manager.itemStart(url);return loader.load(url,function(){scope.manager.itemEnd(url);},undefined,function(){scope.manager.itemEnd(url);scope.manager.itemError(url);});}if(json!==undefined&&json.length>0){var manager=new LoadingManager(onLoad);var loader=new ImageLoader(manager);loader.setCrossOrigin(this.crossOrigin);for(var i=0,l=json.length;i<l;i++){var image=json[i];var path=/^(\/\/)|([a-z]+:(\/\/)?)/i.test(image.url)?image.url:scope.texturePath+image.url;images[image.uuid]=loadImage(path);}}return images;},parseTextures:function(json,images){function parseConstant(value,type){if(typeof value==='number')return value;console.warn('THREE.ObjectLoader.parseTexture: Constant should be in numeric form.',value);return type[value];}var textures={};if(json!==undefined){for(var i=0,l=json.length;i<l;i++){var data=json[i];if(data.image===undefined){console.warn('THREE.ObjectLoader: No "image" specified for',data.uuid);}if(images[data.image]===undefined){console.warn('THREE.ObjectLoader: Undefined image',data.image);}var texture=new Texture(images[data.image]);texture.needsUpdate=true;texture.uuid=data.uuid;if(data.name!==undefined)texture.name=data.name;if(data.mapping!==undefined)texture.mapping=parseConstant(data.mapping,TEXTURE_MAPPING);if(data.offset!==undefined)texture.offset.fromArray(data.offset);if(data.repeat!==undefined)texture.repeat.fromArray(data.repeat);if(data.center!==undefined)texture.center.fromArray(data.center);if(data.rotation!==undefined)texture.rotation=data.rotation;if(data.wrap!==undefined){texture.wrapS=parseConstant(data.wrap[0],TEXTURE_WRAPPING);texture.wrapT=parseConstant(data.wrap[1],TEXTURE_WRAPPING);}if(data.format!==undefined)texture.format=data.format;if(data.minFilter!==undefined)texture.minFilter=parseConstant(data.minFilter,TEXTURE_FILTER);if(data.magFilter!==undefined)texture.magFilter=parseConstant(data.magFilter,TEXTURE_FILTER);if(data.anisotropy!==undefined)texture.anisotropy=data.anisotropy;if(data.flipY!==undefined)texture.flipY=data.flipY;textures[data.uuid]=texture;}}return textures;},parseObject:function(data,geometries,materials){var object;function getGeometry(name){if(geometries[name]===undefined){console.warn('THREE.ObjectLoader: Undefined geometry',name);}return geometries[name];}function getMaterial(name){if(name===undefined)return undefined;if(Array.isArray(name)){var array=[];for(var i=0,l=name.length;i<l;i++){var uuid=name[i];if(materials[uuid]===undefined){console.warn('THREE.ObjectLoader: Undefined material',uuid);}array.push(materials[uuid]);}return array;}if(materials[name]===undefined){console.warn('THREE.ObjectLoader: Undefined material',name);}return materials[name];}switch(data.type){case'Scene':object=new Scene();if(data.background!==undefined){if(Number.isInteger(data.background)){object.background=new Color(data.background);}}if(data.fog!==undefined){if(data.fog.type==='Fog'){object.fog=new Fog(data.fog.color,data.fog.near,data.fog.far);}else if(data.fog.type==='FogExp2'){object.fog=new FogExp2(data.fog.color,data.fog.density);}}break;case'PerspectiveCamera':object=new PerspectiveCamera(data.fov,data.aspect,data.near,data.far);if(data.focus!==undefined)object.focus=data.focus;if(data.zoom!==undefined)object.zoom=data.zoom;if(data.filmGauge!==undefined)object.filmGauge=data.filmGauge;if(data.filmOffset!==undefined)object.filmOffset=data.filmOffset;if(data.view!==undefined)object.view=Object.assign({},data.view);break;case'OrthographicCamera':object=new OrthographicCamera(data.left,data.right,data.top,data.bottom,data.near,data.far);if(data.zoom!==undefined)object.zoom=data.zoom;if(data.view!==undefined)object.view=Object.assign({},data.view);break;case'AmbientLight':object=new AmbientLight(data.color,data.intensity);break;case'DirectionalLight':object=new DirectionalLight(data.color,data.intensity);break;case'PointLight':object=new PointLight(data.color,data.intensity,data.distance,data.decay);break;case'RectAreaLight':object=new RectAreaLight(data.color,data.intensity,data.width,data.height);break;case'SpotLight':object=new SpotLight(data.color,data.intensity,data.distance,data.angle,data.penumbra,data.decay);break;case'HemisphereLight':object=new HemisphereLight(data.color,data.groundColor,data.intensity);break;case'SkinnedMesh':console.warn('THREE.ObjectLoader.parseObject() does not support SkinnedMesh yet.');case'Mesh':var geometry=getGeometry(data.geometry);var material=getMaterial(data.material);if(geometry.bones&&geometry.bones.length>0){object=new SkinnedMesh(geometry,material);}else{object=new Mesh(geometry,material);}break;case'LOD':object=new LOD();break;case'Line':object=new Line(getGeometry(data.geometry),getMaterial(data.material),data.mode);break;case'LineLoop':object=new LineLoop(getGeometry(data.geometry),getMaterial(data.material));break;case'LineSegments':object=new LineSegments(getGeometry(data.geometry),getMaterial(data.material));break;case'PointCloud':case'Points':object=new Points(getGeometry(data.geometry),getMaterial(data.material));break;case'Sprite':object=new Sprite(getMaterial(data.material));break;case'Group':object=new Group();break;default:object=new Object3D();}object.uuid=data.uuid;if(data.name!==undefined)object.name=data.name;if(data.matrix!==undefined){object.matrix.fromArray(data.matrix);if(data.matrixAutoUpdate!==undefined)object.matrixAutoUpdate=data.matrixAutoUpdate;if(object.matrixAutoUpdate)object.matrix.decompose(object.position,object.quaternion,object.scale);}else{if(data.position!==undefined)object.position.fromArray(data.position);if(data.rotation!==undefined)object.rotation.fromArray(data.rotation);if(data.quaternion!==undefined)object.quaternion.fromArray(data.quaternion);if(data.scale!==undefined)object.scale.fromArray(data.scale);}if(data.castShadow!==undefined)object.castShadow=data.castShadow;if(data.receiveShadow!==undefined)object.receiveShadow=data.receiveShadow;if(data.shadow){if(data.shadow.bias!==undefined)object.shadow.bias=data.shadow.bias;if(data.shadow.radius!==undefined)object.shadow.radius=data.shadow.radius;if(data.shadow.mapSize!==undefined)object.shadow.mapSize.fromArray(data.shadow.mapSize);if(data.shadow.camera!==undefined)object.shadow.camera=this.parseObject(data.shadow.camera);}if(data.visible!==undefined)object.visible=data.visible;if(data.frustumCulled!==undefined)object.frustumCulled=data.frustumCulled;if(data.renderOrder!==undefined)object.renderOrder=data.renderOrder;if(data.userData!==undefined)object.userData=data.userData;if(data.children!==undefined){var children=data.children;for(var i=0;i<children.length;i++){object.add(this.parseObject(children[i],geometries,materials));}}if(data.type==='LOD'){var levels=data.levels;for(var l=0;l<levels.length;l++){var level=levels[l];var child=object.getObjectByProperty('uuid',level.object);if(child!==undefined){object.addLevel(child,level.distance);}}}return object;}});var TEXTURE_MAPPING={UVMapping:UVMapping,CubeReflectionMapping:CubeReflectionMapping,CubeRefractionMapping:CubeRefractionMapping,EquirectangularReflectionMapping:EquirectangularReflectionMapping,EquirectangularRefractionMapping:EquirectangularRefractionMapping,SphericalReflectionMapping:SphericalReflectionMapping,CubeUVReflectionMapping:CubeUVReflectionMapping,CubeUVRefractionMapping:CubeUVRefractionMapping};var TEXTURE_WRAPPING={RepeatWrapping:RepeatWrapping,ClampToEdgeWrapping:ClampToEdgeWrapping,MirroredRepeatWrapping:MirroredRepeatWrapping};var TEXTURE_FILTER={NearestFilter:NearestFilter,NearestMipMapNearestFilter:NearestMipMapNearestFilter,NearestMipMapLinearFilter:NearestMipMapLinearFilter,LinearFilter:LinearFilter,LinearMipMapNearestFilter:LinearMipMapNearestFilter,LinearMipMapLinearFilter:LinearMipMapLinearFilter};/**
* @author zz85 / http://www.lab4games.net/zz85/blog
* minimal class for proxing functions to Path. Replaces old "extractSubpaths()"
**/function ShapePath(){this.type='ShapePath';this.color=new Color();this.subPaths=[];this.currentPath=null;}Object.assign(ShapePath.prototype,{moveTo:function(x,y){this.currentPath=new Path();this.subPaths.push(this.currentPath);this.currentPath.moveTo(x,y);},lineTo:function(x,y){this.currentPath.lineTo(x,y);},quadraticCurveTo:function(aCPx,aCPy,aX,aY){this.currentPath.quadraticCurveTo(aCPx,aCPy,aX,aY);},bezierCurveTo:function(aCP1x,aCP1y,aCP2x,aCP2y,aX,aY){this.currentPath.bezierCurveTo(aCP1x,aCP1y,aCP2x,aCP2y,aX,aY);},splineThru:function(pts){this.currentPath.splineThru(pts);},toShapes:function(isCCW,noHoles){function toShapesNoHoles(inSubpaths){var shapes=[];for(var i=0,l=inSubpaths.length;i<l;i++){var tmpPath=inSubpaths[i];var tmpShape=new Shape();tmpShape.curves=tmpPath.curves;shapes.push(tmpShape);}return shapes;}function isPointInsidePolygon(inPt,inPolygon){var polyLen=inPolygon.length;// inPt on polygon contour => immediate success or
// toggling of inside/outside at every single! intersection point of an edge
// with the horizontal line through inPt, left of inPt
// not counting lowerY endpoints of edges and whole edges on that line
var inside=false;for(var p=polyLen-1,q=0;q<polyLen;p=q++){var edgeLowPt=inPolygon[p];var edgeHighPt=inPolygon[q];var edgeDx=edgeHighPt.x-edgeLowPt.x;var edgeDy=edgeHighPt.y-edgeLowPt.y;if(Math.abs(edgeDy)>Number.EPSILON){// not parallel
if(edgeDy<0){edgeLowPt=inPolygon[q];edgeDx=-edgeDx;edgeHighPt=inPolygon[p];edgeDy=-edgeDy;}if(inPt.y<edgeLowPt.y||inPt.y>edgeHighPt.y)continue;if(inPt.y===edgeLowPt.y){if(inPt.x===edgeLowPt.x)return true;// inPt is on contour ?
// continue; // no intersection or edgeLowPt => doesn't count !!!
}else{var perpEdge=edgeDy*(inPt.x-edgeLowPt.x)-edgeDx*(inPt.y-edgeLowPt.y);if(perpEdge===0)return true;// inPt is on contour ?
if(perpEdge<0)continue;inside=!inside;// true intersection left of inPt
}}else{// parallel or collinear
if(inPt.y!==edgeLowPt.y)continue;// parallel
// edge lies on the same horizontal line as inPt
if(edgeHighPt.x<=inPt.x&&inPt.x<=edgeLowPt.x||edgeLowPt.x<=inPt.x&&inPt.x<=edgeHighPt.x)return true;// inPt: Point on contour !
// continue;
}}return inside;}var isClockWise=ShapeUtils.isClockWise;var subPaths=this.subPaths;if(subPaths.length===0)return [];if(noHoles===true)return toShapesNoHoles(subPaths);var solid,tmpPath,tmpShape,shapes=[];if(subPaths.length===1){tmpPath=subPaths[0];tmpShape=new Shape();tmpShape.curves=tmpPath.curves;shapes.push(tmpShape);return shapes;}var holesFirst=!isClockWise(subPaths[0].getPoints());holesFirst=isCCW?!holesFirst:holesFirst;// console.log("Holes first", holesFirst);
var betterShapeHoles=[];var newShapes=[];var newShapeHoles=[];var mainIdx=0;var tmpPoints;newShapes[mainIdx]=undefined;newShapeHoles[mainIdx]=[];for(var i=0,l=subPaths.length;i<l;i++){tmpPath=subPaths[i];tmpPoints=tmpPath.getPoints();solid=isClockWise(tmpPoints);solid=isCCW?!solid:solid;if(solid){if(!holesFirst&&newShapes[mainIdx])mainIdx++;newShapes[mainIdx]={s:new Shape(),p:tmpPoints};newShapes[mainIdx].s.curves=tmpPath.curves;if(holesFirst)mainIdx++;newShapeHoles[mainIdx]=[];//console.log('cw', i);
}else{newShapeHoles[mainIdx].push({h:tmpPath,p:tmpPoints[0]});//console.log('ccw', i);
}}// only Holes? -> probably all Shapes with wrong orientation
if(!newShapes[0])return toShapesNoHoles(subPaths);if(newShapes.length>1){var ambiguous=false;var toChange=[];for(var sIdx=0,sLen=newShapes.length;sIdx<sLen;sIdx++){betterShapeHoles[sIdx]=[];}for(var sIdx=0,sLen=newShapes.length;sIdx<sLen;sIdx++){var sho=newShapeHoles[sIdx];for(var hIdx=0;hIdx<sho.length;hIdx++){var ho=sho[hIdx];var hole_unassigned=true;for(var s2Idx=0;s2Idx<newShapes.length;s2Idx++){if(isPointInsidePolygon(ho.p,newShapes[s2Idx].p)){if(sIdx!==s2Idx)toChange.push({froms:sIdx,tos:s2Idx,hole:hIdx});if(hole_unassigned){hole_unassigned=false;betterShapeHoles[s2Idx].push(ho);}else{ambiguous=true;}}}if(hole_unassigned){betterShapeHoles[sIdx].push(ho);}}}// console.log("ambiguous: ", ambiguous);
if(toChange.length>0){// console.log("to change: ", toChange);
if(!ambiguous)newShapeHoles=betterShapeHoles;}}var tmpHoles;for(var i=0,il=newShapes.length;i<il;i++){tmpShape=newShapes[i].s;shapes.push(tmpShape);tmpHoles=newShapeHoles[i];for(var j=0,jl=tmpHoles.length;j<jl;j++){tmpShape.holes.push(tmpHoles[j].h);}}//console.log("shape", shapes);
return shapes;}});/**
* @author zz85 / http://www.lab4games.net/zz85/blog
* @author mrdoob / http://mrdoob.com/
*/function Font(data){this.type='Font';this.data=data;}Object.assign(Font.prototype,{isFont:true,generateShapes:function(text,size,divisions){if(size===undefined)size=100;if(divisions===undefined)divisions=4;var shapes=[];var paths=createPaths(text,size,divisions,this.data);for(var p=0,pl=paths.length;p<pl;p++){Array.prototype.push.apply(shapes,paths[p].toShapes());}return shapes;}});function createPaths(text,size,divisions,data){var chars=String(text).split('');var scale=size/data.resolution;var line_height=(data.boundingBox.yMax-data.boundingBox.yMin+data.underlineThickness)*scale;var paths=[];var offsetX=0,offsetY=0;for(var i=0;i<chars.length;i++){var char=chars[i];if(char==='\n'){offsetX=0;offsetY-=line_height;}else{var ret=createPath(char,divisions,scale,offsetX,offsetY,data);offsetX+=ret.offsetX;paths.push(ret.path);}}return paths;}function createPath(char,divisions,scale,offsetX,offsetY,data){var glyph=data.glyphs[char]||data.glyphs['?'];if(!glyph)return;var path=new ShapePath();var x,y,cpx,cpy,cpx1,cpy1,cpx2,cpy2;if(glyph.o){var outline=glyph._cachedOutline||(glyph._cachedOutline=glyph.o.split(' '));for(var i=0,l=outline.length;i<l;){var action=outline[i++];switch(action){case'm':// moveTo
x=outline[i++]*scale+offsetX;y=outline[i++]*scale+offsetY;path.moveTo(x,y);break;case'l':// lineTo
x=outline[i++]*scale+offsetX;y=outline[i++]*scale+offsetY;path.lineTo(x,y);break;case'q':// quadraticCurveTo
cpx=outline[i++]*scale+offsetX;cpy=outline[i++]*scale+offsetY;cpx1=outline[i++]*scale+offsetX;cpy1=outline[i++]*scale+offsetY;path.quadraticCurveTo(cpx1,cpy1,cpx,cpy);break;case'b':// bezierCurveTo
cpx=outline[i++]*scale+offsetX;cpy=outline[i++]*scale+offsetY;cpx1=outline[i++]*scale+offsetX;cpy1=outline[i++]*scale+offsetY;cpx2=outline[i++]*scale+offsetX;cpy2=outline[i++]*scale+offsetY;path.bezierCurveTo(cpx1,cpy1,cpx2,cpy2,cpx,cpy);break;}}}return {offsetX:glyph.ha*scale,path:path};}/**
* @author mrdoob / http://mrdoob.com/
*/function FontLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;}Object.assign(FontLoader.prototype,{load:function(url,onLoad,onProgress,onError){var scope=this;var loader=new FileLoader(this.manager);loader.setPath(this.path);loader.load(url,function(text){var json;try{json=JSON.parse(text);}catch(e){console.warn('THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead.');json=JSON.parse(text.substring(65,text.length-2));}var font=scope.parse(json);if(onLoad)onLoad(font);},onProgress,onError);},parse:function(json){return new Font(json);},setPath:function(value){this.path=value;return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/var context;var AudioContext={getContext:function(){if(context===undefined){context=new(window.AudioContext||window.webkitAudioContext)();}return context;},setContext:function(value){context=value;}};/**
* @author Reece Aaron Lecrivain / http://reecenotes.com/
*/function AudioLoader(manager){this.manager=manager!==undefined?manager:DefaultLoadingManager;}Object.assign(AudioLoader.prototype,{load:function(url,onLoad,onProgress,onError){var loader=new FileLoader(this.manager);loader.setResponseType('arraybuffer');loader.load(url,function(buffer){var context=AudioContext.getContext();context.decodeAudioData(buffer,function(audioBuffer){onLoad(audioBuffer);});},onProgress,onError);}});/**
* @author mrdoob / http://mrdoob.com/
*/function StereoCamera(){this.type='StereoCamera';this.aspect=1;this.eyeSep=0.064;this.cameraL=new PerspectiveCamera();this.cameraL.layers.enable(1);this.cameraL.matrixAutoUpdate=false;this.cameraR=new PerspectiveCamera();this.cameraR.layers.enable(2);this.cameraR.matrixAutoUpdate=false;}Object.assign(StereoCamera.prototype,{update:function(){var instance,focus,fov,aspect,near,far,zoom,eyeSep;var eyeRight=new Matrix4();var eyeLeft=new Matrix4();return function update(camera){var needsUpdate=instance!==this||focus!==camera.focus||fov!==camera.fov||aspect!==camera.aspect*this.aspect||near!==camera.near||far!==camera.far||zoom!==camera.zoom||eyeSep!==this.eyeSep;if(needsUpdate){instance=this;focus=camera.focus;fov=camera.fov;aspect=camera.aspect*this.aspect;near=camera.near;far=camera.far;zoom=camera.zoom;// Off-axis stereoscopic effect based on
// http://paulbourke.net/stereographics/stereorender/
var projectionMatrix=camera.projectionMatrix.clone();eyeSep=this.eyeSep/2;var eyeSepOnProjection=eyeSep*near/focus;var ymax=near*Math.tan(_Math.DEG2RAD*fov*0.5)/zoom;var xmin,xmax;// translate xOffset
eyeLeft.elements[12]=-eyeSep;eyeRight.elements[12]=eyeSep;// for left eye
xmin=-ymax*aspect+eyeSepOnProjection;xmax=ymax*aspect+eyeSepOnProjection;projectionMatrix.elements[0]=2*near/(xmax-xmin);projectionMatrix.elements[8]=(xmax+xmin)/(xmax-xmin);this.cameraL.projectionMatrix.copy(projectionMatrix);// for right eye
xmin=-ymax*aspect-eyeSepOnProjection;xmax=ymax*aspect-eyeSepOnProjection;projectionMatrix.elements[0]=2*near/(xmax-xmin);projectionMatrix.elements[8]=(xmax+xmin)/(xmax-xmin);this.cameraR.projectionMatrix.copy(projectionMatrix);}this.cameraL.matrixWorld.copy(camera.matrixWorld).multiply(eyeLeft);this.cameraR.matrixWorld.copy(camera.matrixWorld).multiply(eyeRight);};}()});/**
* Camera for rendering cube maps
* - renders scene into axis-aligned cube
*
* @author alteredq / http://alteredqualia.com/
*/function CubeCamera(near,far,cubeResolution){Object3D.call(this);this.type='CubeCamera';var fov=90,aspect=1;var cameraPX=new PerspectiveCamera(fov,aspect,near,far);cameraPX.up.set(0,-1,0);cameraPX.lookAt(new Vector3(1,0,0));this.add(cameraPX);var cameraNX=new PerspectiveCamera(fov,aspect,near,far);cameraNX.up.set(0,-1,0);cameraNX.lookAt(new Vector3(-1,0,0));this.add(cameraNX);var cameraPY=new PerspectiveCamera(fov,aspect,near,far);cameraPY.up.set(0,0,1);cameraPY.lookAt(new Vector3(0,1,0));this.add(cameraPY);var cameraNY=new PerspectiveCamera(fov,aspect,near,far);cameraNY.up.set(0,0,-1);cameraNY.lookAt(new Vector3(0,-1,0));this.add(cameraNY);var cameraPZ=new PerspectiveCamera(fov,aspect,near,far);cameraPZ.up.set(0,-1,0);cameraPZ.lookAt(new Vector3(0,0,1));this.add(cameraPZ);var cameraNZ=new PerspectiveCamera(fov,aspect,near,far);cameraNZ.up.set(0,-1,0);cameraNZ.lookAt(new Vector3(0,0,-1));this.add(cameraNZ);var options={format:RGBFormat,magFilter:LinearFilter,minFilter:LinearFilter};this.renderTarget=new WebGLRenderTargetCube(cubeResolution,cubeResolution,options);this.renderTarget.texture.name="CubeCamera";this.update=function(renderer,scene){if(this.parent===null)this.updateMatrixWorld();var renderTarget=this.renderTarget;var generateMipmaps=renderTarget.texture.generateMipmaps;renderTarget.texture.generateMipmaps=false;renderTarget.activeCubeFace=0;renderer.render(scene,cameraPX,renderTarget);renderTarget.activeCubeFace=1;renderer.render(scene,cameraNX,renderTarget);renderTarget.activeCubeFace=2;renderer.render(scene,cameraPY,renderTarget);renderTarget.activeCubeFace=3;renderer.render(scene,cameraNY,renderTarget);renderTarget.activeCubeFace=4;renderer.render(scene,cameraPZ,renderTarget);renderTarget.texture.generateMipmaps=generateMipmaps;renderTarget.activeCubeFace=5;renderer.render(scene,cameraNZ,renderTarget);renderer.setRenderTarget(null);};this.clear=function(renderer,color,depth,stencil){var renderTarget=this.renderTarget;for(var i=0;i<6;i++){renderTarget.activeCubeFace=i;renderer.setRenderTarget(renderTarget);renderer.clear(color,depth,stencil);}renderer.setRenderTarget(null);};}CubeCamera.prototype=Object.create(Object3D.prototype);CubeCamera.prototype.constructor=CubeCamera;/**
* @author mrdoob / http://mrdoob.com/
*/function AudioListener(){Object3D.call(this);this.type='AudioListener';this.context=AudioContext.getContext();this.gain=this.context.createGain();this.gain.connect(this.context.destination);this.filter=null;}AudioListener.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:AudioListener,getInput:function(){return this.gain;},removeFilter:function(){if(this.filter!==null){this.gain.disconnect(this.filter);this.filter.disconnect(this.context.destination);this.gain.connect(this.context.destination);this.filter=null;}},getFilter:function(){return this.filter;},setFilter:function(value){if(this.filter!==null){this.gain.disconnect(this.filter);this.filter.disconnect(this.context.destination);}else{this.gain.disconnect(this.context.destination);}this.filter=value;this.gain.connect(this.filter);this.filter.connect(this.context.destination);},getMasterVolume:function(){return this.gain.gain.value;},setMasterVolume:function(value){this.gain.gain.setTargetAtTime(value,this.context.currentTime,0.01);},updateMatrixWorld:function(){var position=new Vector3();var quaternion=new Quaternion();var scale=new Vector3();var orientation=new Vector3();return function updateMatrixWorld(force){Object3D.prototype.updateMatrixWorld.call(this,force);var listener=this.context.listener;var up=this.up;this.matrixWorld.decompose(position,quaternion,scale);orientation.set(0,0,-1).applyQuaternion(quaternion);if(listener.positionX){listener.positionX.setValueAtTime(position.x,this.context.currentTime);listener.positionY.setValueAtTime(position.y,this.context.currentTime);listener.positionZ.setValueAtTime(position.z,this.context.currentTime);listener.forwardX.setValueAtTime(orientation.x,this.context.currentTime);listener.forwardY.setValueAtTime(orientation.y,this.context.currentTime);listener.forwardZ.setValueAtTime(orientation.z,this.context.currentTime);listener.upX.setValueAtTime(up.x,this.context.currentTime);listener.upY.setValueAtTime(up.y,this.context.currentTime);listener.upZ.setValueAtTime(up.z,this.context.currentTime);}else{listener.setPosition(position.x,position.y,position.z);listener.setOrientation(orientation.x,orientation.y,orientation.z,up.x,up.y,up.z);}};}()});/**
* @author mrdoob / http://mrdoob.com/
* @author Reece Aaron Lecrivain / http://reecenotes.com/
*/function Audio(listener){Object3D.call(this);this.type='Audio';this.context=listener.context;this.gain=this.context.createGain();this.gain.connect(listener.getInput());this.autoplay=false;this.buffer=null;this.loop=false;this.startTime=0;this.offset=0;this.playbackRate=1;this.isPlaying=false;this.hasPlaybackControl=true;this.sourceType='empty';this.filters=[];}Audio.prototype=Object.assign(Object.create(Object3D.prototype),{constructor:Audio,getOutput:function(){return this.gain;},setNodeSource:function(audioNode){this.hasPlaybackControl=false;this.sourceType='audioNode';this.source=audioNode;this.connect();return this;},setBuffer:function(audioBuffer){this.buffer=audioBuffer;this.sourceType='buffer';if(this.autoplay)this.play();return this;},play:function(){if(this.isPlaying===true){console.warn('THREE.Audio: Audio is already playing.');return;}if(this.hasPlaybackControl===false){console.warn('THREE.Audio: this Audio has no playback control.');return;}var source=this.context.createBufferSource();source.buffer=this.buffer;source.loop=this.loop;source.onended=this.onEnded.bind(this);source.playbackRate.setValueAtTime(this.playbackRate,this.startTime);this.startTime=this.context.currentTime;source.start(this.startTime,this.offset);this.isPlaying=true;this.source=source;return this.connect();},pause:function(){if(this.hasPlaybackControl===false){console.warn('THREE.Audio: this Audio has no playback control.');return;}if(this.isPlaying===true){this.source.stop();this.offset+=(this.context.currentTime-this.startTime)*this.playbackRate;this.isPlaying=false;}return this;},stop:function(){if(this.hasPlaybackControl===false){console.warn('THREE.Audio: this Audio has no playback control.');return;}this.source.stop();this.offset=0;this.isPlaying=false;return this;},connect:function(){if(this.filters.length>0){this.source.connect(this.filters[0]);for(var i=1,l=this.filters.length;i<l;i++){this.filters[i-1].connect(this.filters[i]);}this.filters[this.filters.length-1].connect(this.getOutput());}else{this.source.connect(this.getOutput());}return this;},disconnect:function(){if(this.filters.length>0){this.source.disconnect(this.filters[0]);for(var i=1,l=this.filters.length;i<l;i++){this.filters[i-1].disconnect(this.filters[i]);}this.filters[this.filters.length-1].disconnect(this.getOutput());}else{this.source.disconnect(this.getOutput());}return this;},getFilters:function(){return this.filters;},setFilters:function(value){if(!value)value=[];if(this.isPlaying===true){this.disconnect();this.filters=value;this.connect();}else{this.filters=value;}return this;},getFilter:function(){return this.getFilters()[0];},setFilter:function(filter){return this.setFilters(filter?[filter]:[]);},setPlaybackRate:function(value){if(this.hasPlaybackControl===false){console.warn('THREE.Audio: this Audio has no playback control.');return;}this.playbackRate=value;if(this.isPlaying===true){this.source.playbackRate.setValueAtTime(this.playbackRate,this.context.currentTime);}return this;},getPlaybackRate:function(){return this.playbackRate;},onEnded:function(){this.isPlaying=false;},getLoop:function(){if(this.hasPlaybackControl===false){console.warn('THREE.Audio: this Audio has no playback control.');return false;}return this.loop;},setLoop:function(value){if(this.hasPlaybackControl===false){console.warn('THREE.Audio: this Audio has no playback control.');return;}this.loop=value;if(this.isPlaying===true){this.source.loop=this.loop;}return this;},getVolume:function(){return this.gain.gain.value;},setVolume:function(value){this.gain.gain.setTargetAtTime(value,this.context.currentTime,0.01);return this;}});/**
* @author mrdoob / http://mrdoob.com/
*/function PositionalAudio(listener){Audio.call(this,listener);this.panner=this.context.createPanner();this.panner.connect(this.gain);}PositionalAudio.prototype=Object.assign(Object.create(Audio.prototype),{constructor:PositionalAudio,getOutput:function(){return this.panner;},getRefDistance:function(){return this.panner.refDistance;},setRefDistance:function(value){this.panner.refDistance=value;},getRolloffFactor:function(){return this.panner.rolloffFactor;},setRolloffFactor:function(value){this.panner.rolloffFactor=value;},getDistanceModel:function(){return this.panner.distanceModel;},setDistanceModel:function(value){this.panner.distanceModel=value;},getMaxDistance:function(){return this.panner.maxDistance;},setMaxDistance:function(value){this.panner.maxDistance=value;},updateMatrixWorld:function(){var position=new Vector3();return function updateMatrixWorld(force){Object3D.prototype.updateMatrixWorld.call(this,force);position.setFromMatrixPosition(this.matrixWorld);this.panner.setPosition(position.x,position.y,position.z);};}()});/**
* @author mrdoob / http://mrdoob.com/
*/function AudioAnalyser(audio,fftSize){this.analyser=audio.context.createAnalyser();this.analyser.fftSize=fftSize!==undefined?fftSize:2048;this.data=new Uint8Array(this.analyser.frequencyBinCount);audio.getOutput().connect(this.analyser);}Object.assign(AudioAnalyser.prototype,{getFrequencyData:function(){this.analyser.getByteFrequencyData(this.data);return this.data;},getAverageFrequency:function(){var value=0,data=this.getFrequencyData();for(var i=0;i<data.length;i++){value+=data[i];}return value/data.length;}});/**
*
* Buffered scene graph property that allows weighted accumulation.
*
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/function PropertyMixer(binding,typeName,valueSize){this.binding=binding;this.valueSize=valueSize;var bufferType=Float64Array,mixFunction;switch(typeName){case'quaternion':mixFunction=this._slerp;break;case'string':case'bool':bufferType=Array;mixFunction=this._select;break;default:mixFunction=this._lerp;}this.buffer=new bufferType(valueSize*4);// layout: [ incoming | accu0 | accu1 | orig ]
//
// interpolators can use .buffer as their .result
// the data then goes to 'incoming'
//
// 'accu0' and 'accu1' are used frame-interleaved for
// the cumulative result and are compared to detect
// changes
//
// 'orig' stores the original state of the property
this._mixBufferRegion=mixFunction;this.cumulativeWeight=0;this.useCount=0;this.referenceCount=0;}Object.assign(PropertyMixer.prototype,{// accumulate data in the 'incoming' region into 'accu<i>'
accumulate:function(accuIndex,weight){// note: happily accumulating nothing when weight = 0, the caller knows
// the weight and shouldn't have made the call in the first place
var buffer=this.buffer,stride=this.valueSize,offset=accuIndex*stride+stride,currentWeight=this.cumulativeWeight;if(currentWeight===0){// accuN := incoming * weight
for(var i=0;i!==stride;++i){buffer[offset+i]=buffer[i];}currentWeight=weight;}else{// accuN := accuN + incoming * weight
currentWeight+=weight;var mix=weight/currentWeight;this._mixBufferRegion(buffer,offset,0,mix,stride);}this.cumulativeWeight=currentWeight;},// apply the state of 'accu<i>' to the binding when accus differ
apply:function(accuIndex){var stride=this.valueSize,buffer=this.buffer,offset=accuIndex*stride+stride,weight=this.cumulativeWeight,binding=this.binding;this.cumulativeWeight=0;if(weight<1){// accuN := accuN + original * ( 1 - cumulativeWeight )
var originalValueOffset=stride*3;this._mixBufferRegion(buffer,offset,originalValueOffset,1-weight,stride);}for(var i=stride,e=stride+stride;i!==e;++i){if(buffer[i]!==buffer[i+stride]){// value has changed -> update scene graph
binding.setValue(buffer,offset);break;}}},// remember the state of the bound property and copy it to both accus
saveOriginalState:function(){var binding=this.binding;var buffer=this.buffer,stride=this.valueSize,originalValueOffset=stride*3;binding.getValue(buffer,originalValueOffset);// accu[0..1] := orig -- initially detect changes against the original
for(var i=stride,e=originalValueOffset;i!==e;++i){buffer[i]=buffer[originalValueOffset+i%stride];}this.cumulativeWeight=0;},// apply the state previously taken via 'saveOriginalState' to the binding
restoreOriginalState:function(){var originalValueOffset=this.valueSize*3;this.binding.setValue(this.buffer,originalValueOffset);},// mix functions
_select:function(buffer,dstOffset,srcOffset,t,stride){if(t>=0.5){for(var i=0;i!==stride;++i){buffer[dstOffset+i]=buffer[srcOffset+i];}}},_slerp:function(buffer,dstOffset,srcOffset,t){Quaternion.slerpFlat(buffer,dstOffset,buffer,dstOffset,buffer,srcOffset,t);},_lerp:function(buffer,dstOffset,srcOffset,t,stride){var s=1-t;for(var i=0;i!==stride;++i){var j=dstOffset+i;buffer[j]=buffer[j]*s+buffer[srcOffset+i]*t;}}});/**
*
* A reference to a real property in the scene graph.
*
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/ // Characters [].:/ are reserved for track binding syntax.
var RESERVED_CHARS_RE='\\[\\]\\.:\\/';function Composite(targetGroup,path,optionalParsedPath){var parsedPath=optionalParsedPath||PropertyBinding.parseTrackName(path);this._targetGroup=targetGroup;this._bindings=targetGroup.subscribe_(path,parsedPath);}Object.assign(Composite.prototype,{getValue:function(array,offset){this.bind();// bind all binding
var firstValidIndex=this._targetGroup.nCachedObjects_,binding=this._bindings[firstValidIndex];// and only call .getValue on the first
if(binding!==undefined)binding.getValue(array,offset);},setValue:function(array,offset){var bindings=this._bindings;for(var i=this._targetGroup.nCachedObjects_,n=bindings.length;i!==n;++i){bindings[i].setValue(array,offset);}},bind:function(){var bindings=this._bindings;for(var i=this._targetGroup.nCachedObjects_,n=bindings.length;i!==n;++i){bindings[i].bind();}},unbind:function(){var bindings=this._bindings;for(var i=this._targetGroup.nCachedObjects_,n=bindings.length;i!==n;++i){bindings[i].unbind();}}});function PropertyBinding(rootNode,path,parsedPath){this.path=path;this.parsedPath=parsedPath||PropertyBinding.parseTrackName(path);this.node=PropertyBinding.findNode(rootNode,this.parsedPath.nodeName)||rootNode;this.rootNode=rootNode;}Object.assign(PropertyBinding,{Composite:Composite,create:function(root,path,parsedPath){if(!(root&&root.isAnimationObjectGroup)){return new PropertyBinding(root,path,parsedPath);}else{return new PropertyBinding.Composite(root,path,parsedPath);}},/**
* Replaces spaces with underscores and removes unsupported characters from
* node names, to ensure compatibility with parseTrackName().
*
* @param {string} name Node name to be sanitized.
* @return {string}
*/sanitizeNodeName:function(){var reservedRe=new RegExp('['+RESERVED_CHARS_RE+']','g');return function sanitizeNodeName(name){return name.replace(/\s/g,'_').replace(reservedRe,'');};}(),parseTrackName:function(){// Attempts to allow node names from any language. ES5's `\w` regexp matches
// only latin characters, and the unicode \p{L} is not yet supported. So
// instead, we exclude reserved characters and match everything else.
var wordChar='[^'+RESERVED_CHARS_RE+']';var wordCharOrDot='[^'+RESERVED_CHARS_RE.replace('\\.','')+']';// Parent directories, delimited by '/' or ':'. Currently unused, but must
// be matched to parse the rest of the track name.
var directoryRe=/((?:WC+[\/:])*)/.source.replace('WC',wordChar);// Target node. May contain word characters (a-zA-Z0-9_) and '.' or '-'.
var nodeRe=/(WCOD+)?/.source.replace('WCOD',wordCharOrDot);// Object on target node, and accessor. May not contain reserved
// characters. Accessor may contain any character except closing bracket.
var objectRe=/(?:\.(WC+)(?:\[(.+)\])?)?/.source.replace('WC',wordChar);// Property and accessor. May not contain reserved characters. Accessor may
// contain any non-bracket characters.
var propertyRe=/\.(WC+)(?:\[(.+)\])?/.source.replace('WC',wordChar);var trackRe=new RegExp(''+'^'+directoryRe+nodeRe+objectRe+propertyRe+'$');var supportedObjectNames=['material','materials','bones'];return function parseTrackName(trackName){var matches=trackRe.exec(trackName);if(!matches){throw new Error('PropertyBinding: Cannot parse trackName: '+trackName);}var results={// directoryName: matches[ 1 ], // (tschw) currently unused
nodeName:matches[2],objectName:matches[3],objectIndex:matches[4],propertyName:matches[5],// required
propertyIndex:matches[6]};var lastDot=results.nodeName&&results.nodeName.lastIndexOf('.');if(lastDot!==undefined&&lastDot!==-1){var objectName=results.nodeName.substring(lastDot+1);// Object names must be checked against a whitelist. Otherwise, there
// is no way to parse 'foo.bar.baz': 'baz' must be a property, but
// 'bar' could be the objectName, or part of a nodeName (which can
// include '.' characters).
if(supportedObjectNames.indexOf(objectName)!==-1){results.nodeName=results.nodeName.substring(0,lastDot);results.objectName=objectName;}}if(results.propertyName===null||results.propertyName.length===0){throw new Error('PropertyBinding: can not parse propertyName from trackName: '+trackName);}return results;};}(),findNode:function(root,nodeName){if(!nodeName||nodeName===""||nodeName==="root"||nodeName==="."||nodeName===-1||nodeName===root.name||nodeName===root.uuid){return root;}// search into skeleton bones.
if(root.skeleton){var bone=root.skeleton.getBoneByName(nodeName);if(bone!==undefined){return bone;}}// search into node subtree.
if(root.children){var searchNodeSubtree=function(children){for(var i=0;i<children.length;i++){var childNode=children[i];if(childNode.name===nodeName||childNode.uuid===nodeName){return childNode;}var result=searchNodeSubtree(childNode.children);if(result)return result;}return null;};var subTreeNode=searchNodeSubtree(root.children);if(subTreeNode){return subTreeNode;}}return null;}});Object.assign(PropertyBinding.prototype,{// prototype, continued
// these are used to "bind" a nonexistent property
_getValue_unavailable:function(){},_setValue_unavailable:function(){},BindingType:{Direct:0,EntireArray:1,ArrayElement:2,HasFromToArray:3},Versioning:{None:0,NeedsUpdate:1,MatrixWorldNeedsUpdate:2},GetterByBindingType:[function getValue_direct(buffer,offset){buffer[offset]=this.node[this.propertyName];},function getValue_array(buffer,offset){var source=this.resolvedProperty;for(var i=0,n=source.length;i!==n;++i){buffer[offset++]=source[i];}},function getValue_arrayElement(buffer,offset){buffer[offset]=this.resolvedProperty[this.propertyIndex];},function getValue_toArray(buffer,offset){this.resolvedProperty.toArray(buffer,offset);}],SetterByBindingTypeAndVersioning:[[// Direct
function setValue_direct(buffer,offset){this.targetObject[this.propertyName]=buffer[offset];},function setValue_direct_setNeedsUpdate(buffer,offset){this.targetObject[this.propertyName]=buffer[offset];this.targetObject.needsUpdate=true;},function setValue_direct_setMatrixWorldNeedsUpdate(buffer,offset){this.targetObject[this.propertyName]=buffer[offset];this.targetObject.matrixWorldNeedsUpdate=true;}],[// EntireArray
function setValue_array(buffer,offset){var dest=this.resolvedProperty;for(var i=0,n=dest.length;i!==n;++i){dest[i]=buffer[offset++];}},function setValue_array_setNeedsUpdate(buffer,offset){var dest=this.resolvedProperty;for(var i=0,n=dest.length;i!==n;++i){dest[i]=buffer[offset++];}this.targetObject.needsUpdate=true;},function setValue_array_setMatrixWorldNeedsUpdate(buffer,offset){var dest=this.resolvedProperty;for(var i=0,n=dest.length;i!==n;++i){dest[i]=buffer[offset++];}this.targetObject.matrixWorldNeedsUpdate=true;}],[// ArrayElement
function setValue_arrayElement(buffer,offset){this.resolvedProperty[this.propertyIndex]=buffer[offset];},function setValue_arrayElement_setNeedsUpdate(buffer,offset){this.resolvedProperty[this.propertyIndex]=buffer[offset];this.targetObject.needsUpdate=true;},function setValue_arrayElement_setMatrixWorldNeedsUpdate(buffer,offset){this.resolvedProperty[this.propertyIndex]=buffer[offset];this.targetObject.matrixWorldNeedsUpdate=true;}],[// HasToFromArray
function setValue_fromArray(buffer,offset){this.resolvedProperty.fromArray(buffer,offset);},function setValue_fromArray_setNeedsUpdate(buffer,offset){this.resolvedProperty.fromArray(buffer,offset);this.targetObject.needsUpdate=true;},function setValue_fromArray_setMatrixWorldNeedsUpdate(buffer,offset){this.resolvedProperty.fromArray(buffer,offset);this.targetObject.matrixWorldNeedsUpdate=true;}]],getValue:function getValue_unbound(targetArray,offset){this.bind();this.getValue(targetArray,offset);// Note: This class uses a State pattern on a per-method basis:
// 'bind' sets 'this.getValue' / 'setValue' and shadows the
// prototype version of these methods with one that represents
// the bound state. When the property is not found, the methods
// become no-ops.
},setValue:function getValue_unbound(sourceArray,offset){this.bind();this.setValue(sourceArray,offset);},// create getter / setter pair for a property in the scene graph
bind:function(){var targetObject=this.node,parsedPath=this.parsedPath,objectName=parsedPath.objectName,propertyName=parsedPath.propertyName,propertyIndex=parsedPath.propertyIndex;if(!targetObject){targetObject=PropertyBinding.findNode(this.rootNode,parsedPath.nodeName)||this.rootNode;this.node=targetObject;}// set fail state so we can just 'return' on error
this.getValue=this._getValue_unavailable;this.setValue=this._setValue_unavailable;// ensure there is a value node
if(!targetObject){console.error('THREE.PropertyBinding: Trying to update node for track: '+this.path+' but it wasn\'t found.');return;}if(objectName){var objectIndex=parsedPath.objectIndex;// special cases were we need to reach deeper into the hierarchy to get the face materials....
switch(objectName){case'materials':if(!targetObject.material){console.error('THREE.PropertyBinding: Can not bind to material as node does not have a material.',this);return;}if(!targetObject.material.materials){console.error('THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.',this);return;}targetObject=targetObject.material.materials;break;case'bones':if(!targetObject.skeleton){console.error('THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.',this);return;}// potential future optimization: skip this if propertyIndex is already an integer
// and convert the integer string to a true integer.
targetObject=targetObject.skeleton.bones;// support resolving morphTarget names into indices.
for(var i=0;i<targetObject.length;i++){if(targetObject[i].name===objectIndex){objectIndex=i;break;}}break;default:if(targetObject[objectName]===undefined){console.error('THREE.PropertyBinding: Can not bind to objectName of node undefined.',this);return;}targetObject=targetObject[objectName];}if(objectIndex!==undefined){if(targetObject[objectIndex]===undefined){console.error('THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.',this,targetObject);return;}targetObject=targetObject[objectIndex];}}// resolve property
var nodeProperty=targetObject[propertyName];if(nodeProperty===undefined){var nodeName=parsedPath.nodeName;console.error('THREE.PropertyBinding: Trying to update property for track: '+nodeName+'.'+propertyName+' but it wasn\'t found.',targetObject);return;}// determine versioning scheme
var versioning=this.Versioning.None;if(targetObject.needsUpdate!==undefined){// material
versioning=this.Versioning.NeedsUpdate;this.targetObject=targetObject;}else if(targetObject.matrixWorldNeedsUpdate!==undefined){// node transform
versioning=this.Versioning.MatrixWorldNeedsUpdate;this.targetObject=targetObject;}// determine how the property gets bound
var bindingType=this.BindingType.Direct;if(propertyIndex!==undefined){// access a sub element of the property array (only primitives are supported right now)
if(propertyName==="morphTargetInfluences"){// potential optimization, skip this if propertyIndex is already an integer, and convert the integer string to a true integer.
// support resolving morphTarget names into indices.
if(!targetObject.geometry){console.error('THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.',this);return;}if(targetObject.geometry.isBufferGeometry){if(!targetObject.geometry.morphAttributes){console.error('THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.',this);return;}for(var i=0;i<this.node.geometry.morphAttributes.position.length;i++){if(targetObject.geometry.morphAttributes.position[i].name===propertyIndex){propertyIndex=i;break;}}}else{if(!targetObject.geometry.morphTargets){console.error('THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphTargets.',this);return;}for(var i=0;i<this.node.geometry.morphTargets.length;i++){if(targetObject.geometry.morphTargets[i].name===propertyIndex){propertyIndex=i;break;}}}}bindingType=this.BindingType.ArrayElement;this.resolvedProperty=nodeProperty;this.propertyIndex=propertyIndex;}else if(nodeProperty.fromArray!==undefined&&nodeProperty.toArray!==undefined){// must use copy for Object3D.Euler/Quaternion
bindingType=this.BindingType.HasFromToArray;this.resolvedProperty=nodeProperty;}else if(Array.isArray(nodeProperty)){bindingType=this.BindingType.EntireArray;this.resolvedProperty=nodeProperty;}else{this.propertyName=propertyName;}// select getter / setter
this.getValue=this.GetterByBindingType[bindingType];this.setValue=this.SetterByBindingTypeAndVersioning[bindingType][versioning];},unbind:function(){this.node=null;// back to the prototype version of getValue / setValue
// note: avoiding to mutate the shape of 'this' via 'delete'
this.getValue=this._getValue_unbound;this.setValue=this._setValue_unbound;}});//!\ DECLARE ALIAS AFTER assign prototype !
Object.assign(PropertyBinding.prototype,{// initial state of these methods that calls 'bind'
_getValue_unbound:PropertyBinding.prototype.getValue,_setValue_unbound:PropertyBinding.prototype.setValue});/**
*
* A group of objects that receives a shared animation state.
*
* Usage:
*
* - Add objects you would otherwise pass as 'root' to the
* constructor or the .clipAction method of AnimationMixer.
*
* - Instead pass this object as 'root'.
*
* - You can also add and remove objects later when the mixer
* is running.
*
* Note:
*
* Objects of this class appear as one object to the mixer,
* so cache control of the individual objects must be done
* on the group.
*
* Limitation:
*
* - The animated properties must be compatible among the
* all objects in the group.
*
* - A single property can either be controlled through a
* target group or directly, but not both.
*
* @author tschw
*/function AnimationObjectGroup(){this.uuid=_Math.generateUUID();// cached objects followed by the active ones
this._objects=Array.prototype.slice.call(arguments);this.nCachedObjects_=0;// threshold
// note: read by PropertyBinding.Composite
var indices={};this._indicesByUUID=indices;// for bookkeeping
for(var i=0,n=arguments.length;i!==n;++i){indices[arguments[i].uuid]=i;}this._paths=[];// inside: string
this._parsedPaths=[];// inside: { we don't care, here }
this._bindings=[];// inside: Array< PropertyBinding >
this._bindingsIndicesByPath={};// inside: indices in these arrays
var scope=this;this.stats={objects:{get total(){return scope._objects.length;},get inUse(){return this.total-scope.nCachedObjects_;}},get bindingsPerObject(){return scope._bindings.length;}};}Object.assign(AnimationObjectGroup.prototype,{isAnimationObjectGroup:true,add:function(){var objects=this._objects,nObjects=objects.length,nCachedObjects=this.nCachedObjects_,indicesByUUID=this._indicesByUUID,paths=this._paths,parsedPaths=this._parsedPaths,bindings=this._bindings,nBindings=bindings.length,knownObject=undefined;for(var i=0,n=arguments.length;i!==n;++i){var object=arguments[i],uuid=object.uuid,index=indicesByUUID[uuid];if(index===undefined){// unknown object -> add it to the ACTIVE region
index=nObjects++;indicesByUUID[uuid]=index;objects.push(object);// accounting is done, now do the same for all bindings
for(var j=0,m=nBindings;j!==m;++j){bindings[j].push(new PropertyBinding(object,paths[j],parsedPaths[j]));}}else if(index<nCachedObjects){knownObject=objects[index];// move existing object to the ACTIVE region
var firstActiveIndex=--nCachedObjects,lastCachedObject=objects[firstActiveIndex];indicesByUUID[lastCachedObject.uuid]=index;objects[index]=lastCachedObject;indicesByUUID[uuid]=firstActiveIndex;objects[firstActiveIndex]=object;// accounting is done, now do the same for all bindings
for(var j=0,m=nBindings;j!==m;++j){var bindingsForPath=bindings[j],lastCached=bindingsForPath[firstActiveIndex],binding=bindingsForPath[index];bindingsForPath[index]=lastCached;if(binding===undefined){// since we do not bother to create new bindings
// for objects that are cached, the binding may
// or may not exist
binding=new PropertyBinding(object,paths[j],parsedPaths[j]);}bindingsForPath[firstActiveIndex]=binding;}}else if(objects[index]!==knownObject){console.error('THREE.AnimationObjectGroup: Different objects with the same UUID '+'detected. Clean the caches or recreate your infrastructure when reloading scenes.');}// else the object is already where we want it to be
}// for arguments
this.nCachedObjects_=nCachedObjects;},remove:function(){var objects=this._objects,nCachedObjects=this.nCachedObjects_,indicesByUUID=this._indicesByUUID,bindings=this._bindings,nBindings=bindings.length;for(var i=0,n=arguments.length;i!==n;++i){var object=arguments[i],uuid=object.uuid,index=indicesByUUID[uuid];if(index!==undefined&&index>=nCachedObjects){// move existing object into the CACHED region
var lastCachedIndex=nCachedObjects++,firstActiveObject=objects[lastCachedIndex];indicesByUUID[firstActiveObject.uuid]=index;objects[index]=firstActiveObject;indicesByUUID[uuid]=lastCachedIndex;objects[lastCachedIndex]=object;// accounting is done, now do the same for all bindings
for(var j=0,m=nBindings;j!==m;++j){var bindingsForPath=bindings[j],firstActive=bindingsForPath[lastCachedIndex],binding=bindingsForPath[index];bindingsForPath[index]=firstActive;bindingsForPath[lastCachedIndex]=binding;}}}// for arguments
this.nCachedObjects_=nCachedObjects;},// remove & forget
uncache:function(){var objects=this._objects,nObjects=objects.length,nCachedObjects=this.nCachedObjects_,indicesByUUID=this._indicesByUUID,bindings=this._bindings,nBindings=bindings.length;for(var i=0,n=arguments.length;i!==n;++i){var object=arguments[i],uuid=object.uuid,index=indicesByUUID[uuid];if(index!==undefined){delete indicesByUUID[uuid];if(index<nCachedObjects){// object is cached, shrink the CACHED region
var firstActiveIndex=--nCachedObjects,lastCachedObject=objects[firstActiveIndex],lastIndex=--nObjects,lastObject=objects[lastIndex];// last cached object takes this object's place
indicesByUUID[lastCachedObject.uuid]=index;objects[index]=lastCachedObject;// last object goes to the activated slot and pop
indicesByUUID[lastObject.uuid]=firstActiveIndex;objects[firstActiveIndex]=lastObject;objects.pop();// accounting is done, now do the same for all bindings
for(var j=0,m=nBindings;j!==m;++j){var bindingsForPath=bindings[j],lastCached=bindingsForPath[firstActiveIndex],last=bindingsForPath[lastIndex];bindingsForPath[index]=lastCached;bindingsForPath[firstActiveIndex]=last;bindingsForPath.pop();}}else{// object is active, just swap with the last and pop
var lastIndex=--nObjects,lastObject=objects[lastIndex];indicesByUUID[lastObject.uuid]=index;objects[index]=lastObject;objects.pop();// accounting is done, now do the same for all bindings
for(var j=0,m=nBindings;j!==m;++j){var bindingsForPath=bindings[j];bindingsForPath[index]=bindingsForPath[lastIndex];bindingsForPath.pop();}}// cached or active
}// if object is known
}// for arguments
this.nCachedObjects_=nCachedObjects;},// Internal interface used by befriended PropertyBinding.Composite:
subscribe_:function(path,parsedPath){// returns an array of bindings for the given path that is changed
// according to the contained objects in the group
var indicesByPath=this._bindingsIndicesByPath,index=indicesByPath[path],bindings=this._bindings;if(index!==undefined)return bindings[index];var paths=this._paths,parsedPaths=this._parsedPaths,objects=this._objects,nObjects=objects.length,nCachedObjects=this.nCachedObjects_,bindingsForPath=new Array(nObjects);index=bindings.length;indicesByPath[path]=index;paths.push(path);parsedPaths.push(parsedPath);bindings.push(bindingsForPath);for(var i=nCachedObjects,n=objects.length;i!==n;++i){var object=objects[i];bindingsForPath[i]=new PropertyBinding(object,path,parsedPath);}return bindingsForPath;},unsubscribe_:function(path){// tells the group to forget about a property path and no longer
// update the array previously obtained with 'subscribe_'
var indicesByPath=this._bindingsIndicesByPath,index=indicesByPath[path];if(index!==undefined){var paths=this._paths,parsedPaths=this._parsedPaths,bindings=this._bindings,lastBindingsIndex=bindings.length-1,lastBindings=bindings[lastBindingsIndex],lastBindingsPath=path[lastBindingsIndex];indicesByPath[lastBindingsPath]=index;bindings[index]=lastBindings;bindings.pop();parsedPaths[index]=parsedPaths[lastBindingsIndex];parsedPaths.pop();paths[index]=paths[lastBindingsIndex];paths.pop();}}});/**
*
* Action provided by AnimationMixer for scheduling clip playback on specific
* objects.
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*
*/function AnimationAction(mixer,clip,localRoot){this._mixer=mixer;this._clip=clip;this._localRoot=localRoot||null;var tracks=clip.tracks,nTracks=tracks.length,interpolants=new Array(nTracks);var interpolantSettings={endingStart:ZeroCurvatureEnding,endingEnd:ZeroCurvatureEnding};for(var i=0;i!==nTracks;++i){var interpolant=tracks[i].createInterpolant(null);interpolants[i]=interpolant;interpolant.settings=interpolantSettings;}this._interpolantSettings=interpolantSettings;this._interpolants=interpolants;// bound by the mixer
// inside: PropertyMixer (managed by the mixer)
this._propertyBindings=new Array(nTracks);this._cacheIndex=null;// for the memory manager
this._byClipCacheIndex=null;// for the memory manager
this._timeScaleInterpolant=null;this._weightInterpolant=null;this.loop=LoopRepeat;this._loopCount=-1;// global mixer time when the action is to be started
// it's set back to 'null' upon start of the action
this._startTime=null;// scaled local time of the action
// gets clamped or wrapped to 0..clip.duration according to loop
this.time=0;this.timeScale=1;this._effectiveTimeScale=1;this.weight=1;this._effectiveWeight=1;this.repetitions=Infinity;// no. of repetitions when looping
this.paused=false;// true -> zero effective time scale
this.enabled=true;// false -> zero effective weight
this.clampWhenFinished=false;// keep feeding the last frame?
this.zeroSlopeAtStart=true;// for smooth interpolation w/o separate
this.zeroSlopeAtEnd=true;// clips for start, loop and end
}Object.assign(AnimationAction.prototype,{// State & Scheduling
play:function(){this._mixer._activateAction(this);return this;},stop:function(){this._mixer._deactivateAction(this);return this.reset();},reset:function(){this.paused=false;this.enabled=true;this.time=0;// restart clip
this._loopCount=-1;// forget previous loops
this._startTime=null;// forget scheduling
return this.stopFading().stopWarping();},isRunning:function(){return this.enabled&&!this.paused&&this.timeScale!==0&&this._startTime===null&&this._mixer._isActiveAction(this);},// return true when play has been called
isScheduled:function(){return this._mixer._isActiveAction(this);},startAt:function(time){this._startTime=time;return this;},setLoop:function(mode,repetitions){this.loop=mode;this.repetitions=repetitions;return this;},// Weight
// set the weight stopping any scheduled fading
// although .enabled = false yields an effective weight of zero, this
// method does *not* change .enabled, because it would be confusing
setEffectiveWeight:function(weight){this.weight=weight;// note: same logic as when updated at runtime
this._effectiveWeight=this.enabled?weight:0;return this.stopFading();},// return the weight considering fading and .enabled
getEffectiveWeight:function(){return this._effectiveWeight;},fadeIn:function(duration){return this._scheduleFading(duration,0,1);},fadeOut:function(duration){return this._scheduleFading(duration,1,0);},crossFadeFrom:function(fadeOutAction,duration,warp){fadeOutAction.fadeOut(duration);this.fadeIn(duration);if(warp){var fadeInDuration=this._clip.duration,fadeOutDuration=fadeOutAction._clip.duration,startEndRatio=fadeOutDuration/fadeInDuration,endStartRatio=fadeInDuration/fadeOutDuration;fadeOutAction.warp(1.0,startEndRatio,duration);this.warp(endStartRatio,1.0,duration);}return this;},crossFadeTo:function(fadeInAction,duration,warp){return fadeInAction.crossFadeFrom(this,duration,warp);},stopFading:function(){var weightInterpolant=this._weightInterpolant;if(weightInterpolant!==null){this._weightInterpolant=null;this._mixer._takeBackControlInterpolant(weightInterpolant);}return this;},// Time Scale Control
// set the time scale stopping any scheduled warping
// although .paused = true yields an effective time scale of zero, this
// method does *not* change .paused, because it would be confusing
setEffectiveTimeScale:function(timeScale){this.timeScale=timeScale;this._effectiveTimeScale=this.paused?0:timeScale;return this.stopWarping();},// return the time scale considering warping and .paused
getEffectiveTimeScale:function(){return this._effectiveTimeScale;},setDuration:function(duration){this.timeScale=this._clip.duration/duration;return this.stopWarping();},syncWith:function(action){this.time=action.time;this.timeScale=action.timeScale;return this.stopWarping();},halt:function(duration){return this.warp(this._effectiveTimeScale,0,duration);},warp:function(startTimeScale,endTimeScale,duration){var mixer=this._mixer,now=mixer.time,interpolant=this._timeScaleInterpolant,timeScale=this.timeScale;if(interpolant===null){interpolant=mixer._lendControlInterpolant();this._timeScaleInterpolant=interpolant;}var times=interpolant.parameterPositions,values=interpolant.sampleValues;times[0]=now;times[1]=now+duration;values[0]=startTimeScale/timeScale;values[1]=endTimeScale/timeScale;return this;},stopWarping:function(){var timeScaleInterpolant=this._timeScaleInterpolant;if(timeScaleInterpolant!==null){this._timeScaleInterpolant=null;this._mixer._takeBackControlInterpolant(timeScaleInterpolant);}return this;},// Object Accessors
getMixer:function(){return this._mixer;},getClip:function(){return this._clip;},getRoot:function(){return this._localRoot||this._mixer._root;},// Interna
_update:function(time,deltaTime,timeDirection,accuIndex){// called by the mixer
if(!this.enabled){// call ._updateWeight() to update ._effectiveWeight
this._updateWeight(time);return;}var startTime=this._startTime;if(startTime!==null){// check for scheduled start of action
var timeRunning=(time-startTime)*timeDirection;if(timeRunning<0||timeDirection===0){return;// yet to come / don't decide when delta = 0
}// start
this._startTime=null;// unschedule
deltaTime=timeDirection*timeRunning;}// apply time scale and advance time
deltaTime*=this._updateTimeScale(time);var clipTime=this._updateTime(deltaTime);// note: _updateTime may disable the action resulting in
// an effective weight of 0
var weight=this._updateWeight(time);if(weight>0){var interpolants=this._interpolants;var propertyMixers=this._propertyBindings;for(var j=0,m=interpolants.length;j!==m;++j){interpolants[j].evaluate(clipTime);propertyMixers[j].accumulate(accuIndex,weight);}}},_updateWeight:function(time){var weight=0;if(this.enabled){weight=this.weight;var interpolant=this._weightInterpolant;if(interpolant!==null){var interpolantValue=interpolant.evaluate(time)[0];weight*=interpolantValue;if(time>interpolant.parameterPositions[1]){this.stopFading();if(interpolantValue===0){// faded out, disable
this.enabled=false;}}}}this._effectiveWeight=weight;return weight;},_updateTimeScale:function(time){var timeScale=0;if(!this.paused){timeScale=this.timeScale;var interpolant=this._timeScaleInterpolant;if(interpolant!==null){var interpolantValue=interpolant.evaluate(time)[0];timeScale*=interpolantValue;if(time>interpolant.parameterPositions[1]){this.stopWarping();if(timeScale===0){// motion has halted, pause
this.paused=true;}else{// warp done - apply final time scale
this.timeScale=timeScale;}}}}this._effectiveTimeScale=timeScale;return timeScale;},_updateTime:function(deltaTime){var time=this.time+deltaTime;if(deltaTime===0)return time;var duration=this._clip.duration,loop=this.loop,loopCount=this._loopCount;if(loop===LoopOnce){if(loopCount===-1){// just started
this._loopCount=0;this._setEndings(true,true,false);}handle_stop:{if(time>=duration){time=duration;}else if(time<0){time=0;}else break handle_stop;if(this.clampWhenFinished)this.paused=true;else this.enabled=false;this._mixer.dispatchEvent({type:'finished',action:this,direction:deltaTime<0?-1:1});}}else{// repetitive Repeat or PingPong
var pingPong=loop===LoopPingPong;if(loopCount===-1){// just started
if(deltaTime>=0){loopCount=0;this._setEndings(true,this.repetitions===0,pingPong);}else{// when looping in reverse direction, the initial
// transition through zero counts as a repetition,
// so leave loopCount at -1
this._setEndings(this.repetitions===0,true,pingPong);}}if(time>=duration||time<0){// wrap around
var loopDelta=Math.floor(time/duration);// signed
time-=duration*loopDelta;loopCount+=Math.abs(loopDelta);var pending=this.repetitions-loopCount;if(pending<=0){// have to stop (switch state, clamp time, fire event)
if(this.clampWhenFinished)this.paused=true;else this.enabled=false;time=deltaTime>0?duration:0;this._mixer.dispatchEvent({type:'finished',action:this,direction:deltaTime>0?1:-1});}else{// keep running
if(pending===1){// entering the last round
var atStart=deltaTime<0;this._setEndings(atStart,!atStart,pingPong);}else{this._setEndings(false,false,pingPong);}this._loopCount=loopCount;this._mixer.dispatchEvent({type:'loop',action:this,loopDelta:loopDelta});}}if(pingPong&&(loopCount&1)===1){// invert time for the "pong round"
this.time=time;return duration-time;}}this.time=time;return time;},_setEndings:function(atStart,atEnd,pingPong){var settings=this._interpolantSettings;if(pingPong){settings.endingStart=ZeroSlopeEnding;settings.endingEnd=ZeroSlopeEnding;}else{// assuming for LoopOnce atStart == atEnd == true
if(atStart){settings.endingStart=this.zeroSlopeAtStart?ZeroSlopeEnding:ZeroCurvatureEnding;}else{settings.endingStart=WrapAroundEnding;}if(atEnd){settings.endingEnd=this.zeroSlopeAtEnd?ZeroSlopeEnding:ZeroCurvatureEnding;}else{settings.endingEnd=WrapAroundEnding;}}},_scheduleFading:function(duration,weightNow,weightThen){var mixer=this._mixer,now=mixer.time,interpolant=this._weightInterpolant;if(interpolant===null){interpolant=mixer._lendControlInterpolant();this._weightInterpolant=interpolant;}var times=interpolant.parameterPositions,values=interpolant.sampleValues;times[0]=now;values[0]=weightNow;times[1]=now+duration;values[1]=weightThen;return this;}});/**
*
* Player for AnimationClips.
*
*
* @author Ben Houston / http://clara.io/
* @author David Sarno / http://lighthaus.us/
* @author tschw
*/function AnimationMixer(root){this._root=root;this._initMemoryManager();this._accuIndex=0;this.time=0;this.timeScale=1.0;}AnimationMixer.prototype=Object.assign(Object.create(EventDispatcher.prototype),{constructor:AnimationMixer,_bindAction:function(action,prototypeAction){var root=action._localRoot||this._root,tracks=action._clip.tracks,nTracks=tracks.length,bindings=action._propertyBindings,interpolants=action._interpolants,rootUuid=root.uuid,bindingsByRoot=this._bindingsByRootAndName,bindingsByName=bindingsByRoot[rootUuid];if(bindingsByName===undefined){bindingsByName={};bindingsByRoot[rootUuid]=bindingsByName;}for(var i=0;i!==nTracks;++i){var track=tracks[i],trackName=track.name,binding=bindingsByName[trackName];if(binding!==undefined){bindings[i]=binding;}else{binding=bindings[i];if(binding!==undefined){// existing binding, make sure the cache knows
if(binding._cacheIndex===null){++binding.referenceCount;this._addInactiveBinding(binding,rootUuid,trackName);}continue;}var path=prototypeAction&&prototypeAction._propertyBindings[i].binding.parsedPath;binding=new PropertyMixer(PropertyBinding.create(root,trackName,path),track.ValueTypeName,track.getValueSize());++binding.referenceCount;this._addInactiveBinding(binding,rootUuid,trackName);bindings[i]=binding;}interpolants[i].resultBuffer=binding.buffer;}},_activateAction:function(action){if(!this._isActiveAction(action)){if(action._cacheIndex===null){// this action has been forgotten by the cache, but the user
// appears to be still using it -> rebind
var rootUuid=(action._localRoot||this._root).uuid,clipUuid=action._clip.uuid,actionsForClip=this._actionsByClip[clipUuid];this._bindAction(action,actionsForClip&&actionsForClip.knownActions[0]);this._addInactiveAction(action,clipUuid,rootUuid);}var bindings=action._propertyBindings;// increment reference counts / sort out state
for(var i=0,n=bindings.length;i!==n;++i){var binding=bindings[i];if(binding.useCount++===0){this._lendBinding(binding);binding.saveOriginalState();}}this._lendAction(action);}},_deactivateAction:function(action){if(this._isActiveAction(action)){var bindings=action._propertyBindings;// decrement reference counts / sort out state
for(var i=0,n=bindings.length;i!==n;++i){var binding=bindings[i];if(--binding.useCount===0){binding.restoreOriginalState();this._takeBackBinding(binding);}}this._takeBackAction(action);}},// Memory manager
_initMemoryManager:function(){this._actions=[];// 'nActiveActions' followed by inactive ones
this._nActiveActions=0;this._actionsByClip={};// inside:
// {
// knownActions: Array< AnimationAction > - used as prototypes
// actionByRoot: AnimationAction - lookup
// }
this._bindings=[];// 'nActiveBindings' followed by inactive ones
this._nActiveBindings=0;this._bindingsByRootAndName={};// inside: Map< name, PropertyMixer >
this._controlInterpolants=[];// same game as above
this._nActiveControlInterpolants=0;var scope=this;this.stats={actions:{get total(){return scope._actions.length;},get inUse(){return scope._nActiveActions;}},bindings:{get total(){return scope._bindings.length;},get inUse(){return scope._nActiveBindings;}},controlInterpolants:{get total(){return scope._controlInterpolants.length;},get inUse(){return scope._nActiveControlInterpolants;}}};},// Memory management for AnimationAction objects
_isActiveAction:function(action){var index=action._cacheIndex;return index!==null&&index<this._nActiveActions;},_addInactiveAction:function(action,clipUuid,rootUuid){var actions=this._actions,actionsByClip=this._actionsByClip,actionsForClip=actionsByClip[clipUuid];if(actionsForClip===undefined){actionsForClip={knownActions:[action],actionByRoot:{}};action._byClipCacheIndex=0;actionsByClip[clipUuid]=actionsForClip;}else{var knownActions=actionsForClip.knownActions;action._byClipCacheIndex=knownActions.length;knownActions.push(action);}action._cacheIndex=actions.length;actions.push(action);actionsForClip.actionByRoot[rootUuid]=action;},_removeInactiveAction:function(action){var actions=this._actions,lastInactiveAction=actions[actions.length-1],cacheIndex=action._cacheIndex;lastInactiveAction._cacheIndex=cacheIndex;actions[cacheIndex]=lastInactiveAction;actions.pop();action._cacheIndex=null;var clipUuid=action._clip.uuid,actionsByClip=this._actionsByClip,actionsForClip=actionsByClip[clipUuid],knownActionsForClip=actionsForClip.knownActions,lastKnownAction=knownActionsForClip[knownActionsForClip.length-1],byClipCacheIndex=action._byClipCacheIndex;lastKnownAction._byClipCacheIndex=byClipCacheIndex;knownActionsForClip[byClipCacheIndex]=lastKnownAction;knownActionsForClip.pop();action._byClipCacheIndex=null;var actionByRoot=actionsForClip.actionByRoot,rootUuid=(action._localRoot||this._root).uuid;delete actionByRoot[rootUuid];if(knownActionsForClip.length===0){delete actionsByClip[clipUuid];}this._removeInactiveBindingsForAction(action);},_removeInactiveBindingsForAction:function(action){var bindings=action._propertyBindings;for(var i=0,n=bindings.length;i!==n;++i){var binding=bindings[i];if(--binding.referenceCount===0){this._removeInactiveBinding(binding);}}},_lendAction:function(action){// [ active actions | inactive actions ]
// [ active actions >| inactive actions ]
// s a
// <-swap->
// a s
var actions=this._actions,prevIndex=action._cacheIndex,lastActiveIndex=this._nActiveActions++,firstInactiveAction=actions[lastActiveIndex];action._cacheIndex=lastActiveIndex;actions[lastActiveIndex]=action;firstInactiveAction._cacheIndex=prevIndex;actions[prevIndex]=firstInactiveAction;},_takeBackAction:function(action){// [ active actions | inactive actions ]
// [ active actions |< inactive actions ]
// a s
// <-swap->
// s a
var actions=this._actions,prevIndex=action._cacheIndex,firstInactiveIndex=--this._nActiveActions,lastActiveAction=actions[firstInactiveIndex];action._cacheIndex=firstInactiveIndex;actions[firstInactiveIndex]=action;lastActiveAction._cacheIndex=prevIndex;actions[prevIndex]=lastActiveAction;},// Memory management for PropertyMixer objects
_addInactiveBinding:function(binding,rootUuid,trackName){var bindingsByRoot=this._bindingsByRootAndName,bindingByName=bindingsByRoot[rootUuid],bindings=this._bindings;if(bindingByName===undefined){bindingByName={};bindingsByRoot[rootUuid]=bindingByName;}bindingByName[trackName]=binding;binding._cacheIndex=bindings.length;bindings.push(binding);},_removeInactiveBinding:function(binding){var bindings=this._bindings,propBinding=binding.binding,rootUuid=propBinding.rootNode.uuid,trackName=propBinding.path,bindingsByRoot=this._bindingsByRootAndName,bindingByName=bindingsByRoot[rootUuid],lastInactiveBinding=bindings[bindings.length-1],cacheIndex=binding._cacheIndex;lastInactiveBinding._cacheIndex=cacheIndex;bindings[cacheIndex]=lastInactiveBinding;bindings.pop();delete bindingByName[trackName];remove_empty_map:{for(var _ in bindingByName)break remove_empty_map;// eslint-disable-line no-unused-vars
delete bindingsByRoot[rootUuid];}},_lendBinding:function(binding){var bindings=this._bindings,prevIndex=binding._cacheIndex,lastActiveIndex=this._nActiveBindings++,firstInactiveBinding=bindings[lastActiveIndex];binding._cacheIndex=lastActiveIndex;bindings[lastActiveIndex]=binding;firstInactiveBinding._cacheIndex=prevIndex;bindings[prevIndex]=firstInactiveBinding;},_takeBackBinding:function(binding){var bindings=this._bindings,prevIndex=binding._cacheIndex,firstInactiveIndex=--this._nActiveBindings,lastActiveBinding=bindings[firstInactiveIndex];binding._cacheIndex=firstInactiveIndex;bindings[firstInactiveIndex]=binding;lastActiveBinding._cacheIndex=prevIndex;bindings[prevIndex]=lastActiveBinding;},// Memory management of Interpolants for weight and time scale
_lendControlInterpolant:function(){var interpolants=this._controlInterpolants,lastActiveIndex=this._nActiveControlInterpolants++,interpolant=interpolants[lastActiveIndex];if(interpolant===undefined){interpolant=new LinearInterpolant(new Float32Array(2),new Float32Array(2),1,this._controlInterpolantsResultBuffer);interpolant.__cacheIndex=lastActiveIndex;interpolants[lastActiveIndex]=interpolant;}return interpolant;},_takeBackControlInterpolant:function(interpolant){var interpolants=this._controlInterpolants,prevIndex=interpolant.__cacheIndex,firstInactiveIndex=--this._nActiveControlInterpolants,lastActiveInterpolant=interpolants[firstInactiveIndex];interpolant.__cacheIndex=firstInactiveIndex;interpolants[firstInactiveIndex]=interpolant;lastActiveInterpolant.__cacheIndex=prevIndex;interpolants[prevIndex]=lastActiveInterpolant;},_controlInterpolantsResultBuffer:new Float32Array(1),// return an action for a clip optionally using a custom root target
// object (this method allocates a lot of dynamic memory in case a
// previously unknown clip/root combination is specified)
clipAction:function(clip,optionalRoot){var root=optionalRoot||this._root,rootUuid=root.uuid,clipObject=typeof clip==='string'?AnimationClip.findByName(root,clip):clip,clipUuid=clipObject!==null?clipObject.uuid:clip,actionsForClip=this._actionsByClip[clipUuid],prototypeAction=null;if(actionsForClip!==undefined){var existingAction=actionsForClip.actionByRoot[rootUuid];if(existingAction!==undefined){return existingAction;}// we know the clip, so we don't have to parse all
// the bindings again but can just copy
prototypeAction=actionsForClip.knownActions[0];// also, take the clip from the prototype action
if(clipObject===null)clipObject=prototypeAction._clip;}// clip must be known when specified via string
if(clipObject===null)return null;// allocate all resources required to run it
var newAction=new AnimationAction(this,clipObject,optionalRoot);this._bindAction(newAction,prototypeAction);// and make the action known to the memory manager
this._addInactiveAction(newAction,clipUuid,rootUuid);return newAction;},// get an existing action
existingAction:function(clip,optionalRoot){var root=optionalRoot||this._root,rootUuid=root.uuid,clipObject=typeof clip==='string'?AnimationClip.findByName(root,clip):clip,clipUuid=clipObject?clipObject.uuid:clip,actionsForClip=this._actionsByClip[clipUuid];if(actionsForClip!==undefined){return actionsForClip.actionByRoot[rootUuid]||null;}return null;},// deactivates all previously scheduled actions
stopAllAction:function(){var actions=this._actions,nActions=this._nActiveActions,bindings=this._bindings,nBindings=this._nActiveBindings;this._nActiveActions=0;this._nActiveBindings=0;for(var i=0;i!==nActions;++i){actions[i].reset();}for(var i=0;i!==nBindings;++i){bindings[i].useCount=0;}return this;},// advance the time and update apply the animation
update:function(deltaTime){deltaTime*=this.timeScale;var actions=this._actions,nActions=this._nActiveActions,time=this.time+=deltaTime,timeDirection=Math.sign(deltaTime),accuIndex=this._accuIndex^=1;// run active actions
for(var i=0;i!==nActions;++i){var action=actions[i];action._update(time,deltaTime,timeDirection,accuIndex);}// update scene graph
var bindings=this._bindings,nBindings=this._nActiveBindings;for(var i=0;i!==nBindings;++i){bindings[i].apply(accuIndex);}return this;},// return this mixer's root target object
getRoot:function(){return this._root;},// free all resources specific to a particular clip
uncacheClip:function(clip){var actions=this._actions,clipUuid=clip.uuid,actionsByClip=this._actionsByClip,actionsForClip=actionsByClip[clipUuid];if(actionsForClip!==undefined){// note: just calling _removeInactiveAction would mess up the
// iteration state and also require updating the state we can
// just throw away
var actionsToRemove=actionsForClip.knownActions;for(var i=0,n=actionsToRemove.length;i!==n;++i){var action=actionsToRemove[i];this._deactivateAction(action);var cacheIndex=action._cacheIndex,lastInactiveAction=actions[actions.length-1];action._cacheIndex=null;action._byClipCacheIndex=null;lastInactiveAction._cacheIndex=cacheIndex;actions[cacheIndex]=lastInactiveAction;actions.pop();this._removeInactiveBindingsForAction(action);}delete actionsByClip[clipUuid];}},// free all resources specific to a particular root target object
uncacheRoot:function(root){var rootUuid=root.uuid,actionsByClip=this._actionsByClip;for(var clipUuid in actionsByClip){var actionByRoot=actionsByClip[clipUuid].actionByRoot,action=actionByRoot[rootUuid];if(action!==undefined){this._deactivateAction(action);this._removeInactiveAction(action);}}var bindingsByRoot=this._bindingsByRootAndName,bindingByName=bindingsByRoot[rootUuid];if(bindingByName!==undefined){for(var trackName in bindingByName){var binding=bindingByName[trackName];binding.restoreOriginalState();this._removeInactiveBinding(binding);}}},// remove a targeted clip from the cache
uncacheAction:function(clip,optionalRoot){var action=this.existingAction(clip,optionalRoot);if(action!==null){this._deactivateAction(action);this._removeInactiveAction(action);}}});/**
* @author mrdoob / http://mrdoob.com/
*/function Uniform(value){if(typeof value==='string'){console.warn('THREE.Uniform: Type parameter is no longer needed.');value=arguments[1];}this.value=value;}Uniform.prototype.clone=function(){return new Uniform(this.value.clone===undefined?this.value:this.value.clone());};/**
* @author benaadams / https://twitter.com/ben_a_adams
*/function InstancedBufferGeometry(){BufferGeometry.call(this);this.type='InstancedBufferGeometry';this.maxInstancedCount=undefined;}InstancedBufferGeometry.prototype=Object.assign(Object.create(BufferGeometry.prototype),{constructor:InstancedBufferGeometry,isInstancedBufferGeometry:true,copy:function(source){BufferGeometry.prototype.copy.call(this,source);this.maxInstancedCount=source.maxInstancedCount;return this;},clone:function(){return new this.constructor().copy(this);}});/**
* @author benaadams / https://twitter.com/ben_a_adams
*/function InterleavedBufferAttribute(interleavedBuffer,itemSize,offset,normalized){this.data=interleavedBuffer;this.itemSize=itemSize;this.offset=offset;this.normalized=normalized===true;}Object.defineProperties(InterleavedBufferAttribute.prototype,{count:{get:function(){return this.data.count;}},array:{get:function(){return this.data.array;}}});Object.assign(InterleavedBufferAttribute.prototype,{isInterleavedBufferAttribute:true,setX:function(index,x){this.data.array[index*this.data.stride+this.offset]=x;return this;},setY:function(index,y){this.data.array[index*this.data.stride+this.offset+1]=y;return this;},setZ:function(index,z){this.data.array[index*this.data.stride+this.offset+2]=z;return this;},setW:function(index,w){this.data.array[index*this.data.stride+this.offset+3]=w;return this;},getX:function(index){return this.data.array[index*this.data.stride+this.offset];},getY:function(index){return this.data.array[index*this.data.stride+this.offset+1];},getZ:function(index){return this.data.array[index*this.data.stride+this.offset+2];},getW:function(index){return this.data.array[index*this.data.stride+this.offset+3];},setXY:function(index,x,y){index=index*this.data.stride+this.offset;this.data.array[index+0]=x;this.data.array[index+1]=y;return this;},setXYZ:function(index,x,y,z){index=index*this.data.stride+this.offset;this.data.array[index+0]=x;this.data.array[index+1]=y;this.data.array[index+2]=z;return this;},setXYZW:function(index,x,y,z,w){index=index*this.data.stride+this.offset;this.data.array[index+0]=x;this.data.array[index+1]=y;this.data.array[index+2]=z;this.data.array[index+3]=w;return this;}});/**
* @author benaadams / https://twitter.com/ben_a_adams
*/function InterleavedBuffer(array,stride){this.array=array;this.stride=stride;this.count=array!==undefined?array.length/stride:0;this.dynamic=false;this.updateRange={offset:0,count:-1};this.version=0;}Object.defineProperty(InterleavedBuffer.prototype,'needsUpdate',{set:function(value){if(value===true)this.version++;}});Object.assign(InterleavedBuffer.prototype,{isInterleavedBuffer:true,onUploadCallback:function(){},setArray:function(array){if(Array.isArray(array)){throw new TypeError('THREE.BufferAttribute: array should be a Typed Array.');}this.count=array!==undefined?array.length/this.stride:0;this.array=array;return this;},setDynamic:function(value){this.dynamic=value;return this;},copy:function(source){this.array=new source.array.constructor(source.array);this.count=source.count;this.stride=source.stride;this.dynamic=source.dynamic;return this;},copyAt:function(index1,attribute,index2){index1*=this.stride;index2*=attribute.stride;for(var i=0,l=this.stride;i<l;i++){this.array[index1+i]=attribute.array[index2+i];}return this;},set:function(value,offset){if(offset===undefined)offset=0;this.array.set(value,offset);return this;},clone:function(){return new this.constructor().copy(this);},onUpload:function(callback){this.onUploadCallback=callback;return this;}});/**
* @author benaadams / https://twitter.com/ben_a_adams
*/function InstancedInterleavedBuffer(array,stride,meshPerAttribute){InterleavedBuffer.call(this,array,stride);this.meshPerAttribute=meshPerAttribute||1;}InstancedInterleavedBuffer.prototype=Object.assign(Object.create(InterleavedBuffer.prototype),{constructor:InstancedInterleavedBuffer,isInstancedInterleavedBuffer:true,copy:function(source){InterleavedBuffer.prototype.copy.call(this,source);this.meshPerAttribute=source.meshPerAttribute;return this;}});/**
* @author benaadams / https://twitter.com/ben_a_adams
*/function InstancedBufferAttribute(array,itemSize,meshPerAttribute){BufferAttribute.call(this,array,itemSize);this.meshPerAttribute=meshPerAttribute||1;}InstancedBufferAttribute.prototype=Object.assign(Object.create(BufferAttribute.prototype),{constructor:InstancedBufferAttribute,isInstancedBufferAttribute:true,copy:function(source){BufferAttribute.prototype.copy.call(this,source);this.meshPerAttribute=source.meshPerAttribute;return this;}});/**
* @author mrdoob / http://mrdoob.com/
* @author bhouston / http://clara.io/
* @author stephomi / http://stephaneginier.com/
*/function Raycaster(origin,direction,near,far){this.ray=new Ray(origin,direction);// direction is assumed to be normalized (for accurate distance calculations)
this.near=near||0;this.far=far||Infinity;this.params={Mesh:{},Line:{},LOD:{},Points:{threshold:1},Sprite:{}};Object.defineProperties(this.params,{PointCloud:{get:function(){console.warn('THREE.Raycaster: params.PointCloud has been renamed to params.Points.');return this.Points;}}});}function ascSort(a,b){return a.distance-b.distance;}function intersectObject(object,raycaster,intersects,recursive){if(object.visible===false)return;object.raycast(raycaster,intersects);if(recursive===true){var children=object.children;for(var i=0,l=children.length;i<l;i++){intersectObject(children[i],raycaster,intersects,true);}}}Object.assign(Raycaster.prototype,{linePrecision:1,set:function(origin,direction){// direction is assumed to be normalized (for accurate distance calculations)
this.ray.set(origin,direction);},setFromCamera:function(coords,camera){if(camera&&camera.isPerspectiveCamera){this.ray.origin.setFromMatrixPosition(camera.matrixWorld);this.ray.direction.set(coords.x,coords.y,0.5).unproject(camera).sub(this.ray.origin).normalize();}else if(camera&&camera.isOrthographicCamera){this.ray.origin.set(coords.x,coords.y,(camera.near+camera.far)/(camera.near-camera.far)).unproject(camera);// set origin in plane of camera
this.ray.direction.set(0,0,-1).transformDirection(camera.matrixWorld);}else{console.error('THREE.Raycaster: Unsupported camera type.');}},intersectObject:function(object,recursive,optionalTarget){var intersects=optionalTarget||[];intersectObject(object,this,intersects,recursive);intersects.sort(ascSort);return intersects;},intersectObjects:function(objects,recursive,optionalTarget){var intersects=optionalTarget||[];if(Array.isArray(objects)===false){console.warn('THREE.Raycaster.intersectObjects: objects is not an Array.');return intersects;}for(var i=0,l=objects.length;i<l;i++){intersectObject(objects[i],this,intersects,recursive);}intersects.sort(ascSort);return intersects;}});/**
* @author alteredq / http://alteredqualia.com/
*/function Clock(autoStart){this.autoStart=autoStart!==undefined?autoStart:true;this.startTime=0;this.oldTime=0;this.elapsedTime=0;this.running=false;}Object.assign(Clock.prototype,{start:function(){this.startTime=(typeof performance==='undefined'?Date:performance).now();// see #10732
this.oldTime=this.startTime;this.elapsedTime=0;this.running=true;},stop:function(){this.getElapsedTime();this.running=false;this.autoStart=false;},getElapsedTime:function(){this.getDelta();return this.elapsedTime;},getDelta:function(){var diff=0;if(this.autoStart&&!this.running){this.start();return 0;}if(this.running){var newTime=(typeof performance==='undefined'?Date:performance).now();diff=(newTime-this.oldTime)/1000;this.oldTime=newTime;this.elapsedTime+=diff;}return diff;}});/**
* @author bhouston / http://clara.io
* @author WestLangley / http://github.com/WestLangley
*
* Ref: https://en.wikipedia.org/wiki/Spherical_coordinate_system
*
* The poles (phi) are at the positive and negative y axis.
* The equator starts at positive z.
*/function Spherical(radius,phi,theta){this.radius=radius!==undefined?radius:1.0;this.phi=phi!==undefined?phi:0;// up / down towards top and bottom pole
this.theta=theta!==undefined?theta:0;// around the equator of the sphere
return this;}Object.assign(Spherical.prototype,{set:function(radius,phi,theta){this.radius=radius;this.phi=phi;this.theta=theta;return this;},clone:function(){return new this.constructor().copy(this);},copy:function(other){this.radius=other.radius;this.phi=other.phi;this.theta=other.theta;return this;},// restrict phi to be betwee EPS and PI-EPS
makeSafe:function(){var EPS=0.000001;this.phi=Math.max(EPS,Math.min(Math.PI-EPS,this.phi));return this;},setFromVector3:function(vec3){this.radius=vec3.length();if(this.radius===0){this.theta=0;this.phi=0;}else{this.theta=Math.atan2(vec3.x,vec3.z);// equator angle around y-up axis
this.phi=Math.acos(_Math.clamp(vec3.y/this.radius,-1,1));// polar angle
}return this;}});/**
* @author Mugen87 / https://github.com/Mugen87
*
* Ref: https://en.wikipedia.org/wiki/Cylindrical_coordinate_system
*
*/function Cylindrical(radius,theta,y){this.radius=radius!==undefined?radius:1.0;// distance from the origin to a point in the x-z plane
this.theta=theta!==undefined?theta:0;// counterclockwise angle in the x-z plane measured in radians from the positive z-axis
this.y=y!==undefined?y:0;// height above the x-z plane
return this;}Object.assign(Cylindrical.prototype,{set:function(radius,theta,y){this.radius=radius;this.theta=theta;this.y=y;return this;},clone:function(){return new this.constructor().copy(this);},copy:function(other){this.radius=other.radius;this.theta=other.theta;this.y=other.y;return this;},setFromVector3:function(vec3){this.radius=Math.sqrt(vec3.x*vec3.x+vec3.z*vec3.z);this.theta=Math.atan2(vec3.x,vec3.z);this.y=vec3.y;return this;}});/**
* @author bhouston / http://clara.io
*/function Box2(min,max){this.min=min!==undefined?min:new Vector2(+Infinity,+Infinity);this.max=max!==undefined?max:new Vector2(-Infinity,-Infinity);}Object.assign(Box2.prototype,{set:function(min,max){this.min.copy(min);this.max.copy(max);return this;},setFromPoints:function(points){this.makeEmpty();for(var i=0,il=points.length;i<il;i++){this.expandByPoint(points[i]);}return this;},setFromCenterAndSize:function(){var v1=new Vector2();return function setFromCenterAndSize(center,size){var halfSize=v1.copy(size).multiplyScalar(0.5);this.min.copy(center).sub(halfSize);this.max.copy(center).add(halfSize);return this;};}(),clone:function(){return new this.constructor().copy(this);},copy:function(box){this.min.copy(box.min);this.max.copy(box.max);return this;},makeEmpty:function(){this.min.x=this.min.y=+Infinity;this.max.x=this.max.y=-Infinity;return this;},isEmpty:function(){// this is a more robust check for empty than ( volume <= 0 ) because volume can get positive with two negative axes
return this.max.x<this.min.x||this.max.y<this.min.y;},getCenter:function(target){if(target===undefined){console.warn('THREE.Box2: .getCenter() target is now required');target=new Vector2();}return this.isEmpty()?target.set(0,0):target.addVectors(this.min,this.max).multiplyScalar(0.5);},getSize:function(target){if(target===undefined){console.warn('THREE.Box2: .getSize() target is now required');target=new Vector2();}return this.isEmpty()?target.set(0,0):target.subVectors(this.max,this.min);},expandByPoint:function(point){this.min.min(point);this.max.max(point);return this;},expandByVector:function(vector){this.min.sub(vector);this.max.add(vector);return this;},expandByScalar:function(scalar){this.min.addScalar(-scalar);this.max.addScalar(scalar);return this;},containsPoint:function(point){return point.x<this.min.x||point.x>this.max.x||point.y<this.min.y||point.y>this.max.y?false:true;},containsBox:function(box){return this.min.x<=box.min.x&&box.max.x<=this.max.x&&this.min.y<=box.min.y&&box.max.y<=this.max.y;},getParameter:function(point,target){// This can potentially have a divide by zero if the box
// has a size dimension of 0.
if(target===undefined){console.warn('THREE.Box2: .getParameter() target is now required');target=new Vector2();}return target.set((point.x-this.min.x)/(this.max.x-this.min.x),(point.y-this.min.y)/(this.max.y-this.min.y));},intersectsBox:function(box){// using 4 splitting planes to rule out intersections
return box.max.x<this.min.x||box.min.x>this.max.x||box.max.y<this.min.y||box.min.y>this.max.y?false:true;},clampPoint:function(point,target){if(target===undefined){console.warn('THREE.Box2: .clampPoint() target is now required');target=new Vector2();}return target.copy(point).clamp(this.min,this.max);},distanceToPoint:function(){var v1=new Vector2();return function distanceToPoint(point){var clampedPoint=v1.copy(point).clamp(this.min,this.max);return clampedPoint.sub(point).length();};}(),intersect:function(box){this.min.max(box.min);this.max.min(box.max);return this;},union:function(box){this.min.min(box.min);this.max.max(box.max);return this;},translate:function(offset){this.min.add(offset);this.max.add(offset);return this;},equals:function(box){return box.min.equals(this.min)&&box.max.equals(this.max);}});/**
* @author alteredq / http://alteredqualia.com/
*/function ImmediateRenderObject(material){Object3D.call(this);this.material=material;this.render=function()/* renderCallback */{};}ImmediateRenderObject.prototype=Object.create(Object3D.prototype);ImmediateRenderObject.prototype.constructor=ImmediateRenderObject;ImmediateRenderObject.prototype.isImmediateRenderObject=true;/**
* @author mrdoob / http://mrdoob.com/
* @author WestLangley / http://github.com/WestLangley
*/function VertexNormalsHelper(object,size,hex,linewidth){this.object=object;this.size=size!==undefined?size:1;var color=hex!==undefined?hex:0xff0000;var width=linewidth!==undefined?linewidth:1;//
var nNormals=0;var objGeometry=this.object.geometry;if(objGeometry&&objGeometry.isGeometry){nNormals=objGeometry.faces.length*3;}else if(objGeometry&&objGeometry.isBufferGeometry){nNormals=objGeometry.attributes.normal.count;}//
var geometry=new BufferGeometry();var positions=new Float32BufferAttribute(nNormals*2*3,3);geometry.addAttribute('position',positions);LineSegments.call(this,geometry,new LineBasicMaterial({color:color,linewidth:width}));//
this.matrixAutoUpdate=false;this.update();}VertexNormalsHelper.prototype=Object.create(LineSegments.prototype);VertexNormalsHelper.prototype.constructor=VertexNormalsHelper;VertexNormalsHelper.prototype.update=function(){var v1=new Vector3();var v2=new Vector3();var normalMatrix=new Matrix3();return function update(){var keys=['a','b','c'];this.object.updateMatrixWorld(true);normalMatrix.getNormalMatrix(this.object.matrixWorld);var matrixWorld=this.object.matrixWorld;var position=this.geometry.attributes.position;//
var objGeometry=this.object.geometry;if(objGeometry&&objGeometry.isGeometry){var vertices=objGeometry.vertices;var faces=objGeometry.faces;var idx=0;for(var i=0,l=faces.length;i<l;i++){var face=faces[i];for(var j=0,jl=face.vertexNormals.length;j<jl;j++){var vertex=vertices[face[keys[j]]];var normal=face.vertexNormals[j];v1.copy(vertex).applyMatrix4(matrixWorld);v2.copy(normal).applyMatrix3(normalMatrix).normalize().multiplyScalar(this.size).add(v1);position.setXYZ(idx,v1.x,v1.y,v1.z);idx=idx+1;position.setXYZ(idx,v2.x,v2.y,v2.z);idx=idx+1;}}}else if(objGeometry&&objGeometry.isBufferGeometry){var objPos=objGeometry.attributes.position;var objNorm=objGeometry.attributes.normal;var idx=0;// for simplicity, ignore index and drawcalls, and render every normal
for(var j=0,jl=objPos.count;j<jl;j++){v1.set(objPos.getX(j),objPos.getY(j),objPos.getZ(j)).applyMatrix4(matrixWorld);v2.set(objNorm.getX(j),objNorm.getY(j),objNorm.getZ(j));v2.applyMatrix3(normalMatrix).normalize().multiplyScalar(this.size).add(v1);position.setXYZ(idx,v1.x,v1.y,v1.z);idx=idx+1;position.setXYZ(idx,v2.x,v2.y,v2.z);idx=idx+1;}}position.needsUpdate=true;};}();/**
* @author alteredq / http://alteredqualia.com/
* @author mrdoob / http://mrdoob.com/
* @author WestLangley / http://github.com/WestLangley
*/function SpotLightHelper(light,color){Object3D.call(this);this.light=light;this.light.updateMatrixWorld();this.matrix=light.matrixWorld;this.matrixAutoUpdate=false;this.color=color;var geometry=new BufferGeometry();var positions=[0,0,0,0,0,1,0,0,0,1,0,1,0,0,0,-1,0,1,0,0,0,0,1,1,0,0,0,0,-1,1];for(var i=0,j=1,l=32;i<l;i++,j++){var p1=i/l*Math.PI*2;var p2=j/l*Math.PI*2;positions.push(Math.cos(p1),Math.sin(p1),1,Math.cos(p2),Math.sin(p2),1);}geometry.addAttribute('position',new Float32BufferAttribute(positions,3));var material=new LineBasicMaterial({fog:false});this.cone=new LineSegments(geometry,material);this.add(this.cone);this.update();}SpotLightHelper.prototype=Object.create(Object3D.prototype);SpotLightHelper.prototype.constructor=SpotLightHelper;SpotLightHelper.prototype.dispose=function(){this.cone.geometry.dispose();this.cone.material.dispose();};SpotLightHelper.prototype.update=function(){var vector=new Vector3();var vector2=new Vector3();return function update(){this.light.updateMatrixWorld();var coneLength=this.light.distance?this.light.distance:1000;var coneWidth=coneLength*Math.tan(this.light.angle);this.cone.scale.set(coneWidth,coneWidth,coneLength);vector.setFromMatrixPosition(this.light.matrixWorld);vector2.setFromMatrixPosition(this.light.target.matrixWorld);this.cone.lookAt(vector2.sub(vector));if(this.color!==undefined){this.cone.material.color.set(this.color);}else{this.cone.material.color.copy(this.light.color);}};}();/**
* @author Sean Griffin / http://twitter.com/sgrif
* @author Michael Guerrero / http://realitymeltdown.com
* @author mrdoob / http://mrdoob.com/
* @author ikerr / http://verold.com
* @author Mugen87 / https://github.com/Mugen87
*/function getBoneList(object){var boneList=[];if(object&&object.isBone){boneList.push(object);}for(var i=0;i<object.children.length;i++){boneList.push.apply(boneList,getBoneList(object.children[i]));}return boneList;}function SkeletonHelper(object){var bones=getBoneList(object);var geometry=new BufferGeometry();var vertices=[];var colors=[];var color1=new Color(0,0,1);var color2=new Color(0,1,0);for(var i=0;i<bones.length;i++){var bone=bones[i];if(bone.parent&&bone.parent.isBone){vertices.push(0,0,0);vertices.push(0,0,0);colors.push(color1.r,color1.g,color1.b);colors.push(color2.r,color2.g,color2.b);}}geometry.addAttribute('position',new Float32BufferAttribute(vertices,3));geometry.addAttribute('color',new Float32BufferAttribute(colors,3));var material=new LineBasicMaterial({vertexColors:VertexColors,depthTest:false,depthWrite:false,transparent:true});LineSegments.call(this,geometry,material);this.root=object;this.bones=bones;this.matrix=object.matrixWorld;this.matrixAutoUpdate=false;}SkeletonHelper.prototype=Object.create(LineSegments.prototype);SkeletonHelper.prototype.constructor=SkeletonHelper;SkeletonHelper.prototype.updateMatrixWorld=function(){var vector=new Vector3();var boneMatrix=new Matrix4();var matrixWorldInv=new Matrix4();return function updateMatrixWorld(force){var bones=this.bones;var geometry=this.geometry;var position=geometry.getAttribute('position');matrixWorldInv.getInverse(this.root.matrixWorld);for(var i=0,j=0;i<bones.length;i++){var bone=bones[i];if(bone.parent&&bone.parent.isBone){boneMatrix.multiplyMatrices(matrixWorldInv,bone.matrixWorld);vector.setFromMatrixPosition(boneMatrix);position.setXYZ(j,vector.x,vector.y,vector.z);boneMatrix.multiplyMatrices(matrixWorldInv,bone.parent.matrixWorld);vector.setFromMatrixPosition(boneMatrix);position.setXYZ(j+1,vector.x,vector.y,vector.z);j+=2;}}geometry.getAttribute('position').needsUpdate=true;Object3D.prototype.updateMatrixWorld.call(this,force);};}();/**
* @author alteredq / http://alteredqualia.com/
* @author mrdoob / http://mrdoob.com/
*/function PointLightHelper(light,sphereSize,color){this.light=light;this.light.updateMatrixWorld();this.color=color;var geometry=new SphereBufferGeometry(sphereSize,4,2);var material=new MeshBasicMaterial({wireframe:true,fog:false});Mesh.call(this,geometry,material);this.matrix=this.light.matrixWorld;this.matrixAutoUpdate=false;this.update();/*
var distanceGeometry = new THREE.IcosahedronGeometry( 1, 2 );
var distanceMaterial = new THREE.MeshBasicMaterial( { color: hexColor, fog: false, wireframe: true, opacity: 0.1, transparent: true } );
this.lightSphere = new THREE.Mesh( bulbGeometry, bulbMaterial );
this.lightDistance = new THREE.Mesh( distanceGeometry, distanceMaterial );
var d = light.distance;
if ( d === 0.0 ) {
this.lightDistance.visible = false;
} else {
this.lightDistance.scale.set( d, d, d );
}
this.add( this.lightDistance );
*/}PointLightHelper.prototype=Object.create(Mesh.prototype);PointLightHelper.prototype.constructor=PointLightHelper;PointLightHelper.prototype.dispose=function(){this.geometry.dispose();this.material.dispose();};PointLightHelper.prototype.update=function(){if(this.color!==undefined){this.material.color.set(this.color);}else{this.material.color.copy(this.light.color);}/*
var d = this.light.distance;
if ( d === 0.0 ) {
this.lightDistance.visible = false;
} else {
this.lightDistance.visible = true;
this.lightDistance.scale.set( d, d, d );
}
*/};/**
* @author abelnation / http://github.com/abelnation
* @author Mugen87 / http://github.com/Mugen87
* @author WestLangley / http://github.com/WestLangley
*/function RectAreaLightHelper(light,color){Object3D.call(this);this.light=light;this.light.updateMatrixWorld();this.matrix=light.matrixWorld;this.matrixAutoUpdate=false;this.color=color;var material=new LineBasicMaterial({fog:false});var geometry=new BufferGeometry();geometry.addAttribute('position',new BufferAttribute(new Float32Array(5*3),3));this.line=new Line(geometry,material);this.add(this.line);this.update();}RectAreaLightHelper.prototype=Object.create(Object3D.prototype);RectAreaLightHelper.prototype.constructor=RectAreaLightHelper;RectAreaLightHelper.prototype.dispose=function(){this.children[0].geometry.dispose();this.children[0].material.dispose();};RectAreaLightHelper.prototype.update=function(){// calculate new dimensions of the helper
var hx=this.light.width*0.5;var hy=this.light.height*0.5;var position=this.line.geometry.attributes.position;var array=position.array;// update vertices
array[0]=hx;array[1]=-hy;array[2]=0;array[3]=hx;array[4]=hy;array[5]=0;array[6]=-hx;array[7]=hy;array[8]=0;array[9]=-hx;array[10]=-hy;array[11]=0;array[12]=hx;array[13]=-hy;array[14]=0;position.needsUpdate=true;if(this.color!==undefined){this.line.material.color.set(this.color);}else{this.line.material.color.copy(this.light.color);}};/**
* @author alteredq / http://alteredqualia.com/
* @author mrdoob / http://mrdoob.com/
* @author Mugen87 / https://github.com/Mugen87
*/function HemisphereLightHelper(light,size,color){Object3D.call(this);this.light=light;this.light.updateMatrixWorld();this.matrix=light.matrixWorld;this.matrixAutoUpdate=false;this.color=color;var geometry=new OctahedronBufferGeometry(size);geometry.rotateY(Math.PI*0.5);this.material=new MeshBasicMaterial({wireframe:true,fog:false});if(this.color===undefined)this.material.vertexColors=VertexColors;var position=geometry.getAttribute('position');var colors=new Float32Array(position.count*3);geometry.addAttribute('color',new BufferAttribute(colors,3));this.add(new Mesh(geometry,this.material));this.update();}HemisphereLightHelper.prototype=Object.create(Object3D.prototype);HemisphereLightHelper.prototype.constructor=HemisphereLightHelper;HemisphereLightHelper.prototype.dispose=function(){this.children[0].geometry.dispose();this.children[0].material.dispose();};HemisphereLightHelper.prototype.update=function(){var vector=new Vector3();var color1=new Color();var color2=new Color();return function update(){var mesh=this.children[0];if(this.color!==undefined){this.material.color.set(this.color);}else{var colors=mesh.geometry.getAttribute('color');color1.copy(this.light.color);color2.copy(this.light.groundColor);for(var i=0,l=colors.count;i<l;i++){var color=i<l/2?color1:color2;colors.setXYZ(i,color.r,color.g,color.b);}colors.needsUpdate=true;}mesh.lookAt(vector.setFromMatrixPosition(this.light.matrixWorld).negate());};}();/**
* @author mrdoob / http://mrdoob.com/
*/function GridHelper(size,divisions,color1,color2){size=size||10;divisions=divisions||10;color1=new Color(color1!==undefined?color1:0x444444);color2=new Color(color2!==undefined?color2:0x888888);var center=divisions/2;var step=size/divisions;var halfSize=size/2;var vertices=[],colors=[];for(var i=0,j=0,k=-halfSize;i<=divisions;i++,k+=step){vertices.push(-halfSize,0,k,halfSize,0,k);vertices.push(k,0,-halfSize,k,0,halfSize);var color=i===center?color1:color2;color.toArray(colors,j);j+=3;color.toArray(colors,j);j+=3;color.toArray(colors,j);j+=3;color.toArray(colors,j);j+=3;}var geometry=new BufferGeometry();geometry.addAttribute('position',new Float32BufferAttribute(vertices,3));geometry.addAttribute('color',new Float32BufferAttribute(colors,3));var material=new LineBasicMaterial({vertexColors:VertexColors});LineSegments.call(this,geometry,material);}GridHelper.prototype=Object.create(LineSegments.prototype);GridHelper.prototype.constructor=GridHelper;/**
* @author mrdoob / http://mrdoob.com/
* @author Mugen87 / http://github.com/Mugen87
* @author Hectate / http://www.github.com/Hectate
*/function PolarGridHelper(radius,radials,circles,divisions,color1,color2){radius=radius||10;radials=radials||16;circles=circles||8;divisions=divisions||64;color1=new Color(color1!==undefined?color1:0x444444);color2=new Color(color2!==undefined?color2:0x888888);var vertices=[];var colors=[];var x,z;var v,i,j,r,color;// create the radials
for(i=0;i<=radials;i++){v=i/radials*(Math.PI*2);x=Math.sin(v)*radius;z=Math.cos(v)*radius;vertices.push(0,0,0);vertices.push(x,0,z);color=i&1?color1:color2;colors.push(color.r,color.g,color.b);colors.push(color.r,color.g,color.b);}// create the circles
for(i=0;i<=circles;i++){color=i&1?color1:color2;r=radius-radius/circles*i;for(j=0;j<divisions;j++){// first vertex
v=j/divisions*(Math.PI*2);x=Math.sin(v)*r;z=Math.cos(v)*r;vertices.push(x,0,z);colors.push(color.r,color.g,color.b);// second vertex
v=(j+1)/divisions*(Math.PI*2);x=Math.sin(v)*r;z=Math.cos(v)*r;vertices.push(x,0,z);colors.push(color.r,color.g,color.b);}}var geometry=new BufferGeometry();geometry.addAttribute('position',new Float32BufferAttribute(vertices,3));geometry.addAttribute('color',new Float32BufferAttribute(colors,3));var material=new LineBasicMaterial({vertexColors:VertexColors});LineSegments.call(this,geometry,material);}PolarGridHelper.prototype=Object.create(LineSegments.prototype);PolarGridHelper.prototype.constructor=PolarGridHelper;/**
* @author mrdoob / http://mrdoob.com/
* @author WestLangley / http://github.com/WestLangley
*/function FaceNormalsHelper(object,size,hex,linewidth){// FaceNormalsHelper only supports THREE.Geometry
this.object=object;this.size=size!==undefined?size:1;var color=hex!==undefined?hex:0xffff00;var width=linewidth!==undefined?linewidth:1;//
var nNormals=0;var objGeometry=this.object.geometry;if(objGeometry&&objGeometry.isGeometry){nNormals=objGeometry.faces.length;}else{console.warn('THREE.FaceNormalsHelper: only THREE.Geometry is supported. Use THREE.VertexNormalsHelper, instead.');}//
var geometry=new BufferGeometry();var positions=new Float32BufferAttribute(nNormals*2*3,3);geometry.addAttribute('position',positions);LineSegments.call(this,geometry,new LineBasicMaterial({color:color,linewidth:width}));//
this.matrixAutoUpdate=false;this.update();}FaceNormalsHelper.prototype=Object.create(LineSegments.prototype);FaceNormalsHelper.prototype.constructor=FaceNormalsHelper;FaceNormalsHelper.prototype.update=function(){var v1=new Vector3();var v2=new Vector3();var normalMatrix=new Matrix3();return function update(){this.object.updateMatrixWorld(true);normalMatrix.getNormalMatrix(this.object.matrixWorld);var matrixWorld=this.object.matrixWorld;var position=this.geometry.attributes.position;//
var objGeometry=this.object.geometry;var vertices=objGeometry.vertices;var faces=objGeometry.faces;var idx=0;for(var i=0,l=faces.length;i<l;i++){var face=faces[i];var normal=face.normal;v1.copy(vertices[face.a]).add(vertices[face.b]).add(vertices[face.c]).divideScalar(3).applyMatrix4(matrixWorld);v2.copy(normal).applyMatrix3(normalMatrix).normalize().multiplyScalar(this.size).add(v1);position.setXYZ(idx,v1.x,v1.y,v1.z);idx=idx+1;position.setXYZ(idx,v2.x,v2.y,v2.z);idx=idx+1;}position.needsUpdate=true;};}();/**
* @author alteredq / http://alteredqualia.com/
* @author mrdoob / http://mrdoob.com/
* @author WestLangley / http://github.com/WestLangley
*/function DirectionalLightHelper(light,size,color){Object3D.call(this);this.light=light;this.light.updateMatrixWorld();this.matrix=light.matrixWorld;this.matrixAutoUpdate=false;this.color=color;if(size===undefined)size=1;var geometry=new BufferGeometry();geometry.addAttribute('position',new Float32BufferAttribute([-size,size,0,size,size,0,size,-size,0,-size,-size,0,-size,size,0],3));var material=new LineBasicMaterial({fog:false});this.lightPlane=new Line(geometry,material);this.add(this.lightPlane);geometry=new BufferGeometry();geometry.addAttribute('position',new Float32BufferAttribute([0,0,0,0,0,1],3));this.targetLine=new Line(geometry,material);this.add(this.targetLine);this.update();}DirectionalLightHelper.prototype=Object.create(Object3D.prototype);DirectionalLightHelper.prototype.constructor=DirectionalLightHelper;DirectionalLightHelper.prototype.dispose=function(){this.lightPlane.geometry.dispose();this.lightPlane.material.dispose();this.targetLine.geometry.dispose();this.targetLine.material.dispose();};DirectionalLightHelper.prototype.update=function(){var v1=new Vector3();var v2=new Vector3();var v3=new Vector3();return function update(){v1.setFromMatrixPosition(this.light.matrixWorld);v2.setFromMatrixPosition(this.light.target.matrixWorld);v3.subVectors(v2,v1);this.lightPlane.lookAt(v3);if(this.color!==undefined){this.lightPlane.material.color.set(this.color);this.targetLine.material.color.set(this.color);}else{this.lightPlane.material.color.copy(this.light.color);this.targetLine.material.color.copy(this.light.color);}this.targetLine.lookAt(v3);this.targetLine.scale.z=v3.length();};}();/**
* @author alteredq / http://alteredqualia.com/
* @author Mugen87 / https://github.com/Mugen87
*
* - shows frustum, line of sight and up of the camera
* - suitable for fast updates
* - based on frustum visualization in lightgl.js shadowmap example
* http://evanw.github.com/lightgl.js/tests/shadowmap.html
*/function CameraHelper(camera){var geometry=new BufferGeometry();var material=new LineBasicMaterial({color:0xffffff,vertexColors:FaceColors});var vertices=[];var colors=[];var pointMap={};// colors
var colorFrustum=new Color(0xffaa00);var colorCone=new Color(0xff0000);var colorUp=new Color(0x00aaff);var colorTarget=new Color(0xffffff);var colorCross=new Color(0x333333);// near
addLine('n1','n2',colorFrustum);addLine('n2','n4',colorFrustum);addLine('n4','n3',colorFrustum);addLine('n3','n1',colorFrustum);// far
addLine('f1','f2',colorFrustum);addLine('f2','f4',colorFrustum);addLine('f4','f3',colorFrustum);addLine('f3','f1',colorFrustum);// sides
addLine('n1','f1',colorFrustum);addLine('n2','f2',colorFrustum);addLine('n3','f3',colorFrustum);addLine('n4','f4',colorFrustum);// cone
addLine('p','n1',colorCone);addLine('p','n2',colorCone);addLine('p','n3',colorCone);addLine('p','n4',colorCone);// up
addLine('u1','u2',colorUp);addLine('u2','u3',colorUp);addLine('u3','u1',colorUp);// target
addLine('c','t',colorTarget);addLine('p','c',colorCross);// cross
addLine('cn1','cn2',colorCross);addLine('cn3','cn4',colorCross);addLine('cf1','cf2',colorCross);addLine('cf3','cf4',colorCross);function addLine(a,b,color){addPoint(a,color);addPoint(b,color);}function addPoint(id,color){vertices.push(0,0,0);colors.push(color.r,color.g,color.b);if(pointMap[id]===undefined){pointMap[id]=[];}pointMap[id].push(vertices.length/3-1);}geometry.addAttribute('position',new Float32BufferAttribute(vertices,3));geometry.addAttribute('color',new Float32BufferAttribute(colors,3));LineSegments.call(this,geometry,material);this.camera=camera;if(this.camera.updateProjectionMatrix)this.camera.updateProjectionMatrix();this.matrix=camera.matrixWorld;this.matrixAutoUpdate=false;this.pointMap=pointMap;this.update();}CameraHelper.prototype=Object.create(LineSegments.prototype);CameraHelper.prototype.constructor=CameraHelper;CameraHelper.prototype.update=function(){var geometry,pointMap;var vector=new Vector3();var camera=new Camera();function setPoint(point,x,y,z){vector.set(x,y,z).unproject(camera);var points=pointMap[point];if(points!==undefined){var position=geometry.getAttribute('position');for(var i=0,l=points.length;i<l;i++){position.setXYZ(points[i],vector.x,vector.y,vector.z);}}}return function update(){geometry=this.geometry;pointMap=this.pointMap;var w=1,h=1;// we need just camera projection matrix
// world matrix must be identity
camera.projectionMatrix.copy(this.camera.projectionMatrix);// center / target
setPoint('c',0,0,-1);setPoint('t',0,0,1);// near
setPoint('n1',-w,-h,-1);setPoint('n2',w,-h,-1);setPoint('n3',-w,h,-1);setPoint('n4',w,h,-1);// far
setPoint('f1',-w,-h,1);setPoint('f2',w,-h,1);setPoint('f3',-w,h,1);setPoint('f4',w,h,1);// up
setPoint('u1',w*0.7,h*1.1,-1);setPoint('u2',-w*0.7,h*1.1,-1);setPoint('u3',0,h*2,-1);// cross
setPoint('cf1',-w,0,1);setPoint('cf2',w,0,1);setPoint('cf3',0,-h,1);setPoint('cf4',0,h,1);setPoint('cn1',-w,0,-1);setPoint('cn2',w,0,-1);setPoint('cn3',0,-h,-1);setPoint('cn4',0,h,-1);geometry.getAttribute('position').needsUpdate=true;};}();/**
* @author mrdoob / http://mrdoob.com/
* @author Mugen87 / http://github.com/Mugen87
*/function BoxHelper(object,color){this.object=object;if(color===undefined)color=0xffff00;var indices=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]);var positions=new Float32Array(8*3);var geometry=new BufferGeometry();geometry.setIndex(new BufferAttribute(indices,1));geometry.addAttribute('position',new BufferAttribute(positions,3));LineSegments.call(this,geometry,new LineBasicMaterial({color:color}));this.matrixAutoUpdate=false;this.update();}BoxHelper.prototype=Object.create(LineSegments.prototype);BoxHelper.prototype.constructor=BoxHelper;BoxHelper.prototype.update=function(){var box=new Box3();return function update(object){if(object!==undefined){console.warn('THREE.BoxHelper: .update() has no longer arguments.');}if(this.object!==undefined){box.setFromObject(this.object);}if(box.isEmpty())return;var min=box.min;var max=box.max;/*
5____4
1/___0/|
| 6__|_7
2/___3/
0: max.x, max.y, max.z
1: min.x, max.y, max.z
2: min.x, min.y, max.z
3: max.x, min.y, max.z
4: max.x, max.y, min.z
5: min.x, max.y, min.z
6: min.x, min.y, min.z
7: max.x, min.y, min.z
*/var position=this.geometry.attributes.position;var array=position.array;array[0]=max.x;array[1]=max.y;array[2]=max.z;array[3]=min.x;array[4]=max.y;array[5]=max.z;array[6]=min.x;array[7]=min.y;array[8]=max.z;array[9]=max.x;array[10]=min.y;array[11]=max.z;array[12]=max.x;array[13]=max.y;array[14]=min.z;array[15]=min.x;array[16]=max.y;array[17]=min.z;array[18]=min.x;array[19]=min.y;array[20]=min.z;array[21]=max.x;array[22]=min.y;array[23]=min.z;position.needsUpdate=true;this.geometry.computeBoundingSphere();};}();BoxHelper.prototype.setFromObject=function(object){this.object=object;this.update();return this;};/**
* @author WestLangley / http://github.com/WestLangley
*/function Box3Helper(box,hex){this.type='Box3Helper';this.box=box;var color=hex!==undefined?hex:0xffff00;var indices=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]);var positions=[1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,-1,-1,1,-1,-1,-1,-1,1,-1,-1];var geometry=new BufferGeometry();geometry.setIndex(new BufferAttribute(indices,1));geometry.addAttribute('position',new Float32BufferAttribute(positions,3));LineSegments.call(this,geometry,new LineBasicMaterial({color:color}));this.geometry.computeBoundingSphere();}Box3Helper.prototype=Object.create(LineSegments.prototype);Box3Helper.prototype.constructor=Box3Helper;Box3Helper.prototype.updateMatrixWorld=function(force){var box=this.box;if(box.isEmpty())return;box.getCenter(this.position);box.getSize(this.scale);this.scale.multiplyScalar(0.5);Object3D.prototype.updateMatrixWorld.call(this,force);};/**
* @author WestLangley / http://github.com/WestLangley
*/function PlaneHelper(plane,size,hex){this.type='PlaneHelper';this.plane=plane;this.size=size===undefined?1:size;var color=hex!==undefined?hex:0xffff00;var positions=[1,-1,1,-1,1,1,-1,-1,1,1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,1,0,0,1,0,0,0];var geometry=new BufferGeometry();geometry.addAttribute('position',new Float32BufferAttribute(positions,3));geometry.computeBoundingSphere();Line.call(this,geometry,new LineBasicMaterial({color:color}));//
var positions2=[1,1,1,-1,1,1,-1,-1,1,1,1,1,-1,-1,1,1,-1,1];var geometry2=new BufferGeometry();geometry2.addAttribute('position',new Float32BufferAttribute(positions2,3));geometry2.computeBoundingSphere();this.add(new Mesh(geometry2,new MeshBasicMaterial({color:color,opacity:0.2,transparent:true,depthWrite:false})));}PlaneHelper.prototype=Object.create(Line.prototype);PlaneHelper.prototype.constructor=PlaneHelper;PlaneHelper.prototype.updateMatrixWorld=function(force){var scale=-this.plane.constant;if(Math.abs(scale)<1e-8)scale=1e-8;// sign does not matter
this.scale.set(0.5*this.size,0.5*this.size,scale);this.lookAt(this.plane.normal);Object3D.prototype.updateMatrixWorld.call(this,force);};/**
* @author WestLangley / http://github.com/WestLangley
* @author zz85 / http://github.com/zz85
* @author bhouston / http://clara.io
*
* Creates an arrow for visualizing directions
*
* Parameters:
* dir - Vector3
* origin - Vector3
* length - Number
* color - color in hex value
* headLength - Number
* headWidth - Number
*/var lineGeometry;var coneGeometry;function ArrowHelper(dir,origin,length,color,headLength,headWidth){// dir is assumed to be normalized
Object3D.call(this);if(color===undefined)color=0xffff00;if(length===undefined)length=1;if(headLength===undefined)headLength=0.2*length;if(headWidth===undefined)headWidth=0.2*headLength;if(lineGeometry===undefined){lineGeometry=new BufferGeometry();lineGeometry.addAttribute('position',new Float32BufferAttribute([0,0,0,0,1,0],3));coneGeometry=new CylinderBufferGeometry(0,0.5,1,5,1);coneGeometry.translate(0,-0.5,0);}this.position.copy(origin);this.line=new Line(lineGeometry,new LineBasicMaterial({color:color}));this.line.matrixAutoUpdate=false;this.add(this.line);this.cone=new Mesh(coneGeometry,new MeshBasicMaterial({color:color}));this.cone.matrixAutoUpdate=false;this.add(this.cone);this.setDirection(dir);this.setLength(length,headLength,headWidth);}ArrowHelper.prototype=Object.create(Object3D.prototype);ArrowHelper.prototype.constructor=ArrowHelper;ArrowHelper.prototype.setDirection=function(){var axis=new Vector3();var radians;return function setDirection(dir){// dir is assumed to be normalized
if(dir.y>0.99999){this.quaternion.set(0,0,0,1);}else if(dir.y<-0.99999){this.quaternion.set(1,0,0,0);}else{axis.set(dir.z,0,-dir.x).normalize();radians=Math.acos(dir.y);this.quaternion.setFromAxisAngle(axis,radians);}};}();ArrowHelper.prototype.setLength=function(length,headLength,headWidth){if(headLength===undefined)headLength=0.2*length;if(headWidth===undefined)headWidth=0.2*headLength;this.line.scale.set(1,Math.max(0,length-headLength),1);this.line.updateMatrix();this.cone.scale.set(headWidth,headLength,headWidth);this.cone.position.y=length;this.cone.updateMatrix();};ArrowHelper.prototype.setColor=function(color){this.line.material.color.copy(color);this.cone.material.color.copy(color);};/**
* @author sroucheray / http://sroucheray.org/
* @author mrdoob / http://mrdoob.com/
*/function AxesHelper(size){size=size||1;var vertices=[0,0,0,size,0,0,0,0,0,0,size,0,0,0,0,0,0,size];var colors=[1,0,0,1,0.6,0,0,1,0,0.6,1,0,0,0,1,0,0.6,1];var geometry=new BufferGeometry();geometry.addAttribute('position',new Float32BufferAttribute(vertices,3));geometry.addAttribute('color',new Float32BufferAttribute(colors,3));var material=new LineBasicMaterial({vertexColors:VertexColors});LineSegments.call(this,geometry,material);}AxesHelper.prototype=Object.create(LineSegments.prototype);AxesHelper.prototype.constructor=AxesHelper;//
Curve.create=function(construct,getPoint){console.log('THREE.Curve.create() has been deprecated');construct.prototype=Object.create(Curve.prototype);construct.prototype.constructor=construct;construct.prototype.getPoint=getPoint;return construct;};//
Object.assign(CurvePath.prototype,{createPointsGeometry:function(divisions){console.warn('THREE.CurvePath: .createPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.');// generate geometry from path points (for Line or Points objects)
var pts=this.getPoints(divisions);return this.createGeometry(pts);},createSpacedPointsGeometry:function(divisions){console.warn('THREE.CurvePath: .createSpacedPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.');// generate geometry from equidistant sampling along the path
var pts=this.getSpacedPoints(divisions);return this.createGeometry(pts);},createGeometry:function(points){console.warn('THREE.CurvePath: .createGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.');var geometry=new Geometry();for(var i=0,l=points.length;i<l;i++){var point=points[i];geometry.vertices.push(new Vector3(point.x,point.y,point.z||0));}return geometry;}});//
Object.assign(Path.prototype,{fromPoints:function(points){console.warn('THREE.Path: .fromPoints() has been renamed to .setFromPoints().');this.setFromPoints(points);}});//
function Spline(points){console.warn('THREE.Spline has been removed. Use THREE.CatmullRomCurve3 instead.');CatmullRomCurve3.call(this,points);this.type='catmullrom';}Spline.prototype=Object.create(CatmullRomCurve3.prototype);Object.assign(Spline.prototype,{initFromArray:function()/* a */{console.error('THREE.Spline: .initFromArray() has been removed.');},getControlPointsArray:function()/* optionalTarget */{console.error('THREE.Spline: .getControlPointsArray() has been removed.');},reparametrizeByArcLength:function()/* samplingCoef */{console.error('THREE.Spline: .reparametrizeByArcLength() has been removed.');}});GridHelper.prototype.setColors=function(){console.error('THREE.GridHelper: setColors() has been deprecated, pass them in the constructor instead.');};SkeletonHelper.prototype.update=function(){console.error('THREE.SkeletonHelper: update() no longer needs to be called.');};//
Object.assign(Loader.prototype,{extractUrlBase:function(url){console.warn('THREE.Loader: .extractUrlBase() has been deprecated. Use THREE.LoaderUtils.extractUrlBase() instead.');return LoaderUtils.extractUrlBase(url);}});//
Object.assign(Box2.prototype,{center:function(optionalTarget){console.warn('THREE.Box2: .center() has been renamed to .getCenter().');return this.getCenter(optionalTarget);},empty:function(){console.warn('THREE.Box2: .empty() has been renamed to .isEmpty().');return this.isEmpty();},isIntersectionBox:function(box){console.warn('THREE.Box2: .isIntersectionBox() has been renamed to .intersectsBox().');return this.intersectsBox(box);},size:function(optionalTarget){console.warn('THREE.Box2: .size() has been renamed to .getSize().');return this.getSize(optionalTarget);}});Object.assign(Box3.prototype,{center:function(optionalTarget){console.warn('THREE.Box3: .center() has been renamed to .getCenter().');return this.getCenter(optionalTarget);},empty:function(){console.warn('THREE.Box3: .empty() has been renamed to .isEmpty().');return this.isEmpty();},isIntersectionBox:function(box){console.warn('THREE.Box3: .isIntersectionBox() has been renamed to .intersectsBox().');return this.intersectsBox(box);},isIntersectionSphere:function(sphere){console.warn('THREE.Box3: .isIntersectionSphere() has been renamed to .intersectsSphere().');return this.intersectsSphere(sphere);},size:function(optionalTarget){console.warn('THREE.Box3: .size() has been renamed to .getSize().');return this.getSize(optionalTarget);}});Line3.prototype.center=function(optionalTarget){console.warn('THREE.Line3: .center() has been renamed to .getCenter().');return this.getCenter(optionalTarget);};Object.assign(_Math,{random16:function(){console.warn('THREE.Math: .random16() has been deprecated. Use Math.random() instead.');return Math.random();},nearestPowerOfTwo:function(value){console.warn('THREE.Math: .nearestPowerOfTwo() has been renamed to .floorPowerOfTwo().');return _Math.floorPowerOfTwo(value);},nextPowerOfTwo:function(value){console.warn('THREE.Math: .nextPowerOfTwo() has been renamed to .ceilPowerOfTwo().');return _Math.ceilPowerOfTwo(value);}});Object.assign(Matrix3.prototype,{flattenToArrayOffset:function(array,offset){console.warn("THREE.Matrix3: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.");return this.toArray(array,offset);},multiplyVector3:function(vector){console.warn('THREE.Matrix3: .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead.');return vector.applyMatrix3(this);},multiplyVector3Array:function()/* a */{console.error('THREE.Matrix3: .multiplyVector3Array() has been removed.');},applyToBuffer:function(buffer/*, offset, length */){console.warn('THREE.Matrix3: .applyToBuffer() has been removed. Use matrix.applyToBufferAttribute( attribute ) instead.');return this.applyToBufferAttribute(buffer);},applyToVector3Array:function()/* array, offset, length */{console.error('THREE.Matrix3: .applyToVector3Array() has been removed.');}});Object.assign(Matrix4.prototype,{extractPosition:function(m){console.warn('THREE.Matrix4: .extractPosition() has been renamed to .copyPosition().');return this.copyPosition(m);},flattenToArrayOffset:function(array,offset){console.warn("THREE.Matrix4: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.");return this.toArray(array,offset);},getPosition:function(){var v1;return function getPosition(){if(v1===undefined)v1=new Vector3();console.warn('THREE.Matrix4: .getPosition() has been removed. Use Vector3.setFromMatrixPosition( matrix ) instead.');return v1.setFromMatrixColumn(this,3);};}(),setRotationFromQuaternion:function(q){console.warn('THREE.Matrix4: .setRotationFromQuaternion() has been renamed to .makeRotationFromQuaternion().');return this.makeRotationFromQuaternion(q);},multiplyToArray:function(){console.warn('THREE.Matrix4: .multiplyToArray() has been removed.');},multiplyVector3:function(vector){console.warn('THREE.Matrix4: .multiplyVector3() has been removed. Use vector.applyMatrix4( matrix ) instead.');return vector.applyMatrix4(this);},multiplyVector4:function(vector){console.warn('THREE.Matrix4: .multiplyVector4() has been removed. Use vector.applyMatrix4( matrix ) instead.');return vector.applyMatrix4(this);},multiplyVector3Array:function()/* a */{console.error('THREE.Matrix4: .multiplyVector3Array() has been removed.');},rotateAxis:function(v){console.warn('THREE.Matrix4: .rotateAxis() has been removed. Use Vector3.transformDirection( matrix ) instead.');v.transformDirection(this);},crossVector:function(vector){console.warn('THREE.Matrix4: .crossVector() has been removed. Use vector.applyMatrix4( matrix ) instead.');return vector.applyMatrix4(this);},translate:function(){console.error('THREE.Matrix4: .translate() has been removed.');},rotateX:function(){console.error('THREE.Matrix4: .rotateX() has been removed.');},rotateY:function(){console.error('THREE.Matrix4: .rotateY() has been removed.');},rotateZ:function(){console.error('THREE.Matrix4: .rotateZ() has been removed.');},rotateByAxis:function(){console.error('THREE.Matrix4: .rotateByAxis() has been removed.');},applyToBuffer:function(buffer/*, offset, length */){console.warn('THREE.Matrix4: .applyToBuffer() has been removed. Use matrix.applyToBufferAttribute( attribute ) instead.');return this.applyToBufferAttribute(buffer);},applyToVector3Array:function()/* array, offset, length */{console.error('THREE.Matrix4: .applyToVector3Array() has been removed.');},makeFrustum:function(left,right,bottom,top,near,far){console.warn('THREE.Matrix4: .makeFrustum() has been removed. Use .makePerspective( left, right, top, bottom, near, far ) instead.');return this.makePerspective(left,right,top,bottom,near,far);}});Plane.prototype.isIntersectionLine=function(line){console.warn('THREE.Plane: .isIntersectionLine() has been renamed to .intersectsLine().');return this.intersectsLine(line);};Quaternion.prototype.multiplyVector3=function(vector){console.warn('THREE.Quaternion: .multiplyVector3() has been removed. Use is now vector.applyQuaternion( quaternion ) instead.');return vector.applyQuaternion(this);};Object.assign(Ray.prototype,{isIntersectionBox:function(box){console.warn('THREE.Ray: .isIntersectionBox() has been renamed to .intersectsBox().');return this.intersectsBox(box);},isIntersectionPlane:function(plane){console.warn('THREE.Ray: .isIntersectionPlane() has been renamed to .intersectsPlane().');return this.intersectsPlane(plane);},isIntersectionSphere:function(sphere){console.warn('THREE.Ray: .isIntersectionSphere() has been renamed to .intersectsSphere().');return this.intersectsSphere(sphere);}});Object.assign(Triangle.prototype,{area:function(){console.warn('THREE.Triangle: .area() has been renamed to .getArea().');return this.getArea();},barycoordFromPoint:function(point,target){console.warn('THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().');return this.getBarycoord(point,target);},midpoint:function(target){console.warn('THREE.Triangle: .midpoint() has been renamed to .getMidpoint().');return this.getMidpoint(target);},normal:function(target){console.warn('THREE.Triangle: .normal() has been renamed to .getNormal().');return this.getNormal(target);},plane:function(target){console.warn('THREE.Triangle: .plane() has been renamed to .getPlane().');return this.getPlane(target);}});Object.assign(Triangle,{barycoordFromPoint:function(point,a,b,c,target){console.warn('THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().');return Triangle.getBarycoord(point,a,b,c,target);},normal:function(a,b,c,target){console.warn('THREE.Triangle: .normal() has been renamed to .getNormal().');return Triangle.getNormal(a,b,c,target);}});Object.assign(Shape.prototype,{extractAllPoints:function(divisions){console.warn('THREE.Shape: .extractAllPoints() has been removed. Use .extractPoints() instead.');return this.extractPoints(divisions);},extrude:function(options){console.warn('THREE.Shape: .extrude() has been removed. Use ExtrudeGeometry() instead.');return new ExtrudeGeometry(this,options);},makeGeometry:function(options){console.warn('THREE.Shape: .makeGeometry() has been removed. Use ShapeGeometry() instead.');return new ShapeGeometry(this,options);}});Object.assign(Vector2.prototype,{fromAttribute:function(attribute,index,offset){console.warn('THREE.Vector2: .fromAttribute() has been renamed to .fromBufferAttribute().');return this.fromBufferAttribute(attribute,index,offset);},distanceToManhattan:function(v){console.warn('THREE.Vector2: .distanceToManhattan() has been renamed to .manhattanDistanceTo().');return this.manhattanDistanceTo(v);},lengthManhattan:function(){console.warn('THREE.Vector2: .lengthManhattan() has been renamed to .manhattanLength().');return this.manhattanLength();}});Object.assign(Vector3.prototype,{setEulerFromRotationMatrix:function(){console.error('THREE.Vector3: .setEulerFromRotationMatrix() has been removed. Use Euler.setFromRotationMatrix() instead.');},setEulerFromQuaternion:function(){console.error('THREE.Vector3: .setEulerFromQuaternion() has been removed. Use Euler.setFromQuaternion() instead.');},getPositionFromMatrix:function(m){console.warn('THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition().');return this.setFromMatrixPosition(m);},getScaleFromMatrix:function(m){console.warn('THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale().');return this.setFromMatrixScale(m);},getColumnFromMatrix:function(index,matrix){console.warn('THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn().');return this.setFromMatrixColumn(matrix,index);},applyProjection:function(m){console.warn('THREE.Vector3: .applyProjection() has been removed. Use .applyMatrix4( m ) instead.');return this.applyMatrix4(m);},fromAttribute:function(attribute,index,offset){console.warn('THREE.Vector3: .fromAttribute() has been renamed to .fromBufferAttribute().');return this.fromBufferAttribute(attribute,index,offset);},distanceToManhattan:function(v){console.warn('THREE.Vector3: .distanceToManhattan() has been renamed to .manhattanDistanceTo().');return this.manhattanDistanceTo(v);},lengthManhattan:function(){console.warn('THREE.Vector3: .lengthManhattan() has been renamed to .manhattanLength().');return this.manhattanLength();}});Object.assign(Vector4.prototype,{fromAttribute:function(attribute,index,offset){console.warn('THREE.Vector4: .fromAttribute() has been renamed to .fromBufferAttribute().');return this.fromBufferAttribute(attribute,index,offset);},lengthManhattan:function(){console.warn('THREE.Vector4: .lengthManhattan() has been renamed to .manhattanLength().');return this.manhattanLength();}});//
Object.assign(Geometry.prototype,{computeTangents:function(){console.error('THREE.Geometry: .computeTangents() has been removed.');},computeLineDistances:function(){console.error('THREE.Geometry: .computeLineDistances() has been removed. Use THREE.Line.computeLineDistances() instead.');}});Object.assign(Object3D.prototype,{getChildByName:function(name){console.warn('THREE.Object3D: .getChildByName() has been renamed to .getObjectByName().');return this.getObjectByName(name);},renderDepth:function(){console.warn('THREE.Object3D: .renderDepth has been removed. Use .renderOrder, instead.');},translate:function(distance,axis){console.warn('THREE.Object3D: .translate() has been removed. Use .translateOnAxis( axis, distance ) instead.');return this.translateOnAxis(axis,distance);},getWorldRotation:function(){console.error('THREE.Object3D: .getWorldRotation() has been removed. Use THREE.Object3D.getWorldQuaternion( target ) instead.');}});Object.defineProperties(Object3D.prototype,{eulerOrder:{get:function(){console.warn('THREE.Object3D: .eulerOrder is now .rotation.order.');return this.rotation.order;},set:function(value){console.warn('THREE.Object3D: .eulerOrder is now .rotation.order.');this.rotation.order=value;}},useQuaternion:{get:function(){console.warn('THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.');},set:function(){console.warn('THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.');}}});Object.defineProperties(LOD.prototype,{objects:{get:function(){console.warn('THREE.LOD: .objects has been renamed to .levels.');return this.levels;}}});Object.defineProperty(Skeleton.prototype,'useVertexTexture',{get:function(){console.warn('THREE.Skeleton: useVertexTexture has been removed.');},set:function(){console.warn('THREE.Skeleton: useVertexTexture has been removed.');}});Object.defineProperty(Curve.prototype,'__arcLengthDivisions',{get:function(){console.warn('THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.');return this.arcLengthDivisions;},set:function(value){console.warn('THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.');this.arcLengthDivisions=value;}});//
PerspectiveCamera.prototype.setLens=function(focalLength,filmGauge){console.warn("THREE.PerspectiveCamera.setLens is deprecated. "+"Use .setFocalLength and .filmGauge for a photographic setup.");if(filmGauge!==undefined)this.filmGauge=filmGauge;this.setFocalLength(focalLength);};//
Object.defineProperties(Light.prototype,{onlyShadow:{set:function(){console.warn('THREE.Light: .onlyShadow has been removed.');}},shadowCameraFov:{set:function(value){console.warn('THREE.Light: .shadowCameraFov is now .shadow.camera.fov.');this.shadow.camera.fov=value;}},shadowCameraLeft:{set:function(value){console.warn('THREE.Light: .shadowCameraLeft is now .shadow.camera.left.');this.shadow.camera.left=value;}},shadowCameraRight:{set:function(value){console.warn('THREE.Light: .shadowCameraRight is now .shadow.camera.right.');this.shadow.camera.right=value;}},shadowCameraTop:{set:function(value){console.warn('THREE.Light: .shadowCameraTop is now .shadow.camera.top.');this.shadow.camera.top=value;}},shadowCameraBottom:{set:function(value){console.warn('THREE.Light: .shadowCameraBottom is now .shadow.camera.bottom.');this.shadow.camera.bottom=value;}},shadowCameraNear:{set:function(value){console.warn('THREE.Light: .shadowCameraNear is now .shadow.camera.near.');this.shadow.camera.near=value;}},shadowCameraFar:{set:function(value){console.warn('THREE.Light: .shadowCameraFar is now .shadow.camera.far.');this.shadow.camera.far=value;}},shadowCameraVisible:{set:function(){console.warn('THREE.Light: .shadowCameraVisible has been removed. Use new THREE.CameraHelper( light.shadow.camera ) instead.');}},shadowBias:{set:function(value){console.warn('THREE.Light: .shadowBias is now .shadow.bias.');this.shadow.bias=value;}},shadowDarkness:{set:function(){console.warn('THREE.Light: .shadowDarkness has been removed.');}},shadowMapWidth:{set:function(value){console.warn('THREE.Light: .shadowMapWidth is now .shadow.mapSize.width.');this.shadow.mapSize.width=value;}},shadowMapHeight:{set:function(value){console.warn('THREE.Light: .shadowMapHeight is now .shadow.mapSize.height.');this.shadow.mapSize.height=value;}}});//
Object.defineProperties(BufferAttribute.prototype,{length:{get:function(){console.warn('THREE.BufferAttribute: .length has been deprecated. Use .count instead.');return this.array.length;}},copyIndicesArray:function()/* indices */{console.error('THREE.BufferAttribute: .copyIndicesArray() has been removed.');}});Object.assign(BufferGeometry.prototype,{addIndex:function(index){console.warn('THREE.BufferGeometry: .addIndex() has been renamed to .setIndex().');this.setIndex(index);},addDrawCall:function(start,count,indexOffset){if(indexOffset!==undefined){console.warn('THREE.BufferGeometry: .addDrawCall() no longer supports indexOffset.');}console.warn('THREE.BufferGeometry: .addDrawCall() is now .addGroup().');this.addGroup(start,count);},clearDrawCalls:function(){console.warn('THREE.BufferGeometry: .clearDrawCalls() is now .clearGroups().');this.clearGroups();},computeTangents:function(){console.warn('THREE.BufferGeometry: .computeTangents() has been removed.');},computeOffsets:function(){console.warn('THREE.BufferGeometry: .computeOffsets() has been removed.');}});Object.defineProperties(BufferGeometry.prototype,{drawcalls:{get:function(){console.error('THREE.BufferGeometry: .drawcalls has been renamed to .groups.');return this.groups;}},offsets:{get:function(){console.warn('THREE.BufferGeometry: .offsets has been renamed to .groups.');return this.groups;}}});//
Object.assign(ExtrudeBufferGeometry.prototype,{getArrays:function(){console.error('THREE.ExtrudeBufferGeometry: .getArrays() has been removed.');},addShapeList:function(){console.error('THREE.ExtrudeBufferGeometry: .addShapeList() has been removed.');},addShape:function(){console.error('THREE.ExtrudeBufferGeometry: .addShape() has been removed.');}});//
Object.defineProperties(Uniform.prototype,{dynamic:{set:function(){console.warn('THREE.Uniform: .dynamic has been removed. Use object.onBeforeRender() instead.');}},onUpdate:{value:function(){console.warn('THREE.Uniform: .onUpdate() has been removed. Use object.onBeforeRender() instead.');return this;}}});//
Object.defineProperties(Material.prototype,{wrapAround:{get:function(){console.warn('THREE.Material: .wrapAround has been removed.');},set:function(){console.warn('THREE.Material: .wrapAround has been removed.');}},wrapRGB:{get:function(){console.warn('THREE.Material: .wrapRGB has been removed.');return new Color();}},shading:{get:function(){console.error('THREE.'+this.type+': .shading has been removed. Use the boolean .flatShading instead.');},set:function(value){console.warn('THREE.'+this.type+': .shading has been removed. Use the boolean .flatShading instead.');this.flatShading=value===FlatShading;}}});Object.defineProperties(MeshPhongMaterial.prototype,{metal:{get:function(){console.warn('THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead.');return false;},set:function(){console.warn('THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead');}}});Object.defineProperties(ShaderMaterial.prototype,{derivatives:{get:function(){console.warn('THREE.ShaderMaterial: .derivatives has been moved to .extensions.derivatives.');return this.extensions.derivatives;},set:function(value){console.warn('THREE. ShaderMaterial: .derivatives has been moved to .extensions.derivatives.');this.extensions.derivatives=value;}}});//
Object.assign(WebGLRenderer.prototype,{getCurrentRenderTarget:function(){console.warn('THREE.WebGLRenderer: .getCurrentRenderTarget() is now .getRenderTarget().');return this.getRenderTarget();},getMaxAnisotropy:function(){console.warn('THREE.WebGLRenderer: .getMaxAnisotropy() is now .capabilities.getMaxAnisotropy().');return this.capabilities.getMaxAnisotropy();},getPrecision:function(){console.warn('THREE.WebGLRenderer: .getPrecision() is now .capabilities.precision.');return this.capabilities.precision;},resetGLState:function(){console.warn('THREE.WebGLRenderer: .resetGLState() is now .state.reset().');return this.state.reset();},supportsFloatTextures:function(){console.warn('THREE.WebGLRenderer: .supportsFloatTextures() is now .extensions.get( \'OES_texture_float\' ).');return this.extensions.get('OES_texture_float');},supportsHalfFloatTextures:function(){console.warn('THREE.WebGLRenderer: .supportsHalfFloatTextures() is now .extensions.get( \'OES_texture_half_float\' ).');return this.extensions.get('OES_texture_half_float');},supportsStandardDerivatives:function(){console.warn('THREE.WebGLRenderer: .supportsStandardDerivatives() is now .extensions.get( \'OES_standard_derivatives\' ).');return this.extensions.get('OES_standard_derivatives');},supportsCompressedTextureS3TC:function(){console.warn('THREE.WebGLRenderer: .supportsCompressedTextureS3TC() is now .extensions.get( \'WEBGL_compressed_texture_s3tc\' ).');return this.extensions.get('WEBGL_compressed_texture_s3tc');},supportsCompressedTexturePVRTC:function(){console.warn('THREE.WebGLRenderer: .supportsCompressedTexturePVRTC() is now .extensions.get( \'WEBGL_compressed_texture_pvrtc\' ).');return this.extensions.get('WEBGL_compressed_texture_pvrtc');},supportsBlendMinMax:function(){console.warn('THREE.WebGLRenderer: .supportsBlendMinMax() is now .extensions.get( \'EXT_blend_minmax\' ).');return this.extensions.get('EXT_blend_minmax');},supportsVertexTextures:function(){console.warn('THREE.WebGLRenderer: .supportsVertexTextures() is now .capabilities.vertexTextures.');return this.capabilities.vertexTextures;},supportsInstancedArrays:function(){console.warn('THREE.WebGLRenderer: .supportsInstancedArrays() is now .extensions.get( \'ANGLE_instanced_arrays\' ).');return this.extensions.get('ANGLE_instanced_arrays');},enableScissorTest:function(boolean){console.warn('THREE.WebGLRenderer: .enableScissorTest() is now .setScissorTest().');this.setScissorTest(boolean);},initMaterial:function(){console.warn('THREE.WebGLRenderer: .initMaterial() has been removed.');},addPrePlugin:function(){console.warn('THREE.WebGLRenderer: .addPrePlugin() has been removed.');},addPostPlugin:function(){console.warn('THREE.WebGLRenderer: .addPostPlugin() has been removed.');},updateShadowMap:function(){console.warn('THREE.WebGLRenderer: .updateShadowMap() has been removed.');},setFaceCulling:function(){console.warn('THREE.WebGLRenderer: .setFaceCulling() has been removed.');}});Object.defineProperties(WebGLRenderer.prototype,{shadowMapEnabled:{get:function(){return this.shadowMap.enabled;},set:function(value){console.warn('THREE.WebGLRenderer: .shadowMapEnabled is now .shadowMap.enabled.');this.shadowMap.enabled=value;}},shadowMapType:{get:function(){return this.shadowMap.type;},set:function(value){console.warn('THREE.WebGLRenderer: .shadowMapType is now .shadowMap.type.');this.shadowMap.type=value;}},shadowMapCullFace:{get:function(){console.warn('THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.');return undefined;},set:function()/* value */{console.warn('THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.');}}});Object.defineProperties(WebGLShadowMap.prototype,{cullFace:{get:function(){console.warn('THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.');return undefined;},set:function()/* cullFace */{console.warn('THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.');}},renderReverseSided:{get:function(){console.warn('THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.');return undefined;},set:function(){console.warn('THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.');}},renderSingleSided:{get:function(){console.warn('THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.');return undefined;},set:function(){console.warn('THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.');}}});//
Object.defineProperties(WebGLRenderTarget.prototype,{wrapS:{get:function(){console.warn('THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.');return this.texture.wrapS;},set:function(value){console.warn('THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.');this.texture.wrapS=value;}},wrapT:{get:function(){console.warn('THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.');return this.texture.wrapT;},set:function(value){console.warn('THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.');this.texture.wrapT=value;}},magFilter:{get:function(){console.warn('THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.');return this.texture.magFilter;},set:function(value){console.warn('THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.');this.texture.magFilter=value;}},minFilter:{get:function(){console.warn('THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.');return this.texture.minFilter;},set:function(value){console.warn('THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.');this.texture.minFilter=value;}},anisotropy:{get:function(){console.warn('THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.');return this.texture.anisotropy;},set:function(value){console.warn('THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.');this.texture.anisotropy=value;}},offset:{get:function(){console.warn('THREE.WebGLRenderTarget: .offset is now .texture.offset.');return this.texture.offset;},set:function(value){console.warn('THREE.WebGLRenderTarget: .offset is now .texture.offset.');this.texture.offset=value;}},repeat:{get:function(){console.warn('THREE.WebGLRenderTarget: .repeat is now .texture.repeat.');return this.texture.repeat;},set:function(value){console.warn('THREE.WebGLRenderTarget: .repeat is now .texture.repeat.');this.texture.repeat=value;}},format:{get:function(){console.warn('THREE.WebGLRenderTarget: .format is now .texture.format.');return this.texture.format;},set:function(value){console.warn('THREE.WebGLRenderTarget: .format is now .texture.format.');this.texture.format=value;}},type:{get:function(){console.warn('THREE.WebGLRenderTarget: .type is now .texture.type.');return this.texture.type;},set:function(value){console.warn('THREE.WebGLRenderTarget: .type is now .texture.type.');this.texture.type=value;}},generateMipmaps:{get:function(){console.warn('THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.');return this.texture.generateMipmaps;},set:function(value){console.warn('THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.');this.texture.generateMipmaps=value;}}});//
Object.defineProperties(WebVRManager.prototype,{standing:{set:function()/* value */{console.warn('THREE.WebVRManager: .standing has been removed.');}}});//
Audio.prototype.load=function(file){console.warn('THREE.Audio: .load has been deprecated. Use THREE.AudioLoader instead.');var scope=this;var audioLoader=new AudioLoader();audioLoader.load(file,function(buffer){scope.setBuffer(buffer);});return this;};AudioAnalyser.prototype.getData=function(){console.warn('THREE.AudioAnalyser: .getData() is now .getFrequencyData().');return this.getFrequencyData();};//
CubeCamera.prototype.updateCubeMap=function(renderer,scene){console.warn('THREE.CubeCamera: .updateCubeMap() is now .update().');return this.update(renderer,scene);};var minivents_commonjs=function Events(target){var events={},empty=[];target=target||this;/**
* On: listen to events
*/target.on=function(type,func,ctx){(events[type]=events[type]||[]).push([func,ctx]);return target;};/**
* Off: stop listening to event / specific callback
*/target.off=function(type,func){type||(events={});var list=events[type]||empty,i=list.length=func?list.length:0;while(i--)func==list[i][0]&&list.splice(i,1);return target;};/**
* Emit: send event, callbacks will be triggered
*/target.emit=function(type){var e=events[type]||empty,list=e.length>0?e.slice(0,e.length):e,i=0,j;while(j=list[i++])j[0].apply(j[1],empty.slice.call(arguments,1));return target;};};// 19.1.2.2 / 15.2.3.5 Object.create(O [, Properties])
_export(_export.S,'Object',{create:_objectCreate});var $Object$2=_core.Object;var create=function create(P,D){return $Object$2.create(P,D);};var create$1=create;var _validateCollection=function(it,TYPE){if(!_isObject(it)||it._t!==TYPE)throw TypeError('Incompatible receiver, '+TYPE+' required!');return it;};var dP$2=_objectDp.f;var fastKey=_meta.fastKey;var SIZE=_descriptors?'_s':'size';var getEntry=function(that,key){// fast case
var index=fastKey(key);var entry;if(index!=='F')return that._i[index];// frozen object case
for(entry=that._f;entry;entry=entry.n){if(entry.k==key)return entry;}};var _collectionStrong={getConstructor:function(wrapper,NAME,IS_MAP,ADDER){var C=wrapper(function(that,iterable){_anInstance(that,C,NAME,'_i');that._t=NAME;// collection type
that._i=_objectCreate(null);// index
that._f=undefined;// first entry
that._l=undefined;// last entry
that[SIZE]=0;// size
if(iterable!=undefined)_forOf(iterable,IS_MAP,that[ADDER],that);});_redefineAll(C.prototype,{// 23.1.3.1 Map.prototype.clear()
// 23.2.3.2 Set.prototype.clear()
clear:function clear(){for(var that=_validateCollection(this,NAME),data=that._i,entry=that._f;entry;entry=entry.n){entry.r=true;if(entry.p)entry.p=entry.p.n=undefined;delete data[entry.i];}that._f=that._l=undefined;that[SIZE]=0;},// 23.1.3.3 Map.prototype.delete(key)
// 23.2.3.4 Set.prototype.delete(value)
'delete':function(key){var that=_validateCollection(this,NAME);var entry=getEntry(that,key);if(entry){var next=entry.n;var prev=entry.p;delete that._i[entry.i];entry.r=true;if(prev)prev.n=next;if(next)next.p=prev;if(that._f==entry)that._f=next;if(that._l==entry)that._l=prev;that[SIZE]--;}return !!entry;},// 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)
// 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)
forEach:function forEach(callbackfn/* , that = undefined */){_validateCollection(this,NAME);var f=_ctx(callbackfn,arguments.length>1?arguments[1]:undefined,3);var entry;while(entry=entry?entry.n:this._f){f(entry.v,entry.k,this);// revert to the last existing entry
while(entry&&entry.r)entry=entry.p;}},// 23.1.3.7 Map.prototype.has(key)
// 23.2.3.7 Set.prototype.has(value)
has:function has(key){return !!getEntry(_validateCollection(this,NAME),key);}});if(_descriptors)dP$2(C.prototype,'size',{get:function(){return _validateCollection(this,NAME)[SIZE];}});return C;},def:function(that,key,value){var entry=getEntry(that,key);var prev,index;// change existing entry
if(entry){entry.v=value;// create new entry
}else{that._l=entry={i:index=fastKey(key,true),// <- index
k:key,// <- key
v:value,// <- value
p:prev=that._l,// <- previous entry
n:undefined,// <- next entry
r:false// <- removed
};if(!that._f)that._f=entry;if(prev)prev.n=entry;that[SIZE]++;// add to index
if(index!=='F')that._i[index]=entry;}return that;},getEntry:getEntry,setStrong:function(C,NAME,IS_MAP){// add .keys, .values, .entries, [@@iterator]
// 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11
_iterDefine(C,NAME,function(iterated,kind){this._t=_validateCollection(iterated,NAME);// target
this._k=kind;// kind
this._l=undefined;// previous
},function(){var that=this;var kind=that._k;var entry=that._l;// revert to the last existing entry
while(entry&&entry.r)entry=entry.p;// get next entry
if(!that._t||!(that._l=entry=entry?entry.n:that._t._f)){// or finish the iteration
that._t=undefined;return _iterStep(1);}// return step by kind
if(kind=='keys')return _iterStep(0,entry.k);if(kind=='values')return _iterStep(0,entry.v);return _iterStep(0,[entry.k,entry.v]);},IS_MAP?'entries':'values',!IS_MAP,true);// add [@@species], 23.1.2.2, 23.2.2.2
_setSpecies(NAME);}};var SPECIES$2=_wks('species');var _arraySpeciesConstructor=function(original){var C;if(_isArray(original)){C=original.constructor;// cross-realm fallback
if(typeof C=='function'&&(C===Array||_isArray(C.prototype)))C=undefined;if(_isObject(C)){C=C[SPECIES$2];if(C===null)C=undefined;}}return C===undefined?Array:C;};// 9.4.2.3 ArraySpeciesCreate(originalArray, length)
var _arraySpeciesCreate=function(original,length){return new(_arraySpeciesConstructor(original))(length);};// 0 -> Array#forEach
// 1 -> Array#map
// 2 -> Array#filter
// 3 -> Array#some
// 4 -> Array#every
// 5 -> Array#find
// 6 -> Array#findIndex
var _arrayMethods=function(TYPE,$create){var IS_MAP=TYPE==1;var IS_FILTER=TYPE==2;var IS_SOME=TYPE==3;var IS_EVERY=TYPE==4;var IS_FIND_INDEX=TYPE==6;var NO_HOLES=TYPE==5||IS_FIND_INDEX;var create=$create||_arraySpeciesCreate;return function($this,callbackfn,that){var O=_toObject($this);var self=_iobject(O);var f=_ctx(callbackfn,that,3);var length=_toLength(self.length);var index=0;var result=IS_MAP?create($this,length):IS_FILTER?create($this,0):undefined;var val,res;for(;length>index;index++)if(NO_HOLES||index in self){val=self[index];res=f(val,index,O);if(TYPE){if(IS_MAP)result[index]=res;// map
else if(res)switch(TYPE){case 3:return true;// some
case 5:return val;// find
case 6:return index;// findIndex
case 2:result.push(val);// filter
}else if(IS_EVERY)return false;// every
}}return IS_FIND_INDEX?-1:IS_SOME||IS_EVERY?IS_EVERY:result;};};var dP$3=_objectDp.f;var each=_arrayMethods(0);var _collection=function(NAME,wrapper,methods,common,IS_MAP,IS_WEAK){var Base=_global[NAME];var C=Base;var ADDER=IS_MAP?'set':'add';var proto=C&&C.prototype;var O={};if(!_descriptors||typeof C!='function'||!(IS_WEAK||proto.forEach&&!_fails(function(){new C().entries().next();}))){// create collection constructor
C=common.getConstructor(wrapper,NAME,IS_MAP,ADDER);_redefineAll(C.prototype,methods);_meta.NEED=true;}else{C=wrapper(function(target,iterable){_anInstance(target,C,NAME,'_c');target._c=new Base();if(iterable!=undefined)_forOf(iterable,IS_MAP,target[ADDER],target);});each('add,clear,delete,forEach,get,has,set,keys,values,entries,toJSON'.split(','),function(KEY){var IS_ADDER=KEY=='add'||KEY=='set';if(KEY in proto&&!(IS_WEAK&&KEY=='clear'))_hide(C.prototype,KEY,function(a,b){_anInstance(this,C,KEY);if(!IS_ADDER&&IS_WEAK&&!_isObject(a))return KEY=='get'?undefined:false;var result=this._c[KEY](a===0?0:a,b);return IS_ADDER?this:result;});});IS_WEAK||dP$3(C.prototype,'size',{get:function(){return this._c.size;}});}_setToStringTag(C,NAME);O[NAME]=C;_export(_export.G+_export.W+_export.F,O);if(!IS_WEAK)common.setStrong(C,NAME,IS_MAP);return C;};var MAP='Map';// 23.1 Map Objects
var es6_map=_collection(MAP,function(get){return function Map(){return get(this,arguments.length>0?arguments[0]:undefined);};},{// 23.1.3.6 Map.prototype.get(key)
get:function get(key){var entry=_collectionStrong.getEntry(_validateCollection(this,MAP),key);return entry&&entry.v;},// 23.1.3.9 Map.prototype.set(key, value)
set:function set(key,value){return _collectionStrong.def(_validateCollection(this,MAP),key===0?0:key,value);}},_collectionStrong,true);var _arrayFromIterable=function(iter,ITERATOR){var result=[];_forOf(iter,false,result.push,result,ITERATOR);return result;};// https://github.com/DavidBruant/Map-Set.prototype.toJSON
var _collectionToJson=function(NAME){return function toJSON(){if(_classof(this)!=NAME)throw TypeError(NAME+"#toJSON isn't generic");return _arrayFromIterable(this);};};// https://github.com/DavidBruant/Map-Set.prototype.toJSON
_export(_export.P+_export.R,'Map',{toJSON:_collectionToJson('Map')});// https://tc39.github.io/proposal-setmap-offrom/
var _setCollectionOf=function(COLLECTION){_export(_export.S,COLLECTION,{of:function of(){var length=arguments.length;var A=new Array(length);while(length--)A[length]=arguments[length];return new this(A);}});};// https://tc39.github.io/proposal-setmap-offrom/#sec-map.of
_setCollectionOf('Map');// https://tc39.github.io/proposal-setmap-offrom/
var _setCollectionFrom=function(COLLECTION){_export(_export.S,COLLECTION,{from:function from(source/* , mapFn, thisArg */){var mapFn=arguments[1];var mapping,A,n,cb;_aFunction(this);mapping=mapFn!==undefined;if(mapping)_aFunction(mapFn);if(source==undefined)return new this();A=[];if(mapping){n=0;cb=_ctx(mapFn,arguments[2],2);_forOf(source,false,function(nextItem){A.push(cb(nextItem,n++));});}else{_forOf(source,false,A.push,A);}return new this(A);}});};// https://tc39.github.io/proposal-setmap-offrom/#sec-map.from
_setCollectionFrom('Map');var map=_core.Map;var map$1=map;var arraySlice=[].slice;var factories={};var construct=function(F,len,args){if(!(len in factories)){for(var n=[],i=0;i<len;i++)n[i]='a['+i+']';// eslint-disable-next-line no-new-func
factories[len]=Function('F,a','return new F('+n.join(',')+')');}return factories[len](F,args);};var _bind=Function.bind||function bind(that/* , ...args */){var fn=_aFunction(this);var partArgs=arraySlice.call(arguments,1);var bound=function()/* args... */{var args=partArgs.concat(arraySlice.call(arguments));return this instanceof bound?construct(fn,args.length,args):_invoke(fn,args,that);};if(_isObject(fn.prototype))bound.prototype=fn.prototype;return bound;};// 26.1.2 Reflect.construct(target, argumentsList [, newTarget])
var rConstruct=(_global.Reflect||{}).construct;// MS Edge supports only 2 arguments and argumentsList argument is optional
// FF Nightly sets third argument as `new.target`, but does not create `this` from it
var NEW_TARGET_BUG=_fails(function(){function F(){/* empty */}return !(rConstruct(function(){/* empty */},[],F)instanceof F);});var ARGS_BUG=!_fails(function(){rConstruct(function(){/* empty */});});_export(_export.S+_export.F*(NEW_TARGET_BUG||ARGS_BUG),'Reflect',{construct:function construct(Target,args/* , newTarget */){_aFunction(Target);_anObject(args);var newTarget=arguments.length<3?Target:_aFunction(arguments[2]);if(ARGS_BUG&&!NEW_TARGET_BUG)return rConstruct(Target,args,newTarget);if(Target==newTarget){// w/o altered newTarget, optimization for 0-4 arguments
switch(args.length){case 0:return new Target();case 1:return new Target(args[0]);case 2:return new Target(args[0],args[1]);case 3:return new Target(args[0],args[1],args[2]);case 4:return new Target(args[0],args[1],args[2],args[3]);}// w/o altered newTarget, lot of arguments case
var $args=[null];$args.push.apply($args,args);return new(_bind.apply(Target,$args))();}// with altered newTarget, not support built-in constructors
var proto=newTarget.prototype;var instance=_objectCreate(_isObject(proto)?proto:Object.prototype);var result=Function.apply.call(Target,instance,args);return _isObject(result)?result:instance;}});var construct$1=_core.Reflect.construct;var construct$2=construct$1;var construct$3=createCommonjsModule(function(module){function _construct$$1(Parent,args,Class){if(typeof Reflect!=="undefined"&&construct$2){module.exports=_construct$$1=construct$2;}else{module.exports=_construct$$1=function _construct$$1(Parent,args,Class){var a=[null];a.push.apply(a,args);var Constructor=Parent.bind.apply(Parent,a);var instance=new Constructor();if(Class)setPrototypeOf$2(instance,Class.prototype);return instance;};}return _construct$$1.apply(null,arguments);}module.exports=_construct$$1;});var wrapNativeSuper=createCommonjsModule(function(module){function _wrapNativeSuper$$1(Class){var _cache=typeof map$1==="function"?new map$1():undefined;module.exports=_wrapNativeSuper$$1=function _wrapNativeSuper$$1(Class){if(typeof Class!=="function"){throw new TypeError("Super expression must either be null or a function");}if(typeof _cache!=="undefined"){if(_cache.has(Class))return _cache.get(Class);_cache.set(Class,Wrapper);}function Wrapper(){}Wrapper.prototype=create$1(Class.prototype,{constructor:{value:Wrapper,enumerable:false,writable:true,configurable:true}});return setPrototypeOf$2(Wrapper,setPrototypeOf$2(function Super(){return construct$3(Class,arguments,getPrototypeOf$2(this).constructor);},Class));};return _wrapNativeSuper$$1(Class);}module.exports=_wrapNativeSuper$$1;});var CompositionError$1=/*#__PURE__*/function(_Error){function CompositionError(classInstance,message,component){var _this;classCallCheck(this,CompositionError);_this=possibleConstructorReturn(this,getPrototypeOf$2(CompositionError).call(this,"@".concat(classInstance,": ").concat(message)));var stackArray=_this.stack.split('\n');stackArray.splice(1,2);_this.stack=stackArray.join('\n');if(console)console.error('Component:',component);_this.name='CompositionError';return _this;}inherits(CompositionError,_Error);return CompositionError;}(wrapNativeSuper(Error));var DependencyError=/*#__PURE__*/function(_Error2){function DependencyError(classInstance,message,activeModule){var _this2;var dependencyModule=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;classCallCheck(this,DependencyError);_this2=possibleConstructorReturn(this,getPrototypeOf$2(DependencyError).call(this,"@".concat(classInstance,": ").concat(message)));var stackArray=_this2.stack.split('\n');stackArray.splice(1,2);_this2.stack=stackArray.join('\n');if(console)console.error('Active module:',activeModule);if(console&&dependencyModule)console.error('Dependency published by module:',dependencyModule);_this2.name='DependencyError';return _this2;}inherits(DependencyError,_Error2);return DependencyError;}(wrapNativeSuper(Error));var ManagerError=/*#__PURE__*/function(_Error3){function ManagerError(classInstance,message,component){var _this3;var activeModule=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;classCallCheck(this,ManagerError);_this3=possibleConstructorReturn(this,getPrototypeOf$2(ManagerError).call(this,"@".concat(classInstance,": ").concat(message)));var stackArray=_this3.stack.split('\n');stackArray.splice(1,2);_this3.stack=stackArray.join('\n');if(console)console.error('Component:',component);if(console&&activeModule)console.error('Active module:',activeModule);_this3.name='ManagerError';return _this3;}inherits(ManagerError,_Error3);return ManagerError;}(wrapNativeSuper(Error));var warnDeps=function warnDeps(){throw new Error('WhitestormJS Framework requ ires Three.js r92. https://threejs.org/');};try{}catch(err){warnDeps();}/**
* @class ModuleSystem
* @category core
* @description Provides API for classes that will use Modules.<br/>
* This class includes basic event system with those supported methods:
* <pre>.on()</pre><pre>.off()</pre><pre>.emit()</pre>
* @extends Events
* @memberof module:core
*/var ModuleSystem=/*#__PURE__*/function(_Events){function ModuleSystem(){classCallCheck(this,ModuleSystem);return possibleConstructorReturn(this,getPrototypeOf$2(ModuleSystem).apply(this,arguments));}createClass(ModuleSystem,[{key:"integrateModules",// INTEGRATING
/**
* @method integrateModules
* @instance
* @description This method applies all modules from .modules collection.
* @param {Object} [source] If source (should be a component) is provided, will replace .modules with source's one before executing modules.
* @memberof module:core.ModuleSystem
*/value:function integrateModules(source){if(!this.modules&&!source)return;if(source&&source.modules)this.modules=source.modules.slice(0);if(this.modules){for(var i=0,max=this.modules.length;i<max;i++){this.applyModule(this.modules[i],false);}}if(source)this.applyBridge({onCopy:source});}// APPLYING MODULE (...and a "bridge" for module)
/**
* @method applyBridge
* @instance
* @description Makes component-specific API to work with modules.
* @param {Object} bridgeMap
* @return {Object} Returns object with modified values.
* @memberof module:core.ModuleSystem
*/},{key:"applyBridge",value:function applyBridge(){var bridgeMap=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var modules=this.modules;if(!modules)return bridgeMap;for(var i=0,max=modules.length;i<max;i++){for(var key in bridgeMap){if(bridgeMap[key]){var module=modules[i];if(module&&module.bridge&&module.bridge[key])bridgeMap[key]=module.bridge[key].apply(this,[bridgeMap[key],module]);}}}return bridgeMap;}/**
* @method applyCommand
* @instance
* @description .applyCommand runs a method called `name` on all modules.
* @param {String} name the method name.
* @param {Function} [cb=(func, moduleScope) => func.apply(this, [moduleScope])] How the function is wrapped/
* @memberof module:core.ModuleSystem
*/},{key:"applyCommand",value:function applyCommand(name){var _this=this;var cb=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(func,moduleScope){return func.apply(_this,[moduleScope]);};var modules=this.modules;if(!modules)return;for(var i=0,max=modules.length;i<max;i++){var module=modules[i];if(name in module)cb(module[name],module);}}/**
* @method applyModule
* @instance
* @description .applyModule is also used in .integrateModules() function.
* It does exactly what its name says (applies module to component or app).
* @param {Object} module the module to apply
* @param {Boolean} [push=true]
* @return {Object} Returns module that was applied.
* @throws {ManagerError}
* @memberof module:core.ModuleSystem
*/},{key:"applyModule",value:function applyModule(module){var push=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;if(!module)return;if(push&&this.modules)this.modules.push(module);else if(push)this.modules=[module];if(this.manager)this.manager.active(module);if(module.manager&&this.manager)module.manager(this.manager);else if(module.manager){throw new ManagerError('Component',"Module requires ModuleManager that is turned off for this component",this,module);}if(module.integrate)module.integrate.bind(this)(module);return module;}/**
* @method disposeModules
* @instance
* @description Disposes of all modules
* @memberof module:core.ModuleSystem
*/},{key:"disposeModules",value:function disposeModules(){while(this.modules.length){this.disposeModule(this.modules[0]);}}/**
* @method disposeModule
* @instance
* @description Disposes of the given module
* @param {Object} module the module to dispose
* @return {Module} Returns module that was removed.
* @memberof module:core.ModuleSystem
*/},{key:"disposeModule",value:function disposeModule(module){if(!module)return;this.modules.splice(this.modules.indexOf(module),1);if(module.dispose)module.dispose.bind(this)(module);return module;}// PIPED METHOD
/**
* @method module
* @instance
* @description piped version of .applyModule().
* @param {Object} module the module to apply
* @return {this} returns this - app/component
* @throws {ManagerError}
* @memberof module:core.ModuleSystem
* @example <caption>Piped modules</caption>
* component
* .module(new Module1())
* .module(new Module2())
* .module(new Module3())
*/},{key:"module",value:function module(_module){this.applyModule(_module);return this;}}]);inherits(ModuleSystem,_Events);return ModuleSystem;}(minivents_commonjs);function _arrayWithHoles$1(arr){if(Array.isArray(arr))return arr;}var arrayWithHoles=_arrayWithHoles$1;var core_getIterator=_core.getIterator=function(it){var iterFn=core_getIteratorMethod(it);if(typeof iterFn!='function')throw TypeError(it+' is not iterable!');return _anObject(iterFn.call(it));};var getIterator=core_getIterator;var getIterator$1=getIterator;function _iterableToArrayLimit$1(arr,i){var _arr=[];var _n=true;var _d=false;var _e=undefined;try{for(var _i=getIterator$1(arr),_s;!(_n=(_s=_i.next()).done);_n=true){_arr.push(_s.value);if(i&&_arr.length===i)break;}}catch(err){_d=true;_e=err;}finally{try{if(!_n&&_i["return"]!=null)_i["return"]();}finally{if(_d)throw _e;}}return _arr;}var iterableToArrayLimit=_iterableToArrayLimit$1;function _nonIterableRest$1(){throw new TypeError("Invalid attempt to destructure non-iterable instance");}var nonIterableRest=_nonIterableRest$1;function _slicedToArray$1(arr,i){return arrayWithHoles(arr)||iterableToArrayLimit(arr,i)||nonIterableRest();}var slicedToArray=_slicedToArray$1;function symbolObservablePonyfill(root){var result;var Symbol=root.Symbol;if(typeof Symbol==='function'){if(Symbol.observable){result=Symbol.observable;}else{result=Symbol('observable');Symbol.observable=result;}}else{result='@@observable';}return result;}/* global window */var root;if(typeof self!=='undefined'){root=self;}else if(typeof window!=='undefined'){root=window;}else if(typeof global!=='undefined'){root=global;}else if(typeof module!=='undefined'){root=module;}else{root=Function('return this')();}var result=symbolObservablePonyfill(root);/**
* These are private action types reserved by Redux.
* For any unknown actions, you must return the current state.
* If the current state is undefined, you must return the initial state.
* Do not reference these action types directly in your code.
*/var ActionTypes={INIT:'@@redux/INIT'+Math.random().toString(36).substring(7).split('').join('.'),REPLACE:'@@redux/REPLACE'+Math.random().toString(36).substring(7).split('').join('.')};var _typeof$1=typeof Symbol==="function"&&typeof Symbol.iterator==="symbol"?function(obj){return typeof obj;}:function(obj){return obj&&typeof Symbol==="function"&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj;};/**
* @param {any} obj The object to inspect.
* @returns {boolean} True if the argument appears to be a plain object.
*/function isPlainObject(obj){if((typeof obj==='undefined'?'undefined':_typeof$1(obj))!=='object'||obj===null)return false;var proto=obj;while(Object.getPrototypeOf(proto)!==null){proto=Object.getPrototypeOf(proto);}return Object.getPrototypeOf(obj)===proto;}/**
* Creates a Redux store that holds the state tree.
* The only way to change the data in the store is to call `dispatch()` on it.
*
* There should only be a single store in your app. To specify how different
* parts of the state tree respond to actions, you may combine several reducers
* into a single reducer function by using `combineReducers`.
*
* @param {Function} reducer A function that returns the next state tree, given
* the current state tree and the action to handle.
*
* @param {any} [preloadedState] The initial state. You may optionally specify it
* to hydrate the state from the server in universal apps, or to restore a
* previously serialized user session.
* If you use `combineReducers` to produce the root reducer function, this must be
* an object with the same shape as `combineReducers` keys.
*
* @param {Function} [enhancer] The store enhancer. You may optionally specify it
* to enhance the store with third-party capabilities such as middleware,
* time travel, persistence, etc. The only store enhancer that ships with Redux
* is `applyMiddleware()`.
*
* @returns {Store} A Redux store that lets you read the state, dispatch actions
* and subscribe to changes.
*/function createStore(reducer,preloadedState,enhancer){var _ref2;if(typeof preloadedState==='function'&&typeof enhancer==='undefined'){enhancer=preloadedState;preloadedState=undefined;}if(typeof enhancer!=='undefined'){if(typeof enhancer!=='function'){throw new Error('Expected the enhancer to be a function.');}return enhancer(createStore)(reducer,preloadedState);}if(typeof reducer!=='function'){throw new Error('Expected the reducer to be a function.');}var currentReducer=reducer;var currentState=preloadedState;var currentListeners=[];var nextListeners=currentListeners;var isDispatching=false;function ensureCanMutateNextListeners(){if(nextListeners===currentListeners){nextListeners=currentListeners.slice();}}/**
* Reads the state tree managed by the store.
*
* @returns {any} The current state tree of your application.
*/function getState(){if(isDispatching){throw new Error('You may not call store.getState() while the reducer is executing. '+'The reducer has already received the state as an argument. '+'Pass it down from the top reducer instead of reading it from the store.');}return currentState;}/**
* Adds a change listener. It will be called any time an action is dispatched,
* and some part of the state tree may potentially have changed. You may then
* call `getState()` to read the current state tree inside the callback.
*
* You may call `dispatch()` from a change listener, with the following
* caveats:
*
* 1. The subscriptions are snapshotted just before every `dispatch()` call.
* If you subscribe or unsubscribe while the listeners are being invoked, this
* will not have any effect on the `dispatch()` that is currently in progress.
* However, the next `dispatch()` call, whether nested or not, will use a more
* recent snapshot of the subscription list.
*
* 2. The listener should not expect to see all state changes, as the state
* might have been updated multiple times during a nested `dispatch()` before
* the listener is called. It is, however, guaranteed that all subscribers
* registered before the `dispatch()` started will be called with the latest
* state by the time it exits.
*
* @param {Function} listener A callback to be invoked on every dispatch.
* @returns {Function} A function to remove this change listener.
*/function subscribe(listener){if(typeof listener!=='function'){throw new Error('Expected the listener to be a function.');}if(isDispatching){throw new Error('You may not call store.subscribe() while the reducer is executing. '+'If you would like to be notified after the store has been updated, subscribe from a '+'component and invoke store.getState() in the callback to access the latest state. '+'See https://redux.js.org/api-reference/store#subscribe(listener) for more details.');}var isSubscribed=true;ensureCanMutateNextListeners();nextListeners.push(listener);return function unsubscribe(){if(!isSubscribed){return;}if(isDispatching){throw new Error('You may not unsubscribe from a store listener while the reducer is executing. '+'See https://redux.js.org/api-reference/store#subscribe(listener) for more details.');}isSubscribed=false;ensureCanMutateNextListeners();var index=nextListeners.indexOf(listener);nextListeners.splice(index,1);};}/**
* Dispatches an action. It is the only way to trigger a state change.
*
* The `reducer` function, used to create the store, will be called with the
* current state tree and the given `action`. Its return value will
* be considered the **next** state of the tree, and the change listeners
* will be notified.
*
* The base implementation only supports plain object actions. If you want to
* dispatch a Promise, an Observable, a thunk, or something else, you need to
* wrap your store creating function into the corresponding middleware. For
* example, see the documentation for the `redux-thunk` package. Even the
* middleware will eventually dispatch plain object actions using this method.
*
* @param {Object} action A plain object representing “what changed”. It is
* a good idea to keep actions serializable so you can record and replay user
* sessions, or use the time travelling `redux-devtools`. An action must have
* a `type` property which may not be `undefined`. It is a good idea to use
* string constants for action types.
*
* @returns {Object} For convenience, the same action object you dispatched.
*
* Note that, if you use a custom middleware, it may wrap `dispatch()` to
* return something else (for example, a Promise you can await).
*/function dispatch(action){if(!isPlainObject(action)){throw new Error('Actions must be plain objects. '+'Use custom middleware for async actions.');}if(typeof action.type==='undefined'){throw new Error('Actions may not have an undefined "type" property. '+'Have you misspelled a constant?');}if(isDispatching){throw new Error('Reducers may not dispatch actions.');}try{isDispatching=true;currentState=currentReducer(currentState,action);}finally{isDispatching=false;}var listeners=currentListeners=nextListeners;for(var i=0;i<listeners.length;i++){var listener=listeners[i];listener();}return action;}/**
* Replaces the reducer currently used by the store to calculate the state.
*
* You might need this if your app implements code splitting and you want to
* load some of the reducers dynamically. You might also need this if you
* implement a hot reloading mechanism for Redux.
*
* @param {Function} nextReducer The reducer for the store to use instead.
* @returns {void}
*/function replaceReducer(nextReducer){if(typeof nextReducer!=='function'){throw new Error('Expected the nextReducer to be a function.');}currentReducer=nextReducer;dispatch({type:ActionTypes.REPLACE});}/**
* Interoperability point for observable/reactive libraries.
* @returns {observable} A minimal observable of state changes.
* For more information, see the observable proposal:
* https://github.com/tc39/proposal-observable
*/function observable(){var _ref;var outerSubscribe=subscribe;return _ref={/**
* The minimal observable subscription method.
* @param {Object} observer Any object that can be used as an observer.
* The observer object should have a `next` method.
* @returns {subscription} An object with an `unsubscribe` method that can
* be used to unsubscribe the observable from the store, and prevent further
* emission of values from the observable.
*/subscribe:function subscribe(observer){if((typeof observer==='undefined'?'undefined':_typeof$1(observer))!=='object'||observer===null){throw new TypeError('Expected the observer to be an object.');}function observeState(){if(observer.next){observer.next(getState());}}observeState();var unsubscribe=outerSubscribe(observeState);return {unsubscribe:unsubscribe};}},_ref[result]=function(){return this;},_ref;}// When a store is created, an "INIT" action is dispatched so that every
// reducer returns their initial state. This effectively populates
// the initial state tree.
dispatch({type:ActionTypes.INIT});return _ref2={dispatch:dispatch,subscribe:subscribe,getState:getState,replaceReducer:replaceReducer},_ref2[result]=observable,_ref2;}/**
* @class ModuleManager
* @category core
* @param {Object} object handler
* @description Solves modules dependencies
* @memberof module:core
*/var ModuleManager=/*#__PURE__*/function(){function ModuleManager(object){classCallCheck(this,ModuleManager);this.handler=object;this.currentModule=null;this.store=createStore(function(){var state=arguments.length>0&&arguments[0]!==undefined?arguments[0]:[{},''];var action=arguments.length>1?arguments[1]:undefined;state[0][action.key]=action.data;state[1]=action.key;return state;});this.modules={};}/**
* @method active
* @instance
* @description Sets .currentModule to provided module.
* @param {Object} module the module to make current
* @memberof module:core.ModuleManager
*/createClass(ModuleManager,[{key:"active",value:function active(module){this.currentModule=module;}/**
* @method reset
* @instance
* @description Set's .currentModule to null.
* @memberof module:core.ModuleManager
*/},{key:"reset",value:function reset(){this.currentModule=null;}/**
* @method define
* @instance
* @description Define the module in manager
* @param name The module name
* @memberof module:core.ModuleManager
*/},{key:"define",value:function define(name){this.modules[name]=this.currentModule;}/**
* @method use
* @instance
* @description Get the defined module from manager
* @param name The module name
* @memberof module:core.ModuleManager
*/},{key:"use",value:function use(name){return this.modules[name];}/**
* @method set
* @instance
* @description An alias for .add() <br/><br/>
* Use this method if you know that you will overwrite existing dependency.<br/>
* Use it in your app, but not in module that you provide to other people.
* @param {String} key the key of the dependency
* @param {Object} data the value of the dependency
* @memberof module:core.ModuleManager
*/},{key:"set",value:function set(key,data){this.store.dispatch({type:'ADD',key:key,data:data});}/**
* @method get
* @instance
* @description Returns dependency in store object, by key.
* @param {String} key the key of the dependency
* @memberof module:core.ModuleManager
* @return {Object|Module}
* @throws {DependencyError} if dependency is not in the store
* @example <caption>Get the 'hello' dependency</caption>
* manager.get('hello'); // -> {world: true}
*/},{key:"get",value:function get(key){if(!this.store.getState()[0][key]){throw new DependencyError('ModuleManager',"Module requires '".concat(key,"' dependency"),this.currentModule);}return this.store.getState()[0][key];}/**
* @method has
* @instance
* @description Returns whether manager has a dependency with the given key
* @param {String} key the key of the dependency
* @memberof module:core.ModuleManager
* @return {Boolean} Promise that is resolved when all promises completed.
* @example <caption>Check whether the store has the 'hello' dependency</caption>
* manager.has('hello'); // -> true
*/},{key:"has",value:function has(key){return Boolean(this.store.getState()[0][key]);}/**
* @method update
* @instance
* @description Updates deps
* @param {Object} [depsMap={}]
* @memberof module:core.ModuleManager
*/},{key:"update",value:function update(){var _this=this;var depsMap=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};this.store.subscribe(function(){var _this$store$getState=_this.store.getState(),_this$store$getState2=slicedToArray(_this$store$getState,2),data=_this$store$getState2[0],changedKey=_this$store$getState2[1];var callback=depsMap[changedKey];if(callback)callback(data[changedKey]);});}/**
* @method add
* @alias module:core.ModuleManager#set
* @memberof module:core.ModuleManager
*/},{key:"add",value:function add(){console.warn('.add() method is deprecated. Use .set() instead');return this.set.apply(this,arguments);}/**
* @method require
* @instance
* @description Require module
* @param {String} name Defined name
* @param {Function} moduleExecutor Function that returns applied module
* @memberof module:core.ModuleManager
*/},{key:"require",value:function require(name,moduleExecutor){if(this.use(name)===undefined)this.handler.applyModule(moduleExecutor());}}]);return ModuleManager;}();/**
* @class Component
* @category core
* @param {Object} [params] - The parameters object.
* @param {Object} [instructions] - The instructions object.
* @extends ModuleSystem
* @memberof module:core
*/var Component=/*#__PURE__*/function(_ModuleSystem){/**
* Default values for parameters
* @member {Object} module:core.Component#defaults
* @static
* @default {
* modules: [],
* manager: true
* }
*/ /**
* Static instructions
* @member {Object} module:core.Component#instructions
* @static
* @default {}
*/ /**
* Array of promises that should be resolved before Component is ready.
* @member {Array} module:core.Component#_wait
* @private
*/ // Collection of promises;
/**
* Collection of `modules`.
* @member {Array} module:core.Component#modules
* @public
*/ // Collection of modules;
/**
* Collection of `child` Components.
* @member {Array} module:core.Component#children
* @public
*/ // For keeping children components;
function Component(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var defaults=arguments.length>1&&arguments[1]!==undefined?arguments[1]:Component.defaults;var instructions=arguments.length>2&&arguments[2]!==undefined?arguments[2]:Component.instructions;classCallCheck(this,Component);_this=possibleConstructorReturn(this,getPrototypeOf$2(Component).call(this));// Apply polyfilled parameters to .params;
defineProperty$3(defineProperty$3(defineProperty$3(assertThisInitialized(assertThisInitialized(_this)),"_wait",[]),"modules",[]),"children",[]);_this.params=extend(transformData(params,instructions),defaults);if(_this.params.manager)_this.manager=new ModuleManager(assertThisInitialized(assertThisInitialized(_this)));_this.modules=_this.params.modules;_this.integrateModules();return _this;}/**
* @method wait
* @instance
* @description Wait for a promise.
* @param {Promise} [promise] - The promise that should be added to a queue.
* @return {Promise} Promise that is resolved when all promises completed.
* @memberof module:core.Component
*/createClass(Component,[{key:"wait",value:function wait(promise){if(promise)this._wait.push(promise);return Promise.all(this._wait);}/**
* @method defer
* @instance
* @description Execute `func` (Callback) when Component is ready.
* @param {Function} func - Callback.
* @memberof module:core.Component
*/},{key:"defer",value:function defer(func){var _this2=this;if(this.isDeffered)this.wait().then(function(){return func(_this2);});else func(this);}// PARAMETERS
/**
* @method updateParams
* @instance
* @description Updates parameters of the Component.
* @return {Object} Params of this Component
* @memberof module:core.Component
*/},{key:"updateParams",value:function updateParams(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};this.params=extend(params,this.params);return this.params;}// COPYING & CLONING
/**
* @method clone
* @instance
* @description Clone this component
* @return {object} a cloned component with all its source component' params copied.
* @memberof module:core.Component
*/},{key:"clone",value:function clone(){return new this.constructor(this.params).copy(this);}/**
* @method copy
* @instance
* @description Copy source native and integrate `modules` to it.
* @param {Component} source - Source component that is used for `copy()` action.
* @param {Function} [customize] - Callback executed before modules integration process.
* @return {this} Component
* @memberof module:core.Component
*/},{key:"copy",value:function copy(source,customize){this.params=objectSpread({},source.params);if(source.native)this.native=source.native.clone(source.params);if(customize)customize();this.integrateModules(source);return this;}/**
* @method add
* @instance
* @description Add a child `Component`.
* @param {Component} object - Component that should be added as a `child`.
* @return {Promise} Resolved when action is done.
* @memberof module:core.Component
*/},{key:"add",value:function(){var _add=asyncToGenerator(/*#__PURE__*/regenerator.mark(function _callee(object){return regenerator.wrap(function _callee$(_context){while(1){switch(_context.prev=_context.next){case 0:if(!object.parent){_context.next=3;break;}_context.next=3;return object.parent.remove(object);case 3:_context.next=5;return this.wait();case 5:_context.next=7;return object.wait();case 7:if(object.native){_context.next=9;break;}throw new CompositionError$1('Component','there is no object.native',this);case 9:object.parent=this;_context.next=12;return this.applyBridge({onAdd:object}).onAdd;case 12:this.native.add(object.native);this.children.push(object);return _context.abrupt("return",object);case 15:case"end":return _context.stop();}}},_callee,this);}));return function add(_x){return _add.apply(this,arguments);};}()/**
* @method remove
* @instance
* @description Remove a child `Component`.
* @param {Component} object - Component that should be a **child** of this Component.
* @return {Promise} Resolved when action is done.
* @memberof module:core.Component
*/},{key:"remove",value:function(){var _remove=asyncToGenerator(/*#__PURE__*/regenerator.mark(function _callee2(object){return regenerator.wrap(function _callee2$(_context2){while(1){switch(_context2.prev=_context2.next){case 0:if(!(object.parent!==this)){_context2.next=2;break;}return _context2.abrupt("return");case 2:_context2.next=4;return this.wait();case 4:_context2.next=6;return object.wait();case 6:object.parent=null;this.native.remove(object.native);this.children.splice(this.children.indexOf(object),1);case 9:case"end":return _context2.stop();}}},_callee2,this);}));return function remove(_x2){return _remove.apply(this,arguments);};}()/**
* @method addTo
* @instance
* @description Adds `this` Component to specified `App`/`Component`.
* @param {Component} object - Component that will be a parent of `this`.
* @memberof module:core.Component
*/},{key:"addTo",value:function addTo(object){return object.add(this);}},{key:"get",value:function get(key){return this.manager.get(key);}},{key:"use",value:function use(key){return this.manager.use(key);}/**
* Returns whether the object is `async` (`wait` promises are more than `0`).
* @member {Boolean} module:core.Component#isDeffered
*/},{key:"isDeffered",get:function get(){return this._wait.length>0;}/**
* Returns the `ModuleManager` used for this component.
* @member {ModuleManager} module:core.Component#manager
* @throws {ManagerError}
*/},{key:"manager",get:function get(){if(this._manager)return this._manager;throw new ManagerError('Component',"ModuleManager is not used in this component. 'manager' parameter should be set as 'true'",this);},set:function set(manager){this._manager=manager;}/**
* Returns the `native` object used for this component.
* @member {Object} module:core.Component#native
*/},{key:"native",get:function get(){return this._native;},set:function set(mesh){this._native=mesh;this._native.component=this;return this._native;}}]);inherits(Component,_ModuleSystem);return Component;}(ModuleSystem);defineProperty$3(defineProperty$3(Component,"defaults",{modules:null,manager:true}),"instructions",{});// 26.1.6 Reflect.get(target, propertyKey [, receiver])
function get(target,propertyKey/* , receiver */){var receiver=arguments.length<3?target:arguments[2];var desc,proto;if(_anObject(target)===receiver)return target[propertyKey];if(desc=_objectGopd.f(target,propertyKey))return _has(desc,'value')?desc.value:desc.get!==undefined?desc.get.call(receiver):undefined;if(_isObject(proto=_objectGpo(target)))return get(proto,propertyKey,receiver);}_export(_export.S,'Reflect',{get:get});var get$1=_core.Reflect.get;var get$2=get$1;function _superPropBase$1(object,property){while(!Object.prototype.hasOwnProperty.call(object,property)){object=getPrototypeOf$2(object);if(object===null)break;}return object;}var superPropBase=_superPropBase$1;var get$3=createCommonjsModule(function(module){function _get$$1(target,property,receiver){if(typeof Reflect!=="undefined"&&get$2){module.exports=_get$$1=get$2;}else{module.exports=_get$$1=function _get$$1(target,property,receiver){var base=superPropBase(target,property);if(!base)return;var desc=getOwnPropertyDescriptor$1(base,property);if(desc.get){return desc.get.call(receiver);}return desc.value;};}return _get$$1(target,property,receiver||target);}module.exports=_get$$1;});function attributes(){for(var _len=arguments.length,mappers=new Array(_len),_key=0;_key<_len;_key++){mappers[_key]=arguments[_key];}return function(target){for(var i=0;i<mappers.length;i++){var mapper=mappers[i];for(var k=0;k<mapper.map.length;k++){var attribute=mapper.map[k];Object.defineProperty(target.prototype,attribute,{get:mapper.getter(attribute),set:mapper.setter(attribute),configurable:mapper.configurable,enumerable:mapper.enumerable});}}};}function copy(){for(var _len2=arguments.length,map=new Array(_len2),_key2=0;_key2<_len2;_key2++){map[_key2]=arguments[_key2];}return {map:map,getter:function getter(name){return function(){return this.native[name];};},setter:function setter(name){return function(value){this.native[name].copy(value);};},configurable:true,enumerable:true};}function mirror(){for(var _len3=arguments.length,map=new Array(_len3),_key3=0;_key3<_len3;_key3++){map[_key3]=arguments[_key3];}return {map:map,getter:function getter(name){return function(){return this.native[name];};},setter:function setter(name){return function(value){this.native[name]=value;};},configurable:true,enumerable:true};}var _dec,_class;var/**
* @class MeshComponent
* @category core
* @param {Object} [params] - The parameters object.
* @param {Object} [instructions] - The instructions object.
* @extends module:core.Component
* @memberof module:core
*/MeshComponent=(_dec=attributes(copy('position','rotation','quaternion','scale'),mirror('material','geometry')),_dec(_class=/*#__PURE__*/function(_Component){createClass(MeshComponent,null,[{key:"custom",/**
* Default values for parameters
* @member {Object} module:core.MeshComponent#defaults
* @static
* @default
* {
* build: true,
* geometry: {},
* material: false,
*
* shadow: {
* cast: true,
* receive: true
* },
*
* position: {x: 0, y: 0, z: 0},
* rotation: {x: 0, y: 0, z: 0},
* scale: {x: 1, y: 1, z: 1}
* }
*/ /**
* Static instructions
* @member {Object} module:core.MeshComponent#instructions
* @static
* @default
* {
* position: ['x', 'y', 'z'],
* rotation: ['x', 'y', 'z'],
* scale: ['x', 'y', 'z']
* }
*/ // CUSTOM GEOMETRY HANDLING
value:function custom(geom){var constructor=arguments.length>1&&arguments[1]!==undefined?arguments[1]:Mesh;return(/*#__PURE__*/function(_MeshComponent){function _class2(){classCallCheck(this,_class2);return possibleConstructorReturn(this,getPrototypeOf$2(_class2).apply(this,arguments));}createClass(_class2,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:geom,material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new constructor(geometry,material)}).mesh;}}]);inherits(_class2,_MeshComponent);return _class2;}(MeshComponent));}},{key:"create",value:function create(geom,params,constructor){return new(MeshComponent.custom(geom,constructor))(params);}},{key:"from",value:function from(mesh){var params=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};params.build=false;var component=new MeshComponent(params);component.native=mesh;component.wrap();return component;}}]);function MeshComponent(params){var _this;var defaults=arguments.length>1&&arguments[1]!==undefined?arguments[1]:MeshComponent.defaults;var instructions=arguments.length>2&&arguments[2]!==undefined?arguments[2]:MeshComponent.instructions;classCallCheck(this,MeshComponent);_this=possibleConstructorReturn(this,getPrototypeOf$2(MeshComponent).call(this,params,defaults,instructions));if(_this.params.build){var build=_this.build(_this.params);if(!build){throw new CompositionError$1('MeshComponent','.build() method should return a THREE.Object3D or a Promise resolved with THREE.Object3D.',assertThisInitialized(assertThisInitialized(_this)));}if(build instanceof Promise){_this.wait(build);_this.wait(new Promise(function(resolve){build.then(function(native){_this.native=native;_this.wrap().then(resolve);});}));}else{_this.native=build;_this.wait(_this.wrap());}}_this.applyCommand('postIntegrate');return _this;}// BUILDING & WRAPPING
/**
* @method build
* @description Build livecycle should return a native object.
* @throws {CompositionError}
* @memberof module:core.MeshComponent
*/createClass(MeshComponent,[{key:"build",value:function build(){throw new CompositionError$1('MeshComponent','Instance should have it\'s own .build().',this);}/**
* @method wrap
* @instance
* @description Wraps transforms (`position` & `rotation`)
* @return {Promise} Resolved when action is completed
* @memberof module:core.MeshComponent
*/},{key:"wrap",value:function wrap(){var _this2=this;return new Promise(function(resolve){// TODO: Fix defer with physics
// this.defer(() => {
var _this2$params=_this2.params,position=_this2$params.position,rotation=_this2$params.rotation,scale=_this2$params.scale,shadow=_this2$params.shadow;_this2.position.set(position.x,position.y,position.z);_this2.rotation.set(rotation.x,rotation.y,rotation.z);_this2.scale.set(scale.x,scale.y,scale.z);_this2.native.castShadow=shadow.cast;_this2.native.receiveShadow=shadow.receive;_this2.applyBridge({onWrap:1});resolve(_this2);// });
});}// COPYING & CLONING
/**
* @method copy
* @instance
* @description Copy source transforms & execute `Component.copy()`
* @return {this} MeshComponent
* @memberof module:core.MeshComponent
*/},{key:"copy",value:function copy$$1(source){var _this3=this;return get$3(getPrototypeOf$2(MeshComponent.prototype),"copy",this).call(this,source,function(){_this3.position.copy(source.position);_this3.rotation.copy(source.rotation);_this3.quaternion.copy(source.quaternion);});}/**
* @method clone
* @instance
* @description Make a clone of this MeshComponent using `.copy()`
* @return {MeshComponent} clone of this object
* @memberof module:core.MeshComponent
*/},{key:"clone",value:function clone(geometry,material){var dest=new this.constructor({build:false}).copy(this);if(geometry)dest.geometry=dest.geometry.clone();if(material)dest.material=dest.material.clone();return dest;}}]);inherits(MeshComponent,_Component);return MeshComponent;}(Component))||_class);defineProperty$3(defineProperty$3(MeshComponent,"defaults",objectSpread({},Component.defaults,{build:true,geometry:{},material:false,shadow:{cast:true,receive:true},position:{x:0,y:0,z:0},rotation:{x:0,y:0,z:0},scale:{x:1,y:1,z:1}})),"instructions",{position:['x','y','z'],rotation:['x','y','z'],scale:['x','y','z']});var _dec$1,_class$1;var/**
* @class LightComponent
* @category core
* @param {Object} [params] - The parameters object.
* @param {Object} [instructions] - The instructions object.
* @extends module:core.Component
* @memberof module:core
*/LightComponent=(_dec$1=attributes(copy('position','rotation','quaternion','target')),_dec$1(_class$1=/*#__PURE__*/function(_Component){createClass(LightComponent,null,[{key:"from",/**
* Default values for parameters
* @member {Object} module:core.LightComponent#defaults
* @static
* @default
* {
* build: true,
*
* shadow: {
* cast: true,
*
* bias: 0,
* radius: 1,
*
* mapSize: {
* width: 1024,
* height: 1024
* },
*
* camera: {
* near: true,
* far: 400,
* fov: 90,
*
* top: 200,
* bottom: -200,
* left: -200,
* right: 200
* }
* },
*
* position: {x: 0, y: 0, z: 0},
* rotation: {x: 0, y: 0, z: 0}
* }
*/ /**
* Static instructions
* @member {Object} module:core.LightComponent#instructions
* @static
* @default
* {
* position: ['x', 'y', 'z'],
* rotation: ['x', 'y', 'z']
* }
*/value:function from(light){var params=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var wrapShadow=arguments.length>2&&arguments[2]!==undefined?arguments[2]:true;params.build=false;var component=new LightComponent(params);component.native=light;component.wrap();if(wrapShadow)component.wrapShadow();return component;}}]);function LightComponent(params){var _this;var defaults=arguments.length>1&&arguments[1]!==undefined?arguments[1]:LightComponent.defaults;var instructions=arguments.length>2&&arguments[2]!==undefined?arguments[2]:LightComponent.instructions;classCallCheck(this,LightComponent);_this=possibleConstructorReturn(this,getPrototypeOf$2(LightComponent).call(this,params,defaults,instructions));if(_this.params.build){var build=_this.build(_this.params);if(!build){throw new CompositionError$1('LightComponent','.build() method should return a THREE.Object3D or a Promise resolved with THREE.Object3D.',assertThisInitialized(assertThisInitialized(_this)));}if(build instanceof Promise){build.then(function(native){_this.native=native;});}else _this.native=build;_this.wait(_this.wrap());}_this.applyCommand('postIntegrate');return _this;}// BUILDING & WRAPPING
/**
* @method build
* @instance
* @description Build livecycle should return a native object.
* @throws {CompositionError}
* @memberof module:core.LightComponent
*/createClass(LightComponent,[{key:"build",value:function build(){throw new CompositionError$1('MeshComponent','Instance should have it\'s own .build().',this);}/**
* @method wrap
* @instance
* @description Wraps transforms (`position` & `rotation`)
* @return {Promise} Resolved when action is completed
* @memberof module:core.LightComponent
*/},{key:"wrap",value:function wrap(){var _this2=this;return new Promise(function(resolve){_this2.defer(function(){var _this2$params=_this2.params,position=_this2$params.position,rotation=_this2$params.rotation;_this2.position.set(position.x,position.y,position.z);_this2.rotation.set(rotation.x,rotation.y,rotation.z);_this2.applyBridge({onWrap:1});resolve(_this2);});});}/**
* @method wrapShadow
* @instance
* @description Wraps shadow properties
* @memberof module:core.LightComponent
*/},{key:"wrapShadow",value:function wrapShadow(){var native=this.native,shadow=this.params.shadow;native.castShadow=shadow.cast;native.shadow.mapSize.width=shadow.mapSize.width;native.shadow.mapSize.height=shadow.mapSize.height;native.shadow.bias=shadow.bias;native.shadow.radius=shadow.radius;var shadowCamera=native.shadow.camera;var camera=shadow.camera;shadowCamera.near=camera.near;shadowCamera.far=camera.far;shadowCamera.fov=camera.fov;shadowCamera.left=camera.left;shadowCamera.right=camera.right;shadowCamera.top=camera.top;shadowCamera.bottom=camera.bottom;}// COPYING & CLONING
/**
* @method copy
* @instance
* @description Copy source transforms & execute `Component.copy()`
* @return {this} LightComponent
* @memberof module:core.LightComponent
*/},{key:"copy",value:function copy$$1(source){var _this3=this;return get$3(getPrototypeOf$2(LightComponent.prototype),"copy",this).call(this,source,function(){if(_this3.target)_this3.target.copy(source.target());_this3.position.copy(source.position);_this3.rotation.copy(source.rotation);_this3.quaternion.copy(source.quaternion);});}/**
* @method clone
* @instance
* @description Make a clone of this LightComponent using `.copy()`
* @return {LightComponent} clone of this object
* @memberof module:core.LightComponent
*/},{key:"clone",value:function clone(){return new this.constructor({build:false}).copy(this);}}]);inherits(LightComponent,_Component);return LightComponent;}(Component))||_class$1);defineProperty$3(defineProperty$3(LightComponent,"defaults",objectSpread({},Component.defaults,{build:true,shadow:{cast:true,bias:0,radius:1,mapSize:{width:1024,height:1024},camera:{near:true,far:400,fov:90,top:200,bottom:-200,left:-200,right:200}},position:{x:0,y:0,z:0},rotation:{x:0,y:0,z:0}})),"instructions",{position:['x','y','z'],rotation:['x','y','z']});var _dec$2,_class$2;var/**
* @class CameraComponent
* @category core
* @param {Object} [params] - The parameters object.
* @param {Object} [instructions] - The instructions object.
* @extends module:core.Component
* @memberof module:core
*/CameraComponent=(_dec$2=attributes(copy('position','rotation','quaternion','target')),_dec$2(_class$2=/*#__PURE__*/function(_Component){createClass(CameraComponent,null,[{key:"from",/**
* Default values for parameters
* @member {Object} module:core.CameraComponent#defaults
* @static
* @default
* {
* build: true,
*
* position: {x: 0, y: 0, z: 0},
* rotation: {x: 0, y: 0, z: 0}
* }
*/ /**
* Static instructions
* @member {Object} module:core.CameraComponent#instructions
* @static
* @default
* {
* position: ['x', 'y', 'z'],
* rotation: ['x', 'y', 'z'],
* scale: ['x', 'y', 'z']
* }
*/value:function from(camera){var params=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};params.build=false;var component=new CameraComponent(params);component.native=camera;component.wrap();return component;}}]);function CameraComponent(params){var _this;var defaults=arguments.length>1&&arguments[1]!==undefined?arguments[1]:CameraComponent.defaults;var instructions=arguments.length>2&&arguments[2]!==undefined?arguments[2]:CameraComponent.instructions;classCallCheck(this,CameraComponent);_this=possibleConstructorReturn(this,getPrototypeOf$2(CameraComponent).call(this,params,defaults,instructions));if(_this.params.build){var build=_this.build(_this.params);if(!build){throw new CompositionError$1('CameraComponent','.build() method should return a THREE.Object3D or a Promise resolved with THREE.Object3D.',assertThisInitialized(assertThisInitialized(_this)));}if(build instanceof Promise){build.then(function(native){_this.native=native;});}else _this.native=build;_this.wait(_this.wrap());}_this.applyCommand('postIntegrate');return _this;}// BUILDING & WRAPPING
/**
* @method build
* @instance
* @description Build livecycle should return a native object.
* @throws {CompositionError}
* @memberof module:core.CameraComponent
*/createClass(CameraComponent,[{key:"build",value:function build(){throw new CompositionError$1('CameraComponent','Instance should have it\'s own .build().',this);}/**
* @method wrap
* @instance
* @description Wraps transforms (`position` & `rotation`)
* @return {Promise} Resolved when action is completed
* @memberof module:core.CameraComponent
*/},{key:"wrap",value:function wrap(){var _this2=this;return new Promise(function(resolve){_this2.defer(function(){_this2.position.set(_this2.params.position.x,_this2.params.position.y,_this2.params.position.z);_this2.rotation.set(_this2.params.rotation.x,_this2.params.rotation.y,_this2.params.rotation.z);_this2.applyBridge({onWrap:1});resolve(_this2);});});}/**
* @method copy
* @instance
* @description Copy source transforms & execute `Component.copy()`
* @return {this} CameraComponent
* @memberof module:core.CameraComponent
*/},{key:"copy",value:function copy$$1(source){var _this3=this;return get$3(getPrototypeOf$2(CameraComponent.prototype),"copy",this).call(this,source,function(){if(_this3.target)_this3.target.copy(source.target());_this3.position.copy(source.position);_this3.rotation.copy(source.rotation);_this3.quaternion.copy(source.quaternion);});}/**
* @method clone
* @instance
* @description Make a clone of this CameraComponent using `.copy()`
* @return {CameraComponent} clone of this object
* @memberof module:core.CameraComponent
*/},{key:"clone",value:function clone(){return new this.constructor({build:false}).copy(this);}}]);inherits(CameraComponent,_Component);return CameraComponent;}(Component))||_class$2);defineProperty$3(defineProperty$3(CameraComponent,"defaults",objectSpread({},Component.defaults,{build:true,position:{x:0,y:0,z:0},rotation:{x:0,y:0,z:0}})),"instructions",{position:['x','y','z'],rotation:['x','y','z'],scale:['x','y','z']});const version="2.2.0-alpha.0";var system={window:typeof window==='undefined'?global:window};/**
* @class App
* @category core
* @description This component is used to prepare a world scene, setup physics, camera, renderer and all other things that you usually do before making meshes.
* @param {Array} [modules=[]] - Array of Modules
* @extends ModuleSystem
* @memberof module:core
*/var App=/*#__PURE__*/function(_ModuleSystem){/**
* @description Defines whether the scene should render or not
* @member {Boolean} module:core.App#enabled
* @public
*/ /**
* Loops in this app
* @description Array of loops that are executed by this app.
* @member {Array} module:core.App#loops
* @public
*/function App(){var _this;var modules=arguments.length>0&&arguments[0]!==undefined?arguments[0]:[];classCallCheck(this,App);console.log("WHS.App ".concat(version));_this=possibleConstructorReturn(this,getPrototypeOf$2(App).call(this));defineProperty$3(defineProperty$3(assertThisInitialized(assertThisInitialized(_this)),"enabled",true),"loops",[]);_this.manager=new ModuleManager(assertThisInitialized(assertThisInitialized(_this)));_this.modules=modules;_this.integrateModules();return _this;}// CONTROLS & UPDATING
/**
* @method start
* @description Start rendering loop and physics simulation (if you use version with physics).
* @memberof module:core.App
*/createClass(App,[{key:"start",value:function start(){var requestAnimFrame=function(){return system.window.requestAnimationFrame||system.window.webkitRequestAnimationFrame||system.window.mozRequestAnimationFrame||function(callback){system.window.setTimeout(callback,1000/60);};}();var loops=this.loops,enabled=this.enabled;function process(){requestAnimFrame(process);if(!enabled)return;for(var i=0,ll=loops.length;i<ll;i++){var e=loops[i];if(e.enabled)e.execute(e.clock);}}this.enabled=true;process();}/**
* @method stop
* @description Stops rendering loops
* @memberof module:core.App
*/},{key:"stop",value:function stop(){this.enabled=false;}/**
* @method addLoop
* @description Adds loop to this app.
* @param {Object} loop - the loop to add
* @return {Promise} Promise that is resolved when promises completed.
* @memberof module:core.App
* @example <caption>Adding a loop to an app</caption>
* const loop = new Loop(() => {
* // ...
* });
*
* const app = new App();
*
* app.addLoop(loop);
* loop.start();
*/},{key:"addLoop",value:function addLoop(loop){var _this2=this;return new Promise(function(resolve){_this2.loops.push(loop);resolve(loop);});}/**
* @method removeLoop
* @description Removes loop from this app.
* @param {Object} loop - the loop to remove
* @return {Promise} Promise that is resolved when promises completed.
* @memberof module:core.App
*/},{key:"removeLoop",value:function removeLoop(loop){var _this3=this;return new Promise(function(resolve){var index=_this3.loops.indexOf(loop);if(index!==-1)_this3.loops.splice(index,1);resolve(loop);});}},{key:"get",value:function get(key){return this.manager.get(key);}},{key:"use",value:function use(key){return this.manager.use(key);}}]);inherits(App,_ModuleSystem);return App;}(ModuleSystem);/**
* @class Loop
* @category core
* @param {Function} func function to execute on each animation frame
* @param {Boolean} [useClock=true] passes a Clock to the function when called, if true
* @memberof module:core
*/var Loop=/*#__PURE__*/function(){function Loop(func){var useClock=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;classCallCheck(this,Loop);this.func=func;this.clock=useClock?new Clock():null;this.enabled=false;}// CONTROLS
/**
* @method start
* @instance
* @description Starts this loop, clock if it has one. Won't do anything if loop enabled already.
* @param {Component} [world] app to add this loop to, if provided.
* @memberof module:core.Loop
*/createClass(Loop,[{key:"start",value:function start(world){if(this.enabled)return;if(world)world.addLoop(this);if(this.clock)this.clock.start();this.enabled=true;}/**
* @method stop
* @instance
* @description Stops this loop and its clock if it has one, won't do anything if this loop is not enabled)
* @param {Component} [world] app to remove this loop from, if provided.
* @memberof module:core.Loop
*/},{key:"stop",value:function stop(world){if(!this.enabled)return;if(this.clock)this.clock.stop();this.enabled=false;if(world)world.removeLoop(this);}// EXECUTION
/**
* @method execute
* @instance
* @description Executes the function of this loop
* @memberof module:core.Loop
* @returns {*} whatever the function of this loop returns
*/},{key:"execute",value:function execute(){return this.func(this.clock);}}]);return Loop;}();/** @module core */ /**
* @class AmbientLight
* @category components/lights
* @description AmbientLight is a simple class, it extends Light and inherits all its methods.
* AmbientLight creates basic light around all scene, so it doesn't need properties like pos or target.
* It supports only color and intensity as parameters, which defines the color of the surrounded light and intensity of light.
* @param {Object} [params={light: {color: 0xffffff, intensity: 1}}] - The params.
* @extends module:core.LightComponent
* @memberof module:components/lights
* @example <caption>Creating an AmbientLight </caption>
* new AmbientLight({
* color: 0xffffff,
* intensity: 0.2
* }).addTo(world);
*/var AmbientLight$1=/*#__PURE__*/function(_LightComponent){function AmbientLight$$1(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,AmbientLight$$1);return possibleConstructorReturn(this,getPrototypeOf$2(AmbientLight$$1).call(this,params,AmbientLight$$1.defaults));}createClass(AmbientLight$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return this.applyBridge({light:new AmbientLight(params.color,params.intensity)}).light;}}]);inherits(AmbientLight$$1,_LightComponent);return AmbientLight$$1;}(LightComponent);defineProperty$3(AmbientLight$1,"defaults",objectSpread({},LightComponent.defaults,{color:0xffffff,intensity:1}));/**
* @class DirectionalLight
* @category components/lights
* @description DirectinalLight creates a light that shines from a specific direction not from a specific position.<br/><br/>
* This light will behave as though it is infinitely far away and the rays produced from it are all parallel. <br/><br/>
* The best analogy would be a light source that acts like the sun: the sun is so far away that all sunlight hitting objects comes from the same angle.<br/><br/>
* It has the same options as AmbientLight in light paramater, but it also supports pos and target paramaters.
* @param {Object} [params={light: {color: 0xffffff, intensity: 1}}] - The params.
* @extends module:core.LightComponent
* @memberof module:components/lights
* @example <caption>Creating a DirectionalLight to fall down from vec3(10, 20, 10) to vec3(0, 0, 0)</caption>
* new DirectionalLight({
* color: 0xffffff,
* intensity: 0.2,
*
* position: [10, 20, 10]
* }).addTo(app);
*/var DirectionalLight$1=/*#__PURE__*/function(_LightComponent){function DirectionalLight$$1(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,DirectionalLight$$1);_this=possibleConstructorReturn(this,getPrototypeOf$2(DirectionalLight$$1).call(this,params,DirectionalLight$$1.defaults));_this.wrapShadow();return _this;}createClass(DirectionalLight$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return this.applyBridge({light:new DirectionalLight(params.color,params.intensity)}).light;}}]);inherits(DirectionalLight$$1,_LightComponent);return DirectionalLight$$1;}(LightComponent);defineProperty$3(DirectionalLight$1,"defaults",objectSpread({},LightComponent.defaults,{color:0xffffff,intensity:1}));/**
* @class HemisphereLight
* @category components/lights
* @description HemisphereLight is a light source positioned directly above the scene.<br/>
* It also doesn't need position and target properties.
* @classDesc
* <iframe src="https://threejs.org/examples/webgl_lights_hemisphere.html"></iframe>
* @param {Object} [params={light: {skyColor: 0xffffff, groundColor: 0xffffff, intensity: 1}}] - The params.
* @extends module:core.LightComponent
* @memberof module:components/lights
* @example <caption>Creating a HemisphereLight</caption>
* new HemisphereLight({
* skyColor: 0xff0000,
* groundColor: 0x0000ff,
* intensity: 0.2
* }).addTo(app);
*/var HemisphereLight$1=/*#__PURE__*/function(_LightComponent){function HemisphereLight$$1(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,HemisphereLight$$1);return possibleConstructorReturn(this,getPrototypeOf$2(HemisphereLight$$1).call(this,params,HemisphereLight$$1.defaults));}createClass(HemisphereLight$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return this.applyBridge({light:new HemisphereLight(params.skyColor,params.groundColor,params.intensity)}).light;}}]);inherits(HemisphereLight$$1,_LightComponent);return HemisphereLight$$1;}(LightComponent);defineProperty$3(HemisphereLight$1,"defaults",objectSpread({},LightComponent.defaults,{skyColor:0xffffff,groundColor:0xffffff,intensity:1}));/**
* @class PointLight
* @category components/lights
* @description PointLight creates a light at a specific position in the scene. The light shines in all directions (roughly similar to a light bulb.)<br/><br/>
* It has the same options as AmbientLight in light paramater, but it also supports position, distance and decay.<br/>
* @param {Object} [params={light: {color: 0xffffff, intensity: 1, distance: 100, decay: 1}}] - The params.
* @extends LightComponent
* @memberof module:components/lights
* @example <caption>Creating a PointLight</caption>
* new PointLight( {
* color: 0xff0000,
* intensity: 2,
* distance: 300
*
* position: [10, 20, 10]
* }).addTo(app);
*/var PointLight$1=/*#__PURE__*/function(_LightComponent){function PointLight$$1(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,PointLight$$1);_this=possibleConstructorReturn(this,getPrototypeOf$2(PointLight$$1).call(this,params,PointLight$$1.defaults));_this.wrapShadow();return _this;}createClass(PointLight$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return this.applyBridge({light:new PointLight(params.color,params.intensity,params.distance,params.decay)}).light;}}]);inherits(PointLight$$1,_LightComponent);return PointLight$$1;}(LightComponent);defineProperty$3(PointLight$1,"defaults",objectSpread({},LightComponent.defaults,{color:0xffffff,intensity:1,distance:100,decay:1}));/**
* @class SpotLight
* @category components/lights
* @description SpotLight creates spot light that can cast shadow in one direction. <br/><br/>
* It has the same parameters as AmbientLight in light, but it also supports pos and target. <br/><br/>
* SpotLight affects meshes with lambert and phong material.
* @classDesc
* <iframe src="https://threejs.org/examples/webgl_lights_spotlight.html"></iframe>
* @param {Object} [params={light: {color: 0xffffff, intensity: 1, distance: 100, angle: Math.PI / 3, exponent: 0, decay: 1}}] - The params.
* @extends module:core.LightComponent
* @memberof module:components/lights
* @example <caption>Creating a SpotLight that falls down from vec3(10, 20, 10) to vec3(0, 0, 0)</caption>
* new SpotLight({
* color: 0x00ff00,
* intensity: 3,
* distance: 1000
*
* position: [10, 20, 10]
* }).addTo(app);
*/var SpotLight$1=/*#__PURE__*/function(_LightComponent){function SpotLight$$1(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,SpotLight$$1);_this=possibleConstructorReturn(this,getPrototypeOf$2(SpotLight$$1).call(this,params,SpotLight$$1.defaults));_this.wrapShadow();return _this;}createClass(SpotLight$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return this.applyBridge({light:new SpotLight(params.color,params.intensity,params.distance,params.angle,params.exponent,params.decay)}).light;}}]);inherits(SpotLight$$1,_LightComponent);return SpotLight$$1;}(LightComponent);defineProperty$3(SpotLight$1,"defaults",objectSpread({},LightComponent.defaults,{color:0xffffff,intensity:1,distance:100,angle:Math.PI/3,exponent:0,decay:1}));var AreaLight=/*#__PURE__*/function(_LightComponent){function AreaLight(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,AreaLight);return possibleConstructorReturn(this,getPrototypeOf$2(AreaLight).call(this,params,AreaLight.defaults));}createClass(AreaLight,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return this.applyBridge({light:new RectAreaLight(params.color,params.intensity,params.width,params.height)}).light;}}]);inherits(AreaLight,_LightComponent);return AreaLight;}(LightComponent);defineProperty$3(AreaLight,"defaults",objectSpread({},LightComponent.defaults,{color:0xffffff,intensity:1,width:10,height:10}));/** @module components/lights */ /**
* @class CubeCamera
* @category components/cameras
* @description Creates 6 cameras that render to a WebGLRenderTargetCube
* @param {Object} [params] - The parameters object.
* @memberof module:components/cameras
* @extends module:core.CameraComponent
* @example <caption>Creates a CubeCamera and set it as app's camera</caption>
* const camera = new CubeCamera({
* camera: {
* cubeResolution: 256
* },
*
* position: {
* x: 0,
* y: 100,
* z: 0
* }
* });
*
* app.camera = camera;
*/var CubeCamera$1=/*#__PURE__*/function(_CameraComponent){/**
* Default values for parameters
* @member {Object} module:components/cameras.CubeCamera#defaults
* @static
* @default <pre>
* {
* camera: {
* near: 1,
* far: 1000,
* cubeResolution: 128
* }
* }</pre>
*/function CubeCamera$$1(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,CubeCamera$$1);return possibleConstructorReturn(this,getPrototypeOf$2(CubeCamera$$1).call(this,params,CubeCamera$$1.defaults));}createClass(CubeCamera$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return this.applyBridge({camera:new CubeCamera(params.near,params.far,params.cubeResolution)}).camera;}}]);inherits(CubeCamera$$1,_CameraComponent);return CubeCamera$$1;}(CameraComponent);defineProperty$3(CubeCamera$1,"defaults",objectSpread({},CameraComponent.defaults,{near:1,far:1000,cubeResolution:128}));/**
* @class OrthographicCamera
* @category components/cameras
* @description Camera with orthographic projection.
* @param {Object} [params] - The parameters object.
* @memberof module:components/cameras
* @extends module:core.CameraComponent
* @example <caption>Create an OrthographicCamera and set it as app's camera</caption>
* const camera = new OrthographicCamera({
* camera: {
* far: 10000
* },
*
* position: {
* y: 50
* }
* });
*
* app.camera = camera;
*/var OrthographicCamera$1=/*#__PURE__*/function(_CameraComponent){/**
* Default values for parameters
* @member {Object} module:components/cameras.OrthographicCamera#defaults
* @static
* @default <pre>
* {
* near: 1,
* far: 1000,
* left: system.window.innerWidth / -2,
* right: system.window.innerWidth / 2,
* top: system.window.innerHeight / 2,
* bottom: system.window.innerHeight / -2
* }</pre>
*/function OrthographicCamera$$1(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,OrthographicCamera$$1);return possibleConstructorReturn(this,getPrototypeOf$2(OrthographicCamera$$1).call(this,params,OrthographicCamera$$1.defaults));}createClass(OrthographicCamera$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return this.applyBridge({camera:new OrthographicCamera(params.left,params.right,params.top,params.bottom,params.near,params.far)}).camera;}}]);inherits(OrthographicCamera$$1,_CameraComponent);return OrthographicCamera$$1;}(CameraComponent);defineProperty$3(OrthographicCamera$1,"defaults",objectSpread({},CameraComponent.defaults,{near:1,far:1000,left:system.window.innerWidth/-2,right:system.window.innerWidth/2,top:system.window.innerHeight/2,bottom:system.window.innerHeight/-2}));/**
* @class PerspectiveCamera
* @description Camera with perspective projection.
* @category components/cameras
* @param {Object} [params] - The parameters object.
* @memberof module:components/cameras
* @extends module:core.CameraComponent
* @example <caption>Create an PerspectiveCamera and set it as app's camera</caption>
* const camera = new PerspectiveCamera({
* fov: 75,
* aspect: window.innerWidth / window.innerHeight,
*
* position: {
* x: 0,
* y: 100,
* z: 0
* }
* });
*
* app.camera = camera;
*/var PerspectiveCamera$1=/*#__PURE__*/function(_CameraComponent){/**
* Default values for parameters
* @member {Object} module:components/cameras.PerspectiveCamera#defaults
* @static
* @default <pre>
* {
* near: 1,
* far: 1000,
* fov: 75,
* aspect: system.window.innerWidth / system.window.innerHeight
* }</pre>
*/function PerspectiveCamera$$1(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,PerspectiveCamera$$1);return possibleConstructorReturn(this,getPrototypeOf$2(PerspectiveCamera$$1).call(this,params,PerspectiveCamera$$1.defaults));}createClass(PerspectiveCamera$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return this.applyBridge({camera:new PerspectiveCamera(params.fov,params.aspect,params.near,params.far)}).camera;}}]);inherits(PerspectiveCamera$$1,_CameraComponent);return PerspectiveCamera$$1;}(CameraComponent);defineProperty$3(PerspectiveCamera$1,"defaults",objectSpread({},CameraComponent.defaults,{near:1,far:1000,fov:75,aspect:system.window.innerWidth/system.window.innerHeight}));/** @module components/cameras */ /**
* @class Box
* @category components/meshes
* @description As told on Component definition, while you can pass any of the inherited params for this component construction, you will need to
* pass specific parameters to build this mesh as a geometry object.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#BoxGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Box, and adding to app</caption>
* new Box({
* geometry: {
* width: 2,
* height: 2,
* depth: 2
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: [50, 60, 70]
* }).addTo(app);
*/var Box=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Box#defaults
* @static
* @default <pre>
* {
* geometry: {
* width: 1,
* height: 1,
* depth: 1,
* widthSegments: 1,
* heightSegments: 1,
* depthSegments: 1
* }
* }</pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Box#instructions
* @static
* @default geometry: ['width', 'height', 'depth', 'widthSegments', 'heightSegments', 'depthSegements']
*/function Box(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Box);return possibleConstructorReturn(this,getPrototypeOf$2(Box).call(this,params,Box.defaults,Box.instructions));}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Box
*/createClass(Box,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var geometry=new(params.buffer?BoxBufferGeometry:BoxGeometry)(params.geometry.width,params.geometry.height,params.geometry.depth,params.geometry.widthSegments,params.geometry.heightSegments,params.geometry.depthSegments);return geometry;}}]);inherits(Box,_MeshComponent);return Box;}(MeshComponent);defineProperty$3(defineProperty$3(Box,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{width:1,height:1,depth:1,widthSegments:1,heightSegments:1,depthSegments:1}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['width','height','depth','widthSegments','heightSegments','depthSegements']}));/**
* @class Circle
* @category components/meshes
* @description As told on Component definition, while you can pass any of the inherited params for this component construction, you will need to
* pass specific parameters to build this mesh as a geometry object.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#CircleGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Circle, and adding to app</caption>
* new Circle({
* geometry: {
* radius: 4,
* segments: 16
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: [50, 60, 70]
* }).addTo(app);
*/var Circle=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Circle#defaults
* @static
* @default <pre>
* {
* geometry: {
* radius: 50,
* segments: 8,
* thetaStart: 0,
* thetaLength: Math.PI * 2
* }
* }</pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Circle#instructions
* @static
* @default geometry: ['radius', 'segments', 'thetaStart', 'thetaLength']
*/function Circle(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Circle);return possibleConstructorReturn(this,getPrototypeOf$2(Circle).call(this,params,Circle.defaults,Circle.instructions));}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Circle
*/createClass(Circle,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var geometry=new(params.buffer?CircleBufferGeometry:CircleGeometry)(params.geometry.radius,params.geometry.segments,params.geometry.thetaStart,params.geometry.thetaLength);return geometry;}}]);inherits(Circle,_MeshComponent);return Circle;}(MeshComponent);defineProperty$3(defineProperty$3(Circle,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radius:50,segments:8,thetaStart:0,thetaLength:Math.PI*2}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['radius','segments','thetaStart','thetaLength']}));/**
* @class Cone
* @category components/meshes
* @description A cylinder is one of the most basic curvilinear geometric shapes, the surface formed by the points at a fixed distance from a given straight line, the axis of the cylinder. <br/><br/>
* The solid enclosed by this surface and by two planes perpendicular to the axis is also called a cylinder.<br/>
* The surface area and the volume of a cylinder have been known since deep antiquity.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#ConeGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Cone, and adding to app</caption>
* new Cone({
* geometry: {
* radiusTop: 2,
* radiusBottom: 4,
* height: 5
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* pos: [0, 100, 0]
* }).addTo(app);
*/var Cone=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Cone#defaults
* @static
* @default <pre>
* {
* geometry: {
* radius: 20,
* height: 100,
* radiusSegments: 32,
* heightSegments: 1,
* openEnded: false,
* thetaStart: 0,
* thetaLength: Math.PI * 2
* }
* }</pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Cone#instructions
* @static
* @default <pre>
* geometry: [
* 'radius',
* 'height',
* 'radiusSegments',
* 'heightSegments',
* 'openEnded',
* 'thetaStart',
* 'thetaLength'
* ]
* </pre>
*/function Cone(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Cone);_this=possibleConstructorReturn(this,getPrototypeOf$2(Cone).call(this,params,Cone.defaults,Cone.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Cone.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Cone
*/createClass(Cone,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var geometry=new(params.buffer?ConeBufferGeometry:ConeGeometry)(params.geometry.radius,params.geometry.height,params.geometry.radiusSegments,params.geometry.heightSegments,params.geometry.openEnded,params.geometry.thetaStart,params.geometry.thetaLength);return geometry;}}]);inherits(Cone,_MeshComponent);return Cone;}(MeshComponent);defineProperty$3(defineProperty$3(Cone,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radius:20,height:100,radiusSegments:32,heightSegments:1,openEnded:false,thetaStart:0,thetaLength:Math.PI*2}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['radius','height','radiusSegments','heightSegments','openEnded','thetaStart','thetaLength']}));/**
* @class Cylinder
* @category components/meshes
* @description A cylinder is one of the most basic curvilinear geometric shapes, the surface formed by the points at a fixed distance from a given straight line, the axis of the cylinder. <br/><br/>
* The solid enclosed by this surface and by two planes perpendicular to the axis is also called a cylinder.<br/>
* The surface area and the volume of a cylinder have been known since deep antiquity.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#CylinderGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Cylinder, and adding to app</caption>
* new Cylinder({
* geometry: {
* radiusTop: 2,
* radiusBottom: 4,
* height: 5
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* pos: [0, 100, 0]
* }).addTo(app);
*/var Cylinder=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Cylinder#defaults
* @static
* @default <pre>
* {
* geometry: {
* radiusTop: 20,
* radiusBottom: 20,
* height: 100,
* radiusSegments: 32,
* heightSegments: 1,
* openEnded: false,
* thetaStart: 0,
* thetaLength: Math.PI * 2
* }
* }</pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Cylinder#instructions
* @static
* @default <pre>
* geometry: [
* 'radiusTop',
* 'radiusBottom',
* 'height',
* 'radiusSegments',
* 'heightSegments',
* 'openEnded',
* 'thetaStart',
* 'thetaLength'
* ]
* </pre>
*/function Cylinder(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Cylinder);_this=possibleConstructorReturn(this,getPrototypeOf$2(Cylinder).call(this,params,Cylinder.defaults,Cylinder.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Cylinder.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Cylinder
*/createClass(Cylinder,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var geometry=new(params.buffer?CylinderBufferGeometry:CylinderGeometry)(params.geometry.radiusTop,params.geometry.radiusBottom,params.geometry.height,params.geometry.radiusSegments,params.geometry.heightSegments,params.geometry.openEnded,params.geometry.thetaStart,params.geometry.thetaLength);return geometry;}}]);inherits(Cylinder,_MeshComponent);return Cylinder;}(MeshComponent);defineProperty$3(defineProperty$3(Cylinder,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radiusTop:0,radiusBottom:1,height:1,radiusSegments:32,heightSegments:1,openEnded:false,thetaStart:0,thetaLength:Math.PI*2}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['radiusTop','radiusBottom','height','radiusSegments','heightSegments','openEnded','thetaStart','thetaLength']}));/**
* @class Dodecahedron
* @category components/meshes
* @description In geometry, a dodecahedron is any polyhedron with twelve flat faces. <br/><br/>
* The most familiar dodecahedron is the regular dodecahedron, which is a Platonic solid. <br/>
* There are also three regular star dodecahedra, which are constructed as stellations of the convex form. <br/>
* All of these have icosahedral symmetry, order 120.
* Dodecahedron creates Dodecahedron object by it's radius and detail.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#DodecahedronGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Dodecahedron, and adding to app</caption>
* new Dodecahedron({
* geometry: {
* radius: 2
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: {
* y: 10
* }
* }).addTo(app);
*/var Dodecahedron=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Dodecahedron#defaults
* @static
* @default <pre>
* geometry: {
* radius: 1,
* detail: 0
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Dodecahedron#instructions
* @static
* @default <pre>
* geometry: ['radius', 'detail']
* </pre>
*/function Dodecahedron(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Dodecahedron);_this=possibleConstructorReturn(this,getPrototypeOf$2(Dodecahedron).call(this,params,Dodecahedron.defaults,Dodecahedron.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Dodecahedron.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Dodecahedron
*/createClass(Dodecahedron,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new(params.buffer?DodecahedronBufferGeometry:DodecahedronGeometry)(params.geometry.radius,params.geometry.detail);}}]);inherits(Dodecahedron,_MeshComponent);return Dodecahedron;}(MeshComponent);defineProperty$3(defineProperty$3(Dodecahedron,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radius:1,detail:0}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['radius','detail']}));/**
* @class Extrude
* @category components/meshes
* @description Extrude geometry means that you can create a 3D mesh from any 2D shape using three.js geometry based on <a href='https://threejs.org/docs/#api/math/Vector2'>THREE.Vector2.</a> <br/>
* Such implementation will help you to make volumed shapes that have their own depth and can be seen from all angels.<br/><br/>
* You can also find some interesting examples made using <a href='threejs.org'>three.js</a> which is a core of whs.js, such as:
* - <a href='http://threejs.org/examples/webgl_geometry_extrude_shapes.html'>Webgl geometry extrude</a>
* - <a href='http://threejs.org/examples/webgl_geometry_extrude_shapes2.html'>Extrude shapes from geodata</a>
* - <a href='http://threejs.org/examples/webgl_geometry_extrude_splines.html'>Extrude splines</a>
*
* Such examples can be easily implemented using whitestorm.js or it's plugins. Use `Extrude` class with <a href='https://threejs.org/docs/#api/extras/core/Shape'>THREE.Shape</a> to get extrude effect of shape defined by 2D vectors.
* This class is similar to <a href='https://threejs.org/docs/#api/geometries/ExtrudeGeometry'>THREE.ExtrudeGeometry</a>,
* but it also contains all properties, applied by `Shape`, such as material, mass and vectors like position (pos) and rotation (rot).
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#ExtrudeGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a shape, then an Extrude from it</caption>
* const shape = new THREE.Shape([
* new THREE.Vector2(-4,-4),
* new THREE.Vector2(-2,0),
* new THREE.Vector2(-4,4),
* new THREE.Vector2(0,2),
* new THREE.Vector2(4,4),
* new THREE.Vector2(2,0),
* new THREE.Vector2(4,-4),
* new THREE.Vector2(0,-2)
* ]);
*
* const extrude = new Extrude({
* geometry: {
* shapes: shape,
* options: {
* bevelEnabled: false,
* bevelSize: 0,
* amount: 2
* }
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: [0, 100, 0]
* });
*
* extrude.addTo(app);
*/var Extrude=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Extrude#defaults
* @static
* @default <pre>
* {
* geometry: {
* shapes: [],
* options: {}
* }
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Extrude#instructions
* @static
* @default <pre>
* {
* geometry: ['shapes', 'options']
* }
* </pre>
*/function Extrude(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Extrude);_this=possibleConstructorReturn(this,getPrototypeOf$2(Extrude).call(this,params,Extrude.defaults,Extrude.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Extrude.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Extrude
*/createClass(Extrude,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var geometry=new ExtrudeGeometry(params.geometry.shapes,params.geometry.options);return params.buffer?new BufferGeometry().fromGeometry(geometry):geometry;}}]);inherits(Extrude,_MeshComponent);return Extrude;}(MeshComponent);defineProperty$3(defineProperty$3(Extrude,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{shapes:[],options:{}}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['shapes','options']}));/**
* @class Icosahedron
* @category components/meshes
* @description In geometry, an icosahedron is a polyhedron with 20 faces.<br/>
* There are many kinds of icosahedra, with some being more symmetrical than others. The most well known is the Platonic, convex regular icosahedron.<br/>
* `Icosahedron` creates an Icosahedron object by its radius and detail.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#IcosahedronGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Icosahedron, and adding to app</caption>
* new Icosahedron({
* geometry: {
* radius: 2,
* detail: 1
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: [0, 100, 0]
* }).addTo(app);
*/var Icosahedron=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Icosahedron#defaults
* @static
* @default <pre>
* {
* geometry: {
* radius: 1,
* detail: 0
* }
* }</pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Icosahedron#instructions
* @static
* @default {geometry: ['radius', 'detail']}
*/function Icosahedron(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Icosahedron);_this=possibleConstructorReturn(this,getPrototypeOf$2(Icosahedron).call(this,params,Icosahedron.defaults,Icosahedron.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Icosahedron.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Icosahedron
*/createClass(Icosahedron,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new(params.buffer?IcosahedronBufferGeometry:IcosahedronGeometry)(params.geometry.radius,params.geometry.detail);}}]);inherits(Icosahedron,_MeshComponent);return Icosahedron;}(MeshComponent);defineProperty$3(defineProperty$3(Icosahedron,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radius:1,detail:0}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['radius','detail']}));/**
* @class Lathe
* @category components/meshes
* @description A `LatheGeometry` allows you to create shapes from a smooth curve.
* This curve is defined by a number of points (also called knots) and is most often called a spline. This spline is rotated around a fixed point and results in vase- and bell-like shapes.<br/><br/>
* In 3D computer graphics, a lathed object is a 3D model whose vertex geometry is produced by rotating the points of a spline or other point set around a fixed axis.
* The lathing may be partial; the amount of rotation is not necessarily a full 360 degrees.
* The point set providing the initial source data can be thought of as a cross section through the object along a plane containing its axis of radial symmetry. <br/><br/>
* The <a href='http://threejs.org/docs/scenes/geometry-browser.html#LatheGeometry'>following example</a> shows a geometry which can be generated using `Lathe` class.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#LatheGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Lath, and adding to app</caption>
* const points = [];
*
* for (let i = 0; i < 10; i++) {
* points.push(
* new THREE.Vector2(
* (Math.sin(i * 0.7) * 15 + 50) / 10,
* (i - 5) * 0.2
* )
* );
* }
*
* const lathe = new Lathe({
* geometry: {
* points: points
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: [0, 50, 10]
* }).addTo(app);
*/var Lathe=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Lathe#defaults
* @static
* @default <pre>
* {
* geometry: {
* points: []
* }
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Lathe#instructions
* @static
* @default <pre>{
* geometry: ['points']
* }
* </pre>
*/function Lathe(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Lathe);_this=possibleConstructorReturn(this,getPrototypeOf$2(Lathe).call(this,params,Lathe.defaults,Lathe.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Lathe.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Lathe
*/createClass(Lathe,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new(params.buffer?LatheBufferGeometry:LatheGeometry)(params.geometry.points);}}]);inherits(Lathe,_MeshComponent);return Lathe;}(MeshComponent);defineProperty$3(defineProperty$3(Lathe,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{points:[]}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['points']}));/**
* @class Line
* @category components/meshes
* @description Line component is generated from a curve/line and amount of vectors that should be used (points).
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Line, and adding to app</caption>
* new Line({
* geometry: {
* curve: new THREE.LineCurve3(new THREE.Vector3(10, 10, 0), new THREE.Vector3(10, 30, 0))
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* })
* }).addTo(app);
*/var Line$1=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Line#defaults
* @static
* @default <pre>
* {
* curve: new LineCurve3(new Vector3(0, 0, 0), new Vector3(10, 0, 0)),
* points: 50
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Line#instructions
* @static
* @default <pre>{
* geometry: ['curve', 'points']
* }
* </pre>
*/function Line$$1(params){classCallCheck(this,Line$$1);return possibleConstructorReturn(this,getPrototypeOf$2(Line$$1).call(this,params,Line$$1.defaults,Line$$1.instructions));}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Line
*/createClass(Line$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Line(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var geometry=params.buffer?new BufferGeometry():new Geometry();if(params.buffer){var pp=params.curve.getPoints(params.points);var verts=new Float32Array(pp.length*3);for(var i=0,max=pp.length;i<max;i++){var i3=i*3;verts[i3]=pp[i].x;verts[i3+1]=pp[i].y;verts[i3+2]=pp[i].z;}geometry.addAttribute('position',new BufferAttribute(verts,3));}else geometry.vertices=params.curve.getPoints(params.points);return geometry;}}]);inherits(Line$$1,_MeshComponent);return Line$$1;}(MeshComponent);defineProperty$3(defineProperty$3(Line$1,"defaults",objectSpread({},MeshComponent.defaults,{curve:null,points:50})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['curve','points']}));/**
* @class Importer
* @category components/meshes
* @description Importer is a loader for meshes and any other data to your scene
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Importer, and adding to app</caption>
* new Importer({
* loader: new THREE.OBJLoader(),
*
* parser(geometry, material) { // data from loader
* return new THREE.Mesh(geometry, material); // should return your .native (mesh in this case)
* },
*
* position: [0, 100, 0]
* }).addTo(app);
*/var Importer=/*#__PURE__*/function(_MeshComponent){createClass(Importer,null,[{key:"filter",/**
* Default values for parameters
* @member {Object} module:components/meshes.Importer#defaults
* @static
* @default <pre>
* {
* url: '',
* loader: new JSONLoader(),
*
* onLoad() {},
* onProgress() {},
* onError() {},
*
* texturePath: null,
* useCustomMaterial: false,
*
* parser(geometry, materials) {
* return new Mesh(geometry, materials);
* }
* }</pre>
*/ /**
* @method filter
* @description Default values for filter
* @static
* @param {THREE.Mesh} object Instance for iterating through it's children.
* @param {Function} filter Function with child as argument, should return a boolean whether include the child or not.
* @return {THREE.Mesh} object with children
* @memberof module:components/meshes.Importer
* @example <caption>Removing unnecessary lights from children</caption>
* new Importer({
* loader: new THREE.OBJLoader(),
*
* parse(group) { // data from loader
* return Importer.filter(group, child => !child.isLight); // remove lights
* },
*
* position: [0, 100, 0]
* }).addTo(app);
*/value:function filter(object,_filter){var processFilter=function processFilter(object){object.children.forEach(function(el,index){if(el.children)processFilter(el);if(!_filter(el))object.children.splice(index,1);});return object;};return processFilter(object);}}]);function Importer(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Importer);return possibleConstructorReturn(this,getPrototypeOf$2(Importer).call(this,params,Importer.defaults,Importer.instructions,false));}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Importer
*/createClass(Importer,[{key:"build",value:function build(){var _this=this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new Promise(function(resolve){if(params.texturePath)params.loader.setTexturePath(params.texturePath);params.loader.load(params.url,function(){for(var _len=arguments.length,data=new Array(_len),_key=0;_key<_len;_key++){data[_key]=arguments[_key];}// geometry, materials
params.onLoad.apply(params,data);var object=params.parser.apply(_this,data);if(params.material)object.material=_this.applyBridge({material:params.material}).material;resolve(object);},params.onProgress,params.onError);});}}]);inherits(Importer,_MeshComponent);return Importer;}(MeshComponent);defineProperty$3(defineProperty$3(Importer,"defaults",objectSpread({},MeshComponent.defaults,{url:'',loader:new JSONLoader(),onLoad:function onLoad(){},onProgress:function onProgress(){},// TODO add onComplete?
onError:function onError(){},texturePath:null,useCustomMaterial:false,parser:function parser(geometry,material){var _this$applyBridge=this.applyBridge({geometry:geometry,material:material}),geom=_this$applyBridge.geometry,mat=_this$applyBridge.material;return this.applyBridge({mesh:geom.bones?new SkinnedMesh(geom,mat):new Mesh(geom,mat)}).mesh;}})),"instructions",objectSpread({},MeshComponent.instructions));/**
* @class Octahedron
* @category components/meshes
* @description In geometry, an octahedron is a polyhedron with eight faces.
* A regular octahedron is a Platonic solid composed of eight equilateral triangles, four of which meet at each vertex.
* <br/><br/>
* `Octahedron` creates an Octahedron object by its `radius` and `detail`.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#OctahedronGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating an Octahedron, and adding to app</caption>
* new Octahedron({
* geometry: {
* radius: 2,
* detail: 1
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: [0, 100, 0]
* }).addTo(app);
*/var Octahedron=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Octahedron#defaults
* @static
* @default <pre>
* {
* geometry: {
* radius: 1,
* detail: 0
* }
* }
* </pre>
*/function Octahedron(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Octahedron);_this=possibleConstructorReturn(this,getPrototypeOf$2(Octahedron).call(this,params,Octahedron.defaults,Octahedron.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Octahedron.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Octahedron
*/createClass(Octahedron,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new(params.buffer?OctahedronBufferGeometry:OctahedronGeometry)(params.geometry.radius,params.geometry.detail);}}]);inherits(Octahedron,_MeshComponent);return Octahedron;}(MeshComponent);defineProperty$3(Octahedron,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radius:1,detail:0}}));/**
* @class Parametric
* @category components/meshes
* @description `Parametric` generates a geometry representing a <a href='https://en.wikipedia.org/wiki/Parametric_surface'>Parametric surface</a>
* <br/><br/>
* It is usually used to develop different kinds of highfields or visualize a <a href='https://stemkoski.github.io/Three.js/Graphulus-Function.html'>math function</a>.
* <br/>
* - <a href='http://math.hws.edu/graphicsbook/source/threejs/curves-and-surfaces.html'>Parametric surface</a>
* - <a href='https://stemkoski.github.io/Three.js/Graphulus-Surface.html'>"Graphulus"</a>
* <br/><br/>
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#ParametricGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Example creating an heightfield-like geometry. `u` and `v` are like `x` and `y` in shape, but their values are always from `0` to `1`.
* We use them in `THREE.Vector3` like `x` and `z` and `Math.random() * 5` for `y`.</caption>
* const createParametric = (u, v) => {
* return new THREE.Vector3(u * 30, Math.random() * 5, v * 30);
* }
*
* new Parametric({
* geometry: {
* func: createParametric
* },
*
* material: new THREE.MeshLambertMaterial({
* color: 0xffffff,
* side: THREE.DoubleSide
* }),
*
* position: [0, 100, -100]
* }).addTo(app);
*/var Parametric=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Parametric#defaults
* @static
* @default <pre>
* {
* geometry: {
* func: (u, v) => new Vector3(u, v, 0),
* slices: 10,
* tacks: 10
* }
* }
* </pre>
*/function Parametric(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Parametric);return possibleConstructorReturn(this,getPrototypeOf$2(Parametric).call(this,params,Parametric.defaults,Parametric.instructions));}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Parametric
*/createClass(Parametric,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new(params.buffer?ParametricBufferGeometry:ParametricGeometry)(params.geometry.func,params.geometry.slices,params.geometry.stacks);}}]);inherits(Parametric,_MeshComponent);return Parametric;}(MeshComponent);defineProperty$3(Parametric,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{func:function func(u,v){return new Vector3(u,v,0);},slices:10,stacks:10}}));/**
* @class Plane
* @category components/meshes
* @description `Plane` is used for creating planes given some `width` and `height`.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#PlaneGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Plane, and adding to app</caption>
* new Plane({
* geometry: {
* width: 20,
* height: 30
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* })
* }).addTo(app);
*/var Plane$1=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Plane#defaults
* @static
* @default <pre>
* {
* geometry: {
* width: 10,
* height: 10,
* wSegments: 1,
* hSegments: 1
* }
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Plane#instructions
* @static
* @default <pre>
* {
* geometry: ['width', 'height', 'wSegments', 'hSegments']
* }
* </pre>
*/function Plane$$1(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Plane$$1);_this=possibleConstructorReturn(this,getPrototypeOf$2(Plane$$1).call(this,params,Plane$$1.defaults,Plane$$1.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Plane$$1.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Plane
*/createClass(Plane$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var geometry=new(params.buffer?PlaneBufferGeometry:PlaneGeometry)(params.geometry.width,params.geometry.height,params.geometry.wSegments,params.geometry.hSegments);return geometry;}}]);inherits(Plane$$1,_MeshComponent);return Plane$$1;}(MeshComponent);defineProperty$3(defineProperty$3(Plane$1,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{width:10,height:10,wSegments:1,hSegments:1}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['width','height','wSegments','hSegments']}));var verticesOfCube=[-1,-1,-1,1,-1,-1,1,1,-1,-1,1,-1,-1,-1,1,1,-1,1,1,1,1,-1,1,1],indicesOfFaces=[2,1,0,0,3,2,0,4,7,7,3,0,0,1,5,5,4,0,1,2,6,6,5,1,2,3,7,7,6,2,4,5,6,6,7,4];/**
* @class Polyhedron
* @category components/meshes
* @description In elementary geometry, a polyhedron is a solid in three dimensions with flat polygonal faces, straight edges and sharp corners or vertices.
* <br/><br/>
* `Polyhedron` creates a Polyhedron by its `radius` and `detail`.
* <br/><br/>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating an Polyhedron, and adding to app</caption>
* new Polyhedron({
* geometry: {
* radius: 2,
* detail: 1
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: [0, 100, 0]
* }).addTo(app);
*/var Polyhedron=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Polyhedron#defaults
* @static
* @default <pre>
* {
* geometry: {
* verticesOfCube: [
* -1, -1, -1, 1, -1, -1, 1, 1, -1, -1, 1, -1,
* -1, -1, 1, 1, -1, 1, 1, 1, 1, -1, 1, 1
* ],
*
* indicesOfFaces: [
* 2, 1, 0, 0, 3, 2,
* 0, 4, 7, 7, 3, 0,
* 0, 1, 5, 5, 4, 0,
* 1, 2, 6, 6, 5, 1,
* 2, 3, 7, 7, 6, 2,
* 4, 5, 6, 6, 7, 4
* ],
*
* radius: 6,
* detail: 2
* }
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Polyhedron#instructions
* @static
* @default <pre>
* {
* geometry: ['verticesOfCube', 'indicesOfFaces', 'radius', 'detail']
* }
* </pre>
*/function Polyhedron(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Polyhedron);_this=possibleConstructorReturn(this,getPrototypeOf$2(Polyhedron).call(this,params,Polyhedron.defaults,Polyhedron.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Polyhedron.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Polyhedron
*/createClass(Polyhedron,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new(params.buffer?PolyhedronBufferGeometry:PolyhedronGeometry)(params.geometry.verticesOfCube,params.geometry.indicesOfFaces,params.geometry.radius,params.geometry.detail);}}]);inherits(Polyhedron,_MeshComponent);return Polyhedron;}(MeshComponent);defineProperty$3(defineProperty$3(defineProperty$3(defineProperty$3(Polyhedron,"verticesOfCube",verticesOfCube),"indicesOfFaces",indicesOfFaces),"defaults",objectSpread({},MeshComponent.defaults,{geometry:{verticesOfCube:verticesOfCube,indicesOfFaces:indicesOfFaces,radius:6,detail:2}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['verticesOfCube','indicesOfFaces','radius','detail']}));/**
* @class Ring
* @category components/meshes
* @description Ring class creates a circle or just 2D Torus. Does not support physics.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#RingGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Ring, and adding to app</caption>
* new Ring({
* geometry: {
* innerRadius: 5,
* outerRadius: 2
* },
*
* material: new THREE.MeshLambertMaterial({
* color: 0xffffff,
* side THREE.DoubleSide
* }),
*
* position: [0, 8, 0],
*
* rotation: {
* x: Math.PI/4
* }
* }).addTo(app);
*/var Ring=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Ring#defaults
* @static
* @default <pre>
* {
* geometry: {
* innerRadius: 0,
* outerRadius: 50,
* thetaSegments: 8,
* phiSegments: 8,
* thetaStart: 0,
* thetaLength: Math.PI * 2
* }
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Ring#instructions
* @static
* @default <pre>
* {
* geometry: [
* 'innerRadius',
* 'outerRadius',
* 'thetaSegments',
* 'phiSegments',
* 'thetaStart',
* 'thetaLength'
* ]
* }
* </pre>
*/function Ring(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Ring);_this=possibleConstructorReturn(this,getPrototypeOf$2(Ring).call(this,params,Ring.defaults,Ring.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Ring.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Ring
*/createClass(Ring,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new(params.buffer?RingBufferGeometry:RingGeometry)(params.geometry.innerRadius,params.geometry.outerRadius,params.geometry.thetaSegments,params.geometry.phiSegments,params.geometry.thetaStart,params.geometry.thetaLength);}}]);inherits(Ring,_MeshComponent);return Ring;}(MeshComponent);defineProperty$3(defineProperty$3(Ring,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{innerRadius:0,outerRadius:50,thetaSegments:8,phiSegments:8,thetaStart:0,thetaLength:Math.PI*2}})),"instructions",objectSpread({},MeshComponent.defaults,{geometry:['innerRadius','outerRadius','thetaSegments','phiSegments','thetaStart','thetaLength']}));/**
* @class Shape
* @category components/meshes
* @description Shape is a universal class. It allows you to create different 2D shapes in 3D scene.<br/>
* Unfortunately, not all of them support physics, an alternative is to make a similar 3D object and scale its width down to near zero.
* <br/><br/>
* `Shape` consists of shapes that are in its shapes parameter.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#ShapeGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a plane looking Shape from a THREE.Shape, and adding it to app</caption>
* const rectWidth = 10,
* rectLength = 5;
*
* const rectShape = new THREE.Shape();
* rectShape.moveTo(0,0);
* rectShape.lineTo(0, rectWidth);
* rectShape.lineTo(rectLength, rectWidth);
* rectShape.lineTo(rectLength, 0);
* rectShape.lineTo(0, 0);
*
* const plane = new Shape({
* geometry: {
* shape: rectShape
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* })
* }).addTo(app);
*/var Shape$1=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Shape#defaults
* @static
* @default <pre>
* {
* geometry: {
* shapes: []
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Shape#instructions
* @static
* @default <pre>
* {
* geometry: ['shapes']
* }
* </pre>
*/function Shape$$1(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Shape$$1);_this=possibleConstructorReturn(this,getPrototypeOf$2(Shape$$1).call(this,params,Shape$$1.defaults,Shape$$1.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Shape$$1.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Shape
*/createClass(Shape$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new(params.buffer?ShapeBufferGeometry:ShapeGeometry)(params.geometry.shapes);}}]);inherits(Shape$$1,_MeshComponent);return Shape$$1;}(MeshComponent);defineProperty$3(defineProperty$3(Shape$1,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{shapes:[]}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['shapes']}));/**
* @class Sphere
* @category components/meshes
* @description Sphere class is used to create sphere objects by its radius property and other values that determines its detality.
* <br/><br/>
* It is similar to THREE.SphereGeometry, but it also contains all `Shape` properties, such as material, mass and vectors like position (pos) and rotation (rot).
* <br/><br/>
* Then it creates an `Three.js mesh` or a `Physijs mesh`, that is similar to `Three.js mesh`, but it also take into consideration collision calculations.
* This mesh is a combination of `Three.js geometry` and `Physijs material` (The same as in three.js, but with friction and restitution).
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#SphereGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Sphere, and adding it to app</caption>
* new Sphere({
* geometry: {
* radius: 2
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: {
* y: 100
* }
* }).addTo(app);
*/var Sphere$1=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Sphere#defaults
* @static
* @default <pre>
* {
* geometry: {
* radius: 1,
* widthSegments: 8,
* heightSegments: 6
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Sphere#instructions
* @static
* @default <pre>
* {
* geometry: ['radius', 'widthSegments', 'heightSegments']
* }
* </pre>
*/function Sphere$$1(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Sphere$$1);return possibleConstructorReturn(this,getPrototypeOf$2(Sphere$$1).call(this,params,Sphere$$1.defaults,Sphere$$1.instructions));}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Sphere
*/createClass(Sphere$$1,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var geometry=new(params.buffer?SphereBufferGeometry:SphereGeometry)(params.geometry.radius,params.geometry.widthSegments,params.geometry.heightSegments);return geometry;}}]);inherits(Sphere$$1,_MeshComponent);return Sphere$$1;}(MeshComponent);defineProperty$3(defineProperty$3(Sphere$1,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radius:1,widthSegments:8,heightSegments:6}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['radius','widthSegments','heightSegments']}));/**
* @class Tetrahedron
* @category components/meshes
* @description In geometry, a tetrahedron is a polyhedron composed of four triangular faces, six straight edges, and four vertex corners.
* The tetrahedron is the simplest of all the ordinary convex polyhedra and the only one that has fewer than 5 faces.
* <br/><br/>
* `Tetrahedron` creates a Tetrahedron object by its `radius` and `detail`
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#TetrahedronGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Tetrahedron, and adding it to app</caption>
* new Tetrahedron({
* geometry: {
* radius: 2,
* detail: 1
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: {
* x: 0,
* y: 100,
* z: 0
* }
* }).addTo(app);
*/var Tetrahedron=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Tetrahedron#defaults
* @static
* @default <pre>
* {
* geometry: {
* radius: 1,
* detail: 0
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Tetrahedron#instructions
* @static
* @default <pre>
* {
* geometry: ['radius', 'detail']
* }
* </pre>
*/function Tetrahedron(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Tetrahedron);_this=possibleConstructorReturn(this,getPrototypeOf$2(Tetrahedron).call(this,params,Tetrahedron.defaults,Tetrahedron.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Tetrahedron.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Tetrahedron
*/createClass(Tetrahedron,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new(params.buffer?TetrahedronBufferGeometry:TetrahedronGeometry)(params.geometry.radius,params.geometry.detail);}}]);inherits(Tetrahedron,_MeshComponent);return Tetrahedron;}(MeshComponent);defineProperty$3(defineProperty$3(Tetrahedron,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radius:1,detail:0}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['radius','detail']}));/**
* @class Text
* @category components/meshes
* @description Text class is made for creating 3D text objects.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#TextGeometry"></iframe>
* <br/><br/>
* Physics text object can be convex or concave. By default it's convex but you can also switch to concave.
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Text, and adding it to app</caption>
* new Text({
* text: 'Some text',
* parameters: {
* font: 'path/to/font.typeface.js',
* size: 20,
* height: 5,
* curveSegments: 6
* }
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: {
* x: -40,
* y: 20,
* z: 0
* }
* }).addTo(app);
*/var Text=/*#__PURE__*/function(_MeshComponent){createClass(Text,null,[{key:"load",/**
* Default values for parameters
* @member {Object} module:components/meshes.Text#defaults
* @static
* @default <pre>
* {
* text: 'Hello World!',
* font: null,
*
* geometry: {
* size: 12,
* height: 50,
* curveSegments: 12,
* font: new Font(),
* bevelEnabled: false,
* bevelThickness: 10,
* bevelSize: 8
* }
* }
* </pre>
*/ /**
* Default FontLoader
* @member {Object} module:components/meshes.Text#loader
* @static
* @default new FontLoader()
*/ /**
* @method load
* @static
* @description load() preloads a Font object and returns a Promise with it.
* @param {String} path Path to the font
* @return {Promise} A promise resolved with a font
* @memberof module:components/meshes.Text
*/value:function load(path){var loader=arguments.length>1&&arguments[1]!==undefined?arguments[1]:Text.loader;return new Promise(function(resolve){loader.load(path,resolve);});}}]);function Text(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Text);return possibleConstructorReturn(this,getPrototypeOf$2(Text).call(this,params,Text.defaults,Text.instructions));}/**
* @method build
* @description Build is called as part of the lifecycle to create a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Text
*/createClass(Text,[{key:"build",value:function build(){var _this=this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var promise=new Promise(function(resolve){(params.font instanceof Promise?params.font:Promise.resolve(params.font)).then(function(font){var _this$applyBridge=_this.applyBridge({geometry:new TextGeometry(params.text,Object.assign(params.geometry,{font:font})),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;resolve(_this.applyBridge({mesh:new Mesh(geometry,material)}).mesh);});});get$3(getPrototypeOf$2(Text.prototype),"wait",this).call(this,promise);return promise;}}]);inherits(Text,_MeshComponent);return Text;}(MeshComponent);defineProperty$3(defineProperty$3(defineProperty$3(Text,"defaults",objectSpread({},MeshComponent.defaults,{text:'Hello World!',font:null,geometry:{size:12,height:50,curveSegments:12,font:new Font(),bevelEnabled:false,bevelThickness:10,bevelSize:8}})),"instructions",objectSpread({},MeshComponent.instructions)),"loader",new FontLoader());/**
* @class Torus
* @category components/meshes
* @description Torus class makes a torus figure. A donut is a torus.
* @classDesc
* <iframe src="https://threejs.org/docs/index.html#api/geometries/TorusGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Torus, and adding it to app</caption>
* new Torus({
* geometry: {
* radius: 5,
* tube: 2
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* position: {
* y: 35
* }
* }).addTo(app);
*/var Torus=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Torus#defaults
* @static
* @default <pre>
* {
* geometry: {
* radius: 100,
* tube: 40,
* radialSegments: 8,
* tubularSegments: 6,
* arc: Math.PI * 2
* }
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Torus#instructions
* @static
* @default <pre>
* {
* geometry: [
* 'radius',
* 'tube',
* 'radialSegments',
* 'tubularSegments',
* 'arc'
* ]
* }
* </pre>
*/function Torus(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Torus);_this=possibleConstructorReturn(this,getPrototypeOf$2(Torus).call(this,params,Torus.defaults,Torus.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Torus.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Torus
*/createClass(Torus,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};return new TorusGeometry(params.geometry.radius,params.geometry.tube,params.geometry.radialSegments,params.geometry.tubularSegments,params.geometry.arc);}}]);inherits(Torus,_MeshComponent);return Torus;}(MeshComponent);defineProperty$3(defineProperty$3(Torus,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radius:100,tube:40,radialSegments:8,tubularSegments:6,arc:Math.PI*2}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['radius','tube','radialSegments','tubularSegments','arc']}));/**
* @class Torusknot
* @category components/meshes
* @description Torusknot class makes a torusknot figure. It's like a crooked donut, very crooked.
* @classDesc
* <iframe src="https://threejs.org/docs/scenes/geometry-browser.html#TorusKnotGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Torusknot, and adding it to app</caption>
* new Torusknot({
* geometry: {
* radius:5,
* tube: 2
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
*
* pos: {
* y: 100
* }
* }).addTo(app);
*/var Torusknot=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Torusknot#defaults
* @static
* @default <pre>
* {
* geometry: {
* radius: 100,
* tube: 40,
* radialSegments: 64,
* tubularSegments: 8,
* p: 2,
* q: 3
* }
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Torusknot#instructions
* @static
* @default <pre>
* {
* geometry: [
* 'radius',
* 'tube',
* 'radialSegments',
* 'tubularSegments',
* 'p',
* 'q'
* ]
* }
* </pre>
*/function Torusknot(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Torusknot);_this=possibleConstructorReturn(this,getPrototypeOf$2(Torusknot).call(this,params,Torusknot.defaults,Torusknot.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Torusknot.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Torusknot
*/createClass(Torusknot,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var GConstruct=params.buffer?TorusKnotBufferGeometry:TorusKnotGeometry;return new GConstruct(params.geometry.radius,params.geometry.tube,params.geometry.radialSegments,params.geometry.tubularSegments,params.geometry.p,params.geometry.q);}}]);inherits(Torusknot,_MeshComponent);return Torusknot;}(MeshComponent);defineProperty$3(defineProperty$3(Torusknot,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{radius:100,tube:40,radialSegments:64,tubularSegments:8,p:2,q:3}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['radius','tube','radialSegments','tubularSegments','p','q']}));/**
* @class Tube
* @category components/meshes
* @description Tube class makes a tube that extrudes along a 3d curve.
* @classDesc
* <iframe src="https://threejs.org/docs/index.html#api/geometries/TubeGeometry"></iframe>
* @param {Object} [params] - The params.
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Creating a Tube from a three.js Curve, and adding it to app</caption>
* const CustomSinCurve = THREE.Curve.create(
* function (scale) { // custom curve constructor
* this.scale = (scale === undefined) ? 1 : scale;
* },
*
* function (t) { // getPoint: t is between 0-1
* const tx = t * 3 - 1.5,
* ty = Math.sin( 2 * Math.PI * t ),
* tz = 0;
*
* return new THREE.Vector3(tx, ty, tz).multiplyScalar(this.scale);
* }
* );
*
* const path = new CustomSinCurve(10);
*
* new Tube({
* geometry: {
* path: path
* },
*
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* })
* }).addTo(app);
*/var Tube=/*#__PURE__*/function(_MeshComponent){/**
* Default values for parameters
* @member {Object} module:components/meshes.Tube#defaults
* @static
* @default <pre>
* {
* geometry: {
* path: new THREE.LineCurve3(new Vector3(0, 0, 0), new Vector3(0, 0, 1)),
* segments: 20,
* radius: 2,
* radiusSegments: 8,
* closed: false
* }
* }
* </pre>
*/ /**
* Instructions
* @member {Object} module:components/meshes.Tube#instructions
* @static
* @default <pre>
* {
* geometry: [
* 'path',
* 'segments',
* 'radius',
* 'radiusSegments',
* 'closed'
* ]
* }
* </pre>
*/function Tube(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,Tube);_this=possibleConstructorReturn(this,getPrototypeOf$2(Tube).call(this,params,Tube.defaults,Tube.instructions));if(params.build){_this.build(params);get$3(getPrototypeOf$2(Tube.prototype),"wrap",assertThisInitialized(_this)).call(assertThisInitialized(_this));}return _this;}/**
* @method build
* @description Build lifecycle creates a mesh using input params.
* @param {Object} params Component parameters.
* @return {THREE.Mesh} Built mesh
* @memberof module:components/meshes.Tube
*/createClass(Tube,[{key:"build",value:function build(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.params;var _this$applyBridge=this.applyBridge({geometry:this.buildGeometry(params),material:params.material}),geometry=_this$applyBridge.geometry,material=_this$applyBridge.material;return this.applyBridge({mesh:new Mesh(geometry,material)}).mesh;}},{key:"buildGeometry",value:function buildGeometry(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var geometry=new(params.buffer?TubeBufferGeometry:TubeGeometry)(params.geometry.path,params.geometry.segments,params.geometry.radius,params.geometry.radiusSegments,params.geometry.closed);return geometry;}}]);inherits(Tube,_MeshComponent);return Tube;}(MeshComponent);defineProperty$3(defineProperty$3(Tube,"defaults",objectSpread({},MeshComponent.defaults,{geometry:{path:new LineCurve3(new Vector3(0,0,0),new Vector3(0,0,1)),segments:20,radius:2,radiusSegments:8,closed:false}})),"instructions",objectSpread({},MeshComponent.instructions,{geometry:['path','segments','radius','radiusSegments','closed']}));/**
* @class Group
* @category components/meshes
* @description Sometimes you need to make groups of objects (it's not conveniently to apply transforms to each object when can make just one to a group).<br/>
* In Three.js you make it using `THREE.Object3D` and it's children. <br/><br/>
* In whs.js we have `Group`
* @extends module:core.MeshComponent
* @memberof module:components/meshes
* @example <caption>Approach 2 - Adding objects to an empty group</caption>
* const sphere = new Sphere();
* const box = new Box();
* const group = new Group();
*
* sphere.addTo(group);
* box.addTo(group);
* @example <caption>Approach 2 - Making a group from objects</caption>
* const sphere = new Sphere();
* const box = new Box();
* const group = new Group(box, sphere);
* // OR: const group = new Group([box, sphere]);
*/var Group$1=/*#__PURE__*/function(_MeshComponent){function Group$$1(){var _this;classCallCheck(this,Group$$1);_this=possibleConstructorReturn(this,getPrototypeOf$2(Group$$1).call(this,{}));for(var i=0;i<arguments.length;i++){var obj=i<0||arguments.length<=i?undefined:arguments[i];if(obj instanceof Component)obj.addTo(assertThisInitialized(assertThisInitialized(_this)));else if(obj instanceof Object3D)_this.native.add(obj);}return _this;}createClass(Group$$1,[{key:"build",value:function build(){return new Object3D();}}]);inherits(Group$$1,_MeshComponent);return Group$$1;}(MeshComponent);/** @module components/meshes */ /**
* @class ElementModule
* @category modules/app
* @param {Object} [container=document.body] container is the DOM object to which application's canvas will be added to.
* @memberof module:modules/app
* @example <caption>Creating an element module, passing it to the App</caption>
* new App([
* new ElementModule(document.getElementById('app'))
* ]);
*/var ElementModule=/*#__PURE__*/function(){function ElementModule(){var container=arguments.length>0&&arguments[0]!==undefined?arguments[0]:document.body;classCallCheck(this,ElementModule);if(container.container){console.warn('ElementModule now accepts only argument which is a DOM object, not a params object.');this.container=container.container;}else this.container=container;this.createElement();}/**
* @method createElement
* @instance
* @description Creates a canvas element.
* @memberof module:modules/app.ElementModule
*/createClass(ElementModule,[{key:"createElement",value:function createElement(){this.element=window.document.createElement('div');this.element.className='whs-app';this.element.style.width='inherit';this.element.style.height='inherit';this.element.style.position='relative';}},{key:"manager",value:function manager(_manager){_manager.set('element',this.element);_manager.set('container',this.container);}},{key:"integrate",value:function integrate(self){self.container.appendChild(self.element);}}]);return ElementModule;}();/**
* @class RenderingModule
* @category modules/app
* @param {Object} [params]
* @memberof module:modules/app
* @example <caption> Creating a rendering module and passing it to App's modules</caption>
* new App([
* new ElementModule(),
* new SceneModule(),
* new DefineModule('camera', new PerspectiveCamera({
* position: new THREE.Vector3(0, 6, 18),
* far: 10000
* })),
* new RenderingModule({
* bgColor: 0x162129,
*
* renderer: {
* antialias: true
* }
* }, {shadow: true})
* ]);
*/var RenderingModule=/*#__PURE__*/function(){/**
* additional
* @description collection of additional scripts
* @static
* @member {Object} module:core.App#additional
* @public
*/ /**
* enabled
* @static
* @member {Boolean} module:core.App#enabled
* @public
*/function RenderingModule(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var additional=arguments.length>1?arguments[1]:undefined;classCallCheck(this,RenderingModule);defineProperty$3(this,"enabled",true);this.params=Object.assign({width:window.innerWidth,height:window.innerHeight,resolution:new Vector2(1,1),pixelRatio:window.devicePixelRatio,bgColor:0x000000,bgOpacity:1,renderer:{},fix:function fix(){}},params);var _this$params=this.params,bgColor=_this$params.bgColor,bgOpacity=_this$params.bgOpacity,_renderer=_this$params.renderer,pixelRatio=_this$params.pixelRatio,width=_this$params.width,height=_this$params.height,resolution=_this$params.resolution,fix=_this$params.fix;this.renderer=new WebGLRenderer(_renderer);this.effects=[];this.renderer.setClearColor(bgColor,bgOpacity);if(pixelRatio)this.renderer.setPixelRatio(pixelRatio);this.setSize(Number(width*resolution.x).toFixed(),Number(height*resolution.y).toFixed());for(var key in additional){if(additional[key])this.applyAdditional(key);}fix(this.renderer);}/**
* @method applyAdditional
* @description Apply additional script from RenderingModule.additional
* @param {Stirng} name Script name
* @return {this}
* @memberof module:modules/app.RenderingModule
*/createClass(RenderingModule,[{key:"applyAdditional",value:function applyAdditional(name){RenderingModule.additional[name].apply(this,[this.renderer]);}/**
* @method integrateRenderer
* @description Integrate renderer
* @param {NodeElement} element DOM object
* @param {THREE.Scene} scene used scene
* @param {THREE.Camera} camera used camera
* @return {Loop} renderLoop
* @memberof module:modules/app.RenderingModule
*/},{key:"integrateRenderer",value:function integrateRenderer(element,scene,camera){var _this=this;this.scene=scene;this.camera=camera;this.attachToCanvas(element);return new Loop(function(){return _this.renderer.render(_this.scene,_this.camera);});}/**
* @method effect
* @description Add three.js effect
* @param {Object} effect three.js effect
* @param {function} effectLoop update function for effect
* @return {this}
* @memberof module:modules/app.RenderingModule
*/},{key:"effect",value:function effect(_effect){var _this2=this;var effectLoop=arguments.length>1&&arguments[1]!==undefined?arguments[1]:function(){_effect.render(_this2.scene,_this2.camera);};this.renderLoop.stop();var size=this.renderer.getSize();_effect.setSize(size.width,size.height);var loop=new Loop(effectLoop);this.effects.push(loop);if(this.enabled)loop.start(this.app);return this;}/**
* @method setSize
* @description Update render target width and height.
* @param {Number} width
* @param {Number} height
* @memberof module:modules/app.RenderingModule
*/},{key:"setSize",value:function setSize(width,height){if(this.renderer)this.renderer.setSize(width,height);}/**
* @method attachToCanvas
* @description Attach renderer.domElement to element
* @param {NodeElement} element DOM object
* @memberof module:modules/app.RenderingModule
*/},{key:"attachToCanvas",value:function attachToCanvas(element){var canvas=this.renderer.domElement;// attach to new parent world dom
element.appendChild(canvas);canvas.style.width='100%';canvas.style.height='100%';}/**
* @method stop
* @description Stops renderLoop and effect loops
* @memberof module:modules/app.RenderingModule
*/},{key:"stop",value:function stop(){this.enabled=false;this.renderLoop.stop();this.effects.forEach(function(loop){return loop.stop();});}/**
* @method play
* @description Resumes renderLoop and effect loops
* @memberof module:modules/app.RenderingModule
*/},{key:"play",value:function play(){this.enabled=true;this.renderLoop.start();this.effects.forEach(function(loop){return loop.start();});}},{key:"manager",value:function manager(_manager){var _this3=this;_manager.define('rendering');_manager.set('renderer',this.renderer);this.app=_manager.handler;this.renderLoop=this.integrateRenderer(_manager.get('element'),_manager.get('scene'),_manager.get('camera').native);_manager.update({element:function element(_element){_this3.attachToCanvas(_element);},scene:function scene(_scene){_this3.scene=_scene;},camera:function camera(_camera){_this3.camera=_camera.native;}});}},{key:"integrate",value:function integrate(self){var _this4=this;self.renderLoop.start(this);self.effects.forEach(function(loop){return loop.start(_this4);});}/**
* @method dispose
* @description Dispose rendering context
* @memberof module:modules/app.RenderingModule
*/},{key:"dispose",value:function dispose(){this.stop();this.renderer.forceContextLoss();}}]);return RenderingModule;}();defineProperty$3(RenderingModule,"additional",{shadow:function shadow(renderer){renderer.shadowMap.enabled=true;}});var SYMBOL_CHILDREN_FOR_SCENE=Symbol('SYMBOL_CHILDREN_FOR_SCENE');/**
* @class SceneModule
* @category modules/app
* @param {Boolean} [willSceneBeReplaced=false] willSceneBeReplaced should be true only if you are going to overwrite scene dependency even without the use of default one.
* @memberof module:modules/app
*/var SceneModule=/*#__PURE__*/function(){function SceneModule(){var willSceneBeReplaced=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;classCallCheck(this,SceneModule);this.scene=willSceneBeReplaced?null:new Scene();}createClass(SceneModule,[{key:"manager",value:function manager(_manager){_manager.set('scene',this.scene);}},{key:"integrate",value:function integrate(self){Object.assign(this,{add:function add(object){var _this=this;return asyncToGenerator(/*#__PURE__*/regenerator.mark(function _callee(){return regenerator.wrap(function _callee$(_context){while(1){switch(_context.prev=_context.next){case 0:if(!object.parent){_context.next=3;break;}_context.next=3;return object.parent.remove(object);case 3:_context.next=5;return object.wait();case 5:if(object.native){_context.next=7;break;}throw new CompositionError('SceneModule','there is no object.native',_this);case 7:object.parent=_this;_context.next=10;return _this.applyBridge({onAdd:object}).onAdd;case 10:self.scene.add(object.native);_this.children.push(object);return _context.abrupt("return",object);case 13:case"end":return _context.stop();}}},_callee,this);}))();},remove:function remove(object){var _this2=this;return asyncToGenerator(/*#__PURE__*/regenerator.mark(function _callee2(){return regenerator.wrap(function _callee2$(_context2){while(1){switch(_context2.prev=_context2.next){case 0:if(!(object.parent!==_this2)){_context2.next=2;break;}return _context2.abrupt("return");case 2:_context2.next=4;return object.wait();case 4:object.parent=null;self.scene.remove(object.native);_this2.children.splice(_this2.children.indexOf(object),1);case 7:case"end":return _context2.stop();}}},_callee2,this);}))();},_setScene:function _setScene(scene){this.children=scene[SYMBOL_CHILDREN_FOR_SCENE]=scene[SYMBOL_CHILDREN_FOR_SCENE]||[];self.scene=scene;},setScene:function setScene(scene){this._setScene(scene);this.manager.set('scene',scene);},getScene:function getScene(){return self.scene;}});if(self.scene)this._setScene(self.scene);}}]);return SceneModule;}();// import {addResizeListener} from 'detect-element-resize';
/**
* @class ResizeModule
* @category modules/app
* @param {Object} [params={auto: true}] - If auto is set to true - resize will be triggered when container resizes
* @memberof module:modules/app
*/var ResizeModule=/*#__PURE__*/function(){function ResizeModule(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,ResizeModule);this.params=Object.assign({auto:true},params);this.callbacks=[this.setSize.bind(this)];}/**
* @function setSize
* @instance
* @description This function sets the provided width & height to the renderer object.
* @param {Number} [width=1] - The promise that should be added to a queue.
* @param {Number} [height=1] - that is resolved when all promises completed.
* @memberof module:modules/app.ResizeModule
*/createClass(ResizeModule,[{key:"setSize",value:function setSize(){var width=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1;var height=arguments.length>1&&arguments[1]!==undefined?arguments[1]:1;this.camera.native.aspect=width/height;this.camera.native.updateProjectionMatrix();if(this.rendering)this.rendering.setSize(width,height);}/**
* @method trigger
* @instance
* @description Triggers resize when called. width & height are determined automatically
* This invokes each callbacks with the new width and height as params
* @memberof module:modules/app.ResizeModule
*/},{key:"trigger",value:function trigger(){var _this$container=this.container,offsetWidth=_this$container.offsetWidth,offsetHeight=_this$container.offsetHeight,resolution=this.resolution;var width=Number(offsetWidth*resolution.x).toFixed();var height=Number(offsetHeight*resolution.y).toFixed();this.callbacks.forEach(function(cb){cb(width,height);});}/**
* @method addAutoresize
* @instance
* @description Sets module to autoresize, this adds an event listene on window resize to trigger the resize
* @memberof module:modules/app.ResizeModule
*/},{key:"addAutoresize",value:function addAutoresize(){this.container=this.getContainer();this.resolution=this.getResolution();if(this.params.auto)window.addEventListener('resize',this.trigger.bind(this));}/**
* @method addCallback
* @instance
* @description Adds a call back function to the existing callbacks list.
* @param {Function} func - The callback function to add
* @memberof module:modules/app.ResizeModule
*/},{key:"addCallback",value:function addCallback(func){this.callbacks.push(func);}},{key:"manager",value:function manager(_manager){var _this=this;_manager.define('resize');this.rendering=_manager.get('renderer');this.camera=_manager.get('camera');this.getResolution=function(){return _manager.use('rendering').params.resolution;};this.getContainer=function(){return _manager.get('container');};_manager.update({container:function container(_container){_this.container=_container;}});this.addAutoresize();}}]);return ResizeModule;}();var fragment="uniform sampler2D tPreviousLum;\r\nuniform sampler2D tCurrentLum;\r\nuniform float minLuminance;\r\nuniform float delta;\r\nuniform float tau;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tfloat previousLum = texture2D(tPreviousLum, vUv, MIP_LEVEL_1X1).r;\r\n\tfloat currentLum = texture2D(tCurrentLum, vUv, MIP_LEVEL_1X1).r;\r\n\r\n\tpreviousLum = max(minLuminance, previousLum);\r\n\tcurrentLum = max(minLuminance, currentLum);\r\n\r\n\t// Adapt the luminance using Pattanaik's technique.\r\n\tfloat adaptedLum = previousLum + (currentLum - previousLum) * (1.0 - exp(-delta * tau));\r\n\r\n\tgl_FragColor.r = adaptedLum;\r\n\r\n}\r\n";var vertex="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* An adaptive luminosity shader material.
*/var AdaptiveLuminosityMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new adaptive luminosity material.
*/function AdaptiveLuminosityMaterial(){classCallCheck(this,AdaptiveLuminosityMaterial);return possibleConstructorReturn(this,getPrototypeOf$2(AdaptiveLuminosityMaterial).call(this,{type:"AdaptiveLuminosityMaterial",defines:{MIP_LEVEL_1X1:"0.0"},uniforms:{tPreviousLum:new Uniform(null),tCurrentLum:new Uniform(null),minLuminance:new Uniform(0.01),delta:new Uniform(0.0),tau:new Uniform(1.0)},fragmentShader:fragment,vertexShader:vertex,depthWrite:false,depthTest:false}));}inherits(AdaptiveLuminosityMaterial,_ShaderMaterial);return AdaptiveLuminosityMaterial;}(ShaderMaterial);var fragment$1="uniform sampler2D tDiffuse;\r\nuniform sampler2D tDepth;\r\n\r\nuniform float focus;\r\nuniform float dof;\r\nuniform float aspect;\r\nuniform float aperture;\r\nuniform float maxBlur;\r\n\r\nvarying vec2 vUv;\r\n\r\n#ifndef USE_LOGDEPTHBUF\r\n\r\n\t#include <packing>\r\n\r\n\tuniform float cameraNear;\r\n\tuniform float cameraFar;\r\n\r\n\tfloat readDepth(sampler2D depthSampler, vec2 coord) {\r\n\r\n\t\tfloat fragCoordZ = texture2D(depthSampler, coord).x;\r\n\t\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\r\n\r\n\t\treturn viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\nvoid main() {\r\n\r\n\tvec2 aspectCorrection = vec2(1.0, aspect);\r\n\r\n\t#ifdef USE_LOGDEPTHBUF\r\n\r\n\t\tfloat depth = texture2D(tDepth, vUv).x;\r\n\r\n\t#else\r\n\r\n\t\tfloat depth = readDepth(tDepth, vUv);\r\n\r\n\t#endif\r\n\r\n\tfloat focusNear = clamp(focus - dof, 0.0, 1.0);\r\n\tfloat focusFar = clamp(focus + dof, 0.0, 1.0);\r\n\r\n\t// Calculate a DoF mask.\r\n\tfloat low = step(depth, focusNear);\r\n\tfloat high = step(focusFar, depth);\r\n\r\n\tfloat factor = (depth - focusNear) * low + (depth - focusFar) * high;\r\n\r\n\tvec2 dofBlur = vec2(clamp(factor * aperture, -maxBlur, maxBlur));\r\n\r\n\tvec2 dofblur9 = dofBlur * 0.9;\r\n\tvec2 dofblur7 = dofBlur * 0.7;\r\n\tvec2 dofblur4 = dofBlur * 0.4;\r\n\r\n\tvec4 color = vec4(0.0);\r\n\r\n\tcolor += texture2D(tDiffuse, vUv);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0, 0.4 ) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.15, 0.37) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29, 0.29) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.37, 0.15) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.40, 0.0 ) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.37, -0.15) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29, -0.29) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.15, -0.37) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0, -0.4 ) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.15, 0.37) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29, 0.29) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.37, 0.15) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.4, 0.0 ) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.37, -0.15) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29, -0.29) * aspectCorrection) * dofBlur);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.15, -0.37) * aspectCorrection) * dofBlur);\r\n\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.15, 0.37) * aspectCorrection) * dofblur9);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.37, 0.15) * aspectCorrection) * dofblur9);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.37, -0.15) * aspectCorrection) * dofblur9);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.15, -0.37) * aspectCorrection) * dofblur9);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.15, 0.37) * aspectCorrection) * dofblur9);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.37, 0.15) * aspectCorrection) * dofblur9);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.37, -0.15) * aspectCorrection) * dofblur9);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.15, -0.37) * aspectCorrection) * dofblur9);\r\n\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29, 0.29) * aspectCorrection) * dofblur7);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.40, 0.0 ) * aspectCorrection) * dofblur7);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29, -0.29) * aspectCorrection) * dofblur7);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0, -0.4 ) * aspectCorrection) * dofblur7);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29, 0.29) * aspectCorrection) * dofblur7);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.4, 0.0 ) * aspectCorrection) * dofblur7);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29, -0.29) * aspectCorrection) * dofblur7);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0, 0.4 ) * aspectCorrection) * dofblur7);\r\n\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29, 0.29) * aspectCorrection) * dofblur4);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.4, 0.0 ) * aspectCorrection) * dofblur4);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29, -0.29) * aspectCorrection) * dofblur4);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0, -0.4 ) * aspectCorrection) * dofblur4);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29, 0.29) * aspectCorrection) * dofblur4);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.4, 0.0 ) * aspectCorrection) * dofblur4);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29, -0.29) * aspectCorrection) * dofblur4);\r\n\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0, 0.4 ) * aspectCorrection) * dofblur4);\r\n\r\n\tgl_FragColor = color / 41.0;\r\n\r\n}\r\n";var vertex$1="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* Depth of Field shader (Bokeh).
*
* Original shader code by Martins Upitis:
* http://artmartinsh.blogspot.com/2010/02/glsl-lens-blur-filter-with-bokeh.html
*/var BokehMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new bokeh material.
*
* @param {PerspectiveCamera} [camera] - A camera.
* @param {Object} [options] - The options.
* @param {Number} [options.focus=1.0] - The focus distance, corresponds directly with the scene depth.
* @param {Number} [options.dof=0.02] - Depth of field. An area in front of and behind the focus point that still appears sharp.
* @param {Number} [options.aperture=0.025] - Camera aperture scale. Bigger values for stronger blur and shallower depth of field.
* @param {Number} [options.maxBlur=1.0] - Maximum blur strength.
*/function BokehMaterial(camera){var _this;var options=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};classCallCheck(this,BokehMaterial);var settings=Object.assign({focus:1.0,dof:0.02,aperture:0.025,maxBlur:1.0},options);_this=possibleConstructorReturn(this,getPrototypeOf$2(BokehMaterial).call(this,{type:"BokehMaterial",uniforms:{cameraNear:new Uniform(0.1),cameraFar:new Uniform(2000),aspect:new Uniform(1.0),tDiffuse:new Uniform(null),tDepth:new Uniform(null),focus:new Uniform(settings.focus),dof:new Uniform(settings.dof),aperture:new Uniform(settings.aperture),maxBlur:new Uniform(settings.maxBlur)},fragmentShader:fragment$1,vertexShader:vertex$1,depthWrite:false,depthTest:false}));_this.adoptCameraSettings(camera);return _this;}/**
* Adopts the settings of the given camera.
*
* @param {PerspectiveCamera} [camera=null] - A camera.
*/createClass(BokehMaterial,[{key:"adoptCameraSettings",value:function adoptCameraSettings(){var camera=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(camera!==null){this.uniforms.cameraNear.value=camera.near;this.uniforms.cameraFar.value=camera.far;this.uniforms.aspect.value=camera.aspect;}}}]);inherits(BokehMaterial,_ShaderMaterial);return BokehMaterial;}(ShaderMaterial);var fragment$2="uniform sampler2D tDiffuse;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\n\r\nvoid main() {\r\n\r\n\tconst vec2 threshold = vec2(EDGE_THRESHOLD);\r\n\r\n\t// Calculate color deltas.\r\n\tvec4 delta;\r\n\tvec3 c = texture2D(tDiffuse, vUv).rgb;\r\n\r\n\tvec3 cLeft = texture2D(tDiffuse, vOffset[0].xy).rgb;\r\n\tvec3 t = abs(c - cLeft);\r\n\tdelta.x = max(max(t.r, t.g), t.b);\r\n\r\n\tvec3 cTop = texture2D(tDiffuse, vOffset[0].zw).rgb;\r\n\tt = abs(c - cTop);\r\n\tdelta.y = max(max(t.r, t.g), t.b);\r\n\r\n\t// We do the usual threshold.\r\n\tvec2 edges = step(threshold, delta.xy);\r\n\r\n\t// Then discard if there is no edge.\r\n\tif(dot(edges, vec2(1.0)) == 0.0) {\r\n\r\n\t\tdiscard;\r\n\r\n\t}\r\n\r\n\t// Calculate right and bottom deltas.\r\n\tvec3 cRight = texture2D(tDiffuse, vOffset[1].xy).rgb;\r\n\tt = abs(c - cRight);\r\n\tdelta.z = max(max(t.r, t.g), t.b);\r\n\r\n\tvec3 cBottom = texture2D(tDiffuse, vOffset[1].zw).rgb;\r\n\tt = abs(c - cBottom);\r\n\tdelta.w = max(max(t.r, t.g), t.b);\r\n\r\n\t// Calculate the maximum delta in the direct neighborhood.\r\n\tfloat maxDelta = max(max(max(delta.x, delta.y), delta.z), delta.w);\r\n\r\n\t// Calculate left-left and top-top deltas.\r\n\tvec3 cLeftLeft = texture2D(tDiffuse, vOffset[2].xy).rgb;\r\n\tt = abs(c - cLeftLeft);\r\n\tdelta.z = max(max(t.r, t.g), t.b);\r\n\r\n\tvec3 cTopTop = texture2D(tDiffuse, vOffset[2].zw).rgb;\r\n\tt = abs(c - cTopTop);\r\n\tdelta.w = max(max(t.r, t.g), t.b);\r\n\r\n\t// Calculate the final maximum delta.\r\n\tmaxDelta = max(max(maxDelta, delta.z), delta.w);\r\n\r\n\t// Local contrast adaptation in action.\r\n\tedges.xy *= step(0.5 * maxDelta, delta.xy);\r\n\r\n\tgl_FragColor = vec4(edges, 0.0, 0.0);\r\n\r\n}\r\n";var vertex$2="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\r\n\tvOffset[0] = uv.xyxy + texelSize.xyxy * vec4(-1.0, 0.0, 0.0, 1.0); // Changed sign in W component.\r\n\tvOffset[1] = uv.xyxy + texelSize.xyxy * vec4(1.0, 0.0, 0.0, -1.0); // Changed sign in W component.\r\n\tvOffset[2] = uv.xyxy + texelSize.xyxy * vec4(-2.0, 0.0, 0.0, 2.0); // Changed sign in W component.\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A material that detects edges in a color texture.
*
* Mainly used for Subpixel Morphological Antialiasing.
*/var ColorEdgesMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new color edges material.
*
* @param {Vector2} [texelSize] - The absolute screen texel size.
*/function ColorEdgesMaterial(){var texelSize=arguments.length>0&&arguments[0]!==undefined?arguments[0]:new Vector2();classCallCheck(this,ColorEdgesMaterial);return possibleConstructorReturn(this,getPrototypeOf$2(ColorEdgesMaterial).call(this,{type:"ColorEdgesMaterial",defines:{EDGE_THRESHOLD:"0.1"},uniforms:{tDiffuse:new Uniform(null),texelSize:new Uniform(texelSize)},fragmentShader:fragment$2,vertexShader:vertex$2,depthWrite:false,depthTest:false}));}/**
* Sets the edge detection sensitivity.
*
* A lower value results in more edges being detected at the expense of
* performance.
*
* 0.1 is a reasonable value, and allows to catch most visible edges.
* 0.05 is a rather overkill value, that allows to catch 'em all.
*
* If temporal supersampling is used, 0.2 could be a reasonable value,
* as low contrast edges are properly filtered by just 2x.
*
* @param {Number} threshold - The edge detection sensitivity. Range: [0, 0.5].
*/createClass(ColorEdgesMaterial,[{key:"setEdgeDetectionThreshold",value:function setEdgeDetectionThreshold(threshold){this.defines.EDGE_THRESHOLD=threshold.toFixed("2");this.needsUpdate=true;}}]);inherits(ColorEdgesMaterial,_ShaderMaterial);return ColorEdgesMaterial;}(ShaderMaterial);var fragment$3="uniform sampler2D texture1;\r\nuniform sampler2D texture2;\r\n\r\nuniform float opacity1;\r\nuniform float opacity2;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel1 = opacity1 * texture2D(texture1, vUv);\r\n\tvec4 texel2 = opacity2 * texture2D(texture2, vUv);\r\n\r\n\t#ifdef SCREEN_MODE\r\n\r\n\t\tvec3 invTexel1 = vec3(1.0) - texel1.rgb;\r\n\t\tvec3 invTexel2 = vec3(1.0) - texel2.rgb;\r\n\r\n\t\tvec4 color = vec4(\r\n\t\t\tvec3(1.0) - invTexel1 * invTexel2,\r\n\t\t\ttexel1.a + texel2.a\r\n\t\t);\r\n\r\n\t#else\r\n\r\n\t\tvec4 color = texel1 + texel2;\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n";var vertex$3="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A material for combining two textures.
*
* This material supports the two blend modes Add and Screen.
*
* In Screen mode, the two textures are effectively projected on a white screen
* simultaneously. In Add mode, the textures are simply added together which
* often produces undesired, washed out results.
*/var CombineMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new combine material.
*
* @param {Boolean} [screenMode=false] - Whether the screen blend mode should be used.
*/function CombineMaterial(){var _this;var screenMode=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;classCallCheck(this,CombineMaterial);_this=possibleConstructorReturn(this,getPrototypeOf$2(CombineMaterial).call(this,{type:"CombineMaterial",uniforms:{texture1:new Uniform(null),texture2:new Uniform(null),opacity1:new Uniform(1.0),opacity2:new Uniform(1.0)},fragmentShader:fragment$3,vertexShader:vertex$3,depthWrite:false,depthTest:false}));_this.setScreenModeEnabled(screenMode);return _this;}/**
* Enables or disables the Screen blend mode.
*
* @param {Boolean} enabled - Whether the Screen blend mode should be enabled.
*/createClass(CombineMaterial,[{key:"setScreenModeEnabled",value:function setScreenModeEnabled(enabled){if(enabled){this.defines.SCREEN_MODE="1";}else{delete this.defines.SCREEN_MODE;}this.needsUpdate=true;}}]);inherits(CombineMaterial,_ShaderMaterial);return CombineMaterial;}(ShaderMaterial);var fragment$4="#include <common>\r\n#include <dithering_pars_fragment>\r\n\r\nuniform sampler2D tDiffuse;\r\n\r\nvarying vec2 vUv0;\r\nvarying vec2 vUv1;\r\nvarying vec2 vUv2;\r\nvarying vec2 vUv3;\r\n\r\nvoid main() {\r\n\r\n\t// Sample top left texel.\r\n\tvec4 sum = texture2D(tDiffuse, vUv0);\r\n\r\n\t// Sample top right texel.\r\n\tsum += texture2D(tDiffuse, vUv1);\r\n\r\n\t// Sample bottom right texel.\r\n\tsum += texture2D(tDiffuse, vUv2);\r\n\r\n\t// Sample bottom left texel.\r\n\tsum += texture2D(tDiffuse, vUv3);\r\n\r\n\t// Compute the average.\r\n\tgl_FragColor = sum * 0.25;\r\n\r\n\t#include <dithering_fragment>\r\n\r\n}\r\n";var vertex$4="uniform vec2 texelSize;\r\nuniform vec2 halfTexelSize;\r\nuniform float kernel;\r\n\r\nvarying vec2 vUv0;\r\nvarying vec2 vUv1;\r\nvarying vec2 vUv2;\r\nvarying vec2 vUv3;\r\n\r\nvoid main() {\r\n\r\n\tvec2 dUv = (texelSize * vec2(kernel)) + halfTexelSize;\r\n\r\n\tvUv0 = vec2(uv.x - dUv.x, uv.y + dUv.y);\r\n\tvUv1 = vec2(uv.x + dUv.x, uv.y + dUv.y);\r\n\tvUv2 = vec2(uv.x + dUv.x, uv.y - dUv.y);\r\n\tvUv3 = vec2(uv.x - dUv.x, uv.y - dUv.y);\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* An optimised convolution shader material.
*
* This material supports dithering.
*
* Based on the GDC2003 Presentation by Masaki Kawase, Bunkasha Games:
* Frame Buffer Postprocessing Effects in DOUBLE-S.T.E.A.L (Wreckless)
* and an article by Filip Strugar, Intel:
* An investigation of fast real-time GPU-based image blur algorithms
*
* Further modified according to Apple's
* [Best Practices for Shaders](https://goo.gl/lmRoM5).
*/var ConvolutionMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new convolution material.
*
* @param {Vector2} [texelSize] - The absolute screen texel size.
*/function ConvolutionMaterial(){var _this;var texelSize=arguments.length>0&&arguments[0]!==undefined?arguments[0]:new Vector2();classCallCheck(this,ConvolutionMaterial);_this=possibleConstructorReturn(this,getPrototypeOf$2(ConvolutionMaterial).call(this,{type:"ConvolutionMaterial",uniforms:{tDiffuse:new Uniform(null),texelSize:new Uniform(new Vector2()),halfTexelSize:new Uniform(new Vector2()),kernel:new Uniform(0.0)},fragmentShader:fragment$4,vertexShader:vertex$4,depthWrite:false,depthTest:false}));_this.setTexelSize(texelSize.x,texelSize.y);/**
* The current kernel size.
*
* @type {KernelSize}
* @default KernelSize.LARGE
*/_this.kernelSize=KernelSize.LARGE;return _this;}/**
* Returns the kernel.
*
* @return {Float32Array} The kernel.
*/createClass(ConvolutionMaterial,[{key:"getKernel",value:function getKernel(){return kernelPresets[this.kernelSize];}/**
* Sets the texel size.
*
* @param {Number} x - The texel width.
* @param {Number} y - The texel height.
*/},{key:"setTexelSize",value:function setTexelSize(x,y){this.uniforms.texelSize.value.set(x,y);this.uniforms.halfTexelSize.value.set(x,y).multiplyScalar(0.5);}}]);inherits(ConvolutionMaterial,_ShaderMaterial);return ConvolutionMaterial;}(ShaderMaterial);/**
* The Kawase blur kernel presets.
*
* @type {Float32Array[]}
* @private
*/var kernelPresets=[new Float32Array([0.0,0.0]),new Float32Array([0.0,1.0,1.0]),new Float32Array([0.0,1.0,1.0,2.0]),new Float32Array([0.0,1.0,2.0,2.0,3.0]),new Float32Array([0.0,1.0,2.0,3.0,4.0,4.0,5.0]),new Float32Array([0.0,1.0,2.0,3.0,4.0,5.0,7.0,8.0,9.0,10.0])];/**
* A kernel size enumeration.
*
* @type {Object}
* @property {Number} VERY_SMALL - A very small kernel that matches a 7x7 Gauss blur kernel.
* @property {Number} SMALL - A small kernel that matches a 15x15 Gauss blur kernel.
* @property {Number} MEDIUM - A medium sized kernel that matches a 23x23 Gauss blur kernel.
* @property {Number} LARGE - A large kernel that matches a 35x35 Gauss blur kernel.
* @property {Number} VERY_LARGE - A very large kernel that matches a 63x63 Gauss blur kernel.
* @property {Number} HUGE - A huge kernel that matches a 127x127 Gauss blur kernel.
*/var KernelSize={VERY_SMALL:0,SMALL:1,MEDIUM:2,LARGE:3,VERY_LARGE:4,HUGE:5};var fragment$5="uniform sampler2D tDiffuse;\r\nuniform float opacity;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tgl_FragColor = opacity * texel;\r\n\r\n}\r\n";var vertex$5="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A simple copy shader material.
*/var CopyMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new copy material.
*/function CopyMaterial(){classCallCheck(this,CopyMaterial);return possibleConstructorReturn(this,getPrototypeOf$2(CopyMaterial).call(this,{type:"CopyMaterial",uniforms:{tDiffuse:new Uniform(null),opacity:new Uniform(1.0)},fragmentShader:fragment$5,vertexShader:vertex$5,depthWrite:false,depthTest:false}));}inherits(CopyMaterial,_ShaderMaterial);return CopyMaterial;}(ShaderMaterial);var fragment$6="#include <packing>\r\n#include <clipping_planes_pars_fragment>\r\n\r\nuniform sampler2D tDepth;\r\nuniform float cameraNear;\r\nuniform float cameraFar;\r\n\r\nvarying float vViewZ;\r\nvarying vec4 vProjTexCoord;\r\n\r\nvoid main() {\r\n\r\n\t#include <clipping_planes_fragment>\r\n\r\n\t// Transform into Cartesian coordinate (not mirrored).\r\n\tvec2 projTexCoord = (vProjTexCoord.xy / vProjTexCoord.w) * 0.5 + 0.5;\r\n\tprojTexCoord = clamp(projTexCoord, 0.002, 0.998);\r\n\r\n\tfloat fragCoordZ = unpackRGBAToDepth(texture2D(tDepth, projTexCoord));\r\n\r\n\t#ifdef PERSPECTIVE_CAMERA\r\n\r\n\t\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\r\n\r\n\t#else\r\n\r\n\t\tfloat viewZ = orthographicDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\r\n\r\n\t#endif\r\n\r\n\tfloat depthTest = (-vViewZ > -viewZ) ? 1.0 : 0.0;\r\n\r\n\tgl_FragColor.rgb = vec3(0.0, depthTest, 1.0);\r\n\r\n}\r\n";var vertex$6="#include <common>\r\n#include <morphtarget_pars_vertex>\r\n#include <skinning_pars_vertex>\r\n#include <clipping_planes_pars_vertex>\r\n\r\nvarying float vViewZ;\r\nvarying vec4 vProjTexCoord;\r\n\r\nvoid main() {\r\n\r\n\t#include <skinbase_vertex>\r\n\r\n\t#include <begin_vertex>\r\n\t#include <morphtarget_vertex>\r\n\t#include <skinning_vertex>\r\n\t#include <project_vertex>\r\n\r\n\tvViewZ = mvPosition.z;\r\n\tvProjTexCoord = gl_Position;\r\n\r\n\t#include <clipping_planes_vertex>\r\n\r\n}\r\n";/**
* A depth comparison shader material.
*/var DepthComparisonMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new depth comparison material.
*
* @param {Texture} [depthTexture=null] - A depth texture.
* @param {PerspectiveCamera} [camera] - A camera.
*/function DepthComparisonMaterial(){var _this;var depthTexture=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;var camera=arguments.length>1?arguments[1]:undefined;classCallCheck(this,DepthComparisonMaterial);_this=possibleConstructorReturn(this,getPrototypeOf$2(DepthComparisonMaterial).call(this,{type:"DepthComparisonMaterial",uniforms:{tDepth:new Uniform(depthTexture),cameraNear:new Uniform(0.1),cameraFar:new Uniform(2000)},fragmentShader:fragment$6,vertexShader:vertex$6,depthWrite:false,depthTest:false,morphTargets:true,skinning:true}));_this.adoptCameraSettings(camera);return _this;}/**
* Adopts the settings of the given camera.
*
* @param {Camera} [camera=null] - A camera.
*/createClass(DepthComparisonMaterial,[{key:"adoptCameraSettings",value:function adoptCameraSettings(){var camera=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(camera!==null){this.uniforms.cameraNear.value=camera.near;this.uniforms.cameraFar.value=camera.far;if(camera instanceof PerspectiveCamera){this.defines.PERSPECTIVE_CAMERA="1";}else{delete this.defines.PERSPECTIVE_CAMERA;}}}}]);inherits(DepthComparisonMaterial,_ShaderMaterial);return DepthComparisonMaterial;}(ShaderMaterial);var fragment$7="uniform sampler2D tDiffuse;\r\n\r\nuniform float angle;\r\nuniform float scale;\r\nuniform float intensity;\r\n\r\nvarying vec2 vUv;\r\nvarying vec2 vUvPattern;\r\n\r\nfloat pattern() {\r\n\r\n\tfloat s = sin(angle);\r\n\tfloat c = cos(angle);\r\n\r\n\tvec2 point = vec2(c * vUvPattern.x - s * vUvPattern.y, s * vUvPattern.x + c * vUvPattern.y) * scale;\r\n\r\n\treturn (sin(point.x) * sin(point.y)) * 4.0;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tvec3 color = texel.rgb;\r\n\r\n\t#ifdef AVERAGE\r\n\r\n\t\tcolor = vec3((color.r + color.g + color.b) / 3.0);\r\n\r\n\t#endif\r\n\r\n\tcolor = vec3(color * 10.0 - 5.0 + pattern());\r\n\tcolor = texel.rgb + (color - texel.rgb) * intensity;\r\n\r\n\tgl_FragColor = vec4(color, texel.a);\r\n\r\n}\r\n";var vertex$7="uniform vec4 offsetRepeat;\r\n\r\nvarying vec2 vUv;\r\nvarying vec2 vUvPattern;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tvUvPattern = uv * offsetRepeat.zw + offsetRepeat.xy;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A dot screen shader material.
*/var DotScreenMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new dot screen material.
*
* @param {Boolean} [options] - The options.
* @param {Boolean} [options.average=false] - Whether the shader should output the colour average (black and white).
* @param {Boolean} [options.angle=1.57] - The angle of the dot pattern.
* @param {Boolean} [options.scale=1.0] - The scale of the dot pattern.
* @param {Boolean} [options.intensity=1.0] - The intensity of the effect.
*/function DotScreenMaterial(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,DotScreenMaterial);var settings=Object.assign({average:false,angle:1.57,scale:1.0,intensity:1.0},options);_this=possibleConstructorReturn(this,getPrototypeOf$2(DotScreenMaterial).call(this,{type:"DotScreenMaterial",uniforms:{tDiffuse:new Uniform(null),angle:new Uniform(settings.angle),scale:new Uniform(settings.scale),intensity:new Uniform(settings.intensity),offsetRepeat:new Uniform(new Vector4(0.5,0.5,1.0,1.0))},fragmentShader:fragment$7,vertexShader:vertex$7,depthWrite:false,depthTest:false}));_this.setAverageEnabled(settings.average);return _this;}/**
* Enables or disables the Screen blend mode.
*
* @param {Boolean} enabled - Whether the Screen blend mode should be enabled.
*/createClass(DotScreenMaterial,[{key:"setAverageEnabled",value:function setAverageEnabled(enabled){if(enabled){this.defines.AVERAGE="1";}else{delete this.defines.AVERAGE;}this.needsUpdate=true;}}]);inherits(DotScreenMaterial,_ShaderMaterial);return DotScreenMaterial;}(ShaderMaterial);var fragment$8="uniform sampler2D tDiffuse;\r\nuniform float time;\r\n\r\nvarying vec2 vUv;\r\n\r\n#ifdef NOISE\r\n\r\n\tuniform float noiseIntensity;\r\n\r\n#endif\r\n\r\n#ifdef SCANLINES\r\n\r\n\tuniform float scanlineIntensity;\r\n\tuniform float scanlineCount;\r\n\r\n#endif\r\n\r\n#ifdef GRID\r\n\r\n\tuniform float gridIntensity;\r\n\tuniform vec2 gridScale;\r\n\tuniform float gridLineWidth;\r\n\r\n#endif\r\n\r\n#ifdef GREYSCALE\r\n\r\n\t#include <common>\r\n\r\n\tuniform float greyscaleIntensity;\r\n\r\n#elif defined(SEPIA)\r\n\r\n\tuniform float sepiaIntensity;\r\n\r\n#endif\r\n\r\n#ifdef VIGNETTE\r\n\r\n\tuniform float vignetteOffset;\r\n\tuniform float vignetteDarkness;\r\n\r\n#endif\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tvec3 color = texel.rgb;\r\n\r\n\t#ifdef SCREEN_MODE\r\n\r\n\t\tvec3 invColor;\r\n\r\n\t#endif\r\n\r\n\t#ifdef NOISE\r\n\r\n\t\tfloat x = vUv.x * vUv.y * time * 1000.0;\r\n\t\tx = mod(x, 13.0) * mod(x, 123.0);\r\n\t\tx = mod(x, 0.01);\r\n\r\n\t\tvec3 noise = texel.rgb * clamp(0.1 + x * 100.0, 0.0, 1.0) * noiseIntensity;\r\n\r\n\t\t#ifdef SCREEN_MODE\r\n\r\n\t\t\tinvColor = vec3(1.0) - color;\r\n\t\t\tvec3 invNoise = vec3(1.0) - noise;\r\n\r\n\t\t\tcolor = vec3(1.0) - invColor * invNoise;\r\n\r\n\t\t#else\r\n\r\n\t\t\tcolor += noise;\r\n\r\n\t\t#endif\r\n\r\n\t#endif\r\n\r\n\t#ifdef SCANLINES\r\n\r\n\t\tvec2 sl = vec2(sin(vUv.y * scanlineCount), cos(vUv.y * scanlineCount));\r\n\t\tvec3 scanlines = texel.rgb * vec3(sl.x, sl.y, sl.x) * scanlineIntensity;\r\n\r\n\t\t#ifdef SCREEN_MODE\r\n\r\n\t\t\tinvColor = vec3(1.0) - color;\r\n\t\t\tvec3 invScanlines = vec3(1.0) - scanlines;\r\n\r\n\t\t\tcolor = vec3(1.0) - invColor * invScanlines;\r\n\r\n\t\t#else\r\n\r\n\t\t\tcolor += scanlines;\r\n\r\n\t\t#endif\r\n\r\n\t#endif\r\n\r\n\t#ifdef GRID\r\n\r\n\t\tfloat grid = 0.5 - max(abs(mod(vUv.x * gridScale.x, 1.0) - 0.5), abs(mod(vUv.y * gridScale.y, 1.0) - 0.5));\r\n\t\tcolor *= (1.0 - gridIntensity) + vec3(smoothstep(0.0, gridLineWidth, grid)) * gridIntensity;\r\n\r\n\t#endif\r\n\r\n\t#ifdef GREYSCALE\r\n\r\n\t\tcolor = mix(color, vec3(linearToRelativeLuminance(color)), greyscaleIntensity);\r\n\r\n\t#elif defined(SEPIA)\r\n\r\n\t\tvec3 c = color.rgb;\r\n\r\n\t\tcolor.r = dot(c, vec3(1.0 - 0.607 * sepiaIntensity, 0.769 * sepiaIntensity, 0.189 * sepiaIntensity));\r\n\t\tcolor.g = dot(c, vec3(0.349 * sepiaIntensity, 1.0 - 0.314 * sepiaIntensity, 0.168 * sepiaIntensity));\r\n\t\tcolor.b = dot(c, vec3(0.272 * sepiaIntensity, 0.534 * sepiaIntensity, 1.0 - 0.869 * sepiaIntensity));\r\n\r\n\t#endif\r\n\r\n\t#ifdef VIGNETTE\r\n\r\n\t\tconst vec2 center = vec2(0.5);\r\n\r\n\t\t#ifdef ESKIL\r\n\r\n\t\t\tvec2 uv = (vUv - center) * vec2(vignetteOffset);\r\n\t\t\tcolor = mix(color.rgb, vec3(1.0 - vignetteDarkness), dot(uv, uv));\r\n\r\n\t\t#else\r\n\r\n\t\t\tfloat dist = distance(vUv, center);\r\n\t\t\tcolor *= smoothstep(0.8, vignetteOffset * 0.799, dist * (vignetteDarkness + vignetteOffset));\r\n\r\n\t\t#endif\t\t\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = vec4(clamp(color, 0.0, 1.0), texel.a);\r\n\r\n}\r\n";var vertex$8="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A cinematic shader that provides the following effects:
* - Film Grain
* - Scanlines
* - Vignette
* - Greyscale
* - Sepia
*
* Original scanlines algorithm by Pat "Hawthorne" Shearon.
* http://www.truevision3d.com/forums/showcase/staticnoise_colorblackwhite_scanline_shaders-t18698.0.html
*
* Optimised scanlines and noise with intensity scaling by Georg "Leviathan"
* Steinrohder. This version was provided under a Creative Commons Attribution
* 3.0 License: http://creativecommons.org/licenses/by/3.0.
*
* The sepia effect is based on:
* https://github.com/evanw/glfx.js
*
* The vignette code is based on PaintEffect postprocess from ro.me:
* http://code.google.com/p/3-dreams-of-black/source/browse/deploy/js/effects/PaintEffect.js
*/var FilmMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new film material.
*
* @param {Object} [options] - The options. Disabled effects will not be included in the final shader and have no negative impact on performance.
* @param {Boolean} [options.greyscale=false] - Enable greyscale effect. Greyscale and sepia are mutually exclusive.
* @param {Boolean} [options.sepia=false] - Enable sepia effect. Greyscale and sepia are mutually exclusive.
* @param {Boolean} [options.vignette=false] - Apply vignette effect.
* @param {Boolean} [options.eskil=false] - Use Eskil's vignette approach. The default looks dusty while Eskil looks burned out.
* @param {Boolean} [options.screenMode=true] - Whether the screen blend mode should be used for noise and scanlines. Both of these effects are computed independently.
* @param {Boolean} [options.noise=true] - Show noise-based film grain.
* @param {Boolean} [options.scanlines=true] - Show scanlines.
* @param {Boolean} [options.grid=true] - Show a grid.
* @param {Number} [options.noiseIntensity=0.5] - The noise intensity.
* @param {Number} [options.scanlineIntensity=0.05] - The scanline intensity.
* @param {Number} [options.gridIntensity=1.0] - The grid strength. 0.0 to 1.0.
* @param {Number} [options.greyscaleIntensity=1.0] - The intensity of the greyscale effect. 0.0 to 1.0.
* @param {Number} [options.sepiaIntensity=1.0] - The intensity of the sepia effect. 0.0 to 1.0.
* @param {Number} [options.vignetteOffset=1.0] - The offset of the vignette effect. 0.0 to 1.0.
* @param {Number} [options.vignetteDarkness=1.0] - The darkness of the vignette effect. 0.0 to 1.0.
*/function FilmMaterial(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,FilmMaterial);var settings=Object.assign({screenMode:true,noise:true,scanlines:true,grid:false,greyscale:false,sepia:false,vignette:false,eskil:false,noiseIntensity:0.5,scanlineIntensity:0.05,gridIntensity:1.0,greyscaleIntensity:1.0,sepiaIntensity:1.0,vignetteOffset:1.0,vignetteDarkness:1.0},options);_this=possibleConstructorReturn(this,getPrototypeOf$2(FilmMaterial).call(this,{type:"FilmMaterial",uniforms:{tDiffuse:new Uniform(null),time:new Uniform(0.0),noiseIntensity:new Uniform(settings.noiseIntensity),scanlineIntensity:new Uniform(settings.scanlineIntensity),gridIntensity:new Uniform(settings.gridIntensity),scanlineCount:new Uniform(0.0),gridScale:new Uniform(new Vector2()),gridLineWidth:new Uniform(0.0),greyscaleIntensity:new Uniform(settings.greyscaleIntensity),sepiaIntensity:new Uniform(settings.sepiaIntensity),vignetteOffset:new Uniform(settings.vignetteOffset),vignetteDarkness:new Uniform(settings.vignetteDarkness)},fragmentShader:fragment$8,vertexShader:vertex$8,depthWrite:false,depthTest:false}));_this.setScreenModeEnabled(settings.screenMode);_this.setNoiseEnabled(settings.noise);_this.setScanlinesEnabled(settings.scanlines);_this.setGridEnabled(settings.grid);_this.setGreyscaleEnabled(settings.greyscale);_this.setSepiaEnabled(settings.sepia);_this.setVignetteEnabled(settings.vignette);_this.setEskilEnabled(settings.eskil);return _this;}/**
* Enables or disables the Screen blend mode.
*
* @param {Boolean} enabled - Whether the Screen blend mode should be enabled.
*/createClass(FilmMaterial,[{key:"setScreenModeEnabled",value:function setScreenModeEnabled(enabled){if(enabled){this.defines.SCREEN_MODE="1";}else{delete this.defines.SCREEN_MODE;}this.needsUpdate=true;}/**
* Enables or disables the noise effect.
*
* @param {Boolean} enabled - Whether the noise effect should be enabled.
*/},{key:"setNoiseEnabled",value:function setNoiseEnabled(enabled){if(enabled){this.defines.NOISE="1";}else{delete this.defines.NOISE;}this.needsUpdate=true;}/**
* Enables or disables the scanlines effect.
*
* @param {Boolean} enabled - Whether the scanlines effect should be enabled.
*/},{key:"setScanlinesEnabled",value:function setScanlinesEnabled(enabled){if(enabled){this.defines.SCANLINES="1";}else{delete this.defines.SCANLINES;}this.needsUpdate=true;}/**
* Enables or disables the grid effect.
*
* @param {Boolean} enabled - Whether the grid effect should be enabled.
*/},{key:"setGridEnabled",value:function setGridEnabled(enabled){if(enabled){this.defines.GRID="1";}else{delete this.defines.GRID;}this.needsUpdate=true;}/**
* Enables or disables the greyscale effect.
*
* @param {Boolean} enabled - Whether the greyscale effect should be enabled.
*/},{key:"setGreyscaleEnabled",value:function setGreyscaleEnabled(enabled){if(enabled){this.defines.GREYSCALE="1";}else{delete this.defines.GREYSCALE;}this.needsUpdate=true;}/**
* Enables or disables the sepia effect.
*
* @param {Boolean} enabled - Whether the sepia effect should be enabled.
*/},{key:"setSepiaEnabled",value:function setSepiaEnabled(enabled){if(enabled){this.defines.SEPIA="1";}else{delete this.defines.SEPIA;}this.needsUpdate=true;}/**
* Enables or disables the Vignette effect.
*
* @param {Boolean} enabled - Whether the Vignette effect should be enabled.
*/},{key:"setVignetteEnabled",value:function setVignetteEnabled(enabled){if(enabled){this.defines.VIGNETTE="1";}else{delete this.defines.VIGNETTE;}this.needsUpdate=true;}/**
* Enables or disables the Eskil Vignette effect.
*
* Has no effect if Vignette is disabled.
*
* @param {Boolean} enabled - Whether the Eskil Vignette effect should be enabled.
*/},{key:"setEskilEnabled",value:function setEskilEnabled(enabled){if(enabled){this.defines.ESKIL="1";}else{delete this.defines.ESKIL;}this.needsUpdate=true;}}]);inherits(FilmMaterial,_ShaderMaterial);return FilmMaterial;}(ShaderMaterial);var fragment$9="uniform sampler2D tDiffuse;\r\nuniform sampler2D tPerturb;\r\n\r\nuniform bool active;\r\n\r\nuniform float amount;\r\nuniform float angle;\r\nuniform float seed;\r\nuniform float seedX;\r\nuniform float seedY;\r\nuniform float distortionX;\r\nuniform float distortionY;\r\nuniform float colS;\r\n\r\nvarying vec2 vUv;\r\n\r\nfloat rand(vec2 tc) {\r\n\r\n\tconst float a = 12.9898;\r\n\tconst float b = 78.233;\r\n\tconst float c = 43758.5453;\r\n\r\n\tfloat dt = dot(tc, vec2(a, b));\r\n\tfloat sn = mod(dt, 3.14);\r\n\r\n\treturn fract(sin(sn) * c);\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec2 coord = vUv;\r\n\r\n\tfloat xs, ys;\r\n\tvec4 normal;\r\n\r\n\tvec2 offset;\r\n\tvec4 cr, cga, cb;\r\n\tvec4 snow, color;\r\n\r\n\tfloat sx, sy;\r\n\r\n\tif(active) {\r\n\r\n\t\txs = floor(gl_FragCoord.x / 0.5);\r\n\t\tys = floor(gl_FragCoord.y / 0.5);\r\n\r\n\t\tnormal = texture2D(tPerturb, coord * seed * seed);\r\n\r\n\t\tif(coord.y < distortionX + colS && coord.y > distortionX - colS * seed) {\r\n\r\n\t\t\tsx = clamp(ceil(seedX), 0.0, 1.0);\r\n\t\t\tcoord.y = sx * (1.0 - (coord.y + distortionY)) + (1.0 - sx) * distortionY;\r\n\r\n\t\t}\r\n\r\n\t\tif(coord.x < distortionY + colS && coord.x > distortionY - colS * seed) {\r\n\r\n\t\t\tsy = clamp(ceil(seedY), 0.0, 1.0);\r\n\t\t\tcoord.x = sy * distortionX + (1.0 - sy) * (1.0 - (coord.x + distortionX));\r\n\r\n\t\t}\r\n\r\n\t\tcoord.x += normal.x * seedX * (seed / 5.0);\r\n\t\tcoord.y += normal.y * seedY * (seed / 5.0);\r\n\r\n\t\toffset = amount * vec2(cos(angle), sin(angle));\r\n\r\n\t\tcr = texture2D(tDiffuse, coord + offset);\r\n\t\tcga = texture2D(tDiffuse, coord);\r\n\t\tcb = texture2D(tDiffuse, coord - offset);\r\n\r\n\t\tcolor = vec4(cr.r, cga.g, cb.b, cga.a);\r\n\t\tsnow = 200.0 * amount * vec4(rand(vec2(xs * seed, ys * seed * 50.0)) * 0.2);\r\n\t\tcolor += snow;\r\n\r\n\t} else {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv);\r\n\r\n\t}\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n";var vertex$9="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A glitch shader material.
*
* Reference:
* https://github.com/staffantan/unityglitch
*/var GlitchMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new glitch material.
*/function GlitchMaterial(){classCallCheck(this,GlitchMaterial);return possibleConstructorReturn(this,getPrototypeOf$2(GlitchMaterial).call(this,{type:"GlitchMaterial",uniforms:{tDiffuse:new Uniform(null),tPerturb:new Uniform(null),active:new Uniform(1),amount:new Uniform(0.8),angle:new Uniform(0.02),seed:new Uniform(0.02),seedX:new Uniform(0.02),seedY:new Uniform(0.02),distortionX:new Uniform(0.5),distortionY:new Uniform(0.6),colS:new Uniform(0.05)},fragmentShader:fragment$9,vertexShader:vertex$9,depthWrite:false,depthTest:false}));}inherits(GlitchMaterial,_ShaderMaterial);return GlitchMaterial;}(ShaderMaterial);var fragment$10="#include <common>\r\n#include <dithering_pars_fragment>\r\n\r\nuniform sampler2D tDiffuse;\r\nuniform vec3 lightPosition;\r\n\r\nuniform float exposure;\r\nuniform float decay;\r\nuniform float density;\r\nuniform float weight;\r\nuniform float clampMax;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec2 texCoord = vUv;\r\n\r\n\t// Calculate vector from pixel to light source in screen space.\r\n\tvec2 deltaTexCoord = texCoord - lightPosition.st;\r\n\tdeltaTexCoord *= 1.0 / NUM_SAMPLES_FLOAT * density;\r\n\r\n\t// A decreasing illumination factor.\r\n\tfloat illuminationDecay = 1.0;\r\n\r\n\tvec4 sample;\r\n\tvec4 color = vec4(0.0);\r\n\r\n\t// Estimate the probability of occlusion at each pixel by summing samples along a ray to the light source.\r\n\tfor(int i = 0; i < NUM_SAMPLES_INT; ++i) {\r\n\r\n\t\ttexCoord -= deltaTexCoord;\r\n\t\tsample = texture2D(tDiffuse, texCoord);\r\n\r\n\t\t// Apply sample attenuation scale/decay factors.\r\n\t\tsample *= illuminationDecay * weight;\r\n\r\n\t\tcolor += sample;\r\n\r\n\t\t// Update exponential decay factor.\r\n\t\tilluminationDecay *= decay;\r\n\r\n\t}\r\n\r\n\tgl_FragColor = clamp(color * exposure, 0.0, clampMax);\r\n\r\n\t#include <dithering_fragment>\r\n\r\n}\r\n";var vertex$10="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A crepuscular rays shader material.
*
* This material supports dithering.
*
* References:
*
* Thibaut Despoulain, 2012:
* [(WebGL) Volumetric Light Approximation in Three.js](
* http://bkcore.com/blog/3d/webgl-three-js-volumetric-light-godrays.html)
*
* Nvidia, GPU Gems 3, 2008:
* [Chapter 13. Volumetric Light Scattering as a Post-Process](
* https://developer.nvidia.com/gpugems/GPUGems3/gpugems3_ch13.html)
*/var GodRaysMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new god rays material.
*
* @param {Object} [options] - The options.
* @param {Number} [options.density=0.96] - The density of the light rays.
* @param {Number} [options.decay=0.93] - An illumination decay factor.
* @param {Number} [options.weight=0.4] - A light ray weight factor.
* @param {Number} [options.exposure=0.6] - A constant attenuation coefficient.
* @param {Number} [options.clampMax=1.0] - An upper bound for the saturation of the overall effect.
*/function GodRaysMaterial(){var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,GodRaysMaterial);var settings=Object.assign({exposure:0.6,density:0.93,decay:0.96,weight:0.4,clampMax:1.0},options);return possibleConstructorReturn(this,getPrototypeOf$2(GodRaysMaterial).call(this,{type:"GodRaysMaterial",defines:{NUM_SAMPLES_FLOAT:"60.0",NUM_SAMPLES_INT:"60"},uniforms:{tDiffuse:new Uniform(null),lightPosition:new Uniform(null),exposure:new Uniform(settings.exposure),decay:new Uniform(settings.decay),density:new Uniform(settings.density),weight:new Uniform(settings.weight),clampMax:new Uniform(settings.clampMax)},fragmentShader:fragment$10,vertexShader:vertex$10,depthWrite:false,depthTest:false}));}inherits(GodRaysMaterial,_ShaderMaterial);return GodRaysMaterial;}(ShaderMaterial);var fragment$11="#include <common>\r\n\r\nuniform sampler2D tDiffuse;\r\nuniform float distinction;\r\nuniform vec2 range;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tfloat l = linearToRelativeLuminance(texel.rgb);\r\n\r\n\t#ifdef RANGE\r\n\r\n\t\tfloat low = step(range.x, l);\r\n\t\tfloat high = step(l, range.y);\r\n\r\n\t\t// Apply the mask.\r\n\t\tl *= low * high;\r\n\r\n\t#endif\r\n\r\n\tl = pow(abs(l), distinction);\r\n\r\n\t#ifdef COLOR\r\n\r\n\t\tgl_FragColor = vec4(texel.rgb * l, texel.a);\r\n\r\n\t#else\r\n\r\n\t\tgl_FragColor = vec4(l, l, l, texel.a);\r\n\r\n\t#endif\r\n\r\n}\r\n";var vertex$11="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A luminosity shader material.
*
* This shader produces a greyscale luminance map that describes the absolute
* amount of light emitted by a scene. It can also be configured to output
* colours that are scaled with their respective luminance value. Additionally,
* a range may be provided to mask out undesired texels.
*
* The alpha channel will remain unaffected in all cases.
*
* On luminance coefficients:
* http://www.poynton.com/notes/colour_and_gamma/ColorFAQ.html#RTFToC9
*
* Coefficients for different colour spaces:
* https://hsto.org/getpro/habr/post_images/2ab/69d/084/2ab69d084f9a597e032624bcd74d57a7.png
*
* Luminance range reference:
* https://cycling74.com/2007/05/23/your-first-shader/#.Vty9FfkrL4Z
*/var LuminosityMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new luminosity material.
*
* @param {Boolean} [colorOutput=false] - Defines whether the shader should output colours scaled with their luminance value.
* @param {Vector2} [luminanceRange] - If provided, the shader will mask out texels that aren't in the specified luminance range.
*/function LuminosityMaterial(){var _this;var colorOutput=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;var luminanceRange=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;classCallCheck(this,LuminosityMaterial);var maskLuminance=luminanceRange!==null;_this=possibleConstructorReturn(this,getPrototypeOf$2(LuminosityMaterial).call(this,{type:"LuminosityMaterial",uniforms:{tDiffuse:new Uniform(null),distinction:new Uniform(1.0),range:new Uniform(maskLuminance?luminanceRange:new Vector2())},fragmentShader:fragment$11,vertexShader:vertex$11}));_this.setColorOutputEnabled(colorOutput);_this.setLuminanceRangeEnabled(maskLuminance);return _this;}/**
* Enables or disables color output.
*
* @param {Boolean} enabled - Whether color output should be enabled.
*/createClass(LuminosityMaterial,[{key:"setColorOutputEnabled",value:function setColorOutputEnabled(enabled){if(enabled){this.defines.COLOR="1";}else{delete this.defines.COLOR;}this.needsUpdate=true;}/**
* Enables or disables the luminance mask.
*
* @param {Boolean} enabled - Whether the luminance mask should be enabled.
*/},{key:"setLuminanceRangeEnabled",value:function setLuminanceRangeEnabled(enabled){if(enabled){this.defines.RANGE="1";}else{delete this.defines.RANGE;}this.needsUpdate=true;}}]);inherits(LuminosityMaterial,_ShaderMaterial);return LuminosityMaterial;}(ShaderMaterial);var fragment$12="uniform sampler2D tDiffuse;\r\nuniform sampler2D tMask;\r\nuniform sampler2D tEdges;\r\n\r\nuniform vec3 visibleEdgeColor;\r\nuniform vec3 hiddenEdgeColor;\r\nuniform float pulse;\r\nuniform float edgeStrength;\r\n\r\n#ifdef USE_PATTERN\r\n\r\n\tuniform sampler2D tPattern;\r\n\tvarying vec2 vPatternCoord;\r\n\r\n#endif\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 color = texture2D(tDiffuse, vUv);\r\n\tvec2 edge = texture2D(tEdges, vUv).rg;\r\n\tvec2 mask = texture2D(tMask, vUv).rg;\r\n\r\n\t#ifndef X_RAY\r\n\r\n\t\tedge.y = 0.0;\r\n\r\n\t#endif\r\n\r\n\tedge *= (edgeStrength * mask.x * pulse);\r\n\tvec3 outlineColor = edge.x * visibleEdgeColor + edge.y * hiddenEdgeColor;\r\n\r\n\t#ifdef ALPHA_BLENDING\r\n\r\n\t\tcolor.rgb = mix(color.rgb, outlineColor, max(edge.x, edge.y));\r\n\r\n\t#else\r\n\r\n\t\tcolor.rgb += outlineColor;\r\n\r\n\t#endif\r\n\r\n\t#ifdef USE_PATTERN\r\n\r\n\t\tvec3 patternColor = texture2D(tPattern, vPatternCoord).rgb;\r\n\r\n\t\t#ifdef X_RAY\r\n\r\n\t\t\tfloat hiddenFactor = 0.5;\r\n\r\n\t\t#else\r\n\r\n\t\t\tfloat hiddenFactor = 0.0;\r\n\r\n\t\t#endif\r\n\r\n\t\tfloat visibilityFactor = (1.0 - mask.y > 0.0) ? 1.0 : hiddenFactor;\r\n\r\n\t\tcolor.rgb += visibilityFactor * (1.0 - mask.x) * (1.0 - patternColor);\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n";var vertex$12="#ifdef USE_PATTERN\r\n\r\n\tuniform float aspect;\r\n\tuniform float patternScale;\r\n\tvarying vec2 vPatternCoord;\r\n\r\n#endif\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\t#ifdef USE_PATTERN\r\n\r\n\t\tvec2 aspectCorrection = vec2(aspect, 1.0);\r\n\t\tvPatternCoord = uv * aspectCorrection * patternScale;\r\n\r\n\t#endif\r\n\r\n\tvUv = uv;\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* An outline blend shader material.
*/var OutlineBlendMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new outline blend material.
*
* @param {Object} [options] - The options.
* @param {Number} [options.edgeStrength=1.0] - The edge strength.
* @param {Number} [options.patternScale=1.0] - The scale of the pattern texture.
* @param {Number} [options.visibleEdgeColor=0xffffff] - The color of visible edges.
* @param {Number} [options.hiddenEdgeColor=0x22090A] - The color of hidden edges.
* @param {Boolean} [alphaBlending=false] - Whether the outline should be blended using alpha.
* @param {Boolean} [xRay=true] - Whether hidden parts of selected objects should be visible.
*/function OutlineBlendMaterial(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,OutlineBlendMaterial);var settings=Object.assign({edgeStrength:1.0,patternScale:1.0,visibleEdgeColor:0xffffff,hiddenEdgeColor:0x22090A,alphaBlending:false,xRay:true},options);_this=possibleConstructorReturn(this,getPrototypeOf$2(OutlineBlendMaterial).call(this,{type:"OutlineBlendMaterial",uniforms:{pulse:new Uniform(1.0),aspect:new Uniform(1.0),tDiffuse:new Uniform(null),tMask:new Uniform(null),tEdges:new Uniform(null),tPattern:new Uniform(null),edgeStrength:new Uniform(settings.edgeStrength),patternScale:new Uniform(settings.patternScale),visibleEdgeColor:new Uniform(new Color(settings.visibleEdgeColor)),hiddenEdgeColor:new Uniform(new Color(settings.hiddenEdgeColor))},fragmentShader:fragment$12,vertexShader:vertex$12,depthWrite:false,depthTest:false}));_this.setAlphaBlendingEnabled(settings.alphaBlending);_this.setXRayEnabled(settings.xRay);return _this;}/**
* Enables or disables the alpha blending.
*
* @param {Boolean} enabled - Whether the alpha blending should be enabled.
*/createClass(OutlineBlendMaterial,[{key:"setAlphaBlendingEnabled",value:function setAlphaBlendingEnabled(enabled){if(enabled){this.defines.ALPHA_BLENDING="1";}else{delete this.defines.ALPHA_BLENDING;}this.needsUpdate=true;}/**
* Defines whether hidden parts of selected objects should be visible.
*
* @param {Boolean} enabled - Whether hidden parts of selected objects should be visible.
*/},{key:"setXRayEnabled",value:function setXRayEnabled(enabled){if(enabled){this.defines.X_RAY="1";}else{delete this.defines.X_RAY;}this.needsUpdate=true;}/**
* Sets a pattern texture to use as overlay.
*
* @param {Texture} [texture=null] - A pattern texture. Set to null to disable the pattern.
*/},{key:"setPatternTexture",value:function setPatternTexture(){var texture=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;if(texture!==null){this.defines.USE_PATTERN="1";}else{delete this.defines.USE_PATTERN;}this.uniforms.tPattern.value=texture;this.needsUpdate=true;}}]);inherits(OutlineBlendMaterial,_ShaderMaterial);return OutlineBlendMaterial;}(ShaderMaterial);var fragment$13="uniform sampler2D tMask;\r\n\r\nvarying vec2 vUv0;\r\nvarying vec2 vUv1;\r\nvarying vec2 vUv2;\r\nvarying vec2 vUv3;\r\n\r\nvoid main() {\r\n\r\n\tvec2 c0 = texture2D(tMask, vUv0).rg;\r\n\tvec2 c1 = texture2D(tMask, vUv1).rg;\r\n\tvec2 c2 = texture2D(tMask, vUv2).rg;\r\n\tvec2 c3 = texture2D(tMask, vUv3).rg;\r\n\r\n\tfloat d0 = (c0.x - c1.x) * 0.5;\r\n\tfloat d1 = (c2.x - c3.x) * 0.5;\r\n\tfloat d = length(vec2(d0, d1));\r\n\r\n\tfloat a0 = min(c0.y, c1.y);\r\n\tfloat a1 = min(c2.y, c3.y);\r\n\tfloat visibilityFactor = min(a0, a1);\r\n\r\n\tgl_FragColor.rg = (1.0 - visibilityFactor > 0.001) ? vec2(d, 0.0) : vec2(0.0, d);\r\n\r\n}\r\n";var vertex$13="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv0;\r\nvarying vec2 vUv1;\r\nvarying vec2 vUv2;\r\nvarying vec2 vUv3;\r\n\r\nvoid main() {\r\n\r\n\tvUv0 = vec2(uv.x + texelSize.x, uv.y);\r\n\tvUv1 = vec2(uv.x - texelSize.x, uv.y);\r\n\tvUv2 = vec2(uv.x, uv.y + texelSize.y);\r\n\tvUv3 = vec2(uv.x, uv.y - texelSize.y);\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* An outline edge detection shader material.
*/var OutlineEdgesMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new outline edge detection material.
*
* @param {Vector2} [texelSize] - The absolute screen texel size.
*/function OutlineEdgesMaterial(){var _this;var texelSize=arguments.length>0&&arguments[0]!==undefined?arguments[0]:new Vector2();classCallCheck(this,OutlineEdgesMaterial);_this=possibleConstructorReturn(this,getPrototypeOf$2(OutlineEdgesMaterial).call(this,{type:"OutlineEdgesMaterial",uniforms:{tMask:new Uniform(null),texelSize:new Uniform(new Vector2())},fragmentShader:fragment$13,vertexShader:vertex$13,depthWrite:false,depthTest:false}));_this.setTexelSize(texelSize.x,texelSize.y);return _this;}/**
* Sets the texel size.
*
* @param {Number} x - The texel width.
* @param {Number} y - The texel height.
*/createClass(OutlineEdgesMaterial,[{key:"setTexelSize",value:function setTexelSize(x,y){this.uniforms.texelSize.value.set(x,y);}}]);inherits(OutlineEdgesMaterial,_ShaderMaterial);return OutlineEdgesMaterial;}(ShaderMaterial);var fragment$14="uniform sampler2D tDiffuse;\r\nuniform float granularity;\r\nuniform float dx;\r\nuniform float dy;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel;\r\n\r\n\tif(granularity > 0.0) {\r\n\r\n\t\tvec2 coord = vec2(\r\n\t\t\tdx * (floor(vUv.x / dx) + 0.5),\r\n\t\t\tdy * (floor(vUv.y / dy) + 0.5)\r\n\t\t);\r\n\r\n\t\ttexel = texture2D(tDiffuse, coord);\r\n\r\n\t} else {\r\n\r\n\t\ttexel = texture2D(tDiffuse, vUv);\r\n\r\n\t}\r\n\r\n\tgl_FragColor = texel;\r\n\r\n}\r\n";var vertex$14="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A pixelation shader material.
*
* Original shader code by Robert Casanova:
* https://github.com/robertcasanova/pixelate-shader
*/var PixelationMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new pixelation material.
*/function PixelationMaterial(){classCallCheck(this,PixelationMaterial);return possibleConstructorReturn(this,getPrototypeOf$2(PixelationMaterial).call(this,{type:"PixelationMaterial",uniforms:{tDiffuse:new Uniform(null),granularity:new Uniform(1.0),resolution:new Uniform(new Vector2(1.0,1.0)),dx:new Uniform(1.0),dy:new Uniform(1.0)},fragmentShader:fragment$14,vertexShader:vertex$14,depthWrite:false,depthTest:false}));}/**
* The pixel granularity.
*
* @type {Number}
*/createClass(PixelationMaterial,[{key:"setResolution",/**
* Sets the resolution.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/value:function setResolution(width,height){this.uniforms.resolution.value.set(width,height);this.granularity=this.granularity;}},{key:"granularity",get:function get(){return this.uniforms.granularity.value;}/**
* A higher value yields coarser visuals.
*
* @type {Number}
*/,set:function set(x){var uniforms=this.uniforms;var resolution=uniforms.resolution.value;uniforms.granularity.value=x;uniforms.dx.value=x/resolution.x;uniforms.dy.value=x/resolution.y;}}]);inherits(PixelationMaterial,_ShaderMaterial);return PixelationMaterial;}(ShaderMaterial);var fragment$15="#include <common>\r\n\r\nuniform sampler2D tDiffuse;\r\nuniform sampler2D tDepth;\r\n\r\nuniform vec2 texelSize;\r\nuniform vec2 halfTexelSize;\r\n\r\nuniform float cameraNear;\r\nuniform float cameraFar;\r\n\r\nuniform float focalLength;\r\nuniform float focalStop;\r\n\r\nuniform float maxBlur;\r\nuniform float luminanceThreshold;\r\nuniform float luminanceGain;\r\nuniform float bias;\r\nuniform float fringe;\r\nuniform float ditherStrength;\r\n\r\n#ifdef SHADER_FOCUS\r\n\r\n\tuniform vec2 focusCoords;\r\n\r\n#else\r\n\r\n\tuniform float focalDepth;\r\n\r\n#endif\r\n\r\nvarying vec2 vUv;\r\n\r\n#ifndef USE_LOGDEPTHBUF\r\n\r\n\t#include <packing>\r\n\r\n\tfloat readDepth(sampler2D depthSampler, vec2 coord) {\r\n\r\n\t\tfloat fragCoordZ = texture2D(depthSampler, coord).x;\r\n\t\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\r\n\r\n\t\treturn viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\n#ifdef PENTAGON\r\n\r\n\tfloat penta(vec2 coords) {\r\n\r\n\t\tconst vec4 HS0 = vec4( 1.0, 0.0, 0.0, 1.0);\r\n\t\tconst vec4 HS1 = vec4( 0.309016994, 0.951056516, 0.0, 1.0);\r\n\t\tconst vec4 HS2 = vec4(-0.809016994, 0.587785252, 0.0, 1.0);\r\n\t\tconst vec4 HS3 = vec4(-0.809016994, -0.587785252, 0.0, 1.0);\r\n\t\tconst vec4 HS4 = vec4( 0.309016994, -0.951056516, 0.0, 1.0);\r\n\t\tconst vec4 HS5 = vec4( 0.0, 0.0, 1.0, 1.0);\r\n\r\n\t\tconst vec4 ONE = vec4(1.0);\r\n\r\n\t\tconst float P_FEATHER = 0.4;\r\n\t\tconst float N_FEATHER = -P_FEATHER;\r\n\r\n\t\tfloat inOrOut = -4.0;\r\n\r\n\t\tvec4 P = vec4(coords, vec2(RINGS_FLOAT - 1.3));\r\n\r\n\t\tvec4 dist = vec4(\r\n\t\t\tdot(P, HS0),\r\n\t\t\tdot(P, HS1),\r\n\t\t\tdot(P, HS2),\r\n\t\t\tdot(P, HS3)\r\n\t\t);\r\n\r\n\t\tdist = smoothstep(N_FEATHER, P_FEATHER, dist);\r\n\r\n\t\tinOrOut += dot(dist, ONE);\r\n\r\n\t\tdist.x = dot(P, HS4);\r\n\t\tdist.y = HS5.w - abs(P.z);\r\n\r\n\t\tdist = smoothstep(N_FEATHER, P_FEATHER, dist);\r\n\t\tinOrOut += dist.x;\r\n\r\n\t\treturn clamp(inOrOut, 0.0, 1.0);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\n#ifdef SHOW_FOCUS\r\n\r\n\tvec3 debugFocus(vec3 c, float blur, float depth) {\r\n\r\n\t\tfloat edge = 0.002 * depth;\r\n\t\tfloat m = clamp(smoothstep(0.0, edge, blur), 0.0, 1.0);\r\n\t\tfloat e = clamp(smoothstep(1.0 - edge, 1.0, blur), 0.0, 1.0);\r\n\r\n\t\tc = mix(c, vec3(1.0, 0.5, 0.0), (1.0 - m) * 0.6);\r\n\t\tc = mix(c, vec3(0.0, 0.5, 1.0), ((1.0 - e) - (1.0 - m)) * 0.2);\r\n\r\n\t\treturn c;\r\n\r\n\t}\r\n\r\n#endif\r\n\r\n#ifdef VIGNETTE\r\n\r\n\tfloat vignette() {\r\n\r\n\t\tconst vec2 CENTER = vec2(0.5);\r\n\r\n\t\tconst float VIGNETTE_OUT = 1.3;\r\n\t\tconst float VIGNETTE_IN = 0.0;\r\n\t\tconst float VIGNETTE_FADE = 22.0; \r\n\r\n\t\tfloat d = distance(vUv, CENTER);\r\n\t\td = smoothstep(VIGNETTE_OUT + (focalStop / VIGNETTE_FADE), VIGNETTE_IN + (focalStop / VIGNETTE_FADE), d);\r\n\r\n\t\treturn clamp(d, 0.0, 1.0);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\nvec2 rand2(vec2 coord) {\r\n\r\n\tvec2 noise;\r\n\r\n\t#ifdef NOISE\r\n\r\n\t\tconst float a = 12.9898;\r\n\t\tconst float b = 78.233;\r\n\t\tconst float c = 43758.5453;\r\n\r\n\t\tnoise.x = clamp(fract(sin(mod(dot(coord, vec2(a, b)), 3.14)) * c), 0.0, 1.0) * 2.0 - 1.0;\r\n\t\tnoise.y = clamp(fract(sin(mod(dot(coord, vec2(a, b) * 2.0), 3.14)) * c), 0.0, 1.0) * 2.0 - 1.0;\r\n\r\n\t#else\r\n\r\n\t\tnoise.x = ((fract(1.0 - coord.s * halfTexelSize.x) * 0.25) + (fract(coord.t * halfTexelSize.y) * 0.75)) * 2.0 - 1.0;\r\n\t\tnoise.y = ((fract(1.0 - coord.s * halfTexelSize.x) * 0.75) + (fract(coord.t * halfTexelSize.y) * 0.25)) * 2.0 - 1.0;\r\n\r\n\t#endif\r\n\r\n\treturn noise;\r\n\r\n}\r\n\r\nvec3 processTexel(vec2 coords, float blur) {\r\n\r\n\tvec3 c;\r\n\tc.r = texture2D(tDiffuse, coords + vec2(0.0, 1.0) * texelSize * fringe * blur).r;\r\n\tc.g = texture2D(tDiffuse, coords + vec2(-0.866, -0.5) * texelSize * fringe * blur).g;\r\n\tc.b = texture2D(tDiffuse, coords + vec2(0.866, -0.5) * texelSize * fringe * blur).b;\r\n\r\n\t// Calculate the luminance of the constructed colour.\r\n\tfloat luminance = linearToRelativeLuminance(c);\r\n\tfloat threshold = max((luminance - luminanceThreshold) * luminanceGain, 0.0);\r\n\r\n\treturn c + mix(vec3(0.0), c, threshold * blur);\r\n\r\n}\r\n\r\nfloat linearize(float depth) {\r\n\r\n\treturn -cameraFar * cameraNear / (depth * (cameraFar - cameraNear) - cameraFar);\r\n\r\n}\r\n\r\nfloat gather(float i, float j, float ringSamples, inout vec3 color, float w, float h, float blur) {\r\n\r\n\tconst float TWO_PI = 6.28318531;\r\n\r\n\tfloat step = TWO_PI / ringSamples;\r\n\tfloat pw = cos(j * step) * i;\r\n\tfloat ph = sin(j * step) * i;\r\n\r\n\t#ifdef PENTAGON\r\n\r\n\t\tfloat p = penta(vec2(pw, ph));\r\n\r\n\t#else\r\n\r\n\t\tfloat p = 1.0;\r\n\r\n\t#endif\r\n\r\n\tcolor += processTexel(vUv + vec2(pw * w, ph * h), blur) * mix(1.0, i / RINGS_FLOAT, bias) * p;\r\n\r\n\treturn mix(1.0, i / RINGS_FLOAT, bias) * p;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\t#ifdef USE_LOGDEPTHBUF\r\n\r\n\t\tfloat depth = linearize(texture2D(tDepth, vUv).x);\r\n\r\n\t#else\r\n\r\n\t\tfloat depth = linearize(readDepth(tDepth, vUv));\r\n\r\n\t#endif\r\n\r\n\t#ifdef SHADER_FOCUS\r\n\r\n\t\t#ifdef USE_LOGDEPTHBUF\r\n\r\n\t\t\tfloat fDepth = linearize(texture2D(tDepth, focusCoords).x);\r\n\r\n\t\t#else\r\n\r\n\t\t\tfloat fDepth = linearize(readDepth(tDepth, focusCoords));\r\n\r\n\t\t#endif\r\n\r\n\t#else\r\n\r\n\t\tfloat fDepth = focalDepth;\r\n\r\n\t#endif\r\n\r\n\t#ifdef MANUAL_DOF\r\n\r\n\t\tconst float nDoFStart = 1.0; \r\n\t\tconst float nDoFDist = 2.0;\r\n\t\tconst float fDoFStart = 1.0;\r\n\t\tconst float fDoFDist = 3.0;\r\n\r\n\t\tfloat focalPlane = depth - fDepth;\r\n\t\tfloat farDoF = (focalPlane - fDoFStart) / fDoFDist;\r\n\t\tfloat nearDoF = (-focalPlane - nDoFStart) / nDoFDist;\r\n\r\n\t\tfloat blur = (focalPlane > 0.0) ? farDoF : nearDoF;\r\n\r\n\t#else\r\n\r\n\t\tconst float CIRCLE_OF_CONFUSION = 0.03; // 35mm film = 0.03mm CoC.\r\n\r\n\t\tfloat focalPlaneMM = fDepth * 1000.0;\r\n\t\tfloat depthMM = depth * 1000.0;\r\n\r\n\t\tfloat focalPlane = (depthMM * focalLength) / (depthMM - focalLength);\r\n\t\tfloat farDoF = (focalPlaneMM * focalLength) / (focalPlaneMM - focalLength);\r\n\t\tfloat nearDoF = (focalPlaneMM - focalLength) / (focalPlaneMM * focalStop * CIRCLE_OF_CONFUSION);\r\n\r\n\t\tfloat blur = abs(focalPlane - farDoF) * nearDoF;\r\n\r\n\t#endif\r\n\r\n\tblur = clamp(blur, 0.0, 1.0);\r\n\r\n\t// Dithering.\r\n\tvec2 noise = rand2(vUv) * ditherStrength * blur;\r\n\r\n\tfloat blurFactorX = texelSize.x * blur * maxBlur + noise.x;\r\n\tfloat blurFactorY = texelSize.y * blur * maxBlur + noise.y;\r\n\r\n\tconst int MAX_RING_SAMPLES = RINGS_INT * SAMPLES_INT;\r\n\r\n\t// Calculation of final color.\r\n\tvec4 color;\r\n\r\n\tif(blur < 0.05) {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv);\r\n\r\n\t} else {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv);\r\n\r\n\t\tfloat s = 1.0;\r\n\t\tint ringSamples;\r\n\r\n\t\tfor(int i = 1; i <= RINGS_INT; ++i) {\r\n\r\n\t\t\tringSamples = i * SAMPLES_INT;\r\n\r\n\t\t\t// Constant loop.\r\n\t\t\tfor(int j = 0; j < MAX_RING_SAMPLES; ++j) {\r\n\r\n\t\t\t\t// Break earlier.\r\n\t\t\t\tif(j >= ringSamples) { break; }\r\n\r\n\t\t\t\ts += gather(float(i), float(j), float(ringSamples), color.rgb, blurFactorX, blurFactorY, blur);\r\n\r\n\t\t\t}\r\n\r\n\t\t}\r\n\r\n\t\tcolor.rgb /= s; // Divide by sample count.\r\n\r\n\t}\r\n\r\n\t#ifdef SHOW_FOCUS\r\n\r\n\t\tcolor.rgb = debugFocus(color.rgb, blur, depth);\r\n\r\n\t#endif\r\n\r\n\t#ifdef VIGNETTE\r\n\r\n\t\tcolor.rgb *= vignette();\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n";var vertex$15="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* Depth of Field shader v2.4.
*
* Original shader code by Martins Upitis:
* http://blenderartists.org/forum/showthread.php?237488-GLSL-depth-of-field-with-bokeh-v2-4-(update)
*/var RealisticBokehMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new bokeh2 material.
*
* @param {PerspectiveCamera} [camera] - The main camera.
* @param {Object} [options] - Additional options.
* @param {Vector2} [options.texelSize] - The absolute screen texel size.
* @param {Boolean} [options.rings=3] - The number of blurring iterations.
* @param {Boolean} [options.samples=2] - The amount of samples taken per ring.
* @param {Boolean} [options.showFocus=false] - Whether the focus point should be highlighted.
* @param {Boolean} [options.manualDoF=false] - Enables manual depth of field blur.
* @param {Boolean} [options.vignette=false] - Enables a vignette effect.
* @param {Boolean} [options.pentagon=false] - Enable to use a pentagonal shape to scale gathered texels.
* @param {Boolean} [options.shaderFocus=true] - Disable if you compute your own focalDepth (in metres!).
* @param {Boolean} [options.noise=true] - Disable if you don't want noise patterns for dithering.
* @param {Number} [options.maxBlur=1.0] - The maximum blur strength.
* @param {Number} [options.luminanceThreshold=0.5] - A luminance threshold.
* @param {Number} [options.luminanceGain=2.0] - A luminance gain factor.
* @param {Number} [options.bias=0.5] - A blur bias.
* @param {Number} [options.fringe=0.7] - A blur offset.
* @param {Number} [options.ditherStrength=0.0001] - The dither strength.
*/function RealisticBokehMaterial(){var _this;var camera=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;var options=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};classCallCheck(this,RealisticBokehMaterial);var settings=Object.assign({texelSize:null,rings:3,samples:2,showFocus:false,manualDoF:false,vignette:false,pentagon:false,shaderFocus:true,noise:true,maxBlur:1.0,luminanceThreshold:0.5,luminanceGain:2.0,bias:0.5,fringe:0.7,ditherStrength:0.0001},options);_this=possibleConstructorReturn(this,getPrototypeOf$2(RealisticBokehMaterial).call(this,{type:"RealisticBokehMaterial",defines:{RINGS_INT:settings.rings.toFixed(0),RINGS_FLOAT:settings.rings.toFixed(1),SAMPLES_INT:settings.samples.toFixed(0),SAMPLES_FLOAT:settings.samples.toFixed(1)},uniforms:{tDiffuse:new Uniform(null),tDepth:new Uniform(null),texelSize:new Uniform(new Vector2()),halfTexelSize:new Uniform(new Vector2()),cameraNear:new Uniform(0.1),cameraFar:new Uniform(2000),focalLength:new Uniform(24.0),focalStop:new Uniform(0.9),maxBlur:new Uniform(settings.maxBlur),luminanceThreshold:new Uniform(settings.luminanceThreshold),luminanceGain:new Uniform(settings.luminanceGain),bias:new Uniform(settings.bias),fringe:new Uniform(settings.fringe),ditherStrength:new Uniform(settings.ditherStrength),focusCoords:new Uniform(new Vector2(0.5,0.5)),focalDepth:new Uniform(1.0)},fragmentShader:fragment$15,vertexShader:vertex$15,depthWrite:false,depthTest:false}));_this.setShowFocusEnabled(settings.showFocus);_this.setManualDepthOfFieldEnabled(settings.manualDoF);_this.setVignetteEnabled(settings.vignette);_this.setPentagonEnabled(settings.pentagon);_this.setShaderFocusEnabled(settings.shaderFocus);_this.setNoiseEnabled(settings.noise);if(settings.texelSize!==null){_this.setTexelSize(settings.texelSize.x,settings.texelSize.y);}_this.adoptCameraSettings(camera);return _this;}/**
* Defines whether the focus should be shown.
*
* @param {Boolean} enabled - True if the focus should be shown, false otherwise.
*/createClass(RealisticBokehMaterial,[{key:"setShowFocusEnabled",value:function setShowFocusEnabled(enabled){if(enabled){this.defines.SHOW_FOCUS="1";}else{delete this.defines.SHOW_FOCUS;}this.needsUpdate=true;}/**
* Defines whether manual Depth of Field should be enabled.
*
* @param {Boolean} enabled - Whether manual DoF should be enabled.
*/},{key:"setManualDepthOfFieldEnabled",value:function setManualDepthOfFieldEnabled(enabled){if(enabled){this.defines.MANUAL_DOF="1";}else{delete this.defines.MANUAL_DOF;}this.needsUpdate=true;}/**
* Defines whether the Vignette effect should be enabled.
*
* @param {Boolean} enabled - Whether the Vignette effect should be enabled.
*/},{key:"setVignetteEnabled",value:function setVignetteEnabled(enabled){if(enabled){this.defines.VIGNETTE="1";}else{delete this.defines.VIGNETTE;}this.needsUpdate=true;}/**
* Defines whether the pentagonal blur effect should be enabled.
*
* @param {Boolean} enabled - Whether the pentagonal blur effect should be enabled.
*/},{key:"setPentagonEnabled",value:function setPentagonEnabled(enabled){if(enabled){this.defines.PENTAGON="1";}else{delete this.defines.PENTAGON;}this.needsUpdate=true;}/**
* Enables or disables the automatic shader focus.
*
* @param {Boolean} enabled - Whether the shader focus should be enabled.
*/},{key:"setShaderFocusEnabled",value:function setShaderFocusEnabled(enabled){if(enabled){this.defines.SHADER_FOCUS="1";}else{delete this.defines.SHADER_FOCUS;}this.needsUpdate=true;}/**
* Defines whether the dithering should compute noise.
*
* @param {Boolean} enabled - Whether noise-based dithering should be enabled.
*/},{key:"setNoiseEnabled",value:function setNoiseEnabled(enabled){if(enabled){this.defines.NOISE="1";}else{delete this.defines.NOISE;}this.needsUpdate=true;}/**
* Sets the texel size.
*
* @param {Number} x - The texel width.
* @param {Number} y - The texel height.
*/},{key:"setTexelSize",value:function setTexelSize(x,y){this.uniforms.texelSize.value.set(x,y);this.uniforms.halfTexelSize.value.set(x,y).multiplyScalar(0.5);}/**
* Adopts the near and far plane and the focal length of the given camera.
*
* @param {PerspectiveCamera} camera - The main camera.
*/},{key:"adoptCameraSettings",value:function adoptCameraSettings(camera){if(camera!==null){this.uniforms.cameraNear.value=camera.near;this.uniforms.cameraFar.value=camera.far;this.uniforms.focalLength.value=camera.getFocalLength();// unit: mm.
}}}]);inherits(RealisticBokehMaterial,_ShaderMaterial);return RealisticBokehMaterial;}(ShaderMaterial);var fragment$16="#include <common>\r\n\r\nuniform sampler2D tDiffuse;\r\nuniform vec2 center;\r\nuniform float aspect;\r\nuniform float waveSize;\r\nuniform float radius;\r\nuniform float maxRadius;\r\nuniform float amplitude;\r\n\r\nvarying vec2 vUv;\r\nvarying float vSize;\r\n\r\nvoid main() {\r\n\r\n\tvec2 aspectCorrection = vec2(aspect, 1.0);\r\n\r\n\tvec2 difference = vUv * aspectCorrection - center * aspectCorrection;\r\n\tfloat distance = sqrt(dot(difference, difference)) * vSize;\r\n\r\n\tvec2 displacement = vec2(0.0);\r\n\r\n\tif(distance > radius) {\r\n\r\n\t\tif(distance < radius + waveSize) {\r\n\r\n\t\t\tfloat angle = (distance - radius) * PI2 / waveSize;\r\n\t\t\tfloat cosSin = (1.0 - cos(angle)) * 0.5;\r\n\r\n\t\t\tfloat extent = maxRadius + waveSize;\r\n\t\t\tfloat decay = max(extent - distance * distance, 0.0) / extent;\r\n\r\n\t\t\tdisplacement = ((cosSin * amplitude * difference) / distance) * decay;\r\n\r\n\t\t}\r\n\r\n\t}\r\n\r\n\tgl_FragColor = texture2D(tDiffuse, vUv - displacement);\r\n\r\n}\r\n";var vertex$16="uniform float size;\r\nuniform float scale;\r\nuniform float cameraDistance;\r\n\r\nvarying vec2 vUv;\r\nvarying float vSize;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tvSize = (0.1 * cameraDistance) / size;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* A shock wave shader material.
*
* Based on a Gist by Jean-Philippe Sarda:
* https://gist.github.com/jpsarda/33cea67a9f2ecb0a0eda
*/var ShockWaveMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new shock wave material.
*
* @param {Object} [options] - The options.
* @param {Number} [options.waveSize=0.2] - The wave size.
* @param {Number} [options.amplitude=0.05] - The distortion amplitude.
*/function ShockWaveMaterial(){var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,ShockWaveMaterial);var settings=Object.assign({maxRadius:1.0,waveSize:0.2,amplitude:0.05},options);return possibleConstructorReturn(this,getPrototypeOf$2(ShockWaveMaterial).call(this,{type:"ShockWaveMaterial",uniforms:{tDiffuse:new Uniform(null),center:new Uniform(new Vector2(0.5,0.5)),aspect:new Uniform(1.0),cameraDistance:new Uniform(1.0),size:new Uniform(1.0),radius:new Uniform(-settings.waveSize),maxRadius:new Uniform(settings.maxRadius),waveSize:new Uniform(settings.waveSize),amplitude:new Uniform(settings.amplitude)},fragmentShader:fragment$16,vertexShader:vertex$16,depthWrite:false,depthTest:false}));}inherits(ShockWaveMaterial,_ShaderMaterial);return ShockWaveMaterial;}(ShaderMaterial);var fragment$17="uniform sampler2D tDiffuse;\r\nuniform sampler2D tWeights;\r\n\r\nuniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset;\r\n\r\nvoid main() {\r\n\r\n\t// Fetch the blending weights for current pixel.\r\n\tvec4 a;\r\n\ta.xz = texture2D(tWeights, vUv).xz;\r\n\ta.y = texture2D(tWeights, vOffset.zw).g;\r\n\ta.w = texture2D(tWeights, vOffset.xy).a;\r\n\r\n\tvec4 color;\r\n\r\n\t// Check if there is any blending weight with a value greater than 0.0.\r\n\tif(dot(a, vec4(1.0)) < 1e-5) {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv, 0.0);\r\n\r\n\t} else {\r\n\r\n\t\t/* Up to four lines can be crossing a pixel (one through each edge).\r\n\t\t * The line with the maximum weight for each direction is favoured.\r\n\t\t */\r\n\r\n\t\tvec2 offset;\r\n\t\toffset.x = a.a > a.b ? a.a : -a.b; // Left vs. right.\r\n\t\toffset.y = a.g > a.r ? -a.g : a.r; // Top vs. bottom (changed signs).\r\n\r\n\t\t// Go in the direction with the maximum weight (horizontal vs. vertical).\r\n\t\tif(abs(offset.x) > abs(offset.y)) {\r\n\r\n\t\t\toffset.y = 0.0;\r\n\r\n\t\t} else {\r\n\r\n\t\t\toffset.x = 0.0;\r\n\r\n\t\t}\r\n\r\n\t\t// Fetch the opposite color and lerp by hand.\r\n\t\tcolor = texture2D(tDiffuse, vUv, 0.0);\r\n\t\tvec2 coord = vUv + sign(offset) * texelSize;\r\n\t\tvec4 oppositeColor = texture2D(tDiffuse, coord, 0.0);\r\n\t\tfloat s = abs(offset.x) > abs(offset.y) ? abs(offset.x) : abs(offset.y);\r\n\r\n\t\t// Gamma correction.\r\n\t\tcolor.rgb = pow(abs(color.rgb), vec3(2.2));\r\n\t\toppositeColor.rgb = pow(abs(oppositeColor.rgb), vec3(2.2));\r\n\t\tcolor = mix(color, oppositeColor, s);\r\n\t\tcolor.rgb = pow(abs(color.rgb), vec3(1.0 / 2.2));\r\n\r\n\t}\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n";var vertex$17="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\r\n\tvOffset = uv.xyxy + texelSize.xyxy * vec4(1.0, 0.0, 0.0, -1.0); // Changed sign in W component.\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* Subpixel Morphological Antialiasing.
*
* This material is used to render the final antialiasing.
*/var SMAABlendMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new SMAA blend material.
*
* @param {Vector2} [texelSize] - The absolute screen texel size.
*/function SMAABlendMaterial(){var texelSize=arguments.length>0&&arguments[0]!==undefined?arguments[0]:new Vector2();classCallCheck(this,SMAABlendMaterial);return possibleConstructorReturn(this,getPrototypeOf$2(SMAABlendMaterial).call(this,{type:"SMAABlendMaterial",uniforms:{tDiffuse:new Uniform(null),tWeights:new Uniform(null),texelSize:new Uniform(texelSize)},fragmentShader:fragment$17,vertexShader:vertex$17,depthWrite:false,depthTest:false}));}inherits(SMAABlendMaterial,_ShaderMaterial);return SMAABlendMaterial;}(ShaderMaterial);var fragment$18="#define sampleLevelZeroOffset(t, coord, offset) texture2D(t, coord + float(offset) * texelSize, 0.0)\r\n\r\nuniform sampler2D tDiffuse;\r\nuniform sampler2D tArea;\r\nuniform sampler2D tSearch;\r\n\r\nuniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\nvarying vec2 vPixCoord;\r\n\r\nvec2 round(vec2 x) {\r\n\r\n\treturn sign(x) * floor(abs(x) + 0.5);\r\n\r\n}\r\n\r\nfloat searchLength(vec2 e, float bias, float scale) {\r\n\r\n\t// Not required if tSearch accesses are set to point.\r\n\t// const vec2 SEARCH_TEX_PIXEL_SIZE = 1.0 / vec2(66.0, 33.0);\r\n\t// e = vec2(bias, 0.0) + 0.5 * SEARCH_TEX_PIXEL_SIZE + e * vec2(scale, 1.0) * vec2(64.0, 32.0) * SEARCH_TEX_PIXEL_SIZE;\r\n\r\n\te.r = bias + e.r * scale;\r\n\r\n\treturn 255.0 * texture2D(tSearch, e, 0.0).r;\r\n\r\n}\r\n\r\nfloat searchXLeft(vec2 texCoord, float end) {\r\n\r\n\t/* @PSEUDO_GATHER4\r\n\t * This texCoord has been offset by (-0.25, -0.125) in the vertex shader to\r\n\t * sample between edge, thus fetching four edges in a row.\r\n\t * Sampling with different offsets in each direction allows to disambiguate\r\n\t * which edges are active from the four fetched ones.\r\n\t */\r\n\r\n\tvec2 e = vec2(0.0, 1.0);\r\n\r\n\tfor(int i = 0; i < MAX_SEARCH_STEPS_INT; ++i) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord -= vec2(2.0, 0.0) * texelSize;\r\n\r\n\t\tif(!(texCoord.x > end && e.g > 0.8281 && e.r == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\t// Correct the previously applied offset (-0.25, -0.125).\r\n\ttexCoord.x += 0.25 * texelSize.x;\r\n\r\n\t// The searches are biased by 1, so adjust the coords accordingly.\r\n\ttexCoord.x += texelSize.x;\r\n\r\n\t// Disambiguate the length added by the last step.\r\n\ttexCoord.x += 2.0 * texelSize.x; // Undo last step.\r\n\ttexCoord.x -= texelSize.x * searchLength(e, 0.0, 0.5);\r\n\r\n\treturn texCoord.x;\r\n\r\n}\r\n\r\nfloat searchXRight(vec2 texCoord, float end) {\r\n\r\n\tvec2 e = vec2(0.0, 1.0);\r\n\r\n\tfor(int i = 0; i < MAX_SEARCH_STEPS_INT; ++i) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord += vec2(2.0, 0.0) * texelSize;\r\n\r\n\t\tif(!(texCoord.x < end && e.g > 0.8281 && e.r == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\ttexCoord.x -= 0.25 * texelSize.x;\r\n\ttexCoord.x -= texelSize.x;\r\n\ttexCoord.x -= 2.0 * texelSize.x;\r\n\ttexCoord.x += texelSize.x * searchLength(e, 0.5, 0.5);\r\n\r\n\treturn texCoord.x;\r\n\r\n}\r\n\r\nfloat searchYUp(vec2 texCoord, float end) {\r\n\r\n\tvec2 e = vec2(1.0, 0.0);\r\n\r\n\tfor(int i = 0; i < MAX_SEARCH_STEPS_INT; ++i) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord += vec2(0.0, 2.0) * texelSize; // Changed sign.\r\n\r\n\t\tif(!(texCoord.y > end && e.r > 0.8281 && e.g == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\ttexCoord.y -= 0.25 * texelSize.y; // Changed sign.\r\n\ttexCoord.y -= texelSize.y; // Changed sign.\r\n\ttexCoord.y -= 2.0 * texelSize.y; // Changed sign.\r\n\ttexCoord.y += texelSize.y * searchLength(e.gr, 0.0, 0.5); // Changed sign.\r\n\r\n\treturn texCoord.y;\r\n\r\n}\r\n\r\nfloat searchYDown(vec2 texCoord, float end) {\r\n\r\n\tvec2 e = vec2(1.0, 0.0);\r\n\r\n\tfor(int i = 0; i < MAX_SEARCH_STEPS_INT; ++i ) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord -= vec2(0.0, 2.0) * texelSize; // Changed sign.\r\n\r\n\t\tif(!(texCoord.y < end && e.r > 0.8281 && e.g == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\ttexCoord.y += 0.25 * texelSize.y; // Changed sign.\r\n\ttexCoord.y += texelSize.y; // Changed sign.\r\n\ttexCoord.y += 2.0 * texelSize.y; // Changed sign.\r\n\ttexCoord.y -= texelSize.y * searchLength(e.gr, 0.5, 0.5); // Changed sign.\r\n\r\n\treturn texCoord.y;\r\n\r\n}\r\n\r\nvec2 area(vec2 dist, float e1, float e2, float offset) {\r\n\r\n\t// Rounding prevents precision errors of bilinear filtering.\r\n\tvec2 texCoord = AREATEX_MAX_DISTANCE * round(4.0 * vec2(e1, e2)) + dist;\r\n\r\n\t// Scale and bias for texel space translation.\r\n\ttexCoord = AREATEX_PIXEL_SIZE * texCoord + (0.5 * AREATEX_PIXEL_SIZE);\r\n\r\n\t// Move to proper place, according to the subpixel offset.\r\n\ttexCoord.y += AREATEX_SUBTEX_SIZE * offset;\r\n\r\n\treturn texture2D(tArea, texCoord, 0.0).rg;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec4 weights = vec4(0.0);\r\n\tvec4 subsampleIndices = vec4(0.0);\r\n\tvec2 e = texture2D(tDiffuse, vUv).rg;\r\n\r\n\tif(e.g > 0.0) {\r\n\r\n\t\t// Edge at north.\r\n\t\tvec2 d;\r\n\r\n\t\t// Find the distance to the left.\r\n\t\tvec2 coords;\r\n\t\tcoords.x = searchXLeft(vOffset[0].xy, vOffset[2].x);\r\n\t\tcoords.y = vOffset[1].y; // vOffset[1].y = vUv.y - 0.25 * texelSize.y (@CROSSING_OFFSET)\r\n\t\td.x = coords.x;\r\n\r\n\t\t/* Now fetch the left crossing edges, two at a time using bilinear\r\n\t\tfiltering. Sampling at -0.25 (see @CROSSING_OFFSET) enables to discern what\r\n\t\tvalue each edge has. */\r\n\t\tfloat e1 = texture2D(tDiffuse, coords, 0.0).r;\r\n\r\n\t\t// Find the distance to the right.\r\n\t\tcoords.x = searchXRight(vOffset[0].zw, vOffset[2].y);\r\n\t\td.y = coords.x;\r\n\r\n\t\t/* Translate distances to pixel units for better interleave arithmetic and\r\n\t\tmemory accesses. */\r\n\t\td = d / texelSize.x - vPixCoord.x;\r\n\r\n\t\t// The area texture is compressed quadratically.\r\n\t\tvec2 sqrtD = sqrt(abs(d));\r\n\r\n\t\t// Fetch the right crossing edges.\r\n\t\tcoords.y -= texelSize.y; // WebGL port note: Added.\r\n\t\tfloat e2 = sampleLevelZeroOffset(tDiffuse, coords, ivec2(1, 0)).r;\r\n\r\n\t\t// Pattern recognised, now get the actual area.\r\n\t\tweights.rg = area(sqrtD, e1, e2, subsampleIndices.y);\r\n\r\n\t}\r\n\r\n\tif(e.r > 0.0) {\r\n\r\n\t\t// Edge at west.\r\n\t\tvec2 d;\r\n\r\n\t\t// Find the distance to the top.\r\n\t\tvec2 coords;\r\n\t\tcoords.y = searchYUp(vOffset[1].xy, vOffset[2].z);\r\n\t\tcoords.x = vOffset[0].x; // vOffset[1].x = vUv.x - 0.25 * texelSize.x;\r\n\t\td.x = coords.y;\r\n\r\n\t\t// Fetch the top crossing edges.\r\n\t\tfloat e1 = texture2D(tDiffuse, coords, 0.0).g;\r\n\r\n\t\t// Find the distance to the bottom.\r\n\t\tcoords.y = searchYDown(vOffset[1].zw, vOffset[2].w);\r\n\t\td.y = coords.y;\r\n\r\n\t\t// Distances in pixel units.\r\n\t\td = d / texelSize.y - vPixCoord.y;\r\n\r\n\t\t// The area texture is compressed quadratically.\r\n\t\tvec2 sqrtD = sqrt(abs(d));\r\n\r\n\t\t// Fetch the bottom crossing edges.\r\n\t\tcoords.y -= texelSize.y; // WebGL port note: Added.\r\n\t\tfloat e2 = sampleLevelZeroOffset(tDiffuse, coords, ivec2(0, 1)).g;\r\n\r\n\t\t// Get the area for this direction.\r\n\t\tweights.ba = area(sqrtD, e1, e2, subsampleIndices.x);\r\n\r\n\t}\r\n\r\n\tgl_FragColor = weights;\r\n\r\n}\r\n";var vertex$18="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\nvarying vec2 vPixCoord;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\r\n\tvPixCoord = uv / texelSize;\r\n\r\n\t// Offsets for the searches (see @PSEUDO_GATHER4).\r\n\tvOffset[0] = uv.xyxy + texelSize.xyxy * vec4(-0.25, 0.125, 1.25, 0.125); // Changed sign in Y and W components.\r\n\tvOffset[1] = uv.xyxy + texelSize.xyxy * vec4(-0.125, 0.25, -0.125, -1.25); //Changed sign in Y and W components.\r\n\r\n\t// This indicates the ends of the loops.\r\n\tvOffset[2] = vec4(vOffset[0].xz, vOffset[1].yw) + vec4(-2.0, 2.0, -2.0, 2.0) * texelSize.xxyy * MAX_SEARCH_STEPS_FLOAT;\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* Subpixel Morphological Antialiasing.
*
* This material computes weights for detected edges.
*/var SMAAWeightsMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new SMAA weights material.
*
* @param {Vector2} [texelSize] - The absolute screen texel size.
*/function SMAAWeightsMaterial(){var texelSize=arguments.length>0&&arguments[0]!==undefined?arguments[0]:new Vector2();classCallCheck(this,SMAAWeightsMaterial);return possibleConstructorReturn(this,getPrototypeOf$2(SMAAWeightsMaterial).call(this,{type:"SMAAWeightsMaterial",defines:{// Configurable settings:
MAX_SEARCH_STEPS_INT:"8",MAX_SEARCH_STEPS_FLOAT:"8.0",// Non-configurable settings:
AREATEX_MAX_DISTANCE:"16.0",AREATEX_PIXEL_SIZE:"(1.0 / vec2(160.0, 560.0))",AREATEX_SUBTEX_SIZE:"(1.0 / 7.0)",SEARCHTEX_SIZE:"vec2(66.0, 33.0)",SEARCHTEX_PACKED_SIZE:"vec2(64.0, 16.0)"},uniforms:{tDiffuse:new Uniform(null),tArea:new Uniform(null),tSearch:new Uniform(null),texelSize:new Uniform(texelSize)},fragmentShader:fragment$18,vertexShader:vertex$18,depthWrite:false,depthTest:false}));}/**
* Sets the maximum amount of steps performed in the horizontal/vertical
* pattern searches, at each side of the pixel.
*
* In number of pixels, it's actually the double. So the maximum line length
* perfectly handled by, for example 16, is 64 (perfectly means that longer
* lines won't look as good, but are still antialiased).
*
* @param {Number} steps - The search steps. Range: [0, 112].
*/createClass(SMAAWeightsMaterial,[{key:"setOrthogonalSearchSteps",value:function setOrthogonalSearchSteps(steps){this.defines.MAX_SEARCH_STEPS_INT=steps.toFixed("0");this.defines.MAX_SEARCH_STEPS_FLOAT=steps.toFixed("1");this.needsUpdate=true;}}]);inherits(SMAAWeightsMaterial,_ShaderMaterial);return SMAAWeightsMaterial;}(ShaderMaterial);var fragment$19="#include <common>\r\n#include <dithering_pars_fragment>\r\n\r\nuniform sampler2D tDiffuse;\r\nuniform float middleGrey;\r\nuniform float maxLuminance;\r\n\r\n#ifdef ADAPTED_LUMINANCE\r\n\r\n\tuniform sampler2D luminanceMap;\r\n\r\n#else\r\n\r\n\tuniform float averageLuminance;\r\n\r\n#endif\r\n\r\nvarying vec2 vUv;\r\n\r\nvec3 toneMap(vec3 c) {\r\n\r\n\t#ifdef ADAPTED_LUMINANCE\r\n\r\n\t\t// Get the calculated average luminance by sampling the center.\r\n\t\tfloat lumAvg = texture2D(luminanceMap, vec2(0.5)).r;\r\n\r\n\t#else\r\n\r\n\t\tfloat lumAvg = averageLuminance;\r\n\r\n\t#endif\r\n\r\n\t// Calculate the luminance of the current pixel.\r\n\tfloat lumPixel = linearToRelativeLuminance(c);\r\n\r\n\t// Apply the modified operator (Reinhard Eq. 4).\r\n\tfloat lumScaled = (lumPixel * middleGrey) / lumAvg;\r\n\r\n\tfloat lumCompressed = (lumScaled * (1.0 + (lumScaled / (maxLuminance * maxLuminance)))) / (1.0 + lumScaled);\r\n\r\n\treturn lumCompressed * c;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tgl_FragColor = vec4(toneMap(texel.rgb), texel.a);\r\n\r\n\t#include <dithering_fragment>\r\n\r\n}\r\n";var vertex$19="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n";/**
* Full-screen tone-mapping shader material.
*
* This material supports dithering.
*
* Reference:
* http://www.cis.rit.edu/people/faculty/ferwerda/publications/sig02_paper.pdf
*/var ToneMappingMaterial=/*#__PURE__*/function(_ShaderMaterial){/**
* Constructs a new tone mapping material.
*/function ToneMappingMaterial(){classCallCheck(this,ToneMappingMaterial);return possibleConstructorReturn(this,getPrototypeOf$2(ToneMappingMaterial).call(this,{type:"ToneMappingMaterial",uniforms:{tDiffuse:new Uniform(null),luminanceMap:new Uniform(null),averageLuminance:new Uniform(1.0),maxLuminance:new Uniform(16.0),middleGrey:new Uniform(0.6)},fragmentShader:fragment$19,vertexShader:vertex$19,depthWrite:false,depthTest:false}));}inherits(ToneMappingMaterial,_ShaderMaterial);return ToneMappingMaterial;}(ShaderMaterial);/**
* A collection of shader materials that are used in the post processing passes.
*
* @module postprocessing/materials
*/ /**
* An abstract pass.
*
* Passes that do not rely on the depth buffer should explicitly disable the
* depth test and depth write in their respective shader materials.
*
* @implements {Resizable}
* @implements {Disposable}
*/var Pass=/*#__PURE__*/function(){/**
* Constructs a new pass.
*
* @param {String} [name] - The name of this pass.
* @param {Scene} [scene] - The scene to render.
* @param {Camera} [camera] - The camera.
* @param {Mesh} [quad] - A quad that fills the screen to render 2D filter effects. Set this to null, if you don't need it (see {@link RenderPass}).
*/function Pass(){var name=arguments.length>0&&arguments[0]!==undefined?arguments[0]:"Pass";var scene=arguments.length>1&&arguments[1]!==undefined?arguments[1]:new Scene();var camera=arguments.length>2&&arguments[2]!==undefined?arguments[2]:new OrthographicCamera(-1,1,1,-1,0,1);var quad=arguments.length>3&&arguments[3]!==undefined?arguments[3]:new Mesh(new PlaneBufferGeometry(2,2),null);classCallCheck(this,Pass);/**
* The name of this pass.
*
* @type {String}
*/this.name=name;/**
* The scene to render.
*
* @type {Scene}
* @protected
*/this.scene=scene;/**
* The camera.
*
* @type {Camera}
* @protected
*/this.camera=camera;/**
* A quad mesh that fills the screen.
*
* @type {Mesh}
* @private
*/this.quad=quad;if(this.quad!==null){this.quad.frustumCulled=false;if(this.scene!==null){this.scene.add(this.quad);}}/**
* Indicates whether this pass should render to screen.
*
* @type {Boolean}
*/this.renderToScreen=false;/**
* Indicates whether this pass should be executed.
*
* @type {Boolean}
*/this.enabled=true;/**
* Indicates whether the {@link EffectComposer} should swap the frame
* buffers after this pass has finished rendering.
*
* Set this to `false` if this pass doesn't render to the output buffer or
* the screen. Otherwise, the contents of the input buffer will be lost.
*
* @type {Boolean}
*/this.needsSwap=true;}/**
* The fullscreen material.
*
* @type {Material}
*/createClass(Pass,[{key:"render",/**
* Renders the effect.
*
* This is an abstract method that must be overridden.
*
* @abstract
* @throws {Error} An error is thrown if the method is not overridden.
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){throw new Error("Render method not implemented!");}/**
* Updates this pass with the renderer's size.
*
* You may override this method in case you want to be informed about the main
* render size.
*
* The {@link EffectComposer} calls this method before this pass is
* initialized and every time its own size is updated.
*
* @param {Number} width - The renderer's width.
* @param {Number} height - The renderer's height.
* @example this.myRenderTarget.setSize(width, height);
*/},{key:"setSize",value:function setSize(width,height){}/**
* Performs initialization tasks.
*
* By overriding this method you gain access to the renderer. You'll also be
* able to configure your custom render targets to use the appropriate format
* (RGB or RGBA).
*
* The provided renderer can be used to warm up special off-screen render
* targets by performing a preliminary render operation.
*
* The {@link EffectComposer} calls this method when this pass is added to its
* queue, but not before its size has been set.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.
* @example if(!alpha) { this.myRenderTarget.texture.format = RGBFormat; }
*/},{key:"initialize",value:function initialize(renderer,alpha){}/**
* Performs a shallow search for properties that define a dispose method and
* deletes them. The pass will be inoperative after this method was called!
*
* Disposable objects:
* - render targets
* - materials
* - textures
*
* The {@link EffectComposer} calls this method when it is being destroyed.
* You may, however, use it independently to free memory when you are certain
* that you don't need this pass anymore.
*/},{key:"dispose",value:function dispose(){var key;var _arr=Object.keys(this);for(var _i=0;_i<_arr.length;_i++){key=_arr[_i];if(this[key]!==null&&typeof this[key].dispose==="function"){this[key].dispose();this[key]=null;}}if(this.material!==null){this.material.dispose();}}},{key:"material",get:function get(){return this.quad!==null?this.quad.material:null;}/**
* Sets the fullscreen material.
*
* The material will be assigned to the quad mesh that fills the screen.
*
* @type {Material}
*/,set:function set(value){if(this.quad!==null){this.quad.material=value;}}}]);return Pass;}();/**
* An efficient, incremental blur pass.
*
* Note: This pass allows the input and output buffer to be the same.
*/var BlurPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new blur pass.
*
* @param {Object} [options] - The options.
* @param {Number} [options.resolutionScale=0.5] - The render texture resolution scale, relative to the screen render size.
* @param {Number} [options.kernelSize=KernelSize.LARGE] - The blur kernel size.
*/function BlurPass(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,BlurPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(BlurPass).call(this,"BlurPass"));/**
* A render target.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetX=new WebGLRenderTarget(1,1,{minFilter:LinearFilter,magFilter:LinearFilter,stencilBuffer:false,depthBuffer:false});_this.renderTargetX.texture.name="Blur.TargetX";_this.renderTargetX.texture.generateMipmaps=false;/**
* A second render target.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetY=_this.renderTargetX.clone();_this.renderTargetY.texture.name="Blur.TargetY";/**
* The resolution scale.
*
* You need to call {@link EffectComposer#setSize} after changing this
* value.
*
* @type {Number}
*/_this.resolutionScale=options.resolutionScale!==undefined?options.resolutionScale:0.5;/**
* A convolution shader material.
*
* @type {ConvolutionMaterial}
* @private
*/_this.convolutionMaterial=new ConvolutionMaterial();/**
* A convolution shader material that uses dithering.
*
* @type {ConvolutionMaterial}
* @private
*/_this.ditheredConvolutionMaterial=new ConvolutionMaterial();_this.ditheredConvolutionMaterial.dithering=true;/**
* Whether the blurred result should also be dithered using noise.
*
* @type {Boolean}
*/_this.dithering=false;_this.kernelSize=options.kernelSize;return _this;}/**
* The absolute width of the internal render targets.
*
* @type {Number}
*/createClass(BlurPass,[{key:"render",/**
* Blurs the input buffer and writes the result to the output buffer. The
* input buffer remains intact, unless its also the output buffer.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var scene=this.scene;var camera=this.camera;var renderTargetX=this.renderTargetX;var renderTargetY=this.renderTargetY;var material=this.convolutionMaterial;var uniforms=material.uniforms;var kernel=material.getKernel();var lastRT=inputBuffer;var destRT;var i,l;this.material=material;// Apply the multi-pass blur.
for(i=0,l=kernel.length-1;i<l;++i){// Alternate between targets.
destRT=i%2===0?renderTargetX:renderTargetY;uniforms.kernel.value=kernel[i];uniforms.tDiffuse.value=lastRT.texture;renderer.render(scene,camera,destRT);lastRT=destRT;}if(this.dithering){material=this.ditheredConvolutionMaterial;uniforms=material.uniforms;this.material=material;}uniforms.kernel.value=kernel[i];uniforms.tDiffuse.value=lastRT.texture;renderer.render(scene,camera,this.renderToScreen?null:outputBuffer);}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){width=Math.max(1,Math.floor(width*this.resolutionScale));height=Math.max(1,Math.floor(height*this.resolutionScale));this.renderTargetX.setSize(width,height);this.renderTargetY.setSize(width,height);this.convolutionMaterial.setTexelSize(1.0/width,1.0/height);this.ditheredConvolutionMaterial.setTexelSize(1.0/width,1.0/height);}/**
* Performs initialization tasks.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.
*/},{key:"initialize",value:function initialize(renderer,alpha){if(!alpha){this.renderTargetX.texture.format=RGBFormat;this.renderTargetY.texture.format=RGBFormat;}}},{key:"width",get:function get(){return this.renderTargetX.width;}/**
* The absolute height of the internal render targets.
*
* @type {Number}
*/},{key:"height",get:function get(){return this.renderTargetX.height;}/**
* The kernel size.
*
* @type {KernelSize}
*/},{key:"kernelSize",get:function get(){return this.convolutionMaterial.kernelSize;}/**
* @type {KernelSize}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:KernelSize.LARGE;this.convolutionMaterial.kernelSize=value;this.ditheredConvolutionMaterial.kernelSize=value;}}]);inherits(BlurPass,_Pass);return BlurPass;}(Pass);/**
* A bloom pass.
*
* This pass renders a scene with superimposed blur by utilizing the fast Kawase
* convolution approach.
*/var BloomPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new bloom pass.
*
* @param {Object} [options] - The options.
* @param {Number} [options.resolutionScale=0.5] - The render texture resolution scale, relative to the screen render size.
* @param {Number} [options.kernelSize=KernelSize.LARGE] - The blur kernel size.
* @param {Number} [options.intensity=1.0] - The strength of the bloom effect.
* @param {Number} [options.distinction=1.0] - The luminance distinction factor. Raise this value to bring out the brighter elements in the scene.
* @param {Number} [options.screenMode=true] - Whether the screen blend mode should be used for combining the bloom texture with the scene colors.
*/function BloomPass(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,BloomPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(BloomPass).call(this,"BloomPass"));/**
* A render target.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTarget=new WebGLRenderTarget(1,1,{minFilter:LinearFilter,magFilter:LinearFilter,stencilBuffer:false,depthBuffer:false});_this.renderTarget.texture.name="Bloom.Target";_this.renderTarget.texture.generateMipmaps=false;/**
* A blur pass.
*
* @type {BlurPass}
* @private
*/_this.blurPass=new BlurPass(options);/**
* A combine shader material.
*
* @type {CombineMaterial}
* @private
*/_this.combineMaterial=new CombineMaterial(options.screenMode!==undefined?options.screenMode:true);_this.intensity=options.intensity;/**
* A luminosity shader material.
*
* @type {LuminosityMaterial}
* @private
*/_this.luminosityMaterial=new LuminosityMaterial(true);_this.distinction=options.distinction;return _this;}/**
* The resolution scale.
*
* @type {Number}
*/createClass(BloomPass,[{key:"render",/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var scene=this.scene;var camera=this.camera;var blurPass=this.blurPass;var luminosityMaterial=this.luminosityMaterial;var combineMaterial=this.combineMaterial;var renderTarget=this.renderTarget;// Luminance filter.
this.material=luminosityMaterial;luminosityMaterial.uniforms.tDiffuse.value=inputBuffer.texture;renderer.render(scene,camera,renderTarget);// Convolution phase.
blurPass.render(renderer,renderTarget,renderTarget);if(this.blend){// Render the original scene with superimposed blur.
this.material=combineMaterial;combineMaterial.uniforms.texture1.value=inputBuffer.texture;combineMaterial.uniforms.texture2.value=renderTarget.texture;renderer.render(scene,camera,this.renderToScreen?null:outputBuffer);}}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){this.blurPass.setSize(width,height);width=this.blurPass.width;height=this.blurPass.height;this.renderTarget.setSize(width,height);}/**
* Performs initialization tasks.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.
*/},{key:"initialize",value:function initialize(renderer,alpha){this.blurPass.initialize(renderer,alpha);if(!alpha){this.renderTarget.texture.format=RGBFormat;}}},{key:"resolutionScale",get:function get(){return this.blurPass.resolutionScale;}/**
* You need to call {@link EffectComposer#setSize} after changing this value.
*
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:0.5;this.blurPass.resolutionScale=value;}/**
* The blur kernel size.
*
* @type {KernelSize}
*/},{key:"kernelSize",get:function get(){return this.blurPass.kernelSize;}/**
* @type {KernelSize}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:KernelSize.LARGE;this.blurPass.kernelSize=value;}/**
* The overall intensity of the effect.
*
* @type {Number}
*/},{key:"intensity",get:function get(){return this.combineMaterial.uniforms.opacity2.value;}/**
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1.0;this.combineMaterial.uniforms.opacity2.value=value;}/**
* The luminance distinction factor.
*
* @type {Number}
*/},{key:"distinction",get:function get(){return this.luminosityMaterial.uniforms.distinction.value;}/**
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1.0;this.luminosityMaterial.uniforms.distinction.value=value;}/**
* Indicates whether dithering is enabled.
*
* @type {Boolean}
*/},{key:"dithering",get:function get(){return this.blurPass.dithering;}/**
* If enabled, the result will be dithered to remove banding artifacts.
*
* @type {Boolean}
*/,set:function set(value){this.blurPass.dithering=value;}/**
* Indicates whether the effect should be applied to the input buffer.
*
* @type {Boolean}
*/},{key:"blend",get:function get(){return this.needsSwap;}/**
* If disabled, the input buffer will remain unaffected.
*
* You may use the {@link BloomPass#overlay} texture to apply the effect to
* your scene.
*
* @type {Boolean}
*/,set:function set(value){this.needsSwap=value;}/**
* The effect overlay texture.
*
* @type {Texture}
*/},{key:"overlay",get:function get(){return this.renderTarget.texture;}}]);inherits(BloomPass,_Pass);return BloomPass;}(Pass);/**
* A Depth of Field (DoF) pass using a bokeh shader.
*
* This pass requires a {@link EffectComposer#depthTexture}.
*/var BokehPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new bokeh pass.
*
* @param {PerspectiveCamera} camera - The main camera. Used to obtain the aspect ratio and the near and far plane settings.
* @param {Object} [options] - Additional parameters. See {@link BokehMaterial} for details.
*/function BokehPass(camera){var _this;var options=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};classCallCheck(this,BokehPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(BokehPass).call(this,"BokehPass"));_this.material=new BokehMaterial(camera,options);return _this;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(BokehPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){this.material.uniforms.tDiffuse.value=inputBuffer.texture;this.material.uniforms.tDepth.value=inputBuffer.depthTexture;renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){this.material.uniforms.aspect.value=width/height;}}]);inherits(BokehPass,_Pass);return BokehPass;}(Pass);/**
* A pass that disables the stencil test.
*/var ClearMaskPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new clear mask pass.
*/function ClearMaskPass(){var _this;classCallCheck(this,ClearMaskPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(ClearMaskPass).call(this,"ClearMaskPass",null,null,null));_this.needsSwap=false;return _this;}/**
* Disables the global stencil test.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(ClearMaskPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){renderer.state.buffers.stencil.setTest(false);}}]);inherits(ClearMaskPass,_Pass);return ClearMaskPass;}(Pass);/**
* Used for saving the original clear color of the renderer.
*
* @type {Color}
* @private
*/var color=new Color();/**
* A pass that clears the input buffer or the screen.
*
* You can prevent specific bits from being cleared by setting either the
* autoClearColor, autoClearStencil or autoClearDepth properties of the renderer
* to false.
*/var ClearPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new clear pass.
*
* @param {Object} [options] - Additional options.
* @param {Color} [options.clearColor=null] - An override clear color.
* @param {Number} [options.clearAlpha=0.0] - An override clear alpha.
*/function ClearPass(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,ClearPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(ClearPass).call(this,"ClearPass",null,null,null));_this.needsSwap=false;/**
* The clear color.
*
* @type {Color}
*/_this.clearColor=options.clearColor!==undefined?options.clearColor:null;/**
* The clear alpha.
*
* @type {Number}
*/_this.clearAlpha=options.clearAlpha!==undefined?options.clearAlpha:0.0;return _this;}/**
* Clears the input buffer or the screen.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(ClearPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var clearColor=this.clearColor;var clearAlpha;if(clearColor!==null){color.copy(renderer.getClearColor());clearAlpha=renderer.getClearAlpha();renderer.setClearColor(clearColor,this.clearAlpha);}renderer.setRenderTarget(this.renderToScreen?null:inputBuffer);renderer.clear();if(clearColor!==null){renderer.setClearColor(color,clearAlpha);}}}]);inherits(ClearPass,_Pass);return ClearPass;}(Pass);/**
* A dot screen pass.
*/var DotScreenPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new dot screen pass.
*
* @param {Object} [options] - The options.
* @param {Boolean} [options.average=false] - Whether the shader should output a colour average (black and white).
* @param {Number} [options.angle=1.57] - The angle of the pattern.
* @param {Number} [options.scale=1.0] - The scale of the overall effect.
* @param {Number} [options.intensity=1.0] - The intensity of the effect.
*/function DotScreenPass(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,DotScreenPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(DotScreenPass).call(this,"DotScreenPass"));_this.material=new DotScreenMaterial(options);return _this;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(DotScreenPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){this.material.uniforms.tDiffuse.value=inputBuffer.texture;renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){width=Math.max(1,width);height=Math.max(1,height);this.material.uniforms.offsetRepeat.value.z=width;this.material.uniforms.offsetRepeat.value.w=height;}}]);inherits(DotScreenPass,_Pass);return DotScreenPass;}(Pass);/**
* A film pass.
*
* Provides various cinematic effects.
*/var FilmPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new film pass.
*
* @param {Object} [options] - The options. See {@link FilmMaterial} for more options.
* @param {Number} [options.scanlineDensity=1.25] - The scanline density, relative to the screen height.
* @param {Number} [options.gridScale=1.0] - The grid scale, relative to the screen height.
* @param {Number} [options.gridLineWidth=0.0] - The grid line width. This value will be added to the base line width.
*/function FilmPass(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,FilmPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(FilmPass).call(this,"FilmPass"));_this.material=new FilmMaterial(options);/**
* The amount of scanlines, relative to the screen height.
*
* You need to call {@link EffectComposer#setSize} after changing this
* value.
*
* @type {Number}
*/_this.scanlineDensity=options.scanlineDensity===undefined?1.25:options.scanlineDensity;/**
* The grid scale, relative to the screen height.
*
* You need to call {@link EffectComposer#setSize} after changing this
* value.
*
* @type {Number}
*/_this.gridScale=options.gridScale===undefined?1.0:Math.max(options.gridScale,1e-6);/**
* The grid line width.
*
* You need to call {@link EffectComposer#setSize} after changing this
* value.
*
* @type {Number}
*/_this.gridLineWidth=options.gridLineWidth===undefined?0.0:Math.max(options.gridLineWidth,0.0);return _this;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(FilmPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){this.material.uniforms.tDiffuse.value=inputBuffer.texture;this.material.uniforms.time.value+=delta;renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){var aspect=width/height;var gridScale=this.gridScale*(height*0.125);this.material.uniforms.scanlineCount.value=Math.round(height*this.scanlineDensity);this.material.uniforms.gridScale.value.set(aspect*gridScale,gridScale);this.material.uniforms.gridLineWidth.value=gridScale/height+this.gridLineWidth;}}]);inherits(FilmPass,_Pass);return FilmPass;}(Pass);/**
* Returns a random integer in the specified range.
*
* @private
* @param {Number} low - The lowest possible value.
* @param {Number} high - The highest possible value.
* @return {Number} The random value.
*/function randomInt(low,high){return low+Math.floor(Math.random()*(high-low+1));}/**
* Returns a random float in the specified range.
*
* @private
* @param {Number} low - The lowest possible value.
* @param {Number} high - The highest possible value.
* @return {Number} The random value.
*/function randomFloat(low,high){return low+Math.random()*(high-low);}/**
* A glitch pass.
*/var GlitchPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new glitch pass.
*
* @param {Object} [options] - The options.
* @param {Texture} [options.perturbMap] - A perturbation map. If none is provided, a noise texture will be created.
* @param {Number} [options.dtSize=64] - The size of the generated noise map. Will be ignored if a perturbation map is provided.
*/function GlitchPass(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,GlitchPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(GlitchPass).call(this,"GlitchPass"));_this.material=new GlitchMaterial();/**
* A perturbation map.
*
* @type {Texture}
* @private
*/_this.texture=null;_this.perturbMap=options.perturbMap!==undefined?options.perturbMap:_this.generatePerturbMap(options.dtSize);_this.perturbMap.name="Glitch.Perturbation";_this.perturbMap.generateMipmaps=false;/**
* The effect mode.
*
* @type {GlitchMode}
*/_this.mode=GlitchMode.SPORADIC;/**
* A counter for the glitch activation and deactivation.
*
* @type {Number}
* @private
*/_this.counter=0;/**
* A random break point for the sporadic glitch activation.
*
* @type {Number}
* @private
*/_this.breakPoint=randomInt(120,240);return _this;}/**
* The current perturbation map.
*
* @type {Texture}
*/createClass(GlitchPass,[{key:"generatePerturbMap",/**
* Destroys the current perturbation map and replaces it with a new one.
*
* @param {Number} [size=64] - The texture size.
* @return {DataTexture} The perturbation texture.
*/value:function generatePerturbMap(){var size=arguments.length>0&&arguments[0]!==undefined?arguments[0]:64;var pixels=size*size;var data=new Float32Array(pixels*3);var dt=this.perturbMap;var i,x;for(i=0;i<pixels;++i){x=Math.random();data[i*3]=x;data[i*3+1]=x;data[i*3+2]=x;}if(dt!==null){dt.dispose();}dt=new DataTexture(data,size,size,RGBFormat,FloatType);dt.needsUpdate=true;this.perturbMap=dt;return dt;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/},{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var mode=this.mode;var counter=this.counter;var breakPoint=this.breakPoint;var uniforms=this.material.uniforms;uniforms.tDiffuse.value=inputBuffer.texture;uniforms.seed.value=Math.random();uniforms.active.value=true;if(counter%breakPoint===0||mode===GlitchMode.CONSTANT_WILD){uniforms.amount.value=Math.random()/30.0;uniforms.angle.value=randomFloat(-Math.PI,Math.PI);uniforms.seedX.value=randomFloat(-1.0,1.0);uniforms.seedY.value=randomFloat(-1.0,1.0);uniforms.distortionX.value=randomFloat(0.0,1.0);uniforms.distortionY.value=randomFloat(0.0,1.0);this.breakPoint=randomInt(120,240);this.counter=0;}else{if(counter%breakPoint<breakPoint/5||mode===GlitchMode.CONSTANT_MILD){uniforms.amount.value=Math.random()/90.0;uniforms.angle.value=randomFloat(-Math.PI,Math.PI);uniforms.distortionX.value=randomFloat(0.0,1.0);uniforms.distortionY.value=randomFloat(0.0,1.0);uniforms.seedX.value=randomFloat(-0.3,0.3);uniforms.seedY.value=randomFloat(-0.3,0.3);}else{// Sporadic.
uniforms.active.value=false;}}++this.counter;renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}},{key:"perturbMap",get:function get(){return this.texture;}/**
* Assigning a new perturbation map does not destroy the current one!
*
* @type {Texture}
*/,set:function set(value){this.texture=value;this.material.uniforms.tPerturb.value=value;}}]);inherits(GlitchPass,_Pass);return GlitchPass;}(Pass);/**
* A glitch mode enumeration.
*
* @type {Object}
* @property {Number} SPORADIC - Sporadic glitches.
* @property {Number} CONSTANT_MILD - Constant mild glitches.
* @property {Number} CONSTANT_WILD - Constant wild glitches.
*/var GlitchMode={SPORADIC:0,CONSTANT_MILD:1,CONSTANT_WILD:2};/**
* A pass that renders a given scene directly on screen or into the read buffer
* for further processing.
*/var RenderPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new render pass.
*
* @param {Scene} scene - The scene to render.
* @param {Camera} camera - The camera to use to render the scene.
* @param {Object} [options] - Additional options.
* @param {Material} [options.overrideMaterial=null] - An override material for the scene.
* @param {Color} [options.clearColor=null] - An override clear color.
* @param {Number} [options.clearAlpha=1.0] - An override clear alpha.
* @param {Boolean} [options.clearDepth=false] - Whether depth should be cleared explicitly.
* @param {Boolean} [options.clear=true] - Whether all buffers should be cleared.
*/function RenderPass(scene,camera){var _this;var options=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{};classCallCheck(this,RenderPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(RenderPass).call(this,"RenderPass",scene,camera,null));_this.needsSwap=false;/**
* A clear pass.
*
* @type {ClearPass}
*/_this.clearPass=new ClearPass(options);/**
* An override material.
*
* @type {Material}
*/_this.overrideMaterial=options.overrideMaterial!==undefined?options.overrideMaterial:null;/**
* Indicates whether the depth buffer should be cleared explicitly.
*
* @type {Boolean}
*/_this.clearDepth=options.clearDepth!==undefined?options.clearDepth:false;/**
* Indicates whether the color, depth and stencil buffers should be cleared.
*
* Even with clear set to true you can prevent specific buffers from being
* cleared by setting either the autoClearColor, autoClearStencil or
* autoClearDepth properties of the renderer to false.
*
* @type {Boolean}
*/_this.clear=options.clear!==undefined?options.clear:true;return _this;}/**
* Renders the scene.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(RenderPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var scene=this.scene;var renderTarget=this.renderToScreen?null:inputBuffer;var overrideMaterial=scene.overrideMaterial;if(this.clear){this.clearPass.renderToScreen=this.renderToScreen;this.clearPass.render(renderer,inputBuffer);}else if(this.clearDepth){renderer.setRenderTarget(renderTarget);renderer.clearDepth();}scene.overrideMaterial=this.overrideMaterial;renderer.render(scene,this.camera,renderTarget);scene.overrideMaterial=overrideMaterial;}}]);inherits(RenderPass,_Pass);return RenderPass;}(Pass);/**
* Clamps a given value.
*
* @private
* @param {Number} value - The value to clamp.
* @param {Number} min - The lowest possible value.
* @param {Number} max - The highest possible value.
* @return {Number} The clamped value.
*/function clamp(value,min,max){return Math.max(min,Math.min(max,value));}/**
* A crepuscular rays pass.
*/var GodRaysPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new god rays pass.
*
* @param {Scene} scene - The main scene.
* @param {Camera} camera - The main camera.
* @param {Object3D} lightSource - The main light source.
* @param {Object} [options] - The options.
* @param {Number} [options.density=0.96] - The density of the light rays.
* @param {Number} [options.decay=0.93] - An illumination decay factor.
* @param {Number} [options.weight=0.4] - A light ray weight factor.
* @param {Number} [options.exposure=0.6] - A constant attenuation coefficient.
* @param {Number} [options.clampMax=1.0] - An upper bound for the saturation of the overall effect.
* @param {Number} [options.intensity=1.0] - A constant factor for additive blending.
* @param {Number} [options.resolutionScale=0.5] - The render texture resolution scale, relative to the screen render size.
* @param {Number} [options.kernelSize=KernelSize.LARGE] - The blur kernel size.
* @param {Number} [options.samples=60] - The number of samples per pixel.
* @param {Number} [options.screenMode=true] - Whether the screen blend mode should be used for combining the god rays texture with the scene colors.
*/function GodRaysPass(scene,camera,lightSource){var _this;var options=arguments.length>3&&arguments[3]!==undefined?arguments[3]:{};classCallCheck(this,GodRaysPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(GodRaysPass).call(this,"GodRaysPass"));/**
* A scene that only contains the light source.
*
* @type {Scene}
* @private
*/_this.lightScene=new Scene();/**
* The main scene.
*
* @type {Scene}
* @private
*/_this.mainScene=scene;/**
* The main camera.
*
* @type {Camera}
* @private
*/_this.mainCamera=camera;/**
* A render target.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetX=new WebGLRenderTarget(1,1,{minFilter:LinearFilter,magFilter:LinearFilter,stencilBuffer:false,depthBuffer:false});_this.renderTargetX.texture.name="GodRays.TargetX";_this.renderTargetX.texture.generateMipmaps=false;/**
* A second render target.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetY=_this.renderTargetX.clone();_this.renderTargetY.texture.name="GodRays.TargetY";/**
* A render target for the masked light scene.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetMask=new WebGLRenderTarget(1,1,{minFilter:LinearFilter,magFilter:LinearFilter});_this.renderTargetMask.texture.name="GodRays.Mask";_this.renderTargetMask.texture.generateMipmaps=false;/**
* A pass that only renders the light source.
*
* @type {RenderPass}
* @private
*/_this.renderPassLight=new RenderPass(_this.lightScene,_this.mainCamera,{clearColor:new Color(0x000000)});/**
* A pass that renders the masked scene over the light.
*
* @type {RenderPass}
* @private
*/_this.renderPassMask=new RenderPass(_this.mainScene,_this.mainCamera,{overrideMaterial:new MeshBasicMaterial({color:0x000000})});_this.renderPassMask.clear=false;/**
* A blur pass.
*
* @type {BlurPass}
* @private
*/_this.blurPass=new BlurPass(options);/**
* The light source.
*
* @type {Object3D}
*/_this.lightSource=lightSource;/**
* The light position in screen space.
*
* @type {Vector3}
* @private
*/_this.screenPosition=new Vector3();/**
* A god rays shader material.
*
* @type {GodRaysMaterial}
* @private
*/_this.godRaysMaterial=new GodRaysMaterial(options);_this.godRaysMaterial.uniforms.lightPosition.value=_this.screenPosition;_this.samples=options.samples;/**
* A combine shader material.
*
* @type {CombineMaterial}
* @private
*/_this.combineMaterial=new CombineMaterial(options.screenMode!==undefined?options.screenMode:true);_this.intensity=options.intensity;return _this;}/**
* The resolution scale.
*
* @type {Number}
*/createClass(GodRaysPass,[{key:"render",/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var scene=this.scene;var camera=this.camera;var mainScene=this.mainScene;var lightSource=this.lightSource;var screenPosition=this.screenPosition;var godRaysMaterial=this.godRaysMaterial;var combineMaterial=this.combineMaterial;var renderTargetMask=this.renderTargetMask;var renderTargetX=this.renderTargetX;var renderTargetY=this.renderTargetY;var background,parent;// Compute the screen light position and translate it to [0.0, 1.0].
screenPosition.copy(lightSource.position).project(this.mainCamera);screenPosition.x=clamp((screenPosition.x+1.0)*0.5,0.0,1.0);screenPosition.y=clamp((screenPosition.y+1.0)*0.5,0.0,1.0);parent=lightSource.parent;background=mainScene.background;mainScene.background=null;this.lightScene.add(lightSource);/* First, render the light source. Then render the scene into the same
buffer using a mask override material with depth test enabled. */this.renderPassLight.render(renderer,renderTargetMask);this.renderPassMask.render(renderer,renderTargetMask);if(parent!==null){parent.add(lightSource);}mainScene.background=background;// Blur the masked scene to reduce artifacts.
this.blurPass.render(renderer,this.renderTargetMask,renderTargetX);// Blur the masked scene along radial lines towards the light source.
this.material=godRaysMaterial;godRaysMaterial.uniforms.tDiffuse.value=renderTargetX.texture;renderer.render(scene,camera,renderTargetY);if(this.blend){// Combine the god rays with the scene colors.
this.material=combineMaterial;combineMaterial.uniforms.texture1.value=inputBuffer.texture;combineMaterial.uniforms.texture2.value=renderTargetY.texture;renderer.render(scene,camera,this.renderToScreen?null:outputBuffer);}}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){this.renderPassLight.setSize(width,height);this.renderPassMask.setSize(width,height);this.blurPass.setSize(width,height);width=this.blurPass.width;height=this.blurPass.height;this.renderTargetMask.setSize(width,height);this.renderTargetX.setSize(width,height);this.renderTargetY.setSize(width,height);}/**
* Performs initialization tasks.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.
*/},{key:"initialize",value:function initialize(renderer,alpha){this.renderPassLight.initialize(renderer,alpha);this.renderPassMask.initialize(renderer,alpha);this.blurPass.initialize(renderer,alpha);if(!alpha){this.renderTargetMask.texture.format=RGBFormat;this.renderTargetX.texture.format=RGBFormat;this.renderTargetY.texture.format=RGBFormat;}}},{key:"resolutionScale",get:function get(){return this.blurPass.resolutionScale;}/**
* You need to call {@link EffectComposer#setSize} after changing this value.
*
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:0.5;this.blurPass.resolutionScale=value;}/**
* The blur kernel size.
*
* @type {KernelSize}
*/},{key:"kernelSize",get:function get(){return this.blurPass.kernelSize;}/**
* @type {KernelSize}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:KernelSize.LARGE;this.blurPass.kernelSize=value;}/**
* The overall intensity of the effect.
*
* @type {Number}
*/},{key:"intensity",get:function get(){return this.combineMaterial.uniforms.opacity2.value;}/**
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1.0;this.combineMaterial.uniforms.opacity2.value=value;}/**
* The number of samples per pixel.
*
* @type {Number}
*/},{key:"samples",get:function get(){return Number.parseInt(this.godRaysMaterial.defines.NUM_SAMPLES_INT);}/**
* This value must be carefully chosen. A higher value directly increases the
* GPU load.
*
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:60;value=Math.floor(value);this.godRaysMaterial.defines.NUM_SAMPLES_FLOAT=value.toFixed(1);this.godRaysMaterial.defines.NUM_SAMPLES_INT=value.toFixed(0);this.godRaysMaterial.needsUpdate=true;}/**
* Indicates whether dithering is enabled.
*
* @type {Boolean}
*/},{key:"dithering",get:function get(){return this.godRaysMaterial.dithering;}/**
* If enabled, the result will be dithered to remove banding artifacts.
*
* @type {Boolean}
*/,set:function set(value){if(this.dithering!==value){this.godRaysMaterial.dithering=value;this.godRaysMaterial.needsUpdate=true;}}/**
* Indicates whether the effect should be applied to the input buffer.
*
* @type {Boolean}
*/},{key:"blend",get:function get(){return this.needsSwap;}/**
* If disabled, the input buffer will remain unaffected.
*
* You may use the {@link BloomPass#overlay} texture to apply the effect to
* your scene.
*
* @type {Boolean}
*/,set:function set(value){this.needsSwap=value;}/**
* The effect overlay texture.
*
* @type {Texture}
*/},{key:"overlay",get:function get(){return this.renderTargetY.texture;}}]);inherits(GodRaysPass,_Pass);return GodRaysPass;}(Pass);/**
* A mask pass.
*/var MaskPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new mask pass.
*
* @param {Scene} scene - The scene to render.
* @param {Camera} camera - The camera to use.
*/function MaskPass(scene,camera){var _this;classCallCheck(this,MaskPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(MaskPass).call(this,"MaskPass",scene,camera,null));_this.needsSwap=false;/**
* Inverse flag.
*
* @type {Boolean}
*/_this.inverse=false;/**
* Stencil buffer clear flag.
*
* @type {Boolean}
*/_this.clearStencil=true;return _this;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(MaskPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var context=renderer.context;var state=renderer.state;var scene=this.scene;var camera=this.camera;var writeValue=this.inverse?0:1;var clearValue=1-writeValue;// Don't update color or depth.
state.buffers.color.setMask(false);state.buffers.depth.setMask(false);// Lock the buffers.
state.buffers.color.setLocked(true);state.buffers.depth.setLocked(true);// Configure the stencil.
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);// Clear the stencil.
if(this.clearStencil){if(this.renderToScreen){renderer.setRenderTarget(null);renderer.clearStencil();}else{renderer.setRenderTarget(inputBuffer);renderer.clearStencil();renderer.setRenderTarget(outputBuffer);renderer.clearStencil();}}// Draw the mask.
if(this.renderToScreen){renderer.render(scene,camera,null);}else{renderer.render(scene,camera,inputBuffer);renderer.render(scene,camera,outputBuffer);}// Unlock the buffers.
state.buffers.color.setLocked(false);state.buffers.depth.setLocked(false);// Only render where the stencil is set to 1.
state.buffers.stencil.setFunc(context.EQUAL,1,0xffffffff);state.buffers.stencil.setOp(context.KEEP,context.KEEP,context.KEEP);}}]);inherits(MaskPass,_Pass);return MaskPass;}(Pass);/**
* A shader pass.
*
* Used to render any shader material as a 2D filter.
*/var ShaderPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new shader pass.
*
* @param {ShaderMaterial} material - The shader material to use.
* @param {String} [textureID="tDiffuse"] - The texture uniform identifier.
*/function ShaderPass(material){var _this;var textureID=arguments.length>1&&arguments[1]!==undefined?arguments[1]:"tDiffuse";classCallCheck(this,ShaderPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(ShaderPass).call(this,"ShaderPass"));_this.material=material;/**
* The name of the color sampler uniform of the given material.
*
* @type {String}
*/_this.textureID=textureID;return _this;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(ShaderPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){if(this.material.uniforms[this.textureID]!==undefined){this.material.uniforms[this.textureID].value=inputBuffer.texture;}renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}}]);inherits(ShaderPass,_Pass);return ShaderPass;}(Pass);/**
* An outline pass.
*/var OutlinePass=/*#__PURE__*/function(_Pass){/**
* Constructs a new outline pass.
*
* @param {Scene} scene - The main scene.
* @param {Camera} camera - The main camera.
* @param {Object} [options] - Additional parameters. See {@link BlurPass}, {@link OutlineBlendMaterial} and {@link OutlineEdgesMaterial} for details.
* @param {Number} [options.pulseSpeed=0.0] - The pulse speed. A value of zero disables the pulse effect.
* @param {Boolean} [options.blur=true] - Whether the outline should be blurred.
*/function OutlinePass(scene,camera){var _this;var options=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{};classCallCheck(this,OutlinePass);_this=possibleConstructorReturn(this,getPrototypeOf$2(OutlinePass).call(this,"OutlinePass"));/**
* The main scene.
*
* @type {Scene}
* @private
*/_this.mainScene=scene;/**
* The main camera.
*
* @type {Camera}
* @private
*/_this.mainCamera=camera;/**
* A render target for depth information.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetDepth=new WebGLRenderTarget(1,1,{minFilter:LinearFilter,magFilter:LinearFilter});_this.renderTargetDepth.texture.name="Outline.Depth";_this.renderTargetDepth.texture.generateMipmaps=false;/**
* A render target for the outline mask.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetMask=_this.renderTargetDepth.clone();_this.renderTargetMask.texture.format=RGBFormat;_this.renderTargetMask.texture.name="Outline.Mask";/**
* A render target for the edge detection.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetEdges=new WebGLRenderTarget(1,1,{minFilter:LinearFilter,magFilter:LinearFilter,stencilBuffer:false,depthBuffer:false,format:RGBFormat});_this.renderTargetEdges.texture.name="Outline.Edges";_this.renderTargetEdges.texture.generateMipmaps=false;/**
* A render target for the blurred outline overlay.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetBlurredEdges=_this.renderTargetEdges.clone();_this.renderTargetBlurredEdges.texture.name="Outline.BlurredEdges";/**
* A depth pass.
*
* @type {RenderPass}
* @private
*/_this.renderPassDepth=new RenderPass(_this.mainScene,_this.mainCamera,{overrideMaterial:new MeshDepthMaterial({depthPacking:RGBADepthPacking,morphTargets:true,skinning:true}),clearColor:new Color(0xffffff),clearAlpha:1.0});/**
* A depth comparison mask pass.
*
* @type {RenderPass}
* @private
*/_this.renderPassMask=new RenderPass(_this.mainScene,_this.mainCamera,{overrideMaterial:new DepthComparisonMaterial(_this.renderTargetDepth.texture,_this.mainCamera),clearColor:new Color(0xffffff),clearAlpha:1.0});/**
* A blur pass.
*
* @type {BlurPass}
* @private
*/_this.blurPass=new BlurPass(options);_this.kernelSize=options.kernelSize;/**
* A copy pass that renders the read buffer to screen if needed.
*
* @type {ShaderPass}
* @private
*/_this.copyPass=new ShaderPass(new CopyMaterial());_this.copyPass.renderToScreen=true;/**
* An outline edge detection material.
*
* @type {OutlineEdgesMaterial}
* @private
*/_this.outlineEdgesMaterial=new OutlineEdgesMaterial(options);_this.outlineEdgesMaterial.uniforms.tMask.value=_this.renderTargetMask.texture;/**
* An outline blend material.
*
* @type {OutlineBlendMaterial}
* @private
*/_this.outlineBlendMaterial=new OutlineBlendMaterial(options);_this.outlineBlendMaterial.uniforms.tMask.value=_this.renderTargetMask.texture;_this.blur=options.blur!==undefined?options.blur:true;/**
* A list of objects to outline.
*
* @type {Object3D[]}
* @private
*/_this.selection=[];/**
* The current animation time.
*
* @type {Number}
* @private
*/_this.time=0.0;/**
* The pulse speed. A value of zero disables the pulse effect.
*
* @type {Number}
*/_this.pulseSpeed=options.pulseSpeed!==undefined?options.pulseSpeed:0.0;/**
* A dedicated render layer for selected objects.
*
* This layer is set to 10 by default. If this collides with your own custom
* layers, please change it to a free layer before rendering!
*
* @type {Number}
*/_this.selectionLayer=10;return _this;}/**
* The resolution scale.
*
* @type {Number}
*/createClass(OutlinePass,[{key:"setPatternTexture",/**
* Sets a pattern texture to use as an overlay for selected objects.
*
* @param {Texture} [texture=null] - A pattern texture. Set to null to disable the pattern.
*/value:function setPatternTexture(){var texture=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;this.outlineBlendMaterial.setPatternTexture(texture);}/**
* Clears the current selection and selects a list of objects.
*
* @param {Object3D[]} objects - The objects that should be outlined. This array will be copied.
* @return {OutlinePass} This pass.
*/},{key:"setSelection",value:function setSelection(objects){var selection=objects.slice(0);var selectionLayer=this.selectionLayer;var i,l;this.clearSelection();for(i=0,l=selection.length;i<l;++i){selection[i].layers.enable(selectionLayer);}this.selection=selection;return this;}/**
* Clears the list of selected objects.
*
* @return {OutlinePass} This pass.
*/},{key:"clearSelection",value:function clearSelection(){var selection=this.selection;var selectionLayer=this.selectionLayer;var i,l;for(i=0,l=selection.length;i<l;++i){selection[i].layers.disable(selectionLayer);}this.selection=[];this.time=0.0;return this;}/**
* Selects an object.
*
* @param {Object3D} object - The object that should be outlined.
* @return {OutlinePass} This pass.
*/},{key:"selectObject",value:function selectObject(object){object.layers.enable(this.selectionLayer);this.selection.push(object);return this;}/**
* Deselects an object.
*
* @param {Object3D} object - The object that should no longer be outlined.
* @return {OutlinePass} This pass.
*/},{key:"deselectObject",value:function deselectObject(object){var selection=this.selection;var index=selection.indexOf(object);if(index>=0){selection[index].layers.disable(this.selectionLayer);selection.splice(index,1);if(selection.length===0){this.time=0.0;}}return this;}/**
* Sets the visibility of all selected objects.
*
* @private
* @param {Boolean} visible - Whether the selected objects should be visible.
*/},{key:"setSelectionVisible",value:function setSelectionVisible(visible){var selection=this.selection;var i,l;for(i=0,l=selection.length;i<l;++i){if(visible){selection[i].layers.enable(0);}else{selection[i].layers.disable(0);}}}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/},{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var mainScene=this.mainScene;var mainCamera=this.mainCamera;var pulse=this.outlineBlendMaterial.uniforms.pulse;var background,mask;if(this.selection.length>0){background=mainScene.background;mask=mainCamera.layers.mask;mainScene.background=null;pulse.value=1.0;if(this.pulseSpeed>0.0){pulse.value=0.625+Math.cos(this.time*this.pulseSpeed*10.0)*0.375;this.time+=delta;}// Render a custom depth texture and ignore selected objects.
this.setSelectionVisible(false);this.renderPassDepth.render(renderer,this.renderTargetDepth);this.setSelectionVisible(true);// Create a mask for the selected objects using the depth information.
mainCamera.layers.mask=1<<this.selectionLayer;this.renderPassMask.render(renderer,this.renderTargetMask);// Restore the camera layer mask and the scene background.
mainCamera.layers.mask=mask;mainScene.background=background;// Detect the outline.
this.material=this.outlineEdgesMaterial;renderer.render(this.scene,this.camera,this.renderTargetEdges);if(this.blurPass.enabled){// Blur the edges.
this.blurPass.render(renderer,this.renderTargetEdges,this.renderTargetBlurredEdges);}if(this.blend){// Draw the final overlay onto the scene colours.
this.material=this.outlineBlendMaterial;this.outlineBlendMaterial.uniforms.tDiffuse.value=inputBuffer.texture;renderer.render(this.scene,this.camera,this.renderToScreen?null:this.outputBuffer);}}else if(this.renderToScreen){// Draw the read buffer to screen.
this.copyPass.render(renderer,inputBuffer);}}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){this.renderTargetDepth.setSize(width,height);this.renderTargetMask.setSize(width,height);this.renderPassDepth.setSize(width,height);this.renderPassMask.setSize(width,height);this.blurPass.setSize(width,height);width=this.blurPass.width;height=this.blurPass.height;this.renderTargetEdges.setSize(width,height);this.renderTargetBlurredEdges.setSize(width,height);this.outlineBlendMaterial.uniforms.aspect.value=width/height;this.outlineEdgesMaterial.setTexelSize(1.0/width,1.0/height);}/**
* Performs initialization tasks.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.
*/},{key:"initialize",value:function initialize(renderer,alpha){this.renderPassDepth.initialize(renderer,alpha);this.renderPassMask.initialize(renderer,alpha);this.blurPass.initialize(renderer,alpha);}},{key:"resolutionScale",get:function get(){return this.blurPass.resolutionScale;}/**
* You need to call {@link EffectComposer#setSize} after changing this value.
*
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:0.5;this.blurPass.resolutionScale=value;}/**
* The blur kernel size.
*
* @type {KernelSize}
*/},{key:"kernelSize",get:function get(){return this.blurPass.kernelSize;}/**
* @type {KernelSize}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:KernelSize.VERY_SMALL;this.blurPass.kernelSize=value;}/**
* Indicates whether the outline overlay should be blurred.
*
* @type {Boolean}
*/},{key:"blur",get:function get(){return this.blurPass.enabled;}/**
* @type {Boolean}
*/,set:function set(value){this.blurPass.enabled=value;this.outlineBlendMaterial.uniforms.tEdges.value=value?this.renderTargetBlurredEdges.texture:this.renderTargetEdges.texture;}/**
* Indicates whether dithering is enabled.
*
* @type {Boolean}
*/},{key:"dithering",get:function get(){return this.blurPass.dithering;}/**
* If enabled, the result will be dithered to remove banding artifacts.
*
* @type {Boolean}
*/,set:function set(value){this.blurPass.dithering=value;}/**
* Indicates whether the effect should be applied to the input buffer.
*
* @type {Boolean}
*/},{key:"blend",get:function get(){return this.needsSwap;}/**
* If disabled, the input buffer will remain unaffected.
*
* You may use the {@link BloomPass#overlay} texture to apply the effect to
* your scene.
*
* @type {Boolean}
*/,set:function set(value){this.needsSwap=value;}/**
* The effect overlay texture.
*
* @type {Texture}
*/},{key:"overlay",get:function get(){return this.outlineBlendMaterial.uniforms.tEdges.value;}}]);inherits(OutlinePass,_Pass);return OutlinePass;}(Pass);/**
* A pixelation pass.
*/var PixelationPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new pixelation pass.
*
* @param {Number} [granularity=30.0] - The intensity of the effect.
*/function PixelationPass(){var _this;var granularity=arguments.length>0&&arguments[0]!==undefined?arguments[0]:30.0;classCallCheck(this,PixelationPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(PixelationPass).call(this,"PixelationPass"));_this.material=new PixelationMaterial();_this.granularity=granularity;return _this;}/**
* The pixel granularity.
*
* @type {Number}
*/createClass(PixelationPass,[{key:"render",/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){this.material.uniforms.tDiffuse.value=inputBuffer.texture;renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){this.material.setResolution(width,height);}},{key:"granularity",get:function get(){return this.material.granularity;}/**
* A higher value yields coarser visuals.
*
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:30;value=Math.floor(value);if(value%2>0){value+=1;}this.material.granularity=value;}}]);inherits(PixelationPass,_Pass);return PixelationPass;}(Pass);/**
* An advanced Depth of Field (DoF) pass.
*
* Yields more realistic results but is also more demanding.
*
* This pass requires a {@link EffectComposer#depthTexture}.
*/var RealisticBokehPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new bokeh pass.
*
* @param {PerspectiveCamera} camera - The main camera. Used to obtain the focal length and the near and far plane settings.
* @param {Object} [options] - Additional parameters. See {@link RealisticBokehMaterial} for details.
*/function RealisticBokehPass(camera){var _this;var options=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};classCallCheck(this,RealisticBokehPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(RealisticBokehPass).call(this,"RealisticBokehPass"));_this.material=new RealisticBokehMaterial(camera,options);return _this;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(RealisticBokehPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){this.material.uniforms.tDiffuse.value=inputBuffer.texture;this.material.uniforms.tDepth.value=inputBuffer.depthTexture;renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){this.material.setTexelSize(1.0/width,1.0/height);}}]);inherits(RealisticBokehPass,_Pass);return RealisticBokehPass;}(Pass);/**
* A pass that renders the result from a previous pass to another render target.
*/var SavePass=/*#__PURE__*/function(_Pass){/**
* Constructs a new save pass.
*
* @param {WebGLRenderTarget} [renderTarget] - The render target to use for saving the input buffer.
* @param {Boolean} [resize=true] - Whether the render target should adjust to the size of the input buffer.
*/function SavePass(renderTarget){var _this;var resize=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;classCallCheck(this,SavePass);_this=possibleConstructorReturn(this,getPrototypeOf$2(SavePass).call(this,"SavePass"));_this.material=new CopyMaterial();_this.needsSwap=false;/**
* The render target.
*
* @type {WebGLRenderTarget}
*/_this.renderTarget=renderTarget!==undefined?renderTarget:new WebGLRenderTarget(1,1,{minFilter:LinearFilter,magFilter:LinearFilter,stencilBuffer:false,depthBuffer:false});_this.renderTarget.texture.name="Save.Target";_this.renderTarget.texture.generateMipmaps=false;/**
* Indicates whether the render target should be resized when the size of
* the composer's frame buffer changes.
*
* @type {Boolean}
*/_this.resize=resize;return _this;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(SavePass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){this.material.uniforms.tDiffuse.value=inputBuffer.texture;renderer.render(this.scene,this.camera,this.renderTarget);}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){if(this.resize){width=Math.max(1,width);height=Math.max(1,height);this.renderTarget.setSize(width,height);}}/**
* Performs initialization tasks.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.
*/},{key:"initialize",value:function initialize(renderer,alpha){if(!alpha){this.renderTarget.texture.format=RGBFormat;}}}]);inherits(SavePass,_Pass);return SavePass;}(Pass);/**
* Half PI.
*
* @type {Number}
* @private
*/var HALF_PI=Math.PI*0.5;/**
* A vector.
*
* @type {Vector3}
* @private
*/var v=new Vector3();/**
* A vector.
*
* @type {Vector3}
* @private
*/var ab=new Vector3();/**
* A shock wave pass.
*/var ShockWavePass=/*#__PURE__*/function(_Pass){/**
* Constructs a new shock wave pass.
*
* @param {Camera} camera - The main camera.
* @param {Vector3} [epicenter] - The world position of the shock wave epicenter.
* @param {Object} [options] - The options.
* @param {Number} [options.speed=1.0] - The animation speed.
* @param {Number} [options.maxRadius=1.0] - The extent of the shock wave.
* @param {Number} [options.waveSize=0.2] - The wave size.
* @param {Number} [options.amplitude=0.05] - The distortion amplitude.
*/function ShockWavePass(camera){var _this;var epicenter=arguments.length>1&&arguments[1]!==undefined?arguments[1]:new Vector3();var options=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{};classCallCheck(this,ShockWavePass);_this=possibleConstructorReturn(this,getPrototypeOf$2(ShockWavePass).call(this,"ShockWavePass"));/**
* The main camera.
*
* @type {Object3D}
*/_this.mainCamera=camera;/**
* The epicenter.
*
* @type {Vector3}
* @example shockWavePass.epicenter = myMesh.position;
*/_this.epicenter=epicenter;/**
* The object position in screen space.
*
* @type {Vector3}
* @private
*/_this.screenPosition=new Vector3();/**
* The speed of the shock wave animation.
*
* @type {Number}
*/_this.speed=options.speed!==undefined?options.speed:2.0;/**
* A time accumulator.
*
* @type {Number}
* @private
*/_this.time=0.0;/**
* Indicates whether the shock wave animation is active.
*
* @type {Boolean}
* @private
*/_this.active=false;/**
* A shock wave shader material.
*
* @type {ShockWaveMaterial}
* @private
*/_this.shockWaveMaterial=new ShockWaveMaterial(options);_this.shockWaveMaterial.uniforms.center.value=_this.screenPosition;/**
* A copy shader material.
*
* @type {CopyMaterial}
* @private
*/_this.copyMaterial=new CopyMaterial();return _this;}/**
* Emits the shock wave.
*/createClass(ShockWavePass,[{key:"explode",value:function explode(){this.time=0.0;this.active=true;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/},{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var epicenter=this.epicenter;var mainCamera=this.mainCamera;var screenPosition=this.screenPosition;var shockWaveMaterial=this.shockWaveMaterial;var uniforms=shockWaveMaterial.uniforms;var center=uniforms.center;var radius=uniforms.radius;var maxRadius=uniforms.maxRadius;var waveSize=uniforms.waveSize;this.copyMaterial.uniforms.tDiffuse.value=inputBuffer.texture;this.material=this.copyMaterial;if(this.active){// Calculate direction vectors.
mainCamera.getWorldDirection(v);ab.copy(mainCamera.position).sub(epicenter);// Don't render the effect if the object is behind the camera.
if(v.angleTo(ab)>HALF_PI){// Scale the effect based on distance to the object.
uniforms.cameraDistance.value=mainCamera.position.distanceTo(epicenter);// Calculate the screen position of the epicenter.
screenPosition.copy(epicenter).project(mainCamera);center.value.x=(screenPosition.x+1.0)*0.5;center.value.y=(screenPosition.y+1.0)*0.5;uniforms.tDiffuse.value=inputBuffer.texture;this.material=shockWaveMaterial;}// Update the shock wave radius based on time.
this.time+=delta*this.speed;radius.value=this.time-waveSize.value;if(radius.value>=(maxRadius.value+waveSize.value)*2){this.active=false;}}renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){this.shockWaveMaterial.uniforms.aspect.value=width/height;}}]);inherits(ShockWavePass,_Pass);return ShockWavePass;}(Pass);// Generated with SMAASearchImageData.generate().toCanvas().toDataURL(), not cropped, low dynamic range.
var searchImageDataURL="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEIAAAAhCAAAAABIXyLAAAAAOElEQVRIx2NgGAWjYBSMglEwEICREYRgFBZBqDCSLA2MGPUIVQETE9iNUAqLR5gIeoQKRgwXjwAAGn4AtaFeYLEAAAAASUVORK5CYII";// Generated with SMAAAreaImageData.generate().toCanvas().toDataURL().
var areaImageDataURL="data:image/png;base64,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";/**
* Subpixel Morphological Antialiasing (SMAA) v2.8.
*
* Preset: SMAA 1x Medium (with color edge detection).
* https://github.com/iryoku/smaa/releases/tag/v2.8
*/var SMAAPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new SMAA pass.
*
* @param {Image} searchImage - The SMAA search image. Preload this image using the {@link searchImageDataURL}.
* @param {Image} areaImage - The SMAA area image. Preload this image using the {@link areaImageDataURL}.
*/function SMAAPass(searchImage,areaImage){var _this;classCallCheck(this,SMAAPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(SMAAPass).call(this,"SMAAPass"));/**
* A clear pass for the color edges buffer.
*
* @type {ClearPass}
* @private
*/_this.clearPass=new ClearPass({clearColor:new Color(0x000000),clearAlpha:1.0});/**
* A render target for the color edge detection.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetColorEdges=new WebGLRenderTarget(1,1,{minFilter:LinearFilter,format:RGBFormat,stencilBuffer:false,depthBuffer:false});_this.renderTargetColorEdges.texture.name="SMAA.ColorEdges";_this.renderTargetColorEdges.texture.generateMipmaps=false;/**
* A render target for the SMAA weights.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetWeights=_this.renderTargetColorEdges.clone();_this.renderTargetWeights.texture.name="SMAA.Weights";_this.renderTargetWeights.texture.format=RGBAFormat;/**
* Color edge detection shader material.
*
* @type {ColorEdgesMaterial}
* @private
*/_this.colorEdgesMaterial=new ColorEdgesMaterial();/**
* SMAA weights shader material.
*
* @type {SMAAWeightsMaterial}
* @private
*/_this.weightsMaterial=new SMAAWeightsMaterial();_this.weightsMaterial.uniforms.tDiffuse.value=_this.renderTargetColorEdges.texture;/**
* The SMAA search texture.
*
* @type {Texture}
* @private
*/_this.searchTexture=new Texture(searchImage);_this.searchTexture.name="SMAA.Search";_this.searchTexture.magFilter=NearestFilter;_this.searchTexture.minFilter=NearestFilter;_this.searchTexture.format=RGBAFormat;_this.searchTexture.generateMipmaps=false;_this.searchTexture.needsUpdate=true;_this.searchTexture.flipY=false;_this.weightsMaterial.uniforms.tSearch.value=_this.searchTexture;/**
* The SMAA area texture.
*
* @type {Texture}
* @private
*/_this.areaTexture=new Texture(areaImage);_this.areaTexture.name="SMAA.Area";_this.areaTexture.minFilter=LinearFilter;_this.areaTexture.format=RGBAFormat;_this.areaTexture.generateMipmaps=false;_this.areaTexture.needsUpdate=true;_this.areaTexture.flipY=false;_this.weightsMaterial.uniforms.tArea.value=_this.areaTexture;/**
* SMAA blend shader material.
*
* @type {SMAABlendMaterial}
* @private
*/_this.blendMaterial=new SMAABlendMaterial();_this.blendMaterial.uniforms.tWeights.value=_this.renderTargetWeights.texture;return _this;}/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/createClass(SMAAPass,[{key:"render",value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){// Detect color edges.
this.material=this.colorEdgesMaterial;this.colorEdgesMaterial.uniforms.tDiffuse.value=inputBuffer.texture;this.clearPass.render(renderer,this.renderTargetColorEdges);renderer.render(this.scene,this.camera,this.renderTargetColorEdges);// Compute edge weights.
this.material=this.weightsMaterial;renderer.render(this.scene,this.camera,this.renderTargetWeights);// Apply the antialiasing filter to the colors.
this.material=this.blendMaterial;this.blendMaterial.uniforms.tDiffuse.value=inputBuffer.texture;renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}/**
* Updates the size of this pass.
*
* @param {Number} width - The width.
* @param {Number} height - The height.
*/},{key:"setSize",value:function setSize(width,height){this.renderTargetColorEdges.setSize(width,height);this.renderTargetWeights.setSize(width,height);this.colorEdgesMaterial.uniforms.texelSize.value.copy(this.weightsMaterial.uniforms.texelSize.value.copy(this.blendMaterial.uniforms.texelSize.value.set(1.0/width,1.0/height)));}/**
* The SMAA search image, encoded as a base64 data URL.
*
* Use this image data to create an Image instance and use it together with
* the area image to create an SMAAPass.
*
* @type {String}
* @example
* const searchImage = new Image();
* searchImage.addEventListener("load", progress);
* searchImage.src = SMAAPass.searchImageDataURL;
*/}],[{key:"searchImageDataURL",get:function get(){return searchImageDataURL;}/**
* The SMAA area image, encoded as a base64 data URL.
*
* Use this image data to create an Image instance and use it together with
* the search image to create an SMAAPass.
*
* @type {String}
* @example
* const areaImage = new Image();
* areaImage.addEventListener("load", progress);
* areaImage.src = SMAAPass.areaImageDataURL;
*/},{key:"areaImageDataURL",get:function get(){return areaImageDataURL;}}]);inherits(SMAAPass,_Pass);return SMAAPass;}(Pass);/**
* A pass that renders a given texture.
*/var TexturePass=/*#__PURE__*/function(_Pass){/**
* Constructs a new texture pass.
*
* @param {Texture} texture - The texture.
* @param {Number} [opacity=1.0] - The texture opacity.
* @param {Boolean} [screenMode=true] - Whether the screen blend mode should be used for combining the texture with the scene colors.
*/function TexturePass(texture){var _this;var opacity=arguments.length>1&&arguments[1]!==undefined?arguments[1]:1.0;var screenMode=arguments.length>2&&arguments[2]!==undefined?arguments[2]:true;classCallCheck(this,TexturePass);_this=possibleConstructorReturn(this,getPrototypeOf$2(TexturePass).call(this,"TexturePass"));_this.material=new CombineMaterial(screenMode);_this.texture=texture;_this.opacitySource=opacity;return _this;}/**
* The texture.
*
* @type {Texture}
*/createClass(TexturePass,[{key:"render",/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){this.material.uniforms.texture1.value=inputBuffer.texture;renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}},{key:"texture",get:function get(){return this.material.uniforms.texture2.value;}/**
* @type {Texture}
*/,set:function set(value){this.material.uniforms.texture2.value=value;}/**
* The opacity of the input buffer.
*
* The destination color is the color from the image in the input buffer.
*
* @type {Number}
*/},{key:"opacityDestination",get:function get(){return this.material.uniforms.opacity1.value;}/**
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1.0;this.material.uniforms.opacity1.value=value;}/**
* The opacity of the texture.
*
* The source color is the color from the texture.
*
* @type {Number}
*/},{key:"opacitySource",get:function get(){return this.material.uniforms.opacity2.value;}/**
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1.0;this.material.uniforms.opacity2.value=value;}}]);inherits(TexturePass,_Pass);return TexturePass;}(Pass);/**
* A tone mapping pass that supports adaptive luminosity.
*
* If adaptivity is enabled, this pass generates a texture that represents the
* luminosity of the current scene and adjusts it over time to simulate the
* optic nerve responding to the amount of light it is receiving.
*
* Reference:
* GDC2007 - Wolfgang Engel, Post-Processing Pipeline
* http://perso.univ-lyon1.fr/jean-claude.iehl/Public/educ/GAMA/2007/gdc07/Post-Processing_Pipeline.pdf
*/var ToneMappingPass=/*#__PURE__*/function(_Pass){/**
* Constructs a new tone mapping pass.
*
* @param {Object} [options] - The options.
* @param {Boolean} [options.adaptive=true] - Whether the tone mapping should use an adaptive luminance map.
* @param {Number} [options.resolution=256] - The render texture resolution.
* @param {Number} [options.distinction=1.0] - A luminance distinction factor.
*/function ToneMappingPass(){var _this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,ToneMappingPass);_this=possibleConstructorReturn(this,getPrototypeOf$2(ToneMappingPass).call(this,"ToneMappingPass"));/**
* The render target for the current luminosity.
*
* @type {WebGLRenderTarget}
* @private
* @todo Use RED format in WebGL 2.0.
*/_this.renderTargetLuminosity=new WebGLRenderTarget(1,1,{minFilter:LinearMipMapLinearFilter,magFilter:LinearFilter,format:RGBFormat,stencilBuffer:false,depthBuffer:false});_this.renderTargetLuminosity.texture.name="ToneMapping.Luminosity";/**
* The render target for adapted luminosity.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetAdapted=_this.renderTargetLuminosity.clone();_this.renderTargetAdapted.texture.name="ToneMapping.AdaptedLuminosity";_this.renderTargetAdapted.texture.generateMipmaps=false;_this.renderTargetAdapted.texture.minFilter=LinearFilter;/**
* A render target that holds a copy of the adapted limonosity.
*
* @type {WebGLRenderTarget}
* @private
*/_this.renderTargetPrevious=_this.renderTargetAdapted.clone();_this.renderTargetPrevious.texture.name="ToneMapping.PreviousLuminosity";/**
* Copy shader material used for saving the luminance map.
*
* @type {CopyMaterial}
* @private
*/_this.copyMaterial=new CopyMaterial();/**
* A luminosity shader material.
*
* @type {LuminosityMaterial}
* @private
*/_this.luminosityMaterial=new LuminosityMaterial();_this.luminosityMaterial.uniforms.distinction.value=options.distinction!==undefined?options.distinction:1.0;/**
* An adaptive luminance shader material.
*
* @type {AdaptiveLuminosityMaterial}
* @private
*/_this.adaptiveLuminosityMaterial=new AdaptiveLuminosityMaterial();_this.resolution=options.resolution;/**
* A tone mapping shader material.
*
* @type {ToneMappingMaterial}
* @private
*/_this.toneMappingMaterial=new ToneMappingMaterial();_this.adaptive=options.adaptive;return _this;}/**
* The resolution of the render targets.
*
* @type {Number}
*/createClass(ToneMappingPass,[{key:"render",/**
* Renders the effect.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.
* @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.
* @param {Number} [delta] - The time between the last frame and the current one in seconds.
* @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.
*/value:function render(renderer,inputBuffer,outputBuffer,delta,stencilTest){var scene=this.scene;var camera=this.camera;var adaptiveLuminosityMaterial=this.adaptiveLuminosityMaterial;var luminosityMaterial=this.luminosityMaterial;var toneMappingMaterial=this.toneMappingMaterial;var copyMaterial=this.copyMaterial;var renderTargetPrevious=this.renderTargetPrevious;var renderTargetLuminosity=this.renderTargetLuminosity;var renderTargetAdapted=this.renderTargetAdapted;if(this.adaptive){// Render the luminance of the current scene into a render target with mipmapping enabled.
this.material=luminosityMaterial;luminosityMaterial.uniforms.tDiffuse.value=inputBuffer.texture;renderer.render(scene,camera,renderTargetLuminosity);// Use the new luminance values, the previous luminance and the frame delta to adapt the luminance over time.
this.material=adaptiveLuminosityMaterial;adaptiveLuminosityMaterial.uniforms.delta.value=delta;adaptiveLuminosityMaterial.uniforms.tPreviousLum.value=renderTargetPrevious.texture;adaptiveLuminosityMaterial.uniforms.tCurrentLum.value=renderTargetLuminosity.texture;renderer.render(scene,camera,renderTargetAdapted);// Copy the new adapted luminance value so that it can be used by the next frame.
this.material=copyMaterial;copyMaterial.uniforms.tDiffuse.value=renderTargetAdapted.texture;renderer.render(scene,camera,renderTargetPrevious);}// Apply the tone mapping to the colours.
this.material=toneMappingMaterial;toneMappingMaterial.uniforms.tDiffuse.value=inputBuffer.texture;renderer.render(this.scene,this.camera,this.renderToScreen?null:outputBuffer);}/**
* Performs initialization tasks.
*
* @param {WebGLRenderer} renderer - The renderer.
* @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.
*/},{key:"initialize",value:function initialize(renderer,alpha){this.material=new MeshBasicMaterial({color:0x7fffff});renderer.render(this.scene,this.camera,this.renderTargetPrevious);this.material.dispose();}},{key:"resolution",get:function get(){return this.renderTargetLuminosity.width;}/**
* The resolution of the render targets. Must be a power of two for mipmaps.
*
* @type {Number}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:256;// Round the given value to the next power of two.
var exponent=Math.max(0,Math.ceil(Math.log2(value)));value=Math.pow(2,exponent);this.renderTargetLuminosity.setSize(value,value);this.renderTargetPrevious.setSize(value,value);this.renderTargetAdapted.setSize(value,value);this.adaptiveLuminosityMaterial.defines.MIP_LEVEL_1X1=exponent.toFixed(1);this.adaptiveLuminosityMaterial.needsUpdate=true;}/**
* Whether this pass uses adaptive luminosity.
*
* @type {Boolean}
* @default true
*/},{key:"adaptive",get:function get(){return this.toneMappingMaterial.defines.ADAPTED_LUMINANCE!==undefined;}/**
* Whether this pass should use adaptive luminosity.
*
* @type {Boolean}
*/,set:function set(){var value=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;if(value){this.toneMappingMaterial.defines.ADAPTED_LUMINANCE="1";this.toneMappingMaterial.uniforms.luminanceMap.value=this.renderTargetAdapted.texture;}else{delete this.toneMappingMaterial.defines.ADAPTED_LUMINANCE;this.toneMappingMaterial.uniforms.luminanceMap.value=null;}this.toneMappingMaterial.needsUpdate=true;}/**
* Indicates whether dithering is enabled.
*
* @type {Boolean}
*/},{key:"dithering",get:function get(){return this.toneMappingMaterial.dithering;}/**
* If enabled, the result will be dithered to remove banding artifacts.
*
* @type {Boolean}
*/,set:function set(value){if(this.dithering!==value){this.toneMappingMaterial.dithering=value;this.toneMappingMaterial.needsUpdate=true;}}}]);inherits(ToneMappingPass,_Pass);return ToneMappingPass;}(Pass);/**
* A compilation of the post processing passes.
*
* @module postprocessing/passes
*/ /**
* The EffectComposer may be used in place of a normal WebGLRenderer.
*
* The auto clear behaviour of the provided renderer will be disabled to prevent
* unnecessary clear operations.
*
* It is common practice to use a {@link RenderPass} as the first pass to
* automatically clear the screen and render the scene to a texture for further
* processing.
*
* @implements {Resizable}
* @implements {Disposable}
*/var EffectComposer=/*#__PURE__*/function(){/**
* Constructs a new effect composer.
*
* @param {WebGLRenderer} [renderer] - The renderer that should be used.
* @param {Object} [options] - The options.
* @param {Boolean} [options.depthBuffer=true] - Whether the main render targets should have a depth buffer.
* @param {Boolean} [options.stencilBuffer=false] - Whether the main render targets should have a stencil buffer.
* @param {Boolean} [options.depthTexture=false] - Set to true if one of your passes relies on a depth texture.
*/function EffectComposer(){var renderer=arguments.length>0&&arguments[0]!==undefined?arguments[0]:null;var options=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};classCallCheck(this,EffectComposer);/**
* The renderer.
*
* You may replace the renderer at any time by using
* {@link EffectComposer#replaceRenderer}.
*
* @type {WebGLRenderer}
*/this.renderer=renderer;/**
* The input buffer.
*
* Reading from and writing to the same render target should be avoided.
* Therefore, two seperate yet identical buffers are used.
*
* @type {WebGLRenderTarget}
* @private
*/this.inputBuffer=null;/**
* The output buffer.
*
* @type {WebGLRenderTarget}
* @private
*/this.outputBuffer=null;if(this.renderer!==null){this.renderer.autoClear=false;this.inputBuffer=this.createBuffer(options.depthBuffer!==undefined?options.depthBuffer:true,options.stencilBuffer!==undefined?options.stencilBuffer:false,options.depthTexture!==undefined?options.depthTexture:false);this.outputBuffer=this.inputBuffer.clone();}/**
* A copy pass used for copying masked scenes.
*
* @type {ShaderPass}
* @private
*/this.copyPass=new ShaderPass(new CopyMaterial());/**
* The passes.
*
* @type {Pass[]}
* @private
*/this.passes=[];}/**
* The depth texture of the input and output buffers.
*
* @type {DepthTexture}
*/createClass(EffectComposer,[{key:"replaceRenderer",/**
* Replaces the current renderer with the given one. The DOM element of the
* current renderer will automatically be removed from its parent node and the
* DOM element of the new renderer will take its place.
*
* The auto clear mechanism of the provided renderer will be disabled.
*
* Switching between renderers allows you to dynamically enable or disable
* antialiasing.
*
* @param {WebGLRenderer} renderer - The new renderer.
* @return {WebGLRenderer} The old renderer.
*/value:function replaceRenderer(renderer){var oldRenderer=this.renderer;var parent,oldSize,newSize;if(oldRenderer!==null&&oldRenderer!==renderer){this.renderer=renderer;this.renderer.autoClear=false;parent=oldRenderer.domElement.parentNode;oldSize=oldRenderer.getSize();newSize=renderer.getSize();if(parent!==null){parent.removeChild(oldRenderer.domElement);parent.appendChild(renderer.domElement);}if(oldSize.width!==newSize.width||oldSize.height!==newSize.height){this.setSize();}}return oldRenderer;}/**
* Creates a new render target by replicating the renderer's canvas.
*
* The created render target uses a linear filter for texel minification and
* magnification. Its render texture format depends on whether the renderer
* uses the alpha channel. Mipmaps are disabled.
*
* @param {Boolean} depthBuffer - Whether the render target should have a depth buffer.
* @param {Boolean} stencilBuffer - Whether the render target should have a stencil buffer.
* @param {Boolean} depthTexture - Whether the render target should have a depth texture.
* @return {WebGLRenderTarget} A new render target that equals the renderer's canvas.
*/},{key:"createBuffer",value:function createBuffer(depthBuffer,stencilBuffer,depthTexture){var drawingBufferSize=this.renderer.getDrawingBufferSize();var alpha=this.renderer.context.getContextAttributes().alpha;var renderTarget=new WebGLRenderTarget(drawingBufferSize.width,drawingBufferSize.height,{minFilter:LinearFilter,magFilter:LinearFilter,format:alpha?RGBAFormat:RGBFormat,depthBuffer:depthBuffer,stencilBuffer:stencilBuffer,depthTexture:depthTexture?new DepthTexture():null});if(depthTexture&&stencilBuffer){renderTarget.depthTexture.format=DepthStencilFormat;renderTarget.depthTexture.type=UnsignedInt248Type;}renderTarget.texture.name="EffectComposer.Buffer";renderTarget.texture.generateMipmaps=false;return renderTarget;}/**
* Adds a pass, optionally at a specific index.
*
* @param {Pass} pass - A new pass.
* @param {Number} [index] - An index at which the pass should be inserted.
*/},{key:"addPass",value:function addPass(pass,index){var renderer=this.renderer;var drawingBufferSize=renderer.getDrawingBufferSize();pass.setSize(drawingBufferSize.width,drawingBufferSize.height);pass.initialize(renderer,renderer.context.getContextAttributes().alpha);if(index!==undefined){this.passes.splice(index,0,pass);}else{this.passes.push(pass);}}/**
* Removes a pass.
*
* @param {Pass} pass - The pass.
*/},{key:"removePass",value:function removePass(pass){this.passes.splice(this.passes.indexOf(pass),1);}/**
* Renders all enabled passes in the order in which they were added.
*
* @param {Number} delta - The time between the last frame and the current one in seconds.
*/},{key:"render",value:function render(delta){var passes=this.passes;var copyPass=this.copyPass;var renderer=this.renderer;var inputBuffer=this.inputBuffer;var outputBuffer=this.outputBuffer;var stencilTest=false;var pass,context,state,buffer;var i,l;for(i=0,l=passes.length;i<l;++i){pass=passes[i];if(pass.enabled){pass.render(renderer,inputBuffer,outputBuffer,delta,stencilTest);if(pass.needsSwap){if(stencilTest){copyPass.renderToScreen=pass.renderToScreen;context=renderer.context;state=renderer.state;// Preserve the unaffected pixels.
state.buffers.stencil.setFunc(context.NOTEQUAL,1,0xffffffff);copyPass.render(renderer,inputBuffer,outputBuffer,delta,stencilTest);state.buffers.stencil.setFunc(context.EQUAL,1,0xffffffff);}buffer=inputBuffer;inputBuffer=outputBuffer;outputBuffer=buffer;}if(pass instanceof MaskPass){stencilTest=true;}else if(pass instanceof ClearMaskPass){stencilTest=false;}}}}/**
* Sets the size of the buffers and the renderer's output canvas.
*
* Every pass will be informed of the new size. It's up to each pass how that
* information is used.
*
* If no width or height is specified, the render targets and passes will be
* updated with the current size of the renderer.
*
* @param {Number} [width] - The width.
* @param {Number} [height] - The height.
*/},{key:"setSize",value:function setSize(width,height){var passes=this.passes;var renderer=this.renderer;var size,drawingBufferSize;var i,l;if(width===undefined||height===undefined){size=renderer.getSize();width=size.width;height=size.height;}// Update the logical render size.
renderer.setSize(width,height);// The drawing buffer size takes the device pixel ratio into account.
drawingBufferSize=renderer.getDrawingBufferSize();this.inputBuffer.setSize(drawingBufferSize.width,drawingBufferSize.height);this.outputBuffer.setSize(drawingBufferSize.width,drawingBufferSize.height);for(i=0,l=passes.length;i<l;++i){passes[i].setSize(drawingBufferSize.width,drawingBufferSize.height);}}/**
* Resets this composer by deleting all passes and creating new buffers.
*/},{key:"reset",value:function reset(){var renderTarget=this.createBuffer(this.inputBuffer.depthBuffer,this.inputBuffer.stencilBuffer,this.inputBuffer.depthTexture!==null);this.dispose();// Reanimate.
this.inputBuffer=renderTarget;this.outputBuffer=renderTarget.clone();this.copyPass=new ShaderPass(new CopyMaterial());}/**
* Destroys this composer and all passes.
*
* This method deallocates all disposable objects created by the passes. It
* also deletes the main frame buffers of this composer.
*/},{key:"dispose",value:function dispose(){var passes=this.passes;var i,l;for(i=0,l=passes.length;i<l;++i){passes[i].dispose();}this.passes=[];if(this.inputBuffer!==null){this.inputBuffer.dispose();this.inputBuffer=null;}if(this.outputBuffer!==null){this.outputBuffer.dispose();this.outputBuffer=null;}this.copyPass.dispose();}},{key:"depthTexture",get:function get(){return this.inputBuffer.depthTexture;}/**
* The input and output buffers share a single depth texture. Depth will be
* written to this texture when something is rendered into one of the buffers
* and the involved materials have depth write enabled.
*
* You may enable this mechanism during the instantiation of the composer or
* by assigning a DepthTexture instance later on. You may also disable it by
* assigning null.
*
* @type {DepthTexture}
*/,set:function set(x){this.inputBuffer.depthTexture=x;this.outputBuffer.depthTexture=x;}}]);return EffectComposer;}();var polyfill=function polyfill(object,method){var showWarn=arguments.length>2&&arguments[2]!==undefined?arguments[2]:true;if(object[method])return;if(showWarn)console.warn("@PostProcessorModule: pass.".concat(method,"() was not found."),object);object[method]=function(){};};/**
* @class PostProcessorModule
* @category modules/app
* @param {Object} [params]
* @memberof module:modules/app
* @example <caption> Creating a rendering module and passing it to App's modules</caption>
* new App([
* new ElementModule(),
* new SceneModule(),
* new DefineModule('camera', new WHS.PerspectiveCamera({
* position: new THREE.Vector3(0, 6, 18),
* far: 10000
* })),
* new RenderingModule(),
* new PostProcessorModule()
* ]);
*
* const processor = app.use('postprocessor');
*
* processor
* .render()
* .pass(new GlitchPass())
* .renderToScreen()
*/var PostProcessorModule=/*#__PURE__*/function(){function PostProcessorModule(){var _this=this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:PostProcessorModule.defaults;classCallCheck(this,PostProcessorModule);defineProperty$3(defineProperty$3(this,"currentPass",null),"defer",new Promise(function(resolve){_this.resolve=resolve;}));this.debug=params.debug;this.params=params;}createClass(PostProcessorModule,[{key:"manager",value:function manager(_manager){var _this2=this;_manager.define('postprocessor');this.effects=_manager.use('rendering').effects;this.renderer=_manager.get('renderer');this.scene=_manager.get('scene');this.camera=_manager.get('camera');this.composer=new EffectComposer(this.renderer,this.params);_manager.use('rendering').stop();var composer=this.composer;this.renderLoop=new Loop(function(clock){return composer.render(clock.getDelta());}).start(_manager.handler);_manager.update({renderer:function renderer(_renderer){_this2.composer.replaceRenderer(_renderer);},scene:function scene(_scene){_this2.scene=_scene;},camera:function camera(_camera){_this2.camera=_camera;}});this.resolve();}/**
* @method render
* @description Adds RenderPass
* @return {this}
* @memberof module:modules/app.PostProcessorModule
*/},{key:"render",value:function render(){var _this3=this;this.defer.then(function(){var pass=new RenderPass(_this3.scene,_this3.camera.native);// TODO: Support for effects.
_this3.composer.addPass(pass);_this3.currentPass=pass;});return this;}/**
* @method pass
* @description Adds your custom pass
* @param {Pass} pass A custom pass
* @return {this}
* @memberof module:modules/app.PostProcessorModule
*/},{key:"pass",value:function pass(_pass){var _this4=this;this.defer.then(function(){polyfill(_pass,'setSize',_this4.debug);polyfill(_pass,'initialise',_this4.debug);_this4.composer.addPass(_pass);_this4.currentPass=_pass;});return this;}/**
* @method shader
* @description Adds a pass made from shader material
* @param {Material} material A ShaderMaterial
* @param {String} textureID Name of the readBuffer uniform
* @return {this}
* @memberof module:modules/app.PostProcessorModule
*/},{key:"shader",value:function shader(material){var _this5=this;var textureID=arguments.length>1&&arguments[1]!==undefined?arguments[1]:'readBuffer';this.defer.then(function(){if(!material.uniforms[textureID])material.uniforms[textureID]={value:null};var pass=new ShaderPass(material,textureID);_this5.composer.addPass(pass);_this5.currentPass=pass;});return this;}/**
* @method get
* @description Returns a pass by the given name
* @param {String} name The name of the pass
* @return {this}
* @memberof module:modules/app.PostProcessorModule
*/},{key:"get",value:function get(name){return name?this.composer.passes.filter(function(pass){return pass.name===name;})[0]:this.currentPass;}/**
* @method renderToScreen
* @description Sets the renderToScreen property of currentPass
* @param {String} [name=true] The name of the pass
* @return {this}
* @memberof module:modules/app.PostProcessorModule
*/},{key:"renderToScreen",value:function renderToScreen(){var _this6=this;var bool=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;this.defer.then(function(){_this6.currentPass.renderToScreen=bool;});return this;}}]);return PostProcessorModule;}();defineProperty$3(PostProcessorModule,"defaults",{debug:true});/**
* @class EventsPatchModule
* @description This one is used in the core to handle events used by modules. If you want to make custom events - please make a similar one.
* @category modules/app
* @memberof module:modules/app
*/var EventsPatchModule=/*#__PURE__*/function(){function EventsPatchModule(){classCallCheck(this,EventsPatchModule);}createClass(EventsPatchModule,[{key:"manager",value:function manager(_manager){_manager.define('events');this.element=_manager.get('renderer').domElement;}/**
* @function patchEvents
* @description This methods patches the list of events on specific object.
* @param {Number} originObject - The object that gives events.
* @param {Number} [destObject=this] - The object that takes events.
* @param {Array[Strings]} [events=[]] - The list of events by names.
* @memberof module:modules/app.EventsPatchModule
*/},{key:"patchEvents",value:function patchEvents(originObject){var destObject=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this;var events=arguments.length>2&&arguments[2]!==undefined?arguments[2]:[];events.forEach(function(event){return originObject.addEventListener(event,function(e){return destObject.emit(event,e);});});}},{key:"integrate",value:function integrate(self){var element=self.element,patchEvents=self.patchEvents;patchEvents(element,this,['mousemove','mouseup','contextmenu','mousedown','click','wheel','touchstart','touchend','touchmove','keydown','keyup','keypress']);}}]);return EventsPatchModule;}();/**
* @class VirtualMouseModule
* @category modules/app
* @param {Boolean} [globalMovement=false]
* @memberof module:modules/app
* @extends Events
*/var VirtualMouseModule=/*#__PURE__*/function(_Events){function VirtualMouseModule(){var _this;var globalMovement=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;classCallCheck(this,VirtualMouseModule);_this=possibleConstructorReturn(this,getPrototypeOf$2(VirtualMouseModule).call(this));defineProperty$3(defineProperty$3(defineProperty$3(defineProperty$3(defineProperty$3(assertThisInitialized(assertThisInitialized(_this)),"mouse",new Vector2()),"raycaster",new Raycaster()),"world",null),"canvas",null),"projectionPlane",new Plane(new Vector3(0,0,1),0));_this.globalMovement=globalMovement;return _this;}createClass(VirtualMouseModule,[{key:"update",value:function update(e,customX,customY){var rect=this.canvas.getBoundingClientRect();var x=customX||e.clientX;var y=customY||e.clientY;this.mouse.x=(x-rect.left)/(rect.right-rect.left)*2-1;this.mouse.y=-((y-rect.top)/(rect.bottom-rect.top))*2+1;this.projectionPlane.normal.copy(this.camera.getWorldDirection());this.raycaster.setFromCamera(this.mouse,this.camera);this.emit('move');}},{key:"manager",value:function manager(_manager){_manager.define('mouse');_manager.require('events',function(){return new EventsPatchModule();});this.canvas=_manager.get('renderer').domElement;this.camera=_manager.get('camera').native;}},{key:"integrate",value:function integrate(self){var _this2=this;['click','mousedown','mouseup','mousemove'].forEach(function(ev){return _this2.on(ev,function(e){return self.emit(ev,e);});});self.globalX=0;self.globalY=0;this.on('mousemove',function(e){if(document.pointerLockElement!==null){self.globalX+=e.movementX;self.globalY+=e.movementY;self.update(e,self.globalX,self.globalY);}else self.update(e);});}/**
* @method track
* @description Starts tracking events on a component
* @param {Component} component A component, that should be tracked by the mouse
* @param {Boolean} nested Whether component's children should be tracked or not
* @memberof module:modules/app.VirtualMouseModule
*/},{key:"track",value:function track(component){var _this3=this;var nested=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;var isHovered=false;this.on('move',function(){if(_this3.hovers(component,nested)){if(isHovered)component.emit('mousemove');else{component.emit('mouseover');isHovered=true;}}else if(isHovered){component.emit('mouseout');isHovered=false;}});this.on('click',function(){if(isHovered)component.emit('click');else component.emit('offClick');});this.on('mousedown',function(){if(isHovered)component.emit('mousedown');});this.on('mouseup',function(){if(isHovered)component.emit('mouseup');});}/**
* @method intersection
* @description Returns an intersection data
* @param {Component} component A component that intersects with mouse ray (or doesn't)
* @param {Boolean} nested Whether component's children should be tracked or not
* @return {Array} intersection data.
* @memberof module:modules/app.VirtualMouseModule
*/},{key:"intersection",value:function intersection(_ref){var native=_ref.native;var nested=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;if(native.children.length>0&&nested){var objects=[];native.traverse(function(child){return objects.push(child);});return this.raycaster.intersectObjects(objects);}return this.raycaster.intersectObject(native);}/**
* @method project
* @description Returns a vector based on mouse ray intersection with plane
* @param {THREE.Plane} [plane=this.projectionPlane] Math plane that is used
* @param {Vector3} [target] Optional target
* @return {Vector3} An intersection point.
* @memberof module:modules/app.VirtualMouseModule
*/},{key:"project",value:function project(){var plane=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.projectionPlane;var target=arguments.length>1?arguments[1]:undefined;return this.raycaster.ray.intersectPlane(plane,target);}/**
* @method hovers
* @description Returns a boolean based on intersection data (Whether mouse hovers the component)
* @param {Component} component A component that intersects with mouse ray (or doesn't)
* @param {Boolean} nested Whether component's children should be tracked or not
* @return {Boolean} Whether the component is hovered.
* @memberof module:modules/app.VirtualMouseModule
*/},{key:"hovers",value:function hovers(component){var nested=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;return this.intersection(component,nested).length>0;}/**
* Mouse ray
* @member {THREE.Ray} module:modules/app.VirtualMouseModule#ray
* @public
*/},{key:"ray",get:function get(){return this.raycaster.ray;}/**
* Mouse x [-1; 1]
* @member {Number} module:modules/app.VirtualMouseModule#x
* @public
*/},{key:"x",get:function get(){return this.mouse.x;}/**
* Mouse y [-1; 1]
* @member {Number} module:modules/app.VirtualMouseModule#y
* @public
*/},{key:"y",get:function get(){return this.mouse.y;}}]);inherits(VirtualMouseModule,_Events);return VirtualMouseModule;}(minivents_commonjs);/**
* @class ControlsModule
* @category modules/app
* @param {Object} [params]
* @memberof module:modules/app
* @example <caption> Creating a rendering module and passing it to App's modules</caption>
* new App([
* new ElementModule(),
* new SceneModule(),
* new DefineModule('camera', new WHS.PerspectiveCamera({
* position: new THREE.Vector3(0, 6, 18),
* far: 10000
* })),
* new RenderingModule(),
* new ControlsModule.from(new THREE.TrackballControls())
* ]);
*/var ControlsModule=/*#__PURE__*/function(){createClass(ControlsModule,null,[{key:"from",value:function from(controls){return new ControlsModule({controls:controls});}}]);function ControlsModule(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,ControlsModule);this.params=Object.assign({controls:false,fix:function fix(controls){return controls;},update:function update(c){this.controls.update(c.getDelta());}},params);this.controls=this.params.controls;this.update=this.params.update;}createClass(ControlsModule,[{key:"manager",value:function manager(_manager){_manager.define('controls');_manager.require('events',function(){return new EventsPatchModule();});}/**
* @method setControls
* @description Set working controls
* @param {Object} controls Working three.js controls object.
* @return {this}
* @memberof module:modules/app.ControlsModule
*/},{key:"setControls",value:function setControls(controls){this.controls=controls;return this;}/**
* @method setUpdate
* @description Set controls update function
* @param {Function} update Update function
* @return {this}
* @memberof module:modules/app.ControlsModule
*/},{key:"setUpdate",value:function setUpdate(update){this.update=update;return this;}},{key:"integrate",value:function integrate(self){self.updateLoop=new Loop(self.update.bind(self));self.updateLoop.start(this);}}]);return ControlsModule;}();/**
* @class FogModule
* @category modules/app
* @param {Object} [params={color: 0xefd1b5, density: 0.020, near: 10, far: 1000}] - The parameters object.
* @param {String} [type=exp2] - The type of fog - exp2 or linear
* @memberof module:modules/app
* @example <caption>How to create and apply a FogModule</caption>
* const fogModule = new FogModule({
* color: 0xffffff,
* density: 0.03,
* near: 20,
* far: 200
* }, 'exp2');
*
* new App([
* ...,
* fogModule
* ]);
*/var FogModule=/*#__PURE__*/function(){function FogModule(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var type=arguments.length>1?arguments[1]:undefined;classCallCheck(this,FogModule);this.params=Object.assign({color:0xefd1b5,density:0.020,near:10,far:1000},params);if(!type||type==='exp2')this.fog=new FogExp2(this.params.color,this.params.density);else if(type==='linear')this.fog=new Fog(this.params.color,this.params.near,this.params.far);}createClass(FogModule,[{key:"manager",value:function manager(_manager){_manager.set('fog',this.fog);_manager.get('scene').fog=this.fog;}}]);return FogModule;}();var isEqualDefault=function isEqualDefault(a,b){if(a===b)return true;else if(a&&a.equals&&a.equals(b))return true;return false;};/**
* @class StateModule
* @description `StateModule` is useful for apps, where you need state manipulation.
* This can be: _transitions between screens, games, development moments_.
* You can check [basic/state](https://whs-dev.surge.sh/examples/?basic/state) example.
* @category modules/app
* @param {Object} [params]
* @memberof module:modules/app
* @example <caption> Creating a state module</caption>
* new App([
* // ...
* new StateModule().default({
* sphereColor: 0xff0000
* })
* ]);
*/var StateModule=/*#__PURE__*/function(){createClass(StateModule,null,[{key:"actionGenerate",value:function actionGenerate(isEqual){return function(){var state=arguments.length>0&&arguments[0]!==undefined?arguments[0]:[{},''];var _ref=arguments.length>1?arguments[1]:undefined,key=_ref.key,data=_ref.data;if(isEqual(state[0][key],data))return state;state[0][key]=data;state[1]=key;return state;};}}]);function StateModule(){var equalCheck=arguments.length>0&&arguments[0]!==undefined?arguments[0]:isEqualDefault;classCallCheck(this,StateModule);this.store=createStore(StateModule.actionGenerate(equalCheck));this.configuration={};this.currentConfig='default';this.prevConfig='default';}/**
* @method default
* @description Add default configuration.
* @param {Object} data Configuration setup
* @memberof module:modules/app.StateModule
* @example
* new WHS.StateModule().default({
* sphereColor: UTILS.$colors.mesh,
* planeColor: 0x447F8B
* })
*/createClass(StateModule,[{key:"default",value:function _default(data){this.config({default:data});return this;}/**
* @method setEqualCheck
* @description Sets an equalCheck function
* @param {Function} func function to generate equal check
* @memberof module:modules/app.StateModule
*/},{key:"setEqualCheck",value:function setEqualCheck(func){this.store.replaceReducer(StateModule.actionGenerate(func));}},{key:"manager",value:function manager(_manager){_manager.define('state');}/**
* @method config
* @description Load configurations from object.
* @param {Object} configs Configuration data
* @memberof module:modules/app.StateModule
* @example <caption> Adding `green` configuration</caption>
* state.config({
* green: {
* sphereColor: 0x00ff00,
* planeColor: 0x00ff00
* }
* });
*/},{key:"config",value:function config(configs){for(var key in configs){if(key){this.configuration[key]=key==='default'?configs[key]:Object.assign({},this.configuration.default,configs[key]);}}}/**
* @method update
* @description Load updates from object.
* @param {Object} updates Updates data
* @memberof module:modules/app.StateModule
* @example <caption> Update callback for `sphereColor`</caption>
* state.update({
* sphereColor: color => sphere.material.color.setHex(color)
* });
*/},{key:"update",value:function update(){var _this=this;var updates=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};this.store.subscribe(function(){var _this$store$getState=_this.store.getState(),_this$store$getState2=slicedToArray(_this$store$getState,2),data=_this$store$getState2[0],changedKey=_this$store$getState2[1];var callback=updates[changedKey];if(callback)callback(data[changedKey]);});}/**
* @method to
* @description Switch to configuration.
* @param {String} configName Configuration name.
* @memberof module:modules/app.StateModule
* @example <caption> Changes configuration to `green`</caption>
* state.to('green');
*/},{key:"to",value:function to(configName){this.prevConfig=this.currentConfig;this.currentConfig=configName;var config=this.configuration[configName]?this.configuration[configName]:this.configuration.default;this.set(config);}/**
* @method set
* @description Set current parameters.
* @param {Object} data Configuration parameters.
* @memberof module:modules/app.StateModule
* @example
* state.set({
* sphereColor: 0x00ff00
* });
*/},{key:"set",value:function set(data){for(var key in data){if(key)this.store.dispatch({type:'ADD',key:key,data:data[key]});}}/**
* @method get
* @description Return data of parameter.
* @param {String} key Parameter name.
* @memberof module:modules/app.StateModule
* @example
* state.get('sphereColor'); // 0x00ff00
*/},{key:"get",value:function get(key){return this.store.getState()[0][key];}/**
* @method prev
* @description Return `trueVal` if `config` match previous configuration, in other case - return `falseVal`.
* @param {String} config Configuration name.
* @param {Any} trueVal Value returned if condition is truthy.
* @param {Any} falseVal Value returned if condition is falsy.
* @memberof module:modules/app.StateModule
*/},{key:"prev",value:function prev(config,trueVal,falseVal){return this.prevConfig===config?trueVal:falseVal;}/**
* @method current
* @description Return `trueVal` if `config` match current configuration, in other case - return `falseVal`.
* @param {String} config Configuration name.
* @param {Any} trueVal Value returned if condition is truthy.
* @param {Any} falseVal Value returned if condition is falsy.
* @memberof module:modules/app.StateModule
*/},{key:"current",value:function current(config,trueVal,falseVal){return this.currentConfig===config?trueVal:falseVal;}}]);return StateModule;}();// Unlike TrackballControls, it maintains the "up" direction object.up (+Y by default).
//
// Orbit - left mouse / touch: one finger move
// Zoom - middle mouse, or mousewheel / touch: two finger spread or squish
// Pan - right mouse, or arrow keys / touch: three finter swipe
var ThreeOrbitControls=/*#__PURE__*/function(_EventDispatcher){function ThreeOrbitControls(object,domElement,eventHandler){var _this;classCallCheck(this,ThreeOrbitControls);_this=possibleConstructorReturn(this,getPrototypeOf$2(ThreeOrbitControls).call(this));_this.object=object;_this.domElement=domElement===undefined?document:domElement;_this.eventHandler=eventHandler;// Set to false to disable this control
_this.enabled=true;// "target" sets the location of focus, where the object orbits around
_this.target=new Vector3();// How far you can dolly in and out ( PerspectiveCamera only )
_this.minDistance=0;_this.maxDistance=Infinity;// How far you can zoom in and out ( OrthographicCamera only )
_this.minZoom=0;_this.maxZoom=Infinity;// How far you can orbit vertically, upper and lower limits.
// Range is 0 to Math.PI radians.
_this.minPolarAngle=0;// radians
_this.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;// radians
_this.maxAzimuthAngle=Infinity;// radians
// Set to true to enable damping (inertia)
// If damping is enabled, you must call controls.update() in your animation loop
_this.enableDamping=false;_this.dampingFactor=0.25;// This option actually enables dollying in and out; left as "zoom" for backwards compatibility.
// Set to false to disable zooming
_this.enableZoom=true;_this.zoomSpeed=1.0;// Set to false to disable rotating
_this.enableRotate=true;_this.rotateSpeed=1.0;// Set to false to disable panning
_this.enablePan=true;_this.keyPanSpeed=7.0;// pixels moved per arrow key push
// Set to true to automatically rotate around the target
// If auto-rotate is enabled, you must call controls.update() in your animation loop
_this.autoRotate=false;_this.autoRotateSpeed=2.0;// 30 seconds per round when fps is 60
// Set to false to disable use of the keys
_this.enableKeys=true;// The four arrow keys
_this.keys={LEFT:37,UP:38,RIGHT:39,BOTTOM:40};// Mouse buttons
_this.mouseButtons={ORBIT:MOUSE.LEFT,ZOOM:MOUSE.MIDDLE,PAN:MOUSE.RIGHT};// for reset
_this.target0=_this.target.clone();_this.position0=_this.object.position.clone();_this.zoom0=_this.object.zoom;//
// public methods
//
_this.getPolarAngle=function(){return spherical.phi;};_this.getAzimuthalAngle=function(){return spherical.theta;};_this.reset=function(){_this.target.copy(_this.target0);_this.object.position.copy(_this.position0);_this.object.zoom=_this.zoom0;_this.object.updateProjectionMatrix();_this.dispatchEvent(changeEvent);_this.update();state=STATE.NONE;};// this method is exposed, but perhaps it would be better if we can make it private...
_this.update=function(){var offset=new Vector3();// so camera.up is the orbit axis
var quat=new Quaternion().setFromUnitVectors(object.up,new Vector3(0,1,0));var quatInverse=quat.clone().inverse();var lastPosition=new Vector3();var lastQuaternion=new Quaternion();return function(){var position=_this.object.position;offset.copy(position).sub(_this.target);// rotate offset to "y-axis-is-up" space
offset.applyQuaternion(quat);// angle from z-axis around y-axis
spherical.setFromVector3(offset);if(_this.autoRotate&&state===STATE.NONE)rotateLeft(getAutoRotationAngle());spherical.theta+=sphericalDelta.theta;spherical.phi+=sphericalDelta.phi;// restrict theta to be between desired limits
spherical.theta=Math.max(_this.minAzimuthAngle,Math.min(_this.maxAzimuthAngle,spherical.theta));// restrict phi to be between desired limits
spherical.phi=Math.max(_this.minPolarAngle,Math.min(_this.maxPolarAngle,spherical.phi));spherical.makeSafe();spherical.radius*=scale;// restrict radius to be between desired limits
spherical.radius=Math.max(_this.minDistance,Math.min(_this.maxDistance,spherical.radius));// move target to panned location
_this.target.add(panOffset);offset.setFromSpherical(spherical);// rotate offset back to "camera-up-vector-is-up" space
offset.applyQuaternion(quatInverse);position.copy(_this.target).add(offset);_this.object.lookAt(_this.target);if(_this.enableDamping===true){sphericalDelta.theta*=1-_this.dampingFactor;sphericalDelta.phi*=1-_this.dampingFactor;}else sphericalDelta.set(0,0,0);scale=1;panOffset.set(0,0,0);// update condition is:
// min(camera displacement, camera rotation in radians)^2 > EPS
// using small-angle approximation cos(x/2) = 1 - x^2 / 8
if(zoomChanged||lastPosition.distanceToSquared(_this.object.position)>EPS||8*(1-lastQuaternion.dot(_this.object.quaternion))>EPS){_this.dispatchEvent(changeEvent);lastPosition.copy(_this.object.position);lastQuaternion.copy(_this.object.quaternion);zoomChanged=false;return true;}return false;}();};_this.dispose=function(){_this.domElement.removeEventListener('contextmenu',onContextMenu,false);_this.domElement.removeEventListener('mousedown',onMouseDown,false);_this.domElement.removeEventListener('wheel',onMouseWheel,false);_this.domElement.removeEventListener('touchstart',onTouchStart,false);_this.domElement.removeEventListener('touchend',onTouchEnd,false);_this.domElement.removeEventListener('touchmove',onTouchMove,false);document.removeEventListener('mousemove',onMouseMove,false);document.removeEventListener('mouseup',onMouseUp,false);window.removeEventListener('keydown',onKeyDown,false);// this.dispatchEvent( { type: 'dispose' } ); // should this be added here?
};//
// internals
//
var changeEvent={type:'change'};var startEvent={type:'start'};var endEvent={type:'end'};var STATE={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_DOLLY:4,TOUCH_PAN:5};var state=STATE.NONE;var EPS=0.000001;// current position in spherical coordinates
var spherical=new Spherical();var sphericalDelta=new Spherical();var scale=1;var panOffset=new Vector3();var zoomChanged=false;var rotateStart=new Vector2();var rotateEnd=new Vector2();var rotateDelta=new Vector2();var panStart=new Vector2();var panEnd=new Vector2();var panDelta=new Vector2();var dollyStart=new Vector2();var dollyEnd=new Vector2();var dollyDelta=new Vector2();var getAutoRotationAngle=function getAutoRotationAngle(){return 2*Math.PI/60/60*_this.autoRotateSpeed;};var getZoomScale=function getZoomScale(){return Math.pow(0.95,_this.zoomSpeed);};var rotateLeft=function rotateLeft(angle){sphericalDelta.theta-=angle;};var rotateUp=function rotateUp(angle){sphericalDelta.phi-=angle;};var panLeft=function(){var v=new Vector3();return function(distance,objectMatrix){v.setFromMatrixColumn(objectMatrix,0);// get X column of objectMatrix
v.multiplyScalar(-distance);panOffset.add(v);};}();var panUp=function(){var v=new Vector3();return function(distance,objectMatrix){v.setFromMatrixColumn(objectMatrix,1);// get Y column of objectMatrix
v.multiplyScalar(distance);panOffset.add(v);};}();// deltaX and deltaY are in pixels; right and down are positive
var pan=function(){var offset=new Vector3();return function(deltaX,deltaY){var element=_this.domElement===document?_this.domElement.body:_this.domElement;if(_this.object instanceof PerspectiveCamera){// perspective
var position=_this.object.position;offset.copy(position).sub(_this.target);var targetDistance=offset.length();// half of the fov is center to top of screen
targetDistance*=Math.tan(_this.object.fov/2*Math.PI/180.0);// we actually don't use screenWidth, since perspective camera is fixed to screen height
panLeft(2*deltaX*targetDistance/element.clientHeight,_this.object.matrix);panUp(2*deltaY*targetDistance/element.clientHeight,_this.object.matrix);}else if(_this.object instanceof OrthographicCamera){// orthographic
panLeft(deltaX*(_this.object.right-_this.object.left)/_this.object.zoom/element.clientWidth,_this.object.matrix);panUp(deltaY*(_this.object.top-_this.object.bottom)/_this.object.zoom/element.clientHeight,_this.object.matrix);}else{// camera neither orthographic nor perspective
console.warn('WARNING: OrbitControlsModule.js encountered an unknown camera type - pan disabled.');_this.enablePan=false;}};}();var dollyIn=function dollyIn(dollyScale){if(_this.object instanceof PerspectiveCamera)scale/=dollyScale;else if(_this.object instanceof OrthographicCamera){_this.object.zoom=Math.max(_this.minZoom,Math.min(_this.maxZoom,_this.object.zoom*dollyScale));_this.object.updateProjectionMatrix();zoomChanged=true;}else{console.warn('WARNING: OrbitControlsModule.js encountered an unknown camera type - dolly/zoom disabled.');_this.enableZoom=false;}};var dollyOut=function dollyOut(dollyScale){if(_this.object instanceof PerspectiveCamera)scale*=dollyScale;else if(_this.object instanceof OrthographicCamera){_this.object.zoom=Math.max(_this.minZoom,Math.min(_this.maxZoom,_this.object.zoom/dollyScale));_this.object.updateProjectionMatrix();zoomChanged=true;}else{console.warn('WARNING: OrbitControlsModule.js encountered an unknown camera type - dolly/zoom disabled.');_this.enableZoom=false;}};//
// event callbacks - update the object state
//
var handleMouseDownRotate=function handleMouseDownRotate(event){// console.log( 'handleMouseDownRotate' );
rotateStart.set(event.clientX,event.clientY);};var handleMouseDownDolly=function handleMouseDownDolly(event){// console.log( 'handleMouseDownDolly' );
dollyStart.set(event.clientX,event.clientY);};var handleMouseDownPan=function handleMouseDownPan(event){// console.log( 'handleMouseDownPan' );
panStart.set(event.clientX,event.clientY);};var handleMouseMoveRotate=function handleMouseMoveRotate(event){// console.log( 'handleMouseMoveRotate' );
rotateEnd.set(event.clientX,event.clientY);rotateDelta.subVectors(rotateEnd,rotateStart);var element=_this.domElement===document?_this.domElement.body:_this.domElement;// rotating across whole screen goes 360 degrees around
rotateLeft(2*Math.PI*rotateDelta.x/element.clientWidth*_this.rotateSpeed);// rotating up and down along whole screen attempts to go 360, but limited to 180
rotateUp(2*Math.PI*rotateDelta.y/element.clientHeight*_this.rotateSpeed);rotateStart.copy(rotateEnd);_this.update();};var handleMouseMoveDolly=function handleMouseMoveDolly(event){// console.log( 'handleMouseMoveDolly' );
dollyEnd.set(event.clientX,event.clientY);dollyDelta.subVectors(dollyEnd,dollyStart);if(dollyDelta.y>0)dollyIn(getZoomScale());else if(dollyDelta.y<0)dollyOut(getZoomScale());dollyStart.copy(dollyEnd);_this.update();};var handleMouseMovePan=function handleMouseMovePan(event){// console.log( 'handleMouseMovePan' );
panEnd.set(event.clientX,event.clientY);panDelta.subVectors(panEnd,panStart);pan(panDelta.x,panDelta.y);panStart.copy(panEnd);_this.update();};var handleMouseWheel=function handleMouseWheel(event){// console.log( 'handleMouseWheel' );
if(event.deltaY<0)dollyOut(getZoomScale());else if(event.deltaY>0)dollyIn(getZoomScale());_this.update();};var handleKeyDown=function handleKeyDown(event){// console.log( 'handleKeyDown' );
switch(event.keyCode){case _this.keys.UP:pan(0,_this.keyPanSpeed);_this.update();break;case _this.keys.BOTTOM:pan(0,-_this.keyPanSpeed);_this.update();break;case _this.keys.LEFT:pan(_this.keyPanSpeed,0);_this.update();break;case _this.keys.RIGHT:pan(-_this.keyPanSpeed,0);_this.update();break;}};var handleTouchStartRotate=function handleTouchStartRotate(event){// console.log( 'handleTouchStartRotate' );
rotateStart.set(event.touches[0].pageX,event.touches[0].pageY);};var handleTouchStartDolly=function handleTouchStartDolly(event){// console.log( 'handleTouchStartDolly' );
var dx=event.touches[0].pageX-event.touches[1].pageX;var dy=event.touches[0].pageY-event.touches[1].pageY;var distance=Math.sqrt(dx*dx+dy*dy);dollyStart.set(0,distance);};var handleTouchStartPan=function handleTouchStartPan(event){// console.log( 'handleTouchStartPan' );
panStart.set(event.touches[0].pageX,event.touches[0].pageY);};var handleTouchMoveRotate=function handleTouchMoveRotate(event){// console.log( 'handleTouchMoveRotate' );
rotateEnd.set(event.touches[0].pageX,event.touches[0].pageY);rotateDelta.subVectors(rotateEnd,rotateStart);var element=_this.domElement===document?_this.domElement.body:_this.domElement;// rotating across whole screen goes 360 degrees around
rotateLeft(2*Math.PI*rotateDelta.x/element.clientWidth*_this.rotateSpeed);// rotating up and down along whole screen attempts to go 360, but limited to 180
rotateUp(2*Math.PI*rotateDelta.y/element.clientHeight*_this.rotateSpeed);rotateStart.copy(rotateEnd);_this.update();};var handleTouchMoveDolly=function handleTouchMoveDolly(event){// console.log( 'handleTouchMoveDolly' );
var dx=event.touches[0].pageX-event.touches[1].pageX;var dy=event.touches[0].pageY-event.touches[1].pageY;var distance=Math.sqrt(dx*dx+dy*dy);dollyEnd.set(0,distance);dollyDelta.subVectors(dollyEnd,dollyStart);if(dollyDelta.y>0)dollyOut(getZoomScale());else if(dollyDelta.y<0)dollyIn(getZoomScale());dollyStart.copy(dollyEnd);_this.update();};var handleTouchMovePan=function handleTouchMovePan(event){// console.log( 'handleTouchMovePan' );
panEnd.set(event.touches[0].pageX,event.touches[0].pageY);panDelta.subVectors(panEnd,panStart);pan(panDelta.x,panDelta.y);panStart.copy(panEnd);_this.update();};// event handlers - FSM: listen for events and reset state
//
var onMouseDown=function onMouseDown(event){if(_this.enabled===false)return;event.preventDefault();if(event.button===_this.mouseButtons.ORBIT){if(_this.enableRotate===false)return;handleMouseDownRotate(event);state=STATE.ROTATE;}else if(event.button===_this.mouseButtons.ZOOM){if(_this.enableZoom===false)return;handleMouseDownDolly(event);state=STATE.DOLLY;}else if(event.button===_this.mouseButtons.PAN){if(_this.enablePan===false)return;handleMouseDownPan(event);state=STATE.PAN;}if(state!==STATE.NONE){_this.eventHandler.on('mousemove',onMouseMove,false);_this.eventHandler.on('mouseup',onMouseUp,false);_this.dispatchEvent(startEvent);}};var onMouseMove=function onMouseMove(event){if(_this.enabled===false)return;event.preventDefault();if(state===STATE.ROTATE){if(_this.enableRotate===false)return;handleMouseMoveRotate(event);}else if(state===STATE.DOLLY){if(_this.enableZoom===false)return;handleMouseMoveDolly(event);}else if(state===STATE.PAN){if(_this.enablePan===false)return;handleMouseMovePan(event);}};var onMouseUp=function onMouseUp(event){if(_this.enabled===false)return;document.removeEventListener('mousemove',onMouseMove,false);document.removeEventListener('mouseup',onMouseUp,false);_this.dispatchEvent(endEvent);state=STATE.NONE;};var onMouseWheel=function onMouseWheel(event){if(_this.enabled===false||_this.enableZoom===false||state!==STATE.NONE&&state!==STATE.ROTATE)return;event.preventDefault();event.stopPropagation();handleMouseWheel(event);_this.dispatchEvent(startEvent);// not sure why these are here...
_this.dispatchEvent(endEvent);};var onKeyDown=function onKeyDown(event){if(_this.enabled===false||_this.enableKeys===false||_this.enablePan===false)return;handleKeyDown(event);};var onTouchStart=function onTouchStart(event){if(_this.enabled===false)return;switch(event.touches.length){case 1:// one-fingered touch: rotate
if(_this.enableRotate===false)return;handleTouchStartRotate(event);state=STATE.TOUCH_ROTATE;break;case 2:// two-fingered touch: dolly
if(_this.enableZoom===false)return;handleTouchStartDolly(event);state=STATE.TOUCH_DOLLY;break;case 3:// three-fingered touch: pan
if(_this.enablePan===false)return;handleTouchStartPan(event);state=STATE.TOUCH_PAN;break;default:state=STATE.NONE;}if(state!==STATE.NONE)_this.dispatchEvent(startEvent);};var onTouchMove=function onTouchMove(event){if(_this.enabled===false)return;event.preventDefault();event.stopPropagation();switch(event.touches.length){case 1:// one-fingered touch: rotate
if(_this.enableRotate===false)return;if(state!==STATE.TOUCH_ROTATE)return;// is this needed?...
handleTouchMoveRotate(event);break;case 2:// two-fingered touch: dolly
if(_this.enableZoom===false)return;if(state!==STATE.TOUCH_DOLLY)return;// is this needed?...
handleTouchMoveDolly(event);break;case 3:// three-fingered touch: pan
if(_this.enablePan===false)return;if(state!==STATE.TOUCH_PAN)return;// is this needed?...
handleTouchMovePan(event);break;default:state=STATE.NONE;}};var onTouchEnd=function onTouchEnd(event){if(_this.enabled===false)return;_this.dispatchEvent(endEvent);state=STATE.NONE;};var onContextMenu=function onContextMenu(event){event.preventDefault();};//
_this.eventHandler.on('contextmenu',onContextMenu,false);_this.eventHandler.on('mousedown',onMouseDown,false);_this.eventHandler.on('wheel',onMouseWheel,false);_this.eventHandler.on('touchstart',onTouchStart,false);_this.eventHandler.on('touchend',onTouchEnd,false);_this.eventHandler.on('touchmove',onTouchMove,false);_this.eventHandler.on('keydown',onKeyDown,false);// force an update at start
_this.update();return _this;}createClass(ThreeOrbitControls,[{key:"center",get:function get(){console.warn('OrbitControls: .center has been renamed to .target');return this.target;}},{key:"noZoom",get:function get(){console.warn('OrbitControls: .noZoom has been deprecated. Use .enableZoom instead.');return !this.enableZoom;},set:function set(value){console.warn('OrbitControls: .noZoom has been deprecated. Use .enableZoom instead.');this.enableZoom=!value;}},{key:"noRotate",get:function get(){console.warn('OrbitControls: .noRotate has been deprecated. Use .enableRotate instead.');return !this.enableRotate;},set:function set(value){console.warn('OrbitControls: .noRotate has been deprecated. Use .enableRotate instead.');this.enableRotate=!value;}},{key:"noPan",get:function get(){console.warn('OrbitControls: .noPan has been deprecated. Use .enablePan instead.');return !this.enablePan;},set:function set(value){console.warn('OrbitControls: .noPan has been deprecated. Use .enablePan instead.');this.enablePan=!value;}},{key:"noKeys",get:function get(){console.warn('OrbitControls: .noKeys has been deprecated. Use .enableKeys instead.');return !this.enableKeys;},set:function set(value){console.warn('OrbitControls: .noKeys has been deprecated. Use .enableKeys instead.');this.enableKeys=!value;}},{key:"staticMoving",get:function get(){console.warn('OrbitControls: .staticMoving has been deprecated. Use .enableDamping instead.');return !this.enableDamping;},set:function set(value){console.warn('OrbitControls: .staticMoving has been deprecated. Use .enableDamping instead.');this.enableDamping=!value;}},{key:"dynamicDampingFactor",get:function get(){console.warn('OrbitControls: .dynamicDampingFactor has been renamed. Use .dampingFactor instead.');return this.dampingFactor;},set:function set(value){console.warn('OrbitControls: .dynamicDampingFactor has been renamed. Use .dampingFactor instead.');this.dampingFactor=value;}}]);inherits(ThreeOrbitControls,_EventDispatcher);return ThreeOrbitControls;}(EventDispatcher);/**
* @class OrbitControlsModule
* @category modules/app
* @param {Object} [params]
* @param {Object} [params.object=camera] Object to which controls are applied.
* @param {THREE.Vector3} [params.target=new Vector3()] Controls center vector.
* @param {Boolean} [params.follow=false] Follow the target
* @memberof module:modules/app
* @example <caption> Creating a rendering module and passing it to App's modules</caption>
* new App([
* new ElementModule(),
* new SceneModule(),
* new DefineModule('camera', new WHS.PerspectiveCamera({
* position: new THREE.Vector3(0, 6, 18),
* far: 10000
* })),
* new RenderingModule(),
* new OrbitControlsModule()
* ]);
*/var OrbitControlsModule=/*#__PURE__*/function(_ControlsModule){function OrbitControlsModule(){var _this;var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,OrbitControlsModule);_this=possibleConstructorReturn(this,getPrototypeOf$2(OrbitControlsModule).call(this,params));_this.params=Object.assign({follow:false,object:null,target:new Vector3()},params);return _this;}createClass(OrbitControlsModule,[{key:"manager",value:function manager(_manager){get$3(getPrototypeOf$2(OrbitControlsModule.prototype),"manager",this).call(this,_manager);var _this$params=this.params,obj=_this$params.object,follow=_this$params.follow,target=_this$params.target;var object=obj?obj.native:_manager.get('camera').native;var controls=new ThreeOrbitControls(object,_manager.get('element'),_manager.handler);var updateProcessor=follow?function(c){controls.update(c.getDelta());controls.target.copy(target);}:function(c){controls.update(c.getDelta());};this.setControls(controls);this.setUpdate(updateProcessor);_manager.update({camera:function camera(_camera){if(obj)return;controls.object=_camera.native;},element:function element(_element){controls.domElement=_element;}});controls.target.copy(target);}}]);inherits(OrbitControlsModule,_ControlsModule);return OrbitControlsModule;}(ControlsModule);/** @module modules/app/controls */ /** @module modules/app */ /**
* @class DynamicGeometryModule
* @category modules/mesh
* @param {Object} [params={attributes: false}] - params
* @param {Boolean} [patchEvents=true]
* @memberof module:modules/mesh
*/var DynamicGeometryModule=/*#__PURE__*/function(){function DynamicGeometryModule(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,DynamicGeometryModule);this.params=Object.assign({attributes:false},params);}createClass(DynamicGeometryModule,[{key:"integrate",value:function integrate(self){var _this=this;var params=self.params;this.g_=function(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};if(this.buildGeometry){this.native.geometry=this.buildGeometry(this.updateParams({geometry:params}));}};if(params.attributes){var _loop=function _loop(key){if(key){Object.defineProperty(_this,"g_".concat(key),{get:function get(){return this.native.geometry.parameters[key];},set:function set(value){this.native.geometry=this.buildGeometry(this.updateParams({geometry:defineProperty$3({},key,value)}));},configurable:true,enumerable:true});}};for(var key in this.params.geometry){_loop(key);}}}}]);return DynamicGeometryModule;}();var loader=new TextureLoader();/**
* @class TextureModule
* @category modules/mesh
* @description A TextureModule can be applied to any Mesh or Model.
* @param {Array} [textures] - array of texture objects
* @memberof module:modules/mesh
* @example <caption>Creating an instance. url takes a path, or a data object.</caption>
* var woodTexture = new TextureModule({
* url: `${process.assetsPath}/textures/wood.jpg`
* });
* @example <caption>More comprehensive example, wood texture applied to a Box.</caption>
* new Box({
* geometry: {
* width: 2,
* height: 2,
* depth: 2
* },
* modules: [
* new TextureModule({
* url: `path/to/texture.jpg`,
* repeat: new THREE.Vector2(1, 1) // optional
* })
* ],
* material: new THREE.MeshBasicMaterial({
* color: 0xffffff
* }),
* position: [50, 60, 70]
* }).addTo(app);
*/var TextureModule=/*#__PURE__*/function(){createClass(TextureModule,null,[{key:"load",value:function load(url){return new TextureModule({url:url}).textures[0][1];}}]);function TextureModule(){var _this=this;classCallCheck(this,TextureModule);defineProperty$3(defineProperty$3(this,"textures",[]),"bridge",{material:function material(_material,self){self.textures.forEach(function(texture){_material[texture[0]]=texture[1];});_material.needsUpdate=true;return _material;}});for(var _len=arguments.length,textures=new Array(_len),_key=0;_key<_len;_key++){textures[_key]=arguments[_key];}textures.forEach(function(_ref){var url=_ref.url,_ref$type=_ref.type,type=_ref$type===void 0?'map':_ref$type,_ref$offset=_ref.offset,offset=_ref$offset===void 0?new Vector2(0,0):_ref$offset,_ref$repeat=_ref.repeat,repeat=_ref$repeat===void 0?new Vector2(1,1):_ref$repeat,_ref$wrap=_ref.wrap,wrap=_ref$wrap===void 0?RepeatWrapping:_ref$wrap,_ref$mapping=_ref.mapping,mapping=_ref$mapping===void 0?UVMapping:_ref$mapping,_ref$fix=_ref.fix,fix=_ref$fix===void 0?function(tex){return tex;}:_ref$fix;var texture=loader.load(url);if(wrap.length>0){texture.wrapS=wrap[0];texture.wrapT=wrap[1];}else texture.wrapS=texture.wrapT=wrap;texture.mapping=mapping;texture.offset.copy(offset);texture.repeat.copy(repeat);texture.magFilter=NearestFilter;texture.minFilter=LinearMipMapLinearFilter;_this.textures.push([type,fix(texture)]);});}return TextureModule;}();/**
* @class AnimationModule
* @category modules/mesh
* @description Convenience module that wraps the <a href='https://threejs.org/docs/#manual/introduction/Animation-system'>three.js animation system</a>
* @param {App} app - the app
* @param {Boolean} [isDeferred=false] - set to true if animation should not start automatically
* @param {Object} [params={speed: 1}] - the params
* @memberof module:modules/mesh
* @example <caption>Create animation module and play a given clip of an imported model</caption>
* const animationModule = new AnimationModule(app, false, {
* speed: 1.2 // speed up animation by 20%
* });
*
* new Importer({
* parser(geometry, materials) {
* // Override parse to generate a skinnedMesh, needed for skinned models
* return new THREE.SkinnedMesh(geometry, materials);
* },
*
* url: `path/to/model.json`,
* useCustomMaterial: true,
*
* material: new THREE.MeshStandardMaterial({
* skinning: true
* }),
*
* modules: [animationModule]
* }).addTo(app).then(() => {
* // adding model to app returns a promise, so pipe the function to kick off the animation clip
* animationModule.play('clipName');
* });
*/var AnimationModule=/*#__PURE__*/function(){function AnimationModule(app,isDeferred){var params=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{};classCallCheck(this,AnimationModule);defineProperty$3(this,"bridge",{mesh:function mesh(_mesh,self){_mesh.geometry.skeleton=_mesh.skeleton;self.mixer=new AnimationMixer(_mesh.geometry);self.clips=_mesh.geometry.animations;return _mesh;}});this.params=Object.assign({speed:1},params);this.clock=new Clock();this.app=app;this.isDeferred=isDeferred;}/**
* @method play
* @instance
* @description Plays the given clip name
* @param {String} clipName - the clip to play
* @return {THREE.AnimationAction} Playing action
* @memberof module:modules/mesh.AnimationModule
*/createClass(AnimationModule,[{key:"play",value:function play(clipName){var clip=AnimationClip.findByName(this.clips,clipName);return this.mixer.clipAction(clip).play();}/**
* @method update
* @instance
* @description Update the mixer (being called on frame animation loop)
* @memberof module:modules/mesh.AnimationModule
*/},{key:"update",value:function update(){if(this.mixer)this.mixer.update(this.clock.getDelta()*this.params.speed);}},{key:"integrate",value:function integrate(self){self.loop=new Loop(function(){self.update();});if(!self.isDeferred)self.loop.start(self.app);}},{key:"manager",value:function manager(_manager){_manager.define('animation');}}]);return AnimationModule;}();/** @module modules/mesh */ /**
* @class DefineModule
* @category modules
* @param {String} name
* @param {Object} data
* @memberof module:modules
* @example <caption> Creating a DefineModule with PerspectiveCamera as camera module and passing it to App's modules</caption>
* new App([
* // ...
* new DefineModule('camera', new PerspectiveCamera())
* ]);
*/var DefineModule=/*#__PURE__*/function(){function DefineModule(name,data){classCallCheck(this,DefineModule);this.name=name;this.data=data;}createClass(DefineModule,[{key:"manager",value:function manager(_manager){_manager.set(this.name,this.data);}}]);return DefineModule;}();/** @module modules */var Model=/*#__PURE__*/function(_Importer){function Model(params){var _getPrototypeOf2;classCallCheck(this,Model);console.warn('Model is deprecated. Use Importer instead.');if(params.geometry){params.url=params.geometry.path;params.loader=params.geometry.loader;}for(var _len=arguments.length,additional=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){additional[_key-1]=arguments[_key];}return possibleConstructorReturn(this,(_getPrototypeOf2=getPrototypeOf$2(Model)).call.apply(_getPrototypeOf2,[this,params].concat(additional)));}inherits(Model,_Importer);return Model;}(Importer);var CameraModule=/*#__PURE__*/function(){function CameraModule(){var params=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};classCallCheck(this,CameraModule);console.warn('CameraModule is deprecated. Use DefineModule instead.');this.camera=new PerspectiveCamera$1(params);}createClass(CameraModule,[{key:"integrate",value:function integrate(self){this.add(self.camera);}},{key:"manager",value:function manager(_manager){_manager.set('camera',this.camera);}}]);return CameraModule;}();
var commonjsGlobal = typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
function createCommonjsModule$1(fn, module) {
return module = { exports: {} }, fn(module, module.exports), module.exports;
}
var stats_min = createCommonjsModule$1(function (module, exports) {
// stats.js - http://github.com/mrdoob/stats.js
(function(f,e){module.exports=e();})(commonjsGlobal,function(){var f=function(){function e(a){c.appendChild(a.dom);return a}function u(a){for(var d=0;d<c.children.length;d++)c.children[d].style.display=d===a?"block":"none";l=a;}var l=0,c=document.createElement("div");c.style.cssText="position:fixed;top:0;left:0;cursor:pointer;opacity:0.9;z-index:10000";c.addEventListener("click",function(a){a.preventDefault();
u(++l%c.children.length);},!1);var k=(performance||Date).now(),g=k,a=0,r=e(new f.Panel("FPS","#0ff","#002")),h=e(new f.Panel("MS","#0f0","#020"));if(self.performance&&self.performance.memory)var t=e(new f.Panel("MB","#f08","#201"));u(0);return {REVISION:16,dom:c,addPanel:e,showPanel:u,begin:function(){k=(performance||Date).now();},end:function(){a++;var c=(performance||Date).now();h.update(c-k,200);if(c>g+1E3&&(r.update(1E3*a/(c-g),100),g=c,a=0,t)){var d=performance.memory;t.update(d.usedJSHeapSize/
1048576,d.jsHeapSizeLimit/1048576);}return c},update:function(){k=this.end();},domElement:c,setMode:u}};f.Panel=function(e,f,l){var c=Infinity,k=0,g=Math.round,a=g(window.devicePixelRatio||1),r=80*a,h=48*a,t=3*a,v=2*a,d=3*a,m=15*a,n=74*a,p=30*a,q=document.createElement("canvas");q.width=r;q.height=h;q.style.cssText="width:80px;height:48px";var b=q.getContext("2d");b.font="bold "+9*a+"px Helvetica,Arial,sans-serif";b.textBaseline="top";b.fillStyle=l;b.fillRect(0,0,r,h);b.fillStyle=f;b.fillText(e,t,v);
b.fillRect(d,m,n,p);b.fillStyle=l;b.globalAlpha=.9;b.fillRect(d,m,n,p);return {dom:q,update:function(h,w){c=Math.min(c,h);k=Math.max(k,h);b.fillStyle=l;b.globalAlpha=1;b.fillRect(0,0,r,m);b.fillStyle=f;b.fillText(g(h)+" "+e+" ("+g(c)+"-"+g(k)+")",t,v);b.drawImage(q,d+a,m,n-a,p,d,m,n-a,p);b.fillRect(d+n-a,m,a,p);b.fillStyle=l;b.globalAlpha=.9;b.fillRect(d+n-a,m,a,g((1-h/w)*p));}}};return f});
});
var StatsModule =
/*#__PURE__*/
function () {
function StatsModule() {
var code = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
_classCallCheck(this, StatsModule);
this.stats = new stats_min();
this.stats.showPanel(code);
}
_createClass(StatsModule, [{
key: "manager",
value: function manager(_manager) {
_manager.get('container').appendChild(this.stats.dom);
_manager.add('stats', this.stats, {
alias: '$stats'
});
}
}, {
key: "integrate",
value: function integrate(self) {
var stats = self.stats;
var preProcess = new Loop(function () {
return stats.begin();
});
var postProcess = new Loop(function () {
return stats.end();
});
this.loops.unshift(preProcess);
this.loops.push(postProcess); // Patch method
self.addLoop = function (loop) {
var _this = this;
return new Promise(function (resolve) {
if (_this.loops[_this.loops.length - 1] === postProcess) _this.loops.pop();
_this.loops.push(loop);
_this.loops.push(postProcess);
resolve(loop);
});
};
preProcess.start();
postProcess.start();
}
}]);
return StatsModule;
}();
_defineProperty(StatsModule, "codes", {
fps: 0,
ms: 1,
mb: 2,
custom: 3
});
export default StatsModule;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"StatsModule.module.js","sources":["../src/modules/extra/rollupPluginBabelHelpers","../../node_modules/whs/build/whs.module.js","../src/modules/extra/node_modules/stats.js/build/stats.min.js","../src/modules/extra/StatsModule.js"],"sourcesContent":["export { _typeof as typeof, _jsx as jsx, _asyncIterator as asyncIterator, _AwaitValue as AwaitValue, _AsyncGenerator as AsyncGenerator, _wrapAsyncGenerator as wrapAsyncGenerator, _awaitAsyncGenerator as awaitAsyncGenerator, _asyncGeneratorDelegate as asyncGeneratorDelegate, _asyncToGenerator as asyncToGenerator, _classCallCheck as classCallCheck, _createClass as createClass, _defineEnumerableProperties as defineEnumerableProperties, _defaults as defaults, _defineProperty as defineProperty, _extends as extends, _objectSpread as objectSpread, _inherits as inherits, _inheritsLoose as inheritsLoose, _getPrototypeOf as getPrototypeOf, _setPrototypeOf as setPrototypeOf, _construct as construct, _wrapNativeSuper as wrapNativeSuper, _instanceof as instanceof, _interopRequireDefault as interopRequireDefault, _interopRequireWildcard as interopRequireWildcard, _newArrowCheck as newArrowCheck, _objectDestructuringEmpty as objectDestructuringEmpty, _objectWithoutProperties as objectWithoutProperties, _assertThisInitialized as assertThisInitialized, _possibleConstructorReturn as possibleConstructorReturn, _superPropBase as superPropBase, _get as get, _set as set, _taggedTemplateLiteral as taggedTemplateLiteral, _taggedTemplateLiteralLoose as taggedTemplateLiteralLoose, _temporalRef as temporalRef, _readOnlyError as readOnlyError, _classNameTDZError as classNameTDZError, _temporalUndefined as temporalUndefined, _slicedToArray as slicedToArray, _slicedToArrayLoose as slicedToArrayLoose, _toArray as toArray, _toConsumableArray as toConsumableArray, _arrayWithoutHoles as arrayWithoutHoles, _arrayWithHoles as arrayWithHoles, _iterableToArray as iterableToArray, _iterableToArrayLimit as iterableToArrayLimit, _iterableToArrayLimitLoose as iterableToArrayLimitLoose, _nonIterableSpread as nonIterableSpread, _nonIterableRest as nonIterableRest, _skipFirstGeneratorNext as skipFirstGeneratorNext, _toPropertyKey as toPropertyKey, _initializerWarningHelper as initializerWarningHelper, _initializerDefineProperty as initializerDefineProperty, _applyDecoratedDescriptor as applyDecoratedDescriptor, _classPrivateFieldLooseKey as classPrivateFieldLooseKey, _classPrivateFieldLooseBase as classPrivateFieldLooseBase, _classPrivateFieldGet as classPrivateFieldGet, _classPrivateFieldSet as classPrivateFieldSet };\n\nfunction _typeof(obj) {\n  if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n    _typeof = function (obj) {\n      return typeof obj;\n    };\n  } else {\n    _typeof = function (obj) {\n      return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n    };\n  }\n\n  return _typeof(obj);\n}\n\nvar REACT_ELEMENT_TYPE;\n\nfunction _jsx(type, props, key, children) {\n  if (!REACT_ELEMENT_TYPE) {\n    REACT_ELEMENT_TYPE = typeof Symbol === \"function\" && Symbol.for && Symbol.for(\"react.element\") || 0xeac7;\n  }\n\n  var defaultProps = type && type.defaultProps;\n  var childrenLength = arguments.length - 3;\n\n  if (!props && childrenLength !== 0) {\n    props = {\n      children: void 0\n    };\n  }\n\n  if (props && defaultProps) {\n    for (var propName in defaultProps) {\n      if (props[propName] === void 0) {\n        props[propName] = defaultProps[propName];\n      }\n    }\n  } else if (!props) {\n    props = defaultProps || {};\n  }\n\n  if (childrenLength === 1) {\n    props.children = children;\n  } else if (childrenLength > 1) {\n    var childArray = new Array(childrenLength);\n\n    for (var i = 0; i < childrenLength; i++) {\n      childArray[i] = arguments[i + 3];\n    }\n\n    props.children = childArray;\n  }\n\n  return {\n    $$typeof: REACT_ELEMENT_TYPE,\n    type: type,\n    key: key === undefined ? null : '' + key,\n    ref: null,\n    props: props,\n    _owner: null\n  };\n}\n\nfunction _asyncIterator(iterable) {\n  var method;\n\n  if (typeof Symbol === \"function\") {\n    if (Symbol.asyncIterator) {\n      method = iterable[Symbol.asyncIterator];\n      if (method != null) return method.call(iterable);\n    }\n\n    if (Symbol.iterator) {\n      method = iterable[Symbol.iterator];\n      if (method != null) return method.call(iterable);\n    }\n  }\n\n  throw new TypeError(\"Object is not async iterable\");\n}\n\nfunction _AwaitValue(value) {\n  this.wrapped = value;\n}\n\nfunction _AsyncGenerator(gen) {\n  var front, back;\n\n  function send(key, arg) {\n    return new Promise(function (resolve, reject) {\n      var request = {\n        key: key,\n        arg: arg,\n        resolve: resolve,\n        reject: reject,\n        next: null\n      };\n\n      if (back) {\n        back = back.next = request;\n      } else {\n        front = back = request;\n        resume(key, arg);\n      }\n    });\n  }\n\n  function resume(key, arg) {\n    try {\n      var result = gen[key](arg);\n      var value = result.value;\n      var wrappedAwait = value instanceof _AwaitValue;\n      Promise.resolve(wrappedAwait ? value.wrapped : value).then(function (arg) {\n        if (wrappedAwait) {\n          resume(\"next\", arg);\n          return;\n        }\n\n        settle(result.done ? \"return\" : \"normal\", arg);\n      }, function (err) {\n        resume(\"throw\", err);\n      });\n    } catch (err) {\n      settle(\"throw\", err);\n    }\n  }\n\n  function settle(type, value) {\n    switch (type) {\n      case \"return\":\n        front.resolve({\n          value: value,\n          done: true\n        });\n        break;\n\n      case \"throw\":\n        front.reject(value);\n        break;\n\n      default:\n        front.resolve({\n          value: value,\n          done: false\n        });\n        break;\n    }\n\n    front = front.next;\n\n    if (front) {\n      resume(front.key, front.arg);\n    } else {\n      back = null;\n    }\n  }\n\n  this._invoke = send;\n\n  if (typeof gen.return !== \"function\") {\n    this.return = undefined;\n  }\n}\n\nif (typeof Symbol === \"function\" && Symbol.asyncIterator) {\n  _AsyncGenerator.prototype[Symbol.asyncIterator] = function () {\n    return this;\n  };\n}\n\n_AsyncGenerator.prototype.next = function (arg) {\n  return this._invoke(\"next\", arg);\n};\n\n_AsyncGenerator.prototype.throw = function (arg) {\n  return this._invoke(\"throw\", arg);\n};\n\n_AsyncGenerator.prototype.return = function (arg) {\n  return this._invoke(\"return\", arg);\n};\n\nfunction _wrapAsyncGenerator(fn) {\n  return function () {\n    return new _AsyncGenerator(fn.apply(this, arguments));\n  };\n}\n\nfunction _awaitAsyncGenerator(value) {\n  return new _AwaitValue(value);\n}\n\nfunction _asyncGeneratorDelegate(inner, awaitWrap) {\n  var iter = {},\n      waiting = false;\n\n  function pump(key, value) {\n    waiting = true;\n    value = new Promise(function (resolve) {\n      resolve(inner[key](value));\n    });\n    return {\n      done: false,\n      value: awaitWrap(value)\n    };\n  }\n\n  ;\n\n  if (typeof Symbol === \"function\" && Symbol.iterator) {\n    iter[Symbol.iterator] = function () {\n      return this;\n    };\n  }\n\n  iter.next = function (value) {\n    if (waiting) {\n      waiting = false;\n      return value;\n    }\n\n    return pump(\"next\", value);\n  };\n\n  if (typeof inner.throw === \"function\") {\n    iter.throw = function (value) {\n      if (waiting) {\n        waiting = false;\n        throw value;\n      }\n\n      return pump(\"throw\", value);\n    };\n  }\n\n  if (typeof inner.return === \"function\") {\n    iter.return = function (value) {\n      return pump(\"return\", value);\n    };\n  }\n\n  return iter;\n}\n\nfunction _asyncToGenerator(fn) {\n  return function () {\n    var self = this,\n        args = arguments;\n    return new Promise(function (resolve, reject) {\n      var gen = fn.apply(self, args);\n\n      function step(key, arg) {\n        try {\n          var info = gen[key](arg);\n          var value = info.value;\n        } catch (error) {\n          reject(error);\n          return;\n        }\n\n        if (info.done) {\n          resolve(value);\n        } else {\n          Promise.resolve(value).then(_next, _throw);\n        }\n      }\n\n      function _next(value) {\n        step(\"next\", value);\n      }\n\n      function _throw(err) {\n        step(\"throw\", err);\n      }\n\n      _next();\n    });\n  };\n}\n\nfunction _classCallCheck(instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n}\n\nfunction _defineProperties(target, props) {\n  for (var i = 0; i < props.length; i++) {\n    var descriptor = props[i];\n    descriptor.enumerable = descriptor.enumerable || false;\n    descriptor.configurable = true;\n    if (\"value\" in descriptor) descriptor.writable = true;\n    Object.defineProperty(target, descriptor.key, descriptor);\n  }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n  if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n  if (staticProps) _defineProperties(Constructor, staticProps);\n  return Constructor;\n}\n\nfunction _defineEnumerableProperties(obj, descs) {\n  for (var key in descs) {\n    var desc = descs[key];\n    desc.configurable = desc.enumerable = true;\n    if (\"value\" in desc) desc.writable = true;\n    Object.defineProperty(obj, key, desc);\n  }\n\n  if (Object.getOwnPropertySymbols) {\n    var objectSymbols = Object.getOwnPropertySymbols(descs);\n\n    for (var i = 0; i < objectSymbols.length; i++) {\n      var sym = objectSymbols[i];\n      var desc = descs[sym];\n      desc.configurable = desc.enumerable = true;\n      if (\"value\" in desc) desc.writable = true;\n      Object.defineProperty(obj, sym, desc);\n    }\n  }\n\n  return obj;\n}\n\nfunction _defaults(obj, defaults) {\n  var keys = Object.getOwnPropertyNames(defaults);\n\n  for (var i = 0; i < keys.length; i++) {\n    var key = keys[i];\n    var value = Object.getOwnPropertyDescriptor(defaults, key);\n\n    if (value && value.configurable && obj[key] === undefined) {\n      Object.defineProperty(obj, key, value);\n    }\n  }\n\n  return obj;\n}\n\nfunction _defineProperty(obj, key, value) {\n  if (key in obj) {\n    Object.defineProperty(obj, key, {\n      value: value,\n      enumerable: true,\n      configurable: true,\n      writable: true\n    });\n  } else {\n    obj[key] = value;\n  }\n\n  return obj;\n}\n\nfunction _extends() {\n  _extends = Object.assign || function (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n\n      for (var key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          target[key] = source[key];\n        }\n      }\n    }\n\n    return target;\n  };\n\n  return _extends.apply(this, arguments);\n}\n\nfunction _objectSpread(target) {\n  for (var i = 1; i < arguments.length; i++) {\n    var source = arguments[i] != null ? arguments[i] : {};\n    var ownKeys = Object.keys(source);\n\n    if (typeof Object.getOwnPropertySymbols === 'function') {\n      ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) {\n        return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n      }));\n    }\n\n    ownKeys.forEach(function (key) {\n      _defineProperty(target, key, source[key]);\n    });\n  }\n\n  return target;\n}\n\nfunction _inherits(subClass, superClass) {\n  if (typeof superClass !== \"function\" && superClass !== null) {\n    throw new TypeError(\"Super expression must either be null or a function\");\n  }\n\n  subClass.prototype = Object.create(superClass && superClass.prototype, {\n    constructor: {\n      value: subClass,\n      writable: true,\n      configurable: true\n    }\n  });\n  if (superClass) _setPrototypeOf(subClass, superClass);\n}\n\nfunction _inheritsLoose(subClass, superClass) {\n  subClass.prototype = Object.create(superClass.prototype);\n  subClass.prototype.constructor = subClass;\n  subClass.__proto__ = superClass;\n}\n\nfunction _getPrototypeOf(o) {\n  _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n    return o.__proto__ || Object.getPrototypeOf(o);\n  };\n  return _getPrototypeOf(o);\n}\n\nfunction _setPrototypeOf(o, p) {\n  _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n    o.__proto__ = p;\n    return o;\n  };\n\n  return _setPrototypeOf(o, p);\n}\n\nfunction isNativeReflectConstruct() {\n  if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n  if (Reflect.construct.sham) return false;\n  if (typeof Proxy === \"function\") return true;\n\n  try {\n    Date.prototype.toString.call(Reflect.construct(Date, [], function () {}));\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\nfunction _construct(Parent, args, Class) {\n  if (isNativeReflectConstruct()) {\n    _construct = Reflect.construct;\n  } else {\n    _construct = function _construct(Parent, args, Class) {\n      var a = [null];\n      a.push.apply(a, args);\n      var Constructor = Function.bind.apply(Parent, a);\n      var instance = new Constructor();\n      if (Class) _setPrototypeOf(instance, Class.prototype);\n      return instance;\n    };\n  }\n\n  return _construct.apply(null, arguments);\n}\n\nfunction _wrapNativeSuper(Class) {\n  var _cache = typeof Map === \"function\" ? new Map() : undefined;\n\n  _wrapNativeSuper = function _wrapNativeSuper(Class) {\n    if (Class === null) return null;\n\n    if (typeof Class !== \"function\") {\n      throw new TypeError(\"Super expression must either be null or a function\");\n    }\n\n    if (typeof _cache !== \"undefined\") {\n      if (_cache.has(Class)) return _cache.get(Class);\n\n      _cache.set(Class, Wrapper);\n    }\n\n    function Wrapper() {\n      return _construct(Class, arguments, _getPrototypeOf(this).constructor);\n    }\n\n    Wrapper.prototype = Object.create(Class.prototype, {\n      constructor: {\n        value: Wrapper,\n        enumerable: false,\n        writable: true,\n        configurable: true\n      }\n    });\n    return _setPrototypeOf(Wrapper, Class);\n  };\n\n  return _wrapNativeSuper(Class);\n}\n\nfunction _instanceof(left, right) {\n  if (right != null && typeof Symbol !== \"undefined\" && right[Symbol.hasInstance]) {\n    return right[Symbol.hasInstance](left);\n  } else {\n    return left instanceof right;\n  }\n}\n\nfunction _interopRequireDefault(obj) {\n  return obj && obj.__esModule ? obj : {\n    default: obj\n  };\n}\n\nfunction _interopRequireWildcard(obj) {\n  if (obj && obj.__esModule) {\n    return obj;\n  } else {\n    var newObj = {};\n\n    if (obj != null) {\n      for (var key in obj) {\n        if (Object.prototype.hasOwnProperty.call(obj, key)) {\n          var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {};\n\n          if (desc.get || desc.set) {\n            Object.defineProperty(newObj, key, desc);\n          } else {\n            newObj[key] = obj[key];\n          }\n        }\n      }\n    }\n\n    newObj.default = obj;\n    return newObj;\n  }\n}\n\nfunction _newArrowCheck(innerThis, boundThis) {\n  if (innerThis !== boundThis) {\n    throw new TypeError(\"Cannot instantiate an arrow function\");\n  }\n}\n\nfunction _objectDestructuringEmpty(obj) {\n  if (obj == null) throw new TypeError(\"Cannot destructure undefined\");\n}\n\nfunction _objectWithoutProperties(source, excluded) {\n  if (source == null) return {};\n  var target = {};\n  var sourceKeys = Object.keys(source);\n  var key, i;\n\n  for (i = 0; i < sourceKeys.length; i++) {\n    key = sourceKeys[i];\n    if (excluded.indexOf(key) >= 0) continue;\n    target[key] = source[key];\n  }\n\n  if (Object.getOwnPropertySymbols) {\n    var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n    for (i = 0; i < sourceSymbolKeys.length; i++) {\n      key = sourceSymbolKeys[i];\n      if (excluded.indexOf(key) >= 0) continue;\n      if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n      target[key] = source[key];\n    }\n  }\n\n  return target;\n}\n\nfunction _assertThisInitialized(self) {\n  if (self === void 0) {\n    throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n  }\n\n  return self;\n}\n\nfunction _possibleConstructorReturn(self, call) {\n  if (call && (typeof call === \"object\" || typeof call === \"function\")) {\n    return call;\n  }\n\n  return _assertThisInitialized(self);\n}\n\nfunction _superPropBase(object, property) {\n  while (!Object.prototype.hasOwnProperty.call(object, property)) {\n    object = _getPrototypeOf(object);\n    if (object === null) break;\n  }\n\n  return object;\n}\n\nfunction _get(target, property, receiver) {\n  if (typeof Reflect !== \"undefined\" && Reflect.get) {\n    _get = Reflect.get;\n  } else {\n    _get = function _get(target, property, receiver) {\n      var base = _superPropBase(target, property);\n\n      if (!base) return;\n      var desc = Object.getOwnPropertyDescriptor(base, property);\n\n      if (desc.get) {\n        return desc.get.call(receiver);\n      }\n\n      return desc.value;\n    };\n  }\n\n  return _get(target, property, receiver || target);\n}\n\nfunction set(target, property, value, receiver) {\n  if (typeof Reflect !== \"undefined\" && Reflect.set) {\n    set = Reflect.set;\n  } else {\n    set = function set(target, property, value, receiver) {\n      var base = _superPropBase(target, property);\n\n      var desc;\n\n      if (base) {\n        desc = Object.getOwnPropertyDescriptor(base, property);\n\n        if (desc.set) {\n          desc.set.call(receiver, value);\n          return true;\n        } else if (!desc.writable) {\n          return false;\n        }\n      }\n\n      desc = Object.getOwnPropertyDescriptor(receiver, property);\n\n      if (desc) {\n        if (!desc.writable) {\n          return false;\n        }\n\n        desc.value = value;\n        Object.defineProperty(receiver, property, desc);\n      } else {\n        _defineProperty(receiver, property, value);\n      }\n\n      return true;\n    };\n  }\n\n  return set(target, property, value, receiver);\n}\n\nfunction _set(target, property, value, receiver, isStrict) {\n  var s = set(target, property, value, receiver || target);\n\n  if (!s && isStrict) {\n    throw new Error('failed to set property');\n  }\n\n  return value;\n}\n\nfunction _taggedTemplateLiteral(strings, raw) {\n  if (!raw) {\n    raw = strings.slice(0);\n  }\n\n  return Object.freeze(Object.defineProperties(strings, {\n    raw: {\n      value: Object.freeze(raw)\n    }\n  }));\n}\n\nfunction _taggedTemplateLiteralLoose(strings, raw) {\n  if (!raw) {\n    raw = strings.slice(0);\n  }\n\n  strings.raw = raw;\n  return strings;\n}\n\nfunction _temporalRef(val, name) {\n  if (val === _temporalUndefined) {\n    throw new ReferenceError(name + \" is not defined - temporal dead zone\");\n  } else {\n    return val;\n  }\n}\n\nfunction _readOnlyError(name) {\n  throw new Error(\"\\\"\" + name + \"\\\" is read-only\");\n}\n\nfunction _classNameTDZError(name) {\n  throw new Error(\"Class \\\"\" + name + \"\\\" cannot be referenced in computed property keys.\");\n}\n\nvar _temporalUndefined = {};\n\nfunction _slicedToArray(arr, i) {\n  return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest();\n}\n\nfunction _slicedToArrayLoose(arr, i) {\n  return _arrayWithHoles(arr) || _iterableToArrayLimitLoose(arr, i) || _nonIterableRest();\n}\n\nfunction _toArray(arr) {\n  return _arrayWithHoles(arr) || _iterableToArray(arr) || _nonIterableRest();\n}\n\nfunction _toConsumableArray(arr) {\n  return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread();\n}\n\nfunction _arrayWithoutHoles(arr) {\n  if (Array.isArray(arr)) {\n    for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];\n\n    return arr2;\n  }\n}\n\nfunction _arrayWithHoles(arr) {\n  if (Array.isArray(arr)) return arr;\n}\n\nfunction _iterableToArray(iter) {\n  if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter);\n}\n\nfunction _iterableToArrayLimit(arr, i) {\n  var _arr = [];\n  var _n = true;\n  var _d = false;\n  var _e = undefined;\n\n  try {\n    for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n      _arr.push(_s.value);\n\n      if (i && _arr.length === i) break;\n    }\n  } catch (err) {\n    _d = true;\n    _e = err;\n  } finally {\n    try {\n      if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n    } finally {\n      if (_d) throw _e;\n    }\n  }\n\n  return _arr;\n}\n\nfunction _iterableToArrayLimitLoose(arr, i) {\n  var _arr = [];\n\n  for (var _iterator = arr[Symbol.iterator](), _step; !(_step = _iterator.next()).done;) {\n    _arr.push(_step.value);\n\n    if (i && _arr.length === i) break;\n  }\n\n  return _arr;\n}\n\nfunction _nonIterableSpread() {\n  throw new TypeError(\"Invalid attempt to spread non-iterable instance\");\n}\n\nfunction _nonIterableRest() {\n  throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n}\n\nfunction _skipFirstGeneratorNext(fn) {\n  return function () {\n    var it = fn.apply(this, arguments);\n    it.next();\n    return it;\n  };\n}\n\nfunction _toPropertyKey(key) {\n  if (typeof key === \"symbol\") {\n    return key;\n  } else {\n    return String(key);\n  }\n}\n\nfunction _initializerWarningHelper(descriptor, context) {\n  throw new Error('Decorating class property failed. Please ensure that ' + 'proposal-class-properties is enabled and set to use loose mode. ' + 'To use proposal-class-properties in spec mode with decorators, wait for ' + 'the next major version of decorators in stage 2.');\n}\n\nfunction _initializerDefineProperty(target, property, descriptor, context) {\n  if (!descriptor) return;\n  Object.defineProperty(target, property, {\n    enumerable: descriptor.enumerable,\n    configurable: descriptor.configurable,\n    writable: descriptor.writable,\n    value: descriptor.initializer ? descriptor.initializer.call(context) : void 0\n  });\n}\n\nfunction _applyDecoratedDescriptor(target, property, decorators, descriptor, context) {\n  var desc = {};\n  Object['ke' + 'ys'](descriptor).forEach(function (key) {\n    desc[key] = descriptor[key];\n  });\n  desc.enumerable = !!desc.enumerable;\n  desc.configurable = !!desc.configurable;\n\n  if ('value' in desc || desc.initializer) {\n    desc.writable = true;\n  }\n\n  desc = decorators.slice().reverse().reduce(function (desc, decorator) {\n    return decorator(target, property, desc) || desc;\n  }, desc);\n\n  if (context && desc.initializer !== void 0) {\n    desc.value = desc.initializer ? desc.initializer.call(context) : void 0;\n    desc.initializer = undefined;\n  }\n\n  if (desc.initializer === void 0) {\n    Object['define' + 'Property'](target, property, desc);\n    desc = null;\n  }\n\n  return desc;\n}\n\nvar id = 0;\n\nfunction _classPrivateFieldLooseKey(name) {\n  return \"__private_\" + id++ + \"_\" + name;\n}\n\nfunction _classPrivateFieldLooseBase(receiver, privateKey) {\n  if (!Object.prototype.hasOwnProperty.call(receiver, privateKey)) {\n    throw new TypeError(\"attempted to use private field on non-instance\");\n  }\n\n  return receiver;\n}\n\nfunction _classPrivateFieldGet(receiver, privateMap) {\n  if (!privateMap.has(receiver)) {\n    throw new TypeError(\"attempted to get private field on non-instance\");\n  }\n\n  return privateMap.get(receiver);\n}\n\nfunction _classPrivateFieldSet(receiver, privateMap, value) {\n  if (!privateMap.has(receiver)) {\n    throw new TypeError(\"attempted to set private field on non-instance\");\n  }\n\n  privateMap.set(receiver, value);\n  return value;\n}","/* WhitestormJS Framework v2.2.0-alpha.0 */\nfunction createCommonjsModule(fn, module) {\n\treturn module = { exports: {} }, fn(module, module.exports), module.exports;\n}\n\nvar runtime = createCommonjsModule(function (module) {\n/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n!(function(global) {\n\n  var Op = Object.prototype;\n  var hasOwn = Op.hasOwnProperty;\n  var undefined; // More compressible than void 0.\n  var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n  var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n  var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n  var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n  var inModule = 'object' === \"object\";\n  var runtime = global.regeneratorRuntime;\n  if (runtime) {\n    if (inModule) {\n      // If regeneratorRuntime is defined globally and we're in a module,\n      // make the exports object identical to regeneratorRuntime.\n      module.exports = runtime;\n    }\n    // Don't bother evaluating the rest of this file if the runtime was\n    // already defined globally.\n    return;\n  }\n\n  // Define the runtime globally (as expected by generated code) as either\n  // module.exports (if we're in a module) or a new, empty object.\n  runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n  function wrap(innerFn, outerFn, self, tryLocsList) {\n    // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n    var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n    var generator = Object.create(protoGenerator.prototype);\n    var context = new Context(tryLocsList || []);\n\n    // The ._invoke method unifies the implementations of the .next,\n    // .throw, and .return methods.\n    generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n    return generator;\n  }\n  runtime.wrap = wrap;\n\n  // Try/catch helper to minimize deoptimizations. Returns a completion\n  // record like context.tryEntries[i].completion. This interface could\n  // have been (and was previously) designed to take a closure to be\n  // invoked without arguments, but in all the cases we care about we\n  // already have an existing method we want to call, so there's no need\n  // to create a new function object. We can even get away with assuming\n  // the method takes exactly one argument, since that happens to be true\n  // in every case, so we don't have to touch the arguments object. The\n  // only additional allocation required is the completion record, which\n  // has a stable shape and so hopefully should be cheap to allocate.\n  function tryCatch(fn, obj, arg) {\n    try {\n      return { type: \"normal\", arg: fn.call(obj, arg) };\n    } catch (err) {\n      return { type: \"throw\", arg: err };\n    }\n  }\n\n  var GenStateSuspendedStart = \"suspendedStart\";\n  var GenStateSuspendedYield = \"suspendedYield\";\n  var GenStateExecuting = \"executing\";\n  var GenStateCompleted = \"completed\";\n\n  // Returning this object from the innerFn has the same effect as\n  // breaking out of the dispatch switch statement.\n  var ContinueSentinel = {};\n\n  // Dummy constructor functions that we use as the .constructor and\n  // .constructor.prototype properties for functions that return Generator\n  // objects. For full spec compliance, you may wish to configure your\n  // minifier not to mangle the names of these two functions.\n  function Generator() {}\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n\n  // This is a polyfill for %IteratorPrototype% for environments that\n  // don't natively support it.\n  var IteratorPrototype = {};\n  IteratorPrototype[iteratorSymbol] = function () {\n    return this;\n  };\n\n  var getProto = Object.getPrototypeOf;\n  var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n  if (NativeIteratorPrototype &&\n      NativeIteratorPrototype !== Op &&\n      hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n    // This environment has a native %IteratorPrototype%; use it instead\n    // of the polyfill.\n    IteratorPrototype = NativeIteratorPrototype;\n  }\n\n  var Gp = GeneratorFunctionPrototype.prototype =\n    Generator.prototype = Object.create(IteratorPrototype);\n  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n  GeneratorFunctionPrototype[toStringTagSymbol] =\n    GeneratorFunction.displayName = \"GeneratorFunction\";\n\n  // Helper for defining the .next, .throw, and .return methods of the\n  // Iterator interface in terms of a single ._invoke method.\n  function defineIteratorMethods(prototype) {\n    [\"next\", \"throw\", \"return\"].forEach(function(method) {\n      prototype[method] = function(arg) {\n        return this._invoke(method, arg);\n      };\n    });\n  }\n\n  runtime.isGeneratorFunction = function(genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor\n      ? ctor === GeneratorFunction ||\n        // For the native GeneratorFunction constructor, the best we can\n        // do is to check its .name property.\n        (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n      : false;\n  };\n\n  runtime.mark = function(genFun) {\n    if (Object.setPrototypeOf) {\n      Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n    } else {\n      genFun.__proto__ = GeneratorFunctionPrototype;\n      if (!(toStringTagSymbol in genFun)) {\n        genFun[toStringTagSymbol] = \"GeneratorFunction\";\n      }\n    }\n    genFun.prototype = Object.create(Gp);\n    return genFun;\n  };\n\n  // Within the body of any async function, `await x` is transformed to\n  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n  // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n  // meant to be awaited.\n  runtime.awrap = function(arg) {\n    return { __await: arg };\n  };\n\n  function AsyncIterator(generator) {\n    function invoke(method, arg, resolve, reject) {\n      var record = tryCatch(generator[method], generator, arg);\n      if (record.type === \"throw\") {\n        reject(record.arg);\n      } else {\n        var result = record.arg;\n        var value = result.value;\n        if (value &&\n            typeof value === \"object\" &&\n            hasOwn.call(value, \"__await\")) {\n          return Promise.resolve(value.__await).then(function(value) {\n            invoke(\"next\", value, resolve, reject);\n          }, function(err) {\n            invoke(\"throw\", err, resolve, reject);\n          });\n        }\n\n        return Promise.resolve(value).then(function(unwrapped) {\n          // When a yielded Promise is resolved, its final value becomes\n          // the .value of the Promise<{value,done}> result for the\n          // current iteration. If the Promise is rejected, however, the\n          // result for this iteration will be rejected with the same\n          // reason. Note that rejections of yielded Promises are not\n          // thrown back into the generator function, as is the case\n          // when an awaited Promise is rejected. This difference in\n          // behavior between yield and await is important, because it\n          // allows the consumer to decide what to do with the yielded\n          // rejection (swallow it and continue, manually .throw it back\n          // into the generator, abandon iteration, whatever). With\n          // await, by contrast, there is no opportunity to examine the\n          // rejection reason outside the generator function, so the\n          // only option is to throw it from the await expression, and\n          // let the generator function handle the exception.\n          result.value = unwrapped;\n          resolve(result);\n        }, reject);\n      }\n    }\n\n    var previousPromise;\n\n    function enqueue(method, arg) {\n      function callInvokeWithMethodAndArg() {\n        return new Promise(function(resolve, reject) {\n          invoke(method, arg, resolve, reject);\n        });\n      }\n\n      return previousPromise =\n        // If enqueue has been called before, then we want to wait until\n        // all previous Promises have been resolved before calling invoke,\n        // so that results are always delivered in the correct order. If\n        // enqueue has not been called before, then it is important to\n        // call invoke immediately, without waiting on a callback to fire,\n        // so that the async generator function has the opportunity to do\n        // any necessary setup in a predictable way. This predictability\n        // is why the Promise constructor synchronously invokes its\n        // executor callback, and why async functions synchronously\n        // execute code before the first await. Since we implement simple\n        // async functions in terms of async generators, it is especially\n        // important to get this right, even though it requires care.\n        previousPromise ? previousPromise.then(\n          callInvokeWithMethodAndArg,\n          // Avoid propagating failures to Promises returned by later\n          // invocations of the iterator.\n          callInvokeWithMethodAndArg\n        ) : callInvokeWithMethodAndArg();\n    }\n\n    // Define the unified helper method that is used to implement .next,\n    // .throw, and .return (see defineIteratorMethods).\n    this._invoke = enqueue;\n  }\n\n  defineIteratorMethods(AsyncIterator.prototype);\n  AsyncIterator.prototype[asyncIteratorSymbol] = function () {\n    return this;\n  };\n  runtime.AsyncIterator = AsyncIterator;\n\n  // Note that simple async functions are implemented on top of\n  // AsyncIterator objects; they just return a Promise for the value of\n  // the final result produced by the iterator.\n  runtime.async = function(innerFn, outerFn, self, tryLocsList) {\n    var iter = new AsyncIterator(\n      wrap(innerFn, outerFn, self, tryLocsList)\n    );\n\n    return runtime.isGeneratorFunction(outerFn)\n      ? iter // If outerFn is a generator, return the full iterator.\n      : iter.next().then(function(result) {\n          return result.done ? result.value : iter.next();\n        });\n  };\n\n  function makeInvokeMethod(innerFn, self, context) {\n    var state = GenStateSuspendedStart;\n\n    return function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        if (method === \"throw\") {\n          throw arg;\n        }\n\n        // Be forgiving, per 25.3.3.3.3 of the spec:\n        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n        return doneResult();\n      }\n\n      context.method = method;\n      context.arg = arg;\n\n      while (true) {\n        var delegate = context.delegate;\n        if (delegate) {\n          var delegateResult = maybeInvokeDelegate(delegate, context);\n          if (delegateResult) {\n            if (delegateResult === ContinueSentinel) continue;\n            return delegateResult;\n          }\n        }\n\n        if (context.method === \"next\") {\n          // Setting context._sent for legacy support of Babel's\n          // function.sent implementation.\n          context.sent = context._sent = context.arg;\n\n        } else if (context.method === \"throw\") {\n          if (state === GenStateSuspendedStart) {\n            state = GenStateCompleted;\n            throw context.arg;\n          }\n\n          context.dispatchException(context.arg);\n\n        } else if (context.method === \"return\") {\n          context.abrupt(\"return\", context.arg);\n        }\n\n        state = GenStateExecuting;\n\n        var record = tryCatch(innerFn, self, context);\n        if (record.type === \"normal\") {\n          // If an exception is thrown from innerFn, we leave state ===\n          // GenStateExecuting and loop back for another invocation.\n          state = context.done\n            ? GenStateCompleted\n            : GenStateSuspendedYield;\n\n          if (record.arg === ContinueSentinel) {\n            continue;\n          }\n\n          return {\n            value: record.arg,\n            done: context.done\n          };\n\n        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n          // Dispatch the exception by looping back around to the\n          // context.dispatchException(context.arg) call above.\n          context.method = \"throw\";\n          context.arg = record.arg;\n        }\n      }\n    };\n  }\n\n  // Call delegate.iterator[context.method](context.arg) and handle the\n  // result, either by returning a { value, done } result from the\n  // delegate iterator, or by modifying context.method and context.arg,\n  // setting context.delegate to null, and returning the ContinueSentinel.\n  function maybeInvokeDelegate(delegate, context) {\n    var method = delegate.iterator[context.method];\n    if (method === undefined) {\n      // A .throw or .return when the delegate iterator has no .throw\n      // method always terminates the yield* loop.\n      context.delegate = null;\n\n      if (context.method === \"throw\") {\n        if (delegate.iterator.return) {\n          // If the delegate iterator has a return method, give it a\n          // chance to clean up.\n          context.method = \"return\";\n          context.arg = undefined;\n          maybeInvokeDelegate(delegate, context);\n\n          if (context.method === \"throw\") {\n            // If maybeInvokeDelegate(context) changed context.method from\n            // \"return\" to \"throw\", let that override the TypeError below.\n            return ContinueSentinel;\n          }\n        }\n\n        context.method = \"throw\";\n        context.arg = new TypeError(\n          \"The iterator does not provide a 'throw' method\");\n      }\n\n      return ContinueSentinel;\n    }\n\n    var record = tryCatch(method, delegate.iterator, context.arg);\n\n    if (record.type === \"throw\") {\n      context.method = \"throw\";\n      context.arg = record.arg;\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    var info = record.arg;\n\n    if (! info) {\n      context.method = \"throw\";\n      context.arg = new TypeError(\"iterator result is not an object\");\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    if (info.done) {\n      // Assign the result of the finished delegate to the temporary\n      // variable specified by delegate.resultName (see delegateYield).\n      context[delegate.resultName] = info.value;\n\n      // Resume execution at the desired location (see delegateYield).\n      context.next = delegate.nextLoc;\n\n      // If context.method was \"throw\" but the delegate handled the\n      // exception, let the outer generator proceed normally. If\n      // context.method was \"next\", forget context.arg since it has been\n      // \"consumed\" by the delegate iterator. If context.method was\n      // \"return\", allow the original .return call to continue in the\n      // outer generator.\n      if (context.method !== \"return\") {\n        context.method = \"next\";\n        context.arg = undefined;\n      }\n\n    } else {\n      // Re-yield the result returned by the delegate method.\n      return info;\n    }\n\n    // The delegate iterator is finished, so forget it and continue with\n    // the outer generator.\n    context.delegate = null;\n    return ContinueSentinel;\n  }\n\n  // Define Generator.prototype.{next,throw,return} in terms of the\n  // unified ._invoke helper method.\n  defineIteratorMethods(Gp);\n\n  Gp[toStringTagSymbol] = \"Generator\";\n\n  // A Generator should always return itself as the iterator object when the\n  // @@iterator function is called on it. Some browsers' implementations of the\n  // iterator prototype chain incorrectly implement this, causing the Generator\n  // object to not be returned from this call. This ensures that doesn't happen.\n  // See https://github.com/facebook/regenerator/issues/274 for more details.\n  Gp[iteratorSymbol] = function() {\n    return this;\n  };\n\n  Gp.toString = function() {\n    return \"[object Generator]\";\n  };\n\n  function pushTryEntry(locs) {\n    var entry = { tryLoc: locs[0] };\n\n    if (1 in locs) {\n      entry.catchLoc = locs[1];\n    }\n\n    if (2 in locs) {\n      entry.finallyLoc = locs[2];\n      entry.afterLoc = locs[3];\n    }\n\n    this.tryEntries.push(entry);\n  }\n\n  function resetTryEntry(entry) {\n    var record = entry.completion || {};\n    record.type = \"normal\";\n    delete record.arg;\n    entry.completion = record;\n  }\n\n  function Context(tryLocsList) {\n    // The root entry object (effectively a try statement without a catch\n    // or a finally block) gives us a place to store values thrown from\n    // locations where there is no enclosing try statement.\n    this.tryEntries = [{ tryLoc: \"root\" }];\n    tryLocsList.forEach(pushTryEntry, this);\n    this.reset(true);\n  }\n\n  runtime.keys = function(object) {\n    var keys = [];\n    for (var key in object) {\n      keys.push(key);\n    }\n    keys.reverse();\n\n    // Rather than returning an object with a next method, we keep\n    // things simple and return the next function itself.\n    return function next() {\n      while (keys.length) {\n        var key = keys.pop();\n        if (key in object) {\n          next.value = key;\n          next.done = false;\n          return next;\n        }\n      }\n\n      // To avoid creating an additional object, we just hang the .value\n      // and .done properties off the next function object itself. This\n      // also ensures that the minifier will not anonymize the function.\n      next.done = true;\n      return next;\n    };\n  };\n\n  function values(iterable) {\n    if (iterable) {\n      var iteratorMethod = iterable[iteratorSymbol];\n      if (iteratorMethod) {\n        return iteratorMethod.call(iterable);\n      }\n\n      if (typeof iterable.next === \"function\") {\n        return iterable;\n      }\n\n      if (!isNaN(iterable.length)) {\n        var i = -1, next = function next() {\n          while (++i < iterable.length) {\n            if (hasOwn.call(iterable, i)) {\n              next.value = iterable[i];\n              next.done = false;\n              return next;\n            }\n          }\n\n          next.value = undefined;\n          next.done = true;\n\n          return next;\n        };\n\n        return next.next = next;\n      }\n    }\n\n    // Return an iterator with no values.\n    return { next: doneResult };\n  }\n  runtime.values = values;\n\n  function doneResult() {\n    return { value: undefined, done: true };\n  }\n\n  Context.prototype = {\n    constructor: Context,\n\n    reset: function(skipTempReset) {\n      this.prev = 0;\n      this.next = 0;\n      // Resetting context._sent for legacy support of Babel's\n      // function.sent implementation.\n      this.sent = this._sent = undefined;\n      this.done = false;\n      this.delegate = null;\n\n      this.method = \"next\";\n      this.arg = undefined;\n\n      this.tryEntries.forEach(resetTryEntry);\n\n      if (!skipTempReset) {\n        for (var name in this) {\n          // Not sure about the optimal order of these conditions:\n          if (name.charAt(0) === \"t\" &&\n              hasOwn.call(this, name) &&\n              !isNaN(+name.slice(1))) {\n            this[name] = undefined;\n          }\n        }\n      }\n    },\n\n    stop: function() {\n      this.done = true;\n\n      var rootEntry = this.tryEntries[0];\n      var rootRecord = rootEntry.completion;\n      if (rootRecord.type === \"throw\") {\n        throw rootRecord.arg;\n      }\n\n      return this.rval;\n    },\n\n    dispatchException: function(exception) {\n      if (this.done) {\n        throw exception;\n      }\n\n      var context = this;\n      function handle(loc, caught) {\n        record.type = \"throw\";\n        record.arg = exception;\n        context.next = loc;\n\n        if (caught) {\n          // If the dispatched exception was caught by a catch block,\n          // then let that catch block handle the exception normally.\n          context.method = \"next\";\n          context.arg = undefined;\n        }\n\n        return !! caught;\n      }\n\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        var record = entry.completion;\n\n        if (entry.tryLoc === \"root\") {\n          // Exception thrown outside of any try block that could handle\n          // it, so set the completion value of the entire function to\n          // throw the exception.\n          return handle(\"end\");\n        }\n\n        if (entry.tryLoc <= this.prev) {\n          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n          if (hasCatch && hasFinally) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            } else if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function(type, arg) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc <= this.prev &&\n            hasOwn.call(entry, \"finallyLoc\") &&\n            this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry &&\n          (type === \"break\" ||\n           type === \"continue\") &&\n          finallyEntry.tryLoc <= arg &&\n          arg <= finallyEntry.finallyLoc) {\n        // Ignore the finally entry if control is not jumping to a\n        // location outside the try/catch block.\n        finallyEntry = null;\n      }\n\n      var record = finallyEntry ? finallyEntry.completion : {};\n      record.type = type;\n      record.arg = arg;\n\n      if (finallyEntry) {\n        this.method = \"next\";\n        this.next = finallyEntry.finallyLoc;\n        return ContinueSentinel;\n      }\n\n      return this.complete(record);\n    },\n\n    complete: function(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" ||\n          record.type === \"continue\") {\n        this.next = record.arg;\n      } else if (record.type === \"return\") {\n        this.rval = this.arg = record.arg;\n        this.method = \"return\";\n        this.next = \"end\";\n      } else if (record.type === \"normal\" && afterLoc) {\n        this.next = afterLoc;\n      }\n\n      return ContinueSentinel;\n    },\n\n    finish: function(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          this.complete(entry.completion, entry.afterLoc);\n          resetTryEntry(entry);\n          return ContinueSentinel;\n        }\n      }\n    },\n\n    \"catch\": function(tryLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc === tryLoc) {\n          var record = entry.completion;\n          if (record.type === \"throw\") {\n            var thrown = record.arg;\n            resetTryEntry(entry);\n          }\n          return thrown;\n        }\n      }\n\n      // The context.catch method must only be called with a location\n      // argument that corresponds to a known catch block.\n      throw new Error(\"illegal catch attempt\");\n    },\n\n    delegateYield: function(iterable, resultName, nextLoc) {\n      this.delegate = {\n        iterator: values(iterable),\n        resultName: resultName,\n        nextLoc: nextLoc\n      };\n\n      if (this.method === \"next\") {\n        // Deliberately forget the last sent value so that we don't\n        // accidentally pass it on to the delegate.\n        this.arg = undefined;\n      }\n\n      return ContinueSentinel;\n    }\n  };\n})(\n  // In sloppy mode, unbound `this` refers to the global object, fallback to\n  // Function constructor if we're in global strict mode. That is sadly a form\n  // of indirect eval which violates Content Security Policy.\n  (function() { return this })() || Function(\"return this\")()\n);\n});\n\n/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n// This method of obtaining a reference to the global object needs to be\n// kept identical to the way it is obtained in runtime.js\nvar g = (function() { return this })() || Function(\"return this\")();\n\n// Use `getOwnPropertyNames` because not all browsers support calling\n// `hasOwnProperty` on the global `self` object in a worker. See #183.\nvar hadRuntime = g.regeneratorRuntime &&\n  Object.getOwnPropertyNames(g).indexOf(\"regeneratorRuntime\") >= 0;\n\n// Save the old regeneratorRuntime in case it needs to be restored later.\nvar oldRuntime = hadRuntime && g.regeneratorRuntime;\n\n// Force reevalutation of runtime.js.\ng.regeneratorRuntime = undefined;\n\nvar runtimeModule = runtime;\n\nif (hadRuntime) {\n  // Restore the original runtime.\n  g.regeneratorRuntime = oldRuntime;\n} else {\n  // Remove the global property added by runtime.js.\n  try {\n    delete g.regeneratorRuntime;\n  } catch(e) {\n    g.regeneratorRuntime = undefined;\n  }\n}\n\nvar regenerator = runtimeModule;\n\n// 7.1.4 ToInteger\nvar ceil = Math.ceil;\nvar floor = Math.floor;\nvar _toInteger = function (it) {\n  return isNaN(it = +it) ? 0 : (it > 0 ? floor : ceil)(it);\n};\n\n// 7.2.1 RequireObjectCoercible(argument)\nvar _defined = function (it) {\n  if (it == undefined) throw TypeError(\"Can't call method on  \" + it);\n  return it;\n};\n\n// true  -> String#at\n// false -> String#codePointAt\nvar _stringAt = function (TO_STRING) {\n  return function (that, pos) {\n    var s = String(_defined(that));\n    var i = _toInteger(pos);\n    var l = s.length;\n    var a, b;\n    if (i < 0 || i >= l) return TO_STRING ? '' : undefined;\n    a = s.charCodeAt(i);\n    return a < 0xd800 || a > 0xdbff || i + 1 === l || (b = s.charCodeAt(i + 1)) < 0xdc00 || b > 0xdfff\n      ? TO_STRING ? s.charAt(i) : a\n      : TO_STRING ? s.slice(i, i + 2) : (a - 0xd800 << 10) + (b - 0xdc00) + 0x10000;\n  };\n};\n\nvar _library = true;\n\nvar _global = createCommonjsModule(function (module) {\n// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar global = module.exports = typeof window != 'undefined' && window.Math == Math\n  ? window : typeof self != 'undefined' && self.Math == Math ? self\n  // eslint-disable-next-line no-new-func\n  : Function('return this')();\nif (typeof __g == 'number') __g = global; // eslint-disable-line no-undef\n});\n\nvar _core = createCommonjsModule(function (module) {\nvar core = module.exports = { version: '2.5.6' };\nif (typeof __e == 'number') __e = core; // eslint-disable-line no-undef\n});\nvar _core_1 = _core.version;\n\nvar _aFunction = function (it) {\n  if (typeof it != 'function') throw TypeError(it + ' is not a function!');\n  return it;\n};\n\n// optional / simple context binding\n\nvar _ctx = function (fn, that, length) {\n  _aFunction(fn);\n  if (that === undefined) return fn;\n  switch (length) {\n    case 1: return function (a) {\n      return fn.call(that, a);\n    };\n    case 2: return function (a, b) {\n      return fn.call(that, a, b);\n    };\n    case 3: return function (a, b, c) {\n      return fn.call(that, a, b, c);\n    };\n  }\n  return function (/* ...args */) {\n    return fn.apply(that, arguments);\n  };\n};\n\nvar _isObject = function (it) {\n  return typeof it === 'object' ? it !== null : typeof it === 'function';\n};\n\nvar _anObject = function (it) {\n  if (!_isObject(it)) throw TypeError(it + ' is not an object!');\n  return it;\n};\n\nvar _fails = function (exec) {\n  try {\n    return !!exec();\n  } catch (e) {\n    return true;\n  }\n};\n\n// Thank's IE8 for his funny defineProperty\nvar _descriptors = !_fails(function () {\n  return Object.defineProperty({}, 'a', { get: function () { return 7; } }).a != 7;\n});\n\nvar document$1 = _global.document;\n// typeof document.createElement is 'object' in old IE\nvar is = _isObject(document$1) && _isObject(document$1.createElement);\nvar _domCreate = function (it) {\n  return is ? document$1.createElement(it) : {};\n};\n\nvar _ie8DomDefine = !_descriptors && !_fails(function () {\n  return Object.defineProperty(_domCreate('div'), 'a', { get: function () { return 7; } }).a != 7;\n});\n\n// 7.1.1 ToPrimitive(input [, PreferredType])\n\n// instead of the ES6 spec version, we didn't implement @@toPrimitive case\n// and the second argument - flag - preferred type is a string\nvar _toPrimitive = function (it, S) {\n  if (!_isObject(it)) return it;\n  var fn, val;\n  if (S && typeof (fn = it.toString) == 'function' && !_isObject(val = fn.call(it))) return val;\n  if (typeof (fn = it.valueOf) == 'function' && !_isObject(val = fn.call(it))) return val;\n  if (!S && typeof (fn = it.toString) == 'function' && !_isObject(val = fn.call(it))) return val;\n  throw TypeError(\"Can't convert object to primitive value\");\n};\n\nvar dP = Object.defineProperty;\n\nvar f = _descriptors ? Object.defineProperty : function defineProperty(O, P, Attributes) {\n  _anObject(O);\n  P = _toPrimitive(P, true);\n  _anObject(Attributes);\n  if (_ie8DomDefine) try {\n    return dP(O, P, Attributes);\n  } catch (e) { /* empty */ }\n  if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported!');\n  if ('value' in Attributes) O[P] = Attributes.value;\n  return O;\n};\n\nvar _objectDp = {\n\tf: f\n};\n\nvar _propertyDesc = function (bitmap, value) {\n  return {\n    enumerable: !(bitmap & 1),\n    configurable: !(bitmap & 2),\n    writable: !(bitmap & 4),\n    value: value\n  };\n};\n\nvar _hide = _descriptors ? function (object, key, value) {\n  return _objectDp.f(object, key, _propertyDesc(1, value));\n} : function (object, key, value) {\n  object[key] = value;\n  return object;\n};\n\nvar hasOwnProperty = {}.hasOwnProperty;\nvar _has = function (it, key) {\n  return hasOwnProperty.call(it, key);\n};\n\nvar PROTOTYPE = 'prototype';\n\nvar $export = function (type, name, source) {\n  var IS_FORCED = type & $export.F;\n  var IS_GLOBAL = type & $export.G;\n  var IS_STATIC = type & $export.S;\n  var IS_PROTO = type & $export.P;\n  var IS_BIND = type & $export.B;\n  var IS_WRAP = type & $export.W;\n  var exports = IS_GLOBAL ? _core : _core[name] || (_core[name] = {});\n  var expProto = exports[PROTOTYPE];\n  var target = IS_GLOBAL ? _global : IS_STATIC ? _global[name] : (_global[name] || {})[PROTOTYPE];\n  var key, own, out;\n  if (IS_GLOBAL) source = name;\n  for (key in source) {\n    // contains in native\n    own = !IS_FORCED && target && target[key] !== undefined;\n    if (own && _has(exports, key)) continue;\n    // export native or passed\n    out = own ? target[key] : source[key];\n    // prevent global pollution for namespaces\n    exports[key] = IS_GLOBAL && typeof target[key] != 'function' ? source[key]\n    // bind timers to global for call from export context\n    : IS_BIND && own ? _ctx(out, _global)\n    // wrap global constructors for prevent change them in library\n    : IS_WRAP && target[key] == out ? (function (C) {\n      var F = function (a, b, c) {\n        if (this instanceof C) {\n          switch (arguments.length) {\n            case 0: return new C();\n            case 1: return new C(a);\n            case 2: return new C(a, b);\n          } return new C(a, b, c);\n        } return C.apply(this, arguments);\n      };\n      F[PROTOTYPE] = C[PROTOTYPE];\n      return F;\n    // make static versions for prototype methods\n    })(out) : IS_PROTO && typeof out == 'function' ? _ctx(Function.call, out) : out;\n    // export proto methods to core.%CONSTRUCTOR%.methods.%NAME%\n    if (IS_PROTO) {\n      (exports.virtual || (exports.virtual = {}))[key] = out;\n      // export proto methods to core.%CONSTRUCTOR%.prototype.%NAME%\n      if (type & $export.R && expProto && !expProto[key]) _hide(expProto, key, out);\n    }\n  }\n};\n// type bitmap\n$export.F = 1;   // forced\n$export.G = 2;   // global\n$export.S = 4;   // static\n$export.P = 8;   // proto\n$export.B = 16;  // bind\n$export.W = 32;  // wrap\n$export.U = 64;  // safe\n$export.R = 128; // real proto method for `library`\nvar _export = $export;\n\nvar _redefine = _hide;\n\nvar _iterators = {};\n\nvar toString = {}.toString;\n\nvar _cof = function (it) {\n  return toString.call(it).slice(8, -1);\n};\n\n// fallback for non-array-like ES3 and non-enumerable old V8 strings\n\n// eslint-disable-next-line no-prototype-builtins\nvar _iobject = Object('z').propertyIsEnumerable(0) ? Object : function (it) {\n  return _cof(it) == 'String' ? it.split('') : Object(it);\n};\n\n// to indexed object, toObject with fallback for non-array-like ES3 strings\n\n\nvar _toIobject = function (it) {\n  return _iobject(_defined(it));\n};\n\n// 7.1.15 ToLength\n\nvar min = Math.min;\nvar _toLength = function (it) {\n  return it > 0 ? min(_toInteger(it), 0x1fffffffffffff) : 0; // pow(2, 53) - 1 == 9007199254740991\n};\n\nvar max = Math.max;\nvar min$1 = Math.min;\nvar _toAbsoluteIndex = function (index, length) {\n  index = _toInteger(index);\n  return index < 0 ? max(index + length, 0) : min$1(index, length);\n};\n\n// false -> Array#indexOf\n// true  -> Array#includes\n\n\n\nvar _arrayIncludes = function (IS_INCLUDES) {\n  return function ($this, el, fromIndex) {\n    var O = _toIobject($this);\n    var length = _toLength(O.length);\n    var index = _toAbsoluteIndex(fromIndex, length);\n    var value;\n    // Array#includes uses SameValueZero equality algorithm\n    // eslint-disable-next-line no-self-compare\n    if (IS_INCLUDES && el != el) while (length > index) {\n      value = O[index++];\n      // eslint-disable-next-line no-self-compare\n      if (value != value) return true;\n    // Array#indexOf ignores holes, Array#includes - not\n    } else for (;length > index; index++) if (IS_INCLUDES || index in O) {\n      if (O[index] === el) return IS_INCLUDES || index || 0;\n    } return !IS_INCLUDES && -1;\n  };\n};\n\nvar _shared = createCommonjsModule(function (module) {\nvar SHARED = '__core-js_shared__';\nvar store = _global[SHARED] || (_global[SHARED] = {});\n\n(module.exports = function (key, value) {\n  return store[key] || (store[key] = value !== undefined ? value : {});\n})('versions', []).push({\n  version: _core.version,\n  mode: _library ? 'pure' : 'global',\n  copyright: '© 2018 Denis Pushkarev (zloirock.ru)'\n});\n});\n\nvar id = 0;\nvar px = Math.random();\nvar _uid = function (key) {\n  return 'Symbol('.concat(key === undefined ? '' : key, ')_', (++id + px).toString(36));\n};\n\nvar shared = _shared('keys');\n\nvar _sharedKey = function (key) {\n  return shared[key] || (shared[key] = _uid(key));\n};\n\nvar arrayIndexOf = _arrayIncludes(false);\nvar IE_PROTO = _sharedKey('IE_PROTO');\n\nvar _objectKeysInternal = function (object, names) {\n  var O = _toIobject(object);\n  var i = 0;\n  var result = [];\n  var key;\n  for (key in O) if (key != IE_PROTO) _has(O, key) && result.push(key);\n  // Don't enum bug & hidden keys\n  while (names.length > i) if (_has(O, key = names[i++])) {\n    ~arrayIndexOf(result, key) || result.push(key);\n  }\n  return result;\n};\n\n// IE 8- don't enum bug keys\nvar _enumBugKeys = (\n  'constructor,hasOwnProperty,isPrototypeOf,propertyIsEnumerable,toLocaleString,toString,valueOf'\n).split(',');\n\n// 19.1.2.14 / 15.2.3.14 Object.keys(O)\n\n\n\nvar _objectKeys = Object.keys || function keys(O) {\n  return _objectKeysInternal(O, _enumBugKeys);\n};\n\nvar _objectDps = _descriptors ? Object.defineProperties : function defineProperties(O, Properties) {\n  _anObject(O);\n  var keys = _objectKeys(Properties);\n  var length = keys.length;\n  var i = 0;\n  var P;\n  while (length > i) _objectDp.f(O, P = keys[i++], Properties[P]);\n  return O;\n};\n\nvar document$2 = _global.document;\nvar _html = document$2 && document$2.documentElement;\n\n// 19.1.2.2 / 15.2.3.5 Object.create(O [, Properties])\n\n\n\nvar IE_PROTO$1 = _sharedKey('IE_PROTO');\nvar Empty = function () { /* empty */ };\nvar PROTOTYPE$1 = 'prototype';\n\n// Create object with fake `null` prototype: use iframe Object with cleared prototype\nvar createDict = function () {\n  // Thrash, waste and sodomy: IE GC bug\n  var iframe = _domCreate('iframe');\n  var i = _enumBugKeys.length;\n  var lt = '<';\n  var gt = '>';\n  var iframeDocument;\n  iframe.style.display = 'none';\n  _html.appendChild(iframe);\n  iframe.src = 'javascript:'; // eslint-disable-line no-script-url\n  // createDict = iframe.contentWindow.Object;\n  // html.removeChild(iframe);\n  iframeDocument = iframe.contentWindow.document;\n  iframeDocument.open();\n  iframeDocument.write(lt + 'script' + gt + 'document.F=Object' + lt + '/script' + gt);\n  iframeDocument.close();\n  createDict = iframeDocument.F;\n  while (i--) delete createDict[PROTOTYPE$1][_enumBugKeys[i]];\n  return createDict();\n};\n\nvar _objectCreate = Object.create || function create(O, Properties) {\n  var result;\n  if (O !== null) {\n    Empty[PROTOTYPE$1] = _anObject(O);\n    result = new Empty();\n    Empty[PROTOTYPE$1] = null;\n    // add \"__proto__\" for Object.getPrototypeOf polyfill\n    result[IE_PROTO$1] = O;\n  } else result = createDict();\n  return Properties === undefined ? result : _objectDps(result, Properties);\n};\n\nvar _wks = createCommonjsModule(function (module) {\nvar store = _shared('wks');\n\nvar Symbol = _global.Symbol;\nvar USE_SYMBOL = typeof Symbol == 'function';\n\nvar $exports = module.exports = function (name) {\n  return store[name] || (store[name] =\n    USE_SYMBOL && Symbol[name] || (USE_SYMBOL ? Symbol : _uid)('Symbol.' + name));\n};\n\n$exports.store = store;\n});\n\nvar def = _objectDp.f;\n\nvar TAG = _wks('toStringTag');\n\nvar _setToStringTag = function (it, tag, stat) {\n  if (it && !_has(it = stat ? it : it.prototype, TAG)) def(it, TAG, { configurable: true, value: tag });\n};\n\nvar IteratorPrototype = {};\n\n// 25.1.2.1.1 %IteratorPrototype%[@@iterator]()\n_hide(IteratorPrototype, _wks('iterator'), function () { return this; });\n\nvar _iterCreate = function (Constructor, NAME, next) {\n  Constructor.prototype = _objectCreate(IteratorPrototype, { next: _propertyDesc(1, next) });\n  _setToStringTag(Constructor, NAME + ' Iterator');\n};\n\n// 7.1.13 ToObject(argument)\n\nvar _toObject = function (it) {\n  return Object(_defined(it));\n};\n\n// 19.1.2.9 / 15.2.3.2 Object.getPrototypeOf(O)\n\n\nvar IE_PROTO$2 = _sharedKey('IE_PROTO');\nvar ObjectProto = Object.prototype;\n\nvar _objectGpo = Object.getPrototypeOf || function (O) {\n  O = _toObject(O);\n  if (_has(O, IE_PROTO$2)) return O[IE_PROTO$2];\n  if (typeof O.constructor == 'function' && O instanceof O.constructor) {\n    return O.constructor.prototype;\n  } return O instanceof Object ? ObjectProto : null;\n};\n\nvar ITERATOR = _wks('iterator');\nvar BUGGY = !([].keys && 'next' in [].keys()); // Safari has buggy iterators w/o `next`\nvar FF_ITERATOR = '@@iterator';\nvar KEYS = 'keys';\nvar VALUES = 'values';\n\nvar returnThis = function () { return this; };\n\nvar _iterDefine = function (Base, NAME, Constructor, next, DEFAULT, IS_SET, FORCED) {\n  _iterCreate(Constructor, NAME, next);\n  var getMethod = function (kind) {\n    if (!BUGGY && kind in proto) return proto[kind];\n    switch (kind) {\n      case KEYS: return function keys() { return new Constructor(this, kind); };\n      case VALUES: return function values() { return new Constructor(this, kind); };\n    } return function entries() { return new Constructor(this, kind); };\n  };\n  var TAG = NAME + ' Iterator';\n  var DEF_VALUES = DEFAULT == VALUES;\n  var VALUES_BUG = false;\n  var proto = Base.prototype;\n  var $native = proto[ITERATOR] || proto[FF_ITERATOR] || DEFAULT && proto[DEFAULT];\n  var $default = $native || getMethod(DEFAULT);\n  var $entries = DEFAULT ? !DEF_VALUES ? $default : getMethod('entries') : undefined;\n  var $anyNative = NAME == 'Array' ? proto.entries || $native : $native;\n  var methods, key, IteratorPrototype;\n  // Fix native\n  if ($anyNative) {\n    IteratorPrototype = _objectGpo($anyNative.call(new Base()));\n    if (IteratorPrototype !== Object.prototype && IteratorPrototype.next) {\n      // Set @@toStringTag to native iterators\n      _setToStringTag(IteratorPrototype, TAG, true);\n      // fix for some old engines\n      if (!_library && typeof IteratorPrototype[ITERATOR] != 'function') _hide(IteratorPrototype, ITERATOR, returnThis);\n    }\n  }\n  // fix Array#{values, @@iterator}.name in V8 / FF\n  if (DEF_VALUES && $native && $native.name !== VALUES) {\n    VALUES_BUG = true;\n    $default = function values() { return $native.call(this); };\n  }\n  // Define iterator\n  if ((!_library || FORCED) && (BUGGY || VALUES_BUG || !proto[ITERATOR])) {\n    _hide(proto, ITERATOR, $default);\n  }\n  // Plug for library\n  _iterators[NAME] = $default;\n  _iterators[TAG] = returnThis;\n  if (DEFAULT) {\n    methods = {\n      values: DEF_VALUES ? $default : getMethod(VALUES),\n      keys: IS_SET ? $default : getMethod(KEYS),\n      entries: $entries\n    };\n    if (FORCED) for (key in methods) {\n      if (!(key in proto)) _redefine(proto, key, methods[key]);\n    } else _export(_export.P + _export.F * (BUGGY || VALUES_BUG), NAME, methods);\n  }\n  return methods;\n};\n\nvar $at = _stringAt(true);\n\n// 21.1.3.27 String.prototype[@@iterator]()\n_iterDefine(String, 'String', function (iterated) {\n  this._t = String(iterated); // target\n  this._i = 0;                // next index\n// 21.1.5.2.1 %StringIteratorPrototype%.next()\n}, function () {\n  var O = this._t;\n  var index = this._i;\n  var point;\n  if (index >= O.length) return { value: undefined, done: true };\n  point = $at(O, index);\n  this._i += point.length;\n  return { value: point, done: false };\n});\n\nvar _iterStep = function (done, value) {\n  return { value: value, done: !!done };\n};\n\n// 22.1.3.4 Array.prototype.entries()\n// 22.1.3.13 Array.prototype.keys()\n// 22.1.3.29 Array.prototype.values()\n// 22.1.3.30 Array.prototype[@@iterator]()\nvar es6_array_iterator = _iterDefine(Array, 'Array', function (iterated, kind) {\n  this._t = _toIobject(iterated); // target\n  this._i = 0;                   // next index\n  this._k = kind;                // kind\n// 22.1.5.2.1 %ArrayIteratorPrototype%.next()\n}, function () {\n  var O = this._t;\n  var kind = this._k;\n  var index = this._i++;\n  if (!O || index >= O.length) {\n    this._t = undefined;\n    return _iterStep(1);\n  }\n  if (kind == 'keys') return _iterStep(0, index);\n  if (kind == 'values') return _iterStep(0, O[index]);\n  return _iterStep(0, [index, O[index]]);\n}, 'values');\n\n// argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)\n_iterators.Arguments = _iterators.Array;\n\nvar TO_STRING_TAG = _wks('toStringTag');\n\nvar DOMIterables = ('CSSRuleList,CSSStyleDeclaration,CSSValueList,ClientRectList,DOMRectList,DOMStringList,' +\n  'DOMTokenList,DataTransferItemList,FileList,HTMLAllCollection,HTMLCollection,HTMLFormElement,HTMLSelectElement,' +\n  'MediaList,MimeTypeArray,NamedNodeMap,NodeList,PaintRequestList,Plugin,PluginArray,SVGLengthList,SVGNumberList,' +\n  'SVGPathSegList,SVGPointList,SVGStringList,SVGTransformList,SourceBufferList,StyleSheetList,TextTrackCueList,' +\n  'TextTrackList,TouchList').split(',');\n\nfor (var i = 0; i < DOMIterables.length; i++) {\n  var NAME = DOMIterables[i];\n  var Collection = _global[NAME];\n  var proto = Collection && Collection.prototype;\n  if (proto && !proto[TO_STRING_TAG]) _hide(proto, TO_STRING_TAG, NAME);\n  _iterators[NAME] = _iterators.Array;\n}\n\n// getting tag from 19.1.3.6 Object.prototype.toString()\n\nvar TAG$1 = _wks('toStringTag');\n// ES3 wrong here\nvar ARG = _cof(function () { return arguments; }()) == 'Arguments';\n\n// fallback for IE11 Script Access Denied error\nvar tryGet = function (it, key) {\n  try {\n    return it[key];\n  } catch (e) { /* empty */ }\n};\n\nvar _classof = function (it) {\n  var O, T, B;\n  return it === undefined ? 'Undefined' : it === null ? 'Null'\n    // @@toStringTag case\n    : typeof (T = tryGet(O = Object(it), TAG$1)) == 'string' ? T\n    // builtinTag case\n    : ARG ? _cof(O)\n    // ES3 arguments fallback\n    : (B = _cof(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : B;\n};\n\nvar _anInstance = function (it, Constructor, name, forbiddenField) {\n  if (!(it instanceof Constructor) || (forbiddenField !== undefined && forbiddenField in it)) {\n    throw TypeError(name + ': incorrect invocation!');\n  } return it;\n};\n\n// call something on iterator step with safe closing on error\n\nvar _iterCall = function (iterator, fn, value, entries) {\n  try {\n    return entries ? fn(_anObject(value)[0], value[1]) : fn(value);\n  // 7.4.6 IteratorClose(iterator, completion)\n  } catch (e) {\n    var ret = iterator['return'];\n    if (ret !== undefined) _anObject(ret.call(iterator));\n    throw e;\n  }\n};\n\n// check on default Array iterator\n\nvar ITERATOR$1 = _wks('iterator');\nvar ArrayProto = Array.prototype;\n\nvar _isArrayIter = function (it) {\n  return it !== undefined && (_iterators.Array === it || ArrayProto[ITERATOR$1] === it);\n};\n\nvar ITERATOR$2 = _wks('iterator');\n\nvar core_getIteratorMethod = _core.getIteratorMethod = function (it) {\n  if (it != undefined) return it[ITERATOR$2]\n    || it['@@iterator']\n    || _iterators[_classof(it)];\n};\n\nvar _forOf = createCommonjsModule(function (module) {\nvar BREAK = {};\nvar RETURN = {};\nvar exports = module.exports = function (iterable, entries, fn, that, ITERATOR) {\n  var iterFn = ITERATOR ? function () { return iterable; } : core_getIteratorMethod(iterable);\n  var f = _ctx(fn, that, entries ? 2 : 1);\n  var index = 0;\n  var length, step, iterator, result;\n  if (typeof iterFn != 'function') throw TypeError(iterable + ' is not iterable!');\n  // fast case for arrays with default iterator\n  if (_isArrayIter(iterFn)) for (length = _toLength(iterable.length); length > index; index++) {\n    result = entries ? f(_anObject(step = iterable[index])[0], step[1]) : f(iterable[index]);\n    if (result === BREAK || result === RETURN) return result;\n  } else for (iterator = iterFn.call(iterable); !(step = iterator.next()).done;) {\n    result = _iterCall(iterator, f, step.value, entries);\n    if (result === BREAK || result === RETURN) return result;\n  }\n};\nexports.BREAK = BREAK;\nexports.RETURN = RETURN;\n});\n\n// 7.3.20 SpeciesConstructor(O, defaultConstructor)\n\n\nvar SPECIES = _wks('species');\nvar _speciesConstructor = function (O, D) {\n  var C = _anObject(O).constructor;\n  var S;\n  return C === undefined || (S = _anObject(C)[SPECIES]) == undefined ? D : _aFunction(S);\n};\n\n// fast apply, http://jsperf.lnkit.com/fast-apply/5\nvar _invoke = function (fn, args, that) {\n  var un = that === undefined;\n  switch (args.length) {\n    case 0: return un ? fn()\n                      : fn.call(that);\n    case 1: return un ? fn(args[0])\n                      : fn.call(that, args[0]);\n    case 2: return un ? fn(args[0], args[1])\n                      : fn.call(that, args[0], args[1]);\n    case 3: return un ? fn(args[0], args[1], args[2])\n                      : fn.call(that, args[0], args[1], args[2]);\n    case 4: return un ? fn(args[0], args[1], args[2], args[3])\n                      : fn.call(that, args[0], args[1], args[2], args[3]);\n  } return fn.apply(that, args);\n};\n\nvar process = _global.process;\nvar setTask = _global.setImmediate;\nvar clearTask = _global.clearImmediate;\nvar MessageChannel = _global.MessageChannel;\nvar Dispatch = _global.Dispatch;\nvar counter = 0;\nvar queue = {};\nvar ONREADYSTATECHANGE = 'onreadystatechange';\nvar defer, channel, port;\nvar run = function () {\n  var id = +this;\n  // eslint-disable-next-line no-prototype-builtins\n  if (queue.hasOwnProperty(id)) {\n    var fn = queue[id];\n    delete queue[id];\n    fn();\n  }\n};\nvar listener = function (event) {\n  run.call(event.data);\n};\n// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\nif (!setTask || !clearTask) {\n  setTask = function setImmediate(fn) {\n    var args = [];\n    var i = 1;\n    while (arguments.length > i) args.push(arguments[i++]);\n    queue[++counter] = function () {\n      // eslint-disable-next-line no-new-func\n      _invoke(typeof fn == 'function' ? fn : Function(fn), args);\n    };\n    defer(counter);\n    return counter;\n  };\n  clearTask = function clearImmediate(id) {\n    delete queue[id];\n  };\n  // Node.js 0.8-\n  if (_cof(process) == 'process') {\n    defer = function (id) {\n      process.nextTick(_ctx(run, id, 1));\n    };\n  // Sphere (JS game engine) Dispatch API\n  } else if (Dispatch && Dispatch.now) {\n    defer = function (id) {\n      Dispatch.now(_ctx(run, id, 1));\n    };\n  // Browsers with MessageChannel, includes WebWorkers\n  } else if (MessageChannel) {\n    channel = new MessageChannel();\n    port = channel.port2;\n    channel.port1.onmessage = listener;\n    defer = _ctx(port.postMessage, port, 1);\n  // Browsers with postMessage, skip WebWorkers\n  // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n  } else if (_global.addEventListener && typeof postMessage == 'function' && !_global.importScripts) {\n    defer = function (id) {\n      _global.postMessage(id + '', '*');\n    };\n    _global.addEventListener('message', listener, false);\n  // IE8-\n  } else if (ONREADYSTATECHANGE in _domCreate('script')) {\n    defer = function (id) {\n      _html.appendChild(_domCreate('script'))[ONREADYSTATECHANGE] = function () {\n        _html.removeChild(this);\n        run.call(id);\n      };\n    };\n  // Rest old browsers\n  } else {\n    defer = function (id) {\n      setTimeout(_ctx(run, id, 1), 0);\n    };\n  }\n}\nvar _task = {\n  set: setTask,\n  clear: clearTask\n};\n\nvar macrotask = _task.set;\nvar Observer = _global.MutationObserver || _global.WebKitMutationObserver;\nvar process$1 = _global.process;\nvar Promise$1 = _global.Promise;\nvar isNode = _cof(process$1) == 'process';\n\nvar _microtask = function () {\n  var head, last, notify;\n\n  var flush = function () {\n    var parent, fn;\n    if (isNode && (parent = process$1.domain)) parent.exit();\n    while (head) {\n      fn = head.fn;\n      head = head.next;\n      try {\n        fn();\n      } catch (e) {\n        if (head) notify();\n        else last = undefined;\n        throw e;\n      }\n    } last = undefined;\n    if (parent) parent.enter();\n  };\n\n  // Node.js\n  if (isNode) {\n    notify = function () {\n      process$1.nextTick(flush);\n    };\n  // browsers with MutationObserver, except iOS Safari - https://github.com/zloirock/core-js/issues/339\n  } else if (Observer && !(_global.navigator && _global.navigator.standalone)) {\n    var toggle = true;\n    var node = document.createTextNode('');\n    new Observer(flush).observe(node, { characterData: true }); // eslint-disable-line no-new\n    notify = function () {\n      node.data = toggle = !toggle;\n    };\n  // environments with maybe non-completely correct, but existent Promise\n  } else if (Promise$1 && Promise$1.resolve) {\n    // Promise.resolve without an argument throws an error in LG WebOS 2\n    var promise = Promise$1.resolve(undefined);\n    notify = function () {\n      promise.then(flush);\n    };\n  // for other environments - macrotask based on:\n  // - setImmediate\n  // - MessageChannel\n  // - window.postMessag\n  // - onreadystatechange\n  // - setTimeout\n  } else {\n    notify = function () {\n      // strange IE + webpack dev server bug - use .call(global)\n      macrotask.call(_global, flush);\n    };\n  }\n\n  return function (fn) {\n    var task = { fn: fn, next: undefined };\n    if (last) last.next = task;\n    if (!head) {\n      head = task;\n      notify();\n    } last = task;\n  };\n};\n\n// 25.4.1.5 NewPromiseCapability(C)\n\n\nfunction PromiseCapability(C) {\n  var resolve, reject;\n  this.promise = new C(function ($$resolve, $$reject) {\n    if (resolve !== undefined || reject !== undefined) throw TypeError('Bad Promise constructor');\n    resolve = $$resolve;\n    reject = $$reject;\n  });\n  this.resolve = _aFunction(resolve);\n  this.reject = _aFunction(reject);\n}\n\nvar f$1 = function (C) {\n  return new PromiseCapability(C);\n};\n\nvar _newPromiseCapability = {\n\tf: f$1\n};\n\nvar _perform = function (exec) {\n  try {\n    return { e: false, v: exec() };\n  } catch (e) {\n    return { e: true, v: e };\n  }\n};\n\nvar navigator = _global.navigator;\n\nvar _userAgent = navigator && navigator.userAgent || '';\n\nvar _promiseResolve = function (C, x) {\n  _anObject(C);\n  if (_isObject(x) && x.constructor === C) return x;\n  var promiseCapability = _newPromiseCapability.f(C);\n  var resolve = promiseCapability.resolve;\n  resolve(x);\n  return promiseCapability.promise;\n};\n\nvar _redefineAll = function (target, src, safe) {\n  for (var key in src) {\n    if (safe && target[key]) target[key] = src[key];\n    else _hide(target, key, src[key]);\n  } return target;\n};\n\nvar SPECIES$1 = _wks('species');\n\nvar _setSpecies = function (KEY) {\n  var C = typeof _core[KEY] == 'function' ? _core[KEY] : _global[KEY];\n  if (_descriptors && C && !C[SPECIES$1]) _objectDp.f(C, SPECIES$1, {\n    configurable: true,\n    get: function () { return this; }\n  });\n};\n\nvar ITERATOR$3 = _wks('iterator');\nvar SAFE_CLOSING = false;\n\ntry {\n  var riter = [7][ITERATOR$3]();\n  riter['return'] = function () { SAFE_CLOSING = true; };\n} catch (e) { /* empty */ }\n\nvar _iterDetect = function (exec, skipClosing) {\n  if (!skipClosing && !SAFE_CLOSING) return false;\n  var safe = false;\n  try {\n    var arr = [7];\n    var iter = arr[ITERATOR$3]();\n    iter.next = function () { return { done: safe = true }; };\n    arr[ITERATOR$3] = function () { return iter; };\n    exec(arr);\n  } catch (e) { /* empty */ }\n  return safe;\n};\n\nvar task = _task.set;\nvar microtask = _microtask();\n\n\n\n\nvar PROMISE = 'Promise';\nvar TypeError$1 = _global.TypeError;\nvar process$2 = _global.process;\nvar versions = process$2 && process$2.versions;\nvar v8 = versions && versions.v8 || '';\nvar $Promise = _global[PROMISE];\nvar isNode$1 = _classof(process$2) == 'process';\nvar empty = function () { /* empty */ };\nvar Internal, newGenericPromiseCapability, OwnPromiseCapability, Wrapper;\nvar newPromiseCapability = newGenericPromiseCapability = _newPromiseCapability.f;\n\nvar USE_NATIVE = !!function () {\n  try {\n    // correct subclassing with @@species support\n    var promise = $Promise.resolve(1);\n    var FakePromise = (promise.constructor = {})[_wks('species')] = function (exec) {\n      exec(empty, empty);\n    };\n    // unhandled rejections tracking support, NodeJS Promise without it fails @@species test\n    return (isNode$1 || typeof PromiseRejectionEvent == 'function')\n      && promise.then(empty) instanceof FakePromise\n      // v8 6.6 (Node 10 and Chrome 66) have a bug with resolving custom thenables\n      // https://bugs.chromium.org/p/chromium/issues/detail?id=830565\n      // we can't detect it synchronously, so just check versions\n      && v8.indexOf('6.6') !== 0\n      && _userAgent.indexOf('Chrome/66') === -1;\n  } catch (e) { /* empty */ }\n}();\n\n// helpers\nvar isThenable = function (it) {\n  var then;\n  return _isObject(it) && typeof (then = it.then) == 'function' ? then : false;\n};\nvar notify = function (promise, isReject) {\n  if (promise._n) return;\n  promise._n = true;\n  var chain = promise._c;\n  microtask(function () {\n    var value = promise._v;\n    var ok = promise._s == 1;\n    var i = 0;\n    var run = function (reaction) {\n      var handler = ok ? reaction.ok : reaction.fail;\n      var resolve = reaction.resolve;\n      var reject = reaction.reject;\n      var domain = reaction.domain;\n      var result, then, exited;\n      try {\n        if (handler) {\n          if (!ok) {\n            if (promise._h == 2) onHandleUnhandled(promise);\n            promise._h = 1;\n          }\n          if (handler === true) result = value;\n          else {\n            if (domain) domain.enter();\n            result = handler(value); // may throw\n            if (domain) {\n              domain.exit();\n              exited = true;\n            }\n          }\n          if (result === reaction.promise) {\n            reject(TypeError$1('Promise-chain cycle'));\n          } else if (then = isThenable(result)) {\n            then.call(result, resolve, reject);\n          } else resolve(result);\n        } else reject(value);\n      } catch (e) {\n        if (domain && !exited) domain.exit();\n        reject(e);\n      }\n    };\n    while (chain.length > i) run(chain[i++]); // variable length - can't use forEach\n    promise._c = [];\n    promise._n = false;\n    if (isReject && !promise._h) onUnhandled(promise);\n  });\n};\nvar onUnhandled = function (promise) {\n  task.call(_global, function () {\n    var value = promise._v;\n    var unhandled = isUnhandled(promise);\n    var result, handler, console;\n    if (unhandled) {\n      result = _perform(function () {\n        if (isNode$1) {\n          process$2.emit('unhandledRejection', value, promise);\n        } else if (handler = _global.onunhandledrejection) {\n          handler({ promise: promise, reason: value });\n        } else if ((console = _global.console) && console.error) {\n          console.error('Unhandled promise rejection', value);\n        }\n      });\n      // Browsers should not trigger `rejectionHandled` event if it was handled here, NodeJS - should\n      promise._h = isNode$1 || isUnhandled(promise) ? 2 : 1;\n    } promise._a = undefined;\n    if (unhandled && result.e) throw result.v;\n  });\n};\nvar isUnhandled = function (promise) {\n  return promise._h !== 1 && (promise._a || promise._c).length === 0;\n};\nvar onHandleUnhandled = function (promise) {\n  task.call(_global, function () {\n    var handler;\n    if (isNode$1) {\n      process$2.emit('rejectionHandled', promise);\n    } else if (handler = _global.onrejectionhandled) {\n      handler({ promise: promise, reason: promise._v });\n    }\n  });\n};\nvar $reject = function (value) {\n  var promise = this;\n  if (promise._d) return;\n  promise._d = true;\n  promise = promise._w || promise; // unwrap\n  promise._v = value;\n  promise._s = 2;\n  if (!promise._a) promise._a = promise._c.slice();\n  notify(promise, true);\n};\nvar $resolve = function (value) {\n  var promise = this;\n  var then;\n  if (promise._d) return;\n  promise._d = true;\n  promise = promise._w || promise; // unwrap\n  try {\n    if (promise === value) throw TypeError$1(\"Promise can't be resolved itself\");\n    if (then = isThenable(value)) {\n      microtask(function () {\n        var wrapper = { _w: promise, _d: false }; // wrap\n        try {\n          then.call(value, _ctx($resolve, wrapper, 1), _ctx($reject, wrapper, 1));\n        } catch (e) {\n          $reject.call(wrapper, e);\n        }\n      });\n    } else {\n      promise._v = value;\n      promise._s = 1;\n      notify(promise, false);\n    }\n  } catch (e) {\n    $reject.call({ _w: promise, _d: false }, e); // wrap\n  }\n};\n\n// constructor polyfill\nif (!USE_NATIVE) {\n  // 25.4.3.1 Promise(executor)\n  $Promise = function Promise(executor) {\n    _anInstance(this, $Promise, PROMISE, '_h');\n    _aFunction(executor);\n    Internal.call(this);\n    try {\n      executor(_ctx($resolve, this, 1), _ctx($reject, this, 1));\n    } catch (err) {\n      $reject.call(this, err);\n    }\n  };\n  // eslint-disable-next-line no-unused-vars\n  Internal = function Promise(executor) {\n    this._c = [];             // <- awaiting reactions\n    this._a = undefined;      // <- checked in isUnhandled reactions\n    this._s = 0;              // <- state\n    this._d = false;          // <- done\n    this._v = undefined;      // <- value\n    this._h = 0;              // <- rejection state, 0 - default, 1 - handled, 2 - unhandled\n    this._n = false;          // <- notify\n  };\n  Internal.prototype = _redefineAll($Promise.prototype, {\n    // 25.4.5.3 Promise.prototype.then(onFulfilled, onRejected)\n    then: function then(onFulfilled, onRejected) {\n      var reaction = newPromiseCapability(_speciesConstructor(this, $Promise));\n      reaction.ok = typeof onFulfilled == 'function' ? onFulfilled : true;\n      reaction.fail = typeof onRejected == 'function' && onRejected;\n      reaction.domain = isNode$1 ? process$2.domain : undefined;\n      this._c.push(reaction);\n      if (this._a) this._a.push(reaction);\n      if (this._s) notify(this, false);\n      return reaction.promise;\n    },\n    // 25.4.5.1 Promise.prototype.catch(onRejected)\n    'catch': function (onRejected) {\n      return this.then(undefined, onRejected);\n    }\n  });\n  OwnPromiseCapability = function () {\n    var promise = new Internal();\n    this.promise = promise;\n    this.resolve = _ctx($resolve, promise, 1);\n    this.reject = _ctx($reject, promise, 1);\n  };\n  _newPromiseCapability.f = newPromiseCapability = function (C) {\n    return C === $Promise || C === Wrapper\n      ? new OwnPromiseCapability(C)\n      : newGenericPromiseCapability(C);\n  };\n}\n\n_export(_export.G + _export.W + _export.F * !USE_NATIVE, { Promise: $Promise });\n_setToStringTag($Promise, PROMISE);\n_setSpecies(PROMISE);\nWrapper = _core[PROMISE];\n\n// statics\n_export(_export.S + _export.F * !USE_NATIVE, PROMISE, {\n  // 25.4.4.5 Promise.reject(r)\n  reject: function reject(r) {\n    var capability = newPromiseCapability(this);\n    var $$reject = capability.reject;\n    $$reject(r);\n    return capability.promise;\n  }\n});\n_export(_export.S + _export.F * (_library || !USE_NATIVE), PROMISE, {\n  // 25.4.4.6 Promise.resolve(x)\n  resolve: function resolve(x) {\n    return _promiseResolve(_library && this === Wrapper ? $Promise : this, x);\n  }\n});\n_export(_export.S + _export.F * !(USE_NATIVE && _iterDetect(function (iter) {\n  $Promise.all(iter)['catch'](empty);\n})), PROMISE, {\n  // 25.4.4.1 Promise.all(iterable)\n  all: function all(iterable) {\n    var C = this;\n    var capability = newPromiseCapability(C);\n    var resolve = capability.resolve;\n    var reject = capability.reject;\n    var result = _perform(function () {\n      var values = [];\n      var index = 0;\n      var remaining = 1;\n      _forOf(iterable, false, function (promise) {\n        var $index = index++;\n        var alreadyCalled = false;\n        values.push(undefined);\n        remaining++;\n        C.resolve(promise).then(function (value) {\n          if (alreadyCalled) return;\n          alreadyCalled = true;\n          values[$index] = value;\n          --remaining || resolve(values);\n        }, reject);\n      });\n      --remaining || resolve(values);\n    });\n    if (result.e) reject(result.v);\n    return capability.promise;\n  },\n  // 25.4.4.4 Promise.race(iterable)\n  race: function race(iterable) {\n    var C = this;\n    var capability = newPromiseCapability(C);\n    var reject = capability.reject;\n    var result = _perform(function () {\n      _forOf(iterable, false, function (promise) {\n        C.resolve(promise).then(capability.resolve, reject);\n      });\n    });\n    if (result.e) reject(result.v);\n    return capability.promise;\n  }\n});\n\n_export(_export.P + _export.R, 'Promise', { 'finally': function (onFinally) {\n  var C = _speciesConstructor(this, _core.Promise || _global.Promise);\n  var isFunction = typeof onFinally == 'function';\n  return this.then(\n    isFunction ? function (x) {\n      return _promiseResolve(C, onFinally()).then(function () { return x; });\n    } : onFinally,\n    isFunction ? function (e) {\n      return _promiseResolve(C, onFinally()).then(function () { throw e; });\n    } : onFinally\n  );\n} });\n\n// https://github.com/tc39/proposal-promise-try\n\n\n\n\n_export(_export.S, 'Promise', { 'try': function (callbackfn) {\n  var promiseCapability = _newPromiseCapability.f(this);\n  var result = _perform(callbackfn);\n  (result.e ? promiseCapability.reject : promiseCapability.resolve)(result.v);\n  return promiseCapability.promise;\n} });\n\nvar promise = _core.Promise;\n\nvar promise$1 = promise;\n\nfunction _asyncToGenerator(fn) {\n  return function () {\n    var self = this,\n        args = arguments;\n    return new promise$1(function (resolve, reject) {\n      var gen = fn.apply(self, args);\n\n      function step(key, arg) {\n        try {\n          var info = gen[key](arg);\n          var value = info.value;\n        } catch (error) {\n          reject(error);\n          return;\n        }\n\n        if (info.done) {\n          resolve(value);\n        } else {\n          promise$1.resolve(value).then(_next, _throw);\n        }\n      }\n\n      function _next(value) {\n        step(\"next\", value);\n      }\n\n      function _throw(err) {\n        step(\"throw\", err);\n      }\n\n      _next();\n    });\n  };\n}\n\nvar asyncToGenerator = _asyncToGenerator;\n\nvar f$2 = {}.propertyIsEnumerable;\n\nvar _objectPie = {\n\tf: f$2\n};\n\nvar gOPD = Object.getOwnPropertyDescriptor;\n\nvar f$3 = _descriptors ? gOPD : function getOwnPropertyDescriptor(O, P) {\n  O = _toIobject(O);\n  P = _toPrimitive(P, true);\n  if (_ie8DomDefine) try {\n    return gOPD(O, P);\n  } catch (e) { /* empty */ }\n  if (_has(O, P)) return _propertyDesc(!_objectPie.f.call(O, P), O[P]);\n};\n\nvar _objectGopd = {\n\tf: f$3\n};\n\n// most Object methods by ES6 should accept primitives\n\n\n\nvar _objectSap = function (KEY, exec) {\n  var fn = (_core.Object || {})[KEY] || Object[KEY];\n  var exp = {};\n  exp[KEY] = exec(fn);\n  _export(_export.S + _export.F * _fails(function () { fn(1); }), 'Object', exp);\n};\n\n// 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\n\nvar $getOwnPropertyDescriptor = _objectGopd.f;\n\n_objectSap('getOwnPropertyDescriptor', function () {\n  return function getOwnPropertyDescriptor(it, key) {\n    return $getOwnPropertyDescriptor(_toIobject(it), key);\n  };\n});\n\nvar $Object = _core.Object;\nvar getOwnPropertyDescriptor = function getOwnPropertyDescriptor(it, key) {\n  return $Object.getOwnPropertyDescriptor(it, key);\n};\n\nvar getOwnPropertyDescriptor$1 = getOwnPropertyDescriptor;\n\nvar _meta = createCommonjsModule(function (module) {\nvar META = _uid('meta');\n\n\nvar setDesc = _objectDp.f;\nvar id = 0;\nvar isExtensible = Object.isExtensible || function () {\n  return true;\n};\nvar FREEZE = !_fails(function () {\n  return isExtensible(Object.preventExtensions({}));\n});\nvar setMeta = function (it) {\n  setDesc(it, META, { value: {\n    i: 'O' + ++id, // object ID\n    w: {}          // weak collections IDs\n  } });\n};\nvar fastKey = function (it, create) {\n  // return primitive with prefix\n  if (!_isObject(it)) return typeof it == 'symbol' ? it : (typeof it == 'string' ? 'S' : 'P') + it;\n  if (!_has(it, META)) {\n    // can't set metadata to uncaught frozen object\n    if (!isExtensible(it)) return 'F';\n    // not necessary to add metadata\n    if (!create) return 'E';\n    // add missing metadata\n    setMeta(it);\n  // return object ID\n  } return it[META].i;\n};\nvar getWeak = function (it, create) {\n  if (!_has(it, META)) {\n    // can't set metadata to uncaught frozen object\n    if (!isExtensible(it)) return true;\n    // not necessary to add metadata\n    if (!create) return false;\n    // add missing metadata\n    setMeta(it);\n  // return hash weak collections IDs\n  } return it[META].w;\n};\n// add metadata on freeze-family methods calling\nvar onFreeze = function (it) {\n  if (FREEZE && meta.NEED && isExtensible(it) && !_has(it, META)) setMeta(it);\n  return it;\n};\nvar meta = module.exports = {\n  KEY: META,\n  NEED: false,\n  fastKey: fastKey,\n  getWeak: getWeak,\n  onFreeze: onFreeze\n};\n});\nvar _meta_1 = _meta.KEY;\nvar _meta_2 = _meta.NEED;\nvar _meta_3 = _meta.fastKey;\nvar _meta_4 = _meta.getWeak;\nvar _meta_5 = _meta.onFreeze;\n\nvar f$4 = _wks;\n\nvar _wksExt = {\n\tf: f$4\n};\n\nvar defineProperty = _objectDp.f;\nvar _wksDefine = function (name) {\n  var $Symbol = _core.Symbol || (_core.Symbol = _library ? {} : _global.Symbol || {});\n  if (name.charAt(0) != '_' && !(name in $Symbol)) defineProperty($Symbol, name, { value: _wksExt.f(name) });\n};\n\nvar f$5 = Object.getOwnPropertySymbols;\n\nvar _objectGops = {\n\tf: f$5\n};\n\n// all enumerable object keys, includes symbols\n\n\n\nvar _enumKeys = function (it) {\n  var result = _objectKeys(it);\n  var getSymbols = _objectGops.f;\n  if (getSymbols) {\n    var symbols = getSymbols(it);\n    var isEnum = _objectPie.f;\n    var i = 0;\n    var key;\n    while (symbols.length > i) if (isEnum.call(it, key = symbols[i++])) result.push(key);\n  } return result;\n};\n\n// 7.2.2 IsArray(argument)\n\nvar _isArray = Array.isArray || function isArray(arg) {\n  return _cof(arg) == 'Array';\n};\n\n// 19.1.2.7 / 15.2.3.4 Object.getOwnPropertyNames(O)\n\nvar hiddenKeys = _enumBugKeys.concat('length', 'prototype');\n\nvar f$6 = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {\n  return _objectKeysInternal(O, hiddenKeys);\n};\n\nvar _objectGopn = {\n\tf: f$6\n};\n\n// fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window\n\nvar gOPN = _objectGopn.f;\nvar toString$1 = {}.toString;\n\nvar windowNames = typeof window == 'object' && window && Object.getOwnPropertyNames\n  ? Object.getOwnPropertyNames(window) : [];\n\nvar getWindowNames = function (it) {\n  try {\n    return gOPN(it);\n  } catch (e) {\n    return windowNames.slice();\n  }\n};\n\nvar f$7 = function getOwnPropertyNames(it) {\n  return windowNames && toString$1.call(it) == '[object Window]' ? getWindowNames(it) : gOPN(_toIobject(it));\n};\n\nvar _objectGopnExt = {\n\tf: f$7\n};\n\n// ECMAScript 6 symbols shim\n\n\n\n\n\nvar META = _meta.KEY;\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar gOPD$1 = _objectGopd.f;\nvar dP$1 = _objectDp.f;\nvar gOPN$1 = _objectGopnExt.f;\nvar $Symbol = _global.Symbol;\nvar $JSON = _global.JSON;\nvar _stringify = $JSON && $JSON.stringify;\nvar PROTOTYPE$2 = 'prototype';\nvar HIDDEN = _wks('_hidden');\nvar TO_PRIMITIVE = _wks('toPrimitive');\nvar isEnum = {}.propertyIsEnumerable;\nvar SymbolRegistry = _shared('symbol-registry');\nvar AllSymbols = _shared('symbols');\nvar OPSymbols = _shared('op-symbols');\nvar ObjectProto$1 = Object[PROTOTYPE$2];\nvar USE_NATIVE$1 = typeof $Symbol == 'function';\nvar QObject = _global.QObject;\n// Don't use setters in Qt Script, https://github.com/zloirock/core-js/issues/173\nvar setter = !QObject || !QObject[PROTOTYPE$2] || !QObject[PROTOTYPE$2].findChild;\n\n// fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687\nvar setSymbolDesc = _descriptors && _fails(function () {\n  return _objectCreate(dP$1({}, 'a', {\n    get: function () { return dP$1(this, 'a', { value: 7 }).a; }\n  })).a != 7;\n}) ? function (it, key, D) {\n  var protoDesc = gOPD$1(ObjectProto$1, key);\n  if (protoDesc) delete ObjectProto$1[key];\n  dP$1(it, key, D);\n  if (protoDesc && it !== ObjectProto$1) dP$1(ObjectProto$1, key, protoDesc);\n} : dP$1;\n\nvar wrap = function (tag) {\n  var sym = AllSymbols[tag] = _objectCreate($Symbol[PROTOTYPE$2]);\n  sym._k = tag;\n  return sym;\n};\n\nvar isSymbol = USE_NATIVE$1 && typeof $Symbol.iterator == 'symbol' ? function (it) {\n  return typeof it == 'symbol';\n} : function (it) {\n  return it instanceof $Symbol;\n};\n\nvar $defineProperty = function defineProperty(it, key, D) {\n  if (it === ObjectProto$1) $defineProperty(OPSymbols, key, D);\n  _anObject(it);\n  key = _toPrimitive(key, true);\n  _anObject(D);\n  if (_has(AllSymbols, key)) {\n    if (!D.enumerable) {\n      if (!_has(it, HIDDEN)) dP$1(it, HIDDEN, _propertyDesc(1, {}));\n      it[HIDDEN][key] = true;\n    } else {\n      if (_has(it, HIDDEN) && it[HIDDEN][key]) it[HIDDEN][key] = false;\n      D = _objectCreate(D, { enumerable: _propertyDesc(0, false) });\n    } return setSymbolDesc(it, key, D);\n  } return dP$1(it, key, D);\n};\nvar $defineProperties = function defineProperties(it, P) {\n  _anObject(it);\n  var keys = _enumKeys(P = _toIobject(P));\n  var i = 0;\n  var l = keys.length;\n  var key;\n  while (l > i) $defineProperty(it, key = keys[i++], P[key]);\n  return it;\n};\nvar $create = function create(it, P) {\n  return P === undefined ? _objectCreate(it) : $defineProperties(_objectCreate(it), P);\n};\nvar $propertyIsEnumerable = function propertyIsEnumerable(key) {\n  var E = isEnum.call(this, key = _toPrimitive(key, true));\n  if (this === ObjectProto$1 && _has(AllSymbols, key) && !_has(OPSymbols, key)) return false;\n  return E || !_has(this, key) || !_has(AllSymbols, key) || _has(this, HIDDEN) && this[HIDDEN][key] ? E : true;\n};\nvar $getOwnPropertyDescriptor$1 = function getOwnPropertyDescriptor(it, key) {\n  it = _toIobject(it);\n  key = _toPrimitive(key, true);\n  if (it === ObjectProto$1 && _has(AllSymbols, key) && !_has(OPSymbols, key)) return;\n  var D = gOPD$1(it, key);\n  if (D && _has(AllSymbols, key) && !(_has(it, HIDDEN) && it[HIDDEN][key])) D.enumerable = true;\n  return D;\n};\nvar $getOwnPropertyNames = function getOwnPropertyNames(it) {\n  var names = gOPN$1(_toIobject(it));\n  var result = [];\n  var i = 0;\n  var key;\n  while (names.length > i) {\n    if (!_has(AllSymbols, key = names[i++]) && key != HIDDEN && key != META) result.push(key);\n  } return result;\n};\nvar $getOwnPropertySymbols = function getOwnPropertySymbols(it) {\n  var IS_OP = it === ObjectProto$1;\n  var names = gOPN$1(IS_OP ? OPSymbols : _toIobject(it));\n  var result = [];\n  var i = 0;\n  var key;\n  while (names.length > i) {\n    if (_has(AllSymbols, key = names[i++]) && (IS_OP ? _has(ObjectProto$1, key) : true)) result.push(AllSymbols[key]);\n  } return result;\n};\n\n// 19.4.1.1 Symbol([description])\nif (!USE_NATIVE$1) {\n  $Symbol = function Symbol() {\n    if (this instanceof $Symbol) throw TypeError('Symbol is not a constructor!');\n    var tag = _uid(arguments.length > 0 ? arguments[0] : undefined);\n    var $set = function (value) {\n      if (this === ObjectProto$1) $set.call(OPSymbols, value);\n      if (_has(this, HIDDEN) && _has(this[HIDDEN], tag)) this[HIDDEN][tag] = false;\n      setSymbolDesc(this, tag, _propertyDesc(1, value));\n    };\n    if (_descriptors && setter) setSymbolDesc(ObjectProto$1, tag, { configurable: true, set: $set });\n    return wrap(tag);\n  };\n  _redefine($Symbol[PROTOTYPE$2], 'toString', function toString() {\n    return this._k;\n  });\n\n  _objectGopd.f = $getOwnPropertyDescriptor$1;\n  _objectDp.f = $defineProperty;\n  _objectGopn.f = _objectGopnExt.f = $getOwnPropertyNames;\n  _objectPie.f = $propertyIsEnumerable;\n  _objectGops.f = $getOwnPropertySymbols;\n\n  if (_descriptors && !_library) {\n    _redefine(ObjectProto$1, 'propertyIsEnumerable', $propertyIsEnumerable, true);\n  }\n\n  _wksExt.f = function (name) {\n    return wrap(_wks(name));\n  };\n}\n\n_export(_export.G + _export.W + _export.F * !USE_NATIVE$1, { Symbol: $Symbol });\n\nfor (var es6Symbols = (\n  // 19.4.2.2, 19.4.2.3, 19.4.2.4, 19.4.2.6, 19.4.2.8, 19.4.2.9, 19.4.2.10, 19.4.2.11, 19.4.2.12, 19.4.2.13, 19.4.2.14\n  'hasInstance,isConcatSpreadable,iterator,match,replace,search,species,split,toPrimitive,toStringTag,unscopables'\n).split(','), j = 0; es6Symbols.length > j;)_wks(es6Symbols[j++]);\n\nfor (var wellKnownSymbols = _objectKeys(_wks.store), k = 0; wellKnownSymbols.length > k;) _wksDefine(wellKnownSymbols[k++]);\n\n_export(_export.S + _export.F * !USE_NATIVE$1, 'Symbol', {\n  // 19.4.2.1 Symbol.for(key)\n  'for': function (key) {\n    return _has(SymbolRegistry, key += '')\n      ? SymbolRegistry[key]\n      : SymbolRegistry[key] = $Symbol(key);\n  },\n  // 19.4.2.5 Symbol.keyFor(sym)\n  keyFor: function keyFor(sym) {\n    if (!isSymbol(sym)) throw TypeError(sym + ' is not a symbol!');\n    for (var key in SymbolRegistry) if (SymbolRegistry[key] === sym) return key;\n  },\n  useSetter: function () { setter = true; },\n  useSimple: function () { setter = false; }\n});\n\n_export(_export.S + _export.F * !USE_NATIVE$1, 'Object', {\n  // 19.1.2.2 Object.create(O [, Properties])\n  create: $create,\n  // 19.1.2.4 Object.defineProperty(O, P, Attributes)\n  defineProperty: $defineProperty,\n  // 19.1.2.3 Object.defineProperties(O, Properties)\n  defineProperties: $defineProperties,\n  // 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\n  getOwnPropertyDescriptor: $getOwnPropertyDescriptor$1,\n  // 19.1.2.7 Object.getOwnPropertyNames(O)\n  getOwnPropertyNames: $getOwnPropertyNames,\n  // 19.1.2.8 Object.getOwnPropertySymbols(O)\n  getOwnPropertySymbols: $getOwnPropertySymbols\n});\n\n// 24.3.2 JSON.stringify(value [, replacer [, space]])\n$JSON && _export(_export.S + _export.F * (!USE_NATIVE$1 || _fails(function () {\n  var S = $Symbol();\n  // MS Edge converts symbol values to JSON as {}\n  // WebKit converts symbol values to JSON as null\n  // V8 throws on boxed symbols\n  return _stringify([S]) != '[null]' || _stringify({ a: S }) != '{}' || _stringify(Object(S)) != '{}';\n})), 'JSON', {\n  stringify: function stringify(it) {\n    var args = [it];\n    var i = 1;\n    var replacer, $replacer;\n    while (arguments.length > i) args.push(arguments[i++]);\n    $replacer = replacer = args[1];\n    if (!_isObject(replacer) && it === undefined || isSymbol(it)) return; // IE8 returns string on undefined\n    if (!_isArray(replacer)) replacer = function (key, value) {\n      if (typeof $replacer == 'function') value = $replacer.call(this, key, value);\n      if (!isSymbol(value)) return value;\n    };\n    args[1] = replacer;\n    return _stringify.apply($JSON, args);\n  }\n});\n\n// 19.4.3.4 Symbol.prototype[@@toPrimitive](hint)\n$Symbol[PROTOTYPE$2][TO_PRIMITIVE] || _hide($Symbol[PROTOTYPE$2], TO_PRIMITIVE, $Symbol[PROTOTYPE$2].valueOf);\n// 19.4.3.5 Symbol.prototype[@@toStringTag]\n_setToStringTag($Symbol, 'Symbol');\n// 20.2.1.9 Math[@@toStringTag]\n_setToStringTag(Math, 'Math', true);\n// 24.3.3 JSON[@@toStringTag]\n_setToStringTag(_global.JSON, 'JSON', true);\n\nvar getOwnPropertySymbols = _core.Object.getOwnPropertySymbols;\n\nvar getOwnPropertySymbols$1 = getOwnPropertySymbols;\n\n// 19.1.2.14 Object.keys(O)\n\n\n\n_objectSap('keys', function () {\n  return function keys(it) {\n    return _objectKeys(_toObject(it));\n  };\n});\n\nvar keys = _core.Object.keys;\n\nvar keys$1 = keys;\n\n// 19.1.2.4 / 15.2.3.6 Object.defineProperty(O, P, Attributes)\n_export(_export.S + _export.F * !_descriptors, 'Object', { defineProperty: _objectDp.f });\n\nvar $Object$1 = _core.Object;\nvar defineProperty$1 = function defineProperty(it, key, desc) {\n  return $Object$1.defineProperty(it, key, desc);\n};\n\nvar defineProperty$2 = defineProperty$1;\n\nfunction _defineProperty(obj, key, value) {\n  if (key in obj) {\n    defineProperty$2(obj, key, {\n      value: value,\n      enumerable: true,\n      configurable: true,\n      writable: true\n    });\n  } else {\n    obj[key] = value;\n  }\n\n  return obj;\n}\n\nvar defineProperty$3 = _defineProperty;\n\nfunction _objectSpread(target) {\n  for (var i = 1; i < arguments.length; i++) {\n    var source = arguments[i] != null ? arguments[i] : {};\n\n    var ownKeys = keys$1(source);\n\n    if (typeof getOwnPropertySymbols$1 === 'function') {\n      ownKeys = ownKeys.concat(getOwnPropertySymbols$1(source).filter(function (sym) {\n        return getOwnPropertyDescriptor$1(source, sym).enumerable;\n      }));\n    }\n\n    ownKeys.forEach(function (key) {\n      defineProperty$3(target, key, source[key]);\n    });\n  }\n\n  return target;\n}\n\nvar objectSpread = _objectSpread;\n\nfunction _classCallCheck(instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n}\n\nvar classCallCheck = _classCallCheck;\n\n// Works with __proto__ only. Old v8 can't work with null proto objects.\n/* eslint-disable no-proto */\n\n\nvar check = function (O, proto) {\n  _anObject(O);\n  if (!_isObject(proto) && proto !== null) throw TypeError(proto + \": can't set as prototype!\");\n};\nvar _setProto = {\n  set: Object.setPrototypeOf || ('__proto__' in {} ? // eslint-disable-line\n    function (test, buggy, set) {\n      try {\n        set = _ctx(Function.call, _objectGopd.f(Object.prototype, '__proto__').set, 2);\n        set(test, []);\n        buggy = !(test instanceof Array);\n      } catch (e) { buggy = true; }\n      return function setPrototypeOf(O, proto) {\n        check(O, proto);\n        if (buggy) O.__proto__ = proto;\n        else set(O, proto);\n        return O;\n      };\n    }({}, false) : undefined),\n  check: check\n};\n\n// 19.1.3.19 Object.setPrototypeOf(O, proto)\n\n_export(_export.S, 'Object', { setPrototypeOf: _setProto.set });\n\nvar setPrototypeOf = _core.Object.setPrototypeOf;\n\nvar setPrototypeOf$1 = setPrototypeOf;\n\nvar setPrototypeOf$2 = createCommonjsModule(function (module) {\nfunction _setPrototypeOf(o, p) {\n  module.exports = _setPrototypeOf = setPrototypeOf$1 || function _setPrototypeOf(o, p) {\n    o.__proto__ = p;\n    return o;\n  };\n\n  return _setPrototypeOf(o, p);\n}\n\nmodule.exports = _setPrototypeOf;\n});\n\nfunction _inherits(subClass, superClass) {\n  if (typeof superClass !== \"function\" && superClass !== null) {\n    throw new TypeError(\"Super expression must either be null or a function\");\n  }\n\n  setPrototypeOf$2(subClass.prototype, superClass && superClass.prototype);\n  if (superClass) setPrototypeOf$2(subClass, superClass);\n}\n\nvar inherits = _inherits;\n\nfunction _defineProperties(target, props) {\n  for (var i = 0; i < props.length; i++) {\n    var descriptor = props[i];\n    descriptor.enumerable = descriptor.enumerable || false;\n    descriptor.configurable = true;\n    if (\"value\" in descriptor) descriptor.writable = true;\n\n    defineProperty$2(target, descriptor.key, descriptor);\n  }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n  if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n  if (staticProps) _defineProperties(Constructor, staticProps);\n  return Constructor;\n}\n\nvar createClass = _createClass;\n\nvar iterator = _wksExt.f('iterator');\n\nvar iterator$1 = iterator;\n\n_wksDefine('asyncIterator');\n\n_wksDefine('observable');\n\nvar symbol = _core.Symbol;\n\nvar symbol$1 = symbol;\n\nvar _typeof_1 = createCommonjsModule(function (module) {\nfunction _typeof2(obj) { if (typeof symbol$1 === \"function\" && typeof iterator$1 === \"symbol\") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof symbol$1 === \"function\" && obj.constructor === symbol$1 && obj !== symbol$1.prototype ? \"symbol\" : typeof obj; }; } return _typeof2(obj); }\n\nfunction _typeof(obj) {\n  if (typeof symbol$1 === \"function\" && _typeof2(iterator$1) === \"symbol\") {\n    module.exports = _typeof = function _typeof(obj) {\n      return _typeof2(obj);\n    };\n  } else {\n    module.exports = _typeof = function _typeof(obj) {\n      return obj && typeof symbol$1 === \"function\" && obj.constructor === symbol$1 && obj !== symbol$1.prototype ? \"symbol\" : _typeof2(obj);\n    };\n  }\n\n  return _typeof(obj);\n}\n\nmodule.exports = _typeof;\n});\n\nfunction _assertThisInitialized(self) {\n  if (self === void 0) {\n    throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n  }\n\n  return self;\n}\n\nvar assertThisInitialized = _assertThisInitialized;\n\nfunction _possibleConstructorReturn(self, call) {\n  if (call && (_typeof_1(call) === \"object\" || typeof call === \"function\")) {\n    return call;\n  }\n\n  return assertThisInitialized(self);\n}\n\nvar possibleConstructorReturn = _possibleConstructorReturn;\n\n// 19.1.2.9 Object.getPrototypeOf(O)\n\n\n\n_objectSap('getPrototypeOf', function () {\n  return function getPrototypeOf(it) {\n    return _objectGpo(_toObject(it));\n  };\n});\n\nvar getPrototypeOf = _core.Object.getPrototypeOf;\n\nvar getPrototypeOf$1 = getPrototypeOf;\n\nvar getPrototypeOf$2 = createCommonjsModule(function (module) {\nfunction _getPrototypeOf(o) {\n  module.exports = _getPrototypeOf = getPrototypeOf$1 || function _getPrototypeOf(o) {\n    return o.__proto__;\n  };\n\n  return _getPrototypeOf(o);\n}\n\nmodule.exports = _getPrototypeOf;\n});\n\nvar extend = function extend(object) {\n  for (var _len = arguments.length, extensions = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n    extensions[_key - 1] = arguments[_key];\n  }\n\n  // $.extend alternative, ... is the spread operator.\n  for (var _i = 0; _i < extensions.length; _i++) {\n    var extension = extensions[_i];\n    // console.log(extension);\n    // console.log(typeof extension);\n    if (!extension) continue; // Ignore null and undefined objects and parameters.\n\n    var _iteratorNormalCompletion = true;\n    var _didIteratorError = false;\n    var _iteratorError = undefined;\n\n    try {\n      for (var _iterator = Object.getOwnPropertyNames(extension)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {\n        var prop = _step.value;\n\n        // Do not traverse the prototype chain.\n        if (object[prop] !== undefined && extension[prop] && object[prop].toString() === '[object Object]' && extension[prop].toString() === '[object Object]') {\n          // Goes deep only if object[prop] and extension[prop] are both objects !\n          if (object[prop].constructor === Object) extend(object[prop], extension[prop]);\n        } else object[prop] = typeof object[prop] === 'undefined' ? extension[prop] : object[prop];\n\n        if (typeof object[prop] === 'undefined' && Array.isArray(extension[prop])) object[prop] = extension[prop].slice(); // Add values that do not already exist.\n        else if (typeof object[prop] === 'undefined' && Array.isArray(extension[prop])) object[prop] = extension[prop];\n      }\n    } catch (err) {\n      _didIteratorError = true;\n      _iteratorError = err;\n    } finally {\n      try {\n        if (!_iteratorNormalCompletion && _iterator.return != null) {\n          _iterator.return();\n        }\n      } finally {\n        if (_didIteratorError) {\n          throw _iteratorError;\n        }\n      }\n    }\n  }\n\n  return object;\n};\n\nvar instruct = function instruct(array, instArray) {\n  var tempObject = {};\n\n  for (var i = 0, max = instArray.length; i < max; i++) {\n    var guide = instArray[i];\n    tempObject[guide] = array[i];\n  }\n\n  return tempObject;\n};\nvar transformData = function transformData(object, instructions) {\n  for (var key in instructions) {\n    if (Array.isArray(object[key])) object[key] = instruct(object[key], instructions[key]);else if (object[key] instanceof Object && !Array.isArray(instructions[key])) object[key] = transformData(object[key], instructions[key]);\n  }\n\n  return object;\n};\nvar toArray = function toArray(object, instruction) {\n  var tempArray = [];\n\n  for (var i = 0, max = instruction.length; i < max; i++) {\n    var guide = instruction[i];\n    tempArray[i] = object[guide];\n  }\n\n  return tempArray;\n};\n\n// Polyfills\n\nif ( Number.EPSILON === undefined ) {\n\n\tNumber.EPSILON = Math.pow( 2, - 52 );\n\n}\n\nif ( Number.isInteger === undefined ) {\n\n\t// Missing in IE\n\t// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/isInteger\n\n\tNumber.isInteger = function ( value ) {\n\n\t\treturn typeof value === 'number' && isFinite( value ) && Math.floor( value ) === value;\n\n\t};\n\n}\n\n//\n\nif ( Math.sign === undefined ) {\n\n\t// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/sign\n\n\tMath.sign = function ( x ) {\n\n\t\treturn ( x < 0 ) ? - 1 : ( x > 0 ) ? 1 : + x;\n\n\t};\n\n}\n\nif ( 'name' in Function.prototype === false ) {\n\n\t// Missing in IE\n\t// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/name\n\n\tObject.defineProperty( Function.prototype, 'name', {\n\n\t\tget: function () {\n\n\t\t\treturn this.toString().match( /^\\s*function\\s*([^\\(\\s]*)/ )[ 1 ];\n\n\t\t}\n\n\t} );\n\n}\n\nif ( Object.assign === undefined ) {\n\n\t// Missing in IE\n\t// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/assign\n\n\t( function () {\n\n\t\tObject.assign = function ( target ) {\n\n\t\t\tif ( target === undefined || target === null ) {\n\n\t\t\t\tthrow new TypeError( 'Cannot convert undefined or null to object' );\n\n\t\t\t}\n\n\t\t\tvar output = Object( target );\n\n\t\t\tfor ( var index = 1; index < arguments.length; index ++ ) {\n\n\t\t\t\tvar source = arguments[ index ];\n\n\t\t\t\tif ( source !== undefined && source !== null ) {\n\n\t\t\t\t\tfor ( var nextKey in source ) {\n\n\t\t\t\t\t\tif ( Object.prototype.hasOwnProperty.call( source, nextKey ) ) {\n\n\t\t\t\t\t\t\toutput[ nextKey ] = source[ nextKey ];\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn output;\n\n\t\t};\n\n\t} )();\n\n}\n\n/**\n * https://github.com/mrdoob/eventdispatcher.js/\n */\n\nfunction EventDispatcher() {}\n\nObject.assign( EventDispatcher.prototype, {\n\n\taddEventListener: function ( type, listener ) {\n\n\t\tif ( this._listeners === undefined ) this._listeners = {};\n\n\t\tvar listeners = this._listeners;\n\n\t\tif ( listeners[ type ] === undefined ) {\n\n\t\t\tlisteners[ type ] = [];\n\n\t\t}\n\n\t\tif ( listeners[ type ].indexOf( listener ) === - 1 ) {\n\n\t\t\tlisteners[ type ].push( listener );\n\n\t\t}\n\n\t},\n\n\thasEventListener: function ( type, listener ) {\n\n\t\tif ( this._listeners === undefined ) return false;\n\n\t\tvar listeners = this._listeners;\n\n\t\treturn listeners[ type ] !== undefined && listeners[ type ].indexOf( listener ) !== - 1;\n\n\t},\n\n\tremoveEventListener: function ( type, listener ) {\n\n\t\tif ( this._listeners === undefined ) return;\n\n\t\tvar listeners = this._listeners;\n\t\tvar listenerArray = listeners[ type ];\n\n\t\tif ( listenerArray !== undefined ) {\n\n\t\t\tvar index = listenerArray.indexOf( listener );\n\n\t\t\tif ( index !== - 1 ) {\n\n\t\t\t\tlistenerArray.splice( index, 1 );\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\tdispatchEvent: function ( event ) {\n\n\t\tif ( this._listeners === undefined ) return;\n\n\t\tvar listeners = this._listeners;\n\t\tvar listenerArray = listeners[ event.type ];\n\n\t\tif ( listenerArray !== undefined ) {\n\n\t\t\tevent.target = this;\n\n\t\t\tvar array = listenerArray.slice( 0 );\n\n\t\t\tfor ( var i = 0, l = array.length; i < l; i ++ ) {\n\n\t\t\t\tarray[ i ].call( this, event );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n} );\n\nvar REVISION = '92';\nvar MOUSE = { LEFT: 0, MIDDLE: 1, RIGHT: 2 };\nvar CullFaceNone = 0;\nvar CullFaceBack = 1;\nvar CullFaceFront = 2;\nvar PCFShadowMap = 1;\nvar PCFSoftShadowMap = 2;\nvar FrontSide = 0;\nvar BackSide = 1;\nvar DoubleSide = 2;\nvar FlatShading = 1;\nvar NoColors = 0;\nvar FaceColors = 1;\nvar VertexColors = 2;\nvar NoBlending = 0;\nvar NormalBlending = 1;\nvar AdditiveBlending = 2;\nvar SubtractiveBlending = 3;\nvar MultiplyBlending = 4;\nvar CustomBlending = 5;\nvar AddEquation = 100;\nvar SubtractEquation = 101;\nvar ReverseSubtractEquation = 102;\nvar MinEquation = 103;\nvar MaxEquation = 104;\nvar ZeroFactor = 200;\nvar OneFactor = 201;\nvar SrcColorFactor = 202;\nvar OneMinusSrcColorFactor = 203;\nvar SrcAlphaFactor = 204;\nvar OneMinusSrcAlphaFactor = 205;\nvar DstAlphaFactor = 206;\nvar OneMinusDstAlphaFactor = 207;\nvar DstColorFactor = 208;\nvar OneMinusDstColorFactor = 209;\nvar SrcAlphaSaturateFactor = 210;\nvar NeverDepth = 0;\nvar AlwaysDepth = 1;\nvar LessDepth = 2;\nvar LessEqualDepth = 3;\nvar EqualDepth = 4;\nvar GreaterEqualDepth = 5;\nvar GreaterDepth = 6;\nvar NotEqualDepth = 7;\nvar MultiplyOperation = 0;\nvar MixOperation = 1;\nvar AddOperation = 2;\nvar NoToneMapping = 0;\nvar LinearToneMapping = 1;\nvar ReinhardToneMapping = 2;\nvar Uncharted2ToneMapping = 3;\nvar CineonToneMapping = 4;\nvar UVMapping = 300;\nvar CubeReflectionMapping = 301;\nvar CubeRefractionMapping = 302;\nvar EquirectangularReflectionMapping = 303;\nvar EquirectangularRefractionMapping = 304;\nvar SphericalReflectionMapping = 305;\nvar CubeUVReflectionMapping = 306;\nvar CubeUVRefractionMapping = 307;\nvar RepeatWrapping = 1000;\nvar ClampToEdgeWrapping = 1001;\nvar MirroredRepeatWrapping = 1002;\nvar NearestFilter = 1003;\nvar NearestMipMapNearestFilter = 1004;\nvar NearestMipMapLinearFilter = 1005;\nvar LinearFilter = 1006;\nvar LinearMipMapNearestFilter = 1007;\nvar LinearMipMapLinearFilter = 1008;\nvar UnsignedByteType = 1009;\nvar ByteType = 1010;\nvar ShortType = 1011;\nvar UnsignedShortType = 1012;\nvar IntType = 1013;\nvar UnsignedIntType = 1014;\nvar FloatType = 1015;\nvar HalfFloatType = 1016;\nvar UnsignedShort4444Type = 1017;\nvar UnsignedShort5551Type = 1018;\nvar UnsignedShort565Type = 1019;\nvar UnsignedInt248Type = 1020;\nvar AlphaFormat = 1021;\nvar RGBFormat = 1022;\nvar RGBAFormat = 1023;\nvar LuminanceFormat = 1024;\nvar LuminanceAlphaFormat = 1025;\nvar DepthFormat = 1026;\nvar DepthStencilFormat = 1027;\nvar RGB_S3TC_DXT1_Format = 33776;\nvar RGBA_S3TC_DXT1_Format = 33777;\nvar RGBA_S3TC_DXT3_Format = 33778;\nvar RGBA_S3TC_DXT5_Format = 33779;\nvar RGB_PVRTC_4BPPV1_Format = 35840;\nvar RGB_PVRTC_2BPPV1_Format = 35841;\nvar RGBA_PVRTC_4BPPV1_Format = 35842;\nvar RGBA_PVRTC_2BPPV1_Format = 35843;\nvar RGB_ETC1_Format = 36196;\nvar RGBA_ASTC_4x4_Format = 37808;\nvar RGBA_ASTC_5x4_Format = 37809;\nvar RGBA_ASTC_5x5_Format = 37810;\nvar RGBA_ASTC_6x5_Format = 37811;\nvar RGBA_ASTC_6x6_Format = 37812;\nvar RGBA_ASTC_8x5_Format = 37813;\nvar RGBA_ASTC_8x6_Format = 37814;\nvar RGBA_ASTC_8x8_Format = 37815;\nvar RGBA_ASTC_10x5_Format = 37816;\nvar RGBA_ASTC_10x6_Format = 37817;\nvar RGBA_ASTC_10x8_Format = 37818;\nvar RGBA_ASTC_10x10_Format = 37819;\nvar RGBA_ASTC_12x10_Format = 37820;\nvar RGBA_ASTC_12x12_Format = 37821;\nvar LoopOnce = 2200;\nvar LoopRepeat = 2201;\nvar LoopPingPong = 2202;\nvar InterpolateDiscrete = 2300;\nvar InterpolateLinear = 2301;\nvar InterpolateSmooth = 2302;\nvar ZeroCurvatureEnding = 2400;\nvar ZeroSlopeEnding = 2401;\nvar WrapAroundEnding = 2402;\nvar TrianglesDrawMode = 0;\nvar TriangleStripDrawMode = 1;\nvar TriangleFanDrawMode = 2;\nvar LinearEncoding = 3000;\nvar sRGBEncoding = 3001;\nvar GammaEncoding = 3007;\nvar RGBEEncoding = 3002;\nvar RGBM7Encoding = 3004;\nvar RGBM16Encoding = 3005;\nvar RGBDEncoding = 3006;\nvar BasicDepthPacking = 3200;\nvar RGBADepthPacking = 3201;\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author mrdoob / http://mrdoob.com/\n */\n\nvar _Math = {\n\n\tDEG2RAD: Math.PI / 180,\n\tRAD2DEG: 180 / Math.PI,\n\n\tgenerateUUID: ( function () {\n\n\t\t// http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/21963136#21963136\n\n\t\tvar lut = [];\n\n\t\tfor ( var i = 0; i < 256; i ++ ) {\n\n\t\t\tlut[ i ] = ( i < 16 ? '0' : '' ) + ( i ).toString( 16 );\n\n\t\t}\n\n\t\treturn function generateUUID() {\n\n\t\t\tvar d0 = Math.random() * 0xffffffff | 0;\n\t\t\tvar d1 = Math.random() * 0xffffffff | 0;\n\t\t\tvar d2 = Math.random() * 0xffffffff | 0;\n\t\t\tvar d3 = Math.random() * 0xffffffff | 0;\n\t\t\tvar uuid = lut[ d0 & 0xff ] + lut[ d0 >> 8 & 0xff ] + lut[ d0 >> 16 & 0xff ] + lut[ d0 >> 24 & 0xff ] + '-' +\n\t\t\t\tlut[ d1 & 0xff ] + lut[ d1 >> 8 & 0xff ] + '-' + lut[ d1 >> 16 & 0x0f | 0x40 ] + lut[ d1 >> 24 & 0xff ] + '-' +\n\t\t\t\tlut[ d2 & 0x3f | 0x80 ] + lut[ d2 >> 8 & 0xff ] + '-' + lut[ d2 >> 16 & 0xff ] + lut[ d2 >> 24 & 0xff ] +\n\t\t\t\tlut[ d3 & 0xff ] + lut[ d3 >> 8 & 0xff ] + lut[ d3 >> 16 & 0xff ] + lut[ d3 >> 24 & 0xff ];\n\n\t\t\t// .toUpperCase() here flattens concatenated strings to save heap memory space.\n\t\t\treturn uuid.toUpperCase();\n\n\t\t};\n\n\t} )(),\n\n\tclamp: function ( value, min, max ) {\n\n\t\treturn Math.max( min, Math.min( max, value ) );\n\n\t},\n\n\t// compute euclidian modulo of m % n\n\t// https://en.wikipedia.org/wiki/Modulo_operation\n\n\teuclideanModulo: function ( n, m ) {\n\n\t\treturn ( ( n % m ) + m ) % m;\n\n\t},\n\n\t// Linear mapping from range <a1, a2> to range <b1, b2>\n\n\tmapLinear: function ( x, a1, a2, b1, b2 ) {\n\n\t\treturn b1 + ( x - a1 ) * ( b2 - b1 ) / ( a2 - a1 );\n\n\t},\n\n\t// https://en.wikipedia.org/wiki/Linear_interpolation\n\n\tlerp: function ( x, y, t ) {\n\n\t\treturn ( 1 - t ) * x + t * y;\n\n\t},\n\n\t// http://en.wikipedia.org/wiki/Smoothstep\n\n\tsmoothstep: function ( x, min, max ) {\n\n\t\tif ( x <= min ) return 0;\n\t\tif ( x >= max ) return 1;\n\n\t\tx = ( x - min ) / ( max - min );\n\n\t\treturn x * x * ( 3 - 2 * x );\n\n\t},\n\n\tsmootherstep: function ( x, min, max ) {\n\n\t\tif ( x <= min ) return 0;\n\t\tif ( x >= max ) return 1;\n\n\t\tx = ( x - min ) / ( max - min );\n\n\t\treturn x * x * x * ( x * ( x * 6 - 15 ) + 10 );\n\n\t},\n\n\t// Random integer from <low, high> interval\n\n\trandInt: function ( low, high ) {\n\n\t\treturn low + Math.floor( Math.random() * ( high - low + 1 ) );\n\n\t},\n\n\t// Random float from <low, high> interval\n\n\trandFloat: function ( low, high ) {\n\n\t\treturn low + Math.random() * ( high - low );\n\n\t},\n\n\t// Random float from <-range/2, range/2> interval\n\n\trandFloatSpread: function ( range ) {\n\n\t\treturn range * ( 0.5 - Math.random() );\n\n\t},\n\n\tdegToRad: function ( degrees ) {\n\n\t\treturn degrees * _Math.DEG2RAD;\n\n\t},\n\n\tradToDeg: function ( radians ) {\n\n\t\treturn radians * _Math.RAD2DEG;\n\n\t},\n\n\tisPowerOfTwo: function ( value ) {\n\n\t\treturn ( value & ( value - 1 ) ) === 0 && value !== 0;\n\n\t},\n\n\tceilPowerOfTwo: function ( value ) {\n\n\t\treturn Math.pow( 2, Math.ceil( Math.log( value ) / Math.LN2 ) );\n\n\t},\n\n\tfloorPowerOfTwo: function ( value ) {\n\n\t\treturn Math.pow( 2, Math.floor( Math.log( value ) / Math.LN2 ) );\n\n\t}\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author philogb / http://blog.thejit.org/\n * @author egraether / http://egraether.com/\n * @author zz85 / http://www.lab4games.net/zz85/blog\n */\n\nfunction Vector2( x, y ) {\n\n\tthis.x = x || 0;\n\tthis.y = y || 0;\n\n}\n\nObject.defineProperties( Vector2.prototype, {\n\n\t\"width\": {\n\n\t\tget: function () {\n\n\t\t\treturn this.x;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis.x = value;\n\n\t\t}\n\n\t},\n\n\t\"height\": {\n\n\t\tget: function () {\n\n\t\t\treturn this.y;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis.y = value;\n\n\t\t}\n\n\t}\n\n} );\n\nObject.assign( Vector2.prototype, {\n\n\tisVector2: true,\n\n\tset: function ( x, y ) {\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t},\n\n\tsetScalar: function ( scalar ) {\n\n\t\tthis.x = scalar;\n\t\tthis.y = scalar;\n\n\t\treturn this;\n\n\t},\n\n\tsetX: function ( x ) {\n\n\t\tthis.x = x;\n\n\t\treturn this;\n\n\t},\n\n\tsetY: function ( y ) {\n\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t},\n\n\tsetComponent: function ( index, value ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: this.x = value; break;\n\t\t\tcase 1: this.y = value; break;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tgetComponent: function ( index ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: return this.x;\n\t\t\tcase 1: return this.y;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.x, this.y );\n\n\t},\n\n\tcopy: function ( v ) {\n\n\t\tthis.x = v.x;\n\t\tthis.y = v.y;\n\n\t\treturn this;\n\n\t},\n\n\tadd: function ( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead.' );\n\t\t\treturn this.addVectors( v, w );\n\n\t\t}\n\n\t\tthis.x += v.x;\n\t\tthis.y += v.y;\n\n\t\treturn this;\n\n\t},\n\n\taddScalar: function ( s ) {\n\n\t\tthis.x += s;\n\t\tthis.y += s;\n\n\t\treturn this;\n\n\t},\n\n\taddVectors: function ( a, b ) {\n\n\t\tthis.x = a.x + b.x;\n\t\tthis.y = a.y + b.y;\n\n\t\treturn this;\n\n\t},\n\n\taddScaledVector: function ( v, s ) {\n\n\t\tthis.x += v.x * s;\n\t\tthis.y += v.y * s;\n\n\t\treturn this;\n\n\t},\n\n\tsub: function ( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.' );\n\t\t\treturn this.subVectors( v, w );\n\n\t\t}\n\n\t\tthis.x -= v.x;\n\t\tthis.y -= v.y;\n\n\t\treturn this;\n\n\t},\n\n\tsubScalar: function ( s ) {\n\n\t\tthis.x -= s;\n\t\tthis.y -= s;\n\n\t\treturn this;\n\n\t},\n\n\tsubVectors: function ( a, b ) {\n\n\t\tthis.x = a.x - b.x;\n\t\tthis.y = a.y - b.y;\n\n\t\treturn this;\n\n\t},\n\n\tmultiply: function ( v ) {\n\n\t\tthis.x *= v.x;\n\t\tthis.y *= v.y;\n\n\t\treturn this;\n\n\t},\n\n\tmultiplyScalar: function ( scalar ) {\n\n\t\tthis.x *= scalar;\n\t\tthis.y *= scalar;\n\n\t\treturn this;\n\n\t},\n\n\tdivide: function ( v ) {\n\n\t\tthis.x /= v.x;\n\t\tthis.y /= v.y;\n\n\t\treturn this;\n\n\t},\n\n\tdivideScalar: function ( scalar ) {\n\n\t\treturn this.multiplyScalar( 1 / scalar );\n\n\t},\n\n\tapplyMatrix3: function ( m ) {\n\n\t\tvar x = this.x, y = this.y;\n\t\tvar e = m.elements;\n\n\t\tthis.x = e[ 0 ] * x + e[ 3 ] * y + e[ 6 ];\n\t\tthis.y = e[ 1 ] * x + e[ 4 ] * y + e[ 7 ];\n\n\t\treturn this;\n\n\t},\n\n\tmin: function ( v ) {\n\n\t\tthis.x = Math.min( this.x, v.x );\n\t\tthis.y = Math.min( this.y, v.y );\n\n\t\treturn this;\n\n\t},\n\n\tmax: function ( v ) {\n\n\t\tthis.x = Math.max( this.x, v.x );\n\t\tthis.y = Math.max( this.y, v.y );\n\n\t\treturn this;\n\n\t},\n\n\tclamp: function ( min, max ) {\n\n\t\t// assumes min < max, componentwise\n\n\t\tthis.x = Math.max( min.x, Math.min( max.x, this.x ) );\n\t\tthis.y = Math.max( min.y, Math.min( max.y, this.y ) );\n\n\t\treturn this;\n\n\t},\n\n\tclampScalar: function () {\n\n\t\tvar min = new Vector2();\n\t\tvar max = new Vector2();\n\n\t\treturn function clampScalar( minVal, maxVal ) {\n\n\t\t\tmin.set( minVal, minVal );\n\t\t\tmax.set( maxVal, maxVal );\n\n\t\t\treturn this.clamp( min, max );\n\n\t\t};\n\n\t}(),\n\n\tclampLength: function ( min, max ) {\n\n\t\tvar length = this.length();\n\n\t\treturn this.divideScalar( length || 1 ).multiplyScalar( Math.max( min, Math.min( max, length ) ) );\n\n\t},\n\n\tfloor: function () {\n\n\t\tthis.x = Math.floor( this.x );\n\t\tthis.y = Math.floor( this.y );\n\n\t\treturn this;\n\n\t},\n\n\tceil: function () {\n\n\t\tthis.x = Math.ceil( this.x );\n\t\tthis.y = Math.ceil( this.y );\n\n\t\treturn this;\n\n\t},\n\n\tround: function () {\n\n\t\tthis.x = Math.round( this.x );\n\t\tthis.y = Math.round( this.y );\n\n\t\treturn this;\n\n\t},\n\n\troundToZero: function () {\n\n\t\tthis.x = ( this.x < 0 ) ? Math.ceil( this.x ) : Math.floor( this.x );\n\t\tthis.y = ( this.y < 0 ) ? Math.ceil( this.y ) : Math.floor( this.y );\n\n\t\treturn this;\n\n\t},\n\n\tnegate: function () {\n\n\t\tthis.x = - this.x;\n\t\tthis.y = - this.y;\n\n\t\treturn this;\n\n\t},\n\n\tdot: function ( v ) {\n\n\t\treturn this.x * v.x + this.y * v.y;\n\n\t},\n\n\tlengthSq: function () {\n\n\t\treturn this.x * this.x + this.y * this.y;\n\n\t},\n\n\tlength: function () {\n\n\t\treturn Math.sqrt( this.x * this.x + this.y * this.y );\n\n\t},\n\n\tmanhattanLength: function () {\n\n\t\treturn Math.abs( this.x ) + Math.abs( this.y );\n\n\t},\n\n\tnormalize: function () {\n\n\t\treturn this.divideScalar( this.length() || 1 );\n\n\t},\n\n\tangle: function () {\n\n\t\t// computes the angle in radians with respect to the positive x-axis\n\n\t\tvar angle = Math.atan2( this.y, this.x );\n\n\t\tif ( angle < 0 ) angle += 2 * Math.PI;\n\n\t\treturn angle;\n\n\t},\n\n\tdistanceTo: function ( v ) {\n\n\t\treturn Math.sqrt( this.distanceToSquared( v ) );\n\n\t},\n\n\tdistanceToSquared: function ( v ) {\n\n\t\tvar dx = this.x - v.x, dy = this.y - v.y;\n\t\treturn dx * dx + dy * dy;\n\n\t},\n\n\tmanhattanDistanceTo: function ( v ) {\n\n\t\treturn Math.abs( this.x - v.x ) + Math.abs( this.y - v.y );\n\n\t},\n\n\tsetLength: function ( length ) {\n\n\t\treturn this.normalize().multiplyScalar( length );\n\n\t},\n\n\tlerp: function ( v, alpha ) {\n\n\t\tthis.x += ( v.x - this.x ) * alpha;\n\t\tthis.y += ( v.y - this.y ) * alpha;\n\n\t\treturn this;\n\n\t},\n\n\tlerpVectors: function ( v1, v2, alpha ) {\n\n\t\treturn this.subVectors( v2, v1 ).multiplyScalar( alpha ).add( v1 );\n\n\t},\n\n\tequals: function ( v ) {\n\n\t\treturn ( ( v.x === this.x ) && ( v.y === this.y ) );\n\n\t},\n\n\tfromArray: function ( array, offset ) {\n\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tthis.x = array[ offset ];\n\t\tthis.y = array[ offset + 1 ];\n\n\t\treturn this;\n\n\t},\n\n\ttoArray: function ( array, offset ) {\n\n\t\tif ( array === undefined ) array = [];\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tarray[ offset ] = this.x;\n\t\tarray[ offset + 1 ] = this.y;\n\n\t\treturn array;\n\n\t},\n\n\tfromBufferAttribute: function ( attribute, index, offset ) {\n\n\t\tif ( offset !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector2: offset has been removed from .fromBufferAttribute().' );\n\n\t\t}\n\n\t\tthis.x = attribute.getX( index );\n\t\tthis.y = attribute.getY( index );\n\n\t\treturn this;\n\n\t},\n\n\trotateAround: function ( center, angle ) {\n\n\t\tvar c = Math.cos( angle ), s = Math.sin( angle );\n\n\t\tvar x = this.x - center.x;\n\t\tvar y = this.y - center.y;\n\n\t\tthis.x = x * c - y * s + center.x;\n\t\tthis.y = x * s + y * c + center.y;\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author supereggbert / http://www.paulbrunt.co.uk/\n * @author philogb / http://blog.thejit.org/\n * @author jordi_ros / http://plattsoft.com\n * @author D1plo1d / http://github.com/D1plo1d\n * @author alteredq / http://alteredqualia.com/\n * @author mikael emtinger / http://gomo.se/\n * @author timknip / http://www.floorplanner.com/\n * @author bhouston / http://clara.io\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction Matrix4() {\n\n\tthis.elements = [\n\n\t\t1, 0, 0, 0,\n\t\t0, 1, 0, 0,\n\t\t0, 0, 1, 0,\n\t\t0, 0, 0, 1\n\n\t];\n\n\tif ( arguments.length > 0 ) {\n\n\t\tconsole.error( 'THREE.Matrix4: the constructor no longer reads arguments. use .set() instead.' );\n\n\t}\n\n}\n\nObject.assign( Matrix4.prototype, {\n\n\tisMatrix4: true,\n\n\tset: function ( n11, n12, n13, n14, n21, n22, n23, n24, n31, n32, n33, n34, n41, n42, n43, n44 ) {\n\n\t\tvar te = this.elements;\n\n\t\tte[ 0 ] = n11; te[ 4 ] = n12; te[ 8 ] = n13; te[ 12 ] = n14;\n\t\tte[ 1 ] = n21; te[ 5 ] = n22; te[ 9 ] = n23; te[ 13 ] = n24;\n\t\tte[ 2 ] = n31; te[ 6 ] = n32; te[ 10 ] = n33; te[ 14 ] = n34;\n\t\tte[ 3 ] = n41; te[ 7 ] = n42; te[ 11 ] = n43; te[ 15 ] = n44;\n\n\t\treturn this;\n\n\t},\n\n\tidentity: function () {\n\n\t\tthis.set(\n\n\t\t\t1, 0, 0, 0,\n\t\t\t0, 1, 0, 0,\n\t\t\t0, 0, 1, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new Matrix4().fromArray( this.elements );\n\n\t},\n\n\tcopy: function ( m ) {\n\n\t\tvar te = this.elements;\n\t\tvar me = m.elements;\n\n\t\tte[ 0 ] = me[ 0 ]; te[ 1 ] = me[ 1 ]; te[ 2 ] = me[ 2 ]; te[ 3 ] = me[ 3 ];\n\t\tte[ 4 ] = me[ 4 ]; te[ 5 ] = me[ 5 ]; te[ 6 ] = me[ 6 ]; te[ 7 ] = me[ 7 ];\n\t\tte[ 8 ] = me[ 8 ]; te[ 9 ] = me[ 9 ]; te[ 10 ] = me[ 10 ]; te[ 11 ] = me[ 11 ];\n\t\tte[ 12 ] = me[ 12 ]; te[ 13 ] = me[ 13 ]; te[ 14 ] = me[ 14 ]; te[ 15 ] = me[ 15 ];\n\n\t\treturn this;\n\n\t},\n\n\tcopyPosition: function ( m ) {\n\n\t\tvar te = this.elements, me = m.elements;\n\n\t\tte[ 12 ] = me[ 12 ];\n\t\tte[ 13 ] = me[ 13 ];\n\t\tte[ 14 ] = me[ 14 ];\n\n\t\treturn this;\n\n\t},\n\n\textractBasis: function ( xAxis, yAxis, zAxis ) {\n\n\t\txAxis.setFromMatrixColumn( this, 0 );\n\t\tyAxis.setFromMatrixColumn( this, 1 );\n\t\tzAxis.setFromMatrixColumn( this, 2 );\n\n\t\treturn this;\n\n\t},\n\n\tmakeBasis: function ( xAxis, yAxis, zAxis ) {\n\n\t\tthis.set(\n\t\t\txAxis.x, yAxis.x, zAxis.x, 0,\n\t\t\txAxis.y, yAxis.y, zAxis.y, 0,\n\t\t\txAxis.z, yAxis.z, zAxis.z, 0,\n\t\t\t0, 0, 0, 1\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\textractRotation: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function extractRotation( m ) {\n\n\t\t\tvar te = this.elements;\n\t\t\tvar me = m.elements;\n\n\t\t\tvar scaleX = 1 / v1.setFromMatrixColumn( m, 0 ).length();\n\t\t\tvar scaleY = 1 / v1.setFromMatrixColumn( m, 1 ).length();\n\t\t\tvar scaleZ = 1 / v1.setFromMatrixColumn( m, 2 ).length();\n\n\t\t\tte[ 0 ] = me[ 0 ] * scaleX;\n\t\t\tte[ 1 ] = me[ 1 ] * scaleX;\n\t\t\tte[ 2 ] = me[ 2 ] * scaleX;\n\n\t\t\tte[ 4 ] = me[ 4 ] * scaleY;\n\t\t\tte[ 5 ] = me[ 5 ] * scaleY;\n\t\t\tte[ 6 ] = me[ 6 ] * scaleY;\n\n\t\t\tte[ 8 ] = me[ 8 ] * scaleZ;\n\t\t\tte[ 9 ] = me[ 9 ] * scaleZ;\n\t\t\tte[ 10 ] = me[ 10 ] * scaleZ;\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tmakeRotationFromEuler: function ( euler ) {\n\n\t\tif ( ! ( euler && euler.isEuler ) ) {\n\n\t\t\tconsole.error( 'THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.' );\n\n\t\t}\n\n\t\tvar te = this.elements;\n\n\t\tvar x = euler.x, y = euler.y, z = euler.z;\n\t\tvar a = Math.cos( x ), b = Math.sin( x );\n\t\tvar c = Math.cos( y ), d = Math.sin( y );\n\t\tvar e = Math.cos( z ), f = Math.sin( z );\n\n\t\tif ( euler.order === 'XYZ' ) {\n\n\t\t\tvar ae = a * e, af = a * f, be = b * e, bf = b * f;\n\n\t\t\tte[ 0 ] = c * e;\n\t\t\tte[ 4 ] = - c * f;\n\t\t\tte[ 8 ] = d;\n\n\t\t\tte[ 1 ] = af + be * d;\n\t\t\tte[ 5 ] = ae - bf * d;\n\t\t\tte[ 9 ] = - b * c;\n\n\t\t\tte[ 2 ] = bf - ae * d;\n\t\t\tte[ 6 ] = be + af * d;\n\t\t\tte[ 10 ] = a * c;\n\n\t\t} else if ( euler.order === 'YXZ' ) {\n\n\t\t\tvar ce = c * e, cf = c * f, de = d * e, df = d * f;\n\n\t\t\tte[ 0 ] = ce + df * b;\n\t\t\tte[ 4 ] = de * b - cf;\n\t\t\tte[ 8 ] = a * d;\n\n\t\t\tte[ 1 ] = a * f;\n\t\t\tte[ 5 ] = a * e;\n\t\t\tte[ 9 ] = - b;\n\n\t\t\tte[ 2 ] = cf * b - de;\n\t\t\tte[ 6 ] = df + ce * b;\n\t\t\tte[ 10 ] = a * c;\n\n\t\t} else if ( euler.order === 'ZXY' ) {\n\n\t\t\tvar ce = c * e, cf = c * f, de = d * e, df = d * f;\n\n\t\t\tte[ 0 ] = ce - df * b;\n\t\t\tte[ 4 ] = - a * f;\n\t\t\tte[ 8 ] = de + cf * b;\n\n\t\t\tte[ 1 ] = cf + de * b;\n\t\t\tte[ 5 ] = a * e;\n\t\t\tte[ 9 ] = df - ce * b;\n\n\t\t\tte[ 2 ] = - a * d;\n\t\t\tte[ 6 ] = b;\n\t\t\tte[ 10 ] = a * c;\n\n\t\t} else if ( euler.order === 'ZYX' ) {\n\n\t\t\tvar ae = a * e, af = a * f, be = b * e, bf = b * f;\n\n\t\t\tte[ 0 ] = c * e;\n\t\t\tte[ 4 ] = be * d - af;\n\t\t\tte[ 8 ] = ae * d + bf;\n\n\t\t\tte[ 1 ] = c * f;\n\t\t\tte[ 5 ] = bf * d + ae;\n\t\t\tte[ 9 ] = af * d - be;\n\n\t\t\tte[ 2 ] = - d;\n\t\t\tte[ 6 ] = b * c;\n\t\t\tte[ 10 ] = a * c;\n\n\t\t} else if ( euler.order === 'YZX' ) {\n\n\t\t\tvar ac = a * c, ad = a * d, bc = b * c, bd = b * d;\n\n\t\t\tte[ 0 ] = c * e;\n\t\t\tte[ 4 ] = bd - ac * f;\n\t\t\tte[ 8 ] = bc * f + ad;\n\n\t\t\tte[ 1 ] = f;\n\t\t\tte[ 5 ] = a * e;\n\t\t\tte[ 9 ] = - b * e;\n\n\t\t\tte[ 2 ] = - d * e;\n\t\t\tte[ 6 ] = ad * f + bc;\n\t\t\tte[ 10 ] = ac - bd * f;\n\n\t\t} else if ( euler.order === 'XZY' ) {\n\n\t\t\tvar ac = a * c, ad = a * d, bc = b * c, bd = b * d;\n\n\t\t\tte[ 0 ] = c * e;\n\t\t\tte[ 4 ] = - f;\n\t\t\tte[ 8 ] = d * e;\n\n\t\t\tte[ 1 ] = ac * f + bd;\n\t\t\tte[ 5 ] = a * e;\n\t\t\tte[ 9 ] = ad * f - bc;\n\n\t\t\tte[ 2 ] = bc * f - ad;\n\t\t\tte[ 6 ] = b * e;\n\t\t\tte[ 10 ] = bd * f + ac;\n\n\t\t}\n\n\t\t// last column\n\t\tte[ 3 ] = 0;\n\t\tte[ 7 ] = 0;\n\t\tte[ 11 ] = 0;\n\n\t\t// bottom row\n\t\tte[ 12 ] = 0;\n\t\tte[ 13 ] = 0;\n\t\tte[ 14 ] = 0;\n\t\tte[ 15 ] = 1;\n\n\t\treturn this;\n\n\t},\n\n\tmakeRotationFromQuaternion: function ( q ) {\n\n\t\tvar te = this.elements;\n\n\t\tvar x = q._x, y = q._y, z = q._z, w = q._w;\n\t\tvar x2 = x + x, y2 = y + y, z2 = z + z;\n\t\tvar xx = x * x2, xy = x * y2, xz = x * z2;\n\t\tvar yy = y * y2, yz = y * z2, zz = z * z2;\n\t\tvar wx = w * x2, wy = w * y2, wz = w * z2;\n\n\t\tte[ 0 ] = 1 - ( yy + zz );\n\t\tte[ 4 ] = xy - wz;\n\t\tte[ 8 ] = xz + wy;\n\n\t\tte[ 1 ] = xy + wz;\n\t\tte[ 5 ] = 1 - ( xx + zz );\n\t\tte[ 9 ] = yz - wx;\n\n\t\tte[ 2 ] = xz - wy;\n\t\tte[ 6 ] = yz + wx;\n\t\tte[ 10 ] = 1 - ( xx + yy );\n\n\t\t// last column\n\t\tte[ 3 ] = 0;\n\t\tte[ 7 ] = 0;\n\t\tte[ 11 ] = 0;\n\n\t\t// bottom row\n\t\tte[ 12 ] = 0;\n\t\tte[ 13 ] = 0;\n\t\tte[ 14 ] = 0;\n\t\tte[ 15 ] = 1;\n\n\t\treturn this;\n\n\t},\n\n\tlookAt: function () {\n\n\t\tvar x = new Vector3();\n\t\tvar y = new Vector3();\n\t\tvar z = new Vector3();\n\n\t\treturn function lookAt( eye, target, up ) {\n\n\t\t\tvar te = this.elements;\n\n\t\t\tz.subVectors( eye, target );\n\n\t\t\tif ( z.lengthSq() === 0 ) {\n\n\t\t\t\t// eye and target are in the same position\n\n\t\t\t\tz.z = 1;\n\n\t\t\t}\n\n\t\t\tz.normalize();\n\t\t\tx.crossVectors( up, z );\n\n\t\t\tif ( x.lengthSq() === 0 ) {\n\n\t\t\t\t// up and z are parallel\n\n\t\t\t\tif ( Math.abs( up.z ) === 1 ) {\n\n\t\t\t\t\tz.x += 0.0001;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tz.z += 0.0001;\n\n\t\t\t\t}\n\n\t\t\t\tz.normalize();\n\t\t\t\tx.crossVectors( up, z );\n\n\t\t\t}\n\n\t\t\tx.normalize();\n\t\t\ty.crossVectors( z, x );\n\n\t\t\tte[ 0 ] = x.x; te[ 4 ] = y.x; te[ 8 ] = z.x;\n\t\t\tte[ 1 ] = x.y; te[ 5 ] = y.y; te[ 9 ] = z.y;\n\t\t\tte[ 2 ] = x.z; te[ 6 ] = y.z; te[ 10 ] = z.z;\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tmultiply: function ( m, n ) {\n\n\t\tif ( n !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead.' );\n\t\t\treturn this.multiplyMatrices( m, n );\n\n\t\t}\n\n\t\treturn this.multiplyMatrices( this, m );\n\n\t},\n\n\tpremultiply: function ( m ) {\n\n\t\treturn this.multiplyMatrices( m, this );\n\n\t},\n\n\tmultiplyMatrices: function ( a, b ) {\n\n\t\tvar ae = a.elements;\n\t\tvar be = b.elements;\n\t\tvar te = this.elements;\n\n\t\tvar a11 = ae[ 0 ], a12 = ae[ 4 ], a13 = ae[ 8 ], a14 = ae[ 12 ];\n\t\tvar a21 = ae[ 1 ], a22 = ae[ 5 ], a23 = ae[ 9 ], a24 = ae[ 13 ];\n\t\tvar a31 = ae[ 2 ], a32 = ae[ 6 ], a33 = ae[ 10 ], a34 = ae[ 14 ];\n\t\tvar a41 = ae[ 3 ], a42 = ae[ 7 ], a43 = ae[ 11 ], a44 = ae[ 15 ];\n\n\t\tvar b11 = be[ 0 ], b12 = be[ 4 ], b13 = be[ 8 ], b14 = be[ 12 ];\n\t\tvar b21 = be[ 1 ], b22 = be[ 5 ], b23 = be[ 9 ], b24 = be[ 13 ];\n\t\tvar b31 = be[ 2 ], b32 = be[ 6 ], b33 = be[ 10 ], b34 = be[ 14 ];\n\t\tvar b41 = be[ 3 ], b42 = be[ 7 ], b43 = be[ 11 ], b44 = be[ 15 ];\n\n\t\tte[ 0 ] = a11 * b11 + a12 * b21 + a13 * b31 + a14 * b41;\n\t\tte[ 4 ] = a11 * b12 + a12 * b22 + a13 * b32 + a14 * b42;\n\t\tte[ 8 ] = a11 * b13 + a12 * b23 + a13 * b33 + a14 * b43;\n\t\tte[ 12 ] = a11 * b14 + a12 * b24 + a13 * b34 + a14 * b44;\n\n\t\tte[ 1 ] = a21 * b11 + a22 * b21 + a23 * b31 + a24 * b41;\n\t\tte[ 5 ] = a21 * b12 + a22 * b22 + a23 * b32 + a24 * b42;\n\t\tte[ 9 ] = a21 * b13 + a22 * b23 + a23 * b33 + a24 * b43;\n\t\tte[ 13 ] = a21 * b14 + a22 * b24 + a23 * b34 + a24 * b44;\n\n\t\tte[ 2 ] = a31 * b11 + a32 * b21 + a33 * b31 + a34 * b41;\n\t\tte[ 6 ] = a31 * b12 + a32 * b22 + a33 * b32 + a34 * b42;\n\t\tte[ 10 ] = a31 * b13 + a32 * b23 + a33 * b33 + a34 * b43;\n\t\tte[ 14 ] = a31 * b14 + a32 * b24 + a33 * b34 + a34 * b44;\n\n\t\tte[ 3 ] = a41 * b11 + a42 * b21 + a43 * b31 + a44 * b41;\n\t\tte[ 7 ] = a41 * b12 + a42 * b22 + a43 * b32 + a44 * b42;\n\t\tte[ 11 ] = a41 * b13 + a42 * b23 + a43 * b33 + a44 * b43;\n\t\tte[ 15 ] = a41 * b14 + a42 * b24 + a43 * b34 + a44 * b44;\n\n\t\treturn this;\n\n\t},\n\n\tmultiplyScalar: function ( s ) {\n\n\t\tvar te = this.elements;\n\n\t\tte[ 0 ] *= s; te[ 4 ] *= s; te[ 8 ] *= s; te[ 12 ] *= s;\n\t\tte[ 1 ] *= s; te[ 5 ] *= s; te[ 9 ] *= s; te[ 13 ] *= s;\n\t\tte[ 2 ] *= s; te[ 6 ] *= s; te[ 10 ] *= s; te[ 14 ] *= s;\n\t\tte[ 3 ] *= s; te[ 7 ] *= s; te[ 11 ] *= s; te[ 15 ] *= s;\n\n\t\treturn this;\n\n\t},\n\n\tapplyToBufferAttribute: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function applyToBufferAttribute( attribute ) {\n\n\t\t\tfor ( var i = 0, l = attribute.count; i < l; i ++ ) {\n\n\t\t\t\tv1.x = attribute.getX( i );\n\t\t\t\tv1.y = attribute.getY( i );\n\t\t\t\tv1.z = attribute.getZ( i );\n\n\t\t\t\tv1.applyMatrix4( this );\n\n\t\t\t\tattribute.setXYZ( i, v1.x, v1.y, v1.z );\n\n\t\t\t}\n\n\t\t\treturn attribute;\n\n\t\t};\n\n\t}(),\n\n\tdeterminant: function () {\n\n\t\tvar te = this.elements;\n\n\t\tvar n11 = te[ 0 ], n12 = te[ 4 ], n13 = te[ 8 ], n14 = te[ 12 ];\n\t\tvar n21 = te[ 1 ], n22 = te[ 5 ], n23 = te[ 9 ], n24 = te[ 13 ];\n\t\tvar n31 = te[ 2 ], n32 = te[ 6 ], n33 = te[ 10 ], n34 = te[ 14 ];\n\t\tvar n41 = te[ 3 ], n42 = te[ 7 ], n43 = te[ 11 ], n44 = te[ 15 ];\n\n\t\t//TODO: make this more efficient\n\t\t//( based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm )\n\n\t\treturn (\n\t\t\tn41 * (\n\t\t\t\t+ n14 * n23 * n32\n\t\t\t\t - n13 * n24 * n32\n\t\t\t\t - n14 * n22 * n33\n\t\t\t\t + n12 * n24 * n33\n\t\t\t\t + n13 * n22 * n34\n\t\t\t\t - n12 * n23 * n34\n\t\t\t) +\n\t\t\tn42 * (\n\t\t\t\t+ n11 * n23 * n34\n\t\t\t\t - n11 * n24 * n33\n\t\t\t\t + n14 * n21 * n33\n\t\t\t\t - n13 * n21 * n34\n\t\t\t\t + n13 * n24 * n31\n\t\t\t\t - n14 * n23 * n31\n\t\t\t) +\n\t\t\tn43 * (\n\t\t\t\t+ n11 * n24 * n32\n\t\t\t\t - n11 * n22 * n34\n\t\t\t\t - n14 * n21 * n32\n\t\t\t\t + n12 * n21 * n34\n\t\t\t\t + n14 * n22 * n31\n\t\t\t\t - n12 * n24 * n31\n\t\t\t) +\n\t\t\tn44 * (\n\t\t\t\t- n13 * n22 * n31\n\t\t\t\t - n11 * n23 * n32\n\t\t\t\t + n11 * n22 * n33\n\t\t\t\t + n13 * n21 * n32\n\t\t\t\t - n12 * n21 * n33\n\t\t\t\t + n12 * n23 * n31\n\t\t\t)\n\n\t\t);\n\n\t},\n\n\ttranspose: function () {\n\n\t\tvar te = this.elements;\n\t\tvar tmp;\n\n\t\ttmp = te[ 1 ]; te[ 1 ] = te[ 4 ]; te[ 4 ] = tmp;\n\t\ttmp = te[ 2 ]; te[ 2 ] = te[ 8 ]; te[ 8 ] = tmp;\n\t\ttmp = te[ 6 ]; te[ 6 ] = te[ 9 ]; te[ 9 ] = tmp;\n\n\t\ttmp = te[ 3 ]; te[ 3 ] = te[ 12 ]; te[ 12 ] = tmp;\n\t\ttmp = te[ 7 ]; te[ 7 ] = te[ 13 ]; te[ 13 ] = tmp;\n\t\ttmp = te[ 11 ]; te[ 11 ] = te[ 14 ]; te[ 14 ] = tmp;\n\n\t\treturn this;\n\n\t},\n\n\tsetPosition: function ( v ) {\n\n\t\tvar te = this.elements;\n\n\t\tte[ 12 ] = v.x;\n\t\tte[ 13 ] = v.y;\n\t\tte[ 14 ] = v.z;\n\n\t\treturn this;\n\n\t},\n\n\tgetInverse: function ( m, throwOnDegenerate ) {\n\n\t\t// based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm\n\t\tvar te = this.elements,\n\t\t\tme = m.elements,\n\n\t\t\tn11 = me[ 0 ], n21 = me[ 1 ], n31 = me[ 2 ], n41 = me[ 3 ],\n\t\t\tn12 = me[ 4 ], n22 = me[ 5 ], n32 = me[ 6 ], n42 = me[ 7 ],\n\t\t\tn13 = me[ 8 ], n23 = me[ 9 ], n33 = me[ 10 ], n43 = me[ 11 ],\n\t\t\tn14 = me[ 12 ], n24 = me[ 13 ], n34 = me[ 14 ], n44 = me[ 15 ],\n\n\t\t\tt11 = n23 * n34 * n42 - n24 * n33 * n42 + n24 * n32 * n43 - n22 * n34 * n43 - n23 * n32 * n44 + n22 * n33 * n44,\n\t\t\tt12 = n14 * n33 * n42 - n13 * n34 * n42 - n14 * n32 * n43 + n12 * n34 * n43 + n13 * n32 * n44 - n12 * n33 * n44,\n\t\t\tt13 = n13 * n24 * n42 - n14 * n23 * n42 + n14 * n22 * n43 - n12 * n24 * n43 - n13 * n22 * n44 + n12 * n23 * n44,\n\t\t\tt14 = n14 * n23 * n32 - n13 * n24 * n32 - n14 * n22 * n33 + n12 * n24 * n33 + n13 * n22 * n34 - n12 * n23 * n34;\n\n\t\tvar det = n11 * t11 + n21 * t12 + n31 * t13 + n41 * t14;\n\n\t\tif ( det === 0 ) {\n\n\t\t\tvar msg = \"THREE.Matrix4: .getInverse() can't invert matrix, determinant is 0\";\n\n\t\t\tif ( throwOnDegenerate === true ) {\n\n\t\t\t\tthrow new Error( msg );\n\n\t\t\t} else {\n\n\t\t\t\tconsole.warn( msg );\n\n\t\t\t}\n\n\t\t\treturn this.identity();\n\n\t\t}\n\n\t\tvar detInv = 1 / det;\n\n\t\tte[ 0 ] = t11 * detInv;\n\t\tte[ 1 ] = ( n24 * n33 * n41 - n23 * n34 * n41 - n24 * n31 * n43 + n21 * n34 * n43 + n23 * n31 * n44 - n21 * n33 * n44 ) * detInv;\n\t\tte[ 2 ] = ( n22 * n34 * n41 - n24 * n32 * n41 + n24 * n31 * n42 - n21 * n34 * n42 - n22 * n31 * n44 + n21 * n32 * n44 ) * detInv;\n\t\tte[ 3 ] = ( n23 * n32 * n41 - n22 * n33 * n41 - n23 * n31 * n42 + n21 * n33 * n42 + n22 * n31 * n43 - n21 * n32 * n43 ) * detInv;\n\n\t\tte[ 4 ] = t12 * detInv;\n\t\tte[ 5 ] = ( n13 * n34 * n41 - n14 * n33 * n41 + n14 * n31 * n43 - n11 * n34 * n43 - n13 * n31 * n44 + n11 * n33 * n44 ) * detInv;\n\t\tte[ 6 ] = ( n14 * n32 * n41 - n12 * n34 * n41 - n14 * n31 * n42 + n11 * n34 * n42 + n12 * n31 * n44 - n11 * n32 * n44 ) * detInv;\n\t\tte[ 7 ] = ( n12 * n33 * n41 - n13 * n32 * n41 + n13 * n31 * n42 - n11 * n33 * n42 - n12 * n31 * n43 + n11 * n32 * n43 ) * detInv;\n\n\t\tte[ 8 ] = t13 * detInv;\n\t\tte[ 9 ] = ( n14 * n23 * n41 - n13 * n24 * n41 - n14 * n21 * n43 + n11 * n24 * n43 + n13 * n21 * n44 - n11 * n23 * n44 ) * detInv;\n\t\tte[ 10 ] = ( n12 * n24 * n41 - n14 * n22 * n41 + n14 * n21 * n42 - n11 * n24 * n42 - n12 * n21 * n44 + n11 * n22 * n44 ) * detInv;\n\t\tte[ 11 ] = ( n13 * n22 * n41 - n12 * n23 * n41 - n13 * n21 * n42 + n11 * n23 * n42 + n12 * n21 * n43 - n11 * n22 * n43 ) * detInv;\n\n\t\tte[ 12 ] = t14 * detInv;\n\t\tte[ 13 ] = ( n13 * n24 * n31 - n14 * n23 * n31 + n14 * n21 * n33 - n11 * n24 * n33 - n13 * n21 * n34 + n11 * n23 * n34 ) * detInv;\n\t\tte[ 14 ] = ( n14 * n22 * n31 - n12 * n24 * n31 - n14 * n21 * n32 + n11 * n24 * n32 + n12 * n21 * n34 - n11 * n22 * n34 ) * detInv;\n\t\tte[ 15 ] = ( n12 * n23 * n31 - n13 * n22 * n31 + n13 * n21 * n32 - n11 * n23 * n32 - n12 * n21 * n33 + n11 * n22 * n33 ) * detInv;\n\n\t\treturn this;\n\n\t},\n\n\tscale: function ( v ) {\n\n\t\tvar te = this.elements;\n\t\tvar x = v.x, y = v.y, z = v.z;\n\n\t\tte[ 0 ] *= x; te[ 4 ] *= y; te[ 8 ] *= z;\n\t\tte[ 1 ] *= x; te[ 5 ] *= y; te[ 9 ] *= z;\n\t\tte[ 2 ] *= x; te[ 6 ] *= y; te[ 10 ] *= z;\n\t\tte[ 3 ] *= x; te[ 7 ] *= y; te[ 11 ] *= z;\n\n\t\treturn this;\n\n\t},\n\n\tgetMaxScaleOnAxis: function () {\n\n\t\tvar te = this.elements;\n\n\t\tvar scaleXSq = te[ 0 ] * te[ 0 ] + te[ 1 ] * te[ 1 ] + te[ 2 ] * te[ 2 ];\n\t\tvar scaleYSq = te[ 4 ] * te[ 4 ] + te[ 5 ] * te[ 5 ] + te[ 6 ] * te[ 6 ];\n\t\tvar scaleZSq = te[ 8 ] * te[ 8 ] + te[ 9 ] * te[ 9 ] + te[ 10 ] * te[ 10 ];\n\n\t\treturn Math.sqrt( Math.max( scaleXSq, scaleYSq, scaleZSq ) );\n\n\t},\n\n\tmakeTranslation: function ( x, y, z ) {\n\n\t\tthis.set(\n\n\t\t\t1, 0, 0, x,\n\t\t\t0, 1, 0, y,\n\t\t\t0, 0, 1, z,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\tmakeRotationX: function ( theta ) {\n\n\t\tvar c = Math.cos( theta ), s = Math.sin( theta );\n\n\t\tthis.set(\n\n\t\t\t1, 0, 0, 0,\n\t\t\t0, c, - s, 0,\n\t\t\t0, s, c, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\tmakeRotationY: function ( theta ) {\n\n\t\tvar c = Math.cos( theta ), s = Math.sin( theta );\n\n\t\tthis.set(\n\n\t\t\t c, 0, s, 0,\n\t\t\t 0, 1, 0, 0,\n\t\t\t- s, 0, c, 0,\n\t\t\t 0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\tmakeRotationZ: function ( theta ) {\n\n\t\tvar c = Math.cos( theta ), s = Math.sin( theta );\n\n\t\tthis.set(\n\n\t\t\tc, - s, 0, 0,\n\t\t\ts, c, 0, 0,\n\t\t\t0, 0, 1, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\tmakeRotationAxis: function ( axis, angle ) {\n\n\t\t// Based on http://www.gamedev.net/reference/articles/article1199.asp\n\n\t\tvar c = Math.cos( angle );\n\t\tvar s = Math.sin( angle );\n\t\tvar t = 1 - c;\n\t\tvar x = axis.x, y = axis.y, z = axis.z;\n\t\tvar tx = t * x, ty = t * y;\n\n\t\tthis.set(\n\n\t\t\ttx * x + c, tx * y - s * z, tx * z + s * y, 0,\n\t\t\ttx * y + s * z, ty * y + c, ty * z - s * x, 0,\n\t\t\ttx * z - s * y, ty * z + s * x, t * z * z + c, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\t return this;\n\n\t},\n\n\tmakeScale: function ( x, y, z ) {\n\n\t\tthis.set(\n\n\t\t\tx, 0, 0, 0,\n\t\t\t0, y, 0, 0,\n\t\t\t0, 0, z, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\tmakeShear: function ( x, y, z ) {\n\n\t\tthis.set(\n\n\t\t\t1, y, z, 0,\n\t\t\tx, 1, z, 0,\n\t\t\tx, y, 1, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\tcompose: function ( position, quaternion, scale ) {\n\n\t\tthis.makeRotationFromQuaternion( quaternion );\n\t\tthis.scale( scale );\n\t\tthis.setPosition( position );\n\n\t\treturn this;\n\n\t},\n\n\tdecompose: function () {\n\n\t\tvar vector = new Vector3();\n\t\tvar matrix = new Matrix4();\n\n\t\treturn function decompose( position, quaternion, scale ) {\n\n\t\t\tvar te = this.elements;\n\n\t\t\tvar sx = vector.set( te[ 0 ], te[ 1 ], te[ 2 ] ).length();\n\t\t\tvar sy = vector.set( te[ 4 ], te[ 5 ], te[ 6 ] ).length();\n\t\t\tvar sz = vector.set( te[ 8 ], te[ 9 ], te[ 10 ] ).length();\n\n\t\t\t// if determine is negative, we need to invert one scale\n\t\t\tvar det = this.determinant();\n\t\t\tif ( det < 0 ) sx = - sx;\n\n\t\t\tposition.x = te[ 12 ];\n\t\t\tposition.y = te[ 13 ];\n\t\t\tposition.z = te[ 14 ];\n\n\t\t\t// scale the rotation part\n\t\t\tmatrix.copy( this );\n\n\t\t\tvar invSX = 1 / sx;\n\t\t\tvar invSY = 1 / sy;\n\t\t\tvar invSZ = 1 / sz;\n\n\t\t\tmatrix.elements[ 0 ] *= invSX;\n\t\t\tmatrix.elements[ 1 ] *= invSX;\n\t\t\tmatrix.elements[ 2 ] *= invSX;\n\n\t\t\tmatrix.elements[ 4 ] *= invSY;\n\t\t\tmatrix.elements[ 5 ] *= invSY;\n\t\t\tmatrix.elements[ 6 ] *= invSY;\n\n\t\t\tmatrix.elements[ 8 ] *= invSZ;\n\t\t\tmatrix.elements[ 9 ] *= invSZ;\n\t\t\tmatrix.elements[ 10 ] *= invSZ;\n\n\t\t\tquaternion.setFromRotationMatrix( matrix );\n\n\t\t\tscale.x = sx;\n\t\t\tscale.y = sy;\n\t\t\tscale.z = sz;\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tmakePerspective: function ( left, right, top, bottom, near, far ) {\n\n\t\tif ( far === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.' );\n\n\t\t}\n\n\t\tvar te = this.elements;\n\t\tvar x = 2 * near / ( right - left );\n\t\tvar y = 2 * near / ( top - bottom );\n\n\t\tvar a = ( right + left ) / ( right - left );\n\t\tvar b = ( top + bottom ) / ( top - bottom );\n\t\tvar c = - ( far + near ) / ( far - near );\n\t\tvar d = - 2 * far * near / ( far - near );\n\n\t\tte[ 0 ] = x;\tte[ 4 ] = 0;\tte[ 8 ] = a;\tte[ 12 ] = 0;\n\t\tte[ 1 ] = 0;\tte[ 5 ] = y;\tte[ 9 ] = b;\tte[ 13 ] = 0;\n\t\tte[ 2 ] = 0;\tte[ 6 ] = 0;\tte[ 10 ] = c;\tte[ 14 ] = d;\n\t\tte[ 3 ] = 0;\tte[ 7 ] = 0;\tte[ 11 ] = - 1;\tte[ 15 ] = 0;\n\n\t\treturn this;\n\n\t},\n\n\tmakeOrthographic: function ( left, right, top, bottom, near, far ) {\n\n\t\tvar te = this.elements;\n\t\tvar w = 1.0 / ( right - left );\n\t\tvar h = 1.0 / ( top - bottom );\n\t\tvar p = 1.0 / ( far - near );\n\n\t\tvar x = ( right + left ) * w;\n\t\tvar y = ( top + bottom ) * h;\n\t\tvar z = ( far + near ) * p;\n\n\t\tte[ 0 ] = 2 * w;\tte[ 4 ] = 0;\tte[ 8 ] = 0;\tte[ 12 ] = - x;\n\t\tte[ 1 ] = 0;\tte[ 5 ] = 2 * h;\tte[ 9 ] = 0;\tte[ 13 ] = - y;\n\t\tte[ 2 ] = 0;\tte[ 6 ] = 0;\tte[ 10 ] = - 2 * p;\tte[ 14 ] = - z;\n\t\tte[ 3 ] = 0;\tte[ 7 ] = 0;\tte[ 11 ] = 0;\tte[ 15 ] = 1;\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( matrix ) {\n\n\t\tvar te = this.elements;\n\t\tvar me = matrix.elements;\n\n\t\tfor ( var i = 0; i < 16; i ++ ) {\n\n\t\t\tif ( te[ i ] !== me[ i ] ) return false;\n\n\t\t}\n\n\t\treturn true;\n\n\t},\n\n\tfromArray: function ( array, offset ) {\n\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tfor ( var i = 0; i < 16; i ++ ) {\n\n\t\t\tthis.elements[ i ] = array[ i + offset ];\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\ttoArray: function ( array, offset ) {\n\n\t\tif ( array === undefined ) array = [];\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tvar te = this.elements;\n\n\t\tarray[ offset ] = te[ 0 ];\n\t\tarray[ offset + 1 ] = te[ 1 ];\n\t\tarray[ offset + 2 ] = te[ 2 ];\n\t\tarray[ offset + 3 ] = te[ 3 ];\n\n\t\tarray[ offset + 4 ] = te[ 4 ];\n\t\tarray[ offset + 5 ] = te[ 5 ];\n\t\tarray[ offset + 6 ] = te[ 6 ];\n\t\tarray[ offset + 7 ] = te[ 7 ];\n\n\t\tarray[ offset + 8 ] = te[ 8 ];\n\t\tarray[ offset + 9 ] = te[ 9 ];\n\t\tarray[ offset + 10 ] = te[ 10 ];\n\t\tarray[ offset + 11 ] = te[ 11 ];\n\n\t\tarray[ offset + 12 ] = te[ 12 ];\n\t\tarray[ offset + 13 ] = te[ 13 ];\n\t\tarray[ offset + 14 ] = te[ 14 ];\n\t\tarray[ offset + 15 ] = te[ 15 ];\n\n\t\treturn array;\n\n\t}\n\n} );\n\n/**\n * @author mikael emtinger / http://gomo.se/\n * @author alteredq / http://alteredqualia.com/\n * @author WestLangley / http://github.com/WestLangley\n * @author bhouston / http://clara.io\n */\n\nfunction Quaternion( x, y, z, w ) {\n\n\tthis._x = x || 0;\n\tthis._y = y || 0;\n\tthis._z = z || 0;\n\tthis._w = ( w !== undefined ) ? w : 1;\n\n}\n\nObject.assign( Quaternion, {\n\n\tslerp: function ( qa, qb, qm, t ) {\n\n\t\treturn qm.copy( qa ).slerp( qb, t );\n\n\t},\n\n\tslerpFlat: function ( dst, dstOffset, src0, srcOffset0, src1, srcOffset1, t ) {\n\n\t\t// fuzz-free, array-based Quaternion SLERP operation\n\n\t\tvar x0 = src0[ srcOffset0 + 0 ],\n\t\t\ty0 = src0[ srcOffset0 + 1 ],\n\t\t\tz0 = src0[ srcOffset0 + 2 ],\n\t\t\tw0 = src0[ srcOffset0 + 3 ],\n\n\t\t\tx1 = src1[ srcOffset1 + 0 ],\n\t\t\ty1 = src1[ srcOffset1 + 1 ],\n\t\t\tz1 = src1[ srcOffset1 + 2 ],\n\t\t\tw1 = src1[ srcOffset1 + 3 ];\n\n\t\tif ( w0 !== w1 || x0 !== x1 || y0 !== y1 || z0 !== z1 ) {\n\n\t\t\tvar s = 1 - t,\n\n\t\t\t\tcos = x0 * x1 + y0 * y1 + z0 * z1 + w0 * w1,\n\n\t\t\t\tdir = ( cos >= 0 ? 1 : - 1 ),\n\t\t\t\tsqrSin = 1 - cos * cos;\n\n\t\t\t// Skip the Slerp for tiny steps to avoid numeric problems:\n\t\t\tif ( sqrSin > Number.EPSILON ) {\n\n\t\t\t\tvar sin = Math.sqrt( sqrSin ),\n\t\t\t\t\tlen = Math.atan2( sin, cos * dir );\n\n\t\t\t\ts = Math.sin( s * len ) / sin;\n\t\t\t\tt = Math.sin( t * len ) / sin;\n\n\t\t\t}\n\n\t\t\tvar tDir = t * dir;\n\n\t\t\tx0 = x0 * s + x1 * tDir;\n\t\t\ty0 = y0 * s + y1 * tDir;\n\t\t\tz0 = z0 * s + z1 * tDir;\n\t\t\tw0 = w0 * s + w1 * tDir;\n\n\t\t\t// Normalize in case we just did a lerp:\n\t\t\tif ( s === 1 - t ) {\n\n\t\t\t\tvar f = 1 / Math.sqrt( x0 * x0 + y0 * y0 + z0 * z0 + w0 * w0 );\n\n\t\t\t\tx0 *= f;\n\t\t\t\ty0 *= f;\n\t\t\t\tz0 *= f;\n\t\t\t\tw0 *= f;\n\n\t\t\t}\n\n\t\t}\n\n\t\tdst[ dstOffset ] = x0;\n\t\tdst[ dstOffset + 1 ] = y0;\n\t\tdst[ dstOffset + 2 ] = z0;\n\t\tdst[ dstOffset + 3 ] = w0;\n\n\t}\n\n} );\n\nObject.defineProperties( Quaternion.prototype, {\n\n\tx: {\n\n\t\tget: function () {\n\n\t\t\treturn this._x;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis._x = value;\n\t\t\tthis.onChangeCallback();\n\n\t\t}\n\n\t},\n\n\ty: {\n\n\t\tget: function () {\n\n\t\t\treturn this._y;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis._y = value;\n\t\t\tthis.onChangeCallback();\n\n\t\t}\n\n\t},\n\n\tz: {\n\n\t\tget: function () {\n\n\t\t\treturn this._z;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis._z = value;\n\t\t\tthis.onChangeCallback();\n\n\t\t}\n\n\t},\n\n\tw: {\n\n\t\tget: function () {\n\n\t\t\treturn this._w;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis._w = value;\n\t\t\tthis.onChangeCallback();\n\n\t\t}\n\n\t}\n\n} );\n\nObject.assign( Quaternion.prototype, {\n\n\tset: function ( x, y, z, w ) {\n\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._w = w;\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this._x, this._y, this._z, this._w );\n\n\t},\n\n\tcopy: function ( quaternion ) {\n\n\t\tthis._x = quaternion.x;\n\t\tthis._y = quaternion.y;\n\t\tthis._z = quaternion.z;\n\t\tthis._w = quaternion.w;\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tsetFromEuler: function ( euler, update ) {\n\n\t\tif ( ! ( euler && euler.isEuler ) ) {\n\n\t\t\tthrow new Error( 'THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.' );\n\n\t\t}\n\n\t\tvar x = euler._x, y = euler._y, z = euler._z, order = euler.order;\n\n\t\t// http://www.mathworks.com/matlabcentral/fileexchange/\n\t\t// \t20696-function-to-convert-between-dcm-euler-angles-quaternions-and-euler-vectors/\n\t\t//\tcontent/SpinCalc.m\n\n\t\tvar cos = Math.cos;\n\t\tvar sin = Math.sin;\n\n\t\tvar c1 = cos( x / 2 );\n\t\tvar c2 = cos( y / 2 );\n\t\tvar c3 = cos( z / 2 );\n\n\t\tvar s1 = sin( x / 2 );\n\t\tvar s2 = sin( y / 2 );\n\t\tvar s3 = sin( z / 2 );\n\n\t\tif ( order === 'XYZ' ) {\n\n\t\t\tthis._x = s1 * c2 * c3 + c1 * s2 * s3;\n\t\t\tthis._y = c1 * s2 * c3 - s1 * c2 * s3;\n\t\t\tthis._z = c1 * c2 * s3 + s1 * s2 * c3;\n\t\t\tthis._w = c1 * c2 * c3 - s1 * s2 * s3;\n\n\t\t} else if ( order === 'YXZ' ) {\n\n\t\t\tthis._x = s1 * c2 * c3 + c1 * s2 * s3;\n\t\t\tthis._y = c1 * s2 * c3 - s1 * c2 * s3;\n\t\t\tthis._z = c1 * c2 * s3 - s1 * s2 * c3;\n\t\t\tthis._w = c1 * c2 * c3 + s1 * s2 * s3;\n\n\t\t} else if ( order === 'ZXY' ) {\n\n\t\t\tthis._x = s1 * c2 * c3 - c1 * s2 * s3;\n\t\t\tthis._y = c1 * s2 * c3 + s1 * c2 * s3;\n\t\t\tthis._z = c1 * c2 * s3 + s1 * s2 * c3;\n\t\t\tthis._w = c1 * c2 * c3 - s1 * s2 * s3;\n\n\t\t} else if ( order === 'ZYX' ) {\n\n\t\t\tthis._x = s1 * c2 * c3 - c1 * s2 * s3;\n\t\t\tthis._y = c1 * s2 * c3 + s1 * c2 * s3;\n\t\t\tthis._z = c1 * c2 * s3 - s1 * s2 * c3;\n\t\t\tthis._w = c1 * c2 * c3 + s1 * s2 * s3;\n\n\t\t} else if ( order === 'YZX' ) {\n\n\t\t\tthis._x = s1 * c2 * c3 + c1 * s2 * s3;\n\t\t\tthis._y = c1 * s2 * c3 + s1 * c2 * s3;\n\t\t\tthis._z = c1 * c2 * s3 - s1 * s2 * c3;\n\t\t\tthis._w = c1 * c2 * c3 - s1 * s2 * s3;\n\n\t\t} else if ( order === 'XZY' ) {\n\n\t\t\tthis._x = s1 * c2 * c3 - c1 * s2 * s3;\n\t\t\tthis._y = c1 * s2 * c3 - s1 * c2 * s3;\n\t\t\tthis._z = c1 * c2 * s3 + s1 * s2 * c3;\n\t\t\tthis._w = c1 * c2 * c3 + s1 * s2 * s3;\n\n\t\t}\n\n\t\tif ( update !== false ) this.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tsetFromAxisAngle: function ( axis, angle ) {\n\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/angleToQuaternion/index.htm\n\n\t\t// assumes axis is normalized\n\n\t\tvar halfAngle = angle / 2, s = Math.sin( halfAngle );\n\n\t\tthis._x = axis.x * s;\n\t\tthis._y = axis.y * s;\n\t\tthis._z = axis.z * s;\n\t\tthis._w = Math.cos( halfAngle );\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tsetFromRotationMatrix: function ( m ) {\n\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToQuaternion/index.htm\n\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\n\t\tvar te = m.elements,\n\n\t\t\tm11 = te[ 0 ], m12 = te[ 4 ], m13 = te[ 8 ],\n\t\t\tm21 = te[ 1 ], m22 = te[ 5 ], m23 = te[ 9 ],\n\t\t\tm31 = te[ 2 ], m32 = te[ 6 ], m33 = te[ 10 ],\n\n\t\t\ttrace = m11 + m22 + m33,\n\t\t\ts;\n\n\t\tif ( trace > 0 ) {\n\n\t\t\ts = 0.5 / Math.sqrt( trace + 1.0 );\n\n\t\t\tthis._w = 0.25 / s;\n\t\t\tthis._x = ( m32 - m23 ) * s;\n\t\t\tthis._y = ( m13 - m31 ) * s;\n\t\t\tthis._z = ( m21 - m12 ) * s;\n\n\t\t} else if ( m11 > m22 && m11 > m33 ) {\n\n\t\t\ts = 2.0 * Math.sqrt( 1.0 + m11 - m22 - m33 );\n\n\t\t\tthis._w = ( m32 - m23 ) / s;\n\t\t\tthis._x = 0.25 * s;\n\t\t\tthis._y = ( m12 + m21 ) / s;\n\t\t\tthis._z = ( m13 + m31 ) / s;\n\n\t\t} else if ( m22 > m33 ) {\n\n\t\t\ts = 2.0 * Math.sqrt( 1.0 + m22 - m11 - m33 );\n\n\t\t\tthis._w = ( m13 - m31 ) / s;\n\t\t\tthis._x = ( m12 + m21 ) / s;\n\t\t\tthis._y = 0.25 * s;\n\t\t\tthis._z = ( m23 + m32 ) / s;\n\n\t\t} else {\n\n\t\t\ts = 2.0 * Math.sqrt( 1.0 + m33 - m11 - m22 );\n\n\t\t\tthis._w = ( m21 - m12 ) / s;\n\t\t\tthis._x = ( m13 + m31 ) / s;\n\t\t\tthis._y = ( m23 + m32 ) / s;\n\t\t\tthis._z = 0.25 * s;\n\n\t\t}\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tsetFromUnitVectors: function () {\n\n\t\t// assumes direction vectors vFrom and vTo are normalized\n\n\t\tvar v1 = new Vector3();\n\t\tvar r;\n\n\t\tvar EPS = 0.000001;\n\n\t\treturn function setFromUnitVectors( vFrom, vTo ) {\n\n\t\t\tif ( v1 === undefined ) v1 = new Vector3();\n\n\t\t\tr = vFrom.dot( vTo ) + 1;\n\n\t\t\tif ( r < EPS ) {\n\n\t\t\t\tr = 0;\n\n\t\t\t\tif ( Math.abs( vFrom.x ) > Math.abs( vFrom.z ) ) {\n\n\t\t\t\t\tv1.set( - vFrom.y, vFrom.x, 0 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tv1.set( 0, - vFrom.z, vFrom.y );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tv1.crossVectors( vFrom, vTo );\n\n\t\t\t}\n\n\t\t\tthis._x = v1.x;\n\t\t\tthis._y = v1.y;\n\t\t\tthis._z = v1.z;\n\t\t\tthis._w = r;\n\n\t\t\treturn this.normalize();\n\n\t\t};\n\n\t}(),\n\n\tinverse: function () {\n\n\t\t// quaternion is assumed to have unit length\n\n\t\treturn this.conjugate();\n\n\t},\n\n\tconjugate: function () {\n\n\t\tthis._x *= - 1;\n\t\tthis._y *= - 1;\n\t\tthis._z *= - 1;\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tdot: function ( v ) {\n\n\t\treturn this._x * v._x + this._y * v._y + this._z * v._z + this._w * v._w;\n\n\t},\n\n\tlengthSq: function () {\n\n\t\treturn this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w;\n\n\t},\n\n\tlength: function () {\n\n\t\treturn Math.sqrt( this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w );\n\n\t},\n\n\tnormalize: function () {\n\n\t\tvar l = this.length();\n\n\t\tif ( l === 0 ) {\n\n\t\t\tthis._x = 0;\n\t\t\tthis._y = 0;\n\t\t\tthis._z = 0;\n\t\t\tthis._w = 1;\n\n\t\t} else {\n\n\t\t\tl = 1 / l;\n\n\t\t\tthis._x = this._x * l;\n\t\t\tthis._y = this._y * l;\n\t\t\tthis._z = this._z * l;\n\t\t\tthis._w = this._w * l;\n\n\t\t}\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tmultiply: function ( q, p ) {\n\n\t\tif ( p !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead.' );\n\t\t\treturn this.multiplyQuaternions( q, p );\n\n\t\t}\n\n\t\treturn this.multiplyQuaternions( this, q );\n\n\t},\n\n\tpremultiply: function ( q ) {\n\n\t\treturn this.multiplyQuaternions( q, this );\n\n\t},\n\n\tmultiplyQuaternions: function ( a, b ) {\n\n\t\t// from http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/code/index.htm\n\n\t\tvar qax = a._x, qay = a._y, qaz = a._z, qaw = a._w;\n\t\tvar qbx = b._x, qby = b._y, qbz = b._z, qbw = b._w;\n\n\t\tthis._x = qax * qbw + qaw * qbx + qay * qbz - qaz * qby;\n\t\tthis._y = qay * qbw + qaw * qby + qaz * qbx - qax * qbz;\n\t\tthis._z = qaz * qbw + qaw * qbz + qax * qby - qay * qbx;\n\t\tthis._w = qaw * qbw - qax * qbx - qay * qby - qaz * qbz;\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tslerp: function ( qb, t ) {\n\n\t\tif ( t === 0 ) return this;\n\t\tif ( t === 1 ) return this.copy( qb );\n\n\t\tvar x = this._x, y = this._y, z = this._z, w = this._w;\n\n\t\t// http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/slerp/\n\n\t\tvar cosHalfTheta = w * qb._w + x * qb._x + y * qb._y + z * qb._z;\n\n\t\tif ( cosHalfTheta < 0 ) {\n\n\t\t\tthis._w = - qb._w;\n\t\t\tthis._x = - qb._x;\n\t\t\tthis._y = - qb._y;\n\t\t\tthis._z = - qb._z;\n\n\t\t\tcosHalfTheta = - cosHalfTheta;\n\n\t\t} else {\n\n\t\t\tthis.copy( qb );\n\n\t\t}\n\n\t\tif ( cosHalfTheta >= 1.0 ) {\n\n\t\t\tthis._w = w;\n\t\t\tthis._x = x;\n\t\t\tthis._y = y;\n\t\t\tthis._z = z;\n\n\t\t\treturn this;\n\n\t\t}\n\n\t\tvar sinHalfTheta = Math.sqrt( 1.0 - cosHalfTheta * cosHalfTheta );\n\n\t\tif ( Math.abs( sinHalfTheta ) < 0.001 ) {\n\n\t\t\tthis._w = 0.5 * ( w + this._w );\n\t\t\tthis._x = 0.5 * ( x + this._x );\n\t\t\tthis._y = 0.5 * ( y + this._y );\n\t\t\tthis._z = 0.5 * ( z + this._z );\n\n\t\t\treturn this;\n\n\t\t}\n\n\t\tvar halfTheta = Math.atan2( sinHalfTheta, cosHalfTheta );\n\t\tvar ratioA = Math.sin( ( 1 - t ) * halfTheta ) / sinHalfTheta,\n\t\t\tratioB = Math.sin( t * halfTheta ) / sinHalfTheta;\n\n\t\tthis._w = ( w * ratioA + this._w * ratioB );\n\t\tthis._x = ( x * ratioA + this._x * ratioB );\n\t\tthis._y = ( y * ratioA + this._y * ratioB );\n\t\tthis._z = ( z * ratioA + this._z * ratioB );\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( quaternion ) {\n\n\t\treturn ( quaternion._x === this._x ) && ( quaternion._y === this._y ) && ( quaternion._z === this._z ) && ( quaternion._w === this._w );\n\n\t},\n\n\tfromArray: function ( array, offset ) {\n\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tthis._x = array[ offset ];\n\t\tthis._y = array[ offset + 1 ];\n\t\tthis._z = array[ offset + 2 ];\n\t\tthis._w = array[ offset + 3 ];\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\ttoArray: function ( array, offset ) {\n\n\t\tif ( array === undefined ) array = [];\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tarray[ offset ] = this._x;\n\t\tarray[ offset + 1 ] = this._y;\n\t\tarray[ offset + 2 ] = this._z;\n\t\tarray[ offset + 3 ] = this._w;\n\n\t\treturn array;\n\n\t},\n\n\tonChange: function ( callback ) {\n\n\t\tthis.onChangeCallback = callback;\n\n\t\treturn this;\n\n\t},\n\n\tonChangeCallback: function () {}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author kile / http://kile.stravaganza.org/\n * @author philogb / http://blog.thejit.org/\n * @author mikael emtinger / http://gomo.se/\n * @author egraether / http://egraether.com/\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction Vector3( x, y, z ) {\n\n\tthis.x = x || 0;\n\tthis.y = y || 0;\n\tthis.z = z || 0;\n\n}\n\nObject.assign( Vector3.prototype, {\n\n\tisVector3: true,\n\n\tset: function ( x, y, z ) {\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\n\t\treturn this;\n\n\t},\n\n\tsetScalar: function ( scalar ) {\n\n\t\tthis.x = scalar;\n\t\tthis.y = scalar;\n\t\tthis.z = scalar;\n\n\t\treturn this;\n\n\t},\n\n\tsetX: function ( x ) {\n\n\t\tthis.x = x;\n\n\t\treturn this;\n\n\t},\n\n\tsetY: function ( y ) {\n\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t},\n\n\tsetZ: function ( z ) {\n\n\t\tthis.z = z;\n\n\t\treturn this;\n\n\t},\n\n\tsetComponent: function ( index, value ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: this.x = value; break;\n\t\t\tcase 1: this.y = value; break;\n\t\t\tcase 2: this.z = value; break;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tgetComponent: function ( index ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: return this.x;\n\t\t\tcase 1: return this.y;\n\t\t\tcase 2: return this.z;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.x, this.y, this.z );\n\n\t},\n\n\tcopy: function ( v ) {\n\n\t\tthis.x = v.x;\n\t\tthis.y = v.y;\n\t\tthis.z = v.z;\n\n\t\treturn this;\n\n\t},\n\n\tadd: function ( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead.' );\n\t\t\treturn this.addVectors( v, w );\n\n\t\t}\n\n\t\tthis.x += v.x;\n\t\tthis.y += v.y;\n\t\tthis.z += v.z;\n\n\t\treturn this;\n\n\t},\n\n\taddScalar: function ( s ) {\n\n\t\tthis.x += s;\n\t\tthis.y += s;\n\t\tthis.z += s;\n\n\t\treturn this;\n\n\t},\n\n\taddVectors: function ( a, b ) {\n\n\t\tthis.x = a.x + b.x;\n\t\tthis.y = a.y + b.y;\n\t\tthis.z = a.z + b.z;\n\n\t\treturn this;\n\n\t},\n\n\taddScaledVector: function ( v, s ) {\n\n\t\tthis.x += v.x * s;\n\t\tthis.y += v.y * s;\n\t\tthis.z += v.z * s;\n\n\t\treturn this;\n\n\t},\n\n\tsub: function ( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.' );\n\t\t\treturn this.subVectors( v, w );\n\n\t\t}\n\n\t\tthis.x -= v.x;\n\t\tthis.y -= v.y;\n\t\tthis.z -= v.z;\n\n\t\treturn this;\n\n\t},\n\n\tsubScalar: function ( s ) {\n\n\t\tthis.x -= s;\n\t\tthis.y -= s;\n\t\tthis.z -= s;\n\n\t\treturn this;\n\n\t},\n\n\tsubVectors: function ( a, b ) {\n\n\t\tthis.x = a.x - b.x;\n\t\tthis.y = a.y - b.y;\n\t\tthis.z = a.z - b.z;\n\n\t\treturn this;\n\n\t},\n\n\tmultiply: function ( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead.' );\n\t\t\treturn this.multiplyVectors( v, w );\n\n\t\t}\n\n\t\tthis.x *= v.x;\n\t\tthis.y *= v.y;\n\t\tthis.z *= v.z;\n\n\t\treturn this;\n\n\t},\n\n\tmultiplyScalar: function ( scalar ) {\n\n\t\tthis.x *= scalar;\n\t\tthis.y *= scalar;\n\t\tthis.z *= scalar;\n\n\t\treturn this;\n\n\t},\n\n\tmultiplyVectors: function ( a, b ) {\n\n\t\tthis.x = a.x * b.x;\n\t\tthis.y = a.y * b.y;\n\t\tthis.z = a.z * b.z;\n\n\t\treturn this;\n\n\t},\n\n\tapplyEuler: function () {\n\n\t\tvar quaternion = new Quaternion();\n\n\t\treturn function applyEuler( euler ) {\n\n\t\t\tif ( ! ( euler && euler.isEuler ) ) {\n\n\t\t\t\tconsole.error( 'THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order.' );\n\n\t\t\t}\n\n\t\t\treturn this.applyQuaternion( quaternion.setFromEuler( euler ) );\n\n\t\t};\n\n\t}(),\n\n\tapplyAxisAngle: function () {\n\n\t\tvar quaternion = new Quaternion();\n\n\t\treturn function applyAxisAngle( axis, angle ) {\n\n\t\t\treturn this.applyQuaternion( quaternion.setFromAxisAngle( axis, angle ) );\n\n\t\t};\n\n\t}(),\n\n\tapplyMatrix3: function ( m ) {\n\n\t\tvar x = this.x, y = this.y, z = this.z;\n\t\tvar e = m.elements;\n\n\t\tthis.x = e[ 0 ] * x + e[ 3 ] * y + e[ 6 ] * z;\n\t\tthis.y = e[ 1 ] * x + e[ 4 ] * y + e[ 7 ] * z;\n\t\tthis.z = e[ 2 ] * x + e[ 5 ] * y + e[ 8 ] * z;\n\n\t\treturn this;\n\n\t},\n\n\tapplyMatrix4: function ( m ) {\n\n\t\tvar x = this.x, y = this.y, z = this.z;\n\t\tvar e = m.elements;\n\n\t\tvar w = 1 / ( e[ 3 ] * x + e[ 7 ] * y + e[ 11 ] * z + e[ 15 ] );\n\n\t\tthis.x = ( e[ 0 ] * x + e[ 4 ] * y + e[ 8 ] * z + e[ 12 ] ) * w;\n\t\tthis.y = ( e[ 1 ] * x + e[ 5 ] * y + e[ 9 ] * z + e[ 13 ] ) * w;\n\t\tthis.z = ( e[ 2 ] * x + e[ 6 ] * y + e[ 10 ] * z + e[ 14 ] ) * w;\n\n\t\treturn this;\n\n\t},\n\n\tapplyQuaternion: function ( q ) {\n\n\t\tvar x = this.x, y = this.y, z = this.z;\n\t\tvar qx = q.x, qy = q.y, qz = q.z, qw = q.w;\n\n\t\t// calculate quat * vector\n\n\t\tvar ix = qw * x + qy * z - qz * y;\n\t\tvar iy = qw * y + qz * x - qx * z;\n\t\tvar iz = qw * z + qx * y - qy * x;\n\t\tvar iw = - qx * x - qy * y - qz * z;\n\n\t\t// calculate result * inverse quat\n\n\t\tthis.x = ix * qw + iw * - qx + iy * - qz - iz * - qy;\n\t\tthis.y = iy * qw + iw * - qy + iz * - qx - ix * - qz;\n\t\tthis.z = iz * qw + iw * - qz + ix * - qy - iy * - qx;\n\n\t\treturn this;\n\n\t},\n\n\tproject: function () {\n\n\t\tvar matrix = new Matrix4();\n\n\t\treturn function project( camera ) {\n\n\t\t\tmatrix.multiplyMatrices( camera.projectionMatrix, matrix.getInverse( camera.matrixWorld ) );\n\t\t\treturn this.applyMatrix4( matrix );\n\n\t\t};\n\n\t}(),\n\n\tunproject: function () {\n\n\t\tvar matrix = new Matrix4();\n\n\t\treturn function unproject( camera ) {\n\n\t\t\tmatrix.multiplyMatrices( camera.matrixWorld, matrix.getInverse( camera.projectionMatrix ) );\n\t\t\treturn this.applyMatrix4( matrix );\n\n\t\t};\n\n\t}(),\n\n\ttransformDirection: function ( m ) {\n\n\t\t// input: THREE.Matrix4 affine matrix\n\t\t// vector interpreted as a direction\n\n\t\tvar x = this.x, y = this.y, z = this.z;\n\t\tvar e = m.elements;\n\n\t\tthis.x = e[ 0 ] * x + e[ 4 ] * y + e[ 8 ] * z;\n\t\tthis.y = e[ 1 ] * x + e[ 5 ] * y + e[ 9 ] * z;\n\t\tthis.z = e[ 2 ] * x + e[ 6 ] * y + e[ 10 ] * z;\n\n\t\treturn this.normalize();\n\n\t},\n\n\tdivide: function ( v ) {\n\n\t\tthis.x /= v.x;\n\t\tthis.y /= v.y;\n\t\tthis.z /= v.z;\n\n\t\treturn this;\n\n\t},\n\n\tdivideScalar: function ( scalar ) {\n\n\t\treturn this.multiplyScalar( 1 / scalar );\n\n\t},\n\n\tmin: function ( v ) {\n\n\t\tthis.x = Math.min( this.x, v.x );\n\t\tthis.y = Math.min( this.y, v.y );\n\t\tthis.z = Math.min( this.z, v.z );\n\n\t\treturn this;\n\n\t},\n\n\tmax: function ( v ) {\n\n\t\tthis.x = Math.max( this.x, v.x );\n\t\tthis.y = Math.max( this.y, v.y );\n\t\tthis.z = Math.max( this.z, v.z );\n\n\t\treturn this;\n\n\t},\n\n\tclamp: function ( min, max ) {\n\n\t\t// assumes min < max, componentwise\n\n\t\tthis.x = Math.max( min.x, Math.min( max.x, this.x ) );\n\t\tthis.y = Math.max( min.y, Math.min( max.y, this.y ) );\n\t\tthis.z = Math.max( min.z, Math.min( max.z, this.z ) );\n\n\t\treturn this;\n\n\t},\n\n\tclampScalar: function () {\n\n\t\tvar min = new Vector3();\n\t\tvar max = new Vector3();\n\n\t\treturn function clampScalar( minVal, maxVal ) {\n\n\t\t\tmin.set( minVal, minVal, minVal );\n\t\t\tmax.set( maxVal, maxVal, maxVal );\n\n\t\t\treturn this.clamp( min, max );\n\n\t\t};\n\n\t}(),\n\n\tclampLength: function ( min, max ) {\n\n\t\tvar length = this.length();\n\n\t\treturn this.divideScalar( length || 1 ).multiplyScalar( Math.max( min, Math.min( max, length ) ) );\n\n\t},\n\n\tfloor: function () {\n\n\t\tthis.x = Math.floor( this.x );\n\t\tthis.y = Math.floor( this.y );\n\t\tthis.z = Math.floor( this.z );\n\n\t\treturn this;\n\n\t},\n\n\tceil: function () {\n\n\t\tthis.x = Math.ceil( this.x );\n\t\tthis.y = Math.ceil( this.y );\n\t\tthis.z = Math.ceil( this.z );\n\n\t\treturn this;\n\n\t},\n\n\tround: function () {\n\n\t\tthis.x = Math.round( this.x );\n\t\tthis.y = Math.round( this.y );\n\t\tthis.z = Math.round( this.z );\n\n\t\treturn this;\n\n\t},\n\n\troundToZero: function () {\n\n\t\tthis.x = ( this.x < 0 ) ? Math.ceil( this.x ) : Math.floor( this.x );\n\t\tthis.y = ( this.y < 0 ) ? Math.ceil( this.y ) : Math.floor( this.y );\n\t\tthis.z = ( this.z < 0 ) ? Math.ceil( this.z ) : Math.floor( this.z );\n\n\t\treturn this;\n\n\t},\n\n\tnegate: function () {\n\n\t\tthis.x = - this.x;\n\t\tthis.y = - this.y;\n\t\tthis.z = - this.z;\n\n\t\treturn this;\n\n\t},\n\n\tdot: function ( v ) {\n\n\t\treturn this.x * v.x + this.y * v.y + this.z * v.z;\n\n\t},\n\n\t// TODO lengthSquared?\n\n\tlengthSq: function () {\n\n\t\treturn this.x * this.x + this.y * this.y + this.z * this.z;\n\n\t},\n\n\tlength: function () {\n\n\t\treturn Math.sqrt( this.x * this.x + this.y * this.y + this.z * this.z );\n\n\t},\n\n\tmanhattanLength: function () {\n\n\t\treturn Math.abs( this.x ) + Math.abs( this.y ) + Math.abs( this.z );\n\n\t},\n\n\tnormalize: function () {\n\n\t\treturn this.divideScalar( this.length() || 1 );\n\n\t},\n\n\tsetLength: function ( length ) {\n\n\t\treturn this.normalize().multiplyScalar( length );\n\n\t},\n\n\tlerp: function ( v, alpha ) {\n\n\t\tthis.x += ( v.x - this.x ) * alpha;\n\t\tthis.y += ( v.y - this.y ) * alpha;\n\t\tthis.z += ( v.z - this.z ) * alpha;\n\n\t\treturn this;\n\n\t},\n\n\tlerpVectors: function ( v1, v2, alpha ) {\n\n\t\treturn this.subVectors( v2, v1 ).multiplyScalar( alpha ).add( v1 );\n\n\t},\n\n\tcross: function ( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead.' );\n\t\t\treturn this.crossVectors( v, w );\n\n\t\t}\n\n\t\treturn this.crossVectors( this, v );\n\n\t},\n\n\tcrossVectors: function ( a, b ) {\n\n\t\tvar ax = a.x, ay = a.y, az = a.z;\n\t\tvar bx = b.x, by = b.y, bz = b.z;\n\n\t\tthis.x = ay * bz - az * by;\n\t\tthis.y = az * bx - ax * bz;\n\t\tthis.z = ax * by - ay * bx;\n\n\t\treturn this;\n\n\t},\n\n\tprojectOnVector: function ( vector ) {\n\n\t\tvar scalar = vector.dot( this ) / vector.lengthSq();\n\n\t\treturn this.copy( vector ).multiplyScalar( scalar );\n\n\t},\n\n\tprojectOnPlane: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function projectOnPlane( planeNormal ) {\n\n\t\t\tv1.copy( this ).projectOnVector( planeNormal );\n\n\t\t\treturn this.sub( v1 );\n\n\t\t};\n\n\t}(),\n\n\treflect: function () {\n\n\t\t// reflect incident vector off plane orthogonal to normal\n\t\t// normal is assumed to have unit length\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function reflect( normal ) {\n\n\t\t\treturn this.sub( v1.copy( normal ).multiplyScalar( 2 * this.dot( normal ) ) );\n\n\t\t};\n\n\t}(),\n\n\tangleTo: function ( v ) {\n\n\t\tvar theta = this.dot( v ) / ( Math.sqrt( this.lengthSq() * v.lengthSq() ) );\n\n\t\t// clamp, to handle numerical problems\n\n\t\treturn Math.acos( _Math.clamp( theta, - 1, 1 ) );\n\n\t},\n\n\tdistanceTo: function ( v ) {\n\n\t\treturn Math.sqrt( this.distanceToSquared( v ) );\n\n\t},\n\n\tdistanceToSquared: function ( v ) {\n\n\t\tvar dx = this.x - v.x, dy = this.y - v.y, dz = this.z - v.z;\n\n\t\treturn dx * dx + dy * dy + dz * dz;\n\n\t},\n\n\tmanhattanDistanceTo: function ( v ) {\n\n\t\treturn Math.abs( this.x - v.x ) + Math.abs( this.y - v.y ) + Math.abs( this.z - v.z );\n\n\t},\n\n\tsetFromSpherical: function ( s ) {\n\n\t\tvar sinPhiRadius = Math.sin( s.phi ) * s.radius;\n\n\t\tthis.x = sinPhiRadius * Math.sin( s.theta );\n\t\tthis.y = Math.cos( s.phi ) * s.radius;\n\t\tthis.z = sinPhiRadius * Math.cos( s.theta );\n\n\t\treturn this;\n\n\t},\n\n\tsetFromCylindrical: function ( c ) {\n\n\t\tthis.x = c.radius * Math.sin( c.theta );\n\t\tthis.y = c.y;\n\t\tthis.z = c.radius * Math.cos( c.theta );\n\n\t\treturn this;\n\n\t},\n\n\tsetFromMatrixPosition: function ( m ) {\n\n\t\tvar e = m.elements;\n\n\t\tthis.x = e[ 12 ];\n\t\tthis.y = e[ 13 ];\n\t\tthis.z = e[ 14 ];\n\n\t\treturn this;\n\n\t},\n\n\tsetFromMatrixScale: function ( m ) {\n\n\t\tvar sx = this.setFromMatrixColumn( m, 0 ).length();\n\t\tvar sy = this.setFromMatrixColumn( m, 1 ).length();\n\t\tvar sz = this.setFromMatrixColumn( m, 2 ).length();\n\n\t\tthis.x = sx;\n\t\tthis.y = sy;\n\t\tthis.z = sz;\n\n\t\treturn this;\n\n\t},\n\n\tsetFromMatrixColumn: function ( m, index ) {\n\n\t\treturn this.fromArray( m.elements, index * 4 );\n\n\t},\n\n\tequals: function ( v ) {\n\n\t\treturn ( ( v.x === this.x ) && ( v.y === this.y ) && ( v.z === this.z ) );\n\n\t},\n\n\tfromArray: function ( array, offset ) {\n\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tthis.x = array[ offset ];\n\t\tthis.y = array[ offset + 1 ];\n\t\tthis.z = array[ offset + 2 ];\n\n\t\treturn this;\n\n\t},\n\n\ttoArray: function ( array, offset ) {\n\n\t\tif ( array === undefined ) array = [];\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tarray[ offset ] = this.x;\n\t\tarray[ offset + 1 ] = this.y;\n\t\tarray[ offset + 2 ] = this.z;\n\n\t\treturn array;\n\n\t},\n\n\tfromBufferAttribute: function ( attribute, index, offset ) {\n\n\t\tif ( offset !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: offset has been removed from .fromBufferAttribute().' );\n\n\t\t}\n\n\t\tthis.x = attribute.getX( index );\n\t\tthis.y = attribute.getY( index );\n\t\tthis.z = attribute.getZ( index );\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author WestLangley / http://github.com/WestLangley\n * @author bhouston / http://clara.io\n * @author tschw\n */\n\nfunction Matrix3() {\n\n\tthis.elements = [\n\n\t\t1, 0, 0,\n\t\t0, 1, 0,\n\t\t0, 0, 1\n\n\t];\n\n\tif ( arguments.length > 0 ) {\n\n\t\tconsole.error( 'THREE.Matrix3: the constructor no longer reads arguments. use .set() instead.' );\n\n\t}\n\n}\n\nObject.assign( Matrix3.prototype, {\n\n\tisMatrix3: true,\n\n\tset: function ( n11, n12, n13, n21, n22, n23, n31, n32, n33 ) {\n\n\t\tvar te = this.elements;\n\n\t\tte[ 0 ] = n11; te[ 1 ] = n21; te[ 2 ] = n31;\n\t\tte[ 3 ] = n12; te[ 4 ] = n22; te[ 5 ] = n32;\n\t\tte[ 6 ] = n13; te[ 7 ] = n23; te[ 8 ] = n33;\n\n\t\treturn this;\n\n\t},\n\n\tidentity: function () {\n\n\t\tthis.set(\n\n\t\t\t1, 0, 0,\n\t\t\t0, 1, 0,\n\t\t\t0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().fromArray( this.elements );\n\n\t},\n\n\tcopy: function ( m ) {\n\n\t\tvar te = this.elements;\n\t\tvar me = m.elements;\n\n\t\tte[ 0 ] = me[ 0 ]; te[ 1 ] = me[ 1 ]; te[ 2 ] = me[ 2 ];\n\t\tte[ 3 ] = me[ 3 ]; te[ 4 ] = me[ 4 ]; te[ 5 ] = me[ 5 ];\n\t\tte[ 6 ] = me[ 6 ]; te[ 7 ] = me[ 7 ]; te[ 8 ] = me[ 8 ];\n\n\t\treturn this;\n\n\t},\n\n\tsetFromMatrix4: function ( m ) {\n\n\t\tvar me = m.elements;\n\n\t\tthis.set(\n\n\t\t\tme[ 0 ], me[ 4 ], me[ 8 ],\n\t\t\tme[ 1 ], me[ 5 ], me[ 9 ],\n\t\t\tme[ 2 ], me[ 6 ], me[ 10 ]\n\n\t\t);\n\n\t\treturn this;\n\n\t},\n\n\tapplyToBufferAttribute: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function applyToBufferAttribute( attribute ) {\n\n\t\t\tfor ( var i = 0, l = attribute.count; i < l; i ++ ) {\n\n\t\t\t\tv1.x = attribute.getX( i );\n\t\t\t\tv1.y = attribute.getY( i );\n\t\t\t\tv1.z = attribute.getZ( i );\n\n\t\t\t\tv1.applyMatrix3( this );\n\n\t\t\t\tattribute.setXYZ( i, v1.x, v1.y, v1.z );\n\n\t\t\t}\n\n\t\t\treturn attribute;\n\n\t\t};\n\n\t}(),\n\n\tmultiply: function ( m ) {\n\n\t\treturn this.multiplyMatrices( this, m );\n\n\t},\n\n\tpremultiply: function ( m ) {\n\n\t\treturn this.multiplyMatrices( m, this );\n\n\t},\n\n\tmultiplyMatrices: function ( a, b ) {\n\n\t\tvar ae = a.elements;\n\t\tvar be = b.elements;\n\t\tvar te = this.elements;\n\n\t\tvar a11 = ae[ 0 ], a12 = ae[ 3 ], a13 = ae[ 6 ];\n\t\tvar a21 = ae[ 1 ], a22 = ae[ 4 ], a23 = ae[ 7 ];\n\t\tvar a31 = ae[ 2 ], a32 = ae[ 5 ], a33 = ae[ 8 ];\n\n\t\tvar b11 = be[ 0 ], b12 = be[ 3 ], b13 = be[ 6 ];\n\t\tvar b21 = be[ 1 ], b22 = be[ 4 ], b23 = be[ 7 ];\n\t\tvar b31 = be[ 2 ], b32 = be[ 5 ], b33 = be[ 8 ];\n\n\t\tte[ 0 ] = a11 * b11 + a12 * b21 + a13 * b31;\n\t\tte[ 3 ] = a11 * b12 + a12 * b22 + a13 * b32;\n\t\tte[ 6 ] = a11 * b13 + a12 * b23 + a13 * b33;\n\n\t\tte[ 1 ] = a21 * b11 + a22 * b21 + a23 * b31;\n\t\tte[ 4 ] = a21 * b12 + a22 * b22 + a23 * b32;\n\t\tte[ 7 ] = a21 * b13 + a22 * b23 + a23 * b33;\n\n\t\tte[ 2 ] = a31 * b11 + a32 * b21 + a33 * b31;\n\t\tte[ 5 ] = a31 * b12 + a32 * b22 + a33 * b32;\n\t\tte[ 8 ] = a31 * b13 + a32 * b23 + a33 * b33;\n\n\t\treturn this;\n\n\t},\n\n\tmultiplyScalar: function ( s ) {\n\n\t\tvar te = this.elements;\n\n\t\tte[ 0 ] *= s; te[ 3 ] *= s; te[ 6 ] *= s;\n\t\tte[ 1 ] *= s; te[ 4 ] *= s; te[ 7 ] *= s;\n\t\tte[ 2 ] *= s; te[ 5 ] *= s; te[ 8 ] *= s;\n\n\t\treturn this;\n\n\t},\n\n\tdeterminant: function () {\n\n\t\tvar te = this.elements;\n\n\t\tvar a = te[ 0 ], b = te[ 1 ], c = te[ 2 ],\n\t\t\td = te[ 3 ], e = te[ 4 ], f = te[ 5 ],\n\t\t\tg = te[ 6 ], h = te[ 7 ], i = te[ 8 ];\n\n\t\treturn a * e * i - a * f * h - b * d * i + b * f * g + c * d * h - c * e * g;\n\n\t},\n\n\tgetInverse: function ( matrix, throwOnDegenerate ) {\n\n\t\tif ( matrix && matrix.isMatrix4 ) {\n\n\t\t\tconsole.error( \"THREE.Matrix3: .getInverse() no longer takes a Matrix4 argument.\" );\n\n\t\t}\n\n\t\tvar me = matrix.elements,\n\t\t\tte = this.elements,\n\n\t\t\tn11 = me[ 0 ], n21 = me[ 1 ], n31 = me[ 2 ],\n\t\t\tn12 = me[ 3 ], n22 = me[ 4 ], n32 = me[ 5 ],\n\t\t\tn13 = me[ 6 ], n23 = me[ 7 ], n33 = me[ 8 ],\n\n\t\t\tt11 = n33 * n22 - n32 * n23,\n\t\t\tt12 = n32 * n13 - n33 * n12,\n\t\t\tt13 = n23 * n12 - n22 * n13,\n\n\t\t\tdet = n11 * t11 + n21 * t12 + n31 * t13;\n\n\t\tif ( det === 0 ) {\n\n\t\t\tvar msg = \"THREE.Matrix3: .getInverse() can't invert matrix, determinant is 0\";\n\n\t\t\tif ( throwOnDegenerate === true ) {\n\n\t\t\t\tthrow new Error( msg );\n\n\t\t\t} else {\n\n\t\t\t\tconsole.warn( msg );\n\n\t\t\t}\n\n\t\t\treturn this.identity();\n\n\t\t}\n\n\t\tvar detInv = 1 / det;\n\n\t\tte[ 0 ] = t11 * detInv;\n\t\tte[ 1 ] = ( n31 * n23 - n33 * n21 ) * detInv;\n\t\tte[ 2 ] = ( n32 * n21 - n31 * n22 ) * detInv;\n\n\t\tte[ 3 ] = t12 * detInv;\n\t\tte[ 4 ] = ( n33 * n11 - n31 * n13 ) * detInv;\n\t\tte[ 5 ] = ( n31 * n12 - n32 * n11 ) * detInv;\n\n\t\tte[ 6 ] = t13 * detInv;\n\t\tte[ 7 ] = ( n21 * n13 - n23 * n11 ) * detInv;\n\t\tte[ 8 ] = ( n22 * n11 - n21 * n12 ) * detInv;\n\n\t\treturn this;\n\n\t},\n\n\ttranspose: function () {\n\n\t\tvar tmp, m = this.elements;\n\n\t\ttmp = m[ 1 ]; m[ 1 ] = m[ 3 ]; m[ 3 ] = tmp;\n\t\ttmp = m[ 2 ]; m[ 2 ] = m[ 6 ]; m[ 6 ] = tmp;\n\t\ttmp = m[ 5 ]; m[ 5 ] = m[ 7 ]; m[ 7 ] = tmp;\n\n\t\treturn this;\n\n\t},\n\n\tgetNormalMatrix: function ( matrix4 ) {\n\n\t\treturn this.setFromMatrix4( matrix4 ).getInverse( this ).transpose();\n\n\t},\n\n\ttransposeIntoArray: function ( r ) {\n\n\t\tvar m = this.elements;\n\n\t\tr[ 0 ] = m[ 0 ];\n\t\tr[ 1 ] = m[ 3 ];\n\t\tr[ 2 ] = m[ 6 ];\n\t\tr[ 3 ] = m[ 1 ];\n\t\tr[ 4 ] = m[ 4 ];\n\t\tr[ 5 ] = m[ 7 ];\n\t\tr[ 6 ] = m[ 2 ];\n\t\tr[ 7 ] = m[ 5 ];\n\t\tr[ 8 ] = m[ 8 ];\n\n\t\treturn this;\n\n\t},\n\n\tsetUvTransform: function ( tx, ty, sx, sy, rotation, cx, cy ) {\n\n\t\tvar c = Math.cos( rotation );\n\t\tvar s = Math.sin( rotation );\n\n\t\tthis.set(\n\t\t\tsx * c, sx * s, - sx * ( c * cx + s * cy ) + cx + tx,\n\t\t\t- sy * s, sy * c, - sy * ( - s * cx + c * cy ) + cy + ty,\n\t\t\t0, 0, 1\n\t\t);\n\n\t},\n\n\tscale: function ( sx, sy ) {\n\n\t\tvar te = this.elements;\n\n\t\tte[ 0 ] *= sx; te[ 3 ] *= sx; te[ 6 ] *= sx;\n\t\tte[ 1 ] *= sy; te[ 4 ] *= sy; te[ 7 ] *= sy;\n\n\t\treturn this;\n\n\t},\n\n\trotate: function ( theta ) {\n\n\t\tvar c = Math.cos( theta );\n\t\tvar s = Math.sin( theta );\n\n\t\tvar te = this.elements;\n\n\t\tvar a11 = te[ 0 ], a12 = te[ 3 ], a13 = te[ 6 ];\n\t\tvar a21 = te[ 1 ], a22 = te[ 4 ], a23 = te[ 7 ];\n\n\t\tte[ 0 ] = c * a11 + s * a21;\n\t\tte[ 3 ] = c * a12 + s * a22;\n\t\tte[ 6 ] = c * a13 + s * a23;\n\n\t\tte[ 1 ] = - s * a11 + c * a21;\n\t\tte[ 4 ] = - s * a12 + c * a22;\n\t\tte[ 7 ] = - s * a13 + c * a23;\n\n\t\treturn this;\n\n\t},\n\n\ttranslate: function ( tx, ty ) {\n\n\t\tvar te = this.elements;\n\n\t\tte[ 0 ] += tx * te[ 2 ]; te[ 3 ] += tx * te[ 5 ]; te[ 6 ] += tx * te[ 8 ];\n\t\tte[ 1 ] += ty * te[ 2 ]; te[ 4 ] += ty * te[ 5 ]; te[ 7 ] += ty * te[ 8 ];\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( matrix ) {\n\n\t\tvar te = this.elements;\n\t\tvar me = matrix.elements;\n\n\t\tfor ( var i = 0; i < 9; i ++ ) {\n\n\t\t\tif ( te[ i ] !== me[ i ] ) return false;\n\n\t\t}\n\n\t\treturn true;\n\n\t},\n\n\tfromArray: function ( array, offset ) {\n\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tfor ( var i = 0; i < 9; i ++ ) {\n\n\t\t\tthis.elements[ i ] = array[ i + offset ];\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\ttoArray: function ( array, offset ) {\n\n\t\tif ( array === undefined ) array = [];\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tvar te = this.elements;\n\n\t\tarray[ offset ] = te[ 0 ];\n\t\tarray[ offset + 1 ] = te[ 1 ];\n\t\tarray[ offset + 2 ] = te[ 2 ];\n\n\t\tarray[ offset + 3 ] = te[ 3 ];\n\t\tarray[ offset + 4 ] = te[ 4 ];\n\t\tarray[ offset + 5 ] = te[ 5 ];\n\n\t\tarray[ offset + 6 ] = te[ 6 ];\n\t\tarray[ offset + 7 ] = te[ 7 ];\n\t\tarray[ offset + 8 ] = te[ 8 ];\n\n\t\treturn array;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n * @author szimek / https://github.com/szimek/\n */\n\nvar textureId = 0;\n\nfunction Texture( image, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding ) {\n\n\tObject.defineProperty( this, 'id', { value: textureId ++ } );\n\n\tthis.uuid = _Math.generateUUID();\n\n\tthis.name = '';\n\n\tthis.image = image !== undefined ? image : Texture.DEFAULT_IMAGE;\n\tthis.mipmaps = [];\n\n\tthis.mapping = mapping !== undefined ? mapping : Texture.DEFAULT_MAPPING;\n\n\tthis.wrapS = wrapS !== undefined ? wrapS : ClampToEdgeWrapping;\n\tthis.wrapT = wrapT !== undefined ? wrapT : ClampToEdgeWrapping;\n\n\tthis.magFilter = magFilter !== undefined ? magFilter : LinearFilter;\n\tthis.minFilter = minFilter !== undefined ? minFilter : LinearMipMapLinearFilter;\n\n\tthis.anisotropy = anisotropy !== undefined ? anisotropy : 1;\n\n\tthis.format = format !== undefined ? format : RGBAFormat;\n\tthis.type = type !== undefined ? type : UnsignedByteType;\n\n\tthis.offset = new Vector2( 0, 0 );\n\tthis.repeat = new Vector2( 1, 1 );\n\tthis.center = new Vector2( 0, 0 );\n\tthis.rotation = 0;\n\n\tthis.matrixAutoUpdate = true;\n\tthis.matrix = new Matrix3();\n\n\tthis.generateMipmaps = true;\n\tthis.premultiplyAlpha = false;\n\tthis.flipY = true;\n\tthis.unpackAlignment = 4;\t// valid values: 1, 2, 4, 8 (see http://www.khronos.org/opengles/sdk/docs/man/xhtml/glPixelStorei.xml)\n\n\t// Values of encoding !== THREE.LinearEncoding only supported on map, envMap and emissiveMap.\n\t//\n\t// Also changing the encoding after already used by a Material will not automatically make the Material\n\t// update.  You need to explicitly call Material.needsUpdate to trigger it to recompile.\n\tthis.encoding = encoding !== undefined ? encoding : LinearEncoding;\n\n\tthis.version = 0;\n\tthis.onUpdate = null;\n\n}\n\nTexture.DEFAULT_IMAGE = undefined;\nTexture.DEFAULT_MAPPING = UVMapping;\n\nTexture.prototype = Object.assign( Object.create( EventDispatcher.prototype ), {\n\n\tconstructor: Texture,\n\n\tisTexture: true,\n\n\tupdateMatrix: function () {\n\n\t\tthis.matrix.setUvTransform( this.offset.x, this.offset.y, this.repeat.x, this.repeat.y, this.rotation, this.center.x, this.center.y );\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tthis.name = source.name;\n\n\t\tthis.image = source.image;\n\t\tthis.mipmaps = source.mipmaps.slice( 0 );\n\n\t\tthis.mapping = source.mapping;\n\n\t\tthis.wrapS = source.wrapS;\n\t\tthis.wrapT = source.wrapT;\n\n\t\tthis.magFilter = source.magFilter;\n\t\tthis.minFilter = source.minFilter;\n\n\t\tthis.anisotropy = source.anisotropy;\n\n\t\tthis.format = source.format;\n\t\tthis.type = source.type;\n\n\t\tthis.offset.copy( source.offset );\n\t\tthis.repeat.copy( source.repeat );\n\t\tthis.center.copy( source.center );\n\t\tthis.rotation = source.rotation;\n\n\t\tthis.matrixAutoUpdate = source.matrixAutoUpdate;\n\t\tthis.matrix.copy( source.matrix );\n\n\t\tthis.generateMipmaps = source.generateMipmaps;\n\t\tthis.premultiplyAlpha = source.premultiplyAlpha;\n\t\tthis.flipY = source.flipY;\n\t\tthis.unpackAlignment = source.unpackAlignment;\n\t\tthis.encoding = source.encoding;\n\n\t\treturn this;\n\n\t},\n\n\ttoJSON: function ( meta ) {\n\n\t\tvar isRootObject = ( meta === undefined || typeof meta === 'string' );\n\n\t\tif ( ! isRootObject && meta.textures[ this.uuid ] !== undefined ) {\n\n\t\t\treturn meta.textures[ this.uuid ];\n\n\t\t}\n\n\t\tfunction getDataURL( image ) {\n\n\t\t\tvar canvas;\n\n\t\t\tif ( image instanceof HTMLCanvasElement ) {\n\n\t\t\t\tcanvas = image;\n\n\t\t\t} else {\n\n\t\t\t\tcanvas = document.createElementNS( 'http://www.w3.org/1999/xhtml', 'canvas' );\n\t\t\t\tcanvas.width = image.width;\n\t\t\t\tcanvas.height = image.height;\n\n\t\t\t\tvar context = canvas.getContext( '2d' );\n\n\t\t\t\tif ( image instanceof ImageData ) {\n\n\t\t\t\t\tcontext.putImageData( image, 0, 0 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tcontext.drawImage( image, 0, 0, image.width, image.height );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( canvas.width > 2048 || canvas.height > 2048 ) {\n\n\t\t\t\treturn canvas.toDataURL( 'image/jpeg', 0.6 );\n\n\t\t\t} else {\n\n\t\t\t\treturn canvas.toDataURL( 'image/png' );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar output = {\n\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Texture',\n\t\t\t\tgenerator: 'Texture.toJSON'\n\t\t\t},\n\n\t\t\tuuid: this.uuid,\n\t\t\tname: this.name,\n\n\t\t\tmapping: this.mapping,\n\n\t\t\trepeat: [ this.repeat.x, this.repeat.y ],\n\t\t\toffset: [ this.offset.x, this.offset.y ],\n\t\t\tcenter: [ this.center.x, this.center.y ],\n\t\t\trotation: this.rotation,\n\n\t\t\twrap: [ this.wrapS, this.wrapT ],\n\n\t\t\tformat: this.format,\n\t\t\tminFilter: this.minFilter,\n\t\t\tmagFilter: this.magFilter,\n\t\t\tanisotropy: this.anisotropy,\n\n\t\t\tflipY: this.flipY\n\n\t\t};\n\n\t\tif ( this.image !== undefined ) {\n\n\t\t\t// TODO: Move to THREE.Image\n\n\t\t\tvar image = this.image;\n\n\t\t\tif ( image.uuid === undefined ) {\n\n\t\t\t\timage.uuid = _Math.generateUUID(); // UGH\n\n\t\t\t}\n\n\t\t\tif ( ! isRootObject && meta.images[ image.uuid ] === undefined ) {\n\n\t\t\t\tmeta.images[ image.uuid ] = {\n\t\t\t\t\tuuid: image.uuid,\n\t\t\t\t\turl: getDataURL( image )\n\t\t\t\t};\n\n\t\t\t}\n\n\t\t\toutput.image = image.uuid;\n\n\t\t}\n\n\t\tif ( ! isRootObject ) {\n\n\t\t\tmeta.textures[ this.uuid ] = output;\n\n\t\t}\n\n\t\treturn output;\n\n\t},\n\n\tdispose: function () {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t},\n\n\ttransformUv: function ( uv ) {\n\n\t\tif ( this.mapping !== UVMapping ) return;\n\n\t\tuv.applyMatrix3( this.matrix );\n\n\t\tif ( uv.x < 0 || uv.x > 1 ) {\n\n\t\t\tswitch ( this.wrapS ) {\n\n\t\t\t\tcase RepeatWrapping:\n\n\t\t\t\t\tuv.x = uv.x - Math.floor( uv.x );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase ClampToEdgeWrapping:\n\n\t\t\t\t\tuv.x = uv.x < 0 ? 0 : 1;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase MirroredRepeatWrapping:\n\n\t\t\t\t\tif ( Math.abs( Math.floor( uv.x ) % 2 ) === 1 ) {\n\n\t\t\t\t\t\tuv.x = Math.ceil( uv.x ) - uv.x;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tuv.x = uv.x - Math.floor( uv.x );\n\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( uv.y < 0 || uv.y > 1 ) {\n\n\t\t\tswitch ( this.wrapT ) {\n\n\t\t\t\tcase RepeatWrapping:\n\n\t\t\t\t\tuv.y = uv.y - Math.floor( uv.y );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase ClampToEdgeWrapping:\n\n\t\t\t\t\tuv.y = uv.y < 0 ? 0 : 1;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase MirroredRepeatWrapping:\n\n\t\t\t\t\tif ( Math.abs( Math.floor( uv.y ) % 2 ) === 1 ) {\n\n\t\t\t\t\t\tuv.y = Math.ceil( uv.y ) - uv.y;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tuv.y = uv.y - Math.floor( uv.y );\n\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.flipY ) {\n\n\t\t\tuv.y = 1 - uv.y;\n\n\t\t}\n\n\t}\n\n} );\n\nObject.defineProperty( Texture.prototype, \"needsUpdate\", {\n\n\tset: function ( value ) {\n\n\t\tif ( value === true ) this.version ++;\n\n\t}\n\n} );\n\n/**\n * @author supereggbert / http://www.paulbrunt.co.uk/\n * @author philogb / http://blog.thejit.org/\n * @author mikael emtinger / http://gomo.se/\n * @author egraether / http://egraether.com/\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction Vector4( x, y, z, w ) {\n\n\tthis.x = x || 0;\n\tthis.y = y || 0;\n\tthis.z = z || 0;\n\tthis.w = ( w !== undefined ) ? w : 1;\n\n}\n\nObject.assign( Vector4.prototype, {\n\n\tisVector4: true,\n\n\tset: function ( x, y, z, w ) {\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\t\tthis.w = w;\n\n\t\treturn this;\n\n\t},\n\n\tsetScalar: function ( scalar ) {\n\n\t\tthis.x = scalar;\n\t\tthis.y = scalar;\n\t\tthis.z = scalar;\n\t\tthis.w = scalar;\n\n\t\treturn this;\n\n\t},\n\n\tsetX: function ( x ) {\n\n\t\tthis.x = x;\n\n\t\treturn this;\n\n\t},\n\n\tsetY: function ( y ) {\n\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t},\n\n\tsetZ: function ( z ) {\n\n\t\tthis.z = z;\n\n\t\treturn this;\n\n\t},\n\n\tsetW: function ( w ) {\n\n\t\tthis.w = w;\n\n\t\treturn this;\n\n\t},\n\n\tsetComponent: function ( index, value ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: this.x = value; break;\n\t\t\tcase 1: this.y = value; break;\n\t\t\tcase 2: this.z = value; break;\n\t\t\tcase 3: this.w = value; break;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tgetComponent: function ( index ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: return this.x;\n\t\t\tcase 1: return this.y;\n\t\t\tcase 2: return this.z;\n\t\t\tcase 3: return this.w;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.x, this.y, this.z, this.w );\n\n\t},\n\n\tcopy: function ( v ) {\n\n\t\tthis.x = v.x;\n\t\tthis.y = v.y;\n\t\tthis.z = v.z;\n\t\tthis.w = ( v.w !== undefined ) ? v.w : 1;\n\n\t\treturn this;\n\n\t},\n\n\tadd: function ( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead.' );\n\t\t\treturn this.addVectors( v, w );\n\n\t\t}\n\n\t\tthis.x += v.x;\n\t\tthis.y += v.y;\n\t\tthis.z += v.z;\n\t\tthis.w += v.w;\n\n\t\treturn this;\n\n\t},\n\n\taddScalar: function ( s ) {\n\n\t\tthis.x += s;\n\t\tthis.y += s;\n\t\tthis.z += s;\n\t\tthis.w += s;\n\n\t\treturn this;\n\n\t},\n\n\taddVectors: function ( a, b ) {\n\n\t\tthis.x = a.x + b.x;\n\t\tthis.y = a.y + b.y;\n\t\tthis.z = a.z + b.z;\n\t\tthis.w = a.w + b.w;\n\n\t\treturn this;\n\n\t},\n\n\taddScaledVector: function ( v, s ) {\n\n\t\tthis.x += v.x * s;\n\t\tthis.y += v.y * s;\n\t\tthis.z += v.z * s;\n\t\tthis.w += v.w * s;\n\n\t\treturn this;\n\n\t},\n\n\tsub: function ( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.' );\n\t\t\treturn this.subVectors( v, w );\n\n\t\t}\n\n\t\tthis.x -= v.x;\n\t\tthis.y -= v.y;\n\t\tthis.z -= v.z;\n\t\tthis.w -= v.w;\n\n\t\treturn this;\n\n\t},\n\n\tsubScalar: function ( s ) {\n\n\t\tthis.x -= s;\n\t\tthis.y -= s;\n\t\tthis.z -= s;\n\t\tthis.w -= s;\n\n\t\treturn this;\n\n\t},\n\n\tsubVectors: function ( a, b ) {\n\n\t\tthis.x = a.x - b.x;\n\t\tthis.y = a.y - b.y;\n\t\tthis.z = a.z - b.z;\n\t\tthis.w = a.w - b.w;\n\n\t\treturn this;\n\n\t},\n\n\tmultiplyScalar: function ( scalar ) {\n\n\t\tthis.x *= scalar;\n\t\tthis.y *= scalar;\n\t\tthis.z *= scalar;\n\t\tthis.w *= scalar;\n\n\t\treturn this;\n\n\t},\n\n\tapplyMatrix4: function ( m ) {\n\n\t\tvar x = this.x, y = this.y, z = this.z, w = this.w;\n\t\tvar e = m.elements;\n\n\t\tthis.x = e[ 0 ] * x + e[ 4 ] * y + e[ 8 ] * z + e[ 12 ] * w;\n\t\tthis.y = e[ 1 ] * x + e[ 5 ] * y + e[ 9 ] * z + e[ 13 ] * w;\n\t\tthis.z = e[ 2 ] * x + e[ 6 ] * y + e[ 10 ] * z + e[ 14 ] * w;\n\t\tthis.w = e[ 3 ] * x + e[ 7 ] * y + e[ 11 ] * z + e[ 15 ] * w;\n\n\t\treturn this;\n\n\t},\n\n\tdivideScalar: function ( scalar ) {\n\n\t\treturn this.multiplyScalar( 1 / scalar );\n\n\t},\n\n\tsetAxisAngleFromQuaternion: function ( q ) {\n\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/quaternionToAngle/index.htm\n\n\t\t// q is assumed to be normalized\n\n\t\tthis.w = 2 * Math.acos( q.w );\n\n\t\tvar s = Math.sqrt( 1 - q.w * q.w );\n\n\t\tif ( s < 0.0001 ) {\n\n\t\t\tthis.x = 1;\n\t\t\tthis.y = 0;\n\t\t\tthis.z = 0;\n\n\t\t} else {\n\n\t\t\tthis.x = q.x / s;\n\t\t\tthis.y = q.y / s;\n\t\t\tthis.z = q.z / s;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tsetAxisAngleFromRotationMatrix: function ( m ) {\n\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToAngle/index.htm\n\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\n\t\tvar angle, x, y, z,\t\t// variables for result\n\t\t\tepsilon = 0.01,\t\t// margin to allow for rounding errors\n\t\t\tepsilon2 = 0.1,\t\t// margin to distinguish between 0 and 180 degrees\n\n\t\t\tte = m.elements,\n\n\t\t\tm11 = te[ 0 ], m12 = te[ 4 ], m13 = te[ 8 ],\n\t\t\tm21 = te[ 1 ], m22 = te[ 5 ], m23 = te[ 9 ],\n\t\t\tm31 = te[ 2 ], m32 = te[ 6 ], m33 = te[ 10 ];\n\n\t\tif ( ( Math.abs( m12 - m21 ) < epsilon ) &&\n\t\t     ( Math.abs( m13 - m31 ) < epsilon ) &&\n\t\t     ( Math.abs( m23 - m32 ) < epsilon ) ) {\n\n\t\t\t// singularity found\n\t\t\t// first check for identity matrix which must have +1 for all terms\n\t\t\t// in leading diagonal and zero in other terms\n\n\t\t\tif ( ( Math.abs( m12 + m21 ) < epsilon2 ) &&\n\t\t\t     ( Math.abs( m13 + m31 ) < epsilon2 ) &&\n\t\t\t     ( Math.abs( m23 + m32 ) < epsilon2 ) &&\n\t\t\t     ( Math.abs( m11 + m22 + m33 - 3 ) < epsilon2 ) ) {\n\n\t\t\t\t// this singularity is identity matrix so angle = 0\n\n\t\t\t\tthis.set( 1, 0, 0, 0 );\n\n\t\t\t\treturn this; // zero angle, arbitrary axis\n\n\t\t\t}\n\n\t\t\t// otherwise this singularity is angle = 180\n\n\t\t\tangle = Math.PI;\n\n\t\t\tvar xx = ( m11 + 1 ) / 2;\n\t\t\tvar yy = ( m22 + 1 ) / 2;\n\t\t\tvar zz = ( m33 + 1 ) / 2;\n\t\t\tvar xy = ( m12 + m21 ) / 4;\n\t\t\tvar xz = ( m13 + m31 ) / 4;\n\t\t\tvar yz = ( m23 + m32 ) / 4;\n\n\t\t\tif ( ( xx > yy ) && ( xx > zz ) ) {\n\n\t\t\t\t// m11 is the largest diagonal term\n\n\t\t\t\tif ( xx < epsilon ) {\n\n\t\t\t\t\tx = 0;\n\t\t\t\t\ty = 0.707106781;\n\t\t\t\t\tz = 0.707106781;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tx = Math.sqrt( xx );\n\t\t\t\t\ty = xy / x;\n\t\t\t\t\tz = xz / x;\n\n\t\t\t\t}\n\n\t\t\t} else if ( yy > zz ) {\n\n\t\t\t\t// m22 is the largest diagonal term\n\n\t\t\t\tif ( yy < epsilon ) {\n\n\t\t\t\t\tx = 0.707106781;\n\t\t\t\t\ty = 0;\n\t\t\t\t\tz = 0.707106781;\n\n\t\t\t\t} else {\n\n\t\t\t\t\ty = Math.sqrt( yy );\n\t\t\t\t\tx = xy / y;\n\t\t\t\t\tz = yz / y;\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// m33 is the largest diagonal term so base result on this\n\n\t\t\t\tif ( zz < epsilon ) {\n\n\t\t\t\t\tx = 0.707106781;\n\t\t\t\t\ty = 0.707106781;\n\t\t\t\t\tz = 0;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tz = Math.sqrt( zz );\n\t\t\t\t\tx = xz / z;\n\t\t\t\t\ty = yz / z;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis.set( x, y, z, angle );\n\n\t\t\treturn this; // return 180 deg rotation\n\n\t\t}\n\n\t\t// as we have reached here there are no singularities so we can handle normally\n\n\t\tvar s = Math.sqrt( ( m32 - m23 ) * ( m32 - m23 ) +\n\t\t                   ( m13 - m31 ) * ( m13 - m31 ) +\n\t\t                   ( m21 - m12 ) * ( m21 - m12 ) ); // used to normalize\n\n\t\tif ( Math.abs( s ) < 0.001 ) s = 1;\n\n\t\t// prevent divide by zero, should not happen if matrix is orthogonal and should be\n\t\t// caught by singularity test above, but I've left it in just in case\n\n\t\tthis.x = ( m32 - m23 ) / s;\n\t\tthis.y = ( m13 - m31 ) / s;\n\t\tthis.z = ( m21 - m12 ) / s;\n\t\tthis.w = Math.acos( ( m11 + m22 + m33 - 1 ) / 2 );\n\n\t\treturn this;\n\n\t},\n\n\tmin: function ( v ) {\n\n\t\tthis.x = Math.min( this.x, v.x );\n\t\tthis.y = Math.min( this.y, v.y );\n\t\tthis.z = Math.min( this.z, v.z );\n\t\tthis.w = Math.min( this.w, v.w );\n\n\t\treturn this;\n\n\t},\n\n\tmax: function ( v ) {\n\n\t\tthis.x = Math.max( this.x, v.x );\n\t\tthis.y = Math.max( this.y, v.y );\n\t\tthis.z = Math.max( this.z, v.z );\n\t\tthis.w = Math.max( this.w, v.w );\n\n\t\treturn this;\n\n\t},\n\n\tclamp: function ( min, max ) {\n\n\t\t// assumes min < max, componentwise\n\n\t\tthis.x = Math.max( min.x, Math.min( max.x, this.x ) );\n\t\tthis.y = Math.max( min.y, Math.min( max.y, this.y ) );\n\t\tthis.z = Math.max( min.z, Math.min( max.z, this.z ) );\n\t\tthis.w = Math.max( min.w, Math.min( max.w, this.w ) );\n\n\t\treturn this;\n\n\t},\n\n\tclampScalar: function () {\n\n\t\tvar min, max;\n\n\t\treturn function clampScalar( minVal, maxVal ) {\n\n\t\t\tif ( min === undefined ) {\n\n\t\t\t\tmin = new Vector4();\n\t\t\t\tmax = new Vector4();\n\n\t\t\t}\n\n\t\t\tmin.set( minVal, minVal, minVal, minVal );\n\t\t\tmax.set( maxVal, maxVal, maxVal, maxVal );\n\n\t\t\treturn this.clamp( min, max );\n\n\t\t};\n\n\t}(),\n\n\tclampLength: function ( min, max ) {\n\n\t\tvar length = this.length();\n\n\t\treturn this.divideScalar( length || 1 ).multiplyScalar( Math.max( min, Math.min( max, length ) ) );\n\n\t},\n\n\tfloor: function () {\n\n\t\tthis.x = Math.floor( this.x );\n\t\tthis.y = Math.floor( this.y );\n\t\tthis.z = Math.floor( this.z );\n\t\tthis.w = Math.floor( this.w );\n\n\t\treturn this;\n\n\t},\n\n\tceil: function () {\n\n\t\tthis.x = Math.ceil( this.x );\n\t\tthis.y = Math.ceil( this.y );\n\t\tthis.z = Math.ceil( this.z );\n\t\tthis.w = Math.ceil( this.w );\n\n\t\treturn this;\n\n\t},\n\n\tround: function () {\n\n\t\tthis.x = Math.round( this.x );\n\t\tthis.y = Math.round( this.y );\n\t\tthis.z = Math.round( this.z );\n\t\tthis.w = Math.round( this.w );\n\n\t\treturn this;\n\n\t},\n\n\troundToZero: function () {\n\n\t\tthis.x = ( this.x < 0 ) ? Math.ceil( this.x ) : Math.floor( this.x );\n\t\tthis.y = ( this.y < 0 ) ? Math.ceil( this.y ) : Math.floor( this.y );\n\t\tthis.z = ( this.z < 0 ) ? Math.ceil( this.z ) : Math.floor( this.z );\n\t\tthis.w = ( this.w < 0 ) ? Math.ceil( this.w ) : Math.floor( this.w );\n\n\t\treturn this;\n\n\t},\n\n\tnegate: function () {\n\n\t\tthis.x = - this.x;\n\t\tthis.y = - this.y;\n\t\tthis.z = - this.z;\n\t\tthis.w = - this.w;\n\n\t\treturn this;\n\n\t},\n\n\tdot: function ( v ) {\n\n\t\treturn this.x * v.x + this.y * v.y + this.z * v.z + this.w * v.w;\n\n\t},\n\n\tlengthSq: function () {\n\n\t\treturn this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w;\n\n\t},\n\n\tlength: function () {\n\n\t\treturn Math.sqrt( this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w );\n\n\t},\n\n\tmanhattanLength: function () {\n\n\t\treturn Math.abs( this.x ) + Math.abs( this.y ) + Math.abs( this.z ) + Math.abs( this.w );\n\n\t},\n\n\tnormalize: function () {\n\n\t\treturn this.divideScalar( this.length() || 1 );\n\n\t},\n\n\tsetLength: function ( length ) {\n\n\t\treturn this.normalize().multiplyScalar( length );\n\n\t},\n\n\tlerp: function ( v, alpha ) {\n\n\t\tthis.x += ( v.x - this.x ) * alpha;\n\t\tthis.y += ( v.y - this.y ) * alpha;\n\t\tthis.z += ( v.z - this.z ) * alpha;\n\t\tthis.w += ( v.w - this.w ) * alpha;\n\n\t\treturn this;\n\n\t},\n\n\tlerpVectors: function ( v1, v2, alpha ) {\n\n\t\treturn this.subVectors( v2, v1 ).multiplyScalar( alpha ).add( v1 );\n\n\t},\n\n\tequals: function ( v ) {\n\n\t\treturn ( ( v.x === this.x ) && ( v.y === this.y ) && ( v.z === this.z ) && ( v.w === this.w ) );\n\n\t},\n\n\tfromArray: function ( array, offset ) {\n\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tthis.x = array[ offset ];\n\t\tthis.y = array[ offset + 1 ];\n\t\tthis.z = array[ offset + 2 ];\n\t\tthis.w = array[ offset + 3 ];\n\n\t\treturn this;\n\n\t},\n\n\ttoArray: function ( array, offset ) {\n\n\t\tif ( array === undefined ) array = [];\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tarray[ offset ] = this.x;\n\t\tarray[ offset + 1 ] = this.y;\n\t\tarray[ offset + 2 ] = this.z;\n\t\tarray[ offset + 3 ] = this.w;\n\n\t\treturn array;\n\n\t},\n\n\tfromBufferAttribute: function ( attribute, index, offset ) {\n\n\t\tif ( offset !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector4: offset has been removed from .fromBufferAttribute().' );\n\n\t\t}\n\n\t\tthis.x = attribute.getX( index );\n\t\tthis.y = attribute.getY( index );\n\t\tthis.z = attribute.getZ( index );\n\t\tthis.w = attribute.getW( index );\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author szimek / https://github.com/szimek/\n * @author alteredq / http://alteredqualia.com/\n * @author Marius Kintel / https://github.com/kintel\n */\n\n/*\n In options, we can specify:\n * Texture parameters for an auto-generated target texture\n * depthBuffer/stencilBuffer: Booleans to indicate if we should generate these buffers\n*/\nfunction WebGLRenderTarget( width, height, options ) {\n\n\tthis.width = width;\n\tthis.height = height;\n\n\tthis.scissor = new Vector4( 0, 0, width, height );\n\tthis.scissorTest = false;\n\n\tthis.viewport = new Vector4( 0, 0, width, height );\n\n\toptions = options || {};\n\n\tif ( options.minFilter === undefined ) options.minFilter = LinearFilter;\n\n\tthis.texture = new Texture( undefined, undefined, options.wrapS, options.wrapT, options.magFilter, options.minFilter, options.format, options.type, options.anisotropy, options.encoding );\n\n\tthis.depthBuffer = options.depthBuffer !== undefined ? options.depthBuffer : true;\n\tthis.stencilBuffer = options.stencilBuffer !== undefined ? options.stencilBuffer : true;\n\tthis.depthTexture = options.depthTexture !== undefined ? options.depthTexture : null;\n\n}\n\nWebGLRenderTarget.prototype = Object.assign( Object.create( EventDispatcher.prototype ), {\n\n\tconstructor: WebGLRenderTarget,\n\n\tisWebGLRenderTarget: true,\n\n\tsetSize: function ( width, height ) {\n\n\t\tif ( this.width !== width || this.height !== height ) {\n\n\t\t\tthis.width = width;\n\t\t\tthis.height = height;\n\n\t\t\tthis.dispose();\n\n\t\t}\n\n\t\tthis.viewport.set( 0, 0, width, height );\n\t\tthis.scissor.set( 0, 0, width, height );\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tthis.width = source.width;\n\t\tthis.height = source.height;\n\n\t\tthis.viewport.copy( source.viewport );\n\n\t\tthis.texture = source.texture.clone();\n\n\t\tthis.depthBuffer = source.depthBuffer;\n\t\tthis.stencilBuffer = source.stencilBuffer;\n\t\tthis.depthTexture = source.depthTexture;\n\n\t\treturn this;\n\n\t},\n\n\tdispose: function () {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t}\n\n} );\n\n/**\n * @author alteredq / http://alteredqualia.com\n */\n\nfunction WebGLRenderTargetCube( width, height, options ) {\n\n\tWebGLRenderTarget.call( this, width, height, options );\n\n\tthis.activeCubeFace = 0; // PX 0, NX 1, PY 2, NY 3, PZ 4, NZ 5\n\tthis.activeMipMapLevel = 0;\n\n}\n\nWebGLRenderTargetCube.prototype = Object.create( WebGLRenderTarget.prototype );\nWebGLRenderTargetCube.prototype.constructor = WebGLRenderTargetCube;\n\nWebGLRenderTargetCube.prototype.isWebGLRenderTargetCube = true;\n\n/**\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction DataTexture( data, width, height, format, type, mapping, wrapS, wrapT, magFilter, minFilter, anisotropy, encoding ) {\n\n\tTexture.call( this, null, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding );\n\n\tthis.image = { data: data, width: width, height: height };\n\n\tthis.magFilter = magFilter !== undefined ? magFilter : NearestFilter;\n\tthis.minFilter = minFilter !== undefined ? minFilter : NearestFilter;\n\n\tthis.generateMipmaps = false;\n\tthis.flipY = false;\n\tthis.unpackAlignment = 1;\n\n}\n\nDataTexture.prototype = Object.create( Texture.prototype );\nDataTexture.prototype.constructor = DataTexture;\n\nDataTexture.prototype.isDataTexture = true;\n\n/**\n * @author bhouston / http://clara.io\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction Box3( min, max ) {\n\n\tthis.min = ( min !== undefined ) ? min : new Vector3( + Infinity, + Infinity, + Infinity );\n\tthis.max = ( max !== undefined ) ? max : new Vector3( - Infinity, - Infinity, - Infinity );\n\n}\n\nObject.assign( Box3.prototype, {\n\n\tisBox3: true,\n\n\tset: function ( min, max ) {\n\n\t\tthis.min.copy( min );\n\t\tthis.max.copy( max );\n\n\t\treturn this;\n\n\t},\n\n\tsetFromArray: function ( array ) {\n\n\t\tvar minX = + Infinity;\n\t\tvar minY = + Infinity;\n\t\tvar minZ = + Infinity;\n\n\t\tvar maxX = - Infinity;\n\t\tvar maxY = - Infinity;\n\t\tvar maxZ = - Infinity;\n\n\t\tfor ( var i = 0, l = array.length; i < l; i += 3 ) {\n\n\t\t\tvar x = array[ i ];\n\t\t\tvar y = array[ i + 1 ];\n\t\t\tvar z = array[ i + 2 ];\n\n\t\t\tif ( x < minX ) minX = x;\n\t\t\tif ( y < minY ) minY = y;\n\t\t\tif ( z < minZ ) minZ = z;\n\n\t\t\tif ( x > maxX ) maxX = x;\n\t\t\tif ( y > maxY ) maxY = y;\n\t\t\tif ( z > maxZ ) maxZ = z;\n\n\t\t}\n\n\t\tthis.min.set( minX, minY, minZ );\n\t\tthis.max.set( maxX, maxY, maxZ );\n\n\t\treturn this;\n\n\t},\n\n\tsetFromBufferAttribute: function ( attribute ) {\n\n\t\tvar minX = + Infinity;\n\t\tvar minY = + Infinity;\n\t\tvar minZ = + Infinity;\n\n\t\tvar maxX = - Infinity;\n\t\tvar maxY = - Infinity;\n\t\tvar maxZ = - Infinity;\n\n\t\tfor ( var i = 0, l = attribute.count; i < l; i ++ ) {\n\n\t\t\tvar x = attribute.getX( i );\n\t\t\tvar y = attribute.getY( i );\n\t\t\tvar z = attribute.getZ( i );\n\n\t\t\tif ( x < minX ) minX = x;\n\t\t\tif ( y < minY ) minY = y;\n\t\t\tif ( z < minZ ) minZ = z;\n\n\t\t\tif ( x > maxX ) maxX = x;\n\t\t\tif ( y > maxY ) maxY = y;\n\t\t\tif ( z > maxZ ) maxZ = z;\n\n\t\t}\n\n\t\tthis.min.set( minX, minY, minZ );\n\t\tthis.max.set( maxX, maxY, maxZ );\n\n\t\treturn this;\n\n\t},\n\n\tsetFromPoints: function ( points ) {\n\n\t\tthis.makeEmpty();\n\n\t\tfor ( var i = 0, il = points.length; i < il; i ++ ) {\n\n\t\t\tthis.expandByPoint( points[ i ] );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tsetFromCenterAndSize: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function setFromCenterAndSize( center, size ) {\n\n\t\t\tvar halfSize = v1.copy( size ).multiplyScalar( 0.5 );\n\n\t\t\tthis.min.copy( center ).sub( halfSize );\n\t\t\tthis.max.copy( center ).add( halfSize );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tsetFromObject: function ( object ) {\n\n\t\tthis.makeEmpty();\n\n\t\treturn this.expandByObject( object );\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( box ) {\n\n\t\tthis.min.copy( box.min );\n\t\tthis.max.copy( box.max );\n\n\t\treturn this;\n\n\t},\n\n\tmakeEmpty: function () {\n\n\t\tthis.min.x = this.min.y = this.min.z = + Infinity;\n\t\tthis.max.x = this.max.y = this.max.z = - Infinity;\n\n\t\treturn this;\n\n\t},\n\n\tisEmpty: function () {\n\n\t\t// this is a more robust check for empty than ( volume <= 0 ) because volume can get positive with two negative axes\n\n\t\treturn ( this.max.x < this.min.x ) || ( this.max.y < this.min.y ) || ( this.max.z < this.min.z );\n\n\t},\n\n\tgetCenter: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Box3: .getCenter() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn this.isEmpty() ? target.set( 0, 0, 0 ) : target.addVectors( this.min, this.max ).multiplyScalar( 0.5 );\n\n\t},\n\n\tgetSize: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Box3: .getSize() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn this.isEmpty() ? target.set( 0, 0, 0 ) : target.subVectors( this.max, this.min );\n\n\t},\n\n\texpandByPoint: function ( point ) {\n\n\t\tthis.min.min( point );\n\t\tthis.max.max( point );\n\n\t\treturn this;\n\n\t},\n\n\texpandByVector: function ( vector ) {\n\n\t\tthis.min.sub( vector );\n\t\tthis.max.add( vector );\n\n\t\treturn this;\n\n\t},\n\n\texpandByScalar: function ( scalar ) {\n\n\t\tthis.min.addScalar( - scalar );\n\t\tthis.max.addScalar( scalar );\n\n\t\treturn this;\n\n\t},\n\n\texpandByObject: function () {\n\n\t\t// Computes the world-axis-aligned bounding box of an object (including its children),\n\t\t// accounting for both the object's, and children's, world transforms\n\n\t\tvar scope, i, l;\n\n\t\tvar v1 = new Vector3();\n\n\t\tfunction traverse( node ) {\n\n\t\t\tvar geometry = node.geometry;\n\n\t\t\tif ( geometry !== undefined ) {\n\n\t\t\t\tif ( geometry.isGeometry ) {\n\n\t\t\t\t\tvar vertices = geometry.vertices;\n\n\t\t\t\t\tfor ( i = 0, l = vertices.length; i < l; i ++ ) {\n\n\t\t\t\t\t\tv1.copy( vertices[ i ] );\n\t\t\t\t\t\tv1.applyMatrix4( node.matrixWorld );\n\n\t\t\t\t\t\tscope.expandByPoint( v1 );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else if ( geometry.isBufferGeometry ) {\n\n\t\t\t\t\tvar attribute = geometry.attributes.position;\n\n\t\t\t\t\tif ( attribute !== undefined ) {\n\n\t\t\t\t\t\tfor ( i = 0, l = attribute.count; i < l; i ++ ) {\n\n\t\t\t\t\t\t\tv1.fromBufferAttribute( attribute, i ).applyMatrix4( node.matrixWorld );\n\n\t\t\t\t\t\t\tscope.expandByPoint( v1 );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn function expandByObject( object ) {\n\n\t\t\tscope = this;\n\n\t\t\tobject.updateMatrixWorld( true );\n\n\t\t\tobject.traverse( traverse );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tcontainsPoint: function ( point ) {\n\n\t\treturn point.x < this.min.x || point.x > this.max.x ||\n\t\t\tpoint.y < this.min.y || point.y > this.max.y ||\n\t\t\tpoint.z < this.min.z || point.z > this.max.z ? false : true;\n\n\t},\n\n\tcontainsBox: function ( box ) {\n\n\t\treturn this.min.x <= box.min.x && box.max.x <= this.max.x &&\n\t\t\tthis.min.y <= box.min.y && box.max.y <= this.max.y &&\n\t\t\tthis.min.z <= box.min.z && box.max.z <= this.max.z;\n\n\t},\n\n\tgetParameter: function ( point, target ) {\n\n\t\t// This can potentially have a divide by zero if the box\n\t\t// has a size dimension of 0.\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Box3: .getParameter() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn target.set(\n\t\t\t( point.x - this.min.x ) / ( this.max.x - this.min.x ),\n\t\t\t( point.y - this.min.y ) / ( this.max.y - this.min.y ),\n\t\t\t( point.z - this.min.z ) / ( this.max.z - this.min.z )\n\t\t);\n\n\t},\n\n\tintersectsBox: function ( box ) {\n\n\t\t// using 6 splitting planes to rule out intersections.\n\t\treturn box.max.x < this.min.x || box.min.x > this.max.x ||\n\t\t\tbox.max.y < this.min.y || box.min.y > this.max.y ||\n\t\t\tbox.max.z < this.min.z || box.min.z > this.max.z ? false : true;\n\n\t},\n\n\tintersectsSphere: ( function () {\n\n\t\tvar closestPoint = new Vector3();\n\n\t\treturn function intersectsSphere( sphere ) {\n\n\t\t\t// Find the point on the AABB closest to the sphere center.\n\t\t\tthis.clampPoint( sphere.center, closestPoint );\n\n\t\t\t// If that point is inside the sphere, the AABB and sphere intersect.\n\t\t\treturn closestPoint.distanceToSquared( sphere.center ) <= ( sphere.radius * sphere.radius );\n\n\t\t};\n\n\t} )(),\n\n\tintersectsPlane: function ( plane ) {\n\n\t\t// We compute the minimum and maximum dot product values. If those values\n\t\t// are on the same side (back or front) of the plane, then there is no intersection.\n\n\t\tvar min, max;\n\n\t\tif ( plane.normal.x > 0 ) {\n\n\t\t\tmin = plane.normal.x * this.min.x;\n\t\t\tmax = plane.normal.x * this.max.x;\n\n\t\t} else {\n\n\t\t\tmin = plane.normal.x * this.max.x;\n\t\t\tmax = plane.normal.x * this.min.x;\n\n\t\t}\n\n\t\tif ( plane.normal.y > 0 ) {\n\n\t\t\tmin += plane.normal.y * this.min.y;\n\t\t\tmax += plane.normal.y * this.max.y;\n\n\t\t} else {\n\n\t\t\tmin += plane.normal.y * this.max.y;\n\t\t\tmax += plane.normal.y * this.min.y;\n\n\t\t}\n\n\t\tif ( plane.normal.z > 0 ) {\n\n\t\t\tmin += plane.normal.z * this.min.z;\n\t\t\tmax += plane.normal.z * this.max.z;\n\n\t\t} else {\n\n\t\t\tmin += plane.normal.z * this.max.z;\n\t\t\tmax += plane.normal.z * this.min.z;\n\n\t\t}\n\n\t\treturn ( min <= plane.constant && max >= plane.constant );\n\n\t},\n\n\tintersectsTriangle: ( function () {\n\n\t\t// triangle centered vertices\n\t\tvar v0 = new Vector3();\n\t\tvar v1 = new Vector3();\n\t\tvar v2 = new Vector3();\n\n\t\t// triangle edge vectors\n\t\tvar f0 = new Vector3();\n\t\tvar f1 = new Vector3();\n\t\tvar f2 = new Vector3();\n\n\t\tvar testAxis = new Vector3();\n\n\t\tvar center = new Vector3();\n\t\tvar extents = new Vector3();\n\n\t\tvar triangleNormal = new Vector3();\n\n\t\tfunction satForAxes( axes ) {\n\n\t\t\tvar i, j;\n\n\t\t\tfor ( i = 0, j = axes.length - 3; i <= j; i += 3 ) {\n\n\t\t\t\ttestAxis.fromArray( axes, i );\n\t\t\t\t// project the aabb onto the seperating axis\n\t\t\t\tvar r = extents.x * Math.abs( testAxis.x ) + extents.y * Math.abs( testAxis.y ) + extents.z * Math.abs( testAxis.z );\n\t\t\t\t// project all 3 vertices of the triangle onto the seperating axis\n\t\t\t\tvar p0 = v0.dot( testAxis );\n\t\t\t\tvar p1 = v1.dot( testAxis );\n\t\t\t\tvar p2 = v2.dot( testAxis );\n\t\t\t\t// actual test, basically see if either of the most extreme of the triangle points intersects r\n\t\t\t\tif ( Math.max( - Math.max( p0, p1, p2 ), Math.min( p0, p1, p2 ) ) > r ) {\n\n\t\t\t\t\t// points of the projected triangle are outside the projected half-length of the aabb\n\t\t\t\t\t// the axis is seperating and we can exit\n\t\t\t\t\treturn false;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn true;\n\n\t\t}\n\n\t\treturn function intersectsTriangle( triangle ) {\n\n\t\t\tif ( this.isEmpty() ) {\n\n\t\t\t\treturn false;\n\n\t\t\t}\n\n\t\t\t// compute box center and extents\n\t\t\tthis.getCenter( center );\n\t\t\textents.subVectors( this.max, center );\n\n\t\t\t// translate triangle to aabb origin\n\t\t\tv0.subVectors( triangle.a, center );\n\t\t\tv1.subVectors( triangle.b, center );\n\t\t\tv2.subVectors( triangle.c, center );\n\n\t\t\t// compute edge vectors for triangle\n\t\t\tf0.subVectors( v1, v0 );\n\t\t\tf1.subVectors( v2, v1 );\n\t\t\tf2.subVectors( v0, v2 );\n\n\t\t\t// test against axes that are given by cross product combinations of the edges of the triangle and the edges of the aabb\n\t\t\t// make an axis testing of each of the 3 sides of the aabb against each of the 3 sides of the triangle = 9 axis of separation\n\t\t\t// axis_ij = u_i x f_j (u0, u1, u2 = face normals of aabb = x,y,z axes vectors since aabb is axis aligned)\n\t\t\tvar axes = [\n\t\t\t\t0, - f0.z, f0.y, 0, - f1.z, f1.y, 0, - f2.z, f2.y,\n\t\t\t\tf0.z, 0, - f0.x, f1.z, 0, - f1.x, f2.z, 0, - f2.x,\n\t\t\t\t- f0.y, f0.x, 0, - f1.y, f1.x, 0, - f2.y, f2.x, 0\n\t\t\t];\n\t\t\tif ( ! satForAxes( axes ) ) {\n\n\t\t\t\treturn false;\n\n\t\t\t}\n\n\t\t\t// test 3 face normals from the aabb\n\t\t\taxes = [ 1, 0, 0, 0, 1, 0, 0, 0, 1 ];\n\t\t\tif ( ! satForAxes( axes ) ) {\n\n\t\t\t\treturn false;\n\n\t\t\t}\n\n\t\t\t// finally testing the face normal of the triangle\n\t\t\t// use already existing triangle edge vectors here\n\t\t\ttriangleNormal.crossVectors( f0, f1 );\n\t\t\taxes = [ triangleNormal.x, triangleNormal.y, triangleNormal.z ];\n\t\t\treturn satForAxes( axes );\n\n\t\t};\n\n\t} )(),\n\n\tclampPoint: function ( point, target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Box3: .clampPoint() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn target.copy( point ).clamp( this.min, this.max );\n\n\t},\n\n\tdistanceToPoint: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function distanceToPoint( point ) {\n\n\t\t\tvar clampedPoint = v1.copy( point ).clamp( this.min, this.max );\n\t\t\treturn clampedPoint.sub( point ).length();\n\n\t\t};\n\n\t}(),\n\n\tgetBoundingSphere: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function getBoundingSphere( target ) {\n\n\t\t\tif ( target === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Box3: .getBoundingSphere() target is now required' );\n\t\t\t\ttarget = new Sphere();\n\n\t\t\t}\n\n\t\t\tthis.getCenter( target.center );\n\n\t\t\ttarget.radius = this.getSize( v1 ).length() * 0.5;\n\n\t\t\treturn target;\n\n\t\t};\n\n\t}(),\n\n\tintersect: function ( box ) {\n\n\t\tthis.min.max( box.min );\n\t\tthis.max.min( box.max );\n\n\t\t// ensure that if there is no overlap, the result is fully empty, not slightly empty with non-inf/+inf values that will cause subsequence intersects to erroneously return valid values.\n\t\tif ( this.isEmpty() ) this.makeEmpty();\n\n\t\treturn this;\n\n\t},\n\n\tunion: function ( box ) {\n\n\t\tthis.min.min( box.min );\n\t\tthis.max.max( box.max );\n\n\t\treturn this;\n\n\t},\n\n\tapplyMatrix4: function () {\n\n\t\tvar points = [\n\t\t\tnew Vector3(),\n\t\t\tnew Vector3(),\n\t\t\tnew Vector3(),\n\t\t\tnew Vector3(),\n\t\t\tnew Vector3(),\n\t\t\tnew Vector3(),\n\t\t\tnew Vector3(),\n\t\t\tnew Vector3()\n\t\t];\n\n\t\treturn function applyMatrix4( matrix ) {\n\n\t\t\t// transform of empty box is an empty box.\n\t\t\tif ( this.isEmpty() ) return this;\n\n\t\t\t// NOTE: I am using a binary pattern to specify all 2^3 combinations below\n\t\t\tpoints[ 0 ].set( this.min.x, this.min.y, this.min.z ).applyMatrix4( matrix ); // 000\n\t\t\tpoints[ 1 ].set( this.min.x, this.min.y, this.max.z ).applyMatrix4( matrix ); // 001\n\t\t\tpoints[ 2 ].set( this.min.x, this.max.y, this.min.z ).applyMatrix4( matrix ); // 010\n\t\t\tpoints[ 3 ].set( this.min.x, this.max.y, this.max.z ).applyMatrix4( matrix ); // 011\n\t\t\tpoints[ 4 ].set( this.max.x, this.min.y, this.min.z ).applyMatrix4( matrix ); // 100\n\t\t\tpoints[ 5 ].set( this.max.x, this.min.y, this.max.z ).applyMatrix4( matrix ); // 101\n\t\t\tpoints[ 6 ].set( this.max.x, this.max.y, this.min.z ).applyMatrix4( matrix ); // 110\n\t\t\tpoints[ 7 ].set( this.max.x, this.max.y, this.max.z ).applyMatrix4( matrix );\t// 111\n\n\t\t\tthis.setFromPoints( points );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\ttranslate: function ( offset ) {\n\n\t\tthis.min.add( offset );\n\t\tthis.max.add( offset );\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( box ) {\n\n\t\treturn box.min.equals( this.min ) && box.max.equals( this.max );\n\n\t}\n\n} );\n\n/**\n * @author bhouston / http://clara.io\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction Sphere( center, radius ) {\n\n\tthis.center = ( center !== undefined ) ? center : new Vector3();\n\tthis.radius = ( radius !== undefined ) ? radius : 0;\n\n}\n\nObject.assign( Sphere.prototype, {\n\n\tset: function ( center, radius ) {\n\n\t\tthis.center.copy( center );\n\t\tthis.radius = radius;\n\n\t\treturn this;\n\n\t},\n\n\tsetFromPoints: function () {\n\n\t\tvar box = new Box3();\n\n\t\treturn function setFromPoints( points, optionalCenter ) {\n\n\t\t\tvar center = this.center;\n\n\t\t\tif ( optionalCenter !== undefined ) {\n\n\t\t\t\tcenter.copy( optionalCenter );\n\n\t\t\t} else {\n\n\t\t\t\tbox.setFromPoints( points ).getCenter( center );\n\n\t\t\t}\n\n\t\t\tvar maxRadiusSq = 0;\n\n\t\t\tfor ( var i = 0, il = points.length; i < il; i ++ ) {\n\n\t\t\t\tmaxRadiusSq = Math.max( maxRadiusSq, center.distanceToSquared( points[ i ] ) );\n\n\t\t\t}\n\n\t\t\tthis.radius = Math.sqrt( maxRadiusSq );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( sphere ) {\n\n\t\tthis.center.copy( sphere.center );\n\t\tthis.radius = sphere.radius;\n\n\t\treturn this;\n\n\t},\n\n\tempty: function () {\n\n\t\treturn ( this.radius <= 0 );\n\n\t},\n\n\tcontainsPoint: function ( point ) {\n\n\t\treturn ( point.distanceToSquared( this.center ) <= ( this.radius * this.radius ) );\n\n\t},\n\n\tdistanceToPoint: function ( point ) {\n\n\t\treturn ( point.distanceTo( this.center ) - this.radius );\n\n\t},\n\n\tintersectsSphere: function ( sphere ) {\n\n\t\tvar radiusSum = this.radius + sphere.radius;\n\n\t\treturn sphere.center.distanceToSquared( this.center ) <= ( radiusSum * radiusSum );\n\n\t},\n\n\tintersectsBox: function ( box ) {\n\n\t\treturn box.intersectsSphere( this );\n\n\t},\n\n\tintersectsPlane: function ( plane ) {\n\n\t\treturn Math.abs( plane.distanceToPoint( this.center ) ) <= this.radius;\n\n\t},\n\n\tclampPoint: function ( point, target ) {\n\n\t\tvar deltaLengthSq = this.center.distanceToSquared( point );\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Sphere: .clampPoint() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\ttarget.copy( point );\n\n\t\tif ( deltaLengthSq > ( this.radius * this.radius ) ) {\n\n\t\t\ttarget.sub( this.center ).normalize();\n\t\t\ttarget.multiplyScalar( this.radius ).add( this.center );\n\n\t\t}\n\n\t\treturn target;\n\n\t},\n\n\tgetBoundingBox: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Sphere: .getBoundingBox() target is now required' );\n\t\t\ttarget = new Box3();\n\n\t\t}\n\n\t\ttarget.set( this.center, this.center );\n\t\ttarget.expandByScalar( this.radius );\n\n\t\treturn target;\n\n\t},\n\n\tapplyMatrix4: function ( matrix ) {\n\n\t\tthis.center.applyMatrix4( matrix );\n\t\tthis.radius = this.radius * matrix.getMaxScaleOnAxis();\n\n\t\treturn this;\n\n\t},\n\n\ttranslate: function ( offset ) {\n\n\t\tthis.center.add( offset );\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( sphere ) {\n\n\t\treturn sphere.center.equals( this.center ) && ( sphere.radius === this.radius );\n\n\t}\n\n} );\n\n/**\n * @author bhouston / http://clara.io\n */\n\nfunction Plane( normal, constant ) {\n\n\t// normal is assumed to be normalized\n\n\tthis.normal = ( normal !== undefined ) ? normal : new Vector3( 1, 0, 0 );\n\tthis.constant = ( constant !== undefined ) ? constant : 0;\n\n}\n\nObject.assign( Plane.prototype, {\n\n\tset: function ( normal, constant ) {\n\n\t\tthis.normal.copy( normal );\n\t\tthis.constant = constant;\n\n\t\treturn this;\n\n\t},\n\n\tsetComponents: function ( x, y, z, w ) {\n\n\t\tthis.normal.set( x, y, z );\n\t\tthis.constant = w;\n\n\t\treturn this;\n\n\t},\n\n\tsetFromNormalAndCoplanarPoint: function ( normal, point ) {\n\n\t\tthis.normal.copy( normal );\n\t\tthis.constant = - point.dot( this.normal );\n\n\t\treturn this;\n\n\t},\n\n\tsetFromCoplanarPoints: function () {\n\n\t\tvar v1 = new Vector3();\n\t\tvar v2 = new Vector3();\n\n\t\treturn function setFromCoplanarPoints( a, b, c ) {\n\n\t\t\tvar normal = v1.subVectors( c, b ).cross( v2.subVectors( a, b ) ).normalize();\n\n\t\t\t// Q: should an error be thrown if normal is zero (e.g. degenerate plane)?\n\n\t\t\tthis.setFromNormalAndCoplanarPoint( normal, a );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( plane ) {\n\n\t\tthis.normal.copy( plane.normal );\n\t\tthis.constant = plane.constant;\n\n\t\treturn this;\n\n\t},\n\n\tnormalize: function () {\n\n\t\t// Note: will lead to a divide by zero if the plane is invalid.\n\n\t\tvar inverseNormalLength = 1.0 / this.normal.length();\n\t\tthis.normal.multiplyScalar( inverseNormalLength );\n\t\tthis.constant *= inverseNormalLength;\n\n\t\treturn this;\n\n\t},\n\n\tnegate: function () {\n\n\t\tthis.constant *= - 1;\n\t\tthis.normal.negate();\n\n\t\treturn this;\n\n\t},\n\n\tdistanceToPoint: function ( point ) {\n\n\t\treturn this.normal.dot( point ) + this.constant;\n\n\t},\n\n\tdistanceToSphere: function ( sphere ) {\n\n\t\treturn this.distanceToPoint( sphere.center ) - sphere.radius;\n\n\t},\n\n\tprojectPoint: function ( point, target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Plane: .projectPoint() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn target.copy( this.normal ).multiplyScalar( - this.distanceToPoint( point ) ).add( point );\n\n\t},\n\n\tintersectLine: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function intersectLine( line, target ) {\n\n\t\t\tif ( target === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Plane: .intersectLine() target is now required' );\n\t\t\t\ttarget = new Vector3();\n\n\t\t\t}\n\n\t\t\tvar direction = line.delta( v1 );\n\n\t\t\tvar denominator = this.normal.dot( direction );\n\n\t\t\tif ( denominator === 0 ) {\n\n\t\t\t\t// line is coplanar, return origin\n\t\t\t\tif ( this.distanceToPoint( line.start ) === 0 ) {\n\n\t\t\t\t\treturn target.copy( line.start );\n\n\t\t\t\t}\n\n\t\t\t\t// Unsure if this is the correct method to handle this case.\n\t\t\t\treturn undefined;\n\n\t\t\t}\n\n\t\t\tvar t = - ( line.start.dot( this.normal ) + this.constant ) / denominator;\n\n\t\t\tif ( t < 0 || t > 1 ) {\n\n\t\t\t\treturn undefined;\n\n\t\t\t}\n\n\t\t\treturn target.copy( direction ).multiplyScalar( t ).add( line.start );\n\n\t\t};\n\n\t}(),\n\n\tintersectsLine: function ( line ) {\n\n\t\t// Note: this tests if a line intersects the plane, not whether it (or its end-points) are coplanar with it.\n\n\t\tvar startSign = this.distanceToPoint( line.start );\n\t\tvar endSign = this.distanceToPoint( line.end );\n\n\t\treturn ( startSign < 0 && endSign > 0 ) || ( endSign < 0 && startSign > 0 );\n\n\t},\n\n\tintersectsBox: function ( box ) {\n\n\t\treturn box.intersectsPlane( this );\n\n\t},\n\n\tintersectsSphere: function ( sphere ) {\n\n\t\treturn sphere.intersectsPlane( this );\n\n\t},\n\n\tcoplanarPoint: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Plane: .coplanarPoint() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn target.copy( this.normal ).multiplyScalar( - this.constant );\n\n\t},\n\n\tapplyMatrix4: function () {\n\n\t\tvar v1 = new Vector3();\n\t\tvar m1 = new Matrix3();\n\n\t\treturn function applyMatrix4( matrix, optionalNormalMatrix ) {\n\n\t\t\tvar normalMatrix = optionalNormalMatrix || m1.getNormalMatrix( matrix );\n\n\t\t\tvar referencePoint = this.coplanarPoint( v1 ).applyMatrix4( matrix );\n\n\t\t\tvar normal = this.normal.applyMatrix3( normalMatrix ).normalize();\n\n\t\t\tthis.constant = - referencePoint.dot( normal );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\ttranslate: function ( offset ) {\n\n\t\tthis.constant -= offset.dot( this.normal );\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( plane ) {\n\n\t\treturn plane.normal.equals( this.normal ) && ( plane.constant === this.constant );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n * @author bhouston / http://clara.io\n */\n\nfunction Frustum( p0, p1, p2, p3, p4, p5 ) {\n\n\tthis.planes = [\n\n\t\t( p0 !== undefined ) ? p0 : new Plane(),\n\t\t( p1 !== undefined ) ? p1 : new Plane(),\n\t\t( p2 !== undefined ) ? p2 : new Plane(),\n\t\t( p3 !== undefined ) ? p3 : new Plane(),\n\t\t( p4 !== undefined ) ? p4 : new Plane(),\n\t\t( p5 !== undefined ) ? p5 : new Plane()\n\n\t];\n\n}\n\nObject.assign( Frustum.prototype, {\n\n\tset: function ( p0, p1, p2, p3, p4, p5 ) {\n\n\t\tvar planes = this.planes;\n\n\t\tplanes[ 0 ].copy( p0 );\n\t\tplanes[ 1 ].copy( p1 );\n\t\tplanes[ 2 ].copy( p2 );\n\t\tplanes[ 3 ].copy( p3 );\n\t\tplanes[ 4 ].copy( p4 );\n\t\tplanes[ 5 ].copy( p5 );\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( frustum ) {\n\n\t\tvar planes = this.planes;\n\n\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\tplanes[ i ].copy( frustum.planes[ i ] );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tsetFromMatrix: function ( m ) {\n\n\t\tvar planes = this.planes;\n\t\tvar me = m.elements;\n\t\tvar me0 = me[ 0 ], me1 = me[ 1 ], me2 = me[ 2 ], me3 = me[ 3 ];\n\t\tvar me4 = me[ 4 ], me5 = me[ 5 ], me6 = me[ 6 ], me7 = me[ 7 ];\n\t\tvar me8 = me[ 8 ], me9 = me[ 9 ], me10 = me[ 10 ], me11 = me[ 11 ];\n\t\tvar me12 = me[ 12 ], me13 = me[ 13 ], me14 = me[ 14 ], me15 = me[ 15 ];\n\n\t\tplanes[ 0 ].setComponents( me3 - me0, me7 - me4, me11 - me8, me15 - me12 ).normalize();\n\t\tplanes[ 1 ].setComponents( me3 + me0, me7 + me4, me11 + me8, me15 + me12 ).normalize();\n\t\tplanes[ 2 ].setComponents( me3 + me1, me7 + me5, me11 + me9, me15 + me13 ).normalize();\n\t\tplanes[ 3 ].setComponents( me3 - me1, me7 - me5, me11 - me9, me15 - me13 ).normalize();\n\t\tplanes[ 4 ].setComponents( me3 - me2, me7 - me6, me11 - me10, me15 - me14 ).normalize();\n\t\tplanes[ 5 ].setComponents( me3 + me2, me7 + me6, me11 + me10, me15 + me14 ).normalize();\n\n\t\treturn this;\n\n\t},\n\n\tintersectsObject: function () {\n\n\t\tvar sphere = new Sphere();\n\n\t\treturn function intersectsObject( object ) {\n\n\t\t\tvar geometry = object.geometry;\n\n\t\t\tif ( geometry.boundingSphere === null )\n\t\t\t\tgeometry.computeBoundingSphere();\n\n\t\t\tsphere.copy( geometry.boundingSphere )\n\t\t\t\t.applyMatrix4( object.matrixWorld );\n\n\t\t\treturn this.intersectsSphere( sphere );\n\n\t\t};\n\n\t}(),\n\n\tintersectsSprite: function () {\n\n\t\tvar sphere = new Sphere();\n\n\t\treturn function intersectsSprite( sprite ) {\n\n\t\t\tsphere.center.set( 0, 0, 0 );\n\t\t\tsphere.radius = 0.7071067811865476;\n\t\t\tsphere.applyMatrix4( sprite.matrixWorld );\n\n\t\t\treturn this.intersectsSphere( sphere );\n\n\t\t};\n\n\t}(),\n\n\tintersectsSphere: function ( sphere ) {\n\n\t\tvar planes = this.planes;\n\t\tvar center = sphere.center;\n\t\tvar negRadius = - sphere.radius;\n\n\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\tvar distance = planes[ i ].distanceToPoint( center );\n\n\t\t\tif ( distance < negRadius ) {\n\n\t\t\t\treturn false;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn true;\n\n\t},\n\n\tintersectsBox: function () {\n\n\t\tvar p1 = new Vector3(),\n\t\t\tp2 = new Vector3();\n\n\t\treturn function intersectsBox( box ) {\n\n\t\t\tvar planes = this.planes;\n\n\t\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\t\tvar plane = planes[ i ];\n\n\t\t\t\tp1.x = plane.normal.x > 0 ? box.min.x : box.max.x;\n\t\t\t\tp2.x = plane.normal.x > 0 ? box.max.x : box.min.x;\n\t\t\t\tp1.y = plane.normal.y > 0 ? box.min.y : box.max.y;\n\t\t\t\tp2.y = plane.normal.y > 0 ? box.max.y : box.min.y;\n\t\t\t\tp1.z = plane.normal.z > 0 ? box.min.z : box.max.z;\n\t\t\t\tp2.z = plane.normal.z > 0 ? box.max.z : box.min.z;\n\n\t\t\t\tvar d1 = plane.distanceToPoint( p1 );\n\t\t\t\tvar d2 = plane.distanceToPoint( p2 );\n\n\t\t\t\t// if both outside plane, no intersection\n\n\t\t\t\tif ( d1 < 0 && d2 < 0 ) {\n\n\t\t\t\t\treturn false;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn true;\n\n\t\t};\n\n\t}(),\n\n\tcontainsPoint: function ( point ) {\n\n\t\tvar planes = this.planes;\n\n\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\tif ( planes[ i ].distanceToPoint( point ) < 0 ) {\n\n\t\t\t\treturn false;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn true;\n\n\t}\n\n} );\n\nvar alphamap_fragment = \"#ifdef USE_ALPHAMAP\\n\\tdiffuseColor.a *= texture2D( alphaMap, vUv ).g;\\n#endif\\n\";\n\nvar alphamap_pars_fragment = \"#ifdef USE_ALPHAMAP\\n\\tuniform sampler2D alphaMap;\\n#endif\\n\";\n\nvar alphatest_fragment = \"#ifdef ALPHATEST\\n\\tif ( diffuseColor.a < ALPHATEST ) discard;\\n#endif\\n\";\n\nvar aomap_fragment = \"#ifdef USE_AOMAP\\n\\tfloat ambientOcclusion = ( texture2D( aoMap, vUv2 ).r - 1.0 ) * aoMapIntensity + 1.0;\\n\\treflectedLight.indirectDiffuse *= ambientOcclusion;\\n\\t#if defined( USE_ENVMAP ) && defined( PHYSICAL )\\n\\t\\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\\n\\t\\treflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.specularRoughness );\\n\\t#endif\\n#endif\\n\";\n\nvar aomap_pars_fragment = \"#ifdef USE_AOMAP\\n\\tuniform sampler2D aoMap;\\n\\tuniform float aoMapIntensity;\\n#endif\";\n\nvar begin_vertex = \"\\nvec3 transformed = vec3( position );\\n\";\n\nvar beginnormal_vertex = \"\\nvec3 objectNormal = vec3( normal );\\n\";\n\nvar bsdfs = \"float punctualLightIntensityToIrradianceFactor( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) {\\n\\tif( decayExponent > 0.0 ) {\\n#if defined ( PHYSICALLY_CORRECT_LIGHTS )\\n\\t\\tfloat distanceFalloff = 1.0 / max( pow( lightDistance, decayExponent ), 0.01 );\\n\\t\\tfloat maxDistanceCutoffFactor = pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) );\\n\\t\\treturn distanceFalloff * maxDistanceCutoffFactor;\\n#else\\n\\t\\treturn pow( saturate( -lightDistance / cutoffDistance + 1.0 ), decayExponent );\\n#endif\\n\\t}\\n\\treturn 1.0;\\n}\\nvec3 BRDF_Diffuse_Lambert( const in vec3 diffuseColor ) {\\n\\treturn RECIPROCAL_PI * diffuseColor;\\n}\\nvec3 F_Schlick( const in vec3 specularColor, const in float dotLH ) {\\n\\tfloat fresnel = exp2( ( -5.55473 * dotLH - 6.98316 ) * dotLH );\\n\\treturn ( 1.0 - specularColor ) * fresnel + specularColor;\\n}\\nfloat G_GGX_Smith( const in float alpha, const in float dotNL, const in float dotNV ) {\\n\\tfloat a2 = pow2( alpha );\\n\\tfloat gl = dotNL + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\\n\\tfloat gv = dotNV + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\\n\\treturn 1.0 / ( gl * gv );\\n}\\nfloat G_GGX_SmithCorrelated( const in float alpha, const in float dotNL, const in float dotNV ) {\\n\\tfloat a2 = pow2( alpha );\\n\\tfloat gv = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\\n\\tfloat gl = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\\n\\treturn 0.5 / max( gv + gl, EPSILON );\\n}\\nfloat D_GGX( const in float alpha, const in float dotNH ) {\\n\\tfloat a2 = pow2( alpha );\\n\\tfloat denom = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0;\\n\\treturn RECIPROCAL_PI * a2 / pow2( denom );\\n}\\nvec3 BRDF_Specular_GGX( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float roughness ) {\\n\\tfloat alpha = pow2( roughness );\\n\\tvec3 halfDir = normalize( incidentLight.direction + geometry.viewDir );\\n\\tfloat dotNL = saturate( dot( geometry.normal, incidentLight.direction ) );\\n\\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\\n\\tfloat dotNH = saturate( dot( geometry.normal, halfDir ) );\\n\\tfloat dotLH = saturate( dot( incidentLight.direction, halfDir ) );\\n\\tvec3 F = F_Schlick( specularColor, dotLH );\\n\\tfloat G = G_GGX_SmithCorrelated( alpha, dotNL, dotNV );\\n\\tfloat D = D_GGX( alpha, dotNH );\\n\\treturn F * ( G * D );\\n}\\nvec2 LTC_Uv( const in vec3 N, const in vec3 V, const in float roughness ) {\\n\\tconst float LUT_SIZE  = 64.0;\\n\\tconst float LUT_SCALE = ( LUT_SIZE - 1.0 ) / LUT_SIZE;\\n\\tconst float LUT_BIAS  = 0.5 / LUT_SIZE;\\n\\tfloat dotNV = saturate( dot( N, V ) );\\n\\tvec2 uv = vec2( roughness, sqrt( 1.0 - dotNV ) );\\n\\tuv = uv * LUT_SCALE + LUT_BIAS;\\n\\treturn uv;\\n}\\nfloat LTC_ClippedSphereFormFactor( const in vec3 f ) {\\n\\tfloat l = length( f );\\n\\treturn max( ( l * l + f.z ) / ( l + 1.0 ), 0.0 );\\n}\\nvec3 LTC_EdgeVectorFormFactor( const in vec3 v1, const in vec3 v2 ) {\\n\\tfloat x = dot( v1, v2 );\\n\\tfloat y = abs( x );\\n\\tfloat a = 0.8543985 + ( 0.4965155 + 0.0145206 * y ) * y;\\n\\tfloat b = 3.4175940 + ( 4.1616724 + y ) * y;\\n\\tfloat v = a / b;\\n\\tfloat theta_sintheta = ( x > 0.0 ) ? v : 0.5 * inversesqrt( max( 1.0 - x * x, 1e-7 ) ) - v;\\n\\treturn cross( v1, v2 ) * theta_sintheta;\\n}\\nvec3 LTC_Evaluate( const in vec3 N, const in vec3 V, const in vec3 P, const in mat3 mInv, const in vec3 rectCoords[ 4 ] ) {\\n\\tvec3 v1 = rectCoords[ 1 ] - rectCoords[ 0 ];\\n\\tvec3 v2 = rectCoords[ 3 ] - rectCoords[ 0 ];\\n\\tvec3 lightNormal = cross( v1, v2 );\\n\\tif( dot( lightNormal, P - rectCoords[ 0 ] ) < 0.0 ) return vec3( 0.0 );\\n\\tvec3 T1, T2;\\n\\tT1 = normalize( V - N * dot( V, N ) );\\n\\tT2 = - cross( N, T1 );\\n\\tmat3 mat = mInv * transposeMat3( mat3( T1, T2, N ) );\\n\\tvec3 coords[ 4 ];\\n\\tcoords[ 0 ] = mat * ( rectCoords[ 0 ] - P );\\n\\tcoords[ 1 ] = mat * ( rectCoords[ 1 ] - P );\\n\\tcoords[ 2 ] = mat * ( rectCoords[ 2 ] - P );\\n\\tcoords[ 3 ] = mat * ( rectCoords[ 3 ] - P );\\n\\tcoords[ 0 ] = normalize( coords[ 0 ] );\\n\\tcoords[ 1 ] = normalize( coords[ 1 ] );\\n\\tcoords[ 2 ] = normalize( coords[ 2 ] );\\n\\tcoords[ 3 ] = normalize( coords[ 3 ] );\\n\\tvec3 vectorFormFactor = vec3( 0.0 );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 0 ], coords[ 1 ] );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 1 ], coords[ 2 ] );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 2 ], coords[ 3 ] );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 3 ], coords[ 0 ] );\\n\\tfloat result = LTC_ClippedSphereFormFactor( vectorFormFactor );\\n\\treturn vec3( result );\\n}\\nvec3 BRDF_Specular_GGX_Environment( const in GeometricContext geometry, const in vec3 specularColor, const in float roughness ) {\\n\\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\\n\\tconst vec4 c0 = vec4( - 1, - 0.0275, - 0.572, 0.022 );\\n\\tconst vec4 c1 = vec4( 1, 0.0425, 1.04, - 0.04 );\\n\\tvec4 r = roughness * c0 + c1;\\n\\tfloat a004 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\\n\\tvec2 AB = vec2( -1.04, 1.04 ) * a004 + r.zw;\\n\\treturn specularColor * AB.x + AB.y;\\n}\\nfloat G_BlinnPhong_Implicit( ) {\\n\\treturn 0.25;\\n}\\nfloat D_BlinnPhong( const in float shininess, const in float dotNH ) {\\n\\treturn RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow( dotNH, shininess );\\n}\\nvec3 BRDF_Specular_BlinnPhong( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float shininess ) {\\n\\tvec3 halfDir = normalize( incidentLight.direction + geometry.viewDir );\\n\\tfloat dotNH = saturate( dot( geometry.normal, halfDir ) );\\n\\tfloat dotLH = saturate( dot( incidentLight.direction, halfDir ) );\\n\\tvec3 F = F_Schlick( specularColor, dotLH );\\n\\tfloat G = G_BlinnPhong_Implicit( );\\n\\tfloat D = D_BlinnPhong( shininess, dotNH );\\n\\treturn F * ( G * D );\\n}\\nfloat GGXRoughnessToBlinnExponent( const in float ggxRoughness ) {\\n\\treturn ( 2.0 / pow2( ggxRoughness + 0.0001 ) - 2.0 );\\n}\\nfloat BlinnExponentToGGXRoughness( const in float blinnExponent ) {\\n\\treturn sqrt( 2.0 / ( blinnExponent + 2.0 ) );\\n}\\n\";\n\nvar bumpmap_pars_fragment = \"#ifdef USE_BUMPMAP\\n\\tuniform sampler2D bumpMap;\\n\\tuniform float bumpScale;\\n\\tvec2 dHdxy_fwd() {\\n\\t\\tvec2 dSTdx = dFdx( vUv );\\n\\t\\tvec2 dSTdy = dFdy( vUv );\\n\\t\\tfloat Hll = bumpScale * texture2D( bumpMap, vUv ).x;\\n\\t\\tfloat dBx = bumpScale * texture2D( bumpMap, vUv + dSTdx ).x - Hll;\\n\\t\\tfloat dBy = bumpScale * texture2D( bumpMap, vUv + dSTdy ).x - Hll;\\n\\t\\treturn vec2( dBx, dBy );\\n\\t}\\n\\tvec3 perturbNormalArb( vec3 surf_pos, vec3 surf_norm, vec2 dHdxy ) {\\n\\t\\tvec3 vSigmaX = vec3( dFdx( surf_pos.x ), dFdx( surf_pos.y ), dFdx( surf_pos.z ) );\\n\\t\\tvec3 vSigmaY = vec3( dFdy( surf_pos.x ), dFdy( surf_pos.y ), dFdy( surf_pos.z ) );\\n\\t\\tvec3 vN = surf_norm;\\n\\t\\tvec3 R1 = cross( vSigmaY, vN );\\n\\t\\tvec3 R2 = cross( vN, vSigmaX );\\n\\t\\tfloat fDet = dot( vSigmaX, R1 );\\n\\t\\tvec3 vGrad = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\\n\\t\\treturn normalize( abs( fDet ) * surf_norm - vGrad );\\n\\t}\\n#endif\\n\";\n\nvar clipping_planes_fragment = \"#if NUM_CLIPPING_PLANES > 0\\n\\tvec4 plane;\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < UNION_CLIPPING_PLANES; i ++ ) {\\n\\t\\tplane = clippingPlanes[ i ];\\n\\t\\tif ( dot( vViewPosition, plane.xyz ) > plane.w ) discard;\\n\\t}\\n\\t#if UNION_CLIPPING_PLANES < NUM_CLIPPING_PLANES\\n\\t\\tbool clipped = true;\\n\\t\\t#pragma unroll_loop\\n\\t\\tfor ( int i = UNION_CLIPPING_PLANES; i < NUM_CLIPPING_PLANES; i ++ ) {\\n\\t\\t\\tplane = clippingPlanes[ i ];\\n\\t\\t\\tclipped = ( dot( vViewPosition, plane.xyz ) > plane.w ) && clipped;\\n\\t\\t}\\n\\t\\tif ( clipped ) discard;\\n\\t#endif\\n#endif\\n\";\n\nvar clipping_planes_pars_fragment = \"#if NUM_CLIPPING_PLANES > 0\\n\\t#if ! defined( PHYSICAL ) && ! defined( PHONG )\\n\\t\\tvarying vec3 vViewPosition;\\n\\t#endif\\n\\tuniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ];\\n#endif\\n\";\n\nvar clipping_planes_pars_vertex = \"#if NUM_CLIPPING_PLANES > 0 && ! defined( PHYSICAL ) && ! defined( PHONG )\\n\\tvarying vec3 vViewPosition;\\n#endif\\n\";\n\nvar clipping_planes_vertex = \"#if NUM_CLIPPING_PLANES > 0 && ! defined( PHYSICAL ) && ! defined( PHONG )\\n\\tvViewPosition = - mvPosition.xyz;\\n#endif\\n\";\n\nvar color_fragment = \"#ifdef USE_COLOR\\n\\tdiffuseColor.rgb *= vColor;\\n#endif\";\n\nvar color_pars_fragment = \"#ifdef USE_COLOR\\n\\tvarying vec3 vColor;\\n#endif\\n\";\n\nvar color_pars_vertex = \"#ifdef USE_COLOR\\n\\tvarying vec3 vColor;\\n#endif\";\n\nvar color_vertex = \"#ifdef USE_COLOR\\n\\tvColor.xyz = color.xyz;\\n#endif\";\n\nvar common = \"#define PI 3.14159265359\\n#define PI2 6.28318530718\\n#define PI_HALF 1.5707963267949\\n#define RECIPROCAL_PI 0.31830988618\\n#define RECIPROCAL_PI2 0.15915494\\n#define LOG2 1.442695\\n#define EPSILON 1e-6\\n#define saturate(a) clamp( a, 0.0, 1.0 )\\n#define whiteCompliment(a) ( 1.0 - saturate( a ) )\\nfloat pow2( const in float x ) { return x*x; }\\nfloat pow3( const in float x ) { return x*x*x; }\\nfloat pow4( const in float x ) { float x2 = x*x; return x2*x2; }\\nfloat average( const in vec3 color ) { return dot( color, vec3( 0.3333 ) ); }\\nhighp float rand( const in vec2 uv ) {\\n\\tconst highp float a = 12.9898, b = 78.233, c = 43758.5453;\\n\\thighp float dt = dot( uv.xy, vec2( a,b ) ), sn = mod( dt, PI );\\n\\treturn fract(sin(sn) * c);\\n}\\nstruct IncidentLight {\\n\\tvec3 color;\\n\\tvec3 direction;\\n\\tbool visible;\\n};\\nstruct ReflectedLight {\\n\\tvec3 directDiffuse;\\n\\tvec3 directSpecular;\\n\\tvec3 indirectDiffuse;\\n\\tvec3 indirectSpecular;\\n};\\nstruct GeometricContext {\\n\\tvec3 position;\\n\\tvec3 normal;\\n\\tvec3 viewDir;\\n};\\nvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\\n\\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\\n}\\nvec3 inverseTransformDirection( in vec3 dir, in mat4 matrix ) {\\n\\treturn normalize( ( vec4( dir, 0.0 ) * matrix ).xyz );\\n}\\nvec3 projectOnPlane(in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\\n\\tfloat distance = dot( planeNormal, point - pointOnPlane );\\n\\treturn - distance * planeNormal + point;\\n}\\nfloat sideOfPlane( in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\\n\\treturn sign( dot( point - pointOnPlane, planeNormal ) );\\n}\\nvec3 linePlaneIntersect( in vec3 pointOnLine, in vec3 lineDirection, in vec3 pointOnPlane, in vec3 planeNormal ) {\\n\\treturn lineDirection * ( dot( planeNormal, pointOnPlane - pointOnLine ) / dot( planeNormal, lineDirection ) ) + pointOnLine;\\n}\\nmat3 transposeMat3( const in mat3 m ) {\\n\\tmat3 tmp;\\n\\ttmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\\n\\ttmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\\n\\ttmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\\n\\treturn tmp;\\n}\\nfloat linearToRelativeLuminance( const in vec3 color ) {\\n\\tvec3 weights = vec3( 0.2126, 0.7152, 0.0722 );\\n\\treturn dot( weights, color.rgb );\\n}\\n\";\n\nvar cube_uv_reflection_fragment = \"#ifdef ENVMAP_TYPE_CUBE_UV\\n#define cubeUV_textureSize (1024.0)\\nint getFaceFromDirection(vec3 direction) {\\n\\tvec3 absDirection = abs(direction);\\n\\tint face = -1;\\n\\tif( absDirection.x > absDirection.z ) {\\n\\t\\tif(absDirection.x > absDirection.y )\\n\\t\\t\\tface = direction.x > 0.0 ? 0 : 3;\\n\\t\\telse\\n\\t\\t\\tface = direction.y > 0.0 ? 1 : 4;\\n\\t}\\n\\telse {\\n\\t\\tif(absDirection.z > absDirection.y )\\n\\t\\t\\tface = direction.z > 0.0 ? 2 : 5;\\n\\t\\telse\\n\\t\\t\\tface = direction.y > 0.0 ? 1 : 4;\\n\\t}\\n\\treturn face;\\n}\\n#define cubeUV_maxLods1  (log2(cubeUV_textureSize*0.25) - 1.0)\\n#define cubeUV_rangeClamp (exp2((6.0 - 1.0) * 2.0))\\nvec2 MipLevelInfo( vec3 vec, float roughnessLevel, float roughness ) {\\n\\tfloat scale = exp2(cubeUV_maxLods1 - roughnessLevel);\\n\\tfloat dxRoughness = dFdx(roughness);\\n\\tfloat dyRoughness = dFdy(roughness);\\n\\tvec3 dx = dFdx( vec * scale * dxRoughness );\\n\\tvec3 dy = dFdy( vec * scale * dyRoughness );\\n\\tfloat d = max( dot( dx, dx ), dot( dy, dy ) );\\n\\td = clamp(d, 1.0, cubeUV_rangeClamp);\\n\\tfloat mipLevel = 0.5 * log2(d);\\n\\treturn vec2(floor(mipLevel), fract(mipLevel));\\n}\\n#define cubeUV_maxLods2 (log2(cubeUV_textureSize*0.25) - 2.0)\\n#define cubeUV_rcpTextureSize (1.0 / cubeUV_textureSize)\\nvec2 getCubeUV(vec3 direction, float roughnessLevel, float mipLevel) {\\n\\tmipLevel = roughnessLevel > cubeUV_maxLods2 - 3.0 ? 0.0 : mipLevel;\\n\\tfloat a = 16.0 * cubeUV_rcpTextureSize;\\n\\tvec2 exp2_packed = exp2( vec2( roughnessLevel, mipLevel ) );\\n\\tvec2 rcp_exp2_packed = vec2( 1.0 ) / exp2_packed;\\n\\tfloat powScale = exp2_packed.x * exp2_packed.y;\\n\\tfloat scale = rcp_exp2_packed.x * rcp_exp2_packed.y * 0.25;\\n\\tfloat mipOffset = 0.75*(1.0 - rcp_exp2_packed.y) * rcp_exp2_packed.x;\\n\\tbool bRes = mipLevel == 0.0;\\n\\tscale =  bRes && (scale < a) ? a : scale;\\n\\tvec3 r;\\n\\tvec2 offset;\\n\\tint face = getFaceFromDirection(direction);\\n\\tfloat rcpPowScale = 1.0 / powScale;\\n\\tif( face == 0) {\\n\\t\\tr = vec3(direction.x, -direction.z, direction.y);\\n\\t\\toffset = vec2(0.0+mipOffset,0.75 * rcpPowScale);\\n\\t\\toffset.y = bRes && (offset.y < 2.0*a) ? a : offset.y;\\n\\t}\\n\\telse if( face == 1) {\\n\\t\\tr = vec3(direction.y, direction.x, direction.z);\\n\\t\\toffset = vec2(scale+mipOffset, 0.75 * rcpPowScale);\\n\\t\\toffset.y = bRes && (offset.y < 2.0*a) ? a : offset.y;\\n\\t}\\n\\telse if( face == 2) {\\n\\t\\tr = vec3(direction.z, direction.x, direction.y);\\n\\t\\toffset = vec2(2.0*scale+mipOffset, 0.75 * rcpPowScale);\\n\\t\\toffset.y = bRes && (offset.y < 2.0*a) ? a : offset.y;\\n\\t}\\n\\telse if( face == 3) {\\n\\t\\tr = vec3(direction.x, direction.z, direction.y);\\n\\t\\toffset = vec2(0.0+mipOffset,0.5 * rcpPowScale);\\n\\t\\toffset.y = bRes && (offset.y < 2.0*a) ? 0.0 : offset.y;\\n\\t}\\n\\telse if( face == 4) {\\n\\t\\tr = vec3(direction.y, direction.x, -direction.z);\\n\\t\\toffset = vec2(scale+mipOffset, 0.5 * rcpPowScale);\\n\\t\\toffset.y = bRes && (offset.y < 2.0*a) ? 0.0 : offset.y;\\n\\t}\\n\\telse {\\n\\t\\tr = vec3(direction.z, -direction.x, direction.y);\\n\\t\\toffset = vec2(2.0*scale+mipOffset, 0.5 * rcpPowScale);\\n\\t\\toffset.y = bRes && (offset.y < 2.0*a) ? 0.0 : offset.y;\\n\\t}\\n\\tr = normalize(r);\\n\\tfloat texelOffset = 0.5 * cubeUV_rcpTextureSize;\\n\\tvec2 s = ( r.yz / abs( r.x ) + vec2( 1.0 ) ) * 0.5;\\n\\tvec2 base = offset + vec2( texelOffset );\\n\\treturn base + s * ( scale - 2.0 * texelOffset );\\n}\\n#define cubeUV_maxLods3 (log2(cubeUV_textureSize*0.25) - 3.0)\\nvec4 textureCubeUV(vec3 reflectedDirection, float roughness ) {\\n\\tfloat roughnessVal = roughness* cubeUV_maxLods3;\\n\\tfloat r1 = floor(roughnessVal);\\n\\tfloat r2 = r1 + 1.0;\\n\\tfloat t = fract(roughnessVal);\\n\\tvec2 mipInfo = MipLevelInfo(reflectedDirection, r1, roughness);\\n\\tfloat s = mipInfo.y;\\n\\tfloat level0 = mipInfo.x;\\n\\tfloat level1 = level0 + 1.0;\\n\\tlevel1 = level1 > 5.0 ? 5.0 : level1;\\n\\tlevel0 += min( floor( s + 0.5 ), 5.0 );\\n\\tvec2 uv_10 = getCubeUV(reflectedDirection, r1, level0);\\n\\tvec4 color10 = envMapTexelToLinear(texture2D(envMap, uv_10));\\n\\tvec2 uv_20 = getCubeUV(reflectedDirection, r2, level0);\\n\\tvec4 color20 = envMapTexelToLinear(texture2D(envMap, uv_20));\\n\\tvec4 result = mix(color10, color20, t);\\n\\treturn vec4(result.rgb, 1.0);\\n}\\n#endif\\n\";\n\nvar defaultnormal_vertex = \"vec3 transformedNormal = normalMatrix * objectNormal;\\n#ifdef FLIP_SIDED\\n\\ttransformedNormal = - transformedNormal;\\n#endif\\n\";\n\nvar displacementmap_pars_vertex = \"#ifdef USE_DISPLACEMENTMAP\\n\\tuniform sampler2D displacementMap;\\n\\tuniform float displacementScale;\\n\\tuniform float displacementBias;\\n#endif\\n\";\n\nvar displacementmap_vertex = \"#ifdef USE_DISPLACEMENTMAP\\n\\ttransformed += normalize( objectNormal ) * ( texture2D( displacementMap, uv ).x * displacementScale + displacementBias );\\n#endif\\n\";\n\nvar emissivemap_fragment = \"#ifdef USE_EMISSIVEMAP\\n\\tvec4 emissiveColor = texture2D( emissiveMap, vUv );\\n\\temissiveColor.rgb = emissiveMapTexelToLinear( emissiveColor ).rgb;\\n\\ttotalEmissiveRadiance *= emissiveColor.rgb;\\n#endif\\n\";\n\nvar emissivemap_pars_fragment = \"#ifdef USE_EMISSIVEMAP\\n\\tuniform sampler2D emissiveMap;\\n#endif\\n\";\n\nvar encodings_fragment = \"  gl_FragColor = linearToOutputTexel( gl_FragColor );\\n\";\n\nvar encodings_pars_fragment = \"\\nvec4 LinearToLinear( in vec4 value ) {\\n\\treturn value;\\n}\\nvec4 GammaToLinear( in vec4 value, in float gammaFactor ) {\\n\\treturn vec4( pow( value.xyz, vec3( gammaFactor ) ), value.w );\\n}\\nvec4 LinearToGamma( in vec4 value, in float gammaFactor ) {\\n\\treturn vec4( pow( value.xyz, vec3( 1.0 / gammaFactor ) ), value.w );\\n}\\nvec4 sRGBToLinear( in vec4 value ) {\\n\\treturn vec4( mix( pow( value.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), value.rgb * 0.0773993808, vec3( lessThanEqual( value.rgb, vec3( 0.04045 ) ) ) ), value.w );\\n}\\nvec4 LinearTosRGB( in vec4 value ) {\\n\\treturn vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.w );\\n}\\nvec4 RGBEToLinear( in vec4 value ) {\\n\\treturn vec4( value.rgb * exp2( value.a * 255.0 - 128.0 ), 1.0 );\\n}\\nvec4 LinearToRGBE( in vec4 value ) {\\n\\tfloat maxComponent = max( max( value.r, value.g ), value.b );\\n\\tfloat fExp = clamp( ceil( log2( maxComponent ) ), -128.0, 127.0 );\\n\\treturn vec4( value.rgb / exp2( fExp ), ( fExp + 128.0 ) / 255.0 );\\n}\\nvec4 RGBMToLinear( in vec4 value, in float maxRange ) {\\n\\treturn vec4( value.xyz * value.w * maxRange, 1.0 );\\n}\\nvec4 LinearToRGBM( in vec4 value, in float maxRange ) {\\n\\tfloat maxRGB = max( value.x, max( value.g, value.b ) );\\n\\tfloat M      = clamp( maxRGB / maxRange, 0.0, 1.0 );\\n\\tM            = ceil( M * 255.0 ) / 255.0;\\n\\treturn vec4( value.rgb / ( M * maxRange ), M );\\n}\\nvec4 RGBDToLinear( in vec4 value, in float maxRange ) {\\n\\treturn vec4( value.rgb * ( ( maxRange / 255.0 ) / value.a ), 1.0 );\\n}\\nvec4 LinearToRGBD( in vec4 value, in float maxRange ) {\\n\\tfloat maxRGB = max( value.x, max( value.g, value.b ) );\\n\\tfloat D      = max( maxRange / maxRGB, 1.0 );\\n\\tD            = min( floor( D ) / 255.0, 1.0 );\\n\\treturn vec4( value.rgb * ( D * ( 255.0 / maxRange ) ), D );\\n}\\nconst mat3 cLogLuvM = mat3( 0.2209, 0.3390, 0.4184, 0.1138, 0.6780, 0.7319, 0.0102, 0.1130, 0.2969 );\\nvec4 LinearToLogLuv( in vec4 value )  {\\n\\tvec3 Xp_Y_XYZp = value.rgb * cLogLuvM;\\n\\tXp_Y_XYZp = max(Xp_Y_XYZp, vec3(1e-6, 1e-6, 1e-6));\\n\\tvec4 vResult;\\n\\tvResult.xy = Xp_Y_XYZp.xy / Xp_Y_XYZp.z;\\n\\tfloat Le = 2.0 * log2(Xp_Y_XYZp.y) + 127.0;\\n\\tvResult.w = fract(Le);\\n\\tvResult.z = (Le - (floor(vResult.w*255.0))/255.0)/255.0;\\n\\treturn vResult;\\n}\\nconst mat3 cLogLuvInverseM = mat3( 6.0014, -2.7008, -1.7996, -1.3320, 3.1029, -5.7721, 0.3008, -1.0882, 5.6268 );\\nvec4 LogLuvToLinear( in vec4 value ) {\\n\\tfloat Le = value.z * 255.0 + value.w;\\n\\tvec3 Xp_Y_XYZp;\\n\\tXp_Y_XYZp.y = exp2((Le - 127.0) / 2.0);\\n\\tXp_Y_XYZp.z = Xp_Y_XYZp.y / value.y;\\n\\tXp_Y_XYZp.x = value.x * Xp_Y_XYZp.z;\\n\\tvec3 vRGB = Xp_Y_XYZp.rgb * cLogLuvInverseM;\\n\\treturn vec4( max(vRGB, 0.0), 1.0 );\\n}\\n\";\n\nvar envmap_fragment = \"#ifdef USE_ENVMAP\\n\\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\\n\\t\\tvec3 cameraToVertex = normalize( vWorldPosition - cameraPosition );\\n\\t\\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\\n\\t\\t#ifdef ENVMAP_MODE_REFLECTION\\n\\t\\t\\tvec3 reflectVec = reflect( cameraToVertex, worldNormal );\\n\\t\\t#else\\n\\t\\t\\tvec3 reflectVec = refract( cameraToVertex, worldNormal, refractionRatio );\\n\\t\\t#endif\\n\\t#else\\n\\t\\tvec3 reflectVec = vReflect;\\n\\t#endif\\n\\t#ifdef ENVMAP_TYPE_CUBE\\n\\t\\tvec4 envColor = textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) );\\n\\t#elif defined( ENVMAP_TYPE_EQUIREC )\\n\\t\\tvec2 sampleUV;\\n\\t\\treflectVec = normalize( reflectVec );\\n\\t\\tsampleUV.y = asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\\n\\t\\tsampleUV.x = atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\\n\\t\\tvec4 envColor = texture2D( envMap, sampleUV );\\n\\t#elif defined( ENVMAP_TYPE_SPHERE )\\n\\t\\treflectVec = normalize( reflectVec );\\n\\t\\tvec3 reflectView = normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0, 0.0, 1.0 ) );\\n\\t\\tvec4 envColor = texture2D( envMap, reflectView.xy * 0.5 + 0.5 );\\n\\t#else\\n\\t\\tvec4 envColor = vec4( 0.0 );\\n\\t#endif\\n\\tenvColor = envMapTexelToLinear( envColor );\\n\\t#ifdef ENVMAP_BLENDING_MULTIPLY\\n\\t\\toutgoingLight = mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity );\\n\\t#elif defined( ENVMAP_BLENDING_MIX )\\n\\t\\toutgoingLight = mix( outgoingLight, envColor.xyz, specularStrength * reflectivity );\\n\\t#elif defined( ENVMAP_BLENDING_ADD )\\n\\t\\toutgoingLight += envColor.xyz * specularStrength * reflectivity;\\n\\t#endif\\n#endif\\n\";\n\nvar envmap_pars_fragment = \"#if defined( USE_ENVMAP ) || defined( PHYSICAL )\\n\\tuniform float reflectivity;\\n\\tuniform float envMapIntensity;\\n#endif\\n#ifdef USE_ENVMAP\\n\\t#if ! defined( PHYSICAL ) && ( defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG ) )\\n\\t\\tvarying vec3 vWorldPosition;\\n\\t#endif\\n\\t#ifdef ENVMAP_TYPE_CUBE\\n\\t\\tuniform samplerCube envMap;\\n\\t#else\\n\\t\\tuniform sampler2D envMap;\\n\\t#endif\\n\\tuniform float flipEnvMap;\\n\\tuniform int maxMipLevel;\\n\\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG ) || defined( PHYSICAL )\\n\\t\\tuniform float refractionRatio;\\n\\t#else\\n\\t\\tvarying vec3 vReflect;\\n\\t#endif\\n#endif\\n\";\n\nvar envmap_pars_vertex = \"#ifdef USE_ENVMAP\\n\\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\\n\\t\\tvarying vec3 vWorldPosition;\\n\\t#else\\n\\t\\tvarying vec3 vReflect;\\n\\t\\tuniform float refractionRatio;\\n\\t#endif\\n#endif\\n\";\n\nvar envmap_vertex = \"#ifdef USE_ENVMAP\\n\\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\\n\\t\\tvWorldPosition = worldPosition.xyz;\\n\\t#else\\n\\t\\tvec3 cameraToVertex = normalize( worldPosition.xyz - cameraPosition );\\n\\t\\tvec3 worldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\\n\\t\\t#ifdef ENVMAP_MODE_REFLECTION\\n\\t\\t\\tvReflect = reflect( cameraToVertex, worldNormal );\\n\\t\\t#else\\n\\t\\t\\tvReflect = refract( cameraToVertex, worldNormal, refractionRatio );\\n\\t\\t#endif\\n\\t#endif\\n#endif\\n\";\n\nvar fog_vertex = \"\\n#ifdef USE_FOG\\nfogDepth = -mvPosition.z;\\n#endif\";\n\nvar fog_pars_vertex = \"#ifdef USE_FOG\\n  varying float fogDepth;\\n#endif\\n\";\n\nvar fog_fragment = \"#ifdef USE_FOG\\n\\t#ifdef FOG_EXP2\\n\\t\\tfloat fogFactor = whiteCompliment( exp2( - fogDensity * fogDensity * fogDepth * fogDepth * LOG2 ) );\\n\\t#else\\n\\t\\tfloat fogFactor = smoothstep( fogNear, fogFar, fogDepth );\\n\\t#endif\\n\\tgl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor );\\n#endif\\n\";\n\nvar fog_pars_fragment = \"#ifdef USE_FOG\\n\\tuniform vec3 fogColor;\\n\\tvarying float fogDepth;\\n\\t#ifdef FOG_EXP2\\n\\t\\tuniform float fogDensity;\\n\\t#else\\n\\t\\tuniform float fogNear;\\n\\t\\tuniform float fogFar;\\n\\t#endif\\n#endif\\n\";\n\nvar gradientmap_pars_fragment = \"#ifdef TOON\\n\\tuniform sampler2D gradientMap;\\n\\tvec3 getGradientIrradiance( vec3 normal, vec3 lightDirection ) {\\n\\t\\tfloat dotNL = dot( normal, lightDirection );\\n\\t\\tvec2 coord = vec2( dotNL * 0.5 + 0.5, 0.0 );\\n\\t\\t#ifdef USE_GRADIENTMAP\\n\\t\\t\\treturn texture2D( gradientMap, coord ).rgb;\\n\\t\\t#else\\n\\t\\t\\treturn ( coord.x < 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 );\\n\\t\\t#endif\\n\\t}\\n#endif\\n\";\n\nvar lightmap_fragment = \"#ifdef USE_LIGHTMAP\\n\\treflectedLight.indirectDiffuse += PI * texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\\n#endif\\n\";\n\nvar lightmap_pars_fragment = \"#ifdef USE_LIGHTMAP\\n\\tuniform sampler2D lightMap;\\n\\tuniform float lightMapIntensity;\\n#endif\";\n\nvar lights_lambert_vertex = \"vec3 diffuse = vec3( 1.0 );\\nGeometricContext geometry;\\ngeometry.position = mvPosition.xyz;\\ngeometry.normal = normalize( transformedNormal );\\ngeometry.viewDir = normalize( -mvPosition.xyz );\\nGeometricContext backGeometry;\\nbackGeometry.position = geometry.position;\\nbackGeometry.normal = -geometry.normal;\\nbackGeometry.viewDir = geometry.viewDir;\\nvLightFront = vec3( 0.0 );\\n#ifdef DOUBLE_SIDED\\n\\tvLightBack = vec3( 0.0 );\\n#endif\\nIncidentLight directLight;\\nfloat dotNL;\\nvec3 directLightColor_Diffuse;\\n#if NUM_POINT_LIGHTS > 0\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\\n\\t\\tgetPointDirectLightIrradiance( pointLights[ i ], geometry, directLight );\\n\\t\\tdotNL = dot( geometry.normal, directLight.direction );\\n\\t\\tdirectLightColor_Diffuse = PI * directLight.color;\\n\\t\\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += saturate( -dotNL ) * directLightColor_Diffuse;\\n\\t\\t#endif\\n\\t}\\n#endif\\n#if NUM_SPOT_LIGHTS > 0\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\\n\\t\\tgetSpotDirectLightIrradiance( spotLights[ i ], geometry, directLight );\\n\\t\\tdotNL = dot( geometry.normal, directLight.direction );\\n\\t\\tdirectLightColor_Diffuse = PI * directLight.color;\\n\\t\\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += saturate( -dotNL ) * directLightColor_Diffuse;\\n\\t\\t#endif\\n\\t}\\n#endif\\n#if NUM_DIR_LIGHTS > 0\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\\n\\t\\tgetDirectionalDirectLightIrradiance( directionalLights[ i ], geometry, directLight );\\n\\t\\tdotNL = dot( geometry.normal, directLight.direction );\\n\\t\\tdirectLightColor_Diffuse = PI * directLight.color;\\n\\t\\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += saturate( -dotNL ) * directLightColor_Diffuse;\\n\\t\\t#endif\\n\\t}\\n#endif\\n#if NUM_HEMI_LIGHTS > 0\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\\n\\t\\tvLightFront += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry );\\n\\t\\t#endif\\n\\t}\\n#endif\\n\";\n\nvar lights_pars_begin = \"uniform vec3 ambientLightColor;\\nvec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {\\n\\tvec3 irradiance = ambientLightColor;\\n\\t#ifndef PHYSICALLY_CORRECT_LIGHTS\\n\\t\\tirradiance *= PI;\\n\\t#endif\\n\\treturn irradiance;\\n}\\n#if NUM_DIR_LIGHTS > 0\\n\\tstruct DirectionalLight {\\n\\t\\tvec3 direction;\\n\\t\\tvec3 color;\\n\\t\\tint shadow;\\n\\t\\tfloat shadowBias;\\n\\t\\tfloat shadowRadius;\\n\\t\\tvec2 shadowMapSize;\\n\\t};\\n\\tuniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];\\n\\tvoid getDirectionalDirectLightIrradiance( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight directLight ) {\\n\\t\\tdirectLight.color = directionalLight.color;\\n\\t\\tdirectLight.direction = directionalLight.direction;\\n\\t\\tdirectLight.visible = true;\\n\\t}\\n#endif\\n#if NUM_POINT_LIGHTS > 0\\n\\tstruct PointLight {\\n\\t\\tvec3 position;\\n\\t\\tvec3 color;\\n\\t\\tfloat distance;\\n\\t\\tfloat decay;\\n\\t\\tint shadow;\\n\\t\\tfloat shadowBias;\\n\\t\\tfloat shadowRadius;\\n\\t\\tvec2 shadowMapSize;\\n\\t\\tfloat shadowCameraNear;\\n\\t\\tfloat shadowCameraFar;\\n\\t};\\n\\tuniform PointLight pointLights[ NUM_POINT_LIGHTS ];\\n\\tvoid getPointDirectLightIrradiance( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight directLight ) {\\n\\t\\tvec3 lVector = pointLight.position - geometry.position;\\n\\t\\tdirectLight.direction = normalize( lVector );\\n\\t\\tfloat lightDistance = length( lVector );\\n\\t\\tdirectLight.color = pointLight.color;\\n\\t\\tdirectLight.color *= punctualLightIntensityToIrradianceFactor( lightDistance, pointLight.distance, pointLight.decay );\\n\\t\\tdirectLight.visible = ( directLight.color != vec3( 0.0 ) );\\n\\t}\\n#endif\\n#if NUM_SPOT_LIGHTS > 0\\n\\tstruct SpotLight {\\n\\t\\tvec3 position;\\n\\t\\tvec3 direction;\\n\\t\\tvec3 color;\\n\\t\\tfloat distance;\\n\\t\\tfloat decay;\\n\\t\\tfloat coneCos;\\n\\t\\tfloat penumbraCos;\\n\\t\\tint shadow;\\n\\t\\tfloat shadowBias;\\n\\t\\tfloat shadowRadius;\\n\\t\\tvec2 shadowMapSize;\\n\\t};\\n\\tuniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];\\n\\tvoid getSpotDirectLightIrradiance( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight directLight  ) {\\n\\t\\tvec3 lVector = spotLight.position - geometry.position;\\n\\t\\tdirectLight.direction = normalize( lVector );\\n\\t\\tfloat lightDistance = length( lVector );\\n\\t\\tfloat angleCos = dot( directLight.direction, spotLight.direction );\\n\\t\\tif ( angleCos > spotLight.coneCos ) {\\n\\t\\t\\tfloat spotEffect = smoothstep( spotLight.coneCos, spotLight.penumbraCos, angleCos );\\n\\t\\t\\tdirectLight.color = spotLight.color;\\n\\t\\t\\tdirectLight.color *= spotEffect * punctualLightIntensityToIrradianceFactor( lightDistance, spotLight.distance, spotLight.decay );\\n\\t\\t\\tdirectLight.visible = true;\\n\\t\\t} else {\\n\\t\\t\\tdirectLight.color = vec3( 0.0 );\\n\\t\\t\\tdirectLight.visible = false;\\n\\t\\t}\\n\\t}\\n#endif\\n#if NUM_RECT_AREA_LIGHTS > 0\\n\\tstruct RectAreaLight {\\n\\t\\tvec3 color;\\n\\t\\tvec3 position;\\n\\t\\tvec3 halfWidth;\\n\\t\\tvec3 halfHeight;\\n\\t};\\n\\tuniform sampler2D ltc_1;\\tuniform sampler2D ltc_2;\\n\\tuniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];\\n#endif\\n#if NUM_HEMI_LIGHTS > 0\\n\\tstruct HemisphereLight {\\n\\t\\tvec3 direction;\\n\\t\\tvec3 skyColor;\\n\\t\\tvec3 groundColor;\\n\\t};\\n\\tuniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];\\n\\tvec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in GeometricContext geometry ) {\\n\\t\\tfloat dotNL = dot( geometry.normal, hemiLight.direction );\\n\\t\\tfloat hemiDiffuseWeight = 0.5 * dotNL + 0.5;\\n\\t\\tvec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );\\n\\t\\t#ifndef PHYSICALLY_CORRECT_LIGHTS\\n\\t\\t\\tirradiance *= PI;\\n\\t\\t#endif\\n\\t\\treturn irradiance;\\n\\t}\\n#endif\\n\";\n\nvar lights_pars_maps = \"#if defined( USE_ENVMAP ) && defined( PHYSICAL )\\n\\tvec3 getLightProbeIndirectIrradiance( const in GeometricContext geometry, const in int maxMIPLevel ) {\\n\\t\\tvec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );\\n\\t\\t#ifdef ENVMAP_TYPE_CUBE\\n\\t\\t\\tvec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\\n\\t\\t\\t#ifdef TEXTURE_LOD_EXT\\n\\t\\t\\t\\tvec4 envMapColor = textureCubeLodEXT( envMap, queryVec, float( maxMIPLevel ) );\\n\\t\\t\\t#else\\n\\t\\t\\t\\tvec4 envMapColor = textureCube( envMap, queryVec, float( maxMIPLevel ) );\\n\\t\\t\\t#endif\\n\\t\\t\\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\\n\\t\\t#elif defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\t\\tvec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\\n\\t\\t\\tvec4 envMapColor = textureCubeUV( queryVec, 1.0 );\\n\\t\\t#else\\n\\t\\t\\tvec4 envMapColor = vec4( 0.0 );\\n\\t\\t#endif\\n\\t\\treturn PI * envMapColor.rgb * envMapIntensity;\\n\\t}\\n\\tfloat getSpecularMIPLevel( const in float blinnShininessExponent, const in int maxMIPLevel ) {\\n\\t\\tfloat maxMIPLevelScalar = float( maxMIPLevel );\\n\\t\\tfloat desiredMIPLevel = maxMIPLevelScalar + 0.79248 - 0.5 * log2( pow2( blinnShininessExponent ) + 1.0 );\\n\\t\\treturn clamp( desiredMIPLevel, 0.0, maxMIPLevelScalar );\\n\\t}\\n\\tvec3 getLightProbeIndirectRadiance( const in GeometricContext geometry, const in float blinnShininessExponent, const in int maxMIPLevel ) {\\n\\t\\t#ifdef ENVMAP_MODE_REFLECTION\\n\\t\\t\\tvec3 reflectVec = reflect( -geometry.viewDir, geometry.normal );\\n\\t\\t#else\\n\\t\\t\\tvec3 reflectVec = refract( -geometry.viewDir, geometry.normal, refractionRatio );\\n\\t\\t#endif\\n\\t\\treflectVec = inverseTransformDirection( reflectVec, viewMatrix );\\n\\t\\tfloat specularMIPLevel = getSpecularMIPLevel( blinnShininessExponent, maxMIPLevel );\\n\\t\\t#ifdef ENVMAP_TYPE_CUBE\\n\\t\\t\\tvec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\\n\\t\\t\\t#ifdef TEXTURE_LOD_EXT\\n\\t\\t\\t\\tvec4 envMapColor = textureCubeLodEXT( envMap, queryReflectVec, specularMIPLevel );\\n\\t\\t\\t#else\\n\\t\\t\\t\\tvec4 envMapColor = textureCube( envMap, queryReflectVec, specularMIPLevel );\\n\\t\\t\\t#endif\\n\\t\\t\\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\\n\\t\\t#elif defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\t\\tvec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\\n\\t\\t\\tvec4 envMapColor = textureCubeUV(queryReflectVec, BlinnExponentToGGXRoughness(blinnShininessExponent));\\n\\t\\t#elif defined( ENVMAP_TYPE_EQUIREC )\\n\\t\\t\\tvec2 sampleUV;\\n\\t\\t\\tsampleUV.y = asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\\n\\t\\t\\tsampleUV.x = atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\\n\\t\\t\\t#ifdef TEXTURE_LOD_EXT\\n\\t\\t\\t\\tvec4 envMapColor = texture2DLodEXT( envMap, sampleUV, specularMIPLevel );\\n\\t\\t\\t#else\\n\\t\\t\\t\\tvec4 envMapColor = texture2D( envMap, sampleUV, specularMIPLevel );\\n\\t\\t\\t#endif\\n\\t\\t\\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\\n\\t\\t#elif defined( ENVMAP_TYPE_SPHERE )\\n\\t\\t\\tvec3 reflectView = normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0,0.0,1.0 ) );\\n\\t\\t\\t#ifdef TEXTURE_LOD_EXT\\n\\t\\t\\t\\tvec4 envMapColor = texture2DLodEXT( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\\n\\t\\t\\t#else\\n\\t\\t\\t\\tvec4 envMapColor = texture2D( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\\n\\t\\t\\t#endif\\n\\t\\t\\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\\n\\t\\t#endif\\n\\t\\treturn envMapColor.rgb * envMapIntensity;\\n\\t}\\n#endif\\n\";\n\nvar lights_phong_fragment = \"BlinnPhongMaterial material;\\nmaterial.diffuseColor = diffuseColor.rgb;\\nmaterial.specularColor = specular;\\nmaterial.specularShininess = shininess;\\nmaterial.specularStrength = specularStrength;\\n\";\n\nvar lights_phong_pars_fragment = \"varying vec3 vViewPosition;\\n#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n#endif\\nstruct BlinnPhongMaterial {\\n\\tvec3\\tdiffuseColor;\\n\\tvec3\\tspecularColor;\\n\\tfloat\\tspecularShininess;\\n\\tfloat\\tspecularStrength;\\n};\\nvoid RE_Direct_BlinnPhong( const in IncidentLight directLight, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\\n\\t#ifdef TOON\\n\\t\\tvec3 irradiance = getGradientIrradiance( geometry.normal, directLight.direction ) * directLight.color;\\n\\t#else\\n\\t\\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\\n\\t\\tvec3 irradiance = dotNL * directLight.color;\\n\\t#endif\\n\\t#ifndef PHYSICALLY_CORRECT_LIGHTS\\n\\t\\tirradiance *= PI;\\n\\t#endif\\n\\treflectedLight.directDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\\n\\treflectedLight.directSpecular += irradiance * BRDF_Specular_BlinnPhong( directLight, geometry, material.specularColor, material.specularShininess ) * material.specularStrength;\\n}\\nvoid RE_IndirectDiffuse_BlinnPhong( const in vec3 irradiance, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\\n\\treflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\\n}\\n#define RE_Direct\\t\\t\\t\\tRE_Direct_BlinnPhong\\n#define RE_IndirectDiffuse\\t\\tRE_IndirectDiffuse_BlinnPhong\\n#define Material_LightProbeLOD( material )\\t(0)\\n\";\n\nvar lights_physical_fragment = \"PhysicalMaterial material;\\nmaterial.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor );\\nmaterial.specularRoughness = clamp( roughnessFactor, 0.04, 1.0 );\\n#ifdef STANDARD\\n\\tmaterial.specularColor = mix( vec3( DEFAULT_SPECULAR_COEFFICIENT ), diffuseColor.rgb, metalnessFactor );\\n#else\\n\\tmaterial.specularColor = mix( vec3( MAXIMUM_SPECULAR_COEFFICIENT * pow2( reflectivity ) ), diffuseColor.rgb, metalnessFactor );\\n\\tmaterial.clearCoat = saturate( clearCoat );\\tmaterial.clearCoatRoughness = clamp( clearCoatRoughness, 0.04, 1.0 );\\n#endif\\n\";\n\nvar lights_physical_pars_fragment = \"struct PhysicalMaterial {\\n\\tvec3\\tdiffuseColor;\\n\\tfloat\\tspecularRoughness;\\n\\tvec3\\tspecularColor;\\n\\t#ifndef STANDARD\\n\\t\\tfloat clearCoat;\\n\\t\\tfloat clearCoatRoughness;\\n\\t#endif\\n};\\n#define MAXIMUM_SPECULAR_COEFFICIENT 0.16\\n#define DEFAULT_SPECULAR_COEFFICIENT 0.04\\nfloat clearCoatDHRApprox( const in float roughness, const in float dotNL ) {\\n\\treturn DEFAULT_SPECULAR_COEFFICIENT + ( 1.0 - DEFAULT_SPECULAR_COEFFICIENT ) * ( pow( 1.0 - dotNL, 5.0 ) * pow( 1.0 - roughness, 2.0 ) );\\n}\\n#if NUM_RECT_AREA_LIGHTS > 0\\n\\tvoid RE_Direct_RectArea_Physical( const in RectAreaLight rectAreaLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\t\\tvec3 normal = geometry.normal;\\n\\t\\tvec3 viewDir = geometry.viewDir;\\n\\t\\tvec3 position = geometry.position;\\n\\t\\tvec3 lightPos = rectAreaLight.position;\\n\\t\\tvec3 halfWidth = rectAreaLight.halfWidth;\\n\\t\\tvec3 halfHeight = rectAreaLight.halfHeight;\\n\\t\\tvec3 lightColor = rectAreaLight.color;\\n\\t\\tfloat roughness = material.specularRoughness;\\n\\t\\tvec3 rectCoords[ 4 ];\\n\\t\\trectCoords[ 0 ] = lightPos - halfWidth - halfHeight;\\t\\trectCoords[ 1 ] = lightPos + halfWidth - halfHeight;\\n\\t\\trectCoords[ 2 ] = lightPos + halfWidth + halfHeight;\\n\\t\\trectCoords[ 3 ] = lightPos - halfWidth + halfHeight;\\n\\t\\tvec2 uv = LTC_Uv( normal, viewDir, roughness );\\n\\t\\tvec4 t1 = texture2D( ltc_1, uv );\\n\\t\\tvec4 t2 = texture2D( ltc_2, uv );\\n\\t\\tmat3 mInv = mat3(\\n\\t\\t\\tvec3( t1.x, 0, t1.y ),\\n\\t\\t\\tvec3(    0, 1,    0 ),\\n\\t\\t\\tvec3( t1.z, 0, t1.w )\\n\\t\\t);\\n\\t\\tvec3 fresnel = ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y );\\n\\t\\treflectedLight.directSpecular += lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords );\\n\\t\\treflectedLight.directDiffuse += lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords );\\n\\t}\\n#endif\\nvoid RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\\n\\tvec3 irradiance = dotNL * directLight.color;\\n\\t#ifndef PHYSICALLY_CORRECT_LIGHTS\\n\\t\\tirradiance *= PI;\\n\\t#endif\\n\\t#ifndef STANDARD\\n\\t\\tfloat clearCoatDHR = material.clearCoat * clearCoatDHRApprox( material.clearCoatRoughness, dotNL );\\n\\t#else\\n\\t\\tfloat clearCoatDHR = 0.0;\\n\\t#endif\\n\\treflectedLight.directSpecular += ( 1.0 - clearCoatDHR ) * irradiance * BRDF_Specular_GGX( directLight, geometry, material.specularColor, material.specularRoughness );\\n\\treflectedLight.directDiffuse += ( 1.0 - clearCoatDHR ) * irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\\n\\t#ifndef STANDARD\\n\\t\\treflectedLight.directSpecular += irradiance * material.clearCoat * BRDF_Specular_GGX( directLight, geometry, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearCoatRoughness );\\n\\t#endif\\n}\\nvoid RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\treflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\\n}\\nvoid RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 clearCoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\t#ifndef STANDARD\\n\\t\\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\\n\\t\\tfloat dotNL = dotNV;\\n\\t\\tfloat clearCoatDHR = material.clearCoat * clearCoatDHRApprox( material.clearCoatRoughness, dotNL );\\n\\t#else\\n\\t\\tfloat clearCoatDHR = 0.0;\\n\\t#endif\\n\\treflectedLight.indirectSpecular += ( 1.0 - clearCoatDHR ) * radiance * BRDF_Specular_GGX_Environment( geometry, material.specularColor, material.specularRoughness );\\n\\t#ifndef STANDARD\\n\\t\\treflectedLight.indirectSpecular += clearCoatRadiance * material.clearCoat * BRDF_Specular_GGX_Environment( geometry, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearCoatRoughness );\\n\\t#endif\\n}\\n#define RE_Direct\\t\\t\\t\\tRE_Direct_Physical\\n#define RE_Direct_RectArea\\t\\tRE_Direct_RectArea_Physical\\n#define RE_IndirectDiffuse\\t\\tRE_IndirectDiffuse_Physical\\n#define RE_IndirectSpecular\\t\\tRE_IndirectSpecular_Physical\\n#define Material_BlinnShininessExponent( material )   GGXRoughnessToBlinnExponent( material.specularRoughness )\\n#define Material_ClearCoat_BlinnShininessExponent( material )   GGXRoughnessToBlinnExponent( material.clearCoatRoughness )\\nfloat computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) {\\n\\treturn saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\\n}\\n\";\n\nvar lights_fragment_begin = \"\\nGeometricContext geometry;\\ngeometry.position = - vViewPosition;\\ngeometry.normal = normal;\\ngeometry.viewDir = normalize( vViewPosition );\\nIncidentLight directLight;\\n#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\\n\\tPointLight pointLight;\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\\n\\t\\tpointLight = pointLights[ i ];\\n\\t\\tgetPointDirectLightIrradiance( pointLight, geometry, directLight );\\n\\t\\t#ifdef USE_SHADOWMAP\\n\\t\\tdirectLight.color *= all( bvec2( pointLight.shadow, directLight.visible ) ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\\n\\t\\t#endif\\n\\t\\tRE_Direct( directLight, geometry, material, reflectedLight );\\n\\t}\\n#endif\\n#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\\n\\tSpotLight spotLight;\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\\n\\t\\tspotLight = spotLights[ i ];\\n\\t\\tgetSpotDirectLightIrradiance( spotLight, geometry, directLight );\\n\\t\\t#ifdef USE_SHADOWMAP\\n\\t\\tdirectLight.color *= all( bvec2( spotLight.shadow, directLight.visible ) ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\\n\\t\\t#endif\\n\\t\\tRE_Direct( directLight, geometry, material, reflectedLight );\\n\\t}\\n#endif\\n#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )\\n\\tDirectionalLight directionalLight;\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\\n\\t\\tdirectionalLight = directionalLights[ i ];\\n\\t\\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\\n\\t\\t#ifdef USE_SHADOWMAP\\n\\t\\tdirectLight.color *= all( bvec2( directionalLight.shadow, directLight.visible ) ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\\n\\t\\t#endif\\n\\t\\tRE_Direct( directLight, geometry, material, reflectedLight );\\n\\t}\\n#endif\\n#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\\n\\tRectAreaLight rectAreaLight;\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\\n\\t\\trectAreaLight = rectAreaLights[ i ];\\n\\t\\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\\n\\t}\\n#endif\\n#if defined( RE_IndirectDiffuse )\\n\\tvec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\\n\\t#if ( NUM_HEMI_LIGHTS > 0 )\\n\\t\\t#pragma unroll_loop\\n\\t\\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\\n\\t\\t\\tirradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\\n\\t\\t}\\n\\t#endif\\n#endif\\n#if defined( RE_IndirectSpecular )\\n\\tvec3 radiance = vec3( 0.0 );\\n\\tvec3 clearCoatRadiance = vec3( 0.0 );\\n#endif\\n\";\n\nvar lights_fragment_maps = \"#if defined( RE_IndirectDiffuse )\\n\\t#ifdef USE_LIGHTMAP\\n\\t\\tvec3 lightMapIrradiance = texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\\n\\t\\t#ifndef PHYSICALLY_CORRECT_LIGHTS\\n\\t\\t\\tlightMapIrradiance *= PI;\\n\\t\\t#endif\\n\\t\\tirradiance += lightMapIrradiance;\\n\\t#endif\\n\\t#if defined( USE_ENVMAP ) && defined( PHYSICAL ) && defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\tirradiance += getLightProbeIndirectIrradiance( geometry, maxMipLevel );\\n\\t#endif\\n#endif\\n#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )\\n\\tradiance += getLightProbeIndirectRadiance( geometry, Material_BlinnShininessExponent( material ), maxMipLevel );\\n\\t#ifndef STANDARD\\n\\t\\tclearCoatRadiance += getLightProbeIndirectRadiance( geometry, Material_ClearCoat_BlinnShininessExponent( material ), maxMipLevel );\\n\\t#endif\\n#endif\\n\";\n\nvar lights_fragment_end = \"#if defined( RE_IndirectDiffuse )\\n\\tRE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\\n#endif\\n#if defined( RE_IndirectSpecular )\\n\\tRE_IndirectSpecular( radiance, clearCoatRadiance, geometry, material, reflectedLight );\\n#endif\\n\";\n\nvar logdepthbuf_fragment = \"#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\\n\\tgl_FragDepthEXT = log2( vFragDepth ) * logDepthBufFC * 0.5;\\n#endif\";\n\nvar logdepthbuf_pars_fragment = \"#ifdef USE_LOGDEPTHBUF\\n\\tuniform float logDepthBufFC;\\n\\t#ifdef USE_LOGDEPTHBUF_EXT\\n\\t\\tvarying float vFragDepth;\\n\\t#endif\\n#endif\\n\";\n\nvar logdepthbuf_pars_vertex = \"#ifdef USE_LOGDEPTHBUF\\n\\t#ifdef USE_LOGDEPTHBUF_EXT\\n\\t\\tvarying float vFragDepth;\\n\\t#endif\\n\\tuniform float logDepthBufFC;\\n#endif\";\n\nvar logdepthbuf_vertex = \"#ifdef USE_LOGDEPTHBUF\\n\\t#ifdef USE_LOGDEPTHBUF_EXT\\n\\t\\tvFragDepth = 1.0 + gl_Position.w;\\n\\t#else\\n\\t\\tgl_Position.z = log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0;\\n\\t\\tgl_Position.z *= gl_Position.w;\\n\\t#endif\\n#endif\\n\";\n\nvar map_fragment = \"#ifdef USE_MAP\\n\\tvec4 texelColor = texture2D( map, vUv );\\n\\ttexelColor = mapTexelToLinear( texelColor );\\n\\tdiffuseColor *= texelColor;\\n#endif\\n\";\n\nvar map_pars_fragment = \"#ifdef USE_MAP\\n\\tuniform sampler2D map;\\n#endif\\n\";\n\nvar map_particle_fragment = \"#ifdef USE_MAP\\n\\tvec2 uv = ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy;\\n\\tvec4 mapTexel = texture2D( map, uv );\\n\\tdiffuseColor *= mapTexelToLinear( mapTexel );\\n#endif\\n\";\n\nvar map_particle_pars_fragment = \"#ifdef USE_MAP\\n\\tuniform mat3 uvTransform;\\n\\tuniform sampler2D map;\\n#endif\\n\";\n\nvar metalnessmap_fragment = \"float metalnessFactor = metalness;\\n#ifdef USE_METALNESSMAP\\n\\tvec4 texelMetalness = texture2D( metalnessMap, vUv );\\n\\tmetalnessFactor *= texelMetalness.b;\\n#endif\\n\";\n\nvar metalnessmap_pars_fragment = \"#ifdef USE_METALNESSMAP\\n\\tuniform sampler2D metalnessMap;\\n#endif\";\n\nvar morphnormal_vertex = \"#ifdef USE_MORPHNORMALS\\n\\tobjectNormal += ( morphNormal0 - normal ) * morphTargetInfluences[ 0 ];\\n\\tobjectNormal += ( morphNormal1 - normal ) * morphTargetInfluences[ 1 ];\\n\\tobjectNormal += ( morphNormal2 - normal ) * morphTargetInfluences[ 2 ];\\n\\tobjectNormal += ( morphNormal3 - normal ) * morphTargetInfluences[ 3 ];\\n#endif\\n\";\n\nvar morphtarget_pars_vertex = \"#ifdef USE_MORPHTARGETS\\n\\t#ifndef USE_MORPHNORMALS\\n\\tuniform float morphTargetInfluences[ 8 ];\\n\\t#else\\n\\tuniform float morphTargetInfluences[ 4 ];\\n\\t#endif\\n#endif\";\n\nvar morphtarget_vertex = \"#ifdef USE_MORPHTARGETS\\n\\ttransformed += ( morphTarget0 - position ) * morphTargetInfluences[ 0 ];\\n\\ttransformed += ( morphTarget1 - position ) * morphTargetInfluences[ 1 ];\\n\\ttransformed += ( morphTarget2 - position ) * morphTargetInfluences[ 2 ];\\n\\ttransformed += ( morphTarget3 - position ) * morphTargetInfluences[ 3 ];\\n\\t#ifndef USE_MORPHNORMALS\\n\\ttransformed += ( morphTarget4 - position ) * morphTargetInfluences[ 4 ];\\n\\ttransformed += ( morphTarget5 - position ) * morphTargetInfluences[ 5 ];\\n\\ttransformed += ( morphTarget6 - position ) * morphTargetInfluences[ 6 ];\\n\\ttransformed += ( morphTarget7 - position ) * morphTargetInfluences[ 7 ];\\n\\t#endif\\n#endif\\n\";\n\nvar normal_fragment_begin = \"#ifdef FLAT_SHADED\\n\\tvec3 fdx = vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );\\n\\tvec3 fdy = vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );\\n\\tvec3 normal = normalize( cross( fdx, fdy ) );\\n#else\\n\\tvec3 normal = normalize( vNormal );\\n\\t#ifdef DOUBLE_SIDED\\n\\t\\tnormal = normal * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\\n\\t#endif\\n#endif\\n\";\n\nvar normal_fragment_maps = \"#ifdef USE_NORMALMAP\\n\\tnormal = perturbNormal2Arb( -vViewPosition, normal );\\n#elif defined( USE_BUMPMAP )\\n\\tnormal = perturbNormalArb( -vViewPosition, normal, dHdxy_fwd() );\\n#endif\\n\";\n\nvar normalmap_pars_fragment = \"#ifdef USE_NORMALMAP\\n\\tuniform sampler2D normalMap;\\n\\tuniform vec2 normalScale;\\n\\tvec3 perturbNormal2Arb( vec3 eye_pos, vec3 surf_norm ) {\\n\\t\\tvec3 q0 = vec3( dFdx( eye_pos.x ), dFdx( eye_pos.y ), dFdx( eye_pos.z ) );\\n\\t\\tvec3 q1 = vec3( dFdy( eye_pos.x ), dFdy( eye_pos.y ), dFdy( eye_pos.z ) );\\n\\t\\tvec2 st0 = dFdx( vUv.st );\\n\\t\\tvec2 st1 = dFdy( vUv.st );\\n\\t\\tfloat scale = sign( st1.t * st0.s - st0.t * st1.s );\\t\\tscale *= float( gl_FrontFacing ) * 2.0 - 1.0;\\n\\t\\tvec3 S = normalize( ( q0 * st1.t - q1 * st0.t ) * scale );\\n\\t\\tvec3 T = normalize( ( - q0 * st1.s + q1 * st0.s ) * scale );\\n\\t\\tvec3 N = normalize( surf_norm );\\n\\t\\tvec3 mapN = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\\n\\t\\tmapN.xy = normalScale * mapN.xy;\\n\\t\\tmat3 tsn = mat3( S, T, N );\\n\\t\\treturn normalize( tsn * mapN );\\n\\t}\\n#endif\\n\";\n\nvar packing = \"vec3 packNormalToRGB( const in vec3 normal ) {\\n\\treturn normalize( normal ) * 0.5 + 0.5;\\n}\\nvec3 unpackRGBToNormal( const in vec3 rgb ) {\\n\\treturn 2.0 * rgb.xyz - 1.0;\\n}\\nconst float PackUpscale = 256. / 255.;const float UnpackDownscale = 255. / 256.;\\nconst vec3 PackFactors = vec3( 256. * 256. * 256., 256. * 256.,  256. );\\nconst vec4 UnpackFactors = UnpackDownscale / vec4( PackFactors, 1. );\\nconst float ShiftRight8 = 1. / 256.;\\nvec4 packDepthToRGBA( const in float v ) {\\n\\tvec4 r = vec4( fract( v * PackFactors ), v );\\n\\tr.yzw -= r.xyz * ShiftRight8;\\treturn r * PackUpscale;\\n}\\nfloat unpackRGBAToDepth( const in vec4 v ) {\\n\\treturn dot( v, UnpackFactors );\\n}\\nfloat viewZToOrthographicDepth( const in float viewZ, const in float near, const in float far ) {\\n\\treturn ( viewZ + near ) / ( near - far );\\n}\\nfloat orthographicDepthToViewZ( const in float linearClipZ, const in float near, const in float far ) {\\n\\treturn linearClipZ * ( near - far ) - near;\\n}\\nfloat viewZToPerspectiveDepth( const in float viewZ, const in float near, const in float far ) {\\n\\treturn (( near + viewZ ) * far ) / (( far - near ) * viewZ );\\n}\\nfloat perspectiveDepthToViewZ( const in float invClipZ, const in float near, const in float far ) {\\n\\treturn ( near * far ) / ( ( far - near ) * invClipZ - far );\\n}\\n\";\n\nvar premultiplied_alpha_fragment = \"#ifdef PREMULTIPLIED_ALPHA\\n\\tgl_FragColor.rgb *= gl_FragColor.a;\\n#endif\\n\";\n\nvar project_vertex = \"vec4 mvPosition = modelViewMatrix * vec4( transformed, 1.0 );\\ngl_Position = projectionMatrix * mvPosition;\\n\";\n\nvar dithering_fragment = \"#if defined( DITHERING )\\n  gl_FragColor.rgb = dithering( gl_FragColor.rgb );\\n#endif\\n\";\n\nvar dithering_pars_fragment = \"#if defined( DITHERING )\\n\\tvec3 dithering( vec3 color ) {\\n\\t\\tfloat grid_position = rand( gl_FragCoord.xy );\\n\\t\\tvec3 dither_shift_RGB = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\\n\\t\\tdither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\\n\\t\\treturn color + dither_shift_RGB;\\n\\t}\\n#endif\\n\";\n\nvar roughnessmap_fragment = \"float roughnessFactor = roughness;\\n#ifdef USE_ROUGHNESSMAP\\n\\tvec4 texelRoughness = texture2D( roughnessMap, vUv );\\n\\troughnessFactor *= texelRoughness.g;\\n#endif\\n\";\n\nvar roughnessmap_pars_fragment = \"#ifdef USE_ROUGHNESSMAP\\n\\tuniform sampler2D roughnessMap;\\n#endif\";\n\nvar shadowmap_pars_fragment = \"#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHTS > 0\\n\\t\\tuniform sampler2D directionalShadowMap[ NUM_DIR_LIGHTS ];\\n\\t\\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHTS ];\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHTS > 0\\n\\t\\tuniform sampler2D spotShadowMap[ NUM_SPOT_LIGHTS ];\\n\\t\\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHTS ];\\n\\t#endif\\n\\t#if NUM_POINT_LIGHTS > 0\\n\\t\\tuniform sampler2D pointShadowMap[ NUM_POINT_LIGHTS ];\\n\\t\\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHTS ];\\n\\t#endif\\n\\tfloat texture2DCompare( sampler2D depths, vec2 uv, float compare ) {\\n\\t\\treturn step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\\n\\t}\\n\\tfloat texture2DShadowLerp( sampler2D depths, vec2 size, vec2 uv, float compare ) {\\n\\t\\tconst vec2 offset = vec2( 0.0, 1.0 );\\n\\t\\tvec2 texelSize = vec2( 1.0 ) / size;\\n\\t\\tvec2 centroidUV = floor( uv * size + 0.5 ) / size;\\n\\t\\tfloat lb = texture2DCompare( depths, centroidUV + texelSize * offset.xx, compare );\\n\\t\\tfloat lt = texture2DCompare( depths, centroidUV + texelSize * offset.xy, compare );\\n\\t\\tfloat rb = texture2DCompare( depths, centroidUV + texelSize * offset.yx, compare );\\n\\t\\tfloat rt = texture2DCompare( depths, centroidUV + texelSize * offset.yy, compare );\\n\\t\\tvec2 f = fract( uv * size + 0.5 );\\n\\t\\tfloat a = mix( lb, lt, f.y );\\n\\t\\tfloat b = mix( rb, rt, f.y );\\n\\t\\tfloat c = mix( a, b, f.x );\\n\\t\\treturn c;\\n\\t}\\n\\tfloat getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) {\\n\\t\\tfloat shadow = 1.0;\\n\\t\\tshadowCoord.xyz /= shadowCoord.w;\\n\\t\\tshadowCoord.z += shadowBias;\\n\\t\\tbvec4 inFrustumVec = bvec4 ( shadowCoord.x >= 0.0, shadowCoord.x <= 1.0, shadowCoord.y >= 0.0, shadowCoord.y <= 1.0 );\\n\\t\\tbool inFrustum = all( inFrustumVec );\\n\\t\\tbvec2 frustumTestVec = bvec2( inFrustum, shadowCoord.z <= 1.0 );\\n\\t\\tbool frustumTest = all( frustumTestVec );\\n\\t\\tif ( frustumTest ) {\\n\\t\\t#if defined( SHADOWMAP_TYPE_PCF )\\n\\t\\t\\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\\n\\t\\t\\tfloat dx0 = - texelSize.x * shadowRadius;\\n\\t\\t\\tfloat dy0 = - texelSize.y * shadowRadius;\\n\\t\\t\\tfloat dx1 = + texelSize.x * shadowRadius;\\n\\t\\t\\tfloat dy1 = + texelSize.y * shadowRadius;\\n\\t\\t\\tshadow = (\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\\n\\t\\t\\t) * ( 1.0 / 9.0 );\\n\\t\\t#elif defined( SHADOWMAP_TYPE_PCF_SOFT )\\n\\t\\t\\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\\n\\t\\t\\tfloat dx0 = - texelSize.x * shadowRadius;\\n\\t\\t\\tfloat dy0 = - texelSize.y * shadowRadius;\\n\\t\\t\\tfloat dx1 = + texelSize.x * shadowRadius;\\n\\t\\t\\tfloat dy1 = + texelSize.y * shadowRadius;\\n\\t\\t\\tshadow = (\\n\\t\\t\\t\\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy, shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\\n\\t\\t\\t) * ( 1.0 / 9.0 );\\n\\t\\t#else\\n\\t\\t\\tshadow = texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\\n\\t\\t#endif\\n\\t\\t}\\n\\t\\treturn shadow;\\n\\t}\\n\\tvec2 cubeToUV( vec3 v, float texelSizeY ) {\\n\\t\\tvec3 absV = abs( v );\\n\\t\\tfloat scaleToCube = 1.0 / max( absV.x, max( absV.y, absV.z ) );\\n\\t\\tabsV *= scaleToCube;\\n\\t\\tv *= scaleToCube * ( 1.0 - 2.0 * texelSizeY );\\n\\t\\tvec2 planar = v.xy;\\n\\t\\tfloat almostATexel = 1.5 * texelSizeY;\\n\\t\\tfloat almostOne = 1.0 - almostATexel;\\n\\t\\tif ( absV.z >= almostOne ) {\\n\\t\\t\\tif ( v.z > 0.0 )\\n\\t\\t\\t\\tplanar.x = 4.0 - v.x;\\n\\t\\t} else if ( absV.x >= almostOne ) {\\n\\t\\t\\tfloat signX = sign( v.x );\\n\\t\\t\\tplanar.x = v.z * signX + 2.0 * signX;\\n\\t\\t} else if ( absV.y >= almostOne ) {\\n\\t\\t\\tfloat signY = sign( v.y );\\n\\t\\t\\tplanar.x = v.x + 2.0 * signY + 2.0;\\n\\t\\t\\tplanar.y = v.z * signY - 2.0;\\n\\t\\t}\\n\\t\\treturn vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\\n\\t}\\n\\tfloat getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\\n\\t\\tvec2 texelSize = vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\\n\\t\\tvec3 lightToPosition = shadowCoord.xyz;\\n\\t\\tfloat dp = ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear );\\t\\tdp += shadowBias;\\n\\t\\tvec3 bd3D = normalize( lightToPosition );\\n\\t\\t#if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT )\\n\\t\\t\\tvec2 offset = vec2( - 1, 1 ) * shadowRadius * texelSize.y;\\n\\t\\t\\treturn (\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\\n\\t\\t\\t) * ( 1.0 / 9.0 );\\n\\t\\t#else\\n\\t\\t\\treturn texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\\n\\t\\t#endif\\n\\t}\\n#endif\\n\";\n\nvar shadowmap_pars_vertex = \"#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHTS > 0\\n\\t\\tuniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHTS ];\\n\\t\\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHTS ];\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHTS > 0\\n\\t\\tuniform mat4 spotShadowMatrix[ NUM_SPOT_LIGHTS ];\\n\\t\\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHTS ];\\n\\t#endif\\n\\t#if NUM_POINT_LIGHTS > 0\\n\\t\\tuniform mat4 pointShadowMatrix[ NUM_POINT_LIGHTS ];\\n\\t\\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHTS ];\\n\\t#endif\\n#endif\\n\";\n\nvar shadowmap_vertex = \"#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHTS > 0\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\\n\\t\\tvDirectionalShadowCoord[ i ] = directionalShadowMatrix[ i ] * worldPosition;\\n\\t}\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHTS > 0\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\\n\\t\\tvSpotShadowCoord[ i ] = spotShadowMatrix[ i ] * worldPosition;\\n\\t}\\n\\t#endif\\n\\t#if NUM_POINT_LIGHTS > 0\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\\n\\t\\tvPointShadowCoord[ i ] = pointShadowMatrix[ i ] * worldPosition;\\n\\t}\\n\\t#endif\\n#endif\\n\";\n\nvar shadowmask_pars_fragment = \"float getShadowMask() {\\n\\tfloat shadow = 1.0;\\n\\t#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHTS > 0\\n\\tDirectionalLight directionalLight;\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\\n\\t\\tdirectionalLight = directionalLights[ i ];\\n\\t\\tshadow *= bool( directionalLight.shadow ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\\n\\t}\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHTS > 0\\n\\tSpotLight spotLight;\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\\n\\t\\tspotLight = spotLights[ i ];\\n\\t\\tshadow *= bool( spotLight.shadow ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\\n\\t}\\n\\t#endif\\n\\t#if NUM_POINT_LIGHTS > 0\\n\\tPointLight pointLight;\\n\\t#pragma unroll_loop\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\\n\\t\\tpointLight = pointLights[ i ];\\n\\t\\tshadow *= bool( pointLight.shadow ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\\n\\t}\\n\\t#endif\\n\\t#endif\\n\\treturn shadow;\\n}\\n\";\n\nvar skinbase_vertex = \"#ifdef USE_SKINNING\\n\\tmat4 boneMatX = getBoneMatrix( skinIndex.x );\\n\\tmat4 boneMatY = getBoneMatrix( skinIndex.y );\\n\\tmat4 boneMatZ = getBoneMatrix( skinIndex.z );\\n\\tmat4 boneMatW = getBoneMatrix( skinIndex.w );\\n#endif\";\n\nvar skinning_pars_vertex = \"#ifdef USE_SKINNING\\n\\tuniform mat4 bindMatrix;\\n\\tuniform mat4 bindMatrixInverse;\\n\\t#ifdef BONE_TEXTURE\\n\\t\\tuniform sampler2D boneTexture;\\n\\t\\tuniform int boneTextureSize;\\n\\t\\tmat4 getBoneMatrix( const in float i ) {\\n\\t\\t\\tfloat j = i * 4.0;\\n\\t\\t\\tfloat x = mod( j, float( boneTextureSize ) );\\n\\t\\t\\tfloat y = floor( j / float( boneTextureSize ) );\\n\\t\\t\\tfloat dx = 1.0 / float( boneTextureSize );\\n\\t\\t\\tfloat dy = 1.0 / float( boneTextureSize );\\n\\t\\t\\ty = dy * ( y + 0.5 );\\n\\t\\t\\tvec4 v1 = texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) );\\n\\t\\t\\tvec4 v2 = texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) );\\n\\t\\t\\tvec4 v3 = texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) );\\n\\t\\t\\tvec4 v4 = texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) );\\n\\t\\t\\tmat4 bone = mat4( v1, v2, v3, v4 );\\n\\t\\t\\treturn bone;\\n\\t\\t}\\n\\t#else\\n\\t\\tuniform mat4 boneMatrices[ MAX_BONES ];\\n\\t\\tmat4 getBoneMatrix( const in float i ) {\\n\\t\\t\\tmat4 bone = boneMatrices[ int(i) ];\\n\\t\\t\\treturn bone;\\n\\t\\t}\\n\\t#endif\\n#endif\\n\";\n\nvar skinning_vertex = \"#ifdef USE_SKINNING\\n\\tvec4 skinVertex = bindMatrix * vec4( transformed, 1.0 );\\n\\tvec4 skinned = vec4( 0.0 );\\n\\tskinned += boneMatX * skinVertex * skinWeight.x;\\n\\tskinned += boneMatY * skinVertex * skinWeight.y;\\n\\tskinned += boneMatZ * skinVertex * skinWeight.z;\\n\\tskinned += boneMatW * skinVertex * skinWeight.w;\\n\\ttransformed = ( bindMatrixInverse * skinned ).xyz;\\n#endif\\n\";\n\nvar skinnormal_vertex = \"#ifdef USE_SKINNING\\n\\tmat4 skinMatrix = mat4( 0.0 );\\n\\tskinMatrix += skinWeight.x * boneMatX;\\n\\tskinMatrix += skinWeight.y * boneMatY;\\n\\tskinMatrix += skinWeight.z * boneMatZ;\\n\\tskinMatrix += skinWeight.w * boneMatW;\\n\\tskinMatrix  = bindMatrixInverse * skinMatrix * bindMatrix;\\n\\tobjectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz;\\n#endif\\n\";\n\nvar specularmap_fragment = \"float specularStrength;\\n#ifdef USE_SPECULARMAP\\n\\tvec4 texelSpecular = texture2D( specularMap, vUv );\\n\\tspecularStrength = texelSpecular.r;\\n#else\\n\\tspecularStrength = 1.0;\\n#endif\";\n\nvar specularmap_pars_fragment = \"#ifdef USE_SPECULARMAP\\n\\tuniform sampler2D specularMap;\\n#endif\";\n\nvar tonemapping_fragment = \"#if defined( TONE_MAPPING )\\n  gl_FragColor.rgb = toneMapping( gl_FragColor.rgb );\\n#endif\\n\";\n\nvar tonemapping_pars_fragment = \"#ifndef saturate\\n\\t#define saturate(a) clamp( a, 0.0, 1.0 )\\n#endif\\nuniform float toneMappingExposure;\\nuniform float toneMappingWhitePoint;\\nvec3 LinearToneMapping( vec3 color ) {\\n\\treturn toneMappingExposure * color;\\n}\\nvec3 ReinhardToneMapping( vec3 color ) {\\n\\tcolor *= toneMappingExposure;\\n\\treturn saturate( color / ( vec3( 1.0 ) + color ) );\\n}\\n#define Uncharted2Helper( x ) max( ( ( x * ( 0.15 * x + 0.10 * 0.50 ) + 0.20 * 0.02 ) / ( x * ( 0.15 * x + 0.50 ) + 0.20 * 0.30 ) ) - 0.02 / 0.30, vec3( 0.0 ) )\\nvec3 Uncharted2ToneMapping( vec3 color ) {\\n\\tcolor *= toneMappingExposure;\\n\\treturn saturate( Uncharted2Helper( color ) / Uncharted2Helper( vec3( toneMappingWhitePoint ) ) );\\n}\\nvec3 OptimizedCineonToneMapping( vec3 color ) {\\n\\tcolor *= toneMappingExposure;\\n\\tcolor = max( vec3( 0.0 ), color - 0.004 );\\n\\treturn pow( ( color * ( 6.2 * color + 0.5 ) ) / ( color * ( 6.2 * color + 1.7 ) + 0.06 ), vec3( 2.2 ) );\\n}\\n\";\n\nvar uv_pars_fragment = \"#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\\n\\tvarying vec2 vUv;\\n#endif\";\n\nvar uv_pars_vertex = \"#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\\n\\tvarying vec2 vUv;\\n\\tuniform mat3 uvTransform;\\n#endif\\n\";\n\nvar uv_vertex = \"#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\\n\\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\\n#endif\";\n\nvar uv2_pars_fragment = \"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\\n\\tvarying vec2 vUv2;\\n#endif\";\n\nvar uv2_pars_vertex = \"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\\n\\tattribute vec2 uv2;\\n\\tvarying vec2 vUv2;\\n#endif\";\n\nvar uv2_vertex = \"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\\n\\tvUv2 = uv2;\\n#endif\";\n\nvar worldpos_vertex = \"#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP )\\n\\tvec4 worldPosition = modelMatrix * vec4( transformed, 1.0 );\\n#endif\\n\";\n\nvar cube_frag = \"uniform samplerCube tCube;\\nuniform float tFlip;\\nuniform float opacity;\\nvarying vec3 vWorldPosition;\\nvoid main() {\\n\\tgl_FragColor = textureCube( tCube, vec3( tFlip * vWorldPosition.x, vWorldPosition.yz ) );\\n\\tgl_FragColor.a *= opacity;\\n}\\n\";\n\nvar cube_vert = \"varying vec3 vWorldPosition;\\n#include <common>\\nvoid main() {\\n\\tvWorldPosition = transformDirection( position, modelMatrix );\\n\\t#include <begin_vertex>\\n\\t#include <project_vertex>\\n\\tgl_Position.z = gl_Position.w;\\n}\\n\";\n\nvar depth_frag = \"#if DEPTH_PACKING == 3200\\n\\tuniform float opacity;\\n#endif\\n#include <common>\\n#include <packing>\\n#include <uv_pars_fragment>\\n#include <map_pars_fragment>\\n#include <alphamap_pars_fragment>\\n#include <logdepthbuf_pars_fragment>\\n#include <clipping_planes_pars_fragment>\\nvoid main() {\\n\\t#include <clipping_planes_fragment>\\n\\tvec4 diffuseColor = vec4( 1.0 );\\n\\t#if DEPTH_PACKING == 3200\\n\\t\\tdiffuseColor.a = opacity;\\n\\t#endif\\n\\t#include <map_fragment>\\n\\t#include <alphamap_fragment>\\n\\t#include <alphatest_fragment>\\n\\t#include <logdepthbuf_fragment>\\n\\t#if DEPTH_PACKING == 3200\\n\\t\\tgl_FragColor = vec4( vec3( 1.0 - gl_FragCoord.z ), opacity );\\n\\t#elif DEPTH_PACKING == 3201\\n\\t\\tgl_FragColor = packDepthToRGBA( gl_FragCoord.z );\\n\\t#endif\\n}\\n\";\n\nvar depth_vert = \"#include <common>\\n#include <uv_pars_vertex>\\n#include <displacementmap_pars_vertex>\\n#include <morphtarget_pars_vertex>\\n#include <skinning_pars_vertex>\\n#include <logdepthbuf_pars_vertex>\\n#include <clipping_planes_pars_vertex>\\nvoid main() {\\n\\t#include <uv_vertex>\\n\\t#include <skinbase_vertex>\\n\\t#ifdef USE_DISPLACEMENTMAP\\n\\t\\t#include <beginnormal_vertex>\\n\\t\\t#include <morphnormal_vertex>\\n\\t\\t#include <skinnormal_vertex>\\n\\t#endif\\n\\t#include <begin_vertex>\\n\\t#include <morphtarget_vertex>\\n\\t#include <skinning_vertex>\\n\\t#include <displacementmap_vertex>\\n\\t#include <project_vertex>\\n\\t#include <logdepthbuf_vertex>\\n\\t#include <clipping_planes_vertex>\\n}\\n\";\n\nvar distanceRGBA_frag = \"#define DISTANCE\\nuniform vec3 referencePosition;\\nuniform float nearDistance;\\nuniform float farDistance;\\nvarying vec3 vWorldPosition;\\n#include <common>\\n#include <packing>\\n#include <uv_pars_fragment>\\n#include <map_pars_fragment>\\n#include <alphamap_pars_fragment>\\n#include <clipping_planes_pars_fragment>\\nvoid main () {\\n\\t#include <clipping_planes_fragment>\\n\\tvec4 diffuseColor = vec4( 1.0 );\\n\\t#include <map_fragment>\\n\\t#include <alphamap_fragment>\\n\\t#include <alphatest_fragment>\\n\\tfloat dist = length( vWorldPosition - referencePosition );\\n\\tdist = ( dist - nearDistance ) / ( farDistance - nearDistance );\\n\\tdist = saturate( dist );\\n\\tgl_FragColor = packDepthToRGBA( dist );\\n}\\n\";\n\nvar distanceRGBA_vert = \"#define DISTANCE\\nvarying vec3 vWorldPosition;\\n#include <common>\\n#include <uv_pars_vertex>\\n#include <displacementmap_pars_vertex>\\n#include <morphtarget_pars_vertex>\\n#include <skinning_pars_vertex>\\n#include <clipping_planes_pars_vertex>\\nvoid main() {\\n\\t#include <uv_vertex>\\n\\t#include <skinbase_vertex>\\n\\t#ifdef USE_DISPLACEMENTMAP\\n\\t\\t#include <beginnormal_vertex>\\n\\t\\t#include <morphnormal_vertex>\\n\\t\\t#include <skinnormal_vertex>\\n\\t#endif\\n\\t#include <begin_vertex>\\n\\t#include <morphtarget_vertex>\\n\\t#include <skinning_vertex>\\n\\t#include <displacementmap_vertex>\\n\\t#include <project_vertex>\\n\\t#include <worldpos_vertex>\\n\\t#include <clipping_planes_vertex>\\n\\tvWorldPosition = worldPosition.xyz;\\n}\\n\";\n\nvar equirect_frag = \"uniform sampler2D tEquirect;\\nvarying vec3 vWorldPosition;\\n#include <common>\\nvoid main() {\\n\\tvec3 direction = normalize( vWorldPosition );\\n\\tvec2 sampleUV;\\n\\tsampleUV.y = asin( clamp( direction.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\\n\\tsampleUV.x = atan( direction.z, direction.x ) * RECIPROCAL_PI2 + 0.5;\\n\\tgl_FragColor = texture2D( tEquirect, sampleUV );\\n}\\n\";\n\nvar equirect_vert = \"varying vec3 vWorldPosition;\\n#include <common>\\nvoid main() {\\n\\tvWorldPosition = transformDirection( position, modelMatrix );\\n\\t#include <begin_vertex>\\n\\t#include <project_vertex>\\n}\\n\";\n\nvar linedashed_frag = \"uniform vec3 diffuse;\\nuniform float opacity;\\nuniform float dashSize;\\nuniform float totalSize;\\nvarying float vLineDistance;\\n#include <common>\\n#include <color_pars_fragment>\\n#include <fog_pars_fragment>\\n#include <logdepthbuf_pars_fragment>\\n#include <clipping_planes_pars_fragment>\\nvoid main() {\\n\\t#include <clipping_planes_fragment>\\n\\tif ( mod( vLineDistance, totalSize ) > dashSize ) {\\n\\t\\tdiscard;\\n\\t}\\n\\tvec3 outgoingLight = vec3( 0.0 );\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include <logdepthbuf_fragment>\\n\\t#include <color_fragment>\\n\\toutgoingLight = diffuseColor.rgb;\\n\\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\\n\\t#include <premultiplied_alpha_fragment>\\n\\t#include <tonemapping_fragment>\\n\\t#include <encodings_fragment>\\n\\t#include <fog_fragment>\\n}\\n\";\n\nvar linedashed_vert = \"uniform float scale;\\nattribute float lineDistance;\\nvarying float vLineDistance;\\n#include <common>\\n#include <color_pars_vertex>\\n#include <fog_pars_vertex>\\n#include <logdepthbuf_pars_vertex>\\n#include <clipping_planes_pars_vertex>\\nvoid main() {\\n\\t#include <color_vertex>\\n\\tvLineDistance = scale * lineDistance;\\n\\tvec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );\\n\\tgl_Position = projectionMatrix * mvPosition;\\n\\t#include <logdepthbuf_vertex>\\n\\t#include <clipping_planes_vertex>\\n\\t#include <fog_vertex>\\n}\\n\";\n\nvar meshbasic_frag = \"uniform vec3 diffuse;\\nuniform float opacity;\\n#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n#endif\\n#include <common>\\n#include <color_pars_fragment>\\n#include <uv_pars_fragment>\\n#include <uv2_pars_fragment>\\n#include <map_pars_fragment>\\n#include <alphamap_pars_fragment>\\n#include <aomap_pars_fragment>\\n#include <lightmap_pars_fragment>\\n#include <envmap_pars_fragment>\\n#include <fog_pars_fragment>\\n#include <specularmap_pars_fragment>\\n#include <logdepthbuf_pars_fragment>\\n#include <clipping_planes_pars_fragment>\\nvoid main() {\\n\\t#include <clipping_planes_fragment>\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include <logdepthbuf_fragment>\\n\\t#include <map_fragment>\\n\\t#include <color_fragment>\\n\\t#include <alphamap_fragment>\\n\\t#include <alphatest_fragment>\\n\\t#include <specularmap_fragment>\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\t#ifdef USE_LIGHTMAP\\n\\t\\treflectedLight.indirectDiffuse += texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\\n\\t#else\\n\\t\\treflectedLight.indirectDiffuse += vec3( 1.0 );\\n\\t#endif\\n\\t#include <aomap_fragment>\\n\\treflectedLight.indirectDiffuse *= diffuseColor.rgb;\\n\\tvec3 outgoingLight = reflectedLight.indirectDiffuse;\\n\\t#include <envmap_fragment>\\n\\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\\n\\t#include <premultiplied_alpha_fragment>\\n\\t#include <tonemapping_fragment>\\n\\t#include <encodings_fragment>\\n\\t#include <fog_fragment>\\n}\\n\";\n\nvar meshbasic_vert = \"#include <common>\\n#include <uv_pars_vertex>\\n#include <uv2_pars_vertex>\\n#include <envmap_pars_vertex>\\n#include <color_pars_vertex>\\n#include <fog_pars_vertex>\\n#include <morphtarget_pars_vertex>\\n#include <skinning_pars_vertex>\\n#include <logdepthbuf_pars_vertex>\\n#include <clipping_planes_pars_vertex>\\nvoid main() {\\n\\t#include <uv_vertex>\\n\\t#include <uv2_vertex>\\n\\t#include <color_vertex>\\n\\t#include <skinbase_vertex>\\n\\t#ifdef USE_ENVMAP\\n\\t#include <beginnormal_vertex>\\n\\t#include <morphnormal_vertex>\\n\\t#include <skinnormal_vertex>\\n\\t#include <defaultnormal_vertex>\\n\\t#endif\\n\\t#include <begin_vertex>\\n\\t#include <morphtarget_vertex>\\n\\t#include <skinning_vertex>\\n\\t#include <project_vertex>\\n\\t#include <logdepthbuf_vertex>\\n\\t#include <worldpos_vertex>\\n\\t#include <clipping_planes_vertex>\\n\\t#include <envmap_vertex>\\n\\t#include <fog_vertex>\\n}\\n\";\n\nvar meshlambert_frag = \"uniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform float opacity;\\nvarying vec3 vLightFront;\\n#ifdef DOUBLE_SIDED\\n\\tvarying vec3 vLightBack;\\n#endif\\n#include <common>\\n#include <packing>\\n#include <dithering_pars_fragment>\\n#include <color_pars_fragment>\\n#include <uv_pars_fragment>\\n#include <uv2_pars_fragment>\\n#include <map_pars_fragment>\\n#include <alphamap_pars_fragment>\\n#include <aomap_pars_fragment>\\n#include <lightmap_pars_fragment>\\n#include <emissivemap_pars_fragment>\\n#include <envmap_pars_fragment>\\n#include <bsdfs>\\n#include <lights_pars_begin>\\n#include <lights_pars_maps>\\n#include <fog_pars_fragment>\\n#include <shadowmap_pars_fragment>\\n#include <shadowmask_pars_fragment>\\n#include <specularmap_pars_fragment>\\n#include <logdepthbuf_pars_fragment>\\n#include <clipping_planes_pars_fragment>\\nvoid main() {\\n\\t#include <clipping_planes_fragment>\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include <logdepthbuf_fragment>\\n\\t#include <map_fragment>\\n\\t#include <color_fragment>\\n\\t#include <alphamap_fragment>\\n\\t#include <alphatest_fragment>\\n\\t#include <specularmap_fragment>\\n\\t#include <emissivemap_fragment>\\n\\treflectedLight.indirectDiffuse = getAmbientLightIrradiance( ambientLightColor );\\n\\t#include <lightmap_fragment>\\n\\treflectedLight.indirectDiffuse *= BRDF_Diffuse_Lambert( diffuseColor.rgb );\\n\\t#ifdef DOUBLE_SIDED\\n\\t\\treflectedLight.directDiffuse = ( gl_FrontFacing ) ? vLightFront : vLightBack;\\n\\t#else\\n\\t\\treflectedLight.directDiffuse = vLightFront;\\n\\t#endif\\n\\treflectedLight.directDiffuse *= BRDF_Diffuse_Lambert( diffuseColor.rgb ) * getShadowMask();\\n\\t#include <aomap_fragment>\\n\\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\\n\\t#include <envmap_fragment>\\n\\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\\n\\t#include <tonemapping_fragment>\\n\\t#include <encodings_fragment>\\n\\t#include <fog_fragment>\\n\\t#include <premultiplied_alpha_fragment>\\n\\t#include <dithering_fragment>\\n}\\n\";\n\nvar meshlambert_vert = \"#define LAMBERT\\nvarying vec3 vLightFront;\\n#ifdef DOUBLE_SIDED\\n\\tvarying vec3 vLightBack;\\n#endif\\n#include <common>\\n#include <uv_pars_vertex>\\n#include <uv2_pars_vertex>\\n#include <envmap_pars_vertex>\\n#include <bsdfs>\\n#include <lights_pars_begin>\\n#include <lights_pars_maps>\\n#include <color_pars_vertex>\\n#include <fog_pars_vertex>\\n#include <morphtarget_pars_vertex>\\n#include <skinning_pars_vertex>\\n#include <shadowmap_pars_vertex>\\n#include <logdepthbuf_pars_vertex>\\n#include <clipping_planes_pars_vertex>\\nvoid main() {\\n\\t#include <uv_vertex>\\n\\t#include <uv2_vertex>\\n\\t#include <color_vertex>\\n\\t#include <beginnormal_vertex>\\n\\t#include <morphnormal_vertex>\\n\\t#include <skinbase_vertex>\\n\\t#include <skinnormal_vertex>\\n\\t#include <defaultnormal_vertex>\\n\\t#include <begin_vertex>\\n\\t#include <morphtarget_vertex>\\n\\t#include <skinning_vertex>\\n\\t#include <project_vertex>\\n\\t#include <logdepthbuf_vertex>\\n\\t#include <clipping_planes_vertex>\\n\\t#include <worldpos_vertex>\\n\\t#include <envmap_vertex>\\n\\t#include <lights_lambert_vertex>\\n\\t#include <shadowmap_vertex>\\n\\t#include <fog_vertex>\\n}\\n\";\n\nvar meshphong_frag = \"#define PHONG\\nuniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform vec3 specular;\\nuniform float shininess;\\nuniform float opacity;\\n#include <common>\\n#include <packing>\\n#include <dithering_pars_fragment>\\n#include <color_pars_fragment>\\n#include <uv_pars_fragment>\\n#include <uv2_pars_fragment>\\n#include <map_pars_fragment>\\n#include <alphamap_pars_fragment>\\n#include <aomap_pars_fragment>\\n#include <lightmap_pars_fragment>\\n#include <emissivemap_pars_fragment>\\n#include <envmap_pars_fragment>\\n#include <gradientmap_pars_fragment>\\n#include <fog_pars_fragment>\\n#include <bsdfs>\\n#include <lights_pars_begin>\\n#include <lights_pars_maps>\\n#include <lights_phong_pars_fragment>\\n#include <shadowmap_pars_fragment>\\n#include <bumpmap_pars_fragment>\\n#include <normalmap_pars_fragment>\\n#include <specularmap_pars_fragment>\\n#include <logdepthbuf_pars_fragment>\\n#include <clipping_planes_pars_fragment>\\nvoid main() {\\n\\t#include <clipping_planes_fragment>\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include <logdepthbuf_fragment>\\n\\t#include <map_fragment>\\n\\t#include <color_fragment>\\n\\t#include <alphamap_fragment>\\n\\t#include <alphatest_fragment>\\n\\t#include <specularmap_fragment>\\n\\t#include <normal_fragment_begin>\\n\\t#include <normal_fragment_maps>\\n\\t#include <emissivemap_fragment>\\n\\t#include <lights_phong_fragment>\\n\\t#include <lights_fragment_begin>\\n\\t#include <lights_fragment_maps>\\n\\t#include <lights_fragment_end>\\n\\t#include <aomap_fragment>\\n\\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\\n\\t#include <envmap_fragment>\\n\\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\\n\\t#include <tonemapping_fragment>\\n\\t#include <encodings_fragment>\\n\\t#include <fog_fragment>\\n\\t#include <premultiplied_alpha_fragment>\\n\\t#include <dithering_fragment>\\n}\\n\";\n\nvar meshphong_vert = \"#define PHONG\\nvarying vec3 vViewPosition;\\n#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n#endif\\n#include <common>\\n#include <uv_pars_vertex>\\n#include <uv2_pars_vertex>\\n#include <displacementmap_pars_vertex>\\n#include <envmap_pars_vertex>\\n#include <color_pars_vertex>\\n#include <fog_pars_vertex>\\n#include <morphtarget_pars_vertex>\\n#include <skinning_pars_vertex>\\n#include <shadowmap_pars_vertex>\\n#include <logdepthbuf_pars_vertex>\\n#include <clipping_planes_pars_vertex>\\nvoid main() {\\n\\t#include <uv_vertex>\\n\\t#include <uv2_vertex>\\n\\t#include <color_vertex>\\n\\t#include <beginnormal_vertex>\\n\\t#include <morphnormal_vertex>\\n\\t#include <skinbase_vertex>\\n\\t#include <skinnormal_vertex>\\n\\t#include <defaultnormal_vertex>\\n#ifndef FLAT_SHADED\\n\\tvNormal = normalize( transformedNormal );\\n#endif\\n\\t#include <begin_vertex>\\n\\t#include <morphtarget_vertex>\\n\\t#include <skinning_vertex>\\n\\t#include <displacementmap_vertex>\\n\\t#include <project_vertex>\\n\\t#include <logdepthbuf_vertex>\\n\\t#include <clipping_planes_vertex>\\n\\tvViewPosition = - mvPosition.xyz;\\n\\t#include <worldpos_vertex>\\n\\t#include <envmap_vertex>\\n\\t#include <shadowmap_vertex>\\n\\t#include <fog_vertex>\\n}\\n\";\n\nvar meshphysical_frag = \"#define PHYSICAL\\nuniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform float roughness;\\nuniform float metalness;\\nuniform float opacity;\\n#ifndef STANDARD\\n\\tuniform float clearCoat;\\n\\tuniform float clearCoatRoughness;\\n#endif\\nvarying vec3 vViewPosition;\\n#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n#endif\\n#include <common>\\n#include <packing>\\n#include <dithering_pars_fragment>\\n#include <color_pars_fragment>\\n#include <uv_pars_fragment>\\n#include <uv2_pars_fragment>\\n#include <map_pars_fragment>\\n#include <alphamap_pars_fragment>\\n#include <aomap_pars_fragment>\\n#include <lightmap_pars_fragment>\\n#include <emissivemap_pars_fragment>\\n#include <envmap_pars_fragment>\\n#include <fog_pars_fragment>\\n#include <bsdfs>\\n#include <cube_uv_reflection_fragment>\\n#include <lights_pars_begin>\\n#include <lights_pars_maps>\\n#include <lights_physical_pars_fragment>\\n#include <shadowmap_pars_fragment>\\n#include <bumpmap_pars_fragment>\\n#include <normalmap_pars_fragment>\\n#include <roughnessmap_pars_fragment>\\n#include <metalnessmap_pars_fragment>\\n#include <logdepthbuf_pars_fragment>\\n#include <clipping_planes_pars_fragment>\\nvoid main() {\\n\\t#include <clipping_planes_fragment>\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include <logdepthbuf_fragment>\\n\\t#include <map_fragment>\\n\\t#include <color_fragment>\\n\\t#include <alphamap_fragment>\\n\\t#include <alphatest_fragment>\\n\\t#include <roughnessmap_fragment>\\n\\t#include <metalnessmap_fragment>\\n\\t#include <normal_fragment_begin>\\n\\t#include <normal_fragment_maps>\\n\\t#include <emissivemap_fragment>\\n\\t#include <lights_physical_fragment>\\n\\t#include <lights_fragment_begin>\\n\\t#include <lights_fragment_maps>\\n\\t#include <lights_fragment_end>\\n\\t#include <aomap_fragment>\\n\\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\\n\\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\\n\\t#include <tonemapping_fragment>\\n\\t#include <encodings_fragment>\\n\\t#include <fog_fragment>\\n\\t#include <premultiplied_alpha_fragment>\\n\\t#include <dithering_fragment>\\n}\\n\";\n\nvar meshphysical_vert = \"#define PHYSICAL\\nvarying vec3 vViewPosition;\\n#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n#endif\\n#include <common>\\n#include <uv_pars_vertex>\\n#include <uv2_pars_vertex>\\n#include <displacementmap_pars_vertex>\\n#include <color_pars_vertex>\\n#include <fog_pars_vertex>\\n#include <morphtarget_pars_vertex>\\n#include <skinning_pars_vertex>\\n#include <shadowmap_pars_vertex>\\n#include <logdepthbuf_pars_vertex>\\n#include <clipping_planes_pars_vertex>\\nvoid main() {\\n\\t#include <uv_vertex>\\n\\t#include <uv2_vertex>\\n\\t#include <color_vertex>\\n\\t#include <beginnormal_vertex>\\n\\t#include <morphnormal_vertex>\\n\\t#include <skinbase_vertex>\\n\\t#include <skinnormal_vertex>\\n\\t#include <defaultnormal_vertex>\\n#ifndef FLAT_SHADED\\n\\tvNormal = normalize( transformedNormal );\\n#endif\\n\\t#include <begin_vertex>\\n\\t#include <morphtarget_vertex>\\n\\t#include <skinning_vertex>\\n\\t#include <displacementmap_vertex>\\n\\t#include <project_vertex>\\n\\t#include <logdepthbuf_vertex>\\n\\t#include <clipping_planes_vertex>\\n\\tvViewPosition = - mvPosition.xyz;\\n\\t#include <worldpos_vertex>\\n\\t#include <shadowmap_vertex>\\n\\t#include <fog_vertex>\\n}\\n\";\n\nvar normal_frag = \"#define NORMAL\\nuniform float opacity;\\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP )\\n\\tvarying vec3 vViewPosition;\\n#endif\\n#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n#endif\\n#include <packing>\\n#include <uv_pars_fragment>\\n#include <bumpmap_pars_fragment>\\n#include <normalmap_pars_fragment>\\n#include <logdepthbuf_pars_fragment>\\nvoid main() {\\n\\t#include <logdepthbuf_fragment>\\n\\t#include <normal_fragment_begin>\\n\\t#include <normal_fragment_maps>\\n\\tgl_FragColor = vec4( packNormalToRGB( normal ), opacity );\\n}\\n\";\n\nvar normal_vert = \"#define NORMAL\\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP )\\n\\tvarying vec3 vViewPosition;\\n#endif\\n#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n#endif\\n#include <uv_pars_vertex>\\n#include <displacementmap_pars_vertex>\\n#include <morphtarget_pars_vertex>\\n#include <skinning_pars_vertex>\\n#include <logdepthbuf_pars_vertex>\\nvoid main() {\\n\\t#include <uv_vertex>\\n\\t#include <beginnormal_vertex>\\n\\t#include <morphnormal_vertex>\\n\\t#include <skinbase_vertex>\\n\\t#include <skinnormal_vertex>\\n\\t#include <defaultnormal_vertex>\\n#ifndef FLAT_SHADED\\n\\tvNormal = normalize( transformedNormal );\\n#endif\\n\\t#include <begin_vertex>\\n\\t#include <morphtarget_vertex>\\n\\t#include <skinning_vertex>\\n\\t#include <displacementmap_vertex>\\n\\t#include <project_vertex>\\n\\t#include <logdepthbuf_vertex>\\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP )\\n\\tvViewPosition = - mvPosition.xyz;\\n#endif\\n}\\n\";\n\nvar points_frag = \"uniform vec3 diffuse;\\nuniform float opacity;\\n#include <common>\\n#include <packing>\\n#include <color_pars_fragment>\\n#include <map_particle_pars_fragment>\\n#include <fog_pars_fragment>\\n#include <shadowmap_pars_fragment>\\n#include <logdepthbuf_pars_fragment>\\n#include <clipping_planes_pars_fragment>\\nvoid main() {\\n\\t#include <clipping_planes_fragment>\\n\\tvec3 outgoingLight = vec3( 0.0 );\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include <logdepthbuf_fragment>\\n\\t#include <map_particle_fragment>\\n\\t#include <color_fragment>\\n\\t#include <alphatest_fragment>\\n\\toutgoingLight = diffuseColor.rgb;\\n\\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\\n\\t#include <premultiplied_alpha_fragment>\\n\\t#include <tonemapping_fragment>\\n\\t#include <encodings_fragment>\\n\\t#include <fog_fragment>\\n}\\n\";\n\nvar points_vert = \"uniform float size;\\nuniform float scale;\\n#include <common>\\n#include <color_pars_vertex>\\n#include <fog_pars_vertex>\\n#include <shadowmap_pars_vertex>\\n#include <logdepthbuf_pars_vertex>\\n#include <clipping_planes_pars_vertex>\\nvoid main() {\\n\\t#include <color_vertex>\\n\\t#include <begin_vertex>\\n\\t#include <project_vertex>\\n\\t#ifdef USE_SIZEATTENUATION\\n\\t\\tgl_PointSize = size * ( scale / - mvPosition.z );\\n\\t#else\\n\\t\\tgl_PointSize = size;\\n\\t#endif\\n\\t#include <logdepthbuf_vertex>\\n\\t#include <clipping_planes_vertex>\\n\\t#include <worldpos_vertex>\\n\\t#include <shadowmap_vertex>\\n\\t#include <fog_vertex>\\n}\\n\";\n\nvar shadow_frag = \"uniform vec3 color;\\nuniform float opacity;\\n#include <common>\\n#include <packing>\\n#include <fog_pars_fragment>\\n#include <bsdfs>\\n#include <lights_pars_begin>\\n#include <shadowmap_pars_fragment>\\n#include <shadowmask_pars_fragment>\\nvoid main() {\\n\\tgl_FragColor = vec4( color, opacity * ( 1.0 - getShadowMask() ) );\\n\\t#include <fog_fragment>\\n}\\n\";\n\nvar shadow_vert = \"#include <fog_pars_vertex>\\n#include <shadowmap_pars_vertex>\\nvoid main() {\\n\\t#include <begin_vertex>\\n\\t#include <project_vertex>\\n\\t#include <worldpos_vertex>\\n\\t#include <shadowmap_vertex>\\n\\t#include <fog_vertex>\\n}\\n\";\n\nvar ShaderChunk = {\n\talphamap_fragment: alphamap_fragment,\n\talphamap_pars_fragment: alphamap_pars_fragment,\n\talphatest_fragment: alphatest_fragment,\n\taomap_fragment: aomap_fragment,\n\taomap_pars_fragment: aomap_pars_fragment,\n\tbegin_vertex: begin_vertex,\n\tbeginnormal_vertex: beginnormal_vertex,\n\tbsdfs: bsdfs,\n\tbumpmap_pars_fragment: bumpmap_pars_fragment,\n\tclipping_planes_fragment: clipping_planes_fragment,\n\tclipping_planes_pars_fragment: clipping_planes_pars_fragment,\n\tclipping_planes_pars_vertex: clipping_planes_pars_vertex,\n\tclipping_planes_vertex: clipping_planes_vertex,\n\tcolor_fragment: color_fragment,\n\tcolor_pars_fragment: color_pars_fragment,\n\tcolor_pars_vertex: color_pars_vertex,\n\tcolor_vertex: color_vertex,\n\tcommon: common,\n\tcube_uv_reflection_fragment: cube_uv_reflection_fragment,\n\tdefaultnormal_vertex: defaultnormal_vertex,\n\tdisplacementmap_pars_vertex: displacementmap_pars_vertex,\n\tdisplacementmap_vertex: displacementmap_vertex,\n\temissivemap_fragment: emissivemap_fragment,\n\temissivemap_pars_fragment: emissivemap_pars_fragment,\n\tencodings_fragment: encodings_fragment,\n\tencodings_pars_fragment: encodings_pars_fragment,\n\tenvmap_fragment: envmap_fragment,\n\tenvmap_pars_fragment: envmap_pars_fragment,\n\tenvmap_pars_vertex: envmap_pars_vertex,\n\tenvmap_vertex: envmap_vertex,\n\tfog_vertex: fog_vertex,\n\tfog_pars_vertex: fog_pars_vertex,\n\tfog_fragment: fog_fragment,\n\tfog_pars_fragment: fog_pars_fragment,\n\tgradientmap_pars_fragment: gradientmap_pars_fragment,\n\tlightmap_fragment: lightmap_fragment,\n\tlightmap_pars_fragment: lightmap_pars_fragment,\n\tlights_lambert_vertex: lights_lambert_vertex,\n\tlights_pars_begin: lights_pars_begin,\n\tlights_pars_maps: lights_pars_maps,\n\tlights_phong_fragment: lights_phong_fragment,\n\tlights_phong_pars_fragment: lights_phong_pars_fragment,\n\tlights_physical_fragment: lights_physical_fragment,\n\tlights_physical_pars_fragment: lights_physical_pars_fragment,\n\tlights_fragment_begin: lights_fragment_begin,\n\tlights_fragment_maps: lights_fragment_maps,\n\tlights_fragment_end: lights_fragment_end,\n\tlogdepthbuf_fragment: logdepthbuf_fragment,\n\tlogdepthbuf_pars_fragment: logdepthbuf_pars_fragment,\n\tlogdepthbuf_pars_vertex: logdepthbuf_pars_vertex,\n\tlogdepthbuf_vertex: logdepthbuf_vertex,\n\tmap_fragment: map_fragment,\n\tmap_pars_fragment: map_pars_fragment,\n\tmap_particle_fragment: map_particle_fragment,\n\tmap_particle_pars_fragment: map_particle_pars_fragment,\n\tmetalnessmap_fragment: metalnessmap_fragment,\n\tmetalnessmap_pars_fragment: metalnessmap_pars_fragment,\n\tmorphnormal_vertex: morphnormal_vertex,\n\tmorphtarget_pars_vertex: morphtarget_pars_vertex,\n\tmorphtarget_vertex: morphtarget_vertex,\n\tnormal_fragment_begin: normal_fragment_begin,\n\tnormal_fragment_maps: normal_fragment_maps,\n\tnormalmap_pars_fragment: normalmap_pars_fragment,\n\tpacking: packing,\n\tpremultiplied_alpha_fragment: premultiplied_alpha_fragment,\n\tproject_vertex: project_vertex,\n\tdithering_fragment: dithering_fragment,\n\tdithering_pars_fragment: dithering_pars_fragment,\n\troughnessmap_fragment: roughnessmap_fragment,\n\troughnessmap_pars_fragment: roughnessmap_pars_fragment,\n\tshadowmap_pars_fragment: shadowmap_pars_fragment,\n\tshadowmap_pars_vertex: shadowmap_pars_vertex,\n\tshadowmap_vertex: shadowmap_vertex,\n\tshadowmask_pars_fragment: shadowmask_pars_fragment,\n\tskinbase_vertex: skinbase_vertex,\n\tskinning_pars_vertex: skinning_pars_vertex,\n\tskinning_vertex: skinning_vertex,\n\tskinnormal_vertex: skinnormal_vertex,\n\tspecularmap_fragment: specularmap_fragment,\n\tspecularmap_pars_fragment: specularmap_pars_fragment,\n\ttonemapping_fragment: tonemapping_fragment,\n\ttonemapping_pars_fragment: tonemapping_pars_fragment,\n\tuv_pars_fragment: uv_pars_fragment,\n\tuv_pars_vertex: uv_pars_vertex,\n\tuv_vertex: uv_vertex,\n\tuv2_pars_fragment: uv2_pars_fragment,\n\tuv2_pars_vertex: uv2_pars_vertex,\n\tuv2_vertex: uv2_vertex,\n\tworldpos_vertex: worldpos_vertex,\n\n\tcube_frag: cube_frag,\n\tcube_vert: cube_vert,\n\tdepth_frag: depth_frag,\n\tdepth_vert: depth_vert,\n\tdistanceRGBA_frag: distanceRGBA_frag,\n\tdistanceRGBA_vert: distanceRGBA_vert,\n\tequirect_frag: equirect_frag,\n\tequirect_vert: equirect_vert,\n\tlinedashed_frag: linedashed_frag,\n\tlinedashed_vert: linedashed_vert,\n\tmeshbasic_frag: meshbasic_frag,\n\tmeshbasic_vert: meshbasic_vert,\n\tmeshlambert_frag: meshlambert_frag,\n\tmeshlambert_vert: meshlambert_vert,\n\tmeshphong_frag: meshphong_frag,\n\tmeshphong_vert: meshphong_vert,\n\tmeshphysical_frag: meshphysical_frag,\n\tmeshphysical_vert: meshphysical_vert,\n\tnormal_frag: normal_frag,\n\tnormal_vert: normal_vert,\n\tpoints_frag: points_frag,\n\tpoints_vert: points_vert,\n\tshadow_frag: shadow_frag,\n\tshadow_vert: shadow_vert\n};\n\n/**\n * Uniform Utilities\n */\n\nvar UniformsUtils = {\n\n\tmerge: function ( uniforms ) {\n\n\t\tvar merged = {};\n\n\t\tfor ( var u = 0; u < uniforms.length; u ++ ) {\n\n\t\t\tvar tmp = this.clone( uniforms[ u ] );\n\n\t\t\tfor ( var p in tmp ) {\n\n\t\t\t\tmerged[ p ] = tmp[ p ];\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn merged;\n\n\t},\n\n\tclone: function ( uniforms_src ) {\n\n\t\tvar uniforms_dst = {};\n\n\t\tfor ( var u in uniforms_src ) {\n\n\t\t\tuniforms_dst[ u ] = {};\n\n\t\t\tfor ( var p in uniforms_src[ u ] ) {\n\n\t\t\t\tvar parameter_src = uniforms_src[ u ][ p ];\n\n\t\t\t\tif ( parameter_src && ( parameter_src.isColor ||\n\t\t\t\t\tparameter_src.isMatrix3 || parameter_src.isMatrix4 ||\n\t\t\t\t\tparameter_src.isVector2 || parameter_src.isVector3 || parameter_src.isVector4 ||\n\t\t\t\t\tparameter_src.isTexture ) ) {\n\n\t\t\t\t\tuniforms_dst[ u ][ p ] = parameter_src.clone();\n\n\t\t\t\t} else if ( Array.isArray( parameter_src ) ) {\n\n\t\t\t\t\tuniforms_dst[ u ][ p ] = parameter_src.slice();\n\n\t\t\t\t} else {\n\n\t\t\t\t\tuniforms_dst[ u ][ p ] = parameter_src;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn uniforms_dst;\n\n\t}\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nvar ColorKeywords = { 'aliceblue': 0xF0F8FF, 'antiquewhite': 0xFAEBD7, 'aqua': 0x00FFFF, 'aquamarine': 0x7FFFD4, 'azure': 0xF0FFFF,\n\t'beige': 0xF5F5DC, 'bisque': 0xFFE4C4, 'black': 0x000000, 'blanchedalmond': 0xFFEBCD, 'blue': 0x0000FF, 'blueviolet': 0x8A2BE2,\n\t'brown': 0xA52A2A, 'burlywood': 0xDEB887, 'cadetblue': 0x5F9EA0, 'chartreuse': 0x7FFF00, 'chocolate': 0xD2691E, 'coral': 0xFF7F50,\n\t'cornflowerblue': 0x6495ED, 'cornsilk': 0xFFF8DC, 'crimson': 0xDC143C, 'cyan': 0x00FFFF, 'darkblue': 0x00008B, 'darkcyan': 0x008B8B,\n\t'darkgoldenrod': 0xB8860B, 'darkgray': 0xA9A9A9, 'darkgreen': 0x006400, 'darkgrey': 0xA9A9A9, 'darkkhaki': 0xBDB76B, 'darkmagenta': 0x8B008B,\n\t'darkolivegreen': 0x556B2F, 'darkorange': 0xFF8C00, 'darkorchid': 0x9932CC, 'darkred': 0x8B0000, 'darksalmon': 0xE9967A, 'darkseagreen': 0x8FBC8F,\n\t'darkslateblue': 0x483D8B, 'darkslategray': 0x2F4F4F, 'darkslategrey': 0x2F4F4F, 'darkturquoise': 0x00CED1, 'darkviolet': 0x9400D3,\n\t'deeppink': 0xFF1493, 'deepskyblue': 0x00BFFF, 'dimgray': 0x696969, 'dimgrey': 0x696969, 'dodgerblue': 0x1E90FF, 'firebrick': 0xB22222,\n\t'floralwhite': 0xFFFAF0, 'forestgreen': 0x228B22, 'fuchsia': 0xFF00FF, 'gainsboro': 0xDCDCDC, 'ghostwhite': 0xF8F8FF, 'gold': 0xFFD700,\n\t'goldenrod': 0xDAA520, 'gray': 0x808080, 'green': 0x008000, 'greenyellow': 0xADFF2F, 'grey': 0x808080, 'honeydew': 0xF0FFF0, 'hotpink': 0xFF69B4,\n\t'indianred': 0xCD5C5C, 'indigo': 0x4B0082, 'ivory': 0xFFFFF0, 'khaki': 0xF0E68C, 'lavender': 0xE6E6FA, 'lavenderblush': 0xFFF0F5, 'lawngreen': 0x7CFC00,\n\t'lemonchiffon': 0xFFFACD, 'lightblue': 0xADD8E6, 'lightcoral': 0xF08080, 'lightcyan': 0xE0FFFF, 'lightgoldenrodyellow': 0xFAFAD2, 'lightgray': 0xD3D3D3,\n\t'lightgreen': 0x90EE90, 'lightgrey': 0xD3D3D3, 'lightpink': 0xFFB6C1, 'lightsalmon': 0xFFA07A, 'lightseagreen': 0x20B2AA, 'lightskyblue': 0x87CEFA,\n\t'lightslategray': 0x778899, 'lightslategrey': 0x778899, 'lightsteelblue': 0xB0C4DE, 'lightyellow': 0xFFFFE0, 'lime': 0x00FF00, 'limegreen': 0x32CD32,\n\t'linen': 0xFAF0E6, 'magenta': 0xFF00FF, 'maroon': 0x800000, 'mediumaquamarine': 0x66CDAA, 'mediumblue': 0x0000CD, 'mediumorchid': 0xBA55D3,\n\t'mediumpurple': 0x9370DB, 'mediumseagreen': 0x3CB371, 'mediumslateblue': 0x7B68EE, 'mediumspringgreen': 0x00FA9A, 'mediumturquoise': 0x48D1CC,\n\t'mediumvioletred': 0xC71585, 'midnightblue': 0x191970, 'mintcream': 0xF5FFFA, 'mistyrose': 0xFFE4E1, 'moccasin': 0xFFE4B5, 'navajowhite': 0xFFDEAD,\n\t'navy': 0x000080, 'oldlace': 0xFDF5E6, 'olive': 0x808000, 'olivedrab': 0x6B8E23, 'orange': 0xFFA500, 'orangered': 0xFF4500, 'orchid': 0xDA70D6,\n\t'palegoldenrod': 0xEEE8AA, 'palegreen': 0x98FB98, 'paleturquoise': 0xAFEEEE, 'palevioletred': 0xDB7093, 'papayawhip': 0xFFEFD5, 'peachpuff': 0xFFDAB9,\n\t'peru': 0xCD853F, 'pink': 0xFFC0CB, 'plum': 0xDDA0DD, 'powderblue': 0xB0E0E6, 'purple': 0x800080, 'rebeccapurple': 0x663399, 'red': 0xFF0000, 'rosybrown': 0xBC8F8F,\n\t'royalblue': 0x4169E1, 'saddlebrown': 0x8B4513, 'salmon': 0xFA8072, 'sandybrown': 0xF4A460, 'seagreen': 0x2E8B57, 'seashell': 0xFFF5EE,\n\t'sienna': 0xA0522D, 'silver': 0xC0C0C0, 'skyblue': 0x87CEEB, 'slateblue': 0x6A5ACD, 'slategray': 0x708090, 'slategrey': 0x708090, 'snow': 0xFFFAFA,\n\t'springgreen': 0x00FF7F, 'steelblue': 0x4682B4, 'tan': 0xD2B48C, 'teal': 0x008080, 'thistle': 0xD8BFD8, 'tomato': 0xFF6347, 'turquoise': 0x40E0D0,\n\t'violet': 0xEE82EE, 'wheat': 0xF5DEB3, 'white': 0xFFFFFF, 'whitesmoke': 0xF5F5F5, 'yellow': 0xFFFF00, 'yellowgreen': 0x9ACD32 };\n\nfunction Color( r, g, b ) {\n\n\tif ( g === undefined && b === undefined ) {\n\n\t\t// r is THREE.Color, hex or string\n\t\treturn this.set( r );\n\n\t}\n\n\treturn this.setRGB( r, g, b );\n\n}\n\nObject.assign( Color.prototype, {\n\n\tisColor: true,\n\n\tr: 1, g: 1, b: 1,\n\n\tset: function ( value ) {\n\n\t\tif ( value && value.isColor ) {\n\n\t\t\tthis.copy( value );\n\n\t\t} else if ( typeof value === 'number' ) {\n\n\t\t\tthis.setHex( value );\n\n\t\t} else if ( typeof value === 'string' ) {\n\n\t\t\tthis.setStyle( value );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tsetScalar: function ( scalar ) {\n\n\t\tthis.r = scalar;\n\t\tthis.g = scalar;\n\t\tthis.b = scalar;\n\n\t\treturn this;\n\n\t},\n\n\tsetHex: function ( hex ) {\n\n\t\thex = Math.floor( hex );\n\n\t\tthis.r = ( hex >> 16 & 255 ) / 255;\n\t\tthis.g = ( hex >> 8 & 255 ) / 255;\n\t\tthis.b = ( hex & 255 ) / 255;\n\n\t\treturn this;\n\n\t},\n\n\tsetRGB: function ( r, g, b ) {\n\n\t\tthis.r = r;\n\t\tthis.g = g;\n\t\tthis.b = b;\n\n\t\treturn this;\n\n\t},\n\n\tsetHSL: function () {\n\n\t\tfunction hue2rgb( p, q, t ) {\n\n\t\t\tif ( t < 0 ) t += 1;\n\t\t\tif ( t > 1 ) t -= 1;\n\t\t\tif ( t < 1 / 6 ) return p + ( q - p ) * 6 * t;\n\t\t\tif ( t < 1 / 2 ) return q;\n\t\t\tif ( t < 2 / 3 ) return p + ( q - p ) * 6 * ( 2 / 3 - t );\n\t\t\treturn p;\n\n\t\t}\n\n\t\treturn function setHSL( h, s, l ) {\n\n\t\t\t// h,s,l ranges are in 0.0 - 1.0\n\t\t\th = _Math.euclideanModulo( h, 1 );\n\t\t\ts = _Math.clamp( s, 0, 1 );\n\t\t\tl = _Math.clamp( l, 0, 1 );\n\n\t\t\tif ( s === 0 ) {\n\n\t\t\t\tthis.r = this.g = this.b = l;\n\n\t\t\t} else {\n\n\t\t\t\tvar p = l <= 0.5 ? l * ( 1 + s ) : l + s - ( l * s );\n\t\t\t\tvar q = ( 2 * l ) - p;\n\n\t\t\t\tthis.r = hue2rgb( q, p, h + 1 / 3 );\n\t\t\t\tthis.g = hue2rgb( q, p, h );\n\t\t\t\tthis.b = hue2rgb( q, p, h - 1 / 3 );\n\n\t\t\t}\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tsetStyle: function ( style ) {\n\n\t\tfunction handleAlpha( string ) {\n\n\t\t\tif ( string === undefined ) return;\n\n\t\t\tif ( parseFloat( string ) < 1 ) {\n\n\t\t\t\tconsole.warn( 'THREE.Color: Alpha component of ' + style + ' will be ignored.' );\n\n\t\t\t}\n\n\t\t}\n\n\n\t\tvar m;\n\n\t\tif ( m = /^((?:rgb|hsl)a?)\\(\\s*([^\\)]*)\\)/.exec( style ) ) {\n\n\t\t\t// rgb / hsl\n\n\t\t\tvar color;\n\t\t\tvar name = m[ 1 ];\n\t\t\tvar components = m[ 2 ];\n\n\t\t\tswitch ( name ) {\n\n\t\t\t\tcase 'rgb':\n\t\t\t\tcase 'rgba':\n\n\t\t\t\t\tif ( color = /^(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)\\s*(,\\s*([0-9]*\\.?[0-9]+)\\s*)?$/.exec( components ) ) {\n\n\t\t\t\t\t\t// rgb(255,0,0) rgba(255,0,0,0.5)\n\t\t\t\t\t\tthis.r = Math.min( 255, parseInt( color[ 1 ], 10 ) ) / 255;\n\t\t\t\t\t\tthis.g = Math.min( 255, parseInt( color[ 2 ], 10 ) ) / 255;\n\t\t\t\t\t\tthis.b = Math.min( 255, parseInt( color[ 3 ], 10 ) ) / 255;\n\n\t\t\t\t\t\thandleAlpha( color[ 5 ] );\n\n\t\t\t\t\t\treturn this;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( color = /^(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*(,\\s*([0-9]*\\.?[0-9]+)\\s*)?$/.exec( components ) ) {\n\n\t\t\t\t\t\t// rgb(100%,0%,0%) rgba(100%,0%,0%,0.5)\n\t\t\t\t\t\tthis.r = Math.min( 100, parseInt( color[ 1 ], 10 ) ) / 100;\n\t\t\t\t\t\tthis.g = Math.min( 100, parseInt( color[ 2 ], 10 ) ) / 100;\n\t\t\t\t\t\tthis.b = Math.min( 100, parseInt( color[ 3 ], 10 ) ) / 100;\n\n\t\t\t\t\t\thandleAlpha( color[ 5 ] );\n\n\t\t\t\t\t\treturn this;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'hsl':\n\t\t\t\tcase 'hsla':\n\n\t\t\t\t\tif ( color = /^([0-9]*\\.?[0-9]+)\\s*,\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*(,\\s*([0-9]*\\.?[0-9]+)\\s*)?$/.exec( components ) ) {\n\n\t\t\t\t\t\t// hsl(120,50%,50%) hsla(120,50%,50%,0.5)\n\t\t\t\t\t\tvar h = parseFloat( color[ 1 ] ) / 360;\n\t\t\t\t\t\tvar s = parseInt( color[ 2 ], 10 ) / 100;\n\t\t\t\t\t\tvar l = parseInt( color[ 3 ], 10 ) / 100;\n\n\t\t\t\t\t\thandleAlpha( color[ 5 ] );\n\n\t\t\t\t\t\treturn this.setHSL( h, s, l );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t} else if ( m = /^\\#([A-Fa-f0-9]+)$/.exec( style ) ) {\n\n\t\t\t// hex color\n\n\t\t\tvar hex = m[ 1 ];\n\t\t\tvar size = hex.length;\n\n\t\t\tif ( size === 3 ) {\n\n\t\t\t\t// #ff0\n\t\t\t\tthis.r = parseInt( hex.charAt( 0 ) + hex.charAt( 0 ), 16 ) / 255;\n\t\t\t\tthis.g = parseInt( hex.charAt( 1 ) + hex.charAt( 1 ), 16 ) / 255;\n\t\t\t\tthis.b = parseInt( hex.charAt( 2 ) + hex.charAt( 2 ), 16 ) / 255;\n\n\t\t\t\treturn this;\n\n\t\t\t} else if ( size === 6 ) {\n\n\t\t\t\t// #ff0000\n\t\t\t\tthis.r = parseInt( hex.charAt( 0 ) + hex.charAt( 1 ), 16 ) / 255;\n\t\t\t\tthis.g = parseInt( hex.charAt( 2 ) + hex.charAt( 3 ), 16 ) / 255;\n\t\t\t\tthis.b = parseInt( hex.charAt( 4 ) + hex.charAt( 5 ), 16 ) / 255;\n\n\t\t\t\treturn this;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( style && style.length > 0 ) {\n\n\t\t\t// color keywords\n\t\t\tvar hex = ColorKeywords[ style ];\n\n\t\t\tif ( hex !== undefined ) {\n\n\t\t\t\t// red\n\t\t\t\tthis.setHex( hex );\n\n\t\t\t} else {\n\n\t\t\t\t// unknown color\n\t\t\t\tconsole.warn( 'THREE.Color: Unknown color ' + style );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.r, this.g, this.b );\n\n\t},\n\n\tcopy: function ( color ) {\n\n\t\tthis.r = color.r;\n\t\tthis.g = color.g;\n\t\tthis.b = color.b;\n\n\t\treturn this;\n\n\t},\n\n\tcopyGammaToLinear: function ( color, gammaFactor ) {\n\n\t\tif ( gammaFactor === undefined ) gammaFactor = 2.0;\n\n\t\tthis.r = Math.pow( color.r, gammaFactor );\n\t\tthis.g = Math.pow( color.g, gammaFactor );\n\t\tthis.b = Math.pow( color.b, gammaFactor );\n\n\t\treturn this;\n\n\t},\n\n\tcopyLinearToGamma: function ( color, gammaFactor ) {\n\n\t\tif ( gammaFactor === undefined ) gammaFactor = 2.0;\n\n\t\tvar safeInverse = ( gammaFactor > 0 ) ? ( 1.0 / gammaFactor ) : 1.0;\n\n\t\tthis.r = Math.pow( color.r, safeInverse );\n\t\tthis.g = Math.pow( color.g, safeInverse );\n\t\tthis.b = Math.pow( color.b, safeInverse );\n\n\t\treturn this;\n\n\t},\n\n\tconvertGammaToLinear: function () {\n\n\t\tvar r = this.r, g = this.g, b = this.b;\n\n\t\tthis.r = r * r;\n\t\tthis.g = g * g;\n\t\tthis.b = b * b;\n\n\t\treturn this;\n\n\t},\n\n\tconvertLinearToGamma: function () {\n\n\t\tthis.r = Math.sqrt( this.r );\n\t\tthis.g = Math.sqrt( this.g );\n\t\tthis.b = Math.sqrt( this.b );\n\n\t\treturn this;\n\n\t},\n\n\tgetHex: function () {\n\n\t\treturn ( this.r * 255 ) << 16 ^ ( this.g * 255 ) << 8 ^ ( this.b * 255 ) << 0;\n\n\t},\n\n\tgetHexString: function () {\n\n\t\treturn ( '000000' + this.getHex().toString( 16 ) ).slice( - 6 );\n\n\t},\n\n\tgetHSL: function ( target ) {\n\n\t\t// h,s,l ranges are in 0.0 - 1.0\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Color: .getHSL() target is now required' );\n\t\t\ttarget = { h: 0, s: 0, l: 0 };\n\n\t\t}\n\n\t\tvar r = this.r, g = this.g, b = this.b;\n\n\t\tvar max = Math.max( r, g, b );\n\t\tvar min = Math.min( r, g, b );\n\n\t\tvar hue, saturation;\n\t\tvar lightness = ( min + max ) / 2.0;\n\n\t\tif ( min === max ) {\n\n\t\t\thue = 0;\n\t\t\tsaturation = 0;\n\n\t\t} else {\n\n\t\t\tvar delta = max - min;\n\n\t\t\tsaturation = lightness <= 0.5 ? delta / ( max + min ) : delta / ( 2 - max - min );\n\n\t\t\tswitch ( max ) {\n\n\t\t\t\tcase r: hue = ( g - b ) / delta + ( g < b ? 6 : 0 ); break;\n\t\t\t\tcase g: hue = ( b - r ) / delta + 2; break;\n\t\t\t\tcase b: hue = ( r - g ) / delta + 4; break;\n\n\t\t\t}\n\n\t\t\thue /= 6;\n\n\t\t}\n\n\t\ttarget.h = hue;\n\t\ttarget.s = saturation;\n\t\ttarget.l = lightness;\n\n\t\treturn target;\n\n\t},\n\n\tgetStyle: function () {\n\n\t\treturn 'rgb(' + ( ( this.r * 255 ) | 0 ) + ',' + ( ( this.g * 255 ) | 0 ) + ',' + ( ( this.b * 255 ) | 0 ) + ')';\n\n\t},\n\n\toffsetHSL: function () {\n\n\t\tvar hsl = {};\n\n\t\treturn function ( h, s, l ) {\n\n\t\t\tthis.getHSL( hsl );\n\n\t\t\thsl.h += h; hsl.s += s; hsl.l += l;\n\n\t\t\tthis.setHSL( hsl.h, hsl.s, hsl.l );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tadd: function ( color ) {\n\n\t\tthis.r += color.r;\n\t\tthis.g += color.g;\n\t\tthis.b += color.b;\n\n\t\treturn this;\n\n\t},\n\n\taddColors: function ( color1, color2 ) {\n\n\t\tthis.r = color1.r + color2.r;\n\t\tthis.g = color1.g + color2.g;\n\t\tthis.b = color1.b + color2.b;\n\n\t\treturn this;\n\n\t},\n\n\taddScalar: function ( s ) {\n\n\t\tthis.r += s;\n\t\tthis.g += s;\n\t\tthis.b += s;\n\n\t\treturn this;\n\n\t},\n\n\tsub: function ( color ) {\n\n\t\tthis.r = Math.max( 0, this.r - color.r );\n\t\tthis.g = Math.max( 0, this.g - color.g );\n\t\tthis.b = Math.max( 0, this.b - color.b );\n\n\t\treturn this;\n\n\t},\n\n\tmultiply: function ( color ) {\n\n\t\tthis.r *= color.r;\n\t\tthis.g *= color.g;\n\t\tthis.b *= color.b;\n\n\t\treturn this;\n\n\t},\n\n\tmultiplyScalar: function ( s ) {\n\n\t\tthis.r *= s;\n\t\tthis.g *= s;\n\t\tthis.b *= s;\n\n\t\treturn this;\n\n\t},\n\n\tlerp: function ( color, alpha ) {\n\n\t\tthis.r += ( color.r - this.r ) * alpha;\n\t\tthis.g += ( color.g - this.g ) * alpha;\n\t\tthis.b += ( color.b - this.b ) * alpha;\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( c ) {\n\n\t\treturn ( c.r === this.r ) && ( c.g === this.g ) && ( c.b === this.b );\n\n\t},\n\n\tfromArray: function ( array, offset ) {\n\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tthis.r = array[ offset ];\n\t\tthis.g = array[ offset + 1 ];\n\t\tthis.b = array[ offset + 2 ];\n\n\t\treturn this;\n\n\t},\n\n\ttoArray: function ( array, offset ) {\n\n\t\tif ( array === undefined ) array = [];\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tarray[ offset ] = this.r;\n\t\tarray[ offset + 1 ] = this.g;\n\t\tarray[ offset + 2 ] = this.b;\n\n\t\treturn array;\n\n\t},\n\n\ttoJSON: function () {\n\n\t\treturn this.getHex();\n\n\t}\n\n} );\n\n/**\n * Uniforms library for shared webgl shaders\n */\n\nvar UniformsLib = {\n\n\tcommon: {\n\n\t\tdiffuse: { value: new Color( 0xeeeeee ) },\n\t\topacity: { value: 1.0 },\n\n\t\tmap: { value: null },\n\t\tuvTransform: { value: new Matrix3() },\n\n\t\talphaMap: { value: null },\n\n\t},\n\n\tspecularmap: {\n\n\t\tspecularMap: { value: null },\n\n\t},\n\n\tenvmap: {\n\n\t\tenvMap: { value: null },\n\t\tflipEnvMap: { value: - 1 },\n\t\treflectivity: { value: 1.0 },\n\t\trefractionRatio: { value: 0.98 },\n\t\tmaxMipLevel: { value: 0 }\n\n\t},\n\n\taomap: {\n\n\t\taoMap: { value: null },\n\t\taoMapIntensity: { value: 1 }\n\n\t},\n\n\tlightmap: {\n\n\t\tlightMap: { value: null },\n\t\tlightMapIntensity: { value: 1 }\n\n\t},\n\n\temissivemap: {\n\n\t\temissiveMap: { value: null }\n\n\t},\n\n\tbumpmap: {\n\n\t\tbumpMap: { value: null },\n\t\tbumpScale: { value: 1 }\n\n\t},\n\n\tnormalmap: {\n\n\t\tnormalMap: { value: null },\n\t\tnormalScale: { value: new Vector2( 1, 1 ) }\n\n\t},\n\n\tdisplacementmap: {\n\n\t\tdisplacementMap: { value: null },\n\t\tdisplacementScale: { value: 1 },\n\t\tdisplacementBias: { value: 0 }\n\n\t},\n\n\troughnessmap: {\n\n\t\troughnessMap: { value: null }\n\n\t},\n\n\tmetalnessmap: {\n\n\t\tmetalnessMap: { value: null }\n\n\t},\n\n\tgradientmap: {\n\n\t\tgradientMap: { value: null }\n\n\t},\n\n\tfog: {\n\n\t\tfogDensity: { value: 0.00025 },\n\t\tfogNear: { value: 1 },\n\t\tfogFar: { value: 2000 },\n\t\tfogColor: { value: new Color( 0xffffff ) }\n\n\t},\n\n\tlights: {\n\n\t\tambientLightColor: { value: [] },\n\n\t\tdirectionalLights: { value: [], properties: {\n\t\t\tdirection: {},\n\t\t\tcolor: {},\n\n\t\t\tshadow: {},\n\t\t\tshadowBias: {},\n\t\t\tshadowRadius: {},\n\t\t\tshadowMapSize: {}\n\t\t} },\n\n\t\tdirectionalShadowMap: { value: [] },\n\t\tdirectionalShadowMatrix: { value: [] },\n\n\t\tspotLights: { value: [], properties: {\n\t\t\tcolor: {},\n\t\t\tposition: {},\n\t\t\tdirection: {},\n\t\t\tdistance: {},\n\t\t\tconeCos: {},\n\t\t\tpenumbraCos: {},\n\t\t\tdecay: {},\n\n\t\t\tshadow: {},\n\t\t\tshadowBias: {},\n\t\t\tshadowRadius: {},\n\t\t\tshadowMapSize: {}\n\t\t} },\n\n\t\tspotShadowMap: { value: [] },\n\t\tspotShadowMatrix: { value: [] },\n\n\t\tpointLights: { value: [], properties: {\n\t\t\tcolor: {},\n\t\t\tposition: {},\n\t\t\tdecay: {},\n\t\t\tdistance: {},\n\n\t\t\tshadow: {},\n\t\t\tshadowBias: {},\n\t\t\tshadowRadius: {},\n\t\t\tshadowMapSize: {},\n\t\t\tshadowCameraNear: {},\n\t\t\tshadowCameraFar: {}\n\t\t} },\n\n\t\tpointShadowMap: { value: [] },\n\t\tpointShadowMatrix: { value: [] },\n\n\t\themisphereLights: { value: [], properties: {\n\t\t\tdirection: {},\n\t\t\tskyColor: {},\n\t\t\tgroundColor: {}\n\t\t} },\n\n\t\t// TODO (abelnation): RectAreaLight BRDF data needs to be moved from example to main src\n\t\trectAreaLights: { value: [], properties: {\n\t\t\tcolor: {},\n\t\t\tposition: {},\n\t\t\twidth: {},\n\t\t\theight: {}\n\t\t} }\n\n\t},\n\n\tpoints: {\n\n\t\tdiffuse: { value: new Color( 0xeeeeee ) },\n\t\topacity: { value: 1.0 },\n\t\tsize: { value: 1.0 },\n\t\tscale: { value: 1.0 },\n\t\tmap: { value: null },\n\t\tuvTransform: { value: new Matrix3() }\n\n\t}\n\n};\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author mrdoob / http://mrdoob.com/\n * @author mikael emtinger / http://gomo.se/\n */\n\nvar ShaderLib = {\n\n\tbasic: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.specularmap,\n\t\t\tUniformsLib.envmap,\n\t\t\tUniformsLib.aomap,\n\t\t\tUniformsLib.lightmap,\n\t\t\tUniformsLib.fog\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshbasic_vert,\n\t\tfragmentShader: ShaderChunk.meshbasic_frag\n\n\t},\n\n\tlambert: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.specularmap,\n\t\t\tUniformsLib.envmap,\n\t\t\tUniformsLib.aomap,\n\t\t\tUniformsLib.lightmap,\n\t\t\tUniformsLib.emissivemap,\n\t\t\tUniformsLib.fog,\n\t\t\tUniformsLib.lights,\n\t\t\t{\n\t\t\t\temissive: { value: new Color( 0x000000 ) }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshlambert_vert,\n\t\tfragmentShader: ShaderChunk.meshlambert_frag\n\n\t},\n\n\tphong: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.specularmap,\n\t\t\tUniformsLib.envmap,\n\t\t\tUniformsLib.aomap,\n\t\t\tUniformsLib.lightmap,\n\t\t\tUniformsLib.emissivemap,\n\t\t\tUniformsLib.bumpmap,\n\t\t\tUniformsLib.normalmap,\n\t\t\tUniformsLib.displacementmap,\n\t\t\tUniformsLib.gradientmap,\n\t\t\tUniformsLib.fog,\n\t\t\tUniformsLib.lights,\n\t\t\t{\n\t\t\t\temissive: { value: new Color( 0x000000 ) },\n\t\t\t\tspecular: { value: new Color( 0x111111 ) },\n\t\t\t\tshininess: { value: 30 }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshphong_vert,\n\t\tfragmentShader: ShaderChunk.meshphong_frag\n\n\t},\n\n\tstandard: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.envmap,\n\t\t\tUniformsLib.aomap,\n\t\t\tUniformsLib.lightmap,\n\t\t\tUniformsLib.emissivemap,\n\t\t\tUniformsLib.bumpmap,\n\t\t\tUniformsLib.normalmap,\n\t\t\tUniformsLib.displacementmap,\n\t\t\tUniformsLib.roughnessmap,\n\t\t\tUniformsLib.metalnessmap,\n\t\t\tUniformsLib.fog,\n\t\t\tUniformsLib.lights,\n\t\t\t{\n\t\t\t\temissive: { value: new Color( 0x000000 ) },\n\t\t\t\troughness: { value: 0.5 },\n\t\t\t\tmetalness: { value: 0.5 },\n\t\t\t\tenvMapIntensity: { value: 1 } // temporary\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshphysical_vert,\n\t\tfragmentShader: ShaderChunk.meshphysical_frag\n\n\t},\n\n\tpoints: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.points,\n\t\t\tUniformsLib.fog\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.points_vert,\n\t\tfragmentShader: ShaderChunk.points_frag\n\n\t},\n\n\tdashed: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.fog,\n\t\t\t{\n\t\t\t\tscale: { value: 1 },\n\t\t\t\tdashSize: { value: 1 },\n\t\t\t\ttotalSize: { value: 2 }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.linedashed_vert,\n\t\tfragmentShader: ShaderChunk.linedashed_frag\n\n\t},\n\n\tdepth: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.displacementmap\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.depth_vert,\n\t\tfragmentShader: ShaderChunk.depth_frag\n\n\t},\n\n\tnormal: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.bumpmap,\n\t\t\tUniformsLib.normalmap,\n\t\t\tUniformsLib.displacementmap,\n\t\t\t{\n\t\t\t\topacity: { value: 1.0 }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.normal_vert,\n\t\tfragmentShader: ShaderChunk.normal_frag\n\n\t},\n\n\t/* -------------------------------------------------------------------------\n\t//\tCube map shader\n\t ------------------------------------------------------------------------- */\n\n\tcube: {\n\n\t\tuniforms: {\n\t\t\ttCube: { value: null },\n\t\t\ttFlip: { value: - 1 },\n\t\t\topacity: { value: 1.0 }\n\t\t},\n\n\t\tvertexShader: ShaderChunk.cube_vert,\n\t\tfragmentShader: ShaderChunk.cube_frag\n\n\t},\n\n\tequirect: {\n\n\t\tuniforms: {\n\t\t\ttEquirect: { value: null },\n\t\t},\n\n\t\tvertexShader: ShaderChunk.equirect_vert,\n\t\tfragmentShader: ShaderChunk.equirect_frag\n\n\t},\n\n\tdistanceRGBA: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.displacementmap,\n\t\t\t{\n\t\t\t\treferencePosition: { value: new Vector3() },\n\t\t\t\tnearDistance: { value: 1 },\n\t\t\t\tfarDistance: { value: 1000 }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.distanceRGBA_vert,\n\t\tfragmentShader: ShaderChunk.distanceRGBA_frag\n\n\t},\n\n\tshadow: {\n\n\t\tuniforms: UniformsUtils.merge( [\n\t\t\tUniformsLib.lights,\n\t\t\tUniformsLib.fog,\n\t\t\t{\n\t\t\t\tcolor: { value: new Color( 0x00000 ) },\n\t\t\t\topacity: { value: 1.0 }\n\t\t\t},\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.shadow_vert,\n\t\tfragmentShader: ShaderChunk.shadow_frag\n\n\t}\n\n};\n\nShaderLib.physical = {\n\n\tuniforms: UniformsUtils.merge( [\n\t\tShaderLib.standard.uniforms,\n\t\t{\n\t\t\tclearCoat: { value: 0 },\n\t\t\tclearCoatRoughness: { value: 0 }\n\t\t}\n\t] ),\n\n\tvertexShader: ShaderChunk.meshphysical_vert,\n\tfragmentShader: ShaderChunk.meshphysical_frag\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLAttributes( gl ) {\n\n\tvar buffers = new WeakMap();\n\n\tfunction createBuffer( attribute, bufferType ) {\n\n\t\tvar array = attribute.array;\n\t\tvar usage = attribute.dynamic ? gl.DYNAMIC_DRAW : gl.STATIC_DRAW;\n\n\t\tvar buffer = gl.createBuffer();\n\n\t\tgl.bindBuffer( bufferType, buffer );\n\t\tgl.bufferData( bufferType, array, usage );\n\n\t\tattribute.onUploadCallback();\n\n\t\tvar type = gl.FLOAT;\n\n\t\tif ( array instanceof Float32Array ) {\n\n\t\t\ttype = gl.FLOAT;\n\n\t\t} else if ( array instanceof Float64Array ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLAttributes: Unsupported data buffer format: Float64Array.' );\n\n\t\t} else if ( array instanceof Uint16Array ) {\n\n\t\t\ttype = gl.UNSIGNED_SHORT;\n\n\t\t} else if ( array instanceof Int16Array ) {\n\n\t\t\ttype = gl.SHORT;\n\n\t\t} else if ( array instanceof Uint32Array ) {\n\n\t\t\ttype = gl.UNSIGNED_INT;\n\n\t\t} else if ( array instanceof Int32Array ) {\n\n\t\t\ttype = gl.INT;\n\n\t\t} else if ( array instanceof Int8Array ) {\n\n\t\t\ttype = gl.BYTE;\n\n\t\t} else if ( array instanceof Uint8Array ) {\n\n\t\t\ttype = gl.UNSIGNED_BYTE;\n\n\t\t}\n\n\t\treturn {\n\t\t\tbuffer: buffer,\n\t\t\ttype: type,\n\t\t\tbytesPerElement: array.BYTES_PER_ELEMENT,\n\t\t\tversion: attribute.version\n\t\t};\n\n\t}\n\n\tfunction updateBuffer( buffer, attribute, bufferType ) {\n\n\t\tvar array = attribute.array;\n\t\tvar updateRange = attribute.updateRange;\n\n\t\tgl.bindBuffer( bufferType, buffer );\n\n\t\tif ( attribute.dynamic === false ) {\n\n\t\t\tgl.bufferData( bufferType, array, gl.STATIC_DRAW );\n\n\t\t} else if ( updateRange.count === - 1 ) {\n\n\t\t\t// Not using update ranges\n\n\t\t\tgl.bufferSubData( bufferType, 0, array );\n\n\t\t} else if ( updateRange.count === 0 ) {\n\n\t\t\tconsole.error( 'THREE.WebGLObjects.updateBuffer: dynamic THREE.BufferAttribute marked as needsUpdate but updateRange.count is 0, ensure you are using set methods or updating manually.' );\n\n\t\t} else {\n\n\t\t\tgl.bufferSubData( bufferType, updateRange.offset * array.BYTES_PER_ELEMENT,\n\t\t\t\tarray.subarray( updateRange.offset, updateRange.offset + updateRange.count ) );\n\n\t\t\tupdateRange.count = - 1; // reset range\n\n\t\t}\n\n\t}\n\n\t//\n\n\tfunction get( attribute ) {\n\n\t\tif ( attribute.isInterleavedBufferAttribute ) attribute = attribute.data;\n\n\t\treturn buffers.get( attribute );\n\n\t}\n\n\tfunction remove( attribute ) {\n\n\t\tif ( attribute.isInterleavedBufferAttribute ) attribute = attribute.data;\n\n\t\tvar data = buffers.get( attribute );\n\n\t\tif ( data ) {\n\n\t\t\tgl.deleteBuffer( data.buffer );\n\n\t\t\tbuffers.delete( attribute );\n\n\t\t}\n\n\t}\n\n\tfunction update( attribute, bufferType ) {\n\n\t\tif ( attribute.isInterleavedBufferAttribute ) attribute = attribute.data;\n\n\t\tvar data = buffers.get( attribute );\n\n\t\tif ( data === undefined ) {\n\n\t\t\tbuffers.set( attribute, createBuffer( attribute, bufferType ) );\n\n\t\t} else if ( data.version < attribute.version ) {\n\n\t\t\tupdateBuffer( data.buffer, attribute, bufferType );\n\n\t\t\tdata.version = attribute.version;\n\n\t\t}\n\n\t}\n\n\treturn {\n\n\t\tget: get,\n\t\tremove: remove,\n\t\tupdate: update\n\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author WestLangley / http://github.com/WestLangley\n * @author bhouston / http://clara.io\n */\n\nfunction Euler( x, y, z, order ) {\n\n\tthis._x = x || 0;\n\tthis._y = y || 0;\n\tthis._z = z || 0;\n\tthis._order = order || Euler.DefaultOrder;\n\n}\n\nEuler.RotationOrders = [ 'XYZ', 'YZX', 'ZXY', 'XZY', 'YXZ', 'ZYX' ];\n\nEuler.DefaultOrder = 'XYZ';\n\nObject.defineProperties( Euler.prototype, {\n\n\tx: {\n\n\t\tget: function () {\n\n\t\t\treturn this._x;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis._x = value;\n\t\t\tthis.onChangeCallback();\n\n\t\t}\n\n\t},\n\n\ty: {\n\n\t\tget: function () {\n\n\t\t\treturn this._y;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis._y = value;\n\t\t\tthis.onChangeCallback();\n\n\t\t}\n\n\t},\n\n\tz: {\n\n\t\tget: function () {\n\n\t\t\treturn this._z;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis._z = value;\n\t\t\tthis.onChangeCallback();\n\n\t\t}\n\n\t},\n\n\torder: {\n\n\t\tget: function () {\n\n\t\t\treturn this._order;\n\n\t\t},\n\n\t\tset: function ( value ) {\n\n\t\t\tthis._order = value;\n\t\t\tthis.onChangeCallback();\n\n\t\t}\n\n\t}\n\n} );\n\nObject.assign( Euler.prototype, {\n\n\tisEuler: true,\n\n\tset: function ( x, y, z, order ) {\n\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._order = order || this._order;\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this._x, this._y, this._z, this._order );\n\n\t},\n\n\tcopy: function ( euler ) {\n\n\t\tthis._x = euler._x;\n\t\tthis._y = euler._y;\n\t\tthis._z = euler._z;\n\t\tthis._order = euler._order;\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tsetFromRotationMatrix: function ( m, order, update ) {\n\n\t\tvar clamp = _Math.clamp;\n\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\n\t\tvar te = m.elements;\n\t\tvar m11 = te[ 0 ], m12 = te[ 4 ], m13 = te[ 8 ];\n\t\tvar m21 = te[ 1 ], m22 = te[ 5 ], m23 = te[ 9 ];\n\t\tvar m31 = te[ 2 ], m32 = te[ 6 ], m33 = te[ 10 ];\n\n\t\torder = order || this._order;\n\n\t\tif ( order === 'XYZ' ) {\n\n\t\t\tthis._y = Math.asin( clamp( m13, - 1, 1 ) );\n\n\t\t\tif ( Math.abs( m13 ) < 0.99999 ) {\n\n\t\t\t\tthis._x = Math.atan2( - m23, m33 );\n\t\t\t\tthis._z = Math.atan2( - m12, m11 );\n\n\t\t\t} else {\n\n\t\t\t\tthis._x = Math.atan2( m32, m22 );\n\t\t\t\tthis._z = 0;\n\n\t\t\t}\n\n\t\t} else if ( order === 'YXZ' ) {\n\n\t\t\tthis._x = Math.asin( - clamp( m23, - 1, 1 ) );\n\n\t\t\tif ( Math.abs( m23 ) < 0.99999 ) {\n\n\t\t\t\tthis._y = Math.atan2( m13, m33 );\n\t\t\t\tthis._z = Math.atan2( m21, m22 );\n\n\t\t\t} else {\n\n\t\t\t\tthis._y = Math.atan2( - m31, m11 );\n\t\t\t\tthis._z = 0;\n\n\t\t\t}\n\n\t\t} else if ( order === 'ZXY' ) {\n\n\t\t\tthis._x = Math.asin( clamp( m32, - 1, 1 ) );\n\n\t\t\tif ( Math.abs( m32 ) < 0.99999 ) {\n\n\t\t\t\tthis._y = Math.atan2( - m31, m33 );\n\t\t\t\tthis._z = Math.atan2( - m12, m22 );\n\n\t\t\t} else {\n\n\t\t\t\tthis._y = 0;\n\t\t\t\tthis._z = Math.atan2( m21, m11 );\n\n\t\t\t}\n\n\t\t} else if ( order === 'ZYX' ) {\n\n\t\t\tthis._y = Math.asin( - clamp( m31, - 1, 1 ) );\n\n\t\t\tif ( Math.abs( m31 ) < 0.99999 ) {\n\n\t\t\t\tthis._x = Math.atan2( m32, m33 );\n\t\t\t\tthis._z = Math.atan2( m21, m11 );\n\n\t\t\t} else {\n\n\t\t\t\tthis._x = 0;\n\t\t\t\tthis._z = Math.atan2( - m12, m22 );\n\n\t\t\t}\n\n\t\t} else if ( order === 'YZX' ) {\n\n\t\t\tthis._z = Math.asin( clamp( m21, - 1, 1 ) );\n\n\t\t\tif ( Math.abs( m21 ) < 0.99999 ) {\n\n\t\t\t\tthis._x = Math.atan2( - m23, m22 );\n\t\t\t\tthis._y = Math.atan2( - m31, m11 );\n\n\t\t\t} else {\n\n\t\t\t\tthis._x = 0;\n\t\t\t\tthis._y = Math.atan2( m13, m33 );\n\n\t\t\t}\n\n\t\t} else if ( order === 'XZY' ) {\n\n\t\t\tthis._z = Math.asin( - clamp( m12, - 1, 1 ) );\n\n\t\t\tif ( Math.abs( m12 ) < 0.99999 ) {\n\n\t\t\t\tthis._x = Math.atan2( m32, m22 );\n\t\t\t\tthis._y = Math.atan2( m13, m11 );\n\n\t\t\t} else {\n\n\t\t\t\tthis._x = Math.atan2( - m23, m33 );\n\t\t\t\tthis._y = 0;\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.Euler: .setFromRotationMatrix() given unsupported order: ' + order );\n\n\t\t}\n\n\t\tthis._order = order;\n\n\t\tif ( update !== false ) this.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\tsetFromQuaternion: function () {\n\n\t\tvar matrix = new Matrix4();\n\n\t\treturn function setFromQuaternion( q, order, update ) {\n\n\t\t\tmatrix.makeRotationFromQuaternion( q );\n\n\t\t\treturn this.setFromRotationMatrix( matrix, order, update );\n\n\t\t};\n\n\t}(),\n\n\tsetFromVector3: function ( v, order ) {\n\n\t\treturn this.set( v.x, v.y, v.z, order || this._order );\n\n\t},\n\n\treorder: function () {\n\n\t\t// WARNING: this discards revolution information -bhouston\n\n\t\tvar q = new Quaternion();\n\n\t\treturn function reorder( newOrder ) {\n\n\t\t\tq.setFromEuler( this );\n\n\t\t\treturn this.setFromQuaternion( q, newOrder );\n\n\t\t};\n\n\t}(),\n\n\tequals: function ( euler ) {\n\n\t\treturn ( euler._x === this._x ) && ( euler._y === this._y ) && ( euler._z === this._z ) && ( euler._order === this._order );\n\n\t},\n\n\tfromArray: function ( array ) {\n\n\t\tthis._x = array[ 0 ];\n\t\tthis._y = array[ 1 ];\n\t\tthis._z = array[ 2 ];\n\t\tif ( array[ 3 ] !== undefined ) this._order = array[ 3 ];\n\n\t\tthis.onChangeCallback();\n\n\t\treturn this;\n\n\t},\n\n\ttoArray: function ( array, offset ) {\n\n\t\tif ( array === undefined ) array = [];\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tarray[ offset ] = this._x;\n\t\tarray[ offset + 1 ] = this._y;\n\t\tarray[ offset + 2 ] = this._z;\n\t\tarray[ offset + 3 ] = this._order;\n\n\t\treturn array;\n\n\t},\n\n\ttoVector3: function ( optionalResult ) {\n\n\t\tif ( optionalResult ) {\n\n\t\t\treturn optionalResult.set( this._x, this._y, this._z );\n\n\t\t} else {\n\n\t\t\treturn new Vector3( this._x, this._y, this._z );\n\n\t\t}\n\n\t},\n\n\tonChange: function ( callback ) {\n\n\t\tthis.onChangeCallback = callback;\n\n\t\treturn this;\n\n\t},\n\n\tonChangeCallback: function () {}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction Layers() {\n\n\tthis.mask = 1 | 0;\n\n}\n\nObject.assign( Layers.prototype, {\n\n\tset: function ( channel ) {\n\n\t\tthis.mask = 1 << channel | 0;\n\n\t},\n\n\tenable: function ( channel ) {\n\n\t\tthis.mask |= 1 << channel | 0;\n\n\t},\n\n\ttoggle: function ( channel ) {\n\n\t\tthis.mask ^= 1 << channel | 0;\n\n\t},\n\n\tdisable: function ( channel ) {\n\n\t\tthis.mask &= ~ ( 1 << channel | 0 );\n\n\t},\n\n\ttest: function ( layers ) {\n\n\t\treturn ( this.mask & layers.mask ) !== 0;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author mikael emtinger / http://gomo.se/\n * @author alteredq / http://alteredqualia.com/\n * @author WestLangley / http://github.com/WestLangley\n * @author elephantatwork / www.elephantatwork.ch\n */\n\nvar object3DId = 0;\n\nfunction Object3D() {\n\n\tObject.defineProperty( this, 'id', { value: object3DId ++ } );\n\n\tthis.uuid = _Math.generateUUID();\n\n\tthis.name = '';\n\tthis.type = 'Object3D';\n\n\tthis.parent = null;\n\tthis.children = [];\n\n\tthis.up = Object3D.DefaultUp.clone();\n\n\tvar position = new Vector3();\n\tvar rotation = new Euler();\n\tvar quaternion = new Quaternion();\n\tvar scale = new Vector3( 1, 1, 1 );\n\n\tfunction onRotationChange() {\n\n\t\tquaternion.setFromEuler( rotation, false );\n\n\t}\n\n\tfunction onQuaternionChange() {\n\n\t\trotation.setFromQuaternion( quaternion, undefined, false );\n\n\t}\n\n\trotation.onChange( onRotationChange );\n\tquaternion.onChange( onQuaternionChange );\n\n\tObject.defineProperties( this, {\n\t\tposition: {\n\t\t\tenumerable: true,\n\t\t\tvalue: position\n\t\t},\n\t\trotation: {\n\t\t\tenumerable: true,\n\t\t\tvalue: rotation\n\t\t},\n\t\tquaternion: {\n\t\t\tenumerable: true,\n\t\t\tvalue: quaternion\n\t\t},\n\t\tscale: {\n\t\t\tenumerable: true,\n\t\t\tvalue: scale\n\t\t},\n\t\tmodelViewMatrix: {\n\t\t\tvalue: new Matrix4()\n\t\t},\n\t\tnormalMatrix: {\n\t\t\tvalue: new Matrix3()\n\t\t}\n\t} );\n\n\tthis.matrix = new Matrix4();\n\tthis.matrixWorld = new Matrix4();\n\n\tthis.matrixAutoUpdate = Object3D.DefaultMatrixAutoUpdate;\n\tthis.matrixWorldNeedsUpdate = false;\n\n\tthis.layers = new Layers();\n\tthis.visible = true;\n\n\tthis.castShadow = false;\n\tthis.receiveShadow = false;\n\n\tthis.frustumCulled = true;\n\tthis.renderOrder = 0;\n\n\tthis.userData = {};\n\n}\n\nObject3D.DefaultUp = new Vector3( 0, 1, 0 );\nObject3D.DefaultMatrixAutoUpdate = true;\n\nObject3D.prototype = Object.assign( Object.create( EventDispatcher.prototype ), {\n\n\tconstructor: Object3D,\n\n\tisObject3D: true,\n\n\tonBeforeRender: function () {},\n\tonAfterRender: function () {},\n\n\tapplyMatrix: function ( matrix ) {\n\n\t\tthis.matrix.multiplyMatrices( matrix, this.matrix );\n\n\t\tthis.matrix.decompose( this.position, this.quaternion, this.scale );\n\n\t},\n\n\tapplyQuaternion: function ( q ) {\n\n\t\tthis.quaternion.premultiply( q );\n\n\t\treturn this;\n\n\t},\n\n\tsetRotationFromAxisAngle: function ( axis, angle ) {\n\n\t\t// assumes axis is normalized\n\n\t\tthis.quaternion.setFromAxisAngle( axis, angle );\n\n\t},\n\n\tsetRotationFromEuler: function ( euler ) {\n\n\t\tthis.quaternion.setFromEuler( euler, true );\n\n\t},\n\n\tsetRotationFromMatrix: function ( m ) {\n\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\n\t\tthis.quaternion.setFromRotationMatrix( m );\n\n\t},\n\n\tsetRotationFromQuaternion: function ( q ) {\n\n\t\t// assumes q is normalized\n\n\t\tthis.quaternion.copy( q );\n\n\t},\n\n\trotateOnAxis: function () {\n\n\t\t// rotate object on axis in object space\n\t\t// axis is assumed to be normalized\n\n\t\tvar q1 = new Quaternion();\n\n\t\treturn function rotateOnAxis( axis, angle ) {\n\n\t\t\tq1.setFromAxisAngle( axis, angle );\n\n\t\t\tthis.quaternion.multiply( q1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\trotateOnWorldAxis: function () {\n\n\t\t// rotate object on axis in world space\n\t\t// axis is assumed to be normalized\n\t\t// method assumes no rotated parent\n\n\t\tvar q1 = new Quaternion();\n\n\t\treturn function rotateOnWorldAxis( axis, angle ) {\n\n\t\t\tq1.setFromAxisAngle( axis, angle );\n\n\t\t\tthis.quaternion.premultiply( q1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\trotateX: function () {\n\n\t\tvar v1 = new Vector3( 1, 0, 0 );\n\n\t\treturn function rotateX( angle ) {\n\n\t\t\treturn this.rotateOnAxis( v1, angle );\n\n\t\t};\n\n\t}(),\n\n\trotateY: function () {\n\n\t\tvar v1 = new Vector3( 0, 1, 0 );\n\n\t\treturn function rotateY( angle ) {\n\n\t\t\treturn this.rotateOnAxis( v1, angle );\n\n\t\t};\n\n\t}(),\n\n\trotateZ: function () {\n\n\t\tvar v1 = new Vector3( 0, 0, 1 );\n\n\t\treturn function rotateZ( angle ) {\n\n\t\t\treturn this.rotateOnAxis( v1, angle );\n\n\t\t};\n\n\t}(),\n\n\ttranslateOnAxis: function () {\n\n\t\t// translate object by distance along axis in object space\n\t\t// axis is assumed to be normalized\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function translateOnAxis( axis, distance ) {\n\n\t\t\tv1.copy( axis ).applyQuaternion( this.quaternion );\n\n\t\t\tthis.position.add( v1.multiplyScalar( distance ) );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\ttranslateX: function () {\n\n\t\tvar v1 = new Vector3( 1, 0, 0 );\n\n\t\treturn function translateX( distance ) {\n\n\t\t\treturn this.translateOnAxis( v1, distance );\n\n\t\t};\n\n\t}(),\n\n\ttranslateY: function () {\n\n\t\tvar v1 = new Vector3( 0, 1, 0 );\n\n\t\treturn function translateY( distance ) {\n\n\t\t\treturn this.translateOnAxis( v1, distance );\n\n\t\t};\n\n\t}(),\n\n\ttranslateZ: function () {\n\n\t\tvar v1 = new Vector3( 0, 0, 1 );\n\n\t\treturn function translateZ( distance ) {\n\n\t\t\treturn this.translateOnAxis( v1, distance );\n\n\t\t};\n\n\t}(),\n\n\tlocalToWorld: function ( vector ) {\n\n\t\treturn vector.applyMatrix4( this.matrixWorld );\n\n\t},\n\n\tworldToLocal: function () {\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function worldToLocal( vector ) {\n\n\t\t\treturn vector.applyMatrix4( m1.getInverse( this.matrixWorld ) );\n\n\t\t};\n\n\t}(),\n\n\tlookAt: function () {\n\n\t\t// This method does not support objects with rotated and/or translated parent(s)\n\n\t\tvar m1 = new Matrix4();\n\t\tvar vector = new Vector3();\n\n\t\treturn function lookAt( x, y, z ) {\n\n\t\t\tif ( x.isVector3 ) {\n\n\t\t\t\tvector.copy( x );\n\n\t\t\t} else {\n\n\t\t\t\tvector.set( x, y, z );\n\n\t\t\t}\n\n\t\t\tif ( this.isCamera ) {\n\n\t\t\t\tm1.lookAt( this.position, vector, this.up );\n\n\t\t\t} else {\n\n\t\t\t\tm1.lookAt( vector, this.position, this.up );\n\n\t\t\t}\n\n\t\t\tthis.quaternion.setFromRotationMatrix( m1 );\n\n\t\t};\n\n\t}(),\n\n\tadd: function ( object ) {\n\n\t\tif ( arguments.length > 1 ) {\n\n\t\t\tfor ( var i = 0; i < arguments.length; i ++ ) {\n\n\t\t\t\tthis.add( arguments[ i ] );\n\n\t\t\t}\n\n\t\t\treturn this;\n\n\t\t}\n\n\t\tif ( object === this ) {\n\n\t\t\tconsole.error( \"THREE.Object3D.add: object can't be added as a child of itself.\", object );\n\t\t\treturn this;\n\n\t\t}\n\n\t\tif ( ( object && object.isObject3D ) ) {\n\n\t\t\tif ( object.parent !== null ) {\n\n\t\t\t\tobject.parent.remove( object );\n\n\t\t\t}\n\n\t\t\tobject.parent = this;\n\t\t\tobject.dispatchEvent( { type: 'added' } );\n\n\t\t\tthis.children.push( object );\n\n\t\t} else {\n\n\t\t\tconsole.error( \"THREE.Object3D.add: object not an instance of THREE.Object3D.\", object );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tremove: function ( object ) {\n\n\t\tif ( arguments.length > 1 ) {\n\n\t\t\tfor ( var i = 0; i < arguments.length; i ++ ) {\n\n\t\t\t\tthis.remove( arguments[ i ] );\n\n\t\t\t}\n\n\t\t\treturn this;\n\n\t\t}\n\n\t\tvar index = this.children.indexOf( object );\n\n\t\tif ( index !== - 1 ) {\n\n\t\t\tobject.parent = null;\n\n\t\t\tobject.dispatchEvent( { type: 'removed' } );\n\n\t\t\tthis.children.splice( index, 1 );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tgetObjectById: function ( id ) {\n\n\t\treturn this.getObjectByProperty( 'id', id );\n\n\t},\n\n\tgetObjectByName: function ( name ) {\n\n\t\treturn this.getObjectByProperty( 'name', name );\n\n\t},\n\n\tgetObjectByProperty: function ( name, value ) {\n\n\t\tif ( this[ name ] === value ) return this;\n\n\t\tfor ( var i = 0, l = this.children.length; i < l; i ++ ) {\n\n\t\t\tvar child = this.children[ i ];\n\t\t\tvar object = child.getObjectByProperty( name, value );\n\n\t\t\tif ( object !== undefined ) {\n\n\t\t\t\treturn object;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn undefined;\n\n\t},\n\n\tgetWorldPosition: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Object3D: .getWorldPosition() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\tthis.updateMatrixWorld( true );\n\n\t\treturn target.setFromMatrixPosition( this.matrixWorld );\n\n\t},\n\n\tgetWorldQuaternion: function () {\n\n\t\tvar position = new Vector3();\n\t\tvar scale = new Vector3();\n\n\t\treturn function getWorldQuaternion( target ) {\n\n\t\t\tif ( target === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Object3D: .getWorldQuaternion() target is now required' );\n\t\t\t\ttarget = new Quaternion();\n\n\t\t\t}\n\n\t\t\tthis.updateMatrixWorld( true );\n\n\t\t\tthis.matrixWorld.decompose( position, target, scale );\n\n\t\t\treturn target;\n\n\t\t};\n\n\t}(),\n\n\tgetWorldScale: function () {\n\n\t\tvar position = new Vector3();\n\t\tvar quaternion = new Quaternion();\n\n\t\treturn function getWorldScale( target ) {\n\n\t\t\tif ( target === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Object3D: .getWorldScale() target is now required' );\n\t\t\t\ttarget = new Vector3();\n\n\t\t\t}\n\n\t\t\tthis.updateMatrixWorld( true );\n\n\t\t\tthis.matrixWorld.decompose( position, quaternion, target );\n\n\t\t\treturn target;\n\n\t\t};\n\n\t}(),\n\n\tgetWorldDirection: function () {\n\n\t\tvar quaternion = new Quaternion();\n\n\t\treturn function getWorldDirection( target ) {\n\n\t\t\tif ( target === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Object3D: .getWorldDirection() target is now required' );\n\t\t\t\ttarget = new Vector3();\n\n\t\t\t}\n\n\t\t\tthis.getWorldQuaternion( quaternion );\n\n\t\t\treturn target.set( 0, 0, 1 ).applyQuaternion( quaternion );\n\n\t\t};\n\n\t}(),\n\n\traycast: function () {},\n\n\ttraverse: function ( callback ) {\n\n\t\tcallback( this );\n\n\t\tvar children = this.children;\n\n\t\tfor ( var i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tchildren[ i ].traverse( callback );\n\n\t\t}\n\n\t},\n\n\ttraverseVisible: function ( callback ) {\n\n\t\tif ( this.visible === false ) return;\n\n\t\tcallback( this );\n\n\t\tvar children = this.children;\n\n\t\tfor ( var i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tchildren[ i ].traverseVisible( callback );\n\n\t\t}\n\n\t},\n\n\ttraverseAncestors: function ( callback ) {\n\n\t\tvar parent = this.parent;\n\n\t\tif ( parent !== null ) {\n\n\t\t\tcallback( parent );\n\n\t\t\tparent.traverseAncestors( callback );\n\n\t\t}\n\n\t},\n\n\tupdateMatrix: function () {\n\n\t\tthis.matrix.compose( this.position, this.quaternion, this.scale );\n\n\t\tthis.matrixWorldNeedsUpdate = true;\n\n\t},\n\n\tupdateMatrixWorld: function ( force ) {\n\n\t\tif ( this.matrixAutoUpdate ) this.updateMatrix();\n\n\t\tif ( this.matrixWorldNeedsUpdate || force ) {\n\n\t\t\tif ( this.parent === null ) {\n\n\t\t\t\tthis.matrixWorld.copy( this.matrix );\n\n\t\t\t} else {\n\n\t\t\t\tthis.matrixWorld.multiplyMatrices( this.parent.matrixWorld, this.matrix );\n\n\t\t\t}\n\n\t\t\tthis.matrixWorldNeedsUpdate = false;\n\n\t\t\tforce = true;\n\n\t\t}\n\n\t\t// update children\n\n\t\tvar children = this.children;\n\n\t\tfor ( var i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tchildren[ i ].updateMatrixWorld( force );\n\n\t\t}\n\n\t},\n\n\ttoJSON: function ( meta ) {\n\n\t\t// meta is a string when called from JSON.stringify\n\t\tvar isRootObject = ( meta === undefined || typeof meta === 'string' );\n\n\t\tvar output = {};\n\n\t\t// meta is a hash used to collect geometries, materials.\n\t\t// not providing it implies that this is the root object\n\t\t// being serialized.\n\t\tif ( isRootObject ) {\n\n\t\t\t// initialize meta obj\n\t\t\tmeta = {\n\t\t\t\tgeometries: {},\n\t\t\t\tmaterials: {},\n\t\t\t\ttextures: {},\n\t\t\t\timages: {},\n\t\t\t\tshapes: {}\n\t\t\t};\n\n\t\t\toutput.metadata = {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Object',\n\t\t\t\tgenerator: 'Object3D.toJSON'\n\t\t\t};\n\n\t\t}\n\n\t\t// standard Object3D serialization\n\n\t\tvar object = {};\n\n\t\tobject.uuid = this.uuid;\n\t\tobject.type = this.type;\n\n\t\tif ( this.name !== '' ) object.name = this.name;\n\t\tif ( this.castShadow === true ) object.castShadow = true;\n\t\tif ( this.receiveShadow === true ) object.receiveShadow = true;\n\t\tif ( this.visible === false ) object.visible = false;\n\t\tif ( this.frustumCulled === false ) object.frustumCulled = false;\n\t\tif ( this.renderOrder !== 0 ) object.renderOrder = this.renderOrder;\n\t\tif ( JSON.stringify( this.userData ) !== '{}' ) object.userData = this.userData;\n\n\t\tobject.matrix = this.matrix.toArray();\n\n\t\tif ( this.matrixAutoUpdate === false ) object.matrixAutoUpdate = false;\n\n\t\t//\n\n\t\tfunction serialize( library, element ) {\n\n\t\t\tif ( library[ element.uuid ] === undefined ) {\n\n\t\t\t\tlibrary[ element.uuid ] = element.toJSON( meta );\n\n\t\t\t}\n\n\t\t\treturn element.uuid;\n\n\t\t}\n\n\t\tif ( this.geometry !== undefined ) {\n\n\t\t\tobject.geometry = serialize( meta.geometries, this.geometry );\n\n\t\t\tvar parameters = this.geometry.parameters;\n\n\t\t\tif ( parameters !== undefined && parameters.shapes !== undefined ) {\n\n\t\t\t\tvar shapes = parameters.shapes;\n\n\t\t\t\tif ( Array.isArray( shapes ) ) {\n\n\t\t\t\t\tfor ( var i = 0, l = shapes.length; i < l; i ++ ) {\n\n\t\t\t\t\t\tvar shape = shapes[ i ];\n\n\t\t\t\t\t\tserialize( meta.shapes, shape );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tserialize( meta.shapes, shapes );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.material !== undefined ) {\n\n\t\t\tif ( Array.isArray( this.material ) ) {\n\n\t\t\t\tvar uuids = [];\n\n\t\t\t\tfor ( var i = 0, l = this.material.length; i < l; i ++ ) {\n\n\t\t\t\t\tuuids.push( serialize( meta.materials, this.material[ i ] ) );\n\n\t\t\t\t}\n\n\t\t\t\tobject.material = uuids;\n\n\t\t\t} else {\n\n\t\t\t\tobject.material = serialize( meta.materials, this.material );\n\n\t\t\t}\n\n\t\t}\n\n\t\t//\n\n\t\tif ( this.children.length > 0 ) {\n\n\t\t\tobject.children = [];\n\n\t\t\tfor ( var i = 0; i < this.children.length; i ++ ) {\n\n\t\t\t\tobject.children.push( this.children[ i ].toJSON( meta ).object );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( isRootObject ) {\n\n\t\t\tvar geometries = extractFromCache( meta.geometries );\n\t\t\tvar materials = extractFromCache( meta.materials );\n\t\t\tvar textures = extractFromCache( meta.textures );\n\t\t\tvar images = extractFromCache( meta.images );\n\t\t\tvar shapes = extractFromCache( meta.shapes );\n\n\t\t\tif ( geometries.length > 0 ) output.geometries = geometries;\n\t\t\tif ( materials.length > 0 ) output.materials = materials;\n\t\t\tif ( textures.length > 0 ) output.textures = textures;\n\t\t\tif ( images.length > 0 ) output.images = images;\n\t\t\tif ( shapes.length > 0 ) output.shapes = shapes;\n\n\t\t}\n\n\t\toutput.object = object;\n\n\t\treturn output;\n\n\t\t// extract data from the cache hash\n\t\t// remove metadata on each item\n\t\t// and return as array\n\t\tfunction extractFromCache( cache ) {\n\n\t\t\tvar values = [];\n\t\t\tfor ( var key in cache ) {\n\n\t\t\t\tvar data = cache[ key ];\n\t\t\t\tdelete data.metadata;\n\t\t\t\tvalues.push( data );\n\n\t\t\t}\n\t\t\treturn values;\n\n\t\t}\n\n\t},\n\n\tclone: function ( recursive ) {\n\n\t\treturn new this.constructor().copy( this, recursive );\n\n\t},\n\n\tcopy: function ( source, recursive ) {\n\n\t\tif ( recursive === undefined ) recursive = true;\n\n\t\tthis.name = source.name;\n\n\t\tthis.up.copy( source.up );\n\n\t\tthis.position.copy( source.position );\n\t\tthis.quaternion.copy( source.quaternion );\n\t\tthis.scale.copy( source.scale );\n\n\t\tthis.matrix.copy( source.matrix );\n\t\tthis.matrixWorld.copy( source.matrixWorld );\n\n\t\tthis.matrixAutoUpdate = source.matrixAutoUpdate;\n\t\tthis.matrixWorldNeedsUpdate = source.matrixWorldNeedsUpdate;\n\n\t\tthis.layers.mask = source.layers.mask;\n\t\tthis.visible = source.visible;\n\n\t\tthis.castShadow = source.castShadow;\n\t\tthis.receiveShadow = source.receiveShadow;\n\n\t\tthis.frustumCulled = source.frustumCulled;\n\t\tthis.renderOrder = source.renderOrder;\n\n\t\tthis.userData = JSON.parse( JSON.stringify( source.userData ) );\n\n\t\tif ( recursive === true ) {\n\n\t\t\tfor ( var i = 0; i < source.children.length; i ++ ) {\n\n\t\t\t\tvar child = source.children[ i ];\n\t\t\t\tthis.add( child.clone() );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author mikael emtinger / http://gomo.se/\n * @author WestLangley / http://github.com/WestLangley\n*/\n\nfunction Camera() {\n\n\tObject3D.call( this );\n\n\tthis.type = 'Camera';\n\n\tthis.matrixWorldInverse = new Matrix4();\n\tthis.projectionMatrix = new Matrix4();\n\n}\n\nCamera.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Camera,\n\n\tisCamera: true,\n\n\tcopy: function ( source, recursive ) {\n\n\t\tObject3D.prototype.copy.call( this, source, recursive );\n\n\t\tthis.matrixWorldInverse.copy( source.matrixWorldInverse );\n\t\tthis.projectionMatrix.copy( source.projectionMatrix );\n\n\t\treturn this;\n\n\t},\n\n\tgetWorldDirection: function () {\n\n\t\tvar quaternion = new Quaternion();\n\n\t\treturn function getWorldDirection( target ) {\n\n\t\t\tif ( target === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Camera: .getWorldDirection() target is now required' );\n\t\t\t\ttarget = new Vector3();\n\n\t\t\t}\n\n\t\t\tthis.getWorldQuaternion( quaternion );\n\n\t\t\treturn target.set( 0, 0, - 1 ).applyQuaternion( quaternion );\n\n\t\t};\n\n\t}(),\n\n\tupdateMatrixWorld: function ( force ) {\n\n\t\tObject3D.prototype.updateMatrixWorld.call( this, force );\n\n\t\tthis.matrixWorldInverse.getInverse( this.matrixWorld );\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n} );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author arose / http://github.com/arose\n */\n\nfunction OrthographicCamera( left, right, top, bottom, near, far ) {\n\n\tCamera.call( this );\n\n\tthis.type = 'OrthographicCamera';\n\n\tthis.zoom = 1;\n\tthis.view = null;\n\n\tthis.left = left;\n\tthis.right = right;\n\tthis.top = top;\n\tthis.bottom = bottom;\n\n\tthis.near = ( near !== undefined ) ? near : 0.1;\n\tthis.far = ( far !== undefined ) ? far : 2000;\n\n\tthis.updateProjectionMatrix();\n\n}\n\nOrthographicCamera.prototype = Object.assign( Object.create( Camera.prototype ), {\n\n\tconstructor: OrthographicCamera,\n\n\tisOrthographicCamera: true,\n\n\tcopy: function ( source, recursive ) {\n\n\t\tCamera.prototype.copy.call( this, source, recursive );\n\n\t\tthis.left = source.left;\n\t\tthis.right = source.right;\n\t\tthis.top = source.top;\n\t\tthis.bottom = source.bottom;\n\t\tthis.near = source.near;\n\t\tthis.far = source.far;\n\n\t\tthis.zoom = source.zoom;\n\t\tthis.view = source.view === null ? null : Object.assign( {}, source.view );\n\n\t\treturn this;\n\n\t},\n\n\tsetViewOffset: function ( fullWidth, fullHeight, x, y, width, height ) {\n\n\t\tif ( this.view === null ) {\n\n\t\t\tthis.view = {\n\t\t\t\tenabled: true,\n\t\t\t\tfullWidth: 1,\n\t\t\t\tfullHeight: 1,\n\t\t\t\toffsetX: 0,\n\t\t\t\toffsetY: 0,\n\t\t\t\twidth: 1,\n\t\t\t\theight: 1\n\t\t\t};\n\n\t\t}\n\n\t\tthis.view.enabled = true;\n\t\tthis.view.fullWidth = fullWidth;\n\t\tthis.view.fullHeight = fullHeight;\n\t\tthis.view.offsetX = x;\n\t\tthis.view.offsetY = y;\n\t\tthis.view.width = width;\n\t\tthis.view.height = height;\n\n\t\tthis.updateProjectionMatrix();\n\n\t},\n\n\tclearViewOffset: function () {\n\n\t\tif ( this.view !== null ) {\n\n\t\t\tthis.view.enabled = false;\n\n\t\t}\n\n\t\tthis.updateProjectionMatrix();\n\n\t},\n\n\tupdateProjectionMatrix: function () {\n\n\t\tvar dx = ( this.right - this.left ) / ( 2 * this.zoom );\n\t\tvar dy = ( this.top - this.bottom ) / ( 2 * this.zoom );\n\t\tvar cx = ( this.right + this.left ) / 2;\n\t\tvar cy = ( this.top + this.bottom ) / 2;\n\n\t\tvar left = cx - dx;\n\t\tvar right = cx + dx;\n\t\tvar top = cy + dy;\n\t\tvar bottom = cy - dy;\n\n\t\tif ( this.view !== null && this.view.enabled ) {\n\n\t\t\tvar zoomW = this.zoom / ( this.view.width / this.view.fullWidth );\n\t\t\tvar zoomH = this.zoom / ( this.view.height / this.view.fullHeight );\n\t\t\tvar scaleW = ( this.right - this.left ) / this.view.width;\n\t\t\tvar scaleH = ( this.top - this.bottom ) / this.view.height;\n\n\t\t\tleft += scaleW * ( this.view.offsetX / zoomW );\n\t\t\tright = left + scaleW * ( this.view.width / zoomW );\n\t\t\ttop -= scaleH * ( this.view.offsetY / zoomH );\n\t\t\tbottom = top - scaleH * ( this.view.height / zoomH );\n\n\t\t}\n\n\t\tthis.projectionMatrix.makeOrthographic( left, right, top, bottom, this.near, this.far );\n\n\t},\n\n\ttoJSON: function ( meta ) {\n\n\t\tvar data = Object3D.prototype.toJSON.call( this, meta );\n\n\t\tdata.object.zoom = this.zoom;\n\t\tdata.object.left = this.left;\n\t\tdata.object.right = this.right;\n\t\tdata.object.top = this.top;\n\t\tdata.object.bottom = this.bottom;\n\t\tdata.object.near = this.near;\n\t\tdata.object.far = this.far;\n\n\t\tif ( this.view !== null ) data.object.view = Object.assign( {}, this.view );\n\n\t\treturn data;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction Face3( a, b, c, normal, color, materialIndex ) {\n\n\tthis.a = a;\n\tthis.b = b;\n\tthis.c = c;\n\n\tthis.normal = ( normal && normal.isVector3 ) ? normal : new Vector3();\n\tthis.vertexNormals = Array.isArray( normal ) ? normal : [];\n\n\tthis.color = ( color && color.isColor ) ? color : new Color();\n\tthis.vertexColors = Array.isArray( color ) ? color : [];\n\n\tthis.materialIndex = materialIndex !== undefined ? materialIndex : 0;\n\n}\n\nObject.assign( Face3.prototype, {\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tthis.a = source.a;\n\t\tthis.b = source.b;\n\t\tthis.c = source.c;\n\n\t\tthis.normal.copy( source.normal );\n\t\tthis.color.copy( source.color );\n\n\t\tthis.materialIndex = source.materialIndex;\n\n\t\tfor ( var i = 0, il = source.vertexNormals.length; i < il; i ++ ) {\n\n\t\t\tthis.vertexNormals[ i ] = source.vertexNormals[ i ].clone();\n\n\t\t}\n\n\t\tfor ( var i = 0, il = source.vertexColors.length; i < il; i ++ ) {\n\n\t\t\tthis.vertexColors[ i ] = source.vertexColors[ i ].clone();\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author kile / http://kile.stravaganza.org/\n * @author alteredq / http://alteredqualia.com/\n * @author mikael emtinger / http://gomo.se/\n * @author zz85 / http://www.lab4games.net/zz85/blog\n * @author bhouston / http://clara.io\n */\n\nvar geometryId = 0; // Geometry uses even numbers as Id\n\nfunction Geometry() {\n\n\tObject.defineProperty( this, 'id', { value: geometryId += 2 } );\n\n\tthis.uuid = _Math.generateUUID();\n\n\tthis.name = '';\n\tthis.type = 'Geometry';\n\n\tthis.vertices = [];\n\tthis.colors = [];\n\tthis.faces = [];\n\tthis.faceVertexUvs = [[]];\n\n\tthis.morphTargets = [];\n\tthis.morphNormals = [];\n\n\tthis.skinWeights = [];\n\tthis.skinIndices = [];\n\n\tthis.lineDistances = [];\n\n\tthis.boundingBox = null;\n\tthis.boundingSphere = null;\n\n\t// update flags\n\n\tthis.elementsNeedUpdate = false;\n\tthis.verticesNeedUpdate = false;\n\tthis.uvsNeedUpdate = false;\n\tthis.normalsNeedUpdate = false;\n\tthis.colorsNeedUpdate = false;\n\tthis.lineDistancesNeedUpdate = false;\n\tthis.groupsNeedUpdate = false;\n\n}\n\nGeometry.prototype = Object.assign( Object.create( EventDispatcher.prototype ), {\n\n\tconstructor: Geometry,\n\n\tisGeometry: true,\n\n\tapplyMatrix: function ( matrix ) {\n\n\t\tvar normalMatrix = new Matrix3().getNormalMatrix( matrix );\n\n\t\tfor ( var i = 0, il = this.vertices.length; i < il; i ++ ) {\n\n\t\t\tvar vertex = this.vertices[ i ];\n\t\t\tvertex.applyMatrix4( matrix );\n\n\t\t}\n\n\t\tfor ( var i = 0, il = this.faces.length; i < il; i ++ ) {\n\n\t\t\tvar face = this.faces[ i ];\n\t\t\tface.normal.applyMatrix3( normalMatrix ).normalize();\n\n\t\t\tfor ( var j = 0, jl = face.vertexNormals.length; j < jl; j ++ ) {\n\n\t\t\t\tface.vertexNormals[ j ].applyMatrix3( normalMatrix ).normalize();\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.boundingBox !== null ) {\n\n\t\t\tthis.computeBoundingBox();\n\n\t\t}\n\n\t\tif ( this.boundingSphere !== null ) {\n\n\t\t\tthis.computeBoundingSphere();\n\n\t\t}\n\n\t\tthis.verticesNeedUpdate = true;\n\t\tthis.normalsNeedUpdate = true;\n\n\t\treturn this;\n\n\t},\n\n\trotateX: function () {\n\n\t\t// rotate geometry around world x-axis\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function rotateX( angle ) {\n\n\t\t\tm1.makeRotationX( angle );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\trotateY: function () {\n\n\t\t// rotate geometry around world y-axis\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function rotateY( angle ) {\n\n\t\t\tm1.makeRotationY( angle );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\trotateZ: function () {\n\n\t\t// rotate geometry around world z-axis\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function rotateZ( angle ) {\n\n\t\t\tm1.makeRotationZ( angle );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\ttranslate: function () {\n\n\t\t// translate geometry\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function translate( x, y, z ) {\n\n\t\t\tm1.makeTranslation( x, y, z );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tscale: function () {\n\n\t\t// scale geometry\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function scale( x, y, z ) {\n\n\t\t\tm1.makeScale( x, y, z );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tlookAt: function () {\n\n\t\tvar obj = new Object3D();\n\n\t\treturn function lookAt( vector ) {\n\n\t\t\tobj.lookAt( vector );\n\n\t\t\tobj.updateMatrix();\n\n\t\t\tthis.applyMatrix( obj.matrix );\n\n\t\t};\n\n\t}(),\n\n\tfromBufferGeometry: function ( geometry ) {\n\n\t\tvar scope = this;\n\n\t\tvar indices = geometry.index !== null ? geometry.index.array : undefined;\n\t\tvar attributes = geometry.attributes;\n\n\t\tvar positions = attributes.position.array;\n\t\tvar normals = attributes.normal !== undefined ? attributes.normal.array : undefined;\n\t\tvar colors = attributes.color !== undefined ? attributes.color.array : undefined;\n\t\tvar uvs = attributes.uv !== undefined ? attributes.uv.array : undefined;\n\t\tvar uvs2 = attributes.uv2 !== undefined ? attributes.uv2.array : undefined;\n\n\t\tif ( uvs2 !== undefined ) this.faceVertexUvs[ 1 ] = [];\n\n\t\tvar tempNormals = [];\n\t\tvar tempUVs = [];\n\t\tvar tempUVs2 = [];\n\n\t\tfor ( var i = 0, j = 0; i < positions.length; i += 3, j += 2 ) {\n\n\t\t\tscope.vertices.push( new Vector3( positions[ i ], positions[ i + 1 ], positions[ i + 2 ] ) );\n\n\t\t\tif ( normals !== undefined ) {\n\n\t\t\t\ttempNormals.push( new Vector3( normals[ i ], normals[ i + 1 ], normals[ i + 2 ] ) );\n\n\t\t\t}\n\n\t\t\tif ( colors !== undefined ) {\n\n\t\t\t\tscope.colors.push( new Color( colors[ i ], colors[ i + 1 ], colors[ i + 2 ] ) );\n\n\t\t\t}\n\n\t\t\tif ( uvs !== undefined ) {\n\n\t\t\t\ttempUVs.push( new Vector2( uvs[ j ], uvs[ j + 1 ] ) );\n\n\t\t\t}\n\n\t\t\tif ( uvs2 !== undefined ) {\n\n\t\t\t\ttempUVs2.push( new Vector2( uvs2[ j ], uvs2[ j + 1 ] ) );\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction addFace( a, b, c, materialIndex ) {\n\n\t\t\tvar vertexNormals = normals !== undefined ? [ tempNormals[ a ].clone(), tempNormals[ b ].clone(), tempNormals[ c ].clone() ] : [];\n\t\t\tvar vertexColors = colors !== undefined ? [ scope.colors[ a ].clone(), scope.colors[ b ].clone(), scope.colors[ c ].clone() ] : [];\n\n\t\t\tvar face = new Face3( a, b, c, vertexNormals, vertexColors, materialIndex );\n\n\t\t\tscope.faces.push( face );\n\n\t\t\tif ( uvs !== undefined ) {\n\n\t\t\t\tscope.faceVertexUvs[ 0 ].push( [ tempUVs[ a ].clone(), tempUVs[ b ].clone(), tempUVs[ c ].clone() ] );\n\n\t\t\t}\n\n\t\t\tif ( uvs2 !== undefined ) {\n\n\t\t\t\tscope.faceVertexUvs[ 1 ].push( [ tempUVs2[ a ].clone(), tempUVs2[ b ].clone(), tempUVs2[ c ].clone() ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar groups = geometry.groups;\n\n\t\tif ( groups.length > 0 ) {\n\n\t\t\tfor ( var i = 0; i < groups.length; i ++ ) {\n\n\t\t\t\tvar group = groups[ i ];\n\n\t\t\t\tvar start = group.start;\n\t\t\t\tvar count = group.count;\n\n\t\t\t\tfor ( var j = start, jl = start + count; j < jl; j += 3 ) {\n\n\t\t\t\t\tif ( indices !== undefined ) {\n\n\t\t\t\t\t\taddFace( indices[ j ], indices[ j + 1 ], indices[ j + 2 ], group.materialIndex );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\taddFace( j, j + 1, j + 2, group.materialIndex );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tif ( indices !== undefined ) {\n\n\t\t\t\tfor ( var i = 0; i < indices.length; i += 3 ) {\n\n\t\t\t\t\taddFace( indices[ i ], indices[ i + 1 ], indices[ i + 2 ] );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tfor ( var i = 0; i < positions.length / 3; i += 3 ) {\n\n\t\t\t\t\taddFace( i, i + 1, i + 2 );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis.computeFaceNormals();\n\n\t\tif ( geometry.boundingBox !== null ) {\n\n\t\t\tthis.boundingBox = geometry.boundingBox.clone();\n\n\t\t}\n\n\t\tif ( geometry.boundingSphere !== null ) {\n\n\t\t\tthis.boundingSphere = geometry.boundingSphere.clone();\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tcenter: function () {\n\n\t\tvar offset = new Vector3();\n\n\t\treturn function center() {\n\n\t\t\tthis.computeBoundingBox();\n\n\t\t\tthis.boundingBox.getCenter( offset ).negate();\n\n\t\t\tthis.translate( offset.x, offset.y, offset.z );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tnormalize: function () {\n\n\t\tthis.computeBoundingSphere();\n\n\t\tvar center = this.boundingSphere.center;\n\t\tvar radius = this.boundingSphere.radius;\n\n\t\tvar s = radius === 0 ? 1 : 1.0 / radius;\n\n\t\tvar matrix = new Matrix4();\n\t\tmatrix.set(\n\t\t\ts, 0, 0, - s * center.x,\n\t\t\t0, s, 0, - s * center.y,\n\t\t\t0, 0, s, - s * center.z,\n\t\t\t0, 0, 0, 1\n\t\t);\n\n\t\tthis.applyMatrix( matrix );\n\n\t\treturn this;\n\n\t},\n\n\tcomputeFaceNormals: function () {\n\n\t\tvar cb = new Vector3(), ab = new Vector3();\n\n\t\tfor ( var f = 0, fl = this.faces.length; f < fl; f ++ ) {\n\n\t\t\tvar face = this.faces[ f ];\n\n\t\t\tvar vA = this.vertices[ face.a ];\n\t\t\tvar vB = this.vertices[ face.b ];\n\t\t\tvar vC = this.vertices[ face.c ];\n\n\t\t\tcb.subVectors( vC, vB );\n\t\t\tab.subVectors( vA, vB );\n\t\t\tcb.cross( ab );\n\n\t\t\tcb.normalize();\n\n\t\t\tface.normal.copy( cb );\n\n\t\t}\n\n\t},\n\n\tcomputeVertexNormals: function ( areaWeighted ) {\n\n\t\tif ( areaWeighted === undefined ) areaWeighted = true;\n\n\t\tvar v, vl, f, fl, face, vertices;\n\n\t\tvertices = new Array( this.vertices.length );\n\n\t\tfor ( v = 0, vl = this.vertices.length; v < vl; v ++ ) {\n\n\t\t\tvertices[ v ] = new Vector3();\n\n\t\t}\n\n\t\tif ( areaWeighted ) {\n\n\t\t\t// vertex normals weighted by triangle areas\n\t\t\t// http://www.iquilezles.org/www/articles/normals/normals.htm\n\n\t\t\tvar vA, vB, vC;\n\t\t\tvar cb = new Vector3(), ab = new Vector3();\n\n\t\t\tfor ( f = 0, fl = this.faces.length; f < fl; f ++ ) {\n\n\t\t\t\tface = this.faces[ f ];\n\n\t\t\t\tvA = this.vertices[ face.a ];\n\t\t\t\tvB = this.vertices[ face.b ];\n\t\t\t\tvC = this.vertices[ face.c ];\n\n\t\t\t\tcb.subVectors( vC, vB );\n\t\t\t\tab.subVectors( vA, vB );\n\t\t\t\tcb.cross( ab );\n\n\t\t\t\tvertices[ face.a ].add( cb );\n\t\t\t\tvertices[ face.b ].add( cb );\n\t\t\t\tvertices[ face.c ].add( cb );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tthis.computeFaceNormals();\n\n\t\t\tfor ( f = 0, fl = this.faces.length; f < fl; f ++ ) {\n\n\t\t\t\tface = this.faces[ f ];\n\n\t\t\t\tvertices[ face.a ].add( face.normal );\n\t\t\t\tvertices[ face.b ].add( face.normal );\n\t\t\t\tvertices[ face.c ].add( face.normal );\n\n\t\t\t}\n\n\t\t}\n\n\t\tfor ( v = 0, vl = this.vertices.length; v < vl; v ++ ) {\n\n\t\t\tvertices[ v ].normalize();\n\n\t\t}\n\n\t\tfor ( f = 0, fl = this.faces.length; f < fl; f ++ ) {\n\n\t\t\tface = this.faces[ f ];\n\n\t\t\tvar vertexNormals = face.vertexNormals;\n\n\t\t\tif ( vertexNormals.length === 3 ) {\n\n\t\t\t\tvertexNormals[ 0 ].copy( vertices[ face.a ] );\n\t\t\t\tvertexNormals[ 1 ].copy( vertices[ face.b ] );\n\t\t\t\tvertexNormals[ 2 ].copy( vertices[ face.c ] );\n\n\t\t\t} else {\n\n\t\t\t\tvertexNormals[ 0 ] = vertices[ face.a ].clone();\n\t\t\t\tvertexNormals[ 1 ] = vertices[ face.b ].clone();\n\t\t\t\tvertexNormals[ 2 ] = vertices[ face.c ].clone();\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.faces.length > 0 ) {\n\n\t\t\tthis.normalsNeedUpdate = true;\n\n\t\t}\n\n\t},\n\n\tcomputeFlatVertexNormals: function () {\n\n\t\tvar f, fl, face;\n\n\t\tthis.computeFaceNormals();\n\n\t\tfor ( f = 0, fl = this.faces.length; f < fl; f ++ ) {\n\n\t\t\tface = this.faces[ f ];\n\n\t\t\tvar vertexNormals = face.vertexNormals;\n\n\t\t\tif ( vertexNormals.length === 3 ) {\n\n\t\t\t\tvertexNormals[ 0 ].copy( face.normal );\n\t\t\t\tvertexNormals[ 1 ].copy( face.normal );\n\t\t\t\tvertexNormals[ 2 ].copy( face.normal );\n\n\t\t\t} else {\n\n\t\t\t\tvertexNormals[ 0 ] = face.normal.clone();\n\t\t\t\tvertexNormals[ 1 ] = face.normal.clone();\n\t\t\t\tvertexNormals[ 2 ] = face.normal.clone();\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.faces.length > 0 ) {\n\n\t\t\tthis.normalsNeedUpdate = true;\n\n\t\t}\n\n\t},\n\n\tcomputeMorphNormals: function () {\n\n\t\tvar i, il, f, fl, face;\n\n\t\t// save original normals\n\t\t// - create temp variables on first access\n\t\t//   otherwise just copy (for faster repeated calls)\n\n\t\tfor ( f = 0, fl = this.faces.length; f < fl; f ++ ) {\n\n\t\t\tface = this.faces[ f ];\n\n\t\t\tif ( ! face.__originalFaceNormal ) {\n\n\t\t\t\tface.__originalFaceNormal = face.normal.clone();\n\n\t\t\t} else {\n\n\t\t\t\tface.__originalFaceNormal.copy( face.normal );\n\n\t\t\t}\n\n\t\t\tif ( ! face.__originalVertexNormals ) face.__originalVertexNormals = [];\n\n\t\t\tfor ( i = 0, il = face.vertexNormals.length; i < il; i ++ ) {\n\n\t\t\t\tif ( ! face.__originalVertexNormals[ i ] ) {\n\n\t\t\t\t\tface.__originalVertexNormals[ i ] = face.vertexNormals[ i ].clone();\n\n\t\t\t\t} else {\n\n\t\t\t\t\tface.__originalVertexNormals[ i ].copy( face.vertexNormals[ i ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t// use temp geometry to compute face and vertex normals for each morph\n\n\t\tvar tmpGeo = new Geometry();\n\t\ttmpGeo.faces = this.faces;\n\n\t\tfor ( i = 0, il = this.morphTargets.length; i < il; i ++ ) {\n\n\t\t\t// create on first access\n\n\t\t\tif ( ! this.morphNormals[ i ] ) {\n\n\t\t\t\tthis.morphNormals[ i ] = {};\n\t\t\t\tthis.morphNormals[ i ].faceNormals = [];\n\t\t\t\tthis.morphNormals[ i ].vertexNormals = [];\n\n\t\t\t\tvar dstNormalsFace = this.morphNormals[ i ].faceNormals;\n\t\t\t\tvar dstNormalsVertex = this.morphNormals[ i ].vertexNormals;\n\n\t\t\t\tvar faceNormal, vertexNormals;\n\n\t\t\t\tfor ( f = 0, fl = this.faces.length; f < fl; f ++ ) {\n\n\t\t\t\t\tfaceNormal = new Vector3();\n\t\t\t\t\tvertexNormals = { a: new Vector3(), b: new Vector3(), c: new Vector3() };\n\n\t\t\t\t\tdstNormalsFace.push( faceNormal );\n\t\t\t\t\tdstNormalsVertex.push( vertexNormals );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tvar morphNormals = this.morphNormals[ i ];\n\n\t\t\t// set vertices to morph target\n\n\t\t\ttmpGeo.vertices = this.morphTargets[ i ].vertices;\n\n\t\t\t// compute morph normals\n\n\t\t\ttmpGeo.computeFaceNormals();\n\t\t\ttmpGeo.computeVertexNormals();\n\n\t\t\t// store morph normals\n\n\t\t\tvar faceNormal, vertexNormals;\n\n\t\t\tfor ( f = 0, fl = this.faces.length; f < fl; f ++ ) {\n\n\t\t\t\tface = this.faces[ f ];\n\n\t\t\t\tfaceNormal = morphNormals.faceNormals[ f ];\n\t\t\t\tvertexNormals = morphNormals.vertexNormals[ f ];\n\n\t\t\t\tfaceNormal.copy( face.normal );\n\n\t\t\t\tvertexNormals.a.copy( face.vertexNormals[ 0 ] );\n\t\t\t\tvertexNormals.b.copy( face.vertexNormals[ 1 ] );\n\t\t\t\tvertexNormals.c.copy( face.vertexNormals[ 2 ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// restore original normals\n\n\t\tfor ( f = 0, fl = this.faces.length; f < fl; f ++ ) {\n\n\t\t\tface = this.faces[ f ];\n\n\t\t\tface.normal = face.__originalFaceNormal;\n\t\t\tface.vertexNormals = face.__originalVertexNormals;\n\n\t\t}\n\n\t},\n\n\tcomputeBoundingBox: function () {\n\n\t\tif ( this.boundingBox === null ) {\n\n\t\t\tthis.boundingBox = new Box3();\n\n\t\t}\n\n\t\tthis.boundingBox.setFromPoints( this.vertices );\n\n\t},\n\n\tcomputeBoundingSphere: function () {\n\n\t\tif ( this.boundingSphere === null ) {\n\n\t\t\tthis.boundingSphere = new Sphere();\n\n\t\t}\n\n\t\tthis.boundingSphere.setFromPoints( this.vertices );\n\n\t},\n\n\tmerge: function ( geometry, matrix, materialIndexOffset ) {\n\n\t\tif ( ! ( geometry && geometry.isGeometry ) ) {\n\n\t\t\tconsole.error( 'THREE.Geometry.merge(): geometry not an instance of THREE.Geometry.', geometry );\n\t\t\treturn;\n\n\t\t}\n\n\t\tvar normalMatrix,\n\t\t\tvertexOffset = this.vertices.length,\n\t\t\tvertices1 = this.vertices,\n\t\t\tvertices2 = geometry.vertices,\n\t\t\tfaces1 = this.faces,\n\t\t\tfaces2 = geometry.faces,\n\t\t\tuvs1 = this.faceVertexUvs[ 0 ],\n\t\t\tuvs2 = geometry.faceVertexUvs[ 0 ],\n\t\t\tcolors1 = this.colors,\n\t\t\tcolors2 = geometry.colors;\n\n\t\tif ( materialIndexOffset === undefined ) materialIndexOffset = 0;\n\n\t\tif ( matrix !== undefined ) {\n\n\t\t\tnormalMatrix = new Matrix3().getNormalMatrix( matrix );\n\n\t\t}\n\n\t\t// vertices\n\n\t\tfor ( var i = 0, il = vertices2.length; i < il; i ++ ) {\n\n\t\t\tvar vertex = vertices2[ i ];\n\n\t\t\tvar vertexCopy = vertex.clone();\n\n\t\t\tif ( matrix !== undefined ) vertexCopy.applyMatrix4( matrix );\n\n\t\t\tvertices1.push( vertexCopy );\n\n\t\t}\n\n\t\t// colors\n\n\t\tfor ( var i = 0, il = colors2.length; i < il; i ++ ) {\n\n\t\t\tcolors1.push( colors2[ i ].clone() );\n\n\t\t}\n\n\t\t// faces\n\n\t\tfor ( i = 0, il = faces2.length; i < il; i ++ ) {\n\n\t\t\tvar face = faces2[ i ], faceCopy, normal, color,\n\t\t\t\tfaceVertexNormals = face.vertexNormals,\n\t\t\t\tfaceVertexColors = face.vertexColors;\n\n\t\t\tfaceCopy = new Face3( face.a + vertexOffset, face.b + vertexOffset, face.c + vertexOffset );\n\t\t\tfaceCopy.normal.copy( face.normal );\n\n\t\t\tif ( normalMatrix !== undefined ) {\n\n\t\t\t\tfaceCopy.normal.applyMatrix3( normalMatrix ).normalize();\n\n\t\t\t}\n\n\t\t\tfor ( var j = 0, jl = faceVertexNormals.length; j < jl; j ++ ) {\n\n\t\t\t\tnormal = faceVertexNormals[ j ].clone();\n\n\t\t\t\tif ( normalMatrix !== undefined ) {\n\n\t\t\t\t\tnormal.applyMatrix3( normalMatrix ).normalize();\n\n\t\t\t\t}\n\n\t\t\t\tfaceCopy.vertexNormals.push( normal );\n\n\t\t\t}\n\n\t\t\tfaceCopy.color.copy( face.color );\n\n\t\t\tfor ( var j = 0, jl = faceVertexColors.length; j < jl; j ++ ) {\n\n\t\t\t\tcolor = faceVertexColors[ j ];\n\t\t\t\tfaceCopy.vertexColors.push( color.clone() );\n\n\t\t\t}\n\n\t\t\tfaceCopy.materialIndex = face.materialIndex + materialIndexOffset;\n\n\t\t\tfaces1.push( faceCopy );\n\n\t\t}\n\n\t\t// uvs\n\n\t\tfor ( i = 0, il = uvs2.length; i < il; i ++ ) {\n\n\t\t\tvar uv = uvs2[ i ], uvCopy = [];\n\n\t\t\tif ( uv === undefined ) {\n\n\t\t\t\tcontinue;\n\n\t\t\t}\n\n\t\t\tfor ( var j = 0, jl = uv.length; j < jl; j ++ ) {\n\n\t\t\t\tuvCopy.push( uv[ j ].clone() );\n\n\t\t\t}\n\n\t\t\tuvs1.push( uvCopy );\n\n\t\t}\n\n\t},\n\n\tmergeMesh: function ( mesh ) {\n\n\t\tif ( ! ( mesh && mesh.isMesh ) ) {\n\n\t\t\tconsole.error( 'THREE.Geometry.mergeMesh(): mesh not an instance of THREE.Mesh.', mesh );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( mesh.matrixAutoUpdate ) mesh.updateMatrix();\n\n\t\tthis.merge( mesh.geometry, mesh.matrix );\n\n\t},\n\n\t/*\n\t * Checks for duplicate vertices with hashmap.\n\t * Duplicated vertices are removed\n\t * and faces' vertices are updated.\n\t */\n\n\tmergeVertices: function () {\n\n\t\tvar verticesMap = {}; // Hashmap for looking up vertices by position coordinates (and making sure they are unique)\n\t\tvar unique = [], changes = [];\n\n\t\tvar v, key;\n\t\tvar precisionPoints = 4; // number of decimal points, e.g. 4 for epsilon of 0.0001\n\t\tvar precision = Math.pow( 10, precisionPoints );\n\t\tvar i, il, face;\n\t\tvar indices, j, jl;\n\n\t\tfor ( i = 0, il = this.vertices.length; i < il; i ++ ) {\n\n\t\t\tv = this.vertices[ i ];\n\t\t\tkey = Math.round( v.x * precision ) + '_' + Math.round( v.y * precision ) + '_' + Math.round( v.z * precision );\n\n\t\t\tif ( verticesMap[ key ] === undefined ) {\n\n\t\t\t\tverticesMap[ key ] = i;\n\t\t\t\tunique.push( this.vertices[ i ] );\n\t\t\t\tchanges[ i ] = unique.length - 1;\n\n\t\t\t} else {\n\n\t\t\t\t//console.log('Duplicate vertex found. ', i, ' could be using ', verticesMap[key]);\n\t\t\t\tchanges[ i ] = changes[ verticesMap[ key ] ];\n\n\t\t\t}\n\n\t\t}\n\n\n\t\t// if faces are completely degenerate after merging vertices, we\n\t\t// have to remove them from the geometry.\n\t\tvar faceIndicesToRemove = [];\n\n\t\tfor ( i = 0, il = this.faces.length; i < il; i ++ ) {\n\n\t\t\tface = this.faces[ i ];\n\n\t\t\tface.a = changes[ face.a ];\n\t\t\tface.b = changes[ face.b ];\n\t\t\tface.c = changes[ face.c ];\n\n\t\t\tindices = [ face.a, face.b, face.c ];\n\n\t\t\t// if any duplicate vertices are found in a Face3\n\t\t\t// we have to remove the face as nothing can be saved\n\t\t\tfor ( var n = 0; n < 3; n ++ ) {\n\n\t\t\t\tif ( indices[ n ] === indices[ ( n + 1 ) % 3 ] ) {\n\n\t\t\t\t\tfaceIndicesToRemove.push( i );\n\t\t\t\t\tbreak;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tfor ( i = faceIndicesToRemove.length - 1; i >= 0; i -- ) {\n\n\t\t\tvar idx = faceIndicesToRemove[ i ];\n\n\t\t\tthis.faces.splice( idx, 1 );\n\n\t\t\tfor ( j = 0, jl = this.faceVertexUvs.length; j < jl; j ++ ) {\n\n\t\t\t\tthis.faceVertexUvs[ j ].splice( idx, 1 );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Use unique set of vertices\n\n\t\tvar diff = this.vertices.length - unique.length;\n\t\tthis.vertices = unique;\n\t\treturn diff;\n\n\t},\n\n\tsetFromPoints: function ( points ) {\n\n\t\tthis.vertices = [];\n\n\t\tfor ( var i = 0, l = points.length; i < l; i ++ ) {\n\n\t\t\tvar point = points[ i ];\n\t\t\tthis.vertices.push( new Vector3( point.x, point.y, point.z || 0 ) );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tsortFacesByMaterialIndex: function () {\n\n\t\tvar faces = this.faces;\n\t\tvar length = faces.length;\n\n\t\t// tag faces\n\n\t\tfor ( var i = 0; i < length; i ++ ) {\n\n\t\t\tfaces[ i ]._id = i;\n\n\t\t}\n\n\t\t// sort faces\n\n\t\tfunction materialIndexSort( a, b ) {\n\n\t\t\treturn a.materialIndex - b.materialIndex;\n\n\t\t}\n\n\t\tfaces.sort( materialIndexSort );\n\n\t\t// sort uvs\n\n\t\tvar uvs1 = this.faceVertexUvs[ 0 ];\n\t\tvar uvs2 = this.faceVertexUvs[ 1 ];\n\n\t\tvar newUvs1, newUvs2;\n\n\t\tif ( uvs1 && uvs1.length === length ) newUvs1 = [];\n\t\tif ( uvs2 && uvs2.length === length ) newUvs2 = [];\n\n\t\tfor ( var i = 0; i < length; i ++ ) {\n\n\t\t\tvar id = faces[ i ]._id;\n\n\t\t\tif ( newUvs1 ) newUvs1.push( uvs1[ id ] );\n\t\t\tif ( newUvs2 ) newUvs2.push( uvs2[ id ] );\n\n\t\t}\n\n\t\tif ( newUvs1 ) this.faceVertexUvs[ 0 ] = newUvs1;\n\t\tif ( newUvs2 ) this.faceVertexUvs[ 1 ] = newUvs2;\n\n\t},\n\n\ttoJSON: function () {\n\n\t\tvar data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Geometry',\n\t\t\t\tgenerator: 'Geometry.toJSON'\n\t\t\t}\n\t\t};\n\n\t\t// standard Geometry serialization\n\n\t\tdata.uuid = this.uuid;\n\t\tdata.type = this.type;\n\t\tif ( this.name !== '' ) data.name = this.name;\n\n\t\tif ( this.parameters !== undefined ) {\n\n\t\t\tvar parameters = this.parameters;\n\n\t\t\tfor ( var key in parameters ) {\n\n\t\t\t\tif ( parameters[ key ] !== undefined ) data[ key ] = parameters[ key ];\n\n\t\t\t}\n\n\t\t\treturn data;\n\n\t\t}\n\n\t\tvar vertices = [];\n\n\t\tfor ( var i = 0; i < this.vertices.length; i ++ ) {\n\n\t\t\tvar vertex = this.vertices[ i ];\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t}\n\n\t\tvar faces = [];\n\t\tvar normals = [];\n\t\tvar normalsHash = {};\n\t\tvar colors = [];\n\t\tvar colorsHash = {};\n\t\tvar uvs = [];\n\t\tvar uvsHash = {};\n\n\t\tfor ( var i = 0; i < this.faces.length; i ++ ) {\n\n\t\t\tvar face = this.faces[ i ];\n\n\t\t\tvar hasMaterial = true;\n\t\t\tvar hasFaceUv = false; // deprecated\n\t\t\tvar hasFaceVertexUv = this.faceVertexUvs[ 0 ][ i ] !== undefined;\n\t\t\tvar hasFaceNormal = face.normal.length() > 0;\n\t\t\tvar hasFaceVertexNormal = face.vertexNormals.length > 0;\n\t\t\tvar hasFaceColor = face.color.r !== 1 || face.color.g !== 1 || face.color.b !== 1;\n\t\t\tvar hasFaceVertexColor = face.vertexColors.length > 0;\n\n\t\t\tvar faceType = 0;\n\n\t\t\tfaceType = setBit( faceType, 0, 0 ); // isQuad\n\t\t\tfaceType = setBit( faceType, 1, hasMaterial );\n\t\t\tfaceType = setBit( faceType, 2, hasFaceUv );\n\t\t\tfaceType = setBit( faceType, 3, hasFaceVertexUv );\n\t\t\tfaceType = setBit( faceType, 4, hasFaceNormal );\n\t\t\tfaceType = setBit( faceType, 5, hasFaceVertexNormal );\n\t\t\tfaceType = setBit( faceType, 6, hasFaceColor );\n\t\t\tfaceType = setBit( faceType, 7, hasFaceVertexColor );\n\n\t\t\tfaces.push( faceType );\n\t\t\tfaces.push( face.a, face.b, face.c );\n\t\t\tfaces.push( face.materialIndex );\n\n\t\t\tif ( hasFaceVertexUv ) {\n\n\t\t\t\tvar faceVertexUvs = this.faceVertexUvs[ 0 ][ i ];\n\n\t\t\t\tfaces.push(\n\t\t\t\t\tgetUvIndex( faceVertexUvs[ 0 ] ),\n\t\t\t\t\tgetUvIndex( faceVertexUvs[ 1 ] ),\n\t\t\t\t\tgetUvIndex( faceVertexUvs[ 2 ] )\n\t\t\t\t);\n\n\t\t\t}\n\n\t\t\tif ( hasFaceNormal ) {\n\n\t\t\t\tfaces.push( getNormalIndex( face.normal ) );\n\n\t\t\t}\n\n\t\t\tif ( hasFaceVertexNormal ) {\n\n\t\t\t\tvar vertexNormals = face.vertexNormals;\n\n\t\t\t\tfaces.push(\n\t\t\t\t\tgetNormalIndex( vertexNormals[ 0 ] ),\n\t\t\t\t\tgetNormalIndex( vertexNormals[ 1 ] ),\n\t\t\t\t\tgetNormalIndex( vertexNormals[ 2 ] )\n\t\t\t\t);\n\n\t\t\t}\n\n\t\t\tif ( hasFaceColor ) {\n\n\t\t\t\tfaces.push( getColorIndex( face.color ) );\n\n\t\t\t}\n\n\t\t\tif ( hasFaceVertexColor ) {\n\n\t\t\t\tvar vertexColors = face.vertexColors;\n\n\t\t\t\tfaces.push(\n\t\t\t\t\tgetColorIndex( vertexColors[ 0 ] ),\n\t\t\t\t\tgetColorIndex( vertexColors[ 1 ] ),\n\t\t\t\t\tgetColorIndex( vertexColors[ 2 ] )\n\t\t\t\t);\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction setBit( value, position, enabled ) {\n\n\t\t\treturn enabled ? value | ( 1 << position ) : value & ( ~ ( 1 << position ) );\n\n\t\t}\n\n\t\tfunction getNormalIndex( normal ) {\n\n\t\t\tvar hash = normal.x.toString() + normal.y.toString() + normal.z.toString();\n\n\t\t\tif ( normalsHash[ hash ] !== undefined ) {\n\n\t\t\t\treturn normalsHash[ hash ];\n\n\t\t\t}\n\n\t\t\tnormalsHash[ hash ] = normals.length / 3;\n\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\treturn normalsHash[ hash ];\n\n\t\t}\n\n\t\tfunction getColorIndex( color ) {\n\n\t\t\tvar hash = color.r.toString() + color.g.toString() + color.b.toString();\n\n\t\t\tif ( colorsHash[ hash ] !== undefined ) {\n\n\t\t\t\treturn colorsHash[ hash ];\n\n\t\t\t}\n\n\t\t\tcolorsHash[ hash ] = colors.length;\n\t\t\tcolors.push( color.getHex() );\n\n\t\t\treturn colorsHash[ hash ];\n\n\t\t}\n\n\t\tfunction getUvIndex( uv ) {\n\n\t\t\tvar hash = uv.x.toString() + uv.y.toString();\n\n\t\t\tif ( uvsHash[ hash ] !== undefined ) {\n\n\t\t\t\treturn uvsHash[ hash ];\n\n\t\t\t}\n\n\t\t\tuvsHash[ hash ] = uvs.length / 2;\n\t\t\tuvs.push( uv.x, uv.y );\n\n\t\t\treturn uvsHash[ hash ];\n\n\t\t}\n\n\t\tdata.data = {};\n\n\t\tdata.data.vertices = vertices;\n\t\tdata.data.normals = normals;\n\t\tif ( colors.length > 0 ) data.data.colors = colors;\n\t\tif ( uvs.length > 0 ) data.data.uvs = [ uvs ]; // temporal backward compatibility\n\t\tdata.data.faces = faces;\n\n\t\treturn data;\n\n\t},\n\n\tclone: function () {\n\n\t\t/*\n\t\t // Handle primitives\n\n\t\t var parameters = this.parameters;\n\n\t\t if ( parameters !== undefined ) {\n\n\t\t var values = [];\n\n\t\t for ( var key in parameters ) {\n\n\t\t values.push( parameters[ key ] );\n\n\t\t }\n\n\t\t var geometry = Object.create( this.constructor.prototype );\n\t\t this.constructor.apply( geometry, values );\n\t\t return geometry;\n\n\t\t }\n\n\t\t return new this.constructor().copy( this );\n\t\t */\n\n\t\treturn new Geometry().copy( this );\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tvar i, il, j, jl, k, kl;\n\n\t\t// reset\n\n\t\tthis.vertices = [];\n\t\tthis.colors = [];\n\t\tthis.faces = [];\n\t\tthis.faceVertexUvs = [[]];\n\t\tthis.morphTargets = [];\n\t\tthis.morphNormals = [];\n\t\tthis.skinWeights = [];\n\t\tthis.skinIndices = [];\n\t\tthis.lineDistances = [];\n\t\tthis.boundingBox = null;\n\t\tthis.boundingSphere = null;\n\n\t\t// name\n\n\t\tthis.name = source.name;\n\n\t\t// vertices\n\n\t\tvar vertices = source.vertices;\n\n\t\tfor ( i = 0, il = vertices.length; i < il; i ++ ) {\n\n\t\t\tthis.vertices.push( vertices[ i ].clone() );\n\n\t\t}\n\n\t\t// colors\n\n\t\tvar colors = source.colors;\n\n\t\tfor ( i = 0, il = colors.length; i < il; i ++ ) {\n\n\t\t\tthis.colors.push( colors[ i ].clone() );\n\n\t\t}\n\n\t\t// faces\n\n\t\tvar faces = source.faces;\n\n\t\tfor ( i = 0, il = faces.length; i < il; i ++ ) {\n\n\t\t\tthis.faces.push( faces[ i ].clone() );\n\n\t\t}\n\n\t\t// face vertex uvs\n\n\t\tfor ( i = 0, il = source.faceVertexUvs.length; i < il; i ++ ) {\n\n\t\t\tvar faceVertexUvs = source.faceVertexUvs[ i ];\n\n\t\t\tif ( this.faceVertexUvs[ i ] === undefined ) {\n\n\t\t\t\tthis.faceVertexUvs[ i ] = [];\n\n\t\t\t}\n\n\t\t\tfor ( j = 0, jl = faceVertexUvs.length; j < jl; j ++ ) {\n\n\t\t\t\tvar uvs = faceVertexUvs[ j ], uvsCopy = [];\n\n\t\t\t\tfor ( k = 0, kl = uvs.length; k < kl; k ++ ) {\n\n\t\t\t\t\tvar uv = uvs[ k ];\n\n\t\t\t\t\tuvsCopy.push( uv.clone() );\n\n\t\t\t\t}\n\n\t\t\t\tthis.faceVertexUvs[ i ].push( uvsCopy );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// morph targets\n\n\t\tvar morphTargets = source.morphTargets;\n\n\t\tfor ( i = 0, il = morphTargets.length; i < il; i ++ ) {\n\n\t\t\tvar morphTarget = {};\n\t\t\tmorphTarget.name = morphTargets[ i ].name;\n\n\t\t\t// vertices\n\n\t\t\tif ( morphTargets[ i ].vertices !== undefined ) {\n\n\t\t\t\tmorphTarget.vertices = [];\n\n\t\t\t\tfor ( j = 0, jl = morphTargets[ i ].vertices.length; j < jl; j ++ ) {\n\n\t\t\t\t\tmorphTarget.vertices.push( morphTargets[ i ].vertices[ j ].clone() );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// normals\n\n\t\t\tif ( morphTargets[ i ].normals !== undefined ) {\n\n\t\t\t\tmorphTarget.normals = [];\n\n\t\t\t\tfor ( j = 0, jl = morphTargets[ i ].normals.length; j < jl; j ++ ) {\n\n\t\t\t\t\tmorphTarget.normals.push( morphTargets[ i ].normals[ j ].clone() );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis.morphTargets.push( morphTarget );\n\n\t\t}\n\n\t\t// morph normals\n\n\t\tvar morphNormals = source.morphNormals;\n\n\t\tfor ( i = 0, il = morphNormals.length; i < il; i ++ ) {\n\n\t\t\tvar morphNormal = {};\n\n\t\t\t// vertex normals\n\n\t\t\tif ( morphNormals[ i ].vertexNormals !== undefined ) {\n\n\t\t\t\tmorphNormal.vertexNormals = [];\n\n\t\t\t\tfor ( j = 0, jl = morphNormals[ i ].vertexNormals.length; j < jl; j ++ ) {\n\n\t\t\t\t\tvar srcVertexNormal = morphNormals[ i ].vertexNormals[ j ];\n\t\t\t\t\tvar destVertexNormal = {};\n\n\t\t\t\t\tdestVertexNormal.a = srcVertexNormal.a.clone();\n\t\t\t\t\tdestVertexNormal.b = srcVertexNormal.b.clone();\n\t\t\t\t\tdestVertexNormal.c = srcVertexNormal.c.clone();\n\n\t\t\t\t\tmorphNormal.vertexNormals.push( destVertexNormal );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// face normals\n\n\t\t\tif ( morphNormals[ i ].faceNormals !== undefined ) {\n\n\t\t\t\tmorphNormal.faceNormals = [];\n\n\t\t\t\tfor ( j = 0, jl = morphNormals[ i ].faceNormals.length; j < jl; j ++ ) {\n\n\t\t\t\t\tmorphNormal.faceNormals.push( morphNormals[ i ].faceNormals[ j ].clone() );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis.morphNormals.push( morphNormal );\n\n\t\t}\n\n\t\t// skin weights\n\n\t\tvar skinWeights = source.skinWeights;\n\n\t\tfor ( i = 0, il = skinWeights.length; i < il; i ++ ) {\n\n\t\t\tthis.skinWeights.push( skinWeights[ i ].clone() );\n\n\t\t}\n\n\t\t// skin indices\n\n\t\tvar skinIndices = source.skinIndices;\n\n\t\tfor ( i = 0, il = skinIndices.length; i < il; i ++ ) {\n\n\t\t\tthis.skinIndices.push( skinIndices[ i ].clone() );\n\n\t\t}\n\n\t\t// line distances\n\n\t\tvar lineDistances = source.lineDistances;\n\n\t\tfor ( i = 0, il = lineDistances.length; i < il; i ++ ) {\n\n\t\t\tthis.lineDistances.push( lineDistances[ i ] );\n\n\t\t}\n\n\t\t// bounding box\n\n\t\tvar boundingBox = source.boundingBox;\n\n\t\tif ( boundingBox !== null ) {\n\n\t\t\tthis.boundingBox = boundingBox.clone();\n\n\t\t}\n\n\t\t// bounding sphere\n\n\t\tvar boundingSphere = source.boundingSphere;\n\n\t\tif ( boundingSphere !== null ) {\n\n\t\t\tthis.boundingSphere = boundingSphere.clone();\n\n\t\t}\n\n\t\t// update flags\n\n\t\tthis.elementsNeedUpdate = source.elementsNeedUpdate;\n\t\tthis.verticesNeedUpdate = source.verticesNeedUpdate;\n\t\tthis.uvsNeedUpdate = source.uvsNeedUpdate;\n\t\tthis.normalsNeedUpdate = source.normalsNeedUpdate;\n\t\tthis.colorsNeedUpdate = source.colorsNeedUpdate;\n\t\tthis.lineDistancesNeedUpdate = source.lineDistancesNeedUpdate;\n\t\tthis.groupsNeedUpdate = source.groupsNeedUpdate;\n\n\t\treturn this;\n\n\t},\n\n\tdispose: function () {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction BufferAttribute( array, itemSize, normalized ) {\n\n\tif ( Array.isArray( array ) ) {\n\n\t\tthrow new TypeError( 'THREE.BufferAttribute: array should be a Typed Array.' );\n\n\t}\n\n\tthis.name = '';\n\n\tthis.array = array;\n\tthis.itemSize = itemSize;\n\tthis.count = array !== undefined ? array.length / itemSize : 0;\n\tthis.normalized = normalized === true;\n\n\tthis.dynamic = false;\n\tthis.updateRange = { offset: 0, count: - 1 };\n\n\tthis.version = 0;\n\n}\n\nObject.defineProperty( BufferAttribute.prototype, 'needsUpdate', {\n\n\tset: function ( value ) {\n\n\t\tif ( value === true ) this.version ++;\n\n\t}\n\n} );\n\nObject.assign( BufferAttribute.prototype, {\n\n\tisBufferAttribute: true,\n\n\tonUploadCallback: function () {},\n\n\tsetArray: function ( array ) {\n\n\t\tif ( Array.isArray( array ) ) {\n\n\t\t\tthrow new TypeError( 'THREE.BufferAttribute: array should be a Typed Array.' );\n\n\t\t}\n\n\t\tthis.count = array !== undefined ? array.length / this.itemSize : 0;\n\t\tthis.array = array;\n\n\t\treturn this;\n\n\t},\n\n\tsetDynamic: function ( value ) {\n\n\t\tthis.dynamic = value;\n\n\t\treturn this;\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tthis.name = source.name;\n\t\tthis.array = new source.array.constructor( source.array );\n\t\tthis.itemSize = source.itemSize;\n\t\tthis.count = source.count;\n\t\tthis.normalized = source.normalized;\n\n\t\tthis.dynamic = source.dynamic;\n\n\t\treturn this;\n\n\t},\n\n\tcopyAt: function ( index1, attribute, index2 ) {\n\n\t\tindex1 *= this.itemSize;\n\t\tindex2 *= attribute.itemSize;\n\n\t\tfor ( var i = 0, l = this.itemSize; i < l; i ++ ) {\n\n\t\t\tthis.array[ index1 + i ] = attribute.array[ index2 + i ];\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tcopyArray: function ( array ) {\n\n\t\tthis.array.set( array );\n\n\t\treturn this;\n\n\t},\n\n\tcopyColorsArray: function ( colors ) {\n\n\t\tvar array = this.array, offset = 0;\n\n\t\tfor ( var i = 0, l = colors.length; i < l; i ++ ) {\n\n\t\t\tvar color = colors[ i ];\n\n\t\t\tif ( color === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.BufferAttribute.copyColorsArray(): color is undefined', i );\n\t\t\t\tcolor = new Color();\n\n\t\t\t}\n\n\t\t\tarray[ offset ++ ] = color.r;\n\t\t\tarray[ offset ++ ] = color.g;\n\t\t\tarray[ offset ++ ] = color.b;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tcopyVector2sArray: function ( vectors ) {\n\n\t\tvar array = this.array, offset = 0;\n\n\t\tfor ( var i = 0, l = vectors.length; i < l; i ++ ) {\n\n\t\t\tvar vector = vectors[ i ];\n\n\t\t\tif ( vector === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.BufferAttribute.copyVector2sArray(): vector is undefined', i );\n\t\t\t\tvector = new Vector2();\n\n\t\t\t}\n\n\t\t\tarray[ offset ++ ] = vector.x;\n\t\t\tarray[ offset ++ ] = vector.y;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tcopyVector3sArray: function ( vectors ) {\n\n\t\tvar array = this.array, offset = 0;\n\n\t\tfor ( var i = 0, l = vectors.length; i < l; i ++ ) {\n\n\t\t\tvar vector = vectors[ i ];\n\n\t\t\tif ( vector === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.BufferAttribute.copyVector3sArray(): vector is undefined', i );\n\t\t\t\tvector = new Vector3();\n\n\t\t\t}\n\n\t\t\tarray[ offset ++ ] = vector.x;\n\t\t\tarray[ offset ++ ] = vector.y;\n\t\t\tarray[ offset ++ ] = vector.z;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tcopyVector4sArray: function ( vectors ) {\n\n\t\tvar array = this.array, offset = 0;\n\n\t\tfor ( var i = 0, l = vectors.length; i < l; i ++ ) {\n\n\t\t\tvar vector = vectors[ i ];\n\n\t\t\tif ( vector === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.BufferAttribute.copyVector4sArray(): vector is undefined', i );\n\t\t\t\tvector = new Vector4();\n\n\t\t\t}\n\n\t\t\tarray[ offset ++ ] = vector.x;\n\t\t\tarray[ offset ++ ] = vector.y;\n\t\t\tarray[ offset ++ ] = vector.z;\n\t\t\tarray[ offset ++ ] = vector.w;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tset: function ( value, offset ) {\n\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tthis.array.set( value, offset );\n\n\t\treturn this;\n\n\t},\n\n\tgetX: function ( index ) {\n\n\t\treturn this.array[ index * this.itemSize ];\n\n\t},\n\n\tsetX: function ( index, x ) {\n\n\t\tthis.array[ index * this.itemSize ] = x;\n\n\t\treturn this;\n\n\t},\n\n\tgetY: function ( index ) {\n\n\t\treturn this.array[ index * this.itemSize + 1 ];\n\n\t},\n\n\tsetY: function ( index, y ) {\n\n\t\tthis.array[ index * this.itemSize + 1 ] = y;\n\n\t\treturn this;\n\n\t},\n\n\tgetZ: function ( index ) {\n\n\t\treturn this.array[ index * this.itemSize + 2 ];\n\n\t},\n\n\tsetZ: function ( index, z ) {\n\n\t\tthis.array[ index * this.itemSize + 2 ] = z;\n\n\t\treturn this;\n\n\t},\n\n\tgetW: function ( index ) {\n\n\t\treturn this.array[ index * this.itemSize + 3 ];\n\n\t},\n\n\tsetW: function ( index, w ) {\n\n\t\tthis.array[ index * this.itemSize + 3 ] = w;\n\n\t\treturn this;\n\n\t},\n\n\tsetXY: function ( index, x, y ) {\n\n\t\tindex *= this.itemSize;\n\n\t\tthis.array[ index + 0 ] = x;\n\t\tthis.array[ index + 1 ] = y;\n\n\t\treturn this;\n\n\t},\n\n\tsetXYZ: function ( index, x, y, z ) {\n\n\t\tindex *= this.itemSize;\n\n\t\tthis.array[ index + 0 ] = x;\n\t\tthis.array[ index + 1 ] = y;\n\t\tthis.array[ index + 2 ] = z;\n\n\t\treturn this;\n\n\t},\n\n\tsetXYZW: function ( index, x, y, z, w ) {\n\n\t\tindex *= this.itemSize;\n\n\t\tthis.array[ index + 0 ] = x;\n\t\tthis.array[ index + 1 ] = y;\n\t\tthis.array[ index + 2 ] = z;\n\t\tthis.array[ index + 3 ] = w;\n\n\t\treturn this;\n\n\t},\n\n\tonUpload: function ( callback ) {\n\n\t\tthis.onUploadCallback = callback;\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.array, this.itemSize ).copy( this );\n\n\t}\n\n} );\n\n//\n\nfunction Int8BufferAttribute( array, itemSize, normalized ) {\n\n\tBufferAttribute.call( this, new Int8Array( array ), itemSize, normalized );\n\n}\n\nInt8BufferAttribute.prototype = Object.create( BufferAttribute.prototype );\nInt8BufferAttribute.prototype.constructor = Int8BufferAttribute;\n\n\nfunction Uint8BufferAttribute( array, itemSize, normalized ) {\n\n\tBufferAttribute.call( this, new Uint8Array( array ), itemSize, normalized );\n\n}\n\nUint8BufferAttribute.prototype = Object.create( BufferAttribute.prototype );\nUint8BufferAttribute.prototype.constructor = Uint8BufferAttribute;\n\n\nfunction Uint8ClampedBufferAttribute( array, itemSize, normalized ) {\n\n\tBufferAttribute.call( this, new Uint8ClampedArray( array ), itemSize, normalized );\n\n}\n\nUint8ClampedBufferAttribute.prototype = Object.create( BufferAttribute.prototype );\nUint8ClampedBufferAttribute.prototype.constructor = Uint8ClampedBufferAttribute;\n\n\nfunction Int16BufferAttribute( array, itemSize, normalized ) {\n\n\tBufferAttribute.call( this, new Int16Array( array ), itemSize, normalized );\n\n}\n\nInt16BufferAttribute.prototype = Object.create( BufferAttribute.prototype );\nInt16BufferAttribute.prototype.constructor = Int16BufferAttribute;\n\n\nfunction Uint16BufferAttribute( array, itemSize, normalized ) {\n\n\tBufferAttribute.call( this, new Uint16Array( array ), itemSize, normalized );\n\n}\n\nUint16BufferAttribute.prototype = Object.create( BufferAttribute.prototype );\nUint16BufferAttribute.prototype.constructor = Uint16BufferAttribute;\n\n\nfunction Int32BufferAttribute( array, itemSize, normalized ) {\n\n\tBufferAttribute.call( this, new Int32Array( array ), itemSize, normalized );\n\n}\n\nInt32BufferAttribute.prototype = Object.create( BufferAttribute.prototype );\nInt32BufferAttribute.prototype.constructor = Int32BufferAttribute;\n\n\nfunction Uint32BufferAttribute( array, itemSize, normalized ) {\n\n\tBufferAttribute.call( this, new Uint32Array( array ), itemSize, normalized );\n\n}\n\nUint32BufferAttribute.prototype = Object.create( BufferAttribute.prototype );\nUint32BufferAttribute.prototype.constructor = Uint32BufferAttribute;\n\n\nfunction Float32BufferAttribute( array, itemSize, normalized ) {\n\n\tBufferAttribute.call( this, new Float32Array( array ), itemSize, normalized );\n\n}\n\nFloat32BufferAttribute.prototype = Object.create( BufferAttribute.prototype );\nFloat32BufferAttribute.prototype.constructor = Float32BufferAttribute;\n\n\nfunction Float64BufferAttribute( array, itemSize, normalized ) {\n\n\tBufferAttribute.call( this, new Float64Array( array ), itemSize, normalized );\n\n}\n\nFloat64BufferAttribute.prototype = Object.create( BufferAttribute.prototype );\nFloat64BufferAttribute.prototype.constructor = Float64BufferAttribute;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction DirectGeometry() {\n\n\tthis.vertices = [];\n\tthis.normals = [];\n\tthis.colors = [];\n\tthis.uvs = [];\n\tthis.uvs2 = [];\n\n\tthis.groups = [];\n\n\tthis.morphTargets = {};\n\n\tthis.skinWeights = [];\n\tthis.skinIndices = [];\n\n\t// this.lineDistances = [];\n\n\tthis.boundingBox = null;\n\tthis.boundingSphere = null;\n\n\t// update flags\n\n\tthis.verticesNeedUpdate = false;\n\tthis.normalsNeedUpdate = false;\n\tthis.colorsNeedUpdate = false;\n\tthis.uvsNeedUpdate = false;\n\tthis.groupsNeedUpdate = false;\n\n}\n\nObject.assign( DirectGeometry.prototype, {\n\n\tcomputeGroups: function ( geometry ) {\n\n\t\tvar group;\n\t\tvar groups = [];\n\t\tvar materialIndex = undefined;\n\n\t\tvar faces = geometry.faces;\n\n\t\tfor ( var i = 0; i < faces.length; i ++ ) {\n\n\t\t\tvar face = faces[ i ];\n\n\t\t\t// materials\n\n\t\t\tif ( face.materialIndex !== materialIndex ) {\n\n\t\t\t\tmaterialIndex = face.materialIndex;\n\n\t\t\t\tif ( group !== undefined ) {\n\n\t\t\t\t\tgroup.count = ( i * 3 ) - group.start;\n\t\t\t\t\tgroups.push( group );\n\n\t\t\t\t}\n\n\t\t\t\tgroup = {\n\t\t\t\t\tstart: i * 3,\n\t\t\t\t\tmaterialIndex: materialIndex\n\t\t\t\t};\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( group !== undefined ) {\n\n\t\t\tgroup.count = ( i * 3 ) - group.start;\n\t\t\tgroups.push( group );\n\n\t\t}\n\n\t\tthis.groups = groups;\n\n\t},\n\n\tfromGeometry: function ( geometry ) {\n\n\t\tvar faces = geometry.faces;\n\t\tvar vertices = geometry.vertices;\n\t\tvar faceVertexUvs = geometry.faceVertexUvs;\n\n\t\tvar hasFaceVertexUv = faceVertexUvs[ 0 ] && faceVertexUvs[ 0 ].length > 0;\n\t\tvar hasFaceVertexUv2 = faceVertexUvs[ 1 ] && faceVertexUvs[ 1 ].length > 0;\n\n\t\t// morphs\n\n\t\tvar morphTargets = geometry.morphTargets;\n\t\tvar morphTargetsLength = morphTargets.length;\n\n\t\tvar morphTargetsPosition;\n\n\t\tif ( morphTargetsLength > 0 ) {\n\n\t\t\tmorphTargetsPosition = [];\n\n\t\t\tfor ( var i = 0; i < morphTargetsLength; i ++ ) {\n\n\t\t\t\tmorphTargetsPosition[ i ] = [];\n\n\t\t\t}\n\n\t\t\tthis.morphTargets.position = morphTargetsPosition;\n\n\t\t}\n\n\t\tvar morphNormals = geometry.morphNormals;\n\t\tvar morphNormalsLength = morphNormals.length;\n\n\t\tvar morphTargetsNormal;\n\n\t\tif ( morphNormalsLength > 0 ) {\n\n\t\t\tmorphTargetsNormal = [];\n\n\t\t\tfor ( var i = 0; i < morphNormalsLength; i ++ ) {\n\n\t\t\t\tmorphTargetsNormal[ i ] = [];\n\n\t\t\t}\n\n\t\t\tthis.morphTargets.normal = morphTargetsNormal;\n\n\t\t}\n\n\t\t// skins\n\n\t\tvar skinIndices = geometry.skinIndices;\n\t\tvar skinWeights = geometry.skinWeights;\n\n\t\tvar hasSkinIndices = skinIndices.length === vertices.length;\n\t\tvar hasSkinWeights = skinWeights.length === vertices.length;\n\n\t\t//\n\n\t\tfor ( var i = 0; i < faces.length; i ++ ) {\n\n\t\t\tvar face = faces[ i ];\n\n\t\t\tthis.vertices.push( vertices[ face.a ], vertices[ face.b ], vertices[ face.c ] );\n\n\t\t\tvar vertexNormals = face.vertexNormals;\n\n\t\t\tif ( vertexNormals.length === 3 ) {\n\n\t\t\t\tthis.normals.push( vertexNormals[ 0 ], vertexNormals[ 1 ], vertexNormals[ 2 ] );\n\n\t\t\t} else {\n\n\t\t\t\tvar normal = face.normal;\n\n\t\t\t\tthis.normals.push( normal, normal, normal );\n\n\t\t\t}\n\n\t\t\tvar vertexColors = face.vertexColors;\n\n\t\t\tif ( vertexColors.length === 3 ) {\n\n\t\t\t\tthis.colors.push( vertexColors[ 0 ], vertexColors[ 1 ], vertexColors[ 2 ] );\n\n\t\t\t} else {\n\n\t\t\t\tvar color = face.color;\n\n\t\t\t\tthis.colors.push( color, color, color );\n\n\t\t\t}\n\n\t\t\tif ( hasFaceVertexUv === true ) {\n\n\t\t\t\tvar vertexUvs = faceVertexUvs[ 0 ][ i ];\n\n\t\t\t\tif ( vertexUvs !== undefined ) {\n\n\t\t\t\t\tthis.uvs.push( vertexUvs[ 0 ], vertexUvs[ 1 ], vertexUvs[ 2 ] );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.warn( 'THREE.DirectGeometry.fromGeometry(): Undefined vertexUv ', i );\n\n\t\t\t\t\tthis.uvs.push( new Vector2(), new Vector2(), new Vector2() );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( hasFaceVertexUv2 === true ) {\n\n\t\t\t\tvar vertexUvs = faceVertexUvs[ 1 ][ i ];\n\n\t\t\t\tif ( vertexUvs !== undefined ) {\n\n\t\t\t\t\tthis.uvs2.push( vertexUvs[ 0 ], vertexUvs[ 1 ], vertexUvs[ 2 ] );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.warn( 'THREE.DirectGeometry.fromGeometry(): Undefined vertexUv2 ', i );\n\n\t\t\t\t\tthis.uvs2.push( new Vector2(), new Vector2(), new Vector2() );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// morphs\n\n\t\t\tfor ( var j = 0; j < morphTargetsLength; j ++ ) {\n\n\t\t\t\tvar morphTarget = morphTargets[ j ].vertices;\n\n\t\t\t\tmorphTargetsPosition[ j ].push( morphTarget[ face.a ], morphTarget[ face.b ], morphTarget[ face.c ] );\n\n\t\t\t}\n\n\t\t\tfor ( var j = 0; j < morphNormalsLength; j ++ ) {\n\n\t\t\t\tvar morphNormal = morphNormals[ j ].vertexNormals[ i ];\n\n\t\t\t\tmorphTargetsNormal[ j ].push( morphNormal.a, morphNormal.b, morphNormal.c );\n\n\t\t\t}\n\n\t\t\t// skins\n\n\t\t\tif ( hasSkinIndices ) {\n\n\t\t\t\tthis.skinIndices.push( skinIndices[ face.a ], skinIndices[ face.b ], skinIndices[ face.c ] );\n\n\t\t\t}\n\n\t\t\tif ( hasSkinWeights ) {\n\n\t\t\t\tthis.skinWeights.push( skinWeights[ face.a ], skinWeights[ face.b ], skinWeights[ face.c ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis.computeGroups( geometry );\n\n\t\tthis.verticesNeedUpdate = geometry.verticesNeedUpdate;\n\t\tthis.normalsNeedUpdate = geometry.normalsNeedUpdate;\n\t\tthis.colorsNeedUpdate = geometry.colorsNeedUpdate;\n\t\tthis.uvsNeedUpdate = geometry.uvsNeedUpdate;\n\t\tthis.groupsNeedUpdate = geometry.groupsNeedUpdate;\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction arrayMax( array ) {\n\n\tif ( array.length === 0 ) return - Infinity;\n\n\tvar max = array[ 0 ];\n\n\tfor ( var i = 1, l = array.length; i < l; ++ i ) {\n\n\t\tif ( array[ i ] > max ) max = array[ i ];\n\n\t}\n\n\treturn max;\n\n}\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author mrdoob / http://mrdoob.com/\n */\n\nvar bufferGeometryId = 1; // BufferGeometry uses odd numbers as Id\n\nfunction BufferGeometry() {\n\n\tObject.defineProperty( this, 'id', { value: bufferGeometryId += 2 } );\n\n\tthis.uuid = _Math.generateUUID();\n\n\tthis.name = '';\n\tthis.type = 'BufferGeometry';\n\n\tthis.index = null;\n\tthis.attributes = {};\n\n\tthis.morphAttributes = {};\n\n\tthis.groups = [];\n\n\tthis.boundingBox = null;\n\tthis.boundingSphere = null;\n\n\tthis.drawRange = { start: 0, count: Infinity };\n\n}\n\nBufferGeometry.prototype = Object.assign( Object.create( EventDispatcher.prototype ), {\n\n\tconstructor: BufferGeometry,\n\n\tisBufferGeometry: true,\n\n\tgetIndex: function () {\n\n\t\treturn this.index;\n\n\t},\n\n\tsetIndex: function ( index ) {\n\n\t\tif ( Array.isArray( index ) ) {\n\n\t\t\tthis.index = new ( arrayMax( index ) > 65535 ? Uint32BufferAttribute : Uint16BufferAttribute )( index, 1 );\n\n\t\t} else {\n\n\t\t\tthis.index = index;\n\n\t\t}\n\n\t},\n\n\taddAttribute: function ( name, attribute ) {\n\n\t\tif ( ! ( attribute && attribute.isBufferAttribute ) && ! ( attribute && attribute.isInterleavedBufferAttribute ) ) {\n\n\t\t\tconsole.warn( 'THREE.BufferGeometry: .addAttribute() now expects ( name, attribute ).' );\n\n\t\t\tthis.addAttribute( name, new BufferAttribute( arguments[ 1 ], arguments[ 2 ] ) );\n\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( name === 'index' ) {\n\n\t\t\tconsole.warn( 'THREE.BufferGeometry.addAttribute: Use .setIndex() for index attribute.' );\n\t\t\tthis.setIndex( attribute );\n\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis.attributes[ name ] = attribute;\n\n\t\treturn this;\n\n\t},\n\n\tgetAttribute: function ( name ) {\n\n\t\treturn this.attributes[ name ];\n\n\t},\n\n\tremoveAttribute: function ( name ) {\n\n\t\tdelete this.attributes[ name ];\n\n\t\treturn this;\n\n\t},\n\n\taddGroup: function ( start, count, materialIndex ) {\n\n\t\tthis.groups.push( {\n\n\t\t\tstart: start,\n\t\t\tcount: count,\n\t\t\tmaterialIndex: materialIndex !== undefined ? materialIndex : 0\n\n\t\t} );\n\n\t},\n\n\tclearGroups: function () {\n\n\t\tthis.groups = [];\n\n\t},\n\n\tsetDrawRange: function ( start, count ) {\n\n\t\tthis.drawRange.start = start;\n\t\tthis.drawRange.count = count;\n\n\t},\n\n\tapplyMatrix: function ( matrix ) {\n\n\t\tvar position = this.attributes.position;\n\n\t\tif ( position !== undefined ) {\n\n\t\t\tmatrix.applyToBufferAttribute( position );\n\t\t\tposition.needsUpdate = true;\n\n\t\t}\n\n\t\tvar normal = this.attributes.normal;\n\n\t\tif ( normal !== undefined ) {\n\n\t\t\tvar normalMatrix = new Matrix3().getNormalMatrix( matrix );\n\n\t\t\tnormalMatrix.applyToBufferAttribute( normal );\n\t\t\tnormal.needsUpdate = true;\n\n\t\t}\n\n\t\tif ( this.boundingBox !== null ) {\n\n\t\t\tthis.computeBoundingBox();\n\n\t\t}\n\n\t\tif ( this.boundingSphere !== null ) {\n\n\t\t\tthis.computeBoundingSphere();\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\trotateX: function () {\n\n\t\t// rotate geometry around world x-axis\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function rotateX( angle ) {\n\n\t\t\tm1.makeRotationX( angle );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\trotateY: function () {\n\n\t\t// rotate geometry around world y-axis\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function rotateY( angle ) {\n\n\t\t\tm1.makeRotationY( angle );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\trotateZ: function () {\n\n\t\t// rotate geometry around world z-axis\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function rotateZ( angle ) {\n\n\t\t\tm1.makeRotationZ( angle );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\ttranslate: function () {\n\n\t\t// translate geometry\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function translate( x, y, z ) {\n\n\t\t\tm1.makeTranslation( x, y, z );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tscale: function () {\n\n\t\t// scale geometry\n\n\t\tvar m1 = new Matrix4();\n\n\t\treturn function scale( x, y, z ) {\n\n\t\t\tm1.makeScale( x, y, z );\n\n\t\t\tthis.applyMatrix( m1 );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tlookAt: function () {\n\n\t\tvar obj = new Object3D();\n\n\t\treturn function lookAt( vector ) {\n\n\t\t\tobj.lookAt( vector );\n\n\t\t\tobj.updateMatrix();\n\n\t\t\tthis.applyMatrix( obj.matrix );\n\n\t\t};\n\n\t}(),\n\n\tcenter: function () {\n\n\t\tvar offset = new Vector3();\n\n\t\treturn function center() {\n\n\t\t\tthis.computeBoundingBox();\n\n\t\t\tthis.boundingBox.getCenter( offset ).negate();\n\n\t\t\tthis.translate( offset.x, offset.y, offset.z );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tsetFromObject: function ( object ) {\n\n\t\t// console.log( 'THREE.BufferGeometry.setFromObject(). Converting', object, this );\n\n\t\tvar geometry = object.geometry;\n\n\t\tif ( object.isPoints || object.isLine ) {\n\n\t\t\tvar positions = new Float32BufferAttribute( geometry.vertices.length * 3, 3 );\n\t\t\tvar colors = new Float32BufferAttribute( geometry.colors.length * 3, 3 );\n\n\t\t\tthis.addAttribute( 'position', positions.copyVector3sArray( geometry.vertices ) );\n\t\t\tthis.addAttribute( 'color', colors.copyColorsArray( geometry.colors ) );\n\n\t\t\tif ( geometry.lineDistances && geometry.lineDistances.length === geometry.vertices.length ) {\n\n\t\t\t\tvar lineDistances = new Float32BufferAttribute( geometry.lineDistances.length, 1 );\n\n\t\t\t\tthis.addAttribute( 'lineDistance', lineDistances.copyArray( geometry.lineDistances ) );\n\n\t\t\t}\n\n\t\t\tif ( geometry.boundingSphere !== null ) {\n\n\t\t\t\tthis.boundingSphere = geometry.boundingSphere.clone();\n\n\t\t\t}\n\n\t\t\tif ( geometry.boundingBox !== null ) {\n\n\t\t\t\tthis.boundingBox = geometry.boundingBox.clone();\n\n\t\t\t}\n\n\t\t} else if ( object.isMesh ) {\n\n\t\t\tif ( geometry && geometry.isGeometry ) {\n\n\t\t\t\tthis.fromGeometry( geometry );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tsetFromPoints: function ( points ) {\n\n\t\tvar position = [];\n\n\t\tfor ( var i = 0, l = points.length; i < l; i ++ ) {\n\n\t\t\tvar point = points[ i ];\n\t\t\tposition.push( point.x, point.y, point.z || 0 );\n\n\t\t}\n\n\t\tthis.addAttribute( 'position', new Float32BufferAttribute( position, 3 ) );\n\n\t\treturn this;\n\n\t},\n\n\tupdateFromObject: function ( object ) {\n\n\t\tvar geometry = object.geometry;\n\n\t\tif ( object.isMesh ) {\n\n\t\t\tvar direct = geometry.__directGeometry;\n\n\t\t\tif ( geometry.elementsNeedUpdate === true ) {\n\n\t\t\t\tdirect = undefined;\n\t\t\t\tgeometry.elementsNeedUpdate = false;\n\n\t\t\t}\n\n\t\t\tif ( direct === undefined ) {\n\n\t\t\t\treturn this.fromGeometry( geometry );\n\n\t\t\t}\n\n\t\t\tdirect.verticesNeedUpdate = geometry.verticesNeedUpdate;\n\t\t\tdirect.normalsNeedUpdate = geometry.normalsNeedUpdate;\n\t\t\tdirect.colorsNeedUpdate = geometry.colorsNeedUpdate;\n\t\t\tdirect.uvsNeedUpdate = geometry.uvsNeedUpdate;\n\t\t\tdirect.groupsNeedUpdate = geometry.groupsNeedUpdate;\n\n\t\t\tgeometry.verticesNeedUpdate = false;\n\t\t\tgeometry.normalsNeedUpdate = false;\n\t\t\tgeometry.colorsNeedUpdate = false;\n\t\t\tgeometry.uvsNeedUpdate = false;\n\t\t\tgeometry.groupsNeedUpdate = false;\n\n\t\t\tgeometry = direct;\n\n\t\t}\n\n\t\tvar attribute;\n\n\t\tif ( geometry.verticesNeedUpdate === true ) {\n\n\t\t\tattribute = this.attributes.position;\n\n\t\t\tif ( attribute !== undefined ) {\n\n\t\t\t\tattribute.copyVector3sArray( geometry.vertices );\n\t\t\t\tattribute.needsUpdate = true;\n\n\t\t\t}\n\n\t\t\tgeometry.verticesNeedUpdate = false;\n\n\t\t}\n\n\t\tif ( geometry.normalsNeedUpdate === true ) {\n\n\t\t\tattribute = this.attributes.normal;\n\n\t\t\tif ( attribute !== undefined ) {\n\n\t\t\t\tattribute.copyVector3sArray( geometry.normals );\n\t\t\t\tattribute.needsUpdate = true;\n\n\t\t\t}\n\n\t\t\tgeometry.normalsNeedUpdate = false;\n\n\t\t}\n\n\t\tif ( geometry.colorsNeedUpdate === true ) {\n\n\t\t\tattribute = this.attributes.color;\n\n\t\t\tif ( attribute !== undefined ) {\n\n\t\t\t\tattribute.copyColorsArray( geometry.colors );\n\t\t\t\tattribute.needsUpdate = true;\n\n\t\t\t}\n\n\t\t\tgeometry.colorsNeedUpdate = false;\n\n\t\t}\n\n\t\tif ( geometry.uvsNeedUpdate ) {\n\n\t\t\tattribute = this.attributes.uv;\n\n\t\t\tif ( attribute !== undefined ) {\n\n\t\t\t\tattribute.copyVector2sArray( geometry.uvs );\n\t\t\t\tattribute.needsUpdate = true;\n\n\t\t\t}\n\n\t\t\tgeometry.uvsNeedUpdate = false;\n\n\t\t}\n\n\t\tif ( geometry.lineDistancesNeedUpdate ) {\n\n\t\t\tattribute = this.attributes.lineDistance;\n\n\t\t\tif ( attribute !== undefined ) {\n\n\t\t\t\tattribute.copyArray( geometry.lineDistances );\n\t\t\t\tattribute.needsUpdate = true;\n\n\t\t\t}\n\n\t\t\tgeometry.lineDistancesNeedUpdate = false;\n\n\t\t}\n\n\t\tif ( geometry.groupsNeedUpdate ) {\n\n\t\t\tgeometry.computeGroups( object.geometry );\n\t\t\tthis.groups = geometry.groups;\n\n\t\t\tgeometry.groupsNeedUpdate = false;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tfromGeometry: function ( geometry ) {\n\n\t\tgeometry.__directGeometry = new DirectGeometry().fromGeometry( geometry );\n\n\t\treturn this.fromDirectGeometry( geometry.__directGeometry );\n\n\t},\n\n\tfromDirectGeometry: function ( geometry ) {\n\n\t\tvar positions = new Float32Array( geometry.vertices.length * 3 );\n\t\tthis.addAttribute( 'position', new BufferAttribute( positions, 3 ).copyVector3sArray( geometry.vertices ) );\n\n\t\tif ( geometry.normals.length > 0 ) {\n\n\t\t\tvar normals = new Float32Array( geometry.normals.length * 3 );\n\t\t\tthis.addAttribute( 'normal', new BufferAttribute( normals, 3 ).copyVector3sArray( geometry.normals ) );\n\n\t\t}\n\n\t\tif ( geometry.colors.length > 0 ) {\n\n\t\t\tvar colors = new Float32Array( geometry.colors.length * 3 );\n\t\t\tthis.addAttribute( 'color', new BufferAttribute( colors, 3 ).copyColorsArray( geometry.colors ) );\n\n\t\t}\n\n\t\tif ( geometry.uvs.length > 0 ) {\n\n\t\t\tvar uvs = new Float32Array( geometry.uvs.length * 2 );\n\t\t\tthis.addAttribute( 'uv', new BufferAttribute( uvs, 2 ).copyVector2sArray( geometry.uvs ) );\n\n\t\t}\n\n\t\tif ( geometry.uvs2.length > 0 ) {\n\n\t\t\tvar uvs2 = new Float32Array( geometry.uvs2.length * 2 );\n\t\t\tthis.addAttribute( 'uv2', new BufferAttribute( uvs2, 2 ).copyVector2sArray( geometry.uvs2 ) );\n\n\t\t}\n\n\t\t// groups\n\n\t\tthis.groups = geometry.groups;\n\n\t\t// morphs\n\n\t\tfor ( var name in geometry.morphTargets ) {\n\n\t\t\tvar array = [];\n\t\t\tvar morphTargets = geometry.morphTargets[ name ];\n\n\t\t\tfor ( var i = 0, l = morphTargets.length; i < l; i ++ ) {\n\n\t\t\t\tvar morphTarget = morphTargets[ i ];\n\n\t\t\t\tvar attribute = new Float32BufferAttribute( morphTarget.length * 3, 3 );\n\n\t\t\t\tarray.push( attribute.copyVector3sArray( morphTarget ) );\n\n\t\t\t}\n\n\t\t\tthis.morphAttributes[ name ] = array;\n\n\t\t}\n\n\t\t// skinning\n\n\t\tif ( geometry.skinIndices.length > 0 ) {\n\n\t\t\tvar skinIndices = new Float32BufferAttribute( geometry.skinIndices.length * 4, 4 );\n\t\t\tthis.addAttribute( 'skinIndex', skinIndices.copyVector4sArray( geometry.skinIndices ) );\n\n\t\t}\n\n\t\tif ( geometry.skinWeights.length > 0 ) {\n\n\t\t\tvar skinWeights = new Float32BufferAttribute( geometry.skinWeights.length * 4, 4 );\n\t\t\tthis.addAttribute( 'skinWeight', skinWeights.copyVector4sArray( geometry.skinWeights ) );\n\n\t\t}\n\n\t\t//\n\n\t\tif ( geometry.boundingSphere !== null ) {\n\n\t\t\tthis.boundingSphere = geometry.boundingSphere.clone();\n\n\t\t}\n\n\t\tif ( geometry.boundingBox !== null ) {\n\n\t\t\tthis.boundingBox = geometry.boundingBox.clone();\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tcomputeBoundingBox: function () {\n\n\t\tif ( this.boundingBox === null ) {\n\n\t\t\tthis.boundingBox = new Box3();\n\n\t\t}\n\n\t\tvar position = this.attributes.position;\n\n\t\tif ( position !== undefined ) {\n\n\t\t\tthis.boundingBox.setFromBufferAttribute( position );\n\n\t\t} else {\n\n\t\t\tthis.boundingBox.makeEmpty();\n\n\t\t}\n\n\t\tif ( isNaN( this.boundingBox.min.x ) || isNaN( this.boundingBox.min.y ) || isNaN( this.boundingBox.min.z ) ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometry.computeBoundingBox: Computed min/max have NaN values. The \"position\" attribute is likely to have NaN values.', this );\n\n\t\t}\n\n\t},\n\n\tcomputeBoundingSphere: function () {\n\n\t\tvar box = new Box3();\n\t\tvar vector = new Vector3();\n\n\t\treturn function computeBoundingSphere() {\n\n\t\t\tif ( this.boundingSphere === null ) {\n\n\t\t\t\tthis.boundingSphere = new Sphere();\n\n\t\t\t}\n\n\t\t\tvar position = this.attributes.position;\n\n\t\t\tif ( position ) {\n\n\t\t\t\tvar center = this.boundingSphere.center;\n\n\t\t\t\tbox.setFromBufferAttribute( position );\n\t\t\t\tbox.getCenter( center );\n\n\t\t\t\t// hoping to find a boundingSphere with a radius smaller than the\n\t\t\t\t// boundingSphere of the boundingBox: sqrt(3) smaller in the best case\n\n\t\t\t\tvar maxRadiusSq = 0;\n\n\t\t\t\tfor ( var i = 0, il = position.count; i < il; i ++ ) {\n\n\t\t\t\t\tvector.x = position.getX( i );\n\t\t\t\t\tvector.y = position.getY( i );\n\t\t\t\t\tvector.z = position.getZ( i );\n\t\t\t\t\tmaxRadiusSq = Math.max( maxRadiusSq, center.distanceToSquared( vector ) );\n\n\t\t\t\t}\n\n\t\t\t\tthis.boundingSphere.radius = Math.sqrt( maxRadiusSq );\n\n\t\t\t\tif ( isNaN( this.boundingSphere.radius ) ) {\n\n\t\t\t\t\tconsole.error( 'THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The \"position\" attribute is likely to have NaN values.', this );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t};\n\n\t}(),\n\n\tcomputeFaceNormals: function () {\n\n\t\t// backwards compatibility\n\n\t},\n\n\tcomputeVertexNormals: function () {\n\n\t\tvar index = this.index;\n\t\tvar attributes = this.attributes;\n\t\tvar groups = this.groups;\n\n\t\tif ( attributes.position ) {\n\n\t\t\tvar positions = attributes.position.array;\n\n\t\t\tif ( attributes.normal === undefined ) {\n\n\t\t\t\tthis.addAttribute( 'normal', new BufferAttribute( new Float32Array( positions.length ), 3 ) );\n\n\t\t\t} else {\n\n\t\t\t\t// reset existing normals to zero\n\n\t\t\t\tvar array = attributes.normal.array;\n\n\t\t\t\tfor ( var i = 0, il = array.length; i < il; i ++ ) {\n\n\t\t\t\t\tarray[ i ] = 0;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tvar normals = attributes.normal.array;\n\n\t\t\tvar vA, vB, vC;\n\t\t\tvar pA = new Vector3(), pB = new Vector3(), pC = new Vector3();\n\t\t\tvar cb = new Vector3(), ab = new Vector3();\n\n\t\t\t// indexed elements\n\n\t\t\tif ( index ) {\n\n\t\t\t\tvar indices = index.array;\n\n\t\t\t\tif ( groups.length === 0 ) {\n\n\t\t\t\t\tthis.addGroup( 0, indices.length );\n\n\t\t\t\t}\n\n\t\t\t\tfor ( var j = 0, jl = groups.length; j < jl; ++ j ) {\n\n\t\t\t\t\tvar group = groups[ j ];\n\n\t\t\t\t\tvar start = group.start;\n\t\t\t\t\tvar count = group.count;\n\n\t\t\t\t\tfor ( var i = start, il = start + count; i < il; i += 3 ) {\n\n\t\t\t\t\t\tvA = indices[ i + 0 ] * 3;\n\t\t\t\t\t\tvB = indices[ i + 1 ] * 3;\n\t\t\t\t\t\tvC = indices[ i + 2 ] * 3;\n\n\t\t\t\t\t\tpA.fromArray( positions, vA );\n\t\t\t\t\t\tpB.fromArray( positions, vB );\n\t\t\t\t\t\tpC.fromArray( positions, vC );\n\n\t\t\t\t\t\tcb.subVectors( pC, pB );\n\t\t\t\t\t\tab.subVectors( pA, pB );\n\t\t\t\t\t\tcb.cross( ab );\n\n\t\t\t\t\t\tnormals[ vA ] += cb.x;\n\t\t\t\t\t\tnormals[ vA + 1 ] += cb.y;\n\t\t\t\t\t\tnormals[ vA + 2 ] += cb.z;\n\n\t\t\t\t\t\tnormals[ vB ] += cb.x;\n\t\t\t\t\t\tnormals[ vB + 1 ] += cb.y;\n\t\t\t\t\t\tnormals[ vB + 2 ] += cb.z;\n\n\t\t\t\t\t\tnormals[ vC ] += cb.x;\n\t\t\t\t\t\tnormals[ vC + 1 ] += cb.y;\n\t\t\t\t\t\tnormals[ vC + 2 ] += cb.z;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// non-indexed elements (unconnected triangle soup)\n\n\t\t\t\tfor ( var i = 0, il = positions.length; i < il; i += 9 ) {\n\n\t\t\t\t\tpA.fromArray( positions, i );\n\t\t\t\t\tpB.fromArray( positions, i + 3 );\n\t\t\t\t\tpC.fromArray( positions, i + 6 );\n\n\t\t\t\t\tcb.subVectors( pC, pB );\n\t\t\t\t\tab.subVectors( pA, pB );\n\t\t\t\t\tcb.cross( ab );\n\n\t\t\t\t\tnormals[ i ] = cb.x;\n\t\t\t\t\tnormals[ i + 1 ] = cb.y;\n\t\t\t\t\tnormals[ i + 2 ] = cb.z;\n\n\t\t\t\t\tnormals[ i + 3 ] = cb.x;\n\t\t\t\t\tnormals[ i + 4 ] = cb.y;\n\t\t\t\t\tnormals[ i + 5 ] = cb.z;\n\n\t\t\t\t\tnormals[ i + 6 ] = cb.x;\n\t\t\t\t\tnormals[ i + 7 ] = cb.y;\n\t\t\t\t\tnormals[ i + 8 ] = cb.z;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis.normalizeNormals();\n\n\t\t\tattributes.normal.needsUpdate = true;\n\n\t\t}\n\n\t},\n\n\tmerge: function ( geometry, offset ) {\n\n\t\tif ( ! ( geometry && geometry.isBufferGeometry ) ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.', geometry );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( offset === undefined ) {\n\n\t\t\toffset = 0;\n\n\t\t\tconsole.warn(\n\t\t\t\t'THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset=0. '\n\t\t\t\t+ 'Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge.'\n\t\t\t);\n\n\t\t}\n\n\t\tvar attributes = this.attributes;\n\n\t\tfor ( var key in attributes ) {\n\n\t\t\tif ( geometry.attributes[ key ] === undefined ) continue;\n\n\t\t\tvar attribute1 = attributes[ key ];\n\t\t\tvar attributeArray1 = attribute1.array;\n\n\t\t\tvar attribute2 = geometry.attributes[ key ];\n\t\t\tvar attributeArray2 = attribute2.array;\n\n\t\t\tvar attributeSize = attribute2.itemSize;\n\n\t\t\tfor ( var i = 0, j = attributeSize * offset; i < attributeArray2.length; i ++, j ++ ) {\n\n\t\t\t\tattributeArray1[ j ] = attributeArray2[ i ];\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tnormalizeNormals: function () {\n\n\t\tvar vector = new Vector3();\n\n\t\treturn function normalizeNormals() {\n\n\t\t\tvar normals = this.attributes.normal;\n\n\t\t\tfor ( var i = 0, il = normals.count; i < il; i ++ ) {\n\n\t\t\t\tvector.x = normals.getX( i );\n\t\t\t\tvector.y = normals.getY( i );\n\t\t\t\tvector.z = normals.getZ( i );\n\n\t\t\t\tvector.normalize();\n\n\t\t\t\tnormals.setXYZ( i, vector.x, vector.y, vector.z );\n\n\t\t\t}\n\n\t\t};\n\n\t}(),\n\n\ttoNonIndexed: function () {\n\n\t\tif ( this.index === null ) {\n\n\t\t\tconsole.warn( 'THREE.BufferGeometry.toNonIndexed(): Geometry is already non-indexed.' );\n\t\t\treturn this;\n\n\t\t}\n\n\t\tvar geometry2 = new BufferGeometry();\n\n\t\tvar indices = this.index.array;\n\t\tvar attributes = this.attributes;\n\n\t\tfor ( var name in attributes ) {\n\n\t\t\tvar attribute = attributes[ name ];\n\n\t\t\tvar array = attribute.array;\n\t\t\tvar itemSize = attribute.itemSize;\n\n\t\t\tvar array2 = new array.constructor( indices.length * itemSize );\n\n\t\t\tvar index = 0, index2 = 0;\n\n\t\t\tfor ( var i = 0, l = indices.length; i < l; i ++ ) {\n\n\t\t\t\tindex = indices[ i ] * itemSize;\n\n\t\t\t\tfor ( var j = 0; j < itemSize; j ++ ) {\n\n\t\t\t\t\tarray2[ index2 ++ ] = array[ index ++ ];\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tgeometry2.addAttribute( name, new BufferAttribute( array2, itemSize ) );\n\n\t\t}\n\n\t\tvar groups = this.groups;\n\n\t\tfor ( var i = 0, l = groups.length; i < l; i ++ ) {\n\n\t\t\tvar group = groups[ i ];\n\t\t\tgeometry2.addGroup( group.start, group.count, group.materialIndex );\n\n\t\t}\n\n\t\treturn geometry2;\n\n\t},\n\n\ttoJSON: function () {\n\n\t\tvar data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'BufferGeometry',\n\t\t\t\tgenerator: 'BufferGeometry.toJSON'\n\t\t\t}\n\t\t};\n\n\t\t// standard BufferGeometry serialization\n\n\t\tdata.uuid = this.uuid;\n\t\tdata.type = this.type;\n\t\tif ( this.name !== '' ) data.name = this.name;\n\n\t\tif ( this.parameters !== undefined ) {\n\n\t\t\tvar parameters = this.parameters;\n\n\t\t\tfor ( var key in parameters ) {\n\n\t\t\t\tif ( parameters[ key ] !== undefined ) data[ key ] = parameters[ key ];\n\n\t\t\t}\n\n\t\t\treturn data;\n\n\t\t}\n\n\t\tdata.data = { attributes: {} };\n\n\t\tvar index = this.index;\n\n\t\tif ( index !== null ) {\n\n\t\t\tvar array = Array.prototype.slice.call( index.array );\n\n\t\t\tdata.data.index = {\n\t\t\t\ttype: index.array.constructor.name,\n\t\t\t\tarray: array\n\t\t\t};\n\n\t\t}\n\n\t\tvar attributes = this.attributes;\n\n\t\tfor ( var key in attributes ) {\n\n\t\t\tvar attribute = attributes[ key ];\n\n\t\t\tvar array = Array.prototype.slice.call( attribute.array );\n\n\t\t\tdata.data.attributes[ key ] = {\n\t\t\t\titemSize: attribute.itemSize,\n\t\t\t\ttype: attribute.array.constructor.name,\n\t\t\t\tarray: array,\n\t\t\t\tnormalized: attribute.normalized\n\t\t\t};\n\n\t\t}\n\n\t\tvar groups = this.groups;\n\n\t\tif ( groups.length > 0 ) {\n\n\t\t\tdata.data.groups = JSON.parse( JSON.stringify( groups ) );\n\n\t\t}\n\n\t\tvar boundingSphere = this.boundingSphere;\n\n\t\tif ( boundingSphere !== null ) {\n\n\t\t\tdata.data.boundingSphere = {\n\t\t\t\tcenter: boundingSphere.center.toArray(),\n\t\t\t\tradius: boundingSphere.radius\n\t\t\t};\n\n\t\t}\n\n\t\treturn data;\n\n\t},\n\n\tclone: function () {\n\n\t\t/*\n\t\t // Handle primitives\n\n\t\t var parameters = this.parameters;\n\n\t\t if ( parameters !== undefined ) {\n\n\t\t var values = [];\n\n\t\t for ( var key in parameters ) {\n\n\t\t values.push( parameters[ key ] );\n\n\t\t }\n\n\t\t var geometry = Object.create( this.constructor.prototype );\n\t\t this.constructor.apply( geometry, values );\n\t\t return geometry;\n\n\t\t }\n\n\t\t return new this.constructor().copy( this );\n\t\t */\n\n\t\treturn new BufferGeometry().copy( this );\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tvar name, i, l;\n\n\t\t// reset\n\n\t\tthis.index = null;\n\t\tthis.attributes = {};\n\t\tthis.morphAttributes = {};\n\t\tthis.groups = [];\n\t\tthis.boundingBox = null;\n\t\tthis.boundingSphere = null;\n\n\t\t// name\n\n\t\tthis.name = source.name;\n\n\t\t// index\n\n\t\tvar index = source.index;\n\n\t\tif ( index !== null ) {\n\n\t\t\tthis.setIndex( index.clone() );\n\n\t\t}\n\n\t\t// attributes\n\n\t\tvar attributes = source.attributes;\n\n\t\tfor ( name in attributes ) {\n\n\t\t\tvar attribute = attributes[ name ];\n\t\t\tthis.addAttribute( name, attribute.clone() );\n\n\t\t}\n\n\t\t// morph attributes\n\n\t\tvar morphAttributes = source.morphAttributes;\n\n\t\tfor ( name in morphAttributes ) {\n\n\t\t\tvar array = [];\n\t\t\tvar morphAttribute = morphAttributes[ name ]; // morphAttribute: array of Float32BufferAttributes\n\n\t\t\tfor ( i = 0, l = morphAttribute.length; i < l; i ++ ) {\n\n\t\t\t\tarray.push( morphAttribute[ i ].clone() );\n\n\t\t\t}\n\n\t\t\tthis.morphAttributes[ name ] = array;\n\n\t\t}\n\n\t\t// groups\n\n\t\tvar groups = source.groups;\n\n\t\tfor ( i = 0, l = groups.length; i < l; i ++ ) {\n\n\t\t\tvar group = groups[ i ];\n\t\t\tthis.addGroup( group.start, group.count, group.materialIndex );\n\n\t\t}\n\n\t\t// bounding box\n\n\t\tvar boundingBox = source.boundingBox;\n\n\t\tif ( boundingBox !== null ) {\n\n\t\t\tthis.boundingBox = boundingBox.clone();\n\n\t\t}\n\n\t\t// bounding sphere\n\n\t\tvar boundingSphere = source.boundingSphere;\n\n\t\tif ( boundingSphere !== null ) {\n\n\t\t\tthis.boundingSphere = boundingSphere.clone();\n\n\t\t}\n\n\t\t// draw range\n\n\t\tthis.drawRange.start = source.drawRange.start;\n\t\tthis.drawRange.count = source.drawRange.count;\n\n\t\treturn this;\n\n\t},\n\n\tdispose: function () {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// BoxGeometry\n\nfunction BoxGeometry( width, height, depth, widthSegments, heightSegments, depthSegments ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'BoxGeometry';\n\n\tthis.parameters = {\n\t\twidth: width,\n\t\theight: height,\n\t\tdepth: depth,\n\t\twidthSegments: widthSegments,\n\t\theightSegments: heightSegments,\n\t\tdepthSegments: depthSegments\n\t};\n\n\tthis.fromBufferGeometry( new BoxBufferGeometry( width, height, depth, widthSegments, heightSegments, depthSegments ) );\n\tthis.mergeVertices();\n\n}\n\nBoxGeometry.prototype = Object.create( Geometry.prototype );\nBoxGeometry.prototype.constructor = BoxGeometry;\n\n// BoxBufferGeometry\n\nfunction BoxBufferGeometry( width, height, depth, widthSegments, heightSegments, depthSegments ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'BoxBufferGeometry';\n\n\tthis.parameters = {\n\t\twidth: width,\n\t\theight: height,\n\t\tdepth: depth,\n\t\twidthSegments: widthSegments,\n\t\theightSegments: heightSegments,\n\t\tdepthSegments: depthSegments\n\t};\n\n\tvar scope = this;\n\n\twidth = width || 1;\n\theight = height || 1;\n\tdepth = depth || 1;\n\n\t// segments\n\n\twidthSegments = Math.floor( widthSegments ) || 1;\n\theightSegments = Math.floor( heightSegments ) || 1;\n\tdepthSegments = Math.floor( depthSegments ) || 1;\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\t// helper variables\n\n\tvar numberOfVertices = 0;\n\tvar groupStart = 0;\n\n\t// build each side of the box geometry\n\n\tbuildPlane( 'z', 'y', 'x', - 1, - 1, depth, height, width, depthSegments, heightSegments, 0 ); // px\n\tbuildPlane( 'z', 'y', 'x', 1, - 1, depth, height, - width, depthSegments, heightSegments, 1 ); // nx\n\tbuildPlane( 'x', 'z', 'y', 1, 1, width, depth, height, widthSegments, depthSegments, 2 ); // py\n\tbuildPlane( 'x', 'z', 'y', 1, - 1, width, depth, - height, widthSegments, depthSegments, 3 ); // ny\n\tbuildPlane( 'x', 'y', 'z', 1, - 1, width, height, depth, widthSegments, heightSegments, 4 ); // pz\n\tbuildPlane( 'x', 'y', 'z', - 1, - 1, width, height, - depth, widthSegments, heightSegments, 5 ); // nz\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\tfunction buildPlane( u, v, w, udir, vdir, width, height, depth, gridX, gridY, materialIndex ) {\n\n\t\tvar segmentWidth = width / gridX;\n\t\tvar segmentHeight = height / gridY;\n\n\t\tvar widthHalf = width / 2;\n\t\tvar heightHalf = height / 2;\n\t\tvar depthHalf = depth / 2;\n\n\t\tvar gridX1 = gridX + 1;\n\t\tvar gridY1 = gridY + 1;\n\n\t\tvar vertexCounter = 0;\n\t\tvar groupCount = 0;\n\n\t\tvar ix, iy;\n\n\t\tvar vector = new Vector3();\n\n\t\t// generate vertices, normals and uvs\n\n\t\tfor ( iy = 0; iy < gridY1; iy ++ ) {\n\n\t\t\tvar y = iy * segmentHeight - heightHalf;\n\n\t\t\tfor ( ix = 0; ix < gridX1; ix ++ ) {\n\n\t\t\t\tvar x = ix * segmentWidth - widthHalf;\n\n\t\t\t\t// set values to correct vector component\n\n\t\t\t\tvector[ u ] = x * udir;\n\t\t\t\tvector[ v ] = y * vdir;\n\t\t\t\tvector[ w ] = depthHalf;\n\n\t\t\t\t// now apply vector to vertex buffer\n\n\t\t\t\tvertices.push( vector.x, vector.y, vector.z );\n\n\t\t\t\t// set values to correct vector component\n\n\t\t\t\tvector[ u ] = 0;\n\t\t\t\tvector[ v ] = 0;\n\t\t\t\tvector[ w ] = depth > 0 ? 1 : - 1;\n\n\t\t\t\t// now apply vector to normal buffer\n\n\t\t\t\tnormals.push( vector.x, vector.y, vector.z );\n\n\t\t\t\t// uvs\n\n\t\t\t\tuvs.push( ix / gridX );\n\t\t\t\tuvs.push( 1 - ( iy / gridY ) );\n\n\t\t\t\t// counters\n\n\t\t\t\tvertexCounter += 1;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// indices\n\n\t\t// 1. you need three indices to draw a single face\n\t\t// 2. a single segment consists of two faces\n\t\t// 3. so we need to generate six (2*3) indices per segment\n\n\t\tfor ( iy = 0; iy < gridY; iy ++ ) {\n\n\t\t\tfor ( ix = 0; ix < gridX; ix ++ ) {\n\n\t\t\t\tvar a = numberOfVertices + ix + gridX1 * iy;\n\t\t\t\tvar b = numberOfVertices + ix + gridX1 * ( iy + 1 );\n\t\t\t\tvar c = numberOfVertices + ( ix + 1 ) + gridX1 * ( iy + 1 );\n\t\t\t\tvar d = numberOfVertices + ( ix + 1 ) + gridX1 * iy;\n\n\t\t\t\t// faces\n\n\t\t\t\tindices.push( a, b, d );\n\t\t\t\tindices.push( b, c, d );\n\n\t\t\t\t// increase counter\n\n\t\t\t\tgroupCount += 6;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// add a group to the geometry. this will ensure multi material support\n\n\t\tscope.addGroup( groupStart, groupCount, materialIndex );\n\n\t\t// calculate new start value for groups\n\n\t\tgroupStart += groupCount;\n\n\t\t// update total number of vertices\n\n\t\tnumberOfVertices += vertexCounter;\n\n\t}\n\n}\n\nBoxBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nBoxBufferGeometry.prototype.constructor = BoxBufferGeometry;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// PlaneGeometry\n\nfunction PlaneGeometry( width, height, widthSegments, heightSegments ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'PlaneGeometry';\n\n\tthis.parameters = {\n\t\twidth: width,\n\t\theight: height,\n\t\twidthSegments: widthSegments,\n\t\theightSegments: heightSegments\n\t};\n\n\tthis.fromBufferGeometry( new PlaneBufferGeometry( width, height, widthSegments, heightSegments ) );\n\tthis.mergeVertices();\n\n}\n\nPlaneGeometry.prototype = Object.create( Geometry.prototype );\nPlaneGeometry.prototype.constructor = PlaneGeometry;\n\n// PlaneBufferGeometry\n\nfunction PlaneBufferGeometry( width, height, widthSegments, heightSegments ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'PlaneBufferGeometry';\n\n\tthis.parameters = {\n\t\twidth: width,\n\t\theight: height,\n\t\twidthSegments: widthSegments,\n\t\theightSegments: heightSegments\n\t};\n\n\twidth = width || 1;\n\theight = height || 1;\n\n\tvar width_half = width / 2;\n\tvar height_half = height / 2;\n\n\tvar gridX = Math.floor( widthSegments ) || 1;\n\tvar gridY = Math.floor( heightSegments ) || 1;\n\n\tvar gridX1 = gridX + 1;\n\tvar gridY1 = gridY + 1;\n\n\tvar segment_width = width / gridX;\n\tvar segment_height = height / gridY;\n\n\tvar ix, iy;\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\t// generate vertices, normals and uvs\n\n\tfor ( iy = 0; iy < gridY1; iy ++ ) {\n\n\t\tvar y = iy * segment_height - height_half;\n\n\t\tfor ( ix = 0; ix < gridX1; ix ++ ) {\n\n\t\t\tvar x = ix * segment_width - width_half;\n\n\t\t\tvertices.push( x, - y, 0 );\n\n\t\t\tnormals.push( 0, 0, 1 );\n\n\t\t\tuvs.push( ix / gridX );\n\t\t\tuvs.push( 1 - ( iy / gridY ) );\n\n\t\t}\n\n\t}\n\n\t// indices\n\n\tfor ( iy = 0; iy < gridY; iy ++ ) {\n\n\t\tfor ( ix = 0; ix < gridX; ix ++ ) {\n\n\t\t\tvar a = ix + gridX1 * iy;\n\t\t\tvar b = ix + gridX1 * ( iy + 1 );\n\t\t\tvar c = ( ix + 1 ) + gridX1 * ( iy + 1 );\n\t\t\tvar d = ( ix + 1 ) + gridX1 * iy;\n\n\t\t\t// faces\n\n\t\t\tindices.push( a, b, d );\n\t\t\tindices.push( b, c, d );\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n}\n\nPlaneBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nPlaneBufferGeometry.prototype.constructor = PlaneBufferGeometry;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n */\n\nvar materialId = 0;\n\nfunction Material() {\n\n\tObject.defineProperty( this, 'id', { value: materialId ++ } );\n\n\tthis.uuid = _Math.generateUUID();\n\n\tthis.name = '';\n\tthis.type = 'Material';\n\n\tthis.fog = true;\n\tthis.lights = true;\n\n\tthis.blending = NormalBlending;\n\tthis.side = FrontSide;\n\tthis.flatShading = false;\n\tthis.vertexColors = NoColors; // THREE.NoColors, THREE.VertexColors, THREE.FaceColors\n\n\tthis.opacity = 1;\n\tthis.transparent = false;\n\n\tthis.blendSrc = SrcAlphaFactor;\n\tthis.blendDst = OneMinusSrcAlphaFactor;\n\tthis.blendEquation = AddEquation;\n\tthis.blendSrcAlpha = null;\n\tthis.blendDstAlpha = null;\n\tthis.blendEquationAlpha = null;\n\n\tthis.depthFunc = LessEqualDepth;\n\tthis.depthTest = true;\n\tthis.depthWrite = true;\n\n\tthis.clippingPlanes = null;\n\tthis.clipIntersection = false;\n\tthis.clipShadows = false;\n\n\tthis.shadowSide = null;\n\n\tthis.colorWrite = true;\n\n\tthis.precision = null; // override the renderer's default precision for this material\n\n\tthis.polygonOffset = false;\n\tthis.polygonOffsetFactor = 0;\n\tthis.polygonOffsetUnits = 0;\n\n\tthis.dithering = false;\n\n\tthis.alphaTest = 0;\n\tthis.premultipliedAlpha = false;\n\n\tthis.overdraw = 0; // Overdrawn pixels (typically between 0 and 1) for fixing antialiasing gaps in CanvasRenderer\n\n\tthis.visible = true;\n\n\tthis.userData = {};\n\n\tthis.needsUpdate = true;\n\n}\n\nMaterial.prototype = Object.assign( Object.create( EventDispatcher.prototype ), {\n\n\tconstructor: Material,\n\n\tisMaterial: true,\n\n\tonBeforeCompile: function () {},\n\n\tsetValues: function ( values ) {\n\n\t\tif ( values === undefined ) return;\n\n\t\tfor ( var key in values ) {\n\n\t\t\tvar newValue = values[ key ];\n\n\t\t\tif ( newValue === undefined ) {\n\n\t\t\t\tconsole.warn( \"THREE.Material: '\" + key + \"' parameter is undefined.\" );\n\t\t\t\tcontinue;\n\n\t\t\t}\n\n\t\t\t// for backward compatability if shading is set in the constructor\n\t\t\tif ( key === 'shading' ) {\n\n\t\t\t\tconsole.warn( 'THREE.' + this.type + ': .shading has been removed. Use the boolean .flatShading instead.' );\n\t\t\t\tthis.flatShading = ( newValue === FlatShading ) ? true : false;\n\t\t\t\tcontinue;\n\n\t\t\t}\n\n\t\t\tvar currentValue = this[ key ];\n\n\t\t\tif ( currentValue === undefined ) {\n\n\t\t\t\tconsole.warn( \"THREE.\" + this.type + \": '\" + key + \"' is not a property of this material.\" );\n\t\t\t\tcontinue;\n\n\t\t\t}\n\n\t\t\tif ( currentValue && currentValue.isColor ) {\n\n\t\t\t\tcurrentValue.set( newValue );\n\n\t\t\t} else if ( ( currentValue && currentValue.isVector3 ) && ( newValue && newValue.isVector3 ) ) {\n\n\t\t\t\tcurrentValue.copy( newValue );\n\n\t\t\t} else if ( key === 'overdraw' ) {\n\n\t\t\t\t// ensure overdraw is backwards-compatible with legacy boolean type\n\t\t\t\tthis[ key ] = Number( newValue );\n\n\t\t\t} else {\n\n\t\t\t\tthis[ key ] = newValue;\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\ttoJSON: function ( meta ) {\n\n\t\tvar isRoot = ( meta === undefined || typeof meta === 'string' );\n\n\t\tif ( isRoot ) {\n\n\t\t\tmeta = {\n\t\t\t\ttextures: {},\n\t\t\t\timages: {}\n\t\t\t};\n\n\t\t}\n\n\t\tvar data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Material',\n\t\t\t\tgenerator: 'Material.toJSON'\n\t\t\t}\n\t\t};\n\n\t\t// standard Material serialization\n\t\tdata.uuid = this.uuid;\n\t\tdata.type = this.type;\n\n\t\tif ( this.name !== '' ) data.name = this.name;\n\n\t\tif ( this.color && this.color.isColor ) data.color = this.color.getHex();\n\n\t\tif ( this.roughness !== undefined ) data.roughness = this.roughness;\n\t\tif ( this.metalness !== undefined ) data.metalness = this.metalness;\n\n\t\tif ( this.emissive && this.emissive.isColor ) data.emissive = this.emissive.getHex();\n\t\tif ( this.emissiveIntensity !== 1 ) data.emissiveIntensity = this.emissiveIntensity;\n\n\t\tif ( this.specular && this.specular.isColor ) data.specular = this.specular.getHex();\n\t\tif ( this.shininess !== undefined ) data.shininess = this.shininess;\n\t\tif ( this.clearCoat !== undefined ) data.clearCoat = this.clearCoat;\n\t\tif ( this.clearCoatRoughness !== undefined ) data.clearCoatRoughness = this.clearCoatRoughness;\n\n\t\tif ( this.map && this.map.isTexture ) data.map = this.map.toJSON( meta ).uuid;\n\t\tif ( this.alphaMap && this.alphaMap.isTexture ) data.alphaMap = this.alphaMap.toJSON( meta ).uuid;\n\t\tif ( this.lightMap && this.lightMap.isTexture ) data.lightMap = this.lightMap.toJSON( meta ).uuid;\n\t\tif ( this.bumpMap && this.bumpMap.isTexture ) {\n\n\t\t\tdata.bumpMap = this.bumpMap.toJSON( meta ).uuid;\n\t\t\tdata.bumpScale = this.bumpScale;\n\n\t\t}\n\t\tif ( this.normalMap && this.normalMap.isTexture ) {\n\n\t\t\tdata.normalMap = this.normalMap.toJSON( meta ).uuid;\n\t\t\tdata.normalScale = this.normalScale.toArray();\n\n\t\t}\n\t\tif ( this.displacementMap && this.displacementMap.isTexture ) {\n\n\t\t\tdata.displacementMap = this.displacementMap.toJSON( meta ).uuid;\n\t\t\tdata.displacementScale = this.displacementScale;\n\t\t\tdata.displacementBias = this.displacementBias;\n\n\t\t}\n\t\tif ( this.roughnessMap && this.roughnessMap.isTexture ) data.roughnessMap = this.roughnessMap.toJSON( meta ).uuid;\n\t\tif ( this.metalnessMap && this.metalnessMap.isTexture ) data.metalnessMap = this.metalnessMap.toJSON( meta ).uuid;\n\n\t\tif ( this.emissiveMap && this.emissiveMap.isTexture ) data.emissiveMap = this.emissiveMap.toJSON( meta ).uuid;\n\t\tif ( this.specularMap && this.specularMap.isTexture ) data.specularMap = this.specularMap.toJSON( meta ).uuid;\n\n\t\tif ( this.envMap && this.envMap.isTexture ) {\n\n\t\t\tdata.envMap = this.envMap.toJSON( meta ).uuid;\n\t\t\tdata.reflectivity = this.reflectivity; // Scale behind envMap\n\n\t\t}\n\n\t\tif ( this.gradientMap && this.gradientMap.isTexture ) {\n\n\t\t\tdata.gradientMap = this.gradientMap.toJSON( meta ).uuid;\n\n\t\t}\n\n\t\tif ( this.size !== undefined ) data.size = this.size;\n\t\tif ( this.sizeAttenuation !== undefined ) data.sizeAttenuation = this.sizeAttenuation;\n\n\t\tif ( this.blending !== NormalBlending ) data.blending = this.blending;\n\t\tif ( this.flatShading === true ) data.flatShading = this.flatShading;\n\t\tif ( this.side !== FrontSide ) data.side = this.side;\n\t\tif ( this.vertexColors !== NoColors ) data.vertexColors = this.vertexColors;\n\n\t\tif ( this.opacity < 1 ) data.opacity = this.opacity;\n\t\tif ( this.transparent === true ) data.transparent = this.transparent;\n\n\t\tdata.depthFunc = this.depthFunc;\n\t\tdata.depthTest = this.depthTest;\n\t\tdata.depthWrite = this.depthWrite;\n\n\t\t// rotation (SpriteMaterial)\n\t\tif ( this.rotation !== 0 ) data.rotation = this.rotation;\n\n\t\tif ( this.linewidth !== 1 ) data.linewidth = this.linewidth;\n\t\tif ( this.dashSize !== undefined ) data.dashSize = this.dashSize;\n\t\tif ( this.gapSize !== undefined ) data.gapSize = this.gapSize;\n\t\tif ( this.scale !== undefined ) data.scale = this.scale;\n\n\t\tif ( this.dithering === true ) data.dithering = true;\n\n\t\tif ( this.alphaTest > 0 ) data.alphaTest = this.alphaTest;\n\t\tif ( this.premultipliedAlpha === true ) data.premultipliedAlpha = this.premultipliedAlpha;\n\n\t\tif ( this.wireframe === true ) data.wireframe = this.wireframe;\n\t\tif ( this.wireframeLinewidth > 1 ) data.wireframeLinewidth = this.wireframeLinewidth;\n\t\tif ( this.wireframeLinecap !== 'round' ) data.wireframeLinecap = this.wireframeLinecap;\n\t\tif ( this.wireframeLinejoin !== 'round' ) data.wireframeLinejoin = this.wireframeLinejoin;\n\n\t\tif ( this.morphTargets === true ) data.morphTargets = true;\n\t\tif ( this.skinning === true ) data.skinning = true;\n\n\t\tif ( this.visible === false ) data.visible = false;\n\t\tif ( JSON.stringify( this.userData ) !== '{}' ) data.userData = this.userData;\n\n\t\t// TODO: Copied from Object3D.toJSON\n\n\t\tfunction extractFromCache( cache ) {\n\n\t\t\tvar values = [];\n\n\t\t\tfor ( var key in cache ) {\n\n\t\t\t\tvar data = cache[ key ];\n\t\t\t\tdelete data.metadata;\n\t\t\t\tvalues.push( data );\n\n\t\t\t}\n\n\t\t\treturn values;\n\n\t\t}\n\n\t\tif ( isRoot ) {\n\n\t\t\tvar textures = extractFromCache( meta.textures );\n\t\t\tvar images = extractFromCache( meta.images );\n\n\t\t\tif ( textures.length > 0 ) data.textures = textures;\n\t\t\tif ( images.length > 0 ) data.images = images;\n\n\t\t}\n\n\t\treturn data;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tthis.name = source.name;\n\n\t\tthis.fog = source.fog;\n\t\tthis.lights = source.lights;\n\n\t\tthis.blending = source.blending;\n\t\tthis.side = source.side;\n\t\tthis.flatShading = source.flatShading;\n\t\tthis.vertexColors = source.vertexColors;\n\n\t\tthis.opacity = source.opacity;\n\t\tthis.transparent = source.transparent;\n\n\t\tthis.blendSrc = source.blendSrc;\n\t\tthis.blendDst = source.blendDst;\n\t\tthis.blendEquation = source.blendEquation;\n\t\tthis.blendSrcAlpha = source.blendSrcAlpha;\n\t\tthis.blendDstAlpha = source.blendDstAlpha;\n\t\tthis.blendEquationAlpha = source.blendEquationAlpha;\n\n\t\tthis.depthFunc = source.depthFunc;\n\t\tthis.depthTest = source.depthTest;\n\t\tthis.depthWrite = source.depthWrite;\n\n\t\tthis.colorWrite = source.colorWrite;\n\n\t\tthis.precision = source.precision;\n\n\t\tthis.polygonOffset = source.polygonOffset;\n\t\tthis.polygonOffsetFactor = source.polygonOffsetFactor;\n\t\tthis.polygonOffsetUnits = source.polygonOffsetUnits;\n\n\t\tthis.dithering = source.dithering;\n\n\t\tthis.alphaTest = source.alphaTest;\n\t\tthis.premultipliedAlpha = source.premultipliedAlpha;\n\n\t\tthis.overdraw = source.overdraw;\n\n\t\tthis.visible = source.visible;\n\t\tthis.userData = JSON.parse( JSON.stringify( source.userData ) );\n\n\t\tthis.clipShadows = source.clipShadows;\n\t\tthis.clipIntersection = source.clipIntersection;\n\n\t\tvar srcPlanes = source.clippingPlanes,\n\t\t\tdstPlanes = null;\n\n\t\tif ( srcPlanes !== null ) {\n\n\t\t\tvar n = srcPlanes.length;\n\t\t\tdstPlanes = new Array( n );\n\n\t\t\tfor ( var i = 0; i !== n; ++ i )\n\t\t\t\tdstPlanes[ i ] = srcPlanes[ i ].clone();\n\n\t\t}\n\n\t\tthis.clippingPlanes = dstPlanes;\n\n\t\tthis.shadowSide = source.shadowSide;\n\n\t\treturn this;\n\n\t},\n\n\tdispose: function () {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n *\n * parameters = {\n *  color: <hex>,\n *  opacity: <float>,\n *  map: new THREE.Texture( <Image> ),\n *\n *  lightMap: new THREE.Texture( <Image> ),\n *  lightMapIntensity: <float>\n *\n *  aoMap: new THREE.Texture( <Image> ),\n *  aoMapIntensity: <float>\n *\n *  specularMap: new THREE.Texture( <Image> ),\n *\n *  alphaMap: new THREE.Texture( <Image> ),\n *\n *  envMap: new THREE.CubeTexture( [posx, negx, posy, negy, posz, negz] ),\n *  combine: THREE.Multiply,\n *  reflectivity: <float>,\n *  refractionRatio: <float>,\n *\n *  depthTest: <bool>,\n *  depthWrite: <bool>,\n *\n *  wireframe: <boolean>,\n *  wireframeLinewidth: <float>,\n *\n *  skinning: <bool>,\n *  morphTargets: <bool>\n * }\n */\n\nfunction MeshBasicMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'MeshBasicMaterial';\n\n\tthis.color = new Color( 0xffffff ); // emissive\n\n\tthis.map = null;\n\n\tthis.lightMap = null;\n\tthis.lightMapIntensity = 1.0;\n\n\tthis.aoMap = null;\n\tthis.aoMapIntensity = 1.0;\n\n\tthis.specularMap = null;\n\n\tthis.alphaMap = null;\n\n\tthis.envMap = null;\n\tthis.combine = MultiplyOperation;\n\tthis.reflectivity = 1;\n\tthis.refractionRatio = 0.98;\n\n\tthis.wireframe = false;\n\tthis.wireframeLinewidth = 1;\n\tthis.wireframeLinecap = 'round';\n\tthis.wireframeLinejoin = 'round';\n\n\tthis.skinning = false;\n\tthis.morphTargets = false;\n\n\tthis.lights = false;\n\n\tthis.setValues( parameters );\n\n}\n\nMeshBasicMaterial.prototype = Object.create( Material.prototype );\nMeshBasicMaterial.prototype.constructor = MeshBasicMaterial;\n\nMeshBasicMaterial.prototype.isMeshBasicMaterial = true;\n\nMeshBasicMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.color.copy( source.color );\n\n\tthis.map = source.map;\n\n\tthis.lightMap = source.lightMap;\n\tthis.lightMapIntensity = source.lightMapIntensity;\n\n\tthis.aoMap = source.aoMap;\n\tthis.aoMapIntensity = source.aoMapIntensity;\n\n\tthis.specularMap = source.specularMap;\n\n\tthis.alphaMap = source.alphaMap;\n\n\tthis.envMap = source.envMap;\n\tthis.combine = source.combine;\n\tthis.reflectivity = source.reflectivity;\n\tthis.refractionRatio = source.refractionRatio;\n\n\tthis.wireframe = source.wireframe;\n\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\tthis.wireframeLinecap = source.wireframeLinecap;\n\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\n\tthis.skinning = source.skinning;\n\tthis.morphTargets = source.morphTargets;\n\n\treturn this;\n\n};\n\n/**\n * @author alteredq / http://alteredqualia.com/\n *\n * parameters = {\n *  defines: { \"label\" : \"value\" },\n *  uniforms: { \"parameter1\": { value: 1.0 }, \"parameter2\": { value2: 2 } },\n *\n *  fragmentShader: <string>,\n *  vertexShader: <string>,\n *\n *  wireframe: <boolean>,\n *  wireframeLinewidth: <float>,\n *\n *  lights: <bool>,\n *\n *  skinning: <bool>,\n *  morphTargets: <bool>,\n *  morphNormals: <bool>\n * }\n */\n\nfunction ShaderMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'ShaderMaterial';\n\n\tthis.defines = {};\n\tthis.uniforms = {};\n\n\tthis.vertexShader = 'void main() {\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\\n}';\n\tthis.fragmentShader = 'void main() {\\n\\tgl_FragColor = vec4( 1.0, 0.0, 0.0, 1.0 );\\n}';\n\n\tthis.linewidth = 1;\n\n\tthis.wireframe = false;\n\tthis.wireframeLinewidth = 1;\n\n\tthis.fog = false; // set to use scene fog\n\tthis.lights = false; // set to use scene lights\n\tthis.clipping = false; // set to use user-defined clipping planes\n\n\tthis.skinning = false; // set to use skinning attribute streams\n\tthis.morphTargets = false; // set to use morph targets\n\tthis.morphNormals = false; // set to use morph normals\n\n\tthis.extensions = {\n\t\tderivatives: false, // set to use derivatives\n\t\tfragDepth: false, // set to use fragment depth values\n\t\tdrawBuffers: false, // set to use draw buffers\n\t\tshaderTextureLOD: false // set to use shader texture LOD\n\t};\n\n\t// When rendered geometry doesn't include these attributes but the material does,\n\t// use these default values in WebGL. This avoids errors when buffer data is missing.\n\tthis.defaultAttributeValues = {\n\t\t'color': [ 1, 1, 1 ],\n\t\t'uv': [ 0, 0 ],\n\t\t'uv2': [ 0, 0 ]\n\t};\n\n\tthis.index0AttributeName = undefined;\n\tthis.uniformsNeedUpdate = false;\n\n\tif ( parameters !== undefined ) {\n\n\t\tif ( parameters.attributes !== undefined ) {\n\n\t\t\tconsole.error( 'THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead.' );\n\n\t\t}\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n}\n\nShaderMaterial.prototype = Object.create( Material.prototype );\nShaderMaterial.prototype.constructor = ShaderMaterial;\n\nShaderMaterial.prototype.isShaderMaterial = true;\n\nShaderMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.fragmentShader = source.fragmentShader;\n\tthis.vertexShader = source.vertexShader;\n\n\tthis.uniforms = UniformsUtils.clone( source.uniforms );\n\n\tthis.defines = Object.assign( {}, source.defines );\n\n\tthis.wireframe = source.wireframe;\n\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\n\tthis.lights = source.lights;\n\tthis.clipping = source.clipping;\n\n\tthis.skinning = source.skinning;\n\n\tthis.morphTargets = source.morphTargets;\n\tthis.morphNormals = source.morphNormals;\n\n\tthis.extensions = source.extensions;\n\n\treturn this;\n\n};\n\nShaderMaterial.prototype.toJSON = function ( meta ) {\n\n\tvar data = Material.prototype.toJSON.call( this, meta );\n\n\tdata.uniforms = this.uniforms;\n\tdata.vertexShader = this.vertexShader;\n\tdata.fragmentShader = this.fragmentShader;\n\n\treturn data;\n\n};\n\n/**\n * @author bhouston / http://clara.io\n */\n\nfunction Ray( origin, direction ) {\n\n\tthis.origin = ( origin !== undefined ) ? origin : new Vector3();\n\tthis.direction = ( direction !== undefined ) ? direction : new Vector3();\n\n}\n\nObject.assign( Ray.prototype, {\n\n\tset: function ( origin, direction ) {\n\n\t\tthis.origin.copy( origin );\n\t\tthis.direction.copy( direction );\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( ray ) {\n\n\t\tthis.origin.copy( ray.origin );\n\t\tthis.direction.copy( ray.direction );\n\n\t\treturn this;\n\n\t},\n\n\tat: function ( t, target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Ray: .at() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn target.copy( this.direction ).multiplyScalar( t ).add( this.origin );\n\n\t},\n\n\tlookAt: function ( v ) {\n\n\t\tthis.direction.copy( v ).sub( this.origin ).normalize();\n\n\t\treturn this;\n\n\t},\n\n\trecast: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function recast( t ) {\n\n\t\t\tthis.origin.copy( this.at( t, v1 ) );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tclosestPointToPoint: function ( point, target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Ray: .closestPointToPoint() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\ttarget.subVectors( point, this.origin );\n\n\t\tvar directionDistance = target.dot( this.direction );\n\n\t\tif ( directionDistance < 0 ) {\n\n\t\t\treturn target.copy( this.origin );\n\n\t\t}\n\n\t\treturn target.copy( this.direction ).multiplyScalar( directionDistance ).add( this.origin );\n\n\t},\n\n\tdistanceToPoint: function ( point ) {\n\n\t\treturn Math.sqrt( this.distanceSqToPoint( point ) );\n\n\t},\n\n\tdistanceSqToPoint: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function distanceSqToPoint( point ) {\n\n\t\t\tvar directionDistance = v1.subVectors( point, this.origin ).dot( this.direction );\n\n\t\t\t// point behind the ray\n\n\t\t\tif ( directionDistance < 0 ) {\n\n\t\t\t\treturn this.origin.distanceToSquared( point );\n\n\t\t\t}\n\n\t\t\tv1.copy( this.direction ).multiplyScalar( directionDistance ).add( this.origin );\n\n\t\t\treturn v1.distanceToSquared( point );\n\n\t\t};\n\n\t}(),\n\n\tdistanceSqToSegment: function () {\n\n\t\tvar segCenter = new Vector3();\n\t\tvar segDir = new Vector3();\n\t\tvar diff = new Vector3();\n\n\t\treturn function distanceSqToSegment( v0, v1, optionalPointOnRay, optionalPointOnSegment ) {\n\n\t\t\t// from http://www.geometrictools.com/GTEngine/Include/Mathematics/GteDistRaySegment.h\n\t\t\t// It returns the min distance between the ray and the segment\n\t\t\t// defined by v0 and v1\n\t\t\t// It can also set two optional targets :\n\t\t\t// - The closest point on the ray\n\t\t\t// - The closest point on the segment\n\n\t\t\tsegCenter.copy( v0 ).add( v1 ).multiplyScalar( 0.5 );\n\t\t\tsegDir.copy( v1 ).sub( v0 ).normalize();\n\t\t\tdiff.copy( this.origin ).sub( segCenter );\n\n\t\t\tvar segExtent = v0.distanceTo( v1 ) * 0.5;\n\t\t\tvar a01 = - this.direction.dot( segDir );\n\t\t\tvar b0 = diff.dot( this.direction );\n\t\t\tvar b1 = - diff.dot( segDir );\n\t\t\tvar c = diff.lengthSq();\n\t\t\tvar det = Math.abs( 1 - a01 * a01 );\n\t\t\tvar s0, s1, sqrDist, extDet;\n\n\t\t\tif ( det > 0 ) {\n\n\t\t\t\t// The ray and segment are not parallel.\n\n\t\t\t\ts0 = a01 * b1 - b0;\n\t\t\t\ts1 = a01 * b0 - b1;\n\t\t\t\textDet = segExtent * det;\n\n\t\t\t\tif ( s0 >= 0 ) {\n\n\t\t\t\t\tif ( s1 >= - extDet ) {\n\n\t\t\t\t\t\tif ( s1 <= extDet ) {\n\n\t\t\t\t\t\t\t// region 0\n\t\t\t\t\t\t\t// Minimum at interior points of ray and segment.\n\n\t\t\t\t\t\t\tvar invDet = 1 / det;\n\t\t\t\t\t\t\ts0 *= invDet;\n\t\t\t\t\t\t\ts1 *= invDet;\n\t\t\t\t\t\t\tsqrDist = s0 * ( s0 + a01 * s1 + 2 * b0 ) + s1 * ( a01 * s0 + s1 + 2 * b1 ) + c;\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t// region 1\n\n\t\t\t\t\t\t\ts1 = segExtent;\n\t\t\t\t\t\t\ts0 = Math.max( 0, - ( a01 * s1 + b0 ) );\n\t\t\t\t\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// region 5\n\n\t\t\t\t\t\ts1 = - segExtent;\n\t\t\t\t\t\ts0 = Math.max( 0, - ( a01 * s1 + b0 ) );\n\t\t\t\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( s1 <= - extDet ) {\n\n\t\t\t\t\t\t// region 4\n\n\t\t\t\t\t\ts0 = Math.max( 0, - ( - a01 * segExtent + b0 ) );\n\t\t\t\t\t\ts1 = ( s0 > 0 ) ? - segExtent : Math.min( Math.max( - segExtent, - b1 ), segExtent );\n\t\t\t\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t\t} else if ( s1 <= extDet ) {\n\n\t\t\t\t\t\t// region 3\n\n\t\t\t\t\t\ts0 = 0;\n\t\t\t\t\t\ts1 = Math.min( Math.max( - segExtent, - b1 ), segExtent );\n\t\t\t\t\t\tsqrDist = s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// region 2\n\n\t\t\t\t\t\ts0 = Math.max( 0, - ( a01 * segExtent + b0 ) );\n\t\t\t\t\t\ts1 = ( s0 > 0 ) ? segExtent : Math.min( Math.max( - segExtent, - b1 ), segExtent );\n\t\t\t\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// Ray and segment are parallel.\n\n\t\t\t\ts1 = ( a01 > 0 ) ? - segExtent : segExtent;\n\t\t\t\ts0 = Math.max( 0, - ( a01 * s1 + b0 ) );\n\t\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t}\n\n\t\t\tif ( optionalPointOnRay ) {\n\n\t\t\t\toptionalPointOnRay.copy( this.direction ).multiplyScalar( s0 ).add( this.origin );\n\n\t\t\t}\n\n\t\t\tif ( optionalPointOnSegment ) {\n\n\t\t\t\toptionalPointOnSegment.copy( segDir ).multiplyScalar( s1 ).add( segCenter );\n\n\t\t\t}\n\n\t\t\treturn sqrDist;\n\n\t\t};\n\n\t}(),\n\n\tintersectSphere: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function intersectSphere( sphere, target ) {\n\n\t\t\tv1.subVectors( sphere.center, this.origin );\n\t\t\tvar tca = v1.dot( this.direction );\n\t\t\tvar d2 = v1.dot( v1 ) - tca * tca;\n\t\t\tvar radius2 = sphere.radius * sphere.radius;\n\n\t\t\tif ( d2 > radius2 ) return null;\n\n\t\t\tvar thc = Math.sqrt( radius2 - d2 );\n\n\t\t\t// t0 = first intersect point - entrance on front of sphere\n\t\t\tvar t0 = tca - thc;\n\n\t\t\t// t1 = second intersect point - exit point on back of sphere\n\t\t\tvar t1 = tca + thc;\n\n\t\t\t// test to see if both t0 and t1 are behind the ray - if so, return null\n\t\t\tif ( t0 < 0 && t1 < 0 ) return null;\n\n\t\t\t// test to see if t0 is behind the ray:\n\t\t\t// if it is, the ray is inside the sphere, so return the second exit point scaled by t1,\n\t\t\t// in order to always return an intersect point that is in front of the ray.\n\t\t\tif ( t0 < 0 ) return this.at( t1, target );\n\n\t\t\t// else t0 is in front of the ray, so return the first collision point scaled by t0\n\t\t\treturn this.at( t0, target );\n\n\t\t};\n\n\t}(),\n\n\tintersectsSphere: function ( sphere ) {\n\n\t\treturn this.distanceToPoint( sphere.center ) <= sphere.radius;\n\n\t},\n\n\tdistanceToPlane: function ( plane ) {\n\n\t\tvar denominator = plane.normal.dot( this.direction );\n\n\t\tif ( denominator === 0 ) {\n\n\t\t\t// line is coplanar, return origin\n\t\t\tif ( plane.distanceToPoint( this.origin ) === 0 ) {\n\n\t\t\t\treturn 0;\n\n\t\t\t}\n\n\t\t\t// Null is preferable to undefined since undefined means.... it is undefined\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\tvar t = - ( this.origin.dot( plane.normal ) + plane.constant ) / denominator;\n\n\t\t// Return if the ray never intersects the plane\n\n\t\treturn t >= 0 ? t : null;\n\n\t},\n\n\tintersectPlane: function ( plane, target ) {\n\n\t\tvar t = this.distanceToPlane( plane );\n\n\t\tif ( t === null ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\treturn this.at( t, target );\n\n\t},\n\n\tintersectsPlane: function ( plane ) {\n\n\t\t// check if the ray lies on the plane first\n\n\t\tvar distToPoint = plane.distanceToPoint( this.origin );\n\n\t\tif ( distToPoint === 0 ) {\n\n\t\t\treturn true;\n\n\t\t}\n\n\t\tvar denominator = plane.normal.dot( this.direction );\n\n\t\tif ( denominator * distToPoint < 0 ) {\n\n\t\t\treturn true;\n\n\t\t}\n\n\t\t// ray origin is behind the plane (and is pointing behind it)\n\n\t\treturn false;\n\n\t},\n\n\tintersectBox: function ( box, target ) {\n\n\t\tvar tmin, tmax, tymin, tymax, tzmin, tzmax;\n\n\t\tvar invdirx = 1 / this.direction.x,\n\t\t\tinvdiry = 1 / this.direction.y,\n\t\t\tinvdirz = 1 / this.direction.z;\n\n\t\tvar origin = this.origin;\n\n\t\tif ( invdirx >= 0 ) {\n\n\t\t\ttmin = ( box.min.x - origin.x ) * invdirx;\n\t\t\ttmax = ( box.max.x - origin.x ) * invdirx;\n\n\t\t} else {\n\n\t\t\ttmin = ( box.max.x - origin.x ) * invdirx;\n\t\t\ttmax = ( box.min.x - origin.x ) * invdirx;\n\n\t\t}\n\n\t\tif ( invdiry >= 0 ) {\n\n\t\t\ttymin = ( box.min.y - origin.y ) * invdiry;\n\t\t\ttymax = ( box.max.y - origin.y ) * invdiry;\n\n\t\t} else {\n\n\t\t\ttymin = ( box.max.y - origin.y ) * invdiry;\n\t\t\ttymax = ( box.min.y - origin.y ) * invdiry;\n\n\t\t}\n\n\t\tif ( ( tmin > tymax ) || ( tymin > tmax ) ) return null;\n\n\t\t// These lines also handle the case where tmin or tmax is NaN\n\t\t// (result of 0 * Infinity). x !== x returns true if x is NaN\n\n\t\tif ( tymin > tmin || tmin !== tmin ) tmin = tymin;\n\n\t\tif ( tymax < tmax || tmax !== tmax ) tmax = tymax;\n\n\t\tif ( invdirz >= 0 ) {\n\n\t\t\ttzmin = ( box.min.z - origin.z ) * invdirz;\n\t\t\ttzmax = ( box.max.z - origin.z ) * invdirz;\n\n\t\t} else {\n\n\t\t\ttzmin = ( box.max.z - origin.z ) * invdirz;\n\t\t\ttzmax = ( box.min.z - origin.z ) * invdirz;\n\n\t\t}\n\n\t\tif ( ( tmin > tzmax ) || ( tzmin > tmax ) ) return null;\n\n\t\tif ( tzmin > tmin || tmin !== tmin ) tmin = tzmin;\n\n\t\tif ( tzmax < tmax || tmax !== tmax ) tmax = tzmax;\n\n\t\t//return point closest to the ray (positive side)\n\n\t\tif ( tmax < 0 ) return null;\n\n\t\treturn this.at( tmin >= 0 ? tmin : tmax, target );\n\n\t},\n\n\tintersectsBox: ( function () {\n\n\t\tvar v = new Vector3();\n\n\t\treturn function intersectsBox( box ) {\n\n\t\t\treturn this.intersectBox( box, v ) !== null;\n\n\t\t};\n\n\t} )(),\n\n\tintersectTriangle: function () {\n\n\t\t// Compute the offset origin, edges, and normal.\n\t\tvar diff = new Vector3();\n\t\tvar edge1 = new Vector3();\n\t\tvar edge2 = new Vector3();\n\t\tvar normal = new Vector3();\n\n\t\treturn function intersectTriangle( a, b, c, backfaceCulling, target ) {\n\n\t\t\t// from http://www.geometrictools.com/GTEngine/Include/Mathematics/GteIntrRay3Triangle3.h\n\n\t\t\tedge1.subVectors( b, a );\n\t\t\tedge2.subVectors( c, a );\n\t\t\tnormal.crossVectors( edge1, edge2 );\n\n\t\t\t// Solve Q + t*D = b1*E1 + b2*E2 (Q = kDiff, D = ray direction,\n\t\t\t// E1 = kEdge1, E2 = kEdge2, N = Cross(E1,E2)) by\n\t\t\t//   |Dot(D,N)|*b1 = sign(Dot(D,N))*Dot(D,Cross(Q,E2))\n\t\t\t//   |Dot(D,N)|*b2 = sign(Dot(D,N))*Dot(D,Cross(E1,Q))\n\t\t\t//   |Dot(D,N)|*t = -sign(Dot(D,N))*Dot(Q,N)\n\t\t\tvar DdN = this.direction.dot( normal );\n\t\t\tvar sign;\n\n\t\t\tif ( DdN > 0 ) {\n\n\t\t\t\tif ( backfaceCulling ) return null;\n\t\t\t\tsign = 1;\n\n\t\t\t} else if ( DdN < 0 ) {\n\n\t\t\t\tsign = - 1;\n\t\t\t\tDdN = - DdN;\n\n\t\t\t} else {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t\tdiff.subVectors( this.origin, a );\n\t\t\tvar DdQxE2 = sign * this.direction.dot( edge2.crossVectors( diff, edge2 ) );\n\n\t\t\t// b1 < 0, no intersection\n\t\t\tif ( DdQxE2 < 0 ) {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t\tvar DdE1xQ = sign * this.direction.dot( edge1.cross( diff ) );\n\n\t\t\t// b2 < 0, no intersection\n\t\t\tif ( DdE1xQ < 0 ) {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t\t// b1+b2 > 1, no intersection\n\t\t\tif ( DdQxE2 + DdE1xQ > DdN ) {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t\t// Line intersects triangle, check if ray does.\n\t\t\tvar QdN = - sign * diff.dot( normal );\n\n\t\t\t// t < 0, no intersection\n\t\t\tif ( QdN < 0 ) {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t\t// Ray intersects triangle.\n\t\t\treturn this.at( QdN / DdN, target );\n\n\t\t};\n\n\t}(),\n\n\tapplyMatrix4: function ( matrix4 ) {\n\n\t\tthis.origin.applyMatrix4( matrix4 );\n\t\tthis.direction.transformDirection( matrix4 );\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( ray ) {\n\n\t\treturn ray.origin.equals( this.origin ) && ray.direction.equals( this.direction );\n\n\t}\n\n} );\n\n/**\n * @author bhouston / http://clara.io\n */\n\nfunction Line3( start, end ) {\n\n\tthis.start = ( start !== undefined ) ? start : new Vector3();\n\tthis.end = ( end !== undefined ) ? end : new Vector3();\n\n}\n\nObject.assign( Line3.prototype, {\n\n\tset: function ( start, end ) {\n\n\t\tthis.start.copy( start );\n\t\tthis.end.copy( end );\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( line ) {\n\n\t\tthis.start.copy( line.start );\n\t\tthis.end.copy( line.end );\n\n\t\treturn this;\n\n\t},\n\n\tgetCenter: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Line3: .getCenter() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn target.addVectors( this.start, this.end ).multiplyScalar( 0.5 );\n\n\t},\n\n\tdelta: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Line3: .delta() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn target.subVectors( this.end, this.start );\n\n\t},\n\n\tdistanceSq: function () {\n\n\t\treturn this.start.distanceToSquared( this.end );\n\n\t},\n\n\tdistance: function () {\n\n\t\treturn this.start.distanceTo( this.end );\n\n\t},\n\n\tat: function ( t, target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Line3: .at() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn this.delta( target ).multiplyScalar( t ).add( this.start );\n\n\t},\n\n\tclosestPointToPointParameter: function () {\n\n\t\tvar startP = new Vector3();\n\t\tvar startEnd = new Vector3();\n\n\t\treturn function closestPointToPointParameter( point, clampToLine ) {\n\n\t\t\tstartP.subVectors( point, this.start );\n\t\t\tstartEnd.subVectors( this.end, this.start );\n\n\t\t\tvar startEnd2 = startEnd.dot( startEnd );\n\t\t\tvar startEnd_startP = startEnd.dot( startP );\n\n\t\t\tvar t = startEnd_startP / startEnd2;\n\n\t\t\tif ( clampToLine ) {\n\n\t\t\t\tt = _Math.clamp( t, 0, 1 );\n\n\t\t\t}\n\n\t\t\treturn t;\n\n\t\t};\n\n\t}(),\n\n\tclosestPointToPoint: function ( point, clampToLine, target ) {\n\n\t\tvar t = this.closestPointToPointParameter( point, clampToLine );\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Line3: .closestPointToPoint() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn this.delta( target ).multiplyScalar( t ).add( this.start );\n\n\t},\n\n\tapplyMatrix4: function ( matrix ) {\n\n\t\tthis.start.applyMatrix4( matrix );\n\t\tthis.end.applyMatrix4( matrix );\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( line ) {\n\n\t\treturn line.start.equals( this.start ) && line.end.equals( this.end );\n\n\t}\n\n} );\n\n/**\n * @author bhouston / http://clara.io\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction Triangle( a, b, c ) {\n\n\tthis.a = ( a !== undefined ) ? a : new Vector3();\n\tthis.b = ( b !== undefined ) ? b : new Vector3();\n\tthis.c = ( c !== undefined ) ? c : new Vector3();\n\n}\n\nObject.assign( Triangle, {\n\n\tgetNormal: function () {\n\n\t\tvar v0 = new Vector3();\n\n\t\treturn function getNormal( a, b, c, target ) {\n\n\t\t\tif ( target === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Triangle: .getNormal() target is now required' );\n\t\t\t\ttarget = new Vector3();\n\n\t\t\t}\n\n\t\t\ttarget.subVectors( c, b );\n\t\t\tv0.subVectors( a, b );\n\t\t\ttarget.cross( v0 );\n\n\t\t\tvar targetLengthSq = target.lengthSq();\n\t\t\tif ( targetLengthSq > 0 ) {\n\n\t\t\t\treturn target.multiplyScalar( 1 / Math.sqrt( targetLengthSq ) );\n\n\t\t\t}\n\n\t\t\treturn target.set( 0, 0, 0 );\n\n\t\t};\n\n\t}(),\n\n\t// static/instance method to calculate barycentric coordinates\n\t// based on: http://www.blackpawn.com/texts/pointinpoly/default.html\n\tgetBarycoord: function () {\n\n\t\tvar v0 = new Vector3();\n\t\tvar v1 = new Vector3();\n\t\tvar v2 = new Vector3();\n\n\t\treturn function getBarycoord( point, a, b, c, target ) {\n\n\t\t\tv0.subVectors( c, a );\n\t\t\tv1.subVectors( b, a );\n\t\t\tv2.subVectors( point, a );\n\n\t\t\tvar dot00 = v0.dot( v0 );\n\t\t\tvar dot01 = v0.dot( v1 );\n\t\t\tvar dot02 = v0.dot( v2 );\n\t\t\tvar dot11 = v1.dot( v1 );\n\t\t\tvar dot12 = v1.dot( v2 );\n\n\t\t\tvar denom = ( dot00 * dot11 - dot01 * dot01 );\n\n\t\t\tif ( target === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Triangle: .getBarycoord() target is now required' );\n\t\t\t\ttarget = new Vector3();\n\n\t\t\t}\n\n\t\t\t// collinear or singular triangle\n\t\t\tif ( denom === 0 ) {\n\n\t\t\t\t// arbitrary location outside of triangle?\n\t\t\t\t// not sure if this is the best idea, maybe should be returning undefined\n\t\t\t\treturn target.set( - 2, - 1, - 1 );\n\n\t\t\t}\n\n\t\t\tvar invDenom = 1 / denom;\n\t\t\tvar u = ( dot11 * dot02 - dot01 * dot12 ) * invDenom;\n\t\t\tvar v = ( dot00 * dot12 - dot01 * dot02 ) * invDenom;\n\n\t\t\t// barycentric coordinates must always sum to 1\n\t\t\treturn target.set( 1 - u - v, v, u );\n\n\t\t};\n\n\t}(),\n\n\tcontainsPoint: function () {\n\n\t\tvar v1 = new Vector3();\n\n\t\treturn function containsPoint( point, a, b, c ) {\n\n\t\t\tTriangle.getBarycoord( point, a, b, c, v1 );\n\n\t\t\treturn ( v1.x >= 0 ) && ( v1.y >= 0 ) && ( ( v1.x + v1.y ) <= 1 );\n\n\t\t};\n\n\t}()\n\n} );\n\nObject.assign( Triangle.prototype, {\n\n\tset: function ( a, b, c ) {\n\n\t\tthis.a.copy( a );\n\t\tthis.b.copy( b );\n\t\tthis.c.copy( c );\n\n\t\treturn this;\n\n\t},\n\n\tsetFromPointsAndIndices: function ( points, i0, i1, i2 ) {\n\n\t\tthis.a.copy( points[ i0 ] );\n\t\tthis.b.copy( points[ i1 ] );\n\t\tthis.c.copy( points[ i2 ] );\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( triangle ) {\n\n\t\tthis.a.copy( triangle.a );\n\t\tthis.b.copy( triangle.b );\n\t\tthis.c.copy( triangle.c );\n\n\t\treturn this;\n\n\t},\n\n\tgetArea: function () {\n\n\t\tvar v0 = new Vector3();\n\t\tvar v1 = new Vector3();\n\n\t\treturn function getArea() {\n\n\t\t\tv0.subVectors( this.c, this.b );\n\t\t\tv1.subVectors( this.a, this.b );\n\n\t\t\treturn v0.cross( v1 ).length() * 0.5;\n\n\t\t};\n\n\t}(),\n\n\tgetMidpoint: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Triangle: .getMidpoint() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn target.addVectors( this.a, this.b ).add( this.c ).multiplyScalar( 1 / 3 );\n\n\t},\n\n\tgetNormal: function ( target ) {\n\n\t\treturn Triangle.getNormal( this.a, this.b, this.c, target );\n\n\t},\n\n\tgetPlane: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Triangle: .getPlane() target is now required' );\n\t\t\ttarget = new Vector3();\n\n\t\t}\n\n\t\treturn target.setFromCoplanarPoints( this.a, this.b, this.c );\n\n\t},\n\n\tgetBarycoord: function ( point, target ) {\n\n\t\treturn Triangle.getBarycoord( point, this.a, this.b, this.c, target );\n\n\t},\n\n\tcontainsPoint: function ( point ) {\n\n\t\treturn Triangle.containsPoint( point, this.a, this.b, this.c );\n\n\t},\n\n\tintersectsBox: function ( box ) {\n\n\t\treturn box.intersectsTriangle( this );\n\n\t},\n\n\tclosestPointToPoint: function () {\n\n\t\tvar plane = new Plane();\n\t\tvar edgeList = [ new Line3(), new Line3(), new Line3() ];\n\t\tvar projectedPoint = new Vector3();\n\t\tvar closestPoint = new Vector3();\n\n\t\treturn function closestPointToPoint( point, target ) {\n\n\t\t\tif ( target === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Triangle: .closestPointToPoint() target is now required' );\n\t\t\t\ttarget = new Vector3();\n\n\t\t\t}\n\n\t\t\tvar minDistance = Infinity;\n\n\t\t\t// project the point onto the plane of the triangle\n\n\t\t\tplane.setFromCoplanarPoints( this.a, this.b, this.c );\n\t\t\tplane.projectPoint( point, projectedPoint );\n\n\t\t\t// check if the projection lies within the triangle\n\n\t\t\tif ( this.containsPoint( projectedPoint ) === true ) {\n\n\t\t\t\t// if so, this is the closest point\n\n\t\t\t\ttarget.copy( projectedPoint );\n\n\t\t\t} else {\n\n\t\t\t\t// if not, the point falls outside the triangle. the target is the closest point to the triangle's edges or vertices\n\n\t\t\t\tedgeList[ 0 ].set( this.a, this.b );\n\t\t\t\tedgeList[ 1 ].set( this.b, this.c );\n\t\t\t\tedgeList[ 2 ].set( this.c, this.a );\n\n\t\t\t\tfor ( var i = 0; i < edgeList.length; i ++ ) {\n\n\t\t\t\t\tedgeList[ i ].closestPointToPoint( projectedPoint, true, closestPoint );\n\n\t\t\t\t\tvar distance = projectedPoint.distanceToSquared( closestPoint );\n\n\t\t\t\t\tif ( distance < minDistance ) {\n\n\t\t\t\t\t\tminDistance = distance;\n\n\t\t\t\t\t\ttarget.copy( closestPoint );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn target;\n\n\t\t};\n\n\t}(),\n\n\tequals: function ( triangle ) {\n\n\t\treturn triangle.a.equals( this.a ) && triangle.b.equals( this.b ) && triangle.c.equals( this.c );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n * @author mikael emtinger / http://gomo.se/\n * @author jonobr1 / http://jonobr1.com/\n */\n\nfunction Mesh( geometry, material ) {\n\n\tObject3D.call( this );\n\n\tthis.type = 'Mesh';\n\n\tthis.geometry = geometry !== undefined ? geometry : new BufferGeometry();\n\tthis.material = material !== undefined ? material : new MeshBasicMaterial( { color: Math.random() * 0xffffff } );\n\n\tthis.drawMode = TrianglesDrawMode;\n\n\tthis.updateMorphTargets();\n\n}\n\nMesh.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Mesh,\n\n\tisMesh: true,\n\n\tsetDrawMode: function ( value ) {\n\n\t\tthis.drawMode = value;\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tObject3D.prototype.copy.call( this, source );\n\n\t\tthis.drawMode = source.drawMode;\n\n\t\tif ( source.morphTargetInfluences !== undefined ) {\n\n\t\t\tthis.morphTargetInfluences = source.morphTargetInfluences.slice();\n\n\t\t}\n\n\t\tif ( source.morphTargetDictionary !== undefined ) {\n\n\t\t\tthis.morphTargetDictionary = Object.assign( {}, source.morphTargetDictionary );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tupdateMorphTargets: function () {\n\n\t\tvar geometry = this.geometry;\n\t\tvar m, ml, name;\n\n\t\tif ( geometry.isBufferGeometry ) {\n\n\t\t\tvar morphAttributes = geometry.morphAttributes;\n\t\t\tvar keys = Object.keys( morphAttributes );\n\n\t\t\tif ( keys.length > 0 ) {\n\n\t\t\t\tvar morphAttribute = morphAttributes[ keys[ 0 ] ];\n\n\t\t\t\tif ( morphAttribute !== undefined ) {\n\n\t\t\t\t\tthis.morphTargetInfluences = [];\n\t\t\t\t\tthis.morphTargetDictionary = {};\n\n\t\t\t\t\tfor ( m = 0, ml = morphAttribute.length; m < ml; m ++ ) {\n\n\t\t\t\t\t\tname = morphAttribute[ m ].name || String( m );\n\n\t\t\t\t\t\tthis.morphTargetInfluences.push( 0 );\n\t\t\t\t\t\tthis.morphTargetDictionary[ name ] = m;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tvar morphTargets = geometry.morphTargets;\n\n\t\t\tif ( morphTargets !== undefined && morphTargets.length > 0 ) {\n\n\t\t\t\tthis.morphTargetInfluences = [];\n\t\t\t\tthis.morphTargetDictionary = {};\n\n\t\t\t\tfor ( m = 0, ml = morphTargets.length; m < ml; m ++ ) {\n\n\t\t\t\t\tname = morphTargets[ m ].name || String( m );\n\n\t\t\t\t\tthis.morphTargetInfluences.push( 0 );\n\t\t\t\t\tthis.morphTargetDictionary[ name ] = m;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\traycast: ( function () {\n\n\t\tvar inverseMatrix = new Matrix4();\n\t\tvar ray = new Ray();\n\t\tvar sphere = new Sphere();\n\n\t\tvar vA = new Vector3();\n\t\tvar vB = new Vector3();\n\t\tvar vC = new Vector3();\n\n\t\tvar tempA = new Vector3();\n\t\tvar tempB = new Vector3();\n\t\tvar tempC = new Vector3();\n\n\t\tvar uvA = new Vector2();\n\t\tvar uvB = new Vector2();\n\t\tvar uvC = new Vector2();\n\n\t\tvar barycoord = new Vector3();\n\n\t\tvar intersectionPoint = new Vector3();\n\t\tvar intersectionPointWorld = new Vector3();\n\n\t\tfunction uvIntersection( point, p1, p2, p3, uv1, uv2, uv3 ) {\n\n\t\t\tTriangle.getBarycoord( point, p1, p2, p3, barycoord );\n\n\t\t\tuv1.multiplyScalar( barycoord.x );\n\t\t\tuv2.multiplyScalar( barycoord.y );\n\t\t\tuv3.multiplyScalar( barycoord.z );\n\n\t\t\tuv1.add( uv2 ).add( uv3 );\n\n\t\t\treturn uv1.clone();\n\n\t\t}\n\n\t\tfunction checkIntersection( object, material, raycaster, ray, pA, pB, pC, point ) {\n\n\t\t\tvar intersect;\n\n\t\t\tif ( material.side === BackSide ) {\n\n\t\t\t\tintersect = ray.intersectTriangle( pC, pB, pA, true, point );\n\n\t\t\t} else {\n\n\t\t\t\tintersect = ray.intersectTriangle( pA, pB, pC, material.side !== DoubleSide, point );\n\n\t\t\t}\n\n\t\t\tif ( intersect === null ) return null;\n\n\t\t\tintersectionPointWorld.copy( point );\n\t\t\tintersectionPointWorld.applyMatrix4( object.matrixWorld );\n\n\t\t\tvar distance = raycaster.ray.origin.distanceTo( intersectionPointWorld );\n\n\t\t\tif ( distance < raycaster.near || distance > raycaster.far ) return null;\n\n\t\t\treturn {\n\t\t\t\tdistance: distance,\n\t\t\t\tpoint: intersectionPointWorld.clone(),\n\t\t\t\tobject: object\n\t\t\t};\n\n\t\t}\n\n\t\tfunction checkBufferGeometryIntersection( object, raycaster, ray, position, uv, a, b, c ) {\n\n\t\t\tvA.fromBufferAttribute( position, a );\n\t\t\tvB.fromBufferAttribute( position, b );\n\t\t\tvC.fromBufferAttribute( position, c );\n\n\t\t\tvar intersection = checkIntersection( object, object.material, raycaster, ray, vA, vB, vC, intersectionPoint );\n\n\t\t\tif ( intersection ) {\n\n\t\t\t\tif ( uv ) {\n\n\t\t\t\t\tuvA.fromBufferAttribute( uv, a );\n\t\t\t\t\tuvB.fromBufferAttribute( uv, b );\n\t\t\t\t\tuvC.fromBufferAttribute( uv, c );\n\n\t\t\t\t\tintersection.uv = uvIntersection( intersectionPoint, vA, vB, vC, uvA, uvB, uvC );\n\n\t\t\t\t}\n\n\t\t\t\tvar face = new Face3( a, b, c );\n\t\t\t\tTriangle.getNormal( vA, vB, vC, face.normal );\n\n\t\t\t\tintersection.face = face;\n\t\t\t\tintersection.faceIndex = a;\n\n\t\t\t}\n\n\t\t\treturn intersection;\n\n\t\t}\n\n\t\treturn function raycast( raycaster, intersects ) {\n\n\t\t\tvar geometry = this.geometry;\n\t\t\tvar material = this.material;\n\t\t\tvar matrixWorld = this.matrixWorld;\n\n\t\t\tif ( material === undefined ) return;\n\n\t\t\t// Checking boundingSphere distance to ray\n\n\t\t\tif ( geometry.boundingSphere === null ) geometry.computeBoundingSphere();\n\n\t\t\tsphere.copy( geometry.boundingSphere );\n\t\t\tsphere.applyMatrix4( matrixWorld );\n\n\t\t\tif ( raycaster.ray.intersectsSphere( sphere ) === false ) return;\n\n\t\t\t//\n\n\t\t\tinverseMatrix.getInverse( matrixWorld );\n\t\t\tray.copy( raycaster.ray ).applyMatrix4( inverseMatrix );\n\n\t\t\t// Check boundingBox before continuing\n\n\t\t\tif ( geometry.boundingBox !== null ) {\n\n\t\t\t\tif ( ray.intersectsBox( geometry.boundingBox ) === false ) return;\n\n\t\t\t}\n\n\t\t\tvar intersection;\n\n\t\t\tif ( geometry.isBufferGeometry ) {\n\n\t\t\t\tvar a, b, c;\n\t\t\t\tvar index = geometry.index;\n\t\t\t\tvar position = geometry.attributes.position;\n\t\t\t\tvar uv = geometry.attributes.uv;\n\t\t\t\tvar i, l;\n\n\t\t\t\tif ( index !== null ) {\n\n\t\t\t\t\t// indexed buffer geometry\n\n\t\t\t\t\tfor ( i = 0, l = index.count; i < l; i += 3 ) {\n\n\t\t\t\t\t\ta = index.getX( i );\n\t\t\t\t\t\tb = index.getX( i + 1 );\n\t\t\t\t\t\tc = index.getX( i + 2 );\n\n\t\t\t\t\t\tintersection = checkBufferGeometryIntersection( this, raycaster, ray, position, uv, a, b, c );\n\n\t\t\t\t\t\tif ( intersection ) {\n\n\t\t\t\t\t\t\tintersection.faceIndex = Math.floor( i / 3 ); // triangle number in indices buffer semantics\n\t\t\t\t\t\t\tintersects.push( intersection );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t} else if ( position !== undefined ) {\n\n\t\t\t\t\t// non-indexed buffer geometry\n\n\t\t\t\t\tfor ( i = 0, l = position.count; i < l; i += 3 ) {\n\n\t\t\t\t\t\ta = i;\n\t\t\t\t\t\tb = i + 1;\n\t\t\t\t\t\tc = i + 2;\n\n\t\t\t\t\t\tintersection = checkBufferGeometryIntersection( this, raycaster, ray, position, uv, a, b, c );\n\n\t\t\t\t\t\tif ( intersection ) intersects.push( intersection );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else if ( geometry.isGeometry ) {\n\n\t\t\t\tvar fvA, fvB, fvC;\n\t\t\t\tvar isMultiMaterial = Array.isArray( material );\n\n\t\t\t\tvar vertices = geometry.vertices;\n\t\t\t\tvar faces = geometry.faces;\n\t\t\t\tvar uvs;\n\n\t\t\t\tvar faceVertexUvs = geometry.faceVertexUvs[ 0 ];\n\t\t\t\tif ( faceVertexUvs.length > 0 ) uvs = faceVertexUvs;\n\n\t\t\t\tfor ( var f = 0, fl = faces.length; f < fl; f ++ ) {\n\n\t\t\t\t\tvar face = faces[ f ];\n\t\t\t\t\tvar faceMaterial = isMultiMaterial ? material[ face.materialIndex ] : material;\n\n\t\t\t\t\tif ( faceMaterial === undefined ) continue;\n\n\t\t\t\t\tfvA = vertices[ face.a ];\n\t\t\t\t\tfvB = vertices[ face.b ];\n\t\t\t\t\tfvC = vertices[ face.c ];\n\n\t\t\t\t\tif ( faceMaterial.morphTargets === true ) {\n\n\t\t\t\t\t\tvar morphTargets = geometry.morphTargets;\n\t\t\t\t\t\tvar morphInfluences = this.morphTargetInfluences;\n\n\t\t\t\t\t\tvA.set( 0, 0, 0 );\n\t\t\t\t\t\tvB.set( 0, 0, 0 );\n\t\t\t\t\t\tvC.set( 0, 0, 0 );\n\n\t\t\t\t\t\tfor ( var t = 0, tl = morphTargets.length; t < tl; t ++ ) {\n\n\t\t\t\t\t\t\tvar influence = morphInfluences[ t ];\n\n\t\t\t\t\t\t\tif ( influence === 0 ) continue;\n\n\t\t\t\t\t\t\tvar targets = morphTargets[ t ].vertices;\n\n\t\t\t\t\t\t\tvA.addScaledVector( tempA.subVectors( targets[ face.a ], fvA ), influence );\n\t\t\t\t\t\t\tvB.addScaledVector( tempB.subVectors( targets[ face.b ], fvB ), influence );\n\t\t\t\t\t\t\tvC.addScaledVector( tempC.subVectors( targets[ face.c ], fvC ), influence );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tvA.add( fvA );\n\t\t\t\t\t\tvB.add( fvB );\n\t\t\t\t\t\tvC.add( fvC );\n\n\t\t\t\t\t\tfvA = vA;\n\t\t\t\t\t\tfvB = vB;\n\t\t\t\t\t\tfvC = vC;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tintersection = checkIntersection( this, faceMaterial, raycaster, ray, fvA, fvB, fvC, intersectionPoint );\n\n\t\t\t\t\tif ( intersection ) {\n\n\t\t\t\t\t\tif ( uvs && uvs[ f ] ) {\n\n\t\t\t\t\t\t\tvar uvs_f = uvs[ f ];\n\t\t\t\t\t\t\tuvA.copy( uvs_f[ 0 ] );\n\t\t\t\t\t\t\tuvB.copy( uvs_f[ 1 ] );\n\t\t\t\t\t\t\tuvC.copy( uvs_f[ 2 ] );\n\n\t\t\t\t\t\t\tintersection.uv = uvIntersection( intersectionPoint, fvA, fvB, fvC, uvA, uvB, uvC );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tintersection.face = face;\n\t\t\t\t\t\tintersection.faceIndex = f;\n\t\t\t\t\t\tintersects.push( intersection );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t};\n\n\t}() ),\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.geometry, this.material ).copy( this );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLBackground( renderer, state, geometries, premultipliedAlpha ) {\n\n\tvar clearColor = new Color( 0x000000 );\n\tvar clearAlpha = 0;\n\n\tvar planeCamera, planeMesh;\n\tvar boxMesh;\n\n\tfunction render( renderList, scene, camera, forceClear ) {\n\n\t\tvar background = scene.background;\n\n\t\tif ( background === null ) {\n\n\t\t\tsetClear( clearColor, clearAlpha );\n\n\t\t} else if ( background && background.isColor ) {\n\n\t\t\tsetClear( background, 1 );\n\t\t\tforceClear = true;\n\n\t\t}\n\n\t\tif ( renderer.autoClear || forceClear ) {\n\n\t\t\trenderer.clear( renderer.autoClearColor, renderer.autoClearDepth, renderer.autoClearStencil );\n\n\t\t}\n\n\t\tif ( background && background.isCubeTexture ) {\n\n\t\t\tif ( boxMesh === undefined ) {\n\n\t\t\t\tboxMesh = new Mesh(\n\t\t\t\t\tnew BoxBufferGeometry( 1, 1, 1 ),\n\t\t\t\t\tnew ShaderMaterial( {\n\t\t\t\t\t\tuniforms: ShaderLib.cube.uniforms,\n\t\t\t\t\t\tvertexShader: ShaderLib.cube.vertexShader,\n\t\t\t\t\t\tfragmentShader: ShaderLib.cube.fragmentShader,\n\t\t\t\t\t\tside: BackSide,\n\t\t\t\t\t\tdepthTest: true,\n\t\t\t\t\t\tdepthWrite: false,\n\t\t\t\t\t\tfog: false\n\t\t\t\t\t} )\n\t\t\t\t);\n\n\t\t\t\tboxMesh.geometry.removeAttribute( 'normal' );\n\t\t\t\tboxMesh.geometry.removeAttribute( 'uv' );\n\n\t\t\t\tboxMesh.onBeforeRender = function ( renderer, scene, camera ) {\n\n\t\t\t\t\tthis.matrixWorld.copyPosition( camera.matrixWorld );\n\n\t\t\t\t};\n\n\t\t\t\tgeometries.update( boxMesh.geometry );\n\n\t\t\t}\n\n\t\t\tboxMesh.material.uniforms.tCube.value = background;\n\n\t\t\trenderList.push( boxMesh, boxMesh.geometry, boxMesh.material, 0, null );\n\n\t\t} else if ( background && background.isTexture ) {\n\n\t\t\tif ( planeCamera === undefined ) {\n\n\t\t\t\tplaneCamera = new OrthographicCamera( - 1, 1, 1, - 1, 0, 1 );\n\n\t\t\t\tplaneMesh = new Mesh(\n\t\t\t\t\tnew PlaneBufferGeometry( 2, 2 ),\n\t\t\t\t\tnew MeshBasicMaterial( { depthTest: false, depthWrite: false, fog: false } )\n\t\t\t\t);\n\n\t\t\t\tgeometries.update( planeMesh.geometry );\n\n\t\t\t}\n\n\t\t\tplaneMesh.material.map = background;\n\n\t\t\t// TODO Push this to renderList\n\n\t\t\trenderer.renderBufferDirect( planeCamera, null, planeMesh.geometry, planeMesh.material, planeMesh, null );\n\n\t\t}\n\n\t}\n\n\tfunction setClear( color, alpha ) {\n\n\t\tstate.buffers.color.setClear( color.r, color.g, color.b, alpha, premultipliedAlpha );\n\n\t}\n\n\treturn {\n\n\t\tgetClearColor: function () {\n\n\t\t\treturn clearColor;\n\n\t\t},\n\t\tsetClearColor: function ( color, alpha ) {\n\n\t\t\tclearColor.set( color );\n\t\t\tclearAlpha = alpha !== undefined ? alpha : 1;\n\t\t\tsetClear( clearColor, clearAlpha );\n\n\t\t},\n\t\tgetClearAlpha: function () {\n\n\t\t\treturn clearAlpha;\n\n\t\t},\n\t\tsetClearAlpha: function ( alpha ) {\n\n\t\t\tclearAlpha = alpha;\n\t\t\tsetClear( clearColor, clearAlpha );\n\n\t\t},\n\t\trender: render\n\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLBufferRenderer( gl, extensions, info ) {\n\n\tvar mode;\n\n\tfunction setMode( value ) {\n\n\t\tmode = value;\n\n\t}\n\n\tfunction render( start, count ) {\n\n\t\tgl.drawArrays( mode, start, count );\n\n\t\tinfo.update( count, mode );\n\n\t}\n\n\tfunction renderInstances( geometry, start, count ) {\n\n\t\tvar extension = extensions.get( 'ANGLE_instanced_arrays' );\n\n\t\tif ( extension === null ) {\n\n\t\t\tconsole.error( 'THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tvar position = geometry.attributes.position;\n\n\t\tif ( position.isInterleavedBufferAttribute ) {\n\n\t\t\tcount = position.data.count;\n\n\t\t\textension.drawArraysInstancedANGLE( mode, 0, count, geometry.maxInstancedCount );\n\n\t\t} else {\n\n\t\t\textension.drawArraysInstancedANGLE( mode, start, count, geometry.maxInstancedCount );\n\n\t\t}\n\n\t\tinfo.update( count, mode, geometry.maxInstancedCount );\n\n\t}\n\n\t//\n\n\tthis.setMode = setMode;\n\tthis.render = render;\n\tthis.renderInstances = renderInstances;\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLCapabilities( gl, extensions, parameters ) {\n\n\tvar maxAnisotropy;\n\n\tfunction getMaxAnisotropy() {\n\n\t\tif ( maxAnisotropy !== undefined ) return maxAnisotropy;\n\n\t\tvar extension = extensions.get( 'EXT_texture_filter_anisotropic' );\n\n\t\tif ( extension !== null ) {\n\n\t\t\tmaxAnisotropy = gl.getParameter( extension.MAX_TEXTURE_MAX_ANISOTROPY_EXT );\n\n\t\t} else {\n\n\t\t\tmaxAnisotropy = 0;\n\n\t\t}\n\n\t\treturn maxAnisotropy;\n\n\t}\n\n\tfunction getMaxPrecision( precision ) {\n\n\t\tif ( precision === 'highp' ) {\n\n\t\t\tif ( gl.getShaderPrecisionFormat( gl.VERTEX_SHADER, gl.HIGH_FLOAT ).precision > 0 &&\n\t\t\t     gl.getShaderPrecisionFormat( gl.FRAGMENT_SHADER, gl.HIGH_FLOAT ).precision > 0 ) {\n\n\t\t\t\treturn 'highp';\n\n\t\t\t}\n\n\t\t\tprecision = 'mediump';\n\n\t\t}\n\n\t\tif ( precision === 'mediump' ) {\n\n\t\t\tif ( gl.getShaderPrecisionFormat( gl.VERTEX_SHADER, gl.MEDIUM_FLOAT ).precision > 0 &&\n\t\t\t     gl.getShaderPrecisionFormat( gl.FRAGMENT_SHADER, gl.MEDIUM_FLOAT ).precision > 0 ) {\n\n\t\t\t\treturn 'mediump';\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn 'lowp';\n\n\t}\n\n\tvar precision = parameters.precision !== undefined ? parameters.precision : 'highp';\n\tvar maxPrecision = getMaxPrecision( precision );\n\n\tif ( maxPrecision !== precision ) {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer:', precision, 'not supported, using', maxPrecision, 'instead.' );\n\t\tprecision = maxPrecision;\n\n\t}\n\n\tvar logarithmicDepthBuffer = parameters.logarithmicDepthBuffer === true;\n\n\tvar maxTextures = gl.getParameter( gl.MAX_TEXTURE_IMAGE_UNITS );\n\tvar maxVertexTextures = gl.getParameter( gl.MAX_VERTEX_TEXTURE_IMAGE_UNITS );\n\tvar maxTextureSize = gl.getParameter( gl.MAX_TEXTURE_SIZE );\n\tvar maxCubemapSize = gl.getParameter( gl.MAX_CUBE_MAP_TEXTURE_SIZE );\n\n\tvar maxAttributes = gl.getParameter( gl.MAX_VERTEX_ATTRIBS );\n\tvar maxVertexUniforms = gl.getParameter( gl.MAX_VERTEX_UNIFORM_VECTORS );\n\tvar maxVaryings = gl.getParameter( gl.MAX_VARYING_VECTORS );\n\tvar maxFragmentUniforms = gl.getParameter( gl.MAX_FRAGMENT_UNIFORM_VECTORS );\n\n\tvar vertexTextures = maxVertexTextures > 0;\n\tvar floatFragmentTextures = !! extensions.get( 'OES_texture_float' );\n\tvar floatVertexTextures = vertexTextures && floatFragmentTextures;\n\n\treturn {\n\n\t\tgetMaxAnisotropy: getMaxAnisotropy,\n\t\tgetMaxPrecision: getMaxPrecision,\n\n\t\tprecision: precision,\n\t\tlogarithmicDepthBuffer: logarithmicDepthBuffer,\n\n\t\tmaxTextures: maxTextures,\n\t\tmaxVertexTextures: maxVertexTextures,\n\t\tmaxTextureSize: maxTextureSize,\n\t\tmaxCubemapSize: maxCubemapSize,\n\n\t\tmaxAttributes: maxAttributes,\n\t\tmaxVertexUniforms: maxVertexUniforms,\n\t\tmaxVaryings: maxVaryings,\n\t\tmaxFragmentUniforms: maxFragmentUniforms,\n\n\t\tvertexTextures: vertexTextures,\n\t\tfloatFragmentTextures: floatFragmentTextures,\n\t\tfloatVertexTextures: floatVertexTextures\n\n\t};\n\n}\n\n/**\n * @author tschw\n */\n\nfunction WebGLClipping() {\n\n\tvar scope = this,\n\n\t\tglobalState = null,\n\t\tnumGlobalPlanes = 0,\n\t\tlocalClippingEnabled = false,\n\t\trenderingShadows = false,\n\n\t\tplane = new Plane(),\n\t\tviewNormalMatrix = new Matrix3(),\n\n\t\tuniform = { value: null, needsUpdate: false };\n\n\tthis.uniform = uniform;\n\tthis.numPlanes = 0;\n\tthis.numIntersection = 0;\n\n\tthis.init = function ( planes, enableLocalClipping, camera ) {\n\n\t\tvar enabled =\n\t\t\tplanes.length !== 0 ||\n\t\t\tenableLocalClipping ||\n\t\t\t// enable state of previous frame - the clipping code has to\n\t\t\t// run another frame in order to reset the state:\n\t\t\tnumGlobalPlanes !== 0 ||\n\t\t\tlocalClippingEnabled;\n\n\t\tlocalClippingEnabled = enableLocalClipping;\n\n\t\tglobalState = projectPlanes( planes, camera, 0 );\n\t\tnumGlobalPlanes = planes.length;\n\n\t\treturn enabled;\n\n\t};\n\n\tthis.beginShadows = function () {\n\n\t\trenderingShadows = true;\n\t\tprojectPlanes( null );\n\n\t};\n\n\tthis.endShadows = function () {\n\n\t\trenderingShadows = false;\n\t\tresetGlobalState();\n\n\t};\n\n\tthis.setState = function ( planes, clipIntersection, clipShadows, camera, cache, fromCache ) {\n\n\t\tif ( ! localClippingEnabled || planes === null || planes.length === 0 || renderingShadows && ! clipShadows ) {\n\n\t\t\t// there's no local clipping\n\n\t\t\tif ( renderingShadows ) {\n\n\t\t\t\t// there's no global clipping\n\n\t\t\t\tprojectPlanes( null );\n\n\t\t\t} else {\n\n\t\t\t\tresetGlobalState();\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tvar nGlobal = renderingShadows ? 0 : numGlobalPlanes,\n\t\t\t\tlGlobal = nGlobal * 4,\n\n\t\t\t\tdstArray = cache.clippingState || null;\n\n\t\t\tuniform.value = dstArray; // ensure unique state\n\n\t\t\tdstArray = projectPlanes( planes, camera, lGlobal, fromCache );\n\n\t\t\tfor ( var i = 0; i !== lGlobal; ++ i ) {\n\n\t\t\t\tdstArray[ i ] = globalState[ i ];\n\n\t\t\t}\n\n\t\t\tcache.clippingState = dstArray;\n\t\t\tthis.numIntersection = clipIntersection ? this.numPlanes : 0;\n\t\t\tthis.numPlanes += nGlobal;\n\n\t\t}\n\n\n\t};\n\n\tfunction resetGlobalState() {\n\n\t\tif ( uniform.value !== globalState ) {\n\n\t\t\tuniform.value = globalState;\n\t\t\tuniform.needsUpdate = numGlobalPlanes > 0;\n\n\t\t}\n\n\t\tscope.numPlanes = numGlobalPlanes;\n\t\tscope.numIntersection = 0;\n\n\t}\n\n\tfunction projectPlanes( planes, camera, dstOffset, skipTransform ) {\n\n\t\tvar nPlanes = planes !== null ? planes.length : 0,\n\t\t\tdstArray = null;\n\n\t\tif ( nPlanes !== 0 ) {\n\n\t\t\tdstArray = uniform.value;\n\n\t\t\tif ( skipTransform !== true || dstArray === null ) {\n\n\t\t\t\tvar flatSize = dstOffset + nPlanes * 4,\n\t\t\t\t\tviewMatrix = camera.matrixWorldInverse;\n\n\t\t\t\tviewNormalMatrix.getNormalMatrix( viewMatrix );\n\n\t\t\t\tif ( dstArray === null || dstArray.length < flatSize ) {\n\n\t\t\t\t\tdstArray = new Float32Array( flatSize );\n\n\t\t\t\t}\n\n\t\t\t\tfor ( var i = 0, i4 = dstOffset; i !== nPlanes; ++ i, i4 += 4 ) {\n\n\t\t\t\t\tplane.copy( planes[ i ] ).applyMatrix4( viewMatrix, viewNormalMatrix );\n\n\t\t\t\t\tplane.normal.toArray( dstArray, i4 );\n\t\t\t\t\tdstArray[ i4 + 3 ] = plane.constant;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tuniform.value = dstArray;\n\t\t\tuniform.needsUpdate = true;\n\n\t\t}\n\n\t\tscope.numPlanes = nPlanes;\n\n\t\treturn dstArray;\n\n\t}\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLExtensions( gl ) {\n\n\tvar extensions = {};\n\n\treturn {\n\n\t\tget: function ( name ) {\n\n\t\t\tif ( extensions[ name ] !== undefined ) {\n\n\t\t\t\treturn extensions[ name ];\n\n\t\t\t}\n\n\t\t\tvar extension;\n\n\t\t\tswitch ( name ) {\n\n\t\t\t\tcase 'WEBGL_depth_texture':\n\t\t\t\t\textension = gl.getExtension( 'WEBGL_depth_texture' ) || gl.getExtension( 'MOZ_WEBGL_depth_texture' ) || gl.getExtension( 'WEBKIT_WEBGL_depth_texture' );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'EXT_texture_filter_anisotropic':\n\t\t\t\t\textension = gl.getExtension( 'EXT_texture_filter_anisotropic' ) || gl.getExtension( 'MOZ_EXT_texture_filter_anisotropic' ) || gl.getExtension( 'WEBKIT_EXT_texture_filter_anisotropic' );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'WEBGL_compressed_texture_s3tc':\n\t\t\t\t\textension = gl.getExtension( 'WEBGL_compressed_texture_s3tc' ) || gl.getExtension( 'MOZ_WEBGL_compressed_texture_s3tc' ) || gl.getExtension( 'WEBKIT_WEBGL_compressed_texture_s3tc' );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'WEBGL_compressed_texture_pvrtc':\n\t\t\t\t\textension = gl.getExtension( 'WEBGL_compressed_texture_pvrtc' ) || gl.getExtension( 'WEBKIT_WEBGL_compressed_texture_pvrtc' );\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\textension = gl.getExtension( name );\n\n\t\t\t}\n\n\t\t\tif ( extension === null ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: ' + name + ' extension not supported.' );\n\n\t\t\t}\n\n\t\t\textensions[ name ] = extension;\n\n\t\t\treturn extension;\n\n\t\t}\n\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLGeometries( gl, attributes, info ) {\n\n\tvar geometries = {};\n\tvar wireframeAttributes = {};\n\n\tfunction onGeometryDispose( event ) {\n\n\t\tvar geometry = event.target;\n\t\tvar buffergeometry = geometries[ geometry.id ];\n\n\t\tif ( buffergeometry.index !== null ) {\n\n\t\t\tattributes.remove( buffergeometry.index );\n\n\t\t}\n\n\t\tfor ( var name in buffergeometry.attributes ) {\n\n\t\t\tattributes.remove( buffergeometry.attributes[ name ] );\n\n\t\t}\n\n\t\tgeometry.removeEventListener( 'dispose', onGeometryDispose );\n\n\t\tdelete geometries[ geometry.id ];\n\n\t\t// TODO Remove duplicate code\n\n\t\tvar attribute = wireframeAttributes[ geometry.id ];\n\n\t\tif ( attribute ) {\n\n\t\t\tattributes.remove( attribute );\n\t\t\tdelete wireframeAttributes[ geometry.id ];\n\n\t\t}\n\n\t\tattribute = wireframeAttributes[ buffergeometry.id ];\n\n\t\tif ( attribute ) {\n\n\t\t\tattributes.remove( attribute );\n\t\t\tdelete wireframeAttributes[ buffergeometry.id ];\n\n\t\t}\n\n\t\t//\n\n\t\tinfo.memory.geometries --;\n\n\t}\n\n\tfunction get( object, geometry ) {\n\n\t\tvar buffergeometry = geometries[ geometry.id ];\n\n\t\tif ( buffergeometry ) return buffergeometry;\n\n\t\tgeometry.addEventListener( 'dispose', onGeometryDispose );\n\n\t\tif ( geometry.isBufferGeometry ) {\n\n\t\t\tbuffergeometry = geometry;\n\n\t\t} else if ( geometry.isGeometry ) {\n\n\t\t\tif ( geometry._bufferGeometry === undefined ) {\n\n\t\t\t\tgeometry._bufferGeometry = new BufferGeometry().setFromObject( object );\n\n\t\t\t}\n\n\t\t\tbuffergeometry = geometry._bufferGeometry;\n\n\t\t}\n\n\t\tgeometries[ geometry.id ] = buffergeometry;\n\n\t\tinfo.memory.geometries ++;\n\n\t\treturn buffergeometry;\n\n\t}\n\n\tfunction update( geometry ) {\n\n\t\tvar index = geometry.index;\n\t\tvar geometryAttributes = geometry.attributes;\n\n\t\tif ( index !== null ) {\n\n\t\t\tattributes.update( index, gl.ELEMENT_ARRAY_BUFFER );\n\n\t\t}\n\n\t\tfor ( var name in geometryAttributes ) {\n\n\t\t\tattributes.update( geometryAttributes[ name ], gl.ARRAY_BUFFER );\n\n\t\t}\n\n\t\t// morph targets\n\n\t\tvar morphAttributes = geometry.morphAttributes;\n\n\t\tfor ( var name in morphAttributes ) {\n\n\t\t\tvar array = morphAttributes[ name ];\n\n\t\t\tfor ( var i = 0, l = array.length; i < l; i ++ ) {\n\n\t\t\t\tattributes.update( array[ i ], gl.ARRAY_BUFFER );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction getWireframeAttribute( geometry ) {\n\n\t\tvar attribute = wireframeAttributes[ geometry.id ];\n\n\t\tif ( attribute ) return attribute;\n\n\t\tvar indices = [];\n\n\t\tvar geometryIndex = geometry.index;\n\t\tvar geometryAttributes = geometry.attributes;\n\n\t\t// console.time( 'wireframe' );\n\n\t\tif ( geometryIndex !== null ) {\n\n\t\t\tvar array = geometryIndex.array;\n\n\t\t\tfor ( var i = 0, l = array.length; i < l; i += 3 ) {\n\n\t\t\t\tvar a = array[ i + 0 ];\n\t\t\t\tvar b = array[ i + 1 ];\n\t\t\t\tvar c = array[ i + 2 ];\n\n\t\t\t\tindices.push( a, b, b, c, c, a );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tvar array = geometryAttributes.position.array;\n\n\t\t\tfor ( var i = 0, l = ( array.length / 3 ) - 1; i < l; i += 3 ) {\n\n\t\t\t\tvar a = i + 0;\n\t\t\t\tvar b = i + 1;\n\t\t\t\tvar c = i + 2;\n\n\t\t\t\tindices.push( a, b, b, c, c, a );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// console.timeEnd( 'wireframe' );\n\n\t\tattribute = new ( arrayMax( indices ) > 65535 ? Uint32BufferAttribute : Uint16BufferAttribute )( indices, 1 );\n\n\t\tattributes.update( attribute, gl.ELEMENT_ARRAY_BUFFER );\n\n\t\twireframeAttributes[ geometry.id ] = attribute;\n\n\t\treturn attribute;\n\n\t}\n\n\treturn {\n\n\t\tget: get,\n\t\tupdate: update,\n\n\t\tgetWireframeAttribute: getWireframeAttribute\n\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLIndexedBufferRenderer( gl, extensions, info ) {\n\n\tvar mode;\n\n\tfunction setMode( value ) {\n\n\t\tmode = value;\n\n\t}\n\n\tvar type, bytesPerElement;\n\n\tfunction setIndex( value ) {\n\n\t\ttype = value.type;\n\t\tbytesPerElement = value.bytesPerElement;\n\n\t}\n\n\tfunction render( start, count ) {\n\n\t\tgl.drawElements( mode, count, type, start * bytesPerElement );\n\n\t\tinfo.update( count, mode );\n\n\t}\n\n\tfunction renderInstances( geometry, start, count ) {\n\n\t\tvar extension = extensions.get( 'ANGLE_instanced_arrays' );\n\n\t\tif ( extension === null ) {\n\n\t\t\tconsole.error( 'THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\textension.drawElementsInstancedANGLE( mode, count, type, start * bytesPerElement, geometry.maxInstancedCount );\n\n\t\tinfo.update( count, mode, geometry.maxInstancedCount );\n\n\t}\n\n\t//\n\n\tthis.setMode = setMode;\n\tthis.setIndex = setIndex;\n\tthis.render = render;\n\tthis.renderInstances = renderInstances;\n\n}\n\n/**\n * @author Mugen87 / https://github.com/Mugen87\n */\n\nfunction WebGLInfo( gl ) {\n\n\tvar memory = {\n\t\tgeometries: 0,\n\t\ttextures: 0\n\t};\n\n\tvar render = {\n\t\tframe: 0,\n\t\tcalls: 0,\n\t\ttriangles: 0,\n\t\tpoints: 0,\n\t\tlines: 0\n\t};\n\n\tfunction update( count, mode, instanceCount ) {\n\n\t\tinstanceCount = instanceCount || 1;\n\n\t\trender.calls ++;\n\n\t\tswitch ( mode ) {\n\n\t\t\tcase gl.TRIANGLES:\n\t\t\t\trender.triangles += instanceCount * ( count / 3 );\n\t\t\t\tbreak;\n\n\t\t\tcase gl.TRIANGLE_STRIP:\n\t\t\tcase gl.TRIANGLE_FAN:\n\t\t\t\trender.triangles += instanceCount * ( count - 2 );\n\t\t\t\tbreak;\n\n\t\t\tcase gl.LINES:\n\t\t\t\trender.lines += instanceCount * ( count / 2 );\n\t\t\t\tbreak;\n\n\t\t\tcase gl.LINE_STRIP:\n\t\t\t\trender.lines += instanceCount * ( count - 1 );\n\t\t\t\tbreak;\n\n\t\t\tcase gl.LINE_LOOP:\n\t\t\t\trender.lines += instanceCount * count;\n\t\t\t\tbreak;\n\n\t\t\tcase gl.POINTS:\n\t\t\t\trender.points += instanceCount * count;\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tconsole.error( 'THREE.WebGLInfo: Unknown draw mode:', mode );\n\t\t\t\tbreak;\n\n\t\t}\n\n\t}\n\n\tfunction reset() {\n\n\t\trender.frame ++;\n\t\trender.calls = 0;\n\t\trender.triangles = 0;\n\t\trender.points = 0;\n\t\trender.lines = 0;\n\n\t}\n\n\treturn {\n\t\tmemory: memory,\n\t\trender: render,\n\t\tprograms: null,\n\t\tautoReset: true,\n\t\treset: reset,\n\t\tupdate: update\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction absNumericalSort( a, b ) {\n\n\treturn Math.abs( b[ 1 ] ) - Math.abs( a[ 1 ] );\n\n}\n\nfunction WebGLMorphtargets( gl ) {\n\n\tvar influencesList = {};\n\tvar morphInfluences = new Float32Array( 8 );\n\n\tfunction update( object, geometry, material, program ) {\n\n\t\tvar objectInfluences = object.morphTargetInfluences;\n\n\t\tvar length = objectInfluences.length;\n\n\t\tvar influences = influencesList[ geometry.id ];\n\n\t\tif ( influences === undefined ) {\n\n\t\t\t// initialise list\n\n\t\t\tinfluences = [];\n\n\t\t\tfor ( var i = 0; i < length; i ++ ) {\n\n\t\t\t\tinfluences[ i ] = [ i, 0 ];\n\n\t\t\t}\n\n\t\t\tinfluencesList[ geometry.id ] = influences;\n\n\t\t}\n\n\t\tvar morphTargets = material.morphTargets && geometry.morphAttributes.position;\n\t\tvar morphNormals = material.morphNormals && geometry.morphAttributes.normal;\n\n\t\t// Remove current morphAttributes\n\n\t\tfor ( var i = 0; i < length; i ++ ) {\n\n\t\t\tvar influence = influences[ i ];\n\n\t\t\tif ( influence[ 1 ] !== 0 ) {\n\n\t\t\t\tif ( morphTargets ) geometry.removeAttribute( 'morphTarget' + i );\n\t\t\t\tif ( morphNormals ) geometry.removeAttribute( 'morphNormal' + i );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Collect influences\n\n\t\tfor ( var i = 0; i < length; i ++ ) {\n\n\t\t\tvar influence = influences[ i ];\n\n\t\t\tinfluence[ 0 ] = i;\n\t\t\tinfluence[ 1 ] = objectInfluences[ i ];\n\n\t\t}\n\n\t\tinfluences.sort( absNumericalSort );\n\n\t\t// Add morphAttributes\n\n\t\tfor ( var i = 0; i < 8; i ++ ) {\n\n\t\t\tvar influence = influences[ i ];\n\n\t\t\tif ( influence ) {\n\n\t\t\t\tvar index = influence[ 0 ];\n\t\t\t\tvar value = influence[ 1 ];\n\n\t\t\t\tif ( value ) {\n\n\t\t\t\t\tif ( morphTargets ) geometry.addAttribute( 'morphTarget' + i, morphTargets[ index ] );\n\t\t\t\t\tif ( morphNormals ) geometry.addAttribute( 'morphNormal' + i, morphNormals[ index ] );\n\n\t\t\t\t\tmorphInfluences[ i ] = value;\n\t\t\t\t\tcontinue;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tmorphInfluences[ i ] = 0;\n\n\t\t}\n\n\t\tprogram.getUniforms().setValue( gl, 'morphTargetInfluences', morphInfluences );\n\n\t}\n\n\treturn {\n\n\t\tupdate: update\n\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLObjects( geometries, info ) {\n\n\tvar updateList = {};\n\n\tfunction update( object ) {\n\n\t\tvar frame = info.render.frame;\n\n\t\tvar geometry = object.geometry;\n\t\tvar buffergeometry = geometries.get( object, geometry );\n\n\t\t// Update once per frame\n\n\t\tif ( updateList[ buffergeometry.id ] !== frame ) {\n\n\t\t\tif ( geometry.isGeometry ) {\n\n\t\t\t\tbuffergeometry.updateFromObject( object );\n\n\t\t\t}\n\n\t\t\tgeometries.update( buffergeometry );\n\n\t\t\tupdateList[ buffergeometry.id ] = frame;\n\n\t\t}\n\n\t\treturn buffergeometry;\n\n\t}\n\n\tfunction dispose() {\n\n\t\tupdateList = {};\n\n\t}\n\n\treturn {\n\n\t\tupdate: update,\n\t\tdispose: dispose\n\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction CubeTexture( images, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding ) {\n\n\timages = images !== undefined ? images : [];\n\tmapping = mapping !== undefined ? mapping : CubeReflectionMapping;\n\n\tTexture.call( this, images, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding );\n\n\tthis.flipY = false;\n\n}\n\nCubeTexture.prototype = Object.create( Texture.prototype );\nCubeTexture.prototype.constructor = CubeTexture;\n\nCubeTexture.prototype.isCubeTexture = true;\n\nObject.defineProperty( CubeTexture.prototype, 'images', {\n\n\tget: function () {\n\n\t\treturn this.image;\n\n\t},\n\n\tset: function ( value ) {\n\n\t\tthis.image = value;\n\n\t}\n\n} );\n\n/**\n * @author tschw\n *\n * Uniforms of a program.\n * Those form a tree structure with a special top-level container for the root,\n * which you get by calling 'new WebGLUniforms( gl, program, renderer )'.\n *\n *\n * Properties of inner nodes including the top-level container:\n *\n * .seq - array of nested uniforms\n * .map - nested uniforms by name\n *\n *\n * Methods of all nodes except the top-level container:\n *\n * .setValue( gl, value, [renderer] )\n *\n * \t\tuploads a uniform value(s)\n *  \tthe 'renderer' parameter is needed for sampler uniforms\n *\n *\n * Static methods of the top-level container (renderer factorizations):\n *\n * .upload( gl, seq, values, renderer )\n *\n * \t\tsets uniforms in 'seq' to 'values[id].value'\n *\n * .seqWithValue( seq, values ) : filteredSeq\n *\n * \t\tfilters 'seq' entries with corresponding entry in values\n *\n *\n * Methods of the top-level container (renderer factorizations):\n *\n * .setValue( gl, name, value )\n *\n * \t\tsets uniform with  name 'name' to 'value'\n *\n * .set( gl, obj, prop )\n *\n * \t\tsets uniform from object and property with same name than uniform\n *\n * .setOptional( gl, obj, prop )\n *\n * \t\tlike .set for an optional property of the object\n *\n */\n\nvar emptyTexture = new Texture();\nvar emptyCubeTexture = new CubeTexture();\n\n// --- Base for inner nodes (including the root) ---\n\nfunction UniformContainer() {\n\n\tthis.seq = [];\n\tthis.map = {};\n\n}\n\n// --- Utilities ---\n\n// Array Caches (provide typed arrays for temporary by size)\n\nvar arrayCacheF32 = [];\nvar arrayCacheI32 = [];\n\n// Float32Array caches used for uploading Matrix uniforms\n\nvar mat4array = new Float32Array( 16 );\nvar mat3array = new Float32Array( 9 );\n\n// Flattening for arrays of vectors and matrices\n\nfunction flatten( array, nBlocks, blockSize ) {\n\n\tvar firstElem = array[ 0 ];\n\n\tif ( firstElem <= 0 || firstElem > 0 ) return array;\n\t// unoptimized: ! isNaN( firstElem )\n\t// see http://jacksondunstan.com/articles/983\n\n\tvar n = nBlocks * blockSize,\n\t\tr = arrayCacheF32[ n ];\n\n\tif ( r === undefined ) {\n\n\t\tr = new Float32Array( n );\n\t\tarrayCacheF32[ n ] = r;\n\n\t}\n\n\tif ( nBlocks !== 0 ) {\n\n\t\tfirstElem.toArray( r, 0 );\n\n\t\tfor ( var i = 1, offset = 0; i !== nBlocks; ++ i ) {\n\n\t\t\toffset += blockSize;\n\t\t\tarray[ i ].toArray( r, offset );\n\n\t\t}\n\n\t}\n\n\treturn r;\n\n}\n\n// Texture unit allocation\n\nfunction allocTexUnits( renderer, n ) {\n\n\tvar r = arrayCacheI32[ n ];\n\n\tif ( r === undefined ) {\n\n\t\tr = new Int32Array( n );\n\t\tarrayCacheI32[ n ] = r;\n\n\t}\n\n\tfor ( var i = 0; i !== n; ++ i )\n\t\tr[ i ] = renderer.allocTextureUnit();\n\n\treturn r;\n\n}\n\n// --- Setters ---\n\n// Note: Defining these methods externally, because they come in a bunch\n// and this way their names minify.\n\n// Single scalar\n\nfunction setValue1f( gl, v ) {\n\n\tgl.uniform1f( this.addr, v );\n\n}\n\nfunction setValue1i( gl, v ) {\n\n\tgl.uniform1i( this.addr, v );\n\n}\n\n// Single float vector (from flat array or THREE.VectorN)\n\nfunction setValue2fv( gl, v ) {\n\n\tif ( v.x === undefined ) {\n\n\t\tgl.uniform2fv( this.addr, v );\n\n\t} else {\n\n\t\tgl.uniform2f( this.addr, v.x, v.y );\n\n\t}\n\n}\n\nfunction setValue3fv( gl, v ) {\n\n\tif ( v.x !== undefined ) {\n\n\t\tgl.uniform3f( this.addr, v.x, v.y, v.z );\n\n\t} else if ( v.r !== undefined ) {\n\n\t\tgl.uniform3f( this.addr, v.r, v.g, v.b );\n\n\t} else {\n\n\t\tgl.uniform3fv( this.addr, v );\n\n\t}\n\n}\n\nfunction setValue4fv( gl, v ) {\n\n\tif ( v.x === undefined ) {\n\n\t\tgl.uniform4fv( this.addr, v );\n\n\t} else {\n\n\t\t gl.uniform4f( this.addr, v.x, v.y, v.z, v.w );\n\n\t}\n\n}\n\n// Single matrix (from flat array or MatrixN)\n\nfunction setValue2fm( gl, v ) {\n\n\tgl.uniformMatrix2fv( this.addr, false, v.elements || v );\n\n}\n\nfunction setValue3fm( gl, v ) {\n\n\tif ( v.elements === undefined ) {\n\n\t\tgl.uniformMatrix3fv( this.addr, false, v );\n\n\t} else {\n\n\t\tmat3array.set( v.elements );\n\t\tgl.uniformMatrix3fv( this.addr, false, mat3array );\n\n\t}\n\n}\n\nfunction setValue4fm( gl, v ) {\n\n\tif ( v.elements === undefined ) {\n\n\t\tgl.uniformMatrix4fv( this.addr, false, v );\n\n\t} else {\n\n\t\tmat4array.set( v.elements );\n\t\tgl.uniformMatrix4fv( this.addr, false, mat4array );\n\n\t}\n\n}\n\n// Single texture (2D / Cube)\n\nfunction setValueT1( gl, v, renderer ) {\n\n\tvar unit = renderer.allocTextureUnit();\n\tgl.uniform1i( this.addr, unit );\n\trenderer.setTexture2D( v || emptyTexture, unit );\n\n}\n\nfunction setValueT6( gl, v, renderer ) {\n\n\tvar unit = renderer.allocTextureUnit();\n\tgl.uniform1i( this.addr, unit );\n\trenderer.setTextureCube( v || emptyCubeTexture, unit );\n\n}\n\n// Integer / Boolean vectors or arrays thereof (always flat arrays)\n\nfunction setValue2iv( gl, v ) {\n\n\tgl.uniform2iv( this.addr, v );\n\n}\n\nfunction setValue3iv( gl, v ) {\n\n\tgl.uniform3iv( this.addr, v );\n\n}\n\nfunction setValue4iv( gl, v ) {\n\n\tgl.uniform4iv( this.addr, v );\n\n}\n\n// Helper to pick the right setter for the singular case\n\nfunction getSingularSetter( type ) {\n\n\tswitch ( type ) {\n\n\t\tcase 0x1406: return setValue1f; // FLOAT\n\t\tcase 0x8b50: return setValue2fv; // _VEC2\n\t\tcase 0x8b51: return setValue3fv; // _VEC3\n\t\tcase 0x8b52: return setValue4fv; // _VEC4\n\n\t\tcase 0x8b5a: return setValue2fm; // _MAT2\n\t\tcase 0x8b5b: return setValue3fm; // _MAT3\n\t\tcase 0x8b5c: return setValue4fm; // _MAT4\n\n\t\tcase 0x8b5e: case 0x8d66: return setValueT1; // SAMPLER_2D, SAMPLER_EXTERNAL_OES\n\t\tcase 0x8b60: return setValueT6; // SAMPLER_CUBE\n\n\t\tcase 0x1404: case 0x8b56: return setValue1i; // INT, BOOL\n\t\tcase 0x8b53: case 0x8b57: return setValue2iv; // _VEC2\n\t\tcase 0x8b54: case 0x8b58: return setValue3iv; // _VEC3\n\t\tcase 0x8b55: case 0x8b59: return setValue4iv; // _VEC4\n\n\t}\n\n}\n\n// Array of scalars\n\nfunction setValue1fv( gl, v ) {\n\n\tgl.uniform1fv( this.addr, v );\n\n}\nfunction setValue1iv( gl, v ) {\n\n\tgl.uniform1iv( this.addr, v );\n\n}\n\n// Array of vectors (flat or from THREE classes)\n\nfunction setValueV2a( gl, v ) {\n\n\tgl.uniform2fv( this.addr, flatten( v, this.size, 2 ) );\n\n}\n\nfunction setValueV3a( gl, v ) {\n\n\tgl.uniform3fv( this.addr, flatten( v, this.size, 3 ) );\n\n}\n\nfunction setValueV4a( gl, v ) {\n\n\tgl.uniform4fv( this.addr, flatten( v, this.size, 4 ) );\n\n}\n\n// Array of matrices (flat or from THREE clases)\n\nfunction setValueM2a( gl, v ) {\n\n\tgl.uniformMatrix2fv( this.addr, false, flatten( v, this.size, 4 ) );\n\n}\n\nfunction setValueM3a( gl, v ) {\n\n\tgl.uniformMatrix3fv( this.addr, false, flatten( v, this.size, 9 ) );\n\n}\n\nfunction setValueM4a( gl, v ) {\n\n\tgl.uniformMatrix4fv( this.addr, false, flatten( v, this.size, 16 ) );\n\n}\n\n// Array of textures (2D / Cube)\n\nfunction setValueT1a( gl, v, renderer ) {\n\n\tvar n = v.length,\n\t\tunits = allocTexUnits( renderer, n );\n\n\tgl.uniform1iv( this.addr, units );\n\n\tfor ( var i = 0; i !== n; ++ i ) {\n\n\t\trenderer.setTexture2D( v[ i ] || emptyTexture, units[ i ] );\n\n\t}\n\n}\n\nfunction setValueT6a( gl, v, renderer ) {\n\n\tvar n = v.length,\n\t\tunits = allocTexUnits( renderer, n );\n\n\tgl.uniform1iv( this.addr, units );\n\n\tfor ( var i = 0; i !== n; ++ i ) {\n\n\t\trenderer.setTextureCube( v[ i ] || emptyCubeTexture, units[ i ] );\n\n\t}\n\n}\n\n// Helper to pick the right setter for a pure (bottom-level) array\n\nfunction getPureArraySetter( type ) {\n\n\tswitch ( type ) {\n\n\t\tcase 0x1406: return setValue1fv; // FLOAT\n\t\tcase 0x8b50: return setValueV2a; // _VEC2\n\t\tcase 0x8b51: return setValueV3a; // _VEC3\n\t\tcase 0x8b52: return setValueV4a; // _VEC4\n\n\t\tcase 0x8b5a: return setValueM2a; // _MAT2\n\t\tcase 0x8b5b: return setValueM3a; // _MAT3\n\t\tcase 0x8b5c: return setValueM4a; // _MAT4\n\n\t\tcase 0x8b5e: return setValueT1a; // SAMPLER_2D\n\t\tcase 0x8b60: return setValueT6a; // SAMPLER_CUBE\n\n\t\tcase 0x1404: case 0x8b56: return setValue1iv; // INT, BOOL\n\t\tcase 0x8b53: case 0x8b57: return setValue2iv; // _VEC2\n\t\tcase 0x8b54: case 0x8b58: return setValue3iv; // _VEC3\n\t\tcase 0x8b55: case 0x8b59: return setValue4iv; // _VEC4\n\n\t}\n\n}\n\n// --- Uniform Classes ---\n\nfunction SingleUniform( id, activeInfo, addr ) {\n\n\tthis.id = id;\n\tthis.addr = addr;\n\tthis.setValue = getSingularSetter( activeInfo.type );\n\n\t// this.path = activeInfo.name; // DEBUG\n\n}\n\nfunction PureArrayUniform( id, activeInfo, addr ) {\n\n\tthis.id = id;\n\tthis.addr = addr;\n\tthis.size = activeInfo.size;\n\tthis.setValue = getPureArraySetter( activeInfo.type );\n\n\t// this.path = activeInfo.name; // DEBUG\n\n}\n\nfunction StructuredUniform( id ) {\n\n\tthis.id = id;\n\n\tUniformContainer.call( this ); // mix-in\n\n}\n\nStructuredUniform.prototype.setValue = function ( gl, value ) {\n\n\t// Note: Don't need an extra 'renderer' parameter, since samplers\n\t// are not allowed in structured uniforms.\n\n\tvar seq = this.seq;\n\n\tfor ( var i = 0, n = seq.length; i !== n; ++ i ) {\n\n\t\tvar u = seq[ i ];\n\t\tu.setValue( gl, value[ u.id ] );\n\n\t}\n\n};\n\n// --- Top-level ---\n\n// Parser - builds up the property tree from the path strings\n\nvar RePathPart = /([\\w\\d_]+)(\\])?(\\[|\\.)?/g;\n\n// extracts\n// \t- the identifier (member name or array index)\n//  - followed by an optional right bracket (found when array index)\n//  - followed by an optional left bracket or dot (type of subscript)\n//\n// Note: These portions can be read in a non-overlapping fashion and\n// allow straightforward parsing of the hierarchy that WebGL encodes\n// in the uniform names.\n\nfunction addUniform( container, uniformObject ) {\n\n\tcontainer.seq.push( uniformObject );\n\tcontainer.map[ uniformObject.id ] = uniformObject;\n\n}\n\nfunction parseUniform( activeInfo, addr, container ) {\n\n\tvar path = activeInfo.name,\n\t\tpathLength = path.length;\n\n\t// reset RegExp object, because of the early exit of a previous run\n\tRePathPart.lastIndex = 0;\n\n\tfor ( ; ; ) {\n\n\t\tvar match = RePathPart.exec( path ),\n\t\t\tmatchEnd = RePathPart.lastIndex,\n\n\t\t\tid = match[ 1 ],\n\t\t\tidIsIndex = match[ 2 ] === ']',\n\t\t\tsubscript = match[ 3 ];\n\n\t\tif ( idIsIndex ) id = id | 0; // convert to integer\n\n\t\tif ( subscript === undefined || subscript === '[' && matchEnd + 2 === pathLength ) {\n\n\t\t\t// bare name or \"pure\" bottom-level array \"[0]\" suffix\n\n\t\t\taddUniform( container, subscript === undefined ?\n\t\t\t\tnew SingleUniform( id, activeInfo, addr ) :\n\t\t\t\tnew PureArrayUniform( id, activeInfo, addr ) );\n\n\t\t\tbreak;\n\n\t\t} else {\n\n\t\t\t// step into inner node / create it in case it doesn't exist\n\n\t\t\tvar map = container.map, next = map[ id ];\n\n\t\t\tif ( next === undefined ) {\n\n\t\t\t\tnext = new StructuredUniform( id );\n\t\t\t\taddUniform( container, next );\n\n\t\t\t}\n\n\t\t\tcontainer = next;\n\n\t\t}\n\n\t}\n\n}\n\n// Root Container\n\nfunction WebGLUniforms( gl, program, renderer ) {\n\n\tUniformContainer.call( this );\n\n\tthis.renderer = renderer;\n\n\tvar n = gl.getProgramParameter( program, gl.ACTIVE_UNIFORMS );\n\n\tfor ( var i = 0; i < n; ++ i ) {\n\n\t\tvar info = gl.getActiveUniform( program, i ),\n\t\t\taddr = gl.getUniformLocation( program, info.name );\n\n\t\tparseUniform( info, addr, this );\n\n\t}\n\n}\n\nWebGLUniforms.prototype.setValue = function ( gl, name, value ) {\n\n\tvar u = this.map[ name ];\n\n\tif ( u !== undefined ) u.setValue( gl, value, this.renderer );\n\n};\n\nWebGLUniforms.prototype.setOptional = function ( gl, object, name ) {\n\n\tvar v = object[ name ];\n\n\tif ( v !== undefined ) this.setValue( gl, name, v );\n\n};\n\n\n// Static interface\n\nWebGLUniforms.upload = function ( gl, seq, values, renderer ) {\n\n\tfor ( var i = 0, n = seq.length; i !== n; ++ i ) {\n\n\t\tvar u = seq[ i ],\n\t\t\tv = values[ u.id ];\n\n\t\tif ( v.needsUpdate !== false ) {\n\n\t\t\t// note: always updating when .needsUpdate is undefined\n\t\t\tu.setValue( gl, v.value, renderer );\n\n\t\t}\n\n\t}\n\n};\n\nWebGLUniforms.seqWithValue = function ( seq, values ) {\n\n\tvar r = [];\n\n\tfor ( var i = 0, n = seq.length; i !== n; ++ i ) {\n\n\t\tvar u = seq[ i ];\n\t\tif ( u.id in values ) r.push( u );\n\n\t}\n\n\treturn r;\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction addLineNumbers( string ) {\n\n\tvar lines = string.split( '\\n' );\n\n\tfor ( var i = 0; i < lines.length; i ++ ) {\n\n\t\tlines[ i ] = ( i + 1 ) + ': ' + lines[ i ];\n\n\t}\n\n\treturn lines.join( '\\n' );\n\n}\n\nfunction WebGLShader( gl, type, string ) {\n\n\tvar shader = gl.createShader( type );\n\n\tgl.shaderSource( shader, string );\n\tgl.compileShader( shader );\n\n\tif ( gl.getShaderParameter( shader, gl.COMPILE_STATUS ) === false ) {\n\n\t\tconsole.error( 'THREE.WebGLShader: Shader couldn\\'t compile.' );\n\n\t}\n\n\tif ( gl.getShaderInfoLog( shader ) !== '' ) {\n\n\t\tconsole.warn( 'THREE.WebGLShader: gl.getShaderInfoLog()', type === gl.VERTEX_SHADER ? 'vertex' : 'fragment', gl.getShaderInfoLog( shader ), addLineNumbers( string ) );\n\n\t}\n\n\t// --enable-privileged-webgl-extension\n\t// console.log( type, gl.getExtension( 'WEBGL_debug_shaders' ).getTranslatedShaderSource( shader ) );\n\n\treturn shader;\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nvar programIdCount = 0;\n\nfunction getEncodingComponents( encoding ) {\n\n\tswitch ( encoding ) {\n\n\t\tcase LinearEncoding:\n\t\t\treturn [ 'Linear', '( value )' ];\n\t\tcase sRGBEncoding:\n\t\t\treturn [ 'sRGB', '( value )' ];\n\t\tcase RGBEEncoding:\n\t\t\treturn [ 'RGBE', '( value )' ];\n\t\tcase RGBM7Encoding:\n\t\t\treturn [ 'RGBM', '( value, 7.0 )' ];\n\t\tcase RGBM16Encoding:\n\t\t\treturn [ 'RGBM', '( value, 16.0 )' ];\n\t\tcase RGBDEncoding:\n\t\t\treturn [ 'RGBD', '( value, 256.0 )' ];\n\t\tcase GammaEncoding:\n\t\t\treturn [ 'Gamma', '( value, float( GAMMA_FACTOR ) )' ];\n\t\tdefault:\n\t\t\tthrow new Error( 'unsupported encoding: ' + encoding );\n\n\t}\n\n}\n\nfunction getTexelDecodingFunction( functionName, encoding ) {\n\n\tvar components = getEncodingComponents( encoding );\n\treturn 'vec4 ' + functionName + '( vec4 value ) { return ' + components[ 0 ] + 'ToLinear' + components[ 1 ] + '; }';\n\n}\n\nfunction getTexelEncodingFunction( functionName, encoding ) {\n\n\tvar components = getEncodingComponents( encoding );\n\treturn 'vec4 ' + functionName + '( vec4 value ) { return LinearTo' + components[ 0 ] + components[ 1 ] + '; }';\n\n}\n\nfunction getToneMappingFunction( functionName, toneMapping ) {\n\n\tvar toneMappingName;\n\n\tswitch ( toneMapping ) {\n\n\t\tcase LinearToneMapping:\n\t\t\ttoneMappingName = 'Linear';\n\t\t\tbreak;\n\n\t\tcase ReinhardToneMapping:\n\t\t\ttoneMappingName = 'Reinhard';\n\t\t\tbreak;\n\n\t\tcase Uncharted2ToneMapping:\n\t\t\ttoneMappingName = 'Uncharted2';\n\t\t\tbreak;\n\n\t\tcase CineonToneMapping:\n\t\t\ttoneMappingName = 'OptimizedCineon';\n\t\t\tbreak;\n\n\t\tdefault:\n\t\t\tthrow new Error( 'unsupported toneMapping: ' + toneMapping );\n\n\t}\n\n\treturn 'vec3 ' + functionName + '( vec3 color ) { return ' + toneMappingName + 'ToneMapping( color ); }';\n\n}\n\nfunction generateExtensions( extensions, parameters, rendererExtensions ) {\n\n\textensions = extensions || {};\n\n\tvar chunks = [\n\t\t( extensions.derivatives || parameters.envMapCubeUV || parameters.bumpMap || parameters.normalMap || parameters.flatShading ) ? '#extension GL_OES_standard_derivatives : enable' : '',\n\t\t( extensions.fragDepth || parameters.logarithmicDepthBuffer ) && rendererExtensions.get( 'EXT_frag_depth' ) ? '#extension GL_EXT_frag_depth : enable' : '',\n\t\t( extensions.drawBuffers ) && rendererExtensions.get( 'WEBGL_draw_buffers' ) ? '#extension GL_EXT_draw_buffers : require' : '',\n\t\t( extensions.shaderTextureLOD || parameters.envMap ) && rendererExtensions.get( 'EXT_shader_texture_lod' ) ? '#extension GL_EXT_shader_texture_lod : enable' : ''\n\t];\n\n\treturn chunks.filter( filterEmptyLine ).join( '\\n' );\n\n}\n\nfunction generateDefines( defines ) {\n\n\tvar chunks = [];\n\n\tfor ( var name in defines ) {\n\n\t\tvar value = defines[ name ];\n\n\t\tif ( value === false ) continue;\n\n\t\tchunks.push( '#define ' + name + ' ' + value );\n\n\t}\n\n\treturn chunks.join( '\\n' );\n\n}\n\nfunction fetchAttributeLocations( gl, program ) {\n\n\tvar attributes = {};\n\n\tvar n = gl.getProgramParameter( program, gl.ACTIVE_ATTRIBUTES );\n\n\tfor ( var i = 0; i < n; i ++ ) {\n\n\t\tvar info = gl.getActiveAttrib( program, i );\n\t\tvar name = info.name;\n\n\t\t// console.log( 'THREE.WebGLProgram: ACTIVE VERTEX ATTRIBUTE:', name, i );\n\n\t\tattributes[ name ] = gl.getAttribLocation( program, name );\n\n\t}\n\n\treturn attributes;\n\n}\n\nfunction filterEmptyLine( string ) {\n\n\treturn string !== '';\n\n}\n\nfunction replaceLightNums( string, parameters ) {\n\n\treturn string\n\t\t.replace( /NUM_DIR_LIGHTS/g, parameters.numDirLights )\n\t\t.replace( /NUM_SPOT_LIGHTS/g, parameters.numSpotLights )\n\t\t.replace( /NUM_RECT_AREA_LIGHTS/g, parameters.numRectAreaLights )\n\t\t.replace( /NUM_POINT_LIGHTS/g, parameters.numPointLights )\n\t\t.replace( /NUM_HEMI_LIGHTS/g, parameters.numHemiLights );\n\n}\n\nfunction replaceClippingPlaneNums( string, parameters ) {\n\n\treturn string\n\t\t.replace( /NUM_CLIPPING_PLANES/g, parameters.numClippingPlanes )\n\t\t.replace( /UNION_CLIPPING_PLANES/g, ( parameters.numClippingPlanes - parameters.numClipIntersection ) );\n\n}\n\nfunction parseIncludes( string ) {\n\n\tvar pattern = /^[ \\t]*#include +<([\\w\\d.]+)>/gm;\n\n\tfunction replace( match, include ) {\n\n\t\tvar replace = ShaderChunk[ include ];\n\n\t\tif ( replace === undefined ) {\n\n\t\t\tthrow new Error( 'Can not resolve #include <' + include + '>' );\n\n\t\t}\n\n\t\treturn parseIncludes( replace );\n\n\t}\n\n\treturn string.replace( pattern, replace );\n\n}\n\nfunction unrollLoops( string ) {\n\n\tvar pattern = /#pragma unroll_loop[\\s]+?for \\( int i \\= (\\d+)\\; i < (\\d+)\\; i \\+\\+ \\) \\{([\\s\\S]+?)(?=\\})\\}/g;\n\n\tfunction replace( match, start, end, snippet ) {\n\n\t\tvar unroll = '';\n\n\t\tfor ( var i = parseInt( start ); i < parseInt( end ); i ++ ) {\n\n\t\t\tunroll += snippet.replace( /\\[ i \\]/g, '[ ' + i + ' ]' );\n\n\t\t}\n\n\t\treturn unroll;\n\n\t}\n\n\treturn string.replace( pattern, replace );\n\n}\n\nfunction WebGLProgram( renderer, extensions, code, material, shader, parameters ) {\n\n\tvar gl = renderer.context;\n\n\tvar defines = material.defines;\n\n\tvar vertexShader = shader.vertexShader;\n\tvar fragmentShader = shader.fragmentShader;\n\n\tvar shadowMapTypeDefine = 'SHADOWMAP_TYPE_BASIC';\n\n\tif ( parameters.shadowMapType === PCFShadowMap ) {\n\n\t\tshadowMapTypeDefine = 'SHADOWMAP_TYPE_PCF';\n\n\t} else if ( parameters.shadowMapType === PCFSoftShadowMap ) {\n\n\t\tshadowMapTypeDefine = 'SHADOWMAP_TYPE_PCF_SOFT';\n\n\t}\n\n\tvar envMapTypeDefine = 'ENVMAP_TYPE_CUBE';\n\tvar envMapModeDefine = 'ENVMAP_MODE_REFLECTION';\n\tvar envMapBlendingDefine = 'ENVMAP_BLENDING_MULTIPLY';\n\n\tif ( parameters.envMap ) {\n\n\t\tswitch ( material.envMap.mapping ) {\n\n\t\t\tcase CubeReflectionMapping:\n\t\t\tcase CubeRefractionMapping:\n\t\t\t\tenvMapTypeDefine = 'ENVMAP_TYPE_CUBE';\n\t\t\t\tbreak;\n\n\t\t\tcase CubeUVReflectionMapping:\n\t\t\tcase CubeUVRefractionMapping:\n\t\t\t\tenvMapTypeDefine = 'ENVMAP_TYPE_CUBE_UV';\n\t\t\t\tbreak;\n\n\t\t\tcase EquirectangularReflectionMapping:\n\t\t\tcase EquirectangularRefractionMapping:\n\t\t\t\tenvMapTypeDefine = 'ENVMAP_TYPE_EQUIREC';\n\t\t\t\tbreak;\n\n\t\t\tcase SphericalReflectionMapping:\n\t\t\t\tenvMapTypeDefine = 'ENVMAP_TYPE_SPHERE';\n\t\t\t\tbreak;\n\n\t\t}\n\n\t\tswitch ( material.envMap.mapping ) {\n\n\t\t\tcase CubeRefractionMapping:\n\t\t\tcase EquirectangularRefractionMapping:\n\t\t\t\tenvMapModeDefine = 'ENVMAP_MODE_REFRACTION';\n\t\t\t\tbreak;\n\n\t\t}\n\n\t\tswitch ( material.combine ) {\n\n\t\t\tcase MultiplyOperation:\n\t\t\t\tenvMapBlendingDefine = 'ENVMAP_BLENDING_MULTIPLY';\n\t\t\t\tbreak;\n\n\t\t\tcase MixOperation:\n\t\t\t\tenvMapBlendingDefine = 'ENVMAP_BLENDING_MIX';\n\t\t\t\tbreak;\n\n\t\t\tcase AddOperation:\n\t\t\t\tenvMapBlendingDefine = 'ENVMAP_BLENDING_ADD';\n\t\t\t\tbreak;\n\n\t\t}\n\n\t}\n\n\tvar gammaFactorDefine = ( renderer.gammaFactor > 0 ) ? renderer.gammaFactor : 1.0;\n\n\t// console.log( 'building new program ' );\n\n\t//\n\n\tvar customExtensions = generateExtensions( material.extensions, parameters, extensions );\n\n\tvar customDefines = generateDefines( defines );\n\n\t//\n\n\tvar program = gl.createProgram();\n\n\tvar prefixVertex, prefixFragment;\n\n\tif ( material.isRawShaderMaterial ) {\n\n\t\tprefixVertex = [\n\n\t\t\tcustomDefines\n\n\t\t].filter( filterEmptyLine ).join( '\\n' );\n\n\t\tif ( prefixVertex.length > 0 ) {\n\n\t\t\tprefixVertex += '\\n';\n\n\t\t}\n\n\t\tprefixFragment = [\n\n\t\t\tcustomExtensions,\n\t\t\tcustomDefines\n\n\t\t].filter( filterEmptyLine ).join( '\\n' );\n\n\t\tif ( prefixFragment.length > 0 ) {\n\n\t\t\tprefixFragment += '\\n';\n\n\t\t}\n\n\t} else {\n\n\t\tprefixVertex = [\n\n\t\t\t'precision ' + parameters.precision + ' float;',\n\t\t\t'precision ' + parameters.precision + ' int;',\n\n\t\t\t'#define SHADER_NAME ' + shader.name,\n\n\t\t\tcustomDefines,\n\n\t\t\tparameters.supportsVertexTextures ? '#define VERTEX_TEXTURES' : '',\n\n\t\t\t'#define GAMMA_FACTOR ' + gammaFactorDefine,\n\n\t\t\t'#define MAX_BONES ' + parameters.maxBones,\n\t\t\t( parameters.useFog && parameters.fog ) ? '#define USE_FOG' : '',\n\t\t\t( parameters.useFog && parameters.fogExp ) ? '#define FOG_EXP2' : '',\n\n\t\t\tparameters.map ? '#define USE_MAP' : '',\n\t\t\tparameters.envMap ? '#define USE_ENVMAP' : '',\n\t\t\tparameters.envMap ? '#define ' + envMapModeDefine : '',\n\t\t\tparameters.lightMap ? '#define USE_LIGHTMAP' : '',\n\t\t\tparameters.aoMap ? '#define USE_AOMAP' : '',\n\t\t\tparameters.emissiveMap ? '#define USE_EMISSIVEMAP' : '',\n\t\t\tparameters.bumpMap ? '#define USE_BUMPMAP' : '',\n\t\t\tparameters.normalMap ? '#define USE_NORMALMAP' : '',\n\t\t\tparameters.displacementMap && parameters.supportsVertexTextures ? '#define USE_DISPLACEMENTMAP' : '',\n\t\t\tparameters.specularMap ? '#define USE_SPECULARMAP' : '',\n\t\t\tparameters.roughnessMap ? '#define USE_ROUGHNESSMAP' : '',\n\t\t\tparameters.metalnessMap ? '#define USE_METALNESSMAP' : '',\n\t\t\tparameters.alphaMap ? '#define USE_ALPHAMAP' : '',\n\t\t\tparameters.vertexColors ? '#define USE_COLOR' : '',\n\n\t\t\tparameters.flatShading ? '#define FLAT_SHADED' : '',\n\n\t\t\tparameters.skinning ? '#define USE_SKINNING' : '',\n\t\t\tparameters.useVertexTexture ? '#define BONE_TEXTURE' : '',\n\n\t\t\tparameters.morphTargets ? '#define USE_MORPHTARGETS' : '',\n\t\t\tparameters.morphNormals && parameters.flatShading === false ? '#define USE_MORPHNORMALS' : '',\n\t\t\tparameters.doubleSided ? '#define DOUBLE_SIDED' : '',\n\t\t\tparameters.flipSided ? '#define FLIP_SIDED' : '',\n\n\t\t\tparameters.shadowMapEnabled ? '#define USE_SHADOWMAP' : '',\n\t\t\tparameters.shadowMapEnabled ? '#define ' + shadowMapTypeDefine : '',\n\n\t\t\tparameters.sizeAttenuation ? '#define USE_SIZEATTENUATION' : '',\n\n\t\t\tparameters.logarithmicDepthBuffer ? '#define USE_LOGDEPTHBUF' : '',\n\t\t\tparameters.logarithmicDepthBuffer && extensions.get( 'EXT_frag_depth' ) ? '#define USE_LOGDEPTHBUF_EXT' : '',\n\n\t\t\t'uniform mat4 modelMatrix;',\n\t\t\t'uniform mat4 modelViewMatrix;',\n\t\t\t'uniform mat4 projectionMatrix;',\n\t\t\t'uniform mat4 viewMatrix;',\n\t\t\t'uniform mat3 normalMatrix;',\n\t\t\t'uniform vec3 cameraPosition;',\n\n\t\t\t'attribute vec3 position;',\n\t\t\t'attribute vec3 normal;',\n\t\t\t'attribute vec2 uv;',\n\n\t\t\t'#ifdef USE_COLOR',\n\n\t\t\t'\tattribute vec3 color;',\n\n\t\t\t'#endif',\n\n\t\t\t'#ifdef USE_MORPHTARGETS',\n\n\t\t\t'\tattribute vec3 morphTarget0;',\n\t\t\t'\tattribute vec3 morphTarget1;',\n\t\t\t'\tattribute vec3 morphTarget2;',\n\t\t\t'\tattribute vec3 morphTarget3;',\n\n\t\t\t'\t#ifdef USE_MORPHNORMALS',\n\n\t\t\t'\t\tattribute vec3 morphNormal0;',\n\t\t\t'\t\tattribute vec3 morphNormal1;',\n\t\t\t'\t\tattribute vec3 morphNormal2;',\n\t\t\t'\t\tattribute vec3 morphNormal3;',\n\n\t\t\t'\t#else',\n\n\t\t\t'\t\tattribute vec3 morphTarget4;',\n\t\t\t'\t\tattribute vec3 morphTarget5;',\n\t\t\t'\t\tattribute vec3 morphTarget6;',\n\t\t\t'\t\tattribute vec3 morphTarget7;',\n\n\t\t\t'\t#endif',\n\n\t\t\t'#endif',\n\n\t\t\t'#ifdef USE_SKINNING',\n\n\t\t\t'\tattribute vec4 skinIndex;',\n\t\t\t'\tattribute vec4 skinWeight;',\n\n\t\t\t'#endif',\n\n\t\t\t'\\n'\n\n\t\t].filter( filterEmptyLine ).join( '\\n' );\n\n\t\tprefixFragment = [\n\n\t\t\tcustomExtensions,\n\n\t\t\t'precision ' + parameters.precision + ' float;',\n\t\t\t'precision ' + parameters.precision + ' int;',\n\n\t\t\t'#define SHADER_NAME ' + shader.name,\n\n\t\t\tcustomDefines,\n\n\t\t\tparameters.alphaTest ? '#define ALPHATEST ' + parameters.alphaTest : '',\n\n\t\t\t'#define GAMMA_FACTOR ' + gammaFactorDefine,\n\n\t\t\t( parameters.useFog && parameters.fog ) ? '#define USE_FOG' : '',\n\t\t\t( parameters.useFog && parameters.fogExp ) ? '#define FOG_EXP2' : '',\n\n\t\t\tparameters.map ? '#define USE_MAP' : '',\n\t\t\tparameters.envMap ? '#define USE_ENVMAP' : '',\n\t\t\tparameters.envMap ? '#define ' + envMapTypeDefine : '',\n\t\t\tparameters.envMap ? '#define ' + envMapModeDefine : '',\n\t\t\tparameters.envMap ? '#define ' + envMapBlendingDefine : '',\n\t\t\tparameters.lightMap ? '#define USE_LIGHTMAP' : '',\n\t\t\tparameters.aoMap ? '#define USE_AOMAP' : '',\n\t\t\tparameters.emissiveMap ? '#define USE_EMISSIVEMAP' : '',\n\t\t\tparameters.bumpMap ? '#define USE_BUMPMAP' : '',\n\t\t\tparameters.normalMap ? '#define USE_NORMALMAP' : '',\n\t\t\tparameters.specularMap ? '#define USE_SPECULARMAP' : '',\n\t\t\tparameters.roughnessMap ? '#define USE_ROUGHNESSMAP' : '',\n\t\t\tparameters.metalnessMap ? '#define USE_METALNESSMAP' : '',\n\t\t\tparameters.alphaMap ? '#define USE_ALPHAMAP' : '',\n\t\t\tparameters.vertexColors ? '#define USE_COLOR' : '',\n\n\t\t\tparameters.gradientMap ? '#define USE_GRADIENTMAP' : '',\n\n\t\t\tparameters.flatShading ? '#define FLAT_SHADED' : '',\n\n\t\t\tparameters.doubleSided ? '#define DOUBLE_SIDED' : '',\n\t\t\tparameters.flipSided ? '#define FLIP_SIDED' : '',\n\n\t\t\tparameters.shadowMapEnabled ? '#define USE_SHADOWMAP' : '',\n\t\t\tparameters.shadowMapEnabled ? '#define ' + shadowMapTypeDefine : '',\n\n\t\t\tparameters.premultipliedAlpha ? '#define PREMULTIPLIED_ALPHA' : '',\n\n\t\t\tparameters.physicallyCorrectLights ? '#define PHYSICALLY_CORRECT_LIGHTS' : '',\n\n\t\t\tparameters.logarithmicDepthBuffer ? '#define USE_LOGDEPTHBUF' : '',\n\t\t\tparameters.logarithmicDepthBuffer && extensions.get( 'EXT_frag_depth' ) ? '#define USE_LOGDEPTHBUF_EXT' : '',\n\n\t\t\tparameters.envMap && extensions.get( 'EXT_shader_texture_lod' ) ? '#define TEXTURE_LOD_EXT' : '',\n\n\t\t\t'uniform mat4 viewMatrix;',\n\t\t\t'uniform vec3 cameraPosition;',\n\n\t\t\t( parameters.toneMapping !== NoToneMapping ) ? '#define TONE_MAPPING' : '',\n\t\t\t( parameters.toneMapping !== NoToneMapping ) ? ShaderChunk[ 'tonemapping_pars_fragment' ] : '', // this code is required here because it is used by the toneMapping() function defined below\n\t\t\t( parameters.toneMapping !== NoToneMapping ) ? getToneMappingFunction( 'toneMapping', parameters.toneMapping ) : '',\n\n\t\t\tparameters.dithering ? '#define DITHERING' : '',\n\n\t\t\t( parameters.outputEncoding || parameters.mapEncoding || parameters.envMapEncoding || parameters.emissiveMapEncoding ) ? ShaderChunk[ 'encodings_pars_fragment' ] : '', // this code is required here because it is used by the various encoding/decoding function defined below\n\t\t\tparameters.mapEncoding ? getTexelDecodingFunction( 'mapTexelToLinear', parameters.mapEncoding ) : '',\n\t\t\tparameters.envMapEncoding ? getTexelDecodingFunction( 'envMapTexelToLinear', parameters.envMapEncoding ) : '',\n\t\t\tparameters.emissiveMapEncoding ? getTexelDecodingFunction( 'emissiveMapTexelToLinear', parameters.emissiveMapEncoding ) : '',\n\t\t\tparameters.outputEncoding ? getTexelEncodingFunction( 'linearToOutputTexel', parameters.outputEncoding ) : '',\n\n\t\t\tparameters.depthPacking ? '#define DEPTH_PACKING ' + material.depthPacking : '',\n\n\t\t\t'\\n'\n\n\t\t].filter( filterEmptyLine ).join( '\\n' );\n\n\t}\n\n\tvertexShader = parseIncludes( vertexShader );\n\tvertexShader = replaceLightNums( vertexShader, parameters );\n\tvertexShader = replaceClippingPlaneNums( vertexShader, parameters );\n\n\tfragmentShader = parseIncludes( fragmentShader );\n\tfragmentShader = replaceLightNums( fragmentShader, parameters );\n\tfragmentShader = replaceClippingPlaneNums( fragmentShader, parameters );\n\n\tvertexShader = unrollLoops( vertexShader );\n\tfragmentShader = unrollLoops( fragmentShader );\n\n\tvar vertexGlsl = prefixVertex + vertexShader;\n\tvar fragmentGlsl = prefixFragment + fragmentShader;\n\n\t// console.log( '*VERTEX*', vertexGlsl );\n\t// console.log( '*FRAGMENT*', fragmentGlsl );\n\n\tvar glVertexShader = WebGLShader( gl, gl.VERTEX_SHADER, vertexGlsl );\n\tvar glFragmentShader = WebGLShader( gl, gl.FRAGMENT_SHADER, fragmentGlsl );\n\n\tgl.attachShader( program, glVertexShader );\n\tgl.attachShader( program, glFragmentShader );\n\n\t// Force a particular attribute to index 0.\n\n\tif ( material.index0AttributeName !== undefined ) {\n\n\t\tgl.bindAttribLocation( program, 0, material.index0AttributeName );\n\n\t} else if ( parameters.morphTargets === true ) {\n\n\t\t// programs with morphTargets displace position out of attribute 0\n\t\tgl.bindAttribLocation( program, 0, 'position' );\n\n\t}\n\n\tgl.linkProgram( program );\n\n\tvar programLog = gl.getProgramInfoLog( program ).trim();\n\tvar vertexLog = gl.getShaderInfoLog( glVertexShader ).trim();\n\tvar fragmentLog = gl.getShaderInfoLog( glFragmentShader ).trim();\n\n\tvar runnable = true;\n\tvar haveDiagnostics = true;\n\n\t// console.log( '**VERTEX**', gl.getExtension( 'WEBGL_debug_shaders' ).getTranslatedShaderSource( glVertexShader ) );\n\t// console.log( '**FRAGMENT**', gl.getExtension( 'WEBGL_debug_shaders' ).getTranslatedShaderSource( glFragmentShader ) );\n\n\tif ( gl.getProgramParameter( program, gl.LINK_STATUS ) === false ) {\n\n\t\trunnable = false;\n\n\t\tconsole.error( 'THREE.WebGLProgram: shader error: ', gl.getError(), 'gl.VALIDATE_STATUS', gl.getProgramParameter( program, gl.VALIDATE_STATUS ), 'gl.getProgramInfoLog', programLog, vertexLog, fragmentLog );\n\n\t} else if ( programLog !== '' ) {\n\n\t\tconsole.warn( 'THREE.WebGLProgram: gl.getProgramInfoLog()', programLog );\n\n\t} else if ( vertexLog === '' || fragmentLog === '' ) {\n\n\t\thaveDiagnostics = false;\n\n\t}\n\n\tif ( haveDiagnostics ) {\n\n\t\tthis.diagnostics = {\n\n\t\t\trunnable: runnable,\n\t\t\tmaterial: material,\n\n\t\t\tprogramLog: programLog,\n\n\t\t\tvertexShader: {\n\n\t\t\t\tlog: vertexLog,\n\t\t\t\tprefix: prefixVertex\n\n\t\t\t},\n\n\t\t\tfragmentShader: {\n\n\t\t\t\tlog: fragmentLog,\n\t\t\t\tprefix: prefixFragment\n\n\t\t\t}\n\n\t\t};\n\n\t}\n\n\t// clean up\n\n\tgl.deleteShader( glVertexShader );\n\tgl.deleteShader( glFragmentShader );\n\n\t// set up caching for uniform locations\n\n\tvar cachedUniforms;\n\n\tthis.getUniforms = function () {\n\n\t\tif ( cachedUniforms === undefined ) {\n\n\t\t\tcachedUniforms = new WebGLUniforms( gl, program, renderer );\n\n\t\t}\n\n\t\treturn cachedUniforms;\n\n\t};\n\n\t// set up caching for attribute locations\n\n\tvar cachedAttributes;\n\n\tthis.getAttributes = function () {\n\n\t\tif ( cachedAttributes === undefined ) {\n\n\t\t\tcachedAttributes = fetchAttributeLocations( gl, program );\n\n\t\t}\n\n\t\treturn cachedAttributes;\n\n\t};\n\n\t// free resource\n\n\tthis.destroy = function () {\n\n\t\tgl.deleteProgram( program );\n\t\tthis.program = undefined;\n\n\t};\n\n\t// DEPRECATED\n\n\tObject.defineProperties( this, {\n\n\t\tuniforms: {\n\t\t\tget: function () {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLProgram: .uniforms is now .getUniforms().' );\n\t\t\t\treturn this.getUniforms();\n\n\t\t\t}\n\t\t},\n\n\t\tattributes: {\n\t\t\tget: function () {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLProgram: .attributes is now .getAttributes().' );\n\t\t\t\treturn this.getAttributes();\n\n\t\t\t}\n\t\t}\n\n\t} );\n\n\n\t//\n\n\tthis.name = shader.name;\n\tthis.id = programIdCount ++;\n\tthis.code = code;\n\tthis.usedTimes = 1;\n\tthis.program = program;\n\tthis.vertexShader = glVertexShader;\n\tthis.fragmentShader = glFragmentShader;\n\n\treturn this;\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLPrograms( renderer, extensions, capabilities ) {\n\n\tvar programs = [];\n\n\tvar shaderIDs = {\n\t\tMeshDepthMaterial: 'depth',\n\t\tMeshDistanceMaterial: 'distanceRGBA',\n\t\tMeshNormalMaterial: 'normal',\n\t\tMeshBasicMaterial: 'basic',\n\t\tMeshLambertMaterial: 'lambert',\n\t\tMeshPhongMaterial: 'phong',\n\t\tMeshToonMaterial: 'phong',\n\t\tMeshStandardMaterial: 'physical',\n\t\tMeshPhysicalMaterial: 'physical',\n\t\tLineBasicMaterial: 'basic',\n\t\tLineDashedMaterial: 'dashed',\n\t\tPointsMaterial: 'points',\n\t\tShadowMaterial: 'shadow'\n\t};\n\n\tvar parameterNames = [\n\t\t\"precision\", \"supportsVertexTextures\", \"map\", \"mapEncoding\", \"envMap\", \"envMapMode\", \"envMapEncoding\",\n\t\t\"lightMap\", \"aoMap\", \"emissiveMap\", \"emissiveMapEncoding\", \"bumpMap\", \"normalMap\", \"displacementMap\", \"specularMap\",\n\t\t\"roughnessMap\", \"metalnessMap\", \"gradientMap\",\n\t\t\"alphaMap\", \"combine\", \"vertexColors\", \"fog\", \"useFog\", \"fogExp\",\n\t\t\"flatShading\", \"sizeAttenuation\", \"logarithmicDepthBuffer\", \"skinning\",\n\t\t\"maxBones\", \"useVertexTexture\", \"morphTargets\", \"morphNormals\",\n\t\t\"maxMorphTargets\", \"maxMorphNormals\", \"premultipliedAlpha\",\n\t\t\"numDirLights\", \"numPointLights\", \"numSpotLights\", \"numHemiLights\", \"numRectAreaLights\",\n\t\t\"shadowMapEnabled\", \"shadowMapType\", \"toneMapping\", 'physicallyCorrectLights',\n\t\t\"alphaTest\", \"doubleSided\", \"flipSided\", \"numClippingPlanes\", \"numClipIntersection\", \"depthPacking\", \"dithering\"\n\t];\n\n\n\tfunction allocateBones( object ) {\n\n\t\tvar skeleton = object.skeleton;\n\t\tvar bones = skeleton.bones;\n\n\t\tif ( capabilities.floatVertexTextures ) {\n\n\t\t\treturn 1024;\n\n\t\t} else {\n\n\t\t\t// default for when object is not specified\n\t\t\t// ( for example when prebuilding shader to be used with multiple objects )\n\t\t\t//\n\t\t\t//  - leave some extra space for other uniforms\n\t\t\t//  - limit here is ANGLE's 254 max uniform vectors\n\t\t\t//    (up to 54 should be safe)\n\n\t\t\tvar nVertexUniforms = capabilities.maxVertexUniforms;\n\t\t\tvar nVertexMatrices = Math.floor( ( nVertexUniforms - 20 ) / 4 );\n\n\t\t\tvar maxBones = Math.min( nVertexMatrices, bones.length );\n\n\t\t\tif ( maxBones < bones.length ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Skeleton has ' + bones.length + ' bones. This GPU supports ' + maxBones + '.' );\n\t\t\t\treturn 0;\n\n\t\t\t}\n\n\t\t\treturn maxBones;\n\n\t\t}\n\n\t}\n\n\tfunction getTextureEncodingFromMap( map, gammaOverrideLinear ) {\n\n\t\tvar encoding;\n\n\t\tif ( ! map ) {\n\n\t\t\tencoding = LinearEncoding;\n\n\t\t} else if ( map.isTexture ) {\n\n\t\t\tencoding = map.encoding;\n\n\t\t} else if ( map.isWebGLRenderTarget ) {\n\n\t\t\tconsole.warn( \"THREE.WebGLPrograms.getTextureEncodingFromMap: don't use render targets as textures. Use their .texture property instead.\" );\n\t\t\tencoding = map.texture.encoding;\n\n\t\t}\n\n\t\t// add backwards compatibility for WebGLRenderer.gammaInput/gammaOutput parameter, should probably be removed at some point.\n\t\tif ( encoding === LinearEncoding && gammaOverrideLinear ) {\n\n\t\t\tencoding = GammaEncoding;\n\n\t\t}\n\n\t\treturn encoding;\n\n\t}\n\n\tthis.getParameters = function ( material, lights, shadows, fog, nClipPlanes, nClipIntersection, object ) {\n\n\t\tvar shaderID = shaderIDs[ material.type ];\n\n\t\t// heuristics to create shader parameters according to lights in the scene\n\t\t// (not to blow over maxLights budget)\n\n\t\tvar maxBones = object.isSkinnedMesh ? allocateBones( object ) : 0;\n\t\tvar precision = capabilities.precision;\n\n\t\tif ( material.precision !== null ) {\n\n\t\t\tprecision = capabilities.getMaxPrecision( material.precision );\n\n\t\t\tif ( precision !== material.precision ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLProgram.getParameters:', material.precision, 'not supported, using', precision, 'instead.' );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar currentRenderTarget = renderer.getRenderTarget();\n\n\t\tvar parameters = {\n\n\t\t\tshaderID: shaderID,\n\n\t\t\tprecision: precision,\n\t\t\tsupportsVertexTextures: capabilities.vertexTextures,\n\t\t\toutputEncoding: getTextureEncodingFromMap( ( ! currentRenderTarget ) ? null : currentRenderTarget.texture, renderer.gammaOutput ),\n\t\t\tmap: !! material.map,\n\t\t\tmapEncoding: getTextureEncodingFromMap( material.map, renderer.gammaInput ),\n\t\t\tenvMap: !! material.envMap,\n\t\t\tenvMapMode: material.envMap && material.envMap.mapping,\n\t\t\tenvMapEncoding: getTextureEncodingFromMap( material.envMap, renderer.gammaInput ),\n\t\t\tenvMapCubeUV: ( !! material.envMap ) && ( ( material.envMap.mapping === CubeUVReflectionMapping ) || ( material.envMap.mapping === CubeUVRefractionMapping ) ),\n\t\t\tlightMap: !! material.lightMap,\n\t\t\taoMap: !! material.aoMap,\n\t\t\temissiveMap: !! material.emissiveMap,\n\t\t\temissiveMapEncoding: getTextureEncodingFromMap( material.emissiveMap, renderer.gammaInput ),\n\t\t\tbumpMap: !! material.bumpMap,\n\t\t\tnormalMap: !! material.normalMap,\n\t\t\tdisplacementMap: !! material.displacementMap,\n\t\t\troughnessMap: !! material.roughnessMap,\n\t\t\tmetalnessMap: !! material.metalnessMap,\n\t\t\tspecularMap: !! material.specularMap,\n\t\t\talphaMap: !! material.alphaMap,\n\n\t\t\tgradientMap: !! material.gradientMap,\n\n\t\t\tcombine: material.combine,\n\n\t\t\tvertexColors: material.vertexColors,\n\n\t\t\tfog: !! fog,\n\t\t\tuseFog: material.fog,\n\t\t\tfogExp: ( fog && fog.isFogExp2 ),\n\n\t\t\tflatShading: material.flatShading,\n\n\t\t\tsizeAttenuation: material.sizeAttenuation,\n\t\t\tlogarithmicDepthBuffer: capabilities.logarithmicDepthBuffer,\n\n\t\t\tskinning: material.skinning && maxBones > 0,\n\t\t\tmaxBones: maxBones,\n\t\t\tuseVertexTexture: capabilities.floatVertexTextures,\n\n\t\t\tmorphTargets: material.morphTargets,\n\t\t\tmorphNormals: material.morphNormals,\n\t\t\tmaxMorphTargets: renderer.maxMorphTargets,\n\t\t\tmaxMorphNormals: renderer.maxMorphNormals,\n\n\t\t\tnumDirLights: lights.directional.length,\n\t\t\tnumPointLights: lights.point.length,\n\t\t\tnumSpotLights: lights.spot.length,\n\t\t\tnumRectAreaLights: lights.rectArea.length,\n\t\t\tnumHemiLights: lights.hemi.length,\n\n\t\t\tnumClippingPlanes: nClipPlanes,\n\t\t\tnumClipIntersection: nClipIntersection,\n\n\t\t\tdithering: material.dithering,\n\n\t\t\tshadowMapEnabled: renderer.shadowMap.enabled && object.receiveShadow && shadows.length > 0,\n\t\t\tshadowMapType: renderer.shadowMap.type,\n\n\t\t\ttoneMapping: renderer.toneMapping,\n\t\t\tphysicallyCorrectLights: renderer.physicallyCorrectLights,\n\n\t\t\tpremultipliedAlpha: material.premultipliedAlpha,\n\n\t\t\talphaTest: material.alphaTest,\n\t\t\tdoubleSided: material.side === DoubleSide,\n\t\t\tflipSided: material.side === BackSide,\n\n\t\t\tdepthPacking: ( material.depthPacking !== undefined ) ? material.depthPacking : false\n\n\t\t};\n\n\t\treturn parameters;\n\n\t};\n\n\tthis.getProgramCode = function ( material, parameters ) {\n\n\t\tvar array = [];\n\n\t\tif ( parameters.shaderID ) {\n\n\t\t\tarray.push( parameters.shaderID );\n\n\t\t} else {\n\n\t\t\tarray.push( material.fragmentShader );\n\t\t\tarray.push( material.vertexShader );\n\n\t\t}\n\n\t\tif ( material.defines !== undefined ) {\n\n\t\t\tfor ( var name in material.defines ) {\n\n\t\t\t\tarray.push( name );\n\t\t\t\tarray.push( material.defines[ name ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\tfor ( var i = 0; i < parameterNames.length; i ++ ) {\n\n\t\t\tarray.push( parameters[ parameterNames[ i ] ] );\n\n\t\t}\n\n\t\tarray.push( material.onBeforeCompile.toString() );\n\n\t\tarray.push( renderer.gammaOutput );\n\n\t\treturn array.join();\n\n\t};\n\n\tthis.acquireProgram = function ( material, shader, parameters, code ) {\n\n\t\tvar program;\n\n\t\t// Check if code has been already compiled\n\t\tfor ( var p = 0, pl = programs.length; p < pl; p ++ ) {\n\n\t\t\tvar programInfo = programs[ p ];\n\n\t\t\tif ( programInfo.code === code ) {\n\n\t\t\t\tprogram = programInfo;\n\t\t\t\t++ program.usedTimes;\n\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( program === undefined ) {\n\n\t\t\tprogram = new WebGLProgram( renderer, extensions, code, material, shader, parameters );\n\t\t\tprograms.push( program );\n\n\t\t}\n\n\t\treturn program;\n\n\t};\n\n\tthis.releaseProgram = function ( program ) {\n\n\t\tif ( -- program.usedTimes === 0 ) {\n\n\t\t\t// Remove from unordered set\n\t\t\tvar i = programs.indexOf( program );\n\t\t\tprograms[ i ] = programs[ programs.length - 1 ];\n\t\t\tprograms.pop();\n\n\t\t\t// Free WebGL resources\n\t\t\tprogram.destroy();\n\n\t\t}\n\n\t};\n\n\t// Exposed for resource monitoring & error feedback via renderer.info:\n\tthis.programs = programs;\n\n}\n\n/**\n * @author fordacious / fordacious.github.io\n */\n\nfunction WebGLProperties() {\n\n\tvar properties = new WeakMap();\n\n\tfunction get( object ) {\n\n\t\tvar map = properties.get( object );\n\n\t\tif ( map === undefined ) {\n\n\t\t\tmap = {};\n\t\t\tproperties.set( object, map );\n\n\t\t}\n\n\t\treturn map;\n\n\t}\n\n\tfunction remove( object ) {\n\n\t\tproperties.delete( object );\n\n\t}\n\n\tfunction update( object, key, value ) {\n\n\t\tproperties.get( object )[ key ] = value;\n\n\t}\n\n\tfunction dispose() {\n\n\t\tproperties = new WeakMap();\n\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tremove: remove,\n\t\tupdate: update,\n\t\tdispose: dispose\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction painterSortStable( a, b ) {\n\n\tif ( a.renderOrder !== b.renderOrder ) {\n\n\t\treturn a.renderOrder - b.renderOrder;\n\n\t} else if ( a.program && b.program && a.program !== b.program ) {\n\n\t\treturn a.program.id - b.program.id;\n\n\t} else if ( a.material.id !== b.material.id ) {\n\n\t\treturn a.material.id - b.material.id;\n\n\t} else if ( a.z !== b.z ) {\n\n\t\treturn a.z - b.z;\n\n\t} else {\n\n\t\treturn a.id - b.id;\n\n\t}\n\n}\n\nfunction reversePainterSortStable( a, b ) {\n\n\tif ( a.renderOrder !== b.renderOrder ) {\n\n\t\treturn a.renderOrder - b.renderOrder;\n\n\t} if ( a.z !== b.z ) {\n\n\t\treturn b.z - a.z;\n\n\t} else {\n\n\t\treturn a.id - b.id;\n\n\t}\n\n}\n\nfunction WebGLRenderList() {\n\n\tvar renderItems = [];\n\tvar renderItemsIndex = 0;\n\n\tvar opaque = [];\n\tvar transparent = [];\n\n\tfunction init() {\n\n\t\trenderItemsIndex = 0;\n\n\t\topaque.length = 0;\n\t\ttransparent.length = 0;\n\n\t}\n\n\tfunction push( object, geometry, material, z, group ) {\n\n\t\tvar renderItem = renderItems[ renderItemsIndex ];\n\n\t\tif ( renderItem === undefined ) {\n\n\t\t\trenderItem = {\n\t\t\t\tid: object.id,\n\t\t\t\tobject: object,\n\t\t\t\tgeometry: geometry,\n\t\t\t\tmaterial: material,\n\t\t\t\tprogram: material.program,\n\t\t\t\trenderOrder: object.renderOrder,\n\t\t\t\tz: z,\n\t\t\t\tgroup: group\n\t\t\t};\n\n\t\t\trenderItems[ renderItemsIndex ] = renderItem;\n\n\t\t} else {\n\n\t\t\trenderItem.id = object.id;\n\t\t\trenderItem.object = object;\n\t\t\trenderItem.geometry = geometry;\n\t\t\trenderItem.material = material;\n\t\t\trenderItem.program = material.program;\n\t\t\trenderItem.renderOrder = object.renderOrder;\n\t\t\trenderItem.z = z;\n\t\t\trenderItem.group = group;\n\n\t\t}\n\n\t\t( material.transparent === true ? transparent : opaque ).push( renderItem );\n\n\t\trenderItemsIndex ++;\n\n\t}\n\n\tfunction sort() {\n\n\t\tif ( opaque.length > 1 ) opaque.sort( painterSortStable );\n\t\tif ( transparent.length > 1 ) transparent.sort( reversePainterSortStable );\n\n\t}\n\n\treturn {\n\t\topaque: opaque,\n\t\ttransparent: transparent,\n\n\t\tinit: init,\n\t\tpush: push,\n\n\t\tsort: sort\n\t};\n\n}\n\nfunction WebGLRenderLists() {\n\n\tvar lists = {};\n\n\tfunction get( scene, camera ) {\n\n\t\tvar hash = scene.id + ',' + camera.id;\n\t\tvar list = lists[ hash ];\n\n\t\tif ( list === undefined ) {\n\n\t\t\t// console.log( 'THREE.WebGLRenderLists:', hash );\n\n\t\t\tlist = new WebGLRenderList();\n\t\t\tlists[ hash ] = list;\n\n\t\t}\n\n\t\treturn list;\n\n\t}\n\n\tfunction dispose() {\n\n\t\tlists = {};\n\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction UniformsCache() {\n\n\tvar lights = {};\n\n\treturn {\n\n\t\tget: function ( light ) {\n\n\t\t\tif ( lights[ light.id ] !== undefined ) {\n\n\t\t\t\treturn lights[ light.id ];\n\n\t\t\t}\n\n\t\t\tvar uniforms;\n\n\t\t\tswitch ( light.type ) {\n\n\t\t\t\tcase 'DirectionalLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tdirection: new Vector3(),\n\t\t\t\t\t\tcolor: new Color(),\n\n\t\t\t\t\t\tshadow: false,\n\t\t\t\t\t\tshadowBias: 0,\n\t\t\t\t\t\tshadowRadius: 1,\n\t\t\t\t\t\tshadowMapSize: new Vector2()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'SpotLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tposition: new Vector3(),\n\t\t\t\t\t\tdirection: new Vector3(),\n\t\t\t\t\t\tcolor: new Color(),\n\t\t\t\t\t\tdistance: 0,\n\t\t\t\t\t\tconeCos: 0,\n\t\t\t\t\t\tpenumbraCos: 0,\n\t\t\t\t\t\tdecay: 0,\n\n\t\t\t\t\t\tshadow: false,\n\t\t\t\t\t\tshadowBias: 0,\n\t\t\t\t\t\tshadowRadius: 1,\n\t\t\t\t\t\tshadowMapSize: new Vector2()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'PointLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tposition: new Vector3(),\n\t\t\t\t\t\tcolor: new Color(),\n\t\t\t\t\t\tdistance: 0,\n\t\t\t\t\t\tdecay: 0,\n\n\t\t\t\t\t\tshadow: false,\n\t\t\t\t\t\tshadowBias: 0,\n\t\t\t\t\t\tshadowRadius: 1,\n\t\t\t\t\t\tshadowMapSize: new Vector2(),\n\t\t\t\t\t\tshadowCameraNear: 1,\n\t\t\t\t\t\tshadowCameraFar: 1000\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'HemisphereLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tdirection: new Vector3(),\n\t\t\t\t\t\tskyColor: new Color(),\n\t\t\t\t\t\tgroundColor: new Color()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'RectAreaLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tcolor: new Color(),\n\t\t\t\t\t\tposition: new Vector3(),\n\t\t\t\t\t\thalfWidth: new Vector3(),\n\t\t\t\t\t\thalfHeight: new Vector3()\n\t\t\t\t\t\t// TODO (abelnation): set RectAreaLight shadow uniforms\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t\tlights[ light.id ] = uniforms;\n\n\t\t\treturn uniforms;\n\n\t\t}\n\n\t};\n\n}\n\nvar count = 0;\n\nfunction WebGLLights() {\n\n\tvar cache = new UniformsCache();\n\n\tvar state = {\n\n\t\tid: count ++,\n\n\t\thash: '',\n\n\t\tambient: [ 0, 0, 0 ],\n\t\tdirectional: [],\n\t\tdirectionalShadowMap: [],\n\t\tdirectionalShadowMatrix: [],\n\t\tspot: [],\n\t\tspotShadowMap: [],\n\t\tspotShadowMatrix: [],\n\t\trectArea: [],\n\t\tpoint: [],\n\t\tpointShadowMap: [],\n\t\tpointShadowMatrix: [],\n\t\themi: []\n\n\t};\n\n\tvar vector3 = new Vector3();\n\tvar matrix4 = new Matrix4();\n\tvar matrix42 = new Matrix4();\n\n\tfunction setup( lights, shadows, camera ) {\n\n\t\tvar r = 0, g = 0, b = 0;\n\n\t\tvar directionalLength = 0;\n\t\tvar pointLength = 0;\n\t\tvar spotLength = 0;\n\t\tvar rectAreaLength = 0;\n\t\tvar hemiLength = 0;\n\n\t\tvar viewMatrix = camera.matrixWorldInverse;\n\n\t\tfor ( var i = 0, l = lights.length; i < l; i ++ ) {\n\n\t\t\tvar light = lights[ i ];\n\n\t\t\tvar color = light.color;\n\t\t\tvar intensity = light.intensity;\n\t\t\tvar distance = light.distance;\n\n\t\t\tvar shadowMap = ( light.shadow && light.shadow.map ) ? light.shadow.map.texture : null;\n\n\t\t\tif ( light.isAmbientLight ) {\n\n\t\t\t\tr += color.r * intensity;\n\t\t\t\tg += color.g * intensity;\n\t\t\t\tb += color.b * intensity;\n\n\t\t\t} else if ( light.isDirectionalLight ) {\n\n\t\t\t\tvar uniforms = cache.get( light );\n\n\t\t\t\tuniforms.color.copy( light.color ).multiplyScalar( light.intensity );\n\t\t\t\tuniforms.direction.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tvector3.setFromMatrixPosition( light.target.matrixWorld );\n\t\t\t\tuniforms.direction.sub( vector3 );\n\t\t\t\tuniforms.direction.transformDirection( viewMatrix );\n\n\t\t\t\tuniforms.shadow = light.castShadow;\n\n\t\t\t\tif ( light.castShadow ) {\n\n\t\t\t\t\tvar shadow = light.shadow;\n\n\t\t\t\t\tuniforms.shadowBias = shadow.bias;\n\t\t\t\t\tuniforms.shadowRadius = shadow.radius;\n\t\t\t\t\tuniforms.shadowMapSize = shadow.mapSize;\n\n\t\t\t\t}\n\n\t\t\t\tstate.directionalShadowMap[ directionalLength ] = shadowMap;\n\t\t\t\tstate.directionalShadowMatrix[ directionalLength ] = light.shadow.matrix;\n\t\t\t\tstate.directional[ directionalLength ] = uniforms;\n\n\t\t\t\tdirectionalLength ++;\n\n\t\t\t} else if ( light.isSpotLight ) {\n\n\t\t\t\tvar uniforms = cache.get( light );\n\n\t\t\t\tuniforms.position.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tuniforms.position.applyMatrix4( viewMatrix );\n\n\t\t\t\tuniforms.color.copy( color ).multiplyScalar( intensity );\n\t\t\t\tuniforms.distance = distance;\n\n\t\t\t\tuniforms.direction.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tvector3.setFromMatrixPosition( light.target.matrixWorld );\n\t\t\t\tuniforms.direction.sub( vector3 );\n\t\t\t\tuniforms.direction.transformDirection( viewMatrix );\n\n\t\t\t\tuniforms.coneCos = Math.cos( light.angle );\n\t\t\t\tuniforms.penumbraCos = Math.cos( light.angle * ( 1 - light.penumbra ) );\n\t\t\t\tuniforms.decay = ( light.distance === 0 ) ? 0.0 : light.decay;\n\n\t\t\t\tuniforms.shadow = light.castShadow;\n\n\t\t\t\tif ( light.castShadow ) {\n\n\t\t\t\t\tvar shadow = light.shadow;\n\n\t\t\t\t\tuniforms.shadowBias = shadow.bias;\n\t\t\t\t\tuniforms.shadowRadius = shadow.radius;\n\t\t\t\t\tuniforms.shadowMapSize = shadow.mapSize;\n\n\t\t\t\t}\n\n\t\t\t\tstate.spotShadowMap[ spotLength ] = shadowMap;\n\t\t\t\tstate.spotShadowMatrix[ spotLength ] = light.shadow.matrix;\n\t\t\t\tstate.spot[ spotLength ] = uniforms;\n\n\t\t\t\tspotLength ++;\n\n\t\t\t} else if ( light.isRectAreaLight ) {\n\n\t\t\t\tvar uniforms = cache.get( light );\n\n\t\t\t\t// (a) intensity is the total visible light emitted\n\t\t\t\t//uniforms.color.copy( color ).multiplyScalar( intensity / ( light.width * light.height * Math.PI ) );\n\n\t\t\t\t// (b) intensity is the brightness of the light\n\t\t\t\tuniforms.color.copy( color ).multiplyScalar( intensity );\n\n\t\t\t\tuniforms.position.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tuniforms.position.applyMatrix4( viewMatrix );\n\n\t\t\t\t// extract local rotation of light to derive width/height half vectors\n\t\t\t\tmatrix42.identity();\n\t\t\t\tmatrix4.copy( light.matrixWorld );\n\t\t\t\tmatrix4.premultiply( viewMatrix );\n\t\t\t\tmatrix42.extractRotation( matrix4 );\n\n\t\t\t\tuniforms.halfWidth.set( light.width * 0.5, 0.0, 0.0 );\n\t\t\t\tuniforms.halfHeight.set( 0.0, light.height * 0.5, 0.0 );\n\n\t\t\t\tuniforms.halfWidth.applyMatrix4( matrix42 );\n\t\t\t\tuniforms.halfHeight.applyMatrix4( matrix42 );\n\n\t\t\t\t// TODO (abelnation): RectAreaLight distance?\n\t\t\t\t// uniforms.distance = distance;\n\n\t\t\t\tstate.rectArea[ rectAreaLength ] = uniforms;\n\n\t\t\t\trectAreaLength ++;\n\n\t\t\t} else if ( light.isPointLight ) {\n\n\t\t\t\tvar uniforms = cache.get( light );\n\n\t\t\t\tuniforms.position.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tuniforms.position.applyMatrix4( viewMatrix );\n\n\t\t\t\tuniforms.color.copy( light.color ).multiplyScalar( light.intensity );\n\t\t\t\tuniforms.distance = light.distance;\n\t\t\t\tuniforms.decay = ( light.distance === 0 ) ? 0.0 : light.decay;\n\n\t\t\t\tuniforms.shadow = light.castShadow;\n\n\t\t\t\tif ( light.castShadow ) {\n\n\t\t\t\t\tvar shadow = light.shadow;\n\n\t\t\t\t\tuniforms.shadowBias = shadow.bias;\n\t\t\t\t\tuniforms.shadowRadius = shadow.radius;\n\t\t\t\t\tuniforms.shadowMapSize = shadow.mapSize;\n\t\t\t\t\tuniforms.shadowCameraNear = shadow.camera.near;\n\t\t\t\t\tuniforms.shadowCameraFar = shadow.camera.far;\n\n\t\t\t\t}\n\n\t\t\t\tstate.pointShadowMap[ pointLength ] = shadowMap;\n\t\t\t\tstate.pointShadowMatrix[ pointLength ] = light.shadow.matrix;\n\t\t\t\tstate.point[ pointLength ] = uniforms;\n\n\t\t\t\tpointLength ++;\n\n\t\t\t} else if ( light.isHemisphereLight ) {\n\n\t\t\t\tvar uniforms = cache.get( light );\n\n\t\t\t\tuniforms.direction.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tuniforms.direction.transformDirection( viewMatrix );\n\t\t\t\tuniforms.direction.normalize();\n\n\t\t\t\tuniforms.skyColor.copy( light.color ).multiplyScalar( intensity );\n\t\t\t\tuniforms.groundColor.copy( light.groundColor ).multiplyScalar( intensity );\n\n\t\t\t\tstate.hemi[ hemiLength ] = uniforms;\n\n\t\t\t\themiLength ++;\n\n\t\t\t}\n\n\t\t}\n\n\t\tstate.ambient[ 0 ] = r;\n\t\tstate.ambient[ 1 ] = g;\n\t\tstate.ambient[ 2 ] = b;\n\n\t\tstate.directional.length = directionalLength;\n\t\tstate.spot.length = spotLength;\n\t\tstate.rectArea.length = rectAreaLength;\n\t\tstate.point.length = pointLength;\n\t\tstate.hemi.length = hemiLength;\n\n\t\tstate.hash = state.id + ',' + directionalLength + ',' + pointLength + ',' + spotLength + ',' + rectAreaLength + ',' + hemiLength + ',' + shadows.length;\n\n\t}\n\n\treturn {\n\t\tsetup: setup,\n\t\tstate: state\n\t};\n\n}\n\n/**\n * @author Mugen87 / https://github.com/Mugen87\n */\n\nfunction WebGLRenderState() {\n\n\tvar lights = new WebGLLights();\n\n\tvar lightsArray = [];\n\tvar shadowsArray = [];\n\tvar spritesArray = [];\n\n\tfunction init() {\n\n\t\tlightsArray.length = 0;\n\t\tshadowsArray.length = 0;\n\t\tspritesArray.length = 0;\n\n\t}\n\n\tfunction pushLight( light ) {\n\n\t\tlightsArray.push( light );\n\n\t}\n\n\tfunction pushShadow( shadowLight ) {\n\n\t\tshadowsArray.push( shadowLight );\n\n\t}\n\n\tfunction pushSprite( shadowLight ) {\n\n\t\tspritesArray.push( shadowLight );\n\n\t}\n\n\tfunction setupLights( camera ) {\n\n\t\tlights.setup( lightsArray, shadowsArray, camera );\n\n\t}\n\n\tvar state = {\n\t\tlightsArray: lightsArray,\n\t\tshadowsArray: shadowsArray,\n\t\tspritesArray: spritesArray,\n\n\t\tlights: lights\n\t};\n\n\treturn {\n\t\tinit: init,\n\t\tstate: state,\n\t\tsetupLights: setupLights,\n\n\t\tpushLight: pushLight,\n\t\tpushShadow: pushShadow,\n\t\tpushSprite: pushSprite\n\t};\n\n}\n\nfunction WebGLRenderStates() {\n\n\tvar renderStates = {};\n\n\tfunction get( scene, camera ) {\n\n\t\tvar hash = scene.id + ',' + camera.id;\n\n\t\tvar renderState = renderStates[ hash ];\n\n\t\tif ( renderState === undefined ) {\n\n\t\t\trenderState = new WebGLRenderState();\n\t\t\trenderStates[ hash ] = renderState;\n\n\t\t}\n\n\t\treturn renderState;\n\n\t}\n\n\tfunction dispose() {\n\n\t\trenderStates = {};\n\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n * @author bhouston / https://clara.io\n * @author WestLangley / http://github.com/WestLangley\n *\n * parameters = {\n *\n *  opacity: <float>,\n *\n *  map: new THREE.Texture( <Image> ),\n *\n *  alphaMap: new THREE.Texture( <Image> ),\n *\n *  displacementMap: new THREE.Texture( <Image> ),\n *  displacementScale: <float>,\n *  displacementBias: <float>,\n *\n *  wireframe: <boolean>,\n *  wireframeLinewidth: <float>\n * }\n */\n\nfunction MeshDepthMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'MeshDepthMaterial';\n\n\tthis.depthPacking = BasicDepthPacking;\n\n\tthis.skinning = false;\n\tthis.morphTargets = false;\n\n\tthis.map = null;\n\n\tthis.alphaMap = null;\n\n\tthis.displacementMap = null;\n\tthis.displacementScale = 1;\n\tthis.displacementBias = 0;\n\n\tthis.wireframe = false;\n\tthis.wireframeLinewidth = 1;\n\n\tthis.fog = false;\n\tthis.lights = false;\n\n\tthis.setValues( parameters );\n\n}\n\nMeshDepthMaterial.prototype = Object.create( Material.prototype );\nMeshDepthMaterial.prototype.constructor = MeshDepthMaterial;\n\nMeshDepthMaterial.prototype.isMeshDepthMaterial = true;\n\nMeshDepthMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.depthPacking = source.depthPacking;\n\n\tthis.skinning = source.skinning;\n\tthis.morphTargets = source.morphTargets;\n\n\tthis.map = source.map;\n\n\tthis.alphaMap = source.alphaMap;\n\n\tthis.displacementMap = source.displacementMap;\n\tthis.displacementScale = source.displacementScale;\n\tthis.displacementBias = source.displacementBias;\n\n\tthis.wireframe = source.wireframe;\n\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\n\treturn this;\n\n};\n\n/**\n * @author WestLangley / http://github.com/WestLangley\n *\n * parameters = {\n *\n *  referencePosition: <float>,\n *  nearDistance: <float>,\n *  farDistance: <float>,\n *\n *  skinning: <bool>,\n *  morphTargets: <bool>,\n *\n *  map: new THREE.Texture( <Image> ),\n *\n *  alphaMap: new THREE.Texture( <Image> ),\n *\n *  displacementMap: new THREE.Texture( <Image> ),\n *  displacementScale: <float>,\n *  displacementBias: <float>\n *\n * }\n */\n\nfunction MeshDistanceMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'MeshDistanceMaterial';\n\n\tthis.referencePosition = new Vector3();\n\tthis.nearDistance = 1;\n\tthis.farDistance = 1000;\n\n\tthis.skinning = false;\n\tthis.morphTargets = false;\n\n\tthis.map = null;\n\n\tthis.alphaMap = null;\n\n\tthis.displacementMap = null;\n\tthis.displacementScale = 1;\n\tthis.displacementBias = 0;\n\n\tthis.fog = false;\n\tthis.lights = false;\n\n\tthis.setValues( parameters );\n\n}\n\nMeshDistanceMaterial.prototype = Object.create( Material.prototype );\nMeshDistanceMaterial.prototype.constructor = MeshDistanceMaterial;\n\nMeshDistanceMaterial.prototype.isMeshDistanceMaterial = true;\n\nMeshDistanceMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.referencePosition.copy( source.referencePosition );\n\tthis.nearDistance = source.nearDistance;\n\tthis.farDistance = source.farDistance;\n\n\tthis.skinning = source.skinning;\n\tthis.morphTargets = source.morphTargets;\n\n\tthis.map = source.map;\n\n\tthis.alphaMap = source.alphaMap;\n\n\tthis.displacementMap = source.displacementMap;\n\tthis.displacementScale = source.displacementScale;\n\tthis.displacementBias = source.displacementBias;\n\n\treturn this;\n\n};\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLShadowMap( _renderer, _objects, maxTextureSize ) {\n\n\tvar _frustum = new Frustum(),\n\t\t_projScreenMatrix = new Matrix4(),\n\n\t\t_shadowMapSize = new Vector2(),\n\t\t_maxShadowMapSize = new Vector2( maxTextureSize, maxTextureSize ),\n\n\t\t_lookTarget = new Vector3(),\n\t\t_lightPositionWorld = new Vector3(),\n\n\t\t_MorphingFlag = 1,\n\t\t_SkinningFlag = 2,\n\n\t\t_NumberOfMaterialVariants = ( _MorphingFlag | _SkinningFlag ) + 1,\n\n\t\t_depthMaterials = new Array( _NumberOfMaterialVariants ),\n\t\t_distanceMaterials = new Array( _NumberOfMaterialVariants ),\n\n\t\t_materialCache = {};\n\n\tvar shadowSide = { 0: BackSide, 1: FrontSide, 2: DoubleSide };\n\n\tvar cubeDirections = [\n\t\tnew Vector3( 1, 0, 0 ), new Vector3( - 1, 0, 0 ), new Vector3( 0, 0, 1 ),\n\t\tnew Vector3( 0, 0, - 1 ), new Vector3( 0, 1, 0 ), new Vector3( 0, - 1, 0 )\n\t];\n\n\tvar cubeUps = [\n\t\tnew Vector3( 0, 1, 0 ), new Vector3( 0, 1, 0 ), new Vector3( 0, 1, 0 ),\n\t\tnew Vector3( 0, 1, 0 ), new Vector3( 0, 0, 1 ),\tnew Vector3( 0, 0, - 1 )\n\t];\n\n\tvar cube2DViewPorts = [\n\t\tnew Vector4(), new Vector4(), new Vector4(),\n\t\tnew Vector4(), new Vector4(), new Vector4()\n\t];\n\n\t// init\n\n\tfor ( var i = 0; i !== _NumberOfMaterialVariants; ++ i ) {\n\n\t\tvar useMorphing = ( i & _MorphingFlag ) !== 0;\n\t\tvar useSkinning = ( i & _SkinningFlag ) !== 0;\n\n\t\tvar depthMaterial = new MeshDepthMaterial( {\n\n\t\t\tdepthPacking: RGBADepthPacking,\n\n\t\t\tmorphTargets: useMorphing,\n\t\t\tskinning: useSkinning\n\n\t\t} );\n\n\t\t_depthMaterials[ i ] = depthMaterial;\n\n\t\t//\n\n\t\tvar distanceMaterial = new MeshDistanceMaterial( {\n\n\t\t\tmorphTargets: useMorphing,\n\t\t\tskinning: useSkinning\n\n\t\t} );\n\n\t\t_distanceMaterials[ i ] = distanceMaterial;\n\n\t}\n\n\t//\n\n\tvar scope = this;\n\n\tthis.enabled = false;\n\n\tthis.autoUpdate = true;\n\tthis.needsUpdate = false;\n\n\tthis.type = PCFShadowMap;\n\n\tthis.render = function ( lights, scene, camera ) {\n\n\t\tif ( scope.enabled === false ) return;\n\t\tif ( scope.autoUpdate === false && scope.needsUpdate === false ) return;\n\n\t\tif ( lights.length === 0 ) return;\n\n\t\t// TODO Clean up (needed in case of contextlost)\n\t\tvar _gl = _renderer.context;\n\t\tvar _state = _renderer.state;\n\n\t\t// Set GL state for depth map.\n\t\t_state.disable( _gl.BLEND );\n\t\t_state.buffers.color.setClear( 1, 1, 1, 1 );\n\t\t_state.buffers.depth.setTest( true );\n\t\t_state.setScissorTest( false );\n\n\t\t// render depth map\n\n\t\tvar faceCount;\n\n\t\tfor ( var i = 0, il = lights.length; i < il; i ++ ) {\n\n\t\t\tvar light = lights[ i ];\n\t\t\tvar shadow = light.shadow;\n\t\t\tvar isPointLight = light && light.isPointLight;\n\n\t\t\tif ( shadow === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLShadowMap:', light, 'has no shadow.' );\n\t\t\t\tcontinue;\n\n\t\t\t}\n\n\t\t\tvar shadowCamera = shadow.camera;\n\n\t\t\t_shadowMapSize.copy( shadow.mapSize );\n\t\t\t_shadowMapSize.min( _maxShadowMapSize );\n\n\t\t\tif ( isPointLight ) {\n\n\t\t\t\tvar vpWidth = _shadowMapSize.x;\n\t\t\t\tvar vpHeight = _shadowMapSize.y;\n\n\t\t\t\t// These viewports map a cube-map onto a 2D texture with the\n\t\t\t\t// following orientation:\n\t\t\t\t//\n\t\t\t\t//  xzXZ\n\t\t\t\t//   y Y\n\t\t\t\t//\n\t\t\t\t// X - Positive x direction\n\t\t\t\t// x - Negative x direction\n\t\t\t\t// Y - Positive y direction\n\t\t\t\t// y - Negative y direction\n\t\t\t\t// Z - Positive z direction\n\t\t\t\t// z - Negative z direction\n\n\t\t\t\t// positive X\n\t\t\t\tcube2DViewPorts[ 0 ].set( vpWidth * 2, vpHeight, vpWidth, vpHeight );\n\t\t\t\t// negative X\n\t\t\t\tcube2DViewPorts[ 1 ].set( 0, vpHeight, vpWidth, vpHeight );\n\t\t\t\t// positive Z\n\t\t\t\tcube2DViewPorts[ 2 ].set( vpWidth * 3, vpHeight, vpWidth, vpHeight );\n\t\t\t\t// negative Z\n\t\t\t\tcube2DViewPorts[ 3 ].set( vpWidth, vpHeight, vpWidth, vpHeight );\n\t\t\t\t// positive Y\n\t\t\t\tcube2DViewPorts[ 4 ].set( vpWidth * 3, 0, vpWidth, vpHeight );\n\t\t\t\t// negative Y\n\t\t\t\tcube2DViewPorts[ 5 ].set( vpWidth, 0, vpWidth, vpHeight );\n\n\t\t\t\t_shadowMapSize.x *= 4.0;\n\t\t\t\t_shadowMapSize.y *= 2.0;\n\n\t\t\t}\n\n\t\t\tif ( shadow.map === null ) {\n\n\t\t\t\tvar pars = { minFilter: NearestFilter, magFilter: NearestFilter, format: RGBAFormat };\n\n\t\t\t\tshadow.map = new WebGLRenderTarget( _shadowMapSize.x, _shadowMapSize.y, pars );\n\t\t\t\tshadow.map.texture.name = light.name + \".shadowMap\";\n\n\t\t\t\tshadowCamera.updateProjectionMatrix();\n\n\t\t\t}\n\n\t\t\tif ( shadow.isSpotLightShadow ) {\n\n\t\t\t\tshadow.update( light );\n\n\t\t\t}\n\n\t\t\tvar shadowMap = shadow.map;\n\t\t\tvar shadowMatrix = shadow.matrix;\n\n\t\t\t_lightPositionWorld.setFromMatrixPosition( light.matrixWorld );\n\t\t\tshadowCamera.position.copy( _lightPositionWorld );\n\n\t\t\tif ( isPointLight ) {\n\n\t\t\t\tfaceCount = 6;\n\n\t\t\t\t// for point lights we set the shadow matrix to be a translation-only matrix\n\t\t\t\t// equal to inverse of the light's position\n\n\t\t\t\tshadowMatrix.makeTranslation( - _lightPositionWorld.x, - _lightPositionWorld.y, - _lightPositionWorld.z );\n\n\t\t\t} else {\n\n\t\t\t\tfaceCount = 1;\n\n\t\t\t\t_lookTarget.setFromMatrixPosition( light.target.matrixWorld );\n\t\t\t\tshadowCamera.lookAt( _lookTarget );\n\t\t\t\tshadowCamera.updateMatrixWorld();\n\n\t\t\t\t// compute shadow matrix\n\n\t\t\t\tshadowMatrix.set(\n\t\t\t\t\t0.5, 0.0, 0.0, 0.5,\n\t\t\t\t\t0.0, 0.5, 0.0, 0.5,\n\t\t\t\t\t0.0, 0.0, 0.5, 0.5,\n\t\t\t\t\t0.0, 0.0, 0.0, 1.0\n\t\t\t\t);\n\n\t\t\t\tshadowMatrix.multiply( shadowCamera.projectionMatrix );\n\t\t\t\tshadowMatrix.multiply( shadowCamera.matrixWorldInverse );\n\n\t\t\t}\n\n\t\t\t_renderer.setRenderTarget( shadowMap );\n\t\t\t_renderer.clear();\n\n\t\t\t// render shadow map for each cube face (if omni-directional) or\n\t\t\t// run a single pass if not\n\n\t\t\tfor ( var face = 0; face < faceCount; face ++ ) {\n\n\t\t\t\tif ( isPointLight ) {\n\n\t\t\t\t\t_lookTarget.copy( shadowCamera.position );\n\t\t\t\t\t_lookTarget.add( cubeDirections[ face ] );\n\t\t\t\t\tshadowCamera.up.copy( cubeUps[ face ] );\n\t\t\t\t\tshadowCamera.lookAt( _lookTarget );\n\t\t\t\t\tshadowCamera.updateMatrixWorld();\n\n\t\t\t\t\tvar vpDimensions = cube2DViewPorts[ face ];\n\t\t\t\t\t_state.viewport( vpDimensions );\n\n\t\t\t\t}\n\n\t\t\t\t// update camera matrices and frustum\n\n\t\t\t\t_projScreenMatrix.multiplyMatrices( shadowCamera.projectionMatrix, shadowCamera.matrixWorldInverse );\n\t\t\t\t_frustum.setFromMatrix( _projScreenMatrix );\n\n\t\t\t\t// set object matrices & frustum culling\n\n\t\t\t\trenderObject( scene, camera, shadowCamera, isPointLight );\n\n\t\t\t}\n\n\t\t}\n\n\t\tscope.needsUpdate = false;\n\n\t};\n\n\tfunction getDepthMaterial( object, material, isPointLight, lightPositionWorld, shadowCameraNear, shadowCameraFar ) {\n\n\t\tvar geometry = object.geometry;\n\n\t\tvar result = null;\n\n\t\tvar materialVariants = _depthMaterials;\n\t\tvar customMaterial = object.customDepthMaterial;\n\n\t\tif ( isPointLight ) {\n\n\t\t\tmaterialVariants = _distanceMaterials;\n\t\t\tcustomMaterial = object.customDistanceMaterial;\n\n\t\t}\n\n\t\tif ( ! customMaterial ) {\n\n\t\t\tvar useMorphing = false;\n\n\t\t\tif ( material.morphTargets ) {\n\n\t\t\t\tif ( geometry && geometry.isBufferGeometry ) {\n\n\t\t\t\t\tuseMorphing = geometry.morphAttributes && geometry.morphAttributes.position && geometry.morphAttributes.position.length > 0;\n\n\t\t\t\t} else if ( geometry && geometry.isGeometry ) {\n\n\t\t\t\t\tuseMorphing = geometry.morphTargets && geometry.morphTargets.length > 0;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( object.isSkinnedMesh && material.skinning === false ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLShadowMap: THREE.SkinnedMesh with material.skinning set to false:', object );\n\n\t\t\t}\n\n\t\t\tvar useSkinning = object.isSkinnedMesh && material.skinning;\n\n\t\t\tvar variantIndex = 0;\n\n\t\t\tif ( useMorphing ) variantIndex |= _MorphingFlag;\n\t\t\tif ( useSkinning ) variantIndex |= _SkinningFlag;\n\n\t\t\tresult = materialVariants[ variantIndex ];\n\n\t\t} else {\n\n\t\t\tresult = customMaterial;\n\n\t\t}\n\n\t\tif ( _renderer.localClippingEnabled &&\n\t\t\t\tmaterial.clipShadows === true &&\n\t\t\t\tmaterial.clippingPlanes.length !== 0 ) {\n\n\t\t\t// in this case we need a unique material instance reflecting the\n\t\t\t// appropriate state\n\n\t\t\tvar keyA = result.uuid, keyB = material.uuid;\n\n\t\t\tvar materialsForVariant = _materialCache[ keyA ];\n\n\t\t\tif ( materialsForVariant === undefined ) {\n\n\t\t\t\tmaterialsForVariant = {};\n\t\t\t\t_materialCache[ keyA ] = materialsForVariant;\n\n\t\t\t}\n\n\t\t\tvar cachedMaterial = materialsForVariant[ keyB ];\n\n\t\t\tif ( cachedMaterial === undefined ) {\n\n\t\t\t\tcachedMaterial = result.clone();\n\t\t\t\tmaterialsForVariant[ keyB ] = cachedMaterial;\n\n\t\t\t}\n\n\t\t\tresult = cachedMaterial;\n\n\t\t}\n\n\t\tresult.visible = material.visible;\n\t\tresult.wireframe = material.wireframe;\n\n\t\tresult.side = ( material.shadowSide != null ) ? material.shadowSide : shadowSide[ material.side ];\n\n\t\tresult.clipShadows = material.clipShadows;\n\t\tresult.clippingPlanes = material.clippingPlanes;\n\t\tresult.clipIntersection = material.clipIntersection;\n\n\t\tresult.wireframeLinewidth = material.wireframeLinewidth;\n\t\tresult.linewidth = material.linewidth;\n\n\t\tif ( isPointLight && result.isMeshDistanceMaterial ) {\n\n\t\t\tresult.referencePosition.copy( lightPositionWorld );\n\t\t\tresult.nearDistance = shadowCameraNear;\n\t\t\tresult.farDistance = shadowCameraFar;\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n\tfunction renderObject( object, camera, shadowCamera, isPointLight ) {\n\n\t\tif ( object.visible === false ) return;\n\n\t\tvar visible = object.layers.test( camera.layers );\n\n\t\tif ( visible && ( object.isMesh || object.isLine || object.isPoints ) ) {\n\n\t\t\tif ( object.castShadow && ( ! object.frustumCulled || _frustum.intersectsObject( object ) ) ) {\n\n\t\t\t\tobject.modelViewMatrix.multiplyMatrices( shadowCamera.matrixWorldInverse, object.matrixWorld );\n\n\t\t\t\tvar geometry = _objects.update( object );\n\t\t\t\tvar material = object.material;\n\n\t\t\t\tif ( Array.isArray( material ) ) {\n\n\t\t\t\t\tvar groups = geometry.groups;\n\n\t\t\t\t\tfor ( var k = 0, kl = groups.length; k < kl; k ++ ) {\n\n\t\t\t\t\t\tvar group = groups[ k ];\n\t\t\t\t\t\tvar groupMaterial = material[ group.materialIndex ];\n\n\t\t\t\t\t\tif ( groupMaterial && groupMaterial.visible ) {\n\n\t\t\t\t\t\t\tvar depthMaterial = getDepthMaterial( object, groupMaterial, isPointLight, _lightPositionWorld, shadowCamera.near, shadowCamera.far );\n\t\t\t\t\t\t\t_renderer.renderBufferDirect( shadowCamera, null, geometry, depthMaterial, object, group );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t} else if ( material.visible ) {\n\n\t\t\t\t\tvar depthMaterial = getDepthMaterial( object, material, isPointLight, _lightPositionWorld, shadowCamera.near, shadowCamera.far );\n\t\t\t\t\t_renderer.renderBufferDirect( shadowCamera, null, geometry, depthMaterial, object, null );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar children = object.children;\n\n\t\tfor ( var i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\trenderObject( children[ i ], camera, shadowCamera, isPointLight );\n\n\t\t}\n\n\t}\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction CanvasTexture( canvas, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy ) {\n\n\tTexture.call( this, canvas, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy );\n\n\tthis.needsUpdate = true;\n\n}\n\nCanvasTexture.prototype = Object.create( Texture.prototype );\nCanvasTexture.prototype.constructor = CanvasTexture;\n\n/**\n * @author mikael emtinger / http://gomo.se/\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction WebGLSpriteRenderer( renderer, gl, state, textures, capabilities ) {\n\n\tvar vertexBuffer, elementBuffer;\n\tvar program, attributes, uniforms;\n\n\tvar texture;\n\n\t// decompose matrixWorld\n\n\tvar spritePosition = new Vector3();\n\tvar spriteRotation = new Quaternion();\n\tvar spriteScale = new Vector3();\n\n\tfunction init() {\n\n\t\tvar vertices = new Float32Array( [\n\t\t\t- 0.5, - 0.5, 0, 0,\n\t\t\t  0.5, - 0.5, 1, 0,\n\t\t\t  0.5, 0.5, 1, 1,\n\t\t\t- 0.5, 0.5, 0, 1\n\t\t] );\n\n\t\tvar faces = new Uint16Array( [\n\t\t\t0, 1, 2,\n\t\t\t0, 2, 3\n\t\t] );\n\n\t\tvertexBuffer = gl.createBuffer();\n\t\telementBuffer = gl.createBuffer();\n\n\t\tgl.bindBuffer( gl.ARRAY_BUFFER, vertexBuffer );\n\t\tgl.bufferData( gl.ARRAY_BUFFER, vertices, gl.STATIC_DRAW );\n\n\t\tgl.bindBuffer( gl.ELEMENT_ARRAY_BUFFER, elementBuffer );\n\t\tgl.bufferData( gl.ELEMENT_ARRAY_BUFFER, faces, gl.STATIC_DRAW );\n\n\t\tprogram = createProgram();\n\n\t\tattributes = {\n\t\t\tposition: gl.getAttribLocation( program, 'position' ),\n\t\t\tuv: gl.getAttribLocation( program, 'uv' )\n\t\t};\n\n\t\tuniforms = {\n\t\t\tuvOffset: gl.getUniformLocation( program, 'uvOffset' ),\n\t\t\tuvScale: gl.getUniformLocation( program, 'uvScale' ),\n\n\t\t\trotation: gl.getUniformLocation( program, 'rotation' ),\n\t\t\tcenter: gl.getUniformLocation( program, 'center' ),\n\t\t\tscale: gl.getUniformLocation( program, 'scale' ),\n\n\t\t\tcolor: gl.getUniformLocation( program, 'color' ),\n\t\t\tmap: gl.getUniformLocation( program, 'map' ),\n\t\t\topacity: gl.getUniformLocation( program, 'opacity' ),\n\n\t\t\tmodelViewMatrix: gl.getUniformLocation( program, 'modelViewMatrix' ),\n\t\t\tprojectionMatrix: gl.getUniformLocation( program, 'projectionMatrix' ),\n\n\t\t\tfogType: gl.getUniformLocation( program, 'fogType' ),\n\t\t\tfogDensity: gl.getUniformLocation( program, 'fogDensity' ),\n\t\t\tfogNear: gl.getUniformLocation( program, 'fogNear' ),\n\t\t\tfogFar: gl.getUniformLocation( program, 'fogFar' ),\n\t\t\tfogColor: gl.getUniformLocation( program, 'fogColor' ),\n\t\t\tfogDepth: gl.getUniformLocation( program, 'fogDepth' ),\n\n\t\t\talphaTest: gl.getUniformLocation( program, 'alphaTest' )\n\t\t};\n\n\t\tvar canvas = document.createElementNS( 'http://www.w3.org/1999/xhtml', 'canvas' );\n\t\tcanvas.width = 8;\n\t\tcanvas.height = 8;\n\n\t\tvar context = canvas.getContext( '2d' );\n\t\tcontext.fillStyle = 'white';\n\t\tcontext.fillRect( 0, 0, 8, 8 );\n\n\t\ttexture = new CanvasTexture( canvas );\n\n\t}\n\n\tthis.render = function ( sprites, scene, camera ) {\n\n\t\tif ( sprites.length === 0 ) return;\n\n\t\t// setup gl\n\n\t\tif ( program === undefined ) {\n\n\t\t\tinit();\n\n\t\t}\n\n\t\tstate.useProgram( program );\n\n\t\tstate.initAttributes();\n\t\tstate.enableAttribute( attributes.position );\n\t\tstate.enableAttribute( attributes.uv );\n\t\tstate.disableUnusedAttributes();\n\n\t\tstate.disable( gl.CULL_FACE );\n\t\tstate.enable( gl.BLEND );\n\n\t\tgl.bindBuffer( gl.ARRAY_BUFFER, vertexBuffer );\n\t\tgl.vertexAttribPointer( attributes.position, 2, gl.FLOAT, false, 2 * 8, 0 );\n\t\tgl.vertexAttribPointer( attributes.uv, 2, gl.FLOAT, false, 2 * 8, 8 );\n\n\t\tgl.bindBuffer( gl.ELEMENT_ARRAY_BUFFER, elementBuffer );\n\n\t\tgl.uniformMatrix4fv( uniforms.projectionMatrix, false, camera.projectionMatrix.elements );\n\n\t\tstate.activeTexture( gl.TEXTURE0 );\n\t\tgl.uniform1i( uniforms.map, 0 );\n\n\t\tvar oldFogType = 0;\n\t\tvar sceneFogType = 0;\n\t\tvar fog = scene.fog;\n\n\t\tif ( fog ) {\n\n\t\t\tgl.uniform3f( uniforms.fogColor, fog.color.r, fog.color.g, fog.color.b );\n\n\t\t\tif ( fog.isFog ) {\n\n\t\t\t\tgl.uniform1f( uniforms.fogNear, fog.near );\n\t\t\t\tgl.uniform1f( uniforms.fogFar, fog.far );\n\n\t\t\t\tgl.uniform1i( uniforms.fogType, 1 );\n\t\t\t\toldFogType = 1;\n\t\t\t\tsceneFogType = 1;\n\n\t\t\t} else if ( fog.isFogExp2 ) {\n\n\t\t\t\tgl.uniform1f( uniforms.fogDensity, fog.density );\n\n\t\t\t\tgl.uniform1i( uniforms.fogType, 2 );\n\t\t\t\toldFogType = 2;\n\t\t\t\tsceneFogType = 2;\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tgl.uniform1i( uniforms.fogType, 0 );\n\t\t\toldFogType = 0;\n\t\t\tsceneFogType = 0;\n\n\t\t}\n\n\n\t\t// update positions and sort\n\n\t\tfor ( var i = 0, l = sprites.length; i < l; i ++ ) {\n\n\t\t\tvar sprite = sprites[ i ];\n\n\t\t\tsprite.modelViewMatrix.multiplyMatrices( camera.matrixWorldInverse, sprite.matrixWorld );\n\t\t\tsprite.z = - sprite.modelViewMatrix.elements[ 14 ];\n\n\t\t}\n\n\t\tsprites.sort( painterSortStable );\n\n\t\t// render all sprites\n\n\t\tvar scale = [];\n\t\tvar center = [];\n\n\t\tfor ( var i = 0, l = sprites.length; i < l; i ++ ) {\n\n\t\t\tvar sprite = sprites[ i ];\n\t\t\tvar material = sprite.material;\n\n\t\t\tif ( material.visible === false ) continue;\n\n\t\t\tsprite.onBeforeRender( renderer, scene, camera, undefined, material, undefined );\n\n\t\t\tgl.uniform1f( uniforms.alphaTest, material.alphaTest );\n\t\t\tgl.uniformMatrix4fv( uniforms.modelViewMatrix, false, sprite.modelViewMatrix.elements );\n\n\t\t\tsprite.matrixWorld.decompose( spritePosition, spriteRotation, spriteScale );\n\n\t\t\tscale[ 0 ] = spriteScale.x;\n\t\t\tscale[ 1 ] = spriteScale.y;\n\n\t\t\tcenter[ 0 ] = sprite.center.x - 0.5;\n\t\t\tcenter[ 1 ] = sprite.center.y - 0.5;\n\n\t\t\tvar fogType = 0;\n\n\t\t\tif ( scene.fog && material.fog ) {\n\n\t\t\t\tfogType = sceneFogType;\n\n\t\t\t}\n\n\t\t\tif ( oldFogType !== fogType ) {\n\n\t\t\t\tgl.uniform1i( uniforms.fogType, fogType );\n\t\t\t\toldFogType = fogType;\n\n\t\t\t}\n\n\t\t\tif ( material.map !== null ) {\n\n\t\t\t\tgl.uniform2f( uniforms.uvOffset, material.map.offset.x, material.map.offset.y );\n\t\t\t\tgl.uniform2f( uniforms.uvScale, material.map.repeat.x, material.map.repeat.y );\n\n\t\t\t} else {\n\n\t\t\t\tgl.uniform2f( uniforms.uvOffset, 0, 0 );\n\t\t\t\tgl.uniform2f( uniforms.uvScale, 1, 1 );\n\n\t\t\t}\n\n\t\t\tgl.uniform1f( uniforms.opacity, material.opacity );\n\t\t\tgl.uniform3f( uniforms.color, material.color.r, material.color.g, material.color.b );\n\n\t\t\tgl.uniform1f( uniforms.rotation, material.rotation );\n\t\t\tgl.uniform2fv( uniforms.center, center );\n\t\t\tgl.uniform2fv( uniforms.scale, scale );\n\n\t\t\tstate.setBlending( material.blending, material.blendEquation, material.blendSrc, material.blendDst, material.blendEquationAlpha, material.blendSrcAlpha, material.blendDstAlpha, material.premultipliedAlpha );\n\t\t\tstate.buffers.depth.setTest( material.depthTest );\n\t\t\tstate.buffers.depth.setMask( material.depthWrite );\n\t\t\tstate.buffers.color.setMask( material.colorWrite );\n\n\t\t\ttextures.setTexture2D( material.map || texture, 0 );\n\n\t\t\tgl.drawElements( gl.TRIANGLES, 6, gl.UNSIGNED_SHORT, 0 );\n\n\t\t\tsprite.onAfterRender( renderer, scene, camera, undefined, material, undefined );\n\n\t\t}\n\n\t\t// restore gl\n\n\t\tstate.enable( gl.CULL_FACE );\n\n\t\tstate.reset();\n\n\t};\n\n\tfunction createProgram() {\n\n\t\tvar program = gl.createProgram();\n\n\t\tvar vertexShader = gl.createShader( gl.VERTEX_SHADER );\n\t\tvar fragmentShader = gl.createShader( gl.FRAGMENT_SHADER );\n\n\t\tgl.shaderSource( vertexShader, [\n\n\t\t\t'precision ' + capabilities.precision + ' float;',\n\n\t\t\t'#define SHADER_NAME ' + 'SpriteMaterial',\n\n\t\t\t'uniform mat4 modelViewMatrix;',\n\t\t\t'uniform mat4 projectionMatrix;',\n\t\t\t'uniform float rotation;',\n\t\t\t'uniform vec2 center;',\n\t\t\t'uniform vec2 scale;',\n\t\t\t'uniform vec2 uvOffset;',\n\t\t\t'uniform vec2 uvScale;',\n\n\t\t\t'attribute vec2 position;',\n\t\t\t'attribute vec2 uv;',\n\n\t\t\t'varying vec2 vUV;',\n\t\t\t'varying float fogDepth;',\n\n\t\t\t'void main() {',\n\n\t\t\t'\tvUV = uvOffset + uv * uvScale;',\n\n\t\t\t'\tvec2 alignedPosition = ( position - center ) * scale;',\n\n\t\t\t'\tvec2 rotatedPosition;',\n\t\t\t'\trotatedPosition.x = cos( rotation ) * alignedPosition.x - sin( rotation ) * alignedPosition.y;',\n\t\t\t'\trotatedPosition.y = sin( rotation ) * alignedPosition.x + cos( rotation ) * alignedPosition.y;',\n\n\t\t\t'\tvec4 mvPosition;',\n\n\t\t\t'\tmvPosition = modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 );',\n\t\t\t'\tmvPosition.xy += rotatedPosition;',\n\n\t\t\t'\tgl_Position = projectionMatrix * mvPosition;',\n\n\t\t\t'\tfogDepth = - mvPosition.z;',\n\n\t\t\t'}'\n\n\t\t].join( '\\n' ) );\n\n\t\tgl.shaderSource( fragmentShader, [\n\n\t\t\t'precision ' + capabilities.precision + ' float;',\n\n\t\t\t'#define SHADER_NAME ' + 'SpriteMaterial',\n\n\t\t\t'uniform vec3 color;',\n\t\t\t'uniform sampler2D map;',\n\t\t\t'uniform float opacity;',\n\n\t\t\t'uniform int fogType;',\n\t\t\t'uniform vec3 fogColor;',\n\t\t\t'uniform float fogDensity;',\n\t\t\t'uniform float fogNear;',\n\t\t\t'uniform float fogFar;',\n\t\t\t'uniform float alphaTest;',\n\n\t\t\t'varying vec2 vUV;',\n\t\t\t'varying float fogDepth;',\n\n\t\t\t'void main() {',\n\n\t\t\t'\tvec4 texture = texture2D( map, vUV );',\n\n\t\t\t'\tgl_FragColor = vec4( color * texture.xyz, texture.a * opacity );',\n\n\t\t\t'\tif ( gl_FragColor.a < alphaTest ) discard;',\n\n\t\t\t'\tif ( fogType > 0 ) {',\n\n\t\t\t'\t\tfloat fogFactor = 0.0;',\n\n\t\t\t'\t\tif ( fogType == 1 ) {',\n\n\t\t\t'\t\t\tfogFactor = smoothstep( fogNear, fogFar, fogDepth );',\n\n\t\t\t'\t\t} else {',\n\n\t\t\t'\t\t\tconst float LOG2 = 1.442695;',\n\t\t\t'\t\t\tfogFactor = exp2( - fogDensity * fogDensity * fogDepth * fogDepth * LOG2 );',\n\t\t\t'\t\t\tfogFactor = 1.0 - clamp( fogFactor, 0.0, 1.0 );',\n\n\t\t\t'\t\t}',\n\n\t\t\t'\t\tgl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor );',\n\n\t\t\t'\t}',\n\n\t\t\t'}'\n\n\t\t].join( '\\n' ) );\n\n\t\tgl.compileShader( vertexShader );\n\t\tgl.compileShader( fragmentShader );\n\n\t\tgl.attachShader( program, vertexShader );\n\t\tgl.attachShader( program, fragmentShader );\n\n\t\tgl.linkProgram( program );\n\n\t\treturn program;\n\n\t}\n\n\tfunction painterSortStable( a, b ) {\n\n\t\tif ( a.renderOrder !== b.renderOrder ) {\n\n\t\t\treturn a.renderOrder - b.renderOrder;\n\n\t\t} else if ( a.z !== b.z ) {\n\n\t\t\treturn b.z - a.z;\n\n\t\t} else {\n\n\t\t\treturn b.id - a.id;\n\n\t\t}\n\n\t}\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLState( gl, extensions, utils ) {\n\n\tfunction ColorBuffer() {\n\n\t\tvar locked = false;\n\n\t\tvar color = new Vector4();\n\t\tvar currentColorMask = null;\n\t\tvar currentColorClear = new Vector4( 0, 0, 0, 0 );\n\n\t\treturn {\n\n\t\t\tsetMask: function ( colorMask ) {\n\n\t\t\t\tif ( currentColorMask !== colorMask && ! locked ) {\n\n\t\t\t\t\tgl.colorMask( colorMask, colorMask, colorMask, colorMask );\n\t\t\t\t\tcurrentColorMask = colorMask;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetLocked: function ( lock ) {\n\n\t\t\t\tlocked = lock;\n\n\t\t\t},\n\n\t\t\tsetClear: function ( r, g, b, a, premultipliedAlpha ) {\n\n\t\t\t\tif ( premultipliedAlpha === true ) {\n\n\t\t\t\t\tr *= a; g *= a; b *= a;\n\n\t\t\t\t}\n\n\t\t\t\tcolor.set( r, g, b, a );\n\n\t\t\t\tif ( currentColorClear.equals( color ) === false ) {\n\n\t\t\t\t\tgl.clearColor( r, g, b, a );\n\t\t\t\t\tcurrentColorClear.copy( color );\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\treset: function () {\n\n\t\t\t\tlocked = false;\n\n\t\t\t\tcurrentColorMask = null;\n\t\t\t\tcurrentColorClear.set( - 1, 0, 0, 0 ); // set to invalid state\n\n\t\t\t}\n\n\t\t};\n\n\t}\n\n\tfunction DepthBuffer() {\n\n\t\tvar locked = false;\n\n\t\tvar currentDepthMask = null;\n\t\tvar currentDepthFunc = null;\n\t\tvar currentDepthClear = null;\n\n\t\treturn {\n\n\t\t\tsetTest: function ( depthTest ) {\n\n\t\t\t\tif ( depthTest ) {\n\n\t\t\t\t\tenable( gl.DEPTH_TEST );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tdisable( gl.DEPTH_TEST );\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetMask: function ( depthMask ) {\n\n\t\t\t\tif ( currentDepthMask !== depthMask && ! locked ) {\n\n\t\t\t\t\tgl.depthMask( depthMask );\n\t\t\t\t\tcurrentDepthMask = depthMask;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetFunc: function ( depthFunc ) {\n\n\t\t\t\tif ( currentDepthFunc !== depthFunc ) {\n\n\t\t\t\t\tif ( depthFunc ) {\n\n\t\t\t\t\t\tswitch ( depthFunc ) {\n\n\t\t\t\t\t\t\tcase NeverDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( gl.NEVER );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase AlwaysDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( gl.ALWAYS );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase LessDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( gl.LESS );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase LessEqualDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( gl.LEQUAL );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase EqualDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( gl.EQUAL );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase GreaterEqualDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( gl.GEQUAL );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase GreaterDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( gl.GREATER );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase NotEqualDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( gl.NOTEQUAL );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tdefault:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( gl.LEQUAL );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tgl.depthFunc( gl.LEQUAL );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tcurrentDepthFunc = depthFunc;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetLocked: function ( lock ) {\n\n\t\t\t\tlocked = lock;\n\n\t\t\t},\n\n\t\t\tsetClear: function ( depth ) {\n\n\t\t\t\tif ( currentDepthClear !== depth ) {\n\n\t\t\t\t\tgl.clearDepth( depth );\n\t\t\t\t\tcurrentDepthClear = depth;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\treset: function () {\n\n\t\t\t\tlocked = false;\n\n\t\t\t\tcurrentDepthMask = null;\n\t\t\t\tcurrentDepthFunc = null;\n\t\t\t\tcurrentDepthClear = null;\n\n\t\t\t}\n\n\t\t};\n\n\t}\n\n\tfunction StencilBuffer() {\n\n\t\tvar locked = false;\n\n\t\tvar currentStencilMask = null;\n\t\tvar currentStencilFunc = null;\n\t\tvar currentStencilRef = null;\n\t\tvar currentStencilFuncMask = null;\n\t\tvar currentStencilFail = null;\n\t\tvar currentStencilZFail = null;\n\t\tvar currentStencilZPass = null;\n\t\tvar currentStencilClear = null;\n\n\t\treturn {\n\n\t\t\tsetTest: function ( stencilTest ) {\n\n\t\t\t\tif ( stencilTest ) {\n\n\t\t\t\t\tenable( gl.STENCIL_TEST );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tdisable( gl.STENCIL_TEST );\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetMask: function ( stencilMask ) {\n\n\t\t\t\tif ( currentStencilMask !== stencilMask && ! locked ) {\n\n\t\t\t\t\tgl.stencilMask( stencilMask );\n\t\t\t\t\tcurrentStencilMask = stencilMask;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetFunc: function ( stencilFunc, stencilRef, stencilMask ) {\n\n\t\t\t\tif ( currentStencilFunc !== stencilFunc ||\n\t\t\t\t     currentStencilRef \t!== stencilRef \t||\n\t\t\t\t     currentStencilFuncMask !== stencilMask ) {\n\n\t\t\t\t\tgl.stencilFunc( stencilFunc, stencilRef, stencilMask );\n\n\t\t\t\t\tcurrentStencilFunc = stencilFunc;\n\t\t\t\t\tcurrentStencilRef = stencilRef;\n\t\t\t\t\tcurrentStencilFuncMask = stencilMask;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetOp: function ( stencilFail, stencilZFail, stencilZPass ) {\n\n\t\t\t\tif ( currentStencilFail\t !== stencilFail \t||\n\t\t\t\t     currentStencilZFail !== stencilZFail ||\n\t\t\t\t     currentStencilZPass !== stencilZPass ) {\n\n\t\t\t\t\tgl.stencilOp( stencilFail, stencilZFail, stencilZPass );\n\n\t\t\t\t\tcurrentStencilFail = stencilFail;\n\t\t\t\t\tcurrentStencilZFail = stencilZFail;\n\t\t\t\t\tcurrentStencilZPass = stencilZPass;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetLocked: function ( lock ) {\n\n\t\t\t\tlocked = lock;\n\n\t\t\t},\n\n\t\t\tsetClear: function ( stencil ) {\n\n\t\t\t\tif ( currentStencilClear !== stencil ) {\n\n\t\t\t\t\tgl.clearStencil( stencil );\n\t\t\t\t\tcurrentStencilClear = stencil;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\treset: function () {\n\n\t\t\t\tlocked = false;\n\n\t\t\t\tcurrentStencilMask = null;\n\t\t\t\tcurrentStencilFunc = null;\n\t\t\t\tcurrentStencilRef = null;\n\t\t\t\tcurrentStencilFuncMask = null;\n\t\t\t\tcurrentStencilFail = null;\n\t\t\t\tcurrentStencilZFail = null;\n\t\t\t\tcurrentStencilZPass = null;\n\t\t\t\tcurrentStencilClear = null;\n\n\t\t\t}\n\n\t\t};\n\n\t}\n\n\t//\n\n\tvar colorBuffer = new ColorBuffer();\n\tvar depthBuffer = new DepthBuffer();\n\tvar stencilBuffer = new StencilBuffer();\n\n\tvar maxVertexAttributes = gl.getParameter( gl.MAX_VERTEX_ATTRIBS );\n\tvar newAttributes = new Uint8Array( maxVertexAttributes );\n\tvar enabledAttributes = new Uint8Array( maxVertexAttributes );\n\tvar attributeDivisors = new Uint8Array( maxVertexAttributes );\n\n\tvar capabilities = {};\n\n\tvar compressedTextureFormats = null;\n\n\tvar currentProgram = null;\n\n\tvar currentBlending = null;\n\tvar currentBlendEquation = null;\n\tvar currentBlendSrc = null;\n\tvar currentBlendDst = null;\n\tvar currentBlendEquationAlpha = null;\n\tvar currentBlendSrcAlpha = null;\n\tvar currentBlendDstAlpha = null;\n\tvar currentPremultipledAlpha = false;\n\n\tvar currentFlipSided = null;\n\tvar currentCullFace = null;\n\n\tvar currentLineWidth = null;\n\n\tvar currentPolygonOffsetFactor = null;\n\tvar currentPolygonOffsetUnits = null;\n\n\tvar maxTextures = gl.getParameter( gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS );\n\n\tvar lineWidthAvailable = false;\n\tvar version = 0;\n\tvar glVersion = gl.getParameter( gl.VERSION );\n\n\tif ( glVersion.indexOf( 'WebGL' ) !== - 1 ) {\n\n\t\tversion = parseFloat( /^WebGL\\ ([0-9])/.exec( glVersion )[ 1 ] );\n\t\tlineWidthAvailable = ( version >= 1.0 );\n\n\t} else if ( glVersion.indexOf( 'OpenGL ES' ) !== - 1 ) {\n\n\t\tversion = parseFloat( /^OpenGL\\ ES\\ ([0-9])/.exec( glVersion )[ 1 ] );\n\t\tlineWidthAvailable = ( version >= 2.0 );\n\n\t}\n\n\tvar currentTextureSlot = null;\n\tvar currentBoundTextures = {};\n\n\tvar currentScissor = new Vector4();\n\tvar currentViewport = new Vector4();\n\n\tfunction createTexture( type, target, count ) {\n\n\t\tvar data = new Uint8Array( 4 ); // 4 is required to match default unpack alignment of 4.\n\t\tvar texture = gl.createTexture();\n\n\t\tgl.bindTexture( type, texture );\n\t\tgl.texParameteri( type, gl.TEXTURE_MIN_FILTER, gl.NEAREST );\n\t\tgl.texParameteri( type, gl.TEXTURE_MAG_FILTER, gl.NEAREST );\n\n\t\tfor ( var i = 0; i < count; i ++ ) {\n\n\t\t\tgl.texImage2D( target + i, 0, gl.RGBA, 1, 1, 0, gl.RGBA, gl.UNSIGNED_BYTE, data );\n\n\t\t}\n\n\t\treturn texture;\n\n\t}\n\n\tvar emptyTextures = {};\n\temptyTextures[ gl.TEXTURE_2D ] = createTexture( gl.TEXTURE_2D, gl.TEXTURE_2D, 1 );\n\temptyTextures[ gl.TEXTURE_CUBE_MAP ] = createTexture( gl.TEXTURE_CUBE_MAP, gl.TEXTURE_CUBE_MAP_POSITIVE_X, 6 );\n\n\t// init\n\n\tcolorBuffer.setClear( 0, 0, 0, 1 );\n\tdepthBuffer.setClear( 1 );\n\tstencilBuffer.setClear( 0 );\n\n\tenable( gl.DEPTH_TEST );\n\tdepthBuffer.setFunc( LessEqualDepth );\n\n\tsetFlipSided( false );\n\tsetCullFace( CullFaceBack );\n\tenable( gl.CULL_FACE );\n\n\tenable( gl.BLEND );\n\tsetBlending( NormalBlending );\n\n\t//\n\n\tfunction initAttributes() {\n\n\t\tfor ( var i = 0, l = newAttributes.length; i < l; i ++ ) {\n\n\t\t\tnewAttributes[ i ] = 0;\n\n\t\t}\n\n\t}\n\n\tfunction enableAttribute( attribute ) {\n\n\t\tnewAttributes[ attribute ] = 1;\n\n\t\tif ( enabledAttributes[ attribute ] === 0 ) {\n\n\t\t\tgl.enableVertexAttribArray( attribute );\n\t\t\tenabledAttributes[ attribute ] = 1;\n\n\t\t}\n\n\t\tif ( attributeDivisors[ attribute ] !== 0 ) {\n\n\t\t\tvar extension = extensions.get( 'ANGLE_instanced_arrays' );\n\n\t\t\textension.vertexAttribDivisorANGLE( attribute, 0 );\n\t\t\tattributeDivisors[ attribute ] = 0;\n\n\t\t}\n\n\t}\n\n\tfunction enableAttributeAndDivisor( attribute, meshPerAttribute ) {\n\n\t\tnewAttributes[ attribute ] = 1;\n\n\t\tif ( enabledAttributes[ attribute ] === 0 ) {\n\n\t\t\tgl.enableVertexAttribArray( attribute );\n\t\t\tenabledAttributes[ attribute ] = 1;\n\n\t\t}\n\n\t\tif ( attributeDivisors[ attribute ] !== meshPerAttribute ) {\n\n\t\t\tvar extension = extensions.get( 'ANGLE_instanced_arrays' );\n\n\t\t\textension.vertexAttribDivisorANGLE( attribute, meshPerAttribute );\n\t\t\tattributeDivisors[ attribute ] = meshPerAttribute;\n\n\t\t}\n\n\t}\n\n\tfunction disableUnusedAttributes() {\n\n\t\tfor ( var i = 0, l = enabledAttributes.length; i !== l; ++ i ) {\n\n\t\t\tif ( enabledAttributes[ i ] !== newAttributes[ i ] ) {\n\n\t\t\t\tgl.disableVertexAttribArray( i );\n\t\t\t\tenabledAttributes[ i ] = 0;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction enable( id ) {\n\n\t\tif ( capabilities[ id ] !== true ) {\n\n\t\t\tgl.enable( id );\n\t\t\tcapabilities[ id ] = true;\n\n\t\t}\n\n\t}\n\n\tfunction disable( id ) {\n\n\t\tif ( capabilities[ id ] !== false ) {\n\n\t\t\tgl.disable( id );\n\t\t\tcapabilities[ id ] = false;\n\n\t\t}\n\n\t}\n\n\tfunction getCompressedTextureFormats() {\n\n\t\tif ( compressedTextureFormats === null ) {\n\n\t\t\tcompressedTextureFormats = [];\n\n\t\t\tif ( extensions.get( 'WEBGL_compressed_texture_pvrtc' ) ||\n\t\t\t     extensions.get( 'WEBGL_compressed_texture_s3tc' ) ||\n\t\t\t     extensions.get( 'WEBGL_compressed_texture_etc1' ) ||\n\t\t\t     extensions.get( 'WEBGL_compressed_texture_astc' ) ) {\n\n\t\t\t\tvar formats = gl.getParameter( gl.COMPRESSED_TEXTURE_FORMATS );\n\n\t\t\t\tfor ( var i = 0; i < formats.length; i ++ ) {\n\n\t\t\t\t\tcompressedTextureFormats.push( formats[ i ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn compressedTextureFormats;\n\n\t}\n\n\tfunction useProgram( program ) {\n\n\t\tif ( currentProgram !== program ) {\n\n\t\t\tgl.useProgram( program );\n\n\t\t\tcurrentProgram = program;\n\n\t\t\treturn true;\n\n\t\t}\n\n\t\treturn false;\n\n\t}\n\n\tfunction setBlending( blending, blendEquation, blendSrc, blendDst, blendEquationAlpha, blendSrcAlpha, blendDstAlpha, premultipliedAlpha ) {\n\n\t\tif ( blending !== NoBlending ) {\n\n\t\t\tenable( gl.BLEND );\n\n\t\t} else {\n\n\t\t\tdisable( gl.BLEND );\n\n\t\t}\n\n\t\tif ( blending !== CustomBlending ) {\n\n\t\t\tif ( blending !== currentBlending || premultipliedAlpha !== currentPremultipledAlpha ) {\n\n\t\t\t\tswitch ( blending ) {\n\n\t\t\t\t\tcase AdditiveBlending:\n\n\t\t\t\t\t\tif ( premultipliedAlpha ) {\n\n\t\t\t\t\t\t\tgl.blendEquationSeparate( gl.FUNC_ADD, gl.FUNC_ADD );\n\t\t\t\t\t\t\tgl.blendFuncSeparate( gl.ONE, gl.ONE, gl.ONE, gl.ONE );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tgl.blendEquation( gl.FUNC_ADD );\n\t\t\t\t\t\t\tgl.blendFunc( gl.SRC_ALPHA, gl.ONE );\n\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase SubtractiveBlending:\n\n\t\t\t\t\t\tif ( premultipliedAlpha ) {\n\n\t\t\t\t\t\t\tgl.blendEquationSeparate( gl.FUNC_ADD, gl.FUNC_ADD );\n\t\t\t\t\t\t\tgl.blendFuncSeparate( gl.ZERO, gl.ZERO, gl.ONE_MINUS_SRC_COLOR, gl.ONE_MINUS_SRC_ALPHA );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tgl.blendEquation( gl.FUNC_ADD );\n\t\t\t\t\t\t\tgl.blendFunc( gl.ZERO, gl.ONE_MINUS_SRC_COLOR );\n\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase MultiplyBlending:\n\n\t\t\t\t\t\tif ( premultipliedAlpha ) {\n\n\t\t\t\t\t\t\tgl.blendEquationSeparate( gl.FUNC_ADD, gl.FUNC_ADD );\n\t\t\t\t\t\t\tgl.blendFuncSeparate( gl.ZERO, gl.SRC_COLOR, gl.ZERO, gl.SRC_ALPHA );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tgl.blendEquation( gl.FUNC_ADD );\n\t\t\t\t\t\t\tgl.blendFunc( gl.ZERO, gl.SRC_COLOR );\n\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\n\t\t\t\t\t\tif ( premultipliedAlpha ) {\n\n\t\t\t\t\t\t\tgl.blendEquationSeparate( gl.FUNC_ADD, gl.FUNC_ADD );\n\t\t\t\t\t\t\tgl.blendFuncSeparate( gl.ONE, gl.ONE_MINUS_SRC_ALPHA, gl.ONE, gl.ONE_MINUS_SRC_ALPHA );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tgl.blendEquationSeparate( gl.FUNC_ADD, gl.FUNC_ADD );\n\t\t\t\t\t\t\tgl.blendFuncSeparate( gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA, gl.ONE, gl.ONE_MINUS_SRC_ALPHA );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tcurrentBlendEquation = null;\n\t\t\tcurrentBlendSrc = null;\n\t\t\tcurrentBlendDst = null;\n\t\t\tcurrentBlendEquationAlpha = null;\n\t\t\tcurrentBlendSrcAlpha = null;\n\t\t\tcurrentBlendDstAlpha = null;\n\n\t\t} else {\n\n\t\t\tblendEquationAlpha = blendEquationAlpha || blendEquation;\n\t\t\tblendSrcAlpha = blendSrcAlpha || blendSrc;\n\t\t\tblendDstAlpha = blendDstAlpha || blendDst;\n\n\t\t\tif ( blendEquation !== currentBlendEquation || blendEquationAlpha !== currentBlendEquationAlpha ) {\n\n\t\t\t\tgl.blendEquationSeparate( utils.convert( blendEquation ), utils.convert( blendEquationAlpha ) );\n\n\t\t\t\tcurrentBlendEquation = blendEquation;\n\t\t\t\tcurrentBlendEquationAlpha = blendEquationAlpha;\n\n\t\t\t}\n\n\t\t\tif ( blendSrc !== currentBlendSrc || blendDst !== currentBlendDst || blendSrcAlpha !== currentBlendSrcAlpha || blendDstAlpha !== currentBlendDstAlpha ) {\n\n\t\t\t\tgl.blendFuncSeparate( utils.convert( blendSrc ), utils.convert( blendDst ), utils.convert( blendSrcAlpha ), utils.convert( blendDstAlpha ) );\n\n\t\t\t\tcurrentBlendSrc = blendSrc;\n\t\t\t\tcurrentBlendDst = blendDst;\n\t\t\t\tcurrentBlendSrcAlpha = blendSrcAlpha;\n\t\t\t\tcurrentBlendDstAlpha = blendDstAlpha;\n\n\t\t\t}\n\n\t\t}\n\n\t\tcurrentBlending = blending;\n\t\tcurrentPremultipledAlpha = premultipliedAlpha;\n\n\t}\n\n\tfunction setMaterial( material, frontFaceCW ) {\n\n\t\tmaterial.side === DoubleSide\n\t\t\t? disable( gl.CULL_FACE )\n\t\t\t: enable( gl.CULL_FACE );\n\n\t\tvar flipSided = ( material.side === BackSide );\n\t\tif ( frontFaceCW ) flipSided = ! flipSided;\n\n\t\tsetFlipSided( flipSided );\n\n\t\tmaterial.transparent === true\n\t\t\t? setBlending( material.blending, material.blendEquation, material.blendSrc, material.blendDst, material.blendEquationAlpha, material.blendSrcAlpha, material.blendDstAlpha, material.premultipliedAlpha )\n\t\t\t: setBlending( NoBlending );\n\n\t\tdepthBuffer.setFunc( material.depthFunc );\n\t\tdepthBuffer.setTest( material.depthTest );\n\t\tdepthBuffer.setMask( material.depthWrite );\n\t\tcolorBuffer.setMask( material.colorWrite );\n\n\t\tsetPolygonOffset( material.polygonOffset, material.polygonOffsetFactor, material.polygonOffsetUnits );\n\n\t}\n\n\t//\n\n\tfunction setFlipSided( flipSided ) {\n\n\t\tif ( currentFlipSided !== flipSided ) {\n\n\t\t\tif ( flipSided ) {\n\n\t\t\t\tgl.frontFace( gl.CW );\n\n\t\t\t} else {\n\n\t\t\t\tgl.frontFace( gl.CCW );\n\n\t\t\t}\n\n\t\t\tcurrentFlipSided = flipSided;\n\n\t\t}\n\n\t}\n\n\tfunction setCullFace( cullFace ) {\n\n\t\tif ( cullFace !== CullFaceNone ) {\n\n\t\t\tenable( gl.CULL_FACE );\n\n\t\t\tif ( cullFace !== currentCullFace ) {\n\n\t\t\t\tif ( cullFace === CullFaceBack ) {\n\n\t\t\t\t\tgl.cullFace( gl.BACK );\n\n\t\t\t\t} else if ( cullFace === CullFaceFront ) {\n\n\t\t\t\t\tgl.cullFace( gl.FRONT );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tgl.cullFace( gl.FRONT_AND_BACK );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tdisable( gl.CULL_FACE );\n\n\t\t}\n\n\t\tcurrentCullFace = cullFace;\n\n\t}\n\n\tfunction setLineWidth( width ) {\n\n\t\tif ( width !== currentLineWidth ) {\n\n\t\t\tif ( lineWidthAvailable ) gl.lineWidth( width );\n\n\t\t\tcurrentLineWidth = width;\n\n\t\t}\n\n\t}\n\n\tfunction setPolygonOffset( polygonOffset, factor, units ) {\n\n\t\tif ( polygonOffset ) {\n\n\t\t\tenable( gl.POLYGON_OFFSET_FILL );\n\n\t\t\tif ( currentPolygonOffsetFactor !== factor || currentPolygonOffsetUnits !== units ) {\n\n\t\t\t\tgl.polygonOffset( factor, units );\n\n\t\t\t\tcurrentPolygonOffsetFactor = factor;\n\t\t\t\tcurrentPolygonOffsetUnits = units;\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tdisable( gl.POLYGON_OFFSET_FILL );\n\n\t\t}\n\n\t}\n\n\tfunction setScissorTest( scissorTest ) {\n\n\t\tif ( scissorTest ) {\n\n\t\t\tenable( gl.SCISSOR_TEST );\n\n\t\t} else {\n\n\t\t\tdisable( gl.SCISSOR_TEST );\n\n\t\t}\n\n\t}\n\n\t// texture\n\n\tfunction activeTexture( webglSlot ) {\n\n\t\tif ( webglSlot === undefined ) webglSlot = gl.TEXTURE0 + maxTextures - 1;\n\n\t\tif ( currentTextureSlot !== webglSlot ) {\n\n\t\t\tgl.activeTexture( webglSlot );\n\t\t\tcurrentTextureSlot = webglSlot;\n\n\t\t}\n\n\t}\n\n\tfunction bindTexture( webglType, webglTexture ) {\n\n\t\tif ( currentTextureSlot === null ) {\n\n\t\t\tactiveTexture();\n\n\t\t}\n\n\t\tvar boundTexture = currentBoundTextures[ currentTextureSlot ];\n\n\t\tif ( boundTexture === undefined ) {\n\n\t\t\tboundTexture = { type: undefined, texture: undefined };\n\t\t\tcurrentBoundTextures[ currentTextureSlot ] = boundTexture;\n\n\t\t}\n\n\t\tif ( boundTexture.type !== webglType || boundTexture.texture !== webglTexture ) {\n\n\t\t\tgl.bindTexture( webglType, webglTexture || emptyTextures[ webglType ] );\n\n\t\t\tboundTexture.type = webglType;\n\t\t\tboundTexture.texture = webglTexture;\n\n\t\t}\n\n\t}\n\n\tfunction compressedTexImage2D() {\n\n\t\ttry {\n\n\t\t\tgl.compressedTexImage2D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\tfunction texImage2D() {\n\n\t\ttry {\n\n\t\t\tgl.texImage2D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\t//\n\n\tfunction scissor( scissor ) {\n\n\t\tif ( currentScissor.equals( scissor ) === false ) {\n\n\t\t\tgl.scissor( scissor.x, scissor.y, scissor.z, scissor.w );\n\t\t\tcurrentScissor.copy( scissor );\n\n\t\t}\n\n\t}\n\n\tfunction viewport( viewport ) {\n\n\t\tif ( currentViewport.equals( viewport ) === false ) {\n\n\t\t\tgl.viewport( viewport.x, viewport.y, viewport.z, viewport.w );\n\t\t\tcurrentViewport.copy( viewport );\n\n\t\t}\n\n\t}\n\n\t//\n\n\tfunction reset() {\n\n\t\tfor ( var i = 0; i < enabledAttributes.length; i ++ ) {\n\n\t\t\tif ( enabledAttributes[ i ] === 1 ) {\n\n\t\t\t\tgl.disableVertexAttribArray( i );\n\t\t\t\tenabledAttributes[ i ] = 0;\n\n\t\t\t}\n\n\t\t}\n\n\t\tcapabilities = {};\n\n\t\tcompressedTextureFormats = null;\n\n\t\tcurrentTextureSlot = null;\n\t\tcurrentBoundTextures = {};\n\n\t\tcurrentProgram = null;\n\n\t\tcurrentBlending = null;\n\n\t\tcurrentFlipSided = null;\n\t\tcurrentCullFace = null;\n\n\t\tcolorBuffer.reset();\n\t\tdepthBuffer.reset();\n\t\tstencilBuffer.reset();\n\n\t}\n\n\treturn {\n\n\t\tbuffers: {\n\t\t\tcolor: colorBuffer,\n\t\t\tdepth: depthBuffer,\n\t\t\tstencil: stencilBuffer\n\t\t},\n\n\t\tinitAttributes: initAttributes,\n\t\tenableAttribute: enableAttribute,\n\t\tenableAttributeAndDivisor: enableAttributeAndDivisor,\n\t\tdisableUnusedAttributes: disableUnusedAttributes,\n\t\tenable: enable,\n\t\tdisable: disable,\n\t\tgetCompressedTextureFormats: getCompressedTextureFormats,\n\n\t\tuseProgram: useProgram,\n\n\t\tsetBlending: setBlending,\n\t\tsetMaterial: setMaterial,\n\n\t\tsetFlipSided: setFlipSided,\n\t\tsetCullFace: setCullFace,\n\n\t\tsetLineWidth: setLineWidth,\n\t\tsetPolygonOffset: setPolygonOffset,\n\n\t\tsetScissorTest: setScissorTest,\n\n\t\tactiveTexture: activeTexture,\n\t\tbindTexture: bindTexture,\n\t\tcompressedTexImage2D: compressedTexImage2D,\n\t\ttexImage2D: texImage2D,\n\n\t\tscissor: scissor,\n\t\tviewport: viewport,\n\n\t\treset: reset\n\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebGLTextures( _gl, extensions, state, properties, capabilities, utils, info ) {\n\n\tvar _isWebGL2 = ( typeof WebGL2RenderingContext !== 'undefined' && _gl instanceof WebGL2RenderingContext ); /* global WebGL2RenderingContext */\n\tvar _videoTextures = {};\n\tvar _canvas;\n\n\t//\n\n\tfunction clampToMaxSize( image, maxSize ) {\n\n\t\tif ( image.width > maxSize || image.height > maxSize ) {\n\n\t\t\tif ( 'data' in image ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: image in DataTexture is too big (' + image.width + 'x' + image.height + ').' );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t\t// Warning: Scaling through the canvas will only work with images that use\n\t\t\t// premultiplied alpha.\n\n\t\t\tvar scale = maxSize / Math.max( image.width, image.height );\n\n\t\t\tvar canvas = document.createElementNS( 'http://www.w3.org/1999/xhtml', 'canvas' );\n\t\t\tcanvas.width = Math.floor( image.width * scale );\n\t\t\tcanvas.height = Math.floor( image.height * scale );\n\n\t\t\tvar context = canvas.getContext( '2d' );\n\t\t\tcontext.drawImage( image, 0, 0, image.width, image.height, 0, 0, canvas.width, canvas.height );\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: image is too big (' + image.width + 'x' + image.height + '). Resized to ' + canvas.width + 'x' + canvas.height, image );\n\n\t\t\treturn canvas;\n\n\t\t}\n\n\t\treturn image;\n\n\t}\n\n\tfunction isPowerOfTwo( image ) {\n\n\t\treturn _Math.isPowerOfTwo( image.width ) && _Math.isPowerOfTwo( image.height );\n\n\t}\n\n\tfunction makePowerOfTwo( image ) {\n\n\t\tif ( image instanceof HTMLImageElement || image instanceof HTMLCanvasElement || image instanceof ImageBitmap ) {\n\n\t\t\tif ( _canvas === undefined ) _canvas = document.createElementNS( 'http://www.w3.org/1999/xhtml', 'canvas' );\n\n\t\t\t_canvas.width = _Math.floorPowerOfTwo( image.width );\n\t\t\t_canvas.height = _Math.floorPowerOfTwo( image.height );\n\n\t\t\tvar context = _canvas.getContext( '2d' );\n\t\t\tcontext.drawImage( image, 0, 0, _canvas.width, _canvas.height );\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: image is not power of two (' + image.width + 'x' + image.height + '). Resized to ' + _canvas.width + 'x' + _canvas.height, image );\n\n\t\t\treturn _canvas;\n\n\t\t}\n\n\t\treturn image;\n\n\t}\n\n\tfunction textureNeedsPowerOfTwo( texture ) {\n\n\t\treturn ( texture.wrapS !== ClampToEdgeWrapping || texture.wrapT !== ClampToEdgeWrapping ) ||\n\t\t\t( texture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter );\n\n\t}\n\n\tfunction textureNeedsGenerateMipmaps( texture, isPowerOfTwo ) {\n\n\t\treturn texture.generateMipmaps && isPowerOfTwo &&\n\t\t\ttexture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter;\n\n\t}\n\n\tfunction generateMipmap( target, texture, width, height ) {\n\n\t\t_gl.generateMipmap( target );\n\n\t\tvar textureProperties = properties.get( texture );\n\n\t\t// Note: Math.log( x ) * Math.LOG2E used instead of Math.log2( x ) which is not supported by IE11\n\t\ttextureProperties.__maxMipLevel = Math.log( Math.max( width, height ) ) * Math.LOG2E;\n\n\t}\n\n\t// Fallback filters for non-power-of-2 textures\n\n\tfunction filterFallback( f ) {\n\n\t\tif ( f === NearestFilter || f === NearestMipMapNearestFilter || f === NearestMipMapLinearFilter ) {\n\n\t\t\treturn _gl.NEAREST;\n\n\t\t}\n\n\t\treturn _gl.LINEAR;\n\n\t}\n\n\t//\n\n\tfunction onTextureDispose( event ) {\n\n\t\tvar texture = event.target;\n\n\t\ttexture.removeEventListener( 'dispose', onTextureDispose );\n\n\t\tdeallocateTexture( texture );\n\n\t\tif ( texture.isVideoTexture ) {\n\n\t\t\tdelete _videoTextures[ texture.id ];\n\n\t\t}\n\n\t\tinfo.memory.textures --;\n\n\t}\n\n\tfunction onRenderTargetDispose( event ) {\n\n\t\tvar renderTarget = event.target;\n\n\t\trenderTarget.removeEventListener( 'dispose', onRenderTargetDispose );\n\n\t\tdeallocateRenderTarget( renderTarget );\n\n\t\tinfo.memory.textures --;\n\n\t}\n\n\t//\n\n\tfunction deallocateTexture( texture ) {\n\n\t\tvar textureProperties = properties.get( texture );\n\n\t\tif ( texture.image && textureProperties.__image__webglTextureCube ) {\n\n\t\t\t// cube texture\n\n\t\t\t_gl.deleteTexture( textureProperties.__image__webglTextureCube );\n\n\t\t} else {\n\n\t\t\t// 2D texture\n\n\t\t\tif ( textureProperties.__webglInit === undefined ) return;\n\n\t\t\t_gl.deleteTexture( textureProperties.__webglTexture );\n\n\t\t}\n\n\t\t// remove all webgl properties\n\t\tproperties.remove( texture );\n\n\t}\n\n\tfunction deallocateRenderTarget( renderTarget ) {\n\n\t\tvar renderTargetProperties = properties.get( renderTarget );\n\t\tvar textureProperties = properties.get( renderTarget.texture );\n\n\t\tif ( ! renderTarget ) return;\n\n\t\tif ( textureProperties.__webglTexture !== undefined ) {\n\n\t\t\t_gl.deleteTexture( textureProperties.__webglTexture );\n\n\t\t}\n\n\t\tif ( renderTarget.depthTexture ) {\n\n\t\t\trenderTarget.depthTexture.dispose();\n\n\t\t}\n\n\t\tif ( renderTarget.isWebGLRenderTargetCube ) {\n\n\t\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\t\t_gl.deleteFramebuffer( renderTargetProperties.__webglFramebuffer[ i ] );\n\t\t\t\tif ( renderTargetProperties.__webglDepthbuffer ) _gl.deleteRenderbuffer( renderTargetProperties.__webglDepthbuffer[ i ] );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t_gl.deleteFramebuffer( renderTargetProperties.__webglFramebuffer );\n\t\t\tif ( renderTargetProperties.__webglDepthbuffer ) _gl.deleteRenderbuffer( renderTargetProperties.__webglDepthbuffer );\n\n\t\t}\n\n\t\tproperties.remove( renderTarget.texture );\n\t\tproperties.remove( renderTarget );\n\n\t}\n\n\t//\n\n\n\n\tfunction setTexture2D( texture, slot ) {\n\n\t\tvar textureProperties = properties.get( texture );\n\n\t\tif ( texture.isVideoTexture ) updateVideoTexture( texture );\n\n\t\tif ( texture.version > 0 && textureProperties.__version !== texture.version ) {\n\n\t\t\tvar image = texture.image;\n\n\t\t\tif ( image === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Texture marked for update but image is undefined', texture );\n\n\t\t\t} else if ( image.complete === false ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Texture marked for update but image is incomplete', texture );\n\n\t\t\t} else {\n\n\t\t\t\tuploadTexture( textureProperties, texture, slot );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t}\n\n\t\tstate.activeTexture( _gl.TEXTURE0 + slot );\n\t\tstate.bindTexture( _gl.TEXTURE_2D, textureProperties.__webglTexture );\n\n\t}\n\n\tfunction setTextureCube( texture, slot ) {\n\n\t\tvar textureProperties = properties.get( texture );\n\n\t\tif ( texture.image.length === 6 ) {\n\n\t\t\tif ( texture.version > 0 && textureProperties.__version !== texture.version ) {\n\n\t\t\t\tif ( ! textureProperties.__image__webglTextureCube ) {\n\n\t\t\t\t\ttexture.addEventListener( 'dispose', onTextureDispose );\n\n\t\t\t\t\ttextureProperties.__image__webglTextureCube = _gl.createTexture();\n\n\t\t\t\t\tinfo.memory.textures ++;\n\n\t\t\t\t}\n\n\t\t\t\tstate.activeTexture( _gl.TEXTURE0 + slot );\n\t\t\t\tstate.bindTexture( _gl.TEXTURE_CUBE_MAP, textureProperties.__image__webglTextureCube );\n\n\t\t\t\t_gl.pixelStorei( _gl.UNPACK_FLIP_Y_WEBGL, texture.flipY );\n\n\t\t\t\tvar isCompressed = ( texture && texture.isCompressedTexture );\n\t\t\t\tvar isDataTexture = ( texture.image[ 0 ] && texture.image[ 0 ].isDataTexture );\n\n\t\t\t\tvar cubeImage = [];\n\n\t\t\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\t\t\tif ( ! isCompressed && ! isDataTexture ) {\n\n\t\t\t\t\t\tcubeImage[ i ] = clampToMaxSize( texture.image[ i ], capabilities.maxCubemapSize );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tcubeImage[ i ] = isDataTexture ? texture.image[ i ].image : texture.image[ i ];\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tvar image = cubeImage[ 0 ],\n\t\t\t\t\tisPowerOfTwoImage = isPowerOfTwo( image ),\n\t\t\t\t\tglFormat = utils.convert( texture.format ),\n\t\t\t\t\tglType = utils.convert( texture.type );\n\n\t\t\t\tsetTextureParameters( _gl.TEXTURE_CUBE_MAP, texture, isPowerOfTwoImage );\n\n\t\t\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\t\t\tif ( ! isCompressed ) {\n\n\t\t\t\t\t\tif ( isDataTexture ) {\n\n\t\t\t\t\t\t\tstate.texImage2D( _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, 0, glFormat, cubeImage[ i ].width, cubeImage[ i ].height, 0, glFormat, glType, cubeImage[ i ].data );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tstate.texImage2D( _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, 0, glFormat, glFormat, glType, cubeImage[ i ] );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tvar mipmap, mipmaps = cubeImage[ i ].mipmaps;\n\n\t\t\t\t\t\tfor ( var j = 0, jl = mipmaps.length; j < jl; j ++ ) {\n\n\t\t\t\t\t\t\tmipmap = mipmaps[ j ];\n\n\t\t\t\t\t\t\tif ( texture.format !== RGBAFormat && texture.format !== RGBFormat ) {\n\n\t\t\t\t\t\t\t\tif ( state.getCompressedTextureFormats().indexOf( glFormat ) > - 1 ) {\n\n\t\t\t\t\t\t\t\t\tstate.compressedTexImage2D( _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j, glFormat, mipmap.width, mipmap.height, 0, mipmap.data );\n\n\t\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()' );\n\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\tstate.texImage2D( _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j, glFormat, mipmap.width, mipmap.height, 0, glFormat, glType, mipmap.data );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tif ( ! isCompressed ) {\n\n\t\t\t\t\ttextureProperties.__maxMipLevel = 0;\n\n\t\t\t\t} else {\n\n\t\t\t\t\ttextureProperties.__maxMipLevel = mipmaps.length - 1;\n\n\t\t\t\t}\n\n\t\t\t\tif ( textureNeedsGenerateMipmaps( texture, isPowerOfTwoImage ) ) {\n\n\t\t\t\t\t// We assume images for cube map have the same size.\n\t\t\t\t\tgenerateMipmap( _gl.TEXTURE_CUBE_MAP, texture, image.width, image.height );\n\n\t\t\t\t}\n\n\t\t\t\ttextureProperties.__version = texture.version;\n\n\t\t\t\tif ( texture.onUpdate ) texture.onUpdate( texture );\n\n\t\t\t} else {\n\n\t\t\t\tstate.activeTexture( _gl.TEXTURE0 + slot );\n\t\t\t\tstate.bindTexture( _gl.TEXTURE_CUBE_MAP, textureProperties.__image__webglTextureCube );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction setTextureCubeDynamic( texture, slot ) {\n\n\t\tstate.activeTexture( _gl.TEXTURE0 + slot );\n\t\tstate.bindTexture( _gl.TEXTURE_CUBE_MAP, properties.get( texture ).__webglTexture );\n\n\t}\n\n\tfunction setTextureParameters( textureType, texture, isPowerOfTwoImage ) {\n\n\t\tvar extension;\n\n\t\tif ( isPowerOfTwoImage ) {\n\n\t\t\t_gl.texParameteri( textureType, _gl.TEXTURE_WRAP_S, utils.convert( texture.wrapS ) );\n\t\t\t_gl.texParameteri( textureType, _gl.TEXTURE_WRAP_T, utils.convert( texture.wrapT ) );\n\n\t\t\t_gl.texParameteri( textureType, _gl.TEXTURE_MAG_FILTER, utils.convert( texture.magFilter ) );\n\t\t\t_gl.texParameteri( textureType, _gl.TEXTURE_MIN_FILTER, utils.convert( texture.minFilter ) );\n\n\t\t} else {\n\n\t\t\t_gl.texParameteri( textureType, _gl.TEXTURE_WRAP_S, _gl.CLAMP_TO_EDGE );\n\t\t\t_gl.texParameteri( textureType, _gl.TEXTURE_WRAP_T, _gl.CLAMP_TO_EDGE );\n\n\t\t\tif ( texture.wrapS !== ClampToEdgeWrapping || texture.wrapT !== ClampToEdgeWrapping ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping.', texture );\n\n\t\t\t}\n\n\t\t\t_gl.texParameteri( textureType, _gl.TEXTURE_MAG_FILTER, filterFallback( texture.magFilter ) );\n\t\t\t_gl.texParameteri( textureType, _gl.TEXTURE_MIN_FILTER, filterFallback( texture.minFilter ) );\n\n\t\t\tif ( texture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter.', texture );\n\n\t\t\t}\n\n\t\t}\n\n\t\textension = extensions.get( 'EXT_texture_filter_anisotropic' );\n\n\t\tif ( extension ) {\n\n\t\t\tif ( texture.type === FloatType && extensions.get( 'OES_texture_float_linear' ) === null ) return;\n\t\t\tif ( texture.type === HalfFloatType && extensions.get( 'OES_texture_half_float_linear' ) === null ) return;\n\n\t\t\tif ( texture.anisotropy > 1 || properties.get( texture ).__currentAnisotropy ) {\n\n\t\t\t\t_gl.texParameterf( textureType, extension.TEXTURE_MAX_ANISOTROPY_EXT, Math.min( texture.anisotropy, capabilities.getMaxAnisotropy() ) );\n\t\t\t\tproperties.get( texture ).__currentAnisotropy = texture.anisotropy;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction uploadTexture( textureProperties, texture, slot ) {\n\n\t\tif ( textureProperties.__webglInit === undefined ) {\n\n\t\t\ttextureProperties.__webglInit = true;\n\n\t\t\ttexture.addEventListener( 'dispose', onTextureDispose );\n\n\t\t\ttextureProperties.__webglTexture = _gl.createTexture();\n\n\t\t\tinfo.memory.textures ++;\n\n\t\t}\n\n\t\tstate.activeTexture( _gl.TEXTURE0 + slot );\n\t\tstate.bindTexture( _gl.TEXTURE_2D, textureProperties.__webglTexture );\n\n\t\t_gl.pixelStorei( _gl.UNPACK_FLIP_Y_WEBGL, texture.flipY );\n\t\t_gl.pixelStorei( _gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, texture.premultiplyAlpha );\n\t\t_gl.pixelStorei( _gl.UNPACK_ALIGNMENT, texture.unpackAlignment );\n\n\t\tvar image = clampToMaxSize( texture.image, capabilities.maxTextureSize );\n\n\t\tif ( textureNeedsPowerOfTwo( texture ) && isPowerOfTwo( image ) === false ) {\n\n\t\t\timage = makePowerOfTwo( image );\n\n\t\t}\n\n\t\tvar isPowerOfTwoImage = isPowerOfTwo( image ),\n\t\t\tglFormat = utils.convert( texture.format ),\n\t\t\tglType = utils.convert( texture.type );\n\n\t\tsetTextureParameters( _gl.TEXTURE_2D, texture, isPowerOfTwoImage );\n\n\t\tvar mipmap, mipmaps = texture.mipmaps;\n\n\t\tif ( texture.isDepthTexture ) {\n\n\t\t\t// populate depth texture with dummy data\n\n\t\t\tvar internalFormat = _gl.DEPTH_COMPONENT;\n\n\t\t\tif ( texture.type === FloatType ) {\n\n\t\t\t\tif ( ! _isWebGL2 ) throw new Error( 'Float Depth Texture only supported in WebGL2.0' );\n\t\t\t\tinternalFormat = _gl.DEPTH_COMPONENT32F;\n\n\t\t\t} else if ( _isWebGL2 ) {\n\n\t\t\t\t// WebGL 2.0 requires signed internalformat for glTexImage2D\n\t\t\t\tinternalFormat = _gl.DEPTH_COMPONENT16;\n\n\t\t\t}\n\n\t\t\tif ( texture.format === DepthFormat && internalFormat === _gl.DEPTH_COMPONENT ) {\n\n\t\t\t\t// The error INVALID_OPERATION is generated by texImage2D if format and internalformat are\n\t\t\t\t// DEPTH_COMPONENT and type is not UNSIGNED_SHORT or UNSIGNED_INT\n\t\t\t\t// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)\n\t\t\t\tif ( texture.type !== UnsignedShortType && texture.type !== UnsignedIntType ) {\n\n\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture.' );\n\n\t\t\t\t\ttexture.type = UnsignedShortType;\n\t\t\t\t\tglType = utils.convert( texture.type );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// Depth stencil textures need the DEPTH_STENCIL internal format\n\t\t\t// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)\n\t\t\tif ( texture.format === DepthStencilFormat ) {\n\n\t\t\t\tinternalFormat = _gl.DEPTH_STENCIL;\n\n\t\t\t\t// The error INVALID_OPERATION is generated by texImage2D if format and internalformat are\n\t\t\t\t// DEPTH_STENCIL and type is not UNSIGNED_INT_24_8_WEBGL.\n\t\t\t\t// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)\n\t\t\t\tif ( texture.type !== UnsignedInt248Type ) {\n\n\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture.' );\n\n\t\t\t\t\ttexture.type = UnsignedInt248Type;\n\t\t\t\t\tglType = utils.convert( texture.type );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tstate.texImage2D( _gl.TEXTURE_2D, 0, internalFormat, image.width, image.height, 0, glFormat, glType, null );\n\n\t\t} else if ( texture.isDataTexture ) {\n\n\t\t\t// use manually created mipmaps if available\n\t\t\t// if there are no manual mipmaps\n\t\t\t// set 0 level mipmap and then use GL to generate other mipmap levels\n\n\t\t\tif ( mipmaps.length > 0 && isPowerOfTwoImage ) {\n\n\t\t\t\tfor ( var i = 0, il = mipmaps.length; i < il; i ++ ) {\n\n\t\t\t\t\tmipmap = mipmaps[ i ];\n\t\t\t\t\tstate.texImage2D( _gl.TEXTURE_2D, i, glFormat, mipmap.width, mipmap.height, 0, glFormat, glType, mipmap.data );\n\n\t\t\t\t}\n\n\t\t\t\ttexture.generateMipmaps = false;\n\t\t\t\ttextureProperties.__maxMipLevel = mipmaps.length - 1;\n\n\t\t\t} else {\n\n\t\t\t\tstate.texImage2D( _gl.TEXTURE_2D, 0, glFormat, image.width, image.height, 0, glFormat, glType, image.data );\n\t\t\t\ttextureProperties.__maxMipLevel = 0;\n\n\t\t\t}\n\n\t\t} else if ( texture.isCompressedTexture ) {\n\n\t\t\tfor ( var i = 0, il = mipmaps.length; i < il; i ++ ) {\n\n\t\t\t\tmipmap = mipmaps[ i ];\n\n\t\t\t\tif ( texture.format !== RGBAFormat && texture.format !== RGBFormat ) {\n\n\t\t\t\t\tif ( state.getCompressedTextureFormats().indexOf( glFormat ) > - 1 ) {\n\n\t\t\t\t\t\tstate.compressedTexImage2D( _gl.TEXTURE_2D, i, glFormat, mipmap.width, mipmap.height, 0, mipmap.data );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()' );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tstate.texImage2D( _gl.TEXTURE_2D, i, glFormat, mipmap.width, mipmap.height, 0, glFormat, glType, mipmap.data );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\ttextureProperties.__maxMipLevel = mipmaps.length - 1;\n\n\t\t} else {\n\n\t\t\t// regular Texture (image, video, canvas)\n\n\t\t\t// use manually created mipmaps if available\n\t\t\t// if there are no manual mipmaps\n\t\t\t// set 0 level mipmap and then use GL to generate other mipmap levels\n\n\t\t\tif ( mipmaps.length > 0 && isPowerOfTwoImage ) {\n\n\t\t\t\tfor ( var i = 0, il = mipmaps.length; i < il; i ++ ) {\n\n\t\t\t\t\tmipmap = mipmaps[ i ];\n\t\t\t\t\tstate.texImage2D( _gl.TEXTURE_2D, i, glFormat, glFormat, glType, mipmap );\n\n\t\t\t\t}\n\n\t\t\t\ttexture.generateMipmaps = false;\n\t\t\t\ttextureProperties.__maxMipLevel = mipmaps.length - 1;\n\n\t\t\t} else {\n\n\t\t\t\tstate.texImage2D( _gl.TEXTURE_2D, 0, glFormat, glFormat, glType, image );\n\t\t\t\ttextureProperties.__maxMipLevel = 0;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( textureNeedsGenerateMipmaps( texture, isPowerOfTwoImage ) ) {\n\n\t\t\tgenerateMipmap( _gl.TEXTURE_2D, texture, image.width, image.height );\n\n\t\t}\n\n\t\ttextureProperties.__version = texture.version;\n\n\t\tif ( texture.onUpdate ) texture.onUpdate( texture );\n\n\t}\n\n\t// Render targets\n\n\t// Setup storage for target texture and bind it to correct framebuffer\n\tfunction setupFrameBufferTexture( framebuffer, renderTarget, attachment, textureTarget ) {\n\n\t\tvar glFormat = utils.convert( renderTarget.texture.format );\n\t\tvar glType = utils.convert( renderTarget.texture.type );\n\t\tstate.texImage2D( textureTarget, 0, glFormat, renderTarget.width, renderTarget.height, 0, glFormat, glType, null );\n\t\t_gl.bindFramebuffer( _gl.FRAMEBUFFER, framebuffer );\n\t\t_gl.framebufferTexture2D( _gl.FRAMEBUFFER, attachment, textureTarget, properties.get( renderTarget.texture ).__webglTexture, 0 );\n\t\t_gl.bindFramebuffer( _gl.FRAMEBUFFER, null );\n\n\t}\n\n\t// Setup storage for internal depth/stencil buffers and bind to correct framebuffer\n\tfunction setupRenderBufferStorage( renderbuffer, renderTarget ) {\n\n\t\t_gl.bindRenderbuffer( _gl.RENDERBUFFER, renderbuffer );\n\n\t\tif ( renderTarget.depthBuffer && ! renderTarget.stencilBuffer ) {\n\n\t\t\t_gl.renderbufferStorage( _gl.RENDERBUFFER, _gl.DEPTH_COMPONENT16, renderTarget.width, renderTarget.height );\n\t\t\t_gl.framebufferRenderbuffer( _gl.FRAMEBUFFER, _gl.DEPTH_ATTACHMENT, _gl.RENDERBUFFER, renderbuffer );\n\n\t\t} else if ( renderTarget.depthBuffer && renderTarget.stencilBuffer ) {\n\n\t\t\t_gl.renderbufferStorage( _gl.RENDERBUFFER, _gl.DEPTH_STENCIL, renderTarget.width, renderTarget.height );\n\t\t\t_gl.framebufferRenderbuffer( _gl.FRAMEBUFFER, _gl.DEPTH_STENCIL_ATTACHMENT, _gl.RENDERBUFFER, renderbuffer );\n\n\t\t} else {\n\n\t\t\t// FIXME: We don't support !depth !stencil\n\t\t\t_gl.renderbufferStorage( _gl.RENDERBUFFER, _gl.RGBA4, renderTarget.width, renderTarget.height );\n\n\t\t}\n\n\t\t_gl.bindRenderbuffer( _gl.RENDERBUFFER, null );\n\n\t}\n\n\t// Setup resources for a Depth Texture for a FBO (needs an extension)\n\tfunction setupDepthTexture( framebuffer, renderTarget ) {\n\n\t\tvar isCube = ( renderTarget && renderTarget.isWebGLRenderTargetCube );\n\t\tif ( isCube ) throw new Error( 'Depth Texture with cube render targets is not supported' );\n\n\t\t_gl.bindFramebuffer( _gl.FRAMEBUFFER, framebuffer );\n\n\t\tif ( ! ( renderTarget.depthTexture && renderTarget.depthTexture.isDepthTexture ) ) {\n\n\t\t\tthrow new Error( 'renderTarget.depthTexture must be an instance of THREE.DepthTexture' );\n\n\t\t}\n\n\t\t// upload an empty depth texture with framebuffer size\n\t\tif ( ! properties.get( renderTarget.depthTexture ).__webglTexture ||\n\t\t\t\trenderTarget.depthTexture.image.width !== renderTarget.width ||\n\t\t\t\trenderTarget.depthTexture.image.height !== renderTarget.height ) {\n\n\t\t\trenderTarget.depthTexture.image.width = renderTarget.width;\n\t\t\trenderTarget.depthTexture.image.height = renderTarget.height;\n\t\t\trenderTarget.depthTexture.needsUpdate = true;\n\n\t\t}\n\n\t\tsetTexture2D( renderTarget.depthTexture, 0 );\n\n\t\tvar webglDepthTexture = properties.get( renderTarget.depthTexture ).__webglTexture;\n\n\t\tif ( renderTarget.depthTexture.format === DepthFormat ) {\n\n\t\t\t_gl.framebufferTexture2D( _gl.FRAMEBUFFER, _gl.DEPTH_ATTACHMENT, _gl.TEXTURE_2D, webglDepthTexture, 0 );\n\n\t\t} else if ( renderTarget.depthTexture.format === DepthStencilFormat ) {\n\n\t\t\t_gl.framebufferTexture2D( _gl.FRAMEBUFFER, _gl.DEPTH_STENCIL_ATTACHMENT, _gl.TEXTURE_2D, webglDepthTexture, 0 );\n\n\t\t} else {\n\n\t\t\tthrow new Error( 'Unknown depthTexture format' );\n\n\t\t}\n\n\t}\n\n\t// Setup GL resources for a non-texture depth buffer\n\tfunction setupDepthRenderbuffer( renderTarget ) {\n\n\t\tvar renderTargetProperties = properties.get( renderTarget );\n\n\t\tvar isCube = ( renderTarget.isWebGLRenderTargetCube === true );\n\n\t\tif ( renderTarget.depthTexture ) {\n\n\t\t\tif ( isCube ) throw new Error( 'target.depthTexture not supported in Cube render targets' );\n\n\t\t\tsetupDepthTexture( renderTargetProperties.__webglFramebuffer, renderTarget );\n\n\t\t} else {\n\n\t\t\tif ( isCube ) {\n\n\t\t\t\trenderTargetProperties.__webglDepthbuffer = [];\n\n\t\t\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\t\t\t_gl.bindFramebuffer( _gl.FRAMEBUFFER, renderTargetProperties.__webglFramebuffer[ i ] );\n\t\t\t\t\trenderTargetProperties.__webglDepthbuffer[ i ] = _gl.createRenderbuffer();\n\t\t\t\t\tsetupRenderBufferStorage( renderTargetProperties.__webglDepthbuffer[ i ], renderTarget );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t_gl.bindFramebuffer( _gl.FRAMEBUFFER, renderTargetProperties.__webglFramebuffer );\n\t\t\t\trenderTargetProperties.__webglDepthbuffer = _gl.createRenderbuffer();\n\t\t\t\tsetupRenderBufferStorage( renderTargetProperties.__webglDepthbuffer, renderTarget );\n\n\t\t\t}\n\n\t\t}\n\n\t\t_gl.bindFramebuffer( _gl.FRAMEBUFFER, null );\n\n\t}\n\n\t// Set up GL resources for the render target\n\tfunction setupRenderTarget( renderTarget ) {\n\n\t\tvar renderTargetProperties = properties.get( renderTarget );\n\t\tvar textureProperties = properties.get( renderTarget.texture );\n\n\t\trenderTarget.addEventListener( 'dispose', onRenderTargetDispose );\n\n\t\ttextureProperties.__webglTexture = _gl.createTexture();\n\n\t\tinfo.memory.textures ++;\n\n\t\tvar isCube = ( renderTarget.isWebGLRenderTargetCube === true );\n\t\tvar isTargetPowerOfTwo = isPowerOfTwo( renderTarget );\n\n\t\t// Setup framebuffer\n\n\t\tif ( isCube ) {\n\n\t\t\trenderTargetProperties.__webglFramebuffer = [];\n\n\t\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\t\trenderTargetProperties.__webglFramebuffer[ i ] = _gl.createFramebuffer();\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\trenderTargetProperties.__webglFramebuffer = _gl.createFramebuffer();\n\n\t\t}\n\n\t\t// Setup color buffer\n\n\t\tif ( isCube ) {\n\n\t\t\tstate.bindTexture( _gl.TEXTURE_CUBE_MAP, textureProperties.__webglTexture );\n\t\t\tsetTextureParameters( _gl.TEXTURE_CUBE_MAP, renderTarget.texture, isTargetPowerOfTwo );\n\n\t\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\t\tsetupFrameBufferTexture( renderTargetProperties.__webglFramebuffer[ i ], renderTarget, _gl.COLOR_ATTACHMENT0, _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i );\n\n\t\t\t}\n\n\t\t\tif ( textureNeedsGenerateMipmaps( renderTarget.texture, isTargetPowerOfTwo ) ) {\n\n\t\t\t\tgenerateMipmap( _gl.TEXTURE_CUBE_MAP, renderTarget.texture, renderTarget.width, renderTarget.height );\n\n\t\t\t}\n\n\t\t\tstate.bindTexture( _gl.TEXTURE_CUBE_MAP, null );\n\n\t\t} else {\n\n\t\t\tstate.bindTexture( _gl.TEXTURE_2D, textureProperties.__webglTexture );\n\t\t\tsetTextureParameters( _gl.TEXTURE_2D, renderTarget.texture, isTargetPowerOfTwo );\n\t\t\tsetupFrameBufferTexture( renderTargetProperties.__webglFramebuffer, renderTarget, _gl.COLOR_ATTACHMENT0, _gl.TEXTURE_2D );\n\n\t\t\tif ( textureNeedsGenerateMipmaps( renderTarget.texture, isTargetPowerOfTwo ) ) {\n\n\t\t\t\tgenerateMipmap( _gl.TEXTURE_2D, renderTarget.texture, renderTarget.width, renderTarget.height );\n\n\t\t\t}\n\n\t\t\tstate.bindTexture( _gl.TEXTURE_2D, null );\n\n\t\t}\n\n\t\t// Setup depth and stencil buffers\n\n\t\tif ( renderTarget.depthBuffer ) {\n\n\t\t\tsetupDepthRenderbuffer( renderTarget );\n\n\t\t}\n\n\t}\n\n\tfunction updateRenderTargetMipmap( renderTarget ) {\n\n\t\tvar texture = renderTarget.texture;\n\t\tvar isTargetPowerOfTwo = isPowerOfTwo( renderTarget );\n\n\t\tif ( textureNeedsGenerateMipmaps( texture, isTargetPowerOfTwo ) ) {\n\n\t\t\tvar target = renderTarget.isWebGLRenderTargetCube ? _gl.TEXTURE_CUBE_MAP : _gl.TEXTURE_2D;\n\t\t\tvar webglTexture = properties.get( texture ).__webglTexture;\n\n\t\t\tstate.bindTexture( target, webglTexture );\n\t\t\tgenerateMipmap( target, texture, renderTarget.width, renderTarget.height );\n\t\t\tstate.bindTexture( target, null );\n\n\t\t}\n\n\t}\n\n\tfunction updateVideoTexture( texture ) {\n\n\t\tvar id = texture.id;\n\t\tvar frame = info.render.frame;\n\n\t\t// Check the last frame we updated the VideoTexture\n\n\t\tif ( _videoTextures[ id ] !== frame ) {\n\n\t\t\t_videoTextures[ id ] = frame;\n\t\t\ttexture.update();\n\n\t\t}\n\n\t}\n\n\tthis.setTexture2D = setTexture2D;\n\tthis.setTextureCube = setTextureCube;\n\tthis.setTextureCubeDynamic = setTextureCubeDynamic;\n\tthis.setupRenderTarget = setupRenderTarget;\n\tthis.updateRenderTargetMipmap = updateRenderTargetMipmap;\n\n}\n\n/**\n * @author thespite / http://www.twitter.com/thespite\n */\n\nfunction WebGLUtils( gl, extensions ) {\n\n\tfunction convert( p ) {\n\n\t\tvar extension;\n\n\t\tif ( p === RepeatWrapping ) return gl.REPEAT;\n\t\tif ( p === ClampToEdgeWrapping ) return gl.CLAMP_TO_EDGE;\n\t\tif ( p === MirroredRepeatWrapping ) return gl.MIRRORED_REPEAT;\n\n\t\tif ( p === NearestFilter ) return gl.NEAREST;\n\t\tif ( p === NearestMipMapNearestFilter ) return gl.NEAREST_MIPMAP_NEAREST;\n\t\tif ( p === NearestMipMapLinearFilter ) return gl.NEAREST_MIPMAP_LINEAR;\n\n\t\tif ( p === LinearFilter ) return gl.LINEAR;\n\t\tif ( p === LinearMipMapNearestFilter ) return gl.LINEAR_MIPMAP_NEAREST;\n\t\tif ( p === LinearMipMapLinearFilter ) return gl.LINEAR_MIPMAP_LINEAR;\n\n\t\tif ( p === UnsignedByteType ) return gl.UNSIGNED_BYTE;\n\t\tif ( p === UnsignedShort4444Type ) return gl.UNSIGNED_SHORT_4_4_4_4;\n\t\tif ( p === UnsignedShort5551Type ) return gl.UNSIGNED_SHORT_5_5_5_1;\n\t\tif ( p === UnsignedShort565Type ) return gl.UNSIGNED_SHORT_5_6_5;\n\n\t\tif ( p === ByteType ) return gl.BYTE;\n\t\tif ( p === ShortType ) return gl.SHORT;\n\t\tif ( p === UnsignedShortType ) return gl.UNSIGNED_SHORT;\n\t\tif ( p === IntType ) return gl.INT;\n\t\tif ( p === UnsignedIntType ) return gl.UNSIGNED_INT;\n\t\tif ( p === FloatType ) return gl.FLOAT;\n\n\t\tif ( p === HalfFloatType ) {\n\n\t\t\textension = extensions.get( 'OES_texture_half_float' );\n\n\t\t\tif ( extension !== null ) return extension.HALF_FLOAT_OES;\n\n\t\t}\n\n\t\tif ( p === AlphaFormat ) return gl.ALPHA;\n\t\tif ( p === RGBFormat ) return gl.RGB;\n\t\tif ( p === RGBAFormat ) return gl.RGBA;\n\t\tif ( p === LuminanceFormat ) return gl.LUMINANCE;\n\t\tif ( p === LuminanceAlphaFormat ) return gl.LUMINANCE_ALPHA;\n\t\tif ( p === DepthFormat ) return gl.DEPTH_COMPONENT;\n\t\tif ( p === DepthStencilFormat ) return gl.DEPTH_STENCIL;\n\n\t\tif ( p === AddEquation ) return gl.FUNC_ADD;\n\t\tif ( p === SubtractEquation ) return gl.FUNC_SUBTRACT;\n\t\tif ( p === ReverseSubtractEquation ) return gl.FUNC_REVERSE_SUBTRACT;\n\n\t\tif ( p === ZeroFactor ) return gl.ZERO;\n\t\tif ( p === OneFactor ) return gl.ONE;\n\t\tif ( p === SrcColorFactor ) return gl.SRC_COLOR;\n\t\tif ( p === OneMinusSrcColorFactor ) return gl.ONE_MINUS_SRC_COLOR;\n\t\tif ( p === SrcAlphaFactor ) return gl.SRC_ALPHA;\n\t\tif ( p === OneMinusSrcAlphaFactor ) return gl.ONE_MINUS_SRC_ALPHA;\n\t\tif ( p === DstAlphaFactor ) return gl.DST_ALPHA;\n\t\tif ( p === OneMinusDstAlphaFactor ) return gl.ONE_MINUS_DST_ALPHA;\n\n\t\tif ( p === DstColorFactor ) return gl.DST_COLOR;\n\t\tif ( p === OneMinusDstColorFactor ) return gl.ONE_MINUS_DST_COLOR;\n\t\tif ( p === SrcAlphaSaturateFactor ) return gl.SRC_ALPHA_SATURATE;\n\n\t\tif ( p === RGB_S3TC_DXT1_Format || p === RGBA_S3TC_DXT1_Format ||\n\t\t\tp === RGBA_S3TC_DXT3_Format || p === RGBA_S3TC_DXT5_Format ) {\n\n\t\t\textension = extensions.get( 'WEBGL_compressed_texture_s3tc' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\tif ( p === RGB_S3TC_DXT1_Format ) return extension.COMPRESSED_RGB_S3TC_DXT1_EXT;\n\t\t\t\tif ( p === RGBA_S3TC_DXT1_Format ) return extension.COMPRESSED_RGBA_S3TC_DXT1_EXT;\n\t\t\t\tif ( p === RGBA_S3TC_DXT3_Format ) return extension.COMPRESSED_RGBA_S3TC_DXT3_EXT;\n\t\t\t\tif ( p === RGBA_S3TC_DXT5_Format ) return extension.COMPRESSED_RGBA_S3TC_DXT5_EXT;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( p === RGB_PVRTC_4BPPV1_Format || p === RGB_PVRTC_2BPPV1_Format ||\n\t\t\tp === RGBA_PVRTC_4BPPV1_Format || p === RGBA_PVRTC_2BPPV1_Format ) {\n\n\t\t\textension = extensions.get( 'WEBGL_compressed_texture_pvrtc' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\tif ( p === RGB_PVRTC_4BPPV1_Format ) return extension.COMPRESSED_RGB_PVRTC_4BPPV1_IMG;\n\t\t\t\tif ( p === RGB_PVRTC_2BPPV1_Format ) return extension.COMPRESSED_RGB_PVRTC_2BPPV1_IMG;\n\t\t\t\tif ( p === RGBA_PVRTC_4BPPV1_Format ) return extension.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG;\n\t\t\t\tif ( p === RGBA_PVRTC_2BPPV1_Format ) return extension.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( p === RGB_ETC1_Format ) {\n\n\t\t\textension = extensions.get( 'WEBGL_compressed_texture_etc1' );\n\n\t\t\tif ( extension !== null ) return extension.COMPRESSED_RGB_ETC1_WEBGL;\n\n\t\t}\n\n\t\tif ( p === RGBA_ASTC_4x4_Format || p === RGBA_ASTC_5x4_Format || p === RGBA_ASTC_5x5_Format ||\n\t\t\tp === RGBA_ASTC_6x5_Format || p === RGBA_ASTC_6x6_Format || p === RGBA_ASTC_8x5_Format ||\n\t\t\tp === RGBA_ASTC_8x6_Format || p === RGBA_ASTC_8x8_Format || p === RGBA_ASTC_10x5_Format ||\n\t\t\tp === RGBA_ASTC_10x6_Format || p === RGBA_ASTC_10x8_Format || p === RGBA_ASTC_10x10_Format ||\n\t\t\tp === RGBA_ASTC_12x10_Format || p === RGBA_ASTC_12x12_Format ) {\n\n\t\t\textension = extensions.get( 'WEBGL_compressed_texture_astc' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\treturn p;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( p === MinEquation || p === MaxEquation ) {\n\n\t\t\textension = extensions.get( 'EXT_blend_minmax' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\tif ( p === MinEquation ) return extension.MIN_EXT;\n\t\t\t\tif ( p === MaxEquation ) return extension.MAX_EXT;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( p === UnsignedInt248Type ) {\n\n\t\t\textension = extensions.get( 'WEBGL_depth_texture' );\n\n\t\t\tif ( extension !== null ) return extension.UNSIGNED_INT_24_8_WEBGL;\n\n\t\t}\n\n\t\treturn 0;\n\n\t}\n\n\treturn { convert: convert };\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author greggman / http://games.greggman.com/\n * @author zz85 / http://www.lab4games.net/zz85/blog\n * @author tschw\n */\n\nfunction PerspectiveCamera( fov, aspect, near, far ) {\n\n\tCamera.call( this );\n\n\tthis.type = 'PerspectiveCamera';\n\n\tthis.fov = fov !== undefined ? fov : 50;\n\tthis.zoom = 1;\n\n\tthis.near = near !== undefined ? near : 0.1;\n\tthis.far = far !== undefined ? far : 2000;\n\tthis.focus = 10;\n\n\tthis.aspect = aspect !== undefined ? aspect : 1;\n\tthis.view = null;\n\n\tthis.filmGauge = 35;\t// width of the film (default in millimeters)\n\tthis.filmOffset = 0;\t// horizontal film offset (same unit as gauge)\n\n\tthis.updateProjectionMatrix();\n\n}\n\nPerspectiveCamera.prototype = Object.assign( Object.create( Camera.prototype ), {\n\n\tconstructor: PerspectiveCamera,\n\n\tisPerspectiveCamera: true,\n\n\tcopy: function ( source, recursive ) {\n\n\t\tCamera.prototype.copy.call( this, source, recursive );\n\n\t\tthis.fov = source.fov;\n\t\tthis.zoom = source.zoom;\n\n\t\tthis.near = source.near;\n\t\tthis.far = source.far;\n\t\tthis.focus = source.focus;\n\n\t\tthis.aspect = source.aspect;\n\t\tthis.view = source.view === null ? null : Object.assign( {}, source.view );\n\n\t\tthis.filmGauge = source.filmGauge;\n\t\tthis.filmOffset = source.filmOffset;\n\n\t\treturn this;\n\n\t},\n\n\t/**\n\t * Sets the FOV by focal length in respect to the current .filmGauge.\n\t *\n\t * The default film gauge is 35, so that the focal length can be specified for\n\t * a 35mm (full frame) camera.\n\t *\n\t * Values for focal length and film gauge must have the same unit.\n\t */\n\tsetFocalLength: function ( focalLength ) {\n\n\t\t// see http://www.bobatkins.com/photography/technical/field_of_view.html\n\t\tvar vExtentSlope = 0.5 * this.getFilmHeight() / focalLength;\n\n\t\tthis.fov = _Math.RAD2DEG * 2 * Math.atan( vExtentSlope );\n\t\tthis.updateProjectionMatrix();\n\n\t},\n\n\t/**\n\t * Calculates the focal length from the current .fov and .filmGauge.\n\t */\n\tgetFocalLength: function () {\n\n\t\tvar vExtentSlope = Math.tan( _Math.DEG2RAD * 0.5 * this.fov );\n\n\t\treturn 0.5 * this.getFilmHeight() / vExtentSlope;\n\n\t},\n\n\tgetEffectiveFOV: function () {\n\n\t\treturn _Math.RAD2DEG * 2 * Math.atan(\n\t\t\tMath.tan( _Math.DEG2RAD * 0.5 * this.fov ) / this.zoom );\n\n\t},\n\n\tgetFilmWidth: function () {\n\n\t\t// film not completely covered in portrait format (aspect < 1)\n\t\treturn this.filmGauge * Math.min( this.aspect, 1 );\n\n\t},\n\n\tgetFilmHeight: function () {\n\n\t\t// film not completely covered in landscape format (aspect > 1)\n\t\treturn this.filmGauge / Math.max( this.aspect, 1 );\n\n\t},\n\n\t/**\n\t * Sets an offset in a larger frustum. This is useful for multi-window or\n\t * multi-monitor/multi-machine setups.\n\t *\n\t * For example, if you have 3x2 monitors and each monitor is 1920x1080 and\n\t * the monitors are in grid like this\n\t *\n\t *   +---+---+---+\n\t *   | A | B | C |\n\t *   +---+---+---+\n\t *   | D | E | F |\n\t *   +---+---+---+\n\t *\n\t * then for each monitor you would call it like this\n\t *\n\t *   var w = 1920;\n\t *   var h = 1080;\n\t *   var fullWidth = w * 3;\n\t *   var fullHeight = h * 2;\n\t *\n\t *   --A--\n\t *   camera.setOffset( fullWidth, fullHeight, w * 0, h * 0, w, h );\n\t *   --B--\n\t *   camera.setOffset( fullWidth, fullHeight, w * 1, h * 0, w, h );\n\t *   --C--\n\t *   camera.setOffset( fullWidth, fullHeight, w * 2, h * 0, w, h );\n\t *   --D--\n\t *   camera.setOffset( fullWidth, fullHeight, w * 0, h * 1, w, h );\n\t *   --E--\n\t *   camera.setOffset( fullWidth, fullHeight, w * 1, h * 1, w, h );\n\t *   --F--\n\t *   camera.setOffset( fullWidth, fullHeight, w * 2, h * 1, w, h );\n\t *\n\t *   Note there is no reason monitors have to be the same size or in a grid.\n\t */\n\tsetViewOffset: function ( fullWidth, fullHeight, x, y, width, height ) {\n\n\t\tthis.aspect = fullWidth / fullHeight;\n\n\t\tif ( this.view === null ) {\n\n\t\t\tthis.view = {\n\t\t\t\tenabled: true,\n\t\t\t\tfullWidth: 1,\n\t\t\t\tfullHeight: 1,\n\t\t\t\toffsetX: 0,\n\t\t\t\toffsetY: 0,\n\t\t\t\twidth: 1,\n\t\t\t\theight: 1\n\t\t\t};\n\n\t\t}\n\n\t\tthis.view.enabled = true;\n\t\tthis.view.fullWidth = fullWidth;\n\t\tthis.view.fullHeight = fullHeight;\n\t\tthis.view.offsetX = x;\n\t\tthis.view.offsetY = y;\n\t\tthis.view.width = width;\n\t\tthis.view.height = height;\n\n\t\tthis.updateProjectionMatrix();\n\n\t},\n\n\tclearViewOffset: function () {\n\n\t\tif ( this.view !== null ) {\n\n\t\t\tthis.view.enabled = false;\n\n\t\t}\n\n\t\tthis.updateProjectionMatrix();\n\n\t},\n\n\tupdateProjectionMatrix: function () {\n\n\t\tvar near = this.near,\n\t\t\ttop = near * Math.tan(\n\t\t\t\t_Math.DEG2RAD * 0.5 * this.fov ) / this.zoom,\n\t\t\theight = 2 * top,\n\t\t\twidth = this.aspect * height,\n\t\t\tleft = - 0.5 * width,\n\t\t\tview = this.view;\n\n\t\tif ( this.view !== null && this.view.enabled ) {\n\n\t\t\tvar fullWidth = view.fullWidth,\n\t\t\t\tfullHeight = view.fullHeight;\n\n\t\t\tleft += view.offsetX * width / fullWidth;\n\t\t\ttop -= view.offsetY * height / fullHeight;\n\t\t\twidth *= view.width / fullWidth;\n\t\t\theight *= view.height / fullHeight;\n\n\t\t}\n\n\t\tvar skew = this.filmOffset;\n\t\tif ( skew !== 0 ) left += near * skew / this.getFilmWidth();\n\n\t\tthis.projectionMatrix.makePerspective( left, left + width, top, top - height, near, this.far );\n\n\t},\n\n\ttoJSON: function ( meta ) {\n\n\t\tvar data = Object3D.prototype.toJSON.call( this, meta );\n\n\t\tdata.object.fov = this.fov;\n\t\tdata.object.zoom = this.zoom;\n\n\t\tdata.object.near = this.near;\n\t\tdata.object.far = this.far;\n\t\tdata.object.focus = this.focus;\n\n\t\tdata.object.aspect = this.aspect;\n\n\t\tif ( this.view !== null ) data.object.view = Object.assign( {}, this.view );\n\n\t\tdata.object.filmGauge = this.filmGauge;\n\t\tdata.object.filmOffset = this.filmOffset;\n\n\t\treturn data;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction ArrayCamera( array ) {\n\n\tPerspectiveCamera.call( this );\n\n\tthis.cameras = array || [];\n\n}\n\nArrayCamera.prototype = Object.assign( Object.create( PerspectiveCamera.prototype ), {\n\n\tconstructor: ArrayCamera,\n\n\tisArrayCamera: true\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction WebVRManager( renderer ) {\n\n\tvar scope = this;\n\n\tvar device = null;\n\tvar frameData = null;\n\n\tvar poseTarget = null;\n\n\tvar standingMatrix = new Matrix4();\n\tvar standingMatrixInverse = new Matrix4();\n\n\tif ( typeof window !== 'undefined' && 'VRFrameData' in window ) {\n\n\t\tframeData = new window.VRFrameData();\n\t\twindow.addEventListener( 'vrdisplaypresentchange', onVRDisplayPresentChange, false );\n\n\t}\n\n\tvar matrixWorldInverse = new Matrix4();\n\tvar tempQuaternion = new Quaternion();\n\tvar tempPosition = new Vector3();\n\n\tvar cameraL = new PerspectiveCamera();\n\tcameraL.bounds = new Vector4( 0.0, 0.0, 0.5, 1.0 );\n\tcameraL.layers.enable( 1 );\n\n\tvar cameraR = new PerspectiveCamera();\n\tcameraR.bounds = new Vector4( 0.5, 0.0, 0.5, 1.0 );\n\tcameraR.layers.enable( 2 );\n\n\tvar cameraVR = new ArrayCamera( [ cameraL, cameraR ] );\n\tcameraVR.layers.enable( 1 );\n\tcameraVR.layers.enable( 2 );\n\n\t//\n\n\tfunction isPresenting() {\n\n\t\treturn device !== null && device.isPresenting === true;\n\n\t}\n\n\tvar currentSize, currentPixelRatio;\n\n\tfunction onVRDisplayPresentChange() {\n\n\t\tif ( isPresenting() ) {\n\n\t\t\tvar eyeParameters = device.getEyeParameters( 'left' );\n\t\t\tvar renderWidth = eyeParameters.renderWidth;\n\t\t\tvar renderHeight = eyeParameters.renderHeight;\n\n\t\t\tcurrentPixelRatio = renderer.getPixelRatio();\n\t\t\tcurrentSize = renderer.getSize();\n\n\t\t\trenderer.setDrawingBufferSize( renderWidth * 2, renderHeight, 1 );\n\n\t\t} else if ( scope.enabled ) {\n\n\t\t\trenderer.setDrawingBufferSize( currentSize.width, currentSize.height, currentPixelRatio );\n\n\t\t}\n\n\t}\n\n\t//\n\n\tthis.enabled = false;\n\tthis.userHeight = 1.6;\n\n\tthis.getDevice = function () {\n\n\t\treturn device;\n\n\t};\n\n\tthis.setDevice = function ( value ) {\n\n\t\tif ( value !== undefined ) device = value;\n\n\t};\n\n\tthis.setPoseTarget = function ( object ) {\n\n\t\tif ( object !== undefined ) poseTarget = object;\n\n\t};\n\n\tthis.getCamera = function ( camera ) {\n\n\t\tif ( device === null ) return camera;\n\n\t\tdevice.depthNear = camera.near;\n\t\tdevice.depthFar = camera.far;\n\n\t\tdevice.getFrameData( frameData );\n\n\t\t//\n\n\t\tvar stageParameters = device.stageParameters;\n\n\t\tif ( stageParameters ) {\n\n\t\t\tstandingMatrix.fromArray( stageParameters.sittingToStandingTransform );\n\n\t\t} else {\n\n\t\t\tstandingMatrix.makeTranslation( 0, scope.userHeight, 0 );\n\n\t\t}\n\n\n\t\tvar pose = frameData.pose;\n\t\tvar poseObject = poseTarget !== null ? poseTarget : camera;\n\n\t\t// We want to manipulate poseObject by its position and quaternion components since users may rely on them.\n\t\tposeObject.matrix.copy( standingMatrix );\n\t\tposeObject.matrix.decompose( poseObject.position, poseObject.quaternion, poseObject.scale );\n\n\t\tif ( pose.orientation !== null ) {\n\n\t\t\ttempQuaternion.fromArray( pose.orientation );\n\t\t\tposeObject.quaternion.multiply( tempQuaternion );\n\n\t\t}\n\n\t\tif ( pose.position !== null ) {\n\n\t\t\ttempQuaternion.setFromRotationMatrix( standingMatrix );\n\t\t\ttempPosition.fromArray( pose.position );\n\t\t\ttempPosition.applyQuaternion( tempQuaternion );\n\t\t\tposeObject.position.add( tempPosition );\n\n\t\t}\n\n\t\tposeObject.updateMatrixWorld();\n\n\t\tif ( device.isPresenting === false ) return camera;\n\n\t\t//\n\n\t\tcameraL.near = camera.near;\n\t\tcameraR.near = camera.near;\n\n\t\tcameraL.far = camera.far;\n\t\tcameraR.far = camera.far;\n\n\t\tcameraVR.matrixWorld.copy( camera.matrixWorld );\n\t\tcameraVR.matrixWorldInverse.copy( camera.matrixWorldInverse );\n\n\t\tcameraL.matrixWorldInverse.fromArray( frameData.leftViewMatrix );\n\t\tcameraR.matrixWorldInverse.fromArray( frameData.rightViewMatrix );\n\n\t\t// TODO (mrdoob) Double check this code\n\n\t\tstandingMatrixInverse.getInverse( standingMatrix );\n\n\t\tcameraL.matrixWorldInverse.multiply( standingMatrixInverse );\n\t\tcameraR.matrixWorldInverse.multiply( standingMatrixInverse );\n\n\t\tvar parent = poseObject.parent;\n\n\t\tif ( parent !== null ) {\n\n\t\t\tmatrixWorldInverse.getInverse( parent.matrixWorld );\n\n\t\t\tcameraL.matrixWorldInverse.multiply( matrixWorldInverse );\n\t\t\tcameraR.matrixWorldInverse.multiply( matrixWorldInverse );\n\n\t\t}\n\n\t\t// envMap and Mirror needs camera.matrixWorld\n\n\t\tcameraL.matrixWorld.getInverse( cameraL.matrixWorldInverse );\n\t\tcameraR.matrixWorld.getInverse( cameraR.matrixWorldInverse );\n\n\t\tcameraL.projectionMatrix.fromArray( frameData.leftProjectionMatrix );\n\t\tcameraR.projectionMatrix.fromArray( frameData.rightProjectionMatrix );\n\n\t\t// HACK (mrdoob)\n\t\t// https://github.com/w3c/webvr/issues/203\n\n\t\tcameraVR.projectionMatrix.copy( cameraL.projectionMatrix );\n\n\t\t//\n\n\t\tvar layers = device.getLayers();\n\n\t\tif ( layers.length ) {\n\n\t\t\tvar layer = layers[ 0 ];\n\n\t\t\tif ( layer.leftBounds !== null && layer.leftBounds.length === 4 ) {\n\n\t\t\t\tcameraL.bounds.fromArray( layer.leftBounds );\n\n\t\t\t}\n\n\t\t\tif ( layer.rightBounds !== null && layer.rightBounds.length === 4 ) {\n\n\t\t\t\tcameraR.bounds.fromArray( layer.rightBounds );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn cameraVR;\n\n\t};\n\n\tthis.getStandingMatrix = function () {\n\n\t\treturn standingMatrix;\n\n\t};\n\n\tthis.submitFrame = function () {\n\n\t\tif ( isPresenting() ) device.submitFrame();\n\n\t};\n\n\tthis.dispose = function () {\n\n\t\tif ( typeof window !== 'undefined' ) {\n\n\t\t\twindow.removeEventListener( 'vrdisplaypresentchange', onVRDisplayPresentChange );\n\n\t\t}\n\n\t};\n\n}\n\n/**\n * @author supereggbert / http://www.paulbrunt.co.uk/\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n * @author szimek / https://github.com/szimek/\n * @author tschw\n */\n\nfunction WebGLRenderer( parameters ) {\n\n\tconsole.log( 'THREE.WebGLRenderer', REVISION );\n\n\tparameters = parameters || {};\n\n\tvar _canvas = parameters.canvas !== undefined ? parameters.canvas : document.createElementNS( 'http://www.w3.org/1999/xhtml', 'canvas' ),\n\t\t_context = parameters.context !== undefined ? parameters.context : null,\n\n\t\t_alpha = parameters.alpha !== undefined ? parameters.alpha : false,\n\t\t_depth = parameters.depth !== undefined ? parameters.depth : true,\n\t\t_stencil = parameters.stencil !== undefined ? parameters.stencil : true,\n\t\t_antialias = parameters.antialias !== undefined ? parameters.antialias : false,\n\t\t_premultipliedAlpha = parameters.premultipliedAlpha !== undefined ? parameters.premultipliedAlpha : true,\n\t\t_preserveDrawingBuffer = parameters.preserveDrawingBuffer !== undefined ? parameters.preserveDrawingBuffer : false,\n\t\t_powerPreference = parameters.powerPreference !== undefined ? parameters.powerPreference : 'default';\n\n\tvar currentRenderList = null;\n\tvar currentRenderState = null;\n\n\t// public properties\n\n\tthis.domElement = _canvas;\n\tthis.context = null;\n\n\t// clearing\n\n\tthis.autoClear = true;\n\tthis.autoClearColor = true;\n\tthis.autoClearDepth = true;\n\tthis.autoClearStencil = true;\n\n\t// scene graph\n\n\tthis.sortObjects = true;\n\n\t// user-defined clipping\n\n\tthis.clippingPlanes = [];\n\tthis.localClippingEnabled = false;\n\n\t// physically based shading\n\n\tthis.gammaFactor = 2.0;\t// for backwards compatibility\n\tthis.gammaInput = false;\n\tthis.gammaOutput = false;\n\n\t// physical lights\n\n\tthis.physicallyCorrectLights = false;\n\n\t// tone mapping\n\n\tthis.toneMapping = LinearToneMapping;\n\tthis.toneMappingExposure = 1.0;\n\tthis.toneMappingWhitePoint = 1.0;\n\n\t// morphs\n\n\tthis.maxMorphTargets = 8;\n\tthis.maxMorphNormals = 4;\n\n\t// internal properties\n\n\tvar _this = this,\n\n\t\t_isContextLost = false,\n\n\t\t// internal state cache\n\n\t\t_currentRenderTarget = null,\n\t\t_currentFramebuffer = null,\n\t\t_currentMaterialId = - 1,\n\t\t_currentGeometryProgram = '',\n\n\t\t_currentCamera = null,\n\t\t_currentArrayCamera = null,\n\n\t\t_currentViewport = new Vector4(),\n\t\t_currentScissor = new Vector4(),\n\t\t_currentScissorTest = null,\n\n\t\t//\n\n\t\t_usedTextureUnits = 0,\n\n\t\t//\n\n\t\t_width = _canvas.width,\n\t\t_height = _canvas.height,\n\n\t\t_pixelRatio = 1,\n\n\t\t_viewport = new Vector4( 0, 0, _width, _height ),\n\t\t_scissor = new Vector4( 0, 0, _width, _height ),\n\t\t_scissorTest = false,\n\n\t\t// frustum\n\n\t\t_frustum = new Frustum(),\n\n\t\t// clipping\n\n\t\t_clipping = new WebGLClipping(),\n\t\t_clippingEnabled = false,\n\t\t_localClippingEnabled = false,\n\n\t\t// camera matrices cache\n\n\t\t_projScreenMatrix = new Matrix4(),\n\n\t\t_vector3 = new Vector3();\n\n\tfunction getTargetPixelRatio() {\n\n\t\treturn _currentRenderTarget === null ? _pixelRatio : 1;\n\n\t}\n\n\t// initialize\n\n\tvar _gl;\n\n\ttry {\n\n\t\tvar contextAttributes = {\n\t\t\talpha: _alpha,\n\t\t\tdepth: _depth,\n\t\t\tstencil: _stencil,\n\t\t\tantialias: _antialias,\n\t\t\tpremultipliedAlpha: _premultipliedAlpha,\n\t\t\tpreserveDrawingBuffer: _preserveDrawingBuffer,\n\t\t\tpowerPreference: _powerPreference\n\t\t};\n\n\t\t// event listeners must be registered before WebGL context is created, see #12753\n\n\t\t_canvas.addEventListener( 'webglcontextlost', onContextLost, false );\n\t\t_canvas.addEventListener( 'webglcontextrestored', onContextRestore, false );\n\n\t\t_gl = _context || _canvas.getContext( 'webgl', contextAttributes ) || _canvas.getContext( 'experimental-webgl', contextAttributes );\n\n\t\tif ( _gl === null ) {\n\n\t\t\tif ( _canvas.getContext( 'webgl' ) !== null ) {\n\n\t\t\t\tthrow new Error( 'Error creating WebGL context with your selected attributes.' );\n\n\t\t\t} else {\n\n\t\t\t\tthrow new Error( 'Error creating WebGL context.' );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Some experimental-webgl implementations do not have getShaderPrecisionFormat\n\n\t\tif ( _gl.getShaderPrecisionFormat === undefined ) {\n\n\t\t\t_gl.getShaderPrecisionFormat = function () {\n\n\t\t\t\treturn { 'rangeMin': 1, 'rangeMax': 1, 'precision': 1 };\n\n\t\t\t};\n\n\t\t}\n\n\t} catch ( error ) {\n\n\t\tconsole.error( 'THREE.WebGLRenderer: ' + error.message );\n\n\t}\n\n\tvar extensions, capabilities, state, info;\n\tvar properties, textures, attributes, geometries, objects;\n\tvar programCache, renderLists, renderStates;\n\n\tvar background, morphtargets, bufferRenderer, indexedBufferRenderer;\n\tvar spriteRenderer;\n\n\tvar utils;\n\n\tfunction initGLContext() {\n\n\t\textensions = new WebGLExtensions( _gl );\n\t\textensions.get( 'WEBGL_depth_texture' );\n\t\textensions.get( 'OES_texture_float' );\n\t\textensions.get( 'OES_texture_float_linear' );\n\t\textensions.get( 'OES_texture_half_float' );\n\t\textensions.get( 'OES_texture_half_float_linear' );\n\t\textensions.get( 'OES_standard_derivatives' );\n\t\textensions.get( 'OES_element_index_uint' );\n\t\textensions.get( 'ANGLE_instanced_arrays' );\n\n\t\tutils = new WebGLUtils( _gl, extensions );\n\n\t\tcapabilities = new WebGLCapabilities( _gl, extensions, parameters );\n\n\t\tstate = new WebGLState( _gl, extensions, utils );\n\t\tstate.scissor( _currentScissor.copy( _scissor ).multiplyScalar( _pixelRatio ) );\n\t\tstate.viewport( _currentViewport.copy( _viewport ).multiplyScalar( _pixelRatio ) );\n\n\t\tinfo = new WebGLInfo( _gl );\n\t\tproperties = new WebGLProperties();\n\t\ttextures = new WebGLTextures( _gl, extensions, state, properties, capabilities, utils, info );\n\t\tattributes = new WebGLAttributes( _gl );\n\t\tgeometries = new WebGLGeometries( _gl, attributes, info );\n\t\tobjects = new WebGLObjects( geometries, info );\n\t\tmorphtargets = new WebGLMorphtargets( _gl );\n\t\tprogramCache = new WebGLPrograms( _this, extensions, capabilities );\n\t\trenderLists = new WebGLRenderLists();\n\t\trenderStates = new WebGLRenderStates();\n\n\t\tbackground = new WebGLBackground( _this, state, geometries, _premultipliedAlpha );\n\n\t\tbufferRenderer = new WebGLBufferRenderer( _gl, extensions, info );\n\t\tindexedBufferRenderer = new WebGLIndexedBufferRenderer( _gl, extensions, info );\n\n\t\tspriteRenderer = new WebGLSpriteRenderer( _this, _gl, state, textures, capabilities );\n\n\t\tinfo.programs = programCache.programs;\n\n\t\t_this.context = _gl;\n\t\t_this.capabilities = capabilities;\n\t\t_this.extensions = extensions;\n\t\t_this.properties = properties;\n\t\t_this.renderLists = renderLists;\n\t\t_this.state = state;\n\t\t_this.info = info;\n\n\t}\n\n\tinitGLContext();\n\n\t// vr\n\n\tvar vr = new WebVRManager( _this );\n\n\tthis.vr = vr;\n\n\t// shadow map\n\n\tvar shadowMap = new WebGLShadowMap( _this, objects, capabilities.maxTextureSize );\n\n\tthis.shadowMap = shadowMap;\n\n\t// API\n\n\tthis.getContext = function () {\n\n\t\treturn _gl;\n\n\t};\n\n\tthis.getContextAttributes = function () {\n\n\t\treturn _gl.getContextAttributes();\n\n\t};\n\n\tthis.forceContextLoss = function () {\n\n\t\tvar extension = extensions.get( 'WEBGL_lose_context' );\n\t\tif ( extension ) extension.loseContext();\n\n\t};\n\n\tthis.forceContextRestore = function () {\n\n\t\tvar extension = extensions.get( 'WEBGL_lose_context' );\n\t\tif ( extension ) extension.restoreContext();\n\n\t};\n\n\tthis.getPixelRatio = function () {\n\n\t\treturn _pixelRatio;\n\n\t};\n\n\tthis.setPixelRatio = function ( value ) {\n\n\t\tif ( value === undefined ) return;\n\n\t\t_pixelRatio = value;\n\n\t\tthis.setSize( _width, _height, false );\n\n\t};\n\n\tthis.getSize = function () {\n\n\t\treturn {\n\t\t\twidth: _width,\n\t\t\theight: _height\n\t\t};\n\n\t};\n\n\tthis.setSize = function ( width, height, updateStyle ) {\n\n\t\tvar device = vr.getDevice();\n\n\t\tif ( device && device.isPresenting ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: Can\\'t change size while VR device is presenting.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\t_width = width;\n\t\t_height = height;\n\n\t\t_canvas.width = width * _pixelRatio;\n\t\t_canvas.height = height * _pixelRatio;\n\n\t\tif ( updateStyle !== false ) {\n\n\t\t\t_canvas.style.width = width + 'px';\n\t\t\t_canvas.style.height = height + 'px';\n\n\t\t}\n\n\t\tthis.setViewport( 0, 0, width, height );\n\n\t};\n\n\tthis.getDrawingBufferSize = function () {\n\n\t\treturn {\n\t\t\twidth: _width * _pixelRatio,\n\t\t\theight: _height * _pixelRatio\n\t\t};\n\n\t};\n\n\tthis.setDrawingBufferSize = function ( width, height, pixelRatio ) {\n\n\t\t_width = width;\n\t\t_height = height;\n\n\t\t_pixelRatio = pixelRatio;\n\n\t\t_canvas.width = width * pixelRatio;\n\t\t_canvas.height = height * pixelRatio;\n\n\t\tthis.setViewport( 0, 0, width, height );\n\n\t};\n\n\tthis.getCurrentViewport = function () {\n\n\t\treturn _currentViewport;\n\n\t};\n\n\tthis.setViewport = function ( x, y, width, height ) {\n\n\t\t_viewport.set( x, _height - y - height, width, height );\n\t\tstate.viewport( _currentViewport.copy( _viewport ).multiplyScalar( _pixelRatio ) );\n\n\t};\n\n\tthis.setScissor = function ( x, y, width, height ) {\n\n\t\t_scissor.set( x, _height - y - height, width, height );\n\t\tstate.scissor( _currentScissor.copy( _scissor ).multiplyScalar( _pixelRatio ) );\n\n\t};\n\n\tthis.setScissorTest = function ( boolean ) {\n\n\t\tstate.setScissorTest( _scissorTest = boolean );\n\n\t};\n\n\t// Clearing\n\n\tthis.getClearColor = function () {\n\n\t\treturn background.getClearColor();\n\n\t};\n\n\tthis.setClearColor = function () {\n\n\t\tbackground.setClearColor.apply( background, arguments );\n\n\t};\n\n\tthis.getClearAlpha = function () {\n\n\t\treturn background.getClearAlpha();\n\n\t};\n\n\tthis.setClearAlpha = function () {\n\n\t\tbackground.setClearAlpha.apply( background, arguments );\n\n\t};\n\n\tthis.clear = function ( color, depth, stencil ) {\n\n\t\tvar bits = 0;\n\n\t\tif ( color === undefined || color ) bits |= _gl.COLOR_BUFFER_BIT;\n\t\tif ( depth === undefined || depth ) bits |= _gl.DEPTH_BUFFER_BIT;\n\t\tif ( stencil === undefined || stencil ) bits |= _gl.STENCIL_BUFFER_BIT;\n\n\t\t_gl.clear( bits );\n\n\t};\n\n\tthis.clearColor = function () {\n\n\t\tthis.clear( true, false, false );\n\n\t};\n\n\tthis.clearDepth = function () {\n\n\t\tthis.clear( false, true, false );\n\n\t};\n\n\tthis.clearStencil = function () {\n\n\t\tthis.clear( false, false, true );\n\n\t};\n\n\tthis.clearTarget = function ( renderTarget, color, depth, stencil ) {\n\n\t\tthis.setRenderTarget( renderTarget );\n\t\tthis.clear( color, depth, stencil );\n\n\t};\n\n\t//\n\n\tthis.dispose = function () {\n\n\t\t_canvas.removeEventListener( 'webglcontextlost', onContextLost, false );\n\t\t_canvas.removeEventListener( 'webglcontextrestored', onContextRestore, false );\n\n\t\trenderLists.dispose();\n\t\trenderStates.dispose();\n\t\tproperties.dispose();\n\t\tobjects.dispose();\n\n\t\tvr.dispose();\n\n\t\tstopAnimation();\n\n\t};\n\n\t// Events\n\n\tfunction onContextLost( event ) {\n\n\t\tevent.preventDefault();\n\n\t\tconsole.log( 'THREE.WebGLRenderer: Context Lost.' );\n\n\t\t_isContextLost = true;\n\n\t}\n\n\tfunction onContextRestore( /* event */ ) {\n\n\t\tconsole.log( 'THREE.WebGLRenderer: Context Restored.' );\n\n\t\t_isContextLost = false;\n\n\t\tinitGLContext();\n\n\t}\n\n\tfunction onMaterialDispose( event ) {\n\n\t\tvar material = event.target;\n\n\t\tmaterial.removeEventListener( 'dispose', onMaterialDispose );\n\n\t\tdeallocateMaterial( material );\n\n\t}\n\n\t// Buffer deallocation\n\n\tfunction deallocateMaterial( material ) {\n\n\t\treleaseMaterialProgramReference( material );\n\n\t\tproperties.remove( material );\n\n\t}\n\n\n\tfunction releaseMaterialProgramReference( material ) {\n\n\t\tvar programInfo = properties.get( material ).program;\n\n\t\tmaterial.program = undefined;\n\n\t\tif ( programInfo !== undefined ) {\n\n\t\t\tprogramCache.releaseProgram( programInfo );\n\n\t\t}\n\n\t}\n\n\t// Buffer rendering\n\n\tfunction renderObjectImmediate( object, program, material ) {\n\n\t\tobject.render( function ( object ) {\n\n\t\t\t_this.renderBufferImmediate( object, program, material );\n\n\t\t} );\n\n\t}\n\n\tthis.renderBufferImmediate = function ( object, program, material ) {\n\n\t\tstate.initAttributes();\n\n\t\tvar buffers = properties.get( object );\n\n\t\tif ( object.hasPositions && ! buffers.position ) buffers.position = _gl.createBuffer();\n\t\tif ( object.hasNormals && ! buffers.normal ) buffers.normal = _gl.createBuffer();\n\t\tif ( object.hasUvs && ! buffers.uv ) buffers.uv = _gl.createBuffer();\n\t\tif ( object.hasColors && ! buffers.color ) buffers.color = _gl.createBuffer();\n\n\t\tvar programAttributes = program.getAttributes();\n\n\t\tif ( object.hasPositions ) {\n\n\t\t\t_gl.bindBuffer( _gl.ARRAY_BUFFER, buffers.position );\n\t\t\t_gl.bufferData( _gl.ARRAY_BUFFER, object.positionArray, _gl.DYNAMIC_DRAW );\n\n\t\t\tstate.enableAttribute( programAttributes.position );\n\t\t\t_gl.vertexAttribPointer( programAttributes.position, 3, _gl.FLOAT, false, 0, 0 );\n\n\t\t}\n\n\t\tif ( object.hasNormals ) {\n\n\t\t\t_gl.bindBuffer( _gl.ARRAY_BUFFER, buffers.normal );\n\n\t\t\tif ( ! material.isMeshPhongMaterial &&\n\t\t\t\t! material.isMeshStandardMaterial &&\n\t\t\t\t! material.isMeshNormalMaterial &&\n\t\t\t\tmaterial.flatShading === true ) {\n\n\t\t\t\tfor ( var i = 0, l = object.count * 3; i < l; i += 9 ) {\n\n\t\t\t\t\tvar array = object.normalArray;\n\n\t\t\t\t\tvar nx = ( array[ i + 0 ] + array[ i + 3 ] + array[ i + 6 ] ) / 3;\n\t\t\t\t\tvar ny = ( array[ i + 1 ] + array[ i + 4 ] + array[ i + 7 ] ) / 3;\n\t\t\t\t\tvar nz = ( array[ i + 2 ] + array[ i + 5 ] + array[ i + 8 ] ) / 3;\n\n\t\t\t\t\tarray[ i + 0 ] = nx;\n\t\t\t\t\tarray[ i + 1 ] = ny;\n\t\t\t\t\tarray[ i + 2 ] = nz;\n\n\t\t\t\t\tarray[ i + 3 ] = nx;\n\t\t\t\t\tarray[ i + 4 ] = ny;\n\t\t\t\t\tarray[ i + 5 ] = nz;\n\n\t\t\t\t\tarray[ i + 6 ] = nx;\n\t\t\t\t\tarray[ i + 7 ] = ny;\n\t\t\t\t\tarray[ i + 8 ] = nz;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t_gl.bufferData( _gl.ARRAY_BUFFER, object.normalArray, _gl.DYNAMIC_DRAW );\n\n\t\t\tstate.enableAttribute( programAttributes.normal );\n\n\t\t\t_gl.vertexAttribPointer( programAttributes.normal, 3, _gl.FLOAT, false, 0, 0 );\n\n\t\t}\n\n\t\tif ( object.hasUvs && material.map ) {\n\n\t\t\t_gl.bindBuffer( _gl.ARRAY_BUFFER, buffers.uv );\n\t\t\t_gl.bufferData( _gl.ARRAY_BUFFER, object.uvArray, _gl.DYNAMIC_DRAW );\n\n\t\t\tstate.enableAttribute( programAttributes.uv );\n\n\t\t\t_gl.vertexAttribPointer( programAttributes.uv, 2, _gl.FLOAT, false, 0, 0 );\n\n\t\t}\n\n\t\tif ( object.hasColors && material.vertexColors !== NoColors ) {\n\n\t\t\t_gl.bindBuffer( _gl.ARRAY_BUFFER, buffers.color );\n\t\t\t_gl.bufferData( _gl.ARRAY_BUFFER, object.colorArray, _gl.DYNAMIC_DRAW );\n\n\t\t\tstate.enableAttribute( programAttributes.color );\n\n\t\t\t_gl.vertexAttribPointer( programAttributes.color, 3, _gl.FLOAT, false, 0, 0 );\n\n\t\t}\n\n\t\tstate.disableUnusedAttributes();\n\n\t\t_gl.drawArrays( _gl.TRIANGLES, 0, object.count );\n\n\t\tobject.count = 0;\n\n\t};\n\n\tthis.renderBufferDirect = function ( camera, fog, geometry, material, object, group ) {\n\n\t\tvar frontFaceCW = ( object.isMesh && object.matrixWorld.determinant() < 0 );\n\n\t\tstate.setMaterial( material, frontFaceCW );\n\n\t\tvar program = setProgram( camera, fog, material, object );\n\t\tvar geometryProgram = geometry.id + '_' + program.id + '_' + ( material.wireframe === true );\n\n\t\tvar updateBuffers = false;\n\n\t\tif ( geometryProgram !== _currentGeometryProgram ) {\n\n\t\t\t_currentGeometryProgram = geometryProgram;\n\t\t\tupdateBuffers = true;\n\n\t\t}\n\n\t\tif ( object.morphTargetInfluences ) {\n\n\t\t\tmorphtargets.update( object, geometry, material, program );\n\n\t\t\tupdateBuffers = true;\n\n\t\t}\n\n\t\t//\n\n\t\tvar index = geometry.index;\n\t\tvar position = geometry.attributes.position;\n\t\tvar rangeFactor = 1;\n\n\t\tif ( material.wireframe === true ) {\n\n\t\t\tindex = geometries.getWireframeAttribute( geometry );\n\t\t\trangeFactor = 2;\n\n\t\t}\n\n\t\tvar attribute;\n\t\tvar renderer = bufferRenderer;\n\n\t\tif ( index !== null ) {\n\n\t\t\tattribute = attributes.get( index );\n\n\t\t\trenderer = indexedBufferRenderer;\n\t\t\trenderer.setIndex( attribute );\n\n\t\t}\n\n\t\tif ( updateBuffers ) {\n\n\t\t\tsetupVertexAttributes( material, program, geometry );\n\n\t\t\tif ( index !== null ) {\n\n\t\t\t\t_gl.bindBuffer( _gl.ELEMENT_ARRAY_BUFFER, attribute.buffer );\n\n\t\t\t}\n\n\t\t}\n\n\t\t//\n\n\t\tvar dataCount = Infinity;\n\n\t\tif ( index !== null ) {\n\n\t\t\tdataCount = index.count;\n\n\t\t} else if ( position !== undefined ) {\n\n\t\t\tdataCount = position.count;\n\n\t\t}\n\n\t\tvar rangeStart = geometry.drawRange.start * rangeFactor;\n\t\tvar rangeCount = geometry.drawRange.count * rangeFactor;\n\n\t\tvar groupStart = group !== null ? group.start * rangeFactor : 0;\n\t\tvar groupCount = group !== null ? group.count * rangeFactor : Infinity;\n\n\t\tvar drawStart = Math.max( rangeStart, groupStart );\n\t\tvar drawEnd = Math.min( dataCount, rangeStart + rangeCount, groupStart + groupCount ) - 1;\n\n\t\tvar drawCount = Math.max( 0, drawEnd - drawStart + 1 );\n\n\t\tif ( drawCount === 0 ) return;\n\n\t\t//\n\n\t\tif ( object.isMesh ) {\n\n\t\t\tif ( material.wireframe === true ) {\n\n\t\t\t\tstate.setLineWidth( material.wireframeLinewidth * getTargetPixelRatio() );\n\t\t\t\trenderer.setMode( _gl.LINES );\n\n\t\t\t} else {\n\n\t\t\t\tswitch ( object.drawMode ) {\n\n\t\t\t\t\tcase TrianglesDrawMode:\n\t\t\t\t\t\trenderer.setMode( _gl.TRIANGLES );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase TriangleStripDrawMode:\n\t\t\t\t\t\trenderer.setMode( _gl.TRIANGLE_STRIP );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase TriangleFanDrawMode:\n\t\t\t\t\t\trenderer.setMode( _gl.TRIANGLE_FAN );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\n\t\t} else if ( object.isLine ) {\n\n\t\t\tvar lineWidth = material.linewidth;\n\n\t\t\tif ( lineWidth === undefined ) lineWidth = 1; // Not using Line*Material\n\n\t\t\tstate.setLineWidth( lineWidth * getTargetPixelRatio() );\n\n\t\t\tif ( object.isLineSegments ) {\n\n\t\t\t\trenderer.setMode( _gl.LINES );\n\n\t\t\t} else if ( object.isLineLoop ) {\n\n\t\t\t\trenderer.setMode( _gl.LINE_LOOP );\n\n\t\t\t} else {\n\n\t\t\t\trenderer.setMode( _gl.LINE_STRIP );\n\n\t\t\t}\n\n\t\t} else if ( object.isPoints ) {\n\n\t\t\trenderer.setMode( _gl.POINTS );\n\n\t\t}\n\n\t\tif ( geometry && geometry.isInstancedBufferGeometry ) {\n\n\t\t\tif ( geometry.maxInstancedCount > 0 ) {\n\n\t\t\t\trenderer.renderInstances( geometry, drawStart, drawCount );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\trenderer.render( drawStart, drawCount );\n\n\t\t}\n\n\t};\n\n\tfunction setupVertexAttributes( material, program, geometry ) {\n\n\t\tif ( geometry && geometry.isInstancedBufferGeometry ) {\n\n\t\t\tif ( extensions.get( 'ANGLE_instanced_arrays' ) === null ) {\n\n\t\t\t\tconsole.error( 'THREE.WebGLRenderer.setupVertexAttributes: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.' );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t}\n\n\t\tstate.initAttributes();\n\n\t\tvar geometryAttributes = geometry.attributes;\n\n\t\tvar programAttributes = program.getAttributes();\n\n\t\tvar materialDefaultAttributeValues = material.defaultAttributeValues;\n\n\t\tfor ( var name in programAttributes ) {\n\n\t\t\tvar programAttribute = programAttributes[ name ];\n\n\t\t\tif ( programAttribute >= 0 ) {\n\n\t\t\t\tvar geometryAttribute = geometryAttributes[ name ];\n\n\t\t\t\tif ( geometryAttribute !== undefined ) {\n\n\t\t\t\t\tvar normalized = geometryAttribute.normalized;\n\t\t\t\t\tvar size = geometryAttribute.itemSize;\n\n\t\t\t\t\tvar attribute = attributes.get( geometryAttribute );\n\n\t\t\t\t\t// TODO Attribute may not be available on context restore\n\n\t\t\t\t\tif ( attribute === undefined ) continue;\n\n\t\t\t\t\tvar buffer = attribute.buffer;\n\t\t\t\t\tvar type = attribute.type;\n\t\t\t\t\tvar bytesPerElement = attribute.bytesPerElement;\n\n\t\t\t\t\tif ( geometryAttribute.isInterleavedBufferAttribute ) {\n\n\t\t\t\t\t\tvar data = geometryAttribute.data;\n\t\t\t\t\t\tvar stride = data.stride;\n\t\t\t\t\t\tvar offset = geometryAttribute.offset;\n\n\t\t\t\t\t\tif ( data && data.isInstancedInterleavedBuffer ) {\n\n\t\t\t\t\t\t\tstate.enableAttributeAndDivisor( programAttribute, data.meshPerAttribute );\n\n\t\t\t\t\t\t\tif ( geometry.maxInstancedCount === undefined ) {\n\n\t\t\t\t\t\t\t\tgeometry.maxInstancedCount = data.meshPerAttribute * data.count;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tstate.enableAttribute( programAttribute );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t_gl.bindBuffer( _gl.ARRAY_BUFFER, buffer );\n\t\t\t\t\t\t_gl.vertexAttribPointer( programAttribute, size, type, normalized, stride * bytesPerElement, offset * bytesPerElement );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tif ( geometryAttribute.isInstancedBufferAttribute ) {\n\n\t\t\t\t\t\t\tstate.enableAttributeAndDivisor( programAttribute, geometryAttribute.meshPerAttribute );\n\n\t\t\t\t\t\t\tif ( geometry.maxInstancedCount === undefined ) {\n\n\t\t\t\t\t\t\t\tgeometry.maxInstancedCount = geometryAttribute.meshPerAttribute * geometryAttribute.count;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tstate.enableAttribute( programAttribute );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t_gl.bindBuffer( _gl.ARRAY_BUFFER, buffer );\n\t\t\t\t\t\t_gl.vertexAttribPointer( programAttribute, size, type, normalized, 0, 0 );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else if ( materialDefaultAttributeValues !== undefined ) {\n\n\t\t\t\t\tvar value = materialDefaultAttributeValues[ name ];\n\n\t\t\t\t\tif ( value !== undefined ) {\n\n\t\t\t\t\t\tswitch ( value.length ) {\n\n\t\t\t\t\t\t\tcase 2:\n\t\t\t\t\t\t\t\t_gl.vertexAttrib2fv( programAttribute, value );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase 3:\n\t\t\t\t\t\t\t\t_gl.vertexAttrib3fv( programAttribute, value );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase 4:\n\t\t\t\t\t\t\t\t_gl.vertexAttrib4fv( programAttribute, value );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t_gl.vertexAttrib1fv( programAttribute, value );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tstate.disableUnusedAttributes();\n\n\t}\n\n\t// Compile\n\n\tthis.compile = function ( scene, camera ) {\n\n\t\tcurrentRenderState = renderStates.get( scene, camera );\n\t\tcurrentRenderState.init();\n\n\t\tscene.traverse( function ( object ) {\n\n\t\t\tif ( object.isLight ) {\n\n\t\t\t\tcurrentRenderState.pushLight( object );\n\n\t\t\t\tif ( object.castShadow ) {\n\n\t\t\t\t\tcurrentRenderState.pushShadow( object );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} );\n\n\t\tcurrentRenderState.setupLights( camera );\n\n\t\tscene.traverse( function ( object ) {\n\n\t\t\tif ( object.material ) {\n\n\t\t\t\tif ( Array.isArray( object.material ) ) {\n\n\t\t\t\t\tfor ( var i = 0; i < object.material.length; i ++ ) {\n\n\t\t\t\t\t\tinitMaterial( object.material[ i ], scene.fog, object );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tinitMaterial( object.material, scene.fog, object );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} );\n\n\t};\n\n\t// Animation Loop\n\n\tvar isAnimating = false;\n\tvar onAnimationFrame = null;\n\n\tfunction startAnimation() {\n\n\t\tif ( isAnimating ) return;\n\n\t\trequestAnimationLoopFrame();\n\n\t\tisAnimating = true;\n\n\t}\n\n\tfunction stopAnimation() {\n\n\t\tisAnimating = false;\n\n\t}\n\n\tfunction requestAnimationLoopFrame() {\n\n\t\tvar device = vr.getDevice();\n\n\t\tif ( device && device.isPresenting ) {\n\n\t\t\tdevice.requestAnimationFrame( animationLoop );\n\n\t\t} else {\n\n\t\t\twindow.requestAnimationFrame( animationLoop );\n\n\t\t}\n\n\t}\n\n\tfunction animationLoop( time ) {\n\n\t\tif ( isAnimating === false ) return;\n\n\t\tonAnimationFrame( time );\n\n\t\trequestAnimationLoopFrame();\n\n\t}\n\n\tthis.animate = function ( callback ) {\n\n\t\tonAnimationFrame = callback;\n\t\tonAnimationFrame !== null ? startAnimation() : stopAnimation();\n\n\t};\n\n\t// Rendering\n\n\tthis.render = function ( scene, camera, renderTarget, forceClear ) {\n\n\t\tif ( ! ( camera && camera.isCamera ) ) {\n\n\t\t\tconsole.error( 'THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( _isContextLost ) return;\n\n\t\t// reset caching for this frame\n\n\t\t_currentGeometryProgram = '';\n\t\t_currentMaterialId = - 1;\n\t\t_currentCamera = null;\n\n\t\t// update scene graph\n\n\t\tif ( scene.autoUpdate === true ) scene.updateMatrixWorld();\n\n\t\t// update camera matrices and frustum\n\n\t\tif ( camera.parent === null ) camera.updateMatrixWorld();\n\n\t\tif ( vr.enabled ) {\n\n\t\t\tcamera = vr.getCamera( camera );\n\n\t\t}\n\n\t\t//\n\n\t\tcurrentRenderState = renderStates.get( scene, camera );\n\t\tcurrentRenderState.init();\n\n\t\tscene.onBeforeRender( _this, scene, camera, renderTarget );\n\n\t\t_projScreenMatrix.multiplyMatrices( camera.projectionMatrix, camera.matrixWorldInverse );\n\t\t_frustum.setFromMatrix( _projScreenMatrix );\n\n\t\t_localClippingEnabled = this.localClippingEnabled;\n\t\t_clippingEnabled = _clipping.init( this.clippingPlanes, _localClippingEnabled, camera );\n\n\t\tcurrentRenderList = renderLists.get( scene, camera );\n\t\tcurrentRenderList.init();\n\n\t\tprojectObject( scene, camera, _this.sortObjects );\n\n\t\tif ( _this.sortObjects === true ) {\n\n\t\t\tcurrentRenderList.sort();\n\n\t\t}\n\n\t\t//\n\n\t\tif ( _clippingEnabled ) _clipping.beginShadows();\n\n\t\tvar shadowsArray = currentRenderState.state.shadowsArray;\n\n\t\tshadowMap.render( shadowsArray, scene, camera );\n\n\t\tcurrentRenderState.setupLights( camera );\n\n\t\tif ( _clippingEnabled ) _clipping.endShadows();\n\n\t\t//\n\n\t\tif ( this.info.autoReset ) this.info.reset();\n\n\t\tif ( renderTarget === undefined ) {\n\n\t\t\trenderTarget = null;\n\n\t\t}\n\n\t\tthis.setRenderTarget( renderTarget );\n\n\t\t//\n\n\t\tbackground.render( currentRenderList, scene, camera, forceClear );\n\n\t\t// render scene\n\n\t\tvar opaqueObjects = currentRenderList.opaque;\n\t\tvar transparentObjects = currentRenderList.transparent;\n\n\t\tif ( scene.overrideMaterial ) {\n\n\t\t\tvar overrideMaterial = scene.overrideMaterial;\n\n\t\t\tif ( opaqueObjects.length ) renderObjects( opaqueObjects, scene, camera, overrideMaterial );\n\t\t\tif ( transparentObjects.length ) renderObjects( transparentObjects, scene, camera, overrideMaterial );\n\n\t\t} else {\n\n\t\t\t// opaque pass (front-to-back order)\n\n\t\t\tif ( opaqueObjects.length ) renderObjects( opaqueObjects, scene, camera );\n\n\t\t\t// transparent pass (back-to-front order)\n\n\t\t\tif ( transparentObjects.length ) renderObjects( transparentObjects, scene, camera );\n\n\t\t}\n\n\t\t// custom renderers\n\n\t\tvar spritesArray = currentRenderState.state.spritesArray;\n\n\t\tspriteRenderer.render( spritesArray, scene, camera );\n\n\t\t// Generate mipmap if we're using any kind of mipmap filtering\n\n\t\tif ( renderTarget ) {\n\n\t\t\ttextures.updateRenderTargetMipmap( renderTarget );\n\n\t\t}\n\n\t\t// Ensure depth buffer writing is enabled so it can be cleared on next render\n\n\t\tstate.buffers.depth.setTest( true );\n\t\tstate.buffers.depth.setMask( true );\n\t\tstate.buffers.color.setMask( true );\n\n\t\tstate.setPolygonOffset( false );\n\n\t\tscene.onAfterRender( _this, scene, camera );\n\n\t\tif ( vr.enabled ) {\n\n\t\t\tvr.submitFrame();\n\n\t\t}\n\n\t\t// _gl.finish();\n\n\t\tcurrentRenderList = null;\n\t\tcurrentRenderState = null;\n\n\t};\n\n\t/*\n\t// TODO Duplicated code (Frustum)\n\n\tvar _sphere = new Sphere();\n\n\tfunction isObjectViewable( object ) {\n\n\t\tvar geometry = object.geometry;\n\n\t\tif ( geometry.boundingSphere === null )\n\t\t\tgeometry.computeBoundingSphere();\n\n\t\t_sphere.copy( geometry.boundingSphere ).\n\t\tapplyMatrix4( object.matrixWorld );\n\n\t\treturn isSphereViewable( _sphere );\n\n\t}\n\n\tfunction isSpriteViewable( sprite ) {\n\n\t\t_sphere.center.set( 0, 0, 0 );\n\t\t_sphere.radius = 0.7071067811865476;\n\t\t_sphere.applyMatrix4( sprite.matrixWorld );\n\n\t\treturn isSphereViewable( _sphere );\n\n\t}\n\n\tfunction isSphereViewable( sphere ) {\n\n\t\tif ( ! _frustum.intersectsSphere( sphere ) ) return false;\n\n\t\tvar numPlanes = _clipping.numPlanes;\n\n\t\tif ( numPlanes === 0 ) return true;\n\n\t\tvar planes = _this.clippingPlanes,\n\n\t\t\tcenter = sphere.center,\n\t\t\tnegRad = - sphere.radius,\n\t\t\ti = 0;\n\n\t\tdo {\n\n\t\t\t// out when deeper than radius in the negative halfspace\n\t\t\tif ( planes[ i ].distanceToPoint( center ) < negRad ) return false;\n\n\t\t} while ( ++ i !== numPlanes );\n\n\t\treturn true;\n\n\t}\n\t*/\n\n\tfunction projectObject( object, camera, sortObjects ) {\n\n\t\tif ( object.visible === false ) return;\n\n\t\tvar visible = object.layers.test( camera.layers );\n\n\t\tif ( visible ) {\n\n\t\t\tif ( object.isLight ) {\n\n\t\t\t\tcurrentRenderState.pushLight( object );\n\n\t\t\t\tif ( object.castShadow ) {\n\n\t\t\t\t\tcurrentRenderState.pushShadow( object );\n\n\t\t\t\t}\n\n\t\t\t} else if ( object.isSprite ) {\n\n\t\t\t\tif ( ! object.frustumCulled || _frustum.intersectsSprite( object ) ) {\n\n\t\t\t\t\tcurrentRenderState.pushSprite( object );\n\n\t\t\t\t}\n\n\t\t\t} else if ( object.isImmediateRenderObject ) {\n\n\t\t\t\tif ( sortObjects ) {\n\n\t\t\t\t\t_vector3.setFromMatrixPosition( object.matrixWorld )\n\t\t\t\t\t\t.applyMatrix4( _projScreenMatrix );\n\n\t\t\t\t}\n\n\t\t\t\tcurrentRenderList.push( object, null, object.material, _vector3.z, null );\n\n\t\t\t} else if ( object.isMesh || object.isLine || object.isPoints ) {\n\n\t\t\t\tif ( object.isSkinnedMesh ) {\n\n\t\t\t\t\tobject.skeleton.update();\n\n\t\t\t\t}\n\n\t\t\t\tif ( ! object.frustumCulled || _frustum.intersectsObject( object ) ) {\n\n\t\t\t\t\tif ( sortObjects ) {\n\n\t\t\t\t\t\t_vector3.setFromMatrixPosition( object.matrixWorld )\n\t\t\t\t\t\t\t.applyMatrix4( _projScreenMatrix );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tvar geometry = objects.update( object );\n\t\t\t\t\tvar material = object.material;\n\n\t\t\t\t\tif ( Array.isArray( material ) ) {\n\n\t\t\t\t\t\tvar groups = geometry.groups;\n\n\t\t\t\t\t\tfor ( var i = 0, l = groups.length; i < l; i ++ ) {\n\n\t\t\t\t\t\t\tvar group = groups[ i ];\n\t\t\t\t\t\t\tvar groupMaterial = material[ group.materialIndex ];\n\n\t\t\t\t\t\t\tif ( groupMaterial && groupMaterial.visible ) {\n\n\t\t\t\t\t\t\t\tcurrentRenderList.push( object, geometry, groupMaterial, _vector3.z, group );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else if ( material.visible ) {\n\n\t\t\t\t\t\tcurrentRenderList.push( object, geometry, material, _vector3.z, null );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar children = object.children;\n\n\t\tfor ( var i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tprojectObject( children[ i ], camera, sortObjects );\n\n\t\t}\n\n\t}\n\n\tfunction renderObjects( renderList, scene, camera, overrideMaterial ) {\n\n\t\tfor ( var i = 0, l = renderList.length; i < l; i ++ ) {\n\n\t\t\tvar renderItem = renderList[ i ];\n\n\t\t\tvar object = renderItem.object;\n\t\t\tvar geometry = renderItem.geometry;\n\t\t\tvar material = overrideMaterial === undefined ? renderItem.material : overrideMaterial;\n\t\t\tvar group = renderItem.group;\n\n\t\t\tif ( camera.isArrayCamera ) {\n\n\t\t\t\t_currentArrayCamera = camera;\n\n\t\t\t\tvar cameras = camera.cameras;\n\n\t\t\t\tfor ( var j = 0, jl = cameras.length; j < jl; j ++ ) {\n\n\t\t\t\t\tvar camera2 = cameras[ j ];\n\n\t\t\t\t\tif ( object.layers.test( camera2.layers ) ) {\n\n\t\t\t\t\t\tvar bounds = camera2.bounds;\n\n\t\t\t\t\t\tvar x = bounds.x * _width;\n\t\t\t\t\t\tvar y = bounds.y * _height;\n\t\t\t\t\t\tvar width = bounds.z * _width;\n\t\t\t\t\t\tvar height = bounds.w * _height;\n\n\t\t\t\t\t\tstate.viewport( _currentViewport.set( x, y, width, height ).multiplyScalar( _pixelRatio ) );\n\n\t\t\t\t\t\trenderObject( object, scene, camera2, geometry, material, group );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t_currentArrayCamera = null;\n\n\t\t\t\trenderObject( object, scene, camera, geometry, material, group );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction renderObject( object, scene, camera, geometry, material, group ) {\n\n\t\tobject.onBeforeRender( _this, scene, camera, geometry, material, group );\n\t\tcurrentRenderState = renderStates.get( scene, _currentArrayCamera || camera );\n\n\t\tobject.modelViewMatrix.multiplyMatrices( camera.matrixWorldInverse, object.matrixWorld );\n\t\tobject.normalMatrix.getNormalMatrix( object.modelViewMatrix );\n\n\t\tif ( object.isImmediateRenderObject ) {\n\n\t\t\tvar frontFaceCW = ( object.isMesh && object.matrixWorld.determinant() < 0 );\n\n\t\t\tstate.setMaterial( material, frontFaceCW );\n\n\t\t\tvar program = setProgram( camera, scene.fog, material, object );\n\n\t\t\t_currentGeometryProgram = '';\n\n\t\t\trenderObjectImmediate( object, program, material );\n\n\t\t} else {\n\n\t\t\t_this.renderBufferDirect( camera, scene.fog, geometry, material, object, group );\n\n\t\t}\n\n\t\tobject.onAfterRender( _this, scene, camera, geometry, material, group );\n\t\tcurrentRenderState = renderStates.get( scene, _currentArrayCamera || camera );\n\n\t}\n\n\tfunction initMaterial( material, fog, object ) {\n\n\t\tvar materialProperties = properties.get( material );\n\n\t\tvar lights = currentRenderState.state.lights;\n\t\tvar shadowsArray = currentRenderState.state.shadowsArray;\n\n\t\tvar parameters = programCache.getParameters(\n\t\t\tmaterial, lights.state, shadowsArray, fog, _clipping.numPlanes, _clipping.numIntersection, object );\n\n\t\tvar code = programCache.getProgramCode( material, parameters );\n\n\t\tvar program = materialProperties.program;\n\t\tvar programChange = true;\n\n\t\tif ( program === undefined ) {\n\n\t\t\t// new material\n\t\t\tmaterial.addEventListener( 'dispose', onMaterialDispose );\n\n\t\t} else if ( program.code !== code ) {\n\n\t\t\t// changed glsl or parameters\n\t\t\treleaseMaterialProgramReference( material );\n\n\t\t} else if ( materialProperties.lightsHash !== lights.state.hash ) {\n\n\t\t\tproperties.update( material, 'lightsHash', lights.state.hash );\n\t\t\tprogramChange = false;\n\n\t\t} else if ( parameters.shaderID !== undefined ) {\n\n\t\t\t// same glsl and uniform list\n\t\t\treturn;\n\n\t\t} else {\n\n\t\t\t// only rebuild uniform list\n\t\t\tprogramChange = false;\n\n\t\t}\n\n\t\tif ( programChange ) {\n\n\t\t\tif ( parameters.shaderID ) {\n\n\t\t\t\tvar shader = ShaderLib[ parameters.shaderID ];\n\n\t\t\t\tmaterialProperties.shader = {\n\t\t\t\t\tname: material.type,\n\t\t\t\t\tuniforms: UniformsUtils.clone( shader.uniforms ),\n\t\t\t\t\tvertexShader: shader.vertexShader,\n\t\t\t\t\tfragmentShader: shader.fragmentShader\n\t\t\t\t};\n\n\t\t\t} else {\n\n\t\t\t\tmaterialProperties.shader = {\n\t\t\t\t\tname: material.type,\n\t\t\t\t\tuniforms: material.uniforms,\n\t\t\t\t\tvertexShader: material.vertexShader,\n\t\t\t\t\tfragmentShader: material.fragmentShader\n\t\t\t\t};\n\n\t\t\t}\n\n\t\t\tmaterial.onBeforeCompile( materialProperties.shader, _this );\n\n\t\t\tprogram = programCache.acquireProgram( material, materialProperties.shader, parameters, code );\n\n\t\t\tmaterialProperties.program = program;\n\t\t\tmaterial.program = program;\n\n\t\t}\n\n\t\tvar programAttributes = program.getAttributes();\n\n\t\tif ( material.morphTargets ) {\n\n\t\t\tmaterial.numSupportedMorphTargets = 0;\n\n\t\t\tfor ( var i = 0; i < _this.maxMorphTargets; i ++ ) {\n\n\t\t\t\tif ( programAttributes[ 'morphTarget' + i ] >= 0 ) {\n\n\t\t\t\t\tmaterial.numSupportedMorphTargets ++;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( material.morphNormals ) {\n\n\t\t\tmaterial.numSupportedMorphNormals = 0;\n\n\t\t\tfor ( var i = 0; i < _this.maxMorphNormals; i ++ ) {\n\n\t\t\t\tif ( programAttributes[ 'morphNormal' + i ] >= 0 ) {\n\n\t\t\t\t\tmaterial.numSupportedMorphNormals ++;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar uniforms = materialProperties.shader.uniforms;\n\n\t\tif ( ! material.isShaderMaterial &&\n\t\t\t! material.isRawShaderMaterial ||\n\t\t\tmaterial.clipping === true ) {\n\n\t\t\tmaterialProperties.numClippingPlanes = _clipping.numPlanes;\n\t\t\tmaterialProperties.numIntersection = _clipping.numIntersection;\n\t\t\tuniforms.clippingPlanes = _clipping.uniform;\n\n\t\t}\n\n\t\tmaterialProperties.fog = fog;\n\n\t\t// store the light setup it was created for\n\n\t\tmaterialProperties.lightsHash = lights.state.hash;\n\n\t\tif ( material.lights ) {\n\n\t\t\t// wire up the material to this renderer's lighting state\n\n\t\t\tuniforms.ambientLightColor.value = lights.state.ambient;\n\t\t\tuniforms.directionalLights.value = lights.state.directional;\n\t\t\tuniforms.spotLights.value = lights.state.spot;\n\t\t\tuniforms.rectAreaLights.value = lights.state.rectArea;\n\t\t\tuniforms.pointLights.value = lights.state.point;\n\t\t\tuniforms.hemisphereLights.value = lights.state.hemi;\n\n\t\t\tuniforms.directionalShadowMap.value = lights.state.directionalShadowMap;\n\t\t\tuniforms.directionalShadowMatrix.value = lights.state.directionalShadowMatrix;\n\t\t\tuniforms.spotShadowMap.value = lights.state.spotShadowMap;\n\t\t\tuniforms.spotShadowMatrix.value = lights.state.spotShadowMatrix;\n\t\t\tuniforms.pointShadowMap.value = lights.state.pointShadowMap;\n\t\t\tuniforms.pointShadowMatrix.value = lights.state.pointShadowMatrix;\n\t\t\t// TODO (abelnation): add area lights shadow info to uniforms\n\n\t\t}\n\n\t\tvar progUniforms = materialProperties.program.getUniforms(),\n\t\t\tuniformsList =\n\t\t\t\tWebGLUniforms.seqWithValue( progUniforms.seq, uniforms );\n\n\t\tmaterialProperties.uniformsList = uniformsList;\n\n\t}\n\n\tfunction setProgram( camera, fog, material, object ) {\n\n\t\t_usedTextureUnits = 0;\n\n\t\tvar materialProperties = properties.get( material );\n\t\tvar lights = currentRenderState.state.lights;\n\n\t\tif ( _clippingEnabled ) {\n\n\t\t\tif ( _localClippingEnabled || camera !== _currentCamera ) {\n\n\t\t\t\tvar useCache =\n\t\t\t\t\tcamera === _currentCamera &&\n\t\t\t\t\tmaterial.id === _currentMaterialId;\n\n\t\t\t\t// we might want to call this function with some ClippingGroup\n\t\t\t\t// object instead of the material, once it becomes feasible\n\t\t\t\t// (#8465, #8379)\n\t\t\t\t_clipping.setState(\n\t\t\t\t\tmaterial.clippingPlanes, material.clipIntersection, material.clipShadows,\n\t\t\t\t\tcamera, materialProperties, useCache );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( material.needsUpdate === false ) {\n\n\t\t\tif ( materialProperties.program === undefined ) {\n\n\t\t\t\tmaterial.needsUpdate = true;\n\n\t\t\t} else if ( material.fog && materialProperties.fog !== fog ) {\n\n\t\t\t\tmaterial.needsUpdate = true;\n\n\t\t\t} else if ( material.lights && materialProperties.lightsHash !== lights.state.hash ) {\n\n\t\t\t\tmaterial.needsUpdate = true;\n\n\t\t\t} else if ( materialProperties.numClippingPlanes !== undefined &&\n\t\t\t\t( materialProperties.numClippingPlanes !== _clipping.numPlanes ||\n\t\t\t\tmaterialProperties.numIntersection !== _clipping.numIntersection ) ) {\n\n\t\t\t\tmaterial.needsUpdate = true;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( material.needsUpdate ) {\n\n\t\t\tinitMaterial( material, fog, object );\n\t\t\tmaterial.needsUpdate = false;\n\n\t\t}\n\n\t\tvar refreshProgram = false;\n\t\tvar refreshMaterial = false;\n\t\tvar refreshLights = false;\n\n\t\tvar program = materialProperties.program,\n\t\t\tp_uniforms = program.getUniforms(),\n\t\t\tm_uniforms = materialProperties.shader.uniforms;\n\n\t\tif ( state.useProgram( program.program ) ) {\n\n\t\t\trefreshProgram = true;\n\t\t\trefreshMaterial = true;\n\t\t\trefreshLights = true;\n\n\t\t}\n\n\t\tif ( material.id !== _currentMaterialId ) {\n\n\t\t\t_currentMaterialId = material.id;\n\n\t\t\trefreshMaterial = true;\n\n\t\t}\n\n\t\tif ( refreshProgram || camera !== _currentCamera ) {\n\n\t\t\tp_uniforms.setValue( _gl, 'projectionMatrix', camera.projectionMatrix );\n\n\t\t\tif ( capabilities.logarithmicDepthBuffer ) {\n\n\t\t\t\tp_uniforms.setValue( _gl, 'logDepthBufFC',\n\t\t\t\t\t2.0 / ( Math.log( camera.far + 1.0 ) / Math.LN2 ) );\n\n\t\t\t}\n\n\t\t\t// Avoid unneeded uniform updates per ArrayCamera's sub-camera\n\n\t\t\tif ( _currentCamera !== ( _currentArrayCamera || camera ) ) {\n\n\t\t\t\t_currentCamera = ( _currentArrayCamera || camera );\n\n\t\t\t\t// lighting uniforms depend on the camera so enforce an update\n\t\t\t\t// now, in case this material supports lights - or later, when\n\t\t\t\t// the next material that does gets activated:\n\n\t\t\t\trefreshMaterial = true;\t\t// set to true on material change\n\t\t\t\trefreshLights = true;\t\t// remains set until update done\n\n\t\t\t}\n\n\t\t\t// load material specific uniforms\n\t\t\t// (shader material also gets them for the sake of genericity)\n\n\t\t\tif ( material.isShaderMaterial ||\n\t\t\t\tmaterial.isMeshPhongMaterial ||\n\t\t\t\tmaterial.isMeshStandardMaterial ||\n\t\t\t\tmaterial.envMap ) {\n\n\t\t\t\tvar uCamPos = p_uniforms.map.cameraPosition;\n\n\t\t\t\tif ( uCamPos !== undefined ) {\n\n\t\t\t\t\tuCamPos.setValue( _gl,\n\t\t\t\t\t\t_vector3.setFromMatrixPosition( camera.matrixWorld ) );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( material.isMeshPhongMaterial ||\n\t\t\t\tmaterial.isMeshLambertMaterial ||\n\t\t\t\tmaterial.isMeshBasicMaterial ||\n\t\t\t\tmaterial.isMeshStandardMaterial ||\n\t\t\t\tmaterial.isShaderMaterial ||\n\t\t\t\tmaterial.skinning ) {\n\n\t\t\t\tp_uniforms.setValue( _gl, 'viewMatrix', camera.matrixWorldInverse );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// skinning uniforms must be set even if material didn't change\n\t\t// auto-setting of texture unit for bone texture must go before other textures\n\t\t// not sure why, but otherwise weird things happen\n\n\t\tif ( material.skinning ) {\n\n\t\t\tp_uniforms.setOptional( _gl, object, 'bindMatrix' );\n\t\t\tp_uniforms.setOptional( _gl, object, 'bindMatrixInverse' );\n\n\t\t\tvar skeleton = object.skeleton;\n\n\t\t\tif ( skeleton ) {\n\n\t\t\t\tvar bones = skeleton.bones;\n\n\t\t\t\tif ( capabilities.floatVertexTextures ) {\n\n\t\t\t\t\tif ( skeleton.boneTexture === undefined ) {\n\n\t\t\t\t\t\t// layout (1 matrix = 4 pixels)\n\t\t\t\t\t\t//      RGBA RGBA RGBA RGBA (=> column1, column2, column3, column4)\n\t\t\t\t\t\t//  with  8x8  pixel texture max   16 bones * 4 pixels =  (8 * 8)\n\t\t\t\t\t\t//       16x16 pixel texture max   64 bones * 4 pixels = (16 * 16)\n\t\t\t\t\t\t//       32x32 pixel texture max  256 bones * 4 pixels = (32 * 32)\n\t\t\t\t\t\t//       64x64 pixel texture max 1024 bones * 4 pixels = (64 * 64)\n\n\n\t\t\t\t\t\tvar size = Math.sqrt( bones.length * 4 ); // 4 pixels needed for 1 matrix\n\t\t\t\t\t\tsize = _Math.ceilPowerOfTwo( size );\n\t\t\t\t\t\tsize = Math.max( size, 4 );\n\n\t\t\t\t\t\tvar boneMatrices = new Float32Array( size * size * 4 ); // 4 floats per RGBA pixel\n\t\t\t\t\t\tboneMatrices.set( skeleton.boneMatrices ); // copy current values\n\n\t\t\t\t\t\tvar boneTexture = new DataTexture( boneMatrices, size, size, RGBAFormat, FloatType );\n\t\t\t\t\t\tboneTexture.needsUpdate = true;\n\n\t\t\t\t\t\tskeleton.boneMatrices = boneMatrices;\n\t\t\t\t\t\tskeleton.boneTexture = boneTexture;\n\t\t\t\t\t\tskeleton.boneTextureSize = size;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tp_uniforms.setValue( _gl, 'boneTexture', skeleton.boneTexture );\n\t\t\t\t\tp_uniforms.setValue( _gl, 'boneTextureSize', skeleton.boneTextureSize );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tp_uniforms.setOptional( _gl, skeleton, 'boneMatrices' );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( refreshMaterial ) {\n\n\t\t\tp_uniforms.setValue( _gl, 'toneMappingExposure', _this.toneMappingExposure );\n\t\t\tp_uniforms.setValue( _gl, 'toneMappingWhitePoint', _this.toneMappingWhitePoint );\n\n\t\t\tif ( material.lights ) {\n\n\t\t\t\t// the current material requires lighting info\n\n\t\t\t\t// note: all lighting uniforms are always set correctly\n\t\t\t\t// they simply reference the renderer's state for their\n\t\t\t\t// values\n\t\t\t\t//\n\t\t\t\t// use the current material's .needsUpdate flags to set\n\t\t\t\t// the GL state when required\n\n\t\t\t\tmarkUniformsLightsNeedsUpdate( m_uniforms, refreshLights );\n\n\t\t\t}\n\n\t\t\t// refresh uniforms common to several materials\n\n\t\t\tif ( fog && material.fog ) {\n\n\t\t\t\trefreshUniformsFog( m_uniforms, fog );\n\n\t\t\t}\n\n\t\t\tif ( material.isMeshBasicMaterial ) {\n\n\t\t\t\trefreshUniformsCommon( m_uniforms, material );\n\n\t\t\t} else if ( material.isMeshLambertMaterial ) {\n\n\t\t\t\trefreshUniformsCommon( m_uniforms, material );\n\t\t\t\trefreshUniformsLambert( m_uniforms, material );\n\n\t\t\t} else if ( material.isMeshPhongMaterial ) {\n\n\t\t\t\trefreshUniformsCommon( m_uniforms, material );\n\n\t\t\t\tif ( material.isMeshToonMaterial ) {\n\n\t\t\t\t\trefreshUniformsToon( m_uniforms, material );\n\n\t\t\t\t} else {\n\n\t\t\t\t\trefreshUniformsPhong( m_uniforms, material );\n\n\t\t\t\t}\n\n\t\t\t} else if ( material.isMeshStandardMaterial ) {\n\n\t\t\t\trefreshUniformsCommon( m_uniforms, material );\n\n\t\t\t\tif ( material.isMeshPhysicalMaterial ) {\n\n\t\t\t\t\trefreshUniformsPhysical( m_uniforms, material );\n\n\t\t\t\t} else {\n\n\t\t\t\t\trefreshUniformsStandard( m_uniforms, material );\n\n\t\t\t\t}\n\n\t\t\t} else if ( material.isMeshDepthMaterial ) {\n\n\t\t\t\trefreshUniformsCommon( m_uniforms, material );\n\t\t\t\trefreshUniformsDepth( m_uniforms, material );\n\n\t\t\t} else if ( material.isMeshDistanceMaterial ) {\n\n\t\t\t\trefreshUniformsCommon( m_uniforms, material );\n\t\t\t\trefreshUniformsDistance( m_uniforms, material );\n\n\t\t\t} else if ( material.isMeshNormalMaterial ) {\n\n\t\t\t\trefreshUniformsCommon( m_uniforms, material );\n\t\t\t\trefreshUniformsNormal( m_uniforms, material );\n\n\t\t\t} else if ( material.isLineBasicMaterial ) {\n\n\t\t\t\trefreshUniformsLine( m_uniforms, material );\n\n\t\t\t\tif ( material.isLineDashedMaterial ) {\n\n\t\t\t\t\trefreshUniformsDash( m_uniforms, material );\n\n\t\t\t\t}\n\n\t\t\t} else if ( material.isPointsMaterial ) {\n\n\t\t\t\trefreshUniformsPoints( m_uniforms, material );\n\n\t\t\t} else if ( material.isShadowMaterial ) {\n\n\t\t\t\tm_uniforms.color.value = material.color;\n\t\t\t\tm_uniforms.opacity.value = material.opacity;\n\n\t\t\t}\n\n\t\t\t// RectAreaLight Texture\n\t\t\t// TODO (mrdoob): Find a nicer implementation\n\n\t\t\tif ( m_uniforms.ltc_1 !== undefined ) m_uniforms.ltc_1.value = UniformsLib.LTC_1;\n\t\t\tif ( m_uniforms.ltc_2 !== undefined ) m_uniforms.ltc_2.value = UniformsLib.LTC_2;\n\n\t\t\tWebGLUniforms.upload( _gl, materialProperties.uniformsList, m_uniforms, _this );\n\n\t\t}\n\n\t\tif ( material.isShaderMaterial && material.uniformsNeedUpdate === true ) {\n\n\t\t\tWebGLUniforms.upload( _gl, materialProperties.uniformsList, m_uniforms, _this );\n\t\t\tmaterial.uniformsNeedUpdate = false;\n\n\t\t}\n\n\t\t// common matrices\n\n\t\tp_uniforms.setValue( _gl, 'modelViewMatrix', object.modelViewMatrix );\n\t\tp_uniforms.setValue( _gl, 'normalMatrix', object.normalMatrix );\n\t\tp_uniforms.setValue( _gl, 'modelMatrix', object.matrixWorld );\n\n\t\treturn program;\n\n\t}\n\n\t// Uniforms (refresh uniforms objects)\n\n\tfunction refreshUniformsCommon( uniforms, material ) {\n\n\t\tuniforms.opacity.value = material.opacity;\n\n\t\tif ( material.color ) {\n\n\t\t\tuniforms.diffuse.value = material.color;\n\n\t\t}\n\n\t\tif ( material.emissive ) {\n\n\t\t\tuniforms.emissive.value.copy( material.emissive ).multiplyScalar( material.emissiveIntensity );\n\n\t\t}\n\n\t\tif ( material.map ) {\n\n\t\t\tuniforms.map.value = material.map;\n\n\t\t}\n\n\t\tif ( material.alphaMap ) {\n\n\t\t\tuniforms.alphaMap.value = material.alphaMap;\n\n\t\t}\n\n\t\tif ( material.specularMap ) {\n\n\t\t\tuniforms.specularMap.value = material.specularMap;\n\n\t\t}\n\n\t\tif ( material.envMap ) {\n\n\t\t\tuniforms.envMap.value = material.envMap;\n\n\t\t\t// don't flip CubeTexture envMaps, flip everything else:\n\t\t\t//  WebGLRenderTargetCube will be flipped for backwards compatibility\n\t\t\t//  WebGLRenderTargetCube.texture will be flipped because it's a Texture and NOT a CubeTexture\n\t\t\t// this check must be handled differently, or removed entirely, if WebGLRenderTargetCube uses a CubeTexture in the future\n\t\t\tuniforms.flipEnvMap.value = ( ! ( material.envMap && material.envMap.isCubeTexture ) ) ? 1 : - 1;\n\n\t\t\tuniforms.reflectivity.value = material.reflectivity;\n\t\t\tuniforms.refractionRatio.value = material.refractionRatio;\n\n\t\t\tuniforms.maxMipLevel.value = properties.get( material.envMap ).__maxMipLevel;\n\n\t\t}\n\n\t\tif ( material.lightMap ) {\n\n\t\t\tuniforms.lightMap.value = material.lightMap;\n\t\t\tuniforms.lightMapIntensity.value = material.lightMapIntensity;\n\n\t\t}\n\n\t\tif ( material.aoMap ) {\n\n\t\t\tuniforms.aoMap.value = material.aoMap;\n\t\t\tuniforms.aoMapIntensity.value = material.aoMapIntensity;\n\n\t\t}\n\n\t\t// uv repeat and offset setting priorities\n\t\t// 1. color map\n\t\t// 2. specular map\n\t\t// 3. normal map\n\t\t// 4. bump map\n\t\t// 5. alpha map\n\t\t// 6. emissive map\n\n\t\tvar uvScaleMap;\n\n\t\tif ( material.map ) {\n\n\t\t\tuvScaleMap = material.map;\n\n\t\t} else if ( material.specularMap ) {\n\n\t\t\tuvScaleMap = material.specularMap;\n\n\t\t} else if ( material.displacementMap ) {\n\n\t\t\tuvScaleMap = material.displacementMap;\n\n\t\t} else if ( material.normalMap ) {\n\n\t\t\tuvScaleMap = material.normalMap;\n\n\t\t} else if ( material.bumpMap ) {\n\n\t\t\tuvScaleMap = material.bumpMap;\n\n\t\t} else if ( material.roughnessMap ) {\n\n\t\t\tuvScaleMap = material.roughnessMap;\n\n\t\t} else if ( material.metalnessMap ) {\n\n\t\t\tuvScaleMap = material.metalnessMap;\n\n\t\t} else if ( material.alphaMap ) {\n\n\t\t\tuvScaleMap = material.alphaMap;\n\n\t\t} else if ( material.emissiveMap ) {\n\n\t\t\tuvScaleMap = material.emissiveMap;\n\n\t\t}\n\n\t\tif ( uvScaleMap !== undefined ) {\n\n\t\t\t// backwards compatibility\n\t\t\tif ( uvScaleMap.isWebGLRenderTarget ) {\n\n\t\t\t\tuvScaleMap = uvScaleMap.texture;\n\n\t\t\t}\n\n\t\t\tif ( uvScaleMap.matrixAutoUpdate === true ) {\n\n\t\t\t\tuvScaleMap.updateMatrix();\n\n\t\t\t}\n\n\t\t\tuniforms.uvTransform.value.copy( uvScaleMap.matrix );\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsLine( uniforms, material ) {\n\n\t\tuniforms.diffuse.value = material.color;\n\t\tuniforms.opacity.value = material.opacity;\n\n\t}\n\n\tfunction refreshUniformsDash( uniforms, material ) {\n\n\t\tuniforms.dashSize.value = material.dashSize;\n\t\tuniforms.totalSize.value = material.dashSize + material.gapSize;\n\t\tuniforms.scale.value = material.scale;\n\n\t}\n\n\tfunction refreshUniformsPoints( uniforms, material ) {\n\n\t\tuniforms.diffuse.value = material.color;\n\t\tuniforms.opacity.value = material.opacity;\n\t\tuniforms.size.value = material.size * _pixelRatio;\n\t\tuniforms.scale.value = _height * 0.5;\n\n\t\tuniforms.map.value = material.map;\n\n\t\tif ( material.map !== null ) {\n\n\t\t\tif ( material.map.matrixAutoUpdate === true ) {\n\n\t\t\t\tmaterial.map.updateMatrix();\n\n\t\t\t}\n\n\t\t\tuniforms.uvTransform.value.copy( material.map.matrix );\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsFog( uniforms, fog ) {\n\n\t\tuniforms.fogColor.value = fog.color;\n\n\t\tif ( fog.isFog ) {\n\n\t\t\tuniforms.fogNear.value = fog.near;\n\t\t\tuniforms.fogFar.value = fog.far;\n\n\t\t} else if ( fog.isFogExp2 ) {\n\n\t\t\tuniforms.fogDensity.value = fog.density;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsLambert( uniforms, material ) {\n\n\t\tif ( material.emissiveMap ) {\n\n\t\t\tuniforms.emissiveMap.value = material.emissiveMap;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsPhong( uniforms, material ) {\n\n\t\tuniforms.specular.value = material.specular;\n\t\tuniforms.shininess.value = Math.max( material.shininess, 1e-4 ); // to prevent pow( 0.0, 0.0 )\n\n\t\tif ( material.emissiveMap ) {\n\n\t\t\tuniforms.emissiveMap.value = material.emissiveMap;\n\n\t\t}\n\n\t\tif ( material.bumpMap ) {\n\n\t\t\tuniforms.bumpMap.value = material.bumpMap;\n\t\t\tuniforms.bumpScale.value = material.bumpScale;\n\n\t\t}\n\n\t\tif ( material.normalMap ) {\n\n\t\t\tuniforms.normalMap.value = material.normalMap;\n\t\t\tuniforms.normalScale.value.copy( material.normalScale );\n\n\t\t}\n\n\t\tif ( material.displacementMap ) {\n\n\t\t\tuniforms.displacementMap.value = material.displacementMap;\n\t\t\tuniforms.displacementScale.value = material.displacementScale;\n\t\t\tuniforms.displacementBias.value = material.displacementBias;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsToon( uniforms, material ) {\n\n\t\trefreshUniformsPhong( uniforms, material );\n\n\t\tif ( material.gradientMap ) {\n\n\t\t\tuniforms.gradientMap.value = material.gradientMap;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsStandard( uniforms, material ) {\n\n\t\tuniforms.roughness.value = material.roughness;\n\t\tuniforms.metalness.value = material.metalness;\n\n\t\tif ( material.roughnessMap ) {\n\n\t\t\tuniforms.roughnessMap.value = material.roughnessMap;\n\n\t\t}\n\n\t\tif ( material.metalnessMap ) {\n\n\t\t\tuniforms.metalnessMap.value = material.metalnessMap;\n\n\t\t}\n\n\t\tif ( material.emissiveMap ) {\n\n\t\t\tuniforms.emissiveMap.value = material.emissiveMap;\n\n\t\t}\n\n\t\tif ( material.bumpMap ) {\n\n\t\t\tuniforms.bumpMap.value = material.bumpMap;\n\t\t\tuniforms.bumpScale.value = material.bumpScale;\n\n\t\t}\n\n\t\tif ( material.normalMap ) {\n\n\t\t\tuniforms.normalMap.value = material.normalMap;\n\t\t\tuniforms.normalScale.value.copy( material.normalScale );\n\n\t\t}\n\n\t\tif ( material.displacementMap ) {\n\n\t\t\tuniforms.displacementMap.value = material.displacementMap;\n\t\t\tuniforms.displacementScale.value = material.displacementScale;\n\t\t\tuniforms.displacementBias.value = material.displacementBias;\n\n\t\t}\n\n\t\tif ( material.envMap ) {\n\n\t\t\t//uniforms.envMap.value = material.envMap; // part of uniforms common\n\t\t\tuniforms.envMapIntensity.value = material.envMapIntensity;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsPhysical( uniforms, material ) {\n\n\t\tuniforms.clearCoat.value = material.clearCoat;\n\t\tuniforms.clearCoatRoughness.value = material.clearCoatRoughness;\n\n\t\trefreshUniformsStandard( uniforms, material );\n\n\t}\n\n\tfunction refreshUniformsDepth( uniforms, material ) {\n\n\t\tif ( material.displacementMap ) {\n\n\t\t\tuniforms.displacementMap.value = material.displacementMap;\n\t\t\tuniforms.displacementScale.value = material.displacementScale;\n\t\t\tuniforms.displacementBias.value = material.displacementBias;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsDistance( uniforms, material ) {\n\n\t\tif ( material.displacementMap ) {\n\n\t\t\tuniforms.displacementMap.value = material.displacementMap;\n\t\t\tuniforms.displacementScale.value = material.displacementScale;\n\t\t\tuniforms.displacementBias.value = material.displacementBias;\n\n\t\t}\n\n\t\tuniforms.referencePosition.value.copy( material.referencePosition );\n\t\tuniforms.nearDistance.value = material.nearDistance;\n\t\tuniforms.farDistance.value = material.farDistance;\n\n\t}\n\n\tfunction refreshUniformsNormal( uniforms, material ) {\n\n\t\tif ( material.bumpMap ) {\n\n\t\t\tuniforms.bumpMap.value = material.bumpMap;\n\t\t\tuniforms.bumpScale.value = material.bumpScale;\n\n\t\t}\n\n\t\tif ( material.normalMap ) {\n\n\t\t\tuniforms.normalMap.value = material.normalMap;\n\t\t\tuniforms.normalScale.value.copy( material.normalScale );\n\n\t\t}\n\n\t\tif ( material.displacementMap ) {\n\n\t\t\tuniforms.displacementMap.value = material.displacementMap;\n\t\t\tuniforms.displacementScale.value = material.displacementScale;\n\t\t\tuniforms.displacementBias.value = material.displacementBias;\n\n\t\t}\n\n\t}\n\n\t// If uniforms are marked as clean, they don't need to be loaded to the GPU.\n\n\tfunction markUniformsLightsNeedsUpdate( uniforms, value ) {\n\n\t\tuniforms.ambientLightColor.needsUpdate = value;\n\n\t\tuniforms.directionalLights.needsUpdate = value;\n\t\tuniforms.pointLights.needsUpdate = value;\n\t\tuniforms.spotLights.needsUpdate = value;\n\t\tuniforms.rectAreaLights.needsUpdate = value;\n\t\tuniforms.hemisphereLights.needsUpdate = value;\n\n\t}\n\n\t// Textures\n\n\tfunction allocTextureUnit() {\n\n\t\tvar textureUnit = _usedTextureUnits;\n\n\t\tif ( textureUnit >= capabilities.maxTextures ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: Trying to use ' + textureUnit + ' texture units while this GPU supports only ' + capabilities.maxTextures );\n\n\t\t}\n\n\t\t_usedTextureUnits += 1;\n\n\t\treturn textureUnit;\n\n\t}\n\n\tthis.allocTextureUnit = allocTextureUnit;\n\n\t// this.setTexture2D = setTexture2D;\n\tthis.setTexture2D = ( function () {\n\n\t\tvar warned = false;\n\n\t\t// backwards compatibility: peel texture.texture\n\t\treturn function setTexture2D( texture, slot ) {\n\n\t\t\tif ( texture && texture.isWebGLRenderTarget ) {\n\n\t\t\t\tif ( ! warned ) {\n\n\t\t\t\t\tconsole.warn( \"THREE.WebGLRenderer.setTexture2D: don't use render targets as textures. Use their .texture property instead.\" );\n\t\t\t\t\twarned = true;\n\n\t\t\t\t}\n\n\t\t\t\ttexture = texture.texture;\n\n\t\t\t}\n\n\t\t\ttextures.setTexture2D( texture, slot );\n\n\t\t};\n\n\t}() );\n\n\tthis.setTexture = ( function () {\n\n\t\tvar warned = false;\n\n\t\treturn function setTexture( texture, slot ) {\n\n\t\t\tif ( ! warned ) {\n\n\t\t\t\tconsole.warn( \"THREE.WebGLRenderer: .setTexture is deprecated, use setTexture2D instead.\" );\n\t\t\t\twarned = true;\n\n\t\t\t}\n\n\t\t\ttextures.setTexture2D( texture, slot );\n\n\t\t};\n\n\t}() );\n\n\tthis.setTextureCube = ( function () {\n\n\t\tvar warned = false;\n\n\t\treturn function setTextureCube( texture, slot ) {\n\n\t\t\t// backwards compatibility: peel texture.texture\n\t\t\tif ( texture && texture.isWebGLRenderTargetCube ) {\n\n\t\t\t\tif ( ! warned ) {\n\n\t\t\t\t\tconsole.warn( \"THREE.WebGLRenderer.setTextureCube: don't use cube render targets as textures. Use their .texture property instead.\" );\n\t\t\t\t\twarned = true;\n\n\t\t\t\t}\n\n\t\t\t\ttexture = texture.texture;\n\n\t\t\t}\n\n\t\t\t// currently relying on the fact that WebGLRenderTargetCube.texture is a Texture and NOT a CubeTexture\n\t\t\t// TODO: unify these code paths\n\t\t\tif ( ( texture && texture.isCubeTexture ) ||\n\t\t\t\t( Array.isArray( texture.image ) && texture.image.length === 6 ) ) {\n\n\t\t\t\t// CompressedTexture can have Array in image :/\n\n\t\t\t\t// this function alone should take care of cube textures\n\t\t\t\ttextures.setTextureCube( texture, slot );\n\n\t\t\t} else {\n\n\t\t\t\t// assumed: texture property of THREE.WebGLRenderTargetCube\n\n\t\t\t\ttextures.setTextureCubeDynamic( texture, slot );\n\n\t\t\t}\n\n\t\t};\n\n\t}() );\n\n\tthis.getRenderTarget = function () {\n\n\t\treturn _currentRenderTarget;\n\n\t};\n\n\tthis.setRenderTarget = function ( renderTarget ) {\n\n\t\t_currentRenderTarget = renderTarget;\n\n\t\tif ( renderTarget && properties.get( renderTarget ).__webglFramebuffer === undefined ) {\n\n\t\t\ttextures.setupRenderTarget( renderTarget );\n\n\t\t}\n\n\t\tvar framebuffer = null;\n\t\tvar isCube = false;\n\n\t\tif ( renderTarget ) {\n\n\t\t\tvar __webglFramebuffer = properties.get( renderTarget ).__webglFramebuffer;\n\n\t\t\tif ( renderTarget.isWebGLRenderTargetCube ) {\n\n\t\t\t\tframebuffer = __webglFramebuffer[ renderTarget.activeCubeFace ];\n\t\t\t\tisCube = true;\n\n\t\t\t} else {\n\n\t\t\t\tframebuffer = __webglFramebuffer;\n\n\t\t\t}\n\n\t\t\t_currentViewport.copy( renderTarget.viewport );\n\t\t\t_currentScissor.copy( renderTarget.scissor );\n\t\t\t_currentScissorTest = renderTarget.scissorTest;\n\n\t\t} else {\n\n\t\t\t_currentViewport.copy( _viewport ).multiplyScalar( _pixelRatio );\n\t\t\t_currentScissor.copy( _scissor ).multiplyScalar( _pixelRatio );\n\t\t\t_currentScissorTest = _scissorTest;\n\n\t\t}\n\n\t\tif ( _currentFramebuffer !== framebuffer ) {\n\n\t\t\t_gl.bindFramebuffer( _gl.FRAMEBUFFER, framebuffer );\n\t\t\t_currentFramebuffer = framebuffer;\n\n\t\t}\n\n\t\tstate.viewport( _currentViewport );\n\t\tstate.scissor( _currentScissor );\n\t\tstate.setScissorTest( _currentScissorTest );\n\n\t\tif ( isCube ) {\n\n\t\t\tvar textureProperties = properties.get( renderTarget.texture );\n\t\t\t_gl.framebufferTexture2D( _gl.FRAMEBUFFER, _gl.COLOR_ATTACHMENT0, _gl.TEXTURE_CUBE_MAP_POSITIVE_X + renderTarget.activeCubeFace, textureProperties.__webglTexture, renderTarget.activeMipMapLevel );\n\n\t\t}\n\n\t};\n\n\tthis.readRenderTargetPixels = function ( renderTarget, x, y, width, height, buffer ) {\n\n\t\tif ( ! ( renderTarget && renderTarget.isWebGLRenderTarget ) ) {\n\n\t\t\tconsole.error( 'THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tvar framebuffer = properties.get( renderTarget ).__webglFramebuffer;\n\n\t\tif ( framebuffer ) {\n\n\t\t\tvar restore = false;\n\n\t\t\tif ( framebuffer !== _currentFramebuffer ) {\n\n\t\t\t\t_gl.bindFramebuffer( _gl.FRAMEBUFFER, framebuffer );\n\n\t\t\t\trestore = true;\n\n\t\t\t}\n\n\t\t\ttry {\n\n\t\t\t\tvar texture = renderTarget.texture;\n\t\t\t\tvar textureFormat = texture.format;\n\t\t\t\tvar textureType = texture.type;\n\n\t\t\t\tif ( textureFormat !== RGBAFormat && utils.convert( textureFormat ) !== _gl.getParameter( _gl.IMPLEMENTATION_COLOR_READ_FORMAT ) ) {\n\n\t\t\t\t\tconsole.error( 'THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format.' );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\tif ( textureType !== UnsignedByteType && utils.convert( textureType ) !== _gl.getParameter( _gl.IMPLEMENTATION_COLOR_READ_TYPE ) && // IE11, Edge and Chrome Mac < 52 (#9513)\n\t\t\t\t\t! ( textureType === FloatType && ( extensions.get( 'OES_texture_float' ) || extensions.get( 'WEBGL_color_buffer_float' ) ) ) && // Chrome Mac >= 52 and Firefox\n\t\t\t\t\t! ( textureType === HalfFloatType && extensions.get( 'EXT_color_buffer_half_float' ) ) ) {\n\n\t\t\t\t\tconsole.error( 'THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.' );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\tif ( _gl.checkFramebufferStatus( _gl.FRAMEBUFFER ) === _gl.FRAMEBUFFER_COMPLETE ) {\n\n\t\t\t\t\t// the following if statement ensures valid read requests (no out-of-bounds pixels, see #8604)\n\n\t\t\t\t\tif ( ( x >= 0 && x <= ( renderTarget.width - width ) ) && ( y >= 0 && y <= ( renderTarget.height - height ) ) ) {\n\n\t\t\t\t\t\t_gl.readPixels( x, y, width, height, utils.convert( textureFormat ), utils.convert( textureType ), buffer );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.error( 'THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete.' );\n\n\t\t\t\t}\n\n\t\t\t} finally {\n\n\t\t\t\tif ( restore ) {\n\n\t\t\t\t\t_gl.bindFramebuffer( _gl.FRAMEBUFFER, _currentFramebuffer );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t};\n\n\tthis.copyFramebufferToTexture = function ( position, texture, level ) {\n\n\t\tvar width = texture.image.width;\n\t\tvar height = texture.image.height;\n\t\tvar glFormat = utils.convert( texture.format );\n\n\t\tthis.setTexture2D( texture, 0 );\n\n\t\t_gl.copyTexImage2D( _gl.TEXTURE_2D, level || 0, glFormat, position.x, position.y, width, height, 0 );\n\n\t};\n\n\tthis.copyTextureToTexture = function ( position, srcTexture, dstTexture, level ) {\n\n\t\tvar width = srcTexture.image.width;\n\t\tvar height = srcTexture.image.height;\n\t\tvar glFormat = utils.convert( dstTexture.format );\n\t\tvar glType = utils.convert( dstTexture.type );\n\t\tvar pixels = srcTexture.isDataTexture ? srcTexture.image.data : srcTexture.image;\n\n\t\tthis.setTexture2D( dstTexture, 0 );\n\n\t\t_gl.texSubImage2D( _gl.TEXTURE_2D, level || 0, position.x, position.y, width, height, glFormat, glType, pixels );\n\n\t};\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction FogExp2( color, density ) {\n\n\tthis.name = '';\n\n\tthis.color = new Color( color );\n\tthis.density = ( density !== undefined ) ? density : 0.00025;\n\n}\n\nFogExp2.prototype.isFogExp2 = true;\n\nFogExp2.prototype.clone = function () {\n\n\treturn new FogExp2( this.color.getHex(), this.density );\n\n};\n\nFogExp2.prototype.toJSON = function ( /* meta */ ) {\n\n\treturn {\n\t\ttype: 'FogExp2',\n\t\tcolor: this.color.getHex(),\n\t\tdensity: this.density\n\t};\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction Fog( color, near, far ) {\n\n\tthis.name = '';\n\n\tthis.color = new Color( color );\n\n\tthis.near = ( near !== undefined ) ? near : 1;\n\tthis.far = ( far !== undefined ) ? far : 1000;\n\n}\n\nFog.prototype.isFog = true;\n\nFog.prototype.clone = function () {\n\n\treturn new Fog( this.color.getHex(), this.near, this.far );\n\n};\n\nFog.prototype.toJSON = function ( /* meta */ ) {\n\n\treturn {\n\t\ttype: 'Fog',\n\t\tcolor: this.color.getHex(),\n\t\tnear: this.near,\n\t\tfar: this.far\n\t};\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction Scene() {\n\n\tObject3D.call( this );\n\n\tthis.type = 'Scene';\n\n\tthis.background = null;\n\tthis.fog = null;\n\tthis.overrideMaterial = null;\n\n\tthis.autoUpdate = true; // checked by the renderer\n\n}\n\nScene.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Scene,\n\n\tcopy: function ( source, recursive ) {\n\n\t\tObject3D.prototype.copy.call( this, source, recursive );\n\n\t\tif ( source.background !== null ) this.background = source.background.clone();\n\t\tif ( source.fog !== null ) this.fog = source.fog.clone();\n\t\tif ( source.overrideMaterial !== null ) this.overrideMaterial = source.overrideMaterial.clone();\n\n\t\tthis.autoUpdate = source.autoUpdate;\n\t\tthis.matrixAutoUpdate = source.matrixAutoUpdate;\n\n\t\treturn this;\n\n\t},\n\n\ttoJSON: function ( meta ) {\n\n\t\tvar data = Object3D.prototype.toJSON.call( this, meta );\n\n\t\tif ( this.background !== null ) data.object.background = this.background.toJSON( meta );\n\t\tif ( this.fog !== null ) data.object.fog = this.fog.toJSON();\n\n\t\treturn data;\n\n\t}\n\n} );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n *\n * parameters = {\n *  color: <hex>,\n *  opacity: <float>,\n *  map: new THREE.Texture( <Image> ),\n *\n *\tuvOffset: new THREE.Vector2(),\n *\tuvScale: new THREE.Vector2()\n * }\n */\n\nfunction SpriteMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'SpriteMaterial';\n\n\tthis.color = new Color( 0xffffff );\n\tthis.map = null;\n\n\tthis.rotation = 0;\n\n\tthis.fog = false;\n\tthis.lights = false;\n\n\tthis.setValues( parameters );\n\n}\n\nSpriteMaterial.prototype = Object.create( Material.prototype );\nSpriteMaterial.prototype.constructor = SpriteMaterial;\nSpriteMaterial.prototype.isSpriteMaterial = true;\n\nSpriteMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.color.copy( source.color );\n\tthis.map = source.map;\n\n\tthis.rotation = source.rotation;\n\n\treturn this;\n\n};\n\n/**\n * @author mikael emtinger / http://gomo.se/\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction Sprite( material ) {\n\n\tObject3D.call( this );\n\n\tthis.type = 'Sprite';\n\n\tthis.material = ( material !== undefined ) ? material : new SpriteMaterial();\n\n\tthis.center = new Vector2( 0.5, 0.5 );\n\n}\n\nSprite.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Sprite,\n\n\tisSprite: true,\n\n\traycast: ( function () {\n\n\t\tvar intersectPoint = new Vector3();\n\t\tvar worldPosition = new Vector3();\n\t\tvar worldScale = new Vector3();\n\n\t\treturn function raycast( raycaster, intersects ) {\n\n\t\t\tworldPosition.setFromMatrixPosition( this.matrixWorld );\n\t\t\traycaster.ray.closestPointToPoint( worldPosition, intersectPoint );\n\n\t\t\tworldScale.setFromMatrixScale( this.matrixWorld );\n\t\t\tvar guessSizeSq = worldScale.x * worldScale.y / 4;\n\n\t\t\tif ( worldPosition.distanceToSquared( intersectPoint ) > guessSizeSq ) return;\n\n\t\t\tvar distance = raycaster.ray.origin.distanceTo( intersectPoint );\n\n\t\t\tif ( distance < raycaster.near || distance > raycaster.far ) return;\n\n\t\t\tintersects.push( {\n\n\t\t\t\tdistance: distance,\n\t\t\t\tpoint: intersectPoint.clone(),\n\t\t\t\tface: null,\n\t\t\t\tobject: this\n\n\t\t\t} );\n\n\t\t};\n\n\t}() ),\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.material ).copy( this );\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tObject3D.prototype.copy.call( this, source );\n\n\t\tif ( source.center !== undefined ) this.center.copy( source.center );\n\n\t\treturn this;\n\n\t}\n\n\n} );\n\n/**\n * @author mikael emtinger / http://gomo.se/\n * @author alteredq / http://alteredqualia.com/\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction LOD() {\n\n\tObject3D.call( this );\n\n\tthis.type = 'LOD';\n\n\tObject.defineProperties( this, {\n\t\tlevels: {\n\t\t\tenumerable: true,\n\t\t\tvalue: []\n\t\t}\n\t} );\n\n}\n\nLOD.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: LOD,\n\n\tcopy: function ( source ) {\n\n\t\tObject3D.prototype.copy.call( this, source, false );\n\n\t\tvar levels = source.levels;\n\n\t\tfor ( var i = 0, l = levels.length; i < l; i ++ ) {\n\n\t\t\tvar level = levels[ i ];\n\n\t\t\tthis.addLevel( level.object.clone(), level.distance );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\taddLevel: function ( object, distance ) {\n\n\t\tif ( distance === undefined ) distance = 0;\n\n\t\tdistance = Math.abs( distance );\n\n\t\tvar levels = this.levels;\n\n\t\tfor ( var l = 0; l < levels.length; l ++ ) {\n\n\t\t\tif ( distance < levels[ l ].distance ) {\n\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t\tlevels.splice( l, 0, { distance: distance, object: object } );\n\n\t\tthis.add( object );\n\n\t},\n\n\tgetObjectForDistance: function ( distance ) {\n\n\t\tvar levels = this.levels;\n\n\t\tfor ( var i = 1, l = levels.length; i < l; i ++ ) {\n\n\t\t\tif ( distance < levels[ i ].distance ) {\n\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn levels[ i - 1 ].object;\n\n\t},\n\n\traycast: ( function () {\n\n\t\tvar matrixPosition = new Vector3();\n\n\t\treturn function raycast( raycaster, intersects ) {\n\n\t\t\tmatrixPosition.setFromMatrixPosition( this.matrixWorld );\n\n\t\t\tvar distance = raycaster.ray.origin.distanceTo( matrixPosition );\n\n\t\t\tthis.getObjectForDistance( distance ).raycast( raycaster, intersects );\n\n\t\t};\n\n\t}() ),\n\n\tupdate: function () {\n\n\t\tvar v1 = new Vector3();\n\t\tvar v2 = new Vector3();\n\n\t\treturn function update( camera ) {\n\n\t\t\tvar levels = this.levels;\n\n\t\t\tif ( levels.length > 1 ) {\n\n\t\t\t\tv1.setFromMatrixPosition( camera.matrixWorld );\n\t\t\t\tv2.setFromMatrixPosition( this.matrixWorld );\n\n\t\t\t\tvar distance = v1.distanceTo( v2 );\n\n\t\t\t\tlevels[ 0 ].object.visible = true;\n\n\t\t\t\tfor ( var i = 1, l = levels.length; i < l; i ++ ) {\n\n\t\t\t\t\tif ( distance >= levels[ i ].distance ) {\n\n\t\t\t\t\t\tlevels[ i - 1 ].object.visible = false;\n\t\t\t\t\t\tlevels[ i ].object.visible = true;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tfor ( ; i < l; i ++ ) {\n\n\t\t\t\t\tlevels[ i ].object.visible = false;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t};\n\n\t}(),\n\n\ttoJSON: function ( meta ) {\n\n\t\tvar data = Object3D.prototype.toJSON.call( this, meta );\n\n\t\tdata.object.levels = [];\n\n\t\tvar levels = this.levels;\n\n\t\tfor ( var i = 0, l = levels.length; i < l; i ++ ) {\n\n\t\t\tvar level = levels[ i ];\n\n\t\t\tdata.object.levels.push( {\n\t\t\t\tobject: level.object.uuid,\n\t\t\t\tdistance: level.distance\n\t\t\t} );\n\n\t\t}\n\n\t\treturn data;\n\n\t}\n\n} );\n\n/**\n * @author mikael emtinger / http://gomo.se/\n * @author alteredq / http://alteredqualia.com/\n * @author michael guerrero / http://realitymeltdown.com\n * @author ikerr / http://verold.com\n */\n\nfunction Skeleton( bones, boneInverses ) {\n\n\t// copy the bone array\n\n\tbones = bones || [];\n\n\tthis.bones = bones.slice( 0 );\n\tthis.boneMatrices = new Float32Array( this.bones.length * 16 );\n\n\t// use the supplied bone inverses or calculate the inverses\n\n\tif ( boneInverses === undefined ) {\n\n\t\tthis.calculateInverses();\n\n\t} else {\n\n\t\tif ( this.bones.length === boneInverses.length ) {\n\n\t\t\tthis.boneInverses = boneInverses.slice( 0 );\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.Skeleton boneInverses is the wrong length.' );\n\n\t\t\tthis.boneInverses = [];\n\n\t\t\tfor ( var i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\t\tthis.boneInverses.push( new Matrix4() );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n}\n\nObject.assign( Skeleton.prototype, {\n\n\tcalculateInverses: function () {\n\n\t\tthis.boneInverses = [];\n\n\t\tfor ( var i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\tvar inverse = new Matrix4();\n\n\t\t\tif ( this.bones[ i ] ) {\n\n\t\t\t\tinverse.getInverse( this.bones[ i ].matrixWorld );\n\n\t\t\t}\n\n\t\t\tthis.boneInverses.push( inverse );\n\n\t\t}\n\n\t},\n\n\tpose: function () {\n\n\t\tvar bone, i, il;\n\n\t\t// recover the bind-time world matrices\n\n\t\tfor ( i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\tbone = this.bones[ i ];\n\n\t\t\tif ( bone ) {\n\n\t\t\t\tbone.matrixWorld.getInverse( this.boneInverses[ i ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// compute the local matrices, positions, rotations and scales\n\n\t\tfor ( i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\tbone = this.bones[ i ];\n\n\t\t\tif ( bone ) {\n\n\t\t\t\tif ( bone.parent && bone.parent.isBone ) {\n\n\t\t\t\t\tbone.matrix.getInverse( bone.parent.matrixWorld );\n\t\t\t\t\tbone.matrix.multiply( bone.matrixWorld );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tbone.matrix.copy( bone.matrixWorld );\n\n\t\t\t\t}\n\n\t\t\t\tbone.matrix.decompose( bone.position, bone.quaternion, bone.scale );\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\tupdate: ( function () {\n\n\t\tvar offsetMatrix = new Matrix4();\n\t\tvar identityMatrix = new Matrix4();\n\n\t\treturn function update() {\n\n\t\t\tvar bones = this.bones;\n\t\t\tvar boneInverses = this.boneInverses;\n\t\t\tvar boneMatrices = this.boneMatrices;\n\t\t\tvar boneTexture = this.boneTexture;\n\n\t\t\t// flatten bone matrices to array\n\n\t\t\tfor ( var i = 0, il = bones.length; i < il; i ++ ) {\n\n\t\t\t\t// compute the offset between the current and the original transform\n\n\t\t\t\tvar matrix = bones[ i ] ? bones[ i ].matrixWorld : identityMatrix;\n\n\t\t\t\toffsetMatrix.multiplyMatrices( matrix, boneInverses[ i ] );\n\t\t\t\toffsetMatrix.toArray( boneMatrices, i * 16 );\n\n\t\t\t}\n\n\t\t\tif ( boneTexture !== undefined ) {\n\n\t\t\t\tboneTexture.needsUpdate = true;\n\n\t\t\t}\n\n\t\t};\n\n\t} )(),\n\n\tclone: function () {\n\n\t\treturn new Skeleton( this.bones, this.boneInverses );\n\n\t},\n\n\tgetBoneByName: function ( name ) {\n\n\t\tfor ( var i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\tvar bone = this.bones[ i ];\n\n\t\t\tif ( bone.name === name ) {\n\n\t\t\t\treturn bone;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn undefined;\n\n\t}\n\n} );\n\n/**\n * @author mikael emtinger / http://gomo.se/\n * @author alteredq / http://alteredqualia.com/\n * @author ikerr / http://verold.com\n */\n\nfunction Bone() {\n\n\tObject3D.call( this );\n\n\tthis.type = 'Bone';\n\n}\n\nBone.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Bone,\n\n\tisBone: true\n\n} );\n\n/**\n * @author mikael emtinger / http://gomo.se/\n * @author alteredq / http://alteredqualia.com/\n * @author ikerr / http://verold.com\n */\n\nfunction SkinnedMesh( geometry, material ) {\n\n\tMesh.call( this, geometry, material );\n\n\tthis.type = 'SkinnedMesh';\n\n\tthis.bindMode = 'attached';\n\tthis.bindMatrix = new Matrix4();\n\tthis.bindMatrixInverse = new Matrix4();\n\n\tvar bones = this.initBones();\n\tvar skeleton = new Skeleton( bones );\n\n\tthis.bind( skeleton, this.matrixWorld );\n\n\tthis.normalizeSkinWeights();\n\n}\n\nSkinnedMesh.prototype = Object.assign( Object.create( Mesh.prototype ), {\n\n\tconstructor: SkinnedMesh,\n\n\tisSkinnedMesh: true,\n\n\tinitBones: function () {\n\n\t\tvar bones = [], bone, gbone;\n\t\tvar i, il;\n\n\t\tif ( this.geometry && this.geometry.bones !== undefined ) {\n\n\t\t\t// first, create array of 'Bone' objects from geometry data\n\n\t\t\tfor ( i = 0, il = this.geometry.bones.length; i < il; i ++ ) {\n\n\t\t\t\tgbone = this.geometry.bones[ i ];\n\n\t\t\t\t// create new 'Bone' object\n\n\t\t\t\tbone = new Bone();\n\t\t\t\tbones.push( bone );\n\n\t\t\t\t// apply values\n\n\t\t\t\tbone.name = gbone.name;\n\t\t\t\tbone.position.fromArray( gbone.pos );\n\t\t\t\tbone.quaternion.fromArray( gbone.rotq );\n\t\t\t\tif ( gbone.scl !== undefined ) bone.scale.fromArray( gbone.scl );\n\n\t\t\t}\n\n\t\t\t// second, create bone hierarchy\n\n\t\t\tfor ( i = 0, il = this.geometry.bones.length; i < il; i ++ ) {\n\n\t\t\t\tgbone = this.geometry.bones[ i ];\n\n\t\t\t\tif ( ( gbone.parent !== - 1 ) && ( gbone.parent !== null ) && ( bones[ gbone.parent ] !== undefined ) ) {\n\n\t\t\t\t\t// subsequent bones in the hierarchy\n\n\t\t\t\t\tbones[ gbone.parent ].add( bones[ i ] );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// topmost bone, immediate child of the skinned mesh\n\n\t\t\t\t\tthis.add( bones[ i ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t// now the bones are part of the scene graph and children of the skinned mesh.\n\t\t// let's update the corresponding matrices\n\n\t\tthis.updateMatrixWorld( true );\n\n\t\treturn bones;\n\n\t},\n\n\tbind: function ( skeleton, bindMatrix ) {\n\n\t\tthis.skeleton = skeleton;\n\n\t\tif ( bindMatrix === undefined ) {\n\n\t\t\tthis.updateMatrixWorld( true );\n\n\t\t\tthis.skeleton.calculateInverses();\n\n\t\t\tbindMatrix = this.matrixWorld;\n\n\t\t}\n\n\t\tthis.bindMatrix.copy( bindMatrix );\n\t\tthis.bindMatrixInverse.getInverse( bindMatrix );\n\n\t},\n\n\tpose: function () {\n\n\t\tthis.skeleton.pose();\n\n\t},\n\n\tnormalizeSkinWeights: function () {\n\n\t\tvar scale, i;\n\n\t\tif ( this.geometry && this.geometry.isGeometry ) {\n\n\t\t\tfor ( i = 0; i < this.geometry.skinWeights.length; i ++ ) {\n\n\t\t\t\tvar sw = this.geometry.skinWeights[ i ];\n\n\t\t\t\tscale = 1.0 / sw.manhattanLength();\n\n\t\t\t\tif ( scale !== Infinity ) {\n\n\t\t\t\t\tsw.multiplyScalar( scale );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tsw.set( 1, 0, 0, 0 ); // do something reasonable\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else if ( this.geometry && this.geometry.isBufferGeometry ) {\n\n\t\t\tvar vec = new Vector4();\n\n\t\t\tvar skinWeight = this.geometry.attributes.skinWeight;\n\n\t\t\tfor ( i = 0; i < skinWeight.count; i ++ ) {\n\n\t\t\t\tvec.x = skinWeight.getX( i );\n\t\t\t\tvec.y = skinWeight.getY( i );\n\t\t\t\tvec.z = skinWeight.getZ( i );\n\t\t\t\tvec.w = skinWeight.getW( i );\n\n\t\t\t\tscale = 1.0 / vec.manhattanLength();\n\n\t\t\t\tif ( scale !== Infinity ) {\n\n\t\t\t\t\tvec.multiplyScalar( scale );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tvec.set( 1, 0, 0, 0 ); // do something reasonable\n\n\t\t\t\t}\n\n\t\t\t\tskinWeight.setXYZW( i, vec.x, vec.y, vec.z, vec.w );\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\tupdateMatrixWorld: function ( force ) {\n\n\t\tMesh.prototype.updateMatrixWorld.call( this, force );\n\n\t\tif ( this.bindMode === 'attached' ) {\n\n\t\t\tthis.bindMatrixInverse.getInverse( this.matrixWorld );\n\n\t\t} else if ( this.bindMode === 'detached' ) {\n\n\t\t\tthis.bindMatrixInverse.getInverse( this.bindMatrix );\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.SkinnedMesh: Unrecognized bindMode: ' + this.bindMode );\n\n\t\t}\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.geometry, this.material ).copy( this );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n *\n * parameters = {\n *  color: <hex>,\n *  opacity: <float>,\n *\n *  linewidth: <float>,\n *  linecap: \"round\",\n *  linejoin: \"round\"\n * }\n */\n\nfunction LineBasicMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'LineBasicMaterial';\n\n\tthis.color = new Color( 0xffffff );\n\n\tthis.linewidth = 1;\n\tthis.linecap = 'round';\n\tthis.linejoin = 'round';\n\n\tthis.lights = false;\n\n\tthis.setValues( parameters );\n\n}\n\nLineBasicMaterial.prototype = Object.create( Material.prototype );\nLineBasicMaterial.prototype.constructor = LineBasicMaterial;\n\nLineBasicMaterial.prototype.isLineBasicMaterial = true;\n\nLineBasicMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.color.copy( source.color );\n\n\tthis.linewidth = source.linewidth;\n\tthis.linecap = source.linecap;\n\tthis.linejoin = source.linejoin;\n\n\treturn this;\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction Line( geometry, material, mode ) {\n\n\tif ( mode === 1 ) {\n\n\t\tconsole.warn( 'THREE.Line: parameter THREE.LinePieces no longer supported. Created THREE.LineSegments instead.' );\n\t\treturn new LineSegments( geometry, material );\n\n\t}\n\n\tObject3D.call( this );\n\n\tthis.type = 'Line';\n\n\tthis.geometry = geometry !== undefined ? geometry : new BufferGeometry();\n\tthis.material = material !== undefined ? material : new LineBasicMaterial( { color: Math.random() * 0xffffff } );\n\n}\n\nLine.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Line,\n\n\tisLine: true,\n\n\tcomputeLineDistances: ( function () {\n\n\t\tvar start = new Vector3();\n\t\tvar end = new Vector3();\n\n\t\treturn function computeLineDistances() {\n\n\t\t\tvar geometry = this.geometry;\n\n\t\t\tif ( geometry.isBufferGeometry ) {\n\n\t\t\t\t// we assume non-indexed geometry\n\n\t\t\t\tif ( geometry.index === null ) {\n\n\t\t\t\t\tvar positionAttribute = geometry.attributes.position;\n\t\t\t\t\tvar lineDistances = [ 0 ];\n\n\t\t\t\t\tfor ( var i = 1, l = positionAttribute.count; i < l; i ++ ) {\n\n\t\t\t\t\t\tstart.fromBufferAttribute( positionAttribute, i - 1 );\n\t\t\t\t\t\tend.fromBufferAttribute( positionAttribute, i );\n\n\t\t\t\t\t\tlineDistances[ i ] = lineDistances[ i - 1 ];\n\t\t\t\t\t\tlineDistances[ i ] += start.distanceTo( end );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tgeometry.addAttribute( 'lineDistance', new Float32BufferAttribute( lineDistances, 1 ) );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.warn( 'THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.' );\n\n\t\t\t\t}\n\n\t\t\t} else if ( geometry.isGeometry ) {\n\n\t\t\t\tvar vertices = geometry.vertices;\n\t\t\t\tvar lineDistances = geometry.lineDistances;\n\n\t\t\t\tlineDistances[ 0 ] = 0;\n\n\t\t\t\tfor ( var i = 1, l = vertices.length; i < l; i ++ ) {\n\n\t\t\t\t\tlineDistances[ i ] = lineDistances[ i - 1 ];\n\t\t\t\t\tlineDistances[ i ] += vertices[ i - 1 ].distanceTo( vertices[ i ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}() ),\n\n\traycast: ( function () {\n\n\t\tvar inverseMatrix = new Matrix4();\n\t\tvar ray = new Ray();\n\t\tvar sphere = new Sphere();\n\n\t\treturn function raycast( raycaster, intersects ) {\n\n\t\t\tvar precision = raycaster.linePrecision;\n\t\t\tvar precisionSq = precision * precision;\n\n\t\t\tvar geometry = this.geometry;\n\t\t\tvar matrixWorld = this.matrixWorld;\n\n\t\t\t// Checking boundingSphere distance to ray\n\n\t\t\tif ( geometry.boundingSphere === null ) geometry.computeBoundingSphere();\n\n\t\t\tsphere.copy( geometry.boundingSphere );\n\t\t\tsphere.applyMatrix4( matrixWorld );\n\n\t\t\tif ( raycaster.ray.intersectsSphere( sphere ) === false ) return;\n\n\t\t\t//\n\n\t\t\tinverseMatrix.getInverse( matrixWorld );\n\t\t\tray.copy( raycaster.ray ).applyMatrix4( inverseMatrix );\n\n\t\t\tvar vStart = new Vector3();\n\t\t\tvar vEnd = new Vector3();\n\t\t\tvar interSegment = new Vector3();\n\t\t\tvar interRay = new Vector3();\n\t\t\tvar step = ( this && this.isLineSegments ) ? 2 : 1;\n\n\t\t\tif ( geometry.isBufferGeometry ) {\n\n\t\t\t\tvar index = geometry.index;\n\t\t\t\tvar attributes = geometry.attributes;\n\t\t\t\tvar positions = attributes.position.array;\n\n\t\t\t\tif ( index !== null ) {\n\n\t\t\t\t\tvar indices = index.array;\n\n\t\t\t\t\tfor ( var i = 0, l = indices.length - 1; i < l; i += step ) {\n\n\t\t\t\t\t\tvar a = indices[ i ];\n\t\t\t\t\t\tvar b = indices[ i + 1 ];\n\n\t\t\t\t\t\tvStart.fromArray( positions, a * 3 );\n\t\t\t\t\t\tvEnd.fromArray( positions, b * 3 );\n\n\t\t\t\t\t\tvar distSq = ray.distanceSqToSegment( vStart, vEnd, interRay, interSegment );\n\n\t\t\t\t\t\tif ( distSq > precisionSq ) continue;\n\n\t\t\t\t\t\tinterRay.applyMatrix4( this.matrixWorld ); //Move back to world space for distance calculation\n\n\t\t\t\t\t\tvar distance = raycaster.ray.origin.distanceTo( interRay );\n\n\t\t\t\t\t\tif ( distance < raycaster.near || distance > raycaster.far ) continue;\n\n\t\t\t\t\t\tintersects.push( {\n\n\t\t\t\t\t\t\tdistance: distance,\n\t\t\t\t\t\t\t// What do we want? intersection point on the ray or on the segment??\n\t\t\t\t\t\t\t// point: raycaster.ray.at( distance ),\n\t\t\t\t\t\t\tpoint: interSegment.clone().applyMatrix4( this.matrixWorld ),\n\t\t\t\t\t\t\tindex: i,\n\t\t\t\t\t\t\tface: null,\n\t\t\t\t\t\t\tfaceIndex: null,\n\t\t\t\t\t\t\tobject: this\n\n\t\t\t\t\t\t} );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tfor ( var i = 0, l = positions.length / 3 - 1; i < l; i += step ) {\n\n\t\t\t\t\t\tvStart.fromArray( positions, 3 * i );\n\t\t\t\t\t\tvEnd.fromArray( positions, 3 * i + 3 );\n\n\t\t\t\t\t\tvar distSq = ray.distanceSqToSegment( vStart, vEnd, interRay, interSegment );\n\n\t\t\t\t\t\tif ( distSq > precisionSq ) continue;\n\n\t\t\t\t\t\tinterRay.applyMatrix4( this.matrixWorld ); //Move back to world space for distance calculation\n\n\t\t\t\t\t\tvar distance = raycaster.ray.origin.distanceTo( interRay );\n\n\t\t\t\t\t\tif ( distance < raycaster.near || distance > raycaster.far ) continue;\n\n\t\t\t\t\t\tintersects.push( {\n\n\t\t\t\t\t\t\tdistance: distance,\n\t\t\t\t\t\t\t// What do we want? intersection point on the ray or on the segment??\n\t\t\t\t\t\t\t// point: raycaster.ray.at( distance ),\n\t\t\t\t\t\t\tpoint: interSegment.clone().applyMatrix4( this.matrixWorld ),\n\t\t\t\t\t\t\tindex: i,\n\t\t\t\t\t\t\tface: null,\n\t\t\t\t\t\t\tfaceIndex: null,\n\t\t\t\t\t\t\tobject: this\n\n\t\t\t\t\t\t} );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else if ( geometry.isGeometry ) {\n\n\t\t\t\tvar vertices = geometry.vertices;\n\t\t\t\tvar nbVertices = vertices.length;\n\n\t\t\t\tfor ( var i = 0; i < nbVertices - 1; i += step ) {\n\n\t\t\t\t\tvar distSq = ray.distanceSqToSegment( vertices[ i ], vertices[ i + 1 ], interRay, interSegment );\n\n\t\t\t\t\tif ( distSq > precisionSq ) continue;\n\n\t\t\t\t\tinterRay.applyMatrix4( this.matrixWorld ); //Move back to world space for distance calculation\n\n\t\t\t\t\tvar distance = raycaster.ray.origin.distanceTo( interRay );\n\n\t\t\t\t\tif ( distance < raycaster.near || distance > raycaster.far ) continue;\n\n\t\t\t\t\tintersects.push( {\n\n\t\t\t\t\t\tdistance: distance,\n\t\t\t\t\t\t// What do we want? intersection point on the ray or on the segment??\n\t\t\t\t\t\t// point: raycaster.ray.at( distance ),\n\t\t\t\t\t\tpoint: interSegment.clone().applyMatrix4( this.matrixWorld ),\n\t\t\t\t\t\tindex: i,\n\t\t\t\t\t\tface: null,\n\t\t\t\t\t\tfaceIndex: null,\n\t\t\t\t\t\tobject: this\n\n\t\t\t\t\t} );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t};\n\n\t}() ),\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.geometry, this.material ).copy( this );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction LineSegments( geometry, material ) {\n\n\tLine.call( this, geometry, material );\n\n\tthis.type = 'LineSegments';\n\n}\n\nLineSegments.prototype = Object.assign( Object.create( Line.prototype ), {\n\n\tconstructor: LineSegments,\n\n\tisLineSegments: true,\n\n\tcomputeLineDistances: ( function () {\n\n\t\tvar start = new Vector3();\n\t\tvar end = new Vector3();\n\n\t\treturn function computeLineDistances() {\n\n\t\t\tvar geometry = this.geometry;\n\n\t\t\tif ( geometry.isBufferGeometry ) {\n\n\t\t\t\t// we assume non-indexed geometry\n\n\t\t\t\tif ( geometry.index === null ) {\n\n\t\t\t\t\tvar positionAttribute = geometry.attributes.position;\n\t\t\t\t\tvar lineDistances = [];\n\n\t\t\t\t\tfor ( var i = 0, l = positionAttribute.count; i < l; i += 2 ) {\n\n\t\t\t\t\t\tstart.fromBufferAttribute( positionAttribute, i );\n\t\t\t\t\t\tend.fromBufferAttribute( positionAttribute, i + 1 );\n\n\t\t\t\t\t\tlineDistances[ i ] = ( i === 0 ) ? 0 : lineDistances[ i - 1 ];\n\t\t\t\t\t\tlineDistances[ i + 1 ] = lineDistances[ i ] + start.distanceTo( end );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tgeometry.addAttribute( 'lineDistance', new Float32BufferAttribute( lineDistances, 1 ) );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.warn( 'THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.' );\n\n\t\t\t\t}\n\n\t\t\t} else if ( geometry.isGeometry ) {\n\n\t\t\t\tvar vertices = geometry.vertices;\n\t\t\t\tvar lineDistances = geometry.lineDistances;\n\n\t\t\t\tfor ( var i = 0, l = vertices.length; i < l; i += 2 ) {\n\n\t\t\t\t\tstart.copy( vertices[ i ] );\n\t\t\t\t\tend.copy( vertices[ i + 1 ] );\n\n\t\t\t\t\tlineDistances[ i ] = ( i === 0 ) ? 0 : lineDistances[ i - 1 ];\n\t\t\t\t\tlineDistances[ i + 1 ] = lineDistances[ i ] + start.distanceTo( end );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}() )\n\n} );\n\n/**\n * @author mgreter / http://github.com/mgreter\n */\n\nfunction LineLoop( geometry, material ) {\n\n\tLine.call( this, geometry, material );\n\n\tthis.type = 'LineLoop';\n\n}\n\nLineLoop.prototype = Object.assign( Object.create( Line.prototype ), {\n\n\tconstructor: LineLoop,\n\n\tisLineLoop: true,\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n *\n * parameters = {\n *  color: <hex>,\n *  opacity: <float>,\n *  map: new THREE.Texture( <Image> ),\n *\n *  size: <float>,\n *  sizeAttenuation: <bool>\n * }\n */\n\nfunction PointsMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'PointsMaterial';\n\n\tthis.color = new Color( 0xffffff );\n\n\tthis.map = null;\n\n\tthis.size = 1;\n\tthis.sizeAttenuation = true;\n\n\tthis.lights = false;\n\n\tthis.setValues( parameters );\n\n}\n\nPointsMaterial.prototype = Object.create( Material.prototype );\nPointsMaterial.prototype.constructor = PointsMaterial;\n\nPointsMaterial.prototype.isPointsMaterial = true;\n\nPointsMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.color.copy( source.color );\n\n\tthis.map = source.map;\n\n\tthis.size = source.size;\n\tthis.sizeAttenuation = source.sizeAttenuation;\n\n\treturn this;\n\n};\n\n/**\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction Points( geometry, material ) {\n\n\tObject3D.call( this );\n\n\tthis.type = 'Points';\n\n\tthis.geometry = geometry !== undefined ? geometry : new BufferGeometry();\n\tthis.material = material !== undefined ? material : new PointsMaterial( { color: Math.random() * 0xffffff } );\n\n}\n\nPoints.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Points,\n\n\tisPoints: true,\n\n\traycast: ( function () {\n\n\t\tvar inverseMatrix = new Matrix4();\n\t\tvar ray = new Ray();\n\t\tvar sphere = new Sphere();\n\n\t\treturn function raycast( raycaster, intersects ) {\n\n\t\t\tvar object = this;\n\t\t\tvar geometry = this.geometry;\n\t\t\tvar matrixWorld = this.matrixWorld;\n\t\t\tvar threshold = raycaster.params.Points.threshold;\n\n\t\t\t// Checking boundingSphere distance to ray\n\n\t\t\tif ( geometry.boundingSphere === null ) geometry.computeBoundingSphere();\n\n\t\t\tsphere.copy( geometry.boundingSphere );\n\t\t\tsphere.applyMatrix4( matrixWorld );\n\t\t\tsphere.radius += threshold;\n\n\t\t\tif ( raycaster.ray.intersectsSphere( sphere ) === false ) return;\n\n\t\t\t//\n\n\t\t\tinverseMatrix.getInverse( matrixWorld );\n\t\t\tray.copy( raycaster.ray ).applyMatrix4( inverseMatrix );\n\n\t\t\tvar localThreshold = threshold / ( ( this.scale.x + this.scale.y + this.scale.z ) / 3 );\n\t\t\tvar localThresholdSq = localThreshold * localThreshold;\n\t\t\tvar position = new Vector3();\n\t\t\tvar intersectPoint = new Vector3();\n\n\t\t\tfunction testPoint( point, index ) {\n\n\t\t\t\tvar rayPointDistanceSq = ray.distanceSqToPoint( point );\n\n\t\t\t\tif ( rayPointDistanceSq < localThresholdSq ) {\n\n\t\t\t\t\tray.closestPointToPoint( point, intersectPoint );\n\t\t\t\t\tintersectPoint.applyMatrix4( matrixWorld );\n\n\t\t\t\t\tvar distance = raycaster.ray.origin.distanceTo( intersectPoint );\n\n\t\t\t\t\tif ( distance < raycaster.near || distance > raycaster.far ) return;\n\n\t\t\t\t\tintersects.push( {\n\n\t\t\t\t\t\tdistance: distance,\n\t\t\t\t\t\tdistanceToRay: Math.sqrt( rayPointDistanceSq ),\n\t\t\t\t\t\tpoint: intersectPoint.clone(),\n\t\t\t\t\t\tindex: index,\n\t\t\t\t\t\tface: null,\n\t\t\t\t\t\tobject: object\n\n\t\t\t\t\t} );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( geometry.isBufferGeometry ) {\n\n\t\t\t\tvar index = geometry.index;\n\t\t\t\tvar attributes = geometry.attributes;\n\t\t\t\tvar positions = attributes.position.array;\n\n\t\t\t\tif ( index !== null ) {\n\n\t\t\t\t\tvar indices = index.array;\n\n\t\t\t\t\tfor ( var i = 0, il = indices.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tvar a = indices[ i ];\n\n\t\t\t\t\t\tposition.fromArray( positions, a * 3 );\n\n\t\t\t\t\t\ttestPoint( position, a );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tfor ( var i = 0, l = positions.length / 3; i < l; i ++ ) {\n\n\t\t\t\t\t\tposition.fromArray( positions, i * 3 );\n\n\t\t\t\t\t\ttestPoint( position, i );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tvar vertices = geometry.vertices;\n\n\t\t\t\tfor ( var i = 0, l = vertices.length; i < l; i ++ ) {\n\n\t\t\t\t\ttestPoint( vertices[ i ], i );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t};\n\n\t}() ),\n\n\tclone: function () {\n\n\t\treturn new this.constructor( this.geometry, this.material ).copy( this );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction Group() {\n\n\tObject3D.call( this );\n\n\tthis.type = 'Group';\n\n}\n\nGroup.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Group,\n\n\tisGroup: true\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction VideoTexture( video, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy ) {\n\n\tTexture.call( this, video, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy );\n\n\tthis.generateMipmaps = false;\n\n}\n\nVideoTexture.prototype = Object.assign( Object.create( Texture.prototype ), {\n\n\tconstructor: VideoTexture,\n\n\tisVideoTexture: true,\n\n\tupdate: function () {\n\n\t\tvar video = this.image;\n\n\t\tif ( video.readyState >= video.HAVE_CURRENT_DATA ) {\n\n\t\t\tthis.needsUpdate = true;\n\n\t\t}\n\n\t}\n\n} );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction CompressedTexture( mipmaps, width, height, format, type, mapping, wrapS, wrapT, magFilter, minFilter, anisotropy, encoding ) {\n\n\tTexture.call( this, null, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding );\n\n\tthis.image = { width: width, height: height };\n\tthis.mipmaps = mipmaps;\n\n\t// no flipping for cube textures\n\t// (also flipping doesn't work for compressed textures )\n\n\tthis.flipY = false;\n\n\t// can't generate mipmaps for compressed textures\n\t// mips must be embedded in DDS files\n\n\tthis.generateMipmaps = false;\n\n}\n\nCompressedTexture.prototype = Object.create( Texture.prototype );\nCompressedTexture.prototype.constructor = CompressedTexture;\n\nCompressedTexture.prototype.isCompressedTexture = true;\n\n/**\n * @author Matt DesLauriers / @mattdesl\n * @author atix / arthursilber.de\n */\n\nfunction DepthTexture( width, height, type, mapping, wrapS, wrapT, magFilter, minFilter, anisotropy, format ) {\n\n\tformat = format !== undefined ? format : DepthFormat;\n\n\tif ( format !== DepthFormat && format !== DepthStencilFormat ) {\n\n\t\tthrow new Error( 'DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat' );\n\n\t}\n\n\tif ( type === undefined && format === DepthFormat ) type = UnsignedShortType;\n\tif ( type === undefined && format === DepthStencilFormat ) type = UnsignedInt248Type;\n\n\tTexture.call( this, null, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy );\n\n\tthis.image = { width: width, height: height };\n\n\tthis.magFilter = magFilter !== undefined ? magFilter : NearestFilter;\n\tthis.minFilter = minFilter !== undefined ? minFilter : NearestFilter;\n\n\tthis.flipY = false;\n\tthis.generateMipmaps\t= false;\n\n}\n\nDepthTexture.prototype = Object.create( Texture.prototype );\nDepthTexture.prototype.constructor = DepthTexture;\nDepthTexture.prototype.isDepthTexture = true;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author Mugen87 / https://github.com/Mugen87\n */\n\nfunction WireframeGeometry( geometry ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'WireframeGeometry';\n\n\t// buffer\n\n\tvar vertices = [];\n\n\t// helper variables\n\n\tvar i, j, l, o, ol;\n\tvar edge = [ 0, 0 ], edges = {}, e, edge1, edge2;\n\tvar key, keys = [ 'a', 'b', 'c' ];\n\tvar vertex;\n\n\t// different logic for Geometry and BufferGeometry\n\n\tif ( geometry && geometry.isGeometry ) {\n\n\t\t// create a data structure that contains all edges without duplicates\n\n\t\tvar faces = geometry.faces;\n\n\t\tfor ( i = 0, l = faces.length; i < l; i ++ ) {\n\n\t\t\tvar face = faces[ i ];\n\n\t\t\tfor ( j = 0; j < 3; j ++ ) {\n\n\t\t\t\tedge1 = face[ keys[ j ] ];\n\t\t\t\tedge2 = face[ keys[ ( j + 1 ) % 3 ] ];\n\t\t\t\tedge[ 0 ] = Math.min( edge1, edge2 ); // sorting prevents duplicates\n\t\t\t\tedge[ 1 ] = Math.max( edge1, edge2 );\n\n\t\t\t\tkey = edge[ 0 ] + ',' + edge[ 1 ];\n\n\t\t\t\tif ( edges[ key ] === undefined ) {\n\n\t\t\t\t\tedges[ key ] = { index1: edge[ 0 ], index2: edge[ 1 ] };\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t// generate vertices\n\n\t\tfor ( key in edges ) {\n\n\t\t\te = edges[ key ];\n\n\t\t\tvertex = geometry.vertices[ e.index1 ];\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\tvertex = geometry.vertices[ e.index2 ];\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t}\n\n\t} else if ( geometry && geometry.isBufferGeometry ) {\n\n\t\tvar position, indices, groups;\n\t\tvar group, start, count;\n\t\tvar index1, index2;\n\n\t\tvertex = new Vector3();\n\n\t\tif ( geometry.index !== null ) {\n\n\t\t\t// indexed BufferGeometry\n\n\t\t\tposition = geometry.attributes.position;\n\t\t\tindices = geometry.index;\n\t\t\tgroups = geometry.groups;\n\n\t\t\tif ( groups.length === 0 ) {\n\n\t\t\t\tgroups = [ { start: 0, count: indices.count, materialIndex: 0 } ];\n\n\t\t\t}\n\n\t\t\t// create a data structure that contains all eges without duplicates\n\n\t\t\tfor ( o = 0, ol = groups.length; o < ol; ++ o ) {\n\n\t\t\t\tgroup = groups[ o ];\n\n\t\t\t\tstart = group.start;\n\t\t\t\tcount = group.count;\n\n\t\t\t\tfor ( i = start, l = ( start + count ); i < l; i += 3 ) {\n\n\t\t\t\t\tfor ( j = 0; j < 3; j ++ ) {\n\n\t\t\t\t\t\tedge1 = indices.getX( i + j );\n\t\t\t\t\t\tedge2 = indices.getX( i + ( j + 1 ) % 3 );\n\t\t\t\t\t\tedge[ 0 ] = Math.min( edge1, edge2 ); // sorting prevents duplicates\n\t\t\t\t\t\tedge[ 1 ] = Math.max( edge1, edge2 );\n\n\t\t\t\t\t\tkey = edge[ 0 ] + ',' + edge[ 1 ];\n\n\t\t\t\t\t\tif ( edges[ key ] === undefined ) {\n\n\t\t\t\t\t\t\tedges[ key ] = { index1: edge[ 0 ], index2: edge[ 1 ] };\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// generate vertices\n\n\t\t\tfor ( key in edges ) {\n\n\t\t\t\te = edges[ key ];\n\n\t\t\t\tvertex.fromBufferAttribute( position, e.index1 );\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\tvertex.fromBufferAttribute( position, e.index2 );\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// non-indexed BufferGeometry\n\n\t\t\tposition = geometry.attributes.position;\n\n\t\t\tfor ( i = 0, l = ( position.count / 3 ); i < l; i ++ ) {\n\n\t\t\t\tfor ( j = 0; j < 3; j ++ ) {\n\n\t\t\t\t\t// three edges per triangle, an edge is represented as (index1, index2)\n\t\t\t\t\t// e.g. the first triangle has the following edges: (0,1),(1,2),(2,0)\n\n\t\t\t\t\tindex1 = 3 * i + j;\n\t\t\t\t\tvertex.fromBufferAttribute( position, index1 );\n\t\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t\tindex2 = 3 * i + ( ( j + 1 ) % 3 );\n\t\t\t\t\tvertex.fromBufferAttribute( position, index2 );\n\t\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\n}\n\nWireframeGeometry.prototype = Object.create( BufferGeometry.prototype );\nWireframeGeometry.prototype.constructor = WireframeGeometry;\n\n/**\n * @author zz85 / https://github.com/zz85\n * @author Mugen87 / https://github.com/Mugen87\n *\n * Parametric Surfaces Geometry\n * based on the brilliant article by @prideout http://prideout.net/blog/?p=44\n */\n\n// ParametricGeometry\n\nfunction ParametricGeometry( func, slices, stacks ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'ParametricGeometry';\n\n\tthis.parameters = {\n\t\tfunc: func,\n\t\tslices: slices,\n\t\tstacks: stacks\n\t};\n\n\tthis.fromBufferGeometry( new ParametricBufferGeometry( func, slices, stacks ) );\n\tthis.mergeVertices();\n\n}\n\nParametricGeometry.prototype = Object.create( Geometry.prototype );\nParametricGeometry.prototype.constructor = ParametricGeometry;\n\n// ParametricBufferGeometry\n\nfunction ParametricBufferGeometry( func, slices, stacks ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'ParametricBufferGeometry';\n\n\tthis.parameters = {\n\t\tfunc: func,\n\t\tslices: slices,\n\t\tstacks: stacks\n\t};\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\tvar EPS = 0.00001;\n\n\tvar normal = new Vector3();\n\n\tvar p0 = new Vector3(), p1 = new Vector3();\n\tvar pu = new Vector3(), pv = new Vector3();\n\n\tvar i, j;\n\n\t// generate vertices, normals and uvs\n\n\tvar sliceCount = slices + 1;\n\n\tfor ( i = 0; i <= stacks; i ++ ) {\n\n\t\tvar v = i / stacks;\n\n\t\tfor ( j = 0; j <= slices; j ++ ) {\n\n\t\t\tvar u = j / slices;\n\n\t\t\t// vertex\n\n\t\t\tfunc( u, v, p0 );\n\t\t\tvertices.push( p0.x, p0.y, p0.z );\n\n\t\t\t// normal\n\n\t\t\t// approximate tangent vectors via finite differences\n\n\t\t\tif ( u - EPS >= 0 ) {\n\n\t\t\t\tfunc( u - EPS, v, p1 );\n\t\t\t\tpu.subVectors( p0, p1 );\n\n\t\t\t} else {\n\n\t\t\t\tfunc( u + EPS, v, p1 );\n\t\t\t\tpu.subVectors( p1, p0 );\n\n\t\t\t}\n\n\t\t\tif ( v - EPS >= 0 ) {\n\n\t\t\t\tfunc( u, v - EPS, p1 );\n\t\t\t\tpv.subVectors( p0, p1 );\n\n\t\t\t} else {\n\n\t\t\t\tfunc( u, v + EPS, p1 );\n\t\t\t\tpv.subVectors( p1, p0 );\n\n\t\t\t}\n\n\t\t\t// cross product of tangent vectors returns surface normal\n\n\t\t\tnormal.crossVectors( pu, pv ).normalize();\n\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t// uv\n\n\t\t\tuvs.push( u, v );\n\n\t\t}\n\n\t}\n\n\t// generate indices\n\n\tfor ( i = 0; i < stacks; i ++ ) {\n\n\t\tfor ( j = 0; j < slices; j ++ ) {\n\n\t\t\tvar a = i * sliceCount + j;\n\t\t\tvar b = i * sliceCount + j + 1;\n\t\t\tvar c = ( i + 1 ) * sliceCount + j + 1;\n\t\t\tvar d = ( i + 1 ) * sliceCount + j;\n\n\t\t\t// faces one and two\n\n\t\t\tindices.push( a, b, d );\n\t\t\tindices.push( b, c, d );\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n}\n\nParametricBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nParametricBufferGeometry.prototype.constructor = ParametricBufferGeometry;\n\n/**\n * @author clockworkgeek / https://github.com/clockworkgeek\n * @author timothypratley / https://github.com/timothypratley\n * @author WestLangley / http://github.com/WestLangley\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// PolyhedronGeometry\n\nfunction PolyhedronGeometry( vertices, indices, radius, detail ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'PolyhedronGeometry';\n\n\tthis.parameters = {\n\t\tvertices: vertices,\n\t\tindices: indices,\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n\tthis.fromBufferGeometry( new PolyhedronBufferGeometry( vertices, indices, radius, detail ) );\n\tthis.mergeVertices();\n\n}\n\nPolyhedronGeometry.prototype = Object.create( Geometry.prototype );\nPolyhedronGeometry.prototype.constructor = PolyhedronGeometry;\n\n// PolyhedronBufferGeometry\n\nfunction PolyhedronBufferGeometry( vertices, indices, radius, detail ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'PolyhedronBufferGeometry';\n\n\tthis.parameters = {\n\t\tvertices: vertices,\n\t\tindices: indices,\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n\tradius = radius || 1;\n\tdetail = detail || 0;\n\n\t// default buffer data\n\n\tvar vertexBuffer = [];\n\tvar uvBuffer = [];\n\n\t// the subdivision creates the vertex buffer data\n\n\tsubdivide( detail );\n\n\t// all vertices should lie on a conceptual sphere with a given radius\n\n\tappplyRadius( radius );\n\n\t// finally, create the uv data\n\n\tgenerateUVs();\n\n\t// build non-indexed geometry\n\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertexBuffer, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( vertexBuffer.slice(), 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvBuffer, 2 ) );\n\n\tif ( detail === 0 ) {\n\n\t\tthis.computeVertexNormals(); // flat normals\n\n\t} else {\n\n\t\tthis.normalizeNormals(); // smooth normals\n\n\t}\n\n\t// helper functions\n\n\tfunction subdivide( detail ) {\n\n\t\tvar a = new Vector3();\n\t\tvar b = new Vector3();\n\t\tvar c = new Vector3();\n\n\t\t// iterate over all faces and apply a subdivison with the given detail value\n\n\t\tfor ( var i = 0; i < indices.length; i += 3 ) {\n\n\t\t\t// get the vertices of the face\n\n\t\t\tgetVertexByIndex( indices[ i + 0 ], a );\n\t\t\tgetVertexByIndex( indices[ i + 1 ], b );\n\t\t\tgetVertexByIndex( indices[ i + 2 ], c );\n\n\t\t\t// perform subdivision\n\n\t\t\tsubdivideFace( a, b, c, detail );\n\n\t\t}\n\n\t}\n\n\tfunction subdivideFace( a, b, c, detail ) {\n\n\t\tvar cols = Math.pow( 2, detail );\n\n\t\t// we use this multidimensional array as a data structure for creating the subdivision\n\n\t\tvar v = [];\n\n\t\tvar i, j;\n\n\t\t// construct all of the vertices for this subdivision\n\n\t\tfor ( i = 0; i <= cols; i ++ ) {\n\n\t\t\tv[ i ] = [];\n\n\t\t\tvar aj = a.clone().lerp( c, i / cols );\n\t\t\tvar bj = b.clone().lerp( c, i / cols );\n\n\t\t\tvar rows = cols - i;\n\n\t\t\tfor ( j = 0; j <= rows; j ++ ) {\n\n\t\t\t\tif ( j === 0 && i === cols ) {\n\n\t\t\t\t\tv[ i ][ j ] = aj;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tv[ i ][ j ] = aj.clone().lerp( bj, j / rows );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t// construct all of the faces\n\n\t\tfor ( i = 0; i < cols; i ++ ) {\n\n\t\t\tfor ( j = 0; j < 2 * ( cols - i ) - 1; j ++ ) {\n\n\t\t\t\tvar k = Math.floor( j / 2 );\n\n\t\t\t\tif ( j % 2 === 0 ) {\n\n\t\t\t\t\tpushVertex( v[ i ][ k + 1 ] );\n\t\t\t\t\tpushVertex( v[ i + 1 ][ k ] );\n\t\t\t\t\tpushVertex( v[ i ][ k ] );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tpushVertex( v[ i ][ k + 1 ] );\n\t\t\t\t\tpushVertex( v[ i + 1 ][ k + 1 ] );\n\t\t\t\t\tpushVertex( v[ i + 1 ][ k ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction appplyRadius( radius ) {\n\n\t\tvar vertex = new Vector3();\n\n\t\t// iterate over the entire buffer and apply the radius to each vertex\n\n\t\tfor ( var i = 0; i < vertexBuffer.length; i += 3 ) {\n\n\t\t\tvertex.x = vertexBuffer[ i + 0 ];\n\t\t\tvertex.y = vertexBuffer[ i + 1 ];\n\t\t\tvertex.z = vertexBuffer[ i + 2 ];\n\n\t\t\tvertex.normalize().multiplyScalar( radius );\n\n\t\t\tvertexBuffer[ i + 0 ] = vertex.x;\n\t\t\tvertexBuffer[ i + 1 ] = vertex.y;\n\t\t\tvertexBuffer[ i + 2 ] = vertex.z;\n\n\t\t}\n\n\t}\n\n\tfunction generateUVs() {\n\n\t\tvar vertex = new Vector3();\n\n\t\tfor ( var i = 0; i < vertexBuffer.length; i += 3 ) {\n\n\t\t\tvertex.x = vertexBuffer[ i + 0 ];\n\t\t\tvertex.y = vertexBuffer[ i + 1 ];\n\t\t\tvertex.z = vertexBuffer[ i + 2 ];\n\n\t\t\tvar u = azimuth( vertex ) / 2 / Math.PI + 0.5;\n\t\t\tvar v = inclination( vertex ) / Math.PI + 0.5;\n\t\t\tuvBuffer.push( u, 1 - v );\n\n\t\t}\n\n\t\tcorrectUVs();\n\n\t\tcorrectSeam();\n\n\t}\n\n\tfunction correctSeam() {\n\n\t\t// handle case when face straddles the seam, see #3269\n\n\t\tfor ( var i = 0; i < uvBuffer.length; i += 6 ) {\n\n\t\t\t// uv data of a single face\n\n\t\t\tvar x0 = uvBuffer[ i + 0 ];\n\t\t\tvar x1 = uvBuffer[ i + 2 ];\n\t\t\tvar x2 = uvBuffer[ i + 4 ];\n\n\t\t\tvar max = Math.max( x0, x1, x2 );\n\t\t\tvar min = Math.min( x0, x1, x2 );\n\n\t\t\t// 0.9 is somewhat arbitrary\n\n\t\t\tif ( max > 0.9 && min < 0.1 ) {\n\n\t\t\t\tif ( x0 < 0.2 ) uvBuffer[ i + 0 ] += 1;\n\t\t\t\tif ( x1 < 0.2 ) uvBuffer[ i + 2 ] += 1;\n\t\t\t\tif ( x2 < 0.2 ) uvBuffer[ i + 4 ] += 1;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction pushVertex( vertex ) {\n\n\t\tvertexBuffer.push( vertex.x, vertex.y, vertex.z );\n\n\t}\n\n\tfunction getVertexByIndex( index, vertex ) {\n\n\t\tvar stride = index * 3;\n\n\t\tvertex.x = vertices[ stride + 0 ];\n\t\tvertex.y = vertices[ stride + 1 ];\n\t\tvertex.z = vertices[ stride + 2 ];\n\n\t}\n\n\tfunction correctUVs() {\n\n\t\tvar a = new Vector3();\n\t\tvar b = new Vector3();\n\t\tvar c = new Vector3();\n\n\t\tvar centroid = new Vector3();\n\n\t\tvar uvA = new Vector2();\n\t\tvar uvB = new Vector2();\n\t\tvar uvC = new Vector2();\n\n\t\tfor ( var i = 0, j = 0; i < vertexBuffer.length; i += 9, j += 6 ) {\n\n\t\t\ta.set( vertexBuffer[ i + 0 ], vertexBuffer[ i + 1 ], vertexBuffer[ i + 2 ] );\n\t\t\tb.set( vertexBuffer[ i + 3 ], vertexBuffer[ i + 4 ], vertexBuffer[ i + 5 ] );\n\t\t\tc.set( vertexBuffer[ i + 6 ], vertexBuffer[ i + 7 ], vertexBuffer[ i + 8 ] );\n\n\t\t\tuvA.set( uvBuffer[ j + 0 ], uvBuffer[ j + 1 ] );\n\t\t\tuvB.set( uvBuffer[ j + 2 ], uvBuffer[ j + 3 ] );\n\t\t\tuvC.set( uvBuffer[ j + 4 ], uvBuffer[ j + 5 ] );\n\n\t\t\tcentroid.copy( a ).add( b ).add( c ).divideScalar( 3 );\n\n\t\t\tvar azi = azimuth( centroid );\n\n\t\t\tcorrectUV( uvA, j + 0, a, azi );\n\t\t\tcorrectUV( uvB, j + 2, b, azi );\n\t\t\tcorrectUV( uvC, j + 4, c, azi );\n\n\t\t}\n\n\t}\n\n\tfunction correctUV( uv, stride, vector, azimuth ) {\n\n\t\tif ( ( azimuth < 0 ) && ( uv.x === 1 ) ) {\n\n\t\t\tuvBuffer[ stride ] = uv.x - 1;\n\n\t\t}\n\n\t\tif ( ( vector.x === 0 ) && ( vector.z === 0 ) ) {\n\n\t\t\tuvBuffer[ stride ] = azimuth / 2 / Math.PI + 0.5;\n\n\t\t}\n\n\t}\n\n\t// Angle around the Y axis, counter-clockwise when looking from above.\n\n\tfunction azimuth( vector ) {\n\n\t\treturn Math.atan2( vector.z, - vector.x );\n\n\t}\n\n\n\t// Angle above the XZ plane.\n\n\tfunction inclination( vector ) {\n\n\t\treturn Math.atan2( - vector.y, Math.sqrt( ( vector.x * vector.x ) + ( vector.z * vector.z ) ) );\n\n\t}\n\n}\n\nPolyhedronBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nPolyhedronBufferGeometry.prototype.constructor = PolyhedronBufferGeometry;\n\n/**\n * @author timothypratley / https://github.com/timothypratley\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// TetrahedronGeometry\n\nfunction TetrahedronGeometry( radius, detail ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'TetrahedronGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n\tthis.fromBufferGeometry( new TetrahedronBufferGeometry( radius, detail ) );\n\tthis.mergeVertices();\n\n}\n\nTetrahedronGeometry.prototype = Object.create( Geometry.prototype );\nTetrahedronGeometry.prototype.constructor = TetrahedronGeometry;\n\n// TetrahedronBufferGeometry\n\nfunction TetrahedronBufferGeometry( radius, detail ) {\n\n\tvar vertices = [\n\t\t1, 1, 1, \t- 1, - 1, 1, \t- 1, 1, - 1, \t1, - 1, - 1\n\t];\n\n\tvar indices = [\n\t\t2, 1, 0, \t0, 3, 2,\t1, 3, 0,\t2, 3, 1\n\t];\n\n\tPolyhedronBufferGeometry.call( this, vertices, indices, radius, detail );\n\n\tthis.type = 'TetrahedronBufferGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n}\n\nTetrahedronBufferGeometry.prototype = Object.create( PolyhedronBufferGeometry.prototype );\nTetrahedronBufferGeometry.prototype.constructor = TetrahedronBufferGeometry;\n\n/**\n * @author timothypratley / https://github.com/timothypratley\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// OctahedronGeometry\n\nfunction OctahedronGeometry( radius, detail ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'OctahedronGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n\tthis.fromBufferGeometry( new OctahedronBufferGeometry( radius, detail ) );\n\tthis.mergeVertices();\n\n}\n\nOctahedronGeometry.prototype = Object.create( Geometry.prototype );\nOctahedronGeometry.prototype.constructor = OctahedronGeometry;\n\n// OctahedronBufferGeometry\n\nfunction OctahedronBufferGeometry( radius, detail ) {\n\n\tvar vertices = [\n\t\t1, 0, 0, \t- 1, 0, 0,\t0, 1, 0,\n\t\t0, - 1, 0, \t0, 0, 1,\t0, 0, - 1\n\t];\n\n\tvar indices = [\n\t\t0, 2, 4,\t0, 4, 3,\t0, 3, 5,\n\t\t0, 5, 2,\t1, 2, 5,\t1, 5, 3,\n\t\t1, 3, 4,\t1, 4, 2\n\t];\n\n\tPolyhedronBufferGeometry.call( this, vertices, indices, radius, detail );\n\n\tthis.type = 'OctahedronBufferGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n}\n\nOctahedronBufferGeometry.prototype = Object.create( PolyhedronBufferGeometry.prototype );\nOctahedronBufferGeometry.prototype.constructor = OctahedronBufferGeometry;\n\n/**\n * @author timothypratley / https://github.com/timothypratley\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// IcosahedronGeometry\n\nfunction IcosahedronGeometry( radius, detail ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'IcosahedronGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n\tthis.fromBufferGeometry( new IcosahedronBufferGeometry( radius, detail ) );\n\tthis.mergeVertices();\n\n}\n\nIcosahedronGeometry.prototype = Object.create( Geometry.prototype );\nIcosahedronGeometry.prototype.constructor = IcosahedronGeometry;\n\n// IcosahedronBufferGeometry\n\nfunction IcosahedronBufferGeometry( radius, detail ) {\n\n\tvar t = ( 1 + Math.sqrt( 5 ) ) / 2;\n\n\tvar vertices = [\n\t\t- 1, t, 0, \t1, t, 0, \t- 1, - t, 0, \t1, - t, 0,\n\t\t 0, - 1, t, \t0, 1, t,\t0, - 1, - t, \t0, 1, - t,\n\t\t t, 0, - 1, \tt, 0, 1, \t- t, 0, - 1, \t- t, 0, 1\n\t];\n\n\tvar indices = [\n\t\t 0, 11, 5, \t0, 5, 1, \t0, 1, 7, \t0, 7, 10, \t0, 10, 11,\n\t\t 1, 5, 9, \t5, 11, 4,\t11, 10, 2,\t10, 7, 6,\t7, 1, 8,\n\t\t 3, 9, 4, \t3, 4, 2,\t3, 2, 6,\t3, 6, 8,\t3, 8, 9,\n\t\t 4, 9, 5, \t2, 4, 11,\t6, 2, 10,\t8, 6, 7,\t9, 8, 1\n\t];\n\n\tPolyhedronBufferGeometry.call( this, vertices, indices, radius, detail );\n\n\tthis.type = 'IcosahedronBufferGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n}\n\nIcosahedronBufferGeometry.prototype = Object.create( PolyhedronBufferGeometry.prototype );\nIcosahedronBufferGeometry.prototype.constructor = IcosahedronBufferGeometry;\n\n/**\n * @author Abe Pazos / https://hamoid.com\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// DodecahedronGeometry\n\nfunction DodecahedronGeometry( radius, detail ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'DodecahedronGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n\tthis.fromBufferGeometry( new DodecahedronBufferGeometry( radius, detail ) );\n\tthis.mergeVertices();\n\n}\n\nDodecahedronGeometry.prototype = Object.create( Geometry.prototype );\nDodecahedronGeometry.prototype.constructor = DodecahedronGeometry;\n\n// DodecahedronBufferGeometry\n\nfunction DodecahedronBufferGeometry( radius, detail ) {\n\n\tvar t = ( 1 + Math.sqrt( 5 ) ) / 2;\n\tvar r = 1 / t;\n\n\tvar vertices = [\n\n\t\t// (±1, ±1, ±1)\n\t\t- 1, - 1, - 1,\t- 1, - 1, 1,\n\t\t- 1, 1, - 1, - 1, 1, 1,\n\t\t1, - 1, - 1, 1, - 1, 1,\n\t\t1, 1, - 1, 1, 1, 1,\n\n\t\t// (0, ±1/φ, ±φ)\n\t\t 0, - r, - t, 0, - r, t,\n\t\t 0, r, - t, 0, r, t,\n\n\t\t// (±1/φ, ±φ, 0)\n\t\t- r, - t, 0, - r, t, 0,\n\t\t r, - t, 0, r, t, 0,\n\n\t\t// (±φ, 0, ±1/φ)\n\t\t- t, 0, - r, t, 0, - r,\n\t\t- t, 0, r, t, 0, r\n\t];\n\n\tvar indices = [\n\t\t3, 11, 7, \t3, 7, 15, \t3, 15, 13,\n\t\t7, 19, 17, \t7, 17, 6, \t7, 6, 15,\n\t\t17, 4, 8, \t17, 8, 10, \t17, 10, 6,\n\t\t8, 0, 16, \t8, 16, 2, \t8, 2, 10,\n\t\t0, 12, 1, \t0, 1, 18, \t0, 18, 16,\n\t\t6, 10, 2, \t6, 2, 13, \t6, 13, 15,\n\t\t2, 16, 18, \t2, 18, 3, \t2, 3, 13,\n\t\t18, 1, 9, \t18, 9, 11, \t18, 11, 3,\n\t\t4, 14, 12, \t4, 12, 0, \t4, 0, 8,\n\t\t11, 9, 5, \t11, 5, 19, \t11, 19, 7,\n\t\t19, 5, 14, \t19, 14, 4, \t19, 4, 17,\n\t\t1, 12, 14, \t1, 14, 5, \t1, 5, 9\n\t];\n\n\tPolyhedronBufferGeometry.call( this, vertices, indices, radius, detail );\n\n\tthis.type = 'DodecahedronBufferGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tdetail: detail\n\t};\n\n}\n\nDodecahedronBufferGeometry.prototype = Object.create( PolyhedronBufferGeometry.prototype );\nDodecahedronBufferGeometry.prototype.constructor = DodecahedronBufferGeometry;\n\n/**\n * @author oosmoxiecode / https://github.com/oosmoxiecode\n * @author WestLangley / https://github.com/WestLangley\n * @author zz85 / https://github.com/zz85\n * @author miningold / https://github.com/miningold\n * @author jonobr1 / https://github.com/jonobr1\n * @author Mugen87 / https://github.com/Mugen87\n *\n */\n\n// TubeGeometry\n\nfunction TubeGeometry( path, tubularSegments, radius, radialSegments, closed, taper ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'TubeGeometry';\n\n\tthis.parameters = {\n\t\tpath: path,\n\t\ttubularSegments: tubularSegments,\n\t\tradius: radius,\n\t\tradialSegments: radialSegments,\n\t\tclosed: closed\n\t};\n\n\tif ( taper !== undefined ) console.warn( 'THREE.TubeGeometry: taper has been removed.' );\n\n\tvar bufferGeometry = new TubeBufferGeometry( path, tubularSegments, radius, radialSegments, closed );\n\n\t// expose internals\n\n\tthis.tangents = bufferGeometry.tangents;\n\tthis.normals = bufferGeometry.normals;\n\tthis.binormals = bufferGeometry.binormals;\n\n\t// create geometry\n\n\tthis.fromBufferGeometry( bufferGeometry );\n\tthis.mergeVertices();\n\n}\n\nTubeGeometry.prototype = Object.create( Geometry.prototype );\nTubeGeometry.prototype.constructor = TubeGeometry;\n\n// TubeBufferGeometry\n\nfunction TubeBufferGeometry( path, tubularSegments, radius, radialSegments, closed ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'TubeBufferGeometry';\n\n\tthis.parameters = {\n\t\tpath: path,\n\t\ttubularSegments: tubularSegments,\n\t\tradius: radius,\n\t\tradialSegments: radialSegments,\n\t\tclosed: closed\n\t};\n\n\ttubularSegments = tubularSegments || 64;\n\tradius = radius || 1;\n\tradialSegments = radialSegments || 8;\n\tclosed = closed || false;\n\n\tvar frames = path.computeFrenetFrames( tubularSegments, closed );\n\n\t// expose internals\n\n\tthis.tangents = frames.tangents;\n\tthis.normals = frames.normals;\n\tthis.binormals = frames.binormals;\n\n\t// helper variables\n\n\tvar vertex = new Vector3();\n\tvar normal = new Vector3();\n\tvar uv = new Vector2();\n\tvar P = new Vector3();\n\n\tvar i, j;\n\n\t// buffer\n\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\tvar indices = [];\n\n\t// create buffer data\n\n\tgenerateBufferData();\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t// functions\n\n\tfunction generateBufferData() {\n\n\t\tfor ( i = 0; i < tubularSegments; i ++ ) {\n\n\t\t\tgenerateSegment( i );\n\n\t\t}\n\n\t\t// if the geometry is not closed, generate the last row of vertices and normals\n\t\t// at the regular position on the given path\n\t\t//\n\t\t// if the geometry is closed, duplicate the first row of vertices and normals (uvs will differ)\n\n\t\tgenerateSegment( ( closed === false ) ? tubularSegments : 0 );\n\n\t\t// uvs are generated in a separate function.\n\t\t// this makes it easy compute correct values for closed geometries\n\n\t\tgenerateUVs();\n\n\t\t// finally create faces\n\n\t\tgenerateIndices();\n\n\t}\n\n\tfunction generateSegment( i ) {\n\n\t\t// we use getPointAt to sample evenly distributed points from the given path\n\n\t\tP = path.getPointAt( i / tubularSegments, P );\n\n\t\t// retrieve corresponding normal and binormal\n\n\t\tvar N = frames.normals[ i ];\n\t\tvar B = frames.binormals[ i ];\n\n\t\t// generate normals and vertices for the current segment\n\n\t\tfor ( j = 0; j <= radialSegments; j ++ ) {\n\n\t\t\tvar v = j / radialSegments * Math.PI * 2;\n\n\t\t\tvar sin = Math.sin( v );\n\t\t\tvar cos = - Math.cos( v );\n\n\t\t\t// normal\n\n\t\t\tnormal.x = ( cos * N.x + sin * B.x );\n\t\t\tnormal.y = ( cos * N.y + sin * B.y );\n\t\t\tnormal.z = ( cos * N.z + sin * B.z );\n\t\t\tnormal.normalize();\n\n\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t// vertex\n\n\t\t\tvertex.x = P.x + radius * normal.x;\n\t\t\tvertex.y = P.y + radius * normal.y;\n\t\t\tvertex.z = P.z + radius * normal.z;\n\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t}\n\n\t}\n\n\tfunction generateIndices() {\n\n\t\tfor ( j = 1; j <= tubularSegments; j ++ ) {\n\n\t\t\tfor ( i = 1; i <= radialSegments; i ++ ) {\n\n\t\t\t\tvar a = ( radialSegments + 1 ) * ( j - 1 ) + ( i - 1 );\n\t\t\t\tvar b = ( radialSegments + 1 ) * j + ( i - 1 );\n\t\t\t\tvar c = ( radialSegments + 1 ) * j + i;\n\t\t\t\tvar d = ( radialSegments + 1 ) * ( j - 1 ) + i;\n\n\t\t\t\t// faces\n\n\t\t\t\tindices.push( a, b, d );\n\t\t\t\tindices.push( b, c, d );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction generateUVs() {\n\n\t\tfor ( i = 0; i <= tubularSegments; i ++ ) {\n\n\t\t\tfor ( j = 0; j <= radialSegments; j ++ ) {\n\n\t\t\t\tuv.x = i / tubularSegments;\n\t\t\t\tuv.y = j / radialSegments;\n\n\t\t\t\tuvs.push( uv.x, uv.y );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n}\n\nTubeBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nTubeBufferGeometry.prototype.constructor = TubeBufferGeometry;\n\n/**\n * @author oosmoxiecode\n * @author Mugen87 / https://github.com/Mugen87\n *\n * based on http://www.blackpawn.com/texts/pqtorus/\n */\n\n// TorusKnotGeometry\n\nfunction TorusKnotGeometry( radius, tube, tubularSegments, radialSegments, p, q, heightScale ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'TorusKnotGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\ttube: tube,\n\t\ttubularSegments: tubularSegments,\n\t\tradialSegments: radialSegments,\n\t\tp: p,\n\t\tq: q\n\t};\n\n\tif ( heightScale !== undefined ) console.warn( 'THREE.TorusKnotGeometry: heightScale has been deprecated. Use .scale( x, y, z ) instead.' );\n\n\tthis.fromBufferGeometry( new TorusKnotBufferGeometry( radius, tube, tubularSegments, radialSegments, p, q ) );\n\tthis.mergeVertices();\n\n}\n\nTorusKnotGeometry.prototype = Object.create( Geometry.prototype );\nTorusKnotGeometry.prototype.constructor = TorusKnotGeometry;\n\n// TorusKnotBufferGeometry\n\nfunction TorusKnotBufferGeometry( radius, tube, tubularSegments, radialSegments, p, q ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'TorusKnotBufferGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\ttube: tube,\n\t\ttubularSegments: tubularSegments,\n\t\tradialSegments: radialSegments,\n\t\tp: p,\n\t\tq: q\n\t};\n\n\tradius = radius || 1;\n\ttube = tube || 0.4;\n\ttubularSegments = Math.floor( tubularSegments ) || 64;\n\tradialSegments = Math.floor( radialSegments ) || 8;\n\tp = p || 2;\n\tq = q || 3;\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\t// helper variables\n\n\tvar i, j;\n\n\tvar vertex = new Vector3();\n\tvar normal = new Vector3();\n\n\tvar P1 = new Vector3();\n\tvar P2 = new Vector3();\n\n\tvar B = new Vector3();\n\tvar T = new Vector3();\n\tvar N = new Vector3();\n\n\t// generate vertices, normals and uvs\n\n\tfor ( i = 0; i <= tubularSegments; ++ i ) {\n\n\t\t// the radian \"u\" is used to calculate the position on the torus curve of the current tubular segement\n\n\t\tvar u = i / tubularSegments * p * Math.PI * 2;\n\n\t\t// now we calculate two points. P1 is our current position on the curve, P2 is a little farther ahead.\n\t\t// these points are used to create a special \"coordinate space\", which is necessary to calculate the correct vertex positions\n\n\t\tcalculatePositionOnCurve( u, p, q, radius, P1 );\n\t\tcalculatePositionOnCurve( u + 0.01, p, q, radius, P2 );\n\n\t\t// calculate orthonormal basis\n\n\t\tT.subVectors( P2, P1 );\n\t\tN.addVectors( P2, P1 );\n\t\tB.crossVectors( T, N );\n\t\tN.crossVectors( B, T );\n\n\t\t// normalize B, N. T can be ignored, we don't use it\n\n\t\tB.normalize();\n\t\tN.normalize();\n\n\t\tfor ( j = 0; j <= radialSegments; ++ j ) {\n\n\t\t\t// now calculate the vertices. they are nothing more than an extrusion of the torus curve.\n\t\t\t// because we extrude a shape in the xy-plane, there is no need to calculate a z-value.\n\n\t\t\tvar v = j / radialSegments * Math.PI * 2;\n\t\t\tvar cx = - tube * Math.cos( v );\n\t\t\tvar cy = tube * Math.sin( v );\n\n\t\t\t// now calculate the final vertex position.\n\t\t\t// first we orient the extrusion with our basis vectos, then we add it to the current position on the curve\n\n\t\t\tvertex.x = P1.x + ( cx * N.x + cy * B.x );\n\t\t\tvertex.y = P1.y + ( cx * N.y + cy * B.y );\n\t\t\tvertex.z = P1.z + ( cx * N.z + cy * B.z );\n\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t// normal (P1 is always the center/origin of the extrusion, thus we can use it to calculate the normal)\n\n\t\t\tnormal.subVectors( vertex, P1 ).normalize();\n\n\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t// uv\n\n\t\t\tuvs.push( i / tubularSegments );\n\t\t\tuvs.push( j / radialSegments );\n\n\t\t}\n\n\t}\n\n\t// generate indices\n\n\tfor ( j = 1; j <= tubularSegments; j ++ ) {\n\n\t\tfor ( i = 1; i <= radialSegments; i ++ ) {\n\n\t\t\t// indices\n\n\t\t\tvar a = ( radialSegments + 1 ) * ( j - 1 ) + ( i - 1 );\n\t\t\tvar b = ( radialSegments + 1 ) * j + ( i - 1 );\n\t\t\tvar c = ( radialSegments + 1 ) * j + i;\n\t\t\tvar d = ( radialSegments + 1 ) * ( j - 1 ) + i;\n\n\t\t\t// faces\n\n\t\t\tindices.push( a, b, d );\n\t\t\tindices.push( b, c, d );\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t// this function calculates the current position on the torus curve\n\n\tfunction calculatePositionOnCurve( u, p, q, radius, position ) {\n\n\t\tvar cu = Math.cos( u );\n\t\tvar su = Math.sin( u );\n\t\tvar quOverP = q / p * u;\n\t\tvar cs = Math.cos( quOverP );\n\n\t\tposition.x = radius * ( 2 + cs ) * 0.5 * cu;\n\t\tposition.y = radius * ( 2 + cs ) * su * 0.5;\n\t\tposition.z = radius * Math.sin( quOverP ) * 0.5;\n\n\t}\n\n}\n\nTorusKnotBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nTorusKnotBufferGeometry.prototype.constructor = TorusKnotBufferGeometry;\n\n/**\n * @author oosmoxiecode\n * @author mrdoob / http://mrdoob.com/\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// TorusGeometry\n\nfunction TorusGeometry( radius, tube, radialSegments, tubularSegments, arc ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'TorusGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\ttube: tube,\n\t\tradialSegments: radialSegments,\n\t\ttubularSegments: tubularSegments,\n\t\tarc: arc\n\t};\n\n\tthis.fromBufferGeometry( new TorusBufferGeometry( radius, tube, radialSegments, tubularSegments, arc ) );\n\tthis.mergeVertices();\n\n}\n\nTorusGeometry.prototype = Object.create( Geometry.prototype );\nTorusGeometry.prototype.constructor = TorusGeometry;\n\n// TorusBufferGeometry\n\nfunction TorusBufferGeometry( radius, tube, radialSegments, tubularSegments, arc ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'TorusBufferGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\ttube: tube,\n\t\tradialSegments: radialSegments,\n\t\ttubularSegments: tubularSegments,\n\t\tarc: arc\n\t};\n\n\tradius = radius || 1;\n\ttube = tube || 0.4;\n\tradialSegments = Math.floor( radialSegments ) || 8;\n\ttubularSegments = Math.floor( tubularSegments ) || 6;\n\tarc = arc || Math.PI * 2;\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\t// helper variables\n\n\tvar center = new Vector3();\n\tvar vertex = new Vector3();\n\tvar normal = new Vector3();\n\n\tvar j, i;\n\n\t// generate vertices, normals and uvs\n\n\tfor ( j = 0; j <= radialSegments; j ++ ) {\n\n\t\tfor ( i = 0; i <= tubularSegments; i ++ ) {\n\n\t\t\tvar u = i / tubularSegments * arc;\n\t\t\tvar v = j / radialSegments * Math.PI * 2;\n\n\t\t\t// vertex\n\n\t\t\tvertex.x = ( radius + tube * Math.cos( v ) ) * Math.cos( u );\n\t\t\tvertex.y = ( radius + tube * Math.cos( v ) ) * Math.sin( u );\n\t\t\tvertex.z = tube * Math.sin( v );\n\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t// normal\n\n\t\t\tcenter.x = radius * Math.cos( u );\n\t\t\tcenter.y = radius * Math.sin( u );\n\t\t\tnormal.subVectors( vertex, center ).normalize();\n\n\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t// uv\n\n\t\t\tuvs.push( i / tubularSegments );\n\t\t\tuvs.push( j / radialSegments );\n\n\t\t}\n\n\t}\n\n\t// generate indices\n\n\tfor ( j = 1; j <= radialSegments; j ++ ) {\n\n\t\tfor ( i = 1; i <= tubularSegments; i ++ ) {\n\n\t\t\t// indices\n\n\t\t\tvar a = ( tubularSegments + 1 ) * j + i - 1;\n\t\t\tvar b = ( tubularSegments + 1 ) * ( j - 1 ) + i - 1;\n\t\t\tvar c = ( tubularSegments + 1 ) * ( j - 1 ) + i;\n\t\t\tvar d = ( tubularSegments + 1 ) * j + i;\n\n\t\t\t// faces\n\n\t\t\tindices.push( a, b, d );\n\t\t\tindices.push( b, c, d );\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n}\n\nTorusBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nTorusBufferGeometry.prototype.constructor = TorusBufferGeometry;\n\n/**\n * @author Mugen87 / https://github.com/Mugen87\n * Port from https://github.com/mapbox/earcut (v2.1.2)\n */\n\nvar Earcut = {\n\n\ttriangulate: function ( data, holeIndices, dim ) {\n\n\t\tdim = dim || 2;\n\n\t\tvar hasHoles = holeIndices && holeIndices.length,\n\t\t\touterLen = hasHoles ? holeIndices[ 0 ] * dim : data.length,\n\t\t\touterNode = linkedList( data, 0, outerLen, dim, true ),\n\t\t\ttriangles = [];\n\n\t\tif ( ! outerNode ) return triangles;\n\n\t\tvar minX, minY, maxX, maxY, x, y, invSize;\n\n\t\tif ( hasHoles ) outerNode = eliminateHoles( data, holeIndices, outerNode, dim );\n\n\t\t// if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox\n\n\t\tif ( data.length > 80 * dim ) {\n\n\t\t\tminX = maxX = data[ 0 ];\n\t\t\tminY = maxY = data[ 1 ];\n\n\t\t\tfor ( var i = dim; i < outerLen; i += dim ) {\n\n\t\t\t\tx = data[ i ];\n\t\t\t\ty = data[ i + 1 ];\n\t\t\t\tif ( x < minX ) minX = x;\n\t\t\t\tif ( y < minY ) minY = y;\n\t\t\t\tif ( x > maxX ) maxX = x;\n\t\t\t\tif ( y > maxY ) maxY = y;\n\n\t\t\t}\n\n\t\t\t// minX, minY and invSize are later used to transform coords into integers for z-order calculation\n\n\t\t\tinvSize = Math.max( maxX - minX, maxY - minY );\n\t\t\tinvSize = invSize !== 0 ? 1 / invSize : 0;\n\n\t\t}\n\n\t\tearcutLinked( outerNode, triangles, dim, minX, minY, invSize );\n\n\t\treturn triangles;\n\n\t}\n\n};\n\n// create a circular doubly linked list from polygon points in the specified winding order\n\nfunction linkedList( data, start, end, dim, clockwise ) {\n\n\tvar i, last;\n\n\tif ( clockwise === ( signedArea( data, start, end, dim ) > 0 ) ) {\n\n\t\tfor ( i = start; i < end; i += dim ) last = insertNode( i, data[ i ], data[ i + 1 ], last );\n\n\t} else {\n\n\t\tfor ( i = end - dim; i >= start; i -= dim ) last = insertNode( i, data[ i ], data[ i + 1 ], last );\n\n\t}\n\n\tif ( last && equals( last, last.next ) ) {\n\n\t\tremoveNode( last );\n\t\tlast = last.next;\n\n\t}\n\n\treturn last;\n\n}\n\n// eliminate colinear or duplicate points\n\nfunction filterPoints( start, end ) {\n\n\tif ( ! start ) return start;\n\tif ( ! end ) end = start;\n\n\tvar p = start, again;\n\n\tdo {\n\n\t\tagain = false;\n\n\t\tif ( ! p.steiner && ( equals( p, p.next ) || area( p.prev, p, p.next ) === 0 ) ) {\n\n\t\t\tremoveNode( p );\n\t\t\tp = end = p.prev;\n\t\t\tif ( p === p.next ) break;\n\t\t\tagain = true;\n\n\t\t} else {\n\n\t\t\tp = p.next;\n\n\t\t}\n\n\t} while ( again || p !== end );\n\n\treturn end;\n\n}\n\n// main ear slicing loop which triangulates a polygon (given as a linked list)\n\nfunction earcutLinked( ear, triangles, dim, minX, minY, invSize, pass ) {\n\n\tif ( ! ear ) return;\n\n\t// interlink polygon nodes in z-order\n\n\tif ( ! pass && invSize ) indexCurve( ear, minX, minY, invSize );\n\n\tvar stop = ear, prev, next;\n\n\t// iterate through ears, slicing them one by one\n\n\twhile ( ear.prev !== ear.next ) {\n\n\t\tprev = ear.prev;\n\t\tnext = ear.next;\n\n\t\tif ( invSize ? isEarHashed( ear, minX, minY, invSize ) : isEar( ear ) ) {\n\n\t\t\t// cut off the triangle\n\t\t\ttriangles.push( prev.i / dim );\n\t\t\ttriangles.push( ear.i / dim );\n\t\t\ttriangles.push( next.i / dim );\n\n\t\t\tremoveNode( ear );\n\n\t\t\t// skipping the next vertice leads to less sliver triangles\n\t\t\tear = next.next;\n\t\t\tstop = next.next;\n\n\t\t\tcontinue;\n\n\t\t}\n\n\t\tear = next;\n\n\t\t// if we looped through the whole remaining polygon and can't find any more ears\n\n\t\tif ( ear === stop ) {\n\n\t\t\t// try filtering points and slicing again\n\n\t\t\tif ( ! pass ) {\n\n\t\t\t\tearcutLinked( filterPoints( ear ), triangles, dim, minX, minY, invSize, 1 );\n\n\t\t\t\t// if this didn't work, try curing all small self-intersections locally\n\n\t\t\t} else if ( pass === 1 ) {\n\n\t\t\t\tear = cureLocalIntersections( ear, triangles, dim );\n\t\t\t\tearcutLinked( ear, triangles, dim, minX, minY, invSize, 2 );\n\n\t\t\t// as a last resort, try splitting the remaining polygon into two\n\n\t\t\t} else if ( pass === 2 ) {\n\n\t\t\t\tsplitEarcut( ear, triangles, dim, minX, minY, invSize );\n\n\t\t\t}\n\n\t\t\tbreak;\n\n\t\t}\n\n\t}\n\n}\n\n// check whether a polygon node forms a valid ear with adjacent nodes\n\nfunction isEar( ear ) {\n\n\tvar a = ear.prev,\n\t\tb = ear,\n\t\tc = ear.next;\n\n\tif ( area( a, b, c ) >= 0 ) return false; // reflex, can't be an ear\n\n\t// now make sure we don't have other points inside the potential ear\n\tvar p = ear.next.next;\n\n\twhile ( p !== ear.prev ) {\n\n\t\tif ( pointInTriangle( a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y ) && area( p.prev, p, p.next ) >= 0 ) {\n\n\t\t\treturn false;\n\n\t\t}\n\n\t\tp = p.next;\n\n\t}\n\n\treturn true;\n\n}\n\nfunction isEarHashed( ear, minX, minY, invSize ) {\n\n\tvar a = ear.prev,\n\t\tb = ear,\n\t\tc = ear.next;\n\n\tif ( area( a, b, c ) >= 0 ) return false; // reflex, can't be an ear\n\n\t// triangle bbox; min & max are calculated like this for speed\n\n\tvar minTX = a.x < b.x ? ( a.x < c.x ? a.x : c.x ) : ( b.x < c.x ? b.x : c.x ),\n\t\tminTY = a.y < b.y ? ( a.y < c.y ? a.y : c.y ) : ( b.y < c.y ? b.y : c.y ),\n\t\tmaxTX = a.x > b.x ? ( a.x > c.x ? a.x : c.x ) : ( b.x > c.x ? b.x : c.x ),\n\t\tmaxTY = a.y > b.y ? ( a.y > c.y ? a.y : c.y ) : ( b.y > c.y ? b.y : c.y );\n\n\t// z-order range for the current triangle bbox;\n\n\tvar minZ = zOrder( minTX, minTY, minX, minY, invSize ),\n\t\tmaxZ = zOrder( maxTX, maxTY, minX, minY, invSize );\n\n\t// first look for points inside the triangle in increasing z-order\n\n\tvar p = ear.nextZ;\n\n\twhile ( p && p.z <= maxZ ) {\n\n\t\tif ( p !== ear.prev && p !== ear.next &&\n\t\t\t\tpointInTriangle( a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y ) &&\n\t\t\t\tarea( p.prev, p, p.next ) >= 0 ) return false;\n\t\tp = p.nextZ;\n\n\t}\n\n\t// then look for points in decreasing z-order\n\n\tp = ear.prevZ;\n\n\twhile ( p && p.z >= minZ ) {\n\n\t\tif ( p !== ear.prev && p !== ear.next &&\n\t\t\t\tpointInTriangle( a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y ) &&\n\t\t\t\tarea( p.prev, p, p.next ) >= 0 ) return false;\n\n\t\tp = p.prevZ;\n\n\t}\n\n\treturn true;\n\n}\n\n// go through all polygon nodes and cure small local self-intersections\n\nfunction cureLocalIntersections( start, triangles, dim ) {\n\n\tvar p = start;\n\n\tdo {\n\n\t\tvar a = p.prev, b = p.next.next;\n\n\t\tif ( ! equals( a, b ) && intersects( a, p, p.next, b ) && locallyInside( a, b ) && locallyInside( b, a ) ) {\n\n\t\t\ttriangles.push( a.i / dim );\n\t\t\ttriangles.push( p.i / dim );\n\t\t\ttriangles.push( b.i / dim );\n\n\t\t\t// remove two nodes involved\n\n\t\t\tremoveNode( p );\n\t\t\tremoveNode( p.next );\n\n\t\t\tp = start = b;\n\n\t\t}\n\n\t\tp = p.next;\n\n\t} while ( p !== start );\n\n\treturn p;\n\n}\n\n// try splitting polygon into two and triangulate them independently\n\nfunction splitEarcut( start, triangles, dim, minX, minY, invSize ) {\n\n\t// look for a valid diagonal that divides the polygon into two\n\n\tvar a = start;\n\n\tdo {\n\n\t\tvar b = a.next.next;\n\n\t\twhile ( b !== a.prev ) {\n\n\t\t\tif ( a.i !== b.i && isValidDiagonal( a, b ) ) {\n\n\t\t\t\t// split the polygon in two by the diagonal\n\n\t\t\t\tvar c = splitPolygon( a, b );\n\n\t\t\t\t// filter colinear points around the cuts\n\n\t\t\t\ta = filterPoints( a, a.next );\n\t\t\t\tc = filterPoints( c, c.next );\n\n\t\t\t\t// run earcut on each half\n\n\t\t\t\tearcutLinked( a, triangles, dim, minX, minY, invSize );\n\t\t\t\tearcutLinked( c, triangles, dim, minX, minY, invSize );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t\tb = b.next;\n\n\t\t}\n\n\t\ta = a.next;\n\n\t} while ( a !== start );\n\n}\n\n// link every hole into the outer loop, producing a single-ring polygon without holes\n\nfunction eliminateHoles( data, holeIndices, outerNode, dim ) {\n\n\tvar queue = [], i, len, start, end, list;\n\n\tfor ( i = 0, len = holeIndices.length; i < len; i ++ ) {\n\n\t\tstart = holeIndices[ i ] * dim;\n\t\tend = i < len - 1 ? holeIndices[ i + 1 ] * dim : data.length;\n\t\tlist = linkedList( data, start, end, dim, false );\n\t\tif ( list === list.next ) list.steiner = true;\n\t\tqueue.push( getLeftmost( list ) );\n\n\t}\n\n\tqueue.sort( compareX );\n\n\t// process holes from left to right\n\n\tfor ( i = 0; i < queue.length; i ++ ) {\n\n\t\teliminateHole( queue[ i ], outerNode );\n\t\touterNode = filterPoints( outerNode, outerNode.next );\n\n\t}\n\n\treturn outerNode;\n\n}\n\nfunction compareX( a, b ) {\n\n\treturn a.x - b.x;\n\n}\n\n// find a bridge between vertices that connects hole with an outer ring and and link it\n\nfunction eliminateHole( hole, outerNode ) {\n\n\touterNode = findHoleBridge( hole, outerNode );\n\n\tif ( outerNode ) {\n\n\t\tvar b = splitPolygon( outerNode, hole );\n\n\t\tfilterPoints( b, b.next );\n\n\t}\n\n}\n\n// David Eberly's algorithm for finding a bridge between hole and outer polygon\n\nfunction findHoleBridge( hole, outerNode ) {\n\n\tvar p = outerNode,\n\t\thx = hole.x,\n\t\thy = hole.y,\n\t\tqx = - Infinity,\n\t\tm;\n\n\t// find a segment intersected by a ray from the hole's leftmost point to the left;\n\t// segment's endpoint with lesser x will be potential connection point\n\n\tdo {\n\n\t\tif ( hy <= p.y && hy >= p.next.y && p.next.y !== p.y ) {\n\n\t\t\tvar x = p.x + ( hy - p.y ) * ( p.next.x - p.x ) / ( p.next.y - p.y );\n\n\t\t\tif ( x <= hx && x > qx ) {\n\n\t\t\t\tqx = x;\n\n\t\t\t\tif ( x === hx ) {\n\n\t\t\t\t\tif ( hy === p.y ) return p;\n\t\t\t\t\tif ( hy === p.next.y ) return p.next;\n\n\t\t\t\t}\n\n\t\t\t\tm = p.x < p.next.x ? p : p.next;\n\n\t\t\t}\n\n\t\t}\n\n\t\tp = p.next;\n\n\t} while ( p !== outerNode );\n\n\tif ( ! m ) return null;\n\n\tif ( hx === qx ) return m.prev; // hole touches outer segment; pick lower endpoint\n\n\t// look for points inside the triangle of hole point, segment intersection and endpoint;\n\t// if there are no points found, we have a valid connection;\n\t// otherwise choose the point of the minimum angle with the ray as connection point\n\n\tvar stop = m,\n\t\tmx = m.x,\n\t\tmy = m.y,\n\t\ttanMin = Infinity,\n\t\ttan;\n\n\tp = m.next;\n\n\twhile ( p !== stop ) {\n\n\t\tif ( hx >= p.x && p.x >= mx && hx !== p.x &&\n\t\t\t\t\t\tpointInTriangle( hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y ) ) {\n\n\t\t\ttan = Math.abs( hy - p.y ) / ( hx - p.x ); // tangential\n\n\t\t\tif ( ( tan < tanMin || ( tan === tanMin && p.x > m.x ) ) && locallyInside( p, hole ) ) {\n\n\t\t\t\tm = p;\n\t\t\t\ttanMin = tan;\n\n\t\t\t}\n\n\t\t}\n\n\t\tp = p.next;\n\n\t}\n\n\treturn m;\n\n}\n\n// interlink polygon nodes in z-order\n\nfunction indexCurve( start, minX, minY, invSize ) {\n\n\tvar p = start;\n\n\tdo {\n\n\t\tif ( p.z === null ) p.z = zOrder( p.x, p.y, minX, minY, invSize );\n\t\tp.prevZ = p.prev;\n\t\tp.nextZ = p.next;\n\t\tp = p.next;\n\n\t} while ( p !== start );\n\n\tp.prevZ.nextZ = null;\n\tp.prevZ = null;\n\n\tsortLinked( p );\n\n}\n\n// Simon Tatham's linked list merge sort algorithm\n// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html\n\nfunction sortLinked( list ) {\n\n\tvar i, p, q, e, tail, numMerges, pSize, qSize, inSize = 1;\n\n\tdo {\n\n\t\tp = list;\n\t\tlist = null;\n\t\ttail = null;\n\t\tnumMerges = 0;\n\n\t\twhile ( p ) {\n\n\t\t\tnumMerges ++;\n\t\t\tq = p;\n\t\t\tpSize = 0;\n\n\t\t\tfor ( i = 0; i < inSize; i ++ ) {\n\n\t\t\t\tpSize ++;\n\t\t\t\tq = q.nextZ;\n\t\t\t\tif ( ! q ) break;\n\n\t\t\t}\n\n\t\t\tqSize = inSize;\n\n\t\t\twhile ( pSize > 0 || ( qSize > 0 && q ) ) {\n\n\t\t\t\tif ( pSize !== 0 && ( qSize === 0 || ! q || p.z <= q.z ) ) {\n\n\t\t\t\t\te = p;\n\t\t\t\t\tp = p.nextZ;\n\t\t\t\t\tpSize --;\n\n\t\t\t\t} else {\n\n\t\t\t\t\te = q;\n\t\t\t\t\tq = q.nextZ;\n\t\t\t\t\tqSize --;\n\n\t\t\t\t}\n\n\t\t\t\tif ( tail ) tail.nextZ = e;\n\t\t\t\telse list = e;\n\n\t\t\t\te.prevZ = tail;\n\t\t\t\ttail = e;\n\n\t\t\t}\n\n\t\t\tp = q;\n\n\t\t}\n\n\t\ttail.nextZ = null;\n\t\tinSize *= 2;\n\n\t} while ( numMerges > 1 );\n\n\treturn list;\n\n}\n\n// z-order of a point given coords and inverse of the longer side of data bbox\n\nfunction zOrder( x, y, minX, minY, invSize ) {\n\n\t// coords are transformed into non-negative 15-bit integer range\n\n\tx = 32767 * ( x - minX ) * invSize;\n\ty = 32767 * ( y - minY ) * invSize;\n\n\tx = ( x | ( x << 8 ) ) & 0x00FF00FF;\n\tx = ( x | ( x << 4 ) ) & 0x0F0F0F0F;\n\tx = ( x | ( x << 2 ) ) & 0x33333333;\n\tx = ( x | ( x << 1 ) ) & 0x55555555;\n\n\ty = ( y | ( y << 8 ) ) & 0x00FF00FF;\n\ty = ( y | ( y << 4 ) ) & 0x0F0F0F0F;\n\ty = ( y | ( y << 2 ) ) & 0x33333333;\n\ty = ( y | ( y << 1 ) ) & 0x55555555;\n\n\treturn x | ( y << 1 );\n\n}\n\n// find the leftmost node of a polygon ring\n\nfunction getLeftmost( start ) {\n\n\tvar p = start, leftmost = start;\n\n\tdo {\n\n\t\tif ( p.x < leftmost.x ) leftmost = p;\n\t\tp = p.next;\n\n\t} while ( p !== start );\n\n\treturn leftmost;\n\n}\n\n// check if a point lies within a convex triangle\n\nfunction pointInTriangle( ax, ay, bx, by, cx, cy, px, py ) {\n\n\treturn ( cx - px ) * ( ay - py ) - ( ax - px ) * ( cy - py ) >= 0 &&\n\t ( ax - px ) * ( by - py ) - ( bx - px ) * ( ay - py ) >= 0 &&\n\t ( bx - px ) * ( cy - py ) - ( cx - px ) * ( by - py ) >= 0;\n\n}\n\n// check if a diagonal between two polygon nodes is valid (lies in polygon interior)\n\nfunction isValidDiagonal( a, b ) {\n\n\treturn a.next.i !== b.i && a.prev.i !== b.i && ! intersectsPolygon( a, b ) &&\n\t\tlocallyInside( a, b ) && locallyInside( b, a ) && middleInside( a, b );\n\n}\n\n// signed area of a triangle\n\nfunction area( p, q, r ) {\n\n\treturn ( q.y - p.y ) * ( r.x - q.x ) - ( q.x - p.x ) * ( r.y - q.y );\n\n}\n\n// check if two points are equal\n\nfunction equals( p1, p2 ) {\n\n\treturn p1.x === p2.x && p1.y === p2.y;\n\n}\n\n// check if two segments intersect\n\nfunction intersects( p1, q1, p2, q2 ) {\n\n\tif ( ( equals( p1, q1 ) && equals( p2, q2 ) ) ||\n\t\t\t( equals( p1, q2 ) && equals( p2, q1 ) ) ) return true;\n\n\treturn area( p1, q1, p2 ) > 0 !== area( p1, q1, q2 ) > 0 &&\n\t\t\t\t area( p2, q2, p1 ) > 0 !== area( p2, q2, q1 ) > 0;\n\n}\n\n// check if a polygon diagonal intersects any polygon segments\n\nfunction intersectsPolygon( a, b ) {\n\n\tvar p = a;\n\n\tdo {\n\n\t\tif ( p.i !== a.i && p.next.i !== a.i && p.i !== b.i && p.next.i !== b.i &&\n\t\t\t\t\t\tintersects( p, p.next, a, b ) ) {\n\n\t\t\treturn true;\n\n\t\t}\n\n\t\tp = p.next;\n\n\t} while ( p !== a );\n\n\treturn false;\n\n}\n\n// check if a polygon diagonal is locally inside the polygon\n\nfunction locallyInside( a, b ) {\n\n\treturn area( a.prev, a, a.next ) < 0 ?\n\t\tarea( a, b, a.next ) >= 0 && area( a, a.prev, b ) >= 0 :\n\t\tarea( a, b, a.prev ) < 0 || area( a, a.next, b ) < 0;\n\n}\n\n// check if the middle point of a polygon diagonal is inside the polygon\n\nfunction middleInside( a, b ) {\n\n\tvar p = a,\n\t\tinside = false,\n\t\tpx = ( a.x + b.x ) / 2,\n\t\tpy = ( a.y + b.y ) / 2;\n\n\tdo {\n\n\t\tif ( ( ( p.y > py ) !== ( p.next.y > py ) ) && p.next.y !== p.y &&\n\t\t\t\t\t\t( px < ( p.next.x - p.x ) * ( py - p.y ) / ( p.next.y - p.y ) + p.x ) ) {\n\n\t\t\tinside = ! inside;\n\n\t\t}\n\n\t\tp = p.next;\n\n\t} while ( p !== a );\n\n\treturn inside;\n\n}\n\n// link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;\n// if one belongs to the outer ring and another to a hole, it merges it into a single ring\n\nfunction splitPolygon( a, b ) {\n\n\tvar a2 = new Node( a.i, a.x, a.y ),\n\t\tb2 = new Node( b.i, b.x, b.y ),\n\t\tan = a.next,\n\t\tbp = b.prev;\n\n\ta.next = b;\n\tb.prev = a;\n\n\ta2.next = an;\n\tan.prev = a2;\n\n\tb2.next = a2;\n\ta2.prev = b2;\n\n\tbp.next = b2;\n\tb2.prev = bp;\n\n\treturn b2;\n\n}\n\n// create a node and optionally link it with previous one (in a circular doubly linked list)\n\nfunction insertNode( i, x, y, last ) {\n\n\tvar p = new Node( i, x, y );\n\n\tif ( ! last ) {\n\n\t\tp.prev = p;\n\t\tp.next = p;\n\n\t} else {\n\n\t\tp.next = last.next;\n\t\tp.prev = last;\n\t\tlast.next.prev = p;\n\t\tlast.next = p;\n\n\t}\n\n\treturn p;\n\n}\n\nfunction removeNode( p ) {\n\n\tp.next.prev = p.prev;\n\tp.prev.next = p.next;\n\n\tif ( p.prevZ ) p.prevZ.nextZ = p.nextZ;\n\tif ( p.nextZ ) p.nextZ.prevZ = p.prevZ;\n\n}\n\nfunction Node( i, x, y ) {\n\n\t// vertice index in coordinates array\n\tthis.i = i;\n\n\t// vertex coordinates\n\tthis.x = x;\n\tthis.y = y;\n\n\t// previous and next vertice nodes in a polygon ring\n\tthis.prev = null;\n\tthis.next = null;\n\n\t// z-order curve value\n\tthis.z = null;\n\n\t// previous and next nodes in z-order\n\tthis.prevZ = null;\n\tthis.nextZ = null;\n\n\t// indicates whether this is a steiner point\n\tthis.steiner = false;\n\n}\n\nfunction signedArea( data, start, end, dim ) {\n\n\tvar sum = 0;\n\n\tfor ( var i = start, j = end - dim; i < end; i += dim ) {\n\n\t\tsum += ( data[ j ] - data[ i ] ) * ( data[ i + 1 ] + data[ j + 1 ] );\n\t\tj = i;\n\n\t}\n\n\treturn sum;\n\n}\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n */\n\nvar ShapeUtils = {\n\n\t// calculate area of the contour polygon\n\n\tarea: function ( contour ) {\n\n\t\tvar n = contour.length;\n\t\tvar a = 0.0;\n\n\t\tfor ( var p = n - 1, q = 0; q < n; p = q ++ ) {\n\n\t\t\ta += contour[ p ].x * contour[ q ].y - contour[ q ].x * contour[ p ].y;\n\n\t\t}\n\n\t\treturn a * 0.5;\n\n\t},\n\n\tisClockWise: function ( pts ) {\n\n\t\treturn ShapeUtils.area( pts ) < 0;\n\n\t},\n\n\ttriangulateShape: function ( contour, holes ) {\n\n\t\tvar vertices = []; // flat array of vertices like [ x0,y0, x1,y1, x2,y2, ... ]\n\t\tvar holeIndices = []; // array of hole indices\n\t\tvar faces = []; // final array of vertex indices like [ [ a,b,d ], [ b,c,d ] ]\n\n\t\tremoveDupEndPts( contour );\n\t\taddContour( vertices, contour );\n\n\t\t//\n\n\t\tvar holeIndex = contour.length;\n\n\t\tholes.forEach( removeDupEndPts );\n\n\t\tfor ( var i = 0; i < holes.length; i ++ ) {\n\n\t\t\tholeIndices.push( holeIndex );\n\t\t\tholeIndex += holes[ i ].length;\n\t\t\taddContour( vertices, holes[ i ] );\n\n\t\t}\n\n\t\t//\n\n\t\tvar triangles = Earcut.triangulate( vertices, holeIndices );\n\n\t\t//\n\n\t\tfor ( var i = 0; i < triangles.length; i += 3 ) {\n\n\t\t\tfaces.push( triangles.slice( i, i + 3 ) );\n\n\t\t}\n\n\t\treturn faces;\n\n\t}\n\n};\n\nfunction removeDupEndPts( points ) {\n\n\tvar l = points.length;\n\n\tif ( l > 2 && points[ l - 1 ].equals( points[ 0 ] ) ) {\n\n\t\tpoints.pop();\n\n\t}\n\n}\n\nfunction addContour( vertices, contour ) {\n\n\tfor ( var i = 0; i < contour.length; i ++ ) {\n\n\t\tvertices.push( contour[ i ].x );\n\t\tvertices.push( contour[ i ].y );\n\n\t}\n\n}\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n *\n * Creates extruded geometry from a path shape.\n *\n * parameters = {\n *\n *  curveSegments: <int>, // number of points on the curves\n *  steps: <int>, // number of points for z-side extrusions / used for subdividing segments of extrude spline too\n *  amount: <int>, // Depth to extrude the shape\n *\n *  bevelEnabled: <bool>, // turn on bevel\n *  bevelThickness: <float>, // how deep into the original shape bevel goes\n *  bevelSize: <float>, // how far from shape outline is bevel\n *  bevelSegments: <int>, // number of bevel layers\n *\n *  extrudePath: <THREE.Curve> // curve to extrude shape along\n *\n *  UVGenerator: <Object> // object that provides UV generator functions\n *\n * }\n */\n\n// ExtrudeGeometry\n\nfunction ExtrudeGeometry( shapes, options ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'ExtrudeGeometry';\n\n\tthis.parameters = {\n\t\tshapes: shapes,\n\t\toptions: options\n\t};\n\n\tthis.fromBufferGeometry( new ExtrudeBufferGeometry( shapes, options ) );\n\tthis.mergeVertices();\n\n}\n\nExtrudeGeometry.prototype = Object.create( Geometry.prototype );\nExtrudeGeometry.prototype.constructor = ExtrudeGeometry;\n\n// ExtrudeBufferGeometry\n\nfunction ExtrudeBufferGeometry( shapes, options ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'ExtrudeBufferGeometry';\n\n\tthis.parameters = {\n\t\tshapes: shapes,\n\t\toptions: options\n\t};\n\n\tshapes = Array.isArray( shapes ) ? shapes : [ shapes ];\n\n\tvar scope = this;\n\n\tvar verticesArray = [];\n\tvar uvArray = [];\n\n\tfor ( var i = 0, l = shapes.length; i < l; i ++ ) {\n\n\t\tvar shape = shapes[ i ];\n\t\taddShape( shape, options );\n\n\t}\n\n\t// build geometry\n\n\tthis.addAttribute( 'position', new Float32BufferAttribute( verticesArray, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvArray, 2 ) );\n\n\tthis.computeVertexNormals();\n\n\t// functions\n\n\tfunction addShape( shape ) {\n\n\t\tvar placeholder = [];\n\n\t\t// options\n\n\t\tvar curveSegments = options.curveSegments !== undefined ? options.curveSegments : 12;\n\t\tvar steps = options.steps !== undefined ? options.steps : 1;\n\t\tvar amount = options.amount !== undefined ? options.amount : 100;\n\n\t\tvar bevelEnabled = options.bevelEnabled !== undefined ? options.bevelEnabled : true;\n\t\tvar bevelThickness = options.bevelThickness !== undefined ? options.bevelThickness : 6;\n\t\tvar bevelSize = options.bevelSize !== undefined ? options.bevelSize : bevelThickness - 2;\n\t\tvar bevelSegments = options.bevelSegments !== undefined ? options.bevelSegments : 3;\n\n\t\tvar extrudePath = options.extrudePath;\n\n\t\tvar uvgen = options.UVGenerator !== undefined ? options.UVGenerator : WorldUVGenerator;\n\n\t\t//\n\n\t\tvar extrudePts, extrudeByPath = false;\n\t\tvar splineTube, binormal, normal, position2;\n\n\t\tif ( extrudePath ) {\n\n\t\t\textrudePts = extrudePath.getSpacedPoints( steps );\n\n\t\t\textrudeByPath = true;\n\t\t\tbevelEnabled = false; // bevels not supported for path extrusion\n\n\t\t\t// SETUP TNB variables\n\n\t\t\t// TODO1 - have a .isClosed in spline?\n\n\t\t\tsplineTube = extrudePath.computeFrenetFrames( steps, false );\n\n\t\t\t// console.log(splineTube, 'splineTube', splineTube.normals.length, 'steps', steps, 'extrudePts', extrudePts.length);\n\n\t\t\tbinormal = new Vector3();\n\t\t\tnormal = new Vector3();\n\t\t\tposition2 = new Vector3();\n\n\t\t}\n\n\t\t// Safeguards if bevels are not enabled\n\n\t\tif ( ! bevelEnabled ) {\n\n\t\t\tbevelSegments = 0;\n\t\t\tbevelThickness = 0;\n\t\t\tbevelSize = 0;\n\n\t\t}\n\n\t\t// Variables initialization\n\n\t\tvar ahole, h, hl; // looping of holes\n\n\t\tvar shapePoints = shape.extractPoints( curveSegments );\n\n\t\tvar vertices = shapePoints.shape;\n\t\tvar holes = shapePoints.holes;\n\n\t\tvar reverse = ! ShapeUtils.isClockWise( vertices );\n\n\t\tif ( reverse ) {\n\n\t\t\tvertices = vertices.reverse();\n\n\t\t\t// Maybe we should also check if holes are in the opposite direction, just to be safe ...\n\n\t\t\tfor ( h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\tahole = holes[ h ];\n\n\t\t\t\tif ( ShapeUtils.isClockWise( ahole ) ) {\n\n\t\t\t\t\tholes[ h ] = ahole.reverse();\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\n\t\tvar faces = ShapeUtils.triangulateShape( vertices, holes );\n\n\t\t/* Vertices */\n\n\t\tvar contour = vertices; // vertices has all points but contour has only points of circumference\n\n\t\tfor ( h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\tahole = holes[ h ];\n\n\t\t\tvertices = vertices.concat( ahole );\n\n\t\t}\n\n\n\t\tfunction scalePt2( pt, vec, size ) {\n\n\t\t\tif ( ! vec ) console.error( \"THREE.ExtrudeGeometry: vec does not exist\" );\n\n\t\t\treturn vec.clone().multiplyScalar( size ).add( pt );\n\n\t\t}\n\n\t\tvar b, bs, t, z,\n\t\t\tvert, vlen = vertices.length,\n\t\t\tface, flen = faces.length;\n\n\n\t\t// Find directions for point movement\n\n\n\t\tfunction getBevelVec( inPt, inPrev, inNext ) {\n\n\t\t\t// computes for inPt the corresponding point inPt' on a new contour\n\t\t\t//   shifted by 1 unit (length of normalized vector) to the left\n\t\t\t// if we walk along contour clockwise, this new contour is outside the old one\n\t\t\t//\n\t\t\t// inPt' is the intersection of the two lines parallel to the two\n\t\t\t//  adjacent edges of inPt at a distance of 1 unit on the left side.\n\n\t\t\tvar v_trans_x, v_trans_y, shrink_by; // resulting translation vector for inPt\n\n\t\t\t// good reading for geometry algorithms (here: line-line intersection)\n\t\t\t// http://geomalgorithms.com/a05-_intersect-1.html\n\n\t\t\tvar v_prev_x = inPt.x - inPrev.x,\n\t\t\t\tv_prev_y = inPt.y - inPrev.y;\n\t\t\tvar v_next_x = inNext.x - inPt.x,\n\t\t\t\tv_next_y = inNext.y - inPt.y;\n\n\t\t\tvar v_prev_lensq = ( v_prev_x * v_prev_x + v_prev_y * v_prev_y );\n\n\t\t\t// check for collinear edges\n\t\t\tvar collinear0 = ( v_prev_x * v_next_y - v_prev_y * v_next_x );\n\n\t\t\tif ( Math.abs( collinear0 ) > Number.EPSILON ) {\n\n\t\t\t\t// not collinear\n\n\t\t\t\t// length of vectors for normalizing\n\n\t\t\t\tvar v_prev_len = Math.sqrt( v_prev_lensq );\n\t\t\t\tvar v_next_len = Math.sqrt( v_next_x * v_next_x + v_next_y * v_next_y );\n\n\t\t\t\t// shift adjacent points by unit vectors to the left\n\n\t\t\t\tvar ptPrevShift_x = ( inPrev.x - v_prev_y / v_prev_len );\n\t\t\t\tvar ptPrevShift_y = ( inPrev.y + v_prev_x / v_prev_len );\n\n\t\t\t\tvar ptNextShift_x = ( inNext.x - v_next_y / v_next_len );\n\t\t\t\tvar ptNextShift_y = ( inNext.y + v_next_x / v_next_len );\n\n\t\t\t\t// scaling factor for v_prev to intersection point\n\n\t\t\t\tvar sf = ( ( ptNextShift_x - ptPrevShift_x ) * v_next_y -\n\t\t\t\t\t\t( ptNextShift_y - ptPrevShift_y ) * v_next_x ) /\n\t\t\t\t\t( v_prev_x * v_next_y - v_prev_y * v_next_x );\n\n\t\t\t\t// vector from inPt to intersection point\n\n\t\t\t\tv_trans_x = ( ptPrevShift_x + v_prev_x * sf - inPt.x );\n\t\t\t\tv_trans_y = ( ptPrevShift_y + v_prev_y * sf - inPt.y );\n\n\t\t\t\t// Don't normalize!, otherwise sharp corners become ugly\n\t\t\t\t//  but prevent crazy spikes\n\t\t\t\tvar v_trans_lensq = ( v_trans_x * v_trans_x + v_trans_y * v_trans_y );\n\t\t\t\tif ( v_trans_lensq <= 2 ) {\n\n\t\t\t\t\treturn new Vector2( v_trans_x, v_trans_y );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tshrink_by = Math.sqrt( v_trans_lensq / 2 );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// handle special case of collinear edges\n\n\t\t\t\tvar direction_eq = false; // assumes: opposite\n\t\t\t\tif ( v_prev_x > Number.EPSILON ) {\n\n\t\t\t\t\tif ( v_next_x > Number.EPSILON ) {\n\n\t\t\t\t\t\tdirection_eq = true;\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( v_prev_x < - Number.EPSILON ) {\n\n\t\t\t\t\t\tif ( v_next_x < - Number.EPSILON ) {\n\n\t\t\t\t\t\t\tdirection_eq = true;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tif ( Math.sign( v_prev_y ) === Math.sign( v_next_y ) ) {\n\n\t\t\t\t\t\t\tdirection_eq = true;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tif ( direction_eq ) {\n\n\t\t\t\t\t// console.log(\"Warning: lines are a straight sequence\");\n\t\t\t\t\tv_trans_x = - v_prev_y;\n\t\t\t\t\tv_trans_y = v_prev_x;\n\t\t\t\t\tshrink_by = Math.sqrt( v_prev_lensq );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// console.log(\"Warning: lines are a straight spike\");\n\t\t\t\t\tv_trans_x = v_prev_x;\n\t\t\t\t\tv_trans_y = v_prev_y;\n\t\t\t\t\tshrink_by = Math.sqrt( v_prev_lensq / 2 );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn new Vector2( v_trans_x / shrink_by, v_trans_y / shrink_by );\n\n\t\t}\n\n\n\t\tvar contourMovements = [];\n\n\t\tfor ( var i = 0, il = contour.length, j = il - 1, k = i + 1; i < il; i ++, j ++, k ++ ) {\n\n\t\t\tif ( j === il ) j = 0;\n\t\t\tif ( k === il ) k = 0;\n\n\t\t\t//  (j)---(i)---(k)\n\t\t\t// console.log('i,j,k', i, j , k)\n\n\t\t\tcontourMovements[ i ] = getBevelVec( contour[ i ], contour[ j ], contour[ k ] );\n\n\t\t}\n\n\t\tvar holesMovements = [],\n\t\t\toneHoleMovements, verticesMovements = contourMovements.concat();\n\n\t\tfor ( h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\tahole = holes[ h ];\n\n\t\t\toneHoleMovements = [];\n\n\t\t\tfor ( i = 0, il = ahole.length, j = il - 1, k = i + 1; i < il; i ++, j ++, k ++ ) {\n\n\t\t\t\tif ( j === il ) j = 0;\n\t\t\t\tif ( k === il ) k = 0;\n\n\t\t\t\t//  (j)---(i)---(k)\n\t\t\t\toneHoleMovements[ i ] = getBevelVec( ahole[ i ], ahole[ j ], ahole[ k ] );\n\n\t\t\t}\n\n\t\t\tholesMovements.push( oneHoleMovements );\n\t\t\tverticesMovements = verticesMovements.concat( oneHoleMovements );\n\n\t\t}\n\n\n\t\t// Loop bevelSegments, 1 for the front, 1 for the back\n\n\t\tfor ( b = 0; b < bevelSegments; b ++ ) {\n\n\t\t\t//for ( b = bevelSegments; b > 0; b -- ) {\n\n\t\t\tt = b / bevelSegments;\n\t\t\tz = bevelThickness * Math.cos( t * Math.PI / 2 );\n\t\t\tbs = bevelSize * Math.sin( t * Math.PI / 2 );\n\n\t\t\t// contract shape\n\n\t\t\tfor ( i = 0, il = contour.length; i < il; i ++ ) {\n\n\t\t\t\tvert = scalePt2( contour[ i ], contourMovements[ i ], bs );\n\n\t\t\t\tv( vert.x, vert.y, - z );\n\n\t\t\t}\n\n\t\t\t// expand holes\n\n\t\t\tfor ( h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\tahole = holes[ h ];\n\t\t\t\toneHoleMovements = holesMovements[ h ];\n\n\t\t\t\tfor ( i = 0, il = ahole.length; i < il; i ++ ) {\n\n\t\t\t\t\tvert = scalePt2( ahole[ i ], oneHoleMovements[ i ], bs );\n\n\t\t\t\t\tv( vert.x, vert.y, - z );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tbs = bevelSize;\n\n\t\t// Back facing vertices\n\n\t\tfor ( i = 0; i < vlen; i ++ ) {\n\n\t\t\tvert = bevelEnabled ? scalePt2( vertices[ i ], verticesMovements[ i ], bs ) : vertices[ i ];\n\n\t\t\tif ( ! extrudeByPath ) {\n\n\t\t\t\tv( vert.x, vert.y, 0 );\n\n\t\t\t} else {\n\n\t\t\t\t// v( vert.x, vert.y + extrudePts[ 0 ].y, extrudePts[ 0 ].x );\n\n\t\t\t\tnormal.copy( splineTube.normals[ 0 ] ).multiplyScalar( vert.x );\n\t\t\t\tbinormal.copy( splineTube.binormals[ 0 ] ).multiplyScalar( vert.y );\n\n\t\t\t\tposition2.copy( extrudePts[ 0 ] ).add( normal ).add( binormal );\n\n\t\t\t\tv( position2.x, position2.y, position2.z );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Add stepped vertices...\n\t\t// Including front facing vertices\n\n\t\tvar s;\n\n\t\tfor ( s = 1; s <= steps; s ++ ) {\n\n\t\t\tfor ( i = 0; i < vlen; i ++ ) {\n\n\t\t\t\tvert = bevelEnabled ? scalePt2( vertices[ i ], verticesMovements[ i ], bs ) : vertices[ i ];\n\n\t\t\t\tif ( ! extrudeByPath ) {\n\n\t\t\t\t\tv( vert.x, vert.y, amount / steps * s );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// v( vert.x, vert.y + extrudePts[ s - 1 ].y, extrudePts[ s - 1 ].x );\n\n\t\t\t\t\tnormal.copy( splineTube.normals[ s ] ).multiplyScalar( vert.x );\n\t\t\t\t\tbinormal.copy( splineTube.binormals[ s ] ).multiplyScalar( vert.y );\n\n\t\t\t\t\tposition2.copy( extrudePts[ s ] ).add( normal ).add( binormal );\n\n\t\t\t\t\tv( position2.x, position2.y, position2.z );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\n\t\t// Add bevel segments planes\n\n\t\t//for ( b = 1; b <= bevelSegments; b ++ ) {\n\t\tfor ( b = bevelSegments - 1; b >= 0; b -- ) {\n\n\t\t\tt = b / bevelSegments;\n\t\t\tz = bevelThickness * Math.cos( t * Math.PI / 2 );\n\t\t\tbs = bevelSize * Math.sin( t * Math.PI / 2 );\n\n\t\t\t// contract shape\n\n\t\t\tfor ( i = 0, il = contour.length; i < il; i ++ ) {\n\n\t\t\t\tvert = scalePt2( contour[ i ], contourMovements[ i ], bs );\n\t\t\t\tv( vert.x, vert.y, amount + z );\n\n\t\t\t}\n\n\t\t\t// expand holes\n\n\t\t\tfor ( h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\tahole = holes[ h ];\n\t\t\t\toneHoleMovements = holesMovements[ h ];\n\n\t\t\t\tfor ( i = 0, il = ahole.length; i < il; i ++ ) {\n\n\t\t\t\t\tvert = scalePt2( ahole[ i ], oneHoleMovements[ i ], bs );\n\n\t\t\t\t\tif ( ! extrudeByPath ) {\n\n\t\t\t\t\t\tv( vert.x, vert.y, amount + z );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tv( vert.x, vert.y + extrudePts[ steps - 1 ].y, extrudePts[ steps - 1 ].x + z );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t/* Faces */\n\n\t\t// Top and bottom faces\n\n\t\tbuildLidFaces();\n\n\t\t// Sides faces\n\n\t\tbuildSideFaces();\n\n\n\t\t/////  Internal functions\n\n\t\tfunction buildLidFaces() {\n\n\t\t\tvar start = verticesArray.length / 3;\n\n\t\t\tif ( bevelEnabled ) {\n\n\t\t\t\tvar layer = 0; // steps + 1\n\t\t\t\tvar offset = vlen * layer;\n\n\t\t\t\t// Bottom faces\n\n\t\t\t\tfor ( i = 0; i < flen; i ++ ) {\n\n\t\t\t\t\tface = faces[ i ];\n\t\t\t\t\tf3( face[ 2 ] + offset, face[ 1 ] + offset, face[ 0 ] + offset );\n\n\t\t\t\t}\n\n\t\t\t\tlayer = steps + bevelSegments * 2;\n\t\t\t\toffset = vlen * layer;\n\n\t\t\t\t// Top faces\n\n\t\t\t\tfor ( i = 0; i < flen; i ++ ) {\n\n\t\t\t\t\tface = faces[ i ];\n\t\t\t\t\tf3( face[ 0 ] + offset, face[ 1 ] + offset, face[ 2 ] + offset );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// Bottom faces\n\n\t\t\t\tfor ( i = 0; i < flen; i ++ ) {\n\n\t\t\t\t\tface = faces[ i ];\n\t\t\t\t\tf3( face[ 2 ], face[ 1 ], face[ 0 ] );\n\n\t\t\t\t}\n\n\t\t\t\t// Top faces\n\n\t\t\t\tfor ( i = 0; i < flen; i ++ ) {\n\n\t\t\t\t\tface = faces[ i ];\n\t\t\t\t\tf3( face[ 0 ] + vlen * steps, face[ 1 ] + vlen * steps, face[ 2 ] + vlen * steps );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tscope.addGroup( start, verticesArray.length / 3 - start, 0 );\n\n\t\t}\n\n\t\t// Create faces for the z-sides of the shape\n\n\t\tfunction buildSideFaces() {\n\n\t\t\tvar start = verticesArray.length / 3;\n\t\t\tvar layeroffset = 0;\n\t\t\tsidewalls( contour, layeroffset );\n\t\t\tlayeroffset += contour.length;\n\n\t\t\tfor ( h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\tahole = holes[ h ];\n\t\t\t\tsidewalls( ahole, layeroffset );\n\n\t\t\t\t//, true\n\t\t\t\tlayeroffset += ahole.length;\n\n\t\t\t}\n\n\n\t\t\tscope.addGroup( start, verticesArray.length / 3 - start, 1 );\n\n\n\t\t}\n\n\t\tfunction sidewalls( contour, layeroffset ) {\n\n\t\t\tvar j, k;\n\t\t\ti = contour.length;\n\n\t\t\twhile ( -- i >= 0 ) {\n\n\t\t\t\tj = i;\n\t\t\t\tk = i - 1;\n\t\t\t\tif ( k < 0 ) k = contour.length - 1;\n\n\t\t\t\t//console.log('b', i,j, i-1, k,vertices.length);\n\n\t\t\t\tvar s = 0,\n\t\t\t\t\tsl = steps + bevelSegments * 2;\n\n\t\t\t\tfor ( s = 0; s < sl; s ++ ) {\n\n\t\t\t\t\tvar slen1 = vlen * s;\n\t\t\t\t\tvar slen2 = vlen * ( s + 1 );\n\n\t\t\t\t\tvar a = layeroffset + j + slen1,\n\t\t\t\t\t\tb = layeroffset + k + slen1,\n\t\t\t\t\t\tc = layeroffset + k + slen2,\n\t\t\t\t\t\td = layeroffset + j + slen2;\n\n\t\t\t\t\tf4( a, b, c, d );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction v( x, y, z ) {\n\n\t\t\tplaceholder.push( x );\n\t\t\tplaceholder.push( y );\n\t\t\tplaceholder.push( z );\n\n\t\t}\n\n\n\t\tfunction f3( a, b, c ) {\n\n\t\t\taddVertex( a );\n\t\t\taddVertex( b );\n\t\t\taddVertex( c );\n\n\t\t\tvar nextIndex = verticesArray.length / 3;\n\t\t\tvar uvs = uvgen.generateTopUV( scope, verticesArray, nextIndex - 3, nextIndex - 2, nextIndex - 1 );\n\n\t\t\taddUV( uvs[ 0 ] );\n\t\t\taddUV( uvs[ 1 ] );\n\t\t\taddUV( uvs[ 2 ] );\n\n\t\t}\n\n\t\tfunction f4( a, b, c, d ) {\n\n\t\t\taddVertex( a );\n\t\t\taddVertex( b );\n\t\t\taddVertex( d );\n\n\t\t\taddVertex( b );\n\t\t\taddVertex( c );\n\t\t\taddVertex( d );\n\n\n\t\t\tvar nextIndex = verticesArray.length / 3;\n\t\t\tvar uvs = uvgen.generateSideWallUV( scope, verticesArray, nextIndex - 6, nextIndex - 3, nextIndex - 2, nextIndex - 1 );\n\n\t\t\taddUV( uvs[ 0 ] );\n\t\t\taddUV( uvs[ 1 ] );\n\t\t\taddUV( uvs[ 3 ] );\n\n\t\t\taddUV( uvs[ 1 ] );\n\t\t\taddUV( uvs[ 2 ] );\n\t\t\taddUV( uvs[ 3 ] );\n\n\t\t}\n\n\t\tfunction addVertex( index ) {\n\n\t\t\tverticesArray.push( placeholder[ index * 3 + 0 ] );\n\t\t\tverticesArray.push( placeholder[ index * 3 + 1 ] );\n\t\t\tverticesArray.push( placeholder[ index * 3 + 2 ] );\n\n\t\t}\n\n\n\t\tfunction addUV( vector2 ) {\n\n\t\t\tuvArray.push( vector2.x );\n\t\t\tuvArray.push( vector2.y );\n\n\t\t}\n\n\t}\n\n}\n\nExtrudeBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nExtrudeBufferGeometry.prototype.constructor = ExtrudeBufferGeometry;\n\nvar WorldUVGenerator = {\n\n\tgenerateTopUV: function ( geometry, vertices, indexA, indexB, indexC ) {\n\n\t\tvar a_x = vertices[ indexA * 3 ];\n\t\tvar a_y = vertices[ indexA * 3 + 1 ];\n\t\tvar b_x = vertices[ indexB * 3 ];\n\t\tvar b_y = vertices[ indexB * 3 + 1 ];\n\t\tvar c_x = vertices[ indexC * 3 ];\n\t\tvar c_y = vertices[ indexC * 3 + 1 ];\n\n\t\treturn [\n\t\t\tnew Vector2( a_x, a_y ),\n\t\t\tnew Vector2( b_x, b_y ),\n\t\t\tnew Vector2( c_x, c_y )\n\t\t];\n\n\t},\n\n\tgenerateSideWallUV: function ( geometry, vertices, indexA, indexB, indexC, indexD ) {\n\n\t\tvar a_x = vertices[ indexA * 3 ];\n\t\tvar a_y = vertices[ indexA * 3 + 1 ];\n\t\tvar a_z = vertices[ indexA * 3 + 2 ];\n\t\tvar b_x = vertices[ indexB * 3 ];\n\t\tvar b_y = vertices[ indexB * 3 + 1 ];\n\t\tvar b_z = vertices[ indexB * 3 + 2 ];\n\t\tvar c_x = vertices[ indexC * 3 ];\n\t\tvar c_y = vertices[ indexC * 3 + 1 ];\n\t\tvar c_z = vertices[ indexC * 3 + 2 ];\n\t\tvar d_x = vertices[ indexD * 3 ];\n\t\tvar d_y = vertices[ indexD * 3 + 1 ];\n\t\tvar d_z = vertices[ indexD * 3 + 2 ];\n\n\t\tif ( Math.abs( a_y - b_y ) < 0.01 ) {\n\n\t\t\treturn [\n\t\t\t\tnew Vector2( a_x, 1 - a_z ),\n\t\t\t\tnew Vector2( b_x, 1 - b_z ),\n\t\t\t\tnew Vector2( c_x, 1 - c_z ),\n\t\t\t\tnew Vector2( d_x, 1 - d_z )\n\t\t\t];\n\n\t\t} else {\n\n\t\t\treturn [\n\t\t\t\tnew Vector2( a_y, 1 - a_z ),\n\t\t\t\tnew Vector2( b_y, 1 - b_z ),\n\t\t\t\tnew Vector2( c_y, 1 - c_z ),\n\t\t\t\tnew Vector2( d_y, 1 - d_z )\n\t\t\t];\n\n\t\t}\n\n\t}\n};\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n * @author alteredq / http://alteredqualia.com/\n *\n * Text = 3D Text\n *\n * parameters = {\n *  font: <THREE.Font>, // font\n *\n *  size: <float>, // size of the text\n *  height: <float>, // thickness to extrude text\n *  curveSegments: <int>, // number of points on the curves\n *\n *  bevelEnabled: <bool>, // turn on bevel\n *  bevelThickness: <float>, // how deep into text bevel goes\n *  bevelSize: <float> // how far from text outline is bevel\n * }\n */\n\n// TextGeometry\n\nfunction TextGeometry( text, parameters ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'TextGeometry';\n\n\tthis.parameters = {\n\t\ttext: text,\n\t\tparameters: parameters\n\t};\n\n\tthis.fromBufferGeometry( new TextBufferGeometry( text, parameters ) );\n\tthis.mergeVertices();\n\n}\n\nTextGeometry.prototype = Object.create( Geometry.prototype );\nTextGeometry.prototype.constructor = TextGeometry;\n\n// TextBufferGeometry\n\nfunction TextBufferGeometry( text, parameters ) {\n\n\tparameters = parameters || {};\n\n\tvar font = parameters.font;\n\n\tif ( ! ( font && font.isFont ) ) {\n\n\t\tconsole.error( 'THREE.TextGeometry: font parameter is not an instance of THREE.Font.' );\n\t\treturn new Geometry();\n\n\t}\n\n\tvar shapes = font.generateShapes( text, parameters.size, parameters.curveSegments );\n\n\t// translate parameters to ExtrudeGeometry API\n\n\tparameters.amount = parameters.height !== undefined ? parameters.height : 50;\n\n\t// defaults\n\n\tif ( parameters.bevelThickness === undefined ) parameters.bevelThickness = 10;\n\tif ( parameters.bevelSize === undefined ) parameters.bevelSize = 8;\n\tif ( parameters.bevelEnabled === undefined ) parameters.bevelEnabled = false;\n\n\tExtrudeBufferGeometry.call( this, shapes, parameters );\n\n\tthis.type = 'TextBufferGeometry';\n\n}\n\nTextBufferGeometry.prototype = Object.create( ExtrudeBufferGeometry.prototype );\nTextBufferGeometry.prototype.constructor = TextBufferGeometry;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author benaadams / https://twitter.com/ben_a_adams\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// SphereGeometry\n\nfunction SphereGeometry( radius, widthSegments, heightSegments, phiStart, phiLength, thetaStart, thetaLength ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'SphereGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\twidthSegments: widthSegments,\n\t\theightSegments: heightSegments,\n\t\tphiStart: phiStart,\n\t\tphiLength: phiLength,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n\tthis.fromBufferGeometry( new SphereBufferGeometry( radius, widthSegments, heightSegments, phiStart, phiLength, thetaStart, thetaLength ) );\n\tthis.mergeVertices();\n\n}\n\nSphereGeometry.prototype = Object.create( Geometry.prototype );\nSphereGeometry.prototype.constructor = SphereGeometry;\n\n// SphereBufferGeometry\n\nfunction SphereBufferGeometry( radius, widthSegments, heightSegments, phiStart, phiLength, thetaStart, thetaLength ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'SphereBufferGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\twidthSegments: widthSegments,\n\t\theightSegments: heightSegments,\n\t\tphiStart: phiStart,\n\t\tphiLength: phiLength,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n\tradius = radius || 1;\n\n\twidthSegments = Math.max( 3, Math.floor( widthSegments ) || 8 );\n\theightSegments = Math.max( 2, Math.floor( heightSegments ) || 6 );\n\n\tphiStart = phiStart !== undefined ? phiStart : 0;\n\tphiLength = phiLength !== undefined ? phiLength : Math.PI * 2;\n\n\tthetaStart = thetaStart !== undefined ? thetaStart : 0;\n\tthetaLength = thetaLength !== undefined ? thetaLength : Math.PI;\n\n\tvar thetaEnd = thetaStart + thetaLength;\n\n\tvar ix, iy;\n\n\tvar index = 0;\n\tvar grid = [];\n\n\tvar vertex = new Vector3();\n\tvar normal = new Vector3();\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\t// generate vertices, normals and uvs\n\n\tfor ( iy = 0; iy <= heightSegments; iy ++ ) {\n\n\t\tvar verticesRow = [];\n\n\t\tvar v = iy / heightSegments;\n\n\t\tfor ( ix = 0; ix <= widthSegments; ix ++ ) {\n\n\t\t\tvar u = ix / widthSegments;\n\n\t\t\t// vertex\n\n\t\t\tvertex.x = - radius * Math.cos( phiStart + u * phiLength ) * Math.sin( thetaStart + v * thetaLength );\n\t\t\tvertex.y = radius * Math.cos( thetaStart + v * thetaLength );\n\t\t\tvertex.z = radius * Math.sin( phiStart + u * phiLength ) * Math.sin( thetaStart + v * thetaLength );\n\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t// normal\n\n\t\t\tnormal.set( vertex.x, vertex.y, vertex.z ).normalize();\n\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t// uv\n\n\t\t\tuvs.push( u, 1 - v );\n\n\t\t\tverticesRow.push( index ++ );\n\n\t\t}\n\n\t\tgrid.push( verticesRow );\n\n\t}\n\n\t// indices\n\n\tfor ( iy = 0; iy < heightSegments; iy ++ ) {\n\n\t\tfor ( ix = 0; ix < widthSegments; ix ++ ) {\n\n\t\t\tvar a = grid[ iy ][ ix + 1 ];\n\t\t\tvar b = grid[ iy ][ ix ];\n\t\t\tvar c = grid[ iy + 1 ][ ix ];\n\t\t\tvar d = grid[ iy + 1 ][ ix + 1 ];\n\n\t\t\tif ( iy !== 0 || thetaStart > 0 ) indices.push( a, b, d );\n\t\t\tif ( iy !== heightSegments - 1 || thetaEnd < Math.PI ) indices.push( b, c, d );\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n}\n\nSphereBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nSphereBufferGeometry.prototype.constructor = SphereBufferGeometry;\n\n/**\n * @author Kaleb Murphy\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// RingGeometry\n\nfunction RingGeometry( innerRadius, outerRadius, thetaSegments, phiSegments, thetaStart, thetaLength ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'RingGeometry';\n\n\tthis.parameters = {\n\t\tinnerRadius: innerRadius,\n\t\touterRadius: outerRadius,\n\t\tthetaSegments: thetaSegments,\n\t\tphiSegments: phiSegments,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n\tthis.fromBufferGeometry( new RingBufferGeometry( innerRadius, outerRadius, thetaSegments, phiSegments, thetaStart, thetaLength ) );\n\tthis.mergeVertices();\n\n}\n\nRingGeometry.prototype = Object.create( Geometry.prototype );\nRingGeometry.prototype.constructor = RingGeometry;\n\n// RingBufferGeometry\n\nfunction RingBufferGeometry( innerRadius, outerRadius, thetaSegments, phiSegments, thetaStart, thetaLength ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'RingBufferGeometry';\n\n\tthis.parameters = {\n\t\tinnerRadius: innerRadius,\n\t\touterRadius: outerRadius,\n\t\tthetaSegments: thetaSegments,\n\t\tphiSegments: phiSegments,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n\tinnerRadius = innerRadius || 0.5;\n\touterRadius = outerRadius || 1;\n\n\tthetaStart = thetaStart !== undefined ? thetaStart : 0;\n\tthetaLength = thetaLength !== undefined ? thetaLength : Math.PI * 2;\n\n\tthetaSegments = thetaSegments !== undefined ? Math.max( 3, thetaSegments ) : 8;\n\tphiSegments = phiSegments !== undefined ? Math.max( 1, phiSegments ) : 1;\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\t// some helper variables\n\n\tvar segment;\n\tvar radius = innerRadius;\n\tvar radiusStep = ( ( outerRadius - innerRadius ) / phiSegments );\n\tvar vertex = new Vector3();\n\tvar uv = new Vector2();\n\tvar j, i;\n\n\t// generate vertices, normals and uvs\n\n\tfor ( j = 0; j <= phiSegments; j ++ ) {\n\n\t\tfor ( i = 0; i <= thetaSegments; i ++ ) {\n\n\t\t\t// values are generate from the inside of the ring to the outside\n\n\t\t\tsegment = thetaStart + i / thetaSegments * thetaLength;\n\n\t\t\t// vertex\n\n\t\t\tvertex.x = radius * Math.cos( segment );\n\t\t\tvertex.y = radius * Math.sin( segment );\n\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t// normal\n\n\t\t\tnormals.push( 0, 0, 1 );\n\n\t\t\t// uv\n\n\t\t\tuv.x = ( vertex.x / outerRadius + 1 ) / 2;\n\t\t\tuv.y = ( vertex.y / outerRadius + 1 ) / 2;\n\n\t\t\tuvs.push( uv.x, uv.y );\n\n\t\t}\n\n\t\t// increase the radius for next row of vertices\n\n\t\tradius += radiusStep;\n\n\t}\n\n\t// indices\n\n\tfor ( j = 0; j < phiSegments; j ++ ) {\n\n\t\tvar thetaSegmentLevel = j * ( thetaSegments + 1 );\n\n\t\tfor ( i = 0; i < thetaSegments; i ++ ) {\n\n\t\t\tsegment = i + thetaSegmentLevel;\n\n\t\t\tvar a = segment;\n\t\t\tvar b = segment + thetaSegments + 1;\n\t\t\tvar c = segment + thetaSegments + 2;\n\t\t\tvar d = segment + 1;\n\n\t\t\t// faces\n\n\t\t\tindices.push( a, b, d );\n\t\t\tindices.push( b, c, d );\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n}\n\nRingBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nRingBufferGeometry.prototype.constructor = RingBufferGeometry;\n\n/**\n * @author astrodud / http://astrodud.isgreat.org/\n * @author zz85 / https://github.com/zz85\n * @author bhouston / http://clara.io\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// LatheGeometry\n\nfunction LatheGeometry( points, segments, phiStart, phiLength ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'LatheGeometry';\n\n\tthis.parameters = {\n\t\tpoints: points,\n\t\tsegments: segments,\n\t\tphiStart: phiStart,\n\t\tphiLength: phiLength\n\t};\n\n\tthis.fromBufferGeometry( new LatheBufferGeometry( points, segments, phiStart, phiLength ) );\n\tthis.mergeVertices();\n\n}\n\nLatheGeometry.prototype = Object.create( Geometry.prototype );\nLatheGeometry.prototype.constructor = LatheGeometry;\n\n// LatheBufferGeometry\n\nfunction LatheBufferGeometry( points, segments, phiStart, phiLength ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'LatheBufferGeometry';\n\n\tthis.parameters = {\n\t\tpoints: points,\n\t\tsegments: segments,\n\t\tphiStart: phiStart,\n\t\tphiLength: phiLength\n\t};\n\n\tsegments = Math.floor( segments ) || 12;\n\tphiStart = phiStart || 0;\n\tphiLength = phiLength || Math.PI * 2;\n\n\t// clamp phiLength so it's in range of [ 0, 2PI ]\n\n\tphiLength = _Math.clamp( phiLength, 0, Math.PI * 2 );\n\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar uvs = [];\n\n\t// helper variables\n\n\tvar base;\n\tvar inverseSegments = 1.0 / segments;\n\tvar vertex = new Vector3();\n\tvar uv = new Vector2();\n\tvar i, j;\n\n\t// generate vertices and uvs\n\n\tfor ( i = 0; i <= segments; i ++ ) {\n\n\t\tvar phi = phiStart + i * inverseSegments * phiLength;\n\n\t\tvar sin = Math.sin( phi );\n\t\tvar cos = Math.cos( phi );\n\n\t\tfor ( j = 0; j <= ( points.length - 1 ); j ++ ) {\n\n\t\t\t// vertex\n\n\t\t\tvertex.x = points[ j ].x * sin;\n\t\t\tvertex.y = points[ j ].y;\n\t\t\tvertex.z = points[ j ].x * cos;\n\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t// uv\n\n\t\t\tuv.x = i / segments;\n\t\t\tuv.y = j / ( points.length - 1 );\n\n\t\t\tuvs.push( uv.x, uv.y );\n\n\n\t\t}\n\n\t}\n\n\t// indices\n\n\tfor ( i = 0; i < segments; i ++ ) {\n\n\t\tfor ( j = 0; j < ( points.length - 1 ); j ++ ) {\n\n\t\t\tbase = j + i * points.length;\n\n\t\t\tvar a = base;\n\t\t\tvar b = base + points.length;\n\t\t\tvar c = base + points.length + 1;\n\t\t\tvar d = base + 1;\n\n\t\t\t// faces\n\n\t\t\tindices.push( a, b, d );\n\t\t\tindices.push( b, c, d );\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t// generate normals\n\n\tthis.computeVertexNormals();\n\n\t// if the geometry is closed, we need to average the normals along the seam.\n\t// because the corresponding vertices are identical (but still have different UVs).\n\n\tif ( phiLength === Math.PI * 2 ) {\n\n\t\tvar normals = this.attributes.normal.array;\n\t\tvar n1 = new Vector3();\n\t\tvar n2 = new Vector3();\n\t\tvar n = new Vector3();\n\n\t\t// this is the buffer offset for the last line of vertices\n\n\t\tbase = segments * points.length * 3;\n\n\t\tfor ( i = 0, j = 0; i < points.length; i ++, j += 3 ) {\n\n\t\t\t// select the normal of the vertex in the first line\n\n\t\t\tn1.x = normals[ j + 0 ];\n\t\t\tn1.y = normals[ j + 1 ];\n\t\t\tn1.z = normals[ j + 2 ];\n\n\t\t\t// select the normal of the vertex in the last line\n\n\t\t\tn2.x = normals[ base + j + 0 ];\n\t\t\tn2.y = normals[ base + j + 1 ];\n\t\t\tn2.z = normals[ base + j + 2 ];\n\n\t\t\t// average normals\n\n\t\t\tn.addVectors( n1, n2 ).normalize();\n\n\t\t\t// assign the new values to both normals\n\n\t\t\tnormals[ j + 0 ] = normals[ base + j + 0 ] = n.x;\n\t\t\tnormals[ j + 1 ] = normals[ base + j + 1 ] = n.y;\n\t\t\tnormals[ j + 2 ] = normals[ base + j + 2 ] = n.z;\n\n\t\t}\n\n\t}\n\n}\n\nLatheBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nLatheBufferGeometry.prototype.constructor = LatheBufferGeometry;\n\n/**\n * @author jonobr1 / http://jonobr1.com\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// ShapeGeometry\n\nfunction ShapeGeometry( shapes, curveSegments ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'ShapeGeometry';\n\n\tif ( typeof curveSegments === 'object' ) {\n\n\t\tconsole.warn( 'THREE.ShapeGeometry: Options parameter has been removed.' );\n\n\t\tcurveSegments = curveSegments.curveSegments;\n\n\t}\n\n\tthis.parameters = {\n\t\tshapes: shapes,\n\t\tcurveSegments: curveSegments\n\t};\n\n\tthis.fromBufferGeometry( new ShapeBufferGeometry( shapes, curveSegments ) );\n\tthis.mergeVertices();\n\n}\n\nShapeGeometry.prototype = Object.create( Geometry.prototype );\nShapeGeometry.prototype.constructor = ShapeGeometry;\n\nShapeGeometry.prototype.toJSON = function () {\n\n\tvar data = Geometry.prototype.toJSON.call( this );\n\n\tvar shapes = this.parameters.shapes;\n\n\treturn toJSON( shapes, data );\n\n};\n\n// ShapeBufferGeometry\n\nfunction ShapeBufferGeometry( shapes, curveSegments ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'ShapeBufferGeometry';\n\n\tthis.parameters = {\n\t\tshapes: shapes,\n\t\tcurveSegments: curveSegments\n\t};\n\n\tcurveSegments = curveSegments || 12;\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\t// helper variables\n\n\tvar groupStart = 0;\n\tvar groupCount = 0;\n\n\t// allow single and array values for \"shapes\" parameter\n\n\tif ( Array.isArray( shapes ) === false ) {\n\n\t\taddShape( shapes );\n\n\t} else {\n\n\t\tfor ( var i = 0; i < shapes.length; i ++ ) {\n\n\t\t\taddShape( shapes[ i ] );\n\n\t\t\tthis.addGroup( groupStart, groupCount, i ); // enables MultiMaterial support\n\n\t\t\tgroupStart += groupCount;\n\t\t\tgroupCount = 0;\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\n\t// helper functions\n\n\tfunction addShape( shape ) {\n\n\t\tvar i, l, shapeHole;\n\n\t\tvar indexOffset = vertices.length / 3;\n\t\tvar points = shape.extractPoints( curveSegments );\n\n\t\tvar shapeVertices = points.shape;\n\t\tvar shapeHoles = points.holes;\n\n\t\t// check direction of vertices\n\n\t\tif ( ShapeUtils.isClockWise( shapeVertices ) === false ) {\n\n\t\t\tshapeVertices = shapeVertices.reverse();\n\n\t\t\t// also check if holes are in the opposite direction\n\n\t\t\tfor ( i = 0, l = shapeHoles.length; i < l; i ++ ) {\n\n\t\t\t\tshapeHole = shapeHoles[ i ];\n\n\t\t\t\tif ( ShapeUtils.isClockWise( shapeHole ) === true ) {\n\n\t\t\t\t\tshapeHoles[ i ] = shapeHole.reverse();\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar faces = ShapeUtils.triangulateShape( shapeVertices, shapeHoles );\n\n\t\t// join vertices of inner and outer paths to a single array\n\n\t\tfor ( i = 0, l = shapeHoles.length; i < l; i ++ ) {\n\n\t\t\tshapeHole = shapeHoles[ i ];\n\t\t\tshapeVertices = shapeVertices.concat( shapeHole );\n\n\t\t}\n\n\t\t// vertices, normals, uvs\n\n\t\tfor ( i = 0, l = shapeVertices.length; i < l; i ++ ) {\n\n\t\t\tvar vertex = shapeVertices[ i ];\n\n\t\t\tvertices.push( vertex.x, vertex.y, 0 );\n\t\t\tnormals.push( 0, 0, 1 );\n\t\t\tuvs.push( vertex.x, vertex.y ); // world uvs\n\n\t\t}\n\n\t\t// incides\n\n\t\tfor ( i = 0, l = faces.length; i < l; i ++ ) {\n\n\t\t\tvar face = faces[ i ];\n\n\t\t\tvar a = face[ 0 ] + indexOffset;\n\t\t\tvar b = face[ 1 ] + indexOffset;\n\t\t\tvar c = face[ 2 ] + indexOffset;\n\n\t\t\tindices.push( a, b, c );\n\t\t\tgroupCount += 3;\n\n\t\t}\n\n\t}\n\n}\n\nShapeBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nShapeBufferGeometry.prototype.constructor = ShapeBufferGeometry;\n\nShapeBufferGeometry.prototype.toJSON = function () {\n\n\tvar data = BufferGeometry.prototype.toJSON.call( this );\n\n\tvar shapes = this.parameters.shapes;\n\n\treturn toJSON( shapes, data );\n\n};\n\n//\n\nfunction toJSON( shapes, data ) {\n\n\tdata.shapes = [];\n\n\tif ( Array.isArray( shapes ) ) {\n\n\t\tfor ( var i = 0, l = shapes.length; i < l; i ++ ) {\n\n\t\t\tvar shape = shapes[ i ];\n\n\t\t\tdata.shapes.push( shape.uuid );\n\n\t\t}\n\n\t} else {\n\n\t\tdata.shapes.push( shapes.uuid );\n\n\t}\n\n\treturn data;\n\n}\n\n/**\n * @author WestLangley / http://github.com/WestLangley\n * @author Mugen87 / https://github.com/Mugen87\n */\n\nfunction EdgesGeometry( geometry, thresholdAngle ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'EdgesGeometry';\n\n\tthis.parameters = {\n\t\tthresholdAngle: thresholdAngle\n\t};\n\n\tthresholdAngle = ( thresholdAngle !== undefined ) ? thresholdAngle : 1;\n\n\t// buffer\n\n\tvar vertices = [];\n\n\t// helper variables\n\n\tvar thresholdDot = Math.cos( _Math.DEG2RAD * thresholdAngle );\n\tvar edge = [ 0, 0 ], edges = {}, edge1, edge2;\n\tvar key, keys = [ 'a', 'b', 'c' ];\n\n\t// prepare source geometry\n\n\tvar geometry2;\n\n\tif ( geometry.isBufferGeometry ) {\n\n\t\tgeometry2 = new Geometry();\n\t\tgeometry2.fromBufferGeometry( geometry );\n\n\t} else {\n\n\t\tgeometry2 = geometry.clone();\n\n\t}\n\n\tgeometry2.mergeVertices();\n\tgeometry2.computeFaceNormals();\n\n\tvar sourceVertices = geometry2.vertices;\n\tvar faces = geometry2.faces;\n\n\t// now create a data structure where each entry represents an edge with its adjoining faces\n\n\tfor ( var i = 0, l = faces.length; i < l; i ++ ) {\n\n\t\tvar face = faces[ i ];\n\n\t\tfor ( var j = 0; j < 3; j ++ ) {\n\n\t\t\tedge1 = face[ keys[ j ] ];\n\t\t\tedge2 = face[ keys[ ( j + 1 ) % 3 ] ];\n\t\t\tedge[ 0 ] = Math.min( edge1, edge2 );\n\t\t\tedge[ 1 ] = Math.max( edge1, edge2 );\n\n\t\t\tkey = edge[ 0 ] + ',' + edge[ 1 ];\n\n\t\t\tif ( edges[ key ] === undefined ) {\n\n\t\t\t\tedges[ key ] = { index1: edge[ 0 ], index2: edge[ 1 ], face1: i, face2: undefined };\n\n\t\t\t} else {\n\n\t\t\t\tedges[ key ].face2 = i;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t// generate vertices\n\n\tfor ( key in edges ) {\n\n\t\tvar e = edges[ key ];\n\n\t\t// an edge is only rendered if the angle (in degrees) between the face normals of the adjoining faces exceeds this value. default = 1 degree.\n\n\t\tif ( e.face2 === undefined || faces[ e.face1 ].normal.dot( faces[ e.face2 ].normal ) <= thresholdDot ) {\n\n\t\t\tvar vertex = sourceVertices[ e.index1 ];\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\tvertex = sourceVertices[ e.index2 ];\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t}\n\n\t}\n\n\t// build geometry\n\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\n}\n\nEdgesGeometry.prototype = Object.create( BufferGeometry.prototype );\nEdgesGeometry.prototype.constructor = EdgesGeometry;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author Mugen87 / https://github.com/Mugen87\n */\n\n// CylinderGeometry\n\nfunction CylinderGeometry( radiusTop, radiusBottom, height, radialSegments, heightSegments, openEnded, thetaStart, thetaLength ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'CylinderGeometry';\n\n\tthis.parameters = {\n\t\tradiusTop: radiusTop,\n\t\tradiusBottom: radiusBottom,\n\t\theight: height,\n\t\tradialSegments: radialSegments,\n\t\theightSegments: heightSegments,\n\t\topenEnded: openEnded,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n\tthis.fromBufferGeometry( new CylinderBufferGeometry( radiusTop, radiusBottom, height, radialSegments, heightSegments, openEnded, thetaStart, thetaLength ) );\n\tthis.mergeVertices();\n\n}\n\nCylinderGeometry.prototype = Object.create( Geometry.prototype );\nCylinderGeometry.prototype.constructor = CylinderGeometry;\n\n// CylinderBufferGeometry\n\nfunction CylinderBufferGeometry( radiusTop, radiusBottom, height, radialSegments, heightSegments, openEnded, thetaStart, thetaLength ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'CylinderBufferGeometry';\n\n\tthis.parameters = {\n\t\tradiusTop: radiusTop,\n\t\tradiusBottom: radiusBottom,\n\t\theight: height,\n\t\tradialSegments: radialSegments,\n\t\theightSegments: heightSegments,\n\t\topenEnded: openEnded,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n\tvar scope = this;\n\n\tradiusTop = radiusTop !== undefined ? radiusTop : 1;\n\tradiusBottom = radiusBottom !== undefined ? radiusBottom : 1;\n\theight = height || 1;\n\n\tradialSegments = Math.floor( radialSegments ) || 8;\n\theightSegments = Math.floor( heightSegments ) || 1;\n\n\topenEnded = openEnded !== undefined ? openEnded : false;\n\tthetaStart = thetaStart !== undefined ? thetaStart : 0.0;\n\tthetaLength = thetaLength !== undefined ? thetaLength : Math.PI * 2;\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\t// helper variables\n\n\tvar index = 0;\n\tvar indexArray = [];\n\tvar halfHeight = height / 2;\n\tvar groupStart = 0;\n\n\t// generate geometry\n\n\tgenerateTorso();\n\n\tif ( openEnded === false ) {\n\n\t\tif ( radiusTop > 0 ) generateCap( true );\n\t\tif ( radiusBottom > 0 ) generateCap( false );\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\tfunction generateTorso() {\n\n\t\tvar x, y;\n\t\tvar normal = new Vector3();\n\t\tvar vertex = new Vector3();\n\n\t\tvar groupCount = 0;\n\n\t\t// this will be used to calculate the normal\n\t\tvar slope = ( radiusBottom - radiusTop ) / height;\n\n\t\t// generate vertices, normals and uvs\n\n\t\tfor ( y = 0; y <= heightSegments; y ++ ) {\n\n\t\t\tvar indexRow = [];\n\n\t\t\tvar v = y / heightSegments;\n\n\t\t\t// calculate the radius of the current row\n\n\t\t\tvar radius = v * ( radiusBottom - radiusTop ) + radiusTop;\n\n\t\t\tfor ( x = 0; x <= radialSegments; x ++ ) {\n\n\t\t\t\tvar u = x / radialSegments;\n\n\t\t\t\tvar theta = u * thetaLength + thetaStart;\n\n\t\t\t\tvar sinTheta = Math.sin( theta );\n\t\t\t\tvar cosTheta = Math.cos( theta );\n\n\t\t\t\t// vertex\n\n\t\t\t\tvertex.x = radius * sinTheta;\n\t\t\t\tvertex.y = - v * height + halfHeight;\n\t\t\t\tvertex.z = radius * cosTheta;\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t// normal\n\n\t\t\t\tnormal.set( sinTheta, slope, cosTheta ).normalize();\n\t\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t\t// uv\n\n\t\t\t\tuvs.push( u, 1 - v );\n\n\t\t\t\t// save index of vertex in respective row\n\n\t\t\t\tindexRow.push( index ++ );\n\n\t\t\t}\n\n\t\t\t// now save vertices of the row in our index array\n\n\t\t\tindexArray.push( indexRow );\n\n\t\t}\n\n\t\t// generate indices\n\n\t\tfor ( x = 0; x < radialSegments; x ++ ) {\n\n\t\t\tfor ( y = 0; y < heightSegments; y ++ ) {\n\n\t\t\t\t// we use the index array to access the correct indices\n\n\t\t\t\tvar a = indexArray[ y ][ x ];\n\t\t\t\tvar b = indexArray[ y + 1 ][ x ];\n\t\t\t\tvar c = indexArray[ y + 1 ][ x + 1 ];\n\t\t\t\tvar d = indexArray[ y ][ x + 1 ];\n\n\t\t\t\t// faces\n\n\t\t\t\tindices.push( a, b, d );\n\t\t\t\tindices.push( b, c, d );\n\n\t\t\t\t// update group counter\n\n\t\t\t\tgroupCount += 6;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// add a group to the geometry. this will ensure multi material support\n\n\t\tscope.addGroup( groupStart, groupCount, 0 );\n\n\t\t// calculate new start value for groups\n\n\t\tgroupStart += groupCount;\n\n\t}\n\n\tfunction generateCap( top ) {\n\n\t\tvar x, centerIndexStart, centerIndexEnd;\n\n\t\tvar uv = new Vector2();\n\t\tvar vertex = new Vector3();\n\n\t\tvar groupCount = 0;\n\n\t\tvar radius = ( top === true ) ? radiusTop : radiusBottom;\n\t\tvar sign = ( top === true ) ? 1 : - 1;\n\n\t\t// save the index of the first center vertex\n\t\tcenterIndexStart = index;\n\n\t\t// first we generate the center vertex data of the cap.\n\t\t// because the geometry needs one set of uvs per face,\n\t\t// we must generate a center vertex per face/segment\n\n\t\tfor ( x = 1; x <= radialSegments; x ++ ) {\n\n\t\t\t// vertex\n\n\t\t\tvertices.push( 0, halfHeight * sign, 0 );\n\n\t\t\t// normal\n\n\t\t\tnormals.push( 0, sign, 0 );\n\n\t\t\t// uv\n\n\t\t\tuvs.push( 0.5, 0.5 );\n\n\t\t\t// increase index\n\n\t\t\tindex ++;\n\n\t\t}\n\n\t\t// save the index of the last center vertex\n\n\t\tcenterIndexEnd = index;\n\n\t\t// now we generate the surrounding vertices, normals and uvs\n\n\t\tfor ( x = 0; x <= radialSegments; x ++ ) {\n\n\t\t\tvar u = x / radialSegments;\n\t\t\tvar theta = u * thetaLength + thetaStart;\n\n\t\t\tvar cosTheta = Math.cos( theta );\n\t\t\tvar sinTheta = Math.sin( theta );\n\n\t\t\t// vertex\n\n\t\t\tvertex.x = radius * sinTheta;\n\t\t\tvertex.y = halfHeight * sign;\n\t\t\tvertex.z = radius * cosTheta;\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t// normal\n\n\t\t\tnormals.push( 0, sign, 0 );\n\n\t\t\t// uv\n\n\t\t\tuv.x = ( cosTheta * 0.5 ) + 0.5;\n\t\t\tuv.y = ( sinTheta * 0.5 * sign ) + 0.5;\n\t\t\tuvs.push( uv.x, uv.y );\n\n\t\t\t// increase index\n\n\t\t\tindex ++;\n\n\t\t}\n\n\t\t// generate indices\n\n\t\tfor ( x = 0; x < radialSegments; x ++ ) {\n\n\t\t\tvar c = centerIndexStart + x;\n\t\t\tvar i = centerIndexEnd + x;\n\n\t\t\tif ( top === true ) {\n\n\t\t\t\t// face top\n\n\t\t\t\tindices.push( i, i + 1, c );\n\n\t\t\t} else {\n\n\t\t\t\t// face bottom\n\n\t\t\t\tindices.push( i + 1, i, c );\n\n\t\t\t}\n\n\t\t\tgroupCount += 3;\n\n\t\t}\n\n\t\t// add a group to the geometry. this will ensure multi material support\n\n\t\tscope.addGroup( groupStart, groupCount, top === true ? 1 : 2 );\n\n\t\t// calculate new start value for groups\n\n\t\tgroupStart += groupCount;\n\n\t}\n\n}\n\nCylinderBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nCylinderBufferGeometry.prototype.constructor = CylinderBufferGeometry;\n\n/**\n * @author abelnation / http://github.com/abelnation\n */\n\n// ConeGeometry\n\nfunction ConeGeometry( radius, height, radialSegments, heightSegments, openEnded, thetaStart, thetaLength ) {\n\n\tCylinderGeometry.call( this, 0, radius, height, radialSegments, heightSegments, openEnded, thetaStart, thetaLength );\n\n\tthis.type = 'ConeGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\theight: height,\n\t\tradialSegments: radialSegments,\n\t\theightSegments: heightSegments,\n\t\topenEnded: openEnded,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n}\n\nConeGeometry.prototype = Object.create( CylinderGeometry.prototype );\nConeGeometry.prototype.constructor = ConeGeometry;\n\n// ConeBufferGeometry\n\nfunction ConeBufferGeometry( radius, height, radialSegments, heightSegments, openEnded, thetaStart, thetaLength ) {\n\n\tCylinderBufferGeometry.call( this, 0, radius, height, radialSegments, heightSegments, openEnded, thetaStart, thetaLength );\n\n\tthis.type = 'ConeBufferGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\theight: height,\n\t\tradialSegments: radialSegments,\n\t\theightSegments: heightSegments,\n\t\topenEnded: openEnded,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n}\n\nConeBufferGeometry.prototype = Object.create( CylinderBufferGeometry.prototype );\nConeBufferGeometry.prototype.constructor = ConeBufferGeometry;\n\n/**\n * @author benaadams / https://twitter.com/ben_a_adams\n * @author Mugen87 / https://github.com/Mugen87\n * @author hughes\n */\n\n// CircleGeometry\n\nfunction CircleGeometry( radius, segments, thetaStart, thetaLength ) {\n\n\tGeometry.call( this );\n\n\tthis.type = 'CircleGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tsegments: segments,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n\tthis.fromBufferGeometry( new CircleBufferGeometry( radius, segments, thetaStart, thetaLength ) );\n\tthis.mergeVertices();\n\n}\n\nCircleGeometry.prototype = Object.create( Geometry.prototype );\nCircleGeometry.prototype.constructor = CircleGeometry;\n\n// CircleBufferGeometry\n\nfunction CircleBufferGeometry( radius, segments, thetaStart, thetaLength ) {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'CircleBufferGeometry';\n\n\tthis.parameters = {\n\t\tradius: radius,\n\t\tsegments: segments,\n\t\tthetaStart: thetaStart,\n\t\tthetaLength: thetaLength\n\t};\n\n\tradius = radius || 1;\n\tsegments = segments !== undefined ? Math.max( 3, segments ) : 8;\n\n\tthetaStart = thetaStart !== undefined ? thetaStart : 0;\n\tthetaLength = thetaLength !== undefined ? thetaLength : Math.PI * 2;\n\n\t// buffers\n\n\tvar indices = [];\n\tvar vertices = [];\n\tvar normals = [];\n\tvar uvs = [];\n\n\t// helper variables\n\n\tvar i, s;\n\tvar vertex = new Vector3();\n\tvar uv = new Vector2();\n\n\t// center point\n\n\tvertices.push( 0, 0, 0 );\n\tnormals.push( 0, 0, 1 );\n\tuvs.push( 0.5, 0.5 );\n\n\tfor ( s = 0, i = 3; s <= segments; s ++, i += 3 ) {\n\n\t\tvar segment = thetaStart + s / segments * thetaLength;\n\n\t\t// vertex\n\n\t\tvertex.x = radius * Math.cos( segment );\n\t\tvertex.y = radius * Math.sin( segment );\n\n\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t// normal\n\n\t\tnormals.push( 0, 0, 1 );\n\n\t\t// uvs\n\n\t\tuv.x = ( vertices[ i ] / radius + 1 ) / 2;\n\t\tuv.y = ( vertices[ i + 1 ] / radius + 1 ) / 2;\n\n\t\tuvs.push( uv.x, uv.y );\n\n\t}\n\n\t// indices\n\n\tfor ( i = 1; i <= segments; i ++ ) {\n\n\t\tindices.push( i, i + 1, 0 );\n\n\t}\n\n\t// build geometry\n\n\tthis.setIndex( indices );\n\tthis.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tthis.addAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\tthis.addAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n}\n\nCircleBufferGeometry.prototype = Object.create( BufferGeometry.prototype );\nCircleBufferGeometry.prototype.constructor = CircleBufferGeometry;\n\n\n\nvar Geometries = Object.freeze({\n\tWireframeGeometry: WireframeGeometry,\n\tParametricGeometry: ParametricGeometry,\n\tParametricBufferGeometry: ParametricBufferGeometry,\n\tTetrahedronGeometry: TetrahedronGeometry,\n\tTetrahedronBufferGeometry: TetrahedronBufferGeometry,\n\tOctahedronGeometry: OctahedronGeometry,\n\tOctahedronBufferGeometry: OctahedronBufferGeometry,\n\tIcosahedronGeometry: IcosahedronGeometry,\n\tIcosahedronBufferGeometry: IcosahedronBufferGeometry,\n\tDodecahedronGeometry: DodecahedronGeometry,\n\tDodecahedronBufferGeometry: DodecahedronBufferGeometry,\n\tPolyhedronGeometry: PolyhedronGeometry,\n\tPolyhedronBufferGeometry: PolyhedronBufferGeometry,\n\tTubeGeometry: TubeGeometry,\n\tTubeBufferGeometry: TubeBufferGeometry,\n\tTorusKnotGeometry: TorusKnotGeometry,\n\tTorusKnotBufferGeometry: TorusKnotBufferGeometry,\n\tTorusGeometry: TorusGeometry,\n\tTorusBufferGeometry: TorusBufferGeometry,\n\tTextGeometry: TextGeometry,\n\tTextBufferGeometry: TextBufferGeometry,\n\tSphereGeometry: SphereGeometry,\n\tSphereBufferGeometry: SphereBufferGeometry,\n\tRingGeometry: RingGeometry,\n\tRingBufferGeometry: RingBufferGeometry,\n\tPlaneGeometry: PlaneGeometry,\n\tPlaneBufferGeometry: PlaneBufferGeometry,\n\tLatheGeometry: LatheGeometry,\n\tLatheBufferGeometry: LatheBufferGeometry,\n\tShapeGeometry: ShapeGeometry,\n\tShapeBufferGeometry: ShapeBufferGeometry,\n\tExtrudeGeometry: ExtrudeGeometry,\n\tExtrudeBufferGeometry: ExtrudeBufferGeometry,\n\tEdgesGeometry: EdgesGeometry,\n\tConeGeometry: ConeGeometry,\n\tConeBufferGeometry: ConeBufferGeometry,\n\tCylinderGeometry: CylinderGeometry,\n\tCylinderBufferGeometry: CylinderBufferGeometry,\n\tCircleGeometry: CircleGeometry,\n\tCircleBufferGeometry: CircleBufferGeometry,\n\tBoxGeometry: BoxGeometry,\n\tBoxBufferGeometry: BoxBufferGeometry\n});\n\n/**\n * @author mrdoob / http://mrdoob.com/\n *\n * parameters = {\n *  color: <THREE.Color>\n * }\n */\n\nfunction ShadowMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'ShadowMaterial';\n\n\tthis.color = new Color( 0x000000 );\n\tthis.transparent = true;\n\n\tthis.setValues( parameters );\n\n}\n\nShadowMaterial.prototype = Object.create( Material.prototype );\nShadowMaterial.prototype.constructor = ShadowMaterial;\n\nShadowMaterial.prototype.isShadowMaterial = true;\n\nShadowMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.color.copy( source.color );\n\n\treturn this;\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction RawShaderMaterial( parameters ) {\n\n\tShaderMaterial.call( this, parameters );\n\n\tthis.type = 'RawShaderMaterial';\n\n}\n\nRawShaderMaterial.prototype = Object.create( ShaderMaterial.prototype );\nRawShaderMaterial.prototype.constructor = RawShaderMaterial;\n\nRawShaderMaterial.prototype.isRawShaderMaterial = true;\n\n/**\n * @author WestLangley / http://github.com/WestLangley\n *\n * parameters = {\n *  color: <hex>,\n *  roughness: <float>,\n *  metalness: <float>,\n *  opacity: <float>,\n *\n *  map: new THREE.Texture( <Image> ),\n *\n *  lightMap: new THREE.Texture( <Image> ),\n *  lightMapIntensity: <float>\n *\n *  aoMap: new THREE.Texture( <Image> ),\n *  aoMapIntensity: <float>\n *\n *  emissive: <hex>,\n *  emissiveIntensity: <float>\n *  emissiveMap: new THREE.Texture( <Image> ),\n *\n *  bumpMap: new THREE.Texture( <Image> ),\n *  bumpScale: <float>,\n *\n *  normalMap: new THREE.Texture( <Image> ),\n *  normalScale: <Vector2>,\n *\n *  displacementMap: new THREE.Texture( <Image> ),\n *  displacementScale: <float>,\n *  displacementBias: <float>,\n *\n *  roughnessMap: new THREE.Texture( <Image> ),\n *\n *  metalnessMap: new THREE.Texture( <Image> ),\n *\n *  alphaMap: new THREE.Texture( <Image> ),\n *\n *  envMap: new THREE.CubeTexture( [posx, negx, posy, negy, posz, negz] ),\n *  envMapIntensity: <float>\n *\n *  refractionRatio: <float>,\n *\n *  wireframe: <boolean>,\n *  wireframeLinewidth: <float>,\n *\n *  skinning: <bool>,\n *  morphTargets: <bool>,\n *  morphNormals: <bool>\n * }\n */\n\nfunction MeshStandardMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.defines = { 'STANDARD': '' };\n\n\tthis.type = 'MeshStandardMaterial';\n\n\tthis.color = new Color( 0xffffff ); // diffuse\n\tthis.roughness = 0.5;\n\tthis.metalness = 0.5;\n\n\tthis.map = null;\n\n\tthis.lightMap = null;\n\tthis.lightMapIntensity = 1.0;\n\n\tthis.aoMap = null;\n\tthis.aoMapIntensity = 1.0;\n\n\tthis.emissive = new Color( 0x000000 );\n\tthis.emissiveIntensity = 1.0;\n\tthis.emissiveMap = null;\n\n\tthis.bumpMap = null;\n\tthis.bumpScale = 1;\n\n\tthis.normalMap = null;\n\tthis.normalScale = new Vector2( 1, 1 );\n\n\tthis.displacementMap = null;\n\tthis.displacementScale = 1;\n\tthis.displacementBias = 0;\n\n\tthis.roughnessMap = null;\n\n\tthis.metalnessMap = null;\n\n\tthis.alphaMap = null;\n\n\tthis.envMap = null;\n\tthis.envMapIntensity = 1.0;\n\n\tthis.refractionRatio = 0.98;\n\n\tthis.wireframe = false;\n\tthis.wireframeLinewidth = 1;\n\tthis.wireframeLinecap = 'round';\n\tthis.wireframeLinejoin = 'round';\n\n\tthis.skinning = false;\n\tthis.morphTargets = false;\n\tthis.morphNormals = false;\n\n\tthis.setValues( parameters );\n\n}\n\nMeshStandardMaterial.prototype = Object.create( Material.prototype );\nMeshStandardMaterial.prototype.constructor = MeshStandardMaterial;\n\nMeshStandardMaterial.prototype.isMeshStandardMaterial = true;\n\nMeshStandardMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.defines = { 'STANDARD': '' };\n\n\tthis.color.copy( source.color );\n\tthis.roughness = source.roughness;\n\tthis.metalness = source.metalness;\n\n\tthis.map = source.map;\n\n\tthis.lightMap = source.lightMap;\n\tthis.lightMapIntensity = source.lightMapIntensity;\n\n\tthis.aoMap = source.aoMap;\n\tthis.aoMapIntensity = source.aoMapIntensity;\n\n\tthis.emissive.copy( source.emissive );\n\tthis.emissiveMap = source.emissiveMap;\n\tthis.emissiveIntensity = source.emissiveIntensity;\n\n\tthis.bumpMap = source.bumpMap;\n\tthis.bumpScale = source.bumpScale;\n\n\tthis.normalMap = source.normalMap;\n\tthis.normalScale.copy( source.normalScale );\n\n\tthis.displacementMap = source.displacementMap;\n\tthis.displacementScale = source.displacementScale;\n\tthis.displacementBias = source.displacementBias;\n\n\tthis.roughnessMap = source.roughnessMap;\n\n\tthis.metalnessMap = source.metalnessMap;\n\n\tthis.alphaMap = source.alphaMap;\n\n\tthis.envMap = source.envMap;\n\tthis.envMapIntensity = source.envMapIntensity;\n\n\tthis.refractionRatio = source.refractionRatio;\n\n\tthis.wireframe = source.wireframe;\n\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\tthis.wireframeLinecap = source.wireframeLinecap;\n\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\n\tthis.skinning = source.skinning;\n\tthis.morphTargets = source.morphTargets;\n\tthis.morphNormals = source.morphNormals;\n\n\treturn this;\n\n};\n\n/**\n * @author WestLangley / http://github.com/WestLangley\n *\n * parameters = {\n *  reflectivity: <float>\n * }\n */\n\nfunction MeshPhysicalMaterial( parameters ) {\n\n\tMeshStandardMaterial.call( this );\n\n\tthis.defines = { 'PHYSICAL': '' };\n\n\tthis.type = 'MeshPhysicalMaterial';\n\n\tthis.reflectivity = 0.5; // maps to F0 = 0.04\n\n\tthis.clearCoat = 0.0;\n\tthis.clearCoatRoughness = 0.0;\n\n\tthis.setValues( parameters );\n\n}\n\nMeshPhysicalMaterial.prototype = Object.create( MeshStandardMaterial.prototype );\nMeshPhysicalMaterial.prototype.constructor = MeshPhysicalMaterial;\n\nMeshPhysicalMaterial.prototype.isMeshPhysicalMaterial = true;\n\nMeshPhysicalMaterial.prototype.copy = function ( source ) {\n\n\tMeshStandardMaterial.prototype.copy.call( this, source );\n\n\tthis.defines = { 'PHYSICAL': '' };\n\n\tthis.reflectivity = source.reflectivity;\n\n\tthis.clearCoat = source.clearCoat;\n\tthis.clearCoatRoughness = source.clearCoatRoughness;\n\n\treturn this;\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n *\n * parameters = {\n *  color: <hex>,\n *  specular: <hex>,\n *  shininess: <float>,\n *  opacity: <float>,\n *\n *  map: new THREE.Texture( <Image> ),\n *\n *  lightMap: new THREE.Texture( <Image> ),\n *  lightMapIntensity: <float>\n *\n *  aoMap: new THREE.Texture( <Image> ),\n *  aoMapIntensity: <float>\n *\n *  emissive: <hex>,\n *  emissiveIntensity: <float>\n *  emissiveMap: new THREE.Texture( <Image> ),\n *\n *  bumpMap: new THREE.Texture( <Image> ),\n *  bumpScale: <float>,\n *\n *  normalMap: new THREE.Texture( <Image> ),\n *  normalScale: <Vector2>,\n *\n *  displacementMap: new THREE.Texture( <Image> ),\n *  displacementScale: <float>,\n *  displacementBias: <float>,\n *\n *  specularMap: new THREE.Texture( <Image> ),\n *\n *  alphaMap: new THREE.Texture( <Image> ),\n *\n *  envMap: new THREE.CubeTexture( [posx, negx, posy, negy, posz, negz] ),\n *  combine: THREE.Multiply,\n *  reflectivity: <float>,\n *  refractionRatio: <float>,\n *\n *  wireframe: <boolean>,\n *  wireframeLinewidth: <float>,\n *\n *  skinning: <bool>,\n *  morphTargets: <bool>,\n *  morphNormals: <bool>\n * }\n */\n\nfunction MeshPhongMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'MeshPhongMaterial';\n\n\tthis.color = new Color( 0xffffff ); // diffuse\n\tthis.specular = new Color( 0x111111 );\n\tthis.shininess = 30;\n\n\tthis.map = null;\n\n\tthis.lightMap = null;\n\tthis.lightMapIntensity = 1.0;\n\n\tthis.aoMap = null;\n\tthis.aoMapIntensity = 1.0;\n\n\tthis.emissive = new Color( 0x000000 );\n\tthis.emissiveIntensity = 1.0;\n\tthis.emissiveMap = null;\n\n\tthis.bumpMap = null;\n\tthis.bumpScale = 1;\n\n\tthis.normalMap = null;\n\tthis.normalScale = new Vector2( 1, 1 );\n\n\tthis.displacementMap = null;\n\tthis.displacementScale = 1;\n\tthis.displacementBias = 0;\n\n\tthis.specularMap = null;\n\n\tthis.alphaMap = null;\n\n\tthis.envMap = null;\n\tthis.combine = MultiplyOperation;\n\tthis.reflectivity = 1;\n\tthis.refractionRatio = 0.98;\n\n\tthis.wireframe = false;\n\tthis.wireframeLinewidth = 1;\n\tthis.wireframeLinecap = 'round';\n\tthis.wireframeLinejoin = 'round';\n\n\tthis.skinning = false;\n\tthis.morphTargets = false;\n\tthis.morphNormals = false;\n\n\tthis.setValues( parameters );\n\n}\n\nMeshPhongMaterial.prototype = Object.create( Material.prototype );\nMeshPhongMaterial.prototype.constructor = MeshPhongMaterial;\n\nMeshPhongMaterial.prototype.isMeshPhongMaterial = true;\n\nMeshPhongMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.color.copy( source.color );\n\tthis.specular.copy( source.specular );\n\tthis.shininess = source.shininess;\n\n\tthis.map = source.map;\n\n\tthis.lightMap = source.lightMap;\n\tthis.lightMapIntensity = source.lightMapIntensity;\n\n\tthis.aoMap = source.aoMap;\n\tthis.aoMapIntensity = source.aoMapIntensity;\n\n\tthis.emissive.copy( source.emissive );\n\tthis.emissiveMap = source.emissiveMap;\n\tthis.emissiveIntensity = source.emissiveIntensity;\n\n\tthis.bumpMap = source.bumpMap;\n\tthis.bumpScale = source.bumpScale;\n\n\tthis.normalMap = source.normalMap;\n\tthis.normalScale.copy( source.normalScale );\n\n\tthis.displacementMap = source.displacementMap;\n\tthis.displacementScale = source.displacementScale;\n\tthis.displacementBias = source.displacementBias;\n\n\tthis.specularMap = source.specularMap;\n\n\tthis.alphaMap = source.alphaMap;\n\n\tthis.envMap = source.envMap;\n\tthis.combine = source.combine;\n\tthis.reflectivity = source.reflectivity;\n\tthis.refractionRatio = source.refractionRatio;\n\n\tthis.wireframe = source.wireframe;\n\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\tthis.wireframeLinecap = source.wireframeLinecap;\n\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\n\tthis.skinning = source.skinning;\n\tthis.morphTargets = source.morphTargets;\n\tthis.morphNormals = source.morphNormals;\n\n\treturn this;\n\n};\n\n/**\n * @author takahirox / http://github.com/takahirox\n *\n * parameters = {\n *  gradientMap: new THREE.Texture( <Image> )\n * }\n */\n\nfunction MeshToonMaterial( parameters ) {\n\n\tMeshPhongMaterial.call( this );\n\n\tthis.defines = { 'TOON': '' };\n\n\tthis.type = 'MeshToonMaterial';\n\n\tthis.gradientMap = null;\n\n\tthis.setValues( parameters );\n\n}\n\nMeshToonMaterial.prototype = Object.create( MeshPhongMaterial.prototype );\nMeshToonMaterial.prototype.constructor = MeshToonMaterial;\n\nMeshToonMaterial.prototype.isMeshToonMaterial = true;\n\nMeshToonMaterial.prototype.copy = function ( source ) {\n\n\tMeshPhongMaterial.prototype.copy.call( this, source );\n\n\tthis.gradientMap = source.gradientMap;\n\n\treturn this;\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author WestLangley / http://github.com/WestLangley\n *\n * parameters = {\n *  opacity: <float>,\n *\n *  bumpMap: new THREE.Texture( <Image> ),\n *  bumpScale: <float>,\n *\n *  normalMap: new THREE.Texture( <Image> ),\n *  normalScale: <Vector2>,\n *\n *  displacementMap: new THREE.Texture( <Image> ),\n *  displacementScale: <float>,\n *  displacementBias: <float>,\n *\n *  wireframe: <boolean>,\n *  wireframeLinewidth: <float>\n *\n *  skinning: <bool>,\n *  morphTargets: <bool>,\n *  morphNormals: <bool>\n * }\n */\n\nfunction MeshNormalMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'MeshNormalMaterial';\n\n\tthis.bumpMap = null;\n\tthis.bumpScale = 1;\n\n\tthis.normalMap = null;\n\tthis.normalScale = new Vector2( 1, 1 );\n\n\tthis.displacementMap = null;\n\tthis.displacementScale = 1;\n\tthis.displacementBias = 0;\n\n\tthis.wireframe = false;\n\tthis.wireframeLinewidth = 1;\n\n\tthis.fog = false;\n\tthis.lights = false;\n\n\tthis.skinning = false;\n\tthis.morphTargets = false;\n\tthis.morphNormals = false;\n\n\tthis.setValues( parameters );\n\n}\n\nMeshNormalMaterial.prototype = Object.create( Material.prototype );\nMeshNormalMaterial.prototype.constructor = MeshNormalMaterial;\n\nMeshNormalMaterial.prototype.isMeshNormalMaterial = true;\n\nMeshNormalMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.bumpMap = source.bumpMap;\n\tthis.bumpScale = source.bumpScale;\n\n\tthis.normalMap = source.normalMap;\n\tthis.normalScale.copy( source.normalScale );\n\n\tthis.displacementMap = source.displacementMap;\n\tthis.displacementScale = source.displacementScale;\n\tthis.displacementBias = source.displacementBias;\n\n\tthis.wireframe = source.wireframe;\n\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\n\tthis.skinning = source.skinning;\n\tthis.morphTargets = source.morphTargets;\n\tthis.morphNormals = source.morphNormals;\n\n\treturn this;\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n *\n * parameters = {\n *  color: <hex>,\n *  opacity: <float>,\n *\n *  map: new THREE.Texture( <Image> ),\n *\n *  lightMap: new THREE.Texture( <Image> ),\n *  lightMapIntensity: <float>\n *\n *  aoMap: new THREE.Texture( <Image> ),\n *  aoMapIntensity: <float>\n *\n *  emissive: <hex>,\n *  emissiveIntensity: <float>\n *  emissiveMap: new THREE.Texture( <Image> ),\n *\n *  specularMap: new THREE.Texture( <Image> ),\n *\n *  alphaMap: new THREE.Texture( <Image> ),\n *\n *  envMap: new THREE.CubeTexture( [posx, negx, posy, negy, posz, negz] ),\n *  combine: THREE.Multiply,\n *  reflectivity: <float>,\n *  refractionRatio: <float>,\n *\n *  wireframe: <boolean>,\n *  wireframeLinewidth: <float>,\n *\n *  skinning: <bool>,\n *  morphTargets: <bool>,\n *  morphNormals: <bool>\n * }\n */\n\nfunction MeshLambertMaterial( parameters ) {\n\n\tMaterial.call( this );\n\n\tthis.type = 'MeshLambertMaterial';\n\n\tthis.color = new Color( 0xffffff ); // diffuse\n\n\tthis.map = null;\n\n\tthis.lightMap = null;\n\tthis.lightMapIntensity = 1.0;\n\n\tthis.aoMap = null;\n\tthis.aoMapIntensity = 1.0;\n\n\tthis.emissive = new Color( 0x000000 );\n\tthis.emissiveIntensity = 1.0;\n\tthis.emissiveMap = null;\n\n\tthis.specularMap = null;\n\n\tthis.alphaMap = null;\n\n\tthis.envMap = null;\n\tthis.combine = MultiplyOperation;\n\tthis.reflectivity = 1;\n\tthis.refractionRatio = 0.98;\n\n\tthis.wireframe = false;\n\tthis.wireframeLinewidth = 1;\n\tthis.wireframeLinecap = 'round';\n\tthis.wireframeLinejoin = 'round';\n\n\tthis.skinning = false;\n\tthis.morphTargets = false;\n\tthis.morphNormals = false;\n\n\tthis.setValues( parameters );\n\n}\n\nMeshLambertMaterial.prototype = Object.create( Material.prototype );\nMeshLambertMaterial.prototype.constructor = MeshLambertMaterial;\n\nMeshLambertMaterial.prototype.isMeshLambertMaterial = true;\n\nMeshLambertMaterial.prototype.copy = function ( source ) {\n\n\tMaterial.prototype.copy.call( this, source );\n\n\tthis.color.copy( source.color );\n\n\tthis.map = source.map;\n\n\tthis.lightMap = source.lightMap;\n\tthis.lightMapIntensity = source.lightMapIntensity;\n\n\tthis.aoMap = source.aoMap;\n\tthis.aoMapIntensity = source.aoMapIntensity;\n\n\tthis.emissive.copy( source.emissive );\n\tthis.emissiveMap = source.emissiveMap;\n\tthis.emissiveIntensity = source.emissiveIntensity;\n\n\tthis.specularMap = source.specularMap;\n\n\tthis.alphaMap = source.alphaMap;\n\n\tthis.envMap = source.envMap;\n\tthis.combine = source.combine;\n\tthis.reflectivity = source.reflectivity;\n\tthis.refractionRatio = source.refractionRatio;\n\n\tthis.wireframe = source.wireframe;\n\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\tthis.wireframeLinecap = source.wireframeLinecap;\n\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\n\tthis.skinning = source.skinning;\n\tthis.morphTargets = source.morphTargets;\n\tthis.morphNormals = source.morphNormals;\n\n\treturn this;\n\n};\n\n/**\n * @author alteredq / http://alteredqualia.com/\n *\n * parameters = {\n *  color: <hex>,\n *  opacity: <float>,\n *\n *  linewidth: <float>,\n *\n *  scale: <float>,\n *  dashSize: <float>,\n *  gapSize: <float>\n * }\n */\n\nfunction LineDashedMaterial( parameters ) {\n\n\tLineBasicMaterial.call( this );\n\n\tthis.type = 'LineDashedMaterial';\n\n\tthis.scale = 1;\n\tthis.dashSize = 3;\n\tthis.gapSize = 1;\n\n\tthis.setValues( parameters );\n\n}\n\nLineDashedMaterial.prototype = Object.create( LineBasicMaterial.prototype );\nLineDashedMaterial.prototype.constructor = LineDashedMaterial;\n\nLineDashedMaterial.prototype.isLineDashedMaterial = true;\n\nLineDashedMaterial.prototype.copy = function ( source ) {\n\n\tLineBasicMaterial.prototype.copy.call( this, source );\n\n\tthis.scale = source.scale;\n\tthis.dashSize = source.dashSize;\n\tthis.gapSize = source.gapSize;\n\n\treturn this;\n\n};\n\n\n\nvar Materials = Object.freeze({\n\tShadowMaterial: ShadowMaterial,\n\tSpriteMaterial: SpriteMaterial,\n\tRawShaderMaterial: RawShaderMaterial,\n\tShaderMaterial: ShaderMaterial,\n\tPointsMaterial: PointsMaterial,\n\tMeshPhysicalMaterial: MeshPhysicalMaterial,\n\tMeshStandardMaterial: MeshStandardMaterial,\n\tMeshPhongMaterial: MeshPhongMaterial,\n\tMeshToonMaterial: MeshToonMaterial,\n\tMeshNormalMaterial: MeshNormalMaterial,\n\tMeshLambertMaterial: MeshLambertMaterial,\n\tMeshDepthMaterial: MeshDepthMaterial,\n\tMeshDistanceMaterial: MeshDistanceMaterial,\n\tMeshBasicMaterial: MeshBasicMaterial,\n\tLineDashedMaterial: LineDashedMaterial,\n\tLineBasicMaterial: LineBasicMaterial,\n\tMaterial: Material\n});\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nvar Cache = {\n\n\tenabled: false,\n\n\tfiles: {},\n\n\tadd: function ( key, file ) {\n\n\t\tif ( this.enabled === false ) return;\n\n\t\t// console.log( 'THREE.Cache', 'Adding key:', key );\n\n\t\tthis.files[ key ] = file;\n\n\t},\n\n\tget: function ( key ) {\n\n\t\tif ( this.enabled === false ) return;\n\n\t\t// console.log( 'THREE.Cache', 'Checking key:', key );\n\n\t\treturn this.files[ key ];\n\n\t},\n\n\tremove: function ( key ) {\n\n\t\tdelete this.files[ key ];\n\n\t},\n\n\tclear: function () {\n\n\t\tthis.files = {};\n\n\t}\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction LoadingManager( onLoad, onProgress, onError ) {\n\n\tvar scope = this;\n\n\tvar isLoading = false;\n\tvar itemsLoaded = 0;\n\tvar itemsTotal = 0;\n\tvar urlModifier = undefined;\n\n\tthis.onStart = undefined;\n\tthis.onLoad = onLoad;\n\tthis.onProgress = onProgress;\n\tthis.onError = onError;\n\n\tthis.itemStart = function ( url ) {\n\n\t\titemsTotal ++;\n\n\t\tif ( isLoading === false ) {\n\n\t\t\tif ( scope.onStart !== undefined ) {\n\n\t\t\t\tscope.onStart( url, itemsLoaded, itemsTotal );\n\n\t\t\t}\n\n\t\t}\n\n\t\tisLoading = true;\n\n\t};\n\n\tthis.itemEnd = function ( url ) {\n\n\t\titemsLoaded ++;\n\n\t\tif ( scope.onProgress !== undefined ) {\n\n\t\t\tscope.onProgress( url, itemsLoaded, itemsTotal );\n\n\t\t}\n\n\t\tif ( itemsLoaded === itemsTotal ) {\n\n\t\t\tisLoading = false;\n\n\t\t\tif ( scope.onLoad !== undefined ) {\n\n\t\t\t\tscope.onLoad();\n\n\t\t\t}\n\n\t\t}\n\n\t};\n\n\tthis.itemError = function ( url ) {\n\n\t\tif ( scope.onError !== undefined ) {\n\n\t\t\tscope.onError( url );\n\n\t\t}\n\n\t};\n\n\tthis.resolveURL = function ( url ) {\n\n\t\tif ( urlModifier ) {\n\n\t\t\treturn urlModifier( url );\n\n\t\t}\n\n\t\treturn url;\n\n\t};\n\n\tthis.setURLModifier = function ( transform ) {\n\n\t\turlModifier = transform;\n\t\treturn this;\n\n\t};\n\n}\n\nvar DefaultLoadingManager = new LoadingManager();\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nvar loading = {};\n\nfunction FileLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n}\n\nObject.assign( FileLoader.prototype, {\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tif ( url === undefined ) url = '';\n\n\t\tif ( this.path !== undefined ) url = this.path + url;\n\n\t\turl = this.manager.resolveURL( url );\n\n\t\tvar scope = this;\n\n\t\tvar cached = Cache.get( url );\n\n\t\tif ( cached !== undefined ) {\n\n\t\t\tscope.manager.itemStart( url );\n\n\t\t\tsetTimeout( function () {\n\n\t\t\t\tif ( onLoad ) onLoad( cached );\n\n\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t}, 0 );\n\n\t\t\treturn cached;\n\n\t\t}\n\n\t\t// Check if request is duplicate\n\n\t\tif ( loading[ url ] !== undefined ) {\n\n\t\t\tloading[ url ].push( {\n\n\t\t\t\tonLoad: onLoad,\n\t\t\t\tonProgress: onProgress,\n\t\t\t\tonError: onError\n\n\t\t\t} );\n\n\t\t\treturn;\n\n\t\t}\n\n\t\t// Check for data: URI\n\t\tvar dataUriRegex = /^data:(.*?)(;base64)?,(.*)$/;\n\t\tvar dataUriRegexResult = url.match( dataUriRegex );\n\n\t\t// Safari can not handle Data URIs through XMLHttpRequest so process manually\n\t\tif ( dataUriRegexResult ) {\n\n\t\t\tvar mimeType = dataUriRegexResult[ 1 ];\n\t\t\tvar isBase64 = !! dataUriRegexResult[ 2 ];\n\t\t\tvar data = dataUriRegexResult[ 3 ];\n\n\t\t\tdata = window.decodeURIComponent( data );\n\n\t\t\tif ( isBase64 ) data = window.atob( data );\n\n\t\t\ttry {\n\n\t\t\t\tvar response;\n\t\t\t\tvar responseType = ( this.responseType || '' ).toLowerCase();\n\n\t\t\t\tswitch ( responseType ) {\n\n\t\t\t\t\tcase 'arraybuffer':\n\t\t\t\t\tcase 'blob':\n\n\t\t\t\t\t\tvar view = new Uint8Array( data.length );\n\n\t\t\t\t\t\tfor ( var i = 0; i < data.length; i ++ ) {\n\n\t\t\t\t\t\t\tview[ i ] = data.charCodeAt( i );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif ( responseType === 'blob' ) {\n\n\t\t\t\t\t\t\tresponse = new Blob( [ view.buffer ], { type: mimeType } );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tresponse = view.buffer;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'document':\n\n\t\t\t\t\t\tvar parser = new DOMParser();\n\t\t\t\t\t\tresponse = parser.parseFromString( data, mimeType );\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'json':\n\n\t\t\t\t\t\tresponse = JSON.parse( data );\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault: // 'text' or other\n\n\t\t\t\t\t\tresponse = data;\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t}\n\n\t\t\t\t// Wait for next browser tick like standard XMLHttpRequest event dispatching does\n\t\t\t\twindow.setTimeout( function () {\n\n\t\t\t\t\tif ( onLoad ) onLoad( response );\n\n\t\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t\t}, 0 );\n\n\t\t\t} catch ( error ) {\n\n\t\t\t\t// Wait for next browser tick like standard XMLHttpRequest event dispatching does\n\t\t\t\twindow.setTimeout( function () {\n\n\t\t\t\t\tif ( onError ) onError( error );\n\n\t\t\t\t\tscope.manager.itemEnd( url );\n\t\t\t\t\tscope.manager.itemError( url );\n\n\t\t\t\t}, 0 );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// Initialise array for duplicate requests\n\n\t\t\tloading[ url ] = [];\n\n\t\t\tloading[ url ].push( {\n\n\t\t\t\tonLoad: onLoad,\n\t\t\t\tonProgress: onProgress,\n\t\t\t\tonError: onError\n\n\t\t\t} );\n\n\t\t\tvar request = new XMLHttpRequest();\n\n\t\t\trequest.open( 'GET', url, true );\n\n\t\t\trequest.addEventListener( 'load', function ( event ) {\n\n\t\t\t\tvar response = this.response;\n\n\t\t\t\tCache.add( url, response );\n\n\t\t\t\tvar callbacks = loading[ url ];\n\n\t\t\t\tdelete loading[ url ];\n\n\t\t\t\tif ( this.status === 200 ) {\n\n\t\t\t\t\tfor ( var i = 0, il = callbacks.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tvar callback = callbacks[ i ];\n\t\t\t\t\t\tif ( callback.onLoad ) callback.onLoad( response );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t\t} else if ( this.status === 0 ) {\n\n\t\t\t\t\t// Some browsers return HTTP Status 0 when using non-http protocol\n\t\t\t\t\t// e.g. 'file://' or 'data://'. Handle as success.\n\n\t\t\t\t\tconsole.warn( 'THREE.FileLoader: HTTP Status 0 received.' );\n\n\t\t\t\t\tfor ( var i = 0, il = callbacks.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tvar callback = callbacks[ i ];\n\t\t\t\t\t\tif ( callback.onLoad ) callback.onLoad( response );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tfor ( var i = 0, il = callbacks.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tvar callback = callbacks[ i ];\n\t\t\t\t\t\tif ( callback.onError ) callback.onError( event );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tscope.manager.itemEnd( url );\n\t\t\t\t\tscope.manager.itemError( url );\n\n\t\t\t\t}\n\n\t\t\t}, false );\n\n\t\t\trequest.addEventListener( 'progress', function ( event ) {\n\n\t\t\t\tvar callbacks = loading[ url ];\n\n\t\t\t\tfor ( var i = 0, il = callbacks.length; i < il; i ++ ) {\n\n\t\t\t\t\tvar callback = callbacks[ i ];\n\t\t\t\t\tif ( callback.onProgress ) callback.onProgress( event );\n\n\t\t\t\t}\n\n\t\t\t}, false );\n\n\t\t\trequest.addEventListener( 'error', function ( event ) {\n\n\t\t\t\tvar callbacks = loading[ url ];\n\n\t\t\t\tdelete loading[ url ];\n\n\t\t\t\tfor ( var i = 0, il = callbacks.length; i < il; i ++ ) {\n\n\t\t\t\t\tvar callback = callbacks[ i ];\n\t\t\t\t\tif ( callback.onError ) callback.onError( event );\n\n\t\t\t\t}\n\n\t\t\t\tscope.manager.itemEnd( url );\n\t\t\t\tscope.manager.itemError( url );\n\n\t\t\t}, false );\n\n\t\t\tif ( this.responseType !== undefined ) request.responseType = this.responseType;\n\t\t\tif ( this.withCredentials !== undefined ) request.withCredentials = this.withCredentials;\n\n\t\t\tif ( request.overrideMimeType ) request.overrideMimeType( this.mimeType !== undefined ? this.mimeType : 'text/plain' );\n\n\t\t\tfor ( var header in this.requestHeader ) {\n\n\t\t\t\trequest.setRequestHeader( header, this.requestHeader[ header ] );\n\n\t\t\t}\n\n\t\t\trequest.send( null );\n\n\t\t}\n\n\t\tscope.manager.itemStart( url );\n\n\t\treturn request;\n\n\t},\n\n\tsetPath: function ( value ) {\n\n\t\tthis.path = value;\n\t\treturn this;\n\n\t},\n\n\tsetResponseType: function ( value ) {\n\n\t\tthis.responseType = value;\n\t\treturn this;\n\n\t},\n\n\tsetWithCredentials: function ( value ) {\n\n\t\tthis.withCredentials = value;\n\t\treturn this;\n\n\t},\n\n\tsetMimeType: function ( value ) {\n\n\t\tthis.mimeType = value;\n\t\treturn this;\n\n\t},\n\n\tsetRequestHeader: function ( value ) {\n\n\t\tthis.requestHeader = value;\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n *\n * Abstract Base class to block based textures loader (dds, pvr, ...)\n */\n\nfunction CompressedTextureLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n\t// override in sub classes\n\tthis._parser = null;\n\n}\n\nObject.assign( CompressedTextureLoader.prototype, {\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tvar scope = this;\n\n\t\tvar images = [];\n\n\t\tvar texture = new CompressedTexture();\n\t\ttexture.image = images;\n\n\t\tvar loader = new FileLoader( this.manager );\n\t\tloader.setPath( this.path );\n\t\tloader.setResponseType( 'arraybuffer' );\n\n\t\tfunction loadTexture( i ) {\n\n\t\t\tloader.load( url[ i ], function ( buffer ) {\n\n\t\t\t\tvar texDatas = scope._parser( buffer, true );\n\n\t\t\t\timages[ i ] = {\n\t\t\t\t\twidth: texDatas.width,\n\t\t\t\t\theight: texDatas.height,\n\t\t\t\t\tformat: texDatas.format,\n\t\t\t\t\tmipmaps: texDatas.mipmaps\n\t\t\t\t};\n\n\t\t\t\tloaded += 1;\n\n\t\t\t\tif ( loaded === 6 ) {\n\n\t\t\t\t\tif ( texDatas.mipmapCount === 1 )\n\t\t\t\t\t\ttexture.minFilter = LinearFilter;\n\n\t\t\t\t\ttexture.format = texDatas.format;\n\t\t\t\t\ttexture.needsUpdate = true;\n\n\t\t\t\t\tif ( onLoad ) onLoad( texture );\n\n\t\t\t\t}\n\n\t\t\t}, onProgress, onError );\n\n\t\t}\n\n\t\tif ( Array.isArray( url ) ) {\n\n\t\t\tvar loaded = 0;\n\n\t\t\tfor ( var i = 0, il = url.length; i < il; ++ i ) {\n\n\t\t\t\tloadTexture( i );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// compressed cubemap texture stored in a single DDS file\n\n\t\t\tloader.load( url, function ( buffer ) {\n\n\t\t\t\tvar texDatas = scope._parser( buffer, true );\n\n\t\t\t\tif ( texDatas.isCubemap ) {\n\n\t\t\t\t\tvar faces = texDatas.mipmaps.length / texDatas.mipmapCount;\n\n\t\t\t\t\tfor ( var f = 0; f < faces; f ++ ) {\n\n\t\t\t\t\t\timages[ f ] = { mipmaps: [] };\n\n\t\t\t\t\t\tfor ( var i = 0; i < texDatas.mipmapCount; i ++ ) {\n\n\t\t\t\t\t\t\timages[ f ].mipmaps.push( texDatas.mipmaps[ f * texDatas.mipmapCount + i ] );\n\t\t\t\t\t\t\timages[ f ].format = texDatas.format;\n\t\t\t\t\t\t\timages[ f ].width = texDatas.width;\n\t\t\t\t\t\t\timages[ f ].height = texDatas.height;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\ttexture.image.width = texDatas.width;\n\t\t\t\t\ttexture.image.height = texDatas.height;\n\t\t\t\t\ttexture.mipmaps = texDatas.mipmaps;\n\n\t\t\t\t}\n\n\t\t\t\tif ( texDatas.mipmapCount === 1 ) {\n\n\t\t\t\t\ttexture.minFilter = LinearFilter;\n\n\t\t\t\t}\n\n\t\t\t\ttexture.format = texDatas.format;\n\t\t\t\ttexture.needsUpdate = true;\n\n\t\t\t\tif ( onLoad ) onLoad( texture );\n\n\t\t\t}, onProgress, onError );\n\n\t\t}\n\n\t\treturn texture;\n\n\t},\n\n\tsetPath: function ( value ) {\n\n\t\tthis.path = value;\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author Nikos M. / https://github.com/foo123/\n *\n * Abstract Base class to load generic binary textures formats (rgbe, hdr, ...)\n */\n\nfunction DataTextureLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n\t// override in sub classes\n\tthis._parser = null;\n\n}\n\nObject.assign( DataTextureLoader.prototype, {\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tvar scope = this;\n\n\t\tvar texture = new DataTexture();\n\n\t\tvar loader = new FileLoader( this.manager );\n\t\tloader.setResponseType( 'arraybuffer' );\n\n\t\tloader.load( url, function ( buffer ) {\n\n\t\t\tvar texData = scope._parser( buffer );\n\n\t\t\tif ( ! texData ) return;\n\n\t\t\tif ( undefined !== texData.image ) {\n\n\t\t\t\ttexture.image = texData.image;\n\n\t\t\t} else if ( undefined !== texData.data ) {\n\n\t\t\t\ttexture.image.width = texData.width;\n\t\t\t\ttexture.image.height = texData.height;\n\t\t\t\ttexture.image.data = texData.data;\n\n\t\t\t}\n\n\t\t\ttexture.wrapS = undefined !== texData.wrapS ? texData.wrapS : ClampToEdgeWrapping;\n\t\t\ttexture.wrapT = undefined !== texData.wrapT ? texData.wrapT : ClampToEdgeWrapping;\n\n\t\t\ttexture.magFilter = undefined !== texData.magFilter ? texData.magFilter : LinearFilter;\n\t\t\ttexture.minFilter = undefined !== texData.minFilter ? texData.minFilter : LinearMipMapLinearFilter;\n\n\t\t\ttexture.anisotropy = undefined !== texData.anisotropy ? texData.anisotropy : 1;\n\n\t\t\tif ( undefined !== texData.format ) {\n\n\t\t\t\ttexture.format = texData.format;\n\n\t\t\t}\n\t\t\tif ( undefined !== texData.type ) {\n\n\t\t\t\ttexture.type = texData.type;\n\n\t\t\t}\n\n\t\t\tif ( undefined !== texData.mipmaps ) {\n\n\t\t\t\ttexture.mipmaps = texData.mipmaps;\n\n\t\t\t}\n\n\t\t\tif ( 1 === texData.mipmapCount ) {\n\n\t\t\t\ttexture.minFilter = LinearFilter;\n\n\t\t\t}\n\n\t\t\ttexture.needsUpdate = true;\n\n\t\t\tif ( onLoad ) onLoad( texture, texData );\n\n\t\t}, onProgress, onError );\n\n\n\t\treturn texture;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction ImageLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n}\n\nObject.assign( ImageLoader.prototype, {\n\n\tcrossOrigin: 'Anonymous',\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tif ( url === undefined ) url = '';\n\n\t\tif ( this.path !== undefined ) url = this.path + url;\n\n\t\turl = this.manager.resolveURL( url );\n\n\t\tvar scope = this;\n\n\t\tvar cached = Cache.get( url );\n\n\t\tif ( cached !== undefined ) {\n\n\t\t\tscope.manager.itemStart( url );\n\n\t\t\tsetTimeout( function () {\n\n\t\t\t\tif ( onLoad ) onLoad( cached );\n\n\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t}, 0 );\n\n\t\t\treturn cached;\n\n\t\t}\n\n\t\tvar image = document.createElementNS( 'http://www.w3.org/1999/xhtml', 'img' );\n\n\t\timage.addEventListener( 'load', function () {\n\n\t\t\tCache.add( url, this );\n\n\t\t\tif ( onLoad ) onLoad( this );\n\n\t\t\tscope.manager.itemEnd( url );\n\n\t\t}, false );\n\n\t\t/*\n\t\timage.addEventListener( 'progress', function ( event ) {\n\n\t\t\tif ( onProgress ) onProgress( event );\n\n\t\t}, false );\n\t\t*/\n\n\t\timage.addEventListener( 'error', function ( event ) {\n\n\t\t\tif ( onError ) onError( event );\n\n\t\t\tscope.manager.itemEnd( url );\n\t\t\tscope.manager.itemError( url );\n\n\t\t}, false );\n\n\t\tif ( url.substr( 0, 5 ) !== 'data:' ) {\n\n\t\t\tif ( this.crossOrigin !== undefined ) image.crossOrigin = this.crossOrigin;\n\n\t\t}\n\n\t\tscope.manager.itemStart( url );\n\n\t\timage.src = url;\n\n\t\treturn image;\n\n\t},\n\n\tsetCrossOrigin: function ( value ) {\n\n\t\tthis.crossOrigin = value;\n\t\treturn this;\n\n\t},\n\n\tsetPath: function ( value ) {\n\n\t\tthis.path = value;\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction CubeTextureLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n}\n\nObject.assign( CubeTextureLoader.prototype, {\n\n\tcrossOrigin: 'Anonymous',\n\n\tload: function ( urls, onLoad, onProgress, onError ) {\n\n\t\tvar texture = new CubeTexture();\n\n\t\tvar loader = new ImageLoader( this.manager );\n\t\tloader.setCrossOrigin( this.crossOrigin );\n\t\tloader.setPath( this.path );\n\n\t\tvar loaded = 0;\n\n\t\tfunction loadTexture( i ) {\n\n\t\t\tloader.load( urls[ i ], function ( image ) {\n\n\t\t\t\ttexture.images[ i ] = image;\n\n\t\t\t\tloaded ++;\n\n\t\t\t\tif ( loaded === 6 ) {\n\n\t\t\t\t\ttexture.needsUpdate = true;\n\n\t\t\t\t\tif ( onLoad ) onLoad( texture );\n\n\t\t\t\t}\n\n\t\t\t}, undefined, onError );\n\n\t\t}\n\n\t\tfor ( var i = 0; i < urls.length; ++ i ) {\n\n\t\t\tloadTexture( i );\n\n\t\t}\n\n\t\treturn texture;\n\n\t},\n\n\tsetCrossOrigin: function ( value ) {\n\n\t\tthis.crossOrigin = value;\n\t\treturn this;\n\n\t},\n\n\tsetPath: function ( value ) {\n\n\t\tthis.path = value;\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction TextureLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n}\n\nObject.assign( TextureLoader.prototype, {\n\n\tcrossOrigin: 'Anonymous',\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tvar texture = new Texture();\n\n\t\tvar loader = new ImageLoader( this.manager );\n\t\tloader.setCrossOrigin( this.crossOrigin );\n\t\tloader.setPath( this.path );\n\n\t\tloader.load( url, function ( image ) {\n\n\t\t\ttexture.image = image;\n\n\t\t\t// JPEGs can't have an alpha channel, so memory can be saved by storing them as RGB.\n\t\t\tvar isJPEG = url.search( /\\.(jpg|jpeg)$/ ) > 0 || url.search( /^data\\:image\\/jpeg/ ) === 0;\n\n\t\t\ttexture.format = isJPEG ? RGBFormat : RGBAFormat;\n\t\t\ttexture.needsUpdate = true;\n\n\t\t\tif ( onLoad !== undefined ) {\n\n\t\t\t\tonLoad( texture );\n\n\t\t\t}\n\n\t\t}, onProgress, onError );\n\n\t\treturn texture;\n\n\t},\n\n\tsetCrossOrigin: function ( value ) {\n\n\t\tthis.crossOrigin = value;\n\t\treturn this;\n\n\t},\n\n\tsetPath: function ( value ) {\n\n\t\tthis.path = value;\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n * Extensible curve object\n *\n * Some common of curve methods:\n * .getPoint( t, optionalTarget ), .getTangent( t )\n * .getPointAt( u, optionalTarget ), .getTangentAt( u )\n * .getPoints(), .getSpacedPoints()\n * .getLength()\n * .updateArcLengths()\n *\n * This following curves inherit from THREE.Curve:\n *\n * -- 2D curves --\n * THREE.ArcCurve\n * THREE.CubicBezierCurve\n * THREE.EllipseCurve\n * THREE.LineCurve\n * THREE.QuadraticBezierCurve\n * THREE.SplineCurve\n *\n * -- 3D curves --\n * THREE.CatmullRomCurve3\n * THREE.CubicBezierCurve3\n * THREE.LineCurve3\n * THREE.QuadraticBezierCurve3\n *\n * A series of curves can be represented as a THREE.CurvePath.\n *\n **/\n\n/**************************************************************\n *\tAbstract Curve base class\n **************************************************************/\n\nfunction Curve() {\n\n\tthis.type = 'Curve';\n\n\tthis.arcLengthDivisions = 200;\n\n}\n\nObject.assign( Curve.prototype, {\n\n\t// Virtual base class method to overwrite and implement in subclasses\n\t//\t- t [0 .. 1]\n\n\tgetPoint: function ( /* t, optionalTarget */ ) {\n\n\t\tconsole.warn( 'THREE.Curve: .getPoint() not implemented.' );\n\t\treturn null;\n\n\t},\n\n\t// Get point at relative position in curve according to arc length\n\t// - u [0 .. 1]\n\n\tgetPointAt: function ( u, optionalTarget ) {\n\n\t\tvar t = this.getUtoTmapping( u );\n\t\treturn this.getPoint( t, optionalTarget );\n\n\t},\n\n\t// Get sequence of points using getPoint( t )\n\n\tgetPoints: function ( divisions ) {\n\n\t\tif ( divisions === undefined ) divisions = 5;\n\n\t\tvar points = [];\n\n\t\tfor ( var d = 0; d <= divisions; d ++ ) {\n\n\t\t\tpoints.push( this.getPoint( d / divisions ) );\n\n\t\t}\n\n\t\treturn points;\n\n\t},\n\n\t// Get sequence of points using getPointAt( u )\n\n\tgetSpacedPoints: function ( divisions ) {\n\n\t\tif ( divisions === undefined ) divisions = 5;\n\n\t\tvar points = [];\n\n\t\tfor ( var d = 0; d <= divisions; d ++ ) {\n\n\t\t\tpoints.push( this.getPointAt( d / divisions ) );\n\n\t\t}\n\n\t\treturn points;\n\n\t},\n\n\t// Get total curve arc length\n\n\tgetLength: function () {\n\n\t\tvar lengths = this.getLengths();\n\t\treturn lengths[ lengths.length - 1 ];\n\n\t},\n\n\t// Get list of cumulative segment lengths\n\n\tgetLengths: function ( divisions ) {\n\n\t\tif ( divisions === undefined ) divisions = this.arcLengthDivisions;\n\n\t\tif ( this.cacheArcLengths &&\n\t\t\t( this.cacheArcLengths.length === divisions + 1 ) &&\n\t\t\t! this.needsUpdate ) {\n\n\t\t\treturn this.cacheArcLengths;\n\n\t\t}\n\n\t\tthis.needsUpdate = false;\n\n\t\tvar cache = [];\n\t\tvar current, last = this.getPoint( 0 );\n\t\tvar p, sum = 0;\n\n\t\tcache.push( 0 );\n\n\t\tfor ( p = 1; p <= divisions; p ++ ) {\n\n\t\t\tcurrent = this.getPoint( p / divisions );\n\t\t\tsum += current.distanceTo( last );\n\t\t\tcache.push( sum );\n\t\t\tlast = current;\n\n\t\t}\n\n\t\tthis.cacheArcLengths = cache;\n\n\t\treturn cache; // { sums: cache, sum: sum }; Sum is in the last element.\n\n\t},\n\n\tupdateArcLengths: function () {\n\n\t\tthis.needsUpdate = true;\n\t\tthis.getLengths();\n\n\t},\n\n\t// Given u ( 0 .. 1 ), get a t to find p. This gives you points which are equidistant\n\n\tgetUtoTmapping: function ( u, distance ) {\n\n\t\tvar arcLengths = this.getLengths();\n\n\t\tvar i = 0, il = arcLengths.length;\n\n\t\tvar targetArcLength; // The targeted u distance value to get\n\n\t\tif ( distance ) {\n\n\t\t\ttargetArcLength = distance;\n\n\t\t} else {\n\n\t\t\ttargetArcLength = u * arcLengths[ il - 1 ];\n\n\t\t}\n\n\t\t// binary search for the index with largest value smaller than target u distance\n\n\t\tvar low = 0, high = il - 1, comparison;\n\n\t\twhile ( low <= high ) {\n\n\t\t\ti = Math.floor( low + ( high - low ) / 2 ); // less likely to overflow, though probably not issue here, JS doesn't really have integers, all numbers are floats\n\n\t\t\tcomparison = arcLengths[ i ] - targetArcLength;\n\n\t\t\tif ( comparison < 0 ) {\n\n\t\t\t\tlow = i + 1;\n\n\t\t\t} else if ( comparison > 0 ) {\n\n\t\t\t\thigh = i - 1;\n\n\t\t\t} else {\n\n\t\t\t\thigh = i;\n\t\t\t\tbreak;\n\n\t\t\t\t// DONE\n\n\t\t\t}\n\n\t\t}\n\n\t\ti = high;\n\n\t\tif ( arcLengths[ i ] === targetArcLength ) {\n\n\t\t\treturn i / ( il - 1 );\n\n\t\t}\n\n\t\t// we could get finer grain at lengths, or use simple interpolation between two points\n\n\t\tvar lengthBefore = arcLengths[ i ];\n\t\tvar lengthAfter = arcLengths[ i + 1 ];\n\n\t\tvar segmentLength = lengthAfter - lengthBefore;\n\n\t\t// determine where we are between the 'before' and 'after' points\n\n\t\tvar segmentFraction = ( targetArcLength - lengthBefore ) / segmentLength;\n\n\t\t// add that fractional amount to t\n\n\t\tvar t = ( i + segmentFraction ) / ( il - 1 );\n\n\t\treturn t;\n\n\t},\n\n\t// Returns a unit vector tangent at t\n\t// In case any sub curve does not implement its tangent derivation,\n\t// 2 points a small delta apart will be used to find its gradient\n\t// which seems to give a reasonable approximation\n\n\tgetTangent: function ( t ) {\n\n\t\tvar delta = 0.0001;\n\t\tvar t1 = t - delta;\n\t\tvar t2 = t + delta;\n\n\t\t// Capping in case of danger\n\n\t\tif ( t1 < 0 ) t1 = 0;\n\t\tif ( t2 > 1 ) t2 = 1;\n\n\t\tvar pt1 = this.getPoint( t1 );\n\t\tvar pt2 = this.getPoint( t2 );\n\n\t\tvar vec = pt2.clone().sub( pt1 );\n\t\treturn vec.normalize();\n\n\t},\n\n\tgetTangentAt: function ( u ) {\n\n\t\tvar t = this.getUtoTmapping( u );\n\t\treturn this.getTangent( t );\n\n\t},\n\n\tcomputeFrenetFrames: function ( segments, closed ) {\n\n\t\t// see http://www.cs.indiana.edu/pub/techreports/TR425.pdf\n\n\t\tvar normal = new Vector3();\n\n\t\tvar tangents = [];\n\t\tvar normals = [];\n\t\tvar binormals = [];\n\n\t\tvar vec = new Vector3();\n\t\tvar mat = new Matrix4();\n\n\t\tvar i, u, theta;\n\n\t\t// compute the tangent vectors for each segment on the curve\n\n\t\tfor ( i = 0; i <= segments; i ++ ) {\n\n\t\t\tu = i / segments;\n\n\t\t\ttangents[ i ] = this.getTangentAt( u );\n\t\t\ttangents[ i ].normalize();\n\n\t\t}\n\n\t\t// select an initial normal vector perpendicular to the first tangent vector,\n\t\t// and in the direction of the minimum tangent xyz component\n\n\t\tnormals[ 0 ] = new Vector3();\n\t\tbinormals[ 0 ] = new Vector3();\n\t\tvar min = Number.MAX_VALUE;\n\t\tvar tx = Math.abs( tangents[ 0 ].x );\n\t\tvar ty = Math.abs( tangents[ 0 ].y );\n\t\tvar tz = Math.abs( tangents[ 0 ].z );\n\n\t\tif ( tx <= min ) {\n\n\t\t\tmin = tx;\n\t\t\tnormal.set( 1, 0, 0 );\n\n\t\t}\n\n\t\tif ( ty <= min ) {\n\n\t\t\tmin = ty;\n\t\t\tnormal.set( 0, 1, 0 );\n\n\t\t}\n\n\t\tif ( tz <= min ) {\n\n\t\t\tnormal.set( 0, 0, 1 );\n\n\t\t}\n\n\t\tvec.crossVectors( tangents[ 0 ], normal ).normalize();\n\n\t\tnormals[ 0 ].crossVectors( tangents[ 0 ], vec );\n\t\tbinormals[ 0 ].crossVectors( tangents[ 0 ], normals[ 0 ] );\n\n\n\t\t// compute the slowly-varying normal and binormal vectors for each segment on the curve\n\n\t\tfor ( i = 1; i <= segments; i ++ ) {\n\n\t\t\tnormals[ i ] = normals[ i - 1 ].clone();\n\n\t\t\tbinormals[ i ] = binormals[ i - 1 ].clone();\n\n\t\t\tvec.crossVectors( tangents[ i - 1 ], tangents[ i ] );\n\n\t\t\tif ( vec.length() > Number.EPSILON ) {\n\n\t\t\t\tvec.normalize();\n\n\t\t\t\ttheta = Math.acos( _Math.clamp( tangents[ i - 1 ].dot( tangents[ i ] ), - 1, 1 ) ); // clamp for floating pt errors\n\n\t\t\t\tnormals[ i ].applyMatrix4( mat.makeRotationAxis( vec, theta ) );\n\n\t\t\t}\n\n\t\t\tbinormals[ i ].crossVectors( tangents[ i ], normals[ i ] );\n\n\t\t}\n\n\t\t// if the curve is closed, postprocess the vectors so the first and last normal vectors are the same\n\n\t\tif ( closed === true ) {\n\n\t\t\ttheta = Math.acos( _Math.clamp( normals[ 0 ].dot( normals[ segments ] ), - 1, 1 ) );\n\t\t\ttheta /= segments;\n\n\t\t\tif ( tangents[ 0 ].dot( vec.crossVectors( normals[ 0 ], normals[ segments ] ) ) > 0 ) {\n\n\t\t\t\ttheta = - theta;\n\n\t\t\t}\n\n\t\t\tfor ( i = 1; i <= segments; i ++ ) {\n\n\t\t\t\t// twist a little...\n\t\t\t\tnormals[ i ].applyMatrix4( mat.makeRotationAxis( tangents[ i ], theta * i ) );\n\t\t\t\tbinormals[ i ].crossVectors( tangents[ i ], normals[ i ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn {\n\t\t\ttangents: tangents,\n\t\t\tnormals: normals,\n\t\t\tbinormals: binormals\n\t\t};\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tthis.arcLengthDivisions = source.arcLengthDivisions;\n\n\t\treturn this;\n\n\t},\n\n\ttoJSON: function () {\n\n\t\tvar data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Curve',\n\t\t\t\tgenerator: 'Curve.toJSON'\n\t\t\t}\n\t\t};\n\n\t\tdata.arcLengthDivisions = this.arcLengthDivisions;\n\t\tdata.type = this.type;\n\n\t\treturn data;\n\n\t},\n\n\tfromJSON: function ( json ) {\n\n\t\tthis.arcLengthDivisions = json.arcLengthDivisions;\n\n\t\treturn this;\n\n\t}\n\n} );\n\nfunction EllipseCurve( aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation ) {\n\n\tCurve.call( this );\n\n\tthis.type = 'EllipseCurve';\n\n\tthis.aX = aX || 0;\n\tthis.aY = aY || 0;\n\n\tthis.xRadius = xRadius || 1;\n\tthis.yRadius = yRadius || 1;\n\n\tthis.aStartAngle = aStartAngle || 0;\n\tthis.aEndAngle = aEndAngle || 2 * Math.PI;\n\n\tthis.aClockwise = aClockwise || false;\n\n\tthis.aRotation = aRotation || 0;\n\n}\n\nEllipseCurve.prototype = Object.create( Curve.prototype );\nEllipseCurve.prototype.constructor = EllipseCurve;\n\nEllipseCurve.prototype.isEllipseCurve = true;\n\nEllipseCurve.prototype.getPoint = function ( t, optionalTarget ) {\n\n\tvar point = optionalTarget || new Vector2();\n\n\tvar twoPi = Math.PI * 2;\n\tvar deltaAngle = this.aEndAngle - this.aStartAngle;\n\tvar samePoints = Math.abs( deltaAngle ) < Number.EPSILON;\n\n\t// ensures that deltaAngle is 0 .. 2 PI\n\twhile ( deltaAngle < 0 ) deltaAngle += twoPi;\n\twhile ( deltaAngle > twoPi ) deltaAngle -= twoPi;\n\n\tif ( deltaAngle < Number.EPSILON ) {\n\n\t\tif ( samePoints ) {\n\n\t\t\tdeltaAngle = 0;\n\n\t\t} else {\n\n\t\t\tdeltaAngle = twoPi;\n\n\t\t}\n\n\t}\n\n\tif ( this.aClockwise === true && ! samePoints ) {\n\n\t\tif ( deltaAngle === twoPi ) {\n\n\t\t\tdeltaAngle = - twoPi;\n\n\t\t} else {\n\n\t\t\tdeltaAngle = deltaAngle - twoPi;\n\n\t\t}\n\n\t}\n\n\tvar angle = this.aStartAngle + t * deltaAngle;\n\tvar x = this.aX + this.xRadius * Math.cos( angle );\n\tvar y = this.aY + this.yRadius * Math.sin( angle );\n\n\tif ( this.aRotation !== 0 ) {\n\n\t\tvar cos = Math.cos( this.aRotation );\n\t\tvar sin = Math.sin( this.aRotation );\n\n\t\tvar tx = x - this.aX;\n\t\tvar ty = y - this.aY;\n\n\t\t// Rotate the point about the center of the ellipse.\n\t\tx = tx * cos - ty * sin + this.aX;\n\t\ty = tx * sin + ty * cos + this.aY;\n\n\t}\n\n\treturn point.set( x, y );\n\n};\n\nEllipseCurve.prototype.copy = function ( source ) {\n\n\tCurve.prototype.copy.call( this, source );\n\n\tthis.aX = source.aX;\n\tthis.aY = source.aY;\n\n\tthis.xRadius = source.xRadius;\n\tthis.yRadius = source.yRadius;\n\n\tthis.aStartAngle = source.aStartAngle;\n\tthis.aEndAngle = source.aEndAngle;\n\n\tthis.aClockwise = source.aClockwise;\n\n\tthis.aRotation = source.aRotation;\n\n\treturn this;\n\n};\n\n\nEllipseCurve.prototype.toJSON = function () {\n\n\tvar data = Curve.prototype.toJSON.call( this );\n\n\tdata.aX = this.aX;\n\tdata.aY = this.aY;\n\n\tdata.xRadius = this.xRadius;\n\tdata.yRadius = this.yRadius;\n\n\tdata.aStartAngle = this.aStartAngle;\n\tdata.aEndAngle = this.aEndAngle;\n\n\tdata.aClockwise = this.aClockwise;\n\n\tdata.aRotation = this.aRotation;\n\n\treturn data;\n\n};\n\nEllipseCurve.prototype.fromJSON = function ( json ) {\n\n\tCurve.prototype.fromJSON.call( this, json );\n\n\tthis.aX = json.aX;\n\tthis.aY = json.aY;\n\n\tthis.xRadius = json.xRadius;\n\tthis.yRadius = json.yRadius;\n\n\tthis.aStartAngle = json.aStartAngle;\n\tthis.aEndAngle = json.aEndAngle;\n\n\tthis.aClockwise = json.aClockwise;\n\n\tthis.aRotation = json.aRotation;\n\n\treturn this;\n\n};\n\nfunction ArcCurve( aX, aY, aRadius, aStartAngle, aEndAngle, aClockwise ) {\n\n\tEllipseCurve.call( this, aX, aY, aRadius, aRadius, aStartAngle, aEndAngle, aClockwise );\n\n\tthis.type = 'ArcCurve';\n\n}\n\nArcCurve.prototype = Object.create( EllipseCurve.prototype );\nArcCurve.prototype.constructor = ArcCurve;\n\nArcCurve.prototype.isArcCurve = true;\n\n/**\n * @author zz85 https://github.com/zz85\n *\n * Centripetal CatmullRom Curve - which is useful for avoiding\n * cusps and self-intersections in non-uniform catmull rom curves.\n * http://www.cemyuksel.com/research/catmullrom_param/catmullrom.pdf\n *\n * curve.type accepts centripetal(default), chordal and catmullrom\n * curve.tension is used for catmullrom which defaults to 0.5\n */\n\n\n/*\nBased on an optimized c++ solution in\n - http://stackoverflow.com/questions/9489736/catmull-rom-curve-with-no-cusps-and-no-self-intersections/\n - http://ideone.com/NoEbVM\n\nThis CubicPoly class could be used for reusing some variables and calculations,\nbut for three.js curve use, it could be possible inlined and flatten into a single function call\nwhich can be placed in CurveUtils.\n*/\n\nfunction CubicPoly() {\n\n\tvar c0 = 0, c1 = 0, c2 = 0, c3 = 0;\n\n\t/*\n\t * Compute coefficients for a cubic polynomial\n\t *   p(s) = c0 + c1*s + c2*s^2 + c3*s^3\n\t * such that\n\t *   p(0) = x0, p(1) = x1\n\t *  and\n\t *   p'(0) = t0, p'(1) = t1.\n\t */\n\tfunction init( x0, x1, t0, t1 ) {\n\n\t\tc0 = x0;\n\t\tc1 = t0;\n\t\tc2 = - 3 * x0 + 3 * x1 - 2 * t0 - t1;\n\t\tc3 = 2 * x0 - 2 * x1 + t0 + t1;\n\n\t}\n\n\treturn {\n\n\t\tinitCatmullRom: function ( x0, x1, x2, x3, tension ) {\n\n\t\t\tinit( x1, x2, tension * ( x2 - x0 ), tension * ( x3 - x1 ) );\n\n\t\t},\n\n\t\tinitNonuniformCatmullRom: function ( x0, x1, x2, x3, dt0, dt1, dt2 ) {\n\n\t\t\t// compute tangents when parameterized in [t1,t2]\n\t\t\tvar t1 = ( x1 - x0 ) / dt0 - ( x2 - x0 ) / ( dt0 + dt1 ) + ( x2 - x1 ) / dt1;\n\t\t\tvar t2 = ( x2 - x1 ) / dt1 - ( x3 - x1 ) / ( dt1 + dt2 ) + ( x3 - x2 ) / dt2;\n\n\t\t\t// rescale tangents for parametrization in [0,1]\n\t\t\tt1 *= dt1;\n\t\t\tt2 *= dt1;\n\n\t\t\tinit( x1, x2, t1, t2 );\n\n\t\t},\n\n\t\tcalc: function ( t ) {\n\n\t\t\tvar t2 = t * t;\n\t\t\tvar t3 = t2 * t;\n\t\t\treturn c0 + c1 * t + c2 * t2 + c3 * t3;\n\n\t\t}\n\n\t};\n\n}\n\n//\n\nvar tmp = new Vector3();\nvar px$1 = new CubicPoly();\nvar py = new CubicPoly();\nvar pz = new CubicPoly();\n\nfunction CatmullRomCurve3( points, closed, curveType, tension ) {\n\n\tCurve.call( this );\n\n\tthis.type = 'CatmullRomCurve3';\n\n\tthis.points = points || [];\n\tthis.closed = closed || false;\n\tthis.curveType = curveType || 'centripetal';\n\tthis.tension = tension || 0.5;\n\n}\n\nCatmullRomCurve3.prototype = Object.create( Curve.prototype );\nCatmullRomCurve3.prototype.constructor = CatmullRomCurve3;\n\nCatmullRomCurve3.prototype.isCatmullRomCurve3 = true;\n\nCatmullRomCurve3.prototype.getPoint = function ( t, optionalTarget ) {\n\n\tvar point = optionalTarget || new Vector3();\n\n\tvar points = this.points;\n\tvar l = points.length;\n\n\tvar p = ( l - ( this.closed ? 0 : 1 ) ) * t;\n\tvar intPoint = Math.floor( p );\n\tvar weight = p - intPoint;\n\n\tif ( this.closed ) {\n\n\t\tintPoint += intPoint > 0 ? 0 : ( Math.floor( Math.abs( intPoint ) / l ) + 1 ) * l;\n\n\t} else if ( weight === 0 && intPoint === l - 1 ) {\n\n\t\tintPoint = l - 2;\n\t\tweight = 1;\n\n\t}\n\n\tvar p0, p1, p2, p3; // 4 points\n\n\tif ( this.closed || intPoint > 0 ) {\n\n\t\tp0 = points[ ( intPoint - 1 ) % l ];\n\n\t} else {\n\n\t\t// extrapolate first point\n\t\ttmp.subVectors( points[ 0 ], points[ 1 ] ).add( points[ 0 ] );\n\t\tp0 = tmp;\n\n\t}\n\n\tp1 = points[ intPoint % l ];\n\tp2 = points[ ( intPoint + 1 ) % l ];\n\n\tif ( this.closed || intPoint + 2 < l ) {\n\n\t\tp3 = points[ ( intPoint + 2 ) % l ];\n\n\t} else {\n\n\t\t// extrapolate last point\n\t\ttmp.subVectors( points[ l - 1 ], points[ l - 2 ] ).add( points[ l - 1 ] );\n\t\tp3 = tmp;\n\n\t}\n\n\tif ( this.curveType === 'centripetal' || this.curveType === 'chordal' ) {\n\n\t\t// init Centripetal / Chordal Catmull-Rom\n\t\tvar pow = this.curveType === 'chordal' ? 0.5 : 0.25;\n\t\tvar dt0 = Math.pow( p0.distanceToSquared( p1 ), pow );\n\t\tvar dt1 = Math.pow( p1.distanceToSquared( p2 ), pow );\n\t\tvar dt2 = Math.pow( p2.distanceToSquared( p3 ), pow );\n\n\t\t// safety check for repeated points\n\t\tif ( dt1 < 1e-4 ) dt1 = 1.0;\n\t\tif ( dt0 < 1e-4 ) dt0 = dt1;\n\t\tif ( dt2 < 1e-4 ) dt2 = dt1;\n\n\t\tpx$1.initNonuniformCatmullRom( p0.x, p1.x, p2.x, p3.x, dt0, dt1, dt2 );\n\t\tpy.initNonuniformCatmullRom( p0.y, p1.y, p2.y, p3.y, dt0, dt1, dt2 );\n\t\tpz.initNonuniformCatmullRom( p0.z, p1.z, p2.z, p3.z, dt0, dt1, dt2 );\n\n\t} else if ( this.curveType === 'catmullrom' ) {\n\n\t\tpx$1.initCatmullRom( p0.x, p1.x, p2.x, p3.x, this.tension );\n\t\tpy.initCatmullRom( p0.y, p1.y, p2.y, p3.y, this.tension );\n\t\tpz.initCatmullRom( p0.z, p1.z, p2.z, p3.z, this.tension );\n\n\t}\n\n\tpoint.set(\n\t\tpx$1.calc( weight ),\n\t\tpy.calc( weight ),\n\t\tpz.calc( weight )\n\t);\n\n\treturn point;\n\n};\n\nCatmullRomCurve3.prototype.copy = function ( source ) {\n\n\tCurve.prototype.copy.call( this, source );\n\n\tthis.points = [];\n\n\tfor ( var i = 0, l = source.points.length; i < l; i ++ ) {\n\n\t\tvar point = source.points[ i ];\n\n\t\tthis.points.push( point.clone() );\n\n\t}\n\n\tthis.closed = source.closed;\n\tthis.curveType = source.curveType;\n\tthis.tension = source.tension;\n\n\treturn this;\n\n};\n\nCatmullRomCurve3.prototype.toJSON = function () {\n\n\tvar data = Curve.prototype.toJSON.call( this );\n\n\tdata.points = [];\n\n\tfor ( var i = 0, l = this.points.length; i < l; i ++ ) {\n\n\t\tvar point = this.points[ i ];\n\t\tdata.points.push( point.toArray() );\n\n\t}\n\n\tdata.closed = this.closed;\n\tdata.curveType = this.curveType;\n\tdata.tension = this.tension;\n\n\treturn data;\n\n};\n\nCatmullRomCurve3.prototype.fromJSON = function ( json ) {\n\n\tCurve.prototype.fromJSON.call( this, json );\n\n\tthis.points = [];\n\n\tfor ( var i = 0, l = json.points.length; i < l; i ++ ) {\n\n\t\tvar point = json.points[ i ];\n\t\tthis.points.push( new Vector3().fromArray( point ) );\n\n\t}\n\n\tthis.closed = json.closed;\n\tthis.curveType = json.curveType;\n\tthis.tension = json.tension;\n\n\treturn this;\n\n};\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n *\n * Bezier Curves formulas obtained from\n * http://en.wikipedia.org/wiki/Bézier_curve\n */\n\nfunction CatmullRom( t, p0, p1, p2, p3 ) {\n\n\tvar v0 = ( p2 - p0 ) * 0.5;\n\tvar v1 = ( p3 - p1 ) * 0.5;\n\tvar t2 = t * t;\n\tvar t3 = t * t2;\n\treturn ( 2 * p1 - 2 * p2 + v0 + v1 ) * t3 + ( - 3 * p1 + 3 * p2 - 2 * v0 - v1 ) * t2 + v0 * t + p1;\n\n}\n\n//\n\nfunction QuadraticBezierP0( t, p ) {\n\n\tvar k = 1 - t;\n\treturn k * k * p;\n\n}\n\nfunction QuadraticBezierP1( t, p ) {\n\n\treturn 2 * ( 1 - t ) * t * p;\n\n}\n\nfunction QuadraticBezierP2( t, p ) {\n\n\treturn t * t * p;\n\n}\n\nfunction QuadraticBezier( t, p0, p1, p2 ) {\n\n\treturn QuadraticBezierP0( t, p0 ) + QuadraticBezierP1( t, p1 ) +\n\t\tQuadraticBezierP2( t, p2 );\n\n}\n\n//\n\nfunction CubicBezierP0( t, p ) {\n\n\tvar k = 1 - t;\n\treturn k * k * k * p;\n\n}\n\nfunction CubicBezierP1( t, p ) {\n\n\tvar k = 1 - t;\n\treturn 3 * k * k * t * p;\n\n}\n\nfunction CubicBezierP2( t, p ) {\n\n\treturn 3 * ( 1 - t ) * t * t * p;\n\n}\n\nfunction CubicBezierP3( t, p ) {\n\n\treturn t * t * t * p;\n\n}\n\nfunction CubicBezier( t, p0, p1, p2, p3 ) {\n\n\treturn CubicBezierP0( t, p0 ) + CubicBezierP1( t, p1 ) + CubicBezierP2( t, p2 ) +\n\t\tCubicBezierP3( t, p3 );\n\n}\n\nfunction CubicBezierCurve( v0, v1, v2, v3 ) {\n\n\tCurve.call( this );\n\n\tthis.type = 'CubicBezierCurve';\n\n\tthis.v0 = v0 || new Vector2();\n\tthis.v1 = v1 || new Vector2();\n\tthis.v2 = v2 || new Vector2();\n\tthis.v3 = v3 || new Vector2();\n\n}\n\nCubicBezierCurve.prototype = Object.create( Curve.prototype );\nCubicBezierCurve.prototype.constructor = CubicBezierCurve;\n\nCubicBezierCurve.prototype.isCubicBezierCurve = true;\n\nCubicBezierCurve.prototype.getPoint = function ( t, optionalTarget ) {\n\n\tvar point = optionalTarget || new Vector2();\n\n\tvar v0 = this.v0, v1 = this.v1, v2 = this.v2, v3 = this.v3;\n\n\tpoint.set(\n\t\tCubicBezier( t, v0.x, v1.x, v2.x, v3.x ),\n\t\tCubicBezier( t, v0.y, v1.y, v2.y, v3.y )\n\t);\n\n\treturn point;\n\n};\n\nCubicBezierCurve.prototype.copy = function ( source ) {\n\n\tCurve.prototype.copy.call( this, source );\n\n\tthis.v0.copy( source.v0 );\n\tthis.v1.copy( source.v1 );\n\tthis.v2.copy( source.v2 );\n\tthis.v3.copy( source.v3 );\n\n\treturn this;\n\n};\n\nCubicBezierCurve.prototype.toJSON = function () {\n\n\tvar data = Curve.prototype.toJSON.call( this );\n\n\tdata.v0 = this.v0.toArray();\n\tdata.v1 = this.v1.toArray();\n\tdata.v2 = this.v2.toArray();\n\tdata.v3 = this.v3.toArray();\n\n\treturn data;\n\n};\n\nCubicBezierCurve.prototype.fromJSON = function ( json ) {\n\n\tCurve.prototype.fromJSON.call( this, json );\n\n\tthis.v0.fromArray( json.v0 );\n\tthis.v1.fromArray( json.v1 );\n\tthis.v2.fromArray( json.v2 );\n\tthis.v3.fromArray( json.v3 );\n\n\treturn this;\n\n};\n\nfunction CubicBezierCurve3( v0, v1, v2, v3 ) {\n\n\tCurve.call( this );\n\n\tthis.type = 'CubicBezierCurve3';\n\n\tthis.v0 = v0 || new Vector3();\n\tthis.v1 = v1 || new Vector3();\n\tthis.v2 = v2 || new Vector3();\n\tthis.v3 = v3 || new Vector3();\n\n}\n\nCubicBezierCurve3.prototype = Object.create( Curve.prototype );\nCubicBezierCurve3.prototype.constructor = CubicBezierCurve3;\n\nCubicBezierCurve3.prototype.isCubicBezierCurve3 = true;\n\nCubicBezierCurve3.prototype.getPoint = function ( t, optionalTarget ) {\n\n\tvar point = optionalTarget || new Vector3();\n\n\tvar v0 = this.v0, v1 = this.v1, v2 = this.v2, v3 = this.v3;\n\n\tpoint.set(\n\t\tCubicBezier( t, v0.x, v1.x, v2.x, v3.x ),\n\t\tCubicBezier( t, v0.y, v1.y, v2.y, v3.y ),\n\t\tCubicBezier( t, v0.z, v1.z, v2.z, v3.z )\n\t);\n\n\treturn point;\n\n};\n\nCubicBezierCurve3.prototype.copy = function ( source ) {\n\n\tCurve.prototype.copy.call( this, source );\n\n\tthis.v0.copy( source.v0 );\n\tthis.v1.copy( source.v1 );\n\tthis.v2.copy( source.v2 );\n\tthis.v3.copy( source.v3 );\n\n\treturn this;\n\n};\n\nCubicBezierCurve3.prototype.toJSON = function () {\n\n\tvar data = Curve.prototype.toJSON.call( this );\n\n\tdata.v0 = this.v0.toArray();\n\tdata.v1 = this.v1.toArray();\n\tdata.v2 = this.v2.toArray();\n\tdata.v3 = this.v3.toArray();\n\n\treturn data;\n\n};\n\nCubicBezierCurve3.prototype.fromJSON = function ( json ) {\n\n\tCurve.prototype.fromJSON.call( this, json );\n\n\tthis.v0.fromArray( json.v0 );\n\tthis.v1.fromArray( json.v1 );\n\tthis.v2.fromArray( json.v2 );\n\tthis.v3.fromArray( json.v3 );\n\n\treturn this;\n\n};\n\nfunction LineCurve( v1, v2 ) {\n\n\tCurve.call( this );\n\n\tthis.type = 'LineCurve';\n\n\tthis.v1 = v1 || new Vector2();\n\tthis.v2 = v2 || new Vector2();\n\n}\n\nLineCurve.prototype = Object.create( Curve.prototype );\nLineCurve.prototype.constructor = LineCurve;\n\nLineCurve.prototype.isLineCurve = true;\n\nLineCurve.prototype.getPoint = function ( t, optionalTarget ) {\n\n\tvar point = optionalTarget || new Vector2();\n\n\tif ( t === 1 ) {\n\n\t\tpoint.copy( this.v2 );\n\n\t} else {\n\n\t\tpoint.copy( this.v2 ).sub( this.v1 );\n\t\tpoint.multiplyScalar( t ).add( this.v1 );\n\n\t}\n\n\treturn point;\n\n};\n\n// Line curve is linear, so we can overwrite default getPointAt\n\nLineCurve.prototype.getPointAt = function ( u, optionalTarget ) {\n\n\treturn this.getPoint( u, optionalTarget );\n\n};\n\nLineCurve.prototype.getTangent = function ( /* t */ ) {\n\n\tvar tangent = this.v2.clone().sub( this.v1 );\n\n\treturn tangent.normalize();\n\n};\n\nLineCurve.prototype.copy = function ( source ) {\n\n\tCurve.prototype.copy.call( this, source );\n\n\tthis.v1.copy( source.v1 );\n\tthis.v2.copy( source.v2 );\n\n\treturn this;\n\n};\n\nLineCurve.prototype.toJSON = function () {\n\n\tvar data = Curve.prototype.toJSON.call( this );\n\n\tdata.v1 = this.v1.toArray();\n\tdata.v2 = this.v2.toArray();\n\n\treturn data;\n\n};\n\nLineCurve.prototype.fromJSON = function ( json ) {\n\n\tCurve.prototype.fromJSON.call( this, json );\n\n\tthis.v1.fromArray( json.v1 );\n\tthis.v2.fromArray( json.v2 );\n\n\treturn this;\n\n};\n\nfunction LineCurve3( v1, v2 ) {\n\n\tCurve.call( this );\n\n\tthis.type = 'LineCurve3';\n\n\tthis.v1 = v1 || new Vector3();\n\tthis.v2 = v2 || new Vector3();\n\n}\n\nLineCurve3.prototype = Object.create( Curve.prototype );\nLineCurve3.prototype.constructor = LineCurve3;\n\nLineCurve3.prototype.isLineCurve3 = true;\n\nLineCurve3.prototype.getPoint = function ( t, optionalTarget ) {\n\n\tvar point = optionalTarget || new Vector3();\n\n\tif ( t === 1 ) {\n\n\t\tpoint.copy( this.v2 );\n\n\t} else {\n\n\t\tpoint.copy( this.v2 ).sub( this.v1 );\n\t\tpoint.multiplyScalar( t ).add( this.v1 );\n\n\t}\n\n\treturn point;\n\n};\n\n// Line curve is linear, so we can overwrite default getPointAt\n\nLineCurve3.prototype.getPointAt = function ( u, optionalTarget ) {\n\n\treturn this.getPoint( u, optionalTarget );\n\n};\n\nLineCurve3.prototype.copy = function ( source ) {\n\n\tCurve.prototype.copy.call( this, source );\n\n\tthis.v1.copy( source.v1 );\n\tthis.v2.copy( source.v2 );\n\n\treturn this;\n\n};\n\nLineCurve3.prototype.toJSON = function () {\n\n\tvar data = Curve.prototype.toJSON.call( this );\n\n\tdata.v1 = this.v1.toArray();\n\tdata.v2 = this.v2.toArray();\n\n\treturn data;\n\n};\n\nLineCurve3.prototype.fromJSON = function ( json ) {\n\n\tCurve.prototype.fromJSON.call( this, json );\n\n\tthis.v1.fromArray( json.v1 );\n\tthis.v2.fromArray( json.v2 );\n\n\treturn this;\n\n};\n\nfunction QuadraticBezierCurve( v0, v1, v2 ) {\n\n\tCurve.call( this );\n\n\tthis.type = 'QuadraticBezierCurve';\n\n\tthis.v0 = v0 || new Vector2();\n\tthis.v1 = v1 || new Vector2();\n\tthis.v2 = v2 || new Vector2();\n\n}\n\nQuadraticBezierCurve.prototype = Object.create( Curve.prototype );\nQuadraticBezierCurve.prototype.constructor = QuadraticBezierCurve;\n\nQuadraticBezierCurve.prototype.isQuadraticBezierCurve = true;\n\nQuadraticBezierCurve.prototype.getPoint = function ( t, optionalTarget ) {\n\n\tvar point = optionalTarget || new Vector2();\n\n\tvar v0 = this.v0, v1 = this.v1, v2 = this.v2;\n\n\tpoint.set(\n\t\tQuadraticBezier( t, v0.x, v1.x, v2.x ),\n\t\tQuadraticBezier( t, v0.y, v1.y, v2.y )\n\t);\n\n\treturn point;\n\n};\n\nQuadraticBezierCurve.prototype.copy = function ( source ) {\n\n\tCurve.prototype.copy.call( this, source );\n\n\tthis.v0.copy( source.v0 );\n\tthis.v1.copy( source.v1 );\n\tthis.v2.copy( source.v2 );\n\n\treturn this;\n\n};\n\nQuadraticBezierCurve.prototype.toJSON = function () {\n\n\tvar data = Curve.prototype.toJSON.call( this );\n\n\tdata.v0 = this.v0.toArray();\n\tdata.v1 = this.v1.toArray();\n\tdata.v2 = this.v2.toArray();\n\n\treturn data;\n\n};\n\nQuadraticBezierCurve.prototype.fromJSON = function ( json ) {\n\n\tCurve.prototype.fromJSON.call( this, json );\n\n\tthis.v0.fromArray( json.v0 );\n\tthis.v1.fromArray( json.v1 );\n\tthis.v2.fromArray( json.v2 );\n\n\treturn this;\n\n};\n\nfunction QuadraticBezierCurve3( v0, v1, v2 ) {\n\n\tCurve.call( this );\n\n\tthis.type = 'QuadraticBezierCurve3';\n\n\tthis.v0 = v0 || new Vector3();\n\tthis.v1 = v1 || new Vector3();\n\tthis.v2 = v2 || new Vector3();\n\n}\n\nQuadraticBezierCurve3.prototype = Object.create( Curve.prototype );\nQuadraticBezierCurve3.prototype.constructor = QuadraticBezierCurve3;\n\nQuadraticBezierCurve3.prototype.isQuadraticBezierCurve3 = true;\n\nQuadraticBezierCurve3.prototype.getPoint = function ( t, optionalTarget ) {\n\n\tvar point = optionalTarget || new Vector3();\n\n\tvar v0 = this.v0, v1 = this.v1, v2 = this.v2;\n\n\tpoint.set(\n\t\tQuadraticBezier( t, v0.x, v1.x, v2.x ),\n\t\tQuadraticBezier( t, v0.y, v1.y, v2.y ),\n\t\tQuadraticBezier( t, v0.z, v1.z, v2.z )\n\t);\n\n\treturn point;\n\n};\n\nQuadraticBezierCurve3.prototype.copy = function ( source ) {\n\n\tCurve.prototype.copy.call( this, source );\n\n\tthis.v0.copy( source.v0 );\n\tthis.v1.copy( source.v1 );\n\tthis.v2.copy( source.v2 );\n\n\treturn this;\n\n};\n\nQuadraticBezierCurve3.prototype.toJSON = function () {\n\n\tvar data = Curve.prototype.toJSON.call( this );\n\n\tdata.v0 = this.v0.toArray();\n\tdata.v1 = this.v1.toArray();\n\tdata.v2 = this.v2.toArray();\n\n\treturn data;\n\n};\n\nQuadraticBezierCurve3.prototype.fromJSON = function ( json ) {\n\n\tCurve.prototype.fromJSON.call( this, json );\n\n\tthis.v0.fromArray( json.v0 );\n\tthis.v1.fromArray( json.v1 );\n\tthis.v2.fromArray( json.v2 );\n\n\treturn this;\n\n};\n\nfunction SplineCurve( points /* array of Vector2 */ ) {\n\n\tCurve.call( this );\n\n\tthis.type = 'SplineCurve';\n\n\tthis.points = points || [];\n\n}\n\nSplineCurve.prototype = Object.create( Curve.prototype );\nSplineCurve.prototype.constructor = SplineCurve;\n\nSplineCurve.prototype.isSplineCurve = true;\n\nSplineCurve.prototype.getPoint = function ( t, optionalTarget ) {\n\n\tvar point = optionalTarget || new Vector2();\n\n\tvar points = this.points;\n\tvar p = ( points.length - 1 ) * t;\n\n\tvar intPoint = Math.floor( p );\n\tvar weight = p - intPoint;\n\n\tvar p0 = points[ intPoint === 0 ? intPoint : intPoint - 1 ];\n\tvar p1 = points[ intPoint ];\n\tvar p2 = points[ intPoint > points.length - 2 ? points.length - 1 : intPoint + 1 ];\n\tvar p3 = points[ intPoint > points.length - 3 ? points.length - 1 : intPoint + 2 ];\n\n\tpoint.set(\n\t\tCatmullRom( weight, p0.x, p1.x, p2.x, p3.x ),\n\t\tCatmullRom( weight, p0.y, p1.y, p2.y, p3.y )\n\t);\n\n\treturn point;\n\n};\n\nSplineCurve.prototype.copy = function ( source ) {\n\n\tCurve.prototype.copy.call( this, source );\n\n\tthis.points = [];\n\n\tfor ( var i = 0, l = source.points.length; i < l; i ++ ) {\n\n\t\tvar point = source.points[ i ];\n\n\t\tthis.points.push( point.clone() );\n\n\t}\n\n\treturn this;\n\n};\n\nSplineCurve.prototype.toJSON = function () {\n\n\tvar data = Curve.prototype.toJSON.call( this );\n\n\tdata.points = [];\n\n\tfor ( var i = 0, l = this.points.length; i < l; i ++ ) {\n\n\t\tvar point = this.points[ i ];\n\t\tdata.points.push( point.toArray() );\n\n\t}\n\n\treturn data;\n\n};\n\nSplineCurve.prototype.fromJSON = function ( json ) {\n\n\tCurve.prototype.fromJSON.call( this, json );\n\n\tthis.points = [];\n\n\tfor ( var i = 0, l = json.points.length; i < l; i ++ ) {\n\n\t\tvar point = json.points[ i ];\n\t\tthis.points.push( new Vector2().fromArray( point ) );\n\n\t}\n\n\treturn this;\n\n};\n\n\n\nvar Curves = Object.freeze({\n\tArcCurve: ArcCurve,\n\tCatmullRomCurve3: CatmullRomCurve3,\n\tCubicBezierCurve: CubicBezierCurve,\n\tCubicBezierCurve3: CubicBezierCurve3,\n\tEllipseCurve: EllipseCurve,\n\tLineCurve: LineCurve,\n\tLineCurve3: LineCurve3,\n\tQuadraticBezierCurve: QuadraticBezierCurve,\n\tQuadraticBezierCurve3: QuadraticBezierCurve3,\n\tSplineCurve: SplineCurve\n});\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n *\n **/\n\n/**************************************************************\n *\tCurved Path - a curve path is simply a array of connected\n *  curves, but retains the api of a curve\n **************************************************************/\n\nfunction CurvePath() {\n\n\tCurve.call( this );\n\n\tthis.type = 'CurvePath';\n\n\tthis.curves = [];\n\tthis.autoClose = false; // Automatically closes the path\n\n}\n\nCurvePath.prototype = Object.assign( Object.create( Curve.prototype ), {\n\n\tconstructor: CurvePath,\n\n\tadd: function ( curve ) {\n\n\t\tthis.curves.push( curve );\n\n\t},\n\n\tclosePath: function () {\n\n\t\t// Add a line curve if start and end of lines are not connected\n\t\tvar startPoint = this.curves[ 0 ].getPoint( 0 );\n\t\tvar endPoint = this.curves[ this.curves.length - 1 ].getPoint( 1 );\n\n\t\tif ( ! startPoint.equals( endPoint ) ) {\n\n\t\t\tthis.curves.push( new LineCurve( endPoint, startPoint ) );\n\n\t\t}\n\n\t},\n\n\t// To get accurate point with reference to\n\t// entire path distance at time t,\n\t// following has to be done:\n\n\t// 1. Length of each sub path have to be known\n\t// 2. Locate and identify type of curve\n\t// 3. Get t for the curve\n\t// 4. Return curve.getPointAt(t')\n\n\tgetPoint: function ( t ) {\n\n\t\tvar d = t * this.getLength();\n\t\tvar curveLengths = this.getCurveLengths();\n\t\tvar i = 0;\n\n\t\t// To think about boundaries points.\n\n\t\twhile ( i < curveLengths.length ) {\n\n\t\t\tif ( curveLengths[ i ] >= d ) {\n\n\t\t\t\tvar diff = curveLengths[ i ] - d;\n\t\t\t\tvar curve = this.curves[ i ];\n\n\t\t\t\tvar segmentLength = curve.getLength();\n\t\t\t\tvar u = segmentLength === 0 ? 0 : 1 - diff / segmentLength;\n\n\t\t\t\treturn curve.getPointAt( u );\n\n\t\t\t}\n\n\t\t\ti ++;\n\n\t\t}\n\n\t\treturn null;\n\n\t\t// loop where sum != 0, sum > d , sum+1 <d\n\n\t},\n\n\t// We cannot use the default THREE.Curve getPoint() with getLength() because in\n\t// THREE.Curve, getLength() depends on getPoint() but in THREE.CurvePath\n\t// getPoint() depends on getLength\n\n\tgetLength: function () {\n\n\t\tvar lens = this.getCurveLengths();\n\t\treturn lens[ lens.length - 1 ];\n\n\t},\n\n\t// cacheLengths must be recalculated.\n\tupdateArcLengths: function () {\n\n\t\tthis.needsUpdate = true;\n\t\tthis.cacheLengths = null;\n\t\tthis.getCurveLengths();\n\n\t},\n\n\t// Compute lengths and cache them\n\t// We cannot overwrite getLengths() because UtoT mapping uses it.\n\n\tgetCurveLengths: function () {\n\n\t\t// We use cache values if curves and cache array are same length\n\n\t\tif ( this.cacheLengths && this.cacheLengths.length === this.curves.length ) {\n\n\t\t\treturn this.cacheLengths;\n\n\t\t}\n\n\t\t// Get length of sub-curve\n\t\t// Push sums into cached array\n\n\t\tvar lengths = [], sums = 0;\n\n\t\tfor ( var i = 0, l = this.curves.length; i < l; i ++ ) {\n\n\t\t\tsums += this.curves[ i ].getLength();\n\t\t\tlengths.push( sums );\n\n\t\t}\n\n\t\tthis.cacheLengths = lengths;\n\n\t\treturn lengths;\n\n\t},\n\n\tgetSpacedPoints: function ( divisions ) {\n\n\t\tif ( divisions === undefined ) divisions = 40;\n\n\t\tvar points = [];\n\n\t\tfor ( var i = 0; i <= divisions; i ++ ) {\n\n\t\t\tpoints.push( this.getPoint( i / divisions ) );\n\n\t\t}\n\n\t\tif ( this.autoClose ) {\n\n\t\t\tpoints.push( points[ 0 ] );\n\n\t\t}\n\n\t\treturn points;\n\n\t},\n\n\tgetPoints: function ( divisions ) {\n\n\t\tdivisions = divisions || 12;\n\n\t\tvar points = [], last;\n\n\t\tfor ( var i = 0, curves = this.curves; i < curves.length; i ++ ) {\n\n\t\t\tvar curve = curves[ i ];\n\t\t\tvar resolution = ( curve && curve.isEllipseCurve ) ? divisions * 2\n\t\t\t\t: ( curve && curve.isLineCurve ) ? 1\n\t\t\t\t\t: ( curve && curve.isSplineCurve ) ? divisions * curve.points.length\n\t\t\t\t\t\t: divisions;\n\n\t\t\tvar pts = curve.getPoints( resolution );\n\n\t\t\tfor ( var j = 0; j < pts.length; j ++ ) {\n\n\t\t\t\tvar point = pts[ j ];\n\n\t\t\t\tif ( last && last.equals( point ) ) continue; // ensures no consecutive points are duplicates\n\n\t\t\t\tpoints.push( point );\n\t\t\t\tlast = point;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.autoClose && points.length > 1 && ! points[ points.length - 1 ].equals( points[ 0 ] ) ) {\n\n\t\t\tpoints.push( points[ 0 ] );\n\n\t\t}\n\n\t\treturn points;\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tCurve.prototype.copy.call( this, source );\n\n\t\tthis.curves = [];\n\n\t\tfor ( var i = 0, l = source.curves.length; i < l; i ++ ) {\n\n\t\t\tvar curve = source.curves[ i ];\n\n\t\t\tthis.curves.push( curve.clone() );\n\n\t\t}\n\n\t\tthis.autoClose = source.autoClose;\n\n\t\treturn this;\n\n\t},\n\n\ttoJSON: function () {\n\n\t\tvar data = Curve.prototype.toJSON.call( this );\n\n\t\tdata.autoClose = this.autoClose;\n\t\tdata.curves = [];\n\n\t\tfor ( var i = 0, l = this.curves.length; i < l; i ++ ) {\n\n\t\t\tvar curve = this.curves[ i ];\n\t\t\tdata.curves.push( curve.toJSON() );\n\n\t\t}\n\n\t\treturn data;\n\n\t},\n\n\tfromJSON: function ( json ) {\n\n\t\tCurve.prototype.fromJSON.call( this, json );\n\n\t\tthis.autoClose = json.autoClose;\n\t\tthis.curves = [];\n\n\t\tfor ( var i = 0, l = json.curves.length; i < l; i ++ ) {\n\n\t\t\tvar curve = json.curves[ i ];\n\t\t\tthis.curves.push( new Curves[ curve.type ]().fromJSON( curve ) );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n * Creates free form 2d path using series of points, lines or curves.\n **/\n\nfunction Path( points ) {\n\n\tCurvePath.call( this );\n\n\tthis.type = 'Path';\n\n\tthis.currentPoint = new Vector2();\n\n\tif ( points ) {\n\n\t\tthis.setFromPoints( points );\n\n\t}\n\n}\n\nPath.prototype = Object.assign( Object.create( CurvePath.prototype ), {\n\n\tconstructor: Path,\n\n\tsetFromPoints: function ( points ) {\n\n\t\tthis.moveTo( points[ 0 ].x, points[ 0 ].y );\n\n\t\tfor ( var i = 1, l = points.length; i < l; i ++ ) {\n\n\t\t\tthis.lineTo( points[ i ].x, points[ i ].y );\n\n\t\t}\n\n\t},\n\n\tmoveTo: function ( x, y ) {\n\n\t\tthis.currentPoint.set( x, y ); // TODO consider referencing vectors instead of copying?\n\n\t},\n\n\tlineTo: function ( x, y ) {\n\n\t\tvar curve = new LineCurve( this.currentPoint.clone(), new Vector2( x, y ) );\n\t\tthis.curves.push( curve );\n\n\t\tthis.currentPoint.set( x, y );\n\n\t},\n\n\tquadraticCurveTo: function ( aCPx, aCPy, aX, aY ) {\n\n\t\tvar curve = new QuadraticBezierCurve(\n\t\t\tthis.currentPoint.clone(),\n\t\t\tnew Vector2( aCPx, aCPy ),\n\t\t\tnew Vector2( aX, aY )\n\t\t);\n\n\t\tthis.curves.push( curve );\n\n\t\tthis.currentPoint.set( aX, aY );\n\n\t},\n\n\tbezierCurveTo: function ( aCP1x, aCP1y, aCP2x, aCP2y, aX, aY ) {\n\n\t\tvar curve = new CubicBezierCurve(\n\t\t\tthis.currentPoint.clone(),\n\t\t\tnew Vector2( aCP1x, aCP1y ),\n\t\t\tnew Vector2( aCP2x, aCP2y ),\n\t\t\tnew Vector2( aX, aY )\n\t\t);\n\n\t\tthis.curves.push( curve );\n\n\t\tthis.currentPoint.set( aX, aY );\n\n\t},\n\n\tsplineThru: function ( pts /*Array of Vector*/ ) {\n\n\t\tvar npts = [ this.currentPoint.clone() ].concat( pts );\n\n\t\tvar curve = new SplineCurve( npts );\n\t\tthis.curves.push( curve );\n\n\t\tthis.currentPoint.copy( pts[ pts.length - 1 ] );\n\n\t},\n\n\tarc: function ( aX, aY, aRadius, aStartAngle, aEndAngle, aClockwise ) {\n\n\t\tvar x0 = this.currentPoint.x;\n\t\tvar y0 = this.currentPoint.y;\n\n\t\tthis.absarc( aX + x0, aY + y0, aRadius,\n\t\t\taStartAngle, aEndAngle, aClockwise );\n\n\t},\n\n\tabsarc: function ( aX, aY, aRadius, aStartAngle, aEndAngle, aClockwise ) {\n\n\t\tthis.absellipse( aX, aY, aRadius, aRadius, aStartAngle, aEndAngle, aClockwise );\n\n\t},\n\n\tellipse: function ( aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation ) {\n\n\t\tvar x0 = this.currentPoint.x;\n\t\tvar y0 = this.currentPoint.y;\n\n\t\tthis.absellipse( aX + x0, aY + y0, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation );\n\n\t},\n\n\tabsellipse: function ( aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation ) {\n\n\t\tvar curve = new EllipseCurve( aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation );\n\n\t\tif ( this.curves.length > 0 ) {\n\n\t\t\t// if a previous curve is present, attempt to join\n\t\t\tvar firstPoint = curve.getPoint( 0 );\n\n\t\t\tif ( ! firstPoint.equals( this.currentPoint ) ) {\n\n\t\t\t\tthis.lineTo( firstPoint.x, firstPoint.y );\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis.curves.push( curve );\n\n\t\tvar lastPoint = curve.getPoint( 1 );\n\t\tthis.currentPoint.copy( lastPoint );\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tCurvePath.prototype.copy.call( this, source );\n\n\t\tthis.currentPoint.copy( source.currentPoint );\n\n\t\treturn this;\n\n\t},\n\n\ttoJSON: function () {\n\n\t\tvar data = CurvePath.prototype.toJSON.call( this );\n\n\t\tdata.currentPoint = this.currentPoint.toArray();\n\n\t\treturn data;\n\n\t},\n\n\tfromJSON: function ( json ) {\n\n\t\tCurvePath.prototype.fromJSON.call( this, json );\n\n\t\tthis.currentPoint.fromArray( json.currentPoint );\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n * Defines a 2d shape plane using paths.\n **/\n\n// STEP 1 Create a path.\n// STEP 2 Turn path into shape.\n// STEP 3 ExtrudeGeometry takes in Shape/Shapes\n// STEP 3a - Extract points from each shape, turn to vertices\n// STEP 3b - Triangulate each shape, add faces.\n\nfunction Shape( points ) {\n\n\tPath.call( this, points );\n\n\tthis.uuid = _Math.generateUUID();\n\n\tthis.type = 'Shape';\n\n\tthis.holes = [];\n\n}\n\nShape.prototype = Object.assign( Object.create( Path.prototype ), {\n\n\tconstructor: Shape,\n\n\tgetPointsHoles: function ( divisions ) {\n\n\t\tvar holesPts = [];\n\n\t\tfor ( var i = 0, l = this.holes.length; i < l; i ++ ) {\n\n\t\t\tholesPts[ i ] = this.holes[ i ].getPoints( divisions );\n\n\t\t}\n\n\t\treturn holesPts;\n\n\t},\n\n\t// get points of shape and holes (keypoints based on segments parameter)\n\n\textractPoints: function ( divisions ) {\n\n\t\treturn {\n\n\t\t\tshape: this.getPoints( divisions ),\n\t\t\tholes: this.getPointsHoles( divisions )\n\n\t\t};\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tPath.prototype.copy.call( this, source );\n\n\t\tthis.holes = [];\n\n\t\tfor ( var i = 0, l = source.holes.length; i < l; i ++ ) {\n\n\t\t\tvar hole = source.holes[ i ];\n\n\t\t\tthis.holes.push( hole.clone() );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\ttoJSON: function () {\n\n\t\tvar data = Path.prototype.toJSON.call( this );\n\n\t\tdata.uuid = this.uuid;\n\t\tdata.holes = [];\n\n\t\tfor ( var i = 0, l = this.holes.length; i < l; i ++ ) {\n\n\t\t\tvar hole = this.holes[ i ];\n\t\t\tdata.holes.push( hole.toJSON() );\n\n\t\t}\n\n\t\treturn data;\n\n\t},\n\n\tfromJSON: function ( json ) {\n\n\t\tPath.prototype.fromJSON.call( this, json );\n\n\t\tthis.uuid = json.uuid;\n\t\tthis.holes = [];\n\n\t\tfor ( var i = 0, l = json.holes.length; i < l; i ++ ) {\n\n\t\t\tvar hole = json.holes[ i ];\n\t\t\tthis.holes.push( new Path().fromJSON( hole ) );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction Light( color, intensity ) {\n\n\tObject3D.call( this );\n\n\tthis.type = 'Light';\n\n\tthis.color = new Color( color );\n\tthis.intensity = intensity !== undefined ? intensity : 1;\n\n\tthis.receiveShadow = undefined;\n\n}\n\nLight.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Light,\n\n\tisLight: true,\n\n\tcopy: function ( source ) {\n\n\t\tObject3D.prototype.copy.call( this, source );\n\n\t\tthis.color.copy( source.color );\n\t\tthis.intensity = source.intensity;\n\n\t\treturn this;\n\n\t},\n\n\ttoJSON: function ( meta ) {\n\n\t\tvar data = Object3D.prototype.toJSON.call( this, meta );\n\n\t\tdata.object.color = this.color.getHex();\n\t\tdata.object.intensity = this.intensity;\n\n\t\tif ( this.groundColor !== undefined ) data.object.groundColor = this.groundColor.getHex();\n\n\t\tif ( this.distance !== undefined ) data.object.distance = this.distance;\n\t\tif ( this.angle !== undefined ) data.object.angle = this.angle;\n\t\tif ( this.decay !== undefined ) data.object.decay = this.decay;\n\t\tif ( this.penumbra !== undefined ) data.object.penumbra = this.penumbra;\n\n\t\tif ( this.shadow !== undefined ) data.object.shadow = this.shadow.toJSON();\n\n\t\treturn data;\n\n\t}\n\n} );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction HemisphereLight( skyColor, groundColor, intensity ) {\n\n\tLight.call( this, skyColor, intensity );\n\n\tthis.type = 'HemisphereLight';\n\n\tthis.castShadow = undefined;\n\n\tthis.position.copy( Object3D.DefaultUp );\n\tthis.updateMatrix();\n\n\tthis.groundColor = new Color( groundColor );\n\n}\n\nHemisphereLight.prototype = Object.assign( Object.create( Light.prototype ), {\n\n\tconstructor: HemisphereLight,\n\n\tisHemisphereLight: true,\n\n\tcopy: function ( source ) {\n\n\t\tLight.prototype.copy.call( this, source );\n\n\t\tthis.groundColor.copy( source.groundColor );\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction LightShadow( camera ) {\n\n\tthis.camera = camera;\n\n\tthis.bias = 0;\n\tthis.radius = 1;\n\n\tthis.mapSize = new Vector2( 512, 512 );\n\n\tthis.map = null;\n\tthis.matrix = new Matrix4();\n\n}\n\nObject.assign( LightShadow.prototype, {\n\n\tcopy: function ( source ) {\n\n\t\tthis.camera = source.camera.clone();\n\n\t\tthis.bias = source.bias;\n\t\tthis.radius = source.radius;\n\n\t\tthis.mapSize.copy( source.mapSize );\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\ttoJSON: function () {\n\n\t\tvar object = {};\n\n\t\tif ( this.bias !== 0 ) object.bias = this.bias;\n\t\tif ( this.radius !== 1 ) object.radius = this.radius;\n\t\tif ( this.mapSize.x !== 512 || this.mapSize.y !== 512 ) object.mapSize = this.mapSize.toArray();\n\n\t\tobject.camera = this.camera.toJSON( false ).object;\n\t\tdelete object.camera.matrix;\n\n\t\treturn object;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction SpotLightShadow() {\n\n\tLightShadow.call( this, new PerspectiveCamera( 50, 1, 0.5, 500 ) );\n\n}\n\nSpotLightShadow.prototype = Object.assign( Object.create( LightShadow.prototype ), {\n\n\tconstructor: SpotLightShadow,\n\n\tisSpotLightShadow: true,\n\n\tupdate: function ( light ) {\n\n\t\tvar camera = this.camera;\n\n\t\tvar fov = _Math.RAD2DEG * 2 * light.angle;\n\t\tvar aspect = this.mapSize.width / this.mapSize.height;\n\t\tvar far = light.distance || camera.far;\n\n\t\tif ( fov !== camera.fov || aspect !== camera.aspect || far !== camera.far ) {\n\n\t\t\tcamera.fov = fov;\n\t\t\tcamera.aspect = aspect;\n\t\t\tcamera.far = far;\n\t\t\tcamera.updateProjectionMatrix();\n\n\t\t}\n\n\t}\n\n} );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction SpotLight( color, intensity, distance, angle, penumbra, decay ) {\n\n\tLight.call( this, color, intensity );\n\n\tthis.type = 'SpotLight';\n\n\tthis.position.copy( Object3D.DefaultUp );\n\tthis.updateMatrix();\n\n\tthis.target = new Object3D();\n\n\tObject.defineProperty( this, 'power', {\n\t\tget: function () {\n\n\t\t\t// intensity = power per solid angle.\n\t\t\t// ref: equation (17) from https://seblagarde.files.wordpress.com/2015/07/course_notes_moving_frostbite_to_pbr_v32.pdf\n\t\t\treturn this.intensity * Math.PI;\n\n\t\t},\n\t\tset: function ( power ) {\n\n\t\t\t// intensity = power per solid angle.\n\t\t\t// ref: equation (17) from https://seblagarde.files.wordpress.com/2015/07/course_notes_moving_frostbite_to_pbr_v32.pdf\n\t\t\tthis.intensity = power / Math.PI;\n\n\t\t}\n\t} );\n\n\tthis.distance = ( distance !== undefined ) ? distance : 0;\n\tthis.angle = ( angle !== undefined ) ? angle : Math.PI / 3;\n\tthis.penumbra = ( penumbra !== undefined ) ? penumbra : 0;\n\tthis.decay = ( decay !== undefined ) ? decay : 1;\t// for physically correct lights, should be 2.\n\n\tthis.shadow = new SpotLightShadow();\n\n}\n\nSpotLight.prototype = Object.assign( Object.create( Light.prototype ), {\n\n\tconstructor: SpotLight,\n\n\tisSpotLight: true,\n\n\tcopy: function ( source ) {\n\n\t\tLight.prototype.copy.call( this, source );\n\n\t\tthis.distance = source.distance;\n\t\tthis.angle = source.angle;\n\t\tthis.penumbra = source.penumbra;\n\t\tthis.decay = source.decay;\n\n\t\tthis.target = source.target.clone();\n\n\t\tthis.shadow = source.shadow.clone();\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\n\nfunction PointLight( color, intensity, distance, decay ) {\n\n\tLight.call( this, color, intensity );\n\n\tthis.type = 'PointLight';\n\n\tObject.defineProperty( this, 'power', {\n\t\tget: function () {\n\n\t\t\t// intensity = power per solid angle.\n\t\t\t// ref: equation (15) from https://seblagarde.files.wordpress.com/2015/07/course_notes_moving_frostbite_to_pbr_v32.pdf\n\t\t\treturn this.intensity * 4 * Math.PI;\n\n\t\t},\n\t\tset: function ( power ) {\n\n\t\t\t// intensity = power per solid angle.\n\t\t\t// ref: equation (15) from https://seblagarde.files.wordpress.com/2015/07/course_notes_moving_frostbite_to_pbr_v32.pdf\n\t\t\tthis.intensity = power / ( 4 * Math.PI );\n\n\t\t}\n\t} );\n\n\tthis.distance = ( distance !== undefined ) ? distance : 0;\n\tthis.decay = ( decay !== undefined ) ? decay : 1;\t// for physically correct lights, should be 2.\n\n\tthis.shadow = new LightShadow( new PerspectiveCamera( 90, 1, 0.5, 500 ) );\n\n}\n\nPointLight.prototype = Object.assign( Object.create( Light.prototype ), {\n\n\tconstructor: PointLight,\n\n\tisPointLight: true,\n\n\tcopy: function ( source ) {\n\n\t\tLight.prototype.copy.call( this, source );\n\n\t\tthis.distance = source.distance;\n\t\tthis.decay = source.decay;\n\n\t\tthis.shadow = source.shadow.clone();\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction DirectionalLightShadow( ) {\n\n\tLightShadow.call( this, new OrthographicCamera( - 5, 5, 5, - 5, 0.5, 500 ) );\n\n}\n\nDirectionalLightShadow.prototype = Object.assign( Object.create( LightShadow.prototype ), {\n\n\tconstructor: DirectionalLightShadow\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction DirectionalLight( color, intensity ) {\n\n\tLight.call( this, color, intensity );\n\n\tthis.type = 'DirectionalLight';\n\n\tthis.position.copy( Object3D.DefaultUp );\n\tthis.updateMatrix();\n\n\tthis.target = new Object3D();\n\n\tthis.shadow = new DirectionalLightShadow();\n\n}\n\nDirectionalLight.prototype = Object.assign( Object.create( Light.prototype ), {\n\n\tconstructor: DirectionalLight,\n\n\tisDirectionalLight: true,\n\n\tcopy: function ( source ) {\n\n\t\tLight.prototype.copy.call( this, source );\n\n\t\tthis.target = source.target.clone();\n\n\t\tthis.shadow = source.shadow.clone();\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction AmbientLight( color, intensity ) {\n\n\tLight.call( this, color, intensity );\n\n\tthis.type = 'AmbientLight';\n\n\tthis.castShadow = undefined;\n\n}\n\nAmbientLight.prototype = Object.assign( Object.create( Light.prototype ), {\n\n\tconstructor: AmbientLight,\n\n\tisAmbientLight: true\n\n} );\n\n/**\n * @author abelnation / http://github.com/abelnation\n */\n\nfunction RectAreaLight( color, intensity, width, height ) {\n\n\tLight.call( this, color, intensity );\n\n\tthis.type = 'RectAreaLight';\n\n\tthis.width = ( width !== undefined ) ? width : 10;\n\tthis.height = ( height !== undefined ) ? height : 10;\n\n}\n\nRectAreaLight.prototype = Object.assign( Object.create( Light.prototype ), {\n\n\tconstructor: RectAreaLight,\n\n\tisRectAreaLight: true,\n\n\tcopy: function ( source ) {\n\n\t\tLight.prototype.copy.call( this, source );\n\n\t\tthis.width = source.width;\n\t\tthis.height = source.height;\n\n\t\treturn this;\n\n\t},\n\n\ttoJSON: function ( meta ) {\n\n\t\tvar data = Light.prototype.toJSON.call( this, meta );\n\n\t\tdata.object.width = this.width;\n\t\tdata.object.height = this.height;\n\n\t\treturn data;\n\n\t}\n\n} );\n\n/**\n *\n * A Track that interpolates Strings\n *\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\nfunction StringKeyframeTrack( name, times, values, interpolation ) {\n\n\tKeyframeTrack.call( this, name, times, values, interpolation );\n\n}\n\nStringKeyframeTrack.prototype = Object.assign( Object.create( KeyframeTrack.prototype ), {\n\n\tconstructor: StringKeyframeTrack,\n\n\tValueTypeName: 'string',\n\tValueBufferType: Array,\n\n\tDefaultInterpolation: InterpolateDiscrete,\n\n\tInterpolantFactoryMethodLinear: undefined,\n\n\tInterpolantFactoryMethodSmooth: undefined\n\n} );\n\n/**\n *\n * A Track of Boolean keyframe values.\n *\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\nfunction BooleanKeyframeTrack( name, times, values ) {\n\n\tKeyframeTrack.call( this, name, times, values );\n\n}\n\nBooleanKeyframeTrack.prototype = Object.assign( Object.create( KeyframeTrack.prototype ), {\n\n\tconstructor: BooleanKeyframeTrack,\n\n\tValueTypeName: 'bool',\n\tValueBufferType: Array,\n\n\tDefaultInterpolation: InterpolateDiscrete,\n\n\tInterpolantFactoryMethodLinear: undefined,\n\tInterpolantFactoryMethodSmooth: undefined\n\n\t// Note: Actually this track could have a optimized / compressed\n\t// representation of a single value and a custom interpolant that\n\t// computes \"firstValue ^ isOdd( index )\".\n\n} );\n\n/**\n * Abstract base class of interpolants over parametric samples.\n *\n * The parameter domain is one dimensional, typically the time or a path\n * along a curve defined by the data.\n *\n * The sample values can have any dimensionality and derived classes may\n * apply special interpretations to the data.\n *\n * This class provides the interval seek in a Template Method, deferring\n * the actual interpolation to derived classes.\n *\n * Time complexity is O(1) for linear access crossing at most two points\n * and O(log N) for random access, where N is the number of positions.\n *\n * References:\n *\n * \t\thttp://www.oodesign.com/template-method-pattern.html\n *\n * @author tschw\n */\n\nfunction Interpolant( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\tthis.parameterPositions = parameterPositions;\n\tthis._cachedIndex = 0;\n\n\tthis.resultBuffer = resultBuffer !== undefined ?\n\t\tresultBuffer : new sampleValues.constructor( sampleSize );\n\tthis.sampleValues = sampleValues;\n\tthis.valueSize = sampleSize;\n\n}\n\nObject.assign( Interpolant.prototype, {\n\n\tevaluate: function ( t ) {\n\n\t\tvar pp = this.parameterPositions,\n\t\t\ti1 = this._cachedIndex,\n\n\t\t\tt1 = pp[ i1 ],\n\t\t\tt0 = pp[ i1 - 1 ];\n\n\t\tvalidate_interval: {\n\n\t\t\tseek: {\n\n\t\t\t\tvar right;\n\n\t\t\t\tlinear_scan: {\n\n\t\t\t\t\t//- See http://jsperf.com/comparison-to-undefined/3\n\t\t\t\t\t//- slower code:\n\t\t\t\t\t//-\n\t\t\t\t\t//- \t\t\t\tif ( t >= t1 || t1 === undefined ) {\n\t\t\t\t\tforward_scan: if ( ! ( t < t1 ) ) {\n\n\t\t\t\t\t\tfor ( var giveUpAt = i1 + 2; ; ) {\n\n\t\t\t\t\t\t\tif ( t1 === undefined ) {\n\n\t\t\t\t\t\t\t\tif ( t < t0 ) break forward_scan;\n\n\t\t\t\t\t\t\t\t// after end\n\n\t\t\t\t\t\t\t\ti1 = pp.length;\n\t\t\t\t\t\t\t\tthis._cachedIndex = i1;\n\t\t\t\t\t\t\t\treturn this.afterEnd_( i1 - 1, t, t0 );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif ( i1 === giveUpAt ) break; // this loop\n\n\t\t\t\t\t\t\tt0 = t1;\n\t\t\t\t\t\t\tt1 = pp[ ++ i1 ];\n\n\t\t\t\t\t\t\tif ( t < t1 ) {\n\n\t\t\t\t\t\t\t\t// we have arrived at the sought interval\n\t\t\t\t\t\t\t\tbreak seek;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// prepare binary search on the right side of the index\n\t\t\t\t\t\tright = pp.length;\n\t\t\t\t\t\tbreak linear_scan;\n\n\t\t\t\t\t}\n\n\t\t\t\t\t//- slower code:\n\t\t\t\t\t//-\t\t\t\t\tif ( t < t0 || t0 === undefined ) {\n\t\t\t\t\tif ( ! ( t >= t0 ) ) {\n\n\t\t\t\t\t\t// looping?\n\n\t\t\t\t\t\tvar t1global = pp[ 1 ];\n\n\t\t\t\t\t\tif ( t < t1global ) {\n\n\t\t\t\t\t\t\ti1 = 2; // + 1, using the scan for the details\n\t\t\t\t\t\t\tt0 = t1global;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// linear reverse scan\n\n\t\t\t\t\t\tfor ( var giveUpAt = i1 - 2; ; ) {\n\n\t\t\t\t\t\t\tif ( t0 === undefined ) {\n\n\t\t\t\t\t\t\t\t// before start\n\n\t\t\t\t\t\t\t\tthis._cachedIndex = 0;\n\t\t\t\t\t\t\t\treturn this.beforeStart_( 0, t, t1 );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif ( i1 === giveUpAt ) break; // this loop\n\n\t\t\t\t\t\t\tt1 = t0;\n\t\t\t\t\t\t\tt0 = pp[ -- i1 - 1 ];\n\n\t\t\t\t\t\t\tif ( t >= t0 ) {\n\n\t\t\t\t\t\t\t\t// we have arrived at the sought interval\n\t\t\t\t\t\t\t\tbreak seek;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// prepare binary search on the left side of the index\n\t\t\t\t\t\tright = i1;\n\t\t\t\t\t\ti1 = 0;\n\t\t\t\t\t\tbreak linear_scan;\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// the interval is valid\n\n\t\t\t\t\tbreak validate_interval;\n\n\t\t\t\t} // linear scan\n\n\t\t\t\t// binary search\n\n\t\t\t\twhile ( i1 < right ) {\n\n\t\t\t\t\tvar mid = ( i1 + right ) >>> 1;\n\n\t\t\t\t\tif ( t < pp[ mid ] ) {\n\n\t\t\t\t\t\tright = mid;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\ti1 = mid + 1;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tt1 = pp[ i1 ];\n\t\t\t\tt0 = pp[ i1 - 1 ];\n\n\t\t\t\t// check boundary cases, again\n\n\t\t\t\tif ( t0 === undefined ) {\n\n\t\t\t\t\tthis._cachedIndex = 0;\n\t\t\t\t\treturn this.beforeStart_( 0, t, t1 );\n\n\t\t\t\t}\n\n\t\t\t\tif ( t1 === undefined ) {\n\n\t\t\t\t\ti1 = pp.length;\n\t\t\t\t\tthis._cachedIndex = i1;\n\t\t\t\t\treturn this.afterEnd_( i1 - 1, t0, t );\n\n\t\t\t\t}\n\n\t\t\t} // seek\n\n\t\t\tthis._cachedIndex = i1;\n\n\t\t\tthis.intervalChanged_( i1, t0, t1 );\n\n\t\t} // validate_interval\n\n\t\treturn this.interpolate_( i1, t0, t, t1 );\n\n\t},\n\n\tsettings: null, // optional, subclass-specific settings structure\n\t// Note: The indirection allows central control of many interpolants.\n\n\t// --- Protected interface\n\n\tDefaultSettings_: {},\n\n\tgetSettings_: function () {\n\n\t\treturn this.settings || this.DefaultSettings_;\n\n\t},\n\n\tcopySampleValue_: function ( index ) {\n\n\t\t// copies a sample value to the result buffer\n\n\t\tvar result = this.resultBuffer,\n\t\t\tvalues = this.sampleValues,\n\t\t\tstride = this.valueSize,\n\t\t\toffset = index * stride;\n\n\t\tfor ( var i = 0; i !== stride; ++ i ) {\n\n\t\t\tresult[ i ] = values[ offset + i ];\n\n\t\t}\n\n\t\treturn result;\n\n\t},\n\n\t// Template methods for derived classes:\n\n\tinterpolate_: function ( /* i1, t0, t, t1 */ ) {\n\n\t\tthrow new Error( 'call to abstract method' );\n\t\t// implementations shall return this.resultBuffer\n\n\t},\n\n\tintervalChanged_: function ( /* i1, t0, t1 */ ) {\n\n\t\t// empty\n\n\t}\n\n} );\n\n//!\\ DECLARE ALIAS AFTER assign prototype !\nObject.assign( Interpolant.prototype, {\n\n\t//( 0, t, t0 ), returns this.resultBuffer\n\tbeforeStart_: Interpolant.prototype.copySampleValue_,\n\n\t//( N-1, tN-1, t ), returns this.resultBuffer\n\tafterEnd_: Interpolant.prototype.copySampleValue_,\n\n} );\n\n/**\n * Spherical linear unit quaternion interpolant.\n *\n * @author tschw\n */\n\nfunction QuaternionLinearInterpolant( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\tInterpolant.call( this, parameterPositions, sampleValues, sampleSize, resultBuffer );\n\n}\n\nQuaternionLinearInterpolant.prototype = Object.assign( Object.create( Interpolant.prototype ), {\n\n\tconstructor: QuaternionLinearInterpolant,\n\n\tinterpolate_: function ( i1, t0, t, t1 ) {\n\n\t\tvar result = this.resultBuffer,\n\t\t\tvalues = this.sampleValues,\n\t\t\tstride = this.valueSize,\n\n\t\t\toffset = i1 * stride,\n\n\t\t\talpha = ( t - t0 ) / ( t1 - t0 );\n\n\t\tfor ( var end = offset + stride; offset !== end; offset += 4 ) {\n\n\t\t\tQuaternion.slerpFlat( result, 0, values, offset - stride, values, offset, alpha );\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n} );\n\n/**\n *\n * A Track of quaternion keyframe values.\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\nfunction QuaternionKeyframeTrack( name, times, values, interpolation ) {\n\n\tKeyframeTrack.call( this, name, times, values, interpolation );\n\n}\n\nQuaternionKeyframeTrack.prototype = Object.assign( Object.create( KeyframeTrack.prototype ), {\n\n\tconstructor: QuaternionKeyframeTrack,\n\n\tValueTypeName: 'quaternion',\n\n\t// ValueBufferType is inherited\n\n\tDefaultInterpolation: InterpolateLinear,\n\n\tInterpolantFactoryMethodLinear: function ( result ) {\n\n\t\treturn new QuaternionLinearInterpolant( this.times, this.values, this.getValueSize(), result );\n\n\t},\n\n\tInterpolantFactoryMethodSmooth: undefined // not yet implemented\n\n} );\n\n/**\n *\n * A Track of keyframe values that represent color.\n *\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\nfunction ColorKeyframeTrack( name, times, values, interpolation ) {\n\n\tKeyframeTrack.call( this, name, times, values, interpolation );\n\n}\n\nColorKeyframeTrack.prototype = Object.assign( Object.create( KeyframeTrack.prototype ), {\n\n\tconstructor: ColorKeyframeTrack,\n\n\tValueTypeName: 'color'\n\n\t// ValueBufferType is inherited\n\n\t// DefaultInterpolation is inherited\n\n\t// Note: Very basic implementation and nothing special yet.\n\t// However, this is the place for color space parameterization.\n\n} );\n\n/**\n *\n * A Track of numeric keyframe values.\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\nfunction NumberKeyframeTrack( name, times, values, interpolation ) {\n\n\tKeyframeTrack.call( this, name, times, values, interpolation );\n\n}\n\nNumberKeyframeTrack.prototype = Object.assign( Object.create( KeyframeTrack.prototype ), {\n\n\tconstructor: NumberKeyframeTrack,\n\n\tValueTypeName: 'number'\n\n\t// ValueBufferType is inherited\n\n\t// DefaultInterpolation is inherited\n\n} );\n\n/**\n * Fast and simple cubic spline interpolant.\n *\n * It was derived from a Hermitian construction setting the first derivative\n * at each sample position to the linear slope between neighboring positions\n * over their parameter interval.\n *\n * @author tschw\n */\n\nfunction CubicInterpolant( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\tInterpolant.call( this, parameterPositions, sampleValues, sampleSize, resultBuffer );\n\n\tthis._weightPrev = - 0;\n\tthis._offsetPrev = - 0;\n\tthis._weightNext = - 0;\n\tthis._offsetNext = - 0;\n\n}\n\nCubicInterpolant.prototype = Object.assign( Object.create( Interpolant.prototype ), {\n\n\tconstructor: CubicInterpolant,\n\n\tDefaultSettings_: {\n\n\t\tendingStart: ZeroCurvatureEnding,\n\t\tendingEnd: ZeroCurvatureEnding\n\n\t},\n\n\tintervalChanged_: function ( i1, t0, t1 ) {\n\n\t\tvar pp = this.parameterPositions,\n\t\t\tiPrev = i1 - 2,\n\t\t\tiNext = i1 + 1,\n\n\t\t\ttPrev = pp[ iPrev ],\n\t\t\ttNext = pp[ iNext ];\n\n\t\tif ( tPrev === undefined ) {\n\n\t\t\tswitch ( this.getSettings_().endingStart ) {\n\n\t\t\t\tcase ZeroSlopeEnding:\n\n\t\t\t\t\t// f'(t0) = 0\n\t\t\t\t\tiPrev = i1;\n\t\t\t\t\ttPrev = 2 * t0 - t1;\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase WrapAroundEnding:\n\n\t\t\t\t\t// use the other end of the curve\n\t\t\t\t\tiPrev = pp.length - 2;\n\t\t\t\t\ttPrev = t0 + pp[ iPrev ] - pp[ iPrev + 1 ];\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault: // ZeroCurvatureEnding\n\n\t\t\t\t\t// f''(t0) = 0 a.k.a. Natural Spline\n\t\t\t\t\tiPrev = i1;\n\t\t\t\t\ttPrev = t1;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( tNext === undefined ) {\n\n\t\t\tswitch ( this.getSettings_().endingEnd ) {\n\n\t\t\t\tcase ZeroSlopeEnding:\n\n\t\t\t\t\t// f'(tN) = 0\n\t\t\t\t\tiNext = i1;\n\t\t\t\t\ttNext = 2 * t1 - t0;\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase WrapAroundEnding:\n\n\t\t\t\t\t// use the other end of the curve\n\t\t\t\t\tiNext = 1;\n\t\t\t\t\ttNext = t1 + pp[ 1 ] - pp[ 0 ];\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault: // ZeroCurvatureEnding\n\n\t\t\t\t\t// f''(tN) = 0, a.k.a. Natural Spline\n\t\t\t\t\tiNext = i1 - 1;\n\t\t\t\t\ttNext = t0;\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar halfDt = ( t1 - t0 ) * 0.5,\n\t\t\tstride = this.valueSize;\n\n\t\tthis._weightPrev = halfDt / ( t0 - tPrev );\n\t\tthis._weightNext = halfDt / ( tNext - t1 );\n\t\tthis._offsetPrev = iPrev * stride;\n\t\tthis._offsetNext = iNext * stride;\n\n\t},\n\n\tinterpolate_: function ( i1, t0, t, t1 ) {\n\n\t\tvar result = this.resultBuffer,\n\t\t\tvalues = this.sampleValues,\n\t\t\tstride = this.valueSize,\n\n\t\t\to1 = i1 * stride,\t\to0 = o1 - stride,\n\t\t\toP = this._offsetPrev, \toN = this._offsetNext,\n\t\t\twP = this._weightPrev,\twN = this._weightNext,\n\n\t\t\tp = ( t - t0 ) / ( t1 - t0 ),\n\t\t\tpp = p * p,\n\t\t\tppp = pp * p;\n\n\t\t// evaluate polynomials\n\n\t\tvar sP = - wP * ppp + 2 * wP * pp - wP * p;\n\t\tvar s0 = ( 1 + wP ) * ppp + ( - 1.5 - 2 * wP ) * pp + ( - 0.5 + wP ) * p + 1;\n\t\tvar s1 = ( - 1 - wN ) * ppp + ( 1.5 + wN ) * pp + 0.5 * p;\n\t\tvar sN = wN * ppp - wN * pp;\n\n\t\t// combine data linearly\n\n\t\tfor ( var i = 0; i !== stride; ++ i ) {\n\n\t\t\tresult[ i ] =\n\t\t\t\t\tsP * values[ oP + i ] +\n\t\t\t\t\ts0 * values[ o0 + i ] +\n\t\t\t\t\ts1 * values[ o1 + i ] +\n\t\t\t\t\tsN * values[ oN + i ];\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n} );\n\n/**\n * @author tschw\n */\n\nfunction LinearInterpolant( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\tInterpolant.call( this, parameterPositions, sampleValues, sampleSize, resultBuffer );\n\n}\n\nLinearInterpolant.prototype = Object.assign( Object.create( Interpolant.prototype ), {\n\n\tconstructor: LinearInterpolant,\n\n\tinterpolate_: function ( i1, t0, t, t1 ) {\n\n\t\tvar result = this.resultBuffer,\n\t\t\tvalues = this.sampleValues,\n\t\t\tstride = this.valueSize,\n\n\t\t\toffset1 = i1 * stride,\n\t\t\toffset0 = offset1 - stride,\n\n\t\t\tweight1 = ( t - t0 ) / ( t1 - t0 ),\n\t\t\tweight0 = 1 - weight1;\n\n\t\tfor ( var i = 0; i !== stride; ++ i ) {\n\n\t\t\tresult[ i ] =\n\t\t\t\t\tvalues[ offset0 + i ] * weight0 +\n\t\t\t\t\tvalues[ offset1 + i ] * weight1;\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n} );\n\n/**\n *\n * Interpolant that evaluates to the sample value at the position preceeding\n * the parameter.\n *\n * @author tschw\n */\n\nfunction DiscreteInterpolant( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\tInterpolant.call( this, parameterPositions, sampleValues, sampleSize, resultBuffer );\n\n}\n\nDiscreteInterpolant.prototype = Object.assign( Object.create( Interpolant.prototype ), {\n\n\tconstructor: DiscreteInterpolant,\n\n\tinterpolate_: function ( i1 /*, t0, t, t1 */ ) {\n\n\t\treturn this.copySampleValue_( i1 - 1 );\n\n\t}\n\n} );\n\n/**\n * @author tschw\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n */\n\nvar AnimationUtils = {\n\n\t// same as Array.prototype.slice, but also works on typed arrays\n\tarraySlice: function ( array, from, to ) {\n\n\t\tif ( AnimationUtils.isTypedArray( array ) ) {\n\n\t\t\t// in ios9 array.subarray(from, undefined) will return empty array\n\t\t\t// but array.subarray(from) or array.subarray(from, len) is correct\n\t\t\treturn new array.constructor( array.subarray( from, to !== undefined ? to : array.length ) );\n\n\t\t}\n\n\t\treturn array.slice( from, to );\n\n\t},\n\n\t// converts an array to a specific type\n\tconvertArray: function ( array, type, forceClone ) {\n\n\t\tif ( ! array || // let 'undefined' and 'null' pass\n\t\t\t\t! forceClone && array.constructor === type ) return array;\n\n\t\tif ( typeof type.BYTES_PER_ELEMENT === 'number' ) {\n\n\t\t\treturn new type( array ); // create typed array\n\n\t\t}\n\n\t\treturn Array.prototype.slice.call( array ); // create Array\n\n\t},\n\n\tisTypedArray: function ( object ) {\n\n\t\treturn ArrayBuffer.isView( object ) &&\n\t\t\t\t! ( object instanceof DataView );\n\n\t},\n\n\t// returns an array by which times and values can be sorted\n\tgetKeyframeOrder: function ( times ) {\n\n\t\tfunction compareTime( i, j ) {\n\n\t\t\treturn times[ i ] - times[ j ];\n\n\t\t}\n\n\t\tvar n = times.length;\n\t\tvar result = new Array( n );\n\t\tfor ( var i = 0; i !== n; ++ i ) result[ i ] = i;\n\n\t\tresult.sort( compareTime );\n\n\t\treturn result;\n\n\t},\n\n\t// uses the array previously returned by 'getKeyframeOrder' to sort data\n\tsortedArray: function ( values, stride, order ) {\n\n\t\tvar nValues = values.length;\n\t\tvar result = new values.constructor( nValues );\n\n\t\tfor ( var i = 0, dstOffset = 0; dstOffset !== nValues; ++ i ) {\n\n\t\t\tvar srcOffset = order[ i ] * stride;\n\n\t\t\tfor ( var j = 0; j !== stride; ++ j ) {\n\n\t\t\t\tresult[ dstOffset ++ ] = values[ srcOffset + j ];\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn result;\n\n\t},\n\n\t// function for parsing AOS keyframe formats\n\tflattenJSON: function ( jsonKeys, times, values, valuePropertyName ) {\n\n\t\tvar i = 1, key = jsonKeys[ 0 ];\n\n\t\twhile ( key !== undefined && key[ valuePropertyName ] === undefined ) {\n\n\t\t\tkey = jsonKeys[ i ++ ];\n\n\t\t}\n\n\t\tif ( key === undefined ) return; // no data\n\n\t\tvar value = key[ valuePropertyName ];\n\t\tif ( value === undefined ) return; // no data\n\n\t\tif ( Array.isArray( value ) ) {\n\n\t\t\tdo {\n\n\t\t\t\tvalue = key[ valuePropertyName ];\n\n\t\t\t\tif ( value !== undefined ) {\n\n\t\t\t\t\ttimes.push( key.time );\n\t\t\t\t\tvalues.push.apply( values, value ); // push all elements\n\n\t\t\t\t}\n\n\t\t\t\tkey = jsonKeys[ i ++ ];\n\n\t\t\t} while ( key !== undefined );\n\n\t\t} else if ( value.toArray !== undefined ) {\n\n\t\t\t// ...assume THREE.Math-ish\n\n\t\t\tdo {\n\n\t\t\t\tvalue = key[ valuePropertyName ];\n\n\t\t\t\tif ( value !== undefined ) {\n\n\t\t\t\t\ttimes.push( key.time );\n\t\t\t\t\tvalue.toArray( values, values.length );\n\n\t\t\t\t}\n\n\t\t\t\tkey = jsonKeys[ i ++ ];\n\n\t\t\t} while ( key !== undefined );\n\n\t\t} else {\n\n\t\t\t// otherwise push as-is\n\n\t\t\tdo {\n\n\t\t\t\tvalue = key[ valuePropertyName ];\n\n\t\t\t\tif ( value !== undefined ) {\n\n\t\t\t\t\ttimes.push( key.time );\n\t\t\t\t\tvalues.push( value );\n\n\t\t\t\t}\n\n\t\t\t\tkey = jsonKeys[ i ++ ];\n\n\t\t\t} while ( key !== undefined );\n\n\t\t}\n\n\t}\n\n};\n\n/**\n *\n * A timed sequence of keyframes for a specific property.\n *\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\nfunction KeyframeTrack( name, times, values, interpolation ) {\n\n\tif ( name === undefined ) throw new Error( 'THREE.KeyframeTrack: track name is undefined' );\n\tif ( times === undefined || times.length === 0 ) throw new Error( 'THREE.KeyframeTrack: no keyframes in track named ' + name );\n\n\tthis.name = name;\n\n\tthis.times = AnimationUtils.convertArray( times, this.TimeBufferType );\n\tthis.values = AnimationUtils.convertArray( values, this.ValueBufferType );\n\n\tthis.setInterpolation( interpolation || this.DefaultInterpolation );\n\n\tthis.validate();\n\tthis.optimize();\n\n}\n\n// Static methods:\n\nObject.assign( KeyframeTrack, {\n\n\t// Serialization (in static context, because of constructor invocation\n\t// and automatic invocation of .toJSON):\n\n\tparse: function ( json ) {\n\n\t\tif ( json.type === undefined ) {\n\n\t\t\tthrow new Error( 'THREE.KeyframeTrack: track type undefined, can not parse' );\n\n\t\t}\n\n\t\tvar trackType = KeyframeTrack._getTrackTypeForValueTypeName( json.type );\n\n\t\tif ( json.times === undefined ) {\n\n\t\t\tvar times = [], values = [];\n\n\t\t\tAnimationUtils.flattenJSON( json.keys, times, values, 'value' );\n\n\t\t\tjson.times = times;\n\t\t\tjson.values = values;\n\n\t\t}\n\n\t\t// derived classes can define a static parse method\n\t\tif ( trackType.parse !== undefined ) {\n\n\t\t\treturn trackType.parse( json );\n\n\t\t} else {\n\n\t\t\t// by default, we assume a constructor compatible with the base\n\t\t\treturn new trackType( json.name, json.times, json.values, json.interpolation );\n\n\t\t}\n\n\t},\n\n\ttoJSON: function ( track ) {\n\n\t\tvar trackType = track.constructor;\n\n\t\tvar json;\n\n\t\t// derived classes can define a static toJSON method\n\t\tif ( trackType.toJSON !== undefined ) {\n\n\t\t\tjson = trackType.toJSON( track );\n\n\t\t} else {\n\n\t\t\t// by default, we assume the data can be serialized as-is\n\t\t\tjson = {\n\n\t\t\t\t'name': track.name,\n\t\t\t\t'times': AnimationUtils.convertArray( track.times, Array ),\n\t\t\t\t'values': AnimationUtils.convertArray( track.values, Array )\n\n\t\t\t};\n\n\t\t\tvar interpolation = track.getInterpolation();\n\n\t\t\tif ( interpolation !== track.DefaultInterpolation ) {\n\n\t\t\t\tjson.interpolation = interpolation;\n\n\t\t\t}\n\n\t\t}\n\n\t\tjson.type = track.ValueTypeName; // mandatory\n\n\t\treturn json;\n\n\t},\n\n\t_getTrackTypeForValueTypeName: function ( typeName ) {\n\n\t\tswitch ( typeName.toLowerCase() ) {\n\n\t\t\tcase 'scalar':\n\t\t\tcase 'double':\n\t\t\tcase 'float':\n\t\t\tcase 'number':\n\t\t\tcase 'integer':\n\n\t\t\t\treturn NumberKeyframeTrack;\n\n\t\t\tcase 'vector':\n\t\t\tcase 'vector2':\n\t\t\tcase 'vector3':\n\t\t\tcase 'vector4':\n\n\t\t\t\treturn VectorKeyframeTrack;\n\n\t\t\tcase 'color':\n\n\t\t\t\treturn ColorKeyframeTrack;\n\n\t\t\tcase 'quaternion':\n\n\t\t\t\treturn QuaternionKeyframeTrack;\n\n\t\t\tcase 'bool':\n\t\t\tcase 'boolean':\n\n\t\t\t\treturn BooleanKeyframeTrack;\n\n\t\t\tcase 'string':\n\n\t\t\t\treturn StringKeyframeTrack;\n\n\t\t}\n\n\t\tthrow new Error( 'THREE.KeyframeTrack: Unsupported typeName: ' + typeName );\n\n\t}\n\n} );\n\nObject.assign( KeyframeTrack.prototype, {\n\n\tconstructor: KeyframeTrack,\n\n\tTimeBufferType: Float32Array,\n\n\tValueBufferType: Float32Array,\n\n\tDefaultInterpolation: InterpolateLinear,\n\n\tInterpolantFactoryMethodDiscrete: function ( result ) {\n\n\t\treturn new DiscreteInterpolant( this.times, this.values, this.getValueSize(), result );\n\n\t},\n\n\tInterpolantFactoryMethodLinear: function ( result ) {\n\n\t\treturn new LinearInterpolant( this.times, this.values, this.getValueSize(), result );\n\n\t},\n\n\tInterpolantFactoryMethodSmooth: function ( result ) {\n\n\t\treturn new CubicInterpolant( this.times, this.values, this.getValueSize(), result );\n\n\t},\n\n\tsetInterpolation: function ( interpolation ) {\n\n\t\tvar factoryMethod;\n\n\t\tswitch ( interpolation ) {\n\n\t\t\tcase InterpolateDiscrete:\n\n\t\t\t\tfactoryMethod = this.InterpolantFactoryMethodDiscrete;\n\n\t\t\t\tbreak;\n\n\t\t\tcase InterpolateLinear:\n\n\t\t\t\tfactoryMethod = this.InterpolantFactoryMethodLinear;\n\n\t\t\t\tbreak;\n\n\t\t\tcase InterpolateSmooth:\n\n\t\t\t\tfactoryMethod = this.InterpolantFactoryMethodSmooth;\n\n\t\t\t\tbreak;\n\n\t\t}\n\n\t\tif ( factoryMethod === undefined ) {\n\n\t\t\tvar message = \"unsupported interpolation for \" +\n\t\t\t\tthis.ValueTypeName + \" keyframe track named \" + this.name;\n\n\t\t\tif ( this.createInterpolant === undefined ) {\n\n\t\t\t\t// fall back to default, unless the default itself is messed up\n\t\t\t\tif ( interpolation !== this.DefaultInterpolation ) {\n\n\t\t\t\t\tthis.setInterpolation( this.DefaultInterpolation );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthrow new Error( message ); // fatal, in this case\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tconsole.warn( 'THREE.KeyframeTrack:', message );\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis.createInterpolant = factoryMethod;\n\n\t},\n\n\tgetInterpolation: function () {\n\n\t\tswitch ( this.createInterpolant ) {\n\n\t\t\tcase this.InterpolantFactoryMethodDiscrete:\n\n\t\t\t\treturn InterpolateDiscrete;\n\n\t\t\tcase this.InterpolantFactoryMethodLinear:\n\n\t\t\t\treturn InterpolateLinear;\n\n\t\t\tcase this.InterpolantFactoryMethodSmooth:\n\n\t\t\t\treturn InterpolateSmooth;\n\n\t\t}\n\n\t},\n\n\tgetValueSize: function () {\n\n\t\treturn this.values.length / this.times.length;\n\n\t},\n\n\t// move all keyframes either forwards or backwards in time\n\tshift: function ( timeOffset ) {\n\n\t\tif ( timeOffset !== 0.0 ) {\n\n\t\t\tvar times = this.times;\n\n\t\t\tfor ( var i = 0, n = times.length; i !== n; ++ i ) {\n\n\t\t\t\ttimes[ i ] += timeOffset;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\t// scale all keyframe times by a factor (useful for frame <-> seconds conversions)\n\tscale: function ( timeScale ) {\n\n\t\tif ( timeScale !== 1.0 ) {\n\n\t\t\tvar times = this.times;\n\n\t\t\tfor ( var i = 0, n = times.length; i !== n; ++ i ) {\n\n\t\t\t\ttimes[ i ] *= timeScale;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\t// removes keyframes before and after animation without changing any values within the range [startTime, endTime].\n\t// IMPORTANT: We do not shift around keys to the start of the track time, because for interpolated keys this will change their values\n\ttrim: function ( startTime, endTime ) {\n\n\t\tvar times = this.times,\n\t\t\tnKeys = times.length,\n\t\t\tfrom = 0,\n\t\t\tto = nKeys - 1;\n\n\t\twhile ( from !== nKeys && times[ from ] < startTime ) {\n\n\t\t\t++ from;\n\n\t\t}\n\n\t\twhile ( to !== - 1 && times[ to ] > endTime ) {\n\n\t\t\t-- to;\n\n\t\t}\n\n\t\t++ to; // inclusive -> exclusive bound\n\n\t\tif ( from !== 0 || to !== nKeys ) {\n\n\t\t\t// empty tracks are forbidden, so keep at least one keyframe\n\t\t\tif ( from >= to ) to = Math.max( to, 1 ), from = to - 1;\n\n\t\t\tvar stride = this.getValueSize();\n\t\t\tthis.times = AnimationUtils.arraySlice( times, from, to );\n\t\t\tthis.values = AnimationUtils.arraySlice( this.values, from * stride, to * stride );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\t// ensure we do not get a GarbageInGarbageOut situation, make sure tracks are at least minimally viable\n\tvalidate: function () {\n\n\t\tvar valid = true;\n\n\t\tvar valueSize = this.getValueSize();\n\t\tif ( valueSize - Math.floor( valueSize ) !== 0 ) {\n\n\t\t\tconsole.error( 'THREE.KeyframeTrack: Invalid value size in track.', this );\n\t\t\tvalid = false;\n\n\t\t}\n\n\t\tvar times = this.times,\n\t\t\tvalues = this.values,\n\n\t\t\tnKeys = times.length;\n\n\t\tif ( nKeys === 0 ) {\n\n\t\t\tconsole.error( 'THREE.KeyframeTrack: Track is empty.', this );\n\t\t\tvalid = false;\n\n\t\t}\n\n\t\tvar prevTime = null;\n\n\t\tfor ( var i = 0; i !== nKeys; i ++ ) {\n\n\t\t\tvar currTime = times[ i ];\n\n\t\t\tif ( typeof currTime === 'number' && isNaN( currTime ) ) {\n\n\t\t\t\tconsole.error( 'THREE.KeyframeTrack: Time is not a valid number.', this, i, currTime );\n\t\t\t\tvalid = false;\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t\tif ( prevTime !== null && prevTime > currTime ) {\n\n\t\t\t\tconsole.error( 'THREE.KeyframeTrack: Out of order keys.', this, i, currTime, prevTime );\n\t\t\t\tvalid = false;\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t\tprevTime = currTime;\n\n\t\t}\n\n\t\tif ( values !== undefined ) {\n\n\t\t\tif ( AnimationUtils.isTypedArray( values ) ) {\n\n\t\t\t\tfor ( var i = 0, n = values.length; i !== n; ++ i ) {\n\n\t\t\t\t\tvar value = values[ i ];\n\n\t\t\t\t\tif ( isNaN( value ) ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.KeyframeTrack: Value is not a valid number.', this, i, value );\n\t\t\t\t\t\tvalid = false;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn valid;\n\n\t},\n\n\t// removes equivalent sequential keys as common in morph target sequences\n\t// (0,0,0,0,1,1,1,0,0,0,0,0,0,0) --> (0,0,1,1,0,0)\n\toptimize: function () {\n\n\t\tvar times = this.times,\n\t\t\tvalues = this.values,\n\t\t\tstride = this.getValueSize(),\n\n\t\t\tsmoothInterpolation = this.getInterpolation() === InterpolateSmooth,\n\n\t\t\twriteIndex = 1,\n\t\t\tlastIndex = times.length - 1;\n\n\t\tfor ( var i = 1; i < lastIndex; ++ i ) {\n\n\t\t\tvar keep = false;\n\n\t\t\tvar time = times[ i ];\n\t\t\tvar timeNext = times[ i + 1 ];\n\n\t\t\t// remove adjacent keyframes scheduled at the same time\n\n\t\t\tif ( time !== timeNext && ( i !== 1 || time !== time[ 0 ] ) ) {\n\n\t\t\t\tif ( ! smoothInterpolation ) {\n\n\t\t\t\t\t// remove unnecessary keyframes same as their neighbors\n\n\t\t\t\t\tvar offset = i * stride,\n\t\t\t\t\t\toffsetP = offset - stride,\n\t\t\t\t\t\toffsetN = offset + stride;\n\n\t\t\t\t\tfor ( var j = 0; j !== stride; ++ j ) {\n\n\t\t\t\t\t\tvar value = values[ offset + j ];\n\n\t\t\t\t\t\tif ( value !== values[ offsetP + j ] ||\n\t\t\t\t\t\t\tvalue !== values[ offsetN + j ] ) {\n\n\t\t\t\t\t\t\tkeep = true;\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tkeep = true;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// in-place compaction\n\n\t\t\tif ( keep ) {\n\n\t\t\t\tif ( i !== writeIndex ) {\n\n\t\t\t\t\ttimes[ writeIndex ] = times[ i ];\n\n\t\t\t\t\tvar readOffset = i * stride,\n\t\t\t\t\t\twriteOffset = writeIndex * stride;\n\n\t\t\t\t\tfor ( var j = 0; j !== stride; ++ j ) {\n\n\t\t\t\t\t\tvalues[ writeOffset + j ] = values[ readOffset + j ];\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\t++ writeIndex;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// flush last keyframe (compaction looks ahead)\n\n\t\tif ( lastIndex > 0 ) {\n\n\t\t\ttimes[ writeIndex ] = times[ lastIndex ];\n\n\t\t\tfor ( var readOffset = lastIndex * stride, writeOffset = writeIndex * stride, j = 0; j !== stride; ++ j ) {\n\n\t\t\t\tvalues[ writeOffset + j ] = values[ readOffset + j ];\n\n\t\t\t}\n\n\t\t\t++ writeIndex;\n\n\t\t}\n\n\t\tif ( writeIndex !== times.length ) {\n\n\t\t\tthis.times = AnimationUtils.arraySlice( times, 0, writeIndex );\n\t\t\tthis.values = AnimationUtils.arraySlice( values, 0, writeIndex * stride );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n *\n * A Track of vectored keyframe values.\n *\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\nfunction VectorKeyframeTrack( name, times, values, interpolation ) {\n\n\tKeyframeTrack.call( this, name, times, values, interpolation );\n\n}\n\nVectorKeyframeTrack.prototype = Object.assign( Object.create( KeyframeTrack.prototype ), {\n\n\tconstructor: VectorKeyframeTrack,\n\n\tValueTypeName: 'vector'\n\n\t// ValueBufferType is inherited\n\n\t// DefaultInterpolation is inherited\n\n} );\n\n/**\n *\n * Reusable set of Tracks that represent an animation.\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n */\n\nfunction AnimationClip( name, duration, tracks ) {\n\n\tthis.name = name;\n\tthis.tracks = tracks;\n\tthis.duration = ( duration !== undefined ) ? duration : - 1;\n\n\tthis.uuid = _Math.generateUUID();\n\n\t// this means it should figure out its duration by scanning the tracks\n\tif ( this.duration < 0 ) {\n\n\t\tthis.resetDuration();\n\n\t}\n\n\tthis.optimize();\n\n}\n\nObject.assign( AnimationClip, {\n\n\tparse: function ( json ) {\n\n\t\tvar tracks = [],\n\t\t\tjsonTracks = json.tracks,\n\t\t\tframeTime = 1.0 / ( json.fps || 1.0 );\n\n\t\tfor ( var i = 0, n = jsonTracks.length; i !== n; ++ i ) {\n\n\t\t\ttracks.push( KeyframeTrack.parse( jsonTracks[ i ] ).scale( frameTime ) );\n\n\t\t}\n\n\t\treturn new AnimationClip( json.name, json.duration, tracks );\n\n\t},\n\n\ttoJSON: function ( clip ) {\n\n\t\tvar tracks = [],\n\t\t\tclipTracks = clip.tracks;\n\n\t\tvar json = {\n\n\t\t\t'name': clip.name,\n\t\t\t'duration': clip.duration,\n\t\t\t'tracks': tracks\n\n\t\t};\n\n\t\tfor ( var i = 0, n = clipTracks.length; i !== n; ++ i ) {\n\n\t\t\ttracks.push( KeyframeTrack.toJSON( clipTracks[ i ] ) );\n\n\t\t}\n\n\t\treturn json;\n\n\t},\n\n\tCreateFromMorphTargetSequence: function ( name, morphTargetSequence, fps, noLoop ) {\n\n\t\tvar numMorphTargets = morphTargetSequence.length;\n\t\tvar tracks = [];\n\n\t\tfor ( var i = 0; i < numMorphTargets; i ++ ) {\n\n\t\t\tvar times = [];\n\t\t\tvar values = [];\n\n\t\t\ttimes.push(\n\t\t\t\t( i + numMorphTargets - 1 ) % numMorphTargets,\n\t\t\t\ti,\n\t\t\t\t( i + 1 ) % numMorphTargets );\n\n\t\t\tvalues.push( 0, 1, 0 );\n\n\t\t\tvar order = AnimationUtils.getKeyframeOrder( times );\n\t\t\ttimes = AnimationUtils.sortedArray( times, 1, order );\n\t\t\tvalues = AnimationUtils.sortedArray( values, 1, order );\n\n\t\t\t// if there is a key at the first frame, duplicate it as the\n\t\t\t// last frame as well for perfect loop.\n\t\t\tif ( ! noLoop && times[ 0 ] === 0 ) {\n\n\t\t\t\ttimes.push( numMorphTargets );\n\t\t\t\tvalues.push( values[ 0 ] );\n\n\t\t\t}\n\n\t\t\ttracks.push(\n\t\t\t\tnew NumberKeyframeTrack(\n\t\t\t\t\t'.morphTargetInfluences[' + morphTargetSequence[ i ].name + ']',\n\t\t\t\t\ttimes, values\n\t\t\t\t).scale( 1.0 / fps ) );\n\n\t\t}\n\n\t\treturn new AnimationClip( name, - 1, tracks );\n\n\t},\n\n\tfindByName: function ( objectOrClipArray, name ) {\n\n\t\tvar clipArray = objectOrClipArray;\n\n\t\tif ( ! Array.isArray( objectOrClipArray ) ) {\n\n\t\t\tvar o = objectOrClipArray;\n\t\t\tclipArray = o.geometry && o.geometry.animations || o.animations;\n\n\t\t}\n\n\t\tfor ( var i = 0; i < clipArray.length; i ++ ) {\n\n\t\t\tif ( clipArray[ i ].name === name ) {\n\n\t\t\t\treturn clipArray[ i ];\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn null;\n\n\t},\n\n\tCreateClipsFromMorphTargetSequences: function ( morphTargets, fps, noLoop ) {\n\n\t\tvar animationToMorphTargets = {};\n\n\t\t// tested with https://regex101.com/ on trick sequences\n\t\t// such flamingo_flyA_003, flamingo_run1_003, crdeath0059\n\t\tvar pattern = /^([\\w-]*?)([\\d]+)$/;\n\n\t\t// sort morph target names into animation groups based\n\t\t// patterns like Walk_001, Walk_002, Run_001, Run_002\n\t\tfor ( var i = 0, il = morphTargets.length; i < il; i ++ ) {\n\n\t\t\tvar morphTarget = morphTargets[ i ];\n\t\t\tvar parts = morphTarget.name.match( pattern );\n\n\t\t\tif ( parts && parts.length > 1 ) {\n\n\t\t\t\tvar name = parts[ 1 ];\n\n\t\t\t\tvar animationMorphTargets = animationToMorphTargets[ name ];\n\t\t\t\tif ( ! animationMorphTargets ) {\n\n\t\t\t\t\tanimationToMorphTargets[ name ] = animationMorphTargets = [];\n\n\t\t\t\t}\n\n\t\t\t\tanimationMorphTargets.push( morphTarget );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar clips = [];\n\n\t\tfor ( var name in animationToMorphTargets ) {\n\n\t\t\tclips.push( AnimationClip.CreateFromMorphTargetSequence( name, animationToMorphTargets[ name ], fps, noLoop ) );\n\n\t\t}\n\n\t\treturn clips;\n\n\t},\n\n\t// parse the animation.hierarchy format\n\tparseAnimation: function ( animation, bones ) {\n\n\t\tif ( ! animation ) {\n\n\t\t\tconsole.error( 'THREE.AnimationClip: No animation in JSONLoader data.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\tvar addNonemptyTrack = function ( trackType, trackName, animationKeys, propertyName, destTracks ) {\n\n\t\t\t// only return track if there are actually keys.\n\t\t\tif ( animationKeys.length !== 0 ) {\n\n\t\t\t\tvar times = [];\n\t\t\t\tvar values = [];\n\n\t\t\t\tAnimationUtils.flattenJSON( animationKeys, times, values, propertyName );\n\n\t\t\t\t// empty keys are filtered out, so check again\n\t\t\t\tif ( times.length !== 0 ) {\n\n\t\t\t\t\tdestTracks.push( new trackType( trackName, times, values ) );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t};\n\n\t\tvar tracks = [];\n\n\t\tvar clipName = animation.name || 'default';\n\t\t// automatic length determination in AnimationClip.\n\t\tvar duration = animation.length || - 1;\n\t\tvar fps = animation.fps || 30;\n\n\t\tvar hierarchyTracks = animation.hierarchy || [];\n\n\t\tfor ( var h = 0; h < hierarchyTracks.length; h ++ ) {\n\n\t\t\tvar animationKeys = hierarchyTracks[ h ].keys;\n\n\t\t\t// skip empty tracks\n\t\t\tif ( ! animationKeys || animationKeys.length === 0 ) continue;\n\n\t\t\t// process morph targets\n\t\t\tif ( animationKeys[ 0 ].morphTargets ) {\n\n\t\t\t\t// figure out all morph targets used in this track\n\t\t\t\tvar morphTargetNames = {};\n\n\t\t\t\tfor ( var k = 0; k < animationKeys.length; k ++ ) {\n\n\t\t\t\t\tif ( animationKeys[ k ].morphTargets ) {\n\n\t\t\t\t\t\tfor ( var m = 0; m < animationKeys[ k ].morphTargets.length; m ++ ) {\n\n\t\t\t\t\t\t\tmorphTargetNames[ animationKeys[ k ].morphTargets[ m ] ] = - 1;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\t// create a track for each morph target with all zero\n\t\t\t\t// morphTargetInfluences except for the keys in which\n\t\t\t\t// the morphTarget is named.\n\t\t\t\tfor ( var morphTargetName in morphTargetNames ) {\n\n\t\t\t\t\tvar times = [];\n\t\t\t\t\tvar values = [];\n\n\t\t\t\t\tfor ( var m = 0; m !== animationKeys[ k ].morphTargets.length; ++ m ) {\n\n\t\t\t\t\t\tvar animationKey = animationKeys[ k ];\n\n\t\t\t\t\t\ttimes.push( animationKey.time );\n\t\t\t\t\t\tvalues.push( ( animationKey.morphTarget === morphTargetName ) ? 1 : 0 );\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttracks.push( new NumberKeyframeTrack( '.morphTargetInfluence[' + morphTargetName + ']', times, values ) );\n\n\t\t\t\t}\n\n\t\t\t\tduration = morphTargetNames.length * ( fps || 1.0 );\n\n\t\t\t} else {\n\n\t\t\t\t// ...assume skeletal animation\n\n\t\t\t\tvar boneName = '.bones[' + bones[ h ].name + ']';\n\n\t\t\t\taddNonemptyTrack(\n\t\t\t\t\tVectorKeyframeTrack, boneName + '.position',\n\t\t\t\t\tanimationKeys, 'pos', tracks );\n\n\t\t\t\taddNonemptyTrack(\n\t\t\t\t\tQuaternionKeyframeTrack, boneName + '.quaternion',\n\t\t\t\t\tanimationKeys, 'rot', tracks );\n\n\t\t\t\taddNonemptyTrack(\n\t\t\t\t\tVectorKeyframeTrack, boneName + '.scale',\n\t\t\t\t\tanimationKeys, 'scl', tracks );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( tracks.length === 0 ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\tvar clip = new AnimationClip( clipName, duration, tracks );\n\n\t\treturn clip;\n\n\t}\n\n} );\n\nObject.assign( AnimationClip.prototype, {\n\n\tresetDuration: function () {\n\n\t\tvar tracks = this.tracks, duration = 0;\n\n\t\tfor ( var i = 0, n = tracks.length; i !== n; ++ i ) {\n\n\t\t\tvar track = this.tracks[ i ];\n\n\t\t\tduration = Math.max( duration, track.times[ track.times.length - 1 ] );\n\n\t\t}\n\n\t\tthis.duration = duration;\n\n\t},\n\n\ttrim: function () {\n\n\t\tfor ( var i = 0; i < this.tracks.length; i ++ ) {\n\n\t\t\tthis.tracks[ i ].trim( 0, this.duration );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\toptimize: function () {\n\n\t\tfor ( var i = 0; i < this.tracks.length; i ++ ) {\n\n\t\t\tthis.tracks[ i ].optimize();\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction MaterialLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\tthis.textures = {};\n\n}\n\nObject.assign( MaterialLoader.prototype, {\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tvar scope = this;\n\n\t\tvar loader = new FileLoader( scope.manager );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\tonLoad( scope.parse( JSON.parse( text ) ) );\n\n\t\t}, onProgress, onError );\n\n\t},\n\n\tsetTextures: function ( value ) {\n\n\t\tthis.textures = value;\n\n\t},\n\n\tparse: function ( json ) {\n\n\t\tvar textures = this.textures;\n\n\t\tfunction getTexture( name ) {\n\n\t\t\tif ( textures[ name ] === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.MaterialLoader: Undefined texture', name );\n\n\t\t\t}\n\n\t\t\treturn textures[ name ];\n\n\t\t}\n\n\t\tvar material = new Materials[ json.type ]();\n\n\t\tif ( json.uuid !== undefined ) material.uuid = json.uuid;\n\t\tif ( json.name !== undefined ) material.name = json.name;\n\t\tif ( json.color !== undefined ) material.color.setHex( json.color );\n\t\tif ( json.roughness !== undefined ) material.roughness = json.roughness;\n\t\tif ( json.metalness !== undefined ) material.metalness = json.metalness;\n\t\tif ( json.emissive !== undefined ) material.emissive.setHex( json.emissive );\n\t\tif ( json.specular !== undefined ) material.specular.setHex( json.specular );\n\t\tif ( json.shininess !== undefined ) material.shininess = json.shininess;\n\t\tif ( json.clearCoat !== undefined ) material.clearCoat = json.clearCoat;\n\t\tif ( json.clearCoatRoughness !== undefined ) material.clearCoatRoughness = json.clearCoatRoughness;\n\t\tif ( json.uniforms !== undefined ) material.uniforms = json.uniforms;\n\t\tif ( json.vertexShader !== undefined ) material.vertexShader = json.vertexShader;\n\t\tif ( json.fragmentShader !== undefined ) material.fragmentShader = json.fragmentShader;\n\t\tif ( json.vertexColors !== undefined ) material.vertexColors = json.vertexColors;\n\t\tif ( json.fog !== undefined ) material.fog = json.fog;\n\t\tif ( json.flatShading !== undefined ) material.flatShading = json.flatShading;\n\t\tif ( json.blending !== undefined ) material.blending = json.blending;\n\t\tif ( json.side !== undefined ) material.side = json.side;\n\t\tif ( json.opacity !== undefined ) material.opacity = json.opacity;\n\t\tif ( json.transparent !== undefined ) material.transparent = json.transparent;\n\t\tif ( json.alphaTest !== undefined ) material.alphaTest = json.alphaTest;\n\t\tif ( json.depthTest !== undefined ) material.depthTest = json.depthTest;\n\t\tif ( json.depthWrite !== undefined ) material.depthWrite = json.depthWrite;\n\t\tif ( json.colorWrite !== undefined ) material.colorWrite = json.colorWrite;\n\t\tif ( json.wireframe !== undefined ) material.wireframe = json.wireframe;\n\t\tif ( json.wireframeLinewidth !== undefined ) material.wireframeLinewidth = json.wireframeLinewidth;\n\t\tif ( json.wireframeLinecap !== undefined ) material.wireframeLinecap = json.wireframeLinecap;\n\t\tif ( json.wireframeLinejoin !== undefined ) material.wireframeLinejoin = json.wireframeLinejoin;\n\n\t\tif ( json.rotation !== undefined ) material.rotation = json.rotation;\n\n\t\tif ( json.linewidth !== 1 ) material.linewidth = json.linewidth;\n\t\tif ( json.dashSize !== undefined ) material.dashSize = json.dashSize;\n\t\tif ( json.gapSize !== undefined ) material.gapSize = json.gapSize;\n\t\tif ( json.scale !== undefined ) material.scale = json.scale;\n\n\t\tif ( json.polygonOffset !== undefined ) material.polygonOffset = json.polygonOffset;\n\t\tif ( json.polygonOffsetFactor !== undefined ) material.polygonOffsetFactor = json.polygonOffsetFactor;\n\t\tif ( json.polygonOffsetUnits !== undefined ) material.polygonOffsetUnits = json.polygonOffsetUnits;\n\n\t\tif ( json.skinning !== undefined ) material.skinning = json.skinning;\n\t\tif ( json.morphTargets !== undefined ) material.morphTargets = json.morphTargets;\n\t\tif ( json.dithering !== undefined ) material.dithering = json.dithering;\n\n\t\tif ( json.visible !== undefined ) material.visible = json.visible;\n\t\tif ( json.userData !== undefined ) material.userData = json.userData;\n\n\t\t// Deprecated\n\n\t\tif ( json.shading !== undefined ) material.flatShading = json.shading === 1; // THREE.FlatShading\n\n\t\t// for PointsMaterial\n\n\t\tif ( json.size !== undefined ) material.size = json.size;\n\t\tif ( json.sizeAttenuation !== undefined ) material.sizeAttenuation = json.sizeAttenuation;\n\n\t\t// maps\n\n\t\tif ( json.map !== undefined ) material.map = getTexture( json.map );\n\n\t\tif ( json.alphaMap !== undefined ) {\n\n\t\t\tmaterial.alphaMap = getTexture( json.alphaMap );\n\t\t\tmaterial.transparent = true;\n\n\t\t}\n\n\t\tif ( json.bumpMap !== undefined ) material.bumpMap = getTexture( json.bumpMap );\n\t\tif ( json.bumpScale !== undefined ) material.bumpScale = json.bumpScale;\n\n\t\tif ( json.normalMap !== undefined ) material.normalMap = getTexture( json.normalMap );\n\t\tif ( json.normalScale !== undefined ) {\n\n\t\t\tvar normalScale = json.normalScale;\n\n\t\t\tif ( Array.isArray( normalScale ) === false ) {\n\n\t\t\t\t// Blender exporter used to export a scalar. See #7459\n\n\t\t\t\tnormalScale = [ normalScale, normalScale ];\n\n\t\t\t}\n\n\t\t\tmaterial.normalScale = new Vector2().fromArray( normalScale );\n\n\t\t}\n\n\t\tif ( json.displacementMap !== undefined ) material.displacementMap = getTexture( json.displacementMap );\n\t\tif ( json.displacementScale !== undefined ) material.displacementScale = json.displacementScale;\n\t\tif ( json.displacementBias !== undefined ) material.displacementBias = json.displacementBias;\n\n\t\tif ( json.roughnessMap !== undefined ) material.roughnessMap = getTexture( json.roughnessMap );\n\t\tif ( json.metalnessMap !== undefined ) material.metalnessMap = getTexture( json.metalnessMap );\n\n\t\tif ( json.emissiveMap !== undefined ) material.emissiveMap = getTexture( json.emissiveMap );\n\t\tif ( json.emissiveIntensity !== undefined ) material.emissiveIntensity = json.emissiveIntensity;\n\n\t\tif ( json.specularMap !== undefined ) material.specularMap = getTexture( json.specularMap );\n\n\t\tif ( json.envMap !== undefined ) material.envMap = getTexture( json.envMap );\n\n\t\tif ( json.reflectivity !== undefined ) material.reflectivity = json.reflectivity;\n\n\t\tif ( json.lightMap !== undefined ) material.lightMap = getTexture( json.lightMap );\n\t\tif ( json.lightMapIntensity !== undefined ) material.lightMapIntensity = json.lightMapIntensity;\n\n\t\tif ( json.aoMap !== undefined ) material.aoMap = getTexture( json.aoMap );\n\t\tif ( json.aoMapIntensity !== undefined ) material.aoMapIntensity = json.aoMapIntensity;\n\n\t\tif ( json.gradientMap !== undefined ) material.gradientMap = getTexture( json.gradientMap );\n\n\t\treturn material;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction BufferGeometryLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n}\n\nObject.assign( BufferGeometryLoader.prototype, {\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tvar scope = this;\n\n\t\tvar loader = new FileLoader( scope.manager );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\tonLoad( scope.parse( JSON.parse( text ) ) );\n\n\t\t}, onProgress, onError );\n\n\t},\n\n\tparse: function ( json ) {\n\n\t\tvar geometry = new BufferGeometry();\n\n\t\tvar index = json.data.index;\n\n\t\tif ( index !== undefined ) {\n\n\t\t\tvar typedArray = new TYPED_ARRAYS[ index.type ]( index.array );\n\t\t\tgeometry.setIndex( new BufferAttribute( typedArray, 1 ) );\n\n\t\t}\n\n\t\tvar attributes = json.data.attributes;\n\n\t\tfor ( var key in attributes ) {\n\n\t\t\tvar attribute = attributes[ key ];\n\t\t\tvar typedArray = new TYPED_ARRAYS[ attribute.type ]( attribute.array );\n\n\t\t\tgeometry.addAttribute( key, new BufferAttribute( typedArray, attribute.itemSize, attribute.normalized ) );\n\n\t\t}\n\n\t\tvar groups = json.data.groups || json.data.drawcalls || json.data.offsets;\n\n\t\tif ( groups !== undefined ) {\n\n\t\t\tfor ( var i = 0, n = groups.length; i !== n; ++ i ) {\n\n\t\t\t\tvar group = groups[ i ];\n\n\t\t\t\tgeometry.addGroup( group.start, group.count, group.materialIndex );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar boundingSphere = json.data.boundingSphere;\n\n\t\tif ( boundingSphere !== undefined ) {\n\n\t\t\tvar center = new Vector3();\n\n\t\t\tif ( boundingSphere.center !== undefined ) {\n\n\t\t\t\tcenter.fromArray( boundingSphere.center );\n\n\t\t\t}\n\n\t\t\tgeometry.boundingSphere = new Sphere( center, boundingSphere.radius );\n\n\t\t}\n\n\t\treturn geometry;\n\n\t}\n\n} );\n\nvar TYPED_ARRAYS = {\n\tInt8Array: Int8Array,\n\tUint8Array: Uint8Array,\n\t// Workaround for IE11 pre KB2929437. See #11440\n\tUint8ClampedArray: typeof Uint8ClampedArray !== 'undefined' ? Uint8ClampedArray : Uint8Array,\n\tInt16Array: Int16Array,\n\tUint16Array: Uint16Array,\n\tInt32Array: Int32Array,\n\tUint32Array: Uint32Array,\n\tFloat32Array: Float32Array,\n\tFloat64Array: Float64Array\n};\n\n/**\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction Loader() {}\n\nLoader.Handlers = {\n\n\thandlers: [],\n\n\tadd: function ( regex, loader ) {\n\n\t\tthis.handlers.push( regex, loader );\n\n\t},\n\n\tget: function ( file ) {\n\n\t\tvar handlers = this.handlers;\n\n\t\tfor ( var i = 0, l = handlers.length; i < l; i += 2 ) {\n\n\t\t\tvar regex = handlers[ i ];\n\t\t\tvar loader = handlers[ i + 1 ];\n\n\t\t\tif ( regex.test( file ) ) {\n\n\t\t\t\treturn loader;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn null;\n\n\t}\n\n};\n\nObject.assign( Loader.prototype, {\n\n\tcrossOrigin: undefined,\n\n\tonLoadStart: function () {},\n\n\tonLoadProgress: function () {},\n\n\tonLoadComplete: function () {},\n\n\tinitMaterials: function ( materials, texturePath, crossOrigin ) {\n\n\t\tvar array = [];\n\n\t\tfor ( var i = 0; i < materials.length; ++ i ) {\n\n\t\t\tarray[ i ] = this.createMaterial( materials[ i ], texturePath, crossOrigin );\n\n\t\t}\n\n\t\treturn array;\n\n\t},\n\n\tcreateMaterial: ( function () {\n\n\t\tvar BlendingMode = {\n\t\t\tNoBlending: NoBlending,\n\t\t\tNormalBlending: NormalBlending,\n\t\t\tAdditiveBlending: AdditiveBlending,\n\t\t\tSubtractiveBlending: SubtractiveBlending,\n\t\t\tMultiplyBlending: MultiplyBlending,\n\t\t\tCustomBlending: CustomBlending\n\t\t};\n\n\t\tvar color = new Color();\n\t\tvar textureLoader = new TextureLoader();\n\t\tvar materialLoader = new MaterialLoader();\n\n\t\treturn function createMaterial( m, texturePath, crossOrigin ) {\n\n\t\t\t// convert from old material format\n\n\t\t\tvar textures = {};\n\n\t\t\tfunction loadTexture( path, repeat, offset, wrap, anisotropy ) {\n\n\t\t\t\tvar fullPath = texturePath + path;\n\t\t\t\tvar loader = Loader.Handlers.get( fullPath );\n\n\t\t\t\tvar texture;\n\n\t\t\t\tif ( loader !== null ) {\n\n\t\t\t\t\ttexture = loader.load( fullPath );\n\n\t\t\t\t} else {\n\n\t\t\t\t\ttextureLoader.setCrossOrigin( crossOrigin );\n\t\t\t\t\ttexture = textureLoader.load( fullPath );\n\n\t\t\t\t}\n\n\t\t\t\tif ( repeat !== undefined ) {\n\n\t\t\t\t\ttexture.repeat.fromArray( repeat );\n\n\t\t\t\t\tif ( repeat[ 0 ] !== 1 ) texture.wrapS = RepeatWrapping;\n\t\t\t\t\tif ( repeat[ 1 ] !== 1 ) texture.wrapT = RepeatWrapping;\n\n\t\t\t\t}\n\n\t\t\t\tif ( offset !== undefined ) {\n\n\t\t\t\t\ttexture.offset.fromArray( offset );\n\n\t\t\t\t}\n\n\t\t\t\tif ( wrap !== undefined ) {\n\n\t\t\t\t\tif ( wrap[ 0 ] === 'repeat' ) texture.wrapS = RepeatWrapping;\n\t\t\t\t\tif ( wrap[ 0 ] === 'mirror' ) texture.wrapS = MirroredRepeatWrapping;\n\n\t\t\t\t\tif ( wrap[ 1 ] === 'repeat' ) texture.wrapT = RepeatWrapping;\n\t\t\t\t\tif ( wrap[ 1 ] === 'mirror' ) texture.wrapT = MirroredRepeatWrapping;\n\n\t\t\t\t}\n\n\t\t\t\tif ( anisotropy !== undefined ) {\n\n\t\t\t\t\ttexture.anisotropy = anisotropy;\n\n\t\t\t\t}\n\n\t\t\t\tvar uuid = _Math.generateUUID();\n\n\t\t\t\ttextures[ uuid ] = texture;\n\n\t\t\t\treturn uuid;\n\n\t\t\t}\n\n\t\t\t//\n\n\t\t\tvar json = {\n\t\t\t\tuuid: _Math.generateUUID(),\n\t\t\t\ttype: 'MeshLambertMaterial'\n\t\t\t};\n\n\t\t\tfor ( var name in m ) {\n\n\t\t\t\tvar value = m[ name ];\n\n\t\t\t\tswitch ( name ) {\n\n\t\t\t\t\tcase 'DbgColor':\n\t\t\t\t\tcase 'DbgIndex':\n\t\t\t\t\tcase 'opticalDensity':\n\t\t\t\t\tcase 'illumination':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'DbgName':\n\t\t\t\t\t\tjson.name = value;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'blending':\n\t\t\t\t\t\tjson.blending = BlendingMode[ value ];\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'colorAmbient':\n\t\t\t\t\tcase 'mapAmbient':\n\t\t\t\t\t\tconsole.warn( 'THREE.Loader.createMaterial:', name, 'is no longer supported.' );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'colorDiffuse':\n\t\t\t\t\t\tjson.color = color.fromArray( value ).getHex();\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'colorSpecular':\n\t\t\t\t\t\tjson.specular = color.fromArray( value ).getHex();\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'colorEmissive':\n\t\t\t\t\t\tjson.emissive = color.fromArray( value ).getHex();\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'specularCoef':\n\t\t\t\t\t\tjson.shininess = value;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'shading':\n\t\t\t\t\t\tif ( value.toLowerCase() === 'basic' ) json.type = 'MeshBasicMaterial';\n\t\t\t\t\t\tif ( value.toLowerCase() === 'phong' ) json.type = 'MeshPhongMaterial';\n\t\t\t\t\t\tif ( value.toLowerCase() === 'standard' ) json.type = 'MeshStandardMaterial';\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapDiffuse':\n\t\t\t\t\t\tjson.map = loadTexture( value, m.mapDiffuseRepeat, m.mapDiffuseOffset, m.mapDiffuseWrap, m.mapDiffuseAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapDiffuseRepeat':\n\t\t\t\t\tcase 'mapDiffuseOffset':\n\t\t\t\t\tcase 'mapDiffuseWrap':\n\t\t\t\t\tcase 'mapDiffuseAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapEmissive':\n\t\t\t\t\t\tjson.emissiveMap = loadTexture( value, m.mapEmissiveRepeat, m.mapEmissiveOffset, m.mapEmissiveWrap, m.mapEmissiveAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapEmissiveRepeat':\n\t\t\t\t\tcase 'mapEmissiveOffset':\n\t\t\t\t\tcase 'mapEmissiveWrap':\n\t\t\t\t\tcase 'mapEmissiveAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapLight':\n\t\t\t\t\t\tjson.lightMap = loadTexture( value, m.mapLightRepeat, m.mapLightOffset, m.mapLightWrap, m.mapLightAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapLightRepeat':\n\t\t\t\t\tcase 'mapLightOffset':\n\t\t\t\t\tcase 'mapLightWrap':\n\t\t\t\t\tcase 'mapLightAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapAO':\n\t\t\t\t\t\tjson.aoMap = loadTexture( value, m.mapAORepeat, m.mapAOOffset, m.mapAOWrap, m.mapAOAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapAORepeat':\n\t\t\t\t\tcase 'mapAOOffset':\n\t\t\t\t\tcase 'mapAOWrap':\n\t\t\t\t\tcase 'mapAOAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapBump':\n\t\t\t\t\t\tjson.bumpMap = loadTexture( value, m.mapBumpRepeat, m.mapBumpOffset, m.mapBumpWrap, m.mapBumpAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapBumpScale':\n\t\t\t\t\t\tjson.bumpScale = value;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapBumpRepeat':\n\t\t\t\t\tcase 'mapBumpOffset':\n\t\t\t\t\tcase 'mapBumpWrap':\n\t\t\t\t\tcase 'mapBumpAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapNormal':\n\t\t\t\t\t\tjson.normalMap = loadTexture( value, m.mapNormalRepeat, m.mapNormalOffset, m.mapNormalWrap, m.mapNormalAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapNormalFactor':\n\t\t\t\t\t\tjson.normalScale = value;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapNormalRepeat':\n\t\t\t\t\tcase 'mapNormalOffset':\n\t\t\t\t\tcase 'mapNormalWrap':\n\t\t\t\t\tcase 'mapNormalAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapSpecular':\n\t\t\t\t\t\tjson.specularMap = loadTexture( value, m.mapSpecularRepeat, m.mapSpecularOffset, m.mapSpecularWrap, m.mapSpecularAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapSpecularRepeat':\n\t\t\t\t\tcase 'mapSpecularOffset':\n\t\t\t\t\tcase 'mapSpecularWrap':\n\t\t\t\t\tcase 'mapSpecularAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapMetalness':\n\t\t\t\t\t\tjson.metalnessMap = loadTexture( value, m.mapMetalnessRepeat, m.mapMetalnessOffset, m.mapMetalnessWrap, m.mapMetalnessAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapMetalnessRepeat':\n\t\t\t\t\tcase 'mapMetalnessOffset':\n\t\t\t\t\tcase 'mapMetalnessWrap':\n\t\t\t\t\tcase 'mapMetalnessAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapRoughness':\n\t\t\t\t\t\tjson.roughnessMap = loadTexture( value, m.mapRoughnessRepeat, m.mapRoughnessOffset, m.mapRoughnessWrap, m.mapRoughnessAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapRoughnessRepeat':\n\t\t\t\t\tcase 'mapRoughnessOffset':\n\t\t\t\t\tcase 'mapRoughnessWrap':\n\t\t\t\t\tcase 'mapRoughnessAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapAlpha':\n\t\t\t\t\t\tjson.alphaMap = loadTexture( value, m.mapAlphaRepeat, m.mapAlphaOffset, m.mapAlphaWrap, m.mapAlphaAnisotropy );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'mapAlphaRepeat':\n\t\t\t\t\tcase 'mapAlphaOffset':\n\t\t\t\t\tcase 'mapAlphaWrap':\n\t\t\t\t\tcase 'mapAlphaAnisotropy':\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'flipSided':\n\t\t\t\t\t\tjson.side = BackSide;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'doubleSided':\n\t\t\t\t\t\tjson.side = DoubleSide;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'transparency':\n\t\t\t\t\t\tconsole.warn( 'THREE.Loader.createMaterial: transparency has been renamed to opacity' );\n\t\t\t\t\t\tjson.opacity = value;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'depthTest':\n\t\t\t\t\tcase 'depthWrite':\n\t\t\t\t\tcase 'colorWrite':\n\t\t\t\t\tcase 'opacity':\n\t\t\t\t\tcase 'reflectivity':\n\t\t\t\t\tcase 'transparent':\n\t\t\t\t\tcase 'visible':\n\t\t\t\t\tcase 'wireframe':\n\t\t\t\t\t\tjson[ name ] = value;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'vertexColors':\n\t\t\t\t\t\tif ( value === true ) json.vertexColors = VertexColors;\n\t\t\t\t\t\tif ( value === 'face' ) json.vertexColors = FaceColors;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tconsole.error( 'THREE.Loader.createMaterial: Unsupported', name, value );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( json.type === 'MeshBasicMaterial' ) delete json.emissive;\n\t\t\tif ( json.type !== 'MeshPhongMaterial' ) delete json.specular;\n\n\t\t\tif ( json.opacity < 1 ) json.transparent = true;\n\n\t\t\tmaterialLoader.setTextures( textures );\n\n\t\t\treturn materialLoader.parse( json );\n\n\t\t};\n\n\t} )()\n\n} );\n\n/**\n * @author Don McCurdy / https://www.donmccurdy.com\n */\n\nvar LoaderUtils = {\n\n\tdecodeText: function ( array ) {\n\n\t\tif ( typeof TextDecoder !== 'undefined' ) {\n\n\t\t\treturn new TextDecoder().decode( array );\n\n\t\t}\n\n\t\t// Avoid the String.fromCharCode.apply(null, array) shortcut, which\n\t\t// throws a \"maximum call stack size exceeded\" error for large arrays.\n\n\t\tvar s = '';\n\n\t\tfor ( var i = 0, il = array.length; i < il; i ++ ) {\n\n\t\t\t// Implicitly assumes little-endian.\n\t\t\ts += String.fromCharCode( array[ i ] );\n\n\t\t}\n\n\t\t// Merges multi-byte utf-8 characters.\n\t\treturn decodeURIComponent( escape( s ) );\n\n\t},\n\n\textractUrlBase: function ( url ) {\n\n\t\tvar index = url.lastIndexOf( '/' );\n\n\t\tif ( index === - 1 ) return './';\n\n\t\treturn url.substr( 0, index + 1 );\n\n\t}\n\n};\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction JSONLoader( manager ) {\n\n\tif ( typeof manager === 'boolean' ) {\n\n\t\tconsole.warn( 'THREE.JSONLoader: showStatus parameter has been removed from constructor.' );\n\t\tmanager = undefined;\n\n\t}\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n\tthis.withCredentials = false;\n\n}\n\nObject.assign( JSONLoader.prototype, {\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tvar scope = this;\n\n\t\tvar texturePath = this.texturePath && ( typeof this.texturePath === 'string' ) ? this.texturePath : LoaderUtils.extractUrlBase( url );\n\n\t\tvar loader = new FileLoader( this.manager );\n\t\tloader.setWithCredentials( this.withCredentials );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\tvar json = JSON.parse( text );\n\t\t\tvar metadata = json.metadata;\n\n\t\t\tif ( metadata !== undefined ) {\n\n\t\t\t\tvar type = metadata.type;\n\n\t\t\t\tif ( type !== undefined ) {\n\n\t\t\t\t\tif ( type.toLowerCase() === 'object' ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.JSONLoader: ' + url + ' should be loaded with THREE.ObjectLoader instead.' );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tvar object = scope.parse( json, texturePath );\n\t\t\tonLoad( object.geometry, object.materials );\n\n\t\t}, onProgress, onError );\n\n\t},\n\n\tsetTexturePath: function ( value ) {\n\n\t\tthis.texturePath = value;\n\n\t},\n\n\tparse: ( function () {\n\n\t\tfunction parseModel( json, geometry ) {\n\n\t\t\tfunction isBitSet( value, position ) {\n\n\t\t\t\treturn value & ( 1 << position );\n\n\t\t\t}\n\n\t\t\tvar i, j, fi,\n\n\t\t\t\toffset, zLength,\n\n\t\t\t\tcolorIndex, normalIndex, uvIndex, materialIndex,\n\n\t\t\t\ttype,\n\t\t\t\tisQuad,\n\t\t\t\thasMaterial,\n\t\t\t\thasFaceVertexUv,\n\t\t\t\thasFaceNormal, hasFaceVertexNormal,\n\t\t\t\thasFaceColor, hasFaceVertexColor,\n\n\t\t\t\tvertex, face, faceA, faceB, hex, normal,\n\n\t\t\t\tuvLayer, uv, u, v,\n\n\t\t\t\tfaces = json.faces,\n\t\t\t\tvertices = json.vertices,\n\t\t\t\tnormals = json.normals,\n\t\t\t\tcolors = json.colors,\n\n\t\t\t\tscale = json.scale,\n\n\t\t\t\tnUvLayers = 0;\n\n\n\t\t\tif ( json.uvs !== undefined ) {\n\n\t\t\t\t// disregard empty arrays\n\n\t\t\t\tfor ( i = 0; i < json.uvs.length; i ++ ) {\n\n\t\t\t\t\tif ( json.uvs[ i ].length ) nUvLayers ++;\n\n\t\t\t\t}\n\n\t\t\t\tfor ( i = 0; i < nUvLayers; i ++ ) {\n\n\t\t\t\t\tgeometry.faceVertexUvs[ i ] = [];\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\toffset = 0;\n\t\t\tzLength = vertices.length;\n\n\t\t\twhile ( offset < zLength ) {\n\n\t\t\t\tvertex = new Vector3();\n\n\t\t\t\tvertex.x = vertices[ offset ++ ] * scale;\n\t\t\t\tvertex.y = vertices[ offset ++ ] * scale;\n\t\t\t\tvertex.z = vertices[ offset ++ ] * scale;\n\n\t\t\t\tgeometry.vertices.push( vertex );\n\n\t\t\t}\n\n\t\t\toffset = 0;\n\t\t\tzLength = faces.length;\n\n\t\t\twhile ( offset < zLength ) {\n\n\t\t\t\ttype = faces[ offset ++ ];\n\n\t\t\t\tisQuad = isBitSet( type, 0 );\n\t\t\t\thasMaterial = isBitSet( type, 1 );\n\t\t\t\thasFaceVertexUv = isBitSet( type, 3 );\n\t\t\t\thasFaceNormal = isBitSet( type, 4 );\n\t\t\t\thasFaceVertexNormal = isBitSet( type, 5 );\n\t\t\t\thasFaceColor = isBitSet( type, 6 );\n\t\t\t\thasFaceVertexColor = isBitSet( type, 7 );\n\n\t\t\t\t// console.log(\"type\", type, \"bits\", isQuad, hasMaterial, hasFaceVertexUv, hasFaceNormal, hasFaceVertexNormal, hasFaceColor, hasFaceVertexColor);\n\n\t\t\t\tif ( isQuad ) {\n\n\t\t\t\t\tfaceA = new Face3();\n\t\t\t\t\tfaceA.a = faces[ offset ];\n\t\t\t\t\tfaceA.b = faces[ offset + 1 ];\n\t\t\t\t\tfaceA.c = faces[ offset + 3 ];\n\n\t\t\t\t\tfaceB = new Face3();\n\t\t\t\t\tfaceB.a = faces[ offset + 1 ];\n\t\t\t\t\tfaceB.b = faces[ offset + 2 ];\n\t\t\t\t\tfaceB.c = faces[ offset + 3 ];\n\n\t\t\t\t\toffset += 4;\n\n\t\t\t\t\tif ( hasMaterial ) {\n\n\t\t\t\t\t\tmaterialIndex = faces[ offset ++ ];\n\t\t\t\t\t\tfaceA.materialIndex = materialIndex;\n\t\t\t\t\t\tfaceB.materialIndex = materialIndex;\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// to get face <=> uv index correspondence\n\n\t\t\t\t\tfi = geometry.faces.length;\n\n\t\t\t\t\tif ( hasFaceVertexUv ) {\n\n\t\t\t\t\t\tfor ( i = 0; i < nUvLayers; i ++ ) {\n\n\t\t\t\t\t\t\tuvLayer = json.uvs[ i ];\n\n\t\t\t\t\t\t\tgeometry.faceVertexUvs[ i ][ fi ] = [];\n\t\t\t\t\t\t\tgeometry.faceVertexUvs[ i ][ fi + 1 ] = [];\n\n\t\t\t\t\t\t\tfor ( j = 0; j < 4; j ++ ) {\n\n\t\t\t\t\t\t\t\tuvIndex = faces[ offset ++ ];\n\n\t\t\t\t\t\t\t\tu = uvLayer[ uvIndex * 2 ];\n\t\t\t\t\t\t\t\tv = uvLayer[ uvIndex * 2 + 1 ];\n\n\t\t\t\t\t\t\t\tuv = new Vector2( u, v );\n\n\t\t\t\t\t\t\t\tif ( j !== 2 ) geometry.faceVertexUvs[ i ][ fi ].push( uv );\n\t\t\t\t\t\t\t\tif ( j !== 0 ) geometry.faceVertexUvs[ i ][ fi + 1 ].push( uv );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( hasFaceNormal ) {\n\n\t\t\t\t\t\tnormalIndex = faces[ offset ++ ] * 3;\n\n\t\t\t\t\t\tfaceA.normal.set(\n\t\t\t\t\t\t\tnormals[ normalIndex ++ ],\n\t\t\t\t\t\t\tnormals[ normalIndex ++ ],\n\t\t\t\t\t\t\tnormals[ normalIndex ]\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tfaceB.normal.copy( faceA.normal );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( hasFaceVertexNormal ) {\n\n\t\t\t\t\t\tfor ( i = 0; i < 4; i ++ ) {\n\n\t\t\t\t\t\t\tnormalIndex = faces[ offset ++ ] * 3;\n\n\t\t\t\t\t\t\tnormal = new Vector3(\n\t\t\t\t\t\t\t\tnormals[ normalIndex ++ ],\n\t\t\t\t\t\t\t\tnormals[ normalIndex ++ ],\n\t\t\t\t\t\t\t\tnormals[ normalIndex ]\n\t\t\t\t\t\t\t);\n\n\n\t\t\t\t\t\t\tif ( i !== 2 ) faceA.vertexNormals.push( normal );\n\t\t\t\t\t\t\tif ( i !== 0 ) faceB.vertexNormals.push( normal );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\n\t\t\t\t\tif ( hasFaceColor ) {\n\n\t\t\t\t\t\tcolorIndex = faces[ offset ++ ];\n\t\t\t\t\t\thex = colors[ colorIndex ];\n\n\t\t\t\t\t\tfaceA.color.setHex( hex );\n\t\t\t\t\t\tfaceB.color.setHex( hex );\n\n\t\t\t\t\t}\n\n\n\t\t\t\t\tif ( hasFaceVertexColor ) {\n\n\t\t\t\t\t\tfor ( i = 0; i < 4; i ++ ) {\n\n\t\t\t\t\t\t\tcolorIndex = faces[ offset ++ ];\n\t\t\t\t\t\t\thex = colors[ colorIndex ];\n\n\t\t\t\t\t\t\tif ( i !== 2 ) faceA.vertexColors.push( new Color( hex ) );\n\t\t\t\t\t\t\tif ( i !== 0 ) faceB.vertexColors.push( new Color( hex ) );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\tgeometry.faces.push( faceA );\n\t\t\t\t\tgeometry.faces.push( faceB );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tface = new Face3();\n\t\t\t\t\tface.a = faces[ offset ++ ];\n\t\t\t\t\tface.b = faces[ offset ++ ];\n\t\t\t\t\tface.c = faces[ offset ++ ];\n\n\t\t\t\t\tif ( hasMaterial ) {\n\n\t\t\t\t\t\tmaterialIndex = faces[ offset ++ ];\n\t\t\t\t\t\tface.materialIndex = materialIndex;\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// to get face <=> uv index correspondence\n\n\t\t\t\t\tfi = geometry.faces.length;\n\n\t\t\t\t\tif ( hasFaceVertexUv ) {\n\n\t\t\t\t\t\tfor ( i = 0; i < nUvLayers; i ++ ) {\n\n\t\t\t\t\t\t\tuvLayer = json.uvs[ i ];\n\n\t\t\t\t\t\t\tgeometry.faceVertexUvs[ i ][ fi ] = [];\n\n\t\t\t\t\t\t\tfor ( j = 0; j < 3; j ++ ) {\n\n\t\t\t\t\t\t\t\tuvIndex = faces[ offset ++ ];\n\n\t\t\t\t\t\t\t\tu = uvLayer[ uvIndex * 2 ];\n\t\t\t\t\t\t\t\tv = uvLayer[ uvIndex * 2 + 1 ];\n\n\t\t\t\t\t\t\t\tuv = new Vector2( u, v );\n\n\t\t\t\t\t\t\t\tgeometry.faceVertexUvs[ i ][ fi ].push( uv );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( hasFaceNormal ) {\n\n\t\t\t\t\t\tnormalIndex = faces[ offset ++ ] * 3;\n\n\t\t\t\t\t\tface.normal.set(\n\t\t\t\t\t\t\tnormals[ normalIndex ++ ],\n\t\t\t\t\t\t\tnormals[ normalIndex ++ ],\n\t\t\t\t\t\t\tnormals[ normalIndex ]\n\t\t\t\t\t\t);\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( hasFaceVertexNormal ) {\n\n\t\t\t\t\t\tfor ( i = 0; i < 3; i ++ ) {\n\n\t\t\t\t\t\t\tnormalIndex = faces[ offset ++ ] * 3;\n\n\t\t\t\t\t\t\tnormal = new Vector3(\n\t\t\t\t\t\t\t\tnormals[ normalIndex ++ ],\n\t\t\t\t\t\t\t\tnormals[ normalIndex ++ ],\n\t\t\t\t\t\t\t\tnormals[ normalIndex ]\n\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\tface.vertexNormals.push( normal );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\n\t\t\t\t\tif ( hasFaceColor ) {\n\n\t\t\t\t\t\tcolorIndex = faces[ offset ++ ];\n\t\t\t\t\t\tface.color.setHex( colors[ colorIndex ] );\n\n\t\t\t\t\t}\n\n\n\t\t\t\t\tif ( hasFaceVertexColor ) {\n\n\t\t\t\t\t\tfor ( i = 0; i < 3; i ++ ) {\n\n\t\t\t\t\t\t\tcolorIndex = faces[ offset ++ ];\n\t\t\t\t\t\t\tface.vertexColors.push( new Color( colors[ colorIndex ] ) );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\tgeometry.faces.push( face );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction parseSkin( json, geometry ) {\n\n\t\t\tvar influencesPerVertex = ( json.influencesPerVertex !== undefined ) ? json.influencesPerVertex : 2;\n\n\t\t\tif ( json.skinWeights ) {\n\n\t\t\t\tfor ( var i = 0, l = json.skinWeights.length; i < l; i += influencesPerVertex ) {\n\n\t\t\t\t\tvar x = json.skinWeights[ i ];\n\t\t\t\t\tvar y = ( influencesPerVertex > 1 ) ? json.skinWeights[ i + 1 ] : 0;\n\t\t\t\t\tvar z = ( influencesPerVertex > 2 ) ? json.skinWeights[ i + 2 ] : 0;\n\t\t\t\t\tvar w = ( influencesPerVertex > 3 ) ? json.skinWeights[ i + 3 ] : 0;\n\n\t\t\t\t\tgeometry.skinWeights.push( new Vector4( x, y, z, w ) );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( json.skinIndices ) {\n\n\t\t\t\tfor ( var i = 0, l = json.skinIndices.length; i < l; i += influencesPerVertex ) {\n\n\t\t\t\t\tvar a = json.skinIndices[ i ];\n\t\t\t\t\tvar b = ( influencesPerVertex > 1 ) ? json.skinIndices[ i + 1 ] : 0;\n\t\t\t\t\tvar c = ( influencesPerVertex > 2 ) ? json.skinIndices[ i + 2 ] : 0;\n\t\t\t\t\tvar d = ( influencesPerVertex > 3 ) ? json.skinIndices[ i + 3 ] : 0;\n\n\t\t\t\t\tgeometry.skinIndices.push( new Vector4( a, b, c, d ) );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tgeometry.bones = json.bones;\n\n\t\t\tif ( geometry.bones && geometry.bones.length > 0 && ( geometry.skinWeights.length !== geometry.skinIndices.length || geometry.skinIndices.length !== geometry.vertices.length ) ) {\n\n\t\t\t\tconsole.warn( 'When skinning, number of vertices (' + geometry.vertices.length + '), skinIndices (' +\n\t\t\t\t\tgeometry.skinIndices.length + '), and skinWeights (' + geometry.skinWeights.length + ') should match.' );\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction parseMorphing( json, geometry ) {\n\n\t\t\tvar scale = json.scale;\n\n\t\t\tif ( json.morphTargets !== undefined ) {\n\n\t\t\t\tfor ( var i = 0, l = json.morphTargets.length; i < l; i ++ ) {\n\n\t\t\t\t\tgeometry.morphTargets[ i ] = {};\n\t\t\t\t\tgeometry.morphTargets[ i ].name = json.morphTargets[ i ].name;\n\t\t\t\t\tgeometry.morphTargets[ i ].vertices = [];\n\n\t\t\t\t\tvar dstVertices = geometry.morphTargets[ i ].vertices;\n\t\t\t\t\tvar srcVertices = json.morphTargets[ i ].vertices;\n\n\t\t\t\t\tfor ( var v = 0, vl = srcVertices.length; v < vl; v += 3 ) {\n\n\t\t\t\t\t\tvar vertex = new Vector3();\n\t\t\t\t\t\tvertex.x = srcVertices[ v ] * scale;\n\t\t\t\t\t\tvertex.y = srcVertices[ v + 1 ] * scale;\n\t\t\t\t\t\tvertex.z = srcVertices[ v + 2 ] * scale;\n\n\t\t\t\t\t\tdstVertices.push( vertex );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( json.morphColors !== undefined && json.morphColors.length > 0 ) {\n\n\t\t\t\tconsole.warn( 'THREE.JSONLoader: \"morphColors\" no longer supported. Using them as face colors.' );\n\n\t\t\t\tvar faces = geometry.faces;\n\t\t\t\tvar morphColors = json.morphColors[ 0 ].colors;\n\n\t\t\t\tfor ( var i = 0, l = faces.length; i < l; i ++ ) {\n\n\t\t\t\t\tfaces[ i ].color.fromArray( morphColors, i * 3 );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction parseAnimations( json, geometry ) {\n\n\t\t\tvar outputAnimations = [];\n\n\t\t\t// parse old style Bone/Hierarchy animations\n\t\t\tvar animations = [];\n\n\t\t\tif ( json.animation !== undefined ) {\n\n\t\t\t\tanimations.push( json.animation );\n\n\t\t\t}\n\n\t\t\tif ( json.animations !== undefined ) {\n\n\t\t\t\tif ( json.animations.length ) {\n\n\t\t\t\t\tanimations = animations.concat( json.animations );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tanimations.push( json.animations );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tfor ( var i = 0; i < animations.length; i ++ ) {\n\n\t\t\t\tvar clip = AnimationClip.parseAnimation( animations[ i ], geometry.bones );\n\t\t\t\tif ( clip ) outputAnimations.push( clip );\n\n\t\t\t}\n\n\t\t\t// parse implicit morph animations\n\t\t\tif ( geometry.morphTargets ) {\n\n\t\t\t\t// TODO: Figure out what an appropraite FPS is for morph target animations -- defaulting to 10, but really it is completely arbitrary.\n\t\t\t\tvar morphAnimationClips = AnimationClip.CreateClipsFromMorphTargetSequences( geometry.morphTargets, 10 );\n\t\t\t\toutputAnimations = outputAnimations.concat( morphAnimationClips );\n\n\t\t\t}\n\n\t\t\tif ( outputAnimations.length > 0 ) geometry.animations = outputAnimations;\n\n\t\t}\n\n\t\treturn function parse( json, texturePath ) {\n\n\t\t\tif ( json.data !== undefined ) {\n\n\t\t\t\t// Geometry 4.0 spec\n\t\t\t\tjson = json.data;\n\n\t\t\t}\n\n\t\t\tif ( json.scale !== undefined ) {\n\n\t\t\t\tjson.scale = 1.0 / json.scale;\n\n\t\t\t} else {\n\n\t\t\t\tjson.scale = 1.0;\n\n\t\t\t}\n\n\t\t\tvar geometry = new Geometry();\n\n\t\t\tparseModel( json, geometry );\n\t\t\tparseSkin( json, geometry );\n\t\t\tparseMorphing( json, geometry );\n\t\t\tparseAnimations( json, geometry );\n\n\t\t\tgeometry.computeFaceNormals();\n\t\t\tgeometry.computeBoundingSphere();\n\n\t\t\tif ( json.materials === undefined || json.materials.length === 0 ) {\n\n\t\t\t\treturn { geometry: geometry };\n\n\t\t\t} else {\n\n\t\t\t\tvar materials = Loader.prototype.initMaterials( json.materials, texturePath, this.crossOrigin );\n\n\t\t\t\treturn { geometry: geometry, materials: materials };\n\n\t\t\t}\n\n\t\t};\n\n\t} )()\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction ObjectLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\tthis.texturePath = '';\n\n}\n\nObject.assign( ObjectLoader.prototype, {\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tif ( this.texturePath === '' ) {\n\n\t\t\tthis.texturePath = url.substring( 0, url.lastIndexOf( '/' ) + 1 );\n\n\t\t}\n\n\t\tvar scope = this;\n\n\t\tvar loader = new FileLoader( scope.manager );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\tvar json = null;\n\n\t\t\ttry {\n\n\t\t\t\tjson = JSON.parse( text );\n\n\t\t\t} catch ( error ) {\n\n\t\t\t\tif ( onError !== undefined ) onError( error );\n\n\t\t\t\tconsole.error( 'THREE:ObjectLoader: Can\\'t parse ' + url + '.', error.message );\n\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t\tvar metadata = json.metadata;\n\n\t\t\tif ( metadata === undefined || metadata.type === undefined || metadata.type.toLowerCase() === 'geometry' ) {\n\n\t\t\t\tconsole.error( 'THREE.ObjectLoader: Can\\'t load ' + url + '. Use THREE.JSONLoader instead.' );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t\tscope.parse( json, onLoad );\n\n\t\t}, onProgress, onError );\n\n\t},\n\n\tsetTexturePath: function ( value ) {\n\n\t\tthis.texturePath = value;\n\n\t},\n\n\tsetCrossOrigin: function ( value ) {\n\n\t\tthis.crossOrigin = value;\n\n\t},\n\n\tparse: function ( json, onLoad ) {\n\n\t\tvar shapes = this.parseShape( json.shapes );\n\t\tvar geometries = this.parseGeometries( json.geometries, shapes );\n\n\t\tvar images = this.parseImages( json.images, function () {\n\n\t\t\tif ( onLoad !== undefined ) onLoad( object );\n\n\t\t} );\n\n\t\tvar textures = this.parseTextures( json.textures, images );\n\t\tvar materials = this.parseMaterials( json.materials, textures );\n\n\t\tvar object = this.parseObject( json.object, geometries, materials );\n\n\t\tif ( json.animations ) {\n\n\t\t\tobject.animations = this.parseAnimations( json.animations );\n\n\t\t}\n\n\t\tif ( json.images === undefined || json.images.length === 0 ) {\n\n\t\t\tif ( onLoad !== undefined ) onLoad( object );\n\n\t\t}\n\n\t\treturn object;\n\n\t},\n\n\tparseShape: function ( json ) {\n\n\t\tvar shapes = {};\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tfor ( var i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tvar shape = new Shape().fromJSON( json[ i ] );\n\n\t\t\t\tshapes[ shape.uuid ] = shape;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn shapes;\n\n\t},\n\n\tparseGeometries: function ( json, shapes ) {\n\n\t\tvar geometries = {};\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tvar geometryLoader = new JSONLoader();\n\t\t\tvar bufferGeometryLoader = new BufferGeometryLoader();\n\n\t\t\tfor ( var i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tvar geometry;\n\t\t\t\tvar data = json[ i ];\n\n\t\t\t\tswitch ( data.type ) {\n\n\t\t\t\t\tcase 'PlaneGeometry':\n\t\t\t\t\tcase 'PlaneBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.width,\n\t\t\t\t\t\t\tdata.height,\n\t\t\t\t\t\t\tdata.widthSegments,\n\t\t\t\t\t\t\tdata.heightSegments\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'BoxGeometry':\n\t\t\t\t\tcase 'BoxBufferGeometry':\n\t\t\t\t\tcase 'CubeGeometry': // backwards compatible\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.width,\n\t\t\t\t\t\t\tdata.height,\n\t\t\t\t\t\t\tdata.depth,\n\t\t\t\t\t\t\tdata.widthSegments,\n\t\t\t\t\t\t\tdata.heightSegments,\n\t\t\t\t\t\t\tdata.depthSegments\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'CircleGeometry':\n\t\t\t\t\tcase 'CircleBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\t\tdata.segments,\n\t\t\t\t\t\t\tdata.thetaStart,\n\t\t\t\t\t\t\tdata.thetaLength\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'CylinderGeometry':\n\t\t\t\t\tcase 'CylinderBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.radiusTop,\n\t\t\t\t\t\t\tdata.radiusBottom,\n\t\t\t\t\t\t\tdata.height,\n\t\t\t\t\t\t\tdata.radialSegments,\n\t\t\t\t\t\t\tdata.heightSegments,\n\t\t\t\t\t\t\tdata.openEnded,\n\t\t\t\t\t\t\tdata.thetaStart,\n\t\t\t\t\t\t\tdata.thetaLength\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'ConeGeometry':\n\t\t\t\t\tcase 'ConeBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\t\tdata.height,\n\t\t\t\t\t\t\tdata.radialSegments,\n\t\t\t\t\t\t\tdata.heightSegments,\n\t\t\t\t\t\t\tdata.openEnded,\n\t\t\t\t\t\t\tdata.thetaStart,\n\t\t\t\t\t\t\tdata.thetaLength\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'SphereGeometry':\n\t\t\t\t\tcase 'SphereBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\t\tdata.widthSegments,\n\t\t\t\t\t\t\tdata.heightSegments,\n\t\t\t\t\t\t\tdata.phiStart,\n\t\t\t\t\t\t\tdata.phiLength,\n\t\t\t\t\t\t\tdata.thetaStart,\n\t\t\t\t\t\t\tdata.thetaLength\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'DodecahedronGeometry':\n\t\t\t\t\tcase 'DodecahedronBufferGeometry':\n\t\t\t\t\tcase 'IcosahedronGeometry':\n\t\t\t\t\tcase 'IcosahedronBufferGeometry':\n\t\t\t\t\tcase 'OctahedronGeometry':\n\t\t\t\t\tcase 'OctahedronBufferGeometry':\n\t\t\t\t\tcase 'TetrahedronGeometry':\n\t\t\t\t\tcase 'TetrahedronBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\t\tdata.detail\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'RingGeometry':\n\t\t\t\t\tcase 'RingBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.innerRadius,\n\t\t\t\t\t\t\tdata.outerRadius,\n\t\t\t\t\t\t\tdata.thetaSegments,\n\t\t\t\t\t\t\tdata.phiSegments,\n\t\t\t\t\t\t\tdata.thetaStart,\n\t\t\t\t\t\t\tdata.thetaLength\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'TorusGeometry':\n\t\t\t\t\tcase 'TorusBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\t\tdata.tube,\n\t\t\t\t\t\t\tdata.radialSegments,\n\t\t\t\t\t\t\tdata.tubularSegments,\n\t\t\t\t\t\t\tdata.arc\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'TorusKnotGeometry':\n\t\t\t\t\tcase 'TorusKnotBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\t\tdata.tube,\n\t\t\t\t\t\t\tdata.tubularSegments,\n\t\t\t\t\t\t\tdata.radialSegments,\n\t\t\t\t\t\t\tdata.p,\n\t\t\t\t\t\t\tdata.q\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'LatheGeometry':\n\t\t\t\t\tcase 'LatheBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.points,\n\t\t\t\t\t\t\tdata.segments,\n\t\t\t\t\t\t\tdata.phiStart,\n\t\t\t\t\t\t\tdata.phiLength\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'PolyhedronGeometry':\n\t\t\t\t\tcase 'PolyhedronBufferGeometry':\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tdata.vertices,\n\t\t\t\t\t\t\tdata.indices,\n\t\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\t\tdata.details\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'ShapeGeometry':\n\t\t\t\t\tcase 'ShapeBufferGeometry':\n\n\t\t\t\t\t\tvar geometryShapes = [];\n\n\t\t\t\t\t\tfor ( var j = 0, jl = data.shapes.length; j < jl; j ++ ) {\n\n\t\t\t\t\t\t\tvar shape = shapes[ data.shapes[ j ] ];\n\n\t\t\t\t\t\t\tgeometryShapes.push( shape );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tgeometry = new Geometries[ data.type ](\n\t\t\t\t\t\t\tgeometryShapes,\n\t\t\t\t\t\t\tdata.curveSegments\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'BufferGeometry':\n\n\t\t\t\t\t\tgeometry = bufferGeometryLoader.parse( data );\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'Geometry':\n\n\t\t\t\t\t\tgeometry = geometryLoader.parse( data, this.texturePath ).geometry;\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\n\t\t\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Unsupported geometry type \"' + data.type + '\"' );\n\n\t\t\t\t\t\tcontinue;\n\n\t\t\t\t}\n\n\t\t\t\tgeometry.uuid = data.uuid;\n\n\t\t\t\tif ( data.name !== undefined ) geometry.name = data.name;\n\n\t\t\t\tgeometries[ data.uuid ] = geometry;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn geometries;\n\n\t},\n\n\tparseMaterials: function ( json, textures ) {\n\n\t\tvar materials = {};\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tvar loader = new MaterialLoader();\n\t\t\tloader.setTextures( textures );\n\n\t\t\tfor ( var i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tvar data = json[ i ];\n\n\t\t\t\tif ( data.type === 'MultiMaterial' ) {\n\n\t\t\t\t\t// Deprecated\n\n\t\t\t\t\tvar array = [];\n\n\t\t\t\t\tfor ( var j = 0; j < data.materials.length; j ++ ) {\n\n\t\t\t\t\t\tarray.push( loader.parse( data.materials[ j ] ) );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tmaterials[ data.uuid ] = array;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tmaterials[ data.uuid ] = loader.parse( data );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn materials;\n\n\t},\n\n\tparseAnimations: function ( json ) {\n\n\t\tvar animations = [];\n\n\t\tfor ( var i = 0; i < json.length; i ++ ) {\n\n\t\t\tvar clip = AnimationClip.parse( json[ i ] );\n\n\t\t\tanimations.push( clip );\n\n\t\t}\n\n\t\treturn animations;\n\n\t},\n\n\tparseImages: function ( json, onLoad ) {\n\n\t\tvar scope = this;\n\t\tvar images = {};\n\n\t\tfunction loadImage( url ) {\n\n\t\t\tscope.manager.itemStart( url );\n\n\t\t\treturn loader.load( url, function () {\n\n\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t}, undefined, function () {\n\n\t\t\t\tscope.manager.itemEnd( url );\n\t\t\t\tscope.manager.itemError( url );\n\n\t\t\t} );\n\n\t\t}\n\n\t\tif ( json !== undefined && json.length > 0 ) {\n\n\t\t\tvar manager = new LoadingManager( onLoad );\n\n\t\t\tvar loader = new ImageLoader( manager );\n\t\t\tloader.setCrossOrigin( this.crossOrigin );\n\n\t\t\tfor ( var i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tvar image = json[ i ];\n\t\t\t\tvar path = /^(\\/\\/)|([a-z]+:(\\/\\/)?)/i.test( image.url ) ? image.url : scope.texturePath + image.url;\n\n\t\t\t\timages[ image.uuid ] = loadImage( path );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn images;\n\n\t},\n\n\tparseTextures: function ( json, images ) {\n\n\t\tfunction parseConstant( value, type ) {\n\n\t\t\tif ( typeof value === 'number' ) return value;\n\n\t\t\tconsole.warn( 'THREE.ObjectLoader.parseTexture: Constant should be in numeric form.', value );\n\n\t\t\treturn type[ value ];\n\n\t\t}\n\n\t\tvar textures = {};\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tfor ( var i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tvar data = json[ i ];\n\n\t\t\t\tif ( data.image === undefined ) {\n\n\t\t\t\t\tconsole.warn( 'THREE.ObjectLoader: No \"image\" specified for', data.uuid );\n\n\t\t\t\t}\n\n\t\t\t\tif ( images[ data.image ] === undefined ) {\n\n\t\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Undefined image', data.image );\n\n\t\t\t\t}\n\n\t\t\t\tvar texture = new Texture( images[ data.image ] );\n\t\t\t\ttexture.needsUpdate = true;\n\n\t\t\t\ttexture.uuid = data.uuid;\n\n\t\t\t\tif ( data.name !== undefined ) texture.name = data.name;\n\n\t\t\t\tif ( data.mapping !== undefined ) texture.mapping = parseConstant( data.mapping, TEXTURE_MAPPING );\n\n\t\t\t\tif ( data.offset !== undefined ) texture.offset.fromArray( data.offset );\n\t\t\t\tif ( data.repeat !== undefined ) texture.repeat.fromArray( data.repeat );\n\t\t\t\tif ( data.center !== undefined ) texture.center.fromArray( data.center );\n\t\t\t\tif ( data.rotation !== undefined ) texture.rotation = data.rotation;\n\n\t\t\t\tif ( data.wrap !== undefined ) {\n\n\t\t\t\t\ttexture.wrapS = parseConstant( data.wrap[ 0 ], TEXTURE_WRAPPING );\n\t\t\t\t\ttexture.wrapT = parseConstant( data.wrap[ 1 ], TEXTURE_WRAPPING );\n\n\t\t\t\t}\n\n\t\t\t\tif ( data.format !== undefined ) texture.format = data.format;\n\n\t\t\t\tif ( data.minFilter !== undefined ) texture.minFilter = parseConstant( data.minFilter, TEXTURE_FILTER );\n\t\t\t\tif ( data.magFilter !== undefined ) texture.magFilter = parseConstant( data.magFilter, TEXTURE_FILTER );\n\t\t\t\tif ( data.anisotropy !== undefined ) texture.anisotropy = data.anisotropy;\n\n\t\t\t\tif ( data.flipY !== undefined ) texture.flipY = data.flipY;\n\n\t\t\t\ttextures[ data.uuid ] = texture;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn textures;\n\n\t},\n\n\tparseObject: function ( data, geometries, materials ) {\n\n\t\tvar object;\n\n\t\tfunction getGeometry( name ) {\n\n\t\t\tif ( geometries[ name ] === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Undefined geometry', name );\n\n\t\t\t}\n\n\t\t\treturn geometries[ name ];\n\n\t\t}\n\n\t\tfunction getMaterial( name ) {\n\n\t\t\tif ( name === undefined ) return undefined;\n\n\t\t\tif ( Array.isArray( name ) ) {\n\n\t\t\t\tvar array = [];\n\n\t\t\t\tfor ( var i = 0, l = name.length; i < l; i ++ ) {\n\n\t\t\t\t\tvar uuid = name[ i ];\n\n\t\t\t\t\tif ( materials[ uuid ] === undefined ) {\n\n\t\t\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Undefined material', uuid );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tarray.push( materials[ uuid ] );\n\n\t\t\t\t}\n\n\t\t\t\treturn array;\n\n\t\t\t}\n\n\t\t\tif ( materials[ name ] === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Undefined material', name );\n\n\t\t\t}\n\n\t\t\treturn materials[ name ];\n\n\t\t}\n\n\t\tswitch ( data.type ) {\n\n\t\t\tcase 'Scene':\n\n\t\t\t\tobject = new Scene();\n\n\t\t\t\tif ( data.background !== undefined ) {\n\n\t\t\t\t\tif ( Number.isInteger( data.background ) ) {\n\n\t\t\t\t\t\tobject.background = new Color( data.background );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tif ( data.fog !== undefined ) {\n\n\t\t\t\t\tif ( data.fog.type === 'Fog' ) {\n\n\t\t\t\t\t\tobject.fog = new Fog( data.fog.color, data.fog.near, data.fog.far );\n\n\t\t\t\t\t} else if ( data.fog.type === 'FogExp2' ) {\n\n\t\t\t\t\t\tobject.fog = new FogExp2( data.fog.color, data.fog.density );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'PerspectiveCamera':\n\n\t\t\t\tobject = new PerspectiveCamera( data.fov, data.aspect, data.near, data.far );\n\n\t\t\t\tif ( data.focus !== undefined ) object.focus = data.focus;\n\t\t\t\tif ( data.zoom !== undefined ) object.zoom = data.zoom;\n\t\t\t\tif ( data.filmGauge !== undefined ) object.filmGauge = data.filmGauge;\n\t\t\t\tif ( data.filmOffset !== undefined ) object.filmOffset = data.filmOffset;\n\t\t\t\tif ( data.view !== undefined ) object.view = Object.assign( {}, data.view );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'OrthographicCamera':\n\n\t\t\t\tobject = new OrthographicCamera( data.left, data.right, data.top, data.bottom, data.near, data.far );\n\n\t\t\t\tif ( data.zoom !== undefined ) object.zoom = data.zoom;\n\t\t\t\tif ( data.view !== undefined ) object.view = Object.assign( {}, data.view );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'AmbientLight':\n\n\t\t\t\tobject = new AmbientLight( data.color, data.intensity );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'DirectionalLight':\n\n\t\t\t\tobject = new DirectionalLight( data.color, data.intensity );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'PointLight':\n\n\t\t\t\tobject = new PointLight( data.color, data.intensity, data.distance, data.decay );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'RectAreaLight':\n\n\t\t\t\tobject = new RectAreaLight( data.color, data.intensity, data.width, data.height );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'SpotLight':\n\n\t\t\t\tobject = new SpotLight( data.color, data.intensity, data.distance, data.angle, data.penumbra, data.decay );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'HemisphereLight':\n\n\t\t\t\tobject = new HemisphereLight( data.color, data.groundColor, data.intensity );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'SkinnedMesh':\n\n\t\t\t\tconsole.warn( 'THREE.ObjectLoader.parseObject() does not support SkinnedMesh yet.' );\n\n\t\t\tcase 'Mesh':\n\n\t\t\t\tvar geometry = getGeometry( data.geometry );\n\t\t\t\tvar material = getMaterial( data.material );\n\n\t\t\t\tif ( geometry.bones && geometry.bones.length > 0 ) {\n\n\t\t\t\t\tobject = new SkinnedMesh( geometry, material );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tobject = new Mesh( geometry, material );\n\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'LOD':\n\n\t\t\t\tobject = new LOD();\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'Line':\n\n\t\t\t\tobject = new Line( getGeometry( data.geometry ), getMaterial( data.material ), data.mode );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'LineLoop':\n\n\t\t\t\tobject = new LineLoop( getGeometry( data.geometry ), getMaterial( data.material ) );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'LineSegments':\n\n\t\t\t\tobject = new LineSegments( getGeometry( data.geometry ), getMaterial( data.material ) );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'PointCloud':\n\t\t\tcase 'Points':\n\n\t\t\t\tobject = new Points( getGeometry( data.geometry ), getMaterial( data.material ) );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'Sprite':\n\n\t\t\t\tobject = new Sprite( getMaterial( data.material ) );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'Group':\n\n\t\t\t\tobject = new Group();\n\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\n\t\t\t\tobject = new Object3D();\n\n\t\t}\n\n\t\tobject.uuid = data.uuid;\n\n\t\tif ( data.name !== undefined ) object.name = data.name;\n\n\t\tif ( data.matrix !== undefined ) {\n\n\t\t\tobject.matrix.fromArray( data.matrix );\n\n\t\t\tif ( data.matrixAutoUpdate !== undefined ) object.matrixAutoUpdate = data.matrixAutoUpdate;\n\t\t\tif ( object.matrixAutoUpdate ) object.matrix.decompose( object.position, object.quaternion, object.scale );\n\n\t\t} else {\n\n\t\t\tif ( data.position !== undefined ) object.position.fromArray( data.position );\n\t\t\tif ( data.rotation !== undefined ) object.rotation.fromArray( data.rotation );\n\t\t\tif ( data.quaternion !== undefined ) object.quaternion.fromArray( data.quaternion );\n\t\t\tif ( data.scale !== undefined ) object.scale.fromArray( data.scale );\n\n\t\t}\n\n\t\tif ( data.castShadow !== undefined ) object.castShadow = data.castShadow;\n\t\tif ( data.receiveShadow !== undefined ) object.receiveShadow = data.receiveShadow;\n\n\t\tif ( data.shadow ) {\n\n\t\t\tif ( data.shadow.bias !== undefined ) object.shadow.bias = data.shadow.bias;\n\t\t\tif ( data.shadow.radius !== undefined ) object.shadow.radius = data.shadow.radius;\n\t\t\tif ( data.shadow.mapSize !== undefined ) object.shadow.mapSize.fromArray( data.shadow.mapSize );\n\t\t\tif ( data.shadow.camera !== undefined ) object.shadow.camera = this.parseObject( data.shadow.camera );\n\n\t\t}\n\n\t\tif ( data.visible !== undefined ) object.visible = data.visible;\n\t\tif ( data.frustumCulled !== undefined ) object.frustumCulled = data.frustumCulled;\n\t\tif ( data.renderOrder !== undefined ) object.renderOrder = data.renderOrder;\n\t\tif ( data.userData !== undefined ) object.userData = data.userData;\n\n\t\tif ( data.children !== undefined ) {\n\n\t\t\tvar children = data.children;\n\n\t\t\tfor ( var i = 0; i < children.length; i ++ ) {\n\n\t\t\t\tobject.add( this.parseObject( children[ i ], geometries, materials ) );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( data.type === 'LOD' ) {\n\n\t\t\tvar levels = data.levels;\n\n\t\t\tfor ( var l = 0; l < levels.length; l ++ ) {\n\n\t\t\t\tvar level = levels[ l ];\n\t\t\t\tvar child = object.getObjectByProperty( 'uuid', level.object );\n\n\t\t\t\tif ( child !== undefined ) {\n\n\t\t\t\t\tobject.addLevel( child, level.distance );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn object;\n\n\t}\n\n} );\n\nvar TEXTURE_MAPPING = {\n\tUVMapping: UVMapping,\n\tCubeReflectionMapping: CubeReflectionMapping,\n\tCubeRefractionMapping: CubeRefractionMapping,\n\tEquirectangularReflectionMapping: EquirectangularReflectionMapping,\n\tEquirectangularRefractionMapping: EquirectangularRefractionMapping,\n\tSphericalReflectionMapping: SphericalReflectionMapping,\n\tCubeUVReflectionMapping: CubeUVReflectionMapping,\n\tCubeUVRefractionMapping: CubeUVRefractionMapping\n};\n\nvar TEXTURE_WRAPPING = {\n\tRepeatWrapping: RepeatWrapping,\n\tClampToEdgeWrapping: ClampToEdgeWrapping,\n\tMirroredRepeatWrapping: MirroredRepeatWrapping\n};\n\nvar TEXTURE_FILTER = {\n\tNearestFilter: NearestFilter,\n\tNearestMipMapNearestFilter: NearestMipMapNearestFilter,\n\tNearestMipMapLinearFilter: NearestMipMapLinearFilter,\n\tLinearFilter: LinearFilter,\n\tLinearMipMapNearestFilter: LinearMipMapNearestFilter,\n\tLinearMipMapLinearFilter: LinearMipMapLinearFilter\n};\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n * minimal class for proxing functions to Path. Replaces old \"extractSubpaths()\"\n **/\n\nfunction ShapePath() {\n\n\tthis.type = 'ShapePath';\n\n\tthis.color = new Color();\n\n\tthis.subPaths = [];\n\tthis.currentPath = null;\n\n}\n\nObject.assign( ShapePath.prototype, {\n\n\tmoveTo: function ( x, y ) {\n\n\t\tthis.currentPath = new Path();\n\t\tthis.subPaths.push( this.currentPath );\n\t\tthis.currentPath.moveTo( x, y );\n\n\t},\n\n\tlineTo: function ( x, y ) {\n\n\t\tthis.currentPath.lineTo( x, y );\n\n\t},\n\n\tquadraticCurveTo: function ( aCPx, aCPy, aX, aY ) {\n\n\t\tthis.currentPath.quadraticCurveTo( aCPx, aCPy, aX, aY );\n\n\t},\n\n\tbezierCurveTo: function ( aCP1x, aCP1y, aCP2x, aCP2y, aX, aY ) {\n\n\t\tthis.currentPath.bezierCurveTo( aCP1x, aCP1y, aCP2x, aCP2y, aX, aY );\n\n\t},\n\n\tsplineThru: function ( pts ) {\n\n\t\tthis.currentPath.splineThru( pts );\n\n\t},\n\n\ttoShapes: function ( isCCW, noHoles ) {\n\n\t\tfunction toShapesNoHoles( inSubpaths ) {\n\n\t\t\tvar shapes = [];\n\n\t\t\tfor ( var i = 0, l = inSubpaths.length; i < l; i ++ ) {\n\n\t\t\t\tvar tmpPath = inSubpaths[ i ];\n\n\t\t\t\tvar tmpShape = new Shape();\n\t\t\t\ttmpShape.curves = tmpPath.curves;\n\n\t\t\t\tshapes.push( tmpShape );\n\n\t\t\t}\n\n\t\t\treturn shapes;\n\n\t\t}\n\n\t\tfunction isPointInsidePolygon( inPt, inPolygon ) {\n\n\t\t\tvar polyLen = inPolygon.length;\n\n\t\t\t// inPt on polygon contour => immediate success    or\n\t\t\t// toggling of inside/outside at every single! intersection point of an edge\n\t\t\t//  with the horizontal line through inPt, left of inPt\n\t\t\t//  not counting lowerY endpoints of edges and whole edges on that line\n\t\t\tvar inside = false;\n\t\t\tfor ( var p = polyLen - 1, q = 0; q < polyLen; p = q ++ ) {\n\n\t\t\t\tvar edgeLowPt = inPolygon[ p ];\n\t\t\t\tvar edgeHighPt = inPolygon[ q ];\n\n\t\t\t\tvar edgeDx = edgeHighPt.x - edgeLowPt.x;\n\t\t\t\tvar edgeDy = edgeHighPt.y - edgeLowPt.y;\n\n\t\t\t\tif ( Math.abs( edgeDy ) > Number.EPSILON ) {\n\n\t\t\t\t\t// not parallel\n\t\t\t\t\tif ( edgeDy < 0 ) {\n\n\t\t\t\t\t\tedgeLowPt = inPolygon[ q ]; edgeDx = - edgeDx;\n\t\t\t\t\t\tedgeHighPt = inPolygon[ p ]; edgeDy = - edgeDy;\n\n\t\t\t\t\t}\n\t\t\t\t\tif ( ( inPt.y < edgeLowPt.y ) || ( inPt.y > edgeHighPt.y ) ) \t\tcontinue;\n\n\t\t\t\t\tif ( inPt.y === edgeLowPt.y ) {\n\n\t\t\t\t\t\tif ( inPt.x === edgeLowPt.x )\t\treturn\ttrue;\t\t// inPt is on contour ?\n\t\t\t\t\t\t// continue;\t\t\t\t// no intersection or edgeLowPt => doesn't count !!!\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tvar perpEdge = edgeDy * ( inPt.x - edgeLowPt.x ) - edgeDx * ( inPt.y - edgeLowPt.y );\n\t\t\t\t\t\tif ( perpEdge === 0 )\t\t\t\treturn\ttrue;\t\t// inPt is on contour ?\n\t\t\t\t\t\tif ( perpEdge < 0 ) \t\t\t\tcontinue;\n\t\t\t\t\t\tinside = ! inside;\t\t// true intersection left of inPt\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// parallel or collinear\n\t\t\t\t\tif ( inPt.y !== edgeLowPt.y ) \t\tcontinue;\t\t\t// parallel\n\t\t\t\t\t// edge lies on the same horizontal line as inPt\n\t\t\t\t\tif ( ( ( edgeHighPt.x <= inPt.x ) && ( inPt.x <= edgeLowPt.x ) ) ||\n\t\t\t\t\t\t ( ( edgeLowPt.x <= inPt.x ) && ( inPt.x <= edgeHighPt.x ) ) )\t\treturn\ttrue;\t// inPt: Point on contour !\n\t\t\t\t\t// continue;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn\tinside;\n\n\t\t}\n\n\t\tvar isClockWise = ShapeUtils.isClockWise;\n\n\t\tvar subPaths = this.subPaths;\n\t\tif ( subPaths.length === 0 ) return [];\n\n\t\tif ( noHoles === true )\treturn\ttoShapesNoHoles( subPaths );\n\n\n\t\tvar solid, tmpPath, tmpShape, shapes = [];\n\n\t\tif ( subPaths.length === 1 ) {\n\n\t\t\ttmpPath = subPaths[ 0 ];\n\t\t\ttmpShape = new Shape();\n\t\t\ttmpShape.curves = tmpPath.curves;\n\t\t\tshapes.push( tmpShape );\n\t\t\treturn shapes;\n\n\t\t}\n\n\t\tvar holesFirst = ! isClockWise( subPaths[ 0 ].getPoints() );\n\t\tholesFirst = isCCW ? ! holesFirst : holesFirst;\n\n\t\t// console.log(\"Holes first\", holesFirst);\n\n\t\tvar betterShapeHoles = [];\n\t\tvar newShapes = [];\n\t\tvar newShapeHoles = [];\n\t\tvar mainIdx = 0;\n\t\tvar tmpPoints;\n\n\t\tnewShapes[ mainIdx ] = undefined;\n\t\tnewShapeHoles[ mainIdx ] = [];\n\n\t\tfor ( var i = 0, l = subPaths.length; i < l; i ++ ) {\n\n\t\t\ttmpPath = subPaths[ i ];\n\t\t\ttmpPoints = tmpPath.getPoints();\n\t\t\tsolid = isClockWise( tmpPoints );\n\t\t\tsolid = isCCW ? ! solid : solid;\n\n\t\t\tif ( solid ) {\n\n\t\t\t\tif ( ( ! holesFirst ) && ( newShapes[ mainIdx ] ) )\tmainIdx ++;\n\n\t\t\t\tnewShapes[ mainIdx ] = { s: new Shape(), p: tmpPoints };\n\t\t\t\tnewShapes[ mainIdx ].s.curves = tmpPath.curves;\n\n\t\t\t\tif ( holesFirst )\tmainIdx ++;\n\t\t\t\tnewShapeHoles[ mainIdx ] = [];\n\n\t\t\t\t//console.log('cw', i);\n\n\t\t\t} else {\n\n\t\t\t\tnewShapeHoles[ mainIdx ].push( { h: tmpPath, p: tmpPoints[ 0 ] } );\n\n\t\t\t\t//console.log('ccw', i);\n\n\t\t\t}\n\n\t\t}\n\n\t\t// only Holes? -> probably all Shapes with wrong orientation\n\t\tif ( ! newShapes[ 0 ] )\treturn\ttoShapesNoHoles( subPaths );\n\n\n\t\tif ( newShapes.length > 1 ) {\n\n\t\t\tvar ambiguous = false;\n\t\t\tvar toChange = [];\n\n\t\t\tfor ( var sIdx = 0, sLen = newShapes.length; sIdx < sLen; sIdx ++ ) {\n\n\t\t\t\tbetterShapeHoles[ sIdx ] = [];\n\n\t\t\t}\n\n\t\t\tfor ( var sIdx = 0, sLen = newShapes.length; sIdx < sLen; sIdx ++ ) {\n\n\t\t\t\tvar sho = newShapeHoles[ sIdx ];\n\n\t\t\t\tfor ( var hIdx = 0; hIdx < sho.length; hIdx ++ ) {\n\n\t\t\t\t\tvar ho = sho[ hIdx ];\n\t\t\t\t\tvar hole_unassigned = true;\n\n\t\t\t\t\tfor ( var s2Idx = 0; s2Idx < newShapes.length; s2Idx ++ ) {\n\n\t\t\t\t\t\tif ( isPointInsidePolygon( ho.p, newShapes[ s2Idx ].p ) ) {\n\n\t\t\t\t\t\t\tif ( sIdx !== s2Idx )\ttoChange.push( { froms: sIdx, tos: s2Idx, hole: hIdx } );\n\t\t\t\t\t\t\tif ( hole_unassigned ) {\n\n\t\t\t\t\t\t\t\thole_unassigned = false;\n\t\t\t\t\t\t\t\tbetterShapeHoles[ s2Idx ].push( ho );\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\tambiguous = true;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\t\t\t\t\tif ( hole_unassigned ) {\n\n\t\t\t\t\t\tbetterShapeHoles[ sIdx ].push( ho );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\t\t\t// console.log(\"ambiguous: \", ambiguous);\n\t\t\tif ( toChange.length > 0 ) {\n\n\t\t\t\t// console.log(\"to change: \", toChange);\n\t\t\t\tif ( ! ambiguous )\tnewShapeHoles = betterShapeHoles;\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar tmpHoles;\n\n\t\tfor ( var i = 0, il = newShapes.length; i < il; i ++ ) {\n\n\t\t\ttmpShape = newShapes[ i ].s;\n\t\t\tshapes.push( tmpShape );\n\t\t\ttmpHoles = newShapeHoles[ i ];\n\n\t\t\tfor ( var j = 0, jl = tmpHoles.length; j < jl; j ++ ) {\n\n\t\t\t\ttmpShape.holes.push( tmpHoles[ j ].h );\n\n\t\t\t}\n\n\t\t}\n\n\t\t//console.log(\"shape\", shapes);\n\n\t\treturn shapes;\n\n\t}\n\n} );\n\n/**\n * @author zz85 / http://www.lab4games.net/zz85/blog\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction Font( data ) {\n\n\tthis.type = 'Font';\n\n\tthis.data = data;\n\n}\n\nObject.assign( Font.prototype, {\n\n\tisFont: true,\n\n\tgenerateShapes: function ( text, size, divisions ) {\n\n\t\tif ( size === undefined ) size = 100;\n\t\tif ( divisions === undefined ) divisions = 4;\n\n\t\tvar shapes = [];\n\t\tvar paths = createPaths( text, size, divisions, this.data );\n\n\t\tfor ( var p = 0, pl = paths.length; p < pl; p ++ ) {\n\n\t\t\tArray.prototype.push.apply( shapes, paths[ p ].toShapes() );\n\n\t\t}\n\n\t\treturn shapes;\n\n\t}\n\n} );\n\nfunction createPaths( text, size, divisions, data ) {\n\n\tvar chars = String( text ).split( '' );\n\tvar scale = size / data.resolution;\n\tvar line_height = ( data.boundingBox.yMax - data.boundingBox.yMin + data.underlineThickness ) * scale;\n\n\tvar paths = [];\n\n\tvar offsetX = 0, offsetY = 0;\n\n\tfor ( var i = 0; i < chars.length; i ++ ) {\n\n\t\tvar char = chars[ i ];\n\n\t\tif ( char === '\\n' ) {\n\n\t\t\toffsetX = 0;\n\t\t\toffsetY -= line_height;\n\n\t\t} else {\n\n\t\t\tvar ret = createPath( char, divisions, scale, offsetX, offsetY, data );\n\t\t\toffsetX += ret.offsetX;\n\t\t\tpaths.push( ret.path );\n\n\t\t}\n\n\t}\n\n\treturn paths;\n\n}\n\nfunction createPath( char, divisions, scale, offsetX, offsetY, data ) {\n\n\tvar glyph = data.glyphs[ char ] || data.glyphs[ '?' ];\n\n\tif ( ! glyph ) return;\n\n\tvar path = new ShapePath();\n\n\tvar x, y, cpx, cpy, cpx1, cpy1, cpx2, cpy2;\n\n\tif ( glyph.o ) {\n\n\t\tvar outline = glyph._cachedOutline || ( glyph._cachedOutline = glyph.o.split( ' ' ) );\n\n\t\tfor ( var i = 0, l = outline.length; i < l; ) {\n\n\t\t\tvar action = outline[ i ++ ];\n\n\t\t\tswitch ( action ) {\n\n\t\t\t\tcase 'm': // moveTo\n\n\t\t\t\t\tx = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\ty = outline[ i ++ ] * scale + offsetY;\n\n\t\t\t\t\tpath.moveTo( x, y );\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'l': // lineTo\n\n\t\t\t\t\tx = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\ty = outline[ i ++ ] * scale + offsetY;\n\n\t\t\t\t\tpath.lineTo( x, y );\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'q': // quadraticCurveTo\n\n\t\t\t\t\tcpx = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy = outline[ i ++ ] * scale + offsetY;\n\t\t\t\t\tcpx1 = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy1 = outline[ i ++ ] * scale + offsetY;\n\n\t\t\t\t\tpath.quadraticCurveTo( cpx1, cpy1, cpx, cpy );\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'b': // bezierCurveTo\n\n\t\t\t\t\tcpx = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy = outline[ i ++ ] * scale + offsetY;\n\t\t\t\t\tcpx1 = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy1 = outline[ i ++ ] * scale + offsetY;\n\t\t\t\t\tcpx2 = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy2 = outline[ i ++ ] * scale + offsetY;\n\n\t\t\t\t\tpath.bezierCurveTo( cpx1, cpy1, cpx2, cpy2, cpx, cpy );\n\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\treturn { offsetX: glyph.ha * scale, path: path };\n\n}\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction FontLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n}\n\nObject.assign( FontLoader.prototype, {\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tvar scope = this;\n\n\t\tvar loader = new FileLoader( this.manager );\n\t\tloader.setPath( this.path );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\tvar json;\n\n\t\t\ttry {\n\n\t\t\t\tjson = JSON.parse( text );\n\n\t\t\t} catch ( e ) {\n\n\t\t\t\tconsole.warn( 'THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead.' );\n\t\t\t\tjson = JSON.parse( text.substring( 65, text.length - 2 ) );\n\n\t\t\t}\n\n\t\t\tvar font = scope.parse( json );\n\n\t\t\tif ( onLoad ) onLoad( font );\n\n\t\t}, onProgress, onError );\n\n\t},\n\n\tparse: function ( json ) {\n\n\t\treturn new Font( json );\n\n\t},\n\n\tsetPath: function ( value ) {\n\n\t\tthis.path = value;\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nvar context;\n\nvar AudioContext = {\n\n\tgetContext: function () {\n\n\t\tif ( context === undefined ) {\n\n\t\t\tcontext = new ( window.AudioContext || window.webkitAudioContext )();\n\n\t\t}\n\n\t\treturn context;\n\n\t},\n\n\tsetContext: function ( value ) {\n\n\t\tcontext = value;\n\n\t}\n\n};\n\n/**\n * @author Reece Aaron Lecrivain / http://reecenotes.com/\n */\n\nfunction AudioLoader( manager ) {\n\n\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n}\n\nObject.assign( AudioLoader.prototype, {\n\n\tload: function ( url, onLoad, onProgress, onError ) {\n\n\t\tvar loader = new FileLoader( this.manager );\n\t\tloader.setResponseType( 'arraybuffer' );\n\t\tloader.load( url, function ( buffer ) {\n\n\t\t\tvar context = AudioContext.getContext();\n\n\t\t\tcontext.decodeAudioData( buffer, function ( audioBuffer ) {\n\n\t\t\t\tonLoad( audioBuffer );\n\n\t\t\t} );\n\n\t\t}, onProgress, onError );\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction StereoCamera() {\n\n\tthis.type = 'StereoCamera';\n\n\tthis.aspect = 1;\n\n\tthis.eyeSep = 0.064;\n\n\tthis.cameraL = new PerspectiveCamera();\n\tthis.cameraL.layers.enable( 1 );\n\tthis.cameraL.matrixAutoUpdate = false;\n\n\tthis.cameraR = new PerspectiveCamera();\n\tthis.cameraR.layers.enable( 2 );\n\tthis.cameraR.matrixAutoUpdate = false;\n\n}\n\nObject.assign( StereoCamera.prototype, {\n\n\tupdate: ( function () {\n\n\t\tvar instance, focus, fov, aspect, near, far, zoom, eyeSep;\n\n\t\tvar eyeRight = new Matrix4();\n\t\tvar eyeLeft = new Matrix4();\n\n\t\treturn function update( camera ) {\n\n\t\t\tvar needsUpdate = instance !== this || focus !== camera.focus || fov !== camera.fov ||\n\t\t\t\t\t\t\t\t\t\t\t\taspect !== camera.aspect * this.aspect || near !== camera.near ||\n\t\t\t\t\t\t\t\t\t\t\t\tfar !== camera.far || zoom !== camera.zoom || eyeSep !== this.eyeSep;\n\n\t\t\tif ( needsUpdate ) {\n\n\t\t\t\tinstance = this;\n\t\t\t\tfocus = camera.focus;\n\t\t\t\tfov = camera.fov;\n\t\t\t\taspect = camera.aspect * this.aspect;\n\t\t\t\tnear = camera.near;\n\t\t\t\tfar = camera.far;\n\t\t\t\tzoom = camera.zoom;\n\n\t\t\t\t// Off-axis stereoscopic effect based on\n\t\t\t\t// http://paulbourke.net/stereographics/stereorender/\n\n\t\t\t\tvar projectionMatrix = camera.projectionMatrix.clone();\n\t\t\t\teyeSep = this.eyeSep / 2;\n\t\t\t\tvar eyeSepOnProjection = eyeSep * near / focus;\n\t\t\t\tvar ymax = ( near * Math.tan( _Math.DEG2RAD * fov * 0.5 ) ) / zoom;\n\t\t\t\tvar xmin, xmax;\n\n\t\t\t\t// translate xOffset\n\n\t\t\t\teyeLeft.elements[ 12 ] = - eyeSep;\n\t\t\t\teyeRight.elements[ 12 ] = eyeSep;\n\n\t\t\t\t// for left eye\n\n\t\t\t\txmin = - ymax * aspect + eyeSepOnProjection;\n\t\t\t\txmax = ymax * aspect + eyeSepOnProjection;\n\n\t\t\t\tprojectionMatrix.elements[ 0 ] = 2 * near / ( xmax - xmin );\n\t\t\t\tprojectionMatrix.elements[ 8 ] = ( xmax + xmin ) / ( xmax - xmin );\n\n\t\t\t\tthis.cameraL.projectionMatrix.copy( projectionMatrix );\n\n\t\t\t\t// for right eye\n\n\t\t\t\txmin = - ymax * aspect - eyeSepOnProjection;\n\t\t\t\txmax = ymax * aspect - eyeSepOnProjection;\n\n\t\t\t\tprojectionMatrix.elements[ 0 ] = 2 * near / ( xmax - xmin );\n\t\t\t\tprojectionMatrix.elements[ 8 ] = ( xmax + xmin ) / ( xmax - xmin );\n\n\t\t\t\tthis.cameraR.projectionMatrix.copy( projectionMatrix );\n\n\t\t\t}\n\n\t\t\tthis.cameraL.matrixWorld.copy( camera.matrixWorld ).multiply( eyeLeft );\n\t\t\tthis.cameraR.matrixWorld.copy( camera.matrixWorld ).multiply( eyeRight );\n\n\t\t};\n\n\t} )()\n\n} );\n\n/**\n * Camera for rendering cube maps\n *\t- renders scene into axis-aligned cube\n *\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction CubeCamera( near, far, cubeResolution ) {\n\n\tObject3D.call( this );\n\n\tthis.type = 'CubeCamera';\n\n\tvar fov = 90, aspect = 1;\n\n\tvar cameraPX = new PerspectiveCamera( fov, aspect, near, far );\n\tcameraPX.up.set( 0, - 1, 0 );\n\tcameraPX.lookAt( new Vector3( 1, 0, 0 ) );\n\tthis.add( cameraPX );\n\n\tvar cameraNX = new PerspectiveCamera( fov, aspect, near, far );\n\tcameraNX.up.set( 0, - 1, 0 );\n\tcameraNX.lookAt( new Vector3( - 1, 0, 0 ) );\n\tthis.add( cameraNX );\n\n\tvar cameraPY = new PerspectiveCamera( fov, aspect, near, far );\n\tcameraPY.up.set( 0, 0, 1 );\n\tcameraPY.lookAt( new Vector3( 0, 1, 0 ) );\n\tthis.add( cameraPY );\n\n\tvar cameraNY = new PerspectiveCamera( fov, aspect, near, far );\n\tcameraNY.up.set( 0, 0, - 1 );\n\tcameraNY.lookAt( new Vector3( 0, - 1, 0 ) );\n\tthis.add( cameraNY );\n\n\tvar cameraPZ = new PerspectiveCamera( fov, aspect, near, far );\n\tcameraPZ.up.set( 0, - 1, 0 );\n\tcameraPZ.lookAt( new Vector3( 0, 0, 1 ) );\n\tthis.add( cameraPZ );\n\n\tvar cameraNZ = new PerspectiveCamera( fov, aspect, near, far );\n\tcameraNZ.up.set( 0, - 1, 0 );\n\tcameraNZ.lookAt( new Vector3( 0, 0, - 1 ) );\n\tthis.add( cameraNZ );\n\n\tvar options = { format: RGBFormat, magFilter: LinearFilter, minFilter: LinearFilter };\n\n\tthis.renderTarget = new WebGLRenderTargetCube( cubeResolution, cubeResolution, options );\n\tthis.renderTarget.texture.name = \"CubeCamera\";\n\n\tthis.update = function ( renderer, scene ) {\n\n\t\tif ( this.parent === null ) this.updateMatrixWorld();\n\n\t\tvar renderTarget = this.renderTarget;\n\t\tvar generateMipmaps = renderTarget.texture.generateMipmaps;\n\n\t\trenderTarget.texture.generateMipmaps = false;\n\n\t\trenderTarget.activeCubeFace = 0;\n\t\trenderer.render( scene, cameraPX, renderTarget );\n\n\t\trenderTarget.activeCubeFace = 1;\n\t\trenderer.render( scene, cameraNX, renderTarget );\n\n\t\trenderTarget.activeCubeFace = 2;\n\t\trenderer.render( scene, cameraPY, renderTarget );\n\n\t\trenderTarget.activeCubeFace = 3;\n\t\trenderer.render( scene, cameraNY, renderTarget );\n\n\t\trenderTarget.activeCubeFace = 4;\n\t\trenderer.render( scene, cameraPZ, renderTarget );\n\n\t\trenderTarget.texture.generateMipmaps = generateMipmaps;\n\n\t\trenderTarget.activeCubeFace = 5;\n\t\trenderer.render( scene, cameraNZ, renderTarget );\n\n\t\trenderer.setRenderTarget( null );\n\n\t};\n\n\tthis.clear = function ( renderer, color, depth, stencil ) {\n\n\t\tvar renderTarget = this.renderTarget;\n\n\t\tfor ( var i = 0; i < 6; i ++ ) {\n\n\t\t\trenderTarget.activeCubeFace = i;\n\t\t\trenderer.setRenderTarget( renderTarget );\n\n\t\t\trenderer.clear( color, depth, stencil );\n\n\t\t}\n\n\t\trenderer.setRenderTarget( null );\n\n\t};\n\n}\n\nCubeCamera.prototype = Object.create( Object3D.prototype );\nCubeCamera.prototype.constructor = CubeCamera;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction AudioListener() {\n\n\tObject3D.call( this );\n\n\tthis.type = 'AudioListener';\n\n\tthis.context = AudioContext.getContext();\n\n\tthis.gain = this.context.createGain();\n\tthis.gain.connect( this.context.destination );\n\n\tthis.filter = null;\n\n}\n\nAudioListener.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: AudioListener,\n\n\tgetInput: function () {\n\n\t\treturn this.gain;\n\n\t},\n\n\tremoveFilter: function ( ) {\n\n\t\tif ( this.filter !== null ) {\n\n\t\t\tthis.gain.disconnect( this.filter );\n\t\t\tthis.filter.disconnect( this.context.destination );\n\t\t\tthis.gain.connect( this.context.destination );\n\t\t\tthis.filter = null;\n\n\t\t}\n\n\t},\n\n\tgetFilter: function () {\n\n\t\treturn this.filter;\n\n\t},\n\n\tsetFilter: function ( value ) {\n\n\t\tif ( this.filter !== null ) {\n\n\t\t\tthis.gain.disconnect( this.filter );\n\t\t\tthis.filter.disconnect( this.context.destination );\n\n\t\t} else {\n\n\t\t\tthis.gain.disconnect( this.context.destination );\n\n\t\t}\n\n\t\tthis.filter = value;\n\t\tthis.gain.connect( this.filter );\n\t\tthis.filter.connect( this.context.destination );\n\n\t},\n\n\tgetMasterVolume: function () {\n\n\t\treturn this.gain.gain.value;\n\n\t},\n\n\tsetMasterVolume: function ( value ) {\n\n\t\tthis.gain.gain.setTargetAtTime( value, this.context.currentTime, 0.01 );\n\n\t},\n\n\tupdateMatrixWorld: ( function () {\n\n\t\tvar position = new Vector3();\n\t\tvar quaternion = new Quaternion();\n\t\tvar scale = new Vector3();\n\n\t\tvar orientation = new Vector3();\n\n\t\treturn function updateMatrixWorld( force ) {\n\n\t\t\tObject3D.prototype.updateMatrixWorld.call( this, force );\n\n\t\t\tvar listener = this.context.listener;\n\t\t\tvar up = this.up;\n\n\t\t\tthis.matrixWorld.decompose( position, quaternion, scale );\n\n\t\t\torientation.set( 0, 0, - 1 ).applyQuaternion( quaternion );\n\n\t\t\tif ( listener.positionX ) {\n\n\t\t\t\tlistener.positionX.setValueAtTime( position.x, this.context.currentTime );\n\t\t\t\tlistener.positionY.setValueAtTime( position.y, this.context.currentTime );\n\t\t\t\tlistener.positionZ.setValueAtTime( position.z, this.context.currentTime );\n\t\t\t\tlistener.forwardX.setValueAtTime( orientation.x, this.context.currentTime );\n\t\t\t\tlistener.forwardY.setValueAtTime( orientation.y, this.context.currentTime );\n\t\t\t\tlistener.forwardZ.setValueAtTime( orientation.z, this.context.currentTime );\n\t\t\t\tlistener.upX.setValueAtTime( up.x, this.context.currentTime );\n\t\t\t\tlistener.upY.setValueAtTime( up.y, this.context.currentTime );\n\t\t\t\tlistener.upZ.setValueAtTime( up.z, this.context.currentTime );\n\n\t\t\t} else {\n\n\t\t\t\tlistener.setPosition( position.x, position.y, position.z );\n\t\t\t\tlistener.setOrientation( orientation.x, orientation.y, orientation.z, up.x, up.y, up.z );\n\n\t\t\t}\n\n\t\t};\n\n\t} )()\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author Reece Aaron Lecrivain / http://reecenotes.com/\n */\n\nfunction Audio( listener ) {\n\n\tObject3D.call( this );\n\n\tthis.type = 'Audio';\n\n\tthis.context = listener.context;\n\n\tthis.gain = this.context.createGain();\n\tthis.gain.connect( listener.getInput() );\n\n\tthis.autoplay = false;\n\n\tthis.buffer = null;\n\tthis.loop = false;\n\tthis.startTime = 0;\n\tthis.offset = 0;\n\tthis.playbackRate = 1;\n\tthis.isPlaying = false;\n\tthis.hasPlaybackControl = true;\n\tthis.sourceType = 'empty';\n\n\tthis.filters = [];\n\n}\n\nAudio.prototype = Object.assign( Object.create( Object3D.prototype ), {\n\n\tconstructor: Audio,\n\n\tgetOutput: function () {\n\n\t\treturn this.gain;\n\n\t},\n\n\tsetNodeSource: function ( audioNode ) {\n\n\t\tthis.hasPlaybackControl = false;\n\t\tthis.sourceType = 'audioNode';\n\t\tthis.source = audioNode;\n\t\tthis.connect();\n\n\t\treturn this;\n\n\t},\n\n\tsetBuffer: function ( audioBuffer ) {\n\n\t\tthis.buffer = audioBuffer;\n\t\tthis.sourceType = 'buffer';\n\n\t\tif ( this.autoplay ) this.play();\n\n\t\treturn this;\n\n\t},\n\n\tplay: function () {\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: Audio is already playing.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tvar source = this.context.createBufferSource();\n\n\t\tsource.buffer = this.buffer;\n\t\tsource.loop = this.loop;\n\t\tsource.onended = this.onEnded.bind( this );\n\t\tsource.playbackRate.setValueAtTime( this.playbackRate, this.startTime );\n\t\tthis.startTime = this.context.currentTime;\n\t\tsource.start( this.startTime, this.offset );\n\n\t\tthis.isPlaying = true;\n\n\t\tthis.source = source;\n\n\t\treturn this.connect();\n\n\t},\n\n\tpause: function () {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\tthis.source.stop();\n\t\t\tthis.offset += ( this.context.currentTime - this.startTime ) * this.playbackRate;\n\t\t\tthis.isPlaying = false;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tstop: function () {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis.source.stop();\n\t\tthis.offset = 0;\n\t\tthis.isPlaying = false;\n\n\t\treturn this;\n\n\t},\n\n\tconnect: function () {\n\n\t\tif ( this.filters.length > 0 ) {\n\n\t\t\tthis.source.connect( this.filters[ 0 ] );\n\n\t\t\tfor ( var i = 1, l = this.filters.length; i < l; i ++ ) {\n\n\t\t\t\tthis.filters[ i - 1 ].connect( this.filters[ i ] );\n\n\t\t\t}\n\n\t\t\tthis.filters[ this.filters.length - 1 ].connect( this.getOutput() );\n\n\t\t} else {\n\n\t\t\tthis.source.connect( this.getOutput() );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tdisconnect: function () {\n\n\t\tif ( this.filters.length > 0 ) {\n\n\t\t\tthis.source.disconnect( this.filters[ 0 ] );\n\n\t\t\tfor ( var i = 1, l = this.filters.length; i < l; i ++ ) {\n\n\t\t\t\tthis.filters[ i - 1 ].disconnect( this.filters[ i ] );\n\n\t\t\t}\n\n\t\t\tthis.filters[ this.filters.length - 1 ].disconnect( this.getOutput() );\n\n\t\t} else {\n\n\t\t\tthis.source.disconnect( this.getOutput() );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tgetFilters: function () {\n\n\t\treturn this.filters;\n\n\t},\n\n\tsetFilters: function ( value ) {\n\n\t\tif ( ! value ) value = [];\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\tthis.disconnect();\n\t\t\tthis.filters = value;\n\t\t\tthis.connect();\n\n\t\t} else {\n\n\t\t\tthis.filters = value;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tgetFilter: function () {\n\n\t\treturn this.getFilters()[ 0 ];\n\n\t},\n\n\tsetFilter: function ( filter ) {\n\n\t\treturn this.setFilters( filter ? [ filter ] : [] );\n\n\t},\n\n\tsetPlaybackRate: function ( value ) {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis.playbackRate = value;\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\tthis.source.playbackRate.setValueAtTime( this.playbackRate, this.context.currentTime );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tgetPlaybackRate: function () {\n\n\t\treturn this.playbackRate;\n\n\t},\n\n\tonEnded: function () {\n\n\t\tthis.isPlaying = false;\n\n\t},\n\n\tgetLoop: function () {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn false;\n\n\t\t}\n\n\t\treturn this.loop;\n\n\t},\n\n\tsetLoop: function ( value ) {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis.loop = value;\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\tthis.source.loop = this.loop;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tgetVolume: function () {\n\n\t\treturn this.gain.gain.value;\n\n\t},\n\n\tsetVolume: function ( value ) {\n\n\t\tthis.gain.gain.setTargetAtTime( value, this.context.currentTime, 0.01 );\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction PositionalAudio( listener ) {\n\n\tAudio.call( this, listener );\n\n\tthis.panner = this.context.createPanner();\n\tthis.panner.connect( this.gain );\n\n}\n\nPositionalAudio.prototype = Object.assign( Object.create( Audio.prototype ), {\n\n\tconstructor: PositionalAudio,\n\n\tgetOutput: function () {\n\n\t\treturn this.panner;\n\n\t},\n\n\tgetRefDistance: function () {\n\n\t\treturn this.panner.refDistance;\n\n\t},\n\n\tsetRefDistance: function ( value ) {\n\n\t\tthis.panner.refDistance = value;\n\n\t},\n\n\tgetRolloffFactor: function () {\n\n\t\treturn this.panner.rolloffFactor;\n\n\t},\n\n\tsetRolloffFactor: function ( value ) {\n\n\t\tthis.panner.rolloffFactor = value;\n\n\t},\n\n\tgetDistanceModel: function () {\n\n\t\treturn this.panner.distanceModel;\n\n\t},\n\n\tsetDistanceModel: function ( value ) {\n\n\t\tthis.panner.distanceModel = value;\n\n\t},\n\n\tgetMaxDistance: function () {\n\n\t\treturn this.panner.maxDistance;\n\n\t},\n\n\tsetMaxDistance: function ( value ) {\n\n\t\tthis.panner.maxDistance = value;\n\n\t},\n\n\tupdateMatrixWorld: ( function () {\n\n\t\tvar position = new Vector3();\n\n\t\treturn function updateMatrixWorld( force ) {\n\n\t\t\tObject3D.prototype.updateMatrixWorld.call( this, force );\n\n\t\t\tposition.setFromMatrixPosition( this.matrixWorld );\n\n\t\t\tthis.panner.setPosition( position.x, position.y, position.z );\n\n\t\t};\n\n\t} )()\n\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction AudioAnalyser( audio, fftSize ) {\n\n\tthis.analyser = audio.context.createAnalyser();\n\tthis.analyser.fftSize = fftSize !== undefined ? fftSize : 2048;\n\n\tthis.data = new Uint8Array( this.analyser.frequencyBinCount );\n\n\taudio.getOutput().connect( this.analyser );\n\n}\n\nObject.assign( AudioAnalyser.prototype, {\n\n\tgetFrequencyData: function () {\n\n\t\tthis.analyser.getByteFrequencyData( this.data );\n\n\t\treturn this.data;\n\n\t},\n\n\tgetAverageFrequency: function () {\n\n\t\tvar value = 0, data = this.getFrequencyData();\n\n\t\tfor ( var i = 0; i < data.length; i ++ ) {\n\n\t\t\tvalue += data[ i ];\n\n\t\t}\n\n\t\treturn value / data.length;\n\n\t}\n\n} );\n\n/**\n *\n * Buffered scene graph property that allows weighted accumulation.\n *\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\nfunction PropertyMixer( binding, typeName, valueSize ) {\n\n\tthis.binding = binding;\n\tthis.valueSize = valueSize;\n\n\tvar bufferType = Float64Array,\n\t\tmixFunction;\n\n\tswitch ( typeName ) {\n\n\t\tcase 'quaternion':\n\t\t\tmixFunction = this._slerp;\n\t\t\tbreak;\n\n\t\tcase 'string':\n\t\tcase 'bool':\n\t\t\tbufferType = Array;\n\t\t\tmixFunction = this._select;\n\t\t\tbreak;\n\n\t\tdefault:\n\t\t\tmixFunction = this._lerp;\n\n\t}\n\n\tthis.buffer = new bufferType( valueSize * 4 );\n\t// layout: [ incoming | accu0 | accu1 | orig ]\n\t//\n\t// interpolators can use .buffer as their .result\n\t// the data then goes to 'incoming'\n\t//\n\t// 'accu0' and 'accu1' are used frame-interleaved for\n\t// the cumulative result and are compared to detect\n\t// changes\n\t//\n\t// 'orig' stores the original state of the property\n\n\tthis._mixBufferRegion = mixFunction;\n\n\tthis.cumulativeWeight = 0;\n\n\tthis.useCount = 0;\n\tthis.referenceCount = 0;\n\n}\n\nObject.assign( PropertyMixer.prototype, {\n\n\t// accumulate data in the 'incoming' region into 'accu<i>'\n\taccumulate: function ( accuIndex, weight ) {\n\n\t\t// note: happily accumulating nothing when weight = 0, the caller knows\n\t\t// the weight and shouldn't have made the call in the first place\n\n\t\tvar buffer = this.buffer,\n\t\t\tstride = this.valueSize,\n\t\t\toffset = accuIndex * stride + stride,\n\n\t\t\tcurrentWeight = this.cumulativeWeight;\n\n\t\tif ( currentWeight === 0 ) {\n\n\t\t\t// accuN := incoming * weight\n\n\t\t\tfor ( var i = 0; i !== stride; ++ i ) {\n\n\t\t\t\tbuffer[ offset + i ] = buffer[ i ];\n\n\t\t\t}\n\n\t\t\tcurrentWeight = weight;\n\n\t\t} else {\n\n\t\t\t// accuN := accuN + incoming * weight\n\n\t\t\tcurrentWeight += weight;\n\t\t\tvar mix = weight / currentWeight;\n\t\t\tthis._mixBufferRegion( buffer, offset, 0, mix, stride );\n\n\t\t}\n\n\t\tthis.cumulativeWeight = currentWeight;\n\n\t},\n\n\t// apply the state of 'accu<i>' to the binding when accus differ\n\tapply: function ( accuIndex ) {\n\n\t\tvar stride = this.valueSize,\n\t\t\tbuffer = this.buffer,\n\t\t\toffset = accuIndex * stride + stride,\n\n\t\t\tweight = this.cumulativeWeight,\n\n\t\t\tbinding = this.binding;\n\n\t\tthis.cumulativeWeight = 0;\n\n\t\tif ( weight < 1 ) {\n\n\t\t\t// accuN := accuN + original * ( 1 - cumulativeWeight )\n\n\t\t\tvar originalValueOffset = stride * 3;\n\n\t\t\tthis._mixBufferRegion(\n\t\t\t\tbuffer, offset, originalValueOffset, 1 - weight, stride );\n\n\t\t}\n\n\t\tfor ( var i = stride, e = stride + stride; i !== e; ++ i ) {\n\n\t\t\tif ( buffer[ i ] !== buffer[ i + stride ] ) {\n\n\t\t\t\t// value has changed -> update scene graph\n\n\t\t\t\tbinding.setValue( buffer, offset );\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\t// remember the state of the bound property and copy it to both accus\n\tsaveOriginalState: function () {\n\n\t\tvar binding = this.binding;\n\n\t\tvar buffer = this.buffer,\n\t\t\tstride = this.valueSize,\n\n\t\t\toriginalValueOffset = stride * 3;\n\n\t\tbinding.getValue( buffer, originalValueOffset );\n\n\t\t// accu[0..1] := orig -- initially detect changes against the original\n\t\tfor ( var i = stride, e = originalValueOffset; i !== e; ++ i ) {\n\n\t\t\tbuffer[ i ] = buffer[ originalValueOffset + ( i % stride ) ];\n\n\t\t}\n\n\t\tthis.cumulativeWeight = 0;\n\n\t},\n\n\t// apply the state previously taken via 'saveOriginalState' to the binding\n\trestoreOriginalState: function () {\n\n\t\tvar originalValueOffset = this.valueSize * 3;\n\t\tthis.binding.setValue( this.buffer, originalValueOffset );\n\n\t},\n\n\n\t// mix functions\n\n\t_select: function ( buffer, dstOffset, srcOffset, t, stride ) {\n\n\t\tif ( t >= 0.5 ) {\n\n\t\t\tfor ( var i = 0; i !== stride; ++ i ) {\n\n\t\t\t\tbuffer[ dstOffset + i ] = buffer[ srcOffset + i ];\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\t_slerp: function ( buffer, dstOffset, srcOffset, t ) {\n\n\t\tQuaternion.slerpFlat( buffer, dstOffset, buffer, dstOffset, buffer, srcOffset, t );\n\n\t},\n\n\t_lerp: function ( buffer, dstOffset, srcOffset, t, stride ) {\n\n\t\tvar s = 1 - t;\n\n\t\tfor ( var i = 0; i !== stride; ++ i ) {\n\n\t\t\tvar j = dstOffset + i;\n\n\t\t\tbuffer[ j ] = buffer[ j ] * s + buffer[ srcOffset + i ] * t;\n\n\t\t}\n\n\t}\n\n} );\n\n/**\n *\n * A reference to a real property in the scene graph.\n *\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\n// Characters [].:/ are reserved for track binding syntax.\nvar RESERVED_CHARS_RE = '\\\\[\\\\]\\\\.:\\\\/';\n\nfunction Composite( targetGroup, path, optionalParsedPath ) {\n\n\tvar parsedPath = optionalParsedPath || PropertyBinding.parseTrackName( path );\n\n\tthis._targetGroup = targetGroup;\n\tthis._bindings = targetGroup.subscribe_( path, parsedPath );\n\n}\n\nObject.assign( Composite.prototype, {\n\n\tgetValue: function ( array, offset ) {\n\n\t\tthis.bind(); // bind all binding\n\n\t\tvar firstValidIndex = this._targetGroup.nCachedObjects_,\n\t\t\tbinding = this._bindings[ firstValidIndex ];\n\n\t\t// and only call .getValue on the first\n\t\tif ( binding !== undefined ) binding.getValue( array, offset );\n\n\t},\n\n\tsetValue: function ( array, offset ) {\n\n\t\tvar bindings = this._bindings;\n\n\t\tfor ( var i = this._targetGroup.nCachedObjects_,\n\t\t\t\t  n = bindings.length; i !== n; ++ i ) {\n\n\t\t\tbindings[ i ].setValue( array, offset );\n\n\t\t}\n\n\t},\n\n\tbind: function () {\n\n\t\tvar bindings = this._bindings;\n\n\t\tfor ( var i = this._targetGroup.nCachedObjects_,\n\t\t\t\t  n = bindings.length; i !== n; ++ i ) {\n\n\t\t\tbindings[ i ].bind();\n\n\t\t}\n\n\t},\n\n\tunbind: function () {\n\n\t\tvar bindings = this._bindings;\n\n\t\tfor ( var i = this._targetGroup.nCachedObjects_,\n\t\t\t\t  n = bindings.length; i !== n; ++ i ) {\n\n\t\t\tbindings[ i ].unbind();\n\n\t\t}\n\n\t}\n\n} );\n\n\nfunction PropertyBinding( rootNode, path, parsedPath ) {\n\n\tthis.path = path;\n\tthis.parsedPath = parsedPath || PropertyBinding.parseTrackName( path );\n\n\tthis.node = PropertyBinding.findNode( rootNode, this.parsedPath.nodeName ) || rootNode;\n\n\tthis.rootNode = rootNode;\n\n}\n\nObject.assign( PropertyBinding, {\n\n\tComposite: Composite,\n\n\tcreate: function ( root, path, parsedPath ) {\n\n\t\tif ( ! ( root && root.isAnimationObjectGroup ) ) {\n\n\t\t\treturn new PropertyBinding( root, path, parsedPath );\n\n\t\t} else {\n\n\t\t\treturn new PropertyBinding.Composite( root, path, parsedPath );\n\n\t\t}\n\n\t},\n\n\t/**\n\t * Replaces spaces with underscores and removes unsupported characters from\n\t * node names, to ensure compatibility with parseTrackName().\n\t *\n\t * @param  {string} name Node name to be sanitized.\n\t * @return {string}\n\t */\n\tsanitizeNodeName: ( function () {\n\n\t\tvar reservedRe = new RegExp( '[' + RESERVED_CHARS_RE + ']', 'g' );\n\n\t\treturn function sanitizeNodeName( name ) {\n\n\t\t\treturn name.replace( /\\s/g, '_' ).replace( reservedRe, '' );\n\n\t\t};\n\n\t}() ),\n\n\tparseTrackName: function () {\n\n\t\t// Attempts to allow node names from any language. ES5's `\\w` regexp matches\n\t\t// only latin characters, and the unicode \\p{L} is not yet supported. So\n\t\t// instead, we exclude reserved characters and match everything else.\n\t\tvar wordChar = '[^' + RESERVED_CHARS_RE + ']';\n\t\tvar wordCharOrDot = '[^' + RESERVED_CHARS_RE.replace( '\\\\.', '' ) + ']';\n\n\t\t// Parent directories, delimited by '/' or ':'. Currently unused, but must\n\t\t// be matched to parse the rest of the track name.\n\t\tvar directoryRe = /((?:WC+[\\/:])*)/.source.replace( 'WC', wordChar );\n\n\t\t// Target node. May contain word characters (a-zA-Z0-9_) and '.' or '-'.\n\t\tvar nodeRe = /(WCOD+)?/.source.replace( 'WCOD', wordCharOrDot );\n\n\t\t// Object on target node, and accessor. May not contain reserved\n\t\t// characters. Accessor may contain any character except closing bracket.\n\t\tvar objectRe = /(?:\\.(WC+)(?:\\[(.+)\\])?)?/.source.replace( 'WC', wordChar );\n\n\t\t// Property and accessor. May not contain reserved characters. Accessor may\n\t\t// contain any non-bracket characters.\n\t\tvar propertyRe = /\\.(WC+)(?:\\[(.+)\\])?/.source.replace( 'WC', wordChar );\n\n\t\tvar trackRe = new RegExp( ''\n\t\t\t+ '^'\n\t\t\t+ directoryRe\n\t\t\t+ nodeRe\n\t\t\t+ objectRe\n\t\t\t+ propertyRe\n\t\t\t+ '$'\n\t\t);\n\n\t\tvar supportedObjectNames = [ 'material', 'materials', 'bones' ];\n\n\t\treturn function parseTrackName( trackName ) {\n\n\t\t\tvar matches = trackRe.exec( trackName );\n\n\t\t\tif ( ! matches ) {\n\n\t\t\t\tthrow new Error( 'PropertyBinding: Cannot parse trackName: ' + trackName );\n\n\t\t\t}\n\n\t\t\tvar results = {\n\t\t\t\t// directoryName: matches[ 1 ], // (tschw) currently unused\n\t\t\t\tnodeName: matches[ 2 ],\n\t\t\t\tobjectName: matches[ 3 ],\n\t\t\t\tobjectIndex: matches[ 4 ],\n\t\t\t\tpropertyName: matches[ 5 ], // required\n\t\t\t\tpropertyIndex: matches[ 6 ]\n\t\t\t};\n\n\t\t\tvar lastDot = results.nodeName && results.nodeName.lastIndexOf( '.' );\n\n\t\t\tif ( lastDot !== undefined && lastDot !== - 1 ) {\n\n\t\t\t\tvar objectName = results.nodeName.substring( lastDot + 1 );\n\n\t\t\t\t// Object names must be checked against a whitelist. Otherwise, there\n\t\t\t\t// is no way to parse 'foo.bar.baz': 'baz' must be a property, but\n\t\t\t\t// 'bar' could be the objectName, or part of a nodeName (which can\n\t\t\t\t// include '.' characters).\n\t\t\t\tif ( supportedObjectNames.indexOf( objectName ) !== - 1 ) {\n\n\t\t\t\t\tresults.nodeName = results.nodeName.substring( 0, lastDot );\n\t\t\t\t\tresults.objectName = objectName;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( results.propertyName === null || results.propertyName.length === 0 ) {\n\n\t\t\t\tthrow new Error( 'PropertyBinding: can not parse propertyName from trackName: ' + trackName );\n\n\t\t\t}\n\n\t\t\treturn results;\n\n\t\t};\n\n\t}(),\n\n\tfindNode: function ( root, nodeName ) {\n\n\t\tif ( ! nodeName || nodeName === \"\" || nodeName === \"root\" || nodeName === \".\" || nodeName === - 1 || nodeName === root.name || nodeName === root.uuid ) {\n\n\t\t\treturn root;\n\n\t\t}\n\n\t\t// search into skeleton bones.\n\t\tif ( root.skeleton ) {\n\n\t\t\tvar bone = root.skeleton.getBoneByName( nodeName );\n\n\t\t\tif ( bone !== undefined ) {\n\n\t\t\t\treturn bone;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// search into node subtree.\n\t\tif ( root.children ) {\n\n\t\t\tvar searchNodeSubtree = function ( children ) {\n\n\t\t\t\tfor ( var i = 0; i < children.length; i ++ ) {\n\n\t\t\t\t\tvar childNode = children[ i ];\n\n\t\t\t\t\tif ( childNode.name === nodeName || childNode.uuid === nodeName ) {\n\n\t\t\t\t\t\treturn childNode;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tvar result = searchNodeSubtree( childNode.children );\n\n\t\t\t\t\tif ( result ) return result;\n\n\t\t\t\t}\n\n\t\t\t\treturn null;\n\n\t\t\t};\n\n\t\t\tvar subTreeNode = searchNodeSubtree( root.children );\n\n\t\t\tif ( subTreeNode ) {\n\n\t\t\t\treturn subTreeNode;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn null;\n\n\t}\n\n} );\n\nObject.assign( PropertyBinding.prototype, { // prototype, continued\n\n\t// these are used to \"bind\" a nonexistent property\n\t_getValue_unavailable: function () {},\n\t_setValue_unavailable: function () {},\n\n\tBindingType: {\n\t\tDirect: 0,\n\t\tEntireArray: 1,\n\t\tArrayElement: 2,\n\t\tHasFromToArray: 3\n\t},\n\n\tVersioning: {\n\t\tNone: 0,\n\t\tNeedsUpdate: 1,\n\t\tMatrixWorldNeedsUpdate: 2\n\t},\n\n\tGetterByBindingType: [\n\n\t\tfunction getValue_direct( buffer, offset ) {\n\n\t\t\tbuffer[ offset ] = this.node[ this.propertyName ];\n\n\t\t},\n\n\t\tfunction getValue_array( buffer, offset ) {\n\n\t\t\tvar source = this.resolvedProperty;\n\n\t\t\tfor ( var i = 0, n = source.length; i !== n; ++ i ) {\n\n\t\t\t\tbuffer[ offset ++ ] = source[ i ];\n\n\t\t\t}\n\n\t\t},\n\n\t\tfunction getValue_arrayElement( buffer, offset ) {\n\n\t\t\tbuffer[ offset ] = this.resolvedProperty[ this.propertyIndex ];\n\n\t\t},\n\n\t\tfunction getValue_toArray( buffer, offset ) {\n\n\t\t\tthis.resolvedProperty.toArray( buffer, offset );\n\n\t\t}\n\n\t],\n\n\tSetterByBindingTypeAndVersioning: [\n\n\t\t[\n\t\t\t// Direct\n\n\t\t\tfunction setValue_direct( buffer, offset ) {\n\n\t\t\t\tthis.targetObject[ this.propertyName ] = buffer[ offset ];\n\n\t\t\t},\n\n\t\t\tfunction setValue_direct_setNeedsUpdate( buffer, offset ) {\n\n\t\t\t\tthis.targetObject[ this.propertyName ] = buffer[ offset ];\n\t\t\t\tthis.targetObject.needsUpdate = true;\n\n\t\t\t},\n\n\t\t\tfunction setValue_direct_setMatrixWorldNeedsUpdate( buffer, offset ) {\n\n\t\t\t\tthis.targetObject[ this.propertyName ] = buffer[ offset ];\n\t\t\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\n\t\t\t}\n\n\t\t], [\n\n\t\t\t// EntireArray\n\n\t\t\tfunction setValue_array( buffer, offset ) {\n\n\t\t\t\tvar dest = this.resolvedProperty;\n\n\t\t\t\tfor ( var i = 0, n = dest.length; i !== n; ++ i ) {\n\n\t\t\t\t\tdest[ i ] = buffer[ offset ++ ];\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tfunction setValue_array_setNeedsUpdate( buffer, offset ) {\n\n\t\t\t\tvar dest = this.resolvedProperty;\n\n\t\t\t\tfor ( var i = 0, n = dest.length; i !== n; ++ i ) {\n\n\t\t\t\t\tdest[ i ] = buffer[ offset ++ ];\n\n\t\t\t\t}\n\n\t\t\t\tthis.targetObject.needsUpdate = true;\n\n\t\t\t},\n\n\t\t\tfunction setValue_array_setMatrixWorldNeedsUpdate( buffer, offset ) {\n\n\t\t\t\tvar dest = this.resolvedProperty;\n\n\t\t\t\tfor ( var i = 0, n = dest.length; i !== n; ++ i ) {\n\n\t\t\t\t\tdest[ i ] = buffer[ offset ++ ];\n\n\t\t\t\t}\n\n\t\t\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\n\t\t\t}\n\n\t\t], [\n\n\t\t\t// ArrayElement\n\n\t\t\tfunction setValue_arrayElement( buffer, offset ) {\n\n\t\t\t\tthis.resolvedProperty[ this.propertyIndex ] = buffer[ offset ];\n\n\t\t\t},\n\n\t\t\tfunction setValue_arrayElement_setNeedsUpdate( buffer, offset ) {\n\n\t\t\t\tthis.resolvedProperty[ this.propertyIndex ] = buffer[ offset ];\n\t\t\t\tthis.targetObject.needsUpdate = true;\n\n\t\t\t},\n\n\t\t\tfunction setValue_arrayElement_setMatrixWorldNeedsUpdate( buffer, offset ) {\n\n\t\t\t\tthis.resolvedProperty[ this.propertyIndex ] = buffer[ offset ];\n\t\t\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\n\t\t\t}\n\n\t\t], [\n\n\t\t\t// HasToFromArray\n\n\t\t\tfunction setValue_fromArray( buffer, offset ) {\n\n\t\t\t\tthis.resolvedProperty.fromArray( buffer, offset );\n\n\t\t\t},\n\n\t\t\tfunction setValue_fromArray_setNeedsUpdate( buffer, offset ) {\n\n\t\t\t\tthis.resolvedProperty.fromArray( buffer, offset );\n\t\t\t\tthis.targetObject.needsUpdate = true;\n\n\t\t\t},\n\n\t\t\tfunction setValue_fromArray_setMatrixWorldNeedsUpdate( buffer, offset ) {\n\n\t\t\t\tthis.resolvedProperty.fromArray( buffer, offset );\n\t\t\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\n\t\t\t}\n\n\t\t]\n\n\t],\n\n\tgetValue: function getValue_unbound( targetArray, offset ) {\n\n\t\tthis.bind();\n\t\tthis.getValue( targetArray, offset );\n\n\t\t// Note: This class uses a State pattern on a per-method basis:\n\t\t// 'bind' sets 'this.getValue' / 'setValue' and shadows the\n\t\t// prototype version of these methods with one that represents\n\t\t// the bound state. When the property is not found, the methods\n\t\t// become no-ops.\n\n\t},\n\n\tsetValue: function getValue_unbound( sourceArray, offset ) {\n\n\t\tthis.bind();\n\t\tthis.setValue( sourceArray, offset );\n\n\t},\n\n\t// create getter / setter pair for a property in the scene graph\n\tbind: function () {\n\n\t\tvar targetObject = this.node,\n\t\t\tparsedPath = this.parsedPath,\n\n\t\t\tobjectName = parsedPath.objectName,\n\t\t\tpropertyName = parsedPath.propertyName,\n\t\t\tpropertyIndex = parsedPath.propertyIndex;\n\n\t\tif ( ! targetObject ) {\n\n\t\t\ttargetObject = PropertyBinding.findNode( this.rootNode, parsedPath.nodeName ) || this.rootNode;\n\n\t\t\tthis.node = targetObject;\n\n\t\t}\n\n\t\t// set fail state so we can just 'return' on error\n\t\tthis.getValue = this._getValue_unavailable;\n\t\tthis.setValue = this._setValue_unavailable;\n\n\t\t// ensure there is a value node\n\t\tif ( ! targetObject ) {\n\n\t\t\tconsole.error( 'THREE.PropertyBinding: Trying to update node for track: ' + this.path + ' but it wasn\\'t found.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( objectName ) {\n\n\t\t\tvar objectIndex = parsedPath.objectIndex;\n\n\t\t\t// special cases were we need to reach deeper into the hierarchy to get the face materials....\n\t\t\tswitch ( objectName ) {\n\n\t\t\t\tcase 'materials':\n\n\t\t\t\t\tif ( ! targetObject.material ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to material as node does not have a material.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( ! targetObject.material.materials ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttargetObject = targetObject.material.materials;\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'bones':\n\n\t\t\t\t\tif ( ! targetObject.skeleton ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// potential future optimization: skip this if propertyIndex is already an integer\n\t\t\t\t\t// and convert the integer string to a true integer.\n\n\t\t\t\t\ttargetObject = targetObject.skeleton.bones;\n\n\t\t\t\t\t// support resolving morphTarget names into indices.\n\t\t\t\t\tfor ( var i = 0; i < targetObject.length; i ++ ) {\n\n\t\t\t\t\t\tif ( targetObject[ i ].name === objectIndex ) {\n\n\t\t\t\t\t\t\tobjectIndex = i;\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\n\t\t\t\t\tif ( targetObject[ objectName ] === undefined ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to objectName of node undefined.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttargetObject = targetObject[ objectName ];\n\n\t\t\t}\n\n\n\t\t\tif ( objectIndex !== undefined ) {\n\n\t\t\t\tif ( targetObject[ objectIndex ] === undefined ) {\n\n\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.', this, targetObject );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\ttargetObject = targetObject[ objectIndex ];\n\n\t\t\t}\n\n\t\t}\n\n\t\t// resolve property\n\t\tvar nodeProperty = targetObject[ propertyName ];\n\n\t\tif ( nodeProperty === undefined ) {\n\n\t\t\tvar nodeName = parsedPath.nodeName;\n\n\t\t\tconsole.error( 'THREE.PropertyBinding: Trying to update property for track: ' + nodeName +\n\t\t\t\t'.' + propertyName + ' but it wasn\\'t found.', targetObject );\n\t\t\treturn;\n\n\t\t}\n\n\t\t// determine versioning scheme\n\t\tvar versioning = this.Versioning.None;\n\n\t\tif ( targetObject.needsUpdate !== undefined ) { // material\n\n\t\t\tversioning = this.Versioning.NeedsUpdate;\n\t\t\tthis.targetObject = targetObject;\n\n\t\t} else if ( targetObject.matrixWorldNeedsUpdate !== undefined ) { // node transform\n\n\t\t\tversioning = this.Versioning.MatrixWorldNeedsUpdate;\n\t\t\tthis.targetObject = targetObject;\n\n\t\t}\n\n\t\t// determine how the property gets bound\n\t\tvar bindingType = this.BindingType.Direct;\n\n\t\tif ( propertyIndex !== undefined ) {\n\n\t\t\t// access a sub element of the property array (only primitives are supported right now)\n\n\t\t\tif ( propertyName === \"morphTargetInfluences\" ) {\n\n\t\t\t\t// potential optimization, skip this if propertyIndex is already an integer, and convert the integer string to a true integer.\n\n\t\t\t\t// support resolving morphTarget names into indices.\n\t\t\t\tif ( ! targetObject.geometry ) {\n\n\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.', this );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\tif ( targetObject.geometry.isBufferGeometry ) {\n\n\t\t\t\t\tif ( ! targetObject.geometry.morphAttributes ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tfor ( var i = 0; i < this.node.geometry.morphAttributes.position.length; i ++ ) {\n\n\t\t\t\t\t\tif ( targetObject.geometry.morphAttributes.position[ i ].name === propertyIndex ) {\n\n\t\t\t\t\t\t\tpropertyIndex = i;\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( ! targetObject.geometry.morphTargets ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphTargets.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tfor ( var i = 0; i < this.node.geometry.morphTargets.length; i ++ ) {\n\n\t\t\t\t\t\tif ( targetObject.geometry.morphTargets[ i ].name === propertyIndex ) {\n\n\t\t\t\t\t\t\tpropertyIndex = i;\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tbindingType = this.BindingType.ArrayElement;\n\n\t\t\tthis.resolvedProperty = nodeProperty;\n\t\t\tthis.propertyIndex = propertyIndex;\n\n\t\t} else if ( nodeProperty.fromArray !== undefined && nodeProperty.toArray !== undefined ) {\n\n\t\t\t// must use copy for Object3D.Euler/Quaternion\n\n\t\t\tbindingType = this.BindingType.HasFromToArray;\n\n\t\t\tthis.resolvedProperty = nodeProperty;\n\n\t\t} else if ( Array.isArray( nodeProperty ) ) {\n\n\t\t\tbindingType = this.BindingType.EntireArray;\n\n\t\t\tthis.resolvedProperty = nodeProperty;\n\n\t\t} else {\n\n\t\t\tthis.propertyName = propertyName;\n\n\t\t}\n\n\t\t// select getter / setter\n\t\tthis.getValue = this.GetterByBindingType[ bindingType ];\n\t\tthis.setValue = this.SetterByBindingTypeAndVersioning[ bindingType ][ versioning ];\n\n\t},\n\n\tunbind: function () {\n\n\t\tthis.node = null;\n\n\t\t// back to the prototype version of getValue / setValue\n\t\t// note: avoiding to mutate the shape of 'this' via 'delete'\n\t\tthis.getValue = this._getValue_unbound;\n\t\tthis.setValue = this._setValue_unbound;\n\n\t}\n\n} );\n\n//!\\ DECLARE ALIAS AFTER assign prototype !\nObject.assign( PropertyBinding.prototype, {\n\n\t// initial state of these methods that calls 'bind'\n\t_getValue_unbound: PropertyBinding.prototype.getValue,\n\t_setValue_unbound: PropertyBinding.prototype.setValue,\n\n} );\n\n/**\n *\n * A group of objects that receives a shared animation state.\n *\n * Usage:\n *\n * \t-\tAdd objects you would otherwise pass as 'root' to the\n * \t\tconstructor or the .clipAction method of AnimationMixer.\n *\n * \t-\tInstead pass this object as 'root'.\n *\n * \t-\tYou can also add and remove objects later when the mixer\n * \t\tis running.\n *\n * Note:\n *\n *  \tObjects of this class appear as one object to the mixer,\n *  \tso cache control of the individual objects must be done\n *  \ton the group.\n *\n * Limitation:\n *\n * \t- \tThe animated properties must be compatible among the\n * \t\tall objects in the group.\n *\n *  -\tA single property can either be controlled through a\n *  \ttarget group or directly, but not both.\n *\n * @author tschw\n */\n\nfunction AnimationObjectGroup() {\n\n\tthis.uuid = _Math.generateUUID();\n\n\t// cached objects followed by the active ones\n\tthis._objects = Array.prototype.slice.call( arguments );\n\n\tthis.nCachedObjects_ = 0;\t\t\t// threshold\n\t// note: read by PropertyBinding.Composite\n\n\tvar indices = {};\n\tthis._indicesByUUID = indices;\t\t// for bookkeeping\n\n\tfor ( var i = 0, n = arguments.length; i !== n; ++ i ) {\n\n\t\tindices[ arguments[ i ].uuid ] = i;\n\n\t}\n\n\tthis._paths = [];\t\t\t\t\t// inside: string\n\tthis._parsedPaths = [];\t\t\t\t// inside: { we don't care, here }\n\tthis._bindings = []; \t\t\t\t// inside: Array< PropertyBinding >\n\tthis._bindingsIndicesByPath = {}; \t// inside: indices in these arrays\n\n\tvar scope = this;\n\n\tthis.stats = {\n\n\t\tobjects: {\n\t\t\tget total() {\n\n\t\t\t\treturn scope._objects.length;\n\n\t\t\t},\n\t\t\tget inUse() {\n\n\t\t\t\treturn this.total - scope.nCachedObjects_;\n\n\t\t\t}\n\t\t},\n\t\tget bindingsPerObject() {\n\n\t\t\treturn scope._bindings.length;\n\n\t\t}\n\n\t};\n\n}\n\nObject.assign( AnimationObjectGroup.prototype, {\n\n\tisAnimationObjectGroup: true,\n\n\tadd: function () {\n\n\t\tvar objects = this._objects,\n\t\t\tnObjects = objects.length,\n\t\t\tnCachedObjects = this.nCachedObjects_,\n\t\t\tindicesByUUID = this._indicesByUUID,\n\t\t\tpaths = this._paths,\n\t\t\tparsedPaths = this._parsedPaths,\n\t\t\tbindings = this._bindings,\n\t\t\tnBindings = bindings.length,\n\t\t\tknownObject = undefined;\n\n\t\tfor ( var i = 0, n = arguments.length; i !== n; ++ i ) {\n\n\t\t\tvar object = arguments[ i ],\n\t\t\t\tuuid = object.uuid,\n\t\t\t\tindex = indicesByUUID[ uuid ];\n\n\t\t\tif ( index === undefined ) {\n\n\t\t\t\t// unknown object -> add it to the ACTIVE region\n\n\t\t\t\tindex = nObjects ++;\n\t\t\t\tindicesByUUID[ uuid ] = index;\n\t\t\t\tobjects.push( object );\n\n\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\tfor ( var j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\tbindings[ j ].push( new PropertyBinding( object, paths[ j ], parsedPaths[ j ] ) );\n\n\t\t\t\t}\n\n\t\t\t} else if ( index < nCachedObjects ) {\n\n\t\t\t\tknownObject = objects[ index ];\n\n\t\t\t\t// move existing object to the ACTIVE region\n\n\t\t\t\tvar firstActiveIndex = -- nCachedObjects,\n\t\t\t\t\tlastCachedObject = objects[ firstActiveIndex ];\n\n\t\t\t\tindicesByUUID[ lastCachedObject.uuid ] = index;\n\t\t\t\tobjects[ index ] = lastCachedObject;\n\n\t\t\t\tindicesByUUID[ uuid ] = firstActiveIndex;\n\t\t\t\tobjects[ firstActiveIndex ] = object;\n\n\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\tfor ( var j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\tvar bindingsForPath = bindings[ j ],\n\t\t\t\t\t\tlastCached = bindingsForPath[ firstActiveIndex ],\n\t\t\t\t\t\tbinding = bindingsForPath[ index ];\n\n\t\t\t\t\tbindingsForPath[ index ] = lastCached;\n\n\t\t\t\t\tif ( binding === undefined ) {\n\n\t\t\t\t\t\t// since we do not bother to create new bindings\n\t\t\t\t\t\t// for objects that are cached, the binding may\n\t\t\t\t\t\t// or may not exist\n\n\t\t\t\t\t\tbinding = new PropertyBinding( object, paths[ j ], parsedPaths[ j ] );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbindingsForPath[ firstActiveIndex ] = binding;\n\n\t\t\t\t}\n\n\t\t\t} else if ( objects[ index ] !== knownObject ) {\n\n\t\t\t\tconsole.error( 'THREE.AnimationObjectGroup: Different objects with the same UUID ' +\n\t\t\t\t\t\t'detected. Clean the caches or recreate your infrastructure when reloading scenes.' );\n\n\t\t\t} // else the object is already where we want it to be\n\n\t\t} // for arguments\n\n\t\tthis.nCachedObjects_ = nCachedObjects;\n\n\t},\n\n\tremove: function () {\n\n\t\tvar objects = this._objects,\n\t\t\tnCachedObjects = this.nCachedObjects_,\n\t\t\tindicesByUUID = this._indicesByUUID,\n\t\t\tbindings = this._bindings,\n\t\t\tnBindings = bindings.length;\n\n\t\tfor ( var i = 0, n = arguments.length; i !== n; ++ i ) {\n\n\t\t\tvar object = arguments[ i ],\n\t\t\t\tuuid = object.uuid,\n\t\t\t\tindex = indicesByUUID[ uuid ];\n\n\t\t\tif ( index !== undefined && index >= nCachedObjects ) {\n\n\t\t\t\t// move existing object into the CACHED region\n\n\t\t\t\tvar lastCachedIndex = nCachedObjects ++,\n\t\t\t\t\tfirstActiveObject = objects[ lastCachedIndex ];\n\n\t\t\t\tindicesByUUID[ firstActiveObject.uuid ] = index;\n\t\t\t\tobjects[ index ] = firstActiveObject;\n\n\t\t\t\tindicesByUUID[ uuid ] = lastCachedIndex;\n\t\t\t\tobjects[ lastCachedIndex ] = object;\n\n\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\tfor ( var j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\tvar bindingsForPath = bindings[ j ],\n\t\t\t\t\t\tfirstActive = bindingsForPath[ lastCachedIndex ],\n\t\t\t\t\t\tbinding = bindingsForPath[ index ];\n\n\t\t\t\t\tbindingsForPath[ index ] = firstActive;\n\t\t\t\t\tbindingsForPath[ lastCachedIndex ] = binding;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} // for arguments\n\n\t\tthis.nCachedObjects_ = nCachedObjects;\n\n\t},\n\n\t// remove & forget\n\tuncache: function () {\n\n\t\tvar objects = this._objects,\n\t\t\tnObjects = objects.length,\n\t\t\tnCachedObjects = this.nCachedObjects_,\n\t\t\tindicesByUUID = this._indicesByUUID,\n\t\t\tbindings = this._bindings,\n\t\t\tnBindings = bindings.length;\n\n\t\tfor ( var i = 0, n = arguments.length; i !== n; ++ i ) {\n\n\t\t\tvar object = arguments[ i ],\n\t\t\t\tuuid = object.uuid,\n\t\t\t\tindex = indicesByUUID[ uuid ];\n\n\t\t\tif ( index !== undefined ) {\n\n\t\t\t\tdelete indicesByUUID[ uuid ];\n\n\t\t\t\tif ( index < nCachedObjects ) {\n\n\t\t\t\t\t// object is cached, shrink the CACHED region\n\n\t\t\t\t\tvar firstActiveIndex = -- nCachedObjects,\n\t\t\t\t\t\tlastCachedObject = objects[ firstActiveIndex ],\n\t\t\t\t\t\tlastIndex = -- nObjects,\n\t\t\t\t\t\tlastObject = objects[ lastIndex ];\n\n\t\t\t\t\t// last cached object takes this object's place\n\t\t\t\t\tindicesByUUID[ lastCachedObject.uuid ] = index;\n\t\t\t\t\tobjects[ index ] = lastCachedObject;\n\n\t\t\t\t\t// last object goes to the activated slot and pop\n\t\t\t\t\tindicesByUUID[ lastObject.uuid ] = firstActiveIndex;\n\t\t\t\t\tobjects[ firstActiveIndex ] = lastObject;\n\t\t\t\t\tobjects.pop();\n\n\t\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\t\tfor ( var j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\t\tvar bindingsForPath = bindings[ j ],\n\t\t\t\t\t\t\tlastCached = bindingsForPath[ firstActiveIndex ],\n\t\t\t\t\t\t\tlast = bindingsForPath[ lastIndex ];\n\n\t\t\t\t\t\tbindingsForPath[ index ] = lastCached;\n\t\t\t\t\t\tbindingsForPath[ firstActiveIndex ] = last;\n\t\t\t\t\t\tbindingsForPath.pop();\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// object is active, just swap with the last and pop\n\n\t\t\t\t\tvar lastIndex = -- nObjects,\n\t\t\t\t\t\tlastObject = objects[ lastIndex ];\n\n\t\t\t\t\tindicesByUUID[ lastObject.uuid ] = index;\n\t\t\t\t\tobjects[ index ] = lastObject;\n\t\t\t\t\tobjects.pop();\n\n\t\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\t\tfor ( var j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\t\tvar bindingsForPath = bindings[ j ];\n\n\t\t\t\t\t\tbindingsForPath[ index ] = bindingsForPath[ lastIndex ];\n\t\t\t\t\t\tbindingsForPath.pop();\n\n\t\t\t\t\t}\n\n\t\t\t\t} // cached or active\n\n\t\t\t} // if object is known\n\n\t\t} // for arguments\n\n\t\tthis.nCachedObjects_ = nCachedObjects;\n\n\t},\n\n\t// Internal interface used by befriended PropertyBinding.Composite:\n\n\tsubscribe_: function ( path, parsedPath ) {\n\n\t\t// returns an array of bindings for the given path that is changed\n\t\t// according to the contained objects in the group\n\n\t\tvar indicesByPath = this._bindingsIndicesByPath,\n\t\t\tindex = indicesByPath[ path ],\n\t\t\tbindings = this._bindings;\n\n\t\tif ( index !== undefined ) return bindings[ index ];\n\n\t\tvar paths = this._paths,\n\t\t\tparsedPaths = this._parsedPaths,\n\t\t\tobjects = this._objects,\n\t\t\tnObjects = objects.length,\n\t\t\tnCachedObjects = this.nCachedObjects_,\n\t\t\tbindingsForPath = new Array( nObjects );\n\n\t\tindex = bindings.length;\n\n\t\tindicesByPath[ path ] = index;\n\n\t\tpaths.push( path );\n\t\tparsedPaths.push( parsedPath );\n\t\tbindings.push( bindingsForPath );\n\n\t\tfor ( var i = nCachedObjects, n = objects.length; i !== n; ++ i ) {\n\n\t\t\tvar object = objects[ i ];\n\t\t\tbindingsForPath[ i ] = new PropertyBinding( object, path, parsedPath );\n\n\t\t}\n\n\t\treturn bindingsForPath;\n\n\t},\n\n\tunsubscribe_: function ( path ) {\n\n\t\t// tells the group to forget about a property path and no longer\n\t\t// update the array previously obtained with 'subscribe_'\n\n\t\tvar indicesByPath = this._bindingsIndicesByPath,\n\t\t\tindex = indicesByPath[ path ];\n\n\t\tif ( index !== undefined ) {\n\n\t\t\tvar paths = this._paths,\n\t\t\t\tparsedPaths = this._parsedPaths,\n\t\t\t\tbindings = this._bindings,\n\t\t\t\tlastBindingsIndex = bindings.length - 1,\n\t\t\t\tlastBindings = bindings[ lastBindingsIndex ],\n\t\t\t\tlastBindingsPath = path[ lastBindingsIndex ];\n\n\t\t\tindicesByPath[ lastBindingsPath ] = index;\n\n\t\t\tbindings[ index ] = lastBindings;\n\t\t\tbindings.pop();\n\n\t\t\tparsedPaths[ index ] = parsedPaths[ lastBindingsIndex ];\n\t\t\tparsedPaths.pop();\n\n\t\t\tpaths[ index ] = paths[ lastBindingsIndex ];\n\t\t\tpaths.pop();\n\n\t\t}\n\n\t}\n\n} );\n\n/**\n *\n * Action provided by AnimationMixer for scheduling clip playback on specific\n * objects.\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n *\n */\n\nfunction AnimationAction( mixer, clip, localRoot ) {\n\n\tthis._mixer = mixer;\n\tthis._clip = clip;\n\tthis._localRoot = localRoot || null;\n\n\tvar tracks = clip.tracks,\n\t\tnTracks = tracks.length,\n\t\tinterpolants = new Array( nTracks );\n\n\tvar interpolantSettings = {\n\t\tendingStart: ZeroCurvatureEnding,\n\t\tendingEnd: ZeroCurvatureEnding\n\t};\n\n\tfor ( var i = 0; i !== nTracks; ++ i ) {\n\n\t\tvar interpolant = tracks[ i ].createInterpolant( null );\n\t\tinterpolants[ i ] = interpolant;\n\t\tinterpolant.settings = interpolantSettings;\n\n\t}\n\n\tthis._interpolantSettings = interpolantSettings;\n\n\tthis._interpolants = interpolants;\t// bound by the mixer\n\n\t// inside: PropertyMixer (managed by the mixer)\n\tthis._propertyBindings = new Array( nTracks );\n\n\tthis._cacheIndex = null;\t\t\t// for the memory manager\n\tthis._byClipCacheIndex = null;\t\t// for the memory manager\n\n\tthis._timeScaleInterpolant = null;\n\tthis._weightInterpolant = null;\n\n\tthis.loop = LoopRepeat;\n\tthis._loopCount = - 1;\n\n\t// global mixer time when the action is to be started\n\t// it's set back to 'null' upon start of the action\n\tthis._startTime = null;\n\n\t// scaled local time of the action\n\t// gets clamped or wrapped to 0..clip.duration according to loop\n\tthis.time = 0;\n\n\tthis.timeScale = 1;\n\tthis._effectiveTimeScale = 1;\n\n\tthis.weight = 1;\n\tthis._effectiveWeight = 1;\n\n\tthis.repetitions = Infinity; \t\t// no. of repetitions when looping\n\n\tthis.paused = false;\t\t\t\t// true -> zero effective time scale\n\tthis.enabled = true;\t\t\t\t// false -> zero effective weight\n\n\tthis.clampWhenFinished \t= false;\t// keep feeding the last frame?\n\n\tthis.zeroSlopeAtStart \t= true;\t\t// for smooth interpolation w/o separate\n\tthis.zeroSlopeAtEnd\t\t= true;\t\t// clips for start, loop and end\n\n}\n\nObject.assign( AnimationAction.prototype, {\n\n\t// State & Scheduling\n\n\tplay: function () {\n\n\t\tthis._mixer._activateAction( this );\n\n\t\treturn this;\n\n\t},\n\n\tstop: function () {\n\n\t\tthis._mixer._deactivateAction( this );\n\n\t\treturn this.reset();\n\n\t},\n\n\treset: function () {\n\n\t\tthis.paused = false;\n\t\tthis.enabled = true;\n\n\t\tthis.time = 0;\t\t\t// restart clip\n\t\tthis._loopCount = - 1;\t// forget previous loops\n\t\tthis._startTime = null;\t// forget scheduling\n\n\t\treturn this.stopFading().stopWarping();\n\n\t},\n\n\tisRunning: function () {\n\n\t\treturn this.enabled && ! this.paused && this.timeScale !== 0 &&\n\t\t\t\tthis._startTime === null && this._mixer._isActiveAction( this );\n\n\t},\n\n\t// return true when play has been called\n\tisScheduled: function () {\n\n\t\treturn this._mixer._isActiveAction( this );\n\n\t},\n\n\tstartAt: function ( time ) {\n\n\t\tthis._startTime = time;\n\n\t\treturn this;\n\n\t},\n\n\tsetLoop: function ( mode, repetitions ) {\n\n\t\tthis.loop = mode;\n\t\tthis.repetitions = repetitions;\n\n\t\treturn this;\n\n\t},\n\n\t// Weight\n\n\t// set the weight stopping any scheduled fading\n\t// although .enabled = false yields an effective weight of zero, this\n\t// method does *not* change .enabled, because it would be confusing\n\tsetEffectiveWeight: function ( weight ) {\n\n\t\tthis.weight = weight;\n\n\t\t// note: same logic as when updated at runtime\n\t\tthis._effectiveWeight = this.enabled ? weight : 0;\n\n\t\treturn this.stopFading();\n\n\t},\n\n\t// return the weight considering fading and .enabled\n\tgetEffectiveWeight: function () {\n\n\t\treturn this._effectiveWeight;\n\n\t},\n\n\tfadeIn: function ( duration ) {\n\n\t\treturn this._scheduleFading( duration, 0, 1 );\n\n\t},\n\n\tfadeOut: function ( duration ) {\n\n\t\treturn this._scheduleFading( duration, 1, 0 );\n\n\t},\n\n\tcrossFadeFrom: function ( fadeOutAction, duration, warp ) {\n\n\t\tfadeOutAction.fadeOut( duration );\n\t\tthis.fadeIn( duration );\n\n\t\tif ( warp ) {\n\n\t\t\tvar fadeInDuration = this._clip.duration,\n\t\t\t\tfadeOutDuration = fadeOutAction._clip.duration,\n\n\t\t\t\tstartEndRatio = fadeOutDuration / fadeInDuration,\n\t\t\t\tendStartRatio = fadeInDuration / fadeOutDuration;\n\n\t\t\tfadeOutAction.warp( 1.0, startEndRatio, duration );\n\t\t\tthis.warp( endStartRatio, 1.0, duration );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tcrossFadeTo: function ( fadeInAction, duration, warp ) {\n\n\t\treturn fadeInAction.crossFadeFrom( this, duration, warp );\n\n\t},\n\n\tstopFading: function () {\n\n\t\tvar weightInterpolant = this._weightInterpolant;\n\n\t\tif ( weightInterpolant !== null ) {\n\n\t\t\tthis._weightInterpolant = null;\n\t\t\tthis._mixer._takeBackControlInterpolant( weightInterpolant );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\t// Time Scale Control\n\n\t// set the time scale stopping any scheduled warping\n\t// although .paused = true yields an effective time scale of zero, this\n\t// method does *not* change .paused, because it would be confusing\n\tsetEffectiveTimeScale: function ( timeScale ) {\n\n\t\tthis.timeScale = timeScale;\n\t\tthis._effectiveTimeScale = this.paused ? 0 : timeScale;\n\n\t\treturn this.stopWarping();\n\n\t},\n\n\t// return the time scale considering warping and .paused\n\tgetEffectiveTimeScale: function () {\n\n\t\treturn this._effectiveTimeScale;\n\n\t},\n\n\tsetDuration: function ( duration ) {\n\n\t\tthis.timeScale = this._clip.duration / duration;\n\n\t\treturn this.stopWarping();\n\n\t},\n\n\tsyncWith: function ( action ) {\n\n\t\tthis.time = action.time;\n\t\tthis.timeScale = action.timeScale;\n\n\t\treturn this.stopWarping();\n\n\t},\n\n\thalt: function ( duration ) {\n\n\t\treturn this.warp( this._effectiveTimeScale, 0, duration );\n\n\t},\n\n\twarp: function ( startTimeScale, endTimeScale, duration ) {\n\n\t\tvar mixer = this._mixer, now = mixer.time,\n\t\t\tinterpolant = this._timeScaleInterpolant,\n\n\t\t\ttimeScale = this.timeScale;\n\n\t\tif ( interpolant === null ) {\n\n\t\t\tinterpolant = mixer._lendControlInterpolant();\n\t\t\tthis._timeScaleInterpolant = interpolant;\n\n\t\t}\n\n\t\tvar times = interpolant.parameterPositions,\n\t\t\tvalues = interpolant.sampleValues;\n\n\t\ttimes[ 0 ] = now;\n\t\ttimes[ 1 ] = now + duration;\n\n\t\tvalues[ 0 ] = startTimeScale / timeScale;\n\t\tvalues[ 1 ] = endTimeScale / timeScale;\n\n\t\treturn this;\n\n\t},\n\n\tstopWarping: function () {\n\n\t\tvar timeScaleInterpolant = this._timeScaleInterpolant;\n\n\t\tif ( timeScaleInterpolant !== null ) {\n\n\t\t\tthis._timeScaleInterpolant = null;\n\t\t\tthis._mixer._takeBackControlInterpolant( timeScaleInterpolant );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\t// Object Accessors\n\n\tgetMixer: function () {\n\n\t\treturn this._mixer;\n\n\t},\n\n\tgetClip: function () {\n\n\t\treturn this._clip;\n\n\t},\n\n\tgetRoot: function () {\n\n\t\treturn this._localRoot || this._mixer._root;\n\n\t},\n\n\t// Interna\n\n\t_update: function ( time, deltaTime, timeDirection, accuIndex ) {\n\n\t\t// called by the mixer\n\n\t\tif ( ! this.enabled ) {\n\n\t\t\t// call ._updateWeight() to update ._effectiveWeight\n\n\t\t\tthis._updateWeight( time );\n\t\t\treturn;\n\n\t\t}\n\n\t\tvar startTime = this._startTime;\n\n\t\tif ( startTime !== null ) {\n\n\t\t\t// check for scheduled start of action\n\n\t\t\tvar timeRunning = ( time - startTime ) * timeDirection;\n\t\t\tif ( timeRunning < 0 || timeDirection === 0 ) {\n\n\t\t\t\treturn; // yet to come / don't decide when delta = 0\n\n\t\t\t}\n\n\t\t\t// start\n\n\t\t\tthis._startTime = null; // unschedule\n\t\t\tdeltaTime = timeDirection * timeRunning;\n\n\t\t}\n\n\t\t// apply time scale and advance time\n\n\t\tdeltaTime *= this._updateTimeScale( time );\n\t\tvar clipTime = this._updateTime( deltaTime );\n\n\t\t// note: _updateTime may disable the action resulting in\n\t\t// an effective weight of 0\n\n\t\tvar weight = this._updateWeight( time );\n\n\t\tif ( weight > 0 ) {\n\n\t\t\tvar interpolants = this._interpolants;\n\t\t\tvar propertyMixers = this._propertyBindings;\n\n\t\t\tfor ( var j = 0, m = interpolants.length; j !== m; ++ j ) {\n\n\t\t\t\tinterpolants[ j ].evaluate( clipTime );\n\t\t\t\tpropertyMixers[ j ].accumulate( accuIndex, weight );\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\t_updateWeight: function ( time ) {\n\n\t\tvar weight = 0;\n\n\t\tif ( this.enabled ) {\n\n\t\t\tweight = this.weight;\n\t\t\tvar interpolant = this._weightInterpolant;\n\n\t\t\tif ( interpolant !== null ) {\n\n\t\t\t\tvar interpolantValue = interpolant.evaluate( time )[ 0 ];\n\n\t\t\t\tweight *= interpolantValue;\n\n\t\t\t\tif ( time > interpolant.parameterPositions[ 1 ] ) {\n\n\t\t\t\t\tthis.stopFading();\n\n\t\t\t\t\tif ( interpolantValue === 0 ) {\n\n\t\t\t\t\t\t// faded out, disable\n\t\t\t\t\t\tthis.enabled = false;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis._effectiveWeight = weight;\n\t\treturn weight;\n\n\t},\n\n\t_updateTimeScale: function ( time ) {\n\n\t\tvar timeScale = 0;\n\n\t\tif ( ! this.paused ) {\n\n\t\t\ttimeScale = this.timeScale;\n\n\t\t\tvar interpolant = this._timeScaleInterpolant;\n\n\t\t\tif ( interpolant !== null ) {\n\n\t\t\t\tvar interpolantValue = interpolant.evaluate( time )[ 0 ];\n\n\t\t\t\ttimeScale *= interpolantValue;\n\n\t\t\t\tif ( time > interpolant.parameterPositions[ 1 ] ) {\n\n\t\t\t\t\tthis.stopWarping();\n\n\t\t\t\t\tif ( timeScale === 0 ) {\n\n\t\t\t\t\t\t// motion has halted, pause\n\t\t\t\t\t\tthis.paused = true;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// warp done - apply final time scale\n\t\t\t\t\t\tthis.timeScale = timeScale;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis._effectiveTimeScale = timeScale;\n\t\treturn timeScale;\n\n\t},\n\n\t_updateTime: function ( deltaTime ) {\n\n\t\tvar time = this.time + deltaTime;\n\n\t\tif ( deltaTime === 0 ) return time;\n\n\t\tvar duration = this._clip.duration,\n\n\t\t\tloop = this.loop,\n\t\t\tloopCount = this._loopCount;\n\n\t\tif ( loop === LoopOnce ) {\n\n\t\t\tif ( loopCount === - 1 ) {\n\n\t\t\t\t// just started\n\n\t\t\t\tthis._loopCount = 0;\n\t\t\t\tthis._setEndings( true, true, false );\n\n\t\t\t}\n\n\t\t\thandle_stop: {\n\n\t\t\t\tif ( time >= duration ) {\n\n\t\t\t\t\ttime = duration;\n\n\t\t\t\t} else if ( time < 0 ) {\n\n\t\t\t\t\ttime = 0;\n\n\t\t\t\t} else break handle_stop;\n\n\t\t\t\tif ( this.clampWhenFinished ) this.paused = true;\n\t\t\t\telse this.enabled = false;\n\n\t\t\t\tthis._mixer.dispatchEvent( {\n\t\t\t\t\ttype: 'finished', action: this,\n\t\t\t\t\tdirection: deltaTime < 0 ? - 1 : 1\n\t\t\t\t} );\n\n\t\t\t}\n\n\t\t} else { // repetitive Repeat or PingPong\n\n\t\t\tvar pingPong = ( loop === LoopPingPong );\n\n\t\t\tif ( loopCount === - 1 ) {\n\n\t\t\t\t// just started\n\n\t\t\t\tif ( deltaTime >= 0 ) {\n\n\t\t\t\t\tloopCount = 0;\n\n\t\t\t\t\tthis._setEndings( true, this.repetitions === 0, pingPong );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// when looping in reverse direction, the initial\n\t\t\t\t\t// transition through zero counts as a repetition,\n\t\t\t\t\t// so leave loopCount at -1\n\n\t\t\t\t\tthis._setEndings( this.repetitions === 0, true, pingPong );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( time >= duration || time < 0 ) {\n\n\t\t\t\t// wrap around\n\n\t\t\t\tvar loopDelta = Math.floor( time / duration ); // signed\n\t\t\t\ttime -= duration * loopDelta;\n\n\t\t\t\tloopCount += Math.abs( loopDelta );\n\n\t\t\t\tvar pending = this.repetitions - loopCount;\n\n\t\t\t\tif ( pending <= 0 ) {\n\n\t\t\t\t\t// have to stop (switch state, clamp time, fire event)\n\n\t\t\t\t\tif ( this.clampWhenFinished ) this.paused = true;\n\t\t\t\t\telse this.enabled = false;\n\n\t\t\t\t\ttime = deltaTime > 0 ? duration : 0;\n\n\t\t\t\t\tthis._mixer.dispatchEvent( {\n\t\t\t\t\t\ttype: 'finished', action: this,\n\t\t\t\t\t\tdirection: deltaTime > 0 ? 1 : - 1\n\t\t\t\t\t} );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// keep running\n\n\t\t\t\t\tif ( pending === 1 ) {\n\n\t\t\t\t\t\t// entering the last round\n\n\t\t\t\t\t\tvar atStart = deltaTime < 0;\n\t\t\t\t\t\tthis._setEndings( atStart, ! atStart, pingPong );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tthis._setEndings( false, false, pingPong );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tthis._loopCount = loopCount;\n\n\t\t\t\t\tthis._mixer.dispatchEvent( {\n\t\t\t\t\t\ttype: 'loop', action: this, loopDelta: loopDelta\n\t\t\t\t\t} );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( pingPong && ( loopCount & 1 ) === 1 ) {\n\n\t\t\t\t// invert time for the \"pong round\"\n\n\t\t\t\tthis.time = time;\n\t\t\t\treturn duration - time;\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis.time = time;\n\t\treturn time;\n\n\t},\n\n\t_setEndings: function ( atStart, atEnd, pingPong ) {\n\n\t\tvar settings = this._interpolantSettings;\n\n\t\tif ( pingPong ) {\n\n\t\t\tsettings.endingStart \t= ZeroSlopeEnding;\n\t\t\tsettings.endingEnd\t\t= ZeroSlopeEnding;\n\n\t\t} else {\n\n\t\t\t// assuming for LoopOnce atStart == atEnd == true\n\n\t\t\tif ( atStart ) {\n\n\t\t\t\tsettings.endingStart = this.zeroSlopeAtStart ? ZeroSlopeEnding : ZeroCurvatureEnding;\n\n\t\t\t} else {\n\n\t\t\t\tsettings.endingStart = WrapAroundEnding;\n\n\t\t\t}\n\n\t\t\tif ( atEnd ) {\n\n\t\t\t\tsettings.endingEnd = this.zeroSlopeAtEnd ? ZeroSlopeEnding : ZeroCurvatureEnding;\n\n\t\t\t} else {\n\n\t\t\t\tsettings.endingEnd \t = WrapAroundEnding;\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\t_scheduleFading: function ( duration, weightNow, weightThen ) {\n\n\t\tvar mixer = this._mixer, now = mixer.time,\n\t\t\tinterpolant = this._weightInterpolant;\n\n\t\tif ( interpolant === null ) {\n\n\t\t\tinterpolant = mixer._lendControlInterpolant();\n\t\t\tthis._weightInterpolant = interpolant;\n\n\t\t}\n\n\t\tvar times = interpolant.parameterPositions,\n\t\t\tvalues = interpolant.sampleValues;\n\n\t\ttimes[ 0 ] = now; \t\t\t\tvalues[ 0 ] = weightNow;\n\t\ttimes[ 1 ] = now + duration;\tvalues[ 1 ] = weightThen;\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n *\n * Player for AnimationClips.\n *\n *\n * @author Ben Houston / http://clara.io/\n * @author David Sarno / http://lighthaus.us/\n * @author tschw\n */\n\nfunction AnimationMixer( root ) {\n\n\tthis._root = root;\n\tthis._initMemoryManager();\n\tthis._accuIndex = 0;\n\n\tthis.time = 0;\n\n\tthis.timeScale = 1.0;\n\n}\n\nAnimationMixer.prototype = Object.assign( Object.create( EventDispatcher.prototype ), {\n\n\tconstructor: AnimationMixer,\n\n\t_bindAction: function ( action, prototypeAction ) {\n\n\t\tvar root = action._localRoot || this._root,\n\t\t\ttracks = action._clip.tracks,\n\t\t\tnTracks = tracks.length,\n\t\t\tbindings = action._propertyBindings,\n\t\t\tinterpolants = action._interpolants,\n\t\t\trootUuid = root.uuid,\n\t\t\tbindingsByRoot = this._bindingsByRootAndName,\n\t\t\tbindingsByName = bindingsByRoot[ rootUuid ];\n\n\t\tif ( bindingsByName === undefined ) {\n\n\t\t\tbindingsByName = {};\n\t\t\tbindingsByRoot[ rootUuid ] = bindingsByName;\n\n\t\t}\n\n\t\tfor ( var i = 0; i !== nTracks; ++ i ) {\n\n\t\t\tvar track = tracks[ i ],\n\t\t\t\ttrackName = track.name,\n\t\t\t\tbinding = bindingsByName[ trackName ];\n\n\t\t\tif ( binding !== undefined ) {\n\n\t\t\t\tbindings[ i ] = binding;\n\n\t\t\t} else {\n\n\t\t\t\tbinding = bindings[ i ];\n\n\t\t\t\tif ( binding !== undefined ) {\n\n\t\t\t\t\t// existing binding, make sure the cache knows\n\n\t\t\t\t\tif ( binding._cacheIndex === null ) {\n\n\t\t\t\t\t\t++ binding.referenceCount;\n\t\t\t\t\t\tthis._addInactiveBinding( binding, rootUuid, trackName );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tcontinue;\n\n\t\t\t\t}\n\n\t\t\t\tvar path = prototypeAction && prototypeAction.\n\t\t\t\t\t_propertyBindings[ i ].binding.parsedPath;\n\n\t\t\t\tbinding = new PropertyMixer(\n\t\t\t\t\tPropertyBinding.create( root, trackName, path ),\n\t\t\t\t\ttrack.ValueTypeName, track.getValueSize() );\n\n\t\t\t\t++ binding.referenceCount;\n\t\t\t\tthis._addInactiveBinding( binding, rootUuid, trackName );\n\n\t\t\t\tbindings[ i ] = binding;\n\n\t\t\t}\n\n\t\t\tinterpolants[ i ].resultBuffer = binding.buffer;\n\n\t\t}\n\n\t},\n\n\t_activateAction: function ( action ) {\n\n\t\tif ( ! this._isActiveAction( action ) ) {\n\n\t\t\tif ( action._cacheIndex === null ) {\n\n\t\t\t\t// this action has been forgotten by the cache, but the user\n\t\t\t\t// appears to be still using it -> rebind\n\n\t\t\t\tvar rootUuid = ( action._localRoot || this._root ).uuid,\n\t\t\t\t\tclipUuid = action._clip.uuid,\n\t\t\t\t\tactionsForClip = this._actionsByClip[ clipUuid ];\n\n\t\t\t\tthis._bindAction( action,\n\t\t\t\t\tactionsForClip && actionsForClip.knownActions[ 0 ] );\n\n\t\t\t\tthis._addInactiveAction( action, clipUuid, rootUuid );\n\n\t\t\t}\n\n\t\t\tvar bindings = action._propertyBindings;\n\n\t\t\t// increment reference counts / sort out state\n\t\t\tfor ( var i = 0, n = bindings.length; i !== n; ++ i ) {\n\n\t\t\t\tvar binding = bindings[ i ];\n\n\t\t\t\tif ( binding.useCount ++ === 0 ) {\n\n\t\t\t\t\tthis._lendBinding( binding );\n\t\t\t\t\tbinding.saveOriginalState();\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis._lendAction( action );\n\n\t\t}\n\n\t},\n\n\t_deactivateAction: function ( action ) {\n\n\t\tif ( this._isActiveAction( action ) ) {\n\n\t\t\tvar bindings = action._propertyBindings;\n\n\t\t\t// decrement reference counts / sort out state\n\t\t\tfor ( var i = 0, n = bindings.length; i !== n; ++ i ) {\n\n\t\t\t\tvar binding = bindings[ i ];\n\n\t\t\t\tif ( -- binding.useCount === 0 ) {\n\n\t\t\t\t\tbinding.restoreOriginalState();\n\t\t\t\t\tthis._takeBackBinding( binding );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis._takeBackAction( action );\n\n\t\t}\n\n\t},\n\n\t// Memory manager\n\n\t_initMemoryManager: function () {\n\n\t\tthis._actions = []; // 'nActiveActions' followed by inactive ones\n\t\tthis._nActiveActions = 0;\n\n\t\tthis._actionsByClip = {};\n\t\t// inside:\n\t\t// {\n\t\t// \t\tknownActions: Array< AnimationAction >\t- used as prototypes\n\t\t// \t\tactionByRoot: AnimationAction\t\t\t- lookup\n\t\t// }\n\n\n\t\tthis._bindings = []; // 'nActiveBindings' followed by inactive ones\n\t\tthis._nActiveBindings = 0;\n\n\t\tthis._bindingsByRootAndName = {}; // inside: Map< name, PropertyMixer >\n\n\n\t\tthis._controlInterpolants = []; // same game as above\n\t\tthis._nActiveControlInterpolants = 0;\n\n\t\tvar scope = this;\n\n\t\tthis.stats = {\n\n\t\t\tactions: {\n\t\t\t\tget total() {\n\n\t\t\t\t\treturn scope._actions.length;\n\n\t\t\t\t},\n\t\t\t\tget inUse() {\n\n\t\t\t\t\treturn scope._nActiveActions;\n\n\t\t\t\t}\n\t\t\t},\n\t\t\tbindings: {\n\t\t\t\tget total() {\n\n\t\t\t\t\treturn scope._bindings.length;\n\n\t\t\t\t},\n\t\t\t\tget inUse() {\n\n\t\t\t\t\treturn scope._nActiveBindings;\n\n\t\t\t\t}\n\t\t\t},\n\t\t\tcontrolInterpolants: {\n\t\t\t\tget total() {\n\n\t\t\t\t\treturn scope._controlInterpolants.length;\n\n\t\t\t\t},\n\t\t\t\tget inUse() {\n\n\t\t\t\t\treturn scope._nActiveControlInterpolants;\n\n\t\t\t\t}\n\t\t\t}\n\n\t\t};\n\n\t},\n\n\t// Memory management for AnimationAction objects\n\n\t_isActiveAction: function ( action ) {\n\n\t\tvar index = action._cacheIndex;\n\t\treturn index !== null && index < this._nActiveActions;\n\n\t},\n\n\t_addInactiveAction: function ( action, clipUuid, rootUuid ) {\n\n\t\tvar actions = this._actions,\n\t\t\tactionsByClip = this._actionsByClip,\n\t\t\tactionsForClip = actionsByClip[ clipUuid ];\n\n\t\tif ( actionsForClip === undefined ) {\n\n\t\t\tactionsForClip = {\n\n\t\t\t\tknownActions: [ action ],\n\t\t\t\tactionByRoot: {}\n\n\t\t\t};\n\n\t\t\taction._byClipCacheIndex = 0;\n\n\t\t\tactionsByClip[ clipUuid ] = actionsForClip;\n\n\t\t} else {\n\n\t\t\tvar knownActions = actionsForClip.knownActions;\n\n\t\t\taction._byClipCacheIndex = knownActions.length;\n\t\t\tknownActions.push( action );\n\n\t\t}\n\n\t\taction._cacheIndex = actions.length;\n\t\tactions.push( action );\n\n\t\tactionsForClip.actionByRoot[ rootUuid ] = action;\n\n\t},\n\n\t_removeInactiveAction: function ( action ) {\n\n\t\tvar actions = this._actions,\n\t\t\tlastInactiveAction = actions[ actions.length - 1 ],\n\t\t\tcacheIndex = action._cacheIndex;\n\n\t\tlastInactiveAction._cacheIndex = cacheIndex;\n\t\tactions[ cacheIndex ] = lastInactiveAction;\n\t\tactions.pop();\n\n\t\taction._cacheIndex = null;\n\n\n\t\tvar clipUuid = action._clip.uuid,\n\t\t\tactionsByClip = this._actionsByClip,\n\t\t\tactionsForClip = actionsByClip[ clipUuid ],\n\t\t\tknownActionsForClip = actionsForClip.knownActions,\n\n\t\t\tlastKnownAction =\n\t\t\t\tknownActionsForClip[ knownActionsForClip.length - 1 ],\n\n\t\t\tbyClipCacheIndex = action._byClipCacheIndex;\n\n\t\tlastKnownAction._byClipCacheIndex = byClipCacheIndex;\n\t\tknownActionsForClip[ byClipCacheIndex ] = lastKnownAction;\n\t\tknownActionsForClip.pop();\n\n\t\taction._byClipCacheIndex = null;\n\n\n\t\tvar actionByRoot = actionsForClip.actionByRoot,\n\t\t\trootUuid = ( action._localRoot || this._root ).uuid;\n\n\t\tdelete actionByRoot[ rootUuid ];\n\n\t\tif ( knownActionsForClip.length === 0 ) {\n\n\t\t\tdelete actionsByClip[ clipUuid ];\n\n\t\t}\n\n\t\tthis._removeInactiveBindingsForAction( action );\n\n\t},\n\n\t_removeInactiveBindingsForAction: function ( action ) {\n\n\t\tvar bindings = action._propertyBindings;\n\t\tfor ( var i = 0, n = bindings.length; i !== n; ++ i ) {\n\n\t\t\tvar binding = bindings[ i ];\n\n\t\t\tif ( -- binding.referenceCount === 0 ) {\n\n\t\t\t\tthis._removeInactiveBinding( binding );\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\t_lendAction: function ( action ) {\n\n\t\t// [ active actions |  inactive actions  ]\n\t\t// [  active actions >| inactive actions ]\n\t\t//                 s        a\n\t\t//                  <-swap->\n\t\t//                 a        s\n\n\t\tvar actions = this._actions,\n\t\t\tprevIndex = action._cacheIndex,\n\n\t\t\tlastActiveIndex = this._nActiveActions ++,\n\n\t\t\tfirstInactiveAction = actions[ lastActiveIndex ];\n\n\t\taction._cacheIndex = lastActiveIndex;\n\t\tactions[ lastActiveIndex ] = action;\n\n\t\tfirstInactiveAction._cacheIndex = prevIndex;\n\t\tactions[ prevIndex ] = firstInactiveAction;\n\n\t},\n\n\t_takeBackAction: function ( action ) {\n\n\t\t// [  active actions  | inactive actions ]\n\t\t// [ active actions |< inactive actions  ]\n\t\t//        a        s\n\t\t//         <-swap->\n\t\t//        s        a\n\n\t\tvar actions = this._actions,\n\t\t\tprevIndex = action._cacheIndex,\n\n\t\t\tfirstInactiveIndex = -- this._nActiveActions,\n\n\t\t\tlastActiveAction = actions[ firstInactiveIndex ];\n\n\t\taction._cacheIndex = firstInactiveIndex;\n\t\tactions[ firstInactiveIndex ] = action;\n\n\t\tlastActiveAction._cacheIndex = prevIndex;\n\t\tactions[ prevIndex ] = lastActiveAction;\n\n\t},\n\n\t// Memory management for PropertyMixer objects\n\n\t_addInactiveBinding: function ( binding, rootUuid, trackName ) {\n\n\t\tvar bindingsByRoot = this._bindingsByRootAndName,\n\t\t\tbindingByName = bindingsByRoot[ rootUuid ],\n\n\t\t\tbindings = this._bindings;\n\n\t\tif ( bindingByName === undefined ) {\n\n\t\t\tbindingByName = {};\n\t\t\tbindingsByRoot[ rootUuid ] = bindingByName;\n\n\t\t}\n\n\t\tbindingByName[ trackName ] = binding;\n\n\t\tbinding._cacheIndex = bindings.length;\n\t\tbindings.push( binding );\n\n\t},\n\n\t_removeInactiveBinding: function ( binding ) {\n\n\t\tvar bindings = this._bindings,\n\t\t\tpropBinding = binding.binding,\n\t\t\trootUuid = propBinding.rootNode.uuid,\n\t\t\ttrackName = propBinding.path,\n\t\t\tbindingsByRoot = this._bindingsByRootAndName,\n\t\t\tbindingByName = bindingsByRoot[ rootUuid ],\n\n\t\t\tlastInactiveBinding = bindings[ bindings.length - 1 ],\n\t\t\tcacheIndex = binding._cacheIndex;\n\n\t\tlastInactiveBinding._cacheIndex = cacheIndex;\n\t\tbindings[ cacheIndex ] = lastInactiveBinding;\n\t\tbindings.pop();\n\n\t\tdelete bindingByName[ trackName ];\n\n\t\tremove_empty_map: {\n\n\t\t\tfor ( var _ in bindingByName ) break remove_empty_map; // eslint-disable-line no-unused-vars\n\n\t\t\tdelete bindingsByRoot[ rootUuid ];\n\n\t\t}\n\n\t},\n\n\t_lendBinding: function ( binding ) {\n\n\t\tvar bindings = this._bindings,\n\t\t\tprevIndex = binding._cacheIndex,\n\n\t\t\tlastActiveIndex = this._nActiveBindings ++,\n\n\t\t\tfirstInactiveBinding = bindings[ lastActiveIndex ];\n\n\t\tbinding._cacheIndex = lastActiveIndex;\n\t\tbindings[ lastActiveIndex ] = binding;\n\n\t\tfirstInactiveBinding._cacheIndex = prevIndex;\n\t\tbindings[ prevIndex ] = firstInactiveBinding;\n\n\t},\n\n\t_takeBackBinding: function ( binding ) {\n\n\t\tvar bindings = this._bindings,\n\t\t\tprevIndex = binding._cacheIndex,\n\n\t\t\tfirstInactiveIndex = -- this._nActiveBindings,\n\n\t\t\tlastActiveBinding = bindings[ firstInactiveIndex ];\n\n\t\tbinding._cacheIndex = firstInactiveIndex;\n\t\tbindings[ firstInactiveIndex ] = binding;\n\n\t\tlastActiveBinding._cacheIndex = prevIndex;\n\t\tbindings[ prevIndex ] = lastActiveBinding;\n\n\t},\n\n\n\t// Memory management of Interpolants for weight and time scale\n\n\t_lendControlInterpolant: function () {\n\n\t\tvar interpolants = this._controlInterpolants,\n\t\t\tlastActiveIndex = this._nActiveControlInterpolants ++,\n\t\t\tinterpolant = interpolants[ lastActiveIndex ];\n\n\t\tif ( interpolant === undefined ) {\n\n\t\t\tinterpolant = new LinearInterpolant(\n\t\t\t\tnew Float32Array( 2 ), new Float32Array( 2 ),\n\t\t\t\t1, this._controlInterpolantsResultBuffer );\n\n\t\t\tinterpolant.__cacheIndex = lastActiveIndex;\n\t\t\tinterpolants[ lastActiveIndex ] = interpolant;\n\n\t\t}\n\n\t\treturn interpolant;\n\n\t},\n\n\t_takeBackControlInterpolant: function ( interpolant ) {\n\n\t\tvar interpolants = this._controlInterpolants,\n\t\t\tprevIndex = interpolant.__cacheIndex,\n\n\t\t\tfirstInactiveIndex = -- this._nActiveControlInterpolants,\n\n\t\t\tlastActiveInterpolant = interpolants[ firstInactiveIndex ];\n\n\t\tinterpolant.__cacheIndex = firstInactiveIndex;\n\t\tinterpolants[ firstInactiveIndex ] = interpolant;\n\n\t\tlastActiveInterpolant.__cacheIndex = prevIndex;\n\t\tinterpolants[ prevIndex ] = lastActiveInterpolant;\n\n\t},\n\n\t_controlInterpolantsResultBuffer: new Float32Array( 1 ),\n\n\t// return an action for a clip optionally using a custom root target\n\t// object (this method allocates a lot of dynamic memory in case a\n\t// previously unknown clip/root combination is specified)\n\tclipAction: function ( clip, optionalRoot ) {\n\n\t\tvar root = optionalRoot || this._root,\n\t\t\trootUuid = root.uuid,\n\n\t\t\tclipObject = typeof clip === 'string' ?\n\t\t\t\tAnimationClip.findByName( root, clip ) : clip,\n\n\t\t\tclipUuid = clipObject !== null ? clipObject.uuid : clip,\n\n\t\t\tactionsForClip = this._actionsByClip[ clipUuid ],\n\t\t\tprototypeAction = null;\n\n\t\tif ( actionsForClip !== undefined ) {\n\n\t\t\tvar existingAction =\n\t\t\t\t\tactionsForClip.actionByRoot[ rootUuid ];\n\n\t\t\tif ( existingAction !== undefined ) {\n\n\t\t\t\treturn existingAction;\n\n\t\t\t}\n\n\t\t\t// we know the clip, so we don't have to parse all\n\t\t\t// the bindings again but can just copy\n\t\t\tprototypeAction = actionsForClip.knownActions[ 0 ];\n\n\t\t\t// also, take the clip from the prototype action\n\t\t\tif ( clipObject === null )\n\t\t\t\tclipObject = prototypeAction._clip;\n\n\t\t}\n\n\t\t// clip must be known when specified via string\n\t\tif ( clipObject === null ) return null;\n\n\t\t// allocate all resources required to run it\n\t\tvar newAction = new AnimationAction( this, clipObject, optionalRoot );\n\n\t\tthis._bindAction( newAction, prototypeAction );\n\n\t\t// and make the action known to the memory manager\n\t\tthis._addInactiveAction( newAction, clipUuid, rootUuid );\n\n\t\treturn newAction;\n\n\t},\n\n\t// get an existing action\n\texistingAction: function ( clip, optionalRoot ) {\n\n\t\tvar root = optionalRoot || this._root,\n\t\t\trootUuid = root.uuid,\n\n\t\t\tclipObject = typeof clip === 'string' ?\n\t\t\t\tAnimationClip.findByName( root, clip ) : clip,\n\n\t\t\tclipUuid = clipObject ? clipObject.uuid : clip,\n\n\t\t\tactionsForClip = this._actionsByClip[ clipUuid ];\n\n\t\tif ( actionsForClip !== undefined ) {\n\n\t\t\treturn actionsForClip.actionByRoot[ rootUuid ] || null;\n\n\t\t}\n\n\t\treturn null;\n\n\t},\n\n\t// deactivates all previously scheduled actions\n\tstopAllAction: function () {\n\n\t\tvar actions = this._actions,\n\t\t\tnActions = this._nActiveActions,\n\t\t\tbindings = this._bindings,\n\t\t\tnBindings = this._nActiveBindings;\n\n\t\tthis._nActiveActions = 0;\n\t\tthis._nActiveBindings = 0;\n\n\t\tfor ( var i = 0; i !== nActions; ++ i ) {\n\n\t\t\tactions[ i ].reset();\n\n\t\t}\n\n\t\tfor ( var i = 0; i !== nBindings; ++ i ) {\n\n\t\t\tbindings[ i ].useCount = 0;\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\t// advance the time and update apply the animation\n\tupdate: function ( deltaTime ) {\n\n\t\tdeltaTime *= this.timeScale;\n\n\t\tvar actions = this._actions,\n\t\t\tnActions = this._nActiveActions,\n\n\t\t\ttime = this.time += deltaTime,\n\t\t\ttimeDirection = Math.sign( deltaTime ),\n\n\t\t\taccuIndex = this._accuIndex ^= 1;\n\n\t\t// run active actions\n\n\t\tfor ( var i = 0; i !== nActions; ++ i ) {\n\n\t\t\tvar action = actions[ i ];\n\n\t\t\taction._update( time, deltaTime, timeDirection, accuIndex );\n\n\t\t}\n\n\t\t// update scene graph\n\n\t\tvar bindings = this._bindings,\n\t\t\tnBindings = this._nActiveBindings;\n\n\t\tfor ( var i = 0; i !== nBindings; ++ i ) {\n\n\t\t\tbindings[ i ].apply( accuIndex );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\t// return this mixer's root target object\n\tgetRoot: function () {\n\n\t\treturn this._root;\n\n\t},\n\n\t// free all resources specific to a particular clip\n\tuncacheClip: function ( clip ) {\n\n\t\tvar actions = this._actions,\n\t\t\tclipUuid = clip.uuid,\n\t\t\tactionsByClip = this._actionsByClip,\n\t\t\tactionsForClip = actionsByClip[ clipUuid ];\n\n\t\tif ( actionsForClip !== undefined ) {\n\n\t\t\t// note: just calling _removeInactiveAction would mess up the\n\t\t\t// iteration state and also require updating the state we can\n\t\t\t// just throw away\n\n\t\t\tvar actionsToRemove = actionsForClip.knownActions;\n\n\t\t\tfor ( var i = 0, n = actionsToRemove.length; i !== n; ++ i ) {\n\n\t\t\t\tvar action = actionsToRemove[ i ];\n\n\t\t\t\tthis._deactivateAction( action );\n\n\t\t\t\tvar cacheIndex = action._cacheIndex,\n\t\t\t\t\tlastInactiveAction = actions[ actions.length - 1 ];\n\n\t\t\t\taction._cacheIndex = null;\n\t\t\t\taction._byClipCacheIndex = null;\n\n\t\t\t\tlastInactiveAction._cacheIndex = cacheIndex;\n\t\t\t\tactions[ cacheIndex ] = lastInactiveAction;\n\t\t\t\tactions.pop();\n\n\t\t\t\tthis._removeInactiveBindingsForAction( action );\n\n\t\t\t}\n\n\t\t\tdelete actionsByClip[ clipUuid ];\n\n\t\t}\n\n\t},\n\n\t// free all resources specific to a particular root target object\n\tuncacheRoot: function ( root ) {\n\n\t\tvar rootUuid = root.uuid,\n\t\t\tactionsByClip = this._actionsByClip;\n\n\t\tfor ( var clipUuid in actionsByClip ) {\n\n\t\t\tvar actionByRoot = actionsByClip[ clipUuid ].actionByRoot,\n\t\t\t\taction = actionByRoot[ rootUuid ];\n\n\t\t\tif ( action !== undefined ) {\n\n\t\t\t\tthis._deactivateAction( action );\n\t\t\t\tthis._removeInactiveAction( action );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvar bindingsByRoot = this._bindingsByRootAndName,\n\t\t\tbindingByName = bindingsByRoot[ rootUuid ];\n\n\t\tif ( bindingByName !== undefined ) {\n\n\t\t\tfor ( var trackName in bindingByName ) {\n\n\t\t\t\tvar binding = bindingByName[ trackName ];\n\t\t\t\tbinding.restoreOriginalState();\n\t\t\t\tthis._removeInactiveBinding( binding );\n\n\t\t\t}\n\n\t\t}\n\n\t},\n\n\t// remove a targeted clip from the cache\n\tuncacheAction: function ( clip, optionalRoot ) {\n\n\t\tvar action = this.existingAction( clip, optionalRoot );\n\n\t\tif ( action !== null ) {\n\n\t\t\tthis._deactivateAction( action );\n\t\t\tthis._removeInactiveAction( action );\n\n\t\t}\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction Uniform( value ) {\n\n\tif ( typeof value === 'string' ) {\n\n\t\tconsole.warn( 'THREE.Uniform: Type parameter is no longer needed.' );\n\t\tvalue = arguments[ 1 ];\n\n\t}\n\n\tthis.value = value;\n\n}\n\nUniform.prototype.clone = function () {\n\n\treturn new Uniform( this.value.clone === undefined ? this.value : this.value.clone() );\n\n};\n\n/**\n * @author benaadams / https://twitter.com/ben_a_adams\n */\n\nfunction InstancedBufferGeometry() {\n\n\tBufferGeometry.call( this );\n\n\tthis.type = 'InstancedBufferGeometry';\n\tthis.maxInstancedCount = undefined;\n\n}\n\nInstancedBufferGeometry.prototype = Object.assign( Object.create( BufferGeometry.prototype ), {\n\n\tconstructor: InstancedBufferGeometry,\n\n\tisInstancedBufferGeometry: true,\n\n\tcopy: function ( source ) {\n\n\t\tBufferGeometry.prototype.copy.call( this, source );\n\n\t\tthis.maxInstancedCount = source.maxInstancedCount;\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n} );\n\n/**\n * @author benaadams / https://twitter.com/ben_a_adams\n */\n\nfunction InterleavedBufferAttribute( interleavedBuffer, itemSize, offset, normalized ) {\n\n\tthis.data = interleavedBuffer;\n\tthis.itemSize = itemSize;\n\tthis.offset = offset;\n\n\tthis.normalized = normalized === true;\n\n}\n\nObject.defineProperties( InterleavedBufferAttribute.prototype, {\n\n\tcount: {\n\n\t\tget: function () {\n\n\t\t\treturn this.data.count;\n\n\t\t}\n\n\t},\n\n\tarray: {\n\n\t\tget: function () {\n\n\t\t\treturn this.data.array;\n\n\t\t}\n\n\t}\n\n} );\n\nObject.assign( InterleavedBufferAttribute.prototype, {\n\n\tisInterleavedBufferAttribute: true,\n\n\tsetX: function ( index, x ) {\n\n\t\tthis.data.array[ index * this.data.stride + this.offset ] = x;\n\n\t\treturn this;\n\n\t},\n\n\tsetY: function ( index, y ) {\n\n\t\tthis.data.array[ index * this.data.stride + this.offset + 1 ] = y;\n\n\t\treturn this;\n\n\t},\n\n\tsetZ: function ( index, z ) {\n\n\t\tthis.data.array[ index * this.data.stride + this.offset + 2 ] = z;\n\n\t\treturn this;\n\n\t},\n\n\tsetW: function ( index, w ) {\n\n\t\tthis.data.array[ index * this.data.stride + this.offset + 3 ] = w;\n\n\t\treturn this;\n\n\t},\n\n\tgetX: function ( index ) {\n\n\t\treturn this.data.array[ index * this.data.stride + this.offset ];\n\n\t},\n\n\tgetY: function ( index ) {\n\n\t\treturn this.data.array[ index * this.data.stride + this.offset + 1 ];\n\n\t},\n\n\tgetZ: function ( index ) {\n\n\t\treturn this.data.array[ index * this.data.stride + this.offset + 2 ];\n\n\t},\n\n\tgetW: function ( index ) {\n\n\t\treturn this.data.array[ index * this.data.stride + this.offset + 3 ];\n\n\t},\n\n\tsetXY: function ( index, x, y ) {\n\n\t\tindex = index * this.data.stride + this.offset;\n\n\t\tthis.data.array[ index + 0 ] = x;\n\t\tthis.data.array[ index + 1 ] = y;\n\n\t\treturn this;\n\n\t},\n\n\tsetXYZ: function ( index, x, y, z ) {\n\n\t\tindex = index * this.data.stride + this.offset;\n\n\t\tthis.data.array[ index + 0 ] = x;\n\t\tthis.data.array[ index + 1 ] = y;\n\t\tthis.data.array[ index + 2 ] = z;\n\n\t\treturn this;\n\n\t},\n\n\tsetXYZW: function ( index, x, y, z, w ) {\n\n\t\tindex = index * this.data.stride + this.offset;\n\n\t\tthis.data.array[ index + 0 ] = x;\n\t\tthis.data.array[ index + 1 ] = y;\n\t\tthis.data.array[ index + 2 ] = z;\n\t\tthis.data.array[ index + 3 ] = w;\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author benaadams / https://twitter.com/ben_a_adams\n */\n\nfunction InterleavedBuffer( array, stride ) {\n\n\tthis.array = array;\n\tthis.stride = stride;\n\tthis.count = array !== undefined ? array.length / stride : 0;\n\n\tthis.dynamic = false;\n\tthis.updateRange = { offset: 0, count: - 1 };\n\n\tthis.version = 0;\n\n}\n\nObject.defineProperty( InterleavedBuffer.prototype, 'needsUpdate', {\n\n\tset: function ( value ) {\n\n\t\tif ( value === true ) this.version ++;\n\n\t}\n\n} );\n\nObject.assign( InterleavedBuffer.prototype, {\n\n\tisInterleavedBuffer: true,\n\n\tonUploadCallback: function () {},\n\n\tsetArray: function ( array ) {\n\n\t\tif ( Array.isArray( array ) ) {\n\n\t\t\tthrow new TypeError( 'THREE.BufferAttribute: array should be a Typed Array.' );\n\n\t\t}\n\n\t\tthis.count = array !== undefined ? array.length / this.stride : 0;\n\t\tthis.array = array;\n\n\t\treturn this;\n\n\t},\n\n\tsetDynamic: function ( value ) {\n\n\t\tthis.dynamic = value;\n\n\t\treturn this;\n\n\t},\n\n\tcopy: function ( source ) {\n\n\t\tthis.array = new source.array.constructor( source.array );\n\t\tthis.count = source.count;\n\t\tthis.stride = source.stride;\n\t\tthis.dynamic = source.dynamic;\n\n\t\treturn this;\n\n\t},\n\n\tcopyAt: function ( index1, attribute, index2 ) {\n\n\t\tindex1 *= this.stride;\n\t\tindex2 *= attribute.stride;\n\n\t\tfor ( var i = 0, l = this.stride; i < l; i ++ ) {\n\n\t\t\tthis.array[ index1 + i ] = attribute.array[ index2 + i ];\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tset: function ( value, offset ) {\n\n\t\tif ( offset === undefined ) offset = 0;\n\n\t\tthis.array.set( value, offset );\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tonUpload: function ( callback ) {\n\n\t\tthis.onUploadCallback = callback;\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author benaadams / https://twitter.com/ben_a_adams\n */\n\nfunction InstancedInterleavedBuffer( array, stride, meshPerAttribute ) {\n\n\tInterleavedBuffer.call( this, array, stride );\n\n\tthis.meshPerAttribute = meshPerAttribute || 1;\n\n}\n\nInstancedInterleavedBuffer.prototype = Object.assign( Object.create( InterleavedBuffer.prototype ), {\n\n\tconstructor: InstancedInterleavedBuffer,\n\n\tisInstancedInterleavedBuffer: true,\n\n\tcopy: function ( source ) {\n\n\t\tInterleavedBuffer.prototype.copy.call( this, source );\n\n\t\tthis.meshPerAttribute = source.meshPerAttribute;\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author benaadams / https://twitter.com/ben_a_adams\n */\n\nfunction InstancedBufferAttribute( array, itemSize, meshPerAttribute ) {\n\n\tBufferAttribute.call( this, array, itemSize );\n\n\tthis.meshPerAttribute = meshPerAttribute || 1;\n\n}\n\nInstancedBufferAttribute.prototype = Object.assign( Object.create( BufferAttribute.prototype ), {\n\n\tconstructor: InstancedBufferAttribute,\n\n\tisInstancedBufferAttribute: true,\n\n\tcopy: function ( source ) {\n\n\t\tBufferAttribute.prototype.copy.call( this, source );\n\n\t\tthis.meshPerAttribute = source.meshPerAttribute;\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author bhouston / http://clara.io/\n * @author stephomi / http://stephaneginier.com/\n */\n\nfunction Raycaster( origin, direction, near, far ) {\n\n\tthis.ray = new Ray( origin, direction );\n\t// direction is assumed to be normalized (for accurate distance calculations)\n\n\tthis.near = near || 0;\n\tthis.far = far || Infinity;\n\n\tthis.params = {\n\t\tMesh: {},\n\t\tLine: {},\n\t\tLOD: {},\n\t\tPoints: { threshold: 1 },\n\t\tSprite: {}\n\t};\n\n\tObject.defineProperties( this.params, {\n\t\tPointCloud: {\n\t\t\tget: function () {\n\n\t\t\t\tconsole.warn( 'THREE.Raycaster: params.PointCloud has been renamed to params.Points.' );\n\t\t\t\treturn this.Points;\n\n\t\t\t}\n\t\t}\n\t} );\n\n}\n\nfunction ascSort( a, b ) {\n\n\treturn a.distance - b.distance;\n\n}\n\nfunction intersectObject( object, raycaster, intersects, recursive ) {\n\n\tif ( object.visible === false ) return;\n\n\tobject.raycast( raycaster, intersects );\n\n\tif ( recursive === true ) {\n\n\t\tvar children = object.children;\n\n\t\tfor ( var i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tintersectObject( children[ i ], raycaster, intersects, true );\n\n\t\t}\n\n\t}\n\n}\n\nObject.assign( Raycaster.prototype, {\n\n\tlinePrecision: 1,\n\n\tset: function ( origin, direction ) {\n\n\t\t// direction is assumed to be normalized (for accurate distance calculations)\n\n\t\tthis.ray.set( origin, direction );\n\n\t},\n\n\tsetFromCamera: function ( coords, camera ) {\n\n\t\tif ( ( camera && camera.isPerspectiveCamera ) ) {\n\n\t\t\tthis.ray.origin.setFromMatrixPosition( camera.matrixWorld );\n\t\t\tthis.ray.direction.set( coords.x, coords.y, 0.5 ).unproject( camera ).sub( this.ray.origin ).normalize();\n\n\t\t} else if ( ( camera && camera.isOrthographicCamera ) ) {\n\n\t\t\tthis.ray.origin.set( coords.x, coords.y, ( camera.near + camera.far ) / ( camera.near - camera.far ) ).unproject( camera ); // set origin in plane of camera\n\t\t\tthis.ray.direction.set( 0, 0, - 1 ).transformDirection( camera.matrixWorld );\n\n\t\t} else {\n\n\t\t\tconsole.error( 'THREE.Raycaster: Unsupported camera type.' );\n\n\t\t}\n\n\t},\n\n\tintersectObject: function ( object, recursive, optionalTarget ) {\n\n\t\tvar intersects = optionalTarget || [];\n\n\t\tintersectObject( object, this, intersects, recursive );\n\n\t\tintersects.sort( ascSort );\n\n\t\treturn intersects;\n\n\t},\n\n\tintersectObjects: function ( objects, recursive, optionalTarget ) {\n\n\t\tvar intersects = optionalTarget || [];\n\n\t\tif ( Array.isArray( objects ) === false ) {\n\n\t\t\tconsole.warn( 'THREE.Raycaster.intersectObjects: objects is not an Array.' );\n\t\t\treturn intersects;\n\n\t\t}\n\n\t\tfor ( var i = 0, l = objects.length; i < l; i ++ ) {\n\n\t\t\tintersectObject( objects[ i ], this, intersects, recursive );\n\n\t\t}\n\n\t\tintersects.sort( ascSort );\n\n\t\treturn intersects;\n\n\t}\n\n} );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction Clock( autoStart ) {\n\n\tthis.autoStart = ( autoStart !== undefined ) ? autoStart : true;\n\n\tthis.startTime = 0;\n\tthis.oldTime = 0;\n\tthis.elapsedTime = 0;\n\n\tthis.running = false;\n\n}\n\nObject.assign( Clock.prototype, {\n\n\tstart: function () {\n\n\t\tthis.startTime = ( typeof performance === 'undefined' ? Date : performance ).now(); // see #10732\n\n\t\tthis.oldTime = this.startTime;\n\t\tthis.elapsedTime = 0;\n\t\tthis.running = true;\n\n\t},\n\n\tstop: function () {\n\n\t\tthis.getElapsedTime();\n\t\tthis.running = false;\n\t\tthis.autoStart = false;\n\n\t},\n\n\tgetElapsedTime: function () {\n\n\t\tthis.getDelta();\n\t\treturn this.elapsedTime;\n\n\t},\n\n\tgetDelta: function () {\n\n\t\tvar diff = 0;\n\n\t\tif ( this.autoStart && ! this.running ) {\n\n\t\t\tthis.start();\n\t\t\treturn 0;\n\n\t\t}\n\n\t\tif ( this.running ) {\n\n\t\t\tvar newTime = ( typeof performance === 'undefined' ? Date : performance ).now();\n\n\t\t\tdiff = ( newTime - this.oldTime ) / 1000;\n\t\t\tthis.oldTime = newTime;\n\n\t\t\tthis.elapsedTime += diff;\n\n\t\t}\n\n\t\treturn diff;\n\n\t}\n\n} );\n\n/**\n * @author bhouston / http://clara.io\n * @author WestLangley / http://github.com/WestLangley\n *\n * Ref: https://en.wikipedia.org/wiki/Spherical_coordinate_system\n *\n * The poles (phi) are at the positive and negative y axis.\n * The equator starts at positive z.\n */\n\nfunction Spherical( radius, phi, theta ) {\n\n\tthis.radius = ( radius !== undefined ) ? radius : 1.0;\n\tthis.phi = ( phi !== undefined ) ? phi : 0; // up / down towards top and bottom pole\n\tthis.theta = ( theta !== undefined ) ? theta : 0; // around the equator of the sphere\n\n\treturn this;\n\n}\n\nObject.assign( Spherical.prototype, {\n\n\tset: function ( radius, phi, theta ) {\n\n\t\tthis.radius = radius;\n\t\tthis.phi = phi;\n\t\tthis.theta = theta;\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( other ) {\n\n\t\tthis.radius = other.radius;\n\t\tthis.phi = other.phi;\n\t\tthis.theta = other.theta;\n\n\t\treturn this;\n\n\t},\n\n\t// restrict phi to be betwee EPS and PI-EPS\n\tmakeSafe: function () {\n\n\t\tvar EPS = 0.000001;\n\t\tthis.phi = Math.max( EPS, Math.min( Math.PI - EPS, this.phi ) );\n\n\t\treturn this;\n\n\t},\n\n\tsetFromVector3: function ( vec3 ) {\n\n\t\tthis.radius = vec3.length();\n\n\t\tif ( this.radius === 0 ) {\n\n\t\t\tthis.theta = 0;\n\t\t\tthis.phi = 0;\n\n\t\t} else {\n\n\t\t\tthis.theta = Math.atan2( vec3.x, vec3.z ); // equator angle around y-up axis\n\t\t\tthis.phi = Math.acos( _Math.clamp( vec3.y / this.radius, - 1, 1 ) ); // polar angle\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author Mugen87 / https://github.com/Mugen87\n *\n * Ref: https://en.wikipedia.org/wiki/Cylindrical_coordinate_system\n *\n */\n\nfunction Cylindrical( radius, theta, y ) {\n\n\tthis.radius = ( radius !== undefined ) ? radius : 1.0; // distance from the origin to a point in the x-z plane\n\tthis.theta = ( theta !== undefined ) ? theta : 0; // counterclockwise angle in the x-z plane measured in radians from the positive z-axis\n\tthis.y = ( y !== undefined ) ? y : 0; // height above the x-z plane\n\n\treturn this;\n\n}\n\nObject.assign( Cylindrical.prototype, {\n\n\tset: function ( radius, theta, y ) {\n\n\t\tthis.radius = radius;\n\t\tthis.theta = theta;\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t},\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( other ) {\n\n\t\tthis.radius = other.radius;\n\t\tthis.theta = other.theta;\n\t\tthis.y = other.y;\n\n\t\treturn this;\n\n\t},\n\n\tsetFromVector3: function ( vec3 ) {\n\n\t\tthis.radius = Math.sqrt( vec3.x * vec3.x + vec3.z * vec3.z );\n\t\tthis.theta = Math.atan2( vec3.x, vec3.z );\n\t\tthis.y = vec3.y;\n\n\t\treturn this;\n\n\t}\n\n} );\n\n/**\n * @author bhouston / http://clara.io\n */\n\nfunction Box2( min, max ) {\n\n\tthis.min = ( min !== undefined ) ? min : new Vector2( + Infinity, + Infinity );\n\tthis.max = ( max !== undefined ) ? max : new Vector2( - Infinity, - Infinity );\n\n}\n\nObject.assign( Box2.prototype, {\n\n\tset: function ( min, max ) {\n\n\t\tthis.min.copy( min );\n\t\tthis.max.copy( max );\n\n\t\treturn this;\n\n\t},\n\n\tsetFromPoints: function ( points ) {\n\n\t\tthis.makeEmpty();\n\n\t\tfor ( var i = 0, il = points.length; i < il; i ++ ) {\n\n\t\t\tthis.expandByPoint( points[ i ] );\n\n\t\t}\n\n\t\treturn this;\n\n\t},\n\n\tsetFromCenterAndSize: function () {\n\n\t\tvar v1 = new Vector2();\n\n\t\treturn function setFromCenterAndSize( center, size ) {\n\n\t\t\tvar halfSize = v1.copy( size ).multiplyScalar( 0.5 );\n\t\t\tthis.min.copy( center ).sub( halfSize );\n\t\t\tthis.max.copy( center ).add( halfSize );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t}(),\n\n\tclone: function () {\n\n\t\treturn new this.constructor().copy( this );\n\n\t},\n\n\tcopy: function ( box ) {\n\n\t\tthis.min.copy( box.min );\n\t\tthis.max.copy( box.max );\n\n\t\treturn this;\n\n\t},\n\n\tmakeEmpty: function () {\n\n\t\tthis.min.x = this.min.y = + Infinity;\n\t\tthis.max.x = this.max.y = - Infinity;\n\n\t\treturn this;\n\n\t},\n\n\tisEmpty: function () {\n\n\t\t// this is a more robust check for empty than ( volume <= 0 ) because volume can get positive with two negative axes\n\n\t\treturn ( this.max.x < this.min.x ) || ( this.max.y < this.min.y );\n\n\t},\n\n\tgetCenter: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Box2: .getCenter() target is now required' );\n\t\t\ttarget = new Vector2();\n\n\t\t}\n\n\t\treturn this.isEmpty() ? target.set( 0, 0 ) : target.addVectors( this.min, this.max ).multiplyScalar( 0.5 );\n\n\t},\n\n\tgetSize: function ( target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Box2: .getSize() target is now required' );\n\t\t\ttarget = new Vector2();\n\n\t\t}\n\n\t\treturn this.isEmpty() ? target.set( 0, 0 ) : target.subVectors( this.max, this.min );\n\n\t},\n\n\texpandByPoint: function ( point ) {\n\n\t\tthis.min.min( point );\n\t\tthis.max.max( point );\n\n\t\treturn this;\n\n\t},\n\n\texpandByVector: function ( vector ) {\n\n\t\tthis.min.sub( vector );\n\t\tthis.max.add( vector );\n\n\t\treturn this;\n\n\t},\n\n\texpandByScalar: function ( scalar ) {\n\n\t\tthis.min.addScalar( - scalar );\n\t\tthis.max.addScalar( scalar );\n\n\t\treturn this;\n\n\t},\n\n\tcontainsPoint: function ( point ) {\n\n\t\treturn point.x < this.min.x || point.x > this.max.x ||\n\t\t\tpoint.y < this.min.y || point.y > this.max.y ? false : true;\n\n\t},\n\n\tcontainsBox: function ( box ) {\n\n\t\treturn this.min.x <= box.min.x && box.max.x <= this.max.x &&\n\t\t\tthis.min.y <= box.min.y && box.max.y <= this.max.y;\n\n\t},\n\n\tgetParameter: function ( point, target ) {\n\n\t\t// This can potentially have a divide by zero if the box\n\t\t// has a size dimension of 0.\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Box2: .getParameter() target is now required' );\n\t\t\ttarget = new Vector2();\n\n\t\t}\n\n\t\treturn target.set(\n\t\t\t( point.x - this.min.x ) / ( this.max.x - this.min.x ),\n\t\t\t( point.y - this.min.y ) / ( this.max.y - this.min.y )\n\t\t);\n\n\t},\n\n\tintersectsBox: function ( box ) {\n\n\t\t// using 4 splitting planes to rule out intersections\n\n\t\treturn box.max.x < this.min.x || box.min.x > this.max.x ||\n\t\t\tbox.max.y < this.min.y || box.min.y > this.max.y ? false : true;\n\n\t},\n\n\tclampPoint: function ( point, target ) {\n\n\t\tif ( target === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Box2: .clampPoint() target is now required' );\n\t\t\ttarget = new Vector2();\n\n\t\t}\n\n\t\treturn target.copy( point ).clamp( this.min, this.max );\n\n\t},\n\n\tdistanceToPoint: function () {\n\n\t\tvar v1 = new Vector2();\n\n\t\treturn function distanceToPoint( point ) {\n\n\t\t\tvar clampedPoint = v1.copy( point ).clamp( this.min, this.max );\n\t\t\treturn clampedPoint.sub( point ).length();\n\n\t\t};\n\n\t}(),\n\n\tintersect: function ( box ) {\n\n\t\tthis.min.max( box.min );\n\t\tthis.max.min( box.max );\n\n\t\treturn this;\n\n\t},\n\n\tunion: function ( box ) {\n\n\t\tthis.min.min( box.min );\n\t\tthis.max.max( box.max );\n\n\t\treturn this;\n\n\t},\n\n\ttranslate: function ( offset ) {\n\n\t\tthis.min.add( offset );\n\t\tthis.max.add( offset );\n\n\t\treturn this;\n\n\t},\n\n\tequals: function ( box ) {\n\n\t\treturn box.min.equals( this.min ) && box.max.equals( this.max );\n\n\t}\n\n} );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n */\n\nfunction ImmediateRenderObject( material ) {\n\n\tObject3D.call( this );\n\n\tthis.material = material;\n\tthis.render = function ( /* renderCallback */ ) {};\n\n}\n\nImmediateRenderObject.prototype = Object.create( Object3D.prototype );\nImmediateRenderObject.prototype.constructor = ImmediateRenderObject;\n\nImmediateRenderObject.prototype.isImmediateRenderObject = true;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction VertexNormalsHelper( object, size, hex, linewidth ) {\n\n\tthis.object = object;\n\n\tthis.size = ( size !== undefined ) ? size : 1;\n\n\tvar color = ( hex !== undefined ) ? hex : 0xff0000;\n\n\tvar width = ( linewidth !== undefined ) ? linewidth : 1;\n\n\t//\n\n\tvar nNormals = 0;\n\n\tvar objGeometry = this.object.geometry;\n\n\tif ( objGeometry && objGeometry.isGeometry ) {\n\n\t\tnNormals = objGeometry.faces.length * 3;\n\n\t} else if ( objGeometry && objGeometry.isBufferGeometry ) {\n\n\t\tnNormals = objGeometry.attributes.normal.count;\n\n\t}\n\n\t//\n\n\tvar geometry = new BufferGeometry();\n\n\tvar positions = new Float32BufferAttribute( nNormals * 2 * 3, 3 );\n\n\tgeometry.addAttribute( 'position', positions );\n\n\tLineSegments.call( this, geometry, new LineBasicMaterial( { color: color, linewidth: width } ) );\n\n\t//\n\n\tthis.matrixAutoUpdate = false;\n\n\tthis.update();\n\n}\n\nVertexNormalsHelper.prototype = Object.create( LineSegments.prototype );\nVertexNormalsHelper.prototype.constructor = VertexNormalsHelper;\n\nVertexNormalsHelper.prototype.update = ( function () {\n\n\tvar v1 = new Vector3();\n\tvar v2 = new Vector3();\n\tvar normalMatrix = new Matrix3();\n\n\treturn function update() {\n\n\t\tvar keys = [ 'a', 'b', 'c' ];\n\n\t\tthis.object.updateMatrixWorld( true );\n\n\t\tnormalMatrix.getNormalMatrix( this.object.matrixWorld );\n\n\t\tvar matrixWorld = this.object.matrixWorld;\n\n\t\tvar position = this.geometry.attributes.position;\n\n\t\t//\n\n\t\tvar objGeometry = this.object.geometry;\n\n\t\tif ( objGeometry && objGeometry.isGeometry ) {\n\n\t\t\tvar vertices = objGeometry.vertices;\n\n\t\t\tvar faces = objGeometry.faces;\n\n\t\t\tvar idx = 0;\n\n\t\t\tfor ( var i = 0, l = faces.length; i < l; i ++ ) {\n\n\t\t\t\tvar face = faces[ i ];\n\n\t\t\t\tfor ( var j = 0, jl = face.vertexNormals.length; j < jl; j ++ ) {\n\n\t\t\t\t\tvar vertex = vertices[ face[ keys[ j ] ] ];\n\n\t\t\t\t\tvar normal = face.vertexNormals[ j ];\n\n\t\t\t\t\tv1.copy( vertex ).applyMatrix4( matrixWorld );\n\n\t\t\t\t\tv2.copy( normal ).applyMatrix3( normalMatrix ).normalize().multiplyScalar( this.size ).add( v1 );\n\n\t\t\t\t\tposition.setXYZ( idx, v1.x, v1.y, v1.z );\n\n\t\t\t\t\tidx = idx + 1;\n\n\t\t\t\t\tposition.setXYZ( idx, v2.x, v2.y, v2.z );\n\n\t\t\t\t\tidx = idx + 1;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else if ( objGeometry && objGeometry.isBufferGeometry ) {\n\n\t\t\tvar objPos = objGeometry.attributes.position;\n\n\t\t\tvar objNorm = objGeometry.attributes.normal;\n\n\t\t\tvar idx = 0;\n\n\t\t\t// for simplicity, ignore index and drawcalls, and render every normal\n\n\t\t\tfor ( var j = 0, jl = objPos.count; j < jl; j ++ ) {\n\n\t\t\t\tv1.set( objPos.getX( j ), objPos.getY( j ), objPos.getZ( j ) ).applyMatrix4( matrixWorld );\n\n\t\t\t\tv2.set( objNorm.getX( j ), objNorm.getY( j ), objNorm.getZ( j ) );\n\n\t\t\t\tv2.applyMatrix3( normalMatrix ).normalize().multiplyScalar( this.size ).add( v1 );\n\n\t\t\t\tposition.setXYZ( idx, v1.x, v1.y, v1.z );\n\n\t\t\t\tidx = idx + 1;\n\n\t\t\t\tposition.setXYZ( idx, v2.x, v2.y, v2.z );\n\n\t\t\t\tidx = idx + 1;\n\n\t\t\t}\n\n\t\t}\n\n\t\tposition.needsUpdate = true;\n\n\t};\n\n}() );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author mrdoob / http://mrdoob.com/\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction SpotLightHelper( light, color ) {\n\n\tObject3D.call( this );\n\n\tthis.light = light;\n\tthis.light.updateMatrixWorld();\n\n\tthis.matrix = light.matrixWorld;\n\tthis.matrixAutoUpdate = false;\n\n\tthis.color = color;\n\n\tvar geometry = new BufferGeometry();\n\n\tvar positions = [\n\t\t0, 0, 0, \t0, 0, 1,\n\t\t0, 0, 0, \t1, 0, 1,\n\t\t0, 0, 0,\t- 1, 0, 1,\n\t\t0, 0, 0, \t0, 1, 1,\n\t\t0, 0, 0, \t0, - 1, 1\n\t];\n\n\tfor ( var i = 0, j = 1, l = 32; i < l; i ++, j ++ ) {\n\n\t\tvar p1 = ( i / l ) * Math.PI * 2;\n\t\tvar p2 = ( j / l ) * Math.PI * 2;\n\n\t\tpositions.push(\n\t\t\tMath.cos( p1 ), Math.sin( p1 ), 1,\n\t\t\tMath.cos( p2 ), Math.sin( p2 ), 1\n\t\t);\n\n\t}\n\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( positions, 3 ) );\n\n\tvar material = new LineBasicMaterial( { fog: false } );\n\n\tthis.cone = new LineSegments( geometry, material );\n\tthis.add( this.cone );\n\n\tthis.update();\n\n}\n\nSpotLightHelper.prototype = Object.create( Object3D.prototype );\nSpotLightHelper.prototype.constructor = SpotLightHelper;\n\nSpotLightHelper.prototype.dispose = function () {\n\n\tthis.cone.geometry.dispose();\n\tthis.cone.material.dispose();\n\n};\n\nSpotLightHelper.prototype.update = function () {\n\n\tvar vector = new Vector3();\n\tvar vector2 = new Vector3();\n\n\treturn function update() {\n\n\t\tthis.light.updateMatrixWorld();\n\n\t\tvar coneLength = this.light.distance ? this.light.distance : 1000;\n\t\tvar coneWidth = coneLength * Math.tan( this.light.angle );\n\n\t\tthis.cone.scale.set( coneWidth, coneWidth, coneLength );\n\n\t\tvector.setFromMatrixPosition( this.light.matrixWorld );\n\t\tvector2.setFromMatrixPosition( this.light.target.matrixWorld );\n\n\t\tthis.cone.lookAt( vector2.sub( vector ) );\n\n\t\tif ( this.color !== undefined ) {\n\n\t\t\tthis.cone.material.color.set( this.color );\n\n\t\t} else {\n\n\t\t\tthis.cone.material.color.copy( this.light.color );\n\n\t\t}\n\n\t};\n\n}();\n\n/**\n * @author Sean Griffin / http://twitter.com/sgrif\n * @author Michael Guerrero / http://realitymeltdown.com\n * @author mrdoob / http://mrdoob.com/\n * @author ikerr / http://verold.com\n * @author Mugen87 / https://github.com/Mugen87\n */\n\nfunction getBoneList( object ) {\n\n\tvar boneList = [];\n\n\tif ( object && object.isBone ) {\n\n\t\tboneList.push( object );\n\n\t}\n\n\tfor ( var i = 0; i < object.children.length; i ++ ) {\n\n\t\tboneList.push.apply( boneList, getBoneList( object.children[ i ] ) );\n\n\t}\n\n\treturn boneList;\n\n}\n\nfunction SkeletonHelper( object ) {\n\n\tvar bones = getBoneList( object );\n\n\tvar geometry = new BufferGeometry();\n\n\tvar vertices = [];\n\tvar colors = [];\n\n\tvar color1 = new Color( 0, 0, 1 );\n\tvar color2 = new Color( 0, 1, 0 );\n\n\tfor ( var i = 0; i < bones.length; i ++ ) {\n\n\t\tvar bone = bones[ i ];\n\n\t\tif ( bone.parent && bone.parent.isBone ) {\n\n\t\t\tvertices.push( 0, 0, 0 );\n\t\t\tvertices.push( 0, 0, 0 );\n\t\t\tcolors.push( color1.r, color1.g, color1.b );\n\t\t\tcolors.push( color2.r, color2.g, color2.b );\n\n\t\t}\n\n\t}\n\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tgeometry.addAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\tvar material = new LineBasicMaterial( { vertexColors: VertexColors, depthTest: false, depthWrite: false, transparent: true } );\n\n\tLineSegments.call( this, geometry, material );\n\n\tthis.root = object;\n\tthis.bones = bones;\n\n\tthis.matrix = object.matrixWorld;\n\tthis.matrixAutoUpdate = false;\n\n}\n\nSkeletonHelper.prototype = Object.create( LineSegments.prototype );\nSkeletonHelper.prototype.constructor = SkeletonHelper;\n\nSkeletonHelper.prototype.updateMatrixWorld = function () {\n\n\tvar vector = new Vector3();\n\n\tvar boneMatrix = new Matrix4();\n\tvar matrixWorldInv = new Matrix4();\n\n\treturn function updateMatrixWorld( force ) {\n\n\t\tvar bones = this.bones;\n\n\t\tvar geometry = this.geometry;\n\t\tvar position = geometry.getAttribute( 'position' );\n\n\t\tmatrixWorldInv.getInverse( this.root.matrixWorld );\n\n\t\tfor ( var i = 0, j = 0; i < bones.length; i ++ ) {\n\n\t\t\tvar bone = bones[ i ];\n\n\t\t\tif ( bone.parent && bone.parent.isBone ) {\n\n\t\t\t\tboneMatrix.multiplyMatrices( matrixWorldInv, bone.matrixWorld );\n\t\t\t\tvector.setFromMatrixPosition( boneMatrix );\n\t\t\t\tposition.setXYZ( j, vector.x, vector.y, vector.z );\n\n\t\t\t\tboneMatrix.multiplyMatrices( matrixWorldInv, bone.parent.matrixWorld );\n\t\t\t\tvector.setFromMatrixPosition( boneMatrix );\n\t\t\t\tposition.setXYZ( j + 1, vector.x, vector.y, vector.z );\n\n\t\t\t\tj += 2;\n\n\t\t\t}\n\n\t\t}\n\n\t\tgeometry.getAttribute( 'position' ).needsUpdate = true;\n\n\t\tObject3D.prototype.updateMatrixWorld.call( this, force );\n\n\t};\n\n}();\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction PointLightHelper( light, sphereSize, color ) {\n\n\tthis.light = light;\n\tthis.light.updateMatrixWorld();\n\n\tthis.color = color;\n\n\tvar geometry = new SphereBufferGeometry( sphereSize, 4, 2 );\n\tvar material = new MeshBasicMaterial( { wireframe: true, fog: false } );\n\n\tMesh.call( this, geometry, material );\n\n\tthis.matrix = this.light.matrixWorld;\n\tthis.matrixAutoUpdate = false;\n\n\tthis.update();\n\n\n\t/*\n\tvar distanceGeometry = new THREE.IcosahedronGeometry( 1, 2 );\n\tvar distanceMaterial = new THREE.MeshBasicMaterial( { color: hexColor, fog: false, wireframe: true, opacity: 0.1, transparent: true } );\n\n\tthis.lightSphere = new THREE.Mesh( bulbGeometry, bulbMaterial );\n\tthis.lightDistance = new THREE.Mesh( distanceGeometry, distanceMaterial );\n\n\tvar d = light.distance;\n\n\tif ( d === 0.0 ) {\n\n\t\tthis.lightDistance.visible = false;\n\n\t} else {\n\n\t\tthis.lightDistance.scale.set( d, d, d );\n\n\t}\n\n\tthis.add( this.lightDistance );\n\t*/\n\n}\n\nPointLightHelper.prototype = Object.create( Mesh.prototype );\nPointLightHelper.prototype.constructor = PointLightHelper;\n\nPointLightHelper.prototype.dispose = function () {\n\n\tthis.geometry.dispose();\n\tthis.material.dispose();\n\n};\n\nPointLightHelper.prototype.update = function () {\n\n\tif ( this.color !== undefined ) {\n\n\t\tthis.material.color.set( this.color );\n\n\t} else {\n\n\t\tthis.material.color.copy( this.light.color );\n\n\t}\n\n\t/*\n\tvar d = this.light.distance;\n\n\tif ( d === 0.0 ) {\n\n\t\tthis.lightDistance.visible = false;\n\n\t} else {\n\n\t\tthis.lightDistance.visible = true;\n\t\tthis.lightDistance.scale.set( d, d, d );\n\n\t}\n\t*/\n\n};\n\n/**\n * @author abelnation / http://github.com/abelnation\n * @author Mugen87 / http://github.com/Mugen87\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction RectAreaLightHelper( light, color ) {\n\n\tObject3D.call( this );\n\n\tthis.light = light;\n\tthis.light.updateMatrixWorld();\n\n\tthis.matrix = light.matrixWorld;\n\tthis.matrixAutoUpdate = false;\n\n\tthis.color = color;\n\n\tvar material = new LineBasicMaterial( { fog: false } );\n\n\tvar geometry = new BufferGeometry();\n\n\tgeometry.addAttribute( 'position', new BufferAttribute( new Float32Array( 5 * 3 ), 3 ) );\n\n\tthis.line = new Line( geometry, material );\n\tthis.add( this.line );\n\n\n\tthis.update();\n\n}\n\nRectAreaLightHelper.prototype = Object.create( Object3D.prototype );\nRectAreaLightHelper.prototype.constructor = RectAreaLightHelper;\n\nRectAreaLightHelper.prototype.dispose = function () {\n\n\tthis.children[ 0 ].geometry.dispose();\n\tthis.children[ 0 ].material.dispose();\n\n};\n\nRectAreaLightHelper.prototype.update = function () {\n\n\t// calculate new dimensions of the helper\n\n\tvar hx = this.light.width * 0.5;\n\tvar hy = this.light.height * 0.5;\n\n\tvar position = this.line.geometry.attributes.position;\n\tvar array = position.array;\n\n\t// update vertices\n\n\tarray[ 0 ] = hx; array[ 1 ] = - hy; array[ 2 ] = 0;\n\tarray[ 3 ] = hx; array[ 4 ] = hy; array[ 5 ] = 0;\n\tarray[ 6 ] = - hx; array[ 7 ] = hy; array[ 8 ] = 0;\n\tarray[ 9 ] = - hx; array[ 10 ] = - hy; array[ 11 ] = 0;\n\tarray[ 12 ] = hx; array[ 13 ] = - hy; array[ 14 ] = 0;\n\n\tposition.needsUpdate = true;\n\n\tif ( this.color !== undefined ) {\n\n\t\tthis.line.material.color.set( this.color );\n\n\t} else {\n\n\t\tthis.line.material.color.copy( this.light.color );\n\n\t}\n\n};\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author mrdoob / http://mrdoob.com/\n * @author Mugen87 / https://github.com/Mugen87\n */\n\nfunction HemisphereLightHelper( light, size, color ) {\n\n\tObject3D.call( this );\n\n\tthis.light = light;\n\tthis.light.updateMatrixWorld();\n\n\tthis.matrix = light.matrixWorld;\n\tthis.matrixAutoUpdate = false;\n\n\tthis.color = color;\n\n\tvar geometry = new OctahedronBufferGeometry( size );\n\tgeometry.rotateY( Math.PI * 0.5 );\n\n\tthis.material = new MeshBasicMaterial( { wireframe: true, fog: false } );\n\tif ( this.color === undefined ) this.material.vertexColors = VertexColors;\n\n\tvar position = geometry.getAttribute( 'position' );\n\tvar colors = new Float32Array( position.count * 3 );\n\n\tgeometry.addAttribute( 'color', new BufferAttribute( colors, 3 ) );\n\n\tthis.add( new Mesh( geometry, this.material ) );\n\n\tthis.update();\n\n}\n\nHemisphereLightHelper.prototype = Object.create( Object3D.prototype );\nHemisphereLightHelper.prototype.constructor = HemisphereLightHelper;\n\nHemisphereLightHelper.prototype.dispose = function () {\n\n\tthis.children[ 0 ].geometry.dispose();\n\tthis.children[ 0 ].material.dispose();\n\n};\n\nHemisphereLightHelper.prototype.update = function () {\n\n\tvar vector = new Vector3();\n\n\tvar color1 = new Color();\n\tvar color2 = new Color();\n\n\treturn function update() {\n\n\t\tvar mesh = this.children[ 0 ];\n\n\t\tif ( this.color !== undefined ) {\n\n\t\t\tthis.material.color.set( this.color );\n\n\t\t} else {\n\n\t\t\tvar colors = mesh.geometry.getAttribute( 'color' );\n\n\t\t\tcolor1.copy( this.light.color );\n\t\t\tcolor2.copy( this.light.groundColor );\n\n\t\t\tfor ( var i = 0, l = colors.count; i < l; i ++ ) {\n\n\t\t\t\tvar color = ( i < ( l / 2 ) ) ? color1 : color2;\n\n\t\t\t\tcolors.setXYZ( i, color.r, color.g, color.b );\n\n\t\t\t}\n\n\t\t\tcolors.needsUpdate = true;\n\n\t\t}\n\n\t\tmesh.lookAt( vector.setFromMatrixPosition( this.light.matrixWorld ).negate() );\n\n\t};\n\n}();\n\n/**\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction GridHelper( size, divisions, color1, color2 ) {\n\n\tsize = size || 10;\n\tdivisions = divisions || 10;\n\tcolor1 = new Color( color1 !== undefined ? color1 : 0x444444 );\n\tcolor2 = new Color( color2 !== undefined ? color2 : 0x888888 );\n\n\tvar center = divisions / 2;\n\tvar step = size / divisions;\n\tvar halfSize = size / 2;\n\n\tvar vertices = [], colors = [];\n\n\tfor ( var i = 0, j = 0, k = - halfSize; i <= divisions; i ++, k += step ) {\n\n\t\tvertices.push( - halfSize, 0, k, halfSize, 0, k );\n\t\tvertices.push( k, 0, - halfSize, k, 0, halfSize );\n\n\t\tvar color = i === center ? color1 : color2;\n\n\t\tcolor.toArray( colors, j ); j += 3;\n\t\tcolor.toArray( colors, j ); j += 3;\n\t\tcolor.toArray( colors, j ); j += 3;\n\t\tcolor.toArray( colors, j ); j += 3;\n\n\t}\n\n\tvar geometry = new BufferGeometry();\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tgeometry.addAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\tvar material = new LineBasicMaterial( { vertexColors: VertexColors } );\n\n\tLineSegments.call( this, geometry, material );\n\n}\n\nGridHelper.prototype = Object.create( LineSegments.prototype );\nGridHelper.prototype.constructor = GridHelper;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author Mugen87 / http://github.com/Mugen87\n * @author Hectate / http://www.github.com/Hectate\n */\n\nfunction PolarGridHelper( radius, radials, circles, divisions, color1, color2 ) {\n\n\tradius = radius || 10;\n\tradials = radials || 16;\n\tcircles = circles || 8;\n\tdivisions = divisions || 64;\n\tcolor1 = new Color( color1 !== undefined ? color1 : 0x444444 );\n\tcolor2 = new Color( color2 !== undefined ? color2 : 0x888888 );\n\n\tvar vertices = [];\n\tvar colors = [];\n\n\tvar x, z;\n\tvar v, i, j, r, color;\n\n\t// create the radials\n\n\tfor ( i = 0; i <= radials; i ++ ) {\n\n\t\tv = ( i / radials ) * ( Math.PI * 2 );\n\n\t\tx = Math.sin( v ) * radius;\n\t\tz = Math.cos( v ) * radius;\n\n\t\tvertices.push( 0, 0, 0 );\n\t\tvertices.push( x, 0, z );\n\n\t\tcolor = ( i & 1 ) ? color1 : color2;\n\n\t\tcolors.push( color.r, color.g, color.b );\n\t\tcolors.push( color.r, color.g, color.b );\n\n\t}\n\n\t// create the circles\n\n\tfor ( i = 0; i <= circles; i ++ ) {\n\n\t\tcolor = ( i & 1 ) ? color1 : color2;\n\n\t\tr = radius - ( radius / circles * i );\n\n\t\tfor ( j = 0; j < divisions; j ++ ) {\n\n\t\t\t// first vertex\n\n\t\t\tv = ( j / divisions ) * ( Math.PI * 2 );\n\n\t\t\tx = Math.sin( v ) * r;\n\t\t\tz = Math.cos( v ) * r;\n\n\t\t\tvertices.push( x, 0, z );\n\t\t\tcolors.push( color.r, color.g, color.b );\n\n\t\t\t// second vertex\n\n\t\t\tv = ( ( j + 1 ) / divisions ) * ( Math.PI * 2 );\n\n\t\t\tx = Math.sin( v ) * r;\n\t\t\tz = Math.cos( v ) * r;\n\n\t\t\tvertices.push( x, 0, z );\n\t\t\tcolors.push( color.r, color.g, color.b );\n\n\t\t}\n\n\t}\n\n\tvar geometry = new BufferGeometry();\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tgeometry.addAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\tvar material = new LineBasicMaterial( { vertexColors: VertexColors } );\n\n\tLineSegments.call( this, geometry, material );\n\n}\n\nPolarGridHelper.prototype = Object.create( LineSegments.prototype );\nPolarGridHelper.prototype.constructor = PolarGridHelper;\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction FaceNormalsHelper( object, size, hex, linewidth ) {\n\n\t// FaceNormalsHelper only supports THREE.Geometry\n\n\tthis.object = object;\n\n\tthis.size = ( size !== undefined ) ? size : 1;\n\n\tvar color = ( hex !== undefined ) ? hex : 0xffff00;\n\n\tvar width = ( linewidth !== undefined ) ? linewidth : 1;\n\n\t//\n\n\tvar nNormals = 0;\n\n\tvar objGeometry = this.object.geometry;\n\n\tif ( objGeometry && objGeometry.isGeometry ) {\n\n\t\tnNormals = objGeometry.faces.length;\n\n\t} else {\n\n\t\tconsole.warn( 'THREE.FaceNormalsHelper: only THREE.Geometry is supported. Use THREE.VertexNormalsHelper, instead.' );\n\n\t}\n\n\t//\n\n\tvar geometry = new BufferGeometry();\n\n\tvar positions = new Float32BufferAttribute( nNormals * 2 * 3, 3 );\n\n\tgeometry.addAttribute( 'position', positions );\n\n\tLineSegments.call( this, geometry, new LineBasicMaterial( { color: color, linewidth: width } ) );\n\n\t//\n\n\tthis.matrixAutoUpdate = false;\n\tthis.update();\n\n}\n\nFaceNormalsHelper.prototype = Object.create( LineSegments.prototype );\nFaceNormalsHelper.prototype.constructor = FaceNormalsHelper;\n\nFaceNormalsHelper.prototype.update = ( function () {\n\n\tvar v1 = new Vector3();\n\tvar v2 = new Vector3();\n\tvar normalMatrix = new Matrix3();\n\n\treturn function update() {\n\n\t\tthis.object.updateMatrixWorld( true );\n\n\t\tnormalMatrix.getNormalMatrix( this.object.matrixWorld );\n\n\t\tvar matrixWorld = this.object.matrixWorld;\n\n\t\tvar position = this.geometry.attributes.position;\n\n\t\t//\n\n\t\tvar objGeometry = this.object.geometry;\n\n\t\tvar vertices = objGeometry.vertices;\n\n\t\tvar faces = objGeometry.faces;\n\n\t\tvar idx = 0;\n\n\t\tfor ( var i = 0, l = faces.length; i < l; i ++ ) {\n\n\t\t\tvar face = faces[ i ];\n\n\t\t\tvar normal = face.normal;\n\n\t\t\tv1.copy( vertices[ face.a ] )\n\t\t\t\t.add( vertices[ face.b ] )\n\t\t\t\t.add( vertices[ face.c ] )\n\t\t\t\t.divideScalar( 3 )\n\t\t\t\t.applyMatrix4( matrixWorld );\n\n\t\t\tv2.copy( normal ).applyMatrix3( normalMatrix ).normalize().multiplyScalar( this.size ).add( v1 );\n\n\t\t\tposition.setXYZ( idx, v1.x, v1.y, v1.z );\n\n\t\t\tidx = idx + 1;\n\n\t\t\tposition.setXYZ( idx, v2.x, v2.y, v2.z );\n\n\t\t\tidx = idx + 1;\n\n\t\t}\n\n\t\tposition.needsUpdate = true;\n\n\t};\n\n}() );\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author mrdoob / http://mrdoob.com/\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction DirectionalLightHelper( light, size, color ) {\n\n\tObject3D.call( this );\n\n\tthis.light = light;\n\tthis.light.updateMatrixWorld();\n\n\tthis.matrix = light.matrixWorld;\n\tthis.matrixAutoUpdate = false;\n\n\tthis.color = color;\n\n\tif ( size === undefined ) size = 1;\n\n\tvar geometry = new BufferGeometry();\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( [\n\t\t- size, size, 0,\n\t\tsize, size, 0,\n\t\tsize, - size, 0,\n\t\t- size, - size, 0,\n\t\t- size, size, 0\n\t], 3 ) );\n\n\tvar material = new LineBasicMaterial( { fog: false } );\n\n\tthis.lightPlane = new Line( geometry, material );\n\tthis.add( this.lightPlane );\n\n\tgeometry = new BufferGeometry();\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( [ 0, 0, 0, 0, 0, 1 ], 3 ) );\n\n\tthis.targetLine = new Line( geometry, material );\n\tthis.add( this.targetLine );\n\n\tthis.update();\n\n}\n\nDirectionalLightHelper.prototype = Object.create( Object3D.prototype );\nDirectionalLightHelper.prototype.constructor = DirectionalLightHelper;\n\nDirectionalLightHelper.prototype.dispose = function () {\n\n\tthis.lightPlane.geometry.dispose();\n\tthis.lightPlane.material.dispose();\n\tthis.targetLine.geometry.dispose();\n\tthis.targetLine.material.dispose();\n\n};\n\nDirectionalLightHelper.prototype.update = function () {\n\n\tvar v1 = new Vector3();\n\tvar v2 = new Vector3();\n\tvar v3 = new Vector3();\n\n\treturn function update() {\n\n\t\tv1.setFromMatrixPosition( this.light.matrixWorld );\n\t\tv2.setFromMatrixPosition( this.light.target.matrixWorld );\n\t\tv3.subVectors( v2, v1 );\n\n\t\tthis.lightPlane.lookAt( v3 );\n\n\t\tif ( this.color !== undefined ) {\n\n\t\t\tthis.lightPlane.material.color.set( this.color );\n\t\t\tthis.targetLine.material.color.set( this.color );\n\n\t\t} else {\n\n\t\t\tthis.lightPlane.material.color.copy( this.light.color );\n\t\t\tthis.targetLine.material.color.copy( this.light.color );\n\n\t\t}\n\n\t\tthis.targetLine.lookAt( v3 );\n\t\tthis.targetLine.scale.z = v3.length();\n\n\t};\n\n}();\n\n/**\n * @author alteredq / http://alteredqualia.com/\n * @author Mugen87 / https://github.com/Mugen87\n *\n *\t- shows frustum, line of sight and up of the camera\n *\t- suitable for fast updates\n * \t- based on frustum visualization in lightgl.js shadowmap example\n *\t\thttp://evanw.github.com/lightgl.js/tests/shadowmap.html\n */\n\nfunction CameraHelper( camera ) {\n\n\tvar geometry = new BufferGeometry();\n\tvar material = new LineBasicMaterial( { color: 0xffffff, vertexColors: FaceColors } );\n\n\tvar vertices = [];\n\tvar colors = [];\n\n\tvar pointMap = {};\n\n\t// colors\n\n\tvar colorFrustum = new Color( 0xffaa00 );\n\tvar colorCone = new Color( 0xff0000 );\n\tvar colorUp = new Color( 0x00aaff );\n\tvar colorTarget = new Color( 0xffffff );\n\tvar colorCross = new Color( 0x333333 );\n\n\t// near\n\n\taddLine( 'n1', 'n2', colorFrustum );\n\taddLine( 'n2', 'n4', colorFrustum );\n\taddLine( 'n4', 'n3', colorFrustum );\n\taddLine( 'n3', 'n1', colorFrustum );\n\n\t// far\n\n\taddLine( 'f1', 'f2', colorFrustum );\n\taddLine( 'f2', 'f4', colorFrustum );\n\taddLine( 'f4', 'f3', colorFrustum );\n\taddLine( 'f3', 'f1', colorFrustum );\n\n\t// sides\n\n\taddLine( 'n1', 'f1', colorFrustum );\n\taddLine( 'n2', 'f2', colorFrustum );\n\taddLine( 'n3', 'f3', colorFrustum );\n\taddLine( 'n4', 'f4', colorFrustum );\n\n\t// cone\n\n\taddLine( 'p', 'n1', colorCone );\n\taddLine( 'p', 'n2', colorCone );\n\taddLine( 'p', 'n3', colorCone );\n\taddLine( 'p', 'n4', colorCone );\n\n\t// up\n\n\taddLine( 'u1', 'u2', colorUp );\n\taddLine( 'u2', 'u3', colorUp );\n\taddLine( 'u3', 'u1', colorUp );\n\n\t// target\n\n\taddLine( 'c', 't', colorTarget );\n\taddLine( 'p', 'c', colorCross );\n\n\t// cross\n\n\taddLine( 'cn1', 'cn2', colorCross );\n\taddLine( 'cn3', 'cn4', colorCross );\n\n\taddLine( 'cf1', 'cf2', colorCross );\n\taddLine( 'cf3', 'cf4', colorCross );\n\n\tfunction addLine( a, b, color ) {\n\n\t\taddPoint( a, color );\n\t\taddPoint( b, color );\n\n\t}\n\n\tfunction addPoint( id, color ) {\n\n\t\tvertices.push( 0, 0, 0 );\n\t\tcolors.push( color.r, color.g, color.b );\n\n\t\tif ( pointMap[ id ] === undefined ) {\n\n\t\t\tpointMap[ id ] = [];\n\n\t\t}\n\n\t\tpointMap[ id ].push( ( vertices.length / 3 ) - 1 );\n\n\t}\n\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tgeometry.addAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\tLineSegments.call( this, geometry, material );\n\n\tthis.camera = camera;\n\tif ( this.camera.updateProjectionMatrix ) this.camera.updateProjectionMatrix();\n\n\tthis.matrix = camera.matrixWorld;\n\tthis.matrixAutoUpdate = false;\n\n\tthis.pointMap = pointMap;\n\n\tthis.update();\n\n}\n\nCameraHelper.prototype = Object.create( LineSegments.prototype );\nCameraHelper.prototype.constructor = CameraHelper;\n\nCameraHelper.prototype.update = function () {\n\n\tvar geometry, pointMap;\n\n\tvar vector = new Vector3();\n\tvar camera = new Camera();\n\n\tfunction setPoint( point, x, y, z ) {\n\n\t\tvector.set( x, y, z ).unproject( camera );\n\n\t\tvar points = pointMap[ point ];\n\n\t\tif ( points !== undefined ) {\n\n\t\t\tvar position = geometry.getAttribute( 'position' );\n\n\t\t\tfor ( var i = 0, l = points.length; i < l; i ++ ) {\n\n\t\t\t\tposition.setXYZ( points[ i ], vector.x, vector.y, vector.z );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\treturn function update() {\n\n\t\tgeometry = this.geometry;\n\t\tpointMap = this.pointMap;\n\n\t\tvar w = 1, h = 1;\n\n\t\t// we need just camera projection matrix\n\t\t// world matrix must be identity\n\n\t\tcamera.projectionMatrix.copy( this.camera.projectionMatrix );\n\n\t\t// center / target\n\n\t\tsetPoint( 'c', 0, 0, - 1 );\n\t\tsetPoint( 't', 0, 0, 1 );\n\n\t\t// near\n\n\t\tsetPoint( 'n1', - w, - h, - 1 );\n\t\tsetPoint( 'n2', w, - h, - 1 );\n\t\tsetPoint( 'n3', - w, h, - 1 );\n\t\tsetPoint( 'n4', w, h, - 1 );\n\n\t\t// far\n\n\t\tsetPoint( 'f1', - w, - h, 1 );\n\t\tsetPoint( 'f2', w, - h, 1 );\n\t\tsetPoint( 'f3', - w, h, 1 );\n\t\tsetPoint( 'f4', w, h, 1 );\n\n\t\t// up\n\n\t\tsetPoint( 'u1', w * 0.7, h * 1.1, - 1 );\n\t\tsetPoint( 'u2', - w * 0.7, h * 1.1, - 1 );\n\t\tsetPoint( 'u3', 0, h * 2, - 1 );\n\n\t\t// cross\n\n\t\tsetPoint( 'cf1', - w, 0, 1 );\n\t\tsetPoint( 'cf2', w, 0, 1 );\n\t\tsetPoint( 'cf3', 0, - h, 1 );\n\t\tsetPoint( 'cf4', 0, h, 1 );\n\n\t\tsetPoint( 'cn1', - w, 0, - 1 );\n\t\tsetPoint( 'cn2', w, 0, - 1 );\n\t\tsetPoint( 'cn3', 0, - h, - 1 );\n\t\tsetPoint( 'cn4', 0, h, - 1 );\n\n\t\tgeometry.getAttribute( 'position' ).needsUpdate = true;\n\n\t};\n\n}();\n\n/**\n * @author mrdoob / http://mrdoob.com/\n * @author Mugen87 / http://github.com/Mugen87\n */\n\nfunction BoxHelper( object, color ) {\n\n\tthis.object = object;\n\n\tif ( color === undefined ) color = 0xffff00;\n\n\tvar indices = new Uint16Array( [ 0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7 ] );\n\tvar positions = new Float32Array( 8 * 3 );\n\n\tvar geometry = new BufferGeometry();\n\tgeometry.setIndex( new BufferAttribute( indices, 1 ) );\n\tgeometry.addAttribute( 'position', new BufferAttribute( positions, 3 ) );\n\n\tLineSegments.call( this, geometry, new LineBasicMaterial( { color: color } ) );\n\n\tthis.matrixAutoUpdate = false;\n\n\tthis.update();\n\n}\n\nBoxHelper.prototype = Object.create( LineSegments.prototype );\nBoxHelper.prototype.constructor = BoxHelper;\n\nBoxHelper.prototype.update = ( function () {\n\n\tvar box = new Box3();\n\n\treturn function update( object ) {\n\n\t\tif ( object !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.BoxHelper: .update() has no longer arguments.' );\n\n\t\t}\n\n\t\tif ( this.object !== undefined ) {\n\n\t\t\tbox.setFromObject( this.object );\n\n\t\t}\n\n\t\tif ( box.isEmpty() ) return;\n\n\t\tvar min = box.min;\n\t\tvar max = box.max;\n\n\t\t/*\n\t\t  5____4\n\t\t1/___0/|\n\t\t| 6__|_7\n\t\t2/___3/\n\n\t\t0: max.x, max.y, max.z\n\t\t1: min.x, max.y, max.z\n\t\t2: min.x, min.y, max.z\n\t\t3: max.x, min.y, max.z\n\t\t4: max.x, max.y, min.z\n\t\t5: min.x, max.y, min.z\n\t\t6: min.x, min.y, min.z\n\t\t7: max.x, min.y, min.z\n\t\t*/\n\n\t\tvar position = this.geometry.attributes.position;\n\t\tvar array = position.array;\n\n\t\tarray[ 0 ] = max.x; array[ 1 ] = max.y; array[ 2 ] = max.z;\n\t\tarray[ 3 ] = min.x; array[ 4 ] = max.y; array[ 5 ] = max.z;\n\t\tarray[ 6 ] = min.x; array[ 7 ] = min.y; array[ 8 ] = max.z;\n\t\tarray[ 9 ] = max.x; array[ 10 ] = min.y; array[ 11 ] = max.z;\n\t\tarray[ 12 ] = max.x; array[ 13 ] = max.y; array[ 14 ] = min.z;\n\t\tarray[ 15 ] = min.x; array[ 16 ] = max.y; array[ 17 ] = min.z;\n\t\tarray[ 18 ] = min.x; array[ 19 ] = min.y; array[ 20 ] = min.z;\n\t\tarray[ 21 ] = max.x; array[ 22 ] = min.y; array[ 23 ] = min.z;\n\n\t\tposition.needsUpdate = true;\n\n\t\tthis.geometry.computeBoundingSphere();\n\n\t};\n\n} )();\n\nBoxHelper.prototype.setFromObject = function ( object ) {\n\n\tthis.object = object;\n\tthis.update();\n\n\treturn this;\n\n};\n\n/**\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction Box3Helper( box, hex ) {\n\n\tthis.type = 'Box3Helper';\n\n\tthis.box = box;\n\n\tvar color = ( hex !== undefined ) ? hex : 0xffff00;\n\n\tvar indices = new Uint16Array( [ 0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7 ] );\n\n\tvar positions = [ 1, 1, 1, - 1, 1, 1, - 1, - 1, 1, 1, - 1, 1, 1, 1, - 1, - 1, 1, - 1, - 1, - 1, - 1, 1, - 1, - 1 ];\n\n\tvar geometry = new BufferGeometry();\n\n\tgeometry.setIndex( new BufferAttribute( indices, 1 ) );\n\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( positions, 3 ) );\n\n\tLineSegments.call( this, geometry, new LineBasicMaterial( { color: color } ) );\n\n\tthis.geometry.computeBoundingSphere();\n\n}\n\nBox3Helper.prototype = Object.create( LineSegments.prototype );\nBox3Helper.prototype.constructor = Box3Helper;\n\nBox3Helper.prototype.updateMatrixWorld = function ( force ) {\n\n\tvar box = this.box;\n\n\tif ( box.isEmpty() ) return;\n\n\tbox.getCenter( this.position );\n\n\tbox.getSize( this.scale );\n\n\tthis.scale.multiplyScalar( 0.5 );\n\n\tObject3D.prototype.updateMatrixWorld.call( this, force );\n\n};\n\n/**\n * @author WestLangley / http://github.com/WestLangley\n */\n\nfunction PlaneHelper( plane, size, hex ) {\n\n\tthis.type = 'PlaneHelper';\n\n\tthis.plane = plane;\n\n\tthis.size = ( size === undefined ) ? 1 : size;\n\n\tvar color = ( hex !== undefined ) ? hex : 0xffff00;\n\n\tvar positions = [ 1, - 1, 1, - 1, 1, 1, - 1, - 1, 1, 1, 1, 1, - 1, 1, 1, - 1, - 1, 1, 1, - 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0 ];\n\n\tvar geometry = new BufferGeometry();\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( positions, 3 ) );\n\tgeometry.computeBoundingSphere();\n\n\tLine.call( this, geometry, new LineBasicMaterial( { color: color } ) );\n\n\t//\n\n\tvar positions2 = [ 1, 1, 1, - 1, 1, 1, - 1, - 1, 1, 1, 1, 1, - 1, - 1, 1, 1, - 1, 1 ];\n\n\tvar geometry2 = new BufferGeometry();\n\tgeometry2.addAttribute( 'position', new Float32BufferAttribute( positions2, 3 ) );\n\tgeometry2.computeBoundingSphere();\n\n\tthis.add( new Mesh( geometry2, new MeshBasicMaterial( { color: color, opacity: 0.2, transparent: true, depthWrite: false } ) ) );\n\n}\n\nPlaneHelper.prototype = Object.create( Line.prototype );\nPlaneHelper.prototype.constructor = PlaneHelper;\n\nPlaneHelper.prototype.updateMatrixWorld = function ( force ) {\n\n\tvar scale = - this.plane.constant;\n\n\tif ( Math.abs( scale ) < 1e-8 ) scale = 1e-8; // sign does not matter\n\n\tthis.scale.set( 0.5 * this.size, 0.5 * this.size, scale );\n\n\tthis.lookAt( this.plane.normal );\n\n\tObject3D.prototype.updateMatrixWorld.call( this, force );\n\n};\n\n/**\n * @author WestLangley / http://github.com/WestLangley\n * @author zz85 / http://github.com/zz85\n * @author bhouston / http://clara.io\n *\n * Creates an arrow for visualizing directions\n *\n * Parameters:\n *  dir - Vector3\n *  origin - Vector3\n *  length - Number\n *  color - color in hex value\n *  headLength - Number\n *  headWidth - Number\n */\n\nvar lineGeometry;\nvar coneGeometry;\n\nfunction ArrowHelper( dir, origin, length, color, headLength, headWidth ) {\n\n\t// dir is assumed to be normalized\n\n\tObject3D.call( this );\n\n\tif ( color === undefined ) color = 0xffff00;\n\tif ( length === undefined ) length = 1;\n\tif ( headLength === undefined ) headLength = 0.2 * length;\n\tif ( headWidth === undefined ) headWidth = 0.2 * headLength;\n\n\tif ( lineGeometry === undefined ) {\n\n\t\tlineGeometry = new BufferGeometry();\n\t\tlineGeometry.addAttribute( 'position', new Float32BufferAttribute( [ 0, 0, 0, 0, 1, 0 ], 3 ) );\n\n\t\tconeGeometry = new CylinderBufferGeometry( 0, 0.5, 1, 5, 1 );\n\t\tconeGeometry.translate( 0, - 0.5, 0 );\n\n\t}\n\n\tthis.position.copy( origin );\n\n\tthis.line = new Line( lineGeometry, new LineBasicMaterial( { color: color } ) );\n\tthis.line.matrixAutoUpdate = false;\n\tthis.add( this.line );\n\n\tthis.cone = new Mesh( coneGeometry, new MeshBasicMaterial( { color: color } ) );\n\tthis.cone.matrixAutoUpdate = false;\n\tthis.add( this.cone );\n\n\tthis.setDirection( dir );\n\tthis.setLength( length, headLength, headWidth );\n\n}\n\nArrowHelper.prototype = Object.create( Object3D.prototype );\nArrowHelper.prototype.constructor = ArrowHelper;\n\nArrowHelper.prototype.setDirection = ( function () {\n\n\tvar axis = new Vector3();\n\tvar radians;\n\n\treturn function setDirection( dir ) {\n\n\t\t// dir is assumed to be normalized\n\n\t\tif ( dir.y > 0.99999 ) {\n\n\t\t\tthis.quaternion.set( 0, 0, 0, 1 );\n\n\t\t} else if ( dir.y < - 0.99999 ) {\n\n\t\t\tthis.quaternion.set( 1, 0, 0, 0 );\n\n\t\t} else {\n\n\t\t\taxis.set( dir.z, 0, - dir.x ).normalize();\n\n\t\t\tradians = Math.acos( dir.y );\n\n\t\t\tthis.quaternion.setFromAxisAngle( axis, radians );\n\n\t\t}\n\n\t};\n\n}() );\n\nArrowHelper.prototype.setLength = function ( length, headLength, headWidth ) {\n\n\tif ( headLength === undefined ) headLength = 0.2 * length;\n\tif ( headWidth === undefined ) headWidth = 0.2 * headLength;\n\n\tthis.line.scale.set( 1, Math.max( 0, length - headLength ), 1 );\n\tthis.line.updateMatrix();\n\n\tthis.cone.scale.set( headWidth, headLength, headWidth );\n\tthis.cone.position.y = length;\n\tthis.cone.updateMatrix();\n\n};\n\nArrowHelper.prototype.setColor = function ( color ) {\n\n\tthis.line.material.color.copy( color );\n\tthis.cone.material.color.copy( color );\n\n};\n\n/**\n * @author sroucheray / http://sroucheray.org/\n * @author mrdoob / http://mrdoob.com/\n */\n\nfunction AxesHelper( size ) {\n\n\tsize = size || 1;\n\n\tvar vertices = [\n\t\t0, 0, 0,\tsize, 0, 0,\n\t\t0, 0, 0,\t0, size, 0,\n\t\t0, 0, 0,\t0, 0, size\n\t];\n\n\tvar colors = [\n\t\t1, 0, 0,\t1, 0.6, 0,\n\t\t0, 1, 0,\t0.6, 1, 0,\n\t\t0, 0, 1,\t0, 0.6, 1\n\t];\n\n\tvar geometry = new BufferGeometry();\n\tgeometry.addAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\tgeometry.addAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\tvar material = new LineBasicMaterial( { vertexColors: VertexColors } );\n\n\tLineSegments.call( this, geometry, material );\n\n}\n\nAxesHelper.prototype = Object.create( LineSegments.prototype );\nAxesHelper.prototype.constructor = AxesHelper;\n\n//\n\nCurve.create = function ( construct, getPoint ) {\n\n\tconsole.log( 'THREE.Curve.create() has been deprecated' );\n\n\tconstruct.prototype = Object.create( Curve.prototype );\n\tconstruct.prototype.constructor = construct;\n\tconstruct.prototype.getPoint = getPoint;\n\n\treturn construct;\n\n};\n\n//\n\nObject.assign( CurvePath.prototype, {\n\n\tcreatePointsGeometry: function ( divisions ) {\n\n\t\tconsole.warn( 'THREE.CurvePath: .createPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.' );\n\n\t\t// generate geometry from path points (for Line or Points objects)\n\n\t\tvar pts = this.getPoints( divisions );\n\t\treturn this.createGeometry( pts );\n\n\t},\n\n\tcreateSpacedPointsGeometry: function ( divisions ) {\n\n\t\tconsole.warn( 'THREE.CurvePath: .createSpacedPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.' );\n\n\t\t// generate geometry from equidistant sampling along the path\n\n\t\tvar pts = this.getSpacedPoints( divisions );\n\t\treturn this.createGeometry( pts );\n\n\t},\n\n\tcreateGeometry: function ( points ) {\n\n\t\tconsole.warn( 'THREE.CurvePath: .createGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.' );\n\n\t\tvar geometry = new Geometry();\n\n\t\tfor ( var i = 0, l = points.length; i < l; i ++ ) {\n\n\t\t\tvar point = points[ i ];\n\t\t\tgeometry.vertices.push( new Vector3( point.x, point.y, point.z || 0 ) );\n\n\t\t}\n\n\t\treturn geometry;\n\n\t}\n\n} );\n\n//\n\nObject.assign( Path.prototype, {\n\n\tfromPoints: function ( points ) {\n\n\t\tconsole.warn( 'THREE.Path: .fromPoints() has been renamed to .setFromPoints().' );\n\t\tthis.setFromPoints( points );\n\n\t}\n\n} );\n\n//\n\nfunction Spline( points ) {\n\n\tconsole.warn( 'THREE.Spline has been removed. Use THREE.CatmullRomCurve3 instead.' );\n\n\tCatmullRomCurve3.call( this, points );\n\tthis.type = 'catmullrom';\n\n}\n\nSpline.prototype = Object.create( CatmullRomCurve3.prototype );\n\nObject.assign( Spline.prototype, {\n\n\tinitFromArray: function ( /* a */ ) {\n\n\t\tconsole.error( 'THREE.Spline: .initFromArray() has been removed.' );\n\n\t},\n\tgetControlPointsArray: function ( /* optionalTarget */ ) {\n\n\t\tconsole.error( 'THREE.Spline: .getControlPointsArray() has been removed.' );\n\n\t},\n\treparametrizeByArcLength: function ( /* samplingCoef */ ) {\n\n\t\tconsole.error( 'THREE.Spline: .reparametrizeByArcLength() has been removed.' );\n\n\t}\n\n} );\n\nGridHelper.prototype.setColors = function () {\n\n\tconsole.error( 'THREE.GridHelper: setColors() has been deprecated, pass them in the constructor instead.' );\n\n};\n\nSkeletonHelper.prototype.update = function () {\n\n\tconsole.error( 'THREE.SkeletonHelper: update() no longer needs to be called.' );\n\n};\n\n//\n\nObject.assign( Loader.prototype, {\n\n\textractUrlBase: function ( url ) {\n\n\t\tconsole.warn( 'THREE.Loader: .extractUrlBase() has been deprecated. Use THREE.LoaderUtils.extractUrlBase() instead.' );\n\t\treturn LoaderUtils.extractUrlBase( url );\n\n\t}\n\n} );\n\n//\n\nObject.assign( Box2.prototype, {\n\n\tcenter: function ( optionalTarget ) {\n\n\t\tconsole.warn( 'THREE.Box2: .center() has been renamed to .getCenter().' );\n\t\treturn this.getCenter( optionalTarget );\n\n\t},\n\tempty: function () {\n\n\t\tconsole.warn( 'THREE.Box2: .empty() has been renamed to .isEmpty().' );\n\t\treturn this.isEmpty();\n\n\t},\n\tisIntersectionBox: function ( box ) {\n\n\t\tconsole.warn( 'THREE.Box2: .isIntersectionBox() has been renamed to .intersectsBox().' );\n\t\treturn this.intersectsBox( box );\n\n\t},\n\tsize: function ( optionalTarget ) {\n\n\t\tconsole.warn( 'THREE.Box2: .size() has been renamed to .getSize().' );\n\t\treturn this.getSize( optionalTarget );\n\n\t}\n} );\n\nObject.assign( Box3.prototype, {\n\n\tcenter: function ( optionalTarget ) {\n\n\t\tconsole.warn( 'THREE.Box3: .center() has been renamed to .getCenter().' );\n\t\treturn this.getCenter( optionalTarget );\n\n\t},\n\tempty: function () {\n\n\t\tconsole.warn( 'THREE.Box3: .empty() has been renamed to .isEmpty().' );\n\t\treturn this.isEmpty();\n\n\t},\n\tisIntersectionBox: function ( box ) {\n\n\t\tconsole.warn( 'THREE.Box3: .isIntersectionBox() has been renamed to .intersectsBox().' );\n\t\treturn this.intersectsBox( box );\n\n\t},\n\tisIntersectionSphere: function ( sphere ) {\n\n\t\tconsole.warn( 'THREE.Box3: .isIntersectionSphere() has been renamed to .intersectsSphere().' );\n\t\treturn this.intersectsSphere( sphere );\n\n\t},\n\tsize: function ( optionalTarget ) {\n\n\t\tconsole.warn( 'THREE.Box3: .size() has been renamed to .getSize().' );\n\t\treturn this.getSize( optionalTarget );\n\n\t}\n} );\n\nLine3.prototype.center = function ( optionalTarget ) {\n\n\tconsole.warn( 'THREE.Line3: .center() has been renamed to .getCenter().' );\n\treturn this.getCenter( optionalTarget );\n\n};\n\nObject.assign( _Math, {\n\n\trandom16: function () {\n\n\t\tconsole.warn( 'THREE.Math: .random16() has been deprecated. Use Math.random() instead.' );\n\t\treturn Math.random();\n\n\t},\n\n\tnearestPowerOfTwo: function ( value ) {\n\n\t\tconsole.warn( 'THREE.Math: .nearestPowerOfTwo() has been renamed to .floorPowerOfTwo().' );\n\t\treturn _Math.floorPowerOfTwo( value );\n\n\t},\n\n\tnextPowerOfTwo: function ( value ) {\n\n\t\tconsole.warn( 'THREE.Math: .nextPowerOfTwo() has been renamed to .ceilPowerOfTwo().' );\n\t\treturn _Math.ceilPowerOfTwo( value );\n\n\t}\n\n} );\n\nObject.assign( Matrix3.prototype, {\n\n\tflattenToArrayOffset: function ( array, offset ) {\n\n\t\tconsole.warn( \"THREE.Matrix3: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.\" );\n\t\treturn this.toArray( array, offset );\n\n\t},\n\tmultiplyVector3: function ( vector ) {\n\n\t\tconsole.warn( 'THREE.Matrix3: .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead.' );\n\t\treturn vector.applyMatrix3( this );\n\n\t},\n\tmultiplyVector3Array: function ( /* a */ ) {\n\n\t\tconsole.error( 'THREE.Matrix3: .multiplyVector3Array() has been removed.' );\n\n\t},\n\tapplyToBuffer: function ( buffer /*, offset, length */ ) {\n\n\t\tconsole.warn( 'THREE.Matrix3: .applyToBuffer() has been removed. Use matrix.applyToBufferAttribute( attribute ) instead.' );\n\t\treturn this.applyToBufferAttribute( buffer );\n\n\t},\n\tapplyToVector3Array: function ( /* array, offset, length */ ) {\n\n\t\tconsole.error( 'THREE.Matrix3: .applyToVector3Array() has been removed.' );\n\n\t}\n\n} );\n\nObject.assign( Matrix4.prototype, {\n\n\textractPosition: function ( m ) {\n\n\t\tconsole.warn( 'THREE.Matrix4: .extractPosition() has been renamed to .copyPosition().' );\n\t\treturn this.copyPosition( m );\n\n\t},\n\tflattenToArrayOffset: function ( array, offset ) {\n\n\t\tconsole.warn( \"THREE.Matrix4: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.\" );\n\t\treturn this.toArray( array, offset );\n\n\t},\n\tgetPosition: function () {\n\n\t\tvar v1;\n\n\t\treturn function getPosition() {\n\n\t\t\tif ( v1 === undefined ) v1 = new Vector3();\n\t\t\tconsole.warn( 'THREE.Matrix4: .getPosition() has been removed. Use Vector3.setFromMatrixPosition( matrix ) instead.' );\n\t\t\treturn v1.setFromMatrixColumn( this, 3 );\n\n\t\t};\n\n\t}(),\n\tsetRotationFromQuaternion: function ( q ) {\n\n\t\tconsole.warn( 'THREE.Matrix4: .setRotationFromQuaternion() has been renamed to .makeRotationFromQuaternion().' );\n\t\treturn this.makeRotationFromQuaternion( q );\n\n\t},\n\tmultiplyToArray: function () {\n\n\t\tconsole.warn( 'THREE.Matrix4: .multiplyToArray() has been removed.' );\n\n\t},\n\tmultiplyVector3: function ( vector ) {\n\n\t\tconsole.warn( 'THREE.Matrix4: .multiplyVector3() has been removed. Use vector.applyMatrix4( matrix ) instead.' );\n\t\treturn vector.applyMatrix4( this );\n\n\t},\n\tmultiplyVector4: function ( vector ) {\n\n\t\tconsole.warn( 'THREE.Matrix4: .multiplyVector4() has been removed. Use vector.applyMatrix4( matrix ) instead.' );\n\t\treturn vector.applyMatrix4( this );\n\n\t},\n\tmultiplyVector3Array: function ( /* a */ ) {\n\n\t\tconsole.error( 'THREE.Matrix4: .multiplyVector3Array() has been removed.' );\n\n\t},\n\trotateAxis: function ( v ) {\n\n\t\tconsole.warn( 'THREE.Matrix4: .rotateAxis() has been removed. Use Vector3.transformDirection( matrix ) instead.' );\n\t\tv.transformDirection( this );\n\n\t},\n\tcrossVector: function ( vector ) {\n\n\t\tconsole.warn( 'THREE.Matrix4: .crossVector() has been removed. Use vector.applyMatrix4( matrix ) instead.' );\n\t\treturn vector.applyMatrix4( this );\n\n\t},\n\ttranslate: function () {\n\n\t\tconsole.error( 'THREE.Matrix4: .translate() has been removed.' );\n\n\t},\n\trotateX: function () {\n\n\t\tconsole.error( 'THREE.Matrix4: .rotateX() has been removed.' );\n\n\t},\n\trotateY: function () {\n\n\t\tconsole.error( 'THREE.Matrix4: .rotateY() has been removed.' );\n\n\t},\n\trotateZ: function () {\n\n\t\tconsole.error( 'THREE.Matrix4: .rotateZ() has been removed.' );\n\n\t},\n\trotateByAxis: function () {\n\n\t\tconsole.error( 'THREE.Matrix4: .rotateByAxis() has been removed.' );\n\n\t},\n\tapplyToBuffer: function ( buffer /*, offset, length */ ) {\n\n\t\tconsole.warn( 'THREE.Matrix4: .applyToBuffer() has been removed. Use matrix.applyToBufferAttribute( attribute ) instead.' );\n\t\treturn this.applyToBufferAttribute( buffer );\n\n\t},\n\tapplyToVector3Array: function ( /* array, offset, length */ ) {\n\n\t\tconsole.error( 'THREE.Matrix4: .applyToVector3Array() has been removed.' );\n\n\t},\n\tmakeFrustum: function ( left, right, bottom, top, near, far ) {\n\n\t\tconsole.warn( 'THREE.Matrix4: .makeFrustum() has been removed. Use .makePerspective( left, right, top, bottom, near, far ) instead.' );\n\t\treturn this.makePerspective( left, right, top, bottom, near, far );\n\n\t}\n\n} );\n\nPlane.prototype.isIntersectionLine = function ( line ) {\n\n\tconsole.warn( 'THREE.Plane: .isIntersectionLine() has been renamed to .intersectsLine().' );\n\treturn this.intersectsLine( line );\n\n};\n\nQuaternion.prototype.multiplyVector3 = function ( vector ) {\n\n\tconsole.warn( 'THREE.Quaternion: .multiplyVector3() has been removed. Use is now vector.applyQuaternion( quaternion ) instead.' );\n\treturn vector.applyQuaternion( this );\n\n};\n\nObject.assign( Ray.prototype, {\n\n\tisIntersectionBox: function ( box ) {\n\n\t\tconsole.warn( 'THREE.Ray: .isIntersectionBox() has been renamed to .intersectsBox().' );\n\t\treturn this.intersectsBox( box );\n\n\t},\n\tisIntersectionPlane: function ( plane ) {\n\n\t\tconsole.warn( 'THREE.Ray: .isIntersectionPlane() has been renamed to .intersectsPlane().' );\n\t\treturn this.intersectsPlane( plane );\n\n\t},\n\tisIntersectionSphere: function ( sphere ) {\n\n\t\tconsole.warn( 'THREE.Ray: .isIntersectionSphere() has been renamed to .intersectsSphere().' );\n\t\treturn this.intersectsSphere( sphere );\n\n\t}\n\n} );\n\nObject.assign( Triangle.prototype, {\n\n\tarea: function () {\n\n\t\tconsole.warn( 'THREE.Triangle: .area() has been renamed to .getArea().' );\n\t\treturn this.getArea();\n\n\t},\n\tbarycoordFromPoint: function ( point, target ) {\n\n\t\tconsole.warn( 'THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().' );\n\t\treturn this.getBarycoord( point, target );\n\n\t},\n\tmidpoint: function ( target ) {\n\n\t\tconsole.warn( 'THREE.Triangle: .midpoint() has been renamed to .getMidpoint().' );\n\t\treturn this.getMidpoint( target );\n\n\t},\n\tnormal: function ( target ) {\n\n\t\tconsole.warn( 'THREE.Triangle: .normal() has been renamed to .getNormal().' );\n\t\treturn this.getNormal( target );\n\n\t},\n\tplane: function ( target ) {\n\n\t\tconsole.warn( 'THREE.Triangle: .plane() has been renamed to .getPlane().' );\n\t\treturn this.getPlane( target );\n\n\t}\n\n} );\n\nObject.assign( Triangle, {\n\n\tbarycoordFromPoint: function ( point, a, b, c, target ) {\n\n\t\tconsole.warn( 'THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().' );\n\t\treturn Triangle.getBarycoord( point, a, b, c, target );\n\n\t},\n\tnormal: function ( a, b, c, target ) {\n\n\t\tconsole.warn( 'THREE.Triangle: .normal() has been renamed to .getNormal().' );\n\t\treturn Triangle.getNormal( a, b, c, target );\n\n\t}\n\n} );\n\nObject.assign( Shape.prototype, {\n\n\textractAllPoints: function ( divisions ) {\n\n\t\tconsole.warn( 'THREE.Shape: .extractAllPoints() has been removed. Use .extractPoints() instead.' );\n\t\treturn this.extractPoints( divisions );\n\n\t},\n\textrude: function ( options ) {\n\n\t\tconsole.warn( 'THREE.Shape: .extrude() has been removed. Use ExtrudeGeometry() instead.' );\n\t\treturn new ExtrudeGeometry( this, options );\n\n\t},\n\tmakeGeometry: function ( options ) {\n\n\t\tconsole.warn( 'THREE.Shape: .makeGeometry() has been removed. Use ShapeGeometry() instead.' );\n\t\treturn new ShapeGeometry( this, options );\n\n\t}\n\n} );\n\nObject.assign( Vector2.prototype, {\n\n\tfromAttribute: function ( attribute, index, offset ) {\n\n\t\tconsole.warn( 'THREE.Vector2: .fromAttribute() has been renamed to .fromBufferAttribute().' );\n\t\treturn this.fromBufferAttribute( attribute, index, offset );\n\n\t},\n\tdistanceToManhattan: function ( v ) {\n\n\t\tconsole.warn( 'THREE.Vector2: .distanceToManhattan() has been renamed to .manhattanDistanceTo().' );\n\t\treturn this.manhattanDistanceTo( v );\n\n\t},\n\tlengthManhattan: function () {\n\n\t\tconsole.warn( 'THREE.Vector2: .lengthManhattan() has been renamed to .manhattanLength().' );\n\t\treturn this.manhattanLength();\n\n\t}\n\n} );\n\nObject.assign( Vector3.prototype, {\n\n\tsetEulerFromRotationMatrix: function () {\n\n\t\tconsole.error( 'THREE.Vector3: .setEulerFromRotationMatrix() has been removed. Use Euler.setFromRotationMatrix() instead.' );\n\n\t},\n\tsetEulerFromQuaternion: function () {\n\n\t\tconsole.error( 'THREE.Vector3: .setEulerFromQuaternion() has been removed. Use Euler.setFromQuaternion() instead.' );\n\n\t},\n\tgetPositionFromMatrix: function ( m ) {\n\n\t\tconsole.warn( 'THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition().' );\n\t\treturn this.setFromMatrixPosition( m );\n\n\t},\n\tgetScaleFromMatrix: function ( m ) {\n\n\t\tconsole.warn( 'THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale().' );\n\t\treturn this.setFromMatrixScale( m );\n\n\t},\n\tgetColumnFromMatrix: function ( index, matrix ) {\n\n\t\tconsole.warn( 'THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn().' );\n\t\treturn this.setFromMatrixColumn( matrix, index );\n\n\t},\n\tapplyProjection: function ( m ) {\n\n\t\tconsole.warn( 'THREE.Vector3: .applyProjection() has been removed. Use .applyMatrix4( m ) instead.' );\n\t\treturn this.applyMatrix4( m );\n\n\t},\n\tfromAttribute: function ( attribute, index, offset ) {\n\n\t\tconsole.warn( 'THREE.Vector3: .fromAttribute() has been renamed to .fromBufferAttribute().' );\n\t\treturn this.fromBufferAttribute( attribute, index, offset );\n\n\t},\n\tdistanceToManhattan: function ( v ) {\n\n\t\tconsole.warn( 'THREE.Vector3: .distanceToManhattan() has been renamed to .manhattanDistanceTo().' );\n\t\treturn this.manhattanDistanceTo( v );\n\n\t},\n\tlengthManhattan: function () {\n\n\t\tconsole.warn( 'THREE.Vector3: .lengthManhattan() has been renamed to .manhattanLength().' );\n\t\treturn this.manhattanLength();\n\n\t}\n\n} );\n\nObject.assign( Vector4.prototype, {\n\n\tfromAttribute: function ( attribute, index, offset ) {\n\n\t\tconsole.warn( 'THREE.Vector4: .fromAttribute() has been renamed to .fromBufferAttribute().' );\n\t\treturn this.fromBufferAttribute( attribute, index, offset );\n\n\t},\n\tlengthManhattan: function () {\n\n\t\tconsole.warn( 'THREE.Vector4: .lengthManhattan() has been renamed to .manhattanLength().' );\n\t\treturn this.manhattanLength();\n\n\t}\n\n} );\n\n//\n\nObject.assign( Geometry.prototype, {\n\n\tcomputeTangents: function () {\n\n\t\tconsole.error( 'THREE.Geometry: .computeTangents() has been removed.' );\n\n\t},\n\tcomputeLineDistances: function () {\n\n\t\tconsole.error( 'THREE.Geometry: .computeLineDistances() has been removed. Use THREE.Line.computeLineDistances() instead.' );\n\n\t}\n\n} );\n\nObject.assign( Object3D.prototype, {\n\n\tgetChildByName: function ( name ) {\n\n\t\tconsole.warn( 'THREE.Object3D: .getChildByName() has been renamed to .getObjectByName().' );\n\t\treturn this.getObjectByName( name );\n\n\t},\n\trenderDepth: function () {\n\n\t\tconsole.warn( 'THREE.Object3D: .renderDepth has been removed. Use .renderOrder, instead.' );\n\n\t},\n\ttranslate: function ( distance, axis ) {\n\n\t\tconsole.warn( 'THREE.Object3D: .translate() has been removed. Use .translateOnAxis( axis, distance ) instead.' );\n\t\treturn this.translateOnAxis( axis, distance );\n\n\t},\n\tgetWorldRotation: function () {\n\n\t\tconsole.error( 'THREE.Object3D: .getWorldRotation() has been removed. Use THREE.Object3D.getWorldQuaternion( target ) instead.' );\n\n\t}\n\n} );\n\nObject.defineProperties( Object3D.prototype, {\n\n\teulerOrder: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.Object3D: .eulerOrder is now .rotation.order.' );\n\t\t\treturn this.rotation.order;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Object3D: .eulerOrder is now .rotation.order.' );\n\t\t\tthis.rotation.order = value;\n\n\t\t}\n\t},\n\tuseQuaternion: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.' );\n\n\t\t},\n\t\tset: function () {\n\n\t\t\tconsole.warn( 'THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.' );\n\n\t\t}\n\t}\n\n} );\n\nObject.defineProperties( LOD.prototype, {\n\n\tobjects: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.LOD: .objects has been renamed to .levels.' );\n\t\t\treturn this.levels;\n\n\t\t}\n\t}\n\n} );\n\nObject.defineProperty( Skeleton.prototype, 'useVertexTexture', {\n\n\tget: function () {\n\n\t\tconsole.warn( 'THREE.Skeleton: useVertexTexture has been removed.' );\n\n\t},\n\tset: function () {\n\n\t\tconsole.warn( 'THREE.Skeleton: useVertexTexture has been removed.' );\n\n\t}\n\n} );\n\nObject.defineProperty( Curve.prototype, '__arcLengthDivisions', {\n\n\tget: function () {\n\n\t\tconsole.warn( 'THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.' );\n\t\treturn this.arcLengthDivisions;\n\n\t},\n\tset: function ( value ) {\n\n\t\tconsole.warn( 'THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.' );\n\t\tthis.arcLengthDivisions = value;\n\n\t}\n\n} );\n\n//\n\nPerspectiveCamera.prototype.setLens = function ( focalLength, filmGauge ) {\n\n\tconsole.warn( \"THREE.PerspectiveCamera.setLens is deprecated. \" +\n\t\t\t\"Use .setFocalLength and .filmGauge for a photographic setup.\" );\n\n\tif ( filmGauge !== undefined ) this.filmGauge = filmGauge;\n\tthis.setFocalLength( focalLength );\n\n};\n\n//\n\nObject.defineProperties( Light.prototype, {\n\tonlyShadow: {\n\t\tset: function () {\n\n\t\t\tconsole.warn( 'THREE.Light: .onlyShadow has been removed.' );\n\n\t\t}\n\t},\n\tshadowCameraFov: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowCameraFov is now .shadow.camera.fov.' );\n\t\t\tthis.shadow.camera.fov = value;\n\n\t\t}\n\t},\n\tshadowCameraLeft: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowCameraLeft is now .shadow.camera.left.' );\n\t\t\tthis.shadow.camera.left = value;\n\n\t\t}\n\t},\n\tshadowCameraRight: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowCameraRight is now .shadow.camera.right.' );\n\t\t\tthis.shadow.camera.right = value;\n\n\t\t}\n\t},\n\tshadowCameraTop: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowCameraTop is now .shadow.camera.top.' );\n\t\t\tthis.shadow.camera.top = value;\n\n\t\t}\n\t},\n\tshadowCameraBottom: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowCameraBottom is now .shadow.camera.bottom.' );\n\t\t\tthis.shadow.camera.bottom = value;\n\n\t\t}\n\t},\n\tshadowCameraNear: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowCameraNear is now .shadow.camera.near.' );\n\t\t\tthis.shadow.camera.near = value;\n\n\t\t}\n\t},\n\tshadowCameraFar: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowCameraFar is now .shadow.camera.far.' );\n\t\t\tthis.shadow.camera.far = value;\n\n\t\t}\n\t},\n\tshadowCameraVisible: {\n\t\tset: function () {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowCameraVisible has been removed. Use new THREE.CameraHelper( light.shadow.camera ) instead.' );\n\n\t\t}\n\t},\n\tshadowBias: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowBias is now .shadow.bias.' );\n\t\t\tthis.shadow.bias = value;\n\n\t\t}\n\t},\n\tshadowDarkness: {\n\t\tset: function () {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowDarkness has been removed.' );\n\n\t\t}\n\t},\n\tshadowMapWidth: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowMapWidth is now .shadow.mapSize.width.' );\n\t\t\tthis.shadow.mapSize.width = value;\n\n\t\t}\n\t},\n\tshadowMapHeight: {\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.Light: .shadowMapHeight is now .shadow.mapSize.height.' );\n\t\t\tthis.shadow.mapSize.height = value;\n\n\t\t}\n\t}\n} );\n\n//\n\nObject.defineProperties( BufferAttribute.prototype, {\n\n\tlength: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.BufferAttribute: .length has been deprecated. Use .count instead.' );\n\t\t\treturn this.array.length;\n\n\t\t}\n\t},\n\tcopyIndicesArray: function ( /* indices */ ) {\n\n\t\tconsole.error( 'THREE.BufferAttribute: .copyIndicesArray() has been removed.' );\n\n\t}\n\n} );\n\nObject.assign( BufferGeometry.prototype, {\n\n\taddIndex: function ( index ) {\n\n\t\tconsole.warn( 'THREE.BufferGeometry: .addIndex() has been renamed to .setIndex().' );\n\t\tthis.setIndex( index );\n\n\t},\n\taddDrawCall: function ( start, count, indexOffset ) {\n\n\t\tif ( indexOffset !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.BufferGeometry: .addDrawCall() no longer supports indexOffset.' );\n\n\t\t}\n\t\tconsole.warn( 'THREE.BufferGeometry: .addDrawCall() is now .addGroup().' );\n\t\tthis.addGroup( start, count );\n\n\t},\n\tclearDrawCalls: function () {\n\n\t\tconsole.warn( 'THREE.BufferGeometry: .clearDrawCalls() is now .clearGroups().' );\n\t\tthis.clearGroups();\n\n\t},\n\tcomputeTangents: function () {\n\n\t\tconsole.warn( 'THREE.BufferGeometry: .computeTangents() has been removed.' );\n\n\t},\n\tcomputeOffsets: function () {\n\n\t\tconsole.warn( 'THREE.BufferGeometry: .computeOffsets() has been removed.' );\n\n\t}\n\n} );\n\nObject.defineProperties( BufferGeometry.prototype, {\n\n\tdrawcalls: {\n\t\tget: function () {\n\n\t\t\tconsole.error( 'THREE.BufferGeometry: .drawcalls has been renamed to .groups.' );\n\t\t\treturn this.groups;\n\n\t\t}\n\t},\n\toffsets: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.BufferGeometry: .offsets has been renamed to .groups.' );\n\t\t\treturn this.groups;\n\n\t\t}\n\t}\n\n} );\n\n//\n\nObject.assign( ExtrudeBufferGeometry.prototype, {\n\n\tgetArrays: function () {\n\n\t\tconsole.error( 'THREE.ExtrudeBufferGeometry: .getArrays() has been removed.' );\n\n\t},\n\n\taddShapeList: function () {\n\n\t\tconsole.error( 'THREE.ExtrudeBufferGeometry: .addShapeList() has been removed.' );\n\n\t},\n\n\taddShape: function () {\n\n\t\tconsole.error( 'THREE.ExtrudeBufferGeometry: .addShape() has been removed.' );\n\n\t}\n\n} );\n\n//\n\nObject.defineProperties( Uniform.prototype, {\n\n\tdynamic: {\n\t\tset: function () {\n\n\t\t\tconsole.warn( 'THREE.Uniform: .dynamic has been removed. Use object.onBeforeRender() instead.' );\n\n\t\t}\n\t},\n\tonUpdate: {\n\t\tvalue: function () {\n\n\t\t\tconsole.warn( 'THREE.Uniform: .onUpdate() has been removed. Use object.onBeforeRender() instead.' );\n\t\t\treturn this;\n\n\t\t}\n\t}\n\n} );\n\n//\n\nObject.defineProperties( Material.prototype, {\n\n\twrapAround: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.Material: .wrapAround has been removed.' );\n\n\t\t},\n\t\tset: function () {\n\n\t\t\tconsole.warn( 'THREE.Material: .wrapAround has been removed.' );\n\n\t\t}\n\t},\n\twrapRGB: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.Material: .wrapRGB has been removed.' );\n\t\t\treturn new Color();\n\n\t\t}\n\t},\n\n\tshading: {\n\t\tget: function () {\n\n\t\t\tconsole.error( 'THREE.' + this.type + ': .shading has been removed. Use the boolean .flatShading instead.' );\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.' + this.type + ': .shading has been removed. Use the boolean .flatShading instead.' );\n\t\t\tthis.flatShading = ( value === FlatShading );\n\n\t\t}\n\t}\n\n} );\n\nObject.defineProperties( MeshPhongMaterial.prototype, {\n\n\tmetal: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead.' );\n\t\t\treturn false;\n\n\t\t},\n\t\tset: function () {\n\n\t\t\tconsole.warn( 'THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead' );\n\n\t\t}\n\t}\n\n} );\n\nObject.defineProperties( ShaderMaterial.prototype, {\n\n\tderivatives: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.ShaderMaterial: .derivatives has been moved to .extensions.derivatives.' );\n\t\t\treturn this.extensions.derivatives;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE. ShaderMaterial: .derivatives has been moved to .extensions.derivatives.' );\n\t\t\tthis.extensions.derivatives = value;\n\n\t\t}\n\t}\n\n} );\n\n//\n\nObject.assign( WebGLRenderer.prototype, {\n\n\tgetCurrentRenderTarget: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .getCurrentRenderTarget() is now .getRenderTarget().' );\n\t\treturn this.getRenderTarget();\n\n\t},\n\n\tgetMaxAnisotropy: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .getMaxAnisotropy() is now .capabilities.getMaxAnisotropy().' );\n\t\treturn this.capabilities.getMaxAnisotropy();\n\n\t},\n\n\tgetPrecision: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .getPrecision() is now .capabilities.precision.' );\n\t\treturn this.capabilities.precision;\n\n\t},\n\n\tresetGLState: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .resetGLState() is now .state.reset().' );\n\t\treturn this.state.reset();\n\n\t},\n\n\tsupportsFloatTextures: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .supportsFloatTextures() is now .extensions.get( \\'OES_texture_float\\' ).' );\n\t\treturn this.extensions.get( 'OES_texture_float' );\n\n\t},\n\tsupportsHalfFloatTextures: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .supportsHalfFloatTextures() is now .extensions.get( \\'OES_texture_half_float\\' ).' );\n\t\treturn this.extensions.get( 'OES_texture_half_float' );\n\n\t},\n\tsupportsStandardDerivatives: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .supportsStandardDerivatives() is now .extensions.get( \\'OES_standard_derivatives\\' ).' );\n\t\treturn this.extensions.get( 'OES_standard_derivatives' );\n\n\t},\n\tsupportsCompressedTextureS3TC: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .supportsCompressedTextureS3TC() is now .extensions.get( \\'WEBGL_compressed_texture_s3tc\\' ).' );\n\t\treturn this.extensions.get( 'WEBGL_compressed_texture_s3tc' );\n\n\t},\n\tsupportsCompressedTexturePVRTC: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .supportsCompressedTexturePVRTC() is now .extensions.get( \\'WEBGL_compressed_texture_pvrtc\\' ).' );\n\t\treturn this.extensions.get( 'WEBGL_compressed_texture_pvrtc' );\n\n\t},\n\tsupportsBlendMinMax: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .supportsBlendMinMax() is now .extensions.get( \\'EXT_blend_minmax\\' ).' );\n\t\treturn this.extensions.get( 'EXT_blend_minmax' );\n\n\t},\n\tsupportsVertexTextures: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .supportsVertexTextures() is now .capabilities.vertexTextures.' );\n\t\treturn this.capabilities.vertexTextures;\n\n\t},\n\tsupportsInstancedArrays: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .supportsInstancedArrays() is now .extensions.get( \\'ANGLE_instanced_arrays\\' ).' );\n\t\treturn this.extensions.get( 'ANGLE_instanced_arrays' );\n\n\t},\n\tenableScissorTest: function ( boolean ) {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .enableScissorTest() is now .setScissorTest().' );\n\t\tthis.setScissorTest( boolean );\n\n\t},\n\tinitMaterial: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .initMaterial() has been removed.' );\n\n\t},\n\taddPrePlugin: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .addPrePlugin() has been removed.' );\n\n\t},\n\taddPostPlugin: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .addPostPlugin() has been removed.' );\n\n\t},\n\tupdateShadowMap: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .updateShadowMap() has been removed.' );\n\n\t},\n\tsetFaceCulling: function () {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer: .setFaceCulling() has been removed.' );\n\n\t}\n\n} );\n\nObject.defineProperties( WebGLRenderer.prototype, {\n\n\tshadowMapEnabled: {\n\t\tget: function () {\n\n\t\t\treturn this.shadowMap.enabled;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMapEnabled is now .shadowMap.enabled.' );\n\t\t\tthis.shadowMap.enabled = value;\n\n\t\t}\n\t},\n\tshadowMapType: {\n\t\tget: function () {\n\n\t\t\treturn this.shadowMap.type;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMapType is now .shadowMap.type.' );\n\t\t\tthis.shadowMap.type = value;\n\n\t\t}\n\t},\n\tshadowMapCullFace: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.' );\n\t\t\treturn undefined;\n\n\t\t},\n\t\tset: function ( /* value */ ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.' );\n\n\t\t}\n\t}\n} );\n\nObject.defineProperties( WebGLShadowMap.prototype, {\n\n\tcullFace: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.' );\n\t\t\treturn undefined;\n\n\t\t},\n\t\tset: function ( /* cullFace */ ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.' );\n\n\t\t}\n\t},\n\trenderReverseSided: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.' );\n\t\t\treturn undefined;\n\n\t\t},\n\t\tset: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.' );\n\n\t\t}\n\t},\n\trenderSingleSided: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.' );\n\t\t\treturn undefined;\n\n\t\t},\n\t\tset: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.' );\n\n\t\t}\n\t}\n\n} );\n\n//\n\nObject.defineProperties( WebGLRenderTarget.prototype, {\n\n\twrapS: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.' );\n\t\t\treturn this.texture.wrapS;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.' );\n\t\t\tthis.texture.wrapS = value;\n\n\t\t}\n\t},\n\twrapT: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.' );\n\t\t\treturn this.texture.wrapT;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.' );\n\t\t\tthis.texture.wrapT = value;\n\n\t\t}\n\t},\n\tmagFilter: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.' );\n\t\t\treturn this.texture.magFilter;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.' );\n\t\t\tthis.texture.magFilter = value;\n\n\t\t}\n\t},\n\tminFilter: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.' );\n\t\t\treturn this.texture.minFilter;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.' );\n\t\t\tthis.texture.minFilter = value;\n\n\t\t}\n\t},\n\tanisotropy: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.' );\n\t\t\treturn this.texture.anisotropy;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.' );\n\t\t\tthis.texture.anisotropy = value;\n\n\t\t}\n\t},\n\toffset: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .offset is now .texture.offset.' );\n\t\t\treturn this.texture.offset;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .offset is now .texture.offset.' );\n\t\t\tthis.texture.offset = value;\n\n\t\t}\n\t},\n\trepeat: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .repeat is now .texture.repeat.' );\n\t\t\treturn this.texture.repeat;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .repeat is now .texture.repeat.' );\n\t\t\tthis.texture.repeat = value;\n\n\t\t}\n\t},\n\tformat: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .format is now .texture.format.' );\n\t\t\treturn this.texture.format;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .format is now .texture.format.' );\n\t\t\tthis.texture.format = value;\n\n\t\t}\n\t},\n\ttype: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .type is now .texture.type.' );\n\t\t\treturn this.texture.type;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .type is now .texture.type.' );\n\t\t\tthis.texture.type = value;\n\n\t\t}\n\t},\n\tgenerateMipmaps: {\n\t\tget: function () {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.' );\n\t\t\treturn this.texture.generateMipmaps;\n\n\t\t},\n\t\tset: function ( value ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.' );\n\t\t\tthis.texture.generateMipmaps = value;\n\n\t\t}\n\t}\n\n} );\n\n//\n\nObject.defineProperties( WebVRManager.prototype, {\n\n\tstanding: {\n\t\tset: function ( /* value */ ) {\n\n\t\t\tconsole.warn( 'THREE.WebVRManager: .standing has been removed.' );\n\n\t\t}\n\t}\n\n} );\n\n//\n\nAudio.prototype.load = function ( file ) {\n\n\tconsole.warn( 'THREE.Audio: .load has been deprecated. Use THREE.AudioLoader instead.' );\n\tvar scope = this;\n\tvar audioLoader = new AudioLoader();\n\taudioLoader.load( file, function ( buffer ) {\n\n\t\tscope.setBuffer( buffer );\n\n\t} );\n\treturn this;\n\n};\n\nAudioAnalyser.prototype.getData = function () {\n\n\tconsole.warn( 'THREE.AudioAnalyser: .getData() is now .getFrequencyData().' );\n\treturn this.getFrequencyData();\n\n};\n\n//\n\nCubeCamera.prototype.updateCubeMap = function ( renderer, scene ) {\n\n\tconsole.warn( 'THREE.CubeCamera: .updateCubeMap() is now .update().' );\n\treturn this.update( renderer, scene );\n\n};\n\nvar minivents_commonjs = function Events(target){\n  var events = {}, empty = [];\n  target = target || this;\n  /**\n   *  On: listen to events\n   */\n  target.on = function(type, func, ctx){\n    (events[type] = events[type] || []).push([func, ctx]);\n    return target\n  };\n  /**\n   *  Off: stop listening to event / specific callback\n   */\n  target.off = function(type, func){\n    type || (events = {});\n    var list = events[type] || empty,\n        i = list.length = func ? list.length : 0;\n    while(i--) func == list[i][0] && list.splice(i,1);\n    return target\n  };\n  /** \n   * Emit: send event, callbacks will be triggered\n   */\n  target.emit = function(type){\n    var e = events[type] || empty, list = e.length > 0 ? e.slice(0, e.length) : e, i=0, j;\n    while(j=list[i++]) j[0].apply(j[1], empty.slice.call(arguments, 1));\n    return target\n  };\n};\n\n// 19.1.2.2 / 15.2.3.5 Object.create(O [, Properties])\n_export(_export.S, 'Object', { create: _objectCreate });\n\nvar $Object$2 = _core.Object;\nvar create = function create(P, D) {\n  return $Object$2.create(P, D);\n};\n\nvar create$1 = create;\n\nvar _validateCollection = function (it, TYPE) {\n  if (!_isObject(it) || it._t !== TYPE) throw TypeError('Incompatible receiver, ' + TYPE + ' required!');\n  return it;\n};\n\nvar dP$2 = _objectDp.f;\n\n\n\n\n\n\n\n\n\nvar fastKey = _meta.fastKey;\n\nvar SIZE = _descriptors ? '_s' : 'size';\n\nvar getEntry = function (that, key) {\n  // fast case\n  var index = fastKey(key);\n  var entry;\n  if (index !== 'F') return that._i[index];\n  // frozen object case\n  for (entry = that._f; entry; entry = entry.n) {\n    if (entry.k == key) return entry;\n  }\n};\n\nvar _collectionStrong = {\n  getConstructor: function (wrapper, NAME, IS_MAP, ADDER) {\n    var C = wrapper(function (that, iterable) {\n      _anInstance(that, C, NAME, '_i');\n      that._t = NAME;         // collection type\n      that._i = _objectCreate(null); // index\n      that._f = undefined;    // first entry\n      that._l = undefined;    // last entry\n      that[SIZE] = 0;         // size\n      if (iterable != undefined) _forOf(iterable, IS_MAP, that[ADDER], that);\n    });\n    _redefineAll(C.prototype, {\n      // 23.1.3.1 Map.prototype.clear()\n      // 23.2.3.2 Set.prototype.clear()\n      clear: function clear() {\n        for (var that = _validateCollection(this, NAME), data = that._i, entry = that._f; entry; entry = entry.n) {\n          entry.r = true;\n          if (entry.p) entry.p = entry.p.n = undefined;\n          delete data[entry.i];\n        }\n        that._f = that._l = undefined;\n        that[SIZE] = 0;\n      },\n      // 23.1.3.3 Map.prototype.delete(key)\n      // 23.2.3.4 Set.prototype.delete(value)\n      'delete': function (key) {\n        var that = _validateCollection(this, NAME);\n        var entry = getEntry(that, key);\n        if (entry) {\n          var next = entry.n;\n          var prev = entry.p;\n          delete that._i[entry.i];\n          entry.r = true;\n          if (prev) prev.n = next;\n          if (next) next.p = prev;\n          if (that._f == entry) that._f = next;\n          if (that._l == entry) that._l = prev;\n          that[SIZE]--;\n        } return !!entry;\n      },\n      // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)\n      // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)\n      forEach: function forEach(callbackfn /* , that = undefined */) {\n        _validateCollection(this, NAME);\n        var f = _ctx(callbackfn, arguments.length > 1 ? arguments[1] : undefined, 3);\n        var entry;\n        while (entry = entry ? entry.n : this._f) {\n          f(entry.v, entry.k, this);\n          // revert to the last existing entry\n          while (entry && entry.r) entry = entry.p;\n        }\n      },\n      // 23.1.3.7 Map.prototype.has(key)\n      // 23.2.3.7 Set.prototype.has(value)\n      has: function has(key) {\n        return !!getEntry(_validateCollection(this, NAME), key);\n      }\n    });\n    if (_descriptors) dP$2(C.prototype, 'size', {\n      get: function () {\n        return _validateCollection(this, NAME)[SIZE];\n      }\n    });\n    return C;\n  },\n  def: function (that, key, value) {\n    var entry = getEntry(that, key);\n    var prev, index;\n    // change existing entry\n    if (entry) {\n      entry.v = value;\n    // create new entry\n    } else {\n      that._l = entry = {\n        i: index = fastKey(key, true), // <- index\n        k: key,                        // <- key\n        v: value,                      // <- value\n        p: prev = that._l,             // <- previous entry\n        n: undefined,                  // <- next entry\n        r: false                       // <- removed\n      };\n      if (!that._f) that._f = entry;\n      if (prev) prev.n = entry;\n      that[SIZE]++;\n      // add to index\n      if (index !== 'F') that._i[index] = entry;\n    } return that;\n  },\n  getEntry: getEntry,\n  setStrong: function (C, NAME, IS_MAP) {\n    // add .keys, .values, .entries, [@@iterator]\n    // 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11\n    _iterDefine(C, NAME, function (iterated, kind) {\n      this._t = _validateCollection(iterated, NAME); // target\n      this._k = kind;                     // kind\n      this._l = undefined;                // previous\n    }, function () {\n      var that = this;\n      var kind = that._k;\n      var entry = that._l;\n      // revert to the last existing entry\n      while (entry && entry.r) entry = entry.p;\n      // get next entry\n      if (!that._t || !(that._l = entry = entry ? entry.n : that._t._f)) {\n        // or finish the iteration\n        that._t = undefined;\n        return _iterStep(1);\n      }\n      // return step by kind\n      if (kind == 'keys') return _iterStep(0, entry.k);\n      if (kind == 'values') return _iterStep(0, entry.v);\n      return _iterStep(0, [entry.k, entry.v]);\n    }, IS_MAP ? 'entries' : 'values', !IS_MAP, true);\n\n    // add [@@species], 23.1.2.2, 23.2.2.2\n    _setSpecies(NAME);\n  }\n};\n\nvar SPECIES$2 = _wks('species');\n\nvar _arraySpeciesConstructor = function (original) {\n  var C;\n  if (_isArray(original)) {\n    C = original.constructor;\n    // cross-realm fallback\n    if (typeof C == 'function' && (C === Array || _isArray(C.prototype))) C = undefined;\n    if (_isObject(C)) {\n      C = C[SPECIES$2];\n      if (C === null) C = undefined;\n    }\n  } return C === undefined ? Array : C;\n};\n\n// 9.4.2.3 ArraySpeciesCreate(originalArray, length)\n\n\nvar _arraySpeciesCreate = function (original, length) {\n  return new (_arraySpeciesConstructor(original))(length);\n};\n\n// 0 -> Array#forEach\n// 1 -> Array#map\n// 2 -> Array#filter\n// 3 -> Array#some\n// 4 -> Array#every\n// 5 -> Array#find\n// 6 -> Array#findIndex\n\n\n\n\n\nvar _arrayMethods = function (TYPE, $create) {\n  var IS_MAP = TYPE == 1;\n  var IS_FILTER = TYPE == 2;\n  var IS_SOME = TYPE == 3;\n  var IS_EVERY = TYPE == 4;\n  var IS_FIND_INDEX = TYPE == 6;\n  var NO_HOLES = TYPE == 5 || IS_FIND_INDEX;\n  var create = $create || _arraySpeciesCreate;\n  return function ($this, callbackfn, that) {\n    var O = _toObject($this);\n    var self = _iobject(O);\n    var f = _ctx(callbackfn, that, 3);\n    var length = _toLength(self.length);\n    var index = 0;\n    var result = IS_MAP ? create($this, length) : IS_FILTER ? create($this, 0) : undefined;\n    var val, res;\n    for (;length > index; index++) if (NO_HOLES || index in self) {\n      val = self[index];\n      res = f(val, index, O);\n      if (TYPE) {\n        if (IS_MAP) result[index] = res;   // map\n        else if (res) switch (TYPE) {\n          case 3: return true;             // some\n          case 5: return val;              // find\n          case 6: return index;            // findIndex\n          case 2: result.push(val);        // filter\n        } else if (IS_EVERY) return false; // every\n      }\n    }\n    return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : result;\n  };\n};\n\nvar dP$3 = _objectDp.f;\nvar each = _arrayMethods(0);\n\n\nvar _collection = function (NAME, wrapper, methods, common, IS_MAP, IS_WEAK) {\n  var Base = _global[NAME];\n  var C = Base;\n  var ADDER = IS_MAP ? 'set' : 'add';\n  var proto = C && C.prototype;\n  var O = {};\n  if (!_descriptors || typeof C != 'function' || !(IS_WEAK || proto.forEach && !_fails(function () {\n    new C().entries().next();\n  }))) {\n    // create collection constructor\n    C = common.getConstructor(wrapper, NAME, IS_MAP, ADDER);\n    _redefineAll(C.prototype, methods);\n    _meta.NEED = true;\n  } else {\n    C = wrapper(function (target, iterable) {\n      _anInstance(target, C, NAME, '_c');\n      target._c = new Base();\n      if (iterable != undefined) _forOf(iterable, IS_MAP, target[ADDER], target);\n    });\n    each('add,clear,delete,forEach,get,has,set,keys,values,entries,toJSON'.split(','), function (KEY) {\n      var IS_ADDER = KEY == 'add' || KEY == 'set';\n      if (KEY in proto && !(IS_WEAK && KEY == 'clear')) _hide(C.prototype, KEY, function (a, b) {\n        _anInstance(this, C, KEY);\n        if (!IS_ADDER && IS_WEAK && !_isObject(a)) return KEY == 'get' ? undefined : false;\n        var result = this._c[KEY](a === 0 ? 0 : a, b);\n        return IS_ADDER ? this : result;\n      });\n    });\n    IS_WEAK || dP$3(C.prototype, 'size', {\n      get: function () {\n        return this._c.size;\n      }\n    });\n  }\n\n  _setToStringTag(C, NAME);\n\n  O[NAME] = C;\n  _export(_export.G + _export.W + _export.F, O);\n\n  if (!IS_WEAK) common.setStrong(C, NAME, IS_MAP);\n\n  return C;\n};\n\nvar MAP = 'Map';\n\n// 23.1 Map Objects\nvar es6_map = _collection(MAP, function (get) {\n  return function Map() { return get(this, arguments.length > 0 ? arguments[0] : undefined); };\n}, {\n  // 23.1.3.6 Map.prototype.get(key)\n  get: function get(key) {\n    var entry = _collectionStrong.getEntry(_validateCollection(this, MAP), key);\n    return entry && entry.v;\n  },\n  // 23.1.3.9 Map.prototype.set(key, value)\n  set: function set(key, value) {\n    return _collectionStrong.def(_validateCollection(this, MAP), key === 0 ? 0 : key, value);\n  }\n}, _collectionStrong, true);\n\nvar _arrayFromIterable = function (iter, ITERATOR) {\n  var result = [];\n  _forOf(iter, false, result.push, result, ITERATOR);\n  return result;\n};\n\n// https://github.com/DavidBruant/Map-Set.prototype.toJSON\n\n\nvar _collectionToJson = function (NAME) {\n  return function toJSON() {\n    if (_classof(this) != NAME) throw TypeError(NAME + \"#toJSON isn't generic\");\n    return _arrayFromIterable(this);\n  };\n};\n\n// https://github.com/DavidBruant/Map-Set.prototype.toJSON\n\n\n_export(_export.P + _export.R, 'Map', { toJSON: _collectionToJson('Map') });\n\n// https://tc39.github.io/proposal-setmap-offrom/\n\n\nvar _setCollectionOf = function (COLLECTION) {\n  _export(_export.S, COLLECTION, { of: function of() {\n    var length = arguments.length;\n    var A = new Array(length);\n    while (length--) A[length] = arguments[length];\n    return new this(A);\n  } });\n};\n\n// https://tc39.github.io/proposal-setmap-offrom/#sec-map.of\n_setCollectionOf('Map');\n\n// https://tc39.github.io/proposal-setmap-offrom/\n\n\n\n\n\nvar _setCollectionFrom = function (COLLECTION) {\n  _export(_export.S, COLLECTION, { from: function from(source /* , mapFn, thisArg */) {\n    var mapFn = arguments[1];\n    var mapping, A, n, cb;\n    _aFunction(this);\n    mapping = mapFn !== undefined;\n    if (mapping) _aFunction(mapFn);\n    if (source == undefined) return new this();\n    A = [];\n    if (mapping) {\n      n = 0;\n      cb = _ctx(mapFn, arguments[2], 2);\n      _forOf(source, false, function (nextItem) {\n        A.push(cb(nextItem, n++));\n      });\n    } else {\n      _forOf(source, false, A.push, A);\n    }\n    return new this(A);\n  } });\n};\n\n// https://tc39.github.io/proposal-setmap-offrom/#sec-map.from\n_setCollectionFrom('Map');\n\nvar map = _core.Map;\n\nvar map$1 = map;\n\nvar arraySlice = [].slice;\nvar factories = {};\n\nvar construct = function (F, len, args) {\n  if (!(len in factories)) {\n    for (var n = [], i = 0; i < len; i++) n[i] = 'a[' + i + ']';\n    // eslint-disable-next-line no-new-func\n    factories[len] = Function('F,a', 'return new F(' + n.join(',') + ')');\n  } return factories[len](F, args);\n};\n\nvar _bind = Function.bind || function bind(that /* , ...args */) {\n  var fn = _aFunction(this);\n  var partArgs = arraySlice.call(arguments, 1);\n  var bound = function (/* args... */) {\n    var args = partArgs.concat(arraySlice.call(arguments));\n    return this instanceof bound ? construct(fn, args.length, args) : _invoke(fn, args, that);\n  };\n  if (_isObject(fn.prototype)) bound.prototype = fn.prototype;\n  return bound;\n};\n\n// 26.1.2 Reflect.construct(target, argumentsList [, newTarget])\n\n\n\n\n\n\n\nvar rConstruct = (_global.Reflect || {}).construct;\n\n// MS Edge supports only 2 arguments and argumentsList argument is optional\n// FF Nightly sets third argument as `new.target`, but does not create `this` from it\nvar NEW_TARGET_BUG = _fails(function () {\n  function F() { /* empty */ }\n  return !(rConstruct(function () { /* empty */ }, [], F) instanceof F);\n});\nvar ARGS_BUG = !_fails(function () {\n  rConstruct(function () { /* empty */ });\n});\n\n_export(_export.S + _export.F * (NEW_TARGET_BUG || ARGS_BUG), 'Reflect', {\n  construct: function construct(Target, args /* , newTarget */) {\n    _aFunction(Target);\n    _anObject(args);\n    var newTarget = arguments.length < 3 ? Target : _aFunction(arguments[2]);\n    if (ARGS_BUG && !NEW_TARGET_BUG) return rConstruct(Target, args, newTarget);\n    if (Target == newTarget) {\n      // w/o altered newTarget, optimization for 0-4 arguments\n      switch (args.length) {\n        case 0: return new Target();\n        case 1: return new Target(args[0]);\n        case 2: return new Target(args[0], args[1]);\n        case 3: return new Target(args[0], args[1], args[2]);\n        case 4: return new Target(args[0], args[1], args[2], args[3]);\n      }\n      // w/o altered newTarget, lot of arguments case\n      var $args = [null];\n      $args.push.apply($args, args);\n      return new (_bind.apply(Target, $args))();\n    }\n    // with altered newTarget, not support built-in constructors\n    var proto = newTarget.prototype;\n    var instance = _objectCreate(_isObject(proto) ? proto : Object.prototype);\n    var result = Function.apply.call(Target, instance, args);\n    return _isObject(result) ? result : instance;\n  }\n});\n\nvar construct$1 = _core.Reflect.construct;\n\nvar construct$2 = construct$1;\n\nvar construct$3 = createCommonjsModule(function (module) {\nfunction _construct(Parent, args, Class) {\n  if (typeof Reflect !== \"undefined\" && construct$2) {\n    module.exports = _construct = construct$2;\n  } else {\n    module.exports = _construct = function _construct(Parent, args, Class) {\n      var a = [null];\n      a.push.apply(a, args);\n      var Constructor = Parent.bind.apply(Parent, a);\n      var instance = new Constructor();\n      if (Class) setPrototypeOf$2(instance, Class.prototype);\n      return instance;\n    };\n  }\n\n  return _construct.apply(null, arguments);\n}\n\nmodule.exports = _construct;\n});\n\nvar wrapNativeSuper = createCommonjsModule(function (module) {\nfunction _wrapNativeSuper(Class) {\n  var _cache = typeof map$1 === \"function\" ? new map$1() : undefined;\n\n  module.exports = _wrapNativeSuper = function _wrapNativeSuper(Class) {\n    if (typeof Class !== \"function\") {\n      throw new TypeError(\"Super expression must either be null or a function\");\n    }\n\n    if (typeof _cache !== \"undefined\") {\n      if (_cache.has(Class)) return _cache.get(Class);\n\n      _cache.set(Class, Wrapper);\n    }\n\n    function Wrapper() {}\n\n    Wrapper.prototype = create$1(Class.prototype, {\n      constructor: {\n        value: Wrapper,\n        enumerable: false,\n        writable: true,\n        configurable: true\n      }\n    });\n    return setPrototypeOf$2(Wrapper, setPrototypeOf$2(function Super() {\n      return construct$3(Class, arguments, getPrototypeOf$2(this).constructor);\n    }, Class));\n  };\n\n  return _wrapNativeSuper(Class);\n}\n\nmodule.exports = _wrapNativeSuper;\n});\n\nvar CompositionError$1 =\n/*#__PURE__*/\nfunction (_Error) {\n  function CompositionError(classInstance, message, component) {\n    var _this;\n\n    classCallCheck(this, CompositionError);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(CompositionError).call(this, \"@\".concat(classInstance, \": \").concat(message)));\n\n    var stackArray = _this.stack.split('\\n');\n\n    stackArray.splice(1, 2);\n    _this.stack = stackArray.join('\\n');\n    if (console) console.error('Component:', component);\n    _this.name = 'CompositionError';\n    return _this;\n  }\n\n  inherits(CompositionError, _Error);\n\n  return CompositionError;\n}(wrapNativeSuper(Error));\nvar DependencyError =\n/*#__PURE__*/\nfunction (_Error2) {\n  function DependencyError(classInstance, message, activeModule) {\n    var _this2;\n\n    var dependencyModule = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n\n    classCallCheck(this, DependencyError);\n\n    _this2 = possibleConstructorReturn(this, getPrototypeOf$2(DependencyError).call(this, \"@\".concat(classInstance, \": \").concat(message)));\n\n    var stackArray = _this2.stack.split('\\n');\n\n    stackArray.splice(1, 2);\n    _this2.stack = stackArray.join('\\n');\n    if (console) console.error('Active module:', activeModule);\n    if (console && dependencyModule) console.error('Dependency published by module:', dependencyModule);\n    _this2.name = 'DependencyError';\n    return _this2;\n  }\n\n  inherits(DependencyError, _Error2);\n\n  return DependencyError;\n}(wrapNativeSuper(Error));\nvar ManagerError =\n/*#__PURE__*/\nfunction (_Error3) {\n  function ManagerError(classInstance, message, component) {\n    var _this3;\n\n    var activeModule = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n\n    classCallCheck(this, ManagerError);\n\n    _this3 = possibleConstructorReturn(this, getPrototypeOf$2(ManagerError).call(this, \"@\".concat(classInstance, \": \").concat(message)));\n\n    var stackArray = _this3.stack.split('\\n');\n\n    stackArray.splice(1, 2);\n    _this3.stack = stackArray.join('\\n');\n    if (console) console.error('Component:', component);\n    if (console && activeModule) console.error('Active module:', activeModule);\n    _this3.name = 'ManagerError';\n    return _this3;\n  }\n\n  inherits(ManagerError, _Error3);\n\n  return ManagerError;\n}(wrapNativeSuper(Error));\n\nvar warnDeps = function warnDeps() {\n  throw new Error('WhitestormJS Framework requ ires Three.js r92. https://threejs.org/');\n};\n\ntry {\n  if (!REVISION) warnDeps();\n} catch (err) {\n  warnDeps();\n}\n/**\n * @class ModuleSystem\n * @category core\n * @description  Provides API for classes that will use Modules.<br/>\n * This class includes basic event system with those supported methods:\n * <pre>.on()</pre><pre>.off()</pre><pre>.emit()</pre>\n * @extends Events\n * @memberof module:core\n */\n\n\nvar ModuleSystem =\n/*#__PURE__*/\nfunction (_Events) {\n  function ModuleSystem() {\n    classCallCheck(this, ModuleSystem);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(ModuleSystem).apply(this, arguments));\n  }\n\n  createClass(ModuleSystem, [{\n    key: \"integrateModules\",\n    // INTEGRATING\n\n    /**\n     * @method integrateModules\n     * @instance\n     * @description This method applies all modules from .modules collection.\n     * @param {Object} [source] If source (should be a component) is provided, will replace .modules with source's one before executing modules.\n     * @memberof module:core.ModuleSystem\n     */\n    value: function integrateModules(source) {\n      if (!this.modules && !source) return;\n      if (source && source.modules) this.modules = source.modules.slice(0);\n\n      if (this.modules) {\n        for (var i = 0, max = this.modules.length; i < max; i++) {\n          this.applyModule(this.modules[i], false);\n        }\n      }\n\n      if (source) this.applyBridge({\n        onCopy: source\n      });\n    } // APPLYING MODULE (...and a \"bridge\" for module)\n\n    /**\n     * @method applyBridge\n     * @instance\n     * @description Makes component-specific API to work with modules.\n     * @param {Object} bridgeMap\n     * @return {Object} Returns object with modified values.\n     * @memberof module:core.ModuleSystem\n     */\n\n  }, {\n    key: \"applyBridge\",\n    value: function applyBridge() {\n      var bridgeMap = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var modules = this.modules;\n      if (!modules) return bridgeMap;\n\n      for (var i = 0, max = modules.length; i < max; i++) {\n        for (var key in bridgeMap) {\n          if (bridgeMap[key]) {\n            var module = modules[i];\n            if (module && module.bridge && module.bridge[key]) bridgeMap[key] = module.bridge[key].apply(this, [bridgeMap[key], module]);\n          }\n        }\n      }\n\n      return bridgeMap;\n    }\n    /**\n     * @method applyCommand\n     * @instance\n     * @description .applyCommand runs a method called `name` on all modules.\n     * @param {String} name the method name.\n     * @param {Function} [cb=(func, moduleScope) => func.apply(this, [moduleScope])] How the function is wrapped/\n     * @memberof module:core.ModuleSystem\n     */\n\n  }, {\n    key: \"applyCommand\",\n    value: function applyCommand(name) {\n      var _this = this;\n\n      var cb = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function (func, moduleScope) {\n        return func.apply(_this, [moduleScope]);\n      };\n      var modules = this.modules;\n      if (!modules) return;\n\n      for (var i = 0, max = modules.length; i < max; i++) {\n        var module = modules[i];\n        if (name in module) cb(module[name], module);\n      }\n    }\n    /**\n     * @method applyModule\n     * @instance\n     * @description .applyModule is also used in .integrateModules() function.\n     * It does exactly what its name says (applies module to component or app).\n     * @param {Object} module the module to apply\n     * @param {Boolean} [push=true]\n     * @return {Object} Returns module that was applied.\n     * @throws {ManagerError}\n     * @memberof module:core.ModuleSystem\n     */\n\n  }, {\n    key: \"applyModule\",\n    value: function applyModule(module) {\n      var push = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n      if (!module) return;\n      if (push && this.modules) this.modules.push(module);else if (push) this.modules = [module];\n      if (this.manager) this.manager.active(module);\n      if (module.manager && this.manager) module.manager(this.manager);else if (module.manager) {\n        throw new ManagerError('Component', \"Module requires ModuleManager that is turned off for this component\", this, module);\n      }\n      if (module.integrate) module.integrate.bind(this)(module);\n      return module;\n    }\n    /**\n     * @method disposeModules\n     * @instance\n     * @description Disposes of all modules\n     * @memberof module:core.ModuleSystem\n     */\n\n  }, {\n    key: \"disposeModules\",\n    value: function disposeModules() {\n      while (this.modules.length) {\n        this.disposeModule(this.modules[0]);\n      }\n    }\n    /**\n     * @method disposeModule\n     * @instance\n     * @description Disposes of the given module\n     * @param {Object} module the module to dispose\n     * @return {Module} Returns module that was removed.\n     * @memberof module:core.ModuleSystem\n     */\n\n  }, {\n    key: \"disposeModule\",\n    value: function disposeModule(module) {\n      if (!module) return;\n      this.modules.splice(this.modules.indexOf(module), 1);\n      if (module.dispose) module.dispose.bind(this)(module);\n      return module;\n    } // PIPED METHOD\n\n    /**\n     * @method module\n     * @instance\n     * @description piped version of .applyModule().\n     * @param {Object} module the module to apply\n     * @return {this} returns this - app/component\n     * @throws {ManagerError}\n     * @memberof module:core.ModuleSystem\n     * @example <caption>Piped modules</caption>\n     * component\n     *   .module(new Module1())\n     *   .module(new Module2())\n     *   .module(new Module3())\n     */\n\n  }, {\n    key: \"module\",\n    value: function module(_module) {\n      this.applyModule(_module);\n      return this;\n    }\n  }]);\n\n  inherits(ModuleSystem, _Events);\n\n  return ModuleSystem;\n}(minivents_commonjs);\n\nfunction _arrayWithHoles(arr) {\n  if (Array.isArray(arr)) return arr;\n}\n\nvar arrayWithHoles = _arrayWithHoles;\n\nvar core_getIterator = _core.getIterator = function (it) {\n  var iterFn = core_getIteratorMethod(it);\n  if (typeof iterFn != 'function') throw TypeError(it + ' is not iterable!');\n  return _anObject(iterFn.call(it));\n};\n\nvar getIterator = core_getIterator;\n\nvar getIterator$1 = getIterator;\n\nfunction _iterableToArrayLimit(arr, i) {\n  var _arr = [];\n  var _n = true;\n  var _d = false;\n  var _e = undefined;\n\n  try {\n    for (var _i = getIterator$1(arr), _s; !(_n = (_s = _i.next()).done); _n = true) {\n      _arr.push(_s.value);\n\n      if (i && _arr.length === i) break;\n    }\n  } catch (err) {\n    _d = true;\n    _e = err;\n  } finally {\n    try {\n      if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n    } finally {\n      if (_d) throw _e;\n    }\n  }\n\n  return _arr;\n}\n\nvar iterableToArrayLimit = _iterableToArrayLimit;\n\nfunction _nonIterableRest() {\n  throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n}\n\nvar nonIterableRest = _nonIterableRest;\n\nfunction _slicedToArray(arr, i) {\n  return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();\n}\n\nvar slicedToArray = _slicedToArray;\n\nfunction symbolObservablePonyfill(root) {\n\tvar result;\n\tvar Symbol = root.Symbol;\n\n\tif (typeof Symbol === 'function') {\n\t\tif (Symbol.observable) {\n\t\t\tresult = Symbol.observable;\n\t\t} else {\n\t\t\tresult = Symbol('observable');\n\t\t\tSymbol.observable = result;\n\t\t}\n\t} else {\n\t\tresult = '@@observable';\n\t}\n\n\treturn result;\n}\n\n/* global window */\n\nvar root;\n\nif (typeof self !== 'undefined') {\n  root = self;\n} else if (typeof window !== 'undefined') {\n  root = window;\n} else if (typeof global !== 'undefined') {\n  root = global;\n} else if (typeof module !== 'undefined') {\n  root = module;\n} else {\n  root = Function('return this')();\n}\n\nvar result = symbolObservablePonyfill(root);\n\n/**\n * These are private action types reserved by Redux.\n * For any unknown actions, you must return the current state.\n * If the current state is undefined, you must return the initial state.\n * Do not reference these action types directly in your code.\n */\nvar ActionTypes = {\n  INIT: '@@redux/INIT' + Math.random().toString(36).substring(7).split('').join('.'),\n  REPLACE: '@@redux/REPLACE' + Math.random().toString(36).substring(7).split('').join('.')\n};\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) {\n  return typeof obj;\n} : function (obj) {\n  return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n};\n\n/**\n * @param {any} obj The object to inspect.\n * @returns {boolean} True if the argument appears to be a plain object.\n */\nfunction isPlainObject(obj) {\n  if ((typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) !== 'object' || obj === null) return false;\n\n  var proto = obj;\n  while (Object.getPrototypeOf(proto) !== null) {\n    proto = Object.getPrototypeOf(proto);\n  }\n\n  return Object.getPrototypeOf(obj) === proto;\n}\n\n/**\n * Creates a Redux store that holds the state tree.\n * The only way to change the data in the store is to call `dispatch()` on it.\n *\n * There should only be a single store in your app. To specify how different\n * parts of the state tree respond to actions, you may combine several reducers\n * into a single reducer function by using `combineReducers`.\n *\n * @param {Function} reducer A function that returns the next state tree, given\n * the current state tree and the action to handle.\n *\n * @param {any} [preloadedState] The initial state. You may optionally specify it\n * to hydrate the state from the server in universal apps, or to restore a\n * previously serialized user session.\n * If you use `combineReducers` to produce the root reducer function, this must be\n * an object with the same shape as `combineReducers` keys.\n *\n * @param {Function} [enhancer] The store enhancer. You may optionally specify it\n * to enhance the store with third-party capabilities such as middleware,\n * time travel, persistence, etc. The only store enhancer that ships with Redux\n * is `applyMiddleware()`.\n *\n * @returns {Store} A Redux store that lets you read the state, dispatch actions\n * and subscribe to changes.\n */\nfunction createStore(reducer, preloadedState, enhancer) {\n  var _ref2;\n\n  if (typeof preloadedState === 'function' && typeof enhancer === 'undefined') {\n    enhancer = preloadedState;\n    preloadedState = undefined;\n  }\n\n  if (typeof enhancer !== 'undefined') {\n    if (typeof enhancer !== 'function') {\n      throw new Error('Expected the enhancer to be a function.');\n    }\n\n    return enhancer(createStore)(reducer, preloadedState);\n  }\n\n  if (typeof reducer !== 'function') {\n    throw new Error('Expected the reducer to be a function.');\n  }\n\n  var currentReducer = reducer;\n  var currentState = preloadedState;\n  var currentListeners = [];\n  var nextListeners = currentListeners;\n  var isDispatching = false;\n\n  function ensureCanMutateNextListeners() {\n    if (nextListeners === currentListeners) {\n      nextListeners = currentListeners.slice();\n    }\n  }\n\n  /**\n   * Reads the state tree managed by the store.\n   *\n   * @returns {any} The current state tree of your application.\n   */\n  function getState() {\n    if (isDispatching) {\n      throw new Error('You may not call store.getState() while the reducer is executing. ' + 'The reducer has already received the state as an argument. ' + 'Pass it down from the top reducer instead of reading it from the store.');\n    }\n\n    return currentState;\n  }\n\n  /**\n   * Adds a change listener. It will be called any time an action is dispatched,\n   * and some part of the state tree may potentially have changed. You may then\n   * call `getState()` to read the current state tree inside the callback.\n   *\n   * You may call `dispatch()` from a change listener, with the following\n   * caveats:\n   *\n   * 1. The subscriptions are snapshotted just before every `dispatch()` call.\n   * If you subscribe or unsubscribe while the listeners are being invoked, this\n   * will not have any effect on the `dispatch()` that is currently in progress.\n   * However, the next `dispatch()` call, whether nested or not, will use a more\n   * recent snapshot of the subscription list.\n   *\n   * 2. The listener should not expect to see all state changes, as the state\n   * might have been updated multiple times during a nested `dispatch()` before\n   * the listener is called. It is, however, guaranteed that all subscribers\n   * registered before the `dispatch()` started will be called with the latest\n   * state by the time it exits.\n   *\n   * @param {Function} listener A callback to be invoked on every dispatch.\n   * @returns {Function} A function to remove this change listener.\n   */\n  function subscribe(listener) {\n    if (typeof listener !== 'function') {\n      throw new Error('Expected the listener to be a function.');\n    }\n\n    if (isDispatching) {\n      throw new Error('You may not call store.subscribe() while the reducer is executing. ' + 'If you would like to be notified after the store has been updated, subscribe from a ' + 'component and invoke store.getState() in the callback to access the latest state. ' + 'See https://redux.js.org/api-reference/store#subscribe(listener) for more details.');\n    }\n\n    var isSubscribed = true;\n\n    ensureCanMutateNextListeners();\n    nextListeners.push(listener);\n\n    return function unsubscribe() {\n      if (!isSubscribed) {\n        return;\n      }\n\n      if (isDispatching) {\n        throw new Error('You may not unsubscribe from a store listener while the reducer is executing. ' + 'See https://redux.js.org/api-reference/store#subscribe(listener) for more details.');\n      }\n\n      isSubscribed = false;\n\n      ensureCanMutateNextListeners();\n      var index = nextListeners.indexOf(listener);\n      nextListeners.splice(index, 1);\n    };\n  }\n\n  /**\n   * Dispatches an action. It is the only way to trigger a state change.\n   *\n   * The `reducer` function, used to create the store, will be called with the\n   * current state tree and the given `action`. Its return value will\n   * be considered the **next** state of the tree, and the change listeners\n   * will be notified.\n   *\n   * The base implementation only supports plain object actions. If you want to\n   * dispatch a Promise, an Observable, a thunk, or something else, you need to\n   * wrap your store creating function into the corresponding middleware. For\n   * example, see the documentation for the `redux-thunk` package. Even the\n   * middleware will eventually dispatch plain object actions using this method.\n   *\n   * @param {Object} action A plain object representing “what changed”. It is\n   * a good idea to keep actions serializable so you can record and replay user\n   * sessions, or use the time travelling `redux-devtools`. An action must have\n   * a `type` property which may not be `undefined`. It is a good idea to use\n   * string constants for action types.\n   *\n   * @returns {Object} For convenience, the same action object you dispatched.\n   *\n   * Note that, if you use a custom middleware, it may wrap `dispatch()` to\n   * return something else (for example, a Promise you can await).\n   */\n  function dispatch(action) {\n    if (!isPlainObject(action)) {\n      throw new Error('Actions must be plain objects. ' + 'Use custom middleware for async actions.');\n    }\n\n    if (typeof action.type === 'undefined') {\n      throw new Error('Actions may not have an undefined \"type\" property. ' + 'Have you misspelled a constant?');\n    }\n\n    if (isDispatching) {\n      throw new Error('Reducers may not dispatch actions.');\n    }\n\n    try {\n      isDispatching = true;\n      currentState = currentReducer(currentState, action);\n    } finally {\n      isDispatching = false;\n    }\n\n    var listeners = currentListeners = nextListeners;\n    for (var i = 0; i < listeners.length; i++) {\n      var listener = listeners[i];\n      listener();\n    }\n\n    return action;\n  }\n\n  /**\n   * Replaces the reducer currently used by the store to calculate the state.\n   *\n   * You might need this if your app implements code splitting and you want to\n   * load some of the reducers dynamically. You might also need this if you\n   * implement a hot reloading mechanism for Redux.\n   *\n   * @param {Function} nextReducer The reducer for the store to use instead.\n   * @returns {void}\n   */\n  function replaceReducer(nextReducer) {\n    if (typeof nextReducer !== 'function') {\n      throw new Error('Expected the nextReducer to be a function.');\n    }\n\n    currentReducer = nextReducer;\n    dispatch({ type: ActionTypes.REPLACE });\n  }\n\n  /**\n   * Interoperability point for observable/reactive libraries.\n   * @returns {observable} A minimal observable of state changes.\n   * For more information, see the observable proposal:\n   * https://github.com/tc39/proposal-observable\n   */\n  function observable() {\n    var _ref;\n\n    var outerSubscribe = subscribe;\n    return _ref = {\n      /**\n       * The minimal observable subscription method.\n       * @param {Object} observer Any object that can be used as an observer.\n       * The observer object should have a `next` method.\n       * @returns {subscription} An object with an `unsubscribe` method that can\n       * be used to unsubscribe the observable from the store, and prevent further\n       * emission of values from the observable.\n       */\n      subscribe: function subscribe(observer) {\n        if ((typeof observer === 'undefined' ? 'undefined' : _typeof(observer)) !== 'object' || observer === null) {\n          throw new TypeError('Expected the observer to be an object.');\n        }\n\n        function observeState() {\n          if (observer.next) {\n            observer.next(getState());\n          }\n        }\n\n        observeState();\n        var unsubscribe = outerSubscribe(observeState);\n        return { unsubscribe: unsubscribe };\n      }\n    }, _ref[result] = function () {\n      return this;\n    }, _ref;\n  }\n\n  // When a store is created, an \"INIT\" action is dispatched so that every\n  // reducer returns their initial state. This effectively populates\n  // the initial state tree.\n  dispatch({ type: ActionTypes.INIT });\n\n  return _ref2 = {\n    dispatch: dispatch,\n    subscribe: subscribe,\n    getState: getState,\n    replaceReducer: replaceReducer\n  }, _ref2[result] = observable, _ref2;\n}\n\n/**\n * @class ModuleManager\n * @category core\n * @param {Object} object handler\n * @description  Solves modules dependencies\n * @memberof module:core\n */\n\nvar ModuleManager =\n/*#__PURE__*/\nfunction () {\n  function ModuleManager(object) {\n    classCallCheck(this, ModuleManager);\n\n    this.handler = object;\n    this.currentModule = null;\n    this.store = createStore(function () {\n      var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [{}, ''];\n      var action = arguments.length > 1 ? arguments[1] : undefined;\n      state[0][action.key] = action.data;\n      state[1] = action.key;\n      return state;\n    });\n    this.modules = {};\n  }\n  /**\n   * @method active\n   * @instance\n   * @description Sets .currentModule to provided module.\n   * @param {Object} module the module to make current\n   * @memberof module:core.ModuleManager\n   */\n\n\n  createClass(ModuleManager, [{\n    key: \"active\",\n    value: function active(module) {\n      this.currentModule = module;\n    }\n    /**\n     * @method reset\n     * @instance\n     * @description Set's .currentModule to null.\n     * @memberof module:core.ModuleManager\n     */\n\n  }, {\n    key: \"reset\",\n    value: function reset() {\n      this.currentModule = null;\n    }\n    /**\n     * @method define\n     * @instance\n     * @description Define the module in manager\n     * @param name The module name\n     * @memberof module:core.ModuleManager\n     */\n\n  }, {\n    key: \"define\",\n    value: function define(name) {\n      this.modules[name] = this.currentModule;\n    }\n    /**\n     * @method use\n     * @instance\n     * @description Get the defined module from manager\n     * @param name The module name\n     * @memberof module:core.ModuleManager\n     */\n\n  }, {\n    key: \"use\",\n    value: function use(name) {\n      return this.modules[name];\n    }\n    /**\n     * @method set\n     * @instance\n     * @description An alias for .add() <br/><br/>\n     * Use this method if you know that you will overwrite existing dependency.<br/>\n     * Use it in your app, but not in module that you provide to other people.\n     * @param {String} key the key of the dependency\n     * @param {Object} data the value of the dependency\n     * @memberof module:core.ModuleManager\n     */\n\n  }, {\n    key: \"set\",\n    value: function set(key, data) {\n      this.store.dispatch({\n        type: 'ADD',\n        key: key,\n        data: data\n      });\n    }\n    /**\n     * @method get\n     * @instance\n     * @description Returns dependency in store object, by key.\n     * @param {String} key the key of the dependency\n     * @memberof module:core.ModuleManager\n     * @return {Object|Module}\n     * @throws {DependencyError} if dependency is not in the store\n     * @example <caption>Get the 'hello' dependency</caption>\n     * manager.get('hello'); // -> {world: true}\n     */\n\n  }, {\n    key: \"get\",\n    value: function get(key) {\n      if (!this.store.getState()[0][key]) {\n        throw new DependencyError('ModuleManager', \"Module requires '\".concat(key, \"' dependency\"), this.currentModule);\n      }\n\n      return this.store.getState()[0][key];\n    }\n    /**\n     * @method has\n     * @instance\n     * @description Returns whether manager has a dependency with the given key\n     * @param {String} key the key of the dependency\n     * @memberof module:core.ModuleManager\n     * @return {Boolean} Promise that is resolved when all promises completed.\n     * @example <caption>Check whether the store has the 'hello' dependency</caption>\n     * manager.has('hello'); // -> true\n     */\n\n  }, {\n    key: \"has\",\n    value: function has(key) {\n      return Boolean(this.store.getState()[0][key]);\n    }\n    /**\n     * @method update\n     * @instance\n     * @description Updates deps\n     * @param {Object} [depsMap={}]\n     * @memberof module:core.ModuleManager\n     */\n\n  }, {\n    key: \"update\",\n    value: function update() {\n      var _this = this;\n\n      var depsMap = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      this.store.subscribe(function () {\n        var _this$store$getState = _this.store.getState(),\n            _this$store$getState2 = slicedToArray(_this$store$getState, 2),\n            data = _this$store$getState2[0],\n            changedKey = _this$store$getState2[1];\n\n        var callback = depsMap[changedKey];\n        if (callback) callback(data[changedKey]);\n      });\n    }\n    /**\n     * @method add\n     * @alias module:core.ModuleManager#set\n     * @memberof module:core.ModuleManager\n     */\n\n  }, {\n    key: \"add\",\n    value: function add() {\n      console.warn('.add() method is deprecated. Use .set() instead');\n      return this.set.apply(this, arguments);\n    }\n    /**\n     * @method require\n     * @instance\n     * @description Require module\n     * @param {String} name Defined name\n     * @param {Function} moduleExecutor Function that returns applied module\n     * @memberof module:core.ModuleManager\n     */\n\n  }, {\n    key: \"require\",\n    value: function require(name, moduleExecutor) {\n      if (this.use(name) === undefined) this.handler.applyModule(moduleExecutor());\n    }\n  }]);\n\n  return ModuleManager;\n}();\n\n/**\n * @class Component\n * @category core\n * @param {Object} [params] - The parameters object.\n * @param {Object} [instructions] - The instructions object.\n * @extends ModuleSystem\n * @memberof module:core\n */\n\nvar Component =\n/*#__PURE__*/\nfunction (_ModuleSystem) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:core.Component#defaults\n   * @static\n   * @default {\n   *   modules: [],\n   *   manager: true\n   * }\n   */\n\n  /**\n   * Static instructions\n   * @member {Object} module:core.Component#instructions\n   * @static\n   * @default {}\n   */\n\n  /**\n   * Array of promises that should be resolved before Component is ready.\n   * @member {Array} module:core.Component#_wait\n   * @private\n   */\n  // Collection of promises;\n\n  /**\n   * Collection of `modules`.\n   * @member {Array} module:core.Component#modules\n   * @public\n   */\n  // Collection of modules;\n\n  /**\n   * Collection of `child` Components.\n   * @member {Array} module:core.Component#children\n   * @public\n   */\n  // For keeping children components;\n  function Component() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n    var defaults = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : Component.defaults;\n    var instructions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : Component.instructions;\n\n    classCallCheck(this, Component);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Component).call(this)); // Apply polyfilled parameters to .params;\n\n    defineProperty$3(defineProperty$3(defineProperty$3(assertThisInitialized(assertThisInitialized(_this)), \"_wait\", []), \"modules\", []), \"children\", []);\n\n    _this.params = extend(transformData(params, instructions), defaults);\n    if (_this.params.manager) _this.manager = new ModuleManager(assertThisInitialized(assertThisInitialized(_this)));\n    _this.modules = _this.params.modules;\n\n    _this.integrateModules();\n\n    return _this;\n  }\n  /**\n   * @method wait\n   * @instance\n   * @description Wait for a promise.\n   * @param {Promise} [promise] - The promise that should be added to a queue.\n   * @return {Promise} Promise that is resolved when all promises completed.\n   * @memberof module:core.Component\n   */\n\n\n  createClass(Component, [{\n    key: \"wait\",\n    value: function wait(promise) {\n      if (promise) this._wait.push(promise);\n      return Promise.all(this._wait);\n    }\n    /**\n     * @method defer\n     * @instance\n     * @description Execute `func` (Callback) when Component is ready.\n     * @param {Function} func - Callback.\n     * @memberof module:core.Component\n     */\n\n  }, {\n    key: \"defer\",\n    value: function defer(func) {\n      var _this2 = this;\n\n      if (this.isDeffered) this.wait().then(function () {\n        return func(_this2);\n      });else func(this);\n    } // PARAMETERS\n\n    /**\n     * @method updateParams\n     * @instance\n     * @description Updates parameters of the Component.\n     * @return {Object} Params of this Component\n     * @memberof module:core.Component\n     */\n\n  }, {\n    key: \"updateParams\",\n    value: function updateParams() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      this.params = extend(params, this.params);\n      return this.params;\n    } // COPYING & CLONING\n\n    /**\n     * @method clone\n     * @instance\n     * @description Clone this component\n     * @return {object} a cloned component with all its source component' params copied.\n     * @memberof module:core.Component\n     */\n\n  }, {\n    key: \"clone\",\n    value: function clone() {\n      return new this.constructor(this.params).copy(this);\n    }\n    /**\n     * @method copy\n     * @instance\n     * @description Copy source native and integrate `modules` to it.\n     * @param {Component} source - Source component that is used for `copy()` action.\n     * @param {Function} [customize] - Callback executed before modules integration process.\n     * @return {this} Component\n     * @memberof module:core.Component\n     */\n\n  }, {\n    key: \"copy\",\n    value: function copy(source, customize) {\n      this.params = objectSpread({}, source.params);\n      if (source.native) this.native = source.native.clone(source.params);\n      if (customize) customize();\n      this.integrateModules(source);\n      return this;\n    }\n    /**\n     * @method add\n     * @instance\n     * @description Add a child `Component`.\n     * @param {Component} object - Component that should be added as a `child`.\n     * @return {Promise} Resolved when action is done.\n     * @memberof module:core.Component\n     */\n\n  }, {\n    key: \"add\",\n    value: function () {\n      var _add = asyncToGenerator(\n      /*#__PURE__*/\n      regenerator.mark(function _callee(object) {\n        return regenerator.wrap(function _callee$(_context) {\n          while (1) {\n            switch (_context.prev = _context.next) {\n              case 0:\n                if (!object.parent) {\n                  _context.next = 3;\n                  break;\n                }\n\n                _context.next = 3;\n                return object.parent.remove(object);\n\n              case 3:\n                _context.next = 5;\n                return this.wait();\n\n              case 5:\n                _context.next = 7;\n                return object.wait();\n\n              case 7:\n                if (object.native) {\n                  _context.next = 9;\n                  break;\n                }\n\n                throw new CompositionError$1('Component', 'there is no object.native', this);\n\n              case 9:\n                object.parent = this;\n                _context.next = 12;\n                return this.applyBridge({\n                  onAdd: object\n                }).onAdd;\n\n              case 12:\n                this.native.add(object.native);\n                this.children.push(object);\n                return _context.abrupt(\"return\", object);\n\n              case 15:\n              case \"end\":\n                return _context.stop();\n            }\n          }\n        }, _callee, this);\n      }));\n\n      return function add(_x) {\n        return _add.apply(this, arguments);\n      };\n    }()\n    /**\n     * @method remove\n     * @instance\n     * @description Remove a child `Component`.\n     * @param {Component} object - Component that should be a **child** of this Component.\n     * @return {Promise} Resolved when action is done.\n     * @memberof module:core.Component\n     */\n\n  }, {\n    key: \"remove\",\n    value: function () {\n      var _remove = asyncToGenerator(\n      /*#__PURE__*/\n      regenerator.mark(function _callee2(object) {\n        return regenerator.wrap(function _callee2$(_context2) {\n          while (1) {\n            switch (_context2.prev = _context2.next) {\n              case 0:\n                if (!(object.parent !== this)) {\n                  _context2.next = 2;\n                  break;\n                }\n\n                return _context2.abrupt(\"return\");\n\n              case 2:\n                _context2.next = 4;\n                return this.wait();\n\n              case 4:\n                _context2.next = 6;\n                return object.wait();\n\n              case 6:\n                object.parent = null;\n                this.native.remove(object.native);\n                this.children.splice(this.children.indexOf(object), 1);\n\n              case 9:\n              case \"end\":\n                return _context2.stop();\n            }\n          }\n        }, _callee2, this);\n      }));\n\n      return function remove(_x2) {\n        return _remove.apply(this, arguments);\n      };\n    }()\n    /**\n     * @method addTo\n     * @instance\n     * @description Adds `this` Component to specified `App`/`Component`.\n     * @param {Component} object - Component that will be a parent of `this`.\n     * @memberof module:core.Component\n     */\n\n  }, {\n    key: \"addTo\",\n    value: function addTo(object) {\n      return object.add(this);\n    }\n  }, {\n    key: \"get\",\n    value: function get(key) {\n      return this.manager.get(key);\n    }\n  }, {\n    key: \"use\",\n    value: function use(key) {\n      return this.manager.use(key);\n    }\n    /**\n     * Returns whether the object is `async` (`wait` promises are more than `0`).\n     * @member {Boolean} module:core.Component#isDeffered\n     */\n\n  }, {\n    key: \"isDeffered\",\n    get: function get() {\n      return this._wait.length > 0;\n    }\n    /**\n     * Returns the `ModuleManager` used for this component.\n     * @member {ModuleManager} module:core.Component#manager\n     * @throws {ManagerError}\n     */\n\n  }, {\n    key: \"manager\",\n    get: function get() {\n      if (this._manager) return this._manager;\n      throw new ManagerError('Component', \"ModuleManager is not used in this component. 'manager' parameter should be set as 'true'\", this);\n    },\n    set: function set(manager) {\n      this._manager = manager;\n    }\n    /**\n     * Returns the `native` object used for this component.\n     * @member {Object} module:core.Component#native\n     */\n\n  }, {\n    key: \"native\",\n    get: function get() {\n      return this._native;\n    },\n    set: function set(mesh) {\n      this._native = mesh;\n      this._native.component = this;\n      return this._native;\n    }\n  }]);\n\n  inherits(Component, _ModuleSystem);\n\n  return Component;\n}(ModuleSystem);\n\ndefineProperty$3(defineProperty$3(Component, \"defaults\", {\n  modules: null,\n  manager: true\n}), \"instructions\", {});\n\n// 26.1.6 Reflect.get(target, propertyKey [, receiver])\n\n\n\n\n\n\n\nfunction get(target, propertyKey /* , receiver */) {\n  var receiver = arguments.length < 3 ? target : arguments[2];\n  var desc, proto;\n  if (_anObject(target) === receiver) return target[propertyKey];\n  if (desc = _objectGopd.f(target, propertyKey)) return _has(desc, 'value')\n    ? desc.value\n    : desc.get !== undefined\n      ? desc.get.call(receiver)\n      : undefined;\n  if (_isObject(proto = _objectGpo(target))) return get(proto, propertyKey, receiver);\n}\n\n_export(_export.S, 'Reflect', { get: get });\n\nvar get$1 = _core.Reflect.get;\n\nvar get$2 = get$1;\n\nfunction _superPropBase(object, property) {\n  while (!Object.prototype.hasOwnProperty.call(object, property)) {\n    object = getPrototypeOf$2(object);\n    if (object === null) break;\n  }\n\n  return object;\n}\n\nvar superPropBase = _superPropBase;\n\nvar get$3 = createCommonjsModule(function (module) {\nfunction _get(target, property, receiver) {\n  if (typeof Reflect !== \"undefined\" && get$2) {\n    module.exports = _get = get$2;\n  } else {\n    module.exports = _get = function _get(target, property, receiver) {\n      var base = superPropBase(target, property);\n      if (!base) return;\n\n      var desc = getOwnPropertyDescriptor$1(base, property);\n\n      if (desc.get) {\n        return desc.get.call(receiver);\n      }\n\n      return desc.value;\n    };\n  }\n\n  return _get(target, property, receiver || target);\n}\n\nmodule.exports = _get;\n});\n\nfunction attributes() {\n  for (var _len = arguments.length, mappers = new Array(_len), _key = 0; _key < _len; _key++) {\n    mappers[_key] = arguments[_key];\n  }\n\n  return function (target) {\n    for (var i = 0; i < mappers.length; i++) {\n      var mapper = mappers[i];\n\n      for (var k = 0; k < mapper.map.length; k++) {\n        var attribute = mapper.map[k];\n        Object.defineProperty(target.prototype, attribute, {\n          get: mapper.getter(attribute),\n          set: mapper.setter(attribute),\n          configurable: mapper.configurable,\n          enumerable: mapper.enumerable\n        });\n      }\n    }\n  };\n}\nfunction copy() {\n  for (var _len2 = arguments.length, map = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n    map[_key2] = arguments[_key2];\n  }\n\n  return {\n    map: map,\n    getter: function getter(name) {\n      return function () {\n        return this.native[name];\n      };\n    },\n    setter: function setter(name) {\n      return function (value) {\n        this.native[name].copy(value);\n      };\n    },\n    configurable: true,\n    enumerable: true\n  };\n}\nfunction mirror() {\n  for (var _len3 = arguments.length, map = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n    map[_key3] = arguments[_key3];\n  }\n\n  return {\n    map: map,\n    getter: function getter(name) {\n      return function () {\n        return this.native[name];\n      };\n    },\n    setter: function setter(name) {\n      return function (value) {\n        this.native[name] = value;\n      };\n    },\n    configurable: true,\n    enumerable: true\n  };\n}\n\nvar _dec, _class;\nvar \n/**\n * @class MeshComponent\n * @category core\n * @param {Object} [params] - The parameters object.\n * @param {Object} [instructions] - The instructions object.\n * @extends module:core.Component\n * @memberof module:core\n */\nMeshComponent = (_dec = attributes(copy('position', 'rotation', 'quaternion', 'scale'), mirror('material', 'geometry')), _dec(_class =\n/*#__PURE__*/\nfunction (_Component) {\n  createClass(MeshComponent, null, [{\n    key: \"custom\",\n\n    /**\n     * Default values for parameters\n     * @member {Object} module:core.MeshComponent#defaults\n     * @static\n     * @default\n     * {\n     *   build: true,\n     *   geometry: {},\n     *   material: false,\n     *\n     *   shadow: {\n     *     cast: true,\n     *     receive: true\n     *   },\n     *\n     *   position: {x: 0, y: 0, z: 0},\n     *   rotation: {x: 0, y: 0, z: 0},\n     *   scale: {x: 1, y: 1, z: 1}\n     * }\n     */\n\n    /**\n     * Static instructions\n     * @member {Object} module:core.MeshComponent#instructions\n     * @static\n     * @default\n     * {\n     *   position: ['x', 'y', 'z'],\n     *   rotation: ['x', 'y', 'z'],\n     *   scale: ['x', 'y', 'z']\n     * }\n     */\n    // CUSTOM GEOMETRY HANDLING\n    value: function custom(geom) {\n      var constructor = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : Mesh;\n      return (\n        /*#__PURE__*/\n        function (_MeshComponent) {\n          function _class2() {\n            classCallCheck(this, _class2);\n\n            return possibleConstructorReturn(this, getPrototypeOf$2(_class2).apply(this, arguments));\n          }\n\n          createClass(_class2, [{\n            key: \"build\",\n            value: function build() {\n              var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n              var _this$applyBridge = this.applyBridge({\n                geometry: geom,\n                material: params.material\n              }),\n                  geometry = _this$applyBridge.geometry,\n                  material = _this$applyBridge.material;\n\n              return this.applyBridge({\n                mesh: new constructor(geometry, material)\n              }).mesh;\n            }\n          }]);\n\n          inherits(_class2, _MeshComponent);\n\n          return _class2;\n        }(MeshComponent)\n      );\n    }\n  }, {\n    key: \"create\",\n    value: function create(geom, params, constructor) {\n      return new (MeshComponent.custom(geom, constructor))(params);\n    }\n  }, {\n    key: \"from\",\n    value: function from(mesh) {\n      var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n      params.build = false;\n      var component = new MeshComponent(params);\n      component.native = mesh;\n      component.wrap();\n      return component;\n    }\n  }]);\n\n  function MeshComponent(params) {\n    var _this;\n\n    var defaults = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : MeshComponent.defaults;\n    var instructions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : MeshComponent.instructions;\n\n    classCallCheck(this, MeshComponent);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(MeshComponent).call(this, params, defaults, instructions));\n\n    if (_this.params.build) {\n      var build = _this.build(_this.params);\n\n      if (!build) {\n        throw new CompositionError$1('MeshComponent', '.build() method should return a THREE.Object3D or a Promise resolved with THREE.Object3D.', assertThisInitialized(assertThisInitialized(_this)));\n      }\n\n      if (build instanceof Promise) {\n        _this.wait(build);\n\n        _this.wait(new Promise(function (resolve) {\n          build.then(function (native) {\n            _this.native = native;\n\n            _this.wrap().then(resolve);\n          });\n        }));\n      } else {\n        _this.native = build;\n\n        _this.wait(_this.wrap());\n      }\n    }\n\n    _this.applyCommand('postIntegrate');\n\n    return _this;\n  } // BUILDING & WRAPPING\n\n  /**\n   * @method build\n   * @description Build livecycle should return a native object.\n   * @throws {CompositionError}\n   * @memberof module:core.MeshComponent\n   */\n\n\n  createClass(MeshComponent, [{\n    key: \"build\",\n    value: function build() {\n      throw new CompositionError$1('MeshComponent', 'Instance should have it\\'s own .build().', this);\n    }\n    /**\n     * @method wrap\n     * @instance\n     * @description Wraps transforms (`position` & `rotation`)\n     * @return {Promise} Resolved when action is completed\n     * @memberof module:core.MeshComponent\n     */\n\n  }, {\n    key: \"wrap\",\n    value: function wrap() {\n      var _this2 = this;\n\n      return new Promise(function (resolve) {\n        // TODO: Fix defer with physics\n        // this.defer(() => {\n        var _this2$params = _this2.params,\n            position = _this2$params.position,\n            rotation = _this2$params.rotation,\n            scale = _this2$params.scale,\n            shadow = _this2$params.shadow;\n\n        _this2.position.set(position.x, position.y, position.z);\n\n        _this2.rotation.set(rotation.x, rotation.y, rotation.z);\n\n        _this2.scale.set(scale.x, scale.y, scale.z);\n\n        _this2.native.castShadow = shadow.cast;\n        _this2.native.receiveShadow = shadow.receive;\n\n        _this2.applyBridge({\n          onWrap: 1\n        });\n\n        resolve(_this2); // });\n      });\n    } // COPYING & CLONING\n\n    /**\n     * @method copy\n     * @instance\n     * @description Copy source transforms & execute `Component.copy()`\n     * @return {this} MeshComponent\n     * @memberof module:core.MeshComponent\n     */\n\n  }, {\n    key: \"copy\",\n    value: function copy$$1(source) {\n      var _this3 = this;\n\n      return get$3(getPrototypeOf$2(MeshComponent.prototype), \"copy\", this).call(this, source, function () {\n        _this3.position.copy(source.position);\n\n        _this3.rotation.copy(source.rotation);\n\n        _this3.quaternion.copy(source.quaternion);\n      });\n    }\n    /**\n     * @method clone\n     * @instance\n     * @description Make a clone of this MeshComponent using `.copy()`\n     * @return {MeshComponent} clone of this object\n     * @memberof module:core.MeshComponent\n     */\n\n  }, {\n    key: \"clone\",\n    value: function clone(geometry, material) {\n      var dest = new this.constructor({\n        build: false\n      }).copy(this);\n      if (geometry) dest.geometry = dest.geometry.clone();\n      if (material) dest.material = dest.material.clone();\n      return dest;\n    }\n  }]);\n\n  inherits(MeshComponent, _Component);\n\n  return MeshComponent;\n}(Component)) || _class);\n\ndefineProperty$3(defineProperty$3(MeshComponent, \"defaults\", objectSpread({}, Component.defaults, {\n  build: true,\n  geometry: {},\n  material: false,\n  shadow: {\n    cast: true,\n    receive: true\n  },\n  position: {\n    x: 0,\n    y: 0,\n    z: 0\n  },\n  rotation: {\n    x: 0,\n    y: 0,\n    z: 0\n  },\n  scale: {\n    x: 1,\n    y: 1,\n    z: 1\n  }\n})), \"instructions\", {\n  position: ['x', 'y', 'z'],\n  rotation: ['x', 'y', 'z'],\n  scale: ['x', 'y', 'z']\n});\n\nvar _dec$1, _class$1;\nvar \n/**\n * @class LightComponent\n * @category core\n * @param {Object} [params] - The parameters object.\n * @param {Object} [instructions] - The instructions object.\n * @extends module:core.Component\n * @memberof module:core\n */\nLightComponent = (_dec$1 = attributes(copy('position', 'rotation', 'quaternion', 'target')), _dec$1(_class$1 =\n/*#__PURE__*/\nfunction (_Component) {\n  createClass(LightComponent, null, [{\n    key: \"from\",\n\n    /**\n     * Default values for parameters\n     * @member {Object} module:core.LightComponent#defaults\n     * @static\n     * @default\n     * {\n     *   build: true,\n     *\n     *   shadow: {\n     *     cast: true,\n     *\n     *     bias: 0,\n     *     radius: 1,\n     *\n     *     mapSize: {\n     *       width: 1024,\n     *       height: 1024\n     *     },\n     *\n     *     camera: {\n     *       near: true,\n     *       far: 400,\n     *       fov: 90,\n     *\n     *       top: 200,\n     *       bottom: -200,\n     *       left: -200,\n     *       right: 200\n     *     }\n     *   },\n     *\n     *   position: {x: 0, y: 0, z: 0},\n     *   rotation: {x: 0, y: 0, z: 0}\n     * }\n     */\n\n    /**\n     * Static instructions\n     * @member {Object} module:core.LightComponent#instructions\n     * @static\n     * @default\n     * {\n     *   position: ['x', 'y', 'z'],\n     *   rotation: ['x', 'y', 'z']\n     * }\n     */\n    value: function from(light) {\n      var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n      var wrapShadow = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n      params.build = false;\n      var component = new LightComponent(params);\n      component.native = light;\n      component.wrap();\n      if (wrapShadow) component.wrapShadow();\n      return component;\n    }\n  }]);\n\n  function LightComponent(params) {\n    var _this;\n\n    var defaults = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : LightComponent.defaults;\n    var instructions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : LightComponent.instructions;\n\n    classCallCheck(this, LightComponent);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(LightComponent).call(this, params, defaults, instructions));\n\n    if (_this.params.build) {\n      var build = _this.build(_this.params);\n\n      if (!build) {\n        throw new CompositionError$1('LightComponent', '.build() method should return a THREE.Object3D or a Promise resolved with THREE.Object3D.', assertThisInitialized(assertThisInitialized(_this)));\n      }\n\n      if (build instanceof Promise) {\n        build.then(function (native) {\n          _this.native = native;\n        });\n      } else _this.native = build;\n\n      _this.wait(_this.wrap());\n    }\n\n    _this.applyCommand('postIntegrate');\n\n    return _this;\n  } // BUILDING & WRAPPING\n\n  /**\n   * @method build\n   * @instance\n   * @description Build livecycle should return a native object.\n   * @throws {CompositionError}\n   * @memberof module:core.LightComponent\n   */\n\n\n  createClass(LightComponent, [{\n    key: \"build\",\n    value: function build() {\n      throw new CompositionError$1('MeshComponent', 'Instance should have it\\'s own .build().', this);\n    }\n    /**\n     * @method wrap\n     * @instance\n     * @description Wraps transforms (`position` & `rotation`)\n     * @return {Promise} Resolved when action is completed\n     * @memberof module:core.LightComponent\n     */\n\n  }, {\n    key: \"wrap\",\n    value: function wrap() {\n      var _this2 = this;\n\n      return new Promise(function (resolve) {\n        _this2.defer(function () {\n          var _this2$params = _this2.params,\n              position = _this2$params.position,\n              rotation = _this2$params.rotation;\n\n          _this2.position.set(position.x, position.y, position.z);\n\n          _this2.rotation.set(rotation.x, rotation.y, rotation.z);\n\n          _this2.applyBridge({\n            onWrap: 1\n          });\n\n          resolve(_this2);\n        });\n      });\n    }\n    /**\n     * @method wrapShadow\n     * @instance\n     * @description Wraps shadow properties\n     * @memberof module:core.LightComponent\n     */\n\n  }, {\n    key: \"wrapShadow\",\n    value: function wrapShadow() {\n      var native = this.native,\n          shadow = this.params.shadow;\n      native.castShadow = shadow.cast;\n      native.shadow.mapSize.width = shadow.mapSize.width;\n      native.shadow.mapSize.height = shadow.mapSize.height;\n      native.shadow.bias = shadow.bias;\n      native.shadow.radius = shadow.radius;\n      var shadowCamera = native.shadow.camera;\n      var camera = shadow.camera;\n      shadowCamera.near = camera.near;\n      shadowCamera.far = camera.far;\n      shadowCamera.fov = camera.fov;\n      shadowCamera.left = camera.left;\n      shadowCamera.right = camera.right;\n      shadowCamera.top = camera.top;\n      shadowCamera.bottom = camera.bottom;\n    } // COPYING & CLONING\n\n    /**\n     * @method copy\n     * @instance\n     * @description Copy source transforms & execute `Component.copy()`\n     * @return {this} LightComponent\n     * @memberof module:core.LightComponent\n     */\n\n  }, {\n    key: \"copy\",\n    value: function copy$$1(source) {\n      var _this3 = this;\n\n      return get$3(getPrototypeOf$2(LightComponent.prototype), \"copy\", this).call(this, source, function () {\n        if (_this3.target) _this3.target.copy(source.target());\n\n        _this3.position.copy(source.position);\n\n        _this3.rotation.copy(source.rotation);\n\n        _this3.quaternion.copy(source.quaternion);\n      });\n    }\n    /**\n     * @method clone\n     * @instance\n     * @description Make a clone of this LightComponent using `.copy()`\n     * @return {LightComponent} clone of this object\n     * @memberof module:core.LightComponent\n     */\n\n  }, {\n    key: \"clone\",\n    value: function clone() {\n      return new this.constructor({\n        build: false\n      }).copy(this);\n    }\n  }]);\n\n  inherits(LightComponent, _Component);\n\n  return LightComponent;\n}(Component)) || _class$1);\n\ndefineProperty$3(defineProperty$3(LightComponent, \"defaults\", objectSpread({}, Component.defaults, {\n  build: true,\n  shadow: {\n    cast: true,\n    bias: 0,\n    radius: 1,\n    mapSize: {\n      width: 1024,\n      height: 1024\n    },\n    camera: {\n      near: true,\n      far: 400,\n      fov: 90,\n      top: 200,\n      bottom: -200,\n      left: -200,\n      right: 200\n    }\n  },\n  position: {\n    x: 0,\n    y: 0,\n    z: 0\n  },\n  rotation: {\n    x: 0,\n    y: 0,\n    z: 0\n  }\n})), \"instructions\", {\n  position: ['x', 'y', 'z'],\n  rotation: ['x', 'y', 'z']\n});\n\nvar _dec$2, _class$2;\nvar \n/**\n * @class CameraComponent\n * @category core\n * @param {Object} [params] - The parameters object.\n * @param {Object} [instructions] - The instructions object.\n * @extends module:core.Component\n * @memberof module:core\n */\nCameraComponent = (_dec$2 = attributes(copy('position', 'rotation', 'quaternion', 'target')), _dec$2(_class$2 =\n/*#__PURE__*/\nfunction (_Component) {\n  createClass(CameraComponent, null, [{\n    key: \"from\",\n\n    /**\n     * Default values for parameters\n     * @member {Object} module:core.CameraComponent#defaults\n     * @static\n     * @default\n     * {\n     *   build: true,\n     *\n     *   position: {x: 0, y: 0, z: 0},\n     *   rotation: {x: 0, y: 0, z: 0}\n     * }\n     */\n\n    /**\n     * Static instructions\n     * @member {Object} module:core.CameraComponent#instructions\n     * @static\n     * @default\n     * {\n     *   position: ['x', 'y', 'z'],\n     *   rotation: ['x', 'y', 'z'],\n     *   scale: ['x', 'y', 'z']\n     * }\n     */\n    value: function from(camera) {\n      var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n      params.build = false;\n      var component = new CameraComponent(params);\n      component.native = camera;\n      component.wrap();\n      return component;\n    }\n  }]);\n\n  function CameraComponent(params) {\n    var _this;\n\n    var defaults = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : CameraComponent.defaults;\n    var instructions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : CameraComponent.instructions;\n\n    classCallCheck(this, CameraComponent);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(CameraComponent).call(this, params, defaults, instructions));\n\n    if (_this.params.build) {\n      var build = _this.build(_this.params);\n\n      if (!build) {\n        throw new CompositionError$1('CameraComponent', '.build() method should return a THREE.Object3D or a Promise resolved with THREE.Object3D.', assertThisInitialized(assertThisInitialized(_this)));\n      }\n\n      if (build instanceof Promise) {\n        build.then(function (native) {\n          _this.native = native;\n        });\n      } else _this.native = build;\n\n      _this.wait(_this.wrap());\n    }\n\n    _this.applyCommand('postIntegrate');\n\n    return _this;\n  } // BUILDING & WRAPPING\n\n  /**\n   * @method build\n   * @instance\n   * @description Build livecycle should return a native object.\n   * @throws {CompositionError}\n   * @memberof module:core.CameraComponent\n   */\n\n\n  createClass(CameraComponent, [{\n    key: \"build\",\n    value: function build() {\n      throw new CompositionError$1('CameraComponent', 'Instance should have it\\'s own .build().', this);\n    }\n    /**\n     * @method wrap\n     * @instance\n     * @description Wraps transforms (`position` & `rotation`)\n     * @return {Promise} Resolved when action is completed\n     * @memberof module:core.CameraComponent\n     */\n\n  }, {\n    key: \"wrap\",\n    value: function wrap() {\n      var _this2 = this;\n\n      return new Promise(function (resolve) {\n        _this2.defer(function () {\n          _this2.position.set(_this2.params.position.x, _this2.params.position.y, _this2.params.position.z);\n\n          _this2.rotation.set(_this2.params.rotation.x, _this2.params.rotation.y, _this2.params.rotation.z);\n\n          _this2.applyBridge({\n            onWrap: 1\n          });\n\n          resolve(_this2);\n        });\n      });\n    }\n    /**\n     * @method copy\n     * @instance\n     * @description Copy source transforms & execute `Component.copy()`\n     * @return {this} CameraComponent\n     * @memberof module:core.CameraComponent\n     */\n\n  }, {\n    key: \"copy\",\n    value: function copy$$1(source) {\n      var _this3 = this;\n\n      return get$3(getPrototypeOf$2(CameraComponent.prototype), \"copy\", this).call(this, source, function () {\n        if (_this3.target) _this3.target.copy(source.target());\n\n        _this3.position.copy(source.position);\n\n        _this3.rotation.copy(source.rotation);\n\n        _this3.quaternion.copy(source.quaternion);\n      });\n    }\n    /**\n     * @method clone\n     * @instance\n     * @description Make a clone of this CameraComponent using `.copy()`\n     * @return {CameraComponent} clone of this object\n     * @memberof module:core.CameraComponent\n     */\n\n  }, {\n    key: \"clone\",\n    value: function clone() {\n      return new this.constructor({\n        build: false\n      }).copy(this);\n    }\n  }]);\n\n  inherits(CameraComponent, _Component);\n\n  return CameraComponent;\n}(Component)) || _class$2);\n\ndefineProperty$3(defineProperty$3(CameraComponent, \"defaults\", objectSpread({}, Component.defaults, {\n  build: true,\n  position: {\n    x: 0,\n    y: 0,\n    z: 0\n  },\n  rotation: {\n    x: 0,\n    y: 0,\n    z: 0\n  }\n})), \"instructions\", {\n  position: ['x', 'y', 'z'],\n  rotation: ['x', 'y', 'z'],\n  scale: ['x', 'y', 'z']\n});\n\nconst version = \"2.2.0-alpha.0\";\n\nvar system = {\n  window: typeof window === 'undefined' ? global : window\n};\n\n/**\n * @class App\n * @category core\n * @description This component is used to prepare a world scene, setup physics, camera, renderer and all other things that you usually do before making meshes.\n * @param {Array} [modules=[]] - Array of Modules\n * @extends ModuleSystem\n * @memberof module:core\n */\n\nvar App =\n/*#__PURE__*/\nfunction (_ModuleSystem) {\n  /**\n   * @description Defines whether the scene should render or not\n   * @member {Boolean} module:core.App#enabled\n   * @public\n   */\n\n  /**\n   * Loops in this app\n   * @description Array of loops that are executed by this app.\n   * @member {Array} module:core.App#loops\n   * @public\n   */\n  function App() {\n    var _this;\n\n    var modules = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n\n    classCallCheck(this, App);\n\n    console.log(\"WHS.App \".concat(version));\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(App).call(this));\n\n    defineProperty$3(defineProperty$3(assertThisInitialized(assertThisInitialized(_this)), \"enabled\", true), \"loops\", []);\n\n    _this.manager = new ModuleManager(assertThisInitialized(assertThisInitialized(_this)));\n    _this.modules = modules;\n\n    _this.integrateModules();\n\n    return _this;\n  } // CONTROLS & UPDATING\n\n  /**\n   * @method start\n   * @description Start rendering loop and physics simulation (if you use version with physics).\n   * @memberof module:core.App\n   */\n\n\n  createClass(App, [{\n    key: \"start\",\n    value: function start() {\n      var requestAnimFrame = function () {\n        return system.window.requestAnimationFrame || system.window.webkitRequestAnimationFrame || system.window.mozRequestAnimationFrame || function (callback) {\n          system.window.setTimeout(callback, 1000 / 60);\n        };\n      }();\n\n      var loops = this.loops,\n          enabled = this.enabled;\n\n      function process() {\n        requestAnimFrame(process);\n        if (!enabled) return;\n\n        for (var i = 0, ll = loops.length; i < ll; i++) {\n          var e = loops[i];\n          if (e.enabled) e.execute(e.clock);\n        }\n      }\n\n      this.enabled = true;\n      process();\n    }\n    /**\n     * @method stop\n     * @description Stops rendering loops\n     * @memberof module:core.App\n     */\n\n  }, {\n    key: \"stop\",\n    value: function stop() {\n      this.enabled = false;\n    }\n    /**\n     * @method addLoop\n     * @description Adds loop to this app.\n     * @param {Object} loop - the loop to add\n     * @return {Promise} Promise that is resolved when promises completed.\n     * @memberof module:core.App\n     * @example <caption>Adding a loop to an app</caption>\n     * const loop = new Loop(() => {\n     *  // ...\n     * });\n     *\n     * const app = new App();\n     *\n     * app.addLoop(loop);\n     * loop.start();\n     */\n\n  }, {\n    key: \"addLoop\",\n    value: function addLoop(loop) {\n      var _this2 = this;\n\n      return new Promise(function (resolve) {\n        _this2.loops.push(loop);\n\n        resolve(loop);\n      });\n    }\n    /**\n     * @method removeLoop\n     * @description Removes loop from this app.\n     * @param {Object} loop - the loop to remove\n     * @return {Promise} Promise that is resolved when promises completed.\n     * @memberof module:core.App\n     */\n\n  }, {\n    key: \"removeLoop\",\n    value: function removeLoop(loop) {\n      var _this3 = this;\n\n      return new Promise(function (resolve) {\n        var index = _this3.loops.indexOf(loop);\n\n        if (index !== -1) _this3.loops.splice(index, 1);\n        resolve(loop);\n      });\n    }\n  }, {\n    key: \"get\",\n    value: function get(key) {\n      return this.manager.get(key);\n    }\n  }, {\n    key: \"use\",\n    value: function use(key) {\n      return this.manager.use(key);\n    }\n  }]);\n\n  inherits(App, _ModuleSystem);\n\n  return App;\n}(ModuleSystem);\n\n/**\n * @class Loop\n * @category core\n * @param {Function} func function to execute on each animation frame\n * @param {Boolean} [useClock=true] passes a Clock to the function when called, if true\n * @memberof module:core\n */\n\nvar Loop =\n/*#__PURE__*/\nfunction () {\n  function Loop(func) {\n    var useClock = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n    classCallCheck(this, Loop);\n\n    this.func = func;\n    this.clock = useClock ? new Clock() : null;\n    this.enabled = false;\n  } // CONTROLS\n\n  /**\n   * @method start\n   * @instance\n   * @description Starts this loop, clock if it has one. Won't do anything if loop enabled already.\n   * @param {Component} [world] app to add this loop to, if provided.\n   * @memberof module:core.Loop\n   */\n\n\n  createClass(Loop, [{\n    key: \"start\",\n    value: function start(world) {\n      if (this.enabled) return;\n      if (world) world.addLoop(this);\n      if (this.clock) this.clock.start();\n      this.enabled = true;\n    }\n    /**\n     * @method stop\n     * @instance\n     * @description Stops this loop and its clock if it has one, won't do anything if this loop is not enabled)\n     * @param {Component} [world] app to remove this loop from, if provided.\n     * @memberof module:core.Loop\n     */\n\n  }, {\n    key: \"stop\",\n    value: function stop(world) {\n      if (!this.enabled) return;\n      if (this.clock) this.clock.stop();\n      this.enabled = false;\n      if (world) world.removeLoop(this);\n    } // EXECUTION\n\n    /**\n     * @method execute\n     * @instance\n     * @description Executes the function of this loop\n     * @memberof module:core.Loop\n     * @returns {*} whatever the function of this loop returns\n     */\n\n  }, {\n    key: \"execute\",\n    value: function execute() {\n      return this.func(this.clock);\n    }\n  }]);\n\n  return Loop;\n}();\n\n/** @module core */\n\n/**\n * @class AmbientLight\n * @category components/lights\n * @description AmbientLight is a simple class, it extends Light and inherits all its methods.\n * AmbientLight creates basic light around all scene, so it doesn't need properties like pos or target.\n * It supports only color and intensity as parameters, which defines the color of the surrounded light and intensity of light.\n * @param {Object} [params={light: {color: 0xffffff, intensity: 1}}] - The params.\n * @extends module:core.LightComponent\n * @memberof module:components/lights\n * @example <caption>Creating an AmbientLight </caption>\n * new AmbientLight({\n *   color: 0xffffff,\n *   intensity: 0.2\n * }).addTo(world);\n */\n\nvar AmbientLight$1 =\n/*#__PURE__*/\nfunction (_LightComponent) {\n  function AmbientLight$$1() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, AmbientLight$$1);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(AmbientLight$$1).call(this, params, AmbientLight$$1.defaults));\n  }\n\n  createClass(AmbientLight$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.applyBridge({\n        light: new AmbientLight(params.color, params.intensity)\n      }).light;\n    }\n  }]);\n\n  inherits(AmbientLight$$1, _LightComponent);\n\n  return AmbientLight$$1;\n}(LightComponent);\n\ndefineProperty$3(AmbientLight$1, \"defaults\", objectSpread({}, LightComponent.defaults, {\n  color: 0xffffff,\n  intensity: 1\n}));\n\n/**\n * @class DirectionalLight\n * @category components/lights\n * @description DirectinalLight creates a light that shines from a specific direction not from a specific position.<br/><br/>\n * This light will behave as though it is infinitely far away and the rays produced from it are all parallel. <br/><br/>\n * The best analogy would be a light source that acts like the sun: the sun is so far away that all sunlight hitting objects comes from the same angle.<br/><br/>\n * It has the same options as AmbientLight in light paramater, but it also supports pos and target paramaters.\n * @param {Object} [params={light: {color: 0xffffff, intensity: 1}}] - The params.\n * @extends module:core.LightComponent\n * @memberof module:components/lights\n * @example <caption>Creating a DirectionalLight to fall down from vec3(10, 20, 10) to vec3(0, 0, 0)</caption>\n * new DirectionalLight({\n *   color: 0xffffff,\n *   intensity: 0.2,\n *\n *   position: [10, 20, 10]\n * }).addTo(app);\n */\n\nvar DirectionalLight$1 =\n/*#__PURE__*/\nfunction (_LightComponent) {\n  function DirectionalLight$$1() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, DirectionalLight$$1);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(DirectionalLight$$1).call(this, params, DirectionalLight$$1.defaults));\n\n    _this.wrapShadow();\n\n    return _this;\n  }\n\n  createClass(DirectionalLight$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.applyBridge({\n        light: new DirectionalLight(params.color, params.intensity)\n      }).light;\n    }\n  }]);\n\n  inherits(DirectionalLight$$1, _LightComponent);\n\n  return DirectionalLight$$1;\n}(LightComponent);\n\ndefineProperty$3(DirectionalLight$1, \"defaults\", objectSpread({}, LightComponent.defaults, {\n  color: 0xffffff,\n  intensity: 1\n}));\n\n/**\n * @class HemisphereLight\n * @category components/lights\n * @description HemisphereLight is a light source positioned directly above the scene.<br/>\n * It also doesn't need position and target properties.\n * @classDesc\n * <iframe src=\"https://threejs.org/examples/webgl_lights_hemisphere.html\"></iframe>\n * @param {Object} [params={light: {skyColor: 0xffffff, groundColor: 0xffffff, intensity: 1}}] - The params.\n * @extends module:core.LightComponent\n * @memberof module:components/lights\n * @example <caption>Creating a HemisphereLight</caption>\n * new HemisphereLight({\n *   skyColor: 0xff0000,\n *   groundColor: 0x0000ff,\n *   intensity: 0.2\n * }).addTo(app);\n */\n\nvar HemisphereLight$1 =\n/*#__PURE__*/\nfunction (_LightComponent) {\n  function HemisphereLight$$1() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, HemisphereLight$$1);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(HemisphereLight$$1).call(this, params, HemisphereLight$$1.defaults));\n  }\n\n  createClass(HemisphereLight$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.applyBridge({\n        light: new HemisphereLight(params.skyColor, params.groundColor, params.intensity)\n      }).light;\n    }\n  }]);\n\n  inherits(HemisphereLight$$1, _LightComponent);\n\n  return HemisphereLight$$1;\n}(LightComponent);\n\ndefineProperty$3(HemisphereLight$1, \"defaults\", objectSpread({}, LightComponent.defaults, {\n  skyColor: 0xffffff,\n  groundColor: 0xffffff,\n  intensity: 1\n}));\n\n/**\n * @class PointLight\n * @category components/lights\n * @description PointLight creates a light at a specific position in the scene. The light shines in all directions (roughly similar to a light bulb.)<br/><br/>\n * It has the same options as AmbientLight in light paramater, but it also supports position, distance and decay.<br/>\n * @param {Object} [params={light: {color: 0xffffff, intensity: 1, distance: 100, decay: 1}}] - The params.\n * @extends LightComponent\n * @memberof module:components/lights\n * @example <caption>Creating a PointLight</caption>\n * new PointLight( {\n *   color: 0xff0000,\n *   intensity: 2,\n *   distance: 300\n *\n *   position: [10, 20, 10]\n * }).addTo(app);\n */\n\nvar PointLight$1 =\n/*#__PURE__*/\nfunction (_LightComponent) {\n  function PointLight$$1() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, PointLight$$1);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(PointLight$$1).call(this, params, PointLight$$1.defaults));\n\n    _this.wrapShadow();\n\n    return _this;\n  }\n\n  createClass(PointLight$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.applyBridge({\n        light: new PointLight(params.color, params.intensity, params.distance, params.decay)\n      }).light;\n    }\n  }]);\n\n  inherits(PointLight$$1, _LightComponent);\n\n  return PointLight$$1;\n}(LightComponent);\n\ndefineProperty$3(PointLight$1, \"defaults\", objectSpread({}, LightComponent.defaults, {\n  color: 0xffffff,\n  intensity: 1,\n  distance: 100,\n  decay: 1\n}));\n\n/**\n * @class SpotLight\n * @category components/lights\n * @description SpotLight creates spot light that can cast shadow in one direction. <br/><br/>\n * It has the same parameters as AmbientLight in light, but it also supports pos and target. <br/><br/>\n * SpotLight affects meshes with lambert and phong material.\n * @classDesc\n * <iframe src=\"https://threejs.org/examples/webgl_lights_spotlight.html\"></iframe>\n * @param {Object} [params={light: {color: 0xffffff, intensity: 1, distance: 100, angle: Math.PI / 3, exponent: 0, decay: 1}}] - The params.\n * @extends module:core.LightComponent\n * @memberof module:components/lights\n * @example <caption>Creating a SpotLight that falls down from vec3(10, 20, 10) to vec3(0, 0, 0)</caption>\n * new SpotLight({\n *   color: 0x00ff00,\n *   intensity: 3,\n *   distance: 1000\n *\n *   position: [10, 20, 10]\n * }).addTo(app);\n */\n\nvar SpotLight$1 =\n/*#__PURE__*/\nfunction (_LightComponent) {\n  function SpotLight$$1() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, SpotLight$$1);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(SpotLight$$1).call(this, params, SpotLight$$1.defaults));\n\n    _this.wrapShadow();\n\n    return _this;\n  }\n\n  createClass(SpotLight$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.applyBridge({\n        light: new SpotLight(params.color, params.intensity, params.distance, params.angle, params.exponent, params.decay)\n      }).light;\n    }\n  }]);\n\n  inherits(SpotLight$$1, _LightComponent);\n\n  return SpotLight$$1;\n}(LightComponent);\n\ndefineProperty$3(SpotLight$1, \"defaults\", objectSpread({}, LightComponent.defaults, {\n  color: 0xffffff,\n  intensity: 1,\n  distance: 100,\n  angle: Math.PI / 3,\n  exponent: 0,\n  decay: 1\n}));\n\nvar AreaLight =\n/*#__PURE__*/\nfunction (_LightComponent) {\n  function AreaLight() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, AreaLight);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(AreaLight).call(this, params, AreaLight.defaults));\n  }\n\n  createClass(AreaLight, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.applyBridge({\n        light: new RectAreaLight(params.color, params.intensity, params.width, params.height)\n      }).light;\n    }\n  }]);\n\n  inherits(AreaLight, _LightComponent);\n\n  return AreaLight;\n}(LightComponent);\n\ndefineProperty$3(AreaLight, \"defaults\", objectSpread({}, LightComponent.defaults, {\n  color: 0xffffff,\n  intensity: 1,\n  width: 10,\n  height: 10\n}));\n\n/** @module components/lights */\n\n/**\n * @class CubeCamera\n * @category components/cameras\n * @description Creates 6 cameras that render to a WebGLRenderTargetCube\n * @param {Object} [params] - The parameters object.\n * @memberof module:components/cameras\n * @extends module:core.CameraComponent\n * @example <caption>Creates a CubeCamera and set it as app's camera</caption>\n * const camera = new CubeCamera({\n *   camera: {\n *     cubeResolution: 256\n *   },\n *\n *   position: {\n *     x: 0,\n *     y: 100,\n *     z: 0\n *   }\n * });\n *\n * app.camera = camera;\n */\n\nvar CubeCamera$1 =\n/*#__PURE__*/\nfunction (_CameraComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/cameras.CubeCamera#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   camera: {\n   *     near: 1,\n   *     far: 1000,\n   *     cubeResolution: 128\n   *   }\n   * }</pre>\n   */\n  function CubeCamera$$1() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, CubeCamera$$1);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(CubeCamera$$1).call(this, params, CubeCamera$$1.defaults));\n  }\n\n  createClass(CubeCamera$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.applyBridge({\n        camera: new CubeCamera(params.near, params.far, params.cubeResolution)\n      }).camera;\n    }\n  }]);\n\n  inherits(CubeCamera$$1, _CameraComponent);\n\n  return CubeCamera$$1;\n}(CameraComponent);\n\ndefineProperty$3(CubeCamera$1, \"defaults\", objectSpread({}, CameraComponent.defaults, {\n  near: 1,\n  far: 1000,\n  cubeResolution: 128\n}));\n\n/**\n * @class OrthographicCamera\n * @category components/cameras\n * @description Camera with orthographic projection.\n * @param {Object} [params] - The parameters object.\n * @memberof module:components/cameras\n * @extends module:core.CameraComponent\n * @example <caption>Create an OrthographicCamera and set it as app's camera</caption>\n * const camera = new OrthographicCamera({\n *   camera: {\n *     far: 10000\n *   },\n *\n *   position: {\n *     y: 50\n *   }\n * });\n *\n * app.camera = camera;\n */\n\nvar OrthographicCamera$1 =\n/*#__PURE__*/\nfunction (_CameraComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/cameras.OrthographicCamera#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   near: 1,\n   *   far: 1000,\n   *   left: system.window.innerWidth / -2,\n   *   right: system.window.innerWidth / 2,\n   *   top: system.window.innerHeight / 2,\n   *   bottom: system.window.innerHeight / -2\n   * }</pre>\n   */\n  function OrthographicCamera$$1() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, OrthographicCamera$$1);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(OrthographicCamera$$1).call(this, params, OrthographicCamera$$1.defaults));\n  }\n\n  createClass(OrthographicCamera$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.applyBridge({\n        camera: new OrthographicCamera(params.left, params.right, params.top, params.bottom, params.near, params.far)\n      }).camera;\n    }\n  }]);\n\n  inherits(OrthographicCamera$$1, _CameraComponent);\n\n  return OrthographicCamera$$1;\n}(CameraComponent);\n\ndefineProperty$3(OrthographicCamera$1, \"defaults\", objectSpread({}, CameraComponent.defaults, {\n  near: 1,\n  far: 1000,\n  left: system.window.innerWidth / -2,\n  right: system.window.innerWidth / 2,\n  top: system.window.innerHeight / 2,\n  bottom: system.window.innerHeight / -2\n}));\n\n/**\n * @class PerspectiveCamera\n * @description Camera with perspective projection.\n * @category components/cameras\n * @param {Object} [params] - The parameters object.\n * @memberof module:components/cameras\n * @extends module:core.CameraComponent\n * @example <caption>Create an PerspectiveCamera and set it as app's camera</caption>\n * const camera = new PerspectiveCamera({\n *   fov: 75,\n *   aspect: window.innerWidth / window.innerHeight,\n *\n *   position: {\n *     x: 0,\n *     y: 100,\n *     z: 0\n *   }\n * });\n *\n * app.camera = camera;\n */\n\nvar PerspectiveCamera$1 =\n/*#__PURE__*/\nfunction (_CameraComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/cameras.PerspectiveCamera#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   near: 1,\n   *   far: 1000,\n   *   fov: 75,\n   *   aspect: system.window.innerWidth / system.window.innerHeight\n   * }</pre>\n   */\n  function PerspectiveCamera$$1() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, PerspectiveCamera$$1);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(PerspectiveCamera$$1).call(this, params, PerspectiveCamera$$1.defaults));\n  }\n\n  createClass(PerspectiveCamera$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return this.applyBridge({\n        camera: new PerspectiveCamera(params.fov, params.aspect, params.near, params.far)\n      }).camera;\n    }\n  }]);\n\n  inherits(PerspectiveCamera$$1, _CameraComponent);\n\n  return PerspectiveCamera$$1;\n}(CameraComponent);\n\ndefineProperty$3(PerspectiveCamera$1, \"defaults\", objectSpread({}, CameraComponent.defaults, {\n  near: 1,\n  far: 1000,\n  fov: 75,\n  aspect: system.window.innerWidth / system.window.innerHeight\n}));\n\n/** @module components/cameras */\n\n/**\n * @class Box\n * @category components/meshes\n * @description As told on Component definition, while you can pass any of the inherited params for this component construction, you will need to\n * pass specific parameters to build this mesh as a geometry object.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#BoxGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Box, and adding to app</caption>\n *  new Box({\n *    geometry: {\n *      width: 2,\n *      height: 2,\n *      depth: 2\n *    },\n *\n *    material: new THREE.MeshBasicMaterial({\n *      color: 0xffffff\n *    }),\n *\n *    position: [50, 60, 70]\n * }).addTo(app);\n */\n\nvar Box =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Box#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     width: 1,\n   *     height: 1,\n   *     depth: 1,\n   *     widthSegments: 1,\n   *     heightSegments: 1,\n   *     depthSegments: 1\n   *   }\n   * }</pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Box#instructions\n   * @static\n   * @default geometry: ['width', 'height', 'depth', 'widthSegments', 'heightSegments', 'depthSegements']\n   */\n  function Box() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Box);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(Box).call(this, params, Box.defaults, Box.instructions));\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Box\n   */\n\n\n  createClass(Box, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var geometry = new (params.buffer ? BoxBufferGeometry : BoxGeometry)(params.geometry.width, params.geometry.height, params.geometry.depth, params.geometry.widthSegments, params.geometry.heightSegments, params.geometry.depthSegments);\n      return geometry;\n    }\n  }]);\n\n  inherits(Box, _MeshComponent);\n\n  return Box;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Box, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    width: 1,\n    height: 1,\n    depth: 1,\n    widthSegments: 1,\n    heightSegments: 1,\n    depthSegments: 1\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['width', 'height', 'depth', 'widthSegments', 'heightSegments', 'depthSegements']\n}));\n\n/**\n * @class Circle\n * @category components/meshes\n * @description As told on Component definition, while you can pass any of the inherited params for this component construction, you will need to\n * pass specific parameters to build this mesh as a geometry object.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#CircleGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Circle, and adding to app</caption>\n *  new Circle({\n *    geometry: {\n *      radius: 4,\n *      segments: 16\n *    },\n *\n *    material: new THREE.MeshBasicMaterial({\n *      color: 0xffffff\n *    }),\n *\n *    position: [50, 60, 70]\n * }).addTo(app);\n */\n\nvar Circle =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Circle#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     radius: 50,\n   *     segments: 8,\n   *     thetaStart: 0,\n   *     thetaLength: Math.PI * 2\n   *   }\n   * }</pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Circle#instructions\n   * @static\n   * @default geometry: ['radius', 'segments', 'thetaStart', 'thetaLength']\n   */\n  function Circle() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Circle);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(Circle).call(this, params, Circle.defaults, Circle.instructions));\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Circle\n   */\n\n\n  createClass(Circle, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var geometry = new (params.buffer ? CircleBufferGeometry : CircleGeometry)(params.geometry.radius, params.geometry.segments, params.geometry.thetaStart, params.geometry.thetaLength);\n      return geometry;\n    }\n  }]);\n\n  inherits(Circle, _MeshComponent);\n\n  return Circle;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Circle, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radius: 50,\n    segments: 8,\n    thetaStart: 0,\n    thetaLength: Math.PI * 2\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['radius', 'segments', 'thetaStart', 'thetaLength']\n}));\n\n/**\n * @class Cone\n * @category components/meshes\n * @description A cylinder is one of the most basic curvilinear geometric shapes, the surface formed by the points at a fixed distance from a given straight line, the axis of the cylinder. <br/><br/>\n * The solid enclosed by this surface and by two planes perpendicular to the axis is also called a cylinder.<br/>\n * The surface area and the volume of a cylinder have been known since deep antiquity.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#ConeGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Cone, and adding to app</caption>\n * new Cone({\n *   geometry: {\n *     radiusTop: 2,\n *     radiusBottom: 4,\n *     height: 5\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   pos: [0, 100, 0]\n * }).addTo(app);\n */\n\nvar Cone =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Cone#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     radius: 20,\n   *     height: 100,\n   *     radiusSegments: 32,\n   *     heightSegments: 1,\n   *     openEnded: false,\n   *     thetaStart: 0,\n   *     thetaLength: Math.PI * 2\n   *   }\n   * }</pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Cone#instructions\n   * @static\n   * @default <pre>\n   * geometry: [\n   *   'radius',\n   *   'height',\n   *   'radiusSegments',\n   *   'heightSegments',\n   *   'openEnded',\n   *   'thetaStart',\n   *   'thetaLength'\n   * ]\n   * </pre>\n   */\n  function Cone() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Cone);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Cone).call(this, params, Cone.defaults, Cone.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Cone.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Cone\n   */\n\n\n  createClass(Cone, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var geometry = new (params.buffer ? ConeBufferGeometry : ConeGeometry)(params.geometry.radius, params.geometry.height, params.geometry.radiusSegments, params.geometry.heightSegments, params.geometry.openEnded, params.geometry.thetaStart, params.geometry.thetaLength);\n      return geometry;\n    }\n  }]);\n\n  inherits(Cone, _MeshComponent);\n\n  return Cone;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Cone, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radius: 20,\n    height: 100,\n    radiusSegments: 32,\n    heightSegments: 1,\n    openEnded: false,\n    thetaStart: 0,\n    thetaLength: Math.PI * 2\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['radius', 'height', 'radiusSegments', 'heightSegments', 'openEnded', 'thetaStart', 'thetaLength']\n}));\n\n/**\n * @class Cylinder\n * @category components/meshes\n * @description A cylinder is one of the most basic curvilinear geometric shapes, the surface formed by the points at a fixed distance from a given straight line, the axis of the cylinder. <br/><br/>\n * The solid enclosed by this surface and by two planes perpendicular to the axis is also called a cylinder.<br/>\n * The surface area and the volume of a cylinder have been known since deep antiquity.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#CylinderGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Cylinder, and adding to app</caption>\n * new Cylinder({\n *   geometry: {\n *     radiusTop: 2,\n *     radiusBottom: 4,\n *     height: 5\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   pos: [0, 100, 0]\n * }).addTo(app);\n */\n\nvar Cylinder =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Cylinder#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     radiusTop: 20,\n   *     radiusBottom: 20,\n   *     height: 100,\n   *     radiusSegments: 32,\n   *     heightSegments: 1,\n   *     openEnded: false,\n   *     thetaStart: 0,\n   *     thetaLength: Math.PI * 2\n   *   }\n   * }</pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Cylinder#instructions\n   * @static\n   * @default <pre>\n   * geometry: [\n   *   'radiusTop',\n   *   'radiusBottom',\n   *   'height',\n   *   'radiusSegments',\n   *   'heightSegments',\n   *   'openEnded',\n   *   'thetaStart',\n   *   'thetaLength'\n   * ]\n   * </pre>\n   */\n  function Cylinder() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Cylinder);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Cylinder).call(this, params, Cylinder.defaults, Cylinder.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Cylinder.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Cylinder\n   */\n\n\n  createClass(Cylinder, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var geometry = new (params.buffer ? CylinderBufferGeometry : CylinderGeometry)(params.geometry.radiusTop, params.geometry.radiusBottom, params.geometry.height, params.geometry.radiusSegments, params.geometry.heightSegments, params.geometry.openEnded, params.geometry.thetaStart, params.geometry.thetaLength);\n      return geometry;\n    }\n  }]);\n\n  inherits(Cylinder, _MeshComponent);\n\n  return Cylinder;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Cylinder, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radiusTop: 0,\n    radiusBottom: 1,\n    height: 1,\n    radiusSegments: 32,\n    heightSegments: 1,\n    openEnded: false,\n    thetaStart: 0,\n    thetaLength: Math.PI * 2\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['radiusTop', 'radiusBottom', 'height', 'radiusSegments', 'heightSegments', 'openEnded', 'thetaStart', 'thetaLength']\n}));\n\n/**\n * @class Dodecahedron\n * @category components/meshes\n * @description In geometry, a dodecahedron is any polyhedron with twelve flat faces. <br/><br/>\n * The most familiar dodecahedron is the regular dodecahedron, which is a Platonic solid. <br/>\n * There are also three regular star dodecahedra, which are constructed as stellations of the convex form. <br/>\n * All of these have icosahedral symmetry, order 120.\n * Dodecahedron creates Dodecahedron object by it's radius and detail.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#DodecahedronGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Dodecahedron, and adding to app</caption>\n * new Dodecahedron({\n *   geometry: {\n *     radius: 2\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: {\n *     y: 10\n *   }\n  * }).addTo(app);\n */\n\nvar Dodecahedron =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Dodecahedron#defaults\n   * @static\n   * @default <pre>\n   * geometry: {\n   *   radius: 1,\n   *   detail: 0\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Dodecahedron#instructions\n   * @static\n   * @default <pre>\n   * geometry: ['radius', 'detail']\n   * </pre>\n   */\n  function Dodecahedron() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Dodecahedron);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Dodecahedron).call(this, params, Dodecahedron.defaults, Dodecahedron.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Dodecahedron.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Dodecahedron\n   */\n\n\n  createClass(Dodecahedron, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new (params.buffer ? DodecahedronBufferGeometry : DodecahedronGeometry)(params.geometry.radius, params.geometry.detail);\n    }\n  }]);\n\n  inherits(Dodecahedron, _MeshComponent);\n\n  return Dodecahedron;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Dodecahedron, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radius: 1,\n    detail: 0\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['radius', 'detail']\n}));\n\n/**\n * @class Extrude\n * @category components/meshes\n * @description Extrude geometry means that you can create a 3D mesh from any 2D shape using three.js geometry based on <a href='https://threejs.org/docs/#api/math/Vector2'>THREE.Vector2.</a> <br/>\n * Such implementation will help you to make volumed shapes that have their own depth and can be seen from all angels.<br/><br/>\n * You can also find some interesting examples made using <a href='threejs.org'>three.js</a> which is a core of whs.js, such as:\n * - <a href='http://threejs.org/examples/webgl_geometry_extrude_shapes.html'>Webgl geometry extrude</a>\n * - <a href='http://threejs.org/examples/webgl_geometry_extrude_shapes2.html'>Extrude shapes from geodata</a>\n * - <a href='http://threejs.org/examples/webgl_geometry_extrude_splines.html'>Extrude splines</a>\n *\n * Such examples can be easily implemented using whitestorm.js or it's plugins. Use `Extrude` class with <a href='https://threejs.org/docs/#api/extras/core/Shape'>THREE.Shape</a> to get extrude effect of shape defined by 2D vectors.\n * This class is similar to <a href='https://threejs.org/docs/#api/geometries/ExtrudeGeometry'>THREE.ExtrudeGeometry</a>,\n * but it also contains all properties, applied by `Shape`, such as material, mass and vectors like position (pos) and rotation (rot).\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#ExtrudeGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a shape, then an Extrude from it</caption>\n * const shape = new THREE.Shape([\n *   new THREE.Vector2(-4,-4),\n *   new THREE.Vector2(-2,0),\n *   new THREE.Vector2(-4,4),\n *   new THREE.Vector2(0,2),\n *   new THREE.Vector2(4,4),\n *   new THREE.Vector2(2,0),\n *   new THREE.Vector2(4,-4),\n *   new THREE.Vector2(0,-2)\n * ]);\n *\n * const extrude = new Extrude({\n *   geometry: {\n *     shapes: shape,\n *     options: {\n *       bevelEnabled: false,\n *       bevelSize: 0,\n *       amount: 2\n *     }\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: [0, 100, 0]\n * });\n *\n * extrude.addTo(app);\n */\n\nvar Extrude =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Extrude#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     shapes: [],\n   *     options: {}\n   *   }\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Extrude#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: ['shapes', 'options']\n   * }\n   * </pre>\n   */\n  function Extrude() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Extrude);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Extrude).call(this, params, Extrude.defaults, Extrude.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Extrude.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Extrude\n   */\n\n\n  createClass(Extrude, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var geometry = new ExtrudeGeometry(params.geometry.shapes, params.geometry.options);\n      return params.buffer ? new BufferGeometry().fromGeometry(geometry) : geometry;\n    }\n  }]);\n\n  inherits(Extrude, _MeshComponent);\n\n  return Extrude;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Extrude, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    shapes: [],\n    options: {}\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['shapes', 'options']\n}));\n\n/**\n * @class Icosahedron\n * @category components/meshes\n * @description In geometry, an icosahedron is a polyhedron with 20 faces.<br/>\n * There are many kinds of icosahedra, with some being more symmetrical than others. The most well known is the Platonic, convex regular icosahedron.<br/>\n * `Icosahedron` creates an Icosahedron object by its radius and detail.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#IcosahedronGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Icosahedron, and adding to app</caption>\n * new Icosahedron({\n *   geometry: {\n *     radius: 2,\n *     detail: 1\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: [0, 100, 0]\n * }).addTo(app);\n */\n\nvar Icosahedron =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Icosahedron#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     radius: 1,\n   *     detail: 0\n   *   }\n   * }</pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Icosahedron#instructions\n   * @static\n   * @default {geometry: ['radius', 'detail']}\n   */\n  function Icosahedron() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Icosahedron);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Icosahedron).call(this, params, Icosahedron.defaults, Icosahedron.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Icosahedron.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Icosahedron\n   */\n\n\n  createClass(Icosahedron, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new (params.buffer ? IcosahedronBufferGeometry : IcosahedronGeometry)(params.geometry.radius, params.geometry.detail);\n    }\n  }]);\n\n  inherits(Icosahedron, _MeshComponent);\n\n  return Icosahedron;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Icosahedron, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radius: 1,\n    detail: 0\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['radius', 'detail']\n}));\n\n/**\n * @class Lathe\n * @category components/meshes\n * @description A `LatheGeometry` allows you to create shapes from a smooth curve.\n * This curve is defined by a number of points (also called knots) and is most often called a spline. This spline is rotated around a fixed point and results in vase- and bell-like shapes.<br/><br/>\n * In 3D computer graphics, a lathed object is a 3D model whose vertex geometry is produced by rotating the points of a spline or other point set around a fixed axis.\n * The lathing may be partial; the amount of rotation is not necessarily a full 360 degrees.\n * The point set providing the initial source data can be thought of as a cross section through the object along a plane containing its axis of radial symmetry. <br/><br/>\n * The <a href='http://threejs.org/docs/scenes/geometry-browser.html#LatheGeometry'>following example</a> shows a geometry which can be generated using `Lathe` class.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#LatheGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Lath, and adding to app</caption>\n * const points = [];\n *\n * for (let i = 0; i < 10; i++) {\n *   points.push(\n *     new THREE.Vector2(\n *       (Math.sin(i * 0.7) * 15 + 50) / 10,\n *       (i - 5) * 0.2\n *     )\n *   );\n * }\n *\n * const lathe = new Lathe({\n *   geometry: {\n *     points: points\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: [0, 50, 10]\n * }).addTo(app);\n */\n\nvar Lathe =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Lathe#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     points: []\n   *   }\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Lathe#instructions\n   * @static\n   * @default <pre>{\n   *   geometry: ['points']\n   * }\n   * </pre>\n   */\n  function Lathe() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Lathe);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Lathe).call(this, params, Lathe.defaults, Lathe.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Lathe.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Lathe\n   */\n\n\n  createClass(Lathe, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new (params.buffer ? LatheBufferGeometry : LatheGeometry)(params.geometry.points);\n    }\n  }]);\n\n  inherits(Lathe, _MeshComponent);\n\n  return Lathe;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Lathe, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    points: []\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['points']\n}));\n\n/**\n * @class Line\n * @category components/meshes\n * @description Line component is generated from a curve/line and amount of vectors that should be used (points).\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Line, and adding to app</caption>\n * new Line({\n *   geometry: {\n *     curve: new THREE.LineCurve3(new THREE.Vector3(10, 10, 0), new THREE.Vector3(10, 30, 0))\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   })\n * }).addTo(app);\n */\n\nvar Line$1 =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Line#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   curve: new LineCurve3(new Vector3(0, 0, 0), new Vector3(10, 0, 0)),\n   *   points: 50\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Line#instructions\n   * @static\n   * @default <pre>{\n   *   geometry: ['curve', 'points']\n   * }\n   * </pre>\n   */\n  function Line$$1(params) {\n    classCallCheck(this, Line$$1);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(Line$$1).call(this, params, Line$$1.defaults, Line$$1.instructions));\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Line\n   */\n\n\n  createClass(Line$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Line(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var geometry = params.buffer ? new BufferGeometry() : new Geometry();\n\n      if (params.buffer) {\n        var pp = params.curve.getPoints(params.points);\n        var verts = new Float32Array(pp.length * 3);\n\n        for (var i = 0, max = pp.length; i < max; i++) {\n          var i3 = i * 3;\n          verts[i3] = pp[i].x;\n          verts[i3 + 1] = pp[i].y;\n          verts[i3 + 2] = pp[i].z;\n        }\n\n        geometry.addAttribute('position', new BufferAttribute(verts, 3));\n      } else geometry.vertices = params.curve.getPoints(params.points);\n\n      return geometry;\n    }\n  }]);\n\n  inherits(Line$$1, _MeshComponent);\n\n  return Line$$1;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Line$1, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  curve: null,\n  points: 50\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['curve', 'points']\n}));\n\n/**\n * @class Importer\n * @category components/meshes\n * @description Importer is a loader for meshes and any other data to your scene\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Importer, and adding to app</caption>\n * new Importer({\n *   loader: new THREE.OBJLoader(),\n *\n *   parser(geometry, material) { // data from loader\n *     return new THREE.Mesh(geometry, material); // should return your .native (mesh in this case)\n *   },\n *\n *   position: [0, 100, 0]\n * }).addTo(app);\n */\n\nvar Importer =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  createClass(Importer, null, [{\n    key: \"filter\",\n\n    /**\n     * Default values for parameters\n     * @member {Object} module:components/meshes.Importer#defaults\n     * @static\n     * @default <pre>\n     * {\n     *   url: '',\n     *   loader: new JSONLoader(),\n     *\n     *   onLoad() {},\n     *   onProgress() {},\n     *   onError() {},\n     *\n     *   texturePath: null,\n     *   useCustomMaterial: false,\n     *\n     *   parser(geometry, materials) {\n     *     return new Mesh(geometry, materials);\n     *   }\n     * }</pre>\n     */\n\n    /**\n     * @method filter\n     * @description Default values for filter\n     * @static\n     * @param {THREE.Mesh} object Instance for iterating through it's children.\n     * @param {Function} filter Function with child as argument, should return a boolean whether include the child or not.\n     * @return {THREE.Mesh} object with children\n     * @memberof module:components/meshes.Importer\n     * @example <caption>Removing unnecessary lights from children</caption>\n     * new Importer({\n     *   loader: new THREE.OBJLoader(),\n     *\n     *   parse(group) { // data from loader\n     *     return Importer.filter(group, child => !child.isLight); // remove lights\n     *   },\n     *\n     *   position: [0, 100, 0]\n     * }).addTo(app);\n     */\n    value: function filter(object, _filter) {\n      var processFilter = function processFilter(object) {\n        object.children.forEach(function (el, index) {\n          if (el.children) processFilter(el);\n          if (!_filter(el)) object.children.splice(index, 1);\n        });\n        return object;\n      };\n\n      return processFilter(object);\n    }\n  }]);\n\n  function Importer() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Importer);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(Importer).call(this, params, Importer.defaults, Importer.instructions, false));\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Importer\n   */\n\n\n  createClass(Importer, [{\n    key: \"build\",\n    value: function build() {\n      var _this = this;\n\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new Promise(function (resolve) {\n        if (params.texturePath) params.loader.setTexturePath(params.texturePath);\n        params.loader.load(params.url, function () {\n          for (var _len = arguments.length, data = new Array(_len), _key = 0; _key < _len; _key++) {\n            data[_key] = arguments[_key];\n          }\n\n          // geometry, materials\n          params.onLoad.apply(params, data);\n          var object = params.parser.apply(_this, data);\n          if (params.material) object.material = _this.applyBridge({\n            material: params.material\n          }).material;\n          resolve(object);\n        }, params.onProgress, params.onError);\n      });\n    }\n  }]);\n\n  inherits(Importer, _MeshComponent);\n\n  return Importer;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Importer, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  url: '',\n  loader: new JSONLoader(),\n  onLoad: function onLoad() {},\n  onProgress: function onProgress() {},\n  // TODO add onComplete?\n  onError: function onError() {},\n  texturePath: null,\n  useCustomMaterial: false,\n  parser: function parser(geometry, material) {\n    var _this$applyBridge = this.applyBridge({\n      geometry: geometry,\n      material: material\n    }),\n        geom = _this$applyBridge.geometry,\n        mat = _this$applyBridge.material;\n\n    return this.applyBridge({\n      mesh: geom.bones ? new SkinnedMesh(geom, mat) : new Mesh(geom, mat)\n    }).mesh;\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions));\n\n/**\n * @class Octahedron\n * @category components/meshes\n * @description In geometry, an octahedron is a polyhedron with eight faces.\n * A regular octahedron is a Platonic solid composed of eight equilateral triangles, four of which meet at each vertex.\n * <br/><br/>\n * `Octahedron` creates an Octahedron object by its `radius` and `detail`.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#OctahedronGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating an Octahedron, and adding to app</caption>\n * new Octahedron({\n *   geometry: {\n *     radius: 2,\n *     detail: 1\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: [0, 100, 0]\n * }).addTo(app);\n */\n\nvar Octahedron =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Octahedron#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     radius: 1,\n   *     detail: 0\n   *   }\n   * }\n   * </pre>\n   */\n  function Octahedron() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Octahedron);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Octahedron).call(this, params, Octahedron.defaults, Octahedron.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Octahedron.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Octahedron\n   */\n\n\n  createClass(Octahedron, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new (params.buffer ? OctahedronBufferGeometry : OctahedronGeometry)(params.geometry.radius, params.geometry.detail);\n    }\n  }]);\n\n  inherits(Octahedron, _MeshComponent);\n\n  return Octahedron;\n}(MeshComponent);\n\ndefineProperty$3(Octahedron, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radius: 1,\n    detail: 0\n  }\n}));\n\n/**\n * @class Parametric\n * @category components/meshes\n * @description `Parametric` generates a geometry representing a <a href='https://en.wikipedia.org/wiki/Parametric_surface'>Parametric surface</a>\n * <br/><br/>\n * It is usually used to develop different kinds of highfields or visualize a <a href='https://stemkoski.github.io/Three.js/Graphulus-Function.html'>math function</a>.\n * <br/>\n * - <a href='http://math.hws.edu/graphicsbook/source/threejs/curves-and-surfaces.html'>Parametric surface</a>\n * - <a href='https://stemkoski.github.io/Three.js/Graphulus-Surface.html'>\"Graphulus\"</a>\n * <br/><br/>\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#ParametricGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Example creating an heightfield-like geometry. `u` and `v` are like `x` and `y` in shape, but their values are always from `0` to `1`.\n * We use them in `THREE.Vector3` like `x` and `z` and `Math.random() * 5` for `y`.</caption>\n * const createParametric = (u, v) => {\n *   return new THREE.Vector3(u * 30, Math.random() * 5, v * 30);\n * }\n *\n * new Parametric({\n *   geometry: {\n *     func: createParametric\n *   },\n *\n *   material: new THREE.MeshLambertMaterial({\n *     color: 0xffffff,\n *     side: THREE.DoubleSide\n *   }),\n *\n *   position: [0, 100, -100]\n * }).addTo(app);\n */\n\nvar Parametric =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Parametric#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     func: (u, v) => new Vector3(u, v, 0),\n   *     slices: 10,\n   *     tacks: 10\n   *   }\n   * }\n   * </pre>\n   */\n  function Parametric() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Parametric);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(Parametric).call(this, params, Parametric.defaults, Parametric.instructions));\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Parametric\n   */\n\n\n  createClass(Parametric, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new (params.buffer ? ParametricBufferGeometry : ParametricGeometry)(params.geometry.func, params.geometry.slices, params.geometry.stacks);\n    }\n  }]);\n\n  inherits(Parametric, _MeshComponent);\n\n  return Parametric;\n}(MeshComponent);\n\ndefineProperty$3(Parametric, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    func: function func(u, v) {\n      return new Vector3(u, v, 0);\n    },\n    slices: 10,\n    stacks: 10\n  }\n}));\n\n/**\n * @class Plane\n * @category components/meshes\n * @description `Plane` is used for creating planes given some `width` and `height`.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#PlaneGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Plane, and adding to app</caption>\n * new Plane({\n *   geometry: {\n *     width: 20,\n *     height: 30\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   })\n * }).addTo(app);\n */\n\nvar Plane$1 =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Plane#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     width: 10,\n   *     height: 10,\n   *     wSegments: 1,\n   *     hSegments: 1\n   *   }\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Plane#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: ['width', 'height', 'wSegments', 'hSegments']\n   * }\n   * </pre>\n   */\n  function Plane$$1() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Plane$$1);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Plane$$1).call(this, params, Plane$$1.defaults, Plane$$1.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Plane$$1.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Plane\n   */\n\n\n  createClass(Plane$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var geometry = new (params.buffer ? PlaneBufferGeometry : PlaneGeometry)(params.geometry.width, params.geometry.height, params.geometry.wSegments, params.geometry.hSegments);\n      return geometry;\n    }\n  }]);\n\n  inherits(Plane$$1, _MeshComponent);\n\n  return Plane$$1;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Plane$1, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    width: 10,\n    height: 10,\n    wSegments: 1,\n    hSegments: 1\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['width', 'height', 'wSegments', 'hSegments']\n}));\n\nvar verticesOfCube = [-1, -1, -1, 1, -1, -1, 1, 1, -1, -1, 1, -1, -1, -1, 1, 1, -1, 1, 1, 1, 1, -1, 1, 1],\n    indicesOfFaces = [2, 1, 0, 0, 3, 2, 0, 4, 7, 7, 3, 0, 0, 1, 5, 5, 4, 0, 1, 2, 6, 6, 5, 1, 2, 3, 7, 7, 6, 2, 4, 5, 6, 6, 7, 4];\n/**\n * @class Polyhedron\n * @category components/meshes\n * @description In elementary geometry, a polyhedron is a solid in three dimensions with flat polygonal faces, straight edges and sharp corners or vertices.\n * <br/><br/>\n * `Polyhedron` creates a Polyhedron by its `radius` and `detail`.\n * <br/><br/>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating an Polyhedron, and adding to app</caption>\n * new Polyhedron({\n *   geometry: {\n *     radius: 2,\n *     detail: 1\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: [0, 100, 0]\n * }).addTo(app);\n */\n\nvar Polyhedron =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Polyhedron#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     verticesOfCube: [\n   *       -1, -1, -1, 1, -1, -1, 1, 1, -1, -1, 1, -1,\n   *       -1, -1, 1, 1, -1, 1, 1, 1, 1, -1, 1, 1\n   *     ],\n   *\n   *     indicesOfFaces: [\n   *       2, 1, 0, 0, 3, 2,\n   *       0, 4, 7, 7, 3, 0,\n   *       0, 1, 5, 5, 4, 0,\n   *       1, 2, 6, 6, 5, 1,\n   *       2, 3, 7, 7, 6, 2,\n   *       4, 5, 6, 6, 7, 4\n   *     ],\n   *\n   *     radius: 6,\n   *     detail: 2\n   *   }\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Polyhedron#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: ['verticesOfCube', 'indicesOfFaces', 'radius', 'detail']\n   * }\n   * </pre>\n   */\n  function Polyhedron() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Polyhedron);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Polyhedron).call(this, params, Polyhedron.defaults, Polyhedron.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Polyhedron.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Polyhedron\n   */\n\n\n  createClass(Polyhedron, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new (params.buffer ? PolyhedronBufferGeometry : PolyhedronGeometry)(params.geometry.verticesOfCube, params.geometry.indicesOfFaces, params.geometry.radius, params.geometry.detail);\n    }\n  }]);\n\n  inherits(Polyhedron, _MeshComponent);\n\n  return Polyhedron;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(defineProperty$3(defineProperty$3(Polyhedron, \"verticesOfCube\", verticesOfCube), \"indicesOfFaces\", indicesOfFaces), \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    verticesOfCube: verticesOfCube,\n    indicesOfFaces: indicesOfFaces,\n    radius: 6,\n    detail: 2\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['verticesOfCube', 'indicesOfFaces', 'radius', 'detail']\n}));\n\n/**\n * @class Ring\n * @category components/meshes\n * @description Ring class creates a circle or just 2D Torus. Does not support physics.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#RingGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Ring, and adding to app</caption>\n * new Ring({\n *   geometry: {\n *     innerRadius: 5,\n *     outerRadius: 2\n *   },\n *\n *   material: new THREE.MeshLambertMaterial({\n *     color: 0xffffff,\n *     side THREE.DoubleSide\n *   }),\n *\n *   position: [0, 8, 0],\n *\n *   rotation: {\n *     x: Math.PI/4\n *   }\n * }).addTo(app);\n */\n\nvar Ring =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Ring#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     innerRadius: 0,\n   *     outerRadius: 50,\n   *     thetaSegments: 8,\n   *     phiSegments: 8,\n   *     thetaStart: 0,\n   *     thetaLength: Math.PI * 2\n   *   }\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Ring#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: [\n   *     'innerRadius',\n   *     'outerRadius',\n   *     'thetaSegments',\n   *     'phiSegments',\n   *     'thetaStart',\n   *     'thetaLength'\n   *   ]\n   * }\n   * </pre>\n   */\n  function Ring() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Ring);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Ring).call(this, params, Ring.defaults, Ring.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Ring.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Ring\n   */\n\n\n  createClass(Ring, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new (params.buffer ? RingBufferGeometry : RingGeometry)(params.geometry.innerRadius, params.geometry.outerRadius, params.geometry.thetaSegments, params.geometry.phiSegments, params.geometry.thetaStart, params.geometry.thetaLength);\n    }\n  }]);\n\n  inherits(Ring, _MeshComponent);\n\n  return Ring;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Ring, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    innerRadius: 0,\n    outerRadius: 50,\n    thetaSegments: 8,\n    phiSegments: 8,\n    thetaStart: 0,\n    thetaLength: Math.PI * 2\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.defaults, {\n  geometry: ['innerRadius', 'outerRadius', 'thetaSegments', 'phiSegments', 'thetaStart', 'thetaLength']\n}));\n\n/**\n * @class Shape\n * @category components/meshes\n * @description Shape is a universal class. It allows you to create different 2D shapes in 3D scene.<br/>\n * Unfortunately, not all of them support physics, an alternative is to make a similar 3D object and scale its width down to near zero.\n * <br/><br/>\n * `Shape` consists of shapes that are in its shapes parameter.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#ShapeGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a plane looking Shape from a THREE.Shape, and adding it to app</caption>\n * const rectWidth = 10,\n * rectLength = 5;\n *\n * const rectShape = new THREE.Shape();\n * rectShape.moveTo(0,0);\n * rectShape.lineTo(0, rectWidth);\n * rectShape.lineTo(rectLength, rectWidth);\n * rectShape.lineTo(rectLength, 0);\n * rectShape.lineTo(0, 0);\n *\n * const plane = new Shape({\n *   geometry: {\n *     shape: rectShape\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   })\n * }).addTo(app);\n */\n\nvar Shape$1 =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Shape#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     shapes: []\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Shape#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: ['shapes']\n   * }\n   * </pre>\n   */\n  function Shape$$1() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Shape$$1);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Shape$$1).call(this, params, Shape$$1.defaults, Shape$$1.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Shape$$1.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Shape\n   */\n\n\n  createClass(Shape$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new (params.buffer ? ShapeBufferGeometry : ShapeGeometry)(params.geometry.shapes);\n    }\n  }]);\n\n  inherits(Shape$$1, _MeshComponent);\n\n  return Shape$$1;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Shape$1, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    shapes: []\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['shapes']\n}));\n\n/**\n * @class Sphere\n * @category components/meshes\n * @description Sphere class is used to create sphere objects by its radius property and other values that determines its detality.\n * <br/><br/>\n * It is similar to THREE.SphereGeometry, but it also contains all `Shape` properties, such as material, mass and vectors like position (pos) and rotation (rot).\n * <br/><br/>\n * Then it creates an `Three.js mesh` or a `Physijs mesh`, that is similar to `Three.js mesh`, but it also take into consideration collision calculations.\n * This mesh is a combination of `Three.js geometry` and `Physijs material` (The same as in three.js, but with friction and restitution).\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#SphereGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Sphere, and adding it to app</caption>\n * new Sphere({\n *   geometry: {\n *     radius: 2\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: {\n *     y: 100\n *   }\n * }).addTo(app);\n */\n\nvar Sphere$1 =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Sphere#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     radius: 1,\n   *     widthSegments: 8,\n   *     heightSegments: 6\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Sphere#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: ['radius', 'widthSegments', 'heightSegments']\n   * }\n   * </pre>\n   */\n  function Sphere$$1() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Sphere$$1);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(Sphere$$1).call(this, params, Sphere$$1.defaults, Sphere$$1.instructions));\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Sphere\n   */\n\n\n  createClass(Sphere$$1, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var geometry = new (params.buffer ? SphereBufferGeometry : SphereGeometry)(params.geometry.radius, params.geometry.widthSegments, params.geometry.heightSegments);\n      return geometry;\n    }\n  }]);\n\n  inherits(Sphere$$1, _MeshComponent);\n\n  return Sphere$$1;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Sphere$1, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radius: 1,\n    widthSegments: 8,\n    heightSegments: 6\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['radius', 'widthSegments', 'heightSegments']\n}));\n\n/**\n * @class Tetrahedron\n * @category components/meshes\n * @description In geometry, a tetrahedron is a polyhedron composed of four triangular faces, six straight edges, and four vertex corners.\n * The tetrahedron is the simplest of all the ordinary convex polyhedra and the only one that has fewer than 5 faces.\n * <br/><br/>\n * `Tetrahedron` creates a Tetrahedron object by its `radius` and `detail`\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#TetrahedronGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Tetrahedron, and adding it to app</caption>\n * new Tetrahedron({\n *   geometry: {\n *     radius: 2,\n *     detail: 1\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: {\n *     x: 0,\n *     y: 100,\n *     z: 0\n *   }\n * }).addTo(app);\n */\n\nvar Tetrahedron =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Tetrahedron#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     radius: 1,\n   *     detail: 0\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Tetrahedron#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: ['radius', 'detail']\n   * }\n   * </pre>\n   */\n  function Tetrahedron() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Tetrahedron);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Tetrahedron).call(this, params, Tetrahedron.defaults, Tetrahedron.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Tetrahedron.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Tetrahedron\n   */\n\n\n  createClass(Tetrahedron, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new (params.buffer ? TetrahedronBufferGeometry : TetrahedronGeometry)(params.geometry.radius, params.geometry.detail);\n    }\n  }]);\n\n  inherits(Tetrahedron, _MeshComponent);\n\n  return Tetrahedron;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Tetrahedron, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radius: 1,\n    detail: 0\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['radius', 'detail']\n}));\n\n/**\n * @class Text\n * @category components/meshes\n * @description Text class is made for creating 3D text objects.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#TextGeometry\"></iframe>\n * <br/><br/>\n * Physics text object can be convex or concave. By default it's convex but you can also switch to concave.\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Text, and adding it to app</caption>\n * new Text({\n *     text: 'Some text',\n *     parameters: {\n *       font: 'path/to/font.typeface.js',\n *       size: 20,\n *       height: 5,\n *       curveSegments: 6\n *     }\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: {\n *     x: -40,\n *     y: 20,\n *     z: 0\n *   }\n * }).addTo(app);\n */\n\nvar Text =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  createClass(Text, null, [{\n    key: \"load\",\n\n    /**\n     * Default values for parameters\n     * @member {Object} module:components/meshes.Text#defaults\n     * @static\n     * @default <pre>\n     * {\n     *   text: 'Hello World!',\n     *   font: null,\n     *\n     *   geometry: {\n     *     size: 12,\n     *     height: 50,\n     *     curveSegments: 12,\n     *     font: new Font(),\n     *     bevelEnabled: false,\n     *     bevelThickness: 10,\n     *     bevelSize: 8\n     *   }\n     * }\n     * </pre>\n     */\n\n    /**\n     * Default FontLoader\n     * @member {Object} module:components/meshes.Text#loader\n     * @static\n     * @default new FontLoader()\n     */\n\n    /**\n     * @method load\n     * @static\n     * @description load() preloads a Font object and returns a Promise with it.\n     * @param {String} path Path to the font\n     * @return {Promise} A promise resolved with a font\n     * @memberof module:components/meshes.Text\n     */\n    value: function load(path) {\n      var loader = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : Text.loader;\n      return new Promise(function (resolve) {\n        loader.load(path, resolve);\n      });\n    }\n  }]);\n\n  function Text() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Text);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(Text).call(this, params, Text.defaults, Text.instructions));\n  }\n  /**\n   * @method build\n   * @description Build is called as part of the lifecycle to create a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Text\n   */\n\n\n  createClass(Text, [{\n    key: \"build\",\n    value: function build() {\n      var _this = this;\n\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n      var promise = new Promise(function (resolve) {\n        (params.font instanceof Promise ? params.font : Promise.resolve(params.font)).then(function (font) {\n          var _this$applyBridge = _this.applyBridge({\n            geometry: new TextGeometry(params.text, Object.assign(params.geometry, {\n              font: font\n            })),\n            material: params.material\n          }),\n              geometry = _this$applyBridge.geometry,\n              material = _this$applyBridge.material;\n\n          resolve(_this.applyBridge({\n            mesh: new Mesh(geometry, material)\n          }).mesh);\n        });\n      });\n\n      get$3(getPrototypeOf$2(Text.prototype), \"wait\", this).call(this, promise);\n\n      return promise;\n    }\n  }]);\n\n  inherits(Text, _MeshComponent);\n\n  return Text;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(defineProperty$3(Text, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  text: 'Hello World!',\n  font: null,\n  geometry: {\n    size: 12,\n    height: 50,\n    curveSegments: 12,\n    font: new Font(),\n    bevelEnabled: false,\n    bevelThickness: 10,\n    bevelSize: 8\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions)), \"loader\", new FontLoader());\n\n/**\n * @class Torus\n * @category components/meshes\n * @description Torus class makes a torus figure. A donut is a torus.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/index.html#api/geometries/TorusGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Torus, and adding it to app</caption>\n * new Torus({\n *   geometry: {\n *     radius: 5,\n *     tube: 2\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   position: {\n *     y: 35\n *   }\n * }).addTo(app);\n */\n\nvar Torus =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Torus#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     radius: 100,\n   *     tube: 40,\n   *     radialSegments: 8,\n   *     tubularSegments: 6,\n   *     arc: Math.PI * 2\n   *   }\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Torus#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: [\n   *     'radius',\n   *     'tube',\n   *     'radialSegments',\n   *     'tubularSegments',\n   *     'arc'\n   *   ]\n   * }\n   * </pre>\n   */\n  function Torus() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Torus);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Torus).call(this, params, Torus.defaults, Torus.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Torus.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Torus\n   */\n\n\n  createClass(Torus, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      return new TorusGeometry(params.geometry.radius, params.geometry.tube, params.geometry.radialSegments, params.geometry.tubularSegments, params.geometry.arc);\n    }\n  }]);\n\n  inherits(Torus, _MeshComponent);\n\n  return Torus;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Torus, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radius: 100,\n    tube: 40,\n    radialSegments: 8,\n    tubularSegments: 6,\n    arc: Math.PI * 2\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['radius', 'tube', 'radialSegments', 'tubularSegments', 'arc']\n}));\n\n/**\n * @class Torusknot\n * @category components/meshes\n * @description Torusknot class makes a torusknot figure. It's like a crooked donut, very crooked.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/scenes/geometry-browser.html#TorusKnotGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Torusknot, and adding it to app</caption>\n * new Torusknot({\n *   geometry: {\n *     radius:5,\n *     tube: 2\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *\n *   pos: {\n *     y: 100\n *   }\n * }).addTo(app);\n */\n\nvar Torusknot =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Torusknot#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     radius: 100,\n   *     tube: 40,\n   *     radialSegments: 64,\n   *     tubularSegments: 8,\n   *     p: 2,\n   *     q: 3\n   *   }\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Torusknot#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: [\n   *     'radius',\n   *     'tube',\n   *     'radialSegments',\n   *     'tubularSegments',\n   *     'p',\n   *     'q'\n   *   ]\n   * }\n   * </pre>\n   */\n  function Torusknot() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Torusknot);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Torusknot).call(this, params, Torusknot.defaults, Torusknot.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Torusknot.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Torusknot\n   */\n\n\n  createClass(Torusknot, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var GConstruct = params.buffer ? TorusKnotBufferGeometry : TorusKnotGeometry;\n      return new GConstruct(params.geometry.radius, params.geometry.tube, params.geometry.radialSegments, params.geometry.tubularSegments, params.geometry.p, params.geometry.q);\n    }\n  }]);\n\n  inherits(Torusknot, _MeshComponent);\n\n  return Torusknot;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Torusknot, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    radius: 100,\n    tube: 40,\n    radialSegments: 64,\n    tubularSegments: 8,\n    p: 2,\n    q: 3\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['radius', 'tube', 'radialSegments', 'tubularSegments', 'p', 'q']\n}));\n\n/**\n * @class Tube\n * @category components/meshes\n * @description Tube class makes a tube that extrudes along a 3d curve.\n * @classDesc\n * <iframe src=\"https://threejs.org/docs/index.html#api/geometries/TubeGeometry\"></iframe>\n * @param {Object} [params] - The params.\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Creating a Tube from a three.js Curve, and adding it to app</caption>\n * const CustomSinCurve = THREE.Curve.create(\n *   function (scale) { // custom curve constructor\n *     this.scale = (scale === undefined) ? 1 : scale;\n *   },\n *\n *   function (t) { // getPoint: t is between 0-1\n *     const tx = t * 3 - 1.5,\n *     ty = Math.sin( 2 * Math.PI * t ),\n *     tz = 0;\n *\n *     return new THREE.Vector3(tx, ty, tz).multiplyScalar(this.scale);\n *   }\n * );\n *\n * const path = new CustomSinCurve(10);\n *\n * new Tube({\n *   geometry: {\n *     path: path\n *   },\n *\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   })\n * }).addTo(app);\n */\n\nvar Tube =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  /**\n   * Default values for parameters\n   * @member {Object} module:components/meshes.Tube#defaults\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: {\n   *     path: new THREE.LineCurve3(new Vector3(0, 0, 0), new Vector3(0, 0, 1)),\n   *     segments: 20,\n   *     radius: 2,\n   *     radiusSegments: 8,\n   *     closed: false\n   *   }\n   * }\n   * </pre>\n   */\n\n  /**\n   * Instructions\n   * @member {Object} module:components/meshes.Tube#instructions\n   * @static\n   * @default <pre>\n   * {\n   *   geometry: [\n   *     'path',\n   *     'segments',\n   *     'radius',\n   *     'radiusSegments',\n   *     'closed'\n   *   ]\n   * }\n   * </pre>\n   */\n  function Tube() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, Tube);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Tube).call(this, params, Tube.defaults, Tube.instructions));\n\n    if (params.build) {\n      _this.build(params);\n\n      get$3(getPrototypeOf$2(Tube.prototype), \"wrap\", assertThisInitialized(_this)).call(assertThisInitialized(_this));\n    }\n\n    return _this;\n  }\n  /**\n   * @method build\n   * @description Build lifecycle creates a mesh using input params.\n   * @param {Object} params Component parameters.\n   * @return {THREE.Mesh} Built mesh\n   * @memberof module:components/meshes.Tube\n   */\n\n\n  createClass(Tube, [{\n    key: \"build\",\n    value: function build() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.params;\n\n      var _this$applyBridge = this.applyBridge({\n        geometry: this.buildGeometry(params),\n        material: params.material\n      }),\n          geometry = _this$applyBridge.geometry,\n          material = _this$applyBridge.material;\n\n      return this.applyBridge({\n        mesh: new Mesh(geometry, material)\n      }).mesh;\n    }\n  }, {\n    key: \"buildGeometry\",\n    value: function buildGeometry() {\n      var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      var geometry = new (params.buffer ? TubeBufferGeometry : TubeGeometry)(params.geometry.path, params.geometry.segments, params.geometry.radius, params.geometry.radiusSegments, params.geometry.closed);\n      return geometry;\n    }\n  }]);\n\n  inherits(Tube, _MeshComponent);\n\n  return Tube;\n}(MeshComponent);\n\ndefineProperty$3(defineProperty$3(Tube, \"defaults\", objectSpread({}, MeshComponent.defaults, {\n  geometry: {\n    path: new LineCurve3(new Vector3(0, 0, 0), new Vector3(0, 0, 1)),\n    segments: 20,\n    radius: 2,\n    radiusSegments: 8,\n    closed: false\n  }\n})), \"instructions\", objectSpread({}, MeshComponent.instructions, {\n  geometry: ['path', 'segments', 'radius', 'radiusSegments', 'closed']\n}));\n\n/**\n * @class Group\n * @category components/meshes\n * @description Sometimes you need to make groups of objects (it's not conveniently to apply transforms to each object when can make just one to a group).<br/>\n * In Three.js you make it using `THREE.Object3D` and it's children. <br/><br/>\n * In whs.js we have `Group`\n * @extends module:core.MeshComponent\n * @memberof module:components/meshes\n * @example <caption>Approach 2 - Adding objects to an empty group</caption>\n * const sphere = new Sphere();\n * const box = new Box();\n * const group = new Group();\n *\n * sphere.addTo(group);\n * box.addTo(group);\n* @example <caption>Approach 2 - Making a group from objects</caption>\n * const sphere = new Sphere();\n * const box = new Box();\n * const group = new Group(box, sphere);\n * // OR: const group = new Group([box, sphere]);\n */\n\nvar Group$1 =\n/*#__PURE__*/\nfunction (_MeshComponent) {\n  function Group$$1() {\n    var _this;\n\n    classCallCheck(this, Group$$1);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(Group$$1).call(this, {}));\n\n    for (var i = 0; i < arguments.length; i++) {\n      var obj = i < 0 || arguments.length <= i ? undefined : arguments[i];\n      if (obj instanceof Component) obj.addTo(assertThisInitialized(assertThisInitialized(_this)));else if (obj instanceof Object3D) _this.native.add(obj);\n    }\n\n    return _this;\n  }\n\n  createClass(Group$$1, [{\n    key: \"build\",\n    value: function build() {\n      return new Object3D();\n    }\n  }]);\n\n  inherits(Group$$1, _MeshComponent);\n\n  return Group$$1;\n}(MeshComponent);\n\n/** @module components/meshes */\n\n/**\n * @class ElementModule\n * @category modules/app\n * @param {Object} [container=document.body] container is the DOM object to which application's canvas will be added to.\n * @memberof module:modules/app\n * @example <caption>Creating an element module, passing it to the App</caption>\n * new App([\n *   new ElementModule(document.getElementById('app'))\n * ]);\n */\nvar ElementModule =\n/*#__PURE__*/\nfunction () {\n  function ElementModule() {\n    var container = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : document.body;\n\n    classCallCheck(this, ElementModule);\n\n    if (container.container) {\n      console.warn('ElementModule now accepts only argument which is a DOM object, not a params object.');\n      this.container = container.container;\n    } else this.container = container;\n\n    this.createElement();\n  }\n  /**\n   * @method createElement\n   * @instance\n   * @description Creates a canvas element.\n   * @memberof module:modules/app.ElementModule\n   */\n\n\n  createClass(ElementModule, [{\n    key: \"createElement\",\n    value: function createElement() {\n      this.element = window.document.createElement('div');\n      this.element.className = 'whs-app';\n      this.element.style.width = 'inherit';\n      this.element.style.height = 'inherit';\n      this.element.style.position = 'relative';\n    }\n  }, {\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.set('element', this.element);\n\n      _manager.set('container', this.container);\n    }\n  }, {\n    key: \"integrate\",\n    value: function integrate(self) {\n      self.container.appendChild(self.element);\n    }\n  }]);\n\n  return ElementModule;\n}();\n\n/**\n * @class RenderingModule\n * @category modules/app\n * @param {Object} [params]\n * @memberof module:modules/app\n * @example <caption> Creating a rendering module and passing it to App's modules</caption>\n * new App([\n *   new ElementModule(),\n *   new SceneModule(),\n *   new DefineModule('camera', new PerspectiveCamera({\n *     position: new THREE.Vector3(0, 6, 18),\n *     far: 10000\n *   })),\n *   new RenderingModule({\n *     bgColor: 0x162129,\n *\n *     renderer: {\n *       antialias: true\n *     }\n *   }, {shadow: true})\n * ]);\n */\n\nvar RenderingModule =\n/*#__PURE__*/\nfunction () {\n  /**\n   * additional\n   * @description collection of additional scripts\n   * @static\n   * @member {Object} module:core.App#additional\n   * @public\n   */\n\n  /**\n   * enabled\n   * @static\n   * @member {Boolean} module:core.App#enabled\n   * @public\n   */\n  function RenderingModule() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n    var additional = arguments.length > 1 ? arguments[1] : undefined;\n\n    classCallCheck(this, RenderingModule);\n\n    defineProperty$3(this, \"enabled\", true);\n\n    this.params = Object.assign({\n      width: window.innerWidth,\n      height: window.innerHeight,\n      resolution: new Vector2(1, 1),\n      pixelRatio: window.devicePixelRatio,\n      bgColor: 0x000000,\n      bgOpacity: 1,\n      renderer: {},\n      fix: function fix() {}\n    }, params);\n    var _this$params = this.params,\n        bgColor = _this$params.bgColor,\n        bgOpacity = _this$params.bgOpacity,\n        _renderer = _this$params.renderer,\n        pixelRatio = _this$params.pixelRatio,\n        width = _this$params.width,\n        height = _this$params.height,\n        resolution = _this$params.resolution,\n        fix = _this$params.fix;\n    this.renderer = new WebGLRenderer(_renderer);\n    this.effects = [];\n    this.renderer.setClearColor(bgColor, bgOpacity);\n    if (pixelRatio) this.renderer.setPixelRatio(pixelRatio);\n    this.setSize(Number(width * resolution.x).toFixed(), Number(height * resolution.y).toFixed());\n\n    for (var key in additional) {\n      if (additional[key]) this.applyAdditional(key);\n    }\n\n    fix(this.renderer);\n  }\n  /**\n   * @method applyAdditional\n   * @description Apply additional script from RenderingModule.additional\n   * @param {Stirng} name Script name\n   * @return {this}\n   * @memberof module:modules/app.RenderingModule\n   */\n\n\n  createClass(RenderingModule, [{\n    key: \"applyAdditional\",\n    value: function applyAdditional(name) {\n      RenderingModule.additional[name].apply(this, [this.renderer]);\n    }\n    /**\n     * @method integrateRenderer\n     * @description Integrate renderer\n     * @param {NodeElement} element DOM object\n     * @param {THREE.Scene} scene used scene\n     * @param {THREE.Camera} camera used camera\n     * @return {Loop} renderLoop\n     * @memberof module:modules/app.RenderingModule\n     */\n\n  }, {\n    key: \"integrateRenderer\",\n    value: function integrateRenderer(element, scene, camera) {\n      var _this = this;\n\n      this.scene = scene;\n      this.camera = camera;\n      this.attachToCanvas(element);\n      return new Loop(function () {\n        return _this.renderer.render(_this.scene, _this.camera);\n      });\n    }\n    /**\n     * @method effect\n     * @description Add three.js effect\n     * @param {Object} effect three.js effect\n     * @param {function} effectLoop update function for effect\n     * @return {this}\n     * @memberof module:modules/app.RenderingModule\n     */\n\n  }, {\n    key: \"effect\",\n    value: function effect(_effect) {\n      var _this2 = this;\n\n      var effectLoop = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function () {\n        _effect.render(_this2.scene, _this2.camera);\n      };\n      this.renderLoop.stop();\n      var size = this.renderer.getSize();\n\n      _effect.setSize(size.width, size.height);\n\n      var loop = new Loop(effectLoop);\n      this.effects.push(loop);\n      if (this.enabled) loop.start(this.app);\n      return this;\n    }\n    /**\n     * @method setSize\n     * @description Update render target width and height.\n     * @param {Number} width\n     * @param {Number} height\n     * @memberof module:modules/app.RenderingModule\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      if (this.renderer) this.renderer.setSize(width, height);\n    }\n    /**\n     * @method attachToCanvas\n     * @description Attach renderer.domElement to element\n     * @param {NodeElement} element DOM object\n     * @memberof module:modules/app.RenderingModule\n     */\n\n  }, {\n    key: \"attachToCanvas\",\n    value: function attachToCanvas(element) {\n      var canvas = this.renderer.domElement; // attach to new parent world dom\n\n      element.appendChild(canvas);\n      canvas.style.width = '100%';\n      canvas.style.height = '100%';\n    }\n    /**\n     * @method stop\n     * @description Stops renderLoop and effect loops\n     * @memberof module:modules/app.RenderingModule\n     */\n\n  }, {\n    key: \"stop\",\n    value: function stop() {\n      this.enabled = false;\n      this.renderLoop.stop();\n      this.effects.forEach(function (loop) {\n        return loop.stop();\n      });\n    }\n    /**\n     * @method play\n     * @description Resumes renderLoop and effect loops\n     * @memberof module:modules/app.RenderingModule\n     */\n\n  }, {\n    key: \"play\",\n    value: function play() {\n      this.enabled = true;\n      this.renderLoop.start();\n      this.effects.forEach(function (loop) {\n        return loop.start();\n      });\n    }\n  }, {\n    key: \"manager\",\n    value: function manager(_manager) {\n      var _this3 = this;\n\n      _manager.define('rendering');\n\n      _manager.set('renderer', this.renderer);\n\n      this.app = _manager.handler;\n      this.renderLoop = this.integrateRenderer(_manager.get('element'), _manager.get('scene'), _manager.get('camera').native);\n\n      _manager.update({\n        element: function element(_element) {\n          _this3.attachToCanvas(_element);\n        },\n        scene: function scene(_scene) {\n          _this3.scene = _scene;\n        },\n        camera: function camera(_camera) {\n          _this3.camera = _camera.native;\n        }\n      });\n    }\n  }, {\n    key: \"integrate\",\n    value: function integrate(self) {\n      var _this4 = this;\n\n      self.renderLoop.start(this);\n      self.effects.forEach(function (loop) {\n        return loop.start(_this4);\n      });\n    }\n    /**\n     * @method dispose\n     * @description Dispose rendering context\n     * @memberof module:modules/app.RenderingModule\n     */\n\n  }, {\n    key: \"dispose\",\n    value: function dispose() {\n      this.stop();\n      this.renderer.forceContextLoss();\n    }\n  }]);\n\n  return RenderingModule;\n}();\n\ndefineProperty$3(RenderingModule, \"additional\", {\n  shadow: function shadow(renderer) {\n    renderer.shadowMap.enabled = true;\n  }\n});\n\nvar SYMBOL_CHILDREN_FOR_SCENE = Symbol('SYMBOL_CHILDREN_FOR_SCENE');\n/**\n * @class SceneModule\n * @category modules/app\n * @param {Boolean} [willSceneBeReplaced=false] willSceneBeReplaced should be true only if you are going to overwrite scene dependency even without the use of default one.\n * @memberof module:modules/app\n */\n\nvar SceneModule =\n/*#__PURE__*/\nfunction () {\n  function SceneModule() {\n    var willSceneBeReplaced = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n\n    classCallCheck(this, SceneModule);\n\n    this.scene = willSceneBeReplaced ? null : new Scene();\n  }\n\n  createClass(SceneModule, [{\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.set('scene', this.scene);\n    }\n  }, {\n    key: \"integrate\",\n    value: function integrate(self) {\n      Object.assign(this, {\n        add: function add(object) {\n          var _this = this;\n\n          return asyncToGenerator(\n          /*#__PURE__*/\n          regenerator.mark(function _callee() {\n            return regenerator.wrap(function _callee$(_context) {\n              while (1) {\n                switch (_context.prev = _context.next) {\n                  case 0:\n                    if (!object.parent) {\n                      _context.next = 3;\n                      break;\n                    }\n\n                    _context.next = 3;\n                    return object.parent.remove(object);\n\n                  case 3:\n                    _context.next = 5;\n                    return object.wait();\n\n                  case 5:\n                    if (object.native) {\n                      _context.next = 7;\n                      break;\n                    }\n\n                    throw new CompositionError('SceneModule', 'there is no object.native', _this);\n\n                  case 7:\n                    object.parent = _this;\n                    _context.next = 10;\n                    return _this.applyBridge({\n                      onAdd: object\n                    }).onAdd;\n\n                  case 10:\n                    self.scene.add(object.native);\n\n                    _this.children.push(object);\n\n                    return _context.abrupt(\"return\", object);\n\n                  case 13:\n                  case \"end\":\n                    return _context.stop();\n                }\n              }\n            }, _callee, this);\n          }))();\n        },\n        remove: function remove(object) {\n          var _this2 = this;\n\n          return asyncToGenerator(\n          /*#__PURE__*/\n          regenerator.mark(function _callee2() {\n            return regenerator.wrap(function _callee2$(_context2) {\n              while (1) {\n                switch (_context2.prev = _context2.next) {\n                  case 0:\n                    if (!(object.parent !== _this2)) {\n                      _context2.next = 2;\n                      break;\n                    }\n\n                    return _context2.abrupt(\"return\");\n\n                  case 2:\n                    _context2.next = 4;\n                    return object.wait();\n\n                  case 4:\n                    object.parent = null;\n                    self.scene.remove(object.native);\n\n                    _this2.children.splice(_this2.children.indexOf(object), 1);\n\n                  case 7:\n                  case \"end\":\n                    return _context2.stop();\n                }\n              }\n            }, _callee2, this);\n          }))();\n        },\n        _setScene: function _setScene(scene) {\n          this.children = scene[SYMBOL_CHILDREN_FOR_SCENE] = scene[SYMBOL_CHILDREN_FOR_SCENE] || [];\n          self.scene = scene;\n        },\n        setScene: function setScene(scene) {\n          this._setScene(scene);\n\n          this.manager.set('scene', scene);\n        },\n        getScene: function getScene() {\n          return self.scene;\n        }\n      });\n      if (self.scene) this._setScene(self.scene);\n    }\n  }]);\n\n  return SceneModule;\n}();\n\n// import {addResizeListener} from 'detect-element-resize';\n\n/**\n * @class ResizeModule\n * @category modules/app\n * @param {Object} [params={auto: true}] - If auto is set to true - resize will be triggered when container resizes\n * @memberof module:modules/app\n */\nvar ResizeModule =\n/*#__PURE__*/\nfunction () {\n  function ResizeModule() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, ResizeModule);\n\n    this.params = Object.assign({\n      auto: true\n    }, params);\n    this.callbacks = [this.setSize.bind(this)];\n  }\n  /**\n   * @function setSize\n   * @instance\n   * @description This function sets the provided width & height to the renderer object.\n   * @param {Number} [width=1] - The promise that should be added to a queue.\n   * @param {Number} [height=1] - that is resolved when all promises completed.\n   * @memberof module:modules/app.ResizeModule\n   */\n\n\n  createClass(ResizeModule, [{\n    key: \"setSize\",\n    value: function setSize() {\n      var width = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1;\n      var height = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n      this.camera.native.aspect = width / height;\n      this.camera.native.updateProjectionMatrix();\n      if (this.rendering) this.rendering.setSize(width, height);\n    }\n    /**\n     * @method trigger\n     * @instance\n     * @description Triggers resize when called. width & height are determined automatically\n     * This invokes each callbacks with the new width and height as params\n     * @memberof module:modules/app.ResizeModule\n     */\n\n  }, {\n    key: \"trigger\",\n    value: function trigger() {\n      var _this$container = this.container,\n          offsetWidth = _this$container.offsetWidth,\n          offsetHeight = _this$container.offsetHeight,\n          resolution = this.resolution;\n      var width = Number(offsetWidth * resolution.x).toFixed();\n      var height = Number(offsetHeight * resolution.y).toFixed();\n      this.callbacks.forEach(function (cb) {\n        cb(width, height);\n      });\n    }\n    /**\n     * @method addAutoresize\n     * @instance\n     * @description Sets module to autoresize, this adds an event listene on window resize to trigger the resize\n     * @memberof module:modules/app.ResizeModule\n     */\n\n  }, {\n    key: \"addAutoresize\",\n    value: function addAutoresize() {\n      this.container = this.getContainer();\n      this.resolution = this.getResolution();\n      if (this.params.auto) window.addEventListener('resize', this.trigger.bind(this));\n    }\n    /**\n     * @method addCallback\n     * @instance\n     * @description Adds a call back function to the existing callbacks list.\n     * @param {Function} func - The callback function to add\n     * @memberof module:modules/app.ResizeModule\n     */\n\n  }, {\n    key: \"addCallback\",\n    value: function addCallback(func) {\n      this.callbacks.push(func);\n    }\n  }, {\n    key: \"manager\",\n    value: function manager(_manager) {\n      var _this = this;\n\n      _manager.define('resize');\n\n      this.rendering = _manager.get('renderer');\n      this.camera = _manager.get('camera');\n\n      this.getResolution = function () {\n        return _manager.use('rendering').params.resolution;\n      };\n\n      this.getContainer = function () {\n        return _manager.get('container');\n      };\n\n      _manager.update({\n        container: function container(_container) {\n          _this.container = _container;\n        }\n      });\n\n      this.addAutoresize();\n    }\n  }]);\n\n  return ResizeModule;\n}();\n\nvar fragment = \"uniform sampler2D tPreviousLum;\\r\\nuniform sampler2D tCurrentLum;\\r\\nuniform float minLuminance;\\r\\nuniform float delta;\\r\\nuniform float tau;\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tfloat previousLum = texture2D(tPreviousLum, vUv, MIP_LEVEL_1X1).r;\\r\\n\\tfloat currentLum = texture2D(tCurrentLum, vUv, MIP_LEVEL_1X1).r;\\r\\n\\r\\n\\tpreviousLum = max(minLuminance, previousLum);\\r\\n\\tcurrentLum = max(minLuminance, currentLum);\\r\\n\\r\\n\\t// Adapt the luminance using Pattanaik's technique.\\r\\n\\tfloat adaptedLum = previousLum + (currentLum - previousLum) * (1.0 - exp(-delta * tau));\\r\\n\\r\\n\\tgl_FragColor.r = adaptedLum;\\r\\n\\r\\n}\\r\\n\";\nvar vertex = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * An adaptive luminosity shader material.\r\n */\n\nvar AdaptiveLuminosityMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new adaptive luminosity material.\r\n   */\n  function AdaptiveLuminosityMaterial() {\n    classCallCheck(this, AdaptiveLuminosityMaterial);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(AdaptiveLuminosityMaterial).call(this, {\n      type: \"AdaptiveLuminosityMaterial\",\n      defines: {\n        MIP_LEVEL_1X1: \"0.0\"\n      },\n      uniforms: {\n        tPreviousLum: new Uniform(null),\n        tCurrentLum: new Uniform(null),\n        minLuminance: new Uniform(0.01),\n        delta: new Uniform(0.0),\n        tau: new Uniform(1.0)\n      },\n      fragmentShader: fragment,\n      vertexShader: vertex,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n\n  inherits(AdaptiveLuminosityMaterial, _ShaderMaterial);\n\n  return AdaptiveLuminosityMaterial;\n}(ShaderMaterial);\n\nvar fragment$1 = \"uniform sampler2D tDiffuse;\\r\\nuniform sampler2D tDepth;\\r\\n\\r\\nuniform float focus;\\r\\nuniform float dof;\\r\\nuniform float aspect;\\r\\nuniform float aperture;\\r\\nuniform float maxBlur;\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\n#ifndef USE_LOGDEPTHBUF\\r\\n\\r\\n\\t#include <packing>\\r\\n\\r\\n\\tuniform float cameraNear;\\r\\n\\tuniform float cameraFar;\\r\\n\\r\\n\\tfloat readDepth(sampler2D depthSampler, vec2 coord) {\\r\\n\\r\\n\\t\\tfloat fragCoordZ = texture2D(depthSampler, coord).x;\\r\\n\\t\\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\\r\\n\\r\\n\\t\\treturn viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\\r\\n\\r\\n\\t}\\r\\n\\r\\n#endif\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec2 aspectCorrection = vec2(1.0, aspect);\\r\\n\\r\\n\\t#ifdef USE_LOGDEPTHBUF\\r\\n\\r\\n\\t\\tfloat depth = texture2D(tDepth, vUv).x;\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tfloat depth = readDepth(tDepth, vUv);\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tfloat focusNear = clamp(focus - dof, 0.0, 1.0);\\r\\n\\tfloat focusFar = clamp(focus + dof, 0.0, 1.0);\\r\\n\\r\\n\\t// Calculate a DoF mask.\\r\\n\\tfloat low = step(depth, focusNear);\\r\\n\\tfloat high = step(focusFar, depth);\\r\\n\\r\\n\\tfloat factor = (depth - focusNear) * low + (depth - focusFar) * high;\\r\\n\\r\\n\\tvec2 dofBlur = vec2(clamp(factor * aperture, -maxBlur, maxBlur));\\r\\n\\r\\n\\tvec2 dofblur9 = dofBlur * 0.9;\\r\\n\\tvec2 dofblur7 = dofBlur * 0.7;\\r\\n\\tvec2 dofblur4 = dofBlur * 0.4;\\r\\n\\r\\n\\tvec4 color = vec4(0.0);\\r\\n\\r\\n\\tcolor += texture2D(tDiffuse, vUv);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0,   0.4 ) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.15,  0.37) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29,  0.29) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.37,  0.15) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.40,  0.0 ) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.37, -0.15) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29, -0.29) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.15, -0.37) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0,  -0.4 ) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.15,  0.37) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29,  0.29) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.37,  0.15) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.4,   0.0 ) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.37, -0.15) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29, -0.29) * aspectCorrection) * dofBlur);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.15, -0.37) * aspectCorrection) * dofBlur);\\r\\n\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.15,  0.37) * aspectCorrection) * dofblur9);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.37,  0.15) * aspectCorrection) * dofblur9);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.37, -0.15) * aspectCorrection) * dofblur9);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.15, -0.37) * aspectCorrection) * dofblur9);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.15,  0.37) * aspectCorrection) * dofblur9);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.37,  0.15) * aspectCorrection) * dofblur9);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.37, -0.15) * aspectCorrection) * dofblur9);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.15, -0.37) * aspectCorrection) * dofblur9);\\r\\n\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29,  0.29) * aspectCorrection) * dofblur7);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.40,  0.0 ) * aspectCorrection) * dofblur7);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29, -0.29) * aspectCorrection) * dofblur7);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0,  -0.4 ) * aspectCorrection) * dofblur7);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29,  0.29) * aspectCorrection) * dofblur7);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.4,   0.0 ) * aspectCorrection) * dofblur7);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29, -0.29) * aspectCorrection) * dofblur7);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0,   0.4 ) * aspectCorrection) * dofblur7);\\r\\n\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29,  0.29) * aspectCorrection) * dofblur4);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.4,   0.0 ) * aspectCorrection) * dofblur4);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.29, -0.29) * aspectCorrection) * dofblur4);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0,  -0.4 ) * aspectCorrection) * dofblur4);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29,  0.29) * aspectCorrection) * dofblur4);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.4,   0.0 ) * aspectCorrection) * dofblur4);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2(-0.29, -0.29) * aspectCorrection) * dofblur4);\\r\\n\\tcolor += texture2D(tDiffuse, vUv + (vec2( 0.0,   0.4 ) * aspectCorrection) * dofblur4);\\r\\n\\r\\n\\tgl_FragColor = color / 41.0;\\r\\n\\r\\n}\\r\\n\";\nvar vertex$1 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * Depth of Field shader (Bokeh).\r\n *\r\n * Original shader code by Martins Upitis:\r\n *  http://artmartinsh.blogspot.com/2010/02/glsl-lens-blur-filter-with-bokeh.html\r\n */\n\nvar BokehMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new bokeh material.\r\n   *\r\n   * @param {PerspectiveCamera} [camera] - A camera.\r\n   * @param {Object} [options] - The options.\r\n   * @param {Number} [options.focus=1.0] - The focus distance, corresponds directly with the scene depth.\r\n   * @param {Number} [options.dof=0.02] - Depth of field. An area in front of and behind the focus point that still appears sharp.\r\n   * @param {Number} [options.aperture=0.025] - Camera aperture scale. Bigger values for stronger blur and shallower depth of field.\r\n   * @param {Number} [options.maxBlur=1.0] - Maximum blur strength.\r\n   */\n  function BokehMaterial(camera) {\n    var _this;\n\n    var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n    classCallCheck(this, BokehMaterial);\n\n    var settings = Object.assign({\n      focus: 1.0,\n      dof: 0.02,\n      aperture: 0.025,\n      maxBlur: 1.0\n    }, options);\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(BokehMaterial).call(this, {\n      type: \"BokehMaterial\",\n      uniforms: {\n        cameraNear: new Uniform(0.1),\n        cameraFar: new Uniform(2000),\n        aspect: new Uniform(1.0),\n        tDiffuse: new Uniform(null),\n        tDepth: new Uniform(null),\n        focus: new Uniform(settings.focus),\n        dof: new Uniform(settings.dof),\n        aperture: new Uniform(settings.aperture),\n        maxBlur: new Uniform(settings.maxBlur)\n      },\n      fragmentShader: fragment$1,\n      vertexShader: vertex$1,\n      depthWrite: false,\n      depthTest: false\n    }));\n\n    _this.adoptCameraSettings(camera);\n\n    return _this;\n  }\n  /**\r\n   * Adopts the settings of the given camera.\r\n   *\r\n   * @param {PerspectiveCamera} [camera=null] - A camera.\r\n   */\n\n\n  createClass(BokehMaterial, [{\n    key: \"adoptCameraSettings\",\n    value: function adoptCameraSettings() {\n      var camera = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n\n      if (camera !== null) {\n        this.uniforms.cameraNear.value = camera.near;\n        this.uniforms.cameraFar.value = camera.far;\n        this.uniforms.aspect.value = camera.aspect;\n      }\n    }\n  }]);\n\n  inherits(BokehMaterial, _ShaderMaterial);\n\n  return BokehMaterial;\n}(ShaderMaterial);\n\nvar fragment$2 = \"uniform sampler2D tDiffuse;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying vec4 vOffset[3];\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tconst vec2 threshold = vec2(EDGE_THRESHOLD);\\r\\n\\r\\n\\t// Calculate color deltas.\\r\\n\\tvec4 delta;\\r\\n\\tvec3 c = texture2D(tDiffuse, vUv).rgb;\\r\\n\\r\\n\\tvec3 cLeft = texture2D(tDiffuse, vOffset[0].xy).rgb;\\r\\n\\tvec3 t = abs(c - cLeft);\\r\\n\\tdelta.x = max(max(t.r, t.g), t.b);\\r\\n\\r\\n\\tvec3 cTop = texture2D(tDiffuse, vOffset[0].zw).rgb;\\r\\n\\tt = abs(c - cTop);\\r\\n\\tdelta.y = max(max(t.r, t.g), t.b);\\r\\n\\r\\n\\t// We do the usual threshold.\\r\\n\\tvec2 edges = step(threshold, delta.xy);\\r\\n\\r\\n\\t// Then discard if there is no edge.\\r\\n\\tif(dot(edges, vec2(1.0)) == 0.0) {\\r\\n\\r\\n\\t\\tdiscard;\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\t// Calculate right and bottom deltas.\\r\\n\\tvec3 cRight = texture2D(tDiffuse, vOffset[1].xy).rgb;\\r\\n\\tt = abs(c - cRight);\\r\\n\\tdelta.z = max(max(t.r, t.g), t.b);\\r\\n\\r\\n\\tvec3 cBottom = texture2D(tDiffuse, vOffset[1].zw).rgb;\\r\\n\\tt = abs(c - cBottom);\\r\\n\\tdelta.w = max(max(t.r, t.g), t.b);\\r\\n\\r\\n\\t// Calculate the maximum delta in the direct neighborhood.\\r\\n\\tfloat maxDelta = max(max(max(delta.x, delta.y), delta.z), delta.w);\\r\\n\\r\\n\\t// Calculate left-left and top-top deltas.\\r\\n\\tvec3 cLeftLeft = texture2D(tDiffuse, vOffset[2].xy).rgb;\\r\\n\\tt = abs(c - cLeftLeft);\\r\\n\\tdelta.z = max(max(t.r, t.g), t.b);\\r\\n\\r\\n\\tvec3 cTopTop = texture2D(tDiffuse, vOffset[2].zw).rgb;\\r\\n\\tt = abs(c - cTopTop);\\r\\n\\tdelta.w = max(max(t.r, t.g), t.b);\\r\\n\\r\\n\\t// Calculate the final maximum delta.\\r\\n\\tmaxDelta = max(max(maxDelta, delta.z), delta.w);\\r\\n\\r\\n\\t// Local contrast adaptation in action.\\r\\n\\tedges.xy *= step(0.5 * maxDelta, delta.xy);\\r\\n\\r\\n\\tgl_FragColor = vec4(edges, 0.0, 0.0);\\r\\n\\r\\n}\\r\\n\";\nvar vertex$2 = \"uniform vec2 texelSize;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying vec4 vOffset[3];\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\r\\n\\tvOffset[0] = uv.xyxy + texelSize.xyxy * vec4(-1.0, 0.0, 0.0, 1.0); // Changed sign in W component.\\r\\n\\tvOffset[1] = uv.xyxy + texelSize.xyxy * vec4(1.0, 0.0, 0.0, -1.0); // Changed sign in W component.\\r\\n\\tvOffset[2] = uv.xyxy + texelSize.xyxy * vec4(-2.0, 0.0, 0.0, 2.0); // Changed sign in W component.\\r\\n\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A material that detects edges in a color texture.\r\n *\r\n * Mainly used for Subpixel Morphological Antialiasing.\r\n */\n\nvar ColorEdgesMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new color edges material.\r\n   *\r\n   * @param {Vector2} [texelSize] - The absolute screen texel size.\r\n   */\n  function ColorEdgesMaterial() {\n    var texelSize = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Vector2();\n\n    classCallCheck(this, ColorEdgesMaterial);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(ColorEdgesMaterial).call(this, {\n      type: \"ColorEdgesMaterial\",\n      defines: {\n        EDGE_THRESHOLD: \"0.1\"\n      },\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        texelSize: new Uniform(texelSize)\n      },\n      fragmentShader: fragment$2,\n      vertexShader: vertex$2,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n  /**\r\n   * Sets the edge detection sensitivity.\r\n   *\r\n   * A lower value results in more edges being detected at the expense of\r\n   * performance.\r\n   *\r\n   * 0.1 is a reasonable value, and allows to catch most visible edges.\r\n   * 0.05 is a rather overkill value, that allows to catch 'em all.\r\n   *\r\n   * If temporal supersampling is used, 0.2 could be a reasonable value,\r\n   * as low contrast edges are properly filtered by just 2x.\r\n   *\r\n   * @param {Number} threshold - The edge detection sensitivity. Range: [0, 0.5].\r\n   */\n\n\n  createClass(ColorEdgesMaterial, [{\n    key: \"setEdgeDetectionThreshold\",\n    value: function setEdgeDetectionThreshold(threshold) {\n      this.defines.EDGE_THRESHOLD = threshold.toFixed(\"2\");\n      this.needsUpdate = true;\n    }\n  }]);\n\n  inherits(ColorEdgesMaterial, _ShaderMaterial);\n\n  return ColorEdgesMaterial;\n}(ShaderMaterial);\n\nvar fragment$3 = \"uniform sampler2D texture1;\\r\\nuniform sampler2D texture2;\\r\\n\\r\\nuniform float opacity1;\\r\\nuniform float opacity2;\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec4 texel1 = opacity1 * texture2D(texture1, vUv);\\r\\n\\tvec4 texel2 = opacity2 * texture2D(texture2, vUv);\\r\\n\\r\\n\\t#ifdef SCREEN_MODE\\r\\n\\r\\n\\t\\tvec3 invTexel1 = vec3(1.0) - texel1.rgb;\\r\\n\\t\\tvec3 invTexel2 = vec3(1.0) - texel2.rgb;\\r\\n\\r\\n\\t\\tvec4 color = vec4(\\r\\n\\t\\t\\tvec3(1.0) - invTexel1 * invTexel2,\\r\\n\\t\\t\\ttexel1.a + texel2.a\\r\\n\\t\\t);\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tvec4 color = texel1 + texel2;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tgl_FragColor = color;\\r\\n\\r\\n}\\r\\n\";\nvar vertex$3 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A material for combining two textures.\r\n *\r\n * This material supports the two blend modes Add and Screen.\r\n *\r\n * In Screen mode, the two textures are effectively projected on a white screen\r\n * simultaneously. In Add mode, the textures are simply added together which\r\n * often produces undesired, washed out results.\r\n */\n\nvar CombineMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new combine material.\r\n   *\r\n   * @param {Boolean} [screenMode=false] - Whether the screen blend mode should be used.\r\n   */\n  function CombineMaterial() {\n    var _this;\n\n    var screenMode = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n\n    classCallCheck(this, CombineMaterial);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(CombineMaterial).call(this, {\n      type: \"CombineMaterial\",\n      uniforms: {\n        texture1: new Uniform(null),\n        texture2: new Uniform(null),\n        opacity1: new Uniform(1.0),\n        opacity2: new Uniform(1.0)\n      },\n      fragmentShader: fragment$3,\n      vertexShader: vertex$3,\n      depthWrite: false,\n      depthTest: false\n    }));\n\n    _this.setScreenModeEnabled(screenMode);\n\n    return _this;\n  }\n  /**\r\n   * Enables or disables the Screen blend mode.\r\n   *\r\n   * @param {Boolean} enabled - Whether the Screen blend mode should be enabled.\r\n   */\n\n\n  createClass(CombineMaterial, [{\n    key: \"setScreenModeEnabled\",\n    value: function setScreenModeEnabled(enabled) {\n      if (enabled) {\n        this.defines.SCREEN_MODE = \"1\";\n      } else {\n        delete this.defines.SCREEN_MODE;\n      }\n\n      this.needsUpdate = true;\n    }\n  }]);\n\n  inherits(CombineMaterial, _ShaderMaterial);\n\n  return CombineMaterial;\n}(ShaderMaterial);\n\nvar fragment$4 = \"#include <common>\\r\\n#include <dithering_pars_fragment>\\r\\n\\r\\nuniform sampler2D tDiffuse;\\r\\n\\r\\nvarying vec2 vUv0;\\r\\nvarying vec2 vUv1;\\r\\nvarying vec2 vUv2;\\r\\nvarying vec2 vUv3;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\t// Sample top left texel.\\r\\n\\tvec4 sum = texture2D(tDiffuse, vUv0);\\r\\n\\r\\n\\t// Sample top right texel.\\r\\n\\tsum += texture2D(tDiffuse, vUv1);\\r\\n\\r\\n\\t// Sample bottom right texel.\\r\\n\\tsum += texture2D(tDiffuse, vUv2);\\r\\n\\r\\n\\t// Sample bottom left texel.\\r\\n\\tsum += texture2D(tDiffuse, vUv3);\\r\\n\\r\\n\\t// Compute the average.\\r\\n\\tgl_FragColor = sum * 0.25;\\r\\n\\r\\n\\t#include <dithering_fragment>\\r\\n\\r\\n}\\r\\n\";\nvar vertex$4 = \"uniform vec2 texelSize;\\r\\nuniform vec2 halfTexelSize;\\r\\nuniform float kernel;\\r\\n\\r\\nvarying vec2 vUv0;\\r\\nvarying vec2 vUv1;\\r\\nvarying vec2 vUv2;\\r\\nvarying vec2 vUv3;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec2 dUv = (texelSize * vec2(kernel)) + halfTexelSize;\\r\\n\\r\\n\\tvUv0 = vec2(uv.x - dUv.x, uv.y + dUv.y);\\r\\n\\tvUv1 = vec2(uv.x + dUv.x, uv.y + dUv.y);\\r\\n\\tvUv2 = vec2(uv.x + dUv.x, uv.y - dUv.y);\\r\\n\\tvUv3 = vec2(uv.x - dUv.x, uv.y - dUv.y);\\r\\n\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * An optimised convolution shader material.\r\n *\r\n * This material supports dithering.\r\n *\r\n * Based on the GDC2003 Presentation by Masaki Kawase, Bunkasha Games:\r\n *  Frame Buffer Postprocessing Effects in DOUBLE-S.T.E.A.L (Wreckless)\r\n * and an article by Filip Strugar, Intel:\r\n *  An investigation of fast real-time GPU-based image blur algorithms\r\n *\r\n * Further modified according to Apple's\r\n * [Best Practices for Shaders](https://goo.gl/lmRoM5).\r\n */\n\nvar ConvolutionMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new convolution material.\r\n   *\r\n   * @param {Vector2} [texelSize] - The absolute screen texel size.\r\n   */\n  function ConvolutionMaterial() {\n    var _this;\n\n    var texelSize = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Vector2();\n\n    classCallCheck(this, ConvolutionMaterial);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(ConvolutionMaterial).call(this, {\n      type: \"ConvolutionMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        texelSize: new Uniform(new Vector2()),\n        halfTexelSize: new Uniform(new Vector2()),\n        kernel: new Uniform(0.0)\n      },\n      fragmentShader: fragment$4,\n      vertexShader: vertex$4,\n      depthWrite: false,\n      depthTest: false\n    }));\n\n    _this.setTexelSize(texelSize.x, texelSize.y);\n    /**\r\n     * The current kernel size.\r\n     *\r\n     * @type {KernelSize}\r\n     * @default KernelSize.LARGE\r\n     */\n\n\n    _this.kernelSize = KernelSize.LARGE;\n    return _this;\n  }\n  /**\r\n   * Returns the kernel.\r\n   *\r\n   * @return {Float32Array} The kernel.\r\n   */\n\n\n  createClass(ConvolutionMaterial, [{\n    key: \"getKernel\",\n    value: function getKernel() {\n      return kernelPresets[this.kernelSize];\n    }\n    /**\r\n     * Sets the texel size.\r\n     *\r\n     * @param {Number} x - The texel width.\r\n     * @param {Number} y - The texel height.\r\n     */\n\n  }, {\n    key: \"setTexelSize\",\n    value: function setTexelSize(x, y) {\n      this.uniforms.texelSize.value.set(x, y);\n      this.uniforms.halfTexelSize.value.set(x, y).multiplyScalar(0.5);\n    }\n  }]);\n\n  inherits(ConvolutionMaterial, _ShaderMaterial);\n\n  return ConvolutionMaterial;\n}(ShaderMaterial);\n/**\r\n * The Kawase blur kernel presets.\r\n *\r\n * @type {Float32Array[]}\r\n * @private\r\n */\n\nvar kernelPresets = [new Float32Array([0.0, 0.0]), new Float32Array([0.0, 1.0, 1.0]), new Float32Array([0.0, 1.0, 1.0, 2.0]), new Float32Array([0.0, 1.0, 2.0, 2.0, 3.0]), new Float32Array([0.0, 1.0, 2.0, 3.0, 4.0, 4.0, 5.0]), new Float32Array([0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 7.0, 8.0, 9.0, 10.0])];\n/**\r\n * A kernel size enumeration.\r\n *\r\n * @type {Object}\r\n * @property {Number} VERY_SMALL - A very small kernel that matches a 7x7 Gauss blur kernel.\r\n * @property {Number} SMALL - A small kernel that matches a 15x15 Gauss blur kernel.\r\n * @property {Number} MEDIUM - A medium sized kernel that matches a 23x23 Gauss blur kernel.\r\n * @property {Number} LARGE - A large kernel that matches a 35x35 Gauss blur kernel.\r\n * @property {Number} VERY_LARGE - A very large kernel that matches a 63x63 Gauss blur kernel.\r\n * @property {Number} HUGE - A huge kernel that matches a 127x127 Gauss blur kernel.\r\n */\n\nvar KernelSize = {\n  VERY_SMALL: 0,\n  SMALL: 1,\n  MEDIUM: 2,\n  LARGE: 3,\n  VERY_LARGE: 4,\n  HUGE: 5\n};\n\nvar fragment$5 = \"uniform sampler2D tDiffuse;\\r\\nuniform float opacity;\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec4 texel = texture2D(tDiffuse, vUv);\\r\\n\\tgl_FragColor = opacity * texel;\\r\\n\\r\\n}\\r\\n\";\nvar vertex$5 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A simple copy shader material.\r\n */\n\nvar CopyMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new copy material.\r\n   */\n  function CopyMaterial() {\n    classCallCheck(this, CopyMaterial);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(CopyMaterial).call(this, {\n      type: \"CopyMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        opacity: new Uniform(1.0)\n      },\n      fragmentShader: fragment$5,\n      vertexShader: vertex$5,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n\n  inherits(CopyMaterial, _ShaderMaterial);\n\n  return CopyMaterial;\n}(ShaderMaterial);\n\nvar fragment$6 = \"#include <packing>\\r\\n#include <clipping_planes_pars_fragment>\\r\\n\\r\\nuniform sampler2D tDepth;\\r\\nuniform float cameraNear;\\r\\nuniform float cameraFar;\\r\\n\\r\\nvarying float vViewZ;\\r\\nvarying vec4 vProjTexCoord;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\t#include <clipping_planes_fragment>\\r\\n\\r\\n\\t// Transform into Cartesian coordinate (not mirrored).\\r\\n\\tvec2 projTexCoord = (vProjTexCoord.xy / vProjTexCoord.w) * 0.5 + 0.5;\\r\\n\\tprojTexCoord = clamp(projTexCoord, 0.002, 0.998);\\r\\n\\r\\n\\tfloat fragCoordZ = unpackRGBAToDepth(texture2D(tDepth, projTexCoord));\\r\\n\\r\\n\\t#ifdef PERSPECTIVE_CAMERA\\r\\n\\r\\n\\t\\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tfloat viewZ = orthographicDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tfloat depthTest = (-vViewZ > -viewZ) ? 1.0 : 0.0;\\r\\n\\r\\n\\tgl_FragColor.rgb = vec3(0.0, depthTest, 1.0);\\r\\n\\r\\n}\\r\\n\";\nvar vertex$6 = \"#include <common>\\r\\n#include <morphtarget_pars_vertex>\\r\\n#include <skinning_pars_vertex>\\r\\n#include <clipping_planes_pars_vertex>\\r\\n\\r\\nvarying float vViewZ;\\r\\nvarying vec4 vProjTexCoord;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\t#include <skinbase_vertex>\\r\\n\\r\\n\\t#include <begin_vertex>\\r\\n\\t#include <morphtarget_vertex>\\r\\n\\t#include <skinning_vertex>\\r\\n\\t#include <project_vertex>\\r\\n\\r\\n\\tvViewZ = mvPosition.z;\\r\\n\\tvProjTexCoord = gl_Position;\\r\\n\\r\\n\\t#include <clipping_planes_vertex>\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A depth comparison shader material.\r\n */\n\nvar DepthComparisonMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new depth comparison material.\r\n   *\r\n   * @param {Texture} [depthTexture=null] - A depth texture.\r\n   * @param {PerspectiveCamera} [camera] - A camera.\r\n   */\n  function DepthComparisonMaterial() {\n    var _this;\n\n    var depthTexture = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n    var camera = arguments.length > 1 ? arguments[1] : undefined;\n\n    classCallCheck(this, DepthComparisonMaterial);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(DepthComparisonMaterial).call(this, {\n      type: \"DepthComparisonMaterial\",\n      uniforms: {\n        tDepth: new Uniform(depthTexture),\n        cameraNear: new Uniform(0.1),\n        cameraFar: new Uniform(2000)\n      },\n      fragmentShader: fragment$6,\n      vertexShader: vertex$6,\n      depthWrite: false,\n      depthTest: false,\n      morphTargets: true,\n      skinning: true\n    }));\n\n    _this.adoptCameraSettings(camera);\n\n    return _this;\n  }\n  /**\r\n   * Adopts the settings of the given camera.\r\n   *\r\n   * @param {Camera} [camera=null] - A camera.\r\n   */\n\n\n  createClass(DepthComparisonMaterial, [{\n    key: \"adoptCameraSettings\",\n    value: function adoptCameraSettings() {\n      var camera = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n\n      if (camera !== null) {\n        this.uniforms.cameraNear.value = camera.near;\n        this.uniforms.cameraFar.value = camera.far;\n\n        if (camera instanceof PerspectiveCamera) {\n          this.defines.PERSPECTIVE_CAMERA = \"1\";\n        } else {\n          delete this.defines.PERSPECTIVE_CAMERA;\n        }\n      }\n    }\n  }]);\n\n  inherits(DepthComparisonMaterial, _ShaderMaterial);\n\n  return DepthComparisonMaterial;\n}(ShaderMaterial);\n\nvar fragment$7 = \"uniform sampler2D tDiffuse;\\r\\n\\r\\nuniform float angle;\\r\\nuniform float scale;\\r\\nuniform float intensity;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying vec2 vUvPattern;\\r\\n\\r\\nfloat pattern() {\\r\\n\\r\\n\\tfloat s = sin(angle);\\r\\n\\tfloat c = cos(angle);\\r\\n\\r\\n\\tvec2 point = vec2(c * vUvPattern.x - s * vUvPattern.y, s * vUvPattern.x + c * vUvPattern.y) * scale;\\r\\n\\r\\n\\treturn (sin(point.x) * sin(point.y)) * 4.0;\\r\\n\\r\\n}\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec4 texel = texture2D(tDiffuse, vUv);\\r\\n\\tvec3 color = texel.rgb;\\r\\n\\r\\n\\t#ifdef AVERAGE\\r\\n\\r\\n\\t\\tcolor = vec3((color.r + color.g + color.b) / 3.0);\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tcolor = vec3(color * 10.0 - 5.0 + pattern());\\r\\n\\tcolor = texel.rgb + (color - texel.rgb) * intensity;\\r\\n\\r\\n\\tgl_FragColor = vec4(color, texel.a);\\r\\n\\r\\n}\\r\\n\";\nvar vertex$7 = \"uniform vec4 offsetRepeat;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying vec2 vUvPattern;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tvUvPattern = uv * offsetRepeat.zw + offsetRepeat.xy;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A dot screen shader material.\r\n */\n\nvar DotScreenMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new dot screen material.\r\n   *\r\n   * @param {Boolean} [options] - The options.\r\n   * @param {Boolean} [options.average=false] - Whether the shader should output the colour average (black and white).\r\n   * @param {Boolean} [options.angle=1.57] - The angle of the dot pattern.\r\n   * @param {Boolean} [options.scale=1.0] - The scale of the dot pattern.\r\n   * @param {Boolean} [options.intensity=1.0] - The intensity of the effect.\r\n   */\n  function DotScreenMaterial() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, DotScreenMaterial);\n\n    var settings = Object.assign({\n      average: false,\n      angle: 1.57,\n      scale: 1.0,\n      intensity: 1.0\n    }, options);\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(DotScreenMaterial).call(this, {\n      type: \"DotScreenMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        angle: new Uniform(settings.angle),\n        scale: new Uniform(settings.scale),\n        intensity: new Uniform(settings.intensity),\n        offsetRepeat: new Uniform(new Vector4(0.5, 0.5, 1.0, 1.0))\n      },\n      fragmentShader: fragment$7,\n      vertexShader: vertex$7,\n      depthWrite: false,\n      depthTest: false\n    }));\n\n    _this.setAverageEnabled(settings.average);\n\n    return _this;\n  }\n  /**\r\n   * Enables or disables the Screen blend mode.\r\n   *\r\n   * @param {Boolean} enabled - Whether the Screen blend mode should be enabled.\r\n   */\n\n\n  createClass(DotScreenMaterial, [{\n    key: \"setAverageEnabled\",\n    value: function setAverageEnabled(enabled) {\n      if (enabled) {\n        this.defines.AVERAGE = \"1\";\n      } else {\n        delete this.defines.AVERAGE;\n      }\n\n      this.needsUpdate = true;\n    }\n  }]);\n\n  inherits(DotScreenMaterial, _ShaderMaterial);\n\n  return DotScreenMaterial;\n}(ShaderMaterial);\n\nvar fragment$8 = \"uniform sampler2D tDiffuse;\\r\\nuniform float time;\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\n#ifdef NOISE\\r\\n\\r\\n\\tuniform float noiseIntensity;\\r\\n\\r\\n#endif\\r\\n\\r\\n#ifdef SCANLINES\\r\\n\\r\\n\\tuniform float scanlineIntensity;\\r\\n\\tuniform float scanlineCount;\\r\\n\\r\\n#endif\\r\\n\\r\\n#ifdef GRID\\r\\n\\r\\n\\tuniform float gridIntensity;\\r\\n\\tuniform vec2 gridScale;\\r\\n\\tuniform float gridLineWidth;\\r\\n\\r\\n#endif\\r\\n\\r\\n#ifdef GREYSCALE\\r\\n\\r\\n\\t#include <common>\\r\\n\\r\\n\\tuniform float greyscaleIntensity;\\r\\n\\r\\n#elif defined(SEPIA)\\r\\n\\r\\n\\tuniform float sepiaIntensity;\\r\\n\\r\\n#endif\\r\\n\\r\\n#ifdef VIGNETTE\\r\\n\\r\\n\\tuniform float vignetteOffset;\\r\\n\\tuniform float vignetteDarkness;\\r\\n\\r\\n#endif\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec4 texel = texture2D(tDiffuse, vUv);\\r\\n\\tvec3 color = texel.rgb;\\r\\n\\r\\n\\t#ifdef SCREEN_MODE\\r\\n\\r\\n\\t\\tvec3 invColor;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t#ifdef NOISE\\r\\n\\r\\n\\t\\tfloat x = vUv.x * vUv.y * time * 1000.0;\\r\\n\\t\\tx = mod(x, 13.0) * mod(x, 123.0);\\r\\n\\t\\tx = mod(x, 0.01);\\r\\n\\r\\n\\t\\tvec3 noise = texel.rgb * clamp(0.1 + x * 100.0, 0.0, 1.0) * noiseIntensity;\\r\\n\\r\\n\\t\\t#ifdef SCREEN_MODE\\r\\n\\r\\n\\t\\t\\tinvColor = vec3(1.0) - color;\\r\\n\\t\\t\\tvec3 invNoise = vec3(1.0) - noise;\\r\\n\\r\\n\\t\\t\\tcolor = vec3(1.0) - invColor * invNoise;\\r\\n\\r\\n\\t\\t#else\\r\\n\\r\\n\\t\\t\\tcolor += noise;\\r\\n\\r\\n\\t\\t#endif\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t#ifdef SCANLINES\\r\\n\\r\\n\\t\\tvec2 sl = vec2(sin(vUv.y * scanlineCount), cos(vUv.y * scanlineCount));\\r\\n\\t\\tvec3 scanlines = texel.rgb * vec3(sl.x, sl.y, sl.x) * scanlineIntensity;\\r\\n\\r\\n\\t\\t#ifdef SCREEN_MODE\\r\\n\\r\\n\\t\\t\\tinvColor = vec3(1.0) - color;\\r\\n\\t\\t\\tvec3 invScanlines = vec3(1.0) - scanlines;\\r\\n\\r\\n\\t\\t\\tcolor = vec3(1.0) - invColor * invScanlines;\\r\\n\\r\\n\\t\\t#else\\r\\n\\r\\n\\t\\t\\tcolor += scanlines;\\r\\n\\r\\n\\t\\t#endif\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t#ifdef GRID\\r\\n\\r\\n\\t\\tfloat grid = 0.5 - max(abs(mod(vUv.x * gridScale.x, 1.0) - 0.5), abs(mod(vUv.y * gridScale.y, 1.0) - 0.5));\\r\\n\\t\\tcolor *= (1.0 - gridIntensity) + vec3(smoothstep(0.0, gridLineWidth, grid)) * gridIntensity;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t#ifdef GREYSCALE\\r\\n\\r\\n\\t\\tcolor = mix(color, vec3(linearToRelativeLuminance(color)), greyscaleIntensity);\\r\\n\\r\\n\\t#elif defined(SEPIA)\\r\\n\\r\\n\\t\\tvec3 c = color.rgb;\\r\\n\\r\\n\\t\\tcolor.r = dot(c, vec3(1.0 - 0.607 * sepiaIntensity, 0.769 * sepiaIntensity, 0.189 * sepiaIntensity));\\r\\n\\t\\tcolor.g = dot(c, vec3(0.349 * sepiaIntensity, 1.0 - 0.314 * sepiaIntensity, 0.168 * sepiaIntensity));\\r\\n\\t\\tcolor.b = dot(c, vec3(0.272 * sepiaIntensity, 0.534 * sepiaIntensity, 1.0 - 0.869 * sepiaIntensity));\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t#ifdef VIGNETTE\\r\\n\\r\\n\\t\\tconst vec2 center = vec2(0.5);\\r\\n\\r\\n\\t\\t#ifdef ESKIL\\r\\n\\r\\n\\t\\t\\tvec2 uv = (vUv - center) * vec2(vignetteOffset);\\r\\n\\t\\t\\tcolor = mix(color.rgb, vec3(1.0 - vignetteDarkness), dot(uv, uv));\\r\\n\\r\\n\\t\\t#else\\r\\n\\r\\n\\t\\t\\tfloat dist = distance(vUv, center);\\r\\n\\t\\t\\tcolor *= smoothstep(0.8, vignetteOffset * 0.799, dist * (vignetteDarkness + vignetteOffset));\\r\\n\\r\\n\\t\\t#endif\\t\\t\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tgl_FragColor = vec4(clamp(color, 0.0, 1.0), texel.a);\\r\\n\\r\\n}\\r\\n\";\nvar vertex$8 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A cinematic shader that provides the following effects:\r\n *  - Film Grain\r\n *  - Scanlines\r\n *  - Vignette\r\n *  - Greyscale\r\n *  - Sepia\r\n *\r\n * Original scanlines algorithm by Pat \"Hawthorne\" Shearon.\r\n *  http://www.truevision3d.com/forums/showcase/staticnoise_colorblackwhite_scanline_shaders-t18698.0.html\r\n *\r\n * Optimised scanlines and noise with intensity scaling by Georg \"Leviathan\"\r\n * Steinrohder. This version was provided under a Creative Commons Attribution\r\n * 3.0 License: http://creativecommons.org/licenses/by/3.0.\r\n *\r\n * The sepia effect is based on:\r\n *  https://github.com/evanw/glfx.js\r\n *\r\n * The vignette code is based on PaintEffect postprocess from ro.me:\r\n *  http://code.google.com/p/3-dreams-of-black/source/browse/deploy/js/effects/PaintEffect.js\r\n */\n\nvar FilmMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new film material.\r\n   *\r\n   * @param {Object} [options] - The options. Disabled effects will not be included in the final shader and have no negative impact on performance.\r\n   * @param {Boolean} [options.greyscale=false] - Enable greyscale effect. Greyscale and sepia are mutually exclusive.\r\n   * @param {Boolean} [options.sepia=false] - Enable sepia effect. Greyscale and sepia are mutually exclusive.\r\n   * @param {Boolean} [options.vignette=false] - Apply vignette effect.\r\n   * @param {Boolean} [options.eskil=false] - Use Eskil's vignette approach. The default looks dusty while Eskil looks burned out.\r\n   * @param {Boolean} [options.screenMode=true] - Whether the screen blend mode should be used for noise and scanlines. Both of these effects are computed independently.\r\n   * @param {Boolean} [options.noise=true] - Show noise-based film grain.\r\n   * @param {Boolean} [options.scanlines=true] - Show scanlines.\r\n   * @param {Boolean} [options.grid=true] - Show a grid.\r\n   * @param {Number} [options.noiseIntensity=0.5] - The noise intensity.\r\n   * @param {Number} [options.scanlineIntensity=0.05] - The scanline intensity.\r\n   * @param {Number} [options.gridIntensity=1.0] - The grid strength. 0.0 to 1.0.\r\n   * @param {Number} [options.greyscaleIntensity=1.0] - The intensity of the greyscale effect. 0.0 to 1.0.\r\n   * @param {Number} [options.sepiaIntensity=1.0] - The intensity of the sepia effect. 0.0 to 1.0.\r\n   * @param {Number} [options.vignetteOffset=1.0] - The offset of the vignette effect. 0.0 to 1.0.\r\n   * @param {Number} [options.vignetteDarkness=1.0] - The darkness of the vignette effect. 0.0 to 1.0.\r\n   */\n  function FilmMaterial() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, FilmMaterial);\n\n    var settings = Object.assign({\n      screenMode: true,\n      noise: true,\n      scanlines: true,\n      grid: false,\n      greyscale: false,\n      sepia: false,\n      vignette: false,\n      eskil: false,\n      noiseIntensity: 0.5,\n      scanlineIntensity: 0.05,\n      gridIntensity: 1.0,\n      greyscaleIntensity: 1.0,\n      sepiaIntensity: 1.0,\n      vignetteOffset: 1.0,\n      vignetteDarkness: 1.0\n    }, options);\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(FilmMaterial).call(this, {\n      type: \"FilmMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        time: new Uniform(0.0),\n        noiseIntensity: new Uniform(settings.noiseIntensity),\n        scanlineIntensity: new Uniform(settings.scanlineIntensity),\n        gridIntensity: new Uniform(settings.gridIntensity),\n        scanlineCount: new Uniform(0.0),\n        gridScale: new Uniform(new Vector2()),\n        gridLineWidth: new Uniform(0.0),\n        greyscaleIntensity: new Uniform(settings.greyscaleIntensity),\n        sepiaIntensity: new Uniform(settings.sepiaIntensity),\n        vignetteOffset: new Uniform(settings.vignetteOffset),\n        vignetteDarkness: new Uniform(settings.vignetteDarkness)\n      },\n      fragmentShader: fragment$8,\n      vertexShader: vertex$8,\n      depthWrite: false,\n      depthTest: false\n    }));\n\n    _this.setScreenModeEnabled(settings.screenMode);\n\n    _this.setNoiseEnabled(settings.noise);\n\n    _this.setScanlinesEnabled(settings.scanlines);\n\n    _this.setGridEnabled(settings.grid);\n\n    _this.setGreyscaleEnabled(settings.greyscale);\n\n    _this.setSepiaEnabled(settings.sepia);\n\n    _this.setVignetteEnabled(settings.vignette);\n\n    _this.setEskilEnabled(settings.eskil);\n\n    return _this;\n  }\n  /**\r\n   * Enables or disables the Screen blend mode.\r\n   *\r\n   * @param {Boolean} enabled - Whether the Screen blend mode should be enabled.\r\n   */\n\n\n  createClass(FilmMaterial, [{\n    key: \"setScreenModeEnabled\",\n    value: function setScreenModeEnabled(enabled) {\n      if (enabled) {\n        this.defines.SCREEN_MODE = \"1\";\n      } else {\n        delete this.defines.SCREEN_MODE;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Enables or disables the noise effect.\r\n     *\r\n     * @param {Boolean} enabled - Whether the noise effect should be enabled.\r\n     */\n\n  }, {\n    key: \"setNoiseEnabled\",\n    value: function setNoiseEnabled(enabled) {\n      if (enabled) {\n        this.defines.NOISE = \"1\";\n      } else {\n        delete this.defines.NOISE;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Enables or disables the scanlines effect.\r\n     *\r\n     * @param {Boolean} enabled - Whether the scanlines effect should be enabled.\r\n     */\n\n  }, {\n    key: \"setScanlinesEnabled\",\n    value: function setScanlinesEnabled(enabled) {\n      if (enabled) {\n        this.defines.SCANLINES = \"1\";\n      } else {\n        delete this.defines.SCANLINES;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Enables or disables the grid effect.\r\n     *\r\n     * @param {Boolean} enabled - Whether the grid effect should be enabled.\r\n     */\n\n  }, {\n    key: \"setGridEnabled\",\n    value: function setGridEnabled(enabled) {\n      if (enabled) {\n        this.defines.GRID = \"1\";\n      } else {\n        delete this.defines.GRID;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Enables or disables the greyscale effect.\r\n     *\r\n     * @param {Boolean} enabled - Whether the greyscale effect should be enabled.\r\n     */\n\n  }, {\n    key: \"setGreyscaleEnabled\",\n    value: function setGreyscaleEnabled(enabled) {\n      if (enabled) {\n        this.defines.GREYSCALE = \"1\";\n      } else {\n        delete this.defines.GREYSCALE;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Enables or disables the sepia effect.\r\n     *\r\n     * @param {Boolean} enabled - Whether the sepia effect should be enabled.\r\n     */\n\n  }, {\n    key: \"setSepiaEnabled\",\n    value: function setSepiaEnabled(enabled) {\n      if (enabled) {\n        this.defines.SEPIA = \"1\";\n      } else {\n        delete this.defines.SEPIA;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Enables or disables the Vignette effect.\r\n     *\r\n     * @param {Boolean} enabled - Whether the Vignette effect should be enabled.\r\n     */\n\n  }, {\n    key: \"setVignetteEnabled\",\n    value: function setVignetteEnabled(enabled) {\n      if (enabled) {\n        this.defines.VIGNETTE = \"1\";\n      } else {\n        delete this.defines.VIGNETTE;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Enables or disables the Eskil Vignette effect.\r\n     *\r\n     * Has no effect if Vignette is disabled.\r\n     *\r\n     * @param {Boolean} enabled - Whether the Eskil Vignette effect should be enabled.\r\n     */\n\n  }, {\n    key: \"setEskilEnabled\",\n    value: function setEskilEnabled(enabled) {\n      if (enabled) {\n        this.defines.ESKIL = \"1\";\n      } else {\n        delete this.defines.ESKIL;\n      }\n\n      this.needsUpdate = true;\n    }\n  }]);\n\n  inherits(FilmMaterial, _ShaderMaterial);\n\n  return FilmMaterial;\n}(ShaderMaterial);\n\nvar fragment$9 = \"uniform sampler2D tDiffuse;\\r\\nuniform sampler2D tPerturb;\\r\\n\\r\\nuniform bool active;\\r\\n\\r\\nuniform float amount;\\r\\nuniform float angle;\\r\\nuniform float seed;\\r\\nuniform float seedX;\\r\\nuniform float seedY;\\r\\nuniform float distortionX;\\r\\nuniform float distortionY;\\r\\nuniform float colS;\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nfloat rand(vec2 tc) {\\r\\n\\r\\n\\tconst float a = 12.9898;\\r\\n\\tconst float b = 78.233;\\r\\n\\tconst float c = 43758.5453;\\r\\n\\r\\n\\tfloat dt = dot(tc, vec2(a, b));\\r\\n\\tfloat sn = mod(dt, 3.14);\\r\\n\\r\\n\\treturn fract(sin(sn) * c);\\r\\n\\r\\n}\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec2 coord = vUv;\\r\\n\\r\\n\\tfloat xs, ys;\\r\\n\\tvec4 normal;\\r\\n\\r\\n\\tvec2 offset;\\r\\n\\tvec4 cr, cga, cb;\\r\\n\\tvec4 snow, color;\\r\\n\\r\\n\\tfloat sx, sy;\\r\\n\\r\\n\\tif(active) {\\r\\n\\r\\n\\t\\txs = floor(gl_FragCoord.x / 0.5);\\r\\n\\t\\tys = floor(gl_FragCoord.y / 0.5);\\r\\n\\r\\n\\t\\tnormal = texture2D(tPerturb, coord * seed * seed);\\r\\n\\r\\n\\t\\tif(coord.y < distortionX + colS && coord.y > distortionX - colS * seed) {\\r\\n\\r\\n\\t\\t\\tsx = clamp(ceil(seedX), 0.0, 1.0);\\r\\n\\t\\t\\tcoord.y = sx * (1.0 - (coord.y + distortionY)) + (1.0 - sx) * distortionY;\\r\\n\\r\\n\\t\\t}\\r\\n\\r\\n\\t\\tif(coord.x < distortionY + colS && coord.x > distortionY - colS * seed) {\\r\\n\\r\\n\\t\\t\\tsy = clamp(ceil(seedY), 0.0, 1.0);\\r\\n\\t\\t\\tcoord.x = sy * distortionX + (1.0 - sy) * (1.0 - (coord.x + distortionX));\\r\\n\\r\\n\\t\\t}\\r\\n\\r\\n\\t\\tcoord.x += normal.x * seedX * (seed / 5.0);\\r\\n\\t\\tcoord.y += normal.y * seedY * (seed / 5.0);\\r\\n\\r\\n\\t\\toffset = amount * vec2(cos(angle), sin(angle));\\r\\n\\r\\n\\t\\tcr = texture2D(tDiffuse, coord + offset);\\r\\n\\t\\tcga = texture2D(tDiffuse, coord);\\r\\n\\t\\tcb = texture2D(tDiffuse, coord - offset);\\r\\n\\r\\n\\t\\tcolor = vec4(cr.r, cga.g, cb.b, cga.a);\\r\\n\\t\\tsnow = 200.0 * amount * vec4(rand(vec2(xs * seed, ys * seed * 50.0)) * 0.2);\\r\\n\\t\\tcolor += snow;\\r\\n\\r\\n\\t} else {\\r\\n\\r\\n\\t\\tcolor = texture2D(tDiffuse, vUv);\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\tgl_FragColor = color;\\r\\n\\r\\n}\\r\\n\";\nvar vertex$9 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A glitch shader material.\r\n *\r\n * Reference:\r\n *  https://github.com/staffantan/unityglitch\r\n */\n\nvar GlitchMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new glitch material.\r\n   */\n  function GlitchMaterial() {\n    classCallCheck(this, GlitchMaterial);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(GlitchMaterial).call(this, {\n      type: \"GlitchMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        tPerturb: new Uniform(null),\n        active: new Uniform(1),\n        amount: new Uniform(0.8),\n        angle: new Uniform(0.02),\n        seed: new Uniform(0.02),\n        seedX: new Uniform(0.02),\n        seedY: new Uniform(0.02),\n        distortionX: new Uniform(0.5),\n        distortionY: new Uniform(0.6),\n        colS: new Uniform(0.05)\n      },\n      fragmentShader: fragment$9,\n      vertexShader: vertex$9,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n\n  inherits(GlitchMaterial, _ShaderMaterial);\n\n  return GlitchMaterial;\n}(ShaderMaterial);\n\nvar fragment$10 = \"#include <common>\\r\\n#include <dithering_pars_fragment>\\r\\n\\r\\nuniform sampler2D tDiffuse;\\r\\nuniform vec3 lightPosition;\\r\\n\\r\\nuniform float exposure;\\r\\nuniform float decay;\\r\\nuniform float density;\\r\\nuniform float weight;\\r\\nuniform float clampMax;\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec2 texCoord = vUv;\\r\\n\\r\\n\\t// Calculate vector from pixel to light source in screen space.\\r\\n\\tvec2 deltaTexCoord = texCoord - lightPosition.st;\\r\\n\\tdeltaTexCoord *= 1.0 / NUM_SAMPLES_FLOAT * density;\\r\\n\\r\\n\\t// A decreasing illumination factor.\\r\\n\\tfloat illuminationDecay = 1.0;\\r\\n\\r\\n\\tvec4 sample;\\r\\n\\tvec4 color = vec4(0.0);\\r\\n\\r\\n\\t// Estimate the probability of occlusion at each pixel by summing samples along a ray to the light source.\\r\\n\\tfor(int i = 0; i < NUM_SAMPLES_INT; ++i) {\\r\\n\\r\\n\\t\\ttexCoord -= deltaTexCoord;\\r\\n\\t\\tsample = texture2D(tDiffuse, texCoord);\\r\\n\\r\\n\\t\\t// Apply sample attenuation scale/decay factors.\\r\\n\\t\\tsample *= illuminationDecay * weight;\\r\\n\\r\\n\\t\\tcolor += sample;\\r\\n\\r\\n\\t\\t// Update exponential decay factor.\\r\\n\\t\\tilluminationDecay *= decay;\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\tgl_FragColor = clamp(color * exposure, 0.0, clampMax);\\r\\n\\r\\n\\t#include <dithering_fragment>\\r\\n\\r\\n}\\r\\n\";\nvar vertex$10 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A crepuscular rays shader material.\r\n *\r\n * This material supports dithering.\r\n *\r\n * References:\r\n *\r\n * Thibaut Despoulain, 2012:\r\n *  [(WebGL) Volumetric Light Approximation in Three.js](\r\n *  http://bkcore.com/blog/3d/webgl-three-js-volumetric-light-godrays.html)\r\n *\r\n * Nvidia, GPU Gems 3, 2008:\r\n *  [Chapter 13. Volumetric Light Scattering as a Post-Process](\r\n *  https://developer.nvidia.com/gpugems/GPUGems3/gpugems3_ch13.html)\r\n */\n\nvar GodRaysMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new god rays material.\r\n   *\r\n   * @param {Object} [options] - The options.\r\n   * @param {Number} [options.density=0.96] - The density of the light rays.\r\n   * @param {Number} [options.decay=0.93] - An illumination decay factor.\r\n   * @param {Number} [options.weight=0.4] - A light ray weight factor.\r\n   * @param {Number} [options.exposure=0.6] - A constant attenuation coefficient.\r\n   * @param {Number} [options.clampMax=1.0] - An upper bound for the saturation of the overall effect.\r\n   */\n  function GodRaysMaterial() {\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, GodRaysMaterial);\n\n    var settings = Object.assign({\n      exposure: 0.6,\n      density: 0.93,\n      decay: 0.96,\n      weight: 0.4,\n      clampMax: 1.0\n    }, options);\n    return possibleConstructorReturn(this, getPrototypeOf$2(GodRaysMaterial).call(this, {\n      type: \"GodRaysMaterial\",\n      defines: {\n        NUM_SAMPLES_FLOAT: \"60.0\",\n        NUM_SAMPLES_INT: \"60\"\n      },\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        lightPosition: new Uniform(null),\n        exposure: new Uniform(settings.exposure),\n        decay: new Uniform(settings.decay),\n        density: new Uniform(settings.density),\n        weight: new Uniform(settings.weight),\n        clampMax: new Uniform(settings.clampMax)\n      },\n      fragmentShader: fragment$10,\n      vertexShader: vertex$10,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n\n  inherits(GodRaysMaterial, _ShaderMaterial);\n\n  return GodRaysMaterial;\n}(ShaderMaterial);\n\nvar fragment$11 = \"#include <common>\\r\\n\\r\\nuniform sampler2D tDiffuse;\\r\\nuniform float distinction;\\r\\nuniform vec2 range;\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec4 texel = texture2D(tDiffuse, vUv);\\r\\n\\tfloat l = linearToRelativeLuminance(texel.rgb);\\r\\n\\r\\n\\t#ifdef RANGE\\r\\n\\r\\n\\t\\tfloat low = step(range.x, l);\\r\\n\\t\\tfloat high = step(l, range.y);\\r\\n\\r\\n\\t\\t// Apply the mask.\\r\\n\\t\\tl *= low * high;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tl = pow(abs(l), distinction);\\r\\n\\r\\n\\t#ifdef COLOR\\r\\n\\r\\n\\t\\tgl_FragColor = vec4(texel.rgb * l, texel.a);\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tgl_FragColor = vec4(l, l, l, texel.a);\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n}\\r\\n\";\nvar vertex$11 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A luminosity shader material.\r\n *\r\n * This shader produces a greyscale luminance map that describes the absolute\r\n * amount of light emitted by a scene. It can also be configured to output\r\n * colours that are scaled with their respective luminance value. Additionally,\r\n * a range may be provided to mask out undesired texels.\r\n *\r\n * The alpha channel will remain unaffected in all cases.\r\n *\r\n * On luminance coefficients:\r\n *  http://www.poynton.com/notes/colour_and_gamma/ColorFAQ.html#RTFToC9\r\n *\r\n * Coefficients for different colour spaces:\r\n *  https://hsto.org/getpro/habr/post_images/2ab/69d/084/2ab69d084f9a597e032624bcd74d57a7.png\r\n *\r\n * Luminance range reference:\r\n *  https://cycling74.com/2007/05/23/your-first-shader/#.Vty9FfkrL4Z\r\n */\n\nvar LuminosityMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new luminosity material.\r\n   *\r\n   * @param {Boolean} [colorOutput=false] - Defines whether the shader should output colours scaled with their luminance value.\r\n   * @param {Vector2} [luminanceRange] - If provided, the shader will mask out texels that aren't in the specified luminance range.\r\n   */\n  function LuminosityMaterial() {\n    var _this;\n\n    var colorOutput = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n    var luminanceRange = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n\n    classCallCheck(this, LuminosityMaterial);\n\n    var maskLuminance = luminanceRange !== null;\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(LuminosityMaterial).call(this, {\n      type: \"LuminosityMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        distinction: new Uniform(1.0),\n        range: new Uniform(maskLuminance ? luminanceRange : new Vector2())\n      },\n      fragmentShader: fragment$11,\n      vertexShader: vertex$11\n    }));\n\n    _this.setColorOutputEnabled(colorOutput);\n\n    _this.setLuminanceRangeEnabled(maskLuminance);\n\n    return _this;\n  }\n  /**\r\n   * Enables or disables color output.\r\n   *\r\n   * @param {Boolean} enabled - Whether color output should be enabled.\r\n   */\n\n\n  createClass(LuminosityMaterial, [{\n    key: \"setColorOutputEnabled\",\n    value: function setColorOutputEnabled(enabled) {\n      if (enabled) {\n        this.defines.COLOR = \"1\";\n      } else {\n        delete this.defines.COLOR;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Enables or disables the luminance mask.\r\n     *\r\n     * @param {Boolean} enabled - Whether the luminance mask should be enabled.\r\n     */\n\n  }, {\n    key: \"setLuminanceRangeEnabled\",\n    value: function setLuminanceRangeEnabled(enabled) {\n      if (enabled) {\n        this.defines.RANGE = \"1\";\n      } else {\n        delete this.defines.RANGE;\n      }\n\n      this.needsUpdate = true;\n    }\n  }]);\n\n  inherits(LuminosityMaterial, _ShaderMaterial);\n\n  return LuminosityMaterial;\n}(ShaderMaterial);\n\nvar fragment$12 = \"uniform sampler2D tDiffuse;\\r\\nuniform sampler2D tMask;\\r\\nuniform sampler2D tEdges;\\r\\n\\r\\nuniform vec3 visibleEdgeColor;\\r\\nuniform vec3 hiddenEdgeColor;\\r\\nuniform float pulse;\\r\\nuniform float edgeStrength;\\r\\n\\r\\n#ifdef USE_PATTERN\\r\\n\\r\\n\\tuniform sampler2D tPattern;\\r\\n\\tvarying vec2 vPatternCoord;\\r\\n\\r\\n#endif\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec4 color = texture2D(tDiffuse, vUv);\\r\\n\\tvec2 edge = texture2D(tEdges, vUv).rg;\\r\\n\\tvec2 mask = texture2D(tMask, vUv).rg;\\r\\n\\r\\n\\t#ifndef X_RAY\\r\\n\\r\\n\\t\\tedge.y = 0.0;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tedge *= (edgeStrength * mask.x * pulse);\\r\\n\\tvec3 outlineColor = edge.x * visibleEdgeColor + edge.y * hiddenEdgeColor;\\r\\n\\r\\n\\t#ifdef ALPHA_BLENDING\\r\\n\\r\\n\\t\\tcolor.rgb = mix(color.rgb, outlineColor, max(edge.x, edge.y));\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tcolor.rgb += outlineColor;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t#ifdef USE_PATTERN\\r\\n\\r\\n\\t\\tvec3 patternColor = texture2D(tPattern, vPatternCoord).rgb;\\r\\n\\r\\n\\t\\t#ifdef X_RAY\\r\\n\\r\\n\\t\\t\\tfloat hiddenFactor = 0.5;\\r\\n\\r\\n\\t\\t#else\\r\\n\\r\\n\\t\\t\\tfloat hiddenFactor = 0.0;\\r\\n\\r\\n\\t\\t#endif\\r\\n\\r\\n\\t\\tfloat visibilityFactor = (1.0 - mask.y > 0.0) ? 1.0 : hiddenFactor;\\r\\n\\r\\n\\t\\tcolor.rgb += visibilityFactor * (1.0 - mask.x) * (1.0 - patternColor);\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tgl_FragColor = color;\\r\\n\\r\\n}\\r\\n\";\nvar vertex$12 = \"#ifdef USE_PATTERN\\r\\n\\r\\n\\tuniform float aspect;\\r\\n\\tuniform float patternScale;\\r\\n\\tvarying vec2 vPatternCoord;\\r\\n\\r\\n#endif\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\t#ifdef USE_PATTERN\\r\\n\\r\\n\\t\\tvec2 aspectCorrection = vec2(aspect, 1.0);\\r\\n\\t\\tvPatternCoord = uv * aspectCorrection * patternScale;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * An outline blend shader material.\r\n */\n\nvar OutlineBlendMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new outline blend material.\r\n   *\r\n   * @param {Object} [options] - The options.\r\n   * @param {Number} [options.edgeStrength=1.0] - The edge strength.\r\n   * @param {Number} [options.patternScale=1.0] - The scale of the pattern texture.\r\n   * @param {Number} [options.visibleEdgeColor=0xffffff] - The color of visible edges.\r\n   * @param {Number} [options.hiddenEdgeColor=0x22090A] - The color of hidden edges.\r\n   * @param {Boolean} [alphaBlending=false] - Whether the outline should be blended using alpha.\r\n   * @param {Boolean} [xRay=true] - Whether hidden parts of selected objects should be visible.\r\n   */\n  function OutlineBlendMaterial() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, OutlineBlendMaterial);\n\n    var settings = Object.assign({\n      edgeStrength: 1.0,\n      patternScale: 1.0,\n      visibleEdgeColor: 0xffffff,\n      hiddenEdgeColor: 0x22090A,\n      alphaBlending: false,\n      xRay: true\n    }, options);\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(OutlineBlendMaterial).call(this, {\n      type: \"OutlineBlendMaterial\",\n      uniforms: {\n        pulse: new Uniform(1.0),\n        aspect: new Uniform(1.0),\n        tDiffuse: new Uniform(null),\n        tMask: new Uniform(null),\n        tEdges: new Uniform(null),\n        tPattern: new Uniform(null),\n        edgeStrength: new Uniform(settings.edgeStrength),\n        patternScale: new Uniform(settings.patternScale),\n        visibleEdgeColor: new Uniform(new Color(settings.visibleEdgeColor)),\n        hiddenEdgeColor: new Uniform(new Color(settings.hiddenEdgeColor))\n      },\n      fragmentShader: fragment$12,\n      vertexShader: vertex$12,\n      depthWrite: false,\n      depthTest: false\n    }));\n\n    _this.setAlphaBlendingEnabled(settings.alphaBlending);\n\n    _this.setXRayEnabled(settings.xRay);\n\n    return _this;\n  }\n  /**\r\n   * Enables or disables the alpha blending.\r\n   *\r\n   * @param {Boolean} enabled - Whether the alpha blending should be enabled.\r\n   */\n\n\n  createClass(OutlineBlendMaterial, [{\n    key: \"setAlphaBlendingEnabled\",\n    value: function setAlphaBlendingEnabled(enabled) {\n      if (enabled) {\n        this.defines.ALPHA_BLENDING = \"1\";\n      } else {\n        delete this.defines.ALPHA_BLENDING;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Defines whether hidden parts of selected objects should be visible.\r\n     *\r\n     * @param {Boolean} enabled - Whether hidden parts of selected objects should be visible.\r\n     */\n\n  }, {\n    key: \"setXRayEnabled\",\n    value: function setXRayEnabled(enabled) {\n      if (enabled) {\n        this.defines.X_RAY = \"1\";\n      } else {\n        delete this.defines.X_RAY;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Sets a pattern texture to use as overlay.\r\n     *\r\n     * @param {Texture} [texture=null] - A pattern texture. Set to null to disable the pattern.\r\n     */\n\n  }, {\n    key: \"setPatternTexture\",\n    value: function setPatternTexture() {\n      var texture = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n\n      if (texture !== null) {\n        this.defines.USE_PATTERN = \"1\";\n      } else {\n        delete this.defines.USE_PATTERN;\n      }\n\n      this.uniforms.tPattern.value = texture;\n      this.needsUpdate = true;\n    }\n  }]);\n\n  inherits(OutlineBlendMaterial, _ShaderMaterial);\n\n  return OutlineBlendMaterial;\n}(ShaderMaterial);\n\nvar fragment$13 = \"uniform sampler2D tMask;\\r\\n\\r\\nvarying vec2 vUv0;\\r\\nvarying vec2 vUv1;\\r\\nvarying vec2 vUv2;\\r\\nvarying vec2 vUv3;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec2 c0 = texture2D(tMask, vUv0).rg;\\r\\n\\tvec2 c1 = texture2D(tMask, vUv1).rg;\\r\\n\\tvec2 c2 = texture2D(tMask, vUv2).rg;\\r\\n\\tvec2 c3 = texture2D(tMask, vUv3).rg;\\r\\n\\r\\n\\tfloat d0 = (c0.x - c1.x) * 0.5;\\r\\n\\tfloat d1 = (c2.x - c3.x) * 0.5;\\r\\n\\tfloat d = length(vec2(d0, d1));\\r\\n\\r\\n\\tfloat a0 = min(c0.y, c1.y);\\r\\n\\tfloat a1 = min(c2.y, c3.y);\\r\\n\\tfloat visibilityFactor = min(a0, a1);\\r\\n\\r\\n\\tgl_FragColor.rg = (1.0 - visibilityFactor > 0.001) ? vec2(d, 0.0) : vec2(0.0, d);\\r\\n\\r\\n}\\r\\n\";\nvar vertex$13 = \"uniform vec2 texelSize;\\r\\n\\r\\nvarying vec2 vUv0;\\r\\nvarying vec2 vUv1;\\r\\nvarying vec2 vUv2;\\r\\nvarying vec2 vUv3;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv0 = vec2(uv.x + texelSize.x, uv.y);\\r\\n\\tvUv1 = vec2(uv.x - texelSize.x, uv.y);\\r\\n\\tvUv2 = vec2(uv.x, uv.y + texelSize.y);\\r\\n\\tvUv3 = vec2(uv.x, uv.y - texelSize.y);\\r\\n\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * An outline edge detection shader material.\r\n */\n\nvar OutlineEdgesMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new outline edge detection material.\r\n   *\r\n   * @param {Vector2} [texelSize] - The absolute screen texel size.\r\n   */\n  function OutlineEdgesMaterial() {\n    var _this;\n\n    var texelSize = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Vector2();\n\n    classCallCheck(this, OutlineEdgesMaterial);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(OutlineEdgesMaterial).call(this, {\n      type: \"OutlineEdgesMaterial\",\n      uniforms: {\n        tMask: new Uniform(null),\n        texelSize: new Uniform(new Vector2())\n      },\n      fragmentShader: fragment$13,\n      vertexShader: vertex$13,\n      depthWrite: false,\n      depthTest: false\n    }));\n\n    _this.setTexelSize(texelSize.x, texelSize.y);\n\n    return _this;\n  }\n  /**\r\n   * Sets the texel size.\r\n   *\r\n   * @param {Number} x - The texel width.\r\n   * @param {Number} y - The texel height.\r\n   */\n\n\n  createClass(OutlineEdgesMaterial, [{\n    key: \"setTexelSize\",\n    value: function setTexelSize(x, y) {\n      this.uniforms.texelSize.value.set(x, y);\n    }\n  }]);\n\n  inherits(OutlineEdgesMaterial, _ShaderMaterial);\n\n  return OutlineEdgesMaterial;\n}(ShaderMaterial);\n\nvar fragment$14 = \"uniform sampler2D tDiffuse;\\r\\nuniform float granularity;\\r\\nuniform float dx;\\r\\nuniform float dy;\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec4 texel;\\r\\n\\r\\n\\tif(granularity > 0.0) {\\r\\n\\r\\n\\t\\tvec2 coord = vec2(\\r\\n\\t\\t\\tdx * (floor(vUv.x / dx) + 0.5),\\r\\n\\t\\t\\tdy * (floor(vUv.y / dy) + 0.5)\\r\\n\\t\\t);\\r\\n\\r\\n\\t\\ttexel = texture2D(tDiffuse, coord);\\r\\n\\r\\n\\t} else {\\r\\n\\r\\n\\t\\ttexel = texture2D(tDiffuse, vUv);\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\tgl_FragColor = texel;\\r\\n\\r\\n}\\r\\n\";\nvar vertex$14 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A pixelation shader material.\r\n *\r\n * Original shader code by Robert Casanova:\r\n *  https://github.com/robertcasanova/pixelate-shader\r\n */\n\nvar PixelationMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new pixelation material.\r\n   */\n  function PixelationMaterial() {\n    classCallCheck(this, PixelationMaterial);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(PixelationMaterial).call(this, {\n      type: \"PixelationMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        granularity: new Uniform(1.0),\n        resolution: new Uniform(new Vector2(1.0, 1.0)),\n        dx: new Uniform(1.0),\n        dy: new Uniform(1.0)\n      },\n      fragmentShader: fragment$14,\n      vertexShader: vertex$14,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n  /**\r\n   * The pixel granularity.\r\n   *\r\n   * @type {Number}\r\n   */\n\n\n  createClass(PixelationMaterial, [{\n    key: \"setResolution\",\n\n    /**\r\n     * Sets the resolution.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n    value: function setResolution(width, height) {\n      this.uniforms.resolution.value.set(width, height);\n      this.granularity = this.granularity;\n    }\n  }, {\n    key: \"granularity\",\n    get: function get() {\n      return this.uniforms.granularity.value;\n    }\n    /**\r\n     * A higher value yields coarser visuals.\r\n     *\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set(x) {\n      var uniforms = this.uniforms;\n      var resolution = uniforms.resolution.value;\n      uniforms.granularity.value = x;\n      uniforms.dx.value = x / resolution.x;\n      uniforms.dy.value = x / resolution.y;\n    }\n  }]);\n\n  inherits(PixelationMaterial, _ShaderMaterial);\n\n  return PixelationMaterial;\n}(ShaderMaterial);\n\nvar fragment$15 = \"#include <common>\\r\\n\\r\\nuniform sampler2D tDiffuse;\\r\\nuniform sampler2D tDepth;\\r\\n\\r\\nuniform vec2 texelSize;\\r\\nuniform vec2 halfTexelSize;\\r\\n\\r\\nuniform float cameraNear;\\r\\nuniform float cameraFar;\\r\\n\\r\\nuniform float focalLength;\\r\\nuniform float focalStop;\\r\\n\\r\\nuniform float maxBlur;\\r\\nuniform float luminanceThreshold;\\r\\nuniform float luminanceGain;\\r\\nuniform float bias;\\r\\nuniform float fringe;\\r\\nuniform float ditherStrength;\\r\\n\\r\\n#ifdef SHADER_FOCUS\\r\\n\\r\\n\\tuniform vec2 focusCoords;\\r\\n\\r\\n#else\\r\\n\\r\\n\\tuniform float focalDepth;\\r\\n\\r\\n#endif\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\n#ifndef USE_LOGDEPTHBUF\\r\\n\\r\\n\\t#include <packing>\\r\\n\\r\\n\\tfloat readDepth(sampler2D depthSampler, vec2 coord) {\\r\\n\\r\\n\\t\\tfloat fragCoordZ = texture2D(depthSampler, coord).x;\\r\\n\\t\\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\\r\\n\\r\\n\\t\\treturn viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\\r\\n\\r\\n\\t}\\r\\n\\r\\n#endif\\r\\n\\r\\n#ifdef PENTAGON\\r\\n\\r\\n\\tfloat penta(vec2 coords) {\\r\\n\\r\\n\\t\\tconst vec4 HS0 = vec4( 1.0,          0.0,         0.0, 1.0);\\r\\n\\t\\tconst vec4 HS1 = vec4( 0.309016994,  0.951056516, 0.0, 1.0);\\r\\n\\t\\tconst vec4 HS2 = vec4(-0.809016994,  0.587785252, 0.0, 1.0);\\r\\n\\t\\tconst vec4 HS3 = vec4(-0.809016994, -0.587785252, 0.0, 1.0);\\r\\n\\t\\tconst vec4 HS4 = vec4( 0.309016994, -0.951056516, 0.0, 1.0);\\r\\n\\t\\tconst vec4 HS5 = vec4( 0.0,          0.0,         1.0, 1.0);\\r\\n\\r\\n\\t\\tconst vec4 ONE = vec4(1.0);\\r\\n\\r\\n\\t\\tconst float P_FEATHER = 0.4;\\r\\n\\t\\tconst float N_FEATHER = -P_FEATHER;\\r\\n\\r\\n\\t\\tfloat inOrOut = -4.0;\\r\\n\\r\\n\\t\\tvec4 P = vec4(coords, vec2(RINGS_FLOAT - 1.3));\\r\\n\\r\\n\\t\\tvec4 dist = vec4(\\r\\n\\t\\t\\tdot(P, HS0),\\r\\n\\t\\t\\tdot(P, HS1),\\r\\n\\t\\t\\tdot(P, HS2),\\r\\n\\t\\t\\tdot(P, HS3)\\r\\n\\t\\t);\\r\\n\\r\\n\\t\\tdist = smoothstep(N_FEATHER, P_FEATHER, dist);\\r\\n\\r\\n\\t\\tinOrOut += dot(dist, ONE);\\r\\n\\r\\n\\t\\tdist.x = dot(P, HS4);\\r\\n\\t\\tdist.y = HS5.w - abs(P.z);\\r\\n\\r\\n\\t\\tdist = smoothstep(N_FEATHER, P_FEATHER, dist);\\r\\n\\t\\tinOrOut += dist.x;\\r\\n\\r\\n\\t\\treturn clamp(inOrOut, 0.0, 1.0);\\r\\n\\r\\n\\t}\\r\\n\\r\\n#endif\\r\\n\\r\\n#ifdef SHOW_FOCUS\\r\\n\\r\\n\\tvec3 debugFocus(vec3 c, float blur, float depth) {\\r\\n\\r\\n\\t\\tfloat edge = 0.002 * depth;\\r\\n\\t\\tfloat m = clamp(smoothstep(0.0, edge, blur), 0.0, 1.0);\\r\\n\\t\\tfloat e = clamp(smoothstep(1.0 - edge, 1.0, blur), 0.0, 1.0);\\r\\n\\r\\n\\t\\tc = mix(c, vec3(1.0, 0.5, 0.0), (1.0 - m) * 0.6);\\r\\n\\t\\tc = mix(c, vec3(0.0, 0.5, 1.0), ((1.0 - e) - (1.0 - m)) * 0.2);\\r\\n\\r\\n\\t\\treturn c;\\r\\n\\r\\n\\t}\\r\\n\\r\\n#endif\\r\\n\\r\\n#ifdef VIGNETTE\\r\\n\\r\\n\\tfloat vignette() {\\r\\n\\r\\n\\t\\tconst vec2 CENTER = vec2(0.5);\\r\\n\\r\\n\\t\\tconst float VIGNETTE_OUT = 1.3;\\r\\n\\t\\tconst float VIGNETTE_IN = 0.0;\\r\\n\\t\\tconst float VIGNETTE_FADE = 22.0; \\r\\n\\r\\n\\t\\tfloat d = distance(vUv, CENTER);\\r\\n\\t\\td = smoothstep(VIGNETTE_OUT + (focalStop / VIGNETTE_FADE), VIGNETTE_IN + (focalStop / VIGNETTE_FADE), d);\\r\\n\\r\\n\\t\\treturn clamp(d, 0.0, 1.0);\\r\\n\\r\\n\\t}\\r\\n\\r\\n#endif\\r\\n\\r\\nvec2 rand2(vec2 coord) {\\r\\n\\r\\n\\tvec2 noise;\\r\\n\\r\\n\\t#ifdef NOISE\\r\\n\\r\\n\\t\\tconst float a = 12.9898;\\r\\n\\t\\tconst float b = 78.233;\\r\\n\\t\\tconst float c = 43758.5453;\\r\\n\\r\\n\\t\\tnoise.x = clamp(fract(sin(mod(dot(coord, vec2(a, b)), 3.14)) * c), 0.0, 1.0) * 2.0 - 1.0;\\r\\n\\t\\tnoise.y = clamp(fract(sin(mod(dot(coord, vec2(a, b) * 2.0), 3.14)) * c), 0.0, 1.0) * 2.0 - 1.0;\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tnoise.x = ((fract(1.0 - coord.s * halfTexelSize.x) * 0.25) + (fract(coord.t * halfTexelSize.y) * 0.75)) * 2.0 - 1.0;\\r\\n\\t\\tnoise.y = ((fract(1.0 - coord.s * halfTexelSize.x) * 0.75) + (fract(coord.t * halfTexelSize.y) * 0.25)) * 2.0 - 1.0;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\treturn noise;\\r\\n\\r\\n}\\r\\n\\r\\nvec3 processTexel(vec2 coords, float blur) {\\r\\n\\r\\n\\tvec3 c;\\r\\n\\tc.r = texture2D(tDiffuse, coords + vec2(0.0, 1.0) * texelSize * fringe * blur).r;\\r\\n\\tc.g = texture2D(tDiffuse, coords + vec2(-0.866, -0.5) * texelSize * fringe * blur).g;\\r\\n\\tc.b = texture2D(tDiffuse, coords + vec2(0.866, -0.5) * texelSize * fringe * blur).b;\\r\\n\\r\\n\\t// Calculate the luminance of the constructed colour.\\r\\n\\tfloat luminance = linearToRelativeLuminance(c);\\r\\n\\tfloat threshold = max((luminance - luminanceThreshold) * luminanceGain, 0.0);\\r\\n\\r\\n\\treturn c + mix(vec3(0.0), c, threshold * blur);\\r\\n\\r\\n}\\r\\n\\r\\nfloat linearize(float depth) {\\r\\n\\r\\n\\treturn -cameraFar * cameraNear / (depth * (cameraFar - cameraNear) - cameraFar);\\r\\n\\r\\n}\\r\\n\\r\\nfloat gather(float i, float j, float ringSamples, inout vec3 color, float w, float h, float blur) {\\r\\n\\r\\n\\tconst float TWO_PI = 6.28318531;\\r\\n\\r\\n\\tfloat step = TWO_PI / ringSamples;\\r\\n\\tfloat pw = cos(j * step) * i;\\r\\n\\tfloat ph = sin(j * step) * i;\\r\\n\\r\\n\\t#ifdef PENTAGON\\r\\n\\r\\n\\t\\tfloat p = penta(vec2(pw, ph));\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tfloat p = 1.0;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tcolor += processTexel(vUv + vec2(pw * w, ph * h), blur) * mix(1.0, i / RINGS_FLOAT, bias) * p;\\r\\n\\r\\n\\treturn mix(1.0, i / RINGS_FLOAT, bias) * p;\\r\\n\\r\\n}\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\t#ifdef USE_LOGDEPTHBUF\\r\\n\\r\\n\\t\\tfloat depth = linearize(texture2D(tDepth, vUv).x);\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tfloat depth = linearize(readDepth(tDepth, vUv));\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t#ifdef SHADER_FOCUS\\r\\n\\r\\n\\t\\t#ifdef USE_LOGDEPTHBUF\\r\\n\\r\\n\\t\\t\\tfloat fDepth = linearize(texture2D(tDepth, focusCoords).x);\\r\\n\\r\\n\\t\\t#else\\r\\n\\r\\n\\t\\t\\tfloat fDepth = linearize(readDepth(tDepth, focusCoords));\\r\\n\\r\\n\\t\\t#endif\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tfloat fDepth = focalDepth;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t#ifdef MANUAL_DOF\\r\\n\\r\\n\\t\\tconst float nDoFStart = 1.0; \\r\\n\\t\\tconst float nDoFDist = 2.0;\\r\\n\\t\\tconst float fDoFStart = 1.0;\\r\\n\\t\\tconst float fDoFDist = 3.0;\\r\\n\\r\\n\\t\\tfloat focalPlane = depth - fDepth;\\r\\n\\t\\tfloat farDoF = (focalPlane - fDoFStart) / fDoFDist;\\r\\n\\t\\tfloat nearDoF = (-focalPlane - nDoFStart) / nDoFDist;\\r\\n\\r\\n\\t\\tfloat blur = (focalPlane > 0.0) ? farDoF : nearDoF;\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tconst float CIRCLE_OF_CONFUSION = 0.03; // 35mm film = 0.03mm CoC.\\r\\n\\r\\n\\t\\tfloat focalPlaneMM = fDepth * 1000.0;\\r\\n\\t\\tfloat depthMM = depth * 1000.0;\\r\\n\\r\\n\\t\\tfloat focalPlane = (depthMM * focalLength) / (depthMM - focalLength);\\r\\n\\t\\tfloat farDoF = (focalPlaneMM * focalLength) / (focalPlaneMM - focalLength);\\r\\n\\t\\tfloat nearDoF = (focalPlaneMM - focalLength) / (focalPlaneMM * focalStop * CIRCLE_OF_CONFUSION);\\r\\n\\r\\n\\t\\tfloat blur = abs(focalPlane - farDoF) * nearDoF;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tblur = clamp(blur, 0.0, 1.0);\\r\\n\\r\\n\\t// Dithering.\\r\\n\\tvec2 noise = rand2(vUv) * ditherStrength * blur;\\r\\n\\r\\n\\tfloat blurFactorX = texelSize.x * blur * maxBlur + noise.x;\\r\\n\\tfloat blurFactorY = texelSize.y * blur * maxBlur + noise.y;\\r\\n\\r\\n\\tconst int MAX_RING_SAMPLES = RINGS_INT * SAMPLES_INT;\\r\\n\\r\\n\\t// Calculation of final color.\\r\\n\\tvec4 color;\\r\\n\\r\\n\\tif(blur < 0.05) {\\r\\n\\r\\n\\t\\tcolor = texture2D(tDiffuse, vUv);\\r\\n\\r\\n\\t} else {\\r\\n\\r\\n\\t\\tcolor = texture2D(tDiffuse, vUv);\\r\\n\\r\\n\\t\\tfloat s = 1.0;\\r\\n\\t\\tint ringSamples;\\r\\n\\r\\n\\t\\tfor(int i = 1; i <= RINGS_INT; ++i) {\\r\\n\\r\\n\\t\\t\\tringSamples = i * SAMPLES_INT;\\r\\n\\r\\n\\t\\t\\t// Constant loop.\\r\\n\\t\\t\\tfor(int j = 0; j < MAX_RING_SAMPLES; ++j) {\\r\\n\\r\\n\\t\\t\\t\\t// Break earlier.\\r\\n\\t\\t\\t\\tif(j >= ringSamples) { break; }\\r\\n\\r\\n\\t\\t\\t\\ts += gather(float(i), float(j), float(ringSamples), color.rgb, blurFactorX, blurFactorY, blur);\\r\\n\\r\\n\\t\\t\\t}\\r\\n\\r\\n\\t\\t}\\r\\n\\r\\n\\t\\tcolor.rgb /= s; // Divide by sample count.\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\t#ifdef SHOW_FOCUS\\r\\n\\r\\n\\t\\tcolor.rgb = debugFocus(color.rgb, blur, depth);\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t#ifdef VIGNETTE\\r\\n\\r\\n\\t\\tcolor.rgb *= vignette();\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\tgl_FragColor = color;\\r\\n\\r\\n}\\r\\n\";\nvar vertex$15 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * Depth of Field shader v2.4.\r\n *\r\n * Original shader code by Martins Upitis:\r\n *  http://blenderartists.org/forum/showthread.php?237488-GLSL-depth-of-field-with-bokeh-v2-4-(update)\r\n */\n\nvar RealisticBokehMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new bokeh2 material.\r\n   *\r\n   * @param {PerspectiveCamera} [camera] - The main camera.\r\n   * @param {Object} [options] - Additional options.\r\n   * @param {Vector2} [options.texelSize] - The absolute screen texel size.\r\n   * @param {Boolean} [options.rings=3] - The number of blurring iterations.\r\n   * @param {Boolean} [options.samples=2] - The amount of samples taken per ring.\r\n   * @param {Boolean} [options.showFocus=false] - Whether the focus point should be highlighted.\r\n   * @param {Boolean} [options.manualDoF=false] - Enables manual depth of field blur.\r\n   * @param {Boolean} [options.vignette=false] - Enables a vignette effect.\r\n   * @param {Boolean} [options.pentagon=false] - Enable to use a pentagonal shape to scale gathered texels.\r\n   * @param {Boolean} [options.shaderFocus=true] - Disable if you compute your own focalDepth (in metres!).\r\n   * @param {Boolean} [options.noise=true] - Disable if you don't want noise patterns for dithering.\r\n   * @param {Number} [options.maxBlur=1.0] - The maximum blur strength.\r\n   * @param {Number} [options.luminanceThreshold=0.5] - A luminance threshold.\r\n   * @param {Number} [options.luminanceGain=2.0] - A luminance gain factor.\r\n   * @param {Number} [options.bias=0.5] - A blur bias.\r\n   * @param {Number} [options.fringe=0.7] - A blur offset.\r\n   * @param {Number} [options.ditherStrength=0.0001] - The dither strength.\r\n   */\n  function RealisticBokehMaterial() {\n    var _this;\n\n    var camera = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n    var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n    classCallCheck(this, RealisticBokehMaterial);\n\n    var settings = Object.assign({\n      texelSize: null,\n      rings: 3,\n      samples: 2,\n      showFocus: false,\n      manualDoF: false,\n      vignette: false,\n      pentagon: false,\n      shaderFocus: true,\n      noise: true,\n      maxBlur: 1.0,\n      luminanceThreshold: 0.5,\n      luminanceGain: 2.0,\n      bias: 0.5,\n      fringe: 0.7,\n      ditherStrength: 0.0001\n    }, options);\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(RealisticBokehMaterial).call(this, {\n      type: \"RealisticBokehMaterial\",\n      defines: {\n        RINGS_INT: settings.rings.toFixed(0),\n        RINGS_FLOAT: settings.rings.toFixed(1),\n        SAMPLES_INT: settings.samples.toFixed(0),\n        SAMPLES_FLOAT: settings.samples.toFixed(1)\n      },\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        tDepth: new Uniform(null),\n        texelSize: new Uniform(new Vector2()),\n        halfTexelSize: new Uniform(new Vector2()),\n        cameraNear: new Uniform(0.1),\n        cameraFar: new Uniform(2000),\n        focalLength: new Uniform(24.0),\n        focalStop: new Uniform(0.9),\n        maxBlur: new Uniform(settings.maxBlur),\n        luminanceThreshold: new Uniform(settings.luminanceThreshold),\n        luminanceGain: new Uniform(settings.luminanceGain),\n        bias: new Uniform(settings.bias),\n        fringe: new Uniform(settings.fringe),\n        ditherStrength: new Uniform(settings.ditherStrength),\n        focusCoords: new Uniform(new Vector2(0.5, 0.5)),\n        focalDepth: new Uniform(1.0)\n      },\n      fragmentShader: fragment$15,\n      vertexShader: vertex$15,\n      depthWrite: false,\n      depthTest: false\n    }));\n\n    _this.setShowFocusEnabled(settings.showFocus);\n\n    _this.setManualDepthOfFieldEnabled(settings.manualDoF);\n\n    _this.setVignetteEnabled(settings.vignette);\n\n    _this.setPentagonEnabled(settings.pentagon);\n\n    _this.setShaderFocusEnabled(settings.shaderFocus);\n\n    _this.setNoiseEnabled(settings.noise);\n\n    if (settings.texelSize !== null) {\n      _this.setTexelSize(settings.texelSize.x, settings.texelSize.y);\n    }\n\n    _this.adoptCameraSettings(camera);\n\n    return _this;\n  }\n  /**\r\n   * Defines whether the focus should be shown.\r\n   *\r\n   * @param {Boolean} enabled - True if the focus should be shown, false otherwise.\r\n   */\n\n\n  createClass(RealisticBokehMaterial, [{\n    key: \"setShowFocusEnabled\",\n    value: function setShowFocusEnabled(enabled) {\n      if (enabled) {\n        this.defines.SHOW_FOCUS = \"1\";\n      } else {\n        delete this.defines.SHOW_FOCUS;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Defines whether manual Depth of Field should be enabled.\r\n     *\r\n     * @param {Boolean} enabled - Whether manual DoF should be enabled.\r\n     */\n\n  }, {\n    key: \"setManualDepthOfFieldEnabled\",\n    value: function setManualDepthOfFieldEnabled(enabled) {\n      if (enabled) {\n        this.defines.MANUAL_DOF = \"1\";\n      } else {\n        delete this.defines.MANUAL_DOF;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Defines whether the Vignette effect should be enabled.\r\n     *\r\n     * @param {Boolean} enabled - Whether the Vignette effect should be enabled.\r\n     */\n\n  }, {\n    key: \"setVignetteEnabled\",\n    value: function setVignetteEnabled(enabled) {\n      if (enabled) {\n        this.defines.VIGNETTE = \"1\";\n      } else {\n        delete this.defines.VIGNETTE;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Defines whether the pentagonal blur effect should be enabled.\r\n     *\r\n     * @param {Boolean} enabled - Whether the pentagonal blur effect should be enabled.\r\n     */\n\n  }, {\n    key: \"setPentagonEnabled\",\n    value: function setPentagonEnabled(enabled) {\n      if (enabled) {\n        this.defines.PENTAGON = \"1\";\n      } else {\n        delete this.defines.PENTAGON;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Enables or disables the automatic shader focus.\r\n     *\r\n     * @param {Boolean} enabled - Whether the shader focus should be enabled.\r\n     */\n\n  }, {\n    key: \"setShaderFocusEnabled\",\n    value: function setShaderFocusEnabled(enabled) {\n      if (enabled) {\n        this.defines.SHADER_FOCUS = \"1\";\n      } else {\n        delete this.defines.SHADER_FOCUS;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Defines whether the dithering should compute noise.\r\n     *\r\n     * @param {Boolean} enabled - Whether noise-based dithering should be enabled.\r\n     */\n\n  }, {\n    key: \"setNoiseEnabled\",\n    value: function setNoiseEnabled(enabled) {\n      if (enabled) {\n        this.defines.NOISE = \"1\";\n      } else {\n        delete this.defines.NOISE;\n      }\n\n      this.needsUpdate = true;\n    }\n    /**\r\n     * Sets the texel size.\r\n     *\r\n     * @param {Number} x - The texel width.\r\n     * @param {Number} y - The texel height.\r\n     */\n\n  }, {\n    key: \"setTexelSize\",\n    value: function setTexelSize(x, y) {\n      this.uniforms.texelSize.value.set(x, y);\n      this.uniforms.halfTexelSize.value.set(x, y).multiplyScalar(0.5);\n    }\n    /**\r\n     * Adopts the near and far plane and the focal length of the given camera.\r\n     *\r\n     * @param {PerspectiveCamera} camera - The main camera.\r\n     */\n\n  }, {\n    key: \"adoptCameraSettings\",\n    value: function adoptCameraSettings(camera) {\n      if (camera !== null) {\n        this.uniforms.cameraNear.value = camera.near;\n        this.uniforms.cameraFar.value = camera.far;\n        this.uniforms.focalLength.value = camera.getFocalLength(); // unit: mm.\n      }\n    }\n  }]);\n\n  inherits(RealisticBokehMaterial, _ShaderMaterial);\n\n  return RealisticBokehMaterial;\n}(ShaderMaterial);\n\nvar fragment$16 = \"#include <common>\\r\\n\\r\\nuniform sampler2D tDiffuse;\\r\\nuniform vec2 center;\\r\\nuniform float aspect;\\r\\nuniform float waveSize;\\r\\nuniform float radius;\\r\\nuniform float maxRadius;\\r\\nuniform float amplitude;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying float vSize;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec2 aspectCorrection = vec2(aspect, 1.0);\\r\\n\\r\\n\\tvec2 difference = vUv * aspectCorrection - center * aspectCorrection;\\r\\n\\tfloat distance = sqrt(dot(difference, difference)) * vSize;\\r\\n\\r\\n\\tvec2 displacement = vec2(0.0);\\r\\n\\r\\n\\tif(distance > radius) {\\r\\n\\r\\n\\t\\tif(distance < radius + waveSize) {\\r\\n\\r\\n\\t\\t\\tfloat angle = (distance - radius) * PI2 / waveSize;\\r\\n\\t\\t\\tfloat cosSin = (1.0 - cos(angle)) * 0.5;\\r\\n\\r\\n\\t\\t\\tfloat extent = maxRadius + waveSize;\\r\\n\\t\\t\\tfloat decay = max(extent - distance * distance, 0.0) / extent;\\r\\n\\r\\n\\t\\t\\tdisplacement = ((cosSin * amplitude * difference) / distance) * decay;\\r\\n\\r\\n\\t\\t}\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\tgl_FragColor = texture2D(tDiffuse, vUv - displacement);\\r\\n\\r\\n}\\r\\n\";\nvar vertex$16 = \"uniform float size;\\r\\nuniform float scale;\\r\\nuniform float cameraDistance;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying float vSize;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tvSize = (0.1 * cameraDistance) / size;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * A shock wave shader material.\r\n *\r\n * Based on a Gist by Jean-Philippe Sarda:\r\n *  https://gist.github.com/jpsarda/33cea67a9f2ecb0a0eda\r\n */\n\nvar ShockWaveMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new shock wave material.\r\n   *\r\n   * @param {Object} [options] - The options.\r\n   * @param {Number} [options.waveSize=0.2] - The wave size.\r\n   * @param {Number} [options.amplitude=0.05] - The distortion amplitude.\r\n   */\n  function ShockWaveMaterial() {\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, ShockWaveMaterial);\n\n    var settings = Object.assign({\n      maxRadius: 1.0,\n      waveSize: 0.2,\n      amplitude: 0.05\n    }, options);\n    return possibleConstructorReturn(this, getPrototypeOf$2(ShockWaveMaterial).call(this, {\n      type: \"ShockWaveMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        center: new Uniform(new Vector2(0.5, 0.5)),\n        aspect: new Uniform(1.0),\n        cameraDistance: new Uniform(1.0),\n        size: new Uniform(1.0),\n        radius: new Uniform(-settings.waveSize),\n        maxRadius: new Uniform(settings.maxRadius),\n        waveSize: new Uniform(settings.waveSize),\n        amplitude: new Uniform(settings.amplitude)\n      },\n      fragmentShader: fragment$16,\n      vertexShader: vertex$16,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n\n  inherits(ShockWaveMaterial, _ShaderMaterial);\n\n  return ShockWaveMaterial;\n}(ShaderMaterial);\n\nvar fragment$17 = \"uniform sampler2D tDiffuse;\\r\\nuniform sampler2D tWeights;\\r\\n\\r\\nuniform vec2 texelSize;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying vec4 vOffset;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\t// Fetch the blending weights for current pixel.\\r\\n\\tvec4 a;\\r\\n\\ta.xz = texture2D(tWeights, vUv).xz;\\r\\n\\ta.y = texture2D(tWeights, vOffset.zw).g;\\r\\n\\ta.w = texture2D(tWeights, vOffset.xy).a;\\r\\n\\r\\n\\tvec4 color;\\r\\n\\r\\n\\t// Check if there is any blending weight with a value greater than 0.0.\\r\\n\\tif(dot(a, vec4(1.0)) < 1e-5) {\\r\\n\\r\\n\\t\\tcolor = texture2D(tDiffuse, vUv, 0.0);\\r\\n\\r\\n\\t} else {\\r\\n\\r\\n\\t\\t/* Up to four lines can be crossing a pixel (one through each edge).\\r\\n\\t\\t * The line with the maximum weight for each direction is favoured.\\r\\n\\t\\t */\\r\\n\\r\\n\\t\\tvec2 offset;\\r\\n\\t\\toffset.x = a.a > a.b ? a.a : -a.b; // Left vs. right.\\r\\n\\t\\toffset.y = a.g > a.r ? -a.g : a.r; // Top vs. bottom (changed signs).\\r\\n\\r\\n\\t\\t// Go in the direction with the maximum weight (horizontal vs. vertical).\\r\\n\\t\\tif(abs(offset.x) > abs(offset.y)) {\\r\\n\\r\\n\\t\\t\\toffset.y = 0.0;\\r\\n\\r\\n\\t\\t} else {\\r\\n\\r\\n\\t\\t\\toffset.x = 0.0;\\r\\n\\r\\n\\t\\t}\\r\\n\\r\\n\\t\\t// Fetch the opposite color and lerp by hand.\\r\\n\\t\\tcolor = texture2D(tDiffuse, vUv, 0.0);\\r\\n\\t\\tvec2 coord = vUv + sign(offset) * texelSize;\\r\\n\\t\\tvec4 oppositeColor = texture2D(tDiffuse, coord, 0.0);\\r\\n\\t\\tfloat s = abs(offset.x) > abs(offset.y) ? abs(offset.x) : abs(offset.y);\\r\\n\\r\\n\\t\\t// Gamma correction.\\r\\n\\t\\tcolor.rgb = pow(abs(color.rgb), vec3(2.2));\\r\\n\\t\\toppositeColor.rgb = pow(abs(oppositeColor.rgb), vec3(2.2));\\r\\n\\t\\tcolor = mix(color, oppositeColor, s);\\r\\n\\t\\tcolor.rgb = pow(abs(color.rgb), vec3(1.0 / 2.2));\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\tgl_FragColor = color;\\r\\n\\r\\n}\\r\\n\";\nvar vertex$17 = \"uniform vec2 texelSize;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying vec4 vOffset;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\r\\n\\tvOffset = uv.xyxy + texelSize.xyxy * vec4(1.0, 0.0, 0.0, -1.0); // Changed sign in W component.\\r\\n\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * Subpixel Morphological Antialiasing.\r\n *\r\n * This material is used to render the final antialiasing.\r\n */\n\nvar SMAABlendMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new SMAA blend material.\r\n   *\r\n   * @param {Vector2} [texelSize] - The absolute screen texel size.\r\n   */\n  function SMAABlendMaterial() {\n    var texelSize = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Vector2();\n\n    classCallCheck(this, SMAABlendMaterial);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(SMAABlendMaterial).call(this, {\n      type: \"SMAABlendMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        tWeights: new Uniform(null),\n        texelSize: new Uniform(texelSize)\n      },\n      fragmentShader: fragment$17,\n      vertexShader: vertex$17,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n\n  inherits(SMAABlendMaterial, _ShaderMaterial);\n\n  return SMAABlendMaterial;\n}(ShaderMaterial);\n\nvar fragment$18 = \"#define sampleLevelZeroOffset(t, coord, offset) texture2D(t, coord + float(offset) * texelSize, 0.0)\\r\\n\\r\\nuniform sampler2D tDiffuse;\\r\\nuniform sampler2D tArea;\\r\\nuniform sampler2D tSearch;\\r\\n\\r\\nuniform vec2 texelSize;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying vec4 vOffset[3];\\r\\nvarying vec2 vPixCoord;\\r\\n\\r\\nvec2 round(vec2 x) {\\r\\n\\r\\n\\treturn sign(x) * floor(abs(x) + 0.5);\\r\\n\\r\\n}\\r\\n\\r\\nfloat searchLength(vec2 e, float bias, float scale) {\\r\\n\\r\\n\\t// Not required if tSearch accesses are set to point.\\r\\n\\t// const vec2 SEARCH_TEX_PIXEL_SIZE = 1.0 / vec2(66.0, 33.0);\\r\\n\\t// e = vec2(bias, 0.0) + 0.5 * SEARCH_TEX_PIXEL_SIZE + e * vec2(scale, 1.0) * vec2(64.0, 32.0) * SEARCH_TEX_PIXEL_SIZE;\\r\\n\\r\\n\\te.r = bias + e.r * scale;\\r\\n\\r\\n\\treturn 255.0 * texture2D(tSearch, e, 0.0).r;\\r\\n\\r\\n}\\r\\n\\r\\nfloat searchXLeft(vec2 texCoord, float end) {\\r\\n\\r\\n\\t/* @PSEUDO_GATHER4\\r\\n\\t * This texCoord has been offset by (-0.25, -0.125) in the vertex shader to\\r\\n\\t * sample between edge, thus fetching four edges in a row.\\r\\n\\t * Sampling with different offsets in each direction allows to disambiguate\\r\\n\\t * which edges are active from the four fetched ones.\\r\\n\\t */\\r\\n\\r\\n\\tvec2 e = vec2(0.0, 1.0);\\r\\n\\r\\n\\tfor(int i = 0; i < MAX_SEARCH_STEPS_INT; ++i) {\\r\\n\\r\\n\\t\\te = texture2D(tDiffuse, texCoord, 0.0).rg;\\r\\n\\t\\ttexCoord -= vec2(2.0, 0.0) * texelSize;\\r\\n\\r\\n\\t\\tif(!(texCoord.x > end && e.g > 0.8281 && e.r == 0.0)) { break; }\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\t// Correct the previously applied offset (-0.25, -0.125).\\r\\n\\ttexCoord.x += 0.25 * texelSize.x;\\r\\n\\r\\n\\t// The searches are biased by 1, so adjust the coords accordingly.\\r\\n\\ttexCoord.x += texelSize.x;\\r\\n\\r\\n\\t// Disambiguate the length added by the last step.\\r\\n\\ttexCoord.x += 2.0 * texelSize.x; // Undo last step.\\r\\n\\ttexCoord.x -= texelSize.x * searchLength(e, 0.0, 0.5);\\r\\n\\r\\n\\treturn texCoord.x;\\r\\n\\r\\n}\\r\\n\\r\\nfloat searchXRight(vec2 texCoord, float end) {\\r\\n\\r\\n\\tvec2 e = vec2(0.0, 1.0);\\r\\n\\r\\n\\tfor(int i = 0; i < MAX_SEARCH_STEPS_INT; ++i) {\\r\\n\\r\\n\\t\\te = texture2D(tDiffuse, texCoord, 0.0).rg;\\r\\n\\t\\ttexCoord += vec2(2.0, 0.0) * texelSize;\\r\\n\\r\\n\\t\\tif(!(texCoord.x < end && e.g > 0.8281 && e.r == 0.0)) { break; }\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\ttexCoord.x -= 0.25 * texelSize.x;\\r\\n\\ttexCoord.x -= texelSize.x;\\r\\n\\ttexCoord.x -= 2.0 * texelSize.x;\\r\\n\\ttexCoord.x += texelSize.x * searchLength(e, 0.5, 0.5);\\r\\n\\r\\n\\treturn texCoord.x;\\r\\n\\r\\n}\\r\\n\\r\\nfloat searchYUp(vec2 texCoord, float end) {\\r\\n\\r\\n\\tvec2 e = vec2(1.0, 0.0);\\r\\n\\r\\n\\tfor(int i = 0; i < MAX_SEARCH_STEPS_INT; ++i) {\\r\\n\\r\\n\\t\\te = texture2D(tDiffuse, texCoord, 0.0).rg;\\r\\n\\t\\ttexCoord += vec2(0.0, 2.0) * texelSize; // Changed sign.\\r\\n\\r\\n\\t\\tif(!(texCoord.y > end && e.r > 0.8281 && e.g == 0.0)) { break; }\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\ttexCoord.y -= 0.25 * texelSize.y; // Changed sign.\\r\\n\\ttexCoord.y -= texelSize.y; // Changed sign.\\r\\n\\ttexCoord.y -= 2.0 * texelSize.y; // Changed sign.\\r\\n\\ttexCoord.y += texelSize.y * searchLength(e.gr, 0.0, 0.5); // Changed sign.\\r\\n\\r\\n\\treturn texCoord.y;\\r\\n\\r\\n}\\r\\n\\r\\nfloat searchYDown(vec2 texCoord, float end) {\\r\\n\\r\\n\\tvec2 e = vec2(1.0, 0.0);\\r\\n\\r\\n\\tfor(int i = 0; i < MAX_SEARCH_STEPS_INT; ++i ) {\\r\\n\\r\\n\\t\\te = texture2D(tDiffuse, texCoord, 0.0).rg;\\r\\n\\t\\ttexCoord -= vec2(0.0, 2.0) * texelSize; // Changed sign.\\r\\n\\r\\n\\t\\tif(!(texCoord.y < end && e.r > 0.8281 && e.g == 0.0)) { break; }\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\ttexCoord.y += 0.25 * texelSize.y; // Changed sign.\\r\\n\\ttexCoord.y += texelSize.y; // Changed sign.\\r\\n\\ttexCoord.y += 2.0 * texelSize.y; // Changed sign.\\r\\n\\ttexCoord.y -= texelSize.y * searchLength(e.gr, 0.5, 0.5); // Changed sign.\\r\\n\\r\\n\\treturn texCoord.y;\\r\\n\\r\\n}\\r\\n\\r\\nvec2 area(vec2 dist, float e1, float e2, float offset) {\\r\\n\\r\\n\\t// Rounding prevents precision errors of bilinear filtering.\\r\\n\\tvec2 texCoord = AREATEX_MAX_DISTANCE * round(4.0 * vec2(e1, e2)) + dist;\\r\\n\\r\\n\\t// Scale and bias for texel space translation.\\r\\n\\ttexCoord = AREATEX_PIXEL_SIZE * texCoord + (0.5 * AREATEX_PIXEL_SIZE);\\r\\n\\r\\n\\t// Move to proper place, according to the subpixel offset.\\r\\n\\ttexCoord.y += AREATEX_SUBTEX_SIZE * offset;\\r\\n\\r\\n\\treturn texture2D(tArea, texCoord, 0.0).rg;\\r\\n\\r\\n}\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec4 weights = vec4(0.0);\\r\\n\\tvec4 subsampleIndices = vec4(0.0);\\r\\n\\tvec2 e = texture2D(tDiffuse, vUv).rg;\\r\\n\\r\\n\\tif(e.g > 0.0) {\\r\\n\\r\\n\\t\\t// Edge at north.\\r\\n\\t\\tvec2 d;\\r\\n\\r\\n\\t\\t// Find the distance to the left.\\r\\n\\t\\tvec2 coords;\\r\\n\\t\\tcoords.x = searchXLeft(vOffset[0].xy, vOffset[2].x);\\r\\n\\t\\tcoords.y = vOffset[1].y; // vOffset[1].y = vUv.y - 0.25 * texelSize.y (@CROSSING_OFFSET)\\r\\n\\t\\td.x = coords.x;\\r\\n\\r\\n\\t\\t/* Now fetch the left crossing edges, two at a time using bilinear\\r\\n\\t\\tfiltering. Sampling at -0.25 (see @CROSSING_OFFSET) enables to discern what\\r\\n\\t\\tvalue each edge has. */\\r\\n\\t\\tfloat e1 = texture2D(tDiffuse, coords, 0.0).r;\\r\\n\\r\\n\\t\\t// Find the distance to the right.\\r\\n\\t\\tcoords.x = searchXRight(vOffset[0].zw, vOffset[2].y);\\r\\n\\t\\td.y = coords.x;\\r\\n\\r\\n\\t\\t/* Translate distances to pixel units for better interleave arithmetic and\\r\\n\\t\\tmemory accesses. */\\r\\n\\t\\td = d / texelSize.x - vPixCoord.x;\\r\\n\\r\\n\\t\\t// The area texture is compressed quadratically.\\r\\n\\t\\tvec2 sqrtD = sqrt(abs(d));\\r\\n\\r\\n\\t\\t// Fetch the right crossing edges.\\r\\n\\t\\tcoords.y -= texelSize.y; // WebGL port note: Added.\\r\\n\\t\\tfloat e2 = sampleLevelZeroOffset(tDiffuse, coords, ivec2(1, 0)).r;\\r\\n\\r\\n\\t\\t// Pattern recognised, now get the actual area.\\r\\n\\t\\tweights.rg = area(sqrtD, e1, e2, subsampleIndices.y);\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\tif(e.r > 0.0) {\\r\\n\\r\\n\\t\\t// Edge at west.\\r\\n\\t\\tvec2 d;\\r\\n\\r\\n\\t\\t// Find the distance to the top.\\r\\n\\t\\tvec2 coords;\\r\\n\\t\\tcoords.y = searchYUp(vOffset[1].xy, vOffset[2].z);\\r\\n\\t\\tcoords.x = vOffset[0].x; // vOffset[1].x = vUv.x - 0.25 * texelSize.x;\\r\\n\\t\\td.x = coords.y;\\r\\n\\r\\n\\t\\t// Fetch the top crossing edges.\\r\\n\\t\\tfloat e1 = texture2D(tDiffuse, coords, 0.0).g;\\r\\n\\r\\n\\t\\t// Find the distance to the bottom.\\r\\n\\t\\tcoords.y = searchYDown(vOffset[1].zw, vOffset[2].w);\\r\\n\\t\\td.y = coords.y;\\r\\n\\r\\n\\t\\t// Distances in pixel units.\\r\\n\\t\\td = d / texelSize.y - vPixCoord.y;\\r\\n\\r\\n\\t\\t// The area texture is compressed quadratically.\\r\\n\\t\\tvec2 sqrtD = sqrt(abs(d));\\r\\n\\r\\n\\t\\t// Fetch the bottom crossing edges.\\r\\n\\t\\tcoords.y -= texelSize.y; // WebGL port note: Added.\\r\\n\\t\\tfloat e2 = sampleLevelZeroOffset(tDiffuse, coords, ivec2(0, 1)).g;\\r\\n\\r\\n\\t\\t// Get the area for this direction.\\r\\n\\t\\tweights.ba = area(sqrtD, e1, e2, subsampleIndices.x);\\r\\n\\r\\n\\t}\\r\\n\\r\\n\\tgl_FragColor = weights;\\r\\n\\r\\n}\\r\\n\";\nvar vertex$18 = \"uniform vec2 texelSize;\\r\\n\\r\\nvarying vec2 vUv;\\r\\nvarying vec4 vOffset[3];\\r\\nvarying vec2 vPixCoord;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\r\\n\\tvPixCoord = uv / texelSize;\\r\\n\\r\\n\\t// Offsets for the searches (see @PSEUDO_GATHER4).\\r\\n\\tvOffset[0] = uv.xyxy + texelSize.xyxy * vec4(-0.25, 0.125, 1.25, 0.125); // Changed sign in Y and W components.\\r\\n\\tvOffset[1] = uv.xyxy + texelSize.xyxy * vec4(-0.125, 0.25, -0.125, -1.25); //Changed sign in Y and W components.\\r\\n\\r\\n\\t// This indicates the ends of the loops.\\r\\n\\tvOffset[2] = vec4(vOffset[0].xz, vOffset[1].yw) + vec4(-2.0, 2.0, -2.0, 2.0) * texelSize.xxyy * MAX_SEARCH_STEPS_FLOAT;\\r\\n\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * Subpixel Morphological Antialiasing.\r\n *\r\n * This material computes weights for detected edges.\r\n */\n\nvar SMAAWeightsMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new SMAA weights material.\r\n   *\r\n   * @param {Vector2} [texelSize] - The absolute screen texel size.\r\n   */\n  function SMAAWeightsMaterial() {\n    var texelSize = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Vector2();\n\n    classCallCheck(this, SMAAWeightsMaterial);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(SMAAWeightsMaterial).call(this, {\n      type: \"SMAAWeightsMaterial\",\n      defines: {\n        // Configurable settings:\n        MAX_SEARCH_STEPS_INT: \"8\",\n        MAX_SEARCH_STEPS_FLOAT: \"8.0\",\n        // Non-configurable settings:\n        AREATEX_MAX_DISTANCE: \"16.0\",\n        AREATEX_PIXEL_SIZE: \"(1.0 / vec2(160.0, 560.0))\",\n        AREATEX_SUBTEX_SIZE: \"(1.0 / 7.0)\",\n        SEARCHTEX_SIZE: \"vec2(66.0, 33.0)\",\n        SEARCHTEX_PACKED_SIZE: \"vec2(64.0, 16.0)\"\n      },\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        tArea: new Uniform(null),\n        tSearch: new Uniform(null),\n        texelSize: new Uniform(texelSize)\n      },\n      fragmentShader: fragment$18,\n      vertexShader: vertex$18,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n  /**\r\n   * Sets the maximum amount of steps performed in the horizontal/vertical\r\n   * pattern searches, at each side of the pixel.\r\n   *\r\n   * In number of pixels, it's actually the double. So the maximum line length\r\n   * perfectly handled by, for example 16, is 64 (perfectly means that longer\r\n   * lines won't look as good, but are still antialiased).\r\n   *\r\n   * @param {Number} steps - The search steps. Range: [0, 112].\r\n   */\n\n\n  createClass(SMAAWeightsMaterial, [{\n    key: \"setOrthogonalSearchSteps\",\n    value: function setOrthogonalSearchSteps(steps) {\n      this.defines.MAX_SEARCH_STEPS_INT = steps.toFixed(\"0\");\n      this.defines.MAX_SEARCH_STEPS_FLOAT = steps.toFixed(\"1\");\n      this.needsUpdate = true;\n    }\n  }]);\n\n  inherits(SMAAWeightsMaterial, _ShaderMaterial);\n\n  return SMAAWeightsMaterial;\n}(ShaderMaterial);\n\nvar fragment$19 = \"#include <common>\\r\\n#include <dithering_pars_fragment>\\r\\n\\r\\nuniform sampler2D tDiffuse;\\r\\nuniform float middleGrey;\\r\\nuniform float maxLuminance;\\r\\n\\r\\n#ifdef ADAPTED_LUMINANCE\\r\\n\\r\\n\\tuniform sampler2D luminanceMap;\\r\\n\\r\\n#else\\r\\n\\r\\n\\tuniform float averageLuminance;\\r\\n\\r\\n#endif\\r\\n\\r\\nvarying vec2 vUv;\\r\\n\\r\\nvec3 toneMap(vec3 c) {\\r\\n\\r\\n\\t#ifdef ADAPTED_LUMINANCE\\r\\n\\r\\n\\t\\t// Get the calculated average luminance by sampling the center.\\r\\n\\t\\tfloat lumAvg = texture2D(luminanceMap, vec2(0.5)).r;\\r\\n\\r\\n\\t#else\\r\\n\\r\\n\\t\\tfloat lumAvg = averageLuminance;\\r\\n\\r\\n\\t#endif\\r\\n\\r\\n\\t// Calculate the luminance of the current pixel.\\r\\n\\tfloat lumPixel = linearToRelativeLuminance(c);\\r\\n\\r\\n\\t// Apply the modified operator (Reinhard Eq. 4).\\r\\n\\tfloat lumScaled = (lumPixel * middleGrey) / lumAvg;\\r\\n\\r\\n\\tfloat lumCompressed = (lumScaled * (1.0 + (lumScaled / (maxLuminance * maxLuminance)))) / (1.0 + lumScaled);\\r\\n\\r\\n\\treturn lumCompressed * c;\\r\\n\\r\\n}\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvec4 texel = texture2D(tDiffuse, vUv);\\r\\n\\tgl_FragColor = vec4(toneMap(texel.rgb), texel.a);\\r\\n\\r\\n\\t#include <dithering_fragment>\\r\\n\\r\\n}\\r\\n\";\nvar vertex$19 = \"varying vec2 vUv;\\r\\n\\r\\nvoid main() {\\r\\n\\r\\n\\tvUv = uv;\\r\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\r\\n\\r\\n}\\r\\n\";\n/**\r\n * Full-screen tone-mapping shader material.\r\n *\r\n * This material supports dithering.\r\n *\r\n * Reference:\r\n *  http://www.cis.rit.edu/people/faculty/ferwerda/publications/sig02_paper.pdf\r\n */\n\nvar ToneMappingMaterial =\n/*#__PURE__*/\nfunction (_ShaderMaterial) {\n  /**\r\n   * Constructs a new tone mapping material.\r\n   */\n  function ToneMappingMaterial() {\n    classCallCheck(this, ToneMappingMaterial);\n\n    return possibleConstructorReturn(this, getPrototypeOf$2(ToneMappingMaterial).call(this, {\n      type: \"ToneMappingMaterial\",\n      uniforms: {\n        tDiffuse: new Uniform(null),\n        luminanceMap: new Uniform(null),\n        averageLuminance: new Uniform(1.0),\n        maxLuminance: new Uniform(16.0),\n        middleGrey: new Uniform(0.6)\n      },\n      fragmentShader: fragment$19,\n      vertexShader: vertex$19,\n      depthWrite: false,\n      depthTest: false\n    }));\n  }\n\n  inherits(ToneMappingMaterial, _ShaderMaterial);\n\n  return ToneMappingMaterial;\n}(ShaderMaterial);\n\n/**\r\n * A collection of shader materials that are used in the post processing passes.\r\n *\r\n * @module postprocessing/materials\r\n */\n\n/**\r\n * An abstract pass.\r\n *\r\n * Passes that do not rely on the depth buffer should explicitly disable the\r\n * depth test and depth write in their respective shader materials.\r\n *\r\n * @implements {Resizable}\r\n * @implements {Disposable}\r\n */\n\nvar Pass =\n/*#__PURE__*/\nfunction () {\n  /**\r\n   * Constructs a new pass.\r\n   *\r\n   * @param {String} [name] - The name of this pass.\r\n   * @param {Scene} [scene] - The scene to render.\r\n   * @param {Camera} [camera] - The camera.\r\n   * @param {Mesh} [quad] - A quad that fills the screen to render 2D filter effects. Set this to null, if you don't need it (see {@link RenderPass}).\r\n   */\n  function Pass() {\n    var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : \"Pass\";\n    var scene = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : new Scene();\n    var camera = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : new OrthographicCamera(-1, 1, 1, -1, 0, 1);\n    var quad = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : new Mesh(new PlaneBufferGeometry(2, 2), null);\n\n    classCallCheck(this, Pass);\n\n    /**\r\n     * The name of this pass.\r\n     *\r\n     * @type {String}\r\n     */\n    this.name = name;\n    /**\r\n     * The scene to render.\r\n     *\r\n     * @type {Scene}\r\n     * @protected\r\n     */\n\n    this.scene = scene;\n    /**\r\n     * The camera.\r\n     *\r\n     * @type {Camera}\r\n     * @protected\r\n     */\n\n    this.camera = camera;\n    /**\r\n     * A quad mesh that fills the screen.\r\n     *\r\n     * @type {Mesh}\r\n     * @private\r\n     */\n\n    this.quad = quad;\n\n    if (this.quad !== null) {\n      this.quad.frustumCulled = false;\n\n      if (this.scene !== null) {\n        this.scene.add(this.quad);\n      }\n    }\n    /**\r\n     * Indicates whether this pass should render to screen.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n\n    this.renderToScreen = false;\n    /**\r\n     * Indicates whether this pass should be executed.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n    this.enabled = true;\n    /**\r\n     * Indicates whether the {@link EffectComposer} should swap the frame\r\n     * buffers after this pass has finished rendering.\r\n     *\r\n     * Set this to `false` if this pass doesn't render to the output buffer or\r\n     * the screen. Otherwise, the contents of the input buffer will be lost.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n    this.needsSwap = true;\n  }\n  /**\r\n   * The fullscreen material.\r\n   *\r\n   * @type {Material}\r\n   */\n\n\n  createClass(Pass, [{\n    key: \"render\",\n\n    /**\r\n     * Renders the effect.\r\n     *\r\n     * This is an abstract method that must be overridden.\r\n     *\r\n     * @abstract\r\n     * @throws {Error} An error is thrown if the method is not overridden.\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      throw new Error(\"Render method not implemented!\");\n    }\n    /**\r\n     * Updates this pass with the renderer's size.\r\n     *\r\n     * You may override this method in case you want to be informed about the main\r\n     * render size.\r\n     *\r\n     * The {@link EffectComposer} calls this method before this pass is\r\n     * initialized and every time its own size is updated.\r\n     *\r\n     * @param {Number} width - The renderer's width.\r\n     * @param {Number} height - The renderer's height.\r\n     * @example this.myRenderTarget.setSize(width, height);\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {}\n    /**\r\n     * Performs initialization tasks.\r\n     *\r\n     * By overriding this method you gain access to the renderer. You'll also be\r\n     * able to configure your custom render targets to use the appropriate format\r\n     * (RGB or RGBA).\r\n     *\r\n     * The provided renderer can be used to warm up special off-screen render\r\n     * targets by performing a preliminary render operation.\r\n     *\r\n     * The {@link EffectComposer} calls this method when this pass is added to its\r\n     * queue, but not before its size has been set.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.\r\n     * @example if(!alpha) { this.myRenderTarget.texture.format = RGBFormat; }\r\n     */\n\n  }, {\n    key: \"initialize\",\n    value: function initialize(renderer, alpha) {}\n    /**\r\n     * Performs a shallow search for properties that define a dispose method and\r\n     * deletes them. The pass will be inoperative after this method was called!\r\n     *\r\n     * Disposable objects:\r\n     *  - render targets\r\n     *  - materials\r\n     *  - textures\r\n     *\r\n     * The {@link EffectComposer} calls this method when it is being destroyed.\r\n     * You may, however, use it independently to free memory when you are certain\r\n     * that you don't need this pass anymore.\r\n     */\n\n  }, {\n    key: \"dispose\",\n    value: function dispose() {\n      var key;\n\n      var _arr = Object.keys(this);\n\n      for (var _i = 0; _i < _arr.length; _i++) {\n        key = _arr[_i];\n\n        if (this[key] !== null && typeof this[key].dispose === \"function\") {\n          this[key].dispose();\n          this[key] = null;\n        }\n      }\n\n      if (this.material !== null) {\n        this.material.dispose();\n      }\n    }\n  }, {\n    key: \"material\",\n    get: function get() {\n      return this.quad !== null ? this.quad.material : null;\n    }\n    /**\r\n     * Sets the fullscreen material.\r\n     *\r\n     * The material will be assigned to the quad mesh that fills the screen.\r\n     *\r\n     * @type {Material}\r\n     */\n    ,\n    set: function set(value) {\n      if (this.quad !== null) {\n        this.quad.material = value;\n      }\n    }\n  }]);\n\n  return Pass;\n}();\n\n/**\r\n * An efficient, incremental blur pass.\r\n *\r\n * Note: This pass allows the input and output buffer to be the same.\r\n */\n\nvar BlurPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new blur pass.\r\n   *\r\n   * @param {Object} [options] - The options.\r\n   * @param {Number} [options.resolutionScale=0.5] - The render texture resolution scale, relative to the screen render size.\r\n   * @param {Number} [options.kernelSize=KernelSize.LARGE] - The blur kernel size.\r\n   */\n  function BlurPass() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, BlurPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(BlurPass).call(this, \"BlurPass\"));\n    /**\r\n     * A render target.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetX = new WebGLRenderTarget(1, 1, {\n      minFilter: LinearFilter,\n      magFilter: LinearFilter,\n      stencilBuffer: false,\n      depthBuffer: false\n    });\n    _this.renderTargetX.texture.name = \"Blur.TargetX\";\n    _this.renderTargetX.texture.generateMipmaps = false;\n    /**\r\n     * A second render target.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetY = _this.renderTargetX.clone();\n    _this.renderTargetY.texture.name = \"Blur.TargetY\";\n    /**\r\n     * The resolution scale.\r\n     *\r\n     * You need to call {@link EffectComposer#setSize} after changing this\r\n     * value.\r\n     *\r\n     * @type {Number}\r\n     */\n\n    _this.resolutionScale = options.resolutionScale !== undefined ? options.resolutionScale : 0.5;\n    /**\r\n     * A convolution shader material.\r\n     *\r\n     * @type {ConvolutionMaterial}\r\n     * @private\r\n     */\n\n    _this.convolutionMaterial = new ConvolutionMaterial();\n    /**\r\n     * A convolution shader material that uses dithering.\r\n     *\r\n     * @type {ConvolutionMaterial}\r\n     * @private\r\n     */\n\n    _this.ditheredConvolutionMaterial = new ConvolutionMaterial();\n    _this.ditheredConvolutionMaterial.dithering = true;\n    /**\r\n     * Whether the blurred result should also be dithered using noise.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n    _this.dithering = false;\n    _this.kernelSize = options.kernelSize;\n    return _this;\n  }\n  /**\r\n   * The absolute width of the internal render targets.\r\n   *\r\n   * @type {Number}\r\n   */\n\n\n  createClass(BlurPass, [{\n    key: \"render\",\n\n    /**\r\n     * Blurs the input buffer and writes the result to the output buffer. The\r\n     * input buffer remains intact, unless its also the output buffer.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var scene = this.scene;\n      var camera = this.camera;\n      var renderTargetX = this.renderTargetX;\n      var renderTargetY = this.renderTargetY;\n      var material = this.convolutionMaterial;\n      var uniforms = material.uniforms;\n      var kernel = material.getKernel();\n      var lastRT = inputBuffer;\n      var destRT;\n      var i, l;\n      this.material = material; // Apply the multi-pass blur.\n\n      for (i = 0, l = kernel.length - 1; i < l; ++i) {\n        // Alternate between targets.\n        destRT = i % 2 === 0 ? renderTargetX : renderTargetY;\n        uniforms.kernel.value = kernel[i];\n        uniforms.tDiffuse.value = lastRT.texture;\n        renderer.render(scene, camera, destRT);\n        lastRT = destRT;\n      }\n\n      if (this.dithering) {\n        material = this.ditheredConvolutionMaterial;\n        uniforms = material.uniforms;\n        this.material = material;\n      }\n\n      uniforms.kernel.value = kernel[i];\n      uniforms.tDiffuse.value = lastRT.texture;\n      renderer.render(scene, camera, this.renderToScreen ? null : outputBuffer);\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      width = Math.max(1, Math.floor(width * this.resolutionScale));\n      height = Math.max(1, Math.floor(height * this.resolutionScale));\n      this.renderTargetX.setSize(width, height);\n      this.renderTargetY.setSize(width, height);\n      this.convolutionMaterial.setTexelSize(1.0 / width, 1.0 / height);\n      this.ditheredConvolutionMaterial.setTexelSize(1.0 / width, 1.0 / height);\n    }\n    /**\r\n     * Performs initialization tasks.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.\r\n     */\n\n  }, {\n    key: \"initialize\",\n    value: function initialize(renderer, alpha) {\n      if (!alpha) {\n        this.renderTargetX.texture.format = RGBFormat;\n        this.renderTargetY.texture.format = RGBFormat;\n      }\n    }\n  }, {\n    key: \"width\",\n    get: function get() {\n      return this.renderTargetX.width;\n    }\n    /**\r\n     * The absolute height of the internal render targets.\r\n     *\r\n     * @type {Number}\r\n     */\n\n  }, {\n    key: \"height\",\n    get: function get() {\n      return this.renderTargetX.height;\n    }\n    /**\r\n     * The kernel size.\r\n     *\r\n     * @type {KernelSize}\r\n     */\n\n  }, {\n    key: \"kernelSize\",\n    get: function get() {\n      return this.convolutionMaterial.kernelSize;\n    }\n    /**\r\n     * @type {KernelSize}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : KernelSize.LARGE;\n      this.convolutionMaterial.kernelSize = value;\n      this.ditheredConvolutionMaterial.kernelSize = value;\n    }\n  }]);\n\n  inherits(BlurPass, _Pass);\n\n  return BlurPass;\n}(Pass);\n\n/**\r\n * A bloom pass.\r\n *\r\n * This pass renders a scene with superimposed blur by utilizing the fast Kawase\r\n * convolution approach.\r\n */\n\nvar BloomPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new bloom pass.\r\n   *\r\n   * @param {Object} [options] - The options.\r\n   * @param {Number} [options.resolutionScale=0.5] - The render texture resolution scale, relative to the screen render size.\r\n   * @param {Number} [options.kernelSize=KernelSize.LARGE] - The blur kernel size.\r\n   * @param {Number} [options.intensity=1.0] - The strength of the bloom effect.\r\n   * @param {Number} [options.distinction=1.0] - The luminance distinction factor. Raise this value to bring out the brighter elements in the scene.\r\n   * @param {Number} [options.screenMode=true] - Whether the screen blend mode should be used for combining the bloom texture with the scene colors.\r\n   */\n  function BloomPass() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, BloomPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(BloomPass).call(this, \"BloomPass\"));\n    /**\r\n     * A render target.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTarget = new WebGLRenderTarget(1, 1, {\n      minFilter: LinearFilter,\n      magFilter: LinearFilter,\n      stencilBuffer: false,\n      depthBuffer: false\n    });\n    _this.renderTarget.texture.name = \"Bloom.Target\";\n    _this.renderTarget.texture.generateMipmaps = false;\n    /**\r\n     * A blur pass.\r\n     *\r\n     * @type {BlurPass}\r\n     * @private\r\n     */\n\n    _this.blurPass = new BlurPass(options);\n    /**\r\n     * A combine shader material.\r\n     *\r\n     * @type {CombineMaterial}\r\n     * @private\r\n     */\n\n    _this.combineMaterial = new CombineMaterial(options.screenMode !== undefined ? options.screenMode : true);\n    _this.intensity = options.intensity;\n    /**\r\n     * A luminosity shader material.\r\n     *\r\n     * @type {LuminosityMaterial}\r\n     * @private\r\n     */\n\n    _this.luminosityMaterial = new LuminosityMaterial(true);\n    _this.distinction = options.distinction;\n    return _this;\n  }\n  /**\r\n   * The resolution scale.\r\n   *\r\n   * @type {Number}\r\n   */\n\n\n  createClass(BloomPass, [{\n    key: \"render\",\n\n    /**\r\n     * Renders the effect.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var scene = this.scene;\n      var camera = this.camera;\n      var blurPass = this.blurPass;\n      var luminosityMaterial = this.luminosityMaterial;\n      var combineMaterial = this.combineMaterial;\n      var renderTarget = this.renderTarget; // Luminance filter.\n\n      this.material = luminosityMaterial;\n      luminosityMaterial.uniforms.tDiffuse.value = inputBuffer.texture;\n      renderer.render(scene, camera, renderTarget); // Convolution phase.\n\n      blurPass.render(renderer, renderTarget, renderTarget);\n\n      if (this.blend) {\n        // Render the original scene with superimposed blur.\n        this.material = combineMaterial;\n        combineMaterial.uniforms.texture1.value = inputBuffer.texture;\n        combineMaterial.uniforms.texture2.value = renderTarget.texture;\n        renderer.render(scene, camera, this.renderToScreen ? null : outputBuffer);\n      }\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      this.blurPass.setSize(width, height);\n      width = this.blurPass.width;\n      height = this.blurPass.height;\n      this.renderTarget.setSize(width, height);\n    }\n    /**\r\n     * Performs initialization tasks.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.\r\n     */\n\n  }, {\n    key: \"initialize\",\n    value: function initialize(renderer, alpha) {\n      this.blurPass.initialize(renderer, alpha);\n\n      if (!alpha) {\n        this.renderTarget.texture.format = RGBFormat;\n      }\n    }\n  }, {\n    key: \"resolutionScale\",\n    get: function get() {\n      return this.blurPass.resolutionScale;\n    }\n    /**\r\n     * You need to call {@link EffectComposer#setSize} after changing this value.\r\n     *\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.5;\n      this.blurPass.resolutionScale = value;\n    }\n    /**\r\n     * The blur kernel size.\r\n     *\r\n     * @type {KernelSize}\r\n     */\n\n  }, {\n    key: \"kernelSize\",\n    get: function get() {\n      return this.blurPass.kernelSize;\n    }\n    /**\r\n     * @type {KernelSize}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : KernelSize.LARGE;\n      this.blurPass.kernelSize = value;\n    }\n    /**\r\n     * The overall intensity of the effect.\r\n     *\r\n     * @type {Number}\r\n     */\n\n  }, {\n    key: \"intensity\",\n    get: function get() {\n      return this.combineMaterial.uniforms.opacity2.value;\n    }\n    /**\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1.0;\n      this.combineMaterial.uniforms.opacity2.value = value;\n    }\n    /**\r\n     * The luminance distinction factor.\r\n     *\r\n     * @type {Number}\r\n     */\n\n  }, {\n    key: \"distinction\",\n    get: function get() {\n      return this.luminosityMaterial.uniforms.distinction.value;\n    }\n    /**\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1.0;\n      this.luminosityMaterial.uniforms.distinction.value = value;\n    }\n    /**\r\n     * Indicates whether dithering is enabled.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n  }, {\n    key: \"dithering\",\n    get: function get() {\n      return this.blurPass.dithering;\n    }\n    /**\r\n     * If enabled, the result will be dithered to remove banding artifacts.\r\n     *\r\n     * @type {Boolean}\r\n     */\n    ,\n    set: function set(value) {\n      this.blurPass.dithering = value;\n    }\n    /**\r\n     * Indicates whether the effect should be applied to the input buffer.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n  }, {\n    key: \"blend\",\n    get: function get() {\n      return this.needsSwap;\n    }\n    /**\r\n     * If disabled, the input buffer will remain unaffected.\r\n     *\r\n     * You may use the {@link BloomPass#overlay} texture to apply the effect to\r\n     * your scene.\r\n     *\r\n     * @type {Boolean}\r\n     */\n    ,\n    set: function set(value) {\n      this.needsSwap = value;\n    }\n    /**\r\n     * The effect overlay texture.\r\n     *\r\n     * @type {Texture}\r\n     */\n\n  }, {\n    key: \"overlay\",\n    get: function get() {\n      return this.renderTarget.texture;\n    }\n  }]);\n\n  inherits(BloomPass, _Pass);\n\n  return BloomPass;\n}(Pass);\n\n/**\r\n * A Depth of Field (DoF) pass using a bokeh shader.\r\n *\r\n * This pass requires a {@link EffectComposer#depthTexture}.\r\n */\n\nvar BokehPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new bokeh pass.\r\n   *\r\n   * @param {PerspectiveCamera} camera - The main camera. Used to obtain the aspect ratio and the near and far plane settings.\r\n   * @param {Object} [options] - Additional parameters. See {@link BokehMaterial} for details.\r\n   */\n  function BokehPass(camera) {\n    var _this;\n\n    var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n    classCallCheck(this, BokehPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(BokehPass).call(this, \"BokehPass\"));\n    _this.material = new BokehMaterial(camera, options);\n    return _this;\n  }\n  /**\r\n   * Renders the effect.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(BokehPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      this.material.uniforms.tDiffuse.value = inputBuffer.texture;\n      this.material.uniforms.tDepth.value = inputBuffer.depthTexture;\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      this.material.uniforms.aspect.value = width / height;\n    }\n  }]);\n\n  inherits(BokehPass, _Pass);\n\n  return BokehPass;\n}(Pass);\n\n/**\r\n * A pass that disables the stencil test.\r\n */\n\nvar ClearMaskPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new clear mask pass.\r\n   */\n  function ClearMaskPass() {\n    var _this;\n\n    classCallCheck(this, ClearMaskPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(ClearMaskPass).call(this, \"ClearMaskPass\", null, null, null));\n    _this.needsSwap = false;\n    return _this;\n  }\n  /**\r\n   * Disables the global stencil test.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(ClearMaskPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      renderer.state.buffers.stencil.setTest(false);\n    }\n  }]);\n\n  inherits(ClearMaskPass, _Pass);\n\n  return ClearMaskPass;\n}(Pass);\n\n/**\r\n * Used for saving the original clear color of the renderer.\r\n *\r\n * @type {Color}\r\n * @private\r\n */\n\nvar color = new Color();\n/**\r\n * A pass that clears the input buffer or the screen.\r\n *\r\n * You can prevent specific bits from being cleared by setting either the\r\n * autoClearColor, autoClearStencil or autoClearDepth properties of the renderer\r\n * to false.\r\n */\n\nvar ClearPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new clear pass.\r\n   *\r\n   * @param {Object} [options] - Additional options.\r\n   * @param {Color} [options.clearColor=null] - An override clear color.\r\n   * @param {Number} [options.clearAlpha=0.0] - An override clear alpha.\r\n   */\n  function ClearPass() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, ClearPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(ClearPass).call(this, \"ClearPass\", null, null, null));\n    _this.needsSwap = false;\n    /**\r\n     * The clear color.\r\n     *\r\n     * @type {Color}\r\n     */\n\n    _this.clearColor = options.clearColor !== undefined ? options.clearColor : null;\n    /**\r\n     * The clear alpha.\r\n     *\r\n     * @type {Number}\r\n     */\n\n    _this.clearAlpha = options.clearAlpha !== undefined ? options.clearAlpha : 0.0;\n    return _this;\n  }\n  /**\r\n   * Clears the input buffer or the screen.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(ClearPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var clearColor = this.clearColor;\n      var clearAlpha;\n\n      if (clearColor !== null) {\n        color.copy(renderer.getClearColor());\n        clearAlpha = renderer.getClearAlpha();\n        renderer.setClearColor(clearColor, this.clearAlpha);\n      }\n\n      renderer.setRenderTarget(this.renderToScreen ? null : inputBuffer);\n      renderer.clear();\n\n      if (clearColor !== null) {\n        renderer.setClearColor(color, clearAlpha);\n      }\n    }\n  }]);\n\n  inherits(ClearPass, _Pass);\n\n  return ClearPass;\n}(Pass);\n\n/**\r\n * A dot screen pass.\r\n */\n\nvar DotScreenPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new dot screen pass.\r\n   *\r\n   * @param {Object} [options] - The options.\r\n   * @param {Boolean} [options.average=false] - Whether the shader should output a colour average (black and white).\r\n   * @param {Number} [options.angle=1.57] - The angle of the pattern.\r\n   * @param {Number} [options.scale=1.0] - The scale of the overall effect.\r\n   * @param {Number} [options.intensity=1.0] - The intensity of the effect.\r\n   */\n  function DotScreenPass() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, DotScreenPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(DotScreenPass).call(this, \"DotScreenPass\"));\n    _this.material = new DotScreenMaterial(options);\n    return _this;\n  }\n  /**\r\n   * Renders the effect.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(DotScreenPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      this.material.uniforms.tDiffuse.value = inputBuffer.texture;\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      width = Math.max(1, width);\n      height = Math.max(1, height);\n      this.material.uniforms.offsetRepeat.value.z = width;\n      this.material.uniforms.offsetRepeat.value.w = height;\n    }\n  }]);\n\n  inherits(DotScreenPass, _Pass);\n\n  return DotScreenPass;\n}(Pass);\n\n/**\r\n * A film pass.\r\n *\r\n * Provides various cinematic effects.\r\n */\n\nvar FilmPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new film pass.\r\n   *\r\n   * @param {Object} [options] - The options. See {@link FilmMaterial} for more options.\r\n   * @param {Number} [options.scanlineDensity=1.25] - The scanline density, relative to the screen height.\r\n   * @param {Number} [options.gridScale=1.0] - The grid scale, relative to the screen height.\r\n   * @param {Number} [options.gridLineWidth=0.0] - The grid line width. This value will be added to the base line width.\r\n   */\n  function FilmPass() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, FilmPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(FilmPass).call(this, \"FilmPass\"));\n    _this.material = new FilmMaterial(options);\n    /**\r\n     * The amount of scanlines, relative to the screen height.\r\n     *\r\n     * You need to call {@link EffectComposer#setSize} after changing this\r\n     * value.\r\n     *\r\n     * @type {Number}\r\n     */\n\n    _this.scanlineDensity = options.scanlineDensity === undefined ? 1.25 : options.scanlineDensity;\n    /**\r\n     * The grid scale, relative to the screen height.\r\n     *\r\n     * You need to call {@link EffectComposer#setSize} after changing this\r\n     * value.\r\n     *\r\n     * @type {Number}\r\n     */\n\n    _this.gridScale = options.gridScale === undefined ? 1.0 : Math.max(options.gridScale, 1e-6);\n    /**\r\n     * The grid line width.\r\n     *\r\n     * You need to call {@link EffectComposer#setSize} after changing this\r\n     * value.\r\n     *\r\n     * @type {Number}\r\n     */\n\n    _this.gridLineWidth = options.gridLineWidth === undefined ? 0.0 : Math.max(options.gridLineWidth, 0.0);\n    return _this;\n  }\n  /**\r\n   * Renders the effect.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(FilmPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      this.material.uniforms.tDiffuse.value = inputBuffer.texture;\n      this.material.uniforms.time.value += delta;\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      var aspect = width / height;\n      var gridScale = this.gridScale * (height * 0.125);\n      this.material.uniforms.scanlineCount.value = Math.round(height * this.scanlineDensity);\n      this.material.uniforms.gridScale.value.set(aspect * gridScale, gridScale);\n      this.material.uniforms.gridLineWidth.value = gridScale / height + this.gridLineWidth;\n    }\n  }]);\n\n  inherits(FilmPass, _Pass);\n\n  return FilmPass;\n}(Pass);\n\n/**\r\n * Returns a random integer in the specified range.\r\n *\r\n * @private\r\n * @param {Number} low - The lowest possible value.\r\n * @param {Number} high - The highest possible value.\r\n * @return {Number} The random value.\r\n */\n\nfunction randomInt(low, high) {\n  return low + Math.floor(Math.random() * (high - low + 1));\n}\n/**\r\n * Returns a random float in the specified range.\r\n *\r\n * @private\r\n * @param {Number} low - The lowest possible value.\r\n * @param {Number} high - The highest possible value.\r\n * @return {Number} The random value.\r\n */\n\n\nfunction randomFloat(low, high) {\n  return low + Math.random() * (high - low);\n}\n/**\r\n * A glitch pass.\r\n */\n\n\nvar GlitchPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new glitch pass.\r\n   *\r\n   * @param {Object} [options] - The options.\r\n   * @param {Texture} [options.perturbMap] - A perturbation map. If none is provided, a noise texture will be created.\r\n   * @param {Number} [options.dtSize=64] - The size of the generated noise map. Will be ignored if a perturbation map is provided.\r\n   */\n  function GlitchPass() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, GlitchPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(GlitchPass).call(this, \"GlitchPass\"));\n    _this.material = new GlitchMaterial();\n    /**\r\n     * A perturbation map.\r\n     *\r\n     * @type {Texture}\r\n     * @private\r\n     */\n\n    _this.texture = null;\n    _this.perturbMap = options.perturbMap !== undefined ? options.perturbMap : _this.generatePerturbMap(options.dtSize);\n    _this.perturbMap.name = \"Glitch.Perturbation\";\n    _this.perturbMap.generateMipmaps = false;\n    /**\r\n     * The effect mode.\r\n     *\r\n     * @type {GlitchMode}\r\n     */\n\n    _this.mode = GlitchMode.SPORADIC;\n    /**\r\n     * A counter for the glitch activation and deactivation.\r\n     *\r\n     * @type {Number}\r\n     * @private\r\n     */\n\n    _this.counter = 0;\n    /**\r\n     * A random break point for the sporadic glitch activation.\r\n     *\r\n     * @type {Number}\r\n     * @private\r\n     */\n\n    _this.breakPoint = randomInt(120, 240);\n    return _this;\n  }\n  /**\r\n   * The current perturbation map.\r\n   *\r\n   * @type {Texture}\r\n   */\n\n\n  createClass(GlitchPass, [{\n    key: \"generatePerturbMap\",\n\n    /**\r\n     * Destroys the current perturbation map and replaces it with a new one.\r\n     *\r\n     * @param {Number} [size=64] - The texture size.\r\n     * @return {DataTexture} The perturbation texture.\r\n     */\n    value: function generatePerturbMap() {\n      var size = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 64;\n      var pixels = size * size;\n      var data = new Float32Array(pixels * 3);\n      var dt = this.perturbMap;\n      var i, x;\n\n      for (i = 0; i < pixels; ++i) {\n        x = Math.random();\n        data[i * 3] = x;\n        data[i * 3 + 1] = x;\n        data[i * 3 + 2] = x;\n      }\n\n      if (dt !== null) {\n        dt.dispose();\n      }\n\n      dt = new DataTexture(data, size, size, RGBFormat, FloatType);\n      dt.needsUpdate = true;\n      this.perturbMap = dt;\n      return dt;\n    }\n    /**\r\n     * Renders the effect.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n\n  }, {\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var mode = this.mode;\n      var counter = this.counter;\n      var breakPoint = this.breakPoint;\n      var uniforms = this.material.uniforms;\n      uniforms.tDiffuse.value = inputBuffer.texture;\n      uniforms.seed.value = Math.random();\n      uniforms.active.value = true;\n\n      if (counter % breakPoint === 0 || mode === GlitchMode.CONSTANT_WILD) {\n        uniforms.amount.value = Math.random() / 30.0;\n        uniforms.angle.value = randomFloat(-Math.PI, Math.PI);\n        uniforms.seedX.value = randomFloat(-1.0, 1.0);\n        uniforms.seedY.value = randomFloat(-1.0, 1.0);\n        uniforms.distortionX.value = randomFloat(0.0, 1.0);\n        uniforms.distortionY.value = randomFloat(0.0, 1.0);\n        this.breakPoint = randomInt(120, 240);\n        this.counter = 0;\n      } else {\n        if (counter % breakPoint < breakPoint / 5 || mode === GlitchMode.CONSTANT_MILD) {\n          uniforms.amount.value = Math.random() / 90.0;\n          uniforms.angle.value = randomFloat(-Math.PI, Math.PI);\n          uniforms.distortionX.value = randomFloat(0.0, 1.0);\n          uniforms.distortionY.value = randomFloat(0.0, 1.0);\n          uniforms.seedX.value = randomFloat(-0.3, 0.3);\n          uniforms.seedY.value = randomFloat(-0.3, 0.3);\n        } else {\n          // Sporadic.\n          uniforms.active.value = false;\n        }\n      }\n\n      ++this.counter;\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n  }, {\n    key: \"perturbMap\",\n    get: function get() {\n      return this.texture;\n    }\n    /**\r\n     * Assigning a new perturbation map does not destroy the current one!\r\n     *\r\n     * @type {Texture}\r\n     */\n    ,\n    set: function set(value) {\n      this.texture = value;\n      this.material.uniforms.tPerturb.value = value;\n    }\n  }]);\n\n  inherits(GlitchPass, _Pass);\n\n  return GlitchPass;\n}(Pass);\n/**\r\n * A glitch mode enumeration.\r\n *\r\n * @type {Object}\r\n * @property {Number} SPORADIC - Sporadic glitches.\r\n * @property {Number} CONSTANT_MILD - Constant mild glitches.\r\n * @property {Number} CONSTANT_WILD - Constant wild glitches.\r\n */\n\nvar GlitchMode = {\n  SPORADIC: 0,\n  CONSTANT_MILD: 1,\n  CONSTANT_WILD: 2\n};\n\n/**\r\n * A pass that renders a given scene directly on screen or into the read buffer\r\n * for further processing.\r\n */\n\nvar RenderPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new render pass.\r\n   *\r\n   * @param {Scene} scene - The scene to render.\r\n   * @param {Camera} camera - The camera to use to render the scene.\r\n   * @param {Object} [options] - Additional options.\r\n   * @param {Material} [options.overrideMaterial=null] - An override material for the scene.\r\n   * @param {Color} [options.clearColor=null] - An override clear color.\r\n   * @param {Number} [options.clearAlpha=1.0] - An override clear alpha.\r\n   * @param {Boolean} [options.clearDepth=false] - Whether depth should be cleared explicitly.\r\n   * @param {Boolean} [options.clear=true] - Whether all buffers should be cleared.\r\n   */\n  function RenderPass(scene, camera) {\n    var _this;\n\n    var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n    classCallCheck(this, RenderPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(RenderPass).call(this, \"RenderPass\", scene, camera, null));\n    _this.needsSwap = false;\n    /**\r\n     * A clear pass.\r\n     *\r\n     * @type {ClearPass}\r\n     */\n\n    _this.clearPass = new ClearPass(options);\n    /**\r\n     * An override material.\r\n     *\r\n     * @type {Material}\r\n     */\n\n    _this.overrideMaterial = options.overrideMaterial !== undefined ? options.overrideMaterial : null;\n    /**\r\n     * Indicates whether the depth buffer should be cleared explicitly.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n    _this.clearDepth = options.clearDepth !== undefined ? options.clearDepth : false;\n    /**\r\n     * Indicates whether the color, depth and stencil buffers should be cleared.\r\n     *\r\n     * Even with clear set to true you can prevent specific buffers from being\r\n     * cleared by setting either the autoClearColor, autoClearStencil or\r\n     * autoClearDepth properties of the renderer to false.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n    _this.clear = options.clear !== undefined ? options.clear : true;\n    return _this;\n  }\n  /**\r\n   * Renders the scene.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(RenderPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var scene = this.scene;\n      var renderTarget = this.renderToScreen ? null : inputBuffer;\n      var overrideMaterial = scene.overrideMaterial;\n\n      if (this.clear) {\n        this.clearPass.renderToScreen = this.renderToScreen;\n        this.clearPass.render(renderer, inputBuffer);\n      } else if (this.clearDepth) {\n        renderer.setRenderTarget(renderTarget);\n        renderer.clearDepth();\n      }\n\n      scene.overrideMaterial = this.overrideMaterial;\n      renderer.render(scene, this.camera, renderTarget);\n      scene.overrideMaterial = overrideMaterial;\n    }\n  }]);\n\n  inherits(RenderPass, _Pass);\n\n  return RenderPass;\n}(Pass);\n\n/**\r\n * Clamps a given value.\r\n *\r\n * @private\r\n * @param {Number} value - The value to clamp.\r\n * @param {Number} min - The lowest possible value.\r\n * @param {Number} max - The highest possible value.\r\n * @return {Number} The clamped value.\r\n */\n\nfunction clamp(value, min, max) {\n  return Math.max(min, Math.min(max, value));\n}\n/**\r\n * A crepuscular rays pass.\r\n */\n\n\nvar GodRaysPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new god rays pass.\r\n   *\r\n   * @param {Scene} scene - The main scene.\r\n   * @param {Camera} camera - The main camera.\r\n   * @param {Object3D} lightSource - The main light source.\r\n   * @param {Object} [options] - The options.\r\n   * @param {Number} [options.density=0.96] - The density of the light rays.\r\n   * @param {Number} [options.decay=0.93] - An illumination decay factor.\r\n   * @param {Number} [options.weight=0.4] - A light ray weight factor.\r\n   * @param {Number} [options.exposure=0.6] - A constant attenuation coefficient.\r\n   * @param {Number} [options.clampMax=1.0] - An upper bound for the saturation of the overall effect.\r\n   * @param {Number} [options.intensity=1.0] - A constant factor for additive blending.\r\n   * @param {Number} [options.resolutionScale=0.5] - The render texture resolution scale, relative to the screen render size.\r\n   * @param {Number} [options.kernelSize=KernelSize.LARGE] - The blur kernel size.\r\n   * @param {Number} [options.samples=60] - The number of samples per pixel.\r\n   * @param {Number} [options.screenMode=true] - Whether the screen blend mode should be used for combining the god rays texture with the scene colors.\r\n   */\n  function GodRaysPass(scene, camera, lightSource) {\n    var _this;\n\n    var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n\n    classCallCheck(this, GodRaysPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(GodRaysPass).call(this, \"GodRaysPass\"));\n    /**\r\n     * A scene that only contains the light source.\r\n     *\r\n     * @type {Scene}\r\n     * @private\r\n     */\n\n    _this.lightScene = new Scene();\n    /**\r\n     * The main scene.\r\n     *\r\n     * @type {Scene}\r\n     * @private\r\n     */\n\n    _this.mainScene = scene;\n    /**\r\n     * The main camera.\r\n     *\r\n     * @type {Camera}\r\n     * @private\r\n     */\n\n    _this.mainCamera = camera;\n    /**\r\n     * A render target.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetX = new WebGLRenderTarget(1, 1, {\n      minFilter: LinearFilter,\n      magFilter: LinearFilter,\n      stencilBuffer: false,\n      depthBuffer: false\n    });\n    _this.renderTargetX.texture.name = \"GodRays.TargetX\";\n    _this.renderTargetX.texture.generateMipmaps = false;\n    /**\r\n     * A second render target.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetY = _this.renderTargetX.clone();\n    _this.renderTargetY.texture.name = \"GodRays.TargetY\";\n    /**\r\n     * A render target for the masked light scene.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetMask = new WebGLRenderTarget(1, 1, {\n      minFilter: LinearFilter,\n      magFilter: LinearFilter\n    });\n    _this.renderTargetMask.texture.name = \"GodRays.Mask\";\n    _this.renderTargetMask.texture.generateMipmaps = false;\n    /**\r\n     * A pass that only renders the light source.\r\n     *\r\n     * @type {RenderPass}\r\n     * @private\r\n     */\n\n    _this.renderPassLight = new RenderPass(_this.lightScene, _this.mainCamera, {\n      clearColor: new Color(0x000000)\n    });\n    /**\r\n     * A pass that renders the masked scene over the light.\r\n     *\r\n     * @type {RenderPass}\r\n     * @private\r\n     */\n\n    _this.renderPassMask = new RenderPass(_this.mainScene, _this.mainCamera, {\n      overrideMaterial: new MeshBasicMaterial({\n        color: 0x000000\n      })\n    });\n    _this.renderPassMask.clear = false;\n    /**\r\n     * A blur pass.\r\n     *\r\n     * @type {BlurPass}\r\n     * @private\r\n     */\n\n    _this.blurPass = new BlurPass(options);\n    /**\r\n     * The light source.\r\n     *\r\n     * @type {Object3D}\r\n     */\n\n    _this.lightSource = lightSource;\n    /**\r\n     * The light position in screen space.\r\n     *\r\n     * @type {Vector3}\r\n     * @private\r\n     */\n\n    _this.screenPosition = new Vector3();\n    /**\r\n     * A god rays shader material.\r\n     *\r\n     * @type {GodRaysMaterial}\r\n     * @private\r\n     */\n\n    _this.godRaysMaterial = new GodRaysMaterial(options);\n    _this.godRaysMaterial.uniforms.lightPosition.value = _this.screenPosition;\n    _this.samples = options.samples;\n    /**\r\n     * A combine shader material.\r\n     *\r\n     * @type {CombineMaterial}\r\n     * @private\r\n     */\n\n    _this.combineMaterial = new CombineMaterial(options.screenMode !== undefined ? options.screenMode : true);\n    _this.intensity = options.intensity;\n    return _this;\n  }\n  /**\r\n   * The resolution scale.\r\n   *\r\n   * @type {Number}\r\n   */\n\n\n  createClass(GodRaysPass, [{\n    key: \"render\",\n\n    /**\r\n     * Renders the effect.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var scene = this.scene;\n      var camera = this.camera;\n      var mainScene = this.mainScene;\n      var lightSource = this.lightSource;\n      var screenPosition = this.screenPosition;\n      var godRaysMaterial = this.godRaysMaterial;\n      var combineMaterial = this.combineMaterial;\n      var renderTargetMask = this.renderTargetMask;\n      var renderTargetX = this.renderTargetX;\n      var renderTargetY = this.renderTargetY;\n      var background, parent; // Compute the screen light position and translate it to [0.0, 1.0].\n\n      screenPosition.copy(lightSource.position).project(this.mainCamera);\n      screenPosition.x = clamp((screenPosition.x + 1.0) * 0.5, 0.0, 1.0);\n      screenPosition.y = clamp((screenPosition.y + 1.0) * 0.5, 0.0, 1.0);\n      parent = lightSource.parent;\n      background = mainScene.background;\n      mainScene.background = null;\n      this.lightScene.add(lightSource);\n      /* First, render the light source. Then render the scene into the same\r\n      buffer using a mask override material with depth test enabled. */\n\n      this.renderPassLight.render(renderer, renderTargetMask);\n      this.renderPassMask.render(renderer, renderTargetMask);\n\n      if (parent !== null) {\n        parent.add(lightSource);\n      }\n\n      mainScene.background = background; // Blur the masked scene to reduce artifacts.\n\n      this.blurPass.render(renderer, this.renderTargetMask, renderTargetX); // Blur the masked scene along radial lines towards the light source.\n\n      this.material = godRaysMaterial;\n      godRaysMaterial.uniforms.tDiffuse.value = renderTargetX.texture;\n      renderer.render(scene, camera, renderTargetY);\n\n      if (this.blend) {\n        // Combine the god rays with the scene colors.\n        this.material = combineMaterial;\n        combineMaterial.uniforms.texture1.value = inputBuffer.texture;\n        combineMaterial.uniforms.texture2.value = renderTargetY.texture;\n        renderer.render(scene, camera, this.renderToScreen ? null : outputBuffer);\n      }\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      this.renderPassLight.setSize(width, height);\n      this.renderPassMask.setSize(width, height);\n      this.blurPass.setSize(width, height);\n      width = this.blurPass.width;\n      height = this.blurPass.height;\n      this.renderTargetMask.setSize(width, height);\n      this.renderTargetX.setSize(width, height);\n      this.renderTargetY.setSize(width, height);\n    }\n    /**\r\n     * Performs initialization tasks.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.\r\n     */\n\n  }, {\n    key: \"initialize\",\n    value: function initialize(renderer, alpha) {\n      this.renderPassLight.initialize(renderer, alpha);\n      this.renderPassMask.initialize(renderer, alpha);\n      this.blurPass.initialize(renderer, alpha);\n\n      if (!alpha) {\n        this.renderTargetMask.texture.format = RGBFormat;\n        this.renderTargetX.texture.format = RGBFormat;\n        this.renderTargetY.texture.format = RGBFormat;\n      }\n    }\n  }, {\n    key: \"resolutionScale\",\n    get: function get() {\n      return this.blurPass.resolutionScale;\n    }\n    /**\r\n     * You need to call {@link EffectComposer#setSize} after changing this value.\r\n     *\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.5;\n      this.blurPass.resolutionScale = value;\n    }\n    /**\r\n     * The blur kernel size.\r\n     *\r\n     * @type {KernelSize}\r\n     */\n\n  }, {\n    key: \"kernelSize\",\n    get: function get() {\n      return this.blurPass.kernelSize;\n    }\n    /**\r\n     * @type {KernelSize}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : KernelSize.LARGE;\n      this.blurPass.kernelSize = value;\n    }\n    /**\r\n     * The overall intensity of the effect.\r\n     *\r\n     * @type {Number}\r\n     */\n\n  }, {\n    key: \"intensity\",\n    get: function get() {\n      return this.combineMaterial.uniforms.opacity2.value;\n    }\n    /**\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1.0;\n      this.combineMaterial.uniforms.opacity2.value = value;\n    }\n    /**\r\n     * The number of samples per pixel.\r\n     *\r\n     * @type {Number}\r\n     */\n\n  }, {\n    key: \"samples\",\n    get: function get() {\n      return Number.parseInt(this.godRaysMaterial.defines.NUM_SAMPLES_INT);\n    }\n    /**\r\n     * This value must be carefully chosen. A higher value directly increases the\r\n     * GPU load.\r\n     *\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 60;\n      value = Math.floor(value);\n      this.godRaysMaterial.defines.NUM_SAMPLES_FLOAT = value.toFixed(1);\n      this.godRaysMaterial.defines.NUM_SAMPLES_INT = value.toFixed(0);\n      this.godRaysMaterial.needsUpdate = true;\n    }\n    /**\r\n     * Indicates whether dithering is enabled.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n  }, {\n    key: \"dithering\",\n    get: function get() {\n      return this.godRaysMaterial.dithering;\n    }\n    /**\r\n     * If enabled, the result will be dithered to remove banding artifacts.\r\n     *\r\n     * @type {Boolean}\r\n     */\n    ,\n    set: function set(value) {\n      if (this.dithering !== value) {\n        this.godRaysMaterial.dithering = value;\n        this.godRaysMaterial.needsUpdate = true;\n      }\n    }\n    /**\r\n     * Indicates whether the effect should be applied to the input buffer.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n  }, {\n    key: \"blend\",\n    get: function get() {\n      return this.needsSwap;\n    }\n    /**\r\n     * If disabled, the input buffer will remain unaffected.\r\n     *\r\n     * You may use the {@link BloomPass#overlay} texture to apply the effect to\r\n     * your scene.\r\n     *\r\n     * @type {Boolean}\r\n     */\n    ,\n    set: function set(value) {\n      this.needsSwap = value;\n    }\n    /**\r\n     * The effect overlay texture.\r\n     *\r\n     * @type {Texture}\r\n     */\n\n  }, {\n    key: \"overlay\",\n    get: function get() {\n      return this.renderTargetY.texture;\n    }\n  }]);\n\n  inherits(GodRaysPass, _Pass);\n\n  return GodRaysPass;\n}(Pass);\n\n/**\r\n * A mask pass.\r\n */\n\nvar MaskPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new mask pass.\r\n   *\r\n   * @param {Scene} scene - The scene to render.\r\n   * @param {Camera} camera - The camera to use.\r\n   */\n  function MaskPass(scene, camera) {\n    var _this;\n\n    classCallCheck(this, MaskPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(MaskPass).call(this, \"MaskPass\", scene, camera, null));\n    _this.needsSwap = false;\n    /**\r\n     * Inverse flag.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n    _this.inverse = false;\n    /**\r\n     * Stencil buffer clear flag.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n    _this.clearStencil = true;\n    return _this;\n  }\n  /**\r\n   * Renders the effect.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(MaskPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var context = renderer.context;\n      var state = renderer.state;\n      var scene = this.scene;\n      var camera = this.camera;\n      var writeValue = this.inverse ? 0 : 1;\n      var clearValue = 1 - writeValue; // Don't update color or depth.\n\n      state.buffers.color.setMask(false);\n      state.buffers.depth.setMask(false); // Lock the buffers.\n\n      state.buffers.color.setLocked(true);\n      state.buffers.depth.setLocked(true); // Configure the stencil.\n\n      state.buffers.stencil.setTest(true);\n      state.buffers.stencil.setOp(context.REPLACE, context.REPLACE, context.REPLACE);\n      state.buffers.stencil.setFunc(context.ALWAYS, writeValue, 0xffffffff);\n      state.buffers.stencil.setClear(clearValue); // Clear the stencil.\n\n      if (this.clearStencil) {\n        if (this.renderToScreen) {\n          renderer.setRenderTarget(null);\n          renderer.clearStencil();\n        } else {\n          renderer.setRenderTarget(inputBuffer);\n          renderer.clearStencil();\n          renderer.setRenderTarget(outputBuffer);\n          renderer.clearStencil();\n        }\n      } // Draw the mask.\n\n\n      if (this.renderToScreen) {\n        renderer.render(scene, camera, null);\n      } else {\n        renderer.render(scene, camera, inputBuffer);\n        renderer.render(scene, camera, outputBuffer);\n      } // Unlock the buffers.\n\n\n      state.buffers.color.setLocked(false);\n      state.buffers.depth.setLocked(false); // Only render where the stencil is set to 1.\n\n      state.buffers.stencil.setFunc(context.EQUAL, 1, 0xffffffff);\n      state.buffers.stencil.setOp(context.KEEP, context.KEEP, context.KEEP);\n    }\n  }]);\n\n  inherits(MaskPass, _Pass);\n\n  return MaskPass;\n}(Pass);\n\n/**\r\n * A shader pass.\r\n *\r\n * Used to render any shader material as a 2D filter.\r\n */\n\nvar ShaderPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new shader pass.\r\n   *\r\n   * @param {ShaderMaterial} material - The shader material to use.\r\n   * @param {String} [textureID=\"tDiffuse\"] - The texture uniform identifier.\r\n   */\n  function ShaderPass(material) {\n    var _this;\n\n    var textureID = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : \"tDiffuse\";\n\n    classCallCheck(this, ShaderPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(ShaderPass).call(this, \"ShaderPass\"));\n    _this.material = material;\n    /**\r\n     * The name of the color sampler uniform of the given material.\r\n     *\r\n     * @type {String}\r\n     */\n\n    _this.textureID = textureID;\n    return _this;\n  }\n  /**\r\n   * Renders the effect.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(ShaderPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      if (this.material.uniforms[this.textureID] !== undefined) {\n        this.material.uniforms[this.textureID].value = inputBuffer.texture;\n      }\n\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n  }]);\n\n  inherits(ShaderPass, _Pass);\n\n  return ShaderPass;\n}(Pass);\n\n/**\r\n * An outline pass.\r\n */\n\nvar OutlinePass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new outline pass.\r\n   *\r\n   * @param {Scene} scene - The main scene.\r\n   * @param {Camera} camera - The main camera.\r\n   * @param {Object} [options] - Additional parameters. See {@link BlurPass}, {@link OutlineBlendMaterial} and {@link OutlineEdgesMaterial} for details.\r\n   * @param {Number} [options.pulseSpeed=0.0] - The pulse speed. A value of zero disables the pulse effect.\r\n   * @param {Boolean} [options.blur=true] - Whether the outline should be blurred.\r\n   */\n  function OutlinePass(scene, camera) {\n    var _this;\n\n    var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n    classCallCheck(this, OutlinePass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(OutlinePass).call(this, \"OutlinePass\"));\n    /**\r\n     * The main scene.\r\n     *\r\n     * @type {Scene}\r\n     * @private\r\n     */\n\n    _this.mainScene = scene;\n    /**\r\n     * The main camera.\r\n     *\r\n     * @type {Camera}\r\n     * @private\r\n     */\n\n    _this.mainCamera = camera;\n    /**\r\n     * A render target for depth information.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetDepth = new WebGLRenderTarget(1, 1, {\n      minFilter: LinearFilter,\n      magFilter: LinearFilter\n    });\n    _this.renderTargetDepth.texture.name = \"Outline.Depth\";\n    _this.renderTargetDepth.texture.generateMipmaps = false;\n    /**\r\n     * A render target for the outline mask.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetMask = _this.renderTargetDepth.clone();\n    _this.renderTargetMask.texture.format = RGBFormat;\n    _this.renderTargetMask.texture.name = \"Outline.Mask\";\n    /**\r\n     * A render target for the edge detection.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetEdges = new WebGLRenderTarget(1, 1, {\n      minFilter: LinearFilter,\n      magFilter: LinearFilter,\n      stencilBuffer: false,\n      depthBuffer: false,\n      format: RGBFormat\n    });\n    _this.renderTargetEdges.texture.name = \"Outline.Edges\";\n    _this.renderTargetEdges.texture.generateMipmaps = false;\n    /**\r\n     * A render target for the blurred outline overlay.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetBlurredEdges = _this.renderTargetEdges.clone();\n    _this.renderTargetBlurredEdges.texture.name = \"Outline.BlurredEdges\";\n    /**\r\n     * A depth pass.\r\n     *\r\n     * @type {RenderPass}\r\n     * @private\r\n     */\n\n    _this.renderPassDepth = new RenderPass(_this.mainScene, _this.mainCamera, {\n      overrideMaterial: new MeshDepthMaterial({\n        depthPacking: RGBADepthPacking,\n        morphTargets: true,\n        skinning: true\n      }),\n      clearColor: new Color(0xffffff),\n      clearAlpha: 1.0\n    });\n    /**\r\n     * A depth comparison mask pass.\r\n     *\r\n     * @type {RenderPass}\r\n     * @private\r\n     */\n\n    _this.renderPassMask = new RenderPass(_this.mainScene, _this.mainCamera, {\n      overrideMaterial: new DepthComparisonMaterial(_this.renderTargetDepth.texture, _this.mainCamera),\n      clearColor: new Color(0xffffff),\n      clearAlpha: 1.0\n    });\n    /**\r\n     * A blur pass.\r\n     *\r\n     * @type {BlurPass}\r\n     * @private\r\n     */\n\n    _this.blurPass = new BlurPass(options);\n    _this.kernelSize = options.kernelSize;\n    /**\r\n     * A copy pass that renders the read buffer to screen if needed.\r\n     *\r\n     * @type {ShaderPass}\r\n     * @private\r\n     */\n\n    _this.copyPass = new ShaderPass(new CopyMaterial());\n    _this.copyPass.renderToScreen = true;\n    /**\r\n     * An outline edge detection material.\r\n     *\r\n     * @type {OutlineEdgesMaterial}\r\n     * @private\r\n     */\n\n    _this.outlineEdgesMaterial = new OutlineEdgesMaterial(options);\n    _this.outlineEdgesMaterial.uniforms.tMask.value = _this.renderTargetMask.texture;\n    /**\r\n     * An outline blend material.\r\n     *\r\n     * @type {OutlineBlendMaterial}\r\n     * @private\r\n     */\n\n    _this.outlineBlendMaterial = new OutlineBlendMaterial(options);\n    _this.outlineBlendMaterial.uniforms.tMask.value = _this.renderTargetMask.texture;\n    _this.blur = options.blur !== undefined ? options.blur : true;\n    /**\r\n     * A list of objects to outline.\r\n     *\r\n     * @type {Object3D[]}\r\n     * @private\r\n     */\n\n    _this.selection = [];\n    /**\r\n     * The current animation time.\r\n     *\r\n     * @type {Number}\r\n     * @private\r\n     */\n\n    _this.time = 0.0;\n    /**\r\n     * The pulse speed. A value of zero disables the pulse effect.\r\n     *\r\n     * @type {Number}\r\n     */\n\n    _this.pulseSpeed = options.pulseSpeed !== undefined ? options.pulseSpeed : 0.0;\n    /**\r\n     * A dedicated render layer for selected objects.\r\n     *\r\n     * This layer is set to 10 by default. If this collides with your own custom\r\n     * layers, please change it to a free layer before rendering!\r\n     *\r\n     * @type {Number}\r\n     */\n\n    _this.selectionLayer = 10;\n    return _this;\n  }\n  /**\r\n   * The resolution scale.\r\n   *\r\n   * @type {Number}\r\n   */\n\n\n  createClass(OutlinePass, [{\n    key: \"setPatternTexture\",\n\n    /**\r\n     * Sets a pattern texture to use as an overlay for selected objects.\r\n     *\r\n     * @param {Texture} [texture=null] - A pattern texture. Set to null to disable the pattern.\r\n     */\n    value: function setPatternTexture() {\n      var texture = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n      this.outlineBlendMaterial.setPatternTexture(texture);\n    }\n    /**\r\n     * Clears the current selection and selects a list of objects.\r\n     *\r\n     * @param {Object3D[]} objects - The objects that should be outlined. This array will be copied.\r\n     * @return {OutlinePass} This pass.\r\n     */\n\n  }, {\n    key: \"setSelection\",\n    value: function setSelection(objects) {\n      var selection = objects.slice(0);\n      var selectionLayer = this.selectionLayer;\n      var i, l;\n      this.clearSelection();\n\n      for (i = 0, l = selection.length; i < l; ++i) {\n        selection[i].layers.enable(selectionLayer);\n      }\n\n      this.selection = selection;\n      return this;\n    }\n    /**\r\n     * Clears the list of selected objects.\r\n     *\r\n     * @return {OutlinePass} This pass.\r\n     */\n\n  }, {\n    key: \"clearSelection\",\n    value: function clearSelection() {\n      var selection = this.selection;\n      var selectionLayer = this.selectionLayer;\n      var i, l;\n\n      for (i = 0, l = selection.length; i < l; ++i) {\n        selection[i].layers.disable(selectionLayer);\n      }\n\n      this.selection = [];\n      this.time = 0.0;\n      return this;\n    }\n    /**\r\n     * Selects an object.\r\n     *\r\n     * @param {Object3D} object - The object that should be outlined.\r\n     * @return {OutlinePass} This pass.\r\n     */\n\n  }, {\n    key: \"selectObject\",\n    value: function selectObject(object) {\n      object.layers.enable(this.selectionLayer);\n      this.selection.push(object);\n      return this;\n    }\n    /**\r\n     * Deselects an object.\r\n     *\r\n     * @param {Object3D} object - The object that should no longer be outlined.\r\n     * @return {OutlinePass} This pass.\r\n     */\n\n  }, {\n    key: \"deselectObject\",\n    value: function deselectObject(object) {\n      var selection = this.selection;\n      var index = selection.indexOf(object);\n\n      if (index >= 0) {\n        selection[index].layers.disable(this.selectionLayer);\n        selection.splice(index, 1);\n\n        if (selection.length === 0) {\n          this.time = 0.0;\n        }\n      }\n\n      return this;\n    }\n    /**\r\n     * Sets the visibility of all selected objects.\r\n     *\r\n     * @private\r\n     * @param {Boolean} visible - Whether the selected objects should be visible.\r\n     */\n\n  }, {\n    key: \"setSelectionVisible\",\n    value: function setSelectionVisible(visible) {\n      var selection = this.selection;\n      var i, l;\n\n      for (i = 0, l = selection.length; i < l; ++i) {\n        if (visible) {\n          selection[i].layers.enable(0);\n        } else {\n          selection[i].layers.disable(0);\n        }\n      }\n    }\n    /**\r\n     * Renders the effect.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n\n  }, {\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var mainScene = this.mainScene;\n      var mainCamera = this.mainCamera;\n      var pulse = this.outlineBlendMaterial.uniforms.pulse;\n      var background, mask;\n\n      if (this.selection.length > 0) {\n        background = mainScene.background;\n        mask = mainCamera.layers.mask;\n        mainScene.background = null;\n        pulse.value = 1.0;\n\n        if (this.pulseSpeed > 0.0) {\n          pulse.value = 0.625 + Math.cos(this.time * this.pulseSpeed * 10.0) * 0.375;\n          this.time += delta;\n        } // Render a custom depth texture and ignore selected objects.\n\n\n        this.setSelectionVisible(false);\n        this.renderPassDepth.render(renderer, this.renderTargetDepth);\n        this.setSelectionVisible(true); // Create a mask for the selected objects using the depth information.\n\n        mainCamera.layers.mask = 1 << this.selectionLayer;\n        this.renderPassMask.render(renderer, this.renderTargetMask); // Restore the camera layer mask and the scene background.\n\n        mainCamera.layers.mask = mask;\n        mainScene.background = background; // Detect the outline.\n\n        this.material = this.outlineEdgesMaterial;\n        renderer.render(this.scene, this.camera, this.renderTargetEdges);\n\n        if (this.blurPass.enabled) {\n          // Blur the edges.\n          this.blurPass.render(renderer, this.renderTargetEdges, this.renderTargetBlurredEdges);\n        }\n\n        if (this.blend) {\n          // Draw the final overlay onto the scene colours.\n          this.material = this.outlineBlendMaterial;\n          this.outlineBlendMaterial.uniforms.tDiffuse.value = inputBuffer.texture;\n          renderer.render(this.scene, this.camera, this.renderToScreen ? null : this.outputBuffer);\n        }\n      } else if (this.renderToScreen) {\n        // Draw the read buffer to screen.\n        this.copyPass.render(renderer, inputBuffer);\n      }\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      this.renderTargetDepth.setSize(width, height);\n      this.renderTargetMask.setSize(width, height);\n      this.renderPassDepth.setSize(width, height);\n      this.renderPassMask.setSize(width, height);\n      this.blurPass.setSize(width, height);\n      width = this.blurPass.width;\n      height = this.blurPass.height;\n      this.renderTargetEdges.setSize(width, height);\n      this.renderTargetBlurredEdges.setSize(width, height);\n      this.outlineBlendMaterial.uniforms.aspect.value = width / height;\n      this.outlineEdgesMaterial.setTexelSize(1.0 / width, 1.0 / height);\n    }\n    /**\r\n     * Performs initialization tasks.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.\r\n     */\n\n  }, {\n    key: \"initialize\",\n    value: function initialize(renderer, alpha) {\n      this.renderPassDepth.initialize(renderer, alpha);\n      this.renderPassMask.initialize(renderer, alpha);\n      this.blurPass.initialize(renderer, alpha);\n    }\n  }, {\n    key: \"resolutionScale\",\n    get: function get() {\n      return this.blurPass.resolutionScale;\n    }\n    /**\r\n     * You need to call {@link EffectComposer#setSize} after changing this value.\r\n     *\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.5;\n      this.blurPass.resolutionScale = value;\n    }\n    /**\r\n     * The blur kernel size.\r\n     *\r\n     * @type {KernelSize}\r\n     */\n\n  }, {\n    key: \"kernelSize\",\n    get: function get() {\n      return this.blurPass.kernelSize;\n    }\n    /**\r\n     * @type {KernelSize}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : KernelSize.VERY_SMALL;\n      this.blurPass.kernelSize = value;\n    }\n    /**\r\n     * Indicates whether the outline overlay should be blurred.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n  }, {\n    key: \"blur\",\n    get: function get() {\n      return this.blurPass.enabled;\n    }\n    /**\r\n     * @type {Boolean}\r\n     */\n    ,\n    set: function set(value) {\n      this.blurPass.enabled = value;\n      this.outlineBlendMaterial.uniforms.tEdges.value = value ? this.renderTargetBlurredEdges.texture : this.renderTargetEdges.texture;\n    }\n    /**\r\n     * Indicates whether dithering is enabled.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n  }, {\n    key: \"dithering\",\n    get: function get() {\n      return this.blurPass.dithering;\n    }\n    /**\r\n     * If enabled, the result will be dithered to remove banding artifacts.\r\n     *\r\n     * @type {Boolean}\r\n     */\n    ,\n    set: function set(value) {\n      this.blurPass.dithering = value;\n    }\n    /**\r\n     * Indicates whether the effect should be applied to the input buffer.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n  }, {\n    key: \"blend\",\n    get: function get() {\n      return this.needsSwap;\n    }\n    /**\r\n     * If disabled, the input buffer will remain unaffected.\r\n     *\r\n     * You may use the {@link BloomPass#overlay} texture to apply the effect to\r\n     * your scene.\r\n     *\r\n     * @type {Boolean}\r\n     */\n    ,\n    set: function set(value) {\n      this.needsSwap = value;\n    }\n    /**\r\n     * The effect overlay texture.\r\n     *\r\n     * @type {Texture}\r\n     */\n\n  }, {\n    key: \"overlay\",\n    get: function get() {\n      return this.outlineBlendMaterial.uniforms.tEdges.value;\n    }\n  }]);\n\n  inherits(OutlinePass, _Pass);\n\n  return OutlinePass;\n}(Pass);\n\n/**\r\n * A pixelation pass.\r\n */\n\nvar PixelationPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new pixelation pass.\r\n   *\r\n   * @param {Number} [granularity=30.0] - The intensity of the effect.\r\n   */\n  function PixelationPass() {\n    var _this;\n\n    var granularity = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 30.0;\n\n    classCallCheck(this, PixelationPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(PixelationPass).call(this, \"PixelationPass\"));\n    _this.material = new PixelationMaterial();\n    _this.granularity = granularity;\n    return _this;\n  }\n  /**\r\n   * The pixel granularity.\r\n   *\r\n   * @type {Number}\r\n   */\n\n\n  createClass(PixelationPass, [{\n    key: \"render\",\n\n    /**\r\n     * Renders the effect.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      this.material.uniforms.tDiffuse.value = inputBuffer.texture;\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      this.material.setResolution(width, height);\n    }\n  }, {\n    key: \"granularity\",\n    get: function get() {\n      return this.material.granularity;\n    }\n    /**\r\n     * A higher value yields coarser visuals.\r\n     *\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 30;\n      value = Math.floor(value);\n\n      if (value % 2 > 0) {\n        value += 1;\n      }\n\n      this.material.granularity = value;\n    }\n  }]);\n\n  inherits(PixelationPass, _Pass);\n\n  return PixelationPass;\n}(Pass);\n\n/**\r\n * An advanced Depth of Field (DoF) pass.\r\n *\r\n * Yields more realistic results but is also more demanding.\r\n *\r\n * This pass requires a {@link EffectComposer#depthTexture}.\r\n */\n\nvar RealisticBokehPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new bokeh pass.\r\n   *\r\n   * @param {PerspectiveCamera} camera - The main camera. Used to obtain the focal length and the near and far plane settings.\r\n   * @param {Object} [options] - Additional parameters. See {@link RealisticBokehMaterial} for details.\r\n   */\n  function RealisticBokehPass(camera) {\n    var _this;\n\n    var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n    classCallCheck(this, RealisticBokehPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(RealisticBokehPass).call(this, \"RealisticBokehPass\"));\n    _this.material = new RealisticBokehMaterial(camera, options);\n    return _this;\n  }\n  /**\r\n   * Renders the effect.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(RealisticBokehPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      this.material.uniforms.tDiffuse.value = inputBuffer.texture;\n      this.material.uniforms.tDepth.value = inputBuffer.depthTexture;\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      this.material.setTexelSize(1.0 / width, 1.0 / height);\n    }\n  }]);\n\n  inherits(RealisticBokehPass, _Pass);\n\n  return RealisticBokehPass;\n}(Pass);\n\n/**\r\n * A pass that renders the result from a previous pass to another render target.\r\n */\n\nvar SavePass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new save pass.\r\n   *\r\n   * @param {WebGLRenderTarget} [renderTarget] - The render target to use for saving the input buffer.\r\n   * @param {Boolean} [resize=true] - Whether the render target should adjust to the size of the input buffer.\r\n   */\n  function SavePass(renderTarget) {\n    var _this;\n\n    var resize = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n    classCallCheck(this, SavePass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(SavePass).call(this, \"SavePass\"));\n    _this.material = new CopyMaterial();\n    _this.needsSwap = false;\n    /**\r\n     * The render target.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     */\n\n    _this.renderTarget = renderTarget !== undefined ? renderTarget : new WebGLRenderTarget(1, 1, {\n      minFilter: LinearFilter,\n      magFilter: LinearFilter,\n      stencilBuffer: false,\n      depthBuffer: false\n    });\n    _this.renderTarget.texture.name = \"Save.Target\";\n    _this.renderTarget.texture.generateMipmaps = false;\n    /**\r\n     * Indicates whether the render target should be resized when the size of\r\n     * the composer's frame buffer changes.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n    _this.resize = resize;\n    return _this;\n  }\n  /**\r\n   * Renders the effect.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(SavePass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      this.material.uniforms.tDiffuse.value = inputBuffer.texture;\n      renderer.render(this.scene, this.camera, this.renderTarget);\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      if (this.resize) {\n        width = Math.max(1, width);\n        height = Math.max(1, height);\n        this.renderTarget.setSize(width, height);\n      }\n    }\n    /**\r\n     * Performs initialization tasks.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.\r\n     */\n\n  }, {\n    key: \"initialize\",\n    value: function initialize(renderer, alpha) {\n      if (!alpha) {\n        this.renderTarget.texture.format = RGBFormat;\n      }\n    }\n  }]);\n\n  inherits(SavePass, _Pass);\n\n  return SavePass;\n}(Pass);\n\n/**\r\n * Half PI.\r\n *\r\n * @type {Number}\r\n * @private\r\n */\n\nvar HALF_PI = Math.PI * 0.5;\n/**\r\n * A vector.\r\n *\r\n * @type {Vector3}\r\n * @private\r\n */\n\nvar v = new Vector3();\n/**\r\n * A vector.\r\n *\r\n * @type {Vector3}\r\n * @private\r\n */\n\nvar ab = new Vector3();\n/**\r\n * A shock wave pass.\r\n */\n\nvar ShockWavePass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new shock wave pass.\r\n   *\r\n   * @param {Camera} camera - The main camera.\r\n   * @param {Vector3} [epicenter] - The world position of the shock wave epicenter.\r\n   * @param {Object} [options] - The options.\r\n   * @param {Number} [options.speed=1.0] - The animation speed.\r\n   * @param {Number} [options.maxRadius=1.0] - The extent of the shock wave.\r\n   * @param {Number} [options.waveSize=0.2] - The wave size.\r\n   * @param {Number} [options.amplitude=0.05] - The distortion amplitude.\r\n   */\n  function ShockWavePass(camera) {\n    var _this;\n\n    var epicenter = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : new Vector3();\n    var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n    classCallCheck(this, ShockWavePass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(ShockWavePass).call(this, \"ShockWavePass\"));\n    /**\r\n     * The main camera.\r\n     *\r\n     * @type {Object3D}\r\n     */\n\n    _this.mainCamera = camera;\n    /**\r\n     * The epicenter.\r\n     *\r\n     * @type {Vector3}\r\n     * @example shockWavePass.epicenter = myMesh.position;\r\n     */\n\n    _this.epicenter = epicenter;\n    /**\r\n     * The object position in screen space.\r\n     *\r\n     * @type {Vector3}\r\n     * @private\r\n     */\n\n    _this.screenPosition = new Vector3();\n    /**\r\n     * The speed of the shock wave animation.\r\n     *\r\n     * @type {Number}\r\n     */\n\n    _this.speed = options.speed !== undefined ? options.speed : 2.0;\n    /**\r\n     * A time accumulator.\r\n     *\r\n     * @type {Number}\r\n     * @private\r\n     */\n\n    _this.time = 0.0;\n    /**\r\n     * Indicates whether the shock wave animation is active.\r\n     *\r\n     * @type {Boolean}\r\n     * @private\r\n     */\n\n    _this.active = false;\n    /**\r\n     * A shock wave shader material.\r\n     *\r\n     * @type {ShockWaveMaterial}\r\n     * @private\r\n     */\n\n    _this.shockWaveMaterial = new ShockWaveMaterial(options);\n    _this.shockWaveMaterial.uniforms.center.value = _this.screenPosition;\n    /**\r\n     * A copy shader material.\r\n     *\r\n     * @type {CopyMaterial}\r\n     * @private\r\n     */\n\n    _this.copyMaterial = new CopyMaterial();\n    return _this;\n  }\n  /**\r\n   * Emits the shock wave.\r\n   */\n\n\n  createClass(ShockWavePass, [{\n    key: \"explode\",\n    value: function explode() {\n      this.time = 0.0;\n      this.active = true;\n    }\n    /**\r\n     * Renders the effect.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n\n  }, {\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var epicenter = this.epicenter;\n      var mainCamera = this.mainCamera;\n      var screenPosition = this.screenPosition;\n      var shockWaveMaterial = this.shockWaveMaterial;\n      var uniforms = shockWaveMaterial.uniforms;\n      var center = uniforms.center;\n      var radius = uniforms.radius;\n      var maxRadius = uniforms.maxRadius;\n      var waveSize = uniforms.waveSize;\n      this.copyMaterial.uniforms.tDiffuse.value = inputBuffer.texture;\n      this.material = this.copyMaterial;\n\n      if (this.active) {\n        // Calculate direction vectors.\n        mainCamera.getWorldDirection(v);\n        ab.copy(mainCamera.position).sub(epicenter); // Don't render the effect if the object is behind the camera.\n\n        if (v.angleTo(ab) > HALF_PI) {\n          // Scale the effect based on distance to the object.\n          uniforms.cameraDistance.value = mainCamera.position.distanceTo(epicenter); // Calculate the screen position of the epicenter.\n\n          screenPosition.copy(epicenter).project(mainCamera);\n          center.value.x = (screenPosition.x + 1.0) * 0.5;\n          center.value.y = (screenPosition.y + 1.0) * 0.5;\n          uniforms.tDiffuse.value = inputBuffer.texture;\n          this.material = shockWaveMaterial;\n        } // Update the shock wave radius based on time.\n\n\n        this.time += delta * this.speed;\n        radius.value = this.time - waveSize.value;\n\n        if (radius.value >= (maxRadius.value + waveSize.value) * 2) {\n          this.active = false;\n        }\n      }\n\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      this.shockWaveMaterial.uniforms.aspect.value = width / height;\n    }\n  }]);\n\n  inherits(ShockWavePass, _Pass);\n\n  return ShockWavePass;\n}(Pass);\n\n// Generated with SMAASearchImageData.generate().toCanvas().toDataURL(), not cropped, low dynamic range.\nvar searchImageDataURL = \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEIAAAAhCAAAAABIXyLAAAAAOElEQVRIx2NgGAWjYBSMglEwEICREYRgFBZBqDCSLA2MGPUIVQETE9iNUAqLR5gIeoQKRgwXjwAAGn4AtaFeYLEAAAAASUVORK5CYII\";\n\n// Generated with SMAAAreaImageData.generate().toCanvas().toDataURL().\nvar areaImageDataURL = \"data:image/png;base64,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\";\n\n/**\r\n * Subpixel Morphological Antialiasing (SMAA) v2.8.\r\n *\r\n * Preset: SMAA 1x Medium (with color edge detection).\r\n *  https://github.com/iryoku/smaa/releases/tag/v2.8\r\n */\n\nvar SMAAPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new SMAA pass.\r\n   *\r\n   * @param {Image} searchImage - The SMAA search image. Preload this image using the {@link searchImageDataURL}.\r\n   * @param {Image} areaImage - The SMAA area image. Preload this image using the {@link areaImageDataURL}.\r\n   */\n  function SMAAPass(searchImage, areaImage) {\n    var _this;\n\n    classCallCheck(this, SMAAPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(SMAAPass).call(this, \"SMAAPass\"));\n    /**\r\n     * A clear pass for the color edges buffer.\r\n     *\r\n     * @type {ClearPass}\r\n     * @private\r\n     */\n\n    _this.clearPass = new ClearPass({\n      clearColor: new Color(0x000000),\n      clearAlpha: 1.0\n    });\n    /**\r\n     * A render target for the color edge detection.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetColorEdges = new WebGLRenderTarget(1, 1, {\n      minFilter: LinearFilter,\n      format: RGBFormat,\n      stencilBuffer: false,\n      depthBuffer: false\n    });\n    _this.renderTargetColorEdges.texture.name = \"SMAA.ColorEdges\";\n    _this.renderTargetColorEdges.texture.generateMipmaps = false;\n    /**\r\n     * A render target for the SMAA weights.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetWeights = _this.renderTargetColorEdges.clone();\n    _this.renderTargetWeights.texture.name = \"SMAA.Weights\";\n    _this.renderTargetWeights.texture.format = RGBAFormat;\n    /**\r\n     * Color edge detection shader material.\r\n     *\r\n     * @type {ColorEdgesMaterial}\r\n     * @private\r\n     */\n\n    _this.colorEdgesMaterial = new ColorEdgesMaterial();\n    /**\r\n     * SMAA weights shader material.\r\n     *\r\n     * @type {SMAAWeightsMaterial}\r\n     * @private\r\n     */\n\n    _this.weightsMaterial = new SMAAWeightsMaterial();\n    _this.weightsMaterial.uniforms.tDiffuse.value = _this.renderTargetColorEdges.texture;\n    /**\r\n     * The SMAA search texture.\r\n     *\r\n     * @type {Texture}\r\n     * @private\r\n     */\n\n    _this.searchTexture = new Texture(searchImage);\n    _this.searchTexture.name = \"SMAA.Search\";\n    _this.searchTexture.magFilter = NearestFilter;\n    _this.searchTexture.minFilter = NearestFilter;\n    _this.searchTexture.format = RGBAFormat;\n    _this.searchTexture.generateMipmaps = false;\n    _this.searchTexture.needsUpdate = true;\n    _this.searchTexture.flipY = false;\n    _this.weightsMaterial.uniforms.tSearch.value = _this.searchTexture;\n    /**\r\n     * The SMAA area texture.\r\n     *\r\n     * @type {Texture}\r\n     * @private\r\n     */\n\n    _this.areaTexture = new Texture(areaImage);\n    _this.areaTexture.name = \"SMAA.Area\";\n    _this.areaTexture.minFilter = LinearFilter;\n    _this.areaTexture.format = RGBAFormat;\n    _this.areaTexture.generateMipmaps = false;\n    _this.areaTexture.needsUpdate = true;\n    _this.areaTexture.flipY = false;\n    _this.weightsMaterial.uniforms.tArea.value = _this.areaTexture;\n    /**\r\n     * SMAA blend shader material.\r\n     *\r\n     * @type {SMAABlendMaterial}\r\n     * @private\r\n     */\n\n    _this.blendMaterial = new SMAABlendMaterial();\n    _this.blendMaterial.uniforms.tWeights.value = _this.renderTargetWeights.texture;\n    return _this;\n  }\n  /**\r\n   * Renders the effect.\r\n   *\r\n   * @param {WebGLRenderer} renderer - The renderer.\r\n   * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n   * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n   * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n   * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n   */\n\n\n  createClass(SMAAPass, [{\n    key: \"render\",\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      // Detect color edges.\n      this.material = this.colorEdgesMaterial;\n      this.colorEdgesMaterial.uniforms.tDiffuse.value = inputBuffer.texture;\n      this.clearPass.render(renderer, this.renderTargetColorEdges);\n      renderer.render(this.scene, this.camera, this.renderTargetColorEdges); // Compute edge weights.\n\n      this.material = this.weightsMaterial;\n      renderer.render(this.scene, this.camera, this.renderTargetWeights); // Apply the antialiasing filter to the colors.\n\n      this.material = this.blendMaterial;\n      this.blendMaterial.uniforms.tDiffuse.value = inputBuffer.texture;\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n    /**\r\n     * Updates the size of this pass.\r\n     *\r\n     * @param {Number} width - The width.\r\n     * @param {Number} height - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      this.renderTargetColorEdges.setSize(width, height);\n      this.renderTargetWeights.setSize(width, height);\n      this.colorEdgesMaterial.uniforms.texelSize.value.copy(this.weightsMaterial.uniforms.texelSize.value.copy(this.blendMaterial.uniforms.texelSize.value.set(1.0 / width, 1.0 / height)));\n    }\n    /**\r\n     * The SMAA search image, encoded as a base64 data URL.\r\n     *\r\n     * Use this image data to create an Image instance and use it together with\r\n     * the area image to create an SMAAPass.\r\n     *\r\n     * @type {String}\r\n     * @example\r\n     * const searchImage = new Image();\r\n     * searchImage.addEventListener(\"load\", progress);\r\n     * searchImage.src = SMAAPass.searchImageDataURL;\r\n     */\n\n  }], [{\n    key: \"searchImageDataURL\",\n    get: function get() {\n      return searchImageDataURL;\n    }\n    /**\r\n     * The SMAA area image, encoded as a base64 data URL.\r\n     *\r\n     * Use this image data to create an Image instance and use it together with\r\n     * the search image to create an SMAAPass.\r\n     *\r\n     * @type {String}\r\n     * @example\r\n     * const areaImage = new Image();\r\n     * areaImage.addEventListener(\"load\", progress);\r\n     * areaImage.src = SMAAPass.areaImageDataURL;\r\n     */\n\n  }, {\n    key: \"areaImageDataURL\",\n    get: function get() {\n      return areaImageDataURL;\n    }\n  }]);\n\n  inherits(SMAAPass, _Pass);\n\n  return SMAAPass;\n}(Pass);\n\n/**\r\n * A pass that renders a given texture.\r\n */\n\nvar TexturePass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new texture pass.\r\n   *\r\n   * @param {Texture} texture - The texture.\r\n   * @param {Number} [opacity=1.0] - The texture opacity.\r\n   * @param {Boolean} [screenMode=true] - Whether the screen blend mode should be used for combining the texture with the scene colors.\r\n   */\n  function TexturePass(texture) {\n    var _this;\n\n    var opacity = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1.0;\n    var screenMode = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n\n    classCallCheck(this, TexturePass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(TexturePass).call(this, \"TexturePass\"));\n    _this.material = new CombineMaterial(screenMode);\n    _this.texture = texture;\n    _this.opacitySource = opacity;\n    return _this;\n  }\n  /**\r\n   * The texture.\r\n   *\r\n   * @type {Texture}\r\n   */\n\n\n  createClass(TexturePass, [{\n    key: \"render\",\n\n    /**\r\n     * Renders the effect.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      this.material.uniforms.texture1.value = inputBuffer.texture;\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n  }, {\n    key: \"texture\",\n    get: function get() {\n      return this.material.uniforms.texture2.value;\n    }\n    /**\r\n     * @type {Texture}\r\n     */\n    ,\n    set: function set(value) {\n      this.material.uniforms.texture2.value = value;\n    }\n    /**\r\n     * The opacity of the input buffer.\r\n     *\r\n     * The destination color is the color from the image in the input buffer.\r\n     *\r\n     * @type {Number}\r\n     */\n\n  }, {\n    key: \"opacityDestination\",\n    get: function get() {\n      return this.material.uniforms.opacity1.value;\n    }\n    /**\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1.0;\n      this.material.uniforms.opacity1.value = value;\n    }\n    /**\r\n     * The opacity of the texture.\r\n     *\r\n     * The source color is the color from the texture.\r\n     *\r\n     * @type {Number}\r\n     */\n\n  }, {\n    key: \"opacitySource\",\n    get: function get() {\n      return this.material.uniforms.opacity2.value;\n    }\n    /**\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1.0;\n      this.material.uniforms.opacity2.value = value;\n    }\n  }]);\n\n  inherits(TexturePass, _Pass);\n\n  return TexturePass;\n}(Pass);\n\n/**\r\n * A tone mapping pass that supports adaptive luminosity.\r\n *\r\n * If adaptivity is enabled, this pass generates a texture that represents the\r\n * luminosity of the current scene and adjusts it over time to simulate the\r\n * optic nerve responding to the amount of light it is receiving.\r\n *\r\n * Reference:\r\n *  GDC2007 - Wolfgang Engel, Post-Processing Pipeline\r\n *  http://perso.univ-lyon1.fr/jean-claude.iehl/Public/educ/GAMA/2007/gdc07/Post-Processing_Pipeline.pdf\r\n */\n\nvar ToneMappingPass =\n/*#__PURE__*/\nfunction (_Pass) {\n  /**\r\n   * Constructs a new tone mapping pass.\r\n   *\r\n   * @param {Object} [options] - The options.\r\n   * @param {Boolean} [options.adaptive=true] - Whether the tone mapping should use an adaptive luminance map.\r\n   * @param {Number} [options.resolution=256] - The render texture resolution.\r\n   * @param {Number} [options.distinction=1.0] - A luminance distinction factor.\r\n   */\n  function ToneMappingPass() {\n    var _this;\n\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, ToneMappingPass);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(ToneMappingPass).call(this, \"ToneMappingPass\"));\n    /**\r\n     * The render target for the current luminosity.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     * @todo Use RED format in WebGL 2.0.\r\n     */\n\n    _this.renderTargetLuminosity = new WebGLRenderTarget(1, 1, {\n      minFilter: LinearMipMapLinearFilter,\n      magFilter: LinearFilter,\n      format: RGBFormat,\n      stencilBuffer: false,\n      depthBuffer: false\n    });\n    _this.renderTargetLuminosity.texture.name = \"ToneMapping.Luminosity\";\n    /**\r\n     * The render target for adapted luminosity.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetAdapted = _this.renderTargetLuminosity.clone();\n    _this.renderTargetAdapted.texture.name = \"ToneMapping.AdaptedLuminosity\";\n    _this.renderTargetAdapted.texture.generateMipmaps = false;\n    _this.renderTargetAdapted.texture.minFilter = LinearFilter;\n    /**\r\n     * A render target that holds a copy of the adapted limonosity.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    _this.renderTargetPrevious = _this.renderTargetAdapted.clone();\n    _this.renderTargetPrevious.texture.name = \"ToneMapping.PreviousLuminosity\";\n    /**\r\n     * Copy shader material used for saving the luminance map.\r\n     *\r\n     * @type {CopyMaterial}\r\n     * @private\r\n     */\n\n    _this.copyMaterial = new CopyMaterial();\n    /**\r\n     * A luminosity shader material.\r\n     *\r\n     * @type {LuminosityMaterial}\r\n     * @private\r\n     */\n\n    _this.luminosityMaterial = new LuminosityMaterial();\n    _this.luminosityMaterial.uniforms.distinction.value = options.distinction !== undefined ? options.distinction : 1.0;\n    /**\r\n     * An adaptive luminance shader material.\r\n     *\r\n     * @type {AdaptiveLuminosityMaterial}\r\n     * @private\r\n     */\n\n    _this.adaptiveLuminosityMaterial = new AdaptiveLuminosityMaterial();\n    _this.resolution = options.resolution;\n    /**\r\n     * A tone mapping shader material.\r\n     *\r\n     * @type {ToneMappingMaterial}\r\n     * @private\r\n     */\n\n    _this.toneMappingMaterial = new ToneMappingMaterial();\n    _this.adaptive = options.adaptive;\n    return _this;\n  }\n  /**\r\n   * The resolution of the render targets.\r\n   *\r\n   * @type {Number}\r\n   */\n\n\n  createClass(ToneMappingPass, [{\n    key: \"render\",\n\n    /**\r\n     * Renders the effect.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {WebGLRenderTarget} inputBuffer - A frame buffer that contains the result of the previous pass.\r\n     * @param {WebGLRenderTarget} outputBuffer - A frame buffer that serves as the output render target unless this pass renders to screen.\r\n     * @param {Number} [delta] - The time between the last frame and the current one in seconds.\r\n     * @param {Boolean} [stencilTest] - Indicates whether a stencil mask is active.\r\n     */\n    value: function render(renderer, inputBuffer, outputBuffer, delta, stencilTest) {\n      var scene = this.scene;\n      var camera = this.camera;\n      var adaptiveLuminosityMaterial = this.adaptiveLuminosityMaterial;\n      var luminosityMaterial = this.luminosityMaterial;\n      var toneMappingMaterial = this.toneMappingMaterial;\n      var copyMaterial = this.copyMaterial;\n      var renderTargetPrevious = this.renderTargetPrevious;\n      var renderTargetLuminosity = this.renderTargetLuminosity;\n      var renderTargetAdapted = this.renderTargetAdapted;\n\n      if (this.adaptive) {\n        // Render the luminance of the current scene into a render target with mipmapping enabled.\n        this.material = luminosityMaterial;\n        luminosityMaterial.uniforms.tDiffuse.value = inputBuffer.texture;\n        renderer.render(scene, camera, renderTargetLuminosity); // Use the new luminance values, the previous luminance and the frame delta to adapt the luminance over time.\n\n        this.material = adaptiveLuminosityMaterial;\n        adaptiveLuminosityMaterial.uniforms.delta.value = delta;\n        adaptiveLuminosityMaterial.uniforms.tPreviousLum.value = renderTargetPrevious.texture;\n        adaptiveLuminosityMaterial.uniforms.tCurrentLum.value = renderTargetLuminosity.texture;\n        renderer.render(scene, camera, renderTargetAdapted); // Copy the new adapted luminance value so that it can be used by the next frame.\n\n        this.material = copyMaterial;\n        copyMaterial.uniforms.tDiffuse.value = renderTargetAdapted.texture;\n        renderer.render(scene, camera, renderTargetPrevious);\n      } // Apply the tone mapping to the colours.\n\n\n      this.material = toneMappingMaterial;\n      toneMappingMaterial.uniforms.tDiffuse.value = inputBuffer.texture;\n      renderer.render(this.scene, this.camera, this.renderToScreen ? null : outputBuffer);\n    }\n    /**\r\n     * Performs initialization tasks.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The renderer.\r\n     * @param {Boolean} alpha - Whether the renderer uses the alpha channel or not.\r\n     */\n\n  }, {\n    key: \"initialize\",\n    value: function initialize(renderer, alpha) {\n      this.material = new MeshBasicMaterial({\n        color: 0x7fffff\n      });\n      renderer.render(this.scene, this.camera, this.renderTargetPrevious);\n      this.material.dispose();\n    }\n  }, {\n    key: \"resolution\",\n    get: function get() {\n      return this.renderTargetLuminosity.width;\n    }\n    /**\r\n     * The resolution of the render targets. Must be a power of two for mipmaps.\r\n     *\r\n     * @type {Number}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 256;\n      // Round the given value to the next power of two.\n      var exponent = Math.max(0, Math.ceil(Math.log2(value)));\n      value = Math.pow(2, exponent);\n      this.renderTargetLuminosity.setSize(value, value);\n      this.renderTargetPrevious.setSize(value, value);\n      this.renderTargetAdapted.setSize(value, value);\n      this.adaptiveLuminosityMaterial.defines.MIP_LEVEL_1X1 = exponent.toFixed(1);\n      this.adaptiveLuminosityMaterial.needsUpdate = true;\n    }\n    /**\r\n     * Whether this pass uses adaptive luminosity.\r\n     *\r\n     * @type {Boolean}\r\n     * @default true\r\n     */\n\n  }, {\n    key: \"adaptive\",\n    get: function get() {\n      return this.toneMappingMaterial.defines.ADAPTED_LUMINANCE !== undefined;\n    }\n    /**\r\n     * Whether this pass should use adaptive luminosity.\r\n     *\r\n     * @type {Boolean}\r\n     */\n    ,\n    set: function set() {\n      var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n\n      if (value) {\n        this.toneMappingMaterial.defines.ADAPTED_LUMINANCE = \"1\";\n        this.toneMappingMaterial.uniforms.luminanceMap.value = this.renderTargetAdapted.texture;\n      } else {\n        delete this.toneMappingMaterial.defines.ADAPTED_LUMINANCE;\n        this.toneMappingMaterial.uniforms.luminanceMap.value = null;\n      }\n\n      this.toneMappingMaterial.needsUpdate = true;\n    }\n    /**\r\n     * Indicates whether dithering is enabled.\r\n     *\r\n     * @type {Boolean}\r\n     */\n\n  }, {\n    key: \"dithering\",\n    get: function get() {\n      return this.toneMappingMaterial.dithering;\n    }\n    /**\r\n     * If enabled, the result will be dithered to remove banding artifacts.\r\n     *\r\n     * @type {Boolean}\r\n     */\n    ,\n    set: function set(value) {\n      if (this.dithering !== value) {\n        this.toneMappingMaterial.dithering = value;\n        this.toneMappingMaterial.needsUpdate = true;\n      }\n    }\n  }]);\n\n  inherits(ToneMappingPass, _Pass);\n\n  return ToneMappingPass;\n}(Pass);\n\n/**\r\n * A compilation of the post processing passes.\r\n *\r\n * @module postprocessing/passes\r\n */\n\n/**\r\n * The EffectComposer may be used in place of a normal WebGLRenderer.\r\n *\r\n * The auto clear behaviour of the provided renderer will be disabled to prevent\r\n * unnecessary clear operations.\r\n *\r\n * It is common practice to use a {@link RenderPass} as the first pass to\r\n * automatically clear the screen and render the scene to a texture for further\r\n * processing.\r\n *\r\n * @implements {Resizable}\r\n * @implements {Disposable}\r\n */\n\nvar EffectComposer =\n/*#__PURE__*/\nfunction () {\n  /**\r\n   * Constructs a new effect composer.\r\n   *\r\n   * @param {WebGLRenderer} [renderer] - The renderer that should be used.\r\n   * @param {Object} [options] - The options.\r\n   * @param {Boolean} [options.depthBuffer=true] - Whether the main render targets should have a depth buffer.\r\n   * @param {Boolean} [options.stencilBuffer=false] - Whether the main render targets should have a stencil buffer.\r\n   * @param {Boolean} [options.depthTexture=false] - Set to true if one of your passes relies on a depth texture.\r\n   */\n  function EffectComposer() {\n    var renderer = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n    var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n    classCallCheck(this, EffectComposer);\n\n    /**\r\n     * The renderer.\r\n     *\r\n     * You may replace the renderer at any time by using\r\n     * {@link EffectComposer#replaceRenderer}.\r\n     *\r\n     * @type {WebGLRenderer}\r\n     */\n    this.renderer = renderer;\n    /**\r\n     * The input buffer.\r\n     *\r\n     * Reading from and writing to the same render target should be avoided.\r\n     * Therefore, two seperate yet identical buffers are used.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    this.inputBuffer = null;\n    /**\r\n     * The output buffer.\r\n     *\r\n     * @type {WebGLRenderTarget}\r\n     * @private\r\n     */\n\n    this.outputBuffer = null;\n\n    if (this.renderer !== null) {\n      this.renderer.autoClear = false;\n      this.inputBuffer = this.createBuffer(options.depthBuffer !== undefined ? options.depthBuffer : true, options.stencilBuffer !== undefined ? options.stencilBuffer : false, options.depthTexture !== undefined ? options.depthTexture : false);\n      this.outputBuffer = this.inputBuffer.clone();\n    }\n    /**\r\n     * A copy pass used for copying masked scenes.\r\n     *\r\n     * @type {ShaderPass}\r\n     * @private\r\n     */\n\n\n    this.copyPass = new ShaderPass(new CopyMaterial());\n    /**\r\n     * The passes.\r\n     *\r\n     * @type {Pass[]}\r\n     * @private\r\n     */\n\n    this.passes = [];\n  }\n  /**\r\n   * The depth texture of the input and output buffers.\r\n   *\r\n   * @type {DepthTexture}\r\n   */\n\n\n  createClass(EffectComposer, [{\n    key: \"replaceRenderer\",\n\n    /**\r\n     * Replaces the current renderer with the given one. The DOM element of the\r\n     * current renderer will automatically be removed from its parent node and the\r\n     * DOM element of the new renderer will take its place.\r\n     *\r\n     * The auto clear mechanism of the provided renderer will be disabled.\r\n     *\r\n     * Switching between renderers allows you to dynamically enable or disable\r\n     * antialiasing.\r\n     *\r\n     * @param {WebGLRenderer} renderer - The new renderer.\r\n     * @return {WebGLRenderer} The old renderer.\r\n     */\n    value: function replaceRenderer(renderer) {\n      var oldRenderer = this.renderer;\n      var parent, oldSize, newSize;\n\n      if (oldRenderer !== null && oldRenderer !== renderer) {\n        this.renderer = renderer;\n        this.renderer.autoClear = false;\n        parent = oldRenderer.domElement.parentNode;\n        oldSize = oldRenderer.getSize();\n        newSize = renderer.getSize();\n\n        if (parent !== null) {\n          parent.removeChild(oldRenderer.domElement);\n          parent.appendChild(renderer.domElement);\n        }\n\n        if (oldSize.width !== newSize.width || oldSize.height !== newSize.height) {\n          this.setSize();\n        }\n      }\n\n      return oldRenderer;\n    }\n    /**\r\n     * Creates a new render target by replicating the renderer's canvas.\r\n     *\r\n     * The created render target uses a linear filter for texel minification and\r\n     * magnification. Its render texture format depends on whether the renderer\r\n     * uses the alpha channel. Mipmaps are disabled.\r\n     *\r\n     * @param {Boolean} depthBuffer - Whether the render target should have a depth buffer.\r\n     * @param {Boolean} stencilBuffer - Whether the render target should have a stencil buffer.\r\n     * @param {Boolean} depthTexture - Whether the render target should have a depth texture.\r\n     * @return {WebGLRenderTarget} A new render target that equals the renderer's canvas.\r\n     */\n\n  }, {\n    key: \"createBuffer\",\n    value: function createBuffer(depthBuffer, stencilBuffer, depthTexture) {\n      var drawingBufferSize = this.renderer.getDrawingBufferSize();\n      var alpha = this.renderer.context.getContextAttributes().alpha;\n      var renderTarget = new WebGLRenderTarget(drawingBufferSize.width, drawingBufferSize.height, {\n        minFilter: LinearFilter,\n        magFilter: LinearFilter,\n        format: alpha ? RGBAFormat : RGBFormat,\n        depthBuffer: depthBuffer,\n        stencilBuffer: stencilBuffer,\n        depthTexture: depthTexture ? new DepthTexture() : null\n      });\n\n      if (depthTexture && stencilBuffer) {\n        renderTarget.depthTexture.format = DepthStencilFormat;\n        renderTarget.depthTexture.type = UnsignedInt248Type;\n      }\n\n      renderTarget.texture.name = \"EffectComposer.Buffer\";\n      renderTarget.texture.generateMipmaps = false;\n      return renderTarget;\n    }\n    /**\r\n     * Adds a pass, optionally at a specific index.\r\n     *\r\n     * @param {Pass} pass - A new pass.\r\n     * @param {Number} [index] - An index at which the pass should be inserted.\r\n     */\n\n  }, {\n    key: \"addPass\",\n    value: function addPass(pass, index) {\n      var renderer = this.renderer;\n      var drawingBufferSize = renderer.getDrawingBufferSize();\n      pass.setSize(drawingBufferSize.width, drawingBufferSize.height);\n      pass.initialize(renderer, renderer.context.getContextAttributes().alpha);\n\n      if (index !== undefined) {\n        this.passes.splice(index, 0, pass);\n      } else {\n        this.passes.push(pass);\n      }\n    }\n    /**\r\n     * Removes a pass.\r\n     *\r\n     * @param {Pass} pass - The pass.\r\n     */\n\n  }, {\n    key: \"removePass\",\n    value: function removePass(pass) {\n      this.passes.splice(this.passes.indexOf(pass), 1);\n    }\n    /**\r\n     * Renders all enabled passes in the order in which they were added.\r\n     *\r\n     * @param {Number} delta - The time between the last frame and the current one in seconds.\r\n     */\n\n  }, {\n    key: \"render\",\n    value: function render(delta) {\n      var passes = this.passes;\n      var copyPass = this.copyPass;\n      var renderer = this.renderer;\n      var inputBuffer = this.inputBuffer;\n      var outputBuffer = this.outputBuffer;\n      var stencilTest = false;\n      var pass, context, state, buffer;\n      var i, l;\n\n      for (i = 0, l = passes.length; i < l; ++i) {\n        pass = passes[i];\n\n        if (pass.enabled) {\n          pass.render(renderer, inputBuffer, outputBuffer, delta, stencilTest);\n\n          if (pass.needsSwap) {\n            if (stencilTest) {\n              copyPass.renderToScreen = pass.renderToScreen;\n              context = renderer.context;\n              state = renderer.state; // Preserve the unaffected pixels.\n\n              state.buffers.stencil.setFunc(context.NOTEQUAL, 1, 0xffffffff);\n              copyPass.render(renderer, inputBuffer, outputBuffer, delta, stencilTest);\n              state.buffers.stencil.setFunc(context.EQUAL, 1, 0xffffffff);\n            }\n\n            buffer = inputBuffer;\n            inputBuffer = outputBuffer;\n            outputBuffer = buffer;\n          }\n\n          if (pass instanceof MaskPass) {\n            stencilTest = true;\n          } else if (pass instanceof ClearMaskPass) {\n            stencilTest = false;\n          }\n        }\n      }\n    }\n    /**\r\n     * Sets the size of the buffers and the renderer's output canvas.\r\n     *\r\n     * Every pass will be informed of the new size. It's up to each pass how that\r\n     * information is used.\r\n     *\r\n     * If no width or height is specified, the render targets and passes will be\r\n     * updated with the current size of the renderer.\r\n     *\r\n     * @param {Number} [width] - The width.\r\n     * @param {Number} [height] - The height.\r\n     */\n\n  }, {\n    key: \"setSize\",\n    value: function setSize(width, height) {\n      var passes = this.passes;\n      var renderer = this.renderer;\n      var size, drawingBufferSize;\n      var i, l;\n\n      if (width === undefined || height === undefined) {\n        size = renderer.getSize();\n        width = size.width;\n        height = size.height;\n      } // Update the logical render size.\n\n\n      renderer.setSize(width, height); // The drawing buffer size takes the device pixel ratio into account.\n\n      drawingBufferSize = renderer.getDrawingBufferSize();\n      this.inputBuffer.setSize(drawingBufferSize.width, drawingBufferSize.height);\n      this.outputBuffer.setSize(drawingBufferSize.width, drawingBufferSize.height);\n\n      for (i = 0, l = passes.length; i < l; ++i) {\n        passes[i].setSize(drawingBufferSize.width, drawingBufferSize.height);\n      }\n    }\n    /**\r\n     * Resets this composer by deleting all passes and creating new buffers.\r\n     */\n\n  }, {\n    key: \"reset\",\n    value: function reset() {\n      var renderTarget = this.createBuffer(this.inputBuffer.depthBuffer, this.inputBuffer.stencilBuffer, this.inputBuffer.depthTexture !== null);\n      this.dispose(); // Reanimate.\n\n      this.inputBuffer = renderTarget;\n      this.outputBuffer = renderTarget.clone();\n      this.copyPass = new ShaderPass(new CopyMaterial());\n    }\n    /**\r\n     * Destroys this composer and all passes.\r\n     *\r\n     * This method deallocates all disposable objects created by the passes. It\r\n     * also deletes the main frame buffers of this composer.\r\n     */\n\n  }, {\n    key: \"dispose\",\n    value: function dispose() {\n      var passes = this.passes;\n      var i, l;\n\n      for (i = 0, l = passes.length; i < l; ++i) {\n        passes[i].dispose();\n      }\n\n      this.passes = [];\n\n      if (this.inputBuffer !== null) {\n        this.inputBuffer.dispose();\n        this.inputBuffer = null;\n      }\n\n      if (this.outputBuffer !== null) {\n        this.outputBuffer.dispose();\n        this.outputBuffer = null;\n      }\n\n      this.copyPass.dispose();\n    }\n  }, {\n    key: \"depthTexture\",\n    get: function get() {\n      return this.inputBuffer.depthTexture;\n    }\n    /**\r\n     * The input and output buffers share a single depth texture. Depth will be\r\n     * written to this texture when something is rendered into one of the buffers\r\n     * and the involved materials have depth write enabled.\r\n     *\r\n     * You may enable this mechanism during the instantiation of the composer or\r\n     * by assigning a DepthTexture instance later on. You may also disable it by\r\n     * assigning null.\r\n     *\r\n     * @type {DepthTexture}\r\n     */\n    ,\n    set: function set(x) {\n      this.inputBuffer.depthTexture = x;\n      this.outputBuffer.depthTexture = x;\n    }\n  }]);\n\n  return EffectComposer;\n}();\n\nvar polyfill = function polyfill(object, method) {\n  var showWarn = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n  if (object[method]) return;\n  if (showWarn) console.warn(\"@PostProcessorModule: pass.\".concat(method, \"() was not found.\"), object);\n\n  object[method] = function () {};\n};\n/**\n * @class PostProcessorModule\n * @category modules/app\n * @param {Object} [params]\n * @memberof module:modules/app\n * @example <caption> Creating a rendering module and passing it to App's modules</caption>\n * new App([\n *   new ElementModule(),\n *   new SceneModule(),\n *   new DefineModule('camera', new WHS.PerspectiveCamera({\n *     position: new THREE.Vector3(0, 6, 18),\n *     far: 10000\n *   })),\n *   new RenderingModule(),\n *   new PostProcessorModule()\n * ]);\n *\n * const processor = app.use('postprocessor');\n *\n * processor\n *   .render()\n *   .pass(new GlitchPass())\n *   .renderToScreen()\n */\n\n\nvar PostProcessorModule =\n/*#__PURE__*/\nfunction () {\n  function PostProcessorModule() {\n    var _this = this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : PostProcessorModule.defaults;\n\n    classCallCheck(this, PostProcessorModule);\n\n    defineProperty$3(defineProperty$3(this, \"currentPass\", null), \"defer\", new Promise(function (resolve) {\n      _this.resolve = resolve;\n    }));\n\n    this.debug = params.debug;\n    this.params = params;\n  }\n\n  createClass(PostProcessorModule, [{\n    key: \"manager\",\n    value: function manager(_manager) {\n      var _this2 = this;\n\n      _manager.define('postprocessor');\n\n      this.effects = _manager.use('rendering').effects;\n      this.renderer = _manager.get('renderer');\n      this.scene = _manager.get('scene');\n      this.camera = _manager.get('camera');\n      this.composer = new EffectComposer(this.renderer, this.params);\n\n      _manager.use('rendering').stop();\n\n      var composer = this.composer;\n      this.renderLoop = new Loop(function (clock) {\n        return composer.render(clock.getDelta());\n      }).start(_manager.handler);\n\n      _manager.update({\n        renderer: function renderer(_renderer) {\n          _this2.composer.replaceRenderer(_renderer);\n        },\n        scene: function scene(_scene) {\n          _this2.scene = _scene;\n        },\n        camera: function camera(_camera) {\n          _this2.camera = _camera;\n        }\n      });\n\n      this.resolve();\n    }\n    /**\n     * @method render\n     * @description Adds RenderPass\n     * @return {this}\n     * @memberof module:modules/app.PostProcessorModule\n     */\n\n  }, {\n    key: \"render\",\n    value: function render() {\n      var _this3 = this;\n\n      this.defer.then(function () {\n        var pass = new RenderPass(_this3.scene, _this3.camera.native); // TODO: Support for effects.\n\n        _this3.composer.addPass(pass);\n\n        _this3.currentPass = pass;\n      });\n      return this;\n    }\n    /**\n     * @method pass\n     * @description Adds your custom pass\n     * @param {Pass} pass A custom pass\n     * @return {this}\n     * @memberof module:modules/app.PostProcessorModule\n     */\n\n  }, {\n    key: \"pass\",\n    value: function pass(_pass) {\n      var _this4 = this;\n\n      this.defer.then(function () {\n        polyfill(_pass, 'setSize', _this4.debug);\n        polyfill(_pass, 'initialise', _this4.debug);\n\n        _this4.composer.addPass(_pass);\n\n        _this4.currentPass = _pass;\n      });\n      return this;\n    }\n    /**\n     * @method shader\n     * @description Adds a pass made from shader material\n     * @param {Material} material A ShaderMaterial\n     * @param {String} textureID Name of the readBuffer uniform\n     * @return {this}\n     * @memberof module:modules/app.PostProcessorModule\n     */\n\n  }, {\n    key: \"shader\",\n    value: function shader(material) {\n      var _this5 = this;\n\n      var textureID = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'readBuffer';\n      this.defer.then(function () {\n        if (!material.uniforms[textureID]) material.uniforms[textureID] = {\n          value: null\n        };\n        var pass = new ShaderPass(material, textureID);\n\n        _this5.composer.addPass(pass);\n\n        _this5.currentPass = pass;\n      });\n      return this;\n    }\n    /**\n     * @method get\n     * @description Returns a pass by the given name\n     * @param {String} name The name of the pass\n     * @return {this}\n     * @memberof module:modules/app.PostProcessorModule\n     */\n\n  }, {\n    key: \"get\",\n    value: function get(name) {\n      return name ? this.composer.passes.filter(function (pass) {\n        return pass.name === name;\n      })[0] : this.currentPass;\n    }\n    /**\n     * @method renderToScreen\n     * @description Sets the renderToScreen property of currentPass\n     * @param {String} [name=true] The name of the pass\n     * @return {this}\n     * @memberof module:modules/app.PostProcessorModule\n     */\n\n  }, {\n    key: \"renderToScreen\",\n    value: function renderToScreen() {\n      var _this6 = this;\n\n      var bool = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n      this.defer.then(function () {\n        _this6.currentPass.renderToScreen = bool;\n      });\n      return this;\n    }\n  }]);\n\n  return PostProcessorModule;\n}();\n\ndefineProperty$3(PostProcessorModule, \"defaults\", {\n  debug: true\n});\n\n/**\n * @class EventsPatchModule\n * @description This one is used in the core to handle events used by modules. If you want to make custom events - please make a similar one.\n * @category modules/app\n * @memberof module:modules/app\n */\nvar EventsPatchModule =\n/*#__PURE__*/\nfunction () {\n  function EventsPatchModule() {\n    classCallCheck(this, EventsPatchModule);\n  }\n\n  createClass(EventsPatchModule, [{\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.define('events');\n\n      this.element = _manager.get('renderer').domElement;\n    }\n    /**\n     * @function patchEvents\n     * @description This methods patches the list of events on specific object.\n     * @param {Number} originObject - The object that gives events.\n     * @param {Number} [destObject=this] - The object that takes events.\n     * @param {Array[Strings]} [events=[]] - The list of events by names.\n     * @memberof module:modules/app.EventsPatchModule\n     */\n\n  }, {\n    key: \"patchEvents\",\n    value: function patchEvents(originObject) {\n      var destObject = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this;\n      var events = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];\n      events.forEach(function (event) {\n        return originObject.addEventListener(event, function (e) {\n          return destObject.emit(event, e);\n        });\n      });\n    }\n  }, {\n    key: \"integrate\",\n    value: function integrate(self) {\n      var element = self.element,\n          patchEvents = self.patchEvents;\n      patchEvents(element, this, ['mousemove', 'mouseup', 'contextmenu', 'mousedown', 'click', 'wheel', 'touchstart', 'touchend', 'touchmove', 'keydown', 'keyup', 'keypress']);\n    }\n  }]);\n\n  return EventsPatchModule;\n}();\n\n/**\n * @class VirtualMouseModule\n * @category modules/app\n * @param {Boolean} [globalMovement=false]\n * @memberof module:modules/app\n * @extends Events\n */\n\nvar VirtualMouseModule =\n/*#__PURE__*/\nfunction (_Events) {\n  function VirtualMouseModule() {\n    var _this;\n\n    var globalMovement = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n\n    classCallCheck(this, VirtualMouseModule);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(VirtualMouseModule).call(this));\n\n    defineProperty$3(defineProperty$3(defineProperty$3(defineProperty$3(defineProperty$3(assertThisInitialized(assertThisInitialized(_this)), \"mouse\", new Vector2()), \"raycaster\", new Raycaster()), \"world\", null), \"canvas\", null), \"projectionPlane\", new Plane(new Vector3(0, 0, 1), 0));\n\n    _this.globalMovement = globalMovement;\n    return _this;\n  }\n\n  createClass(VirtualMouseModule, [{\n    key: \"update\",\n    value: function update(e, customX, customY) {\n      var rect = this.canvas.getBoundingClientRect();\n      var x = customX || e.clientX;\n      var y = customY || e.clientY;\n      this.mouse.x = (x - rect.left) / (rect.right - rect.left) * 2 - 1;\n      this.mouse.y = -((y - rect.top) / (rect.bottom - rect.top)) * 2 + 1;\n      this.projectionPlane.normal.copy(this.camera.getWorldDirection());\n      this.raycaster.setFromCamera(this.mouse, this.camera);\n      this.emit('move');\n    }\n  }, {\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.define('mouse');\n\n      _manager.require('events', function () {\n        return new EventsPatchModule();\n      });\n\n      this.canvas = _manager.get('renderer').domElement;\n      this.camera = _manager.get('camera').native;\n    }\n  }, {\n    key: \"integrate\",\n    value: function integrate(self) {\n      var _this2 = this;\n\n      ['click', 'mousedown', 'mouseup', 'mousemove'].forEach(function (ev) {\n        return _this2.on(ev, function (e) {\n          return self.emit(ev, e);\n        });\n      });\n      self.globalX = 0;\n      self.globalY = 0;\n      this.on('mousemove', function (e) {\n        if (document.pointerLockElement !== null) {\n          self.globalX += e.movementX;\n          self.globalY += e.movementY;\n          self.update(e, self.globalX, self.globalY);\n        } else self.update(e);\n      });\n    }\n    /**\n     * @method track\n     * @description Starts tracking events on a component\n     * @param {Component} component A component, that should be tracked by the mouse\n     * @param {Boolean} nested Whether component's children should be tracked or not\n     * @memberof module:modules/app.VirtualMouseModule\n     */\n\n  }, {\n    key: \"track\",\n    value: function track(component) {\n      var _this3 = this;\n\n      var nested = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n      var isHovered = false;\n      this.on('move', function () {\n        if (_this3.hovers(component, nested)) {\n          if (isHovered) component.emit('mousemove');else {\n            component.emit('mouseover');\n            isHovered = true;\n          }\n        } else if (isHovered) {\n          component.emit('mouseout');\n          isHovered = false;\n        }\n      });\n      this.on('click', function () {\n        if (isHovered) component.emit('click');else component.emit('offClick');\n      });\n      this.on('mousedown', function () {\n        if (isHovered) component.emit('mousedown');\n      });\n      this.on('mouseup', function () {\n        if (isHovered) component.emit('mouseup');\n      });\n    }\n    /**\n     * @method intersection\n     * @description Returns an intersection data\n     * @param {Component} component A component that intersects with mouse ray (or doesn't)\n     * @param {Boolean} nested Whether component's children should be tracked or not\n     * @return {Array} intersection data.\n     * @memberof module:modules/app.VirtualMouseModule\n     */\n\n  }, {\n    key: \"intersection\",\n    value: function intersection(_ref) {\n      var native = _ref.native;\n      var nested = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n      if (native.children.length > 0 && nested) {\n        var objects = [];\n        native.traverse(function (child) {\n          return objects.push(child);\n        });\n        return this.raycaster.intersectObjects(objects);\n      }\n\n      return this.raycaster.intersectObject(native);\n    }\n    /**\n     * @method project\n     * @description Returns a vector based on mouse ray intersection with plane\n     * @param {THREE.Plane} [plane=this.projectionPlane] Math plane that is used\n     * @param {Vector3} [target] Optional target\n     * @return {Vector3} An intersection point.\n     * @memberof module:modules/app.VirtualMouseModule\n     */\n\n  }, {\n    key: \"project\",\n    value: function project() {\n      var plane = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.projectionPlane;\n      var target = arguments.length > 1 ? arguments[1] : undefined;\n      return this.raycaster.ray.intersectPlane(plane, target);\n    }\n    /**\n     * @method hovers\n     * @description Returns a boolean based on intersection data (Whether mouse hovers the component)\n     * @param {Component} component A component that intersects with mouse ray (or doesn't)\n     * @param {Boolean} nested Whether component's children should be tracked or not\n     * @return {Boolean} Whether the component is hovered.\n     * @memberof module:modules/app.VirtualMouseModule\n     */\n\n  }, {\n    key: \"hovers\",\n    value: function hovers(component) {\n      var nested = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n      return this.intersection(component, nested).length > 0;\n    }\n    /**\n     * Mouse ray\n     * @member {THREE.Ray} module:modules/app.VirtualMouseModule#ray\n     * @public\n     */\n\n  }, {\n    key: \"ray\",\n    get: function get() {\n      return this.raycaster.ray;\n    }\n    /**\n     * Mouse x [-1; 1]\n     * @member {Number} module:modules/app.VirtualMouseModule#x\n     * @public\n     */\n\n  }, {\n    key: \"x\",\n    get: function get() {\n      return this.mouse.x;\n    }\n    /**\n     * Mouse y [-1; 1]\n     * @member {Number} module:modules/app.VirtualMouseModule#y\n     * @public\n     */\n\n  }, {\n    key: \"y\",\n    get: function get() {\n      return this.mouse.y;\n    }\n  }]);\n\n  inherits(VirtualMouseModule, _Events);\n\n  return VirtualMouseModule;\n}(minivents_commonjs);\n\n/**\n * @class ControlsModule\n * @category modules/app\n * @param {Object} [params]\n * @memberof module:modules/app\n * @example <caption> Creating a rendering module and passing it to App's modules</caption>\n * new App([\n *   new ElementModule(),\n *   new SceneModule(),\n *   new DefineModule('camera', new WHS.PerspectiveCamera({\n *     position: new THREE.Vector3(0, 6, 18),\n *     far: 10000\n *   })),\n *   new RenderingModule(),\n *   new ControlsModule.from(new THREE.TrackballControls())\n * ]);\n */\n\nvar ControlsModule =\n/*#__PURE__*/\nfunction () {\n  createClass(ControlsModule, null, [{\n    key: \"from\",\n    value: function from(controls) {\n      return new ControlsModule({\n        controls: controls\n      });\n    }\n  }]);\n\n  function ControlsModule() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, ControlsModule);\n\n    this.params = Object.assign({\n      controls: false,\n      fix: function fix(controls) {\n        return controls;\n      },\n      update: function update(c) {\n        this.controls.update(c.getDelta());\n      }\n    }, params);\n    this.controls = this.params.controls;\n    this.update = this.params.update;\n  }\n\n  createClass(ControlsModule, [{\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.define('controls');\n\n      _manager.require('events', function () {\n        return new EventsPatchModule();\n      });\n    }\n    /**\n     * @method setControls\n     * @description Set working controls\n     * @param {Object} controls Working three.js controls object.\n     * @return {this}\n     * @memberof module:modules/app.ControlsModule\n     */\n\n  }, {\n    key: \"setControls\",\n    value: function setControls(controls) {\n      this.controls = controls;\n      return this;\n    }\n    /**\n     * @method setUpdate\n     * @description Set controls update function\n     * @param {Function} update Update function\n     * @return {this}\n     * @memberof module:modules/app.ControlsModule\n     */\n\n  }, {\n    key: \"setUpdate\",\n    value: function setUpdate(update) {\n      this.update = update;\n      return this;\n    }\n  }, {\n    key: \"integrate\",\n    value: function integrate(self) {\n      self.updateLoop = new Loop(self.update.bind(self));\n      self.updateLoop.start(this);\n    }\n  }]);\n\n  return ControlsModule;\n}();\n\n/**\n * @class FogModule\n * @category modules/app\n * @param {Object} [params={color: 0xefd1b5, density: 0.020, near: 10, far: 1000}] - The parameters object.\n * @param {String} [type=exp2] - The type of fog - exp2 or linear\n * @memberof module:modules/app\n * @example <caption>How to create and apply a FogModule</caption>\n * const fogModule = new FogModule({\n *    color: 0xffffff,\n *    density: 0.03,\n *    near: 20,\n *    far: 200\n *  }, 'exp2');\n *\n * new App([\n *  ...,\n *  fogModule\n * ]);\n */\n\nvar FogModule =\n/*#__PURE__*/\nfunction () {\n  function FogModule() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n    var type = arguments.length > 1 ? arguments[1] : undefined;\n\n    classCallCheck(this, FogModule);\n\n    this.params = Object.assign({\n      color: 0xefd1b5,\n      density: 0.020,\n      near: 10,\n      far: 1000\n    }, params);\n    if (!type || type === 'exp2') this.fog = new FogExp2(this.params.color, this.params.density);else if (type === 'linear') this.fog = new Fog(this.params.color, this.params.near, this.params.far);\n  }\n\n  createClass(FogModule, [{\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.set('fog', this.fog);\n\n      _manager.get('scene').fog = this.fog;\n    }\n  }]);\n\n  return FogModule;\n}();\n\nvar isEqualDefault = function isEqualDefault(a, b) {\n  if (a === b) return true;else if (a && a.equals && a.equals(b)) return true;\n  return false;\n};\n/**\n * @class StateModule\n * @description `StateModule` is useful for apps, where you need state manipulation.\n * This can be: _transitions between screens, games, development moments_.\n * You can check [basic/state](https://whs-dev.surge.sh/examples/?basic/state) example.\n * @category modules/app\n * @param {Object} [params]\n * @memberof module:modules/app\n * @example <caption> Creating a state module</caption>\n * new App([\n *   // ...\n *   new StateModule().default({\n *     sphereColor: 0xff0000\n *   })\n * ]);\n */\n\n\nvar StateModule =\n/*#__PURE__*/\nfunction () {\n  createClass(StateModule, null, [{\n    key: \"actionGenerate\",\n    value: function actionGenerate(isEqual) {\n      return function () {\n        var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [{}, ''];\n\n        var _ref = arguments.length > 1 ? arguments[1] : undefined,\n            key = _ref.key,\n            data = _ref.data;\n\n        if (isEqual(state[0][key], data)) return state;\n        state[0][key] = data;\n        state[1] = key;\n        return state;\n      };\n    }\n  }]);\n\n  function StateModule() {\n    var equalCheck = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : isEqualDefault;\n\n    classCallCheck(this, StateModule);\n\n    this.store = createStore(StateModule.actionGenerate(equalCheck));\n    this.configuration = {};\n    this.currentConfig = 'default';\n    this.prevConfig = 'default';\n  }\n  /**\n   * @method default\n   * @description Add default configuration.\n   * @param {Object} data Configuration setup\n   * @memberof module:modules/app.StateModule\n   * @example\n   * new WHS.StateModule().default({\n   *   sphereColor: UTILS.$colors.mesh,\n   *   planeColor: 0x447F8B\n   * })\n   */\n\n\n  createClass(StateModule, [{\n    key: \"default\",\n    value: function _default(data) {\n      this.config({\n        default: data\n      });\n      return this;\n    }\n    /**\n     * @method setEqualCheck\n     * @description Sets an equalCheck function\n     * @param {Function} func function to generate equal check\n     * @memberof module:modules/app.StateModule\n     */\n\n  }, {\n    key: \"setEqualCheck\",\n    value: function setEqualCheck(func) {\n      this.store.replaceReducer(StateModule.actionGenerate(func));\n    }\n  }, {\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.define('state');\n    }\n    /**\n     * @method config\n     * @description Load configurations from object.\n     * @param {Object} configs Configuration data\n     * @memberof module:modules/app.StateModule\n     * @example <caption> Adding `green` configuration</caption>\n     * state.config({\n     *   green: {\n     *     sphereColor: 0x00ff00,\n     *     planeColor: 0x00ff00\n     *   }\n     * });\n     */\n\n  }, {\n    key: \"config\",\n    value: function config(configs) {\n      for (var key in configs) {\n        if (key) {\n          this.configuration[key] = key === 'default' ? configs[key] : Object.assign({}, this.configuration.default, configs[key]);\n        }\n      }\n    }\n    /**\n     * @method update\n     * @description Load updates from object.\n     * @param {Object} updates Updates data\n     * @memberof module:modules/app.StateModule\n     * @example <caption> Update callback for `sphereColor`</caption>\n     * state.update({\n     *   sphereColor: color => sphere.material.color.setHex(color)\n     * });\n     */\n\n  }, {\n    key: \"update\",\n    value: function update() {\n      var _this = this;\n\n      var updates = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      this.store.subscribe(function () {\n        var _this$store$getState = _this.store.getState(),\n            _this$store$getState2 = slicedToArray(_this$store$getState, 2),\n            data = _this$store$getState2[0],\n            changedKey = _this$store$getState2[1];\n\n        var callback = updates[changedKey];\n        if (callback) callback(data[changedKey]);\n      });\n    }\n    /**\n     * @method to\n     * @description Switch to configuration.\n     * @param {String} configName Configuration name.\n     * @memberof module:modules/app.StateModule\n     * @example <caption> Changes configuration to `green`</caption>\n     * state.to('green');\n     */\n\n  }, {\n    key: \"to\",\n    value: function to(configName) {\n      this.prevConfig = this.currentConfig;\n      this.currentConfig = configName;\n      var config = this.configuration[configName] ? this.configuration[configName] : this.configuration.default;\n      this.set(config);\n    }\n    /**\n     * @method set\n     * @description Set current parameters.\n     * @param {Object} data Configuration parameters.\n     * @memberof module:modules/app.StateModule\n     * @example\n     * state.set({\n     *   sphereColor: 0x00ff00\n     * });\n     */\n\n  }, {\n    key: \"set\",\n    value: function set(data) {\n      for (var key in data) {\n        if (key) this.store.dispatch({\n          type: 'ADD',\n          key: key,\n          data: data[key]\n        });\n      }\n    }\n    /**\n     * @method get\n     * @description Return data of parameter.\n     * @param {String} key Parameter name.\n     * @memberof module:modules/app.StateModule\n     * @example\n     * state.get('sphereColor'); // 0x00ff00\n     */\n\n  }, {\n    key: \"get\",\n    value: function get(key) {\n      return this.store.getState()[0][key];\n    }\n    /**\n     * @method prev\n     * @description Return `trueVal` if `config` match previous configuration, in other case - return `falseVal`.\n     * @param {String} config Configuration name.\n     * @param {Any} trueVal Value returned if condition is truthy.\n     * @param {Any} falseVal Value returned if condition is falsy.\n     * @memberof module:modules/app.StateModule\n     */\n\n  }, {\n    key: \"prev\",\n    value: function prev(config, trueVal, falseVal) {\n      return this.prevConfig === config ? trueVal : falseVal;\n    }\n    /**\n     * @method current\n     * @description Return `trueVal` if `config` match current configuration, in other case - return `falseVal`.\n     * @param {String} config Configuration name.\n     * @param {Any} trueVal Value returned if condition is truthy.\n     * @param {Any} falseVal Value returned if condition is falsy.\n     * @memberof module:modules/app.StateModule\n     */\n\n  }, {\n    key: \"current\",\n    value: function current(config, trueVal, falseVal) {\n      return this.currentConfig === config ? trueVal : falseVal;\n    }\n  }]);\n\n  return StateModule;\n}();\n\n// Unlike TrackballControls, it maintains the \"up\" direction object.up (+Y by default).\n//\n//    Orbit - left mouse / touch: one finger move\n//    Zoom - middle mouse, or mousewheel / touch: two finger spread or squish\n//    Pan - right mouse, or arrow keys / touch: three finter swipe\n\nvar ThreeOrbitControls =\n/*#__PURE__*/\nfunction (_EventDispatcher) {\n  function ThreeOrbitControls(object, domElement, eventHandler) {\n    var _this;\n\n    classCallCheck(this, ThreeOrbitControls);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(ThreeOrbitControls).call(this));\n    _this.object = object;\n    _this.domElement = domElement === undefined ? document : domElement;\n    _this.eventHandler = eventHandler; // Set to false to disable this control\n\n    _this.enabled = true; // \"target\" sets the location of focus, where the object orbits around\n\n    _this.target = new Vector3(); // How far you can dolly in and out ( PerspectiveCamera only )\n\n    _this.minDistance = 0;\n    _this.maxDistance = Infinity; // How far you can zoom in and out ( OrthographicCamera only )\n\n    _this.minZoom = 0;\n    _this.maxZoom = Infinity; // How far you can orbit vertically, upper and lower limits.\n    // Range is 0 to Math.PI radians.\n\n    _this.minPolarAngle = 0; // radians\n\n    _this.maxPolarAngle = Math.PI; // radians\n    // How far you can orbit horizontally, upper and lower limits.\n    // If set, must be a sub-interval of the interval [ - Math.PI, Math.PI ].\n\n    _this.minAzimuthAngle = -Infinity; // radians\n\n    _this.maxAzimuthAngle = Infinity; // radians\n    // Set to true to enable damping (inertia)\n    // If damping is enabled, you must call controls.update() in your animation loop\n\n    _this.enableDamping = false;\n    _this.dampingFactor = 0.25; // This option actually enables dollying in and out; left as \"zoom\" for backwards compatibility.\n    // Set to false to disable zooming\n\n    _this.enableZoom = true;\n    _this.zoomSpeed = 1.0; // Set to false to disable rotating\n\n    _this.enableRotate = true;\n    _this.rotateSpeed = 1.0; // Set to false to disable panning\n\n    _this.enablePan = true;\n    _this.keyPanSpeed = 7.0; // pixels moved per arrow key push\n    // Set to true to automatically rotate around the target\n    // If auto-rotate is enabled, you must call controls.update() in your animation loop\n\n    _this.autoRotate = false;\n    _this.autoRotateSpeed = 2.0; // 30 seconds per round when fps is 60\n    // Set to false to disable use of the keys\n\n    _this.enableKeys = true; // The four arrow keys\n\n    _this.keys = {\n      LEFT: 37,\n      UP: 38,\n      RIGHT: 39,\n      BOTTOM: 40\n    }; // Mouse buttons\n\n    _this.mouseButtons = {\n      ORBIT: MOUSE.LEFT,\n      ZOOM: MOUSE.MIDDLE,\n      PAN: MOUSE.RIGHT\n    }; // for reset\n\n    _this.target0 = _this.target.clone();\n    _this.position0 = _this.object.position.clone();\n    _this.zoom0 = _this.object.zoom; //\n    // public methods\n    //\n\n    _this.getPolarAngle = function () {\n      return spherical.phi;\n    };\n\n    _this.getAzimuthalAngle = function () {\n      return spherical.theta;\n    };\n\n    _this.reset = function () {\n      _this.target.copy(_this.target0);\n\n      _this.object.position.copy(_this.position0);\n\n      _this.object.zoom = _this.zoom0;\n\n      _this.object.updateProjectionMatrix();\n\n      _this.dispatchEvent(changeEvent);\n\n      _this.update();\n\n      state = STATE.NONE;\n    }; // this method is exposed, but perhaps it would be better if we can make it private...\n\n\n    _this.update = function () {\n      var offset = new Vector3(); // so camera.up is the orbit axis\n\n      var quat = new Quaternion().setFromUnitVectors(object.up, new Vector3(0, 1, 0));\n      var quatInverse = quat.clone().inverse();\n      var lastPosition = new Vector3();\n      var lastQuaternion = new Quaternion();\n      return function () {\n        var position = _this.object.position;\n        offset.copy(position).sub(_this.target); // rotate offset to \"y-axis-is-up\" space\n\n        offset.applyQuaternion(quat); // angle from z-axis around y-axis\n\n        spherical.setFromVector3(offset);\n        if (_this.autoRotate && state === STATE.NONE) rotateLeft(getAutoRotationAngle());\n        spherical.theta += sphericalDelta.theta;\n        spherical.phi += sphericalDelta.phi; // restrict theta to be between desired limits\n\n        spherical.theta = Math.max(_this.minAzimuthAngle, Math.min(_this.maxAzimuthAngle, spherical.theta)); // restrict phi to be between desired limits\n\n        spherical.phi = Math.max(_this.minPolarAngle, Math.min(_this.maxPolarAngle, spherical.phi));\n        spherical.makeSafe();\n        spherical.radius *= scale; // restrict radius to be between desired limits\n\n        spherical.radius = Math.max(_this.minDistance, Math.min(_this.maxDistance, spherical.radius)); // move target to panned location\n\n        _this.target.add(panOffset);\n\n        offset.setFromSpherical(spherical); // rotate offset back to \"camera-up-vector-is-up\" space\n\n        offset.applyQuaternion(quatInverse);\n        position.copy(_this.target).add(offset);\n\n        _this.object.lookAt(_this.target);\n\n        if (_this.enableDamping === true) {\n          sphericalDelta.theta *= 1 - _this.dampingFactor;\n          sphericalDelta.phi *= 1 - _this.dampingFactor;\n        } else sphericalDelta.set(0, 0, 0);\n\n        scale = 1;\n        panOffset.set(0, 0, 0); // update condition is:\n        // min(camera displacement, camera rotation in radians)^2 > EPS\n        // using small-angle approximation cos(x/2) = 1 - x^2 / 8\n\n        if (zoomChanged || lastPosition.distanceToSquared(_this.object.position) > EPS || 8 * (1 - lastQuaternion.dot(_this.object.quaternion)) > EPS) {\n          _this.dispatchEvent(changeEvent);\n\n          lastPosition.copy(_this.object.position);\n          lastQuaternion.copy(_this.object.quaternion);\n          zoomChanged = false;\n          return true;\n        }\n\n        return false;\n      }();\n    };\n\n    _this.dispose = function () {\n      _this.domElement.removeEventListener('contextmenu', onContextMenu, false);\n\n      _this.domElement.removeEventListener('mousedown', onMouseDown, false);\n\n      _this.domElement.removeEventListener('wheel', onMouseWheel, false);\n\n      _this.domElement.removeEventListener('touchstart', onTouchStart, false);\n\n      _this.domElement.removeEventListener('touchend', onTouchEnd, false);\n\n      _this.domElement.removeEventListener('touchmove', onTouchMove, false);\n\n      document.removeEventListener('mousemove', onMouseMove, false);\n      document.removeEventListener('mouseup', onMouseUp, false);\n      window.removeEventListener('keydown', onKeyDown, false); // this.dispatchEvent( { type: 'dispose' } ); // should this be added here?\n    }; //\n    // internals\n    //\n\n\n    var changeEvent = {\n      type: 'change'\n    };\n    var startEvent = {\n      type: 'start'\n    };\n    var endEvent = {\n      type: 'end'\n    };\n    var STATE = {\n      NONE: -1,\n      ROTATE: 0,\n      DOLLY: 1,\n      PAN: 2,\n      TOUCH_ROTATE: 3,\n      TOUCH_DOLLY: 4,\n      TOUCH_PAN: 5\n    };\n    var state = STATE.NONE;\n    var EPS = 0.000001; // current position in spherical coordinates\n\n    var spherical = new Spherical();\n    var sphericalDelta = new Spherical();\n    var scale = 1;\n    var panOffset = new Vector3();\n    var zoomChanged = false;\n    var rotateStart = new Vector2();\n    var rotateEnd = new Vector2();\n    var rotateDelta = new Vector2();\n    var panStart = new Vector2();\n    var panEnd = new Vector2();\n    var panDelta = new Vector2();\n    var dollyStart = new Vector2();\n    var dollyEnd = new Vector2();\n    var dollyDelta = new Vector2();\n\n    var getAutoRotationAngle = function getAutoRotationAngle() {\n      return 2 * Math.PI / 60 / 60 * _this.autoRotateSpeed;\n    };\n\n    var getZoomScale = function getZoomScale() {\n      return Math.pow(0.95, _this.zoomSpeed);\n    };\n\n    var rotateLeft = function rotateLeft(angle) {\n      sphericalDelta.theta -= angle;\n    };\n\n    var rotateUp = function rotateUp(angle) {\n      sphericalDelta.phi -= angle;\n    };\n\n    var panLeft = function () {\n      var v = new Vector3();\n      return function (distance, objectMatrix) {\n        v.setFromMatrixColumn(objectMatrix, 0); // get X column of objectMatrix\n\n        v.multiplyScalar(-distance);\n        panOffset.add(v);\n      };\n    }();\n\n    var panUp = function () {\n      var v = new Vector3();\n      return function (distance, objectMatrix) {\n        v.setFromMatrixColumn(objectMatrix, 1); // get Y column of objectMatrix\n\n        v.multiplyScalar(distance);\n        panOffset.add(v);\n      };\n    }(); // deltaX and deltaY are in pixels; right and down are positive\n\n\n    var pan = function () {\n      var offset = new Vector3();\n      return function (deltaX, deltaY) {\n        var element = _this.domElement === document ? _this.domElement.body : _this.domElement;\n\n        if (_this.object instanceof PerspectiveCamera) {\n          // perspective\n          var position = _this.object.position;\n          offset.copy(position).sub(_this.target);\n          var targetDistance = offset.length(); // half of the fov is center to top of screen\n\n          targetDistance *= Math.tan(_this.object.fov / 2 * Math.PI / 180.0); // we actually don't use screenWidth, since perspective camera is fixed to screen height\n\n          panLeft(2 * deltaX * targetDistance / element.clientHeight, _this.object.matrix);\n          panUp(2 * deltaY * targetDistance / element.clientHeight, _this.object.matrix);\n        } else if (_this.object instanceof OrthographicCamera) {\n          // orthographic\n          panLeft(deltaX * (_this.object.right - _this.object.left) / _this.object.zoom / element.clientWidth, _this.object.matrix);\n          panUp(deltaY * (_this.object.top - _this.object.bottom) / _this.object.zoom / element.clientHeight, _this.object.matrix);\n        } else {\n          // camera neither orthographic nor perspective\n          console.warn('WARNING: OrbitControlsModule.js encountered an unknown camera type - pan disabled.');\n          _this.enablePan = false;\n        }\n      };\n    }();\n\n    var dollyIn = function dollyIn(dollyScale) {\n      if (_this.object instanceof PerspectiveCamera) scale /= dollyScale;else if (_this.object instanceof OrthographicCamera) {\n        _this.object.zoom = Math.max(_this.minZoom, Math.min(_this.maxZoom, _this.object.zoom * dollyScale));\n\n        _this.object.updateProjectionMatrix();\n\n        zoomChanged = true;\n      } else {\n        console.warn('WARNING: OrbitControlsModule.js encountered an unknown camera type - dolly/zoom disabled.');\n        _this.enableZoom = false;\n      }\n    };\n\n    var dollyOut = function dollyOut(dollyScale) {\n      if (_this.object instanceof PerspectiveCamera) scale *= dollyScale;else if (_this.object instanceof OrthographicCamera) {\n        _this.object.zoom = Math.max(_this.minZoom, Math.min(_this.maxZoom, _this.object.zoom / dollyScale));\n\n        _this.object.updateProjectionMatrix();\n\n        zoomChanged = true;\n      } else {\n        console.warn('WARNING: OrbitControlsModule.js encountered an unknown camera type - dolly/zoom disabled.');\n        _this.enableZoom = false;\n      }\n    }; //\n    // event callbacks - update the object state\n    //\n\n\n    var handleMouseDownRotate = function handleMouseDownRotate(event) {\n      // console.log( 'handleMouseDownRotate' );\n      rotateStart.set(event.clientX, event.clientY);\n    };\n\n    var handleMouseDownDolly = function handleMouseDownDolly(event) {\n      // console.log( 'handleMouseDownDolly' );\n      dollyStart.set(event.clientX, event.clientY);\n    };\n\n    var handleMouseDownPan = function handleMouseDownPan(event) {\n      // console.log( 'handleMouseDownPan' );\n      panStart.set(event.clientX, event.clientY);\n    };\n\n    var handleMouseMoveRotate = function handleMouseMoveRotate(event) {\n      // console.log( 'handleMouseMoveRotate' );\n      rotateEnd.set(event.clientX, event.clientY);\n      rotateDelta.subVectors(rotateEnd, rotateStart);\n      var element = _this.domElement === document ? _this.domElement.body : _this.domElement; // rotating across whole screen goes 360 degrees around\n\n      rotateLeft(2 * Math.PI * rotateDelta.x / element.clientWidth * _this.rotateSpeed); // rotating up and down along whole screen attempts to go 360, but limited to 180\n\n      rotateUp(2 * Math.PI * rotateDelta.y / element.clientHeight * _this.rotateSpeed);\n      rotateStart.copy(rotateEnd);\n\n      _this.update();\n    };\n\n    var handleMouseMoveDolly = function handleMouseMoveDolly(event) {\n      // console.log( 'handleMouseMoveDolly' );\n      dollyEnd.set(event.clientX, event.clientY);\n      dollyDelta.subVectors(dollyEnd, dollyStart);\n      if (dollyDelta.y > 0) dollyIn(getZoomScale());else if (dollyDelta.y < 0) dollyOut(getZoomScale());\n      dollyStart.copy(dollyEnd);\n\n      _this.update();\n    };\n\n    var handleMouseMovePan = function handleMouseMovePan(event) {\n      // console.log( 'handleMouseMovePan' );\n      panEnd.set(event.clientX, event.clientY);\n      panDelta.subVectors(panEnd, panStart);\n      pan(panDelta.x, panDelta.y);\n      panStart.copy(panEnd);\n\n      _this.update();\n    };\n\n    var handleMouseWheel = function handleMouseWheel(event) {\n      // console.log( 'handleMouseWheel' );\n      if (event.deltaY < 0) dollyOut(getZoomScale());else if (event.deltaY > 0) dollyIn(getZoomScale());\n\n      _this.update();\n    };\n\n    var handleKeyDown = function handleKeyDown(event) {\n      // console.log( 'handleKeyDown' );\n      switch (event.keyCode) {\n        case _this.keys.UP:\n          pan(0, _this.keyPanSpeed);\n\n          _this.update();\n\n          break;\n\n        case _this.keys.BOTTOM:\n          pan(0, -_this.keyPanSpeed);\n\n          _this.update();\n\n          break;\n\n        case _this.keys.LEFT:\n          pan(_this.keyPanSpeed, 0);\n\n          _this.update();\n\n          break;\n\n        case _this.keys.RIGHT:\n          pan(-_this.keyPanSpeed, 0);\n\n          _this.update();\n\n          break;\n      }\n    };\n\n    var handleTouchStartRotate = function handleTouchStartRotate(event) {\n      // console.log( 'handleTouchStartRotate' );\n      rotateStart.set(event.touches[0].pageX, event.touches[0].pageY);\n    };\n\n    var handleTouchStartDolly = function handleTouchStartDolly(event) {\n      // console.log( 'handleTouchStartDolly' );\n      var dx = event.touches[0].pageX - event.touches[1].pageX;\n      var dy = event.touches[0].pageY - event.touches[1].pageY;\n      var distance = Math.sqrt(dx * dx + dy * dy);\n      dollyStart.set(0, distance);\n    };\n\n    var handleTouchStartPan = function handleTouchStartPan(event) {\n      // console.log( 'handleTouchStartPan' );\n      panStart.set(event.touches[0].pageX, event.touches[0].pageY);\n    };\n\n    var handleTouchMoveRotate = function handleTouchMoveRotate(event) {\n      // console.log( 'handleTouchMoveRotate' );\n      rotateEnd.set(event.touches[0].pageX, event.touches[0].pageY);\n      rotateDelta.subVectors(rotateEnd, rotateStart);\n      var element = _this.domElement === document ? _this.domElement.body : _this.domElement; // rotating across whole screen goes 360 degrees around\n\n      rotateLeft(2 * Math.PI * rotateDelta.x / element.clientWidth * _this.rotateSpeed); // rotating up and down along whole screen attempts to go 360, but limited to 180\n\n      rotateUp(2 * Math.PI * rotateDelta.y / element.clientHeight * _this.rotateSpeed);\n      rotateStart.copy(rotateEnd);\n\n      _this.update();\n    };\n\n    var handleTouchMoveDolly = function handleTouchMoveDolly(event) {\n      // console.log( 'handleTouchMoveDolly' );\n      var dx = event.touches[0].pageX - event.touches[1].pageX;\n      var dy = event.touches[0].pageY - event.touches[1].pageY;\n      var distance = Math.sqrt(dx * dx + dy * dy);\n      dollyEnd.set(0, distance);\n      dollyDelta.subVectors(dollyEnd, dollyStart);\n      if (dollyDelta.y > 0) dollyOut(getZoomScale());else if (dollyDelta.y < 0) dollyIn(getZoomScale());\n      dollyStart.copy(dollyEnd);\n\n      _this.update();\n    };\n\n    var handleTouchMovePan = function handleTouchMovePan(event) {\n      // console.log( 'handleTouchMovePan' );\n      panEnd.set(event.touches[0].pageX, event.touches[0].pageY);\n      panDelta.subVectors(panEnd, panStart);\n      pan(panDelta.x, panDelta.y);\n      panStart.copy(panEnd);\n\n      _this.update();\n    };\n    // event handlers - FSM: listen for events and reset state\n    //\n\n\n    var onMouseDown = function onMouseDown(event) {\n      if (_this.enabled === false) return;\n      event.preventDefault();\n\n      if (event.button === _this.mouseButtons.ORBIT) {\n        if (_this.enableRotate === false) return;\n        handleMouseDownRotate(event);\n        state = STATE.ROTATE;\n      } else if (event.button === _this.mouseButtons.ZOOM) {\n        if (_this.enableZoom === false) return;\n        handleMouseDownDolly(event);\n        state = STATE.DOLLY;\n      } else if (event.button === _this.mouseButtons.PAN) {\n        if (_this.enablePan === false) return;\n        handleMouseDownPan(event);\n        state = STATE.PAN;\n      }\n\n      if (state !== STATE.NONE) {\n        _this.eventHandler.on('mousemove', onMouseMove, false);\n\n        _this.eventHandler.on('mouseup', onMouseUp, false);\n\n        _this.dispatchEvent(startEvent);\n      }\n    };\n\n    var onMouseMove = function onMouseMove(event) {\n      if (_this.enabled === false) return;\n      event.preventDefault();\n\n      if (state === STATE.ROTATE) {\n        if (_this.enableRotate === false) return;\n        handleMouseMoveRotate(event);\n      } else if (state === STATE.DOLLY) {\n        if (_this.enableZoom === false) return;\n        handleMouseMoveDolly(event);\n      } else if (state === STATE.PAN) {\n        if (_this.enablePan === false) return;\n        handleMouseMovePan(event);\n      }\n    };\n\n    var onMouseUp = function onMouseUp(event) {\n      if (_this.enabled === false) return;\n      document.removeEventListener('mousemove', onMouseMove, false);\n      document.removeEventListener('mouseup', onMouseUp, false);\n\n      _this.dispatchEvent(endEvent);\n\n      state = STATE.NONE;\n    };\n\n    var onMouseWheel = function onMouseWheel(event) {\n      if (_this.enabled === false || _this.enableZoom === false || state !== STATE.NONE && state !== STATE.ROTATE) return;\n      event.preventDefault();\n      event.stopPropagation();\n      handleMouseWheel(event);\n\n      _this.dispatchEvent(startEvent); // not sure why these are here...\n\n\n      _this.dispatchEvent(endEvent);\n    };\n\n    var onKeyDown = function onKeyDown(event) {\n      if (_this.enabled === false || _this.enableKeys === false || _this.enablePan === false) return;\n      handleKeyDown(event);\n    };\n\n    var onTouchStart = function onTouchStart(event) {\n      if (_this.enabled === false) return;\n\n      switch (event.touches.length) {\n        case 1:\n          // one-fingered touch: rotate\n          if (_this.enableRotate === false) return;\n          handleTouchStartRotate(event);\n          state = STATE.TOUCH_ROTATE;\n          break;\n\n        case 2:\n          // two-fingered touch: dolly\n          if (_this.enableZoom === false) return;\n          handleTouchStartDolly(event);\n          state = STATE.TOUCH_DOLLY;\n          break;\n\n        case 3:\n          // three-fingered touch: pan\n          if (_this.enablePan === false) return;\n          handleTouchStartPan(event);\n          state = STATE.TOUCH_PAN;\n          break;\n\n        default:\n          state = STATE.NONE;\n      }\n\n      if (state !== STATE.NONE) _this.dispatchEvent(startEvent);\n    };\n\n    var onTouchMove = function onTouchMove(event) {\n      if (_this.enabled === false) return;\n      event.preventDefault();\n      event.stopPropagation();\n\n      switch (event.touches.length) {\n        case 1:\n          // one-fingered touch: rotate\n          if (_this.enableRotate === false) return;\n          if (state !== STATE.TOUCH_ROTATE) return; // is this needed?...\n\n          handleTouchMoveRotate(event);\n          break;\n\n        case 2:\n          // two-fingered touch: dolly\n          if (_this.enableZoom === false) return;\n          if (state !== STATE.TOUCH_DOLLY) return; // is this needed?...\n\n          handleTouchMoveDolly(event);\n          break;\n\n        case 3:\n          // three-fingered touch: pan\n          if (_this.enablePan === false) return;\n          if (state !== STATE.TOUCH_PAN) return; // is this needed?...\n\n          handleTouchMovePan(event);\n          break;\n\n        default:\n          state = STATE.NONE;\n      }\n    };\n\n    var onTouchEnd = function onTouchEnd(event) {\n      if (_this.enabled === false) return;\n\n      _this.dispatchEvent(endEvent);\n\n      state = STATE.NONE;\n    };\n\n    var onContextMenu = function onContextMenu(event) {\n      event.preventDefault();\n    }; //\n\n\n    _this.eventHandler.on('contextmenu', onContextMenu, false);\n\n    _this.eventHandler.on('mousedown', onMouseDown, false);\n\n    _this.eventHandler.on('wheel', onMouseWheel, false);\n\n    _this.eventHandler.on('touchstart', onTouchStart, false);\n\n    _this.eventHandler.on('touchend', onTouchEnd, false);\n\n    _this.eventHandler.on('touchmove', onTouchMove, false);\n\n    _this.eventHandler.on('keydown', onKeyDown, false); // force an update at start\n\n\n    _this.update();\n\n    return _this;\n  }\n\n  createClass(ThreeOrbitControls, [{\n    key: \"center\",\n    get: function get() {\n      console.warn('OrbitControls: .center has been renamed to .target');\n      return this.target;\n    }\n  }, {\n    key: \"noZoom\",\n    get: function get() {\n      console.warn('OrbitControls: .noZoom has been deprecated. Use .enableZoom instead.');\n      return !this.enableZoom;\n    },\n    set: function set(value) {\n      console.warn('OrbitControls: .noZoom has been deprecated. Use .enableZoom instead.');\n      this.enableZoom = !value;\n    }\n  }, {\n    key: \"noRotate\",\n    get: function get() {\n      console.warn('OrbitControls: .noRotate has been deprecated. Use .enableRotate instead.');\n      return !this.enableRotate;\n    },\n    set: function set(value) {\n      console.warn('OrbitControls: .noRotate has been deprecated. Use .enableRotate instead.');\n      this.enableRotate = !value;\n    }\n  }, {\n    key: \"noPan\",\n    get: function get() {\n      console.warn('OrbitControls: .noPan has been deprecated. Use .enablePan instead.');\n      return !this.enablePan;\n    },\n    set: function set(value) {\n      console.warn('OrbitControls: .noPan has been deprecated. Use .enablePan instead.');\n      this.enablePan = !value;\n    }\n  }, {\n    key: \"noKeys\",\n    get: function get() {\n      console.warn('OrbitControls: .noKeys has been deprecated. Use .enableKeys instead.');\n      return !this.enableKeys;\n    },\n    set: function set(value) {\n      console.warn('OrbitControls: .noKeys has been deprecated. Use .enableKeys instead.');\n      this.enableKeys = !value;\n    }\n  }, {\n    key: \"staticMoving\",\n    get: function get() {\n      console.warn('OrbitControls: .staticMoving has been deprecated. Use .enableDamping instead.');\n      return !this.enableDamping;\n    },\n    set: function set(value) {\n      console.warn('OrbitControls: .staticMoving has been deprecated. Use .enableDamping instead.');\n      this.enableDamping = !value;\n    }\n  }, {\n    key: \"dynamicDampingFactor\",\n    get: function get() {\n      console.warn('OrbitControls: .dynamicDampingFactor has been renamed. Use .dampingFactor instead.');\n      return this.dampingFactor;\n    },\n    set: function set(value) {\n      console.warn('OrbitControls: .dynamicDampingFactor has been renamed. Use .dampingFactor instead.');\n      this.dampingFactor = value;\n    }\n  }]);\n\n  inherits(ThreeOrbitControls, _EventDispatcher);\n\n  return ThreeOrbitControls;\n}(EventDispatcher);\n\n/**\n * @class OrbitControlsModule\n * @category modules/app\n * @param {Object} [params]\n * @param {Object} [params.object=camera] Object to which controls are applied.\n * @param {THREE.Vector3} [params.target=new Vector3()] Controls center vector.\n * @param {Boolean} [params.follow=false] Follow the target\n * @memberof module:modules/app\n * @example <caption> Creating a rendering module and passing it to App's modules</caption>\n * new App([\n *   new ElementModule(),\n *   new SceneModule(),\n *   new DefineModule('camera', new WHS.PerspectiveCamera({\n *     position: new THREE.Vector3(0, 6, 18),\n *     far: 10000\n *   })),\n *   new RenderingModule(),\n *   new OrbitControlsModule()\n * ]);\n */\n\nvar OrbitControlsModule =\n/*#__PURE__*/\nfunction (_ControlsModule) {\n  function OrbitControlsModule() {\n    var _this;\n\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, OrbitControlsModule);\n\n    _this = possibleConstructorReturn(this, getPrototypeOf$2(OrbitControlsModule).call(this, params));\n    _this.params = Object.assign({\n      follow: false,\n      object: null,\n      target: new Vector3()\n    }, params);\n    return _this;\n  }\n\n  createClass(OrbitControlsModule, [{\n    key: \"manager\",\n    value: function manager(_manager) {\n      get$3(getPrototypeOf$2(OrbitControlsModule.prototype), \"manager\", this).call(this, _manager);\n\n      var _this$params = this.params,\n          obj = _this$params.object,\n          follow = _this$params.follow,\n          target = _this$params.target;\n      var object = obj ? obj.native : _manager.get('camera').native;\n      var controls = new ThreeOrbitControls(object, _manager.get('element'), _manager.handler);\n      var updateProcessor = follow ? function (c) {\n        controls.update(c.getDelta());\n        controls.target.copy(target);\n      } : function (c) {\n        controls.update(c.getDelta());\n      };\n      this.setControls(controls);\n      this.setUpdate(updateProcessor);\n\n      _manager.update({\n        camera: function camera(_camera) {\n          if (obj) return;\n          controls.object = _camera.native;\n        },\n        element: function element(_element) {\n          controls.domElement = _element;\n        }\n      });\n\n      controls.target.copy(target);\n    }\n  }]);\n\n  inherits(OrbitControlsModule, _ControlsModule);\n\n  return OrbitControlsModule;\n}(ControlsModule);\n\n/** @module modules/app/controls */\n\n/** @module modules/app */\n\n/**\n * @class DynamicGeometryModule\n * @category modules/mesh\n * @param {Object} [params={attributes: false}] - params\n * @param {Boolean} [patchEvents=true]\n * @memberof module:modules/mesh\n */\nvar DynamicGeometryModule =\n/*#__PURE__*/\nfunction () {\n  function DynamicGeometryModule() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, DynamicGeometryModule);\n\n    this.params = Object.assign({\n      attributes: false\n    }, params);\n  }\n\n  createClass(DynamicGeometryModule, [{\n    key: \"integrate\",\n    value: function integrate(self) {\n      var _this = this;\n\n      var params = self.params;\n\n      this.g_ = function () {\n        var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n        if (this.buildGeometry) {\n          this.native.geometry = this.buildGeometry(this.updateParams({\n            geometry: params\n          }));\n        }\n      };\n\n      if (params.attributes) {\n        var _loop = function _loop(key) {\n          if (key) {\n            Object.defineProperty(_this, \"g_\".concat(key), {\n              get: function get() {\n                return this.native.geometry.parameters[key];\n              },\n              set: function set(value) {\n                this.native.geometry = this.buildGeometry(this.updateParams({\n                  geometry: defineProperty$3({}, key, value)\n                }));\n              },\n              configurable: true,\n              enumerable: true\n            });\n          }\n        };\n\n        for (var key in this.params.geometry) {\n          _loop(key);\n        }\n      }\n    }\n  }]);\n\n  return DynamicGeometryModule;\n}();\n\nvar loader = new TextureLoader();\n/**\n * @class TextureModule\n * @category modules/mesh\n * @description A TextureModule can be applied to any Mesh or Model.\n * @param {Array} [textures] - array of texture objects\n * @memberof module:modules/mesh\n * @example <caption>Creating an instance. url takes a path, or a data object.</caption>\n * var woodTexture = new TextureModule({\n *   url: `${process.assetsPath}/textures/wood.jpg`\n * });\n * @example <caption>More comprehensive example, wood texture applied to a Box.</caption>\n * new Box({\n *   geometry: {\n *     width: 2,\n *     height: 2,\n *     depth: 2\n *   },\n *   modules: [\n *     new TextureModule({\n *       url: `path/to/texture.jpg`,\n *       repeat: new THREE.Vector2(1, 1) // optional\n *     })\n *   ],\n *   material: new THREE.MeshBasicMaterial({\n *     color: 0xffffff\n *   }),\n *   position: [50, 60, 70]\n * }).addTo(app);\n */\n\nvar TextureModule =\n/*#__PURE__*/\nfunction () {\n  createClass(TextureModule, null, [{\n    key: \"load\",\n    value: function load(url) {\n      return new TextureModule({\n        url: url\n      }).textures[0][1];\n    }\n  }]);\n\n  function TextureModule() {\n    var _this = this;\n\n    classCallCheck(this, TextureModule);\n\n    defineProperty$3(defineProperty$3(this, \"textures\", []), \"bridge\", {\n      material: function material(_material, self) {\n        self.textures.forEach(function (texture) {\n          _material[texture[0]] = texture[1];\n        });\n        _material.needsUpdate = true;\n        return _material;\n      }\n    });\n\n    for (var _len = arguments.length, textures = new Array(_len), _key = 0; _key < _len; _key++) {\n      textures[_key] = arguments[_key];\n    }\n\n    textures.forEach(function (_ref) {\n      var url = _ref.url,\n          _ref$type = _ref.type,\n          type = _ref$type === void 0 ? 'map' : _ref$type,\n          _ref$offset = _ref.offset,\n          offset = _ref$offset === void 0 ? new Vector2(0, 0) : _ref$offset,\n          _ref$repeat = _ref.repeat,\n          repeat = _ref$repeat === void 0 ? new Vector2(1, 1) : _ref$repeat,\n          _ref$wrap = _ref.wrap,\n          wrap = _ref$wrap === void 0 ? RepeatWrapping : _ref$wrap,\n          _ref$mapping = _ref.mapping,\n          mapping = _ref$mapping === void 0 ? UVMapping : _ref$mapping,\n          _ref$fix = _ref.fix,\n          fix = _ref$fix === void 0 ? function (tex) {\n        return tex;\n      } : _ref$fix;\n      var texture = loader.load(url);\n\n      if (wrap.length > 0) {\n        texture.wrapS = wrap[0];\n        texture.wrapT = wrap[1];\n      } else texture.wrapS = texture.wrapT = wrap;\n\n      texture.mapping = mapping;\n      texture.offset.copy(offset);\n      texture.repeat.copy(repeat);\n      texture.magFilter = NearestFilter;\n      texture.minFilter = LinearMipMapLinearFilter;\n\n      _this.textures.push([type, fix(texture)]);\n    });\n  }\n\n  return TextureModule;\n}();\n\n/**\n * @class AnimationModule\n * @category modules/mesh\n * @description Convenience module that wraps the <a href='https://threejs.org/docs/#manual/introduction/Animation-system'>three.js animation system</a>\n * @param {App} app - the app\n * @param {Boolean} [isDeferred=false] - set to true if animation should not start automatically\n * @param {Object} [params={speed: 1}] - the params\n * @memberof module:modules/mesh\n * @example <caption>Create animation module and play a given clip of an imported model</caption>\n * const animationModule = new AnimationModule(app, false, {\n *   speed: 1.2 // speed up animation by 20%\n * });\n *\n * new Importer({\n *   parser(geometry, materials) {\n *     // Override parse to generate a skinnedMesh, needed for skinned models\n *     return new THREE.SkinnedMesh(geometry, materials);\n *   },\n *\n *   url: `path/to/model.json`,\n *   useCustomMaterial: true,\n *\n *   material: new THREE.MeshStandardMaterial({\n *     skinning: true\n *   }),\n *\n *   modules: [animationModule]\n * }).addTo(app).then(() => {\n *   // adding model to app returns a promise, so pipe the function to kick off the animation clip\n *   animationModule.play('clipName');\n * });\n */\n\nvar AnimationModule =\n/*#__PURE__*/\nfunction () {\n  function AnimationModule(app, isDeferred) {\n    var params = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n    classCallCheck(this, AnimationModule);\n\n    defineProperty$3(this, \"bridge\", {\n      mesh: function mesh(_mesh, self) {\n        _mesh.geometry.skeleton = _mesh.skeleton;\n        self.mixer = new AnimationMixer(_mesh.geometry);\n        self.clips = _mesh.geometry.animations;\n        return _mesh;\n      }\n    });\n\n    this.params = Object.assign({\n      speed: 1\n    }, params);\n    this.clock = new Clock();\n    this.app = app;\n    this.isDeferred = isDeferred;\n  }\n  /**\n   * @method play\n   * @instance\n   * @description Plays the given clip name\n   * @param {String} clipName - the clip to play\n   * @return {THREE.AnimationAction} Playing action \n   * @memberof module:modules/mesh.AnimationModule\n   */\n\n\n  createClass(AnimationModule, [{\n    key: \"play\",\n    value: function play(clipName) {\n      var clip = AnimationClip.findByName(this.clips, clipName);\n      return this.mixer.clipAction(clip).play();\n    }\n    /**\n     * @method update\n     * @instance\n     * @description Update the mixer (being called on frame animation loop)\n     * @memberof module:modules/mesh.AnimationModule\n     */\n\n  }, {\n    key: \"update\",\n    value: function update() {\n      if (this.mixer) this.mixer.update(this.clock.getDelta() * this.params.speed);\n    }\n  }, {\n    key: \"integrate\",\n    value: function integrate(self) {\n      self.loop = new Loop(function () {\n        self.update();\n      });\n      if (!self.isDeferred) self.loop.start(self.app);\n    }\n  }, {\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.define('animation');\n    }\n  }]);\n\n  return AnimationModule;\n}();\n\n/** @module modules/mesh */\n\n/**\n * @class DefineModule\n * @category modules\n * @param {String} name\n * @param {Object} data\n * @memberof module:modules\n * @example <caption> Creating a DefineModule with PerspectiveCamera as camera module and passing it to App's modules</caption>\n * new App([\n *   // ...\n *   new DefineModule('camera', new PerspectiveCamera())\n * ]);\n */\nvar DefineModule =\n/*#__PURE__*/\nfunction () {\n  function DefineModule(name, data) {\n    classCallCheck(this, DefineModule);\n\n    this.name = name;\n    this.data = data;\n  }\n\n  createClass(DefineModule, [{\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.set(this.name, this.data);\n    }\n  }]);\n\n  return DefineModule;\n}();\n\n/** @module modules */\n\nvar Model =\n/*#__PURE__*/\nfunction (_Importer) {\n  function Model(params) {\n    var _getPrototypeOf2;\n\n    classCallCheck(this, Model);\n\n    console.warn('Model is deprecated. Use Importer instead.');\n\n    if (params.geometry) {\n      params.url = params.geometry.path;\n      params.loader = params.geometry.loader;\n    }\n\n    for (var _len = arguments.length, additional = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n      additional[_key - 1] = arguments[_key];\n    }\n\n    return possibleConstructorReturn(this, (_getPrototypeOf2 = getPrototypeOf$2(Model)).call.apply(_getPrototypeOf2, [this, params].concat(additional)));\n  }\n\n  inherits(Model, _Importer);\n\n  return Model;\n}(Importer);\nvar CameraModule =\n/*#__PURE__*/\nfunction () {\n  function CameraModule() {\n    var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    classCallCheck(this, CameraModule);\n\n    console.warn('CameraModule is deprecated. Use DefineModule instead.');\n    this.camera = new PerspectiveCamera$1(params);\n  }\n\n  createClass(CameraModule, [{\n    key: \"integrate\",\n    value: function integrate(self) {\n      this.add(self.camera);\n    }\n  }, {\n    key: \"manager\",\n    value: function manager(_manager) {\n      _manager.set('camera', this.camera);\n    }\n  }]);\n\n  return CameraModule;\n}();\n\n/**\n * Namespace containing all classes from all modules. Used as global in UMD pattern.\n * @namespace WHS\n * @example <caption>The use of WHS namespace.</caption>\n * new WHS.App() // core\n * new WHS.PerspectiveCamera() // components\n * new WHS.ResizeModule() // modules\n * WHS.extend() // utils\n */\n\nexport { Component, MeshComponent, LightComponent, CameraComponent, App, Loop, ModuleManager, AmbientLight$1 as AmbientLight, DirectionalLight$1 as DirectionalLight, HemisphereLight$1 as HemisphereLight, PointLight$1 as PointLight, SpotLight$1 as SpotLight, AreaLight, CubeCamera$1 as CubeCamera, OrthographicCamera$1 as OrthographicCamera, PerspectiveCamera$1 as PerspectiveCamera, Box, Circle, Cone, Cylinder, Dodecahedron, Extrude, Icosahedron, Lathe, Line$1 as Line, Importer, Octahedron, Parametric, Plane$1 as Plane, Polyhedron, Ring, Shape$1 as Shape, Sphere$1 as Sphere, Tetrahedron, Text, Torus, Torusknot, Tube, Group$1 as Group, extend, instruct, transformData, toArray, ElementModule, RenderingModule, SceneModule, ResizeModule, PostProcessorModule, VirtualMouseModule, EventsPatchModule, ControlsModule, FogModule, StateModule, OrbitControlsModule, DynamicGeometryModule, TextureModule, AnimationModule, DefineModule, Model, CameraModule };\n//# sourceMappingURL=whs.module.js.map\n","// stats.js - http://github.com/mrdoob/stats.js\n(function(f,e){\"object\"===typeof exports&&\"undefined\"!==typeof module?module.exports=e():\"function\"===typeof define&&define.amd?define(e):f.Stats=e()})(this,function(){var f=function(){function e(a){c.appendChild(a.dom);return a}function u(a){for(var d=0;d<c.children.length;d++)c.children[d].style.display=d===a?\"block\":\"none\";l=a}var l=0,c=document.createElement(\"div\");c.style.cssText=\"position:fixed;top:0;left:0;cursor:pointer;opacity:0.9;z-index:10000\";c.addEventListener(\"click\",function(a){a.preventDefault();\nu(++l%c.children.length)},!1);var k=(performance||Date).now(),g=k,a=0,r=e(new f.Panel(\"FPS\",\"#0ff\",\"#002\")),h=e(new f.Panel(\"MS\",\"#0f0\",\"#020\"));if(self.performance&&self.performance.memory)var t=e(new f.Panel(\"MB\",\"#f08\",\"#201\"));u(0);return{REVISION:16,dom:c,addPanel:e,showPanel:u,begin:function(){k=(performance||Date).now()},end:function(){a++;var c=(performance||Date).now();h.update(c-k,200);if(c>g+1E3&&(r.update(1E3*a/(c-g),100),g=c,a=0,t)){var d=performance.memory;t.update(d.usedJSHeapSize/\n1048576,d.jsHeapSizeLimit/1048576)}return c},update:function(){k=this.end()},domElement:c,setMode:u}};f.Panel=function(e,f,l){var c=Infinity,k=0,g=Math.round,a=g(window.devicePixelRatio||1),r=80*a,h=48*a,t=3*a,v=2*a,d=3*a,m=15*a,n=74*a,p=30*a,q=document.createElement(\"canvas\");q.width=r;q.height=h;q.style.cssText=\"width:80px;height:48px\";var b=q.getContext(\"2d\");b.font=\"bold \"+9*a+\"px Helvetica,Arial,sans-serif\";b.textBaseline=\"top\";b.fillStyle=l;b.fillRect(0,0,r,h);b.fillStyle=f;b.fillText(e,t,v);\nb.fillRect(d,m,n,p);b.fillStyle=l;b.globalAlpha=.9;b.fillRect(d,m,n,p);return{dom:q,update:function(h,w){c=Math.min(c,h);k=Math.max(k,h);b.fillStyle=l;b.globalAlpha=1;b.fillRect(0,0,r,m);b.fillStyle=f;b.fillText(g(h)+\" \"+e+\" (\"+g(c)+\"-\"+g(k)+\")\",t,v);b.drawImage(q,d+a,m,n-a,p,d,m,n-a,p);b.fillRect(d+n-a,m,a,p);b.fillStyle=l;b.globalAlpha=.9;b.fillRect(d+n-a,m,a,g((1-h/w)*p))}}};return f});\n","import {Loop} from 'whs';\nimport Stats from 'stats.js';\n\nexport default class StatsModule {\n  static codes = {\n    fps: 0,\n    ms: 1,\n    mb: 2,\n    custom: 3\n  }\n\n  constructor(code = 0) {\n    this.stats = new Stats();\n    this.stats.showPanel(code);\n  }\n\n  manager(manager) {\n    manager.get('container').appendChild(this.stats.dom);\n    manager.add('stats', this.stats, {alias: '$stats'});\n  }\n\n  integrate(self) {\n    const stats = self.stats;\n\n    const preProcess = new Loop(() => stats.begin());\n    const postProcess = new Loop(() => stats.end());\n\n    this.loops.unshift(preProcess);\n    this.loops.push(postProcess);\n\n    // Patch method\n    self.addLoop = function (loop) {\n      return new Promise(resolve => {\n        if (this.loops[this.loops.length - 1] === postProcess) this.loops.pop();\n        this.loops.push(loop);\n        this.loops.push(postProcess);\n        resolve(loop);\n      });\n    };\n\n    preProcess.start();\n    postProcess.start();\n  }\n}\n"],"names":["fn","module","exports","createCommonjsModule","global","Object","prototype","Op","hasOwnProperty","Symbol","$Symbol","iterator","asyncIterator","toStringTag","regeneratorRuntime","runtime","inModule","innerFn","outerFn","self","tryLocsList","Generator","create","protoGenerator","generator","_invoke","makeInvokeMethod","context","wrap","obj","arg","type","call","err","IteratorPrototype","iteratorSymbol","getPrototypeOf","getProto","values","NativeIteratorPrototype","hasOwn","GeneratorFunctionPrototype","GeneratorFunction","Gp","constructor","toStringTagSymbol","displayName","forEach","method","isGeneratorFunction","genFun","ctor","name","mark","setPrototypeOf","__proto__","awrap","__await","resolve","reject","tryCatch","record","result","value","then","invoke","unwrapped","previousPromise","callInvokeWithMethodAndArg","enqueue","defineIteratorMethods","AsyncIterator","asyncIteratorSymbol","async","iter","next","done","GenStateSuspendedStart","state","GenStateExecuting","GenStateCompleted","delegate","maybeInvokeDelegate","delegateResult","ContinueSentinel","sent","_sent","dispatchException","abrupt","GenStateSuspendedYield","undefined","return","info","resultName","nextLoc","toString","locs","tryLoc","entry","catchLoc","finallyLoc","afterLoc","tryEntries","push","completion","pushTryEntry","reset","keys","object","key","reverse","length","pop","iterable","iteratorMethod","isNaN","i","doneResult","Context","skipTempReset","prev","resetTryEntry","charAt","slice","stop","rootEntry","rootRecord","rval","exception","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","delegateYield","Function","g","getOwnPropertyNames","indexOf","hadRuntime","oldRuntime","e","runtimeModule","Math","ceil","floor","it","TO_STRING","that","pos","String","_defined","_toInteger","s","b","l","a","charCodeAt","window","__g","version","__e","core","_core","_aFunction","c","apply","arguments","_isObject","exec","_fails","defineProperty","get","_global","document","document$1","createElement","_descriptors","_domCreate","S","val","valueOf","O","P","Attributes","_anObject","_toPrimitive","_ie8DomDefine","f","bitmap","enumerable","configurable","writable","_propertyDesc","source","$export","F","G","B","W","IS_GLOBAL","PROTOTYPE","IS_STATIC","own","out","IS_FORCED","target","_has","IS_BIND","_ctx","IS_WRAP","C","IS_PROTO","virtual","R","expProto","_hide","U","propertyIsEnumerable","split","min","max","index","min$1","IS_INCLUDES","$this","el","fromIndex","_toIobject","_toLength","_toAbsoluteIndex","SHARED","store","mode","_library","copyright","random","concat","id","px","_shared","shared","_uid","_arrayIncludes","_sharedKey","names","IE_PROTO","arrayIndexOf","_enumBugKeys","defineProperties","Properties","_objectKeys","_objectDp","document$2","documentElement","iframe","style","display","_html","appendChild","src","iframeDocument","contentWindow","open","write","lt","gt","close","createDict","PROTOTYPE$1","Empty","IE_PROTO$1","_objectDps","USE_SYMBOL","$exports","_wks","tag","stat","TAG","def","Constructor","NAME","_objectCreate","_setToStringTag","_toObject","IE_PROTO$2","ObjectProto","Base","DEFAULT","IS_SET","FORCED","_iterCreate","kind","BUGGY","VALUES","proto","ITERATOR","FF_ITERATOR","$native","getMethod","DEF_VALUES","$default","entries","$anyNative","_objectGpo","VALUES_BUG","_iterators","returnThis","methods","KEYS","$entries","_redefine","_export","_stringAt","_iterDefine","iterated","_t","_i","point","$at","Array","_k","Arguments","DOMIterables","Collection","TO_STRING_TAG","_cof","T","tryGet","TAG$1","ARG","callee","forbiddenField","ret","ArrayProto","ITERATOR$1","getIteratorMethod","ITERATOR$2","_classof","core_getIteratorMethod","step","_isArrayIter","iterFn","BREAK","RETURN","_iterCall","D","SPECIES","args","process","setImmediate","clearImmediate","MessageChannel","Dispatch","channel","port","queue","event","run","data","setTask","clearTask","counter","defer","nextTick","now","port2","port1","onmessage","listener","postMessage","addEventListener","importScripts","ONREADYSTATECHANGE","removeChild","setTimeout","set","clear","_task","MutationObserver","WebKitMutationObserver","Promise","process$1","last","notify","isNode","parent","domain","exit","head","enter","flush","Observer","navigator","standalone","createTextNode","observe","node","characterData","toggle","Promise$1","promise","macrotask","task","$$resolve","$$reject","f$1","v","userAgent","x","_newPromiseCapability","promiseCapability","safe","KEY","SPECIES$1","ITERATOR$3","riter","SAFE_CLOSING","skipClosing","arr","_microtask","TypeError","process$2","versions","v8","PROMISE","newGenericPromiseCapability","OwnPromiseCapability","Wrapper","$Promise","empty","isNode$1","_userAgent","isReject","_n","_c","microtask","_v","_s","reaction","ok","fail","exited","handler","_h","onHandleUnhandled","TypeError$1","isThenable","chain","onUnhandled","isUnhandled","console","unhandled","_perform","emit","onunhandledrejection","reason","error","_a","onrejectionhandled","_d","_w","$resolve","wrapper","$reject","USE_NATIVE","executor","_anInstance","Internal","_redefineAll","onFulfilled","onRejected","newPromiseCapability","_speciesConstructor","_setSpecies","r","capability","_iterDetect","all","_forOf","remaining","alreadyCalled","$index","race","onFinally","isFunction","callbackfn","gen","promise$1","_next","_throw","_asyncToGenerator","f$2","getOwnPropertyDescriptor","gOPD","_objectPie","f$3","exp","_objectGopd","_objectSap","isExtensible","preventExtensions","setDesc","META","w","setMeta","FREEZE","meta","NEED","fastKey","getWeak","onFreeze","_meta","f$4","_wksExt","getOwnPropertySymbols","f$5","_objectGops","getSymbols","symbols","isEnum","isArray","hiddenKeys","f$6","_objectGopn","toString$1","getWindowNames","gOPN","f$7","_objectGopnExt","JSON","$JSON","stringify","PROTOTYPE$2","QObject","findChild","dP$1","gOPD$1","ObjectProto$1","protoDesc","AllSymbols","sym","USE_NATIVE$1","$defineProperty","OPSymbols","HIDDEN","_enumKeys","$defineProperties","E","gOPN$1","IS_OP","$set","setSymbolDesc","setter","$getOwnPropertyDescriptor$1","$getOwnPropertyNames","$propertyIsEnumerable","$getOwnPropertySymbols","j","es6Symbols","k","wellKnownSymbols","_wksDefine","SymbolRegistry","keyFor","isSymbol","useSetter","useSimple","$create","_stringify","$replacer","replacer","_isArray","TO_PRIMITIVE","desc","defineProperty$1","defineProperty$2","_defineProperty","keys$1","ownKeys","getOwnPropertySymbols$1","filter","defineProperty$3","_objectSpread","instance","_classCallCheck","test","buggy","check","_setProto","o","p","_setPrototypeOf","setPrototypeOf$1","subClass","superClass","setPrototypeOf$2","_inherits","props","descriptor","protoProps","staticProps","_defineProperties","_createClass","symbol","_typeof2","symbol$1","iterator$1","_typeof","_assertThisInitialized","_typeof_1","_possibleConstructorReturn","_getPrototypeOf","getPrototypeOf$1","extensions","_len","_key","extension","_step","_iteratorNormalCompletion","_iterator","prop","extend","_didIteratorError","_iteratorError","array","instArray","tempObject","guide","instructions","instruct","transformData","Number","EPSILON","pow","isInteger","isFinite","sign","match","assign","nextKey","output","EventDispatcher","_listeners","listeners","hasEventListener","removeEventListener","listenerArray","splice","dispatchEvent","LEFT","MIDDLE","RIGHT","DEG2RAD","PI","RAD2DEG","generateUUID","lut","d0","d1","d2","d3","toUpperCase","clamp","euclideanModulo","n","m","mapLinear","a1","a2","b1","b2","lerp","y","t","smoothstep","smootherstep","randInt","low","high","randFloat","randFloatSpread","range","degToRad","degrees","_Math","radToDeg","radians","isPowerOfTwo","ceilPowerOfTwo","log","LN2","floorPowerOfTwo","Vector2","isVector2","setScalar","scalar","setX","setY","setComponent","getComponent","clone","copy","add","warn","addVectors","addScalar","addScaledVector","sub","subVectors","subScalar","multiply","multiplyScalar","divide","divideScalar","applyMatrix3","elements","clampScalar","minVal","maxVal","clampLength","round","roundToZero","negate","dot","lengthSq","sqrt","manhattanLength","abs","normalize","angle","atan2","distanceTo","distanceToSquared","dy","dx","manhattanDistanceTo","setLength","alpha","lerpVectors","v1","v2","equals","fromArray","offset","toArray","fromBufferAttribute","attribute","getX","getY","rotateAround","center","cos","sin","Matrix4","isMatrix4","n11","n12","n13","n14","n21","n22","n23","n24","n31","n32","n33","n34","n41","n42","n43","n44","te","identity","me","copyPosition","extractBasis","xAxis","yAxis","zAxis","setFromMatrixColumn","makeBasis","z","extractRotation","scaleX","scaleY","scaleZ","makeRotationFromEuler","euler","isEuler","d","order","af","be","bf","ae","cf","de","df","ce","ad","bc","bd","ac","makeRotationFromQuaternion","q","_x","_y","_z","y2","z2","x2","xy","xz","yz","zz","wy","wz","yy","xx","wx","lookAt","eye","up","crossVectors","multiplyMatrices","premultiply","a12","a13","a14","a22","a23","a24","a32","a33","a34","a42","a43","a44","b12","b13","b14","b22","b23","b24","b32","b33","b34","b42","b43","b44","a11","b11","b21","b31","b41","a21","a31","a41","applyToBufferAttribute","count","getZ","applyMatrix4","setXYZ","determinant","transpose","tmp","setPosition","getInverse","throwOnDegenerate","t11","t12","t13","t14","det","msg","detInv","scale","getMaxScaleOnAxis","scaleXSq","scaleYSq","scaleZSq","makeTranslation","makeRotationX","theta","makeRotationY","makeRotationZ","makeRotationAxis","axis","ty","tx","makeScale","makeShear","compose","position","quaternion","decompose","vector","sx","matrix","sy","sz","invSX","invSY","invSZ","setFromRotationMatrix","makePerspective","left","right","top","bottom","near","far","makeOrthographic","h","Quaternion","slerp","qa","qb","qm","slerpFlat","dst","dstOffset","src0","srcOffset0","src1","srcOffset1","y0","z0","w0","x1","y1","z1","w1","x0","dir","sqrSin","len","tDir","onChangeCallback","setFromEuler","update","s1","c2","c3","c1","s2","s3","setFromAxisAngle","halfAngle","m11","m12","m13","m21","m22","m23","m31","m32","m33","trace","setFromUnitVectors","vFrom","vTo","EPS","inverse","conjugate","multiplyQuaternions","qay","qaz","qaw","qby","qbz","qbw","qax","qbx","cosHalfTheta","sinHalfTheta","halfTheta","ratioB","ratioA","onChange","callback","Vector3","isVector3","setZ","multiplyVectors","applyEuler","applyQuaternion","applyAxisAngle","qy","qz","qw","qx","ix","iw","iy","iz","project","camera","projectionMatrix","matrixWorld","unproject","transformDirection","cross","ay","az","by","bz","bx","ax","projectOnVector","projectOnPlane","planeNormal","reflect","normal","angleTo","acos","dz","setFromSpherical","phi","radius","sinPhiRadius","setFromCylindrical","setFromMatrixPosition","setFromMatrixScale","Matrix3","isMatrix3","setFromMatrix4","getNormalMatrix","matrix4","transposeIntoArray","setUvTransform","rotation","cx","cy","rotate","translate","image","mapping","wrapS","wrapT","magFilter","minFilter","format","anisotropy","encoding","textureId","uuid","Texture","DEFAULT_IMAGE","mipmaps","DEFAULT_MAPPING","ClampToEdgeWrapping","LinearFilter","LinearMipMapLinearFilter","RGBAFormat","UnsignedByteType","repeat","matrixAutoUpdate","generateMipmaps","premultiplyAlpha","flipY","unpackAlignment","LinearEncoding","onUpdate","UVMapping","isTexture","updateMatrix","toJSON","isRootObject","textures","canvas","createElementNS","width","height","getContext","putImageData","drawImage","toDataURL","metadata","images","url","getDataURL","dispose","transformUv","uv","Vector4","isVector4","setW","setAxisAngleFromQuaternion","setAxisAngleFromRotationMatrix","epsilon","epsilon2","getW","options","scissor","scissorTest","viewport","texture","depthBuffer","stencilBuffer","depthTexture","WebGLRenderTarget","isWebGLRenderTarget","setSize","activeCubeFace","activeMipMapLevel","WebGLRenderTargetCube","isWebGLRenderTargetCube","NearestFilter","DataTexture","isDataTexture","Infinity","Box3","isBox3","setFromArray","minX","minY","minZ","maxX","maxY","maxZ","setFromBufferAttribute","setFromPoints","points","makeEmpty","il","expandByPoint","setFromCenterAndSize","size","halfSize","setFromObject","expandByObject","box","isEmpty","getCenter","getSize","expandByVector","expandByScalar","geometry","isGeometry","vertices","scope","isBufferGeometry","attributes","updateMatrixWorld","traverse","containsPoint","containsBox","getParameter","intersectsBox","intersectsSphere","sphere","clampPoint","closestPoint","intersectsPlane","plane","constant","intersectsTriangle","axes","testAxis","extents","v0","p0","p1","p2","triangle","f0","f1","f2","satForAxes","triangleNormal","distanceToPoint","getBoundingSphere","intersect","union","Sphere","optionalCenter","maxRadiusSq","radiusSum","deltaLengthSq","getBoundingBox","Plane","setComponents","setFromNormalAndCoplanarPoint","setFromCoplanarPoints","inverseNormalLength","distanceToSphere","projectPoint","intersectLine","line","delta","direction","denominator","start","intersectsLine","end","endSign","startSign","coplanarPoint","optionalNormalMatrix","m1","normalMatrix","referencePoint","p3","p4","p5","planes","Frustum","frustum","setFromMatrix","me1","me2","me3","me5","me6","me7","me9","me10","me11","me13","me14","me15","me0","me4","me8","me12","intersectsObject","boundingSphere","computeBoundingSphere","intersectsSprite","sprite","distance","negRadius","alphamap_fragment","alphamap_pars_fragment","alphatest_fragment","aomap_fragment","aomap_pars_fragment","begin_vertex","beginnormal_vertex","bsdfs","bumpmap_pars_fragment","clipping_planes_fragment","clipping_planes_pars_fragment","clipping_planes_pars_vertex","clipping_planes_vertex","color_fragment","color_pars_fragment","color_pars_vertex","color_vertex","common","cube_uv_reflection_fragment","defaultnormal_vertex","displacementmap_pars_vertex","displacementmap_vertex","emissivemap_fragment","emissivemap_pars_fragment","encodings_fragment","encodings_pars_fragment","envmap_fragment","envmap_pars_fragment","envmap_pars_vertex","envmap_vertex","fog_vertex","fog_pars_vertex","fog_fragment","fog_pars_fragment","gradientmap_pars_fragment","lightmap_fragment","lightmap_pars_fragment","lights_lambert_vertex","lights_pars_begin","lights_pars_maps","lights_phong_fragment","lights_phong_pars_fragment","lights_physical_fragment","lights_physical_pars_fragment","lights_fragment_begin","lights_fragment_maps","lights_fragment_end","logdepthbuf_fragment","logdepthbuf_pars_fragment","logdepthbuf_pars_vertex","logdepthbuf_vertex","map_fragment","map_pars_fragment","map_particle_fragment","map_particle_pars_fragment","metalnessmap_fragment","metalnessmap_pars_fragment","morphnormal_vertex","morphtarget_pars_vertex","morphtarget_vertex","normal_fragment_begin","normal_fragment_maps","normalmap_pars_fragment","packing","premultiplied_alpha_fragment","project_vertex","dithering_fragment","dithering_pars_fragment","roughnessmap_fragment","roughnessmap_pars_fragment","shadowmap_pars_fragment","shadowmap_pars_vertex","shadowmap_vertex","shadowmask_pars_fragment","skinbase_vertex","skinning_pars_vertex","skinning_vertex","skinnormal_vertex","specularmap_fragment","specularmap_pars_fragment","tonemapping_fragment","tonemapping_pars_fragment","uv_pars_fragment","uv_pars_vertex","uv_vertex","uv2_pars_fragment","uv2_pars_vertex","uv2_vertex","worldpos_vertex","cube_frag","cube_vert","depth_frag","depth_vert","distanceRGBA_frag","distanceRGBA_vert","equirect_frag","equirect_vert","linedashed_frag","linedashed_vert","meshbasic_frag","meshbasic_vert","meshlambert_frag","meshlambert_vert","meshphong_frag","meshphong_vert","meshphysical_frag","meshphysical_vert","normal_frag","normal_vert","points_frag","points_vert","shadow_frag","shadow_vert","merge","uniforms","u","merged","uniforms_src","uniforms_dst","parameter_src","isColor","setRGB","Color","setHex","setStyle","hex","setHSL","hue2rgb","string","parseFloat","color","components","parseInt","handleAlpha","ColorKeywords","copyGammaToLinear","gammaFactor","copyLinearToGamma","safeInverse","convertGammaToLinear","convertLinearToGamma","getHex","getHexString","getHSL","saturation","hue","lightness","getStyle","offsetHSL","hsl","addColors","color1","color2","diffuse","opacity","map","uvTransform","alphaMap","specularmap","specularMap","envmap","envMap","flipEnvMap","reflectivity","refractionRatio","maxMipLevel","aomap","aoMap","aoMapIntensity","lightmap","lightMap","lightMapIntensity","emissivemap","emissiveMap","bumpmap","bumpMap","bumpScale","normalmap","normalMap","normalScale","displacementmap","displacementMap","displacementScale","displacementBias","roughnessmap","roughnessMap","metalnessmap","metalnessMap","gradientmap","gradientMap","fog","fogDensity","fogNear","fogFar","fogColor","lights","ambientLightColor","directionalLights","properties","shadow","shadowBias","shadowRadius","shadowMapSize","directionalShadowMap","directionalShadowMatrix","spotLights","coneCos","penumbraCos","decay","spotShadowMap","spotShadowMatrix","pointLights","shadowCameraNear","shadowCameraFar","pointShadowMap","pointShadowMatrix","hemisphereLights","skyColor","groundColor","rectAreaLights","basic","UniformsUtils","UniformsLib","vertexShader","ShaderChunk","fragmentShader","lambert","emissive","phong","specular","shininess","standard","roughness","metalness","envMapIntensity","dashed","dashSize","totalSize","depth","cube","tCube","tFlip","equirect","tEquirect","distanceRGBA","referencePosition","nearDistance","farDistance","ShaderLib","physical","clearCoat","clearCoatRoughness","gl","bufferType","dynamic","DYNAMIC_DRAW","STATIC_DRAW","createBuffer","bindBuffer","buffer","bufferData","usage","onUploadCallback","FLOAT","UNSIGNED_SHORT","SHORT","UNSIGNED_INT","INT","BYTE","UNSIGNED_BYTE","bytesPerElement","BYTES_PER_ELEMENT","updateRange","bufferSubData","subarray","isInterleavedBufferAttribute","buffers","deleteBuffer","delete","updateBuffer","remove","_order","Euler","DefaultOrder","RotationOrders","asin","setFromQuaternion","setFromVector3","reorder","newOrder","toVector3","optionalResult","mask","Layers","enable","disable","layers","object3DId","children","Object3D","DefaultUp","onRotationChange","onQuaternionChange","modelViewMatrix","DefaultMatrixAutoUpdate","matrixWorldNeedsUpdate","visible","castShadow","receiveShadow","frustumCulled","renderOrder","userData","isObject3D","onBeforeRender","onAfterRender","applyMatrix","setRotationFromAxisAngle","setRotationFromEuler","setRotationFromMatrix","setRotationFromQuaternion","rotateOnAxis","q1","rotateOnWorldAxis","rotateX","rotateY","rotateZ","translateOnAxis","translateX","translateY","translateZ","localToWorld","worldToLocal","isCamera","getObjectById","getObjectByProperty","getObjectByName","child","getWorldPosition","getWorldQuaternion","getWorldScale","getWorldDirection","raycast","traverseVisible","traverseAncestors","force","geometries","materials","shapes","library","element","serialize","parameters","shape","material","uuids","extractFromCache","cache","recursive","parse","matrixWorldInverse","Camera","zoom","view","updateProjectionMatrix","OrthographicCamera","isOrthographicCamera","setViewOffset","fullWidth","fullHeight","enabled","offsetX","offsetY","clearViewOffset","scaleW","zoomW","scaleH","zoomH","materialIndex","vertexNormals","vertexColors","Face3","geometryId","colors","faces","faceVertexUvs","morphTargets","morphNormals","skinWeights","skinIndices","lineDistances","boundingBox","elementsNeedUpdate","verticesNeedUpdate","uvsNeedUpdate","normalsNeedUpdate","colorsNeedUpdate","lineDistancesNeedUpdate","groupsNeedUpdate","Geometry","vertex","face","jl","computeBoundingBox","fromBufferGeometry","uv2","uvs2","positions","normals","tempNormals","uvs","tempUVs","tempUVs2","groups","group","indices","addFace","computeFaceNormals","ab","fl","cb","vC","vB","vA","computeVertexNormals","areaWeighted","vl","computeFlatVertexNormals","computeMorphNormals","__originalFaceNormal","__originalVertexNormals","tmpGeo","faceNormals","faceNormal","dstNormalsFace","dstNormalsVertex","materialIndexOffset","vertexOffset","vertices1","vertices2","faces1","faces2","uvs1","colors1","colors2","vertexCopy","faceCopy","faceVertexNormals","faceVertexColors","uvCopy","mergeMesh","mesh","isMesh","mergeVertices","changes","precisionPoints","precision","verticesMap","unique","faceIndicesToRemove","idx","sortFacesByMaterialIndex","_id","sort","materialIndexSort","newUvs2","newUvs1","faceType","setBit","hasMaterial","hasFaceUv","hasFaceVertexUv","hasFaceNormal","hasFaceVertexNormal","hasFaceColor","hasFaceVertexColor","getUvIndex","getNormalIndex","getColorIndex","normalsHash","hash","colorsHash","uvsHash","kl","uvsCopy","morphTarget","morphNormal","destVertexNormal","srcVertexNormal","itemSize","normalized","BufferAttribute","isBufferAttribute","setArray","setDynamic","copyAt","index1","index2","copyArray","copyColorsArray","copyVector2sArray","vectors","copyVector3sArray","copyVector4sArray","setXY","setXYZW","onUpload","Int8BufferAttribute","Uint8BufferAttribute","Uint8ClampedBufferAttribute","Int16BufferAttribute","Uint16BufferAttribute","Int32BufferAttribute","Uint32BufferAttribute","Float32BufferAttribute","Float64BufferAttribute","DirectGeometry","computeGroups","fromGeometry","morphTargetsLength","morphTargetsPosition","morphNormalsLength","morphTargetsNormal","vertexUvs","hasFaceVertexUv2","hasSkinIndices","hasSkinWeights","bufferGeometryId","morphAttributes","drawRange","BufferGeometry","getIndex","setIndex","arrayMax","addAttribute","getAttribute","removeAttribute","addGroup","clearGroups","setDrawRange","needsUpdate","isPoints","isLine","updateFromObject","__directGeometry","direct","lineDistance","fromDirectGeometry","pB","pC","pA","normalizeNormals","attribute1","attribute2","attributeSize","attributeArray2","attributeArray1","toNonIndexed","array2","geometry2","morphAttribute","widthSegments","heightSegments","depthSegments","BoxGeometry","buildPlane","udir","vdir","gridX","gridY","gridY1","segmentHeight","heightHalf","gridX1","segmentWidth","widthHalf","depthHalf","vertexCounter","numberOfVertices","groupCount","groupStart","BoxBufferGeometry","PlaneGeometry","segment_height","height_half","segment_width","width_half","PlaneBufferGeometry","materialId","blending","NormalBlending","side","FrontSide","flatShading","NoColors","transparent","blendSrc","SrcAlphaFactor","blendDst","OneMinusSrcAlphaFactor","blendEquation","AddEquation","blendSrcAlpha","blendDstAlpha","blendEquationAlpha","depthFunc","LessEqualDepth","depthTest","depthWrite","clippingPlanes","clipIntersection","clipShadows","shadowSide","colorWrite","polygonOffset","polygonOffsetFactor","polygonOffsetUnits","dithering","alphaTest","premultipliedAlpha","overdraw","Material","isMaterial","onBeforeCompile","setValues","newValue","FlatShading","currentValue","isRoot","emissiveIntensity","sizeAttenuation","linewidth","gapSize","wireframe","wireframeLinewidth","wireframeLinecap","wireframeLinejoin","skinning","dstPlanes","srcPlanes","combine","MultiplyOperation","MeshBasicMaterial","isMeshBasicMaterial","defines","clipping","derivatives","fragDepth","drawBuffers","shaderTextureLOD","defaultAttributeValues","index0AttributeName","uniformsNeedUpdate","ShaderMaterial","isShaderMaterial","origin","Ray","ray","at","recast","closestPointToPoint","directionDistance","distanceSqToPoint","distanceSqToSegment","optionalPointOnRay","optionalPointOnSegment","segCenter","segDir","diff","a01","sqrDist","extDet","s0","b0","segExtent","invDet","intersectSphere","tca","radius2","thc","t0","t1","distanceToPlane","intersectPlane","distToPoint","intersectBox","tmax","tymin","tymax","tzmin","tzmax","invdiry","invdirz","invdirx","tmin","intersectTriangle","backfaceCulling","edge1","edge2","DdN","DdQxE2","DdE1xQ","QdN","Line3","distanceSq","closestPointToPointParameter","clampToLine","startP","startEnd","startEnd_startP","startEnd2","Triangle","getNormal","targetLengthSq","getBarycoord","dot00","dot11","dot01","denom","dot02","dot12","invDenom","setFromPointsAndIndices","i0","i1","i2","getArea","getMidpoint","getPlane","projectedPoint","edgeList","minDistance","drawMode","TrianglesDrawMode","updateMorphTargets","Mesh","setDrawMode","morphTargetInfluences","morphTargetDictionary","ml","uv1","uv3","barycoord","raycaster","BackSide","DoubleSide","intersectionPointWorld","checkIntersection","intersectionPoint","intersection","uvA","uvB","uvC","uvIntersection","faceIndex","intersects","inverseMatrix","checkBufferGeometryIntersection","fvB","fvC","isMultiMaterial","faceMaterial","fvA","tl","morphInfluences","influence","tempA","targets","tempB","tempC","uvs_f","renderer","planeMesh","renderList","scene","forceClear","background","setClear","clearColor","clearAlpha","autoClear","autoClearColor","autoClearDepth","autoClearStencil","isCubeTexture","boxMesh","planeCamera","renderBufferDirect","getClearColor","setClearColor","getClearAlpha","setClearAlpha","render","drawArrays","drawArraysInstancedANGLE","maxInstancedCount","setMode","renderInstances","maxAnisotropy","MAX_TEXTURE_MAX_ANISOTROPY_EXT","getShaderPrecisionFormat","VERTEX_SHADER","HIGH_FLOAT","FRAGMENT_SHADER","MEDIUM_FLOAT","getMaxPrecision","maxPrecision","logarithmicDepthBuffer","MAX_TEXTURE_IMAGE_UNITS","MAX_VERTEX_TEXTURE_IMAGE_UNITS","MAX_TEXTURE_SIZE","MAX_CUBE_MAP_TEXTURE_SIZE","MAX_VERTEX_ATTRIBS","MAX_VERTEX_UNIFORM_VECTORS","MAX_VARYING_VECTORS","MAX_FRAGMENT_UNIFORM_VECTORS","maxVertexTextures","vertexTextures","floatFragmentTextures","getMaxAnisotropy","maxTextures","maxTextureSize","maxCubemapSize","maxAttributes","maxVertexUniforms","maxVaryings","maxFragmentUniforms","floatVertexTextures","globalState","numGlobalPlanes","localClippingEnabled","renderingShadows","viewNormalMatrix","uniform","numPlanes","numIntersection","init","enableLocalClipping","projectPlanes","beginShadows","endShadows","resetGlobalState","setState","fromCache","lGlobal","nGlobal","dstArray","clippingState","skipTransform","nPlanes","viewMatrix","flatSize","i4","getExtension","buffergeometry","onGeometryDispose","wireframeAttributes","memory","_bufferGeometry","ELEMENT_ARRAY_BUFFER","geometryAttributes","ARRAY_BUFFER","geometryIndex","getWireframeAttribute","drawElements","drawElementsInstancedANGLE","frame","calls","triangles","lines","instanceCount","TRIANGLES","TRIANGLE_STRIP","TRIANGLE_FAN","LINES","LINE_STRIP","LINE_LOOP","POINTS","programs","autoReset","program","objectInfluences","influencesList","influences","absNumericalSort","getUniforms","setValue","updateList","CubeReflectionMapping","CubeTexture","seq","nBlocks","blockSize","firstElem","arrayCacheF32","arrayCacheI32","allocTextureUnit","uniform1f","addr","uniform1i","uniform2fv","uniform2f","uniform3f","uniform3fv","uniform4fv","uniform4f","uniformMatrix2fv","uniformMatrix3fv","mat3array","uniformMatrix4fv","mat4array","unit","setTexture2D","emptyTexture","setTextureCube","emptyCubeTexture","uniform2iv","uniform3iv","uniform4iv","uniform1fv","uniform1iv","flatten","units","allocTexUnits","activeInfo","getSingularSetter","getPureArraySetter","UniformContainer","StructuredUniform","container","uniformObject","pathLength","path","RePathPart","lastIndex","matchEnd","idIsIndex","subscript","addUniform","getProgramParameter","ACTIVE_UNIFORMS","getActiveUniform","getUniformLocation","parseUniform","WebGLUniforms","setOptional","upload","seqWithValue","join","createShader","shaderSource","shader","compileShader","getShaderParameter","COMPILE_STATUS","getShaderInfoLog","addLineNumbers","functionName","getEncodingComponents","toneMapping","toneMappingName","rendererExtensions","envMapCubeUV","filterEmptyLine","chunks","ACTIVE_ATTRIBUTES","getActiveAttrib","getAttribLocation","replace","numDirLights","numSpotLights","numRectAreaLights","numPointLights","numHemiLights","numClippingPlanes","numClipIntersection","include","pattern","snippet","unroll","code","shadowMapType","PCFShadowMap","shadowMapTypeDefine","PCFSoftShadowMap","envMapTypeDefine","envMapModeDefine","envMapBlendingDefine","generateExtensions","generateDefines","createProgram","prefixFragment","isRawShaderMaterial","prefixVertex","customDefines","customExtensions","supportsVertexTextures","gammaFactorDefine","maxBones","useFog","fogExp","useVertexTexture","doubleSided","flipSided","shadowMapEnabled","physicallyCorrectLights","NoToneMapping","getToneMappingFunction","outputEncoding","mapEncoding","envMapEncoding","emissiveMapEncoding","getTexelDecodingFunction","getTexelEncodingFunction","depthPacking","parseIncludes","replaceLightNums","replaceClippingPlaneNums","unrollLoops","WebGLShader","vertexGlsl","fragmentGlsl","attachShader","glVertexShader","glFragmentShader","bindAttribLocation","linkProgram","getProgramInfoLog","trim","LINK_STATUS","runnable","getError","VALIDATE_STATUS","programLog","vertexLog","fragmentLog","haveDiagnostics","diagnostics","prefix","deleteShader","cachedUniforms","getAttributes","cachedAttributes","fetchAttributeLocations","destroy","deleteProgram","programIdCount","usedTimes","capabilities","MeshDepthMaterial","MeshDistanceMaterial","MeshNormalMaterial","MeshLambertMaterial","MeshPhongMaterial","MeshToonMaterial","MeshStandardMaterial","MeshPhysicalMaterial","LineBasicMaterial","LineDashedMaterial","PointsMaterial","ShadowMaterial","skeleton","bones","nVertexUniforms","nVertexMatrices","gammaOverrideLinear","GammaEncoding","getParameters","shadows","nClipPlanes","nClipIntersection","shaderIDs","isSkinnedMesh","allocateBones","getRenderTarget","shaderID","getTextureEncodingFromMap","currentRenderTarget","gammaOutput","gammaInput","envMapMode","CubeUVReflectionMapping","CubeUVRefractionMapping","isFogExp2","maxMorphTargets","maxMorphNormals","directional","spot","rectArea","hemi","shadowMap","getProgramCode","parameterNames","acquireProgram","pl","programInfo","releaseProgram","renderItemsIndex","opaque","renderItems","renderItem","painterSortStable","reversePainterSortStable","lists","list","light","halfWidth","halfHeight","ambient","intensity","isAmbientLight","isDirectionalLight","vector3","bias","mapSize","directionalLength","isSpotLight","penumbra","spotLength","isRectAreaLight","matrix42","rectAreaLength","isPointLight","pointLength","isHemisphereLight","hemiLength","setup","lightsArray","shadowsArray","spritesArray","shadowLight","setupLights","pushLight","pushShadow","pushSprite","renderStates","renderState","BasicDepthPacking","isMeshDepthMaterial","isMeshDistanceMaterial","_renderer","_objects","_projScreenMatrix","_shadowMapSize","_maxShadowMapSize","_lookTarget","_lightPositionWorld","_MorphingFlag","_SkinningFlag","_NumberOfMaterialVariants","_depthMaterials","_distanceMaterials","_materialCache","RGBADepthPacking","useMorphing","useSkinning","depthMaterial","distanceMaterial","autoUpdate","_state","_gl","BLEND","setTest","setScissorTest","cube2DViewPorts","vpWidth","vpHeight","pars","shadowCamera","isSpotLightShadow","faceCount","shadowMatrix","setRenderTarget","cubeDirections","cubeUps","vpDimensions","_frustum","renderObject","lightPositionWorld","customDepthMaterial","materialVariants","customMaterial","customDistanceMaterial","variantIndex","keyB","keyA","materialsForVariant","cachedMaterial","groupMaterial","getDepthMaterial","CanvasTexture","elementBuffer","vertexBuffer","uvOffset","uvScale","fogType","fogDepth","fillStyle","fillRect","sprites","useProgram","initAttributes","enableAttribute","disableUnusedAttributes","CULL_FACE","vertexAttribPointer","activeTexture","TEXTURE0","isFog","oldFogType","sceneFogType","density","spritePosition","spriteRotation","spriteScale","setBlending","setMask","utils","colorMask","currentColorMask","locked","setLocked","lock","currentColorClear","DEPTH_TEST","depthMask","currentDepthMask","setFunc","currentDepthFunc","NEVER","ALWAYS","LESS","LEQUAL","EQUAL","GEQUAL","GREATER","NOTEQUAL","currentDepthClear","clearDepth","stencilTest","STENCIL_TEST","stencilMask","currentStencilMask","stencilFunc","stencilRef","currentStencilFunc","currentStencilRef","currentStencilFuncMask","setOp","stencilFail","stencilZFail","stencilZPass","currentStencilFail","currentStencilZFail","currentStencilZPass","stencilOp","stencil","currentStencilClear","clearStencil","maxVertexAttributes","MAX_COMBINED_TEXTURE_IMAGE_UNITS","VERSION","glVersion","lineWidthAvailable","createTexture","bindTexture","texParameteri","TEXTURE_MIN_FILTER","NEAREST","TEXTURE_MAG_FILTER","texImage2D","RGBA","emptyTextures","TEXTURE_2D","TEXTURE_CUBE_MAP","TEXTURE_CUBE_MAP_POSITIVE_X","colorBuffer","setFlipSided","setCullFace","CullFaceBack","newAttributes","enabledAttributes","enableVertexAttribArray","attributeDivisors","vertexAttribDivisorANGLE","meshPerAttribute","disableVertexAttribArray","compressedTextureFormats","COMPRESSED_TEXTURE_FORMATS","formats","currentProgram","NoBlending","CustomBlending","currentBlending","currentPremultipledAlpha","blendEquationSeparate","FUNC_ADD","blendFuncSeparate","ONE","blendFunc","SRC_ALPHA","ZERO","ONE_MINUS_SRC_COLOR","ONE_MINUS_SRC_ALPHA","SRC_COLOR","currentBlendEquation","currentBlendSrc","currentBlendDst","currentBlendEquationAlpha","currentBlendSrcAlpha","currentBlendDstAlpha","convert","frontFaceCW","setPolygonOffset","currentFlipSided","frontFace","CW","CCW","cullFace","CullFaceNone","currentCullFace","BACK","CullFaceFront","FRONT","FRONT_AND_BACK","currentLineWidth","lineWidth","factor","POLYGON_OFFSET_FILL","currentPolygonOffsetFactor","currentPolygonOffsetUnits","SCISSOR_TEST","webglSlot","currentTextureSlot","webglType","webglTexture","currentBoundTextures","boundTexture","compressedTexImage2D","currentScissor","currentViewport","enableAttributeAndDivisor","getCompressedTextureFormats","setMaterial","setLineWidth","maxSize","_canvas","generateMipmap","textureProperties","__maxMipLevel","LOG2E","NearestMipMapNearestFilter","NearestMipMapLinearFilter","LINEAR","onTextureDispose","deallocateTexture","isVideoTexture","renderTarget","onRenderTargetDispose","deallocateRenderTarget","__image__webglTextureCube","deleteTexture","__webglInit","__webglTexture","deleteFramebuffer","renderTargetProperties","__webglFramebuffer","__webglDepthbuffer","deleteRenderbuffer","slot","updateVideoTexture","__version","uploadTexture","pixelStorei","UNPACK_FLIP_Y_WEBGL","isCompressedTexture","isCompressed","cubeImage","clampToMaxSize","isPowerOfTwoImage","glFormat","glType","setTextureParameters","mipmap","RGBFormat","textureNeedsGenerateMipmaps","textureType","TEXTURE_WRAP_S","TEXTURE_WRAP_T","CLAMP_TO_EDGE","filterFallback","FloatType","HalfFloatType","__currentAnisotropy","texParameterf","TEXTURE_MAX_ANISOTROPY_EXT","UNPACK_PREMULTIPLY_ALPHA_WEBGL","UNPACK_ALIGNMENT","textureNeedsPowerOfTwo","makePowerOfTwo","isDepthTexture","DEPTH_COMPONENT","_isWebGL2","internalFormat","DEPTH_COMPONENT32F","DEPTH_COMPONENT16","DepthFormat","UnsignedShortType","UnsignedIntType","DepthStencilFormat","DEPTH_STENCIL","UnsignedInt248Type","framebuffer","attachment","textureTarget","bindFramebuffer","FRAMEBUFFER","framebufferTexture2D","renderbuffer","bindRenderbuffer","RENDERBUFFER","renderbufferStorage","framebufferRenderbuffer","DEPTH_ATTACHMENT","DEPTH_STENCIL_ATTACHMENT","RGBA4","isCube","webglDepthTexture","setupDepthTexture","createRenderbuffer","setupRenderBufferStorage","createFramebuffer","isTargetPowerOfTwo","setupFrameBufferTexture","COLOR_ATTACHMENT0","setupDepthRenderbuffer","_videoTextures","setTextureCubeDynamic","setupRenderTarget","updateRenderTargetMipmap","RepeatWrapping","REPEAT","MirroredRepeatWrapping","MIRRORED_REPEAT","NEAREST_MIPMAP_NEAREST","NEAREST_MIPMAP_LINEAR","LinearMipMapNearestFilter","LINEAR_MIPMAP_NEAREST","LINEAR_MIPMAP_LINEAR","UnsignedShort4444Type","UNSIGNED_SHORT_4_4_4_4","UnsignedShort5551Type","UNSIGNED_SHORT_5_5_5_1","UnsignedShort565Type","UNSIGNED_SHORT_5_6_5","ByteType","ShortType","IntType","HALF_FLOAT_OES","AlphaFormat","ALPHA","RGB","LuminanceFormat","LUMINANCE","LuminanceAlphaFormat","LUMINANCE_ALPHA","SubtractEquation","FUNC_SUBTRACT","ReverseSubtractEquation","FUNC_REVERSE_SUBTRACT","ZeroFactor","OneFactor","SrcColorFactor","OneMinusSrcColorFactor","DstAlphaFactor","DST_ALPHA","OneMinusDstAlphaFactor","ONE_MINUS_DST_ALPHA","DstColorFactor","DST_COLOR","OneMinusDstColorFactor","ONE_MINUS_DST_COLOR","SrcAlphaSaturateFactor","SRC_ALPHA_SATURATE","RGB_S3TC_DXT1_Format","RGBA_S3TC_DXT1_Format","RGBA_S3TC_DXT3_Format","RGBA_S3TC_DXT5_Format","COMPRESSED_RGB_S3TC_DXT1_EXT","COMPRESSED_RGBA_S3TC_DXT1_EXT","COMPRESSED_RGBA_S3TC_DXT3_EXT","COMPRESSED_RGBA_S3TC_DXT5_EXT","RGB_PVRTC_4BPPV1_Format","RGB_PVRTC_2BPPV1_Format","RGBA_PVRTC_4BPPV1_Format","RGBA_PVRTC_2BPPV1_Format","COMPRESSED_RGB_PVRTC_4BPPV1_IMG","COMPRESSED_RGB_PVRTC_2BPPV1_IMG","COMPRESSED_RGBA_PVRTC_4BPPV1_IMG","COMPRESSED_RGBA_PVRTC_2BPPV1_IMG","RGB_ETC1_Format","COMPRESSED_RGB_ETC1_WEBGL","RGBA_ASTC_4x4_Format","RGBA_ASTC_5x4_Format","RGBA_ASTC_5x5_Format","RGBA_ASTC_6x5_Format","RGBA_ASTC_6x6_Format","RGBA_ASTC_8x5_Format","RGBA_ASTC_8x6_Format","RGBA_ASTC_8x8_Format","RGBA_ASTC_10x5_Format","RGBA_ASTC_10x6_Format","RGBA_ASTC_10x8_Format","RGBA_ASTC_10x10_Format","RGBA_ASTC_12x10_Format","RGBA_ASTC_12x12_Format","MinEquation","MaxEquation","MIN_EXT","MAX_EXT","UNSIGNED_INT_24_8_WEBGL","fov","aspect","focus","filmGauge","filmOffset","PerspectiveCamera","isPerspectiveCamera","setFocalLength","focalLength","getFilmHeight","atan","vExtentSlope","getFocalLength","tan","getEffectiveFOV","getFilmWidth","skew","cameras","ArrayCamera","isArrayCamera","frameData","VRFrameData","onVRDisplayPresentChange","cameraL","bounds","cameraR","cameraVR","device","isPresenting","currentPixelRatio","getEyeParameters","eyeParameters","renderWidth","renderHeight","getPixelRatio","currentSize","setDrawingBufferSize","userHeight","getDevice","setDevice","setPoseTarget","poseTarget","getCamera","depthNear","depthFar","getFrameData","stageParameters","standingMatrix","sittingToStandingTransform","pose","poseObject","orientation","tempQuaternion","tempPosition","leftViewMatrix","rightViewMatrix","standingMatrixInverse","leftProjectionMatrix","rightProjectionMatrix","getLayers","layer","leftBounds","rightBounds","getStandingMatrix","submitFrame","REVISION","_context","_alpha","_depth","_stencil","_antialias","antialias","_premultipliedAlpha","_preserveDrawingBuffer","preserveDrawingBuffer","_powerPreference","powerPreference","domElement","sortObjects","LinearToneMapping","toneMappingExposure","toneMappingWhitePoint","_isContextLost","_currentRenderTarget","_currentFramebuffer","_currentMaterialId","_currentGeometryProgram","_currentCamera","_currentArrayCamera","_currentViewport","_currentScissor","_currentScissorTest","_usedTextureUnits","_width","_height","_pixelRatio","_viewport","_scissor","_scissorTest","_clipping","_clippingEnabled","_localClippingEnabled","_vector3","onContextLost","onContextRestore","contextAttributes","message","objects","renderLists","morphtargets","bufferRenderer","indexedBufferRenderer","programCache","_this","spriteRenderer","initGLContext","vr","getContextAttributes","forceContextLoss","loseContext","forceContextRestore","restoreContext","setPixelRatio","updateStyle","setViewport","getDrawingBufferSize","pixelRatio","getCurrentViewport","setScissor","boolean","bits","COLOR_BUFFER_BIT","DEPTH_BUFFER_BIT","STENCIL_BUFFER_BIT","clearTarget","stopAnimation","preventDefault","onMaterialDispose","deallocateMaterial","releaseMaterialProgramReference","renderBufferImmediate","hasPositions","hasNormals","hasUvs","hasColors","positionArray","programAttributes","isMeshPhongMaterial","isMeshStandardMaterial","isMeshNormalMaterial","normalArray","nx","ny","nz","uvArray","colorArray","setProgram","geometryProgram","updateBuffers","rangeFactor","setupVertexAttributes","dataCount","rangeStart","rangeCount","drawEnd","drawStart","drawCount","getTargetPixelRatio","isLineSegments","isLineLoop","isInstancedBufferGeometry","programAttribute","geometryAttribute","stride","isInstancedInterleavedBuffer","isInstancedBufferAttribute","materialDefaultAttributeValues","vertexAttrib2fv","vertexAttrib3fv","vertexAttrib4fv","vertexAttrib1fv","compile","currentRenderState","isLight","initMaterial","isAnimating","requestAnimationLoopFrame","requestAnimationFrame","animationLoop","time","onAnimationFrame","animate","startAnimation","currentRenderList","projectObject","overrideMaterial","opaqueObjects","renderObjects","transparentObjects","isSprite","isImmediateRenderObject","camera2","renderObjectImmediate","materialProperties","lightsHash","programChange","numSupportedMorphTargets","numSupportedMorphNormals","uniformsList","progUniforms","useCache","p_uniforms","m_uniforms","refreshProgram","refreshMaterial","refreshLights","cameraPosition","uCamPos","isMeshLambertMaterial","boneTexture","boneMatrices","boneTextureSize","markUniformsLightsNeedsUpdate","refreshUniformsFog","refreshUniformsCommon","refreshUniformsLambert","isMeshToonMaterial","refreshUniformsToon","refreshUniformsPhong","isMeshPhysicalMaterial","refreshUniformsPhysical","refreshUniformsStandard","refreshUniformsDepth","refreshUniformsDistance","refreshUniformsNormal","isLineBasicMaterial","refreshUniformsLine","isLineDashedMaterial","refreshUniformsDash","isPointsMaterial","refreshUniformsPoints","isShadowMaterial","ltc_1","LTC_1","ltc_2","LTC_2","uvScaleMap","textureUnit","warned","setTexture","readRenderTargetPixels","restore","textureFormat","IMPLEMENTATION_COLOR_READ_FORMAT","IMPLEMENTATION_COLOR_READ_TYPE","checkFramebufferStatus","FRAMEBUFFER_COMPLETE","readPixels","copyFramebufferToTexture","level","copyTexImage2D","copyTextureToTexture","srcTexture","dstTexture","texSubImage2D","pixels","FogExp2","Fog","Scene","SpriteMaterial","isSpriteMaterial","Sprite","worldPosition","intersectPoint","worldScale","guessSizeSq","levels","LOD","addLevel","getObjectForDistance","matrixPosition","boneInverses","calculateInverses","Skeleton","bone","isBone","identityMatrix","offsetMatrix","getBoneByName","Bone","bindMode","bindMatrix","bindMatrixInverse","initBones","bind","normalizeSkinWeights","SkinnedMesh","gbone","rotq","scl","sw","skinWeight","vec","linecap","linejoin","Line","computeLineDistances","positionAttribute","linePrecision","vStart","vEnd","interRay","interSegment","distSq","precisionSq","nbVertices","LineSegments","LineLoop","Points","params","threshold","localThreshold","rayPointDistanceSq","localThresholdSq","distanceToRay","testPoint","Group","isGroup","video","VideoTexture","readyState","HAVE_CURRENT_DATA","CompressedTexture","DepthTexture","ol","edges","edge","WireframeGeometry","func","slices","stacks","ParametricGeometry","pv","pu","sliceCount","ParametricBufferGeometry","detail","PolyhedronGeometry","subdivide","appplyRadius","generateUVs","uvBuffer","getVertexByIndex","subdivideFace","cols","rows","aj","bj","pushVertex","azimuth","inclination","correctUVs","correctSeam","centroid","correctUV","azi","PolyhedronBufferGeometry","TetrahedronGeometry","TetrahedronBufferGeometry","OctahedronGeometry","OctahedronBufferGeometry","IcosahedronGeometry","IcosahedronBufferGeometry","DodecahedronGeometry","DodecahedronBufferGeometry","tubularSegments","radialSegments","closed","taper","tangents","bufferGeometry","binormals","TubeGeometry","computeFrenetFrames","frames","generateBufferData","generateSegment","generateIndices","getPointAt","N","TubeBufferGeometry","tube","heightScale","TorusKnotGeometry","calculatePositionOnCurve","P1","P2","quOverP","cs","cu","su","TorusKnotBufferGeometry","arc","TorusGeometry","TorusBufferGeometry","triangulate","holeIndices","dim","outerLen","hasHoles","outerNode","linkedList","invSize","eliminateHoles","earcutLinked","clockwise","signedArea","insertNode","removeNode","again","steiner","area","ear","pass","indexCurve","isEarHashed","isEar","filterPoints","cureLocalIntersections","splitEarcut","pointInTriangle","minTY","maxTX","maxTY","zOrder","minTX","nextZ","prevZ","locallyInside","isValidDiagonal","splitPolygon","getLeftmost","compareX","eliminateHole","hole","findHoleBridge","hx","hy","mx","my","tanMin","sortLinked","tail","numMerges","pSize","qSize","inSize","leftmost","py","intersectsPolygon","middleInside","q2","inside","an","bp","sum","contour","isClockWise","pts","triangulateShape","holes","removeDupEndPts","addContour","holeIndex","Earcut","ExtrudeGeometry","addShape","verticesArray","curveSegments","steps","amount","bevelEnabled","bevelThickness","bevelSize","bevelSegments","extrudePath","UVGenerator","WorldUVGenerator","extrudeByPath","binormal","position2","extrudePts","getSpacedPoints","splineTube","hl","extractPoints","shapePoints","ShapeUtils","ahole","pt","bs","vert","vlen","flen","inPt","inPrev","inNext","v_trans_y","shrink_by","v_prev_y","v_next_y","v_prev_x","v_next_x","collinear0","v_prev_lensq","v_prev_len","v_next_len","ptNextShift_x","ptPrevShift_x","ptNextShift_y","ptPrevShift_y","v_trans_x","sf","v_trans_lensq","direction_eq","contourMovements","getBevelVec","oneHoleMovements","verticesMovements","holesMovements","scalePt2","buildLidFaces","buildSideFaces","f3","sidewalls","layeroffset","sl","slen1","slen2","f4","placeholder","addVertex","uvgen","generateTopUV","nextIndex","addUV","generateSideWallUV","vector2","ExtrudeBufferGeometry","indexA","indexB","indexC","a_x","a_y","b_x","b_y","c_x","c_y","indexD","a_z","b_z","c_z","d_x","d_z","d_y","text","TextGeometry","font","isFont","generateShapes","TextBufferGeometry","phiStart","phiLength","thetaStart","thetaLength","SphereGeometry","verticesRow","grid","thetaEnd","SphereBufferGeometry","innerRadius","outerRadius","thetaSegments","phiSegments","RingGeometry","segment","radiusStep","thetaSegmentLevel","RingBufferGeometry","segments","LatheGeometry","inverseSegments","base","n1","n2","LatheBufferGeometry","ShapeGeometry","shapeHole","shapeVertices","shapeHoles","indexOffset","ShapeBufferGeometry","thresholdAngle","face1","face2","thresholdDot","sourceVertices","EdgesGeometry","radiusTop","radiusBottom","openEnded","CylinderGeometry","generateTorso","generateCap","sinTheta","cosTheta","slope","indexRow","indexArray","centerIndexStart","centerIndexEnd","CylinderBufferGeometry","ConeGeometry","ConeBufferGeometry","CircleGeometry","CircleBufferGeometry","freeze","RawShaderMaterial","files","file","onLoad","onProgress","onError","onStart","itemStart","itemsTotal","isLoading","itemsLoaded","itemEnd","itemError","resolveURL","urlModifier","setURLModifier","transform","manager","DefaultLoadingManager","FileLoader","load","Cache","cached","loading","dataUriRegex","dataUriRegexResult","decodeURIComponent","isBase64","atob","responseType","toLowerCase","response","mimeType","parser","parseFromString","request","status","callbacks","withCredentials","overrideMimeType","requestHeader","setRequestHeader","header","send","setPath","setResponseType","setWithCredentials","setMimeType","_parser","CompressedTextureLoader","loader","texDatas","loaded","mipmapCount","loadTexture","isCubemap","DataTextureLoader","texData","ImageLoader","crossOrigin","substr","setCrossOrigin","CubeTextureLoader","urls","TextureLoader","search","isJPEG","arcLengthDivisions","Curve","getPoint","optionalTarget","getUtoTmapping","getPoints","divisions","getLength","getLengths","lengths","cacheArcLengths","current","updateArcLengths","arcLengths","targetArcLength","comparison","lengthAfter","lengthBefore","segmentLength","segmentFraction","getTangent","t2","pt2","pt1","getTangentAt","MAX_VALUE","tz","mat","fromJSON","json","aX","aY","xRadius","yRadius","aStartAngle","aEndAngle","aClockwise","aRotation","EllipseCurve","isEllipseCurve","deltaAngle","twoPi","samePoints","aRadius","ArcCurve","isArcCurve","c0","initCatmullRom","x3","tension","initNonuniformCatmullRom","dt0","dt1","dt2","calc","t3","curveType","CatmullRomCurve3","isCatmullRomCurve3","intPoint","weight","px$1","pz","QuadraticBezierP1","QuadraticBezierP2","CubicBezierP1","CubicBezierP2","CubicBezierP3","v3","CubicBezierCurve","isCubicBezierCurve","CubicBezier","CubicBezierCurve3","isCubicBezierCurve3","LineCurve","isLineCurve","LineCurve3","isLineCurve3","QuadraticBezierCurve","isQuadraticBezierCurve","QuadraticBezier","QuadraticBezierCurve3","isQuadraticBezierCurve3","SplineCurve","isSplineCurve","CatmullRom","curves","autoClose","CurvePath","curve","closePath","startPoint","endPoint","getCurveLengths","curveLengths","lens","cacheLengths","sums","resolution","currentPoint","Path","moveTo","lineTo","quadraticCurveTo","aCPx","aCPy","bezierCurveTo","aCP1x","aCP1y","aCP2x","aCP2y","splineThru","npts","absarc","absellipse","ellipse","firstPoint","lastPoint","Shape","getPointsHoles","holesPts","Light","HemisphereLight","LightShadow","SpotLightShadow","power","SpotLight","PointLight","DirectionalLightShadow","DirectionalLight","AmbientLight","RectAreaLight","times","interpolation","KeyframeTrack","StringKeyframeTrack","ValueTypeName","ValueBufferType","DefaultInterpolation","InterpolateDiscrete","InterpolantFactoryMethodLinear","InterpolantFactoryMethodSmooth","BooleanKeyframeTrack","parameterPositions","sampleValues","sampleSize","resultBuffer","_cachedIndex","valueSize","Interpolant","evaluate","pp","validate_interval","seek","linear_scan","forward_scan","afterEnd_","giveUpAt","t1global","beforeStart_","mid","intervalChanged_","interpolate_","settings","DefaultSettings_","getSettings_","copySampleValue_","QuaternionLinearInterpolant","QuaternionKeyframeTrack","InterpolateLinear","getValueSize","ColorKeyframeTrack","NumberKeyframeTrack","_weightPrev","_offsetPrev","_weightNext","_offsetNext","CubicInterpolant","endingStart","ZeroCurvatureEnding","endingEnd","iPrev","iNext","tPrev","tNext","halfDt","o1","o0","oP","oN","wP","wN","ppp","sP","sN","LinearInterpolant","offset1","offset0","weight1","weight0","DiscreteInterpolant","arraySlice","from","to","AnimationUtils","isTypedArray","convertArray","forceClone","isView","getKeyframeOrder","compareTime","sortedArray","nValues","srcOffset","flattenJSON","jsonKeys","valuePropertyName","TimeBufferType","setInterpolation","validate","optimize","_getTrackTypeForValueTypeName","trackType","track","getInterpolation","typeName","Float32Array","InterpolantFactoryMethodDiscrete","factoryMethod","createInterpolant","shift","timeOffset","timeScale","startTime","endTime","nKeys","valid","currTime","prevTime","smoothInterpolation","InterpolateSmooth","writeIndex","timeNext","offsetP","offsetN","keep","writeOffset","readOffset","VectorKeyframeTrack","duration","tracks","resetDuration","AnimationClip","jsonTracks","frameTime","fps","clip","clipTracks","CreateFromMorphTargetSequence","morphTargetSequence","noLoop","numMorphTargets","findByName","objectOrClipArray","clipArray","animations","CreateClipsFromMorphTargetSequences","parts","animationToMorphTargets","animationMorphTargets","clips","parseAnimation","animation","trackName","animationKeys","propertyName","destTracks","hierarchy","hierarchyTracks","morphTargetNames","animationKey","morphTargetName","addNonemptyTrack","boneName","clipName","MaterialLoader","setTextures","shading","getTexture","BufferGeometryLoader","typedArray","drawcalls","offsets","Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float64Array","Loader","Handlers","handlers","regex","onLoadStart","onLoadProgress","onLoadComplete","initMaterials","texturePath","createMaterial","AdditiveBlending","SubtractiveBlending","MultiplyBlending","fullPath","textureLoader","BlendingMode","mapDiffuseRepeat","mapDiffuseOffset","mapDiffuseWrap","mapDiffuseAnisotropy","mapEmissiveRepeat","mapEmissiveOffset","mapEmissiveWrap","mapEmissiveAnisotropy","mapLightRepeat","mapLightOffset","mapLightWrap","mapLightAnisotropy","mapAORepeat","mapAOOffset","mapAOWrap","mapAOAnisotropy","mapBumpRepeat","mapBumpOffset","mapBumpWrap","mapBumpAnisotropy","mapNormalRepeat","mapNormalOffset","mapNormalWrap","mapNormalAnisotropy","mapSpecularRepeat","mapSpecularOffset","mapSpecularWrap","mapSpecularAnisotropy","mapMetalnessRepeat","mapMetalnessOffset","mapMetalnessWrap","mapMetalnessAnisotropy","mapRoughnessRepeat","mapRoughnessOffset","mapRoughnessWrap","mapRoughnessAnisotropy","mapAlphaRepeat","mapAlphaOffset","mapAlphaWrap","mapAlphaAnisotropy","VertexColors","FaceColors","materialLoader","decodeText","decode","fromCharCode","escape","extractUrlBase","lastIndexOf","JSONLoader","LoaderUtils","setTexturePath","fi","zLength","colorIndex","normalIndex","uvIndex","isQuad","faceA","faceB","uvLayer","nUvLayers","isBitSet","influencesPerVertex","srcVertices","dstVertices","morphColors","outputAnimations","morphAnimationClips","parseModel","parseSkin","parseMorphing","parseAnimations","ObjectLoader","substring","parseShape","parseGeometries","parseImages","parseTextures","parseMaterials","parseObject","details","geometryShapes","bufferGeometryLoader","geometryLoader","loadImage","parseConstant","TEXTURE_MAPPING","TEXTURE_WRAPPING","TEXTURE_FILTER","getGeometry","getMaterial","CubeRefractionMapping","EquirectangularReflectionMapping","EquirectangularRefractionMapping","SphericalReflectionMapping","subPaths","currentPath","ShapePath","toShapes","isCCW","noHoles","inSubpaths","tmpShape","tmpPath","inPolygon","polyLen","edgeHighPt","edgeLowPt","edgeDy","edgeDx","perpEdge","holesFirst","newShapes","mainIdx","newShapeHoles","tmpPoints","solid","sLen","sIdx","betterShapeHoles","hIdx","sho","s2Idx","isPointInsidePolygon","ho","toChange","froms","tos","hole_unassigned","ambiguous","tmpHoles","Font","createPaths","paths","yMax","yMin","underlineThickness","chars","char","line_height","createPath","glyphs","glyph","cpx","cpy","cpx1","cpy1","cpx2","cpy2","_cachedOutline","outline","action","ha","FontLoader","AudioContext","webkitAudioContext","setContext","AudioLoader","decodeAudioData","audioBuffer","eyeSep","StereoCamera","xmax","eyeLeft","eyeRight","xmin","ymax","eyeSepOnProjection","cubeResolution","cameraPX","cameraNX","cameraPY","cameraNY","cameraPZ","cameraNZ","CubeCamera","gain","createGain","connect","destination","AudioListener","getInput","removeFilter","disconnect","getFilter","setFilter","getMasterVolume","setMasterVolume","setTargetAtTime","currentTime","positionX","setValueAtTime","positionY","positionZ","forwardX","forwardY","forwardZ","upX","upY","upZ","setOrientation","autoplay","loop","playbackRate","isPlaying","hasPlaybackControl","sourceType","filters","Audio","getOutput","setNodeSource","audioNode","setBuffer","play","createBufferSource","onended","onEnded","pause","getFilters","setFilters","setPlaybackRate","getPlaybackRate","getLoop","setLoop","getVolume","setVolume","panner","createPanner","PositionalAudio","getRefDistance","refDistance","setRefDistance","getRolloffFactor","rolloffFactor","setRolloffFactor","getDistanceModel","distanceModel","setDistanceModel","getMaxDistance","maxDistance","setMaxDistance","audio","fftSize","analyser","createAnalyser","frequencyBinCount","AudioAnalyser","getFrequencyData","getByteFrequencyData","getAverageFrequency","binding","mixFunction","_slerp","_select","_lerp","_mixBufferRegion","cumulativeWeight","useCount","referenceCount","PropertyMixer","accumulate","accuIndex","currentWeight","mix","originalValueOffset","saveOriginalState","getValue","restoreOriginalState","targetGroup","optionalParsedPath","PropertyBinding","parseTrackName","_targetGroup","_bindings","subscribe_","parsedPath","Composite","nCachedObjects_","firstValidIndex","bindings","unbind","rootNode","findNode","nodeName","root","isAnimationObjectGroup","sanitizeNodeName","RESERVED_CHARS_RE","reservedRe","wordChar","wordCharOrDot","directoryRe","nodeRe","objectRe","propertyRe","trackRe","matches","objectName","objectIndex","propertyIndex","results","lastDot","supportedObjectNames","childNode","searchNodeSubtree","subTreeNode","_getValue_unavailable","_setValue_unavailable","BindingType","Direct","EntireArray","ArrayElement","HasFromToArray","Versioning","None","NeedsUpdate","MatrixWorldNeedsUpdate","GetterByBindingType","resolvedProperty","SetterByBindingTypeAndVersioning","targetObject","dest","targetArray","sourceArray","nodeProperty","versioning","bindingType","_getValue_unbound","_setValue_unbound","_indicesByUUID","_paths","_parsedPaths","_bindingsIndicesByPath","stats","total","AnimationObjectGroup","nObjects","nCachedObjects","indicesByUUID","parsedPaths","nBindings","knownObject","lastCachedObject","firstActiveIndex","lastCached","bindingsForPath","firstActiveObject","lastCachedIndex","firstActive","uncache","lastObject","indicesByPath","unsubscribe_","lastBindingsIndex","lastBindings","lastBindingsPath","mixer","localRoot","_mixer","_clip","_localRoot","nTracks","interpolants","interpolant","interpolantSettings","_interpolantSettings","_interpolants","_propertyBindings","_cacheIndex","_byClipCacheIndex","_timeScaleInterpolant","_weightInterpolant","LoopRepeat","_loopCount","_startTime","_effectiveTimeScale","_effectiveWeight","repetitions","paused","clampWhenFinished","zeroSlopeAtStart","zeroSlopeAtEnd","AnimationAction","_activateAction","_deactivateAction","stopFading","stopWarping","isRunning","_isActiveAction","isScheduled","startAt","setEffectiveWeight","getEffectiveWeight","fadeIn","_scheduleFading","fadeOut","crossFadeFrom","fadeOutAction","warp","fadeOutDuration","startEndRatio","fadeInDuration","endStartRatio","crossFadeTo","fadeInAction","weightInterpolant","_takeBackControlInterpolant","setEffectiveTimeScale","getEffectiveTimeScale","setDuration","syncWith","halt","startTimeScale","endTimeScale","_lendControlInterpolant","timeScaleInterpolant","getMixer","getClip","getRoot","_root","_update","deltaTime","timeDirection","_updateWeight","timeRunning","_updateTimeScale","_updateTime","clipTime","propertyMixers","interpolantValue","loopCount","LoopOnce","_setEndings","handle_stop","LoopPingPong","pingPong","loopDelta","pending","atStart","atEnd","ZeroSlopeEnding","WrapAroundEnding","weightNow","weightThen","_initMemoryManager","_accuIndex","AnimationMixer","_bindAction","prototypeAction","rootUuid","bindingsByRoot","_bindingsByRootAndName","bindingsByName","_addInactiveBinding","clipUuid","actionsForClip","_actionsByClip","knownActions","_addInactiveAction","_lendBinding","_lendAction","_takeBackBinding","_takeBackAction","_actions","_nActiveActions","_nActiveBindings","_controlInterpolants","_nActiveControlInterpolants","actions","controlInterpolants","actionsByClip","actionByRoot","_removeInactiveAction","lastInactiveAction","cacheIndex","knownActionsForClip","lastKnownAction","byClipCacheIndex","_removeInactiveBindingsForAction","_removeInactiveBinding","prevIndex","lastActiveIndex","firstInactiveAction","firstInactiveIndex","lastActiveAction","bindingByName","propBinding","lastInactiveBinding","remove_empty_map","firstInactiveBinding","lastActiveBinding","_controlInterpolantsResultBuffer","__cacheIndex","lastActiveInterpolant","clipAction","optionalRoot","clipObject","existingAction","newAction","stopAllAction","nActions","uncacheClip","actionsToRemove","uncacheRoot","uncacheAction","Uniform","InstancedBufferGeometry","interleavedBuffer","InterleavedBufferAttribute","InterleavedBuffer","isInterleavedBuffer","InstancedInterleavedBuffer","InstancedBufferAttribute","PointCloud","intersectObject","Raycaster","setFromCamera","coords","ascSort","intersectObjects","autoStart","oldTime","elapsedTime","running","Clock","Date","performance","getElapsedTime","getDelta","newTime","Spherical","other","makeSafe","vec3","Cylindrical","Box2","ImmediateRenderObject","objGeometry","nNormals","VertexNormalsHelper","objPos","objNorm","cone","SpotLightHelper","coneLength","coneWidth","boneList","getBoneList","SkeletonHelper","matrixWorldInv","boneMatrix","sphereSize","PointLightHelper","RectAreaLightHelper","HemisphereLightHelper","GridHelper","radials","circles","PolarGridHelper","FaceNormalsHelper","lightPlane","targetLine","DirectionalLightHelper","addLine","colorFrustum","colorCone","colorUp","colorTarget","colorCross","addPoint","pointMap","CameraHelper","setPoint","BoxHelper","Box3Helper","positions2","PlaneHelper","headLength","headWidth","lineGeometry","coneGeometry","setDirection","ArrowHelper","setColor","AxesHelper","construct","createPointsGeometry","createGeometry","createSpacedPointsGeometry","fromPoints","Spline","initFromArray","getControlPointsArray","reparametrizeByArcLength","setColors","isIntersectionBox","isIntersectionSphere","random16","nearestPowerOfTwo","nextPowerOfTwo","flattenToArrayOffset","multiplyVector3","multiplyVector3Array","applyToBuffer","applyToVector3Array","extractPosition","getPosition","multiplyToArray","multiplyVector4","rotateAxis","crossVector","rotateByAxis","makeFrustum","isIntersectionLine","isIntersectionPlane","barycoordFromPoint","midpoint","extractAllPoints","extrude","makeGeometry","fromAttribute","distanceToManhattan","lengthManhattan","setEulerFromRotationMatrix","setEulerFromQuaternion","getPositionFromMatrix","getScaleFromMatrix","getColumnFromMatrix","applyProjection","computeTangents","getChildByName","renderDepth","getWorldRotation","eulerOrder","useQuaternion","setLens","onlyShadow","shadowCameraFov","shadowCameraLeft","shadowCameraRight","shadowCameraTop","shadowCameraBottom","shadowCameraVisible","shadowDarkness","shadowMapWidth","shadowMapHeight","copyIndicesArray","addIndex","addDrawCall","clearDrawCalls","computeOffsets","getArrays","addShapeList","wrapAround","wrapRGB","metal","WebGLRenderer","getCurrentRenderTarget","getPrecision","resetGLState","supportsFloatTextures","supportsHalfFloatTextures","supportsStandardDerivatives","supportsCompressedTextureS3TC","supportsCompressedTexturePVRTC","supportsBlendMinMax","supportsInstancedArrays","enableScissorTest","addPrePlugin","addPostPlugin","updateShadowMap","setFaceCulling","shadowMapCullFace","WebGLShadowMap","renderReverseSided","renderSingleSided","WebVRManager","standing","audioLoader","getData","updateCubeMap","on","ctx","events","off","TYPE","_f","getConstructor","IS_MAP","ADDER","_l","SIZE","_validateCollection","getEntry","has","dP$2","setStrong","original","SPECIES$2","_arraySpeciesConstructor","IS_FIND_INDEX","_arraySpeciesCreate","_iobject","IS_FILTER","res","NO_HOLES","IS_EVERY","IS_SOME","_arrayMethods","IS_WEAK","each","IS_ADDER","dP$3","_collection","MAP","_collectionStrong","_collectionToJson","COLLECTION","of","A","_setCollectionOf","mapFn","nextItem","_setCollectionFrom","Map","factories","partArgs","bound","Reflect","rConstruct","NEW_TARGET_BUG","ARGS_BUG","Target","newTarget","$args","_bind","construct$1","Parent","Class","construct$2","_construct","_wrapNativeSuper","_cache","create$1","getPrototypeOf$2","_Error","classInstance","component","classCallCheck","CompositionError","possibleConstructorReturn","stack","stackArray","inherits","wrapNativeSuper","Error","_Error2","activeModule","DependencyError","_this2","dependencyModule","_Error3","ManagerError","_this3","warnDeps","_Events","ModuleSystem","createClass","modules","applyModule","applyBridge","onCopy","bridgeMap","bridge","moduleScope","active","integrate","disposeModule","_module","minivents_commonjs","_arrayWithHoles","getIterator","core_getIterator","getIterator$1","_arr","_e","_iterableToArrayLimit","_nonIterableRest","iterableToArrayLimit","nonIterableRest","_slicedToArray","observable","symbolObservablePonyfill","INIT","REPLACE","reducer","preloadedState","enhancer","createStore","currentListeners","nextListeners","isDispatching","ensureCanMutateNextListeners","isSubscribed","isPlainObject","currentState","currentReducer","nextReducer","dispatch","ActionTypes","subscribe","observer","getState","observeState","outerSubscribe","unsubscribe","_ref","replaceReducer","_ref2","ModuleManager","currentModule","_this$store$getState2","slicedToArray","_this$store$getState","changedKey","depsMap","moduleExecutor","use","_ModuleSystem","Component","defaults","assertThisInitialized","integrateModules","_wait","isDeffered","wait","customize","objectSpread","native","asyncToGenerator","regenerator","onAdd","_callee","_context2","_callee2","_x2","_manager","_native","propertyKey","receiver","get$1","property","_superPropBase","get$2","_get","superPropBase","getOwnPropertyDescriptor$1","mappers","mapper","getter","_len2","_key2","_len3","_key3","_class","MeshComponent","_dec","mirror","_Component","geom","_MeshComponent","_class2","_this$applyBridge","custom","build","applyCommand","_this2$params","cast","receive","onWrap","_class$1","LightComponent","_dec$1","wrapShadow","_class$2","CameraComponent","_dec$2","App","system","webkitRequestAnimationFrame","mozRequestAnimationFrame","loops","requestAnimFrame","ll","execute","clock","Loop","useClock","world","addLoop","removeLoop","_LightComponent","AmbientLight$$1","AmbientLight$1","DirectionalLight$$1","DirectionalLight$1","HemisphereLight$$1","HemisphereLight$1","PointLight$$1","PointLight$1","SpotLight$$1","exponent","SpotLight$1","AreaLight","_CameraComponent","CubeCamera$$1","CubeCamera$1","OrthographicCamera$$1","OrthographicCamera$1","innerWidth","innerHeight","PerspectiveCamera$$1","PerspectiveCamera$1","Box","buildGeometry","Circle","Cone","get$3","radiusSegments","Cylinder","Dodecahedron","Extrude","Icosahedron","Lathe","Line$$1","verts","i3","Line$1","Importer","_filter","processFilter","useCustomMaterial","Octahedron","Parametric","Plane$$1","wSegments","hSegments","Plane$1","indicesOfFaces","Polyhedron","verticesOfCube","Ring","Shape$$1","Shape$1","Sphere$$1","Sphere$1","Tetrahedron","Text","Torus","Torusknot","Tube","Group$$1","addTo","body","ElementModule","className","RenderingModule","devicePixelRatio","bgColor","bgOpacity","fix","_this$params","effects","toFixed","additional","applyAdditional","attachToCanvas","_effect","renderLoop","effectLoop","app","define","integrateRenderer","_element","_scene","_camera","_this4","SceneModule","willSceneBeReplaced","_setScene","SYMBOL_CHILDREN_FOR_SCENE","setScene","getScene","ResizeModule","auto","rendering","offsetWidth","_this$container","offsetHeight","getContainer","getResolution","trigger","_container","addAutoresize","_ShaderMaterial","AdaptiveLuminosityMaterial","MIP_LEVEL_1X1","tPreviousLum","tCurrentLum","minLuminance","tau","fragment","BokehMaterial","dof","aperture","maxBlur","cameraNear","cameraFar","tDiffuse","tDepth","fragment$1","vertex$1","adoptCameraSettings","ColorEdgesMaterial","EDGE_THRESHOLD","texelSize","fragment$2","vertex$2","CombineMaterial","texture1","texture2","opacity1","opacity2","fragment$3","vertex$3","setScreenModeEnabled","screenMode","SCREEN_MODE","ConvolutionMaterial","halfTexelSize","kernel","fragment$4","vertex$4","setTexelSize","kernelSize","KernelSize","LARGE","VERY_SMALL","SMALL","MEDIUM","VERY_LARGE","HUGE","CopyMaterial","fragment$5","vertex$5","DepthComparisonMaterial","fragment$6","vertex$6","PERSPECTIVE_CAMERA","DotScreenMaterial","average","offsetRepeat","fragment$7","vertex$7","setAverageEnabled","AVERAGE","FilmMaterial","noise","scanlines","greyscale","sepia","vignette","eskil","noiseIntensity","scanlineIntensity","gridIntensity","greyscaleIntensity","sepiaIntensity","vignetteOffset","vignetteDarkness","scanlineCount","gridScale","gridLineWidth","fragment$8","vertex$8","setNoiseEnabled","setScanlinesEnabled","setGridEnabled","setGreyscaleEnabled","setSepiaEnabled","setVignetteEnabled","setEskilEnabled","NOISE","SCANLINES","GRID","GREYSCALE","SEPIA","VIGNETTE","ESKIL","GlitchMaterial","tPerturb","seed","seedX","seedY","distortionX","distortionY","colS","fragment$9","vertex$9","GodRaysMaterial","exposure","clampMax","NUM_SAMPLES_FLOAT","NUM_SAMPLES_INT","lightPosition","fragment$10","vertex$10","LuminosityMaterial","luminanceRange","distinction","maskLuminance","fragment$11","vertex$11","setColorOutputEnabled","colorOutput","setLuminanceRangeEnabled","COLOR","RANGE","OutlineBlendMaterial","edgeStrength","patternScale","visibleEdgeColor","hiddenEdgeColor","alphaBlending","xRay","pulse","tMask","tEdges","tPattern","fragment$12","vertex$12","setAlphaBlendingEnabled","setXRayEnabled","ALPHA_BLENDING","X_RAY","USE_PATTERN","OutlineEdgesMaterial","fragment$13","vertex$13","PixelationMaterial","granularity","fragment$14","vertex$14","RealisticBokehMaterial","rings","samples","showFocus","manualDoF","pentagon","shaderFocus","luminanceThreshold","luminanceGain","fringe","ditherStrength","RINGS_INT","RINGS_FLOAT","SAMPLES_INT","SAMPLES_FLOAT","focalStop","focusCoords","focalDepth","fragment$15","vertex$15","setShowFocusEnabled","setManualDepthOfFieldEnabled","setPentagonEnabled","setShaderFocusEnabled","SHOW_FOCUS","MANUAL_DOF","PENTAGON","SHADER_FOCUS","ShockWaveMaterial","maxRadius","waveSize","amplitude","cameraDistance","fragment$16","vertex$16","SMAABlendMaterial","tWeights","fragment$17","vertex$17","SMAAWeightsMaterial","MAX_SEARCH_STEPS_INT","MAX_SEARCH_STEPS_FLOAT","AREATEX_MAX_DISTANCE","AREATEX_PIXEL_SIZE","AREATEX_SUBTEX_SIZE","SEARCHTEX_SIZE","SEARCHTEX_PACKED_SIZE","tArea","tSearch","fragment$18","vertex$18","ToneMappingMaterial","luminanceMap","averageLuminance","maxLuminance","middleGrey","fragment$19","vertex$19","Pass","quad","renderToScreen","needsSwap","inputBuffer","outputBuffer","_Pass","BlurPass","renderTargetX","renderTargetY","resolutionScale","convolutionMaterial","ditheredConvolutionMaterial","getKernel","destRT","lastRT","BloomPass","blurPass","combineMaterial","luminosityMaterial","blend","initialize","BokehPass","ClearMaskPass","ClearPass","DotScreenPass","FilmPass","scanlineDensity","GlitchPass","perturbMap","generatePerturbMap","dtSize","GlitchMode","SPORADIC","breakPoint","randomInt","dt","CONSTANT_WILD","randomFloat","CONSTANT_MILD","RenderPass","clearPass","lightSource","GodRaysPass","lightScene","mainScene","mainCamera","renderTargetMask","renderPassLight","renderPassMask","screenPosition","godRaysMaterial","MaskPass","writeValue","clearValue","KEEP","ShaderPass","textureID","OutlinePass","renderTargetDepth","renderTargetEdges","renderTargetBlurredEdges","renderPassDepth","copyPass","outlineEdgesMaterial","outlineBlendMaterial","blur","selection","pulseSpeed","selectionLayer","setPatternTexture","clearSelection","setSelectionVisible","PixelationPass","setResolution","RealisticBokehPass","SavePass","resize","ShockWavePass","epicenter","speed","shockWaveMaterial","copyMaterial","HALF_PI","searchImage","areaImage","SMAAPass","renderTargetColorEdges","renderTargetWeights","colorEdgesMaterial","weightsMaterial","searchTexture","areaTexture","blendMaterial","TexturePass","opacitySource","ToneMappingPass","renderTargetLuminosity","renderTargetAdapted","renderTargetPrevious","adaptiveLuminosityMaterial","toneMappingMaterial","adaptive","log2","ADAPTED_LUMINANCE","EffectComposer","passes","oldSize","newSize","oldRenderer","parentNode","drawingBufferSize","showWarn","PostProcessorModule","debug","composer","replaceRenderer","addPass","currentPass","_pass","polyfill","_this5","_this6","bool","EventsPatchModule","originObject","patchEvents","VirtualMouseModule","globalMovement","customX","customY","getBoundingClientRect","clientX","clientY","mouse","rect","projectionPlane","require","ev","globalX","globalY","pointerLockElement","movementX","movementY","hovers","nested","isHovered","ControlsModule","controls","updateLoop","FogModule","StateModule","isEqual","isEqualDefault","actionGenerate","equalCheck","configuration","currentConfig","prevConfig","config","default","configs","updates","configName","trueVal","falseVal","_EventDispatcher","eventHandler","ThreeOrbitControls","minZoom","maxZoom","minPolarAngle","maxPolarAngle","minAzimuthAngle","maxAzimuthAngle","enableDamping","dampingFactor","enableZoom","zoomSpeed","enableRotate","rotateSpeed","enablePan","keyPanSpeed","autoRotate","autoRotateSpeed","enableKeys","UP","BOTTOM","mouseButtons","ORBIT","MOUSE","ZOOM","PAN","target0","position0","zoom0","getPolarAngle","getAzimuthalAngle","changeEvent","STATE","NONE","quat","spherical","rotateLeft","getAutoRotationAngle","sphericalDelta","panOffset","quatInverse","zoomChanged","lastPosition","lastQuaternion","onContextMenu","onMouseDown","onMouseWheel","onTouchStart","onTouchEnd","onTouchMove","onMouseMove","onMouseUp","onKeyDown","ROTATE","DOLLY","TOUCH_ROTATE","TOUCH_DOLLY","TOUCH_PAN","objectMatrix","deltaX","deltaY","targetDistance","panLeft","clientHeight","panUp","clientWidth","dollyScale","rotateStart","dollyStart","panStart","rotateEnd","rotateDelta","rotateUp","dollyEnd","dollyDelta","dollyIn","getZoomScale","dollyOut","panEnd","panDelta","pan","keyCode","touches","pageX","pageY","button","handleMouseDownRotate","handleMouseDownDolly","handleMouseDownPan","startEvent","handleMouseMoveRotate","handleMouseMoveDolly","handleMouseMovePan","endEvent","stopPropagation","handleMouseWheel","handleKeyDown","handleTouchStartRotate","handleTouchStartDolly","handleTouchStartPan","handleTouchMoveRotate","handleTouchMoveDolly","handleTouchMovePan","_ControlsModule","OrbitControlsModule","follow","setControls","setUpdate","updateProcessor","DynamicGeometryModule","g_","updateParams","_loop","TextureModule","_material","_ref$type","_ref$offset","_ref$repeat","_ref$wrap","_ref$mapping","_ref$fix","tex","isDeferred","AnimationModule","_mesh","DefineModule","_Importer","Model","_getPrototypeOf2","CameraModule","this","StatsModule","Stats","showPanel","dom","preProcess","begin","postProcess","unshift"],"mappings":"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"}