HTML5自学笔记[ 11 ]canvas绘图基础1
html5新增<canvas>标签用于绘制图像,默认宽高是300*150,canvas的宽高需要在这里设置,在css中设置会有问题:设置的形状,如矩形,会等比缩放,而非设置的宽高。
在不支持canvas的浏览器里会显示这行文字,这里的文字颜色要和canvas背景色一致才行:
<canvas id="canvas1" width="1000" height="1000"> <span>该浏览器不支持canvas</span> </canvas>在canvas画布上绘制图像,必须借助JavaScript脚本,JavaScript提供了绘制图像的接口和一系列方法:
var oCanvas = document.getElementById('canvas1'); var oContext = oCanvas.getContext('2d'); //获取绘图的2d环境绘制填充的矩形,默认填充黑色,参数:矩形左上角x坐标、矩形左上角y坐标、矩形宽、矩形高;绘制一个顶点为(50,20)宽为100,高为50的矩形如下:
oContext.fillRect(50,20,100,50);绘制边框矩形,默认边框色为黑色,边框宽度为1px;参数和填充矩形一样;例如下:
oContext.strokeRect(50,20,100,50);注:实际浏览器显示的边框为2px,若要显示1px,就要将起点坐标偏移0.5px;例如下:
oContext.strokeRect(50.5,20.5,100,50);绘制路径所需的方法:
- beginPath() --> 准备开始绘制,如果不写这个方法,就会出问题
- moveTo(x1,y1) --> 画笔移动到起始点
- lineTo(xn,yn) --> 画笔移动到第二个点,多次使用这个方法,可绘制多边形
- closePath() --> 闭合路径,即:将画笔从(xn,yn)移动到起始点,若不写,多边形不闭合
- stroke() --> 绘制若干直线,依次连接(x1,y1)、(x2,y2)...、(xn,yn)
- fill() --> 填充多边形
- fillStyle --> 填充色
- strokeStyle --> 边框颜色
- lineWidth --> 边框线宽
例1.绘制一个任意三角形,不填充:
oContext.beginPath(); 2 oContext.moveTo(100,50); 3 oContext.lineTo(50,100); 4 oContext.lineTo(200,100); 5 oContext.closePath(); 6 oContext.stroke();例2.绘制一个四边形,填充红色:
oContext.beginPath(); oContext.moveTo(100,50); oContext.lineTo(50,100); oContext.lineTo(200,100); oContext.lineTo(300,50); oContext.closePath(); oContext.fillStyle = 'red'; oContext.fill();例3.绘制两条直线:
oContext.beginPath(); oContext.moveTo(100,50); oContext.lineTo(50,100); oContext.lineTo(200,100); oContext.stroke();clearRect:该方法用于清除画布中指定矩形区域内的图形,参数:x/y/w/h:
oContext.clearRct(0,0,oCanvas.width,oCanvas.height);前面说过,如果不写beginPath就会出问题,看下面的例子:
画两个三角形,第一个仅画边框,第二个填充颜色,正确写法如下:
oContext.beginPath(); oContext.moveTo(100,50); oContext.lineTo(50,100); oContext.lineTo(200,100); oContext.closePath(); oContext.stroke(); oContext.beginPath(); oContext.moveTo(100,150); oContext.lineTo(50,200); oContext.lineTo(200,200); oContext.closePath(); oContext.fill();
但是如果第二个不写beginPath,那么fill就找不到第二个三角形的起始点,因此会连同前面的形状一起填充:
oContext.beginPath(); oContext.moveTo(100,50); oContext.lineTo(50,100); oContext.lineTo(200,100); oContext.closePath(); oContext.stroke(); oContext.moveTo(100,150); oContext.lineTo(50,200); oContext.lineTo(200,200); oContext.closePath(); oContext.fill();
如果在绘制第一个三角形前设置填充色,就会作用于后面的每一个填充,如果只想让该设置只作用于第一个形状,那么应该先保存路径save并在开始第二个路径前恢复路径restore:
oContext.save(); oContext.fillStyle = 'red'; oContext.beginPath(); oContext.moveTo(100,50); oContext.lineTo(50,100); oContext.lineTo(200,100); oContext.closePath(); oContext.fill(); oContext.restore(); oContext.beginPath(); oContext.moveTo(100,150); oContext.lineTo(50,200); oContext.lineTo(200,200); oContext.closePath(); oContext.fill();
HTML5自学笔记[ 11 ]canvas绘图基础1的更多相关文章
- HTML5自学笔记[ 17 ]canvas绘图基础4
绘制图像: drawImage(oImg,x,y),oImg是一个Image对象,(x,y)为绘制起点,绘制的图像大小和源图大小一样. drawImage(oImg,x,y,w,h),后两个参数设置绘 ...
- HTML5自学笔记[ 16 ]canvas绘图基础3
canvas还提供提供了一些动态方法,使图像可以旋转.缩放和移动,与css3中的方法一样. 移动:translate(x,y),x和y为横竖方向的偏移量 旋转:rotate(弧度),弧度=角度*Mat ...
- HTML5自学笔记[ 14 ]canvas绘图基础2
canvas绘制路径不仅可以绘制直线和多边形,还提供了绘制曲线的方法,利用这些方法可以画出多种曲线效果. 方法1:arc(x,y,r,起始弧度,结束弧度,绘制方向);其中(x,y)为圆心坐标,r为半径 ...
- HTML5自学笔记[ 23 ]canvas绘图基础7
变换矩阵: transform(a,b,c,d,e,f),多次使用该函数,效果是多次状态改变的累加: setTransform(a,b,c,d,e,f),会忽略之前的变换,从起始状态开始改变.
- HTML5自学笔记[ 15 ]canvas绘图基础6
关于线条的一些属性: lineCap,这个属性表示的是线条两端的样式,值有butt(默认)/round/square. lineJoin,这个属性表示线条相交的方式,值有miter(默认)/bevel ...
- HTML5自学笔记[ 18 ]canvas绘图基础5
获取图像数据:getImgData(x,y,w,h),返回的是一个ImageData对象,这个对象有三个属性保存图像信息:width/height/data.data是一个数组,保存了每个像素的信息, ...
- HTML5自学笔记[ 15 ]canvas绘图实例之钟表
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- HTML5自学笔记[ 13 ]canvas绘图小实例之方块移动
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- HTML5自学笔记[ 12 ]canvas绘图小示例之鼠标画线
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
随机推荐
- 通过继承Rect类编写一个具有确定位置的矩形类PlainRect,其确定位置用 矩形的左上角坐标来标识,包含: 添加两个属性:矩形左上角坐标startX和startY。 两个构造方法: 带4个参数的构造方法,用于对startX、startY、width和height属性 初始化; 不带参数的构造方法,将矩形初始化为左上角坐标、长和宽都为0 的矩形; 添加一个方法: 判断某个点是否在矩形内部的方法
package b; public class Rect { Double width; Double height; public Double getWidth() { return width; ...
- DIV的表单布局
表单布局其实用表格最好了,可是表格的话,无法定位,这个是一个硬伤. <!DOCTYPE html> <html> <head> <meta charset=& ...
- C#在泛型类中,通过表达式树构造lambda表达式
场景 最近对爬虫的数据库架构做调整,需要将数据迁移到MongoDB上去,需要重新实现一个针对MongoDB的Dao泛型类,好吧,动手开工,当实现删除操作的时候问题来了. 我们的删除操作定义如下:voi ...
- Margin and Padding in Windows Forms Controls
https://msdn.microsoft.com/en-us/library/ms229627.aspx Margin and Padding Precise placement of contr ...
- CANopen笔记1
CAN现场总线只定义了OSI网络模型的第一层(物理层) 和第二层(数据链路层) ,而这两层一般已被CAN硬件完全实现了.由于没有规定应用层,本身并不完整,需要一个高层协议来定义CAN报文中的11/29 ...
- printf()函数
printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出信息. printf()函数的调用格式为: printf("<格式化字符串>", <参 ...
- vim使用札记
最近开始用vim编辑器了,从最开始的配置到现在慢慢使用,我在这儿会贴出一些我的使用上遇到过的问题和如何解决的方案,留给自己和一些会用到的人看看 1.vim怎么使汇编语法高亮 开始不知道,然后把文件的后 ...
- JVM 1.类的加载、连接、初始化
Java类的加载是由类加载器来完成的,过程如下: 首先,加载是把硬盘.网络.数据库等的class文件中的二进制数据加载到内存的过程,然后会在Java虚拟机的运行时数据区的堆区创建一个Class对象,用 ...
- Codeforces Round #279 (Div. 2) C. Hacking Cypher 前缀+后缀
C. Hacking Cypher time limit per test 1 second memory limit per test 256 megabytes input standard in ...
- 模仿$.Callbacks实现
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

