canvas学习(一):线条,图像变换和状态保存

一:绘制一条线段:

var canvas = document.getElementById('canvas')
var ctx = canvas.getContext('2d') //状态设置
ctx.moveTo(0,300)
ctx.lineTo(400,300)
ctx.lineWidth = 20
ctx.strokeStyle = '#ddd' ctx.stroke() //执行绘制

二:绘制三条不同颜色的线段:

var canvas = document.getElementById('canvas')
var ctx = canvas.getContext('2d') ctx.lineWidth = 20
//状态设置
ctx.beginPath()
ctx.moveTo(0,200)
ctx.lineTo(400,300)
ctx.strokeStyle = '#ddd'
ctx.stroke() //执行绘制 ctx.beginPath()
ctx.moveTo(100,300)
ctx.lineTo(500,300)
ctx.strokeStyle = '#333'
ctx.stroke() //执行绘制 ctx.beginPath()
ctx.moveTo(200,400)
ctx.lineTo(600,300)
ctx.strokeStyle = '#red'
ctx.stroke() //执行绘制

beginPath()表示进行一次新的路径绘制。

三:多边形的绘制和closePath

1:封闭箭头

var canvas = document.getElementById('canvas')
var ctx = canvas.getContext('2d') //状态设置
ctx.moveTo(20,300)
ctx.lineTo(400,300)
ctx.lineTo(400,200)
ctx.lineTo(700,350)
ctx.lineTo(400,500)
ctx.lineTo(400,400) ctx.lineTo(20,400)
ctx.lineTo(20,300)
ctx.lineWidth = 20
ctx.strokeStyle = '#ddd'
ctx.stroke() //执行绘制

  

注意:当我们使用上述方法时,线段在封闭时会出现一点点缺口。所以我们需要baginPath和closePath结合使用:

//状态设置
ctx.beginPath()
ctx.moveTo(20,300)
ctx.lineTo(400,300)
ctx.lineTo(400,200)
ctx.lineTo(700,350)
ctx.lineTo(400,500)
ctx.lineTo(400,400) ctx.lineTo(20,400)
//ctx.lineTo(20,300) //这一段可以省略。closePath会自动连接
ctx.closePath()
ctx.lineWidth = 20
ctx.strokeStyle = '#ddd'
ctx.stroke() //执行绘制

  

2:填充箭头:在上述代码后面添加

ctx.fillStyle="red"
ctx.fill()

  

注意:从这张图我们可以发现,边框的宽度变细了。那是因为填充色在边框色后面执行了,会覆盖掉边框的部分颜色。所以我们要记住:

在绘制一个需要填充的描边图案时,需要先填充,后描边

ctx.fillStyle="red"
ctx.fill() //填充
ctx.strokeStyle = '#ddd'
ctx.stroke() //描边

  

因为canvas是基于状态绘制的,所以我们可以将设置状态的代码放一起,将绘制的代码放一起:

ctx.beginPath()
ctx.moveTo(20,300)
ctx.lineTo(400,300)
ctx.lineTo(400,200)
ctx.lineTo(700,350)
ctx.lineTo(400,500)
ctx.lineTo(400,400) ctx.lineTo(20,400)
ctx.lineTo(20,300)
ctx.closePath() //状态设置
ctx.lineWidth = 20
ctx.fillStyle="red"
ctx.strokeStyle = '#ddd' //执行绘制
ctx.fill()
ctx.stroke()

  

3:定义一个绘制填充描边矩形的函数:

function draw(ele,startX,startY,width,height,lineW,fillColor,strokeColor) {
var canvas = document.getElementById(ele)
ctx = canvas.getContext('2d') ctx.beginPath();
ctx.moveTo(startX, startY);
ctx.lineTo(startX+width,startY);
ctx.lineTo(startX+width,startY+height);
ctx.lineTo(startX,startY+height);
ctx.closePath(); ctx.lineWidth = lineW;
ctx.fillStyle = fillColor ? fillColor: 'black' //默认颜色
ctx.strokeStyle = strokeColor ? strokeColor: '#ddd' //默认颜色 ctx.fill();
ctx.stroke();
} draw("myCanvas", 100, 100, 200, 300, 20)

  

  

四:矩形,覆盖和透明色

1:绘制矩形的方法:rect()

2:绘制填充矩形的方法:fillRect()

3:绘制描边矩形的方法:strokeRect()

4:设置颜色值:

颜色名,rgb, rgba,hsl, hsla,渐变色等

例如使用渐变色:

