gpt4 book ai didi

javascript - HTML5 Canvas |图案显示基于图案像素颜色的重叠线条艺术

转载 作者:行者123 更新时间:2023-12-03 11:51:25 25 4
gpt4 key购买 nike

我需要通过canvas元素将一种颜色(黑色)位图图像(线条艺术)应用到2种颜色(红色和黄色)位图图像(图案)上,并且只有该图案的红色像素被着色重叠的线条艺术,有点像相交。我看到了这个: https://developer.mozilla.org/en/docs/Web/Guide/HTML/Canvas_tutorial/Compositing (请参阅 globalCompositeOperation > Darker method )并想知道这种效果是否是我需要的。由于该方法似乎不再受支持,有没有办法模拟这种效果?用于此目的的所有图像仅包含专色(100% 红色、100% 黄色、100% 黑色、100% 白色)。任何导致解决方案的 JavaScript 代码示例或提示都很棒。感谢您的输入。

最佳答案

如果您可以仅将红色部分隔离到单独的图像上,那么您可以使用合成来重新着色黑色与红色相交的位置。

否则,您可以使用 context.getImageData 获取两个图像上的所有像素颜色。

然后您可以将红色和黑色相交处的红色像素更改为黑色。

enter image description here

示例代码和演示:http://jsfiddle.net/m1erickson/pcsmbr22/

<!doctype html>
<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="reset.css" /> <!-- reset css -->
<script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>
<style>
body{ background-color: ivory; margin:20px; }
canvas{border:1px solid red;}
</style>
<script>
$(function(){

var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var canvasB=document.getElementById("black");
var ctxB=canvasB.getContext("2d");
var canvasC=document.getElementById("color2");
var ctxC=canvasC.getContext("2d");

ctxB.fillRect(50,50,50,100);
ctxC.fillStyle='yellow';
ctxC.fillRect(75,50,50,50);
ctxC.fillStyle='red';
ctxC.fillRect(75,100,50,50);

var iDataB=ctxB.getImageData(0,0,canvasB.width,canvasB.height);
var dataB=iDataB.data;
var iDataC=ctxC.getImageData(0,0,canvasC.width,canvasC.height);
var dataC=iDataC.data;

// copy yellow-red onto results canvas
ctx.drawImage(canvasC,0,0);

var iData=ctx.getImageData(0,0,canvas.width,canvas.height);
var data=iData.data;

// copy black pixels when intersecting red pixels
for(var i=0;i<dataC.length;i+=4){
var isBlack=(dataB[i]==0 && dataB[i+1]==0 && dataB[i+2]==0 && dataB[i+3]==255);
var isRed=(dataC[i]==255 && dataC[i+1]==0 && dataC[i+2]==0 && dataC[i+3]==255);
if(isBlack && isRed){
data[i]=0;
data[i+1]=0;
data[i+2]=0;
data[i+3]=255;
}
}
ctx.putImageData(iData,0,0);

}); // end $(function(){});
</script>
</head>
<body>
<canvas id="black" width=200 height=200></canvas>
<canvas id="color2" width=200 height=200></canvas>
<canvas id="canvas" width=200 height=200></canvas>
</body>
</html>

关于javascript - HTML5 Canvas |图案显示基于图案像素颜色的重叠线条艺术,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25827051/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com