在 FabricJS 画布上拖放和删除对象

Posted

技术标签:

【中文标题】在 FabricJS 画布上拖放和删除对象【英文标题】:Drag, drop and delete objects on FabricJS canvas 【发布时间】:2017-08-08 14:53:13 【问题描述】:

我在使用 JQuery 处理 FabricJS 时遇到问题。

选择一个对象并单击删除没有问题。

这是我的代码演示 Fiddle

我可以在 FabricJS 之外进行拖放和删除操作(只需拖动不相关的元素即可删除),但我很难将两者结合起来。

也许我需要在画布中合并删除按钮才能使“拖放”起作用?当我尝试这个时,#delete 元素消失了。

JS

var canvas = new fabric.Canvas('canvas');
$("#delete").click(function() 
  deleteObjects();
);

//Test objects on the canvas
//Circle
var circle = new fabric.Circle(
  left: 200,
  top: 150,
  radius: 30,
  fill: "#ff0072"
);
circle.hasRotatingPoint = true;
canvas.add(circle);

// adding triangle
var triangle = new fabric.Triangle(
  left: 130,
  top: 150,
  strokeWidth: 1,
  width: 70,
  height: 60,
  fill: '#00b4ff',
  selectable: true,
  originX: 'center'
);
triangle.hasRotatingPoint = true;
canvas.add(triangle);

//Select all objects
function deleteObjects() 
  var activeObject = canvas.getActiveObject(),
    activeGroup = canvas.getActiveGroup();
  if (activeObject) 
    canvas.remove(activeObject);
  

//Drag and drop delete
$(function() 
  $('#delete').droppable(
    drop: function(event, ui) 
      deleteObjects();
    
  );
);

html

<section class="canvas__container">
  <canvas id="canvas"  ></canvas>
  <div id="delete">&#x267B;</div>
</section>

(我没有粘贴我的 CSS,因为这不是特别相关)

【问题讨论】:

我在下面留下了答案,如果您还需要什么,请告诉我?您倾向于包含在画布中可能是您​​最好的选择。 @TimHarker 非常感谢您的帮助,这太棒了。没有别的了,谢谢,我会努力让自己走得更远,我会从我的斗争中学习:D,并花一些时间查看您的代码以更好地理解它 不用担心。如果您有任何问题,请发布另一个问题,很乐意再次提供帮助。 【参考方案1】:

这应该让你接近:

var bin;
var selectedObject;
fabric.Image.fromURL('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADUAAAA1CAIAAABuhDQnAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAPPSURBVGhDzZd9U+IwEIfv+3+2Gxln9PAEcYRBURQVkVeFe9rdC2laIFsK+Pzh2Cab/ZF9Sfpr9bMpr+/r6+v5+fn+/v5vyuXl5e8U/uGx2Wwy9Pr6yjQ1KIVZ32w2e3x8xL2oiYHJmGCoS1gw6MPB7e2t+iwF5laVUfqIEcGq1WrqZw9YhKXig75bHzlUiTIfFmRZdbCVHfrIG13yALC4utnMRn2EYM9siwEX22NdrA8b1y8ODY62SCzWd4Sd88GdOs5RoO+gObeJTbkY6qOs1OLoFFZ0Rh95UHkriQfX+UTM6Ot2uzr3RCBApfxnrY+T54SbJyAgOADX+krX7NnZGTeAm5ub8/NzfbUHQS2rPlTruJFOp7NYLGQR+P7+5vHz8/Pl5eX6+lonGfG3UPWV6ykPDw/L5VJWyIPQcjHxe43qM93nBEz8nSvk4+OD6KtBNKys9qKPqtYRC3d3d/P5XFYRptMpBei/ZGXyUg0suEaT6OOarq/toHI8HrPIZDLhWn91dTUajdKVE4g+tz2dasH16kSfte1Rp29vb71e7+LiQt78SeFRtPqQ7ExmVGZG4hphoo8fra+jQRx7A5QqJeySjJoNgs5jueQW8zL6Wq0WqSb2wnA41LG0gbm6YRqKUW+9rSFJVkj0mYxJsqDFs4s0Gh1OISlJcGJdr9cRR3ytvQZJsniiT9/FQeMVSwe+86240WiQjuDKxXozEiuzPupULB00OR3Lgmg/DTA09UKxMsfX10fuE8cguA6izHGnU9PJ5IaO7SITX1N9uPjijx1CXKFXCpDR4MfEO8rUh6n+3a5QFqQUGSbvaYrtdnswGBBThqghioO6Tr0kUCUyM4ZMfzH1Z3iosEGksFVPT0/6nELcqQz2TB4R7X5JDJn+bD3fAilsJx0xyDYftDKqxnFkzjfs9XUcHPmYiD0QTQ5ZttDtVkC/31fLaNz6iT6wHkFsuRgKoiB/+ML7+7uprYBLPlB91vspLjFxv1J6L3/JRU5kV0C0RlPaCQX3U9bVQSOcEySftBguCpSwvN8H//xUfVDuLl45yFBBKWt9qP4J35d+5cFaH1gvqpXj2p4jow/tJ9zC/OZBRh9Yb0EV4nqyT6gPyn0L74nfU3wK9MGRazmoWZ9ifeSB9YuhNDjKp52jWB9gc4RdxMUWcbBRn3DQXNyUcz479AFlVXnTYcHCas2zWx8QAjpnJSpZhKW2x9QnSp/AAbhnRmLun/0xGPQJOCBvTPdFJmNiVSaY9TmIETlEsHDP55brR/zDIy8ZYkJ8KAspr+84/Gx9q9U/+FfCZwDz5ogAAAAASUVORK5CYII=', function(img) 
  img.set(
    left: 174,
    top: 329,
    selectable: false
  );
  bin = img;
  canvas.add(img, circle, triangle);
);
canvas.on('object:selected', function(evn) 
  selectedObject = evn.target;
)
canvas.on('mouse:up', function(evn) 
  var x = evn.e.offsetX;
  var y = evn.e.offsetY;
  if (x > bin.left && x < (bin.left + bin.width) &&
    y > bin.top && y < (bin.top + bin.height)) 
    canvas.remove(selectedObject);
  
);

您的 JSFiddle 已更新,https://jsfiddle.net/rekrah/jgruwse0/。

如果您还有其他问题,请告诉我。

【讨论】:

以上是关于在 FabricJS 画布上拖放和删除对象的主要内容,如果未能解决你的问题,请参考以下文章

JQuery-UI 在 Re-Drag 上拖放和重新拖动克隆

是否可以同时在 FabricJS 画布上独立拖放多个对象?

在画布上拖放形状

Jquery拖放和克隆

如何在散点图上拖放

从画布中删除图像-fabricjs(javascript)