var g = ctx.createLinearGradient(0,0,180,0);  //创建渐变对象  渐变开始点和渐变结束点
g.addColorStop(0, '#A9D25B'); //添加颜色点
g.addColorStop(1, '#FA5A2D'); //添加颜色点
ctx.strokeStyle = g; //使用渐变对象

  

五:线段的其他属性

1:lineCap:设置线段两端的形状 ( butt[default],round【圆头】,square【方头】)

注意:只能用于线段的开头出和结尾处

2:lineJoin:设置线段和线段相交时的形态 ( miter[default],bevel【斜切】,round【圆头】)

            

3:miterLimit:需要一个非常尖锐的角时:

ctx.lineJoin = "miter"
ctx.miterLimit = 10 //这个数字10为默认值

  

六:画一个星星

canvas的坐标轴,X轴向右,Y轴向下!

var canvas = document.getElementById("canvas")
var ctx = canvas.getContext('2d') function drawStar(ctx,R,r,x,y,rot) {
ctx.beginPath(); for (var i = 0; i <=5; i++) {
ctx.lineTo(
Math.cos((18+i*72 - rot)/180*Math.PI) * R +x,
-Math.sin((18+i*72 - rot)/180*Math.PI) * R +y
)
ctx.lineTo(
Math.cos((54+i*72 - rot)/180*Math.PI) * r +x,
-Math.sin((54+i*72 - rot)/180*Math.PI)* r +y
)
}
ctx.closePath();
ctx.lineWidth = 10;
ctx.stroke()
} drawStar(ctx,300,150,400,400,20)

 

七:画一片星空

var canvas = document.getElementById("canvas")
var ctx = canvas.getContext('2d') ctx.fillStyle = "black"
ctx.fillRect(0,0,canvas.width,canvas.height) function drawStar(ctx,R,r,x,y,rot) {
ctx.beginPath(); for (var i = 0; i <=5; i++) {
ctx.lineTo(
     Math.cos((18+i*72 - rot)/180*Math.PI) * R +x,
-Math.sin((18+i*72 - rot)/180*Math.PI) * R +y
)
ctx.lineTo(
Math.cos((54+i*72 - rot)/180*Math.PI) * r +x,
-Math.sin((54+i*72 - rot)/180*Math.PI)* r +y
)
}
ctx.closePath();
ctx.lineWidth = 3;
ctx.lineJoin = "round"
ctx.fillStyle="#fb3"
ctx.strokeStyle="#fd5"
ctx.fill()
ctx.stroke() } for(var i=0;i<=100;i++){
var r = Math.random() *10 +10;
//var x = Math.random()*canvas.width
//var y = Math.random()*canvas.height
var x=Math.abs(Math.random()*canvas.width- 2*r)+r;
var y=Math.abs(Math.random()*canvas.height- 2*r)+r; var a = Math.random()*360
drawStar(ctx,r,r/2,x,y,a)
}

  

八:图像变换和状态保存:

translate() 方法:移动画布到相应位置

rotate() 方法:旋转当前的绘图

scale() 方法:缩放当前绘图,更大或更小 (副作用:对位置,边框大小等都会进行改变)

注意:我们在多次使用图像变化的方法时,后续的使用会在之前使用的基础上。例如:

ctx.fillStyle = "red"
ctx.translate(100,100) // 先执行操作
ctx.fillRect(0,0,400,400) // 后执行绘制 ctx.fillStyle = "green"
ctx.translate(300,300)
ctx.fillRect(0,0,400,400)

此时第二个点的左边会基于第一个点移动,所以变成了 400,,40 。此时我们需要用到状态保存save和restore

ctx.save()
ctx.fillStyle = "red"
ctx.translate(100,100)
ctx.fillRect(0,0,400,400)
ctx.restore() ctx.save()
ctx.fillStyle = "green"
ctx.translate(300,300)
ctx.fillRect(0,0,400,400)
ctx.restore()

  

  

八:深入理解图形变换:

利用transform()替换 translate(),rotate(),scale():

注意:当我们在多次使用transform()时,每次的transform()都是基于上次效果之上的。所以我们可以使用setTransform()来回到特定的效果:

ctx.save()
ctx.transform(1,0,0,1,50,100)
ctx.transform(2,0,0,1.5,50,100)
ctx.setTransform(1,0,0,1,50,100) //回到某个状态
ctx.restore()

  

canvas学习(一):线条,图像变换和状态保存的更多相关文章

  1. canvas学习-----1px线条模糊问题

    canvas有时候会出现1像素的线条模糊不清且好像更宽的情况,如下图: 这样的线条显然不是我们想要的. 这篇文章的目的就是弄清楚里面的原理,以及解决它. 大家都知道屏幕上最小的显示尺寸就是1像素,虽然 ...

  2. canvas 图片拖拽旋转之二——canvas状态保存(save和restore)

    引言 在上一篇日志“canvas 图片拖拽旋转之一”中,对坐标转换有了比较深入的了解,但是仅仅利用坐标转换实现的拖拽旋转,会改变canvas坐标系的状态,从而影响画布上其他元素的绘制.因此,这个时候需 ...

  3. Android基础部分再学习---activity的状态保存

    主要是bundle   这个參数 參考地址:http://blog.csdn.net/lonelyroamer/article/details/18715975 学习Activity的生命周期,我们知 ...

  4. canvas学习api

    1.canvas.getContext():获取渲染上下文和绘画功能: 一.绘制矩形 2.ctx.fillRect(x,y,width,height):绘制矩形: 3.ctx.strokeRect(x ...

  5. canvas学习笔记、小函数整理

    http://bbs.csdn.net/topics/391493648 canvas实例分享 2016-3-16 http://bbs.csdn.net/topics/390582151 html5 ...

  6. Canvas学习:封装Canvas绘制基本图形API

    Canvas学习:封装Canvas绘制基本图形API Canvas Canvas学习   从前面的文章中我们了解到,通过Canvas中的CanvasRenderingContext2D对象中的属性和方 ...

  7. canvas学习(一)

    Canvas 学习之路 (一) canvas 是H5 里面神一样的东西,使得只是通过html和js就能做出非常棒的游戏和画面. 因为对前端无限的爱好,更加对canvas充满好奇,将我学习canvas的 ...

  8. HTML5-Canvas 图形变换+状态保存

    1. 图形变换 canvas是基于状态绘制图形的.故此一般情况下,canvas的绘制的图形路径和状态时分离的. function drawShape(ctx){ // 绘制路径 shapePath(c ...

  9. Canvas:橡皮筋线条绘制

    Canvas:橡皮筋线条绘制 效果演示 实现要点 事件监听 [说明]: 在Canvas中检测鼠标事件是非常简单的,可以在canvas中添加一个事件监听器,当事件发生时,浏览器就会调用这个监听器. 我们 ...

随机推荐

  1. 从技术上分析八叉网www.xxxxxxxxvideos.com的自动定时发布文章功能是怎么实现的

    做网站开发的都需要用到网站广告自动定时发布功能,也就是说,编辑在网站后台把文章编写好之后,设置发布时间,点确定后发布,这时在网站前台访客是看不到这篇文章的,必须要等到文章设置的发布时间之后才能看到.八 ...

  2. 500. Keyboard Row (5月26日)

    解答 class Solution { public: vector<string> findWords(vector<string>& words) { vector ...

  3. Thinkphp5 使用composer中seeder播种机

    前因: 前几天,客户要求做一个会员问答的系统,我就按流程做了,到了需要调用数据库数据时,觉得一个个添加又有点笨~ 解决过程: 后来查了查手册,看看国外blog案例,我搞出来了个不错的方法~~~ 我的使 ...

  4. PHP实现openSug.js参数调试

    这是一款利PHP对百度搜索下拉框提示免费代码实现参数配置调试的程序源代码. 由想要对网站进行搜索下拉调试的站长朋友们进行方便.快速的效果演示,具体参考下面的PHP代码. 如何使用? 请新建一份PHP文 ...

  5. Python学习5——基本格式化输出

    整数的格式化输出 十进制.八进制.十六进制 num01 = 100 print("十进制输出:%d"%num01) print("八进制输出:%o"%num01 ...

  6. PHP变量问题,Bugku变量1

    知识点:php正则表达式,php函数,全局变量GLOBALS(注意global和$GLOBALS[]的区别) PHP函数: isset():     条件判断 get方法传递的args参数是否存在 p ...

  7. HyperLedger Fabric 1.4 单机单节点部署(10.2)

    单机单节点指在一台电脑上部署一个排序(Orderer)服务.一个组织(Org1),一个节点(Peer,属于Org1),然后运行官方案例中的example02智能合约例子,实现转财交易和查询功能.单机单 ...

  8. UPDATE_ENTITY実行

    1.クラスZCL_Z_EPM_RKT_DPC_EXTのクラスビルダ画面から.SALESORDERS_UPDATE_ENTITYメソッドを選択し.右クリックで.再定義をクリックします. 2.以下のソース ...

  9. 北京Uber优步司机奖励政策(2月7日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  10. 成都Uber优步司机奖励政策(1月10日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...