Support standards fonts
This commit is contained in:
parent
9d6eb079f3
commit
aa41a75f6e
85
fonts.js
85
fonts.js
@ -15,11 +15,51 @@ var kMaxFontFileSize = 200000;
|
||||
var kMaxWaitForFontFace = 1000;
|
||||
|
||||
/**
|
||||
* Hold a map of decoded fonts and of the standard fourteen Type1 fonts and
|
||||
* their acronyms.
|
||||
* TODO Add the standard fourteen Type1 fonts list by default
|
||||
* http://cgit.freedesktop.org/poppler/poppler/tree/poppler/GfxFont.cc#n65
|
||||
* Hold a map of decoded fonts and of the standard fourteen Type1
|
||||
* fonts and their acronyms.
|
||||
*/
|
||||
var stdFontMap = {
|
||||
"Arial": "Helvetica",
|
||||
"Arial_Bold": "Helvetica-Bold",
|
||||
"Arial_BoldItalic": "Helvetica-BoldOblique",
|
||||
"Arial_Italic": "Helvetica-Oblique",
|
||||
"Arial_BoldItalicMT": "Helvetica-BoldOblique",
|
||||
"Arial_BoldMT": "Helvetica-Bold",
|
||||
"Arial_ItalicMT": "Helvetica-Oblique",
|
||||
"ArialMT": "Helvetica",
|
||||
"Courier_Bold": "Courier-Bold",
|
||||
"Courier_BoldItalic": "Courier-BoldOblique",
|
||||
"Courier_Italic": "Courier-Oblique",
|
||||
"CourierNew": "Courier",
|
||||
"CourierNew_Bold": "Courier-Bold",
|
||||
"CourierNew_BoldItalic": "Courier-BoldOblique",
|
||||
"CourierNew_Italic": "Courier-Oblique",
|
||||
"CourierNewPS_BoldItalicMT": "Courier-BoldOblique",
|
||||
"CourierNewPS_BoldMT": "Courier-Bold",
|
||||
"CourierNewPS_ItalicMT": "Courier-Oblique",
|
||||
"CourierNewPSMT": "Courier",
|
||||
"Helvetica_Bold": "Helvetica-Bold",
|
||||
"Helvetica_BoldItalic": "Helvetica-BoldOblique",
|
||||
"Helvetica_Italic": "Helvetica-Oblique",
|
||||
"Symbol_Bold": "Symbol",
|
||||
"Symbol_BoldItalic": "Symbol",
|
||||
"Symbol_Italic": "Symbol",
|
||||
"TimesNewRoman": "Times-Roman",
|
||||
"TimesNewRoman_Bold": "Times-Bold",
|
||||
"TimesNewRoman_BoldItalic": "Times-BoldItalic",
|
||||
"TimesNewRoman_Italic": "Times-Italic",
|
||||
"TimesNewRomanPS": "Times-Roman",
|
||||
"TimesNewRomanPS_Bold": "Times-Bold",
|
||||
"TimesNewRomanPS_BoldItalic": "Times-BoldItalic",
|
||||
"TimesNewRomanPS_BoldItalicMT": "Times-BoldItalic",
|
||||
"TimesNewRomanPS_BoldMT": "Times-Bold",
|
||||
"TimesNewRomanPS_Italic": "Times-Italic",
|
||||
"TimesNewRomanPS_ItalicMT": "Times-Italic",
|
||||
"TimesNewRomanPSMT": "Times-Roman",
|
||||
"TimesNewRomanPSMT_Bold": "Times-Bold",
|
||||
"TimesNewRomanPSMT_BoldItalic": "Times-BoldItalic",
|
||||
"TimesNewRomanPSMT_Italic": "Times-Italic"
|
||||
};
|
||||
|
||||
var FontMeasure = (function FontMeasure() {
|
||||
var kScalePrecision = 50;
|
||||
@ -39,7 +79,12 @@ var FontMeasure = (function FontMeasure() {
|
||||
measureCache = null
|
||||
}
|
||||
|
||||
ctx.font = (size * kScalePrecision) + 'px "' + font.loadedName + '"';
|
||||
var name = font.loadedName;
|
||||
var bold = font.bold ? "bold" : "normal";
|
||||
var italic = font.italic ? "italic" : "normal";
|
||||
size *= kScalePrecision;
|
||||
var rule = bold + " " + italic + " " + size + 'px "' + name + '"';
|
||||
ctx.font = rule;
|
||||
},
|
||||
measureText: function fonts_measureText(text) {
|
||||
var width;
|
||||
@ -78,19 +123,20 @@ var FontLoader = {
|
||||
var font = fonts[i];
|
||||
|
||||
var obj = new Font(font.name, font.file, font.properties);
|
||||
obj.loading = true;
|
||||
objs.push(obj);
|
||||
|
||||
var str = '';
|
||||
var data = obj.data;
|
||||
var length = data.length;
|
||||
for (var j = 0; j < length; j++)
|
||||
str += String.fromCharCode(data[j]);
|
||||
if (data) {
|
||||
var length = data.length;
|
||||
for (var j = 0; j < length; j++)
|
||||
str += String.fromCharCode(data[j]);
|
||||
|
||||
var rule = isWorker ? obj.bindWorker(str) : obj.bindDOM(str);
|
||||
if (rule) {
|
||||
rules.push(rule);
|
||||
names.push(obj.loadedName);
|
||||
var rule = isWorker ? obj.bindWorker(str) : obj.bindDOM(str);
|
||||
if (rule) {
|
||||
rules.push(rule);
|
||||
names.push(obj.loadedName);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -350,6 +396,16 @@ var Font = (function Font() {
|
||||
// to avoid the cost of waiting for it be be loaded by the platform.
|
||||
if (properties.ignore) {
|
||||
this.loadedName = 'Arial';
|
||||
this.loading = false;
|
||||
return;
|
||||
}
|
||||
|
||||
if (!file) {
|
||||
var fontName = stdFontMap[name];
|
||||
this.bold = (fontName.indexOf("Bold") != -1);
|
||||
this.italic = (fontName.indexOf("Oblique") != -1);
|
||||
this.loadedName = fontName.split("-")[0];
|
||||
this.loading = false;
|
||||
return;
|
||||
}
|
||||
|
||||
@ -385,10 +441,11 @@ var Font = (function Font() {
|
||||
}
|
||||
|
||||
this.data = data;
|
||||
this.textMatrix = properties.textMatrix || IDENTITY_MATRIX;
|
||||
this.type = properties.type;
|
||||
this.textMatrix = properties.textMatrix;
|
||||
this.loadedName = getUniqueName();
|
||||
this.compositeFont = properties.compositeFont;
|
||||
this.loading = true;
|
||||
};
|
||||
|
||||
var numFonts = 0;
|
||||
|
36
pdf.js
36
pdf.js
@ -3662,11 +3662,6 @@ var PartialEvaluator = (function() {
|
||||
assertWellFormed(IsName(fontName), 'invalid font name');
|
||||
fontName = fontName.name.replace(/[\+,\-]/g, '_');
|
||||
|
||||
var fontFile = descriptor.get('FontFile', 'FontFile2', 'FontFile3');
|
||||
if (!fontFile)
|
||||
error('FontFile not found for font: ' + fontName);
|
||||
fontFile = xref.fetchIfRef(fontFile);
|
||||
|
||||
var encodingMap = {};
|
||||
var charset = [];
|
||||
if (compositeFont) {
|
||||
@ -3821,10 +3816,15 @@ var PartialEvaluator = (function() {
|
||||
}
|
||||
}
|
||||
|
||||
if (fontFile && fontFile.dict) {
|
||||
var fileType = fontFile.dict.get('Subtype');
|
||||
if (fileType)
|
||||
fileType = fileType.name;
|
||||
var fontFile = descriptor.get('FontFile', 'FontFile2', 'FontFile3');
|
||||
if (fontFile) {
|
||||
fontFile = xref.fetchIfRef(fontFile);
|
||||
|
||||
if (fontFile.dict) {
|
||||
var fileType = fontFile.dict.get('Subtype');
|
||||
if (fileType)
|
||||
fileType = fileType.name;
|
||||
}
|
||||
}
|
||||
|
||||
var widths = fontDict.get('Widths');
|
||||
@ -4154,26 +4154,30 @@ var CanvasGraphics = (function() {
|
||||
if (!font)
|
||||
return;
|
||||
|
||||
var fontName = '';
|
||||
var name = '';
|
||||
var fontObj = font.fontObj;
|
||||
if (fontObj)
|
||||
fontName = fontObj.loadedName;
|
||||
name = fontObj.loadedName;
|
||||
|
||||
if (!fontName) {
|
||||
if (!name) {
|
||||
// TODO: fontDescriptor is not available, fallback to default font
|
||||
fontName = 'sans-serif';
|
||||
name = 'sans-serif';
|
||||
}
|
||||
|
||||
this.current.font = fontObj;
|
||||
this.current.fontSize = size;
|
||||
|
||||
if (this.ctx.$setFont) {
|
||||
this.ctx.$setFont(fontName, size);
|
||||
this.ctx.$setFont(name, size);
|
||||
} else {
|
||||
FontMeasure.setActive(fontObj, size);
|
||||
|
||||
size = (size <= kRasterizerMin) ? size * kScalePrecision : size;
|
||||
this.ctx.font = size + 'px "' + fontName + '"';
|
||||
|
||||
var bold = fontObj.bold ? "bold" : "normal";
|
||||
var italic = fontObj.italic ? "italic" : "normal";
|
||||
var rule = bold + " " + italic + " " + size + 'px "' + name + '"';
|
||||
this.ctx.font = rule;
|
||||
}
|
||||
},
|
||||
setTextRenderingMode: function(mode) {
|
||||
@ -4224,7 +4228,7 @@ var CanvasGraphics = (function() {
|
||||
scaleFactorX = scaleFactorY = kScalePrecision;
|
||||
ctx.scale(1 / scaleFactorX, 1 / scaleFactorY);
|
||||
}
|
||||
ctx.transform.apply(ctx, font.textMatrix);
|
||||
ctx.transform.apply(ctx, font.textMatrix || IDENTITY_MATRIX);
|
||||
text = font.charsToUnicode(text);
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user