Merge pull request #7863 from timvandermeij/colorspace
Colorspace: refactoring to prevent unnecessary creation of intermediate arrays
This commit is contained in:
commit
94ddd8f61d
@ -294,13 +294,8 @@ var ColorSpace = (function ColorSpaceClosure() {
|
||||
}
|
||||
|
||||
cs = xref.fetchIfRef(cs);
|
||||
var mode;
|
||||
|
||||
if (isName(cs)) {
|
||||
mode = cs.name;
|
||||
this.mode = mode;
|
||||
|
||||
switch (mode) {
|
||||
switch (cs.name) {
|
||||
case 'DeviceGray':
|
||||
case 'G':
|
||||
return 'DeviceGrayCS';
|
||||
@ -313,11 +308,10 @@ var ColorSpace = (function ColorSpaceClosure() {
|
||||
case 'Pattern':
|
||||
return ['PatternCS', null];
|
||||
default:
|
||||
error('unrecognized colorspace ' + mode);
|
||||
error('unrecognized colorspace ' + cs.name);
|
||||
}
|
||||
} else if (isArray(cs)) {
|
||||
mode = xref.fetchIfRef(cs[0]).name;
|
||||
this.mode = mode;
|
||||
var mode = xref.fetchIfRef(cs[0]).name;
|
||||
var numComps, params, alt, whitePoint, blackPoint, gamma;
|
||||
|
||||
switch (mode) {
|
||||
@ -384,12 +378,7 @@ var ColorSpace = (function ColorSpaceClosure() {
|
||||
case 'Separation':
|
||||
case 'DeviceN':
|
||||
var name = xref.fetchIfRef(cs[1]);
|
||||
numComps = 1;
|
||||
if (isName(name)) {
|
||||
numComps = 1;
|
||||
} else if (isArray(name)) {
|
||||
numComps = name.length;
|
||||
}
|
||||
numComps = isArray(name) ? name.length : 1;
|
||||
alt = ColorSpace.parseToIR(cs[2], xref, res);
|
||||
var tintFnIR = PDFFunction.getIR(xref, xref.fetchIfRef(cs[3]));
|
||||
return ['AlternateCS', numComps, alt, tintFnIR];
|
||||
@ -492,26 +481,22 @@ var AlternateCS = (function AlternateCSClosure() {
|
||||
var scaled = new Float32Array(numComps);
|
||||
var tinted = new Float32Array(baseNumComps);
|
||||
var i, j;
|
||||
if (usesZeroToOneRange) {
|
||||
|
||||
for (i = 0; i < count; i++) {
|
||||
for (j = 0; j < numComps; j++) {
|
||||
scaled[j] = src[srcOffset++] * scale;
|
||||
}
|
||||
tintFn(scaled, 0, tinted, 0);
|
||||
if (usesZeroToOneRange) {
|
||||
for (j = 0; j < baseNumComps; j++) {
|
||||
baseBuf[pos++] = tinted[j] * 255;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
for (i = 0; i < count; i++) {
|
||||
for (j = 0; j < numComps; j++) {
|
||||
scaled[j] = src[srcOffset++] * scale;
|
||||
}
|
||||
tintFn(scaled, 0, tinted, 0);
|
||||
base.getRgbItem(tinted, 0, baseBuf, pos);
|
||||
pos += baseNumComps;
|
||||
}
|
||||
}
|
||||
|
||||
if (!isPassthrough) {
|
||||
base.getRgbBuffer(baseBuf, 0, count, dest, destOffset, 8, alpha01);
|
||||
}
|
||||
@ -547,29 +532,27 @@ var IndexedCS = (function IndexedCSClosure() {
|
||||
function IndexedCS(base, highVal, lookup) {
|
||||
this.name = 'Indexed';
|
||||
this.numComps = 1;
|
||||
this.defaultColor = new Uint8Array([0]);
|
||||
this.defaultColor = new Uint8Array(this.numComps);
|
||||
this.base = base;
|
||||
this.highVal = highVal;
|
||||
|
||||
var baseNumComps = base.numComps;
|
||||
var length = baseNumComps * highVal;
|
||||
var lookupArray;
|
||||
|
||||
if (isStream(lookup)) {
|
||||
lookupArray = new Uint8Array(length);
|
||||
this.lookup = new Uint8Array(length);
|
||||
var bytes = lookup.getBytes(length);
|
||||
lookupArray.set(bytes);
|
||||
this.lookup.set(bytes);
|
||||
} else if (isString(lookup)) {
|
||||
lookupArray = new Uint8Array(length);
|
||||
this.lookup = new Uint8Array(length);
|
||||
for (var i = 0; i < length; ++i) {
|
||||
lookupArray[i] = lookup.charCodeAt(i);
|
||||
this.lookup[i] = lookup.charCodeAt(i);
|
||||
}
|
||||
} else if (lookup instanceof Uint8Array || lookup instanceof Array) {
|
||||
lookupArray = lookup;
|
||||
this.lookup = lookup;
|
||||
} else {
|
||||
error('Unrecognized lookup table: ' + lookup);
|
||||
}
|
||||
this.lookup = lookupArray;
|
||||
}
|
||||
|
||||
IndexedCS.prototype = {
|
||||
@ -613,7 +596,7 @@ var DeviceGrayCS = (function DeviceGrayCSClosure() {
|
||||
function DeviceGrayCS() {
|
||||
this.name = 'DeviceGray';
|
||||
this.numComps = 1;
|
||||
this.defaultColor = new Float32Array([0]);
|
||||
this.defaultColor = new Float32Array(this.numComps);
|
||||
}
|
||||
|
||||
DeviceGrayCS.prototype = {
|
||||
@ -655,7 +638,7 @@ var DeviceRgbCS = (function DeviceRgbCSClosure() {
|
||||
function DeviceRgbCS() {
|
||||
this.name = 'DeviceRGB';
|
||||
this.numComps = 3;
|
||||
this.defaultColor = new Float32Array([0, 0, 0]);
|
||||
this.defaultColor = new Float32Array(this.numComps);
|
||||
}
|
||||
DeviceRgbCS.prototype = {
|
||||
getRgb: ColorSpace.prototype.getRgb,
|
||||
@ -748,7 +731,9 @@ var DeviceCmykCS = (function DeviceCmykCSClosure() {
|
||||
function DeviceCmykCS() {
|
||||
this.name = 'DeviceCMYK';
|
||||
this.numComps = 4;
|
||||
this.defaultColor = new Float32Array([0, 0, 0, 1]);
|
||||
this.defaultColor = new Float32Array(this.numComps);
|
||||
// Set the fourth component to the maximum value for a black color.
|
||||
this.defaultColor[3] = 1;
|
||||
}
|
||||
DeviceCmykCS.prototype = {
|
||||
getRgb: ColorSpace.prototype.getRgb,
|
||||
@ -788,7 +773,7 @@ var CalGrayCS = (function CalGrayCSClosure() {
|
||||
function CalGrayCS(whitePoint, blackPoint, gamma) {
|
||||
this.name = 'CalGray';
|
||||
this.numComps = 1;
|
||||
this.defaultColor = new Float32Array([0]);
|
||||
this.defaultColor = new Float32Array(this.numComps);
|
||||
|
||||
if (!whitePoint) {
|
||||
error('WhitePoint missing - required for color space CalGray');
|
||||
@ -911,7 +896,7 @@ var CalRGBCS = (function CalRGBCSClosure() {
|
||||
function CalRGBCS(whitePoint, blackPoint, gamma, matrix) {
|
||||
this.name = 'CalRGB';
|
||||
this.numComps = 3;
|
||||
this.defaultColor = new Float32Array(3);
|
||||
this.defaultColor = new Float32Array(this.numComps);
|
||||
|
||||
if (!whitePoint) {
|
||||
error('WhitePoint missing - required for color space CalRGB');
|
||||
@ -1187,7 +1172,7 @@ var LabCS = (function LabCSClosure() {
|
||||
function LabCS(whitePoint, blackPoint, range) {
|
||||
this.name = 'Lab';
|
||||
this.numComps = 3;
|
||||
this.defaultColor = new Float32Array([0, 0, 0]);
|
||||
this.defaultColor = new Float32Array(this.numComps);
|
||||
|
||||
if (!whitePoint) {
|
||||
error('WhitePoint missing - required for color space Lab');
|
||||
|
Loading…
Reference in New Issue
Block a user