初学画布canvas的chapter1
——这篇读后感是我阅读《写给Web开发人员看的HTML5教程》一书中的第5章画布后的小小看法,由于编程实力有限,很多效果病没有一一去实现,所以只是停留在纸上谈兵的阶段。
画布(canvas)作为HTML5新增的最有趣最出名的元素之一,程序员可以通过canvas元素实现非常多有趣的功能,虽然现今只是停留在2D环境,但未来不排除加入3D等环境的可能;而且我们也可以通过一些方法实现伪3D的效果。
要使用元素canvas,我们要先对它进行定义:
<canvas width="" height="">
</canvas>
元素开始与结束标记之间的区域是用于浏览器不支持canvas时显示。
定义完元素canvas之后,我们就要在JavaScript中加入绘制命令,首先要引用canvas:
var canvas = document.querySelector("canvas");——querySelector是jQuery引入的方法
其次要定义它的绘制环境:
var context = cnvas.getContext('2d');
然后就可以开始绘制了。
以下是阅读完第五章后了解到的有关canvas的一些应用:
矩形,颜色和阴影及渐变
1.矩形可以通过四种方法来创建:
context.fillRect(x,y,w,h) ——创建被填充的矩形
context.strokeRect(x,y,w,h) ——创建有边框无填充的矩形
context.clearRect(x,y,w,h) ——创建橡皮擦
context.rect(x,y,,h) ——通过路径创建矩形
2.颜色:
FillStyle——定义填充颜色
strokeStyle——定义线条颜色
颜色的有效值:
Hexadecimal ——#FF0000
Hexadecimal(short) ——#F00
RGB ——rgb(255,0,0)
RGB(percent) ——rgb(100%,0%,0%)
RGBA ——rgba(255,0,0,1.0)
RGBA(percent) ——rgba(100%,0%,0%,1.0)
HSL ——hsl(0,100%,50%)
HSLA ——hsla(0,100%,50%,1.0)
SVG(named color) ——red
3.阴影:
context.shadowOffsetX = ——定义阴影的X轴偏移量
context.shadowOffsetY = ——定义阴影的Y轴偏移量
context.shadowColor = ——定义阴影的颜色及透明度
context.shadpwBlur = ——定义阴影的模糊度
4.渐变:
var linGrad = context.createl.inearGradient(x0,y0,x1,y1);
——创建变量存储CanvasGradient对象并通过x0,y0,x1,y1定义渐变方向。
linGrad.addColorStop(0.0,’red’); ——代表起点上的颜色
linGrad.addColorStop(0.5,’yellow’); ——渐变颜色
linGrad.addColorStop(1.0,’purple’); ——代表终点上的颜色
路径绘图
线段:
初始化路径:beginPath()
定义路径轨迹:moveTo()和lineTo()
画线:stroke()
曲线:
context.quadraticCurveTo(cpx,cpy,x,y)
context.bezierCurveTo(cp1x,cp1y,cp2x,cp2y,x,y)
弧线:
context.artTo(x1,y1,x2,y2,radius)
context.arc(x,y,radius.startAngle,endAngle,anticlockwise)
轮廓:
context.lineWidth = [] ——定义线条粗细
context.lineCap = [] ——定义线条两端线端
context.lineJoin = [] ——定义交点
填充:
context.fill()
遮罩:
context.clip() ——定义路径图不被画出来
初学画布canvas的chapter1的更多相关文章
- 初学画布canvas的chapter2
文本 1.字体属性 context.font = [css font property] ——使用CSS规范,语法跟CSS字体速记符号一致 ——line-height无效,并永远忽略 Context. ...
- HTML 5 画布(canvas)
canvas 元素使用 JavaScript 在网页上绘制图像,本身是没有绘图能力. canvas 是一个矩形区域,可以控制其每一像素. canvas 拥有多种绘制路径.矩形.圆形.字符以及添加图像的 ...
- HTML5画布Canvas
一.Canvas概念介绍 1.概念 Canvas : 画布 2.作用 : HTML5 Canvas 元素用于图形的绘制, 通过脚本(通常是JavaScript)来完成.它本身只是个图形容器,必须使用脚 ...
- HTML5画布(CANVAS)速查简表
HTML5画布(CANVAS)速查简表 http://www.webhek.com/misc/html5-canvas-cheat-sheet/
- PHP《将画布(canvas)图像保存成本地图片的方法》
用PHP将网页上的Canvas图像保存到服务器上的方法 2014年6月27日 歪脖骇客 发表回复 8 在几年前HTML5还没有流行的时候,我们的项目经理曾经向我提出这样一个需求:让项目评审专家们在评审 ...
- Tkinter画布-Canvas
Python - Tkinter画布-Canvas: Canvas是一个长方形的面积,图画或其他复杂的布局.可以放置在画布上的图形,文字,部件,或是帧 Canvas是一个长方形的面积,图画或其他复杂的 ...
- 转载:将画布(canvas)图像保存成本地图片的方法
之前我曾介绍过如何将HTML5画布(canvas)内容转变成图片形式,方法十分简单.但后来我发现只将canvas内容转变成图片输出还不够,如何能将转变后的图片保存到本地呢? 其实,这个方法也是非常简单 ...
- 面向画布(Canvas)的JavaScript库
面向画布(Canvas)的JavaScript库 总结 每个库各有特色,根据需求选择 学习要点 面向画布(Canvas)的JavaScript库 EaselJS 是一个封装了 HTML5 画布(C ...
- 学习前端第二天心得体会(初步了解HTML5的部分API以及画布Canvas)
一.HTML5部分API 1.选择器querySelector和querySelectorAll 1.1.querySelector:返回文档中匹配指定的CSS选择器的第一元素. document. ...
随机推荐
- Struts 2.x No result defined for action 异常
这是我跑struts2的第一个例子,跑的也够郁闷的,这个问题烦了我几个钟... 2011-5-10 10:10:17 com.opensymphony.xwork2.util.logging.co ...
- Python之什么是函数
我们知道圆的面积计算公式为: S = πr² 当我们知道半径r的值时,就可以根据公式计算出面积.假设我们需要计算3个不同大小的圆的面积: r1 = 12.34 r2 = 9.08 r3 = 73.1 ...
- Kafka组件监控
Kafka web console http://blog.csdn.net/hengyunabc/article/details/40431627 KafkaOffsetMonitor http:/ ...
- 使用Notepad++代替笨拙的Arduino IDE
Arduino自带的IDE 太不好用了,下面是用强大,轻量级,免费,开源,丰富插件的的Notepad++编辑器来打造Arduino开发环境 . 配置过程对新生来说可能有些繁琐,但是我尽力写的很详细了, ...
- 在windows下新建maven项目
1.拷贝settings到.m2文件下 2.修改文件 3.新建Project项目 4.转换为maven项目 config下转换 5.拷贝pom文件 6.新建目录 src/main/java src/m ...
- php导出数据到excel,防止身份证等数字字符格式变成科学计数的方法
而关于php的也有,但是大多都是用phpExcel导出的方法或者spreadsheet等类或者控件之类的导出方法,而我所在维护的系统却用很简单的方法,如下,网上很少有讲如何设置要导出数据的EXcel格 ...
- centos 下 安装zookpeer
tar xvf zookeeper-3.4.6.tar.gz cd /usr/local/zookpeer/ mkdir /var/zookpeer mkdir /var/zookpeer/data ...
- Audio Session Interruption
近期处理了一个挂断电话后,莫名手机开始播放音乐的Bug. 所以顺便在这总结一下,对于IOS的AudioSession中断的几种处理情况. 一.通过C语言的init方法配置interruptionl回调 ...
- ios - GCD简单小结
首先GCD两个名词: 队列 同步异步. 队列: 任务放到队列,队列中的任务执行方式取决于执行队列中任务的方式---同步异步. 串行队列: 任务顺序执行,可以叫阻塞队列.只有前面任务完成才执行后面的. ...
- [Android Tips] 9. framework notification layout font size
android 4.4 framework notification layout 相关字体大小 * title: notification_title_text_size: 18dp * conte ...