KineticJS中的Mouseover事件问题

时间:2012-05-14 05:41:08

标签: javascript html5 javascript-events canvas kineticjs

我正在尝试使用KinetiJs Canvas库进行一些实验。我在下面做的是 - 绘制一个矩形,只要有鼠标悬停,我想在特定点之间绘制一条线。

问题是,鼠标悬停发生时我看不到任何行。

我已经尝试检查onmousemove函数是否被调用并且它被调用,但该行不会被绘制。有人可以解释一下原因吗?

谢谢,

$(document).ready(function () {
    var stage = new Kinetic.Stage({
        container: "sketchcanvas",
        width: 600,
        height: 600
    });
    var layer = new Kinetic.Layer();
    var rect = new Kinetic.Rect({
        x: 50,
        y: 50,
        width: 500,
        height: 500,
        fill: "#00D2FF",
        stroke: "black",
        strokeWidth: 4
    });
    rect.on("mousemove", function () {
        var mousePos = stage.getMousePosition();
        var x = mousePos.x;
        var y = mousePos.y;
        var line = new Kinetic.Line({
            points: [60, 60, 80, 80, 100, 200],
            stroke: "black",
            strokeWidth: 15,
            lineCap: 'round',
            lineJoin: 'round'
        });
        layer.add(line);
    });
    layer.add(rect);
    stage.add(layer);
});

1 个答案:

答案 0 :(得分:2)

在KineticJS中,对图层进行更改或添加后,需要draw()到图层才能显示效果

...
layer.add(line);
layer.draw();