Note: FILTER.js project, for Image Processing and Computer Vision, includes a HaarDetector plugin which can be seen as the continuation of this project.
Feature Detection Library for JavaScript (uses HTML5 canvas on browser and canvas alternative on Node)
Based on Viola-Jones Feature Detection Algorithm using Haar Cascades and improvement Viola-Jones-Lienhart et al Feature Detection Algorithm
This is a port of OpenCV C++ Haar Detection and of JViolaJones Java) to JavaScript.
there is also a php
version: HAARPHP
Light-weight (~11kB minified, ~5kB gzipped).
You can use the existing openCV cascades to build your detectors.
To do this just transform the opencv xml file to javascript or json format using the haartojs (php) tool (in cascades folder)
examples:
to use opencv's haarcascades_frontalface_alt.xml in javascript do:
haartojs haarcascades_frontalface_alt.xml > haarcascades_frontalface_alt.js
this creates a javascript file: haarcascades_frontalface_alt.js which you can include in your html file or node file
the variable to use in javascript is similarly haarcascades_frontalface_alt (both in browser and node)
to transform a cascade xml file to json format do:
haartojson haarcascades_frontalface_alt.xml > haarcascades_frontalface_alt.json
The structure of the .js and .json formats is exactly the same, so you can interchange between the two freely
HAAR.js works both in the browser and in Node.js (supporting parallel computations with Parallel.js
)
NOTE HAAR.js
(0.4.4+) (and the generated cascades) support umd-style generic loading capability for: commonjs / node , amd , browsers script tags
Loading with script tags.
You can run the example face.html or mouth.html inside your browser.
For running in nodejs, the package has a dependency on canvas.
Canvas
alternatives for nodejs:
To work properly node-canvas
needs some system dependencies.
You can find instruction on https://github.com/Automattic/node-canvas/wiki
You can find an example inside examples/nodes.js for both alternatives.
Example Output
node examples/node.js
processing the picture
[{"x":84,"y":90,"width":202,"height":202,"area":40804}]
As a third option, you can load the library with requireJS, both in the browser in node. There is an example of loading with RequireJS inside node in examples/require.js. The configuration would be the same inside a browser
The parallel.js library is included in this repository, see the face.html example for how to use. In most cases using parallel computation (if supported) can be much faster (eg eye.html example)
- OpenCV
- This resource
- search the web :)
- Train your own with a little extra help here and here
- A haarcascade for eyes contributed by Mar Canet demo here
- SmileDetectJS
- ObjectDetect (some common ideas with HAAR.js are used)
- optimize detector for real-time usage on browsers (eg. -> https://github.com/liuliu/ccv) [DONE use parallel.js]
- add selection option, detection is confined to that selection (eg detect nose while face already detected) [DONE]
- check if some operations can use fixed-point arithmetic, or other micro-optimizations [DONE where applicable]
- keep up with the changes in openCV cascades xml format (will try)
see also:
- Abacus advanced Combinatorics and Algebraic Number Theory Symbolic Computation library for JavaScript, Python
- MOD3 3D Modifier Library in JavaScript
- Geometrize Computational Geometry and Rendering Library for JavaScript
- Plot.js simple and small library which can plot graphs of functions and various simple charts and can render to Canvas, SVG and plain HTML
- HAAR.js image feature detection based on Haar Cascades in JavaScript (Viola-Jones-Lienhart et al Algorithm)
- HAARPHP image feature detection based on Haar Cascades in PHP (Viola-Jones-Lienhart et al Algorithm)
- FILTER.js video and image processing and computer vision Library in pure JavaScript (browser and node)
- Xpresion a simple and flexible eXpression parser engine (with custom functions and variables support), based on GrammarTemplate, for PHP, JavaScript, Python
- Regex Analyzer/Composer Regular Expression Analyzer and Composer for PHP, JavaScript, Python
- GrammarTemplate grammar-based templating for PHP, JavaScript, Python
- codemirror-grammar transform a formal grammar in JSON format into a syntax-highlight parser for CodeMirror editor
- ace-grammar transform a formal grammar in JSON format into a syntax-highlight parser for ACE editor
- prism-grammar transform a formal grammar in JSON format into a syntax-highlighter for Prism code highlighter
- highlightjs-grammar transform a formal grammar in JSON format into a syntax-highlight mode for Highlight.js code highlighter
- syntaxhighlighter-grammar transform a formal grammar in JSON format to a highlight brush for SyntaxHighlighter code highlighter
- SortingAlgorithms implementations of Sorting Algorithms in JavaScript
- PatternMatchingAlgorithms implementations of Pattern Matching Algorithms in JavaScript
- CanvasLite an html canvas implementation in pure JavaScript
- Rasterizer stroke and fill lines, rectangles, curves and paths, without canvaσ
- Gradient create linear, radial, conic and elliptic gradients and image patterns without canvas
- css-color simple class to parse and manipulate colors in various formats