canvas练习之形状的绘制

复习

之前学习了canvas的基础知识和利用canvas画一条追线。

  • 首先canvas是一个新的h5 dom,在一些老的浏览器上可能存在不支持的风险,需要做好回退策略。

  • 利用canvas进行绘制时,首先要获取canvas的dom,然后通过getContext()接口,传入参数‘2d’来获取绘制上下文。

  • canvas背景是一个以左上角为(0,0)点的坐标轴,只有正数。

  • 利用canvas绘制一条直线时,需要有四个基于绘制上下文的接口:beginPath()开始绘画。moveTo(x,y)落笔,lineTo(x,y)将笔触拉到某一个点,closePath()结束绘制,起笔,stroke()给已经绘制出来的线条上色。

学习,用canvas绘制三角形

我们已经学习过如何绘制线条。现在,我们就利用已经学习过的内容,将三角形绘制出来。

<canvas id="mycanvas3" width="400" height="400"><canvas>
<script>
var canvas = document.getElementById('mycanvas3')
if (canvas.getContext) {
  var ctx = canvas.getContext('2d')
  ctx.beginPath()
  ctx.MoveTo(20,20)
  ctx.lineTo(60, 20)
  ctx.lineTo(40,50)
  ctx.lineTo(20,20)
  ctx.closePath()
  ctx.stroke()
}
</script>

点击查看效果

这样,我们的第一个三角形就画出来了,接下来,我们进一步认识一下closePath()。观察上面的代码可以发现,有一个点我们画了两次,一次是开始的时候,另一次是结束的时候,那么,有没有可能只画一次呢?

答案当然是有的。在上面的代码中,我们将结束的一个点删掉,既删掉ctx.lineTo(20,20),我们会发现三角形依旧画了出来,这就是closePath()的另外一个作用,会将未闭合的图形给闭合了,闭合方法是连接终点和起点。

总结:closePath()的第一个作用是结束画笔和画板的接触;第二个作用是通过连接终点和起点将图形闭合。

现在,我们画出来的三角形是由线条组成的,内部空白。如果我们需要的不是一个线条组成的三角形,而是一个被填充了的三角形,该怎么办呢?

上一节我们学习了stroke()方法,可以对线条进行上色,让线条显示出来。所以,肯定也有一个方法,可以对图形上色。这个方法就是fill()。现在,只需要将上面代码中的stroke()用fill()替换即可。快去练习一下吧。

学习,画一个矩形

通过画三角形,我们很容就能画出一个矩形来,只要掌握好每次落笔的位置就行了,如下:

<canvas id="mycanvas3" width="400" height="400"></canvas>
<script>
let canvas = document.getElementById('mycanvas3')
if (canvas.getContext) {
  let ctx = canvas.getContext('2d')
  ctx.beginPath()
  ctx.moveTo(20,20)
  ctx.lineTo(40,20)
  ctx.lineTo(40, 40)
  ctx.lineTo(20, 40)
  ctx.closePath()
  ctx.stroke()
} else {
  console.log('浏览器不支持canvas')
}
</script>

点击查看效果

练习:请将上面例子中的正方形中的填充去掉,只显示四条边。

利用已经学习过的方法,我们还可以绘制更多的图形,只要你有足够的想象力。不过在绘制矩形这一块上,我们还有更加简单的方法。下面我们来学习一下。

  1. fillRect(x,y,width, height).绘制一个有填充的矩形,x和y是这个矩形的左上角,对应上面方法中的画笔落笔处。width是矩形的宽度,height是矩形的高度。
  2. strokeRect(x,y,width,height).绘制一个无填充的矩形,参数同上。

例:

<canvas id="canvasFillRect"></canvas>
<script>
let canvas = document.getElementById('canvasFillRect')
if (canvas.getContext) {
  let ctx = canvas.getContext('2d')
  ctx.fillRect(10, 10, 30, 50)
}
</script>

绘制有填充的矩形

点击查看效果

填充无填充的矩形

<iframe height="265" style="width: 100%;" scrolling="no" title="abOwaZQ" src="https://codepen.io/zhangxiaochunxy/embed/abOwaZQ?height=265&theme-id=light&default-tab=js,result" frameborder="no" allowtransparency="true" allowfullscreen="true">
See the Pen <a href='https://codepen.io/zhangxiaochunxy/pen/abOwaZQ'>abOwaZQ</a> by 张小春Nathan
(<a href='https://codepen.io/zhangxiaochunxy'>@zhangxiaochunxy</a>) on <a href='https://codepen.io'>CodePen</a>.
</iframe>

学习。擦子

我们知道,平时绘画时,我们有时需要擦出一些内容,canvas中,也为我们提供了这样一个接口,clearRect(x,y,width, height),x和y代表的是要擦除地点的起点,width和height代表要擦除区域的宽度和高度。去亲自试一下下面的代码吧。

<canvas id="canvasFillRect"></canvas>
<script>
let canvas = document.getElementById('canvasFillRect')
if (canvas.getContext) {
  let ctx = canvas.getContext('2d')
  ctx.fillRect(10, 10, 30, 50)
  ctx.clearRect(10,10,10, 20)
}
</script>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,242评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,769评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,484评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,133评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,007评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,080评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,496评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,190评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,464评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,549评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,330评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,205评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,567评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,889评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,160评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,475评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,650评论 2 335