4dage.js 314 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504
  1. var webview, dom = {}, rotInfo = {
  2. idleTime: 3e3,
  3. speed: .15,
  4. pivot: [],
  5. stopWhenZoom: !1
  6. };
  7. function getQueryVariable(e) {
  8. for (var t = window.location.search.substring(1).split("&"), i = 0; i < t.length; i++) {
  9. var s = t[i].split("=");
  10. if (s[0] == e)
  11. return s[1]
  12. }
  13. return !1
  14. }
  15. dom.addClass = function (e, t) {
  16. if (void 0 === e.className)
  17. e.className = t;
  18. else if (e.className !== t) {
  19. var i = e.className.split(/ +/);
  20. -1 == i.indexOf(t) && (i.push(t),
  21. e.className = i.join(" ").replace(/^\s+/, "").replace(/\s+$/, ""))
  22. }
  23. }
  24. ,
  25. dom.removeClass = function (e, t) {
  26. if (t)
  27. if (void 0 === e.className)
  28. ;
  29. else if (e.className === t)
  30. e.removeAttribute("class");
  31. else {
  32. var i = e.className.split(/ +/)
  33. , s = i.indexOf(t);
  34. -1 != s && (i.splice(s, 1),
  35. e.className = i.join(" "))
  36. }
  37. else
  38. e.className = void 0
  39. }
  40. ,
  41. dom.hasClass = function (e, t) {
  42. return new RegExp("(?:^|\\s+)" + t + "(?:\\s+|$)").test(e.className) || !1
  43. }
  44. ,
  45. dom.id = function (e, t) {
  46. return (t = t || document).getElementById && t.getElementById(e) || document.getElementById(e)
  47. }
  48. ,
  49. dom.Tag = function (e, t) {
  50. return (t = t || document).getElementsByTagName(e)
  51. }
  52. ,
  53. dom.cla = function (e, t) {
  54. return (t = t || document).getElementsByClassName(e)
  55. }
  56. ,
  57. dom.ifVoid = function (e, t) {
  58. return null == e ? t : e
  59. }
  60. ,
  61. dom.objToArray = function (e) {
  62. if (e instanceof Array)
  63. return e;
  64. var t = [];
  65. for (var i in e)
  66. t.push(e[i]);
  67. return t
  68. }
  69. ;
  70. var Clamp = function (e, t, i) {
  71. return void 0 === t && (t = 0),
  72. void 0 === i && (i = 1),
  73. Math.min(i, Math.max(t, e))
  74. }
  75. , codeToCh = function (e) {
  76. return unescape(e)
  77. };
  78. fdage = {},
  79. function (I) {
  80. "use strict";
  81. function r(e, t, i) {
  82. if (this.name = t.partName,
  83. this.animatedProperties = [],
  84. this.sceneObjectType = t.sceneObjectType,
  85. this.skinningRigIndex = t.skinningRigIndex,
  86. this.id = i,
  87. this.mesh = this.skinningRig = 0,
  88. this.materialIndex = this.lightIndex = this.meshIndex = -1,
  89. this.emissiveProperty = this.offsetVProperty = this.offsetUProperty = this.material = 0,
  90. this.debugMe = t.debugMe,
  91. this.debugString = "",
  92. this.hasTransform = !1,
  93. this.modelPartIndex = t.modelPartIndex,
  94. this.modelPartFPS = t.modelPartFPS,
  95. this.modelPartScale = t.modelPartScale,
  96. this.parentIndex = t.parentIndex,
  97. this.totalFrames = t.totalFrames,
  98. this.animationLength = 1 / this.modelPartFPS * this.totalFrames,
  99. this.turnTableSpinOffset = this.turnTableSpin = this.spinProperty = this.dispersionProperty = this.lightIllumProperty = this.skyIllumProperty = this.opacityProperty = this.spotSharpnessProperty = this.spotAngleProperty = this.distanceProperty = this.brightnessProperty = this.blueProperty = this.greenProperty = this.redProperty = this.visibleProperty = 0,
  100. t.animatedProperties) {
  101. i = t.animatedProperties.length;
  102. for (var s = 0; s < i; ++s) {
  103. var n = t.animatedProperties[s]
  104. , r = new a;
  105. r.name = n.name,
  106. this.animatedProperties.push(r),
  107. "Red" != r.name || this.redProperty || (this.redProperty = r),
  108. "Green" != r.name || this.greenProperty || (this.greenProperty = r),
  109. "Blue" != r.name || this.blueProperty || (this.blueProperty = r),
  110. "Brightness" != r.name || this.brightnessProperty || (this.brightnessProperty = r),
  111. "Distance" != r.name || this.distanceProperty || (this.distanceProperty = r),
  112. "Spot Angle" != r.name || this.spotAngleProperty || (this.spotAngleProperty = r),
  113. "Spot Sharpness" != r.name || this.spotSharpnessProperty || (this.spotSharpnessProperty = r),
  114. "Opacity" != r.name || this.opacityProperty || (this.opacityProperty = r),
  115. "Sky Illumination" != r.name || this.skyIllumProperty || (this.skyIllumProperty = r),
  116. "Light Illumination" != r.name || this.lightIllumProperty || (this.lightIllumProperty = r),
  117. "Dispersion" != r.name || this.dispersionProperty || (this.dispersionProperty = r),
  118. "Visible" != r.name || this.visibleProperty || (this.visibleProperty = r),
  119. "Spin Rate" == r.name && (this.spinProperty = r),
  120. "OffsetU" == r.name && (this.offsetUProperty = r),
  121. "OffsetV" == r.name && (this.offsetVProperty = r),
  122. "EmissiveIntensity" == r.name && (this.emissiveProperty = r)
  123. }
  124. }
  125. this.keyframesSharedBufferUShorts = this.keyframesSharedBufferFloats = this.keyFramesByteStream = 0,
  126. (e = e.get(t.file)) && (this.keyFramesByteStream = new u(e.data),
  127. this.unPackKeyFrames()),
  128. this.animatedLocalTransform = new o(this),
  129. this.hasTransform = this.animatedLocalTransform.hasTranslation || this.animatedLocalTransform.hasRotation || this.animatedLocalTransform.hasScale,
  130. this.cachedWorldTransform0 = S.identity(),
  131. this.cachedWorldTransform1 = S.identity(),
  132. this.cachedWorldTransform2 = S.identity(),
  133. this.cachedWorldTransform3 = S.identity(),
  134. this.cachedFrame3 = this.cachedFrame2 = this.cachedFrame1 = this.cachedFrame0 = -10,
  135. this.cachedFrameUse3 = this.cachedFrameUse2 = this.cachedFrameUse1 = this.cachedFrameUse0 = 0,
  136. this.useFixedLocalTransform = this.useFixedWorldTransform = !1
  137. }
  138. function a() {
  139. this.currentValue = 0,
  140. this.keyframeBufferStartIndexFloat = -1,
  141. this.lastValue = this.interpolationOffsetUShort = this.frameIndexOffsetUShort = this.weighOutOffsetFloat = this.weighInOffsetFloat = this.valueOffsetFloat = this.indexUShortSkip = this.indexFloatSkip = this.interpolationType = this.bytesPerKeyFrame = this.keyframePackingType = 0,
  142. this.lastFramePercent = -10,
  143. this.enable = !0,
  144. this.name = "NONE",
  145. this.splineKF0 = new i(0, 0),
  146. this.splineKF1 = new i(0, 0),
  147. this.splineKF2 = new i(0, 0),
  148. this.splineKF3 = new i(0, 0),
  149. this.debugMe = !0,
  150. this.debugString = "",
  151. this.lastSearchIndex = 1,
  152. this.savedSearchIndex = 0,
  153. this.splineKF0.frameIndex = 0,
  154. this.splineKF1.frameIndex = 1,
  155. this.splineKF2.frameIndex = 2,
  156. this.splineKF3.frameIndex = 3,
  157. this.numKeyframes = 0
  158. }
  159. function o(e) {
  160. var t = e.animatedProperties;
  161. for (this.TX = this.TY = this.TZ = this.RX = this.RY = this.RZ = this.SX = this.SY = this.SZ = 0,
  162. this.hostObject = e,
  163. this.matrix = S.identity(),
  164. this.cachedmatrix0 = S.identity(),
  165. this.cachedmatrix1 = S.identity(),
  166. this.cachedmatrix2 = S.identity(),
  167. this.cachedmatrix3 = S.identity(),
  168. this.cachedFrame3 = this.cachedFrame2 = this.cachedFrame1 = this.cachedFrame0 = -1,
  169. this.cachedFrameUse3 = this.cachedFrameUse2 = this.cachedFrameUse1 = this.cachedFrameUse0 = 0,
  170. this.debugString = "",
  171. e = 0; e < t.length; e++) {
  172. var i = t[e];
  173. "Translation X" == i.name ? this.TX = i : "Translation Y" == i.name ? this.TY = i : "Translation Z" == i.name ? this.TZ = i : "Rotation X" == i.name ? this.RX = i : "Rotation Y" == i.name ? this.RY = i : "Rotation Z" == i.name ? this.RZ = i : "Scale X" == i.name ? this.SX = i : "Scale Y" == i.name ? this.SY = i : "Scale Z" == i.name && (this.SZ = i)
  174. }
  175. this.hasTranslation = this.TX && this.TY && this.TZ,
  176. this.hasRotation = this.RX && this.RY && this.RZ,
  177. this.hasScale = this.SX && this.SY && this.SZ,
  178. this.lockTransform = !1
  179. }
  180. function c(e, t) {
  181. if (this.originalFPS = 1,
  182. this.name = t.name,
  183. this.totalSeconds = t.length,
  184. this.originalFPS = t.originalFPS,
  185. this.totalFrames = t.totalFrames,
  186. this.expectedNumAnimatedObjects = t.numAnimatedObjects,
  187. this.animatedObjects = [],
  188. this.sceneTransform = S.identity(),
  189. this.debugString = "",
  190. t.animatedObjects)
  191. for (var i = t.animatedObjects.length, s = 0; s < i; ++s) {
  192. var n = new r(e, t.animatedObjects[s], s);
  193. this.animatedObjects.push(n),
  194. this.debugString += n.debugString
  195. }
  196. this.meshObjects = [],
  197. this.lightObjects = [],
  198. this.materialObjects = [],
  199. this.turnTableObjects = [],
  200. this.cameraObjects = []
  201. }
  202. function h(e) {
  203. for (this.files = [],
  204. e = new u(e); !e.empty();) {
  205. var t = {};
  206. t.name = e.readCString(),
  207. t.type = e.readCString();
  208. var i = e.readUint32()
  209. , s = e.readUint32()
  210. , n = e.readUint32();
  211. if (t.data = e.readBytes(s),
  212. !(t.data.length < s)) {
  213. if (1 & i && (t.data = this.decompress(t.data, n),
  214. null === t.data))
  215. continue;
  216. this.files[t.name] = t
  217. }
  218. }
  219. }
  220. function l(e) {
  221. this.digits = new Uint16Array(e || 0)
  222. }
  223. function d(e) {
  224. for (var t = 0; t < e.length; ++t) {
  225. var i = e[t].bounds;
  226. if (void 0 === this.min)
  227. this.min = [i.min[0], i.min[1], i.min[2]],
  228. this.max = [i.max[0], i.max[1], i.max[2]];
  229. else
  230. for (var s = 0; s < 3; ++s)
  231. this.min[s] = Math.min(i.min[s], this.min[s]),
  232. this.max[s] = Math.max(i.max[s], this.max[s])
  233. }
  234. this.min = this.min ? this.min : [0, 0, 0],
  235. this.max = this.max ? this.max : [0, 0, 0],
  236. this.center = [.5 * (this.min[0] + this.max[0]), .5 * (this.min[1] + this.max[1]), .5 * (this.min[2] + this.max[2])],
  237. this.radius = [this.max[0] - this.center[0], this.max[1] - this.center[1], this.max[2] - this.center[2]],
  238. this.radiusDiagonal = Math.sqrt(this.radius[0] * this.radius[0] + this.radius[1] * this.radius[1] + this.radius[2] * this.radius[2])
  239. }
  240. function p(e) {
  241. this.name = "none",
  242. this.text = "default text",
  243. this.title = "none",
  244. this.debugString = this.imagePath = "",
  245. this.controlRect = new s(e),
  246. this.defaultAlpha = .5,
  247. this.focusAlpha = 1,
  248. this.updateAlphas = !0,
  249. this.linkedBackground = this.backgroundOffsetY = this.backgroundOffsetX = this.edgePixelsY = this.edgePixelsX = this.backgroundBottomMiddle = this.backgroundBottomRight = this.backgroundBottomLeft = this.backgroundMiddleMiddle = this.backgroundMiddleRight = this.backgroundMiddleLeft = this.backgroundTopMiddle = this.backgroundTopRight = this.backgroundTopLeft = this.backgroundMiddle = this.backgroundRight = this.backgroundLeft = 0
  250. }
  251. function u(e) {
  252. this.bytes = new Uint8Array(e)
  253. }
  254. function s(e) {
  255. this.name = "none",
  256. this.title = "frame",
  257. this.yPercent = this.xPercent = 0,
  258. this.heightPercent = this.widthPercent = 1,
  259. this.debugString = "",
  260. this.parentControlRect = 0,
  261. this.childControlRects = [],
  262. this.clicked = this.mouseDown = this.mouseOver = !1,
  263. this.localMouseYPercent = this.localMouseXPercent = 0,
  264. this.enabled = this.visible = !0,
  265. this.opacity = 1,
  266. this.guiScreen = e,
  267. this.id = this.callBack = this.linkedControl = 0
  268. }
  269. r.prototype.setFixedWorldTransform = function (e) {
  270. this.useFixedWorldTransform = !0,
  271. S.copy(this.cachedWorldTransform0, e)
  272. }
  273. ,
  274. r.prototype.setFixedLocalTransform = function (e) {
  275. this.useFixedLocalTransform = !0,
  276. this.animatedLocalTransform.lockTransform = !0,
  277. S.copy(this.animatedLocalTransform.cachedmatrix0, e)
  278. }
  279. ,
  280. r.prototype.getCachedWorldTransform = function (e) {
  281. return this.useFixedWorldTransform ? 0 : e == this.cachedFrame0 ? this.cachedmatrix0 : e == this.cachedFrame1 ? this.cachedmatrix1 : e == this.cachedFrame2 ? this.cachedmatrix2 : e == this.cachedFrame3 ? this.cachedmatrix3 : 0
  282. }
  283. ,
  284. r.prototype.getFreeCachedWorldTransform = function (e) {
  285. return this.useFixedWorldTransform ? 0 : (this.cachedFrameUse0--,
  286. this.cachedFrameUse1--,
  287. this.cachedFrameUse2--,
  288. this.cachedFrameUse3--,
  289. this.cachedFrameUse0 <= this.cachedFrameUse1 && this.cachedFrameUse0 <= this.cachedFrameUse2 && this.cachedFrameUse0 <= this.cachedFrameUse3 ? (this.cachedFrame0 = e,
  290. this.cachedFrameUse0 = 0,
  291. this.cachedWorldTransform0) : this.cachedFrameUse1 <= this.cachedFrameUse0 && this.cachedFrameUse1 <= this.cachedFrameUse2 && this.cachedFrameUse1 <= this.cachedFrameUse3 ? (this.cachedFrame1 = e,
  292. this.cachedFrameUse1 = 0,
  293. this.cachedWorldTransform1) : this.cachedFrameUse2 <= this.cachedFrameUse0 && this.cachedFrameUse2 <= this.cachedFrameUse1 && this.cachedFrameUse2 <= this.cachedFrameUse3 ? (this.cachedFrame2 = e,
  294. this.cachedFrameUse2 = 0,
  295. this.cachedWorldTransform2) : (this.cachedFrame3 = e,
  296. this.cachedFrameUse3 = 0,
  297. this.cachedWorldTransform3))
  298. }
  299. ,
  300. r.prototype.unPackKeyFrames = function () {
  301. if (this.keyFramesByteStream) {
  302. var e = new Float32Array(this.keyFramesByteStream.bytes.buffer)
  303. , t = new Uint32Array(this.keyFramesByteStream.bytes.buffer)
  304. , i = new Uint16Array(this.keyFramesByteStream.bytes.buffer)
  305. , s = new Uint8Array(this.keyFramesByteStream.bytes.buffer);
  306. this.keyframesSharedBufferFloats = e;
  307. e = 0,
  308. e = 1 + (t = (this.keyframesSharedBufferUShorts = t)[0]),
  309. t = this.animatedProperties.length;
  310. for (var n = 0; n < t; n++) {
  311. var r = this.animatedProperties[n]
  312. , a = 2 + 2 * n
  313. , o = 2 * a;
  314. r.keyframeBufferStartIndexFloat = e,
  315. r.numKeyframes = i[a],
  316. r.keyframePackingType = s[2 + o],
  317. r.interpolationType = s[3 + o],
  318. r.indexFloatSkip = 0,
  319. (r.indexUShortSkip = 0) < r.numKeyframes && (0 == r.keyframePackingType ? (r.bytesPerKeyFrame = 16,
  320. r.indexFloatSkip = 4,
  321. r.indexUShortSkip = 8,
  322. r.valueOffsetFloat = 0,
  323. r.weighInOffsetFloat = 1,
  324. r.weighOutOffsetFloat = 2,
  325. r.frameIndexOffsetUShort = 6,
  326. r.interpolationOffsetUShort = 7) : 1 == r.keyframePackingType ? (r.bytesPerKeyFrame = 8,
  327. r.indexFloatSkip = 2,
  328. r.indexUShortSkip = 4,
  329. r.valueOffsetFloat = 0,
  330. r.weighInOffsetFloat = 0,
  331. r.weighOutOffsetFloat = 0,
  332. r.frameIndexOffsetUShort = 2,
  333. r.interpolationOffsetUShort = 3) : 2 == r.keyframePackingType && (r.bytesPerKeyFrame = 4,
  334. r.indexFloatSkip = 1,
  335. r.indexUShortSkip = 2,
  336. r.valueOffsetFloat = 0,
  337. r.weighInOffsetFloat = 0,
  338. r.weighOutOffsetFloat = 0,
  339. r.frameIndexOffsetUShort = 0,
  340. r.interpolationOffsetUShort = 0)),
  341. e += r.numKeyframes * r.indexFloatSkip
  342. }
  343. }
  344. }
  345. ,
  346. r.prototype.setupSkinningRig = function (e, t, i, s) {
  347. var n = S.identity()
  348. , r = S.identity()
  349. , a = (a = i * (o = e.animatedObjects[t]).modelPartFPS) - Math.floor(a)
  350. , o = (i = Math.floor(e.getObjectAnimationFramePercent(o, i))) + 1
  351. , h = 1 - a
  352. , l = s.skinningClusters.length;
  353. if (0 < l)
  354. for (var d = 0; d < l; d++) {
  355. (c = s.skinningClusters[d]).solveClusterTransformAtFrame(e, t, i, n),
  356. c.solveClusterTransformAtFrame(e, t, o, r);
  357. for (var c = c.matrix, u = 0; u < 16; u++)
  358. c[u] = n[u] * h + r[u] * a
  359. }
  360. }
  361. ,
  362. r.prototype.evaluateLocalTransformAtFramePercent = function (e, t, i, s) {
  363. if (this.useFixedLocalTransform)
  364. S.copy(t, this.animatedLocalTransform.cachedmatrix0);
  365. else {
  366. var n = 0;
  367. s && (n = this.animatedLocalTransform.getCachedTransform(e)),
  368. n ? S.copy(t, n) : ((n = this.animatedLocalTransform.getFreeCachedTransform(e)) ? (this.animatedLocalTransform.evaluateMatrix(n, this.totalFrames, e, i),
  369. S.copy(t, n)) : this.animatedLocalTransform.evaluateMatrix(t, this.totalFrames, e, i),
  370. 0 != this.turnTableSpin && (e = S.rotation(S.empty(), this.turnTableSpin, 1),
  371. S.mul(t, t, e)))
  372. }
  373. }
  374. ,
  375. r.prototype.hasAnimatedTransform = function () {
  376. var e = this.animatedLocalTransform;
  377. return !!(e.TX && 1 < e.TX.numKeyframes || e.TY && 1 < e.TY.numKeyframes || e.TZ && 1 < e.TZ.numKeyframes || e.RX && 1 < e.RX.numKeyframes || e.RY && 1 < e.RY.numKeyframes || e.RZ && 1 < e.RZ.numKeyframes || e.SX && 1 < e.SX.numKeyframes || e.SY && 1 < e.SY.numKeyframes || e.SZ && 1 < e.SZ.numKeyframes)
  378. }
  379. ,
  380. a.prototype.evaluateCurve = function (e, t) {
  381. var i = this.splineKF1.frameIndex
  382. , s = this.splineKF2.frameIndex
  383. , n = this.splineKF1.value
  384. , r = this.splineKF2.value
  385. , a = i - (this.splineKF2.frameIndex - this.splineKF0.frameIndex)
  386. , o = s - (this.splineKF1.frameIndex - this.splineKF3.frameIndex)
  387. , h = n - (this.splineKF2.value - this.splineKF0.value) * this.splineKF1.weighOut
  388. , l = r - (this.splineKF1.value - this.splineKF3.value) * this.splineKF2.weighIn;
  389. return 3 == this.splineKF1.interpolation && (a = i - (this.splineKF2.frameIndex - this.splineKF1.frameIndex),
  390. h = n - this.splineKF1.weighOut),
  391. 3 == this.splineKF2.interpolation && (o = s - (this.splineKF1.frameIndex - this.splineKF2.frameIndex),
  392. l = r + this.splineKF2.weighIn),
  393. a = (e - a) / (i - a),
  394. i = (e - i) / (s - i),
  395. s = (e - s) / (o - s),
  396. ((h * (1 - a) + n * a) * (1 - i) + (o = n * (1 - i) + r * i) * i) * (1 - i) + ((r * (1 - s) + l * s) * i + o * (1 - i)) * i
  397. }
  398. ,
  399. a.prototype.evaluate = function (e, t, i) {
  400. if (!i)
  401. return t;
  402. if (0 == this.numKeyframes)
  403. return this.lastValue = t;
  404. if (1 == this.numKeyframes)
  405. return this.lastValue = 2 == this.keyframePackingType ? i.keyframesSharedBufferFloats[this.keyframeBufferStartIndexFloat] : i.keyframesSharedBufferFloats[this.keyframeBufferStartIndexFloat + this.valueOffsetFloat];
  406. if (this.lastFramePercent == e)
  407. return this.lastValue;
  408. var s = this.keyframeBufferStartIndexFloat
  409. , n = 2 * this.keyframeBufferStartIndexFloat;
  410. if (this.lastValue = t,
  411. this.lastFramePercent = e,
  412. 2 == this.keyframePackingType) {
  413. var r = e - (t = Math.floor(e));
  414. return e >= this.numKeyframes && (t -= Math.floor(e / this.numKeyframes) * this.numKeyframes),
  415. t >= this.numKeyframes ? this.lastValue = i.keyframesSharedBufferFloats[s + (this.numKeyframes - 1)] : t < 0 ? this.lastValue = i.keyframesSharedBufferFloats[s] : 0 == r ? this.lastValue = i.keyframesSharedBufferFloats[s + t] : (e = n = i.keyframesSharedBufferFloats[s + t],
  416. ++t >= this.numKeyframes && (t -= this.numKeyframes),
  417. 0 <= t && t < this.numKeyframes ? e = n * (1 - r) + i.keyframesSharedBufferFloats[s + t] * r : i.debugString += "<br>bad lerp frame " + t + " of " + this.numKeyframes,
  418. this.lastValue = e)
  419. }
  420. var a = this.numKeyframes;
  421. r = i.keyframesSharedBufferUShorts[n + this.frameIndexOffsetUShort];
  422. if (e >= i.keyframesSharedBufferUShorts[n + (a - 1) * this.indexUShortSkip + this.frameIndexOffsetUShort])
  423. return this.lastValue = i.keyframesSharedBufferFloats[s + (a - 1) * this.indexFloatSkip + this.valueOffsetFloat];
  424. if (e < r)
  425. return this.lastValue = i.keyframesSharedBufferFloats[s + this.valueOffsetFloat];
  426. this.lastSearchIndex < this.numKeyframes && e > i.keyframesSharedBufferUShorts[n + this.lastSearchIndex * this.indexUShortSkip + this.frameIndexOffsetUShort] && (this.lastSearchIndex = 1);
  427. for (var o = this.lastSearchIndex; o < a; o++) {
  428. r = s + o * this.indexFloatSkip;
  429. var h = s + (o - 1) * this.indexFloatSkip
  430. , l = n + o * this.indexUShortSkip
  431. , d = n + (o - 1) * this.indexUShortSkip;
  432. if (e >= i.keyframesSharedBufferUShorts[d + this.frameIndexOffsetUShort] && e <= i.keyframesSharedBufferUShorts[l + this.frameIndexOffsetUShort]) {
  433. this.lastSearchIndex = o;
  434. var c = i.keyframesSharedBufferUShorts[d + this.interpolationOffsetUShort];
  435. if (2 == c) {
  436. this.lastValue = e = e >= i.keyframesSharedBufferUShorts[l + this.frameIndexOffsetUShort] ? i.keyframesSharedBufferFloats[r + this.valueOffsetFloat] : i.keyframesSharedBufferFloats[h + this.valueOffsetFloat];
  437. break
  438. }
  439. if (0 == c) {
  440. s = i.keyframesSharedBufferUShorts[d + this.frameIndexOffsetUShort],
  441. t = i.keyframesSharedBufferFloats[h + this.valueOffsetFloat],
  442. n = i.keyframesSharedBufferFloats[r + this.valueOffsetFloat],
  443. r = (e - s) / (i.keyframesSharedBufferUShorts[l + this.frameIndexOffsetUShort] - s),
  444. this.lastValue = e = t * (1 - r) + n * r;
  445. break
  446. }
  447. if (1 == c || 3 == c) {
  448. var u = c = !1
  449. , f = 0
  450. , m = i.keyframesSharedBufferFloats[h + this.valueOffsetFloat]
  451. , p = i.keyframesSharedBufferFloats[r + this.valueOffsetFloat]
  452. , g = 0
  453. , v = 0
  454. , x = (d = i.keyframesSharedBufferUShorts[d + this.frameIndexOffsetUShort],
  455. l = i.keyframesSharedBufferUShorts[l + this.frameIndexOffsetUShort],
  456. 0)
  457. , y = 1
  458. , b = 1
  459. , S = 1
  460. , T = 1
  461. , w = 1
  462. , C = 1
  463. , R = 1
  464. , A = 1;
  465. 0 != this.weighInOffsetFloat && (b = i.keyframesSharedBufferFloats[h + this.weighInOffsetFloat],
  466. S = i.keyframesSharedBufferFloats[r + this.weighInOffsetFloat],
  467. C = i.keyframesSharedBufferFloats[h + this.weighOutOffsetFloat],
  468. R = i.keyframesSharedBufferFloats[r + this.weighOutOffsetFloat]),
  469. 1 < o && (c = !0,
  470. f = i.keyframesSharedBufferFloats[s + (o - 2) * this.indexFloatSkip + this.valueOffsetFloat],
  471. v = i.keyframesSharedBufferUShorts[n + (o - 2) * this.indexUShortSkip + this.frameIndexOffsetUShort],
  472. 0 != this.weighInOffsetFloat && (y = i.keyframesSharedBufferFloats[s + (o - 2) * this.indexFloatSkip + this.weighInOffsetFloat],
  473. w = i.keyframesSharedBufferFloats[s + (o - 2) * this.indexFloatSkip + this.weighOutOffsetFloat])),
  474. o < a - 1 && (u = !0,
  475. g = i.keyframesSharedBufferFloats[s + (o + 1) * this.indexFloatSkip + this.valueOffsetFloat],
  476. x = i.keyframesSharedBufferUShorts[n + (o + 1) * this.indexUShortSkip + this.frameIndexOffsetUShort],
  477. 0 != this.weighInOffsetFloat && (T = i.keyframesSharedBufferFloats[s + (o + 1) * this.indexFloatSkip + this.weighInOffsetFloat],
  478. A = i.keyframesSharedBufferFloats[s + (o + 1) * this.indexFloatSkip + this.weighOutOffsetFloat])),
  479. c && u ? (this.splineKF0.value = f,
  480. this.splineKF1.value = m,
  481. this.splineKF2.value = p,
  482. this.splineKF3.value = g,
  483. this.splineKF0.frameIndex = v,
  484. this.splineKF1.frameIndex = d,
  485. this.splineKF2.frameIndex = l,
  486. this.splineKF3.frameIndex = x,
  487. this.splineKF0.weighIn = y,
  488. this.splineKF0.weighOut = w,
  489. this.splineKF1.weighIn = b,
  490. this.splineKF1.weighOut = C,
  491. this.splineKF2.weighIn = S,
  492. this.splineKF2.weighOut = R,
  493. this.splineKF3.weighIn = T,
  494. this.splineKF3.weighOut = A) : (this.splineKF0.value = m,
  495. this.splineKF1.value = m,
  496. this.splineKF2.value = p,
  497. this.splineKF3.value = p,
  498. this.splineKF0.frameIndex = d,
  499. this.splineKF1.frameIndex = d,
  500. this.splineKF2.frameIndex = l,
  501. this.splineKF3.frameIndex = l,
  502. this.splineKF1.weighIn = b,
  503. this.splineKF2.weighIn = S,
  504. this.splineKF1.weighOut = C,
  505. this.splineKF2.weighOut = R,
  506. u ? (this.splineKF3.value = g,
  507. this.splineKF3.frameIndex = x,
  508. this.splineKF3.weighIn = T,
  509. this.splineKF3.weighOut = A) : (this.splineKF3.frameIndex++,
  510. this.splineKF3.value = this.splineKF1.value,
  511. this.splineKF3.weighIn = 1,
  512. this.splineKF3.weighOut = 1),
  513. c ? (this.splineKF0.value = f,
  514. this.splineKF0.frameIndex = v,
  515. this.splineKF0.weighIn = y,
  516. this.splineKF0.weighOut = w) : (this.splineKF0.value = this.splineKF2.value,
  517. this.splineKF0.weighIn = 1,
  518. this.splineKF0.weighOut = 1,
  519. 0 < this.splineKF0.frameIndex ? this.splineKF0.frameIndex-- : (this.splineKF1.frameIndex++,
  520. this.splineKF2.frameIndex++,
  521. this.splineKF3.frameIndex++,
  522. e++))),
  523. this.lastValue = e = this.evaluateCurve(e, t);
  524. break
  525. }
  526. }
  527. }
  528. return this.lastValue
  529. }
  530. ,
  531. o.prototype.getTRSValue = function (e, t, i) {
  532. return t ? (t.evaluate(e, i, this.hostObject),
  533. "" != t.debugString && (this.debugString += t.debugString),
  534. t.lastValue) : i
  535. }
  536. ,
  537. o.prototype.evaluateMatrix = function (e, t, i, s) {
  538. if (this.lockTransform)
  539. S.copy(e, this.cachedmatrix0);
  540. else {
  541. var n = 0
  542. , r = t = 0;
  543. n = r = t = 0,
  544. n = r = t = 1;
  545. this.hasRotation ? (n = this.getTRSValue(i, this.RX, 0),
  546. t = this.getTRSValue(i, this.RY, 0),
  547. r = this.getTRSValue(i, this.RZ, 0),
  548. s ? (this.matrix = S.rotation(S.empty(), r, 2),
  549. s = S.rotation(S.empty(), n, 0),
  550. S.mul(s, s, this.matrix),
  551. this.matrix = S.rotation(S.empty(), t, 1)) : (this.matrix = S.rotation(S.empty(), n, 0),
  552. s = S.rotation(S.empty(), t, 1),
  553. S.mul(s, s, this.matrix),
  554. this.matrix = S.rotation(S.empty(), r, 2)),
  555. S.mul(this.matrix, this.matrix, s)) : S.copy(this.matrix, S.identity()),
  556. this.hasTranslation && (t = this.getTRSValue(i, this.TX, 0),
  557. r = this.getTRSValue(i, this.TY, 0),
  558. n = this.getTRSValue(i, this.TZ, 0),
  559. this.matrix[12] = t,
  560. this.matrix[13] = r,
  561. this.matrix[14] = n),
  562. this.hasScale && (t = this.getTRSValue(i, this.SX, 1),
  563. r = this.getTRSValue(i, this.SY, 1),
  564. n = this.getTRSValue(i, this.SZ, 1),
  565. this.matrix[0] *= t,
  566. this.matrix[4] *= r,
  567. this.matrix[8] *= n,
  568. this.matrix[1] *= t,
  569. this.matrix[5] *= r,
  570. this.matrix[9] *= n,
  571. this.matrix[2] *= t,
  572. this.matrix[6] *= r,
  573. this.matrix[10] *= n,
  574. this.matrix[3] *= t,
  575. this.matrix[7] *= r,
  576. this.matrix[11] *= n),
  577. S.copy(e, this.matrix)
  578. }
  579. }
  580. ,
  581. o.prototype.clearCachedTransforms = function () {
  582. this.cachedFrame3 = this.cachedFrame2 = this.cachedFrame1 = this.cachedFrame0 = -1,
  583. this.cachedFrameUse3 = this.cachedFrameUse2 = this.cachedFrameUse1 = this.cachedFrameUse0 = 0,
  584. this.TX && (this.TX.lastFramePercent = -10),
  585. this.TY && (this.TY.lastFramePercent = -10),
  586. this.TZ && (this.TZ.lastFramePercent = -10),
  587. this.RX && (this.RX.lastFramePercent = -10),
  588. this.RY && (this.RY.lastFramePercent = -10),
  589. this.RZ && (this.RZ.lastFramePercent = -10),
  590. this.SX && (this.SX.lastFramePercent = -10),
  591. this.SY && (this.SY.lastFramePercent = -10),
  592. this.SZ && (this.SZ.lastFramePercent = -10),
  593. this.lockTransform = !1
  594. }
  595. ,
  596. o.prototype.getCachedTransform = function (e) {
  597. return this.lockTransform ? 0 : this.cachedFrame0 == e ? this.cachedmatrix0 : this.cachedFrame1 == e ? this.cachedmatrix1 : this.cachedFrame2 == e ? this.cachedmatrix2 : this.cachedFrame3 == e ? this.cachedmatrix3 : 0
  598. }
  599. ,
  600. o.prototype.getFreeCachedTransform = function (e) {
  601. return this.lockTransform ? 0 : (this.cachedFrameUse0--,
  602. this.cachedFrameUse1--,
  603. this.cachedFrameUse2--,
  604. this.cachedFrameUse3--,
  605. this.cachedFrameUse0 <= this.cachedFrameUse1 && this.cachedFrameUse0 <= this.cachedFrameUse2 && this.cachedFrameUse0 <= this.cachedFrameUse3 || this.cachedFrame0 == e ? (this.cachedFrame0 = e,
  606. this.cachedFrameUse0 = 0,
  607. this.cachedmatrix0) : this.cachedFrameUse1 <= this.cachedFrameUse0 && this.cachedFrameUse1 <= this.cachedFrameUse2 && this.cachedFrameUse1 <= this.cachedFrameUse3 || this.cachedFrame1 == e ? (this.cachedFrame1 = e,
  608. this.cachedFrameUse1 = 0,
  609. this.cachedmatrix1) : this.cachedFrameUse2 <= this.cachedFrameUse0 && this.cachedFrameUse2 <= this.cachedFrameUse1 && this.cachedFrameUse2 <= this.cachedFrameUse3 || this.cachedFrame2 == e ? (this.cachedFrame2 = e,
  610. this.cachedFrameUse2 = 0,
  611. this.cachedmatrix2) : (this.cachedFrame3 = e,
  612. this.cachedFrameUse3 = 0,
  613. this.cachedmatrix3))
  614. }
  615. ,
  616. c.prototype.evaluateModelPartTransformAtFrame = function (e, t, i, s) {
  617. S.copy(i, S.identity());
  618. for (var n = 0; n < 100; n++) {
  619. var r = this.animatedObjects[e];
  620. if (e == r.parentIndex)
  621. break;
  622. if (r.useFixedWorldTransform) {
  623. S.mul(i, r.cachedWorldTransform0, i);
  624. break
  625. }
  626. var a = 0;
  627. if (s && (a = r.getCachedWorldTransform(t)),
  628. a) {
  629. S.mul(i, a, i);
  630. break
  631. }
  632. a = S.identity(),
  633. r.evaluateLocalTransformAtFramePercent(t, a, !1, s),
  634. S.mul(i, a, i),
  635. e == r.parentIndex && (n = 100),
  636. e = r.parentIndex
  637. }
  638. }
  639. ,
  640. c.prototype.lerpModelPartTransform = function (e, t, i, s) {
  641. var n = this.animatedObjects[e];
  642. if (n.useFixedWorldTransform)
  643. S.copy(i, n.cachedWorldTransform0);
  644. else {
  645. var r = (r = t * n.modelPartFPS) - Math.floor(r)
  646. , a = Math.floor(this.getObjectAnimationFramePercent(n, t))
  647. , o = a + 1
  648. , h = t = 0;
  649. for (s && (t = n.getCachedWorldTransform(a),
  650. h = n.getCachedWorldTransform(o)),
  651. t || ((t = n.getFreeCachedWorldTransform(a)) || (t = S.identity()),
  652. this.evaluateModelPartTransformAtFrame(e, a, t, s)),
  653. h || ((h = n.getFreeCachedWorldTransform(o)) || (h = S.identity()),
  654. this.evaluateModelPartTransformAtFrame(e, o, h, s)),
  655. e = 1 - r,
  656. s = 0; s < 16; s++)
  657. i[s] = t[s] * e + h[s] * r
  658. }
  659. }
  660. ,
  661. c.prototype.getModelPartTransform = function (e, t, i, s) {
  662. this.lerpModelPartTransform(e, t, i, s)
  663. }
  664. ,
  665. c.prototype.getAnimatedLocalTransform = function (e, t, i, s) {
  666. e = this.animatedObjects[e];
  667. var n = this.animatedObjects[e.parentIndex]
  668. , r = n.modelPartIndex != n.id
  669. , a = S.identity();
  670. if (this.getModelPartTransform(e.modelPartIndex, t, a, s),
  671. r) {
  672. r = S.identity();
  673. var o = S.identity();
  674. this.getModelPartTransform(n.modelPartIndex, t, r, s),
  675. S.invert(o, r),
  676. S.mul(i, o, a),
  677. i[12] *= e.modelPartScale,
  678. i[13] *= e.modelPartScale,
  679. i[14] *= e.modelPartScale
  680. } else
  681. S.copy(i, a)
  682. }
  683. ,
  684. c.prototype.isVisibleAtFramePercent = function (e, t) {
  685. for (var i = e, s = 0, n = 0; n < 100; n++) {
  686. if ((s = this.animatedObjects[i]).visibleProperty) {
  687. if (s.visibleProperty.evaluate(t, 1, s),
  688. "" != s.debugString || "" != s.visibleProperty.debugString)
  689. return this.debugString += s.debugString,
  690. this.debugString += s.visibleProperty.debugString,
  691. !1;
  692. if (0 == s.visibleProperty.lastValue)
  693. return !1
  694. }
  695. i == s.parentIndex && (n = 100),
  696. i = s.parentIndex
  697. }
  698. return !0
  699. }
  700. ,
  701. c.prototype.getWorldTransform = function (e, t, i, s, n) {
  702. if ((e = this.animatedObjects[e]).useFixedWorldTransform)
  703. S.copy(i, e.cachedWorldTransform0);
  704. else {
  705. var r = this.getObjectAnimationFramePercent(e, t)
  706. , a = S.identity();
  707. if (e.evaluateLocalTransformAtFramePercent(r, a, !0, n),
  708. r = e.modelPartIndex != e.id) {
  709. r = S.identity();
  710. var o = S.identity();
  711. S.copy(o, a),
  712. this.getAnimatedLocalTransform(e.id, t, r),
  713. S.mul(a, r, o)
  714. }
  715. if (S.copy(i, a),
  716. e.parentIndex != e.id)
  717. for (var h = e.parentIndex, l = 0; l < 100; l++)
  718. e = this.animatedObjects[h],
  719. r = this.getObjectAnimationFramePercent(e, t),
  720. a = S.identity(),
  721. e.evaluateLocalTransformAtFramePercent(r, a, !0, n),
  722. (r = e.modelPartIndex != e.id) ? (r = S.identity(),
  723. this.getAnimatedLocalTransform(e.id, t, r),
  724. o = S.identity(),
  725. S.mul(o, a, i),
  726. S.mul(i, r, o)) : (o = S.identity(),
  727. S.copy(o, i),
  728. S.mul(i, a, o)),
  729. h == e.parentIndex && (l = 100),
  730. h = e.parentIndex;
  731. i[12] *= s,
  732. i[13] *= s,
  733. i[14] *= s
  734. }
  735. }
  736. ,
  737. c.prototype.hasParentInHierarchy = function (e, t) {
  738. for (var i = e.parentIndex, s = 0; s < 100; s++) {
  739. if ((e = this.animatedObjects[i]).id == t)
  740. return !0;
  741. i == e.parentIndex && (s = 100),
  742. i = e.parentIndex
  743. }
  744. return !1
  745. }
  746. ,
  747. c.prototype.hasParentTypeInHierarchy = function (e, t) {
  748. for (var i = e.parentIndex, s = 0; s < 100; s++) {
  749. if ((e = this.animatedObjects[i]).sceneObjectType == t)
  750. return !0;
  751. i == e.parentIndex && (s = 100),
  752. i = e.parentIndex
  753. }
  754. return !1
  755. }
  756. ,
  757. c.prototype.searchAnimationUpHierarchy = function (e) {
  758. for (var t = e.id, i = 0; i < 100; i++) {
  759. if ((e = this.animatedObjects[t]).animatedLocalTransform && (e.hasAnimatedTransform() || e.id != e.modelPartIndex && this.searchAnimationUpHierarchy(this.animatedObjects[e.modelPartIndex])))
  760. return !0;
  761. t == e.parentIndex && (i = 100),
  762. t = e.parentIndex
  763. }
  764. return !1
  765. }
  766. ,
  767. c.prototype.hasAnimationInHierarchy = function (e) {
  768. return !!(this.searchAnimationUpHierarchy(e) || e.id != e.modelPartIndex && this.searchAnimationUpHierarchy(this.animatedObjects[e.modelPartIndex]) || this.hasParentTypeInHierarchy(e, "TurnTableSO") || this.hasParentTypeInHierarchy(e, "CameraSO") || "CameraSO" == e.sceneObjectType)
  769. }
  770. ,
  771. c.prototype.getObjectAnimationFramePercent = function (e, t) {
  772. if (0 == this.totalFrames || 0 == e.animationLength)
  773. return 0;
  774. var i = t / e.animationLength;
  775. i = Math.floor(i);
  776. return (i = (t -= e.animationLength * i) * e.modelPartFPS) >= e.totalFrames + 1 && (i = e.totalFrames),
  777. i
  778. }
  779. ,
  780. h.prototype.get = function (e) {
  781. return this.files[e]
  782. }
  783. ,
  784. h.prototype.extract = function (e) {
  785. var t = this.files[e];
  786. return delete this.files[e],
  787. t
  788. }
  789. ,
  790. h.prototype.checkSignature = function (e) {
  791. if (!e)
  792. return !1;
  793. var t = this.get(e.name + ".sig");
  794. if (!t)
  795. return !1;
  796. if (!(t = JSON.parse(String.fromCharCode.apply(null, t.data))))
  797. return !1;
  798. for (var i = 5381, s = 0; s < e.data.length; ++s)
  799. i = 33 * i + e.data[s] & 4294967295;
  800. return (e = new l).setBytes([0, 233, 33, 170, 116, 86, 29, 195, 228, 46, 189, 3, 185, 31, 245, 19, 159, 105, 73, 190, 158, 80, 175, 38, 210, 116, 221, 229, 171, 134, 104, 144, 140, 5, 99, 255, 208, 78, 248, 215, 172, 44, 79, 83, 5, 244, 152, 19, 92, 137, 112, 10, 101, 142, 209, 100, 244, 92, 190, 125, 28, 0, 185, 54, 143, 247, 49, 37, 15, 254, 142, 180, 185, 232, 50, 219, 11, 186, 106, 116, 78, 212, 10, 105, 53, 26, 14, 181, 80, 47, 87, 213, 182, 19, 126, 151, 86, 109, 182, 224, 37, 135, 80, 59, 22, 93, 125, 68, 214, 106, 209, 152, 235, 157, 249, 245, 48, 76, 203, 0, 0, 95, 200, 246, 243, 229, 85, 79, 169], !0),
  801. (s = new l).setBytes(t[0]),
  802. s.powmod(65537, e).toInt32() == i
  803. }
  804. ,
  805. h.prototype.decompress = function (e, t) {
  806. var i = new Uint8Array(t)
  807. , s = 0
  808. , n = new Uint32Array(4096)
  809. , r = new Uint32Array(4096)
  810. , a = 256
  811. , o = e.length
  812. , h = 0
  813. , l = 1
  814. , d = 0
  815. , c = 1;
  816. i[s++] = e[0];
  817. for (var u = 1; !(o <= (c = u + (u >> 1)) + 1); u++) {
  818. d = e[c + 1],
  819. c = e[c];
  820. if ((f = 1 & u ? d << 4 | c >> 4 : (15 & d) << 8 | c) < a)
  821. if (f < 256)
  822. d = s,
  823. c = 1,
  824. i[s++] = f;
  825. else {
  826. d = s,
  827. c = r[f];
  828. for (var f, m = (f = n[f]) + c; f < m;)
  829. i[s++] = i[f++]
  830. }
  831. else {
  832. if (f != a)
  833. break;
  834. for (d = s,
  835. c = l + 1,
  836. m = (f = h) + l; f < m;)
  837. i[s++] = i[f++];
  838. i[s++] = i[h]
  839. }
  840. n[a] = h,
  841. r[a++] = l + 1,
  842. h = d,
  843. l = c,
  844. a = 4096 <= a ? 256 : a
  845. }
  846. return s == t ? i : null
  847. }
  848. ,
  849. l.prototype.setBytes = function (e, t) {
  850. var i = (e.length + 1) / 2 | 0;
  851. if (this.digits = new Uint16Array(i),
  852. t) {
  853. var s = 0;
  854. for (i = e.length - 1; 0 <= i; i -= 2)
  855. this.digits[s++] = e[i] + (0 < i ? 256 * e[i - 1] : 0)
  856. } else
  857. for (s = 0; s < i; ++s)
  858. this.digits[s] = e[2 * s] + 256 * e[2 * s + 1];
  859. this.trim()
  860. }
  861. ,
  862. l.prototype.toInt32 = function () {
  863. var e = 0;
  864. return 0 < this.digits.length && (e = this.digits[0],
  865. 1 < this.digits.length && (e |= this.digits[1] << 16)),
  866. e
  867. }
  868. ,
  869. l.prototype.lessThan = function (e) {
  870. if (this.digits.length == e.digits.length)
  871. for (var t = this.digits.length - 1; 0 <= t; --t) {
  872. var i = this.digits[t]
  873. , s = e.digits[t];
  874. if (i != s)
  875. return i < s
  876. }
  877. return this.digits.length < e.digits.length
  878. }
  879. ,
  880. l.prototype.shiftRight = function () {
  881. for (var e = 0, t = this.digits, i = t.length - 1; 0 <= i; --i) {
  882. var s = t[i];
  883. t[i] = s >> 1 | e << 15,
  884. e = s
  885. }
  886. this.trim()
  887. }
  888. ,
  889. l.prototype.shiftLeft = function (e) {
  890. if (0 < e) {
  891. for (var t = e / 16 | 0, i = 16 - (e %= 16), s = this.digits.length + t + 1, n = new l(s), r = 0; r < s; ++r)
  892. n.digits[r] = 65535 & ((r < t || r >= this.digits.length + t ? 0 : this.digits[r - t]) << e | (r < 1 + t ? 0 : this.digits[r - t - 1]) >>> i);
  893. return n.trim(),
  894. n
  895. }
  896. return new l(this)
  897. }
  898. ,
  899. l.prototype.bitCount = function () {
  900. var e = 0;
  901. if (0 < this.digits.length) {
  902. e = 16 * (this.digits.length - 1);
  903. for (var t = this.digits[this.digits.length - 1]; t;)
  904. t >>>= 1,
  905. ++e
  906. }
  907. return e
  908. }
  909. ,
  910. l.prototype.sub = function (e) {
  911. var t = this.digits
  912. , i = e.digits
  913. , s = this.digits.length;
  914. e = e.digits.length;
  915. for (var n = 0, r = 0; r < s; ++r) {
  916. var a, o = (o = t[r]) + ((n = o < (a = (a = r < e ? i[r] : 0) + n) ? 1 : 0) << 16);
  917. t[r] = o - a & 65535
  918. }
  919. this.trim()
  920. }
  921. ,
  922. l.prototype.mul = function (e) {
  923. for (var t = new l(this.digits.length + e.digits.length), i = t.digits, s = 0; s < this.digits.length; ++s)
  924. for (var n = this.digits[s], r = 0; r < e.digits.length; ++r)
  925. for (var a = n * e.digits[r], o = s + r; a;) {
  926. var h = (65535 & a) + i[o];
  927. i[o] = 65535 & h,
  928. a >>>= 16,
  929. a += h >>> 16,
  930. ++o
  931. }
  932. return t.trim(),
  933. t
  934. }
  935. ,
  936. l.prototype.mod = function (e) {
  937. if (this.digits.length <= 0 || e.digits.length <= 0)
  938. return new l(0);
  939. var t = new l(this.digits);
  940. if (!this.lessThan(e)) {
  941. for (var i = (i = new l(e.digits)).shiftLeft(t.bitCount() - i.bitCount()); !t.lessThan(e);)
  942. i.lessThan(t) && t.sub(i),
  943. i.shiftRight();
  944. t.trim()
  945. }
  946. return t
  947. }
  948. ,
  949. l.prototype.powmod = function (e, t) {
  950. for (var i = new l([1]), s = this.mod(t); e;)
  951. 1 & e && (i = i.mul(s).mod(t)),
  952. e >>>= 1,
  953. s = s.mul(s).mod(t);
  954. return i
  955. }
  956. ,
  957. l.prototype.trim = function () {
  958. for (var e = this.digits.length; 0 < e && 0 == this.digits[e - 1];)
  959. --e;
  960. e != this.digits.length && (this.digits = this.digits.subarray(0, e))
  961. }
  962. ,
  963. p.prototype.setBackground3x1 = function (e, t, i, s, n, r, a) {
  964. this.backgroundOffsetX = t,
  965. this.backgroundOffsetY = i,
  966. this.edgePixelsX = a,
  967. this.backgroundLeft = e.addImage(s),
  968. this.backgroundMiddle = e.addImage(n),
  969. this.backgroundRight = e.addImage(r),
  970. this.backgroundLeft.linkedControl.style.zIndex = "0",
  971. this.backgroundMiddle.linkedControl.style.zIndex = "0",
  972. this.backgroundRight.linkedControl.style.zIndex = "0",
  973. this.setOpacity(this.defaultAlpha)
  974. }
  975. ,
  976. p.prototype.setBackground3x3 = function (e, t, i, s, n, r, a, o, h, l, d, c, u, f) {
  977. this.backgroundOffsetX = t,
  978. this.backgroundOffsetY = i,
  979. this.edgePixelsX = u,
  980. this.edgePixelsY = f,
  981. this.backgroundTopLeft = e.addImage(s),
  982. this.backgroundMiddleLeft = e.addImage(a),
  983. this.backgroundBottomLeft = e.addImage(l),
  984. this.backgroundTopMiddle = e.addImage(n),
  985. this.backgroundMiddleMiddle = e.addImage(o),
  986. this.backgroundBottomMiddle = e.addImage(d),
  987. this.backgroundTopRight = e.addImage(r),
  988. this.backgroundMiddleRight = e.addImage(h),
  989. this.backgroundBottomRight = e.addImage(c),
  990. this.backgroundTopLeft.linkedControl.style.zIndex = "0",
  991. this.backgroundTopRight.linkedControl.style.zIndex = "0",
  992. this.backgroundTopMiddle.linkedControl.style.zIndex = "0",
  993. this.backgroundMiddleLeft.linkedControl.style.zIndex = "0",
  994. this.backgroundMiddleRight.linkedControl.style.zIndex = "0",
  995. this.backgroundMiddleMiddle.linkedControl.style.zIndex = "0",
  996. this.backgroundBottomLeft.linkedControl.style.zIndex = "0",
  997. this.backgroundBottomRight.linkedControl.style.zIndex = "0",
  998. this.backgroundBottomMiddle.linkedControl.style.zIndex = "0",
  999. this.setOpacity(this.defaultAlpha)
  1000. }
  1001. ,
  1002. p.prototype.alignBackground = function () {
  1003. var e = (n = (s = this.controlRect).guiScreen).left * (1 - s.getScreenXPercent())
  1004. , t = n.bottom * (1 - s.getScreenYPercent())
  1005. , i = n.width * s.getScreenWidthPercent()
  1006. , s = n.height * s.getScreenHeightPercent();
  1007. t += this.backgroundOffsetY,
  1008. e += this.backgroundOffsetX;
  1009. if (this.backgroundTopLeft && this.backgroundTopRight && this.backgroundTopMiddle && this.backgroundMiddleLeft && this.backgroundMiddleRight && this.backgroundMiddleMiddle && this.backgroundBottomLeft && this.backgroundBottomRight && this.backgroundBottomMiddle) {
  1010. var n = i - 2 * this.edgePixelsX
  1011. , r = s - 2 * this.edgePixelsY;
  1012. this.backgroundTopLeft.linkedControl.style.height = this.edgePixelsY + "px",
  1013. this.backgroundTopMiddle.linkedControl.style.height = this.edgePixelsY + "px",
  1014. this.backgroundTopRight.linkedControl.style.height = this.edgePixelsY + "px",
  1015. this.backgroundBottomLeft.linkedControl.style.height = this.edgePixelsY + "px",
  1016. this.backgroundBottomMiddle.linkedControl.style.height = this.edgePixelsY + "px",
  1017. this.backgroundBottomRight.linkedControl.style.height = this.edgePixelsY + "px",
  1018. this.backgroundMiddleLeft.linkedControl.style.height = r + "px",
  1019. this.backgroundMiddleMiddle.linkedControl.style.height = r + "px",
  1020. this.backgroundMiddleRight.linkedControl.style.height = r + "px",
  1021. this.backgroundTopLeft.linkedControl.style.width = this.edgePixelsX + "px",
  1022. this.backgroundBottomLeft.linkedControl.style.width = this.edgePixelsX + "px",
  1023. this.backgroundMiddleLeft.linkedControl.style.width = this.edgePixelsX + "px",
  1024. this.backgroundTopRight.linkedControl.style.width = this.edgePixelsX + "px",
  1025. this.backgroundBottomRight.linkedControl.style.width = this.edgePixelsX + "px",
  1026. this.backgroundMiddleRight.linkedControl.style.width = this.edgePixelsX + "px",
  1027. this.backgroundTopMiddle.linkedControl.style.width = n + "px",
  1028. this.backgroundBottomMiddle.linkedControl.style.width = n + "px",
  1029. this.backgroundMiddleMiddle.linkedControl.style.width = n + "px",
  1030. this.backgroundTopLeft.linkedControl.style.left = e + "px",
  1031. this.backgroundBottomLeft.linkedControl.style.left = e + "px",
  1032. this.backgroundMiddleLeft.linkedControl.style.left = e + "px",
  1033. e += this.edgePixelsX,
  1034. this.backgroundTopMiddle.linkedControl.style.left = e + "px",
  1035. this.backgroundBottomMiddle.linkedControl.style.left = e + "px",
  1036. this.backgroundMiddleMiddle.linkedControl.style.left = e + "px",
  1037. e += n,
  1038. this.backgroundTopRight.linkedControl.style.left = e + "px",
  1039. this.backgroundBottomRight.linkedControl.style.left = e + "px",
  1040. this.backgroundMiddleRight.linkedControl.style.left = e + "px",
  1041. this.backgroundBottomLeft.linkedControl.style.bottom = t + "px",
  1042. this.backgroundBottomMiddle.linkedControl.style.bottom = t + "px",
  1043. this.backgroundBottomRight.linkedControl.style.bottom = t + "px",
  1044. t += this.edgePixelsY,
  1045. this.backgroundMiddleLeft.linkedControl.style.bottom = t + "px",
  1046. this.backgroundMiddleRight.linkedControl.style.bottom = t + "px",
  1047. this.backgroundMiddleMiddle.linkedControl.style.bottom = t + "px",
  1048. t += r,
  1049. this.backgroundTopLeft.linkedControl.style.bottom = t + "px",
  1050. this.backgroundTopMiddle.linkedControl.style.bottom = t + "px",
  1051. this.backgroundTopRight.linkedControl.style.bottom = t + "px"
  1052. }
  1053. this.backgroundLeft && this.backgroundRight && this.backgroundMiddle && (i -= 2 * this.edgePixelsX,
  1054. this.backgroundLeft.linkedControl.style.bottom = t + "px",
  1055. this.backgroundMiddle.linkedControl.style.bottom = t + "px",
  1056. this.backgroundRight.linkedControl.style.bottom = t + "px",
  1057. this.backgroundLeft.linkedControl.style.height = s + "px",
  1058. this.backgroundMiddle.linkedControl.style.height = s + "px",
  1059. this.backgroundRight.linkedControl.style.height = s + "px",
  1060. this.backgroundLeft.linkedControl.style.width = this.edgePixelsX + "px",
  1061. this.backgroundMiddle.linkedControl.style.width = i + "px",
  1062. this.backgroundRight.linkedControl.style.width = this.edgePixelsX + "px",
  1063. this.backgroundLeft.linkedControl.style.left = e + "px",
  1064. e += this.edgePixelsX,
  1065. this.backgroundMiddle.linkedControl.style.left = e + "px",
  1066. this.backgroundRight.linkedControl.style.left = e + i + "px")
  1067. }
  1068. ,
  1069. p.prototype.setOpacity = function (e) {
  1070. this.controlRect.linkedControl.style.opacity = e,
  1071. this.backgroundLeft && (this.backgroundLeft.linkedControl.style.opacity = e),
  1072. this.backgroundRight && (this.backgroundRight.linkedControl.style.opacity = e),
  1073. this.backgroundMiddle && (this.backgroundMiddle.linkedControl.style.opacity = e),
  1074. this.backgroundTopLeft && (this.backgroundTopLeft.linkedControl.style.opacity = e),
  1075. this.backgroundTopRight && (this.backgroundTopRight.linkedControl.style.opacity = e),
  1076. this.backgroundTopMiddle && (this.backgroundTopMiddle.linkedControl.style.opacity = e),
  1077. this.backgroundMiddleLeft && (this.backgroundMiddleLeft.linkedControl.style.opacity = e),
  1078. this.backgroundMiddleRight && (this.backgroundMiddleRight.linkedControl.style.opacity = e),
  1079. this.backgroundMiddleMiddle && (this.backgroundMiddleMiddle.linkedControl.style.opacity = e),
  1080. this.backgroundBottomLeft && (this.backgroundBottomLeft.linkedControl.style.opacity = e),
  1081. this.backgroundBottomRight && (this.backgroundBottomRight.linkedControl.style.opacity = e),
  1082. this.backgroundBottomMiddle && (this.backgroundBottomMiddle.linkedControl.style.opacity = e)
  1083. }
  1084. ,
  1085. p.prototype.setBackgroundVisible = function (e) {
  1086. this.backgroundLeft && this.backgroundLeft.showControl(e),
  1087. this.backgroundRight && this.backgroundRight.showControl(e),
  1088. this.backgroundMiddle && this.backgroundMiddle.showControl(e),
  1089. this.backgroundTopLeft && this.backgroundTopLeft.showControl(e),
  1090. this.backgroundTopRight && this.backgroundTopRight.showControl(e),
  1091. this.backgroundTopMiddle && this.backgroundTopMiddle.showControl(e),
  1092. this.backgroundMiddleLeft && this.backgroundMiddleLeft.showControl(e),
  1093. this.backgroundMiddleRight && this.backgroundMiddleRight.showControl(e),
  1094. this.backgroundMiddleMiddle && this.backgroundMiddleMiddle.showControl(e),
  1095. this.backgroundBottomLeft && this.backgroundBottomLeft.showControl(e),
  1096. this.backgroundBottomRight && this.backgroundBottomRight.showControl(e),
  1097. this.backgroundBottomMiddle && this.backgroundBottomMiddle.showControl(e)
  1098. }
  1099. ,
  1100. p.prototype.setVisible = function (e) {
  1101. this.controlRect.showControl(e),
  1102. this.setBackgroundVisible(e)
  1103. }
  1104. ,
  1105. p.prototype.linkControl = function (e) {
  1106. (this.controlRect.linkedControl = e).onmouseover = function () {
  1107. this.updateAlphas && (this.setOpacity(this.focusAlpha),
  1108. this.controlRect.mouseOver = !0,
  1109. this.linkedBackground && this.linkedBackground.setOpacity(this.focusAlpha))
  1110. }
  1111. .bind(this),
  1112. e.onmouseout = function () {
  1113. this.updateAlphas && (this.setOpacity(this.defaultAlpha),
  1114. this.controlRect.mouseOver = !1,
  1115. this.linkedBackground && this.linkedBackground.setOpacity(this.defaultAlpha))
  1116. }
  1117. .bind(this)
  1118. }
  1119. ,
  1120. u.prototype.empty = function () {
  1121. return this.bytes.length <= 0
  1122. }
  1123. ,
  1124. u.prototype.readCString = function () {
  1125. for (var e = this.bytes, t = e.length, i = 0; i < t; ++i)
  1126. if (0 == e[i])
  1127. return e = String.fromCharCode.apply(null, this.bytes.subarray(0, i)),
  1128. this.bytes = this.bytes.subarray(i + 1),
  1129. e;
  1130. return null
  1131. }
  1132. ,
  1133. u.prototype.asString = function () {
  1134. for (var e = "", t = 0; t < this.bytes.length; ++t)
  1135. e += String.fromCharCode(this.bytes[t]);
  1136. return e
  1137. }
  1138. ,
  1139. u.prototype.readBytes = function (e) {
  1140. var t = this.bytes.subarray(0, e);
  1141. return this.bytes = this.bytes.subarray(e),
  1142. t
  1143. }
  1144. ,
  1145. u.prototype.readUint32 = function () {
  1146. var e = this.bytes
  1147. , t = e[0] | e[1] << 8 | e[2] << 16 | e[3] << 24;
  1148. return this.bytes = e.subarray(4),
  1149. t
  1150. }
  1151. ,
  1152. u.prototype.readUint8 = function () {
  1153. var e = this.bytes
  1154. , t = e[0];
  1155. return this.bytes = e.subarray(1),
  1156. t
  1157. }
  1158. ,
  1159. u.prototype.readUint16 = function () {
  1160. var e = this.bytes
  1161. , t = e[0] | e[1] << 8;
  1162. return this.bytes = e.subarray(2),
  1163. t
  1164. }
  1165. ,
  1166. u.prototype.readFloat32 = function () {
  1167. var e = new Uint8Array(this.bytes);
  1168. e = new Float32Array(e.buffer);
  1169. return this.bytes = this.bytes.subarray(4),
  1170. e[0]
  1171. }
  1172. ,
  1173. u.prototype.seekUint32 = function (e) {
  1174. return (e = this.bytes.subarray(4 * e))[0] | e[1] << 8 | e[2] << 16 | e[3] << 24
  1175. }
  1176. ,
  1177. u.prototype.seekFloat32 = function (e) {
  1178. return e = new Uint8Array(this.bytes.subarray(4 * e)),
  1179. new Float32Array(e.buffer)[0]
  1180. }
  1181. ,
  1182. u.prototype.getMatrix = function (e) {
  1183. return new Float32Array(this.bytes.buffer, 64 * e, 16)
  1184. }
  1185. ,
  1186. s.prototype.getScreenWidth = function () {
  1187. if (this.linkedControl)
  1188. return this.guiScreen.width * this.getScreenWidthPercent()
  1189. }
  1190. ,
  1191. s.prototype.getScreenHeight = function () {
  1192. if (this.linkedControl)
  1193. return this.guiScreen.height * this.getScreenHeightPercent()
  1194. }
  1195. ,
  1196. s.prototype.updateElement = function () {
  1197. var e = this.linkedControl;
  1198. if (e) {
  1199. var t = this.guiScreen.left * (1 - this.getScreenXPercent())
  1200. , i = this.guiScreen.bottom * (1 - this.getScreenYPercent())
  1201. , s = this.guiScreen.width * this.getScreenWidthPercent()
  1202. , n = this.guiScreen.height * this.getScreenHeightPercent();
  1203. e.style.left = t + "px",
  1204. e.style.bottom = i + "px",
  1205. e.style.width = s + "px",
  1206. e.style.height = n + "px"
  1207. }
  1208. }
  1209. ,
  1210. s.prototype.updateElement = function () {
  1211. var e = this.linkedControl;
  1212. if (e) {
  1213. var t = this.guiScreen.left * (1 - this.getScreenXPercent())
  1214. , i = this.guiScreen.bottom * (1 - this.getScreenYPercent())
  1215. , s = this.guiScreen.width * this.getScreenWidthPercent()
  1216. , n = this.guiScreen.height * this.getScreenHeightPercent();
  1217. e.style.left = t + "px",
  1218. e.style.bottom = i + "px",
  1219. e.style.width = s + "px",
  1220. e.style.height = n + "px"
  1221. }
  1222. }
  1223. ,
  1224. s.prototype.updateChildElements = function () {
  1225. this.updateElement();
  1226. for (var e = 0; e < this.childControlRects.length; e++)
  1227. this.childControlRects[e].updateChildElements()
  1228. }
  1229. ,
  1230. s.prototype.set = function (e, t, i, s) {
  1231. this.xPercent = e,
  1232. this.yPercent = t,
  1233. this.widthPercent = i,
  1234. this.heightPercent = s
  1235. }
  1236. ,
  1237. s.prototype.linkControl = function (e) {
  1238. (this.linkedControl = e).onmouseover = function () {
  1239. this.mouseOver = !0
  1240. }
  1241. .bind(this),
  1242. e.onmouseout = function () {
  1243. this.mouseOver = !1
  1244. }
  1245. .bind(this),
  1246. e.onmousedown = function () {
  1247. this.mouseDown = !0
  1248. }
  1249. .bind(this),
  1250. e.onmouseup = function () {
  1251. this.mouseDown = !1
  1252. }
  1253. .bind(this),
  1254. e.onclick = function () {
  1255. this.callBack && this.callBack(this),
  1256. this.clicked = !0
  1257. }
  1258. .bind(this)
  1259. }
  1260. ,
  1261. s.prototype.showControl = function (e) {
  1262. this.visible = e,
  1263. this.linkedControl && (this.linkedControl.style.display = e ? "block" : "none")
  1264. }
  1265. ,
  1266. s.prototype.setOpacity = function (e) {
  1267. this.opacity = e,
  1268. this.linkedControl && (this.linkedControl.style.opacity = e)
  1269. }
  1270. ,
  1271. s.prototype.hasChildControlRect = function (e) {
  1272. for (var t = 0; t < this.childControlRects.length; t++)
  1273. if (this.childControlRects[t] == e)
  1274. return !0;
  1275. return !1
  1276. }
  1277. ,
  1278. s.prototype.registerChildControlRect = function (e) {
  1279. this.hasChildControlRect(e) || (this.childControlRects.push(e),
  1280. e.parentControlRect = this)
  1281. }
  1282. ,
  1283. s.prototype.getScreenWidthPercent = function () {
  1284. var e = this.widthPercent;
  1285. return this.parentControlRect && (e *= this.parentControlRect.getScreenWidthPercent()),
  1286. e
  1287. }
  1288. ,
  1289. s.prototype.getScreenHeightPercent = function () {
  1290. var e = this.heightPercent;
  1291. return this.parentControlRect && (e *= this.parentControlRect.getScreenHeightPercent()),
  1292. e
  1293. }
  1294. ,
  1295. s.prototype.getScreenXPercent = function () {
  1296. var e = this.xPercent;
  1297. return this.parentControlRect && (e *= this.parentControlRect.getScreenWidthPercent(),
  1298. e += this.parentControlRect.getScreenXPercent()),
  1299. e
  1300. }
  1301. ,
  1302. s.prototype.getScreenYPercent = function () {
  1303. var e = this.yPercent;
  1304. return this.parentControlRect && (e *= this.parentControlRect.getScreenHeightPercent(),
  1305. e += this.parentControlRect.getScreenYPercent()),
  1306. e
  1307. }
  1308. ;
  1309. function n(e, t, i, s) {
  1310. var n = !1
  1311. , r = e + (-1 == e.indexOf("?") ? "?" : "&") + "thumb=1"
  1312. , a = function (e) {
  1313. return (e = new h(e).extract("thumbnail.jpg")) ? N.parseFile(e, t, s) : n ? i && i() : (n = !0,
  1314. C.fetchBinaryIncremental(r, a, i, 394240)),
  1315. 0
  1316. };
  1317. C.fetchBinaryIncremental(r, a, i, 65536)
  1318. }
  1319. function f(e, t) {
  1320. this.desc = t,
  1321. this.gl = e,
  1322. this.iblShader = e.shaderCache.fromURLs("fogvert.glsl", "fogfrag.glsl", ["#define FOG_IBL"]);
  1323. var i = ["#define FOG_DIR"];
  1324. this.dirShader = e.shaderCache.fromURLs("fogvert.glsl", "fogfrag.glsl", i),
  1325. i.push("#define FOG_SHADOWS"),
  1326. this.dirShaderShadow = e.shaderCache.fromURLs("fogvert.glsl", "fogfrag.glsl", i),
  1327. i = ["#define FOG_SPOT"],
  1328. this.spotShader = e.shaderCache.fromURLs("fogvert.glsl", "fogfrag.glsl", i),
  1329. i.push("#define FOG_SHADOWS"),
  1330. this.spotShaderShadow = e.shaderCache.fromURLs("fogvert.glsl", "fogfrag.glsl", i),
  1331. i = ["#define FOG_OMNI"],
  1332. this.omniShaderShadow = this.omniShader = e.shaderCache.fromURLs("fogvert.glsl", "fogfrag.glsl", i),
  1333. this.fullscreenTriangle = e.createBuffer(),
  1334. e.bindBuffer(e.ARRAY_BUFFER, this.fullscreenTriangle),
  1335. i = new Float32Array([0, 0, 2, 0, 0, 2]),
  1336. e.bufferData(e.ARRAY_BUFFER, i, e.STATIC_DRAW),
  1337. e.bindBuffer(e.ARRAY_BUFFER, null)
  1338. }
  1339. function m(e, t) {
  1340. this.gl = e,
  1341. this.fbo = e.createFramebuffer(),
  1342. e.bindFramebuffer(e.FRAMEBUFFER, this.fbo),
  1343. t && (this.width = t.width,
  1344. this.height = t.height,
  1345. t.color0 && (this.color0 = t.color0,
  1346. e.framebufferTexture2D(e.FRAMEBUFFER, e.COLOR_ATTACHMENT0, e.TEXTURE_2D, this.color0.id, 0),
  1347. this.width = t.color0.desc.width,
  1348. this.height = t.color0.desc.height),
  1349. t.depth ? (this.depth = t.depth,
  1350. e.framebufferTexture2D(e.FRAMEBUFFER, e.DEPTH_ATTACHMENT, e.TEXTURE_2D, this.depth.id, 0)) : (this.depthBuffer = t.depthBuffer,
  1351. t.createDepth && !this.depthBuffer && (this.depthBuffer = m.createDepthBuffer(e, this.width, this.height)),
  1352. this.depthBuffer && (e.bindRenderbuffer(e.RENDERBUFFER, this.depthBuffer),
  1353. e.framebufferRenderbuffer(e.FRAMEBUFFER, e.DEPTH_ATTACHMENT, e.RENDERBUFFER, this.depthBuffer),
  1354. e.bindRenderbuffer(e.RENDERBUFFER, null)))),
  1355. this.valid = t && t.ignoreStatus || e.checkFramebufferStatus(e.FRAMEBUFFER) == e.FRAMEBUFFER_COMPLETE,
  1356. e.bindFramebuffer(e.FRAMEBUFFER, null)
  1357. }
  1358. (I = void 0 === I ? {} : I).embed = function (e, t) {
  1359. var i, s = (t = function (e) {
  1360. if (e = e || {},
  1361. document.location.search)
  1362. for (var t = document.location.search.substring(1).split("&"), i = 0; i < t.length; ++i) {
  1363. var s = t[i].split("=");
  1364. e[s[0]] = s[1]
  1365. }
  1366. return t = function (e) {
  1367. if (0 | e)
  1368. return !0;
  1369. for (var t = "true True TRUE yes Yes YES".split(" "), i = 0; i < t.length; ++i)
  1370. if (e === t[i])
  1371. return !0;
  1372. return !1
  1373. }
  1374. ,
  1375. e.width = e.width || 800,
  1376. e.height = e.height || 600,
  1377. e.autoStart = t(e.autoStart),
  1378. e.pagePreset = t(e.pagePreset),
  1379. e.fullFrame = t(e.fullFrame) || t(e.bare),
  1380. e.fullFrame = !e.pagePreset && e.fullFrame,
  1381. e
  1382. }(t)).thumbnailURL;
  1383. if (t.pagePreset) {
  1384. i = new W(t.width, t.height, e, !!s),
  1385. document.body.style.backgroundColor = "#d7e4da";
  1386. var n = document.createElement("div");
  1387. n.style.position = "relative",
  1388. n.style.backgroundColor = "#e4e7e4",
  1389. n.style.width = t.width + 12 + "px",
  1390. n.style.height = t.height + 6 + 16 + "px",
  1391. n.style.margin = "auto",
  1392. n.style.boxShadow = "3px 5px 12px 0px grey",
  1393. document.body.appendChild(n);
  1394. var r = document.createElement("div");
  1395. if (r.style.position = "relative",
  1396. r.style.left = "6px",
  1397. r.style.top = "6px",
  1398. n.appendChild(r),
  1399. r.appendChild(i.domRoot),
  1400. !i.mobile) {
  1401. n.style.resize = "both",
  1402. n.style.overflow = "hidden";
  1403. var a = [n.style.width, n.style.height]
  1404. , o = function () {
  1405. g.active() ? n.style.resize = "none" : (n.style.resize = "both",
  1406. a[0] == n.style.width && a[1] == n.style.height || (a[0] = n.style.width,
  1407. a[1] = n.style.height,
  1408. i.resize(n.clientWidth - 12, n.clientHeight - 6 - 16))),
  1409. window.setTimeout(o, 100)
  1410. };
  1411. o()
  1412. }
  1413. } else
  1414. i = new W(t.fullFrame ? window.innerWidth : t.width, t.fullFrame ? window.innerHeight : t.height, e, !!s),
  1415. document.body.appendChild(i.domRoot),
  1416. t.fullFrame && (i.domRoot.style.position = "absolute",
  1417. i.domRoot.style.left = i.domRoot.style.top = 0,
  1418. window.addEventListener("resize", function () {
  1419. g.active() || i.resize(this.document.body.clientWidth, this.document.body.clientHeight)
  1420. }));
  1421. return (webview = i).ui.setThumbnailURL(s),
  1422. t.autoStart && i.loadScene(),
  1423. i
  1424. }
  1425. ,
  1426. I.fetchThumbnail = n,
  1427. f.prototype.draw = function (e, t) {
  1428. var i = this.gl
  1429. , s = e.view
  1430. , n = s.projectionMatrix
  1431. , r = S.empty();
  1432. S.mul(r, s.viewMatrix, s.projectionMatrix),
  1433. S.invert(r, s.viewProjectionMatrix),
  1434. r = [n[10] + n[11], -n[14], -2 * n[11]],
  1435. n = [-2 / n[0], -2 / n[5], (1 - n[8]) / n[0], (1 - n[9]) / n[5]],
  1436. i.enable(i.BLEND),
  1437. i.blendFunc(i.ONE, i.ONE_MINUS_SRC_ALPHA);
  1438. for (var a = 0; a < e.lights.count + 1; ++a) {
  1439. var o, h = a - 1, l = h < e.lights.shadowCount;
  1440. (o = 0 == a ? this.iblShader : 0 < e.lights.spot[3 * h] ? l ? this.spotShaderShadow : this.spotShader : 0 < e.lights.getLightPos(h)[3] ? this.omniShader : l ? this.dirShaderShadow : this.dirShader).bind();
  1441. var d = o.params;
  1442. if (i.uniform3fv(d.uDepthToZ, r),
  1443. i.uniform4fv(d.uUnproject, n),
  1444. i.uniformMatrix4fv(d.uInvViewMatrix, !1, s.transform),
  1445. i.uniform1f(d.uFogInvDistance, 1 / this.desc.distance),
  1446. i.uniform1f(d.uFogOpacity, this.desc.opacity * (1 - e.stripData.activeFade())),
  1447. i.uniform1f(d.uFogDispersion, 1 - this.desc.dispersion),
  1448. (u = [0, 0, 0])[this.desc.type] = 1,
  1449. i.uniform3fv(d.uFogType, u),
  1450. i.uniform3fv(d.uFogColor, this.desc.color),
  1451. i.uniform1f(d.uFogIllum, 0 == a ? this.desc.skyIllum : this.desc.lightIllum),
  1452. i.uniformMatrix4fv(d.uLightMatrix, !1, e.lights.invMatrix),
  1453. 0 == a) {
  1454. for (h = new Float32Array(e.sky.diffuseCoefficients),
  1455. l = 4; l < 16; ++l)
  1456. h[l] *= 1 - this.desc.dispersion;
  1457. for (l = 16; l < 36; ++l)
  1458. h[l] *= 1 - this.desc.dispersion * this.desc.dispersion;
  1459. i.uniform4fv(d.uFogLightSphere, h)
  1460. } else {
  1461. var c = e.lights.getLightPos(h)
  1462. , u = (c = S.mul4(V.empty(), e.lights.invMatrix, c[0], c[1], c[2], c[3]),
  1463. e.lights.getLightDir(h));
  1464. u = S.mulVec(V.empty(), e.lights.invMatrix, u[0], u[1], u[2]);
  1465. i.uniform4fv(d.uLightPosition, c),
  1466. i.uniform3fv(d.uLightColor, e.lights.getColor(h));
  1467. c = .01745329251 * e.lights.spot[3 * h];
  1468. var f = Math.cos(.5 * c);
  1469. i.uniform4fv(d.uSpotParams, [-u[0], -u[1], -u[2], 0 < c ? f * f : 0]),
  1470. i.uniform4fv(d.uLightAttenuation, [e.lights.parameters[3 * h + 0], e.lights.parameters[3 * h + 1], e.lights.parameters[3 * h + 2], f]),
  1471. l && (l = S.mul(S.empty(), e.lights.finalTransformBuffer.subarray(16 * h), e.lights.matrix),
  1472. i.uniformMatrix4fv(d.uShadowProj, !1, l),
  1473. e.shadow.depthTextures[h].bind(o.samplers.uShadowMap),
  1474. h = 0,
  1475. 1 < e.postRender.sampleCount && (h = e.postRender.currentSample() / e.postRender.sampleCount),
  1476. i.uniform1f(d.uDitherOffset, h),
  1477. i.uniform3fv(d.uAABBMin, e.bounds.min),
  1478. i.uniform3fv(d.uAABBMax, e.bounds.max),
  1479. h = V.lerp(V.empty(), e.bounds.min, e.bounds.max, .5),
  1480. l = V.distance(h, e.bounds.min),
  1481. i.uniform4f(d.uCylinder, h[0], h[1], h[2], l * l))
  1482. }
  1483. t.bind(o.samplers.tDepth),
  1484. o = o.attribs.vCoord,
  1485. i.bindBuffer(i.ARRAY_BUFFER, this.fullscreenTriangle),
  1486. i.enableVertexAttribArray(o),
  1487. i.vertexAttribPointer(o, 2, i.FLOAT, !1, 0, 0),
  1488. i.drawArrays(i.TRIANGLES, 0, 3),
  1489. i.disableVertexAttribArray(o),
  1490. i.bindBuffer(i.ARRAY_BUFFER, null)
  1491. }
  1492. i.disable(i.BLEND)
  1493. }
  1494. ,
  1495. f.prototype.complete = function () {
  1496. return this.iblShader.complete() && this.dirShader.complete() && this.dirShaderShadow.complete() && this.spotShader.complete() && this.spotShaderShadow.complete() && this.omniShader.complete() && this.omniShaderShadow.complete()
  1497. }
  1498. ,
  1499. m.createDepthBuffer = function (e, t, i) {
  1500. var s = e.createRenderbuffer();
  1501. return e.bindRenderbuffer(e.RENDERBUFFER, s),
  1502. e.renderbufferStorage(e.RENDERBUFFER, e.DEPTH_COMPONENT16, t, i),
  1503. e.bindRenderbuffer(e.RENDERBUFFER, null),
  1504. s
  1505. }
  1506. ,
  1507. m.prototype.bind = function () {
  1508. this.gl.bindFramebuffer(this.gl.FRAMEBUFFER, this.fbo),
  1509. this.gl.viewport(0, 0, this.width, this.height)
  1510. }
  1511. ,
  1512. m.bindNone = function (e) {
  1513. e.bindFramebuffer(e.FRAMEBUFFER, null)
  1514. }
  1515. ;
  1516. var g = {
  1517. support: function () {
  1518. return !!(document.fullscreenEnabled || document.webkitFullscreenEnabled || document.mozFullScreenEnabled || document.msFullscreenEnabled)
  1519. },
  1520. begin: function (e, t) {
  1521. var i = e.requestFullscreen || e.webkitRequestFullScreen || e.mozRequestFullScreen || e.msRequestFullscreen;
  1522. if (i) {
  1523. var s = function () {
  1524. g.active() || (document.removeEventListener("fullscreenchange", s),
  1525. document.removeEventListener("webkitfullscreenchange", s),
  1526. document.removeEventListener("mozfullscreenchange", s),
  1527. document.removeEventListener("MSFullscreenChange", s)),
  1528. t && t()
  1529. };
  1530. document.addEventListener("fullscreenchange", s),
  1531. document.addEventListener("webkitfullscreenchange", s),
  1532. document.addEventListener("mozfullscreenchange", s),
  1533. document.addEventListener("MSFullscreenChange", s),
  1534. i.bind(e)()
  1535. }
  1536. },
  1537. end: function () {
  1538. var e = document.exitFullscreen || document.webkitExitFullscreen || document.mozCancelFullScreen || document.msExitFullscreen;
  1539. e && e.bind(document)()
  1540. },
  1541. active: function () {
  1542. return !!(document.fullscreenElement || document.webkitIsFullScreen || document.mozFullScreenElement || document.msFullscreenElement)
  1543. }
  1544. };
  1545. function v(e) {
  1546. this.debugString = "GUIRegion",
  1547. this.name = "Default",
  1548. this.controlRect = new s(e),
  1549. this.yPercent = this.xPercent = 0,
  1550. this.heightPercent = this.widthPercent = 1,
  1551. this.guiScreen = e
  1552. }
  1553. function t(e) {
  1554. this.init = !1,
  1555. this.ui = e,
  1556. this.bottom = this.left = this.height = this.width = 0,
  1557. this.clicked = this.mouseDown = !1,
  1558. this.playbackControls = 0,
  1559. e = 1,
  1560. window.devicePixelRatio && (2 < window.devicePixelRatio ? e = 4 : 1 < window.devicePixelRatio && (e = 2)),
  1561. this.imageSetNumber = e
  1562. }
  1563. function e(e) {
  1564. this.onTap = [],
  1565. this.onSingleTap = [],
  1566. this.onDoubleTap = [],
  1567. this.onDrag = [],
  1568. this.onZoom = [],
  1569. this.onPan = [],
  1570. this.onPan2 = [],
  1571. this.onAnything = [],
  1572. this.mouseDownCount = 0,
  1573. this.macHax = 0 <= navigator.platform.toUpperCase().indexOf("MAC"),
  1574. e && this.attach(e)
  1575. }
  1576. function i(e, t) {
  1577. e && t ? (this.frameIndex = t.frameIndex,
  1578. this.value = t.value,
  1579. this.interpolation = t.interpolation,
  1580. this.weighIn = t.weighIn,
  1581. this.weighOut = t.weighOut) : (this.interpolation = this.value = this.frameIndex = 0,
  1582. this.weighOut = this.weighIn = 1)
  1583. }
  1584. function x(e, t) {
  1585. for (var i in this.rotation = this.shadowCount = this.count = 0,
  1586. this.positions = [],
  1587. this.directions = [],
  1588. this.matrixWeights = [],
  1589. this.matrix = S.identity(),
  1590. this.invMatrix = S.identity(),
  1591. this.defaultmatrix = S.identity(),
  1592. this.defaultviewmatrix = S.identity(),
  1593. e)
  1594. this[i] = e[i];
  1595. this.count = this.positions.length / 4,
  1596. this.count = Math.min(6, this.count),
  1597. this.shadowCount = Math.min(3, this.shadowCount),
  1598. this.positions = new Float32Array(this.positions),
  1599. this.positionBuffer = new Float32Array(this.positions),
  1600. this.directions = new Float32Array(this.directions),
  1601. this.directionBuffer = new Float32Array(this.directions),
  1602. this.colors = new Float32Array(this.colors),
  1603. this.colorsBuffer = new Float32Array(this.colors),
  1604. this.modelViewBuffer = new Float32Array(16 * this.shadowCount),
  1605. this.projectionBuffer = new Float32Array(16 * this.shadowCount),
  1606. this.finalTransformBuffer = new Float32Array(16 * this.shadowCount),
  1607. this.inverseTransformBuffer = new Float32Array(16 * this.shadowCount),
  1608. this.shadowTexelPadProjections = new Float32Array(4 * this.shadowCount),
  1609. this.shadowsNeedUpdate = new Uint8Array(this.shadowCount);
  1610. for (var s = 0; s < this.shadowsNeedUpdate.length; ++s)
  1611. this.shadowsNeedUpdate[s] = 1;
  1612. for (S.rotation(this.matrix, this.rotation, 1),
  1613. S.transpose(this.invMatrix, this.matrix),
  1614. S.copy(this.defaultmatrix, this.matrix),
  1615. S.copy(this.defaultviewmatrix, t.viewMatrix),
  1616. s = 0; s < this.count; ++s) {
  1617. i = this.positions.subarray(4 * s, 4 * s + 4);
  1618. var n = this.directions.subarray(3 * s, 3 * s + 3);
  1619. 1 == this.matrixWeights[s] ? (S.mul4(i, this.matrix, i[0], i[1], i[2], i[3]),
  1620. S.mulVec(n, this.matrix, n[0], n[1], n[2])) : 2 == this.matrixWeights[s] && (S.mul4(i, t.viewMatrix, i[0], i[1], i[2], i[3]),
  1621. S.mulVec(n, t.viewMatrix, n[0], n[1], n[2]))
  1622. }
  1623. }
  1624. function y(e) {
  1625. this.name = "none",
  1626. this.text = "default text",
  1627. this.title = "none",
  1628. this.debugString = this.imagePath = "",
  1629. this.controlRect = new s(e),
  1630. this.textEntries = [],
  1631. this.textOffsetsX = [],
  1632. this.textOffsetsY = [],
  1633. this.buttons = [],
  1634. this.listBoxEntryHeight = 20,
  1635. this.selectedItemText = "",
  1636. this.selectedIndex = -1,
  1637. this.localPixelsY = 0,
  1638. this.localPixelsX = 100,
  1639. this.labelPixelDrop = 0,
  1640. this.labelPixelInset = 10,
  1641. this.labelTextHeight = 16,
  1642. this.closed = !1,
  1643. this.defaultButtonText = this.spacerMiddle = this.spacerRight = this.spacerLeft = this.spacerControl = 0,
  1644. this.listBoxButtons = [],
  1645. this.listBoxRegion = new v(e),
  1646. this.guiScreen = e,
  1647. this.lastMouseOverIndex = -1,
  1648. this.selectionChangedCallback = 0,
  1649. this.debugString = ""
  1650. }
  1651. function b(e, t, i) {
  1652. this.gl = e,
  1653. this.name = i.name;
  1654. var s = {
  1655. mipmap: !0,
  1656. aniso: e.hints.mobile ? 0 : 4,
  1657. clamp: !!i.textureWrapClamp,
  1658. mirror: !!i.textureWrapMirror
  1659. }
  1660. , n = {
  1661. mipmap: s.mipmap,
  1662. clamp: s.clamp,
  1663. mirror: s.mirror,
  1664. nofilter: i.textureFilterNearest || !1
  1665. };
  1666. if (n.nofilter || (n.aniso = e.hints.mobile ? 2 : 4),
  1667. this.textures = {
  1668. albedo: e.textureCache.fromFilesMergeAlpha(t.get(i.albedoTex), t.get(i.alphaTex), n),
  1669. reflectivity: e.textureCache.fromFilesMergeAlpha(t.get(i.reflectivityTex), t.get(i.glossTex), s),
  1670. normal: e.textureCache.fromFile(t.get(i.normalTex), s),
  1671. extras: e.textureCache.fromFilesMergeAlpha(t.get(i.extrasTex), t.get(i.extrasTexA), s)
  1672. },
  1673. this.extrasTexCoordRanges = {},
  1674. i.extrasTexCoordRanges)
  1675. for (var r in i.extrasTexCoordRanges)
  1676. this.extrasTexCoordRanges[r] = new Float32Array(i.extrasTexCoordRanges[r].scaleBias);
  1677. this.textures.extras || ((t = new U(e, {
  1678. width: 1,
  1679. height: 1
  1680. })).loadArray(new Uint8Array([255, 255, 255, 255])),
  1681. this.textures.extras = t);
  1682. var a = i.blendTint || [1, 1, 1];
  1683. t = {
  1684. none: function () {
  1685. e.disable(e.BLEND)
  1686. },
  1687. alpha: function () {
  1688. e.enable(e.BLEND),
  1689. e.blendFuncSeparate(e.SRC_ALPHA, e.ONE_MINUS_SRC_ALPHA, e.ONE_MINUS_DST_ALPHA, e.ONE)
  1690. },
  1691. add: function () {
  1692. e.enable(e.BLEND),
  1693. e.blendColor(a[0], a[1], a[2], 1),
  1694. e.blendFunc(e.ONE, e.CONSTANT_COLOR)
  1695. }
  1696. },
  1697. this.blend = t[i.blend] || t.none,
  1698. this.alphaTest = i.alphaTest || 0,
  1699. this.usesBlending = this.blend !== t.none,
  1700. this.usesRefraction = !!i.refraction,
  1701. this.shadowAlphaTest = this.alphaTest,
  1702. this.shadowAlphaTest <= 0 && this.blend === t.alpha && (this.shadowAlphaTest = .5),
  1703. this.castShadows = this.blend !== t.add,
  1704. this.horizonOcclude = i.horizonOcclude || 0,
  1705. this.fresnel = new Float32Array(i.fresnel ? i.fresnel : [1, 1, 1]),
  1706. this.emissiveIntensity = i.emissiveIntensity || 1,
  1707. n = !(s = []),
  1708. 0 < i.lightCount && s.push("#define LIGHT_COUNT " + i.lightCount),
  1709. 0 < i.shadowCount && (r = Math.min(i.lightCount, i.shadowCount),
  1710. this.usesRefraction && e.limits.textureCount <= 8 && (r = 2 < r ? 2 : r),
  1711. s.push("#define SHADOW_COUNT " + r)),
  1712. 0 < i.alphaTest && s.push("#define ALPHA_TEST"),
  1713. this.blend === t.alpha ? s.push("#define TRANSPARENCY_DITHER") : this.blend === t.none && s.push("#define NOBLEND"),
  1714. e.hints.mobile && s.push("#define MOBILE"),
  1715. e.ext.textureDepth && s.push("#define SHADOW_NATIVE_DEPTH"),
  1716. r = function (e) {
  1717. return 1 / (2 / 3 * 3.1415962 * (e * e + e + 1))
  1718. }
  1719. ,
  1720. i.useSkin && (s.push("#define SKIN"),
  1721. this.skinParams = i.skinParams || {
  1722. subdermisColor: [1, 1, 1],
  1723. transColor: [1, 0, 0, 1],
  1724. fresnelColor: [.2, .2, .2, .5],
  1725. fresnelOcc: 1,
  1726. fresnelGlossMask: 1,
  1727. transSky: .5,
  1728. shadowBlur: .5,
  1729. normalSmooth: .5,
  1730. transScatter: 0,
  1731. transDepth: 0,
  1732. millimeterScale: 1
  1733. },
  1734. this.extrasTexCoordRanges.subdermisTex || s.push("#define SKIN_NO_SUBDERMIS_TEX"),
  1735. this.extrasTexCoordRanges.translucencyTex || s.push("#define SKIN_NO_TRANSLUCENCY_TEX"),
  1736. this.extrasTexCoordRanges.fuzzTex || s.push("#define SKIN_NO_FUZZ_TEX"),
  1737. void 0 === this.skinParams.version && (this.skinParams.version = 1),
  1738. 2 == this.skinParams.version ? (s.push("#define SKIN_VERSION_2"),
  1739. this.skinParams.shadowBlur *= 4,
  1740. this.skinParams.shadowBlur = Math.min(this.skinParams.shadowBlur, 40),
  1741. this.skinParams.transIntegral = r(.5 * this.skinParams.transScatter),
  1742. this.skinParams.fresnelIntegral = 1 / 3.14159 * (1 - .5 * this.skinParams.fresnelColor[3]),
  1743. this.skinParams.transSky = 0) : (s.push("#define SKIN_VERSION_1"),
  1744. this.skinParams.shadowBlur = 8 * Math.min(this.skinParams.shadowBlur, 1),
  1745. this.skinParams.transDepth = 0,
  1746. this.skinParams.transScatter = this.skinParams.transColor[3],
  1747. this.skinParams.transIntegral = 1 / 3.14159 * (1 - .5 * this.skinParams.transScatter),
  1748. this.skinParams.fresnelIntegral = 1 / 3.14159 * (1 - .5 * this.skinParams.fresnelColor[3]),
  1749. this.skinParams.transSky *= 1.25,
  1750. this.skinParams.transIntegral *= 1.25)),
  1751. i.aniso && (s.push("#define ANISO"),
  1752. this.anisoParams = i.anisoParams || {
  1753. strength: 1,
  1754. tangent: [1, 0, 0],
  1755. integral: .5
  1756. },
  1757. this.extrasTexCoordRanges.anisoTex || s.push("#define ANISO_NO_DIR_TEX")),
  1758. i.microfiber && (s.push("#define MICROFIBER"),
  1759. this.microfiberParams = i.microfiberParams || {
  1760. fresnelColor: [.2, .2, .2, .5],
  1761. fresnelOcc: 1,
  1762. fresnelGlossMask: 1
  1763. },
  1764. this.microfiberParams.fresnelIntegral = 1 / 3.14159 * (1 - .5 * this.microfiberParams.fresnelColor[3]),
  1765. this.extrasTexCoordRanges.fuzzTex || s.push("#define MICROFIBER_NO_FUZZ_TEX")),
  1766. i.refraction && (s.push("#define REFRACTION"),
  1767. this.refractionParams = i.refractionParams || {
  1768. distantBackground: !1,
  1769. tint: [1, 1, 1],
  1770. useAlbedoTint: !1,
  1771. IOR: 1.5
  1772. },
  1773. this.extrasTexCoordRanges.refractionMaskTex || s.push("#define REFRACTION_NO_MASK_TEX")),
  1774. i.vertexColor && (s.push("#define VERTEX_COLOR"),
  1775. i.vertexColorsRGB && s.push("#define VERTEX_COLOR_SRGB"),
  1776. i.vertexColorAlpha && s.push("#define VERTEX_COLOR_ALPHA")),
  1777. this.horizonSmoothing = i.horizonSmoothing || 0,
  1778. 0 < this.horizonSmoothing && s.push("#define HORIZON_SMOOTHING"),
  1779. i.unlitDiffuse && s.push("#define DIFFUSE_UNLIT"),
  1780. this.extrasTexCoordRanges.emissiveTex && (s.push("#define EMISSIVE"),
  1781. i.emissiveSecondaryUV && (s.push("#define EMISSIVE_SECONDARY_UV"),
  1782. n = !0)),
  1783. this.extrasTexCoordRanges.aoTex && (s.push("#define AMBIENT_OCCLUSION"),
  1784. i.aoSecondaryUV && (s.push("#define AMBIENT_OCCLUSION_SECONDARY_UV"),
  1785. n = !0)),
  1786. i.tangentOrthogonalize && s.push("#define TSPACE_ORTHOGONALIZE"),
  1787. i.tangentNormalize && s.push("#define TSPACE_RENORMALIZE"),
  1788. i.tangentGenerateBitangent && s.push("#define TSPACE_COMPUTE_BITANGENT"),
  1789. n && s.push("#define TEXCOORD_SECONDARY"),
  1790. this.vOffset = this.uOffset = 0,
  1791. s.push("#define UV_OFFSET "),
  1792. this.shader = e.shaderCache.fromURLs("matvert.glsl", "matfrag.glsl", s),
  1793. s.push("#define STRIPVIEW"),
  1794. this.stripShader = e.shaderCache.fromURLs("matvert.glsl", "matfrag.glsl", s),
  1795. this.wireShader = e.shaderCache.fromURLs("wirevert.glsl", "wirefrag.glsl"),
  1796. this.blend === t.alpha && (this.prepassShader = e.shaderCache.fromURLs("alphaprepassvert.glsl", "alphaprepassfrag.glsl"))
  1797. }
  1798. v.prototype.addImageElement = function (e, t) {
  1799. var i = this.guiScreen.ui.menuCluster.contents
  1800. , s = document.createElement("input");
  1801. e.linkControl(s),
  1802. this.guiScreen.updateElement(e),
  1803. s.type = "image",
  1804. s.src = I.dataLocale + t,
  1805. s.style.position = "absolute",
  1806. s.style.border = "none",
  1807. s.style.outline = "0px",
  1808. s.style.zIndex = "1",
  1809. s.title = t,
  1810. s.style.opacity = e.opacity;
  1811. var n = new XMLHttpRequest;
  1812. return n.open("HEAD", s.src, !0),
  1813. n.onload = function (e) {
  1814. e.appendChild(this)
  1815. }
  1816. .bind(s, i),
  1817. n.send(),
  1818. s
  1819. }
  1820. ,
  1821. v.prototype.addImage = function (e) {
  1822. var t = new s(this.guiScreen);
  1823. return this.addImageElement(t, e),
  1824. t
  1825. }
  1826. ,
  1827. v.prototype.addTextButton = function (e, t, i, s, n, r) {
  1828. var a = new p(this.guiScreen);
  1829. return a.name = "none",
  1830. a.text = e,
  1831. a.controlRect.set(t, i, s, n),
  1832. a.controlRect.opacity = r,
  1833. this.controlRect.registerChildControlRect(a.controlRect),
  1834. t = this.guiScreen.ui.menuCluster.contents,
  1835. (i = document.createElement("text")).style.color = "white",
  1836. i.style.fontFamily = "Arial",
  1837. i.style.fontSize = I.largeUI ? "14px" : "12px",
  1838. i.style.textShadow = "2px 2px 3px #000000",
  1839. t.appendChild(i),
  1840. a.controlRect.linkControl(i),
  1841. this.guiScreen.updateElement(a.controlRect),
  1842. i.type = "text",
  1843. i.name = "text",
  1844. i.style.position = "absolute",
  1845. i.style.border = "none",
  1846. i.style.outline = "0px",
  1847. i.style.zIndex = "2",
  1848. i.innerHTML = e,
  1849. i.style.opacity = a.controlRect.opacity,
  1850. a.linkControl(i),
  1851. a
  1852. }
  1853. ,
  1854. t.prototype.setSize = function (e, t) {
  1855. this.width = e,
  1856. this.height = t,
  1857. this.left = -e,
  1858. this.bottom = -t,
  1859. this.playbackControls && this.playbackControls.resize(this)
  1860. }
  1861. ,
  1862. t.prototype.setupActiveView = function (e) {
  1863. this.init || (this.init = !0,
  1864. (this.ui = e).viewer.scene.sceneAnimator && (this.playbackControls = new R(this),
  1865. this.playbackControls.resize(this)))
  1866. }
  1867. ,
  1868. t.prototype.updateElement = function (e) {
  1869. var t = e.linkedControl;
  1870. if (t) {
  1871. var i = this.left * (1 - e.getScreenXPercent())
  1872. , s = this.bottom * (1 - e.getScreenYPercent())
  1873. , n = this.width * e.getScreenWidthPercent();
  1874. e = this.height * e.getScreenHeightPercent(),
  1875. t.style.left = i + "px",
  1876. t.style.bottom = s + "px",
  1877. t.style.width = n + "px",
  1878. t.style.height = e + "px"
  1879. }
  1880. }
  1881. ,
  1882. e.prototype.attach = function (e) {
  1883. this.element = e;
  1884. var m = function (e) {
  1885. for (var t = 0; t < this.onAnything.length; ++t)
  1886. this.onAnything[t]();
  1887. e.preventDefault()
  1888. }
  1889. .bind(this);
  1890. this.mouseStates = [{
  1891. pressed: !1,
  1892. position: [0, 0],
  1893. downPosition: [0, 0]
  1894. }, {
  1895. pressed: !1,
  1896. position: [0, 0],
  1897. downPosition: [0, 0]
  1898. }, {
  1899. pressed: !1,
  1900. position: [0, 0],
  1901. downPosition: [0, 0]
  1902. }],
  1903. this.lastTapPos = [0, 0],
  1904. e = function (e) {
  1905. if (e.target === this.element) {
  1906. this.mouseDownCount++;
  1907. var t = this.mouseStates[e.button];
  1908. if (t) {
  1909. t.pressed = !0;
  1910. var i = this.element.getBoundingClientRect();
  1911. t.position[0] = t.downPosition[0] = e.clientX - i.left,
  1912. t.position[1] = t.downPosition[1] = e.clientY - i.top,
  1913. m(e)
  1914. }
  1915. }
  1916. }
  1917. .bind(this),
  1918. this.element.addEventListener("mousedown", e),
  1919. e = function (e) {
  1920. var t = this.mouseStates[e.button];
  1921. if (t) {
  1922. var i = this.element.getBoundingClientRect()
  1923. , s = e.clientX - i.left;
  1924. i = e.clientY - i.top;
  1925. if (t.pressed = !1,
  1926. t.position[0] = s,
  1927. t.position[1] = i,
  1928. 0 == e.button && e.target == this.element && Math.abs(t.position[0] - t.downPosition[0]) + Math.abs(t.position[1] - t.downPosition[1]) < 10) {
  1929. for (var n = 0; n < this.onTap.length; ++n)
  1930. this.onTap[n](s, i);
  1931. if (this.needSingleClick = !0,
  1932. window.setTimeout(function (e, t) {
  1933. if (this.needSingleClick) {
  1934. for (var i = 0; i < this.onSingleTap.length; ++i)
  1935. this.onSingleTap[i](e, t);
  1936. this.needSingleClick = !1
  1937. }
  1938. }
  1939. .bind(this, s, i), 301),
  1940. t = !1,
  1941. void 0 !== this.doubleClickTimer && (n = Math.abs(s - this.lastTapPos[0]) + Math.abs(i - this.lastTapPos[1]) < 8,
  1942. Date.now() - this.doubleClickTimer < 300 && n))
  1943. for (t = !0,
  1944. this.needSingleClick = !1,
  1945. n = 0; n < this.onDoubleTap.length; ++n)
  1946. this.onDoubleTap[n](s, i);
  1947. this.doubleClickTimer = Date.now(),
  1948. t && (this.doubleClickTimer = -1e9),
  1949. this.lastTapPos[0] = s,
  1950. this.lastTapPos[1] = i
  1951. }
  1952. }
  1953. m(e)
  1954. }
  1955. .bind(this),
  1956. this.element.addEventListener("mouseup", e),
  1957. e = function (e) {
  1958. for (var t = !1, i = this.element.getBoundingClientRect(), s = 0; s < 3; ++s) {
  1959. var n = this.mouseStates[s];
  1960. if (n.pressed) {
  1961. webview.stopRotate();
  1962. t = e.clientX - i.left;
  1963. var r = e.clientY - i.top
  1964. , a = t - n.position[0]
  1965. , o = r - n.position[1];
  1966. if (n.position[0] = t,
  1967. n.position[1] = r,
  1968. 2 == s && e.altKey)
  1969. for (n = 0; n < this.onZoom.length; ++n)
  1970. this.onZoom[n](2 * o);
  1971. else if (1 <= s || e.ctrlKey)
  1972. for (n = 0; n < this.onPan.length; ++n)
  1973. this.onPan[n](a, o);
  1974. else if (0 == s)
  1975. if (e.shiftKey)
  1976. for (n = 0; n < this.onPan2.length; ++n)
  1977. this.onPan2[n](a, o);
  1978. else
  1979. for (n = 0; n < this.onDrag.length; ++n)
  1980. this.onDrag[n](t, r, a, o);
  1981. t = !0
  1982. }
  1983. }
  1984. t && m(e)
  1985. }
  1986. .bind(this),
  1987. this.element.addEventListener("mousemove", e),
  1988. e = function (e) {
  1989. var t = 0;
  1990. e.deltaY ? (t = -.4 * e.deltaY,
  1991. 1 == e.deltaMode ? t *= 16 : 2 == e.deltaMode && (t *= this.element.clientHeight)) : e.wheelDelta ? t = this.macHax && 120 == Math.abs(e.wheelDelta) ? .08 * e.wheelDelta : .4 * e.wheelDelta : e.detail && (t = -10 * e.detail);
  1992. for (var i = 0; i < this.onZoom.length; ++i)
  1993. this.onZoom[i](t);
  1994. m(e)
  1995. }
  1996. .bind(this),
  1997. this.element.addEventListener("mousewheel", e),
  1998. this.element.addEventListener("DOMMouseScroll", e),
  1999. this.element.addEventListener("wheel", e),
  2000. e = function (e) {
  2001. for (var t = 0; t < this.mouseStates.length; ++t)
  2002. this.mouseStates[t].pressed = !1;
  2003. e.preventDefault()
  2004. }
  2005. .bind(this),
  2006. this.element.addEventListener("mouseleave", e),
  2007. this.element.addEventListener("contextmenu", function (e) {
  2008. e.preventDefault()
  2009. }),
  2010. this.touches = {},
  2011. this.tapPossible = !1,
  2012. this.touchCountFloor = 0,
  2013. e = function (e) {
  2014. for (var t = this.element.getBoundingClientRect(), i = !1, s = 0; s < e.changedTouches.length; ++s)
  2015. if (e.target === this.element) {
  2016. var n = e.changedTouches[s];
  2017. (i = {
  2018. x: n.clientX - t.left,
  2019. y: n.clientY - t.top
  2020. }).startX = i.x,
  2021. i.startY = i.y,
  2022. this.touches[n.identifier] = i,
  2023. i = !0
  2024. }
  2025. for (this.tapPossible = 1 == e.touches.length,
  2026. n = t = 0; n < this.touches.length; ++n)
  2027. t++;
  2028. t > this.touchCountFloor && (this.touchCountFloor = t),
  2029. i && m(e)
  2030. }
  2031. .bind(this),
  2032. this.element.addEventListener("touchstart", e),
  2033. e = function (e) {
  2034. for (var t = !1, i = 0; i < e.changedTouches.length; ++i) {
  2035. var s = e.changedTouches[i]
  2036. , n = this.touches[s.identifier];
  2037. if (n) {
  2038. if (this.tapPossible) {
  2039. var r = this.element.getBoundingClientRect();
  2040. t = s.clientX - r.left,
  2041. r = s.clientY - r.top;
  2042. if (Math.max(Math.abs(t - n.startX), Math.abs(r - n.startY)) < 24) {
  2043. for (i = 0; i < this.onTap.length; ++i)
  2044. this.onTap[i](t, r);
  2045. if (this.needSingleTap = !0,
  2046. window.setTimeout(function (e, t) {
  2047. if (this.needSingleTap) {
  2048. for (var i = 0; i < this.onSingleTap.length; ++i)
  2049. this.onSingleTap[i](e, t);
  2050. this.needSingleTap = !1
  2051. }
  2052. }
  2053. .bind(this, t, r), 501),
  2054. n = !1,
  2055. void 0 !== this.doubleTapTimer) {
  2056. var a = Math.max(Math.abs(t - this.lastTapPos[0]), Math.abs(r - this.lastTapPos[1])) < 24
  2057. , o = Date.now() - this.doubleTapTimer < 500;
  2058. if (a && o)
  2059. for (n = !0,
  2060. i = 0; i < this.onDoubleTap.length; ++i)
  2061. this.onDoubleTap[i](t, r)
  2062. }
  2063. this.doubleTapTimer = Date.now(),
  2064. n && (this.doubleTapTimer = -1e9),
  2065. this.lastTapPos[0] = t,
  2066. this.lastTapPos[1] = r
  2067. }
  2068. this.tapPossible = !1
  2069. }
  2070. delete this.touches[s.identifier],
  2071. t = !0
  2072. }
  2073. }
  2074. for (s = i = 0; s < this.touches.length; ++s)
  2075. i++;
  2076. i <= 0 && (this.touchCountFloor = 0),
  2077. t && m(e)
  2078. }
  2079. .bind(this),
  2080. this.element.addEventListener("touchend", e),
  2081. this.element.addEventListener("touchcancel", e),
  2082. this.element.addEventListener("touchleave", e),
  2083. e = function (e) {
  2084. webview.stopRotate();
  2085. for (var t = [], i = 0; i < e.touches.length; ++i)
  2086. e.touches[i].target === this.element && t.push(e.touches[i]);
  2087. var s = this.element.getBoundingClientRect();
  2088. if (1 == t.length && this.touchCountFloor <= 1) {
  2089. var n = t[0]
  2090. , r = this.touches[n.identifier];
  2091. if (r) {
  2092. var a = n.clientX - s.left
  2093. , o = (n = n.clientY - s.top,
  2094. s = a - r.x,
  2095. n - r.y);
  2096. for (r.x = a,
  2097. r.y = n,
  2098. i = 0; i < this.onDrag.length; ++i)
  2099. this.onDrag[i](a, n, s, o, e.shiftKey)
  2100. }
  2101. } else if (2 == t.length && this.touchCountFloor <= 2) {
  2102. if (o = t[0],
  2103. i = this.touches[o.identifier],
  2104. n = t[1],
  2105. r = this.touches[n.identifier],
  2106. i && r) {
  2107. a = o.clientX - s.left,
  2108. o = o.clientY - s.top;
  2109. var h = n.clientX - s.left
  2110. , l = n.clientY - s.top
  2111. , d = Math.sqrt((a - h) * (a - h) + (o - l) * (o - l))
  2112. , c = Math.sqrt((i.x - r.x) * (i.x - r.x) + (i.y - r.y) * (i.y - r.y))
  2113. , u = Math.abs(d - c)
  2114. , f = (s = (a - i.x + h - r.x) / 2,
  2115. n = (o - i.y + l - r.y) / 2,
  2116. Math.sqrt(s * s + n * n));
  2117. if (i.x = a,
  2118. i.y = o,
  2119. r.x = h,
  2120. r.y = l,
  2121. 0 < u)
  2122. for (r = u / (u + f),
  2123. i = 0; i < this.onZoom.length; ++i)
  2124. this.onZoom[i](2 * (d - c) * r);
  2125. if (0 < f)
  2126. for (r = f / (u + f),
  2127. i = 0; i < this.onDrag.length; ++i)
  2128. this.onPan[i](s * r, n * r)
  2129. }
  2130. } else if (3 <= t.length) {
  2131. for (i = c = d = h = o = 0; i < t.length; ++i)
  2132. n = t[i],
  2133. r = this.touches[n.identifier],
  2134. d += a = n.clientX - s.left,
  2135. c += n = n.clientY - s.top,
  2136. r && (o += r.x,
  2137. h += r.y,
  2138. r.x = a,
  2139. r.y = n);
  2140. for (o /= t.length,
  2141. h /= t.length,
  2142. d /= t.length,
  2143. c /= t.length,
  2144. i = 0; i < this.onPan2.length; ++i)
  2145. this.onPan2[i](d - o, c - h)
  2146. }
  2147. 0 < t.length && m(e)
  2148. }
  2149. .bind(this),
  2150. this.element.addEventListener("touchmove", e)
  2151. }
  2152. ,
  2153. x.prototype.getLightPos = function (e) {
  2154. return this.positionBuffer.subarray(4 * e, 4 * e + 4)
  2155. }
  2156. ,
  2157. x.prototype.setLightDistance = function (e, t) {
  2158. t <= 0 && (t = 1e-5),
  2159. this.parameters[3 * e + 2] = 1 / t
  2160. }
  2161. ,
  2162. x.prototype.setLightSpotAngle = function (e, t) {
  2163. t <= 0 && (t = 1e-6),
  2164. this.spot[3 * e] = t;
  2165. var i = Math.sin(3.1415926 / 180 * t / 2);
  2166. this.spot[3 * e + 2] = 1 / (i * i) * this.spot[3 * e + 1]
  2167. }
  2168. ,
  2169. x.prototype.setLightSpotSharpness = function (e, t) {
  2170. this.spot[3 * e + 1] = t,
  2171. this.setLightSpotAngle(this.spot[3 * e])
  2172. }
  2173. ,
  2174. x.prototype.setLightPos = function (e, t) {
  2175. this.positions[4 * e + 0] = t[0],
  2176. this.positions[4 * e + 1] = t[1],
  2177. this.positions[4 * e + 2] = t[2];
  2178. var i = this.positions.subarray(4 * e, 4 * e + 4);
  2179. 1 == this.matrixWeights[e] ? S.mul4(i, this.defaultmatrix, t[0], t[1], t[2], i[3]) : 2 == this.matrixWeights[e] && S.mul4(i, this.defaultviewmatrix, t[0], t[1], t[2], i[3])
  2180. }
  2181. ,
  2182. x.prototype.setLightDir = function (e, t) {
  2183. this.directions[3 * e + 0] = t[0],
  2184. this.directions[3 * e + 1] = t[1],
  2185. this.directions[3 * e + 2] = t[2];
  2186. var i = this.directions.subarray(3 * e, 3 * e + 3);
  2187. 1 == this.matrixWeights[e] ? S.mulVec(i, this.defaultmatrix, t[0], t[1], t[2]) : 2 == this.matrixWeights[e] && S.mulVec(i, this.defaultviewmatrix, t[0], t[1], t[2])
  2188. }
  2189. ,
  2190. x.prototype.getLightColor = function (e) {
  2191. return this.colors.subarray(3 * e, 3 * e + 3)
  2192. }
  2193. ,
  2194. x.prototype.setLightColor = function (e, t) {
  2195. this.colors[3 * e + 0] = t[0],
  2196. this.colors[3 * e + 1] = t[1],
  2197. this.colors[3 * e + 2] = t[2]
  2198. }
  2199. ,
  2200. x.prototype.getLightDir = function (e) {
  2201. return this.directionBuffer.subarray(3 * e, 3 * e + 3)
  2202. }
  2203. ,
  2204. x.prototype.getColor = function (e) {
  2205. return e *= 3,
  2206. [this.colors[e], this.colors[e + 1], this.colors[e + 2]]
  2207. }
  2208. ,
  2209. x.prototype.update = function (e, t) {
  2210. var i = new S.type(this.matrix);
  2211. S.rotation(this.matrix, this.rotation, 1),
  2212. S.transpose(this.invMatrix, this.matrix);
  2213. for (var s = 0; s < this.count; ++s) {
  2214. var n = this.positions.subarray(4 * s, 4 * s + 4)
  2215. , r = this.directions.subarray(3 * s, 3 * s + 3)
  2216. , a = this.getLightPos(s)
  2217. , o = this.getLightDir(s);
  2218. 1 == this.matrixWeights[s] ? (a[0] = n[0],
  2219. a[1] = n[1],
  2220. a[2] = n[2],
  2221. a[3] = n[3],
  2222. o[0] = r[0],
  2223. o[1] = r[1],
  2224. o[2] = r[2]) : 2 == this.matrixWeights[s] ? (S.mul4(a, e.transform, n[0], n[1], n[2], n[3]),
  2225. S.mulVec(o, e.transform, r[0], r[1], r[2]),
  2226. S.mul4(a, this.matrix, a[0], a[1], a[2], a[3]),
  2227. S.mulVec(o, this.matrix, o[0], o[1], o[2])) : (S.mul4(a, this.matrix, n[0], n[1], n[2], n[3]),
  2228. S.mulVec(o, this.matrix, r[0], r[1], r[2])),
  2229. V.normalize(o, o)
  2230. }
  2231. r = new Float32Array(this.finalTransformBuffer),
  2232. a = S.empty(),
  2233. o = S.empty();
  2234. var h = S.empty()
  2235. , l = V.empty()
  2236. , d = V.empty()
  2237. , c = V.empty()
  2238. , u = V.empty()
  2239. , f = (n = V.empty(),
  2240. [])
  2241. , m = []
  2242. , p = S.create(.5, 0, 0, .5, 0, .5, 0, .5, 0, 0, .5, .5, 0, 0, 0, 1);
  2243. for (s = 0; s < this.count; ++s) {
  2244. for (l = this.getLightPos(s),
  2245. d = this.getLightDir(s),
  2246. .99 < Math.abs(d[1]) ? V.set(c, 1, 0, 0) : V.set(c, 0, 1, 0),
  2247. V.cross(u, c, d),
  2248. V.normalize(u, u),
  2249. V.cross(c, d, u),
  2250. V.normalize(c, c),
  2251. S.set(a, u[0], u[1], u[2], -V.dot(u, l), c[0], c[1], c[2], -V.dot(c, l), d[0], d[1], d[2], -V.dot(d, l), 0, 0, 0, 1),
  2252. l = 0; l < 8; ++l)
  2253. n[0] = 1 & l ? t.max[0] : t.min[0],
  2254. n[1] = 2 & l ? t.max[1] : t.min[1],
  2255. n[2] = 4 & l ? t.max[2] : t.min[2],
  2256. S.mulPoint(n, this.matrix, 1.005 * n[0], 1.005 * n[1], 1.005 * n[2]),
  2257. S.mulPoint(n, a, n[0], n[1], n[2]),
  2258. 0 == l ? (f[0] = m[0] = n[0],
  2259. f[1] = m[1] = n[1],
  2260. f[2] = m[2] = n[2]) : (f[0] = Math.min(f[0], n[0]),
  2261. f[1] = Math.min(f[1], n[1]),
  2262. f[2] = Math.min(f[2], n[2]),
  2263. m[0] = Math.max(m[0], n[0]),
  2264. m[1] = Math.max(m[1], n[1]),
  2265. m[2] = Math.max(m[2], n[2]));
  2266. l = -f[2],
  2267. d = -m[2];
  2268. var g = this.spot[3 * s];
  2269. 0 < g ? (l = Math.min(l, 1 / this.parameters[3 * s + 2]),
  2270. d = Math.max(.04 * l, d),
  2271. S.perspective(o, g, 1, d, l),
  2272. s < this.shadowCount && (l = 2 * -Math.tan(.00872664625 * g),
  2273. this.shadowTexelPadProjections[4 * s + 0] = this.modelViewBuffer[16 * s + 2] * l,
  2274. this.shadowTexelPadProjections[4 * s + 1] = this.modelViewBuffer[16 * s + 6] * l,
  2275. this.shadowTexelPadProjections[4 * s + 2] = this.modelViewBuffer[16 * s + 10] * l,
  2276. this.shadowTexelPadProjections[4 * s + 3] = this.modelViewBuffer[16 * s + 14] * l)) : (S.ortho(o, f[0], m[0], f[1], m[1], d, l),
  2277. s < this.shadowCount && (this.shadowTexelPadProjections[4 * s + 0] = this.shadowTexelPadProjections[4 * s + 1] = this.shadowTexelPadProjections[4 * s + 2] = 0,
  2278. this.shadowTexelPadProjections[4 * s + 3] = Math.max(m[0] - f[0], m[1] - f[1]))),
  2279. S.mul(h, o, a),
  2280. S.mul(h, p, h),
  2281. S.copyToBuffer(this.modelViewBuffer, 16 * s, a),
  2282. S.copyToBuffer(this.projectionBuffer, 16 * s, o),
  2283. S.copyToBuffer(this.finalTransformBuffer, 16 * s, h),
  2284. S.invert(h, h),
  2285. S.copyToBuffer(this.inverseTransformBuffer, 16 * s, h)
  2286. }
  2287. for (n = !1,
  2288. s = 0; s < i.length; ++s)
  2289. if (i[s] != this.matrix[s]) {
  2290. n = !0;
  2291. break
  2292. }
  2293. for (s = 0; s < this.shadowCount; s++)
  2294. if (n && 1 == this.matrixWeights[s])
  2295. this.shadowsNeedUpdate[s] = 1;
  2296. else
  2297. for (i = 16 * s; i < 16 * s + 16; ++i)
  2298. if (r[i] != this.finalTransformBuffer[i]) {
  2299. this.shadowsNeedUpdate[s] = 1;
  2300. break
  2301. }
  2302. }
  2303. ,
  2304. x.prototype.flagUpdateAnimatedLighting = function () {
  2305. for (var e = 0; e < this.shadowCount; e++)
  2306. this.shadowsNeedUpdate[e] = 1
  2307. }
  2308. ,
  2309. y.prototype.linkControl = function (e) {
  2310. this.controlRect.linkControl(e)
  2311. }
  2312. ,
  2313. y.prototype.spawnControl = function (e, t, i, s, n, r) {
  2314. var a = "backgroundTopLE" + (w = this.guiScreen.imageSetNumber) + "x.png"
  2315. , o = "backgroundTopM" + w + "x.png"
  2316. , h = "backgroundTopRE" + w + "x.png"
  2317. , l = "backgroundMiddleLE" + w + "x.png"
  2318. , d = "backgroundMiddleM" + w + "x.png"
  2319. , c = "backgroundMiddleRE" + w + "x.png"
  2320. , u = "backgroundBottomLE" + w + "x.png"
  2321. , f = "backgroundBottomM" + w + "x.png"
  2322. , m = "backgroundBottomRE" + w + "x.png"
  2323. , p = 3 * w
  2324. , g = "backgroundLE" + w + "x.png"
  2325. , v = "backgroundM" + w + "x.png"
  2326. , x = "backgroundRE" + w + "x.png"
  2327. , y = 2 * w
  2328. , b = "spacerLE" + w + "x.png"
  2329. , S = "spacerM" + w + "x.png"
  2330. , T = "spacerRE" + w + "x.png"
  2331. , w = 2 * w
  2332. , C = this.controlRect.guiScreen.width
  2333. , R = this.controlRect.guiScreen.height;
  2334. if (n) {
  2335. n = this.textEntries.length;
  2336. var A = i;
  2337. for (i = 0; i < n; i++) {
  2338. var k = 8 * (this.textEntries[i] ? this.textEntries[i].length : 0);
  2339. A < k && (A = k)
  2340. }
  2341. i = A + r
  2342. }
  2343. for (r = 1 / (n = this.textEntries.length + 1),
  2344. this.localPixelsX = i,
  2345. this.listBoxEntryHeight = s,
  2346. this.localPixelsY = (this.textEntries.length + 1) * this.listBoxEntryHeight,
  2347. i = 8 / this.localPixelsY,
  2348. s = 6 / this.localPixelsX,
  2349. A = 4 / this.localPixelsX,
  2350. k = r - i / 4,
  2351. this.labelTextHeight = I.largeUI ? 20 : 16,
  2352. this.labelPixelDrop = (this.listBoxEntryHeight - this.labelTextHeight) / 2,
  2353. this.listBoxRegion.controlRect.widthPercent = this.localPixelsX / C,
  2354. this.listBoxRegion.controlRect.heightPercent = this.localPixelsY / R,
  2355. this.listBoxRegion.controlRect.xPercent = e / C,
  2356. this.listBoxRegion.controlRect.yPercent = t / R,
  2357. this.openBackground = this.listBoxRegion.addTextButton("", 0, 0, 1, 1 + i, 1),
  2358. this.openBackground.setBackground3x3(this.listBoxRegion, 0, 0, a, o, h, l, d, c, u, f, m, p, p),
  2359. this.closedBackground = this.listBoxRegion.addTextButton("", 0, 0, 1, r, 1),
  2360. this.closedBackground.setBackground3x1(this.listBoxRegion, 0, 0, g, v, x, y),
  2361. e = this.labelPixelInset + this.textOffsetsX[0],
  2362. t = this.labelPixelDrop + this.textOffsetsY[0],
  2363. t /= this.localPixelsY,
  2364. e /= this.localPixelsX,
  2365. this.defaultButton = this.listBoxRegion.addTextButton("Selected", e, -t, 1, r, .5),
  2366. this.selectedIndex = 0,
  2367. this.defaultButton.controlRect.linkedControl.innerHTML = this.textEntries[this.selectedIndex],
  2368. this.defaultButton.linkedBackground = this.closedBackground,
  2369. this.spacerControl = this.listBoxRegion.addTextButton("", s, k, 1 - (s + A), i, 1),
  2370. this.spacerControl.defaultAlpha = 1,
  2371. this.spacerControl.setBackground3x1(this.listBoxRegion, 0, 0, b, S, T, w),
  2372. this.spacerControl.setVisible(!1),
  2373. this.spacerControl.linkedBackground = this.openBackground,
  2374. i = 1; i < n; i++)
  2375. e = this.labelPixelInset + this.textOffsetsX[i - 1],
  2376. t = this.labelPixelDrop + this.textOffsetsY[i - 1] - 4,
  2377. e /= this.localPixelsX,
  2378. t /= this.localPixelsY,
  2379. b = this.listBoxRegion.addTextButton(this.textEntries[i - 1], e, r * i - t, 1 - e, r, .5),
  2380. this.listBoxButtons.push(b),
  2381. b.linkedBackground = this.openBackground;
  2382. this.showList(!1),
  2383. this.setupCallbacks()
  2384. }
  2385. ,
  2386. y.prototype.setControl = function (e, t, i, s, n, r) {
  2387. var a = this.controlRect.guiScreen.width
  2388. , o = this.controlRect.guiScreen.height;
  2389. if (n) {
  2390. n = this.textEntries.length;
  2391. for (var h = 0; h < n; h++) {
  2392. var l = 8 * (this.textEntries[h] ? this.textEntries[h].length : 0);
  2393. i < l && (i = l)
  2394. }
  2395. i += r
  2396. }
  2397. this.localPixelsX = i,
  2398. this.listBoxEntryHeight = s,
  2399. this.localPixelsY = (this.textEntries.length + 1) * this.listBoxEntryHeight,
  2400. this.listBoxRegion.controlRect.widthPercent = this.localPixelsX / a,
  2401. this.listBoxRegion.controlRect.heightPercent = this.localPixelsY / o,
  2402. this.listBoxRegion.controlRect.xPercent = e / a,
  2403. this.listBoxRegion.controlRect.yPercent = t / o,
  2404. this.listBoxRegion.controlRect.updateChildElements(),
  2405. this.spacerControl.alignBackground(),
  2406. this.openBackground.alignBackground(),
  2407. this.closedBackground.alignBackground()
  2408. }
  2409. ,
  2410. y.prototype.addItem = function (e, t, i) {
  2411. this.textEntries.push(e),
  2412. this.textOffsetsX.push(t),
  2413. this.textOffsetsY.push(i)
  2414. }
  2415. ,
  2416. y.prototype.showList = function (e) {
  2417. for (var t = this.listBoxButtons.length, i = 0; i < t; i++)
  2418. this.listBoxButtons[i].setVisible(e);
  2419. this.closed = !e,
  2420. this.spacerControl && this.spacerControl.setVisible(e),
  2421. this.openBackground && this.openBackground.setVisible(e),
  2422. this.closedBackground && this.closedBackground.setVisible(!e),
  2423. e ? (this.defaultButton.linkedBackground = this.openBackground,
  2424. this.openBackground.setOpacity(1),
  2425. this.closedBackground.setOpacity(.5)) : this.defaultButton.linkedBackground = this.closedBackground
  2426. }
  2427. ,
  2428. y.prototype.selectItem = function (e) {
  2429. this.selectedItemText = this.textEntries[e],
  2430. this.selectedIndex = e,
  2431. this.defaultButton.controlRect.linkedControl.innerHTML = this.textEntries[this.selectedIndex],
  2432. e = (this.labelTextHeight - this.listBoxEntryHeight + 3) / this.localPixelsY,
  2433. this.defaultButton.controlRect.xPercent = (this.labelPixelInset + this.textOffsetsX[this.selectedIndex]) / this.localPixelsX,
  2434. this.defaultButton.controlRect.yPercent = e,
  2435. this.defaultButton.controlRect.updateElement()
  2436. }
  2437. ,
  2438. y.prototype.setupCallbacks = function () {
  2439. var e = function (e) {
  2440. if (this.closed) {
  2441. var t = (t = this.closedBackground.controlRect.linkedControl).getBoundingClientRect()
  2442. , i = e.clientX - t.left;
  2443. e = e.clientY - t.top,
  2444. i /= t.width,
  2445. t = e / t.height,
  2446. 0 <= i && i <= 1 && 0 <= t && t <= 1 ? this.closedBackground.setOpacity(1) : this.closedBackground.setOpacity(.5)
  2447. } else
  2448. t = (t = this.openBackground.controlRect.linkedControl).getBoundingClientRect(),
  2449. i = e.clientX - t.left,
  2450. e = e.clientY - t.top,
  2451. i /= t.width,
  2452. t = e / t.height,
  2453. 0 <= i && i <= 1 && 0 <= t && t <= 1 ? this.openBackground.setOpacity(1) : this.openBackground.setOpacity(.5)
  2454. }
  2455. .bind(this);
  2456. this.defaultButton.controlRect.linkedControl.onclick = function () {
  2457. this.closed ? this.showList(!0) : (this.showList(this.closed),
  2458. this.closedBackground.setOpacity(1),
  2459. this.defaultButton.setOpacity(1))
  2460. }
  2461. .bind(this);
  2462. for (var t = function (e) {
  2463. this.selectItem(e.id),
  2464. this.showList(!1),
  2465. this.defaultButton.setOpacity(.5),
  2466. this.selectionChangedCallback && this.selectionChangedCallback(this)
  2467. }
  2468. .bind(this), i = function (e) {
  2469. e = this.listBoxButtons.length;
  2470. for (var t = 0; t < e; t++)
  2471. this.listBoxButtons[t].controlRect.mouseOver && (this.selectItem(t),
  2472. t = e,
  2473. this.selectionChangedCallback && this.selectionChangedCallback(this));
  2474. this.showList(!1)
  2475. }
  2476. .bind(this), s = this.listBoxButtons.length, n = 0; n < s; n++)
  2477. this.listBoxButtons[n].controlRect.callBack = t,
  2478. this.listBoxButtons[n].controlRect.id = n,
  2479. this.listBoxButtons[n].controlRect.linkedControl.addEventListener("mousemove", e);
  2480. this.guiScreen.ui.viewer.input.element.addEventListener("mousemove", e),
  2481. this.openBackground.controlRect.linkedControl.addEventListener("mousemove", e),
  2482. this.closedBackground.controlRect.linkedControl.addEventListener("mousemove", e),
  2483. this.guiScreen.ui.viewer.input.element.addEventListener("mousedown", i)
  2484. }
  2485. ,
  2486. b.prototype.bind = function (e, t) {
  2487. if (!this.complete())
  2488. return !1;
  2489. var i, s = e.view, n = e.lights, r = e.sky, a = e.shadow, o = e.stripData.active() ? this.stripShader : this.shader, h = this.skinParams, l = this.anisoParams, d = this.microfiberParams, c = this.gl, u = o.params, f = this.textures, m = o.samplers;
  2490. o.bind(),
  2491. this.blend();
  2492. var p = t.mesh.displayMatrix
  2493. , g = S.mul(S.empty(), s.viewMatrix, p)
  2494. , v = S.mul(S.empty(), s.projectionMatrix, s.viewMatrix);
  2495. g = S.mul(S.empty(), s.projectionMatrix, g),
  2496. p = S.mul(S.empty(), n.matrix, p);
  2497. return c.uniformMatrix4fv(u.uModelViewProjectionMatrix, !1, g),
  2498. c.uniformMatrix4fv(u.uSkyMatrix, !1, p),
  2499. p = S.mulPoint(V.empty(), n.matrix, s.transform[12], s.transform[13], s.transform[14]),
  2500. c.uniform3f(u.uCameraPosition, p[0], p[1], p[2]),
  2501. c.uniform3fv(u.uFresnel, this.fresnel),
  2502. c.uniform1f(u.uAlphaTest, this.alphaTest),
  2503. c.uniform1f(u.uHorizonOcclude, this.horizonOcclude),
  2504. c.uniform1f(u.uHorizonSmoothing, this.horizonSmoothing),
  2505. c.uniform4fv(u.uDiffuseCoefficients, r.diffuseCoefficients),
  2506. 0 < n.count && (c.uniform4fv(u.uLightPositions, n.positionBuffer),
  2507. c.uniform3fv(u.uLightDirections, n.directionBuffer),
  2508. c.uniform3fv(u.uLightColors, n.colors),
  2509. c.uniform3fv(u.uLightParams, n.parameters),
  2510. c.uniform3fv(u.uLightSpot, n.spot),
  2511. p = .392699 * e.postRender.currentSample(),
  2512. c.uniform2f(u.uShadowKernelRotation, .5 * Math.cos(p), .5 * Math.sin(p)),
  2513. 0 < n.shadowCount && (p = a.depthTextures[0].desc.width,
  2514. c.uniform2f(u.uShadowMapSize, p, 1 / p),
  2515. c.uniformMatrix4fv(u.uShadowMatrices, !1, n.finalTransformBuffer),
  2516. c.uniformMatrix4fv(u.uInvShadowMatrices, !1, n.inverseTransformBuffer),
  2517. c.uniform4fv(u.uShadowTexelPadProjections, n.shadowTexelPadProjections),
  2518. a.bindDepthTexture(m.tDepth0, 0),
  2519. a.bindDepthTexture(m.tDepth1, 1),
  2520. a.bindDepthTexture(m.tDepth2, 2))),
  2521. h && (c.uniform3fv(u.uSubdermisColor, h.subdermisColor),
  2522. c.uniform4fv(u.uTransColor, h.transColor),
  2523. c.uniform1f(u.uTransScatter, h.transScatter),
  2524. c.uniform4fv(u.uFresnelColor, h.fresnelColor),
  2525. c.uniform1f(u.uFresnelOcc, h.fresnelOcc),
  2526. c.uniform1f(u.uFresnelGlossMask, h.fresnelGlossMask),
  2527. c.uniform1f(u.uFresnelIntegral, h.fresnelIntegral),
  2528. c.uniform1f(u.uTransIntegral, h.transIntegral),
  2529. c.uniform1f(u.uSkinTransDepth, h.transDepth),
  2530. c.uniform1f(u.uTransSky, h.transSky),
  2531. c.uniform1f(u.uSkinShadowBlur, h.shadowBlur),
  2532. c.uniform1f(u.uNormalSmooth, h.normalSmooth),
  2533. (i = this.extrasTexCoordRanges.subdermisTex) && c.uniform4fv(u.uTexRangeSubdermis, i),
  2534. (i = this.extrasTexCoordRanges.translucencyTex) && c.uniform4fv(u.uTexRangeTranslucency, i),
  2535. (i = this.extrasTexCoordRanges.fuzzTex) && c.uniform4fv(u.uTexRangeFuzz, i)),
  2536. d && (c.uniform4fv(u.uFresnelColor, d.fresnelColor),
  2537. c.uniform1f(u.uFresnelOcc, d.fresnelOcc),
  2538. c.uniform1f(u.uFresnelGlossMask, d.fresnelGlossMask),
  2539. c.uniform1f(u.uFresnelIntegral, d.fresnelIntegral),
  2540. (i = this.extrasTexCoordRanges.fuzzTex) && c.uniform4fv(u.uTexRangeFuzz, i)),
  2541. l && (c.uniform3fv(u.uAnisoTangent, l.tangent),
  2542. c.uniform1f(u.uAnisoStrength, l.strength),
  2543. c.uniform1f(u.uAnisoIntegral, l.integral),
  2544. (i = this.extrasTexCoordRanges.anisoTex) && c.uniform4fv(u.uTexRangeAniso, i)),
  2545. this.usesRefraction && (e.refractionSurface && e.refractionSurface.bind(m.tRefraction),
  2546. n = S.mul(S.empty(), v, n.invMatrix),
  2547. c.uniformMatrix4fv(u.uRefractionViewProjection, !1, n),
  2548. c.uniform1f(u.uRefractionRayDistance, this.refractionParams.distantBackground ? 1e10 : 4 * t.mesh.bounds.maxExtent),
  2549. c.uniform3fv(u.uRefractionTint, this.refractionParams.tint),
  2550. c.uniform1f(u.uRefractionAlbedoTint, this.refractionParams.useAlbedoTint ? 1 : 0),
  2551. c.uniform1f(u.uRefractionIOREntry, 1 / this.refractionParams.IOR),
  2552. (i = this.extrasTexCoordRanges.refractionMaskTex) && c.uniform4fv(u.uTexRangeRefraction, i)),
  2553. (i = this.extrasTexCoordRanges.emissiveTex) && (c.uniform4fv(u.uTexRangeEmissive, i),
  2554. c.uniform1f(u.uEmissiveScale, this.emissiveIntensity)),
  2555. (i = this.extrasTexCoordRanges.aoTex) && c.uniform4fv(u.uTexRangeAO, i),
  2556. f.albedo.bind(m.tAlbedo),
  2557. f.reflectivity.bind(m.tReflectivity),
  2558. f.normal.bind(m.tNormal),
  2559. f.extras.bind(m.tExtras),
  2560. r.specularTexture.bind(m.tSkySpecular),
  2561. o === this.stripShader && (c.uniform1fv(u.uStrips, e.stripData.strips),
  2562. c.uniform2f(u.uStripRes, 2 / s.size[0], 2 / s.size[1])),
  2563. c.uniform2f(u.uUVOffset, this.uOffset, this.vOffset),
  2564. !0
  2565. }
  2566. ,
  2567. b.prototype.bindAlphaPrepass = function (e, t) {
  2568. if (!this.complete() || !this.prepassShader)
  2569. return !1;
  2570. var i = this.gl
  2571. , s = this.prepassShader.params
  2572. , n = this.prepassShader.samplers;
  2573. this.prepassShader.bind();
  2574. var r = S.mul(S.empty(), e.view.viewMatrix, t.mesh.displayMatrix);
  2575. r = S.mul(S.empty(), e.view.projectionMatrix, r);
  2576. return i.uniformMatrix4fv(s.uModelViewProjectionMatrix, !1, r),
  2577. i.uniform2f(s.uUVOffset, this.uOffset, this.vOffset),
  2578. this.textures.albedo.bind(n.tAlbedo),
  2579. !0
  2580. }
  2581. ,
  2582. b.prototype.bindWire = function (e, t) {
  2583. if (!this.complete())
  2584. return !1;
  2585. var i = this.gl
  2586. , s = this.wireShader.params
  2587. , n = e.view;
  2588. i.enable(i.BLEND),
  2589. i.blendFunc(i.SRC_ALPHA, i.ONE_MINUS_SRC_ALPHA),
  2590. i.depthMask(!1),
  2591. this.wireShader.bind();
  2592. var r = S.mul(S.empty(), e.view.viewMatrix, t.mesh.displayMatrix);
  2593. r = S.mul(S.empty(), e.view.projectionMatrix, r);
  2594. return i.uniformMatrix4fv(s.uModelViewProjectionMatrix, !1, r),
  2595. i.uniform4f(s.uStripParams, 2 / n.size[0], 2 / n.size[1], e.stripData.strips[3], e.stripData.strips[4]),
  2596. !0
  2597. }
  2598. ,
  2599. b.prototype.complete = function () {
  2600. return this.wireShader.complete() && this.shader.complete() && this.stripShader.complete() && (!this.prepassShader || this.prepassShader.complete()) && (!this.refractionShader || this.refractionShader.complete()) && this.textures.albedo.complete() && this.textures.reflectivity.complete() && this.textures.normal.complete()
  2601. }
  2602. ;
  2603. var S = {
  2604. type: Float32Array,
  2605. create: function (e, t, i, s, n, r, a, o, h, l, d, c, u, f, m, p) {
  2606. var g = new S.type(16);
  2607. return g[0] = e,
  2608. g[4] = t,
  2609. g[8] = i,
  2610. g[12] = s,
  2611. g[1] = n,
  2612. g[5] = r,
  2613. g[9] = a,
  2614. g[13] = o,
  2615. g[2] = h,
  2616. g[6] = l,
  2617. g[10] = d,
  2618. g[14] = c,
  2619. g[3] = u,
  2620. g[7] = f,
  2621. g[11] = m,
  2622. g[15] = p,
  2623. g
  2624. },
  2625. empty: function () {
  2626. return new S.type(16)
  2627. },
  2628. identity: function () {
  2629. var e = new S.type(16);
  2630. return e[0] = 1,
  2631. e[4] = 0,
  2632. e[8] = 0,
  2633. e[12] = 0,
  2634. e[1] = 0,
  2635. e[5] = 1,
  2636. e[9] = 0,
  2637. e[13] = 0,
  2638. e[2] = 0,
  2639. e[6] = 0,
  2640. e[10] = 1,
  2641. e[14] = 0,
  2642. e[3] = 0,
  2643. e[7] = 0,
  2644. e[11] = 0,
  2645. e[15] = 1,
  2646. e
  2647. },
  2648. set: function (e, t, i, s, n, r, a, o, h, l, d, c, u, f, m, p, g) {
  2649. e[0] = t,
  2650. e[4] = i,
  2651. e[8] = s,
  2652. e[12] = n,
  2653. e[1] = r,
  2654. e[5] = a,
  2655. e[9] = o,
  2656. e[13] = h,
  2657. e[2] = l,
  2658. e[6] = d,
  2659. e[10] = c,
  2660. e[14] = u,
  2661. e[3] = f,
  2662. e[7] = m,
  2663. e[11] = p,
  2664. e[15] = g
  2665. },
  2666. translation: function (e, t, i, s) {
  2667. return S.set(e, 1, 0, 0, t, 0, 1, 0, i, 0, 0, 1, s, 0, 0, 0, 1),
  2668. e
  2669. },
  2670. rotation: function (e, t, i) {
  2671. e[0] = 1,
  2672. e[4] = 0,
  2673. e[8] = 0,
  2674. e[12] = 0,
  2675. e[1] = 0,
  2676. e[5] = 1,
  2677. e[9] = 0,
  2678. e[13] = 0,
  2679. e[2] = 0,
  2680. e[6] = 0,
  2681. e[10] = 1,
  2682. e[14] = 0,
  2683. e[3] = 0,
  2684. e[7] = 0,
  2685. e[11] = 0,
  2686. e[15] = 1;
  2687. var s = .0174532925 * t;
  2688. switch (t = Math.sin(s),
  2689. s = Math.cos(s),
  2690. i) {
  2691. case 0:
  2692. e[5] = s,
  2693. e[9] = -t,
  2694. e[6] = t,
  2695. e[10] = s;
  2696. break;
  2697. case 1:
  2698. e[0] = s,
  2699. e[8] = t,
  2700. e[2] = -t,
  2701. e[10] = s;
  2702. break;
  2703. case 2:
  2704. e[0] = s,
  2705. e[4] = -t,
  2706. e[1] = t,
  2707. e[5] = s
  2708. }
  2709. return e
  2710. },
  2711. mul: function (e, t, i) {
  2712. var s = t[0]
  2713. , n = t[1]
  2714. , r = t[2]
  2715. , a = t[3]
  2716. , o = t[4]
  2717. , h = t[5]
  2718. , l = t[6]
  2719. , d = t[7]
  2720. , c = t[8]
  2721. , u = t[9]
  2722. , f = t[10]
  2723. , m = t[11]
  2724. , p = t[12]
  2725. , g = t[13]
  2726. , v = t[14];
  2727. t = t[15];
  2728. var x = i[0]
  2729. , y = i[1]
  2730. , b = i[2]
  2731. , S = i[3];
  2732. return e[0] = x * s + y * o + b * c + S * p,
  2733. e[1] = x * n + y * h + b * u + S * g,
  2734. e[2] = x * r + y * l + b * f + S * v,
  2735. e[3] = x * a + y * d + b * m + S * t,
  2736. x = i[4],
  2737. y = i[5],
  2738. b = i[6],
  2739. S = i[7],
  2740. e[4] = x * s + y * o + b * c + S * p,
  2741. e[5] = x * n + y * h + b * u + S * g,
  2742. e[6] = x * r + y * l + b * f + S * v,
  2743. e[7] = x * a + y * d + b * m + S * t,
  2744. x = i[8],
  2745. y = i[9],
  2746. b = i[10],
  2747. S = i[11],
  2748. e[8] = x * s + y * o + b * c + S * p,
  2749. e[9] = x * n + y * h + b * u + S * g,
  2750. e[10] = x * r + y * l + b * f + S * v,
  2751. e[11] = x * a + y * d + b * m + S * t,
  2752. x = i[12],
  2753. y = i[13],
  2754. b = i[14],
  2755. S = i[15],
  2756. e[12] = x * s + y * o + b * c + S * p,
  2757. e[13] = x * n + y * h + b * u + S * g,
  2758. e[14] = x * r + y * l + b * f + S * v,
  2759. e[15] = x * a + y * d + b * m + S * t,
  2760. e
  2761. },
  2762. invert: function (e, t) {
  2763. var i = t[0]
  2764. , s = t[1]
  2765. , n = t[2]
  2766. , r = t[3]
  2767. , a = t[4]
  2768. , o = t[5]
  2769. , h = t[6]
  2770. , l = t[7]
  2771. , d = t[8]
  2772. , c = t[9]
  2773. , u = t[10]
  2774. , f = t[11]
  2775. , m = t[12]
  2776. , p = t[13]
  2777. , g = t[14]
  2778. , v = t[15]
  2779. , x = i * o - s * a
  2780. , y = i * h - n * a
  2781. , b = i * l - r * a
  2782. , S = s * h - n * o
  2783. , T = s * l - r * o
  2784. , w = n * l - r * h
  2785. , C = d * p - c * m
  2786. , R = d * g - u * m
  2787. , A = d * v - f * m
  2788. , k = c * g - u * p
  2789. , I = c * v - f * p
  2790. , P = u * v - f * g
  2791. , F = x * P - y * I + b * k + S * A - T * R + w * C;
  2792. return F ? (F = 1 / F,
  2793. e[0] = (o * P - h * I + l * k) * F,
  2794. e[1] = (n * I - s * P - r * k) * F,
  2795. e[2] = (p * w - g * T + v * S) * F,
  2796. e[3] = (u * T - c * w - f * S) * F,
  2797. e[4] = (h * A - a * P - l * R) * F,
  2798. e[5] = (i * P - n * A + r * R) * F,
  2799. e[6] = (g * b - m * w - v * y) * F,
  2800. e[7] = (d * w - u * b + f * y) * F,
  2801. e[8] = (a * I - o * A + l * C) * F,
  2802. e[9] = (s * A - i * I - r * C) * F,
  2803. e[10] = (m * T - p * b + v * x) * F,
  2804. e[11] = (c * b - d * T - f * x) * F,
  2805. e[12] = (o * R - a * k - h * C) * F,
  2806. e[13] = (i * k - s * R + n * C) * F,
  2807. e[14] = (p * y - m * S - g * x) * F,
  2808. e[15] = (d * S - c * y + u * x) * F,
  2809. e) : null
  2810. },
  2811. transpose: function (e, t) {
  2812. return e[0] = t[0],
  2813. e[4] = t[1],
  2814. e[8] = t[2],
  2815. e[12] = t[3],
  2816. e[1] = t[4],
  2817. e[5] = t[5],
  2818. e[9] = t[6],
  2819. e[13] = t[7],
  2820. e[2] = t[8],
  2821. e[6] = t[9],
  2822. e[10] = t[10],
  2823. e[14] = t[11],
  2824. e[3] = t[12],
  2825. e[7] = t[13],
  2826. e[11] = t[14],
  2827. e[15] = t[15],
  2828. e
  2829. },
  2830. mul4: function (e, t, i, s, n, r) {
  2831. return e[0] = t[0] * i + t[4] * s + t[8] * n + t[12] * r,
  2832. e[1] = t[1] * i + t[5] * s + t[9] * n + t[13] * r,
  2833. e[2] = t[2] * i + t[6] * s + t[10] * n + t[14] * r,
  2834. e[3] = t[3] * i + t[7] * s + t[11] * n + t[15] * r,
  2835. e
  2836. },
  2837. mulPoint: function (e, t, i, s, n) {
  2838. return e[0] = t[0] * i + t[4] * s + t[8] * n + t[12],
  2839. e[1] = t[1] * i + t[5] * s + t[9] * n + t[13],
  2840. e[2] = t[2] * i + t[6] * s + t[10] * n + t[14],
  2841. e
  2842. },
  2843. mulVec: function (e, t, i, s, n) {
  2844. return e[0] = t[0] * i + t[4] * s + t[8] * n,
  2845. e[1] = t[1] * i + t[5] * s + t[9] * n,
  2846. e[2] = t[2] * i + t[6] * s + t[10] * n,
  2847. e
  2848. },
  2849. perspective: function (e, t, i, s, n, r) {
  2850. return r = r || 0,
  2851. t = 1 / Math.tan(.00872664625 * t),
  2852. e[0] = t / i,
  2853. e[1] = e[2] = e[3] = 0,
  2854. e[5] = t,
  2855. e[4] = e[6] = e[7] = 0,
  2856. e[8] = e[9] = 0,
  2857. e[10] = (n + s) / (s - n) - 30518044e-12 * r,
  2858. e[11] = -1,
  2859. e[14] = 2 * n * s / (s - n),
  2860. e[12] = e[13] = e[15] = 0,
  2861. e
  2862. },
  2863. perspectiveInfinite: function (e, t, i, s, n) {
  2864. return n = n || 0,
  2865. t = 1 / Math.tan(.00872664625 * t),
  2866. e[0] = t / i,
  2867. e[1] = e[2] = e[3] = 0,
  2868. e[5] = t,
  2869. e[4] = e[6] = e[7] = 0,
  2870. e[8] = e[9] = 0,
  2871. e[10] = e[11] = -1 - 30518044e-12 * n,
  2872. e[14] = -2 * s,
  2873. e[12] = e[13] = e[15] = 0,
  2874. e
  2875. },
  2876. ortho: function (e, t, i, s, n, r, a, o) {
  2877. var h = 1 / (i - t)
  2878. , l = 1 / (n - s)
  2879. , d = 1 / (a - r);
  2880. return e[0] = h + h,
  2881. e[1] = e[2] = e[3] = 0,
  2882. e[5] = l + l,
  2883. e[4] = e[6] = e[7] = 0,
  2884. e[12] = -(i + t) * h,
  2885. e[13] = -(n + s) * l,
  2886. e[10] = -(d + d) - 30518044e-12 * (o || 0),
  2887. e[14] = -(a + r) * d,
  2888. e[8] = e[9] = e[11] = 0,
  2889. e[15] = 1,
  2890. e
  2891. },
  2892. lookAt: function (e, t, i, s) {
  2893. var n = e.subarray(0, 3)
  2894. , r = e.subarray(4, 7)
  2895. , a = e.subarray(8, 11);
  2896. V.sub(a, t, i),
  2897. V.cross(n, s, a),
  2898. V.normalize(a, a),
  2899. V.normalize(n, n),
  2900. V.cross(r, a, n),
  2901. S.set(e, n[0], n[1], n[2], -V.dot(n, t), r[0], r[1], r[2], -V.dot(r, t), a[0], a[1], a[2], -V.dot(a, t), 0, 0, 0, 1)
  2902. },
  2903. copy: function (e, t) {
  2904. for (var i = 0; i < 16; ++i)
  2905. e[i] = t[i]
  2906. },
  2907. copyToBuffer: function (e, t, i) {
  2908. for (var s = 0; s < 16; ++s)
  2909. e[t + s] = i[s]
  2910. }
  2911. };
  2912. function T(e, t, i) {
  2913. this.gl = e;
  2914. var s = (this.desc = t).isDynamicMesh;
  2915. this.numSubMeshes = this.dynamicVertexData = 0,
  2916. this.displayMatrix = S.identity(),
  2917. this.name = t.name,
  2918. this.modelMatrix = S.identity(),
  2919. this.origin = t.transform ? V.create(t.transform[12], t.transform[13], t.transform[14], 1) : V.create(0, 5, 0, 1),
  2920. this.stride = 32,
  2921. (this.vertexColor = t.vertexColor) && (this.stride += 4),
  2922. (this.secondaryTexCoord = t.secondaryTexCoord) && (this.stride += 8),
  2923. i = new u(i.data),
  2924. this.indexCount = t.indexCount,
  2925. this.indexTypeSize = t.indexTypeSize,
  2926. this.indexType = 4 == this.indexTypeSize ? e.UNSIGNED_INT : e.UNSIGNED_SHORT,
  2927. this.indexBuffer = e.createBuffer(),
  2928. e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, this.indexBuffer);
  2929. var n = i.readBytes(this.indexCount * this.indexTypeSize);
  2930. e.bufferData(e.ELEMENT_ARRAY_BUFFER, n, e.STATIC_DRAW),
  2931. this.wireCount = t.wireCount,
  2932. this.wireBuffer = e.createBuffer(),
  2933. e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, this.wireBuffer),
  2934. n = i.readBytes(this.wireCount * this.indexTypeSize),
  2935. e.bufferData(e.ELEMENT_ARRAY_BUFFER, n, e.STATIC_DRAW),
  2936. e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, null),
  2937. this.vertexCount = t.vertexCount,
  2938. this.vertexBuffer = e.createBuffer(),
  2939. e.bindBuffer(e.ARRAY_BUFFER, this.vertexBuffer),
  2940. i = i.readBytes(this.vertexCount * this.stride),
  2941. s ? (this.dynamicVertexData = new Uint8Array(i),
  2942. e.bufferData(e.ARRAY_BUFFER, i, e.DYNAMIC_DRAW)) : e.bufferData(e.ARRAY_BUFFER, i, e.STATIC_DRAW),
  2943. e.bindBuffer(e.ARRAY_BUFFER, null),
  2944. this.bounds = void 0 === t.minBound || void 0 === t.maxBound ? {
  2945. min: V.create(-10, -10, -10, 1),
  2946. max: V.create(10, 10, -0, 1)
  2947. } : {
  2948. min: V.create(t.minBound[0], t.minBound[1], t.minBound[2], 1),
  2949. max: V.create(t.maxBound[0], t.maxBound[1], t.maxBound[2], 1)
  2950. },
  2951. this.bounds.maxExtent = Math.max(Math.max(t.maxBound[0] - t.minBound[0], t.maxBound[1] - t.minBound[1]), t.maxBound[2] - t.minBound[2]),
  2952. this.bounds.averageExtent = (t.maxBound[0] - t.minBound[0] + (t.maxBound[1] - t.minBound[1]) + (t.maxBound[2] - t.minBound[2])) / 3
  2953. }
  2954. function w(e, t, i) {
  2955. this.mesh = e,
  2956. this.gl = this.mesh.gl,
  2957. this.indexOffset = t.firstIndex * e.indexTypeSize,
  2958. this.indexCount = t.indexCount,
  2959. this.wireIndexOffset = t.firstWireIndex * e.indexTypeSize,
  2960. this.wireIndexCount = t.wireIndexCount,
  2961. this.material = i,
  2962. this.visible = !0
  2963. }
  2964. w.prototype.draw = function (e) {
  2965. var t = this.gl;
  2966. if (this.material.bind(e, this)) {
  2967. e = this.material.shader.attribs;
  2968. var i = this.mesh.stride;
  2969. this.mesh.desc.cullBackFaces ? (t.enable(t.CULL_FACE),
  2970. t.cullFace(t.BACK)) : t.disable(t.CULL_FACE),
  2971. t.bindBuffer(t.ELEMENT_ARRAY_BUFFER, this.mesh.indexBuffer),
  2972. t.bindBuffer(t.ARRAY_BUFFER, this.mesh.vertexBuffer),
  2973. t.enableVertexAttribArray(e.vPosition),
  2974. t.enableVertexAttribArray(e.vTexCoord),
  2975. t.enableVertexAttribArray(e.vTangent),
  2976. t.enableVertexAttribArray(e.vBitangent),
  2977. t.enableVertexAttribArray(e.vNormal);
  2978. var s = this.mesh.vertexColor && void 0 !== e.vColor;
  2979. s && t.enableVertexAttribArray(e.vColor);
  2980. var n = this.mesh.secondaryTexCoord && void 0 !== e.vTexCoord2;
  2981. n && t.enableVertexAttribArray(e.vTexCoord2);
  2982. var r = 0;
  2983. t.vertexAttribPointer(e.vPosition, 3, t.FLOAT, !1, i, r),
  2984. r += 12,
  2985. t.vertexAttribPointer(e.vTexCoord, 2, t.FLOAT, !1, i, r),
  2986. r += 8,
  2987. this.mesh.secondaryTexCoord && (n && t.vertexAttribPointer(e.vTexCoord2, 2, t.FLOAT, !1, i, r),
  2988. r += 8),
  2989. t.vertexAttribPointer(e.vTangent, 2, t.UNSIGNED_SHORT, !0, i, r),
  2990. r += 4,
  2991. t.vertexAttribPointer(e.vBitangent, 2, t.UNSIGNED_SHORT, !0, i, r),
  2992. r += 4,
  2993. t.vertexAttribPointer(e.vNormal, 2, t.UNSIGNED_SHORT, !0, i, r),
  2994. s && t.vertexAttribPointer(e.vColor, 4, t.UNSIGNED_BYTE, !0, i, r + 4),
  2995. t.drawElements(t.TRIANGLES, this.indexCount, this.mesh.indexType, this.indexOffset),
  2996. t.disableVertexAttribArray(e.vPosition),
  2997. t.disableVertexAttribArray(e.vTexCoord),
  2998. t.disableVertexAttribArray(e.vTangent),
  2999. t.disableVertexAttribArray(e.vBitangent),
  3000. t.disableVertexAttribArray(e.vNormal),
  3001. s && t.disableVertexAttribArray(e.vColor),
  3002. n && t.disableVertexAttribArray(e.vTexCoord2)
  3003. }
  3004. }
  3005. ,
  3006. w.prototype.drawShadow = function (e) {
  3007. var t = this.gl;
  3008. this.mesh.desc.cullBackFaces ? (t.enable(t.CULL_FACE),
  3009. t.cullFace(t.BACK)) : t.disable(t.CULL_FACE),
  3010. t.bindBuffer(t.ELEMENT_ARRAY_BUFFER, this.mesh.indexBuffer),
  3011. t.bindBuffer(t.ARRAY_BUFFER, this.mesh.vertexBuffer),
  3012. t.enableVertexAttribArray(e),
  3013. t.vertexAttribPointer(e, 3, t.FLOAT, !1, this.mesh.stride, 0),
  3014. t.drawElements(t.TRIANGLES, this.indexCount, this.mesh.indexType, this.indexOffset),
  3015. t.disableVertexAttribArray(e)
  3016. }
  3017. ,
  3018. w.prototype.drawAlphaShadow = function (e, t) {
  3019. var i = this.gl;
  3020. this.mesh.desc.cullBackFaces ? (i.enable(i.CULL_FACE),
  3021. i.cullFace(i.BACK)) : i.disable(i.CULL_FACE),
  3022. i.bindBuffer(i.ELEMENT_ARRAY_BUFFER, this.mesh.indexBuffer),
  3023. i.bindBuffer(i.ARRAY_BUFFER, this.mesh.vertexBuffer),
  3024. i.enableVertexAttribArray(e),
  3025. i.enableVertexAttribArray(t),
  3026. i.vertexAttribPointer(e, 3, i.FLOAT, !1, this.mesh.stride, 0),
  3027. i.vertexAttribPointer(t, 2, i.FLOAT, !1, this.mesh.stride, 12),
  3028. i.drawElements(i.TRIANGLES, this.indexCount, this.mesh.indexType, this.indexOffset),
  3029. i.disableVertexAttribArray(e),
  3030. i.disableVertexAttribArray(t)
  3031. }
  3032. ,
  3033. w.prototype.drawAlphaPrepass = function (e) {
  3034. var t = this.gl;
  3035. if (this.material.bindAlphaPrepass(e, this)) {
  3036. e = this.material.prepassShader.attribs;
  3037. var i = this.mesh.stride;
  3038. this.mesh.desc.cullBackFaces ? (t.enable(t.CULL_FACE),
  3039. t.cullFace(t.BACK)) : t.disable(t.CULL_FACE),
  3040. t.bindBuffer(t.ELEMENT_ARRAY_BUFFER, this.mesh.indexBuffer),
  3041. t.bindBuffer(t.ARRAY_BUFFER, this.mesh.vertexBuffer),
  3042. t.enableVertexAttribArray(e.vPosition),
  3043. t.enableVertexAttribArray(e.vTexCoord),
  3044. t.vertexAttribPointer(e.vPosition, 3, t.FLOAT, !1, i, 0),
  3045. t.vertexAttribPointer(e.vTexCoord, 2, t.FLOAT, !1, i, 12),
  3046. t.drawElements(t.TRIANGLES, this.indexCount, this.mesh.indexType, this.indexOffset),
  3047. t.disableVertexAttribArray(e.vPosition),
  3048. t.disableVertexAttribArray(e.vTexCoord)
  3049. }
  3050. }
  3051. ,
  3052. w.prototype.drawWire = function (e) {
  3053. var t = this.material.wireShader.attribs
  3054. , i = this.gl;
  3055. this.material.bindWire(e, this) && (i.enableVertexAttribArray(t.vPosition),
  3056. i.bindBuffer(i.ELEMENT_ARRAY_BUFFER, this.mesh.wireBuffer),
  3057. i.bindBuffer(i.ARRAY_BUFFER, this.mesh.vertexBuffer),
  3058. i.vertexAttribPointer(t.vPosition, 3, i.FLOAT, !1, this.mesh.stride, 0),
  3059. i.drawElements(i.LINES, this.wireIndexCount, this.mesh.indexType, this.wireIndexOffset),
  3060. i.disableVertexAttribArray(t.vPosition))
  3061. }
  3062. ,
  3063. w.prototype.complete = function () {
  3064. return this.material.complete()
  3065. }
  3066. ;
  3067. var C = {
  3068. fetchImage: function (e, t, i) {
  3069. var s = new Image;
  3070. s.crossOrigin = "Anonymous",
  3071. s.onload = function () {
  3072. 0 < s.width && 0 < s.height ? t(s) : i && i()
  3073. }
  3074. ,
  3075. i && (req.onerror = function () {
  3076. i()
  3077. }
  3078. ),
  3079. s.src = e
  3080. },
  3081. fetchText: function (e, t, i, s) {
  3082. var n = new XMLHttpRequest;
  3083. n.open("GET", e, !0),
  3084. n.onload = function () {
  3085. 200 == n.status ? t(n.responseText) : i && i()
  3086. }
  3087. ,
  3088. i && (n.onerror = function () {
  3089. i()
  3090. }
  3091. ),
  3092. s && (n.onprogress = function (e) {
  3093. s(e.loaded, e.total)
  3094. }
  3095. ),
  3096. n.send()
  3097. },
  3098. fetchBinary: function (e, t, i, s) {
  3099. var n = new XMLHttpRequest;
  3100. n.open("GET", e, !0),
  3101. n.responseType = "arraybuffer",
  3102. n.onload = function () {
  3103. 200 == n.status ? t(n.response) : i && i()
  3104. }
  3105. ,
  3106. i && (n.onerror = function () {
  3107. i()
  3108. }
  3109. ),
  3110. s && (n.onprogress = function (e) {
  3111. s(e.loaded, e.total)
  3112. }
  3113. ),
  3114. n.send()
  3115. },
  3116. fetchBinaryIncremental: function (r, a, t, o) {
  3117. var i = new XMLHttpRequest;
  3118. i.open("HEAD", r, !0),
  3119. i.onload = function () {
  3120. if (200 == i.status) {
  3121. var e = i.getResponseHeader("Accept-Ranges");
  3122. if (e && "none" != e) {
  3123. var s = 0 | i.getResponseHeader("Content-Length")
  3124. , n = function (e, t) {
  3125. var i = new XMLHttpRequest;
  3126. i.open("GET", r, !0),
  3127. i.setRequestHeader("Range", "bytes=" + e + "-" + t),
  3128. i.responseType = "arraybuffer",
  3129. i.onload = function () {
  3130. (206 == i.status || 200 == i.status) && a(i.response) && t < s && n(e += o, t = (t += o) < s - 1 ? t : s - 1)
  3131. }
  3132. ,
  3133. i.send()
  3134. };
  3135. n(0, o - 1)
  3136. } else
  3137. t && t()
  3138. } else
  3139. t && t()
  3140. }
  3141. ,
  3142. t && (i.onerror = function () {
  3143. t()
  3144. }
  3145. ),
  3146. i.send()
  3147. }
  3148. };
  3149. function R(e) {
  3150. this.debugString = "",
  3151. this.init = !1,
  3152. this.speedList = this.cameraList = this.animationList = this.playButton = this.timelineSlider = this.playbackRegion = this.previousFrameButton = this.nextFrameButton = this.pauseButton = this.playButton = 0,
  3153. this.visible = !1,
  3154. this.backgroundRegion = this.screenButton = 0,
  3155. this.guiScreen = e,
  3156. this.playbackRegion = new v(e),
  3157. this.idealSliderWidth = 650,
  3158. this.totalListBoxPixelsX = 0,
  3159. this.minWidth = 500,
  3160. this.compactMode = !1,
  3161. this.ui = e.ui;
  3162. var t = "animationpause" + e.imageSetNumber + "x.png"
  3163. , i = "animationplay" + e.imageSetNumber + "x.png"
  3164. , s = "timelineLE" + e.imageSetNumber + "x.png"
  3165. , n = "timelineM" + e.imageSetNumber + "x.png"
  3166. , r = "timelineRE" + e.imageSetNumber + "x.png"
  3167. , a = e.ui.viewer.scene.sceneAnimator.animations.length;
  3168. if (0 != a) {
  3169. var o = this.idealSliderWidth;
  3170. this.bottomOffset = 85,
  3171. this.centerOffset = 60;
  3172. var h, l = (h = e.width / 2 + this.centerOffset) - o / 2, d = l - 14 - 32, c = (h = h + o / 2) - d, u = 32 / e.height, f = this.bottomOffset / e.height, m = this.playbackRegion;
  3173. if (m.controlRect.widthPercent = c / e.width,
  3174. m.controlRect.heightPercent = u,
  3175. m.controlRect.xPercent = d / e.width,
  3176. m.controlRect.yPercent = f,
  3177. u = 32 / c,
  3178. this.pauseButton = new p(this.guiScreen),
  3179. this.pauseButton.controlRect.set(0, .125, u, .75),
  3180. this.pauseButton.controlRect.opacity = .5,
  3181. m.controlRect.registerChildControlRect(this.pauseButton.controlRect),
  3182. this.pauseButton.linkControl(m.addImageElement(this.pauseButton.controlRect, t)),
  3183. this.playButton = new p(this.guiScreen),
  3184. this.playButton.controlRect.set(0, .125, u, .75),
  3185. this.playButton.controlRect.opacity = .5,
  3186. m.controlRect.registerChildControlRect(this.playButton.controlRect),
  3187. this.playButton.linkControl(m.addImageElement(this.playButton.controlRect, i)),
  3188. t = o / c,
  3189. c = (l - d) / c,
  3190. this.timelineSlider = new z(this.guiScreen, m),
  3191. this.timelineSlider.controlRect.set(c, .03125, t, 1),
  3192. m.controlRect.registerChildControlRect(this.timelineSlider.controlRect),
  3193. this.timelineSlider.setBackground3x1(m, s, n, r),
  3194. this.pauseButton.controlRect.showControl(!e.ui.viewer.scene.sceneAnimator.paused),
  3195. this.playButton.controlRect.showControl(e.ui.viewer.scene.sceneAnimator.paused),
  3196. s = h + 14,
  3197. n = this.bottomOffset + 4,
  3198. r = e.ui.viewer.scene.sceneAnimator.animations[0].cameraObjects.length,
  3199. e.ui.viewer.scene.sceneAnimator.selectDefaultCamera(),
  3200. e.ui.viewer.scene.sceneAnimator.setViewFromSelectedCamera(),
  3201. this.maxListPixelsX = 0,
  3202. 1 < r) {
  3203. for (this.cameraList = new y(e),
  3204. c = 0; c < r; c++)
  3205. this.cameraList.addItem(e.ui.viewer.scene.sceneAnimator.animations[0].cameraObjects[c].name, 0, 0);
  3206. this.cameraList.spawnControl(s, n, 10, 24, !0, 8),
  3207. this.cameraList.selectItem(e.ui.viewer.scene.sceneAnimator.selectedCameraIndex),
  3208. this.maxListPixelsX = this.cameraList.localPixelsX,
  3209. this.totalListBoxPixelsX += this.cameraList.localPixelsX + 14
  3210. }
  3211. if (1 < a) {
  3212. for (this.animationList = new y(e),
  3213. c = 0; c < a; c++)
  3214. this.animationList.addItem(e.ui.viewer.scene.sceneAnimator.animations[c].name, 0, 0);
  3215. this.animationList.spawnControl(s, n, 10, 24, !0, 8),
  3216. this.maxListPixelsX < this.animationList.localPixelsX && (this.maxListPixelsX = this.animationList.localPixelsX),
  3217. this.totalListBoxPixelsX += this.animationList.localPixelsX + 14,
  3218. this.animationList.selectItem(e.ui.viewer.scene.sceneAnimator.selectedAnimationIndex)
  3219. }
  3220. c = h - (s = d - 44 - 14) + this.totalListBoxPixelsX,
  3221. this.speedList = new y(e),
  3222. this.speedList.addItem("4.0x", 4, 0),
  3223. this.speedList.addItem("2.0x", 4, 0),
  3224. this.speedList.addItem("1.0x", 4, 0),
  3225. this.speedList.addItem("0.5x", 4, 0),
  3226. this.speedList.addItem("0.25x", -2, 0),
  3227. this.speedList.spawnControl(s, n, 44, 24, !1, 0),
  3228. this.speedList.selectItem(2),
  3229. c > e.width && (this.idealSliderWidth = e.width - (118 + (this.totalListBoxPixelsX + 14)) - this.centerOffset,
  3230. e = 0,
  3231. this.cameraList && e++,
  3232. this.animationList && e++,
  3233. 1 == e && (this.idealSliderWidth += 56,
  3234. this.centerOffset -= 14),
  3235. 2 == e && (this.idealSliderWidth += 63,
  3236. this.centerOffset -= 63)),
  3237. this.setupCallbacks()
  3238. }
  3239. }
  3240. function A(e, t, i) {
  3241. if (this.gl = e,
  3242. this.desc = t,
  3243. t = [],
  3244. 0 != this.desc.sharpen && t.push("#define SHARPEN"),
  3245. (this.useBloom = 0 < this.desc.bloomColor[0] * this.desc.bloomColor[3] || 0 < this.desc.bloomColor[1] * this.desc.bloomColor[3] || 0 < this.desc.bloomColor[2] * this.desc.bloomColor[3]) && t.push("#define BLOOM"),
  3246. 0 != this.desc.vignette[3] && t.push("#define VIGNETTE"),
  3247. 1 == this.desc.saturation[0] * this.desc.saturation[3] && 1 == this.desc.saturation[1] * this.desc.saturation[3] && 1 == this.desc.saturation[2] * this.desc.saturation[3] || t.push("#define SATURATION"),
  3248. 1 == this.desc.contrast[0] * this.desc.contrast[3] && 1 == this.desc.contrast[1] * this.desc.contrast[3] && 1 == this.desc.contrast[2] * this.desc.contrast[3] && 1 == this.desc.brightness[0] * this.desc.brightness[3] && 1 == this.desc.brightness[1] * this.desc.brightness[3] && 1 == this.desc.brightness[2] * this.desc.brightness[3] || t.push("#define CONTRAST"),
  3249. 0 != this.desc.grain && t.push("#define GRAIN"),
  3250. 1 == this.desc.toneMap ? t.push("#define REINHARD") : 2 == this.desc.toneMap && t.push("#define HEJL"),
  3251. this.desc.colorLUT && t.push("#define COLOR_LUT"),
  3252. this.sampleIndex = 0,
  3253. this.sampleCount = 1,
  3254. i && (this.sampleCount = 4,
  3255. this.sampleOffsets = [[-.5, -.5], [.5, -.5], [-.5, .5], [.5, .5]]),
  3256. this.aaShader = e.shaderCache.fromURLs("postvert.glsl", "postaa.glsl"),
  3257. this.shader = e.shaderCache.fromURLs("postvert.glsl", "postfrag.glsl", t),
  3258. this.plainShader = e.shaderCache.fromURLs("postvert.glsl", "postfrag.glsl", []),
  3259. this.fullscreenTriangle = e.createBuffer(),
  3260. e.bindBuffer(e.ARRAY_BUFFER, this.fullscreenTriangle),
  3261. i = new Float32Array([0, 0, 2, 0, 0, 2]),
  3262. e.bufferData(e.ARRAY_BUFFER, i, e.STATIC_DRAW),
  3263. e.bindBuffer(e.ARRAY_BUFFER, null),
  3264. this.useBloom) {
  3265. for (this.bloomTextures = [],
  3266. this.bloomTargets = [],
  3267. i = 0; i < 2; ++i)
  3268. t = {
  3269. width: 256,
  3270. height: 256,
  3271. clamp: !0
  3272. },
  3273. this.bloomTextures[i] = new U(e, t),
  3274. this.bloomTextures[i].loadArray(null, e.RGBA, e.ext.textureHalf && e.ext.textureHalfLinear ? e.ext.textureHalf.HALF_FLOAT_OES : e.UNSIGNED_BYTE),
  3275. this.bloomTargets[i] = new m(e, {
  3276. width: t.width,
  3277. height: t.height,
  3278. color0: this.bloomTextures[i]
  3279. });
  3280. for (this.bloomSamples = 64; this.bloomSamples + 16 >= e.limits.fragmentUniforms;)
  3281. this.bloomSamples /= 2;
  3282. this.bloomShader = e.shaderCache.fromURLs("postvert.glsl", "bloom.glsl", ["#define BLOOM_SAMPLES " + this.bloomSamples]),
  3283. this.shrinkShader = e.shaderCache.fromURLs("postvert.glsl", "bloomshrink.glsl")
  3284. }
  3285. for (e = new Uint8Array(16384),
  3286. i = 0; i < 16384; i++) {
  3287. t = 255 * Math.random();
  3288. var s = 255 * Math.random();
  3289. e[i] = .5 * (t + s)
  3290. }
  3291. this.noiseTexture = new U(this.gl, {
  3292. width: 128,
  3293. height: 128
  3294. }),
  3295. this.noiseTexture.loadArray(e, this.gl.LUMINANCE),
  3296. this.desc.colorLUT && (e = this.desc.colorLUT,
  3297. this.colorLUT = new U(this.gl, {
  3298. width: e.length / 3 | 0,
  3299. height: 1,
  3300. clamp: !0
  3301. }),
  3302. this.colorLUT.loadArray(new Uint8Array(e), this.gl.RGB)),
  3303. this.blackTexture = new U(this.gl, {
  3304. width: 1,
  3305. height: 1
  3306. }),
  3307. this.blackTexture.loadArray(new Uint8Array([0, 0, 0, 0])),
  3308. this.bloomResult = this.blackTexture
  3309. }
  3310. function k(e) {
  3311. this.gl = e,
  3312. this.name = "untitled",
  3313. this.meshes = [],
  3314. this.meshRenderables = [],
  3315. this.materials = {},
  3316. this.sky = this.view = null,
  3317. this.selectedPartIndex = 0,
  3318. this.soloPart = !1,
  3319. this.miscnotes = "",
  3320. this.nextView = null,
  3321. this.viewFade = 0,
  3322. this.refractionSurface = this.shadow = this.stripData = this.lights = null,
  3323. this.sceneAnimator = this.frameCounter = 0,
  3324. this.sceneLoaded = !1,
  3325. this.debugString = ""
  3326. }
  3327. function P(e, t, i) {
  3328. if (this.scene = e,
  3329. this.animations = [],
  3330. this.skinningRigs = [],
  3331. this.meshIDs = [],
  3332. this.lightIDs = [],
  3333. this.materialIDs = [],
  3334. this.views = [],
  3335. this.viewYawOffsets = [],
  3336. this.viewPitchOffsets = [],
  3337. this.cameraObjectIndices = [],
  3338. this.cameraChildrenIndices = [],
  3339. this.subMeshObjectIndices = [],
  3340. this.subMeshLiveIndices = [],
  3341. this.scene = e,
  3342. this.selectedCameraIndex = -1,
  3343. this.selectedAnimationIndex = 0,
  3344. this.debugString = "",
  3345. this.scenePlaybackSpeed = this.playbackSpeed = 1,
  3346. this.animationProgress = this.totalSeconds = 0,
  3347. this.paused = this.autoAdvanceNextAnimation = !1,
  3348. this.animateVisibility = this.drawAnimated = this.linkSceneObjects = this.loadSkinningRigs = this.animateMaterials = this.animateTurntables = this.enableSkinning = this.animateMeshes = this.animateLights = this.playAnimations = this.loadAnimations = !0,
  3349. this.showDebugInfo = !1,
  3350. this.loopCount = 0,
  3351. this.loopTurntables = this.lockPlayback = !1,
  3352. this.fogObjectIndex = -1,
  3353. this.unitScaleSkinnedMeshes = !0,
  3354. this.sceneScale = i.sceneScale,
  3355. this.defaultCameraGlobalIndex = i.selectedCamera,
  3356. this.selectedAnimationIndex = i.selectedAnimation,
  3357. this.autoPlayAnims = i.autoPlayAnims,
  3358. this.showPlayControls = i.showPlayControls,
  3359. i.scenePlaybackSpeed && (this.scenePlaybackSpeed = i.scenePlaybackSpeed,
  3360. 0 == this.scenePlaybackSpeed && (this.scenePlaybackSpeed = 1)),
  3361. this.autoPlayAnims || (this.paused = !0),
  3362. this.loadAnimations) {
  3363. if (i.meshIDs)
  3364. for (var s = i.meshIDs.length, n = 0; n < s; ++n) {
  3365. var r = i.meshIDs[n].partIndex;
  3366. this.meshIDs.push(r)
  3367. }
  3368. if (i.lightIDs)
  3369. for (s = i.lightIDs.length,
  3370. n = 0; n < s; ++n)
  3371. r = (r = i.lightIDs[n]).partIndex,
  3372. this.lightIDs.push(r);
  3373. if (i.materialIDs)
  3374. for (s = i.materialIDs.length,
  3375. n = 0; n < s; ++n)
  3376. r = (r = i.materialIDs[n]).partIndex,
  3377. this.materialIDs.push(r);
  3378. if (this.numMatricesInTable = i.numMatrices,
  3379. r = new u((n = t.get("MatTable.bin")).data),
  3380. n || (this.numMatricesInTable = 0,
  3381. this.debugString += "<br>No mattable?"),
  3382. i.skinningRigs && this.loadSkinningRigs)
  3383. for (s = i.skinningRigs.length,
  3384. n = 0; n < s; ++n) {
  3385. "" == (a = new M(t, i.skinningRigs[n], r)).debugString ? this.skinningRigs.push(a) : (this.debugString += "<br>Error loading skinning rig " + n + " :" + a.debugString,
  3386. this.debugString += "<br>Skipping the rest",
  3387. n = s)
  3388. }
  3389. if (i.animations)
  3390. for (r = i.animations.length,
  3391. n = 0; n < r; ++n)
  3392. s = new c(t, i.animations[n]),
  3393. this.animations.push(s);
  3394. if (this.startMS = Date.now(),
  3395. r = this.animations.length,
  3396. this.linkSceneObjects && 0 != r) {
  3397. for (n = 0; n < r; n++)
  3398. for (s = (t = this.animations[n]).animatedObjects.length,
  3399. i = 0; i < s; i++)
  3400. "LightSO" == (a = t.animatedObjects[i]).sceneObjectType && (a.lightIndex = this.findLightIndexByPartIndex(i),
  3401. -1 != a.lightIndex ? t.lightObjects.push(a) : this.debugString += "<br> got light not in scene " + a.name),
  3402. "FogSO" == a.sceneObjectType && (this.fogObjectIndex = i),
  3403. "SubMeshSO" == a.sceneObjectType && 0 == n && (this.subMeshObjectIndices.push(i),
  3404. this.subMeshLiveIndices.push(-1)),
  3405. "Material" == a.sceneObjectType && (a.materialIndex = this.findMaterialIndexByPartIndex(i),
  3406. -1 == a.materialIndex ? this.debugString += "<br> can't find material index for object " + i : t.materialObjects.push(a)),
  3407. "TurnTableSO" == a.sceneObjectType && t.turnTableObjects.push(a),
  3408. "MeshSO" == a.sceneObjectType && (a.meshIndex = this.findMeshIndexByPartIndex(this.scene.meshes, i),
  3409. -1 == a.meshIndex ? (this.debugString += "<br> can't find mesh index for object " + i,
  3410. this.logObjectInfo(i, 0)) : (t.meshObjects.push(a),
  3411. a.mesh = this.scene.meshes[a.meshIndex],
  3412. -1 != a.skinningRigIndex && a.mesh && a.skinningRigIndex < this.skinningRigs.length && (a.skinningRig = this.skinningRigs[a.skinningRigIndex],
  3413. a.skinningRig.isRigidSkin || (a.mesh.dynamicVertexData ? a.skinningRig.useOriginalMeshVertices(a.mesh) : (this.debugString += "Skinning object - but mesh is not dynamic",
  3414. this.debugString += "<br>Rig index " + a.skinningRigIndex,
  3415. this.debugString += " not tagged as rigid"))))),
  3416. "CameraSO" == a.sceneObjectType && (a.modelPartIndex = a.id,
  3417. t.cameraObjects.push(a));
  3418. for (i = (t = this.animations[0]).cameraObjects.length,
  3419. n = 0; n < i; n++)
  3420. r = t.cameraObjects[n],
  3421. (s = this.scene.cameras[r.name]) ? (s = s.view) && (s = new H(s),
  3422. this.cameraObjectIndices.push(r.id),
  3423. this.views.push(s),
  3424. this.viewYawOffsets.push(0),
  3425. this.viewPitchOffsets.push(0)) : (this.debugString += "<br>no camDesc for " + r.name,
  3426. this.views.push(e.view));
  3427. for (e = this.scene.meshes.length,
  3428. r = this.subMeshObjectIndices.length,
  3429. n = s = 0; n < e; n++) {
  3430. var a = this.scene.meshes[n]
  3431. , o = !1;
  3432. for (i = 0; i < r; i++) {
  3433. var h = this.subMeshObjectIndices[i]
  3434. , l = t.animatedObjects[h]
  3435. , d = t.animatedObjects[l.parentIndex];
  3436. if (d.mesh || (this.debugString += "<br>submesh parent object has no mesh?",
  3437. this.debugString += "<br>obj.name " + l.name,
  3438. this.debugString += "<br>parent.name " + d.name,
  3439. this.debugString += "<br>submesh index " + i,
  3440. this.debugString += "<br>obj.index " + h),
  3441. d.mesh == a) {
  3442. for (o = 0; o < a.numSubMeshes; o++)
  3443. this.subMeshLiveIndices[i + (a.numSubMeshes - 1 - o)] = s,
  3444. s++;
  3445. i = r,
  3446. o = !0
  3447. }
  3448. }
  3449. o || (this.debugString += "<br>Missing submesh? - no matches for mesh " + n + " of " + e)
  3450. }
  3451. for (n = 0; n < r; n++)
  3452. -1 == this.subMeshLiveIndices[n] && (this.debugString += "<br>Missing mesh? Unused submesh " + n + " of " + r);
  3453. this.showDebugInfo = this.stopEverything = this.runDebugMode = !1,
  3454. this.selectDefaultCamera(),
  3455. this.findCameraChildren(),
  3456. this.findFixedTransforms(),
  3457. this.runDebugMode && (this.setAnimationProgress(0, !0),
  3458. "" != this.debugString ? this.stopEverything = !0 : this.checkDebug())
  3459. }
  3460. } else
  3461. this.debugString += "<br>Skip loading animation data"
  3462. }
  3463. function F(e) {
  3464. this.gl = e,
  3465. this.program = null,
  3466. this.params = {},
  3467. this.samplers = {},
  3468. this.attribs = {}
  3469. }
  3470. function O(e) {
  3471. this.gl = e,
  3472. this.cache = []
  3473. }
  3474. function E(e, t) {
  3475. if (this.gl = e,
  3476. this.shadowCount = t,
  3477. this.nativeDepth = !!e.ext.textureDepth,
  3478. this.desc = i,
  3479. i = this.nativeDepth ? ["#define SHADOW_NATIVE_DEPTH"] : [],
  3480. this.shaderSolid = e.shaderCache.fromURLs("shadowvert.glsl", "shadowfrag.glsl", i),
  3481. i.push("#define ALPHA_TEST 1"),
  3482. this.shaderAlphaTest = e.shaderCache.fromURLs("shadowvert.glsl", "shadowfrag.glsl", i),
  3483. this.depthTextures = [],
  3484. this.depthTargets = [],
  3485. 0 < this.shadowCount) {
  3486. var i = {
  3487. width: 2048,
  3488. height: 2048,
  3489. clamp: !0,
  3490. mipmap: !1,
  3491. nofilter: !0
  3492. };
  3493. e.hints.mobile && (i.width = i.height = 1536);
  3494. var s, n, r = {
  3495. width: i.width,
  3496. height: i.height
  3497. };
  3498. n = this.nativeDepth ? (s = e.DEPTH_COMPONENT,
  3499. e.UNSIGNED_SHORT) : (r.depthBuffer = m.createDepthBuffer(e, i.width, i.height),
  3500. s = e.RGB,
  3501. e.UNSIGNED_BYTE);
  3502. for (var a = 0; a < this.shadowCount; ++a)
  3503. this.depthTextures[a] = new U(e, i),
  3504. this.depthTextures[a].loadArray(null, s, n),
  3505. this.nativeDepth ? r.depth = this.depthTextures[a] : r.color0 = this.depthTextures[a],
  3506. this.depthTargets[a] = new m(e, r)
  3507. }
  3508. }
  3509. function B(e, t, i, s) {
  3510. this.gl = e,
  3511. this.desc = t,
  3512. this.lightCount = s.count,
  3513. this.shadowCount = i.shadowCount,
  3514. (t = this.nativeDepth ? ["#define SHADOW_NATIVE_DEPTH"] : []).push("#define LIGHT_COUNT " + this.lightCount),
  3515. t.push("#define SHADOW_COUNT " + this.shadowCount),
  3516. e.hints.mobile && t.push("#define MOBILE"),
  3517. this.shader = e.shaderCache.fromURLs("shadowfloorvert.glsl", "shadowfloorfrag.glsl", t),
  3518. t = new Float32Array([-1, 0, -1, -1, 0, 1, 1, 0, 1, -1, 0, -1, 1, 0, 1, 1, 0, -1]),
  3519. this.quadGeom = e.createBuffer(),
  3520. e.bindBuffer(e.ARRAY_BUFFER, this.quadGeom),
  3521. e.bufferData(e.ARRAY_BUFFER, t, e.STATIC_DRAW),
  3522. e.bindBuffer(e.ARRAY_BUFFER, null)
  3523. }
  3524. function L() {
  3525. this.associateObjectIndex = this.linkObjectIndex = this.linkMode = 0,
  3526. this.vertexIndices = [],
  3527. this.vertexWeights = [],
  3528. this.matrix = S.identity(),
  3529. this.defaultAssociateWorldTransform = this.defaultClusterWorldTransform = this.defaultClusterBaseTransform = 0,
  3530. this.defaultClusterWorldTransformInvert = S.identity(),
  3531. this.defaultAssociateWorldTransformInvert = S.identity(),
  3532. this.debugString = ""
  3533. }
  3534. function M(e, t, i) {
  3535. if (this.debugString = "",
  3536. this.skinningClusters = [],
  3537. this.srcVFile = t.file,
  3538. e = e.get(this.srcVFile))
  3539. if (e.data) {
  3540. this.rigByteStream = new u(e.data),
  3541. e = new Uint32Array(this.rigByteStream.bytes.buffer, 0, this.rigByteStream.bytes.length / 4),
  3542. this.expectedNumClusters = e[0],
  3543. this.expectedNumVertices = e[1],
  3544. this.numClusterLinks = e[2],
  3545. this.originalObjectIndex = e[3],
  3546. this.isRigidSkin = e[4],
  3547. this.tangentMethod = e[5],
  3548. t = 6 + 7 * this.expectedNumClusters;
  3549. for (var s = 0; s < this.expectedNumClusters; s++) {
  3550. var n = new L;
  3551. this.skinningClusters.push(n);
  3552. var r = 6 + 7 * s;
  3553. n.linkMode = e[1 + r],
  3554. n.linkObjectIndex = e[2 + r],
  3555. n.associateObjectIndex = e[3 + r];
  3556. var a = e[5 + r];
  3557. n.defaultClusterWorldTransform = i.getMatrix(e[4 + r]),
  3558. n.defaultClusterBaseTransform = i.getMatrix(a),
  3559. S.invert(n.defaultClusterWorldTransformInvert, n.defaultClusterWorldTransform),
  3560. 1 == n.linkMode && (n.defaultAssociateWorldTransform = i.getMatrix(e[6 + r]),
  3561. S.invert(n.defaultAssociateWorldTransformInvert, n.defaultAssociateWorldTransform))
  3562. }
  3563. e = (t = (i = 4 * t) + this.expectedNumVertices) + 2 * this.numClusterLinks,
  3564. t = new Uint8Array(this.rigByteStream.bytes.subarray(t)),
  3565. e = new Uint8Array(this.rigByteStream.bytes.subarray(e)),
  3566. this.linkMapCount = new Uint8Array(this.rigByteStream.bytes.buffer, i, this.expectedNumVertices),
  3567. this.linkMapClusterIndices = new Uint16Array(t.buffer),
  3568. this.linkMapWeights = new Float32Array(e.buffer)
  3569. } else
  3570. this.debugString += "<br>No data in " + this.srcVFile;
  3571. else
  3572. this.debugString += "<br>Error loading buffer for skinning rig " + this.srcVFile
  3573. }
  3574. function _(e, t, i) {
  3575. if (this.gl = e,
  3576. void 0 !== (s = t.extract("sky.dat") || t.extract("sky.png"))) {
  3577. this.specularTexture = new U(e, {
  3578. width: 256,
  3579. height: 2048,
  3580. clamp: !0
  3581. }),
  3582. t = s.data;
  3583. for (var s, n = (s = s.data.length) / 4, r = new Uint8Array(s), a = 0, o = 0; a < s; ++o)
  3584. r[a++] = t[o + 2 * n],
  3585. r[a++] = t[o + n],
  3586. r[a++] = t[o],
  3587. r[a++] = t[o + 3 * n];
  3588. this.specularTexture.loadArray(r)
  3589. }
  3590. if (this.diffuseCoefficients = new Float32Array(i.diffuseCoefficients),
  3591. this.backgroundMode = i.backgroundMode || 0,
  3592. this.backgroundBrightness = i.backgroundBrightness || 1,
  3593. this.backgroundColor = new Float32Array(i.backgroundColor),
  3594. 1 <= this.backgroundMode)
  3595. if (this.backgroundShader = e.shaderCache.fromURLs("skyvert.glsl", 3 == this.backgroundMode ? "skySH.glsl" : "sky.glsl", ["#define SKYMODE " + this.backgroundMode]),
  3596. this.vertexBuffer = e.createBuffer(),
  3597. e.bindBuffer(e.ARRAY_BUFFER, this.vertexBuffer),
  3598. i = 1 / 256,
  3599. s = 2.8 * (t = .5 / 256),
  3600. n = .5 * t,
  3601. i = new Float32Array([0, 1, 0, .49609375 + i, .49609375 + i, 1, 0, 0, .9921875 + i, .49609375 + i, 0, 0, 1, .49609375 + i, .9921875 + i, -1, 0, 0, 0 + i, .49609375 + i, 0, 0, -1, .49609375 + i, 0 + i, 0, -1, 0, .9921875 + i, 0 + i, 0, -1, 0, .9921875 + i, .9921875 + i, 0, -1, 0, 0 + i, .9921875 + i, 0, -1, 0, 0 + i, 0 + i, s, 1 - s, -s, .5 + t, .5 - t, s, 1 - s, s, .5 + t, .5 + t, -s, 1 - s, s, .5 - t, .5 + t, -s, 1 - s, -s, .5 - t, .5 - t, -s, 0, -1 + s, .5 - t, 0 + i + t, s, 0, -1 + s, .5 + t, 0 + i + t, 1 - s, 0, -s, .9921875 + i - t, .5 - t, 1 - s, 0, s, .9921875 + i - t, .5 + t, s, 0, 1 - s, .5 + t, .9921875 + i - t, -s, 0, 1 - s, .5 - t, .9921875 + i - t, -1 + s, 0, s, 0 + i + t, .5 + t, -1 + s, 0, -s, 0 + i + t, .5 - t, 1, 0, 0, .9921875 + i - n, .49609375 + i, 0, 0, 1, .49609375 + i, .9921875 + i - n, -1, 0, 0, 0 + i + n, .49609375 + i, 0, 0, -1, .49609375 + i, 0 + i + n, 0, 1, 0, .49609375 + i - n, .49609375 + i, 0, 1, 0, .49609375 + i, .49609375 + i - n, 0, 1, 0, .49609375 + i + n, .49609375 + i, 0, 1, 0, .49609375 + i, .49609375 + i + n]),
  3602. e.bufferData(e.ARRAY_BUFFER, i, e.STATIC_DRAW),
  3603. e.bindBuffer(e.ARRAY_BUFFER, null),
  3604. this.indexBuffer = e.createBuffer(),
  3605. e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, this.indexBuffer),
  3606. i = new Uint16Array([2, 1, 6, 3, 2, 7, 8, 4, 3, 4, 5, 1, 9, 14, 15, 17, 10, 16, 18, 19, 11, 20, 13, 12, 28, 12, 13, 13, 24, 28, 28, 24, 9, 9, 24, 14, 25, 9, 15, 25, 15, 21, 10, 25, 21, 10, 21, 16, 22, 26, 10, 22, 10, 17, 18, 11, 26, 22, 18, 26, 19, 23, 27, 19, 27, 11, 23, 20, 27, 27, 20, 12]),
  3607. this.skyIndexCount = i.length,
  3608. e.bufferData(e.ELEMENT_ARRAY_BUFFER, i, e.STATIC_DRAW),
  3609. e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, null),
  3610. 3 == this.backgroundMode)
  3611. for (this.backgroundCoefficients = new Float32Array(this.diffuseCoefficients),
  3612. a = 0; a < this.backgroundCoefficients.length; ++a)
  3613. this.backgroundCoefficients[a] *= this.backgroundBrightness;
  3614. else {
  3615. var h;
  3616. this.backgroundTexture = new U(e, {
  3617. width: 256,
  3618. height: 256,
  3619. clamp: !0
  3620. }),
  3621. i = !1,
  3622. e.ext.textureHalf && e.ext.textureHalfLinear && (this.backgroundTexture.loadArray(null, e.RGB, e.ext.textureHalf.HALF_FLOAT_OES),
  3623. i = (h = new m(e, {
  3624. color0: this.backgroundTexture
  3625. })).valid),
  3626. !i && e.ext.textureFloat && e.ext.textureFloatLinear && !e.hints.mobile && (this.backgroundTexture.loadArray(null, e.RGB, e.FLOAT),
  3627. i = (h = new m(e, {
  3628. color0: this.backgroundTexture
  3629. })).valid),
  3630. i || (this.backgroundTexture.loadArray(),
  3631. h = new m(e, {
  3632. color0: this.backgroundTexture
  3633. })),
  3634. h.bind(),
  3635. (h = new F(e)).build("precision highp float; varying vec2 tc; attribute vec4 p; void main(){ gl_Position=p; tc=vec2(0.5,0.5/8.0)*p.xy+vec2(0.5,6.5/8.0); }", "precision highp float; varying vec2 tc; uniform sampler2D tex; uniform float b; void main(){vec4 s=texture2D(tex,tc); gl_FragColor.xyz=s.xyz*(b*s.w);}"),
  3636. h.bind(),
  3637. e.uniform1f(h.params.b, 7 * Math.sqrt(this.backgroundBrightness)),
  3638. this.specularTexture.bind(h.samplers.tex),
  3639. i = e.createBuffer(),
  3640. e.bindBuffer(e.ARRAY_BUFFER, i),
  3641. i = new Float32Array([-1, -1, .5, 1, 3, -1, .5, 1, -1, 3, .5, 1]),
  3642. e.bufferData(e.ARRAY_BUFFER, i, e.STATIC_DRAW),
  3643. e.enableVertexAttribArray(h.attribs.p),
  3644. e.vertexAttribPointer(h.attribs.p, 4, e.FLOAT, !1, 0, 0),
  3645. e.drawArrays(e.TRIANGLES, 0, 3),
  3646. e.disableVertexAttribArray(h.attribs.p)
  3647. }
  3648. }
  3649. function D() {
  3650. this.STRIP_NONE = -2,
  3651. this.STRIP_MENU = -1,
  3652. this.stripCount = 5,
  3653. this.strips = [0, 0, 0, 0, 0],
  3654. this.labels = ["Normals", "Albedo", "Reflectivity", "Gloss", "Topology"],
  3655. this.stripSlant = .25,
  3656. this.selectedStrip = this.STRIP_NONE,
  3657. this.animationActive = !1,
  3658. this.timestamp = Date.now(),
  3659. this.update(!0)
  3660. }
  3661. function U(e, t) {
  3662. this.gl = e,
  3663. this.id = null,
  3664. this.type = e.TEXTURE_2D,
  3665. this.format = e.RGBA,
  3666. this.componentType = e.UNSIGNED_BYTE,
  3667. t = t || {},
  3668. this.desc = {
  3669. width: t.width || 1,
  3670. height: t.height || 1,
  3671. mipmap: t.mipmap,
  3672. clamp: t.clamp,
  3673. mirror: t.mirror,
  3674. aniso: t.aniso,
  3675. nofilter: t.nofilter
  3676. }
  3677. }
  3678. function N(e) {
  3679. this.gl = e,
  3680. this.cache = []
  3681. }
  3682. function z(e, t) {
  3683. this.name = "none",
  3684. this.debugString = "",
  3685. this.knobControlRect = new s(e),
  3686. this.controlRect = new s(e);
  3687. var i = document.createElement("div");
  3688. i.id = "sliderUI",
  3689. i.style.position = "absolute",
  3690. i.style.overflow = "hidden",
  3691. i.style["-moz-user-select"] = "none",
  3692. i.style["-khtml-user-select"] = "none",
  3693. i.style["-webkit-user-select"] = "none",
  3694. i.style["-ms-user-select"] = "none",
  3695. this.controlRect.linkedControl = i,
  3696. this.backgroundControl = 0,
  3697. this.controlRect.registerChildControlRect(this.knobControlRect),
  3698. this.knobControlRect.setOpacity(.65),
  3699. this.sliderPercent = this.pixelsY = this.pixelsX = 0,
  3700. this.draggingSlider = !1,
  3701. this.guiScreen = e,
  3702. t.addImageElement(this.knobControlRect, "animationknob" + e.imageSetNumber + "x.png")
  3703. }
  3704. function j(e) {
  3705. this.viewer = e,
  3706. this.stripData = e.stripData,
  3707. (e = this.container = document.createElement("div")).id = "fdageUI",
  3708. e.style.position = "absolute",
  3709. e.style.overflow = "hidden",
  3710. e.style["-moz-user-select"] = "none",
  3711. e.style["-khtml-user-select"] = "none",
  3712. e.style["-webkit-user-select"] = "none",
  3713. e.style["-ms-user-select"] = "none",
  3714. this.viewer.domRoot.appendChild(e),
  3715. this.guiScreen = new t(this)
  3716. }
  3717. R.prototype.resize = function (e) {
  3718. e.ui.viewer.scene.sceneAnimator.showPlayControls || (e.width = 1,
  3719. e.height = 1),
  3720. this.compactMode = e.width < this.minWidth;
  3721. var t = this.bottomOffset
  3722. , i = this.bottomOffset + 4
  3723. , s = 0;
  3724. this.cameraList && this.animationList ? s += 42 + this.cameraList.localPixelsX + this.animationList.localPixelsX : this.cameraList ? s += 28 + this.cameraList.localPixelsX : this.animationList && (s += 28 + this.animationList.localPixelsX);
  3725. var n = e.width - s - 72;
  3726. 0 == s && (n -= 14);
  3727. var r = 116
  3728. , a = r + n + 14;
  3729. this.compactMode && (r = 58,
  3730. n += 44 + s,
  3731. 0 < s && (t += 32),
  3732. s || (i += 32));
  3733. var o = (s = 32 / n) + 14 / n
  3734. , h = 1 - o
  3735. , l = this.playbackRegion;
  3736. l.controlRect.widthPercent = n / e.width,
  3737. l.controlRect.heightPercent = 32 / e.height,
  3738. l.controlRect.xPercent = r / e.width,
  3739. l.controlRect.yPercent = t / e.height,
  3740. this.pauseButton.controlRect.set(0, .125, s, .75),
  3741. this.playButton.controlRect.set(0, .125, s, .75),
  3742. this.timelineSlider.controlRect.set(o, .03125, h, 1),
  3743. this.timelineSlider.setSize(n - 46, 32),
  3744. l.controlRect.updateElement(),
  3745. l.controlRect.updateChildElements(),
  3746. this.speedList.setControl(58, i, 44, 24, !1),
  3747. this.cameraList && (this.cameraList.setControl(a, i, 10, 24, !0, 8),
  3748. a += this.cameraList.localPixelsX + 14),
  3749. this.animationList && this.animationList.setControl(a, i, 10, 24, !0, 8),
  3750. this.timelineSlider.backgroundControl.alignBackground()
  3751. }
  3752. ,
  3753. R.prototype.setupCallbacks = function () {
  3754. var e = function (e) {
  3755. "0.01x" == this.speedList.selectedItemText && this.ui.viewer.scene.sceneAnimator.setPlaybackSpeed(.01),
  3756. "0.05x" == this.speedList.selectedItemText && this.ui.viewer.scene.sceneAnimator.setPlaybackSpeed(.05),
  3757. "0.25x" == this.speedList.selectedItemText && this.ui.viewer.scene.sceneAnimator.setPlaybackSpeed(.25),
  3758. "0.5x" == this.speedList.selectedItemText && this.ui.viewer.scene.sceneAnimator.setPlaybackSpeed(.5),
  3759. "1.0x" == this.speedList.selectedItemText && this.ui.viewer.scene.sceneAnimator.setPlaybackSpeed(1),
  3760. "2.0x" == this.speedList.selectedItemText && this.ui.viewer.scene.sceneAnimator.setPlaybackSpeed(2),
  3761. "4.0x" == this.speedList.selectedItemText && this.ui.viewer.scene.sceneAnimator.setPlaybackSpeed(4)
  3762. }
  3763. .bind(this)
  3764. , t = function (e) {
  3765. this.ui.viewer.scene.sceneAnimator.selectCamera(this.cameraList.selectedIndex),
  3766. this.ui.viewer.wake()
  3767. }
  3768. .bind(this)
  3769. , i = function (e) {
  3770. this.ui.viewer.scene.sceneAnimator.selectAnimation(this.animationList.selectedIndex),
  3771. this.ui.viewer.wake()
  3772. }
  3773. .bind(this);
  3774. this.speedList && (this.speedList.selectionChangedCallback = e),
  3775. this.cameraList && (this.cameraList.selectionChangedCallback = t),
  3776. this.animationList && (this.animationList.selectionChangedCallback = i),
  3777. this.playButton.controlRect.linkedControl.onclick = function () {
  3778. this.ui.viewer.scene.sceneAnimator.pause(!1),
  3779. this.playButton.controlRect.showControl(!1),
  3780. this.pauseButton.controlRect.showControl(!0),
  3781. this.ui.viewer.wake()
  3782. }
  3783. .bind(this),
  3784. this.pauseButton.controlRect.linkedControl.onclick = function () {
  3785. this.ui.viewer.scene.sceneAnimator.pause(!0),
  3786. this.playButton.controlRect.showControl(!0),
  3787. this.pauseButton.controlRect.showControl(!1)
  3788. }
  3789. .bind(this)
  3790. }
  3791. ,
  3792. A.prototype.prepareBloom = function (e) {
  3793. if (this.useBloom && this.bloomShader.complete() && this.shrinkShader.complete()) {
  3794. this.shrinkShader.bind(),
  3795. this.bloomTargets[1].bind(),
  3796. e.bind(this.shrinkShader.samplers.tInput),
  3797. this.fillScreen(this.shrinkShader.attribs.vCoord),
  3798. this.bloomShader.bind();
  3799. var t = [];
  3800. this.bloomTargets[0].bind(),
  3801. this.bloomTextures[1].bind(this.bloomShader.samplers.tInput);
  3802. for (var i = 0, s = 0; s < this.bloomSamples; ++s) {
  3803. var n, r = 2 * s / (this.bloomSamples - 1) - 1;
  3804. n = 4 * r,
  3805. i += n = Math.exp(-.5 * n * n / 1) / 2.50662827463,
  3806. t[4 * s + 0] = r * this.desc.bloomSize,
  3807. t[4 * s + 1] = 0,
  3808. t[4 * s + 2] = n,
  3809. t[4 * s + 3] = 0
  3810. }
  3811. for (s = 0; s < this.bloomSamples; ++s)
  3812. t[4 * s + 2] /= i;
  3813. for (this.gl.uniform4fv(this.bloomShader.params.uKernel, t),
  3814. this.fillScreen(this.bloomShader.attribs.vCoord),
  3815. this.bloomTargets[1].bind(),
  3816. this.bloomTextures[0].bind(this.bloomShader.samplers.tInput),
  3817. s = 0; s < this.bloomSamples; ++s)
  3818. i = t[4 * s + 0],
  3819. i *= e.desc.width / e.desc.height,
  3820. t[4 * s + 0] = 0,
  3821. t[4 * s + 1] = i;
  3822. this.gl.uniform4fv(this.bloomShader.params.uKernel, t),
  3823. this.fillScreen(this.bloomShader.attribs.vCoord),
  3824. this.bloomResult = this.bloomTextures[1]
  3825. } else
  3826. this.bloomResult = this.blackTexture
  3827. }
  3828. ,
  3829. A.prototype.computeParams = function (e, t) {
  3830. var i = this.desc
  3831. , s = {};
  3832. s.scale = [i.contrast[0] * i.contrast[3], i.contrast[1] * i.contrast[3], i.contrast[2] * i.contrast[3]],
  3833. s.bias = [i.bias[0] * i.bias[3], i.bias[1] * i.bias[3], i.bias[2] * i.bias[3]],
  3834. s.bias = [-s.bias[0] * s.scale[0] + s.bias[0], -s.bias[1] * s.scale[1] + s.bias[1], -s.bias[2] * s.scale[2] + s.bias[2]];
  3835. var n = [i.brightness[0] * i.brightness[3], i.brightness[1] * i.brightness[3], i.brightness[2] * i.brightness[3]];
  3836. s.scale = [s.scale[0] * n[0], s.scale[1] * n[1], s.scale[2] * n[2]],
  3837. s.bias = [s.bias[0] * n[0], s.bias[1] * n[1], s.bias[2] * n[2]],
  3838. s.saturation = [i.saturation[0] * i.saturation[3], i.saturation[1] * i.saturation[3], i.saturation[2] * i.saturation[3]],
  3839. s.bloomColor = [i.bloomColor[0] * i.bloomColor[3], i.bloomColor[1] * i.bloomColor[3], i.bloomColor[2] * i.bloomColor[3]],
  3840. s.sharpen = [i.sharpen, .25 * i.sharpen, i.sharpenLimit],
  3841. s.sharpenKernel = [1 / e, 0, 0, 1 / t],
  3842. n = t < e ? e : t,
  3843. s.vignetteAspect = [e / n, t / n, .5 * e / n, .5 * t / n],
  3844. s.vignette = [2 * (1 - i.vignette[0]) * i.vignette[3], 2 * (1 - i.vignette[1]) * i.vignette[3], 2 * (1 - i.vignette[2]) * i.vignette[3], i.vignetteCurve];
  3845. n = 1 / this.noiseTexture.desc.width;
  3846. var r = 1 / this.noiseTexture.desc.height
  3847. , a = 1 - i.grainSharpness;
  3848. return s.grainCoord = [n * e, r * t, .5 * a * n, .5 * a * r],
  3849. s.grainScaleBias = [2 * i.grain, -i.grain],
  3850. s
  3851. }
  3852. ,
  3853. A.prototype.present = function (e, t, i, s) {
  3854. if (s || this.prepareBloom(e),
  3855. 1 < this.sampleCount && this.allocAABuffer(t, i),
  3856. (s = s ? this.plainShader : this.shader).bind()) {
  3857. var n = this.gl
  3858. , r = s.samplers
  3859. , a = s.params
  3860. , o = this.computeParams(t, i);
  3861. if (e.bind(r.tInput),
  3862. this.bloomResult.bind(r.tBloom),
  3863. this.noiseTexture.bind(r.tGrain),
  3864. this.colorLUT && this.colorLUT.bind(r.tLUT),
  3865. n.uniform3fv(a.uScale, o.scale),
  3866. n.uniform3fv(a.uBias, o.bias),
  3867. n.uniform3fv(a.uSaturation, o.saturation),
  3868. n.uniform4fv(a.uSharpenKernel, o.sharpenKernel),
  3869. n.uniform3fv(a.uSharpness, o.sharpen),
  3870. n.uniform3fv(a.uBloomColor, o.bloomColor),
  3871. n.uniform4fv(a.uVignetteAspect, o.vignetteAspect),
  3872. n.uniform4fv(a.uVignette, o.vignette),
  3873. n.uniform4fv(a.uGrainCoord, o.grainCoord),
  3874. n.uniform2fv(a.uGrainScaleBias, o.grainScaleBias),
  3875. e = 1 < this.sampleCount && 0 <= this.sampleIndex) {
  3876. var h = 1 / (1 + this.sampleIndex);
  3877. this.sampleIndex += 1,
  3878. h < 1 && (n.enable(n.BLEND),
  3879. n.blendColor(h, h, h, h),
  3880. n.blendFunc(n.CONSTANT_ALPHA, n.ONE_MINUS_CONSTANT_ALPHA)),
  3881. this.aaTarget.bind()
  3882. } else
  3883. m.bindNone(n),
  3884. 1 < this.sampleCount && (this.sampleIndex += 1);
  3885. n.viewport(0, 0, t, i),
  3886. this.fillScreen(s.attribs.vCoord),
  3887. e && (h < 1 && n.disable(n.BLEND),
  3888. m.bindNone(n),
  3889. this.aaShader.bind(),
  3890. this.aaBuffer.bind(this.aaShader.samplers.tInput),
  3891. this.fillScreen(this.aaShader.attribs.vCoord))
  3892. }
  3893. }
  3894. ,
  3895. A.prototype.allocAABuffer = function (e, t) {
  3896. this.aaBuffer && this.aaBuffer.desc.width == e && this.aaBuffer.desc.height == t || (this.aaBuffer && this.aaBuffer.destroy(),
  3897. this.aaBuffer = new U(this.gl, {
  3898. width: e,
  3899. height: t,
  3900. clamp: !0
  3901. }),
  3902. this.aaBuffer.loadArray(),
  3903. this.aaTarget = new m(this.gl, {
  3904. color0: this.aaBuffer,
  3905. ignoreStatus: !0
  3906. }))
  3907. }
  3908. ,
  3909. A.prototype.adjustProjectionForSupersampling = function (e) {
  3910. if (1 < this.sampleCount) {
  3911. var t = this.currentSample()
  3912. , i = this.sampleOffsets[t][0] / e.size[0];
  3913. t = this.sampleOffsets[t][1] / e.size[1],
  3914. i = S.translation(S.empty(), i, t, 0);
  3915. S.mul(e.projectionMatrix, i, e.projectionMatrix)
  3916. }
  3917. }
  3918. ,
  3919. A.prototype.discardAAHistory = function () {
  3920. this.sampleIndex = -1
  3921. }
  3922. ,
  3923. A.prototype.currentSample = function () {
  3924. return (this.sampleIndex < 0 ? 0 : this.sampleIndex) % this.sampleCount
  3925. }
  3926. ,
  3927. A.prototype.fillScreen = function (e) {
  3928. var t = this.gl;
  3929. t.bindBuffer(t.ARRAY_BUFFER, this.fullscreenTriangle),
  3930. t.enableVertexAttribArray(e),
  3931. t.vertexAttribPointer(e, 2, t.FLOAT, !1, 0, 0),
  3932. t.drawArrays(t.TRIANGLES, 0, 3),
  3933. t.disableVertexAttribArray(e),
  3934. t.bindBuffer(t.ARRAY_BUFFER, null)
  3935. }
  3936. ,
  3937. A.prototype.blitTexture = function (e) {
  3938. this.aaShader.bind(),
  3939. e.bind(this.aaShader.samplers.tInput),
  3940. this.fillScreen(this.aaShader.attribs.vCoord)
  3941. }
  3942. ,
  3943. k.prototype.load = function (e) {
  3944. var t, i = this.gl, s = e.extract("scene.json");
  3945. if (void 0 === s)
  3946. return !1;
  3947. if (!e.checkSignature(s))
  3948. return !1;
  3949. if (null == (s = new u(s.data).asString()) || s.length <= 0)
  3950. return !1;
  3951. try {
  3952. t = JSON.parse(s)
  3953. } catch (e) {
  3954. return console.error(e),
  3955. !1
  3956. }
  3957. for (var n in this.metaData = t.metaData,
  3958. this.view = new H(t.mainCamera.view),
  3959. this.sky = new _(this.gl, e, t.sky),
  3960. this.lights = new x(t.lights, this.view),
  3961. this.materialsList = [],
  3962. this.materials = {},
  3963. t.materials) {
  3964. var r = t.materials[n];
  3965. r.lightCount = this.lights.count,
  3966. r.shadowCount = this.lights.shadowCount,
  3967. s = new b(this.gl, e, r),
  3968. this.materials[r.name] = s,
  3969. this.materialsList.push(s)
  3970. }
  3971. if (t.meshes)
  3972. for (r = 0; r < t.meshes.length; ++r) {
  3973. n = t.meshes[r],
  3974. n = new T(this.gl, n, e.extract(n.file)),
  3975. this.meshes.push(n);
  3976. for (var a = 0; a < n.desc.subMeshes.length; ++a) {
  3977. var o = n.desc.subMeshes[a];
  3978. (s = this.materials[o.material]) && (n.numSubMeshes++,
  3979. this.meshRenderables.push(new w(n, o, s)))
  3980. }
  3981. }
  3982. return this.bounds = new d(this.meshes),
  3983. this.postRender = new A(this.gl, t.mainCamera.post, !0),
  3984. this.shadow = new E(i, this.lights.shadowCount),
  3985. this.cameras = t.Cameras,
  3986. t.AnimData && (this.sceneAnimator = new P(this, e, t.AnimData)),
  3987. t.fog && (this.fog = new f(i, t.fog)),
  3988. t.shadowFloor && (this.shadowFloor = new B(i, t.shadowFloor, this.shadow, this.lights)),
  3989. this.sceneLoaded = !0
  3990. }
  3991. ,
  3992. k.prototype.update = function () {
  3993. this.sceneAnimator && (this.frameCounter++,
  3994. this.lights.flagUpdateAnimatedLighting(),
  3995. this.sceneAnimator.drawAnimated && (1 == this.frameCounter ? this.sceneAnimator.resetPlayback() : this.sceneAnimator.updateAnimationPlayback())),
  3996. this.lights.update(this.view, this.bounds)
  3997. }
  3998. ,
  3999. k.prototype.collectShadows = function (e) {
  4000. this.shadow.collect(this, e)
  4001. }
  4002. ,
  4003. k.prototype.draw = function (e) {
  4004. var t = this.gl;
  4005. if (this.sceneLoaded) {
  4006. this.sky.setClearColor(),
  4007. t.clear(t.COLOR_BUFFER_BIT | t.DEPTH_BUFFER_BIT | t.STENCIL_BUFFER_BIT),
  4008. t.enable(t.DEPTH_TEST),
  4009. this.sky.draw(this),
  4010. this.shadowFloor && this.shadowFloor.draw(this);
  4011. for (var i = 0; i < this.meshRenderables.length; ++i)
  4012. this.meshRenderables[i].material.usesBlending || this.meshRenderables[i].material.usesRefraction || !this.meshRenderables[i].visible || this.meshRenderables[i].draw(this);
  4013. for (t.enable(t.POLYGON_OFFSET_FILL),
  4014. t.polygonOffset(1, 1),
  4015. t.colorMask(!1, !1, !1, !1),
  4016. i = 0; i < this.meshRenderables.length; ++i)
  4017. this.meshRenderables[i].drawAlphaPrepass(this);
  4018. for (t.colorMask(!0, !0, !0, !0),
  4019. t.disable(t.POLYGON_OFFSET_FILL),
  4020. t.depthFunc(t.LEQUAL),
  4021. t.depthMask(!1),
  4022. i = 0; i < this.meshRenderables.length; ++i)
  4023. this.meshRenderables[i].material.usesBlending && this.meshRenderables[i].visible && this.meshRenderables[i].draw(this);
  4024. t.disable(t.BLEND),
  4025. t.depthMask(!0),
  4026. t.depthFunc(t.LESS);
  4027. var s = !1;
  4028. for (i = 0; i < this.meshRenderables.length; ++i)
  4029. if (this.meshRenderables[i].material.usesRefraction) {
  4030. s = !0;
  4031. break
  4032. }
  4033. if (s)
  4034. for (this.refractionSurface && this.refractionSurface.desc.width == e.color0.desc.width && this.refractionSurface.desc.height == e.color0.desc.height || (this.refractionSurface = new U(t, e.color0.desc),
  4035. this.refractionSurface.loadArray(null, e.color0.format, e.color0.componentType),
  4036. this.refractionBuffer = new m(this.gl, {
  4037. color0: this.refractionSurface
  4038. })),
  4039. this.refractionBuffer.bind(),
  4040. this.postRender.blitTexture(e.color0),
  4041. e.bind(),
  4042. i = 0; i < this.meshRenderables.length; ++i)
  4043. this.meshRenderables[i].material.usesRefraction && this.meshRenderables[i].visible && this.meshRenderables[i].draw(this);
  4044. if (this.stripData.activeWireframe() && 0 < this.meshRenderables.length) {
  4045. for (i = 0; i < this.meshRenderables.length; ++i)
  4046. this.meshRenderables[i].visible && this.meshRenderables[i].drawWire(this);
  4047. t.depthMask(!0)
  4048. }
  4049. t.disable(t.BLEND)
  4050. }
  4051. }
  4052. ,
  4053. k.prototype.drawSecondary = function (e) {
  4054. this.fog && this.fog.draw(this, e)
  4055. }
  4056. ,
  4057. k.prototype.complete = function () {
  4058. if (!this.sky.complete() || !this.shadow.complete() || this.fog && !this.fog.complete() || this.shadowFloor && !this.shadowFloor.complete())
  4059. return !1;
  4060. for (var e = 0; e < this.meshRenderables.length; ++e)
  4061. if (!this.meshRenderables[e].complete())
  4062. return !1;
  4063. return !0
  4064. }
  4065. ,
  4066. P.prototype.flagAllForDebugging = function () {
  4067. for (var e = this.animations.length, t = 0; t < e; t++)
  4068. for (var i = this.animations[t], s = i.animatedObjects.length, n = 0; n < s; n++)
  4069. i.animatedObjects[n].debugMe = !0
  4070. }
  4071. ,
  4072. P.prototype.checkDebug = function () {
  4073. this.debugString = "<br>--------------------------------------Debug Info:",
  4074. this.debugString += "<br>this.selectedAnimationIndex :" + this.selectedAnimationIndex;
  4075. var e = this.animations[this.selectedAnimationIndex]
  4076. , t = e.animatedObjects.length;
  4077. this.debugString += "<br>numAnimatedObjects :" + t,
  4078. "" != e.debugString && (this.debugString += "<br>--------------------------------------------------Got animation bug info:",
  4079. this.debugString += e.debugString,
  4080. this.showDebugInfo = this.stopEverything = !0,
  4081. e.debugString = "");
  4082. for (var i = 0; i < t; i++) {
  4083. var s = e.animatedObjects[i];
  4084. "" == s.debugString && "" == s.animatedLocalTransform.debugString || (this.debugString += "<br>--------------------------------------------------Got object bug info:",
  4085. this.debugString += s.debugString,
  4086. this.debugString += s.animatedLocalTransform.debugString,
  4087. this.showDebugInfo = this.stopEverything = !0,
  4088. s.debugString = "",
  4089. s.animatedLocalTransform.debugString = ""),
  4090. s.skinningRig && "" != s.skinningRig.debugString && (this.debugString += "<br>--------------------------------------------------Got skin rig info:",
  4091. this.debugString += s.skinningRig.debugString,
  4092. s.skinningRig.debugString = "",
  4093. this.showDebugInfo = this.stopEverything = !0)
  4094. }
  4095. this.debugString += "<br>--------------------------------------Done Debug Info:"
  4096. }
  4097. ,
  4098. P.prototype.logObjectInfo = function (e, t) {
  4099. var i = t * (o = this.animations[this.selectedAnimationIndex]).originalFPS;
  4100. if (e >= o.animatedObjects.length)
  4101. this.debugString += "object index " + e + " exceeds " + o.animatedObjects.length;
  4102. else {
  4103. var s = o.animatedObjects[e]
  4104. , n = o.animatedObjects[s.modelPartIndex]
  4105. , r = o.getObjectAnimationFramePercent(s, t)
  4106. , a = o.getObjectAnimationFramePercent(n, t);
  4107. this.debugString = "",
  4108. this.debugString += "<br>Object Name: " + s.name,
  4109. this.debugString += "<br>Object Type: " + s.sceneObjectType,
  4110. this.debugString += "<br>Object Index: " + s.id,
  4111. this.debugString += "<br>Part Index: " + s.modelPartIndex,
  4112. this.debugString += "<br>Part Scale: " + s.modelPartScale,
  4113. this.debugString += "<br>Mesh Index: " + s.meshIndex,
  4114. this.debugString += "<br>Light Index: " + s.lightIndex,
  4115. this.debugString += "<br>Deformer Index: " + s.skinningRigIndex,
  4116. this.debugString += "<br>Parent Index: " + s.parentIndex,
  4117. this.debugString += "<br>Scene time " + t,
  4118. this.debugString += "<br>Scene framepercent " + i,
  4119. this.debugString += "<br>Object looped framepercent " + r,
  4120. this.debugString += "<br>Model looped framepercent " + a,
  4121. this.debugString += "<br>Object Anim length " + s.animationLength,
  4122. this.debugString += "<br>Object Total frames " + s.totalFrames,
  4123. this.debugString += "<br>Object FPS " + s.modelPartFPS,
  4124. this.debugString += "<br>Model Part Anim length " + n.animationLength,
  4125. this.debugString += "<br>Model total frames " + n.totalFrames,
  4126. this.debugString += "<br>Model Part FPS " + n.modelPartFPS,
  4127. i = S.identity(),
  4128. o.getWorldTransform(s.id, t, i, this.sceneScale, !0),
  4129. this.debugString += s.debugString;
  4130. var o = i[0]
  4131. , h = (s = i[1],
  4132. n = i[2],
  4133. r = i[4],
  4134. a = i[5],
  4135. i[6])
  4136. , l = i[8]
  4137. , d = i[9];
  4138. i = i[10];
  4139. Math.sqrt(o * o + s * s + n * n),
  4140. Math.sqrt(r * r + a * a + h * h),
  4141. Math.sqrt(l * l + d * d + i * i)
  4142. }
  4143. }
  4144. ,
  4145. P.prototype.resetPlayback = function () {
  4146. this.startMS = Date.now(),
  4147. this.animationProgress = this.totalSeconds = 0,
  4148. this.setAnimationProgress(0, !0)
  4149. }
  4150. ,
  4151. P.prototype.pause = function (e) {
  4152. this.paused = e,
  4153. this.startMS = Date.now() - 1e3 * this.totalSeconds / (this.playbackSpeed * this.scenePlaybackSpeed)
  4154. }
  4155. ,
  4156. P.prototype.setAnimationProgress = function (e, t) {
  4157. var i = this.animations[this.selectedAnimationIndex];
  4158. this.animationProgress = e,
  4159. this.totalSeconds = i.totalSeconds * this.animationProgress,
  4160. this.totalSeconds -= 1 / i.originalFPS,
  4161. this.totalSeconds < 0 && (this.totalSeconds = 0),
  4162. this.startMS = Date.now() - 1e3 * this.totalSeconds / (this.playbackSpeed * this.scenePlaybackSpeed),
  4163. t && this.updateScene()
  4164. }
  4165. ,
  4166. P.prototype.setPlaybackSpeed = function (e) {
  4167. this.playbackSpeed = e,
  4168. this.startMS = Date.now() - 1e3 * this.totalSeconds / (this.playbackSpeed * this.scenePlaybackSpeed)
  4169. }
  4170. ,
  4171. P.prototype.resetCustomView = function () {
  4172. 0 <= this.selectedCameraIndex && this.selectedCameraIndex < this.views.length && (this.viewYawOffsets[this.selectedCameraIndex] = 0,
  4173. this.viewPitchOffsets[this.selectedCameraIndex] = 0,
  4174. this.scene.view.rotation[1] = this.views[this.selectedCameraIndex].rotation[1],
  4175. this.scene.view.rotation[0] = this.views[this.selectedCameraIndex].rotation[0],
  4176. this.setViewFromSelectedCamera())
  4177. }
  4178. ,
  4179. P.prototype.updateUserCamera = function () {
  4180. if (this.clearCacheForCameraChildren(),
  4181. 0 <= this.selectedCameraIndex && this.selectedCameraIndex < this.views.length && this.selectedAnimationIndex < this.animations.length) {
  4182. var e = this.cameraObjectIndices[this.selectedCameraIndex]
  4183. , t = this.animations[this.selectedAnimationIndex];
  4184. if (e < t.animatedObjects.length) {
  4185. var i = this.views[this.selectedCameraIndex]
  4186. , s = this.scene.view.rotation[1]
  4187. , n = this.scene.view.rotation[0]
  4188. , r = n - i.rotation[0];
  4189. this.viewYawOffsets[this.selectedCameraIndex] = s - i.rotation[1],
  4190. this.viewPitchOffsets[this.selectedCameraIndex] = r,
  4191. i = t.animatedObjects[e],
  4192. t.getObjectAnimationFramePercent(i, this.totalSeconds);
  4193. r = S.identity();
  4194. var a = S.identity();
  4195. i.useFixedWorldTransform = !1,
  4196. i.useFixedLocalTransform = !1,
  4197. i.animatedLocalTransform.lockTransform = !1,
  4198. i.animatedLocalTransform.clearCachedTransforms(),
  4199. i.cachedFrame0 = -1,
  4200. i.cachedFrame1 = -1,
  4201. i.cachedFrame2 = -1,
  4202. i.cachedFrame3 = -1,
  4203. i.cachedFrameUse0 = 0,
  4204. i.cachedFrameUse1 = 0,
  4205. i.cachedFrameUse2 = 0,
  4206. i.cachedFrameUse3 = 0,
  4207. t.getWorldTransform(e, this.totalSeconds, a, this.sceneScale, !1);
  4208. e = a[0];
  4209. var o = a[1]
  4210. , h = a[2]
  4211. , l = a[4]
  4212. , d = a[5]
  4213. , c = a[6]
  4214. , u = a[8]
  4215. , f = a[9]
  4216. , m = a[10];
  4217. e = Math.sqrt(e * e + o * o + h * h),
  4218. l = Math.sqrt(l * l + d * d + c * c),
  4219. d = Math.sqrt(u * u + f * f + m * m);
  4220. (c = -(this.scene.view.pivot[0] - a[12])) * u + (o = -(this.scene.view.pivot[1] - a[13])) * f + (a = -(this.scene.view.pivot[2] - a[14])) * m <= 0 && (s += 180),
  4221. s = S.rotation(S.empty(), s, 1),
  4222. n = S.rotation(S.empty(), n, 0),
  4223. S.mul(r, s, n),
  4224. n = Math.sqrt(c * c + o * o + a * a),
  4225. s = this.scene.view.pivot[1] + r[9] * n,
  4226. a = this.scene.view.pivot[2] + r[10] * n,
  4227. r[12] = this.scene.view.pivot[0] + r[8] * n,
  4228. r[13] = s,
  4229. r[14] = a,
  4230. n = S.identity(),
  4231. t.getWorldTransform(i.parentIndex, this.totalSeconds, n, this.sceneScale, !1),
  4232. t = S.identity(),
  4233. S.invert(t, n),
  4234. n = S.identity(),
  4235. S.mul(n, t, r),
  4236. n[12] /= this.sceneScale,
  4237. n[13] /= this.sceneScale,
  4238. n[14] /= this.sceneScale,
  4239. r[0] *= e,
  4240. r[1] *= e,
  4241. r[2] *= e,
  4242. r[4] *= l,
  4243. r[5] *= l,
  4244. r[6] *= l,
  4245. r[8] *= d,
  4246. r[9] *= d,
  4247. r[10] *= d,
  4248. i.setFixedWorldTransform(r),
  4249. i.setFixedLocalTransform(n)
  4250. }
  4251. }
  4252. }
  4253. ,
  4254. P.prototype.setViewFromSelectedCamera = function () {
  4255. if (0 <= this.selectedCameraIndex && this.selectedCameraIndex < this.views.length) {
  4256. var e = this.views[this.selectedCameraIndex]
  4257. , t = this.scene.view
  4258. , i = this.viewYawOffsets[this.selectedCameraIndex]
  4259. , s = this.viewPitchOffsets[this.selectedCameraIndex];
  4260. t.pivot[0] = e.pivot[0],
  4261. t.pivot[1] = e.pivot[1],
  4262. t.pivot[2] = e.pivot[2],
  4263. t.rotation[0] = e.rotation[0] + s,
  4264. t.rotation[1] = e.rotation[1] + i,
  4265. t.radius = e.radius,
  4266. t.nearPlane = e.nearPlane,
  4267. t.fov = e.fov,
  4268. t.saveResetView(),
  4269. t.updateProjection(),
  4270. t.updateView()
  4271. }
  4272. }
  4273. ,
  4274. P.prototype.selectDefaultCamera = function () {
  4275. if (-1 != this.defaultCameraGlobalIndex && 0 < this.animations.length)
  4276. for (var e = this.animations[0], t = e.cameraObjects.length, i = 0; i < t; i++)
  4277. if (e.cameraObjects[i].id == this.defaultCameraGlobalIndex)
  4278. return void (this.selectedCameraIndex = i);
  4279. this.selectedCameraIndex = 0
  4280. }
  4281. ,
  4282. P.prototype.updateAnimationPlayback = function () {
  4283. if (!this.stopEverything || !this.runDebugMode) {
  4284. var e = this.animations[this.selectedAnimationIndex];
  4285. if (this.updateUserCamera(),
  4286. this.paused || !this.playAnimations)
  4287. this.startMS = 0 < this.playbackSpeed ? Date.now() - 1e3 * this.totalSeconds / (this.playbackSpeed * this.scenePlaybackSpeed) : Date.now() - 1e3 * this.totalSeconds,
  4288. this.refreshTransformsOnly(),
  4289. this.runDebugMode && this.checkDebug(),
  4290. (e = this.scene.view).saveResetView(),
  4291. e.updateProjection(),
  4292. e.updateView();
  4293. else {
  4294. this.lockPlayback && 0 < this.playbackSpeed && (this.startMS = Date.now() - 1e3 * this.totalSeconds / (this.playbackSpeed * this.scenePlaybackSpeed));
  4295. var t = (Date.now() - this.startMS) / 1e3 * this.playbackSpeed * this.scenePlaybackSpeed;
  4296. this.totalSeconds = (Date.now() - this.startMS) / 1e3 * this.playbackSpeed * this.scenePlaybackSpeed;
  4297. var i = (i = t / e.totalSeconds) - (t = Math.floor(i));
  4298. t != this.loopCount && (this.loopCount++,
  4299. this.loopTurntables && this.rolloverTurntables(),
  4300. this.autoAdvanceNextAnimation && (this.nextAnimation(),
  4301. this.resetPlayback())),
  4302. this.totalSeconds = e.totalSeconds * i,
  4303. this.animationProgress = this.totalSeconds / e.totalSeconds - Math.floor(this.totalSeconds / e.totalSeconds),
  4304. this.updateScene(),
  4305. this.runDebugMode && this.checkDebug()
  4306. }
  4307. }
  4308. }
  4309. ,
  4310. P.prototype.updateScene = function () {
  4311. this.lastSceneFramePercent = this.totalSeconds * this.animations[this.selectedAnimationIndex].originalFPS,
  4312. 0 != this.fogObjectIndex && this.updateFog(),
  4313. this.animateTurntables && this.updateTurntables(),
  4314. this.animateMeshes && this.poseMeshes(),
  4315. this.animateLights && this.updateLights(),
  4316. this.animateMaterials && this.updateMaterials(),
  4317. this.animateVisibility && this.updateVisibility()
  4318. }
  4319. ,
  4320. P.prototype.findCameraChildren = function () {
  4321. for (var e = this.animations[0], t = e.animatedObjects.length, i = 0; i < t; i++)
  4322. e.hasParentTypeInHierarchy(e.animatedObjects[i], "CameraSO") && this.cameraChildrenIndices.push(i)
  4323. }
  4324. ,
  4325. P.prototype.findFixedTransforms = function () {
  4326. for (var e = this.animations.length, t = 0; t < e; t++)
  4327. for (var i = this.animations[t], s = i.animatedObjects.length, n = 0; n < s; n++) {
  4328. var r = i.animatedObjects[n];
  4329. if (!r.useFixedWorldTransform && !i.hasAnimationInHierarchy(r))
  4330. if ("Material" == r.sceneObjectType)
  4331. r.setFixedWorldTransform(S.identity()),
  4332. r.setFixedLocalTransform(S.identity());
  4333. else {
  4334. var a = S.identity()
  4335. , o = S.identity();
  4336. i.hasParentTypeInHierarchy(r, "SceneRootSO") ? (i.getWorldTransform(r.id, 0, a, this.sceneScale, !1),
  4337. r.evaluateLocalTransformAtFramePercent(0, o, !0, !1)) : (i.evaluateModelPartTransformAtFrame(r.id, 0, a, !1),
  4338. r.evaluateLocalTransformAtFramePercent(0, o, !1, !1)),
  4339. r.setFixedWorldTransform(a),
  4340. r.setFixedLocalTransform(o)
  4341. }
  4342. }
  4343. }
  4344. ,
  4345. P.prototype.clearCacheForCameraChildren = function () {
  4346. for (var e = this.animations[this.selectedAnimationIndex], t = this.cameraChildrenIndices.length, i = 0; i < t; i++) {
  4347. var s = e.animatedObjects[this.cameraChildrenIndices[i]];
  4348. s.useFixedWorldTransform = !1,
  4349. s.useFixedLocalTransform = !1,
  4350. s.cachedFrame0 = -10,
  4351. s.cachedFrame1 = -10,
  4352. s.cachedFrame2 = -10,
  4353. s.cachedFrame3 = -10,
  4354. s.cachedFrameUse0 = 0,
  4355. s.cachedFrameUse1 = 0,
  4356. s.cachedFrameUse2 = 0,
  4357. s.cachedFrameUse3 = 0,
  4358. s.animatedLocalTransform.clearCachedTransforms(),
  4359. s.animatedLocalTransform.lockTransform = !1
  4360. }
  4361. }
  4362. ,
  4363. P.prototype.refreshTransformsOnly = function () {
  4364. for (var e = this.animations[this.selectedAnimationIndex], t = e.meshObjects.length, i = 0; i < t; i++) {
  4365. var s = e.meshObjects[i];
  4366. if (e.getWorldTransform(s.id, this.totalSeconds, s.mesh.displayMatrix, this.sceneScale, !0),
  4367. this.enableSkinning && s.skinningRig && this.unitScaleSkinnedMeshes && !s.skinningRig.isRigidSkin) {
  4368. var n = (s = s.mesh.displayMatrix)[0]
  4369. , r = s[1]
  4370. , a = s[2]
  4371. , o = s[4]
  4372. , h = s[5]
  4373. , l = s[6]
  4374. , d = s[8]
  4375. , c = s[9]
  4376. , u = s[10];
  4377. d = ((n = Math.sqrt(n * n + r * r + a * a)) + (o = Math.sqrt(o * o + h * h + l * l)) + (d = Math.sqrt(d * d + c * c + u * u))) / 2;
  4378. s[0] /= d,
  4379. s[1] /= d,
  4380. s[2] /= d,
  4381. s[4] /= d,
  4382. s[5] /= d,
  4383. s[6] /= d,
  4384. s[8] /= d,
  4385. s[9] /= d,
  4386. s[10] /= d
  4387. }
  4388. }
  4389. if (this.animateLights)
  4390. for (t = e.lightObjects.length,
  4391. i = 0; i < t; i++)
  4392. (s = e.lightObjects[i]).useFixedWorldTransform || (d = this.scene.lights.getLightPos(s.lightIndex),
  4393. c = this.scene.lights.getLightDir(s.lightIndex),
  4394. u = S.identity(),
  4395. e.getWorldTransform(s.id, this.totalSeconds, u, this.sceneScale, !0),
  4396. c[0] = u[8],
  4397. c[1] = u[9],
  4398. c[2] = u[10],
  4399. 0 != d[3] && (d[0] = u[12],
  4400. d[1] = u[13],
  4401. d[2] = u[14],
  4402. this.scene.lights.setLightPos(s.lightIndex, d)),
  4403. this.scene.lights.setLightDir(s.lightIndex, c))
  4404. }
  4405. ,
  4406. P.prototype.findMeshIndexByPartIndex = function (e, t) {
  4407. for (var i = 0; i < this.meshIDs.length; ++i)
  4408. if (t == this.meshIDs[i])
  4409. return i;
  4410. return -1
  4411. }
  4412. ,
  4413. P.prototype.findLightIndexByPartIndex = function (e) {
  4414. for (var t = 0; t < this.lightIDs.length; t++)
  4415. if (e == this.lightIDs[t])
  4416. return t;
  4417. return -1
  4418. }
  4419. ,
  4420. P.prototype.findMaterialIndexByPartIndex = function (e) {
  4421. for (var t = 0; t < this.materialIDs.length; t++)
  4422. if (e == this.materialIDs[t])
  4423. return t;
  4424. return -1
  4425. }
  4426. ,
  4427. P.prototype.nextAnimation = function () {
  4428. this.selectedAnimationIndex++,
  4429. this.selectedAnimationIndex >= this.animations.length && (this.selectedAnimationIndex = 0)
  4430. }
  4431. ,
  4432. P.prototype.selectAnimation = function (e) {
  4433. 0 <= e && e < this.animations.length && (this.selectedAnimationIndex = e),
  4434. this.paused && this.setAnimationProgress(this.animationProgress, !0)
  4435. }
  4436. ,
  4437. P.prototype.selectCamera = function (e) {
  4438. -1 != e && this.selectedCameraIndex != e && (this.selectedCameraIndex = e,
  4439. this.setViewFromSelectedCamera())
  4440. }
  4441. ,
  4442. P.prototype.getAnimatedCamera = function () {
  4443. if (0 <= this.selectedCameraIndex && this.selectedAnimationIndex < this.animations.length) {
  4444. var e = this.animations[this.selectedAnimationIndex];
  4445. if (this.selectedCameraIndex < e.cameraObjects.length)
  4446. return e.cameraObjects[this.selectedCameraIndex]
  4447. }
  4448. }
  4449. ,
  4450. P.prototype.poseMeshes = function () {
  4451. for (var e = this.animations[this.selectedAnimationIndex], t = e.meshObjects.length, i = 0; i < t; i++) {
  4452. var s = e.meshObjects[i];
  4453. if (this.enableSkinning && s.skinningRig)
  4454. if (s.skinningRig.isRigidSkin)
  4455. e.getWorldTransform(s.id, this.totalSeconds, s.mesh.displayMatrix, this.sceneScale, !0);
  4456. else {
  4457. s.setupSkinningRig(e, s.modelPartIndex, this.totalSeconds, s.skinningRig),
  4458. e.getWorldTransform(s.id, this.totalSeconds, s.mesh.displayMatrix, this.sceneScale, !0);
  4459. var n = s.modelPartScale * this.sceneScale;
  4460. if (this.unitScaleSkinnedMeshes) {
  4461. var r = s.mesh.displayMatrix
  4462. , a = r[0]
  4463. , o = r[1]
  4464. , h = r[2]
  4465. , l = r[4]
  4466. , d = r[5]
  4467. , c = r[6]
  4468. , u = r[8]
  4469. , f = r[9]
  4470. , m = r[10];
  4471. u = ((a = Math.sqrt(a * a + o * o + h * h)) + (l = Math.sqrt(l * l + d * d + c * c)) + (u = Math.sqrt(u * u + f * f + m * m))) / 2;
  4472. r[0] /= u,
  4473. r[1] /= u,
  4474. r[2] /= u,
  4475. r[4] /= u,
  4476. r[5] /= u,
  4477. r[6] /= u,
  4478. r[8] /= u,
  4479. r[9] /= u,
  4480. r[10] /= u,
  4481. n *= u
  4482. }
  4483. s.skinningRig.deformMesh(s.mesh, n)
  4484. }
  4485. else
  4486. e.getWorldTransform(s.id, this.totalSeconds, s.mesh.displayMatrix, this.sceneScale, !0)
  4487. }
  4488. }
  4489. ,
  4490. P.prototype.updateLights = function () {
  4491. for (var e = this.animations[this.selectedAnimationIndex], t = this.totalSeconds * e.originalFPS, i = e.lightObjects.length, s = 0; s < i; s++) {
  4492. var n = e.lightObjects[s]
  4493. , r = this.scene.lights.getLightPos(n.lightIndex)
  4494. , a = this.scene.lights.getLightDir(n.lightIndex)
  4495. , o = this.scene.lights.getLightColor(n.lightIndex)
  4496. , h = S.identity()
  4497. , l = 1;
  4498. n.useFixedWorldTransform || e.getWorldTransform(n.id, this.totalSeconds, h, this.sceneScale, !0),
  4499. n.redProperty && (n.redProperty.evaluate(t, o[0], n),
  4500. o[0] = n.redProperty.lastValue),
  4501. n.greenProperty && (n.greenProperty.evaluate(t, o[1], n),
  4502. o[1] = n.greenProperty.lastValue),
  4503. n.blueProperty && (n.blueProperty.evaluate(t, o[2], n),
  4504. o[2] = n.blueProperty.lastValue),
  4505. n.brightnessProperty && (n.brightnessProperty.evaluate(t, l, n),
  4506. l = n.brightnessProperty.lastValue),
  4507. o[0] *= l,
  4508. o[1] *= l,
  4509. o[2] *= l,
  4510. 0 != r[3] && (n.useFixedWorldTransform || (r[0] = h[12],
  4511. r[1] = h[13],
  4512. r[2] = h[14],
  4513. this.scene.lights.setLightPos(n.lightIndex, r)),
  4514. n.spotAngleProperty && 0 < this.scene.lights.spot[3 * n.lightIndex] && (r = 0,
  4515. n.spotAngleProperty.evaluate(t, r, n),
  4516. r = n.spotAngleProperty.lastValue,
  4517. this.scene.lights.setLightSpotAngle(n.lightIndex, r)),
  4518. n.spotSharpnessProperty && (r = 0,
  4519. n.spotSharpnessProperty.evaluate(t, r, n),
  4520. r = n.spotSharpnessProperty.lastValue,
  4521. this.scene.lights.setLightSpotSharpness(n.lightIndex, r)),
  4522. n.distanceProperty && (r = 1,
  4523. n.distanceProperty.evaluate(t, r, n),
  4524. r = n.distanceProperty.lastValue * this.sceneScale,
  4525. this.scene.lights.setLightDistance(n.lightIndex, r))),
  4526. n.useFixedWorldTransform || (a[0] = h[8],
  4527. a[1] = h[9],
  4528. a[2] = h[10],
  4529. this.scene.lights.setLightDir(n.lightIndex, a)),
  4530. this.scene.lights.setLightColor(n.lightIndex, o)
  4531. }
  4532. }
  4533. ,
  4534. P.prototype.updateTurntables = function () {
  4535. for (var e = this.animations[this.selectedAnimationIndex], t = this.totalSeconds * e.originalFPS, i = e.turnTableObjects.length, s = 0; s < i; s++) {
  4536. var n = e.turnTableObjects[s];
  4537. n.spinProperty.evaluate(t, 0, n),
  4538. n.turnTableSpin = n.turnTableSpinOffset + n.spinProperty.lastValue * this.totalSeconds
  4539. }
  4540. }
  4541. ,
  4542. P.prototype.rolloverTurntables = function () {
  4543. for (var e = this.animations[this.selectedAnimationIndex], t = e.turnTableObjects.length, i = 0; i < t; i++) {
  4544. var s = e.turnTableObjects[i];
  4545. s.turnTableSpinOffset = s.turnTableSpin
  4546. }
  4547. }
  4548. ,
  4549. P.prototype.updateMaterials = function () {
  4550. for (var e = this.animations[this.selectedAnimationIndex], t = this.totalSeconds * e.originalFPS, i = e.materialObjects.length, s = 0; s < i; s++) {
  4551. var n = e.materialObjects[s];
  4552. n.offsetUProperty && (n.offsetUProperty.evaluate(t, 0, n),
  4553. this.scene.materialsList[n.materialIndex].uOffset = n.offsetUProperty.lastValue),
  4554. n.offsetVProperty && (n.offsetVProperty.evaluate(t, 0, n),
  4555. this.scene.materialsList[n.materialIndex].vOffset = n.offsetVProperty.lastValue),
  4556. n.emissiveProperty && 1 < n.emissiveProperty.numKeyframes && (n.emissiveProperty.evaluate(t, 0, n),
  4557. this.scene.materialsList[n.materialIndex].emissiveIntensity = n.emissiveProperty.lastValue)
  4558. }
  4559. }
  4560. ,
  4561. P.prototype.updateFog = function () {
  4562. var e = this.animations[this.selectedAnimationIndex]
  4563. , t = this.totalSeconds * e.originalFPS;
  4564. 0 <= this.fogObjectIndex && this.fogObjectIndex < e.animatedObjects.length && this.scene.fog && ((e = e.animatedObjects[this.fogObjectIndex]).redProperty && (this.scene.fog.desc.color[0] = e.redProperty.evaluate(t, this.scene.fog.desc.color[0], e)),
  4565. e.greenProperty && (this.scene.fog.desc.color[1] = e.greenProperty.evaluate(t, this.scene.fog.desc.color[1], e)),
  4566. e.blueProperty && (this.scene.fog.desc.color[2] = e.blueProperty.evaluate(t, this.scene.fog.desc.color[2], e)),
  4567. e.distanceProperty && (this.scene.fog.desc.distance = e.distanceProperty.evaluate(t, this.scene.fog.desc.distance, e)),
  4568. e.opacityProperty && (this.scene.fog.desc.opacity = e.opacityProperty.evaluate(t, this.scene.fog.desc.opacity, e)),
  4569. e.skyIllumProperty && (this.scene.fog.desc.skyIllum = e.skyIllumProperty.evaluate(t, this.scene.fog.desc.skyIllum, e)),
  4570. e.lightIllumProperty && (this.scene.fog.desc.lightIllum = e.lightIllumProperty.evaluate(t, this.scene.fog.desc.lightIllum, e)),
  4571. e.dispersionProperty && (this.scene.fog.desc.dispersion = e.dispersionProperty.evaluate(t, this.scene.fog.desc.dispersion, e)))
  4572. }
  4573. ,
  4574. P.prototype.updateVisibility = function () {
  4575. for (var e = this.animations[this.selectedAnimationIndex], t = this.subMeshObjectIndices.length, i = 0; i < t; i++) {
  4576. if (-1 != (n = this.subMeshLiveIndices[i])) {
  4577. var s = this.subMeshObjectIndices[i]
  4578. , n = this.scene.meshRenderables[n]
  4579. , r = e.getObjectAnimationFramePercent(e.animatedObjects[s], this.totalSeconds);
  4580. n.visible = e.isVisibleAtFramePercent(s, r)
  4581. }
  4582. }
  4583. }
  4584. ,
  4585. F.prototype.build = function (e, t) {
  4586. var i = this.gl;
  4587. this.program = i.createProgram(),
  4588. this.params = {},
  4589. this.samplers = {},
  4590. this.attribs = {};
  4591. var s = function (e) {
  4592. for (var t = "", i = e.indexOf("\n"), s = 0; -1 != i;)
  4593. t += ++s + ": ",
  4594. t += e.substring(0, i + 1),
  4595. i = (e = e.substring(i + 1, e.length)).indexOf("\n");
  4596. console.log(t)
  4597. }
  4598. , n = i.createShader(i.VERTEX_SHADER);
  4599. i.shaderSource(n, e),
  4600. i.compileShader(n),
  4601. i.getShaderParameter(n, i.COMPILE_STATUS) || (console.log(i.getShaderInfoLog(n)),
  4602. I.verboseErrors && s(e)),
  4603. i.attachShader(this.program, n),
  4604. n = i.createShader(i.FRAGMENT_SHADER),
  4605. i.shaderSource(n, t),
  4606. i.compileShader(n),
  4607. i.getShaderParameter(n, i.COMPILE_STATUS) || (console.log(i.getShaderInfoLog(n)),
  4608. I.verboseErrors && s(t)),
  4609. i.attachShader(this.program, n),
  4610. i.linkProgram(this.program),
  4611. i.getProgramParameter(this.program, i.LINK_STATUS) || console.log(i.getProgramInfoLog(this.program));
  4612. n = i.getProgramParameter(this.program, i.ACTIVE_UNIFORMS);
  4613. var r = 0;
  4614. for (s = 0; s < n; ++s) {
  4615. var a = i.getActiveUniform(this.program, s)
  4616. , o = a.name
  4617. , h = o.indexOf("[");
  4618. 0 <= h && (o = o.substring(0, h)),
  4619. h = i.getUniformLocation(this.program, a.name),
  4620. a.type == i.SAMPLER_2D || a.type == i.SAMPLER_CUBE ? this.samplers[o] = {
  4621. location: h,
  4622. unit: r++
  4623. } : this.params[o] = h
  4624. }
  4625. for (n = i.getProgramParameter(this.program, i.ACTIVE_ATTRIBUTES),
  4626. s = 0; s < n; ++s)
  4627. r = i.getActiveAttrib(this.program, s),
  4628. this.attribs[r.name] = i.getAttribLocation(this.program, r.name)
  4629. }
  4630. ,
  4631. F.prototype.bind = function () {
  4632. return !!this.program && (this.gl.useProgram(this.program),
  4633. !0)
  4634. }
  4635. ,
  4636. F.prototype.complete = function () {
  4637. return !!this.program
  4638. }
  4639. ,
  4640. O.prototype.fromURLs = function (e, t, i) {
  4641. var s = "";
  4642. if (i)
  4643. for (var n = 0; n < i.length; ++n)
  4644. s = i[n] + "\n" + s;
  4645. if (i = s + ":" + e + "|" + t,
  4646. void 0 !== (n = this.cache[i]))
  4647. return n;
  4648. function r() {
  4649. null != o && null != h && a.build(o, h)
  4650. }
  4651. var a = new F(this.gl)
  4652. , o = null
  4653. , h = null;
  4654. return this.fetch(e, function (e) {
  4655. o = s + e,
  4656. r()
  4657. }),
  4658. this.fetch(t, function (e) {
  4659. h = s + e,
  4660. r()
  4661. }),
  4662. this.cache[i] = a
  4663. }
  4664. ,
  4665. O.prototype.fetch = function (e, t) {
  4666. void 0 !== G ? void 0 !== G[e] ? this.resolveIncludes(new String(G[e]), t) : t("") : C.fetchText("src/shader/" + e, function (e) {
  4667. this.resolveIncludes(e, t)
  4668. }
  4669. .bind(this), function () {
  4670. t("")
  4671. })
  4672. }
  4673. ,
  4674. O.prototype.resolveIncludes = function (t, i) {
  4675. for (var r = [], a = !0, e = function (e, t, i, s, n) {
  4676. return a = !0,
  4677. r.push({
  4678. offset: n,
  4679. path: t.slice(1, t.length - 1)
  4680. }),
  4681. ""
  4682. }; a;)
  4683. a = !1,
  4684. t = t.replace(/#include\s((<[^>]+>)|("[^"]+"))/, e);
  4685. if (0 < r.length) {
  4686. var s = r.length;
  4687. for (e = 0; e < r.length; ++e)
  4688. this.fetch(r[e].path, function (e) {
  4689. if (this.src = e,
  4690. --s <= 0) {
  4691. for (e = r.length - 1; 0 <= e; --e)
  4692. t = t.substring(0, r[e].offset) + r[e].src + t.substring(r[e].offset);
  4693. i(t)
  4694. }
  4695. }
  4696. .bind(r[e]))
  4697. } else
  4698. i(t)
  4699. }
  4700. ,
  4701. E.prototype.bindDepthTexture = function (e, t) {
  4702. this.shadowCount > t && this.depthTextures[t].bind(e)
  4703. }
  4704. ,
  4705. E.prototype.collect = function (e, t) {
  4706. for (var i = this.gl, s = e.lights, n = s.shadowCount, r = s.modelViewBuffer, a = s.projectionBuffer, o = s.matrix, h = 0 != e.sceneAnimator, l = S.empty(), d = !1, c = 0; c < n; ++c)
  4707. if (s.shadowsNeedUpdate[c]) {
  4708. d = !(s.shadowsNeedUpdate[c] = 0),
  4709. S.mul(l, r.subarray(16 * c, 16 * (c + 1)), o),
  4710. S.mul(l, a.subarray(16 * c, 16 * (c + 1)), l),
  4711. this.depthTargets[c].bind(),
  4712. i.clearColor(1, 1, 1, 1),
  4713. i.clear(i.COLOR_BUFFER_BIT | i.DEPTH_BUFFER_BIT);
  4714. var u = this.shaderSolid;
  4715. u.bind(),
  4716. i.uniformMatrix4fv(u.params.uViewProjection, !1, l),
  4717. i.uniformMatrix4fv(u.params.uMeshTransform, !1, S.identity());
  4718. for (var f = 0; f < e.meshRenderables.length; ++f) {
  4719. var m = e.meshRenderables[f]
  4720. , p = m.material;
  4721. !m.mesh.desc.castShadows || !p.castShadows || 0 < p.shadowAlphaTest || (h && i.uniformMatrix4fv(u.params.uMeshTransform, !1, m.mesh.displayMatrix),
  4722. m.drawShadow(u.attribs.vPosition))
  4723. }
  4724. for ((u = this.shaderAlphaTest).bind(),
  4725. i.uniformMatrix4fv(u.params.uViewProjection, !1, l),
  4726. i.uniformMatrix4fv(u.params.uMeshTransform, !1, S.identity()),
  4727. f = 0; f < e.meshRenderables.length; ++f)
  4728. p = (m = e.meshRenderables[f]).material,
  4729. m.mesh.desc.castShadows && p.castShadows && 0 < p.shadowAlphaTest && (p.textures.albedo.bind(u.samplers.tAlbedo),
  4730. h && (i.uniform2f(u.params.uUVOffset, p.uOffset, p.vOffset),
  4731. i.uniformMatrix4fv(u.params.uMeshTransform, !1, m.mesh.displayMatrix)),
  4732. m.drawAlphaShadow(u.attribs.vPosition, u.attribs.vTexCoord))
  4733. }
  4734. d && (t.bind(),
  4735. i.enable(i.CULL_FACE),
  4736. i.cullFace(i.BACK))
  4737. }
  4738. ,
  4739. E.prototype.complete = function () {
  4740. return this.shaderSolid.complete() && this.shaderAlphaTest.complete()
  4741. }
  4742. ,
  4743. B.prototype.draw = function (e) {
  4744. var t = e.view
  4745. , i = e.lights
  4746. , s = e.shadow
  4747. , n = this.gl
  4748. , r = this.shader.params
  4749. , a = this.shader.samplers;
  4750. this.shader.bind(),
  4751. t = S.mul(S.empty(), t.projectionMatrix, t.viewMatrix),
  4752. S.mul(t, t, this.desc.transform),
  4753. n.uniformMatrix4fv(r.uModelViewProjectionMatrix, !1, t),
  4754. t = S.mul(S.empty(), i.matrix, this.desc.transform),
  4755. n.uniformMatrix4fv(r.uModelSkyMatrix, !1, t),
  4756. 0 < i.count && (n.uniform4fv(r.uLightPositions, i.positionBuffer),
  4757. n.uniform3fv(r.uLightDirections, i.directionBuffer),
  4758. n.uniform3fv(r.uLightColors, i.colors),
  4759. n.uniform3fv(r.uLightParams, i.parameters),
  4760. n.uniform3fv(r.uLightSpot, i.spot),
  4761. e = .392699 * e.postRender.currentSample(),
  4762. n.uniform2f(r.uShadowKernelRotation, .5 * Math.cos(e), .5 * Math.sin(e)),
  4763. 0 < i.shadowCount && (e = s.depthTextures[0].desc.width,
  4764. n.uniform2f(r.uShadowMapSize, e, 1 / e),
  4765. n.uniformMatrix4fv(r.uShadowMatrices, !1, i.finalTransformBuffer),
  4766. n.uniformMatrix4fv(r.uInvShadowMatrices, !1, i.inverseTransformBuffer),
  4767. n.uniform4fv(r.uShadowTexelPadProjections, i.shadowTexelPadProjections),
  4768. s.bindDepthTexture(a.tDepth0, 0),
  4769. s.bindDepthTexture(a.tDepth1, 1),
  4770. s.bindDepthTexture(a.tDepth2, 2))),
  4771. n.uniform3f(r.uShadowCatcherParams, this.desc.simple ? 1 : 0, this.desc.alpha, this.desc.edgeFade),
  4772. n.depthMask(!1),
  4773. n.enable(n.BLEND),
  4774. n.blendFunc(n.ZERO, n.SRC_COLOR),
  4775. i = this.shader.attribs.vPosition,
  4776. n.bindBuffer(n.ARRAY_BUFFER, this.quadGeom),
  4777. n.enableVertexAttribArray(i),
  4778. n.vertexAttribPointer(i, 3, n.FLOAT, !1, 0, 0),
  4779. n.drawArrays(n.TRIANGLES, 0, 6),
  4780. n.disableVertexAttribArray(i),
  4781. n.bindBuffer(n.ARRAY_BUFFER, null),
  4782. n.disable(n.BLEND),
  4783. n.depthMask(!0)
  4784. }
  4785. ,
  4786. B.prototype.complete = function () {
  4787. return this.shader.complete()
  4788. }
  4789. ,
  4790. L.prototype.solveAdditiveClusterTransform = function (e, t, i) {
  4791. t = S.identity();
  4792. var s = S.identity()
  4793. , n = S.identity();
  4794. S.mul(t, e, this.defaultClusterBaseTransform),
  4795. S.mul(s, this.defaultAssociateWorldTransformInvert, t),
  4796. S.mul(n, this.defaultAssociateWorldTransformInvert, s),
  4797. S.mul(i, this.defaultClusterWorldTransformInvert, n)
  4798. }
  4799. ,
  4800. L.prototype.solveSimpleClusterTransform = function (e, t, i) {
  4801. var s = S.identity()
  4802. , n = S.identity();
  4803. S.invert(n, t),
  4804. S.mul(s, n, e),
  4805. S.mul(i, s, this.defaultClusterBaseTransform)
  4806. }
  4807. ,
  4808. L.prototype.solveClusterTransformAtFrame = function (e, t, i, s) {
  4809. if (1 == this.linkMode) {
  4810. var n = S.identity();
  4811. t = S.identity(),
  4812. e.evaluateModelPartTransformAtFrame(this.linkObjectIndex, i, n, !1),
  4813. e.evaluateModelPartTransformAtFrame(this.associateObjectIndex, i, t, !1),
  4814. this.solveAdditiveClusterTransform(n, t, s)
  4815. } else {
  4816. n = S.identity();
  4817. var r = S.identity();
  4818. e.evaluateModelPartTransformAtFrame(this.linkObjectIndex, i, n, !1),
  4819. e.evaluateModelPartTransformAtFrame(t, i, r, !1),
  4820. this.solveSimpleClusterTransform(n, r, s)
  4821. }
  4822. }
  4823. ,
  4824. M.prototype.unpackUnitVectors = function (e, t, i, s) {
  4825. for (var n = 0; n < i; n++) {
  4826. var r = t[s * n]
  4827. , a = 32768 <= (o = t[s * n + 1]);
  4828. a && (o -= 32768);
  4829. var o, h = 1 - ((r = r / 32767.4 * 2 - 1) * r + (o = o / 32767.4 * 2 - 1) * o);
  4830. h = Math.sqrt(h),
  4831. h = isNaN(h) ? 0 : h;
  4832. a && (h = -h),
  4833. e[3 * n] = r,
  4834. e[3 * n + 1] = o,
  4835. e[3 * n + 2] = h
  4836. }
  4837. }
  4838. ,
  4839. M.prototype.copyOriginalVertices = function (e) {
  4840. if (!this.unTransformedVertices)
  4841. if (this.unTransformedVertices = new Float32Array(3 * e.vertexCount),
  4842. this.unTransformedNormals = new Float32Array(3 * e.vertexCount),
  4843. this.unTransformedTangents = new Float32Array(3 * e.vertexCount),
  4844. this.unTransformedBiTangents = new Float32Array(3 * e.vertexCount),
  4845. this.skinVertexWeights = new Float32Array(e.vertexCount),
  4846. this.skinVertexTransform4x3 = new Float32Array(12),
  4847. e.dynamicVertexData) {
  4848. var t = new Float32Array(e.dynamicVertexData.buffer);
  4849. new Uint8Array(e.dynamicVertexData.buffer);
  4850. var i = s = 0
  4851. , s = s + 12 + 8;
  4852. e.secondaryTexCoord && (s += 8);
  4853. var n = s
  4854. , r = s += 4
  4855. , a = (s = s + 4,
  4856. e.stride / 2);
  4857. s = new Uint8Array(e.dynamicVertexData.subarray(s)),
  4858. s = new Uint16Array(s.buffer),
  4859. n = new Uint8Array(e.dynamicVertexData.subarray(n)),
  4860. n = new Uint16Array(n.buffer),
  4861. r = new Uint8Array(e.dynamicVertexData.subarray(r)),
  4862. r = new Uint16Array(r.buffer);
  4863. for (this.unpackUnitVectors(this.unTransformedNormals, s, e.vertexCount, a),
  4864. this.unpackUnitVectors(this.unTransformedTangents, n, e.vertexCount, a),
  4865. this.unpackUnitVectors(this.unTransformedBiTangents, r, e.vertexCount, a),
  4866. a = 0; a < e.vertexCount; a++)
  4867. r = (e.stride * a + i) / 4,
  4868. this.unTransformedVertices[3 * a] = t[r],
  4869. this.unTransformedVertices[3 * a + 1] = t[r + 1],
  4870. this.unTransformedVertices[3 * a + 2] = t[r + 2]
  4871. } else
  4872. this.debugString += "<br>Can't init skinning rig - mesh buffer is not dynamic - rigid is " + this.isRigidSkin
  4873. }
  4874. ,
  4875. M.prototype.useOriginalMeshVertices = function (e) {
  4876. this.isRigidSkin ? this.debugString += "<br>useOriginalMeshVertices for rigid skin?" : this.copyOriginalVertices(e)
  4877. }
  4878. ,
  4879. M.prototype.deformMeshVertices = function (e, t) {
  4880. if (0 != this.skinningClusters.length && this.unTransformedVertices) {
  4881. var i, s = e.stride / 4, n = new Float32Array(e.dynamicVertexData.buffer), r = new Uint16Array(e.dynamicVertexData.buffer);
  4882. new Uint8Array(e.dynamicVertexData.buffer),
  4883. i = 20,
  4884. e.secondaryTexCoord && (i += 8);
  4885. var a = i
  4886. , o = i += 4;
  4887. i += 4;
  4888. for (var h = this.unTransformedVertices.length / 3, l = 0, d = 0; d < h; ++d) {
  4889. var c = d
  4890. , u = (c * e.stride + a) / 2
  4891. , f = (c * e.stride + o) / 2
  4892. , m = (c * e.stride + i) / 2
  4893. , p = this.linkMapCount[c];
  4894. (k = this.skinVertexTransform4x3)[this.skinVertexWeights[c] = 0] = 0,
  4895. k[1] = 0,
  4896. k[2] = 0,
  4897. k[3] = 0,
  4898. k[4] = 0,
  4899. k[5] = 0,
  4900. k[6] = 0,
  4901. k[7] = 0,
  4902. k[8] = 0,
  4903. k[9] = 0,
  4904. k[10] = 0,
  4905. k[11] = 0;
  4906. var g = this.linkMapWeights[l];
  4907. if (1 == p && 1 == g) {
  4908. var v = this.linkMapClusterIndices[l]
  4909. , x = (v = this.skinningClusters[v]).matrix;
  4910. k[0] = x[0],
  4911. k[1] = x[1],
  4912. k[2] = x[2],
  4913. k[3] = x[4],
  4914. k[4] = x[5],
  4915. k[5] = x[6],
  4916. k[6] = x[8],
  4917. k[7] = x[9],
  4918. k[8] = x[10],
  4919. k[9] = x[12],
  4920. k[10] = x[13],
  4921. k[11] = x[14],
  4922. this.skinVertexWeights[c] = 1
  4923. } else
  4924. for (var y = this.skinVertexWeights[c] = 0; y < p; y++)
  4925. g = this.linkMapWeights[l + y],
  4926. (v = this.linkMapClusterIndices[l + y]) < this.skinningClusters.length && (x = (v = this.skinningClusters[v]).matrix,
  4927. k[0] += g * x[0],
  4928. k[1] += g * x[1],
  4929. k[2] += g * x[2],
  4930. k[3] += g * x[4],
  4931. k[4] += g * x[5],
  4932. k[5] += g * x[6],
  4933. k[6] += g * x[8],
  4934. k[7] += g * x[9],
  4935. k[8] += g * x[10],
  4936. k[9] += g * x[12],
  4937. k[10] += g * x[13],
  4938. k[11] += g * x[14],
  4939. this.skinVertexWeights[c] += g,
  4940. 1 == v.linkMode && (this.skinVertexWeights[c] = 1));
  4941. if (l += this.linkMapCount[d],
  4942. 0 < this.skinVertexWeights[c]) {
  4943. var b = this.unTransformedVertices[3 * d + 0]
  4944. , S = this.unTransformedVertices[3 * d + 1]
  4945. , T = this.unTransformedVertices[3 * d + 2]
  4946. , w = this.unTransformedNormals[3 * d + 0]
  4947. , C = this.unTransformedNormals[3 * d + 1]
  4948. , R = this.unTransformedNormals[3 * d + 2]
  4949. , A = (v = this.unTransformedTangents[3 * d + 0],
  4950. x = this.unTransformedTangents[3 * d + 1],
  4951. this.unTransformedTangents[3 * d + 2])
  4952. , k = (p = this.unTransformedBiTangents[3 * d + 0],
  4953. this.unTransformedBiTangents[3 * d + 1])
  4954. , I = (g = this.unTransformedBiTangents[3 * d + 2],
  4955. y = this.skinVertexTransform4x3,
  4956. 1);
  4957. 0 < this.skinVertexWeights[c] && (I = 1 / this.skinVertexWeights[c]),
  4958. n[s * d] = I * (b * y[0] + S * y[3] + T * y[6] + y[9]) * t,
  4959. n[s * d + 1] = I * (b * y[1] + S * y[4] + T * y[7] + y[10]) * t,
  4960. n[s * d + 2] = I * (b * y[2] + S * y[5] + T * y[8] + y[11]) * t,
  4961. b = w * y[0] + C * y[3] + R * y[6],
  4962. c = w * y[1] + C * y[4] + R * y[7],
  4963. w = w * y[2] + C * y[5] + R * y[8],
  4964. C = v * y[0] + x * y[3] + A * y[6],
  4965. R = v * y[1] + x * y[4] + A * y[7],
  4966. v = v * y[2] + x * y[5] + A * y[8],
  4967. x = p * y[0] + k * y[3] + g * y[6],
  4968. A = p * y[1] + k * y[4] + g * y[7],
  4969. p = p * y[2] + k * y[5] + g * y[8],
  4970. c /= k = Math.sqrt(b * b + c * c + w * w),
  4971. w /= k,
  4972. k = 32767.4 * ((b /= k) / 2 + .5),
  4973. g = 32767.4 * (c / 2 + .5),
  4974. w < 0 && (g += 32768),
  4975. r[m] = Math.floor(k),
  4976. r[1 + m] = Math.floor(g),
  4977. R /= k = Math.sqrt(C * C + R * R + v * v),
  4978. v /= k,
  4979. k = 32767.4 * ((C /= k) / 2 + .5),
  4980. g = 32767.4 * (R / 2 + .5),
  4981. v < 0 && (g += 32768),
  4982. r[u] = Math.floor(k),
  4983. r[1 + u] = Math.floor(g),
  4984. A /= k = Math.sqrt(x * x + A * A + p * p),
  4985. p /= k,
  4986. k = 32767.4 * ((x /= k) / 2 + .5),
  4987. g = 32767.4 * (A / 2 + .5),
  4988. p < 0 && (g += 32768),
  4989. r[f] = Math.floor(k),
  4990. r[1 + f] = Math.floor(g)
  4991. } else
  4992. b = this.unTransformedVertices[3 * d + 0],
  4993. S = this.unTransformedVertices[3 * d + 1],
  4994. T = this.unTransformedVertices[3 * d + 2],
  4995. n[s * d] = b * t,
  4996. n[s * d + 1] = S * t,
  4997. n[s * d + 2] = T * t
  4998. }
  4999. }
  5000. }
  5001. ,
  5002. M.prototype.deformMesh = function (e, t) {
  5003. if (0 != this.skinningClusters.length && !this.isRigidSkin) {
  5004. this.deformMeshVertices(e, t);
  5005. var i = e.gl;
  5006. i.bindBuffer(i.ARRAY_BUFFER, e.vertexBuffer),
  5007. i.bufferData(i.ARRAY_BUFFER, e.dynamicVertexData, i.DYNAMIC_DRAW),
  5008. i.bindBuffer(i.ARRAY_BUFFER, null)
  5009. }
  5010. }
  5011. ,
  5012. _.prototype.setClearColor = function () {
  5013. if (I.transparentBackground)
  5014. this.gl.clearColor(0, 0, 0, 0);
  5015. else if (this.backgroundMode < 1) {
  5016. var e = this.backgroundColor;
  5017. this.gl.clearColor(e[0], e[1], e[2], 1)
  5018. } else
  5019. this.gl.clearColor(.0582, .06772, .07805, 1)
  5020. }
  5021. ,
  5022. _.prototype.draw = function (e) {
  5023. if (this.backgroundMode < 1 || I.transparentBackground)
  5024. return !1;
  5025. if (this.complete()) {
  5026. var t = this.gl
  5027. , i = this.backgroundShader
  5028. , s = e.view
  5029. , n = e.lights.invMatrix;
  5030. i.bind(),
  5031. t.uniformMatrix4fv(i.params.uInverseSkyMatrix, !1, n),
  5032. t.uniformMatrix4fv(i.params.uViewProjection, !1, s.viewProjectionMatrix),
  5033. 3 == this.backgroundMode ? t.uniform4fv(i.params.uSkyCoefficients, this.backgroundCoefficients) : this.backgroundTexture.bind(i.samplers.tSkyTexture),
  5034. e = .07 + .94 * (1 - e.stripData.activeFade()),
  5035. t.uniform1f(i.params.uAlpha, e),
  5036. t.bindBuffer(t.ARRAY_BUFFER, this.vertexBuffer),
  5037. t.enableVertexAttribArray(i.attribs.vPosition),
  5038. t.vertexAttribPointer(i.attribs.vPosition, 3, t.FLOAT, !1, 20, 0),
  5039. t.enableVertexAttribArray(i.attribs.vTexCoord),
  5040. t.vertexAttribPointer(i.attribs.vTexCoord, 2, t.FLOAT, !1, 20, 12),
  5041. t.bindBuffer(t.ELEMENT_ARRAY_BUFFER, this.indexBuffer),
  5042. e < 1 && (t.enable(t.BLEND),
  5043. t.blendFunc(t.SRC_ALPHA, t.ONE_MINUS_SRC_ALPHA)),
  5044. t.depthMask(!1),
  5045. t.disable(t.DEPTH_TEST),
  5046. t.drawElements(t.TRIANGLES, this.skyIndexCount, t.UNSIGNED_SHORT, 0),
  5047. t.enable(t.DEPTH_TEST),
  5048. t.depthMask(!0),
  5049. e < 1 && t.disable(t.BLEND),
  5050. t.disableVertexAttribArray(i.attribs.vPosition),
  5051. t.disableVertexAttribArray(i.attribs.vTexCoord)
  5052. }
  5053. }
  5054. ,
  5055. _.prototype.complete = function () {
  5056. return !(this.backgroundShader && !this.backgroundShader.complete()) && this.specularTexture.complete()
  5057. }
  5058. ,
  5059. D.expDecay = function (e, t) {
  5060. return Math.exp(-.69314718 / e * t)
  5061. }
  5062. ,
  5063. D.prototype.update = function (e) {
  5064. var t = .001 * (Date.now() - this.timestamp);
  5065. this.timestamp = Date.now();
  5066. for (var i = !1, s = 0; s < this.stripCount; ++s) {
  5067. var n = this.selectedStrip == this.STRIP_MENU ? .3 * (s + 1) - .9 : this.selectedStrip < 0 || s < this.selectedStrip ? -2 : 2;
  5068. if (e)
  5069. this.strips[s] = n;
  5070. else {
  5071. var r = (r = n - this.strips[s]) * D.expDecay(.05, t);
  5072. this.animationActive && (this.strips[s] = n - r),
  5073. i = i || .001 < Math.abs(r)
  5074. }
  5075. }
  5076. this.animationActive = i
  5077. }
  5078. ,
  5079. D.prototype.active = function () {
  5080. return this.selectedStrip >= this.STRIP_MENU
  5081. }
  5082. ,
  5083. D.prototype.activeFade = function () {
  5084. var e;
  5085. return (e = 1 < (e = (this.strips[this.stripCount - 1] - -2) / (.3 * this.stripCount - .9 - -2)) ? 1 : e) < 0 ? 0 : e
  5086. }
  5087. ,
  5088. D.prototype.activeWireframe = function () {
  5089. return this.active() && .01 < Math.abs(this.strips[4] - this.strips[3])
  5090. }
  5091. ,
  5092. D.prototype.toggleMenu = function () {
  5093. this.selectedStrip = this.selectedStrip == this.STRIP_MENU ? this.STRIP_NONE : this.STRIP_MENU
  5094. }
  5095. ,
  5096. D.prototype.selectStrip = function (e, t) {
  5097. if (this.selectedStrip == this.STRIP_MENU) {
  5098. var i = e + t * this.stripSlant;
  5099. this.selectedStrip = this.STRIP_NONE;
  5100. for (var s = 0; s < this.stripCount; ++s)
  5101. if (i < this.strips[s]) {
  5102. this.selectedStrip = s;
  5103. break
  5104. }
  5105. } else
  5106. this.selectedStrip = this.STRIP_MENU
  5107. }
  5108. ,
  5109. U.prototype.loadImage = function (e, t) {
  5110. var i = this.gl;
  5111. e && e.width && e.height && (this.desc.width = e.width,
  5112. this.desc.height = e.height),
  5113. this.id = i.createTexture(),
  5114. i.bindTexture(this.type, this.id),
  5115. this.format = t || i.RGBA,
  5116. this.componentType = i.UNSIGNED_BYTE,
  5117. i.pixelStorei(i.UNPACK_FLIP_Y_WEBGL, !0),
  5118. i.texImage2D(this.type, 0, this.format, this.format, this.componentType, e),
  5119. this.setParams(),
  5120. i.bindTexture(this.type, null)
  5121. }
  5122. ,
  5123. U.prototype.loadArray = function (e, t, i) {
  5124. var s = this.gl;
  5125. this.id = s.createTexture(),
  5126. s.bindTexture(this.type, this.id),
  5127. this.format = t || s.RGBA,
  5128. this.componentType = i || s.UNSIGNED_BYTE,
  5129. s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL, !0),
  5130. s.texImage2D(this.type, 0, this.format, this.desc.width, this.desc.height, 0, this.format, this.componentType, e || null),
  5131. this.setParams(),
  5132. s.bindTexture(this.type, null)
  5133. }
  5134. ,
  5135. U.prototype.setParams = function () {
  5136. var e = this.gl
  5137. , t = function (e) {
  5138. return 0 < e && 0 == (e & e - 1)
  5139. };
  5140. t(this.desc.width) && t(this.desc.height) || (this.desc.clamp = !0,
  5141. this.desc.mipmap = !1),
  5142. t = !this.desc.nofilter,
  5143. this.desc.mipmap ? (e.generateMipmap(this.type),
  5144. e.texParameteri(this.type, e.TEXTURE_MIN_FILTER, t ? e.LINEAR_MIPMAP_LINEAR : e.NEAREST_MIPMAP_NEAREST)) : e.texParameteri(this.type, e.TEXTURE_MIN_FILTER, t ? e.LINEAR : e.NEAREST),
  5145. e.texParameteri(this.type, e.TEXTURE_MAG_FILTER, t ? e.LINEAR : e.NEAREST),
  5146. (this.desc.clamp || this.desc.mirror) && (t = this.desc.clamp ? e.CLAMP_TO_EDGE : e.MIRRORED_REPEAT,
  5147. e.texParameteri(this.type, e.TEXTURE_WRAP_S, t),
  5148. e.texParameteri(this.type, e.TEXTURE_WRAP_T, t)),
  5149. this.desc.aniso && e.ext.textureAniso && e.texParameteri(this.type, e.ext.textureAniso.TEXTURE_MAX_ANISOTROPY_EXT, this.desc.aniso)
  5150. }
  5151. ,
  5152. U.prototype.rebuildMips = function () {
  5153. this.desc.mipmap && (this.gl.bindTexture(this.type, this.id),
  5154. this.gl.generateMipmap(this.type))
  5155. }
  5156. ,
  5157. U.prototype.copyColorBuffer = function () {
  5158. this.gl.bindTexture(this.type, this.id),
  5159. this.gl.copyTexSubImage2D(this.type, 0, 0, 0, 0, 0, this.desc.width, this.desc.height)
  5160. }
  5161. ,
  5162. U.prototype.bind = function (e) {
  5163. if (e) {
  5164. var t = this.gl;
  5165. t.uniform1i(e.location, e.unit),
  5166. t.activeTexture(t.TEXTURE0 + e.unit),
  5167. t.bindTexture(this.type, this.id)
  5168. }
  5169. }
  5170. ,
  5171. U.prototype.destroy = function () {
  5172. this.gl.deleteTexture(this.id),
  5173. this.id = null
  5174. }
  5175. ,
  5176. U.prototype.complete = function () {
  5177. return !!this.id
  5178. }
  5179. ,
  5180. N.prototype.fromURL = function (e, t) {
  5181. var i = this.cache[e];
  5182. if (void 0 !== i)
  5183. return i;
  5184. var s = new U(this.gl, t);
  5185. return C.fetchImage(e, function (e) {
  5186. s.loadImage(e)
  5187. }),
  5188. this.cache[e] = s
  5189. }
  5190. ,
  5191. N.prototype.fromFile = function (e, t) {
  5192. if (!e)
  5193. return null;
  5194. var i = this.cache[e.name];
  5195. if (void 0 !== i)
  5196. return i;
  5197. var s = new U(this.gl, t);
  5198. return this.cache[e.name] = s,
  5199. N.parseFile(e, function (e) {
  5200. s.loadImage(e),
  5201. N.closeImage(e)
  5202. }),
  5203. s
  5204. }
  5205. ,
  5206. N.prototype.fromFilesMergeAlpha = function (e, t, i) {
  5207. if (!t)
  5208. return this.fromFile(e, i);
  5209. var s = e.name + "|" + t.name
  5210. , n = this.cache[s];
  5211. if (void 0 !== n)
  5212. return n;
  5213. var r = this.gl;
  5214. this.blitShader || (this.blitShader = new F(this.gl),
  5215. this.blitShader.build("precision highp float; varying vec2 c; attribute vec2 pos; void main(){ gl_Position.xy = 2.0*pos-vec2(1.0); gl_Position.zw = vec2(0.5,1.0); c=pos; }", "precision highp float; varying vec2 c; uniform sampler2D tTex; void main(){ gl_FragColor=texture2D(tTex,c).rgbr; }"),
  5216. this.mergeVerts = r.createBuffer(),
  5217. r.bindBuffer(r.ARRAY_BUFFER, this.mergeVerts),
  5218. n = new Float32Array([0, 0, 2, 0, 0, 2]),
  5219. r.bufferData(r.ARRAY_BUFFER, n, r.STATIC_DRAW),
  5220. r.bindBuffer(r.ARRAY_BUFFER, null));
  5221. var a = function (e) {
  5222. this.blitShader.bind(),
  5223. e.bind(this.blitShader.samplers.tTex),
  5224. r.bindBuffer(r.ARRAY_BUFFER, this.mergeVerts),
  5225. r.enableVertexAttribArray(this.blitShader.attribs.pos),
  5226. r.vertexAttribPointer(this.blitShader.attribs.pos, 2, r.FLOAT, !1, 0, 0),
  5227. r.drawArrays(r.TRIANGLES, 0, 3),
  5228. r.disableVertexAttribArray(this.blitShader.attribs.pos),
  5229. r.bindBuffer(r.ARRAY_BUFFER, null)
  5230. }
  5231. .bind(this)
  5232. , o = new U(this.gl, i);
  5233. this.cache[s] = o;
  5234. var h = 0
  5235. , l = 0
  5236. , d = function () {
  5237. if (h && l) {
  5238. var e, t;
  5239. if (t = l.width * l.height > h.width * h.height ? (e = l.width,
  5240. l.height) : (e = h.width,
  5241. h.height),
  5242. o.desc.width = e,
  5243. o.desc.height = t,
  5244. e <= r.limits.viewportSizes[0] && t <= r.limits.viewportSizes[1]) {
  5245. var i = {
  5246. clamp: !0
  5247. };
  5248. h.width == e && h.height == t ? (o.loadImage(h, r.RGBA),
  5249. e = new m(r, {
  5250. color0: o,
  5251. ignoreStatus: !0
  5252. }),
  5253. N.closeImage(h)) : ((t = new U(r, i)).loadImage(h, r.RGB),
  5254. N.closeImage(h),
  5255. o.loadArray(null),
  5256. (e = new m(r, {
  5257. color0: o,
  5258. ignoreStatus: !0
  5259. })).bind(),
  5260. a(t),
  5261. t.destroy()),
  5262. (t = new U(r, i)).loadImage(l, r.RGB),
  5263. N.closeImage(l),
  5264. e.bind(),
  5265. r.colorMask(!1, !1, !1, !0),
  5266. a(t),
  5267. r.colorMask(!0, !0, !0, !0),
  5268. t.destroy(),
  5269. m.bindNone(r),
  5270. o.rebuildMips()
  5271. } else {
  5272. (i = document.createElement("canvas")).width = e,
  5273. i.height = t;
  5274. var s = i.getContext("2d");
  5275. for (s.drawImage(h, 0, 0),
  5276. N.closeImage(h),
  5277. i = s.getImageData(0, 0, e, t),
  5278. i = new Uint8Array(i.data.buffer, i.data.byteOffset, i.data.length),
  5279. s.drawImage(l, 0, 0),
  5280. N.closeImage(l),
  5281. s = s.getImageData(0, 0, e, t).data,
  5282. e = e * t * 4,
  5283. t = 0; t < e; t += 4)
  5284. i[t + 3] = s[t];
  5285. o.loadArray(i)
  5286. }
  5287. N.closeImage(l)
  5288. }
  5289. }
  5290. .bind(this);
  5291. return N.parseFile(e, function (e) {
  5292. h = e,
  5293. d()
  5294. }),
  5295. N.parseFile(t, function (e) {
  5296. l = e,
  5297. d()
  5298. }),
  5299. o
  5300. }
  5301. ,
  5302. N.parseFile = function (e, t, i) {
  5303. var s = i || new Image;
  5304. if ("undefined" != typeof URL && void 0 !== URL.createObjectURL) {
  5305. e = new Blob([e.data], {
  5306. type: e.type
  5307. });
  5308. var n = URL.createObjectURL(e);
  5309. s.onload = function () {
  5310. URL.revokeObjectURL(n),
  5311. t && t(s)
  5312. }
  5313. ,
  5314. s.src = n
  5315. } else {
  5316. e = new Blob([e.data], {
  5317. type: e.type
  5318. });
  5319. var r = new FileReader;
  5320. r.onload = function (e) {
  5321. s.src = r.result
  5322. }
  5323. ,
  5324. s.onload = function () {
  5325. t && t(s)
  5326. }
  5327. ,
  5328. r.readAsDataURL(e)
  5329. }
  5330. }
  5331. ,
  5332. N.closeImage = function (e) {
  5333. e && 256 < e.width * e.height && (e.onload = null,
  5334. e.onerror = null,
  5335. e.src = "data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs%3D")
  5336. }
  5337. ,
  5338. z.prototype.setBackground3x1 = function (e, t, i, s) {
  5339. var n = 8 / this.controlRect.getScreenHeight();
  5340. this.backgroundControl = e.addTextButton("", 0, (1 - n) / 2, 1, n, 1),
  5341. this.backgroundControl.defaultAlpha = 1,
  5342. this.backgroundControl.setBackground3x1(e, 0, 0, t, i, s, 4),
  5343. this.backgroundControl.controlRect.xPercent = this.controlRect.xPercent,
  5344. this.backgroundControl.controlRect.widthPercent = this.controlRect.widthPercent,
  5345. this.controlRect.linkedControl.style.zIndex = "3",
  5346. this.setupCallbacks()
  5347. }
  5348. ,
  5349. z.prototype.setSize = function (e, t) {
  5350. this.pixelsX = e;
  5351. var i = 24 / (this.pixelsY = t);
  5352. this.knobWidthPercent = 24 / e,
  5353. this.knobControlRect.xPercent = .5 - this.knobWidthPercent / 2,
  5354. this.knobControlRect.yPercent = (1 - i) / 2 + -1 / t,
  5355. this.knobControlRect.widthPercent = this.knobWidthPercent,
  5356. this.knobControlRect.heightPercent = i,
  5357. this.controlRect.updateElement(),
  5358. this.backgroundControl.controlRect.xPercent = this.controlRect.xPercent,
  5359. this.backgroundControl.controlRect.widthPercent = this.controlRect.widthPercent,
  5360. this.backgroundControl.controlRect.updateElement()
  5361. }
  5362. ,
  5363. z.prototype.setSliderPercent = function (e) {
  5364. e < 0 && (e = 0),
  5365. 1 < e && (e = 1),
  5366. this.sliderPercent = e,
  5367. this.knobControlRect.xPercent = e - this.knobWidthPercent / 2,
  5368. this.knobControlRect.updateElement()
  5369. }
  5370. ,
  5371. z.prototype.setupCallbacks = function () {
  5372. var e = function (e) {
  5373. if (this.draggingSlider) {
  5374. var t = this.backgroundControl.controlRect.linkedControl.getBoundingClientRect();
  5375. this.setSliderPercent((e.clientX - t.left) / t.width),
  5376. this.guiScreen.ui.viewer.scene.sceneAnimator.setAnimationProgress(this.sliderPercent, !0),
  5377. this.guiScreen.ui.viewer.scene.sceneAnimator.paused && (this.guiScreen.ui.viewer.scene.postRender.discardAAHistory(),
  5378. this.guiScreen.ui.viewer.reDrawScene())
  5379. }
  5380. }
  5381. .bind(this)
  5382. , t = function (e) {
  5383. this.draggingSlider = !0;
  5384. var t = this.backgroundControl.controlRect.linkedControl.getBoundingClientRect();
  5385. this.setSliderPercent((e.clientX - t.left) / t.width),
  5386. this.guiScreen.ui.viewer.scene.sceneAnimator.setAnimationProgress(this.sliderPercent, !0),
  5387. this.guiScreen.ui.viewer.scene.sceneAnimator.lockPlayback = !0,
  5388. this.guiScreen.ui.viewer.scene.sceneAnimator.paused && (this.guiScreen.ui.viewer.scene.postRender.discardAAHistory(),
  5389. this.guiScreen.ui.viewer.reDrawScene())
  5390. }
  5391. .bind(this)
  5392. , i = function (e) {
  5393. this.draggingSlider = !1,
  5394. this.guiScreen.ui.viewer.scene.sceneAnimator.lockPlayback = !1
  5395. }
  5396. .bind(this);
  5397. this.guiScreen.ui.viewer.input.element.addEventListener("mousemove", e),
  5398. this.guiScreen.ui.viewer.input.element.addEventListener("mouseup", i),
  5399. this.backgroundControl.controlRect.linkedControl.addEventListener("mousemove", e),
  5400. this.backgroundControl.controlRect.linkedControl.addEventListener("mousedown", t),
  5401. this.backgroundControl.controlRect.linkedControl.addEventListener("mouseup", i),
  5402. this.controlRect.linkedControl.addEventListener("mouseup", i)
  5403. }
  5404. ,
  5405. j.prototype.setSize = function (e, t) {
  5406. this.container.width = 0 | e,
  5407. this.container.height = 0 | t,
  5408. this.container.style.width = e + "px",
  5409. this.container.style.height = t + "px",
  5410. this.guiScreen.setSize(this.container.width, this.container.height)
  5411. }
  5412. ,
  5413. j.prototype.clearView = function () {
  5414. for (; this.container.hasChildNodes();)
  5415. this.container.removeChild(this.container.childNodes[0]);
  5416. delete this.progressBar,
  5417. delete this.thumbnail,
  5418. delete this.fadeThumbnail,
  5419. delete this.playButton,
  5420. delete this.helpOverlay
  5421. }
  5422. ,
  5423. j.prototype.bindInput = function (i) {
  5424. i.onSingleTap.push(function (e, t) {
  5425. this.stripData.selectedStrip != this.stripData.STRIP_NONE && (e = 2 / i.element.clientWidth * e - 1,
  5426. t = 1 - 2 / i.element.clientHeight * t,
  5427. this.stripData.selectStrip(e, t),
  5428. this.stripData.selectedStrip == this.stripData.STRIP_MENU && this.helpOverlay.active && this.helpOverlay.toggle(),
  5429. this.refreshUI(),
  5430. this.viewer.wake())
  5431. }
  5432. .bind(this))
  5433. }
  5434. ,
  5435. j.sanitize = function (e) {
  5436. return e ? e.replace(/<|>|\(|\)|$|%|=/g, "") : e
  5437. }
  5438. ,
  5439. j.sanitizeURL = function (e) {
  5440. return e ? 0 == e.indexOf("http://") || 0 == e.indexOf("https://") || 0 == e.indexOf("ftp://") ? encodeURI(e) : "http://" + encodeURI(e) : e
  5441. }
  5442. ,
  5443. j.prototype.showFailure = function (e, t) {
  5444. this.container.innerHTML = "";
  5445. var i = document.createElement("canvas")
  5446. , s = this.container.width / this.container.height;
  5447. i.width = 100,
  5448. i.height = i.height * s | 0,
  5449. i.style.position = "absolute",
  5450. i.style["z-index"] = "0",
  5451. i.style.width = i.style.height = "100%";
  5452. var n = i.getContext("2d")
  5453. , r = n.fillStyle = n.createRadialGradient(i.width / 2, i.height / 2, (i.width + i.height) / 2, i.width / 2, i.height / 2, 0);
  5454. r.addColorStop(0, "rgb(0,0,0)"),
  5455. r.addColorStop(1, "rgb(35,60,80)"),
  5456. n.fillStyle = r,
  5457. n.fillRect(0, 0, i.width, i.height),
  5458. this.container.appendChild(i);
  5459. var a = document.createElement("div");
  5460. dom.addClass(a, "error"),
  5461. a.style["background-image"] = "url(images/errorBG.png)";
  5462. var o = '<div class="errorInfo"><p style="font-size:1.5em; font-weight:lighter">转换模型时出错</p><p style="font-size:1.3em;letter-spacing:2px;font-weight:bold;line-height:1.5em;margin-top:30px">错误信息: ' + (e || "文件无效(ERROR)请检查您所上传的文件以确定其稳定性") + '</p><p style="font-size:0.8em;line-height:1.5em; margin-top:50px">您可以联系我们的客服、或点击<a href="http://www.4dage.com/tutorial.html" style="color: #a6ccea;">视频教程</a>获取更详细的上传解说<br>4Dweb将全程为您提供最优质的模型展示</p></div>';
  5463. a.innerHTML = o,
  5464. this.container.appendChild(a)
  5465. }
  5466. ,
  5467. j.prototype.showPreview = function (e) {
  5468. this.clearView(),
  5469. this.thumbnail = document.createElement("canvas");
  5470. var t = this.container.width / this.container.height;
  5471. this.thumbnail.height = this.viewer.mobile ? 200 : 300,
  5472. this.thumbnail.width = this.thumbnail.height * t | 0,
  5473. this.thumbnail.style.width = this.thumbnail.style.height = "100%";
  5474. var i = (t = this.thumbnail.getContext("2d")).fillStyle = t.createRadialGradient(this.thumbnail.width / 2, this.thumbnail.height / 2, (this.thumbnail.width + this.thumbnail.height) / 2, this.thumbnail.width / 2, 0, 0);
  5475. i.addColorStop(0, "rgb(0,0,0)"),
  5476. i.addColorStop(1, "rgb(150,150,150)"),
  5477. t.fillStyle = i,
  5478. t.fillRect(0, 0, this.thumbnail.width, this.thumbnail.height),
  5479. this.container.appendChild(this.thumbnail),
  5480. this.playButton = document.createElement("input"),
  5481. this.playButton.type = "image",
  5482. // this.playButton.src = I.dataLocale + "play.png",
  5483. this.playButton.style.position = "absolute",
  5484. this.playButton.style.left = "50%",
  5485. this.playButton.style.top = "50%",
  5486. this.playButton.style["-webkit-transform"] = this.playButton.style.transform = "translate(-50%,-50%) scale(0.4,0.4)",
  5487. this.playButton.style.opacity = .5,
  5488. this.playButton.style.outline = "0px",
  5489. this.playButton.onclick = function () {
  5490. this.viewer.loadScene(this.viewer.sceneURL),
  5491. this.container.removeChild(this.playButton),
  5492. delete this.playButton
  5493. }
  5494. .bind(this),
  5495. this.container.appendChild(this.playButton),
  5496. e || n(this.viewer.sceneURL, function (e) {
  5497. this.loadingImageURL || this.setThumbnail(e)
  5498. }
  5499. .bind(this))
  5500. }
  5501. ,
  5502. j.prototype.setThumbnailURL = function (e) {
  5503. (this.loadingImageURL = e) && C.fetchImage(this.loadingImageURL, this.setThumbnail.bind(this))
  5504. }
  5505. ,
  5506. j.prototype.setThumbnail = function (e) {
  5507. if (this.thumbnail)
  5508. if (e.height >= this.container.height) {
  5509. var t = this.container.height / e.height;
  5510. e.style.position = "absolute",
  5511. e.style.outline = "0px",
  5512. e.style.left = "50%",
  5513. e.style.top = "50%",
  5514. e.style["-webkit-transform"] = e.style.transform = "translate(-50%,-50%) scale(" + t + "," + t + ")",
  5515. this.container.replaceChild(e, this.thumbnail),
  5516. this.thumbnail = e
  5517. } else {
  5518. var i, s = this.thumbnail.getContext("2d"), n = this.thumbnail.width, r = this.thumbnail.height;
  5519. t = r / e.height;
  5520. s.drawImage(e, (n - e.width * t) / 2, 0, e.width * t, r);
  5521. try {
  5522. i = s.getImageData(0, 0, n, r)
  5523. } catch (e) {
  5524. return
  5525. }
  5526. e = s.createImageData(n, r);
  5527. for (var a = 0; a < 2; ++a) {
  5528. t = i.data;
  5529. for (var o = e.data, h = 0, l = 0; l < r; ++l)
  5530. for (var d = 0; d < n; ++d) {
  5531. for (var c = 0, u = 0, f = 0, m = -2; m <= 2; ++m)
  5532. for (var p = (p = l + m) < 0 ? 0 : r <= p ? r - 1 : p, g = -2; g <= 2; ++g) {
  5533. var v;
  5534. c = c + t[v = 4 * (p * n + (v = (v = d + g) < 0 ? 0 : n <= v ? n - 1 : v))],
  5535. u = u + t[v + 1],
  5536. f = f + t[v + 2]
  5537. }
  5538. o[h++] = c / 25,
  5539. o[h++] = u / 25,
  5540. o[h++] = f / 25,
  5541. o[h++] = 255
  5542. }
  5543. t = i,
  5544. i = e,
  5545. e = t
  5546. }
  5547. s.putImageData(i, 0, 0)
  5548. }
  5549. }
  5550. ,
  5551. j.prototype.showActiveView = function () {
  5552. var e, t, i, s, n, r = this.thumbnail;
  5553. this.clearView(),
  5554. r && (this.fadeThumbnail = r,
  5555. this.fadeThumbnail.style.opacity = 1,
  5556. this.container.appendChild(this.fadeThumbnail)),
  5557. void 0 === I.largeUI && (I.largeUI = this.viewer.mobile),
  5558. this.container.width < 450 && (I.largeUI = !1);
  5559. var a = g.support();
  5560. r = 1;
  5561. window.devicePixelRatio && (2 < window.devicePixelRatio ? r = 4 : 1 < window.devicePixelRatio && (r = 2)),
  5562. I.largeUI && r < 4 && (r *= 2);
  5563. var o = I.largeUI ? .3 : .5;
  5564. this.helpOverlay = document.createElement("div"),
  5565. this.helpOverlay.style.pointerEvents = "none",
  5566. this.container.appendChild(this.helpOverlay),
  5567. this.hideSigOnHelp = e = this.container.width < 450,
  5568. this.hideSigOnStrips = !0,
  5569. t = [8, 8],
  5570. s = e ? (i = 198 + 2 * t[0],
  5571. 258 + 2 * t[1]) : (i = 354 + 2 * t[0],
  5572. 218 + 2 * t[1]),
  5573. (n = document.createElement("div")).style.position = "absolute",
  5574. n.style.width = n.style.height = "100%",
  5575. this.helpOverlay.contents = n,
  5576. (n = document.createElement("div")).style.position = "absolute",
  5577. n.style.right = I.largeUI ? "85px" : "45px",
  5578. n.style.top = I.largeUI ? "20px" : "12px",
  5579. n.style["z-index"] = "20",
  5580. n.style.width = i + "px",
  5581. n.style.height = s + "px",
  5582. this.helpOverlay.contents.appendChild(n),
  5583. (s = document.createElement("div")).style.position = "absolute",
  5584. s.style.width = "100%",
  5585. s.style.height = "100%",
  5586. s.style.backgroundColor = "black",
  5587. s.style.opacity = "0.65",
  5588. s.style.borderRadius = "16px",
  5589. n.appendChild(s),
  5590. s = document.createElement("a"),
  5591. dom.addClass(s, "tipClose"),
  5592. s.style.position = "absolute",
  5593. s.style.color = "#FFFFFF",
  5594. s.style.backgroundColor = "rgba(0,0,0,0.0)",
  5595. s.style.border = "0px",
  5596. s.style.outline = "0px",
  5597. s.style.fontSize = I.largeUI ? "16pt" : "10pt",
  5598. s.style.right = I.largeUI ? "-9px" : "4px",
  5599. s.style.top = I.largeUI ? "3px" : "7px",
  5600. s.style.width = s.style.height = I.largeUI ? "32px" : "16px",
  5601. s.style.pointerEvents = "auto",
  5602. s.style.cursor = "pointer",
  5603. s.onclick = function (e) {
  5604. this.helpOverlay.toggle(),
  5605. this.refreshUI()
  5606. }
  5607. .bind(this, s),
  5608. n.appendChild(s),
  5609. (s = document.createElement("center")).style.position = "absolute",
  5610. s.style.left = t[0] - 4 + "px",
  5611. s.style.right = t[0] + 4 + "px",
  5612. s.style.top = s.style.bottom = t[1] + "px",
  5613. s.style.paddingTop = "8px",
  5614. e || (s.style.paddingRight = "8px"),
  5615. n.appendChild(s),
  5616. n = s,
  5617. t = (this.viewer.mobile ? "M" : "PC") + (2 < r ? 4 : 2) + "x.png",
  5618. (s = document.createElement("img")).style.width = "66px",
  5619. s.style.height = "90px",
  5620. n.appendChild(s),
  5621. (s = document.createElement("img")).style.width = "66px",
  5622. s.style.height = "90px",
  5623. n.appendChild(s),
  5624. (s = document.createElement("img")).style.width = "66px",
  5625. s.style.height = "90px",
  5626. n.appendChild(s),
  5627. (s = document.createElement("img")).style.width = "66px",
  5628. s.style.height = "90px",
  5629. n.appendChild(s),
  5630. (s = document.createElement("img")).style.position = "relative",
  5631. e || (s.style.left = "8px"),
  5632. s.style.width = "66px",
  5633. s.style.height = "90px",
  5634. n.appendChild(s),
  5635. (t = document.createElement("a")).href = "http://www.4dage.com/",
  5636. t.target = "_blank",
  5637. t.style.pointerEvents = "auto",
  5638. t.style.cursor = "pointer",
  5639. n.appendChild(t),
  5640. (s = document.createElement("img")).style.position = "absolute",
  5641. s.style.left = .5 * i - (e ? 65 : 116) + "px",
  5642. s.style.bottom = e ? "8px" : "12px",
  5643. s.style.width = e ? "116px" : "232px",
  5644. t.appendChild(s),
  5645. (i = document.createElement("div")).style.position = "absolute",
  5646. i.style.left = 0,
  5647. i.style.right = e ? "30px" : "128px",
  5648. i.style.bottom = e ? "-4px" : "4px",
  5649. i.style.textAlign = "right",
  5650. i.style.fontFamilly = "Open Sans Arial",
  5651. n.appendChild(i),
  5652. (e = document.createElement("font")).style.fontSize = "9pt",
  5653. e.style.fontFamily = "Open Sans Arial",
  5654. i.appendChild(e),
  5655. e.appendChild(t),
  5656. this.helpOverlay.active = !1,
  5657. this.helpOverlay.toggle = function (e) {
  5658. this.active ? this.removeChild(this.contents) : this.appendChild(this.contents),
  5659. this.active = !this.active
  5660. }
  5661. .bind(this.helpOverlay, this.viewer),
  5662. this.menuCluster = document.createElement("div"),
  5663. this.menuCluster.style.position = "absolute",
  5664. this.menuCluster.style.right = I.largeUI ? "4px" : "0px",
  5665. this.menuCluster.style.top = I.largeUI ? "20px" : "10px",
  5666. I.largeUI ? (this.menuCluster.style.width = "72px",
  5667. this.menuCluster.style.height = "64px") : (this.menuCluster.style.width = "36px",
  5668. this.menuCluster.style.height = "36px"),
  5669. (n = document.createElement("div")).style.left = n.style.top = "0px",
  5670. n.style.width = n.style.height = "100%",
  5671. this.menuCluster.contents = n,
  5672. this.menuCluster.appendChild(n),
  5673. e = 0;
  5674. var h = (i = function (e, t, i, s, n, r) {
  5675. var a = document.createElement("div");
  5676. return dom.addClass(a, "controlBtn"),
  5677. dom.addClass(a, i),
  5678. a.title = t,
  5679. I.largeUI && dom.addClass(a, "largeUI"),
  5680. e.appendChild(a),
  5681. a
  5682. }
  5683. )(this.menuCluster.contents, "4DAGE主页", "home", "", e++, o);
  5684. for (h.onclick = function (e) {
  5685. window.open("http://www.4dage.com", "_blank")
  5686. }
  5687. .bind(this, h),
  5688. a && ((a = i(this.menuCluster.contents, "全屏", "fullscreen", "fullscreen" + r + "x.png", e++, o)).onclick = function (e) {
  5689. g.active() ? g.end() : g.begin(this.viewer.domRoot, this.viewer.fullscreenChange.bind(this.viewer)),
  5690. dom.hasClass(e, "full") ? dom.removeClass(e, "full") : dom.addClass(e, "full"),
  5691. this.refreshUI()
  5692. }
  5693. .bind(this, a)),
  5694. (a = i(this.menuCluster.contents, "操作方式说明", "tips", "help" + r + "x.png", e++, o)).onclick = function (e) {
  5695. this.helpOverlay.toggle(),
  5696. this.refreshUI()
  5697. }
  5698. .bind(this, a),
  5699. this.container.appendChild(this.menuCluster),
  5700. this.menuCluster.active = !0,
  5701. this.menuCluster.toggle = function () {
  5702. this.active ? this.removeChild(this.contents) : this.appendChild(this.contents),
  5703. this.active = !this.active
  5704. }
  5705. .bind(this.menuCluster),
  5706. void 0 !== I.hostImage && (I.hostURL && ((t = document.createElement("a")).href = I.hostURL,
  5707. t.target = "_blank"),
  5708. (s = document.createElement("img")).src = I.hostImage,
  5709. s.style.position = "absolute",
  5710. s.style.top = "4px",
  5711. s.style.left = "4px",
  5712. s.style.opacity = .65,
  5713. s.style["-webkit-transform"] = s.style.transform = "translate(-50%,-50%) scale(0.5,0.5) translate(50%,50%)",
  5714. I.hostURL ? (s.onmouseover = function () {
  5715. this.style.opacity = 1
  5716. }
  5717. .bind(s),
  5718. s.onmouseout = function () {
  5719. this.style.opacity = .5
  5720. }
  5721. .bind(s),
  5722. t.appendChild(s),
  5723. this.hostLogo = t) : this.hostLogo = s,
  5724. (e = new XMLHttpRequest).open("HEAD", s.src, !0),
  5725. e.onload = function () {
  5726. this.container.appendChild(this.hostLogo)
  5727. }
  5728. .bind(this),
  5729. e.send()),
  5730. this.sceneStats = document.createElement("text"),
  5731. this.sceneStats.style.position = "absolute",
  5732. this.sceneStats.style.left = "9px",
  5733. this.sceneStats.style.bottom = "8px",
  5734. this.sceneStats.style.color = "gray",
  5735. this.sceneStats.style.fontFamily = "Open Sans Arial",
  5736. this.sceneStats.style.fontSize = "75%",
  5737. e = a = r = 0; e < this.viewer.scene.meshes.length; ++e)
  5738. r += (i = this.viewer.scene.meshes[e]).indexCount / 3,
  5739. a += i.vertexCount;
  5740. this.sceneStats.innerHTML = "Triangles: " + (0 | r).toLocaleString() + "<br>Vertices: " + (0 | a).toLocaleString(),
  5741. I.showFrameTime && (this.frameTimer = document.createElement("text"),
  5742. this.frameTimer.style.position = "absolute",
  5743. this.frameTimer.style.left = this.frameTimer.style.top = "5px",
  5744. this.frameTimer.style.color = "gray",
  5745. this.frameTimer.style.fontSize = "75%",
  5746. this.container.appendChild(this.frameTimer),
  5747. this.frameTimer.innerHTML = "--",
  5748. this.frameCount = 1e20)
  5749. }
  5750. ,
  5751. j.prototype.refreshUI = function () {
  5752. if (this.sigCluster) {
  5753. var e = !1
  5754. , t = this.stripData.selectedStrip == this.stripData.STRIP_MENU;
  5755. this.hideSigOnStrips && (e = e || t),
  5756. this.hideSigOnHelp && (e = e || this.helpOverlay.active),
  5757. this.sigCluster.active == e && this.sigCluster.toggle()
  5758. }
  5759. }
  5760. ,
  5761. j.prototype.signalLoadProgress = function (e, t) {
  5762. if (this.thumbnail) {
  5763. if (!this.progressBar) {
  5764. var i = document.createElement("div");
  5765. i.style.backgroundColor = "rgb(240,240,240)",
  5766. i.style.opacity = .9,
  5767. i.style.position = "absolute",
  5768. i.style.zIndex = 999
  5769. i.style.left = "20%",
  5770. i.style.width = "60%",
  5771. i.style.bottom = "30%",
  5772. i.style.height = "4px",
  5773. i.style["border-radius"] = "2px",
  5774. this.progressBar = document.createElement("div"),
  5775. this.progressBar.style.backgroundColor = "#00ccff",
  5776. this.progressBar.style.position = "absolute",
  5777. this.progressBar.style.left = this.progressBar.style.bottom = "0px",
  5778. this.progressBar.style.height = "100%",
  5779. this.progressBar.style.width = "0px",
  5780. this.progressBar.style["border-radius"] = "2px",
  5781. i.appendChild(this.progressBar),
  5782. this.container.appendChild(i),
  5783. this.playButton && (this.container.removeChild(this.playButton),
  5784. delete this.playButton)
  5785. }
  5786. this.progressBar.style.width = t <= 0 ? (100 * e / (2097152 + e) | 0) + "%" : (100 * e / t | 0) + "%"
  5787. }
  5788. }
  5789. ,
  5790. j.prototype.animating = function () {
  5791. return !!this.fadeThumbnail || !!this.frameTimer
  5792. }
  5793. ,
  5794. j.prototype.animate = function () {
  5795. if (this.fadeThumbnail && (this.fadeThumbnailTimer = this.fadeThumbnailTimer || Date.now(),
  5796. this.fadeThumbnail.style.opacity = 1 - .0015 * (Date.now() - this.fadeThumbnailTimer),
  5797. this.fadeThumbnail.style.opacity < .01 && (this.container.removeChild(this.fadeThumbnail),
  5798. delete this.fadeThumbnail,
  5799. delete this.fadeThumbnailTimer)),
  5800. this.frameTimer && (this.frameCount++,
  5801. 60 <= this.frameCount)) {
  5802. var e = (new Date).getTime();
  5803. if (void 0 !== this.frameTime) {
  5804. var t = (e - this.frameTime) / this.frameCount;
  5805. t = Math.floor(100 * t) / 100;
  5806. this.frameTimer.innerHTML = t + " ms",
  5807. this.frameTimer.style.color = t < 32 ? "green" : "red"
  5808. }
  5809. this.frameCount = 0,
  5810. this.frameTime = e
  5811. }
  5812. if (this.guiScreen && this.guiScreen.playbackControls && ((e = this.guiScreen.playbackControls.timelineSlider).draggingSlider ? this.viewer.scene.sceneAnimator.setAnimationProgress(e.sliderPercent, !0) : e.setSliderPercent(this.viewer.scene.sceneAnimator.animationProgress)),
  5813. this.sceneStats) {
  5814. for (var i = t = e = 0; i < this.viewer.scene.meshes.length; ++i) {
  5815. var s = this.viewer.scene.meshes[i];
  5816. e = e + s.indexCount / 3,
  5817. t = t + s.vertexCount
  5818. }
  5819. this.sceneStats.innerHTML = "Triangles: " + (0 | e).toLocaleString() + "<br>Vertices: " + (0 | t).toLocaleString(),
  5820. this.viewer.scene.sceneAnimator && this.viewer.scene.sceneAnimator.showPlayControls && (this.sceneStats.innerHTML += "<br><br><br><br>"),
  5821. e = !!this.sceneStats.parentElement,
  5822. t = this.stripData.active() || !1,
  5823. e && !t ? (this.container.removeChild(this.sceneStats),
  5824. this.hostLogo && this.container.appendChild(this.hostLogo)) : !e && t && (this.container.appendChild(this.sceneStats),
  5825. this.hostLogo && this.container.removeChild(this.hostLogo))
  5826. }
  5827. this.refreshUI(),
  5828. (this.stripData.animationActive || this.stripData.active()) && (this.animateStrips(),
  5829. this.stripData.animationActive && this.viewer.wake())
  5830. }
  5831. ,
  5832. j.prototype.animateStrips = function () {
  5833. if (this.stripText)
  5834. for (var e = Math.atan(this.viewer.canvas.height / this.viewer.canvas.width / this.stripData.stripSlant), t = 0; t < this.stripData.labels.length; ++t) {
  5835. var i = .5 + .5 * (i = (i = this.stripData.strips[t]) - this.stripData.stripSlant);
  5836. t == this.stripData.selectedStrip ? (this.stripText[t].style["-ms-transform"] = this.stripText[t].style["-webkit-transform"] = this.stripText[t].style.transform = "none",
  5837. this.stripText[t].style.top = "4px",
  5838. this.stripText[t].style.left = "0px",
  5839. this.stripText[t].style.width = "150px",
  5840. this.stripText[t].txt.style.textAlign = "center",
  5841. this.stripText[t].txt.style.background = "rgba(0, 0, 0, 0.75)",
  5842. this.stripText[t].txt.style.background = "-webkit-linear-gradient(left, rgba(0,0,0,0.75), rgba(0,0,0,0))",
  5843. this.stripText[t].txt.style.background = "-o-linear-gradient(left, rgba(0,0,0,0.75), rgba(0,0,0,0))",
  5844. this.stripText[t].txt.style.background = "-moz-linear-gradient(left, rgba(0,0,0,0.75), rgba(0,0,0,0))",
  5845. this.stripText[t].txt.style.background = "linear-gradient(left, rgba(0,0,0,0.75), rgba(0,0,0,0))",
  5846. this.stripText[t].txt.style.paddingLeft = "32px",
  5847. this.stripText[t].txt.style.paddingTop = "6px",
  5848. this.stripText[t].txt.style.paddingBottom = "4px",
  5849. this.stripText[t].txt.style.textShadow = "1px 1px 2px rgba(0,0,0,0.7)",
  5850. this.stripText[t].line.style.opacity = .5,
  5851. this.stripText[t].line.style.top = "100%",
  5852. this.stripText[t].line.style.width = "100%",
  5853. this.stripText[t].line.style.height = "1px") : (this.stripText[t].style["-ms-transform"] = this.stripText[t].style["-webkit-transform"] = this.stripText[t].style.transform = "translate(-50%, -50%) rotate(" + e + "rad) translate(50%, 50%)",
  5854. this.stripText[t].style.left = 100 * i + "%",
  5855. this.stripText[t].style.top = "0px",
  5856. this.stripText[t].style.width = "85px",
  5857. this.stripText[t].txt.style.textAlign = "left",
  5858. this.stripText[t].txt.style.background = "none",
  5859. this.stripText[t].txt.style.paddingLeft = "8px",
  5860. this.stripText[t].txt.style.paddingTop = "6px",
  5861. this.stripText[t].txt.style.paddingBottom = "4px",
  5862. this.stripText[t].txt.style.textShadow = "2px 0px 3px rgba(0,0,0,0.7)",
  5863. this.stripText[t].line.style.opacity = 1,
  5864. this.stripText[t].line.style.top = "-1px",
  5865. this.stripText[t].line.style.width = "10000px",
  5866. this.stripText[t].line.style.height = "2px")
  5867. }
  5868. }
  5869. ;
  5870. var V = {
  5871. type: Float32Array,
  5872. create: function (e, t, i, s) {
  5873. var n = new V.type(4);
  5874. return n[0] = e,
  5875. n[1] = t,
  5876. n[2] = i,
  5877. n[3] = s,
  5878. n
  5879. },
  5880. empty: function () {
  5881. return new V.type(4)
  5882. },
  5883. set: function (e, t, i, s, n) {
  5884. e[0] = t,
  5885. e[1] = i,
  5886. e[2] = s,
  5887. e[3] = n
  5888. },
  5889. copy: function (e, t) {
  5890. e[0] = t[0],
  5891. e[1] = t[1],
  5892. e[2] = t[2],
  5893. e[3] = t[3]
  5894. },
  5895. add: function (e, t, i) {
  5896. return e[0] = t[0] + i[0],
  5897. e[1] = t[1] + i[1],
  5898. e[2] = t[2] + i[2],
  5899. e[3] = t[3] + i[3],
  5900. e
  5901. },
  5902. sub: function (e, t, i) {
  5903. return e[0] = t[0] - i[0],
  5904. e[1] = t[1] - i[1],
  5905. e[2] = t[2] - i[2],
  5906. e[3] = t[3] - i[3],
  5907. e
  5908. },
  5909. scale: function (e, t, i) {
  5910. return e[0] = i[0] * t,
  5911. e[1] = i[1] * t,
  5912. e[2] = i[2] * t,
  5913. e[3] = i[3] * t,
  5914. e
  5915. },
  5916. mul: function (e, t, i) {
  5917. return e[0] = t[0] * i[0],
  5918. e[1] = t[1] * i[1],
  5919. e[2] = t[2] * i[2],
  5920. e[3] = t[3] * i[3],
  5921. e
  5922. },
  5923. mad: function (e, t, i, s) {
  5924. return e[0] = t[0] * i[0] + s[0],
  5925. e[1] = t[1] * i[1] + s[1],
  5926. e[2] = t[2] * i[2] + s[2],
  5927. e[3] = t[3] * i[3] + s[3],
  5928. e
  5929. },
  5930. smad: function (e, t, i, s) {
  5931. return e[0] = t * i[0] + s[0],
  5932. e[1] = t * i[1] + s[1],
  5933. e[2] = t * i[2] + s[2],
  5934. e[3] = t * i[3] + s[3],
  5935. e
  5936. },
  5937. negate: function (e, t) {
  5938. return e[0] = -t[0],
  5939. e[1] = -t[1],
  5940. e[2] = -t[2],
  5941. e
  5942. },
  5943. negate4: function (e, t) {
  5944. return e[0] = -t[0],
  5945. e[1] = -t[1],
  5946. e[2] = -t[2],
  5947. e[3] = -t[3],
  5948. e
  5949. },
  5950. length: function (e) {
  5951. var t = e[0]
  5952. , i = e[1];
  5953. return e = e[2],
  5954. Math.sqrt(t * t + i * i + e * e)
  5955. },
  5956. distance: function (e, t) {
  5957. var i = e[0] - t[0]
  5958. , s = e[1] - t[1]
  5959. , n = e[2] - t[2];
  5960. return Math.sqrt(i * i + s * s + n * n)
  5961. },
  5962. dot: function (e, t) {
  5963. return e[0] * t[0] + e[1] * t[1] + e[2] * t[2]
  5964. },
  5965. dot4: function (e, t) {
  5966. return e[0] * t[0] + e[1] * t[1] + e[2] * t[2] + e[3] * t[3]
  5967. },
  5968. normalize: function (e, t) {
  5969. var i = t[0]
  5970. , s = t[1]
  5971. , n = t[2]
  5972. , r = Math.sqrt(i * i + s * s + n * n);
  5973. return 0 == r ? V.set(e, 0, 0, 0, 0) : (r = 1 / r,
  5974. e[0] = i * r,
  5975. e[1] = s * r,
  5976. e[2] = n * r,
  5977. e)
  5978. },
  5979. cross: function (e, t, i) {
  5980. return e[0] = t[1] * i[2],
  5981. e[0] += -t[2] * i[1],
  5982. e[1] = t[2] * i[0] - t[0] * i[2],
  5983. e[2] = t[0] * i[1] - t[1] * i[0],
  5984. e
  5985. },
  5986. lerp: function (e, t, i, s) {
  5987. var n = 1 - s;
  5988. return e[0] = t[0] * n + i[0] * s,
  5989. e[1] = t[1] * n + i[1] * s,
  5990. e[2] = t[2] * n + i[2] * s,
  5991. e
  5992. },
  5993. lerp4: function (e, t, i, s) {
  5994. var n = 1 - s;
  5995. return e[0] = t[0] * n + i[0] * s,
  5996. e[1] = t[1] * n + i[1] * s,
  5997. e[2] = t[2] * n + i[2] * s,
  5998. e[3] = t[3] * n + i[3] * s,
  5999. e
  6000. },
  6001. min: function (e, t, i) {
  6002. return e[0] = Math.min(t[0], i[0]),
  6003. e[1] = Math.min(t[1], i[1]),
  6004. e[2] = Math.min(t[2], i[2]),
  6005. e[3] = Math.min(t[3], i[3]),
  6006. e
  6007. },
  6008. max: function (e, t, i) {
  6009. return e[0] = Math.max(t[0], i[0]),
  6010. e[1] = Math.max(t[1], i[1]),
  6011. e[2] = Math.max(t[2], i[2]),
  6012. e[3] = Math.max(t[3], i[3]),
  6013. e
  6014. },
  6015. projectOnPlane: function (e, t, i, s) {
  6016. var n = V.empty();
  6017. return V.sub(n, t, i),
  6018. i = V.dot(n, s),
  6019. smad(e, -i, normal, t),
  6020. e
  6021. }
  6022. };
  6023. function H(e) {
  6024. this.pivot = [0, 0, 0],
  6025. this.rotation = [0, 0],
  6026. this.radius = 1,
  6027. this.nearPlane = .3,
  6028. this.fov = 45,
  6029. this.size = [1, 1],
  6030. this.transform = S.empty(),
  6031. this.viewMatrix = S.empty(),
  6032. this.projectionMatrix = S.empty(),
  6033. this.viewProjectionMatrix = S.empty(),
  6034. e ? this.loadView(e, !0) : (this.saveResetView(),
  6035. this.updateView(),
  6036. this.updateProjection())
  6037. }
  6038. function W(e, t, i, s) {
  6039. var n;
  6040. if (this.mobile = !!/Android|iPhone|iPod|iPad|Windows Phone|IEMobile|BlackBerry|webOS/.test(navigator.userAgent),
  6041. this.mobileFast = !!/iPhone|iPad/.test(navigator.userAgent),
  6042. n = !this.mobile)
  6043. e: {
  6044. if ((n = document.createElement("canvas")).width = n.height = 16,
  6045. n = n.getContext("webgl", {}) || n.getContext("experimental-webgl", {})) {
  6046. var r = n.getExtension("WEBGL_debug_renderer_info");
  6047. if (r) {
  6048. n = n.getParameter(r.UNMASKED_RENDERER_WEBGL),
  6049. n = !!/Intel|INTEL/.test(n);
  6050. break e
  6051. }
  6052. }
  6053. n = !1
  6054. }
  6055. this.desktopSlow = n,
  6056. this.domRoot = document.createElement("div"),
  6057. this.domRoot.style.width = e + "px",
  6058. this.domRoot.style.height = t + "px",
  6059. this.initCanvas(e, t),
  6060. this.scene = this.input = null,
  6061. this.sceneURL = i,
  6062. this.sleepCounter = 8,
  6063. this.onLoad = null,
  6064. this.stripData = new D,
  6065. this.ui = new j(this),
  6066. this.ui.setSize(e, t),
  6067. this.ui.showPreview(s)
  6068. }
  6069. H.prototype.saveResetView = function () {
  6070. this.resetDesc = {
  6071. angles: [this.rotation[0], this.rotation[1]],
  6072. pivot: [this.pivot[0], this.pivot[1], this.pivot[2]],
  6073. limits: this.limits,
  6074. orbitRadius: this.radius,
  6075. fov: this.fov
  6076. }
  6077. }
  6078. ,
  6079. H.prototype.loadView = function (e, t) {
  6080. e && (this.rotation[0] = e.angles[0],
  6081. this.rotation[1] = e.angles[1],
  6082. rotInfo.pivot[0] || (rotInfo.pivot[0] = e.pivot[0]),
  6083. rotInfo.pivot[1] || (rotInfo.pivot[1] = e.pivot[1]),
  6084. rotInfo.pivot[2] || (rotInfo.pivot[2] = e.pivot[2]),
  6085. this.pivot[0] = rotInfo.pivot[0],
  6086. this.pivot[1] = rotInfo.pivot[1],
  6087. this.pivot[2] = rotInfo.pivot[2],
  6088. this.radius = parseFloat(e.orbitRadius),
  6089. this.fov = e.fov,
  6090. this.limits = e.limits,
  6091. t && this.saveResetView(),
  6092. this.updateView(),
  6093. this.updateProjection())
  6094. }
  6095. ,
  6096. H.prototype.reset = function () {
  6097. this.loadView(this.resetDesc)
  6098. }
  6099. ,
  6100. H.prototype.updateView = function () {
  6101. if (void 0 !== this.limits) {
  6102. if (this.limits.angles) {
  6103. var e = this.limits.angles.x
  6104. , t = this.limits.angles.y;
  6105. if (void 0 !== e) {
  6106. var i = this.rotation[0] - e.offset;
  6107. e = Math.min(Math.max(i, e.min), e.max);
  6108. this.rotation[0] += e - i
  6109. }
  6110. void 0 !== t && (i = this.rotation[1] - t.offset,
  6111. e = Math.min(Math.max(i, t.min), t.max),
  6112. this.rotation[1] += e - i)
  6113. }
  6114. void 0 !== this.limits.orbitRadius && (t = this.limits.orbitRadius.min,
  6115. i = this.limits.orbitRadius.max,
  6116. void 0 !== t && (this.radius = Math.max(this.radius, t)),
  6117. void 0 !== i && (this.radius = Math.min(this.radius, i))),
  6118. void 0 !== this.limits.pan && (t = this.limits.pan,
  6119. i = this.resetDesc.pivot,
  6120. t.x && (this.pivot[0] = i[0]),
  6121. t.y && (this.pivot[1] = i[1]),
  6122. t.z && (this.pivot[2] = i[2]))
  6123. }
  6124. S.translation(this.transform, 0, 0, this.radius),
  6125. t = S.rotation(S.empty(), this.rotation[0], 0),
  6126. i = S.rotation(S.empty(), this.rotation[1], 1),
  6127. S.mul(t, i, t),
  6128. S.mul(this.transform, t, this.transform),
  6129. this.transform[12] += this.pivot[0],
  6130. this.transform[13] += this.pivot[1],
  6131. this.transform[14] += this.pivot[2],
  6132. S.invert(this.viewMatrix, this.transform),
  6133. S.mul(this.viewProjectionMatrix, this.viewMatrix, this.projectionMatrix)
  6134. }
  6135. ,
  6136. H.prototype.updateProjection = function (e) {
  6137. S.perspectiveInfinite(this.projectionMatrix, this.fov, this.size[0] / this.size[1], this.nearPlane, e),
  6138. S.mul(this.viewProjectionMatrix, this.projectionMatrix, this.viewMatrix)
  6139. }
  6140. ,
  6141. W.prototype.initCanvas = function (e, t) {
  6142. if (this.canvas && this.canvas.parentNode && this.canvas.parentNode.removeChild(this.canvas),
  6143. this.canvas = document.createElement("canvas"),
  6144. this.pixelRatio = window.devicePixelRatio || 1,
  6145. this.mobile) {
  6146. var i = this.mobileFast ? 1.5 : 1;
  6147. this.pixelRatio = this.pixelRatio > i ? i : this.pixelRatio
  6148. } else
  6149. this.desktopSlow && (this.pixelRatio = 1);
  6150. this.canvas.width = e * this.pixelRatio,
  6151. this.canvas.height = t * this.pixelRatio,
  6152. this.canvas.style.width = e + "px",
  6153. this.canvas.style.height = t + "px",
  6154. this.canvas.style.position = "absolute",
  6155. this.domRoot.appendChild(this.canvas)
  6156. }
  6157. ,
  6158. W.prototype.initGL = function () {
  6159. var e = {
  6160. alpha: !!I.transparentBackground,
  6161. depth: !1,
  6162. stencil: !1,
  6163. antialias: !1,
  6164. premultipliedAlpha: !!I.transparentBackground,
  6165. preserveDrawingBuffer: !1
  6166. };
  6167. e = this.gl = this.canvas.getContext("webgl", e) || this.canvas.getContext("experimental-webgl", e);
  6168. return this.gl ? (this.canvas.addEventListener("webglcontextlost", function (e) {
  6169. e.preventDefault()
  6170. }
  6171. .bind(this), !1),
  6172. this.canvas.addEventListener("webglcontextrestored", function (e) {
  6173. this.loadScene(this.sceneURL)
  6174. }
  6175. .bind(this), !1),
  6176. e.ext = {
  6177. textureAniso: e.getExtension("EXT_texture_filter_anisotropic") || e.getExtension("WEBKIT_EXT_texture_filter_anisotropic") || e.getExtension("MOZ_EXT_texture_filter_anisotropic"),
  6178. textureFloat: e.getExtension("OES_texture_float"),
  6179. textureFloatLinear: e.getExtension("OES_texture_float_linear"),
  6180. textureHalf: e.getExtension("OES_texture_half_float"),
  6181. textureHalfLinear: e.getExtension("OES_texture_half_float_linear"),
  6182. textureDepth: e.getExtension("WEBGL_depth_texture"),
  6183. colorBufferFloat: e.getExtension("WEBGL_color_buffer_float"),
  6184. colorBufferHalf: e.getExtension("EXT_color_buffer_half_float"),
  6185. index32bit: e.getExtension("OES_element_index_uint"),
  6186. loseContext: e.getExtension("WEBGL_lose_context"),
  6187. derivatives: e.getExtension("OES_standard_derivatives"),
  6188. renderInfo: e.getExtension("WEBGL_debug_renderer_info")
  6189. },
  6190. e.limits = {
  6191. textureSize: e.getParameter(e.MAX_TEXTURE_SIZE),
  6192. textureCount: e.getParameter(e.MAX_TEXTURE_IMAGE_UNITS),
  6193. varyings: e.getParameter(e.MAX_VARYING_VECTORS),
  6194. vertexAttribs: e.getParameter(e.MAX_VERTEX_ATTRIBS),
  6195. vertexUniforms: e.getParameter(e.MAX_VERTEX_UNIFORM_VECTORS),
  6196. fragmentUniforms: e.getParameter(e.MAX_FRAGMENT_UNIFORM_VECTORS),
  6197. viewportSizes: e.getParameter(e.MAX_VIEWPORT_DIMS),
  6198. vendor: e.getParameter(e.VENDOR),
  6199. version: e.getParameter(e.VERSION)
  6200. },
  6201. e.hints = {
  6202. mobile: this.mobile,
  6203. pixelRatio: this.pixelRatio
  6204. },
  6205. e.enable(e.DEPTH_TEST),
  6206. e.shaderCache = new O(e),
  6207. e.textureCache = new N(e),
  6208. this.allocBacking(),
  6209. !0) : (this.ui.showFailure('webgl出错。</br>建议您将浏览器升级至最新版本,以获最好的体验。<br><span style="font-size:0.8em">获知更多webgl浏览器信息请<a href="webglInfo.html" style="color: #a6ccea;">点击此处</a></span>', this),
  6210. !1)
  6211. }
  6212. ,
  6213. W.prototype.allocBacking = function () {
  6214. var e = this.gl
  6215. , t = !1
  6216. , i = {
  6217. width: this.canvas.width,
  6218. height: this.canvas.height
  6219. };
  6220. for (this.mainColor = new U(e, i),
  6221. this.mainDepth = null,
  6222. e.ext.textureDepth && (this.mainDepth = new U(e, {
  6223. width: this.canvas.width,
  6224. height: this.canvas.height,
  6225. nofilter: !0
  6226. }),
  6227. this.mainDepth.loadArray(null, e.DEPTH_COMPONENT, e.UNSIGNED_INT)),
  6228. e.ext.textureHalf && e.ext.textureHalfLinear && (this.mainColor.loadArray(null, e.RGBA, e.ext.textureHalf.HALF_FLOAT_OES),
  6229. this.mainBuffer = new m(e, {
  6230. color0: this.mainColor,
  6231. depth: this.mainDepth,
  6232. createDepth: !this.mainDepth
  6233. }),
  6234. t = this.mainBuffer.valid),
  6235. !t && e.ext.textureFloat && e.ext.textureFloatLinear && !e.hints.mobile && (this.mainColor.loadArray(null, e.RGBA, e.FLOAT),
  6236. this.mainBuffer = new m(e, {
  6237. color0: this.mainColor,
  6238. depth: this.mainDepth,
  6239. createDepth: !this.mainDepth
  6240. }),
  6241. t = this.mainBuffer.valid); !t;)
  6242. this.mainColor = new U(e, i),
  6243. this.mainColor.loadArray(null, e.RGBA, e.UNSIGNED_BYTE),
  6244. this.mainBuffer = new m(e, {
  6245. color0: this.mainColor,
  6246. depth: this.mainDepth,
  6247. createDepth: !this.mainDepth
  6248. }),
  6249. t = this.mainBuffer.valid,
  6250. i.width /= 2,
  6251. i.height /= 2,
  6252. this.mainDepth && (this.mainDepth.destroy(),
  6253. this.mainDepth = null);
  6254. this.mainBufferNoDepth = new m(e, {
  6255. color0: this.mainColor
  6256. })
  6257. }
  6258. ,
  6259. W.prototype.loadScene = function (e) {
  6260. if (this.sceneURL = e || this.sceneURL,
  6261. this.scene = this.input = null,
  6262. this.initGL() && this.sceneURL) {
  6263. var t = this.ui.signalLoadProgress.bind(this.ui);
  6264. e = function (e) {
  6265. t(1, 1),
  6266. this.scene = new k(this.gl),
  6267. this.scene.stripData = this.stripData,
  6268. this.scene.load(new h(e)) ? this.scene.metaData.tbVersion <= 2070 ? this.ui.showFailure("模型文件版本过低", this) : (this.bindInput(),
  6269. this.requestFrame(this.updateLoad.bind(this)),
  6270. this.onLoad && this.onLoad()) : this.ui.showFailure("模型文件无法读取或无效", this)
  6271. }
  6272. .bind(this);
  6273. var i = function () {
  6274. this.ui.showFailure("模型文件 (" + this.sceneURL + ") 无法获取.", this)
  6275. }
  6276. .bind(this);
  6277. C.fetchBinary(this.sceneURL, e, i, t)
  6278. }
  6279. }
  6280. ,
  6281. W.prototype.unload = function () {
  6282. delete this.scene,
  6283. delete this.input,
  6284. delete this.ui,
  6285. delete this.mainColor,
  6286. delete this.mainBuffer,
  6287. delete this.gl;
  6288. var e = this.domRoot.clientWidth
  6289. , t = this.domRoot.clientHeight;
  6290. this.initCanvas(e, t),
  6291. this.ui = new j(this),
  6292. this.ui.setSize(e, t),
  6293. this.ui.showPreview(),
  6294. this.cancelFrame()
  6295. }
  6296. ,
  6297. W.prototype.bindInput = function () {
  6298. this.input = new e(this.ui.container),
  6299. this.input.onDrag.push(function (e, t, i, s) {
  6300. e = 1 - 2.2 / (Math.sqrt(i * i + s * s) + 2.2),
  6301. (t = this.scene.view).rotation[1] -= .4 * i * e,
  6302. t.rotation[0] -= .4 * s * e,
  6303. t.rotation[0] = 90 < t.rotation[0] ? 90 : t.rotation[0],
  6304. t.rotation[0] = t.rotation[0] < -90 ? -90 : t.rotation[0],
  6305. t.updateView(),
  6306. this.wake()
  6307. }
  6308. .bind(this)),
  6309. this.input.onPan.push(function (e, t) {
  6310. var i = this.scene.view
  6311. , s = -e * (n = i.fov / 45 * .8 * (i.radius / this.domRoot.clientHeight))
  6312. , n = t * n;
  6313. i.pivot[0] += s * i.transform[0] + n * i.transform[4],
  6314. i.pivot[1] += s * i.transform[1] + n * i.transform[5],
  6315. i.pivot[2] += s * i.transform[2] + n * i.transform[6],
  6316. i.updateView(),
  6317. this.wake()
  6318. }
  6319. .bind(this)),
  6320. this.input.onPan2.push(function (e, t) {
  6321. var i = 1 - 2.2 / (Math.sqrt(e * e + t * t) + 2.2);
  6322. this.scene.lights.rotation -= .4 * e * i,
  6323. this.wake()
  6324. }
  6325. .bind(this)),
  6326. this.input.onZoom.push(function (e) {
  6327. rotInfo.stopWhenZoom && webview.stopRotate();
  6328. var t = this.scene.view;
  6329. t.radius *= 1 - .002 * e,
  6330. t.radius = t.radius < .001 ? .001 : t.radius,
  6331. t.radius = 1e3 < t.radius ? 1e3 : t.radius,
  6332. t.updateView(),
  6333. this.wake()
  6334. }
  6335. .bind(this)),
  6336. this.input.onDoubleTap.push(function (e, t) {
  6337. this.scene.view.reset(),
  6338. this.scene.sceneAnimator && this.scene.sceneAnimator.resetCustomView(),
  6339. this.wake()
  6340. }
  6341. .bind(this)),
  6342. this.ui.bindInput(this.input)
  6343. }
  6344. ,
  6345. W.prototype.rotateWhenIdle = function () {
  6346. rotInfo.radiusK && (webview.scene.view.radius = rotInfo.radiusK / (dom.id("fdageUI").clientWidth / dom.id("fdageUI").clientHeight)),
  6347. webview.scene.view.pivot = rotInfo.pivot.slice(),
  6348. webview.rotate = setInterval(function () {
  6349. webview.scene.view.rotation[1] -= rotInfo.speed,
  6350. webview.updateView(!0, !0, 1)
  6351. }, 16)
  6352. }
  6353. ,
  6354. W.prototype.stopRotate = function () {
  6355. webview.rotate ? (clearInterval(webview.rotate),
  6356. console.log("clearInterval(webview.rotate)"),
  6357. webview.rotate = null,
  6358. webview.countIdelTime = setTimeout(webview.rotateWhenIdle, rotInfo.idleTime)) : webview.countIdelTime && (clearTimeout(webview.countIdelTime),
  6359. console.log("clearInterval(countIdelTime)"),
  6360. webview.countIdelTime = setTimeout(webview.rotateWhenIdle, rotInfo.idleTime))
  6361. }
  6362. ,
  6363. W.prototype.wake = function (e) {
  6364. e = e || 16,
  6365. this.sleepCounter = this.sleepCounter < e ? e : this.sleepCounter,
  6366. this.scene.postRender.discardAAHistory(),
  6367. this.requestFrame(this.update.bind(this))
  6368. }
  6369. ,
  6370. W.prototype.requestFrame = function (e) {
  6371. var t = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame;
  6372. if (!this.frameRequestPending) {
  6373. var i = function () {
  6374. this.frameRequestPending = 0,
  6375. e()
  6376. }
  6377. .bind(this);
  6378. this.frameRequestPending = t(i, this.canvas)
  6379. }
  6380. }
  6381. ,
  6382. W.prototype.cancelFrame = function () {
  6383. this.frameRequestPending && (window.cancelAnimationFrame || window.mozCancelAnimationFrame || window.webkitCancelAnimationFrame || window.msCancelAnimationFrame)(this.frameRequestPending)
  6384. }
  6385. ,
  6386. W.prototype.fullscreenChange = function () {
  6387. g.active() ? (this.oldRootWidth = this.domRoot.style.width,
  6388. this.oldRootHeight = this.domRoot.style.height,
  6389. this.domRoot.style.width = "100%",
  6390. this.domRoot.style.height = "100%") : (this.domRoot.style.width = this.oldRootWidth,
  6391. this.domRoot.style.height = this.oldRootHeight),
  6392. this.wake()
  6393. }
  6394. ,
  6395. W.prototype.resize = function (e, t) {
  6396. e && t ? (this.domRoot.style.width = e + "px",
  6397. this.domRoot.style.height = t + "px") : (e = this.domRoot.clientWidth,
  6398. t = this.domRoot.clientHeight),
  6399. this.canvas.width = e * this.pixelRatio,
  6400. this.canvas.height = t * this.pixelRatio,
  6401. this.canvas.style.width = e + "px",
  6402. this.canvas.style.height = t + "px",
  6403. this.ui.setSize(e, t),
  6404. this.allocBacking(),
  6405. this.wake()
  6406. }
  6407. ,
  6408. W.prototype.updateLoad = function () {
  6409. this.scene.complete() ? this.start() : this.requestFrame(this.updateLoad.bind(this)),
  6410. this.ui.animate()
  6411. }
  6412. ,
  6413. W.prototype.start = function () {
  6414. console.log('模型加载完成');
  6415. setTimeout(() => {
  6416. let dom = document.querySelector('.outerImg')
  6417. dom.style.opacity = 0
  6418. dom.style.pointerEvents = 'none'
  6419. }, 500);
  6420. this.scene.view.updateView(),
  6421. this.ui.showActiveView(),
  6422. this.requestFrame(this.update.bind(this)),
  6423. window.autoRotate && this.rotateWhenIdle(),
  6424. document.documentElement.style.height = "100%",
  6425. document.documentElement.style.width = "100%",
  6426. document.documentElement.style.margin = "0",
  6427. document.documentElement.style.padding = "0",
  6428. document.body.style.height = "100%",
  6429. document.body.style.width = "100%",
  6430. document.body.style.margin = "0",
  6431. document.body.style.padding = "0"
  6432. }
  6433. ,
  6434. W.prototype.update = function () {
  6435. var e = this.scene.sceneAnimator && !this.scene.sceneAnimator.paused;
  6436. (0 < this.sleepCounter || this.ui.animating() || e || this.stripData.animationActive) && (this.stripData.update(),
  6437. this.ui.animate(),
  6438. this.scene.update(),
  6439. this.drawScene(),
  6440. this.requestFrame(this.update.bind(this))),
  6441. e ? this.scene.postRender.discardAAHistory() : this.sleepCounter--
  6442. }
  6443. ,
  6444. W.prototype.reDrawScene = function () {
  6445. this.stripData.update(),
  6446. this.ui.animate(),
  6447. this.scene.update(),
  6448. this.drawScene(),
  6449. this.requestFrame(this.update.bind(this)),
  6450. this.scene.postRender.discardAAHistory()
  6451. }
  6452. ,
  6453. W.prototype.drawScene = function () {
  6454. this.gl.isContextLost() || (this.domRoot.clientWidth == this.canvas.clientWidth && this.domRoot.clientHeight == this.canvas.clientHeight || this.resize(),
  6455. this.scene.view.size = [this.mainBuffer.width, this.mainBuffer.height],
  6456. this.scene.view.updateProjection(),
  6457. this.scene.postRender.adjustProjectionForSupersampling(this.scene.view),
  6458. this.scene.collectShadows(this.mainBuffer),
  6459. this.mainBuffer.bind(),
  6460. this.scene.draw(this.mainBuffer),
  6461. this.mainDepth && (this.mainBufferNoDepth.bind(),
  6462. this.scene.drawSecondary(this.mainDepth)),
  6463. this.scene.postRender.present(this.mainColor, this.canvas.width, this.canvas.height, this.stripData.active()))
  6464. }
  6465. ,
  6466. W.prototype.updateView = function (e, t, i) {
  6467. t && webview.scene.view.updateView(),
  6468. webview.wake(i || 4),
  6469. e && webview.scene.postRender.discardAAHistory()
  6470. }
  6471. ,
  6472. (I = void 0 === I ? {} : I).WebViewer = W,
  6473. I.dataLocale = "images/";
  6474. var G = {
  6475. "alphaprepassfrag.glsl": "precision mediump float;\n#include <matdither.glsl>\nuniform sampler2D tAlbedo;varying mediump vec2 d;void main(){float e=texture2D(tAlbedo,d).a;if(e<=f(d.x)){discard;}gl_FragColor=vec4(0.0);}",
  6476. "alphaprepassvert.glsl": "precision highp float;uniform mat4 uModelViewProjectionMatrix;uniform vec2 uUVOffset;attribute vec3 vPosition;attribute vec2 vTexCoord;varying mediump vec2 d;vec4 h(mat4 i,vec3 p){return i[0]*p.x+(i[1]*p.y+(i[2]*p.z+i[3]));}void main(void){gl_Position=h(uModelViewProjectionMatrix,vPosition.xyz);d=vTexCoord+uUVOffset;}",
  6477. "bloom.glsl": "precision mediump float;uniform sampler2D tInput;uniform vec4 uKernel[BLOOM_SAMPLES];varying highp vec2 j;void main(void){vec3 c=vec3(0.0,0.0,0.0);for(int k=0;k<BLOOM_SAMPLES;++k){vec3 l=uKernel[k].xyz;vec3 m=texture2D(tInput,j+l.xy).xyz;m=max(m,vec3(0.0,0.0,0.0));c+=m*l.z;}gl_FragColor.xyz=c;gl_FragColor.w=0.0;}",
  6478. "bloomshrink.glsl": "precision highp float;uniform sampler2D tInput;varying highp vec2 j;void main(void){float o=0.25/256.0;gl_FragColor=0.25*(texture2D(tInput,j+vec2(o,o))+texture2D(tInput,j+vec2(o,-o))+texture2D(tInput,j+vec2(-o,o))+texture2D(tInput,j+vec2(-o,-o)));}",
  6479. "fogfrag.glsl": "precision highp float;uniform sampler2D tDepth;uniform vec3 uDepthToZ;uniform vec4 uUnproject;uniform mat4 uInvViewMatrix;uniform float uFogInvDistance;uniform float uFogOpacity;uniform float uFogDispersion;uniform vec3 uFogType;uniform vec3 uFogColor;uniform float uFogIllum;uniform mat4 uLightMatrix;\n#ifdef FOG_IBL\nuniform vec4 uFogLightSphere[9];\n#else\nuniform vec4 uSpotParams;uniform vec4 uLightPosition;uniform vec3 uLightColor;uniform vec4 uLightAttenuation;\n#ifdef FOG_SHADOWS\nuniform mat4 uShadowProj;uniform sampler2D uShadowMap;uniform float uDitherOffset;uniform vec4 uCylinder;\n#endif\n#endif\nvec4 h(mat4 i,vec3 p){return i[0]*p.x+(i[1]*p.y+(i[2]*p.z+i[3]));}vec3 u(mat4 i,vec3 v){return i[0].xyz*v.x+i[1].xyz*v.y+i[2].xyz*v.z;}float A(float B){B*=uFogInvDistance;float C=uFogType.x*min(B,1.0)+(uFogType.y-uFogType.y/(1.0+16.0*B*B))+(uFogType.z-uFogType.z*exp(-3.0*B));return C*uFogOpacity;}\n#ifdef FOG_SHADOWS\nfloat D(vec3 E){vec4 p=h(uShadowProj,E);vec3 F=p.xyz/p.w;vec4 G=texture2D(uShadowMap,F.xy);float H=(G.x+G.y*(1.0/255.0))+G.z*(1.0/65025.0);return F.z<H || H>=1.0?1.0:0.0;}float f(vec2 I){return fract(sin(dot(I,vec2(12.9898,78.233)))*43758.5453+uDitherOffset);}void J(vec3 K,vec3 L,out float M,out float N){vec3 v=uSpotParams.xyz,p=uCylinder.xyz;vec3 O=L-dot(L,v)*v;vec3 P=(K-p)-dot(K-p,v)*v;float a=dot(O,O);float b=2.0*dot(O,P);float c=dot(P,P)-uCylinder.w;float Q=b*b-4.0*a*c;if(Q>=0.0){Q=sqrt(Q);M=(-b-Q)/(2.0*a);N=(-b+Q)/(2.0*a);}else {M=N=0.0;}}\n#endif\nvarying vec2 j;void main(void){vec3 R=uInvViewMatrix[3].xyz;float H=texture2D(tDepth,j).x;H=min(H,0.9999);vec3 S;S.z=uDepthToZ.y/(uDepthToZ.z*H+uDepthToZ.x);S.xy=S.z*(j*uUnproject.xy+uUnproject.zw);S=h(uInvViewMatrix,S).xyz;vec3 T;T.xy=(j*uUnproject.xy+uUnproject.zw);T.z=1.0;T=normalize(u(uInvViewMatrix,-T).xyz);vec3 U=uFogColor;\n#if defined(FOG_IBL)\nvec3 G=u(uLightMatrix,T);vec3 V=uFogLightSphere[0].xyz;V+=uFogLightSphere[1].xyz*G.y;V+=uFogLightSphere[2].xyz*G.z;V+=uFogLightSphere[3].xyz*G.x;vec3 swz=G.yyz*G.xzx;V+=uFogLightSphere[4].xyz*swz.x;V+=uFogLightSphere[5].xyz*swz.y;V+=uFogLightSphere[7].xyz*swz.z;vec3 sqr=G*G;V+=uFogLightSphere[6].xyz*(3.0*sqr.z-1.0);V+=uFogLightSphere[8].xyz*(sqr.x-sqr.y);U=mix(U,U*V,uFogIllum);float C=A(length(S-R));gl_FragColor.xyz=U*C;gl_FragColor.w=C;return;\n#else\n#if defined(FOG_SPOT) || defined(FOG_OMNI)\nfloat W=0.0,X=0.0;{float r=1.0/(uLightAttenuation.z);float a=1.0;float b=2.0*dot(T,R-uLightPosition.xyz);float c=dot(uLightPosition.xyz,uLightPosition.xyz)+dot(R,R)+-2.0*dot(uLightPosition.xyz,R)+-r*r;float Q=b*b-4.0*a*c;if(Q>=0.0){Q=sqrt(Q);W=(-b-Q)/(2.0*a);X=(-b+Q)/(2.0*a);}}\n#if defined(FOG_SPOT)\n{float Y=uSpotParams.w,Z=1.0-Y;vec3 v=T;vec3 dc=uSpotParams.xyz;vec3 dd=R-uLightPosition.xyz;vec3 de=v-dot(v,dc)*dc,df=dd-dot(dd,dc)*dc;float a=Y*dot(de,de)-Z*dot(v,dc)*dot(v,dc);float b=2.0*Y*dot(de,df)-2.0*Z*dot(v,dc)*dot(dd,dc);float c=Y*dot(df,df)-Z*dot(dd,dc)*dot(dd,dc);float Q=b*b-4.0*a*c;if(Q>=0.0){float dh=(-b-sqrt(Q))/(2.0*a);float di=(-b+sqrt(Q))/(2.0*a);if(di<dh){float de=dh;dh=di;di=de;}bool dj=dot(-uLightPosition.xyz+R+T*dh,uSpotParams.xyz)<=0.0;bool dk=dot(-uLightPosition.xyz+R+T*di,uSpotParams.xyz)<=0.0;if(!dj ||!dk){if(dj){dh=di;di=X;}else if(dk){di=dh;dh=W;}W=max(W,dh);X=min(X,di);}else {X=W=0.0;}}else {X=W=0.0;}}\n#endif\nfloat tx=dot(T,S-R);W=clamp(W,0.0,tx);X=clamp(X,0.0,tx);float dl=0.0;if(X>W){\n#ifdef FOG_SHADOWS\n#ifdef MOBILE\n#define SAMPLES 16\n#else\n#define SAMPLES 32\n#endif\nfloat dm=f(j)*(X-W)/float(SAMPLES-2);\n#else\n#define SAMPLES 8\nfloat dm=0.0;\n#endif\nfor(int k=0;k<SAMPLES;++k){float t=W+(X-W)*float(k)/float(SAMPLES-1);vec3 p=R+(t+dm)*T;float a=clamp(length(p-uLightPosition.xyz)*uLightAttenuation.z,0.0,1.0);a=1.0+uLightAttenuation.x*a+uLightAttenuation.y*a*a;\n#ifdef FOG_SHADOWS\na*=D(p);\n#endif\ndl+=a-a*A(t);}dl*=1.0/float(SAMPLES);dl*=(X-W)*uLightAttenuation.z;dl*=A(X-W);}U*=dl*uFogIllum;\n#elif defined(FOG_DIR)\nfloat C=A(dot(T,S-R));\n#ifdef FOG_SHADOWS\nfloat W,X;J(R,T,W,X);float tx=dot(T,S-R);W=clamp(W,0.0,tx);X=clamp(X,0.0,tx);if(X>W){\n#ifdef MOBILE\n#define SAMPLES 16\n#else\n#define SAMPLES 32\n#endif\nfloat dl=0.0;float dm=f(j)*(X-W)/float(SAMPLES-2);float dn=(X-W)*(1.0/float(SAMPLES));for(int k=0;k<SAMPLES;++k){float t=W+float(k)*dn+dm;vec3 p=R+t*T;float s=D(p);C-=(1.0-s)*(A(t+dn)-A(t));}}\n#endif\nfloat du=0.5+0.5*dot(T,-uSpotParams.xyz);du=1.0+uFogDispersion*(2.0*du*du-1.0);U*=(0.1*C)*(du*uFogIllum);\n#endif\ngl_FragColor.xyz=U*uLightColor;gl_FragColor.w=0.0;\n#endif\n}",
  6480. "fogvert.glsl": "precision highp float;attribute vec2 vCoord;varying vec2 j;void main(void){j=vCoord;gl_Position.xy=2.0*vCoord-vec2(1.0,1.0);gl_Position.zw=vec2(0.0,1.0);}",
  6481. "matdither.glsl": "float f(highp float I){highp float G=0.5*fract(gl_FragCoord.x*0.5)+0.5*fract(gl_FragCoord.y*0.5);return 0.4+0.6*fract(G+3.141592e6*I);}",
  6482. "matfrag.glsl": "\n#extension GL_OES_standard_derivatives : enable\nprecision mediump float;varying highp vec3 dv;varying mediump vec2 d;varying mediump vec3 dA;varying mediump vec3 dB;varying mediump vec3 dC;\n#ifdef VERTEX_COLOR\nvarying lowp vec4 dD;\n#endif\n#ifdef TEXCOORD_SECONDARY\nvarying mediump vec2 dE;\n#endif\nuniform sampler2D tAlbedo;uniform sampler2D tReflectivity;uniform sampler2D tNormal;uniform sampler2D tExtras;uniform sampler2D tSkySpecular;\n#ifdef REFRACTION\nuniform sampler2D tRefraction;\n#endif\nuniform vec4 uDiffuseCoefficients[9];uniform vec3 uCameraPosition;uniform float uAlphaTest;uniform vec3 uFresnel;uniform float uHorizonOcclude;uniform float uHorizonSmoothing;\n#ifdef EMISSIVE\nuniform float uEmissiveScale;uniform vec4 uTexRangeEmissive;\n#endif\n#ifdef AMBIENT_OCCLUSION\nuniform vec4 uTexRangeAO;\n#endif\n#ifdef REFRACTION\nuniform float uRefractionIOREntry;uniform float uRefractionRayDistance;uniform vec3 uRefractionTint;uniform float uRefractionAlbedoTint;uniform mat4 uRefractionViewProjection;uniform vec4 uTexRangeRefraction;\n#endif\n#ifdef LIGHT_COUNT\nuniform vec4 uLightPositions[LIGHT_COUNT];uniform vec3 uLightDirections[LIGHT_COUNT];uniform vec3 uLightColors[LIGHT_COUNT];uniform vec3 uLightParams[LIGHT_COUNT];uniform vec3 uLightSpot[LIGHT_COUNT];\n#endif\n#ifdef ANISO\nuniform float uAnisoStrength;uniform vec3 uAnisoTangent;uniform float uAnisoIntegral;uniform vec4 uTexRangeAniso;\n#endif\n#define saturate(x) clamp( x, 0.0, 1.0 )\n#include <matsampling.glsl>\n#include <matlighting.glsl>\n#include <matshadows.glsl>\n#include <matskin.glsl>\n#include <matmicrofiber.glsl>\n#include <matstrips.glsl>\n#ifdef TRANSPARENCY_DITHER\n#include <matdither.glsl>\n#endif\nvoid main(void){vec4 m=texture2D(tAlbedo,d);vec3 dF=dG(m.xyz);float e=m.w;\n#ifdef VERTEX_COLOR\n{vec3 dH=dD.xyz;\n#ifdef VERTEX_COLOR_SRGB\ndH=dH*(dH*(dH*0.305306011+vec3(0.682171111))+vec3(0.012522878));\n#endif\ndF*=dH;\n#ifdef VERTEX_COLOR_ALPHA\ne*=dD.w;\n#endif\n}\n#endif\n#ifdef ALPHA_TEST\nif(e<uAlphaTest){discard;}\n#endif\n#ifdef TRANSPARENCY_DITHER\ne=(e>f(d.x))?1.0:e;\n#endif\nvec3 dI=dJ(texture2D(tNormal,d).xyz);\n#ifdef ANISO\n#ifdef ANISO_NO_DIR_TEX\nvec3 dK=dL(uAnisoTangent);\n#else\nm=dM(d,uTexRangeAniso);vec3 dK=2.0*m.xyz-vec3(1.0);dK=dL(dK);\n#endif\ndK=dK-dI*dot(dK,dI);dK=normalize(dK);vec3 dN=dK*uAnisoStrength;\n#endif\nvec3 dO=normalize(uCameraPosition-dv);m=texture2D(tReflectivity,d);vec3 dP=dG(m.xyz);float dQ=m.w;float dR=dQ;\n#ifdef HORIZON_SMOOTHING\nfloat dS=dot(dO,dI);dS=uHorizonSmoothing-dS*uHorizonSmoothing;dQ=mix(dQ,1.0,dS*dS);\n#endif\n#ifdef STRIPVIEW\ndT dU;dV(dU,dQ,dP);\n#endif\nfloat dW=1.0;\n#ifdef AMBIENT_OCCLUSION\n#ifdef AMBIENT_OCCLUSION_SECONDARY_UV\ndW=dM(dE,uTexRangeAO).x;\n#else\ndW=dM(d,uTexRangeAO).x;\n#endif\ndW*=dW;\n#endif\n#if defined(SKIN)\ndX dY;dZ(dY);dY.ec*=dW;\n#elif defined(MICROFIBER)\ned ee;ef(ee,dI);ee.eh*=dW;\n#else\nvec3 ei=ej(dI);ei*=dW;\n#endif\nvec3 ek=reflect(-dO,dI);\n#ifdef ANISO\nvec3 rt=ek-(0.5*dN*dot(ek,dK));vec3 el=em(rt,mix(dQ,0.5*dQ,uAnisoStrength));\n#else\nvec3 el=em(ek,dQ);\n#endif\nel*=en(ek,dC);\n#ifdef LIGHT_COUNT\nhighp float eo=10.0/log2(dQ*0.968+0.03);eo*=eo;float eu=eo*(1.0/(8.0*3.1415926))+(4.0/(8.0*3.1415926));eu=min(eu,1.0e3);\n#ifdef SHADOW_COUNT\nev eA;\n#ifdef SKIN\n#ifdef SKIN_VERSION_1\neB(eA,SHADOW_KERNEL+SHADOW_KERNEL*dY.eC);\n#else\neD eE;float eF=SHADOW_KERNEL+SHADOW_KERNEL*dY.eC;eG(eE,eF);eB(eA,eF);\n#endif\n#else\neB(eA,SHADOW_KERNEL);\n#endif\n#endif\n#ifdef ANISO\neu*=uAnisoIntegral;\n#endif\nfor(int k=0;k<LIGHT_COUNT;++k){vec3 eH=uLightPositions[k].xyz-dv*uLightPositions[k].w;float eI=inversesqrt(dot(eH,eH));eH*=eI;float a=saturate(uLightParams[k].z/eI);a=1.0+a*(uLightParams[k].x+uLightParams[k].y*a);float s=saturate(dot(eH,uLightDirections[k]));s=saturate(uLightSpot[k].y-uLightSpot[k].z*(1.0-s*s));vec3 eJ=(a*s)*uLightColors[k].xyz;\n#if defined(SKIN)\n#ifdef SHADOW_COUNT\n#ifdef SKIN_VERSION_1\neK(dY,eA.eL[k],1.0,eH,dI,eJ);\n#else\neK(dY,eA.eL[k],eE.eE[k],eH,dI,eJ);\n#endif\n#else\neK(dY,1.0,0.0,eH,dI,eJ);\n#endif\n#elif defined(MICROFIBER)\n#ifdef SHADOW_COUNT\neM(ee,eA.eL[k],eH,dI,eJ);\n#else\neM(ee,1.0,eH,dI,eJ);\n#endif\n#else\nfloat eN=saturate((1.0/3.1415926)*dot(eH,dI));\n#ifdef SHADOW_COUNT\neN*=eA.eL[k];\n#endif\nei+=eN*eJ;\n#endif\nvec3 eO=eH+dO;\n#ifdef ANISO\neO=eO-(dN*dot(eO,dK));\n#endif\neO=normalize(eO);float eP=eu*pow(saturate(dot(eO,dI)),eo);\n#ifdef SHADOW_COUNT\neP*=eA.eL[k];\n#endif\nel+=eP*eJ;}\n#endif\n#if defined(SKIN)\nvec3 ei,diff_extra;eQ(ei,diff_extra,dY,dO,dI,dQ);\n#elif defined(MICROFIBER)\nvec3 ei,diff_extra;eR(ei,diff_extra,ee,dO,dI,dQ);\n#endif\nvec3 eS=eT(dO,dI,dP,dQ*dQ);el*=eS;\n#ifdef REFRACTION\nvec4 eU;{vec3 G=refract(-dO,dI,uRefractionIOREntry);G=dv+G*uRefractionRayDistance;vec4 eV=uRefractionViewProjection[0]*G.x+(uRefractionViewProjection[1]*G.y+(uRefractionViewProjection[2]*G.z+uRefractionViewProjection[3]));vec2 c=eV.xy/eV.w;c=0.5*c+vec2(0.5,0.5);vec2 i=mod(floor(c),2.0);c=fract(c);c.x=i.x>0.0?1.0-c.x:c.x;c.y=i.y>0.0?1.0-c.y:c.y;eU.rgb=texture2D(tRefraction,c).xyz;eU.rgb=mix(eU.rgb,eU.rgb*dF,uRefractionAlbedoTint);eU.rgb=eU.rgb-eU.rgb*eS;eU.rgb*=uRefractionTint;\n#ifdef REFRACTION_NO_MASK_TEX\neU.a=1.0;\n#else\neU.a=dM(d,uTexRangeRefraction).x;\n#endif\n}\n#endif\n#ifdef DIFFUSE_UNLIT\ngl_FragColor.xyz=dF;\n#else\ngl_FragColor.xyz=ei*dF;\n#endif\n#ifdef REFRACTION\ngl_FragColor.xyz=mix(gl_FragColor.xyz,eU.rgb,eU.a);\n#endif\ngl_FragColor.xyz+=el;\n#if defined(SKIN) || defined(MICROFIBER)\ngl_FragColor.xyz+=diff_extra;\n#endif\n#ifdef EMISSIVE\n#ifdef EMISSIVE_SECONDARY_UV\nvec2 eW=dE;\n#else\nvec2 eW=d;\n#endif\ngl_FragColor.xyz+=uEmissiveScale*dG(dM(eW,uTexRangeEmissive).xyz);\n#endif\n#ifdef STRIPVIEW\ngl_FragColor.xyz=eX(dU,dI,dF,dP,dR,ei,el,gl_FragColor.xyz);\n#endif\n#ifdef NOBLEND\ngl_FragColor.w=1.0;\n#else\ngl_FragColor.w=e;\n#endif\n}",
  6483. "matlighting.glsl": "vec3 eY(vec3 eZ,float fc){return exp(-0.5*fc/(eZ*eZ))/(eZ*2.5066283);}vec3 fd(vec3 eZ){return vec3(1.0,1.0,1.0)/(eZ*2.5066283);}vec3 fe(vec3 ff){return vec3(-0.5,-0.5,-0.5)/(ff);}vec3 fh(vec3 fi,float fc){return exp(fi*fc);}\n#define SAMPLE_COUNT 21.0\n#define SAMPLE_HALF 10.0\n#define GAUSS_SPREAD 0.05\nvec3 fj(float fk,float fl,vec3 fm){vec3 fn=vec3(fl,fl,fl);fn=0.8*fn+vec3(0.2);vec3 fo=cos(fn*3.14159);vec3 fu=cos(fn*3.14159*0.5);fu*=fu;fu*=fu;fu*=fu;fn=fn+0.05*fo*fu*fm;fu*=fu;fu*=fu;fu*=fu;fn=fn+0.1*fo*fu*fm;fn=saturate(fn);fn*=fn*1.2;return fn;}vec3 fv(vec3 fm){return vec3(1.0,1.0,1.0)/3.1415926;}float fA(float fk,float fm){return saturate(-fk*fm+fk+fm);}vec3 fB(float fk,vec3 fm){return saturate(-fk*fm+vec3(fk)+fm);}float fC(float fm){return-0.31830988618379*fm+0.31830988618379;}vec3 fD(vec3 fm){return-0.31830988618379*fm+vec3(0.31830988618379);}vec3 eT(vec3 dO,vec3 dI,vec3 dP,float fE){float C=1.0-saturate(dot(dO,dI));float fF=C*C;C*=fF*fF;C*=fE;return(dP-C*dP)+C*uFresnel;}vec2 fG(vec2 fH,vec2 fm){fH=1.0-fH;vec2 fI=fH*fH;fI*=fI;fH=mix(fI,fH*0.4,fm);return fH;}vec3 ej(vec3 fJ){\n#define c(n) uDiffuseCoefficients[n].xyz\nvec3 G=(c(0)+fJ.y*((c(1)+c(4)*fJ.x)+c(5)*fJ.z))+fJ.x*(c(3)+c(7)*fJ.z)+c(2)*fJ.z;\n#undef c\nvec3 sqr=fJ*fJ;G+=uDiffuseCoefficients[6].xyz*(3.0*sqr.z-1.0);G+=uDiffuseCoefficients[8].xyz*(sqr.x-sqr.y);return G;}void fK(inout vec3 fL,inout vec3 fM,inout vec3 fN,vec3 fJ){fL=uDiffuseCoefficients[0].xyz;fM=uDiffuseCoefficients[1].xyz*fJ.y;fM+=uDiffuseCoefficients[2].xyz*fJ.z;fM+=uDiffuseCoefficients[3].xyz*fJ.x;vec3 swz=fJ.yyz*fJ.xzx;fN=uDiffuseCoefficients[4].xyz*swz.x;fN+=uDiffuseCoefficients[5].xyz*swz.y;fN+=uDiffuseCoefficients[7].xyz*swz.z;vec3 sqr=fJ*fJ;fN+=uDiffuseCoefficients[6].xyz*(3.0*sqr.z-1.0);fN+=uDiffuseCoefficients[8].xyz*(sqr.x-sqr.y);}vec3 fO(vec3 fL,vec3 fM,vec3 fN,vec3 fP,float fm){fP=mix(vec3(1.0),fP,fm);return(fL+fM*fP.x)+fN*fP.z;}vec3 fQ(vec3 fL,vec3 fM,vec3 fN,vec3 fP,vec3 fR){vec3 fS=mix(vec3(1.0),fP.yyy,fR);vec3 fT=mix(vec3(1.0),fP.zzz,fR);return(fL+fM*fS)+fN*fT;}vec3 em(vec3 fJ,float dQ){fJ/=dot(vec3(1.0),abs(fJ));vec2 fU=abs(fJ.zx)-vec2(1.0,1.0);vec2 fV=vec2(fJ.x<0.0?fU.x:-fU.x,fJ.z<0.0?fU.y:-fU.y);vec2 fW=(fJ.y<0.0)?fV:fJ.xz;fW=vec2(0.5*(254.0/256.0),0.125*0.5*(254.0/256.0))*fW+vec2(0.5,0.125*0.5);float fX=fract(7.0*dQ);fW.y+=0.125*(7.0*dQ-fX);vec2 fY=fW+vec2(0.0,0.125);vec4 fZ=mix(texture2D(tSkySpecular,fW),texture2D(tSkySpecular,fY),fX);vec3 r=fZ.xyz*(7.0*fZ.w);return r*r;}float en(vec3 fJ,vec3 hc){float hd=dot(fJ,hc);hd=saturate(1.0+uHorizonOcclude*hd);return hd*hd;}",
  6484. "matmicrofiber.glsl": "\n#ifdef MICROFIBER\nuniform vec4 uTexRangeFuzz;uniform vec4 uFresnelColor;uniform float uFresnelIntegral;uniform float uFresnelOcc;uniform float uFresnelGlossMask;struct ed{vec3 eh;vec3 eN;vec3 he;vec3 hf;vec3 hh;};void ef(out ed s,vec3 dI){s.eh=s.eN=ej(dI);s.he=vec3(0.0);s.hf=uFresnelColor.rgb;s.hh=uFresnelColor.aaa*vec3(1.0,0.5,0.25);\n#ifndef MICROFIBER_NO_FUZZ_TEX\nvec4 m=dM(d,uTexRangeFuzz);s.hf*=dG(m.rgb);\n#endif\n}void eM(inout ed s,float hi,vec3 eH,vec3 dI,vec3 eJ){float fk=dot(eH,dI);float eN=saturate((1.0/3.1415926)*fk);float hj=fA(fk,s.hh.z);\n#ifdef SHADOW_COUNT\neN*=hi;float hk=mix(1.0,hi,uFresnelOcc);float he=hj*hk;\n#else \nfloat he=hj;\n#endif\ns.he=he*eJ+s.he;s.eN=eN*eJ+s.eN;}void eR(out vec3 ei,out vec3 diff_extra,inout ed s,vec3 dO,vec3 dI,float dQ){s.he*=uFresnelIntegral;float fH=dot(dO,dI);vec2 hl=fG(vec2(fH,fH),s.hh.xy);s.he=s.eh*hl.x+(s.he*hl.y);s.he*=s.hf;float hm=saturate(1.0+-uFresnelGlossMask*dQ);s.he*=hm*hm;ei=s.eN;diff_extra=s.he;}\n#endif\n",
  6485. "matsampling.glsl": "vec3 dG(vec3 c){return c*c;}vec3 dJ(vec3 n){vec3 hn=dA;vec3 ho=dB;vec3 hu=gl_FrontFacing?dC:-dC;\n#ifdef TSPACE_RENORMALIZE\nhu=normalize(hu);\n#endif\n#ifdef TSPACE_ORTHOGONALIZE\nhn-=dot(hn,hu)*hu;\n#endif\n#ifdef TSPACE_RENORMALIZE\nhn=normalize(hn);\n#endif\n#ifdef TSPACE_ORTHOGONALIZE\nho=(ho-dot(ho,hu)*hu)-dot(ho,hn)*hn;\n#endif\n#ifdef TSPACE_RENORMALIZE\nho=normalize(ho);\n#endif\n#ifdef TSPACE_COMPUTE_BITANGENT\nvec3 hv=cross(hu,hn);ho=dot(hv,ho)<0.0?-hv:hv;\n#endif\nn=2.0*n-vec3(1.0);return normalize(hn*n.x+ho*n.y+hu*n.z);}vec3 dL(vec3 t){vec3 hu=gl_FrontFacing?dC:-dC;return normalize(dA*t.x+dB*t.y+hu*t.z);}vec4 dM(vec2 hA,vec4 hB){\n#if GL_OES_standard_derivatives\nvec2 hC=fract(hA);vec2 hD=fwidth(hC);float hE=(hD.x+hD.y)>0.5?-6.0:0.0;return texture2D(tExtras,hC*hB.xy+hB.zw,hE);\n#else\nreturn texture2D(tExtras,fract(hA)*hB.xy+hB.zw);\n#endif\n}vec3 hF(sampler2D hG,vec2 hH,float hI){vec3 n=texture2D(hG,hH,hI*2.5).xyz;return dJ(n);}",
  6486. "matshadows.glsl": "\n#ifdef SHADOW_COUNT\n#ifdef MOBILE\n#define SHADOW_KERNEL (4.0/1536.0)\n#else\n#define SHADOW_KERNEL (4.0/2048.0)\n#endif\nhighp vec4 h(highp mat4 i,highp vec3 p){return i[0]*p.x+(i[1]*p.y+(i[2]*p.z+i[3]));}uniform sampler2D tDepth0;\n#if SHADOW_COUNT > 1\nuniform sampler2D tDepth1;\n#if SHADOW_COUNT > 2\nuniform sampler2D tDepth2;\n#endif\n#endif\nuniform highp vec2 uShadowKernelRotation;uniform highp vec2 uShadowMapSize;uniform highp mat4 uShadowMatrices[SHADOW_COUNT];uniform highp vec4 uShadowTexelPadProjections[SHADOW_COUNT];\n#ifndef MOBILE\nuniform highp mat4 uInvShadowMatrices[SHADOW_COUNT];\n#endif\nhighp float hJ(highp vec3 G){\n#ifdef SHADOW_NATIVE_DEPTH\nreturn G.x;\n#else\nreturn(G.x+G.y*(1.0/255.0))+G.z*(1.0/65025.0);\n#endif\n}\n#ifndef SHADOW_COMPARE\n#define SHADOW_COMPARE(a,b) ((a) < (b) ? 1.0 : 0.0)\n#endif\n#ifndef SHADOW_CLIP\n#define SHADOW_CLIP(c,v) v\n#endif\nfloat hK(sampler2D hL,highp vec2 hA,highp float H){\n#ifndef MOBILE\nhighp vec2 c=hA*uShadowMapSize.x;highp vec2 a=floor(c)*uShadowMapSize.y,b=ceil(c)*uShadowMapSize.y;highp vec4 eE;eE.x=hJ(texture2D(hL,a).xyz);eE.y=hJ(texture2D(hL,vec2(b.x,a.y)).xyz);eE.z=hJ(texture2D(hL,vec2(a.x,b.y)).xyz);eE.w=hJ(texture2D(hL,b).xyz);highp vec4 hM;hM.x=SHADOW_COMPARE(H,eE.x);hM.y=SHADOW_COMPARE(H,eE.y);hM.z=SHADOW_COMPARE(H,eE.z);hM.w=SHADOW_COMPARE(H,eE.w);highp vec2 w=c-a*uShadowMapSize.x;vec2 s=(w.y*hM.zw+hM.xy)-w.y*hM.xy;return(w.x*s.y+s.x)-w.x*s.x;\n#else\nhighp float G=hJ(texture2D(hL,hA.xy).xyz);return SHADOW_COMPARE(H,G);\n#endif\n}highp float hN(sampler2D hL,highp vec3 hA,float hO){highp vec2 l=uShadowKernelRotation*hO;float s;s=hK(hL,hA.xy+l,hA.z);s+=hK(hL,hA.xy-l,hA.z);s+=hK(hL,hA.xy+vec2(-l.y,l.x),hA.z);s+=hK(hL,hA.xy+vec2(l.y,-l.x),hA.z);s*=0.25;return s*s;}struct ev{float eL[LIGHT_COUNT];};void eB(out ev ss,float hO){highp vec3 hP[SHADOW_COUNT];vec3 hu=gl_FrontFacing?dC:-dC;for(int k=0;k<SHADOW_COUNT;++k){vec4 hQ=uShadowTexelPadProjections[k];float hR=hQ.x*dv.x+(hQ.y*dv.y+(hQ.z*dv.z+hQ.w));\n#ifdef MOBILE\nhR*=.001+hO;\n#else\nhR*=.0005+0.5*hO;\n#endif\nhighp vec4 hS=h(uShadowMatrices[k],dv+hR*hu);hP[k]=hS.xyz/hS.w;}float m;\n#if SHADOW_COUNT > 0\nm=hN(tDepth0,hP[0],hO);ss.eL[0]=SHADOW_CLIP(hP[0].xy,m);\n#endif\n#if SHADOW_COUNT > 1\nm=hN(tDepth1,hP[1],hO);ss.eL[1]=SHADOW_CLIP(hP[1].xy,m);\n#endif\n#if SHADOW_COUNT > 2\nm=hN(tDepth2,hP[2],hO);ss.eL[2]=SHADOW_CLIP(hP[2].xy,m);\n#endif\nfor(int k=SHADOW_COUNT;k<LIGHT_COUNT;++k){ss.eL[k]=1.0;}}struct eD{highp float eE[LIGHT_COUNT];};\n#ifdef MOBILE\nvoid eG(out eD ss,float hO){for(int k=0;k<LIGHT_COUNT;++k){ss.eE[k]=1.0;}}\n#else\nhighp vec4 hT(sampler2D hL,highp vec2 hA,highp mat4 hU){highp vec4 E;E.xy=hA;\n#ifndef MOBILE\nhighp vec2 c=hA*uShadowMapSize.x;highp vec2 a=floor(c)*uShadowMapSize.y,b=ceil(c)*uShadowMapSize.y;highp vec4 hM;hM.x=hJ(texture2D(hL,a).xyz);hM.y=hJ(texture2D(hL,vec2(b.x,a.y)).xyz);hM.z=hJ(texture2D(hL,vec2(a.x,b.y)).xyz);hM.w=hJ(texture2D(hL,b).xyz);highp vec2 w=c-a*uShadowMapSize.x;vec2 s=(w.y*hM.zw+hM.xy)-w.y*hM.xy;E.z=(w.x*s.y+s.x)-w.x*s.x;\n#else \nE.z=hJ(texture2D(hL,hA.xy).xyz);\n#endif\nE=h(hU,E.xyz);E.xyz/=E.w;return E;}void eG(out eD ss,float hO){highp vec3 hV[SHADOW_COUNT];vec3 hu=gl_FrontFacing?dC:-dC;hu*=0.6;for(int k=0;k<SHADOW_COUNT;++k){vec4 hQ=uShadowTexelPadProjections[k];float hR=hQ.x*dv.x+(hQ.y*dv.y+(hQ.z*dv.z+hQ.w));\n#ifdef MOBILE\nhR*=.001+hO;\n#else\nhR*=.0005+0.5*hO;\n#endif\nhighp vec4 hS=h(uShadowMatrices[k],dv-hR*hu);hV[k]=hS.xyz/hS.w;}highp vec4 hW;\n#if SHADOW_COUNT > 0\nhW=hT(tDepth0,hV[0].xy,uInvShadowMatrices[0]);ss.eE[0]=length(dv.xyz-hW.xyz);\n#endif\n#if SHADOW_COUNT > 1\nhW=hT(tDepth1,hV[1].xy,uInvShadowMatrices[1]);ss.eE[1]=length(dv.xyz-hW.xyz);\n#endif\n#if SHADOW_COUNT > 2\nhW=hT(tDepth2,hV[2].xy,uInvShadowMatrices[2]);ss.eE[2]=length(dv.xyz-hW.xyz);\n#endif\nfor(int k=SHADOW_COUNT;k<LIGHT_COUNT;++k){ss.eE[k]=1.0;}}\n#endif\n#endif\n",
  6487. "matskin.glsl": "\n#ifdef SKIN\n#ifndef SKIN_NO_SUBDERMIS_TEX\nuniform vec4 uTexRangeSubdermis;\n#endif\n#ifndef SKIN_NO_TRANSLUCENCY_TEX\nuniform vec4 uTexRangeTranslucency;\n#endif\n#ifndef SKIN_NO_FUZZ_TEX\nuniform vec4 uTexRangeFuzz;\n#endif\nuniform vec4 uTransColor;uniform vec4 uFresnelColor;uniform vec3 uSubdermisColor;uniform float uTransScatter;uniform float uFresnelOcc;uniform float uFresnelGlossMask;uniform float uTransSky;uniform float uFresnelIntegral;uniform float uTransIntegral;uniform float uSkinTransDepth;uniform float uSkinShadowBlur;uniform float uNormalSmooth;struct dX{vec3 hX;vec3 hY,hZ,ic,he;vec3 ec,eh,id;vec3 ie;vec3 ih;vec3 ii;vec3 ij;float ik;float il;float im;float eC;};void dZ(out dX s){vec4 m;\n#ifdef SKIN_NO_SUBDERMIS_TEX\ns.hX=uSubdermisColor;s.im=1.0;\n#else \nm=dM(d,uTexRangeSubdermis);s.hX=dG(m.xyz);s.im=m.w*m.w;\n#endif\ns.ij=uTransColor.rgb;s.ik=uTransScatter;\n#ifdef SKIN_VERSION_1\ns.eC=uSkinShadowBlur*s.im;\n#else \ns.il=max(max(s.ij.r,s.ij.g),s.ij.b)*uTransColor.a;float io=max(s.hX.r,max(s.hX.g,s.hX.b));io=1.0-io;io*=io;io*=io;io*=io;io=1.0-(io*io);s.im*=io;s.eC=uSkinShadowBlur*s.im*dot(s.hX.rgb,vec3(0.333,0.334,0.333));\n#endif\n#ifndef SKIN_NO_TRANSLUCENCY_TEX\nm=dM(d,uTexRangeTranslucency);s.ij*=dG(m.xyz);\n#endif\ns.ie=hF(tNormal,d,uNormalSmooth*s.im);vec3 iu,iv,iA;fK(iu,iv,iA,s.ie);s.eh=s.hY=iu+iv+iA;\n#ifdef SKIN_VERSION_1 \ns.ec=fQ(iu,iv,iA,vec3(1.0,0.6667,0.25),s.hX);\n#else\ns.ec=fQ(iu,iv,iA,vec3(1.0,0.6667,0.25),s.hX*0.2+vec3(0.1));\n#endif\n#ifdef SKIN_VERSION_1\nvec3 iB,iC,iD;fK(iB,iC,iD,-s.ie);s.id=fO(iB,iC,iD,vec3(1.0,0.4444,0.0625),s.ik);s.id*=uTransSky;\n#else \ns.id=vec3(0.0);\n#endif\ns.hZ=s.ic=s.he=vec3(0.0);s.hX*=0.5;s.ik*=0.5;s.ih=uFresnelColor.rgb;s.ii=uFresnelColor.aaa*vec3(1.0,0.5,0.25);\n#ifndef SKIN_NO_FUZZ_TEX\nm=dM(d,uTexRangeFuzz);s.ih*=dG(m.rgb);\n#endif\n}void eK(inout dX s,float iE,float iF,vec3 eH,vec3 dI,vec3 eJ){float fk=dot(eH,dI);float fl=dot(eH,s.ie);float eN=saturate((1.0/3.1415926)*fk);float hi=iE*iE;hi*=hi;hi=saturate(6.0*hi);\n#ifdef SKIN_VERSION_1 \nvec3 iG=fB(fl,s.hX);\n#else \nvec3 iG=fj(fk,fl,s.hX);\n#endif\nfloat iH=fA(-fl,s.ik);vec3 ic=vec3(iH*iH);\n#ifdef SKIN_VERSION_1\n#ifdef SHADOW_COUNT\nvec3 iI=vec3(iE);float iJ=saturate(hi-2.0*(iE*iE));iI+=iJ*s.hX;float iK=iE;\n#endif\n#else\n#ifdef SHADOW_COUNT\nvec3 iI;highp vec3 iL=(0.995*s.hX)+vec3(0.005,0.005,0.005);highp vec3 iM=vec3(1.0)-iL;iL=mix(iL,iM,iE);float iN=sqrt(iE);vec3 iO=2.0*vec3(1.0-iN);iN=1.0-iN;iN=(1.0-iN*iN);iI=saturate(pow(iL*iN,iO));highp float iP=0.35/(uSkinTransDepth+0.001);highp float iQ=saturate(iF*iP);iQ=saturate(1.0-iQ);iQ*=iQ;highp vec3 iR=vec3((-3.0*iQ)+3.15);highp vec3 iS=(0.9975*s.ij)+vec3(0.0025,0.0025,0.0025);highp float io=saturate(10.0*dot(iS,iS));vec3 iK=pow(iS*iQ,iR)*io;\n#else \nic=vec3(0.0);\n#endif\n#endif\nfloat hj=fA(fl,s.ii.z);\n#ifdef SHADOW_COUNT\nvec3 hk=mix(vec3(1.0),iI,uFresnelOcc);vec3 he=hj*hk;\n#else\nvec3 he=vec3(hj);\n#endif\n#ifdef SHADOW_COUNT\niG*=iI;eN*=hi;ic*=iK;\n#endif\ns.he=he*eJ+s.he;s.ic=ic*eJ+s.ic;s.hZ=iG*eJ+s.hZ;s.hY=eN*eJ+s.hY;}void eQ(out vec3 ei,out vec3 diff_extra,inout dX s,vec3 dO,vec3 dI,float dQ){s.he*=uFresnelIntegral;float fH=dot(dO,dI);vec2 hl=fG(vec2(fH,fH),s.ii.xy);s.he=s.eh*hl.x+(s.he*hl.y);s.he*=s.ih;float hm=saturate(1.0+-uFresnelGlossMask*dQ);s.he*=hm*hm;s.ic=s.ic*uTransIntegral;\n#ifdef SKIN_VERSION_1\ns.hZ=(s.hZ*fD(s.hX))+s.ec;\n#else\ns.hZ=(s.hZ*fv(s.hX))+s.ec;\n#endif\nei=mix(s.hY,s.hZ,s.im);\n#ifdef SKIN_VERSION_1\ns.ic=(s.ic+s.id)*s.ij;diff_extra=(s.he+s.ic)*s.im;\n#else\nei+=s.ic*s.il;diff_extra=s.he*s.im;\n#endif\n}\n#endif\n",
  6488. "matstrips.glsl": "\n#ifdef STRIPVIEW\nuniform float uStrips[5];uniform vec2 uStripRes;struct dT{float io[5];float bg;};void dV(out dT iT,inout float dQ,inout vec3 dP){highp vec2 hA=gl_FragCoord.xy*uStripRes-vec2(1.0,1.0);hA.x+=0.25*hA.y;iT.io[0]=step(hA.x,uStrips[0]);iT.io[1]=step(hA.x,uStrips[1]);iT.io[2]=step(hA.x,uStrips[2]);iT.io[3]=step(hA.x,uStrips[3]);iT.io[4]=step(hA.x,uStrips[4]);iT.bg=1.0-iT.io[4];iT.io[4]-=iT.io[3];iT.io[3]-=iT.io[2];iT.io[2]-=iT.io[1];iT.io[1]-=iT.io[0];bool iU=iT.io[4]>0.0;dQ=iU?0.5:dQ;dP=iU?vec3(0.1):dP;}vec3 eX(dT iT,vec3 dI,vec3 dF,vec3 dP,float dQ,vec3 ei,vec3 el,vec3 iV){return iT.io[0]*(dI*0.5+vec3(0.5))+iT.io[1]*dF+iT.io[2]*dP+vec3(iT.io[3]*dQ)+iT.io[4]*(vec3(0.12)+0.3*ei+el)+iT.bg*iV;}\n#endif\n",
  6489. "matvert.glsl": "precision highp float;uniform mat4 uModelViewProjectionMatrix;uniform mat4 uSkyMatrix;uniform vec2 uUVOffset;attribute vec3 vPosition;attribute vec2 vTexCoord;attribute vec2 vTangent;attribute vec2 vBitangent;attribute vec2 vNormal;\n#ifdef VERTEX_COLOR\nattribute vec4 vColor;\n#endif\n#ifdef TEXCOORD_SECONDARY\nattribute vec2 vTexCoord2;\n#endif\nvarying highp vec3 dv;varying mediump vec2 d;varying mediump vec3 dA;varying mediump vec3 dB;varying mediump vec3 dC;\n#ifdef VERTEX_COLOR\nvarying lowp vec4 dD;\n#endif\n#ifdef TEXCOORD_SECONDARY\nvarying mediump vec2 dE;\n#endif\nvec3 iW(vec2 v){bool iX=(v.y>(32767.1/65535.0));v.y=iX?(v.y-(32768.0/65535.0)):v.y;vec3 r;r.xy=(2.0*65535.0/32767.0)*v-vec2(1.0);r.z=sqrt(clamp(1.0-dot(r.xy,r.xy),0.0,1.0));r.z=iX?-r.z:r.z;return r;}vec4 h(mat4 i,vec3 p){return i[0]*p.x+(i[1]*p.y+(i[2]*p.z+i[3]));}vec3 u(mat4 i,vec3 v){return i[0].xyz*v.x+i[1].xyz*v.y+i[2].xyz*v.z;}void main(void){gl_Position=h(uModelViewProjectionMatrix,vPosition.xyz);d=vTexCoord+uUVOffset;dA=u(uSkyMatrix,iW(vTangent));dB=u(uSkyMatrix,iW(vBitangent));dC=u(uSkyMatrix,iW(vNormal));dv=h(uSkyMatrix,vPosition.xyz).xyz;\n#ifdef VERTEX_COLOR\ndD=vColor;\n#endif\n#ifdef TEXCOORD_SECONDARY\ndE=vTexCoord2;\n#endif\n}",
  6490. "postaa.glsl": "precision mediump float;uniform sampler2D tInput;varying vec2 j;void main(void){gl_FragColor=texture2D(tInput,j);}",
  6491. "postfrag.glsl": "precision mediump float;uniform sampler2D tInput;\n#ifdef BLOOM\nuniform sampler2D tBloom;\n#endif\n#ifdef GRAIN\nuniform sampler2D tGrain;\n#endif\n#ifdef COLOR_LUT\nuniform sampler2D tLUT;\n#endif\nuniform vec3 uScale;uniform vec3 uBias;uniform vec3 uSaturation;uniform vec4 uSharpenKernel;uniform vec3 uSharpness;uniform vec3 uBloomColor;uniform vec4 uVignetteAspect;uniform vec4 uVignette;uniform vec4 uGrainCoord;uniform vec2 uGrainScaleBias;varying vec2 j;vec3 iY(vec3 c){vec3 iZ=sqrt(c);return(iZ-iZ*c)+c*(0.4672*c+vec3(0.5328));}void main(void){vec4 jc=texture2D(tInput,j);vec3 c=jc.xyz;\n#ifdef SHARPEN\nvec3 hM=texture2D(tInput,j+uSharpenKernel.xy).xyz;hM+=texture2D(tInput,j-uSharpenKernel.xy).xyz;hM+=texture2D(tInput,j+uSharpenKernel.zw).xyz;hM+=texture2D(tInput,j-uSharpenKernel.zw).xyz;vec3 jd=uSharpness.x*c-uSharpness.y*hM;c+=clamp(jd,-uSharpness.z,uSharpness.z);\n#endif\n#ifdef BLOOM\nc+=uBloomColor*texture2D(tBloom,j).xyz;\n#endif\n#ifdef VIGNETTE\nvec2 je=j*uVignetteAspect.xy-uVignetteAspect.zw;vec3 v=clamp(vec3(1.0,1.0,1.0)-uVignette.xyz*dot(je,je),0.0,1.0);vec3 jf=v*v;jf*=v;c*=mix(v,jf,uVignette.w);\n#endif\n#ifdef SATURATION\nfloat gray=dot(c,vec3(0.3,0.59,0.11));c=mix(vec3(gray,gray,gray),c,uSaturation);\n#endif\n#ifdef CONTRAST\nc=c*uScale+uBias;\n#endif\n#ifdef GRAIN\nfloat jh=uGrainScaleBias.x*texture2D(tGrain,j*uGrainCoord.xy+uGrainCoord.zw).x+uGrainScaleBias.y;c+=c*jh;\n#endif\n#ifdef REINHARD\n{c*=1.8;float ji=dot(c,vec3(0.3333));c=clamp(c/(1.0+ji),0.0,1.0);}\n#elif defined(HEJL)\n{const highp float jj=0.22,jk=0.3,jl=.1,jm=0.2,jn=.01,jo=0.3;const highp float ju=1.25;highp vec3 eO=max(vec3(0.0),c-vec3(.004));c=(eO*((ju*jj)*eO+ju*vec3(jl*jk,jl*jk,jl*jk))+ju*vec3(jm*jn,jm*jn,jm*jn))/(eO*(jj*eO+vec3(jk,jk,jk))+vec3(jm*jo,jm*jo,jm*jo))-ju*vec3(jn/jo,jn/jo,jn/jo);}\n#endif\n#ifdef COLOR_LUT\nc=clamp(c,0.0,1.0);c=(255.0/256.0)*c+vec3(0.5/256.0);c.x=texture2D(tLUT,c.xx).x;c.y=texture2D(tLUT,c.yy).y;c.z=texture2D(tLUT,c.zz).z;c*=c;\n#endif\ngl_FragColor.xyz=iY(c);gl_FragColor.w=jc.w;}",
  6492. "postvert.glsl": "precision highp float;attribute vec2 vCoord;varying vec2 j;void main(void){j=vCoord;gl_Position.xy=2.0*vCoord-vec2(1.0,1.0);gl_Position.zw=vec2(0.0,1.0);}",
  6493. "shadowfloorfrag.glsl": "precision mediump float;varying highp vec3 dv;varying mediump vec2 jv;varying mediump vec3 dC;uniform vec3 uShadowCatcherParams;\n#ifdef LIGHT_COUNT\nuniform vec4 uLightPositions[LIGHT_COUNT];uniform vec3 uLightDirections[LIGHT_COUNT];uniform vec3 uLightColors[LIGHT_COUNT];uniform vec3 uLightParams[LIGHT_COUNT];uniform vec3 uLightSpot[LIGHT_COUNT];\n#endif\n#define saturate(x) clamp( x, 0.0, 1.0 )\n#define SHADOW_COMPARE(a,b) ((a) < (b) || (b) >= 1.0 ? 1.0 : 0.0)\n#define SHADOW_CLIP(c,v) ((c.x<0.0 || c.x>1.0 || c.y<0.0 || c.y>1.0) ? 1.0 : v)\n#include <matshadows.glsl>\nvoid main(void){ev eA;eB(eA,SHADOW_KERNEL);vec3 jA=vec3(0.0,0.0,0.0);vec3 jB=vec3(0.0,0.0,0.0);for(int k=0;k<SHADOW_COUNT;++k){vec3 eH=uLightPositions[k].xyz-dv*uLightPositions[k].w;float eI=inversesqrt(dot(eH,eH));eH*=eI;float a=saturate(uLightParams[k].z/eI);a=1.0+a*(uLightParams[k].x+uLightParams[k].y*a);float s=saturate(dot(eH,uLightDirections[k]));s=saturate(uLightSpot[k].y-uLightSpot[k].z*(1.0-s*s));vec3 jC=mix(uLightColors[k].xyz,vec3(1.0,1.0,1.0),uShadowCatcherParams.x);vec3 jD=(a*s)*jC;jD*=saturate(dot(eH,dC));jB+=jD;jA+=jD*eA.eL[k];}float jE=1.0e-4;vec3 r=(jA+jE)/(jB+jE);float jF=saturate(dot(jv,jv))*uShadowCatcherParams.z;r=mix(r,vec3(1.0,1.0,1.0),jF);r=mix(vec3(1.0,1.0,1.0),r,uShadowCatcherParams.y);gl_FragColor.xyz=r;gl_FragColor.w=1.0;}",
  6494. "shadowfloorvert.glsl": "precision highp float;uniform mat4 uModelViewProjectionMatrix;uniform mat4 uModelSkyMatrix;uniform float uScale;attribute vec3 vPosition;varying highp vec3 dv;varying mediump vec2 jv;varying mediump vec3 dC;vec4 h(mat4 i,vec3 p){return i[0]*p.x+(i[1]*p.y+(i[2]*p.z+i[3]));}void main(void){jv=vPosition.xz;dC=normalize(uModelSkyMatrix[1].xyz);dv=h(uModelSkyMatrix,vPosition).xyz;gl_Position=h(uModelViewProjectionMatrix,vPosition);}",
  6495. "shadowfrag.glsl": "precision highp float;varying vec2 jG;\n#ifdef ALPHA_TEST\nvarying mediump vec2 d;uniform sampler2D tAlbedo;\n#endif\nvec3 jH(float v){vec4 jI=vec4(1.0,255.0,65025.0,16581375.0)*v;jI=fract(jI);jI.xyz-=jI.yzw*(1.0/255.0);return jI.xyz;}void main(void){\n#ifdef ALPHA_TEST\nfloat e=texture2D(tAlbedo,d).a;if(e<0.5){discard;}\n#endif\n#ifdef SHADOW_NATIVE_DEPTH\ngl_FragColor.xyz=vec3(0.0,0.0,0.0);\n#else\ngl_FragColor.xyz=jH((jG.x/jG.y)*0.5+0.5);\n#endif\ngl_FragColor.w=0.0;}",
  6496. "shadowvert.glsl": "precision highp float;attribute vec3 vPosition;attribute vec2 vTexCoord;uniform mat4 uMeshTransform;uniform mat4 uViewProjection;varying vec2 jG;\n#ifdef ALPHA_TEST\nvarying mediump vec2 d;uniform vec2 uUVOffset;\n#endif\nvec4 h(mat4 i,vec3 p){return i[0]*p.x+(i[1]*p.y+(i[2]*p.z+i[3]));}void main(void){vec3 p=h(uMeshTransform,vPosition).xyz;gl_Position=h(uViewProjection,p);jG=gl_Position.zw;\n#ifdef ALPHA_TEST\nd=vTexCoord+uUVOffset;\n#endif\n}",
  6497. "sky.glsl": "precision highp float;uniform sampler2D tSkyTexture;uniform float uAlpha;varying vec2 d;void main(void){vec3 r=texture2D(tSkyTexture,d).xyz;gl_FragColor.xyz=r*r;gl_FragColor.w=uAlpha;}",
  6498. "skySH.glsl": "precision mediump float;uniform vec4 uSkyCoefficients[9];uniform float uAlpha;varying vec3 jJ;void main(void){vec3 G=normalize(jJ);vec3 r=uSkyCoefficients[0].xyz;r+=uSkyCoefficients[1].xyz*G.y;r+=uSkyCoefficients[2].xyz*G.z;r+=uSkyCoefficients[3].xyz*G.x;vec3 swz=G.yyz*G.xzx;r+=uSkyCoefficients[4].xyz*swz.x;r+=uSkyCoefficients[5].xyz*swz.y;r+=uSkyCoefficients[7].xyz*swz.z;vec3 sqr=G*G;r+=uSkyCoefficients[6].xyz*(3.0*sqr.z-1.0);r+=uSkyCoefficients[8].xyz*(sqr.x-sqr.y);gl_FragColor.xyz=r;gl_FragColor.w=uAlpha;}",
  6499. "skyvert.glsl": "precision highp float;uniform mat4 uInverseSkyMatrix;uniform mat4 uViewProjection;attribute vec3 vPosition;attribute vec2 vTexCoord;\n#if SKYMODE == 3\nvarying vec3 jJ;\n#else\nvarying vec2 d;\n#endif\nvec4 h(mat4 i,vec3 p){return i[0]*p.x+(i[1]*p.y+(i[2]*p.z+i[3]));}vec4 u(mat4 i,vec3 v){return i[0]*v.x+i[1]*v.y+i[2]*v.z;}void main(void){vec3 p=h(uInverseSkyMatrix,vPosition).xyz;gl_Position=u(uViewProjection,p);gl_Position.z-=(1.0/65535.0)*gl_Position.w;\n#if SKYMODE == 3\njJ=vPosition;jJ.xy+=1e-20*vTexCoord;\n#else\nd=vTexCoord;\n#endif\n}",
  6500. "wirefrag.glsl": "precision highp float;uniform vec4 uStripParams;void main(void){vec2 c=gl_FragCoord.xy*uStripParams.xy-vec2(1.0,1.0);c.x+=0.25*c.y;float a=c.x<uStripParams.z?0.0:0.9;a=c.x<uStripParams.w?a:0.0;gl_FragColor=vec4(0.0,0.0,0.0,a);}",
  6501. "wirevert.glsl": "precision highp float;uniform mat4 uModelViewProjectionMatrix;attribute vec3 vPosition;vec4 h(mat4 i,vec3 p){return i[0]*p.x+(i[1]*p.y+(i[2]*p.z+i[3]));}void main(void){gl_Position=h(uModelViewProjectionMatrix,vPosition);gl_Position.z+=-0.00005*gl_Position.w;}",
  6502. nil: ""
  6503. }
  6504. }(fdage);