我尝试使用phantomjs 2.1.1这段代码:
var webPage = require('webpage');
var page = webPage.create();
page.open("http://google.com", function (status){
var out = page.evaluate(function(){
var image = new Image();
image.src = "";
var x = 0, y = 0;
image.width = 50;
image.height = 50;
var canvas = document.createElement('canvas');
canvas.id = "mycanvas";
canvas.width = 50;
canvas.height = 50;
var context = canvas.getContext("2d");
document.body.appendChild(canvas);
context.drawImage(
image,
x,
y,
canvas.width,
canvas.height,
0,
0,
image.width,
image.height
);
var imageData = context.getImageData(x, y, canvas.width, canvas.height);
var data = imageData.data;
var pix = 0;
var text = "";
// iterate over all rgba values of each pixels
for (var i = 0; i < data.length; i += 4) {
pix++;
red = data[i];
green = data[i+1];
blue = data[i+2];
alpha = data[i+3];
text += "pix " + pix + " red="+red+" green="+green+" blue="+blue+" alpha="+alpha+"\n";
}
return text;
});
console.log("out"+out);
phantom.exit();
});
脚本应该打印此图片的rgba
值,但都是rgba(0,0,0,0)
。
如果您复制粘贴评估部分在Chrome开发工具版本55.0.2883.75 64位或firefox 50.0.2(通过示例),您将从内部看到和值!= rgba(0,0,0,0)
控制台。
所以在casperjs中,我也无法获得rgba
个值。 任何人都知道另一种方法来获取此rgba值并修改base64图像中的值吗?如果可能的话,可以在vanilla javascript中找到
答案 0 :(得分:0)
找到一种解决方法:需要先在另一个yield from ((x, y) for x in i for y in j)
中创建image元素:
evaluate()