From 811547f36a9591eee6e7c36ed3e634f93316ac92 Mon Sep 17 00:00:00 2001 From: hestsan <71839259+Heston1@users.noreply.github.com> Date: Wed, 29 Dec 2021 21:24:40 +0000 Subject: [PATCH] add option to embed entire font --- lib/font/embedded.js | 37 ++++++++++++++++++++++++++----------- lib/font_factory.js | 4 ++-- lib/mixins/fonts.js | 4 ++-- 3 files changed, 30 insertions(+), 15 deletions(-) diff --git a/lib/font/embedded.js b/lib/font/embedded.js index fe26154f5..03095b2d4 100644 --- a/lib/font/embedded.js +++ b/lib/font/embedded.js @@ -1,3 +1,4 @@ +var fs = require('fs'); import PDFFont from '../font'; const toHex = function(num) { @@ -5,15 +6,27 @@ const toHex = function(num) { }; class EmbeddedFont extends PDFFont { - constructor(document, font, id) { + constructor(document, font, id, subset = true) { super(); this.document = document; this.font = font; this.id = id; - this.subset = this.font.createSubset(); + + this.subset = subset + this.subsetFont = this.subset && this.font.createSubset(); this.unicode = [[0]]; this.widths = [this.font.getGlyph(0).advanceWidth]; + if (this.subset == false) { + this.font.characterSet.forEach(codePoint => { + if (this.font.hasGlyphForCodePoint(codePoint)) { + const glyph = this.font.glyphForCodePoint(codePoint); + this.unicode[glyph.id] = [codePoint]; + this.widths[glyph.id] = (glyph.advanceWidth * this.scale); + } + }); + } + this.name = this.font.postscriptName; this.scale = 1000 / this.font.unitsPerEm; this.ascender = this.font.ascent * this.scale; @@ -100,14 +113,17 @@ class EmbeddedFont extends PDFFont { const res = []; for (let i = 0; i < glyphs.length; i++) { const glyph = glyphs[i]; - const gid = this.subset.includeGlyph(glyph.id); + const gid = this.subset ? this.subsetFont.includeGlyph(glyph.id) : glyph.id; + res.push(`0000${gid.toString(16)}`.slice(-4)); - if (this.widths[gid] == null) { - this.widths[gid] = glyph.advanceWidth * this.scale; - } - if (this.unicode[gid] == null) { - this.unicode[gid] = glyph.codePoints; + if (this.subset) { + if (this.widths[gid] == null) { + this.widths[gid] = glyph.advanceWidth * this.scale; + } + if (this.unicode[gid] == null) { + this.unicode[gid] = glyph.codePoints; + } } } @@ -121,15 +137,14 @@ class EmbeddedFont extends PDFFont { } embed() { - const isCFF = this.subset.cff != null; + const isCFF = (this.subsetFont || this.font).cff != null; const fontFile = this.document.ref(); if (isCFF) { fontFile.data.Subtype = 'CIDFontType0C'; } - this.subset - .encodeStream() + (this.subset ? this.font.encodeStream() : fs.createReadStream(this.font.filename)) .on('data', data => fontFile.write(data)) .on('end', () => fontFile.end()); diff --git a/lib/font_factory.js b/lib/font_factory.js index cfb743671..3c940ce2e 100644 --- a/lib/font_factory.js +++ b/lib/font_factory.js @@ -4,7 +4,7 @@ import StandardFont from './font/standard'; import EmbeddedFont from './font/embedded'; class PDFFontFactory { - static open(document, src, family, id) { + static open(document, src, family, id, subset = true) { let font; if (typeof src === 'string') { if (StandardFont.isStandardFont(src)) { @@ -25,7 +25,7 @@ class PDFFontFactory { throw new Error('Not a supported font format or standard PDF font.'); } - return new EmbeddedFont(document, font, id); + return new EmbeddedFont(document, font, id, subset); } } diff --git a/lib/mixins/fonts.js b/lib/mixins/fonts.js index d66d4a71f..de52a70f8 100644 --- a/lib/mixins/fonts.js +++ b/lib/mixins/fonts.js @@ -18,7 +18,7 @@ export default { } }, - font(src, family, size) { + font(src, family, size, subset) { let cacheKey, font; if (typeof family === 'number') { size = family; @@ -48,7 +48,7 @@ export default { // load the font const id = `F${++this._fontCount}`; - this._font = PDFFontFactory.open(this, src, family, id); + this._font = PDFFontFactory.open(this, src, family, id, subset); // check for existing font familes with the same name already in the PDF // useful if the font was passed as a buffer