Я пытаюсь нарисовать ограничивающие рамки на изображении на холсте. Но как только я нарисую ограничивающие рамки, изображение исчезнет. Может кто-нибудь помочь мне исправить это, со ссылкой на мой следующий код:
<body>
<canvas id="canvas1" width="300" height="300"></canvas>
<script>
var canv = document.getElementById('canvas1'),
ctx = canv.getContext('2d'),
rect = {},
drag = false;
function draw() {
ctx.strokeRect(rect.startX, rect.startY, rect.w, rect.h);
}
function mouseDown(e) {
rect.startX = e.pageX - this.offsetLeft;
rect.startY = e.pageY - this.offsetTop;
drag = true;
}
function mouseUp() {
drag = false;
}
function mouseMove(e) {
if (drag) {
rect.w = (e.pageX - this.offsetLeft) - rect.startX;
rect.h = (e.pageY - this.offsetTop) - rect.startY ;
ctx.clearRect(0, 0, canv.width, canv.height);
draw();
}
}
function init() {
canv.addEventListener('mousedown', mouseDown, false);
canv.addEventListener('mouseup', mouseUp, false);
canv.addEventListener('mousemove', mouseMove, false);
}
function loadImage(canvas, context){
var img = new Image();
img.onload = function(){
context.drawImage(img, 0, 0, img.width, img.height,
0, 0, canvas.width, canvas.height );
};
img.src = "./Pics/img3.png";
}
init();
loadImage(canv, ctx);
</script>
</body>
ПРИМЕЧАНИЕ. Я рендеринг изображений, размеры которых (ширина и высота) превышают размеры холста