帆布。如何在绘制之前获取背景像素

时间:2016-07-18 10:08:02

标签: javascript html5 canvas

我为地图应用程序创建了一个小插件。此插件将文本标签添加到几何要素。它看起来像这样:

enter image description here

在上面的屏幕上,您可以看到地图,水平线串和文字标签。我使用canvascanvas.getContext("2d")和一些标准函数(如ctx.strokeTextctx.fillText等创建了此标签。我现在面临的问题是屏幕上的线串是互动或可移动,我也想让我的标签移动。我不是在问我问题的确切解决方案。我感兴趣的是如何获得背景像素(在我的文字标签下方),以便我可以在我移动"之前恢复它们。或者在新地方重新标记标签。如果你可以提供一个很小的例子,你有一些背景,然后绘制一些对象,然后"删除"它会很棒。

1 个答案:

答案 0 :(得分:2)

您可能希望使用context.getImageData和context.putImageData

假设您的画布具有id" myCanvas",调用doDraw()将导致黑色矩形在复杂背景上闪烁。

首先,在doDraw()中绘制背景。然后,在drawRectangle()中捕获要由矩形覆盖的背景并保存在变量" imageData"中。然后在背景上绘制矩形。然后,1秒后,调用eraseRectangle(),并通过调用putImageData()替换背景。

在这个小提琴中:

https://jsfiddle.net/f3Luxcoc/

这是javascript:

//coordinates of rectangle
var xp = 20;
var yp = 20;
var wp = 80;
var hp = 80;

//saved background image
var imageData = null;

function doDraw() {

 var can = document.getElementById("myCanvas");
 can.width = 500;
 can.height = 500;
 var context = can.getContext("2d");

 //draw background contents  

 var image = getImage();
 context.drawImage(image, 0, 0);
 context.drawImage(image, 100, 0);
 context.drawImage(image, 0, 100);
 context.drawImage(image, 100, 100);

 drawRectangle();
}

function drawRectangle() {    

 var can = document.getElementById("myCanvas");
 var context = can.getContext("2d");

 //capture background 
 imageData = context.getImageData(xp, yp, wp, hp);

 //draw Rectangle
 context.rect(xp, yp, wp, hp);
 context.fill();

 setTimeout(function() {
  eraseRectangle();
 }, 1000);
}

function eraseRectangle() {
  var can = document.getElementById("myCanvas");
  var context = can.getContext("2d");

  context.putImageData(imageData, xp, yp);

  setTimeout(function() {
    drawRectangle();
  }, 1000);
}

doDraw();

function getImage() {
var image1 = new Image(237, 110);
  image1.src =     ""

return image1;
}