2
0

pattern.js 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937
  1. /**
  2. * @licstart The following is the entire license notice for the
  3. * Javascript code in this page
  4. *
  5. * Copyright 2018 Mozilla Foundation
  6. *
  7. * Licensed under the Apache License, Version 2.0 (the "License");
  8. * you may not use this file except in compliance with the License.
  9. * You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing, software
  14. * distributed under the License is distributed on an "AS IS" BASIS,
  15. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  16. * See the License for the specific language governing permissions and
  17. * limitations under the License.
  18. *
  19. * @licend The above is the entire license notice for the
  20. * Javascript code in this page
  21. */
  22. "use strict";
  23. Object.defineProperty(exports, "__esModule", {
  24. value: true
  25. });
  26. exports.getTilingPatternIR = getTilingPatternIR;
  27. exports.Pattern = void 0;
  28. var _util = require("../shared/util");
  29. var _colorspace = require("./colorspace");
  30. var _primitives = require("./primitives");
  31. var ShadingType = {
  32. FUNCTION_BASED: 1,
  33. AXIAL: 2,
  34. RADIAL: 3,
  35. FREE_FORM_MESH: 4,
  36. LATTICE_FORM_MESH: 5,
  37. COONS_PATCH_MESH: 6,
  38. TENSOR_PATCH_MESH: 7
  39. };
  40. var Pattern = function PatternClosure() {
  41. function Pattern() {
  42. (0, _util.unreachable)('should not call Pattern constructor');
  43. }
  44. Pattern.prototype = {
  45. getPattern: function Pattern_getPattern(ctx) {
  46. (0, _util.unreachable)("Should not call Pattern.getStyle: ".concat(ctx));
  47. }
  48. };
  49. Pattern.parseShading = function (shading, matrix, xref, res, handler, pdfFunctionFactory) {
  50. var dict = (0, _primitives.isStream)(shading) ? shading.dict : shading;
  51. var type = dict.get('ShadingType');
  52. try {
  53. switch (type) {
  54. case ShadingType.AXIAL:
  55. case ShadingType.RADIAL:
  56. return new Shadings.RadialAxial(dict, matrix, xref, res, pdfFunctionFactory);
  57. case ShadingType.FREE_FORM_MESH:
  58. case ShadingType.LATTICE_FORM_MESH:
  59. case ShadingType.COONS_PATCH_MESH:
  60. case ShadingType.TENSOR_PATCH_MESH:
  61. return new Shadings.Mesh(shading, matrix, xref, res, pdfFunctionFactory);
  62. default:
  63. throw new _util.FormatError('Unsupported ShadingType: ' + type);
  64. }
  65. } catch (ex) {
  66. if (ex instanceof _util.MissingDataException) {
  67. throw ex;
  68. }
  69. handler.send('UnsupportedFeature', {
  70. featureId: _util.UNSUPPORTED_FEATURES.shadingPattern
  71. });
  72. (0, _util.warn)(ex);
  73. return new Shadings.Dummy();
  74. }
  75. };
  76. return Pattern;
  77. }();
  78. exports.Pattern = Pattern;
  79. var Shadings = {};
  80. Shadings.SMALL_NUMBER = 1e-6;
  81. Shadings.RadialAxial = function RadialAxialClosure() {
  82. function RadialAxial(dict, matrix, xref, res, pdfFunctionFactory) {
  83. this.matrix = matrix;
  84. this.coordsArr = dict.getArray('Coords');
  85. this.shadingType = dict.get('ShadingType');
  86. this.type = 'Pattern';
  87. var cs = dict.get('ColorSpace', 'CS');
  88. cs = _colorspace.ColorSpace.parse(cs, xref, res, pdfFunctionFactory);
  89. this.cs = cs;
  90. var t0 = 0.0,
  91. t1 = 1.0;
  92. if (dict.has('Domain')) {
  93. var domainArr = dict.getArray('Domain');
  94. t0 = domainArr[0];
  95. t1 = domainArr[1];
  96. }
  97. var extendStart = false,
  98. extendEnd = false;
  99. if (dict.has('Extend')) {
  100. var extendArr = dict.getArray('Extend');
  101. extendStart = extendArr[0];
  102. extendEnd = extendArr[1];
  103. }
  104. if (this.shadingType === ShadingType.RADIAL && (!extendStart || !extendEnd)) {
  105. var x1 = this.coordsArr[0];
  106. var y1 = this.coordsArr[1];
  107. var r1 = this.coordsArr[2];
  108. var x2 = this.coordsArr[3];
  109. var y2 = this.coordsArr[4];
  110. var r2 = this.coordsArr[5];
  111. var distance = Math.sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2));
  112. if (r1 <= r2 + distance && r2 <= r1 + distance) {
  113. (0, _util.warn)('Unsupported radial gradient.');
  114. }
  115. }
  116. this.extendStart = extendStart;
  117. this.extendEnd = extendEnd;
  118. var fnObj = dict.get('Function');
  119. var fn = pdfFunctionFactory.createFromArray(fnObj);
  120. var diff = t1 - t0;
  121. var step = diff / 10;
  122. var colorStops = this.colorStops = [];
  123. if (t0 >= t1 || step <= 0) {
  124. (0, _util.info)('Bad shading domain.');
  125. return;
  126. }
  127. var color = new Float32Array(cs.numComps),
  128. ratio = new Float32Array(1);
  129. var rgbColor;
  130. for (var i = t0; i <= t1; i += step) {
  131. ratio[0] = i;
  132. fn(ratio, 0, color, 0);
  133. rgbColor = cs.getRgb(color, 0);
  134. var cssColor = _util.Util.makeCssRgb(rgbColor[0], rgbColor[1], rgbColor[2]);
  135. colorStops.push([(i - t0) / diff, cssColor]);
  136. }
  137. var background = 'transparent';
  138. if (dict.has('Background')) {
  139. rgbColor = cs.getRgb(dict.get('Background'), 0);
  140. background = _util.Util.makeCssRgb(rgbColor[0], rgbColor[1], rgbColor[2]);
  141. }
  142. if (!extendStart) {
  143. colorStops.unshift([0, background]);
  144. colorStops[1][0] += Shadings.SMALL_NUMBER;
  145. }
  146. if (!extendEnd) {
  147. colorStops[colorStops.length - 1][0] -= Shadings.SMALL_NUMBER;
  148. colorStops.push([1, background]);
  149. }
  150. this.colorStops = colorStops;
  151. }
  152. RadialAxial.prototype = {
  153. getIR: function RadialAxial_getIR() {
  154. var coordsArr = this.coordsArr;
  155. var shadingType = this.shadingType;
  156. var type, p0, p1, r0, r1;
  157. if (shadingType === ShadingType.AXIAL) {
  158. p0 = [coordsArr[0], coordsArr[1]];
  159. p1 = [coordsArr[2], coordsArr[3]];
  160. r0 = null;
  161. r1 = null;
  162. type = 'axial';
  163. } else if (shadingType === ShadingType.RADIAL) {
  164. p0 = [coordsArr[0], coordsArr[1]];
  165. p1 = [coordsArr[3], coordsArr[4]];
  166. r0 = coordsArr[2];
  167. r1 = coordsArr[5];
  168. type = 'radial';
  169. } else {
  170. (0, _util.unreachable)("getPattern type unknown: ".concat(shadingType));
  171. }
  172. var matrix = this.matrix;
  173. if (matrix) {
  174. p0 = _util.Util.applyTransform(p0, matrix);
  175. p1 = _util.Util.applyTransform(p1, matrix);
  176. if (shadingType === ShadingType.RADIAL) {
  177. var scale = _util.Util.singularValueDecompose2dScale(matrix);
  178. r0 *= scale[0];
  179. r1 *= scale[1];
  180. }
  181. }
  182. return ['RadialAxial', type, this.colorStops, p0, p1, r0, r1];
  183. }
  184. };
  185. return RadialAxial;
  186. }();
  187. Shadings.Mesh = function MeshClosure() {
  188. function MeshStreamReader(stream, context) {
  189. this.stream = stream;
  190. this.context = context;
  191. this.buffer = 0;
  192. this.bufferLength = 0;
  193. var numComps = context.numComps;
  194. this.tmpCompsBuf = new Float32Array(numComps);
  195. var csNumComps = context.colorSpace.numComps;
  196. this.tmpCsCompsBuf = context.colorFn ? new Float32Array(csNumComps) : this.tmpCompsBuf;
  197. }
  198. MeshStreamReader.prototype = {
  199. get hasData() {
  200. if (this.stream.end) {
  201. return this.stream.pos < this.stream.end;
  202. }
  203. if (this.bufferLength > 0) {
  204. return true;
  205. }
  206. var nextByte = this.stream.getByte();
  207. if (nextByte < 0) {
  208. return false;
  209. }
  210. this.buffer = nextByte;
  211. this.bufferLength = 8;
  212. return true;
  213. },
  214. readBits: function MeshStreamReader_readBits(n) {
  215. var buffer = this.buffer;
  216. var bufferLength = this.bufferLength;
  217. if (n === 32) {
  218. if (bufferLength === 0) {
  219. return (this.stream.getByte() << 24 | this.stream.getByte() << 16 | this.stream.getByte() << 8 | this.stream.getByte()) >>> 0;
  220. }
  221. buffer = buffer << 24 | this.stream.getByte() << 16 | this.stream.getByte() << 8 | this.stream.getByte();
  222. var nextByte = this.stream.getByte();
  223. this.buffer = nextByte & (1 << bufferLength) - 1;
  224. return (buffer << 8 - bufferLength | (nextByte & 0xFF) >> bufferLength) >>> 0;
  225. }
  226. if (n === 8 && bufferLength === 0) {
  227. return this.stream.getByte();
  228. }
  229. while (bufferLength < n) {
  230. buffer = buffer << 8 | this.stream.getByte();
  231. bufferLength += 8;
  232. }
  233. bufferLength -= n;
  234. this.bufferLength = bufferLength;
  235. this.buffer = buffer & (1 << bufferLength) - 1;
  236. return buffer >> bufferLength;
  237. },
  238. align: function MeshStreamReader_align() {
  239. this.buffer = 0;
  240. this.bufferLength = 0;
  241. },
  242. readFlag: function MeshStreamReader_readFlag() {
  243. return this.readBits(this.context.bitsPerFlag);
  244. },
  245. readCoordinate: function MeshStreamReader_readCoordinate() {
  246. var bitsPerCoordinate = this.context.bitsPerCoordinate;
  247. var xi = this.readBits(bitsPerCoordinate);
  248. var yi = this.readBits(bitsPerCoordinate);
  249. var decode = this.context.decode;
  250. var scale = bitsPerCoordinate < 32 ? 1 / ((1 << bitsPerCoordinate) - 1) : 2.3283064365386963e-10;
  251. return [xi * scale * (decode[1] - decode[0]) + decode[0], yi * scale * (decode[3] - decode[2]) + decode[2]];
  252. },
  253. readComponents: function MeshStreamReader_readComponents() {
  254. var numComps = this.context.numComps;
  255. var bitsPerComponent = this.context.bitsPerComponent;
  256. var scale = bitsPerComponent < 32 ? 1 / ((1 << bitsPerComponent) - 1) : 2.3283064365386963e-10;
  257. var decode = this.context.decode;
  258. var components = this.tmpCompsBuf;
  259. for (var i = 0, j = 4; i < numComps; i++, j += 2) {
  260. var ci = this.readBits(bitsPerComponent);
  261. components[i] = ci * scale * (decode[j + 1] - decode[j]) + decode[j];
  262. }
  263. var color = this.tmpCsCompsBuf;
  264. if (this.context.colorFn) {
  265. this.context.colorFn(components, 0, color, 0);
  266. }
  267. return this.context.colorSpace.getRgb(color, 0);
  268. }
  269. };
  270. function decodeType4Shading(mesh, reader) {
  271. var coords = mesh.coords;
  272. var colors = mesh.colors;
  273. var operators = [];
  274. var ps = [];
  275. var verticesLeft = 0;
  276. while (reader.hasData) {
  277. var f = reader.readFlag();
  278. var coord = reader.readCoordinate();
  279. var color = reader.readComponents();
  280. if (verticesLeft === 0) {
  281. if (!(0 <= f && f <= 2)) {
  282. throw new _util.FormatError('Unknown type4 flag');
  283. }
  284. switch (f) {
  285. case 0:
  286. verticesLeft = 3;
  287. break;
  288. case 1:
  289. ps.push(ps[ps.length - 2], ps[ps.length - 1]);
  290. verticesLeft = 1;
  291. break;
  292. case 2:
  293. ps.push(ps[ps.length - 3], ps[ps.length - 1]);
  294. verticesLeft = 1;
  295. break;
  296. }
  297. operators.push(f);
  298. }
  299. ps.push(coords.length);
  300. coords.push(coord);
  301. colors.push(color);
  302. verticesLeft--;
  303. reader.align();
  304. }
  305. mesh.figures.push({
  306. type: 'triangles',
  307. coords: new Int32Array(ps),
  308. colors: new Int32Array(ps)
  309. });
  310. }
  311. function decodeType5Shading(mesh, reader, verticesPerRow) {
  312. var coords = mesh.coords;
  313. var colors = mesh.colors;
  314. var ps = [];
  315. while (reader.hasData) {
  316. var coord = reader.readCoordinate();
  317. var color = reader.readComponents();
  318. ps.push(coords.length);
  319. coords.push(coord);
  320. colors.push(color);
  321. }
  322. mesh.figures.push({
  323. type: 'lattice',
  324. coords: new Int32Array(ps),
  325. colors: new Int32Array(ps),
  326. verticesPerRow: verticesPerRow
  327. });
  328. }
  329. var MIN_SPLIT_PATCH_CHUNKS_AMOUNT = 3;
  330. var MAX_SPLIT_PATCH_CHUNKS_AMOUNT = 20;
  331. var TRIANGLE_DENSITY = 20;
  332. var getB = function getBClosure() {
  333. function buildB(count) {
  334. var lut = [];
  335. for (var i = 0; i <= count; i++) {
  336. var t = i / count,
  337. t_ = 1 - t;
  338. lut.push(new Float32Array([t_ * t_ * t_, 3 * t * t_ * t_, 3 * t * t * t_, t * t * t]));
  339. }
  340. return lut;
  341. }
  342. var cache = [];
  343. return function getB(count) {
  344. if (!cache[count]) {
  345. cache[count] = buildB(count);
  346. }
  347. return cache[count];
  348. };
  349. }();
  350. function buildFigureFromPatch(mesh, index) {
  351. var figure = mesh.figures[index];
  352. (0, _util.assert)(figure.type === 'patch', 'Unexpected patch mesh figure');
  353. var coords = mesh.coords,
  354. colors = mesh.colors;
  355. var pi = figure.coords;
  356. var ci = figure.colors;
  357. var figureMinX = Math.min(coords[pi[0]][0], coords[pi[3]][0], coords[pi[12]][0], coords[pi[15]][0]);
  358. var figureMinY = Math.min(coords[pi[0]][1], coords[pi[3]][1], coords[pi[12]][1], coords[pi[15]][1]);
  359. var figureMaxX = Math.max(coords[pi[0]][0], coords[pi[3]][0], coords[pi[12]][0], coords[pi[15]][0]);
  360. var figureMaxY = Math.max(coords[pi[0]][1], coords[pi[3]][1], coords[pi[12]][1], coords[pi[15]][1]);
  361. var splitXBy = Math.ceil((figureMaxX - figureMinX) * TRIANGLE_DENSITY / (mesh.bounds[2] - mesh.bounds[0]));
  362. splitXBy = Math.max(MIN_SPLIT_PATCH_CHUNKS_AMOUNT, Math.min(MAX_SPLIT_PATCH_CHUNKS_AMOUNT, splitXBy));
  363. var splitYBy = Math.ceil((figureMaxY - figureMinY) * TRIANGLE_DENSITY / (mesh.bounds[3] - mesh.bounds[1]));
  364. splitYBy = Math.max(MIN_SPLIT_PATCH_CHUNKS_AMOUNT, Math.min(MAX_SPLIT_PATCH_CHUNKS_AMOUNT, splitYBy));
  365. var verticesPerRow = splitXBy + 1;
  366. var figureCoords = new Int32Array((splitYBy + 1) * verticesPerRow);
  367. var figureColors = new Int32Array((splitYBy + 1) * verticesPerRow);
  368. var k = 0;
  369. var cl = new Uint8Array(3),
  370. cr = new Uint8Array(3);
  371. var c0 = colors[ci[0]],
  372. c1 = colors[ci[1]],
  373. c2 = colors[ci[2]],
  374. c3 = colors[ci[3]];
  375. var bRow = getB(splitYBy),
  376. bCol = getB(splitXBy);
  377. for (var row = 0; row <= splitYBy; row++) {
  378. cl[0] = (c0[0] * (splitYBy - row) + c2[0] * row) / splitYBy | 0;
  379. cl[1] = (c0[1] * (splitYBy - row) + c2[1] * row) / splitYBy | 0;
  380. cl[2] = (c0[2] * (splitYBy - row) + c2[2] * row) / splitYBy | 0;
  381. cr[0] = (c1[0] * (splitYBy - row) + c3[0] * row) / splitYBy | 0;
  382. cr[1] = (c1[1] * (splitYBy - row) + c3[1] * row) / splitYBy | 0;
  383. cr[2] = (c1[2] * (splitYBy - row) + c3[2] * row) / splitYBy | 0;
  384. for (var col = 0; col <= splitXBy; col++, k++) {
  385. if ((row === 0 || row === splitYBy) && (col === 0 || col === splitXBy)) {
  386. continue;
  387. }
  388. var x = 0,
  389. y = 0;
  390. var q = 0;
  391. for (var i = 0; i <= 3; i++) {
  392. for (var j = 0; j <= 3; j++, q++) {
  393. var m = bRow[row][i] * bCol[col][j];
  394. x += coords[pi[q]][0] * m;
  395. y += coords[pi[q]][1] * m;
  396. }
  397. }
  398. figureCoords[k] = coords.length;
  399. coords.push([x, y]);
  400. figureColors[k] = colors.length;
  401. var newColor = new Uint8Array(3);
  402. newColor[0] = (cl[0] * (splitXBy - col) + cr[0] * col) / splitXBy | 0;
  403. newColor[1] = (cl[1] * (splitXBy - col) + cr[1] * col) / splitXBy | 0;
  404. newColor[2] = (cl[2] * (splitXBy - col) + cr[2] * col) / splitXBy | 0;
  405. colors.push(newColor);
  406. }
  407. }
  408. figureCoords[0] = pi[0];
  409. figureColors[0] = ci[0];
  410. figureCoords[splitXBy] = pi[3];
  411. figureColors[splitXBy] = ci[1];
  412. figureCoords[verticesPerRow * splitYBy] = pi[12];
  413. figureColors[verticesPerRow * splitYBy] = ci[2];
  414. figureCoords[verticesPerRow * splitYBy + splitXBy] = pi[15];
  415. figureColors[verticesPerRow * splitYBy + splitXBy] = ci[3];
  416. mesh.figures[index] = {
  417. type: 'lattice',
  418. coords: figureCoords,
  419. colors: figureColors,
  420. verticesPerRow: verticesPerRow
  421. };
  422. }
  423. function decodeType6Shading(mesh, reader) {
  424. var coords = mesh.coords;
  425. var colors = mesh.colors;
  426. var ps = new Int32Array(16);
  427. var cs = new Int32Array(4);
  428. while (reader.hasData) {
  429. var f = reader.readFlag();
  430. if (!(0 <= f && f <= 3)) {
  431. throw new _util.FormatError('Unknown type6 flag');
  432. }
  433. var i, ii;
  434. var pi = coords.length;
  435. for (i = 0, ii = f !== 0 ? 8 : 12; i < ii; i++) {
  436. coords.push(reader.readCoordinate());
  437. }
  438. var ci = colors.length;
  439. for (i = 0, ii = f !== 0 ? 2 : 4; i < ii; i++) {
  440. colors.push(reader.readComponents());
  441. }
  442. var tmp1, tmp2, tmp3, tmp4;
  443. switch (f) {
  444. case 0:
  445. ps[12] = pi + 3;
  446. ps[13] = pi + 4;
  447. ps[14] = pi + 5;
  448. ps[15] = pi + 6;
  449. ps[8] = pi + 2;
  450. ps[11] = pi + 7;
  451. ps[4] = pi + 1;
  452. ps[7] = pi + 8;
  453. ps[0] = pi;
  454. ps[1] = pi + 11;
  455. ps[2] = pi + 10;
  456. ps[3] = pi + 9;
  457. cs[2] = ci + 1;
  458. cs[3] = ci + 2;
  459. cs[0] = ci;
  460. cs[1] = ci + 3;
  461. break;
  462. case 1:
  463. tmp1 = ps[12];
  464. tmp2 = ps[13];
  465. tmp3 = ps[14];
  466. tmp4 = ps[15];
  467. ps[12] = tmp4;
  468. ps[13] = pi + 0;
  469. ps[14] = pi + 1;
  470. ps[15] = pi + 2;
  471. ps[8] = tmp3;
  472. ps[11] = pi + 3;
  473. ps[4] = tmp2;
  474. ps[7] = pi + 4;
  475. ps[0] = tmp1;
  476. ps[1] = pi + 7;
  477. ps[2] = pi + 6;
  478. ps[3] = pi + 5;
  479. tmp1 = cs[2];
  480. tmp2 = cs[3];
  481. cs[2] = tmp2;
  482. cs[3] = ci;
  483. cs[0] = tmp1;
  484. cs[1] = ci + 1;
  485. break;
  486. case 2:
  487. tmp1 = ps[15];
  488. tmp2 = ps[11];
  489. ps[12] = ps[3];
  490. ps[13] = pi + 0;
  491. ps[14] = pi + 1;
  492. ps[15] = pi + 2;
  493. ps[8] = ps[7];
  494. ps[11] = pi + 3;
  495. ps[4] = tmp2;
  496. ps[7] = pi + 4;
  497. ps[0] = tmp1;
  498. ps[1] = pi + 7;
  499. ps[2] = pi + 6;
  500. ps[3] = pi + 5;
  501. tmp1 = cs[3];
  502. cs[2] = cs[1];
  503. cs[3] = ci;
  504. cs[0] = tmp1;
  505. cs[1] = ci + 1;
  506. break;
  507. case 3:
  508. ps[12] = ps[0];
  509. ps[13] = pi + 0;
  510. ps[14] = pi + 1;
  511. ps[15] = pi + 2;
  512. ps[8] = ps[1];
  513. ps[11] = pi + 3;
  514. ps[4] = ps[2];
  515. ps[7] = pi + 4;
  516. ps[0] = ps[3];
  517. ps[1] = pi + 7;
  518. ps[2] = pi + 6;
  519. ps[3] = pi + 5;
  520. cs[2] = cs[0];
  521. cs[3] = ci;
  522. cs[0] = cs[1];
  523. cs[1] = ci + 1;
  524. break;
  525. }
  526. ps[5] = coords.length;
  527. coords.push([(-4 * coords[ps[0]][0] - coords[ps[15]][0] + 6 * (coords[ps[4]][0] + coords[ps[1]][0]) - 2 * (coords[ps[12]][0] + coords[ps[3]][0]) + 3 * (coords[ps[13]][0] + coords[ps[7]][0])) / 9, (-4 * coords[ps[0]][1] - coords[ps[15]][1] + 6 * (coords[ps[4]][1] + coords[ps[1]][1]) - 2 * (coords[ps[12]][1] + coords[ps[3]][1]) + 3 * (coords[ps[13]][1] + coords[ps[7]][1])) / 9]);
  528. ps[6] = coords.length;
  529. coords.push([(-4 * coords[ps[3]][0] - coords[ps[12]][0] + 6 * (coords[ps[2]][0] + coords[ps[7]][0]) - 2 * (coords[ps[0]][0] + coords[ps[15]][0]) + 3 * (coords[ps[4]][0] + coords[ps[14]][0])) / 9, (-4 * coords[ps[3]][1] - coords[ps[12]][1] + 6 * (coords[ps[2]][1] + coords[ps[7]][1]) - 2 * (coords[ps[0]][1] + coords[ps[15]][1]) + 3 * (coords[ps[4]][1] + coords[ps[14]][1])) / 9]);
  530. ps[9] = coords.length;
  531. coords.push([(-4 * coords[ps[12]][0] - coords[ps[3]][0] + 6 * (coords[ps[8]][0] + coords[ps[13]][0]) - 2 * (coords[ps[0]][0] + coords[ps[15]][0]) + 3 * (coords[ps[11]][0] + coords[ps[1]][0])) / 9, (-4 * coords[ps[12]][1] - coords[ps[3]][1] + 6 * (coords[ps[8]][1] + coords[ps[13]][1]) - 2 * (coords[ps[0]][1] + coords[ps[15]][1]) + 3 * (coords[ps[11]][1] + coords[ps[1]][1])) / 9]);
  532. ps[10] = coords.length;
  533. coords.push([(-4 * coords[ps[15]][0] - coords[ps[0]][0] + 6 * (coords[ps[11]][0] + coords[ps[14]][0]) - 2 * (coords[ps[12]][0] + coords[ps[3]][0]) + 3 * (coords[ps[2]][0] + coords[ps[8]][0])) / 9, (-4 * coords[ps[15]][1] - coords[ps[0]][1] + 6 * (coords[ps[11]][1] + coords[ps[14]][1]) - 2 * (coords[ps[12]][1] + coords[ps[3]][1]) + 3 * (coords[ps[2]][1] + coords[ps[8]][1])) / 9]);
  534. mesh.figures.push({
  535. type: 'patch',
  536. coords: new Int32Array(ps),
  537. colors: new Int32Array(cs)
  538. });
  539. }
  540. }
  541. function decodeType7Shading(mesh, reader) {
  542. var coords = mesh.coords;
  543. var colors = mesh.colors;
  544. var ps = new Int32Array(16);
  545. var cs = new Int32Array(4);
  546. while (reader.hasData) {
  547. var f = reader.readFlag();
  548. if (!(0 <= f && f <= 3)) {
  549. throw new _util.FormatError('Unknown type7 flag');
  550. }
  551. var i, ii;
  552. var pi = coords.length;
  553. for (i = 0, ii = f !== 0 ? 12 : 16; i < ii; i++) {
  554. coords.push(reader.readCoordinate());
  555. }
  556. var ci = colors.length;
  557. for (i = 0, ii = f !== 0 ? 2 : 4; i < ii; i++) {
  558. colors.push(reader.readComponents());
  559. }
  560. var tmp1, tmp2, tmp3, tmp4;
  561. switch (f) {
  562. case 0:
  563. ps[12] = pi + 3;
  564. ps[13] = pi + 4;
  565. ps[14] = pi + 5;
  566. ps[15] = pi + 6;
  567. ps[8] = pi + 2;
  568. ps[9] = pi + 13;
  569. ps[10] = pi + 14;
  570. ps[11] = pi + 7;
  571. ps[4] = pi + 1;
  572. ps[5] = pi + 12;
  573. ps[6] = pi + 15;
  574. ps[7] = pi + 8;
  575. ps[0] = pi;
  576. ps[1] = pi + 11;
  577. ps[2] = pi + 10;
  578. ps[3] = pi + 9;
  579. cs[2] = ci + 1;
  580. cs[3] = ci + 2;
  581. cs[0] = ci;
  582. cs[1] = ci + 3;
  583. break;
  584. case 1:
  585. tmp1 = ps[12];
  586. tmp2 = ps[13];
  587. tmp3 = ps[14];
  588. tmp4 = ps[15];
  589. ps[12] = tmp4;
  590. ps[13] = pi + 0;
  591. ps[14] = pi + 1;
  592. ps[15] = pi + 2;
  593. ps[8] = tmp3;
  594. ps[9] = pi + 9;
  595. ps[10] = pi + 10;
  596. ps[11] = pi + 3;
  597. ps[4] = tmp2;
  598. ps[5] = pi + 8;
  599. ps[6] = pi + 11;
  600. ps[7] = pi + 4;
  601. ps[0] = tmp1;
  602. ps[1] = pi + 7;
  603. ps[2] = pi + 6;
  604. ps[3] = pi + 5;
  605. tmp1 = cs[2];
  606. tmp2 = cs[3];
  607. cs[2] = tmp2;
  608. cs[3] = ci;
  609. cs[0] = tmp1;
  610. cs[1] = ci + 1;
  611. break;
  612. case 2:
  613. tmp1 = ps[15];
  614. tmp2 = ps[11];
  615. ps[12] = ps[3];
  616. ps[13] = pi + 0;
  617. ps[14] = pi + 1;
  618. ps[15] = pi + 2;
  619. ps[8] = ps[7];
  620. ps[9] = pi + 9;
  621. ps[10] = pi + 10;
  622. ps[11] = pi + 3;
  623. ps[4] = tmp2;
  624. ps[5] = pi + 8;
  625. ps[6] = pi + 11;
  626. ps[7] = pi + 4;
  627. ps[0] = tmp1;
  628. ps[1] = pi + 7;
  629. ps[2] = pi + 6;
  630. ps[3] = pi + 5;
  631. tmp1 = cs[3];
  632. cs[2] = cs[1];
  633. cs[3] = ci;
  634. cs[0] = tmp1;
  635. cs[1] = ci + 1;
  636. break;
  637. case 3:
  638. ps[12] = ps[0];
  639. ps[13] = pi + 0;
  640. ps[14] = pi + 1;
  641. ps[15] = pi + 2;
  642. ps[8] = ps[1];
  643. ps[9] = pi + 9;
  644. ps[10] = pi + 10;
  645. ps[11] = pi + 3;
  646. ps[4] = ps[2];
  647. ps[5] = pi + 8;
  648. ps[6] = pi + 11;
  649. ps[7] = pi + 4;
  650. ps[0] = ps[3];
  651. ps[1] = pi + 7;
  652. ps[2] = pi + 6;
  653. ps[3] = pi + 5;
  654. cs[2] = cs[0];
  655. cs[3] = ci;
  656. cs[0] = cs[1];
  657. cs[1] = ci + 1;
  658. break;
  659. }
  660. mesh.figures.push({
  661. type: 'patch',
  662. coords: new Int32Array(ps),
  663. colors: new Int32Array(cs)
  664. });
  665. }
  666. }
  667. function updateBounds(mesh) {
  668. var minX = mesh.coords[0][0],
  669. minY = mesh.coords[0][1],
  670. maxX = minX,
  671. maxY = minY;
  672. for (var i = 1, ii = mesh.coords.length; i < ii; i++) {
  673. var x = mesh.coords[i][0],
  674. y = mesh.coords[i][1];
  675. minX = minX > x ? x : minX;
  676. minY = minY > y ? y : minY;
  677. maxX = maxX < x ? x : maxX;
  678. maxY = maxY < y ? y : maxY;
  679. }
  680. mesh.bounds = [minX, minY, maxX, maxY];
  681. }
  682. function packData(mesh) {
  683. var i, ii, j, jj;
  684. var coords = mesh.coords;
  685. var coordsPacked = new Float32Array(coords.length * 2);
  686. for (i = 0, j = 0, ii = coords.length; i < ii; i++) {
  687. var xy = coords[i];
  688. coordsPacked[j++] = xy[0];
  689. coordsPacked[j++] = xy[1];
  690. }
  691. mesh.coords = coordsPacked;
  692. var colors = mesh.colors;
  693. var colorsPacked = new Uint8Array(colors.length * 3);
  694. for (i = 0, j = 0, ii = colors.length; i < ii; i++) {
  695. var c = colors[i];
  696. colorsPacked[j++] = c[0];
  697. colorsPacked[j++] = c[1];
  698. colorsPacked[j++] = c[2];
  699. }
  700. mesh.colors = colorsPacked;
  701. var figures = mesh.figures;
  702. for (i = 0, ii = figures.length; i < ii; i++) {
  703. var figure = figures[i],
  704. ps = figure.coords,
  705. cs = figure.colors;
  706. for (j = 0, jj = ps.length; j < jj; j++) {
  707. ps[j] *= 2;
  708. cs[j] *= 3;
  709. }
  710. }
  711. }
  712. function Mesh(stream, matrix, xref, res, pdfFunctionFactory) {
  713. if (!(0, _primitives.isStream)(stream)) {
  714. throw new _util.FormatError('Mesh data is not a stream');
  715. }
  716. var dict = stream.dict;
  717. this.matrix = matrix;
  718. this.shadingType = dict.get('ShadingType');
  719. this.type = 'Pattern';
  720. this.bbox = dict.getArray('BBox');
  721. var cs = dict.get('ColorSpace', 'CS');
  722. cs = _colorspace.ColorSpace.parse(cs, xref, res, pdfFunctionFactory);
  723. this.cs = cs;
  724. this.background = dict.has('Background') ? cs.getRgb(dict.get('Background'), 0) : null;
  725. var fnObj = dict.get('Function');
  726. var fn = fnObj ? pdfFunctionFactory.createFromArray(fnObj) : null;
  727. this.coords = [];
  728. this.colors = [];
  729. this.figures = [];
  730. var decodeContext = {
  731. bitsPerCoordinate: dict.get('BitsPerCoordinate'),
  732. bitsPerComponent: dict.get('BitsPerComponent'),
  733. bitsPerFlag: dict.get('BitsPerFlag'),
  734. decode: dict.getArray('Decode'),
  735. colorFn: fn,
  736. colorSpace: cs,
  737. numComps: fn ? 1 : cs.numComps
  738. };
  739. var reader = new MeshStreamReader(stream, decodeContext);
  740. var patchMesh = false;
  741. switch (this.shadingType) {
  742. case ShadingType.FREE_FORM_MESH:
  743. decodeType4Shading(this, reader);
  744. break;
  745. case ShadingType.LATTICE_FORM_MESH:
  746. var verticesPerRow = dict.get('VerticesPerRow') | 0;
  747. if (verticesPerRow < 2) {
  748. throw new _util.FormatError('Invalid VerticesPerRow');
  749. }
  750. decodeType5Shading(this, reader, verticesPerRow);
  751. break;
  752. case ShadingType.COONS_PATCH_MESH:
  753. decodeType6Shading(this, reader);
  754. patchMesh = true;
  755. break;
  756. case ShadingType.TENSOR_PATCH_MESH:
  757. decodeType7Shading(this, reader);
  758. patchMesh = true;
  759. break;
  760. default:
  761. (0, _util.unreachable)('Unsupported mesh type.');
  762. break;
  763. }
  764. if (patchMesh) {
  765. updateBounds(this);
  766. for (var i = 0, ii = this.figures.length; i < ii; i++) {
  767. buildFigureFromPatch(this, i);
  768. }
  769. }
  770. updateBounds(this);
  771. packData(this);
  772. }
  773. Mesh.prototype = {
  774. getIR: function Mesh_getIR() {
  775. return ['Mesh', this.shadingType, this.coords, this.colors, this.figures, this.bounds, this.matrix, this.bbox, this.background];
  776. }
  777. };
  778. return Mesh;
  779. }();
  780. Shadings.Dummy = function DummyClosure() {
  781. function Dummy() {
  782. this.type = 'Pattern';
  783. }
  784. Dummy.prototype = {
  785. getIR: function Dummy_getIR() {
  786. return ['Dummy'];
  787. }
  788. };
  789. return Dummy;
  790. }();
  791. function getTilingPatternIR(operatorList, dict, args) {
  792. var matrix = dict.getArray('Matrix');
  793. var bbox = _util.Util.normalizeRect(dict.getArray('BBox'));
  794. var xstep = dict.get('XStep');
  795. var ystep = dict.get('YStep');
  796. var paintType = dict.get('PaintType');
  797. var tilingType = dict.get('TilingType');
  798. if (bbox[2] - bbox[0] === 0 || bbox[3] - bbox[1] === 0) {
  799. throw new _util.FormatError("Invalid getTilingPatternIR /BBox array: [".concat(bbox, "]."));
  800. }
  801. return ['TilingPattern', args, operatorList, matrix, bbox, xstep, ystep, paintType, tilingType];
  802. }