XFA - Use fake MyriadPro as a fallback for missing fonts

- aims to fix #13597.
This commit is contained in:
Calixte Denizet 2021-07-10 16:18:45 +02:00
parent d416b23898
commit 690b5d1941
6 changed files with 62 additions and 31 deletions

View File

@ -993,7 +993,22 @@ class PDFDocument {
promises.length = 0;
pdfFonts.length = 0;
const reallyMissingFonts = new Set();
for (const missing of missingFonts) {
if (!getXfaFontWidths(`${missing}-Regular`)) {
// No substitution available: we'll fallback on Myriad.
reallyMissingFonts.add(missing);
}
}
if (reallyMissingFonts.size) {
missingFonts.push("PdfJS-Fallback");
}
for (const missing of missingFonts) {
if (reallyMissingFonts.has(missing)) {
continue;
}
for (const fontInfo of [
{ name: "Regular", fontWeight: 400, italicAngle: 0 },
{ name: "Bold", fontWeight: 700, italicAngle: 0 },
@ -1002,10 +1017,6 @@ class PDFDocument {
]) {
const name = `${missing}-${fontInfo.name}`;
const widths = getXfaFontWidths(name);
if (!widths) {
continue;
}
const dict = new Dict(null);
dict.set("BaseFont", Name.get(name));
dict.set("Type", Name.get("Font"));
@ -1040,7 +1051,7 @@ class PDFDocument {
}
await Promise.all(promises);
this.xfaFactory.appendFonts(pdfFonts);
this.xfaFactory.appendFonts(pdfFonts, reallyMissingFonts);
}
async serializeXfaData(annotationStorage) {

View File

@ -83,8 +83,8 @@ class XFAFactory {
return null;
}
appendFonts(fonts) {
this.form[$globalData].fontFinder.add(fonts);
appendFonts(fonts, reallyMissingFonts) {
this.form[$globalData].fontFinder.add(fonts, reallyMissingFonts);
}
getPages() {

View File

@ -24,7 +24,7 @@ class FontFinder {
this.add(pdfFonts);
}
add(pdfFonts) {
add(pdfFonts, reallyMissingFonts = null) {
for (const pdfFont of pdfFonts) {
this.addPdfFont(pdfFont);
}
@ -33,6 +33,14 @@ class FontFinder {
pdfFont.regular = pdfFont.italic || pdfFont.bold || pdfFont.bolditalic;
}
}
if (!reallyMissingFonts || reallyMissingFonts.size === 0) {
return;
}
const myriad = this.fonts.get("PdfJS-Fallback-PdfJS-XFA");
for (const missing of reallyMissingFonts) {
this.fonts.set(missing, myriad);
}
}
addPdfFont(pdfFont) {
@ -47,13 +55,10 @@ class FontFinder {
}
}
let property = "";
if (cssFontInfo.italicAngle !== "0") {
if (parseFloat(cssFontInfo.fontWeight) >= 700) {
property = "bolditalic";
} else {
property = "italic";
}
} else if (parseFloat(cssFontInfo.fontWeight) >= 700) {
const fontWeight = parseFloat(cssFontInfo.fontWeight);
if (parseFloat(cssFontInfo.italicAngle) !== 0) {
property = fontWeight >= 700 ? "bolditalic" : "italic";
} else if (fontWeight >= 700) {
property = "bold";
}
@ -91,7 +96,7 @@ class FontFinder {
return font;
}
const pattern = /,|-| |bolditalic|bold|italic|regular|it/gi;
const pattern = /,|-|_| |bolditalic|bold|italic|regular|it/gi;
let name = fontName.replace(pattern, "");
font = this.fonts.get(name);
if (font) {

View File

@ -63,25 +63,31 @@ import { getLookupTableFactory } from "./core_utils.js";
import { normalizeFontName } from "./fonts_utils.js";
const getXFAFontMap = getLookupTableFactory(function (t) {
t["MyriadPro-Regular"] = {
t["MyriadPro-Regular"] = t["PdfJS-Fallback-Regular"] = {
name: "LiberationSans-Regular",
factors: MyriadProRegularFactors,
baseWidths: LiberationSansRegularWidths,
lineHeight: MyriadProRegularLineHeight,
};
t["MyriadPro-Bold"] = {
t["MyriadPro-Bold"] = t["PdfJS-Fallback-Bold"] = {
name: "LiberationSans-Bold",
factors: MyriadProBoldFactors,
baseWidths: LiberationSansBoldWidths,
lineHeight: MyriadProBoldLineHeight,
};
t["MyriadPro-It"] = {
t["MyriadPro-It"] =
t["MyriadPro-Italic"] =
t["PdfJS-Fallback-Italic"] =
{
name: "LiberationSans-Italic",
factors: MyriadProItalicFactors,
baseWidths: LiberationSansItalicWidths,
lineHeight: MyriadProItalicLineHeight,
};
t["MyriadPro-BoldIt"] = {
t["MyriadPro-BoldIt"] =
t["MyriadPro-BoldItalic"] =
t["PdfJS-Fallback-BoldItalic"] =
{
name: "LiberationSans-BoldItalic",
factors: MyriadProBoldItalicFactors,
baseWidths: LiberationSansBoldItalicWidths,
@ -154,7 +160,7 @@ const getXFAFontMap = getLookupTableFactory(function (t) {
baseWidths: LiberationSansBoldItalicWidths,
lineHeight: SegoeuiBoldItalicLineHeight,
};
t["Helvetica-Regular"] = {
t["Helvetica-Regular"] = t.Helvetica = {
name: "LiberationSans-Regular",
factors: HelveticaRegularFactors,
baseWidths: LiberationSansRegularWidths,

View File

@ -0,0 +1 @@
https://web.archive.org/web/20210710141547/https://help.adobe.com/en_US/livecycle/11.0/SampleForms/941/Form.pdf

View File

@ -1184,6 +1184,14 @@
"enableXfa": true,
"type": "eq"
},
{ "id": "xfa_issue13597",
"file": "pdfs/xfa_issue13597.pdf",
"md5": "1ed9338f7e797789c0b41182f51b9002",
"link": true,
"rounds": 1,
"enableXfa": true,
"type": "eq"
},
{ "id": "xfa_issue13633",
"file": "pdfs/xfa_issue13633.pdf",
"md5": "e5b0d09285ca6a140eba08d740be0ea0",