繁体   English   中英

JavaScript 和 Canvas 绘图不正确

[英]JavaScript and Canvas not drawing correctly

有一些代码可以在 canvas 上显示图像,该图像存储为文本区域内的“数据:图像/png;base64”。 这一切都有效,但由于某种原因,我无法让它的绘制部分正常工作。 它只是在 canvas 的左上角画了一个小标记。

HTML:

<html>
<head>

</head>
<body>
<div class="container-fluid rtc-edges">
<div class="page-heading">
    <div class="page-header">
        <h1>Sign Test</h1>
    </div>
</div>
<div class="row">
    <div class="col-md-12 middle-column">
        <div class="form">
            <textarea rows="4" maxlength="10000" id="rtc_benficiarysignature" class="textarea form-control" style="width:100%"></textarea>
        </div>   
    </div>
</div>
</div>
</body>
</html>

这是 JavaScript 代码:

window.onload = function() {

//get target field
var benficiarySignature = document.querySelector('#rtc_benficiarysignature');
var context;

var innerHtml = '<div class="canvas-wrapper">';
innerHtml += '<div class="canvas-area">';
innerHtml += '<canvas id="canvasSign"></canvas>';
innerHtml += '</div>'
innerHtml += '<div class="actions"><button type="button" id="btnClear">Clear</button><button type="button" id="btnOk">OK</button></div>';
innerHtml += '</div>';

    //insert the above HTML before the textarea (need this because of where this will finally end up)
benficiarySignature.insertAdjacentHTML("beforebegin", innerHtml);


var mainCanvas = document.getElementById('canvasSign');
var btnClear = document.getElementById('btnClear');
var btnOk = document.getElementById('btnOk');


if(mainCanvas.getContext) {
    
    context = mainCanvas.getContext('2d');
    context.strokeStyle = "#000";
    context.lineJoin = "round";
    context.lineWidth = 2;
    
} else {

    console.log('Failed to create context');

}

//click event to clear the canvas
btnClear.addEventListener("click", function(){
    context.clearRect(0, 0, mainCanvas.width, mainCanvas.height);
});

//click event to clear the canvas
btnOk.addEventListener("click", function(){
    
    var tmpCanvas = mainCanvas.toDataURL("image/png");

    if(tmpCanvas) {
        benficiarySignature.value = tmpCanvas;
    }

});

//display the image in the canvas area, if there is a value
if(benficiarySignature.value) {

    //clear canvas, just to make sure
    context.clearRect(0, 0, mainCanvas.width, mainCanvas.height);

    var img = new Image();
    img.src = benficiarySignature.value;

    //small delay to display signature
    setTimeout(function() {
        context.drawImage(img, 0, 0, mainCanvas.width, mainCanvas.height);
        img.remove();
    },500);
}

var clickX = clickY = clickDrag = [];
var paint;

/**
 * Add information where the user clicked at.
 * @param {number} x
 * @param {number} y
 * @return {boolean} dragging
 */
function addClick(x, y, dragging) {
    clickX.push(x);
    clickY.push(y);
    clickDrag.push(dragging);
}

/**
 * Draw the newly added point.
 * @return {void}
 */
function drawNew() {
    var i = clickX.length - 1
    if (!clickDrag[i]) {
        if (clickX.length == 0) {
            context.beginPath();
            context.moveTo(clickX[i], clickY[i]);
            context.stroke();
        } else {
            context.closePath();
            context.beginPath();
            context.moveTo(clickX[i], clickY[i]);
            context.stroke();
        }
    } else {
        context.lineTo(clickX[i], clickY[i]);
        context.stroke();
    }
}

function mouseDownEventHandler(e) {
    paint = true;
    var x = e.pageX - mainCanvas.offsetLeft;
    var y = e.pageY - mainCanvas.offsetTop;
    if (paint) {
        addClick(x, y, false);
        drawNew();
    }
}

function touchstartEventHandler(e) {
    paint = true;
    if (paint) {
        addClick(e.touches[0].pageX - mainCanvas.offsetLeft, e.touches[0].pageY - mainCanvas.offsetTop, false);
        drawNew();
    }
}

function mouseUpEventHandler(e) {
    context.closePath();
    paint = false;
}

function mouseMoveEventHandler(e) {
    var x = e.pageX - mainCanvas.offsetLeft;
    var y = e.pageY - mainCanvas.offsetTop;

            //alert('PageX: ' + e.pageX + ' | PageY: ' +  e.pageY);

    if (paint) {
        addClick(x, y, true);
        drawNew();
    }
}

function touchMoveEventHandler(e) {
    if (paint) {
        addClick(e.touches[0].pageX - mainCanvas.offsetLeft, e.touches[0].pageY - mainCanvas.offsetTop, true);
        drawNew();
    }
}

function setUpHandler(isMouseandNotTouch, detectEvent) {
    removeRaceHandlers();
    if (isMouseandNotTouch) {
        mainCanvas.addEventListener('mouseup', mouseUpEventHandler);
        mainCanvas.addEventListener('mousemove', mouseMoveEventHandler);
        mainCanvas.addEventListener('mousedown', mouseDownEventHandler);
        mouseDownEventHandler(detectEvent);
    } else {
        mainCanvas.addEventListener('touchstart', touchstartEventHandler);
        mainCanvas.addEventListener('touchmove', touchMoveEventHandler);
        mainCanvas.addEventListener('touchend', mouseUpEventHandler);
        touchstartEventHandler(detectEvent);
    }
}

function mouseWins(e) {
    setUpHandler(true, e);
}

function touchWins(e) {
    setUpHandler(false, e);
}

function removeRaceHandlers() {
    mainCanvas.removeEventListener('mousedown', mouseWins);
    mainCanvas.removeEventListener('touchstart', touchWins);
}

mainCanvas.addEventListener('mousedown', mouseWins);
mainCanvas.addEventListener('touchstart', touchWins);

}

完整的代码可以在这里看到https://jsfiddle.net/trekmp00/gcjhtkra/2/并且非常感谢一些帮助尝试让它工作。 当您看到代码时,您会看到我正在通过 JavaScript 添加 canvas 和按钮,我必须这样做,因为我要将它注入到表单中,我无法直接访问表单布局或添加这样的自定义元素(来自 Microsoft CRM 门户)

如果你改变var clickX = [] clickY = clickDrag = [];

var clickX = []; var clickY = []; var clickDrag = []; var clickX = []; var clickY = []; var clickDrag = [];

这使它工作

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM