yeet
This commit is contained in:
23
node_modules/@jimp/plugin-rotate/CHANGELOG.md
generated
vendored
Normal file
23
node_modules/@jimp/plugin-rotate/CHANGELOG.md
generated
vendored
Normal file
@ -0,0 +1,23 @@
|
||||
# v0.11.0 (Fri May 15 2020)
|
||||
|
||||
#### 🚀 Enhancement
|
||||
|
||||
- Removed Core-JS as a dependency. [#882](https://github.com/oliver-moran/jimp/pull/882) ([@EricRabil](https://github.com/EricRabil))
|
||||
|
||||
#### Authors: 1
|
||||
|
||||
- Eric Rabil ([@EricRabil](https://github.com/EricRabil))
|
||||
|
||||
---
|
||||
|
||||
# v0.9.3 (Tue Nov 26 2019)
|
||||
|
||||
#### 🐛 Bug Fix
|
||||
|
||||
- `@jimp/cli`, `@jimp/core`, `@jimp/custom`, `jimp`, `@jimp/plugin-blit`, `@jimp/plugin-blur`, `@jimp/plugin-circle`, `@jimp/plugin-color`, `@jimp/plugin-contain`, `@jimp/plugin-cover`, `@jimp/plugin-crop`, `@jimp/plugin-displace`, `@jimp/plugin-dither`, `@jimp/plugin-fisheye`, `@jimp/plugin-flip`, `@jimp/plugin-gaussian`, `@jimp/plugin-invert`, `@jimp/plugin-mask`, `@jimp/plugin-normalize`, `@jimp/plugin-print`, `@jimp/plugin-resize`, `@jimp/plugin-rotate`, `@jimp/plugin-scale`, `@jimp/plugin-shadow`, `@jimp/plugin-threshold`, `@jimp/plugins`, `@jimp/test-utils`, `@jimp/bmp`, `@jimp/gif`, `@jimp/jpeg`, `@jimp/png`, `@jimp/tiff`, `@jimp/types`, `@jimp/utils`
|
||||
- Fix regeneratorRuntime errors [#815](https://github.com/oliver-moran/jimp/pull/815) ([@crutchcorn](https://github.com/crutchcorn) [@hipstersmoothie](https://github.com/hipstersmoothie))
|
||||
|
||||
#### Authors: 2
|
||||
|
||||
- Andrew Lisowski ([@hipstersmoothie](https://github.com/hipstersmoothie))
|
||||
- Corbin Crutchley ([@crutchcorn](https://github.com/crutchcorn))
|
21
node_modules/@jimp/plugin-rotate/LICENSE
generated
vendored
Normal file
21
node_modules/@jimp/plugin-rotate/LICENSE
generated
vendored
Normal file
@ -0,0 +1,21 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) 2018 Oliver Moran
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
26
node_modules/@jimp/plugin-rotate/README.md
generated
vendored
Normal file
26
node_modules/@jimp/plugin-rotate/README.md
generated
vendored
Normal file
@ -0,0 +1,26 @@
|
||||
<div align="center">
|
||||
<img width="200" height="200"
|
||||
src="https://s3.amazonaws.com/pix.iemoji.com/images/emoji/apple/ios-11/256/crayon.png">
|
||||
<h1>@jimp/plugin-rotate</h1>
|
||||
<p>Rotate an image.</p>
|
||||
</div>
|
||||
|
||||
Rotates the image clockwise by a number of degrees. By default the width and height of the image will be resized appropriately.
|
||||
|
||||
## Usage
|
||||
|
||||
- @param {number} deg the number of degrees to rotate the image by
|
||||
- @param {string|boolean} mode (optional) resize mode or a boolean, if false then the width and height of the image will not be changed
|
||||
- @param {function(Error, Jimp)} cb (optional) a callback for when complete
|
||||
|
||||
```js
|
||||
import jimp from 'jimp';
|
||||
|
||||
async function main() {
|
||||
const image = await jimp.read('test/image.png');
|
||||
|
||||
image.rotate(90);
|
||||
}
|
||||
|
||||
main();
|
||||
```
|
139
node_modules/@jimp/plugin-rotate/dist/index.js
generated
vendored
Normal file
139
node_modules/@jimp/plugin-rotate/dist/index.js
generated
vendored
Normal file
@ -0,0 +1,139 @@
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports["default"] = void 0;
|
||||
|
||||
var _utils = require("@jimp/utils");
|
||||
|
||||
/**
|
||||
* Rotates an image clockwise by an arbitrary number of degrees. NB: 'this' must be a Jimp object.
|
||||
* @param {number} deg the number of degrees to rotate the image by
|
||||
* @param {string|boolean} mode (optional) resize mode or a boolean, if false then the width and height of the image will not be changed
|
||||
*/
|
||||
function advancedRotate(deg, mode) {
|
||||
deg %= 360;
|
||||
var rad = deg * Math.PI / 180;
|
||||
var cosine = Math.cos(rad);
|
||||
var sine = Math.sin(rad); // the final width and height will change if resize == true
|
||||
|
||||
var w = this.bitmap.width;
|
||||
var h = this.bitmap.height;
|
||||
|
||||
if (mode === true || typeof mode === 'string') {
|
||||
// resize the image to it maximum dimension and blit the existing image
|
||||
// onto the center so that when it is rotated the image is kept in bounds
|
||||
// http://stackoverflow.com/questions/3231176/how-to-get-size-of-a-rotated-rectangle
|
||||
// Plus 1 border pixel to ensure to show all rotated result for some cases.
|
||||
w = Math.ceil(Math.abs(this.bitmap.width * cosine) + Math.abs(this.bitmap.height * sine)) + 1;
|
||||
h = Math.ceil(Math.abs(this.bitmap.width * sine) + Math.abs(this.bitmap.height * cosine)) + 1; // Ensure destination to have even size to a better result.
|
||||
|
||||
if (w % 2 !== 0) {
|
||||
w++;
|
||||
}
|
||||
|
||||
if (h % 2 !== 0) {
|
||||
h++;
|
||||
}
|
||||
|
||||
var c = this.cloneQuiet();
|
||||
this.scanQuiet(0, 0, this.bitmap.width, this.bitmap.height, function (x, y, idx) {
|
||||
this.bitmap.data.writeUInt32BE(this._background, idx);
|
||||
});
|
||||
var max = Math.max(w, h, this.bitmap.width, this.bitmap.height);
|
||||
this.resize(max, max, mode);
|
||||
this.blit(c, this.bitmap.width / 2 - c.bitmap.width / 2, this.bitmap.height / 2 - c.bitmap.height / 2);
|
||||
}
|
||||
|
||||
var bW = this.bitmap.width;
|
||||
var bH = this.bitmap.height;
|
||||
var dstBuffer = Buffer.alloc(this.bitmap.data.length);
|
||||
|
||||
function createTranslationFunction(deltaX, deltaY) {
|
||||
return function (x, y) {
|
||||
return {
|
||||
x: x + deltaX,
|
||||
y: y + deltaY
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
var translate2Cartesian = createTranslationFunction(-(bW / 2), -(bH / 2));
|
||||
var translate2Screen = createTranslationFunction(bW / 2 + 0.5, bH / 2 + 0.5);
|
||||
|
||||
for (var y = 1; y <= bH; y++) {
|
||||
for (var x = 1; x <= bW; x++) {
|
||||
var cartesian = translate2Cartesian(x, y);
|
||||
var source = translate2Screen(cosine * cartesian.x - sine * cartesian.y, cosine * cartesian.y + sine * cartesian.x);
|
||||
var dstIdx = bW * (y - 1) + x - 1 << 2;
|
||||
|
||||
if (source.x >= 0 && source.x < bW && source.y >= 0 && source.y < bH) {
|
||||
var srcIdx = (bW * (source.y | 0) + source.x | 0) << 2;
|
||||
var pixelRGBA = this.bitmap.data.readUInt32BE(srcIdx);
|
||||
dstBuffer.writeUInt32BE(pixelRGBA, dstIdx);
|
||||
} else {
|
||||
// reset off-image pixels
|
||||
dstBuffer.writeUInt32BE(this._background, dstIdx);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
this.bitmap.data = dstBuffer;
|
||||
|
||||
if (mode === true || typeof mode === 'string') {
|
||||
// now crop the image to the final size
|
||||
var _x = bW / 2 - w / 2;
|
||||
|
||||
var _y = bH / 2 - h / 2;
|
||||
|
||||
this.crop(_x, _y, w, h);
|
||||
}
|
||||
}
|
||||
|
||||
var _default = function _default() {
|
||||
return {
|
||||
/**
|
||||
* Rotates the image clockwise by a number of degrees. By default the width and height of the image will be resized appropriately.
|
||||
* @param {number} deg the number of degrees to rotate the image by
|
||||
* @param {string|boolean} mode (optional) resize mode or a boolean, if false then the width and height of the image will not be changed
|
||||
* @param {function(Error, Jimp)} cb (optional) a callback for when complete
|
||||
* @returns {Jimp} this for chaining of methods
|
||||
*/
|
||||
rotate: function rotate(deg, mode, cb) {
|
||||
// enable overloading
|
||||
if (typeof mode === 'undefined' || mode === null) {
|
||||
// e.g. image.resize(120);
|
||||
// e.g. image.resize(120, null, cb);
|
||||
// e.g. image.resize(120, undefined, cb);
|
||||
mode = true;
|
||||
}
|
||||
|
||||
if (typeof mode === 'function' && typeof cb === 'undefined') {
|
||||
// e.g. image.resize(120, cb);
|
||||
cb = mode;
|
||||
mode = true;
|
||||
}
|
||||
|
||||
if (typeof deg !== 'number') {
|
||||
return _utils.throwError.call(this, 'deg must be a number', cb);
|
||||
}
|
||||
|
||||
if (typeof mode !== 'boolean' && typeof mode !== 'string') {
|
||||
return _utils.throwError.call(this, 'mode must be a boolean or a string', cb);
|
||||
}
|
||||
|
||||
advancedRotate.call(this, deg, mode, cb);
|
||||
|
||||
if ((0, _utils.isNodePattern)(cb)) {
|
||||
cb.call(this, null, this);
|
||||
}
|
||||
|
||||
return this;
|
||||
}
|
||||
};
|
||||
};
|
||||
|
||||
exports["default"] = _default;
|
||||
module.exports = exports.default;
|
||||
//# sourceMappingURL=index.js.map
|
1
node_modules/@jimp/plugin-rotate/dist/index.js.map
generated
vendored
Normal file
1
node_modules/@jimp/plugin-rotate/dist/index.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
138
node_modules/@jimp/plugin-rotate/es/index.js
generated
vendored
Normal file
138
node_modules/@jimp/plugin-rotate/es/index.js
generated
vendored
Normal file
@ -0,0 +1,138 @@
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports["default"] = void 0;
|
||||
|
||||
var _utils = require("@jimp/utils");
|
||||
|
||||
/**
|
||||
* Rotates an image clockwise by an arbitrary number of degrees. NB: 'this' must be a Jimp object.
|
||||
* @param {number} deg the number of degrees to rotate the image by
|
||||
* @param {string|boolean} mode (optional) resize mode or a boolean, if false then the width and height of the image will not be changed
|
||||
*/
|
||||
function advancedRotate(deg, mode) {
|
||||
deg %= 360;
|
||||
var rad = deg * Math.PI / 180;
|
||||
var cosine = Math.cos(rad);
|
||||
var sine = Math.sin(rad); // the final width and height will change if resize == true
|
||||
|
||||
var w = this.bitmap.width;
|
||||
var h = this.bitmap.height;
|
||||
|
||||
if (mode === true || typeof mode === 'string') {
|
||||
// resize the image to it maximum dimension and blit the existing image
|
||||
// onto the center so that when it is rotated the image is kept in bounds
|
||||
// http://stackoverflow.com/questions/3231176/how-to-get-size-of-a-rotated-rectangle
|
||||
// Plus 1 border pixel to ensure to show all rotated result for some cases.
|
||||
w = Math.ceil(Math.abs(this.bitmap.width * cosine) + Math.abs(this.bitmap.height * sine)) + 1;
|
||||
h = Math.ceil(Math.abs(this.bitmap.width * sine) + Math.abs(this.bitmap.height * cosine)) + 1; // Ensure destination to have even size to a better result.
|
||||
|
||||
if (w % 2 !== 0) {
|
||||
w++;
|
||||
}
|
||||
|
||||
if (h % 2 !== 0) {
|
||||
h++;
|
||||
}
|
||||
|
||||
var c = this.cloneQuiet();
|
||||
this.scanQuiet(0, 0, this.bitmap.width, this.bitmap.height, function (x, y, idx) {
|
||||
this.bitmap.data.writeUInt32BE(this._background, idx);
|
||||
});
|
||||
var max = Math.max(w, h, this.bitmap.width, this.bitmap.height);
|
||||
this.resize(max, max, mode);
|
||||
this.blit(c, this.bitmap.width / 2 - c.bitmap.width / 2, this.bitmap.height / 2 - c.bitmap.height / 2);
|
||||
}
|
||||
|
||||
var bW = this.bitmap.width;
|
||||
var bH = this.bitmap.height;
|
||||
var dstBuffer = Buffer.alloc(this.bitmap.data.length);
|
||||
|
||||
function createTranslationFunction(deltaX, deltaY) {
|
||||
return function (x, y) {
|
||||
return {
|
||||
x: x + deltaX,
|
||||
y: y + deltaY
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
var translate2Cartesian = createTranslationFunction(-(bW / 2), -(bH / 2));
|
||||
var translate2Screen = createTranslationFunction(bW / 2 + 0.5, bH / 2 + 0.5);
|
||||
|
||||
for (var y = 1; y <= bH; y++) {
|
||||
for (var x = 1; x <= bW; x++) {
|
||||
var cartesian = translate2Cartesian(x, y);
|
||||
var source = translate2Screen(cosine * cartesian.x - sine * cartesian.y, cosine * cartesian.y + sine * cartesian.x);
|
||||
var dstIdx = bW * (y - 1) + x - 1 << 2;
|
||||
|
||||
if (source.x >= 0 && source.x < bW && source.y >= 0 && source.y < bH) {
|
||||
var srcIdx = (bW * (source.y | 0) + source.x | 0) << 2;
|
||||
var pixelRGBA = this.bitmap.data.readUInt32BE(srcIdx);
|
||||
dstBuffer.writeUInt32BE(pixelRGBA, dstIdx);
|
||||
} else {
|
||||
// reset off-image pixels
|
||||
dstBuffer.writeUInt32BE(this._background, dstIdx);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
this.bitmap.data = dstBuffer;
|
||||
|
||||
if (mode === true || typeof mode === 'string') {
|
||||
// now crop the image to the final size
|
||||
var _x = bW / 2 - w / 2;
|
||||
|
||||
var _y = bH / 2 - h / 2;
|
||||
|
||||
this.crop(_x, _y, w, h);
|
||||
}
|
||||
}
|
||||
|
||||
var _default = function _default() {
|
||||
return {
|
||||
/**
|
||||
* Rotates the image clockwise by a number of degrees. By default the width and height of the image will be resized appropriately.
|
||||
* @param {number} deg the number of degrees to rotate the image by
|
||||
* @param {string|boolean} mode (optional) resize mode or a boolean, if false then the width and height of the image will not be changed
|
||||
* @param {function(Error, Jimp)} cb (optional) a callback for when complete
|
||||
* @returns {Jimp} this for chaining of methods
|
||||
*/
|
||||
rotate: function rotate(deg, mode, cb) {
|
||||
// enable overloading
|
||||
if (typeof mode === 'undefined' || mode === null) {
|
||||
// e.g. image.resize(120);
|
||||
// e.g. image.resize(120, null, cb);
|
||||
// e.g. image.resize(120, undefined, cb);
|
||||
mode = true;
|
||||
}
|
||||
|
||||
if (typeof mode === 'function' && typeof cb === 'undefined') {
|
||||
// e.g. image.resize(120, cb);
|
||||
cb = mode;
|
||||
mode = true;
|
||||
}
|
||||
|
||||
if (typeof deg !== 'number') {
|
||||
return _utils.throwError.call(this, 'deg must be a number', cb);
|
||||
}
|
||||
|
||||
if (typeof mode !== 'boolean' && typeof mode !== 'string') {
|
||||
return _utils.throwError.call(this, 'mode must be a boolean or a string', cb);
|
||||
}
|
||||
|
||||
advancedRotate.call(this, deg, mode, cb);
|
||||
|
||||
if ((0, _utils.isNodePattern)(cb)) {
|
||||
cb.call(this, null, this);
|
||||
}
|
||||
|
||||
return this;
|
||||
}
|
||||
};
|
||||
};
|
||||
|
||||
exports["default"] = _default;
|
||||
//# sourceMappingURL=index.js.map
|
1
node_modules/@jimp/plugin-rotate/es/index.js.map
generated
vendored
Normal file
1
node_modules/@jimp/plugin-rotate/es/index.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
8
node_modules/@jimp/plugin-rotate/index.d.ts
generated
vendored
Normal file
8
node_modules/@jimp/plugin-rotate/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,8 @@
|
||||
import { ImageCallback } from '@jimp/core';
|
||||
|
||||
interface Rotate {
|
||||
rotate(deg: number, cb?: ImageCallback<this>): this;
|
||||
rotate(deg: number, mode: string | boolean, cb?: ImageCallback<this>): this;
|
||||
}
|
||||
|
||||
export default function(): Rotate;
|
43
node_modules/@jimp/plugin-rotate/package.json
generated
vendored
Normal file
43
node_modules/@jimp/plugin-rotate/package.json
generated
vendored
Normal file
@ -0,0 +1,43 @@
|
||||
{
|
||||
"name": "@jimp/plugin-rotate",
|
||||
"version": "0.12.1",
|
||||
"description": "Rotate an image.",
|
||||
"main": "dist/index.js",
|
||||
"module": "es/index.js",
|
||||
"types": "index.d.ts",
|
||||
"scripts": {
|
||||
"test": "cross-env BABEL_ENV=test mocha --require @babel/register",
|
||||
"test:watch": "npm run test -- --reporter min --watch",
|
||||
"test:coverage": "nyc npm run test",
|
||||
"build": "npm run build:node:production && npm run build:module",
|
||||
"build:watch": "npm run build:node:debug -- -- --watch --verbose",
|
||||
"build:debug": "npm run build:node:debug",
|
||||
"build:module": "cross-env BABEL_ENV=module babel src -d es --source-maps --config-file ../../babel.config.js",
|
||||
"build:node": "babel src -d dist --source-maps --config-file ../../babel.config.js",
|
||||
"build:node:debug": "cross-env BABEL_ENV=development npm run build:node",
|
||||
"build:node:production": "cross-env BABEL_ENV=production npm run build:node"
|
||||
},
|
||||
"author": "",
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"@babel/runtime": "^7.7.2",
|
||||
"@jimp/utils": "^0.12.1"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"@jimp/custom": ">=0.3.5",
|
||||
"@jimp/plugin-blit": ">=0.3.5",
|
||||
"@jimp/plugin-crop": ">=0.3.5",
|
||||
"@jimp/plugin-resize": ">=0.3.5"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@jimp/custom": "^0.12.1",
|
||||
"@jimp/plugin-blit": "^0.12.1",
|
||||
"@jimp/plugin-crop": "^0.12.1",
|
||||
"@jimp/plugin-resize": "^0.12.1",
|
||||
"@jimp/test-utils": "^0.12.1"
|
||||
},
|
||||
"publishConfig": {
|
||||
"access": "public"
|
||||
},
|
||||
"gitHead": "942e635564e36fc243767531b4f8be036afa40b5"
|
||||
}
|
150
node_modules/@jimp/plugin-rotate/src/index.js
generated
vendored
Normal file
150
node_modules/@jimp/plugin-rotate/src/index.js
generated
vendored
Normal file
@ -0,0 +1,150 @@
|
||||
import { throwError, isNodePattern } from '@jimp/utils';
|
||||
|
||||
/**
|
||||
* Rotates an image clockwise by an arbitrary number of degrees. NB: 'this' must be a Jimp object.
|
||||
* @param {number} deg the number of degrees to rotate the image by
|
||||
* @param {string|boolean} mode (optional) resize mode or a boolean, if false then the width and height of the image will not be changed
|
||||
*/
|
||||
function advancedRotate(deg, mode) {
|
||||
deg %= 360;
|
||||
const rad = (deg * Math.PI) / 180;
|
||||
const cosine = Math.cos(rad);
|
||||
const sine = Math.sin(rad);
|
||||
|
||||
// the final width and height will change if resize == true
|
||||
let w = this.bitmap.width;
|
||||
let h = this.bitmap.height;
|
||||
|
||||
if (mode === true || typeof mode === 'string') {
|
||||
// resize the image to it maximum dimension and blit the existing image
|
||||
// onto the center so that when it is rotated the image is kept in bounds
|
||||
|
||||
// http://stackoverflow.com/questions/3231176/how-to-get-size-of-a-rotated-rectangle
|
||||
// Plus 1 border pixel to ensure to show all rotated result for some cases.
|
||||
w =
|
||||
Math.ceil(
|
||||
Math.abs(this.bitmap.width * cosine) +
|
||||
Math.abs(this.bitmap.height * sine)
|
||||
) + 1;
|
||||
h =
|
||||
Math.ceil(
|
||||
Math.abs(this.bitmap.width * sine) +
|
||||
Math.abs(this.bitmap.height * cosine)
|
||||
) + 1;
|
||||
// Ensure destination to have even size to a better result.
|
||||
if (w % 2 !== 0) {
|
||||
w++;
|
||||
}
|
||||
|
||||
if (h % 2 !== 0) {
|
||||
h++;
|
||||
}
|
||||
|
||||
const c = this.cloneQuiet();
|
||||
this.scanQuiet(0, 0, this.bitmap.width, this.bitmap.height, function(
|
||||
x,
|
||||
y,
|
||||
idx
|
||||
) {
|
||||
this.bitmap.data.writeUInt32BE(this._background, idx);
|
||||
});
|
||||
|
||||
const max = Math.max(w, h, this.bitmap.width, this.bitmap.height);
|
||||
this.resize(max, max, mode);
|
||||
|
||||
this.blit(
|
||||
c,
|
||||
this.bitmap.width / 2 - c.bitmap.width / 2,
|
||||
this.bitmap.height / 2 - c.bitmap.height / 2
|
||||
);
|
||||
}
|
||||
|
||||
const bW = this.bitmap.width;
|
||||
const bH = this.bitmap.height;
|
||||
const dstBuffer = Buffer.alloc(this.bitmap.data.length);
|
||||
|
||||
function createTranslationFunction(deltaX, deltaY) {
|
||||
return function(x, y) {
|
||||
return {
|
||||
x: x + deltaX,
|
||||
y: y + deltaY
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
const translate2Cartesian = createTranslationFunction(-(bW / 2), -(bH / 2));
|
||||
const translate2Screen = createTranslationFunction(
|
||||
bW / 2 + 0.5,
|
||||
bH / 2 + 0.5
|
||||
);
|
||||
|
||||
for (let y = 1; y <= bH; y++) {
|
||||
for (let x = 1; x <= bW; x++) {
|
||||
const cartesian = translate2Cartesian(x, y);
|
||||
const source = translate2Screen(
|
||||
cosine * cartesian.x - sine * cartesian.y,
|
||||
cosine * cartesian.y + sine * cartesian.x
|
||||
);
|
||||
const dstIdx = (bW * (y - 1) + x - 1) << 2;
|
||||
|
||||
if (source.x >= 0 && source.x < bW && source.y >= 0 && source.y < bH) {
|
||||
const srcIdx = ((bW * (source.y | 0) + source.x) | 0) << 2;
|
||||
const pixelRGBA = this.bitmap.data.readUInt32BE(srcIdx);
|
||||
dstBuffer.writeUInt32BE(pixelRGBA, dstIdx);
|
||||
} else {
|
||||
// reset off-image pixels
|
||||
dstBuffer.writeUInt32BE(this._background, dstIdx);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
this.bitmap.data = dstBuffer;
|
||||
|
||||
if (mode === true || typeof mode === 'string') {
|
||||
// now crop the image to the final size
|
||||
const x = bW / 2 - w / 2;
|
||||
const y = bH / 2 - h / 2;
|
||||
this.crop(x, y, w, h);
|
||||
}
|
||||
}
|
||||
|
||||
export default () => ({
|
||||
/**
|
||||
* Rotates the image clockwise by a number of degrees. By default the width and height of the image will be resized appropriately.
|
||||
* @param {number} deg the number of degrees to rotate the image by
|
||||
* @param {string|boolean} mode (optional) resize mode or a boolean, if false then the width and height of the image will not be changed
|
||||
* @param {function(Error, Jimp)} cb (optional) a callback for when complete
|
||||
* @returns {Jimp} this for chaining of methods
|
||||
*/
|
||||
rotate(deg, mode, cb) {
|
||||
// enable overloading
|
||||
if (typeof mode === 'undefined' || mode === null) {
|
||||
// e.g. image.resize(120);
|
||||
// e.g. image.resize(120, null, cb);
|
||||
// e.g. image.resize(120, undefined, cb);
|
||||
mode = true;
|
||||
}
|
||||
|
||||
if (typeof mode === 'function' && typeof cb === 'undefined') {
|
||||
// e.g. image.resize(120, cb);
|
||||
cb = mode;
|
||||
mode = true;
|
||||
}
|
||||
|
||||
if (typeof deg !== 'number') {
|
||||
return throwError.call(this, 'deg must be a number', cb);
|
||||
}
|
||||
|
||||
if (typeof mode !== 'boolean' && typeof mode !== 'string') {
|
||||
return throwError.call(this, 'mode must be a boolean or a string', cb);
|
||||
}
|
||||
|
||||
advancedRotate.call(this, deg, mode, cb);
|
||||
|
||||
if (isNodePattern(cb)) {
|
||||
cb.call(this, null, this);
|
||||
}
|
||||
|
||||
return this;
|
||||
}
|
||||
});
|
636
node_modules/@jimp/plugin-rotate/test/rotation.test.js
generated
vendored
Normal file
636
node_modules/@jimp/plugin-rotate/test/rotation.test.js
generated
vendored
Normal file
@ -0,0 +1,636 @@
|
||||
import { Jimp, mkJGD } from '@jimp/test-utils';
|
||||
import configure from '@jimp/custom';
|
||||
import blit from '@jimp/plugin-blit';
|
||||
import crop from '@jimp/plugin-crop';
|
||||
import resize from '@jimp/plugin-resize';
|
||||
|
||||
import rotate from '../src';
|
||||
|
||||
const jimp = configure({ plugins: [rotate, blit, crop, resize] }, Jimp);
|
||||
|
||||
describe('Rotate a image with even size', () => {
|
||||
let imgSrc = null;
|
||||
|
||||
before(done => {
|
||||
jimp
|
||||
.read(
|
||||
mkJGD(
|
||||
'▰▴▴▴▪▪▪▰',
|
||||
'▴▴▴▴▪▪▪▪',
|
||||
'▴▴▴▴▪▪▪▪',
|
||||
'▴▴▴▴▪▪▪▪',
|
||||
'▪▪▪▪▴▴▴▴',
|
||||
'▪▪▪▪▴▴▴▴',
|
||||
'▪▪▪▪▴▴▴▴',
|
||||
'▦▪▪▪▴▴▴▦'
|
||||
)
|
||||
)
|
||||
.then(imgJimp => {
|
||||
imgSrc = imgJimp;
|
||||
done();
|
||||
})
|
||||
.catch(done);
|
||||
});
|
||||
|
||||
it('1 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(1, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
'▰▴▴▴▪▪▪▰ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▦▪▪▪▴▴▴▦ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('91 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(91, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
'▰▪▪▪▴▴▴▦ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▰▴▴▴▪▪▪▦ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('30 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(30, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ▰▰ ',
|
||||
' ▪▪▪▪ ',
|
||||
' ▴▪▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▴▴▴ ',
|
||||
'▴▴▴▴▪▴▴▴▴▴ ',
|
||||
' ▴▴▪▪▴▴▴▴▦ ',
|
||||
' ▪▪▪▪▪▴▴▴ ',
|
||||
' ▪▪▪▪▪ ',
|
||||
' ▪▪▪ ',
|
||||
' ▦ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('45 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(45, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▰ ',
|
||||
' ▪▪▪ ',
|
||||
' ▪▪▪▪▪ ',
|
||||
' ▴▴▪▪▪▪▴ ',
|
||||
' ▴▴▴▴▪▪▴▴▴ ',
|
||||
'▰▰▴▴▴▴▴▴▴▴▦ ',
|
||||
' ▴▴▴▴▪▪▴▴▴ ',
|
||||
' ▴▴▪▪▪▪▴ ',
|
||||
' ▪▪▪▪▪ ',
|
||||
' ▪▪▪ ',
|
||||
' ▦ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('60 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(60, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ▰ ',
|
||||
' ▪▪▪ ',
|
||||
' ▪▪▪▪▪ ',
|
||||
' ▪▪▪▪▪▴▴▴ ',
|
||||
' ▴▴▪▪▴▴▴▴▦ ',
|
||||
'▴▴▴▴▪▴▴▴▴▴ ',
|
||||
'▴▴▴▴▪▪▴▴▴ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
' ▴▪▪▪▪▪ ',
|
||||
' ▪▪▪▪ ',
|
||||
' ▦▦ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('90 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(90, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
'▰▪▪▪▴▴▴▦ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▰▴▴▴▪▪▪▦ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('120 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(120, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▴▦ ',
|
||||
' ▴▴▴▴ ',
|
||||
' ▪▪▴▴▴▴ ',
|
||||
'▰▪▪▪▴▴▴▴▪ ',
|
||||
'▰▪▪▪▪▴▴▪▪▪ ',
|
||||
' ▪▪▪▪▪▪▪▪▪ ',
|
||||
' ▪▪▴▴▴▪▪▪▪▦ ',
|
||||
' ▴▴▴▴▴▪▪ ',
|
||||
' ▴▴▴▴▪ ',
|
||||
' ▴▴▴ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('135 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(135, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ',
|
||||
' ▦ ',
|
||||
' ▴▴▴ ',
|
||||
' ▴▴▴▴▴ ',
|
||||
' ▪▪▴▴▴▪▪ ',
|
||||
' ▪▪▪▪▴▪▪▪▪ ',
|
||||
' ▰▪▪▪▪▴▪▪▪▪▦ ',
|
||||
' ▪▪▪▴▴▴▪▪▪ ',
|
||||
' ▪▴▴▴▴▴▪ ',
|
||||
' ▴▴▴▴▴ ',
|
||||
' ▴▰▴ ',
|
||||
' ▰ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('180 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(180, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▦▴▴▴▪▪▪▦ ',
|
||||
' ▴▴▴▴▪▪▪▪ ',
|
||||
' ▴▴▴▴▪▪▪▪ ',
|
||||
' ▴▴▴▴▪▪▪▪ ',
|
||||
' ▪▪▪▪▴▴▴▴ ',
|
||||
' ▪▪▪▪▴▴▴▴ ',
|
||||
' ▪▪▪▪▴▴▴▴ ',
|
||||
' ▰▪▪▪▴▴▴▰ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('225 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(225, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▦ ',
|
||||
' ▪▪▪ ',
|
||||
' ▪▪▪▪▪ ',
|
||||
' ▴▪▪▪▪▴▴ ',
|
||||
' ▴▴▴▪▪▴▴▴▴ ',
|
||||
' ▦▴▴▴▴▴▴▴▴▰▰ ',
|
||||
' ▴▴▴▪▪▴▴▴▴ ',
|
||||
' ▴▪▪▪▪▴▴ ',
|
||||
' ▪▪▪▪▪ ',
|
||||
' ▪▪▪ ',
|
||||
' ▰ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('270 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(270, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ▦▪▪▪▴▴▴▰ ',
|
||||
' ▪▪▪▪▴▴▴▴ ',
|
||||
' ▪▪▪▪▴▴▴▴ ',
|
||||
' ▪▪▪▪▴▴▴▴ ',
|
||||
' ▴▴▴▴▪▪▪▪ ',
|
||||
' ▴▴▴▴▪▪▪▪ ',
|
||||
' ▴▴▴▴▪▪▪▪ ',
|
||||
' ▦▴▴▴▪▪▪▰ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('315 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(315, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ▰ ',
|
||||
' ▴▰▴ ',
|
||||
' ▴▴▴▴▴ ',
|
||||
' ▪▴▴▴▴▴▪ ',
|
||||
' ▪▪▪▴▴▴▪▪▪ ',
|
||||
' ▦▪▪▪▪▴▪▪▪▪▰ ',
|
||||
' ▪▪▪▪▴▪▪▪▪ ',
|
||||
' ▪▪▴▴▴▪▪ ',
|
||||
' ▴▴▴▴▴ ',
|
||||
' ▴▴▴ ',
|
||||
' ▦ ',
|
||||
' ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('360 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(360, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
'▰▴▴▴▪▪▪▰ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▪▪▪▪▴▴▴▴ ',
|
||||
'▦▪▪▪▴▴▴▦ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
describe('Rotate a image with odd size', () => {
|
||||
let imgSrc = null;
|
||||
before(done => {
|
||||
jimp
|
||||
.read(
|
||||
mkJGD(
|
||||
'▴▴▴▦▪▪▪',
|
||||
'▴▴▴▦▪▪▪',
|
||||
'▴▴▴▦▪▪▪',
|
||||
'▦▦▦▦▦▦▦',
|
||||
'▴▴▴▦▴▴▴',
|
||||
'▴▴▴▦▴▴▴',
|
||||
'▴▴▴▦▴▴▴'
|
||||
)
|
||||
)
|
||||
.then(imgJimp => {
|
||||
imgSrc = imgJimp;
|
||||
done();
|
||||
})
|
||||
.catch(done);
|
||||
});
|
||||
|
||||
it('45 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(45, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▪ ',
|
||||
' ▪▪▪ ',
|
||||
' ▦▪▪▪▦ ',
|
||||
' ▴▴▦▪▦▴▴ ',
|
||||
' ▴▴▴▴▦▴▴▴▴ ',
|
||||
' ▴▴▦▴▦▴▴ ',
|
||||
' ▦▴▴▴▦ ',
|
||||
' ▴▴▴ ',
|
||||
' ▴ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('135 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(135, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▴ ',
|
||||
' ▴▴▴ ',
|
||||
' ▦▴▴▴▦ ',
|
||||
' ▪▪▦▴▦▴▴ ',
|
||||
' ▪▪▪▪▦▴▴▴▴ ',
|
||||
' ▪▪▦▴▦▴▴ ',
|
||||
' ▦▴▴▴▦ ',
|
||||
' ▴▴▴ ',
|
||||
' ▴ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('225 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(225, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▴ ',
|
||||
' ▴▴▴ ',
|
||||
' ▦▴▴▴▦ ',
|
||||
' ▴▴▦▴▦▴▴ ',
|
||||
' ▴▴▴▴▦▴▴▴▴ ',
|
||||
' ▴▴▦▪▦▴▴ ',
|
||||
' ▦▪▪▪▦ ',
|
||||
' ▪▪▪ ',
|
||||
' ▪ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('315 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(315, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▴ ',
|
||||
' ▴▴▴ ',
|
||||
' ▦▴▴▴▦ ',
|
||||
' ▴▴▦▴▦▪▪ ',
|
||||
' ▴▴▴▴▦▪▪▪▪ ',
|
||||
' ▴▴▦▴▦▪▪ ',
|
||||
' ▦▴▴▴▦ ',
|
||||
' ▴▴▴ ',
|
||||
' ▴ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
describe('Rotate a non-square image', () => {
|
||||
let imgSrc = null;
|
||||
before(done => {
|
||||
jimp
|
||||
.read(mkJGD('▴▴▴▴▪▪▪▪', '▴▴▴▴▪▪▪▪', '▦▦▦▦▴▴▴▴', '▦▦▦▦▴▴▴▴'))
|
||||
.then(imgJimp => {
|
||||
imgSrc = imgJimp;
|
||||
done();
|
||||
})
|
||||
.catch(done);
|
||||
});
|
||||
|
||||
it('1 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(1, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▪ ',
|
||||
'▦▦▦▦▴▴▴▴ ',
|
||||
'▦▦▦▦▴▴▴▴ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('10 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(10, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ▪ ',
|
||||
' ▴▴▴▪▪▪▪ ',
|
||||
'▴▴▴▴▪▪▪▴ ',
|
||||
'▴▴▦▦▴▴▴▴ ',
|
||||
'▦▦▦▦▴▴▴ ',
|
||||
'▦▦ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('30 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(30, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▪▪ ',
|
||||
' ▪▪▪▪ ',
|
||||
' ▴▴▪▪▴▴▴ ',
|
||||
'▴▴▴▦▴▴▴ ',
|
||||
'▴▴▦▦▴▴ ',
|
||||
'▦▦▦▦ ',
|
||||
' ▦ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('45 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(45, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▪▪ ',
|
||||
' ▪▪▪▴ ',
|
||||
' ▴▪▪▴▴▴ ',
|
||||
' ▴▴▴▴▴▴ ',
|
||||
'▴▴▴▦▦▴ ',
|
||||
'▴▴▦▦▦ ',
|
||||
' ▦▦▦ ',
|
||||
' ▦ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('90 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(90, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
'▪▪▴▴ ',
|
||||
'▪▪▴▴ ',
|
||||
'▪▪▴▴ ',
|
||||
'▪▪▴▴ ',
|
||||
'▴▴▦▦ ',
|
||||
'▴▴▦▦ ',
|
||||
'▴▴▦▦ ',
|
||||
'▴▴▦▦ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('135 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(135, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▴ ',
|
||||
' ▴▴▴ ',
|
||||
' ▪▪▴▴▴ ',
|
||||
' ▪▪▪▴▦▦ ',
|
||||
' ▪▪▴▦▦▦ ',
|
||||
' ▴▴▴▦▦▦ ',
|
||||
' ▴▴▴▦ ',
|
||||
' ▴▴ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('180 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(180, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ',
|
||||
' ▴▴▴▴▦▦▦▦ ',
|
||||
' ▴▴▴▴▦▦▦▦ ',
|
||||
' ▪▪▪▪▴▴▴▴ ',
|
||||
' ▪▪▪▪▴▴▴▴ ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('225 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(225, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ▦ ',
|
||||
' ▦▦▦ ',
|
||||
' ▦▦▦▴▴ ',
|
||||
' ▴▦▦▴▴▴ ',
|
||||
' ▴▴▴▴▴▴ ',
|
||||
' ▴▴▴▪▪▴ ',
|
||||
' ▴▪▪▪ ',
|
||||
' ▪▪ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
|
||||
it('315 degrees', () => {
|
||||
imgSrc
|
||||
.clone()
|
||||
.rotate(315, true)
|
||||
.getJGDSync()
|
||||
.should.be.sameJGD(
|
||||
mkJGD(
|
||||
' ▴▴ ',
|
||||
' ▦▴▴▴ ',
|
||||
'▦▦▦▴▴▴ ',
|
||||
' ▦▦▦▴▪▪ ',
|
||||
' ▦▦▴▪▪▪ ',
|
||||
' ▴▴▴▪▪ ',
|
||||
' ▴▴▴ ',
|
||||
' ▴ ',
|
||||
' ',
|
||||
' '
|
||||
)
|
||||
);
|
||||
});
|
||||
});
|
Reference in New Issue
Block a user