This commit is contained in:
Yamozha
2021-04-02 02:24:13 +03:00
parent c23950b545
commit 7256d79e2c
31493 changed files with 3036630 additions and 0 deletions

23
node_modules/@jimp/plugin-rotate/CHANGELOG.md generated vendored Normal file
View 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
View 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
View 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
View 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

File diff suppressed because one or more lines are too long

138
node_modules/@jimp/plugin-rotate/es/index.js generated vendored Normal file
View 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

File diff suppressed because one or more lines are too long

8
node_modules/@jimp/plugin-rotate/index.d.ts generated vendored Normal file
View 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
View 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
View 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
View 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(
' ▴▴ ',
' ▦▴▴▴ ',
'▦▦▦▴▴▴ ',
' ▦▦▦▴▪▪ ',
' ▦▦▴▪▪▪ ',
' ▴▴▴▪▪ ',
' ▴▴▴ ',
' ▴ ',
' ',
' '
)
);
});
});