Moving CID-2 hack in fixWidths

This commit is contained in:
notmasteryet 2011-09-29 20:35:10 -05:00
parent cbfbd93e7a
commit cd63fce80b

View File

@ -1212,25 +1212,11 @@ var Font = (function Font() {
}
var encoding = properties.encoding, i;
if (!encoding[0]) {
// the font is directly characters to glyphs with no encoding
// so create an identity encoding
var widths = properties.widths;
for (i = 0; i < numGlyphs; i++) {
var width = widths[i];
encoding[i] = {
unicode: i <= 0x1f || (i >= 127 && i <= 255) ?
i + kCmapGlyphOffset : i,
width: isNum(width) ? width : properties.defaultWidth
};
}
} else {
for (i in encoding) {
if (encoding.hasOwnProperty(i)) {
var unicode = encoding[i].unicode;
if (unicode <= 0x1f || (unicode >= 127 && unicode <= 255))
encoding[i].unicode = unicode += kCmapGlyphOffset;
}
for (i in encoding) {
if (encoding.hasOwnProperty(i)) {
var unicode = encoding[i].unicode;
if (unicode <= 0x1f || (unicode >= 127 && unicode <= 255))
encoding[i].unicode = unicode += kCmapGlyphOffset;
}
}
@ -1407,6 +1393,10 @@ var Font = (function Font() {
},
fixWidths: function font_fixWidths(properties) {
if (properties.type !== 'CIDFontType0' &&
properties.type !== 'CIDFontType2')
return;
var encoding = properties.encoding;
if (encoding[0])
return;
@ -1414,30 +1404,48 @@ var Font = (function Font() {
if (!glyphsWidths)
return;
var defaultWidth = properties.defaultWidth;
var cidSystemInfo = properties.cidSystemInfo;
var cidToUnicode;
if (cidSystemInfo) {
cidToUnicode = CIDToUnicodeMaps[cidSystemInfo.registry +
'-' + cidSystemInfo.ordering];
cidToUnicode = CIDToUnicodeMaps[
cidSystemInfo.registry + '-' + cidSystemInfo.ordering];
}
if (!cidToUnicode)
if (!cidToUnicode) {
// the font is directly characters to glyphs with no encoding
// so create an identity encoding
for (i = 0; i < 0xD800; i++) {
var width = glyphsWidths[i];
encoding[i] = {
unicode: i,
width: isNum(width) ? width : defaultWidth
};
}
// skipping surrogates + 256-user defined
for (i = 0xE100; i <= 0xFFFF; i++) {
var width = glyphsWidths[i];
encoding[i] = {
unicode: i,
width: isNum(width) ? width : defaultWidth
};
}
return;
}
encoding[0] = { unicode: 0, width: 0 };
var glyph = 1, i, j, k;
for (i = 0; i < cidToUnicode.length; ++i) {
var unicode = cidToUnicode[i];
var width;
if (isArray(unicode)) {
if (glyph in glyphsWidths) {
var length = unicode.length;
for (j = 0; j < length; j++) {
k = unicode[j];
encoding[k] = {
unicode: k <= 0x1f || (k >= 127 && k <= 255) ?
k + kCmapGlyphOffset : k,
width: glyphsWidths[glyph]
};
}
var length = unicode.length;
width = glyphsWidths[glyph];
for (j = 0; j < length; j++) {
k = unicode[j];
encoding[k] = {
unicode: k,
width: isNum(width) ? width : defaultWidth
};
}
glyph++;
} else if (typeof unicode === 'object') {
@ -1445,24 +1453,20 @@ var Font = (function Font() {
if (fillLength) {
k = unicode.c;
for (j = 0; j < fillLength; ++j) {
if (!(glyph in glyphsWidths))
continue;
width = glyphsWidths[glyph++];
encoding[k] = {
unicode: k <= 0x1f || (k >= 127 && k <= 255) ?
k + kCmapGlyphOffset : k,
width: glyphsWidths[glyph]
unicode: k,
width: isNum(width) ? width : defaultWidth
};
k++;
glyph++;
}
} else
glyph += unicode.s;
} else if (unicode && (glyph in glyphsWidths)) {
k = unicode;
encoding[k] = {
unicode: k <= 0x1f || (k >= 127 && k <= 255) ?
k + kCmapGlyphOffset : k,
width: glyphsWidths[glyph++]
} else if (unicode) {
width = glyphsWidths[glyph++];
encoding[unicode] = {
unicode: unicode,
width: isNum(width) ? width : defaultWidth
};
} else
glyph++;