sharp 0.35.0-rc.3 → 0.35.0-rc.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/channel.cjs +177 -0
- package/dist/channel.mjs +177 -0
- package/dist/colour.cjs +195 -0
- package/dist/colour.mjs +195 -0
- package/dist/composite.cjs +212 -0
- package/dist/composite.mjs +212 -0
- package/dist/constructor.cjs +505 -0
- package/dist/constructor.mjs +505 -0
- package/dist/index.cjs +25 -0
- package/dist/index.mjs +25 -0
- package/dist/input.cjs +803 -0
- package/dist/input.mjs +803 -0
- package/dist/is.cjs +143 -0
- package/dist/is.mjs +143 -0
- package/dist/libvips.cjs +212 -0
- package/dist/libvips.mjs +212 -0
- package/dist/operation.cjs +987 -0
- package/dist/operation.mjs +987 -0
- package/dist/output.cjs +1799 -0
- package/dist/output.mjs +1799 -0
- package/dist/resize.cjs +611 -0
- package/dist/resize.mjs +611 -0
- package/dist/sharp.cjs +162 -0
- package/dist/sharp.mjs +164 -0
- package/dist/utility.cjs +293 -0
- package/dist/utility.mjs +295 -0
- package/package.json +17 -17
package/dist/channel.cjs
ADDED
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
Copyright 2013 Lovell Fuller and others.
|
|
3
|
+
SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
const is = require('./is.cjs');
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Boolean operations for bandbool.
|
|
10
|
+
* @private
|
|
11
|
+
*/
|
|
12
|
+
const bool = {
|
|
13
|
+
and: 'and',
|
|
14
|
+
or: 'or',
|
|
15
|
+
eor: 'eor'
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Remove alpha channels, if any. This is a no-op if the image does not have an alpha channel.
|
|
20
|
+
*
|
|
21
|
+
* See also {@link /api-operation/#flatten flatten}.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* sharp('rgba.png')
|
|
25
|
+
* .removeAlpha()
|
|
26
|
+
* .toFile('rgb.png', function(err, info) {
|
|
27
|
+
* // rgb.png is a 3 channel image without an alpha channel
|
|
28
|
+
* });
|
|
29
|
+
*
|
|
30
|
+
* @returns {Sharp}
|
|
31
|
+
*/
|
|
32
|
+
function removeAlpha () {
|
|
33
|
+
this.options.removeAlpha = true;
|
|
34
|
+
return this;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Ensure the output image has an alpha transparency channel.
|
|
39
|
+
* If missing, the added alpha channel will have the specified
|
|
40
|
+
* transparency level, defaulting to fully-opaque (1).
|
|
41
|
+
* This is a no-op if the image already has an alpha channel.
|
|
42
|
+
*
|
|
43
|
+
* @since 0.21.2
|
|
44
|
+
*
|
|
45
|
+
* @example
|
|
46
|
+
* // rgba.png will be a 4 channel image with a fully-opaque alpha channel
|
|
47
|
+
* await sharp('rgb.jpg')
|
|
48
|
+
* .ensureAlpha()
|
|
49
|
+
* .toFile('rgba.png')
|
|
50
|
+
*
|
|
51
|
+
* @example
|
|
52
|
+
* // rgba is a 4 channel image with a fully-transparent alpha channel
|
|
53
|
+
* const rgba = await sharp(rgb)
|
|
54
|
+
* .ensureAlpha(0)
|
|
55
|
+
* .toBuffer();
|
|
56
|
+
*
|
|
57
|
+
* @param {number} [alpha=1] - alpha transparency level (0=fully-transparent, 1=fully-opaque)
|
|
58
|
+
* @returns {Sharp}
|
|
59
|
+
* @throws {Error} Invalid alpha transparency level
|
|
60
|
+
*/
|
|
61
|
+
function ensureAlpha (alpha) {
|
|
62
|
+
if (is.defined(alpha)) {
|
|
63
|
+
if (is.number(alpha) && is.inRange(alpha, 0, 1)) {
|
|
64
|
+
this.options.ensureAlpha = alpha;
|
|
65
|
+
} else {
|
|
66
|
+
throw is.invalidParameterError('alpha', 'number between 0 and 1', alpha);
|
|
67
|
+
}
|
|
68
|
+
} else {
|
|
69
|
+
this.options.ensureAlpha = 1;
|
|
70
|
+
}
|
|
71
|
+
return this;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* Extract a single channel from a multi-channel image.
|
|
76
|
+
*
|
|
77
|
+
* The output colourspace will be either `b-w` (8-bit) or `grey16` (16-bit).
|
|
78
|
+
*
|
|
79
|
+
* @example
|
|
80
|
+
* // green.jpg is a greyscale image containing the green channel of the input
|
|
81
|
+
* await sharp(input)
|
|
82
|
+
* .extractChannel('green')
|
|
83
|
+
* .toFile('green.jpg');
|
|
84
|
+
*
|
|
85
|
+
* @example
|
|
86
|
+
* // red1 is the red value of the first pixel, red2 the second pixel etc.
|
|
87
|
+
* const [red1, red2, ...] = await sharp(input)
|
|
88
|
+
* .extractChannel(0)
|
|
89
|
+
* .raw()
|
|
90
|
+
* .toBuffer();
|
|
91
|
+
*
|
|
92
|
+
* @param {number|string} channel - zero-indexed channel/band number to extract, or `red`, `green`, `blue` or `alpha`.
|
|
93
|
+
* @returns {Sharp}
|
|
94
|
+
* @throws {Error} Invalid channel
|
|
95
|
+
*/
|
|
96
|
+
function extractChannel (channel) {
|
|
97
|
+
const channelMap = { red: 0, green: 1, blue: 2, alpha: 3 };
|
|
98
|
+
if (Object.keys(channelMap).includes(channel)) {
|
|
99
|
+
channel = channelMap[channel];
|
|
100
|
+
}
|
|
101
|
+
if (is.integer(channel) && is.inRange(channel, 0, 4)) {
|
|
102
|
+
this.options.extractChannel = channel;
|
|
103
|
+
} else {
|
|
104
|
+
throw is.invalidParameterError('channel', 'integer or one of: red, green, blue, alpha', channel);
|
|
105
|
+
}
|
|
106
|
+
return this;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
/**
|
|
110
|
+
* Join one or more channels to the image.
|
|
111
|
+
* The meaning of the added channels depends on the output colourspace, set with `toColourspace()`.
|
|
112
|
+
* By default the output image will be web-friendly sRGB, with additional channels interpreted as alpha channels.
|
|
113
|
+
* Channel ordering follows vips convention:
|
|
114
|
+
* - sRGB: 0: Red, 1: Green, 2: Blue, 3: Alpha.
|
|
115
|
+
* - CMYK: 0: Magenta, 1: Cyan, 2: Yellow, 3: Black, 4: Alpha.
|
|
116
|
+
*
|
|
117
|
+
* Buffers may be any of the image formats supported by sharp.
|
|
118
|
+
* For raw pixel input, the `options` object should contain a `raw` attribute, which follows the format of the attribute of the same name in the `sharp()` constructor.
|
|
119
|
+
*
|
|
120
|
+
* @param {Array<string|Buffer>|string|Buffer} images - one or more images (file paths, Buffers).
|
|
121
|
+
* @param {Object} options - image options, see `sharp()` constructor.
|
|
122
|
+
* @returns {Sharp}
|
|
123
|
+
* @throws {Error} Invalid parameters
|
|
124
|
+
*/
|
|
125
|
+
function joinChannel (images, options) {
|
|
126
|
+
if (Array.isArray(images)) {
|
|
127
|
+
images.forEach(function (image) {
|
|
128
|
+
this.options.joinChannelIn.push(this._createInputDescriptor(image, options));
|
|
129
|
+
}, this);
|
|
130
|
+
} else {
|
|
131
|
+
this.options.joinChannelIn.push(this._createInputDescriptor(images, options));
|
|
132
|
+
}
|
|
133
|
+
return this;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
/**
|
|
137
|
+
* Perform a bitwise boolean operation on all input image channels (bands) to produce a single channel output image.
|
|
138
|
+
*
|
|
139
|
+
* @example
|
|
140
|
+
* sharp('3-channel-rgb-input.png')
|
|
141
|
+
* .bandbool(sharp.bool.and)
|
|
142
|
+
* .toFile('1-channel-output.png', function (err, info) {
|
|
143
|
+
* // The output will be a single channel image where each pixel `P = R & G & B`.
|
|
144
|
+
* // If `I(1,1) = [247, 170, 14] = [0b11110111, 0b10101010, 0b00001111]`
|
|
145
|
+
* // then `O(1,1) = 0b11110111 & 0b10101010 & 0b00001111 = 0b00000010 = 2`.
|
|
146
|
+
* });
|
|
147
|
+
*
|
|
148
|
+
* @param {string} boolOp - one of `and`, `or` or `eor` to perform that bitwise operation, like the C logic operators `&`, `|` and `^` respectively.
|
|
149
|
+
* @returns {Sharp}
|
|
150
|
+
* @throws {Error} Invalid parameters
|
|
151
|
+
*/
|
|
152
|
+
function bandbool (boolOp) {
|
|
153
|
+
if (is.string(boolOp) && is.inArray(boolOp, ['and', 'or', 'eor'])) {
|
|
154
|
+
this.options.bandBoolOp = boolOp;
|
|
155
|
+
} else {
|
|
156
|
+
throw is.invalidParameterError('boolOp', 'one of: and, or, eor', boolOp);
|
|
157
|
+
}
|
|
158
|
+
return this;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/**
|
|
162
|
+
* Decorate the Sharp prototype with channel-related functions.
|
|
163
|
+
* @module Sharp
|
|
164
|
+
* @private
|
|
165
|
+
*/
|
|
166
|
+
module.exports = (Sharp) => {
|
|
167
|
+
Object.assign(Sharp.prototype, {
|
|
168
|
+
// Public instance functions
|
|
169
|
+
removeAlpha,
|
|
170
|
+
ensureAlpha,
|
|
171
|
+
extractChannel,
|
|
172
|
+
joinChannel,
|
|
173
|
+
bandbool
|
|
174
|
+
});
|
|
175
|
+
// Class attributes
|
|
176
|
+
Sharp.bool = bool;
|
|
177
|
+
};
|
package/dist/channel.mjs
ADDED
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
Copyright 2013 Lovell Fuller and others.
|
|
3
|
+
SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import is from './is.mjs';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Boolean operations for bandbool.
|
|
10
|
+
* @private
|
|
11
|
+
*/
|
|
12
|
+
const bool = {
|
|
13
|
+
and: 'and',
|
|
14
|
+
or: 'or',
|
|
15
|
+
eor: 'eor'
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Remove alpha channels, if any. This is a no-op if the image does not have an alpha channel.
|
|
20
|
+
*
|
|
21
|
+
* See also {@link /api-operation/#flatten flatten}.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* sharp('rgba.png')
|
|
25
|
+
* .removeAlpha()
|
|
26
|
+
* .toFile('rgb.png', function(err, info) {
|
|
27
|
+
* // rgb.png is a 3 channel image without an alpha channel
|
|
28
|
+
* });
|
|
29
|
+
*
|
|
30
|
+
* @returns {Sharp}
|
|
31
|
+
*/
|
|
32
|
+
function removeAlpha () {
|
|
33
|
+
this.options.removeAlpha = true;
|
|
34
|
+
return this;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Ensure the output image has an alpha transparency channel.
|
|
39
|
+
* If missing, the added alpha channel will have the specified
|
|
40
|
+
* transparency level, defaulting to fully-opaque (1).
|
|
41
|
+
* This is a no-op if the image already has an alpha channel.
|
|
42
|
+
*
|
|
43
|
+
* @since 0.21.2
|
|
44
|
+
*
|
|
45
|
+
* @example
|
|
46
|
+
* // rgba.png will be a 4 channel image with a fully-opaque alpha channel
|
|
47
|
+
* await sharp('rgb.jpg')
|
|
48
|
+
* .ensureAlpha()
|
|
49
|
+
* .toFile('rgba.png')
|
|
50
|
+
*
|
|
51
|
+
* @example
|
|
52
|
+
* // rgba is a 4 channel image with a fully-transparent alpha channel
|
|
53
|
+
* const rgba = await sharp(rgb)
|
|
54
|
+
* .ensureAlpha(0)
|
|
55
|
+
* .toBuffer();
|
|
56
|
+
*
|
|
57
|
+
* @param {number} [alpha=1] - alpha transparency level (0=fully-transparent, 1=fully-opaque)
|
|
58
|
+
* @returns {Sharp}
|
|
59
|
+
* @throws {Error} Invalid alpha transparency level
|
|
60
|
+
*/
|
|
61
|
+
function ensureAlpha (alpha) {
|
|
62
|
+
if (is.defined(alpha)) {
|
|
63
|
+
if (is.number(alpha) && is.inRange(alpha, 0, 1)) {
|
|
64
|
+
this.options.ensureAlpha = alpha;
|
|
65
|
+
} else {
|
|
66
|
+
throw is.invalidParameterError('alpha', 'number between 0 and 1', alpha);
|
|
67
|
+
}
|
|
68
|
+
} else {
|
|
69
|
+
this.options.ensureAlpha = 1;
|
|
70
|
+
}
|
|
71
|
+
return this;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* Extract a single channel from a multi-channel image.
|
|
76
|
+
*
|
|
77
|
+
* The output colourspace will be either `b-w` (8-bit) or `grey16` (16-bit).
|
|
78
|
+
*
|
|
79
|
+
* @example
|
|
80
|
+
* // green.jpg is a greyscale image containing the green channel of the input
|
|
81
|
+
* await sharp(input)
|
|
82
|
+
* .extractChannel('green')
|
|
83
|
+
* .toFile('green.jpg');
|
|
84
|
+
*
|
|
85
|
+
* @example
|
|
86
|
+
* // red1 is the red value of the first pixel, red2 the second pixel etc.
|
|
87
|
+
* const [red1, red2, ...] = await sharp(input)
|
|
88
|
+
* .extractChannel(0)
|
|
89
|
+
* .raw()
|
|
90
|
+
* .toBuffer();
|
|
91
|
+
*
|
|
92
|
+
* @param {number|string} channel - zero-indexed channel/band number to extract, or `red`, `green`, `blue` or `alpha`.
|
|
93
|
+
* @returns {Sharp}
|
|
94
|
+
* @throws {Error} Invalid channel
|
|
95
|
+
*/
|
|
96
|
+
function extractChannel (channel) {
|
|
97
|
+
const channelMap = { red: 0, green: 1, blue: 2, alpha: 3 };
|
|
98
|
+
if (Object.keys(channelMap).includes(channel)) {
|
|
99
|
+
channel = channelMap[channel];
|
|
100
|
+
}
|
|
101
|
+
if (is.integer(channel) && is.inRange(channel, 0, 4)) {
|
|
102
|
+
this.options.extractChannel = channel;
|
|
103
|
+
} else {
|
|
104
|
+
throw is.invalidParameterError('channel', 'integer or one of: red, green, blue, alpha', channel);
|
|
105
|
+
}
|
|
106
|
+
return this;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
/**
|
|
110
|
+
* Join one or more channels to the image.
|
|
111
|
+
* The meaning of the added channels depends on the output colourspace, set with `toColourspace()`.
|
|
112
|
+
* By default the output image will be web-friendly sRGB, with additional channels interpreted as alpha channels.
|
|
113
|
+
* Channel ordering follows vips convention:
|
|
114
|
+
* - sRGB: 0: Red, 1: Green, 2: Blue, 3: Alpha.
|
|
115
|
+
* - CMYK: 0: Magenta, 1: Cyan, 2: Yellow, 3: Black, 4: Alpha.
|
|
116
|
+
*
|
|
117
|
+
* Buffers may be any of the image formats supported by sharp.
|
|
118
|
+
* For raw pixel input, the `options` object should contain a `raw` attribute, which follows the format of the attribute of the same name in the `sharp()` constructor.
|
|
119
|
+
*
|
|
120
|
+
* @param {Array<string|Buffer>|string|Buffer} images - one or more images (file paths, Buffers).
|
|
121
|
+
* @param {Object} options - image options, see `sharp()` constructor.
|
|
122
|
+
* @returns {Sharp}
|
|
123
|
+
* @throws {Error} Invalid parameters
|
|
124
|
+
*/
|
|
125
|
+
function joinChannel (images, options) {
|
|
126
|
+
if (Array.isArray(images)) {
|
|
127
|
+
images.forEach(function (image) {
|
|
128
|
+
this.options.joinChannelIn.push(this._createInputDescriptor(image, options));
|
|
129
|
+
}, this);
|
|
130
|
+
} else {
|
|
131
|
+
this.options.joinChannelIn.push(this._createInputDescriptor(images, options));
|
|
132
|
+
}
|
|
133
|
+
return this;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
/**
|
|
137
|
+
* Perform a bitwise boolean operation on all input image channels (bands) to produce a single channel output image.
|
|
138
|
+
*
|
|
139
|
+
* @example
|
|
140
|
+
* sharp('3-channel-rgb-input.png')
|
|
141
|
+
* .bandbool(sharp.bool.and)
|
|
142
|
+
* .toFile('1-channel-output.png', function (err, info) {
|
|
143
|
+
* // The output will be a single channel image where each pixel `P = R & G & B`.
|
|
144
|
+
* // If `I(1,1) = [247, 170, 14] = [0b11110111, 0b10101010, 0b00001111]`
|
|
145
|
+
* // then `O(1,1) = 0b11110111 & 0b10101010 & 0b00001111 = 0b00000010 = 2`.
|
|
146
|
+
* });
|
|
147
|
+
*
|
|
148
|
+
* @param {string} boolOp - one of `and`, `or` or `eor` to perform that bitwise operation, like the C logic operators `&`, `|` and `^` respectively.
|
|
149
|
+
* @returns {Sharp}
|
|
150
|
+
* @throws {Error} Invalid parameters
|
|
151
|
+
*/
|
|
152
|
+
function bandbool (boolOp) {
|
|
153
|
+
if (is.string(boolOp) && is.inArray(boolOp, ['and', 'or', 'eor'])) {
|
|
154
|
+
this.options.bandBoolOp = boolOp;
|
|
155
|
+
} else {
|
|
156
|
+
throw is.invalidParameterError('boolOp', 'one of: and, or, eor', boolOp);
|
|
157
|
+
}
|
|
158
|
+
return this;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/**
|
|
162
|
+
* Decorate the Sharp prototype with channel-related functions.
|
|
163
|
+
* @module Sharp
|
|
164
|
+
* @private
|
|
165
|
+
*/
|
|
166
|
+
export default (Sharp) => {
|
|
167
|
+
Object.assign(Sharp.prototype, {
|
|
168
|
+
// Public instance functions
|
|
169
|
+
removeAlpha,
|
|
170
|
+
ensureAlpha,
|
|
171
|
+
extractChannel,
|
|
172
|
+
joinChannel,
|
|
173
|
+
bandbool
|
|
174
|
+
});
|
|
175
|
+
// Class attributes
|
|
176
|
+
Sharp.bool = bool;
|
|
177
|
+
};
|
package/dist/colour.cjs
ADDED
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
Copyright 2013 Lovell Fuller and others.
|
|
3
|
+
SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
const color = require('@img/colour');
|
|
7
|
+
const is = require('./is.cjs');
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Colourspaces.
|
|
11
|
+
* @private
|
|
12
|
+
*/
|
|
13
|
+
const colourspace = {
|
|
14
|
+
multiband: 'multiband',
|
|
15
|
+
'b-w': 'b-w',
|
|
16
|
+
bw: 'b-w',
|
|
17
|
+
cmyk: 'cmyk',
|
|
18
|
+
srgb: 'srgb'
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Tint the image using the provided colour.
|
|
23
|
+
* An alpha channel may be present and will be unchanged by the operation.
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* const output = await sharp(input)
|
|
27
|
+
* .tint({ r: 255, g: 240, b: 16 })
|
|
28
|
+
* .toBuffer();
|
|
29
|
+
*
|
|
30
|
+
* @param {string|Object} tint - Parsed by the [color](https://www.npmjs.org/package/color) module.
|
|
31
|
+
* @returns {Sharp}
|
|
32
|
+
* @throws {Error} Invalid parameter
|
|
33
|
+
*/
|
|
34
|
+
function tint (tint) {
|
|
35
|
+
this._setBackgroundColourOption('tint', tint);
|
|
36
|
+
return this;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Convert to 8-bit greyscale; 256 shades of grey.
|
|
41
|
+
* This is a linear operation. If the input image is in a non-linear colour space such as sRGB, use `gamma()` with `greyscale()` for the best results.
|
|
42
|
+
* By default the output image will be web-friendly sRGB and contain three (identical) colour channels.
|
|
43
|
+
* This may be overridden by other sharp operations such as `toColourspace('b-w')`,
|
|
44
|
+
* which will produce an output image containing one colour channel.
|
|
45
|
+
* An alpha channel may be present, and will be unchanged by the operation.
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* const output = await sharp(input).greyscale().toBuffer();
|
|
49
|
+
*
|
|
50
|
+
* @param {Boolean} [greyscale=true]
|
|
51
|
+
* @returns {Sharp}
|
|
52
|
+
*/
|
|
53
|
+
function greyscale (greyscale) {
|
|
54
|
+
this.options.greyscale = is.bool(greyscale) ? greyscale : true;
|
|
55
|
+
return this;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Alternative spelling of `greyscale`.
|
|
60
|
+
* @param {Boolean} [grayscale=true]
|
|
61
|
+
* @returns {Sharp}
|
|
62
|
+
*/
|
|
63
|
+
function grayscale (grayscale) {
|
|
64
|
+
return this.greyscale(grayscale);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Set the pipeline colourspace.
|
|
69
|
+
*
|
|
70
|
+
* The input image will be converted to the provided colourspace at the start of the pipeline.
|
|
71
|
+
* All operations will use this colourspace before converting to the output colourspace,
|
|
72
|
+
* as defined by {@link #tocolourspace toColourspace}.
|
|
73
|
+
*
|
|
74
|
+
* @since 0.29.0
|
|
75
|
+
*
|
|
76
|
+
* @example
|
|
77
|
+
* // Run pipeline in 16 bits per channel RGB while converting final result to 8 bits per channel sRGB.
|
|
78
|
+
* await sharp(input)
|
|
79
|
+
* .pipelineColourspace('rgb16')
|
|
80
|
+
* .toColourspace('srgb')
|
|
81
|
+
* .toFile('16bpc-pipeline-to-8bpc-output.png')
|
|
82
|
+
*
|
|
83
|
+
* @param {string} [colourspace] - pipeline colourspace e.g. `rgb16`, `scrgb`, `lab`, `grey16` [...](https://www.libvips.org/API/current/enum.Interpretation.html)
|
|
84
|
+
* @returns {Sharp}
|
|
85
|
+
* @throws {Error} Invalid parameters
|
|
86
|
+
*/
|
|
87
|
+
function pipelineColourspace (colourspace) {
|
|
88
|
+
if (!is.string(colourspace)) {
|
|
89
|
+
throw is.invalidParameterError('colourspace', 'string', colourspace);
|
|
90
|
+
}
|
|
91
|
+
this.options.colourspacePipeline = colourspace;
|
|
92
|
+
return this;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Alternative spelling of `pipelineColourspace`.
|
|
97
|
+
* @param {string} [colorspace] - pipeline colorspace.
|
|
98
|
+
* @returns {Sharp}
|
|
99
|
+
* @throws {Error} Invalid parameters
|
|
100
|
+
*/
|
|
101
|
+
function pipelineColorspace (colorspace) {
|
|
102
|
+
return this.pipelineColourspace(colorspace);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Set the output colourspace.
|
|
107
|
+
* By default output image will be web-friendly sRGB, with additional channels interpreted as alpha channels.
|
|
108
|
+
*
|
|
109
|
+
* @example
|
|
110
|
+
* // Output 16 bits per pixel RGB
|
|
111
|
+
* await sharp(input)
|
|
112
|
+
* .toColourspace('rgb16')
|
|
113
|
+
* .toFile('16-bpp.png')
|
|
114
|
+
*
|
|
115
|
+
* @param {string} [colourspace] - output colourspace e.g. `srgb`, `rgb`, `cmyk`, `lab`, `b-w` [...](https://www.libvips.org/API/current/enum.Interpretation.html)
|
|
116
|
+
* @returns {Sharp}
|
|
117
|
+
* @throws {Error} Invalid parameters
|
|
118
|
+
*/
|
|
119
|
+
function toColourspace (colourspace) {
|
|
120
|
+
if (!is.string(colourspace)) {
|
|
121
|
+
throw is.invalidParameterError('colourspace', 'string', colourspace);
|
|
122
|
+
}
|
|
123
|
+
this.options.colourspace = colourspace;
|
|
124
|
+
return this;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
/**
|
|
128
|
+
* Alternative spelling of `toColourspace`.
|
|
129
|
+
* @param {string} [colorspace] - output colorspace.
|
|
130
|
+
* @returns {Sharp}
|
|
131
|
+
* @throws {Error} Invalid parameters
|
|
132
|
+
*/
|
|
133
|
+
function toColorspace (colorspace) {
|
|
134
|
+
return this.toColourspace(colorspace);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Create a RGBA colour array from a given value.
|
|
139
|
+
* @private
|
|
140
|
+
* @param {string|Object} value
|
|
141
|
+
* @throws {Error} Invalid value
|
|
142
|
+
*/
|
|
143
|
+
function _getBackgroundColourOption (value) {
|
|
144
|
+
if (
|
|
145
|
+
is.object(value) ||
|
|
146
|
+
(is.string(value) && value.length >= 3 && value.length <= 200)
|
|
147
|
+
) {
|
|
148
|
+
const colour = color(value);
|
|
149
|
+
return [
|
|
150
|
+
colour.red(),
|
|
151
|
+
colour.green(),
|
|
152
|
+
colour.blue(),
|
|
153
|
+
Math.round(colour.alpha() * 255)
|
|
154
|
+
];
|
|
155
|
+
} else {
|
|
156
|
+
throw is.invalidParameterError('background', 'object or string', value);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
/**
|
|
161
|
+
* Update a colour attribute of the this.options Object.
|
|
162
|
+
* @private
|
|
163
|
+
* @param {string} key
|
|
164
|
+
* @param {string|Object} value
|
|
165
|
+
* @throws {Error} Invalid value
|
|
166
|
+
*/
|
|
167
|
+
function _setBackgroundColourOption (key, value) {
|
|
168
|
+
if (is.defined(value)) {
|
|
169
|
+
this.options[key] = _getBackgroundColourOption(value);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
/**
|
|
174
|
+
* Decorate the Sharp prototype with colour-related functions.
|
|
175
|
+
* @module Sharp
|
|
176
|
+
* @private
|
|
177
|
+
*/
|
|
178
|
+
module.exports = (Sharp) => {
|
|
179
|
+
Object.assign(Sharp.prototype, {
|
|
180
|
+
// Public
|
|
181
|
+
tint,
|
|
182
|
+
greyscale,
|
|
183
|
+
grayscale,
|
|
184
|
+
pipelineColourspace,
|
|
185
|
+
pipelineColorspace,
|
|
186
|
+
toColourspace,
|
|
187
|
+
toColorspace,
|
|
188
|
+
// Private
|
|
189
|
+
_getBackgroundColourOption,
|
|
190
|
+
_setBackgroundColourOption
|
|
191
|
+
});
|
|
192
|
+
// Class attributes
|
|
193
|
+
Sharp.colourspace = colourspace;
|
|
194
|
+
Sharp.colorspace = colourspace;
|
|
195
|
+
};
|