Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mouafa/roya
🔎 Find diff between two images
https://github.com/mouafa/roya
diff matching regression
Last synced: 4 months ago
JSON representation
🔎 Find diff between two images
- Host: GitHub
- URL: https://github.com/mouafa/roya
- Owner: mouafa
- Created: 2018-08-31T20:19:48.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2019-02-21T13:58:39.000Z (almost 6 years ago)
- Last Synced: 2024-10-22T05:17:13.617Z (4 months ago)
- Topics: diff, matching, regression
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/malal
- Size: 130 KB
- Stars: 1
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Roya is a small low-level image comparison library.
[data:image/s3,"s3://crabby-images/979ea/979ea92f8ec773021a48422031df2723802a2423" alt="npm version"](https://badge.fury.io/js/roya)
[data:image/s3,"s3://crabby-images/a3b98/a3b980e9cc5566de85da378feedc6ac8f3e83f01" alt="Coverage Status"](https://coveralls.io/github/mouafa/roya?branch=master)
[data:image/s3,"s3://crabby-images/e3615/e3615415c6d788e9fffb2fed47b4cf929582aa40" alt="Build Status"](https://travis-ci.org/mouafa/roya#)Inspired by [pixelmatch](https://github.com/mapbox/pixelmatch) with more bells and whistles.
## Installation
using yarn
```bash
yarn add roya
```using npm
```bash
npm i -S roya
```### API
```
roya(img1, img2, [, options])
````img1`, `img2` — Image data of type `Buffer` of the images to compare
`options` Optional object options with the following properties:
| Property | Description | Default |
| -------------- | -------------------------------------------------------------------------------------------------------------- | ----------- |
| threshold | Matching threshold, ranges from 0 to 1. Smaller values make the comparison more sensitive | 0.1 |
| highlightFade | Highlight color intensity will depend on the pixel ditance value | true |
| highlightColor | The used highlight color, should be an array of [R,G,B] values | [255, 0, 0] |
| transparent | Whether to keep the original image ot to use a blank convas to highlight the diff | false |
| overlapse | Whether to use the highlight color or use the changing pixel itself | false |
| method | Matching and diffing method to be used, should be one of the available methods, rgb, rgbTuned, yiq or yiqTuned | 'rgb' |**P.S.** rgb method is the fastest but it might not be the best for your usecase, try the others method and pick the right one for you.
### Example:
| img1 | img2 |
| ------------------------------- | ------------------------------- |
| data:image/s3,"s3://crabby-images/da7f4/da7f452233dba12bc73f04d5bfe7b740ff987edf" alt="" | data:image/s3,"s3://crabby-images/13751/1375180cfc6d58bd6bcc3449dcac2829bccba4a5" alt="" || options | result |
| ---------------------------------------------- | ------------------------------------------------ |
| `undefined` | data:image/s3,"s3://crabby-images/be6dc/be6dc85fb0403d6c28b1a4a7198bb9ae5b42069d" alt="" |
| `{ threshold: 0.5 }` | data:image/s3,"s3://crabby-images/e870d/e870de0936e32a1077b36fcac0bab485b162af8e" alt="" |
| `{ highlightColor: [255, 255, 0] }` | data:image/s3,"s3://crabby-images/23037/2303756717164630c980e479185af3348d396666" alt="" |
| `{ highlightFade: false }` | data:image/s3,"s3://crabby-images/2c787/2c787ba20c7121f8bc7e6daf73f1b5d2d05574b2" alt="" |
| `{ transparent: true, highlightFade: false }` | data:image/s3,"s3://crabby-images/40b8b/40b8bca53db3c15ce8bc6880c5b2810e14b3bf5c" alt="" |
| `{ overlapse: true, transparent: true }` | data:image/s3,"s3://crabby-images/3f882/3f882a9676dd03901bff4e8c71b8af3fc592486e" alt="" |
| |
| `{ method: 'rgb', highlightFade: false }` | data:image/s3,"s3://crabby-images/aabc2/aabc2036a7d324b9e515a6d676a7c77ca3b5161e" alt="" |
| `{ method: 'rgbTuned', highlightFade: false }` | data:image/s3,"s3://crabby-images/fa4d4/fa4d4401aa4811073118c568a0bfbb7c298d944e" alt="" |
| `{ method: 'yiq', highlightFade: false }` | data:image/s3,"s3://crabby-images/5e205/5e205c307270bcc3fdf935cf38cf671d38bd410b" alt="" |
| `{ method: 'yiqTuned', highlightFade: false }` | data:image/s3,"s3://crabby-images/8d6ba/8d6bab3e38ade3a4aea26369b7f0a8803b309944" alt="" |## Usage
```js
const fs = require('fs')
const PNG = require('pngjs').PNG
const roya = require('roya')var img1 = fs
.createReadStream('img1.png')
.pipe(new PNG())
.on('parsed', parsed)var img2 = fs
.createReadStream('img2.png')
.pipe(new PNG())
.on('parsed', parsed)let done = 0
function parsed() {
done++
if (done < 2) return
const out = roya(img1.data, img2.data)const diff = new PNG({ width: img1.width, height: img1.height })
diff.data = out.data
diff
.pack()
.pipe(fs.createWriteStream('diff.png'))
.on('finish', () => console.log('done'))
}
```**P.S.** image dimensions must be equal.