Skip to content

Instantly share code, notes, and snippets.

@Sphinxxxx
Created January 29, 2021 11:29
Show Gist options
  • Save Sphinxxxx/09a1d1cdf46db5ddb2cf8128bb6e20c6 to your computer and use it in GitHub Desktop.
Save Sphinxxxx/09a1d1cdf46db5ddb2cf8128bb6e20c6 to your computer and use it in GitHub Desktop.
Canny edge detection with jsfeat
<script>console.clear();</script>
<script type="text/javascript" src="https://unpkg.com/[email protected]/build/dat.gui.js"></script>
<script type="text/javascript" src="https://cdn.jsdelivr.net/gh/inspirit/jsfeat@master/build/jsfeat.js"></script>
<canvas id="canv"></canvas>
<input type="file" id="source" accept="image/*"/>
(function() {
"use strict";
const _canvas = document.querySelector('#canv'),
_options = {
blur_radius: 5,
low_threshold: 1,
high_threshold: 70,
};
let _img, _w, _h, _ctx, _bitmap;
function init(img) {
_img = img;
_w = img.width;
_h = img.height;
const measure = Math.max(_w, _h);
if(measure > 600) {
const shrink = 600/measure;
_w = Math.round(_w * shrink);
_h = Math.round(_h * shrink);
}
_canvas.width = _w;
_canvas.height = _h;
_ctx = _canvas.getContext("2d");
_bitmap = new jsfeat.matrix_t(_w, _h, jsfeat.U8C1_t);
}
function render() {
const ctx = _ctx;
_ctx.drawImage(_img, 0, 0, _w, _h);
var imageData = ctx.getImageData(0, 0, _w, _h);
console.log("grayscale");
jsfeat.imgproc.grayscale(imageData.data, _w, _h, _bitmap);
var r = _options.blur_radius | 0.0;
var kernel_size = (r + 1) << 1;
console.log("gauss blur " + r + ' ' + kernel_size);
jsfeat.imgproc.gaussian_blur(_bitmap, _bitmap, kernel_size, 0);
console.log("canny edge");
jsfeat.imgproc.canny(
_bitmap,
_bitmap,
_options.low_threshold,
_options.high_threshold
);
// render result back to canvas
//console.log("render", _bitmap);
var data_u32 = new Uint32Array(imageData.data.buffer);
var alpha = 0xff << 24;
var i = _bitmap.cols * _bitmap.rows,
pix = 0;
while (--i >= 0) {
pix = _bitmap.data[i];
data_u32[i] = alpha | (pix << 16) | (pix << 8) | pix;
}
ctx.putImageData(imageData, 0, 0);
}
(function load() {
const gui = new dat.GUI();
gui.add(_options, "blur_radius", 0, 10).step(1).onChange(render);
gui.add(_options, "low_threshold", 1, 200).step(1).onChange(render);
gui.add(_options, "high_threshold", 1, 200).step(1).onChange(render);
const img = new Image();
img.onload = e => {
init(img);
render();
}
document.querySelector('#source').onchange = function(e) {
var url = URL.createObjectURL(this.files[0]);
img.src = url;
};
img.src = '';
})();
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment