读书笔记 - js高级程序设计 - 第十五章 使用Canvas绘图
canvas |
具备绘图能力的2D上下文 及文本API
很多浏览器对WebGL的3D上下文支持还不够好
有时候即使浏览器支持,操作系统如果缺缺乏必要的绘图驱动程序,则浏览器即使支持了也没用
|
<canvas>
var drawing = document.getElementById("drawing");
if( drawing.getContext ){
drawing.getContext("2d");
}
|
|
toDataURL |
可以导出在canvas元素上绘制的图像
var src = drawing.toDataURL("image/png");
注意toDataURL是canvas对象的方法,不是上下文对象的方法
|
填充色 描边色 |
var context = drawing.getContext("2d")
context.strokeStyle = "red;
context.fillStyle = "#0000ff";
|
绘制矩形 |
fillRect( x,y,width,height);
strokeRect( x,y,width,height);
clearRect( x,y,width,height);
lineWidth
lineGap butt round square
lineJoin round bevel miter
|
绘制路径 |
beginPath()
arc() 画弧线
arcTo 从上一点开始绘制一条弧线
bezierCurveTo 穿过一个点 ,把两个点用弧线连起来
lineTo(x,y) 绘制直线
moveTo() 移动 不绘线
quadraticCurveTo( cx,cy,x,y ) 从上一点开发绘制一条二次曲线,到x,y为止,并且以cx cy为控制点
rect() 绘制一条矩形线路
closePath
fillStyle fill()
stokeStyle stoke()
clip()
|
isPointInPath | 确定画面上的某一点是否位于路径上 |
绘制文本 |
fillText( str,x ,y ,最大像素宽度 )
strokeText( str, x, y, 最大像素宽度 )
|
font "px Arial"
textAlign start end left right center
textBaseline top hanging middle alphabetic ideographic bottom
|
|
measureText() |
var fontSize = 100
context.font = fontSize + "px Arial";
while( context.measureText("Hello world?").width > 140 ){
fontSize -- ;
context.font = fontSize + "px Arial" ;
}
context.fillText( "hello world!", 10, 10 ) ;
context.fillText("font size is" + fontSize + "px", 10, 50 ) ;
|
绘制变换 |
rotate( angle );
scale( scaleX, saleY ) 缩放图像
translate( x, y ) 更改原点
transform() 修改变换矩阵
setTransform() 先变换矩阵重置为默认状态,然后再调用 transform()
|
绘制变化和恢复 |
save
restore
|
绘制图像 |
var image = document.images[0] ;
context.drawImage( image, x, y, width, height ) ;
还可以
context.drawImage( image, orginalX, originalY, originalWidth, originalHeight, x, y, width, height ) ;
image这个参数也可以传其它canvas
|
阴影 |
只在在绘制前为它们设置适当的值,就能自动产生阴影
var context = drawing.getContext("2d");
context.shadowOffsetX = 5 ;
context.shadowOffsetY = 5 ;
context.shadowBlur = 4 ;
context.shadowColor = "rgba(0,0,0,0.5 ) ;
|
渐变 |
由CanvasGradient实例来演示
var gradient = context.createLinearGradient( 30, 30, 70, 70 );
gradient.addColorStop( 0, "white" ) ;
gradient.addColorStop( 1, "black" ) ;
context.fillStyle = gradient ;
context.fillRect( 30, 30, 50, 50 ) ;
注意要确保坐标匹配
|
createRadialGradient()方法 放射渐变 | |
模式 |
就是重复的图像
pattern = context.createPattern( image, "repeat");
context.fillStyle = pattern ;
context.fillRect ( 10, 10, 150, 150 ) ;
注意 模式与渐变一样,都是从原点开始的,并不是要从某个位置开始绘制重复的图像.
createPattern的第一个元素,也可以是video元素 或另一个canvas元素
|
使用图像数据 |
var imageData = context.getImageData( 10, 5, 50, 50 ) ;
这里返回的对象是ImageData的实例,每个实例对象有三个属性 width height data
data属性是一个数组,保存着图像中每一个像素的数据.
可以修改它,然后回写图像数据
imageData.data = data ;
context.putImageData( imageData, 0, 0 ) ;
用上述方法可以实现灰阶过滤器
|
合成 |
globalAlpha 全局透明度
globalCompositionOperation表示后绘制的图形怎样与先绘制的图形结合
这个属性的值是字符串,可能的值如下
source-over 默认值:
source-out
source-atop
destination-over
destination-in
destination-out
destination-atop
lighter
copy
xor
|
WebGL |
针对Canvas的3D 上下文
www.learningwebgl.com 有非常棒的教程
|
类型化数组 typed arrays ,类型化数组也是数组.
ArrayBuffer的类型
var buffer = new ArrayBuffer( 20 ) ;// 分配20B
var num = buffer.byteLenght // 10 ;
var view = new DataView( buffer, 可选的字节偏移量,可选的要选择的字节数);
|
|
类型化视图 | 继承自DataView |
WebGL上下文 |
var drawing = document.getElementById("drawing");
var param = {};
param.alpha = tue ;
param.depth = true 16位
param.stencil = // 可能使用8位模板缓冲区 默认值是false
param.antialias //表示将使用默认机制执行抗锯齿操作。默认值是true
param.premultipliedAlpha //值为true, 表示组图缓冲区有预乘Alph
param.preserveDrawingBuffer //值为true, 表示在组图完成后保留绘图缓冲区
if( drawing.getContext ){
var gl = drawing.getContext("experimental-webgl");
if( gl ){
//使用WebGL
}
}
|
WebGL常量 | gl.COLOR_BUFFER_BIT |
方法命名 |
类似
gl.uniform4f() 接收4个浮点数
gl.uniform3i() 接收3个整数
gl.uniform3iv() 接收包含3个整数的数组
|
准备绘图 |
gl.clearColor(0,0,0,1);
gl.clear( gl.COLOR_BUFFER_BIT ) ;
先清理缓冲区,然后再执行其它绘图操作
|
视口与坐标 |
gl.viewport( x, y, width, height );
坐标原点在左下角
|
在视口内部 坐标原点是视口的中心 | |
缓冲区 |
gl.createBuffer();
bindBuffer
bufferData
gl.getError()
|
着色器 | shader 顶点着色器 和 片段着色器 |
编写着色器 | |
编写着色器程序 | |
为着色器传入值 | |
绘图 | 只能绘制点 线 三角 |
纹理 | gl.createTexture() 然后再将一幅图像绑定到该纹理 |
读取像素 |
readPixels()
像素信息是从帧缓冲区读取的
|
支持 |
Firefox4+ chrome Safari 5.1 都实现了WebGL API
但Safari里默认是禁用的
在使用WebGL之前,最好检测其是否得到了机算机驱动的支持,而不只是检测监测特定的浏览器版本。
WebGL是一个正在制定的发展中的规范,函数名 签名 数据类型 都有可能改变
可以说 WebGL目前只适合实验性地学习,不适合真正开发和应用.d
|
读书笔记 - js高级程序设计 - 第十五章 使用Canvas绘图的更多相关文章
- 读书笔记 - js高级程序设计 - 第十二章 DOM2和DOM3
Node类型的变化 访问元素的样式 myDiv.style.backgroundColor = "red" myDiv.style.width = "100px& ...
- 读书笔记 - js高级程序设计 - 第五章 引用类型
引用类型 和 类 不是一个概念 用typeof来检测属性是否存在 typeof args.name == "string" 需要实验 访问属性的方法 .号和[] 一般情况下要 ...
- R in action读书笔记(20)第十五章 处理缺失数据的高级方法
处理缺失数据的高级方法 15.1 处理缺失值的步骤 一个完整的处理方法通常包含以下几个步骤: (1) 识别缺失数据: (2) 检查导致数据缺失的原因: (3) 删除包含缺失值的实例或用合理的数值代替( ...
- 读书笔记 - js高级程序设计 - 第十章 DOM
文档元素 是文档的最外层元素,在Html页面中,文档元素始终都是<html>元素 在xml中,任何元素都可以是文档元素 Node类型 Node.ELEMENT_NODE 元素 Node ...
- 读书笔记 - js高级程序设计 - 第八章 BOM
BOM的核心对象是window 它表示浏览器的一个实例,在浏览器中,window对象有双重角色,它既是通过js访问浏览器窗口的一个接口,又是ECMAScript规定的Global对象,这意味着在网 ...
- JavaScript高级程序设计学习笔记第十五章--使用Canvas绘图
一.基本用法 1.要使用<canvas>元素,必须先设置其 width 和 height 属性,指定可以绘图的区域大小.能通过 CSS 为该元素添加样式,如果不添加任何样式或者不绘制任何图 ...
- 读书笔记 - js高级程序设计 - 第十一章 DOM扩展
对DOM的两个主要的扩展 Selectors API HTML5 Element Traversal 元素遍历规范 querySelector var body = document.query ...
- 读书笔记 - js高级程序设计 - 第七章 函数表达式
闭包 有权访问另一个函数作用域中的变量的函数 匿名函数 函数没有名字 少用闭包 由于闭包会携带包含它的函数的作用域,因此会比其它函数占用更多的内存.过度使用闭包可能会导致内存占用过多,我们建议读者 ...
- 读书笔记 - js高级程序设计 - 第六章 面向对象的程序设计
EcmaScript有两种属性 数据属性 和 访问器属性 数据属性有4个特性 Configurable Enumerable Writable Value 前三个值的默认值都为false ...
随机推荐
- Day10 - D - 矿场搭建 HYSBZ - 2730
煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决定在某些挖煤点设立救援出口,使得无论哪一个挖煤点坍塌之后,其他挖 ...
- 安装oracle客户端后,怎样设置电脑的环境变量?
安装配置参考: http://www.haodaima.net/art/2854001 设置环境变量(修改PATH和TNS_ADMIN环境变量): 对于NLS_LANG环境变量, 最好设置成和数据库端 ...
- Kotlin 学习 (一)
开始学习kotlin mark入门资料一篇: Kotlin入门第一课:从对比Java开始 未完待续...
- Hive的原生部署方式
一.Hive的部署 1.官方文档 https://cwiki.apache.org/confluence/display/Hive/GettingStarted 2.前提条件 需要安装JDK1.7之上 ...
- 部署 Helm【转】
本节我们将安装和部署 Helm 客户端和 Tiller 服务器. Helm 客户端 通常,我们将 Helm 客户端安装在能够执行 kubectl 命令的节点上,只需要下面一条命令: curl http ...
- 有没有比NRF51822更好的智能穿戴蓝牙方案
现在在智能穿戴领域市场不断的追求低功耗.低成本的蓝牙芯片.蓝牙芯片目前除了Dialog公司研制蓝牙芯片是最求超低功耗的但是对于其它性能上还比较满足不了其它领域的功能,另外NORDIC.TI的蓝牙芯片虽 ...
- 洛谷 P2031 脑力达人之分割字串
题目传送门 解题思路: f[i]表示到第i位可获得的最大分割次数,对于每个f[i]都可由其符合条件的前缀转移过来,条件就是当前串除了前缀的剩余字符里有所给单词,然后一看,这不是在剩余字符里找有没有所给 ...
- 需要多个参数输入时-----------------考虑使用变种的Builder模式
业务需求: 创建一个不可变的Person对象,这个Person可以拥有以下几个属性:名字.性别.年龄.职业.车.鞋子.衣服.钱.房子. 要求: 其中名字和性别是必填项,而其他选填项可以根据情况自由输入 ...
- imagenet下载及训练
imagenet 种子 迅雷打开验证集http://academictorrents.com/download/5d6d0df7ed81efd49ca99ea4737e0ae5e3a5f2e5.tor ...
- net.sf.json.JSONObject maven下载到了但是java后台一直用不了问题
需求,实体转JSON,然后用到JSONObject转JSON,但是我向下面这样引入,后台就是用不了,还是报红, <dependency> <groupId>net.sf.jso ...