Add a direct translation to one of the way to format charstring number in flattenCharstring (28, x, y)
This commit is contained in:
parent
01847a0e29
commit
89c9bc39de
26
PDFFont.js
26
PDFFont.js
@ -1173,24 +1173,13 @@ CFF.prototype = {
|
||||
return data;
|
||||
},
|
||||
|
||||
encodeNumber: function(aValue, aIsCharstring) {
|
||||
encodeNumber: function(aValue) {
|
||||
var x = 0;
|
||||
if (aIsCharstring && aValue >= -107 && aValue <= 107) {
|
||||
return [aValue + 139];
|
||||
} else if (aValue >= -32768 && aValue <= 32767) {
|
||||
return [
|
||||
28,
|
||||
FontsUtils.integerToBytes(aValue >> 8, 1),
|
||||
FontsUtils.integerToBytes(aValue, 1)
|
||||
];
|
||||
if (aValue >= -32768 && aValue <= 32767) {
|
||||
return [ 28, aValue >> 8, aValue ];
|
||||
} else if (aValue >= (-2147483647-1) && aValue <= 2147483647) {
|
||||
return [
|
||||
0xFF,
|
||||
FontsUtils.integerToBytes(aValue >> 24, 1),
|
||||
FontsUtils.integerToBytes(aValue >> 16, 1),
|
||||
FontsUtils.integerToBytes(aValue >> 8, 1),
|
||||
FontsUtils.integerToBytes(aValue, 1)
|
||||
];
|
||||
0xFF, aValue >> 24, Value >> 16, aValue >> 8, aValue ];
|
||||
} else {
|
||||
error("Value: " + aValue + " is not allowed");
|
||||
}
|
||||
@ -1310,11 +1299,8 @@ CFF.prototype = {
|
||||
for (var j = 0; j < aCharstring.length; j++) {
|
||||
var command = aCharstring[j];
|
||||
if (parseFloat(command) == command) {
|
||||
var number = this.encodeNumber(command, true);
|
||||
aCharstring.splice(j, 1);
|
||||
for (var k = 0; k < number.length; k++)
|
||||
aCharstring.splice(j + k, 0, number[k]);
|
||||
j+= number.length - 1;
|
||||
aCharstring.splice(j, 1, 28, command >> 8, command);
|
||||
j+= 2;
|
||||
} else if (command.charAt) {
|
||||
var command = this.commandsMap[command];
|
||||
if (IsArray(command)) {
|
||||
|
Loading…
Reference in New Issue
Block a user