A Pen by Andreas Borgen on CodePen.
Created
January 29, 2021 11:29
-
-
Save Sphinxxxx/09a1d1cdf46db5ddb2cf8128bb6e20c6 to your computer and use it in GitHub Desktop.
Canny edge detection with jsfeat
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<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/*"/> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(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