UTIF.js 57 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160
  1. ;(function(){
  2. var UTIF = {};
  3. // Make available for import by `require()`
  4. if (typeof module == "object") {module.exports = UTIF;}
  5. else {self.UTIF = UTIF;}
  6. var pako;
  7. if (typeof require == "function") {pako = require("pako");}
  8. else {pako = self.pako;}
  9. function log() { if (typeof process=="undefined" || process.env.NODE_ENV=="development") console.log.apply(console, arguments); }
  10. (function(UTIF, pako){
  11. // Following lines add a JPEG decoder to UTIF.JpegDecoder
  12. (function(){var V="function"===typeof Symbol&&"symbol"===typeof Symbol.iterator?function(g){return typeof g}:function(g){return g&&"function"===typeof Symbol&&g.constructor===Symbol&&g!==Symbol.prototype?"symbol":typeof g},D=function(){function g(g){this.message="JPEG error: "+g}g.prototype=Error();g.prototype.name="JpegError";return g.constructor=g}(),P=function(){function g(g,D){this.message=g;this.g=D}g.prototype=Error();g.prototype.name="DNLMarkerError";return g.constructor=g}();(function(){function g(){this.M=
  13. null;this.B=-1}function W(a,d){for(var f=0,e=[],b,B,k=16;0<k&&!a[k-1];)k--;e.push({children:[],index:0});var l=e[0],r;for(b=0;b<k;b++){for(B=0;B<a[b];B++){l=e.pop();for(l.children[l.index]=d[f];0<l.index;)l=e.pop();l.index++;for(e.push(l);e.length<=b;)e.push(r={children:[],index:0}),l.children[l.index]=r.children,l=r;f++}b+1<k&&(e.push(r={children:[],index:0}),l.children[l.index]=r.children,l=r)}return e[0].children}function X(a,d,f,e,b,B,k,l,r){function n(){if(0<x)return x--,z>>x&1;z=a[d++];if(255===
  14. z){var c=a[d++];if(c){if(220===c&&g){d+=2;var b=a[d++]<<8|a[d++];if(0<b&&b!==f.g)throw new P("Found DNL marker (0xFFDC) while parsing scan data",b);}throw new D("unexpected marker "+(z<<8|c).toString(16));}}x=7;return z>>>7}function q(a){for(;;){a=a[n()];if("number"===typeof a)return a;if("object"!==("undefined"===typeof a?"undefined":V(a)))throw new D("invalid huffman sequence");}}function h(a){for(var c=0;0<a;)c=c<<1|n(),a--;return c}function c(a){if(1===a)return 1===n()?1:-1;var c=h(a);return c>=
  15. 1<<a-1?c:c+(-1<<a)+1}function C(a,b){var d=q(a.D);d=0===d?0:c(d);a.a[b]=a.m+=d;for(d=1;64>d;){var h=q(a.o),k=h&15;h>>=4;if(0===k){if(15>h)break;d+=16}else d+=h,a.a[b+J[d]]=c(k),d++}}function w(a,d){var b=q(a.D);b=0===b?0:c(b)<<r;a.a[d]=a.m+=b}function p(a,c){a.a[c]|=n()<<r}function m(a,b){if(0<A)A--;else for(var d=B;d<=k;){var e=q(a.o),f=e&15;e>>=4;if(0===f){if(15>e){A=h(e)+(1<<e)-1;break}d+=16}else d+=e,a.a[b+J[d]]=c(f)*(1<<r),d++}}function t(a,d){for(var b=B,e=0,f;b<=k;){f=d+J[b];var l=0>a.a[f]?
  16. -1:1;switch(E){case 0:e=q(a.o);f=e&15;e>>=4;if(0===f)15>e?(A=h(e)+(1<<e),E=4):(e=16,E=1);else{if(1!==f)throw new D("invalid ACn encoding");Q=c(f);E=e?2:3}continue;case 1:case 2:a.a[f]?a.a[f]+=l*(n()<<r):(e--,0===e&&(E=2===E?3:0));break;case 3:a.a[f]?a.a[f]+=l*(n()<<r):(a.a[f]=Q<<r,E=0);break;case 4:a.a[f]&&(a.a[f]+=l*(n()<<r))}b++}4===E&&(A--,0===A&&(E=0))}var g=9<arguments.length&&void 0!==arguments[9]?arguments[9]:!1,u=f.P,v=d,z=0,x=0,A=0,E=0,Q,K=e.length,F,L,M,I;var R=f.S?0===B?0===l?w:p:0===l?
  17. m:t:C;var G=0;var O=1===K?e[0].c*e[0].l:u*f.O;for(var S,T;G<O;){var U=b?Math.min(O-G,b):O;for(F=0;F<K;F++)e[F].m=0;A=0;if(1===K){var y=e[0];for(I=0;I<U;I++)R(y,64*((y.c+1)*(G/y.c|0)+G%y.c)),G++}else for(I=0;I<U;I++){for(F=0;F<K;F++)for(y=e[F],S=y.h,T=y.j,L=0;L<T;L++)for(M=0;M<S;M++)R(y,64*((y.c+1)*((G/u|0)*y.j+L)+(G%u*y.h+M)));G++}x=0;(y=N(a,d))&&y.f&&((0,_util.warn)("decodeScan - unexpected MCU data, current marker is: "+y.f),d=y.offset);y=y&&y.F;if(!y||65280>=y)throw new D("marker was not found");
  18. if(65488<=y&&65495>=y)d+=2;else break}(y=N(a,d))&&y.f&&((0,_util.warn)("decodeScan - unexpected Scan data, current marker is: "+y.f),d=y.offset);return d-v}function Y(a,d){for(var f=d.c,e=d.l,b=new Int16Array(64),B=0;B<e;B++)for(var k=0;k<f;k++){var l=64*((d.c+1)*B+k),r=b,n=d.G,q=d.a;if(!n)throw new D("missing required Quantization Table.");for(var h=0;64>h;h+=8){var c=q[l+h];var C=q[l+h+1];var w=q[l+h+2];var p=q[l+h+3];var m=q[l+h+4];var t=q[l+h+5];var g=q[l+h+6];var u=q[l+h+7];c*=n[h];if(0===(C|
  19. w|p|m|t|g|u))c=5793*c+512>>10,r[h]=c,r[h+1]=c,r[h+2]=c,r[h+3]=c,r[h+4]=c,r[h+5]=c,r[h+6]=c,r[h+7]=c;else{C*=n[h+1];w*=n[h+2];p*=n[h+3];m*=n[h+4];t*=n[h+5];g*=n[h+6];u*=n[h+7];var v=5793*c+128>>8;var z=5793*m+128>>8;var x=w;var A=g;m=2896*(C-u)+128>>8;u=2896*(C+u)+128>>8;p<<=4;t<<=4;v=v+z+1>>1;z=v-z;c=3784*x+1567*A+128>>8;x=1567*x-3784*A+128>>8;A=c;m=m+t+1>>1;t=m-t;u=u+p+1>>1;p=u-p;v=v+A+1>>1;A=v-A;z=z+x+1>>1;x=z-x;c=2276*m+3406*u+2048>>12;m=3406*m-2276*u+2048>>12;u=c;c=799*p+4017*t+2048>>12;p=4017*
  20. p-799*t+2048>>12;t=c;r[h]=v+u;r[h+7]=v-u;r[h+1]=z+t;r[h+6]=z-t;r[h+2]=x+p;r[h+5]=x-p;r[h+3]=A+m;r[h+4]=A-m}}for(n=0;8>n;++n)c=r[n],C=r[n+8],w=r[n+16],p=r[n+24],m=r[n+32],t=r[n+40],g=r[n+48],u=r[n+56],0===(C|w|p|m|t|g|u)?(c=5793*c+8192>>14,c=-2040>c?0:2024<=c?255:c+2056>>4,q[l+n]=c,q[l+n+8]=c,q[l+n+16]=c,q[l+n+24]=c,q[l+n+32]=c,q[l+n+40]=c,q[l+n+48]=c,q[l+n+56]=c):(v=5793*c+2048>>12,z=5793*m+2048>>12,x=w,A=g,m=2896*(C-u)+2048>>12,u=2896*(C+u)+2048>>12,v=(v+z+1>>1)+4112,z=v-z,c=3784*x+1567*A+2048>>
  21. 12,x=1567*x-3784*A+2048>>12,A=c,m=m+t+1>>1,t=m-t,u=u+p+1>>1,p=u-p,v=v+A+1>>1,A=v-A,z=z+x+1>>1,x=z-x,c=2276*m+3406*u+2048>>12,m=3406*m-2276*u+2048>>12,u=c,c=799*p+4017*t+2048>>12,p=4017*p-799*t+2048>>12,t=c,c=v+u,u=v-u,C=z+t,g=z-t,w=x+p,t=x-p,p=A+m,m=A-m,c=16>c?0:4080<=c?255:c>>4,C=16>C?0:4080<=C?255:C>>4,w=16>w?0:4080<=w?255:w>>4,p=16>p?0:4080<=p?255:p>>4,m=16>m?0:4080<=m?255:m>>4,t=16>t?0:4080<=t?255:t>>4,g=16>g?0:4080<=g?255:g>>4,u=16>u?0:4080<=u?255:u>>4,q[l+n]=c,q[l+n+8]=C,q[l+n+16]=w,q[l+n+24]=
  22. p,q[l+n+32]=m,q[l+n+40]=t,q[l+n+48]=g,q[l+n+56]=u)}return d.a}function N(a,d){var f=2<arguments.length&&void 0!==arguments[2]?arguments[2]:d,e=a.length-1;f=f<d?f:d;if(d>=e)return null;var b=a[d]<<8|a[d+1];if(65472<=b&&65534>=b)return{f:null,F:b,offset:d};for(var B=a[f]<<8|a[f+1];!(65472<=B&&65534>=B);){if(++f>=e)return null;B=a[f]<<8|a[f+1]}return{f:b.toString(16),F:B,offset:f}}var J=new Uint8Array([0,1,8,16,9,2,3,10,17,24,32,25,18,11,4,5,12,19,26,33,40,48,41,34,27,20,13,6,7,14,21,28,35,42,49,56,
  23. 57,50,43,36,29,22,15,23,30,37,44,51,58,59,52,45,38,31,39,46,53,60,61,54,47,55,62,63]);g.prototype={parse:function(a){function d(){var d=a[k]<<8|a[k+1];k+=2;return d}function f(){var b=d();b=k+b-2;var c=N(a,b,k);c&&c.f&&((0,_util.warn)("readDataBlock - incorrect length, current marker is: "+c.f),b=c.offset);b=a.subarray(k,b);k+=b.length;return b}function e(a){for(var b=Math.ceil(a.v/8/a.s),c=Math.ceil(a.g/8/a.u),d=0;d<a.b.length;d++){v=a.b[d];var e=Math.ceil(Math.ceil(a.v/8)*v.h/a.s),f=Math.ceil(Math.ceil(a.g/
  24. 8)*v.j/a.u);v.a=new Int16Array(64*c*v.j*(b*v.h+1));v.c=e;v.l=f}a.P=b;a.O=c}var b=(1<arguments.length&&void 0!==arguments[1]?arguments[1]:{}).N,B=void 0===b?null:b,k=0,l=null,r=0;b=[];var n=[],q=[],h=d();if(65496!==h)throw new D("SOI not found");for(h=d();65497!==h;){switch(h){case 65504:case 65505:case 65506:case 65507:case 65508:case 65509:case 65510:case 65511:case 65512:case 65513:case 65514:case 65515:case 65516:case 65517:case 65518:case 65519:case 65534:var c=f();65518===h&&65===c[0]&&100===
  25. c[1]&&111===c[2]&&98===c[3]&&101===c[4]&&(l={version:c[5]<<8|c[6],Y:c[7]<<8|c[8],Z:c[9]<<8|c[10],W:c[11]});break;case 65499:h=d()+k-2;for(var g;k<h;){var w=a[k++],p=new Uint16Array(64);if(0===w>>4)for(c=0;64>c;c++)g=J[c],p[g]=a[k++];else if(1===w>>4)for(c=0;64>c;c++)g=J[c],p[g]=d();else throw new D("DQT - invalid table spec");b[w&15]=p}break;case 65472:case 65473:case 65474:if(m)throw new D("Only single frame JPEGs supported");d();var m={};m.X=65473===h;m.S=65474===h;m.precision=a[k++];h=d();m.g=
  26. B||h;m.v=d();m.b=[];m.C={};c=a[k++];for(h=p=w=0;h<c;h++){g=a[k];var t=a[k+1]>>4;var H=a[k+1]&15;w<t&&(w=t);p<H&&(p=H);t=m.b.push({h:t,j:H,T:a[k+2],G:null});m.C[g]=t-1;k+=3}m.s=w;m.u=p;e(m);break;case 65476:g=d();for(h=2;h<g;){w=a[k++];p=new Uint8Array(16);for(c=t=0;16>c;c++,k++)t+=p[c]=a[k];H=new Uint8Array(t);for(c=0;c<t;c++,k++)H[c]=a[k];h+=17+t;(0===w>>4?q:n)[w&15]=W(p,H)}break;case 65501:d();var u=d();break;case 65498:c=1===++r&&!B;d();w=a[k++];g=[];for(h=0;h<w;h++){p=m.C[a[k++]];var v=m.b[p];
  27. p=a[k++];v.D=q[p>>4];v.o=n[p&15];g.push(v)}h=a[k++];w=a[k++];p=a[k++];try{var z=X(a,k,m,g,u,h,w,p>>4,p&15,c);k+=z}catch(x){if(x instanceof P)return(0,_util.warn)('Attempting to re-parse JPEG image using "scanLines" parameter found in DNL marker (0xFFDC) segment.'),this.parse(a,{N:x.g});throw x;}break;case 65500:k+=4;break;case 65535:255!==a[k]&&k--;break;default:if(255===a[k-3]&&192<=a[k-2]&&254>=a[k-2])k-=3;else if((c=N(a,k-2))&&c.f)(0,_util.warn)("JpegImage.parse - unexpected data, current marker is: "+
  28. c.f),k=c.offset;else throw new D("unknown marker "+h.toString(16));}h=d()}this.width=m.v;this.height=m.g;this.A=l;this.b=[];for(h=0;h<m.b.length;h++){v=m.b[h];if(u=b[v.T])v.G=u;this.b.push({R:Y(m,v),U:v.h/m.s,V:v.j/m.u,c:v.c,l:v.l})}this.i=this.b.length},L:function(a,d){var f=this.width/a,e=this.height/d,b,g,k=this.b.length,l=a*d*k,r=new Uint8ClampedArray(l),n=new Uint32Array(a);for(g=0;g<k;g++){var q=this.b[g];var h=q.U*f;var c=q.V*e;var C=g;var w=q.R;var p=q.c+1<<3;for(b=0;b<a;b++)q=0|b*h,n[b]=
  29. (q&4294967288)<<3|q&7;for(h=0;h<d;h++)for(q=0|h*c,q=p*(q&4294967288)|(q&7)<<3,b=0;b<a;b++)r[C]=w[q+n[b]],C+=k}if(e=this.M)for(g=0;g<l;)for(f=q=0;q<k;q++,g++,f+=2)r[g]=(r[g]*e[f]>>8)+e[f+1];return r},w:function(){return this.A?!!this.A.W:3===this.i?0===this.B?!1:!0:1===this.B?!0:!1},I:function(a){for(var d,f,e,b=0,g=a.length;b<g;b+=3)d=a[b],f=a[b+1],e=a[b+2],a[b]=d-179.456+1.402*e,a[b+1]=d+135.459-.344*f-.714*e,a[b+2]=d-226.816+1.772*f;return a},K:function(a){for(var d,f,e,b,g=0,k=0,l=a.length;k<l;k+=
  30. 4)d=a[k],f=a[k+1],e=a[k+2],b=a[k+3],a[g++]=-122.67195406894+f*(-6.60635669420364E-5*f+4.37130475926232E-4*e-5.4080610064599E-5*d+4.8449797120281E-4*b-.154362151871126)+e*(-9.57964378445773E-4*e+8.17076911346625E-4*d-.00477271405408747*b+1.53380253221734)+d*(9.61250184130688E-4*d-.00266257332283933*b+.48357088451265)+b*(-3.36197177618394E-4*b+.484791561490776),a[g++]=107.268039397724+f*(2.19927104525741E-5*f-6.40992018297945E-4*e+6.59397001245577E-4*d+4.26105652938837E-4*b-.176491792462875)+e*(-7.78269941513683E-4*
  31. e+.00130872261408275*d+7.70482631801132E-4*b-.151051492775562)+d*(.00126935368114843*d-.00265090189010898*b+.25802910206845)+b*(-3.18913117588328E-4*b-.213742400323665),a[g++]=-20.810012546947+f*(-5.70115196973677E-4*f-2.63409051004589E-5*e+.0020741088115012*d-.00288260236853442*b+.814272968359295)+e*(-1.53496057440975E-5*e-1.32689043961446E-4*d+5.60833691242812E-4*b-.195152027534049)+d*(.00174418132927582*d-.00255243321439347*b+.116935020465145)+b*(-3.43531996510555E-4*b+.24165260232407);return a.subarray(0,
  32. g)},J:function(a){for(var d,f,e,b=0,g=a.length;b<g;b+=4)d=a[b],f=a[b+1],e=a[b+2],a[b]=434.456-d-1.402*e,a[b+1]=119.541-d+.344*f+.714*e,a[b+2]=481.816-d-1.772*f;return a},H:function(a){for(var d,f,e,b,g=0,k=1/255,l=0,r=a.length;l<r;l+=4)d=a[l]*k,f=a[l+1]*k,e=a[l+2]*k,b=a[l+3]*k,a[g++]=255+d*(-4.387332384609988*d+54.48615194189176*f+18.82290502165302*e+212.25662451639585*b-285.2331026137004)+f*(1.7149763477362134*f-5.6096736904047315*e-17.873870861415444*b-5.497006427196366)+e*(-2.5217340131683033*
  33. e-21.248923337353073*b+17.5119270841813)-b*(21.86122147463605*b+189.48180835922747),a[g++]=255+d*(8.841041422036149*d+60.118027045597366*f+6.871425592049007*e+31.159100130055922*b-79.2970844816548)+f*(-15.310361306967817*f+17.575251261109482*e+131.35250912493976*b-190.9453302588951)+e*(4.444339102852739*e+9.8632861493405*b-24.86741582555878)-b*(20.737325471181034*b+187.80453709719578),a[g++]=255+d*(.8842522430003296*d+8.078677503112928*f+30.89978309703729*e-.23883238689178934*b-14.183576799673286)+
  34. f*(10.49593273432072*f+63.02378494754052*e+50.606957656360734*b-112.23884253719248)+e*(.03296041114873217*e+115.60384449646641*b-193.58209356861505)-b*(22.33816807309886*b+180.12613974708367);return a.subarray(0,g)},getData:function(a,d,f){if(4<this.i)throw new D("Unsupported color mode");a=this.L(a,d);if(1===this.i&&f){f=a.length;d=new Uint8ClampedArray(3*f);for(var e=0,b=0;b<f;b++){var g=a[b];d[e++]=g;d[e++]=g;d[e++]=g}return d}if(3===this.i&&this.w())return this.I(a);if(4===this.i){if(this.w())return f?
  35. this.K(a):this.J(a);if(f)return this.H(a)}return a}}; UTIF.JpegDecoder=g})()})();
  36. //UTIF.JpegDecoder = PDFJS.JpegImage;
  37. UTIF.encodeImage = function(rgba, w, h, metadata)
  38. {
  39. var idf = { "t256":[w], "t257":[h], "t258":[8,8,8,8], "t259":[1], "t262":[2], "t273":[1000], // strips offset
  40. "t277":[4], "t278":[h], /* rows per strip */ "t279":[w*h*4], // strip byte counts
  41. "t282":[1], "t283":[1], "t284":[1], "t286":[0], "t287":[0], "t296":[1], "t305": ["Photopea (UTIF.js)"], "t338":[1]
  42. };
  43. if (metadata) for (var i in metadata) idf[i] = metadata[i];
  44. var prfx = new Uint8Array(UTIF.encode([idf]));
  45. var img = new Uint8Array(rgba);
  46. var data = new Uint8Array(1000+w*h*4);
  47. for(var i=0; i<prfx.length; i++) data[i] = prfx[i];
  48. for(var i=0; i<img .length; i++) data[1000+i] = img[i];
  49. return data.buffer;
  50. }
  51. UTIF.encode = function(ifds)
  52. {
  53. var data = new Uint8Array(20000), offset = 4, bin = UTIF._binBE;
  54. data[0]=77; data[1]=77; data[3]=42;
  55. var ifdo = 8;
  56. bin.writeUint(data, offset, ifdo); offset+=4;
  57. for(var i=0; i<ifds.length; i++)
  58. {
  59. var noffs = UTIF._writeIFD(bin, data, ifdo, ifds[i]);
  60. ifdo = noffs[1];
  61. if(i<ifds.length-1) bin.writeUint(data, noffs[0], ifdo);
  62. }
  63. return data.slice(0, ifdo).buffer;
  64. }
  65. //UTIF.encode._writeIFD
  66. UTIF.decode = function(buff)
  67. {
  68. UTIF.decode._decodeG3.allow2D = null;
  69. var data = new Uint8Array(buff), offset = 0;
  70. var id = UTIF._binBE.readASCII(data, offset, 2); offset+=2;
  71. var bin = id=="II" ? UTIF._binLE : UTIF._binBE;
  72. var num = bin.readUshort(data, offset); offset+=2;
  73. var ifdo = bin.readUint(data, offset); offset+=4;
  74. var ifds = [];
  75. while(true) {
  76. var noff = UTIF._readIFD(bin, data, ifdo, ifds, 0, false);
  77. ifdo = bin.readUint(data, noff);
  78. if(ifdo==0) break;
  79. }
  80. return ifds;
  81. }
  82. UTIF.decodeImage = function(buff, img, ifds)
  83. {
  84. var data = new Uint8Array(buff);
  85. var id = UTIF._binBE.readASCII(data, 0, 2);
  86. if(img["t256"]==null) return; // No width => probably not an image
  87. img.isLE = id=="II";
  88. img.width = img["t256"][0]; //delete img["t256"];
  89. img.height = img["t257"][0]; //delete img["t257"];
  90. var cmpr = img["t259"] ? img["t259"][0] : 1; //delete img["t259"];
  91. var fo = img["t266"] ? img["t266"][0] : 1; //delete img["t266"];
  92. if(img["t284"] && img["t284"][0]==2) log("PlanarConfiguration 2 should not be used!");
  93. var bipp; // bits per pixel
  94. if(img["t258"]) bipp = Math.min(32,img["t258"][0])*img["t258"].length;
  95. else bipp = (img["t277"]?img["t277"][0]:1);
  96. // Some .NEF files have t258==14, even though they use 16 bits per pixel
  97. if(cmpr==1 && img["t279"]!=null && img["t278"] && img["t262"][0]==32803) {
  98. bipp = Math.round((img["t279"][0]*8)/(img.width*img["t278"][0]));
  99. }
  100. var bipl = Math.ceil(img.width*bipp/8)*8;
  101. var soff = img["t273"]; if(soff==null) soff = img["t324"];
  102. var bcnt = img["t279"]; if(cmpr==1 && soff.length==1) bcnt = [img.height*(bipl>>>3)]; if(bcnt==null) bcnt = img["t325"];
  103. var bytes = new Uint8Array(img.height*(bipl>>>3)), bilen = 0;
  104. if(img["t322"]!=null) // tiled
  105. {
  106. var tw = img["t322"][0], th = img["t323"][0];
  107. var tx = Math.floor((img.width + tw - 1) / tw);
  108. var ty = Math.floor((img.height + th - 1) / th);
  109. var tbuff = new Uint8Array(Math.ceil(tw*th*bipp/8)|0);
  110. for(var y=0; y<ty; y++)
  111. for(var x=0; x<tx; x++)
  112. {
  113. var i = y*tx+x; for(var j=0; j<tbuff.length; j++) tbuff[j]=0;
  114. UTIF.decode._decompress(img,ifds, data, soff[i], bcnt[i], cmpr, tbuff, 0, fo);
  115. // Might be required for 7 too. Need to check
  116. if (cmpr==6) bytes = tbuff;
  117. else UTIF._copyTile(tbuff, Math.ceil(tw*bipp/8)|0, th, bytes, Math.ceil(img.width*bipp/8)|0, img.height, Math.ceil(x*tw*bipp/8)|0, y*th);
  118. }
  119. bilen = bytes.length*8;
  120. }
  121. else // stripped
  122. {
  123. var rps = img["t278"] ? img["t278"][0] : img.height; rps = Math.min(rps, img.height);
  124. for(var i=0; i<soff.length; i++)
  125. {
  126. UTIF.decode._decompress(img,ifds, data, soff[i], bcnt[i], cmpr, bytes, Math.ceil(bilen/8)|0, fo);
  127. bilen += bipl * rps;
  128. }
  129. bilen = Math.min(bilen, bytes.length*8);
  130. }
  131. img.data = new Uint8Array(bytes.buffer, 0, Math.ceil(bilen/8)|0);
  132. }
  133. UTIF.decode._decompress = function(img,ifds, data, off, len, cmpr, tgt, toff, fo) // fill order
  134. {
  135. //console.log("compression", cmpr);
  136. //var time = Date.now();
  137. if(false) {}
  138. else if(cmpr==1 || (len==tgt.length && cmpr!=32767)) for(var j=0; j<len; j++) tgt[toff+j] = data[off+j];
  139. else if(cmpr==3) UTIF.decode._decodeG3 (data, off, len, tgt, toff, img.width, fo);
  140. else if(cmpr==4) UTIF.decode._decodeG4 (data, off, len, tgt, toff, img.width, fo);
  141. else if(cmpr==5) UTIF.decode._decodeLZW(data, off, tgt, toff);
  142. else if(cmpr==6) UTIF.decode._decodeOldJPEG(img, data, off, len, tgt, toff);
  143. else if(cmpr==7) UTIF.decode._decodeNewJPEG(img, data, off, len, tgt, toff);
  144. else if(cmpr==8) { var src = new Uint8Array(data.buffer,off,len); var bin = pako["inflate"](src); for(var i=0; i<bin.length; i++) tgt[toff+i]=bin[i]; }
  145. else if(cmpr==32767) UTIF.decode._decodeARW(img, data, off, len, tgt, toff);
  146. else if(cmpr==32773) UTIF.decode._decodePackBits(data, off, len, tgt, toff);
  147. else if(cmpr==32809) UTIF.decode._decodeThunder (data, off, len, tgt, toff);
  148. else if(cmpr==34713) //for(var j=0; j<len; j++) tgt[toff+j] = data[off+j];
  149. UTIF.decode._decodeNikon (img,ifds, data, off, len, tgt, toff);
  150. else log("Unknown compression", cmpr);
  151. //console.log(Date.now()-time);
  152. var bps = (img["t258"]?Math.min(32,img["t258"][0]):1);
  153. var noc = (img["t277"]?img["t277"][0]:1), bpp=(bps*noc)>>>3, h = (img["t278"] ? img["t278"][0] : img.height), bpl = Math.ceil(bps*noc*img.width/8);
  154. // convert to Little Endian /*
  155. if(bps==16 && !img.isLE && img["t33422"]==null) // not DNG
  156. for(var y=0; y<h; y++) {
  157. //console.log("fixing endianity");
  158. var roff = toff+y*bpl;
  159. for(var x=1; x<bpl; x+=2) { var t=tgt[roff+x]; tgt[roff+x]=tgt[roff+x-1]; tgt[roff+x-1]=t; }
  160. } //*/
  161. if(img["t317"] && img["t317"][0]==2)
  162. {
  163. for(var y=0; y<h; y++)
  164. {
  165. var ntoff = toff+y*bpl;
  166. if(bps==16) for(var j=bpp; j<bpl; j+=2) {
  167. var nv = ((tgt[ntoff+j+1]<<8)|tgt[ntoff+j]) + ((tgt[ntoff+j-bpp+1]<<8)|tgt[ntoff+j-bpp]);
  168. tgt[ntoff+j] = nv&255; tgt[ntoff+j+1] = (nv>>>8)&255;
  169. }
  170. else if(noc==3) for(var j= 3; j<bpl; j+=3)
  171. {
  172. tgt[ntoff+j ] = (tgt[ntoff+j ] + tgt[ntoff+j-3])&255;
  173. tgt[ntoff+j+1] = (tgt[ntoff+j+1] + tgt[ntoff+j-2])&255;
  174. tgt[ntoff+j+2] = (tgt[ntoff+j+2] + tgt[ntoff+j-1])&255;
  175. }
  176. else for(var j=bpp; j<bpl; j++) tgt[ntoff+j] = (tgt[ntoff+j] + tgt[ntoff+j-bpp])&255;
  177. }
  178. }
  179. }
  180. UTIF.decode._ljpeg_diff = function(data, prm, huff) {
  181. var getbithuff = UTIF.decode._getbithuff;
  182. var len, diff;
  183. len = getbithuff(data, prm, huff[0], huff);
  184. diff = getbithuff(data, prm, len, 0);
  185. if ((diff & (1 << (len-1))) == 0) diff -= (1 << len) - 1;
  186. return diff;
  187. }
  188. UTIF.decode._decodeARW = function(img, inp, off, src_length, tgt, toff) {
  189. var raw_width = img["t256"][0], height=img["t257"][0], tiff_bps=img["t258"][0];
  190. var bin=(img.isLE ? UTIF._binLE : UTIF._binBE);
  191. //console.log(raw_width, height, tiff_bps, raw_width*height, src_length);
  192. var arw2 = (raw_width*height == src_length) || (raw_width*height*1.5 == src_length);
  193. //arw2 = true;
  194. //console.log("ARW2: ", arw2, raw_width*height, src_length, tgt.length);
  195. if(!arw2) { //"sony_arw_load_raw"; // not arw2
  196. height+=8;
  197. var prm = [off,0,0,0];
  198. var huff = new Uint16Array(32770);
  199. var tab = [ 0xf11,0xf10,0xe0f,0xd0e,0xc0d,0xb0c,0xa0b,0x90a,0x809,
  200. 0x708,0x607,0x506,0x405,0x304,0x303,0x300,0x202,0x201 ];
  201. var i, c, n, col, row, sum=0;
  202. var ljpeg_diff = UTIF.decode._ljpeg_diff;
  203. huff[0] = 15;
  204. for (n=i=0; i < 18; i++) {
  205. var lim = 32768 >>> (tab[i] >>> 8);
  206. for(var c=0; c<lim; c++) huff[++n] = tab[i];
  207. }
  208. for (col = raw_width; col--; )
  209. for (row=0; row < height+1; row+=2) {
  210. if (row == height) row = 1;
  211. sum += ljpeg_diff(inp, prm, huff);
  212. if (row < height) {
  213. var clr = (sum)&4095;
  214. UTIF.decode._putsF(tgt, (row*raw_width+col)*tiff_bps, clr<<(16-tiff_bps));
  215. }
  216. }
  217. return;
  218. }
  219. if(raw_width*height*1.5==src_length) {
  220. //console.log("weird compression");
  221. for(var i=0; i<src_length; i+=3) { var b0=inp[off+i+0], b1=inp[off+i+1], b2=inp[off+i+2];
  222. tgt[toff+i]=(b1<<4)|(b0>>>4); tgt[toff+i+1]=(b0<<4)|(b2>>>4); tgt[toff+i+2]=(b2<<4)|(b1>>>4); }
  223. return;
  224. }
  225. var pix = new Uint16Array(16);
  226. var row, col, val, max, min, imax, imin, sh, bit, i, dp;
  227. var data = new Uint8Array(raw_width+1);
  228. for (row=0; row < height; row++) {
  229. //fread (data, 1, raw_width, ifp);
  230. for(var j=0; j<raw_width; j++) data[j]=inp[off++];
  231. for (dp=0, col=0; col < raw_width-30; dp+=16) {
  232. max = 0x7ff & (val = bin.readUint(data,dp));
  233. min = 0x7ff & (val >>> 11);
  234. imax = 0x0f & (val >>> 22);
  235. imin = 0x0f & (val >>> 26);
  236. for (sh=0; sh < 4 && 0x80 << sh <= max-min; sh++);
  237. for (bit=30, i=0; i < 16; i++)
  238. if (i == imax) pix[i] = max;
  239. else if (i == imin) pix[i] = min;
  240. else {
  241. pix[i] = ((bin.readUshort(data, dp+(bit >> 3)) >>> (bit & 7) & 0x7f) << sh) + min;
  242. if (pix[i] > 0x7ff) pix[i] = 0x7ff;
  243. bit += 7;
  244. }
  245. for (i=0; i < 16; i++, col+=2) {
  246. //RAW(row,col) = curve[pix[i] << 1] >> 2;
  247. var clr = pix[i]<<1; //clr = 0xffff;
  248. UTIF.decode._putsF(tgt, (row*raw_width+col)*tiff_bps, clr<<(16-tiff_bps));
  249. }
  250. col -= col & 1 ? 1:31;
  251. }
  252. }
  253. }
  254. UTIF.decode._decodeNikon = function(img,imgs, data, off, src_length, tgt, toff)
  255. {
  256. var nikon_tree = [
  257. [ 0, 0,1,5,1,1,1,1,1,1,2,0,0,0,0,0,0, /* 12-bit lossy */
  258. 5,4,3,6,2,7,1,0,8,9,11,10,12 ],
  259. [ 0, 0,1,5,1,1,1,1,1,1,2,0,0,0,0,0,0, /* 12-bit lossy after split */
  260. 0x39,0x5a,0x38,0x27,0x16,5,4,3,2,1,0,11,12,12 ],
  261. [ 0, 0,1,4,2,3,1,2,0,0,0,0,0,0,0,0,0, /* 12-bit lossless */
  262. 5,4,6,3,7,2,8,1,9,0,10,11,12 ],
  263. [ 0, 0,1,4,3,1,1,1,1,1,2,0,0,0,0,0,0, /* 14-bit lossy */
  264. 5,6,4,7,8,3,9,2,1,0,10,11,12,13,14 ],
  265. [ 0, 0,1,5,1,1,1,1,1,1,1,2,0,0,0,0,0, /* 14-bit lossy after split */
  266. 8,0x5c,0x4b,0x3a,0x29,7,6,5,4,3,2,1,0,13,14 ],
  267. [ 0, 0,1,4,2,2,3,1,2,0,0,0,0,0,0,0,0, /* 14-bit lossless */
  268. 7,6,8,5,9,4,10,3,11,12,2,0,1,13,14 ] ];
  269. var raw_width = img["t256"][0], height=img["t257"][0], tiff_bps=img["t258"][0];
  270. var tree = 0, split = 0;
  271. var make_decoder = UTIF.decode._make_decoder;
  272. var getbithuff = UTIF.decode._getbithuff;
  273. var mn = imgs[0].exifIFD.makerNote, md = mn["t150"]?mn["t150"]:mn["t140"], mdo=0; //console.log(mn,md);
  274. //console.log(md[0].toString(16), md[1].toString(16), tiff_bps);
  275. var ver0 = md[mdo++], ver1 = md[mdo++];
  276. if (ver0 == 0x49 || ver1 == 0x58) mdo+=2110;
  277. if (ver0 == 0x46) tree = 2;
  278. if (tiff_bps == 14) tree += 3;
  279. var vpred = [[0,0],[0,0]], bin=(img.isLE ? UTIF._binLE : UTIF._binBE);
  280. for(var i=0; i<2; i++) for(var j=0; j<2; j++) { vpred[i][j] = bin.readShort(md,mdo); mdo+=2; } // not sure here ... [i][j] or [j][i]
  281. //console.log(vpred);
  282. var max = 1 << tiff_bps & 0x7fff, step=0;
  283. var csize = bin.readShort(md,mdo); mdo+=2;
  284. if (csize > 1) step = Math.floor(max / (csize-1));
  285. if (ver0 == 0x44 && ver1 == 0x20 && step > 0) split = bin.readShort(md,562);
  286. var i;
  287. var row, col;
  288. var len, shl, diff;
  289. var min_v = 0;
  290. var hpred = [0,0];
  291. var huff = make_decoder(nikon_tree[tree]);
  292. //var g_input_offset=0, bitbuf=0, vbits=0, reset=0;
  293. var prm = [off,0,0,0];
  294. //console.log(split); split = 170;
  295. for (min_v=row=0; row < height; row++) {
  296. if (split && row == split) {
  297. //free (huff);
  298. huff = make_decoder (nikon_tree[tree+1]);
  299. //max_v += (min_v = 16) << 1;
  300. }
  301. for (col=0; col < raw_width; col++) {
  302. i = getbithuff(data,prm,huff[0],huff);
  303. len = i & 15;
  304. shl = i >>> 4;
  305. diff = (((getbithuff(data,prm,len-shl,0) << 1) + 1) << shl) >>> 1;
  306. if ((diff & (1 << (len-1))) == 0)
  307. diff -= (1 << len) - (shl==0?1:0);
  308. if (col < 2) hpred[col] = vpred[row & 1][col] += diff;
  309. else hpred[col & 1] += diff;
  310. var clr = Math.min(Math.max(hpred[col & 1],0),(1<<tiff_bps)-1);
  311. var bti = (row*raw_width+col)*tiff_bps;
  312. UTIF.decode._putsF(tgt, bti, clr<<(16-tiff_bps));
  313. }
  314. }
  315. }
  316. // put 16 bits
  317. UTIF.decode._putsF= function(dt, pos, val) { val = val<<(8-(pos&7)); var o=(pos>>>3); dt[o]|=val>>>16; dt[o+1]|=val>>>8; dt[o+2]|=val; }
  318. UTIF.decode._getbithuff = function(data,prm,nbits, huff) {
  319. var zero_after_ff = 0;
  320. var get_byte = UTIF.decode._get_byte;
  321. var c;
  322. var off=prm[0], bitbuf=prm[1], vbits=prm[2], reset=prm[3];
  323. //if (nbits > 25) return 0;
  324. //if (nbits < 0) return bitbuf = vbits = reset = 0;
  325. if (nbits == 0 || vbits < 0) return 0;
  326. while (!reset && vbits < nbits && (c = data[off++]) != -1 &&
  327. !(reset = zero_after_ff && c == 0xff && data[off++])) {
  328. //console.log("byte read into c");
  329. bitbuf = (bitbuf << 8) + c;
  330. vbits += 8;
  331. }
  332. c = (bitbuf << (32-vbits)) >>> (32-nbits);
  333. if (huff) {
  334. vbits -= huff[c+1] >>> 8; //console.log(c, huff[c]>>8);
  335. c = huff[c+1]&255;
  336. } else
  337. vbits -= nbits;
  338. if (vbits < 0) throw "e";
  339. prm[0]=off; prm[1]=bitbuf; prm[2]=vbits; prm[3]=reset;
  340. return c;
  341. }
  342. UTIF.decode._make_decoder = function(source) {
  343. var max, len, h, i, j;
  344. var huff = [];
  345. for (max=16; max!=0 && !source[max]; max--);
  346. var si=17;
  347. huff[0] = max;
  348. for (h=len=1; len <= max; len++)
  349. for (i=0; i < source[len]; i++, ++si)
  350. for (j=0; j < 1 << (max-len); j++)
  351. if (h <= 1 << max)
  352. huff[h++] = (len << 8) | source[si];
  353. return huff;
  354. }
  355. UTIF.decode._decodeNewJPEG = function(img, data, off, len, tgt, toff)
  356. {
  357. var tables = img["t347"], tlen = tables ? tables.length : 0, buff = new Uint8Array(tlen + len);
  358. if (tables) {
  359. var SOI = 216, EOI = 217, boff = 0;
  360. for (var i=0; i<(tlen-1); i++)
  361. {
  362. // Skip EOI marker from JPEGTables
  363. if (tables[i]==255 && tables[i+1]==EOI) break;
  364. buff[boff++] = tables[i];
  365. }
  366. // Skip SOI marker from data
  367. var byte1 = data[off], byte2 = data[off + 1];
  368. if (byte1!=255 || byte2!=SOI)
  369. {
  370. buff[boff++] = byte1;
  371. buff[boff++] = byte2;
  372. }
  373. for (var i=2; i<len; i++) buff[boff++] = data[off+i];
  374. }
  375. else for (var i=0; i<len; i++) buff[i] = data[off+i];
  376. if(img["t262"][0]==32803 || img["t262"][0]==34892) // lossless JPEG and lossy JPEG (used in DNG files)
  377. {
  378. var bps = img["t258"][0];//, dcdr = new LosslessJpegDecoder();
  379. var out = UTIF.LosslessJpegDecode(buff), olen=out.length; //console.log(olen);
  380. if(false) {}
  381. else if(bps==16) {
  382. if(img.isLE) for(var i=0; i<olen; i++ ) { tgt[toff+(i<<1)] = (out[i]&255); tgt[toff+(i<<1)+1] = (out[i]>>>8); }
  383. else for(var i=0; i<olen; i++ ) { tgt[toff+(i<<1)] = (out[i]>>>8); tgt[toff+(i<<1)+1] = (out[i]&255); }
  384. }
  385. else if(bps==14 || bps==12) { // 4 * 14 == 56 == 7 * 8
  386. var rst = 16-bps;
  387. for(var i=0; i<olen; i++) UTIF.decode._putsF(tgt, i*bps, out[i]<<rst);
  388. }
  389. else throw new Error("unsupported bit depth "+bps);
  390. }
  391. else
  392. {
  393. var parser = new UTIF.JpegDecoder(); parser.parse(buff);
  394. var decoded = parser.getData(parser.width, parser.height);
  395. for (var i=0; i<decoded.length; i++) tgt[toff + i] = decoded[i];
  396. }
  397. // PhotometricInterpretation is 6 (YCbCr) for JPEG, but after decoding we populate data in
  398. // RGB format, so updating the tag value
  399. if(img["t262"][0] == 6) img["t262"][0] = 2;
  400. }
  401. UTIF.decode._decodeOldJPEGInit = function(img, data, off, len)
  402. {
  403. var SOI = 216, EOI = 217, DQT = 219, DHT = 196, DRI = 221, SOF0 = 192, SOS = 218;
  404. var joff = 0, soff = 0, tables, sosMarker, isTiled = false, i, j, k;
  405. var jpgIchgFmt = img["t513"], jifoff = jpgIchgFmt ? jpgIchgFmt[0] : 0;
  406. var jpgIchgFmtLen = img["t514"], jiflen = jpgIchgFmtLen ? jpgIchgFmtLen[0] : 0;
  407. var soffTag = img["t324"] || img["t273"] || jpgIchgFmt;
  408. var ycbcrss = img["t530"], ssx = 0, ssy = 0;
  409. var spp = img["t277"]?img["t277"][0]:1;
  410. var jpgresint = img["t515"];
  411. if(soffTag)
  412. {
  413. soff = soffTag[0];
  414. isTiled = (soffTag.length > 1);
  415. }
  416. if(!isTiled)
  417. {
  418. if(data[off]==255 && data[off+1]==SOI) return { jpegOffset: off };
  419. if(jpgIchgFmt!=null)
  420. {
  421. if(data[off+jifoff]==255 && data[off+jifoff+1]==SOI) joff = off+jifoff;
  422. else log("JPEGInterchangeFormat does not point to SOI");
  423. if(jpgIchgFmtLen==null) log("JPEGInterchangeFormatLength field is missing");
  424. else if(jifoff >= soff || (jifoff+jiflen) <= soff) log("JPEGInterchangeFormatLength field value is invalid");
  425. if(joff != null) return { jpegOffset: joff };
  426. }
  427. }
  428. if(ycbcrss!=null) { ssx = ycbcrss[0]; ssy = ycbcrss[1]; }
  429. if(jpgIchgFmt!=null)
  430. if(jpgIchgFmtLen!=null)
  431. if(jiflen >= 2 && (jifoff+jiflen) <= soff)
  432. {
  433. if(data[off+jifoff+jiflen-2]==255 && data[off+jifoff+jiflen-1]==SOI) tables = new Uint8Array(jiflen-2);
  434. else tables = new Uint8Array(jiflen);
  435. for(i=0; i<tables.length; i++) tables[i] = data[off+jifoff+i];
  436. log("Incorrect JPEG interchange format: using JPEGInterchangeFormat offset to derive tables");
  437. }
  438. else log("JPEGInterchangeFormat+JPEGInterchangeFormatLength > offset to first strip or tile");
  439. if(tables == null)
  440. {
  441. var ooff = 0, out = [];
  442. out[ooff++] = 255; out[ooff++] = SOI;
  443. var qtables = img["t519"];
  444. if(qtables==null) throw new Error("JPEGQTables tag is missing");
  445. for(i=0; i<qtables.length; i++)
  446. {
  447. out[ooff++] = 255; out[ooff++] = DQT; out[ooff++] = 0; out[ooff++] = 67; out[ooff++] = i;
  448. for(j=0; j<64; j++) out[ooff++] = data[off+qtables[i]+j];
  449. }
  450. for(k=0; k<2; k++)
  451. {
  452. var htables = img[(k == 0) ? "t520" : "t521"];
  453. if(htables==null) throw new Error(((k == 0) ? "JPEGDCTables" : "JPEGACTables") + " tag is missing");
  454. for(i=0; i<htables.length; i++)
  455. {
  456. out[ooff++] = 255; out[ooff++] = DHT;
  457. //out[ooff++] = 0; out[ooff++] = 67; out[ooff++] = i;
  458. var nc = 19;
  459. for(j=0; j<16; j++) nc += data[off+htables[i]+j];
  460. out[ooff++] = (nc >>> 8); out[ooff++] = nc & 255;
  461. out[ooff++] = (i | (k << 4));
  462. for(j=0; j<16; j++) out[ooff++] = data[off+htables[i]+j];
  463. for(j=0; j<nc; j++) out[ooff++] = data[off+htables[i]+16+j];
  464. }
  465. }
  466. out[ooff++] = 255; out[ooff++] = SOF0;
  467. out[ooff++] = 0; out[ooff++] = 8 + 3*spp; out[ooff++] = 8;
  468. out[ooff++] = (img.height >>> 8) & 255; out[ooff++] = img.height & 255;
  469. out[ooff++] = (img.width >>> 8) & 255; out[ooff++] = img.width & 255;
  470. out[ooff++] = spp;
  471. if(spp==1) { out[ooff++] = 1; out[ooff++] = 17; out[ooff++] = 0; }
  472. else for(i=0; i<3; i++)
  473. {
  474. out[ooff++] = i + 1;
  475. out[ooff++] = (i != 0) ? 17 : (((ssx & 15) << 4) | (ssy & 15));
  476. out[ooff++] = i;
  477. }
  478. if(jpgresint!=null && jpgresint[0]!=0)
  479. {
  480. out[ooff++] = 255; out[ooff++] = DRI; out[ooff++] = 0; out[ooff++] = 4;
  481. out[ooff++] = (jpgresint[0] >>> 8) & 255;
  482. out[ooff++] = jpgresint[0] & 255;
  483. }
  484. tables = new Uint8Array(out);
  485. }
  486. var sofpos = -1;
  487. i = 0;
  488. while(i < (tables.length - 1)) {
  489. if(tables[i]==255 && tables[i+1]==SOF0) { sofpos = i; break; }
  490. i++;
  491. }
  492. if(sofpos == -1)
  493. {
  494. var tmptab = new Uint8Array(tables.length + 10 + 3*spp);
  495. tmptab.set(tables);
  496. var tmpoff = tables.length;
  497. sofpos = tables.length;
  498. tables = tmptab;
  499. tables[tmpoff++] = 255; tables[tmpoff++] = SOF0;
  500. tables[tmpoff++] = 0; tables[tmpoff++] = 8 + 3*spp; tables[tmpoff++] = 8;
  501. tables[tmpoff++] = (img.height >>> 8) & 255; tables[tmpoff++] = img.height & 255;
  502. tables[tmpoff++] = (img.width >>> 8) & 255; tables[tmpoff++] = img.width & 255;
  503. tables[tmpoff++] = spp;
  504. if(spp==1) { tables[tmpoff++] = 1; tables[tmpoff++] = 17; tables[tmpoff++] = 0; }
  505. else for(i=0; i<3; i++)
  506. {
  507. tables[tmpoff++] = i + 1;
  508. tables[tmpoff++] = (i != 0) ? 17 : (((ssx & 15) << 4) | (ssy & 15));
  509. tables[tmpoff++] = i;
  510. }
  511. }
  512. if(data[soff]==255 && data[soff+1]==SOS)
  513. {
  514. var soslen = (data[soff+2]<<8) | data[soff+3];
  515. sosMarker = new Uint8Array(soslen+2);
  516. sosMarker[0] = data[soff]; sosMarker[1] = data[soff+1]; sosMarker[2] = data[soff+2]; sosMarker[3] = data[soff+3];
  517. for(i=0; i<(soslen-2); i++) sosMarker[i+4] = data[soff+i+4];
  518. }
  519. else
  520. {
  521. sosMarker = new Uint8Array(2 + 6 + 2*spp);
  522. var sosoff = 0;
  523. sosMarker[sosoff++] = 255; sosMarker[sosoff++] = SOS;
  524. sosMarker[sosoff++] = 0; sosMarker[sosoff++] = 6 + 2*spp; sosMarker[sosoff++] = spp;
  525. if(spp==1) { sosMarker[sosoff++] = 1; sosMarker[sosoff++] = 0; }
  526. else for(i=0; i<3; i++)
  527. {
  528. sosMarker[sosoff++] = i+1; sosMarker[sosoff++] = (i << 4) | i;
  529. }
  530. sosMarker[sosoff++] = 0; sosMarker[sosoff++] = 63; sosMarker[sosoff++] = 0;
  531. }
  532. return { jpegOffset: off, tables: tables, sosMarker: sosMarker, sofPosition: sofpos };
  533. }
  534. UTIF.decode._decodeOldJPEG = function(img, data, off, len, tgt, toff)
  535. {
  536. var i, dlen, tlen, buff, buffoff;
  537. var jpegData = UTIF.decode._decodeOldJPEGInit(img, data, off, len);
  538. if(jpegData.jpegOffset!=null)
  539. {
  540. dlen = off+len-jpegData.jpegOffset;
  541. buff = new Uint8Array(dlen);
  542. for(i=0; i<dlen; i++) buff[i] = data[jpegData.jpegOffset+i];
  543. }
  544. else
  545. {
  546. tlen = jpegData.tables.length;
  547. buff = new Uint8Array(tlen + jpegData.sosMarker.length + len + 2);
  548. buff.set(jpegData.tables);
  549. buffoff = tlen;
  550. buff[jpegData.sofPosition+5] = (img.height >>> 8) & 255; buff[jpegData.sofPosition+6] = img.height & 255;
  551. buff[jpegData.sofPosition+7] = (img.width >>> 8) & 255; buff[jpegData.sofPosition+8] = img.width & 255;
  552. if(data[off]!=255 || data[off+1]!=SOS)
  553. {
  554. buff.set(jpegData.sosMarker, buffoff);
  555. buffoff += sosMarker.length;
  556. }
  557. for(i=0; i<len; i++) buff[buffoff++] = data[off+i];
  558. buff[buffoff++] = 255; buff[buffoff++] = EOI;
  559. }
  560. var parser = new UTIF.JpegDecoder(); parser.parse(buff);
  561. var decoded = parser.getData(parser.width, parser.height);
  562. for (var i=0; i<decoded.length; i++) tgt[toff + i] = decoded[i];
  563. // PhotometricInterpretation is 6 (YCbCr) for JPEG, but after decoding we populate data in
  564. // RGB format, so updating the tag value
  565. if(img["t262"] && img["t262"][0] == 6) img["t262"][0] = 2;
  566. }
  567. UTIF.decode._decodePackBits = function(data, off, len, tgt, toff)
  568. {
  569. var sa = new Int8Array(data.buffer), ta = new Int8Array(tgt.buffer), lim = off+len;
  570. while(off<lim)
  571. {
  572. var n = sa[off]; off++;
  573. if(n>=0 && n<128) for(var i=0; i< n+1; i++) { ta[toff]=sa[off]; toff++; off++; }
  574. if(n>=-127 && n<0) { for(var i=0; i<-n+1; i++) { ta[toff]=sa[off]; toff++; } off++; }
  575. }
  576. }
  577. UTIF.decode._decodeThunder = function(data, off, len, tgt, toff)
  578. {
  579. var d2 = [ 0, 1, 0, -1 ], d3 = [ 0, 1, 2, 3, 0, -3, -2, -1 ];
  580. var lim = off+len, qoff = toff*2, px = 0;
  581. while(off<lim)
  582. {
  583. var b = data[off], msk = (b>>>6), n = (b&63); off++;
  584. if(msk==3) { px=(n&15); tgt[qoff>>>1] |= (px<<(4*(1-qoff&1))); qoff++; }
  585. if(msk==0) for(var i=0; i<n; i++) { tgt[qoff>>>1] |= (px<<(4*(1-qoff&1))); qoff++; }
  586. if(msk==2) for(var i=0; i<2; i++) { var d=(n>>>(3*(1-i)))&7; if(d!=4) { px+=d3[d]; tgt[qoff>>>1] |= (px<<(4*(1-qoff&1))); qoff++; } }
  587. if(msk==1) for(var i=0; i<3; i++) { var d=(n>>>(2*(2-i)))&3; if(d!=2) { px+=d2[d]; tgt[qoff>>>1] |= (px<<(4*(1-qoff&1))); qoff++; } }
  588. }
  589. }
  590. UTIF.decode._dmap = { "1":0,"011":1,"000011":2,"0000011":3, "010":-1,"000010":-2,"0000010":-3 };
  591. UTIF.decode._lens = ( function()
  592. {
  593. var addKeys = function(lens, arr, i0, inc) { for(var i=0; i<arr.length; i++) lens[arr[i]] = i0 + i*inc; }
  594. var termW = "00110101,000111,0111,1000,1011,1100,1110,1111,10011,10100,00111,01000,001000,000011,110100,110101," // 15
  595. + "101010,101011,0100111,0001100,0001000,0010111,0000011,0000100,0101000,0101011,0010011,0100100,0011000,00000010,00000011,00011010," // 31
  596. + "00011011,00010010,00010011,00010100,00010101,00010110,00010111,00101000,00101001,00101010,00101011,00101100,00101101,00000100,00000101,00001010," // 47
  597. + "00001011,01010010,01010011,01010100,01010101,00100100,00100101,01011000,01011001,01011010,01011011,01001010,01001011,00110010,00110011,00110100";
  598. var termB = "0000110111,010,11,10,011,0011,0010,00011,000101,000100,0000100,0000101,0000111,00000100,00000111,000011000," // 15
  599. + "0000010111,0000011000,0000001000,00001100111,00001101000,00001101100,00000110111,00000101000,00000010111,00000011000,000011001010,000011001011,000011001100,000011001101,000001101000,000001101001," // 31
  600. + "000001101010,000001101011,000011010010,000011010011,000011010100,000011010101,000011010110,000011010111,000001101100,000001101101,000011011010,000011011011,000001010100,000001010101,000001010110,000001010111," // 47
  601. + "000001100100,000001100101,000001010010,000001010011,000000100100,000000110111,000000111000,000000100111,000000101000,000001011000,000001011001,000000101011,000000101100,000001011010,000001100110,000001100111";
  602. var makeW = "11011,10010,010111,0110111,00110110,00110111,01100100,01100101,01101000,01100111,011001100,011001101,011010010,011010011,011010100,011010101,011010110,"
  603. + "011010111,011011000,011011001,011011010,011011011,010011000,010011001,010011010,011000,010011011";
  604. var makeB = "0000001111,000011001000,000011001001,000001011011,000000110011,000000110100,000000110101,0000001101100,0000001101101,0000001001010,0000001001011,0000001001100,"
  605. + "0000001001101,0000001110010,0000001110011,0000001110100,0000001110101,0000001110110,0000001110111,0000001010010,0000001010011,0000001010100,0000001010101,0000001011010,"
  606. + "0000001011011,0000001100100,0000001100101";
  607. var makeA = "00000001000,00000001100,00000001101,000000010010,000000010011,000000010100,000000010101,000000010110,000000010111,000000011100,000000011101,000000011110,000000011111";
  608. termW = termW.split(","); termB = termB.split(","); makeW = makeW.split(","); makeB = makeB.split(","); makeA = makeA.split(",");
  609. var lensW = {}, lensB = {};
  610. addKeys(lensW, termW, 0, 1); addKeys(lensW, makeW, 64,64); addKeys(lensW, makeA, 1792,64);
  611. addKeys(lensB, termB, 0, 1); addKeys(lensB, makeB, 64,64); addKeys(lensB, makeA, 1792,64);
  612. return [lensW, lensB];
  613. } )();
  614. UTIF.decode._decodeG4 = function(data, off, slen, tgt, toff, w, fo)
  615. {
  616. var U = UTIF.decode, boff=off<<3, len=0, wrd=""; // previous starts with 1
  617. var line=[], pline=[]; for(var i=0; i<w; i++) pline.push(0); pline=U._makeDiff(pline);
  618. var a0=0, a1=0, a2=0, b1=0, b2=0, clr=0;
  619. var y=0, mode="", toRead=0;
  620. var bipl = Math.ceil(w/8)*8;
  621. while((boff>>>3)<off+slen)
  622. {
  623. b1 = U._findDiff(pline, a0+(a0==0?0:1), 1-clr), b2 = U._findDiff(pline, b1, clr); // could be precomputed
  624. var bit =0;
  625. if(fo==1) bit = (data[boff>>>3]>>>(7-(boff&7)))&1;
  626. if(fo==2) bit = (data[boff>>>3]>>>( (boff&7)))&1;
  627. boff++; wrd+=bit;
  628. if(mode=="H")
  629. {
  630. if(U._lens[clr][wrd]!=null)
  631. {
  632. var dl=U._lens[clr][wrd]; wrd=""; len+=dl;
  633. if(dl<64) { U._addNtimes(line,len,clr); a0+=len; clr=1-clr; len=0; toRead--; if(toRead==0) mode=""; }
  634. }
  635. }
  636. else
  637. {
  638. if(wrd=="0001") { wrd=""; U._addNtimes(line,b2-a0,clr); a0=b2; }
  639. if(wrd=="001" ) { wrd=""; mode="H"; toRead=2; }
  640. if(U._dmap[wrd]!=null) { a1 = b1+U._dmap[wrd]; U._addNtimes(line, a1-a0, clr); a0=a1; wrd=""; clr=1-clr; }
  641. }
  642. if(line.length==w && mode=="")
  643. {
  644. U._writeBits(line, tgt, toff*8+y*bipl);
  645. clr=0; y++; a0=0;
  646. pline=U._makeDiff(line); line=[];
  647. }
  648. //if(wrd.length>150) { log(wrd); break; throw "e"; }
  649. }
  650. }
  651. UTIF.decode._findDiff = function(line, x, clr) { for(var i=0; i<line.length; i+=2) if(line[i]>=x && line[i+1]==clr) return line[i]; }
  652. UTIF.decode._makeDiff = function(line)
  653. {
  654. var out = []; if(line[0]==1) out.push(0,1);
  655. for(var i=1; i<line.length; i++) if(line[i-1]!=line[i]) out.push(i, line[i]);
  656. out.push(line.length,0,line.length,1); return out;
  657. }
  658. UTIF.decode._decodeG3 = function(data, off, slen, tgt, toff, w, fo)
  659. {
  660. var U = UTIF.decode, boff=off<<3, len=0, wrd="";
  661. var line=[], pline=[]; for(var i=0; i<w; i++) line.push(0);
  662. var a0=0, a1=0, a2=0, b1=0, b2=0, clr=0;
  663. var y=-1, mode="", toRead=0, is1D=false;
  664. var bipl = Math.ceil(w/8)*8;
  665. while((boff>>>3)<off+slen)
  666. {
  667. b1 = U._findDiff(pline, a0+(a0==0?0:1), 1-clr), b2 = U._findDiff(pline, b1, clr); // could be precomputed
  668. var bit =0;
  669. if(fo==1) bit = (data[boff>>>3]>>>(7-(boff&7)))&1;
  670. if(fo==2) bit = (data[boff>>>3]>>>( (boff&7)))&1;
  671. boff++; wrd+=bit;
  672. if(is1D)
  673. {
  674. if(U._lens[clr][wrd]!=null)
  675. {
  676. var dl=U._lens[clr][wrd]; wrd=""; len+=dl;
  677. if(dl<64) { U._addNtimes(line,len,clr); clr=1-clr; len=0; }
  678. }
  679. }
  680. else
  681. {
  682. if(mode=="H")
  683. {
  684. if(U._lens[clr][wrd]!=null)
  685. {
  686. var dl=U._lens[clr][wrd]; wrd=""; len+=dl;
  687. if(dl<64) { U._addNtimes(line,len,clr); a0+=len; clr=1-clr; len=0; toRead--; if(toRead==0) mode=""; }
  688. }
  689. }
  690. else
  691. {
  692. if(wrd=="0001") { wrd=""; U._addNtimes(line,b2-a0,clr); a0=b2; }
  693. if(wrd=="001" ) { wrd=""; mode="H"; toRead=2; }
  694. if(U._dmap[wrd]!=null) { a1 = b1+U._dmap[wrd]; U._addNtimes(line, a1-a0, clr); a0=a1; wrd=""; clr=1-clr; }
  695. }
  696. }
  697. if(wrd.endsWith("000000000001")) // needed for some files
  698. {
  699. if(y>=0) U._writeBits(line, tgt, toff*8+y*bipl);
  700. if(fo==1) is1D = ((data[boff>>>3]>>>(7-(boff&7)))&1)==1;
  701. if(fo==2) is1D = ((data[boff>>>3]>>>( (boff&7)))&1)==1;
  702. boff++;
  703. if(U._decodeG3.allow2D==null) U._decodeG3.allow2D=is1D;
  704. if(!U._decodeG3.allow2D) { is1D = true; boff--; }
  705. //log("EOL",y, "next 1D:", is1D);
  706. wrd=""; clr=0; y++; a0=0;
  707. pline=U._makeDiff(line); line=[];
  708. }
  709. }
  710. if(line.length==w) U._writeBits(line, tgt, toff*8+y*bipl);
  711. }
  712. UTIF.decode._addNtimes = function(arr, n, val) { for(var i=0; i<n; i++) arr.push(val); }
  713. UTIF.decode._writeBits = function(bits, tgt, boff)
  714. {
  715. for(var i=0; i<bits.length; i++) tgt[(boff+i)>>>3] |= (bits[i]<<(7-((boff+i)&7)));
  716. }
  717. UTIF.decode._decodeLZW = function(data, off, tgt, toff)
  718. {
  719. if(UTIF.decode._lzwTab==null)
  720. {
  721. var tb=new Uint32Array(0xffff), tn=new Uint16Array(0xffff), chr=new Uint8Array(2e6);
  722. for(var i=0; i<256; i++) { chr[i<<2]=i; tb[i]=i<<2; tn[i]=1; }
  723. UTIF.decode._lzwTab = [tb,tn,chr];
  724. }
  725. var copy = UTIF.decode._copyData;
  726. var tab = UTIF.decode._lzwTab[0], tln=UTIF.decode._lzwTab[1], chr=UTIF.decode._lzwTab[2], totl = 258, chrl = 258<<2;
  727. var bits = 9, boff = off<<3; // offset in bits
  728. var ClearCode = 256, EoiCode = 257;
  729. var v = 0, Code = 0, OldCode = 0;
  730. while(true)
  731. {
  732. v = (data[boff>>>3]<<16) | (data[(boff+8)>>>3]<<8) | data[(boff+16)>>>3];
  733. Code = ( v>>(24-(boff&7)-bits) ) & ((1<<bits)-1); boff+=bits;
  734. if(Code==EoiCode) break;
  735. if(Code==ClearCode)
  736. {
  737. bits=9; totl = 258; chrl = 258<<2;
  738. v = (data[boff>>>3]<<16) | (data[(boff+8)>>>3]<<8) | data[(boff+16)>>>3];
  739. Code = ( v>>(24-(boff&7)-bits) ) & ((1<<bits)-1); boff+=bits;
  740. if(Code==EoiCode) break;
  741. tgt[toff]=Code; toff++;
  742. }
  743. else if(Code<totl)
  744. {
  745. var cd = tab[Code], cl = tln[Code];
  746. copy(chr,cd,tgt,toff,cl); toff += cl;
  747. if(OldCode>=totl) { tab[totl] = chrl; chr[tab[totl]] = cd[0]; tln[totl]=1; chrl=(chrl+1+3)&~0x03; totl++; }
  748. else
  749. {
  750. tab[totl] = chrl;
  751. var nit = tab[OldCode], nil = tln[OldCode];
  752. copy(chr,nit,chr,chrl,nil);
  753. chr[chrl+nil]=chr[cd]; nil++;
  754. tln[totl]=nil; totl++;
  755. chrl=(chrl+nil+3)&~0x03;
  756. }
  757. if(totl+1==(1<<bits)) bits++;
  758. }
  759. else
  760. {
  761. if(OldCode>=totl) { tab[totl] = chrl; tln[totl]=0; totl++; }
  762. else
  763. {
  764. tab[totl] = chrl;
  765. var nit = tab[OldCode], nil = tln[OldCode];
  766. copy(chr,nit,chr,chrl,nil);
  767. chr[chrl+nil]=chr[chrl]; nil++;
  768. tln[totl]=nil; totl++;
  769. copy(chr,chrl,tgt,toff,nil); toff += nil;
  770. chrl=(chrl+nil+3)&~0x03;
  771. }
  772. if(totl+1==(1<<bits)) bits++;
  773. }
  774. OldCode = Code;
  775. }
  776. }
  777. UTIF.decode._copyData = function(s,so,t,to,l) { for(var i=0;i<l;i+=4) { t[to+i]=s[so+i]; t[to+i+1]=s[so+i+1]; t[to+i+2]=s[so+i+2]; t[to+i+3]=s[so+i+3]; } }
  778. UTIF.tags = {};
  779. UTIF.ttypes = { 256:3,257:3,258:3, 259:3, 262:3, 273:4, 274:3, 277:3,278:4,279:4, 282:5, 283:5, 284:3, 286:5,287:5, 296:3, 305:2, 306:2, 338:3, 513:4, 514:4, 34665:4 };
  780. UTIF._readIFD = function(bin, data, offset, ifds, depth, debug)
  781. {
  782. var cnt = bin.readUshort(data, offset); offset+=2;
  783. var ifd = {}; ifds.push(ifd);
  784. if(debug) log(" ".repeat(depth),ifds.length-1,">>>----------------");
  785. for(var i=0; i<cnt; i++)
  786. {
  787. var tag = bin.readUshort(data, offset); offset+=2;
  788. var type = bin.readUshort(data, offset); offset+=2;
  789. var num = bin.readUint (data, offset); offset+=4;
  790. var voff = bin.readUint (data, offset); offset+=4;
  791. //if(tag==33723) {type=1; num*=4;}//console.log(type,num,voff);//type = 1; // IPTC/NAA
  792. var arr = [];
  793. //ifd["t"+tag+"-"+UTIF.tags[tag]] = arr;
  794. if(type== 1 || type==7) { arr = new Uint8Array(data.buffer, (num<5 ? offset-4 : voff), num); }
  795. if(type== 2) { var o0 = (num<5 ? offset-4 : voff), c=data[o0];
  796. if(c<128) arr.push( bin.readASCII(data, o0, num-1) );
  797. else arr = new Uint8Array(data.buffer, o0, num-1); }
  798. if(type== 3) { for(var j=0; j<num; j++) arr.push(bin.readUshort(data, (num<3 ? offset-4 : voff)+2*j)); }
  799. if(type== 4) { for(var j=0; j<num; j++) arr.push(bin.readUint (data, (num<2 ? offset-4 : voff)+4*j)); }
  800. if(type== 5) { for(var j=0; j<num; j++) arr.push(bin.readUint (data, voff+j*8) / bin.readUint(data,voff+j*8+4)); }
  801. if(type== 8) { for(var j=0; j<num; j++) arr.push(bin.readShort (data, (num<3 ? offset-4 : voff)+2*j)); }
  802. if(type== 9) { for(var j=0; j<num; j++) arr.push(bin.readInt (data, (num<2 ? offset-4 : voff)+4*j)); }
  803. if(type==10) { for(var j=0; j<num; j++) arr.push(bin.readInt (data, voff+j*8) / bin.readInt (data,voff+j*8+4)); }
  804. if(type==11) { for(var j=0; j<num; j++) arr.push(bin.readFloat (data, voff+j*4)); }
  805. if(type==12) { for(var j=0; j<num; j++) arr.push(bin.readDouble(data, voff+j*8)); }
  806. ifd["t"+tag] = arr;
  807. if(num!=0 && arr.length==0) { log("unknown TIFF tag type: ", type, "num:",num); }
  808. if(debug) log(" ".repeat(depth), tag, type, UTIF.tags[tag], arr);
  809. if(tag==330 && ifd["t272"] && ifd["t272"][0]=="DSLR-A100") { }
  810. // ifd["t258"]=[12]; ifd["t259"]=[32767]; ifd["t273"]=[offset+arr[0]]; ifd["t277"]=[1]; ifd["t279"]=[1]; ifd["t33421"]=[2,2]; ifd["t33422"]=[0,1,1,2];
  811. else if(tag==330 || tag==34665 || (tag==50740 && bin.readUshort(data,bin.readUint(arr,0))<300 )) {
  812. var oarr = tag==50740 ? [bin.readUint(arr,0)] : arr;
  813. var subfd = [];
  814. for(var j=0; j<oarr.length; j++) UTIF._readIFD(bin, data, oarr[j], subfd, depth+1, debug);
  815. if(tag== 330) ifd.subIFD = subfd;
  816. if(tag==34665) ifd.exifIFD = subfd[0];
  817. if(tag==50740) ifd.dngPrvt = subfd[0];
  818. }
  819. if(tag==37500) {
  820. var mn = arr;
  821. //console.log(bin.readASCII(mn,0,mn.length), mn);
  822. if(bin.readASCII(mn,0,5)=="Nikon") ifd.makerNote = UTIF["decode"](mn.slice(10).buffer)[0];
  823. else if(bin.readUshort(data,voff)<300){
  824. var subsub=[]; UTIF._readIFD(bin, data, voff, subsub, depth+1, debug);
  825. ifd.makerNote = subsub[0];
  826. }
  827. }
  828. }
  829. if(debug) log(" ".repeat(depth),"<<<---------------");
  830. return offset;
  831. }
  832. UTIF._writeIFD = function(bin, data, offset, ifd)
  833. {
  834. var keys = Object.keys(ifd);
  835. bin.writeUshort(data, offset, keys.length); offset+=2;
  836. var eoff = offset + keys.length*12 + 4;
  837. for(var ki=0; ki<keys.length; ki++)
  838. {
  839. var key = keys[ki];
  840. var tag = parseInt(key.slice(1)), type = UTIF.ttypes[tag]; if(type==null) throw new Error("unknown type of tag: "+tag);
  841. var val = ifd[key]; if(type==2) val=val[0]+"\u0000"; var num = val.length;
  842. bin.writeUshort(data, offset, tag ); offset+=2;
  843. bin.writeUshort(data, offset, type); offset+=2;
  844. bin.writeUint (data, offset, num ); offset+=4;
  845. var dlen = [-1, 1, 1, 2, 4, 8, 0, 0, 0, 0, 0, 0, 8][type] * num;
  846. var toff = offset;
  847. if(dlen>4) { bin.writeUint(data, offset, eoff); toff=eoff; }
  848. if(type==2) { bin.writeASCII(data, toff, val); }
  849. if(type==3) { for(var i=0; i<num; i++) bin.writeUshort(data, toff+2*i, val[i]); }
  850. if(type==4) { for(var i=0; i<num; i++) bin.writeUint (data, toff+4*i, val[i]); }
  851. if(type==5) { for(var i=0; i<num; i++) { bin.writeUint(data, toff+8*i, Math.round(val[i]*10000)); bin.writeUint(data, toff+8*i+4, 10000); } }
  852. if (type == 12) { for (var i = 0; i < num; i++) bin.writeDouble(data, toff + 8 * i, val[i]); }
  853. if(dlen>4) { dlen += (dlen&1); eoff += dlen; }
  854. offset += 4;
  855. }
  856. return [offset, eoff];
  857. }
  858. UTIF.toRGBA8 = function(out)
  859. {
  860. var w = out.width, h = out.height, area = w*h, qarea = area*4, data = out.data;
  861. var img = new Uint8Array(area*4);
  862. //console.log(out);
  863. // 0: WhiteIsZero, 1: BlackIsZero, 2: RGB, 3: Palette color, 4: Transparency mask, 5: CMYK
  864. var intp = (out["t262"] ? out["t262"][0]: 2), bps = (out["t258"]?Math.min(32,out["t258"][0]):1);
  865. //log("interpretation: ", intp, "bps", bps, out);
  866. if(false) {}
  867. else if(intp==0)
  868. {
  869. var bpl = Math.ceil(bps*w/8);
  870. for(var y=0; y<h; y++) {
  871. var off = y*bpl, io = y*w;
  872. if(bps== 1) for(var i=0; i<w; i++) { var qi=(io+i)<<2, px=((data[off+(i>>3)])>>(7- (i&7)))& 1; img[qi]=img[qi+1]=img[qi+2]=( 1-px)*255; img[qi+3]=255; }
  873. if(bps== 4) for(var i=0; i<w; i++) { var qi=(io+i)<<2, px=((data[off+(i>>1)])>>(4-4*(i&1)))&15; img[qi]=img[qi+1]=img[qi+2]=(15-px)* 17; img[qi+3]=255; }
  874. if(bps== 8) for(var i=0; i<w; i++) { var qi=(io+i)<<2, px=data[off+i]; img[qi]=img[qi+1]=img[qi+2]=255-px; img[qi+3]=255; }
  875. }
  876. }
  877. else if(intp==1)
  878. {
  879. var bpl = Math.ceil(bps*w/8);
  880. for(var y=0; y<h; y++) {
  881. var off = y*bpl, io = y*w;
  882. if(bps== 1) for(var i=0; i<w; i++) { var qi=(io+i)<<2, px=((data[off+(i>>3)])>>(7- (i&7)))&1; img[qi]=img[qi+1]=img[qi+2]=(px)*255; img[qi+3]=255; }
  883. if(bps== 2) for(var i=0; i<w; i++) { var qi=(io+i)<<2, px=((data[off+(i>>2)])>>(6-2*(i&3)))&3; img[qi]=img[qi+1]=img[qi+2]=(px)* 85; img[qi+3]=255; }
  884. if(bps== 8) for(var i=0; i<w; i++) { var qi=(io+i)<<2, px=data[off+i]; img[qi]=img[qi+1]=img[qi+2]= px; img[qi+3]=255; }
  885. if(bps==16) for(var i=0; i<w; i++) { var qi=(io+i)<<2, px=data[off+(2*i+1)]; img[qi]=img[qi+1]=img[qi+2]= Math.min(255,px); img[qi+3]=255; } // ladoga.tif
  886. }
  887. }
  888. else if(intp==2)
  889. {
  890. var smpls = out["t258"]?out["t258"].length : 3;
  891. if(bps== 8)
  892. {
  893. if(smpls==4) for(var i=0; i<qarea; i++) img[i] = data[i];
  894. if(smpls==3) for(var i=0; i< area; i++) { var qi=i<<2, ti=i*3; img[qi]=data[ti]; img[qi+1]=data[ti+1]; img[qi+2]=data[ti+2]; img[qi+3]=255; }
  895. }
  896. else{ // 3x 16-bit channel
  897. if(smpls==4) for(var i=0; i<area; i++) { var qi=i<<2, ti=i*8+1; img[qi]=data[ti]; img[qi+1]=data[ti+2]; img[qi+2]=data[ti+4]; img[qi+3]=data[ti+6]; }
  898. if(smpls==3) for(var i=0; i<area; i++) { var qi=i<<2, ti=i*6+1; img[qi]=data[ti]; img[qi+1]=data[ti+2]; img[qi+2]=data[ti+4]; img[qi+3]=255; }
  899. }
  900. }
  901. else if(intp==3)
  902. {
  903. var map = out["t320"];
  904. for(var i=0; i<area; i++) { var qi=i<<2, mi=data[i]; img[qi]=(map[mi]>>8); img[qi+1]=(map[256+mi]>>8); img[qi+2]=(map[512+mi]>>8); img[qi+3]=255; }
  905. }
  906. else if(intp==5)
  907. {
  908. var smpls = out["t258"]?out["t258"].length : 4;
  909. var gotAlpha = smpls>4 ? 1 : 0;
  910. for(var i=0; i<area; i++) {
  911. var qi=i<<2, si=i*smpls; var C=255-data[si], M=255-data[si+1], Y=255-data[si+2], K=(255-data[si+3])*(1/255);
  912. img[qi]=~~(C*K+0.5); img[qi+1]=~~(M*K+0.5); img[qi+2]=~~(Y*K+0.5); img[qi+3]=255*(1-gotAlpha)+data[si+4]*gotAlpha;
  913. }
  914. }
  915. else log("Unknown Photometric interpretation: "+intp);
  916. return img;
  917. }
  918. UTIF.replaceIMG = function(imgs)
  919. {
  920. if(imgs==null) imgs = document.getElementsByTagName("img");
  921. var sufs = ["tif","tiff","dng","cr2","nef"]
  922. for (var i=0; i<imgs.length; i++)
  923. {
  924. var img=imgs[i], src=img.getAttribute("src"); if(src==null) continue;
  925. var suff=src.split(".").pop().toLowerCase();
  926. if(sufs.indexOf(suff)==-1) continue;
  927. var xhr = new XMLHttpRequest(); UTIF._xhrs.push(xhr); UTIF._imgs.push(img);
  928. xhr.open("GET", src); xhr.responseType = "arraybuffer";
  929. xhr.onload = UTIF._imgLoaded; xhr.send();
  930. }
  931. }
  932. UTIF._xhrs = []; UTIF._imgs = [];
  933. UTIF._imgLoaded = function(e)
  934. {
  935. var buff = e.target.response;
  936. var ifds = UTIF.decode(buff); //console.log(ifds);
  937. var vsns = ifds, ma=0, page=vsns[0]; if(ifds[0].subIFD) vsns = vsns.concat(ifds[0].subIFD);
  938. for(var i=0; i<vsns.length; i++) {
  939. var img = vsns[i];
  940. if(img["t258"]==null || img["t258"].length<3) continue;
  941. var ar = img["t256"]*img["t257"];
  942. if(ar>ma) { ma=ar; page=img; }
  943. }
  944. UTIF.decodeImage(buff, page, ifds);
  945. var rgba = UTIF.toRGBA8(page), w=page.width, h=page.height;
  946. var ind = UTIF._xhrs.indexOf(e.target), img = UTIF._imgs[ind];
  947. UTIF._xhrs.splice(ind,1); UTIF._imgs.splice(ind,1);
  948. var cnv = document.createElement("canvas"); cnv.width=w; cnv.height=h;
  949. var ctx = cnv.getContext("2d"), imgd = ctx.createImageData(w,h);
  950. for(var i=0; i<rgba.length; i++) imgd.data[i]=rgba[i]; ctx.putImageData(imgd,0,0);
  951. img.setAttribute("src",cnv.toDataURL());
  952. }
  953. UTIF._binBE =
  954. {
  955. nextZero : function(data, o) { while(data[o]!=0) o++; return o; },
  956. readUshort : function(buff, p) { return (buff[p]<< 8) | buff[p+1]; },
  957. readShort : function(buff, p) { var a=UTIF._binBE.ui8; a[0]=buff[p+1]; a[1]=buff[p+0]; return UTIF._binBE. i16[0]; },
  958. readInt : function(buff, p) { var a=UTIF._binBE.ui8; a[0]=buff[p+3]; a[1]=buff[p+2]; a[2]=buff[p+1]; a[3]=buff[p+0]; return UTIF._binBE. i32[0]; },
  959. readUint : function(buff, p) { var a=UTIF._binBE.ui8; a[0]=buff[p+3]; a[1]=buff[p+2]; a[2]=buff[p+1]; a[3]=buff[p+0]; return UTIF._binBE.ui32[0]; },
  960. readASCII : function(buff, p, l) { var s = ""; for(var i=0; i<l; i++) s += String.fromCharCode(buff[p+i]); return s; },
  961. readFloat : function(buff, p) { var a=UTIF._binBE.ui8; for(var i=0;i<4;i++) a[i]=buff[p+3-i]; return UTIF._binBE.fl32[0]; },
  962. readDouble : function(buff, p) { var a=UTIF._binBE.ui8; for(var i=0;i<8;i++) a[i]=buff[p+7-i]; return UTIF._binBE.fl64[0]; },
  963. writeUshort: function(buff, p, n) { buff[p] = (n>> 8)&255; buff[p+1] = n&255; },
  964. writeUint : function(buff, p, n) { buff[p] = (n>>24)&255; buff[p+1] = (n>>16)&255; buff[p+2] = (n>>8)&255; buff[p+3] = (n>>0)&255; },
  965. writeASCII : function(buff, p, s) { for(var i = 0; i < s.length; i++) buff[p+i] = s.charCodeAt(i); },
  966. writeDouble: function(buff, p, n)
  967. {
  968. UTIF._binBE.fl64[0] = n;
  969. for (var i = 0; i < 8; i++) buff[p + i] = UTIF._binBE.ui8[7 - i];
  970. }
  971. }
  972. UTIF._binBE.ui8 = new Uint8Array (8);
  973. UTIF._binBE.i16 = new Int16Array (UTIF._binBE.ui8.buffer);
  974. UTIF._binBE.i32 = new Int32Array (UTIF._binBE.ui8.buffer);
  975. UTIF._binBE.ui32 = new Uint32Array (UTIF._binBE.ui8.buffer);
  976. UTIF._binBE.fl32 = new Float32Array(UTIF._binBE.ui8.buffer);
  977. UTIF._binBE.fl64 = new Float64Array(UTIF._binBE.ui8.buffer);
  978. UTIF._binLE =
  979. {
  980. nextZero : UTIF._binBE.nextZero,
  981. readUshort : function(buff, p) { return (buff[p+1]<< 8) | buff[p]; },
  982. readShort : function(buff, p) { var a=UTIF._binBE.ui8; a[0]=buff[p+0]; a[1]=buff[p+1]; return UTIF._binBE. i16[0]; },
  983. readInt : function(buff, p) { var a=UTIF._binBE.ui8; a[0]=buff[p+0]; a[1]=buff[p+1]; a[2]=buff[p+2]; a[3]=buff[p+3]; return UTIF._binBE. i32[0]; },
  984. readUint : function(buff, p) { var a=UTIF._binBE.ui8; a[0]=buff[p+0]; a[1]=buff[p+1]; a[2]=buff[p+2]; a[3]=buff[p+3]; return UTIF._binBE.ui32[0]; },
  985. readASCII : UTIF._binBE.readASCII,
  986. readFloat : function(buff, p) { var a=UTIF._binBE.ui8; for(var i=0;i<4;i++) a[i]=buff[p+ i]; return UTIF._binBE.fl32[0]; },
  987. readDouble : function(buff, p) { var a=UTIF._binBE.ui8; for(var i=0;i<8;i++) a[i]=buff[p+ i]; return UTIF._binBE.fl64[0]; }
  988. }
  989. UTIF._copyTile = function(tb, tw, th, b, w, h, xoff, yoff)
  990. {
  991. //log("copyTile", tw, th, w, h, xoff, yoff);
  992. var xlim = Math.min(tw, w-xoff);
  993. var ylim = Math.min(th, h-yoff);
  994. for(var y=0; y<ylim; y++)
  995. {
  996. var tof = (yoff+y)*w+xoff;
  997. var sof = y*tw;
  998. for(var x=0; x<xlim; x++) b[tof+x] = tb[sof+x];
  999. }
  1000. }
  1001. UTIF.LosslessJpegDecode = (function(){function t(Z){this.w=Z;this.N=0;this._=0;this.G=0}t.prototype={t:function(Z){this.N=Math.max(0,Math.min(this.w.length,Z))},i:function(){return this.w[this.N++]},l:function(){var Z=this.N;
  1002. this.N+=2;return this.w[Z]<<8|this.w[Z+1]},J:function(){if(this._==0){this.G=this.w[this.N];this.N+=1+(this.G+1>>>8);
  1003. this._=8}return this.G>>>--this._&1},Z:function(Z){var X=this._,s=this.G,E=Math.min(X,Z);Z-=E;X-=E;var Y=s>>>X&(1<<E)-1;
  1004. while(Z>0){s=this.w[this.N];this.N+=1+(s+1>>>8);E=Math.min(8,Z);Z-=E;X=8-E;Y<<=E;Y|=s>>>X&(1<<E)-1}this._=X;
  1005. this.G=s;return Y}};var i={};i.X=function(){return[0,0,-1]};i.s=function(Z,X,s){Z[i.Y(Z,0,s)+2]=X};i.Y=function(Z,X,s){if(Z[X+2]!=-1)return 0;
  1006. if(s==0)return X;for(var E=0;E<2;E++){if(Z[X+E]==0){Z[X+E]=Z.length;Z.push(0);Z.push(0);Z.push(-1)}var Y=i.Y(Z,Z[X+E],s-1);
  1007. if(Y!=0)return Y}return 0};i.B=function(Z,X){var s=0,E=0,Y=0,B=X._,$=X.G,e=X.N;while(!0){if(B==0){$=X.w[e];
  1008. e+=1+($+1>>>8);B=8}Y=$>>>--B&1;s=Z[s+Y];E=Z[s+2];if(E!=-1){X._=B;X.G=$;X.N=e;return E}}return-1};function l(Z){this.z=new t(Z);
  1009. this.D(this.z)}l.prototype={$:function(Z,X){this.Q=Z.i();this.F=Z.l();this.o=Z.l();var s=this.O=Z.i();
  1010. this.L=[];for(var E=0;E<s;E++){var Y=Z.i(),B=Z.i();Z.i();this.L[Y]=E}Z.t(Z.N+X-(6+s*3))},e:function(){var Z=0,X=this.z.i();
  1011. if(this.H==null)this.H={};var s=this.H[X]=i.X(),E=[];for(var Y=0;Y<16;Y++){E[Y]=this.z.i();Z+=E[Y]}for(var Y=0;
  1012. Y<16;Y++)for(var B=0;B<E[Y];B++)i.s(s,this.z.i(),Y+1);return Z+17},W:function(Z){while(Z>0)Z-=this.e()},p:function(Z,X){var s=Z.i();
  1013. if(!this.U){this.U=[]}for(var E=0;E<s;E++){var Y=Z.i(),B=Z.i();this.U[this.L[Y]]=this.H[B>>>4]}this.g=Z.i();
  1014. Z.t(Z.N+X-(2+s*2))},D:function(Z){var X=!1,s=Z.l();if(s!==l.q)return;do{var s=Z.l(),E=Z.l()-2;switch(s){case l.m:this.$(Z,E);
  1015. break;case l.K:this.W(E);break;case l.V:this.p(Z,E);X=!0;break;default:Z.t(Z.N+E);break}}while(!X)},I:function(Z,X){var s=i.B(X,Z);
  1016. if(s==16)return-32768;var E=Z.Z(s);if((E&1<<s-1)==0)E-=(1<<s)-1;return E},B:function(Z,X){var s=this.z,E=this.O,Y=this.F,B=this.I,$=this.g,e=this.o*E,W=this.U;
  1017. for(var p=0;p<E;p++){Z[p]=B(s,W[p])+(1<<this.Q-1)}for(var D=E;D<e;D+=E){for(var p=0;p<E;p++)Z[D+p]=B(s,W[p])+Z[D+p-E]}var I=X;
  1018. for(var m=1;m<Y;m++){for(var p=0;p<E;p++){Z[I+p]=B(s,W[p])+Z[I+p-X]}for(var D=E;D<e;D+=E){for(var p=0;
  1019. p<E;p++){var K=I+D+p,q=Z[K-E];if($==6)q=Z[K-X]+(q-Z[K-E-X]>>>1);Z[K]=q+B(s,W[p])}}I+=X}}};l.m=65475;
  1020. l.K=65476;l.q=65496;l.V=65498;function J(Z){var X=new l(Z),s=X.Q>8?Uint16Array:Uint8Array,E=new s(X.o*X.F*X.O),Y=X.o*X.O;
  1021. X.B(E,Y);return E}return J}())
  1022. })(UTIF, pako);
  1023. })();