fbf6dee8ee
As it turns out, most of the code-paths in the `PDFImage`-class won't actually pass the TypedArray (containing the image-data) to the `ColorSpace`-code. Hence we *generally* don't need to force the image-data to be a `Uint8ClampedArray`, and can just as well directly use a `Uint8Array` instead. In the following cases we're returning the data without any `ColorSpace`-parsing, and the exact TypedArray used shouldn't matter: -b72a448327/src/core/image.js (L714)
-b72a448327/src/core/image.js (L751)
In the following cases the image-data is only used *internally*, and again the exact TypedArray used shouldn't matter: -b72a448327/src/core/image.js (L762)
with the actual image-data being defined (as `Uint8ClampedArray`) further below -b72a448327/src/core/image.js (L837)
*Please note:* This is tagged `api-minor` because it's API-observable, given that *some* image/mask-data will now be returned as `Uint8Array` rather than using `Uint8ClampedArray` unconditionally. However, that seems like a small price to pay to (slightly) reduce memory usage during image-conversion.
100 lines
2.1 KiB
JavaScript
100 lines
2.1 KiB
JavaScript
/* Copyright 2012 Mozilla Foundation
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import { BaseStream } from "./base_stream.js";
|
|
import { stringToBytes } from "../shared/util.js";
|
|
|
|
class Stream extends BaseStream {
|
|
constructor(arrayBuffer, start, length, dict) {
|
|
super();
|
|
|
|
this.bytes =
|
|
arrayBuffer instanceof Uint8Array
|
|
? arrayBuffer
|
|
: new Uint8Array(arrayBuffer);
|
|
this.start = start || 0;
|
|
this.pos = this.start;
|
|
this.end = start + length || this.bytes.length;
|
|
this.dict = dict;
|
|
}
|
|
|
|
get length() {
|
|
return this.end - this.start;
|
|
}
|
|
|
|
get isEmpty() {
|
|
return this.length === 0;
|
|
}
|
|
|
|
getByte() {
|
|
if (this.pos >= this.end) {
|
|
return -1;
|
|
}
|
|
return this.bytes[this.pos++];
|
|
}
|
|
|
|
getBytes(length) {
|
|
const bytes = this.bytes;
|
|
const pos = this.pos;
|
|
const strEnd = this.end;
|
|
|
|
if (!length) {
|
|
return bytes.subarray(pos, strEnd);
|
|
}
|
|
let end = pos + length;
|
|
if (end > strEnd) {
|
|
end = strEnd;
|
|
}
|
|
this.pos = end;
|
|
return bytes.subarray(pos, end);
|
|
}
|
|
|
|
getByteRange(begin, end) {
|
|
if (begin < 0) {
|
|
begin = 0;
|
|
}
|
|
if (end > this.end) {
|
|
end = this.end;
|
|
}
|
|
return this.bytes.subarray(begin, end);
|
|
}
|
|
|
|
reset() {
|
|
this.pos = this.start;
|
|
}
|
|
|
|
moveStart() {
|
|
this.start = this.pos;
|
|
}
|
|
|
|
makeSubStream(start, length, dict = null) {
|
|
return new Stream(this.bytes.buffer, start, length, dict);
|
|
}
|
|
}
|
|
|
|
class StringStream extends Stream {
|
|
constructor(str) {
|
|
super(stringToBytes(str));
|
|
}
|
|
}
|
|
|
|
class NullStream extends Stream {
|
|
constructor() {
|
|
super(new Uint8Array(0));
|
|
}
|
|
}
|
|
|
|
export { NullStream, Stream, StringStream };
|