canvas 基础知识整理(一)
canvas这个 HTML 元素是为了客户端矢量图形而设计的。它自己没有行为,但却把一个绘图 API 展现给客户端 JavaScript 以使脚本能够把想绘制的东西都绘制到一块画布上。
html的基本结构
<!DOCTYPE html> <html lang="en"> <head> <meta charset=UTF-8> <title>Document</title> <style> #myCanvas{ background: #CCC; } * { margin:0; padding: 0;} html,body{ width: 100%; height: 100%;} canvas{ display: block;} </style> </head> <body> <canvas id="myCanvas" width="800" height="800" ></canvas> </body> </html>
------------------------------分隔线------------------------------------------
第一部分:基本概念等
1. 创建canvas画布
<canvas id="myCanvas" width="800" height="800" ></canvas>
注意:① width、height,这两个属性定义了canvas元素宽和高,从而相应的定义了2D渲染上下文的尺寸。
② 2D渲染上下文的尺寸默认值:宽300像素、高150像素
2. 坐标
左上角为原点(0,0)
右移:x坐标增加
下移:y坐标增加
3. 2D渲染上下文(真正绘制图形的地方)
<script type="text/javascript"> var canvas = document.getElementById('myCanvas'); // 获取canvas的ID var context =canvas.getContext("2d"); </script>
第二部分:矩形
1.绘制矩形
方法:context.fillRect(x,y,width,height);
2.绘制描边矩形
方法:strokeRect(x,y,width,height)
实例:
<script> function draw1(id){ var canvas = document.getElementById(id); var context =canvas.getContext("2d"); context.fillRect(0,0,100,100); // 绘制一个矩形,默认颜色为黑色 context.strokeRect(120, 0, 100, 100); // 绘制描边矩形 }draw1('myCanvas'); </script>
第三部分:线条
线条(路径)绘制步骤:
1)beginPath() 准备
2)moveTo() 绘制路径的原点坐标(x,y)
3) lineTo() 设置线条的终点坐标(x,y)
4) closePath() 完成路径的绘制
5)stroke() 绘制轮廓,显示路径
实例:
<script> function draw1(id){ var canvas = document.getElementById(id); var context =canvas.getContext("2d"); context.beginPath(); context.moveTo(40,40); context.lineTo(140,40); context.closePath(); context.stroke(); }draw1('myCanvas'); </script>
第四部分:圆形
canvas 通过绘制圆弧并将其首尾相连,达到绘制圆形的目的。
创建圆弧的方法:context.arc(x, y, radius, starAngle,endAngle, anticlockwise)
对应参数:
1)圆弧原点的(x,y)坐标值,也就是例子中的圆心
2)圆弧半径
3)开始角度
4)结束角度
5)布尔值(顺时针false,逆时针true)
注意: canvas中的圆是以弧度而不是角度为单位的。
360度(一个完整的圆)是2π(PI的2倍)弧度
实例:
<script type="text/javascript"> function draw1(id){ var canvas = document.getElementById(id); var context =canvas.getContext("2d"); context.beginPath(); context.arc(230,90,50,0,Math.PI*2,false); // 绘制圆形 context.closePath(); context.fill(); // 填充路径 }draw1('myCanvas'); </script>
第五部分:样式
1. fillStyle :给矩形填充颜色
2. strokeStyle:给描边和线条添加颜色
3. lineWidth:修改线宽(线宽默认为1),这个属性也会影响图形
通过设置2D渲染上下文的fillStyle属性,就能够修改形状和路径的填充颜色,如下,绘制一个红色的正方形
<script type="text/javascript"> function draw1(id){ var canvas = document.getElementById(id); var context =canvas.getContext("2d"); context.fillStyle = "red"; // 给图形填充红色 context.fillRect(0,0,50,50); // 一个红色的正方形 context.fillRect(70,70,80,80); // 又一个红色正方形 context.fillStyle = "blue"; // 给图形填充蓝色 context.fillRect(70,70,80,80); // 一个蓝色正方形 context.strokeStyle = "yellow"; // 给图形填充黄色描边 context.strokeRect(170,170,100,100); // 一个黄色描边的正方形 context.strokeStyle = "blue"; // 绘制蓝色线条 context.beginPath(); // 绘制线条开始 context.moveTo(290,290); context.lineTo(350,350); context.closePath(); context.stroke(); // 绘制线条结束 context.lineWidth = 5; // 加粗线条 context.strokeStyle = "blue"; // 绘制蓝色线条 context.beginPath(); context.moveTo(320,340); context.lineTo(370,390); context.closePath(); context.stroke(); // 加粗的线条绘制完成 context.strokeRect(380,380,50,50) // 受影响的图形,描边已加粗 }draw1('myCanvas'); </script>
第六部分:绘制文本
canvas绘制文本:
① canvas中的文本以图片形式绘制,不可用普通文字一样用鼠标指针选取
② 文字绘制后不可编辑,除非先擦除文字,重新绘制
注:通常是使用html来处理文本,使用canvas来处理像素和图形
1.绘制文本:fillText
参数:
准备绘制的文本,文本原点(左下角)的(x,y)坐标值
默认:10px sans-serif
2.修改文字属性:font
3.描边文本:strokeText
<script type="text/javascript"> function draw1(id){ var canvas = document.getElementById(id); var context =canvas.getContext("2d"); var text = "hello world!"; context.font="30px serif" // 把文本大小设置为30px context.fillText(text,40,40); // 绘制文本 context.strokeText(text,40,80); // 描边文笔塔你 }draw1('myCanvas'); </script>
第七部分:擦除canvas
① clearRect();
参数:原点坐标,宽,高
<script type="text/javascript"> function draw1(id){ var canvas = document.getElementById(id); var context =canvas.getContext("2d"); context.beginPath(); // 绘圆开始 context.arc(230,90,50,0,Math.PI*2,false); context.closePath(); context.fill(); // 绘圆结束 context.fillStyle= "blue"; context.fillRect(180,140,100,100); // 正方形绘图完成 context.clearRect(180,140,100,100); // 从原点(180,140)位置开始擦除,擦除掉100 X 100的区域(清除了上面的正方形) context.clearRect(230,90,50,50); // 弧形的原点是它的中心,为了获得clearRect方法所需的正确原点,需要用原点的x,y坐标减去它的半径(清除掉了圆的部分区域) }draw1('myCanvas'); </script>
第八部分:
使canvas填满浏览器窗口
canvas会忽略百分比,将100%解释为100px,所以要使canvas填满窗口,只需将canvas元素的高度和宽度精确设置为浏览器窗口的高度和宽度即可(为了避免随意调整窗口大小会出现滚动条的问题,要配合onresize方法使用)
<script type="text/javascript"> window.onresize = resizeCanvas; function resizeCanvas(){ var canvas = document.getElementById('myCanvas'); var context =canvas.getContext("2d"); canvas.width = window.innerWidth; canvas.height = window.innerHeight; context.fillStyle="red"; context.fillRect(50,50,150,150); }; resizeCanvas(); </script>
随意调整窗口大小,都不会出现滚动条。
-----------------------------------------------------------------------
以上是学习的时候做的笔记,如果有问题,欢迎指正,不甚感激 ~
参考资料 《 HTML5 Canvas 基础教程 》
canvas 基础知识整理(一)的更多相关文章
- canvas 基础知识整理(二)
html部分: <canvas id="myCanvas" width="800" height="800" ></can ...
- Kali Linux渗透基础知识整理(四):维持访问
Kali Linux渗透基础知识整理系列文章回顾 维持访问 在获得了目标系统的访问权之后,攻击者需要进一步维持这一访问权限.使用木马程序.后门程序和rootkit来达到这一目的.维持访问是一种艺术形式 ...
- Kali Linux渗透基础知识整理(二)漏洞扫描
Kali Linux渗透基础知识整理系列文章回顾 漏洞扫描 网络流量 Nmap Hping3 Nessus whatweb DirBuster joomscan WPScan 网络流量 网络流量就是网 ...
- 【OGG】OGG基础知识整理
[OGG]OGG基础知识整理 一.GoldenGate介绍 GoldenGate软件是一种基于日志的结构化数据复制软件.GoldenGate 能够实现大量交易数据的实时捕捉.变换和投递,实现源数据库与 ...
- java部分基础知识整理----百度脑图版
近期发现,通过百度脑图可以很好的归纳总结和整理知识点,本着学习和复习的目的,梳理了一下java部分的知识点,不定期更新,若有不恰之处,请指正,谢谢! 脑图链接如下:java部分基础知识整理----百度 ...
- canvas基础知识
canvas基础知识 ## CanvasDOM对象 #### 获取绘图环境```canvas.getContext();``` #### 设置宽和高```canvas.width = 500;canv ...
- wifi基础知识整理
转自 :http://blog.chinaunix.net/uid-9525959-id-3326047.html WIFI基本知识整理 这里对wifi的802.11协议中比较常见的知识做一个基本的总 ...
- JavaScript基础知识整理
只整理基础知识中关键技术,旨在系统性的学习和备忘. 1.在 JScript 中 null 和 undefined 的主要区别是 null 的操作象数字 0,而 undefined 的操作象特殊值NaN ...
- canvas API ,通俗的canvas基础知识(四)
今天要讲的内容是canvas的转换功能,前面的内容没用看的同学可以出门右转,先看看前面的基础知识,废话不多说,开始进入正题吧! 何为转换功能?熟悉css3的同学都知道,css3里面有transform ...
随机推荐
- HDU 1003 基础dp 最大连续序列和
常常做错的一道题.. 因为总是要有一个长度的 所以一开始的s与e都是1 maxx也是a[1] 然后再求 从i=2开始 在这里注意 me永远是当前i 而ms则可能留在原地 可能直接等于i 判断条件就是当 ...
- [ZZ] Understanding 3D rendering step by step with 3DMark11 - BeHardware >> Graphics cards
http://www.behardware.com/art/lire/845/ --> Understanding 3D rendering step by step with 3DMark11 ...
- pox目录中的交换机mac地址学习模块 l2_multi源码
# Copyright 2012-2013 James McCauley # # Licensed under the Apache License, Version 2.0 (the "L ...
- 各种常用的JSON接口,开动你的大脑你就可以做出各种应用,值得收藏
各种常用的JSON接口,开动你的大脑你就可以做出各种应用,值得收藏 浏览:1412 发布日期:2014/01/27 分类:技术分享 这里为大家搜集了一些能够返回JSON格式的服务接口.部分需要用J ...
- typecho插件编写教程1 - 从HelloWorld说起
typecho插件编写教程1 - 从HelloWorld说起 老高 187 5月25日 发布 推荐 0 推荐 收藏 2 收藏,189 浏览 最近老高正在编写一个关于typecho的插件,由于typec ...
- PHP file_get_contents函数读取远程数据超时的解决方法
PHP file_get_contents函数读取远程数据超时的解决方法 投稿:junjie 字体:[增加 减小] 类型:转载 这篇文章主要介绍了PHP file_get_contents函数读取 ...
- P1379 八数码问题
aoapc上的八数码问题,在luogu上也有类似的题,p1379,经典题目,lrj给出了一个算法,同时给出了三种判重的方法.本来想用std::queue改写一下,但是出了各种问题,只好抄代码ac掉这道 ...
- spring mvc配置文件dispatcher-servlet.xml详解
Spring的配置文档<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="ht ...
- JAVA中的throws和throw的区别
Java 一直对java中的throws和throw不太理解.最近一直在查这两个方面的资料,算是能明白一点吧.如果我下面的观点哪有不对,希望指出来,我加以改进. throw:( ...
- java.lang.ClassNotFoundException: springosgi
该问题困扰多天,终于查到原因. 问题:对webwork源码的修改始终无法加载,osgi总是读取源码中未修改的类 com.opensymphony.webwork.dispatcher.Dispatch ...