我正在尝试编写一个Darkroom.JS插件,将图像中的空白区域转换为透明度。
我已使用此answer(仅基于画布)编写此代码:
(function() {
'use strict';
var Transparency = Darkroom.Transformation.extend({
applyTransformation: function(canvas, image, next) {
console.log(canvas);
console.log(image);
var context = canvas.getContext("2d");
var upperContext = $('.upper-canvas').get(0).getContext("2d");
var imageData = context.getImageData(0, 0, image.getWidth(), image.getHeight());
//var upperImageData = upperContext.createImageData(image.getWidth(), image.getHeight());
console.log("apply transformation called");
for(var i = 0, n = imageData.data.length; i < n; i +=4){
var r = imageData.data[i],
g = imageData.data[i+1],
b = imageData.data[i+2];
if(r >= 230 && g >= 230 && b >= 230){
imageData.data[i] = 0;
imageData.data[i+1] = 0;
imageData.data[i+2] = 0;
imageData.data[i+3] = 1;
}
};
context.putImageData(imageData, 0, 0);
upperContext.putImageData(imageData, 0, 0);
//canvas.renderAll();
next();
}
});
Darkroom.plugins['transparency'] = Darkroom.Plugin.extend({
defaults: {
clearWhiteSpace: function() {
this.darkroom.applyTransformation(
new Transparency()
);
}
},
initialize: function InitializeDarkroomTransparencyPlugin() {
var buttonGroup = this.darkroom.toolbar.createButtonGroup();
this.destroyButton = buttonGroup.createButton({
image: 'wand' //Magic Wand by John O'Shea from the Noun Project
});
this.destroyButton.addEventListener('click', this.options.clearWhiteSpace.bind(this));
},
});
})();
(我还应该注意,我基于现有rotate plugin的插件结构)
代码被调用,我目前在代码中没有它(出于性能原因),但是一条日志语句表明也会调用完成像素编辑的if块。
要验证,我目前将像素设置为完全不透明和黑色(而不是透明,以便我可以看到编辑效果)。
另外,我注意到Darkroom.JS似乎生成了两个画布对象,一个上部画布和下部画布。传递给transform函数的对象是&#34; lower canvas&#34;对象,所以我甚至尝试使用jQuery来抓住&#34;鞋帮&#34;一,并设置图像数据,无济于事。
我错过了什么?
答案 0 :(得分:0)
我正专注于在Darkroom.JS上寻找答案。 Darkroom.JS只是Fabric.JS上的一个层,这个答案占据了关键: fabric js or imagick remove white from image
我实际上使用了第二个答案,它完美无缺:
所以Fabric.js中有一个过滤器可以做到这一点。
http://fabricjs.com/docs/fabric.Image.filters.RemoveWhite.html
var filter = new fabric.Image.filters.RemoveWhite({threshold:40,
距离:140}); image.filters.push(过滤器); image.applyFilters(canvas.renderAll.bind(画布));
这是我完成的代码(删除了一些无关的细节以简化):
fabric.Image.fromURL(imgData.URL, function(logoImg){
canvas.add(logoImg);
var threshold = 40;
var whitespace = function(){
var filter = new fabric.Image.filters.RemoveWhite({
threshold: threshold,
distance: 140
});
threshold+=20;
logoImg.filters.push(filter);
logoImg.applyFilters(canvas.renderAll.bind(canvas));
};
});