Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/html/75.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 帆布。如何在绘图前获取背景像素_Javascript_Html_Canvas - Fatal编程技术网

Javascript 帆布。如何在绘图前获取背景像素

Javascript 帆布。如何在绘图前获取背景像素,javascript,html,canvas,Javascript,Html,Canvas,我为我的地图应用程序创建了一个小插件。此插件将文本标签添加到几何特征中。看起来是这样的: 在上面的屏幕上,您可以看到地图、水平线字符串和文本标签。我使用canvas、canvas.getContext(“2d”)和一系列标准函数(如ctx.strokeText、ctx.fillText等)创建了这个标签。我现在面临的问题是,屏幕上的线条字符串是交互式的或可移动的,我希望我的标签也可以移动。我不是在问我的问题的确切解决办法。我感兴趣的是如何取回像素(就在我的文本标签下面),这样我就可以在“移动”

我为我的地图应用程序创建了一个小插件。此插件将文本标签添加到几何特征中。看起来是这样的:


在上面的屏幕上,您可以看到地图、水平线字符串和文本标签。我使用
canvas
canvas.getContext(“2d”)
和一系列标准函数(如
ctx.strokeText
ctx.fillText
等)创建了这个标签。我现在面临的问题是,屏幕上的线条字符串是交互式的或可移动的,我希望我的标签也可以移动。我不是在问我的问题的确切解决办法。我感兴趣的是如何取回像素(就在我的文本标签下面),这样我就可以在“移动”或在新位置重新绘制标签之前恢复它们。如果您可以提供一个很小的示例,其中您有一些背景,然后绘制一些对象,然后“删除”它,那将非常好。

您可能需要使用context.getImageData和context.putImageData

假设画布的id为“myCanvas”,则调用doDraw()将导致黑色矩形在复杂背景上闪烁

首先,在doDraw()中绘制背景。然后,将被矩形覆盖的背景捕获到drawRectangle()中,并保存在变量“imageData”中。然后在背景上绘制矩形。然后,1秒后,调用eraseRectangle(),并用调用putImageData()替换背景

在这把小提琴中:

下面是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;
}

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

假设画布的id为“myCanvas”,则调用doDraw()将导致黑色矩形在复杂背景上闪烁

首先,在doDraw()中绘制背景。然后,将被矩形覆盖的背景捕获到drawRectangle()中,并保存在变量“imageData”中。然后在背景上绘制矩形。然后,1秒后,调用eraseRectangle(),并用调用putImageData()替换背景

在这把小提琴中:

下面是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;
}

也许您可以使用某种“分层”解决方案。也许您可以使用某种“分层”解决方案。