在jquery显示转换后无法绘制画布元素

时间:2012-02-09 22:14:35

标签: jquery html5 canvas

我正在使用画布创建绘图应用程序。如果显示包含canvas元素的div,它可以正常工作。但是,我想最初隐藏包含div,然后使用jquery转换“启动”绘图应用程序以淡入绘图界面。所以包含div最初将其css'display'属性设置为'none',然后我显示它。但是,当我这样做时,canvas元素将不再接收任何绘图输入。我尝试在我的脚本渲染canvas元素之后动态设置display:none,以确保那里没有干扰,但没有骰子。有什么建议吗?

以下是绘图界面的html结构:

<!--DRAWING INTERFACE-->
    <style>
       #draw-container {
         display:none;
         width:1920px;
         height:1080px;
         position:absolute;
         top:0px;
         left:0px;
       }
     </style>
<div id="draw-container">
    <h1>Send a Drawing</h1>
    <div id="draw" class="panel">
    </div>
    <div id="draw-buttons">
        <a id="sendButton" href="#" class="round">></a>
        <a id="clearButton" href="#" class="round">+</a>
    </div>
</div>

然后调用此函数,它将canvas元素创建为“draw”div的子元素:

//creating canvasses
function drawCanvas(id,xOffset){
    //draw
    var canvas = document.createElement("canvas");
    canvas.width = canvasWidth;
    canvas.height = canvasHeight;
    canvas.id = id;
    $('#draw').append(canvas);
}

当用户点击按钮以显示绘图模块时:

document.getElementById('drawLaunch').addEventListener("click", function(){
    $('#draw-container').show();
});

最后,这是绘图功能:

function _drawCircle(mouseX, mouseY) {
//get position
var x = mouseX - offsetLeft,
    y = mouseY - offsetTop;
//move mouse to the previous point
if (lastX == null) {
    lastX = x;
    lastY = y;
}
context.moveTo(lastX,lastY);
//draw line
context.lineTo(x, y);
context.stroke();
//set new last point
lastX = x;
lastY = y;

}

现在,如果我保持一切相同,但只是从样式表中删除'display:none;',以便在加载页面时显示画布,一切正常。但如果它被隐藏然后显示,你可以不能借鉴它。

1 个答案:

答案 0 :(得分:6)

 #draw-container {
     visibility:hidden;
     width:1920px;
     height:1080px;
     position:absolute;
     top:0px;
     left:0px;
   }

你能使用visibility:hidden而不是display:none吗?那样,元素一直存在于页面上,肉眼看不到?

当你希望它再次可见时,只需写下

即可
  visibility:visible;

或在您的代码中

document.getElementById('drawLaunch').addEventListener("click", function(){
    $('#draw-container').css('visibility','visibile');
});