您的位置:首页> HTML5教程> canvas API

canvas globalCompositeOperation 属性

2019-8-30 12:05| 作者: admin| 查看: 360| 评论: 0|来自: 蚂蚁部落

此属性设置或返回如何将一个源(新的)图像绘制到目标(已有的)的图像上。

(1).源图像:您打算放置到画布上的绘图。

(2).目标图像:您已经放置在画布上的绘图。

语法结构:

[JavaScript] 纯文本查看 复制代码
context.globalCompositeOperation="source-in";

属性值说明:

(1).source-over:默认,在目标图像上显示源图像。

(2).source-atop:在目标图像顶部显示源图像。源图像位于目标图像之外的部分是不可见的。

(3).source-in:在目标图像中显示源图像。只有目标图像之内的源图像部分会显示,目标图像是透明的。

(4).source-out:在目标图像之外显示源图像。只有目标图像之外的源图像部分会显示,目标图像是透明的。

(5).destination-over:在源图像上显示目标图像。

(6).destination-atop:在源图像顶部显示目标图像。目标图像位于源图像之外的部分是不可见的。

(7).destination-in:在源图像中显示目标图像。只有源图像之内的目标图像部分会被显示,源图像是透明的。

(8).destination-out:在源图像之外显示目标图像。只有源图像之外的目标图像部分会被显示,源图像透明。

(9).lighter:显示源图像 + 目标图像。

(10).copy:显示源图像,忽略目标图像。

(11).xor:使用异或操作对源图像与目标图像进行组合。

属性值具体表现如下:

a:3:{s:3:\"pic\";s:43:\"portal/201908/30/121152oq12pa5pypa2pnn3.jpg\";s:5:\"thumb\";s:0:\"\";s:6:\"remote\";N;}

浏览器兼容:

(1).IE9+浏览器支持此属性。

(2).edge浏览器支持此属性。

(3).谷歌浏览器支持此属性。

(4).火狐浏览器支持此属性。

(5).Opera浏览器支持此属性。

(6).Safari浏览器支持此属性。

代码实例如下:

[HTML] 纯文本查看 复制代码运行代码
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>蚂蚁部落</title>
<style>
canvas{
  border:1px solid #d3d3d3;
  width:300px;
  height:150px;
}
</style> 
<script>
window.onload = () => {
  let cvs=document.getElementById("ant");
  let ctx=cvs.getContext("2d");
  ctx.fillStyle="red";
  ctx.fillRect(20,20,75,50);
  ctx.fillStyle="blue";        
  ctx.globalCompositeOperation="source-over";
  ctx.fillRect(50,50,75,50);        
  ctx.fillStyle="red";
  ctx.fillRect(150,20,75,50);
  ctx.fillStyle="blue";        
  ctx.globalCompositeOperation="destination-over";
  ctx.fillRect(180,50,75,50);
}
</script>
</head>
<body>
  <canvas id="ant">当前浏览器不支持canvas标签</canvas>
</body>
</html>

代码运行效果截图如下:

a:3:{s:3:\"pic\";s:43:\"portal/201908/30/120605juto1at8ojese79e.jpg\";s:5:\"thumb\";s:0:\"\";s:6:\"remote\";N;}

非常简单的效果,可以对照前面的属性值作用观察具体表现。


鲜花

握手

雷人

路过

鸡蛋

最新评论

返回顶部