89 lines
3.2 KiB
JavaScript
89 lines
3.2 KiB
JavaScript
class DebugCanvas {
|
|
constructor(ardConf){
|
|
this.conf = ardConf;
|
|
}
|
|
|
|
init(canvasSize, canvasPosition) {
|
|
console.log("initiating DebugCanvas")
|
|
|
|
var body = document.getElementsByTagName('body')[0];
|
|
|
|
if(!canvasPosition){
|
|
canvasPosition = {
|
|
top: 1200,
|
|
left: 800
|
|
}
|
|
}
|
|
if(!this.canvas){
|
|
this.canvas = document.createElement("canvas");
|
|
body.appendChild(this.canvas);
|
|
}
|
|
|
|
this.canvas.style.position = "absolute";
|
|
this.canvas.style.left = `${canvasPosition.left}px`;
|
|
this.canvas.style.top = `${canvasPosition.top}px`;
|
|
this.canvas.style.zIndex = 10002;
|
|
this.canvas.style.transform = "scale(2.5, 2.5)";
|
|
this.canvas.id = "uw_debug_canvas";
|
|
|
|
this.context = this.canvas.getContext("2d");
|
|
|
|
this.canvas.width = canvasSize.width;
|
|
this.canvas.height = canvasSize.height;
|
|
|
|
console.log("debug canvas is:", this.canvas, "context:", this.context)
|
|
}
|
|
|
|
setBuffer(buffer) {
|
|
// this.imageBuffer = buffer.splice(0);
|
|
this.imageBuffer = new Uint8ClampedArray(buffer);
|
|
}
|
|
|
|
trace(arrayIndex, colorClass) {
|
|
this.imageBuffer[arrayIndex ] = colorClass.colorRgb[0];
|
|
this.imageBuffer[arrayIndex+1] = colorClass.colorRgb[1];
|
|
this.imageBuffer[arrayIndex+2] = colorClass.colorRgb[2];
|
|
}
|
|
|
|
update() {
|
|
if(this.context && this.imageBuffer instanceof Uint8ClampedArray){
|
|
var idata = new ImageData(this.imageBuffer, this.canvas.width, this.canvas.height);
|
|
this.putImageData(this.context, idata, 0, 0);
|
|
}
|
|
}
|
|
|
|
|
|
putImageData(ctx, imageData, dx, dy, dirtyX, dirtyY, dirtyWidth, dirtyHeight) {
|
|
var data = imageData.data;
|
|
var height = imageData.height;
|
|
var width = imageData.width;
|
|
dirtyX = dirtyX || 0;
|
|
dirtyY = dirtyY || 0;
|
|
dirtyWidth = dirtyWidth !== undefined? dirtyWidth: width;
|
|
dirtyHeight = dirtyHeight !== undefined? dirtyHeight: height;
|
|
var limitBottom = Math.min(dirtyHeight, height);
|
|
var limitRight = Math.min(dirtyWidth, width);
|
|
for (var y = dirtyY; y < limitBottom; y++) {
|
|
for (var x = dirtyX; x < limitRight; x++) {
|
|
var pos = y * width + x;
|
|
ctx.fillStyle = 'rgba(' + data[pos*4+0]
|
|
+ ',' + data[pos*4+1]
|
|
+ ',' + data[pos*4+2]
|
|
+ ',' + (data[pos*4+3]/255) + ')';
|
|
ctx.fillRect(x + dx, y + dy, 1, 1);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
DebugCanvasClasses = {
|
|
VIOLATION: {color: '#ff4400', colorRgb: [255, 68, 0], text: 'violation (general)'},
|
|
WARN: {color: '#d08539', colorRgb: [208, 133, 57], text: 'lesser violation (general)'},
|
|
GUARDLINE_BLACKBAR: {color: '#3333FF', colorRgb: [51, 51, 255], text: 'guardline/blackbar (expected value)'},
|
|
GUARDLINE_IMAGE: {color: '#000088', colorRgb: [0, 0, 136], text: 'guardline/image (expected value)'},
|
|
|
|
EDGEDETECT_ONBLACK: {color: '#444444', colorRgb: [68, 68, 68], text: 'edge detect - perpendicular (to edge)'},
|
|
EDGEDETECT_CANDIDATE: {color: '#FFFFFF', colorRgb: [255, 255, 255], text: 'edge detect - edge candidate'},
|
|
EDGEDETECT_BLACKBAR: {color: '#07ac93', colorRgb: [7, 172, 147], text: 'edge detect - parallel, black test'},
|
|
EDGEDETECT_IMAGE: {color: '#046c5c', colorRgb: [4, 108, 92], text: 'edge detect - parallel, image test'}
|
|
} |