javascript - 如何使用助手 'clone' 拖动 Canvas ?

标签 javascript jquery css canvas jquery-ui-draggable

我有一个简单的 HTML Canvas

<div class='circle'>
  <canvas id="myCanvas" width="100" height="100">Your browser does not support the HTML5 canvas tag.</canvas>
</div>

有风格

.circle {
  height: auto;
  width: auto;
}

和脚本

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
});

似乎我无法使用辅助选项,当我拖动它时,我想在原始位置保留一个圆的副本。仅当我删除助手选项时,可拖动才会起作用。这只发生在 Canvas 上,如果我使用 css 绘制圆圈则不会。 fiddle 是 here .谢谢!

最佳答案

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

fiddle :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
});

关于javascript - 如何使用助手 'clone' 拖动 Canvas ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19039746/

相关文章:

javascript - 使用 ng-click 在 angularJs 中添加和删除类

javascript - slider 和光滑轮播之间的 Jquery 文件冲突

javascript - 如何确定 Office 加载项是在 Excel 还是 Excel Online 下运行?

javascript - 如何使用 for 循环删除 div 并延迟 5 秒

javascript - 当我们点击它时如何聚焦 Accordion 顶部标题

javascript - 如何获取拖动元素所在的元素的对象?

javascript - 为 DOMMouseScroll 事件添加延迟

css - 遗留 flex 盒的基线对齐

javascript - typescript 路径别名在每个文件上都需要模块别名/注册

javascript - 无法使用 moment.js 增加日期