Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/reg-viz/img-diff-js
:art: Node.js library to compare 2 images without native libs.
https://github.com/reg-viz/img-diff-js
difference image-processing
Last synced: 2 months ago
JSON representation
:art: Node.js library to compare 2 images without native libs.
- Host: GitHub
- URL: https://github.com/reg-viz/img-diff-js
- Owner: reg-viz
- License: mit
- Created: 2017-07-15T09:25:42.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-07-30T22:22:57.000Z (5 months ago)
- Last Synced: 2024-07-30T23:21:47.119Z (5 months ago)
- Topics: difference, image-processing
- Language: TypeScript
- Homepage:
- Size: 1.51 MB
- Stars: 112
- Watchers: 6
- Forks: 15
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# img-diff-js
[![github actions](https://github.com/reg-viz/img-diff-js/workflows/build/badge.svg)](https://github.com/reg-viz/img-diff-js/actions)
[![npm version](https://badge.fury.io/js/img-diff-js.svg)](https://badge.fury.io/js/img-diff-js)
[![codecov](https://codecov.io/gh/reg-viz/img-diff-js/graph/badge.svg?token=6QopebRnI6)](https://codecov.io/gh/reg-viz/img-diff-js)
[![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](https://opensource.org/licenses/MIT):art: Node.js library to compare 2 images without native libs.
| Actual | Expected | Difference |
| :---------------------------: | :-------------------------------: | :-----------------------: |
| ![actual](example/actual.png) | ![expected](example/expected.png) | ![diff](example/diff.png) |## Install
```sh
npm install img-diff-js
``````js
const { imgDiff } = require("img-diff-js");imgDiff({
actualFilename: "example/actual.png",
expectedFilename: "example/expected.png",
diffFilename: "example/diff.png",
}).then(result => console.log(result));
```## API Usage
### `imgDiff(opt: ImgDiffOptions): Promise`
Create image differential between two images.
#### `ImgDiffOptions`
```ts
{
actualFilename: string;
expectedFilename: string;
diffFilename?: string;
generateOnlyDiffFile?: boolean; // default false
options?: {
threshold?: number; // default 0.1
includeAA?: boolean; // default false
}
}
```- `actualFilename` - _Required_ - Path to actual image file.
- `expectedFilename` - _Required_ - Path to expected image file.
- `diffFilename` - _Optional_ - Path to differential image file. If omitted, `imgDiff` does not output image file.
- `generateOnlyDiffFile` - _Optional_ - Generate only files with difference
- `options` - _Optional_ - An object to pass through [pixelmatch](https://github.com/mapbox/pixelmatch#api).#### `ImgDiffResult`
```ts
{
width: number;
height: number;
imagesAreSame: boolean;
diffCount: number;
}
```- `width` - Differential image's width.
- `height` - Differential image's height.
- `imagesAreSame` - It'll be true only if 2 images are same perfectly.
- `diffCount` - The number of differential pixels.## Available format
The following codecs are available for input image files.
- [x] png
- [x] jpeg
- [x] tiff (limited. See https://github.com/Quramy/decode-tiff#compatibility )
- [ ] bmp`imgDiff` detects the input image format from it's extension name. For example, if the input file name ends with ".jpeg", `imgDiff` attempts to decode in JPEG way regardless of the actual file format.
The output image format is PNG only.
## Contribute
PR or issue is welcome :)
### Setup
```sh
yarn
```### Test
```sh
yarn test
```### Run benchmark script
```sh
yarn run perf
```## License
MIT License. See LICENSE under this repository.