2017-02-23 121 views
0

我有一個PNG圖像,有一些透明的部分。現在我想將顏色疊加層應用於圖像的非透明部分,同時保持透明部分不變。如何用Easeljs/Createjs中的顏色疊加位圖的非透明部分?

如果我使用ColorFilter它填充整個位圖。我也嘗試了AlphaMaskFilter(使用與源代碼相同的PNG),但它也不起作用。整個位圖總是以顏色填充。

有關如何做到這一點的其他建議?

回答

3

你會寫一個過濾器,或者:

  • 作品像AlphaMaskFilter,只使用rect()source-out compositeOperation OR
  • 作品像AlphaMapFilter,而是畫在那裏遇到了像素着色源圖像中的空像素。

下面是使用上述第一種方法的樣本插件,這可能是最有效的:

(function() { 
    "use strict"; 
    function ColorMaskFilter(color) { 
     this.color = color; 
    } 
    var p = createjs.extend(ColorMaskFilter, createjs.Filter); 
    p.applyFilter = function (ctx, x, y, width, height, targetCtx, targetX, targetY) { 
     if (!this.color) { return true; } 
     targetCtx = targetCtx || ctx; 
     if (targetX == null) { targetX = x; } 
     if (targetY == null) { targetY = y; } 

     targetCtx.save(); 
     if (ctx != targetCtx) { 
      return false; 
     } 

     targetCtx.globalCompositeOperation = "source-out"; // Use source-in to fill the shape instead 
    targetCtx.fillStyle = this.color; 
     targetCtx.rect(targetX,targetY,width,height); 
    targetCtx.fill(); 

     targetCtx.restore(); 
     return true; 
    }; 
    p.clone = function() { 
     return new AlphaMaskFilter(this.color); 
    }; 
    createjs.ColorMaskFilter = createjs.promote(ColorMaskFilter, "Filter"); 
}()); 

我用這個例子放在一起快速小提琴:http://jsfiddle.net/dbtwd463/

注:編輯從原來只是建議的方法,包括一個樣品和小提琴

+0

您好,感謝您的回答。根據你的建議,我在下面發佈了一個ColorMaskFilter過濾器。它似乎正在按預期工作,但如果您可以請看看,我將不勝感激。 – supersan

+1

你的方法應該沒問題 - 但這裏基於AlphaMaskFilter更簡單。 http://jsfiddle.net/dbtwd463/ – Lanny

+0

謝謝。非常感謝您的投入和時間。我將你的答案標記爲已接受的答案。當你有機會的時候,請按照SO推薦的那樣用小提琴的複製粘貼來更新你的答案。 – supersan

1

根據蘭尼的建議,我可以拿出噸他的過濾器。

<script src="https://code.createjs.com/createjs-2015.11.26.min.js"></script> 
 

 
<canvas id="canvas" width="50" height="50" style="border:1px solid red; background: pink"> 
 
     no canvas! 
 
    </canvas> 
 

 
<script> 
 
    var canvas = document.getElementById('canvas'); 
 
    var ctx = canvas.getContext("2d"); 
 
    var stage = new createjs.Stage(canvas); 
 

 
    function init(img) { 
 
    var bmp = new createjs.Bitmap(img); 
 
    stage.addChild(bmp); 
 
    
 
    bmp.filters = [new createjs.ColorMaskFilter('#ffff00')]; 
 
    bmp.cache(0, 0, 30, 30); 
 

 
    stage.update(); 
 
    } 
 

 
    (function() { 
 
    "use strict"; 
 

 
    function ColorMaskFilter(color) { 
 
     this.color = color; 
 
    } 
 

 
    var p = createjs.extend(ColorMaskFilter, createjs.Filter); 
 

 
    p.applyFilter = function(ctx, x, y, width, height, targetCtx, targetX, targetY) { 
 
     targetCtx = targetCtx || ctx; 
 
     if (targetX == null) { 
 
     targetX = x; 
 
     } 
 
     if (targetY == null) { 
 
     targetY = y; 
 
     } 
 

 
     targetCtx.save(); 
 
     if (ctx != targetCtx) { 
 
     // TODO: support targetCtx and targetX/Y 
 
     // clearRect, then draw the ctx in? 
 
     return false; 
 
     } 
 

 
     if (!this.mask || this.mask.width != width || this.mask.height != height) { 
 
     var shape = new createjs.Shape(); 
 
     shape.graphics.beginFill(this.color || '#ff0000'); 
 
     shape.graphics.drawRect(0, 0, width, height); 
 
     shape.cache(0, 0, width, height); 
 

 
     this.mask = shape.cacheCanvas; 
 
     } 
 

 
     targetCtx.globalCompositeOperation = "source-in"; 
 
     targetCtx.drawImage(this.mask, targetX, targetY); 
 
     targetCtx.restore(); 
 
     return true; 
 
    }; 
 

 
    /** docced in super class **/ 
 
    p.clone = function() { 
 
     return new ColorMaskFilter(this.color); 
 
    }; 
 

 
    /** docced in super class **/ 
 
    p.toString = function() { 
 
     return "[ColorMaskFilter]"; 
 
    }; 
 

 

 
    createjs.ColorMaskFilter = createjs.promote(ColorMaskFilter, "Filter"); 
 
    }()); 
 
</script> 
 

 
<hr>Source: <img width="30" height="30" onload="init(this)" title="" alt="" src="" 
 
/>