html5 canvas 笔记五(合成与裁剪)
globalCompositeOperation
syntax:
globalCompositeOperation = type
注意:下面所有例子中,蓝色方块是先绘制的,即“已有的 canvas 内容”,红色圆形是后面绘制,即“新图形”。
source-over 这是默认设置,新图形会覆盖在原有内容之上。

destination-over 会在原有内容之下绘制新图形。

source-in 新图形会仅仅出现与原有内容重叠的部分。其它区域都变成透明的。

destination-in 原有内容中与新图形重叠的部分会被保留,其它区域都变成透明的。

source-out 结果是只有新图形中与原有内容不重叠的部分会被绘制出来。

destination-out 原有内容中与新图形不重叠的部分会被保留。

source-atop 新图形中与原有内容重叠的部分会被绘制,并覆盖于原有内容之上。

destination-atop 原有内容中与新内容重叠的部分会被保留,并会在原有内容之下绘制新图形

lighter 两图形中重叠部分作加色处理。

darker 两图形中重叠的部分作减色处理。

xor 重叠的部分会变成透明。

copy 只有新图形会被保留,其它都被清除掉。

裁切路径和普通的 canvas 图形差不多,不同的是它的作用是遮罩,用来隐藏没有遮罩的部分。
syntax
clip()
实例:
 function draw() {
   var ctx = document.getElementById('canvas').getContext('2d');
   ctx.fillRect(0,0,150,150);
   ctx.translate(75,75);
   // Create a circular clipping path
   ctx.beginPath();
   ctx.arc(0,0,60,0,Math.PI*2,true);
   ctx.clip();
   // draw background
   var lingrad = ctx.createLinearGradient(0,-75,0,75);
   lingrad.addColorStop(0, '#232256');
   lingrad.addColorStop(1, '#143778');
   ctx.fillStyle = lingrad;
   ctx.fillRect(-75,-75,150,150);
   // draw stars
   for (var j=1;j<50;j++){
     ctx.save();
     ctx.fillStyle = '#fff';
     ctx.translate(75-Math.floor(Math.random()*150),
                   75-Math.floor(Math.random()*150));
     drawStar(ctx,Math.floor(Math.random()*4)+2);
     ctx.restore();
   }
 }
 function drawStar(ctx,r){
   ctx.save();
   ctx.beginPath()
   ctx.moveTo(r,0);
   for (var i=0;i<9;i++){
     ctx.rotate(Math.PI/5);
     if(i%2 == 0) {
       ctx.lineTo((r/0.525731)*0.200811,0);
     } else {
       ctx.lineTo(r,0);
     }
   }
   ctx.closePath();
   ctx.fill();
   ctx.restore();
 }
html5 canvas 笔记五(合成与裁剪)的更多相关文章
- Html5 Canvas 实现图片合成
		
多个图片合成一张 <!doctype html> <html> <head> <meta charset="utf-8"> < ...
 - Html5 Canvas笔记(1)-CanvasAppTemplate代码
		
学了一段时间的Html5 Canvas,现想一段一段的将学习笔记整理出来放上来,先整理一段Canvas的模版文件代码,以后建立Canvas程序就不用重新写这些代码了,当然最好是将这个Html代码保存到 ...
 - html5 canvas画布上合成
		
source-over 默认.在目标图像上显示源图像. source-atop 在目标图像顶部显示源图像.源图像位于目标图像之外的部分是不可见的. source-in 在目标图像中显示源图像.只有目标 ...
 - HTML5学习笔记五:html5表单
		
表单是页面上非常重要的一块内容,用户可输入的大部分内容都是在表单元素中完成的,与后台的交互大多数也是通过点击表单中的按钮. 一.新增的元素和属性 1.新增属性: 1.1 form属性:页面中的任何元素 ...
 - html5 canvas 笔记四(变形 Transformations)
		
绘制复杂图形必不可少的方法 save() 保存 canvas 状态 restore() 恢复 canvas 状态 Canvas 的状态就是当前画面应用的所有样式和变形的一个快照. Canvas 的状态 ...
 - html5 canvas 笔记三(绘制文本和图片)
		
绘制文本 fillText(text, x, y [, maxWidth]) 在指定的(x,y)位置填充指定的文本,绘制的最大宽度是可选的. strokeText(text, x, y [, ma ...
 - html5 canvas 笔记二(添加样式和颜色)
		
色彩 Colors fillStyle = color 设置图形的填充颜色. strokeStyle = color 设置图形轮廓的颜色. 透明度 Transparency globalAlpha = ...
 - html5 canvas 笔记一(基本用法与绘制图形)
		
<canvas> 元素 <canvas id="tutorial" width="150" height="150"> ...
 - Html5 Canvas笔记(3)-Canvas状态
		
p{ font-size: 15px; text-indent: 2em; } .alexrootdiv>div{ background: #eeeeee; border: 1px solid ...
 
随机推荐
- 【android异步处理】一个关于android异步处理的文章系列
			
最近读了Android异步处理系列文章索引,感觉这个文章系列写得不错!可以作为参考
 - Listener监听器使用小案例
			
这里介绍的就是一个客户流失监听器案例 新建一个监听器实现ServletContextListener接口 覆写contextDestroyed和contextInitialized 方法 packag ...
 - Linux磁盘及文件系统管理
			
在LINUX中我们知道一个很重要的概念,那就是"一切皆文件",这里的一切表示所有在LINUX系统的对象,自然也包括了LINUX中的硬盘设备.在LINUX中所有设备都被抽象成一个文件 ...
 - 关于UGUI Image Sliced模式的一个BUG。
			
Unity4.6.2f1 在Android/IOS平台下,Image选择Sliced模式,并且对Sprite设置好Border后,会发现并没有按照预计的 情况进行拉伸. 搜了一下是因为Sprite的G ...
 - isset 和empty 两个函数的用法
			
关于用php 获取当前脚本的url很多朋友会说很简单,但是要获取很详细的就要经过多次判断哦. $PHP_TIME = time();$PHP_SELF = isset($_SERVER['PHP_SE ...
 - 如何获得中国所有的IP地址段
			
转自: https://wjianz.wordpress.com/2014/09/12/howto-%E4%BB%8Eapnic%E8%8E%B7%E5%8F%96%E4%B8%AD%E5%9B%BD ...
 - 序列化(Serialization)据为JSONP远端请求
			
Insus.NET前些日子,有分享了一段代码,<使用JSONP跨域请求数据>http://www.cnblogs.com/insus/p/3512271.html 是使用jQuery的Da ...
 - 【ionic】微信表情设置教程
			
NO.0 前提你的下载我的App :超级逗表情 Andorid:http://fir.im/chaojidbq Ios:https://github.com/apanly/chaojidbq (源码, ...
 - 在windows下新建maven项目
			
1.拷贝settings到.m2文件下 2.修改文件 3.新建Project项目 4.转换为maven项目 config下转换 5.拷贝pom文件 6.新建目录 src/main/java src/m ...
 - centos7 开机画面定制
			
安装包 yum install plymouth-plugin-script 设置开机启动画面 mkdir /usr/share/plymouth/themes/tup 创建主题目录 cp /root ...