帆布形状移动

时间:2015-08-07 12:12:35

标签: javascript html5 canvas shape drag

我有这个代码。此脚本可以像画图应用程序一样在画布中着色。都好。现在我在脚本的底部添加了一个添加图像的功能。我想让那个图像移动,所以我可以拖动它。我看到了一些脚本,但我想我需要以某种方式结合我的函数findxy,但我不知道如何。如果有人可以帮助我。

var canvas, ctx, flag = false,
    prevX = 0,
    currX = 0,
    prevY = 0,
    currY = 0,
    dot_flag = false;

var x = "white",
    y = 2;

function init() {
    canvas = document.getElementById('can');
    ctx = canvas.getContext("2d");
    teams();
    w = canvas.width;
    h = canvas.height;

    canvas.addEventListener("mousemove", function (e) {
        findxy('move', e)
    }, false);
    canvas.addEventListener("mousedown", function (e) {
        findxy('down', e)
    }, false);
    canvas.addEventListener("mouseup", function (e) {
        findxy('up', e)
    }, false);
    canvas.addEventListener("mouseout", function (e) {
        findxy('out', e)
    }, false);
}

function color(obj) {
    switch (obj.id) {
        case "blue":
            x = "blue";
            break;
        case "red":
            x = "red";
            break;
        case "white":
            x = "white";
            break;
    }

}

function draw() {
    ctx.beginPath();
    ctx.moveTo(prevX, prevY);
    ctx.lineTo(currX, currY);
    ctx.strokeStyle = x;
    ctx.lineWidth = y;
    ctx.stroke();
    ctx.setDither = true;                    // set the dither to true    // set to STOKE
    ctx.setAntiAlias = true;                         // set anti alias so it smooths
    ctx.closePath();
}

function erase() {
    var m = confirm("Want to clear");
    if (m) {
        ctx.clearRect(0, 0, w, h);
        teams();
    }
}


function findxy(res, e) {
    if (res == 'down') {
        prevX = currX;
        prevY = currY;
        currX = e.clientX - canvas.offsetLeft;
        currY = e.clientY - canvas.offsetTop;

        flag = true;
        dot_flag = true;
        if (dot_flag) {
            ctx.beginPath();
            ctx.fillStyle = x;
            ctx.fillRect(currX, currY, 2, 2);
            ctx.closePath();
            dot_flag = false;
        }
    }
    if (res == 'up' || res == "out") {
        flag = false;
    }
    if (res == 'move') {
        if (flag) {
            prevX = currX;
            prevY = currY;
            currX = e.clientX - canvas.offsetLeft;
            currY = e.clientY - canvas.offsetTop;
            draw();
        }
    }
}
function teams() {
    var c=document.getElementById("can");
    var ctx=c.getContext("2d");
    var img=document.getElementById("topb");
    ctx.drawImage(img,103,80);
};

0 个答案:

没有答案