12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060 |
- /**
- * Jeeliz Face Filter - https://github.com/jeeliz/jeelizFaceFilter
- *
- * Copyright 2020 WebAR.rocks ( https://webar.rocks )
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- /* eslint-enable */
- /* prettier-ignore */
- const JEELIZFACEFILTERGEN = function() {
- function Fb(a) {
- var c = null,
- d = null,
- e = null,
- g = 0;
- this.o = function(m) {
- this.Ff(m.pb);
- e.we({
- pc: m.pc,
- mc: m.mc
- })
- };
- this.Se = function(m) {
- return c[m]
- };
- this.Ff = function(m) {
- var t = null;
- g = m.length;
- c = m.map(function(p, q) {
- p = Object.assign({}, p, {
- index: q,
- parent: this,
- vb: t,
- ef: q === g - 1
- });
- return t = q = 0 === q ? Gb.instance(p) : Hb.instance(p)
- });
- d = c[0];
- e = c[g - 1];
- c.forEach(function(p, q) {
- 0 !== q && p.vf()
- })
- };
- this.T = function(m) {
- m.g(0);
- var t = m;
- c.forEach(function(p) {
- t = p.T(t, !1)
- });
- return t
- };
- this.Re = function() {
- return d.F()
- };
- this.Vb = function() {
- return e.Ue()
- };
- this.gd = function() {
- return e.gd()
- };
- this.m = function() {
- c && (c.forEach(function(m) {
- m.m()
- }), e = d = c = null, g = 0)
- };
- "undefined" !== typeof a && this.o(a)
- }
- function eb(a, c) {
- var d = c % 8;
- return a[(c - d) / 8] >> 7 - d & 1
- }
- function Ib(a) {
- var c = JSON.parse(a);
- a = c.ne;
- var d = c.nf,
- e = c.n;
- var g = "undefined" === typeof btoa ? Buffer.from(c.data, "base64")
- .toString("latin1") : atob(c.data);
- var m = g.length;
- c = new Uint8Array(m);
- for(var t = 0; t < m; ++t) c[t] = g.charCodeAt(t);
- g = new Float32Array(e);
- m = new Float32Array(d);
- t = a + d +
- 1;
- for(var p = 0; p < e; ++p) {
- for(var q = t * p, u = 0 === eb(c, q) ? 1 : -1, r = q + 1, A = 1, v = 0, n = r + a - 1; n >= r; --n) v += A * eb(c, n), A *= 2;
- r = v;
- q = q + 1 + a;
- A = m.length;
- v = 0;
- for(n = q; n < q + A; ++n) m[v] = eb(c, n, !0), ++v;
- for(A = q = 0; A < d; ++A) q += m[A] * Math.pow(2, -A - 1);
- g[p] = 0 === q && 0 === r ? 0 : u * (1 + q) * Math.pow(2, 1 + r - Math.pow(2, a - 1))
- }
- return g
- }
- function Ya() {
- return -1 !== [ia.ready, ia.play, ia.pause].indexOf(na)
- }
- function fb() {
- if(na === ia.play) return !1;
- na = ia.play;
- Na.stop();
- rb(0)
- }
- function sb() {
- if(na !== ia.play) return !1;
- qa.stop();
- Na.stop();
- na = ia.pause;
- return !0
- }
- function Ea(a,
- c, d, e, g) {
- a = 4 * (3 * c + a) + d;
- return e + (U.buffer[a] / 255 + U.buffer[a + 12] / 65025) * (g - e)
- }
- function gb() {
- b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, !1);
- Ha.Ye()
- }
- function Jb() {
- var a = da.na();
- va.O();
- b.viewport(0, 0, 3, 2 * a);
- D.set("s53");
- U.ta.g(0);
- T.l(!1, !1);
- return aa.xb(0, 0, 3, 2 * a, U.buffer, tb)
- }
- function rb() {
- na !== ia.pause && (ba.isCleanGLStateAtEachIteration && (D.Wc(), T.reset(), T.va(), b.disable(b.DEPTH_TEST), b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, !1), D.Ca()), qa.qc(Kb, Jb, Lb, tb, Mb, ba.animateProcessOrder))
- }
- function Kb() {
- va.ca();
- if(!G.kb)
- if(G.jb) G.element.needsUpdate &&
- (G.K.Sd(G.element.videoWidth, G.element.videoHeight), G.K.Db(G.element.arrayBuffer), G.element.needsUpdate = !1);
- else {
- var a = G.element.currentTime,
- c = a - G.wb;
- 0 > c && (G.wb = a, c = 0);
- 1E3 * c < ea.Xf || (G.wb += c, G.K.refresh())
- } a = qa.Te();
- da.update(a, Fa);
- for(c = 0; c < a; ++c) {
- da.Bb(c);
- D.set("s55");
- var d = Fa[da.hd()];
- D.G("u43", 1 + Oa.rc * (Math.cos(d.ry) - 1));
- Q.wa && D.G("u42", d.rz);
- da.Yd("u41");
- Z.Oa.$();
- G.K.g(0);
- U.ta.g(1);
- T.l(!1, !1);
- Pa.T(Z.Oa)
- }
- qa.Bb()
- }
- function tb() {
- va.Uf();
- ba.isCleanGLStateAtEachIteration && (va.reset(), X.reset(), b.enable(b.DEPTH_TEST));
- Q.Gb && Q.Gb(da.yd() ? Fa : Fa[0]);
- ba.isCleanGLStateAtEachIteration && (b.disable(b.BLEND), T.reset(), T.va())
- }
- function Lb() {
- for(var a = 0; a < da.na(); ++a)
- if(da.jf(a)) {
- var c = a,
- d = Sa[c],
- e = [c],
- g = Fa[c],
- m = hb[c],
- t = 2 * c;
- d.Xa = Ea(1, t, 3, 0, 1);
- g.detected = wa.X(g.detected, d.Xa, ea.ee);
- d.x = Ea(0, t, 1, -1, 1);
- d.y = Ea(0, t, 2, -1, 1);
- d.ja = Ea(0, t, 3, 0, 1);
- if(d.Xa < ba.multiDetectionThresholdFactors[0] * ba.threshold) d.qa = Math.floor(d.qa / 2), Q.wa && (g.rz = 0, g.ry = 0);
- else {
- var p = U.Qa;
- d.rx = Ea(1, t, 0, -p[0], p[0]);
- d.ry = Ea(1, t, 1, -p[1], p[1]);
- d.Ra = Ea(1, t, 2, -p[2],
- p[2]);
- for(p = 0; p < U.Y; ++p) d.cd[p] = U.Na[p](Ea(2, t, p, 0, 1));
- t = d.ja * U.Nd;
- e.dx = d.x - g.xRaw;
- e.dy = d.y - g.yRaw;
- e.Pb = t - g.sRaw;
- e.Mb = d.rx - g.rx;
- e.Nb = d.ry - g.ry;
- e.Ob = Q.wa ? d.Ra : d.Ra - g.rz;
- p = qa.Me();
- e = (1 - Za.qb(ra.translationFactorRange[0], ra.translationFactorRange[1], Math.sqrt(e.dx * e.dx + e.dy * e.dy + e.Pb * e.Pb) / p)) * (1 - Za.qb(ra.rotationFactorRange[0], ra.rotationFactorRange[1], Math.sqrt(e.Mb * e.Mb + e.Nb * e.Nb + e.Ob * e.Ob) / p)) * Za.qb(ra.qualityFactorRange[0], ra.qualityFactorRange[1], d.Xa);
- c = m[++ib[c] % m.length] = e;
- for(p = 0; p < m.length; ++p) c =
- Math.min(c, m[p]);
- c = Math.max(.5, c);
- e = Math.min(c, e);
- m = wa.X(ra.alphaRange[1], ra.alphaRange[0], Math.pow(e, ea.ge));
- g.xRaw = wa.X(g.xRaw, d.x, m);
- g.yRaw = wa.X(g.yRaw, d.y, m);
- g.sRaw = wa.X(g.sRaw, t, m);
- g.rx = wa.X(g.rx, d.rx, m);
- g.ry = wa.X(g.ry, d.ry, m);
- g.rz = Q.wa ? g.rz + ra.followZRotAlphaFactor * m * d.Ra : wa.X(g.rz, d.Ra, m);
- c = g.sRaw * Oa.Lb * Math.sin(g.ry);
- t = Math.sin(g.rz) * c / Qa;
- g.x = g.xRaw + Math.cos(g.rz) * c;
- g.y = g.yRaw + t;
- g.s = g.sRaw;
- m = Math.max(m, ea.fe);
- for(c = 0; c < U.Y; ++c) g.expressions[c] = wa.X(g.expressions[c], d.cd[c], m);
- ++d.qa
- }
- }
- }
- function Mb() {
- na ===
- ia.play && Na.qc(rb)
- }
- function ub() {
- Z.Oa = X.instance({
- isPot: !0,
- isFloat: !1,
- width: Pa.Re()
- });
- var a = {
- width: ea.Vd,
- height: da.na(),
- isFloat: !0,
- isPot: !1,
- array: da.Ce(new Float32Array([0, .5, .5, 0, 0, 0, 0, 0, 0, 0, 0, 0]))
- };
- U.ta = Nb.instance(a)
- }
- function jb() {
- D.S("s55", [{
- type: "1i",
- name: "u1",
- value: 0
- }, {
- type: "1i",
- name: "u39",
- value: 1
- }, {
- type: "2f",
- name: "u40",
- value: Z.D
- }, {
- type: "1f",
- name: "u41",
- value: .5
- }, {
- type: "1f",
- name: "u42",
- value: 0
- }]);
- D.S("s56", [{
- type: "1i",
- name: "u44",
- value: 0
- }, {
- type: "1i",
- name: "u39",
- value: 1
- }, {
- type: "1f",
- name: "u47",
- value: ea.Sf
- },
- {
- type: "1f",
- name: "u48",
- value: ba.threshold
- }, {
- type: "3f",
- name: "u46",
- value: [U.N[0] * Z.D[0], U.N[1] * Z.D[1], U.N[2]]
- }, {
- type: "1f",
- name: "u41",
- value: .5
- }, {
- type: "1f",
- name: "u49",
- value: 1
- }, {
- type: "1f",
- name: "u42",
- value: 0
- }
- ]);
- var a = [{
- type: "1i",
- name: "u44",
- value: 0
- }];
- D.S("s57", a);
- D.S("s58", a);
- D.S("s53", [{
- type: "1i",
- name: "u39",
- value: 0
- }, {
- type: "1f",
- name: "u52",
- value: Z.D[0]
- }, {
- type: "2f",
- name: "u51",
- value: [0, .5 / da.na()]
- }])
- }
- function kb() {
- Z.D[0] = 1;
- Z.D[1] = Z.C / Z.L;
- vb.o({
- ub: ba.overlapFactors,
- Ed: ba.nScaleLevels,
- C: Z.C,
- L: Z.L,
- Md: ba.scale0Factor,
- N: U.N,
- Od: ba.scanCenterFirst
- })
- }
- function Ob(a) {
- if(Q.Fa) wb("string" === typeof Q.Fa ? JSON.parse(Q.Fa) : Q.Fa, a);
- else {
- var c = Q.Gc;
- "JSON" !== c.toUpperCase()
- .split(".")
- .pop() && (c += ea.neuralNetworkPath);
- $a.get(c, function(d) {
- d = JSON.parse(d);
- wb(d, a)
- })
- }
- }
- function wb(a, c) {
- if(a.exportData) {
- var d = a.exportData;
- d.rotationEulerAnglesFactors && (U.Qa = d.rotationEulerAnglesFactors);
- if(d.translationScalingFactors) {
- var e = d.translationScalingFactors,
- g = ba.translationScalingFactors;
- U.N[0] = e[0] * g[0];
- U.N[1] = e[1] * g[1];
- U.N[2] = e[2] * g[2]
- }
- "undefined" !==
- typeof d.nExpressions && (U.Y = d.nExpressions);
- U.Nd = d.dsMean ? 1 + d.dsMean : 1;
- Oa.rc = .4;
- Oa.Lb = .7;
- "undefined" !== typeof d.fgScaleXFactor && (Oa.rc = d.fgScaleXFactor);
- "undefined" !== typeof d.fgDisplaceXFactor && (Oa.Lb = d.fgDisplaceXFactor)
- }
- U.Y || (U.Y = ea.Dd);
- if(!U.Na)
- for(U.Na = [], d = 0; d < U.Y; ++d) U.Na.push(ea.Ge);
- c(a)
- }
- function Pb() {
- if(Ha.o({
- Wa: Q.da,
- width: Z.C,
- height: Z.L,
- debug: !1,
- lc: function() {
- Ia("GLCONTEXT_LOST")
- },
- antialias: Q.antialias,
- premultipliedAlpha: !0
- })) return !0;
- Ia("GL_INCOMPATIBLE");
- return !1
- }
- function Qb() {
- var a = da.hd(),
- c = Fa[a];
- U.ta.Df(1);
- b.viewport(0, a, 1, 1);
- D.set("s56");
- Q.wa && D.G("u42", c.rz);
- da.Yd("u41");
- var d = 1,
- e = da.Nf(Sa, Z.C / Z.L);
- da.yd() && (e && (d = 0, Sa[a].qa = 0, c.isDetected = !1, c.detected = 0), D.G("u49", d));
- D.Jf("u45", vb.get(a));
- T.l(!1, !1);
- if(da.xd() || e) b.viewport(1, a, 1, 1), D.set("s57"), D.G("u49", d), T.l(!1, !1);
- da.xd() && (b.viewport(2, a, 1, 1), D.set("s58"), T.l(!1, !1));
- U.ta.sync()
- }
- function xb() {
- G.K && G.K.remove();
- G.jb = G.element.isFakeVideo ? !0 : !1;
- if(G.jb) {
- var a = yb();
- a = {
- isFlipY: !1,
- array: G.element.arrayBuffer,
- width: a.w,
- height: a.ya,
- isKeepArray: !0
- }
- } else a = {
- H: G.element
- };
- G.vc = X.instance(Object.assign({
- isPot: !1,
- isLinear: !0,
- isFloat: !1
- }, a));
- G.K = G.vc
- }
- function Ja() {
- var a = [{
- type: "mat2",
- name: "u38",
- value: G.v
- }];
- D.S("s54", [{
- type: "1i",
- name: "u1",
- value: 0
- }].concat(a));
- D.S("s55", a)
- }
- function Ka() {
- var a = [.5, .5],
- c = G.D[1] / G.D[0];
- Qa = Ha.U() / Ha.F();
- 90 === Math.abs(pa.rotate) && (c = 1 / c);
- c > Qa ? a[1] *= Qa / c : a[0] *= c / Qa;
- D.S("s56", [{
- name: "u50",
- type: "1f",
- value: Qa
- }]);
- G.v[0] = 0;
- G.v[1] = 0;
- G.v[2] = 0;
- G.v[3] = 0;
- switch (pa.rotate) {
- case 0:
- G.v[0] = a[0];
- G.v[3] = a[1];
- break;
- case 180:
- G.v[0] = -a[0];
- G.v[3] = -a[1];
- break;
- case 90:
- G.v[1] = a[0];
- G.v[2] = -a[1];
- break;
- case -90:
- G.v[1] = -a[0], G.v[2] = a[1]
- }
- pa.flipX && (G.v[0] *= -1, G.v[2] *= -1);
- G.kb || (G.v[1] *= -1, G.v[3] *= -1)
- }
- function yb() {
- var a = {
- w: G.element.videoWidth || G.element.width,
- ya: G.element.videoHeight || G.element.height
- };
- if(!a.w || !a.ya || 4 > a.w || 4 > a.ya) throw Error("INVALID VIDEO DIMENSIONS - width = " + a.w + " height = " + a.ya);
- return a
- }
- function lb() {
- var a = yb(),
- c = G.D[0] !== a.w || G.D[1] !== a.ya;
- c && (G.D[0] = a.w, G.D[1] = a.ya);
- return c
- }
- function ab(a, c) {
- if(na === ia.error) return !1;
- G.element = a;
- lb();
- c && c();
- return !0
- }
- function zb(a, c, d) {
- a && a();
- G.Ka = {
- video: {
- facingMode: {
- exact: pa.facingMode
- },
- width: {
- min: pa.minWidth,
- max: pa.maxWidth,
- ideal: pa.idealWidth
- },
- height: {
- min: pa.minHeight,
- max: pa.maxHeight,
- ideal: pa.idealHeight
- }
- },
- audio: !1
- };
- V.Ic(G.Ka, pa.deviceId);
- V.get(G.element ? G.element : V.ld(), function(e) {
- c && c(e);
- d(e)
- }, function() {
- Ia("WEBCAM_UNAVAILABLE")
- }, G.Ka)
- }
- function Ia(a) {
- na !== ia.error && (na = ia.error, Q.Ja && Q.Ja(a))
- }
- var wa = {
- Wg: function(a) {
- return Math.ceil(Math.log2(a))
- },
- sh: function(a) {
- return Math.log2(a)
- },
- oh: function(a) {
- return 0 === Math.log2(a) % 1
- },
- hg: function(a) {
- var c = [0, 0, 0, 0];
- a.forEach(function(d) {
- c[0] += d[0];
- c[1] += d[1];
- c[2] += d[2];
- c[3] += d[3]
- });
- return c
- },
- ig: function(a, c, d) {
- return Math.min(Math.max(a, c), d)
- },
- lg: function(a) {
- return a * Math.PI / 180
- },
- yh: function(a, c) {
- c = Math.pow(10, c);
- return Math.round(a * c) / c
- },
- zh: function(a) {
- return Math.round(1E6 * a) / 1E6
- },
- Xg: function(a, c) {
- return (100 * a / c)
- .toFixed(3)
- },
- X: function(a, c, d) {
- return a * (1 - d) + c * d
- },
- th: function(a, c) {
- return a[0] * (1 - c) + a[1] * c
- },
- Ae: function(a, c) {
- return wa.se(a -
- c)
- },
- se: function(a) {
- for(; a > Math.PI;) a -= 2 * Math.PI;
- for(; a <= -Math.PI;) a += 2 * Math.PI;
- return a
- },
- qg: function(a, c) {
- return Math.abs(wa.Ae(a, c))
- },
- Yf: function(a, c) {
- return Math.atan2(Math.sin(a) + Math.sin(c), Math.cos(a) + Math.cos(c))
- }
- },
- $a = {
- get: function(a, c, d) {
- var e = new XMLHttpRequest;
- e.open("GET", a, !0);
- e.withCredentials = !1;
- e.onreadystatechange = function() {
- 4 === e.readyState && (200 === e.status || 0 === e.status ? c(e.responseText) : "undefined" !== typeof d && d(e.status))
- };
- e.send()
- },
- Ve: function(a) {
- return new Promise(function(c,
- d) {
- $a.get(a, c, d)
- })
- },
- Tg: function(a, c, d) {
- a += d ? "?" + $a.Ee(d) : "";
- $a.get(a, function(e) {
- c(JSON.parse(e))
- })
- },
- vh: function(a, c, d) {
- var e = new XMLHttpRequest;
- e.open("POST", a, !0);
- e.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
- e.onreadystatechange = function() {
- 4 !== e.readyState || 200 !== e.status && 0 !== e.status || d(e.responseText)
- };
- e.send(c)
- },
- Ee: function(a) {
- return "string" === typeof a ? a : Object.keys(a)
- .map(function(c) {
- return encodeURIComponent(c) + "=" + encodeURIComponent(a[c])
- })
- .join("&")
- },
- Hg: function(a,
- c) {
- var d = new XMLHttpRequest;
- d.open("POST", a, !0);
- d.responseType = "arraybuffer";
- d.onload = function() {
- c(d.response)
- };
- d.send()
- }
- },
- Rb = {
- create: function(a, c) {
- for(var d = Array(c), e = 0; e < c; ++e) d[e] = a;
- return d
- },
- mg: function(a, c) {
- for(var d = 0; d < a.length; ++d) c[d] = a[d]
- },
- clone: function(a) {
- for(var c = Array(a.length), d = 0; d < a.length; ++d) c[d] = a[d];
- return c
- },
- Ch: function(a, c, d) {
- a.forEach(function(e, g) {
- c[g] = e * d
- })
- },
- Lh: function(a) {
- for(var c = a.length - 1; 0 < c; --c) {
- var d = Math.floor(Math.random() * (c + 1)),
- e = a[c];
- a[c] = a[d];
- a[d] = e
- }
- },
- Nh: function(a) {
- return a.sort(function(c,
- d) {
- return c - d
- })
- },
- Rf: function(a) {
- return Array.isArray(a) || a.constructor === Float32Array || a.constructor === Uint8Array
- }
- },
- mb = {
- Jb: function(a, c) {
- if(0 === c || "object" !== typeof a) return a;
- a = Object.assign({}, a);
- c = void 0 === c || -1 === c ? -1 : c - 1;
- for(var d in a) a[d] = mb.Jb(a[d], c);
- return a
- },
- pg: function(a) {
- return JSON.parse(JSON.stringify(a))
- }
- },
- Za = {
- Mh: function(a, c, d) {
- a = Math.min(Math.max((d - a) / (c - a), 0), 1);
- return a * a * (3 - 2 * a)
- },
- qb: function(a, c, d) {
- return Math.min(Math.max((d - a) / (c - a), 0), 1)
- },
- Bg: function(a, c, d, e) {
- return Math.pow(Math.min(Math.max((e -
- a) / (c - a), 0), 1), d)
- },
- Rh: function() {
- return 0
- },
- uh: function() {
- return 1
- },
- rh: function(a) {
- return a
- },
- yg: function(a) {
- return a * a
- },
- Dg: function(a) {
- return a * (2 - a)
- },
- vg: function(a) {
- return .5 > a ? 2 * a * a : -1 + (4 - 2 * a) * a
- },
- tg: function(a) {
- return a * a * a
- },
- Cg: function(a) {
- return --a * a * a + 1
- },
- ug: function(a) {
- return .5 > a ? 4 * a * a * a : (a - 1) * (2 * a - 2) * (2 * a - 2) + 1
- },
- zg: function(a) {
- return a * a * a * a
- },
- Eg: function(a) {
- return 1 - --a * a * a * a
- },
- wg: function(a) {
- return .5 > a ? 8 * a * a * a * a : 1 - 8 * --a * a * a * a
- },
- Ag: function(a) {
- return a * a * a * a * a
- },
- Fg: function(a) {
- return 1 + --a * a * a * a *
- a
- },
- xg: function(a) {
- return .5 > a ? 16 * a * a * a * a * a : 1 + 16 * --a * a * a * a * a
- }
- },
- Sb = {
- Ie: function(a, c, d) {
- switch (a) {
- case "relu":
- return d + "=max(vec4(0.,0.,0.,0.)," + c + ");";
- case "elu":
- return d + "=mix(exp(-abs(" + c + "))-vec4(1.,1.,1.,1.)," + c + ",step(0.," + c + "));";
- case "elu01":
- return d + "=mix(0.1*exp(-abs(" + c + "))-vec4(0.1,0.1,0.1,0.1)," + c + ",step(0.," + c + "));";
- case "arctan":
- return d + "=atan(3.14159265359*texture2D(u0,vUV))/3.14159265359;";
- case "copy":
- return "";
- default:
- return !1
- }
- }
- },
- D = function() {
- function a(x, f, z) {
- f = x.createShader(f);
- x.shaderSource(f,
- z);
- x.compileShader(f);
- return x.getShaderParameter(f, x.COMPILE_STATUS) ? f : !1
- }
- function c(x, f, z) {
- f = a(x, x.VERTEX_SHADER, f);
- z = a(x, x.FRAGMENT_SHADER, z);
- x === b && p.push(f, z);
- var I = x.createProgram();
- x.attachShader(I, f);
- x.attachShader(I, z);
- x.linkProgram(I);
- return I
- }
- function d(x) {
- return ["float", "sampler2D", "int"].map(function(f) {
- return "precision " + x + " " + f + ";\n"
- })
- .join("")
- }
- function e(x, f) {
- f.B = f.B ? !0 : !1;
- if(!f.B) {
- f.ua = f.ua || "precision lowp float;attribute vec2 a0;varying vec2 vv0;void main(){gl_Position=vec4(a0,0.,1.),vv0=a0*.5+vec2(.5,.5);}";
- f.Va = f.Va || ["a0"];
- f.Ha = f.Ha || [2];
- f.precision = f.precision || v;
- f.id = r++;
- void 0 !== f.Qd && (f.Qd.forEach(function(h, C) {
- f.h = f.h.replace(h, f.yb[C])
- }), f.Qd.splice(0));
- f.Cc = 0;
- f.Ha.forEach(function(h) {
- f.Cc += 4 * h
- });
- var z = d(f.precision);
- f.ra = c(x, z + f.ua, z + f.h);
- f.A = {};
- f.i.forEach(function(h) {
- f.A[h] = x.getUniformLocation(f.ra, h)
- });
- f.attributes = {};
- f.Ia = [];
- f.Va.forEach(function(h) {
- var C = x.getAttribLocation(f.ra, h);
- f.attributes[h] = C;
- f.Ia.push(C)
- });
- if(f.j) {
- x.useProgram(f.ra);
- u = f;
- q = f.id;
- for(var I in f.j) x.uniform1i(f.A[I],
- f.j[I])
- }
- f.pa = !0
- }
- }
- function g(x) {
- xa.If(N);
- q !== x.id && (N.P(), q = x.id, u = x, b.useProgram(x.ra), x.Ia.forEach(function(f) {
- 0 !== f && b.enableVertexAttribArray(f)
- }))
- }
- function m(x, f, z) {
- e(x, f, z);
- x.useProgram(f.ra);
- x.enableVertexAttribArray(f.attributes.a0);
- q = -1;
- return u = f
- }
- function t() {
- return {
- h: "uniform sampler2D u1;varying vec2 vv0;void main(){gl_FragColor=texture2D(u1,vv0);}",
- i: ["u1"],
- j: {
- u1: 0
- }
- }
- }
- var p = [],
- q = -1,
- u = null,
- r = 0,
- A = !1,
- v = "highp",
- n = ["u1"],
- y = ["u0"],
- E = {
- u1: 0
- },
- k = {
- u0: 0
- },
- M = {
- u1: 0,
- u2: 1
- },
- H = {
- u3: 0
- },
- l = {
- s0: t(),
- s1: {
- h: "uniform sampler2D u1;varying vec2 vv0;void main(){gl_FragColor=texture2D(u1,vv0);}",
- i: n,
- j: E,
- precision: "lowp"
- },
- s2: {
- h: "uniform sampler2D u1,u2;varying vec2 vv0;void main(){vec4 a=texture2D(u2,vv0),b=texture2D(u1,vv0);gl_FragColor=a*b;}",
- i: ["u1", "u2"],
- j: M
- },
- s3: {
- h: "uniform sampler2D u1;uniform vec2 u4,u5;varying vec2 vv0;void main(){vec2 a=vv0*u4+u5;gl_FragColor=texture2D(u1,a);}",
- i: ["u1", "u4", "u5"],
- j: E,
- B: !0
- },
- s4: {
- h: "uniform sampler2D u1;varying vec2 vv0;const vec4 f=vec4(1.,1.,1.,1.);void main(){vec4 a=texture2D(u1,vv0);gl_FragColor=a.r*f;}",
- i: n,
- j: E
- },
- s5: {
- h: "uniform sampler2D u1,u2;varying vec2 vv0;const vec4 f=vec4(1.,1.,1.,1.);void main(){vec4 a=texture2D(u2,vv0),b=texture2D(u1,vv0);gl_FragColor=a.a*b.r*f;}",
- i: ["u1", "u2"],
- j: M
- },
- s6: {
- h: "uniform sampler2D u1;varying vec2 vv0;void main(){gl_FragColor=texture2D(u1,vec2(1.-vv0.x,vv0.y));}",
- i: n,
- j: E
- },
- s7: {
- h: "uniform sampler2D u1;varying vec2 vv0;void main(){gl_FragColor=texture2D(u1,vec2(vv0.x,1.-vv0.y));}",
- i: n,
- j: E
- },
- s8: {
- h: "uniform sampler2D u0;uniform float u4;varying vec2 vv0;void main(){vec4 a=texture2D(u0,vv0);gl_FragColor=a*u4;}",
- i: ["u0", "u4"],
- j: k
- },
- s9: {
- h: "uniform sampler2D u0;uniform float u4;varying vec2 vv0;const vec4 f=vec4(.25,.25,.25,.25),g=vec4(1.,1.,1.,1.);void main(){vec4 a=texture2D(u0,vv0);float b=dot(a*u4,f);gl_FragColor=b*g;}",
- i: ["u0", "u4"],
- j: k
- },
- s10: {
- h: "uniform sampler2D u1;varying vec2 vv0;const vec4 e=vec4(1.,1.,1.,1.);void main(){float a=.25*dot(e,texture2D(u1,vv0));gl_FragColor=a*e;}",
- i: n,
- j: E
- },
- s11: {
- h: "uniform sampler2D u1,u6;uniform float u7;const vec4 f=vec4(1.,1.,1.,1.);varying vec2 vv0;void main(){vec4 a=texture2D(u1,vv0),b=texture2D(u6,vv0);gl_FragColor=mix(b,a,u7*f);}",
- i: ["u1", "u6", "u7"],
- j: {
- u1: 0,
- u6: 1
- }
- },
- s12: {
- h: "uniform sampler2D u1;uniform vec2 u8;varying vec2 vv0;void main(){gl_FragColor=.25*(texture2D(u1,vv0+u8)+texture2D(u1,vv0+u8*vec2(1.,-1.))+texture2D(u1,vv0+u8*vec2(-1.,-1.))+texture2D(u1,vv0+u8*vec2(-1.,1.)));}",
- i: ["u1", "u8"],
- j: E
- },
- s13: {
- h: "uniform sampler2D u1;uniform vec4 u9;varying vec2 vv0;float g(float a,float b){a=floor(a)+.5;return floor(a/exp2(b));}float h(float a,float b){return floor(a*exp2(b)+.5);}float i(float a,float b){return mod(a,h(1.,b));}float e(float c,float a,float b){a=floor(a+.5),b=floor(b+.5);return i(g(c,a),b-a);}vec4 j(float a){if(a==0.)return vec4(0.,0.,0.,0.);float k=128.*step(a,0.);a=abs(a);float c=floor(log2(a)),l=c+127.,b=(a/exp2(c)-1.)*8388608.,d=l/2.,m=fract(d)*2.,n=floor(d),o=e(b,0.,8.),p=e(b,8.,16.),q=m*128.+e(b,16.,23.),r=k+n;return vec4(o,p,q,r)/255.;}void main(){float a=dot(texture2D(u1,vv0),u9);gl_FragColor=j(a);}",
- i: ["u1", "u9"],
- j: E
- },
- s14: {
- h: "uniform sampler2D u0;varying vec2 vv0;const vec4 e=vec4(1.,1.,1.,1.);void main(){vec4 a=texture2D(u0,vv0),b=e/(e+exp(-a));gl_FragColor=b;}",
- i: y,
- j: k,
- B: !0
- },
- s15: {
- h: "uniform sampler2D u0;varying vec2 vv0;const vec4 f=vec4(0.,0.,0.,0.);void main(){vec4 a=texture2D(u0,vv0);gl_FragColor=max(f,a);}",
- i: y,
- j: k
- },
- s16: {
- h: "uniform sampler2D u0;varying vec2 vv0;const vec4 f=vec4(1.,1.,1.,1.);void main(){vec4 a=texture2D(u0,vv0);gl_FragColor=mix(exp(-abs(a))-f,a,step(0.,a));}",
- i: y,
- j: k
- },
- s17: {
- h: "uniform sampler2D u0;varying vec2 vv0;const vec4 f=vec4(1.,1.,1.,1.);void main(){vec4 a=texture2D(u0,vv0),b=exp(-abs(a))-f;gl_FragColor=mix(.1*b,a,step(0.,a));}",
- i: y,
- j: k
- },
- s18: {
- h: "uniform sampler2D u0,u7,u10;varying vec2 vv0;const vec4 f=vec4(1.,1.,1.,1.);void main(){vec4 a=texture2D(u0,vv0),c=texture2D(u7,vv0),d=texture2D(u10,vv0),b=a/d;gl_FragColor=c*mix(exp(-abs(b))-f,b,step(0.,a));}",
- i: ["u0", "u7", "u10"],
- j: {
- u0: 0,
- u7: 1,
- u10: 2
- },
- B: !0
- },
- s19: {
- h: "uniform sampler2D u0;const float e=3.141593;varying vec2 vv0;void main(){gl_FragColor=atan(e*texture2D(u0,vv0))/e;}",
- i: y,
- j: k
- },
- s20: {
- h: "uniform sampler2D u0;varying vec2 vv0;const vec4 f=vec4(1.,1.,1.,1.);void main(){vec4 a=texture2D(u0,vv0),b=log(f+a);gl_FragColor=b;}",
- i: y,
- j: k,
- B: !0
- },
- s21: {
- h: "uniform sampler2D u0,u11;uniform float u12;const vec2 e=vec2(.5,.5);const float f=1e-5;const vec4 g=vec4(1.,1.,1.,1.),i=vec4(0.,0.,0.,0.);varying vec2 vv0;void main(){vec4 a=texture2D(u11,e);float b=u12*u12;vec4 c=max(b*a,f*g);gl_FragColor=texture2D(u0,vv0)/c;}",
- i: ["u0", "u11", "u12"],
- j: {
- u0: 0,
- u11: 1
- },
- B: !0
- },
- s22: {
- h: "uniform sampler2D u1;uniform vec2 u13;varying vec2 vv0;void main(){float a=u13.x*u13.y;vec2 b=floor(vv0*a)/a,c=fract(vv0*a),d=floor(b*u13.y),f=floor(u13.x*fract(b*u13.y)),g=(f*u13.y+d)/a;gl_FragColor=texture2D(u1,g+c/a);}",
- i: ["u1", "u13"],
- j: E
- },
- s23: {
- h: "uniform sampler2D u14,u15,u16;varying vec2 vv0;void main(){vec4 a=texture2D(u16,vv0);vec2 b=a.rg,c=a.ba;vec4 d=texture2D(u14,b),f=texture2D(u15,c);gl_FragColor=d*f;}",
- i: ["u14", "u15", "u16"],
- j: {
- u15: 0,
- u14: 1,
- u16: 2
- },
- B: !0
- },
- s24: {
- h: "uniform float u17;uniform sampler2D u14,u15;varying vec2 vv0;void main(){vec2 a=fract(vv0*u17);vec4 b=texture2D(u14,vv0),c=texture2D(u15,a);gl_FragColor=b*c;}",
- i: ["u15", "u14", "u17"],
- j: {
- u15: 0,
- u14: 1
- }
- },
- s25: {
- h: "uniform float u17;uniform sampler2D u14,u15,u18,u19,u20,u21;varying vec2 vv0;const vec4 e=vec4(1.,1.,1.,1.),g=vec4(1e-3,1e-3,1e-3,1e-3);void main(){vec2 h=vv0*u17,l=floor(h),c=h-l;vec4 m=texture2D(u14,vv0),d=texture2D(u15,c),a=texture2D(u21,vv0);a=a*255.;vec4 n=texture2D(u18,c),o=texture2D(u19,c),p=texture2D(u20,c),i=step(-g,-a),b=e-i,j=b*step(-e-g,-a);b*=e-j;vec4 k=b*step(-2.*e-g,-a);b*=e-k;vec4 q=b;d=i*d+j*n+k*o+q*p,gl_FragColor=m*d;}",
- i: "u14 u15 u17 u21 u18 u19 u20".split(" "),
- j: {
- u15: 0,
- u14: 1,
- u21: 3,
- u18: 4,
- u19: 5,
- u20: 6
- },
- B: !0
- },
- s26: {
- h: "uniform sampler2D u14,u15,u22;uniform float u17,u23,u24,u25;varying vec2 vv0;const vec2 j=vec2(1.,1.),k=vec2(0.,0.);void main(){vec2 b=floor(u23*vv0),c=u23*vv0-b;float d=u17/u23;vec2 f=floor(c*d),g=c*d-f,h=(b+g)/u23;float l=u23*u25/u17;vec2 m=l*f,a=(m+g*u24)/u25;a+=.25/u25;vec2 i=step(a,j)*step(k,a);vec4 n=texture2D(u14,h),o=texture2D(u15,a),p=n*o,q=texture2D(u22,h);gl_FragColor=(p*u24*u24+q)*i.x*i.y;}",
- i: "u14 u15 u17 u23 u24 u25 u22".split(" "),
- j: {
- u15: 0,
- u14: 1,
- u22: 2
- }
- },
- s27: {
- h: "uniform sampler2D u14,u15;varying vec2 vv0;void main(){vec4 a=texture2D(u14,vv0),b=texture2D(u15,vv0);gl_FragColor=a*b;}",
- i: ["u14", "u15"],
- j: {
- u15: 0,
- u14: 1
- },
- B: !0
- },
- s28: {
- h: "uniform sampler2D u1,u22;uniform float u26;varying vec2 vv0;void main(){gl_FragColor=texture2D(u22,vv0)+u26*texture2D(u1,vv0);}",
- i: ["u1", "u22", "u26"],
- j: {
- u1: 0,
- u22: 1
- }
- },
- s29: {
- h: "varying vec2 vv0;uniform sampler2D u1;const vec4 f=vec4(1.,1.,1.,1.),g=vec4(.299,.587,.114,0.);void main(){vec4 a=texture2D(u1,vv0);gl_FragColor=dot(a,g)*f;}",
- i: n,
- j: E,
- precision: "lowp"
- },
- s30: {
- h: "varying vec2 vv0;uniform sampler2D u1;uniform float u27;const vec3 f=vec3(.299,.587,.114);void main(){vec3 a=texture2D(u1,vv0).rgb,b=texture2D(u1,vv0+vec2(0.,u27)).rgb,c=texture2D(u1,vv0+vec2(u27,u27)).rgb,d=texture2D(u1,vv0+vec2(u27,0.)).rgb;gl_FragColor=vec4(dot(a,f),dot(b,f),dot(c,f),dot(d,f));}",
- i: ["u1", "u27"],
- j: E,
- precision: "lowp"
- },
- s31: {
- h: "varying vec2 vv0;uniform sampler2D u1;uniform float u27;const vec3 f=vec3(.299,.587,.114);void main(){vec3 a=texture2D(u1,vv0).rgb,b=texture2D(u1,vv0+vec2(0.,u27)).rgb,c=texture2D(u1,vv0+vec2(u27,u27)).rgb,d=texture2D(u1,vv0+vec2(u27,0.)).rgb;gl_FragColor=vec4(a.r,b.g,c.b,dot(d,f));}",
- i: ["u1", "u27"],
- j: E,
- precision: "lowp"
- },
- s32: {
- h: "varying vec2 vv0;uniform sampler2D u1,u2;uniform float u28;const vec4 f=vec4(1.,1.,1.,1.);void main(){vec4 a=vec4(0.);a-=texture2D(u1,vec2(vv0.x-u28,vv0.y-u28))*1.,a-=texture2D(u1,vec2(vv0.x-u28,vv0.y))*2.,a-=texture2D(u1,vec2(vv0.x-u28,vv0.y+u28))*1.,a+=texture2D(u1,vec2(vv0.x+u28,vv0.y-u28))*1.,a+=texture2D(u1,vec2(vv0.x+u28,vv0.y))*2.,a+=texture2D(u1,vec2(vv0.x+u28,vv0.y+u28))*1.;vec4 b=vec4(0.);b-=texture2D(u1,vec2(vv0.x-u28,vv0.y-u28))*1.,b-=texture2D(u1,vec2(vv0.x,vv0.y-u28))*2.,b-=texture2D(u1,vec2(vv0.x+u28,vv0.y-u28))*1.,b+=texture2D(u1,vec2(vv0.x-u28,vv0.y+u28))*1.,b+=texture2D(u1,vec2(vv0.x,vv0.y+u28))*2.,b+=texture2D(u1,vec2(vv0.x+u28,vv0.y+u28))*1.;vec3 c=sqrt(a.rgb*a.rgb+b.rgb*b.rgb);vec4 e=vec4(c,texture2D(u1,vv0).a),g=texture2D(u2,vv0);gl_FragColor=g.a*e.r*f;}",
- i: ["u1", "u2", "u28"],
- j: M,
- B: !0
- },
- s33: {
- h: "varying vec2 vv0;uniform sampler2D u1,u2;uniform float u28;const vec4 j=vec4(1.,1.,1.,1.);const vec2 k=vec2(1.,1.);void main(){float h=0.;vec2 l=k*u28,a,b;float c,d,i=0.;for(float e=-4.;e<=4.;e+=1.)for(float f=-4.;f<=4.;f+=1.)a=vec2(e,f),c=length(a)/2.,d=exp(-c*c),b=vv0+l*a,h+=d*texture2D(u1,b).r,i+=d;vec4 m=texture2D(u2,vv0);gl_FragColor=m.a*(texture2D(u1,b).r-h/i)*j;}",
- i: ["u1", "u2", "u28"],
- j: M,
- B: !0
- },
- s34: {
- h: "uniform sampler2D u3;uniform vec2 u8;varying vec2 vv0;vec4 e(vec4 a,vec4 b){vec4 c=step(a,b);return mix(a,b,c);}const vec2 g=vec2(.5,.5),h=vec2(1.,0.),i=vec2(0.,1.);void main(){vec2 a=vv0-u8*g;vec4 b=texture2D(u3,a),c=texture2D(u3,a+u8*h),d=texture2D(u3,a+u8*i),j=texture2D(u3,a+u8),k=e(b,c),l=e(d,j);gl_FragColor=e(k,l);}",
- i: ["u3", "u8"],
- j: H
- },
- s35: {
- h: "uniform sampler2D u3;uniform vec2 u8;varying vec2 vv0;const vec2 k=vec2(1.,0.),l=vec2(0.,1.),m=vec2(2.,0.),n=vec2(0.,2.);vec4 e(vec4 a,vec4 b){vec4 c=step(a,b);return mix(a,b,c);}vec4 f(vec2 a){vec4 b=texture2D(u3,a),c=texture2D(u3,a+u8*k),d=texture2D(u3,a+u8*l),g=texture2D(u3,a+u8),h=e(b,c),i=e(d,g);return e(h,i);}void main(){vec2 a=vv0+u8*vec2(-.55,-1.05);vec4 b=f(a),c=f(a+u8*m),d=f(a+u8*2.),g=f(a+u8*n),h=e(b,c),i=e(d,g);gl_FragColor=e(h,i);}",
- i: ["u3", "u8"],
- j: H,
- B: !0
- },
- s36: {
- h: "uniform sampler2D u1;varying vec2 vv0;void main(){vec4 a=texture2D(u1,vv0);gl_FragColor=a*a;}",
- i: ["u1"],
- j: E,
- precision: "lowp",
- B: !0
- },
- s37: {
- h: "uniform sampler2D u1;uniform vec2 u8;varying vec2 vv0;const float e=15444.;void main(){vec4 a=1001./e*texture2D(u1,vv0-3.*u8)+2002./e*texture2D(u1,vv0-2.*u8)+3003./e*texture2D(u1,vv0-u8)+3432./e*texture2D(u1,vv0)+3003./e*texture2D(u1,vv0+u8)+2002./e*texture2D(u1,vv0+2.*u8)+1001./e*texture2D(u1,vv0+3.*u8);gl_FragColor=a;}",
- i: ["u8", "u1"],
- j: E,
- precision: "lowp",
- B: !0
- },
- s38: {
- h: "uniform sampler2D u1,u11,u29;varying vec2 vv0;const vec4 f=vec4(1.,1.,1.,1.);const float g=.1;void main(){vec4 a=texture2D(u11,vv0),b=texture2D(u29,vv0),c=texture2D(u1,vv0),d=max(f*g,b-a*a),h=sqrt(d);gl_FragColor=(c-a)/h;}",
- i: ["u1", "u11", "u29"],
- j: {
- u1: 0,
- u11: 1,
- u29: 2
- },
- B: !0
- }
- },
- J = {
- s39: {
- h: "uniform float u17,u30;uniform sampler2D u14,u15,u22;varying vec2 vv0;const vec2 ZERO2=vec2(0.,0.),ONE2=vec2(1.,1.),HALF2=vec2(.5,.5),EPS2=vec2(1e-5,1e-5);void main(){vec4 sum=texture2D(u22,vv0);float toSparsity=1.1111;vec2 uvFrom,uvWeight,xyPatch=ZERO2,eps2=EPS2/u17,xyTo=floor(vv0*u17+eps2);float weightSize=toSparsity*u17;vec2 halfFromSparsity=ONE2*(toSparsity-1.)/2.;for(float patch_x=0.;patch_x<1.1111;patch_x+=1.){xyPatch.x=patch_x;for(float patch_y=0.;patch_y<1.1111;patch_y+=1.)xyPatch.y=patch_y,uvFrom=(xyTo+HALF2+u30*(xyPatch-halfFromSparsity))/u17,uvFrom+=step(uvFrom,-eps2),uvFrom-=step(ONE2-eps2,uvFrom),uvWeight=(xyTo*toSparsity+xyPatch+HALF2)/weightSize,sum+=texture2D(u14,uvWeight)*texture2D(u15,uvFrom);}gl_FragColor=sum,gl_FragColor*=2.2222;}",
- i: ["u17", "u14", "u15", "u22", "u30"],
- yb: ["1.1111", "gl_FragColor\\*=2.2222;"]
- },
- s40: {
- h: "uniform float u17,u30,u25;uniform sampler2D u14,u15,u22;varying vec2 vv0;const vec2 ZERO2=vec2(0.,0.),ONE2=vec2(1.,1.),HALF2=vec2(.5,.5),EPS2=vec2(1e-4,1e-4);void main(){vec4 sum=texture2D(u22,vv0);float fromSparsity=1.1111,shrinkFactor=3.3333;vec2 uvFrom,uvWeight,xyFrom,xyPatchTo,xyPatch=ZERO2,xyShrink=ZERO2,eps2=EPS2/u25,xyTo=floor(vv0*u17+eps2);float weightSize=fromSparsity*u25;vec2 halfFromSparsity=ONE2*(fromSparsity-1.)/2.;float toSparsity=weightSize/u17;vec2 xyFrom0=xyTo*shrinkFactor;for(float patch_x=0.;patch_x<1.1111;patch_x+=1.){xyPatch.x=patch_x;for(float patch_y=0.;patch_y<1.1111;patch_y+=1.){xyPatch.y=patch_y;for(float shrink_x=0.;shrink_x<3.3333;shrink_x+=1.){xyShrink.x=shrink_x;for(float shrink_y=0.;shrink_y<3.3333;shrink_y+=1.)xyShrink.y=shrink_y,xyFrom=xyFrom0+xyShrink+shrinkFactor*u30*(xyPatch-halfFromSparsity),uvFrom=(xyFrom+HALF2)/u25,uvFrom+=step(uvFrom,-eps2),uvFrom-=step(ONE2-eps2,uvFrom),xyPatchTo=xyPatch*shrinkFactor+xyShrink,uvWeight=(xyTo*toSparsity+xyPatchTo+HALF2)/weightSize,sum+=texture2D(u14,uvWeight)*texture2D(u15,uvFrom);}}}gl_FragColor=sum,gl_FragColor*=2.2222;}",
- i: "u17 u25 u14 u15 u22 u30".split(" "),
- yb: ["1.1111", "gl_FragColor\\*=2.2222;", "3.3333"]
- }
- },
- w = null,
- L = null,
- N = {
- nb: function() {
- return A
- },
- o: function() {
- if(!A) {
- w = mb.Jb(l, 2);
- L = mb.Jb(J, 2);
- v = "highp";
- b.getShaderPrecisionFormat && (b.getShaderPrecisionFormat(b.FRAGMENT_SHADER, b.MEDIUM_FLOAT), b.getShaderPrecisionFormat(b.FRAGMENT_SHADER, b.LOW_FLOAT));
- for(var x in w) e(b, w[x], x);
- D.set("s0");
- b.enableVertexAttribArray(0);
- A = !0
- }
- },
- Kc: function(x) {
- x.forEach(function(f) {
- N.Jc(f)
- })
- },
- Jc: function(x) {
- w[x.id] = x;
- e(b, x, x.id)
- },
- nd: function(x,
- f, z) {
- f || (f = x);
- w[f] = Object.create(L[x]);
- w[f].df = !0;
- L[x].yb && L[x].yb.forEach(function(I, h) {
- w[f].h = w[f].h.replace(new RegExp(I, "g"), z[h])
- });
- e(b, w[f], f)
- },
- set: function(x) {
- var f = w[x];
- f.B && (f.B = !1, e(b, f, x));
- g(f)
- },
- Sa: function(x) {
- return m(x, t(), "s41")
- },
- tc: function(x) {
- return m(x, {
- h: "void main(){gl_FragColor=vec4(.5,.5,.5,.5);}",
- i: [],
- precision: v
- }, "s42")
- },
- Fe: function(x) {
- return "undefined" === typeof w[x] ? !1 : w[x].pa
- },
- P: function() {
- -1 !== q && (q = -1, u.Ia.forEach(function(x) {
- 0 !== x && b.disableVertexAttribArray(x)
- }))
- },
- uc: function() {
- var x =
- 0;
- u.Ia.forEach(function(f, z) {
- z = u.Ha[z];
- b.vertexAttribPointer(f, z, b.FLOAT, !1, u.Cc, x);
- x += 4 * z
- })
- },
- Wc: function() {
- b.enableVertexAttribArray(0)
- },
- Ca: function() {
- N.zb(b)
- },
- zb: function(x) {
- x.vertexAttribPointer(u.Ia[0], 2, x.FLOAT, !1, 8, 0)
- },
- Fh: function(x, f) {
- b.uniform1i(u.A[x], f)
- },
- G: function(x, f) {
- b.uniform1f(u.A[x], f)
- },
- sa: function(x, f, z) {
- b.uniform2f(u.A[x], f, z)
- },
- Gh: function(x, f) {
- b.uniform2fv(u.A[x], f)
- },
- Jf: function(x, f) {
- b.uniform3fv(u.A[x], f)
- },
- Hh: function(x, f, z, I) {
- b.uniform3f(u.A[x], f, z, I)
- },
- Kf: function(x, f, z, I, h) {
- b.uniform4f(u.A[x],
- f, z, I, h)
- },
- Td: function(x, f) {
- b.uniform4fv(u.A[x], f)
- },
- Ih: function(x, f) {
- b.uniformMatrix2fv(u.A[x], !1, f)
- },
- Jh: function(x, f) {
- b.uniformMatrix3fv(u.A[x], !1, f)
- },
- Kh: function(x, f) {
- b.uniformMatrix4fv(u.A[x], !1, f)
- },
- S: function(x, f) {
- N.set(x);
- f.forEach(function(z) {
- switch (z.type) {
- case "4f":
- b.uniform4fv(u.A[z.name], z.value);
- break;
- case "3f":
- b.uniform3fv(u.A[z.name], z.value);
- break;
- case "2f":
- b.uniform2fv(u.A[z.name], z.value);
- break;
- case "1f":
- b.uniform1f(u.A[z.name], z.value);
- break;
- case "1i":
- b.uniform1i(u.A[z.name], z.value);
- break;
- case "mat2":
- b.uniformMatrix2fv(u.A[z.name], !1, z.value);
- break;
- case "mat3":
- b.uniformMatrix3fv(u.A[z.name], !1, z.value);
- break;
- case "mat4":
- b.uniformMatrix4fv(u.A[z.name], !1, z.value)
- }
- })
- },
- Vg: function() {
- return "lowp"
- },
- m: function() {
- N.P();
- b.disableVertexAttribArray(0);
- for(var x in w) {
- var f = w[x];
- f.pa && (f.pa = !1, b.deleteProgram(f.ra));
- f.df && delete w[x]
- }
- p.forEach(function(z) {
- b.deleteShader(z)
- });
- p.splice(0);
- r = 0;
- A = !1;
- u = null;
- q = -1
- }
- };
- return N
- }(),
- b = null,
- Ha = function() {
- function a(n) {
- console.log("ERROR in ContextFF: ",
- n);
- return !1
- }
- function c() {
- return navigator.userAgent && -1 !== navigator.userAgent.indexOf("forceWebGL1")
- }
- function d(n) {
- function y() {
- Ba.m();
- aa.reset();
- k.getExtension("WEBGL_lose_context")
- .loseContext()
- }
- if(c()) return !1;
- var E = document.createElement("canvas");
- E.setAttribute("width", 5);
- E.setAttribute("height", 5);
- var k = null;
- try {
- k = E.getContext("webgl2", n)
- } catch (M) {
- return !1
- }
- if(!k) return !1;
- e(k);
- aa.Xc(k);
- n = aa.Kb(k);
- if(!n.fa && !n.ha) return y(), !1;
- n = Ba.Nc(k, n);
- y();
- return n ? !0 : !1
- }
- function e(n) {
- n.clearColor(0, 0, 0, 0);
- n.disable(n.DEPTH_TEST);
- n.disable(n.BLEND);
- n.disable(n.DITHER);
- n.disable(n.STENCIL_TEST);
- n.disable(n.CULL_FACE);
- n.GENERATE_MIPMAP_HINT && n.hint(n.GENERATE_MIPMAP_HINT, n.FASTEST);
- n.disable(n.SAMPLE_ALPHA_TO_COVERAGE);
- n.disable(n.SAMPLE_COVERAGE);
- n.depthFunc(n.LEQUAL);
- n.clearDepth(1)
- }
- var g = null,
- m = null,
- t = null,
- p = null,
- q = !0,
- u = null,
- r = null,
- A = [],
- v = {
- F: function() {
- return g.width
- },
- U: function() {
- return g.height
- },
- Mg: function() {
- return g
- },
- Kg: function() {
- return b
- },
- ia: function() {
- return q
- },
- flush: function() {
- b.flush()
- },
- Ye: function() {
- va.ca();
- X.reset();
- T.reset();
- D.P();
- D.Wc();
- b.disable(b.DEPTH_TEST);
- b.disable(b.BLEND);
- T.va();
- D.Ca()
- },
- Le: function() {
- u || (u = new Uint8Array(g.width * g.height * 4));
- b.readPixels(0, 0, g.width, g.height, b.RGBA, b.UNSIGNED_BYTE, u);
- return u
- },
- Og: function() {
- return g.toDataURL("image/jpeg")
- },
- Pg: function() {
- va.O();
- m || (m = document.createElement("canvas"), t = m.getContext("2d"));
- m.width = g.width;
- m.height = g.height;
- for(var n = v.Le(), y = t.createImageData(m.width, m.height), E = m.width, k = m.height, M = y.data, H = 0; H < k; ++H)
- for(var l = k - H - 1, J = 0; J < E; ++J) {
- var w =
- 4 * (H * E + J),
- L = 4 * (l * E + J);
- M[w] = n[L];
- M[w + 1] = n[L + 1];
- M[w + 2] = n[L + 2];
- M[w + 3] = n[L + 3]
- }
- t.putImageData(y, 0, 0);
- return m.toDataURL("image/png")
- },
- Ng: function(n) {
- !m && n && (m = document.createElement("canvas"), t = m.getContext("2d"));
- var y = n ? m : document.createElement("canvas");
- y.width = g.width;
- y.height = g.height;
- (n ? t : y.getContext("2d"))
- .drawImage(g, 0, 0);
- return y
- },
- o: function(n) {
- n = Object.assign({
- ga: null,
- lc: null,
- Wa: null,
- Tc: null,
- width: 512,
- height: 512,
- premultipliedAlpha: !1,
- bf: !0,
- antialias: !1,
- debug: !1,
- og: !1
- }, n);
- n.ga ? (b = n.ga, g = n.ga.canvas) :
- n.Tc && !n.Wa ? g = document.getElementById(n.Tc) : n.Wa && (g = n.Wa);
- g || (g = document.createElement("canvas"));
- g.width = n.width;
- g.height = n.height;
- if(b) q = b instanceof WebGL2RenderingContext;
- else {
- q = !0;
- var y = {
- antialias: n.antialias,
- alpha: !0,
- preserveDrawingBuffer: !0,
- premultipliedAlpha: n.premultipliedAlpha,
- stencil: !1,
- depth: n.bf,
- failIfMajorPerformanceCaveat: !0,
- powerPreference: "high-performance"
- };
- navigator && navigator.userAgent && -1 !== navigator.userAgent.indexOf("noAntialiasing") && (y.antialias = !1);
- var E = d(y);
- E || !y.antialias ||
- c() || (y.antialias = !1, E = d(y));
- E && (b = g.getContext("webgl2", y));
- b ? q = !0 : ((b = g.getContext("webgl", y)) || (b = g.getContext("experimental-webgl", y)), q = !1)
- }
- if(!b) return a("WebGL1 and 2 are not enabled");
- n.lc && g.addEventListener && (p = b.getExtension("WEBGL_lose_context")) && (r = n.lc, g.addEventListener("webglcontextlost", r, !1));
- if(!aa.o()) return a("Not enough GL capabilities");
- e(b);
- D.o();
- T.o();
- Ba.Nc(b, aa.Ke());
- A.forEach(function(k) {
- k(b)
- });
- A.splice(0);
- return !0
- },
- dg: function() {
- return new Promise(function(n) {
- b ? n(b) : A.push(n)
- })
- },
- m: function() {
- b && (aa.m(), D.m(), Ba.m());
- p && r && (g.removeEventListener("webglcontextlost", r, !1), p = r = null);
- b = u = t = m = g = null;
- A.splice(0)
- }
- };
- return v
- }(),
- xa = function() {
- function a() {
- null === c && ("undefined" !== typeof D ? c = D : "undefined" !== typeof JEShaders && (c = JEShaders))
- }
- var c = null;
- return {
- reset: function() {
- c = null
- },
- If: function(d) {
- c !== d && (c && c.P(), c = d)
- },
- nb: function() {
- return c.nb()
- },
- Ca: function() {
- return c.Ca()
- },
- zb: function(d) {
- return c.zb(d)
- },
- uc: function() {
- return c.uc()
- },
- P: function() {
- return c.P()
- },
- set: function(d) {
- a();
- return c.set(d)
- },
- Sa: function(d) {
- a();
- return c.Sa(d)
- },
- tc: function(d) {
- a();
- return c.tc(d)
- }
- }
- }(),
- Aa = function() {
- function a(h) {
- b.bindTexture(b.TEXTURE_2D, h)
- }
- function c(h) {
- x[0] = h;
- h = f[0];
- var C = h >> 16 & 32768,
- K = h >> 12 & 2047,
- O = h >> 23 & 255;
- return 103 > O ? C : 142 < O ? C | 31744 | ((255 == O ? 0 : 1) && h & 8388607) : 113 > O ? (K |= 2048, C | (K >> 114 - O) + (K >> 113 - O & 1)) : C = (C | O - 112 << 10 | K >> 1) + (K & 1)
- }
- function d(h) {
- var C = new Uint16Array(h.length);
- h.forEach(function(K, O) {
- C[O] = c(K)
- });
- return C
- }
- function e() {
- if(null !== z.Xb) return z.Xb;
- var h = m(d([.5, .5, .5, .5]), !0);
- return null === h ? !0 : z.Xb = h
- }
- function g() {
- if(null !== z.Yb) return z.Yb;
- var h = m(new Uint8Array([127, 127, 127, 127]), !1);
- return null === h ? !0 : z.Yb = h
- }
- function m(h, C) {
- if(!xa.nb() || !E) return null;
- var K = null,
- O = Math.sqrt(h.length / 4);
- try {
- var Y = b.getError();
- if("FUCKING_BIG_ERROR" === Y) return !1;
- K = I.instance({
- isFloat: !1,
- R: C,
- array: h,
- width: O
- });
- Y = b.getError();
- if(Y !== b.NO_ERROR) return !1
- } catch (oa) {
- return !1
- }
- la.O();
- b.viewport(0, 0, O, O);
- b.clearColor(0, 0, 0, 0);
- b.clear(b.COLOR_BUFFER_BIT);
- xa.set("s0");
- K.Lc(0);
- ma.l(!0, !0);
- h = 4 * O * O;
- C = new Uint8Array(h);
- b.readPixels(0, 0, O, O, b.RGBA, b.UNSIGNED_BYTE, C);
- O = !0;
- for(Y = 0; Y < h; ++Y) O = O && 3 > Math.abs(C[Y] - 127);
- K.remove();
- la.ca();
- return O
- }
- var t = 0,
- p = null,
- q = 0,
- u = null,
- r = null,
- A = null,
- v = null,
- n = null,
- y = null,
- E = !1,
- k = [],
- M = {
- isFloat: !1,
- isPot: !0,
- isLinear: !1,
- isMipmap: !1,
- isAnisotropicFiltering: !1,
- isMirrorX: !1,
- isMirrorY: !1,
- isSrgb: !1,
- isKeepArray: !1,
- isFlipY: null,
- width: 0,
- height: 0,
- url: null,
- array: null,
- data: null,
- H: null,
- Wb: null,
- cf: !1,
- R: !1,
- ma: null,
- sb: 4,
- ec: 0
- },
- H = !1,
- l = null,
- J = null,
- w = [
- [1, 0, 0, 0],
- [0, 1, 0, 0],
- [0, 0, 1, 0],
- [0, 0, 0,
- 1
- ]
- ],
- L = !1,
- N = !1,
- x = new Float32Array(1),
- f = new Int32Array(x.buffer),
- z = {
- Xb: null,
- Yb: null
- },
- I = {
- o: function() {
- E || (n = [b.RGBA, null, b.RGBA, b.RGBA], y = [b.RGBA, null, b.RGBA, b.RGBA], p = [b.TEXTURE0, b.TEXTURE1, b.TEXTURE2, b.TEXTURE3, b.TEXTURE4, b.TEXTURE5, b.TEXTURE6, b.TEXTURE7], L = "undefined" !== typeof JEContext, N = "undefined" !== typeof aa, L && JEContext.ph() && p.push(b.TEXTURE8, b.TEXTURE9), u = [-1, -1, -1, -1, -1, -1, -1, -1], v = [b.UNSIGNED_BYTE, b.FLOAT, b.FLOAT], E = !0)
- },
- Ze: function() {
- if(!r) {
- for(var h = new Float32Array(16384), C = 0; 16384 > C; ++C) h[C] =
- 2 * Math.random() - 1;
- r = {
- random: I.instance({
- isFloat: !0,
- isPot: !0,
- array: h,
- width: 64
- }),
- ae: I.instance({
- isFloat: !1,
- isPot: !0,
- width: 1,
- array: new Uint8Array([0, 0, 0, 0])
- })
- }
- }
- I.Wf()
- },
- eh: function() {
- return r.ae
- },
- Wf: function() {
- v[1] = aa.Tb(b)
- },
- Gf: function() {
- y = n = [b.RGBA, b.RGBA, b.RGBA, b.RGBA]
- },
- Ld: function(h) {
- D.set("s1");
- la.O();
- var C = h.F(),
- K = h.U();
- b.viewport(0, 0, C, K);
- h.g(0);
- ma.l(!1, !1)
- },
- wh: function(h, C) {
- I.Ld(h);
- b.readPixels(0, 0, h.F(), h.U(), b.RGBA, b.UNSIGNED_BYTE, C)
- },
- xh: function(h, C) {
- I.Ld(h);
- return aa.xb(0, 0, h.F(), h.U(), C)
- },
- ed: function(h, C, K, O, Y, oa, sa) {
- h.activeTexture(h.TEXTURE0);
- var Ca = h.createTexture();
- h.bindTexture(h.TEXTURE_2D, Ca);
- Y = Y instanceof Float32Array ? Y : new Float32Array(Y);
- h.texParameteri(h.TEXTURE_2D, h.TEXTURE_WRAP_S, h.CLAMP_TO_EDGE);
- h.texParameteri(h.TEXTURE_2D, h.TEXTURE_WRAP_T, h.CLAMP_TO_EDGE);
- h.texParameteri(h.TEXTURE_2D, h.TEXTURE_MAG_FILTER, h.NEAREST);
- h.texParameteri(h.TEXTURE_2D, h.TEXTURE_MIN_FILTER, h.NEAREST);
- h.pixelStorei(h.UNPACK_FLIP_Y_WEBGL, oa);
- h.texImage2D(h.TEXTURE_2D, 0, h.RGBA, K, O, 0, h.RGBA, h.FLOAT,
- Y);
- h.bindTexture(h.TEXTURE_2D, null);
- h.pixelStorei(h.UNPACK_FLIP_Y_WEBGL, !1);
- sa && (la.ca(), D.Sa(h));
- h.viewport(0, 0, K, O);
- h.framebufferTexture2D(h.FRAMEBUFFER, h.COLOR_ATTACHMENT0, h.TEXTURE_2D, C, 0);
- h.bindTexture(h.TEXTURE_2D, Ca);
- sa ? ma.l(!0, !0) : T.bb(h);
- h.deleteTexture(Ca);
- E && (u[0] = -1, A = null, t = 0)
- },
- Fb: function(h) {
- h !== t && (b.activeTexture(p[h]), t = h)
- },
- instance: function(h) {
- var C;
- function K() {
- R = void 0 !== B.H.videoWidth ? B.H.videoWidth : B.H.width;
- S = void 0 !== B.H.videoHeight ? B.H.videoHeight : B.H.height
- }
- function O(F) {
- var P =
- b.getError();
- if("FUCKING_BIG_ERROR" === P) return !1;
- b.texImage2D(b.TEXTURE_2D, 0, ja, fa, ha, F);
- P = b.getError();
- P !== b.NO_ERROR && fa !== b.RGBA && (fa = b.RGBA, b.texImage2D(b.TEXTURE_2D, 0, ja, fa, ha, F));
- return !0
- }
- function Y() {
- if(!Ab) {
- a(ta);
- za && b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, za);
- B.isPot ? (b.texParameteri(b.TEXTURE_2D, b.TEXTURE_WRAP_S, B.isMirrorX ? b.MIRRORED_REPEAT : b.REPEAT), b.texParameteri(b.TEXTURE_2D, b.TEXTURE_WRAP_T, B.isMirrorY ? b.MIRRORED_REPEAT : b.REPEAT)) : (b.texParameteri(b.TEXTURE_2D, b.TEXTURE_WRAP_S, b.CLAMP_TO_EDGE),
- b.texParameteri(b.TEXTURE_2D, b.TEXTURE_WRAP_T, b.CLAMP_TO_EDGE));
- B.isAnisotropicFiltering && "undefined" !== typeof JESETTINGS && b.texParameterf(b.TEXTURE_2D, JEContext.Qg()
- .TEXTURE_MAX_ANISOTROPY_EXT, JESETTINGS.$f);
- b.texParameteri(b.TEXTURE_2D, b.TEXTURE_MAG_FILTER, B.isLinear ? b.LINEAR : b.NEAREST);
- B.isLinear ? b.texParameteri(b.TEXTURE_2D, b.TEXTURE_MIN_FILTER, B.isMipmap && !La ? b.NEAREST_MIPMAP_LINEAR : b.LINEAR) : b.texParameteri(b.TEXTURE_2D, b.TEXTURE_MIN_FILTER, B.isMipmap && !La ? b.NEAREST_MIPMAP_NEAREST : b.NEAREST);
- fa = n[B.sb - 1];
- ja = y[B.sb - 1];
- ha = v[nb];
- if(aa.ia()) {
- var F = aa.Ne();
- fa === b.RGBA && ha === b.FLOAT ? B.isMipmap || B.isLinear ? ja = Ba.Pe(b) : aa.Oc() ? F && (ja = F) : ja = b.RGBA16F || b.RGBA : fa === b.RGB && ha === b.FLOAT && F && (ja = F, fa = b.RGBA)
- }
- if(B.R && !B.isFloat || B.isFloat && B.isMipmap && Ba.hf()) ja = aa.Oe(), ha = aa.Tb(b);
- B.ec && (bb = B.ec);
- B.isSrgb && 4 === B.sb && (fa = JEContext.bh());
- if(B.H) O(B.H);
- else if(B.url) O(Ga);
- else if(ua) {
- F = ua;
- try {
- "FUCKING_BIG_ERROR" !== b.getError() && (b.texImage2D(b.TEXTURE_2D, 0, ja, R, S, 0, fa, ha, F), b.getError() !== b.NO_ERROR &&
- (b.texImage2D(b.TEXTURE_2D, 0, ja, R, S, 0, fa, ha, null), b.getError() !== b.NO_ERROR && b.texImage2D(b.TEXTURE_2D, 0, b.RGBA, R, S, 0, b.RGBA, b.UNSIGNED_BYTE, null)))
- } catch (ec) {
- b.texImage2D(b.TEXTURE_2D, 0, ja, R, S, 0, fa, ha, null)
- }
- B.isKeepArray || (ua = null)
- } else F = b.getError(), "FUCKING_BIG_ERROR" !== F && (b.texImage2D(b.TEXTURE_2D, 0, ja, R, S, 0, fa, ha, null), F = b.getError(), F !== b.NO_ERROR && (fa = b.RGBA, B.R && ha !== b.FLOAT && (ha = b.FLOAT, b.texImage2D(b.TEXTURE_2D, 0, ja, R, S, 0, fa, ha, null))));
- if(B.isMipmap)
- if(!La && ca) ca.Sb(), cb = !0;
- else if(La) {
- F =
- Math.log2(Math.min(R, S));
- Ra = Array(1 + F);
- Ra[0] = ta;
- for(var P = 1; P <= F; ++P) {
- var ka = Math.pow(2, P),
- W = R / ka;
- ka = S / ka;
- var Ma = b.createTexture();
- a(Ma);
- b.texParameteri(b.TEXTURE_2D, b.TEXTURE_MIN_FILTER, b.NEAREST);
- b.texParameteri(b.TEXTURE_2D, b.TEXTURE_MAG_FILTER, b.NEAREST);
- b.texImage2D(b.TEXTURE_2D, 0, ja, W, ka, 0, fa, ha, null);
- a(null);
- Ra[P] = Ma
- }
- cb = !0
- }
- a(null);
- u[t] = -1;
- za && b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, !1);
- Ta = !0;
- B.ma && ca && (B.ma(ca), B.ma = null)
- }
- }
- function oa() {
- for(var F = R * S, P = 2 * F, ka = 3 * F, W = 0; W < F; ++W) ya[0][W] = Ua[W], ya[1][W] =
- Ua[W + F], ya[2][W] = Ua[W + P], ya[3][W] = Ua[W + ka]
- }
- function sa() {
- var F = R * S * 4;
- Da = [new Uint8Array(F), new Uint8Array(F), new Uint8Array(F), new Uint8Array(F)];
- ya = [new Float32Array(Da[0].buffer), new Float32Array(Da[1].buffer), new Float32Array(Da[2].buffer), new Float32Array(Da[3].buffer)];
- db = new Uint8Array(4 * F);
- Ua = new Float32Array(db.buffer);
- Va = !0
- }
- function Ca() {
- C = new Uint8Array(R * S * 4);
- Bb = new Float32Array(C.buffer);
- ob = !0
- }
- var B = Object.assign({}, M, h),
- Wa = q++;
- null === B.isFlipY && (B.isFlipY = B.url ? !0 : !1);
- B.data && (B.array =
- "string" === typeof B.data ? Ib(B.data) : B.isFloat ? new Float32Array(B.data) : new Uint8Array(B.data), B.isFlipY = !1);
- var nb = 0,
- Cb = B.H ? !0 : !1,
- Xa = null,
- pb = null,
- Db = !1;
- B.R = B.R || B.isFloat;
- B.R && (nb = 1);
- !B.cf && B.isFloat && N && !aa.Oc() && (B.isFloat = !1);
- B.isFloat && (nb = 2);
- B.isAnisotropicFiltering && L && !JEContext.ih() && (B.isAnisotropicFiltering = !1);
- var ta = B.Wb || b.createTexture(),
- Ga = null,
- ua = !1,
- R = 0,
- S = 0,
- Ta = !1,
- Ab = !1,
- Va = !1,
- ya = null,
- Da = null,
- db = null,
- Ua = null,
- ja = null,
- fa = null,
- ha = null,
- za = B.isFlipY,
- Tb = (h = B.R && B.isMipmap) && Ba.me(),
- La = h &&
- Tb ? !0 : !1,
- Ra = null,
- bb = -1,
- cb = !1;
- var ob = !1;
- var Bb = C = null;
- B.width && (R = B.width, S = B.height ? B.height : R);
- var ca = {
- get: function() {
- return ta
- },
- F: function() {
- return R
- },
- U: function() {
- return S
- },
- fh: function() {
- return B.url
- },
- jh: function() {
- return B.isFloat
- },
- lh: function() {
- return B.R
- },
- mh: function() {
- return B.isLinear
- },
- Sb: function() {
- b.generateMipmap(b.TEXTURE_2D)
- },
- ke: function(F, P) {
- La ? (F || (F = ca.jd()), I.Fb(P), a(Ra[F]), u[P] = -1) : ca.g(P)
- },
- jd: function() {
- -1 === bb && (bb = Math.log(R) / Math.log(2));
- return bb
- },
- He: function(F) {
- if(La) {
- F || (F =
- ca.jd());
- D.set("s12");
- I.Fb(0);
- for(var P = R, ka = S, W = 1; W <= F; ++W) P /= 2, ka /= 2, D.sa("u8", .25 / P, .25 / ka), b.viewport(0, 0, P, ka), a(Ra[W - 1]), b.framebufferTexture2D(la.fb(), b.COLOR_ATTACHMENT0, b.TEXTURE_2D, Ra[W], 0), ma.l(!1, 1 === W);
- u[0] = -1
- } else ca.Sb()
- },
- Eh: function(F) {
- (Cb = !Rb.Rf(F)) ? (ua = null, B.H = F, K()) : ua = F
- },
- g: function(F) {
- if(!Ta) return !1;
- I.Fb(F);
- if(u[F] === Wa) return !1;
- a(ta);
- u[F] = Wa;
- return !0
- },
- Lc: function(F) {
- b.activeTexture(p[F]);
- t = F;
- a(ta);
- u[F] = Wa
- },
- u: function() {
- A = ca;
- b.framebufferTexture2D(la.fb(), b.COLOR_ATTACHMENT0,
- b.TEXTURE_2D, ta, 0)
- },
- $: function() {
- A = ca;
- b.viewport(0, 0, R, S);
- b.framebufferTexture2D(la.fb(), b.COLOR_ATTACHMENT0, b.TEXTURE_2D, ta, 0)
- },
- Ac: I.Ac,
- Sd: function(F, P) {
- R = F;
- S = P
- },
- resize: function(F, P) {
- ca.Sd(F, P);
- Y()
- },
- clone: function(F) {
- F = I.instance({
- width: R,
- height: S,
- R: B.R,
- isFloat: B.isFloat,
- isLinear: B.isLinear,
- isMirrorY: B.isMirrorY,
- isFlipY: F ? !za : za,
- isPot: B.isPot
- });
- xa.set("s0");
- la.ca();
- F.u();
- b.viewport(0, 0, R, S);
- ca.g(0);
- ma.l(!0, !0);
- return F
- },
- Lf: function() {
- b.viewport(0, 0, R, S)
- },
- remove: function() {
- b.deleteTexture(ta);
- Ab = !0;
- k.splice(k.indexOf(ca), 1);
- ca = null
- },
- refresh: function() {
- ca.Lc(0);
- za && b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, !0);
- Cb ? b.texImage2D(b.TEXTURE_2D, 0, ja, fa, ha, B.H) : b.texImage2D(b.TEXTURE_2D, 0, ja, R, S, 0, fa, ha, ua);
- za && b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, !1)
- },
- Kd: function() {
- Va || sa();
- b.readPixels(0, 0, R, 4 * S, b.RGBA, b.UNSIGNED_BYTE, db);
- oa();
- return ya
- },
- yf: function() {
- Va || sa();
- return aa.xb(0, 0, R, 4 * S, db)
- .then(function() {
- oa();
- return ya
- })
- },
- Af: function() {
- ob || Ca();
- b.readPixels(0, 0, R, S, b.RGBA, b.UNSIGNED_BYTE, C);
- return Bb
- },
- zf: function() {
- ob || Ca();
- return aa.xb(0, 0, R, S, C)
- },
- Uc: function(F) {
- la.O();
- D.set("s13");
- ca.g(0);
- if(F) b.viewport(0, 0, R, S), D.Kf("u9", .25, .25, .25, .25), ma.l(!1, !0);
- else
- for(F = 0; 4 > F; ++F) b.viewport(0, S * F, R, S), D.Td("u9", w[F]), ma.l(!1, 0 === F)
- },
- Db: function(F) {
- var P = ha === v[0] && !g();
- a(ta);
- za && b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, !0);
- P ? (Db || (Xa = document.createElement("canvas"), Xa.width = R, Xa.height = S, pb = Xa.getContext("2d"), pb.createImageData(R, S), Db = !0), null.data.set(F), pb.putImageData(null, 0, 0), b.texImage2D(b.TEXTURE_2D,
- 0, ja, fa, ha, Xa)) : b.texImage2D(b.TEXTURE_2D, 0, ja, R, S, 0, fa, ha, F);
- u[t] = Wa;
- za && b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, !1)
- },
- Qh: function(F, P) {
- a(ta);
- P && b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, !0);
- b.texImage2D(b.TEXTURE_2D, 0, ja, fa, ha, F);
- u[t] = Wa;
- P && b.pixelStorei(b.UNPACK_FLIP_Y_WEBGL, !1)
- },
- Dh: function(F, P) {
- var ka = R * S,
- W = 4 * ka;
- F = B.R ? F ? "RGBE" : "JSON" : "RGBA";
- P && (F = P);
- P = aa.ia() && !1;
- var Ma = null;
- switch (F) {
- case "RGBE":
- Ma = "s43";
- break;
- case "JSON":
- Ma = P ? "s0" : "s13";
- break;
- case "RGBA":
- case "RGBAARRAY":
- Ma = "s7"
- }
- Va || ("RGBA" === F || "RGBE" ===
- F || "RGBAARRAY" === F ? (Da = new Uint8Array(W), Va = !0) : "JSON" !== F || P || sa());
- la.O();
- D.set(Ma);
- ca.g(0);
- W = null;
- if("RGBA" === F || "RGBE" === F || "RGBAARRAY" === F) {
- b.viewport(0, 0, R, S);
- ma.l(!0, !0);
- b.readPixels(0, 0, R, S, b.RGBA, b.UNSIGNED_BYTE, Da);
- if("RGBAARRAY" === F) return {
- data: Da
- };
- H || (l = document.createElement("canvas"), J = l.getContext("2d"), H = !0);
- l.width = R;
- l.height = S;
- ka = J.createImageData(R, S);
- ka.data.set(Da);
- J.putImageData(ka, 0, 0);
- W = l.toDataURL("image/png")
- } else if("JSON" === F)
- if(P) W = new Float32Array(ka), b.viewport(0, 0,
- R, S), ma.l(!0, !0), b.readPixels(0, 0, R, S, b.RGBA, b.FLOAT, W);
- else {
- for(W = 0; 4 > W; ++W) b.viewport(0, S * W, R, S), D.Td("u9", w[W]), ma.l(!W, !W);
- ca.Kd();
- W = Array(ka);
- for(P = 0; P < ka; ++P) W[4 * P] = ya[0][P], W[4 * P + 1] = ya[1][P], W[4 * P + 2] = ya[2][P], W[4 * P + 3] = ya[3][P]
- } return {
- format: F,
- data: W,
- width: R,
- height: S,
- isMirrorY: B.isMirrorY,
- isFlipY: "RGBA" === F ? B.isFlipY : !B.isFlipY
- }
- }
- };
- B.isMipmap && !La && Ta && !cb && (ca.Sb(), cb = !0);
- if(B.url) a(ta), b.texImage2D(b.TEXTURE_2D, 0, b.RGBA, 1, 1, 0, b.RGBA, b.UNSIGNED_BYTE, null), Ga = new Image, Ga.ng = "Anonymous", Ga.crossOrigin =
- "Anonymous", Ga.src = B.url, Ga.onload = function() {
- R = Ga.width;
- S = Ga.height;
- Y()
- };
- else if(B.H) {
- var Eb = function() {
- K();
- R ? Y() : setTimeout(Eb, 1)
- };
- Eb()
- } else B.array ? (B.R && !B.isFloat ? B.array instanceof Uint16Array ? (ua = B.array, Y()) : e() ? (ua = d(B.array), Y()) : (Y(), I.ed(b, ta, ca.F(), ca.U(), B.array, za, !0)) : (ua = B.isFloat ? B.array instanceof Float32Array ? B.array : new Float32Array(B.array) : B.array instanceof Uint8Array ? B.array : new Uint8Array(B.array), Y()), B.isKeepArray || (ua && ua !== B.array && (ua = null), delete B.array)) : B.Wb ? Ta = !0 : Y();
- ca.$g = ca.F;
- B.ma && Ta && (B.ma(ca), B.ma = null);
- k.push(ca);
- return ca
- },
- O: function(h) {
- h !== t && (b.activeTexture(p[h]), t = h);
- u[h] = -1;
- a(null)
- },
- cg: function(h) {
- r.random.g(h)
- },
- Ac: function() {
- A = null;
- b.framebufferTexture2D(la.fb(), b.COLOR_ATTACHMENT0, b.TEXTURE_2D, null, 0)
- },
- reset: function() {
- 0 !== t && b.activeTexture(p[0]);
- for(var h = 0; h < p.length; ++h) u[h] = -1;
- t = -1
- },
- Ah: function() {
- t = -1
- },
- Tf: function() {
- for(var h = 0; h < p.length; ++h) I.O(h)
- },
- fd: function() {
- r && (r.random.remove(), r.ae.remove())
- },
- Ph: function(h, C) {
- if("RGBA" === h.format ||
- "RGBE" === h.format) {
- var K = new Image;
- K.src = h.data;
- K.onload = function() {
- I.instance({
- isMirrorY: h.isMirrorY,
- isFlipY: h.isFlipY,
- isFloat: !1,
- H: K,
- ma: function(O) {
- if("RGBA" === h.format) C(O);
- else {
- var Y = h.width,
- oa = h.height,
- sa = I.instance({
- isMirrorY: h.isMirrorY,
- isFloat: !0,
- width: Y,
- height: oa,
- isFlipY: h.isFlipY
- });
- la.ca();
- b.viewport(0, 0, Y, oa);
- D.set("s44");
- sa.u();
- O.g(0);
- ma.l(!0, !0);
- I.O(0);
- C(sa);
- aa.flush();
- setTimeout(O.remove, 50)
- }
- }
- })
- }
- } else "JSON" === h.format ? C(I.instance({
- isFloat: !0,
- isFlipY: h.isFlipY,
- width: h.width,
- height: h.height,
- array: new Float32Array(h.data)
- })) : C(!1)
- },
- te: d,
- m: function() {
- A && (va.ca(), I.Ac(), va.O());
- I.Tf();
- k.slice(0)
- .forEach(function(h) {
- h.remove()
- });
- k.splice(0);
- E = !1;
- q = 0;
- "undefined" !== typeof Ba && Ba.m();
- r = null
- }
- };
- return I
- }(),
- Nb = function() {
- return {
- instance: function(a) {
- var c = [Aa.instance(a), Aa.instance(a)],
- d = [c[1], c[0]],
- e = d,
- g = {
- Df: function(m) {
- e[1].u();
- e[0].g(m);
- g.Wd()
- },
- Ef: function(m) {
- e[1].$();
- e[0].g(m);
- g.Wd()
- },
- Wd: function() {
- e = e === c ? d : c
- },
- refresh: function() {
- e[0].refresh();
- e[1].refresh()
- },
- g: function(m) {
- e[0].g(m)
- },
- bg: function(m) {
- e[1].g(m)
- },
- Ug: function() {
- return e[0]
- },
- Yg: function() {
- return e[1]
- },
- Db: function(m) {
- e[0].Db(m);
- e[1].Db(m)
- },
- remove: function() {
- e[0].remove();
- e[1].remove();
- e = null
- },
- sync: function() {
- g.Ef(0);
- D.set("s0");
- T.l(!1, !1)
- }
- };
- return g
- }
- }
- }(),
- ma = function() {
- function a(q) {
- var u = {
- aa: null,
- J: null
- };
- u.aa = q.createBuffer();
- q.bindBuffer(q.ARRAY_BUFFER, u.aa);
- q.bufferData(q.ARRAY_BUFFER, new Float32Array([-1, -1, 3, -1, -1, 3]), q.STATIC_DRAW);
- u.J = q.createBuffer();
- q.bindBuffer(q.ELEMENT_ARRAY_BUFFER, u.J);
- q.bufferData(q.ELEMENT_ARRAY_BUFFER, new Uint16Array([0,
- 1, 2
- ]), q.STATIC_DRAW);
- return u
- }
- var c = null,
- d = 0,
- e = !1,
- g = [],
- m = -2,
- t = -2,
- p = {
- reset: function() {
- t = m = -2
- },
- o: function() {
- e || (c = a(b), p.va(), e = !0)
- },
- instance: function(q) {
- var u = d++,
- r = q.J ? q.J.length : 0,
- A = "undefined" === typeof q.mode ? b.STATIC_DRAW : q.mode,
- v = b.createBuffer();
- b.bindBuffer(b.ARRAY_BUFFER, v);
- b.bufferData(b.ARRAY_BUFFER, q.aa instanceof Float32Array ? q.aa : new Float32Array(q.aa), A);
- m = u;
- var n = null,
- y = null,
- E = null;
- if(q.J) {
- n = b.createBuffer();
- b.bindBuffer(b.ELEMENT_ARRAY_BUFFER, n);
- var k = null;
- 65536 > q.J.length ? (k = Uint16Array,
- y = b.UNSIGNED_SHORT, E = 2) : (k = Uint32Array, y = b.UNSIGNED_INT, E = 4);
- k = q.J instanceof k ? q.J : new k(q.J);
- b.bufferData(b.ELEMENT_ARRAY_BUFFER, k, A);
- t = u
- }
- var M = {
- le: function(H) {
- m !== u && (b.bindBuffer(b.ARRAY_BUFFER, v), m = u);
- H && xa.uc()
- },
- ie: function() {
- t !== u && (b.bindBuffer(b.ELEMENT_ARRAY_BUFFER, n), t = u)
- },
- bind: function(H) {
- M.le(H);
- M.ie()
- },
- rg: function() {
- b.drawElements(b.TRIANGLES, r, y, 0)
- },
- sg: function(H, l) {
- b.drawElements(b.TRIANGLES, H, y, l * E)
- },
- remove: function() {
- b.deleteBuffer(v);
- q.J && b.deleteBuffer(n);
- M = null
- }
- };
- g.push(M);
- return M
- },
- va: function() {
- -1 !== m && (b.bindBuffer(b.ARRAY_BUFFER, c.aa), m = -1); - 1 !== t && (b.bindBuffer(b.ELEMENT_ARRAY_BUFFER, c.J), t = -1)
- },
- l: function(q, u) {
- q && ma.va();
- u && xa.Ca();
- b.drawElements(b.TRIANGLES, 3, b.UNSIGNED_SHORT, 0)
- },
- bb: function(q) {
- q = q || b;
- var u = a(q);
- q.bindBuffer(q.ARRAY_BUFFER, u.aa);
- q.bindBuffer(q.ELEMENT_ARRAY_BUFFER, u.J);
- xa.zb(q);
- q.clear(q.COLOR_BUFFER_BIT);
- q.drawElements(q.TRIANGLES, 3, q.UNSIGNED_SHORT, 0);
- q.flush();
- q.bindBuffer(q.ARRAY_BUFFER, null);
- q.bindBuffer(q.ELEMENT_ARRAY_BUFFER, null);
- q.deleteBuffer(u.aa);
- q.deleteBuffer(u.J);
- p.reset();
- e && (p.va(), xa.Ca())
- },
- fd: function() {
- var q = b,
- u = c;
- q.deleteBuffer(u.aa);
- q.deleteBuffer(u.J)
- },
- m: function() {
- p.fd();
- g.forEach(function(q) {
- q.remove()
- });
- b.bindBuffer(b.ARRAY_BUFFER, null);
- b.bindBuffer(b.ELEMENT_ARRAY_BUFFER, null);
- p.reset();
- e = !1;
- g.splice(0);
- d = 0
- }
- };
- return p
- }(),
- la = function() {
- var a = null,
- c = null,
- d = null,
- e = !1,
- g = [],
- m = {
- I: -2,
- dd: 1
- },
- t = {
- nb: function() {
- return e
- },
- o: function() {
- if(!e) {
- a = b.createFramebuffer();
- var p = aa.ia();
- c = p && b.DRAW_FRAMEBUFFER ? b.DRAW_FRAMEBUFFER : b.FRAMEBUFFER;
- d =
- p && b.READ_FRAMEBUFFER ? b.READ_FRAMEBUFFER : b.FRAMEBUFFER;
- e = !0
- }
- },
- Rg: function() {
- return c
- },
- Qe: function() {
- return d
- },
- fb: function() {
- return b.FRAMEBUFFER
- },
- Zg: function() {
- return m
- },
- Jg: function() {
- return a
- },
- instance: function(p) {
- void 0 === p.qd && (p.qd = !1);
- var q = p.K ? p.K : null,
- u = p.width,
- r = void 0 !== p.height ? p.height : p.width,
- A = a,
- v = null,
- n = !1,
- y = !1,
- E = 0;
- q && (u = u ? u : q.F(), r = r ? r : q.U());
- var k = {
- Rd: function() {
- n || (A = b.createFramebuffer(), n = !0, E = m.dd++)
- },
- de: function() {
- k.Rd();
- k.u();
- v = b.createRenderbuffer();
- b.bindRenderbuffer(b.RENDERBUFFER,
- v);
- b.renderbufferStorage(b.RENDERBUFFER, b.DEPTH_COMPONENT16, u, r);
- b.framebufferRenderbuffer(c, b.DEPTH_ATTACHMENT, b.RENDERBUFFER, v);
- b.clearDepth(1)
- },
- bind: function(M, H) {
- E !== m.I && (b.bindFramebuffer(c, A), m.I = E);
- q && q.u();
- H && b.viewport(0, 0, u, r);
- M && b.clear(b.COLOR_BUFFER_BIT | b.DEPTH_BUFFER_BIT)
- },
- ag: function() {
- E !== m.I && (b.bindFramebuffer(c, A), m.I = E)
- },
- clear: function() {
- b.clear(b.COLOR_BUFFER_BIT | b.DEPTH_BUFFER_BIT)
- },
- jg: function() {
- b.clear(b.COLOR_BUFFER_BIT)
- },
- kg: function() {
- b.clear(b.DEPTH_BUFFER_BIT)
- },
- Lf: function() {
- b.viewport(0,
- 0, u, r)
- },
- u: function() {
- E !== m.I && (b.bindFramebuffer(c, A), m.I = E)
- },
- rtt: function(M) {
- q = M;
- m.I !== E && (b.bindFramebuffer(b.FRAMEBUFFER, A), m.I = E);
- M.u()
- },
- O: function() {
- b.bindFramebuffer(c, null);
- m.I = -1
- },
- resize: function(M, H) {
- u = M;
- r = H;
- v && (b.bindRenderbuffer(b.RENDERBUFFER, v), b.renderbufferStorage(b.RENDERBUFFER, b.DEPTH_COMPONENT16, u, r))
- },
- remove: function() {
- A === a || y || (b.bindFramebuffer(c, A), b.framebufferTexture2D(c, b.COLOR_ATTACHMENT0, b.TEXTURE_2D, null, 0), v && b.framebufferRenderbuffer(c, b.DEPTH_ATTACHMENT, b.RENDERBUFFER,
- null), b.bindFramebuffer(c, null), b.deleteFramebuffer(A), v && b.deleteRenderbuffer(v));
- y = !0
- }
- };
- p.qd && k.de();
- g.push(k);
- return k
- },
- O: function() {
- b.bindFramebuffer(c, null);
- m.I = -1
- },
- Uf: function() {
- b.bindFramebuffer(c, null);
- b.clear(b.COLOR_BUFFER_BIT | b.DEPTH_BUFFER_BIT);
- aa.Ud();
- m.I = -1
- },
- reset: function() {
- m.I = -2
- },
- ca: function() {
- 0 !== m.I && (b.bindFramebuffer(c, a), m.I = 0)
- },
- clear: function() {
- aa.Ud();
- b.clear(b.COLOR_BUFFER_BIT)
- },
- m: function() {
- t.O();
- g.forEach(function(p) {
- p.remove()
- });
- null !== a && (b.deleteFramebuffer(a), a = null);
- t.reset();
- e = !1;
- g.splice(0);
- m.dd = 1
- }
- };
- return t
- }(),
- aa = function() {
- function a() {
- p = "undefined" === typeof Ha ? JEContext : Ha;
- q = !0
- }
- function c(l, J) {
- for(var w = 0; w < l.length; ++w) {
- var L = J.getExtension(l[w]);
- if(L) return L
- }
- return null
- }
- function d() {
- null !== k.Cb && (clearInterval(k.Cb), k.Cb = null);
- k.za = !1
- }
- function e(l) {
- if(0 === k.oa.length) {
- k.V = b.PIXEL_PACK_BUFFER;
- k.oa.splice(0);
- k.gb.splice(0);
- for(var J = 0; J < k.La; ++J) k.oa.push(b.createBuffer()), k.gb.push(-1);
- k.ea = 0;
- k.jc = 0
- }
- b.bindBuffer(k.V, k.oa[k.ea]);
- l.byteLength !== k.gb[k.ea] &&
- (b.bufferData(k.V, l.byteLength, b.STREAM_READ), k.gb[k.ea] = l.byteLength);
- k.gh = !0
- }
- function g() {
- b.bindBuffer(k.V, null)
- }
- function m() {
- k.xa.forEach(function(l) {
- b.deleteSync(l)
- });
- k.xa.splice(0)
- }
- function t() {
- k.ea = (k.ea + 1) % k.La;
- ++k.jc
- }
- var p = null,
- q = !1,
- u = {
- sd: !1,
- wc: null,
- xc: null,
- vd: !1,
- gf: !1,
- yc: null,
- wd: !1,
- zc: null,
- td: !1,
- Hb: null,
- $e: !1,
- Ib: null,
- af: !1
- },
- r = null,
- A = {
- fa: !0,
- ha: !0,
- Rb: !0,
- Jd: !1
- },
- v = null,
- n = !0,
- y = null,
- E = null,
- k = {
- ue: 1,
- La: -1,
- ea: 0,
- jc: 0,
- za: !1,
- oa: [],
- xa: [],
- gb: [],
- V: null,
- Cb: null
- },
- M = "undefined" === typeof window ? {} : window,
- H = {
- o: function() {
- if(q) return !0;
- H.reset();
- q || a();
- var l = b;
- if(!r.sd) {
- r.wc = H.$c(l);
- M.GL_EXT_FLOAT = r.wc;
- r.vd = r.wc ? !0 : !1;
- if(r.vd || H.ia()) r.xc = H.ad(l), r.gf = r.xc ? !0 : !1, M.GL_EXT_FLOATLINEAR = r.xc;
- r.sd = !0
- }
- if(!r.td) {
- r.yc = H.$a(l);
- r.yc && (r.wd = !0, M.GL_EXT_HALFFLOAT = r.yc);
- if(r.wd || H.ia()) r.zc = H.bd(l), M.GL_EXT_HALFFLOATLINEAR = r.zc;
- r.hh = r.zc ? !0 : !1;
- r.td = !0
- }
- r.Hb = H.Yc(l);
- r.$e = r.Hb ? !0 : !1;
- M.GL_EXT_COLORBUFFERFLOAT = r.Hb;
- r.Ib = H.Zc(l);
- r.af = r.Ib ? !0 : !1;
- M.GL_EXT_COLORBUFFERHALFFLOAT = r.Ib;
- la.o();
- Aa.o();
- if(!H.xe()) return !1;
- ma.o();
- Aa.Ze();
- return !0
- },
- reset: function() {
- r = Object.assign({}, u);
- v = Object.assign({}, A)
- },
- F: function() {
- q || a();
- return p.F()
- },
- U: function() {
- q || a();
- return p.U()
- },
- ia: function() {
- q || a();
- return p.ia()
- },
- Xc: function(l) {
- H.Yc(l);
- H.Zc(l);
- H.$c(l);
- H.ad(l);
- H.$a(l);
- H.bd(l)
- },
- Yc: c.bind(null, ["EXT_color_buffer_float", "WEBGL_color_buffer_float", "OES_color_buffer_float"]),
- Zc: c.bind(null, ["EXT_color_buffer_half_float", "WEBGL_color_buffer_half_float", "OES_color_buffer_half_float"]),
- $c: c.bind(null, ["OES_texture_float", "MOZ_OES_texture_float",
- "WEBKIT_OES_texture_float"
- ]),
- ad: c.bind(null, ["OES_texture_float_linear", "MOZ_OES_texture_float_linear", "WEBKIT_OES_texture_float_linear"]),
- $a: c.bind(null, ["OES_texture_half_float", "MOZ_OES_texture_half_float", "WEBKIT_OES_texture_half_float"]),
- bd: c.bind(null, ["OES_texture_half_float_linear", "MOZ_OES_texture_half_float_linear", "WEBKIT_OES_texture_half_float_linear"]),
- Tb: function(l) {
- var J = H.$a(l);
- return J && J.HALF_FLOAT_OES ? J.HALF_FLOAT_OES : l.HALF_FLOAT || l.FLOAT
- },
- Ne: function() {
- return E || b.RGBA32F || b.RGBA
- },
- Oe: function() {
- return y || b.RGBA16F || b.RGBA
- },
- Ke: function() {
- return v
- },
- Oc: function() {
- return v.fa
- },
- fg: function() {
- return v.ha
- },
- eg: function() {
- return v.Rb
- },
- oe: function() {
- return v.Jd && n
- },
- Zd: function(l) {
- n = l;
- !l && k.za && (m(), b.bindBuffer(k.V, null), k.za = !1)
- },
- nh: function() {
- return k.za
- },
- Ab: function(l, J, w) {
- function L() {
- l.bindTexture(l.TEXTURE_2D, null);
- l.bindFramebuffer(N, null);
- l.deleteTexture(z);
- l.deleteFramebuffer(f)
- }
- var N = l.FRAMEBUFFER,
- x = l.NEAREST,
- f = l.createFramebuffer();
- l.bindFramebuffer(N, f);
- var z = l.createTexture();
- l.activeTexture(l.TEXTURE0);
- l.bindTexture(l.TEXTURE_2D, z);
- l.pixelStorei(l.UNPACK_FLIP_Y_WEBGL, !1);
- l.texParameteri(l.TEXTURE_2D, l.TEXTURE_WRAP_S, l.CLAMP_TO_EDGE);
- l.texParameteri(l.TEXTURE_2D, l.TEXTURE_WRAP_T, l.CLAMP_TO_EDGE);
- l.texParameteri(l.TEXTURE_2D, l.TEXTURE_MAG_FILTER, x);
- l.texParameteri(l.TEXTURE_2D, l.TEXTURE_MIN_FILTER, x);
- l.texImage2D(l.TEXTURE_2D, 0, J, 3, 3, 0, l.RGBA, w, null);
- l.framebufferTexture2D(l.FRAMEBUFFER, l.COLOR_ATTACHMENT0, l.TEXTURE_2D, z, 0);
- if(l.checkFramebufferStatus(l.READ_FRAMEBUFFER ||
- l.FRAMEBUFFER) !== l.FRAMEBUFFER_COMPLETE) return L(), !1;
- xa.tc(l);
- l.clearColor(0, 0, 0, 0);
- l.viewport(0, 0, 3, 3);
- l.disable(l.DEPTH_TEST);
- l.clear(l.COLOR_BUFFER_BIT);
- ma.bb(l);
- l.bindFramebuffer(N, null);
- xa.Sa(l);
- l.activeTexture(l.TEXTURE0);
- l.bindTexture(l.TEXTURE_2D, z);
- ma.bb(l);
- J = new Uint8Array(36);
- l.readPixels(0, 0, 3, 3, l.RGBA, l.UNSIGNED_BYTE, J);
- L();
- for(w = 0; 36 > w; ++w)
- if(3 !== w % 4 && 3 < Math.abs(J[w] - 127)) return !1;
- return !0
- },
- Kb: function(l) {
- var J = {
- fa: !1,
- ha: !1
- };
- l.disable(l.BLEND);
- l.clearColor(0, 0, 0, 0);
- l.clear(l.COLOR_BUFFER_BIT);
- l.RGBA32F && H.Ab(l, l.RGBA32F, l.FLOAT) && (J.fa = !0, E = l.RGBA32F);
- !J.fa && H.Ab(l, l.RGBA, l.FLOAT) && (J.fa = !0, E = l.RGBA);
- var w = H.Tb(l);
- y = null;
- l.RGBA16F && H.Ab(l, l.RGBA16F, w) && (J.ha = !0, y = l.RGBA16F);
- !J.ha && H.Ab(l, l.RGBA, w) && (J.ha = !0, y = l.RGBA);
- return J
- },
- ye: function() {
- var l = la.instance({
- width: 2
- });
- l.Rd();
- var J = Aa.instance({
- width: 2,
- isFloat: !0,
- sb: 3
- });
- l.u();
- J.u();
- H.flush();
- b.checkFramebufferStatus(la.Qe()) !== b.FRAMEBUFFER_COMPLETE ? (Aa.Gf(), v.Rb = !1) : v.Rb = !0;
- l.remove();
- J.remove()
- },
- ze: function() {
- var l = !1;
- H.ia() && (l = "PIXEL_PACK_BUFFER STREAM_READ SYNC_GPU_COMMANDS_COMPLETE WAIT_FAILED fenceSync deleteSync createBuffer".split(" ")
- .every(function(J) {
- return "undefined" !==
- typeof b[J]
- }));
- v.Jd = l
- },
- xe: function() {
- var l = H.Kb(b);
- Object.assign(v, l);
- if(!v.fa && !v.ha) return !1;
- H.ye();
- H.ze();
- return !0
- },
- Bf: function(l, J, w, L, N) {
- b.readPixels(l, J, w, L, b.RGBA, b.UNSIGNED_BYTE, N);
- return Promise.resolve(N, !1)
- },
- xb: function(l, J, w, L, N, x, f) {
- if(!H.oe()) return H.Bf(l, J, w, L, N);
- k.La = f || k.ue;
- e(N);
- b.readPixels(l, J, w, L, b.RGBA, b.UNSIGNED_BYTE, 0);
- k.xa[k.ea] = b.fenceSync(b.SYNC_GPU_COMMANDS_COMPLETE, 0);
- H.flush();
- var z = !1;
- return new Promise(function(I, h) {
- function C() {
- if(!k.za) return d(), g(), t(), h(), !1;
- var K =
- (k.ea + 1) % k.La;
- switch (b.clientWaitSync(k.xa[K], 0, 0)) {
- case b.TIMEOUT_EXPIRED:
- case b.WAIT_FAILED:
- return !1;
- default:
- return d(), b.deleteSync(k.xa[K]), k.xa[K] = null, b.bindBuffer(k.V, k.oa[K]), b.getBufferSubData(k.V, 0, N), g(), t(), I(N, z), !0
- }
- }
- d();
- k.jc + 1 < k.La ? (g(), t(), I(N, !1)) : (k.za = !0, C() || (x && !z && (z = !0, x()), k.Cb = setInterval(C, 0)))
- })
- },
- Ud: function() {
- b.viewport(0, 0, H.F(), H.U())
- },
- flush: function() {
- b.flush()
- },
- m: function() {
- d();
- m();
- Aa.m();
- la.m();
- ma.m();
- k.oa.forEach(function(l) {
- b.deleteBuffer(l)
- });
- k.oa.splice(0);
- xa.reset();
- q = !1
- }
- };
- return H
- }(),
- T = ma,
- va = la,
- X = Aa,
- Ba = function() {
- function a(w, L, N, x) {
- k.texParameteri(k.TEXTURE_2D, k.TEXTURE_MIN_FILTER, x ? k.NEAREST_MIPMAP_NEAREST : k.LINEAR);
- var f = null;
- if(null !== N) try {
- f = k.getError();
- if("FUCKING_BIG_ERROR" === f) return !1;
- k.texImage2D(k.TEXTURE_2D, 0, w, 4, 4, 0, k.RGBA, L, N);
- f = k.getError();
- if(f !== k.NO_ERROR) return !1
- } catch (z) {
- return !1
- }
- x && k.generateMipmap(k.TEXTURE_2D);
- k.clear(k.COLOR_BUFFER_BIT);
- T.bb(k);
- f = k.getError();
- if("FUCKING_BIG_ERROR" === f) return !1;
- k.readPixels(0, 0, 2, 2, k.RGBA, k.UNSIGNED_BYTE,
- r);
- f = k.getError();
- f === k.INVALID_OPERATION && "undefined" !== typeof k.PIXEL_PACK_BUFFER && (k.bindBuffer(k.PIXEL_PACK_BUFFER, null), k.readPixels(0, 0, 2, 2, k.RGBA, k.UNSIGNED_BYTE, r), f = k.getError());
- if(f !== k.NO_ERROR) return !1;
- N = !0;
- for(x = 0; 16 > x; ++x) N = N && 4 > Math.abs(r[x] - 127);
- N && (q.Gd = L, q.pd = w);
- return N
- }
- function c(w, L) {
- return M.fa && a(w, k.FLOAT, new Float32Array(A), L) ? (p = t.Hc, !0) : !1
- }
- function d(w, L, N) {
- if(!M.ha) return !1;
- var x = Aa.te(A),
- f = aa.$a(k);
- if(f && f.HALF_FLOAT_OES && a(w, f.HALF_FLOAT_OES, x, L) || k.HALF_FLOAT && a(w,
- k.HALF_FLOAT, x, L)) return p = t.Ga, !0;
- x = new Float32Array(A);
- if(a(w, k.FLOAT, x, L)) return p = t.Ga, !0;
- k.bindTexture(k.TEXTURE_2D, N);
- k.texImage2D(k.TEXTURE_2D, 0, k.RGBA, 2, 2, 0, k.RGBA, k.UNSIGNED_BYTE, null);
- k.bindFramebuffer(q.Ya, J);
- Aa.ed(k, N, 2, 2, x, !1, !1);
- k.bindFramebuffer(q.Ya, null);
- k.bindTexture(k.TEXTURE_2D, N);
- return a(w, null, null, L) ? (p = t.Ga, !0) : !1
- }
- function e(w, L, N) {
- u = !0;
- if(d(w, !0, N) || c(L, !0)) return !0;
- u = !1;
- return d(w, !1, N) || c(L, !1) ? !0 : !1
- }
- function g(w) {
- if(p === t.P) {
- k = w || b;
- p = t.RGBA8;
- u = !0;
- aa.Xc(k);
- M || (M = aa.Kb(k));
- va.reset();
- J = k.createFramebuffer();
- q.Ya = k.DRAW_FRAMEBUFFER || k.FRAMEBUFFER;
- k.bindFramebuffer(q.Ya, null);
- k.clearColor(0, 0, 0, 0);
- k.viewport(0, 0, 2, 2);
- D.P();
- H = D.Sa(k);
- w = k.createTexture();
- k.activeTexture(k.TEXTURE0);
- k.bindTexture(k.TEXTURE_2D, w);
- k.texParameteri(k.TEXTURE_2D, k.TEXTURE_WRAP_S, k.REPEAT);
- k.texParameteri(k.TEXTURE_2D, k.TEXTURE_WRAP_T, k.REPEAT);
- k.texParameteri(k.TEXTURE_2D, k.TEXTURE_MAG_FILTER, k.NEAREST);
- l = w;
- var L = w = k.RGBA,
- N = k.RGBA16F,
- x = k.RGBA32F;
- x && (w = x);
- N && (L = N);
- if((N || x) && e(L, w, l)) return m(),
- !0;
- w = L = k.RGBA;
- if(e(L, w, l)) return m(), !0;
- p = t.RGBA8;
- m();
- return !1
- }
- }
- function m() {
- k.deleteProgram(H.ra);
- k.deleteTexture(l);
- l = H = null
- }
- for(var t = {
- P: -1,
- Hc: 3,
- Ga: 2,
- RGBA8: 0
- }, p = t.P, q = {
- Gd: null,
- pd: null,
- Ya: null
- }, u = !0, r = new Uint8Array(16), A = Array(64), v = 0; 4 > v; ++v)
- for(var n = 0; 4 > n; ++n) {
- var y = 0 === (n + v) % 2 ? 1 : 0,
- E = 4 * v + n;
- A[4 * E] = y;
- A[4 * E + 1] = y;
- A[4 * E + 2] = y;
- A[4 * E + 3] = y
- }
- var k = null,
- M = null,
- H = null,
- l = null,
- J = null;
- return {
- me: function(w) {
- g(w);
- return u
- },
- Nc: function(w, L) {
- p === t.P && (typeof("undefined" !== L) && (M = L), g(w));
- return p !== t.RGBA8
- },
- kh: function(w) {
- g(w);
- return p === t.Hc
- },
- hf: function(w) {
- g(w);
- return p === t.Ga
- },
- Sg: function(w) {
- g(w);
- return q.Gd
- },
- Pe: function(w) {
- g(w);
- return q.pd
- },
- m: function() {
- k = null;
- u = !0;
- p = t.P;
- M = null
- }
- }
- }(),
- Ub = function() {
- return {
- instance: function(a) {
- var c = X.instance(a.alpha),
- d = X.instance(a.beta);
- return {
- Be: function() {
- c.g(1);
- d.g(2)
- }
- }
- }
- }
- }(),
- Gb = function() {
- return {
- instance: function(a) {
- var c = null,
- d = !1,
- e = !1,
- g = null,
- m = !1,
- t = !1,
- p = null,
- q = "undefined" === typeof a.preprocessing ? !1 : a.preprocessing,
- u = "undefined" === typeof a.preprocessingSize ? a.size : a.preprocessingSize;
- a.mask && (d = !0, ea && void 0 !== ea.he && (a.mask = ea.he + a.mask), c = X.instance({
- isFloat: !1,
- url: a.mask
- }));
- var r = !1;
- a.customInputShader && (r = "s45", D.Jc({
- name: "_",
- id: r,
- h: a.customInputShader,
- Oh: ["uSource"],
- precision: "lowp"
- }), D.S(r, [{
- type: "1i",
- name: "_",
- value: 0
- }]));
- switch (q) {
- case "sobel":
- p = "s32";
- m = !0;
- break;
- case "meanNormalization":
- p = "s33";
- m = !0;
- break;
- case "grayScale":
- p = "s29";
- m = !1;
- break;
- case "grayScaleTilt":
- p = "s30";
- t = !0;
- m = !1;
- break;
- case "rgbGrayTilt":
- p = "s31";
- t = !0;
- m = !1;
- break;
- case "copy":
- p = r ? r : "s0";
- break;
- case "inputLightRegulation":
- p =
- r ? r : "s29";
- g = Vb.instance({
- od: u,
- Fd: a.size,
- Cd: a.nBlurPass,
- mb: !1
- });
- e = !0;
- break;
- case "inputMix0":
- p = "none";
- g = Wb.instance({
- C: u,
- be: a.varianceMin,
- Mc: a.blurKernelSizePx,
- mb: !1
- });
- e = !0;
- break;
- case "direct":
- case "none":
- p = "abort";
- break;
- default:
- p = "s4"
- }
- t && D.S(p, [{
- name: "u27",
- type: "1f",
- value: a.tilt
- }]);
- d && (p += "Mask");
- var A = X.instance({
- isFloat: !1,
- isPot: !1,
- width: a.size
- }),
- v = {
- F: function() {
- return u
- },
- Ub: function() {
- return v.F()
- },
- Ue: function() {
- return e ? g.Vb() : A
- },
- T: function(n) {
- va.ca();
- "abort" !== p && ("none" !== p && (D.set(p), m && D.G("u28",
- 1 / a.size), A.$(), d && c.g(1), T.l(!1, !1), A.g(0), n = A), e && g.process(n))
- },
- m: function() {
- A.remove();
- d && c.remove()
- }
- };
- return v
- }
- }
- }(),
- Hb = function() {
- return {
- instance: function(a) {
- function c(h) {
- g.forEach(function(C, K) {
- m[K][0] = h[0][C];
- m[K][1] = h[1][C];
- m[K][2] = h[2][C];
- m[K][3] = h[3][C]
- });
- return m
- }
- a.normalize = a.normalize || !1;
- var d = {
- input: null,
- bias: null,
- Zb: null,
- Z: null,
- tb: null,
- nc: null,
- oc: null
- },
- e = null,
- g = [],
- m = [],
- t = !1,
- p = null,
- q = !0,
- u = -1,
- r = a.isReorganize ? a.isReorganize : !1,
- A = a.kernelsCount ? !0 : !1,
- v = a.dynPelu ? Ub.instance(a.dynPelu) :
- !1,
- n = v ? !0 : !1,
- y = {
- isEnabled: !1
- };
- a.ef ? (a.sparsity = "undefined" !== typeof a.sparsity ? a.sparsity : a.vb.Ub(), q = !1) : "full" === a.connectivityUp && (a.sparsity = a.vb.Ub());
- var E = {
- elu: "s16",
- elu01: "s17",
- relu: "s15",
- arctan: "s19",
- sigmoid: "s14",
- copy: "s0",
- softplus: "s20",
- dynPelu: "s18"
- } [a.activation],
- k = a.sparsity * a.sparsity,
- M = !1,
- H = a.size,
- l = "";
- if(a.maxPooling) {
- switch (a.maxPooling.size) {
- case 2:
- l = "s34";
- break;
- case 4:
- l = "s35"
- }
- M = !0;
- H /= a.maxPooling.size;
- d.nc = X.instance({
- isFloat: !0,
- isPot: !1,
- width: H
- })
- }
- var J = a.normalization ? !0 : !1,
- w =
- null,
- L = null,
- N = null;
- if(J) {
- w = "s46" + a.index.toString();
- D.nd("s46", w, [((a.normalization.n - 1) / 2)
- .toFixed(1)
- ]);
- D.S(w, [{
- type: "1i",
- name: "u1",
- value: 0
- }, {
- type: "2f",
- name: "u8",
- value: [1 / a.size, 1 / a.size]
- }, {
- type: "1f",
- name: "u7",
- value: a.normalization.alpha
- }, {
- type: "1f",
- name: "u10",
- value: a.normalization.beta
- }, {
- type: "1f",
- name: "u31",
- value: a.normalization.k
- }]);
- var x = {
- isFloat: !0,
- isPot: !0,
- width: a.size
- };
- L = X.instance(x);
- N = X.instance(x)
- }
- var f = -1,
- z = null;
- q && (d.Z = X.instance({
- isFloat: !0,
- isPot: !1,
- width: a.size
- }));
- d.bias = X.instance(a.bias);
- var I = {
- F: function() {
- return a.size
- },
- Ub: function() {
- return H
- },
- gd: function() {
- return a.classesCount
- },
- je: function(h) {
- e.g(h)
- },
- vf: function() {
- a.remap && a.remap.isEnabled && (y = {
- isEnabled: !0,
- lf: X.instance({
- isFloat: !1,
- isFlipY: !1,
- array: new Uint8Array(a.remap.maskTexture.data),
- width: a.remap.maskTexture.width,
- isPot: !1
- }),
- pb: a.remap.layers.map(function(h) {
- return a.parent.Se(h)
- }),
- depth: a.remap.depth
- })
- },
- Hf: function() {
- switch (a.connectivityUp) {
- case "direct":
- z = Xb.instance(a.connectivity);
- break;
- case "square":
- z = Yb.instance(a.connectivity);
- break;
- case "squareFast":
- z = Zb.instance(a.connectivity, a.activation);
- break;
- case "full":
- z = $b.instance(a.connectivity);
- break;
- case "conv":
- u = a.kernelsCount, z = ac.instance(a.connectivity), r && (d.tb = X.instance({
- width: H,
- isFloat: !0,
- isFlipY: !1,
- isPot: !1
- }))
- }
- if(z.Da) {
- var h = a.size * a.sparsity;
- f = Math.log(h / a.size) / Math.log(2);
- d.input = X.instance({
- isMipmap: !0,
- isFloat: !0,
- isPot: !0,
- width: h,
- ec: f
- });
- d.Zb = X.instance({
- isFloat: !0,
- isPot: !0,
- width: a.size
- })
- }
- },
- T: function(h, C) {
- e = h;
- z.Da ? (d.input.$(), A && d.bias.g(2), z.T(y), d.input.g(0),
- d.input.He(f), d.Zb.$(), A ? D.set("s0") : (D.set("s28"), D.G("u26", k), d.bias.g(1)), d.input.ke(f, 0), T.l(!1, !1), D.set(E), J ? L.u() : d.Z.u(), d.Zb.g(0), n && v.Be(), T.l(!1, !1)) : (d.Z.$(), d.bias.g(1), z.T());
- J && (D.set(w), N.u(), L.g(0), T.l(!1, !1), D.set("s47"), D.G("u7", 1), d.Z.u(), N.g(1), T.l(!1, !1));
- if(q) return M ? (d.nc.$(), d.Z.g(0), D.set(l), D.sa("u8", 1 / a.size, 1 / a.size), T.l(!1, !1), C = d.nc) : C = d.Z, C.g(0), r && (d.tb.u(), D.set("s22"), D.sa("u13", u, H / u), T.l(!1, !1), C = d.tb, d.tb.g(0)), C;
- var K = d.Z;
- a.normalize && (D.set("gpuRawAvg" === t ?
- "s9" : "s8"), D.G("u4", 1 / a.size), d.oc.$(), d.Z.g(0), T.l(!1, !1), K = d.oc);
- h = null;
- switch (t) {
- case "cpuRGBA2Float":
- K.Uc(!1);
- C ? h = I.wf(K)
- .then(p) : (K = I.xf(K), p(K));
- break;
- case "cpuMeanFloat":
- K.Uc(!0);
- if(C) h = K.zf()
- .then(p);
- else {
- K = K.Af();
- for(var O = 0; O < K.length; ++O);
- p(K)
- }
- break;
- case "gpuRawAvg":
- case "gpuRaw":
- K.g(0);
- case "none":
- null !== p && p(K)
- }
- C && null === h && (h = Promise.resolve());
- return h
- },
- we: function(h) {
- h && (t = h.pc || "none", p = h.mc || null);
- d.Z = X.instance({
- isFloat: !0,
- isPot: !0,
- isMipmap: !1,
- width: a.size
- });
- h = "undefined" !== typeof a.classesCount &&
- a.classesCount ? a.classesCount : a.size * a.size;
- for(var C = 0, K = 0, O = 0; C < h; ++C) g.push(K + (a.size - 1 - O) * a.size), m.push([-1, -1, -1, -1]), ++K, K === a.size && (K = 0, ++O);
- a.normalize && (d.oc = X.instance({
- isFloat: !0,
- isPot: !0,
- width: a.size
- }))
- },
- wf: function(h) {
- return h.yf()
- .then(c)
- },
- xf: function(h) {
- h = h.Kd();
- c(h);
- return m
- },
- m: function() {
- for(var h in d) {
- var C = d[h];
- C && C.remove()
- }
- z && (z.m(), z = null)
- }
- };
- a.vb && I.Hf(a.vb);
- return I
- }
- }
- }(),
- Xb = function() {
- return {
- instance: function(a) {
- var c = X.instance(a.weights);
- return {
- Da: !0,
- eb: function() {
- return 1
- },
- m: function() {
- c.remove()
- },
- Xe: function() {
- return c
- },
- T: function() {
- D.set("s27");
- c.g(1);
- T.l(!1, !1)
- }
- }
- }
- }
- }(),
- $b = function() {
- return {
- instance: function(a) {
- var c = a.fromLayerSize,
- d = X.instance(a.weights);
- return {
- Da: !0,
- eb: function() {
- return c
- },
- m: function() {
- d.remove()
- },
- T: function(e) {
- if(e.isEnabled) {
- D.set("s25");
- e.lf.g(3);
- var g, m = Math.min(e.pb.length, e.depth);
- for(g = 0; g < m; ++g) e.pb[g].je(4 + g)
- } else D.set("s24");
- D.G("u17", a.toLayerSize);
- d.g(1);
- T.l(!1, !1)
- }
- }
- }
- }
- }(),
- Yb = function() {
- return {
- instance: function(a) {
- for(var c = a.fromLayerSize,
- d = a.toLayerSize, e = a.toSparsity, g = e * d, m = g / c, t = c / d, p = 0, q = 0, u = 0, r = Array(e * d * e * d * 4), A = Array(e * d * e * d * 4), v = Array(c * c), n = 0; n < v.length; ++n) v[n] = 0;
- n = Math.floor(e / 2);
- for(var y = .5 / d, E = .5 / c, k = .5 / g, M = 0; M < d; ++M)
- for(var H = Math.round(M * t), l = 0; l < d; ++l) {
- var J = Math.round(l * t),
- w = M / d,
- L = l / d;
- w += y;
- L += y;
- for(var N = 0; N < e; ++N) {
- var x = H + N - n;
- 0 > x && (x += c);
- x >= c && (x -= c);
- for(var f = 0; f < e; ++f) {
- var z = p / g,
- I = q / g,
- h = J + f - n;
- 0 > h && (h += c);
- h >= c && (h -= c);
- var C = x / c,
- K = h / c;
- I = 1 - I - 1 / g;
- C += E;
- K += E;
- z += k;
- I += k;
- var O = M * e + N,
- Y = l * e + f;
- Y = d * e - Y - 1;
- O = Y * d * e + O;
- r[4 * O] =
- z;
- r[4 * O + 1] = I;
- r[4 * O + 2] = C;
- r[4 * O + 3] = K;
- K = v[h * c + x]++;
- O = K % m;
- C = x * m + O;
- h = h * m + (K - O) / m;
- h = c * m - 1 - h;
- h = h * c * m + C;
- A[4 * h] = z;
- A[4 * h + 1] = I;
- A[4 * h + 2] = w;
- A[4 * h + 3] = L;
- ++p >= g && (p = 0, ++q);
- ++u
- }
- }
- }
- v = null;
- var oa = X.instance(a.weights);
- delete a.weights.data;
- var sa = X.instance({
- width: g,
- isFloat: !0,
- array: new Float32Array(A),
- isPot: !0
- });
- A = null;
- var Ca = X.instance({
- width: g,
- isFloat: !0,
- array: new Float32Array(r),
- isPot: !0
- });
- r = null;
- return {
- Da: !0,
- eb: function() {
- return m
- },
- m: function() {
- sa.remove();
- Ca.remove();
- oa.remove()
- },
- T: function() {
- D.set("s23");
- oa.g(1);
- Ca.g(2);
- T.l(!1, !1)
- }
- }
- }
- }
- }(),
- ac = function() {
- return {
- instance: function(a) {
- var c = a.kernelsCount,
- d = a.toSparsity,
- e = d * a.toLayerSize / a.fromLayerSize,
- g = X.instance(a.weights);
- return {
- Da: !0,
- eb: function() {
- return e
- },
- dh: function() {
- return d
- },
- Xe: function() {
- return g
- },
- m: function() {
- g.remove()
- },
- T: function() {
- D.set("s26");
- D.G("u23", c);
- D.G("u24", d);
- D.G("u17", a.toLayerSize);
- D.G("u25", a.fromLayerSize);
- g.g(1);
- T.l(!1, !1)
- }
- }
- }
- }
- }(),
- Zb = function() {
- return {
- instance: function(a, c) {
- var d = a.fromLayerSize,
- e = a.toLayerSize,
- g = a.toSparsity,
- m = a.stride ?
- a.stride : 1,
- t = g * e / d,
- p = e < d,
- q = d / e,
- u = X.instance(a.weights),
- r = "s48" + [d.toString(), e.toString(), g.toString(), m.toString(), c].join("_");
- D.Fe(r) || (a = Sb.Ie(c, "gl_FragColor", "gl_FragColor"), e = [{
- type: "1f",
- name: "u17",
- value: e
- }, {
- type: "1f",
- name: "u30",
- value: m
- }], p && e.push({
- type: "1f",
- name: "u25",
- value: d
- }), d = [(p ? t : g)
- .toFixed(1), a
- ], p && d.push(q.toFixed(1)), D.nd(p ? "s40" : "s39", r, d), D.S(r, e.concat([{
- type: "1i",
- name: "u15",
- value: 0
- }, {
- type: "1i",
- name: "u22",
- value: 1
- }, {
- type: "1i",
- name: "u14",
- value: 3
- }])));
- return {
- Da: !1,
- eb: function() {
- return t
- },
- m: function() {
- u.remove()
- },
- T: function() {
- D.set(r);
- u.g(3);
- T.l(!1, !1)
- }
- }
- }
- }
- }(),
- Vb = function() {
- return {
- instance: function(a) {
- var c = a.Cd ? a.Cd : 3,
- d = a.od ? a.od : 64,
- e = a.Fd ? a.Fd : 64,
- g = a.mb ? !0 : !1;
- a = {
- isFloat: !1,
- width: d,
- isPot: !1,
- isFlipY: !1
- };
- var m = X.instance(a),
- t = X.instance(a),
- p = X.instance(a),
- q = X.instance(a),
- u = X.instance({
- isFloat: !0,
- width: e,
- isPot: !1,
- isFlipY: !1
- }),
- r = 1 / d;
- return {
- process: function(A) {
- D.set("s36");
- q.u();
- T.l(g, !1);
- D.set("s37");
- for(var v = 0; v < c; ++v) m.u(), D.sa("u8", r, 0), T.l(g, !1), p.u(), q.g(0), T.l(g, !1), t.u(), m.g(0),
- D.sa("u8", 0, r), T.l(g, !1), q.u(), p.g(0), T.l(g, !1), v !== c - 1 && t.g(0);
- D.set("s38");
- u.u();
- A.g(0);
- t.g(1);
- q.g(2);
- T.l(g, !1);
- u.g(0)
- },
- Vb: function() {
- return u
- }
- }
- }
- }
- }(),
- Wb = function() {
- return {
- instance: function(a) {
- function c(u) {
- return X.instance({
- isFloat: u,
- width: d.C,
- isPot: !1,
- isFlipY: !1
- })
- }
- var d = Object.assign({
- be: .1,
- Mc: 9,
- C: 128,
- mb: !1
- }, a),
- e = c(!1),
- g = [c(!1), c(!1), c(!1)],
- m = [c(!1), c(!1), c(!1)],
- t = c(!0),
- p = [e, m[0], m[1]];
- a = "uniform sampler2D u1;const float e=1.1111,g=2.2222;uniform vec2 u32;varying vec2 vv0;void main(){float b=0.,c=0.;for(float a=-e;a<=e;a+=1.){vec2 i=u32*a,j=vv0+i*g;float d=1.2*a/e,f=exp(-d*d);b+=f*texture2D(u1,j).r,c+=f;}b/=c,gl_FragColor=vec4(b,0.,0.,1.);}".replace("1.1111",
- Math.round((d.Mc - 1) / 2)
- .toFixed(2))
- .replace("2.2222", (1 / d.C)
- .toFixed(6));
- var q = {
- u1: 0
- };
- D.Kc([{
- id: "s50",
- name: "_",
- h: "uniform sampler2D u1;varying vec2 vv0;const vec3 f=vec3(.2126,.7152,.0722),g=vec3(1.,1.,1.);void main(){vec3 b=texture2D(u1,vv0).rgb;float a=dot(b,f);gl_FragColor=vec4(a,a,a,a);}",
- j: q,
- i: ["u1"],
- precision: "lowp"
- }, {
- id: "s51",
- name: "_",
- h: a,
- j: q,
- i: ["u1", "u32"],
- precision: "lowp"
- }, {
- id: "s52",
- name: "_",
- h: "uniform sampler2D u33,u34,u35,u36;const float f=1.1111;const vec3 g=vec3(1.,1.,1.);varying vec2 vv0;void main(){vec3 a=texture2D(u33,vv0).rgb;float c=texture2D(u34,vv0).r,d=texture2D(u35,vv0).r,h=texture2D(u36,vv0).r,i=a.r*a.r;vec3 b=vec3(c,d,h),j=max(g*f,abs(i-b*b)),k=sqrt(j);gl_FragColor=vec4(a.r,(a-b)/k);}".replace("1.1111",
- d.be.toFixed(4)),
- j: {
- u33: 0,
- u34: 1,
- u35: 2,
- u36: 3
- },
- i: ["u33", "u34", "u35", "u36"],
- precision: "highp"
- }]);
- return {
- process: function() {
- D.set("s50");
- e.$();
- T.l(d.mb, !1);
- D.set("s51");
- for(var u = 0; 3 > u; ++u) D.sa("u32", 1, 0), g[u].u(), p[u].g(0), T.l(!1, !1), D.sa("u32", 0, 1), m[u].u(), g[u].g(0), T.l(!1, !1);
- D.set("s52");
- t.u();
- e.g(0);
- m[0].g(1);
- m[1].g(2);
- m[2].g(3);
- T.l(!1, !1);
- t.g(0)
- },
- Vb: function() {
- return t
- }
- }
- }
- }
- }(),
- V = {
- ld: function() {
- return V.Sc() ? document.createElement("video") : !1
- },
- Ma: function(a, c) {
- a[c] = !0;
- a.setAttribute(c, "true")
- },
- re: function() {
- var a = !1,
- c = navigator.userAgent || navigator.vendor || window.opera;
- if(/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(c) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(c.substr(0,
- 4))) a = !0;
- return a
- },
- Pc: function() {
- return /iPad|iPhone|iPod/.test(navigator.userAgent) && !window.MSStream
- },
- Je: function() {
- var a = navigator.appVersion.match(/OS (\d+)_(\d+)_?(\d+)?/);
- return a && a.length && 2 < a.length ? [parseInt(a[1], 10), parseInt(a[2], 10), parseInt(a[3] || 0, 10)] : [0, 0, 0]
- },
- zd: function() {
- try {
- return window.matchMedia("(orientation: portrait)")
- .matches ? !0 : !1
- } catch (a) {
- return window.innerHeight > window.innerWidth
- }
- },
- qe: function() {
- return V.Qc() || V.Pc()
- },
- Qc: function() {
- var a = navigator.userAgent.toLowerCase();
- return -1 !== a.indexOf("safari") && -1 === a.indexOf("chrome") ? !0 : !1
- },
- Gg: function() {
- return V.re() ? V.zd() ? window.innerHeight / window.innerWidth * 45 : 45 : 45
- },
- Sc: function() {
- return navigator.mediaDevices && navigator.mediaDevices.getUserMedia ? !0 : !1
- },
- pause: function(a) {
- a.pause()
- },
- Bh: function(a) {
- a.play()
- },
- release: function(a) {
- a.pause();
- a.videoStream && a.videoStream.stop();
- a.videoStream = null
- },
- Rc: function(a) {
- if(!a) return a;
- var c = null;
- if(a.video) {
- var d = function(e) {
- return e && "object" === typeof e ? Object.assign({}, e) : e
- };
- c = {};
- "undefined" !== typeof a.video.width && (c.width = d(a.video.width));
- "undefined" !== typeof a.video.height && (c.height = d(a.video.height));
- "undefined" !== typeof a.video.facingMode && (c.facingMode = d(a.video.facingMode))
- }
- c = {
- audio: a.audio,
- video: c
- };
- "undefined" !== typeof a.deviceId && V.Ic(c, a.deviceId);
- return c
- },
- Ic: function(a, c) {
- c && (a.video = a.video || {}, a.video.deviceId = {
- exact: c
- }, a.video.facingMode && delete a.video.facingMode)
- },
- Xd: function(a) {
- var c = a.video.width;
- a.video.width = a.video.height;
- a.video.height = c;
- return a
- },
- ve: function(a) {
- function c(v) {
- return [480, 576, 640, 648, 720, 768, 800, 960, 1080, 1152, 1280, 1366, 1920].sort(function(n, y) {
- return Math.abs(n - v) - Math.abs(y - v)
- })
- }
- function d(v) {
- var n = V.Rc(a);
- v = v(n);
- g.push(v);
- e(v)
- }
- function e(v) {
- if(v.video && v.video.facingMode && v.video.facingMode.exact) {
- var n = v.video.facingMode.exact;
- v = V.Rc(v);
- delete v.video.facingMode.exact;
- v.video.facingMode.ideal = n;
- g.push(v)
- }
- }
- var g = [];
- if(!a || !a.video) return g;
- e(a);
- if(a.video.width && a.video.height) {
- if(a.video.width.ideal && a.video.height.ideal) {
- var m =
- c(a.video.width.ideal)
- .slice(0, 3),
- t = c(a.video.height.ideal)
- .slice(0, 3),
- p = {},
- q = 0;
- for(p.la = void 0; q < m.length; p = {
- la: p.la
- }, ++q) {
- p.la = m[q];
- var u = {},
- r = 0;
- for(u.ka = void 0; r < t.length; u = {
- ka: u.ka
- }, ++r)
- if(u.ka = t[r], p.la !== a.video.width.ideal || u.ka !== a.video.height.ideal) {
- var A = Math.max(p.la, u.ka) / Math.min(p.la, u.ka);
- A < 4 / 3 - .1 || A > 16 / 9 + .1 || d(function(v, n) {
- return function(y) {
- y.video.width.ideal = v.la;
- y.video.height.ideal = n.ka;
- return y
- }
- }(p, u))
- }
- }
- }
- d(function(v) {
- return V.Xd(v)
- })
- }
- a.video.width && a.video.height && (a.video.width.ideal &&
- a.video.height.ideal && d(function(v) {
- delete v.video.width.ideal;
- delete v.video.height.ideal;
- return v
- }), d(function(v) {
- delete v.video.width;
- delete v.video.height;
- return v
- }));
- a.video.facingMode && (d(function(v) {
- delete v.video.facingMode;
- return v
- }), a.video.width && a.video.height && d(function(v) {
- V.Xd(v);
- delete v.video.facingMode;
- return v
- }));
- g.push({
- audio: a.audio,
- video: !0
- });
- return g
- },
- Qf: function(a) {
- if(V.zd()) {
- if(!a || !a.video) return !1;
- var c = a.video.width,
- d = a.video.height;
- if(!c || !d) return !1;
- if(c.ideal && d.ideal &&
- c.ideal > d.ideal) return a.video.height = c, a.video.width = d, !0
- }
- return !1
- },
- rb: function(a) {
- a.volume = 0;
- V.Ma(a, "muted");
- if(V.Qc()) {
- if(1 === a.volume) {
- var c = function() {
- a.volume = 0;
- window.removeEventListener("mousemove", c, !1);
- window.removeEventListener("touchstart", c, !1)
- };
- window.addEventListener("mousemove", c, !1);
- window.addEventListener("touchstart", c, !1)
- }
- setTimeout(function() {
- a.volume = 0;
- V.Ma(a, "muted")
- }, 5)
- }
- },
- $d: function(a, c, d) {
- return null === a ? Promise.resolve() : new Promise(function(e, g) {
- if(a.srcObject && a.srcObject.getVideoTracks) {
- var m =
- a.srcObject.getVideoTracks();
- 1 !== m.length ? g("INVALID_TRACKNUMBER") : (m = m[0], c ? V.get(a, e, g, d) : (m.stop(), e()))
- } else g("BAD_IMPLEMENTATION")
- })
- },
- kd: function(a, c, d, e) {
- function g(t) {
- m || (m = !0, d(t))
- }
- var m = !1;
- return navigator.mediaDevices.getUserMedia(e)
- .then(function(t) {
- function p() {
- setTimeout(function() {
- if(a.currentTime) {
- var u = a.videoWidth,
- r = a.videoHeight;
- if(0 === u || 0 === r) g("VIDEO_NULLSIZE");
- else {
- u && (a.style.width = u.toString() + "px");
- r && (a.style.height = r.toString() + "px");
- var A = {
- pe: null,
- Mf: null,
- mf: null
- };
- try {
- var v =
- t.getVideoTracks()[0];
- v && (A.mf = v, A.pe = v.getCapabilities(), A.Mf = v.getSettings())
- } catch (n) {}
- V.qe() ? a.parentNode && null !== a.parentNode ? (m || c(a, t, A), setTimeout(function() {
- a.play()
- }, 100)) : (document.body.appendChild(a), V.rb(a), setTimeout(function() {
- a.style.transform = "scale(0.0001,0.0001)";
- a.style.position = "fixed";
- a.style.bottom = "0px";
- a.style.right = "0px";
- V.rb(a);
- setTimeout(function() {
- a.play();
- m || c(a, t, A)
- }, 100)
- }, 80)) : m || c(a, t, A)
- }
- } else g("VIDEO_NOTSTARTED")
- }, 700)
- }
- function q() {
- a.removeEventListener("loadeddata",
- q, !1);
- var u = a.play();
- V.rb(a);
- "undefined" === typeof u ? p() : u.then(function() {
- p()
- })
- .catch(function() {
- g("VIDEO_PLAYPROMISEREJECTED")
- })
- }
- "undefined" !== typeof a.srcObject ? a.srcObject = t : (a.src = window.URL.createObjectURL(t), a.videoStream = t);
- V.rb(a);
- a.addEventListener("loadeddata", q, !1)
- })
- .catch(function(t) {
- g(t)
- })
- },
- Ve: function(a, c) {
- var d = c || V.ld();
- return new Promise(function(e, g) {
- V.get(d, e, g, a)
- })
- },
- get: function(a, c, d, e) {
- if(!a) return d && d("VIDEO_NOTPROVIDED"), !1;
- if(!V.Sc()) return d && d("MEDIASTREAMAPI_NOTFOUND"),
- !1;
- if(e && e.video) {
- if(V.Pc()) {
- var g = V.Je();
- 0 !== g[0] && (12 > g[0] || 12 === g[0] && 2 > g[1]) && V.Qf(e)
- }
- e.video.width && e.video.width.ideal && (a.style.width = e.video.width.ideal + "px");
- e.video.height && e.video.height.ideal && (a.style.height = e.video.height.ideal + "px")
- }
- V.Ma(a, "autoplay");
- V.Ma(a, "playsinline");
- e && e.audio ? a.volume = 0 : V.Ma(a, "muted");
- V.kd(a, c, function() {
- function m(p) {
- if(0 === p.length) d("INVALID_FALLBACKCONSTRAINTS");
- else {
- var q = p.shift();
- V.kd(a, c, function() {
- m(p)
- }, q)
- }
- }
- var t = V.ve(e);
- m(t)
- }, e)
- },
- We: function(a) {
- if(!navigator.mediaDevices ||
- !navigator.mediaDevices.enumerateDevices) return a(!1, "NOTSUPPORTED"), !1;
- navigator.mediaDevices.enumerateDevices()
- .then(function(c) {
- (c = c.filter(function(d) {
- return d.kind && -1 !== d.kind.toLowerCase()
- .indexOf("video") && d.label && d.deviceId
- })) && c.length && 0 < c.length ? a(c, !1) : a(!1, "NODEVICESFOUND")
- })
- .catch(function() {
- a(!1, "PROMISEREJECTED")
- })
- },
- gg: function(a, c, d) {
- var e = {};
- e[c] = d;
- c = [];
- c.push(e);
- a.applyConstraints({
- advanced: c
- })
- .catch(function() {})
- }
- },
- qa = function() {
- function a(y, E, k, M, H, l, J) {
- if(!v)
- if(J === l.length) H();
- else {
- switch (l[J]) {
- case "A":
- k();
- break;
- case "D":
- y();
- break;
- case "S":
- E()
- .then(function(w, L) {
- n.Bb();
- a(y, E, k, L ? null : M, H, l, ++J)
- })
- .catch(function() {
- H()
- });
- return;
- case "R":
- M && M()
- }
- a(y, E, k, M, H, l, ++J)
- }
- }
- var c = {
- n: 5,
- ic: 1,
- Bd: 0,
- cb: [35, 49],
- Za: [2, 200],
- k: .7,
- Vf: 200,
- uf: .05
- },
- d = -1,
- e = null,
- g = -1,
- m = -1,
- t = 0,
- p = -1,
- q = -1,
- u = 0,
- r = 0,
- A = c.Za[1],
- v = !0,
- n = {
- Te: function() {
- switch (d) {
- case -1:
- return -1;
- case 0:
- return q + e.Bd;
- case 1:
- return u
- }
- },
- Lg: function(y) {
- return Math.pow(Math.min(Math.max(p, 0), e.n - 1) / (e.n - 1), y || 1)
- },
- o: function(y) {
- e = Object.assign({},
- c, y);
- p = q = e.ic;
- d = 0;
- n.reset()
- },
- Bb: function(y) {
- y = ("undefined" === typeof y ? Date.now() : y) || 0;
- var E = Math.min(Math.max(y - r, e.Za[0]), e.Za[1]);
- A = E;
- r = y;
- var k = -1 === g ? 0 : e.k;
- g = Math.min(Math.max(1E3 / E, 5), 120) * (1 - k) + g * k;
- y - m > e.Vf && 5 < ++t && (E = e.k, p = p * (1 - E) + (g < e.cb[0] ? q - 1 : g > e.cb[1] ? q + 1 : q) * E, Math.abs(p - q) > 1 - e.uf && (E = Math.min(Math.max(Math.round(p), 0), e.n - 1), E !== q && (p = q = E, g = (e.cb[1] - e.cb[0]) / 2)), m = y)
- },
- qc: function(y, E, k, M, H, l) {
- v = !1;
- a(y, E, k, M, H, l, 0)
- },
- stop: function() {
- v = !0
- },
- sc: function(y) {
- u = y;
- d = 1
- },
- Bc: function() {
- d = 0;
- n.reset()
- },
- reset: function() {
- A = c.Za[1];
- m = g = -1;
- t = 0
- },
- Me: function() {
- return A
- }
- };
- return n
- }(),
- Na = function() {
- function a() {
- d(E + n.hc);
- k.port.postMessage("DONE")
- }
- function c() {
- J.Ua = 0 === n.Ta ? H(d) : H(e)
- }
- function d(f) {
- l.Aa && null !== y && (f -= E, f = Math.min(Math.max(f, n.Vc[0]), n.Vc[1]), E += f, m(), w.isEnabled && w.Pa && l.W && E - w.cc > n.Fc && (u(), w.cc = E), y(E))
- }
- function e(f) {
- l.Aa && (J.timeout = setTimeout(d.bind(null, f), n.Ta))
- }
- function g() {
- y = null;
- l.Aa = !1;
- m()
- }
- function m() {
- J.Ua && (window.cancelAnimationFrame(J.Ua), J.Ua = null);
- J.timeout && (window.clearTimeout(J.timeout),
- J.timeout = null)
- }
- function t(f) {
- f && !l.W ? (l.W = !0, M && qa.Bc(), k.port.postMessage("STOP"), aa.Zd(!0), c()) : !f && l.W && (l.W = !1, M && qa.sc(1), aa.Zd(!1), k.port.postMessage("START"))
- }
- function p(f) {
- f.target.hidden ? N() : L()
- }
- function q(f, z, I) {
- z = f.createShader(z);
- f.shaderSource(z, I);
- f.compileShader(z);
- return z
- }
- function u() {
- w.Pa = !1;
- var f = w.ga,
- z = w.hb,
- I = w.ib,
- h = w.V;
- f.uniform1f(w.md, Math.random());
- w.Ba ? z.beginQueryEXT(h, I) : f.beginQuery(h, I);
- f.drawElements(f.POINTS, 1, f.UNSIGNED_SHORT, 0);
- w.Ba ? z.endQueryEXT(h) : f.endQuery(h);
- aa.flush();
- A()
- .then(function(C) {
- C = n.ce * n.Ec * 1E3 / C;
- w.Eb = (w.Eb + 1) % n.Ea;
- w.dc[w.Eb] = C;
- ++w.Ad > n.Ea && (w.ob.set(w.dc), w.ob.sort(function(K, O) {
- return K - O
- }), C = w.ob[Math.floor(n.Ea / 2)], w.ab = Math.max(w.ab, C), n.Dc(C / w.ab));
- w.Pa = !0
- })
- .catch(function() {
- w.Pa = !0
- })
- }
- function r(f) {
- var z = w.ga,
- I = w.hb,
- h = w.ib;
- h = w.Ba ? I.Ig(h, I.QUERY_RESULT_AVAILABLE_EXT) : z.getQueryParameter(h, z.QUERY_RESULT_AVAILABLE);
- z = z.getParameter(I.GPU_DISJOINT_EXT);
- h ? f(!z) : setTimeout(r.bind(null, f), .1)
- }
- function A() {
- return new Promise(function(f, z) {
- r(function(I) {
- if(I) {
- I =
- w.ga;
- var h = w.hb,
- C = w.ib;
- I = w.Ba ? h.getQueryObjectEXT(C, h.QUERY_RESULT_EXT) : I.getQueryParameter(C, I.QUERY_RESULT);
- f(I)
- } else z()
- })
- })
- }
- var v = {
- ud: !0,
- Vc: [1, 200],
- hc: 20,
- Ta: 0,
- Ec: 50,
- ce: 240,
- Fc: 3E3,
- Ea: 3,
- Dc: null
- },
- n = null,
- y = null,
- E = 0,
- k = null,
- M = !1,
- H = null,
- l = {
- pa: !1,
- W: !0,
- bc: !1,
- ac: !1,
- $b: !1,
- Aa: !1
- },
- J = {
- Ua: null,
- timeout: null
- },
- w = {
- isEnabled: !1,
- Pa: !1,
- ga: null,
- hb: null,
- ib: null,
- V: null,
- md: null,
- Ba: !0,
- cc: 0,
- Ad: 0,
- dc: null,
- ob: null,
- Eb: 0,
- ab: 0
- },
- L = t.bind(null, !0),
- N = t.bind(null, !1),
- x = {
- o: function(f) {
- n = Object.assign(v, f);
- Object.assign(l, {
- W: !0,
- pa: !0,
- Aa: !1
- });
- H = window.requestPostAnimationFrame || window.requestAnimationFrame;
- if(null !== n.Dc) {
- f = document.createElement("canvas");
- f.setAttribute("width", "1");
- f.setAttribute("height", "1");
- var z = {
- antialias: !1
- };
- f = f.getContext("webgl2", z) || f.getContext("webgl", z);
- if(z = f.getExtension("EXT_disjoint_timer_query") || f.getExtension("EXT_disjoint_timer_query_webgl2")) {
- w.ga = f;
- w.hb = z;
- w.isEnabled = !0;
- w.Ba = z.beginQueryEXT ? !0 : !1;
- var I = q(f, f.VERTEX_SHADER, "attribute vec4 a0;void main(){gl_Position=a0;}"),
- h = q(f, f.FRAGMENT_SHADER,
- "precision lowp float;uniform float u37;void main(){vec4 a=u37*vec4(1.,2.,3.,4.);for(int b=0;b<666;b+=1)a=cos(a);gl_FragColor=a;}".replace("666", n.Ec.toString())),
- C = f.createProgram();
- f.attachShader(C, I);
- f.attachShader(C, h);
- f.linkProgram(C);
- I = f.getAttribLocation(C, "a0");
- w.md = f.getUniformLocation(C, "u37");
- f.useProgram(C);
- f.enableVertexAttribArray(I);
- C = f.createBuffer();
- f.bindBuffer(f.ARRAY_BUFFER, C);
- f.bufferData(f.ARRAY_BUFFER, new Float32Array([.5, .5, 0, 1]), f.STATIC_DRAW);
- f.vertexAttribPointer(I, 4, f.FLOAT,
- !1, 16, 0);
- C = f.createBuffer();
- f.bindBuffer(f.ELEMENT_ARRAY_BUFFER, C);
- f.bufferData(f.ELEMENT_ARRAY_BUFFER, new Uint16Array([0]), f.STATIC_DRAW);
- f.disable(f.DEPTH_TEST);
- f.disable(f.DITHER);
- f.disable(f.STENCIL_TEST);
- f.viewport(0, 0, 1, 1);
- C = w.Ba ? z.createQueryEXT() : f.createQuery();
- w.ib = C;
- w.V = z.TIME_ELAPSED_EXT || f.TIME_ELAPSED;
- w.cc = -n.Fc;
- w.dc = new Float32Array(n.Ea);
- w.ob = new Float32Array(n.Ea);
- w.ab = 0;
- w.Eb = 0;
- w.Ad = 0;
- w.Pa = !0
- }
- }
- if(n.ud) {
- f = !1;
- try {
- if("undefined" === typeof SharedWorker) {
- var K = URL.createObjectURL(new Blob(["let handler = null;\n self.addEventListener('message', function(e){\n if (handler !== null){\n clearTimeout(handler);\n handler = null;\n }\n switch (e.data) {\n case 'START':\n case 'DONE':\n handler = setTimeout(function(){\n self.postMessage('TICK');\n }, " +
- n.hc.toString() + ");\n break;\n case 'STOP':\n break;\n };\n }, false);"
- ], {
- type: "text/javascript"
- })),
- O = new Worker(K);
- O.addEventListener("message", a);
- k = {
- Id: O,
- port: O
- };
- l.bc = !0
- } else {
- var Y = URL.createObjectURL(new Blob(["let handler = null;\n onconnect = function(e) {\n const port = e.ports[0];\n port.addEventListener('message', function(e) {\n \n if (handler !== null){\n clearTimeout(handler);\n handler = null;\n }\n switch (e.data) {\n case 'START':\n case 'DONE':\n handler = setTimeout(function(){\n port.postMessage('TICK');\n }, " +
- n.hc.toString() + ");\n break;\n case 'STOP':\n break;\n };\n \n });\n \n port.start();\n } // end onconnect()"
- ], {
- type: "text/javascript"
- })),
- oa = new SharedWorker(Y);
- oa.port.start();
- oa.port.addEventListener("message", a);
- k = {
- Id: oa,
- port: oa.port
- };
- l.ac = !0
- }
- f = !0
- } catch (sa) {}
- f && ("onvisibilitychange" in document ? document.addEventListener("visibilitychange", p) : (window.addEventListener("blur", N), window.addEventListener("focus", L)), l.$b = !0)
- }
- M = "undefined" !== typeof qa
- },
- m: function() {
- g();
- l.$b && ("onvisibilitychange" in document ? document.removeEventListener("visibilitychange", p) : (window.removeEventListener("blur", N), window.removeEventListener("focus", L)), l.$b = !1);
- l.ac ? (k.port.close(), l.ac = !1) : l.bc && (k.Id.terminate(), l.bc = !1);
- Object.assign(l, {
- W: !0,
- pa: !1,
- Aa: !1
- });
- y = null
- },
- qh: function() {
- return l.W
- },
- update: function(f) {
- Object.assign(n, f)
- },
- qc: function(f) {
- l.pa || x.o({});
- m();
- l.Aa = !0;
- y = f;
- l.W && c()
- },
- stop: g
- };
- return x
- }(),
- vb = function() {
- var a = {
- Ed: 4,
- ub: [1.5,
- 1.5, 2
- ],
- N: [.1, .1, .1],
- Md: 1,
- C: -1,
- L: -1,
- Pf: 2,
- tf: 1,
- Od: !0,
- De: .8
- },
- c = null,
- d = [],
- e = [0],
- g = [.5, .5, 1];
- return {
- o: function(m) {
- c = Object.assign({}, a, m);
- d.splice(0);
- m = c.ub[0] * c.N[0];
- var t = c.ub[1] * c.N[1],
- p = 1 / (1 + c.ub[2] * c.N[2]),
- q = c.Md * Math.min(c.C, c.L),
- u = q / c.C;
- q /= c.L;
- var r = .5 * c.De;
- r *= r;
- for(var A = 0; A < c.Ed; ++A) {
- var v = Math.pow(p, A),
- n = u * v,
- y = q * v;
- v = n * c.tf;
- var E = n * m,
- k = y * t;
- n /= 2;
- y /= 2;
- for(var M = 1 + (1 - n - n) / E, H = 1 + (1 - y - y) / k, l = 0; l < H; ++l)
- for(var J = y + l * k, w = J - .5, L = 0; L < M; ++L) {
- var N = n + L * E,
- x = N - .5;
- x * x + w * w > r || d.push([N, J, v])
- }
- }
- c.Od && d.sort(function(f,
- z) {
- var I = f[0] - .5;
- f = f[1] - .5;
- var h = z[0] - .5;
- z = z[1] - .5;
- return I * I + f * f - (h * h + z * z)
- })
- },
- get: function(m) {
- var t = d.length;
- if(0 === t) return g;
- for(; m >= e.length;) e.push(0);
- e[m] >= t && (e[m] = 0);
- var p = d[Math.floor(e[m])];
- e[m] = (e[m] + 1 / c.Pf) % t;
- return p
- },
- reset: function() {
- for(var m = d.length / e.length, t = 0; t < e.length; ++t) e[t] = Math.floor(t * m)
- }
- }
- }(),
- da = function() {
- function a(r, A, v, n) {
- return v > r ? Math.max(0, r + A / 2 - (v - n / 2)) : Math.max(0, v + n / 2 - (r - A / 2))
- }
- function c(r) {
- return !g.rd(r)
- }
- function d(r, A, v) {
- return r.some(function(n, y) {
- if(y === A) return !1;
- y = r[A];
- return y.qa > n.qa || 3 > n.qa || a(y.x, y.ja, n.x, n.ja) < g.fc * y.ja ? !1 : a(y.y, y.ja * v, n.y, n.ja * v) > g.fc * y.ja * v
- })
- }
- var e = {
- M: 1,
- fc: .3,
- Pd: .3,
- rd: null,
- ff: !0
- },
- g = null,
- m = 0,
- t = null,
- p = !1,
- q = 0,
- u = 0;
- return {
- o: function(r) {
- g = Object.assign({}, e, r);
- t = [0]
- },
- yd: function() {
- return 1 !== g.M
- },
- hd: function() {
- return m
- },
- xd: function() {
- return p
- },
- na: function() {
- return g.M
- },
- ah: function() {
- return t
- },
- jf: function(r) {
- return t.includes(r)
- },
- update: function(r, A) {
- var v = t;
- if(v.length > r) v.splice(0, v.length - r);
- else
- for(; v.length < r;) v.push(0);
- if(1 !== g.M)
- if(A.every(c)) {
- A =
- q;
- for(var n = 0; n < r; ++n) v[n] = A, A = (A + 1) % g.M;
- q = A
- } else {
- n = Math.round(g.Pd * r);
- n = Math.max(1, n);
- for(var y = q, E = 0, k = 0; E < r; ++E) {
- if(c(A[y]) && ++k > n) {
- do ++y === g.M && (y = 0); while(c(A[y]))
- }
- v[E] = y;
- y = (y + 1) % g.M
- }
- q = y
- }
- },
- Bb: function(r) {
- m = t[r];
- u = (.5 + m) / g.M;
- p = t.lastIndexOf(m) === r;
- return m
- },
- Nf: function(r, A) {
- return 1 === g.M ? !1 : d(r, m, A)
- },
- Yd: function(r) {
- g.ff && 1 === g.M || D.G(r, u)
- },
- Ce: function(r) {
- for(var A = new Float32Array(r.length * g.M), v = 0, n; v < g.M; ++v)
- for(n = 0; n < r.length; ++n) A[v * r.length + n] = r[n];
- return A
- },
- Qb: function(r) {
- for(var A = [],
- v = 0; v < g.M; ++v) A.push(JSON.parse(JSON.stringify(r)));
- return A
- }
- }
- }(),
- ea = {
- neuralNetworkPath: "NN_DEFAULT.json",
- ba: 0,
- Cf: {
- threshold: 1.2,
- nScaleLevels: 2,
- scale0Factor: .8,
- nDetectsPerLoopRange: [2, 12],
- overlapFactors: [2, 2, 3],
- scanCenterFirst: !0,
- nDetectsPerLoop: -1,
- multiDetectionThresholdFactors: [.5, .6],
- translationScalingFactors: [.3, .3, 1],
- isCleanGLStateAtEachIteration: !0,
- animateProcessOrder: "DSAR"
- },
- Sf: 50,
- qf: .4,
- pf: 8,
- rf: .3,
- Of: {
- translationFactorRange: [.002, .005],
- rotationFactorRange: [.015,
- .1
- ],
- qualityFactorRange: [.9, .98],
- alphaRange: [.05, 1],
- followZRotAlphaFactor: .8
- },
- Qa: [.65, 1, .262],
- ee: .2,
- ge: 2,
- fe: .1,
- sf: 8,
- Dd: 1,
- Ge: Za.qb.bind(null, .3, .7),
- Xf: 20,
- Vd: 3
- },
- pa = {
- facingMode: "user",
- idealWidth: 800,
- idealHeight: 600,
- minWidth: 480,
- maxWidth: 1920,
- minHeight: 480,
- maxHeight: 1920,
- rotate: 0,
- flipX: !1
- },
- ia = {
- kc: -3,
- kf: -1,
- error: -2,
- ready: 1,
- play: 2,
- pause: 3
- },
- na = ia.kc,
- G = null,
- bc = {
- kb: !1,
- vc: null,
- element: null,
- K: null,
- D: [0, 0],
- v: [.5, 0, 0, .5],
- wb: 0,
- Ka: null,
- jb: !1
- },
- Q = null,
- cc = {
- Ja: null,
- Gb: null,
- antialias: !0,
- Gc: "./",
- Fa: null,
- da: null,
- ba: ea.ba,
- Hd: ea.ba,
- lb: !1,
- wa: !0
- },
- Pa = null,
- ba = null,
- ra = null,
- Qa = 1,
- Oa = {
- rc: -1,
- Lb: -1
- },
- Z = null,
- dc = {
- C: 0,
- L: 0,
- D: [0, 0],
- Oa: null
- },
- U = {
- ta: null,
- buffer: null,
- N: null,
- Qa: null,
- Y: ea.Dd,
- Nd: 1,
- Na: null
- },
- Sa = null,
- Fa = null,
- hb = [],
- ib = [],
- qb = {
- VERSION: "3.1.1",
- init: function(a) {
- function c() {
- na !== ia.error && 2 === ++e && (Ka(), xb(), Ja(), Q.Ja && (na = ia.ready, Q.Ja(!1, {
- GL: b,
- canvasElement: Q.da,
- videoTexture: G.K.get(),
- videoTransformMat2: G.v,
- maxFacesDetected: da.na(),
- videoElement: G.element
- }), gb()), fb())
- }
- if(na !== ia.kc) return a.callbackReady && a.callbackReady("ALREADY_INITIALIZED"),
- !1;
- na = ia.kf;
- G = Object.assign({}, bc);
- Q = Object.assign({}, cc);
- Z = Object.assign({}, dc);
- U.Qa = ea.Qa.slice(0);
- "undefined" !== typeof a.antialias && (Q.antialias = a.antialias);
- a.callbackReady && (Q.Ja = a.callbackReady);
- a.callbackTrack && (Q.Gb = a.callbackTrack);
- a.nExpressions && (U.Y = a.nExpressions);
- a.expressionsEasings && (U.Na = a.expressionsEasings);
- "undefined" !== typeof a.animateDelay && (Q.ba = a.animateDelay);
- "undefined" !== typeof a.NNCPath && (Q.Gc = a.NNCPath);
- "undefined" !== typeof a.NNC && (Q.Fa = a.NNC);
- "undefined" !== typeof a.followZRot &&
- (Q.wa = a.followZRot ? !0 : !1);
- if(!a.canvasId && !a.canvas) return Ia("NO_CANVASID"), !1;
- Q.da = a.canvas ? a.canvas : document.getElementById(a.canvasId);
- if(!Q.da) return Ia("INVALID_CANVASID"), !1;
- Z.C = Q.da.width;
- Z.L = Q.da.height;
- if(!Z.C || !Z.L) return Ia("INVALID_CANVASDIMENSIONS"), !1;
- ba = Object.create(ea.Cf);
- a.scanSettings && Object.assign(ba, a.scanSettings);
- var d = 1;
- "undefined" !== typeof a.maxFacesDetected && (d = Math.max(1, a.maxFacesDetected));
- if(d > ea.pf) return Ia("MAXFACES_TOOHIGH"), !1;
- da.o({
- M: d,
- fc: ea.qf,
- Pd: ea.rf,
- rd: function(g) {
- return g.detected >
- ba.multiDetectionThresholdFactors[1] * ba.threshold
- }
- });
- for(d = 0; d < da.na(); ++d) hb.push(new Float32Array(ea.sf)), ib.push(0);
- Na.o({
- ud: a.isKeepRunningOnWinFocusLost || !1,
- Ta: Q.ba
- });
- qa.o({
- ic: 0,
- n: ba.nDetectsPerLoopRange[1] - ba.nDetectsPerLoopRange[0] + 1,
- Bd: ba.nDetectsPerLoopRange[0]
- }); - 1 !== ba.nDetectsPerLoop ? qa.sc(ba.nDetectsPerLoop) : qa.Bc();
- U.N = ba.translationScalingFactors.slice(0);
- ra = Object.create(ea.Of);
- a.stabilizationSettings && Object.assign(ra, a.stabilizationSettings);
- var e = 0;
- a.videoSettings && a.videoSettings.videoElement ?
- ab(a.videoSettings.videoElement, c) : (a.videoSettings && Object.assign(pa, a.videoSettings), zb(a.onWebcamAsk, a.onWebcamGet, function(g) {
- ab(g, c)
- }));
- Ob(function(g) {
- if(!Pb()) return !1;
- Pa = new Fb({
- pb: g.layers,
- pc: "gpuRawAvg",
- mc: Qb
- });
- D.Kc([{
- id: "s54",
- name: "_",
- ua: "attribute vec2 a0;uniform mat2 u38;varying vec2 vv0;void main(){gl_Position=vec4(a0,0.,1.),vv0=vec2(.5,.5)+u38*a0;}",
- Va: ["a0"],
- Ha: [2],
- h: "uniform sampler2D u1;varying vec2 vv0;void main(){gl_FragColor=texture2D(u1,vv0);}",
- i: ["u1", "u38"],
- precision: "lowp"
- },
- {
- id: "s55",
- name: "_",
- h: "uniform sampler2D u1;varying vec2 vv0;void main(){gl_FragColor=texture2D(u1,vv0);}",
- ua: "attribute vec2 a0;uniform sampler2D u39;uniform mat2 u38;uniform vec2 u40;uniform float u41,u42,u43;varying vec2 vv0;void main(){vec4 a=texture2D(u39,vec2(.17,u41));vec2 f=a.gb,g=a.a*u40,b=a0;b.x*=u43;float c=cos(u42),d=sin(u42);vec2 h=mat2(c,d,-d,c)*b,i=f+h*.5*g,j=i-.5;vv0=vec2(.5,.5)+2.*u38*j,gl_Position=vec4(a0,0.,1.);}",
- Va: ["a0"],
- Ha: [2],
- i: "u1 u39 u40 u41 u42 u43 u38".split(" "),
- precision: "lowp"
- },
- {
- id: "s56",
- name: "_",
- h: "uniform sampler2D u44,u39;uniform vec3 u45,u46;uniform float u47,u48,u41,u49,u42,u50;const vec4 e=vec4(.25,.25,.25,.25);void main(){vec4 d=texture2D(u44,vec2(.625,.625)),f=texture2D(u44,vec2(.875,.625)),a=texture2D(u39,vec2(.17,u41));float g=dot(d-f,e);bool h=g>u48;a.r<-.5?a.r+=1.:h?a.r=2.:a.r>u47?a.r=0.:a.r>1.9?a.r+=1.:0.,a.r=mix(-2.,a.r,u49);if(a.r<.9)a=vec4(1.,u45);else{a.r*=step(1.9,a.r);float i=dot(e,texture2D(u44,vec2(.875,.875))),j=dot(e,texture2D(u44,vec2(.125,.625))),k=dot(e,texture2D(u44,vec2(.375,.625))),b=cos(u42),c=sin(u42);vec2 l=mat2(b,c*u50,-c/u50,b)*vec2(i,j);a.gba+=vec3(l,k)*u46*a.a;}gl_FragColor=a;}",
- ua: "attribute vec2 a0;void main(){gl_Position=vec4(a0,0.,1.);}",
- i: "u44 u39 u45 u47 u46 u49 u42 u50 u48 u41".split(" ")
- }, {
- id: "s57",
- name: "_",
- ua: "attribute vec2 a0;void main(){gl_Position=vec4(a0,0.,1.);}",
- h: "uniform sampler2D u44;uniform float u49;const vec4 e=vec4(.25,.25,.25,.25);const vec3 f=vec3(.5,.5,.5);void main(){float a=dot(e,texture2D(u44,vec2(.125,.875))),b=dot(e,texture2D(u44,vec2(.375,.875))),c=dot(e,texture2D(u44,vec2(.625,.875))),d=dot(e,texture2D(u44,vec2(.625,.625)));vec3 g=vec3(a,b,c)*.5+f;gl_FragColor=vec4(g,d*u49);}",
- i: ["u44", "u49"]
- }, {
- id: "s58",
- name: "_",
- ua: "attribute vec2 a0;void main(){gl_Position=vec4(a0,0.,1.);}",
- h: "uniform sampler2D u44;const vec4 e=vec4(.25,.25,.25,.25);void main(){float a=dot(e,texture2D(u44,vec2(.375,.375))),b=dot(e,texture2D(u44,vec2(.625,.375))),c=dot(e,texture2D(u44,vec2(.875,.375))),d=dot(e,texture2D(u44,vec2(.125,.125)));gl_FragColor=vec4(a,b,c,d);}",
- i: ["u44"]
- }, {
- id: "s53",
- name: "_",
- h: "uniform sampler2D u39;uniform vec2 u51;uniform float u52;varying vec2 vv0;void main(){float f=step(.5,mod(gl_FragCoord.y+1.5,2.)),c=step(.33,vv0.x);vec4 a=texture2D(u39,vv0+u51);a.a=mix(a.a*u52,a.a,c);vec4 d=floor(255.*a),g=255.*(255.*a-d),b=mix(d,g,f)/255.;b.x=mix(step(a.x,1.5),b.x,c),gl_FragColor=b;}",
- i: ["u39", "u52", "u51"]
- }
- ]);
- ub();
- U.buffer = new Uint8Array(8 * ea.Vd * da.na());
- Sa = da.Qb({
- Xa: 0,
- x: 0,
- y: 0,
- ja: 1,
- rx: 0,
- ry: 0,
- Ra: 0,
- cd: new Float32Array(U.Y),
- qa: 0
- });
- Fa = da.Qb({
- detected: 0,
- x: 0,
- y: 0,
- s: 1,
- xRaw: 0,
- yRaw: 0,
- sRaw: 1,
- rx: 0,
- ry: 0,
- rz: 0,
- expressions: new Float32Array(U.Y)
- });
- da.Qb({
- dx: 0,
- dy: 0,
- Pb: 0,
- Mb: 0,
- Nb: 0,
- Ob: 0
- });
- kb();
- jb();
- c()
- });
- return !0
- },
- destroy: function() {
- Na.m();
- return new Promise(function(a) {
- qb.toggle_pause(!0, !0)
- .finally(function() {
- Pa && Pa.m();
- Ha.m();
- Pa = Fa = Sa = null;
- hb.splice(0);
- ib.splice(0);
- Z.Oa = null;
- U.ta = null;
- G.K = null;
- na = ia.kc;
- a()
- })
- .catch(function() {})
- })
- },
- toggle_videoStream: function(a) {
- return G.jb || !G.element ? Promise.resolve() : V.$d(G.element, a, G.Ka)
- },
- toggle_pause: function(a, c) {
- if(!Ya()) return Promise.reject("NOT_READY");
- c = c ? qb.toggle_videoStream(!a) : Promise.resolve();
- a ? sb() : c.then(function() {
- fb()
- });
- return c
- },
- update_videoSettings: function(a) {
- sb();
- return new Promise(function(c, d) {
- V.$d(G.element, !1, G.Ka)
- .then(function() {
- Object.assign(pa, a);
- zb(null, null, function(e) {
- ab(e, function() {
- Ka();
- Ja();
- fb();
- c()
- })
- })
- })
- .catch(d)
- })
- },
- toggle_slow: function(a) {
- Ya() && na === ia.play && (a && !Q.lb ? (Q.Hd = Q.ba, ba.nDetectsPerLoop = 1, this.set_animateDelay(ea.Zf), Q.lb = !0) : !a && Q.lb && (ba.nDetectsPerLoop = -1, this.set_animateDelay(Q.Hd), Q.lb = !1))
- },
- set_animateDelay: function(a) {
- Q.ba = a;
- Na.update({
- Ta: Q.ba
- })
- },
- resize: function() {
- if(!Ya()) return !1;
- var a = Q.da.width,
- c = Q.da.height;
- if(!lb() && a === Z.C && c === Z.L) return !1;
- Z.C = a;
- Z.L = c;
- D.P();
- kb();
- jb();
- Ka();
- Ja();
- return !0
- },
- set_inputTexture: function(a, c, d) {
- G.D[0] = c;
- G.D[1] = d;
- G.K = X.instance({
- width: c,
- height: d,
- Wb: a
- });
- G.kb = !0;
- Ka();
- gb();
- Ja()
- },
- reset_GLState: function() {
- gb();
- Z.Oa.remove();
- U.ta.remove();
- ub()
- },
- render_video: function() {
- va.O();
- D.set("s54");
- b.viewport(0, 0, Z.C, Z.L);
- G.K.g(0);
- T.l(!0, !0)
- },
- reset_inputTexture: function() {
- G.kb = !1;
- G.K = G.vc;
- lb();
- Ka();
- Ja()
- },
- get_videoDevices: function(a) {
- return V.We(a)
- },
- set_scanSettings: function(a) {
- Object.assign(ba, a); - 1 !== ba.nDetectsPerLoop ? qa.sc(ba.nDetectsPerLoop) : qa.Bc();
- kb();
- jb()
- },
- set_stabilizationSettings: function(a) {
- Object.assign(ra, a)
- },
- set_videoOrientation: function(a, c) {
- Ya() && (pa.flipX =
- c, pa.rotate = a, Ka(), Ja())
- },
- update_videoElement: function(a, c) {
- ab(a ? a : G.element, function() {
- xb();
- Ka();
- Ja();
- c && c()
- })
- },
- create_new: function() {
- return JEELIZFACEFILTERGEN()
- }
- };
- return qb
- };
- const JEELIZFACEFILTER = JEELIZFACEFILTERGEN();
- if(typeof(module) !== 'undefined') {
- module.exports = JEELIZFACEFILTER;
- }
|