Skip to content

Image perceptual hash calculation in javascript, browser and Node.JS

License

Notifications You must be signed in to change notification settings

theartur/blockhash-js

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

38 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

blockhash-js

This is a perceptual image hash calculation tool based on algorithm descibed in Block Mean Value Based Image Perceptual Hashing by Bian Yang, Fan Gu and Xiamu Niu.

Node.JS support by @theartur.

Installation

This repository is a fork with added Node.JS support, and the module is installed via npm:

  $ npm install https://github.com/theartur/blockhash-js

Use in the browser

To use this library in the browser, you can build it with Browserify with something like browserify index.js --standalone blockhashjs > blockhash.js

Include it and zlib.js on your page:

<!DOCTYPE html>
<html>
  <head>
    <title>Blockhash</title>
  </head>
  <body>
    <script src="node_modules/png-js/zlib.js"></script>
    <script src="blockhash.js"></script>
    <script>
      var blockhash = blockhashjs.blockhash;
    </script>
  </body>
</html>

Use in Node.JS

var blockhash = require("blockhash").blockhash;
blockhash("./example.png", 32, 2, function (err, hash) {
	if (err) throw err;
	console.log("example.png perceptual hash: ", result);
});

Node.JS and browser use

Call blockhash(src, bits, method, callback), where src is an image URL, bits is the number of bits in a row, method is a number 1-2 (see below), and callback is a function with (error, result) signature. On success, result will be array of binary values.

The available methods are:

  1. Quick and crude, non-overlapping blocks
  2. Precise but slower, non-overlapping blocks

Method 2 is recommended as a good tradeoff between speed and good matches on any image size. The quick ones are only advisable when the image width and height are an even multiple of the number of blocks used.

License

Copyright 2014 Commons Machinery http://commonsmachinery.se/

Distributed under an MIT license, please see LICENSE in the top dir.

Contact: dev@commonsmachinery.se

About

Image perceptual hash calculation in javascript, browser and Node.JS

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 96.0%
  • Makefile 4.0%