Canvas绘图API
Canvas就是一个画布,可以进行任何的线、图形、填充等一系列的操作。
Canvas的Context对象
要使用Canvas来绘制图形必须在页面中添加Canvas的标签
<canvas id="canvasDemo" width="400" height="400">
<p>请使用支持html5的浏览器查看实例</p>
</canvas>
id是必须的,js要用id来那当前的Canvas的Dom对象。通过次Cancas的Dom对象就可以获取它的上下文(Context)。
<script type="text/javascript">
var canvasDom = document.getElementById("canvaDemo");
var context = canvasDom.getContext('2d');
</script>
Context上下文默认两种绘制方式:绘制线(stroke)或填充(fill)。
Canvas绘制步骤:创建HTML页面,设置画布标签。编写js,获取画布dom对象。通过canvas标签的dom对象获取上下文。设置绘制样式、颜色。绘制矩形或填充矩形。
<body>
<canvas id="canvasDemo" width="500" height="500">
<p>请使用支持HMTL5的浏览器查看本实例</p>
</canvas>
<script type="text/javascript">
var canvasDom = document.getElementById("canvasDemo");
var context = canvas.getContext('2d');
context.strokeStyle="red";
context.stroke.Rect(10,10,190,100);
context.fillStyle="blue";
context.fillRect(110,110,100,100);
</script>
</body>
Canvas绘制线条
Context对象的beginPath方法表示开始绘制路径,moveTo(x,y)方法设置线段的起点,lineTo(x,y)方法设置线段的终点,stroke方法用来给透明的线段着色。moveto和lineto方法可以多次使用。最后,还可以使用closePath方法,自动绘制一条当前点到起点的直线,形成一个封闭图形,省却使用一次lineto方法。
<body>
<canvas id="canvasDemo" width="500" height="500" />
<script type="text/javascript">
var canvasDom = document.getElementById("canvasDemo");
var context = canvasDom.getContext("2d");
context.beginPath(); //开始路径绘制
context.moveTo(20, 20); //设置路径起点 坐标为(20, 20)
context.lineTo(200, 200); //绘制一条到(200,20)的直线
context.lineTo(400, 20);
context.closePath();
context.lineWidth = 2.0; //设置线宽
context.strokeStyle = "#CC0000"; //设置线条颜色
context.stroke(); //对颜色进行着色,此时线条才可见
</script>
</body>
Canvas绘制文本
Context上下文对象的fillText(string x, y)方法是用来绘制文本。他的三个参数分别为文本内容、起点的x坐标,y坐标。使用之前,需用font设置文本、大小、样式。strokeText方法用来添加空心字。fillText方法不支持文本断行,即所有文本出现在一行。若要生成多行文本,只有调用多次fillText方法。
<canvas id="canvasDemo" width="500" height="500" />
<script type="text/javascript">
var canvas = document.getElementById("canvasDemo");
var context = canvasDom.getContext("2d");
context.moveTo(200, 200);
context.font = "Bold 50px Arial";
context.textAlign = "left";
context.fillStyle = "#005600";
context.fillText("哈哈", 10, 50);
context.strokeText("blog.itjeek.com", 10, 100);
</script>
Canvas绘制图形和椭圆
Context的arc方法就是绘制原形或椭圆,arc方法的x和y参数是圆心坐标,radius是半径,startAngle和endAnlge则是扇形的起始角度和终止角度,anticlockwise表示做图形时是逆时针(true)还是顺时针(false)。
<canvas id="canvasDemo" width="500" height="500" />
<script type="text/javascript">
var canvasDom = document.getElementById("canvasDemo");
var context = canvasDom.getContext("2d");
context.beginPath();
context.arc(60, 60, 50 , 0, Math.PI * 2, true);
context.lineWidth = 2.0;
context.strokeStyle = "#000";
context.stroke();
</script>
Canvas绘制图片
<canvas id="canvasdemo" height="500" width="500" />
<script type="text/javascript">
var canvasDom = document.getElementById("canvasDemo");
var context = canvasDom.getContext("2d");
var image = new Image();
image.src = "images/a.png";
image.onload = function(){
for(var i = 0 ; i < 10 ; i++){
context.drawImage(image, 100+i*80, 100+i*80);
}
};
</script>
Canvas绘图API的更多相关文章
- Html5 学习系列(五)Canvas绘图API快速入门(2)
Canvas绘图API Demos 上一篇文章中,笔者已经给大家演示了怎么快速用Canvas的API绘制一个矩形出来.接下里我会在本文中给各位介绍Canvas的其他API:绘制线条.绘制椭圆.绘制图片 ...
- Html5 学习系列(五)Canvas绘图API快速入门(1)
引言:Canvas绘图API快速入门 在接触HTML5的初学者包括我都在很多地方见到非常炫的一些页面,甚至好多学习HTML5的开发者都是冲着Web端的页游去的,那么HTML5那么绚丽的页面效果以及游戏 ...
- 引言:Canvas绘图API快速入门
引言:Canvas绘图API快速入门 在接触HTML5的初学者包括我都在很多地方见到非常炫的一些页面,甚至好多学习HTML5的开发者都是冲着Web端的页游去的,那么HTML5那么绚丽的页面效果以及游戏 ...
- canvas绘图API详解
canvas绘图API详解 1.context的状态 矩阵变换属性 当前剪辑区域 context的其他状态属性: strokeStyle, fillStyle, globalAlpha, lineWi ...
- canvas 绘图api的位置问题
很久没碰canvas了,今天因为canvas绘图的为之问题浪费了一些时间. 我们知道canvas的默认宽高是300X150嘛. 实际使用的时候当然是自定义一个高宽啦. 通常我们会习惯性地在js中通过c ...
- 有趣的Javascript:只需一个JS让万恶的IE5、IE6、IE7、IE8全都支持H5原生Canvas绘图(有演示demo)
该demo支持IE5以上任意内核的浏览器 查看演示demo:支持IE5以上版本的浏览器Canvas绘图demo 补充:chats.js和echarts等图表库也可以使用本方法兼容IE6以上浏览器 1. ...
- HTML5 学习总结(四)——canvas绘图、WebGL、SVG
一.Canvas canvas是HTML5中新增一个HTML5标签与操作canvas的javascript API,它可以实现在网页中完成动态的2D与3D图像技术.<canvas> 标记和 ...
- canvas绘图、WebGL、SVG
目录 一.Canvas 1.1.创建canvas元素 1.2.画线 1.3.绘制矩形 1.4.绘制圆弧 1.5.绘制图像 1.6.绘制文字 1.7.随机颜色与简单动画 二.WebGL 2.1.HTML ...
- HTML5 学习笔记(四)——canvas绘图、WebGL、SVG
一.Canvas canvas是HTML5中新增一个HTML5标签与操作canvas的javascript API,它可以实现在网页中完成动态的2D与3D图像技术.<canvas> 标记和 ...
随机推荐
- VS2012外接程序VMDebugger未能加载或导致了异常
转http://blog.csdn.net/maryhuan/article/details/42676915 故障现象:打开Visual Studio 2010后弹出错误框,外接程序VMDebugg ...
- 修改WAMPServer中MySql中文乱码的方法
修改MySql的配置文件my.ini,在[client]段落增加:default-character-set=utf8;在[mysqld]段落增加:character_set_server=utf8; ...
- oracle Redhat64 安装错误3
问题描述 /usr/bin/ld: cannot find -lxxx 其中xxx即表示函式库文件名称,其命名规则是:lib+库名(即xxx)+.so. 可能原因: 1 安装了,但相对应的lib版本 ...
- eclipse-mysql-tomcat搭建jspk开发环境
...本来不想写,刚刚给女朋友又安了一次发现几乎忘了,还是记一下吧.. 1.默认安装好jdk以及eclipse或相关ide. 2.检查jdk环境变量是否配置成功:cmd下输入 java -versio ...
- 在 Ubuntu 上配置高性能的 HHVM 环境
HHVM全称为 HipHop Virtual Machine,它是一个开源虚拟机,用来运行由 Hack(一种编程语言)和 PHP 开发应用.HHVM 在保证了 PHP 程序员最关注的高灵活性的要求下, ...
- 搞懂offsetY、offsetTop、scrollTop、offsetHeight、scrollHeight
先搞offsetTop,最难懂的就是它了 官方解释:返回当前元素的上边界到它的包含元素的上边界的偏移量,以像素为单位.这真TM坑爹啊!有木有!经过仔细研究查找得出结论:offsetTop是相对于离它最 ...
- bzoj 1965: [Ahoi2005]SHUFFLE 洗牌
#include<cstdio> #include<cstring> #include<iostream> #define ll long long using n ...
- TaskTracker启动过程源码级分析
TaskTracker也是作为一个单独的JVM来运行的,其main函数就是TaskTracker的入口函数,当运行start-all.sh时,脚本就是通过SSH运行该函数来启动TaskTracker的 ...
- 线程系列3---ThreadLocal类研究
2013-12-23 17:44:44 Java为线程安全提供了一些工具类,如ThreadLocal类,它代表一个线程局部变量,通过把数据放在ThreadLocal中就可以让每个线程创建一个该变量的副 ...
- windbg调试C#代码(一)
用windbg调试C#代码是比较麻烦的,因为windbg是针对OS层级的,而C#被CLR隔了一层,很多原生的命令如查看局部变量dv.查看变量类型dt等在CLR的环境中都不能用了.必须使用针对CLR的扩 ...