如何使用帮助器'clone'拖动画布?

mar*_*ant 5 javascript css jquery canvas jquery-ui-draggable

我有一个简单的HTML画布

<div class='circle'>
  <canvas id="myCanvas" width="100" height="100">Your browser does not support the HTML5 canvas tag.</canvas>
</div>
Run Code Online (Sandbox Code Playgroud)

风格

.circle {
  height: auto;
  width: auto;
}
Run Code Online (Sandbox Code Playgroud)

和脚本

var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.beginPath();
ctx.arc(50, 50, 50, 0, 2 * Math.PI);
ctx.fill();

$('.circle').draggable({
    helper: 'clone' // Remove this line to make it draggable
});
Run Code Online (Sandbox Code Playgroud)

似乎我不能使用帮助器选项,我想在我拖动时保持原始位置的圆圈副本.只有删除帮助程序选项时,draggable才会起作用.这只发生在画布上,而不是我用css绘制圆圈.小提琴就在这里.谢谢!

Ker*_*Liu 3

不幸的是,当您克隆画布元素时,这不会复制图像数据。您可能希望将画布数据导出为数据 URL 并克隆图像。

小提琴: http: //jsfiddle.net/gwwar/Bdpq9/2/

<div class='circle'>
</div>

var c = document.createElement("canvas");
var ctx = c.getContext("2d");
ctx.beginPath();
ctx.arc(50, 50, 50, 0, 2 * Math.PI);
ctx.fill();
var url = c.toDataURL();
var img = document.createElement("img");
img.setAttribute("src",url);
$(".circle").append(img);

$('.circle').draggable({
    helper: 'clone' // Remove this line to make it draggable
});
Run Code Online (Sandbox Code Playgroud)